html {
  font-family: "Helvetica Neue",
    Arial,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    Meiryo,
    sans-serif;
  -webkit-font-feature-settings: 'palt' 1;
  font-feature-settings: 'palt' 1;
}

h2 {
  font-weight: 600;
}

h3 {
  font-weight: 600;
}

img {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.white {
  color: #fff !important;
}

.block {
  display: block;
}

@media screen and (max-width: 566px) {
  .sp-block {
    display: block;
  }
}

.Ti:before {
  content: url(../img/title_icon.png);
  padding-right: 10px;
}

.Ti02:before {
  content: url(../img/title_icon02.png);
  padding-right: 10px;
}

.Ti03:before {
  content: url(../img/title_icon03.png);
  padding-right: 10px;
}

.Ti04:before {
  content: url(../img/title_icon04.png);
  padding-right: 10px;
}

.Ti05:before {
  content: url(../img/title_icon05.png);
  padding-right: 10px;
}

.Ti06:before {
  content: url(../img/title_icon06.png);
  padding-right: 10px;
}

.Ti07:before {
  content: url(../img/title_icon07.png);
  padding-right: 10px;
}

.en {
  font-weight: 500;
  font-style: normal;
}

.priceBox01,
.priceBox02 {
  margin-top: 20px;
  float: left;
  width: 47%;
  margin-right: 3%;
}

.priceBox02 {
  margin-right: 0;
}

.price_box .tax {
  font-size: 0.4em;
  font-weight: 600;
}

.mv-priceBox {
  display: flex;
  flex-wrap: wrap;
  max-width: 425px;
}

.mv-priceBox img {
  padding: 5px;
  width: 50%;
  height: auto;
}

.mv-priceBox img:nth-of-type(2) {
  height: 120px;
  margin-top: 70px;
}

@media (max-width: 991px) {
  .mv-priceBox {
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }

  .mv-priceBox img:nth-of-type(2) {
    margin-top: 10px;
    height: auto;
  }
  .text-left-device{
    text-align: left;}
}

@-webkit-keyframes double-flash_3062 {
  0% {
    opacity: 1;
  }

  12.5% {
    opacity: 0;
  }

  25% {
    opacity: 1;
  }

  37.5% {
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 1;
  }
}

@keyframes double-flash_3062 {
  0% {
    opacity: 1;
  }

  12.5% {
    opacity: 0;
  }

  25% {
    opacity: 1;
  }

  37.5% {
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 1;
  }
}

.priceBox01_l {
  text-align: center;
  padding: 10px;
  color: #fff;
  font-size: 1.2em;
  letter-spacing: 0.1em;
  background: #ffcb15;
}

.priceBox01_r {
  text-align: center;
  border: 1px solid #ffcb15;
  padding: 17px;
  padding-bottom: 15px;
  color: #ffcb15;
  font-size: 1.45em;
  letter-spacing: 0.07em;
  margin-top: -1px;
  background: white;
  line-height: 0.7em;
}

.priceBox02_l {
  text-align: center;
  padding: 10px;
  color: #fff;
  font-size: 1.2em;
  letter-spacing: 0.1em;
  background: #6cce2a;
}

.priceBox02_r {
  text-align: center;
  border: 1px solid #6cce2a;
  padding: 17px;
  padding-bottom: 15px;
  color: #6cce2a;
  font-size: 1.45em;
  letter-spacing: 0.07em;
  margin-top: -1px;
  background: white;
  line-height: 0.7em;
}

.trans--grow {
  -webkit-transition: width 1.5s ease-out;
  /* For Safari 3.1 to 6.0 */
  transition: width 1.5s ease-out;
  width: 0%;
}

.grow {
  width: 100%;
}

.hr1 {
  left: 0;
}

.esim-banner {
  display: block;
  margin: auto;
  max-width: 90%;
  width: 300px;
}

@media (max-width: 767px) {
  #MainVisual {
    display: none;
  }
}

@media (min-width: 768px) {

  #MainVisual-sp,
  .esim-banner {
    display: none;
  }
}

.main-visual {
  width: 100%;
  height: 767px;
  position: relative;
}

.vegas-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 90%;
}

@media (max-width: 767px) {
  .main-visual {
    height: 480px;
    align-items: flex-start;
  }
}

.main-visual .img-title {
  width: 900px;
  max-width: 100%;
  margin-top: -50px;
}

.main-visual .img-sim {
  width: 450px;
  max-width: 100%;
  margin-bottom: -170px;
}

@media (max-width: 767px) {
  .main-visual .img-title {
    position: absolute;
    width: 320px;
    max-width: 90%;
    top: 90px;
    left: 0;
    right: 0;
    margin: auto;
  }

  .main-visual .img-sim {
    margin-bottom: -30px;
  }
}

.main-visual .img-price {
  width: 255px;
  max-width: 100%;
  position: absolute;
  bottom: 24px;
  right: 24px;
}

@media (max-width: 767px) {
  .main-visual .img-price {
    width: 180px;
    bottom: 20px;
    right: 10px;
    margin: auto;
  }

  .main-visual .img-sim {
    width: 320px;
    position: absolute;
    bottom: 40px;
  }

  .vegas-content {
    padding-top: 50px !important;
  }
}

#MV {
  padding-top: 130px;
  padding-bottom: 100px;
  height: 767px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-image: url(/assets/img/main-page/main-visual/back.webp);
  background-size: cover;
  background-position: center;
  position: relative;
}

#MV .in {
  width: 90vw;
  max-width: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

#MV .in .mv-title {
  max-width: 100%;
  width: 60vw;
}

#MV .in .mv-sim {
  max-width: 100%;
  width: 28vw;
  height: auto;
}

#MV .mv-present {
  position: absolute;
  left: 20px;
  bottom: 20px;
  width: 460px;
}

@media (max-width: 930px) {
  #MV .mv-present {
    width: 320px;
  }
}

@media (min-width: 768px) {
  #MV .in .mv-sim {
    min-width: 500px;
  }

  #MV .in .mv-title {
    min-width: 700px;
  }
}

@media (max-width: 767px) {
  #MV {
    height: auto !important;
  }

  #MV .mv-present {
    position: relative;
    left: 0;
    bottom: 0;
    width: 320px;
    margin-top: 20px !important;
    margin: auto;
  }

  #MV .in .mv-sim {
    margin-top: -30px;
  }
}

.mv-news {
  position: absolute;
  bottom: 20px;
  right: 20px;
  background: #fff;
  padding: 20px 15px;
}

.mv-news table {
  position: relative;
}

.mv-news .news-title {
  position: absolute;
  display: inline-block;
  background: #1aa7ff;
  color: #fff;
  padding: 7px 20px;
  top: -30px;
  left: 0;
  right: 0;
  text-align: center;
  width: 120px;
  margin: auto;
  font-weight: bold;
}

.mv-news table tr {
  display: flex;
  flex-direction: column;
  padding: 5px 0;
  border-bottom: 1px solid #d6d6d6;
}

.mv-news table tr td:nth-of-type(2) {
  margin-top: -10px;
  font-weight: bold;
}

@media (max-width: 767px) {
  .mv-none-SP {
    display: none;
  }

  #MV {
    padding-top: 80px;
    padding-bottom: 40px;
    background-image: url(/assets/img/main-page/main-visual/sp/back.webp);
  }

  .mv-sim {
    width: 320px !important;
  }
}

@media (min-width: 768px) {
  .mv-none-PC {
    display: none !important;
  }
}

.port {
  display: flex;
  flex-wrap: wrap;
  overflow: hidden;
}

.port .box {
  width: calc(100% / 3);
  overflow: hidden;
  object-fit: cover;
  overflow: hidden;
}

@media (max-width: 550px) {
  .port .box {
    width: 100%;
  }
}

.port .box img {
  max-width: 101%;
  transition: 0.3s;
}

.port .box img:hover {
  transform: scale(1.02);
}

#MV2 {
  height: 100%;
  padding-top: 170px;
  padding-bottom: 70px;
  background-image: url(../img/MV_bg_3.jpg);
  background-size: cover;
  background-position: center;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  /* 子要素をflexboxにより縦方向に揃える */
  justify-content: center;
  /* 子要素をflexboxにより中央に配置する */
  align-items: center;
  /* 子要素をflexboxにより中央に配置する */
}

#MV2 .MV2_inner {
  max-width: 1200px;
  margin: auto;
  position: relative;
}

#MV2 .MV2_inner svg {
  display: block;
  width: 96.5%;
  margin: 0 auto;
}

#MV2 .MV2_inner hr {
  margin-top: 50px;
  margin-bottom: 50px;
}

#MV2 .MV2_left {
  width: 50%;
  float: left;
}

#MV2 .MV2_right {
  width: 50%;
  float: left;
}

#MV2 .MV2_left {
  padding-top: 0px;
  margin-top: -35px;
}

#MV2 .MV2_right {
  padding-left: 3%;
  padding-right: 2%;
  margin-top: 30px;
}

#MV2 .MV2_text {
  font-size: 1.43em;
  letter-spacing: 0.56em;
  color: #484848;
  font-weight: 300;
}

#MV2 .MV2_text_2 {
  font-size: 1.44em;
  letter-spacing: 0.8em;
  color: #484848;
  font-weight: 300;
}

.campaign {
  max-width: 100%;
  margin-top: 20px;
  padding-right: 15px;
}

@media (max-width: 1100px) {
  #MV2 {
    padding-left: 5%;
    padding-right: 5%;
  }

  #MV2 .MV2_text {
    font-size: 2.04vw;
    letter-spacing: 0.525em;
    color: #484848;
  }

  #MV2 .MV2_text_2 {
    font-size: 2.04vw;
    color: #484848;
  }
}

@media (max-width: 910px) {

  .priceBox01_l,
  .priceBox02_l {
    font-size: 1em;
  }

  .priceBox01_r,
  .priceBox02_r {
    font-size: 1em;
  }

  #MV2 .MV2_text {
    font-size: 2.04vw;
    letter-spacing: 0.525em;
    color: #474747;
  }

  #MV2 .MV2_text_2 {
    font-size: 2.04vw;
    letter-spacing: 0.705em;
    color: #474747;
  }
}

@media (min-width: 768px) {
  .MV2m_none {
    display: none;
  }

  .d_none768 {
    display: none;
  }

  .d_none {
    display: none;
  }
}

@media (max-width: 767px) {
  .MV2d_none {
    display: none;
  }

  #MV2 hr {
    display: none;
  }

  #MV2 {
    padding-top: 120px;
    padding-bottom: 40px;
  }

  .MV2_right,
  .MV2_left {
    clear: both;
    float: inherit;
  }

  #MV2 .MV2_inner {
    max-width: 500px;
    margin: auto;
    position: relative;
  }

  #MV2 .MV2_left,
  #MV2 .MV2_right {
    width: 100%;
    margin: auto;
    float: left;
  }

  #MV2 .MV2_right {
    padding-left: 3%;
    padding-right: 3%;
  }

  #MV2 .MV2_left img {
    width: 300px;
  }

  #MV2 .MV2_inner hr {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  #MV2 .MV2_text,
  #MV2 .MV2_text_2 {
    text-align: center;
  }

  #MV2 .MV2_text span,
  #MV2 .MV2_text_2 span {
    letter-spacing: 0;
  }

  #MV2 .MV2_text {
    font-size: 1.46em;
    letter-spacing: 0.67em;
  }

  #MV2 .MV2_text_2 {
    font-size: 1.5em;
    letter-spacing: 0.87em;
  }

  #MV2 .MV2_banner {
    margin-top: 30px;
  }

  .priceBox01_l,
  .priceBox02_l {
    font-size: 1.2em;
  }

  .priceBox01_r,
  .priceBox02_r {
    font-size: 1.35em;
    line-height: 0.8em;
  }
}

@media (max-width: 580px) {
  #MV2 .MV2_text {
    font-size: 4vw;
    letter-spacing: 0.67em;
  }

  #MV2 .MV2_text_2 {
    font-size: 4vw;
    letter-spacing: 0.87em;
  }
}

@media (max-width: 480px) {
  .priceBox01 span {
    font-size: 8px;
    letter-spacing: 0.1em;
  }

  #MV2 .MV2_inner svg {
    width: 114%;
    padding-bottom: 10px;
  }

  #MV2 .MV2_left img {
    width: 250px;
  }

  #MV2 .MV2_text_2 {
    margin-top: -5px;
  }

  #MV2 .MV2_text {
    font-size: 4.1vw;
    letter-spacing: 0.53em;
  }

  #MV2 .MV2_text_2 {
    font-size: 4.1vw;
    letter-spacing: 0.73em;
  }

  #MV2 .priceBox01,
  #MV2 .priceBox02 {
    margin-top: 10px;
  }

  #MV2 .MV2_banner {
    margin-top: 10px;
  }

  #MV2 hr {
    display: none;
  }

  #MV2 {
    padding-left: 10%;
    padding-right: 10%;
  }

  #MV2 .MV2_right {
    padding-left: 0;
    padding-right: 0;
  }

  #MV2 .MV2_left {
    padding-top: 0px;
  }
}

@media (max-width: 375px) {

  .priceBox01_r,
  .priceBox02_r {
    font-size: 1.2em;
  }

  .priceBox01_l,
  .priceBox02_l {
    font-size: 0.9em;
  }
}

@media (max-width: 320px) {
  #MV2 .MV2_text {
    font-size: 13px;
    letter-spacing: 0.6em;
  }

  #MV2 .MV2_text_2 {
    font-size: 13px;
    letter-spacing: 0.8em;
  }

  .priceBox01_r,
  .priceBox02_r,
  .priceBox01_l,
  .priceBox02_l {
    font-size: 0.8em;
  }
}

#SERVICE {
  background-image: url(../img/SERVICE_back.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  padding-top: 50px;
  padding-bottom: 130px;
}

.title_text h2 {
  font-size: 2.8em;
}

.title_text hr {
  width: 200px;
  border-top: 1px solid #000;
  margin: auto;
  margin-bottom: 10px;
}

.title_text p {
  font-size: 1.4em;
  letter-spacing: 0.1em;
}

h4.topService {
  font-size: 25px;
  margin-top: 0px;
}

#SERVICE .box {
  border-top: 5px solid #000;
  background: #fff;
  -webkit-box-shadow: 2.828px 2.828px 5px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 2.828px 2.828px 5px 0px rgba(0, 0, 0, 0.1);
  padding: 35px 20px 30px 20px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

#SERVICE .box h4 {
  font-weight: 600;
  font-size: 1.3em;
}

#SERVICE .box p {
  font-size: 13px;
}

#SERVICE .box .number {
  position: absolute;
  font-size: 140px;
  opacity: 0.1;
  top: -30px;
  bottom: 0;
}

#PLAN {
  padding-top: 100px;
  padding-bottom: 130px;
}

#PLAN h3 {
  font-size: 2.2em;
}

#PLAN .PLAN_fee {
  margin-top: -25px;
  text-align: center;
  font-size: 2em;
}

#PLAN .PLAN_fee span {
  font-size: 0.6em;
  margin-left: -5px;
  letter-spacing: 0.2em;
}

.title_subtext {
  font-size: 15px;
  letter-spacing: 0.15em;
  margin-top: 20px;
}

#PLAN table {
  font-size: 0.9em;
  width: 100%;
  max-width: 300px;
  margin: auto;
  margin-top: 10px;
}

#PLAN table tr td {
  padding: 10px;
  text-align: left;
  padding-left: 30px;
}

.tab_wrap #PLAN table tr td {
  padding: 10px;
}

#PLAN table tr td:nth-child(2) {
  text-align: right;
  padding-right: 20px;
  padding-left: 0;
}

.plan_box {
  box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
}

.tab_wrap #PLAN {
  padding-top: 0;
  padding-bottom: 0;
}

#FLOW {
  padding-top: 100px;
  padding-bottom: 100px;
  background-color: #f8f8f8;
  background-position: right;
  background-size: cover;
}

@media (max-width: 480px) {
  #FLOW {
    padding-bottom: 100px;
  }
}

#FLOW h4 {
  font-size: 18px;
  text-align: center;
  font-weight: bold;
  margin-top: 20px;
  letter-spacing: 0.1em;
}

#FLOW div:nth-child(3) h4 {
  font-size: 17px;
  text-align: center;
  font-weight: bold;
  margin-top: 20px;
  letter-spacing: 0.1em;
}

#FLOW .flow_text p {
  font-size: 15px;
  letter-spacing: 0.2em;
  font-weight: 300;
  margin-top: 15px;
  padding: 0px 10px;
}

a.flowAnchor {
  display: block;
  margin-top: 5px;
  color: #07aef9;
}

a.flowAnchor::before {
  content: '\f363';
  padding-right: 10px;
  line-height: 1.8;
  font-family: ionicons;
}

@media (max-width: 991px) {
  #FLOW .flow_text p {
    text-align: center;
    padding: 0px;
  }

  #PLAN .box {
    clear: both;
    width: calc(100% / 0.92);
    background: #f4f4f4;
    margin-left: -4%;
    -webkit-box-shadow: 40.305px 40.305px 80px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 40.305px 40.305px 80px 0px rgba(0, 0, 0, 0.2);
    margin-bottom: 100px;
    margin-top: -50px;
    -webkit-transition: 0.6s;
    transition: 0.6s;
    -webkit-transition-timing-function: ease-out;
    transition-timing-function: ease-out;
  }

  #PLAN .box:first-child {
    margin-left: -4%;
    margin-top: 20px;
  }

  #PLAN .PLAN_inner .phone_margin {
    margin-left: 25px;
    margin-right: 25px;
    padding-right: 15px;
    padding-left: 15px;
    margin: auto;
    max-width: 470px;
  }

  #PLAN .box_choice {
    width: calc(100% / 2 - 2%);
  }

  #PLAN .choice .box01 {
    margin-left: 0;
    border-top: 5px solid #07aef9;
  }

  #PLAN .other_margin {
    margin-left: 25px;
    margin-right: 25px;
    margin: auto;
    max-width: 470px;
  }
}

