@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&display=swap');

:root{
  --ah-red:#ff131b;
  --ah-red-dark:#e31218;
  --ah-gold:#d4af37;
  --ah-emerald:#0b7a5a;

  --ah-text:#0b1220;
  --ah-muted:#6b7280;
  --ah-bg:#ffffff;
  --ah-soft:#f6f7f8;

  --ah-border:rgba(0,0,0,.10);
  --radius:18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--ah-bg);
  color:var(--ah-text);
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit}

.container{max-width:1120px;margin:0 auto;padding:0 20px}

/* =========================================================
   HEADER / NAVBAR (sesuai includes/header.php lu)
========================================================= */
.topbar{
  position:sticky;
  top:0;
  z-index:999;
  background:var(--ah-red);
  border-bottom:1px solid rgba(255,255,255,.14);
  transition:background .18s ease, box-shadow .18s ease;
}
.topbar .topbar-inner{
  min-height:70px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

/* home overlay class (header.php kasih overlay), kita bikin tetap merah solid */
.topbar.overlay{
  position:fixed;
  left:0; right:0; top:0;
  background:var(--ah-red);
  border-bottom:1px solid rgba(255,255,255,.14);
  box-shadow:none;
}
.topbar.overlay.scrolled{
  background:var(--ah-red);
  box-shadow:0 10px 24px rgba(0,0,0,.12);
}

.brand{display:flex;align-items:center}
.brand img{height:42px;width:auto;object-fit:contain;display:block}

.nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.navlink{
  display:inline-flex;
  align-items:center;
  padding:10px 12px;
  border-radius:999px;
  font-weight:900;
  font-size:14px;
  color:#fff;
  border:1px solid transparent;
  transition:.15s ease;
}
.navlink:hover{background:rgba(255,255,255,.15)}
.navlink.active{
  background:rgba(255,255,255,.22);
  border-color:transparent;
  color:#fff;
}

/* tombol admin di navbar */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:14px;
  font-weight:1000;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  color:var(--ah-text);
  cursor:pointer;
  transition:.15s ease;
  user-select:none;
}
.btn:hover{border-color:rgba(0,0,0,.20)}
.btn-admin{
  background:#fff;
  border-color:transparent;
  color:var(--ah-red);
  font-weight:1000;
}
.btn-admin:hover{background:#f3f4f6}

/* buttons umum (dipakai home) */
.btn-primary{
  background:var(--ah-red);
  border-color:transparent;
  color:#fff;
}
.btn-primary:hover{background:var(--ah-red-dark)}
.btn-outline{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.65);
}
.btn-outline:hover{background:rgba(255,255,255,.12)}
.btn-ghost{
  background:#fff;
  border-color:rgba(0,0,0,.10);
  color:var(--ah-text);
}
.btn-ghost:hover{border-color:rgba(0,0,0,.18)}

/* main wrapper */
.page{min-height:60vh}

/* =========================================================
   SECTIONS / COMMON
========================================================= */
.section{padding:48px 0}
.section-soft{background:var(--ah-soft)}
.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  margin-bottom:16px
}
.section-head h2{
  margin:0;
  font-size:28px;
  letter-spacing:-.02em
}
.muted{color:var(--ah-muted);line-height:1.65}

/* =========================================================
   HERO (judul premium, spacing lega)
========================================================= */
.hero{position:relative;min-height:600px;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{
  position:relative;
  min-height:600px;
  display:flex;
  align-items:center;
  background:linear-gradient(90deg, rgba(0,0,0,.62), rgba(0,0,0,.34), rgba(0,0,0,.12));
}
.hero-content{
  max-width:820px;
  margin:0 auto;
  padding:96px 20px 72px; /* lebih lega, ga dempet */
  text-align:center;
}
.hero-content h1{
  margin:0 0 18px;
  font-family:"Playfair Display", serif;
  font-size:52px;
  line-height:1.18;
  letter-spacing:.2px;
  font-weight:700;
  color:#fff;
}
.hero-content p{
  margin:0 auto 22px;
  max-width:720px;
  color:rgba(255,255,255,.92);
  font-size:18px;
  line-height:1.75;
}
.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
}

