div {
  box-sizing: border-box;
}

@font-face {
  src: url("fonts/icons.woff") format("woff");
  font-family: "Icons";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-decoration: inherit;
  text-transform: none;
}
* {
  margin: 0;
  padding: 0;
  font-size: 4.1vw;
}

em,
i {
  font-style: normal;
}

ul,
ol {
  list-style: none;
}

a {
  text-decoration: none;
}

header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 5.04vw;
  height: 16.5vw;
}
header h1 {
  margin-right: 3.5vw;
  width: 8.165vw;
  height: 6.9vw;
  background-image: url("/static/images/roaming/logo.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
header a.link {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 1.4vw 3.5vw;
  font-size: 3.3vw;
  color: #fff;
  line-height: 1;
  border: 1px solid #00bdd0;
  border-radius: 5vw;
  background-color: #00bdd0;
}
header a.link.line {
  margin-left: 1.2vw;
  color: #00bdd0;
  background-color: #fff;
}
header a.search {
  position: relative;
  margin-left: auto;
  overflow: hidden;
}
header a.search em {
  color: #fff;
}
header a.search:before {
  content: "";
  position: absolute;
  top: 0;
  right: 5px;
  width: 17px;
  height: 17px;
  border: solid 2px #0d0d0d;
  border-radius: 30px;
}
header a.search:after {
  content: "";
  position: absolute;
  top: 19px;
  right: 2px;
  width: 12px;
  height: 12px;
  border-right: solid 2px #0d0d0d;
  transform: rotate(-45deg);
}

section .local {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  flex-wrap: wrap;
  padding: 0 8vw;
  min-height: 21vh;
  background-image: url("/static/images/roaming/bg_location.png");
  background-repeat: no-repeat;
  background-position: center 0;
  background-size: cover;
}
section .local .flag {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
section .local .flag i {
  width: 10vw;
  height: 83%;
}
section .local .flag i img {
  width: 100%;
}
section .local .flag span {
  margin-left: 1.5vw;
  font-size: 6.3vw;
  color: #000;
  line-height: 1;
}
section .local .btn {
  margin: 4vw 0;
}
section .local .btn a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 2.4vw 0;
  width: 40vw;
  font-size: 3.8vw;
  color: #fff;
  line-height: 1;
  border: 1px solid #00bdd0;
  border-radius: 5vw;
  background-color: #00bdd0;
}
section .local .btn a.line {
  margin-left: 1vw;
  border-color: #73787a;
  color: #000;
  background-color: #fff;
}
section .local p {
  font-size: 3.5vw;
  color: #222;
  line-height: 1.3;
  text-align: center;
}
section .local p a {
  font: inherit;
  font-weight: 600;
  color: #000;
  text-decoration: underline;
}
section .local .gps {
  display: flex;
  align-items: center;
  flex-direction: column;
  row-gap: 1.3vh;
  width: 100%;
}
section .local .gps:before {
  content: "";
  display: block;
  width: 16vw;
  height: 16vw;
  background-image: url("/static/images/roaming/img_gps.png");
  background-size: contain;
}
section .login {
  border-top: solid 1px #e2e2e2;
}
section .login .use {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3vw 5vw;
}
section .login .use em {
  font-weight: 600;
  font-size: 4.6vw;
  color: #000;
}
section .login .use:after {
  content: "";
  display: block;
  width: 2vw;
  height: 2vw;
  border: 2px solid #000;
  border-left-color: #fff;
  border-bottom-color: #fff;
  transform: rotate(45deg);
}
section .login div.after div.line {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3vw 5vw;
  border-bottom: 1px solid #e2e2e2;
}
section .login div.after div.line div select {
  padding-right: 2vw;
  font-size: 4vw;
  color: #555;
  border: 0;
}
section .login div.after div.line div p {
  font-size: 4vw;
  color: #555;
}
section .login div.after div.line a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 1.5vw 2vw;
  font-size: 3.5vw;
  color: #00bdd0;
  line-height: 1;
  border: 1px solid #00bdd0;
  border-radius: 1.5vw;
  background-color: #fff;
}
section .login div.after ul.list li {
  position: relative;
  padding: 4vw 5vw 4vw 10.5vw;
  font-weight: 600;
  font-size: 4vw;
  color: #000;
  line-height: 1;
  border-bottom: 1px solid #f0f0f0;
}
section .login div.after ul.list li:before {
  position: absolute;
  top: calc(50% - 2vw);
  left: 5vw;
  content: "";
  display: block;
  width: 4vw;
  height: 4vw;
  border-radius: 50%;
  background-color: #c6c6c6;
}
section .login div.after ul.list li:after {
  position: absolute;
  top: calc(50% - 1.55vw);
  left: 6.06vw;
  z-index: 2;
  content: "";
  display: block;
  width: 1vw;
  height: 1vw;
  border: 2px solid #fff;
  border-left-color: transparent;
  border-top-color: transparent;
  transform: rotate(45deg);
}
section .login div.after .wait {
  display: flex;
  align-items: center;
  flex-direction: column;
  row-gap: 4vw;
  padding: 7vw 0;
  border-top: solid 1px #e2e2e2;
}
section .login div.after .wait p {
  font-size: 4vw;
  color: #555;
  line-height: 1.5;
  text-align: center;
}
section .login div.after .wait span {
  position: relative;
}
section .login div.after .wait span.none {
  width: 9vw;
  height: 9vw;
  border: 2px solid #777;
  border-radius: 50%;
}
section .login div.after .wait span.none:before {
  position: absolute;
  top: 50%;
  left: 1.6vw;
  content: "";
  display: block;
  width: 6vw;
  height: 2px;
  background-color: #777;
  transform: rotate(-45deg);
}
section .login div.after .wait span.none:after {
  position: absolute;
  top: 50%;
  left: 1.6vw;
  content: "";
  display: block;
  width: 6vw;
  height: 2px;
  background-color: #777;
  transform: rotate(45deg);
}
section .login div.after .wait span.system {
  font-weight: 700;
  font-size: 5vw;
  line-height: 1.2;
}
section .login div.after .wait span.system:before {
  content: "";
  position: absolute;
  top: -3vw;
  left: -5.3vw;
  z-index: -2;
  border-left: 6vw solid transparent;
  border-right: 6vw solid transparent;
  border-bottom: 10vw solid #777777;
}
section .login div.after .wait span.system:after {
  content: "";
  position: absolute;
  top: -2vw;
  left: -4.2vw;
  z-index: -1;
  border-left: 5vw solid transparent;
  border-right: 5vw solid transparent;
  border-bottom: 8.5vw solid #ffffff;
}
section .login div.after .wait button {
  padding: 2vw 3vw;
  font-size: 4vw;
  color: #fff;
  line-height: 1;
  border-radius: 1vw;
  background-color: #303030;
}
section .login div.before {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  height: 14vh;
  border-top: solid 1px #e2e2e2;
}
section .login div.before p {
  margin-bottom: 1vh;
  font-size: 4vw;
  color: #666;
}
section .login div.before a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 2.4vw 0;
  width: 40vw;
  font-size: 4vw;
  color: #00bdd0;
  line-height: 1;
  border: 1px solid #00bdd0;
  border-radius: 5vw;
  background-color: #fff;
}
section .login div.before a i {
  position: relative;
  margin-right: 1vw;
  width: 3vw;
  height: 3vw;
  border: 2px solid #00bdd0;
  border-radius: 2vw;
}
section .login div.before a i:before {
  position: absolute;
  top: -1.5vw;
  left: calc(50% - 3px);
  content: "";
  display: block;
  width: 2px;
  height: 2vw;
  border: 2px solid #fff;
  background-color: #00bdd0;
}
section .product .tab {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1vh solid #ebebeb;
  border-bottom: 1vh solid #ebebeb;
}
section .product .tab button {
  position: relative;
  padding: 2vh 0;
  width: 100%;
  font-size: 4.35vw;
  color: #555;
  border: none;
  background-color: #fff;
}
section .product .tab button + button:before {
  position: absolute;
  top: calc(50% - 3vh);
  left: 0;
  content: "";
  display: block;
  width: 1px;
  height: 6vh;
  background-color: #ececec;
}
section .product .tab button.on {
  font-weight: 600;
  color: #00aac3;
}
section .product ul li {
  padding: 4vw 3vw;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #f0f0f0;
}
section .product ul li a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 2.4vw 4vw;
  font-size: 4vw;
  color: #00bdd0;
  line-height: 1;
  border: 1px solid #00bdd0;
  border-radius: 5vw;
  background-color: #fff;
}
section .product ul li div {
  display: flex;
  flex-direction: column;
}
section .product ul li div > span {
  font-size: 3.9vw;
  color: #424141;
}
section .product ul li div > em {
  font-size: 3.35vw;
  color: #73787a;
}
section .product ul li div > p {
  font-size: 6.5vw;
  color: #00aac3;
  letter-spacing: -0.4vw;
}
section .product ul li div > p i {
  font-size: 4.5vw;
  color: #555;
}
section .product ul li.btn {
  justify-content: center;
  background-color: #fafafa;
}
section .product ul li.btn button {
  position: relative;
  display: flex;
  align-items: center;
  color: #555;
  border-color: transparent;
  background-color: transparent;
}
section .product ul li.btn button.more:before {
  position: absolute;
  top: calc(50% - 2vw);
  right: calc(2vw - 1px);
  content: "";
  display: block;
  width: 2px;
  height: 4vw;
  background-color: #959595;
}
section .product ul li.btn button.more:after {
  margin-left: 2vw;
  content: "";
  display: block;
  width: 4vw;
  height: 2px;
  background-color: #959595;
}
section .product ul li.btn button.close {
  display: none;
}
section .product ul li.btn button.close:after {
  position: absolute;
  top: 2.8vw;
  right: -5vw;
  margin-left: 2vw;
  content: "";
  display: block;
  width: 1.6vw;
  height: 1.6vw;
  border: 2px solid #959595;
  border-left-color: transparent;
  border-top-color: transparent;
  transform: rotate(-135deg);
}
section .link {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1vh solid #ebebeb;
  border-bottom: 1vh solid #ebebeb;
}
section .link li {
  border-left: 1px solid #e2e2e2;
  border-bottom: 1px solid #e2e2e2;
}
section .link li a {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 4vw;
  color: #555;
  width: 100%;
  height: 5.8vh;
}
section .link li:nth-child(3n+1) {
  border-left: 0;
}
section .info {
  padding-bottom: 2vh;
}
section .info ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  padding: 2vh 0;
}
section .info ul li + li {
  border-left: 1px solid #e2e2e2;
}
section .info ul li a {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  font-size: 4vw;
  color: #555;
}
section .info ul li a:before {
  content: "";
  display: block;
  width: 20vw;
  height: 20vw;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 60%;
}
section .info ul li:nth-child(1) a:before {
  background-image: url("/static/images/roaming/icon_svc_01.png");
}
section .info ul li:nth-child(2) a:before {
  background-image: url("/static/images/roaming/icon_svc_02.png");
}
section .info ul li:nth-child(3) a:before {
  background-image: url("/static/images/roaming/icon_svc_03.png");
}
section .info p {
  font-size: 3.4vw;
  color: #555;
  text-align: center;
}

footer {
  display: flex;
  flex-direction: column;
  padding: 3.04vw;
  border-top: solid 1px #e2e2e2;
  background-color: #ececec;
}
footer b {
  color: #444;
}
footer span {
  color: #555;
}

.state {
  position: fixed;
  bottom: 3vw;
  left: 3vw;
  padding: 4vw 0;
  width: 94vw;
  font-size: 4vw;
  color: #fff;
  line-height: 1.5;
  text-align: center;
  border-radius: 3vw;
  background-color: rgba(75, 84, 91, 0.9);
}
.state button {
  position: absolute;
  top: 1vw;
  right: 1vw;
  width: 5vw;
  height: 5vw;
  border-color: transparent;
  background-color: transparent;
  text-indent: -1000px;
  overflow: hidden;
}
.state button:before {
  content: "";
  position: absolute;
  top: 0;
  right: 50%;
  width: 2px;
  height: 5vw;
  background: #a5aaad;
  transform: rotate(45deg);
}
.state button:after {
  content: "";
  position: absolute;
  top: 0;
  right: 50%;
  width: 2px;
  height: 5vw;
  background: #a5aaad;
  transform: rotate(-45deg);
}/*# sourceMappingURL=roaming.css.map */