@media (max-width: 767px) {
  #PLAN .concept h5 {
    font-size: 1.2em;
    line-height: 1.8em;
  }

  #PLAN .phone_margin {
    margin-left: 15px;
    margin-right: 15px;
  }

  #PLAN .top_subtitle h2,
  #SERVICE .top_subtitle h2,
  #SUPPORT .top_subtitle h2,
  #FLOW .top_subtitle h2 {
    font-size: 2em;
    font-weight: bold;
    letter-spacing: 0.2em;
    text-align: center;
  }
}

#SUPPORT {
  padding-top: 100px;
  padding-bottom: 100px;
}

#SUPPORT h4 {
  font-size: 20px;
  font-weight: bold;
}

#SUPPORT .text01 {
  margin-top: 20px;
  line-height: 24px;
  font-size: 16px;
  letter-spacing: 0.1em;
}

#SUPPORT .text02 {
  font-size: 15px;
  line-height: 20px;
  letter-spacing: 0.1em;
}

#SUPPORT .icon {
  margin-top: 40px;
}

#SUPPORT .support_btn {
  padding: 15px 30px;
  background: #fabc27;
  color: #fff;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  font-weight: bold;
  font-size: 16px;
  border-radius: 5px;
  -webkit-box-shadow: 39.598px 20px 60px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 39.598px 20px 60px 0px rgba(0, 0, 0, 0.2);
}

#SUPPORT .support_btn:hover {
  background: #e9a80c;
}

#OUR {
  margin-top: 150px;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

#OUR h2 {
  font-weight: bold;
  font-size: 25px;
  letter-spacing: 0.2em;
  text-align: center;
  color: #fff;
}

#OUR p {
  text-align: center;
  font-size: 16px;
  line-height: 25px;
  margin-top: 15px;
  letter-spacing: 0.1em;
  color: #fff;
  font-weight: 500;
}

#OUR .our_btn01,
#OUR .our_btn02 {
  margin-top: 10px;
}

#OUR .our_btn01 a:hover {
  background: #49b600;
}

.our_btn02 a,
.our_btn02 button {
  padding: 15px 30px;
  letter-spacing: 0.2em;
  background: #1889ea;
  color: #fff;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  font-weight: bold;
  font-size: 16px;
  border-radius: 5px;
  -webkit-box-shadow: 39.598px 20px 60px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 39.598px 20px 60px 0px rgba(0, 0, 0, 0.2);
}

.our_btn02 a:hover,
.our_btn02 button:hover {
  background: #1378ce;
}

#OUR .btn {
  background: #fabc27;
  color: #fff;
  font-size: 17px;
  letter-spacing: 0.2em;
  font-weight: bold;
  padding: 10px 40px;
  border-radius: 3px;
  -webkit-box-shadow: 39.598px 39.598px 120px 0px rgba(0, 0, 0, 0.4);
  box-shadow: 39.598px 39.598px 120px 0px rgba(0, 0, 0, 0.4);
  margin-top: 20px;
}

@media (max-width: 480px) {
  #OUR h2 {
    font-size: 5.5vw;
  }
}

#footer {
  background-image: url(../img/footer/back.webp);
  background-position: center;
  background-size: cover;
  padding-top: 80px;
  padding-bottom: 220px;
  padding-left: 15px;
  padding-right: 15px;
  color: #fff;
  position: relative;
  -webkit-box-shadow: inset 0px 157px 34px -114px rgba(0, 0, 0, 0.1);
  box-shadow: inset 0px 157px 34px -114px rgba(0, 0, 0, 0.1);
}

.icon-open::after {
  content: '';
  background-image: url(/assets/img/open.png);
  display: inline-block;
  width: 12px;
  height: 12px;
  background-size: contain;
  vertical-align: middle;
  margin-left: 2px;
}

#footer h4 {
  color: #000;
  font-size: 19px;
}

#footer ul {
  color: #000;
  padding-left: 0;
}

#footer a {
  color: #000;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  margin-left: -5px;
  font-size: 12px;
}

#footer a:hover {
  opacity: 0.8;
}

#footer p {
  font-size: 14px;
  letter-spacing: 0.1em;
  color: #000;
}

#footer ul li {
  font-size: 15px;
  line-height: 1.1;
  margin-bottom: 8px;
  letter-spacing: 0.1em;
}

#footer .footer_bottom {
  padding-top: 25px;
  padding-bottom: 25px;
  background: rgba(0, 0, 0, 0.75);
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

#footer .footer_bottom .footer_bottomIN {
  display: block;
  margin: auto;
  left: 0;
  right: 0;
}

#footer i {
  font-size: 0.3em !important;
}

#footer .footer_sns img {
  padding-top: 10px;
}

#footer .footer_sns a {
  margin: 15px;
}

#footer .footer_sns a:first-child {
  margin-left: 0px;
}

@media (max-width: 991px) {
  #footer .footer_sns a:first-child {
    margin-left: 14px;
  }

  #footer a {
    font-size: 13px;
  }
}

.F_col1 {
  width: 28%;
}

.F_col2 {
  width: 26%;
}

.F_col3 {
  width: 20%;
  margin-left: 2%;
}

.F_col4 {
  width: 15%;
  margin-left: 2%;
}

.trans_btn {
  color: #000;
  border: 1px solid;
  border-radius: 30px;
  padding: 10px 38px;
  line-height: 4em;
  letter-spacing: 0.1em;
  font-size: 0.9em;
}

.blue_btn {
  background: #30b6fc;
  color: #fff !important;
  font-weight: bold;
  border-radius: 30px;
  padding: 6px 16px;
  line-height: 4em;
  -webkit-box-shadow: 16.263px 16.263px 40px 0px rgba(0, 0, 0, 0.25);
  box-shadow: 16.263px 16.263px 40px 0px rgba(0, 0, 0, 0.25);
  letter-spacing: 0.1em;
}

.blue_btn2 {
  background: #1889ea;
  color: #fff !important;
  font-weight: bold;
  border: 1px solid #1889ea;
  border-radius: 30px;
  padding: 10px 40px;
  -webkit-box-shadow: 16.263px 16.263px 40px 0px rgba(0, 0, 0, 0.25);
  box-shadow: 16.263px 16.263px 40px 0px rgba(0, 0, 0, 0.25);
  letter-spacing: 0.1em;
}

.cta-btn--yellow {
  background-color: #E6BA3F;
}

@media (max-width: 1199px) {
  .trans_btn {
    padding: 6px 20px;
    font-size: 0.8em;
  }

  #footer ul li {
    font-size: 0.85em;
  }

  #footer h4 {
    font-size: 1em;
  }

  #footer p {
    font-size: 0.8em;
  }

  .blue_btn {
    padding: 10px 20px;
    font-size: 1em;
  }
}

@media (max-width: 768px) {
  .F_col1 {
    width: 35%;
  }

  .F_col2 {
    width: 26%;
  }

  .F_col3 {
    width: 15%;
  }

  .F_col4 {
    width: 15%;
  }

  .trans_btn {
    padding: 6px 15px;
    font-size: 0.9em;
  }

  .blue_btn {
    padding: 12px 30px;
    letter-spacing: 0;
  }
}

.share {
  margin-top: 60px;
  margin-bottom: 20px;
}

.share h3 {
  font-size: 25px;
  letter-spacing: 0.2em;
  font-weight: bold;
}

.share img {
  -webkit-box-shadow: 25px 25px 40px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 25px 25px 40px 0px rgba(0, 0, 0, 0.2);
  margin-top: 30px;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  border-radius: 10px;
}

.share iframe {
  -webkit-box-shadow: 25px 25px 40px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 25px 25px 40px 0px rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  width: 45px !important;
  margin: auto;
  display: block;
  margin-top: 30px;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

@media (max-width: 480px) {
  #footer .footer_bottom {
    padding-top: 15px;
    padding-bottom: 75px;
  }

  #PLAN .top_subtitle h2,
  #SERVICE .top_subtitle h2,
  #SUPPORT .top_subtitle h2,
  #FLOW .top_subtitle h2 {
    font-size: 1.5em;
  }

  #OUR p br {
    display: none;
  }

  #footer .list {
    margin-top: -15px;
  }

  #footer p {
    font-size: 13px;
    letter-spacing: 0.15em;
  }

  .title_text img {
    height: 24px;
  }
}

@media (min-width: 481px) {
  .BR_none {
    display: none;
  }

  .cb-slideshow2 p span {
    display: none;
  }
}

/*

SUBPAGE

*/

.page-sub-title {
  background-color: #65C4E7;
  background-image: none;
  padding: 102px 0 46px;
}

.page-sub-title-text {
  margin-bottom: 8px;
}

.page-sub-title>p {
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: 0;
}

.page-sub-title>p .sp-only {
  display: block;
}

.page-sub-title>p .sp-only a {
  color: #fff;
  text-decoration: underline !important;
}

.page-sub-title>p .block a {
  color: #fff;
  text-decoration: underline !important;
}

.page-sub-title>.text-center {
  margin-bottom: 0;
}

@media screen and (min-width:566px) {
  .page-sub-title>p .sp-only {
    display: none;
  }
}

@media screen and (min-width:768px) {
  .page-sub-title {
    padding: 46px 0;
  }
}

.page-sub-title-text {
  font-size: 24px;
  text-align: center;
  color: #fff;
  letter-spacing: 0.05em;
  font-weight: 700;
  text-shadow: 2.5px 2.5px 0px rgba(0, 0, 0, 0.4);
  margin-top: 0;
}

#SUBPAGE_TITLE p {
  font-size: 14px;
  text-align: center;
  font-weight: 400;
  color: #fff;
  line-height: 1.6;
  padding: 0 20px;
}

#SUBPAGE_TITLE2 {
  padding-top: 20px;
  padding-bottom: 30px;
}

#SUBPAGE_TITLE2 h2 {
  font-size: 45px;
  text-align: center;
  color: #fff;
  letter-spacing: 0.1em;
}

#SUBPAGE_TITLE2 hr {
  width: 230px;
  margin-top: 15px;
  margin-bottom: 15px;
  border-top: 1px solid #fff !important;
}

#SUBPAGE_TITLE2 p {
  font-size: 22px;
  text-align: center;
  color: #fff;
  letter-spacing: 0.1em;
  font-weight: 600;
}

#CONTENT h3 {
  font-size: 26px;
  letter-spacing: 0.2em;
  font-weight: 600;
}

#CONTENT .plan_contentWhite h3,
#CONTENT .plan_contentBlack h3 {
  font-size: 29px;
  font-weight: 900;
  letter-spacing: 0.05em;
}

#CONTENT p.service {
  margin-top: 10px;
  text-align: center;
  font-size: 25px;
  letter-spacing: 0em;
}

.content01,
.content02,
.content03,
.content04,
.content05,
.content06 {
  margin-top: 80px;
}

.accordion {
  margin-top: 50px;
  background: none;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  border-radius: 3px;
}

.heading {
  font-size: 17px;
  font-weight: bold;
  border-bottom: 1px solid #cdcdcd;
  letter-spacing: 0.1em;
  padding: 25px;
  cursor: pointer;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

.heading:nth-last-child(2) {
  border-bottom: 0;
}

.heading:hover {
  background: #f7f7f7;
  border-radius: 0;
}

.heading:first-child:hover {
  border-radius: 3px 3px 0 0;
}

.heading:nth-last-child(2):hover {
  border-radius: 0 0 3px 3px;
}

.heading::before {
  content: '';
  vertical-align: middle;
  display: inline-block;
  border-top: 7px solid #333;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  float: right;
  -webkit-transform: rotate(0);
  transform: rotate(0);
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  margin-top: 10px;
  margin-left: 15px;
}

.active.heading {
  background: #f7f7f7;
}

.active.heading::before {
  -webkit-transform: rotate(-180deg);
  transform: rotate(-180deg);
}

.not-active.heading::before {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.contents {
  display: none;
  background: #fff;
  padding: 30px 40px;
  font-size: 14px;
  line-height: 22px;
  letter-spacing: 0.1em;
  text-align: justify;
}

@media (max-width: 991px) {
  #CONTENT h3 {
    font-size: 24px;
  }

  #OUR .our_btn01 {
    text-align: center;
  }

  #OUR .our_btn01 {
    margin-top: 30px;
  }

  #OUR .our_btn01 a {
    float: inherit;
    width: 300px !important;
  }
}

.sp_start {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 999;
  width: 100%;
}

.sp_start .box01 {
  float: left;
  width: 50%;
  text-align: center;
  color: #fff;
  font-weight: bold;
  background: #6cce2a;
}

.sp_start .box02 {
  float: left;
  width: 100%;
  text-align: center;
  color: #fff;
  font-weight: bold;
  background: #fc3058;
  letter-spacing: 0.2em;
}

.sp_start .box01,
.sp_start .box02 {
  padding-top: 20px;
  padding-bottom: 10px;
  letter-spacing: 0.05em;
}

@media (min-width: 768px) {
  .sp_start {
    display: none;
  }
}

@media (max-width: 200px) {

  .sp_start .box01,
  .sp_start .box02 {
    padding-top: 10px;
    padding-bottom: 0px;
    letter-spacing: 0em;
    font-size: 0.8em;
  }

  #SUBPAGE_TITLE h2 {
    font-size: 8vw;
  }
}

.tab_wrap {
  margin: 10px auto 80px auto;
  max-width: 1000px;
}

.tab_area {
  font-size: 0;
  padding: 0 55px;
  display: flex;
  align-items: flex-end;
}

.tab_area .apply_label {
  display: inline-block;
  padding: 12px 0 10px;
  color: #fff;
  background: #000;
  text-align: center;
  cursor: pointer;
  -webkit-transition: ease 0.2s opacity;
  transition: ease 0.2s opacity;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  vertical-align: bottom;
  -webkit-transition: ease 0.2s;
  transition: ease 0.2s;
  margin: 10px 5px 0;
  width: 33%;
  font-size: 24px;
  transition: ease 0.2s opacity;
  font-weight: 500;
}

.apply_label.active {
  padding-bottom: 20px !important;
}

@media (max-width: 500px) {
  .tab_area .apply_label {
    display: inline-block;
    padding: 14px 0 12px;
    color: #fff;
    background: #d4f7bc;
    text-align: center;
    cursor: pointer;
    -webkit-transition: ease 0.2s opacity;
    transition: ease 0.2s opacity;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    vertical-align: bottom;
    -webkit-transition: ease 0.2s;
    transition: ease 0.2s;
    width: 46.5%;
    font-size: 17px;
    transition: ease 0.2s opacity;
  }

  .tab_area {
    padding: 0;
  }

  /* #SUBPAGE_TITLE {
    padding-top: 90px;
    padding-bottom: 50px;
  }

  #SUBPAGE_TITLE h2 {
    font-size: 7vw;
  } */

  #SUBPAGE_TITLE2 {
    padding-top: 30px;
    padding-bottom: 30px;
  }

  #SUBPAGE_TITLE2 h2 {
    font-size: 7vw;
  }
}

.tab_area .apply_label:hover {
  opacity: 1;
}

.tab_panel {
  width: 100%;
  padding: 80px 0;
}

.tab_panel p {
  font-size: 14px;
  letter-spacing: 1px;
  text-align: center;
}

.panel_area {
  background: #ffffff;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
}

.tab_panel {
  width: 100%;
  padding: 80px 0;
  display: none;
}

.tab_panel p {
  font-size: 16px;
  letter-spacing: 1px;
  text-align: center;
}

#tab1:checked~.tab_area .tab1_label,
#tab0:checked~.tab_area .tab0_label {
  padding-bottom: 10px;
}

#tab0:checked~.panel_area #50gb {
  display: block;
}

#tab1:checked~.panel_area #100gb {
  display: block;
}

#tab2:checked~.tab_area .tab2_label {
  padding-bottom: 11px;
}

.tab_area .tab2_label {
  background: #ffb1c0;
}

#tab2:checked~.panel_area #panel2 {
  display: block;
}

.apply-tab .box_choice {
  background: #fff;
  float: left;
  width: 350px;
  padding: 26px 3%;
  padding-top: 26px;
  -webkit-box-shadow: 0px 23px 77px -48px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 23px 77px -48px rgba(0, 0, 0, 0.2);
}

.apply-tab .choice .box01 {
  border-top: 5px solid #07aef9;
}

.apply-tab .choice .box02 {
  border-top: 5px solid #eb1f1f;
}

.apply-tab .choice .box01 h5 {
  font-size: 16px;
  color: #07aef9;
  font-weight: bold;
}

.apply-tab.choice .box02 h5 {
  font-size: 16px;
  color: #eb1f1f;
  font-weight: bold;
}

.apply-tab .price_choice {
  font-size: 32px;
  font-weight: bold;
  margin-bottom: 0;
  margin-top: 10px;
}

.price_choice-flex {
  display: flex;
  justify-content: center;
  align-items: center;
}

.price_choice {
  width: auto !important;
}

.price_choice tr {
  display: flex;
  justify-content: flex-end;
}

.price_choice th:nth-of-type(1) {
  margin-top: auto;
  padding-bottom: 42px;
}

@media (max-width: 480px) {
  .can-price {
    padding-right: 15px !important;
  }

  .price_choice th:nth-of-type(1) {
    padding-bottom: 33px;
  }

  .price_choice th.price-left {
    margin-right: 7px;
  }
}

.price_choice th:nth-of-type(2) {
  margin-left: auto;
}

.price_choice tr th {
  border-top: none !important;
  line-height: 0.45em !important;
}

.apply-tab .price_choice span {
  font-size: 0.5em;
  font-weight: normal;
  padding-left: 5px;
}

.apply-tab .PLAN_subtitle {
  width: 190px;
  display: inline-block;
}

.apply-tab .box_choice .left {
  float: left;
}

.apply-tab .box_choice .left {
  padding-right: 10px;
}

.apply-tab .other_text {
  letter-spacing: 0.2em;
  font-size: 14px;
  color: #949494;
}