/* =========================================================
   WHY (MERAH + BATIK GOLD + EMERALD)
========================================================= */
.why{padding:52px 0}
.why-red{
  position:relative;
  overflow:hidden;
  background:var(--ah-red);
}

/* layer motif gold */
.why-red::before{
  content:"";
  position:absolute;
  inset:-20px;
  background:
    repeating-linear-gradient(
      45deg,
      rgba(212,175,55,.22) 0px,
      rgba(212,175,55,.22) 2px,
      transparent 2px,
      transparent 22px
    );
  opacity:.35;
  pointer-events:none;
}

/* layer aksen emerald batik-line */
.why-red::after{
  content:"";
  position:absolute;
  inset:-40px;
  background:
    radial-gradient(circle at 18% 30%, rgba(11,122,90,.35), transparent 44%),
    radial-gradient(circle at 82% 20%, rgba(11,122,90,.28), transparent 46%),
    radial-gradient(circle at 76% 78%, rgba(11,122,90,.20), transparent 52%);
  opacity:.65;
  pointer-events:none;
}

.why-title{
  position:relative;
  text-align:center;
  margin:0 0 22px;
  font-size:26px;
  letter-spacing:.02em;
  color:#fff;
}

.why-grid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}

.why-card{
  background:rgba(255,255,255,.95);
  border:1px solid rgba(255,255,255,.22);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:0 16px 40px rgba(0,0,0,.16);
  display:flex;
  gap:12px;
  backdrop-filter: blur(2px);
}
.why-icon{
  width:42px;height:42px;border-radius:14px;
  background:rgba(212,175,55,.18);
  border:1px solid rgba(212,175,55,.45);
  display:flex;align-items:center;justify-content:center;
  font-weight:1000;color:#b8860b;
}
.why-text{line-height:1.55;color:#111}

/* =========================================================
   STATS
========================================================= */
.stats-wrap{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.stat{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius);
  padding:16px;
  text-align:center;
  box-shadow:0 10px 26px rgba(0,0,0,.04);
}
.stat-num{font-size:30px;font-weight:1000;color:var(--ah-red);letter-spacing:-.02em}
.stat-label{margin-top:6px;color:var(--ah-muted);font-weight:800}

/* =========================================================
   GRID + CARD
========================================================= */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:0 10px 26px rgba(0,0,0,.04);
}
.card h3{margin:10px 0 6px;font-size:18px;letter-spacing:-.01em}
.meta{color:var(--ah-muted);font-weight:700}
.price{margin-top:8px;font-size:20px;font-weight:1000;color:var(--ah-red)}

/* =========================================================
   FOTO PAKET (UNGGULAN) — FULL (NO CROP) ✅
   NB: kamu punya 2 style kemungkinan:
   - home: .paket-photo (yang gue bikin di index.php slider)
   - layout lain: .card .card-photo
   Kita fix DUA-DUANYA biar aman.
========================================================= */

/* ✅ kalau home pakai .paket-photo */
.paket-photo{
  width:100%;
  height:340px;               /* besarin */
  border-radius:16px;
  overflow:hidden;
  background:#000;
  border:1px solid rgba(0,0,0,.06);
  display:flex;
  align-items:center;
  justify-content:center;
}
.paket-photo img{ object-fit:contain !important; }
  width:100%;
  height:100%;
  object-fit:contain;         /* full kelihatan */
  object-position:center;
  background:#000;
  display:block;
}

/* ✅ kalau layout pakai .card-photo */
.card .card-photo{
  width:100%;
  height:340px;               /* besarin juga */
  border-radius:16px;
  overflow:hidden;
  background:#000;
  border:1px solid rgba(0,0,0,.06);
  display:flex;
  align-items:center;
  justify-content:center;
}
.card .card-photo img{
  width:100%;
  height:100%;
  object-fit:contain;         /* full kelihatan */
  object-position:center;
  background:#000;
  display:block;
}

