/* ===================================================
   PUSAKA LAND BANJARBARU — tanahmurahbanjarbaru.net
   Theme: Luxury Green & Gold
   =================================================== */

/* ---------- TOKENS ---------- */
:root{
  --green-900:#062a17;
  --green-800:#0a3a20;
  --green-700:#0d4d2a;
  --green-600:#11633a;
  --green-500:#178a4f;
  --green-50:#eaf6ee;

  --gold-700:#a07a1f;
  --gold-600:#c39a32;
  --gold-500:#d4af37;
  --gold-400:#e6c462;
  --gold-300:#f1d987;

  --cream:#fdf8ec;
  --bg:#faf7f1;
  --ink:#0f1a14;
  --muted:#5a6a60;
  --line:rgba(13,77,42,.12);

  --radius-sm:10px;
  --radius:16px;
  --radius-lg:24px;
  --shadow-sm:0 6px 18px rgba(6,42,23,.08);
  --shadow:0 18px 50px rgba(6,42,23,.16);
  --shadow-gold:0 14px 40px rgba(212,175,55,.35);

  --container:1200px;

  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  margin:0;
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px;line-height:1.6;color:var(--ink);background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  -webkit-tap-highlight-color:transparent;
}
img,picture{max-width:100%;display:block}
picture{width:100%}
picture img{width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.15;margin:0 0 .6em;word-wrap:break-word}
p{margin:0 0 1em;word-wrap:break-word}
iframe{max-width:100%}

/* ---------- SCROLL REVEAL (replaces AOS) ---------- */
[data-aos]{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .6s ease-out, transform .6s ease-out;
  will-change:opacity,transform;
}
[data-aos="fade-right"]{transform:translateX(-24px)}
[data-aos="fade-left"]{transform:translateX(24px)}
[data-aos="zoom-in"]{transform:scale(.92)}
[data-aos="flip-left"]{transform:perspective(800px) rotateY(-12deg);transform-origin:left}
[data-aos].is-revealed{
  opacity:1;
  transform:none;
}
@media (prefers-reduced-motion:reduce){
  [data-aos]{opacity:1;transform:none;transition:none}
}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 22px}

.text-gold{
  background:linear-gradient(135deg,var(--gold-400),var(--gold-600) 60%,var(--gold-300));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

.eyebrow{
  display:inline-flex;align-items:center;gap:.5em;
  font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--green-700);
  padding:.4em .9em;border:1px solid var(--line);border-radius:999px;
  background:linear-gradient(135deg,#fff,#f6f3e7);margin-bottom:14px;
}

.section{padding:96px 0;position:relative}
.section__head{text-align:center;max-width:780px;margin:0 auto 56px}
.section__title{font-size:clamp(28px,3.4vw,46px)}
.section__lead{color:var(--muted);font-size:17px}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:14px 26px;border-radius:999px;font-weight:700;letter-spacing:.02em;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),color .25s var(--ease);
  position:relative;overflow:hidden;white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
  color:#fff;box-shadow:0 12px 30px rgba(13,77,42,.35);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(13,77,42,.45)}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-500),var(--gold-300) 50%,var(--gold-600));
  color:#3a2a05;box-shadow:var(--shadow-gold);
}
.btn-gold:hover{transform:translateY(-2px);filter:brightness(1.05)}
.btn-ghost{
  background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.4);
  backdrop-filter:blur(6px);
}
.btn-ghost:hover{background:rgba(255,255,255,.16);border-color:#fff}
.btn-block{display:flex;width:100%}
.btn-lg{padding:18px 32px;font-size:17px}

/* ---------- TOPBAR ---------- */
.topbar{
  background:linear-gradient(90deg,var(--green-800),var(--green-700));
  color:#f3e9c5;font-size:13.5px;
  border-bottom:1px solid rgba(212,175,55,.25);
}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;padding:9px 22px;gap:20px;flex-wrap:wrap}
.topbar__inner i{color:var(--gold-400);margin-right:6px}
.topbar__contact{display:flex;gap:18px}
.topbar__contact a:hover{color:var(--gold-300)}

/* ---------- NAVBAR ---------- */
.navbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  transition:padding .25s var(--ease),background .25s var(--ease);
}
.navbar.scrolled{padding:2px 0;background:rgba(255,255,255,.95);box-shadow:var(--shadow-sm)}
.navbar__inner{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;gap:20px}
.navbar__brand{display:flex;align-items:center;gap:12px}
.brand__mark{
  width:46px;height:46px;border-radius:12px;
  display:grid;place-items:center;font-size:20px;color:var(--gold-400);
  background:radial-gradient(circle at 30% 30%,var(--green-600),var(--green-800));
  box-shadow:0 8px 20px rgba(13,77,42,.35),inset 0 0 0 1px rgba(212,175,55,.4);
}
.brand__text strong{display:block;font-family:'Playfair Display',serif;font-size:18px;color:var(--green-800);letter-spacing:.02em}
.brand__text small{display:block;font-size:11px;letter-spacing:.32em;color:var(--gold-700);text-transform:uppercase}

