/* CSPLUS v2.4.5 — Global UI/UX Premium Polish + Mobile Menu */
:root{
  --uip-ink:#0b1220;
  --uip-muted:#64748b;
  --uip-line:#e2e8f0;
  --uip-soft:#f8fafc;
  --uip-blue:#2563eb;
  --uip-green:#16a34a;
  --uip-shadow:0 18px 48px rgba(15,23,42,.10);
}
html{scroll-behavior:smooth}
body{
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
}
.site-header{
  z-index:80!important;
}
.mobile-menu-toggle{
  display:none;
  border:0;
  background:#0b1220;
  color:#fff;
  width:48px;
  height:48px;
  border-radius:18px;
  align-items:center;
  justify-content:center;
  box-shadow:0 14px 30px rgba(15,23,42,.14);
  cursor:pointer;
}
.mobile-menu-toggle span,
.mobile-menu-toggle span:before,
.mobile-menu-toggle span:after{
  content:"";
  display:block;
  width:20px;
  height:2px;
  border-radius:99px;
  background:#fff;
  transition:.18s ease;
}
.mobile-menu-toggle span{
  position:relative;
}
.mobile-menu-toggle span:before{
  position:absolute;
  transform:translateY(-7px);
}
.mobile-menu-toggle span:after{
  position:absolute;
  transform:translateY(7px);
}
body.mobile-menu-open .mobile-menu-toggle span{
  background:transparent;
}
body.mobile-menu-open .mobile-menu-toggle span:before{
  transform:rotate(45deg);
}
body.mobile-menu-open .mobile-menu-toggle span:after{
  transform:rotate(-45deg);
}
.mobile-drawer-overlay{
  position:fixed;
  inset:0;
  z-index:85;
  background:rgba(2,6,23,.42);
  opacity:0;
  pointer-events:none;
  transition:.2s ease;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}
