
:root {
  /* Colors */
  --bg:       #080c14;
  --bg-2:     #0d1421;
  --bg-3:     #111827;
  --surface:  #141c2e;
  --surface-2:#1a2540;
  --border:   rgba(255,255,255,.07);
  --border-2: rgba(255,255,255,.12);

  --gold:     #d4a84b;
  --gold-2:   #f0c96a;
  --gold-dim: rgba(212,168,75,.15);
  --blue:     #3b6bff;
  --blue-2:   #5a85ff;
  --blue-dim: rgba(59,107,255,.12);

  --text:     #e8eaf0;
  --text-2:   #94a3b8;
  --text-3:   #4a5a72;

  /* Space */
  --r:  12px;
  --r2: 20px;

  /* Motion */
  --ease: cubic-bezier(.25,.46,.45,.94);
  --ease-out: cubic-bezier(0,.55,.45,1);

  /* Font */
  --font-display: 'Cormorant Garamond', serif;
  --font-ui:      'Syne', sans-serif;
  --font-mono:    'DM Mono', monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-ui);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font-family:var(--font-ui);cursor:pointer}
input,select,textarea{font-family:var(--font-ui)}


::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:3px}

.noise{
  position:fixed;inset:0;z-index:9999;
  pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:180px;
}

.loader{
  position:fixed;inset:0;z-index:9998;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .6s var(--ease), visibility .6s;
}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}
.ldr-ico{
  width:52px;height:52px;color:var(--gold);
  animation:spin 2s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.ldr-bar{
  width:160px;height:2px;background:var(--surface-2);border-radius:2px;overflow:hidden;
}
.ldr-fill{
  height:100%;width:0%;background:linear-gradient(90deg,var(--gold),var(--gold-2));
  border-radius:2px;transition:width .3s var(--ease);
}
.ldr-label{
  font-family:var(--font-mono);font-size:12px;color:var(--text-3);letter-spacing:.1em;
}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.sec{padding:100px 0}
.sec-dark{background:var(--bg-2)}

.reveal{
  opacity:0;
  transform:translateY(32px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
  transition-delay:var(--d, 0ms);
}
.reveal.in{opacity:1;transform:none}

.sec-eye{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:11px;
  color:var(--gold);letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:16px;
}
.sec-eye::before{
  content:'';display:block;width:24px;height:1px;background:var(--gold);
}
.sec-title{
  font-family:var(--font-display);
  font-size:clamp(38px,5vw,64px);
  font-weight:600;line-height:1.05;
  letter-spacing:-.02em;margin-bottom:20px;
  color:#fff;
}
.sec-title em{
  font-style:italic;font-weight:300;color:var(--gold);
}
.sec-sub{
  color:var(--text-2);font-size:16px;
  max-width:480px;margin:0 auto;line-height:1.75;
}
.sec-head{text-align:center;margin-bottom:60px}

/* ── HEADER ── */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  border-bottom:1px solid transparent;
  transition:background .4s var(--ease),border-color .4s;
}
header.stuck{
  background:rgba(8,12,20,.9);
  backdrop-filter:blur(20px);
  border-color:var(--border);
}
.nav-inner{
  max-width:1180px;margin:0 auto;
  display:flex;align-items:center;
  padding:0 24px;height:68px;gap:32px;
}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo-ico{
  width:38px;height:38px;border-radius:10px;
  background:var(--gold-dim);border:1px solid rgba(212,168,75,.3);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);flex-shrink:0;
  transition:background .25s;
}
.logo:hover .logo-ico{background:rgba(212,168,75,.25)}
.logo-txt{display:flex;flex-direction:column;gap:0}
.logo-name{font-family:var(--font-ui);font-weight:800;font-size:17px;letter-spacing:-.3px;color:#fff;line-height:1}
.logo-sub{font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}
.nav-links{
  display:flex;align-items:center;gap:2px;
  flex:1;justify-content:center;list-style:none;
}
.nav-links a{
  font-size:13px;font-weight:600;color:var(--text-2);
  padding:7px 16px;border-radius:8px;
  transition:color .2s,background .2s;letter-spacing:.02em;
}
.nav-links a:hover,.nav-links a.active{color:#fff;background:var(--surface)}
.nav-actions{display:flex;gap:10px;align-items:center;flex-shrink:0}

.btn-outline-sm{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 18px;border-radius:var(--r);
  border:1px solid var(--border-2);background:transparent;
  font-size:13px;font-weight:600;color:var(--text-2);
  transition:all .2s;
}
.btn-outline-sm:hover{border-color:var(--gold);color:var(--gold)}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 22px;border-radius:var(--r);
  background:var(--gold);border:none;
  font-size:13px;font-weight:700;color:#0a0a0a;
  transition:all .25s var(--ease);letter-spacing:.01em;
}
.btn-primary:hover{background:var(--gold-2);transform:translateY(-1px);box-shadow:0 8px 24px rgba(212,168,75,.3)}
.btn-arrow{transition:transform .2s}
.btn-primary:hover .btn-arrow{transform:translateX(3px)}

.burger{
  display:none;flex-direction:column;gap:6px;
  background:none;border:none;padding:6px;margin-left:auto;
  cursor:pointer;
}
.burger span{
  display:block;width:22px;height:2px;background:#fff;
  border-radius:2px;transition:all .3s var(--ease);transform-origin:center;
}
.burger.open span:nth-child(1){transform:translateY(4px) rotate(45deg)}
.burger.open span:nth-child(2){transform:translateY(-4px) rotate(-45deg)}

.mobile-nav{
  display:none;flex-direction:column;
  position:absolute;top:68px;left:0;right:0;
  background:var(--bg-2);border-bottom:1px solid var(--border);
  padding:16px 24px 24px;gap:4px;
}
.mobile-nav.open{display:flex}
.mobile-nav a{
  padding:10px 14px;border-radius:var(--r);
  font-size:14px;font-weight:600;color:var(--text-2);
  transition:all .2s;
}
.mobile-nav a:hover{color:#fff;background:var(--surface)}
.mobile-nav hr{border:none;border-top:1px solid var(--border);margin:8px 0}

.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:120px 24px 80px;position:relative;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.orb{
  position:absolute;border-radius:50%;
  filter:blur(100px);opacity:.3;
}
.orb.a{width:600px;height:600px;background:radial-gradient(circle,#1e3a8a,transparent);top:-20%;left:-15%;animation:drift 20s ease-in-out infinite alternate}
.orb.b{width:400px;height:400px;background:radial-gradient(circle,#92400e,transparent);top:30%;right:-10%;animation:drift 25s ease-in-out infinite alternate-reverse}
.orb.c{width:300px;height:300px;background:radial-gradient(circle,#064e3b,transparent);bottom:0;left:40%;animation:drift 18s ease-in-out infinite alternate}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(40px,30px) scale(1.08)}}

.grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--border) 1px,transparent 1px),
    linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:60px 60px;opacity:.5;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 30%,transparent 100%);
}

.hero-body{
  position:relative;z-index:1;
  max-width:780px;margin:0 auto;text-align:center;width:100%;
}

/* Eyebrow */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(212,168,75,.08);border:1px solid rgba(212,168,75,.2);
  color:var(--gold);font-family:var(--font-mono);
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:8px 18px;border-radius:30px;margin-bottom:28px;
}
.eyebrow-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.eyebrow-chip{
  background:var(--gold);color:#000;
  font-size:9px;font-weight:700;
  padding:2px 8px;border-radius:20px;letter-spacing:.05em;
}

.hero-h1{
  font-family:var(--font-display);
  font-size:clamp(42px,7vw,86px);
  line-height:1.02;letter-spacing:-.03em;
  margin-bottom:28px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
}
.hero-h1 span{color:var(--text);font-weight:300}
.hero-h1 em{
  font-style:italic;font-weight:300;
  color:var(--gold);
  -webkit-text-stroke:.5px var(--gold);
}
.hero-h1 strong{font-weight:700;color:#fff}
.period{color:var(--gold)}

.hero-p{
  color:var(--text-2);font-size:16px;
  line-height:1.85;margin-bottom:40px;
}

/* Search Box */
.search-box{
  display:flex;align-items:center;
  background:var(--surface);
  border:1px solid var(--border-2);border-radius:16px;
  padding:6px 6px 6px 24px;
  box-shadow:0 0 60px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.03);
  margin-bottom:48px;gap:0;
  flex-wrap:wrap;
}
.sb-field{
  flex:1;min-width:140px;
  display:flex;flex-direction:column;gap:4px;
  padding:10px 16px 10px 0;
}
.sb-field label{
  display:flex;align-items:center;gap:5px;
  font-family:var(--font-mono);font-size:10px;
  color:var(--text-3);letter-spacing:.1em;text-transform:uppercase;
}
.sb-field select,.sb-field input{
  background:transparent;border:none;outline:none;
  font-size:14px;font-weight:600;color:var(--text);
  width:100%;
}
.sb-field select option{background:var(--bg-3)}
.sb-sep{width:1px;height:36px;background:var(--border);flex-shrink:0}
.sb-btn{
  display:flex;align-items:center;gap:8px;
  background:var(--gold);border:none;
  padding:13px 26px;border-radius:12px;
  font-size:14px;font-weight:700;color:#000;
  transition:all .25s;flex-shrink:0;margin-left:auto;
}
.sb-btn:hover{background:var(--gold-2);transform:translateY(-1px)}

/* Stats */
.hero-stats{
  display:flex;align-items:center;justify-content:center;
  gap:0;flex-wrap:wrap;
}
.hstat{text-align:center;padding:0 32px}
.hstat-n{
  display:block;font-family:var(--font-display);
  font-size:clamp(28px,4vw,42px);font-weight:600;color:#fff;
  line-height:1;margin-bottom:4px;
}
.hstat-n sup{font-size:.55em;vertical-align:super}
.hstat-l{font-family:var(--font-mono);font-size:10px;color:var(--text-3);letter-spacing:.12em;text-transform:uppercase}
.hstat-div{width:1px;height:36px;background:var(--border)}

/* Scroll cue */
.scroll-cue{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:10px;color:var(--text-3);
  letter-spacing:.1em;text-transform:uppercase;
}
.scroll-line{
  width:1px;height:40px;
  background:linear-gradient(var(--gold),transparent);
  animation:scrollDown 2s ease-in-out infinite;
}
@keyframes scrollDown{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(--bg-2);border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  overflow:hidden;padding:14px 0;
}
.ticker-track{
  display:flex;align-items:center;gap:28px;
  white-space:nowrap;
  animation:ticker 25s linear infinite;
  font-family:var(--font-mono);font-size:12px;
  color:var(--text-3);letter-spacing:.1em;text-transform:uppercase;
}
.td{color:var(--gold);font-size:8px}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}


.filter-bar{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:12px 16px;
  margin-bottom:32px;flex-wrap:wrap;gap:12px;
}
.filter-pills{display:flex;gap:6px;flex-wrap:wrap}
.pill{
  padding:7px 18px;border-radius:30px;
  border:1px solid var(--border);background:transparent;
  font-size:12px;font-weight:600;color:var(--text-2);
  transition:all .2s;
}
.pill:hover{border-color:var(--gold);color:var(--gold)}
.pill.active{background:var(--gold);color:#000;border-color:var(--gold)}
.filter-meta{display:flex;align-items:center;gap:12px}
.filter-count{
  font-family:var(--font-mono);font-size:11px;color:var(--text-3);
}
.sort-sel{
  background:var(--bg);border:1px solid var(--border);
  color:var(--text-2);font-size:12px;font-weight:600;
  padding:7px 12px;border-radius:8px;outline:none;
  transition:border-color .2s;
}
.sort-sel:focus{border-color:var(--gold)}

.car-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:20px;
}
.car-card{
  background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r2);
  overflow:hidden;transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
  opacity:0;transform:translateY(24px);
  animation:cardIn .5s var(--ease) forwards;
}
@keyframes cardIn{to{opacity:1;transform:none}}
.car-card:hover{
  transform:translateY(-5px);border-color:rgba(212,168,75,.3);
  box-shadow:0 24px 64px rgba(0,0,0,.4),0 0 0 1px rgba(212,168,75,.1);
}
.car-card.unavailable{opacity:.5}


.car-photo {
  position: relative;
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.car-photo::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 60%, rgba(0,0,0,.7));
  z-index: 1;
  pointer-events: none;
}

