.hero{padding:26px 0 10px}
.hero-inner{display:grid;gap:14px;align-items:center}
@media(min-width:980px){
  .hero-inner{grid-template-columns: 1.1fr .9fr}
}

.badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;color:var(--mut);
  border:1px solid var(--line);
  background: rgba(255,255,255,.06);
  border-radius:999px;
  padding:7px 10px;
}

h1{margin:10px 0 8px;font-size:30px;letter-spacing:.2px}
.lead{margin:0;color:var(--mut);line-height:1.7}
.cta{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
.mini{margin-top:10px;font-size:12px;color:var(--mut)}

.hero-card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 22px;
  overflow:hidden;
  box-shadow: var(--shadow);
}
.hero-card img{display:block;width:100%;height:auto}
.hero-card-foot{padding:12px 12px}
.hero-card-title{font-weight:900}
.hero-card-sub{font-size:12px;color:var(--mut);margin-top:2px}

.chips{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.chip{
  font-size:12px;color:var(--mut);
  border:1px solid var(--line);
  background: rgba(0,0,0,.14);
  border-radius:999px;
  padding:6px 10px;
}

.form{
  margin:14px auto 0;
  max-width:560px;
  padding:14px;
  border-radius: 18px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow);
}
.form label{display:block;margin-bottom:10px}
.form span{display:block;font-size:12px;color:var(--mut);margin-bottom:6px}
.form input,.form textarea{
  width:100%;
  padding:12px 12px;
  border-radius: 12px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.18);
  color:var(--txt);
  outline:none;
}
.form textarea{min-height:96px;resize:vertical}
.form input:focus,.form textarea:focus{
  border-color: rgba(96,165,250,.55);
  box-shadow: 0 0 0 4px rgba(96,165,250,.14);
}

.faq details{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 16px;
  padding:10px 12px;
  margin-top:10px;
}
.faq summary{cursor:pointer;font-weight:800}
.faq p{margin:8px 0 0;color:var(--mut);line-height:1.65;font-size:14px}

/* WhatsApp Floating Button — Theme (Blue + Rose) + sparkle pulse */
.wa-float{
  position:fixed;right:16px;bottom:16px;
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  border-radius:999px;

  /* warna disesuaikan tema */
  background: linear-gradient(135deg, rgba(37,99,235,.95), rgba(225,29,72,.90));
  color:#ffffff;
  font-weight:900;
  text-decoration:none;

  border:1px solid rgba(15,23,42,.14);
  box-shadow: 0 18px 48px rgba(2,6,23,.18);

  /* animasi kedip (redup-terang) + sedikit floating */
  animation: waPulse 1.25s ease-in-out infinite, waFloat 3.2s ease-in-out infinite;
  overflow:hidden;
  isolation:isolate;
}

/* ring glow */
.wa-float::after{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:inherit;
  background: radial-gradient(circle at 50% 50%, rgba(37,99,235,.22), transparent 60%);
  opacity:.0;
  animation: waGlow 1.25s ease-in-out infinite;
  z-index:-1;
}

/* gemerlap (shine sweep) */
.wa-float::before{
  content:"";
  position:absolute;
  top:-40%;
  left:-60%;
  width:70%;
  height:180%;
  transform: rotate(22deg);
  background: linear-gradient(90deg,
    transparent,
    rgba(255,255,255,.65),
    transparent
  );
  opacity:.0;
  animation: waShine 2.2s ease-in-out infinite;
  pointer-events:none;
}

/* hover: lebih “hidup” */
.wa-float:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 60px rgba(2,6,23,.22);
}
.wa-float:active{transform: translateY(0) scale(.98)}

/* Accessibility: kalau user prefer reduce motion */
@media (prefers-reduced-motion: reduce){
  .wa-float, .wa-float::before, .wa-float::after{animation:none}
}

/* Keyframes */
@keyframes waPulse{
  0%   { filter: brightness(1);   }
  50%  { filter: brightness(1.18); }
  100% { filter: brightness(1);   }
}
@keyframes waGlow{
  0%   { opacity:0;   transform: scale(.92); }
  50%  { opacity:1;   transform: scale(1); }
  100% { opacity:0;   transform: scale(.92); }
}
@keyframes waShine{
  0%, 40%  { opacity:0; transform: translateX(0) rotate(22deg); }
  55%      { opacity:.9; }
  70%      { opacity:0; transform: translateX(220%) rotate(22deg); }
  100%     { opacity:0; transform: translateX(220%) rotate(22deg); }
}
@keyframes waFloat{
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}




/* =========================
   TRUST SIGNALS (Shopee/TikTok-ish reviews)
   ========================= */

.trust-head{
  display:flex;
  gap:14px;
  justify-content:space-between;
  align-items:flex-end;
  flex-wrap:wrap;
}

