/*
Theme Name:  Alvadenny
Theme URI:   https://dennykartika.com
Description: Child theme GeneratePress untuk Denny Kartika / ALVA OMEGA. Design system premium dark/gold, font Manrope. Tampilan (CSS/JS/template) ada di sini; struktur data (Portfolio, Testimoni, Klien) ditangani plugin terpisah.
Author:      Denny Kartika
Author URI:  https://dennykartika.com
Template:    generatepress
Version:     1.0.0
Text Domain: alvadenny
*/

/* ================================================================
   1. TOKENS
   ================================================================ */
:root {
  --bg:      #111111;
  --bg2:     #1a1a1a;
  --gold:    #C9A84C;
  --gold-lt: #E8C97A;
  --gold-dk: #9A7535;
  --g-gold:  linear-gradient(135deg,#E8C97A 0%,#C9A84C 55%,#9A7535 100%);
  --gold-bg: rgba(201,168,76,.06);
  --gold-bd: rgba(201,168,76,.18);
  --txt:     #F0EDE8;
  --txt2:    rgba(240,237,232,.52);
  --txt3:    rgba(240,237,232,.26);
  --bd:      rgba(255,255,255,.07);
  --surf:    rgba(255,255,255,.025);
  --ease:    cubic-bezier(.16,1,.3,1);
  --maxw:    1200px;
  --green:   #22C55E;
}

/* ================================================================
   2. BASE
   ================================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body.alvadenny,
body{
  background:var(--bg);
  color:var(--txt);
  font-family:'Manrope',system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5,h6{font-family:'Manrope',sans-serif;color:var(--txt);letter-spacing:-.02em}
a{color:var(--gold);text-decoration:none}
a:hover{color:var(--gold-lt)}
::-webkit-scrollbar{width:2px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}
::selection{background:rgba(201,168,76,.28);color:#fff}

/* container helper */
.alv-container{max-width:var(--maxw);margin:0 auto;padding-left:2rem;padding-right:2rem}
@media(max-width:768px){.alv-container{padding-left:1.25rem;padding-right:1.25rem}}

/* ================================================================
   3. KEYFRAMES
   ================================================================ */
@keyframes fadeUp    {from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
@keyframes fadeIn    {from{opacity:0}to{opacity:1}}
@keyframes slideDown {from{opacity:0;transform:translateY(-28px)}to{opacity:1;transform:none}}
@keyframes shimmer   {from{transform:translateX(-100%)}to{transform:translateX(110%)}}
@keyframes blob1     {0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-44px,32px) scale(1.06)}66%{transform:translate(22px,-18px) scale(.95)}}
@keyframes blob2     {0%,100%{transform:translate(0,0) scale(1)}40%{transform:translate(30px,-44px) scale(1.08)}70%{transform:translate(-16px,22px) scale(.94)}}
@keyframes floatY    {0%,100%{transform:translateY(0)}50%{transform:translateY(14px)}}
@keyframes spin      {to{transform:rotate(360deg)}}
@keyframes pulseRing {0%{box-shadow:0 0 0 0 rgba(201,168,76,.4)}70%{box-shadow:0 0 0 9px rgba(201,168,76,0)}100%{box-shadow:0 0 0 0 rgba(201,168,76,0)}}

/* ================================================================
   4. AMBIENT BACKGROUND  (markup di-inject lewat functions.php)
   ================================================================ */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9997;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='256' height='256'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.028'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.grid-bg{position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.013) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.013) 1px,transparent 1px);
  background-size:80px 80px;}
.blob{position:fixed;border-radius:50%;pointer-events:none;z-index:0;filter:blur(90px)}
.blob-1{width:640px;height:640px;top:-120px;right:-80px;background:radial-gradient(circle,rgba(201,168,76,.07) 0%,transparent 70%);animation:blob1 20s ease-in-out infinite}
.blob-2{width:520px;height:520px;bottom:15%;left:-100px;background:radial-gradient(circle,rgba(201,168,76,.05) 0%,transparent 70%);animation:blob2 24s ease-in-out infinite}

/* keep page content above background layers */
.site,#page,.site-content{position:relative;z-index:1}

/* ================================================================
   5. HELPERS / TYPO
   ================================================================ */
.g-gold{background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.s-label{display:inline-flex;align-items:center;gap:10px;margin-bottom:1.2rem}
.s-label::before{content:'';display:block;width:24px;height:1px;background:var(--gold)}
.s-label span{font-size:.67rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:700}
.sec-h{font-size:clamp(1.75rem,2.9vw,2.75rem);font-weight:800;letter-spacing:-.03em;color:var(--txt);line-height:1.12}
.sec-sub{font-size:1.02rem;line-height:1.8;color:var(--txt2);max-width:600px;margin-top:1.1rem}

/* ================================================================
   6. BUTTONS
   ================================================================ */
.btn-gold{
  position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:8px;
  padding:.9rem 2rem;border-radius:100px;border:none;
  background:var(--g-gold);color:#080808;font-weight:700;
  font-size:.86rem;letter-spacing:.04em;font-family:'Manrope',sans-serif;
  cursor:pointer;white-space:nowrap;text-decoration:none;
  transition:transform .2s var(--ease),box-shadow .3s;
}
.btn-gold:hover{transform:scale(1.04);box-shadow:0 8px 32px rgba(201,168,76,.22);color:#080808}
.btn-gold:active{transform:scale(.97)}
.btn-gold::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transform:translateX(-100%);transition:transform 0s}
.btn-gold:hover::after{animation:shimmer .55s ease forwards}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:.9rem 2rem;border-radius:100px;
  border:1px solid rgba(201,168,76,.28);background:transparent;color:var(--gold);
  font-weight:600;font-size:.86rem;letter-spacing:.04em;font-family:'Manrope',sans-serif;
  cursor:pointer;white-space:nowrap;text-decoration:none;
  transition:border-color .25s,background .25s,transform .2s var(--ease);
}
.btn-ghost:hover{border-color:rgba(201,168,76,.65);background:rgba(201,168,76,.07);transform:scale(1.03);color:var(--gold-lt)}

/* ================================================================
   7. SCROLL REVEAL  (di-toggle oleh assets/js/main.js)
   ================================================================ */