.mobile-drawer{
  position:fixed;
  z-index:90;
  top:0;
  right:0;
  width:min(365px,calc(100vw - 34px));
  height:100dvh;
  padding:calc(env(safe-area-inset-top,0px) + 18px) 18px calc(env(safe-area-inset-bottom,0px) + 24px);
  background:linear-gradient(180deg,#ffffff,#f8fbff);
  border-left:1px solid rgba(226,232,240,.9);
  box-shadow:-24px 0 70px rgba(15,23,42,.20);
  transform:translateX(108%);
  transition:.24s cubic-bezier(.2,.8,.2,1);
  display:flex;
  flex-direction:column;
  gap:14px;
}
body.mobile-menu-open .mobile-drawer-overlay{
  opacity:1;
  pointer-events:auto;
}
body.mobile-menu-open .mobile-drawer{
  transform:translateX(0);
}
.mobile-drawer-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:2px 0 8px;
}
.mobile-drawer-brand{
  display:flex;
  align-items:center;
  gap:10px;
}
.mobile-drawer-brand b{
  display:block;
  font-size:18px;
  letter-spacing:-.025em;
}
.mobile-drawer-brand small{
  display:block;
  color:#64748b;
  font-weight:700;
}
.mobile-drawer-logo{
  width:44px;
  height:44px;
  border-radius:16px;
  background:#0b1220;
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:1000;
}
.mobile-drawer-close{
  border:0;
  width:42px;
  height:42px;
  border-radius:15px;
  background:#eef2f7;
  color:#0b1220;
  font-size:25px;
  line-height:1;
}
.mobile-drawer-nav{
  display:grid;
  gap:9px;
}
.mobile-drawer-nav a{
  min-height:54px;
  border-radius:18px;
  border:1px solid #e2e8f0;
  background:#fff;
  padding:13px 14px;
  color:#0b1220;
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-weight:900;
  box-shadow:0 10px 24px rgba(15,23,42,.045);
}
.mobile-drawer-nav a.active{
  background:#0b1220;
  color:#fff;
  border-color:#0b1220;
}
.mobile-drawer-nav a span{
  color:#94a3b8;
  font-weight:1000;
}
.mobile-drawer-cta{
  margin-top:auto;
  border-radius:24px;
  padding:16px;
  background:linear-gradient(135deg,#0b1220,#14532d);
  color:#fff;
}
.mobile-drawer-cta b{
  display:block;
  font-size:18px;
  margin-bottom:6px;
}
.mobile-drawer-cta p{
  margin:0 0 12px;
  color:#dbeafe;
  font-size:13px;
  line-height:1.45;
}
.mobile-drawer-cta a{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  border-radius:16px;
  background:#fff;
  color:#0b1220;
  font-weight:1000;
}

/* Premium global cards/forms */
.product-card,
.panel,
.stat-card,
.install-card,
.jualhp-form-card,
.service-form-card,
.key-card,
.value-card,
.safe-card,
.main-device-card,
.home-service-focus-card,
.faq-list details{
  border-color:rgba(226,232,240,.95)!important;
}
input,select,textarea{
  font-size:16px!important;
}
button,.btn,.cta,.home-slide-card,.product-card,a{
  -webkit-tap-highlight-color:transparent;
}

/* Mobile first polish */
@media(max-width:860px){
  body{
    background:#f8fbff!important;
    padding-bottom:calc(92px + env(safe-area-inset-bottom,0px));
  }
  .site-header{
    min-height:76px!important;
    padding:12px 16px!important;
    background:rgba(255,255,255,.94)!important;
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(226,232,240,.92)!important;
    box-shadow:0 8px 28px rgba(15,23,42,.055)!important;
  }
  .brand{
    min-width:0;
    gap:11px!important;
  }
  .brand-logo{
    width:52px!important;
    height:52px!important;
    border-radius:19px!important;
    font-size:18px!important;
    box-shadow:0 14px 28px rgba(15,23,42,.14)!important;
  }
  .brand span:last-child{
    min-width:0;
  }
  .brand b{
    font-size:21px!important;
    letter-spacing:-.035em!important;
    line-height:1.05!important;
  }
  .brand small{
    font-size:14px!important;
    color:#64748b!important;
    font-weight:700!important;
    line-height:1.1!important;
  }
  .desktop-nav{
    display:none!important;
  }
  .mobile-menu-toggle{
    display:flex;
  }

  .home-wrap,
  .jualhp-wrap,
  .service-wrap{
    width:calc(100% - 24px)!important;
  }
  .hero-ads,
  .jualhp-hero,
  .service-hero{
    padding-top:24px!important;
  }
  .hero-title,
  .jualhp-title,
  .service-title{
    font-size:clamp(36px,11vw,46px)!important;
    line-height:1!important;
    letter-spacing:-.065em!important;
  }
  .hero-sub,
  .jualhp-sub,
  .service-sub{
    font-size:16px!important;
    line-height:1.6!important;
  }
  .hero-actions,
  .jualhp-cta-row,
  .service-cta-row{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  .cta,
  .jualhp-cta,
  .service-cta{
    width:100%!important;
    border-radius:18px!important;
    min-height:54px!important;
    box-shadow:0 14px 28px rgba(15,23,42,.09)!important;
  }
  .promo-pill,
  .jualhp-pill,
  .service-pill{
    max-width:100%;
    font-size:12.5px!important;
    white-space:normal!important;
  }

  .trust-row,
  .jualhp-trust,
  .service-trust{
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  .trust-item,
  .jualhp-trust-card,
  .service-trust-card{
    border-radius:22px!important;
    padding:14px!important;
  }

  .home-slider-intro .home-wrap h2{
    font-size:29px!important;
  }
  .home-click-slider{
    margin-top:10px!important;
  }
  .home-slider-track{
    padding:4px 12px 14px!important;
    gap:12px!important;
    scroll-padding-left:12px!important;
  }
  .home-slide-card{
    min-width:84%!important;
    min-height:210px!important;
    border-radius:28px!important;
    padding:19px!important;
  }
  .home-slide-card h3{
    font-size:24px!important;
    max-width:90%!important;
  }
  .home-slide-card p{
    font-size:14px!important;
    line-height:1.48!important;
    max-width:95%!important;
  }
  .home-slide-icon{
    width:48px!important;
    height:48px!important;
    border-radius:18px!important;
  }
  .home-slide-cta{
    max-width:max-content!important;
    min-width:0!important;
    padding:10px 13px!important;
    font-size:12.5px!important;
  }

  .section-pad,
  .jualhp-section,
  .service-section{
    padding:30px 0!important;
  }
  .section-title{
    text-align:left!important;
    margin-bottom:16px!important;
  }
  .section-title h2{
    font-size:30px!important;
    line-height:1.08!important;
  }
  .section-title p{
    font-size:15px!important;
  }

  .value-grid,
  .key-grid,
  .main-device-grid,
  .home-service-focus-grid,
  .issue-grid,
  .flow-grid,
  .safe-box{
    grid-template-columns:1fr!important;
    gap:12px!important;
  }
  .value-card,
  .key-card,
  .main-device-card,
  .home-service-focus-card,
  .issue-card,
  .flow-step,
  .safe-card{
    border-radius:26px!important;
    padding:18px!important;
    box-shadow:0 14px 36px rgba(15,23,42,.06)!important;
  }
  .value-card,
  .key-card{
    text-align:left!important;
  }
  .value-icon,
  .key-icon,
  .main-device-icon,
  .home-service-focus-icon{
    margin-left:0!important;
  }

  .jualhp-form-card,
  .service-form-card{
    border-radius:28px!important;
    padding:18px!important;
    box-shadow:0 18px 44px rgba(15,23,42,.08)!important;
  }
  .jualhp-form,
  .service-form{
    grid-template-columns:1fr!important;
    gap:13px!important;
  }
  .jualhp-form input,
  .jualhp-form select,
  .jualhp-form textarea,
  .service-form input,
  .service-form select,
  .service-form textarea,
  input,select,textarea{
    min-height:56px!important;
    border-radius:18px!important;
  }
  .form-note{
    border-radius:18px!important;
  }

  .product-grid{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:14px!important;
    padding:0 12px!important;
  }
  .product-card{
    border-radius:28px!important;
    overflow:hidden!important;
    box-shadow:0 16px 44px rgba(15,23,42,.075)!important;
  }
  .product-image,
  .product-thumb{
    border-radius:0!important;
    min-height:auto!important;
  }
  .detail-grid,
  .product-detail-grid{
    grid-template-columns:1fr!important;
    gap:14px!important;
    padding:0 12px!important;
  }

  .bottom-nav{
    position:fixed!important;
    left:0!important;
    right:0!important;
    bottom:0!important;
    z-index:75!important;
    padding:10px 10px calc(10px + env(safe-area-inset-bottom,0px))!important;
    min-height:74px!important;
    background:rgba(255,255,255,.96)!important;
    backdrop-filter:blur(18px)!important;
    -webkit-backdrop-filter:blur(18px)!important;
    border-top:1px solid rgba(226,232,240,.96)!important;
    box-shadow:0 -12px 32px rgba(15,23,42,.08)!important;
    gap:4px!important;
  }
  .bottom-nav a{
    min-height:46px!important;
    border-radius:18px!important;
    font-size:13px!important;
    font-weight:950!important;
    color:#475569!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    padding:0 10px!important;
  }
  .bottom-nav a.active{
    background:#0b1220!important;
    color:#fff!important;
    box-shadow:0 10px 24px rgba(15,23,42,.13)!important;
  }

  .live-chat-button,
}

/* Desktop premium refinements */
@media(min-width:861px){
  .mobile-drawer,
  .mobile-drawer-overlay,
  .mobile-menu-toggle{
    display:none!important;
  }
  .home-slider-track{
    align-items:stretch!important;
  }
  .home-slide-card{
    min-height:238px!important;
  }
  .hero-title,
  .jualhp-title,
  .service-title{
    text-wrap:balance;
  }
  .product-card,
  .home-slide-card,
  .value-card,
  .key-card,
  .main-device-card,
  .home-service-focus-card{
    will-change:transform;
  }
}


/* CSPLUS v2.4.7 fixed header safety */
.site-header{position:fixed!important;top:0!important;left:0!important;right:0!important;z-index:240!important}
.page-main{padding-top:78px!important}
@media(max-width:860px){.site-header{position:fixed!important}.page-main{padding-top:78px!important}}