.apply-tab .box h4 {
  text-align: center;
  font-size: 23px;
  letter-spacing: 0.012em;
  background: #0066ff;
  display: inline-block;
  padding: 7px 20px;
  padding-top: 10px;
  border-radius: 50px;
}

.apply-tab .box_top {
  padding-top: 20px;
  padding-bottom: 20px;
  color: #fff;
  text-align: center;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
}

.apply-tab .box_top {
  background: #07aef9;
}

.apply-tab .box_top hr {
  max-width: 180px;
  margin-top: 8px;
  margin-bottom: 8px;
}

.apply-tab .box p span:first-child {
  font-size: 36px;
  letter-spacing: -0.012em;
  font-weight: bold;
}

.apply-tab .box p span:nth-child(2) {
  font-size: 26px;
  letter-spacing: -0.012em;
}

.apply-tab .box p {
  font-size: 15px;
  margin-bottom: 0;
}

.apply-tab .box_bottom {
  padding: 40px;
  padding-bottom: 45px;
  background: #f7f7f7;
}

.apply-tab .table-css table {
  width: 100%;
}

.apply-tab .table-css table tr td {
  font-size: 15px;
  letter-spacing: 0.05em;
  padding-bottom: 15px;
  padding: 10px;
  text-align: left;
  padding-left: 30px;
}

.apply-tab .table-css table tr td:nth-child(2) {
  text-align: right;
  font-size: 14px;
  letter-spacing: 0;
  font-weight: 200;
  color: #939393;
  padding-right: 20px;
  padding-left: 0;
}

.apply-tab .start_btn a {
  position: absolute;
  width: 100%;
  height: 100%;
}

.apply-tab .box {
  max-width: 350px;
}

.apply-tab .box02 .box_top {
  background: #6cce2a;
}

.apply-tab .box02 .box_bottom {
  border-left: none;
  border-right: none;
}

.apply-tab.box03 .box_bottom {
  border-left: none;
  border-right: none;
}

.apply-tab .flow {
  display: inline-block;
  margin: auto;
}

.apply-tab.flow01 {
  background: #fabc27;
  padding: 20px 50px;
  font-size: 17px;
  font-weight: bold;
  color: #ffff;
  letter-spacing: 0.1em;
  display: inherit;
  margin: 10px;
}

.apply-tab .flow02 {
  background: #aeaeae;
  padding: 20px 50px;
  font-size: 17px;
  font-weight: bold;
  color: #ffff;
  letter-spacing: 0.1em;
  display: inherit;
  margin: 10px;
}

.apply-tab form {
  width: 800px;
  margin: auto;
}

.plan_arrowSpace {
  position: relative;
  float: left;
  width: 100%;
  height: 50px;
  padding-top: 20px;
  padding-bottom: 40px;
  max-width: 350px;
}

.plan_arrow {
  width: 0;
  height: 0;
  border-top: 20px solid #4b8db0;
  border-right: 60px solid transparent;
  border-bottom: 30px solid transparent;
  border-left: 60px solid transparent;
  left: 10px;
  right: 0;
  margin: auto;
  position: absolute;
}

@media (max-width: 991px) {
  .plan_arrowSpace {
    max-width: 100%;
  }

  .plan_arrow {
    width: 0;
    height: 0;
    border-top: 20px solid #4b8db0;
    border-right: 60px solid transparent;
    border-bottom: 30px solid transparent;
    border-left: 60px solid transparent;
    left: 0;
    right: 0;
    margin: auto;
    position: absolute;
  }

  #50gb .box,
  #100gb .box,
  #panel2 .box {
    padding-bottom: 50px;
  }
}

@media (max-width: 967px) {

  #50gb form,
  #100gb form,
  #panel2 form {
    width: 100%;
  }
}

.apply-tab form .left {
  float: left;
  width: 50%;
}

.apply-tab form .right {
  float: left;
  width: 50%;
}

.apply-tab form label {
  color: #333;
}

.apply-tab .Ti02 {
  font-size: 20px;
  padding-bottom: 10px;
  padding-top: 30px;
  letter-spacing: 0.15em;
}

.firstFee {
  margin-top: 50px;
  max-width: 790px;
}

.firstFee h5 {
  font-size: 20px;
  letter-spacing: 0.1em;
  font-weight: bold;
  text-align: center;
}

.firstFee p {
  font-size: 16px;
  letter-spacing: 0.1em;
}

.fF_price {
  text-align: center;
  font-size: 32px !important;
  letter-spacing: 0em !important;
  font-weight: bold;
  color: #fff;
}

.fF_price:nth-child(3) {
  margin-top: -5px;
}

.firstFee .left {
  padding-top: 30px;
  padding-bottom: 40px;
  background: #ffb423;
  width: 48%;
  float: left;
  color: #fff;
}

.firstFee .center {
  width: 6%;
  float: left;
  background: -webkit-gradient(linear,
      right top,
      left bottom,
      color-stop(50%, #fff),
      color-stop(50.5%, #ffb423)) no-repeat top left/100% 50.5%,
    -webkit-gradient(linear,
      right bottom,
      left top,
      color-stop(50%, #fff),
      color-stop(50.5%, #ffb423)) no-repeat bottom right/100% 50.5%;
  background: linear-gradient(to bottom left, #fff 50%, #ffb423 50.5%) no-repeat top left/100% 50.5%,
    linear-gradient(to top left, #fff 50%, #ffb423 50.5%) no-repeat bottom right/100% 50.5%;
}

.pro_fF .firstFee .left {
  background: #17c6ff;
}

.pro_fF .firstFee .center {
  background: -webkit-gradient(linear,
      right top,
      left bottom,
      color-stop(50%, #48d6ff),
      color-stop(50.5%, #17c6ff)) no-repeat top left/100% 50.5%,
    -webkit-gradient(linear,
      right bottom,
      left top,
      color-stop(50%, #48d6ff),
      color-stop(50.5%, #17c6ff)) no-repeat bottom right/100% 50.5%;
  background: linear-gradient(to bottom left, #48d6ff 50%, #17c6ff 50.5%) no-repeat top left/100% 50.5%,
    linear-gradient(to top left, #48d6ff 50%, #17c6ff 50.5%) no-repeat bottom right/100% 50.5%;
}

.firstFee .right {
  width: 45%;
  float: left;
  background: #fff;
}

.firstFee .right h5 {
  margin-top: 40px;
}

.pro_fF .firstFee .right {
  background: #48d6ff;
}

.firstFee .right .fF_price {
  text-align: center;
  font-size: 35px !important;
  letter-spacing: 0em !important;
  font-weight: bold;
  color: #464646;
}

@media (max-width: 767px) {
  .firstFee .left {
    width: 100%;
    float: inherit;
    height: auto !important;
    padding-bottom: 10px;
  }

  .firstFee .center {
    width: 100%;
    height: 40px !important;
    float: inherit;
    background: -webkit-gradient(linear,
        left bottom,
        right top,
        color-stop(50%, #feca2d),
        color-stop(50.5%, #ffb423)) no-repeat top left/50.5% 100%,
      -webkit-gradient(linear,
        right bottom,
        left top,
        color-stop(50%, #feca2d),
        color-stop(50.5%, #ffb423)) no-repeat top right/50.5% 100%;
    background: linear-gradient(to top right, #feca2d 50%, #ffb423 50.5%) no-repeat top left/50.5% 100%,
      linear-gradient(to top left, #feca2d 50%, #ffb423 50.5%) no-repeat top right/50.5% 100%;
  }

  .pro_fF .firstFee .center {
    width: 100%;
    height: 40px !important;
    float: inherit;
    background: -webkit-gradient(linear,
        left bottom,
        right top,
        color-stop(50%, #48d6ff),
        color-stop(50.5%, #17c6ff)) no-repeat top left/50.5% 100%,
      -webkit-gradient(linear,
        right bottom,
        left top,
        color-stop(50%, #48d6ff),
        color-stop(50.5%, #17c6ff)) no-repeat top right/50.5% 100%;
    background: linear-gradient(to top right, #48d6ff 50%, #17c6ff 50.5%) no-repeat top left/50.5% 100%,
      linear-gradient(to top left, #48d6ff 50%, #17c6ff 50.5%) no-repeat top right/50.5% 100%;
  }

  .firstFee .right {
    width: 100%;
    float: inherit;
    height: auto !important;
  }

  .firstFee .right .fF_price {
    padding-bottom: 40px;
  }

  .firstFee .right h5 {
    margin-top: 0px;
    padding-top: 30px;
  }

  #50gb form .Ti02,
  #100gb form .Ti02,
  #panel2 form .Ti02 {
    font-size: 18px;
  }
}

select {
  height: 30px;
}

.apply-tab input[type='text'] {
  height: 40px;
  width: 80%;
  padding-left: 8px;
}

.apply-tab .kome {
  text-align: left;
  color: #1aa6ff;
  font-size: 14px;
  font-weight: 500;
}

.apply-tab .kome2 {
  text-align: left;
  color: #939393;
  font-size: 14px;
  font-weight: 500;
}

input[type='file'] {
  font-size: 13px;
}

.kiyaku {
  padding: 30px;
  background: #f9f9f9;
  color: #939393;
  height: 300px;
  overflow-x: hidden;
  overflow-y: scroll;
}

.kiyaku h5 {
  font-size: 14px;
  font-weight: bold;
}

.kiyaku p {
  text-align: left;
  font-size: 14px;
}

.checkbox_text {
  font-size: 16px;
}

.apply-tab input[type='submit'] {
  padding: 15px 60px;
  background: #1889ea;
  color: #fff;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: bold;
  border-radius: 5px;
  -webkit-box-shadow: 39px 39px 60px 0px rgba(0, 0, 0, 0.3);
  box-shadow: 39px 39px 60px 0px rgba(0, 0, 0, 0.3);
  border: none;
}

.none_check input[type='radio'] {
  display: none;
}

.esim-flex {
  display: flex;
  width: 900px;
  max-width: 90%;
  margin: auto;
  justify-content: space-between;
  margin-top: 50px;
}

.esim-flex_left {
  width: 60%;
  padding: 0 30px;
}

.esim-flex_right {
  width: 40%;
}

.esim-flex_right img {
  display: block;
  width: 320px;
  max-width: 100%;
  border: 1px solid #ddd;
  border-radius: 10px;
  margin: auto;
}

.esim-subTitle {
  z-index: 2;
  position: relative;
}

.cloud-bg {
  position: relative;
}

.tivel {
  position: absolute;
  top: -70px;
  width: 340px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 1;
}

.esim-subTitle {
  display: flex;
  width: fit-content;
  margin: auto;
  justify-content: space-between;
  margin-top: 100px;
}

.esim-subTitle h4 {
  font-weight: 600;
  padding-left: 10px;
}

.esim-textBox {
  width: 500px;
  margin: auto;
  max-width: 100%;
  padding: 10px;
  margin-top: 50px;
}

@media (max-width: 576px) {
  .esim-flex {
    align-items: center;
    flex-direction: column;
  }

  .esim-flex_left,
  .esim-flex_right {
    width: 100%;
  }

  .esim-flex_left {
    padding: 0;
  }
}

@media (max-width: 991px) {
  .apply-tab form {
    width: 100%;
  }

  .apply-tab form .left {
    width: 100%;
    float: inherit;
    clear: both;
  }

  .apply-tab form .right {
    width: 100%;
    float: inherit;
    clear: both;
    margin-top: 20px;
  }

  .apply-tab .box_choice {
    float: inherit;
    clear: both;
    margin-top: 0 !important;
    margin: auto;
  }

  .apply-tab .box {
    max-width: 500px;
    margin: auto;
  }

  .apply-tab .box_choice {
    max-width: 500px;
    width: 100%;
  }

  .APN .step3 .col-md-6:nth-child(2) h5 {
    margin-top: 50px;
  }
}

h3.applyForm+hr {
  margin-bottom: 0px;
  border-color: #d0d0d0;
  width: 80%;
}

p::-webkit-scrollbar {
  width: 12px;
}

p::-webkit-scrollbar-track {
  background: #fff;
  border: none;
  border-radius: 10px;
  -webkit-box-shadow: inset 0 0 2px #777;
  box-shadow: inset 0 0 2px #777;
}

p::-webkit-scrollbar-thumb {
  background: #aaa;
  border-radius: 10px;
  -webkit-box-shadow: none;
  box-shadow: none;
}

.success p:nth-child(2) {
  font-size: 20px;
  font-weight: bold;
  margin-top: 20px;
  letter-spacing: 0.2em;
}

.success p:nth-child(3) {
  font-size: 16px;
  letter-spacing: 0.2em;
  font-weight: 500;
  margin-top: 20px;
}

.success {
  padding-bottom: 100px;
}

.APN p {
  font-size: 16px;
  letter-spacing: 0.2em;
  line-height: 26px;
}

.APN h4 {
  font-size: 21px;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  margin-top: 100px;
}

.APN .step1 p:nth-child(3),
.APN .step2 p:nth-child(3),
.APN .step4 p:nth-child(3) {
  font-size: 16px;
  letter-spacing: 0.2em;
  font-weight: 500;
  text-align: center;
  margin-top: 30px;
}

.APN .step1 p:nth-child(4) {
  font-size: 15px;
  letter-spacing: 0.2em;
  text-align: center;
  color: #a8a8a8;
}

.APN .step3 h5 {
  font-size: 22px;
}

.APN .step3 .h501::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 24px;
  margin-right: 10px;
  margin-top: -8px;
  background: url('../img/APN/icon01.png') no-repeat;
  background-size: contain;
  vertical-align: middle;
}

.APN .step3 .h502::before {
  content: '';
  display: inline-block;
  width: 23px;
  height: 27px;
  margin-right: 13px;
  margin-top: -7px;
  background: url('../img/APN/icon02.png') no-repeat;
  background-size: contain;
  vertical-align: middle;
}

.APN .step3 .device {
  padding: 0px 30px;
}

.APN .step3 p:nth-child(2) {
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 500;
  margin-top: 10px;
}

.APN .APN_btn {
  background: #1889ea;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  padding: 10px 20px;
  border-radius: 5px;
  letter-spacing: 0.1em;
}

.APN .ios_box {
  background: #f7f7f7;
  padding: 30px 40px;
  border-top: 5px solid #4b8db0;
  width: 280px;
  margin: auto;
  margin-top: 30px;
  line-height: 2em;
}

.cancel {
  margin-bottom: 150px;
}

.cancel h3,
.purchase h3 {
  font-size: 30px !important;
  margin-top: 150px;
  line-height: 1.3em;
}

.cancel p:nth-child(2) {
  font-size: 20px;
  letter-spacing: 0.2em;
  font-weight: 500;
  text-align: center;
  margin-top: 20px;
}

.cancel p:nth-child(3) {
  font-size: 16px;
  letter-spacing: 0.2em;
  font-weight: 400;
  margin-top: 20px;
}

.page_list {
  text-align: left;
  color: #1aa6ff;
  font-size: 14px;
  line-height: 1.8em;
}

.page_list a {
  color: #1aa6ff;
  text-decoration: underline !important;
}

@media (max-width: 1118px) {
  .success p:nth-child(2) {
    font-size: 18px;
  }

  .cancel h3,
  .purchase h3 {
    font-size: 24px !important;
    margin-top: 150px;
  }
}

.purchase .main_text p:nth-child(2) {
  font-size: 20px;
  font-weight: bold;
  padding-bottom: 10px;
  letter-spacing: 0.2em;
}

.purchase .main_text p:nth-child(3) {
  font-size: 16px;
  padding-bottom: 10px;
  letter-spacing: 0.2em;
  font-weight: 500;
}

.purchase .main_text p:nth-child(4) {
  font-size: 14px;
  color: #fc3058;
  letter-spacing: 0.1em;
}

.purchase .purchase_text h5 {
  font-weight: bold;
  font-size: 16px;
}

.purchase .purchase_text {
  font-size: 15px;
  padding-bottom: 10px;
  letter-spacing: 0.1em;
  font-weight: 400;
}

.purchase .our_btn02 button {
  margin-top: 10px;
}

.purchase .img01 {
  margin-top: 100px;
  margin-bottom: 150px;
}

.spec p {
  font-size: 15px;
  font-weight: 500;
  line-height: 1.7em;
}

.contact input[type='text'],
.contact select {
  width: 100%;
  height: 44px;
  border: 1px solid #999;
  border-radius: 3px;
  padding: 10px;
  outline: 0;
  font-size: 14px;
}

.contact textarea {
  border: 1px solid #999;
  border-radius: 3px;
  padding: 10px;
  outline: 0;
}

.contact dt {
  margin-top: 30px;
}

.commerce table td {
  padding-top: 20px;
  padding-bottom: 20px;
}

.commerce table td:first-child {
  font-weight: 600;
}

.commerce table tr {
  border-bottom: 1px solid;
  padding-bottom: 10px;
}

.commerce table {
  margin-top: 100px;
}

.top_text {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.2em;
}

@media (max-width: 320px) {
  #CONTENT {
    overflow: hidden;
  }

  #50gb dd,
  #100gb dd,
  dt,
  #panel2 dd,
  dt {
    text-align: left;
  }

  .APN .APN_btn {
    font-size: 14px;
    padding: 10px 10px;
    letter-spacing: 0em;
  }
}

/*平澤追記*/

.contactMail {
  display: block;
  font-size: 18px;
  color: blue;
  padding-top: 20px;
  letter-spacing: 0.1em;
}

span.release {
  display: block;
  font-size: 13px;
  line-height: 19px;
  margin-top: 10px;
}

.testimoni {
  position: relative;
  float: left;
  overflow: hidden;
  margin: 10px 1%;
  max-width: 100%;
  width: 100%;
  color: #464646;
  text-align: left;
  line-height: 1.4em;
  background-color: #08b6ff;
  padding-top: 120px;
  border-radius: 10px;
}

.tesimoni h3 {
  font-weight: bold;
  color: white;
}

.testimoni * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.testimoni img {
  max-width: 100%;
  vertical-align: top;
  opacity: 0.85;
}

.testimoni .pic {
  width: 100%;
  background-color: #f7f7f7;
  padding: 25px;
  position: relative;
}

.testimoni .pic:before {
  position: absolute;
  content: '';
  bottom: 100%;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 55px 0 0 400px;
  border-color: transparent transparent transparent #f7f7f7;
}

.testimoni .profile {
  border-radius: 50%;
  position: absolute;
  bottom: 100%;
  left: 25px;
  z-index: 1;
  max-width: 90px;
  opacity: 1;
  -webkit-box-shadow: 0 0 15px rgba(0, 0, 0, 0.3);
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.3);
}

.testimoni h3 {
  font-size: 1.3em;
  margin: 25px;
  font-weight: 300;
  position: absolute;
  top: 0;
  right: 0;
  text-align: right;
  color: white;
  font-weight: bold;
}

.testimoni h3 span {
  display: block;
  font-size: 0.55em;
  letter-spacing: -0.05em;
  color: #fff;
}

.testimoni p {
  margin: 0 0 10px;
  padding: 0;
  letter-spacing: 1px;
  font-style: italic;
  font-weight: 300;
}

.testimoni a {
  text-decoration: underline;
  color: white;
  font-weight: bold;
  background: #6cce2a;
  border-radius: 5px;
  padding: 8px 12px;
  float: right;
}

.testimoni a:nth-child(odd) {
  background: #1da1f1;
}

.clear {
  clear: both;
}

.oshirase h4 {
  font-weight: bold;
  font-size: 22px;
}

.obon {
  background: #f9f9f9;
  padding: 25px 50px;
  text-align: center;
  border: 1px solid #e3e3e3;
}

.obon h4 {
  font-weight: 900;
  margin-bottom: 20px;
  font-size: 20px;
}

.obon p {
  letter-spacing: 0.1em;
}

@-webkit-keyframes Gradient {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

@keyframes Gradient {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

.change h3 {
  font-size: 1.7em !important;
}

/*SERVICE
サービス*/

#SUBPAGE_TITLE_service {
  overflow: hidden;
}

#SUBPAGE_TITLE_service h2 {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  height: 100%;
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 0.2em;
  top: 50%;
  font-size: 28px;
  font-weight: 700;
}

#SERVICE_sub {
  padding-bottom: 150px;
  background-image: url(../img/SERVICE_back.png);
  background-position: center;
  background-size: cover;
  background: #f7f7f7;
}

#SERVICE_sub .box {
  padding-bottom: 40px;
  background: #fff;
  -webkit-box-shadow: 2.828px 2.828px 5px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 2.828px 2.828px 5px 0px rgba(0, 0, 0, 0.1);
  text-align: center;
  position: relative;
  overflow: hidden;
}

#SERVICE_sub .box h4 {
  font-weight: 600;
  font-size: 1.4em;
}

#SERVICE_sub .box p {
  font-size: 15px;
  padding-left: 5%;
  padding-right: 5%;
}

#SERVICE_sub .box .text1 {
  font-weight: 500;
}

#SERVICE_sub .box .text2 {
  font-size: 0.8em;
  color: #707070;
}

.link {
  color: #0097ee;
  border-bottom: 1px solid #0097ee;
  letter-spacing: 0.05em;
}

p a.link {
  line-height: 20px;
}

#SERVICE_sub .box .number {
  position: absolute;
  font-size: 140px;
  opacity: 0.06;
  top: 0;
  bottom: 0;
}

#ser_scene {
  padding-top: 100px;
  padding-bottom: 100px;
}

#ser_scene .box01,
#ser_scene .box02 {
  border: 5px solid #000;
  position: relative;
  z-index: 3;
}

#ser_scene .box01 .box_top h4,
#ser_scene .box02 .box_top h4 {
  display: inline-block;
  padding: 15px 30px;
  background: #000;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.2em;
  font-size: 22px;
  margin-top: -30px;
  z-index: 2;
  position: relative;
}

#ser_scene .box01 .box_bottom,
#ser_scene .box02 .box_bottom {
  padding: 5% 5%;
  padding-bottom: 50px;
}

#ser_scene .box01 .ser_box01Img,
#ser_scene .box02 .ser_box02Img {
  z-index: 0;
  width: 100%;
  z-index: -5;
  /*  transform: scale(1.05);*/
}

#ser_scene ul {
  padding-left: 10px;
}

#ser_scene ul li {
  list-style: none;
  line-height: 1.8em;
  font-size: 0.9em;
}

#ser_device {
  padding-top: 100px;
  background: #f7f7f7;
}

#ser_device .dev_box {
  background: rgba(255, 255, 255, 1);
  margin-top: -70px;
  z-index: 2;
  position: relative;
  margin-left: 8%;
  margin-right: 8%;
  padding: 30px 50px;
}

@media (max-width: 480px) {
  #ser_device .dev_box {
    margin-top: -25px;
  }
}

#ser_device .dev_box h4 {
  text-align: center;
  font-size: 1.3em;
  letter-spacing: 0.2em;
  color: #1ea9f9;
  font-weight: 700;
}

#ser_scene {
  padding-top: 100px;
  background: #fff;
}

#ser_miryoku {
  padding-top: 100px;
  background: #fff;
  padding-bottom: 150px;
  overflow: hidden;
}

.miryoku_box {
  padding: 20px 7% 30px 7%;
  border-top: 5px solid #000;
  background: #fff;
  -webkit-box-shadow: 2.828px 2.828px 5px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 2.828px 2.828px 5px 0px rgba(0, 0, 0, 0.1);
}

.miryoku_back01 {
  position: absolute;
  left: -30%;
  top: 20%;
}

.miryoku_back02 {
  position: absolute;
  right: -34%;
  top: 30%;
}

.scene_text_right {
  margin-left: -90%;
  background: rgba(52, 52, 52, 0.9);
  padding: 50px 50px;
  margin-top: 110px;
}

.scene_text_right p:nth-child(1),
.scene_text_left p:nth-child(1) {
  color: #1ea9f9;
  font-weight: 500;
}

.scene_text_right h4 {
  font-size: 1.3em;
  letter-spacing: 0.2em;
  font-weight: bold;
}

.scene_text_right h4,
.scene_text_right p {
  color: #fff;
}

.scene_text_left {
  margin-right: -90%;
  background: rgba(248, 248, 248, 0.9);
  padding: 50px 50px;
  position: absolute;
  margin-top: 100px;
}

.scene_text_left h4 {
  font-size: 1.3em;
  letter-spacing: 0.2em;
  font-weight: bold;
}

#ser_about {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(/assets/img/service/about/back.jpg);
  background-size: cover;
  background-position: center bottom;
  overflow: hidden;
}

#ser_about .box {
  background: rgba(255, 255, 255, 0.8);
  padding: 40px 70px 60px 70px;
  max-width: 1100px;
  margin: auto;
  border-radius: 20px;
}

#ser_about .box p {
  letter-spacing: 0.2em;
  margin-bottom: 30px;
}

#ser_about hr {
  margin-top: 10px;
  margin-bottom: 15px;
  border-top: 1px solid #424242;
  width: 130px;
}

#ser_about h3 {
  font-weight: 500 !important;
}

@media (max-width: 1199px) {
  .scene_text_right {
    margin-top: 50px;
  }

  .scene_text_left {
    margin-top: 30px;
  }

  #ser_scene div:nth-child(3) .scene_text_left {
    margin-top: 60px;
  }
}

@media (min-width: 1200px) and (max-width: 1350px) {
  .miryoku_back01 {
    position: absolute;
    left: -14%;
  }

  .miryoku_back02 {
    position: absolute;
    right: -18%;
  }
}

@media (min-width: 992px) {
  .miryoku_pw {
    margin-top: 60px;
  }
}

@media (max-width: 991px) {
  .scene_text_right {
    margin-top: 20px;
    margin-left: -220%;
  }

  .scene_text_left {
    margin-top: 5px;
    margin-right: -220%;
  }

  #ser_scene div:nth-child(3) .scene_text_left {
    margin-top: 30px;
    margin-right: -220%;
  }
}

.miryoku_box h4 {
  font-weight: 600;
}

.miryoku_box p {
  font-size: 15px;
}

@media (max-width: 767px) {
  .scene_text_right {
    margin-top: -40px;
    margin-left: 0%;
    position: relative;
  }

  .scene_text_left {
    margin-top: -40px;
    margin-right: 0%;
    position: relative;
  }

  #ser_scene div:nth-child(3) .scene_text_left {
    margin-top: -40px;
    margin-right: 0%;
    position: relative;
  }

  .m_none767 {
    display: none;
  }

  .m_none {
    display: none;
  }

  .miryoku_pw {
    width: 140px !important;
  }

  .miryoku_box,
  #SERVICE_sub .box {
    max-width: 310px;
    margin: auto;
  }

  .pro6_1,
  .pro6_2,
  .pro6_3,
  .pro6_4,
  .pro6_5,
  .pro6_6 {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
}