.fade-up{opacity:0;transform:translateY(26px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.fade-up.in-view{opacity:1;transform:none}
.fade-right{opacity:0;transform:translateX(-26px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.fade-right.in-view{opacity:1;transform:none}
.fade-left{opacity:0;transform:translateX(26px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.fade-left.in-view{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .fade-up,.fade-right,.fade-left{opacity:1!important;transform:none!important;transition:none}
  .blob{animation:none}
}

/* ================================================================
   8. KEYFRAMES TAMBAHAN (dipakai komponen)
   ================================================================ */
@keyframes fadeRight    {from{opacity:0;transform:translateX(44px)}to{opacity:1;transform:none}}
@keyframes bounce       {0%,100%{transform:translateY(0)}50%{transform:translateY(9px)}}
@keyframes pulseGreen   {0%{box-shadow:0 0 0 0 rgba(34,197,94,.45)}70%{box-shadow:0 0 0 9px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
@keyframes tickerScroll {from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes lcSlide      {from{transform:translateX(-50%)}to{transform:translateX(0)}}
@keyframes testiScroll  {from{transform:translateY(0)}to{transform:translateY(calc(-50% - .625rem))}}

/* divider tipis emas */
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.18),transparent);margin:5.5rem 0}

/* ================================================================
   9. NAV
   ================================================================ */
#site-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:10px 24px;animation:slideDown .9s var(--ease) .3s both}
.nav-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:11px 18px 11px 14px;border-radius:100px;transition:background .4s ease;border:1px solid rgba(255,255,255,.07)}
.nav-inner.scrolled{background:rgba(17,17,17,.9);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px)}
.nav-inner.top{background:rgba(17,17,17,.45);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px)}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo-mark{width:36px;height:36px;border-radius:10px;background:var(--g-gold);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;color:#080808;flex-shrink:0}
.nav-logo-name{font-size:15px;font-weight:600;color:var(--txt);letter-spacing:.01em}
.nav-links{display:flex;gap:4px}
.nav-links .nav-menu{display:flex;gap:4px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links .nav-menu li{position:relative}
.nav-link{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border-radius:100px;font-size:.875rem;font-weight:500;color:rgba(240,237,232,.6);text-decoration:none;transition:color .15s,background .15s}
.nav-link:hover{color:var(--txt);background:rgba(255,255,255,.07)}
/* tanda dropdown pada parent */
.nav-menu .menu-item-has-children > a.nav-link::after{content:'';width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-1px);opacity:.6;transition:transform .25s}
.nav-menu .menu-item-has-children:hover > a.nav-link::after{transform:rotate(225deg)}
/* dropdown */
.nav-menu .sub-menu{list-style:none;margin:0;padding:6px;position:absolute;top:100%;left:0;min-width:210px;background:rgba(17,17,17,.97);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid var(--bd);border-radius:14px;box-shadow:0 18px 44px rgba(0,0,0,.45);display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s;z-index:130}
.nav-menu li:hover > .sub-menu{opacity:1;visibility:visible;transform:none}
.nav-menu .sub-menu .nav-link{display:block;white-space:nowrap;color:rgba(240,237,232,.62)}
.nav-menu .sub-menu .nav-link:hover{color:var(--txt);background:rgba(201,168,76,.1)}
.nav-hamburger{display:none;padding:8px;background:none;border:none;color:var(--gold);transition:transform .2s;cursor:pointer}
.nav-hamburger:hover{transform:scale(1.1)}
.nav-mobile{max-width:var(--maxw);margin:8px auto 0;border-radius:1.5rem;overflow:hidden;background:rgba(17,17,17,.96);backdrop-filter:blur(28px);border:1px solid var(--bd);max-height:0;transition:max-height .35s var(--ease),opacity .3s ease;opacity:0}
.nav-mobile.open{max-height:420px;opacity:1}
.nav-mobile-inner{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}
.nav-mobile-link{padding:.7rem 0;font-size:1.05rem;font-weight:500;color:rgba(240,237,232,.7);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.05)}
@media(max-width:768px){.nav-links,.nav-cta-desk{display:none!important}.nav-hamburger{display:block}}

/* ================================================================
   10. HERO
   ================================================================ */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:visible;padding-top:80px}
.hero-grid{max-width:var(--maxw);margin:0 auto;padding:3.5rem 2rem;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero-grid>div{min-width:0}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}.hero-portrait-wrap{display:none}}
.hero-rule-top{position:absolute;top:110px;left:0;width:50%;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.1));pointer-events:none}
.hero-rule-bot{position:absolute;bottom:0;right:0;width:35%;height:1px;background:linear-gradient(270deg,transparent,rgba(201,168,76,.08));pointer-events:none}
/* entrance */
.hero-eyebrow{animation:fadeUp .7s var(--ease) .55s both}
.hero-title  {animation:fadeUp .9s var(--ease) .75s both}
.hero-sub    {animation:fadeUp .7s var(--ease) 1.05s both}
.hero-ctas   {display:flex;gap:12px;flex-wrap:wrap;animation:fadeUp .7s var(--ease) 1.25s both}
.hero-stats  {animation:fadeIn .7s ease 1.65s both}
.hero-portrait-wrap{animation:fadeRight 1s var(--ease) .7s both}
/* eyebrow pill (pengganti inline) */
.hero-eyebrow-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 16px 6px 8px;border-radius:100px;background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.16);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.hero-eyebrow-dot{width:6px;height:6px;border-radius:50%;background:#C9A84C;flex-shrink:0;box-shadow:0 0 7px rgba(201,168,76,.7);animation:pulseRing 2s ease infinite}
.hero-eyebrow-text{font-size:11px;letter-spacing:.16em;color:#C9A84C;font-weight:600;text-transform:uppercase}
/* title + sub (pengganti inline) */
.hero-title h1{font-size:clamp(2.6rem,4.2vw,4.4rem);font-weight:900;line-height:1.04;letter-spacing:-.025em;color:var(--txt);margin-bottom:1.5rem}
.hero-sub p{font-size:1.025rem;line-height:1.78;color:rgba(240,237,232,.5);max-width:430px;margin-bottom:2.25rem}
/* portrait */
.hero-portrait-outer{position:relative;width:100%}
.hero-portrait-inner{position:relative;z-index:1;width:100%}
.hero-portrait-png{position:relative;z-index:1;overflow:visible}
.hero-portrait-png img{width:100%;height:auto;display:block;-webkit-mask-image:linear-gradient(to bottom,black 0%,black 52%,transparent 100%);mask-image:linear-gradient(to bottom,black 0%,black 52%,transparent 100%);filter:drop-shadow(0 0 80px rgba(201,168,76,.07)) drop-shadow(0 24px 60px rgba(0,0,0,.4))}
.hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;height:90%;border-radius:50%;background:radial-gradient(ellipse,rgba(201,168,76,.09) 0%,transparent 68%);pointer-events:none;z-index:0}
.hero-glow-2{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120%;height:115%;border-radius:50%;background:radial-gradient(ellipse,rgba(201,168,76,.04) 0%,transparent 65%);pointer-events:none;z-index:0}
/* glass badges */
.hero-badge{position:absolute;bottom:72px;left:-32px;z-index:10;background:rgba(17,17,17,.82);backdrop-filter:blur(28px) saturate(1.5);-webkit-backdrop-filter:blur(28px) saturate(1.5);border:1px solid rgba(255,255,255,.11);border-radius:1.4rem;padding:14px 18px;min-width:192px;box-shadow:0 8px 40px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.07);animation:fadeIn .7s ease 1.7s both;transition:transform .3s var(--ease),box-shadow .3s}
.hero-badge:hover{transform:scale(1.04) translateY(-2px);box-shadow:0 16px 48px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.09)}
.hero-badge-row{display:flex;align-items:center;gap:7px;margin-bottom:5px}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:#22C55E;flex-shrink:0;box-shadow:0 0 8px rgba(34,197,94,.9);animation:pulseGreen 2s ease infinite}
.hero-badge-available{font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#22C55E}
.hero-badge-title{font-size:14px;font-weight:700;color:var(--txt);letter-spacing:-.01em}
.hero-badge-note{font-size:11px;color:rgba(240,237,232,.38);margin-top:4px;line-height:1.4}
.hero-aivo{position:absolute;top:24px;right:8px;z-index:10;background:rgba(201,168,76,.07);backdrop-filter:blur(28px) saturate(1.4);-webkit-backdrop-filter:blur(28px) saturate(1.4);border:1px solid rgba(201,168,76,.28);border-radius:1.1rem;padding:10px 16px;box-shadow:0 6px 28px rgba(0,0,0,.35),inset 0 1px 0 rgba(201,168,76,.12),0 0 0 1px rgba(201,168,76,.04);animation:fadeIn .6s ease 2s both;transition:transform .3s var(--ease)}
.hero-aivo:hover{transform:scale(1.05) translateY(-2px)}
.hero-aivo-label{font-size:10px;font-weight:700;color:#C9A84C;letter-spacing:.14em;text-transform:uppercase;margin-bottom:3px}
.hero-aivo-val{font-size:12px;color:rgba(240,237,232,.5);font-weight:500}
.hero-acc-line{position:absolute;top:14%;right:-10px;width:2px;height:26%;background:linear-gradient(to bottom,var(--gold),transparent);border-radius:2px}
.hero-trust-card{position:absolute;top:38%;right:8px;z-index:10;background:rgba(10,10,10,.76);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border:1px solid rgba(255,255,255,.09);box-shadow:0 8px 28px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.05);border-radius:1.1rem;padding:13px 18px;min-width:126px;animation:fadeIn .6s ease 2.1s both;transition:transform .3s var(--ease)}
.hero-trust-card:hover{transform:scale(1.04) translateY(-2px)}
.hero-trust-num{font-size:1.5rem;font-weight:900;line-height:1;background:linear-gradient(135deg,#E8C97A,#C9A84C);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-trust-lbl{font-size:.68rem;color:rgba(240,237,232,.4);margin-top:5px;letter-spacing:.05em;line-height:1.3}
/* logo ticker */
.hero-ticker-wrap{position:relative;overflow:hidden;margin-top:3rem}
.hero-ticker-label{font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;color:var(--txt3);margin-bottom:.9rem}
.hero-ticker-mask{position:relative;overflow:hidden}
.hero-ticker-mask::before,.hero-ticker-mask::after{content:'';position:absolute;top:0;bottom:0;z-index:2;pointer-events:none;width:60px}
.hero-ticker-mask::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.hero-ticker-mask::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.hero-ticker-inner{display:flex;align-items:center;animation:tickerScroll 28s linear infinite;width:max-content}
.hero-ticker-inner:hover{animation-play-state:paused}
.ticker-logo{display:flex;align-items:center;gap:.5rem;padding:0 2rem;white-space:nowrap;border-right:1px solid rgba(255,255,255,.05)}
.ticker-logo-icon{font-size:.9rem;line-height:1;filter:grayscale(1);opacity:.6}
.ticker-logo-name{font-weight:700;font-size:.75rem;letter-spacing:.07em;text-transform:uppercase;color:rgba(240,237,232,.22);transition:color .2s}
.ticker-logo:hover .ticker-logo-name{color:rgba(240,237,232,.45)}
.ticker-sep{width:4px;height:4px;border-radius:50%;background:rgba(201,168,76,.22);flex-shrink:0}
/* scroll indicator */
.scroll-ind{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;animation:fadeIn .8s ease 2.2s both}
.scroll-ind-text{font-size:9px;letter-spacing:.22em;color:rgba(201,168,76,.4);text-transform:uppercase}
.scroll-ind-line{width:1px;height:36px;background:linear-gradient(to bottom,rgba(201,168,76,.4),transparent);animation:bounce 2.2s ease-in-out infinite}

/* ================================================================
   11. CREDBAR
   ================================================================ */
#credbar{padding:0 2rem 5.5rem}
.credbar-inner{max-width:var(--maxw);margin:0 auto;background:var(--gold-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(201,168,76,.13);border-radius:1.5rem;padding:2.25rem 2.75rem;display:flex;flex-wrap:wrap;gap:2rem;align-items:center;justify-content:space-between}
.credbar-stat{text-align:center;flex:1 1 100px}
.credbar-num{font-size:2.4rem;font-weight:700;line-height:1;background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.credbar-lbl{font-size:.76rem;color:var(--txt2);margin-top:5px;letter-spacing:.05em}
.credbar-sep{width:1px;height:56px;background:rgba(255,255,255,.06)}
.credbar-inds{flex:2 1 260px}
.credbar-inds-label{font-size:.64rem;color:rgba(201,168,76,.58);text-transform:uppercase;letter-spacing:.18em;margin-bottom:10px}
.credbar-pills{display:flex;flex-wrap:wrap;gap:8px}
.pill{padding:4px 13px;border-radius:100px;font-size:.78rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:var(--txt2);font-weight:500}
@media(max-width:768px){.credbar-sep{display:none}.credbar-inner{padding:1.75rem}}

/* ================================================================
   12. SERVICES
   ================================================================ */
#services{padding:0 2rem 7rem}
.services-inner{max-width:var(--maxw);margin:0 auto}
.services-head{margin-bottom:3.25rem}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}
.svc-card{display:block;text-decoration:none;color:inherit;position:relative;overflow:hidden;cursor:pointer;background:var(--surf);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--bd);border-radius:1.5rem;padding:2rem;transition:background .3s,border-color .3s,transform .3s var(--ease),box-shadow .3s}
.svc-card:hover{background:rgba(201,168,76,.04);border-color:rgba(201,168,76,.22);transform:translateY(-7px);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.svc-topline{position:absolute;top:0;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,#C9A84C,transparent);transform:scaleX(0);transform-origin:center;transition:transform .7s var(--ease)}
.svc-card.in-view .svc-topline{transform:scaleX(1)}
.svc-icon{width:46px;height:46px;border-radius:.85rem;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.18);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:1.4rem;flex-shrink:0;transition:background .3s}
.svc-card:hover .svc-icon{background:rgba(201,168,76,.14)}
.svc-title{font-size:1.15rem;font-weight:700;color:var(--txt);margin-bottom:.7rem}
.svc-desc{font-size:.875rem;line-height:1.72;color:var(--txt2);margin-bottom:1.5rem}
.svc-footer{display:flex;align-items:center;justify-content:space-between}
.svc-tag{padding:3px 11px;border-radius:100px;font-size:.68rem;font-weight:600;background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.18);color:var(--gold);letter-spacing:.06em}
.svc-arr{color:var(--gold);font-size:1.1rem;transition:transform .2s var(--ease)}
.svc-card:hover .svc-arr{transform:translateX(5px)}
.svc-glow{position:absolute;bottom:-30px;right:-30px;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.1) 0%,transparent 70%);pointer-events:none;opacity:0;transform:scale(1);transition:opacity .4s,transform .4s}
.svc-card:hover .svc-glow{opacity:1;transform:scale(1.7)}

/* ================================================================
   13. ABOUT
   ================================================================ */
#about{padding:0 2rem 7rem}
.about-inner{max-width:var(--maxw);margin:0 auto}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
@media(max-width:900px){.about-grid{grid-template-columns:1fr}}
.about-img-wrap{position:relative}
.about-img-frame{border-radius:1.75rem;overflow:hidden;aspect-ratio:4/5;max-height:555px;border:1px solid rgba(201,168,76,.13);position:relative}
.about-img-frame img{width:100%;height:100%;object-fit:cover;filter:grayscale(12%) contrast(1.04);display:block}
.about-img-fade{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,17,17,.65) 0%,transparent 55%);pointer-events:none}
.about-stat{position:absolute;bottom:-18px;right:-18px;background:rgba(17,17,17,.92);backdrop-filter:blur(24px);border:1px solid rgba(201,168,76,.22);border-radius:1.1rem;padding:1.1rem 1.4rem;transition:transform .25s var(--ease)}
.about-stat:hover{transform:scale(1.04)}
.about-stat-num{font-size:2rem;font-weight:700;line-height:1;background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.about-stat-label{font-size:.75rem;color:var(--txt3);margin-top:4px;line-height:1.4}
.about-acc{position:absolute;top:10%;left:-10px;width:2px;height:22%;background:linear-gradient(to bottom,#C9A84C,transparent);border-radius:2px}
.about-text p{font-size:1rem;line-height:1.78;color:var(--txt2);margin-bottom:1.1rem}
.about-text strong{color:var(--gold);font-weight:600}
.about-link{display:inline-flex;align-items:center;gap:7px;margin-top:2rem;color:var(--gold);font-size:.88rem;font-weight:600;text-decoration:none;letter-spacing:.04em;transition:gap .2s var(--ease)}
.about-link:hover{gap:14px}

/* ================================================================
   14. WHY
   ================================================================ */
#why{padding:0 2rem 7rem}
.why-inner{max-width:var(--maxw);margin:0 auto}
.why-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:4.5rem;align-items:start}
.why-head{margin-bottom:2.75rem}
.why-head-sub{font-size:.95rem;color:var(--txt2);margin-top:.9rem;max-width:440px;line-height:1.72}
.why-rows{display:flex;flex-direction:column;border-top:1px solid rgba(255,255,255,.06)}
.why-media{position:sticky;top:120px}
.why-placeholder{position:relative;width:100%;aspect-ratio:4/5;border-radius:1.5rem;background:transparent;border:1px dashed rgba(201,168,76,.28);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;overflow:hidden}
.why-placeholder::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 50% 40%,rgba(201,168,76,.06),transparent 70%)}
.why-ph-icon{font-size:2.4rem;opacity:.4;position:relative;z-index:1}
.why-ph-label{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--txt3);position:relative;z-index:1}
@media(max-width:880px){.why-grid{grid-template-columns:1fr;gap:2.5rem}.why-media{display:none}}
.why-row{position:relative;overflow:hidden;display:grid;grid-template-columns:88px 1fr auto;align-items:center;gap:2rem;padding:2.25rem 0;border-bottom:1px solid rgba(255,255,255,.055);cursor:default}
.why-row::before{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(201,168,76,.07) 0%,rgba(201,168,76,.02) 55%,transparent 100%);transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease)}
.why-row:hover::before{transform:scaleX(1)}
.why-row-line{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,rgba(201,168,76,.45),rgba(201,168,76,.12),transparent 75%);transform:scaleX(0);transform-origin:left;transition:transform .85s var(--ease)}
.why-row.in-view .why-row-line{transform:scaleX(1)}
.why-row-num{font-size:3.75rem;font-weight:900;color:rgba(201,168,76,.09);line-height:1;letter-spacing:-.04em;transition:color .35s,transform .35s var(--ease);position:relative;z-index:1;user-select:none}
.why-row:hover .why-row-num{color:rgba(201,168,76,.3);transform:scale(1.04)}
.why-row-body{position:relative;z-index:1}
.why-row-title{font-size:1.05rem;font-weight:700;color:var(--txt);line-height:1.3;margin-bottom:.5rem}
.why-row-desc{font-size:.875rem;line-height:1.72;color:var(--txt2)}
.why-row-right{display:flex;align-items:center;gap:14px;flex-shrink:0;position:relative;z-index:1}
.why-row-icon{width:44px;height:44px;border-radius:12px;background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.13);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0;transition:background .3s,border-color .3s,transform .3s var(--ease),box-shadow .3s}
.why-row:hover .why-row-icon{background:rgba(201,168,76,.13);border-color:rgba(201,168,76,.38);transform:scale(1.1) rotate(-4deg);box-shadow:0 4px 22px rgba(201,168,76,.16)}
.why-row-arr{font-size:1.1rem;color:rgba(201,168,76,.28);transition:color .3s,transform .3s var(--ease)}
.why-row:hover .why-row-arr{color:var(--gold);transform:translateX(7px)}
@media(max-width:768px){.why-row{grid-template-columns:60px 1fr;gap:1rem}.why-row-right{display:none}.why-row-num{font-size:2.75rem}}

/* ================================================================
   15. TESTIMONIALS (kolom marquee)
   ================================================================ */
#testimonials{padding:0 2rem 7rem}
.testi-inner{max-width:var(--maxw);margin:0 auto}
.testi-head{margin-bottom:3.5rem}
.testi-cols{display:flex;gap:1.25rem;justify-content:center;max-height:720px;overflow:hidden;-webkit-mask-image:linear-gradient(to bottom,transparent,black 25%,black 75%,transparent);mask-image:linear-gradient(to bottom,transparent,black 25%,black 75%,transparent)}
.testi-col{flex:1 1 0;max-width:380px}
.testi-col-inner{display:flex;flex-direction:column;gap:1.25rem;animation:testiScroll var(--dur,18s) linear infinite}
.testi-col-inner:hover{animation-play-state:paused}
.testi-card{position:relative;overflow:hidden;background:rgba(255,255,255,.025);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,.08);border-radius:1.75rem;padding:2.1rem}
.testi-card-topline{position:absolute;top:0;left:12%;right:12%;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.2),transparent)}
.testi-quote-mark{font-size:3.2rem;line-height:1;color:rgba(201,168,76,.18);font-family:Georgia,serif;margin-bottom:.4rem;margin-top:-.3rem}
.testi-quote{font-size:.92rem;line-height:1.7;color:rgba(240,237,232,.78);margin-bottom:1.4rem}
.testi-meta{display:flex;align-items:center;gap:12px}
.testi-avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:var(--g-gold);display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700;color:#080808}
.testi-name{font-size:.88rem;font-weight:700;color:var(--txt)}
.testi-role{font-size:.74rem;color:var(--txt3);margin-top:2px}
.testi-industry{margin-left:auto;padding:3px 11px;border-radius:100px;font-size:.64rem;font-weight:600;background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.18);color:var(--gold);white-space:nowrap}
@media(max-width:1024px){.testi-col-3{display:none}}
@media(max-width:768px){.testi-col-2{display:none}}

/* ================================================================
   16. INSIGHT
   ================================================================ */
#insight{padding:0 2rem 7rem}
.insight-inner{max-width:var(--maxw);margin:0 auto}
.insight-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:3.5rem}
.insight-all{display:inline-flex;align-items:center;gap:6px;color:var(--gold);font-size:.85rem;font-weight:600;text-decoration:none;letter-spacing:.04em;transition:gap .2s var(--ease)}
.insight-all:hover{gap:12px}
.insight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.25rem}
.ins-card-link{display:block;text-decoration:none;color:inherit}
.ins-card{background:var(--surf);border:1px solid var(--bd);border-radius:1.5rem;overflow:hidden;cursor:pointer;position:relative;transition:transform .3s var(--ease),box-shadow .3s}
.ins-card:hover{transform:translateY(-7px);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.ins-thumb{aspect-ratio:16/9;overflow:hidden;position:relative;background:rgba(255,255,255,.03)}
.ins-thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(16%) brightness(.72);display:block;transition:transform .5s var(--ease)}
.ins-card:hover .ins-thumb img{transform:scale(1.06)}
.ins-thumb-fade{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 20%,rgba(17,17,17,.45) 100%);pointer-events:none}
.ins-tag{position:absolute;top:12px;left:12px;padding:3px 11px;border-radius:100px;font-size:.66rem;font-weight:600;background:rgba(201,168,76,.14);backdrop-filter:blur(10px);border:1px solid rgba(201,168,76,.26);color:var(--gold)}
.ins-body{padding:1.4rem}
.ins-title{font-size:.97rem;font-weight:600;color:var(--txt);line-height:1.5;margin-bottom:1rem}
.ins-meta{display:flex;justify-content:space-between;align-items:center}
.ins-date{font-size:.72rem;color:var(--txt3)}
.ins-arr{color:var(--gold);font-size:.9rem}
.ins-bottomline{position:absolute;bottom:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transform-origin:center;transition:transform .4s var(--ease)}
.ins-card:hover .ins-bottomline{transform:scaleX(1)}

/* ================================================================
   17. LOGO CLOUD (opsional — tambahkan markupnya bila perlu)
   ================================================================ */
