@charset "UTF-8";

/* Scss Document */
/***************************************************************
File name  　　　　 : 　　　common.css
Description 　　　　:　　　 共通スタイル定義
Date       　　　　 :      2021/03
**************************************************************/
/*beforeやafterの共通項目*/
/*約半用フォントスタイル*/
/*Winでも綺麗に見える游ゴシック太字*/
/*variable*/
/*-------------------------------------------------------------
reset
-------------------------------------------------------------*/
* {
  margin: 0px;
  padding: 0px;
  box-sizing: border-box;
  outline: none;
}

*:after,
*:before {
  box-sizing: border-box;
}

table {
  border-collapse: collapse;
  border-spacing: 0px;
}

ul,
li {
  list-style-type: none;
}

img{
  max-width: 100%;
}

/*-------------------------------------------------------------
common
-------------------------------------------------------------*/
body {
  margin-top: 70px;
  font-family: "Arial", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  color: #181818;
  position: relative;
  min-width: 1080px;
  background: url(../img/bg.png);
}

a {
  text-decoration: none;
  display: inline-block;
}

img {
  display: block;
}

main {
  margin-bottom: 72px;
  font-family: "Noto Sans JP", sans-serif;
}

main>div {
  padding: 80px 0 80px;
}

main>div:nth-of-type(odd) {
  background-color: #FFFAEB;
}

main>div:nth-of-type(even) {
  background-color: #ffffff;
}

main>div picture img {
  margin: 0 auto;
}

main>div h2 {
  margin: 40px 10px 30px 50px;
  padding-left: 10px;
  border-left: 20px solid #009EA7;
}

main>div h2:first-of-type {
  margin: 60px 10px 30px 50px;
}

main>div p {
  margin-top: 30px;
  padding: 0 50px;
}

main>div p strong {
  font-family: "Arial", "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
}

main>div.contact {
  padding: 60px 0 70px;
}

.pc_none{
  display: none;
}

/*-------------------------------------------------------------
ヘッダー
-------------------------------------------------------------*/
header {
  display: flex;
  position: fixed;
  z-index: 40;
  top: 0;
  width: 100%;
  height: 70px;
  justify-content: space-between;
  background-color: #fff;
  box-shadow: 0 4px rgba(5, 63, 15, 0.2);
}

header h1 {
  margin: 10px 0 0 40px;
}

header .btn {
  display: flex;
}

header .btn .contactBtn {
  display: flex;
  z-index: 40;
}

header .btn a {
  background-color: #fff;
}

header .menu #menuBtn {
  width: 70px;
  height: 70px;
  top: 30px;
  right: 0;
  padding-top: 21px;
  cursor: pointer;
}

header .menu #menuBtn>span {
  display: block;
  position: relative;
  width: 32px;
  height: 2px;
  margin: 0 auto;
  background-color: #53c8c4;
  transition: 0.3s;
}

header .menu #menuBtn>span:nth-of-type(1) {
  top: 0;
}

header .menu #menuBtn>span:nth-of-type(2) {
  top: 11px;
}

header .menu #menuBtn>span:nth-of-type(3) {
  top: 22px;
}

header .menu .menuClose {
  perspective: 42px;
  -webkit-perspective: 42px;
}

header .menu .menuClose>span:nth-of-type(1) {
  transform: translateY(13px) rotate(-45deg);
}

header .menu .menuClose>span:nth-of-type(2) {
  opacity: 0;
}

header .menu .menuClose>span:nth-of-type(3) {
  transform: translateY(-13px) rotate(45deg);
}

header .menu nav {
  position: fixed;
  top: 70px;
  right: -100%;
  transition: 0.3s;
}

header .menu nav ul {
  padding: 40px 50px 70px;
  border-top: 4px rgba(5, 63, 15, 0.3) solid;
  border-left: 5px #53c8c4 solid;
  border-bottom: 5px #53c8c4 solid;
  border-radius: 0 0 0 80px;
  background-color: #fff;
  box-shadow: 4px 4px rgba(5, 63, 15, 0.3);
}

