:root{--bg:#f6f7f9;--surface:#ffffff;--surface-2:#f1f3f5;--text:#1a1f2b;--muted:#6b7280;--primary:#ACB392;--primary-700:#8E9675;--accent:#ffd166;--container:1140px;--radius:16px;--shadow:0 8px 24px rgba(0,0,0,.12)}*{box-sizing:border-box}html{scroll-behavior:smooth;scrollbar-gutter:stable}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.6}
@supports not (scrollbar-gutter: stable){html{overflow-y:scroll}}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block;border-radius:12px}
p{color:var(--text);line-height:1.6}
.container{width:min(var(--container),92vw);margin:0 auto}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.2rem;border-radius:999px;background:rgba(0,0,0,.04);color:var(--text);border:1px solid rgba(0,0,0,.08);backdrop-filter:blur(8px);transition:all .2s ease;font-weight:600;letter-spacing:.2px;line-height:1}
.btn:hover{transform:translateY(-1px);background:rgba(0,0,0,.07)}
.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn.primary:hover{background:var(--primary-700)}
.btn.outline{background:transparent;border:1px solid var(--primary);color:var(--primary-700)}
.btn.outline:hover{background:rgba(172,179,146,.12)}
/* Olive variant to keep brand color consistent */
.btn.olive{border-color:var(--primary)}
.btn.primary.olive{background:var(--primary);border-color:var(--primary);color:#fff}
.btn.primary.olive:hover{background:var(--primary-700)}
.btn.outline.olive{border-color:var(--primary);color:var(--primary-700)}
.btn.outline.olive:hover{background:rgba(172,179,146,.12)}
/* Focus, active, and disabled states */
.btn:focus-visible{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px rgba(142,150,117,.45)}
.btn:active{transform:translateY(0);filter:brightness(.98)}
.btn[disabled],.btn.disabled{opacity:.6;pointer-events:none}
/* Tiny size variant for compact contexts */
.btn.tiny{padding:.45rem .7rem;font-size:.88rem}

.site-header{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.06)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}
.brand{display:flex;align-items:center;gap:.55rem;font-weight:700;letter-spacing:.2px;flex:1 1 auto}
.brand-logo{width:34px;height:34px;border-radius:50%;object-fit:cover;flex-shrink:0}
.brand-text{display:block;white-space:normal;overflow:visible;text-overflow:unset;max-width:100%;overflow-wrap:anywhere;letter-spacing:.8px;flex:1 1 auto;min-width:0}
/* Utility class to elongate any span/text when needed */
.elongated{display:inline-block;letter-spacing:.8px;word-spacing:.1rem;overflow-wrap:anywhere}
.nav{position:relative}
.nav-toggle{display:none;align-items:center;justify-content:center;border:1px solid rgba(0,0,0,.12);background:#fff;color:var(--text);cursor:pointer;border-radius:12px;width:40px;height:40px;box-shadow:var(--shadow)}
.nav-toggle:focus-visible{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px rgba(142,150,117,.45)}
.nav-items{list-style:none;display:flex;gap:1rem;margin:0;padding:0;align-items:center}
.nav-items a{padding:.6rem .8rem;border-radius:999px;display:inline-flex;align-items:center}
/* Hover umum untuk desktop; akan dioverride khusus mobile */
.nav-items a:hover{background:rgba(255,255,255,.08)}

.hero{position:relative}
.slides{position:relative;height:72vh;min-height:540px;overflow:hidden}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.02);transition:opacity .6s ease,transform 1.2s ease}
.slide.active{opacity:1;transform:scale(1)}
.slide .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(172,179,146,.20) 0%,rgba(172,179,146,.40) 55%,rgba(255,255,255,.88) 100%)}
.hero-content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:3rem}
.hero-content{gap:.6rem}
/* Static hero variant (no slider) */
.hero.hero-static{height:72vh;min-height:540px;overflow:hidden}
.hero.hero-static .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.02)}
.hero.hero-static .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.48) 0%,rgba(0,0,0,.48) 100%)}
.hero.hero-static .hero-content{justify-content:center;padding-bottom:0}
.hero.hero-static .hero-content .subtitle{margin-top:.2rem}
.hero h1{font-size:clamp(2rem,4vw,3rem);line-height:1.2;margin:0 0 .4rem;color:#fff}
.hero p{color:#fff;margin:0 0 1rem}
.benefits{display:flex;flex-wrap:wrap;gap:.6rem;margin:1rem 0}
.badge{display:inline-flex;align-items:center;padding:.5rem .7rem;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);font-size:.9rem}
.note{display:block;color:var(--muted);margin-top:.6rem}
.slide-controls{position:absolute;bottom:1rem;left:0;right:0;display:flex;justify-content:space-between;align-items:center}
.control{display:inline-flex;align-items:center;justify-content:center;background:rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.12);color:var(--text);border-radius:999px;padding:.4rem;cursor:pointer;backdrop-filter:blur(8px)}
.control:hover{background:rgba(0,0,0,.1)}
/* Keep CTA tight inside hero */
.hero .btn{width:auto;max-width:max-content;align-self:flex-start}
/* Bullet list & price styles in hero */
.hero-points{list-style:none;margin:.6rem 0 1rem;padding:0;color:#fff}
.hero-points li{display:flex;align-items:center;gap:.5rem;margin:.25rem 0}
.hero-points li::before{content:'\2713';display:inline-block;color:#a5d6a7;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);width:22px;height:22px;border-radius:999px;line-height:22px;text-align:center;font-weight:700}
.price{color:#fff;font-weight:700;margin:.4rem 0 1rem;border-left:4px solid var(--primary);padding-left:12px}

.features{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:2rem 0}
.feature{padding:1.2rem;border-radius:16px;background:linear-gradient(180deg,rgba(0,0,0,.03),rgba(0,0,0,.01));border:1px solid rgba(0,0,0,.08);display:flex;align-items:center;gap:.9rem;box-shadow:var(--shadow)}
.feature .icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;background:rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.12)}
.feature h3{margin:0;font-size:1rem}

.units{padding:2rem 0}
.units h2,.location h2,.facilities h2,.cta h2{margin:0 0 1rem}
.unit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;align-items:stretch}
@media (max-width: 640px){.unit-grid{grid-template-columns:1fr}}
.unit-card{background:var(--surface);border:1px solid rgba(0,0,0,.08);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;height:100%}
/* Badge status untuk unit non-cluster */
.unit-card{position:relative}
.unit-card .status-badge{position:absolute;top:8px;left:8px;background:#f44336;color:#fff;font-weight:700;font-size:.85rem;padding:.32rem .6rem;border-radius:999px;box-shadow:var(--shadow);letter-spacing:.4px;text-transform:uppercase;z-index:2}
.unit-card.sold img{filter:grayscale(100%)}
.unit-info{padding:1rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.specs{list-style:none;padding:0;margin:.5rem 0 1rem;color:var(--muted);display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem}
/* Clamp judul dan item specs agar kartu tidak terlalu tinggi */
.unit-card .unit-info h3{margin:0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-clamp:2}
.unit-card .specs li{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;line-clamp:1}

.location{padding:2rem 0}
.location-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.loc-card{background:var(--surface);border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:1rem;box-shadow:var(--shadow)}
.loc-card h4{margin:.2rem 0 .7rem}
.loc-card ul{list-style:none;padding:0;margin:0;color:var(--muted);display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}
.loc-card li{padding:.15rem .4rem}

.facilities{padding:2rem 0}
.facility-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.facility{background:linear-gradient(180deg,rgba(0,0,0,.03),rgba(0,0,0,.01));border:1px solid rgba(0,0,0,.08);border-radius:14px;padding:.9rem;display:flex;align-items:center;gap:.6rem;box-shadow:var(--shadow)}

/* About section */
.about{padding:2rem 0;text-align:center}
.about h2{margin:0 0 1rem}
/* Paragraf tanpa card: nyaman dibaca */
.about p{max-width:980px;margin:.6rem auto;color:var(--text);text-align:center;line-height:1.8}
/* Ikon ringkas untuk ringkasan penawaran */
.about-icons{display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem;margin:0 0 1rem}
.about-icons .item{display:flex;flex-direction:column;align-items:center;gap:.35rem;background:linear-gradient(180deg,rgba(0,0,0,.03),rgba(0,0,0,.01));border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:.7rem .9rem;min-width:120px}
.about-icons .icon{font-size:28px;color:var(--primary)}
.about-icons .label{font-weight:600;font-size:.92rem}

.cta{padding:2.2rem 0;background:linear-gradient(180deg,rgba(172,179,146,.14),rgba(172,179,146,.05));border-top:1px solid rgba(0,0,0,.08);border-bottom:1px solid rgba(0,0,0,.08)}
.cta p{color:var(--text)}
.cta-actions{display:flex;gap:.8rem;margin-top:1rem}
/* Align CTA inside unit-card to bottom and match cluster style */
.unit-card .cta-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:auto}
.unit-card .cta-actions .btn{min-width:140px;min-height:44px;justify-content:center;margin-top:0;flex:1 1 0}

/* Typography consistency for action buttons */
.cta-actions .btn,.cluster-actions .btn{font-weight:600;letter-spacing:.2px;line-height:1}

.site-footer{border-top:1px solid rgba(0,0,0,.08);padding:1.4rem 0;color:var(--muted)}
.site-footer .footer-content{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.site-footer .footer-social{display:flex;align-items:center;gap:12px}
.site-footer .footer-social .social{display:inline-flex;align-items:center;gap:6px;color:inherit;text-decoration:none;padding:6px 10px;border-radius:8px;border:1px solid rgba(0,0,0,.08)}
.site-footer .footer-social .social:hover{background:rgba(0,0,0,.04)}
.site-footer .footer-social .social svg,.site-footer .footer-social .social img{width:18px;height:18px;display:inline-block;vertical-align:middle;flex-shrink:0}

/* Reveal targets: do not hide cluster/unit cards by default */
.feature,.loc-card,.facility,.cta .container{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.feature.visible,.loc-card.visible,.facility.visible,.cta .container.visible{opacity:1;transform:none}
/* Ensure cluster/unit cards are visible even if reveal script fails */
.cluster-card,.unit-card{opacity:1;transform:none}

/* Clusters Section */
.clusters{padding:80px 0}
.clusters .container>h2{margin-bottom:8px}
.clusters .container>p{color:var(--muted);margin-bottom:24px}
/* Back button wrapper */
.page-actions{margin-bottom:12px}
.page-actions .btn{gap:.4rem}
/* Cluster grid layout */
.clusters .cluster-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
@media (max-width: 992px){.clusters .cluster-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 640px){.clusters .cluster-grid{grid-template-columns:1fr}}

/* Global cluster grid for pages without .clusters wrapper */
.cluster-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
@media (max-width: 992px){.cluster-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 640px){.cluster-grid{grid-template-columns:1fr}}

/* Khusus katalog Non-Cluster: tetap 3 kolom */
#noncluster-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width: 992px){#noncluster-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 640px){#noncluster-grid{grid-template-columns:1fr}}

/* Spacing saat noncluster-grid ditampilkan di beranda (section .clusters) */
.clusters #noncluster-grid{margin-top:16px}

/* Cluster card tidy styles */
.cluster-card{background:var(--surface);border:1px solid rgba(0,0,0,.08);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;cursor:pointer;display:flex;flex-direction:column;height:100%}
.cluster-card .thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:#f5f5f5;border-radius:16px 16px 0 0}
.cluster-card .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.cluster-card .thumb .status-badge{position:absolute;top:8px;left:8px;background:#f44336;color:#fff;font-weight:700;font-size:.85rem;padding:.32rem .6rem;border-radius:999px;box-shadow:var(--shadow);letter-spacing:.4px;text-transform:uppercase;z-index:2}
.cluster-card .thumb .status-badge.sold{background:#f44336}
/* Status badge untuk sisa kavling & ruko */
.cluster-card .thumb .status-badge.remaining{background:#ffeb3b;color:#000}
/* Grayscale untuk unit cluster yang sudah terjual */
.cluster-card.sold .thumb img{filter:grayscale(100%)}
/* Grayscale untuk unit yang tidak aktif namun masih ada sisa kavling/ruko */
.cluster-card.dim .thumb img{filter:grayscale(100%)}
.cluster-card[data-focus="top"] .thumb img{object-position:top center}
.cluster-card .cluster-info{padding:14px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.cluster-card h3{margin:0 0 4px;font-size:1.1rem;line-height:1.28;font-weight:700;letter-spacing:.2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;overflow:hidden}
.cluster-card .meta{margin:0;color:var(--muted);font-size:.96rem;line-height:1.4;letter-spacing:.1px}
.cluster-card .summary{margin:6px 0 0;color:var(--muted);font-size:.98rem;line-height:1.45;letter-spacing:.06px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;line-clamp:3;overflow:hidden}
.cluster-card .btn{margin-top:auto;min-width:140px;align-self:flex-start;width:auto}
/* Actions container for cluster cards: keeps CTAs aligned and at bottom */
.cluster-card .cluster-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:auto}
/* Inside actions container: make both buttons same size and centered */
.cluster-card .cluster-actions .btn{margin-top:0;min-width:140px;min-height:44px;justify-content:center;flex:1 1 0}
.cluster-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.08)}
/* Aturan thumb img sudah didefinisikan di atas; duplikasi dihapus untuk kerapian */
.cluster-card .cluster-hero img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:10px;box-shadow:var(--shadow)}
.info-grid .card{background:var(--surface);border-radius:10px;box-shadow:var(--shadow);padding:10px}
.info-grid th,.info-grid td{padding:8px;border-bottom:1px dashed rgba(0,0,0,.12)}
.cluster-info .meta{color:var(--muted);margin:0 0 8px}
/* .legend .item didefinisikan ulang di bagian Siteplan legend di bawah untuk konsistensi; duplikasi dihapus */
.gallery-grid img{width:100%;border-radius:12px;box-shadow:var(--shadow)}
/* .specs-block .item dikonsolidasikan pada blok utama di bawah; duplikasi dihapus */
.promo{background:rgba(125, 141, 90, 0.08);border:1px solid rgba(0,0,0,.08);border-radius:14px;padding:16px}
.promo h3{margin:0 0 8px}
.promo ul{margin:0;padding-left:18px}

/* CTA improvements for detail page reuse */
.cta .container .cta-actions .btn.primary{min-width:180px}
@media (max-width:1024px){
  .slides{height:64vh}
  .features{grid-template-columns:repeat(3,1fr)}
  .facility-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:820px){
  .nav-toggle{display:flex}
  /* Dropdown nav versi mobile: kontras lebih baik dan tombol full width */
  .nav-items{position:absolute;right:12px;top:calc(100% + .5rem);background:rgba(12,16,21,.9);color:#fff;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px;display:none;flex-direction:column;min-width:220px;max-width:calc(100vw - 24px);gap:.5rem;z-index:100}
  .nav.open .nav-items{display:flex}
  /* Link biasa memenuhi lebar panel dan teks putih */
  .nav-items a{color:#fff;width:100%;justify-content:flex-start;padding:.8rem 1rem;border-radius:10px}
  /* Hover hanya untuk link biasa, tidak mengganggu .btn */
  .nav-items a:not(.btn):hover{background:rgba(255,255,255,.12)}
  /* Tombol Book Now dibuat full width & centered */
  .nav-items .btn{width:100%;justify-content:center;margin-top:.2rem}
  .slides{height:58vh}
  .features{grid-template-columns:repeat(2,1fr)}
  .unit-grid{grid-template-columns:1fr}
  .location-grid{grid-template-columns:1fr}
  .facility-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:520px){
  .hero h1{font-size:1.8rem}
  .badge{font-size:.85rem}
  .cta-actions{flex-direction:column}
}
/* WhatsApp Floating Chat */
.wa-widget{position:fixed;bottom:84px;right:20px;z-index:50}
@media(max-width:768px){
  .wa-widget{bottom:96px}
}
.wa-floating-button{gap:.4rem;box-shadow:var(--shadow);border-radius:999px;padding:.7rem 1rem}
.wa-widget .wa-label{font-weight:600}
.wa-panel{display:none;position:fixed;bottom:80px;right:20px;width:min(92vw,360px);background:var(--surface);border:1px solid rgba(0,0,0,.12);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;opacity:0;transform:translateY(12px);transition:opacity .25s ease,transform .25s ease}
.wa-widget.open .wa-panel{display:block;opacity:1;transform:none}
.wa-header{display:flex;align-items:center;gap:.8rem;padding:.8rem;border-bottom:1px solid rgba(0,0,0,.08)}
.wa-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}
.wa-meta{display:flex;flex-direction:column;line-height:1.2}
.wa-meta .status{color:var(--muted);font-size:.85rem}
.wa-close{margin-left:auto;border:none;background:transparent;color:var(--text);cursor:pointer;border-radius:10px;padding:.3rem}
.wa-body{padding:.8rem}
.wa-quick{display:flex;flex-wrap:wrap;gap:.4rem;margin:.6rem 0 .8rem}
.chip{background:rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.12);color:var(--text);padding:.4rem .6rem;border-radius:999px;cursor:pointer}
.chip:hover{background:rgba(0,0,0,.1)}
.wa-input{display:flex;gap:.5rem;align-items:center}
#wa-message{flex:1;background:var(--surface-2);border:1px solid rgba(0,0,0,.12);border-radius:12px;color:var(--text);padding:.6rem .7rem;outline:none}
.wa-input .send{white-space:nowrap;padding:.6rem .9rem}
@media (max-width:520px){.wa-panel{bottom:74px;right:10px;width:min(94vw,380px)}}

/* Mini clusters preview inside unit-card */
.unit-card .mini-clusters{margin:.6rem 0}
.unit-card .mini-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem}
@media(max-width:640px){.unit-card .mini-grid{grid-template-columns:repeat(2,1fr)}}
.unit-card .mini-card{background:var(--surface);border:1px solid rgba(0,0,0,.08);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.unit-card .mini-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.unit-card .mini-card .meta{padding:.5rem .6rem}
.unit-card .mini-card .meta .title{font-size:.88rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.unit-card .mini-card .btn.tiny{margin:.5rem .6rem;padding:.4rem .6rem;font-size:.85rem}
/* Hover affordance for unit cards */
.unit-card{transition:transform .18s ease,box-shadow .18s ease;will-change:transform,box-shadow}
@media (hover:hover){
  .unit-card:hover{transform:translateY(-3px);box-shadow:0 12px 24px rgba(0,0,0,.14)}
}
/* Keep snappy transitions after reveal */
.unit-card.visible{transition:transform .18s ease,box-shadow .18s ease}
/* Font: samakan dengan Non-Cluster agar gaya tombol konsisten */
.clusters, .cluster-modal {
  font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

/* Side Drawer Modal (Cluster) */
.cluster-modal{position:fixed;inset:0;z-index:1000;display:none}
.cluster-modal.open{display:block}
.cluster-modal .overlay{position:absolute;inset:0;background:rgba(0,0,0,.35)}
.cluster-modal .dialog{position:absolute;right:0;top:0;height:100vh;width:clamp(320px,48vw,560px);max-width:560px;background:#fff;box-shadow:-8px 0 24px rgba(0,0,0,.12);transform:translateX(100%);transition:transform .24s ease;display:flex;flex-direction:column;border-radius:0;--drawer-cta-h:84px}
@media(max-width:768px){.cluster-modal .dialog{width:100vw}}
.cluster-modal.open .dialog{transform:translateX(0)}

/* Drawer header */
.drawer-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.08);background:#fff;position:sticky;top:0;z-index:2}
.drawer-header .back{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(0,0,0,.12);color:var(--text);padding:.6rem 1rem;border-radius:12px;cursor:pointer;min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.drawer-header .back span[aria-hidden]{font-size:18px;line-height:1}
.drawer-header .back:hover{background:#f7f7f7}
.drawer-header .back:active{transform:translateY(1px)}
.drawer-header .title{margin:0;font-size:1rem;font-weight:600}
.drawer-header .modal-close{margin-left:auto;background:#fff;border:1px solid rgba(0,0,0,.12);color:var(--text);padding:.5rem;border-radius:12px;cursor:pointer;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center}
/* Modal header variant */
.cluster-modal .modal-header .modal-back{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(0,0,0,.12);color:var(--text);padding:.6rem 1rem;border-radius:12px;cursor:pointer;min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.cluster-modal .modal-header .modal-back span.material-symbols-outlined{font-size:20px}
.cluster-modal .modal-header .modal-back:hover{background:#f7f7f7}
.cluster-modal .modal-header .modal-back:focus-visible{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px rgba(142,150,117,.45)}

/* Drawer body */
.cluster-modal .modal-body{padding:12px 12px calc(var(--drawer-cta-h) + 12px);overflow-y:auto;flex:1;min-height:0}
.cluster-modal .section{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;box-shadow:var(--shadow);padding:12px;margin-bottom:12px}
.cluster-modal .section h3{margin:0 0 8px;font-size:.95rem}
.cluster-modal .cluster-hero img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:10px;box-shadow:var(--shadow)}
.cluster-modal .cluster-hero h2{margin:8px 0 4px;font-size:1.05rem}
.cluster-modal .info-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:10px}
@media(max-width:768px){.cluster-modal .info-grid{grid-template-columns:1fr}}
.cluster-modal table{width:100%;border-collapse:collapse}
.cluster-modal th,.cluster-modal td{padding:6px 8px;border-bottom:1px solid rgba(0,0,0,.08);text-align:left;font-size:.9rem}
.cluster-modal .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.cluster-modal .actions .btn{flex:1;min-width:140px}

/* Siteplan legend */
.legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.legend .item{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;color:var(--muted)}
.legend .dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.legend .dot.green{background:#4caf50}
.legend .dot.orange{background:#ff9800}
.legend .dot.red{background:#f44336}

.cluster-modal .siteplan img{width:100%;aspect-ratio:16/9;object-fit:contain;background:#f8f8f8;border-radius:10px;box-shadow:var(--shadow)}

/* Specs grid */
.specs-block .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.specs-block .item{background:var(--surface);border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:10px;box-shadow:var(--shadow)}
.specs-block .item strong{display:block;margin-bottom:4px;font-size:.9rem}
.promo-card{background:#fff4e7;border:1px dashed #f5b469;color:#7b4b27;border-radius:10px;padding:10px;margin-top:10px}

/* Gallery slider — improved UX */
.gallery .gallery-wrapper{position:relative}
.gallery .gallery-track{display:grid;grid-auto-flow:column;grid-auto-columns:100%;gap:12px;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;padding-bottom:8px;-ms-overflow-style:none;scrollbar-width:none}
.gallery .gallery-track::-webkit-scrollbar{display:none}
.gallery .gallery-track .item{flex:0 0 100%;max-width:100%;scroll-snap-align:center}
/* Always full width items to avoid ruang kosong */
@media(min-width:768px){.gallery .gallery-track .item{flex:0 0 100%;max-width:100%}}
.gallery .gallery-track .item .media{width:100%;aspect-ratio:16/9;border-radius:10px;box-shadow:var(--shadow);background:#f5f5f5;overflow:hidden}
.gallery .gallery-track .item img{width:100%;height:100%;object-fit:cover;display:block}
.gallery .gallery-nav{position:absolute;top:50%;transform:translateY(-50%);display:flex;gap:8px;z-index:2}
.gallery .gallery-nav.prev{left:6px}
.gallery .gallery-nav.next{right:6px}
.gallery .gallery-nav button{background:#fff;border:1px solid rgba(0,0,0,.12);box-shadow:var(--shadow);border-radius:50%;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.gallery .thumbs{display:flex;gap:8px;margin-top:8px;overflow-x:auto;padding-bottom:4px}
.gallery .thumbs .thumb{flex:0 0 auto;width:84px;height:56px;border-radius:8px;overflow:hidden;border:1px solid rgba(0,0,0,.08);cursor:pointer;opacity:.7}
.gallery .thumbs .thumb.active{opacity:1;border-color:#333}
.gallery .dots{display:flex;justify-content:center;gap:6px;margin-top:6px}
.gallery .dots .dot{width:6px;height:6px;border-radius:50%;background:rgba(0,0,0,.2)}
.gallery .dots .dot.active{background:#333}
/* Fallback untuk browser tanpa dukungan aspect-ratio */
@supports not (aspect-ratio: 1) {
  .gallery .gallery-track .item .media{position:relative;height:0;padding-top:56.25%}
  .gallery .gallery-track .item .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
}

/* Fixed CTA di bawah drawer */
/* padding modal-body telah dikonsolidasikan di atas; baris ini dihapus untuk menghindari duplikasi */
.drawer-cta{position:absolute;bottom:0;left:0;right:0;background:#fff;border-top:1px solid rgba(0,0,0,.08);box-shadow:0 -6px 16px rgba(0,0,0,.06);padding:12px;z-index:3;padding-bottom:calc(12px + env(safe-area-inset-bottom, 0px))}
.drawer-cta .cta-actions{display:flex;gap:10px;align-items:stretch}
.drawer-cta .cta-actions .btn{flex:1 1 0;min-height:44px;justify-content:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width:520px){
  .drawer-cta .cta-actions{flex-direction:column}
  .drawer-cta .cta-actions .btn{white-space:normal}
}

/* Olive button (non-primary variant only) */
.btn:not(.primary).olive{background:#C2C7B0;color:#fff;border-color:transparent}
.btn:not(.primary).olive:hover{background:#b5bca1}
/* Breadcrumb, Tabs, Filters for Non-Cluster */
.breadcrumb{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:.92rem;margin:8px 0 10px}
.breadcrumb a{color:inherit;text-decoration:none}
.breadcrumb .sep{opacity:.6}
.breadcrumb .current{color:var(--text)}

.banner.noncluster,.banner.cluster{background:linear-gradient(180deg,rgba(172,179,146,.12),rgba(172,179,146,.04));border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:16px}

.tabs-switch{display:flex;gap:8px;flex-wrap:wrap}
.tabs-switch .tab{display:inline-flex;align-items:center;gap:6px;padding:.42rem .8rem;border:1px solid rgba(0,0,0,.12);border-radius:999px;text-decoration:none;color:var(--text);background:rgba(0,0,0,.04)}
.tabs-switch .tab.active{background:#C2C7B0;color:#fff;border-color:#C2C7B0}

.filters{margin:10px 0 16px}
.filters-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.filters-bar .filter{background:var(--surface);border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:.6rem .7rem;box-shadow:var(--shadow)}
.filters-bar label{display:block;font-size:.86rem;color:var(--muted);margin-bottom:.3rem}
.filters-bar select{width:100%;background:var(--surface-2);border:1px solid rgba(0,0,0,.12);border-radius:10px;color:var(--text);padding:.5rem .6rem}
@media(max-width:768px){.filters-bar{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.filters-bar{grid-template-columns:1fr}}

.empty-state{background:var(--surface);border:1px dashed rgba(0,0,0,.18);border-radius:12px;padding:16px;text-align:center;color:var(--muted)}
.empty-state .icon{font-size:24px;display:block;margin-bottom:6px}
/* Uniform unit card thumbnails */
.unit-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.unit-card{transition:transform .18s ease,box-shadow .18s ease;will-change:transform,box-shadow}
@media (hover:hover){
  .unit-card:hover{transform:translateY(-3px);box-shadow:0 12px 24px rgba(0,0,0,.14)}
}
/* Keep snappy transitions after reveal */
.unit-card.visible{transition:transform .18s ease,box-shadow .18s ease}
/* Font override for Cluster section and modal */
.clusters, .cluster-modal {
  font-family: 'Poppins', Montserrat, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

/* Side Drawer Modal (Cluster) */
.cluster-modal{position:fixed;inset:0;z-index:1000;display:none}
.cluster-modal.open{display:block}
.cluster-modal .overlay{position:absolute;inset:0;background:rgba(0,0,0,.35)}
.cluster-modal .dialog{position:absolute;right:0;top:0;height:100vh;width:clamp(320px,48vw,560px);max-width:560px;background:#fff;box-shadow:-8px 0 24px rgba(0,0,0,.12);transform:translateX(100%);transition:transform .24s ease;display:flex;flex-direction:column;border-radius:0;--drawer-cta-h:84px}
@media(max-width:768px){.cluster-modal .dialog{width:100vw}}
.cluster-modal.open .dialog{transform:translateX(0)}

/* Drawer header */
.drawer-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.08);background:#fff;position:sticky;top:0;z-index:2}
.drawer-header .back{display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;color:var(--text);padding:6px 8px;border-radius:10px;cursor:pointer}
.drawer-header .title{margin:0;font-size:1rem;font-weight:600}
.drawer-header .modal-close{margin-left:auto;background:transparent;border:0;color:var(--text);padding:6px;border-radius:10px;cursor:pointer}

/* Drawer body */
.cluster-modal .modal-body{padding:12px 12px calc(var(--drawer-cta-h) + 12px);overflow-y:auto;flex:1;min-height:0}
.cluster-modal .section{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;box-shadow:var(--shadow);padding:12px;margin-bottom:12px}
.cluster-modal .section h3{margin:0 0 8px;font-size:.95rem}
.cluster-modal .cluster-hero img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:10px;box-shadow:var(--shadow)}
.cluster-modal .cluster-hero h2{margin:8px 0 4px;font-size:1.05rem}
.cluster-modal .info-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:10px}
@media(max-width:768px){.cluster-modal .info-grid{grid-template-columns:1fr}}
.cluster-modal table{width:100%;border-collapse:collapse}
.cluster-modal th,.cluster-modal td{padding:6px 8px;border-bottom:1px solid rgba(0,0,0,.08);text-align:left;font-size:.9rem}
.cluster-modal .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.cluster-modal .actions .btn{flex:1;min-width:140px}

/* Siteplan legend */
.legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.legend .item{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;color:var(--muted)}
.legend .dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.legend .dot.green{background:#4caf50}
.legend .dot.orange{background:#ff9800}
.legend .dot.red{background:#f44336}

.cluster-modal .siteplan img{width:100%;aspect-ratio:16/9;object-fit:contain;background:#f8f8f8;border-radius:10px;box-shadow:var(--shadow)}

/* Specs grid */
.specs-block .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.specs-block .item{background:var(--surface);border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:10px;box-shadow:var(--shadow)}
.specs-block .item strong{display:block;margin-bottom:4px;font-size:.9rem}
.promo-card{background:#fff4e7;border:1px dashed #f5b469;color:#7b4b27;border-radius:10px;padding:10px;margin-top:10px}

/* Gallery slider — improved UX */
.gallery .gallery-wrapper{position:relative}
.gallery .gallery-track{display:grid;grid-auto-flow:column;grid-auto-columns:100%;gap:12px;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;padding-bottom:8px;-ms-overflow-style:none;scrollbar-width:none}
.gallery .gallery-track::-webkit-scrollbar{display:none}
.gallery .gallery-track .item{flex:0 0 100%;max-width:100%;scroll-snap-align:center}
/* Always full width items to avoid ruang kosong */
@media(min-width:768px){.gallery .gallery-track .item{flex:0 0 100%;max-width:100%}}
.gallery .gallery-track .item .media{width:100%;aspect-ratio:16/9;border-radius:10px;box-shadow:var(--shadow);background:#f5f5f5;overflow:hidden}
.gallery .gallery-track .item img{width:100%;height:100%;object-fit:cover;display:block}
.gallery .gallery-nav{position:absolute;top:50%;transform:translateY(-50%);display:flex;gap:8px;z-index:2}
.gallery .gallery-nav.prev{left:6px}
.gallery .gallery-nav.next{right:6px}
.gallery .gallery-nav button{background:#fff;border:1px solid rgba(0,0,0,.12);box-shadow:var(--shadow);border-radius:50%;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.gallery .thumbs{display:flex;gap:8px;margin-top:8px;overflow-x:auto;padding-bottom:4px}
.gallery .thumbs .thumb{flex:0 0 auto;width:84px;height:56px;border-radius:8px;overflow:hidden;border:1px solid rgba(0,0,0,.08);cursor:pointer;opacity:.7}
.gallery .thumbs .thumb.active{opacity:1;border-color:#333}
.gallery .dots{display:flex;justify-content:center;gap:6px;margin-top:6px}
.gallery .dots .dot{width:6px;height:6px;border-radius:50%;background:rgba(0,0,0,.2)}
.gallery .dots .dot.active{background:#333}
/* Fallback untuk browser tanpa dukungan aspect-ratio */
@supports not (aspect-ratio: 1) {
  .gallery .gallery-track .item .media{position:relative;height:0;padding-top:56.25%}
  .gallery .gallery-track .item .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
}

/* Fixed CTA di bawah drawer */
/* padding modal-body telah dikonsolidasikan di atas; baris ini dihapus untuk menghindari duplikasi */
.drawer-cta{position:absolute;bottom:0;left:0;right:0;background:#fff;border-top:1px solid rgba(0,0,0,.08);box-shadow:0 -6px 16px rgba(0,0,0,.06);padding:12px;z-index:3;padding-bottom:calc(12px + env(safe-area-inset-bottom, 0px))}
.drawer-cta .cta-actions{display:flex;gap:10px;align-items:stretch}
.drawer-cta .cta-actions .btn{flex:1 1 0;min-height:44px;justify-content:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width:520px){
  .drawer-cta .cta-actions{flex-direction:column}
  .drawer-cta .cta-actions .btn{white-space:normal}
}

/* Olive button (non-primary, non-outline) — hindari menimpa varian lain */
.btn:not(.primary):not(.outline).olive{background:#C2C7B0;color:#fff;border-color:transparent}
.btn:not(.primary):not(.outline).olive:hover{background:#b5bca1}
.hero-points{list-style:none;margin:.6rem 0 1rem;padding:0;color:#fff}
.hero-points li{display:flex;align-items:center;gap:.5rem;margin:.25rem 0}
.hero-points li::before{content:'\2713';display:inline-block;color:#a5d6a7;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);width:22px;height:22px;border-radius:999px;line-height:22px;text-align:center;font-weight:700}
.price{color:#fff;font-weight:700;margin:.4rem 0 1rem}
.hero .btn{width:auto;max-width:max-content;align-self:flex-start}

/* === Unified Modal Header styles for all drawers === */
.cluster-modal .modal-header{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid rgba(0,0,0,.08);background:#fff;position:sticky;top:0;z-index:3;min-height:52px}
.cluster-modal .modal-header .modal-back{display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;color:var(--text);padding:6px 8px;border-radius:10px;cursor:pointer}
.cluster-modal .modal-header .modal-title{margin:0;font-size:1.05rem;font-weight:600;flex:1}
.cluster-modal .modal-header .modal-close{margin-left:auto;background:transparent;border:0;color:var(--text);padding:6px;border-radius:10px;cursor:pointer}
.cluster-modal .modal-header .modal-back,
.cluster-modal .modal-header .modal-close{min-width:44px;min-height:44px}
/* Saat menggunakan desain drawer lama (header di dalam body), sembunyikan header bawaan */
.cluster-modal.with-drawer-header .modal-header{display:none}
.cluster-modal{--drawer-cta-h:84px}
@media(max-width:520px){.cluster-modal{--drawer-cta-h:96px}}