#logocloud{padding:5.5rem 2rem 7rem}
.lc-inner{max-width:var(--maxw);margin:0 auto}
.lc-wrap{position:relative;max-width:760px;margin:0 auto;text-align:center}
.lc-glow{position:absolute;top:42%;left:50%;transform:translate(-50%,-50%);width:90%;height:220px;border-radius:50%;background:radial-gradient(ellipse,rgba(201,168,76,.08),transparent 70%);pointer-events:none;z-index:0}
.lc-head{position:relative;z-index:1;font-size:clamp(1.45rem,2.5vw,2.1rem);line-height:1.3;letter-spacing:-.015em}
.lc-head .muted{color:var(--txt);font-weight:400}
.lc-head .strong{color:var(--txt);font-weight:700}
.lc-rule{position:relative;z-index:1;height:1px;margin:2.4rem 0;background:linear-gradient(to right,transparent,rgba(201,168,76,.3),transparent)}
.lc-slider{position:relative;z-index:1;overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent,black 16%,black 84%,transparent);mask-image:linear-gradient(to right,transparent,black 16%,black 84%,transparent)}
.lc-track{display:flex;width:max-content;align-items:center;gap:2.6rem;animation:lcSlide 50s linear infinite}
.lc-track:hover{animation-play-state:paused}
.lc-logo{display:inline-flex;align-items:center;gap:9px;opacity:.4;filter:grayscale(1);transition:opacity .3s,filter .3s}
.lc-logo:hover{opacity:.95;filter:grayscale(0)}
.lc-logo-icon{font-size:1.15rem;line-height:1}
.lc-logo-name{font-weight:700;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;color:var(--txt);white-space:nowrap}

/* ================================================================
   18. CTA
   ================================================================ */
#cta-close{padding:0 2rem 7rem}
.cta-inner{max-width:var(--maxw);margin:0 auto}
.cta-label-wrap{display:flex;justify-content:center;margin-bottom:1.25rem}
.cta-hero{position:relative;overflow:hidden;border-radius:2rem;min-height:560px;display:flex;align-items:center;justify-content:center;background:#030303;border:1px solid rgba(255,255,255,.05)}
.cta-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(135deg,rgba(201,168,76,.08),transparent 45%,rgba(232,201,122,.07))}
.cta-hero::after{content:'';position:absolute;inset:0;pointer-events:none;z-index:5;background:linear-gradient(to bottom,rgba(3,3,3,.88) 0%,transparent 22%,transparent 78%,rgba(3,3,3,.92) 100%)}
.cta-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1}
.cta-shape{position:absolute;opacity:0;animation:fadeIn 1.6s var(--ease) both,floatY 13s ease-in-out infinite}
.cta-shape .bar{width:100%;height:100%;border-radius:100px;border:2px solid rgba(255,255,255,.12);box-shadow:0 8px 32px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,255,255,.07);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);-webkit-mask-image:radial-gradient(120% 120% at 30% 30%,black 55%,transparent);mask-image:radial-gradient(120% 120% at 30% 30%,black 55%,transparent)}
.cta-shape-1{left:-8%;top:14%;width:min(600px,52vw);height:130px;animation-delay:.3s,.3s}
.cta-shape-1 .bar{transform:rotate(12deg);background:linear-gradient(to right,rgba(201,168,76,.22),rgba(201,168,76,.02))}
.cta-shape-2{right:-6%;top:66%;width:min(480px,44vw);height:115px;animation-delay:.5s,.7s}
.cta-shape-2 .bar{transform:rotate(-15deg);background:linear-gradient(to right,rgba(232,201,122,.2),rgba(232,201,122,.02))}
.cta-shape-3{left:5%;bottom:7%;width:min(300px,30vw);height:80px;animation-delay:.4s,1.1s}
.cta-shape-3 .bar{transform:rotate(-8deg);background:linear-gradient(to right,rgba(154,117,53,.24),rgba(154,117,53,.02))}
.cta-shape-4{right:13%;top:11%;width:min(220px,24vw);height:62px;animation-delay:.6s,.5s}
.cta-shape-4 .bar{transform:rotate(20deg);background:linear-gradient(to right,rgba(255,255,255,.14),rgba(255,255,255,.01))}
.cta-shape-5{left:18%;top:6%;width:min(160px,18vw);height:46px;animation-delay:.7s,1.4s}
.cta-shape-5 .bar{transform:rotate(-22deg);background:linear-gradient(to right,rgba(201,168,76,.18),rgba(201,168,76,.02))}
.cta-hero-content{position:relative;z-index:10;text-align:center;padding:4rem 2rem;max-width:680px}
.cta-h{font-size:clamp(2.2rem,4.5vw,4rem);font-weight:900;letter-spacing:-.025em;color:var(--txt);margin-bottom:1rem}
.cta-sub{font-size:1.05rem;color:var(--txt2);max-width:460px;margin:0 auto 2.75rem;line-height:1.75}
.cta-btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.cta-wp-icon{display:flex;align-items:center;gap:8px}
@media(max-width:768px){.cta-hero{min-height:470px}.cta-shape-1,.cta-shape-5{display:none}}

/* ================================================================
   19. FOOTER
   ================================================================ */
footer{border-top:1px solid rgba(255,255,255,.05);padding:2.5rem 2rem}
.footer-inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.5rem}
.footer-logo{display:flex;align-items:center;gap:10px}
.footer-logo-mark{width:30px;height:30px;border-radius:8px;background:var(--g-gold);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;color:#080808}
.footer-name{font-size:.88rem;font-weight:600;color:var(--txt)}
.footer-tagline{font-size:.72rem;color:var(--txt3);margin-top:2px}
.footer-nav{display:flex;gap:1.75rem;flex-wrap:wrap}
.footer-link{font-size:.8rem;color:var(--txt3);text-decoration:none;transition:color .2s}
.footer-link:hover{color:rgba(201,168,76,.8)}
.footer-cr{font-size:.72rem;color:rgba(240,237,232,.2)}

/* ================================================================
   20. PAGE HERO (halaman dalam: Layanan, dll) — SHARED
   ================================================================ */
#page-hero{position:relative;padding:150px 2rem 90px;overflow:hidden;min-height:min(82vh,720px);display:flex;align-items:center}
.page-hero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2;width:100%}
.page-hero-eyebrow{animation:fadeUp .6s var(--ease) .3s both}
.page-hero-headrow{display:flex;flex-wrap:wrap;align-items:baseline;gap:0 1.4rem;margin-bottom:1.75rem;animation:fadeUp .8s var(--ease) .45s both}
.page-hero-h{font-size:clamp(3.5rem,7vw,7.5rem);font-weight:900;letter-spacing:-.04em;color:var(--txt);line-height:.95}
.page-hero-scramble{font-family:'Manrope',monospace;font-size:clamp(2.4rem,5vw,5.3rem);font-weight:900;letter-spacing:-.02em;line-height:1;background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}
.page-hero-scramble .dud{-webkit-text-fill-color:var(--gold-lt);color:var(--gold-lt);opacity:.78}
.page-hero-sub{font-size:1.1rem;line-height:1.8;color:var(--txt2);max-width:600px;animation:fadeUp .7s var(--ease) .65s both}
.page-hero-rule{position:absolute;bottom:0;left:0;right:0;height:1px;z-index:2;background:linear-gradient(90deg,transparent 0%,rgba(201,168,76,.18) 50%,transparent 100%)}
/* raining letters (di-generate main.js) */
.rain-layer{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.rain-layer::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 30% 50%,rgba(17,17,17,.55) 0%,rgba(17,17,17,.86) 70%);pointer-events:none}
.rain-char{position:absolute;font-family:'Manrope',monospace;line-height:1;will-change:transform,top;user-select:none;color:rgba(240,237,232,.13);transition:color .1s,transform .1s,text-shadow .1s,opacity .1s}
.rain-char.on{color:rgba(240,237,232,.92);font-weight:700;z-index:1;text-shadow:0 0 8px rgba(255,255,255,.18),0 0 16px rgba(255,255,255,.084)}

/* ================================================================
   21. SERVICES LIST (halaman Layanan)
   ================================================================ */
#services-list{padding:5rem 2rem 0}
.sl-inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-direction:column;gap:7rem}
.sl-row{display:grid;grid-template-columns:1.05fr 1fr;gap:4.5rem;align-items:center}
.sl-row.alt{grid-template-columns:1fr 1.05fr}
.sl-row.alt .sl-media{order:2}
@media(max-width:900px){.sl-row,.sl-row.alt{grid-template-columns:1fr;gap:2.5rem}.sl-row.alt .sl-media{order:0}}
.sl-media{position:relative}
.sl-media-frame{position:relative;overflow:hidden;border-radius:1.75rem;aspect-ratio:4/3;border:1px solid rgba(201,168,76,.16);background:linear-gradient(135deg,rgba(201,168,76,.14),rgba(17,17,17,.4));box-shadow:0 30px 80px rgba(0,0,0,.4)}
.sl-media-frame img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(20%) contrast(1.04) brightness(.9);transition:transform .8s var(--ease),filter .6s ease}
.sl-row:hover .sl-media-frame img{transform:scale(1.05);filter:grayscale(0%) contrast(1.06) brightness(1)}
.sl-media-fade{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,17,17,.62) 0%,transparent 52%);pointer-events:none}
.sl-media-tag{position:absolute;left:1.25rem;bottom:1.25rem;z-index:2;display:inline-flex;align-items:center;gap:8px;padding:.55rem 1rem;border-radius:100px;background:rgba(8,8,8,.55);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(201,168,76,.28);font-size:.72rem;font-weight:600;letter-spacing:.04em;color:var(--gold-lt)}
.sl-media-tag svg{color:var(--gold)}
.sl-media-badge{position:absolute;right:-16px;top:-16px;z-index:3;width:60px;height:60px;border-radius:1.1rem;background:var(--g-gold);color:#080808;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px rgba(201,168,76,.32);transition:transform .3s var(--ease)}
.sl-row:hover .sl-media-badge{transform:rotate(6deg) scale(1.07)}
.sl-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:1rem}
.sl-eyebrow::before{content:'';width:24px;height:1px;background:var(--gold)}
.sl-eyebrow span{font-size:.67rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600}
.sl-content-title{font-size:clamp(1.9rem,3vw,2.6rem);font-weight:800;color:var(--txt);letter-spacing:-.025em;line-height:1.08;margin-bottom:1rem}
.sl-content-title .dot{color:var(--gold)}
.sl-content-desc{font-size:1rem;line-height:1.8;color:var(--txt2);margin-bottom:1.75rem;max-width:520px}
.sl-content-features{display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.5rem;margin-bottom:2rem}
@media(max-width:520px){.sl-content-features{grid-template-columns:1fr}}
.sl-feat{display:flex;align-items:flex-start;gap:.7rem;font-size:.85rem;line-height:1.5;color:var(--txt2)}
.sl-feat-dot{width:18px;height:18px;border-radius:50%;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.22);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.sl-feat-dot svg{color:var(--gold)}
.sl-content-cta{display:inline-flex;align-items:center;gap:8px;padding:.8rem 1.7rem;border-radius:100px;border:1px solid rgba(201,168,76,.28);background:transparent;color:var(--gold);font-size:.84rem;font-weight:600;letter-spacing:.04em;text-decoration:none;transition:border-color .25s,background .25s,gap .2s var(--ease),transform .2s var(--ease)}
.sl-content-cta:hover{border-color:rgba(201,168,76,.65);background:rgba(201,168,76,.07);gap:14px;transform:translateX(3px)}
.sl-content-cta svg{transition:transform .2s var(--ease)}
.sl-content-cta:hover svg{transform:translateX(3px)}

/* ================================================================
   22. NOT SURE (CTA konsultasi) — SHARED
   ================================================================ */
#not-sure{padding:5rem 2rem}
.ns-inner{max-width:var(--maxw);margin:0 auto}
.ns-box{position:relative;overflow:hidden;border-radius:2rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;padding:4rem;background:var(--gold-bg);border:1px solid rgba(201,168,76,.14);align-items:center}
@media(max-width:768px){.ns-box{grid-template-columns:1fr;padding:2.5rem}}
.ns-topline{position:absolute;top:0;left:12%;right:12%;height:1px;background:linear-gradient(90deg,transparent,#C9A84C,transparent)}
.ns-botline{position:absolute;bottom:0;left:28%;right:28%;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.3),transparent)}
.ns-glow{position:absolute;top:50%;right:-5%;transform:translateY(-50%);width:45%;height:80%;border-radius:50%;background:radial-gradient(ellipse,rgba(201,168,76,.07) 0%,transparent 70%);pointer-events:none}
.ns-content{position:relative;z-index:1}
.ns-h{font-size:clamp(1.5rem,2.5vw,2.2rem);font-weight:800;color:var(--txt);letter-spacing:-.02em;margin-bottom:1.1rem;line-height:1.2}
.ns-sub{font-size:.95rem;line-height:1.8;color:var(--txt2)}
.ns-btns{position:relative;z-index:1;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
@media(max-width:768px){.ns-btns{flex-direction:row;flex-wrap:wrap}}
.ns-btn-wp{display:inline-flex;align-items:center;gap:10px;padding:.9rem 2rem;border-radius:100px;border:none;background:var(--g-gold);color:#080808;font-weight:700;font-size:.9rem;letter-spacing:.04em;position:relative;overflow:hidden;cursor:pointer;text-decoration:none;transition:transform .2s var(--ease),box-shadow .3s}
.ns-btn-wp:hover{transform:scale(1.04);box-shadow:0 8px 32px rgba(201,168,76,.22);color:#080808}
.ns-btn-wp::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transform:translateX(-100%)}
.ns-btn-wp:hover::after{animation:shimmer .55s ease forwards}
.ns-bullet{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--txt3)}
.ns-bullet svg{color:var(--gold);flex-shrink:0}

/* ================================================================
   23. FAQ (accordion) — SHARED
   ================================================================ */
#faq{padding:0 2rem 7rem}
.faq-inner{max-width:840px;margin:0 auto}
.faq-head{margin-bottom:3rem}
.faq-list{display:flex;flex-direction:column;gap:.75rem}
.faq-item{border-radius:1.25rem;background:rgba(255,255,255,.02);border:1px solid var(--bd);overflow:hidden;transition:border-color .25s,background .25s}
.faq-item.open{background:rgba(201,168,76,.04);border-color:rgba(201,168,76,.18)}
.faq-q{width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.3rem 1.5rem;background:none;border:none;cursor:pointer;font-size:.95rem;font-weight:600;color:var(--txt);line-height:1.45;font-family:'Manrope',sans-serif}
.faq-q:hover{color:var(--gold)}
.faq-chevron{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold);transition:transform .35s var(--ease),background .25s}
.faq-item.open .faq-chevron{transform:rotate(180deg);background:rgba(201,168,76,.12)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease),opacity .35s ease;opacity:0}
.faq-item.open .faq-a{max-height:300px;opacity:1}
.faq-a-inner{padding:.25rem 1.5rem 1.5rem;font-size:.9rem;line-height:1.8;color:var(--txt2)}

/* ================================================================
   24. ABOUT HERO + QUICK FACTS + JOURNEY + APPROACH + ECOSYSTEM (Tentang)
   ================================================================ */