.car-visual {
  position: absolute; inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 20px;
}
.car-visual .car-image-real {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 16/9;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,0.15));
  display: block;
  transition: transform .45s var(--ease), filter .45s var(--ease);
}

/* Reconstruct Pajero: Blending & Studio Lighting */
.card-pajero .car-image-real {
  filter: brightness(1.1) contrast(1.1) drop-shadow(0 20px 30px rgba(0,0,0,0.5));
  transform: scale(1.1); /* Posisikan lebih besar agar rapi */
  mask-image: radial-gradient(circle at center, black 60%, transparent 95%);
  -webkit-mask-image: radial-gradient(circle at center, black 60%, transparent 95%);
}

.car-card.unavailable .car-visual .car-image-real {
  filter: grayscale(1) opacity(0.5);
}
.car-card:hover .car-visual .car-image-real {
  transform: scale(1.08) translateY(-4px);
  filter: drop-shadow(0 15px 25px rgba(0,0,0,0.25));
}

.card-pajero:hover .car-visual .car-image-real {
  transform: scale(1.15) translateY(-6px);
  filter: brightness(1.2) contrast(1.15) drop-shadow(0 25px 40px rgba(0,0,0,0.6));
}

.car-badge{
  position:absolute;top:14px;left:14px;z-index:1;
  padding:4px 11px;border-radius:20px;
  font-size:10px;font-weight:700;letter-spacing:.05em;
  backdrop-filter:blur(8px);
}
.badge-terlaris{background:rgba(245,197,66,.15);color:#f5c542;border:1px solid rgba(245,197,66,.3)}
.badge-premium{background:rgba(139,92,246,.15);color:#a78bfa;border:1px solid rgba(139,92,246,.3)}
.badge-hemat{background:rgba(52,211,153,.15);color:#34d399;border:1px solid rgba(52,211,153,.3)}
.badge-vip{background:rgba(212,168,75,.9);color:#000;border:none}
.badge-favorit{background:rgba(251,113,133,.15);color:#fb7185;border:1px solid rgba(251,113,133,.3)}

/* Status dot */
.car-status{
  position:absolute;top:14px;right:14px;z-index:1;
  display:flex;align-items:center;gap:5px;
  background:rgba(0,0,0,.6);backdrop-filter:blur(8px);
  padding:4px 10px;border-radius:20px;
  font-size:10px;font-weight:600;color:#fff;
}
.status-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);animation:blink 2s infinite;
}
.car-card.unavailable .status-dot{background:#ef4444;animation:none}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* Car Body */
.car-body{padding:20px}
.car-name{font-size:17px;font-weight:700;color:#fff;margin-bottom:4px;letter-spacing:-.2px}
.car-cat{font-family:var(--font-mono);font-size:11px;color:var(--text-3);margin-bottom:14px;letter-spacing:.05em}
.car-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.tag{
  padding:3px 10px;border-radius:6px;
  background:var(--surface-2);border:1px solid var(--border);
  font-size:11px;color:var(--text-2);
}
.car-rating{display:flex;align-items:center;gap:7px;margin-bottom:18px}
.stars{color:var(--gold);font-size:12px;letter-spacing:1px}
.r-num{font-weight:700;font-size:13px;color:#fff}
.r-cnt{font-family:var(--font-mono);font-size:11px;color:var(--text-3)}

.car-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:16px;border-top:1px solid var(--border);
}
.price-wrap .price{
  font-family:var(--font-display);
  font-size:26px;font-weight:600;color:var(--gold);
  line-height:1;letter-spacing:-.03em;
}
.price-wrap .price-note{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:3px}

.btn-book{
  padding:10px 22px;border-radius:var(--r);
  background:var(--gold);border:none;
  font-size:12px;font-weight:700;color:#000;
  transition:all .25s;
}
.btn-book:hover{background:var(--gold-2);transform:translateY(-1px);box-shadow:0 8px 20px rgba(212,168,75,.3)}
.btn-book:disabled{
  background:var(--surface-2);color:var(--text-3);
  cursor:not-allowed;transform:none;box-shadow:none;
}

/* Empty state */
.empty{
  grid-column:1/-1;text-align:center;padding:80px 20px;
  color:var(--text-3);
}
.empty .ei{font-size:48px;margin-bottom:16px;opacity:.4}
.empty h3{font-size:18px;font-weight:700;margin-bottom:6px;color:var(--text-2)}

/* ── KEUNGGULAN ── */
.two-col{
  display:grid;grid-template-columns:1fr 1.4fr;
  gap:80px;align-items:center;
}
.feat-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.feat-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r2);padding:24px 20px;
  transition:border-color .3s,transform .3s,box-shadow .3s;
}
.feat-card:hover{
  border-color:rgba(212,168,75,.25);transform:translateY(-3px);
  box-shadow:0 16px 40px rgba(0,0,0,.3);
}
.fc-icon{
  width:42px;height:42px;border-radius:12px;
  background:var(--gold-dim);border:1px solid rgba(212,168,75,.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);margin-bottom:14px;
}
.feat-card h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:6px}
.feat-card p{font-size:12px;color:var(--text-2);line-height:1.6}

/* ── PROMO ── */
.promo-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;
}
.promo-card{
  border-radius:var(--r2);padding:32px 28px;
  position:relative;overflow:hidden;
  transition:transform .3s var(--ease);
}
.promo-card:hover{transform:translateY(-4px)}
.promo-card::before{
  content:'';position:absolute;
  right:-60px;top:-60px;width:200px;height:200px;
  border-radius:50%;background:rgba(255,255,255,.06);
}
.promo-card::after{
  content:'';position:absolute;
  right:-20px;bottom:-40px;width:130px;height:130px;
  border-radius:50%;background:rgba(255,255,255,.04);
}

.pc-blue{background:linear-gradient(135deg,#1a3a8f,#2563eb)}
.pc-purple{background:linear-gradient(135deg,#4c1d95,#7c3aed)}
.pc-teal{background:linear-gradient(135deg,#134e4a,#0d9488)}

.pc-discount{
  position:absolute;top:20px;right:24px;
  font-family:var(--font-display);font-size:52px;font-weight:700;
  color:rgba(255,255,255,.12);line-height:1;
}
.pc-code{
  font-family:var(--font-mono);font-size:13px;font-weight:500;
  background:rgba(255,255,255,.15);color:#fff;
  display:inline-block;padding:5px 14px;border-radius:8px;
  border:1px dashed rgba(255,255,255,.3);margin-bottom:12px;
  letter-spacing:.06em;
}
.promo-card h3{font-size:20px;font-weight:700;color:#fff;margin-bottom:8px}
.promo-card p{font-size:13px;color:rgba(255,255,255,.75);line-height:1.65;margin-bottom:20px}
.promo-card button{
  background:rgba(255,255,255,.15);color:#fff;
  border:1px solid rgba(255,255,255,.3);
  padding:9px 20px;border-radius:var(--r);
  font-size:12px;font-weight:700;cursor:pointer;
  transition:all .25s;backdrop-filter:blur(4px);
}
.promo-card button:hover{background:rgba(255,255,255,.3)}

/* ── FOOTER ── */
footer{background:var(--bg-2);border-top:1px solid var(--border)}
.footer-grid{
  display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;
  gap:48px;padding:72px 0 64px;
}
.fg-brand p{font-size:13px;color:var(--text-2);line-height:1.75;max-width:280px;margin:20px 0 24px}
.socials{display:flex;gap:8px}
.social{
  width:36px;height:36px;border-radius:10px;
  background:var(--surface);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-2);transition:all .2s;
}
.social:hover{background:var(--gold-dim);border-color:rgba(212,168,75,.3);color:var(--gold)}

.fg-col h5{
  font-size:11px;font-family:var(--font-mono);
  color:var(--text-3);letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:18px;
}
.fg-col a{
  display:block;font-size:13px;color:var(--text-2);
  margin-bottom:10px;transition:color .2s;
}
.fg-col a:hover{color:var(--gold)}
.fc-item{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13px;color:var(--text-2);margin-bottom:12px;
}
.fc-item svg{flex-shrink:0;margin-top:2px;color:var(--gold)}

.footer-bottom{border-top:1px solid var(--border);padding:20px 0}
.footer-bottom-row{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.footer-bottom-row span,.footer-bottom-row a{
  font-family:var(--font-mono);font-size:11px;color:var(--text-3);letter-spacing:.05em;
}
.footer-bottom-row div{display:flex;gap:20px}
.footer-bottom-row a:hover{color:var(--gold)}

/* ── FABs ── */
.wa-fab{
  position:fixed;bottom:28px;right:28px;z-index:50;
  width:54px;height:54px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,.4);
  transition:transform .25s,box-shadow .25s;
}
.wa-fab:hover{transform:scale(1.1);box-shadow:0 12px 36px rgba(37,211,102,.55)}

.back-top{
  position:fixed;bottom:28px;right:96px;z-index:50;
  width:44px;height:44px;border-radius:50%;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text-2);display:none;align-items:center;justify-content:center;
  transition:all .25s;
}
.back-top.show{display:flex}
.back-top:hover{background:var(--gold-dim);border-color:rgba(212,168,75,.3);color:var(--gold)}

/* ── MODAL ── */
.overlay{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.75);backdrop-filter:blur(10px);
  align-items:center;justify-content:center;padding:20px;
}
.overlay.open{display:flex}
.modal{
  background:var(--bg-3);border:1px solid var(--border-2);
  border-radius:24px;width:100%;max-width:500px;max-height:90vh;
  overflow-y:auto;
  animation:modalIn .3s var(--ease);
}
@keyframes modalIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
.modal-ok{max-width:440px}

.modal-head{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:28px 28px 20px;border-bottom:1px solid var(--border);
  gap:16px;
}
.modal-eye{
  font-family:var(--font-mono);font-size:10px;color:var(--gold);
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;
}
.modal-car{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}
.modal-price{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}
.modal-x{
  background:var(--surface);border:1px solid var(--border);
  width:32px;height:32px;border-radius:50%;
  color:var(--text-2);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all .2s;
}
.modal-x:hover{background:var(--surface-2);color:#fff}

.modal-info { flex: 1; }
.modal-img-wrap {
  width: 120px;
  height: 70px;
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface);
  border: 1px solid var(--border);
}
.modal-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
}

.modal-body{padding:24px 28px;display:flex;flex-direction:column;gap:16px}
.mf-row,.mf-2col{display:flex;gap:14px}
.mf-2col{gap:14px}
.mf-field{flex:1;display:flex;flex-direction:column;gap:6px}
.mf-field label{
  font-family:var(--font-mono);font-size:10px;
  color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;
}
.mf-field input,.mf-field select{
  background:var(--surface);border:1px solid var(--border);
  color:var(--text);border-radius:var(--r);
  padding:11px 14px;font-size:14px;outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.mf-field input:focus,.mf-field select:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(212,168,75,.12);
}
.mf-field select option{background:var(--bg-3)}
.mf-promo{display:flex;gap:10px;align-items:flex-end}
.btn-apply{
  padding:11px 18px;border-radius:var(--r);
  background:var(--surface-2);border:1px solid var(--border-2);
  font-size:12px;font-weight:700;color:var(--text-2);
  white-space:nowrap;transition:all .2s;
}
.btn-apply:hover{border-color:var(--gold);color:var(--gold)}

/* Cost box */
.cost-box{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:16px;
  display:flex;flex-direction:column;gap:10px;
}
.cost-row{
  display:flex;justify-content:space-between;
  font-size:13px;color:var(--text-2);
}
.cost-row strong{color:var(--text)}
.cost-green strong{color:#34d399}
.cost-total{
  display:flex;justify-content:space-between;
  font-size:16px;font-weight:700;
  border-top:1px solid var(--border);padding-top:12px;
}
.cost-total strong{color:var(--gold);font-family:var(--font-display);font-size:20px}

.modal-foot{padding:0 28px 28px}
.btn-confirm{
  width:100%;padding:14px 24px;
  background:var(--gold);border:none;border-radius:var(--r);
  font-size:15px;font-weight:700;color:#000;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .25s;
}
.btn-confirm:hover{background:var(--gold-2);transform:translateY(-1px);box-shadow:0 10px 30px rgba(212,168,75,.35)}
.btn-confirm .btn-arrow{transition:transform .2s}
.btn-confirm:hover .btn-arrow{transform:translateX(4px)}

/* Success Modal — E-Kwitansi Receipt */
.modal-receipt{max-width:480px;background:var(--bg-3);border:1px solid var(--border-2);max-height:90vh;overflow-y:auto}

.receipt-body{padding:44px 32px 36px;text-align:center}

/* Success Icon with pulse */
.receipt-success-icon{
  position:relative;
  width:80px;height:80px;
  margin:0 auto 24px;
}
.receipt-check-ring{
  width:80px;height:80px;border-radius:50%;
  background:linear-gradient(135deg,#059669,#10b981);
  display:flex;align-items:center;justify-content:center;
  color:#fff;position:relative;z-index:1;
  animation:popIn .5s cubic-bezier(.175,.885,.32,1.275);
  box-shadow:0 8px 32px rgba(16,185,129,.35);
}
.receipt-check-pulse{
  position:absolute;inset:-8px;border-radius:50%;
  border:2px solid rgba(16,185,129,.35);
  animation:receiptPulse 2s ease-out infinite;
}
@keyframes receiptPulse{
  0%{transform:scale(.85);opacity:.8}
  100%{transform:scale(1.4);opacity:0}
}

.receipt-title{
  font-size:26px;font-weight:700;color:#fff;margin-bottom:8px;
  letter-spacing:-.02em;
}
.receipt-subtitle{
  font-size:14px;color:var(--text-2);margin-bottom:28px;line-height:1.6;
}

/* ── Receipt Card (Struk) ── */
.receipt-card{
  background:var(--surface);
  border:1px solid var(--border-2);
  border-radius:16px;
  padding:0;
  margin-bottom:24px;
  overflow:hidden;
  text-align:left;
  box-shadow:0 8px 40px rgba(0,0,0,.25);
}

.receipt-card-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;
}
.receipt-brand{
  display:flex;align-items:center;gap:8px;
  color:var(--gold);font-family:var(--font-ui);
  font-size:14px;font-weight:700;
}
.receipt-label{
  font-family:var(--font-mono);font-size:10px;
  color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;
  background:var(--surface-2);border:1px solid var(--border);
  padding:4px 12px;border-radius:20px;
}

/* Notched divider — mimics real receipt tear line */
.receipt-divider{
  display:flex;align-items:center;
  position:relative;margin:0 -1px;
}
.receipt-divider-notch{
  width:14px;height:14px;border-radius:50%;
  background:var(--bg-3);flex-shrink:0;
  position:relative;z-index:1;
}
.receipt-divider-notch.left{margin-left:-7px}
.receipt-divider-notch.right{margin-right:-7px}
.receipt-divider-line{
  flex:1;height:1px;
  border-top:1px dashed var(--border-2);
}

.receipt-divider-dashed{
  border-top:1px dashed var(--border);
  margin:0 22px;
}

/* Booking ID highlight */
.receipt-booking-id{
  display:flex;flex-direction:column;align-items:center;
  padding:18px 22px;gap:6px;
}
.receipt-booking-label{
  font-family:var(--font-mono);font-size:10px;
  color:var(--text-3);letter-spacing:.15em;text-transform:uppercase;
}
.receipt-booking-code{
  font-family:var(--font-mono);font-size:22px;font-weight:700;
  color:var(--gold);letter-spacing:.1em;
  background:var(--gold-dim);
  padding:10px 28px;border-radius:var(--r);
  border:1px dashed rgba(212,168,75,.3);
  display:inline-block;
  animation:shimmerBooking 3s ease-in-out infinite;
}
@keyframes shimmerBooking{
  0%,100%{box-shadow:0 0 0 0 rgba(212,168,75,.0)}
  50%{box-shadow:0 0 20px 4px rgba(212,168,75,.12)}
}

/* Detail rows inside receipt */
.receipt-details{
  padding:16px 22px;
  display:flex;flex-direction:column;gap:11px;
}
.receipt-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;
}
.receipt-row span{color:var(--text-2);font-weight:400}
.receipt-row strong{
  color:var(--text);font-weight:600;text-align:right;
  max-width:55%;word-break:break-word;
}

/* Total row */
.receipt-total-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 22px;
}
.receipt-total-row span{
  font-size:14px;font-weight:600;color:var(--text-2);
}
.receipt-total-row strong{
  font-family:var(--font-display);
  font-size:24px;font-weight:700;color:var(--gold);
  letter-spacing:-.02em;
}

/* Footer note */
.receipt-footer-note{
  display:flex;align-items:center;gap:8px;
  padding:14px 22px 18px;
  font-size:11px;color:var(--text-3);
  font-family:var(--font-mono);
}
.receipt-footer-note svg{
  flex-shrink:0;color:var(--text-3);opacity:.6;
}

/* ── Action Buttons ── */
.receipt-actions{
  display:flex;flex-direction:column;gap:12px;
}

.btn-wa-chat{
  width:100%;padding:14px 24px;border-radius:var(--r);
  background:#25D366;border:none;
  font-size:15px;font-weight:700;color:#fff;
  display:flex;align-items:center;justify-content:center;gap:10px;
  cursor:pointer;transition:all .25s var(--ease);
  box-shadow:0 6px 24px rgba(37,211,102,.3);
}
.btn-wa-chat:hover{
  background:#22c55e;transform:translateY(-2px);
  box-shadow:0 10px 32px rgba(37,211,102,.45);
}
.btn-wa-chat:active{transform:translateY(0)}

.btn-outline-back{
  width:100%;padding:13px 24px;border-radius:var(--r);
  background:transparent;
  border:1px solid var(--border-2);
  font-size:14px;font-weight:600;color:var(--text-2);
  display:flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;transition:all .25s var(--ease);
}
.btn-outline-back:hover{
  border-color:var(--gold);color:var(--gold);
  background:var(--gold-dim);
}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:28px;left:50%;transform:translateX(-50%);
  background:var(--surface-2);border:1px solid var(--border-2);
  color:var(--text);padding:12px 24px;border-radius:12px;
  font-size:13px;font-weight:600;z-index:9000;
  display:none;align-items:center;gap:8px;
  box-shadow:0 16px 48px rgba(0,0,0,.5);
  white-space:nowrap;
  animation:toastIn .3s var(--ease);
}
.toast.show{display:flex}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}


.scroll-progress{
  position:fixed;top:0;left:0;z-index:101;
  height:2px;width:0%;
  background:linear-gradient(90deg,var(--gold),var(--gold-2),var(--blue-2));
  transition:width .05s linear;
  box-shadow:0 0 8px rgba(212,168,75,.4);
}


.cursor-glow{
  position:fixed;z-index:9997;
  width:280px;height:280px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(212,168,75,.06) 0%,transparent 70%);
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:opacity .3s;
  opacity:0;
}
.cursor-glow.active{opacity:1}