header .menu nav ul li {
  padding: 15px 0;
}

header .menu nav ul li a {
  color: #53c8c4;
  font-size: 22px;
  font-family: "Arial", "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  line-height: 1.3;
}

header .menu nav.open {
  right: 0;
}

/*-------------------------------------------------------------
ローカルナビ
-------------------------------------------------------------*/
.local {
  background-color: #53c8c4;
}

.local ul {
  display: flex;
  flex-wrap: wrap;
  /*justify-content: space-between;*/
  padding: 40px 70px 20px;
}

.local ul li {
  position: relative;
  margin-bottom: 20px;
  margin-right: 10px;
}

.local ul li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 300px;
  height: 62px;
  padding: 0 50px;
  border: 3px #181818 solid;
  border-radius: 31px;
  background-color: #fff;
  box-shadow: 4px 4px rgba(5, 63, 15, 0.3);
  font-family: "Arial", "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  color: #181818;
  text-align: center;
  font-size: 21px;
  line-height: 1.3;
}

.local ul li a:after {
  content: "";
  position: absolute;
  display: inline-block;
  width: 20px;
  height: 20px;
  background-size: cover;
  background-image: url("../img/arrow_down.svg");
  top: 50%;
  right: 25px;
  margin-top: -10px;
}

/*-------------------------------------------------------------
トップバナーとお申込みボタン 20240502
-------------------------------------------------------------*/
.mv {
  display: block;
  position: relative;
}

#mv-img {
  width: 100%;
  height: auto;
  display: block;
}

.mv>#omoshikomi-Btn_mv {
  position: absolute;
  left: 25%;
  top: 83.4%;
  display: block;
  width: 570px;
  box-sizing: border-box;
  background: #FFF;
  border: 2px solid #DB0212;
  border-radius: 10px;
  padding: 20px;
  text-align: center;
  color: #DB0212;
  font-size: 1.3em;
  font-weight: bold;
  transition: .3s;
  text-decoration: none;
  box-shadow: 0px 5px #C81B1B;
  transition: 0.2s ease-in-out;
}

#omoshikomi-Btn_mv::after {
  content: '';
  /*絶対配置で矢印の位置を決める*/
  position: absolute;
  top: 42%;
  right: 60px;
  /*矢印の形状*/
  width: 11px;
  height: 11px;
  border-top: 3px solid #C81B1B;
  border-right: 3px solid #C81B1B;
  transform: rotate(45deg);
}

.mv>#omoshikomi-Btn_mv:hover {
  box-shadow: none;
  transform: translate(5px, 5px);
  color: #C81B1B;
}

/*-------------------------------------------------------------
共通
-------------------------------------------------------------*/
.title_h2 {
  color: #fff;
  font-size: 2.25em;
  font-weight: bold;
  text-align: center;
  padding: 12px 20px 16px;
  width: 95%;
  background-color: #009ea9;
  border-radius: 60px;
  margin: 0 auto !important;
}

.plan_shoki-hiyo_h3,
.option-survice_h3 {
  color: #009ea9;
  text-shadow: 0 0 5px white;
  padding: 0.2em 0.5em;
  background: -webkit-repeating-linear-gradient(-70deg, #ccffe2, hsl(167, 100%, 90%) 3px, #e9fff9 3px, #e9fffa 7px);
  background: repeating-linear-gradient(-70deg, #BCF0F3, #BCF0F3 4px, #fff 3px, #fff 5px);
  margin: 30px 50px 30px 50px !important;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
}


/*-------------------------------------------------------------
月額料金
-------------------------------------------------------------*/
#price p {
  margin: 30px auto 0;
}

/*-------------------------------------------------------------
おすすめポイント
-------------------------------------------------------------*/
#osusume-point {
  background-color: #FFFAEB;
}

