/* =========================================================
   MOBILE OVERRIDES (Anti-Highlight & Fast Tap)
========================================================= */
*, *::before, *::after {
    -webkit-tap-highlight-color: transparent !important;
}

html {
    touch-action: manipulation;
    -webkit-text-size-adjust: 100%;
}


.mobile-topbar,
.mobile-overlay {
    display: none;
}



/* default desktop */
.menu-toggle,
.nav-konsultasi-mobile{
  display: none;
}


/* =========================
   MOBILE STYLE
   ========================= */

@media screen and (max-width: 768px){

  *{
    box-sizing: border-box;
  }

  body.menu-open{
    overflow: hidden;
  }

  /* =========================
     NAVBAR MOBILE
     ========================= */

nav{
  height: 58px !important;
  padding: 0 10px !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #ffffff;
  z-index: 9999;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
  backdrop-filter: none;
}

.logo-nav{
  display: flex;
  align-items: center;
  flex: 0 0 auto;
  margin: 0;
  padding: 0;
}

.logo-nav img{
  display: block;
  height: 150px !important;
  width: auto;
  object-fit: contain;
  margin: 0;
  padding: 0;
}

.desktop-konsultasi{
  display: none !important;
}

.menu-toggle{
  width: 34px;
  height: 34px;
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
  border-radius: 8px;
  flex-shrink: 0;
}

.menu-toggle span{
  display: block;
  width: 16px;
  height: 2px;
  background: #0F3D3A;
  margin: 0 auto;
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.22s ease, background 0.2s ease;
}

.menu-toggle.active span:nth-child(1){
  transform: translateY(6px) rotate(45deg);
}

.menu-toggle.active span:nth-child(2){
  opacity: 0;
}

.menu-toggle.active span:nth-child(3){
  transform: translateY(-6px) rotate(-45deg);
}

.nav-links{
  position: absolute;
  top: 58px;
  left: -1px;
  right: 1px;
  margin: 0;
  background: #ffffff;
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0px 10px 14px;
  border-radius: 14px;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.10);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px) scale(0.98);

}

.nav-links.show{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.nav-links li{
  list-style: none;
  width: 100%;
  border-bottom: 1px solid #edf0f2;
  opacity: 0;
  transform: translateY(-4px);

}

.nav-links.show li{
  opacity: 1;
  transform: translateY(0);
}

.nav-links.show li:nth-child(1)
.nav-links.show li:nth-child(2)
.nav-links.show li:nth-child(3)
.nav-links.show li:nth-child(4)
.nav-links.show li:nth-child(5)
.nav-links.show li:nth-child(6)
.nav-links.show li:nth-child(7)
.nav-links.show li:nth-child(8)

.nav-links li:last-child{
  border-bottom: none;
}

.nav-links li a{
  display: block;
  width: 100%;
  padding: 11px 0;
  font-size: 14px;
  font-weight: 100;
  color: #0F172A;
  text-decoration: none;
}

.nav-konsultasi-mobile{
  display: block;
  margin-top: 4px;
  border-bottom: none !important;
}

.nav-konsultasi-mobile a{
  display: block !important;
  text-align: center !important;
  background: #0F3D3A !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 10px 14px !important;
  font-weight: 600 !important;
  margin-top: 40px !important;
  font-size: 13px !important;
  line-height: 1.2;
  text-decoration: none !important;
  box-shadow: none !important;
}
}



  /* =========================
   HERO MOBILE - ALL PHONE
   ========================= */