.trust-score{
  min-width:220px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 18px;
  padding:12px 12px;
  box-shadow: var(--shadow);
}

.trust-score-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.trust-rating{
  font-size:28px;
  font-weight:900;
  letter-spacing:.2px;
}

.trust-stars{
  display:flex;
  gap:2px;
  font-size:14px;
  transform: translateY(-1px);
}
.trust-stars .dim{opacity:.35}

.trust-meta{
  margin-top:6px;
  font-size:12px;
  color: var(--mut);
  display:flex;
  align-items:center;
  gap:8px;
}
.trust-meta .dot{
  width:6px;height:6px;border-radius:999px;
  background: rgba(34,197,94,.9);
  box-shadow: 0 0 0 4px rgba(34,197,94,.12);
}

.trust-row{
  margin-top:14px;
  display:grid;
  gap:12px;
  grid-template-columns: 1fr;
}
@media(min-width:980px){
  .trust-row{grid-template-columns: .9fr 1.1fr;}
}

.trust-badges{
  display:grid;
  gap:10px;
}
.badge-card{
  display:flex;
  gap:10px;
  align-items:flex-start;
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius: 18px;
  padding:12px 12px;
  box-shadow: var(--shadow);
}
.badge-card .ico{
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.12);
}
.badge-card .ttl{font-weight:900}
.badge-card .sub{margin-top:2px;font-size:12px;color:var(--mut);line-height:1.5}

.trust-filter{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
}

.chipx{
  cursor:pointer;
  font-size:12px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.14);
  color: var(--mut);
  font-weight:800;
}
.chipx:hover{color:var(--txt); border-color: rgba(96,165,250,.45)}
.chipx.is-active{
  background: rgba(34,197,94,.20);
  border-color: rgba(34,197,94,.55);
  color: var(--txt);
}

.review-list{display:grid; gap:10px}
.review-card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 18px;
  padding:12px 12px;
  box-shadow: var(--shadow);
}

.review-top{
  display:flex;
  align-items:center;
  gap:10px;
}

.avatar{
  width:40px;height:40px;
  border-radius: 14px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(96,165,250,.18), rgba(34,197,94,.12));
}

.who{min-width:0}
.who .name{font-weight:900}
.who .meta{font-size:12px;color:var(--mut);margin-top:2px}

.score{
  margin-left:auto;
  display:flex;align-items:center;gap:6px;
  font-size:12px;
  color: var(--txt);
  border:1px solid var(--line);
  background: rgba(0,0,0,.14);
  padding:7px 9px;
  border-radius: 999px;
  white-space:nowrap;
}
.score .star{opacity:.9}

.review-card .text{
  margin:10px 0 0;
  color: var(--mut);
  line-height:1.7;
  font-size:14px;
}

.tags{
  margin-top:10px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.tag{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.12);
  color: var(--mut);
}

.trust-note{
  font-size:12px;
  color: var(--mut);
  padding:10px 12px;
  border:1px dashed rgba(255,255,255,.18);
  border-radius: 16px;
  background: rgba(0,0,0,.10);
}

/* =========================
   NAP + GEOTAG
   ========================= */
.nap-wrap{
  display:grid;
  gap:12px;
  grid-template-columns: 1fr;
}
@media(min-width:980px){
  .nap-wrap{grid-template-columns: 1.1fr .9fr; align-items:start;}
}

.nap-card{
  margin-top:12px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 18px;
  padding:12px 12px;
  box-shadow: var(--shadow);
}

.nap-row{
  display:flex;
  gap:10px;
  justify-content:space-between;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nap-row:last-child{border-bottom:none}

.nap-row .k{
  font-size:12px;
  color: var(--mut);
  min-width:92px;
}
.nap-row .v{
  text-align:right;
  color: var(--txt);
  line-height:1.5;
}

.nap-link{
  color: var(--acc2);
  text-decoration:none;
  font-weight:900;
}
.nap-link:hover{text-decoration:underline}
.muted{color:var(--mut); font-size:12px}

.nap-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}

.map-card{
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius: 18px;
  overflow:hidden;
  box-shadow: var(--shadow);
}

.map-top{
  padding:12px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.map-title{font-weight:900}
.map-sub{font-size:12px;color:var(--mut);margin-top:2px}

.map-box{
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px 12px;
  text-decoration:none;
  color:inherit;
}
.map-box:hover{background: rgba(0,0,0,.10)}
.map-pin{
  width:44px;height:44px;
  border-radius: 16px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
  background: rgba(0,0,0,.12);
}
.map-text{min-width:0}
.map-main{font-weight:900}
.map-mini{font-size:12px;color:var(--mut);margin-top:2px}
.map-go{
  margin-left:auto;
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.10);
  color: var(--mut);
}

