/* style.css — Senopati Tour */

/* Reset ringkas */
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#fff}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.container{max-width:1200px;margin:0 auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:10px;padding:10px 16px;font-weight:600;border:1px solid transparent;transition:.2s}
.btn.primary{background:#5b43d6;color:#fff}
.btn.primary:hover{filter:brightness(1.05)}
.btn.ghost{background:transparent;border-color:#5b43d6;color:#5b43d6}
.btn.ghost:hover{background:#5b43d612}
.btn.sm{padding:8px 12px;font-size:14px}
.btn.lg{padding:12px 22px;font-size:18px}
.btn.block{width:100%}

/* ===== TOPBAR ===== */
.topbar{
  background:#5b43d6;
  color:#fff;
  font-size:14px;
}
.topbar .container{
  display:flex;
  justify-content:center;
  align-items:center;
  height:34px;
  gap:24px;
}
.topbar .left{
  display:flex;
  align-items:center;
  gap:24px;
}
.topbar .left a.tap{
  color:rgba(255,255,255,.85);
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-size:16px;
  letter-spacing:.01em;
  transition:color .15s;
}
.topbar .left a.tap:hover{color:#fff}
.topbar .social a{margin-left:10px;opacity:.9}

/* ===== HEADER FLOATING PILL ===== */
.header{
  position:sticky;
  top:0;
  z-index:40;
  background:transparent;
  border-bottom:none;
  box-shadow:none;
  padding:10px 20px;
  pointer-events:none;
  /* background transparent agar konten di bawah tembus */
}
.header-inner{
  max-width:1160px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:6px;
  height:60px;
  background:#fff;
  border-radius:999px;
  padding:0 8px 0 14px;
  box-shadow:0 4px 24px rgba(91,67,214,.13), 0 1px 4px rgba(0,0,0,.06);
  border:1px solid #ede9ff;
  pointer-events:all;
}

/* Brand */
.brand{
  display:flex;align-items:center;gap:9px;
  font-weight:800;font-size:18px;color:#1a1830;
  padding:0 6px 0 0;
  flex-shrink:0;
  position:relative;
}
.brand::after{
  content:'';
  display:block;
  width:1px;height:22px;
  background:#e4e0f7;
  margin-left:12px;
}
.brand img{
  width:46px;height:46px;
  border-radius:50%;
  border:2px solid #ede9ff;
}

/* Nav links */
.nav{display:flex;gap:2px;align-items:center;flex:1}
.nav a{
  padding:7px 14px;
  border-radius:999px;
  font-size:18px;
  font-weight:500;
  color:#4a4568;
  white-space:nowrap;
  transition:background .15s, color .15s;
}
.nav a:hover{background:#f4f2ff;color:#5b43d6}
.nav a.active{background:#ede9ff;color:#5b43d6;font-weight:600}

/* Dropdown */
.dropdown{position:relative}
.dropdown > button{
  background:transparent;border:0;font:inherit;cursor:pointer;
  padding:7px 14px;font-size:13.5px;font-weight:500;
  color:#4a4568;border-radius:999px;
  transition:background .15s,color .15s;
}
.dropdown > button:hover{background:#f4f2ff;color:#5b43d6}
.dropdown .menu{
  position:absolute;top:calc(100% + 10px);left:0;
  background:#fff;border:1px solid #ede9ff;
  border-radius:16px;
  box-shadow:0 12px 36px rgba(91,67,214,.13);
  padding:8px;display:none;min-width:200px;
}
.dropdown:hover .menu{display:block}
.dropdown .menu a{display:block;padding:10px 14px;border-radius:10px;font-size:13.5px;color:#4a4568}
.dropdown .menu a:hover{background:#f4f2ff;color:#5b43d6}

/* Kontak button */
.header .btn.primary{
  border-radius:999px;
  padding:10px 22px;
  font-size:16px;
  font-weight:700;
  background:#5b43d6;
  border:none;
  color:#fff;
  white-space:nowrap;
  flex-shrink:0;
  box-shadow:none;
  transition:background .2s, transform .15s, box-shadow .2s;
  margin-left:2px;
}
.header .btn.primary:hover{
  background:#4835b0;
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(91,67,214,.32);
}

/* Hamburger */
.hamburger{
  font-size:18px;
  background:transparent;
  border:1px solid #ede9ff;
  border-radius:999px;
  width:38px;height:38px;
  display:none;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:#5b43d6;
  margin-left:2px;
  flex-shrink:0;
  transition:background .15s;
}
.hamburger:hover{background:#f4f2ff}

@media (max-width:980px){
  .header{top:8px;padding:0 12px}
  .header-inner{padding:0 8px 0 10px;height:54px}
  .hamburger{display:inline-flex}
  .nav{
    position:fixed;
    left:12px;right:12px;
    top:86px;
    background:#fff;
    border:1px solid #ede9ff;
    border-radius:20px;
    box-shadow:0 12px 36px rgba(91,67,214,.14);
    display:none;flex-direction:column;
    padding:10px;
    z-index:50;
    gap:2px;
    align-items:stretch;
  }
  .nav.show{display:flex}
  .nav a{padding:13px 16px;border-radius:12px;text-align:center;font-size:15px}
}

/* ===== HERO (FINAL) — pakai <img>, full responsif, tanpa kotak hitam ===== */
.hero{ position:relative; overflow:hidden; margin-bottom:32px; }
.hero-slide{ display:none; position:relative; background:none !important; min-height:auto; }
.hero-slide.active{ display:block; }

.hero-img{
  width:100%; height:auto; display:block;
  object-fit:contain;
  object-position:center;
}
.hero .overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.55));
  z-index:1; pointer-events:none;
}
.hero-content{
  position:absolute; inset:0;
  display:flex; flex-direction:column; justify-content:center;
  padding:clamp(20px, 5vw, 60px);
  color:#fff; z-index:2;
  background:transparent !important; backdrop-filter:none !important;
}
.hero-content h1{ font-size:40px; line-height:1.15; margin:16px 0 10px; font-weight:800; text-shadow:0 6px 25px rgba(0,0,0,.35); }
.hero-content p{ opacity:.95; margin-bottom:14px; }
.hero-content .price-start{ margin:8px 0 18px; opacity:.95; }

.hero .hero-dots{ position:absolute; left:50%; transform:translateX(-50%); bottom:14px; display:flex; gap:8px; z-index:3; }
.hero-dots button{ width:10px; height:10px; border-radius:50%; border:0; background:#ffffff80; cursor:pointer; }
.hero-dots button.active{ background:#fff; }
.stars{ opacity:.9 }

@media (max-width:768px){
  .hero-content{
    justify-content:flex-end;
    padding:14px 16px 64px;
    max-width:92vw;
  }
  .hero-content h1{ font-size:24px; line-height:1.2; }
  .hero-content p{ font-size:14px; }
  .btn.lg{ padding:10px 16px; font-size:16px; }
  .hero-dots button{ width:8px; height:8px; }
}
@media (min-width:992px){ .hero-content{ justify-content:center; } }

.edit-hook{ display:none }
body.admin .edit-hook{ display:inline-block; margin-top:8px; font-size:12px; opacity:.7 }

/* Icon strip */
.icon-strip{background:#ffffff;margin-top:0}
.icons{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.icon-card{background:#ffffff;border:1px solid #eee;border-radius:16px;padding:12px;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 6px 24px rgba(0,0,0,.05)}
.icon-card img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid #5b43d620}
.icon-card p{margin:8px 0 0;font-size:15px}

@media (max-width:980px){
  .icons{
    display:flex;
    flex-direction:row;
    overflow-x:auto;
    gap:12px;
    padding-bottom:8px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    -ms-overflow-style:none;
    scrollbar-width:none;
  }
  .icons::-webkit-scrollbar{display:none}
  .icon-card{
    flex:0 0 130px;
    scroll-snap-align:start;
  }
}

/* Section */
.section{padding:48px 0;background:#fff;}
.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.section h2{
  margin:0;
  font-size:24px;
  font-weight:800;
  color:#1a1830;
  position:relative;
  padding-left:14px;
}
.section h2::before{
  content:'';
  position:absolute;
  left:0; top:50%;
  transform:translateY(-50%);
  width:4px; height:70%;
  background:linear-gradient(180deg,#5b43d6,#9b8af4);
  border-radius:4px;
}

/* Cards grid */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* === CARD REDESIGN === */
.card{
  background:#fff;
  border:1.5px solid #ede9ff;
  border-radius:20px;
  overflow:hidden;
  -webkit-mask-image:-webkit-radial-gradient(white,black); /* Safari fix */
  mask-image:radial-gradient(white,black);
  box-shadow:0 2px 12px rgba(91,67,214,.07), 0 8px 32px rgba(0,0,0,.06);
  display:flex;
  flex-direction:column;
  transition:transform .25s ease, box-shadow .25s ease;
  position:relative;
  isolation:isolate;
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 12px 40px rgba(91,67,214,.18), 0 4px 16px rgba(0,0,0,.08);
}

/* Thumbnail */
.thumb{
  display:block;
  aspect-ratio:4/3;
  background:#e0e0e0;
  overflow:hidden;
  position:relative;
  border-radius:20px 20px 0 0; /* ikuti sudut atas kartu */
  flex-shrink:0;
  margin:0; /* tidak ada gap */
}
.thumb img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .4s ease;
  display:block;
  margin:0; /* hapus gap inline */
}
.card:hover .thumb img{
  transform:scale(1.06);
}

/* Badge lokasi overlay di atas foto */
.thumb::after{
  content:attr(data-loc);
  position:absolute;
  bottom:10px; left:10px;
  background:rgba(255,255,255,.92);
  color:#5b43d6;
  font-size:13px;font-weight:700;
  padding:4px 10px;
  border-radius:999px;
  backdrop-filter:blur(4px);
  pointer-events:none;
}

/* Card body */
.card-body{
  padding:16px 18px 18px;
  display:flex;
  flex-direction:column;
  flex:1;
  gap:6px;
}
.card .title{
  margin:0;
  font-size:16px;
  font-weight:700;
  color:#1a1830;
  line-height:1.35;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Rating & lokasi */
.sub{
  display:flex;
  align-items:center;
  gap:6px;
  color:#888;
  font-size:13px;
  flex-wrap:wrap;
}
.rating{
  display:inline-flex;
  align-items:center;
  gap:3px;
  color:#f5a623;
  font-weight:600;
}
.rating small{color:#888;font-weight:400}
.dot{opacity:.5}
.loc{
  color:#8b86b0;
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:120px;
}

/* Divider tipis */
.card-body::before{
  content:'';
  display:block;
  order:-1;
}

/* Price */
.price{
  margin:4px 0 10px;
  font-size:14px;
  color:#888;
  flex:1;
}
.price strong{
  display:block;
  font-size:19px;
  font-weight:800;
  color:#5b43d6;
  line-height:1.2;
  margin-top:2px;
}

/* Button override di dalam card */
.card .btn.primary.block{
  border-radius:12px;
  padding:11px 16px;
  font-size:15px;
  font-weight:700;
  background:linear-gradient(135deg,#5b43d6,#7c63ee);
  border:none;
  letter-spacing:.01em;
  transition:filter .2s, transform .15s;
}
.card .btn.primary.block:hover{
  filter:brightness(1.1);
  transform:translateY(-1px);
}

@media (max-width:980px){ .cards{grid-template-columns:repeat(2,1fr)} }
@media (max-width:620px){ .cards{grid-template-columns:1fr} }

/* Why */
.why{background:#f5f3ff;padding:52px 0 64px}
.why-eyebrow{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#4835b0;background:#edeaff;border:1px solid #c9c2f5;padding:4px 14px;border-radius:100px;margin-bottom:10px}
.why-heading{font-size:26px;font-weight:800;color:#1a1830;margin:0 0 28px;line-height:1.3}
.why-heading span{color:#5b43d6}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.why-card{background:#fff;border:1px solid #e4e0f7;border-radius:20px;padding:24px 22px 20px;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:.2s}
.why-card::after{content:'';position:absolute;bottom:0;right:0;width:90px;height:90px;border-radius:50%;background:#f5f3ff;transform:translate(35%,35%)}
.why-card:hover{border-color:#b0a6e8;box-shadow:0 8px 32px rgba(91,67,214,.09)}
.why-card--accent{background:#a8a0cd;border-color:#7264b7}
.why-card--accent::after{background:#4e38c4}
.why-card--accent:hover{border-color:#4e38c4;box-shadow:0 8px 32px rgba(91,67,214,.28)}
.why-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px}
.why-icon{width:46px;height:46px;border-radius:13px;background:#edeaff;display:flex;align-items:center;justify-content:center;color:#5b43d6;flex-shrink:0}
.why-card--accent .why-icon{background:rgba(255,255,255,.15);color:#fff}
.why-num{font-size:37px;font-weight:800;color:#e4e0f7;line-height:1;letter-spacing:-.02em}
.why-card--accent .why-num{color:rgba(255,255,255,.15)}
.why-title{font-size:16px;font-weight:800;color:#1a1830;margin:0 0 8px}
.why-card--accent .why-title{color:#fff}
.why-desc{font-size:14px;color:#6d6890;line-height:1.65;margin:0 0 16px;flex:1}
.why-card--accent .why-desc{color:rgba(255,255,255,.75)}
.why-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#5b43d6;background:#edeaff;border:1px solid #c9c2f5;padding:4px 11px;border-radius:100px;position:relative;z-index:1}
.why-card--accent .why-pill{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3);color:#fff}
@media (max-width:980px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.why-grid{grid-template-columns:1fr}}

/* Testimoni */
.testi{padding:48px 0 36px;background:#fff}
.testi-eyebrow{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#4835b0;margin-bottom:20px;display:block}
.testi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:0}
.testi-card{border:1px solid #e4e0f7;border-radius:16px;padding:16px;background:#f8f7ff;display:flex;flex-direction:column;gap:8px}
.testi-card .head{display:flex;gap:10px;align-items:center}
.testi-card img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid #c9c2f5}
.testi-card strong{font-size:15px;color:#1a1830;display:block;line-height:1.3}
.testi-card .meta{font-size:13px;color:#9a96b8;margin-top:2px}
.testi-stars{color:#f5c842}
.testi-quote{font-size:28px;color:#c9c2f5;font-family:Georgia,serif;line-height:1;margin-top:2px}
.testi-card p{font-size:14px;color:#6d6890;line-height:1.65;margin:0;font-style:italic}
.center{text-align:center;margin-top:16px}
@media (max-width:980px){.testi-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.testi-grid{grid-template-columns:1fr}}

/* CTA */
.cta{background:#fff;padding:0 0 48px}
.cta-box{position:relative;border-radius:22px;overflow:hidden;min-height:220px;display:flex;align-items:center;justify-content:center;background:url('assets/kawah-bromo.jpg') center/cover no-repeat}
.cta-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(60,30,180,.78),rgba(91,67,214,.65))}
.cta-content{position:relative;z-index:2;text-align:center;padding:44px 32px}
.cta-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);padding:4px 14px;border-radius:100px;margin-bottom:14px}
.cta-box h3{font-size:20px;font-weight:800;color:#fff;line-height:1.45;margin:0 0 8px}
.cta-sub{font-size:13px;color:rgba(255,255,255,.75);margin:0 0 22px}
.cta-box .btn.primary{background:#5b43d6;border-radius:100px;padding:13px 30px;font-size:15px;box-shadow:0 8px 24px rgba(0,0,0,.25)}

/* Footer */

/* ===== FOOTER ===== */
.footer {
  position: relative;
  background: #0f0c24;
  color: #fff;
  overflow: hidden;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
}

/* Ambient glow kiri atas */
.footer::before {
  content: '';
  position: absolute;
  top: -120px; left: -80px;
  width: 420px; height: 420px;
  background: radial-gradient(circle, rgba(91,67,214,.25) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
/* Ambient glow kanan bawah */
.footer::after {
  content: '';
  position: absolute;
  bottom: -100px; right: -60px;
  width: 340px; height: 340px;
  background: radial-gradient(circle, rgba(155,138,244,.15) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* Garis tipis gradient di paling atas footer */
.footer-topline {
  height: 1px;
  background: linear-gradient(90deg, transparent, #5b43d660, #9b8af440, transparent);
}

/* ===== GRID UTAMA ===== */
.foot-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.7fr 1.4fr 1.2fr;
  gap: 48px;
  padding: 56px 28px 48px;
  max-width: 1200px;
  margin: 0 auto;
}

/* ===== COL 1: Brand ===== */
.brand.foot {
  display: flex;
  align-items: center;
  gap: 11px;
  margin-bottom: 16px;
}
.brand.foot img {
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 2px solid rgba(91,67,214,.5);
  object-fit: cover;
}
.brand.foot span {
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.01em;
}
/* hilangkan divider vertikal yang muncul di header */
.brand.foot::after { display: none; }

.footer .foot-grid > div:first-child > p {
  font-size: 14px;
  line-height: 1.75;
  color: rgba(255,255,255,.5);
  margin-bottom: 22px;
  max-width: 280px;
}

/* Social icons */
.footer .social {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.footer .social a {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.6);
  font-size: 15px;
  margin: 0;
  transition: background .18s, color .18s, border-color .18s, transform .18s;
  text-decoration: none;
}
.footer .social a:hover {
  background: #5b43d6;
  border-color: #5b43d6;
  color: #fff;
  transform: translateY(-2px);
}

/* ===== COL 2: Kontak ===== */
.foot-grid h4 {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #9b8af4;
  margin: 0 0 18px;
}
.foot-grid address {
  font-size: 14px;
  color: rgba(255,255,255,.55);
  line-height: 1.75;
  margin-bottom: 18px;
  font-style: normal;
}
.foot-grid address strong {
  display: block;
  color: rgba(255,255,255,.82);
  font-weight: 600;
  font-size: 13.5px;
  margin-bottom: 5px;
}

/* Link kontak (tel & email) */
.foot-grid a.tap {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,.6);
  font-size: 14px;
  margin-bottom: 10px;
  transition: color .15s;
  text-decoration: none;
}
.foot-grid a.tap:hover { color: #9b8af4; }

/* Icon pill kecil di sebelah kontak */
.foot-grid a.tap::before {
  content: '';
  display: inline-block;
  width: 32px; height: 32px;
  border-radius: 9px;
  background: rgba(91,67,214,.2);
  flex-shrink: 0;
}
/* Override spesifik untuk tel */
.foot-grid a[href^="tel"]::before  { content: '📞'; font-size: 13px; display:inline-flex; align-items:center; justify-content:center; }
.foot-grid a[href^="mailto"]::before { content: '✉️'; font-size: 13px; display:inline-flex; align-items:center; justify-content:center; }

/* ===== COL 3: Partnership ===== */
.galeri {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.galeri img {
  width: 100%;
  aspect-ratio: 2/1;
  object-fit: contain;
  padding: 6px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px;
  filter: brightness(.8) grayscale(.25);
  transition: filter .18s, border-color .18s, background .18s;
}
.galeri img:hover {
  filter: brightness(1) grayscale(0);
  border-color: rgba(91,67,214,.45);
  background: rgba(91,67,214,.1);
}

/* ===== BOTTOM BAR (copyright) ===== */
.copy {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 16px 28px;
  border-top: 1px solid rgba(255,255,255,.07);
  color: rgba(255,255,255,.3);
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}


/* ===== RESPONSIVE FOOTER ===== */
@media (max-width: 980px) {
  .foot-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    padding: 40px 20px;
  }
  .foot-grid > div:last-child {
    grid-column: 1 / -1;
  }
  .galeri { grid-template-columns: repeat(6, 1fr); }
}
@media (max-width: 720px) {
  .footer {
    overflow-x: hidden;
  }
  .foot-grid {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 28px 16px;
    word-break: break-word;
  }
  .galeri { grid-template-columns: repeat(3, 1fr); }
  .footer .foot-grid > div:first-child > p { max-width: 100%; }
  .copy {
    padding: 14px 16px;
    flex-direction: column;
    gap: 6px;
  }
  .copy::after { display: none; }
}
@media (max-width: 520px) {
  .foot-grid { padding: 20px 14px; }
  .copy { font-size: 12px; }
  .foot-grid address,
  .foot-grid a.tap {
    font-size: 13px;
  }
}

/* Chat promo badge */
.chat-badge{position:fixed;right:18px;bottom:18px;background:#ff3b6b;color:#fff;border-radius:999px;padding:12px 16px;font-weight:700;box-shadow:0 12px 30px rgba(0,0,0,.2);z-index:60}

/* Small helpers */
.primary{background:#5b43d6}

/* ===== FIX FINAL: Hero stabil di semua ukuran, no grey bars ===== */

/* container hero punya tinggi pasti berbasis viewport */
.hero{ margin-bottom: 28px; margin-top: -80px; padding-top: 80px; }

.hero-slide{
  position: relative;
  background: #000;          /* latar netral saat gambar loading */
  height: 62vw;              /* default: proporsional di HP (tinggi = 62% lebar) */
  min-height: 320px;         /* jangan terlalu pendek */
  max-height: 68vh;          /* jangan melebihi 68% layar */
  overflow: hidden;
  display: none;
}
.hero-slide.active{ display:block; }

/* di tablet/desktop, pakai tinggi berbasis viewport */
@media (min-width: 768px){
  .hero-slide{
    height: 56vh;
    min-height: 420px;
    max-height: 72vh;
  }
}
@media (min-width: 1200px){
  .hero-slide{
    height: 70vh;
    min-height: 520px;
    max-height: 80vh;
  }
}

/* gambar jadi layer latar yang mengisi penuh area hero */
.hero-img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover;          /* KUNCI: isi penuh, boleh terpotong sedikit */
  object-position: center;    /* kalau perlu fokus atas: center top */
  display:block;
}

/* overlay gradasi untuk kontras teks */
.hero .overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.56));
  z-index:1; pointer-events:none;
}

/* teks mengambang di atas gambar */
.hero-content{
  position:absolute; inset:0;
  display:flex; flex-direction:column; justify-content:center;
  padding: clamp(18px, 5vw, 60px);
  color:#fff; z-index:2;
  background:transparent !important; backdrop-filter:none !important;
}

/* di HP, taruh teks ke bawah supaya foto tetap terlihat */
@media (max-width: 768px){
  .hero-content{
    justify-content:flex-end;
    padding: 14px 16px 72px; /* ruang untuk dots */
    max-width: 92vw;
  }
  .hero-dots button{ width:8px; height:8px; }
}

/* indikator slide */
.hero .hero-dots{
  position:absolute; left:50%; transform:translateX(-50%);
  bottom:14px; display:flex; gap:8px; z-index:3;
}
.hero-dots button{ width:10px; height:10px; border-radius:50%; border:0; background:#ffffff80; cursor:pointer; }
.hero-dots button.active{ background:#fff; }

/* ==== SLIDER HORIZONTAL UNTUK SECTION PAKET ==== */

/* header section: tombol View All + panah */
.head-actions{display:flex;align-items:center;gap:10px}
.slider-arrows{display:flex;gap:8px}
.slider-arrows .arrow{
  width:36px;height:36px;border-radius:999px;
  border:1px solid #e6e3ff;background:#fff;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(0,0,0,.08);font-size:18px;line-height:1;transition:.15s;
}
.slider-arrows .arrow:hover{transform:translateY(-1px)}
.slider-arrows .arrow:disabled{opacity:.45;cursor:default;transform:none}

/* scroller: geser kanan-kiri + snap */
.cards.hscroll{
  display:flex;gap:18px;
  overflow-x:auto;overflow-y:hidden;padding-bottom:12px;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none; /* Firefox */
}
.cards.hscroll::-webkit-scrollbar{display:none} /* WebKit */

/* ukuran kartu di slider */
.cards.hscroll .card{
  flex:0 0 clamp(270px, 30vw, 340px);
  scroll-snap-align:start;
}

/* responsif: di tablet/HP tampilin 1–1.2 kartu */
@media (max-width:980px){ .cards.hscroll .card{flex-basis:76vw} }
@media (max-width:520px){ .cards.hscroll .card{flex-basis:84vw} }

/* Kecilkan tombol CTA di hero (tidak full width) */
.hero-content{
  align-items: flex-start;          /* hindari stretch ke lebar penuh */
}
.hero-content .btn.lg{
  align-self: flex-start;           /* paksa ukuran mengikuti konten */
  width: auto;
  min-width: 0;
  padding: 10px 18px;               /* opsional: agak compact */
}

/* ===== Responsive header & footer SEO/UX ===== */
.tap{touch-action:manipulation}

@media (max-width: 520px){
  /* Topbar stack */
  .topbar .container{
    flex-wrap:wrap; gap:6px; height:auto; padding:8px 20px;
  }
  .topbar .left{display:flex; gap:12px; flex-wrap:wrap}
  .topbar .left .tap{color:#fff; opacity:.95}
  .topbar .social a{font-size:18px}

  /* Header ringkas */
  .header-inner{height:54px}
  .brand img{width:32px;height:32px}
  .brand span{font-size:16px}
  .btn.primary{padding:8px 12px;font-size:14px}
  .nav a{padding:12px 16px}
}

@media (max-width: 980px){
  .nav a{display:block;padding:12px 16px;font-size:15px;border-radius:12px}
  .dropdown > button{padding:12px 16px;width:100%}
  .dropdown .menu{position:static;border:0;box-shadow:none;padding:0 0 0 12px}
  .dropdown .menu a{padding:10px 12px}
}



/* === Tag chips (badge) – kecil & rapat === */
.tags{               /* bungkus kumpulan tag */
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin:6px 0;
}
a.badge, .badge{
  display:inline-flex !important;   /* paksa bukan block */
  align-items:center;
  width:auto !important;            /* jangan 100% */
  max-width:fit-content;
  padding:4px 8px;                  /* lebih kecil */
  font-size:12px;
  line-height:1;
  border-radius:999px;
  background:#5b43d6;
  color:#fff;
  text-decoration:none;
}

/* Gambar di dalam artikel */
.blog-content .blog-img{ margin:16px 0; text-align:center }
.blog-content .blog-img img{ max-width:100%; height:auto; border-radius:12px }
.blog-content .blog-img figcaption{ font-size:12px; color:#666; margin-top:6px }

/* Ukuran & align opsional */
.blog-content .blog-img.half{ width:50% }
.blog-content .blog-img.third{ width:33% }
.blog-content .blog-img.left{ float:left; margin:0 16px 12px 0; text-align:left }
.blog-content .blog-img.right{ float:right; margin:0 0 12px 16px; text-align:right }

/* Clear float di akhir konten */
.blog-content::after{ content:""; display:block; clear:both; }

/* Mobile tweaks */
@media (max-width:680px){
  .blog-content .blog-img{
    width:100% !important;
    float:none !important;
    margin:12px 0;
    text-align:center;
  }
  .blog-content .blog-img img{
    width:100%;
    height:auto;
  }
  .blog-content .blog-img.half,
  .blog-content .blog-img.third{
    width:100% !important;
  }
  .blog-content .blog-img.left,
  .blog-content .blog-img.right{
    float:none !important;
    margin:12px 0 !important;
    text-align:center;
  }
  .blog-content .blog-img figcaption{
    font-size:11px;
    margin-top:4px;
  }
}

/* ===== RAPIKAN FORM ADMIN (AMAN DIPASANG DI style.css) ===== */

/* Padding ke dalam card/form supaya tidak nempel ke tepi */
.admin-ui .admin-form,
.admin-form{
  padding: 18px 20px;        /* dorong konten ke dalam */
  border-radius: 16px;
}

/* Sedikit “gutter” per kolom */
.admin-ui .admin-form > div,
.admin-form > div{
  padding: 0 8px;
}

/* Spasi label & field */
.admin-ui .admin-form label,
.admin-form label{
  display:block;
  margin: 10px 0 6px;
  font-weight: 600;
}

/* Input/textarea/select lebih empuk & tidak nempel */
.admin-ui .admin-form input[type=text],
.admin-ui .admin-form input[type=file],
.admin-ui .admin-form input[type=number],
.admin-ui .admin-form select,
.admin-ui .admin-form textarea,
.admin-form input[type=text],
.admin-form input[type=file],
.admin-form input[type=number],
.admin-form select,
.admin-form textarea{
  width: 100%;
  padding: 12px 14px;        /* inner padding nyaman */
  border: 1px solid #e7e7ef;
  border-radius: 12px;
  background: #fff;
  outline: none;
  box-sizing: border-box;
  margin-bottom: 10px;        /* jarak antar field */
}

.admin-ui .admin-form textarea,
.admin-form textarea{
  min-height: 140px;
  line-height: 1.45;
}

/* Grid dua kolom tetap rapi + gap antar kolom */
.admin-ui .admin-form,
.admin-form{
  display: grid;
  grid-template-columns: 1.25fr 1fr; /* kiri sedikit lebih lebar */
  gap: 24px;
  align-items: start;
}

/* Mobile: satu kolom penuh */
@media (max-width: 880px){
  .admin-ui .admin-form,
  .admin-form{
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 14px 16px;
  }
}

/* Sticky footer */
body { height:100%; }
body{
  min-height:100vh;
  display:flex;
  flex-direction:column;
}

/* Elemen isi halaman harus mengambil sisa tinggi */
main.page, .page-content{ flex:1 0 auto; }

/* Pastikan footer terdorong ke bawah */
.footer{ margin-top:auto; }

/* ==== Mobile nav - floating pill style ==== */
@media (max-width:980px){
  .header-inner{ position: relative; }
}

/* (opsional) kalau browser kamu sudah dukung :has(), hilangkan border header saat menu terbuka */
@supports(selector(.header:has(.nav.show))){
  .header:has(.nav.show){ border-bottom-color:transparent; }
}

.page-body{ line-height:1.8; font-size:16px; }
.page-body p{ margin:0 0 14px; text-align:justify; }
.page-body ul,.page-body ol{ padding-left:22px; margin:0 0 14px; }


/* Loading overlay */
#app-loader {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  min-height: 100svh;
  background: #5b43d6;
  z-index: 99999;
  transition: opacity .45s ease, visibility .45s ease;
}
#app-loader.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.loader-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
  position: relative;
}
/* Logo + pulse ring */
.loader-box { position: relative; }
.loader-pulse-ring {
  position: absolute;
  top: -8px; left: 50%;
  transform: translateX(-50%);
  width: 88px; height: 88px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.3);
  animation: loader-pulse 2s ease-out infinite;
  pointer-events: none;
}
.loader-logo {
  width: 72px; height: 72px;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,0.25);
  display: block;
  position: relative;
  z-index: 1;
}
/* Teks */
.loader-brand {
  font-weight: 800;
  font-size: 20px;
  letter-spacing: .3px;
  color: #fff;
}
.loader-sub {
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  margin-top: 2px;
}
/* Dots */
.loader-dots {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 4px;
}
.loader-dots span {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #fff;
  display: block;
  animation: loader-bounce 1.2s ease-in-out infinite;
}
.loader-dots span:nth-child(2) { animation-delay: .2s; }
.loader-dots span:nth-child(3) { animation-delay: .4s; }

@keyframes loader-pulse {
  0%   { transform: translateX(-50%) scale(1); opacity: .6; }
  70%  { transform: translateX(-50%) scale(1.4); opacity: 0; }
  100% { transform: translateX(-50%) scale(1.4); opacity: 0; }
}
@keyframes loader-bounce {
  0%, 80%, 100% { transform: translateY(0);    opacity: .35; }
  40%            { transform: translateY(-10px); opacity: 1;   }
}

@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
   RESPONSIVE FIX — mobile-first corrections
   ============================================================ */

/* 1. Perbaiki body flex yang merusak layout di beberapa browser */
body {
  display: block !important;
  min-height: 100vh;
}
.footer { margin-top: 0; }

/* 2. Icon strip — pastikan 2 kolom di HP kecil, tidak terpotong */
@media (max-width: 480px) {
  .icons {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    padding: 0 4px;
  }
  .icon-card img {
    width: 64px;
    height: 64px;
  }
  .icon-card p {
    font-size: 11px;
  }
}

/* 3. Section paket cards biasa (non-hscroll) */
@media (max-width: 540px) {
  .cards:not(.hscroll) {
    grid-template-columns: 1fr;
  }
}

/* 4. Testimoni: 1 kolom di HP */
@media (max-width: 640px) {
  .testi-grid {
    grid-template-columns: 1fr;
  }
}
/* 4b. CTA box mobile */
@media (max-width: 480px) {
  .cta-content { padding: 32px 18px; }
  .cta-box h3 { font-size: 16px; }
}

/* 5. Why grid: 1 kolom di HP kecil */
@media (max-width: 540px) {
  .why-grid {
    grid-template-columns: 1fr;
  }
}

/* 6. Footer: 1 kolom mulai dari 720px ke bawah */
@media (max-width: 720px) {
  .foot-grid {
    grid-template-columns: 1fr !important;
    gap: 16px;
  }
}

/* 7. Topbar: nomor HP dan email sejajar horizontal di mobile */
@media (max-width: 600px) {
  .topbar .container {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    height: auto;
    padding: 6px 12px;
    gap: 0;
  }
  .topbar .left {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex-wrap: nowrap;
    width: 100%;
  }
  .topbar .left .tap {
    font-size: 11px;
    color: #fff;
    white-space: nowrap;
  }
}

/* 8. Container padding di HP kecil */
@media (max-width: 480px) {
  .container {
    padding: 0 14px;
  }
  .section {
    padding: 28px 0;
  }
}

/* 9. CTA box padding di HP — handled in testi block above */

/* 10. Section head: judul kiri, tombol tetap di kanan */
@media (max-width: 480px) {
  .section-head {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 12px;
  }
  .section-head h2 {
    font-size: 16px;
    margin: 0;
    flex: 1;
  }
  .head-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
  }
  .btn.ghost.sm {
    padding: 6px 10px;
    font-size: 12px;
  }
  .slider-arrows .arrow {
    width: 30px;
    height: 30px;
    font-size: 15px;
  }
}

/* 11. Icon strip padding */
.icon-strip {
  padding: 20px 0;
}

/* 12. Topbar link warna di mobile */
.topbar .left a.tap {
  color: #fff;
}

/* Fix topbar height konsisten di semua halaman */
.topbar {
  line-height: 1;
}
.topbar .container {
  min-height: 0;
}
@media (max-width: 600px) {
  .topbar .container {
    padding-top: 7px;
    padding-bottom: 7px;
  }
}

/* Wrapper section atas */
.dh-wrap {
  background: #fff;
  padding: 18px 0 0;
}
 
/* Breadcrumb */
.dh-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #888;
  margin-bottom: 14px;
}
.dh-breadcrumb a { color: #5b43d6; }
.dh-breadcrumb a:hover { text-decoration: underline; }
.dh-breadcrumb span { color: #bbb; }
.dh-breadcrumb span:last-child { color: #555; font-size: 13px; }
 
/* Photo grid: kiri 1 foto besar, kanan 2 foto stack */
.dh-photo-grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  grid-template-rows: 420px;
  gap: 10px;
  border-radius: 20px;
  overflow: hidden;
  height: 420px;
  align-items: stretch;
}
 
.dh-photo-main {
  overflow: hidden;
  position: relative;
  border-radius: 16px 0 0 16px;
}
.dh-photo-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .4s ease;
}
.dh-photo-main:hover img { transform: scale(1.03); }
 
.dh-photo-side {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 10px;
  height: 100%;
  min-height: 0;
}
 
.dh-photo-thumb {
  overflow: hidden;
  position: relative;
  border-radius: 0;
  min-height: 0;
}
.dh-photo-thumb:first-child { border-radius: 0 16px 0 0; }
.dh-photo-thumb:last-child  { border-radius: 0 0 16px 0; }
.dh-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .4s ease;
}
.dh-photo-thumb:hover img { transform: scale(1.05); }
 
/* Title bar di bawah foto */
.dh-title-bar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 0 22px;
  flex-wrap: wrap;
}
 
.dh-title-left { flex: 1; min-width: 0; }
 
.dh-cat-badge {
  display: inline-block;
  background: #ede9ff;
  color: #5b43d6;
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 8px;
}
 
.dh-title {
  font-size: 28px;
  font-weight: 800;
  color: #1a1830;
  margin: 0 0 8px;
  line-height: 1.2;
}
 
.dh-meta {
  display: flex;
  gap: 14px;
  font-size: 13.5px;
  color: #666;
  flex-wrap: wrap;
}
 
.dh-price-block {
  text-align: right;
  flex-shrink: 0;
}
.dh-price-label {
  font-size: 12px;
  color: #888;
  margin-bottom: 2px;
}
.dh-price-value {
  font-size: 26px;
  font-weight: 800;
  color: #5b43d6;
  line-height: 1;
}
 
/* Responsive */
@media (max-width: 768px) {
  .dh-photo-grid {
    grid-template-columns: 1fr;
    grid-template-rows: 240px 100px;
    height: auto;
    max-height: none;
  }
  .dh-photo-main { border-radius: 16px 16px 0 0; }
  .dh-photo-side {
    grid-template-rows: 1fr;
    grid-template-columns: 1fr 1fr;
  }
  .dh-photo-thumb:first-child { border-radius: 0; }
  .dh-photo-thumb:last-child  { border-radius: 0 0 16px 0; }
  .dh-photo-side .dh-photo-thumb:first-child { border-radius: 0 0 0 16px; }
 
  .dh-title { font-size: 22px; }
  .dh-price-value { font-size: 20px; }
  .dh-title-bar { flex-direction: column; align-items: flex-start; gap: 10px; }
  .dh-price-block { text-align: left; }
}
 
@media (max-width: 480px) {
  .dh-photo-grid { grid-template-rows: 200px 90px; }
  .dh-title { font-size: 18px; }
}

/* Card konten kiri */
.dc-card {
  background: #fff;
  border: 1.5px solid #ede9ff;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 16px;
  box-shadow: 0 2px 12px rgba(91,67,214,.06);
}
 
.dc-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 20px;
  font-size: 15px;
  font-weight: 700;
  color: #1a1830;
  border-left: 4px solid #5b43d6;
  background: #faf9ff;
  border-bottom: 1px solid #ede9ff;
}
 
.dc-icon {
  font-size: 16px;
}
 
.dc-body {
  padding: 18px 20px;
  font-size: 14px;
  color: #444;
  line-height: 1.75;
}
.dc-body p { margin: 0 0 10px; }
.dc-body p:last-child { margin-bottom: 0; }
 
/* Fasilitas 2 kolom */
.dc-facilities ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 16px;
}
.dc-facilities ul li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13.5px;
  color: #444;
}
.dc-facilities ul li::before {
  content: '✓';
  color: #5b43d6;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}
@media (max-width: 600px) {
  .dc-facilities ul { grid-template-columns: 1fr; }
}
 
/* Tabel harga */
.dc-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}
.dc-table thead tr {
  background: #f4f2ff;
}
.dc-table th {
  padding: 10px 14px;
  color: #888;
  font-weight: 600;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  border-bottom: 1px solid #ede9ff;
  text-align: left;
}
.dc-table td {
  padding: 11px 14px;
  border-bottom: 1px solid #f0eeff;
  color: #333;
  vertical-align: middle;
}
.dc-table tbody tr:last-child td { border-bottom: none; }
.dc-table tbody tr:hover td { background: #faf9ff; }
 
.dc-price-cell {
  font-weight: 700;
  color: #5b43d6;
}
 
/* Badge label kendaraan */
.dc-badge {
  display: inline-block;
  border-radius: 999px;
  padding: 3px 11px;
  font-size: 11.5px;
  font-weight: 600;
}
.dc-badge-blue   { background: #dbeafe; color: #1d4ed8; }
.dc-badge-purple { background: #ede9ff; color: #5b43d6; }
.dc-badge-green  { background: #dcfce7; color: #15803d; }
.dc-badge-orange { background:#FAC775; color:#633806; } 

.dc-note {
  display: block;
  margin-top: 10px;
  font-size: 12px;
  color: #aaa;
  font-style: italic;
}
 
/* ===== SIDEBAR ===== */
.dc-sidebar {
  background: #fff;
  border: 1.5px solid #ede9ff;
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 2px 16px rgba(91,67,214,.08);
}
 
.dc-sidebar-price {
  margin-bottom: 14px;
}
.dc-sidebar-label {
  font-size: 12px;
  color: #888;
  margin-bottom: 2px;
}
.dc-sidebar-value {
  font-size: 26px;
  font-weight: 800;
  color: #5b43d6;
  line-height: 1.1;
}
.dc-sidebar-rating {
  font-size: 13px;
  color: #f59e0b;
  margin-top: 4px;
}
.dc-sidebar-rating strong { color: #333; }
 
/* Tombol WA hijau */
.dc-btn-wa {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #25d366;
  color: #fff;
  border-radius: 12px;
  padding: 13px 16px;
  font-weight: 700;
  font-size: 14.5px;
  width: 100%;
  text-decoration: none;
  transition: filter .2s;
  margin-bottom: 8px;
}
.dc-btn-wa:hover { filter: brightness(1.07); color: #fff; }
 
/* Tombol marketing outline */
.dc-btn-marketing {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: #fff;
  color: #5b43d6;
  border: 1.5px solid #5b43d6;
  border-radius: 12px;
  padding: 11px 16px;
  font-weight: 600;
  font-size: 14px;
  width: 100%;
  text-decoration: none;
  transition: background .2s, color .2s;
  margin-bottom: 14px;
}
.dc-btn-marketing:hover { background: #f4f2ff; }
 
/* Info rows */
.dc-info-list {
  border-top: 1px solid #f0eeff;
  padding-top: 12px;
  margin-bottom: 14px;
}
.dc-info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid #f8f7ff;
  font-size: 13px;
}
.dc-info-row:last-child { border-bottom: none; }
.dc-info-key { color: #888; }
.dc-info-val { font-weight: 600; color: #1a1830; }
.dc-info-link { color: #5b43d6; text-decoration: underline; cursor: pointer; }
 
/* Tags */
.dc-tags-wrap { margin-bottom: 14px; }
.dc-tags-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #aaa;
  margin-bottom: 8px;
}
.dc-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.dc-tag {
  background: #f4f2ff;
  color: #5b43d6;
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 500;
}
 
/* Share buttons */
.dc-share-wrap { border-top: 1px solid #f0eeff; padding-top: 14px; }
.dc-share-btns {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}
.dc-share-copy, .dc-share-wa {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 9px 10px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s;
  border: 1.5px solid #ede9ff;
  background: #faf9ff;
  color: #5b43d6;
}
.dc-share-copy:hover, .dc-share-wa:hover { background: #ede9ff; }

.dest-popular { padding: 56px 0; }
 
.dest-grid {
  display: flex;
  flex-direction: row;
  gap: 14px;
  margin-top: 28px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 8px;
}

/* Sembunyikan scrollbar tapi tetap bisa scroll */
.dest-grid::-webkit-scrollbar { display: none; }
.dest-grid { -ms-overflow-style: none; scrollbar-width: none; }

.dest-card {
  flex: 0 0 260px; /* 6 per baris di desktop */
  scroll-snap-align: start;
  aspect-ratio: 2 / 3;
}

@media (max-width: 900px) {
  .dest-card { flex: 0 0 160px; }
}
@media (max-width: 560px) {
  .dest-card {
    flex: 0 0 180px;
    height: 240px;
  }
}
 
.dest-card {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  display: block;
  text-decoration: none;
  cursor: pointer;
  transition: transform .25s ease, box-shadow .25s ease;
  aspect-ratio: 3/4;
  background: #e8e8f0;
}
.dest-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(91,67,214,.18);
}
 
.dest-img-wrap {
  position: absolute;
  inset: 0;
}
.dest-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.dest-card:hover .dest-img-wrap img {
  transform: scale(1.06);
}
 
.dest-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,12,36,.75) 0%, rgba(15,12,36,.1) 55%, transparent 100%);
}
 
.dest-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 14px 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.dest-name {
  color: #fff;
  font-weight: 700;
  font-size: 1.3rem;
  line-height: 1.2;
  text-shadow: 0 1px 4px rgba(0,0,0,.4);
}
.dest-country {
  color: rgba(255,255,255,.75);
  font-size: .78rem;
  font-weight: 400;
}
 
.section-eyebrow {
  font-size: .8rem;
  font-weight: 600;
  color: #5b43d6;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.lokasi-labels {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 5px 0 8px;
}
.lokasi-chip {
  background: #f0edff;
  color: #5b43d6;
  font-size: 12.5px;
  padding: 3px 7px;
  border-radius: 20px;
  white-space: nowrap;
  font-weight: 500;
}