@media (max-width: 480px) {
  #ser_miryoku {
    padding-bottom: 100px;
  }

  #ser_scene img,
  #ser_scene .scene_text_right,
  #ser_scene .scene_text_left,
  #ser_device img {
    margin: auto;
    width: 310px;
  }

  #ser_device .dev_box {
    padding: 20px 30px;
  }

  #ser_scene .scene_text_right,
  #ser_scene .scene_text_left {
    padding: 30px 25px;
  }

  #ser_scene .scene_text_right {
    margin-top: -40px;
    margin-right: auto;
  }

  #ser_scene .scene_text_left {
    margin-top: -40px;
  }

  #ser_scene div:nth-child(3) .scene_text_left {
    margin-right: auto;
  }
}

.pro6_1 {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(/assets/img/service/property/bg-01.webp);
  background-position: center;
  background-size: cover;
  margin-bottom: 30px;
}

.pro6_2 {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(/assets/img/service/property/bg-02.webp);
  background-position: center;
  background-size: cover;
  margin-bottom: 30px;
}

.pro6_3 {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(/assets/img/service/property/bg-03.webp);
  background-position: center;
  background-size: cover;
  margin-bottom: 30px;
}

.pro6_4 {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(/assets/img/service/property/bg-04.webp);
  background-position: center;
  background-size: cover;
  margin-bottom: 30px;
}

.pro6_5 {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(/assets/img/service/property/bg-05.webp);
  background-position: center;
  background-size: cover;
  margin-bottom: 30px;
}

.pro6_6 {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(/assets/img/service/property/bg-06.webp);
  background-position: center;
  background-size: cover;
  margin-bottom: 30px;
}

.pro6_1 h4,
.pro6_2 h4,
.pro6_3 h4,
.pro6_4 h4,
.pro6_5 h4,
.pro6_6 h4 {
  color: #fff;
}

.plan_sub {
  padding-top: 100px;
}

.plan_sub h4 {
  font-size: 1.5em;
}

.plan_sub .com_title {
  font-weight: bold;
}

.plan_sub .box01 {
  width: 49.9%;
  float: left;
  margin-top: 20px;
  padding: 0% 6% 4% 6%;
}

.plan_sub .box02 {
  width: 49.9%;
  float: left;
  margin-top: 20px;
  padding: 0% 6% 4% 6%;
  border-left: 1px solid #424242;
}

.plan_sub .plan-50-100-list-sp {
  display: flex;
  justify-content: center;
}

.plan_sub .plan-50-100-list-sp p {
  font-weight: bold;
  font-size: 18px;
  margin: 15px 50px;
}

.plan_sub ul li {
  list-style: none;
  font-size: 0.9em;
  line-height: 1.8em;
}

.plan_sub ul {
  padding-left: 0;
}

.plan_youryo_left,
.plan_youryo_right {
  font-size: 1.4em !important;
  font-weight: 600;
}

.plan_contentBlack {
  padding-top: 80px;
  padding-bottom: 120px;
  background: #f8f8f8;
}

.plan_contentWhite {
  padding-top: 80px;
  padding-bottom: 120px;
  background: #fff;
}

.plan_content h4 {
  font-weight: bold;
}

.plan_content .en {
  font-weight: 600;
}

.plan_content hr {
  border-top: 1px solid #424242;
  max-width: 350px;
}

.plan_content .plan_fee {
  font-size: 1.8em;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.plan_title {
  font-size: 1.2em;
  font-weight: 600;
}

.plan_content .plan_fee span {
  font-size: 0.5em;
  margin-left: 2px;
  font-weight: 500;
  letter-spacing: 0.03em;
}

.plan_text {
  color: #777777;
  font-weight: 500;
  font-size: 0.9em;
}

.plan_subText {
  font-size: 1.1em;
  font-weight: bold;
  line-height: 1.5em;
}

.plan_sub table {
  width: 100%;
}

.plan_sub .band th,
.plan_sub .band td {
  font-size: 0.8em;
}

.plan_sub table th {
  border-bottom: 2px solid #d7d7d7;
  padding: 6px;
}

.plan_sub table td {
  border-bottom: 1px solid #d7d7d7;
  padding: 6px;
}

.plan_sub .pw th {
  border-bottom: none;
  padding: 10px;
}

.plan_sub .pw td {
  border-bottom: none;
  padding: 10px;
  color: #333;
  font-weight: 200;
}

#footer .trans_btn {
  width: 130px;
  display: block;
  padding: 0;
  text-align: center;
  line-height: 2.6em;
  margin-top: 10px;
}

#footer .F_col4 div:nth-child(2) .trans_btn {
  margin-top: 8px;
}

.tax_title img {
  margin: auto;
  display: block;
  pointer-events: none;
}

.tax_titleSP {
  color: #fff;
  font-weight: 500;
  font-size: 2.1em;
  line-height: 0.9em;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  letter-spacing: 0em;
  display: flex;
  flex-direction: column;
}

.tax_titleSP span {
  font-size: 0.5em;
  font-weight: 600;
}

.tax_titleSP .en-flex {
  display: flex;
  flex-direction: column;
  flex-flow: column;
  width: 40px;
}

.tax_titleSP2 {
  font-weight: 500;
  font-size: 2.3em;
  line-height: 0.9em;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  letter-spacing: 0.01em;
  display: flex;
  justify-content: center;
}

.tax_titleSP2-in1 span {
  font-weight: 600;
  font-size: 0.45em;
}

.tax_titleSP2-in2 {
  display: inline-flex;
  flex-direction: column;
  flex-flow: column;
  font-size: 0.3em;
  line-height: 1.5em;
  font-weight: 600;
}

.tax_title p {
  color: #fff;
  font-size: 1.9em;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  letter-spacing: 0.02em;
}

.tax_title hr {
  margin-top: 7px;
  margin-bottom: 7px;
  padding-top: 0;
  padding-bottom: 0;
  width: 180px;
}

.tax_title p:nth-last-of-type(1) {
  font-size: 1.8em;
  line-height: 0.65em;
}

.tax_title p:nth-last-of-type(1) span {
  font-size: 0.4em;
  font-weight: 600;
  letter-spacing: 0.15em;
}

.plan_box {
  width: 250px;
  margin: auto;
  position: relative;
  overflow: hidden;
}

.plan_boxtop {
  background: #30b6fc;
  overflow: hidden;
  padding-top: 20px;
  padding-bottom: 20px;
}

.plan_boxbottom {
  padding-top: 20px;
  padding-bottom: 30px;
  background: #fff;
}

.mini_new {
  position: absolute;
  top: 0;
  left: 0;
  width: 60px;
}

.plan_boxSP {
  margin-left: 15px;
  margin-right: 15px;
  margin-top: 15px;
  border-radius: 5px;
  max-width: 290px;
  margin: auto;
  -webkit-box-shadow: 0px 0px 15px 2px rgba(0, 0, 0, 0.17);
  box-shadow: 0px 0px 15px 2px rgba(0, 0, 0, 0.17);
}

.plan_boxSP_top {
  padding-top: 10px;
  padding-bottom: 10px;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
  overflow: hidden;
  background: #30b6fc;
}

.plan_boxSP_bot {
  padding-top: 30px;
  padding-bottom: 25px;
}

.plan_boxSP table td {
  font-size: 1.3em !important;
}

@media (max-width: 991px) {
  #footer ul li {
    line-height: 30px;
  }

  #footer h4 {
    font-weight: 500;
    text-align: center;
  }

  #footer .trans_btn {
    margin: auto;
  }

  #footer .F_col4 div:nth-last-child(1) .trans_btn {
    margin-top: 10px;
  }

  #footer .blue_btn {
    padding: 7px 30px !important;
  }

  #footer .footer_logo {
    width: 170px;
  }

  #footer {
    padding-top: 40px;
    padding-bottom: 190px;
  }

  #footer .footer_inflame {
    width: 380px;
    margin: auto;
    margin-top: 15px;
  }

  #footer .inflame_01,
  #footer .inflame_02,
  #footer .inflame_03 {
    width: 30%;
    float: left;
    text-align: center;
    padding: 0px;
    color: #fff;
    border-left: 1px solid #fff;
  }

  #footer .inflame_02 {
    width: 39%;
  }

  #footer .inflame_01 {
    border-left: none;
  }

  #footer .inflame_01 a,
  #footer .inflame_02 a,
  #footer .inflame_03 a {
    color: #fff;
    text-align: center;
    font-size: 11px;
  }

  .pc_footer {
    display: none;
  }

  .F_col2 {
    width: 100%;
  }

  .F_col4 {
    width: 100%;
    margin-left: 0;
  }
}

@media screen and (min-width: 580px) and (max-width: 991px) {
  .F_col2 {
    width: 41%;
    margin-left: 8%;
  }

  .F_col4 {
    width: 35%;
  }
}

