/* H5 repair for pages/operator/index. Keep this scoped to the operator page. */
.operator-page,
.operator-page * {
  box-sizing: border-box !important;
}

.operator-page {
  width: 100% !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
  overflow-x: hidden !important;
  background: linear-gradient(180deg, #edf6ff 0%, #f7fbff 38%, #ffffff 100%) !important;
}

.operator-page .operator-shell {
  width: 100% !important;
  max-width: 430px !important;
  margin: 0 auto !important;
  padding: 18px 16px calc(128px + env(safe-area-inset-bottom)) !important;
}

.operator-page .hero {
  min-height: 168px !important;
  padding-top: 5px !important;
  overflow: hidden !important;
}

.operator-page .trust {
  max-width: calc(100vw - 32px) !important;
  height: 29px !important;
  gap: 5px !important;
  padding: 0 11px !important;
  border-width: 1px !important;
  border-radius: 16px !important;
  font-size: 13px !important;
  line-height: 29px !important;
  white-space: nowrap !important;
}

.operator-page .shield {
  flex: 0 0 16px !important;
  width: 16px !important;
  height: 16px !important;
  border-radius: 5px !important;
  font-size: 12px !important;
  line-height: 16px !important;
}

.operator-page .hero-copy {
  margin-top: 19px !important;
  padding-right: 124px !important;
}

.operator-page .headline {
  font-size: 27px !important;
  line-height: 34px !important;
  letter-spacing: 0 !important;
}

.operator-page .subline {
  margin-top: 13px !important;
  font-size: 14px !important;
  line-height: 20px !important;
  white-space: nowrap !important;
}

.operator-page .progress-entry {
  width: 150px !important;
  height: 34px !important;
  margin-top: 14px !important;
  padding: 0 12px !important;
  border-width: 1px !important;
  border-radius: 18px !important;
  font-size: 13px !important;
}

.operator-page .progress-entry text:last-child {
  font-size: 22px !important;
  line-height: 22px !important;
}

.operator-page .hero-visual {
  right: 0 !important;
  top: 46px !important;
  width: 140px !important;
  height: 125px !important;
  pointer-events: none !important;
}

.operator-page .sim-card {
  right: 23px !important;
  top: 6px !important;
  width: 63px !important;
  height: 86px !important;
  border-width: 1px !important;
  border-radius: 14px !important;
}

.operator-page .sim-card text {
  top: 19px !important;
  left: 14px !important;
  font-size: 13px !important;
}

.operator-page .signal {
  left: 17px !important;
  bottom: 21px !important;
  width: 29px !important;
  height: 20px !important;
  border-top-width: 5px !important;
}

.operator-page .halo.one {
  bottom: 20px !important;
  width: 115px !important;
  height: 36px !important;
}

.operator-page .halo.two {
  right: 41px !important;
  top: 56px !important;
  width: 36px !important;
  height: 36px !important;
}

.operator-page .business-card {
  min-height: 230px !important;
  margin-top: 14px !important;
  padding: 24px 18px !important;
  border-width: 1px !important;
  border-radius: 17px !important;
  overflow: hidden !important;
}

.operator-page .business-card.sim {
  margin-bottom: 16px !important;
}

.operator-page .card-copy {
  width: 58% !important;
  min-width: 0 !important;
}

.operator-page .card-title {
  font-size: 25px !important;
  line-height: 31px !important;
}

.operator-page .card-desc {
  margin-top: 8px !important;
  font-size: 13px !important;
  line-height: 19px !important;
}

.operator-page .features {
  flex-wrap: nowrap !important;
  gap: 14px !important;
  margin-top: 25px !important;
}

.operator-page .feature {
  flex: 0 0 auto !important;
  gap: 6px !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
}

.operator-page .feature-icon {
  width: 23px !important;
  height: 23px !important;
  border-radius: 8px !important;
  font-size: 11px !important;
}

.operator-page .primary-btn {
  width: 144px !important;
  height: 40px !important;
  margin: 25px 0 0 !important;
  gap: 9px !important;
  border-radius: 22px !important;
  font-size: 15px !important;
  line-height: 40px !important;
}

.operator-page .arrow {
  width: 22px !important;
  height: 22px !important;
  font-size: 23px !important;
  line-height: 20px !important;
}

.operator-page .card-visual {
  right: 8px !important;
  top: 15px !important;
  width: 155px !important;
  height: 180px !important;
  pointer-events: none !important;
}

.operator-page .wifi {
  right: 33px !important;
  top: 15px !important;
  width: 60px !important;
  height: 50px !important;
}

.operator-page .wifi view {
  border-top-width: 6px !important;
}

.operator-page .wifi view:nth-child(1) {
  width: 75px !important;
  height: 44px !important;
}

.operator-page .wifi view:nth-child(2) {
  top: 19px !important;
  width: 52px !important;
  height: 31px !important;
}

.operator-page .wifi view:nth-child(3) {
  top: 41px !important;
  width: 9px !important;
  height: 9px !important;
}

.operator-page .screen {
  right: 21px !important;
  top: 59px !important;
  width: 74px !important;
  height: 52px !important;
  border-radius: 9px !important;
}

.operator-page .router {
  right: 15px !important;
  top: 127px !important;
  width: 48px !important;
  height: 12px !important;
  border-radius: 9px !important;
}

.operator-page .speed {
  right: 3px !important;
  bottom: 0 !important;
  font-size: 27px !important;
}

.operator-page .big-sim {
  right: 26px !important;
  top: 40px !important;
  width: 65px !important;
  height: 85px !important;
  border-radius: 14px !important;
}

.operator-page .chip {
  left: 19px !important;
  top: 27px !important;
  width: 28px !important;
  height: 32px !important;
  border-radius: 6px !important;
}

.operator-page .fiveg {
  right: 14px !important;
  bottom: 0 !important;
  font-size: 34px !important;
}

@media screen and (max-width: 360px) {
  .operator-page .operator-shell {
    padding-right: 14px !important;
    padding-left: 14px !important;
  }

  .operator-page .hero-copy {
    padding-right: 108px !important;
  }

  .operator-page .headline {
    font-size: 25px !important;
    line-height: 32px !important;
  }

  .operator-page .subline {
    font-size: 13px !important;
  }

  .operator-page .card-visual {
    right: 0 !important;
    transform: scale(0.92) !important;
    transform-origin: top right !important;
  }

  .operator-page .features {
    gap: 10px !important;
  }

  .operator-page .feature {
    font-size: 11px !important;
  }
}