@media screen and (max-width: 768px){

  .sect-hero{
    position: relative;
    min-height: 0 !important;
    height: auto !important;
    padding-top: calc(78px + env(safe-area-inset-top)) !important;
    padding-right: 18px !important;
    padding-left: 18px !important;
    padding-bottom: 0 !important;
    background-size: cover;
    background-position: center top;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    overflow: hidden;
  }

  .overlay{
    position: absolute;
    inset: 0;
    display: block;
    background: linear-gradient(
      180deg,
      rgba(15,61,58,0.74) 0%,
      rgba(15,61,58,0.84) 45%,
      rgba(15,61,58,0.90) 100%
    );
    z-index: 1;
  }

  .hero-container{
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 360px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .hero-logo-center{
    width: clamp(74px, 20vw, 94px);
    height: auto;
    margin-bottom: 14px;
  }

  .hero-container .title-white{
    margin: 0;
    font-family: 'Playfair Display', serif;
    font-size: clamp(30px, 8vw, 38px);
    line-height: 1.12;
    font-weight: 700;
    color: #ffffff;
    text-align: center;
  }

  .hero-container .title-gold{
    margin: 6px 0 0;
    font-family: 'Playfair Display', serif;
    font-size: clamp(20px, 5.6vw, 27px);
    line-height: 1.18;
    font-weight: 700;
    color: #C9A24D;
    text-align: center;
  }

  .hero-desc{
    width: 100%;
    max-width: 320px;
    margin: 18px auto 20px;
    font-size: clamp(13px, 3.7vw, 14px);
    line-height: 1.8;
    color: rgba(255,255,255,0.92);
    opacity: 1;
  }

  .cta-group{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 12px;
  }

  .btn-main{
    width: 100%;
    min-height: 48px;
    padding: 14px 16px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  .stats-grid{
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
     margin-bottom: 0;
  }

  .stat-item{
    padding: 11px 8px;
    text-align: center;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 14px;
    backdrop-filter: blur(4px);
  }

  .stat-item h3{
    margin: 0 0 4px;
    font-size: clamp(18px, 5vw, 24px);
    line-height: 1.1;
    color: #ffffff;
  }

  .stat-item p{
    margin: 0;
    font-size: 11px;
    line-height: 1.35;
    color: rgba(255,255,255,0.85);
  }


}



/* =========================
   HERO MOBILE - IPHONE
   ========================= */

@media screen and (max-width: 430px){

  .sect-hero{
    min-height: 0 !important;
    height: auto !important;
    padding: calc(25px + env(safe-area-inset-top)) 18px 30px !important;
    background-position: center top;
  }
  .hero-container{
    max-width: 340px;
  }

  .hero-logo-center{
    width: 100px;
    margin-bottom: 12px;
  }

  .hero-desc{
    max-width: 300px;
    margin: 16px auto 18px;
  }

  .cta-group{
    gap: 10px;
    margin-bottom: 16px;
  }

  .stats-grid{
    gap: 7px;
  }
}

/* =========================
   HERO MOBILE - ANDROID
   ========================= */

@media screen and (max-width: 380px){

  .sect-hero{
    min-height: 0 !important;
    height: auto !important;
    padding: calc(30px + env(safe-area-inset-top)) 16px 30px !important;
    background-position: center top;
  }

  .hero-container{
    max-width: 320px;
  }

  .hero-logo-center{
    width: 80px;
    margin-bottom: 10px;
  }

  .hero-container .title-white{
    font-size: clamp(26px, 7.2vw, 32px);
  }

  .hero-container .title-gold{
    font-size: clamp(18px, 5vw, 22px);
  }

  .hero-desc{
    max-width: 286px;
    margin: 14px auto 16px;
    font-size: 13px;
    line-height: 1.72;
  }

  .btn-main{
    min-height: 46px;
    padding: 13px 14px;
    font-size: 13px;
  }

  .stats-grid{
    gap: 6px;
  }

  .stat-item{
    padding: 10px 6px;
    border-radius: 12px;
  }

  .stat-item p{
    font-size: 10px;
  }
}

/* =========================
   SECTION 2 - ABOUT MOBILE
   ========================= */

/* ===== ALL PHONE ===== */
@media screen and (max-width: 768px){

  .sect-about{
    padding: 48px 18px 28px;
    background: #f8f8f8;
  }

  .container-about{
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  .about-content{
    width: 100%;
    order: 1;
    text-align: left;
  }

  /* gambar disembunyikan dulu */
  .about-visual{
    display: none;
  }

  .top-label{
    display: inline-block;
    margin-bottom: 12px;
    text-align: left;
  }

  .section-title{
    margin: 0 0 14px;
    font-size: clamp(28px, 8vw, 40px);
    line-height: 1.2;
    text-align: left;
  }

  .intro-text{
    margin: 0 0 18px;
    font-size: 15px;
    line-height: 1.85;
    text-align: left;
  }

  /* ===== VISI MISI ===== */
  .vm-card{
    background: #ffffff;
    border: 1px solid #d9dde3;
    border-radius: 20px;
    padding: 18px 16px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.03);
    margin-bottom: 18px;
    text-align: left;
  }

  .vm-block{
    text-align: left;
  }

  .vm-block + .vm-block{
    margin-top: 18px;
  }

  .gold-label{
    display: block;
    margin: 0 0 10px;
    font-size: 18px;
    text-align: left;
  }

  .vm-block p{
    margin: 0;
    font-size: 14px;
    line-height: 1.85;
    text-align: left;
  }

  .vm-block ol{
    margin: 0;
    padding-left: 18px;
    text-align: left;
  }

  .vm-block ol li{
    margin-bottom: 8px;
    font-size: 14px;
    line-height: 1.65;
    text-align: left;
  }

  .vm-block ol li:last-child{
    margin-bottom: 0;
  }

  /* ===== FITUR ===== */
  .features-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px 14px;
    margin-top: 4px;
  }

  .feat-card{
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 0;
    background: transparent;
    border: none;
    box-shadow: none;
    text-align: left;
  }

  .icon-box{
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: #eef7f5;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 38px;
  }

  .icon-box img{
    width: 18px;
    height: 18px;
    object-fit: contain;
  }

  .feat-info{
    text-align: left;
  }

  .feat-info strong{
    display: block;
    margin-bottom: 4px;
    font-size: 15px;
    line-height: 1.35;
    text-align: left;
  }

  .feat-info p{
    margin: 0;
    font-size: 13px;
    line-height: 1.55;
    text-align: left;
  }

  /* ===== BADGE ===== */
  .halal-tag{
    margin: 20px 0 0;
    padding: 12px 18px;
    border: 1px solid #cfd6dc;
    border-radius: 999px;
    background: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    box-shadow: 0 6px 14px rgba(0,0,0,0.05);
    text-align: left;
  }

  .halal-icon-img{
    width: 90px;
    height: 20px;
    object-fit: contain;
  }

  .halal-tag span{
    font-size: 14px;
    font-weight: 500;
    text-align: left;
  }
}

/* ===== IPHONE / MEDIUM PHONE ===== */
@media screen and (max-width: 430px){

  .sect-about{
    padding: 44px 18px 26px;
  }

  .section-title{
    font-size: clamp(26px, 7.5vw, 34px);
    line-height: 1.22;
    margin-bottom: 12px;
  }

  .intro-text{
    font-size: 14px;
    line-height: 1.8;
    margin-bottom: 16px;
  }

  .vm-card{
    padding: 17px 15px;
    border-radius: 18px;
    margin-bottom: 16px;
  }

  .vm-block + .vm-block{
    margin-top: 16px;
  }

  .gold-label{
    font-size: 17px;
    margin-bottom: 8px;
  }

  .vm-block p,
  .vm-block ol li{
    font-size: 13px;
  }

  .features-grid{
    gap: 16px 12px;
  }

  .feat-info strong{
    font-size: 14px;
  }

  .feat-info p{
    font-size: 12px;
    line-height: 1.5;
  }

    .icon-box{
    width: 34px;
    height: 34px;
    border-radius: 10px;
    flex: 0 0 34px;
  }

  .icon-box img{
    width: 160px;
    height: 50px;
  }

 .halal-tag{
    width: 80%;
    margin: 3px 0 0;
     margin-left: 30px;
    padding: 11px 14px;
    border-radius: 999px;
  }

  .halal-icon-img{
    width: 50px;
    height: 40px;
     flex: 0 0 28px;
  }

  .halal-tag span{
    font-size: 12px;
    margin-left: 7px;

  }
}

/* ===== ANDROID SMALL / NARROW PHONE ===== */
@media screen and (max-width: 380px){

  .sect-about{
    padding: 40px 16px 24px;
  }

  .top-label{
    margin-bottom: 10px;
    font-size: 12px;
  }

  .section-title{
    font-size: clamp(24px, 8vw, 30px);
    line-height: 1.22;
    margin-bottom: 12px;
  }

  .intro-text{
    font-size: 14px;
    line-height: 1.72;
    margin-bottom: 14px;
  }

  .vm-card{
    padding: 16px 14px;
    border-radius: 16px;
    margin-bottom: 14px;
  }

  .gold-label{
    font-size: 16px;
    margin-bottom: 8px;
  }

  .vm-block + .vm-block{
    margin-top: 14px;
  }

  .vm-block p{
    font-size: 13px;
    line-height: 1.75;
  }

  .vm-block ol{
    padding-left: 16px;
  }

  .vm-block ol li{
    font-size: 13px;
    line-height: 1.55;
    margin-bottom: 6px;
  }

  .features-grid{
    gap: 14px 10px;
  }

  .icon-box{
    width: 34px;
    height: 34px;
    border-radius: 10px;
    flex: 0 0 34px;
  }

  .icon-box img{
    width: 160px;
    height: 50px;
  }

  .feat-card{
    gap: 8px;
  }

  .feat-info strong{
    font-size: 13px;
    margin-bottom: 3px;
  }

  .feat-info p{
    font-size: 11px;
    line-height: 1.45;
  }

  .halal-tag{
    width: 80%;
    margin: 4px 0 0;
     margin-left: 30px;
    padding: 11px 14px;
    border-radius: 999px;
  }

  .halal-icon-img{
    width: 50px;
    height: 40px;
     flex: 0 0 28px;
  }

  .halal-tag span{
    font-size: 12px;
    margin-left: 7px;

  }
}


/* =========================================
   MOBILE LAYANAN - ACCORDION LOOK ONLY
   TANPA UBAH HTML / TANPA UBAH DESKTOP
   ========================================= */
@media screen and (max-width: 480px){

  .sect-services{
    padding: 34px 14px 38px;
    background: #0F3D3A;
    text-align: center;
    overflow: hidden;
  }

  .container-services{
    width: 100%;
    max-width: 100%;
  }

  .header-services{
    max-width: 100%;
    margin: 0 auto 18px;
  }

  .top-label-gold{
    display: block;
    font-size: 10px;
    letter-spacing: 2.1px;
    line-height: 1.6;
    color: #C9A24D;
    margin-bottom: 8px;
  }

  .section-title-services{
    font-size: 30px;
    line-height: 1.05;
    color: #ffffff;
    margin: 0;
    font-weight: 800;
  }

  .title-line{
    display: none;
  }

  .services-grid{
    display: flex;
    align-items: stretch;
    gap: 3px;
    height: 430px;
    margin-bottom: 18px;
    overflow: hidden;
    touch-action: pan-y;
    user-select: none;
  }

  .service-card{
    position: relative;
    flex: 0 0 50px !important;
    min-width: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    overflow: hidden;
    transition:
      flex .55s cubic-bezier(.4,0,.2,1),
      transform .35s ease,
      filter .35s ease;
  }

  .service-card.is-active{
    flex: 1 1 48% !important;
  }

  .service-card:not(.is-active){
    cursor: pointer;
  }

  .service-card:first-child{
    border-radius: 24px 0 0 24px;
  }

  .service-card:last-child{
    border-radius: 0 24px 24px 0;
  }

  .service-img-wrapper{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }

  .main-img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: filter .35s ease, transform .45s ease;
  }

  .service-card:not(.is-active) .main-img{
    filter: brightness(.42) saturate(.55);
  }

  .service-card.is-active .main-img{
    filter: brightness(.92) saturate(.95);
    transform: scale(1.02);
  }

  .service-img-wrapper::before{
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
  }

  .service-card:nth-child(1) .service-img-wrapper::before{
    background: rgba(15, 61, 58, 0.34);
  }

  .service-card:nth-child(2) .service-img-wrapper::before{
    background: rgba(201, 162, 77, 0.28);
  }

  .service-card:nth-child(3) .service-img-wrapper::before{
    background: rgba(91, 33, 182, 0.28);
  }

  .service-card:nth-child(4) .service-img-wrapper::before{
    background: rgba(190, 24, 93, 0.24);
  }

  .service-img-wrapper::after{
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    background: linear-gradient(
      180deg,
      rgba(0,0,0,0.08) 0%,
      rgba(0,0,0,0.18) 28%,
      rgba(0,0,0,0.78) 100%
    );
  }

  .badge-fav-right{
    position: absolute;
    top: 10px;
    right: 10px;
    width: 54px;
    z-index: 7;
  }

  .service-card:not(.is-active) .badge-fav-right{
    display: none;
  }

  .service-card::before{
    position: absolute;
    z-index: 6;
    font-weight: 800;
    color: #C9A24D;
    letter-spacing: 1px;
  }

  .service-card:nth-child(1)::before{ content: "01"; }
  .service-card:nth-child(2)::before{ content: "02"; }
  .service-card:nth-child(3)::before{ content: "03"; }
  .service-card:nth-child(4)::before{ content: "04"; }

  .service-card:not(.is-active)::before{
    top: 72px !important;
    left: 50%;
    transform: translateX(-50%) !important;
    font-size: 15px !important;
  }

  .service-card.is-active::before{
    top: 14px;
    right: 14px;
    font-size: 72px;
    color: rgba(255,255,255,0.07);
    letter-spacing: 0;
  }

  .service-info{
    position: absolute;
    z-index: 8;
  }

  /* panel kecil */
  .service-card:not(.is-active) .service-info{
    inset: 0;
    padding: 0 !important;
    display: block !important;
    background: none !important;
    text-align: center;
  }

  .service-card:not(.is-active) h3{
    position: absolute;
    left: 50%;
    bottom: 16px;
    transform: translateX(-50%) rotate(180deg) !important;
    transform-origin: center;
    writing-mode: vertical-rl;
    white-space: nowrap;
    margin: 0 !important;
    color: #ffffff;
    font-size: 10px !important;
    line-height: 1;
    letter-spacing: 1px !important;
    text-transform: uppercase;
    font-weight: 700;
    text-align: center;
  }

  .service-card:not(.is-active) .desc,
  .service-card:not(.is-active) .rating,
  .service-card:not(.is-active) .price,
  .service-card:not(.is-active) .service-detail-btn,
  .service-card:not(.is-active) .service-sub,
  .service-card:not(.is-active) .service-chip,
  .service-card:not(.is-active) .service-rating-badge{
    display: none !important;
  }

  /* panel aktif */
  .service-card.is-active .service-info{
    left: 0;
    right: 0;
    bottom: 0;
    padding: 16px 14px 16px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    text-align: left;
    background: linear-gradient(
      180deg,
      rgba(15,61,58,0) 0%,
      rgba(15,61,58,0.55) 44%,
      rgba(15,61,58,0.92) 100%
    );
  }

  /* yang disembunyikan cukup deskripsi & rating asli */
  .service-card.is-active .desc{
    display: none !important;
  }

  .service-card.is-active .rating{
    display: none !important;
  }

  /* rating custom */
  .service-rating-badge{
    display: none;
  }

  .service-card.is-active .service-rating-badge{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 10px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,0.14);
    border: 1px solid rgba(255,255,255,0.16);
    color: #C9A24D;
    font-size: 12px;
    font-weight: 700;
    backdrop-filter: blur(6px);
    opacity: 0;
    transform: translateY(16px);
    animation: serviceFadeUp .38s ease forwards;
    animation-delay: .05s;
  }

  /* judul tampil */
  .service-card.is-active h3{
    display: block !important;
    margin: 0 0 8px;
    color: #ffffff;
    font-size: 22px !important;
    line-height: 1.08;
    font-weight: 800;
    opacity: 0;
    transform: translateY(16px);
    animation: serviceFadeUp .38s ease forwards;
    animation-delay: .08s;
  }

  /* harga tampil */
  .service-card.is-active .price{
    display: block !important;
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
    color: #C9A24D;
    font-size: 22px !important;
    font-weight: 800;
    line-height: 1.1;
    opacity: 0;
    transform: translateY(16px);
    animation: serviceFadeUp .38s ease forwards;
    animation-delay: .12s;
  }

  .service-card.is-active .price::before{
    content: "MULAI DARI";
    display: block;
    margin-bottom: 6px;
    font-size: 9px;
    letter-spacing: 1.5px;
    color: rgba(255,255,255,0.66);
    font-weight: 700;
  }

  .service-detail-btn{
    margin-top: 10px;
    min-width: 118px;
    height: 46px;
    padding: 0 16px;
    border: none;
    border-radius: 14px;
    background: #C9A24D;
    color: #0F3D3A;
    font-size: 14px;
    font-weight: 700;
    opacity: 0;
    transform: translateY(16px);
    animation: serviceFadeUp .38s ease forwards;
    animation-delay: .16s;
  }

  @keyframes serviceFadeUp{
    from{
      opacity: 0;
      transform: translateY(16px);
    }
    to{
      opacity: 1;
      transform: translateY(0);
    }
  }

  .view-more-wrapper{
    margin-top: 6px;
  }

  .btn-view-more{
    width: 100%;
    min-width: 0;
    height: 50px;
    border-radius: 18px;
    background: linear-gradient(90deg, #0F3D3A 0%, #0F3D3A 100%);
    color: #ece7db;
    border: 1px solid rgba(201, 162, 77, 0.38);
    font-size: 15px;
    font-weight: 700;
    box-shadow: none;
  }

  .btn-view-more:hover{
    transform: none;
    background: linear-gradient(90deg, #0F3D3A 0%, #0F3D3A 100%);
    color: #eaeaea;
  }

  /* ===== modal detail simpel ===== */
  .service-sheet-backdrop{
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(15,61,58,0.58);
    backdrop-filter: blur(4px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease;
  }

  .service-sheet-backdrop.open{
    opacity: 1;
    pointer-events: auto;
  }

  .service-sheet{
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    background: #faf7f1;
    border-radius: 24px 24px 0 0;
    transform: translateY(100%);
    overflow: hidden;
  }

  .service-sheet-backdrop.open .service-sheet{
    animation: sheetUp .34s cubic-bezier(.22,1,.36,1) forwards;
  }

  .service-sheet-backdrop.closing .service-sheet{
    animation: sheetDown .24s ease forwards;
  }

  @keyframes sheetUp{
    from{ transform: translateY(100%); }
    to{ transform: translateY(0); }
  }

  @keyframes sheetDown{
    from{ transform: translateY(0); }
    to{ transform: translateY(100%); }
  }

  .sheet-scroll{
    max-height: 92vh;
    overflow-y: auto;
  }

  .sheet-hero{
    position: relative;
    height: 220px;
  }

  .sheet-hero img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .sheet-hero::after{
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
      180deg,
      rgba(15,61,58,0.06) 0%,
      rgba(15,61,58,0.20) 36%,
      rgba(15,61,58,0.82) 100%
    );
  }

  .sheet-close{
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 2;
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 50%;
    background: rgba(255,255,255,0.18);
    color: #fff;
    font-size: 24px;
    line-height: 1;
    backdrop-filter: blur(6px);
  }

  .sheet-head{
    position: absolute;
    left: 16px;
    right: 16px;
    bottom: 16px;
    z-index: 2;
    color: #fff;
  }

  .sheet-head h3{
    margin: 0 0 6px;
    font-size: 24px;
    line-height: 1.08;
  }

  .sheet-head .sheet-price-top{
    color: #C9A24D;
    font-size: 15px;
    font-weight: 700;
  }

  .sheet-body{
    padding: 18px 16px 110px;
  }

  .sheet-section{
    background: #fff;
    border-radius: 16px;
    padding: 15px;
    border: 1px solid rgba(15,61,58,0.08);
  }

  .sheet-section h4{
    margin: 0 0 10px;
    color: #0F3D3A;
    font-size: 15px;
  }

  .sheet-section p{
    margin: 0;
    color: #4b5563;
    font-size: 13px;
    line-height: 1.75;
  }

  .sheet-footer{
    position: sticky;
    bottom: 0;
    background: rgba(250,247,241,0.96);
    backdrop-filter: blur(8px);
    border-top: 1px solid rgba(15,61,58,0.08);
    padding: 14px 16px calc(14px + env(safe-area-inset-bottom));
  }

  .sheet-book{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 48px;
    border-radius: 14px;
    text-decoration: none;
    background: #C9A24D;
    color: #0F3D3A;
    font-size: 14px;
    font-weight: 800;
  }
}

/* hide rating badge mobile di desktop */
.service-rating-badge{
  display: none !important;
}

/* tampilkan hanya di mobile pada card aktif */
@media screen and (max-width: 480px){
  .service-card.is-active .service-rating-badge{
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
  }
}

/* =========================================
   SECTION 4 - PRODUK MOBILE
   LANJUTAN RESPONSIVE.CSS
   ========================================= */

/* elemen mobile-only: default disembunyikan di desktop */
.product-detail-btn,
.product-sheet-backdrop,
.product-actions-mobile{
  display: none;
}

@media screen and (max-width: 480px){

  /* =========================
     JEDA HALUS SECTION 3 -> 4
     ========================= */
  .sect-products{
    position: relative;
    padding: 58px 14px 40px;
    background: #0F3D3A;
    overflow: hidden;
  }

  .sect-products::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 48px;
    background: linear-gradient(
      180deg,
      #0F3D3A 0%,
      #0F3D3A 100%
    );
    pointer-events: none;
  }

  .sect-products::after{
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 42px;
    background: linear-gradient(
      180deg,
      rgba(15,61,58,0) 0%,
      rgba(15,61,58,0.22) 100%
    );
    pointer-events: none;
  }

  .container-products{
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 100%;
  }

  .header-products{
    max-width: 100%;
    margin: 0 auto 18px;
    text-align: center;
  }

  .top-label-gold{
    display: block;
    font-size: 10px;
    letter-spacing: 2px;
    line-height: 1.6;
    color: #C9A24D;
    margin-bottom: 8px;
  }

  .section-title-products{
    margin: 0;
    color: #ffffff;
    font-size: 30px;
    line-height: 1.06;
    font-weight: 800;
  }

  .header-products .title-line{
    display: none;
  }

  /* =========================
     HORIZONTAL CARD
     ========================= */
  .products-grid{
    display: flex;
    gap: 12px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 4px 2px 10px;
    scroll-snap-type: x mandatory;
    -ms-overflow-style: none;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .products-grid::-webkit-scrollbar{
    display: none;
  }

  .product-card{
    flex: 0 0 84%;
    min-width: 84%;
    scroll-snap-align: start;
    background: #0F3D3A;
    border: 1px solid rgba(201, 162, 77, 0.10);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 18px 36px rgba(0,0,0,0.18);
    transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease;
  }

  /* class active bisa dipakai JS */
  .product-card.is-active{
    transform: translateY(-4px);
    border-color: rgba(201, 162, 77, 0.72);
    box-shadow: 0 22px 42px rgba(0,0,0,0.22);
  }

  /* =========================
     IMAGE AREA
     ========================= */
  .product-img-wrapper{
    position: relative;
    height: 230px;
    overflow: hidden;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
  }

  .product-img{
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: transform .35s ease, filter .35s ease;
  }

  .product-card:not(.is-active) .product-img{
    filter: brightness(.48) saturate(.68);
  }

  .product-card.is-active .product-img{
    filter: brightness(.95) saturate(.95);
    transform: scale(1.02);
  }

  .product-img-wrapper::after{
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
      180deg,
      rgba(0,0,0,0.04) 0%,
      rgba(0,0,0,0.10) 28%,
      rgba(15,61,58,0.30) 100%
    );
    pointer-events: none;
  }

  .discount-tag{
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 3;
    min-width: 56px;
    height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #C9A24D 0%, #C9A24D 100%);
    color: #0F3D3A;
    font-size: 12px;
    font-weight: 800;
    box-shadow: 0 10px 20px rgba(201, 162, 77, 0.22);
  }

  /* =========================
     BODY CARD - TIDAK NEMPEL GAMBAR
     ========================= */
  .product-info{
    position: relative;
    padding: 16px 16px 16px;
    text-align: left;
    background: linear-gradient(
      180deg,
      #0F3D3A 0%,
      #0F3D3A 100%
    );
  }

  .product-info h3{
    margin: 0 0 6px;
    color: #ffffff;
    font-size: 20px;
    line-height: 1.14;
    font-weight: 800;

    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .product-desc{
    margin: 0 0 12px;
    color: rgba(255,255,255,0.82);
    font-size: 13px;
    line-height: 1.6;
    text-transform: none;
    letter-spacing: 0;

    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 42px;
  }

  .product-meta{
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
    color: #C9A24D;
    font-size: 12px;
    font-weight: 700;
  }

  .product-meta .rating{
    color: #C9A24D;
  }

  .product-meta .sold{
    color: rgba(255,255,255,0.68);
  }

  .price-box{
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
  }

  .current-price{
    display: block;
    color: #ffffff;
    font-size: 22px;
    line-height: 1.06;
    font-weight: 800;
  }

  .old-price{
    display: block;
    color: rgba(255,255,255,0.55);
    font-size: 13px;
    line-height: 1.2;
    text-decoration: line-through;
    white-space: nowrap;
    padding-bottom: 3px;
  }

  /* =========================
     ACTION DI CARD MOBILE
     ========================= */

  /* tombol marketplace di card mobile disembunyikan */
  .shop-buttons{
    display: none !important;
  }

  /* JS inject ini */
  .product-actions-mobile{
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: 4px;
  }

  .product-detail-btn{
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 46px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, #C9A24D 0%, #C9A24D 100%);
    color: #0F3D3A;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 0 12px 26px rgba(201, 162, 77, 0.18);
  }

  /* =========================
     BUTTON BAWAH SECTION
     ========================= */
  .btn-see-more-dark{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 50px;
    margin-top: 12px;
    border-radius: 16px;
    text-decoration: none;
    background: linear-gradient(90deg, #0F3D3A 0%, #0F3D3A 100%);
    color: #C9A24D;
    border: 1px solid rgba(201, 162, 77, 0.28);
    font-size: 14px;
    font-weight: 700;
    box-shadow: none;
  }

  .text-market{
    margin: 14px auto 12px;
    max-width: 320px;
    text-align: center;
    color: rgba(255,255,255,0.74);
    font-size: 12px;
    line-height: 1.6;
  }

  .market-buttons-group{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .market-buttons-group .btn-outline{
    min-height: 46px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
  }

  /* =========================
     MODAL DETAIL PRODUK
     ========================= */
  .product-sheet-backdrop{
    display: block !important;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(15,61,58,0.58);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease;
  }

  .product-sheet-backdrop.open{
    opacity: 1;
    pointer-events: auto;
  }

  .product-sheet{
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    max-width: 480px;
    margin: 0 auto;
    background: #faf7f1;
    border-top-left-radius: 26px;
    border-top-right-radius: 26px;
    transform: translateY(100%);
    overflow: hidden;
    box-shadow: 0 -22px 40px rgba(0,0,0,0.24);
  }

  .product-sheet-backdrop.open .product-sheet{
    animation: sheetUp .24s ease both;
  }

  .product-sheet-backdrop.closing .product-sheet{
    animation: sheetDown .24s ease both;
  }

  .product-sheet-scroll{
    max-height: 92vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .product-sheet-pull{
    width: 44px;
    height: 5px;
    border-radius: 999px;
    background: #d1d5db;
    margin: 10px auto 8px;
  }

  .product-sheet-hero{
    position: relative;
    height: 220px;
    overflow: hidden;
  }

  .product-sheet-hero img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .product-sheet-hero::after{
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
      180deg,
      rgba(15,61,58,0.08) 0%,
      rgba(15,61,58,0.16) 36%,
      rgba(15,61,58,0.82) 100%
    );
  }

  .product-sheet-close{
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 2;
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 50%;
    background: rgba(255,255,255,0.18);
    color: #ffffff;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    backdrop-filter: blur(8px);
  }

  .product-sheet-badges{
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 2;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
  }

  .product-sheet-tag{
    padding: 7px 11px;
    border-radius: 999px;
    background: rgba(255,255,255,0.16);
    color: #ffffff;
    border: 1px solid rgba(255,255,255,0.14);
    font-size: 12px;
    font-weight: 700;
    backdrop-filter: blur(8px);
  }

  .product-sheet-disc{
    padding: 7px 11px;
    border-radius: 999px;
    background: linear-gradient(135deg, #C9A24D 0%, #C9A24D 100%);
    color: #0F3D3A;
    font-size: 12px;
    font-weight: 800;
    box-shadow: 0 10px 20px rgba(201, 162, 77, 0.20);
  }

  .product-sheet-head{
    position: absolute;
    left: 16px;
    right: 16px;
    bottom: 16px;
    z-index: 2;
    color: #ffffff;
  }

  .product-sheet-head h3{
    margin: 0 0 6px;
    font-size: 24px;
    line-height: 1.08;
    font-weight: 800;
  }

  .product-sheet-head .product-sheet-price-top{
    color: #C9A24D;
    font-size: 16px;
    font-weight: 800;
  }

  .product-sheet-body{
    padding: 18px 16px 118px;
  }

  .product-sheet-meta{
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 14px;
  }

  .product-sheet-rating{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    border-radius: 999px;
    background: #fff7df;
    color: #C9A24D;
    font-size: 12px;
    font-weight: 700;
  }

  .product-sheet-disc-inline{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 12px;
    border-radius: 999px;
    background: #fff;
    color: #0F3D3A;
    border: 1px solid rgba(15,61,58,0.08);
    font-size: 12px;
    font-weight: 700;
  }

  .product-sheet-section{
    background: #ffffff;
    border-radius: 18px;
    padding: 16px;
    border: 1px solid rgba(15,61,58,0.08);
    box-shadow: 0 8px 18px rgba(0,0,0,0.03);
  }

  .product-sheet-section h4{
    margin: 0 0 10px;
    color: #0F3D3A;
    font-size: 15px;
    font-weight: 800;
  }

  .product-sheet-section p{
    margin: 0;
    color: #4b5563;
    font-size: 13px;
    line-height: 1.75;
    text-transform: none;
    letter-spacing: 0;
  }

  .product-sheet-footer{
    position: sticky;
    bottom: 0;
    background: rgba(250,247,241,0.96);
    backdrop-filter: blur(8px);
    border-top: 1px solid rgba(15,61,58,0.08);
    padding: 14px 16px calc(14px + env(safe-area-inset-bottom));
  }

  .product-sheet-actions{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .product-sheet-actions a{
    min-height: 48px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 14px;
    font-weight: 800;
  }


  .product-sheet-actions .btn-shopee{
    background: #ee4d2d;
    color: #ffffff;
    border: none;
  }

  .product-sheet-actions .btn-tiktok{
    background: #111111;
    color: #ffffff;
    border: none;
  }
}

/* =========================================
   PATCH SECTION 4 MOBILE
   - gambar tidak kepotong
   - diskon pendek & pindah kiri
   - tombol Shopee/TikTok langsung berwarna
   ========================================= */
@media screen and (max-width: 480px){

  /* =========================
     GAMBAR PRODUK: jangan kepotong
     ========================= */
  .product-img-wrapper{
    height: 230px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 14px;
    background:
      radial-gradient(circle at top, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0) 55%),
      linear-gradient(180deg, #f6f1e4 0%, #ddd6c6 100%);
  }

  .product-img{
    width: 100%;
    height: 100%;
    object-fit: contain !important;
    object-position: center;
    display: block;
  }

  /* overlay gambar dibuat lebih soft */
  .product-img-wrapper::after{
    background: linear-gradient(
      180deg,
      rgba(0,0,0,0.02) 0%,
      rgba(0,0,0,0.06) 38%,
      rgba(15,61,58,0.14) 100%
    ) !important;
  }

  /* =========================
     DISKON: lebih pendek & kiri atas
     ========================= */
  .discount-tag{
    top: 12px !important;
    left: 12px !important;
    right: auto !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: 82px;
    height: 28px !important;
    padding: 0 12px !important;
    border-radius: 999px;
    font-size: 11px !important;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    background: linear-gradient(135deg, #C9A24D 0%, #C9A24D 100%) !important;
    color: #0F3D3A !important;
    box-shadow: 0 8px 18px rgba(201, 162, 77, 0.22);
  }

  /* modal badge diskon juga dipendekin */
  .product-sheet-disc,
  .product-sheet-disc-inline{
    min-width: 0 !important;
    width: auto !important;
    max-width: 96px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 11px !important;
  }

  /* =========================
     TOMBOL MARKETPLACE:
     langsung berwarna, tidak perlu hover dulu
     ========================= */

  /* tombol di bawah section */
  .market-buttons-group .btn-shopee,
  .market-buttons-group a[href*="shopee"]{
    background: #ee4d2d !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: 0 12px 22px rgba(238,77,45,0.22);
  }

  .market-buttons-group .btn-tiktok,
  .market-buttons-group a[href*="tiktok"]{
    background: #111111 !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: 0 12px 22px rgba(0,0,0,0.22);
  }

  /* tombol di modal detail */
  .product-sheet-actions .btn-shopee,
  .product-sheet-actions a[href*="shopee"]{
    background: #ee4d2d !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: 0 12px 22px rgba(238,77,45,0.22);
  }

  .product-sheet-actions .btn-tiktok,
  .product-sheet-actions a[href*="tiktok"]{
    background: #111111 !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: 0 12px 22px rgba(0,0,0,0.22);
  }

  /* hover */
  .market-buttons-group .btn-shopee:hover,
  .market-buttons-group a[href*="shopee"]:hover,
  .product-sheet-actions .btn-shopee:hover,
  .product-sheet-actions a[href*="shopee"]:hover{
    background: #ee4d2d !important;
    color: #ffffff !important;
  }

  .market-buttons-group .btn-tiktok:hover,
  .market-buttons-group a[href*="tiktok"]:hover,
  .product-sheet-actions .btn-tiktok:hover,
  .product-sheet-actions a[href*="tiktok"]:hover{
    background: #111111 !important;
    color: #ffffff !important;
  }
}

/* =========================================
   HIDE ELEMEN MOBILE PRODUK DI DESKTOP
   ========================================= */
@media screen and (min-width: 481px){
  .product-dots,
  .product-dot,
  .product-actions-mobile,
  .product-detail-btn,
  .product-sheet-backdrop{
    display: none !important;
  }
}

/* =========================================
   TAMPILKAN HANYA DI MOBILE
   ========================================= */
@media screen and (max-width: 480px){
  .product-dots{
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 12px 0 0;
  }

  .product-dot{
    display: inline-block !important;
  }
}

/* =========================================
   SECTION 5 - DOKTER MOBILE
   TANPA JEDA / TANPA TRANSISI WARNA
   ========================================= */
@media screen and (max-width: 480px){

  /* section produk tetap normal, tanpa tambahan jeda */
  .sect-products{
    padding-bottom: 40px !important;
  }

  /* section dokter */
  .sect-experts{
    position: relative;
    margin-top: 0;
    padding: 34px 16px 34px;
    background: #0F3D3A;
    text-align: center;
    overflow: hidden;
  }

  /* hilangkan transisi atas */
  .sect-experts::before{
    display: none !important;
    content: none !important;
  }

  .container-experts{
    width: 100%;
    max-width: 100%;
  }

  .header-experts{
    margin: 0 auto 26px;
    text-align: center;
  }

  .header-experts .top-label-gold{
    display: block;
    margin-bottom: 10px;
    color: #C9A24D;
    font-size: 11px;
    letter-spacing: 2.4px;
    font-weight: 700;
    line-height: 1.4;
  }

  .section-title-experts{
    margin: 0;
    color: #ffffff;
    font-size: 28px;
    line-height: 1.08;
    font-weight: 800;
  }

  .header-experts .title-line{
    width: 38px;
    height: 3px;
    margin: 12px auto 0;
    border-radius: 999px;
    background: rgba(201, 162, 77, 0.79);
  }

  .experts-grid{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    align-items: start;
  }

  .expert-card{
    width: 100%;
    max-width: 100%;
    padding: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    text-align: center;
  }

  .expert-img-container{
    width: 100%;
    height: 220px;
    margin: 0 0 12px;
    border: none;
    padding: 0;
    border-radius: 22px;
    overflow: hidden;
    background: #dfe6e3;
    box-shadow: 0 12px 24px rgba(15,61,58,0.10);
  }

  .expert-img-container img{
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    border-radius: 22px;
  }

  .expert-info{
    padding: 0 4px;
  }

  .expert-info h3{
    margin: 0 0 4px;
    color: #C9A24D;
    font-size: 14px;
    line-height: 1.35;
    font-weight: 800;
  }

  .expert-info p{
    margin: 0;
    color: #C9A24D;
    font-size: 12px;
    line-height: 1.45;
    font-weight: 500;
  }

  .expert-info::after{
    content: "";
    display: block;
    width: 22px;
    height: 2px;
    border-radius: 999px;
    background: #ffffff;
    margin: 10px auto 0;
  }
}

/* =========================================
   SECTION CTA MOBILE
   NYAMBUNG DENGAN SECTION DOKTER
   ========================================= */
@media screen and (max-width: 480px){

  /* section dokter dibikin rapat ke bawah */
  .sect-experts{
    padding-bottom: 18px !important;
    margin-bottom: 0 !important;
  }

  /* CTA langsung nyambung, tanpa jeda putih */
  .sect-cta{
    position: relative;
    margin-top: 0 !important;
    padding: 34px 16px 44px !important;
    background-image: url('Img/WhatsApp Image 2026-02-12 at 20.58.42.webp');
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    background-attachment: scroll !important;
    text-align: center;
    overflow: hidden;
  }

  /* overlay tetap ada biar teks kebaca */
  .cta-overlay{
    position: absolute;
    inset: 0;
    background: rgba(15, 61, 58, 0.68) !important;
    z-index: 1;
  }

  .cta-content{
    position: relative;
    z-index: 2;
    max-width: 100%;
    margin: 0 auto;
  }

  .cta-title{
    margin: 0 0 16px;
    color: #ffffff;
    font-size: 28px;
    line-height: 1.18;
    font-weight: 800;
    text-align: center;
  }

  .cta-desc{
    margin: 0 auto 28px;
    max-width: 320px;
    color: rgba(255,255,255,0.90);
    font-size: 14px;
    line-height: 1.8;
    font-weight: 400;
    text-align: center;
  }

  .cta-buttons-group{
    display: flex;
    flex-direction: column;
    gap: 14px;
    align-items: stretch;
  }

  .btn-cta-gold,
  .btn-cta-outline{
    width: 100%;
    min-height: 52px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 15px;
    font-weight: 700;
    text-decoration: none;
  }

  .btn-cta-gold{
    background: #C9A24D;
    color: #0F3D3A;
    border: none;
    box-shadow: 0 14px 28px rgba(201, 162, 77, 0.22);
  }

  .btn-cta-outline{
    background: rgba(255,255,255,0.04);
    color: #ffffff;
    border: 2px solid rgba(255,255,255,0.92);
    backdrop-filter: blur(2px);
  }

  .btn-cta-gold:hover,
  .btn-cta-outline:hover{
    transform: none;
  }
}

/* =========================================
   SECTION KONTAK MOBILE
   REFERENSI LAYOUT DESKTOP
   ========================================= */
@media screen and (max-width: 480px){

  .sect-contact{
    padding: 42px 14px 34px;
    background: #f8f5ee;
  }

  .container-contact{
    width: 100%;
    max-width: 100%;
  }

  .header-contact{
    text-align: center;
    margin: 0 auto 22px;
  }

  .header-contact .top-label-gold,
  .top-label-contact{
    display: block;
    margin-bottom: 8px;
    color: #C9A24D;
    font-size: 10px;
    line-height: 1.5;
    letter-spacing: 2.2px;
    font-weight: 700;
    text-transform: uppercase;
  }

  .section-title-contact,
  .header-contact h2{
    margin: 0;
    color: #0F3D3A;
    font-size: 30px;
    line-height: 1.08;
    font-weight: 800;
  }

  .header-contact .title-line{
    width: 40px;
    height: 3px;
    margin: 12px auto 0;
    border-radius: 999px;
    background: #C9A24D;
  }

  /* wrapper utama jadi 1 kolom */
  .contact-content,
  .contact-grid,
  .contact-wrapper{
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  /* =========================
     MAP
     ========================= */
  .contact-map,
  .map-wrapper,
  .contact-map-wrapper{
    width: 100%;
    border-radius: 22px;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid rgba(15,61,58,0.08);
    box-shadow: 0 12px 26px rgba(15,61,58,0.08);
  }

  .contact-map iframe,
  .map-wrapper iframe,
  .contact-map-wrapper iframe{
    width: 100%;
    height: 230px;
    display: block;
    border: 0;
  }

  /* kalau map pakai embed div internal */
  .contact-map .gmap_canvas,
  .map-wrapper .gmap_canvas,
  .contact-map-wrapper .gmap_canvas,
  .contact-map .mapouter,
  .map-wrapper .mapouter,
  .contact-map-wrapper .mapouter{
    width: 100% !important;
    height: 230px !important;
  }

  /* =========================
     INFO KONTAK
     ========================= */
  .contact-info,
  .contact-details,
  .contact-right{
    display: flex;
    flex-direction: column;
    gap: 0;
    background: transparent;
  }

  .contact-item,
  .info-item,
  .contact-card{
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 16px 0;
    border-bottom: 1px solid rgba(15,61,58,0.08);
    background: transparent;
    box-shadow: none;
    border-radius: 0;
  }

  .contact-item:first-child,
  .info-item:first-child,
  .contact-card:first-child{
    padding-top: 0;
  }

  .contact-item:last-child,
  .info-item:last-child,
  .contact-card:last-child{
    border-bottom: 0;
    padding-bottom: 0;
  }

  .contact-icon,
  .info-icon{
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    border-radius: 50%;
    background: #0F3D3A;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    box-shadow: none;
  }

  .contact-text,
  .info-text{
    flex: 1;
    text-align: left;
  }

  .contact-text h3,
  .info-text h3,
  .contact-item h3,
  .contact-card h3{
    margin: 0 0 4px;
    color: #0F3D3A;
    font-size: 16px;
    line-height: 1.35;
    font-weight: 800;
  }

  .contact-text p,
  .info-text p,
  .contact-item p,
  .contact-card p{
    margin: 0;
    color: #6b7b73;
    font-size: 13px;
    line-height: 1.7;
  }

  .contact-text strong,
  .info-text strong{
    color: #0F3D3A;
  }

  .contact-link-map,
  .contact-text a[href*="maps"],
  .info-text a[href*="maps"]{
    display: inline-block;
    margin-top: 8px;
    color: #C9A24D;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
  }

  .contact-link-map:hover,
  .contact-text a[href*="maps"]:hover,
  .info-text a[href*="maps"]:hover{
    color: #C9A24D;
  }

  /* =========================
     SOCIAL BUTTONS
     ========================= */
  .contact-socials,
  .social-contact,
  .contact-buttons{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 16px;
  }

  .contact-socials a,
  .social-contact a,
  .contact-buttons a,
  .btn-instagram,
  .btn-tiktok{
    min-height: 48px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    padding: 0 12px;
  }

  .btn-instagram,
  .contact-socials a[href*="instagram"],
  .social-contact a[href*="instagram"],
  .contact-buttons a[href*="instagram"]{
    background: #C9A24D;
    color: #0F3D3A;
    border: none;
    box-shadow: 0 12px 22px rgba(201, 162, 77, 0.18);
  }

  .btn-tiktok,
  .contact-socials a[href*="tiktok"],
  .social-contact a[href*="tiktok"],
  .contact-buttons a[href*="tiktok"]{
    background: #0F3D3A;
    color: #ffffff;
    border: none;
    box-shadow: 0 12px 22px rgba(15,61,58,0.16);
  }

  /* no hover shift di mobile */
  .btn-instagram:hover,
  .btn-tiktok:hover,
  .contact-socials a:hover,
  .social-contact a:hover,
  .contact-buttons a:hover{
    transform: none;
  }
}

/* =========================================
   FOOTER MOBILE - FIX ORANGE BAND
   ========================================= */
@media screen and (max-width: 768px){

  /* wrapper luar */
  .sect-footer,
  .site-footer,
  .sect-footer-wrapper,
  footer{
    position: relative;
    padding: 0 !important;
    margin-top: 18px !important;
    background: #0F3D3A !important;
    overflow: hidden;
  }

  /* garis hijau atas */
  .sect-footer::before,
  .site-footer::before,
  .sect-footer-wrapper::before,
  footer::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 6px;
    background: #0F3D3A;
    z-index: 2;
  }

  /* layer emas luar */
  .footer-gold-layer{
    position: relative;
    z-index: 3;
    margin-top: 6px !important;
    padding: 0 !important;
    background: #C9A24D !important;
    border-top-left-radius: 34px;
    border-top-right-radius: 34px;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    box-shadow: none !important;
  }

  /* panel isi footer */
  .footer-container,
  .container-footer,
  .footer-inner{
    position: relative;
    z-index: 4;
    margin-top: 0 !important;
    padding: 40px 12px 5px !important;
    background: #C9A24D !important;
    border-top-left-radius: 34px;
    border-top-right-radius: 34px;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    box-shadow: none !important;
  }

  /* layout */
  .footer-grid,
  .footer-content,
  .footer-columns{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px;
  }

  /* logo */
  .footer-logo-box,
  .footer-brand-card,
  .footer-logo-wrap,
  .logo-box{
    width: 200px;
    height: 200px;
    padding: 8px;
    border-radius: 40px;
    margin-bottom: 12px;
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .footer-logo-box img,
  .footer-brand-card img,
  .footer-logo-wrap img,
  .logo-box img{
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    transform: scale(1.2);
  }

  /* desc */
  .footer-brand p,
  .footer-about p,
  .footer-desc,
  .brand-desc{
    font-size: 10px;
    line-height: 1.45;
    margin-bottom: 10px;
    color: #0F3D3A;
  }

  /* social */
  .footer-socials,
  .footer-social-icons,
  .social-footer,
  .social-buttons-box{
    display: flex;
    gap: 8px;
  }

  .footer-socials a,
  .footer-social-icons a,
  .social-footer a,
  .soc-btn{
    width: 28px;
    height: 28px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
  }

  .footer-socials a img,
  .footer-social-icons a img,
  .social-footer a img,
  .soc-btn img{
    width: 14px;
    height: 14px;
    object-fit: contain;
    display: block;
  }

  /* title */
  .col-title,
  .footer-title,
  .footer-heading{
    font-size: 13px;
    margin-bottom: 8px;
    color: #0F3D3A;
  }

  /* list */
  .footer-list li,
  .footer-links li{
    margin-bottom: 6px;
  }

  .footer-list a,
  .footer-links a{
    font-size: 10px;
    gap: 8px;
    color: #0F3D3A;
    text-decoration: none;
  }

  .footer-list img,
  .footer-links img{
    width: 14px;
    height: 14px;
    object-fit: contain;
  }

  /* contact */
  .contact-list li,
  .footer-contact li{
    display: grid !important;
    grid-template-columns: 14px 1fr;
    gap: 8px;
    align-items: start;
    font-size: 10px;
    margin-bottom: 8px;
    line-height: 1.4;
  }

  .contact-list .contact-icon,
  .footer-contact .contact-icon{
    width: 14px;
    height: 14px;
    margin-top: 1px;
    object-fit: contain;
    display: block;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
  }

  /* copyright */
  .footer-bottom,
  .footer-copyright,
  .copyright-footer{
    margin-top: 8px !important;
    padding-top: 8px !important;
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
    border-top: 1px solid rgba(15,61,58,0.18);
    text-align: center;
  }

  .footer-bottom p,
  .footer-copyright p,
  .copyright-footer p,
  .footer-bottom a,
  .footer-copyright a,
  .copyright-footer a{
    font-size: 9px;
    line-height: 1.4;
    color: rgba(15,61,58,0.62);
    text-decoration: none;
    margin: 0 !important;
  }
}


@media screen and (max-width: 768px){
  .contact-list .contact-icon{
    width: 20px !important;
    height: 20px !important;
    flex: 0 0 20px !important;
    display: block !important;
    object-fit: contain !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin-top: 3px !important;
  }
}
@media screen and (max-width: 480px){

  .sect-services{
    background: #fbfbfb !important;
  }

  .sect-products{
    background: #fbfbfb !important;
  }

  .sect-products::before{
    background: linear-gradient(
      180deg,
      #fbfbfb 0%,
      #ffffff 100%
    ) !important;
  }

  .sect-products::after{
    background: none !important;
  }

}

@media screen and (max-width: 480px){

  /* bikin section putih clean */
  .sect-services,
  .sect-products{
    background: #ffffff !important;
  }

  /* hilangkan layer/gradasi yang bikin ada warna lain */
  .sect-services::before,
  .sect-services::after,
  .sect-products::before,
  .sect-products::after{
    background: none !important;
  }

  /* heading tetap kontras */
  .top-label-gold{
    color:#C9A24D !important;
  }

  .section-title-services,
  .section-title-products{
    color: #0F3D3A !important;
  }
}
@media screen and (max-width: 480px){

  /* badge diskon sama seperti desktop */
  .discount-tag{
    background: #ff4d4d !important;
    color: #ffffff !important;
  }

  /* tombol/teks lihat selengkapnya sama seperti desktop */
  .btn-see-more-dark{
    background: #0F3D3A !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
  }

  .btn-see-more-dark:hover,
  .btn-see-more-dark:focus,
  .btn-see-more-dark:active{
    background: #0F3D3A !important;
    color: #ffffff !important;
  }
} 

@media (max-width: 768px) {
    .logo-nav {
        margin-left: -33px !important;
    }
}


/* =========================
   IPAD / TABLET OVERRIDE
   tetap ngikut desktop, ukuran dipaskan
   ========================= */
@media screen and (min-width: 768px) and (max-width: 1024px) {
  body {
    overflow-x: hidden;
  }

  /* NAVBAR */
  nav {
    height: 68px !important;
    padding: 0 20px !important;
    gap: 14px !important;
    justify-content: space-between !important;
  }

  .logo-nav {
    margin-left: 0 !important;
    flex: 0 0 auto !important;
  }

  .logo-nav img {
    height: 118px !important;
    width: auto !important;
  }

  .menu-toggle,
  .nav-konsultasi-mobile {
    display: none !important;
  }

  .desktop-konsultasi {
    display: inline-flex !important;
    padding: 10px 16px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
    flex: 0 0 auto !important;
    gap: 6px !important;
  }

  .nav-links {
    position: static !important;
    inset: auto !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    flex: 1 1 auto !important;
    margin: 0 8px !important;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  .nav-links li {
    width: auto !important;
    border-bottom: none !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .nav-links li a {
    display: inline-flex !important;
    align-items: center !important;
    padding: 0 !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
  }

  /* HERO */
  .sect-hero {
    min-height: 100vh !important;
    height: auto !important;
    padding: 118px 32px 82px !important;
    align-items: center !important;
  }

  .hero-container {
    width: 100% !important;
    max-width: 760px !important;
    padding-top: 0 !important;
  }

  .hero-logo-center {
    width: 104px !important;
    transform: scale(1.45) !important;
    margin-bottom: 6px !important;
  }

  .hero-container .title-white,
  .title-white {
    font-size: 50px !important;
    line-height: 1.08 !important;
  }

  .hero-container .title-gold,
  .title-gold {
    font-size: 44px !important;
    line-height: 1.1 !important;
    margin-top: -4px !important;
  }

  .hero-desc {
    max-width: 670px !important;
    margin: 20px auto 34px !important;
    font-size: 15px !important;
  }

  .cta-group {
    gap: 14px !important;
    margin-bottom: 42px !important;
    flex-wrap: wrap !important;
  }

  .btn-main {
    padding: 14px 24px !important;
    font-size: 14px !important;
  }

  .stats-grid {
    max-width: 720px !important;
    margin: 0 auto !important;
    gap: 18px !important;
    padding-top: 24px !important;
  }

  .stat-item h3 {
    font-size: 34px !important;
  }

  .stat-item p {
    font-size: 13px !important;
  }

  /* GENERAL SECTION SPACING */
  .sect-about,
  .sect-services,
  .sect-products,
  .sect-experts,
  .sect-contact-final {
    padding-left: 32px !important;
    padding-right: 32px !important;
  }

  .sect-about {
    padding-top: 72px !important;
    padding-bottom: 72px !important;
    background: #ffffff !important;
  }

  .sect-services,
  .sect-products,
  .sect-experts,
  .sect-contact-final {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  .section-title,
  .section-title-services,
  .section-title-products,
  .section-title-experts,
  .main-title {
    font-size: 34px !important;
    line-height: 1.2 !important;
  }

  /* ABOUT */
  .container-about {
    display: flex !important;
    flex-direction: row !important;
    gap: 34px !important;
    align-items: center !important;
  }

  .about-content {
    width: auto !important;
    flex: 1.05 !important;
    order: 0 !important;
    text-align: left !important;
  }

  .about-visual {
    display: flex !important;
    flex: 0.95 !important;
    justify-content: center !important;
  }

  .intro-text {
    font-size: 15px !important;
    margin-bottom: 24px !important;
  }

  .vm-card {
    padding: 24px !important;
    margin-bottom: 28px !important;
  }

  .vm-block p,
  .vm-block li {
    font-size: 13px !important;
  }

  .features-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
    margin-bottom: 28px !important;
  }

  .feat-card {
    gap: 12px !important;
    align-items: flex-start !important;
  }

  .icon-box {
    width: 48px !important;
    height: 48px !important;
    flex: 0 0 48px !important;
  }

  .icon-box img {
    width: 22px !important;
    height: 22px !important;
  }

  .feat-info strong {
    font-size: 14px !important;
  }

  .feat-info p {
    font-size: 12px !important;
  }

  .photo-frame {
    max-width: 340px !important;
    height: 470px !important;
    border-radius: 220px 220px 46px 46px !important;
  }

  .halal-tag {
    width: fit-content !important;
    margin: 24px 0 0 !important;
    padding: 10px 22px !important;
    gap: 12px !important;
  }

  .halal-icon-img {
    width: 28px !important;
    height: auto !important;
  }

  .halal-tag span {
    font-size: 13px !important;
  }

  /* SERVICES / PRODUCTS / EXPERT */
  .services-grid,
  .products-grid {
    gap: 20px !important;
  }

  .service-img-wrapper {
    height: 210px !important;
  }

  .product-img-wrapper {
    height: 250px !important;
  }

  .discount-tag {
    top: 12px !important;
    right: 12px !important;
    left: auto !important;
  }

  .expert-card {
    width: 420px !important;
    max-width: calc(50% - 16px) !important;
    padding: 44px 20px !important;
    border-radius: 28px !important;
  }

  .expert-img-container {
    width: 190px !important;
    height: 190px !important;
    margin-bottom: 24px !important;
  }

  .expert-info h3 {
    font-size: 22px !important;
  }

  .expert-info p {
    font-size: 16px !important;
  }

  /* CTA */
  .sect-cta {
    padding: 90px 32px 100px !important;
    background-attachment: scroll !important;
  }

  .cta-content {
    max-width: 760px !important;
  }

  .cta-title {
    font-size: 40px !important;
    margin-bottom: 16px !important;
  }

  .cta-desc {
    max-width: 650px !important;
    margin-bottom: 28px !important;
    font-size: 16px !important;
  }

  .cta-buttons-group {
    flex-direction: row !important;
    justify-content: center !important;
    gap: 14px !important;
  }

  .btn-cta-gold,
  .btn-cta-outline {
    width: auto !important;
    min-width: 220px !important;
    min-height: 50px !important;
    padding: 0 22px !important;
  }

  /* CONTACT */
  .container {
    max-width: 1000px !important;
  }

  .contact-content {
    grid-template-columns: 1.05fr 0.95fr !important;
    gap: 28px !important;
  }

  .map-container iframe {
    height: 380px !important;
  }

  .info-container {
    gap: 26px !important;
  }

  .info-item {
    gap: 14px !important;
  }

  .icon-circle {
    width: 44px !important;
    height: 44px !important;
    font-size: 17px !important;
  }

  .icon-maps {
    width: 190px !important;
    height: 44px !important;
  }

  .info-text h3 {
    font-size: 20px !important;
  }

  .info-text p {
    font-size: 14px !important;
  }

  .social-buttons {
    flex-direction: row !important;
    gap: 12px !important;
  }

  .btn-sosmed {
    padding: 13px 14px !important;
    font-size: 15px !important;
  }

  /* FOOTER */
  .sect-footer-wrapper,
  footer {
    margin-top: 56px !important;
    background: #0F3D3A !important;
    padding: 0 !important;
  }

  .sect-footer-wrapper::before,
  footer::before {
    display: none !important;
  }

  .footer-gold-layer {
    margin-top: 0 !important;
    padding: 56px 32px 28px !important;
    background: #C9A24D !important;
    border-radius: 40px 40px 0 0 !important;
    box-shadow: none !important;
  }

  .footer-container {
    max-width: 1000px !important;
    padding: 0 !important;
    margin: 0 auto !important;
    background: transparent !important;
  }

  .footer-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 26px !important;
    align-items: start !important;
  }

  .logo-box {
    width: 180px !important;
    height: 180px !important;
    padding: 12px !important;
    border-radius: 30px !important;
    margin-bottom: 18px !important;
  }

  .logo-box img {
    transform: scale(1.6) !important;
  }

  .brand-desc {
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: #0F3D3A !important;
  }

  .social-buttons-box {
    gap: 12px !important;
  }

  .soc-btn {
    width: 40px !important;
    height: 40px !important;
    border-radius: 12px !important;
    background: rgba(255, 255, 255, 0.28) !important;
  }

  .soc-btn img {
    width: 20px !important;
    height: 20px !important;
  }

  .col-title {
    font-size: 18px !important;
    margin-bottom: 18px !important;
    color: #0F3D3A !important;
  }

  .footer-list a,
  .contact-list li {
    font-size: 13px !important;
  }

  .footer-list img,
  .contact-icon {
    width: 18px !important;
    height: 18px !important;
  }

  .footer-copyright {
    grid-column: 1 / -1 !important;
    margin-top: 0 !important;
    padding-top: 18px !important;
    padding-bottom: 0 !important;
  }
}

  @media screen and (max-width: 480px){

  .shop-buttons a.disabled{
    opacity: 0.35 !important;
    filter: grayscale(100%) !important;
    background: #9ca3af !important;
    color: #ffffff !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
    box-shadow: none !important;
    border: none !important;
  }

  .shop-buttons a.disabled:hover{
    transform: none !important;
  }

}