@media (max-width: 480px) {
  #ser_about {
    padding-top: 70px;
    padding-bottom: 70px;
    background-image: url(/assets/img/service/about/sp/back.jpg);
    background-size: cover;
    background-position: center bottom;
  }

  #ser_about h3 {
    padding-bottom: 0 !important;
  }

  #ser_about .box {
    background: rgba(255, 255, 255, 0.8);
    padding: 10px 20px 30px 20px;
    max-width: 310px;
    margin: auto;
  }

  #ser_about p {
    letter-spacing: 0.04em !important;
  }

  #ser_about img {
    width: 200px;
  }

  #ser_scene .ser_brNo br {
    display: none;
  }

  #SUBPAGE_TITLE_service h2 {
    font-size: 5.6vw;
  }

  #SERVICE_sub,
  #ser_scene {
    padding-bottom: 100px;
  }

  #ser_device {
    padding-bottom: 0px;
  }

  .margin_0 {
    margin-top: 0;
  }

  #ser_scene .box01 .box_top h4,
  #ser_scene .box02 .box_top h4 {
    font-size: 18px;
  }

  #footer p:last-child {
    font-size: 8px !important;
  }

  .plan_contentBlack {
    padding-top: 50px;
    padding-bottom: 50px;
    background: #f8f8f8;
  }

  .plan_contentWhite {
    padding-top: 50px;
    padding-bottom: 50px;
    background: #fff;
  }

  .plan-warp {
    margin-top: 0;
  }
}

@media (max-width: 991px) {
  #ser_about .box {
    background: rgba(255, 255, 255, 0.8);
    max-width: 90%;
    margin: auto;
  }

  #ser_about .box img {
    width: 300px;
  }

  .content01,
  .content02,
  .content03,
  .content04,
  .content05,
  .content06 {
    margin-top: 50px;
  }
}

@media (max-width: 480px) {
  body {
    font-size: 13px;
  }

  .apply-tab .box_choice .left {
    float: inherit;
  }

  .next_sim {
    top: 75px;
  }

  #CONTENT h3 {
    font-size: 1.5em;
    padding-bottom: 10px;
  }

  .APN p:nth-child(2) {
    font-size: 13px;
    letter-spacing: 0.1em;
    line-height: 1.6em;
    text-align: left;
  }

  .APN h4 {
    font-size: 1.1em;
  }

  .op_text {
    font-size: 1.2em !important;
  }

  .purchase .main_text p:nth-child(2) {
    font-size: 13px;
    letter-spacing: 0em;
    line-height: 1.6em;
  }

  .purchase .main_text p:nth-child(2):before {
    content: url(../img/title_icon08.png);
    padding-right: 5px;
  }

  .purchase p {
    font-size: 13px;
  }

  .cancel h3 {
    font-size: 6vw !important;
  }

  .cancel p:nth-child(2) {
    font-size: 1.2em;
  }

  .cancel p:nth-child(3) {
    font-size: 13px;
  }

  .success p:nth-child(2) {
    font-size: 13px;
    letter-spacing: 0.1em;
  }

  .success p:nth-child(3) {
    font-size: 13px;
    letter-spacing: 0.1em;
  }

  .success {
    padding-bottom: 70px;
  }

  .success_img {
    width: 180px;
    margin-top: 50px;
  }

  .APN .step3 h5 {
    font-size: 1.2em;
    margin-top: -10px;
  }

  #PLAN .PLAN_inner .phone_margin {
    max-width: 340px;
    padding-right: 0;
    padding-left: 0;
  }

  #FLOW .flow_text img {
    width: 100px;
  }

  #PLAN .box_choice:first-child {
    margin-top: 20px !important;
  }

  #PLAN .box_choice {
    max-width: 100%;
    margin: auto;
    padding: 20px 3%;
    padding-top: 20px;
  }

  #PLAN .choice .box01 {
    margin-top: 10px;
    margin-left: auto;
  }

  #PLAN .choice .box02 {
    margin-top: 10px;
    margin-left: 4%;
  }

  #FLOW .flow_text p {
    font-size: 13px;
    text-align: justify;
    max-width: 160px;
    margin: auto;
    margin-top: -5px;
    letter-spacing: 0.1em;
  }

  .other_center {
    text-align: center;
  }

  .heading::before {
    content: '';
    border-top: 5px solid #333;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    margin-top: 5px;
    margin-right: 10px;
    margin-left: 10px;
  }

  .heading {
    font-size: 13px;
    padding: 10px 0px;
  }

  .accordion {
    margin-top: 20px;
  }

  .contents {
    padding: 10px 10px;
    font-size: 13px;
    line-height: 1.5em;
  }

  .change h3 {
    font-size: 1.2em !important;
  }

  #PLAN .top_subtitle hr {
    width: 150px;
    margin-top: 0px;
    margin-bottom: 10px;
  }

  #SERVICE .top_subtitle p,
  #PLAN .top_subtitle p,
  #SUPPORT .top_subtitle p,
  #FLOW .top_subtitle p {
    font-size: 1.1em;
  }

  span.release {
    font-size: 13px;
    line-height: 1.3em;
  }

  .next_sim,
  .phone01,
  .phone02 {
    display: none;
  }

  .backSP_img01 {
    position: absolute;
    z-index: 1;
    top: 21px;
    width: 90px;
  }

  .backSP_img02 {
    position: absolute;
    z-index: 1;
    right: 0;
    bottom: 20px;
    width: 90px;
  }

  .i01 {
    position: absolute;
    top: -10px;
    right: 10%;
    width: 40px;
  }

  .i02 {
    position: absolute;
    top: 200px;
    left: 10px;
    width: 9px;
  }

  .i03 {
    position: absolute;
    top: 390px;
    top: 390px;
    right: -5%;
    width: 40px;
  }

  .i04 {
    position: absolute;
    top: 620px;
    left: 30px;
    width: 30px;
  }

  .i05 {
    position: absolute;
    top: 860px;
    right: 1%;
    width: 15px;
  }

  .i06 {
    position: absolute;
    top: 1090px;
    left: 5px;
    width: 9px;
  }

  #PLAN {
    padding-top: 70px;
  }

  #PLAN .concept h5 {
    font-size: 1em;
    margin-top: 10px;
  }

  #PLAN .PLAN_inner .phone_margin {
    max-width: 270px;
    margin: auto;
  }

  #PLAN .phone_margin .box02 {
    margin-top: 10px;
  }

  #PLAN .box h4 {
    font-size: 19px;
    padding: 12px 18px 8px 18px;
    margin-bottom: 5px;
  }

  #PLAN .box p span:first-child {
    font-size: 34px;
    letter-spacing: -0.012em;
  }

  #PLAN .box p span:nth-child(2) {
    font-size: 13px;
    letter-spacing: -0.012em;
  }

  #PLAN .box_top {
    padding-top: 15px;
    padding-bottom: 15px;
  }

  #PLAN table tr td {
    font-size: 13px;
    letter-spacing: 0em !important;
    height: 32px;
  }

  #PLAN table tr td:nth-child(2) {
    font-size: 13px;
    font-weight: 300;
    color: #717171;
  }

  #PLAN table tr td {
    padding-bottom: 10px;
  }

  #PLAN .box_bottom {
    padding: 35px 30px;
    padding-bottom: 35px;
  }

  #PLAN .box {
    margin-top: -30px;
    margin-bottom: 70px;
  }

  #PLAN .concept h4,
  #PLAN .choice h4 {
    font-size: 15px;
    line-height: 14px;
    letter-spacing: 0.1em;
    clear: both;
  }

  #PLAN .choice {
    margin-top: 10px;
  }

  #PLAN .choice .box01 {
    border-top: 3px solid #07aef9;
  }

  #PLAN .choice .box02 {
    width: 48%;
    border-top: 3px solid #eb1f1f;
  }

  #PLAN .choice .box01 h5 {
    font-size: 14px;
  }

  #PLAN .choice .box02 h5,
  #PLAN .choice .box02 h5 span {
    font-size: 13px;
  }

  #PLAN .price_choice {
    font-size: 27px;
  }

  #PLAN .price_choice span {
    font-size: 13px;
  }

  #PLAN .box_choice p:nth-child(3) {
    margin-top: -10px;
  }

  #PLAN .box_choice p:nth-child(4) {
    font-size: 13px;
    text-align: center;
    letter-spacing: -0.02em;
    margin-bottom: 0;
    padding-bottom: 10px;
  }

  #PLAN .Ti:before {
    content: url(../img/title_icon08.png);
    padding-right: 3px;
  }

  #PLAN .PLAN_subtitle .left img {
    height: 25px;
    width: 35px;
  }

  #PLAN .box_choice .left {
    padding-right: 7px;
  }

  #PLAN .box_choice .right h5 {
    margin-top: 4px;
  }

  #PLAN .choice .box02 h5 {
    margin-top: -2px;
    margin-bottom: 5px;
  }

  #FLOW h4 {
    font-size: 14px;
    letter-spacing: 0.06em;
    margin-top: 10px;
  }

  #FLOW div:nth-child(3) h4 {
    font-size: 14px;
    margin-top: 10px;
  }

  #FLOW .flow_letter {
    letter-spacing: 0.05em !important;
    font-size: 14px !important;
  }

  #FLOW .flow_text01 {
    margin-top: -20px;
  }

  #OUR {
    margin-top: 50px;
    background-size: cover;
    background-position: right;
  }

  #OUR p {
    font-size: 13px;
    line-height: 1.7em;
    letter-spacing: 0.1em;
    width: 80%;
    margin: auto;
  }

  .our_btn02 a,
  .our_btn02 button {
    padding: 7px 25px;
    letter-spacing: 0.2em;
    -webkit-transition: 0.2s;
    transition: 0.2s;
    font-size: 13px;
    border-radius: 5px;
    padding-bottom: 10px;
    display: block;
    margin: 0 auto;
  }

  .our_btn02 a.forNomad {
    display: inline;
  }

  .our_btn02 {
    text-align: left;
    padding-top: 0;
    margin-top: 5px !important;
    width: 128px;
  }

  .purchase .our_btn02 {
    text-align: center;
  }

  .apn_flow01 {
    width: 280px;
    height: auto;
    margin-top: 30px;
  }

  .apn_flow02 {
    width: 140px;
    height: auto;
    margin-top: 30px;
  }

  .apn_flow04 {
    width: 40px;
    height: auto;
    margin-top: 30px;
  }

  .APN h4 {
    margin-top: 50px;
  }

  .APN h4:before {
    content: url(../img/title_icon08.png);
    padding-right: 10px;
  }

  .APN .apn_marginTop {
    margin-top: 50px !important;
  }

  .APN .step1 p:nth-child(3),
  .APN .step2 p:nth-child(3),
  .APN .step4 p:nth-child(3) {
    font-size: 13px;
    letter-spacing: 0.15em;
  }

  .APN .step1 p:nth-child(4) {
    font-size: 13px;
    letter-spacing: 0.15em;
  }

  .APN .step3 p:nth-child(2) {
    font-size: 13px;
  }

  .APN .APN_btn {
    font-size: 13px;
  }

  .tab_area .apply_label {
    font-size: 14px;
    padding-top: 8px;
    padding-bottom: 8px;
  }

  .tab_panel {
    padding-top: 40px;
  }

  .apply-tab .box_top hr {
    display: none;
  }

  .apply-tab .box h4 {
    font-size: 15px;
    padding: 5px 15px;
    padding-top: 10px;
    margin-bottom: 0;
  }

  .apply-tab p span:first-child {
    /* font-size: 26px; */
  }

  .apply-tab .box p span:nth-child(2) {
    font-size: 15px;
  }

  .apply-tab .box_top {
    padding-top: 5px;
    padding-bottom: 5px;
  }

  .apply-tab .table-css table tr td {
    font-size: 13px;
  }

  .apply-tab .table-css table tr td:nth-child(2) {
    font-size: 13px;
  }

  .apply-tab .box {
    max-width: 270px;
  }

  .apply-tab .box_bottom {
    padding: 20px 40px;
  }

  .apply-tab .table-css table tr td {
    padding-bottom: 8px;
  }

  .op_text {
    margin-top: 70px;
  }

  .apply-tab .box_choice {
    width: 100%;
  }

  .apply-tab .price_choice {
    font-size: 26px;
  }

  .apply-tab .choice .box01 {
    border-top: 3px solid #000;
  }

  .apply-tab .box_choice {
    padding: 10px;
    padding-bottom: 20px;
    padding-top: 20px;
  }

  .apply-tab form .Ti02 {
    font-size: 16px;
  }

  .apply-tab form .Ti02:before {
    content: url(../img/title_icon04.png);
    padding-right: 5px;
  }

  .apply-tab form .Ti02 span {
    font-size: 13px !important;
  }

  .apply-tab .checkbox_text {
    font-size: 13px;
  }

  .apply-tab .kome,
  .apply-tab .kome2 {
    font-size: 13px;
  }

  .apply-tab .label p {
    font-size: 13px;
  }

  .apply-tab .kiyaku h5 {
    font-size: 14px;
  }

  .apply-tab .kiyaku p {
    font-size: 13px;
  }

  .apply-tab input[type='submit'] {
    font-size: 13px;
    padding: 15px 30px;
  }

  .cancel h3,
  .purchase h3 {
    margin-top: 70px;
  }

  .cancel p:nth-child(3) {
    margin-top: 10px;
    letter-spacing: 0.1em;
  }

  .page_list {
    font-size: 12px;
  }

  .commerce table {
    margin-top: 70px;
  }

  .contact_margin {
    margin-top: 70px;
  }

  .contact label {
    font-size: 13px;
    margin-bottom: 0px;
  }

  .contact Ti02 {
    font-size: 16px !important;
  }

  .contact p {
    font-size: 13px !important;
  }

  #CONTENT .content03 {
    margin-top: 50px;
  }

  #SUPPORT img {
    width: 180px;
    height: auto;
  }

  .SUPPORT_img {
    margin-top: 20px;
  }

  .SUPPORT_text {
    margin-top: 40px;
  }

  #SUPPORT .top_subtitle hr {
    width: 150px;
    margin-top: 10px;
    margin-bottom: 10px;
  }

  #SUPPORT h4 {
    font-size: 13px;
    text-align: center;
    margin-top: -20px;
  }

  #SUPPORT .text01 {
    margin-top: 10px;
    font-size: 13px;
    line-height: 1.2em;
    text-align: center;
  }

  #SUPPORT .text02 {
    margin-top: 10px;
    font-size: 13px;
    line-height: 1.2em;
    text-align: center;
  }

  #SUPPORT .support_btn {
    font-size: 13px;
    padding: 10px 20px;
    padding-top: 8px;
  }

  .support_btnCenter {
    text-align: center;
    margin-top: -20px;
  }

  #SUPPORT {
    padding-bottom: 50px;
  }

  .purchase h3 {
    font-size: 15px !important;
    margin-top: 70px;
  }

  .cancel h3 {
    font-size: 5vw !important;
    margin-top: 70px;
  }

  .purchase .purchase_text h5 {
    font-size: 13px;
  }

  .purchase_red {
    font-size: 13px !important;
  }

  .purchase .our_btn02 button {
    text-align: center;
  }

  .purchase .img01 {
    width: 160px;
    margin-top: 70px;
    margin-bottom: 70px;
  }

  .change .Ti:before {
    content: url(../img/title_icon08.png);
    padding-right: 5px;
  }

  .change .Ti {
    font-weight: bold;
    text-align: center;
  }

  .spec p {
    font-size: 13px;
  }

  .spec_subtitle {
    font-size: 13px !important;
  }

  .spec_margin,
  .success_margin {
    margin-top: 50px;
  }

  .Privacy_Title_sp h2 {
    font-size: 4vw !important;
  }

  #MV .box h4 {
    padding: 5px 12px;
    padding-top: 8px;
  }

  #MV .box h4 {
    font-size: 14px !important;
  }
}

@media (min-width: 992px) {
  .flow_text::after {
    clear: none !important;
  }
}

.banner_1 {
  position: relative;
  overflow: hidden;
  text-align: center;
  width: 50%;
  float: left;
  background: #f6f6f6;
  height: 300px;
}

.banner_2 {
  position: relative;
  overflow: hidden;
  text-align: center;
  width: 50%;
  float: left;
  background-image: url(../img/banner02_back.jpg);
  background-position: center;
  background-size: cover;
  height: 300px;
}

.banner_1 .box01 {
  width: 50%;
  float: left;
  height: 300px;
  position: relative;
}

.banner_1 .box02 {
  width: 50%;
  float: left;
  height: 100%;
  height: 300px;
  position: relative;
}

.banner_1 .box01 img {
  width: 85%;
  position: absolute;
  right: -10%;
  top: 0%;
  bottom: 0;
  margin: auto;
  max-width: 320px;
}

.banner_1 .box02 img {
  width: 60%;
  position: absolute;
  left: 10%;
  top: 0%;
  bottom: 0;
  margin: auto;
  max-width: 250px;
}

.banner01_text02 {
  position: absolute;
  bottom: 7%;
  margin: auto;
  left: 0;
  right: 0;
  display: block;
  width: 35%;
  max-width: 360px;
}

.banner_2 img {
  margin: auto;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  position: absolute;
  width: 45%;
  max-width: 300px;
}

@media (max-width: 1440px) {

  .banner_1,
  .banner_2,
  .banner_1 .box01,
  .banner_1 .box02 {
    height: 250px;
  }

  .banner_2 img {
    width: 270px;
  }
}

@media (max-width: 768px) {

  .banner_1,
  .banner_2,
  .banner_1 .box01,
  .banner_1 .box02 {
    height: 180px;
  }

  .banner_2 img {
    width: 180px;
  }
}

@media (max-width: 480px) {

  .banner_1,
  .banner_2 {
    width: 100%;
  }

  .banner_1,
  .banner_2,
  .banner_1 .box01,
  .banner_1 .box02 {
    height: 170px;
  }

  .banner_1 .box01 img {
    width: 90%;
    top: 5%;
    left: 0%;
  }

  .banner_1 .box02 img {
    width: 70%;
    top: 4%;
  }

  .banner01_text02 {
    position: absolute;
    bottom: 12%;
    margin: auto;
    left: 0;
    right: 0;
    display: block;
    width: 55%;
    max-width: 360px;
  }
}

@media (max-width: 480px) {

  #CONTENT .plan_contentWhite h3,
  #CONTENT .plan_contentBlack h3 {
    font-size: 24px;
  }

  .share .col-xs-3 {
    width: 22%;
  }

  .share .col-xs-3:first-child {
    margin-left: 6%;
  }
}