.navbar__nav{display:flex;align-items:center;gap:6px}
.navbar__nav a{
  position:relative;padding:10px 14px;font-weight:600;color:var(--ink);font-size:15px;border-radius:8px;
  transition:color .2s;
}
.navbar__nav a:hover{color:var(--green-700)}
.navbar__nav a:not(.nav-cta)::after{
  content:"";position:absolute;left:14px;right:14px;bottom:6px;height:2px;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300));
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);
}
.navbar__nav a:hover:not(.nav-cta)::after{transform:scaleX(1)}
.nav-cta{
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
  color:#fff !important;padding:10px 22px !important;border-radius:999px;
  margin-left:6px;box-shadow:0 8px 20px rgba(13,77,42,.3);
}
.nav-cta:hover{transform:translateY(-1px);color:#fff !important}

.navbar__toggle{display:none;width:42px;height:42px;border-radius:10px;background:#fff;box-shadow:var(--shadow-sm);position:relative}
.navbar__toggle span{
  position:absolute;left:11px;right:11px;height:2px;background:var(--green-700);border-radius:2px;
  transition:transform .25s var(--ease),opacity .2s;
}
.navbar__toggle span:nth-child(1){top:14px}
.navbar__toggle span:nth-child(2){top:20px}
.navbar__toggle span:nth-child(3){top:26px}
.navbar.open .navbar__toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.navbar.open .navbar__toggle span:nth-child(2){opacity:0}
.navbar.open .navbar__toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ---------- HERO ---------- */
.hero{
  position:relative;color:#fff;overflow:hidden;
  padding:90px 0 110px;isolation:isolate;
}
.hero__bg{position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(1200px 600px at 100% -10%,rgba(212,175,55,.18),transparent 60%),
    radial-gradient(900px 700px at -10% 110%,rgba(23,138,79,.35),transparent 60%),
    linear-gradient(135deg,var(--green-900),var(--green-700) 60%,var(--green-800));
}
.hero__overlay{position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(255,255,255,.06),transparent 60%)}
.hero__pattern{
  position:absolute;inset:0;opacity:.08;
  background-image:
    linear-gradient(rgba(212,175,55,.6) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,175,55,.6) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
}
.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}

.hero__badge{
  display:inline-flex;align-items:center;gap:.5em;
  padding:8px 16px;border-radius:999px;font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  background:linear-gradient(135deg,rgba(212,175,55,.2),rgba(212,175,55,.05));
  border:1px solid rgba(212,175,55,.45);color:var(--gold-300);
  margin-bottom:18px;
}
.hero__title{
  font-size:clamp(34px,4.4vw,60px);line-height:1.08;margin-bottom:18px;
  text-shadow:0 6px 30px rgba(0,0,0,.35);
}
.hero__subtitle{font-size:18px;color:rgba(255,255,255,.86);max-width:560px;margin-bottom:30px}
.hero__subtitle strong{color:var(--gold-300)}

.hero__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:30px;max-width:560px}
.stat{
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;padding:14px;text-align:center;backdrop-filter:blur(4px);
}
.stat strong{display:block;font-family:'Playfair Display',serif;font-size:24px;color:var(--gold-300)}
.stat strong small{font-size:13px;color:#fff;opacity:.7;margin-left:2px}
.stat span{font-size:11.5px;color:rgba(255,255,255,.7);letter-spacing:.04em}

.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:24px}

.hero__trust{font-size:14px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:8px}
.hero__trust i{color:var(--gold-400)}
.hero__trust strong{color:#fff}

/* hero visual */
.hero__visual{position:relative;perspective:1200px}
.hero__card{
  position:relative;border-radius:24px;overflow:hidden;
  box-shadow:0 40px 80px rgba(0,0,0,.45),0 0 0 1px rgba(212,175,55,.25);
  transform:rotate3d(0,1,0,-6deg) rotate3d(1,0,0,4deg);
  transition:transform .6s var(--ease);
}
.hero__card:hover{transform:rotate3d(0,1,0,-2deg) rotate3d(1,0,0,2deg) translateY(-6px)}
.hero__card picture,
.hero__card img{display:block;width:100%;height:auto}
.hero__shine{
  position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.18) 45%,transparent 60%);
  transform:translateX(-100%);
  animation:shine 6s ease-in-out infinite;
}
@keyframes shine{
  0%,100%{transform:translateX(-100%)}
  50%{transform:translateX(100%)}
}
.hero__floating{
  position:absolute;background:#fff;color:var(--ink);
  padding:14px 18px;border-radius:14px;display:flex;align-items:center;gap:12px;
  box-shadow:0 14px 40px rgba(0,0,0,.25);
  animation:float 4.5s ease-in-out infinite;
}
.hero__floating i{
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
}
.hero__floating strong{display:block;font-size:14px}
.hero__floating small{display:block;font-size:11.5px;color:var(--muted)}
.hero__floating--1{top:14%;left:8px;animation-delay:.2s}
.hero__floating--2{bottom:10%;right:8px;animation-delay:1.2s}
.hero__floating--2 i{background:linear-gradient(135deg,var(--gold-600),var(--gold-400));color:#3a2a05}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}

.hero__scroll{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.65);
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.hero__scroll span{
  display:block;width:1px;height:34px;background:linear-gradient(180deg,var(--gold-400),transparent);
  animation:scrolldot 2s ease-in-out infinite;
}
@keyframes scrolldot{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

/* ---------- TICKER ---------- */
.ticker{background:var(--green-800);color:#fff;padding:14px 0;overflow:hidden;border-top:1px solid rgba(212,175,55,.2);border-bottom:1px solid rgba(212,175,55,.2)}
.ticker__track{display:flex;gap:60px;white-space:nowrap;animation:ticker 30s linear infinite;font-weight:600;letter-spacing:.05em}
.ticker__track span i{color:var(--gold-400);margin-right:8px}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- ABOUT ---------- */
.section--about{background:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center}
.about-grid__media{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
.about-grid__media picture,
.about-grid__media img{width:100%;height:auto;display:block}
.about-badge{
  position:absolute;left:18px;bottom:18px;background:#fff;border-radius:14px;padding:14px 18px;
  display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm);
}
.about-badge i{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#3a2a05;font-size:18px;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-300));
}
.about-badge strong{display:block;font-size:15px}
.about-badge small{display:block;font-size:12px;color:var(--muted)}

.check-list{margin:18px 0 28px;display:grid;gap:10px}
.check-list li{display:flex;align-items:flex-start;gap:12px;font-size:15.5px}
.check-list i{
  flex:0 0 24px;height:24px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:12px;
  background:linear-gradient(135deg,var(--green-700),var(--green-500));margin-top:3px;
}

/* ---------- FEATURES ---------- */
.section--features{
  background:linear-gradient(180deg,#fff,#f4f0e2);
}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  position:relative;overflow:hidden;
}
.feature::before{
  content:"";position:absolute;inset:auto -30% -60% auto;width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,55,.18),transparent 70%);transition:transform .5s;
}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(212,175,55,.45)}
.feature:hover::before{transform:scale(1.4)}
.feature__icon{
  width:58px;height:58px;border-radius:16px;display:grid;place-items:center;margin-bottom:18px;
  font-size:22px;color:var(--gold-300);
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
  box-shadow:0 10px 24px rgba(13,77,42,.25);
}
.feature h3{font-size:20px;margin-bottom:8px}
.feature p{color:var(--muted);font-size:15px;margin:0}

