.icatch,
.wifi-feature-col-icatch {
  position: relative;
  z-index: 1;
  color: #113b5c;
  font-weight: bold;
  line-height: 1em;
  font-style: italic;
  text-align: left;
  display: inline-block;
  font-size: clamp(10px, 0.833333333333333vw, 12px);
  padding: 5px 8px;
}
.icatch::before,
.wifi-feature-col-icatch::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  transform: skewX(-15deg);
  width: 100%;
  height: 100%;
  background-color: #1fecb5;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .icatch,
  .wifi-feature-col-icatch {
    font-size: clamp(10px, 2.5vw, 12px);
  }
}
@media screen and (max-width: 767px) {
  .body {
    padding-top: 60px;
  }
}
* {
  box-sizing: border-box;
}
picture img,
img {
  max-width: 100%;
  height: auto;
}
table {
  margin-bottom: 10px;
  border-collapse: collapse;
}
table tr th,
table tr td {
  padding: 20px 2.083333333333333vw;
  border-top: 1px #ddd solid;
  border-bottom: 1px #ddd solid;
}
table tr th {
  width: 30%;
  background: #efefef;
  text-align: left;
}
.headernav.is-fixed {
  width: 100%;
  position: fixed;
  z-index: 100;
  top: 0;
}
@media screen and (max-width: 767px) {
  .js-scrollable {
    overflow-y: hidden;
    overflow-x: auto;
    scrollbar-base-color: #ffdff9;
    scrollbar-arrow-color: #ffdff9;
  }
}
.footer-inner {
  width: 100%;
  max-width: 1080px;
  margin: auto;
}
/* ========================================================================
   Component: webonly
 ========================================================================== */