/* ── STEPS / HOW IT WORKS ── */
.steps-row{
  display:flex;align-items:center;justify-content:center;
  gap:0;flex-wrap:wrap;
}
.step-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r2);
  padding:32px 28px;
  text-align:center;
  flex:1;min-width:200px;max-width:300px;
  position:relative;
  transition:border-color .3s,transform .3s,box-shadow .3s;
}
.step-card:hover{
  border-color:rgba(212,168,75,.25);
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(0,0,0,.3);
}
.step-num{
  font-family:var(--font-display);
  font-size:48px;font-weight:700;
  color:rgba(212,168,75,.1);
  line-height:1;margin-bottom:8px;
  letter-spacing:-.02em;
}
.step-icon{
  width:52px;height:52px;border-radius:14px;
  background:var(--gold-dim);border:1px solid rgba(212,168,75,.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);margin:0 auto 16px;
}
.step-card h4{
  font-size:16px;font-weight:700;color:#fff;margin-bottom:8px;
}
.step-card p{
  font-size:13px;color:var(--text-2);line-height:1.65;
}
.step-connector{
  display:flex;align-items:center;justify-content:center;
  padding:0 12px;flex-shrink:0;
}

/* ── TESTIMONIALS ── */
.testi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:20px;
}
.testi-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r2);
  padding:28px 24px;
  transition:border-color .3s,transform .3s,box-shadow .3s;
  display:flex;flex-direction:column;
}
.testi-card:hover{
  border-color:rgba(212,168,75,.25);
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(0,0,0,.3);
}
.testi-stars{
  color:var(--gold);font-size:14px;
  letter-spacing:2px;margin-bottom:16px;
}
.testi-quote{
  font-family:var(--font-display);
  font-size:18px;font-weight:300;
  font-style:italic;
  color:var(--text);line-height:1.7;
  flex:1;margin-bottom:20px;
}
.testi-author{
  display:flex;align-items:center;gap:12px;
  padding-top:16px;border-top:1px solid var(--border);
}
.testi-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--gold-dim);border:1px solid rgba(212,168,75,.3);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:12px;font-weight:700;
  color:var(--gold);flex-shrink:0;
}
.testi-name{
  font-size:14px;font-weight:700;color:#fff;
}
.testi-role{
  font-family:var(--font-mono);font-size:11px;
  color:var(--text-3);letter-spacing:.05em;margin-top:2px;
}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .two-col{grid-template-columns:1fr;gap:48px}
  .col-left{text-align:center}
  .col-left .sec-sub{margin:0 auto}
  .col-left .btn-primary{display:inline-flex}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .fg-brand{grid-column:1/-1}
  .steps-row{gap:16px}
  .step-connector{display:none}
}
@media(max-width:768px){
  .nav-links,.nav-actions{display:none}
  .burger{display:flex}
  .search-box{flex-direction:column;padding:16px}
  .sb-field{padding:0;width:100%}
  .sb-sep{width:100%;height:1px}
  .sb-btn{width:100%;justify-content:center}
  .feat-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .hero-stats{gap:0}
  .hstat{padding:0 16px}
  .mf-2col{flex-direction:column}
  .testi-grid{grid-template-columns:1fr}
  .cursor-glow{display:none}
}
@media(max-width:480px){
  .sec{padding:70px 0}
  .hero{padding:100px 20px 70px}
  .hstat{padding:0 12px}
  .hstat-n{font-size:24px}
  .hstat-div{height:24px}
  .car-grid{grid-template-columns:1fr}
  .promo-grid{grid-template-columns:1fr}
  .receipt-body{padding:32px 18px 40px}
  .receipt-booking-code{font-size:18px;padding:8px 20px}
  .receipt-total-row strong{font-size:20px}
  .receipt-card-header{padding:14px 16px}
  .receipt-details{padding:14px 16px}
  .receipt-total-row{padding:14px 16px}
  .receipt-footer-note{padding:10px 16px 14px}
  .receipt-booking-id{padding:14px 16px}
  .modal-head,.modal-body,.modal-foot{padding-left:20px;padding-right:20px}
  .step-card{min-width:100%;max-width:100%}
}