@keyframes lineGrow{from{height:0}to{height:100%}}
/* about hero */
#about-hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:88px;overflow:hidden}
.ah-grid{max-width:var(--maxw);margin:0 auto;padding:3rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;width:100%}
@media(max-width:900px){.ah-grid{grid-template-columns:1fr}.ah-portrait-col{display:none}}
.ah-eyebrow{animation:fadeUp .6s var(--ease) .35s both}
.ah-headline{font-size:clamp(3rem,6vw,6rem);font-weight:900;letter-spacing:-.04em;line-height:.95;color:var(--txt);margin-bottom:1.4rem;animation:fadeUp .9s var(--ease) .5s both}
.ah-sub{font-size:1.05rem;line-height:1.82;color:var(--txt2);max-width:520px;margin-bottom:2rem;animation:fadeUp .7s var(--ease) .75s both}
.ah-tags{display:flex;flex-wrap:wrap;gap:8px;animation:fadeUp .6s var(--ease) .95s both}
.ah-tag{padding:5px 14px;border-radius:100px;font-size:.74rem;font-weight:600;letter-spacing:.06em;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);color:var(--txt2)}
.ah-tag-gold{background:var(--gold-bg);border-color:var(--gold-bd);color:var(--gold)}
.ah-portrait-col{position:relative;animation:fadeRight 1s var(--ease) .6s both}
.ah-portrait-frame{border-radius:1.75rem;overflow:hidden;aspect-ratio:3/4;max-height:600px;border:1px solid rgba(201,168,76,.15);position:relative}
.ah-portrait-frame img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(8%) contrast(1.05);display:block}
.ah-portrait-fade{position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to top,#111111 0%,transparent 100%);pointer-events:none}
.ah-portrait-bd{position:absolute;inset:0;border-radius:inherit;border:1px solid rgba(201,168,76,.12);pointer-events:none}
.ah-glow{position:absolute;inset:-30px;border-radius:50%;background:radial-gradient(ellipse,rgba(201,168,76,.06) 0%,transparent 60%);pointer-events:none}
.ah-badge{position:absolute;bottom:60px;left:-28px;background:rgba(17,17,17,.9);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(201,168,76,.22);border-radius:1.1rem;padding:14px 18px;min-width:160px;animation:fadeIn .7s ease 1.4s both;transition:transform .25s var(--ease)}
.ah-badge:hover{transform:scale(1.04)}
.ah-badge-num{font-size:2.2rem;font-weight:900;line-height:1;background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ah-badge-lbl{font-size:.72rem;color:var(--txt3);margin-top:4px;letter-spacing:.04em}
.ah-acc{position:absolute;top:10%;right:-10px;width:2px;height:28%;background:linear-gradient(to bottom,#C9A84C,transparent);border-radius:2px}
.ah-rule-bot{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.14),transparent)}
/* quick facts */
#quick-facts{padding:0 2rem 7rem}
.qf-inner{max-width:var(--maxw);margin:0 auto}
.qf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:rgba(255,255,255,.06);border-radius:1.75rem;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.qf-cell{background:var(--bg);padding:2.25rem 2rem;transition:background .3s}
.qf-cell:hover{background:rgba(201,168,76,.04)}
.qf-num{font-size:2.8rem;font-weight:900;line-height:1;background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.6rem}
.qf-label{font-size:.8rem;color:var(--txt2);line-height:1.5}
.qf-sub{font-size:.72rem;color:var(--txt3);margin-top:.35rem}
.qf-pills{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.qf-pill{padding:2px 9px;border-radius:100px;font-size:.66rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:var(--txt3);font-weight:500}
/* journey */
#journey{padding:0 2rem 7rem}
.jn-inner{max-width:var(--maxw);margin:0 auto}
.jn-head{margin-bottom:4.5rem;max-width:600px}
.jn-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
@media(max-width:900px){.jn-grid{grid-template-columns:1fr}}
.jn-timeline{position:relative;padding-left:2rem}
.jn-line{position:absolute;left:0;top:8px;width:1px;height:100%;background:linear-gradient(to bottom,var(--gold),rgba(201,168,76,.1))}
.jn-line.in-view{animation:lineGrow 1.4s var(--ease) .2s both}
.jn-item{position:relative;margin-bottom:3rem}
.jn-item:last-child{margin-bottom:0}
.jn-dot{position:absolute;left:-2.55rem;top:4px;width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.15),0 0 12px rgba(201,168,76,.3)}
.jn-year{font-size:.7rem;font-weight:700;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;margin-bottom:.5rem}
.jn-title{font-size:1.05rem;font-weight:700;color:var(--txt);margin-bottom:.6rem;line-height:1.3}
.jn-desc{font-size:.88rem;line-height:1.8;color:var(--txt2)}
.jn-desc em{color:rgba(201,168,76,.85);font-style:normal;font-weight:500}
.jn-quote{padding:3rem;border-radius:1.75rem;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);position:sticky;top:120px}
.jn-quote-mark{font-size:5rem;line-height:.8;color:rgba(201,168,76,.15);font-family:Georgia,serif;margin-bottom:.5rem}
.jn-quote-text{font-size:1.15rem;font-weight:500;line-height:1.72;color:var(--txt);font-style:italic;margin-bottom:2rem}
.jn-quote-text em{color:var(--gold);font-style:normal;font-weight:700}
.jn-quote-rule{height:1px;background:linear-gradient(90deg,var(--gold),transparent);width:48px;margin-bottom:1.25rem}
.jn-quote-meta{font-size:.8rem;color:var(--txt3);letter-spacing:.05em}
.jn-quote-stats{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.06);display:flex;gap:1.5rem}
.jn-qs-num{font-size:1.1rem;font-weight:800;background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.jn-qs-lbl{font-size:.7rem;color:var(--txt3);margin-top:3px;line-height:1.4}
/* approach */
#approach{padding:0 2rem 7rem}
.ap-inner{max-width:var(--maxw);margin:0 auto}
.ap-head{margin-bottom:3.5rem}
.ap-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@media(max-width:768px){.ap-grid{grid-template-columns:1fr}}
.ap-card{padding:2.25rem;border-radius:1.5rem;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);transition:background .3s,border-color .3s,transform .3s var(--ease),box-shadow .3s;position:relative;overflow:hidden}
.ap-card:hover{background:rgba(201,168,76,.04);border-color:rgba(201,168,76,.2);transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.25)}
.ap-card-topline{position:absolute;top:0;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,#C9A84C,transparent);transform:scaleX(0);transform-origin:center;transition:transform .6s var(--ease)}
.ap-card.in-view .ap-card-topline{transform:scaleX(1)}
.ap-num{font-size:.68rem;font-weight:700;color:var(--gold);letter-spacing:.12em;margin-bottom:1.1rem}
.ap-title{font-size:1.1rem;font-weight:700;color:var(--txt);margin-bottom:.7rem;line-height:1.25}
.ap-desc{font-size:.875rem;line-height:1.75;color:var(--txt2)}
.ap-desc em{color:var(--gold);font-style:normal;font-weight:600}
.ap-card-glow{position:absolute;bottom:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.1) 0%,transparent 70%);pointer-events:none;opacity:0;transition:opacity .4s,transform .4s}
.ap-card:hover .ap-card-glow{opacity:1;transform:scale(1.8)}
/* ecosystem */
#ecosystem{padding:0 2rem 7rem}
.ec-inner{max-width:var(--maxw);margin:0 auto}
.ec-head{margin-bottom:1rem;display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.ec-sub{font-size:.97rem;color:var(--txt2);max-width:500px;line-height:1.75;margin-bottom:3rem}
.ec-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media(max-width:768px){.ec-grid{grid-template-columns:1fr}}
.ec-card{position:relative;overflow:hidden;border-radius:1.75rem;padding:2.75rem;border:1px solid var(--bd);background:rgba(255,255,255,.02);transition:background .3s,border-color .3s,transform .3s var(--ease),box-shadow .3s;cursor:pointer}
.ec-card:hover{background:rgba(201,168,76,.04);border-color:rgba(201,168,76,.22);transform:translateY(-7px);box-shadow:0 24px 70px rgba(0,0,0,.3)}
.ec-topline{position:absolute;top:0;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,#C9A84C,transparent);transform:scaleX(0);transform-origin:center;transition:transform .7s var(--ease)}
.ec-card.in-view .ec-topline{transform:scaleX(1)}
.ec-icon{width:52px;height:52px;border-radius:1rem;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.18);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:1.4rem;transition:background .3s,transform .25s var(--ease)}
.ec-card:hover .ec-icon{background:rgba(201,168,76,.15);transform:scale(1.08) rotate(3deg)}
.ec-name{font-size:1.35rem;font-weight:800;color:var(--txt);margin-bottom:.6rem;letter-spacing:-.02em}
.ec-desc{font-size:.9rem;line-height:1.75;color:var(--txt2);margin-bottom:1.75rem}
.ec-link{display:inline-flex;align-items:center;gap:7px;color:var(--gold);font-size:.82rem;font-weight:600;letter-spacing:.04em;text-decoration:none;transition:gap .2s var(--ease)}
.ec-link:hover{gap:13px}
.ec-glow{position:absolute;bottom:-30px;right:-30px;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.1) 0%,transparent 70%);pointer-events:none;opacity:0;transition:opacity .4s,transform .4s}
.ec-card:hover .ec-glow{opacity:1;transform:scale(1.7)}

/* ================================================================
   25. HUBUNGI — page hero (bars), contact form, info strip
   ================================================================ */