.osusume-point_h3 img {
  margin: 67px auto 52px;
}

.box_flex {
  display: flex;
  justify-content: space-between;
  padding: 0 104px;
}

.osusume-point_p {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.6;
  padding: 0;
  margin-top: 0;
  max-width: 410px;
}

.font-normal {
  font-size: 16px;
  font-weight: normal;
}

#point p {
  margin-top: 20px;
  padding-left: 65px;
  color: #fff;
}

#point .contact {
  margin-top: 50px;
}

.ccnetbtn {
  margin: 30px auto 50px;
  padding: 0;
  max-width: 396px;
}

.ccnetbtn a {
  display: inline-block;
  width: 100%;
  padding: 10px 50px;
  margin: 20px auto 10px auto;
  border-radius: 30px;
  border: #009EA7 2px solid;
  background-color: #FFF;
  font-size: 20px;
  font-weight: 700;
  color: #009EA7;
  letter-spacing: 1px;
  /*width: 300px;*/
  text-align: center;
}

.ccnetbtn a:hover {
  background-color: #009EA7;
  color: #fff;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
}

#osusume-point p:has(.ccnetbtn) {
  margin-top: 0;
}

.omoshikomi-Btn {
  margin: 40px auto;
}

.omoshikomi-Btn a {
  /*padding: 20px 50px;
  margin: 20px auto 10px auto;
  border-radius: 15px;
  border: #009EA7 2px solid;
  background-color: #F6FEFF;
  font-size: 1.25em;
  font-weight: 700;
  color: #009EA7;
  letter-spacing: 1px;
  width: 600px;
  text-align: center;*/
  display: block;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  position: relative;
  width: 640px;
  margin: auto;
  padding: 1.5rem 2rem;
  font-size: 23px;
  font-weight: bold;
  letter-spacing: 1px;
  border-radius: 15px;
  color: #DA0212;
  background-color: #FFF;
  border: 2px solid #C81B1B;
  box-shadow: 0px 5px #C81B1B;
  transition: 0.3s ease-in-out;
}

.omoshikomi-Btn a::after {
  content: '';
  /*絶対配置で矢印の位置を決める*/
  position: absolute;
  top: 42%;
  right: 60px;
  /*矢印の形状*/
  width: 11px;
  height: 11px;
  border-top: 3px solid #C81B1B;
  border-right: 3px solid #C81B1B;
  transform: rotate(45deg);
}


.omoshikomi-Btn a:hover {
  box-shadow: none;
  transform: translate(5px, 5px);
  color: #C81B1B;
}
#osusume-point{
  padding-bottom: 86px;
}
#osusume-point .omoshikomi-Btn{
  margin: 64px 0 0 0;
}


/*-------------------------------------------------------------
プラン・エリア
-------------------------------------------------------------*/
#plan p {
  margin: 20px auto 0;
}

#plan .area {
  margin-top: 100px;
}
#plan_shoki-hiyo{
  padding: 100px 0 66px;
}
#plan_shoki-hiyo .plan_shoki-hiyo_h3{
  margin-top: 50px !important;
}
#plan_shoki-hiyo .note{
  margin: 25px 0 60px 0;
  padding: 0 100px;
  font-size: 18px;
}


/*-------------------------------------------------------------
ご利用の流れ
-------------------------------------------------------------*/
#flow {
  position: relative;
}

#flow .btn {
  display: flex;
  position: absolute;
  top: 430px;
  left: 170px;
}

#flow .btn a {
  width: 364px;
  display: block;
}

#flow .btn a:first-of-type {
  margin-right: 15px;
}

#flow .btn a img {
  width: 100%;
  height: auto;
}