/* ---------- PRICING ---------- */
.section--pricing{background:#fff}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.price-card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:24px;padding:34px 28px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  display:flex;flex-direction:column;
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(212,175,55,.4)}
.price-card__head{margin-bottom:18px}
.price-card__tag{
  display:inline-block;font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--green-700);background:var(--green-50);padding:5px 12px;border-radius:999px;margin-bottom:12px;
}
.price-card h3{font-size:22px;margin:0}

.price-card__price{
  display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;
  padding:18px 20px;border-radius:16px;margin-bottom:22px;
  background:linear-gradient(135deg,#0a3a20,#11633a);color:#fff;position:relative;overflow:hidden;
}
.price-card__price::before{
  content:"";position:absolute;inset:auto -50% -150% auto;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,55,.25),transparent 70%);
}
.price-card__price small{display:block;width:100%;font-size:12px;letter-spacing:.18em;color:var(--gold-300);margin-bottom:2px;text-transform:uppercase}
.price-card__price strong{
  font-family:'Playfair Display',serif;font-size:40px;line-height:1;color:var(--gold-300);
}
.price-card__price strong span{font-size:54px;color:#fff;margin-right:4px}
.price-card__per{font-size:13px;color:rgba(255,255,255,.7)}

.price-card__list{margin:0 0 26px;display:grid;gap:10px}
.price-card__list li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:#243027}
.price-card__list i{color:var(--green-600);margin-top:4px}

.price-card--featured{
  border:2px solid transparent;
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(135deg,var(--gold-500),var(--green-700)) border-box;
  box-shadow:0 22px 60px rgba(13,77,42,.18);
  transform:translateY(-8px);
}
.price-card--featured:hover{transform:translateY(-14px)}
.price-card__ribbon{
  position:absolute;top:-14px;right:24px;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-300));
  color:#3a2a05;font-weight:800;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  padding:6px 14px;border-radius:999px;box-shadow:var(--shadow-gold);
}