#footer {
  overflow: hidden;
}

#footer ul {
  list-style: none;
}

#footer ul li:before {
  content: url(/assets/img/btn-icon.svg);
  padding-right: 10px;
  line-height: 1.6;
}

p.semaiP {
  margin-top: -4px !important;
}

.sp_footer h4 {
  font-size: 16px !important;
}

.sp_footer p {
  line-height: 1.7em;
}

.plan-container {
  width: 1160px;
  max-width: 100%;
  margin: auto;
}

.main-plan {
  display: flex;
  justify-content: center;
}

.main-plan-box {
  margin: 10px 20px;
  margin-top: 30px;
}

@media (max-width: 1200px) {
  .plan-container {
    width: 600px;
  }

  .main-plan {
    flex-wrap: wrap;
  }
}

@media (min-width: 992px) {
  .sp_footer {
    display: none;
  }
}

@media (max-width: 480px) {
  #SERVICE {
    padding-top: 30px;
    padding-bottom: 100px;
    background: url(../img/SERVICE_backSP.png);
  }

  #PLAN {
    padding-top: 70px;
    padding-bottom: 70px;
  }

  #FLOW {
    padding-top: 70px;
  }

  #SERVICE .box p {
    font-size: 13px;
  }

  .title_subtext,
  .title_text p {
    font-size: 13px;
  }

  .cards_basic,
  .cards_pro {
    width: 280px;
  }

  #PLAN table {
    width: 250px;
  }

  #PLAN table tr td {
    text-align: left;
    padding-left: 20px;
  }
}

/*SLIDER2*/

.cb-slideshow2 {
  position: relative;
  padding-left: 0;
}

.cb-slideshow2 li {
  list-style: none;
}

.cb-slideshow2,
.cb-slideshow2:after {
  position: relative;
  width: 100%;
  padding-top: 70px;
  padding-bottom: 70px;
  top: 0px;
  left: 0px;
  z-index: 0;
  overflow: hidden;
  background: #2b2b2b;
}

.cb-slideshow2 li span {
  width: 100vw;
  height: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
  color: transparent;
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: none;
  opacity: 0;
  z-index: 0;
  -webkit-backface-visibility: hidden;
  -webkit-animation-name: imageAnimation;
  animation-name: imageAnimation;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-duration: 24s;
  animation-duration: 24s;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

.cb-slideshow2 li:nth-child(1) span {
  background-image: url(../img/footer/our/slider/background01.webp);
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
}

.cb-slideshow2 li:nth-child(2) span {
  background-image: url(../img/footer/our/slider/background02.webp);
  -webkit-animation-delay: 3s;
  animation-delay: 4s;
}

.cb-slideshow2 li:nth-child(3) span {
  background-image: url(../img/footer/our/slider/background03.webp);
  -webkit-animation-delay: 6s;
  animation-delay: 8s;
}

.cb-slideshow2 li:nth-child(4) span {
  background-image: url(../img/footer/our/slider/background04.webp);
  -webkit-animation-delay: 9s;
  animation-delay: 12s;
}

.cb-slideshow2 li:nth-child(5) span {
  background-image: url(../img/footer/our/slider/background05.webp);
  -webkit-animation-delay: 12s;
  animation-delay: 16s;
}

.cb-slideshow2 li:nth-child(6) span {
  background-image: url(../img/footer/our/slider/background06.webp);
  -webkit-animation-delay: 15s;
  animation-delay: 19s;
}

@-webkit-keyframes imageAnimation {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  40% {
    opacity: 1;
  }

  50% {
    -webkit-transform: scale3d(1.2, 1.2, 1);
    transform: scale3d(1.2, 1.2, 1);
    opacity: 0;
  }

  51% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes imageAnimation {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  40% {
    opacity: 1;
  }

  50% {
    -webkit-transform: scale3d(1.2, 1.2, 1);
    transform: scale3d(1.2, 1.2, 1);
    opacity: 0;
  }

  51% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@media (max-width: 480px) {
  #footer .footer_contantBtn {
    display: flex;
    justify-content: center;
  }

  .miryoku_box p {
    font-size: 13px;
  }

  #SERVICE_sub .box p {
    font-size: 14px;
    padding-left: 3%;
    padding-right: 3%;
  }

  #ser_miryoku {
    padding-top: 70px;
  }

  #ser_device {
    padding-top: 70px;
  }

  #50gb form .Ti02:before,
  #100gb form .Ti02:before,
  #panel2 form .Ti02:before,
  .contact .Ti02:before {
    content: url(../img/title_icon04.png) !important;
  }

  #50gb form .Ti02,
  #100gb form .Ti02,
  #panel2 form .Ti02,
  .contact .Ti02 {
    font-size: 16px !important;
  }

  #footer ul li {
    letter-spacing: 0em;
  }

  .cb-slideshow,
  .cb-slideshow:after {
    height: 50vh;
  }
}

/* Show at least something when animations not supported */

.no-cssanimations .cb-slideshow li span {
  opacity: 1;
}

@media (min-width: 1201px) {
  .plan_kosho {
    padding-left: 8%;
    padding-right: 8%;
  }
}

@media (min-width: 481px) {
  .plan_youryo_right {
    margin-right: 5%;
  }
}

@media screen and (min-width: 481px) and (max-width: 991px) {
  #ser_device .col-sm-9 {
    width: 60%;
    float: left;
  }

  #ser_device .col-sm-3 {
    width: 40%;
    float: left;
  }

  #ser_device .col-sm-pull-9 {
    right: 60%;
  }

  #ser_device .col-sm-push-3 {
    left: 40%;
  }
}

@media (max-width: 375px) {
  #footer .sp_footer .F_col2 .col-xs-6 {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }

  .cb-slideshow2,
  .cb-slideshow2:after {
    padding-top: 45px !important;
    padding-bottom: 50px !important;
  }
}

@media (max-width: 480px) {
  .plan_box {
    width: 300px;
  }
}

@media (max-width: 320px) {
  .plan_box {
    width: 280px;
  }

  #footer .inflame_01 {
    width: 23%;
    font-size: 0.8em;
  }

  #footer .inflame_02 {
    width: 35%;
    font-size: 0.8em;
  }

  #footer .inflame_01 {
    width: 23%;
    font-size: 0.8em;
  }

  #footer .col-xs-3 {
    padding: 0px;
    font-size: 0.8em;
  }

  #footer .trans_btn {
    width: 110px;
  }

  #footer {
    padding-bottom: 150px;
  }
}

/*細かいレスポンシブ*/

@media (min-width: 991px) and (max-width: 1199px) {
  p.plan_fee span {
    font-size: 0.35em;
    letter-spacing: 0;
  }
}

.notice {
  text-align: center;
  margin-top: 50px;
  background: #f6f6f6;
  padding: 20px;
  padding-bottom: 30px;
  -webkit-font-feature-settings: 'palt' 1;
  font-feature-settings: 'palt' 1;
}

.notice i {
  display: block;
  font-size: 28px;
  color: #ffc90f;
}

.notice h4 {
  font-size: 17px;
}

@media (max-width: 800px) {
  .notice {
    width: 92%;
    margin-left: 4%;
  }

  .notice p {
    text-align: center;
  }

  .notice .nenshi {
    text-align: center;
  }

  .notice br.BR_none2 {
    display: none;
  }
}

.lan {
  position: absolute;
  right: 3%;
  top: 90px;
}

.lan button:before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url(../img/lan01.png);
  background-size: contain;
  vertical-align: middle;
  margin-right: 5px;
}

.lan button {
  padding: 5px 10px;
}

.lan .caret {
  margin-left: 5px;
}

.lan ul li:nth-child(1) a:before {
  content: '';
  display: inline-block;
  width: 30px;
  height: 20px;
  background-image: url(../img/lan02.png);
  background-size: contain;
  vertical-align: middle;
  border: 1px solid #999;
  margin-right: 5px;
}

.lan ul li:nth-child(2) a:before {
  content: '';
  display: inline-block;
  width: 30px;
  height: 20px;
  background-image: url(../img/lan03.png);
  background-size: contain;
  vertical-align: middle;
  border: 1px solid #999;
  margin-right: 5px;
}

.lan ul li:nth-child(3) a:before {
  content: '';
  display: inline-block;
  width: 30px;
  height: 20px;
  background-image: url(../img/lan04.png);
  background-size: contain;
  vertical-align: middle;
  border: 1px solid #999;
  margin-right: 5px;
}

.lan ul li:nth-child(4) a:before {
  content: '';
  display: inline-block;
  width: 30px;
  height: 20px;
  background-image: url(../img/lan04.png);
  background-size: contain;
  vertical-align: middle;
  border: 1px solid #999;
  margin-right: 5px;
}

.dropdown-menu>li>a {
  padding: 5px 10px;
}

.lan_sp {
  position: relative;
}

.lan_sp {
  right: 0%;
  top: auto;
  margin-bottom: 10px;
}

@media (min-width: 1180px) {
  .lan_sp {
    display: none;
  }
}

@media (max-width: 1179px) {
  .lan_pc {
    display: none;
  }

  .dropdown-menu {
    right: 0;
  }
}

.CTAbanner1,
.CTAbanner2,
.CTAbanner3 {
  padding: 0px;
}

.CTAbanner1 {
  background: #f6f6f6;
}

.CTAbanner2 {
  background-image: url(../img/CTAbanner2_b.jpg);
}

.CTAbanner3 {
  background-image: url(../img/CTAbanner3_b.jpg);
}

.S_point {
  background: #ffffff;
}

.device-service {
  background: #f7fbfd;
}

.device-service .device_contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.device-service .device_contents .box {
  display: flex;
  width: 550px;
  margin: 10px;
  background: #FFF;
  border-radius: 10px;
  padding: 20px;
}

.device-service .device_contents .box p {
  color: #191919;
  font-size: 15px;
  font-weight: 400;
  text-align: left;
}

.device-service .device_contents .box h5 {
  font-size: 18px;
  font-weight: 600;
}

.device_contents-text {
  margin-left: 20px;
}


.device_contents-box-img {
  width: 150px;
  height: 150px;
  border-radius: 100%;
}

.S_point .box {
  height: 230px;
  width: calc(33.333% - 20px);
  float: left;
  background: #fafafa;
  display: table;
  background-position: center;
  background-size: cover;
  margin: 10px;
  border-radius: 10px;
}

.S_point .box p {
  text-align: center;
  display: table-cell;
  vertical-align: middle;
  color: #fff;
  letter-spacing: 0.12em;
  font-weight: 600;
}

.S_point .box01 {
  background-image: url(/assets/img/service/reccommend/bg-01.webp);
}

.S_point .box02 {
  background-image: url(/assets/img/service/reccommend/bg-02.webp);
}

.S_point .box03 {
  background-image: url(/assets/img/service/reccommend/bg-03.webp);
}

.S_point .box04 {
  background-image: url(/assets/img/service/reccommend/bg-04.webp);
}

.S_point .box05 {
  background-image: url(/assets/img/service/reccommend/bg-05.webp);
}

.S_point .box06 {
  background-image: url(/assets/img/service/reccommend/bg-06.webp);
}

@media (max-width: 991px) {
  .miryoku_pw {
    width: 200px;
    margin-bottom: 30px;
  }

  .plan_sub .band {
    max-width: 340px;
    margin: auto;
  }

  .S_point .box {
    float: inherit;
    clear: left;
    width: 100%;
  }

  .S_point .container {
    padding-left: 10%;
    padding-right: 10%;
  }

  .S_point .box {
    height: 180px;
  }
}

.visit {
  position: absolute;
  bottom: 20px;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.3);
  padding-top: 20px;
  padding-bottom: 15px;
}

.visit p.visitTitle {
  text-align: center;
  font-size: 22px !important;
  letter-spacing: 0.2em !important;
  margin-bottom: 2px;
  font-weight: 600;
}

.visit p.visitCampaign {
  text-align: center;
  font-size: 14px !important;
  letter-spacing: 0.2em !important;
}

@media (max-width: 480px) {
  .device-service .device_contents .box {
    flex-direction: column;
  }

  .device_contents-box-img {
    display: block;
    margin: auto;
    margin-bottom: 20px;
  }

  .device-service .device_contents .box p {
    font-size: 14px;
  }

  .device-service .device_contents .box h5 {
    font-size: 16px;
  }

  .apply-tab .choice .box01 {
    width: 90%;
  }

  .S_point .box {
    height: 130px;
  }

  .pw {
    border-collapse: collapse;
  }

  .pw td,
  .pw th {
    display: block;
    width: 100%;
    text-align: center;
  }

  .pw th {
    background: #f2f2f2;
  }

  .plan_sub .band {
    max-width: 220px;
  }

  .plan_content hr {
    max-width: 300px;
  }

  .visit {
    position: absolute;
    bottom: 20px;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.2);
    padding-top: 25px;
    padding-bottom: 15px;
  }

  .visit p.visitTitle {
    margin-bottom: 5px;
    font-size: 17px !important;
  }

  .visit p.visitCampaign {
    text-align: center;
    font-size: 12px !important;
    letter-spacing: 0.2em !important;
    margin-top: 3px !important;
  }
}

@media (max-width: 480px) {
  .nenshi2 {
    text-align: left !important;
  }
}

/*APN*/

.nav-pills>li>a {
  background: #f3f3f3;
  font-weight: 500;
  padding: 8px;
  border: 1px solid #dddddd;
}

.APN .box {
  width: 300px;
  margin: auto;
}

.APN .box p {
  font-size: 1em;
  text-align: left;
  margin-top: 10px;
}

.APN .box p span {
  font-size: 1.1em;
  font-weight: bold;
  padding-right: 5px;
}

.nav-pills>li.active>a,
.nav-pills>li.active>a:focus,
.nav-pills>li.active>a:hover {
  background: #4b8db0;
}

.APN #iphone .row:nth-child(2) p:last-child,
.APN #android .row:nth-child(2) p:nth-child(2),
.APN #router .row:nth-child(2) p:nth-child(3),
.APN #laptop .row:nth-child(2) p:nth-child(2) {
  font-size: 0.9em;
  text-align: left;
  color: #ff0000;
  line-height: 1.5em;
}

.APN #router .row:nth-child(2) p:nth-child(2) {
  font-size: 0.9em;
  text-align: left;
}

.APN h3 {
  font-size: 1.8em !important;
  letter-spacing: 0.1em !important;
}

.APN h4 {
  margin-top: 80px;
  text-align: center;
  font-size: 1.4em;
  letter-spacing: 0.1em;
  font-weight: 600;
}

.APN .ios_box {
  background: #f7f7f7;
  padding: 20px 40px;
  border-top: 5px solid #07aef9;
  width: 300px;
  margin: auto;
  margin-top: 30px;
  line-height: 1.8em;
  font-size: 0.9em;
}

.APN .nav-pills>li>a {
  border-radius: 0px;
}

.APN .nav-pills>li+li,
.APN .nav-pills>li+li:active {
  margin-left: 3px;
}

@media (max-width: 991px) {

  .APN .nav-pills>li+li:nth-child(3),
  .APN .nav-pills>li+li:nth-child(4),
  .APN .nav-pills>li+li:nth-child(5),
  .APN .nav-pills>li+li:nth-child(6) {
    margin-top: 3px;
  }

  .APN .nav-pills>li+li:nth-child(3),
  .APN .nav-pills>li+li:nth-child(5) {
    margin-left: 0px;
  }
}

.blue_btnM {
  background: #1889ea;
  color: #fff !important;
  font-weight: bold;
  border: 1px solid #1889ea;
  border-radius: 30px;
  padding: 10px 20px 12px 20px;
  line-height: 4em;
  -webkit-box-shadow: 16.263px 16.263px 40px 0px rgba(0, 0, 0, 0.25);
  box-shadow: 16.263px 16.263px 40px 0px rgba(0, 0, 0, 0.25);
  letter-spacing: 0.1em;
}

.stop {
  background: #f7f7f7;
  padding: 35px;
}

.inview_body {
  position: relative;
  overflow: hidden;
}

.showup {
  display: block;
  overflow: hidden;
  position: relative;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform-origin: left;
  transform-origin: left;
  -webkit-transition-duration: 1.5s;
  transition-duration: 1.5s;
  -webkit-transition-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
  transition-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transform: translate3d(-110.5%, 0, 0);
  transform: translate3d(-110.5%, 0, 0);
}

.showup2 {
  display: block;
  overflow: hidden;
  position: relative;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform-origin: right;
  transform-origin: right;
  -webkit-transition-duration: 1.5s;
  transition-duration: 1.5s;
  -webkit-transition-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
  transition-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transform: translate3d(110.5%, 0, 0);
  transform: translate3d(110.5%, 0, 0);
}

.show {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.covid19 {
  width: 500px;
  max-width: 100%;
  margin: 20px auto 0px auto;
  background: rgba(255, 255, 255, 0.6);
  padding: 23px;
  border: 1px solid white;
}

.covid19 p {
  font-size: 14px;
  margin-bottom: 5px;
}

.covid19 h3 {
  letter-spacing: 0.05em;
  font-size: 16px;
  font-weight: bold;
  line-height: 26px;
  margin-top: 0px;
}

@media (max-width: 480px) {
  .covid19 {
    width: 100%;
    margin-top: 20px;
    padding: 20px 30px;
    margin-bottom: 50px;
  }
}

.addressChange {
  text-align: left;
}

.tax-price {
  font-size: 0.45em;
  letter-spacing: 0.14em;
}

.news-table {
  font-size: 0.9em;
  color: #1aa7ff;
}

.news-table a {
  color: #1aa7ff;
}

.news-table tr td {
  border-top: none !important;
  padding: 5px !important;
  padding-right: 10px !important;
}

.news-table {
  height: 125px;
  overflow-y: scroll;
}

/*スクロールバーの横幅指定*/
.news-table::-webkit-scrollbar {
  width: 10px;
}

/*スクロールバーの背景色・角丸指定*/
.news-table::-webkit-scrollbar-track {
  border-radius: 8px;
  background: #f2f2f2;
}

/*スクロールバーの色・角丸指定*/
.news-table::-webkit-scrollbar-thumb {
  border-radius: 8px;
  background: rgba(48, 182, 252, 0.9);
}

#CONTENT .news-box td {
  padding: 10px;
  font-size: 0.9em;
}

