
  :root{
    --navy:#0e1c33;
    --navy-deep:#0a1526;
    --navy-card:#16273f;
    --navy-card-2:#1b2e49;
    --navy-line:rgba(255,255,255,.08);
    --gold:#d8a838;
    --gold-2:#e8c45f;
    --gold-deep:#b98a23;
    --ink:#16213a;
    --ink-soft:#5a6576;
    --ink-faint:#8a93a3;
    --bg:#f5f7f9;
    --bg-2:#eef1f4;
    --white:#fff;
    --line:#e6e9ee;
    --red:#e23b3b;
    --red-bg:#fdeaea;
    --green:#15a35b;
    --green-bg:#e6f6ee;
    --lav:#eceffb;
    --r:14px;
    --r-lg:20px;
    --shadow:0 18px 50px -22px rgba(13,27,52,.28);
    --shadow-soft:0 10px 30px -18px rgba(13,27,52,.22);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth;scroll-padding-top:96px}
  body{font-family:'Poppins',sans-serif;color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  a{text-decoration:none;color:inherit}
  img,svg{display:block;max-width:100%}
  h1,h2,h3{line-height:1.15;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
  section{position:relative}
  .wrap{max-width:1200px;margin:0 auto;padding:0 24px}
  .eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;padding:8px 18px;border-radius:999px}
  .eyebrow.light{background:var(--lav);color:#33417a}
  .eyebrow.dark{background:rgba(216,168,56,.12);color:var(--gold-2);border:1px solid rgba(216,168,56,.35)}
  .sec-head{text-align:center;max-width:760px;margin:0 auto 54px}
  .sec-head h2{font-size:clamp(28px,4.2vw,46px);margin:18px 0 14px}
  .sec-head p{color:var(--ink-soft);font-size:17px}
  .dark .sec-head h2{color:#fff}
  .dark .sec-head p{color:#9fb0c9}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:inherit;font-weight:700;font-size:15px;border:none;border-radius:12px;padding:15px 26px;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;line-height:1}
  .btn:active{transform:scale(.98)}
  .btn-gold{background:var(--gold);color:#1c1402;box-shadow:0 12px 26px -12px rgba(216,168,56,.7)}
  .btn-gold:hover{background:var(--gold-2);box-shadow:0 16px 32px -12px rgba(216,168,56,.8)}
  .btn-dark{background:var(--navy);color:#fff}
  .btn-dark:hover{background:var(--navy-card-2)}
  .btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
  .btn-ghost:hover{border-color:var(--gold);color:var(--gold-deep)}
  .btn-navy{background:#000080;color:#fff}
  .btn-navy:hover{background:#00006a}
  .btn-white{background:#fff;color:#000080;box-shadow:0 12px 26px -14px rgba(0,0,0,.4)}
  .btn-white:hover{background:#f1f3ff}
  .btn-wa{background:#EFBF04;color:#fff;box-shadow:0 12px 26px -12px rgba(239,191,4,.6)}
  .btn-wa:hover{background:#e0b300}
  .icon{width:20px;height:20px;flex:none}

  /* ===== HEADER ===== */
  header{position:sticky;top:0;z-index:60;background:#fff;border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;gap:18px;height:76px;flex-wrap:nowrap}
  .brand{display:flex;align-items:center;gap:10px;flex:none}
  .brand-mark{width:42px;height:42px;border-radius:11px;background:var(--navy);display:grid;place-items:center;flex:none}
  .brand-mark svg{width:23px;height:23px}
  .brand-name{font-weight:800;font-size:18px;letter-spacing:-.02em;line-height:1;white-space:nowrap}
  .brand-name .k{color:var(--gold)}
  .brand-tag{font-size:9px;font-weight:600;letter-spacing:.1em;color:var(--ink-faint);text-transform:uppercase;margin-top:3px;white-space:nowrap}
  nav.links{display:flex;gap:24px;flex:1;justify-content:center;flex-wrap:nowrap}
  nav.links a{font-size:14px;font-weight:600;color:#000080;transition:color .15s;white-space:nowrap}
  nav.links a:hover{color:var(--gold-deep)}
  .brand-logo{height:40px;width:auto;display:block}
  .nav-cta{display:inline-flex;align-items:center;gap:8px;flex:none;white-space:nowrap;background:var(--navy);color:#fff;font-weight:700;font-size:12px;letter-spacing:.03em;text-transform:uppercase;padding:12px 18px;border-radius:11px;border:1.5px solid rgba(216,168,56,.55);box-shadow:0 0 0 4px rgba(216,168,56,.10),0 14px 30px -16px rgba(216,168,56,.5);transition:transform .18s,box-shadow .18s}
  .nav-cta:hover{transform:translateY(-1px);box-shadow:0 0 0 5px rgba(216,168,56,.16),0 18px 34px -16px rgba(216,168,56,.6)}
  .nav-cta .dot{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px 1px var(--gold)}
  .burger{display:none;margin-left:auto;background:none;border:none;cursor:pointer;padding:8px}
  .burger span{display:block;width:26px;height:2.5px;background:var(--ink);margin:5px 0;border-radius:2px;transition:.25s}
  .mobile-menu{display:none;position:fixed;inset:76px 0 0;background:var(--navy);z-index:55;padding:30px 24px;flex-direction:column;gap:6px}
  .mobile-menu a{color:#dbe4f1;font-size:18px;font-weight:600;padding:14px 6px;border-bottom:1px solid var(--navy-line)}
  .mobile-menu .nav-cta{margin-top:18px;justify-content:center}
  body.menu-open .mobile-menu{display:flex}
  body.menu-open{overflow:hidden}

  /* ===== HERO ===== */
  .hero{background:radial-gradient(120% 120% at 80% 0%,#19305a 0%,var(--navy) 42%,var(--navy-deep) 100%);color:#fff;position:relative;overflow:hidden}
  .dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1.3px,transparent 1.3px);background-size:26px 26px;opacity:.8;pointer-events:none}
  .hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding-top:72px;padding-bottom:80px}
  .hero h1{font-size:clamp(34px,5vw,58px);color:#fff;margin:22px 0}
  .hero h1 .grad{background:linear-gradient(100deg,var(--gold) 10%,var(--gold-2) 60%,#f3dd9a 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .hero p.lead{color:#fff;font-size:17.5px;max-width:560px;margin-bottom:34px}
  .hero-cta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:42px}
  .focus-label{font-size:12px;font-weight:700;letter-spacing:.13em;color:#7d90b0;text-transform:uppercase;margin-bottom:14px}
  .chips{display:flex;flex-wrap:wrap;gap:12px}
  .chip{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid var(--navy-line);color:#cdd8ea;font-size:13.5px;font-weight:500;padding:9px 16px;border-radius:999px}
  .chip svg{width:16px;height:16px;color:var(--gold-2)}
  .hero-visual{position:relative}
  .hero-card{position:relative;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.12);box-shadow:0 40px 80px -30px rgba(0,0,0,.6);background:#0c1626}
  .ph{position:relative;display:grid;place-items:center;background:
      radial-gradient(100% 80% at 70% 10%,#274877 0%,#152949 55%,#0d1c34 100%);
      color:#9fb6da}
  .ph .house{width:46%;max-width:230px;opacity:.92}
  .ph .ph-tag{position:absolute;top:14px;left:14px;background:rgba(8,16,30,.7);border:1px solid rgba(255,255,255,.14);color:#cdd9ec;font-size:11px;font-weight:600;letter-spacing:.06em;padding:6px 12px;border-radius:8px;text-transform:uppercase}
  .hero-overlay{position:absolute;left:22px;right:22px;bottom:22px;background:linear-gradient(180deg,rgba(14,28,51,.82),rgba(10,21,38,.94));border:1px solid rgba(216,168,56,.3);border-radius:14px;padding:16px 20px;backdrop-filter:blur(4px)}
  .hero-overlay .t{color:var(--gold-2);font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase}
  .hero-overlay .d{color:#e7eefb;font-size:15px;font-weight:600;margin-top:4px}

  /* ===== PROBLEM ===== */
  .sec-pad{padding:92px 0}
  .bg-soft{background:var(--bg)}
  .cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .pcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 30px;box-shadow:var(--shadow-soft)}
  .pcard .pic{width:58px;height:58px;border-radius:15px;display:grid;place-items:center;margin-bottom:22px}
  .pic.red{background:var(--red-bg);color:var(--red)}
  .pcard h3{font-size:21px;margin-bottom:12px}
  .pcard p{color:var(--ink-soft);font-size:15px}

  /* ===== SOLUTION ===== */
  .split{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center}
  .sol-visual{position:relative;background:#fff;border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:var(--shadow);overflow:hidden}
  .sol-visual:before{content:"";position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(216,168,56,.22),transparent 70%);top:-60px;right:-60px}
  .sol-dark{position:relative;background:var(--navy);border-radius:16px;padding:22px;display:flex;align-items:center;gap:16px;margin-bottom:18px}
  .sol-dark .ic{width:46px;height:46px;border-radius:12px;background:var(--gold);display:grid;place-items:center;flex:none;color:#1c1402}
  .sol-dark .tt{color:var(--gold-2);font-weight:700;font-size:15px}
  .sol-dark .ds{color:#b9c6dc;font-size:13px}
  .sol-light{position:relative;background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px}
  .sol-light .row{display:flex;align-items:center;gap:10px;color:var(--green);font-weight:700;font-size:15px;margin-bottom:8px}
  .sol-light p{color:var(--ink-soft);font-size:14px}
  .feat{display:flex;gap:18px;margin-top:26px}
  .feat .fic{width:46px;height:46px;border-radius:12px;background:rgba(216,168,56,.14);color:var(--gold-deep);display:grid;place-items:center;flex:none}
  .feat h4{font-size:18px;font-weight:700;margin-bottom:4px}
  .feat p{color:var(--ink-soft);font-size:14.5px}

  /* ===== PROJECTS ===== */
  .filterbar{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:46px}
  .filt{font-family:inherit;font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;padding:13px 26px;border-radius:12px;border:1.5px solid var(--line);background:#fff;color:var(--ink-soft);cursor:pointer;transition:.18s}
  .filt.active{background:var(--navy);color:#fff;border-color:var(--navy)}
  .proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  .proj{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .2s,box-shadow .2s}
  .proj:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
  .proj .img{position:relative;aspect-ratio:16/11;overflow:hidden}
  .proj .img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .badge{position:absolute;top:14px;left:14px;z-index:2;background:var(--navy);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:6px 12px;border-radius:8px}
  .proj .body{padding:22px 24px}
  .proj h3{font-size:20px;margin-bottom:8px}
  .proj .desc{color:var(--ink-faint);font-size:14px;margin-bottom:16px}
  .specs{border-top:1px solid var(--line);padding-top:14px;margin-bottom:18px}
  .spec{display:flex;align-items:center;gap:10px;color:var(--ink-soft);font-size:14px;margin:9px 0;font-weight:500}
  .spec svg{width:17px;height:17px;color:var(--gold-deep);flex:none}
  .proj .foot{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
  .price-lbl{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-faint)}
  .price{font-size:20px;font-weight:800;color:var(--ink)}
  .proj .foot .btn{padding:12px 16px;font-size:12px;letter-spacing:.04em}

  /* ===== BINA ATAS TANAH ===== */
  .bat .split{gap:66px}
  .ticks{margin:26px 0 32px}
  .tick{display:flex;gap:14px;align-items:flex-start;margin:16px 0}
  .tick .c{width:26px;height:26px;border-radius:50%;background:var(--green-bg);color:var(--green);display:grid;place-items:center;flex:none;margin-top:1px}
  .tick .c svg{width:15px;height:15px}
  .tick p{color:var(--ink-soft);font-size:15.5px}
  .tick b{color:var(--ink);font-weight:600}
  .bat-img{border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:5/4}
  .bat-img img{width:100%;height:100%;object-fit:cover;display:block}
  .hero-card img.hero-photo{display:block;width:100%;aspect-ratio:4/3;object-fit:cover}

  /* ===== PROCESS (dark) ===== */
  .steps{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
  .step{background:rgba(255,255,255,.025);border:1px solid var(--navy-line);border-radius:16px;padding:28px 20px;text-align:center}
  .step .num{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:22px;margin:0 auto 18px;background:var(--gold);color:#000;box-shadow:0 0 0 6px rgba(216,168,56,.16)}
  .step.first .num{background:var(--gold);color:#000;box-shadow:0 0 0 6px rgba(216,168,56,.16)}
  .step h4{color:#fff;font-size:15px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px}
  .step p{color:#94a6c2;font-size:13.5px}

  /* ===== CALCULATOR ===== */
  .calc-sec{background:linear-gradient(160deg,#11203b,var(--navy-deep));color:#fff}
  .calc-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:40px;align-items:stretch}
  .calc-panel{background:rgba(255,255,255,.04);border:1px solid var(--navy-line);border-radius:var(--r-lg);padding:34px}
  .calc-panel h3{color:#fff;font-size:22px;margin-bottom:6px}
  .calc-panel .sub{color:#9fb0c9;font-size:14px;margin-bottom:26px}
  .field{margin-bottom:20px}
  .field label{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;font-weight:600;color:#cdd9ec;margin-bottom:9px}
  .field .val{color:var(--gold-2);font-weight:700}
  .field input[type=number]{width:100%;font-family:inherit;font-size:16px;font-weight:600;color:#fff;background:rgba(255,255,255,.05);border:1px solid var(--navy-line);border-radius:11px;padding:13px 15px;transition:border .15s}
  .field input[type=number]:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(216,168,56,.16)}
  .field .pre{position:relative}
  .field .pre span{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:#7d90b0;font-weight:600;font-size:15px;pointer-events:none}
  .field .pre input{padding-left:46px}
  input[type=range]{-webkit-appearance:none;width:100%;height:6px;border-radius:6px;background:rgba(255,255,255,.14);outline:none;margin-top:4px}
  input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--gold);cursor:pointer;border:3px solid #1a2c49;box-shadow:0 2px 8px rgba(0,0,0,.4)}
  input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--gold);cursor:pointer;border:3px solid #1a2c49}
  .seg{display:flex;background:rgba(255,255,255,.05);border:1px solid var(--navy-line);border-radius:11px;padding:5px;gap:5px}
  .seg button{flex:1;font-family:inherit;font-weight:600;font-size:13.5px;color:#a9bbd6;background:none;border:none;padding:11px;border-radius:8px;cursor:pointer;transition:.15s}
  .seg button.on{background:var(--gold);color:#1c1402}
  /* result */
  .calc-result{background:#fff;color:var(--ink);border-radius:var(--r-lg);padding:34px;display:flex;flex-direction:column;box-shadow:0 30px 60px -28px rgba(0,0,0,.55)}
  .res-top{border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:22px}
  .res-top .lbl{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
  .res-big{font-size:clamp(34px,5vw,46px);font-weight:800;letter-spacing:-.02em;color:var(--navy);margin-top:6px;line-height:1.05}
  .res-note{font-size:13px;color:var(--ink-soft);margin-top:8px}
  .res-rows{display:grid;gap:14px;margin-bottom:8px}
  .res-row{display:flex;justify-content:space-between;align-items:center;font-size:14.5px}
  .res-row .k{color:var(--ink-soft)}
  .res-row .v{font-weight:700;color:var(--ink)}
  .dsr{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-radius:12px;padding:14px 16px;margin:18px 0}
  .dsr .left{font-size:13.5px;color:var(--ink-soft);font-weight:500}
  .dsr .pill{font-size:12.5px;font-weight:700;padding:6px 12px;border-radius:999px}
  .pill.good{background:var(--green-bg);color:var(--green)}
  .pill.mid{background:#fff3df;color:#b07908}
  .pill.bad{background:var(--red-bg);color:var(--red)}
  .alert{display:none;background:var(--red-bg);border:1px solid #f6c9c9;border-radius:12px;padding:16px 18px;margin-bottom:18px}
  .alert.show{display:block}
  .alert b{color:var(--red);display:block;margin-bottom:4px;font-size:14.5px}
  .alert p{color:#9a4444;font-size:13.5px}
  .alert .btn{margin-top:12px;background:var(--navy);color:#fff;font-size:13px;padding:11px 18px}
  .res-foot{margin-top:auto;padding-top:22px}
  .res-foot .btn{width:100%}
  .disclaimer{font-size:11.5px;color:var(--ink-faint);margin-top:14px;line-height:1.5}

  /* ===== TESTIMONIALS ===== */
  .tcards{display:grid;grid-template-columns:1fr 1fr;gap:28px}
  .tcard{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 32px;position:relative}
  .tcard .q{position:absolute;top:24px;right:28px;font-size:52px;line-height:1;color:#dfe4ea;font-weight:800;font-family:Georgia,serif}
  .tcard .head{display:flex;align-items:center;gap:16px;margin-bottom:18px}
  .ava{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#2a3f63,#152846);color:var(--gold-2);display:grid;place-items:center;font-weight:700;font-size:18px;flex:none;border:2px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.12)}
  .tcard .nm{font-weight:700;font-size:16px;color:var(--ink)}
  .tcard .role{font-size:12.5px;color:var(--ink-faint);font-weight:500}
  .tcard .txt{color:var(--ink-soft);font-style:italic;font-size:15px;line-height:1.7}

  /* ===== FINAL CTA ===== */
  .cta{background:radial-gradient(120% 150% at 50% -20%,#21407a,var(--navy) 55%);color:#fff;text-align:center;padding:84px 0}
  .cta h2{color:#fff;font-size:clamp(28px,4vw,42px);margin-bottom:16px}
  .cta p{color:#a9bbd6;max-width:560px;margin:0 auto 30px;font-size:17px}
  .cta .row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

  /* ===== FOOTER ===== */
  footer{background:var(--navy-deep);color:#cdd8ea;padding:66px 0 30px}
  .foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--navy-line)}
  .foot-about p{color:#8497b4;font-size:14px;margin-top:18px;max-width:330px}
  .foot h5{color:var(--gold-2);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:20px}
  .foot ul{list-style:none}
  .foot ul li{margin-bottom:13px}
  .foot ul a{color:#b6c4da;font-size:14.5px;transition:color .15s}
  .foot ul a:hover{color:var(--gold-2)}
  .foot-contact .ci{display:flex;align-items:center;gap:12px;margin-bottom:15px;color:#b6c4da;font-size:14.5px}
  .foot-contact .ci svg{width:18px;height:18px;color:var(--gold-2);flex:none}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;flex-wrap:wrap;gap:12px}
  .foot-bottom .cr{color:#7387a5;font-size:13.5px}
  .foot-bottom .lk{display:flex;gap:18px;align-items:center;color:#9fb0c9;font-size:13.5px}
  .foot-bottom .lk a:hover{color:var(--gold-2)}

  /* ===== WHATSAPP FLOAT ===== */
  .wa{position:fixed;right:22px;bottom:22px;z-index:50;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.6);transition:transform .2s}
  .wa:hover{transform:scale(1.07)}
  .wa svg{width:32px;height:32px;color:#fff}

  /* ===== REVEAL ===== */
  .rv{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
  .rv.in{opacity:1;transform:none}

  /* ===== RESPONSIVE ===== */
  @media(max-width:980px){
    nav.links,.nav-cta:not(.mobile-menu .nav-cta){display:none}
    .burger{display:block}
    .hero .wrap,.split,.calc-grid{grid-template-columns:1fr;gap:40px}
    .cards-3,.proj-grid{grid-template-columns:1fr}
    .steps{grid-template-columns:1fr 1fr}
    .tcards,.foot-grid{grid-template-columns:1fr}
    .foot-grid{gap:30px}
  }
  @media(max-width:560px){
    .wrap{padding:0 18px}
    .sec-pad{padding:64px 0}
    .steps{grid-template-columns:1fr}
    .hero .wrap{padding-top:50px;padding-bottom:60px}
    .nav{height:72px}
    header{position:sticky}
    .mobile-menu{inset:72px 0 0}
    .proj .foot{flex-direction:column;align-items:flex-start}
  }

/* ============ MULTI-PAGE COMPONENTS ============ */
nav.links a.active{color:var(--gold-deep)}
.phero{background:radial-gradient(120% 130% at 75% 0%,#19305a,var(--navy) 45%,var(--navy-deep));color:#fff;position:relative;overflow:hidden}
.phero .wrap{position:relative;padding:60px 24px 68px;max-width:900px;text-align:center}
.phero h1{color:#fff;font-size:clamp(30px,4.6vw,50px);margin:16px auto 18px;max-width:840px}
.phero h1 .grad{background:linear-gradient(100deg,var(--gold) 10%,var(--gold-2) 60%,#f3dd9a 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.phero p.lead{color:#fff;font-size:17.5px;max-width:700px;margin:0 auto 30px}
.phero .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.crumb{font-size:13px;color:#8497b4;letter-spacing:.03em}
.crumb a{color:#a9bbd6}
.crumb a:hover{color:var(--gold-2)}
.psec{padding:80px 0}
.center-head{text-align:center;max-width:780px;margin:0 auto 46px}
.center-head h2{font-size:clamp(26px,3.8vw,42px)}
.center-head p{color:var(--ink-soft);font-size:17px;margin-top:12px}
.dark .center-head h2{color:#fff}
.dark .center-head p{color:#9fb0c9}
.prose{max-width:720px;margin:0 auto;text-align:center}
.prose p{color:var(--ink-soft);font-size:17px;margin-bottom:14px}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:14px 26px;max-width:900px;margin:0 auto}
.check{display:flex;gap:13px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow-soft)}
.check .ic{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex:none;margin-top:1px}
.check .ic svg{width:16px;height:16px}
.check.x .ic{background:var(--red-bg);color:var(--red)}
.check.v .ic{background:var(--green-bg);color:var(--green)}
.check p{font-size:15px;color:var(--ink);font-weight:500}
.dark .check{background:rgba(255,255,255,.04);border-color:var(--navy-line)}
.dark .check p{color:#dbe4f1}
.steps-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:18px}
.ba{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:900px;margin:0 auto}
.ba-card{border-radius:var(--r-lg);padding:30px;border:1px solid var(--line)}
.ba-card.before{background:#fdf3f3;border-color:#f3d4d4}
.ba-card.after{background:#eef9f2;border-color:#cdeede}
.ba-card h3{font-size:21px;margin-bottom:16px}
.ba-card .li{display:flex;gap:11px;align-items:center;margin:13px 0;font-size:15px;color:var(--ink);font-weight:500}
.ba-card .li svg{width:20px;height:20px;flex:none}
.gal{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}
.gal .g{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-soft)}
.gal .g .ph2{aspect-ratio:4/3;display:grid;place-items:center;background:radial-gradient(100% 80% at 60% 20%,#e7ecf3,#f3f5f8)}
.gal .g .lbl{padding:15px 16px;font-weight:600;color:var(--ink);text-align:center;font-size:15.5px}
.factors{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:16px;max-width:960px;margin:0 auto}
.factor{display:flex;gap:13px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow-soft);font-weight:600;color:var(--ink);font-size:15px}
.factor .ic{width:42px;height:42px;border-radius:11px;background:rgba(216,168,56,.14);color:var(--gold-deep);display:grid;place-items:center;flex:none}
.factor .ic svg{width:22px;height:22px}
.faq{max-width:800px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-soft)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 22px;cursor:pointer;font-weight:600;font-size:16.5px;color:var(--ink)}
.faq-q .arw{transition:transform .25s;color:var(--gold-deep);flex:none;display:flex}
.faq-item.open .arw{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--ink-soft);font-size:15.5px}
.faq-a div{padding:0 22px 20px}
.lead{max-width:640px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow)}
.lead .fg{margin-bottom:17px}
.lead label{display:block;font-size:13.5px;font-weight:600;margin-bottom:8px;color:var(--ink)}
.lead input[type=text],.lead input[type=tel],.lead input[type=number]{width:100%;font-family:inherit;font-size:15px;padding:13px 15px;border:1px solid var(--line);border-radius:11px;background:#fff;color:var(--ink)}
.lead input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(216,168,56,.16)}
.opts{display:flex;flex-direction:column;gap:10px}
.opt{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:11px;padding:13px 15px;cursor:pointer;font-size:14.5px;color:var(--ink);font-weight:500;transition:.15s}
.opt input{accent-color:var(--gold-deep);width:17px;height:17px}
.opt.sel{border-color:var(--gold);background:rgba(216,168,56,.09)}
.cta .row .btn{display:inline-flex}
@media(max-width:760px){.checks,.ba{grid-template-columns:1fr}}

/* ============ TESTIMONI PHOTO GALLERY ============ */
.tgal{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px}
.tgal .tg{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-soft);background:#fff;transition:transform .2s,box-shadow .2s}
.tgal .tg:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tgal .tg img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.tgal .tg .cap{display:flex;align-items:center;gap:9px;padding:13px 16px;font-size:13px;font-weight:600;color:var(--ink-soft)}
.tgal .tg .cap svg{width:16px;height:16px;color:#1aa35a;flex:none}

/* ============ PAKEJ SHOWCASE (Bina Banglo) ============ */
.pkg{display:grid;grid-template-columns:1.02fr 1fr;gap:44px;align-items:center;margin-bottom:50px}
.pkg:last-of-type{margin-bottom:0}
.pkg.rev .pkg-media{order:2}
.pkg-media{display:flex;flex-direction:column;gap:12px}
.pkg-media .m0{border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:16/10}
.pkg-media .thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pkg-media .thumbs .t{border-radius:12px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-soft);aspect-ratio:4/3}
.pkg-media img{width:100%;height:100%;object-fit:cover;display:block}
.pkg-info .tier{display:inline-block;background:var(--gold);color:#1c1402;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:8px;margin-bottom:14px}
.pkg-info h3{font-size:clamp(22px,3vw,30px);margin-bottom:5px}
.pkg-info .sub{color:var(--gold-deep);font-weight:700;font-size:14px;margin-bottom:14px}
.pkg-info p.d{color:var(--ink-soft);font-size:15px;line-height:1.7;margin-bottom:18px}
.pkg-info .pspecs{list-style:none;margin:0 0 20px;padding:0}
.pkg-info .pspecs li{display:flex;align-items:flex-start;gap:11px;margin:11px 0;color:var(--ink-soft);font-size:14.5px;font-weight:500}
.pkg-info .pspecs li svg{width:18px;height:18px;color:var(--gold-deep);flex:none;margin-top:1px}
.pkg-price{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.pkg-price .pl{font-size:11.5px;color:var(--ink-faint);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.pkg-price .pp{font-size:24px;font-weight:800;color:var(--navy);line-height:1.1}
@media(max-width:860px){.pkg{grid-template-columns:1fr;gap:24px;margin-bottom:40px}.pkg.rev .pkg-media{order:0}}

/* real image inside .gal cards (portfolio) */
.gal .g .gimg{aspect-ratio:4/3;overflow:hidden}
.gal .g .gimg img{width:100%;height:100%;object-fit:cover;display:block}


/* ===== FIX: hero description — remove white box (collision with form .lead) ===== */
p.lead{background:none;border:none;box-shadow:none;padding:0}

/* ===== Portfolio gallery: 3 per row on desktop ===== */
.gal.g3{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.gal.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gal.g3{grid-template-columns:1fr}}

/* ===== Anggaran Kos: 1 faktor = 1 baris ===== */
.factors.col1{grid-template-columns:1fr;max-width:560px}

/* ===== Proses: 3 kotak per baris (Nak Bina Kelayakan) ===== */
.steps-auto.s3{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.steps-auto.s3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.steps-auto.s3{grid-template-columns:1fr}}

/* ===== Form radio options: jarak & sebaris dengan tick ===== */
.opts .opt{display:flex;gap:14px;align-items:center}
.opts .opt input{flex:none;width:18px;height:18px;margin:0}