#omoushikomi-nagare .omoshikomi-Btn{
  margin-top: 86px;
}
.omoushikomi-nagare-inner{
  padding: 0 50px;
}
.flow{
  display: inline-block;
  margin-bottom: 78px;
}
.omoshikomi-Link{
  text-align: right;
}
.omoshikomi-Link a{
  margin-top: 18px;
  font-size: 20px;
  font-weight: bold;
  margin-top: 0;
  text-decoration: underline;
  color: #000000;
}

#hanbai-kisyu{
  padding-bottom: 38px;
}

#hanbai-kisyu .title_h2{
  margin-bottom: 58px !important;
}

#option-survice .title_h2{
  margin-bottom: 58px !important;
}
#tuwa-option .note{
  margin-top: 35px;
  font-size: 18px;
}

/*-------------------------------------------------------------
よくある質問
-------------------------------------------------------------*/
#faq .contact {
  margin-top: 110px;
}

/*-------------------------------------------------------------
オプション
-------------------------------------------------------------*/
#option {
  padding-bottom: 130px;
}

#option p {
  margin: 60px auto 0;
}
#yuryo-option {
  margin-top: 86px;
}


/*-------------------------------------------------------------
お問い合わせ
-------------------------------------------------------------*/
.contact .afterBg {
  position: relative;
  margin: 0 auto;
}

.contact .afterBg:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 20px;
  left: 20px;
  border-radius: 8px;
  background: url("../img/bg_line.png");
}

.contact .afterBg .wrap {
  position: relative;
  z-index: 20;
  padding: 40px;
  border: 4px #181818 solid;
  border-radius: 10px;
  background-color: #fff;
}

.contact .afterBg .ttl {
  display: flex;
  position: relative;
  margin-bottom: 20px;
}

.contact .afterBg .ttl:after {
  content: "";
  position: absolute;
  display: inline-block;
  width: 394px;
  height: 173px;
  background-size: cover;
  background-image: url("../img/img_fukidashi.png");
  top: -120px;
  right: -60px;
}

.contact .afterBg .btn {
  display: flex;
  justify-content: space-between;
}

.contact .afterBg .btn a {
  display: block;
  width: 414px;
}

.contact .afterBg .btn a img {
  width: 100%;
  height: auto;
}

#contact {
  padding: 50px 0 0;
  background-color: #fff;
}

#contact .contact {
  background-color: #4ba2d4;
  padding: 60px 0 80px;
}

/*-------------------------------------------------------------
フッター
-------------------------------------------------------------*/
footer {
  background-color: #fff;
}

footer .note {
  padding: 40px 0;
}

footer .copy {
  padding: 5px 10px;
  text-align: center;
  color: #fff;
  background-color: #53c8c4;
}

/*-------------------------------------------------------------
IEのみ
-------------------------------------------------------------*/
@media all and (-ms-high-contrast: none) {
  .local ul li a span {
    position: relative;
    top: 3px;
  }
}

/*-------------------------------------------------------------
PC（hover/一部の装飾）
-------------------------------------------------------------*/
@media (min-width: 481px) {
  a * {
    transition: opacity 0.5s;
  }

  a:hover {
    cursor: pointer;
  }

  a:hover * {
    opacity: 0.7;
  }

  br.sp {
    display: none;
  }

  .mv,
  .local,
  main>div,
  .note {
    width: 1080px;
    margin: 0 auto;
  }
  /*.mv{
    margin-bottom: 30px;
  }*/

  header .menu .menuOpen:hover>span {
    width: 34px;
    opacity: 0.7;
  }

  header .menu .menuOpen:hover>span:nth-of-type(1) {
    top: -2px !important;
  }

  header .menu .menuOpen:hover>span:nth-of-type(2) {
    top: 11px !important;
  }

  header .menu .menuOpen:hover>span:nth-of-type(3) {
    top: 24px !important;
  }

  .local ul li a {
    position: relative;
    transition: 0.3s;
  }

  .local ul li:hover a {
    top: 4px;
    right: -4px;
    box-shadow: none;
  }

  #price p {
    width: 920px;
  }

  #point p {
    width: 500px;
  }

  #plan p {
    width: 815px;
  }

  #plan .plan {
    position: relative;
    left: -30px;
  }

  #option p {
    width: 810px;
  }

  .contact .afterBg {
    width: 960px;
  }

  #option-survice #tuwa-option .omoshikomi-Btn{
    display: none;
  }
  #omoushikomi-nagare{
    padding: 100px 0 80px;
  }
  #omoushikomi-nagare .omoushikomi-nagare-inner{
    margin-top: 30px;
  }
}