@media (min-width: 481px) {
  #CONTENT .news-box .sp {
    display: none;
  }
}

@media (max-width: 480px) {
  #CONTENT .news-box td {
    width: 100%;
    display: block;
  }

  #CONTENT .news-box .pc {
    display: none;
  }
}

/* みんなの声　トップページ */
.review {
  width: 1100px;
  margin: auto;
  margin-bottom: 130px;
  max-width: 90%;
  background: #e3faff;
  border-radius: 20px;
  padding: 70px 20px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .review {
    display: none;
  }
}

.review .back_01 {
  position: absolute;
  top: 10%;
  left: 10%;
}

@media screen and (max-width: 991px) {
  .review .back_01 {
    opacity: 0.4;
  }
}

.review .back_02 {
  position: absolute;
  top: 5%;
  right: 10%;
}

@media screen and (max-width: 991px) {
  .review .back_02 {
    opacity: 0.4;
  }
}

.review h3 {
  font-size: 24px;
  font-weight: 800;
  position: relative;
  z-index: 2;
}

.review p {
  font-weight: 600;
  position: relative;
  z-index: 2;
}

.review a img {
  transition: 0.2s;
  margin-top: 10px;
}

.review a img:hover {
  transform: scale(1.01);
}

.review-sp {
  width: 100%;
  margin-bottom: 100px;
}

.review-sp img {
  display: block;
  margin: auto;
  max-width: 90%;
}

@media screen and (min-width: 768px) {
  .review-sp {
    display: none;
  }
}

/* みんなの声 */
.media-page {
  padding-top: 100px;
  padding-bottom: 100px;
}

.media-page .content {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 960px;
  max-width: 90%;
  margin: auto;
}

.media-page .content .box {
  width: calc(320px - 30px);
  margin: 15px;
  border-radius: 10px;
  border: 1px solid #adadad;
  overflow: hidden;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  transition: 0.2s;
}

.media-page .content .box:hover {
  opacity: 0.8;
}

.media-page .content .box .top img {
  display: block;
  width: 100%;
}

.media-page .content .box .blog::after {
  position: absolute;
  bottom: 10px;
  right: 10px;
  content: 'ブログ';
  color: #fff;
  font-weight: bold;
  padding: 4px 10px;
  background: #7cbfe2;
  font-size: 0.7em;
}

.media-page .content .box .text {
  padding: 20px 20px 30px 20px;
  position: relative;
}

.media-page .content .box .text h5 {
  font-size: 1em;
  font-weight: bold;
}

.media-page .content .box .text p {
  font-size: 0.9em;
}

.media-page .content-twitter {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  flex-direction: row;
  width: 1200px;
  max-width: 90%;
  margin: auto;
  margin-top: 30px;
}

.media-page .content-twitter .box {
  width: calc(400px - 30px);
  margin: 15px;
  padding: 20px;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  transition: 0.2s;
  font-size: 0.8em;
  position: relative;
}

@media screen and (max-width: 767px) {
  .media-page .content-twitter .box {
    width: calc(100% - 30px);
  }
}

.media-page .content-twitter .box .twitter-img {
  max-width: 100%;
  margin-top: 20px;
  border-radius: 10px;
}

.media-page .content-twitter .box .logo {
  position: absolute;
  top: 20px;
  right: 20px;
}

.media-page .content-twitter .box:hover {
  opacity: 0.8;
}

.media-page .content-twitter .box p {
  max-width: 90%;
  margin: auto;
  margin-top: 20px;
}

.media-page .content-twitter .box .name {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.media-page .content-twitter .box .name .left {
  width: 60px;
}

.media-page .content-twitter .box .name .left img {
  width: 50px;
  border-radius: 50em;
}

.media-page .content-twitter .box .name .right {
  width: 240px;
  font-weight: bold;
}

.media-page .content-twitter .box .name .right span {
  color: #7e7e7e;
  font-weight: normal;
}

.media-page .content-twitter .box .link {
  margin-top: 20px;
  border-radius: 10px;
  background: #fff;
  border: 0.5px solid #bebebe;
  box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.12);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  overflow: hidden;
}

.media-page .content-twitter .box .link .left {
  width: 80px;
}

@media screen and (max-width: 767px) {
  .media-page .content-twitter .box .link .left {
    width: 60px;
  }
}

.media-page .content-twitter .box .link .left img {
  width: 70px;
}

@media screen and (max-width: 767px) {
  .media-page .content-twitter .box .link .left img {
    width: 65px;
    height: 65px;
  }
}

.media-page .content-twitter .box .link .right {
  width: 240px;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .media-page .content-twitter .box .link .right {
    width: 190px;
    font-size: 0.8em;
    margin-left: auto;
  }
}

.media-page .content-twitter .box .link .right span {
  color: #7e7e7e;
  font-weight: normal;
}

/* 購入ページ　カードセット・ルーターセットタブ */
/* .tab0_label::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  background-image: url(/assets/img/apply/sim-card.png);
  background-size: contain;
  vertical-align: middle;
  margin-top: -5px;
  margin-right: 3px;
}

.tab1_label::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url(/assets/img/apply/device.png);
  background-size: contain;
  vertical-align: middle;
  margin-top: -5px;
  margin-right: 3px;
} */

@media (max-width: 480px) {

  .tab0_label,
  .tab1_label {
    font-size: 14px !important;
  }
}

.corporration-page {
  padding-top: 100px;
  position: relative;
  padding-bottom: 50px;
}

.corporrationBox {
  text-align: center;
  font-size: 18px;
  font-weight: 500;
}

.corporrationBtn {
  text-align: center;
  padding: 15px 40px;
  background: #1989ea;
  color: #fff;
  font-weight: 700;
  font-size: 20px;
  border-radius: 5px;
  display: block;
  margin: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 30px;
}

.corporrationBtn:hover {
  color: #fff;
}

.corporrationImg {
  position: absolute;
  right: 0;
  bottom: -150px;
  width: 27vw;
  max-width: 300px;
}

@media screen and (max-width: 480px) {
  .corporrationBox {
    font-size: 13px;
  }

  .corporrationImg {
    bottom: -70px;
  }

  .corporrationBtn {
    font-size: 16px;
  }
}

.affiliate-page .content .blue-btn {
  padding: 15px 60px;
  background: #1989ea;
  font-weight: 700;
  font-size: 20px;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #fff;
  border-radius: 10px;
}

.affiliate-page .content .content-1.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px;
  padding-top: 50px;
  padding-bottom: 100px;
  width: 1000px;
  margin: auto;
  max-width: 100%;
}

@media (max-width: 867px) {
  .affiliate-page .content .content-1.flex {
    display: block;
  }
}

.affiliate-page .content .content-1.flex .left {
  padding-top: 50px;
}

.affiliate-page .content .content-1.flex .left h4 {
  font-size: 25px;
  font-weight: 700;
}

@media (max-width: 867px) {
  .affiliate-page .content .content-1.flex .left h4 {
    text-align: center;
    font-size: 20px;
    font-weight: 800;
  }
}

.affiliate-page .content .content-1.flex .left p {
  width: 390px;
  max-width: 100%;
  font-size: 18px;
  line-height: 36px;
  font-weight: 500;
}

@media (max-width: 867px) {
  .affiliate-page .content .content-1.flex .left p {
    width: 100%;
    text-align: center;
    font-size: 16px;
    line-height: 28px;
  }
}

@media (max-width: 867px) {
  .affiliate-page .content .content-1.flex .left .blue-btn {
    margin: auto;
  }
}

.affiliate-page .content .content-1.flex .right {
  padding-top: 50px;
  width: 100%;
}

.affiliate-page .content .content-1.flex .right img {
  display: block;
  width: 400px;
  margin: auto;
  margin-top: 30px;
}

@media (max-width: 867px) {
  .affiliate-page .content .content-1.flex .right img {
    width: 270px;
    margin: auto;
    margin-top: 0;
  }
}

.affiliate-page .content .content-2 {
  padding-top: 100px;
  padding-bottom: 100px;
  background: #f7f7f7;
}

.affiliate-page .content .content-2-box1 {
  width: 730px;
  max-width: 100%;
  margin: auto;
}

.affiliate-page .content .content-2-box1 .img1 {
  display: block;
  width: 730px;
  max-width: 100%;
  margin: auto;
  margin-top: 30px;
}

@media (max-width: 867px) {
  .affiliate-page .content .content-2-box1 .img1 {
    display: none;
  }
}

.affiliate-page .content .content-2-box1 .img2 {
  display: block;
  width: 220px;
  max-width: 100%;
  margin: auto;
  margin-top: 30px;
}

@media (min-width: 868px) {
  .affiliate-page .content .content-2-box1 .img2 {
    display: none;
  }
}

.affiliate-page .content .content-2-box1 h4 {
  font-size: 26px;
  font-weight: 700;
  text-align: center;
}

@media (max-width: 867px) {
  .affiliate-page .content .content-2-box1 h4 {
    text-align: center;
    font-size: 20px;
    font-weight: 800;
  }
}

.affiliate-page .content .content-2-box1 p {
  font-size: 15px;
  margin-top: 10px;
  font-weight: 500;
  padding: 0 20px;
}

.affiliate-page .content .content-2-box1 .blue-btn {
  margin: auto;
  margin-top: 20px;
}

.affiliate-page .content #content-5 {
  padding-top: 100px;
  padding-bottom: 100px;
}

.affiliate-page .content #content-5 h4 {
  font-size: 26px;
  font-weight: 700;
  text-align: center;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-5 h4 {
    text-align: center;
    font-size: 20px;
    font-weight: 800;
  }
}

.affiliate-page .content #content-5 .content-5__left {
  width: 15%;
}

.affiliate-page .content #content-5 .content-5__left img {
  display: block;
  height: 30px;
  margin: auto;
  margin-top: 30px;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-5 .content-5__left img {
    height: 25px;
  }
}

.affiliate-page .content #content-5 .content-5__right {
  width: 85%;
  padding: 30px;
  padding-left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
}

.affiliate-page .content #content-5 .content-5__right .border-text {
  background: -webkit-gradient(linear,
      left top,
      left bottom,
      color-stop(60%, transparent),
      color-stop(60%, #9ee1fd));
  background: linear-gradient(transparent 60%, #9ee1fd 60%);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.affiliate-page .content #content-5 .content-5__right .num {
  position: absolute;
  left: 45px;
  top: 33px;
}

.affiliate-page .content #content-5 .content-5__right h5 {
  font-size: 22px;
  font-weight: 700;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-5 .content-5__right h5 {
    font-size: 18px;
  }
}

.affiliate-page .content #content-5 .content-5__right p {
  font-size: 15px;
  margin-top: 5px;
}

.affiliate-page .content #content-5 .content-5__right a {
  color: #00b1ff;
  text-decoration: underline;
}

.affiliate-page .content #content-5 .moshimo {
  display: block;
  width: 170px;
  margin: auto;
  margin-top: 20px;
}

.affiliate-page .content #content-5 .container-mini {
  width: 720px;
  max-width: 100%;
  margin: auto;
  margin-top: 30px;
}

.affiliate-page .content #content-5 .container-mini .flex-column {
  margin-bottom: 20px;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-5 .container-mini .flex-column {
    padding: 0 15px;
  }
}

.affiliate-page .content #content-5 .container-mini .flex-column .box-side.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.affiliate-page .content #content-5 .container-mini .flex-column .box-side.program {
  padding: 50px 70px;
  background: #f7f7f7;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-5 .container-mini .flex-column .box-side.program {
    padding: 20px 30px;
  }
}

.affiliate-page .content #content-5 .container-mini .flex-column .box-side {
  width: 720px;
  max-width: 100%;
  margin: auto;
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid #ddd;
}

.affiliate-page .content #content-6 {
  background: #f7f7f7;
  padding-top: 100px;
  padding-bottom: 100px;
}

.affiliate-page .content #content-6 h4 {
  font-size: 26px;
  font-weight: 700;
  text-align: center;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-6 h4 {
    text-align: center;
    font-size: 20px;
    font-weight: 800;
  }
}

.affiliate-page .content #content-6 .accordion {
  width: 720px;
  max-width: 100%;
  margin: auto;
}

.affiliate-page .content #content-6 .accordion__item {
  margin: 5px;
  margin-top: 15px;
  border: 1px solid #e5e5e5;
  padding: 20px;
  border-radius: 20px;
  -webkit-box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.1);
  background: #fff;
}

.affiliate-page .content #content-6 .accordion__item dt {
  font-weight: 700;
  font-size: 19px;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-6 .accordion__item dt {
    font-size: 16px;
  }
}

.affiliate-page .content #content-6 .accordion__title {
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.affiliate-page .content #content-6 .accordion__title img {
  margin-right: 20px;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-6 .accordion__title img {
    width: 23px;
  }
}

.affiliate-page .content #content-6 .accordion__content {
  display: none;
  cursor: pointer;
  padding-top: 30px;
}

.affiliate-page .content #content-6 .accordion__content img {
  float: left;
  margin-right: 20px;
  padding-bottom: 20px;
}

@media (max-width: 867px) {
  .affiliate-page .content #content-6 .accordion__content img {
    width: 23px;
  }
}

.affiliate-page .content #content-6 .accordion__content p::after {
  content: '';
  clear: both;
}

.affiliate-page .content #content-6 .accordion__content.is-open {
  display: block;
}

.plan_100gb .plan_boxtop {
  background: #e15358;
}

.plan_wifi-100gb .plan_boxtop {
  background: #5dd233;
}

.plan_esim .plan_boxtop {
  background: #fcc200;
}

.plan_100gb_btn.blue_btn {
  background: #e15358;
}

.plan_wifi-100gb_btn.blue_btn {
  background: #4ac636;
}

.plan_wifi-100gb_btn.blue_btn::after {
  content: '';
  display: inline-block;
  background-image: url(/assets/img/main/plan-wifi-icon.svg);
  width: 14px;
  height: 15px;
  margin-left: 5px;
}

.tab1_label.soldout {
  pointer-events: none;
}

.tab1_label.soldout {
  position: relative;
}

.tab1_label.soldout::after {
  content: '入荷待ち';
  position: absolute;
  top: -15px;
  right: 15px;
  font-size: 12px;
  background: #ed4354;
  padding: 4px 10px;
  border-radius: 3px;
}

.port {
  width: 1200px;
  max-width: 100%;
  margin: auto;
  margin-top: 50px;
  margin-bottom: 50px;
}

.port .port-list {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.port .port-box {
  width: 380px;
  max-width: 100%;
  margin: 10px;
}

.port .port-box img {
  max-width: 100%;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

@media screen and (max-width: 767px) {
  .port .port-box img {
    width: 280px;
    display: block;
    margin: auto;
  }
}

.port .port-box img:hover {
  opacity: 0.8;
}

.port .port-box p {
  text-align: center;
  margin-top: 15px;
}

/* FAQ */
.faq-page {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 1200px;
  max-width: 90%;
  margin: auto;
  padding-top: 100px;
  padding-bottom: 130px;
}

.faq-page .list {
  width: 18%;
}

@media screen and (max-width: 991px) {
  .faq-page .list {
    width: 100%;
  }
}

.faq-page .list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
}

@media screen and (max-width: 991px) {
  .faq-page .list ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: inherit;
    flex-flow: inherit;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

.faq-page .list ul li {
  text-align: center;
}

.faq-page .list ul li a {
  font-weight: bold;
  background: #fff;
  border: 1px solid #5db4f2;
  width: 155px;
  padding: 17px;
  margin: 5px;
  -webkit-transition: 0.2;
  transition: 0.2;
  position: relative;
}

@media screen and (max-width: 991px) {
  .faq-page .list ul li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 150px;
    padding: 5px;
    font-size: 14px;
  }
}

.faq-page .list ul li a::before {
  display: block;
  margin: auto;
}

@media screen and (max-width: 991px) {
  .faq-page .list ul li a::before {
    display: inline;
    margin: 7px;
    margin-bottom: 5px;
  }
}

.faq-page .list ul li .q1::before {
  content: url('/assets/img/faq/list/q1.svg');
}

.faq-page .list ul li.active .q1::before {
  content: url('/assets/img/faq/list/q1-active.svg');
}

.faq-page .list ul li .q2::before {
  content: url('/assets/img/faq/list/q2.svg');
}

.faq-page .list ul li.active .q2::before {
  content: url('/assets/img/faq/list/q2-active.svg');
}

.faq-page .list ul li .q3::before {
  content: url('/assets/img/faq/list/q3.svg');
}

.faq-page .list ul li.active .q3::before {
  content: url('/assets/img/faq/list/q3-active.svg');
}

.faq-page .list ul li .q4::before {
  content: url('/assets/img/faq/list/q4.svg');
}

.faq-page .list ul li.active .q4::before {
  content: url('/assets/img/faq/list/q4-active.svg');
}

.faq-page .list ul li .q5::before {
  content: url('/assets/img/faq/list/q5.svg');
}

.faq-page .list ul li.active .q5::before {
  content: url('/assets/img/faq/list/q5-active.svg');
}

.faq-page .list ul li .q6::before {
  content: url('/assets/img/faq/list/q6.svg');
}

.faq-page .list ul li.active .q6::before {
  content: url('/assets/img/faq/list/q6-active.svg');
}

.faq-page .list ul li .q7::before {
  content: url('/assets/img/faq/list/q7.svg');
}

.faq-page .list ul li.active .q7::before {
  content: url('/assets/img/faq/list/q7-active.svg');
}

.faq-page .list ul li .q8::before {
  content: url('/assets/img/faq/list/q8.svg');
}

.faq-page .list ul li.active .q8::before {
  content: url('/assets/img/faq/list/q8-active.svg');
}

.faq-page .list ul li .q9::before {
  content: url('/assets/img/faq/list/q9.svg');
}

.faq-page .list ul li.active a {
  color: #fff;
  background: #5db4f2;
}

.faq-page .list ul li.active a::after {
  position: absolute;
  content: '';
  border-top: 15px solid #5db4f2;
  border-right: 10px solid transparent;
  border-left: 10px solid transparent;
  height: 20px;
  width: 20px;
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  margin-right: -20px;
}

@media screen and (max-width: 991px) {
  .faq-page .list ul li a.active::after {
    display: none;
  }
}

.faq-page .content {
  margin-left: 0px;
  width: 70%;
}

@media screen and (max-width: 991px) {
  .faq-page .content {
    margin-left: auto;
    width: 100%;
    margin-top: 30px;
  }
}

.faq-page .content .accordion .card {
  margin-top: 20px;
}

.faq-page .content .accordion .card:nth-child(1) {
  margin-top: 0;
}

.faq-page .content .accordion button {
  text-align: left;
  font-weight: bold;
  white-space: normal;
}

@media screen and (max-width: 991px) {
  .faq-page .content .accordion button {
    font-size: 1em;
  }
}

.faq-page .content .accordion button img {
  margin-right: 20px;
}

.faq-page .accordion .card-body {
  background: rgba(31, 190, 196, 0.05);
  color: #2b2b2b;
}

.faq-page .accordion {
  margin-top: 0;
}

.accordion .card {
  border: none;
  overflow: visible;
}

.accordion .card-header {
  padding: 14px 20px;
  background: #fff;
  border: none;
  -webkit-box-shadow: 0px 2px 10px -6px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 2px 10px -6px rgba(0, 0, 0, 0.4);
}

.accordion .card-header button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: none;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  outline: none;
}