.map-note{
  padding:10px 12px;
  font-size:12px;
  color: var(--mut);
  border-top:1px solid rgba(255,255,255,.08);
}

/* ===== Brands ===== */
.brand-grid{
  margin-top:12px;
  display:grid;
  gap:10px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
@media(min-width:700px){ .brand-grid{grid-template-columns: repeat(4, minmax(0,1fr));} }
@media(min-width:980px){ .brand-grid{grid-template-columns: repeat(6, minmax(0,1fr));} }

.brand-item{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 16px;
  padding:12px 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: var(--shadow);
}
.brand-mark{
  font-weight:900;
  font-size:12px;
  letter-spacing:.8px;
  color: rgba(168, 6, 9, 0.92);
  opacity:.92;
}

/* ===== Expertise ===== */
.expertise{
  margin-top:14px;
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius: 18px;
  padding:14px 14px;
  box-shadow: var(--shadow);
}
.expertise h3{margin:0 0 8px;font-size:16px}
.expertise p{margin:0 0 10px;color:var(--mut);line-height:1.75;font-size:14px}
.expertise-pills{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;
}
.xp{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.14);
  color: var(--mut);
}

/* ===== Mini Blog ===== */
.blog-grid{
  margin-top:14px;
  display:grid;
  gap:12px;
  grid-template-columns: 1fr;
}
@media(min-width:980px){ .blog-grid{grid-template-columns: 1fr 1fr;} }

.blog-card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 18px;
  padding:14px 14px;
  box-shadow: var(--shadow);
}
.blog-head h3{margin:8px 0 0;font-size:16px}
.blog-badge{
  display:inline-flex;
  font-size:12px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.14);
  color: var(--mut);
}
.blog-body p{margin:10px 0 0;color:var(--mut);line-height:1.75;font-size:14px}
.blog-list{margin:10px 0 0;padding-left:18px;color:var(--mut);line-height:1.7;font-size:14px}
.blog-note{margin-top:10px;font-size:12px;color:var(--mut);opacity:.95}

/* ===== SOP ===== */
.sop-wrap{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 18px;
  padding:14px 14px;
  box-shadow: var(--shadow);
  margin-top:12px;
}
.sop-ol{
  margin:0;
  padding-left:18px;
  color: var(--mut);
  line-height:1.75;
  font-size:14px;
}
.sop-ol li{margin:10px 0}
.sop-ol strong{color: rgba(241, 5, 41, 0.92)}

/* ===== Price Table ===== */
.table-wrap{
  margin-top:12px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 18px;
  padding:12px 12px;
  box-shadow: var(--shadow);
  overflow:auto;
}
.price-table{
  width:100%;
  border-collapse: collapse;
  min-width: 720px;
}
.price-table caption{
  text-align:left;
  font-weight:900;
  margin:4px 0 10px;
  color: rgba(234,242,255,.92);
}
.price-table th, .price-table td{
  padding:12px 10px;
  border-bottom:1px solid rgba(255,255,255,.10);
  text-align:left;
  font-size:14px;
}
.price-table th{
  font-size:12px;
  color: var(--mut);
  text-transform: uppercase;
  letter-spacing: .6px;
  background: rgba(0,0,0,.10);
}
.price-table tbody tr:hover{
  background: rgba(0,0,0,.10);
}
.table-note{
  margin-top:10px;
  font-size:12px;
  color: var(--mut);
  line-height:1.6;
}

/* =========================
   PHOTO SLIDER (3 images)
   ========================= */
.slider-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.slider-actions{display:flex; gap:8px}
.sbtn{
  width:40px;height:40px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.14);
  color: var(--txt);
  font-size:18px;
  font-weight:900;
  cursor:pointer;
}
.sbtn:hover{border-color: rgba(96,165,250,.45)}
.sbtn:active{transform: translateY(1px)}

.slider{
  margin-top:12px;
  border:1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow);
  overflow:hidden;
}

.track{
  display:flex;
  overflow-x:auto;
  scroll-snap-type: x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.track::-webkit-scrollbar{display:none}

.slide{
  flex: 0 0 100%;
  scroll-snap-align: start;
  margin:0;
  position:relative;
}

.slide img{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.slide figcaption{
  position:absolute;
  left:10px;
  right:10px;
  bottom:10px;
  padding:10px 10px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.40);
  color: rgba(234,242,255,.92);
  font-size:12px;
  line-height:1.4;
  backdrop-filter: blur(10px);
}

.dots{
  display:flex;
  gap:8px;
  justify-content:center;
  padding:10px 10px;
  border-top:1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.10);
}

.dot{
  width:10px;height:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  cursor:pointer;
}
.dot.is-active{
  background: rgba(34,197,94,.75);
  border-color: rgba(34,197,94,.85);
  box-shadow: 0 0 0 4px rgba(34,197,94,.12);
}