/* rincian paket (stack kebawah) */
.pmeta{margin-top:10px;line-height:1.7}
.pmeta .row{display:flex;gap:8px;margin:4px 0;align-items:flex-start}
.pmeta .lbl{min-width:175px;font-weight:900}
.pmeta .val{flex:1;opacity:.95}
.pmeta .mut{opacity:.7;font-weight:700}
.pprices{margin-top:8px}
.pprices .plist{display:grid;gap:6px;margin-top:6px}
.pprices .price-item{
  display:flex;justify-content:space-between;gap:10px;
  padding:8px 10px;border-radius:12px;
  background:#f6f7f8;border:1px solid rgba(0,0,0,.06);
  font-weight:900;
}

/* chips */
.pchips{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.pchip{
  display:inline-flex;align-items:center;
  padding:6px 10px;border-radius:999px;
  font-size:12px;font-weight:900;
  background:rgba(255,19,27,.08);
  border:1px solid rgba(255,19,27,.18);
}
.pchip.soft{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.pchip.ok{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
.pchip.bad{background:#fee2e2;border-color:#fecaca;color:#991b1b}

/* =========================================================
   TESTIMONI FOTO ONLY
========================================================= */
.review-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.review-grid a{
  display:block;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 15px 35px rgba(0,0,0,.08);
  transition:.25s ease;
  background:#fff;
}
.review-grid a:hover{transform:translateY(-6px)}
.review-grid img{width:100%;height:auto;display:block}

/* =========================================================
   GALLERY
========================================================= */
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.g-item{
  position:relative;border:none;padding:0;cursor:pointer;
  border-radius:16px;overflow:hidden;
  background:#e5e7eb;
  border:1px solid rgba(0,0,0,.08);
}
.g-item img{width:100%;height:220px;object-fit:cover}
.g-zoom{
  position:absolute;right:10px;bottom:10px;
  background:rgba(0,0,0,.65);color:#fff;
  padding:7px 10px;border-radius:999px;
  font-size:12px;font-weight:1000;
}

/* =========================================================
   FAQ
========================================================= */
.faq{display:grid;gap:10px}
.faq-item{
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
  padding:2px 12px;
  box-shadow:0 10px 26px rgba(0,0,0,.03);
}
.faq-item summary{
  cursor:pointer;
  list-style:none;
  padding:14px 8px;
  font-weight:1000;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-body{padding:0 8px 14px;color:var(--ah-muted);line-height:1.7}

/* =========================================================
   LIGHTBOX
========================================================= */
.lightbox{
  position:fixed;inset:0;
  background:rgba(0,0,0,.82);
  display:none;align-items:center;justify-content:center;
  z-index:9999;
  padding:20px;
}
.lightbox.open{display:flex}
.lightbox img{
  max-width:min(980px, 92vw);
  max-height:86vh;
  border-radius:18px;
  box-shadow:0 18px 50px rgba(0,0,0,.40);
}
.lb-close{
  position:absolute;top:16px;right:16px;
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(0,0,0,.35);
  color:#fff;font-size:26px;cursor:pointer;
}

/* reveal */
.reveal{opacity:0;transform:translateY(12px);transition:.55s ease}
.reveal.in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width: 980px){
  .why-grid{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .stats-wrap{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .hero{min-height:560px}
  .hero-overlay{min-height:560px}
  .hero-content{padding:96px 18px 54px}
  .hero-content h1{font-size:40px}

  /* foto paket responsif */
  .paket-photo{height:320px}
  .card .card-photo{height:320px}
}

@media (max-width: 780px){
  /* nav biar ga berantakan: scroll horizontal */
  .nav{
    gap:8px;
    flex-wrap:nowrap;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .nav::-webkit-scrollbar{display:none}
  .navlink{white-space:nowrap;padding:9px 10px}
  .btn{white-space:nowrap}
}

@media (max-width: 560px){
  .container{padding:0 16px}
  .stats-wrap{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .g-item img{height:210px}
  .hero-content h1{font-size:34px}
  .hero-content p{font-size:16px}
  .pmeta .row{flex-direction:column;gap:2px;margin:8px 0}
  .pmeta .lbl{min-width:unset}
  .review-grid{grid-template-columns:1fr}

  .paket-photo{height:260px}
  .card .card-photo{height:260px}
}

/* =========================================================
   Fine-tune v2 (mobile polish) — tempel di PALING BAWAH
========================================================= */

/* Navbar: lebih rapih & nyaman di scroll horizontal */
@media (max-width: 780px){
  .topbar .topbar-inner{min-height:64px}
  .brand img{height:38px}
  .nav{padding-bottom:6px}
  .navlink{
    padding:8px 10px;
    font-size:13px;
    border-radius:999px;
  }
  .btn{padding:9px 12px;border-radius:14px}
  .btn-admin{padding:9px 12px}
}

/* Hero: judul ga dempet, lebih breathing space */
@media (max-width: 980px){
  .hero-content{padding:92px 18px 52px}
  .hero-content h1{letter-spacing:.3px}
}
@media (max-width: 560px){
  .hero{min-height:540px}
  .hero-overlay{min-height:540px}
  .hero-content{padding:92px 16px 46px}
  .hero-content h1{
    font-size:32px;
    line-height:1.25;
    margin-bottom:14px;
  }
  .hero-content p{
    font-size:15.5px;
    line-height:1.75;
    margin-bottom:18px;
  }
  .hero-actions{gap:10px}
  .hero-actions .btn{width:100%}  /* tombol full biar enak di tap */
}

/* Cards: padding & shadow lebih halus (premium) */
.card{box-shadow:0 12px 28px rgba(0,0,0,.045)}
@media (max-width: 560px){
  .card{padding:14px;border-radius:18px}
  .card h3{font-size:17px}
}

/* Rincian paket: label lebih enak dibaca */
.pmeta .lbl{letter-spacing:.1px}
@media (max-width: 980px){
  .pmeta .lbl{min-width:165px}
}
@media (max-width: 560px){
  .pmeta{margin-top:8px}
  .pmeta .row{margin:10px 0}
  .pmeta .lbl{font-size:13px}
  .pmeta .val{font-size:14px}
  .pprices .price-item{padding:10px 10px}
}

/* Chips: lebih rapih dan gak terlalu rame */
.pchips{gap:7px}
.pchip{font-size:11.5px;padding:6px 9px}

/* Gallery: spacing lebih halus */
@media (max-width: 560px){
  .gallery{gap:12px}
  .g-item{border-radius:18px}
  .g-item img{height:220px}
}

/* FAQ: tap target lebih enak */
.faq-item summary{padding:16px 8px}

/* Smooth feel (optional tapi enak) */
html{scroll-behavior:smooth}

/* SLIDER */
.slider{overflow:hidden;position:relative}
.slider-track{display:flex;transition:transform .6s ease}
.slide{min-width:100%;flex-shrink:0;padding:10px}
.slide img{width:100%;border-radius:20px;box-shadow:0 20px 40px rgba(0,0,0,.12)}
.slider.large .slide img{height:380px;object-fit:cover}
@media(max-width:768px){
  .slider.large .slide img{height:250px}
}

/* ===== FIX: WHY overlay jangan nutup konten ===== */
.why-red{position:relative;overflow:hidden}
.why-red::before,
.why-red::after{z-index:0}
.why-red .container{position:relative;z-index:1}

/* ===== Slider (Testimoni + Galeri) ===== */
.xslider{
  position:relative;
  overflow:hidden;
  border-radius:24px;
}
.xtrack{
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 2px 12px;
  scrollbar-width:none;
}
.xtrack::-webkit-scrollbar{display:none}

.xslide{
  scroll-snap-align:start;
  flex:0 0 auto;
  width:min(520px, 86vw);
}
.xslide img{
  width:100%;
  height:auto;
  display:block;
  border-radius:22px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 22px 48px rgba(0,0,0,.10);
}

/* galeri lebih besar */
.xlarge .xslide{width:min(720px, 92vw)}
.xlarge .xslide img{
  height:360px;
  object-fit:cover;
}

@media(max-width:768px){
  .xslide{width:min(360px, 86vw)}
  .xlarge .xslide{width:min(420px, 92vw)}
  .xlarge .xslide img{height:240px}
}