/* CSPLUS v2.10.89 — Fixed Public Header + CMS Drawer Safe Layout */
:root{
  --cs-header-h:78px;
}
.site-header{
  position:fixed!important;
  top:0!important;
  left:0!important;
  right:0!important;
  width:100%!important;
  z-index:240!important;
  transform:none!important;
  will-change:auto!important;
  background:rgba(255,255,255,.96)!important;
  backdrop-filter:blur(18px)!important;
  -webkit-backdrop-filter:blur(18px)!important;
  border-bottom:1px solid rgba(226,232,240,.95)!important;
  box-shadow:0 10px 28px rgba(15,23,42,.08)!important;
}
.page-main{
  padding-top:var(--cs-header-h)!important;
}
.mobile-drawer-overlay{
  z-index:250!important;
}
.mobile-drawer{
  position:fixed!important;
  top:0!important;
  right:0!important;
  z-index:260!important;
  overflow-y:auto!important;
  overscroll-behavior:contain;
  max-height:100dvh!important;
}
.mobile-drawer-nav{
  max-height:none!important;
}
.mobile-drawer-nav a{
  text-decoration:none!important;
}
body.mobile-menu-open{
  overflow:hidden!important;
}
@media(min-width:861px){
  :root{--cs-header-h:78px}
  .desktop-nav{
    flex-wrap:wrap!important;
    justify-content:flex-end!important;
    max-width:720px!important;
    gap:5px!important;
  }
  .desktop-nav a{
    font-size:13px!important;
    padding:9px 10px!important;
  }
  .site-header{
    align-items:center!important;
  }
}
@media(max-width:860px){
  :root{--cs-header-h:78px}
  .site-header{
    min-height:78px!important;
    height:78px!important;
    padding:12px 16px!important;
  }
  .page-main{
    padding-top:78px!important;
  }
  .mobile-drawer-nav{
    display:grid!important;
    gap:8px!important;
    padding-bottom:6px!important;
  }
  .mobile-drawer-nav a{
    min-height:50px!important;
    border-radius:17px!important;
  }
  .hero-ads,
  .jualhp-hero,
  .service-hero{
    padding-top:22px!important;
  }
}
@media(max-width:380px){
  .brand-logo{
    width:48px!important;
    height:48px!important;
  }
  .brand b{
    font-size:19px!important;
  }
  .brand small{
    font-size:13px!important;
  }
}


/* Mobile drawer source cleanup: dedicated overlay state, no floating collision */
@media(max-width:860px){
  .mobile-drawer{
    height:100dvh!important;
    max-height:100dvh!important;
    overflow:hidden!important;
    display:flex!important;
    flex-direction:column!important;
    padding-bottom:calc(18px + env(safe-area-inset-bottom,0px))!important;
  }
  .mobile-drawer-head{flex:0 0 auto!important}
  .mobile-drawer-nav{
    flex:1 1 auto!important;
    min-height:0!important;
    overflow-y:auto!important;
    overscroll-behavior:contain!important;
    -webkit-overflow-scrolling:touch!important;
    padding:2px 3px 14px 0!important;
    margin-bottom:4px!important;
  }
  .mobile-drawer-nav a{
    min-height:54px!important;
    padding:13px 15px!important;
    border-radius:18px!important;
  }
  .mobile-drawer-cta{
    flex:0 0 auto!important;
    margin-top:0!important;
    border-radius:22px!important;
    padding:15px!important;
  }
  body.mobile-menu-open .bottom-nav,
  body.mobile-menu-open #csplusLiveChatButton,
  body.mobile-menu-open #csplusWaButton{
    opacity:0!important;
    visibility:hidden!important;
    pointer-events:none!important;
    transform:translateY(14px)!important;
  }
  .bottom-nav,#csplusLiveChatButton,#csplusWaButton{
    transition:opacity .16s ease, transform .16s ease, visibility .16s ease!important;
  }
}