#page-hero.contact, body.page-template #page-hero{ } /* marker */
.ph-bars{position:absolute;top:-2.5rem;right:-15rem;z-index:0;display:flex;flex-direction:column;align-items:flex-end;filter:blur(20px);pointer-events:none}
.ph-bar{height:10rem;border-radius:9999px;filter:blur(6rem)}
.ph-bar-1{width:60rem;background:linear-gradient(to bottom,#E8C97A,#9A7535)}
.ph-bar-2{width:90rem;background:linear-gradient(to bottom,#B45309,#FACC15)}
.ph-bar-3{width:60rem;background:linear-gradient(to bottom,#9A7535,#E8C97A)}
.ph-noise{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.38;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='256' height='256'%3E%3Cfilter id='hn'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23hn)'/%3E%3C/svg%3E")}
.ph-inner{max-width:860px;margin:0 auto;position:relative;z-index:2}
.ph-pill{display:inline-flex;align-items:center;gap:9px;padding:8px 16px;border-radius:100px;background:transparent;border:1px solid rgba(255,255,255,.5);font-size:.875rem;color:var(--txt);margin-bottom:2rem;text-decoration:none;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:background .25s,border-color .25s;animation:fadeUp .6s var(--ease) .3s both}
.ph-pill:hover{background:rgba(255,255,255,.08);border-color:#fff}
.ph-pill-text{font-weight:500;color:#fff}
.ph-pill-arr{display:flex;color:#fff;transition:transform .25s var(--ease)}
.ph-pill:hover .ph-pill-arr{transform:translateX(3px)}
.ph-h{font-size:clamp(2.8rem,6.5vw,5.5rem);font-weight:900;letter-spacing:-.04em;color:#fff;line-height:1.05;margin:0 auto 1.6rem;max-width:13ch;animation:fadeUp .9s var(--ease) .45s both}
.ph-sub{font-size:1.12rem;line-height:1.8;color:var(--txt2);max-width:560px;margin:0 auto 2.5rem;animation:fadeUp .7s var(--ease) .65s both}
.ph-rule{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.15),transparent)}
/* halaman hubungi: page-hero center + tinggi beda */
#contact ~ *,#contact{}
#page-hero:has(~ #contact){min-height:70vh;text-align:center;justify-content:center}
/* contact */
#contact{padding:5rem 2rem 0}
.ct-inner{max-width:var(--maxw);margin:0 auto}
.ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}
@media(max-width:768px){.ct-grid{grid-template-columns:1fr}}
.ct-form-card{position:relative;overflow:hidden;border-radius:2rem;padding:3rem;background:rgba(255,255,255,.02);border:1px solid var(--bd);transition:border-color .3s}
.ct-form-topline{position:absolute;top:0;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,#C9A84C,transparent);transform:scaleX(0);transform-origin:center;transition:transform .6s var(--ease)}
.ct-form-card.in-view .ct-form-topline{transform:scaleX(1)}
.ct-form-label{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(201,168,76,.6);font-weight:600;margin-bottom:.5rem}
.ct-form-title{font-size:1.55rem;font-weight:800;color:var(--txt);margin-bottom:2rem;letter-spacing:-.02em}
.ct-form{display:flex;flex-direction:column;gap:1.25rem}
.ct-field{display:flex;flex-direction:column;gap:.5rem}
.ct-flabel{font-size:.78rem;font-weight:600;color:var(--txt2);letter-spacing:.01em}
.ct-input,.ct-select,.ct-textarea{width:100%;font-family:'Manrope',sans-serif;font-size:.92rem;color:var(--txt);background:rgba(255,255,255,.03);border:1px solid var(--bd);border-radius:.85rem;padding:.85rem 1rem;transition:border-color .25s,background .25s,box-shadow .25s}
.ct-input::placeholder,.ct-textarea::placeholder{color:var(--txt3)}
.ct-input:focus,.ct-select:focus,.ct-textarea:focus{outline:none;border-color:rgba(201,168,76,.45);background:rgba(201,168,76,.04);box-shadow:0 0 0 3px rgba(201,168,76,.08)}
.ct-select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C9A84C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.ct-select option{background:var(--bg2);color:var(--txt)}
.ct-textarea{resize:vertical;min-height:120px;line-height:1.6}
.ct-submit{display:inline-flex;align-items:center;justify-content:center;gap:10px;margin-top:.5rem;padding:1rem 1.8rem;border-radius:100px;cursor:pointer;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.32);color:var(--green);font-size:.95rem;font-weight:700;letter-spacing:.03em;font-family:'Manrope',sans-serif;transition:background .25s,border-color .25s,transform .2s var(--ease),gap .2s var(--ease)}
.ct-submit:hover{background:rgba(34,197,94,.2);border-color:rgba(34,197,94,.6);gap:14px;transform:translateY(-2px)}
.ct-contacts{display:flex;flex-direction:column;padding-top:.5rem;padding-left:2.5rem}
@media(max-width:768px){.ct-contacts{padding-left:0}}
.ct-contacts-label{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(201,168,76,.6);font-weight:600;margin-bottom:.5rem}
.ct-contacts-title{font-size:1.55rem;font-weight:800;color:var(--txt);margin-bottom:1.75rem;letter-spacing:-.02em}
.ct-list-item{display:flex;align-items:center;gap:1rem;padding:1.15rem 0;border-bottom:1px solid rgba(255,255,255,.06);text-decoration:none;transition:transform .2s var(--ease)}
.ct-list-item:last-child{border-bottom:none}
.ct-list-item:hover{transform:translateX(4px)}
.ct-list-icon{width:42px;height:42px;border-radius:.8rem;flex-shrink:0;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.16);display:flex;align-items:center;justify-content:center;color:var(--gold);transition:background .25s}
.ct-list-item:hover .ct-list-icon{background:rgba(201,168,76,.15)}
.ct-list-meta{display:flex;flex-direction:column;gap:1px;min-width:0}
.ct-list-name{font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--txt3);font-weight:600}
.ct-list-val{font-size:.95rem;font-weight:600;color:var(--txt);letter-spacing:-.01em;transition:color .2s}
.ct-list-item:hover .ct-list-val{color:var(--gold)}
/* info strip */
#info-strip{padding:4rem 2rem}
.is-inner{max-width:var(--maxw);margin:0 auto}
.is-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.05);border-radius:1.5rem;overflow:hidden;border:1px solid rgba(255,255,255,.05)}
@media(max-width:768px){.is-grid{grid-template-columns:1fr}}
.is-cell{background:var(--bg);padding:2rem 2.25rem;transition:background .3s}
.is-cell:hover{background:rgba(201,168,76,.03)}
.is-icon{width:38px;height:38px;border-radius:.75rem;background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.15);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:1rem}
.is-title{font-size:.84rem;font-weight:700;color:var(--txt);margin-bottom:.4rem}
.is-desc{font-size:.8rem;line-height:1.7;color:var(--txt2)}
.is-desc strong{color:rgba(240,237,232,.75);font-weight:600}

/* ================================================================
   26. HALAMAN LAYANAN DETAIL (Website dll) — body.tpl-service
   ================================================================ */
@keyframes floatY2{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* — hero & why di-scope agar tidak bentrok homepage — */
body.tpl-service #hero{min-height:auto;display:block;padding:150px 2rem 70px}
body.tpl-service .hero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2}
body.tpl-service .hero-back{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;color:var(--txt2);text-decoration:none;margin-bottom:1.5rem;transition:color .2s,gap .2s var(--ease);animation:fadeUp .6s var(--ease) .2s both}
body.tpl-service .hero-back:hover{color:var(--gold);gap:11px}
body.tpl-service .hero-grid{grid-template-columns:1.04fr .96fr;gap:4.5rem;align-items:center;padding:0}
@media(max-width:960px){body.tpl-service .hero-grid{grid-template-columns:1fr;gap:3.25rem}}
body.tpl-service .hero-eyebrow{animation:fadeUp .6s var(--ease) .3s both}
body.tpl-service .hero-h{font-size:clamp(2.7rem,5.2vw,4.7rem);font-weight:900;letter-spacing:-.035em;line-height:1.04;color:var(--txt);margin-bottom:1.4rem;animation:fadeUp .8s var(--ease) .42s both}
body.tpl-service .hero-sub{font-size:1.08rem;line-height:1.8;color:var(--txt2);max-width:520px;margin:0;animation:fadeUp .7s var(--ease) .58s both}
body.tpl-service .hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:2.3rem;animation:fadeUp .7s var(--ease) .72s both}
body.tpl-service .hero-meta{display:flex;gap:2.25rem;flex-wrap:wrap;margin-top:2.6rem;animation:fadeUp .7s var(--ease) .85s both}
body.tpl-service .hero-meta-item{display:flex;flex-direction:column;gap:3px}
body.tpl-service .hero-meta-k{font-size:1.5rem;font-weight:800;color:var(--txt);letter-spacing:-.02em}
body.tpl-service .hero-meta-v{font-size:.74rem;color:var(--txt3);letter-spacing:.04em}
body.tpl-service #why{padding:5rem 2rem}
body.tpl-service .why-inner{max-width:var(--maxw);margin:0 auto}
body.tpl-service .why-head{margin-bottom:3rem;max-width:640px}
body.tpl-service .why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:860px){body.tpl-service .why-grid{grid-template-columns:1fr}}
body.tpl-service .why-grid .fade-up{height:100%}
/* hero visual: browser mockup */
.hero-visual{position:relative;animation:fadeUp .9s var(--ease) .5s both}
.browser{position:relative;border-radius:1.25rem;overflow:hidden;border:1px solid rgba(201,168,76,.18);background:#0c0c0c;box-shadow:0 40px 110px rgba(0,0,0,.55);animation:floatY 9s ease-in-out infinite}
.browser-bar{display:flex;align-items:center;gap:6px;padding:.7rem 1rem;background:rgba(255,255,255,.03);border-bottom:1px solid var(--bd)}
.browser-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.16)}
.browser-url{margin-left:.7rem;flex:1;height:24px;border-radius:100px;background:rgba(255,255,255,.05);display:flex;align-items:center;gap:6px;padding:0 .8rem;font-size:.62rem;color:var(--txt3);font-family:monospace;letter-spacing:.02em}
.browser-img{aspect-ratio:16/10;overflow:hidden}
.browser-img img{width:100%;height:100%;object-fit:cover;display:block;filter:contrast(1.05) brightness(.95)}
.hero-chip{position:absolute;z-index:3;display:inline-flex;align-items:center;gap:8px;padding:.6rem 1rem;border-radius:100px;background:rgba(12,12,12,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(201,168,76,.3);font-size:.74rem;font-weight:600;color:var(--gold-lt);box-shadow:0 12px 34px rgba(0,0,0,.4)}
.hero-chip svg{color:var(--gold)}
.hero-chip-1{top:-20px;left:-26px;animation:floatY2 7s ease-in-out infinite}
.hero-chip-2{bottom:30px;right:-30px;animation:floatY 8s ease-in-out infinite}
@media(max-width:520px){.hero-chip-1{left:-6px}.hero-chip-2{right:-6px}}
/* why cards */
.why-card{position:relative;height:100%;overflow:hidden;background:rgba(255,255,255,.02);border:1px solid var(--bd);border-radius:1.5rem;padding:2.2rem;transition:background .35s,border-color .35s,transform .35s var(--ease)}
.why-card:hover{background:rgba(201,168,76,.035);border-color:rgba(201,168,76,.2);transform:translateY(-6px)}
.why-icon{width:48px;height:48px;border-radius:.9rem;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.18);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:1.3rem}
.why-title{font-size:1.12rem;font-weight:700;color:var(--txt);margin-bottom:.6rem;letter-spacing:-.01em}
.why-desc{font-size:.9rem;line-height:1.75;color:var(--txt2)}
/* types */
#types{padding:5rem 2rem}
.types-inner{max-width:var(--maxw);margin:0 auto}
.types-head{margin-bottom:3rem;max-width:660px}
.types-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
@media(max-width:900px){.types-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.types-grid{grid-template-columns:1fr}}
.types-grid .fade-up{height:100%}
.type-card{position:relative;height:100%;overflow:hidden;background:rgba(255,255,255,.02);border:1px solid var(--bd);border-radius:1.25rem;padding:1.7rem;transition:background .35s,border-color .35s,transform .35s var(--ease)}
.type-card:hover{background:rgba(201,168,76,.035);border-color:rgba(201,168,76,.2);transform:translateY(-5px)}
.type-card.feat{background:linear-gradient(165deg,rgba(201,168,76,.09),rgba(255,255,255,.02));border-color:rgba(201,168,76,.32)}
.type-badge{position:absolute;top:1.1rem;right:1.1rem;padding:4px 10px;border-radius:100px;font-size:.56rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--g-gold);color:#080808}
.type-ic{width:44px;height:44px;border-radius:.85rem;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.18);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:1.1rem}
.type-t{font-size:1.02rem;font-weight:700;color:var(--txt);margin-bottom:.4rem;letter-spacing:-.01em}
.type-d{font-size:.82rem;line-height:1.62;color:var(--txt2)}
/* packages */
#packages{padding:5rem 2rem}
.pkg-inner{max-width:var(--maxw);margin:0 auto}
.pkg-head{text-align:center;margin-bottom:3.25rem;display:flex;flex-direction:column;align-items:center}
.pkg-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.75rem;align-items:stretch}
@media(max-width:860px){.pkg-grid{grid-template-columns:1fr}}
.pkg-grid .fade-up{height:100%}
.pkg-card{position:relative;height:100%;display:flex;flex-direction:column;border-radius:1.75rem;padding:2.75rem;background:rgba(255,255,255,.02);border:1px solid var(--bd);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.pkg-card:hover{transform:translateY(-6px);box-shadow:0 28px 80px rgba(0,0,0,.32)}
.pkg-card.featured{background:linear-gradient(165deg,rgba(201,168,76,.09),rgba(255,255,255,.02));border-color:rgba(201,168,76,.32)}
.pkg-flag{position:absolute;top:1.5rem;right:1.5rem;padding:5px 12px;border-radius:100px;font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--g-gold);color:#080808}
.pkg-name{font-size:1.4rem;font-weight:800;color:var(--txt);letter-spacing:-.02em;margin-bottom:.5rem}
.pkg-name .g-gold{font-weight:800}
.pkg-tagline{font-size:.92rem;line-height:1.7;color:var(--txt2);margin-bottom:1.6rem;max-width:90%}
.pkg-price{display:flex;align-items:baseline;gap:8px;padding-bottom:1.6rem;margin-bottom:1.6rem;border-bottom:1px solid var(--bd)}
.pkg-price-k{font-size:.74rem;color:var(--txt3);letter-spacing:.03em}
.pkg-price-v{font-size:1.05rem;font-weight:700;color:var(--gold-lt)}
.pkg-feats{display:flex;flex-direction:column;gap:.85rem;margin-bottom:2.2rem;flex:1}
.pkg-feat{display:flex;align-items:flex-start;gap:.8rem;font-size:.9rem;line-height:1.55;color:var(--txt2)}
.pkg-feat.muted{color:var(--txt3)}
.pkg-dot{width:19px;height:19px;border-radius:50%;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.24);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.pkg-dot svg{color:var(--gold)}
.pkg-dot.off{background:rgba(255,255,255,.03);border-color:var(--bd)}
.pkg-dot.off svg{color:var(--txt3)}
/* aivo add-on */
#aivo{padding:3rem 2rem 5.5rem;position:relative}
.aivo-inner-wrap{max-width:var(--maxw);margin:0 auto}
.aivo-panel{position:relative;border-radius:2.25rem;padding:1.5px;background:linear-gradient(135deg,rgba(232,201,122,.55),rgba(201,168,76,.12) 45%,rgba(232,201,122,.45));overflow:hidden}
.aivo-panel::before{content:'';position:absolute;inset:-60%;z-index:0;background:conic-gradient(from 0deg,transparent 0deg,rgba(232,201,122,.65) 55deg,transparent 130deg,transparent 235deg,rgba(232,201,122,.4) 300deg,transparent 360deg);animation:spin 9s linear infinite}
.aivo-body{position:relative;z-index:1;border-radius:calc(2.25rem - 1.5px);background:linear-gradient(160deg,#181715 0%,#101010 70%);padding:3.75rem;overflow:hidden}
.aivo-glow{position:absolute;top:-10%;right:-6%;width:46%;height:80%;border-radius:50%;background:radial-gradient(ellipse,rgba(201,168,76,.12) 0%,transparent 70%);pointer-events:none}
.aivo-watermark{position:absolute;right:2.5rem;bottom:-1.5rem;font-weight:900;font-size:clamp(5rem,12vw,11rem);letter-spacing:-.05em;line-height:1;color:rgba(201,168,76,.05);pointer-events:none;user-select:none}
.aivo-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:center}
@media(max-width:900px){.aivo-grid{grid-template-columns:1fr;gap:2.5rem}.aivo-body{padding:2.4rem}}
.aivo-badge{display:inline-flex;align-items:center;gap:9px;padding:7px 15px;border-radius:100px;background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.32);font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:1.5rem}
.aivo-badge .ping{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulseRing 2s infinite}
.aivo-h{font-size:clamp(1.8rem,3.1vw,2.7rem);font-weight:800;letter-spacing:-.025em;line-height:1.12;color:var(--txt);margin-bottom:1.1rem}
.aivo-sub{font-size:1rem;line-height:1.85;color:var(--txt2);margin-bottom:2rem;max-width:540px}
.aivo-points{display:flex;flex-direction:column;gap:1.05rem;margin-bottom:2.3rem}
.aivo-point{display:flex;align-items:flex-start;gap:1rem}
.aivo-point-ic{width:34px;height:34px;border-radius:.7rem;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.22);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.aivo-point-t{font-size:.95rem;font-weight:700;color:var(--txt);margin-bottom:.2rem}
.aivo-point-d{font-size:.84rem;line-height:1.6;color:var(--txt2)}
.aivo-card{position:relative;border-radius:1.5rem;padding:2rem;background:rgba(8,8,8,.5);border:1px solid var(--gold-bd);backdrop-filter:blur(10px)}
.aivo-card-label{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--txt3);margin-bottom:1.3rem;display:flex;align-items:center;gap:8px}
.aivo-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);display:inline-block}
.aivo-engines{display:flex;flex-direction:column;gap:.7rem}
.aivo-engine{display:flex;align-items:center;gap:.9rem;padding:.85rem 1rem;border-radius:.9rem;background:rgba(255,255,255,.025);border:1px solid var(--bd);transition:border-color .3s,background .3s}
.aivo-engine:hover{border-color:rgba(201,168,76,.3);background:rgba(201,168,76,.04)}
.aivo-engine-ic{width:30px;height:30px;border-radius:8px;background:rgba(201,168,76,.1);display:flex;align-items:center;justify-content:center;color:var(--gold-lt);font-size:.72rem;font-weight:800;flex-shrink:0}
.aivo-engine-n{font-size:.88rem;font-weight:600;color:var(--txt);flex:1}
.aivo-engine-s{font-size:.66rem;color:var(--gold);display:flex;align-items:center;gap:5px}
.aivo-card-foot{margin-top:1.4rem;padding-top:1.3rem;border-top:1px solid var(--bd);font-size:.78rem;line-height:1.6;color:var(--txt2)}
/* process */
#process{padding:5rem 2rem}
.proc-inner{max-width:var(--maxw);margin:0 auto}
.proc-head{margin-bottom:3rem;max-width:600px}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
@media(max-width:900px){.proc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.proc-grid{grid-template-columns:1fr}}
.proc-step{position:relative;padding:2rem 1.6rem;border-radius:1.4rem;background:rgba(255,255,255,.02);border:1px solid var(--bd);transition:border-color .3s,transform .3s var(--ease)}
.proc-step:hover{border-color:rgba(201,168,76,.2);transform:translateY(-4px)}
.proc-num{font-weight:900;font-size:1.05rem;width:38px;height:38px;border-radius:50%;border:1px solid rgba(201,168,76,.3);color:var(--gold);display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem}
.proc-t{font-size:1.02rem;font-weight:700;color:var(--txt);margin-bottom:.5rem}
.proc-d{font-size:.85rem;line-height:1.65;color:var(--txt2)}

/* ================================================================
   27. DESAIN GRAFIS — hero art, scope, brand identity panel
   ================================================================ */