/*-------------------------------------------------------------
PC（お問い合わせ）
-------------------------------------------------------------*/
@media (max-width: 1080px) {
  header {
    padding-right: 70px;
  }

  header h1 {
    margin-left: 20px;
  }

  /* header .btn {
    position: fixed;
    bottom: 0;
    right: 0;
  } */

  header .menu #menuBtn {
    position: fixed;
    top: 0;
  }

  footer .copy {
    padding-bottom: 80px;
  }
}

/*-------------------------------------------------------------
スマホ
-------------------------------------------------------------*/
@media (max-width: 480px) {
  body {
    min-width: 100%;
  }

  .mv,
  .local,
  main>div,
  .note {
    width: 100%;
  }

  main>div {
    padding: 72px 5% 62px;
  }

  header {
    display: block;
  }

  header h1 {
    max-width: 270px;
    margin-top: 15px;
  }

  header h1 img {
    width: 100%;
    height: auto;
  }

  header .btn {
    width: 100%;
    position: fixed;
    left: 0;
    bottom: 0;
    display: block;
  }

  header .btn .tel {
    max-width: 282px;
  }

  header .btn .tel img {
    width: 100%;
    height: auto;
  }

  header .btn .mail {
    max-width: 230px;
  }

  header .btn .mail img {
    width: 100%;
    height: auto;
  }

  header .menu nav ul {
    padding: 40px 30px;
    border-radius: 0 0 0 40px;
  }

  header .menu nav ul li a {
    font-size: 16px;
  }

  .mv>#omoshikomi-Btn_mv{
    width: 90%;
    left: 0;
    right: 0;
    margin: auto;
    padding: 9px 40px;
    font-size: 18px;
  }
  .mv>#omoshikomi-Btn_mv::after{
    top: 0;
    bottom: 0;
    margin: auto;
    right: 23px;
  }
  .omoshikomi-Btn a{
    width: 100%;
    padding: 6px 40px;
    font-size: 18px;
  }
  .omoshikomi-Btn a::after{
    top: 0;
    bottom: 0;
    margin: auto;
    right: 23px;
  }

  main {
    margin-bottom: 0;
  }

  main>div picture img {
    width: 100%;
  }

  .pc_none{
    display: block;
  }

  .title_h2{
    font-size: 30px;
    border-radius: 15px;
    margin: 0 0 26px 0 !important;
    width: 100%;
    border-left: 0;
  }
  main>div h2 {
    margin: 40px 10px 20px 0;
    padding-left: 10px;
    border-left: 20px solid #009EA7;
  }

  main>div h2:first-of-type {
    margin: 40px 10px 20px 0;
  }
  .box_flex{
    display: block;
    padding: 0;
  }
  #osusume-point .omoshikomi-Btn{
    margin: 75px auto 0;
  }
  .osusume-point_p{
    margin: 0 0 20px 0;
    padding: 0;
    max-width: none;
    font-size: 16px;
  }
  .osusume-point_img{
    text-align: center;
  }
  .osusume-point_img img{
    display: inline-block;
  }
  .osusume-point_img img#point5_img{
    max-width: 211px;
  }
  #plan_shoki-hiyo .plan_shoki-hiyo_h3,
  .option-survice_h3{
    width: 100%;
    margin: 0 0 23px 0 !important;
    margin-top: 0 !important;
    padding: 7px 0;
    font-size: 25px;
  }
  .osusume-point_h3 img{
    margin: 44px auto 18px;
  }
  .font-normal{
    display: block;
    font-size: 13px;
  }
  .ccnetbtn a{
    font-size: 18px;
    padding: 10px 20px;
    margin: 0;
  }
  #plan_shoki-hiyo{
    padding: 72px 5% 62px;
  }
  #plan_shoki-hiyo .note{
    padding: 0;
    margin-bottom: 52px;
    font-size: 15px;
  }
  .omoushikomi-nagare-inner{
    padding: 0;
  }
  .omoshikomi-Link{
    text-align: left;
  }
  #plan_shoki-hiyo .omoshikomi-Btn{
    margin: 52px auto 0;
  }
  .flow{
    margin-bottom: 64px;
  }

  #omoushikomi-nagare .omoshikomi-Btn{
    margin: 46px auto 0;
  }
  #option-survice .title_h2{
    margin-bottom: 20px !important;
  }
  #option-survice .note{
    margin-top: 14px;
    margin-bottom: 52px;
    font-size: 15px;
  }
  #option-survice .omoshikomi-Btn{
    margin: 52px auto 64px;
  }
  #yuryo-option .omoshikomi-Btn{
    margin: 36px auto 0;
  }
  .yuryo-option_inner{
    padding: 0 8px;
  }
  #hanbai-kisyu{
    padding-bottom: 30px;
  }




  main>div p {
    margin-top: 20px;
    padding: 0;
  }

  main>div.contact {
    padding: 70px 5%;
  }

  .mv img {
    width: 100%;
    height: auto;
  }

  .local ul {
    padding: 33px 3% 37px;
    justify-content: space-between;
  }

  .local ul li {
    width: 48.5%;
    width: calc((100% - 15px) / 2);
    margin-right: 0;
  }

  .local ul li:last-child{
    margin-bottom: 0;
  }

  .local ul li a {
    width: 100%;
    min-height: 62px;
    height: auto;
    padding: 0 30px;
    font-size: 15px;
  }

  .local ul li a:after {
    width: 15px;
    height: 15px;
    right: 18px;
    margin-top: -7.5px;
  }

  #plan .area {
    margin-top: 50px;
  }

  #point p {
    padding-left: 0;
  }

  #point .contact {
    margin-top: 120px;
  }

  #flow .btn {
    display: block;
    top: 23.5%;
    left: 50%;
    margin-left: -130px;
  }

  #flow .btn a {
    max-width: 260px;
  }

  #flow .btn a:first-of-type {
    margin-bottom: 25px;
  }

  #option {
    padding-bottom: 50px;
  }

  #contact .contact {
    padding: 80px 5%;
  }

  .contact .afterBg:after {
    width: 95%;
    height: 95%;
    top: 24px;
    left: 20px;
  }

  .contact .afterBg .wrap {
    padding: 20px;
  }

  .contact .afterBg .ttl {
    display: block;
  }

  .contact .afterBg .ttl:after {
    top: -126px;
    right: -20px;
    width: 270px;
    height: 118px;
  }

  .contact .afterBg img {
    width: 100%;
    height: auto;
  }

  .contact .afterBg .btn {
    display: block;
  }

  .contact .afterBg .btn a {
    width: 100%;
  }

  .contact .afterBg .btn a:first-of-type {
    margin-bottom: 20px;
  }

  footer .note {
    padding: 40px 5%;
  }

  footer .copy {
    padding-top: 20px;
    padding-bottom: 100px;
  }
}

/*-------------------------------------------------------------
スマホ__おすすめポイント
-------------------------------------------------------------*/
@media (max-width: 480px) {

}

/*-------------------------------------------------------------
スマホ（横）
-------------------------------------------------------------*/
@media screen and (max-height: 525px) {
  nav {
    height: 100%;
  }

  nav ul {
    overflow-y: auto;
    height: 100%;
  }
}

/*# sourceMappingURL=common.css.map */