/* ---------- SITEPLAN ---------- */
.section--siteplan{background:linear-gradient(180deg,#f4f0e2,#fff)}
.siteplan{display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:center}
.siteplan__img{
  position:relative;display:block;border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow);background:#fff;
}
.siteplan__img picture,
.siteplan__img img{width:100%;height:auto;display:block;transition:transform .6s var(--ease)}
.siteplan__img:hover img{transform:scale(1.04)}
.siteplan__zoom{
  position:absolute;right:18px;bottom:18px;background:rgba(255,255,255,.95);color:var(--green-800);
  padding:10px 16px;border-radius:999px;font-size:13px;font-weight:600;
  display:inline-flex;align-items:center;gap:8px;backdrop-filter:blur(6px);
}
.siteplan__specs{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.siteplan__specs > div{
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;text-align:center;
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.siteplan__specs > div:hover{transform:translateY(-4px);border-color:rgba(212,175,55,.5);box-shadow:var(--shadow-sm)}
.siteplan__specs strong{display:block;font-family:'Playfair Display',serif;font-size:24px;color:var(--green-800)}
.siteplan__specs span{font-size:13px;color:var(--muted)}

/* ---------- LOCATION ---------- */
.section--location{background:#fff}
.location-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center}
.location-grid__map{border-radius:24px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.location-grid__map iframe{display:block;width:100%}

.access-list{display:grid;gap:14px;margin:18px 0 26px}
.access-list li{
  display:flex;align-items:center;gap:14px;background:#fbf7e9;border:1px solid var(--line);
  border-radius:14px;padding:14px 18px;transition:transform .25s,border-color .25s;
}
.access-list li:hover{transform:translateX(4px);border-color:rgba(212,175,55,.5)}
.access-list i{
  width:44px;height:44px;border-radius:12px;display:grid;place-items:center;color:var(--gold-300);font-size:18px;
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
}
.access-list strong{display:block;font-size:16px;color:var(--green-800)}
.access-list span{font-size:14px;color:var(--muted)}

/* ---------- PROMO ---------- */
.section--promo{
  position:relative;background:linear-gradient(135deg,var(--green-900),var(--green-700));color:#fff;overflow:hidden;
}
.section--promo::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(212,175,55,.18),transparent 50%);
  pointer-events:none;
}
.promo-card{
  position:relative;display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:center;
  background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid rgba(212,175,55,.3);border-radius:28px;padding:36px;backdrop-filter:blur(6px);
}
.promo-card__media{border-radius:18px;overflow:hidden;box-shadow:0 30px 60px rgba(0,0,0,.4)}
.promo-card__media picture,
.promo-card__media img{width:100%;height:auto;display:block}
.promo-card__content .eyebrow{background:rgba(212,175,55,.12);border-color:rgba(212,175,55,.4);color:var(--gold-300)}
.promo-card__content h2{color:#fff}
.promo-card__content p{color:rgba(255,255,255,.78);font-size:17px}

.gift-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:22px 0 28px}
.gift{
  background:rgba(255,255,255,.06);border:1px solid rgba(212,175,55,.25);border-radius:16px;
  padding:18px 10px;text-align:center;transition:transform .3s,background .3s,border-color .3s;
}
.gift:hover{transform:translateY(-4px);background:rgba(212,175,55,.1);border-color:rgba(212,175,55,.55)}
.gift i{font-size:26px;color:var(--gold-400);margin-bottom:8px;display:block}
.gift span{font-size:13px;font-weight:600;color:#fff}

/* ---------- GALLERY ---------- */
.section--gallery{background:linear-gradient(180deg,#fff,#f4f0e2)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gallery-grid a{
  display:block;border-radius:18px;overflow:hidden;position:relative;
  box-shadow:var(--shadow-sm);transition:transform .4s,box-shadow .4s;
  background:linear-gradient(135deg,#fbf7e9,#f4f0e2);
  border:1px solid var(--line);
  aspect-ratio:3/4;
}
.gallery-grid a:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.gallery-grid picture{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.gallery-grid img{
  width:100%;height:100%;
  object-fit:contain;
  padding:6px;
  transition:transform .6s var(--ease);
}
.gallery-grid a:hover img{transform:scale(1.04)}
.gallery-grid a::after{
  content:"\f00e";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:22px;
  background:linear-gradient(0deg,rgba(13,77,42,.55),rgba(13,77,42,0));
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.gallery-grid a:hover::after{opacity:1}

/* ---------- FAQ ---------- */
.section--faq{background:#fff}
.faq{max-width:860px;margin:0 auto;display:grid;gap:12px}
.faq__item{
  background:#fbf7e9;border:1px solid var(--line);border-radius:16px;padding:0 22px;overflow:hidden;
  transition:border-color .25s,box-shadow .25s;
}
.faq__item[open]{border-color:rgba(212,175,55,.5);box-shadow:var(--shadow-sm);background:#fff}
.faq__item summary{
  list-style:none;cursor:pointer;padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:18px;
  font-weight:600;font-size:16.5px;color:var(--green-800);
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary i{
  width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:13px;
  background:linear-gradient(135deg,var(--green-700),var(--green-500));transition:transform .3s,background .3s;flex-shrink:0;
}
.faq__item[open] summary i{transform:rotate(45deg);background:linear-gradient(135deg,var(--gold-500),var(--gold-300));color:#3a2a05}
.faq__item p{padding:0 0 18px;color:var(--muted);font-size:15px;margin:0}

/* ---------- CONTACT ---------- */
.section--contact{
  background:linear-gradient(180deg,#fff,#f4f0e2);
}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:start}
.contact-list{display:grid;gap:14px;margin:22px 0 24px}
.contact-list li{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 18px}
.contact-list i{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:var(--gold-300);font-size:16px;
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
}
.contact-list strong{display:block;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.contact-list a,.contact-list span{font-size:16px;color:var(--green-800);font-weight:600}
.contact-list a:hover{color:var(--gold-700)}

.socials{display:flex;gap:10px;margin-top:6px}
.socials a{
  width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
  transition:transform .25s,background .25s;
}
.socials a:hover{transform:translateY(-3px);background:linear-gradient(135deg,var(--gold-500),var(--gold-300));color:#3a2a05}

.contact-form{
  background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px;box-shadow:var(--shadow-sm);
}
.contact-form h3{margin:0 0 18px;font-size:24px}
.contact-form label{display:block;margin-bottom:14px}
.contact-form label > span{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px;letter-spacing:.04em}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;font:inherit;background:#fbf7e9;
  transition:border-color .2s,background .2s;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--green-500);background:#fff;
  box-shadow:0 0 0 4px rgba(23,138,79,.12);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-note{display:block;text-align:center;color:var(--muted);font-size:12.5px;margin-top:10px}
.form-note i{color:var(--green-600);margin-right:4px}

/* ---------- CTA STRIP ---------- */
.cta-strip{
  background:
    linear-gradient(135deg,rgba(13,77,42,.92),rgba(10,58,32,.92)),
    url('../assets/images/pusaka-land-banjarbaru-investasi-cerdas.jpg') center/cover no-repeat;
  color:#fff;padding:60px 0;
}
.cta-strip__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cta-strip h2{font-size:clamp(24px,2.6vw,34px);margin:0 0 6px;color:#fff}
.cta-strip p{margin:0;color:rgba(255,255,255,.78)}

/* ---------- FOOTER ---------- */
.footer{background:#062a17;color:#cdd5cf;padding:70px 0 0}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1.1fr 1fr;gap:36px;padding-bottom:50px}
.navbar__brand--footer .brand__text strong{color:#fff}
.navbar__brand--footer{margin-bottom:14px}
.footer p{color:rgba(255,255,255,.6);font-size:14px}
.footer h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;color:#fff;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px}
.footer ul{display:grid;gap:10px}
.footer ul a:hover{color:var(--gold-300)}
.footer ul li i{color:var(--gold-400);margin-right:8px;width:14px;text-align:center}
.footer__tagline{margin-top:14px;font-size:13px;color:var(--gold-300);letter-spacing:.16em;text-transform:uppercase}

.footer__bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:18px 0;font-size:13.5px;
}
.footer__bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:rgba(255,255,255,.55)}
.footer__bottom a{color:var(--gold-300)}

/* ---------- FLOATING WHATSAPP ---------- */
.float-wa{
  position:fixed;right:22px;bottom:22px;z-index:60;
  width:62px;height:62px;border-radius:50%;background:#25d366;color:#fff;
  display:grid;place-items:center;font-size:30px;
  box-shadow:0 14px 30px rgba(37,211,102,.45);
  transition:transform .25s;
}
.float-wa:hover{transform:scale(1.08);color:#fff}
.float-wa__pulse{
  position:absolute;inset:0;border-radius:50%;border:3px solid #25d366;
  animation:pulse 1.8s ease-out infinite;opacity:.7;
}
@keyframes pulse{
  0%{transform:scale(.95);opacity:.7}
  100%{transform:scale(1.6);opacity:0}
}

/* ---------- LIGHTBOX ---------- */
.lightbox{
  position:fixed;inset:0;background:rgba(6,42,23,.92);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;z-index:100;padding:30px;
}
.lightbox.active{display:flex;animation:fadeIn .25s}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox__close{
  position:absolute;top:20px;right:24px;width:46px;height:46px;border-radius:50%;
  background:#fff;color:var(--green-800);font-size:30px;line-height:1;display:grid;place-items:center;
}
.lightbox__close:hover{background:var(--gold-400)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ===================================================
   RESPONSIVE — Multi-breakpoint
   - 1280px: large screens
   - 1080px: small desktop / landscape tablet
   - 920px:  portrait tablet
   - 760px:  large phone / phablet
   - 600px:  medium phone
   - 480px:  small phone
   - 380px:  very small phone
   =================================================== */

/* ---------- LARGE SCREENS (≤1280px) ---------- */
@media (max-width:1280px){
  :root{ --container:1100px; }
  .hero__title{ font-size:clamp(32px,4.2vw,52px) }
  .section{ padding:84px 0 }
}

/* ---------- SMALL DESKTOP / LANDSCAPE TABLET (≤1080px) ---------- */
@media (max-width:1080px){
  :root{ --container:960px; }
  .container{ padding:0 20px }
  .section{ padding:74px 0 }
  .section__head{ margin-bottom:42px }

  .features-grid{ grid-template-columns:repeat(2,1fr) }
  .pricing-grid{ grid-template-columns:1fr;gap:18px;max-width:520px;margin:0 auto }
  .price-card--featured{ transform:none }
  .price-card--featured:hover{ transform:translateY(-6px) }
  .siteplan{ grid-template-columns:1fr }
  .location-grid{ grid-template-columns:1fr }
  .promo-card{ grid-template-columns:1fr;padding:28px }
  .gallery-grid{ grid-template-columns:repeat(2,1fr) }
  .contact-grid{ grid-template-columns:1fr;gap:36px }
  .footer__grid{ grid-template-columns:1fr 1fr;gap:32px }

  .hero{ padding:80px 0 100px }
  .hero__inner{ grid-template-columns:1fr;gap:50px }
  .hero__content{ text-align:center;max-width:760px;margin:0 auto }
  .hero__subtitle{ margin-left:auto;margin-right:auto }
  .hero__cta{ justify-content:center }
  .hero__trust{ justify-content:center }
  .hero__visual{ max-width:480px;margin:0 auto }
  .hero__floating--1{ left:8px }
  .hero__floating--2{ right:8px }

  .area-grid{ grid-template-columns:repeat(2,1fr) }
  .testi-grid{ grid-template-columns:1fr;max-width:680px }
}

/* ---------- PORTRAIT TABLET (≤920px) ---------- */
@media (max-width:920px){
  .features-grid{ gap:18px }
  .area-grid{ gap:18px }
  .gallery-grid{ gap:14px }
  .siteplan__specs{ grid-template-columns:repeat(2,1fr);gap:12px }
  .gift-grid{ gap:12px }
  .promo-card{ gap:30px }
  .footer__grid{ gap:28px }
}

/* ---------- LARGE PHONE / PHABLET (≤760px) ---------- */
@media (max-width:760px){
  :root{ --container:100%; }
  .container{ padding:0 18px }
  .section{ padding:60px 0 }
  .section__head{ margin-bottom:36px }
  .section__title{ font-size:clamp(24px,5.5vw,34px) }
  .section__lead{ font-size:15.5px }

  /* Topbar */
  .topbar{ font-size:12.5px }
  .topbar__inner{ padding:8px 18px;gap:10px }
  .topbar__contact{ display:none }

  /* Navbar */
  .navbar__inner{ padding:12px 18px }
  .brand__mark{ width:42px;height:42px;font-size:18px;border-radius:10px }
  .brand__text strong{ font-size:16px }
  .brand__text small{ font-size:10px;letter-spacing:.28em }

  .navbar__nav{
    position:fixed;inset:62px 0 auto;flex-direction:column;align-items:stretch;gap:0;
    background:#fff;padding:14px;border-top:1px solid var(--line);
    transform:translateY(-130%);transition:transform .35s var(--ease);
    box-shadow:var(--shadow);max-height:calc(100vh - 62px);overflow-y:auto;
  }
  .navbar.open .navbar__nav{ transform:translateY(0) }
  .navbar__nav a{ padding:14px 16px;border-bottom:1px solid var(--line);font-size:15px }
  .navbar__nav a:last-child{ border-bottom:0 }
  .navbar__nav a:not(.nav-cta)::after{ display:none }
  .nav-cta{ margin:10px 16px 0;text-align:center }
  .navbar__toggle{ display:block }

  /* Hero */
  .hero{ padding:50px 0 70px }
  .hero__title{ font-size:clamp(26px,7vw,40px);line-height:1.15 }
  .hero__subtitle{ font-size:15.5px }
  .hero__badge{ font-size:11px;padding:7px 14px;letter-spacing:.12em }
  .hero__stats{ grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:24px }
  .stat{ padding:12px 10px }
  .stat strong{ font-size:20px }
  .stat span{ font-size:11px }
  .hero__floating{ display:none }
  .hero__cta{ flex-direction:column;align-items:stretch }
  .hero__cta .btn{ width:100% }
  .hero__scroll{ display:none }

  /* Buttons */
  .btn{ padding:13px 22px;font-size:14.5px }
  .btn-lg{ padding:15px 26px;font-size:16px }

  /* Features / About */
  .about-grid{ grid-template-columns:1fr;gap:30px }
  .about-cta{ flex-direction:column }
  .about-cta .btn{ width:100% }
  .features-grid{ grid-template-columns:1fr }
  .feature{ padding:26px 22px }

  /* Pricing */
  .price-card{ padding:28px 22px }
  .price-card__price strong{ font-size:34px }
  .price-card__price strong span{ font-size:46px }

  /* Siteplan */
  .siteplan__specs{ grid-template-columns:1fr 1fr }
  .siteplan__zoom{ font-size:11px;padding:8px 12px;right:12px;bottom:12px }

  /* Location */
  .location-grid__map iframe{ height:340px }

  /* Area */
  .area-grid{ grid-template-columns:1fr }
  .area-card{ padding:24px 22px }
  .area-cities{ padding:20px 18px }
  .area-cities p{ font-size:13.5px;line-height:1.7 }

  /* Promo */
  .promo-card{ padding:24px;gap:24px }
  .gift-grid{ grid-template-columns:1fr 1fr }

  /* Gallery */
  .gallery-grid{ grid-template-columns:repeat(2,1fr);gap:12px }

  /* Testimoni */
  .testi{ padding:22px }
  .testi p{ font-size:14.5px }

  /* FAQ */
  .faq__item{ padding:0 18px }
  .faq__item summary{ font-size:15px;padding:16px 0;gap:12px }

  /* Contact */
  .form-row{ grid-template-columns:1fr;gap:0 }
  .contact-form{ padding:24px 20px }
  .contact-form h3{ font-size:21px }
  .contact-list li{ padding:12px 14px }

  /* CTA strip */
  .cta-strip{ padding:46px 0 }
  .cta-strip__inner{ flex-direction:column;text-align:center }
  .cta-strip__inner .btn{ width:100% }

  /* Footer */
  .footer{ padding:50px 0 0 }
  .footer__grid{ grid-template-columns:1fr;gap:26px;padding-bottom:30px }
  .footer__bottom .container{ flex-direction:column;text-align:center;gap:6px }

  /* Floating WA */
  .float-wa{ width:54px;height:54px;font-size:26px;right:14px;bottom:14px }

  /* Lightbox */
  .lightbox{ padding:14px }
  .lightbox__close{ width:42px;height:42px;font-size:26px;top:14px;right:14px }
}

/* ---------- MEDIUM PHONE (≤600px) ---------- */
@media (max-width:600px){
  .container{ padding:0 16px }
  .section{ padding:54px 0 }

  .topbar__inner{ padding:7px 14px;font-size:11.5px }
  .topbar strong{ font-weight:700 }

  .hero__title{ font-size:clamp(24px,7.5vw,34px) }
  .hero__subtitle{ font-size:15px }
  .hero__badge{ font-size:10.5px }

  .price-card{ padding:24px 20px;border-radius:20px }
  .price-card__price{ padding:14px 16px }

  .feature{ padding:24px 20px }
  .feature__icon{ width:52px;height:52px;font-size:20px }
  .feature h3{ font-size:18px }

  .access-list li{ padding:12px 14px;gap:12px }
  .access-list i{ width:40px;height:40px;font-size:16px }
  .access-list strong{ font-size:15px }
  .access-list span{ font-size:13px }

  .area-card{ padding:22px 20px }
  .area-card i{ width:48px;height:48px;font-size:20px }
  .area-card h3{ font-size:18px }

  .gallery-grid{ gap:10px }
  /* gallery img tetap object-fit:contain, tidak override aspect-ratio */

  .footer__bottom{ font-size:12.5px }
}

/* ---------- SMALL PHONE (≤480px) ---------- */
@media (max-width:480px){
  .container{ padding:0 14px }
  .section{ padding:48px 0 }
  .section__head{ margin-bottom:30px }

  .topbar{ font-size:11px }
  .topbar__inner{ padding:6px 12px }
  .topbar__inner > span:first-child{ font-size:11px }

  /* Eyebrow */
  .eyebrow{ font-size:10.5px;padding:.35em .8em;letter-spacing:.14em }

  /* Hero */
  .hero{ padding:40px 0 60px }
  .hero__title{ font-size:clamp(22px,8vw,30px) }
  .hero__subtitle{ font-size:14.5px;margin-bottom:24px }
  .hero__stats{ gap:8px }
  .stat{ padding:10px 8px }
  .stat strong{ font-size:18px }
  .stat strong small{ font-size:11px }
  .hero__trust{ font-size:12.5px;line-height:1.5 }

  /* Pricing */
  .price-card__tag{ font-size:11px }
  .price-card__price strong{ font-size:30px }
  .price-card__price strong span{ font-size:40px }
  .price-card__list li{ font-size:14.5px }
  .price-card__ribbon{ font-size:11px;padding:5px 12px }

  /* Siteplan */
  .siteplan__specs{ grid-template-columns:1fr;gap:10px }
  .siteplan__specs > div{ display:flex;align-items:center;justify-content:space-between;text-align:left;padding:14px 16px }
  .siteplan__specs strong{ font-size:18px }

  /* Lokasi */
  .location-grid__map iframe{ height:280px }

  /* Promo */
  .promo-card{ padding:22px 18px }
  .gift{ padding:14px 8px }
  .gift i{ font-size:22px }
  .gift span{ font-size:12px }

  /* Gallery */
  .gallery-grid{ grid-template-columns:1fr 1fr }

  /* Testimoni */
  .testi{ padding:20px 18px;border-radius:16px }
  .testi__avatar{ width:42px;height:42px;font-size:18px }
  .testi p{ font-size:14px }

  /* FAQ */
  .faq__item{ padding:0 16px;border-radius:14px }
  .faq__item summary{ font-size:14px;gap:10px }
  .faq__item summary i{ width:28px;height:28px;font-size:11px }
  .faq__item p{ font-size:14px;padding-bottom:16px }

  /* Contact */
  .contact-form{ padding:22px 18px;border-radius:18px }
  .contact-form input,
  .contact-form select,
  .contact-form textarea{ padding:12px 12px;font-size:14.5px;border-radius:10px }
  .contact-list li{ padding:11px 12px }
  .contact-list i{ width:38px;height:38px;font-size:14px }
  .contact-list strong{ font-size:11.5px }
  .contact-list a, .contact-list span{ font-size:14.5px }

  /* CTA strip */
  .cta-strip{ padding:36px 0 }
  .cta-strip h2{ font-size:22px }
  .cta-strip p{ font-size:14px }

  /* Float WA */
  .float-wa{ width:50px;height:50px;font-size:24px;right:12px;bottom:12px }

  /* About */
  .about-grid{ gap:24px }
  .about-grid__media{ border-radius:18px }
  .about-badge{ left:12px;bottom:12px;padding:10px 14px;border-radius:12px }
  .about-badge i{ width:36px;height:36px;font-size:14px }
  .about-badge strong{ font-size:13.5px }
  .about-badge small{ font-size:11px }
}

/* ---------- VERY SMALL PHONE (≤380px) ---------- */
@media (max-width:380px){
  .container{ padding:0 12px }
  .topbar__inner > span:first-child{ font-size:10.5px;line-height:1.4 }

  .brand__text strong{ font-size:14.5px }
  .brand__text small{ font-size:9.5px;letter-spacing:.24em }

  .hero__title{ font-size:24px }
  .hero__subtitle{ font-size:14px }
  .hero__stats{ grid-template-columns:1fr 1fr }
  .stat strong{ font-size:17px }

  .section__title{ font-size:24px }
  .section__lead{ font-size:14.5px }

  .btn{ padding:12px 18px;font-size:14px }
  .btn-block{ font-size:14.5px }

  .price-card__price strong{ font-size:26px }
  .price-card__price strong span{ font-size:34px }

  .gallery-grid{ grid-template-columns:1fr }
  .gallery-grid a{ aspect-ratio:auto;max-width:340px;margin:0 auto }
  .gallery-grid img{ aspect-ratio:auto;height:auto }

  .gift-grid{ grid-template-columns:1fr 1fr;gap:10px }
}

/* ---------- LANDSCAPE ORIENTATION on small heights ---------- */
@media (max-height:520px) and (orientation:landscape){
  .hero{ padding:30px 0 50px }
  .hero__title{ font-size:28px }
  .hero__visual{ display:none }
  .hero__inner{ grid-template-columns:1fr }
}

/* ---------- AOS smooth fallback ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}


/* ===================================================
   ANDROID / MOBILE POLISH — anti-overflow, touch targets, perf
   =================================================== */

/* Hard clamp untuk mencegah horizontal scroll/shift */
html,body{ overflow-x:clip; max-width:100%; width:100% }
body{ position:relative }

/* Disable hero card 3D transform on touch / small screens */
@media (max-width:1080px),(hover:none),(pointer:coarse){
  .hero__card{ transform:none !important }
  .hero__card:hover{ transform:none !important }
  .hero__shine{ display:none }
}

/* Touch-friendly tap targets */
@media (hover:none),(pointer:coarse){
  .btn{ min-height:46px }
  .navbar__nav a{ min-height:46px;display:flex;align-items:center }
  .socials a{ min-width:42px;min-height:42px }
  .access-list li,
  .contact-list li{ min-height:60px }
  .faq__item summary{ min-height:48px }
}

/* Prevent any horizontal overflow — pakai 100% bukan 100vw biar nggak include scrollbar */
.section,.container,.hero,.topbar,.navbar,
main,footer,.cta-strip,.ticker,.section--promo,
.section--area,.section--testimoni,.section--gallery,
.section--features,.section--pricing,.section--siteplan,
.section--location,.section--faq,.section--contact,.section--about{
  max-width:100%;
  overflow-x:clip;
}
.hero__bg,.hero__overlay,.hero__pattern{ max-width:100% }
.hero__visual{ overflow:visible }

/* Pastikan inner content tidak overflow */
.container{ overflow-x:clip }

/* Better topbar wrapping on small screens */
@media (max-width:760px){
  .topbar__inner{ justify-content:center;text-align:center }
  .topbar__inner > span:first-child{ display:block;width:100%;line-height:1.45 }
}

/* Ensure ticker doesn't add horizontal scroll */
.ticker{ width:100%;overflow:hidden }

/* Safer iframe fitting */
.location-grid__map{ position:relative }
.location-grid__map iframe{ display:block;width:100%;border:0 }

/* Hero floating cards: kunci di dalam visual area, no negative offset di mobile */
.hero__visual{ position:relative }
@media (max-width:1080px){
  .hero__floating--1{ left:0 }
  .hero__floating--2{ right:0 }
}
@media (max-width:760px){
  .hero__floating{ display:none !important }
}

/* Prevent emoji/icon overflow on tiny screens */
@media (max-width:380px){
  .hero__badge{ word-break:break-word;line-height:1.4;text-align:center }
  .topbar__inner i{ flex-shrink:0 }
}

/* Hindari word-break pada tombol & nav */
.btn,.navbar__nav a,.nav-cta{ white-space:nowrap }

/* Long unbroken strings (URL, email) — wrap aman */
.contact-list a,.contact-list span,
.area-cities,.faq__item p{ overflow-wrap:anywhere }

/* Cegah CTA strip background image scaling diluar viewport */
.cta-strip{ background-attachment:scroll;background-size:cover;background-position:center }

/* About CTA group */
.about-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}

/* Ghost button for dark text on light bg */
.btn-ghost-dark{
  background:#fff;color:var(--green-800);
  border:1.5px solid var(--green-700);
}
.btn-ghost-dark:hover{
  background:var(--green-700);color:#fff;transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(13,77,42,.25);
}

/* ========== AREA LAYANAN ========== */
.section--area{
  background:linear-gradient(180deg,#fff,#f4f0e2);
  position:relative;
}
.area-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:40px;
}
.area-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 24px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  position:relative;overflow:hidden;
}
.area-card::before{
  content:"";position:absolute;inset:auto -30% -60% auto;width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,55,.18),transparent 70%);
  transition:transform .5s;
}
.area-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(212,175,55,.5)}
.area-card:hover::before{transform:scale(1.4)}
.area-card i{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:22px;
  color:var(--gold-300);background:linear-gradient(135deg,var(--green-700),var(--green-500));
  box-shadow:0 10px 24px rgba(13,77,42,.25);margin-bottom:16px;
}
.area-card h3{font-size:20px;margin-bottom:8px;color:var(--green-800)}
.area-card p{color:var(--muted);font-size:15px;margin:0}

.area-card--primary{
  background:linear-gradient(135deg,var(--green-800),var(--green-600));color:#fff;
  border-color:transparent;
}
.area-card--primary h3{color:#fff}
.area-card--primary p{color:rgba(255,255,255,.85)}
.area-card--primary i{
  background:linear-gradient(135deg,var(--gold-500),var(--gold-300));color:#3a2a05;
}

.area-cities{
  text-align:center;max-width:900px;margin:0 auto;padding:24px 28px;
  background:#fff;border:1px dashed rgba(212,175,55,.45);border-radius:16px;
}
.area-cities p{margin:0 0 6px;color:var(--muted);font-size:14.5px;line-height:1.7}
.area-cities p:first-child{color:var(--green-800);font-weight:600;margin-bottom:10px}

/* ========== TESTIMONI ========== */
.section--testimoni{
  background:linear-gradient(180deg,#f4f0e2,#fff);
  position:relative;
}
.testi-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:22px;max-width:1040px;margin:0 auto;
}
.testi{
  background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px 28px;
  position:relative;transition:transform .3s,box-shadow .3s,border-color .3s;
}
.testi::before{
  content:"\201C";position:absolute;top:-10px;left:22px;
  font-family:'Playfair Display',serif;font-size:90px;line-height:1;color:var(--gold-400);
  opacity:.45;
}
.testi:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(212,175,55,.45)}
.testi__stars{color:var(--gold-500);font-size:14px;margin-bottom:10px;letter-spacing:2px}
.testi p{font-size:15.5px;color:#243027;margin:0 0 18px;line-height:1.65;position:relative;z-index:1}
.testi footer{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:14px}
.testi__avatar{
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  font-family:'Playfair Display',serif;font-weight:700;font-size:20px;color:#fff;
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
  box-shadow:0 6px 16px rgba(13,77,42,.25);
}
.testi footer strong{display:block;font-size:15px;color:var(--green-800)}
.testi footer small{display:block;font-size:12.5px;color:var(--muted)}
.testi-note{
  text-align:center;color:var(--muted);font-size:13.5px;margin-top:28px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.testi-note i{color:var(--gold-600)}

/* ========== ACTIVE NAV LINK ========== */
.navbar__nav a.is-active{color:var(--green-700)}
.navbar__nav a.is-active:not(.nav-cta)::after{transform:scaleX(1)}