.art{position:relative;border-radius:1.5rem;overflow:hidden;border:1px solid rgba(201,168,76,.18);background:#0c0c0c;box-shadow:0 40px 110px rgba(0,0,0,.55);animation:floatY 9s ease-in-out infinite}
.art-img{aspect-ratio:4/5;overflow:hidden}
.art-img img{width:100%;height:100%;object-fit:cover;display:block;filter:contrast(1.05) saturate(1.08)}
.art-sub{position:absolute;left:-30px;bottom:34px;width:46%;border-radius:1.1rem;overflow:hidden;border:1px solid rgba(201,168,76,.22);box-shadow:0 22px 60px rgba(0,0,0,.55);animation:floatY2 8s ease-in-out infinite}
.art-sub img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
.hero-swatch{position:absolute;z-index:3;top:32%;right:-30px;display:flex;gap:7px;padding:.7rem .85rem;border-radius:100px;background:rgba(12,12,12,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1);box-shadow:0 12px 34px rgba(0,0,0,.4);animation:floatY 8s ease-in-out infinite}
.hero-swatch i{width:18px;height:18px;border-radius:50%;display:block}
/* scope */
#scope{padding:5rem 2rem}
.scope-inner{max-width:var(--maxw);margin:0 auto}
.scope-head{margin-bottom:3rem;max-width:640px}
.scope-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:860px){.scope-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.scope-grid{grid-template-columns:1fr}}
.scope-grid .fade-up{height:100%}
.scope-card{position:relative;height:100%;overflow:hidden;border-radius:1.5rem;border:1px solid var(--bd);background:rgba(255,255,255,.02);transition:border-color .35s,transform .35s var(--ease)}
.scope-card:hover{border-color:rgba(201,168,76,.24);transform:translateY(-5px)}
.scope-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.scope-media img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.35) contrast(1.04);transition:filter .5s var(--ease),transform .6s var(--ease)}
.scope-card:hover .scope-media img{filter:grayscale(0) contrast(1.06);transform:scale(1.05)}
.scope-media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(12,12,12,.85),transparent 60%)}
.scope-ic{position:absolute;top:1rem;left:1rem;z-index:2;width:38px;height:38px;border-radius:.7rem;background:rgba(12,12,12,.7);backdrop-filter:blur(8px);border:1px solid rgba(201,168,76,.28);display:flex;align-items:center;justify-content:center;color:var(--gold-lt)}
.scope-body{padding:1.5rem 1.6rem 1.8rem}
.scope-t{font-size:1.08rem;font-weight:700;color:var(--txt);margin-bottom:.5rem;letter-spacing:-.01em}
.scope-d{font-size:.86rem;line-height:1.65;color:var(--txt2)}
/* brand identity flagship (struktur sama dgn aivo panel) */
#identity{padding:3rem 2rem 5.5rem;position:relative}
.bi-inner-wrap{max-width:var(--maxw);margin:0 auto}
.bi-panel{position:relative;border-radius:2.25rem;padding:1.5px;background:linear-gradient(135deg,rgba(232,201,122,.55),rgba(201,168,76,.12) 45%,rgba(232,201,122,.45));overflow:hidden}
.bi-panel::before{content:'';position:absolute;inset:-60%;z-index:0;background:conic-gradient(from 0deg,transparent 0deg,rgba(232,201,122,.65) 55deg,transparent 130deg,transparent 235deg,rgba(232,201,122,.4) 300deg,transparent 360deg);animation:spin 9s linear infinite}
.bi-body{position:relative;z-index:1;border-radius:calc(2.25rem - 1.5px);background:linear-gradient(160deg,#181715 0%,#101010 70%);padding:3.75rem;overflow:hidden}
.bi-glow{position:absolute;top:-10%;right:-6%;width:46%;height:80%;border-radius:50%;background:radial-gradient(ellipse,rgba(201,168,76,.12) 0%,transparent 70%);pointer-events:none}
.bi-watermark{position:absolute;right:2rem;bottom:-1.8rem;font-weight:900;font-size:clamp(4.5rem,11vw,10rem);letter-spacing:-.05em;line-height:1;color:rgba(201,168,76,.05);pointer-events:none;user-select:none}
.bi-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:center}
@media(max-width:900px){.bi-grid{grid-template-columns:1fr;gap:2.5rem}.bi-body{padding:2.4rem}}
.bi-badge{display:inline-flex;align-items:center;gap:9px;padding:7px 15px;border-radius:100px;background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.32);font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:1.5rem}
.bi-badge .ping{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulseRing 2s infinite}
.bi-h{font-size:clamp(1.8rem,3.1vw,2.7rem);font-weight:800;letter-spacing:-.025em;line-height:1.12;color:var(--txt);margin-bottom:1.1rem}
.bi-sub{font-size:1rem;line-height:1.85;color:var(--txt2);margin-bottom:2rem;max-width:540px}
.bi-points{display:flex;flex-direction:column;gap:1.05rem;margin-bottom:2.3rem}
.bi-point{display:flex;align-items:flex-start;gap:1rem}
.bi-point-ic{width:34px;height:34px;border-radius:.7rem;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.22);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.bi-point-t{font-size:.95rem;font-weight:700;color:var(--txt);margin-bottom:.2rem}
.bi-point-d{font-size:.84rem;line-height:1.6;color:var(--txt2)}
.bi-card{position:relative;border-radius:1.5rem;padding:2rem;background:rgba(8,8,8,.5);border:1px solid var(--gold-bd);backdrop-filter:blur(10px)}
.bi-card-label{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--txt3);margin-bottom:1.3rem;display:flex;align-items:center;gap:8px}
.bi-deliv{display:flex;flex-direction:column;gap:.7rem}
.bi-deliv-row{display:flex;align-items:center;gap:.9rem;padding:.85rem 1rem;border-radius:.9rem;background:rgba(255,255,255,.025);border:1px solid var(--bd);transition:border-color .3s,background .3s}
.bi-deliv-row:hover{border-color:rgba(201,168,76,.3);background:rgba(201,168,76,.04)}
.bi-deliv-ic{width:30px;height:30px;border-radius:8px;background:rgba(201,168,76,.1);display:flex;align-items:center;justify-content:center;color:var(--gold-lt);flex-shrink:0}
.bi-deliv-n{font-size:.88rem;font-weight:600;color:var(--txt);flex:1}
.bi-deliv-c{color:var(--gold)}
.bi-card-foot{margin-top:1.4rem;padding-top:1.3rem;border-top:1px solid var(--bd);font-size:.78rem;line-height:1.6;color:var(--txt2)}

/* ================================================================
   28. SOCIAL MEDIA — phone mockup, platforms, LinkedIn spotlight
   ================================================================ */