.accordion .card-header button:active {
  outline: none;
  box-shadow: none;
}

.accordion .card-body {
  background: #fafafa;
  margin-top: 10px;
  padding: 20px;
  font-size: 14px;
}

.accordion table tr td {
  border: none;
}

.accordion table tr td:first-child {
  font-weight: bold;
}

/* QRページ */

.youtube-thum {
  aspect-ratio: 16 / 9;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 767px) {
  #eSIM-SETTING p {
    font-size: 15px;
  }

  #eSIM-SETTING p.bold {
    font-size: 17px;
  }
}

/* NEWS */
#CONTENT.news-page h3{
  font-size: 23px;
  border-bottom: 2px solid #0097ee;
  width: fit-content;
  margin: auto;
  margin-bottom: 10px;
}

#CONTENT.news-page ul li,
#CONTENT .news-content ul li {
  margin-bottom: 5px;
}

.news-date {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.1em;
}

/* 申し込み タブ*/
.apply-tab .tab {
  margin: 0;
  display: flex;
  justify-content: center;
  list-style: none;
  padding-left: 0;
}

.apply-tab .tab li {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 250px;
  height: 50px;
  text-align: center;
  cursor: pointer;
  color: #fff;
  background: #a3a3a3;
  margin: 5px;
  font-size: 22px;
  font-weight: 500;
  border-radius: 2px;
}

/* .apply-tab li:nth-child(1).active {
  background: #efb802;
} */
.apply-tab li:nth-child(1).active {
  background: #30b6fc;
}

.apply-tab li:nth-child(2).active {
  background: #ed4354;
}

.apply-tab {
  padding: 10px;
}

.apply-tab div.area {
  width: 1000px;
  max-width: 100%;
  border: 1px solid #ddd;
  margin: auto;
  border-radius: 10px;
  margin-top: 20px;
  padding: 30px;
  padding-bottom: 80px;
}

.tab li a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  width: 100%;
  height: 100%;
}

/*エリアの表示非表示と形状*/
.area {
  display: none;
  /*はじめは非表示*/
  opacity: 0;
  /*透過0*/
}

/*areaにis-activeというクラスがついた時の形状*/
.area.is-active {
  display: block;
  /*表示*/
  animation-name: displayAnime;
  /*ふわっと表示させるためのアニメーション*/
  animation-duration: 1s;
  animation-fill-mode: forwards;
}

@keyframes displayAnime {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@media screen and (max-width: 767px) {
  .apply-tab .tab li {
    height: 40px;
  }

  .apply-tab div.area {
    padding: 20px 0 70px 0;
  }

  .apply-tab li {
    font-size: 18px;
    height: 40px;
    margin: 3px;
  }
}

.apply-tab-area li#tab2.soldout {
  pointer-events: none;
  position: relative;
}

.apply-tab-area li#tab2.soldout::after {
  content: '入荷待ち';
  position: absolute;
  top: -15px;
  right: 5px;
  width: 60px;
  margin: auto;
  font-size: 10px;
  background: #ed4354;
  padding: 4px 10px;
  border-radius: 3px;
}

/* SIM申し込みページ 本人確認書類 */
.identity-document-img {
  list-style: none;
  padding: 0;
  margin: 40px 0;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  column-gap: 8px;
  row-gap: 16px;
}

.identity-document-img li {
  height: auto;
  width: 100%;
  margin: 0;
}

.identity-document-img li img {
  width: 100%;
  max-width: 100%;
}

.identity-document-desc {
  font-size: 12px;
  color: #686868;
  font-weight: 400;
  text-align: center;
  margin-bottom: 3px;
  white-space: nowrap;
}

@media screen and (min-width: 368px) {
  .identity-document-img {
    justify-content: flex-start;
  }

  .identity-document-img li {
    width: calc((100% - 8px) / 2);
  }
}

@media screen and (min-width: 560px) {

  .identity-document-img li {
    width: calc((100% - 16px) / 3);
  }
}

@media screen and (min-width: 768px) {

  .identity-document-img li {
    width: calc((100% - 24px) / 4);
  }
}

@media screen and (min-width: 998px) {
  .identity-document-img {
    flex-wrap: nowrap;
  }

  .identity-document-img li {
    width: auto;
  }

  .identity-document-img li img {
    width: auto;
  }
}

/* eSIMサービス */
.esim-service__concept {
  padding: 0 15px;
}

.esim-service__concept__container {
  display: flex;
  align-items: center;
  position: relative;
  width: 920px;
  max-width: 100%;
  margin: auto;
}

.esim-service .esim-service__concept__container h3 {
  text-align: left;
}

.esim-service__concept__inner.text {
  width: 50%;
  padding-top: 50px;
}

.esim-service__concept__inner.visual {
  width: 50%;
  margin-top: -70px;
}

.esim-service__concept__inner.visual figure {
  width: 480px;
  max-width: 100%;
}

.esim-service__concept__inner.visual figure img {
  width: 100%;
}

.esim-service .btn,
.sim-service__property .btn,
a.service-btn {
  padding: 12px 40px;
  background: #4cc3f2;
  color: #fff;
  font-weight: 600;
  display: block;
  width: fit-content;
  margin-top: 20px;
}

.sim-service__property .text-center .btn {
  margin: auto;
}

.esim-service,
.esim-service__property h3 {
  text-align: center;
}

.esim-service h4,
.esim-service__property h4 {
  font-weight: 600;
  margin-bottom: 7px;
}

.esim-service__property {
  background: #f7fbfd;
  padding: 70px 15px;
}

.esim-service__property__container {
  display: flex;
  align-items: flex-end;
  flex-direction: row-reverse;
  max-width: 920px;
  min-height: 170px;
  margin: auto;
  position: relative;
  margin-bottom: 24px;
}

.esim-service__property__container.img-right {
  flex-direction: row;
}

.esim-service__property__inner {
  margin-top: 40px;
}

.esim-service__property__inner.text {
  width: 64%;
  min-width: 229px;
  background: #fff;
  border-radius: 20px;
  padding: 16px 24px;
  z-index: 5;
  box-shadow: 0px 3px 40px rgba(0, 0, 0, 0.06);
}

.esim-service__property__inner.text h4 {
  font-size: 15px;
  margin-top: 0;
  margin-bottom: 4px;
}

.esim-service__property__inner.text>p,
.esim-service__property__inner.text>a {
  font-size: 12px;
  letter-spacing: 0;
  line-height: 1.5;
}

.esim-service__property__inner.text>p {
  margin-bottom: 6px;
}

.img-left .esim-service__property__inner.text {
  margin-top: 48px;
  text-align: left;
}

.img-right .esim-service__property__inner.text {
  margin-top: 48px;
  text-align: left;
}

.esim-service__property__inner.visual {
  width: 63%;
  max-width: 270px;
  min-width: 226px;
  margin: 0;
  position: absolute;
  top: 0;
}

.img-left .esim-service__property__inner.visual {
  left: 0;
}

.img-right .esim-service__property__inner.visual {
  right: 0;
}

.esim-service__property__inner.visual img {
  width: 100%;
  min-width: 160px;
  border-radius: 20px;
}

.esim-service__area {
  margin-top: 100px;
  margin-bottom: 100px;
}

@media screen and (min-width: 576px) {
  .esim-service__property__container {
    flex-direction: row;
  }

  .esim-service__property__container.img-right {
    flex-direction: row-reverse;
  }

  .esim-service__property__container {
    display: flex;
    align-items: flex-end;
    position: relative;
    width: 920px;
    max-width: 100%;
    margin: auto;
  }

  .esim-service__property__inner.text {
    width: 500px;
    margin-bottom: 20px;
    padding: 20px 30px;
  }

  .esim-service__property__inner.visual {
    width: 70%;
    max-width: none;
    position: static;
    margin-top: 40px;
  }

  .img-left .esim-service__property__inner.text {
    margin-left: -70px;
  }

  .img-right .esim-service__property__inner.text {
    margin-right: -70px;
  }

  .esim-service__property__inner.text h4 {
    font-size: 18px;
    margin-bottom: 8px;
  }

  .esim-service__property__inner.text>p,
  .esim-service__property__inner.text>a {
    font-size: 13px;
    letter-spacing: .15em;
  }

  .esim-service__property__inner.text>p {
    margin-bottom: 6px;
  }
}

.esim-service__area__container {
  display: flex;
  justify-content: center;
  position: relative;
  width: 920px;
  max-width: 100%;
  margin: auto;
  flex-wrap: wrap;
}

.esim-service__area__item {
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(100% / 3 - 20px);
  min-width: 280px;
  margin: 10px;
  padding: 18px 30px;
  border-radius: 10px;
  box-shadow: 0px 3px 20px rgba(0, 0, 0, 0.06);
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  transition: 0.2s;
}

.esim-service__area__item:hover {
  transform: scale(0.97);
}

.esim-service__area__item img {
  margin-right: 8px;
}

.esim-service__area .modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  width: 100%;
  padding: 20px;
}

.esim-service__area .modal__bg {
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
  height: 100vh;
  position: absolute;
  width: 100%;
  z-index: 0;
}

.esim-service__area .modal__content a.js-modal-close {
  position: absolute;
  right: 15px;
  top: 15px;
}

.esim-service__area .modal__content {
  position: relative;
  background: #fff;
  padding: 50px 20px;
  width: 600px;
  max-width: 100%;
  height: fit-content;
  max-height: 100%;
  overflow-y: scroll;
  z-index: 10;
  margin: auto;
}

.esim-service__area .modal h3 {
  text-align: center;
  margin-bottom: 20px;
  margin-top: 0;
}

.esim-service__area .modal table {
  width: 300px;
  max-width: 100%;
  margin: auto;
}

@media (min-width: 481px) {
  .modal table {
    width: 480px;
  }
}

.esim-service__area .modal tr td {
  border: 1px solid #ddd;
  padding: 10px;
}

.esim-service__scene {
  margin-top: 100px;
  padding-top: 70px;
  padding-bottom: 70px;
  background: #f7fbfd;
}

.esim-service__scene__container {
  display: flex;
  justify-content: center;
  position: relative;
  width: 920px;
  max-width: 100%;
  margin: auto;
  flex-wrap: wrap;
}

.esim-service__scene__item {
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(100% / 3 - 20px);
  min-width: 280px;
  margin: 10px;
  padding: 70px 20px;
  border-radius: 20px;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  background: #000;
  color: #fff;
  background-size: cover;
  background-position: center center;
}

.esim-service__setting__container {
  width: 500px;
  max-width: 90%;
  background: #f7fbfd;
  padding: 30px;
  margin: auto;
  border-radius: 10px;
  margin-top: 70px;
  position: relative;
}

.esim-service__setting__container h4 {
  text-align: center;
  margin-top: 10px;
}

.esim-service__setting__container p {
  text-align: center;
}

.esim-service__setting__container .btn {
  margin: 20px auto;
}

.visual-sp {
  position: absolute;
  bottom: 20px;
  right: 10px;
  transform: rotate(20deg);
  opacity: 0.2;
}

@media (max-width: 900px) {
  .esim-service__concept__container {
    flex-direction: column;
  }

  .esim-service__concept__inner.visual {
    order: 0;
    margin-top: -40px;
    width: 60%;
  }

  .esim-service__concept__inner.text {
    order: 1;
    width: 90%;
    padding-top: 20px;
  }

  .esim-service__property {
    padding: 50px 15px;
  }

  .esim-service h4 {
    font-size: 16px;
  }

  .esim-service__area .modal__content {
    max-height: 100%;
  }
}

.esim-service .faq {
  margin-top: 100px;
}

.esim-service .accordion {
  display: flex;
  flex-wrap: wrap;
  width: 920px;
  max-width: 100%;
  margin: auto;
}

.esim-service .accordion .card {
  width: calc(50% - 20px);
  margin: 10px;
}

.esim-service .accordion .card button {
  color: #000;
  white-space: normal;
  margin: 0;
  padding: 10px;
  text-align: left;
}

.esim-service .accordion .card button img {
  margin-right: 15px;
}

.esim-service .accordion .tab_panel p {
  text-align: left;
}

.esim-service #ser_about {
  background-image: url(/assets/img/service/esim/main-bg.jpg) !important;
  padding-left: 15px;
  padding-right: 15px;
}

.esim-service #ser_about .visual-phone {
  margin-top: -130px;
}

.esim-service .esim-service__concept-title {
  margin-right: auto;
  width: fit-content;
}

.esim-service #ser_about h3 {
  font-size: 32px;
}

.esim-service #ser_about .box hr {
  margin-right: auto;
  margin-left: 0;
  text-align: left;
  width: 90px;
}

.esim-service #ser_about .box {
  border-radius: 30px;
  padding: 40px 10px 40px 50px;
  max-width: 1180px;
}

.esim-service #ser_about .box p {
  line-height: 1.7;
  text-align: left;
  letter-spacing: 0.15em;
}

@media (max-width: 992px) {
  .esim-service #ser_about .visual-phone {
    margin-top: -20px;
  }

  .esim-service #ser_about .visual-phone img {
    width: 260px;
  }

  .esim-service .esim-service__concept-title {
    text-align: center;
    width: 100%;
  }

  .esim-service #ser_about h3 {
    font-size: 25px;
  }

  .esim-service #ser_about .box hr {
    margin-right: auto;
    margin-left: auto;
    text-align: center;
    width: 75px;
  }

  .esim-service #ser_about .box {
    padding: 30px;
  }
}

@media (max-width: 567px) {
  .esim-service .main-faq .accordion {
    flex-direction: column;
  }

  .esim-service .accordion .card {
    width: 90%;
    margin: auto;
    margin-bottom: 5px;
  }
}

/* EN-FOOTER */
.en-footer .pc_footer .container {
  width: 1200px;
}

.en-footer .pc_footer .container .F_col1 {
  width: 30%;
}

.en-footer .pc_footer .container .F_col2 {
  width: 30%;
}

.en-footer .pc_footer .container .F_col3 {
  margin-left: 0;
  width: 18%;
}

.en-footer .pc_footer .container .F_col4 {
  margin-left: 0;
  width: 10%;
}

#footer.en-footer .trans_btn {
  line-height: 15px;
  padding: 10px;
  border-radius: 7px;
}

.nav-toggle-icon::after {
  display: inline-block;
  content: '';
  width: 8px;
  height: 8px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
  margin-bottom: 4px;
  margin-left: 7px;
}

.kome.startMonth {
  margin-top: 10px;
}

.service-main-boxes {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.service-main-box-1,
.service-main-box-2,
.service-main-box-3 {
  width: 203px;
  height: 140px;
  border-radius: 10px;
  margin: 5px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-size: cover;
  color: #fff;
  font-weight: bold;
}

.service-main-box-1 {
  background-image: url(/assets/img/service/main-box-1.jpg);
}

.service-main-box-2 {
  background-image: url(/assets/img/service/main-box-2.jpg);
}

.service-main-box-3 {
  background-image: url(/assets/img/service/main-box-3.jpg);
}

.main-service-position {
  position: relative;
}

.main-service-position .back-01 {
  position: absolute;
  top: -30px;
  right: 0;
  width: 130px;
}

.main-service-position .back-02 {
  position: absolute;
  bottom: -120px;
  left: 0;
  width: 150px;
}

@media(max-width:1040px) {

  .main-service-position .back-01,
  .main-service-position .back-02 {
    display: none;
  }
}

#DEVICE .nav-pills>li.active.esim-device--active>a {
  background: #efb802;
}

#DEVICE .nav-pills>li.esim-device--active:hover>a {
  background: #efb802;
}

#DEVICE .nav-pills>li.active.esim-device--active>a,
#DEVICE .nav-pills>li.active.esim-device--active>a:focus,
#DEVICE .nav-pills>li.active.esim-device--active>a:hover {
  background: #efb802;
}

#DEVICE .nav-pills>li.active.esim-device--active>a:after {
  border-top-color: #efb802 !important;
  border-top: 8px solid #efb802;
}

#DEVICE .nav>li.esim-device--active>a {
  background: #fff7e1;
}

.news-content {
  padding: 24px;
  background-color: #ebf9fe;
  max-width: 510px;
  width: 94%;
  margin: 40px auto 0;
}
.news-content-title {
  text-align: center;
  font-weight: 700;
  margin-bottom: 20px;
  color: #1aa7ff;
  font-size: 17px;
}
.contact .news-content {
  background-color: #eee;
}
.contact .news-content-title {
  color: inherit;
}