.webonly {
  position: relative;
  margin-top: 6.597222222222222vw;
}
@media screen and (min-width: 1440px) {
  .webonly {
    margin-top: 95px;
  }
}
@media screen and (max-width: 767px) {
  .webonly {
    margin-top: 18.75vw;
  }
}
.webonly-inner {
  border-radius: 10px;
  background: #fff;
  position: relative;
  border: 4px solid #3da2db;
  padding-bottom: 1.736111111111111vw;
}
@media screen and (min-width: 1440px) {
  .webonly-inner {
    padding-bottom: 25px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-inner {
    padding: 8.333333333333332vw 4.166666666666666vw;
  }
}
.webonly-badge {
  position: absolute;
  top: 0;
  right: 0;
  color: #fff;
  text-align: center;
  line-height: 1em;
  font-weight: bold;
  transform: translateX(30%) translateY(-42%);
  font-size: clamp(10px, 1.25vw, 18px);
  width: 12.708333333333332vw;
  padding-top: 3.472222222222222vw;
}
@media screen and (min-width: 1440px) {
  .webonly-badge {
    width: 183px;
    padding-top: 50px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-badge {
    transform: translateX(10%) translateY(-95%);
    width: 33.125vw;
    padding-top: 8.333333333333332vw;
    font-size: clamp(10px, 3.125vw, 15px);
  }
}
.webonly-badge::before {
  content: "";
  display: block;
  background: #3da2db;
  border-radius: 100%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  border: 0.277777777777778vw solid #fff;
  width: 12.708333333333332vw;
  height: 12.708333333333332vw;
}
@media screen and (min-width: 1440px) {
  .webonly-badge::before {
    width: 183px;
    height: 183px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-badge::before {
    border: 2px solid #fff;
    width: 33.125vw;
    height: 33.125vw;
  }
}
.webonly-badge span {
  display: block;
  font-size: clamp(10px, 3.472222222222222vw, 50px);
}
@media screen and (max-width: 767px) {
  .webonly-badge span {
    font-size: clamp(10px, 8.958333333333334vw, 43px);
  }
}
.webonly-title {
  font-weight: bold;
  text-align: center;
  font-size: clamp(10px, 2.916666666666667vw, 42px);
}
@media screen and (max-width: 767px) {
  .webonly-title {
    font-size: clamp(10px, 7.5vw, 36px);
  }
}
.webonly-title-sub {
  display: block;
  margin-top: 45px;
  font-size: clamp(10px, 1.527777777777778vw, 22px);
}
@media screen and (max-width: 767px) {
  .webonly-title-sub {
    margin-top: 0;
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
.webonly-title-sub::before,
.webonly-title-sub::after {
  content: "";
  display: inline-block;
  width: 1px;
  background: #3da2db;
  vertical-align: middle;
  height: 1.736111111111111vw;
}
@media screen and (min-width: 1440px) {
  .webonly-title-sub::before,
  .webonly-title-sub::after {
    height: 25px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-title-sub::before,
  .webonly-title-sub::after {
    height: 5.208333333333334vw;
  }
}
.webonly-title-sub::before {
  margin-right: 0.5em;
  transform: rotate(-40deg);
}
.webonly-title-sub::after {
  margin-left: 0.5em;
  transform: rotate(40deg);
}
.webonly-title-line {
  margin-top: 5px;
  display: inline-block;
  position: relative;
  z-index: 1;
}
.webonly-title-line span {
  font-size: clamp(10px, 2.222222222222222vw, 32px);
}
@media screen and (max-width: 767px) {
  .webonly-title-line span {
    font-size: clamp(10px, 5.833333333333333vw, 28px);
  }
}
.webonly-title-line::after {
  display: inline-block;
  content: "";
  width: 100%;
  height: 0.5em;
  background: #e5f6ff;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
.webonly-box {
  display: flex;
  justify-content: center;
  position: relative;
  margin-top: 2.777777777777778vw;
}
@media screen and (min-width: 1440px) {
  .webonly-box {
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-box {
    justify-content: space-between;
    margin-top: 5.208333333333334vw;
  }
}
.webonly-card {
  width: 20.833333333333336vw;
}
@media screen and (min-width: 1440px) {
  .webonly-card {
    width: 300px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-card {
    width: 34.375vw;
  }
  .webonly-card:nth-child(1) .webonly-card-price {
    margin-bottom: 1.041666666666667vw;
  }
}
.webonly-card-inner {
  background: #f8f8f8;
  border-radius: 8px;
  text-align: center;
  padding: 1.388888888888889vw;
}
@media screen and (min-width: 1440px) {
  .webonly-card-inner {
    padding: 20px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-card-inner {
    padding: 2.083333333333333vw;
  }
}
.webonly-card-title {
  text-align: center;
  font-weight: bold;
  border-bottom: 1px dashed #000;
  padding-bottom: 10px;
  font-size: clamp(10px, 1.666666666666667vw, 24px);
}
@media screen and (max-width: 767px) {
  .webonly-card-title {
    padding-bottom: 0.833333333333333vw;
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
.webonly-card-title-sup {
  font-size: clamp(10px, 0.694444444444444vw, 10px);
}
.webonly-card-text {
  color: #666;
  font-weight: bold;
  display: inline-block;
  position: relative;
  padding: 0 5px;
  margin-top: 5px;
  line-height: 1.5em;
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .webonly-card-text {
    font-size: 12px;
  }
}
.webonly-card-text span {
  font-size: clamp(10px, 0.972222222222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .webonly-card-text span {
    font-size: 12px;
  }
}
.webonly-card-correct {
  color: #666;
  font-weight: bold;
  display: inline-block;
  position: relative;
  padding: 0 5px;
  margin-top: 5px;
  line-height: 1;
  font-size: clamp(10px, 1.944444444444444vw, 28px);
}
@media screen and (max-width: 767px) {
  .webonly-card-correct {
    margin-top: 10px;
    font-size: 20px;
  }
}
.webonly-card-correct span {
  font-size: clamp(10px, 1.527777777777778vw, 22px);
}
@media screen and (max-width: 767px) {
  .webonly-card-correct span {
    font-size: clamp(10px, 2.916666666666667vw, 14px);
  }
}
.webonly-card-correct::before,
.webonly-card-correct::after {
  display: inline-block;
  content: "";
  width: 100%;
  height: 1.5px;
  background: #666;
  position: absolute;
  top: 44%;
  left: 0;
}
.webonly-card-correct::before {
  transform: translateY(-2px);
}
.webonly-card-correct::after {
  transform: translateY(2px);
}
.webonly-card-iconarrow {
  margin: 5px auto 0;
  width: 0;
  height: 0;
  border-top: solid 5px transparent;
  border-right: solid 5px transparent;
  border-bottom: solid 5px transparent;
  border-left: solid 8px #3da2db;
  transform: rotate(90deg);
}
@media screen and (max-width: 767px) {
  .webonly-card-iconarrow {
    margin: 10px auto 0;
  }
}
.webonly-card-price {
  line-height: 1em;
  color: #3da2db;
  font-weight: bold;
  font-size: clamp(10px, 4.097222222222222vw, 59px);
}
@media screen and (max-width: 767px) {
  .webonly-card-price {
    font-size: clamp(10px, 6.666666666666667vw, 32px);
  }
}
.webonly-card-price span {
  font-size: clamp(10px, 1.944444444444444vw, 28px);
}
@media screen and (max-width: 767px) {
  .webonly-card-price span {
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
.webonly-card-price span.webonly-card-price-attention {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size: clamp(10px, 1.25vw, 18px);
  background: #3da2db;
  color: #fff;
  padding: 3px 0 6px;
  border-radius: 3px;
  margin-right: 4px;
  vertical-align: bottom;
}
@media screen and (max-width: 767px) {
  .webonly-card-price span.webonly-card-price-attention {
    vertical-align: text-bottom;
  }
}
.webonly-card-note {
  font-weight: 500;
  font-size: clamp(10px, 0.972222222222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .webonly-card-note {
    margin-top: 10px;
    font-size: clamp(10px, 2.5vw, 12px);
    line-height: 1.2em;
  }
}
.webonly-more {
  text-align: center;
  font-weight: bold;
  font-size: clamp(10px, 1.527777777777778vw, 22px);
  margin: 70px 25px 0;
}
@media screen and (max-width: 767px) {
  .webonly-more {
    margin: 9.375vw 0 0;
    font-size: clamp(10px, 3.333333333333333vw, 16px);
    letter-spacing: -0.15em;
  }
}
.webonly-more-plus {
  margin-top: 10px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .webonly-more-plus {
    margin-top: 35px;
  }
}
.webonly-more-plus::before,
.webonly-more-plus::after {
  content: "";
  display: block;
  width: 2.777777777777778vw;
  height: 0.694444444444444vw;
  background: #333;
  position: absolute;
  left: 50%;
}
@media screen and (min-width: 1440px) {
  .webonly-more-plus::before,
  .webonly-more-plus::after {
    width: 40px;
    height: 10px;
  }
}
.webonly-more-plus::before {
  transform: translateY(50%) translateX(-50%);
}
.webonly-more-plus::after {
  transform: translateY(50%) translateX(-50%) rotate(90deg);
}
.webonly-link {
  display: flex;
  justify-content: center;
  margin-top: 2.083333333333333vw;
}
@media screen and (min-width: 1440px) {
  .webonly-link {
    margin-top: 30px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-link {
    display: inherit;
    margin-top: 0;
  }
}
.webonly-link-list {
  margin: 0 2.777777777777778vw;
  width: 20.833333333333336vw;
}
@media screen and (min-width: 1440px) {
  .webonly-link-list {
    margin: 0 40px;
    width: 300px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-link-list {
    margin: 3.125vw 0 0;
    width: 100%;
  }
}
.webonly-link-list::after {
  width: 0.694444444444444vw;
  height: 0.694444444444444vw;
  right: 1.736111111111111vw;
}
@media screen and (min-width: 1440px) {
  .webonly-link-list::after {
    width: 10px;
    height: 10px;
    right: 25px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-link-list::after {
    width: 2.083333333333333vw;
    height: 2.083333333333333vw;
    right: 6.25vw;
  }
}
.webonly-link-list a {
  line-height: 4.861111111111112vw;
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (min-width: 1440px) {
  .webonly-link-list a {
    line-height: 70px;
  }
}
@media screen and (max-width: 767px) {
  .webonly-link-list a {
    line-height: 14.583333333333334vw;
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.webonly-note {
  margin-top: 15px;
  font-size: clamp(10px, 0.694444444444444vw, 10px);
}
@media screen and (max-width: 767px) {
  .webonly-note {
    font-size: clamp(10px, 2.083333333333333vw, 10px);
  }
}
/* ========================================================================
   Component: provider
 ========================================================================== */
.provider-inner {
  padding: 5.555555555555555vw 0;
}
.provider-lead {
  font-size: clamp(10px, 1.666666666666667vw, 24px);
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 2.777777777777778vw;
}
@media screen and (min-width: 768px) {
  .provider-lead {
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .provider-lead {
    font-size: clamp(10px, 4.166666666666666vw, 20px);
    margin-bottom: 40px;
  }
}
@media screen and (min-width: 768px) {
  .provider-case {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    margin-bottom: 4.166666666666666vw;
  }
}
@media screen and (min-width: 768px) {
  .provider-col {
    display: flex;
    align-items: stretch;
    flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  .provider-col {
    margin-bottom: 40px;
  }
}
@media screen and (min-width: 768px) {
  .provider-col:first-child {
    width: 64%;
  }
}
@media screen and (min-width: 768px) {
  .provider-col:last-child {
    width: 33%;
  }
}
.provider-col-title {
  font-size: clamp(10px, 2.222222222222222vw, 32px);
  font-weight: bold;
}
@media screen and (max-width: 820px) {
  .provider-col-title {
    font-size: clamp(10px, 1.805555555555555vw, 26px);
  }
}
@media screen and (max-width: 767px) {
  .provider-col-title {
    font-size: clamp(10px, 5vw, 24px);
  }
}
.provider-col-catch {
  font-size: clamp(10px, 1.388888888888889vw, 20px);
  font-weight: bold;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .provider-col-catch {
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
.provider-col-inner {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}
.provider-col-ipv4,
.provider-col-ipv6,
.provider-col-price {
  padding: 30px 20px 20px;
  border-radius: 20px;
}
@media screen and (max-width: 767px) {
  .provider-col-ipv4,
  .provider-col-ipv6,
  .provider-col-price {
    padding: 15px 10px;
  }
}
@media screen and (min-width: 768px) {
  .provider-col-ipv4,
  .provider-col-ipv6 {
    width: 49%;
  }
}
@media screen and (max-width: 767px) {
  .provider-col-ipv4,
  .provider-col-ipv6 {
    width: 50%;
  }
}
.provider-col-ipv4-title span,
.provider-col-ipv6-title span {
  display: inline-block;
  font-size: clamp(10px, 1.25vw, 18px);
  font-weight: bold;
  border-radius: 20px;
  padding: 0.347222222222222vw 2.083333333333333vw;
}
@media screen and (max-width: 820px) {
  .provider-col-ipv4-title span,
  .provider-col-ipv6-title span {
    width: 100%;
    padding: 0.347222222222222vw 0;
  }
}
@media screen and (max-width: 767px) {
  .provider-col-ipv4-title span,
  .provider-col-ipv6-title span {
    font-size: clamp(10px, 2.916666666666667vw, 14px);
    padding: 5px 0;
  }
}
.provider-col-ipv4-product,
.provider-col-ipv6-product {
  font-size: clamp(10px, 2.222222222222222vw, 32px);
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .provider-col-ipv4-product,
  .provider-col-ipv6-product {
    font-size: clamp(10px, 4.583333333333333vw, 22px);
  }
}
.provider-col-ipv4-product-img,
.provider-col-ipv6-product-img {
  min-height: 152px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.694444444444444vw;
}
@media screen and (max-width: 767px) {
  .provider-col-ipv4-product-img,
  .provider-col-ipv6-product-img {
    min-height: 0;
  }
}
.provider-col-ipv4,
.provider-col-price {
  background: #f8f8f8;
}
.provider-col-ipv4-lead,
.provider-col-price-lead {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .provider-col-ipv4-lead,
  .provider-col-price-lead {
    padding: 0 10px;
  }
}
@media screen and (max-width: 767px) {
  .provider-col-ipv4-lead,
  .provider-col-price-lead {
    margin-top: 10px;
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
@media screen and (min-width: 768px) {
  .provider-col-price {
    display: flex;
    flex-direction: column;
    flex: 1 0 auto;
  }
}
.provider-col-ipv4 {
  position: relative;
}
@media screen and (max-width: 767px) {
  .provider-col-ipv4 {
    padding: 15px 20px 15px 10px;
  }
}
.provider-col-ipv4-title {
  text-align: center;
}
.provider-col-ipv4-title span {
  background: #fff;
}
.provider-col-ipv4:after {
  content: "";
  background: url("/images/service/network/uspot/about/img_arrow.svg");
  background-size: contain;
  background-repeat: no-repeat;
  width: 3.958333333333333vw;
  height: 5.347222222222222vw;
  max-width: 57px;
  position: absolute;
  right: -1.944444444444444vw;
  top: 45%;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .provider-col-ipv4:after {
    width: 30px;
    height: 40px;
    right: -15px;
  }
}
.provider-col-ipv6 {
  background: #e5f6ff;
}
@media screen and (max-width: 767px) {
  .provider-col-ipv6 {
    padding: 15px 10px 15px 20px;
  }
}
.provider-col-ipv6-title {
  text-align: center;
}
.provider-col-ipv6-title span {
  color: #fff;
  background: #3da2db;
}
.provider-col-ipv6-lead {
  font-size: clamp(10px, 2.222222222222222vw, 32px);
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .provider-col-ipv6-lead {
    font-size: clamp(10px, 4.166666666666666vw, 20px);
  }
}
@media screen and (max-width: 767px) {
  .provider-col-price {
    padding: 15px;
  }
}
.provider-col-price-product-img {
  margin-bottom: 0.694444444444444vw;
  text-align: center;
}
.provider-detail {
  width: 100%;
  max-width: 730px;
  margin: auto;
}
.provider-detail-table {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .provider-detail-table {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.provider-detail .list-asterisk {
  font-size: clamp(10px, 0.972222222222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .provider-detail .list-asterisk {
    font-size: clamp(10px, 2.916666666666667vw, 14px);
  }
}
/* ========================================================================
   Component: wifi
 ========================================================================== */
.wifi {
  background: #f8f8f8;
  padding: 4.166666666666666vw 0;
}
@media screen and (max-width: 767px) {
  .wifi {
    padding: 50px 0 20px;
  }
}
@media screen and (min-width: 768px) {
  .wifi-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
@media screen and (min-width: 768px) {
  .wifi-content-detail {
    width: 60%;
  }
}
@media screen and (min-width: 768px) {
  .wifi-content-img {
    width: 38%;
  }
}
@media screen and (max-width: 767px) {
  .wifi-content-img {
    margin-top: 15px;
  }
}
@media screen and (max-width: 767px) {
  .wifi-content-img img {
    width: 100%;
  }
}
.wifi-content-title {
  font-size: clamp(10px, 2.222222222222222vw, 32px);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .wifi-content-title {
    font-size: clamp(10px, 5vw, 24px);
  }
}
.wifi-content-subtitle {
  font-size: clamp(10px, 1.527777777777778vw, 22px);
  font-weight: bold;
  margin: 1.597222222222222vw 0;
}
@media screen and (max-width: 767px) {
  .wifi-content-subtitle {
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
.wifi-content-text {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .wifi-content-text {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.wifi .bg-white {
  padding: 2.430555555555556vw;
  margin-bottom: 2.777777777777778vw;
}
@media screen and (max-width: 767px) {
  .wifi .bg-white {
    padding: 40px 20px 20px;
    margin-bottom: 40px;
  }
}
.wifi-connection {
  margin-top: 1.388888888888889vw;
}
.wifi-connection-title {
  font-size: clamp(10px, 1.527777777777778vw, 22px);
  font-weight: bold;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .wifi-connection-title {
    font-size: clamp(10px, 4.583333333333333vw, 22px);
  }
}
.wifi-connection-title:before {
  content: "";
  background: url("/images/service/network/uspot/about/ic_wifi.svg");
  width: 19px;
  height: 14px;
  display: inline-block;
  margin-right: 5px;
}
.wifi-connection-inner {
  background: #f8f8f8;
  border-radius: 8px;
  padding: 1.944444444444444vw;
}
@media screen and (min-width: 768px) {
  .wifi-connection-inner {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .wifi-connection-inner {
    padding: 20px 15px;
  }
}
.wifi-connection-col {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .wifi-connection-col {
    width: 50%;
  }
}
.wifi-connection-col-inner:first-child {
  margin-right: 1.944444444444444vw;
}
@media screen and (max-width: 767px) {
  .wifi-connection-col-inner {
    width: 49%;
  }
}
@media screen and (min-width: 768px) {
  .wifi-connection-col:first-child {
    border-right: 1px solid #ddd;
    padding-right: 1.736111111111111vw;
  }
}
@media screen and (max-width: 767px) {
  .wifi-connection-col:first-child {
    border-bottom: 1px solid #ddd;
    padding-bottom: 25px;
    margin-bottom: 25px;
  }
}
.wifi-connection-col:first-child .wifi-connection-col-inner:last-child {
  text-align: right;
}
@media screen and (max-width: 767px) {
  .wifi-connection-col:first-child .wifi-connection-col-inner:last-child img {
    width: 90%;
  }
}
@media screen and (min-width: 768px) {
  .wifi-connection-col:last-child {
    padding-left: 1.736111111111111vw;
  }
}
.wifi-connection-col:last-child .wifi-connection-col-inner {
  margin-right: 0;
}
.wifi-connection-col-title,
.wifi-connection-col-catch {
  font-weight: bold;
  line-height: 1.6;
}
.wifi-connection-col-title {
  font-size: clamp(10px, 1.388888888888889vw, 20px);
}
@media screen and (max-width: 767px) {
  .wifi-connection-col-title {
    font-size: clamp(10px, 4.166666666666666vw, 20px);
  }
}
.wifi-connection-col-catch {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .wifi-connection-col-catch {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.wifi-connection-col-list li {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
  background: #3da2db;
  color: #fff;
  border-radius: 4px;
  padding: 0.347222222222222vw 0.694444444444444vw;
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .wifi-connection-col-list li {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.wifi-connection-col-list li span {
  display: inline-block;
  font-size: clamp(10px, 0.833333333333333vw, 12px);
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .wifi-connection-col-list li span {
    font-size: clamp(10px, 2.5vw, 12px);
  }
}
@media screen and (min-width: 768px) {
  .wifi-feature {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.wifi-feature-col {
  width: 100%;
  background: #fff;
  margin-bottom: 2.777777777777778vw;
  border-radius: 8px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .wifi-feature-col {
    width: 48%;
    max-width: 450px;
  }
}
@media screen and (max-width: 767px) {
  .wifi-feature-col {
    margin-bottom: 40px;
  }
}
.wifi-feature-col .anchor-header {
  position: absolute;
}
.wifi-feature-col-inner {
  padding: 2.777777777777778vw;
}
@media screen and (max-width: 767px) {
  .wifi-feature-col-inner {
    padding: 15px 15px 20px;
  }
}
.wifi-feature-col-title {
  font-size: clamp(10px, 1.944444444444444vw, 28px);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .wifi-feature-col-title {
    font-size: clamp(10px, 5vw, 24px);
  }
}
.wifi-feature-col-title-small {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .wifi-feature-col-title-small {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.wifi-feature-col-subtitle {
  font-size: clamp(10px, 1.388888888888889vw, 20px);
  font-weight: bold;
  margin-bottom: 1.041666666666667vw;
}
@media screen and (max-width: 767px) {
  .wifi-feature-col-subtitle {
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
.wifi-feature-col-text {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .wifi-feature-col-text {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.wifi-feature-col-caution {
  font-size: clamp(10px, 0.972222222222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .wifi-feature-col-caution {
    font-size: clamp(10px, 2.916666666666667vw, 14px);
  }
}
@media screen and (max-width: 767px) {
  .wifi-feature-col img {
    width: 100%;
  }
}
/* ========================================================================
   Component: setting
 ========================================================================== */
.setting {
  padding: 3.472222222222222vw 0;
}
@media screen and (max-width: 767px) {
  .setting {
    padding: 50px 0;
  }
}
@media screen and (min-width: 768px) {
  .setting-cards {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .setting-cards {
    margin: auto;
  }
}
@media screen and (max-width: 820px) {
  .setting-card {
    width: 30%;
  }
}
@media screen and (max-width: 767px) {
  .setting-card {
    width: 100%;
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 767px) {
  .setting-card-image {
    width: 70vw;
    margin: 0 auto;
  }
}
.setting-card-title {
  font-size: clamp(10px, 1.666666666666667vw, 24px);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .setting-card-title {
    padding: 10px 0;
    font-size: clamp(10px, 5vw, 24px);
  }
}
.setting-card-detail {
  padding: 1.388888888888889vw 0;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}
@media screen and (max-width: 767px) {
  .setting-card-detail {
    padding: 15px 0;
  }
}
.setting-card-detail span {
  display: block;
  font-weight: 500;
}
.setting-card-detail span:first-child {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .setting-card-detail span:first-child {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.setting-card-detail span:last-child {
  font-size: clamp(10px, 1.666666666666667vw, 24px);
}
@media screen and (max-width: 767px) {
  .setting-card-detail span:last-child {
    font-size: clamp(10px, 5vw, 24px);
  }
}
.setting-scope {
  width: 100%;
  max-width: 680px;
  margin: 4.861111111111112vw auto 0;
}
@media screen and (min-width: 768px) {
  .setting-scope-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
.setting-scope-img {
  width: 189px;
  margin-right: 2.083333333333333vw;
}
@media screen and (max-width: 767px) {
  .setting-scope-img {
    margin: 0 auto 20px;
  }
}
.setting-scope-text {
  flex: 1;
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .setting-scope-text {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.setting-scope-text a {
  display: inline-block;
  border-bottom: 1px solid #333;
  transition: 0.3s;
}
.setting-scope-text a:hover {
  border-bottom: 1px solid transparent;
}
/* ========================================================================
   Component: spec
 ========================================================================== */
.spec {
  background: #f8f8f8;
  padding: 3.472222222222222vw 0;
}
@media screen and (max-width: 767px) {
  .spec {
    padding: 50px 0;
  }
}
.spec-detail {
  width: 100%;
  max-width: 780px;
  margin: auto;
}
.spec-detail table {
  background: #fff;
  width: 100%;
  font-size: clamp(10px, 1.111111111111111vw, 16px);
}
@media screen and (max-width: 767px) {
  .spec-detail table {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
.spec-detail-note {
  font-size: clamp(10px, 0.972222222222222vw, 14px);
}
@media screen and (max-width: 767px) {
  .spec-detail-note {
    font-size: clamp(10px, 2.916666666666667vw, 14px);
  }
}
.spec-detail-img {
  text-align: center;
}
/* ========================================================================
   Component: service
 ========================================================================== */
.other {
  margin-bottom: 8.333333333333332vw;
}
@media screen and (max-width: 767px) {
  .other {
    padding: 50px 0;
  }
}
@media screen and (min-width: 768px) {
  .service-cols {
    display: flex;
    justify-content: space-between;
  }
}
.service-col {
  background: #f8f8f8;
  border-radius: 6px 6px 0px 0px;
}
@media screen and (min-width: 768px) {
  .service-col:first-child {
    width: 34%;
  }
}
@media screen and (max-width: 767px) {
  .service-col:first-child {
    margin-bottom: 30px;
  }
}
@media screen and (min-width: 768px) {
  .service-col:last-child {
    width: 64%;
  }
}
.service-col:last-child ul .service-col-inner:first-child {
  padding: 1.388888888888889vw 0.694444444444444vw 1.388888888888889vw 1.388888888888889vw;
}
@media screen and (max-width: 767px) {
  .service-col:last-child ul .service-col-inner:first-child {
    padding: 20px 10px 10px;
  }
}
.service-col:last-child ul .service-col-inner:last-child {
  padding: 1.388888888888889vw 1.388888888888889vw 1.388888888888889vw 0.694444444444444vw;
}
@media screen and (max-width: 767px) {
  .service-col:last-child ul .service-col-inner:last-child {
    padding: 20px 10px 10px;
  }
}
@media screen and (min-width: 768px) {
  .service-col ul {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .service-col ul li {
    width: 50%;
  }
}
.service-col-title {
  font-size: clamp(10px, 1.25vw, 18px);
  color: #fff;
  text-align: center;
  background: #3da2db;
  border-radius: 6px 6px 0px 0px;
  padding: 5px 0;
}
@media screen and (max-width: 767px) {
  .service-col-title {
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
.service-col-catch {
  font-size: clamp(10px, 1.25vw, 18px);
  font-weight: bold;
  margin-bottom: 1.388888888888889vw;
}
@media screen and (max-width: 820px) {
  .service-col-catch {
    min-height: 6.944444444444445vw;
  }
}
@media screen and (max-width: 767px) {
  .service-col-catch {
    margin-bottom: 10px;
    text-align: center;
    font-size: clamp(10px, 3.75vw, 18px);
  }
}
.service-col-inner {
  padding: 1.388888888888889vw;
}
@media screen and (max-width: 767px) {
  .service-col-inner {
    padding: 20px 10px 10px;
  }
}
.service-col-detail {
  background: #fff;
  padding: 1.041666666666667vw;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .service-col-detail {
    padding: 15px;
  }
}
.service-col-img {
  min-height: 88px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.service-col-lead {
  font-size: clamp(10px, 1.111111111111111vw, 16px);
  margin-bottom: 1.041666666666667vw;
}
@media screen and (max-width: 767px) {
  .service-col-lead {
    font-size: clamp(10px, 3.333333333333333vw, 16px);
  }
}