.tpl-social .hero-visual{display:flex;justify-content:center}
.tpl-social .hero-chip-1{top:12%;left:-6px;animation:floatY2 7s ease-in-out infinite}
.tpl-social .hero-chip-2{bottom:16%;right:-10px;animation:floatY 8s ease-in-out infinite}
@media(max-width:520px){.tpl-social .hero-chip-1{left:-2px}.tpl-social .hero-chip-2{right:-2px}}
/* phone */
.phone{position:relative;width:min(300px,80%);aspect-ratio:300/620;border-radius:3.4rem;padding:12px;background:linear-gradient(150deg,#3c3c40,#0b0b0c 46%,#26262a);box-shadow:0 45px 120px rgba(0,0,0,.65),0 0 0 1px rgba(0,0,0,.55),inset 0 1px 1px rgba(255,255,255,.14);animation:floatY 9s ease-in-out infinite}
.phone::before{content:'';position:absolute;right:-2px;top:148px;width:3px;height:64px;border-radius:0 3px 3px 0;background:linear-gradient(#3a3a40,#141418)}
.phone::after{content:'';position:absolute;left:-2px;top:128px;width:3px;height:34px;border-radius:3px 0 0 3px;background:linear-gradient(#3a3a40,#141418);box-shadow:0 46px 0 0 #1a1a1e}
.phone-screen{position:relative;height:100%;border-radius:2.7rem;overflow:hidden;background:#0c0c0c;display:flex;flex-direction:column}
.phone-island{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:88px;height:25px;border-radius:100px;background:#000;z-index:6;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.phone-status{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.4rem .15rem;flex-shrink:0}
.phone-status-time{font-size:.66rem;font-weight:700;color:var(--txt);letter-spacing:.02em}
.phone-status-ic{display:flex;align-items:center;gap:6px;color:var(--txt)}
.phone-hd{display:flex;align-items:center;gap:.7rem;padding:.7rem .9rem;flex-shrink:0}
.phone-av{width:42px;height:42px;border-radius:50%;background:var(--g-gold);padding:2px;flex-shrink:0}
.phone-av span{display:flex;width:100%;height:100%;border-radius:50%;background:#0d0d0d;align-items:center;justify-content:center;font-weight:900;font-size:.78rem;color:var(--gold-lt)}
.phone-hd-meta{flex:1}
.phone-hd-n{font-size:.82rem;font-weight:700;color:var(--txt)}
.phone-hd-s{font-size:.62rem;color:var(--txt3)}
.phone-hd-btn{font-size:.6rem;font-weight:700;color:#080808;background:var(--g-gold);padding:5px 12px;border-radius:100px}
.phone-stats{display:flex;gap:1.3rem;padding:.2rem .9rem 1rem;border-bottom:1px solid var(--bd);flex-shrink:0}
.phone-stat{display:flex;flex-direction:column}
.phone-stat b{font-size:.82rem;font-weight:800;color:var(--txt)}
.phone-stat i{font-size:.55rem;color:var(--txt3);font-style:normal;letter-spacing:.03em}
.phone-feed{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:3px;flex:1;align-content:start;overflow:hidden}
.phone-feed-img{aspect-ratio:1;overflow:hidden;background:#191919}
.phone-feed-img img{width:100%;height:100%;object-fit:cover;display:block}
.phone-home{flex-shrink:0;height:26px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:7px;background:#0c0c0c}
.phone-home::after{content:'';width:118px;height:4px;border-radius:100px;background:rgba(255,255,255,.55)}
/* platforms */
#platforms{padding:4rem 0;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);background:rgba(255,255,255,.012)}
.plat-inner{max-width:1100px;margin:0 auto;padding:0 6vw;text-align:center}
.plat-lead{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:.9rem}
.plat-h{font-weight:800;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:-.02em;color:var(--txt);line-height:1.2}
.plat-list{display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center;margin-top:2rem}
.plat{display:inline-flex;align-items:center;gap:.6rem;padding:.7rem 1.15rem;border-radius:100px;border:1px solid var(--bd);background:rgba(255,255,255,.025);font-size:.9rem;font-weight:600;color:var(--txt2);transition:border-color .3s,background .3s,transform .3s var(--ease)}
.plat:hover{transform:translateY(-3px);border-color:var(--gold-bd);color:var(--txt)}
.plat svg{color:var(--txt2);transition:color .3s}
.plat:hover svg{color:var(--gold)}
.plat-hi{border-color:rgba(201,168,76,.45);background:rgba(201,168,76,.08);color:var(--gold-lt)}
.plat-hi svg{color:var(--gold)}
.plat-hi-tag{font-size:.6rem;font-weight:700;letter-spacing:.04em;color:#080808;background:var(--g-gold);padding:2px 7px;border-radius:100px;margin-left:.2rem}
.plat-note{font-size:.92rem;line-height:1.75;color:var(--txt2);max-width:560px;margin:1.9rem auto 0}
.plat-note b{color:var(--gold-lt);font-weight:700}
/* linkedin spotlight */
#linkedin{padding:7rem 0;position:relative;overflow:hidden}
#linkedin::before{content:'';position:absolute;top:20%;right:-10%;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.09),transparent 65%);filter:blur(20px);pointer-events:none}
.li-inner{max-width:1180px;margin:0 auto;padding:0 6vw;display:grid;grid-template-columns:1.05fr 1fr;gap:4.5rem;align-items:center;position:relative}
@media(max-width:900px){.li-inner{grid-template-columns:1fr;gap:3rem}}
.li-tag{display:inline-flex;align-items:center;gap:8px;padding:.5rem .95rem;border-radius:100px;border:1px solid var(--gold-bd);background:var(--gold-bg);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-lt)}
.li-tag svg{color:var(--gold)}
.li-h{font-weight:800;font-size:clamp(1.9rem,4vw,2.7rem);letter-spacing:-.02em;line-height:1.14;color:var(--txt);margin:1.2rem 0}
.li-h em{font-style:normal;color:transparent;background:var(--g-gold);-webkit-background-clip:text;background-clip:text}
.li-sub{font-size:1rem;line-height:1.85;color:var(--txt2);max-width:480px;margin-bottom:2.2rem}
.li-list{display:flex;flex-direction:column;gap:1.1rem}
.li-row{display:flex;align-items:flex-start;gap:.95rem}
.li-ric{flex-shrink:0;width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--gold-bg);border:1px solid var(--gold-bd);color:var(--gold)}
.li-rtx b{font-size:.94rem;font-weight:700;color:var(--txt);display:block;margin-bottom:.15rem}
.li-rtx span{font-size:.84rem;line-height:1.6;color:var(--txt2)}
.li-visual{display:flex;justify-content:center;animation:floatY 10s ease-in-out infinite}
.li-card{position:relative;width:100%;max-width:380px;border-radius:1.4rem;overflow:hidden;border:1px solid var(--bd);background:#0c0c0c;box-shadow:0 45px 110px rgba(0,0,0,.55)}
.li-banner{height:88px;background:linear-gradient(120deg,#9A7535,#1c1c1c 70%);position:relative}
.li-banner::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 30%,rgba(232,201,122,.4),transparent 55%)}
.li-prof{padding:0 1.3rem 1.2rem;border-bottom:1px solid var(--bd)}
.li-av{width:74px;height:74px;border-radius:50%;background:var(--g-gold);padding:3px;margin-top:-37px;position:relative;z-index:2;border:3px solid #0c0c0c;box-sizing:content-box}
.li-av span{display:flex;width:100%;height:100%;border-radius:50%;background:#0d0d0d;align-items:center;justify-content:center;font-weight:900;font-size:1.3rem;color:var(--gold-lt)}
.li-name{font-weight:800;font-size:1.15rem;color:var(--txt);margin-top:.7rem}
.li-head{font-size:.82rem;line-height:1.55;color:var(--txt);opacity:.85;margin-top:.35rem}
.li-loc{font-size:.74rem;color:var(--txt3);margin-top:.5rem}
.li-loc b{color:var(--gold-lt);font-weight:700}
.li-btns{display:flex;gap:.6rem;margin-top:1.1rem}
.li-btn-pri{font-size:.78rem;font-weight:700;color:#080808;background:var(--g-gold);padding:.5rem 1.2rem;border-radius:100px}
.li-btn-sec{font-size:.78rem;font-weight:700;color:var(--gold-lt);border:1px solid var(--gold-bd);padding:.5rem 1.2rem;border-radius:100px}
.li-post{padding:1.1rem 1.3rem 1.3rem}
.li-post-hd{display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem}
.li-av-sm{width:34px;height:34px;border-radius:50%;background:var(--g-gold);padding:2px;flex-shrink:0}
.li-av-sm span{display:flex;width:100%;height:100%;border-radius:50%;background:#0d0d0d;align-items:center;justify-content:center;font-weight:900;font-size:.62rem;color:var(--gold-lt)}
.li-post-hd b{font-size:.78rem;font-weight:700;color:var(--txt);display:block;line-height:1.2}
.li-post-hd i{font-size:.66rem;color:var(--txt3);font-style:normal}
.li-post-txt{font-size:.82rem;line-height:1.6;color:var(--txt);opacity:.9}
.li-post-eng{display:flex;align-items:center;gap:.4rem;margin-top:.9rem;padding-top:.8rem;border-top:1px solid var(--bd);font-size:.72rem;color:var(--txt3)}
.li-post-eng svg{color:var(--gold)}

/* ================================================================
   29. BRANDING — hero board collage + posisi chip
   ================================================================ */
.tpl-brand .hero-visual{display:flex;justify-content:center}
.tpl-brand .hero-chip-1{top:8%;left:-14px;animation:floatY2 7s ease-in-out infinite}
.tpl-brand .hero-chip-2{bottom:11%;right:-16px;animation:floatY 8s ease-in-out infinite}
@media(max-width:520px){.tpl-brand .hero-chip-1{left:-2px}.tpl-brand .hero-chip-2{right:-2px}}
.board{position:relative;width:min(460px,100%);border-radius:1.7rem;border:1px solid var(--bd);background:linear-gradient(160deg,#181715,#101010);padding:1.15rem;box-shadow:0 45px 120px rgba(0,0,0,.62);display:grid;grid-template-columns:1fr 1fr;gap:.85rem;animation:floatY 10s ease-in-out infinite}
.board-tile{border-radius:1rem;border:1px solid var(--bd);background:rgba(255,255,255,.025);overflow:hidden;position:relative}
.board-logo{grid-column:1/-1;aspect-ratio:2.5/1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;background:radial-gradient(circle at 50% 35%,rgba(201,168,76,.12),transparent 70%)}
.board-logo-mark{width:56px;height:56px;border-radius:15px;background:var(--g-gold);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.45rem;color:#080808}
.board-logo-wm{font-weight:800;letter-spacing:.34em;font-size:.82rem;color:var(--txt);padding-left:.34em}
.board-pal{display:flex;flex-direction:column;justify-content:center;gap:.6rem;padding:1.1rem}
.board-label{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--txt3)}
.board-swatches{display:flex;gap:.4rem}
.board-sw{flex:1;height:34px;border-radius:7px}
.board-type{display:flex;flex-direction:column;justify-content:center;padding:1.1rem}
.board-type-aa{font-weight:900;font-size:2.3rem;line-height:.9;color:var(--txt)}
.board-type-meta{font-size:.62rem;color:var(--txt3);margin-top:.55rem;line-height:1.6}
.board-type-meta b{color:var(--gold-lt);font-weight:700}
.board-img{grid-column:1/-1;aspect-ratio:2.7/1}
.board-img img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.25) contrast(1.05)}

/* ================================================================
   30. INSIGHT (blog: home.php / index.php)
   ================================================================ */
.nav-link.active{color:var(--gold);background:rgba(201,168,76,.08)}
/* featured hero */
#ins-hero{position:relative;z-index:1;width:100%}
.feat-stage{position:relative;width:100%;min-height:660px;overflow:hidden;border-bottom:1px solid var(--bd);background:#0a0a0a}
.feat-media{position:absolute;inset:0}
.feat-media img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.82)}
.feat-overlay{position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(8,8,8,.96) 0%,rgba(8,8,8,.6) 38%,rgba(8,8,8,.15) 60%,rgba(8,8,8,.5) 88%,rgba(8,8,8,.78) 100%),linear-gradient(180deg,rgba(8,8,8,.7) 0%,transparent 22%,transparent 55%,rgba(8,8,8,.55) 100%)}
.feat-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;min-height:660px;padding:130px 2rem 3rem;display:grid;grid-template-columns:1fr 350px;gap:2.5rem;align-items:center}
@media(max-width:880px){.feat-inner{grid-template-columns:1fr;align-items:end}.feat-stage{min-height:600px}}
.feat-content{max-width:560px}
.feat-cat{display:inline-block;padding:5px 13px;border-radius:100px;font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:rgba(201,168,76,.16);border:1px solid rgba(201,168,76,.3);color:var(--gold);margin-bottom:1.1rem}
.feat-title{font-size:clamp(1.8rem,3.4vw,2.8rem);font-weight:900;letter-spacing:-.03em;line-height:1.1;color:#fff;margin-bottom:1rem}
.feat-desc{font-size:1rem;line-height:1.7;color:rgba(240,237,232,.72);margin-bottom:1.6rem;max-width:480px}
.feat-meta{display:flex;align-items:center;gap:.7rem;font-size:.76rem;color:var(--txt3);font-weight:500;margin-bottom:1.6rem}
.feat-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--txt3)}
.feat-btn{display:inline-flex;align-items:center;gap:9px;padding:.85rem 1.6rem;border-radius:100px;border:1px solid rgba(201,168,76,.4);background:rgba(201,168,76,.08);color:var(--gold);font-size:.86rem;font-weight:700;letter-spacing:.03em;text-decoration:none;transition:background .25s,border-color .25s,gap .2s var(--ease)}
.feat-btn:hover{background:rgba(201,168,76,.16);border-color:rgba(201,168,76,.65);gap:14px}
.feat-list{display:flex;flex-direction:column;gap:.7rem}
.feat-item{position:relative;overflow:hidden;display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-radius:1.1rem;text-align:left;width:100%;cursor:pointer;outline:none;background:rgba(255,255,255,.05);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);transition:background .25s,border-color .25s,transform .2s var(--ease)}
.feat-item:hover{background:rgba(255,255,255,.09);transform:translateX(-3px)}
.feat-item.active{background:rgba(201,168,76,.12);border-color:var(--gold-bd)}
.feat-item.active::before{content:'';position:absolute;left:0;top:14%;bottom:14%;width:3px;border-radius:2px;background:var(--g-gold)}
.feat-num{font-weight:900;font-size:1.15rem;line-height:1;color:var(--txt3);flex-shrink:0;width:1.7em;transition:color .25s}
.feat-item.active .feat-num{background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.feat-item-meta{min-width:0}
.feat-item-cat{font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:.25rem;opacity:.8}
.feat-item-title{font-size:.86rem;font-weight:600;color:rgba(240,237,232,.66);line-height:1.35;transition:color .25s;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.feat-item.active .feat-item-title{color:#fff}
/* filters */
.ins-filters{display:flex;flex-wrap:wrap;gap:.6rem;margin:2.5rem 0 0}
.ins-chip{padding:.55rem 1.15rem;border-radius:100px;border:1px solid var(--bd);background:var(--surf);color:var(--txt2);font-size:.82rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:color .2s,background .2s,border-color .2s,transform .15s var(--ease)}
.ins-chip:hover{color:var(--txt);border-color:rgba(201,168,76,.3);transform:translateY(-2px)}
.ins-chip.active{background:var(--g-gold);color:#080808;border-color:transparent}
/* layout */
#ins-main{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:2.25rem 2rem 7rem}
.ins-layout{display:grid;grid-template-columns:1fr 330px;gap:3.5rem;align-items:start}
@media(max-width:980px){.ins-layout{grid-template-columns:1fr;gap:3rem}}
.ins-archive-head{max-width:760px}
.ins-count{font-size:.78rem;color:var(--txt3);letter-spacing:.04em;margin-bottom:1.5rem}
.ins-count b{color:var(--gold);font-weight:700}
/* rows */
.ins-list{display:flex;flex-direction:column;gap:1.1rem}
.ins-row{display:grid;grid-template-columns:230px 1fr;gap:1.5rem;background:var(--surf);border:1px solid var(--bd);border-radius:1.5rem;overflow:hidden;text-decoration:none;position:relative;transition:border-color .3s,background .3s,transform .35s var(--ease),box-shadow .35s}
.ins-row:hover{border-color:var(--gold-bd);background:var(--gold-bg);transform:translateY(-5px);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.ins-row-thumb{position:relative;overflow:hidden;min-height:170px;background:rgba(255,255,255,.03)}
.ins-row-thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(16%) brightness(.74);display:block;transition:transform .5s var(--ease)}
.ins-row:hover .ins-row-thumb img{transform:scale(1.06)}
.ins-row-tag{position:absolute;top:12px;left:12px;padding:3px 11px;border-radius:100px;font-size:.64rem;font-weight:700;letter-spacing:.04em;background:rgba(201,168,76,.16);backdrop-filter:blur(10px);border:1px solid rgba(201,168,76,.3);color:var(--gold)}
.ins-row-body{padding:1.7rem 1.8rem 1.7rem 0;display:flex;flex-direction:column;justify-content:center}
.ins-row-title{font-size:1.18rem;font-weight:700;color:var(--txt);line-height:1.35;letter-spacing:-.02em;margin-bottom:.6rem;transition:color .2s}
.ins-row:hover .ins-row-title{color:var(--gold-lt)}
.ins-row-desc{font-size:.88rem;line-height:1.65;color:var(--txt2);margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ins-row-meta{display:flex;align-items:center;gap:.7rem;font-size:.74rem;color:var(--txt3);font-weight:500}
.ins-row-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--txt3)}
.ins-row-arr{margin-left:auto;color:var(--gold);font-size:1rem;transition:transform .25s var(--ease)}
.ins-row:hover .ins-row-arr{transform:translateX(5px)}
@media(max-width:560px){.ins-row{grid-template-columns:1fr}.ins-row-thumb{min-height:0;aspect-ratio:16/9}.ins-row-body{padding:1.4rem 1.5rem}}
.ins-empty{padding:3rem 1.5rem;text-align:center;color:var(--txt3);font-size:.9rem;border:1px dashed var(--bd);border-radius:1.5rem}
.ins-pagination{margin-top:2.5rem}
.ins-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;margin:0 3px;border-radius:100px;border:1px solid var(--bd);color:var(--txt2);text-decoration:none;font-size:.85rem;transition:border-color .2s,color .2s,background .2s}
.ins-pagination .page-numbers:hover{border-color:var(--gold-bd);color:var(--gold)}
.ins-pagination .page-numbers.current{background:var(--g-gold);color:#080808;border-color:transparent;font-weight:700}
/* sidebar */
.ins-side{position:sticky;top:100px;display:flex;flex-direction:column;gap:1.5rem}
@media(max-width:980px){.ins-side{position:static}}
.side-card{background:var(--surf);border:1px solid var(--bd);border-radius:1.5rem;padding:1.75rem}
.side-label{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(201,168,76,.6);font-weight:700;margin-bottom:.4rem}
.side-title{font-size:1.15rem;font-weight:800;color:var(--txt);letter-spacing:-.02em;margin-bottom:1.4rem}
.search-card{padding:1.1rem}
.search-wrap{position:relative;display:flex;align-items:center;margin:0}
.search-ico{position:absolute;left:1rem;display:flex;color:var(--txt3);pointer-events:none}
.search-input{width:100%;font-family:'Manrope',sans-serif;font-size:.9rem;color:var(--txt);background:rgba(0,0,0,.25);border:1px solid var(--bd);border-radius:.85rem;padding:.8rem 1rem .8rem 2.8rem;transition:border-color .25s,box-shadow .25s}
.search-input::placeholder{color:var(--txt3)}
.search-input:focus{outline:none;border-color:rgba(201,168,76,.45);box-shadow:0 0 0 3px rgba(201,168,76,.08)}
.pop-item{display:flex;gap:1rem;padding:1rem 0;border-top:1px solid rgba(255,255,255,.06);text-decoration:none;align-items:flex-start;transition:transform .2s var(--ease)}
.pop-item:first-of-type{border-top:none;padding-top:0}
.pop-item:hover{transform:translateX(3px)}
.pop-num{font-weight:900;font-size:1.2rem;line-height:1;background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex-shrink:0;width:1.4em}
.pop-meta{min-width:0}
.pop-cat{font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:.3rem}
.pop-title{font-size:.86rem;font-weight:600;color:var(--txt);line-height:1.4;transition:color .2s}
.pop-item:hover .pop-title{color:var(--gold-lt)}
.cat-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.8rem 0;border-top:1px solid rgba(255,255,255,.06);text-decoration:none;transition:padding .2s var(--ease)}
.cat-item:first-of-type{border-top:none;padding-top:0}
.cat-item:hover{padding-left:.35rem}
.cat-name{font-size:.88rem;font-weight:600;color:var(--txt2);transition:color .2s}
.cat-item:hover .cat-name{color:var(--gold-lt)}
.cat-count{font-size:.72rem;font-weight:700;color:var(--txt3);background:rgba(255,255,255,.04);border:1px solid var(--bd);border-radius:100px;padding:.15rem .6rem;transition:color .2s,border-color .2s}
.cat-item:hover .cat-count{color:var(--gold);border-color:var(--gold-bd)}
.sub-card{position:relative;overflow:hidden;background:linear-gradient(160deg,rgba(201,168,76,.09),rgba(201,168,76,.02));border:1px solid var(--gold-bd)}
.sub-glow{position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.16),transparent 70%);pointer-events:none}
.sub-desc{font-size:.85rem;line-height:1.65;color:var(--txt2);margin-bottom:1.3rem;position:relative;z-index:1}
.sub-form{display:flex;flex-direction:column;gap:.7rem;position:relative;z-index:1}
.sub-input{width:100%;font-family:'Manrope',sans-serif;font-size:.88rem;color:var(--txt);background:rgba(0,0,0,.25);border:1px solid var(--bd);border-radius:.85rem;padding:.8rem 1rem;transition:border-color .25s,box-shadow .25s}
.sub-input::placeholder{color:var(--txt3)}
.sub-input:focus{outline:none;border-color:rgba(201,168,76,.45);box-shadow:0 0 0 3px rgba(201,168,76,.08)}
.sub-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:.85rem 1rem;border:none;border-radius:.85rem;background:var(--g-gold);color:#080808;font-weight:700;font-size:.86rem;letter-spacing:.02em;cursor:pointer;transition:transform .2s var(--ease),box-shadow .3s}
.sub-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,168,76,.22)}
.sub-note{font-size:.7rem;color:var(--txt3);margin-top:.2rem;text-align:center}

/* ================================================================
   31. ARTIKEL (single.php)
   ================================================================ */
#progress-bar{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;background:var(--g-gold);transition:width .1s linear}
#art-hero{position:relative;z-index:1;width:100%}
.art-stage{position:relative;width:100%;min-height:560px;overflow:hidden;border-bottom:1px solid var(--bd);background:#0a0a0a}
.art-stage-media{position:absolute;inset:0}
.art-stage-media img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.66)}
.art-stage-overlay{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(8,8,8,.55) 0%,transparent 26%,transparent 42%,rgba(8,8,8,.78) 100%),linear-gradient(90deg,rgba(8,8,8,.72) 0%,rgba(8,8,8,.25) 55%,rgba(8,8,8,.45) 100%)}
.art-stage-inner{position:relative;z-index:2;max-width:900px;margin:0 auto;min-height:560px;padding:150px 2rem 3.5rem;display:flex;flex-direction:column;justify-content:flex-end}
.art-hero-cat{align-self:flex-start;display:inline-block;padding:5px 14px;border-radius:100px;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(201,168,76,.16);border:1px solid rgba(201,168,76,.3);color:var(--gold);margin-bottom:1.25rem}
.art-hero-title{font-size:clamp(1.9rem,4vw,3.2rem);font-weight:900;letter-spacing:-.04em;line-height:1.08;color:#fff;margin-bottom:1.25rem;max-width:820px}
.art-hero-meta{display:flex;align-items:center;gap:.7rem;font-size:.8rem;color:var(--txt2);font-weight:500}
.art-hero-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--txt3)}
@media(max-width:640px){.art-stage{min-height:480px}.art-stage-inner{min-height:480px;padding:120px 1.5rem 2.5rem}}
.article-wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:4rem 2rem 8rem}
.art-body-grid{display:grid;grid-template-columns:1fr 300px;gap:4rem;align-items:start}
.art-content{min-width:0;max-width:760px}
.art-content h2{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;line-height:1.2;color:var(--txt);margin:3rem 0 1rem;padding-top:.5rem;scroll-margin-top:120px}
.art-content h3{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;color:var(--txt);margin:2rem 0 .75rem}
.art-content p{color:rgba(240,237,232,.78);line-height:1.8;margin-bottom:1.25rem;font-size:1rem}
.art-content a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.art-content strong{color:var(--txt);font-weight:600}
.art-content em{color:var(--gold);font-style:normal;font-weight:500}
.art-content img{max-width:100%;height:auto;border-radius:1rem;margin:1.5rem 0;display:block}
.art-content ul,.art-content ol{margin:1rem 0 1.5rem 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:.6rem}
.art-content ul li,.art-content ol li{display:flex;gap:.75rem;color:rgba(240,237,232,.78);font-size:.97rem;line-height:1.7}
.art-content ul li::before{content:'→';color:var(--gold);flex-shrink:0;font-weight:700;margin-top:.02em}
.art-content ol{counter-reset:ol-c}
.art-content ol li{counter-increment:ol-c}
.art-content ol li::before{content:counter(ol-c,decimal-leading-zero);color:var(--gold);flex-shrink:0;font-weight:700;font-size:.8rem;width:1.4em;text-align:right;margin-top:.15em}
.art-content blockquote{border-left:3px solid var(--gold);padding:1rem 1.5rem;margin:2rem 0;font-size:1.15rem;font-style:italic;color:var(--txt2);font-weight:500;letter-spacing:-.01em;line-height:1.5}
.art-content blockquote p{color:inherit;margin:0}
.art-callout{background:var(--gold-bg);border:1px solid var(--gold-bd);border-left:3px solid var(--gold);border-radius:1rem;padding:1.5rem 1.75rem;margin:2rem 0;border-top-left-radius:.25rem;border-bottom-left-radius:.25rem}
.art-callout p{margin:0;color:var(--txt2)}
.art-callout strong{color:var(--gold)}
.art-content hr,.art-divider{border:none;height:1px;background:var(--bd);margin:2.5rem 0}
.art-pullquote{border-left:3px solid var(--gold);padding:1rem 1.5rem;margin:2rem 0;font-size:1.15rem;font-style:italic;color:var(--txt2);font-weight:500;letter-spacing:-.01em;line-height:1.5}
/* sticky sidebar */
.art-side{position:sticky;top:110px;align-self:start;display:flex;flex-direction:column;gap:1.5rem}
.toc-card{background:var(--surf);border:1px solid var(--bd);border-radius:1.5rem;overflow:hidden}
.toc-card[data-toc]:not(.has-toc){display:none}
.toc-header{background:rgba(255,255,255,.03);border-bottom:1px solid var(--bd);padding:1rem 1.25rem}
.toc-header-label{font-size:.66rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(201,168,76,.6)}
.toc-list{padding:.5rem 0;list-style:none;margin:0}
.toc-item a{display:flex;align-items:flex-start;gap:.75rem;padding:.7rem 1.25rem;text-decoration:none;transition:background .2s,color .2s;border-left:3px solid transparent}
.toc-item a:hover{background:rgba(255,255,255,.03)}
.toc-num{font-size:.72rem;font-weight:700;color:var(--txt3);flex-shrink:0;padding-top:.15em;transition:color .2s}
.toc-text{font-size:.82rem;font-weight:600;color:var(--txt2);line-height:1.45;transition:color .2s}
.toc-item.active a{background:rgba(201,168,76,.05);border-left-color:var(--gold)}
.toc-item.active .toc-num{color:var(--gold)}
.toc-item.active .toc-text{color:var(--txt)}
.toc-progress{padding:.75rem 1.25rem;border-top:1px solid var(--bd)}
.toc-prog-label{font-size:.72rem;color:var(--txt3);margin-bottom:.5rem;display:flex;justify-content:space-between}
.toc-prog-bar{height:4px;background:var(--bd);border-radius:2px;overflow:hidden}
.toc-prog-fill{height:100%;background:var(--g-gold);border-radius:2px;width:0;transition:width .2s linear}
.art-footer{margin-top:4rem;padding-top:3rem;border-top:1px solid var(--bd)}
.art-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.art-tag{font-size:.75rem;font-weight:500;color:var(--txt3);background:rgba(255,255,255,.04);border:1px solid var(--bd);padding:.3rem .8rem;border-radius:2rem;text-decoration:none;transition:color .2s,border-color .2s}
.art-tag:hover{color:var(--gold);border-color:var(--gold-bd)}
.art-related{margin-top:4rem;padding-top:2.5rem;border-top:1px solid var(--bd)}
.art-related-title{font-size:1.1rem;font-weight:800;color:var(--txt);margin-bottom:1rem;letter-spacing:-.02em}
.art-related-list{display:grid;grid-template-columns:1fr 1fr;column-gap:2.5rem}
.art-rel-row{display:flex;align-items:center;gap:1.25rem;padding:1.4rem 0;border-top:1px solid var(--bd);text-decoration:none;transition:padding .25s var(--ease)}
.art-rel-row:nth-child(-n+2){border-top:none}
.art-rel-row:hover{padding-left:.4rem}
.art-rel-info{min-width:0}
.art-rel-cat{font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.art-rel-title{font-size:.92rem;font-weight:500;color:var(--txt);line-height:1.35;letter-spacing:-.01em;transition:color .2s}
.art-rel-row:hover .art-rel-title{color:var(--gold-lt)}
.art-rel-arr{margin-left:auto;color:var(--gold);font-size:1.05rem;flex-shrink:0;transition:transform .25s var(--ease)}
.art-rel-row:hover .art-rel-arr{transform:translateX(5px)}
@media(max-width:900px){.art-body-grid{grid-template-columns:1fr}.art-side{position:static}.art-content{max-width:none}}
@media(max-width:560px){.art-related-list{grid-template-columns:1fr}.art-rel-row{border-top:1px solid var(--bd)}.art-rel-row:first-child{border-top:none}}

/* ================================================================
   32. PORTOFOLIO (archive-portfolio.php)
   ================================================================ */
#pf-work{padding:3rem 2rem 2rem}
.pf-work-inner{max-width:var(--maxw);margin:0 auto}
.pf-work-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:2.5rem}
.pf-work-head h2{font-size:clamp(1.75rem,2.8vw,2.6rem);font-weight:800;letter-spacing:-.025em;color:var(--txt);line-height:1.1}
.pf-filter{display:flex;flex-wrap:wrap;gap:.6rem}
.pf-chip{display:inline-flex;align-items:center;gap:8px;padding:.55rem 1.15rem;border-radius:100px;background:rgba(255,255,255,.03);border:1px solid var(--bd);color:var(--txt2);font-size:.82rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:color .2s,background .2s,border-color .2s,transform .2s var(--ease)}
.pf-chip:hover{color:var(--txt);border-color:rgba(201,168,76,.3);transform:translateY(-2px)}
.pf-chip.active{background:var(--g-gold);color:#080808;border-color:transparent}
.pf-chip-count{font-size:.7rem;opacity:.7}
.pf-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.25rem}
@media(max-width:900px){.pf-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pf-grid{grid-template-columns:1fr}}
.pf-card{position:relative;overflow:hidden;cursor:pointer;grid-column:span 2;border-radius:1.5rem;background:var(--surf);border:1px solid var(--bd);aspect-ratio:4/3;text-decoration:none;transition:border-color .3s,transform .35s var(--ease),box-shadow .35s}
.pf-card.feat{grid-column:span 3;aspect-ratio:3/2}
@media(max-width:900px){.pf-card,.pf-card.feat{grid-column:span 1;aspect-ratio:4/3}}
@media(max-width:560px){.pf-card,.pf-card.feat{aspect-ratio:5/4}}
.pf-card:hover{border-color:rgba(201,168,76,.3);transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.pf-card-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(28%) brightness(.62) contrast(1.05);transition:transform .7s var(--ease),filter .5s ease}
.pf-card:hover .pf-card-img{transform:scale(1.07);filter:grayscale(0%) brightness(.72) contrast(1.08)}
.pf-card-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,8,.92) 4%,rgba(8,8,8,.35) 45%,rgba(8,8,8,.1) 100%);pointer-events:none}
.pf-card-topline{position:absolute;top:0;left:9%;right:9%;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transform-origin:center;transition:transform .6s var(--ease)}
.pf-card:hover .pf-card-topline{transform:scaleX(1)}
.pf-card-idx{position:absolute;top:1.1rem;right:1.25rem;font-size:.78rem;font-weight:700;color:rgba(240,237,232,.4);letter-spacing:.1em;z-index:2}
.pf-card-cat{position:absolute;top:1.1rem;left:1.25rem;z-index:2;padding:4px 12px;border-radius:100px;font-size:.64rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:rgba(201,168,76,.14);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(201,168,76,.28);color:var(--gold-lt)}
.pf-card-body{position:absolute;left:0;right:0;bottom:0;padding:1.5rem;z-index:2}
.pf-card-client{font-size:1.15rem;font-weight:700;color:var(--txt);line-height:1.2;margin-bottom:.35rem}
.pf-card.feat .pf-card-client{font-size:1.45rem}
.pf-card-ind{font-size:.78rem;color:var(--txt2);margin-bottom:.9rem}
.pf-card-metric{display:inline-flex;align-items:baseline;gap:7px;opacity:0;transform:translateY(10px);transition:opacity .4s var(--ease) .05s,transform .4s var(--ease) .05s}
.pf-card:hover .pf-card-metric{opacity:1;transform:none}
.pf-card-metric-val{font-size:1.35rem;font-weight:800;background:var(--g-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.pf-card-metric-lbl{font-size:.74rem;color:var(--txt2)}
.pf-card-view{position:absolute;bottom:1.5rem;right:1.5rem;z-index:2;width:38px;height:38px;border-radius:50%;background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.3);display:flex;align-items:center;justify-content:center;color:var(--gold);opacity:0;transform:scale(.7) rotate(-30deg);transition:opacity .35s var(--ease),transform .35s var(--ease),background .25s}
.pf-card:hover .pf-card-view{opacity:1;transform:none}

/* ================================================================
   33. HALAMAN KLIEN (page-klien.php) — scope tpl-klien
   ================================================================ */
.tpl-klien #hero{position:relative;padding:160px 2rem 60px;overflow:hidden;text-align:center;min-height:auto}
.tpl-klien .hero-inner{max-width:880px;margin:0 auto;position:relative;z-index:2}
.tpl-klien .hero-back{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;color:var(--txt2);text-decoration:none;margin-bottom:1.5rem;transition:color .2s,gap .2s var(--ease)}
.tpl-klien .hero-back:hover{color:var(--gold);gap:11px}
.tpl-klien .hero-eyebrow{display:flex;justify-content:center;animation:fadeUp .6s var(--ease) .3s both}
.tpl-klien .hero-h{font-size:clamp(2.4rem,5vw,4rem);font-weight:800;letter-spacing:-.035em;line-height:1.06;color:var(--txt);margin-bottom:1.3rem;animation:fadeUp .8s var(--ease) .42s both}
.tpl-klien .hero-sub{font-size:1.08rem;line-height:1.8;color:var(--txt2);max-width:580px;margin:0 auto;animation:fadeUp .7s var(--ease) .58s both}
.tpl-klien .hero-ctas{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:2.3rem;animation:fadeUp .7s var(--ease) .72s both}
/* wall */
#wall{padding:3rem 2rem 6rem}
.wall-inner{max-width:var(--maxw);margin:0 auto}
.wall-head{margin-bottom:2.5rem;max-width:640px}
.wall-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(178px,1fr));gap:1px;background:var(--bd);border:1px solid var(--bd);border-radius:1.25rem;overflow:hidden}
.wall-cell{background:var(--bg);min-height:108px;display:flex;align-items:center;justify-content:center;gap:.65rem;padding:1.1rem;text-align:center;transition:background .3s}
.wall-cell:hover{background:rgba(201,168,76,.05)}
.wall-ic{font-size:1.3rem;line-height:1;opacity:.5;filter:grayscale(1);transition:opacity .3s,filter .3s}
.wall-name{font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--txt2);transition:color .3s}
.wall-cell:hover .wall-ic{opacity:1;filter:none}
.wall-cell:hover .wall-name{color:var(--txt)}
.wall-note{margin-top:1.2rem;font-size:.8rem;color:var(--txt3);text-align:center}
/* testi (masonry, khusus klien) */
.tpl-klien #testi{padding:3rem 2rem 6rem}
.tpl-klien .testi-inner{max-width:var(--maxw);margin:0 auto}
.tpl-klien .testi-head{margin-bottom:3rem;max-width:680px}
.tpl-klien .testi-filter{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:2.5rem}
.tpl-klien .testi-chip{padding:.5rem 1.05rem;border-radius:100px;font-size:.78rem;font-weight:600;border:1px solid var(--bd);background:var(--surf);color:var(--txt2);cursor:pointer;transition:.25s}
.tpl-klien .testi-chip:hover{border-color:rgba(201,168,76,.4);color:var(--txt)}
.tpl-klien .testi-chip.on,.tpl-klien .testi-chip.active{background:rgba(201,168,76,.1);border-color:rgba(201,168,76,.32);color:var(--gold)}
.tpl-klien .testi-cols{columns:3;column-gap:1.25rem;display:block;max-height:none;overflow:visible;-webkit-mask-image:none;mask-image:none}
@media(max-width:900px){.tpl-klien .testi-cols{columns:2}}
@media(max-width:600px){.tpl-klien .testi-cols{columns:1}}
.tpl-klien .testi-card{break-inside:avoid;margin-bottom:1.25rem;position:relative;overflow:hidden;background:rgba(255,255,255,.025);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,.08);border-radius:1.6rem;padding:2rem;transition:border-color .35s,transform .35s var(--ease)}
.tpl-klien .testi-card:hover{border-color:rgba(201,168,76,.22);transform:translateY(-4px)}
.tpl-klien .testi-quote{font-size:.92rem;line-height:1.7;color:rgba(240,237,232,.78);margin-bottom:1.4rem}

/* ================================================================
   34. RESPONSIVE HELPERS
   ================================================================ */
.hide-desk{display:none!important}
@media(max-width:768px){
  .hide-mob{display:none!important}
  .hide-desk{display:block!important}
  section{padding-left:1rem!important;padding-right:1rem!important}
  .sl-inner{gap:5rem}
  #services-list{padding:4rem 1rem 0}
}
