@charset "UTF-8";

* {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
}
html{
  overflow-y: scroll;
  scroll-behavior: smooth;
}

body {
  background-color: #fff;
  width: 100%;
  margin: 0 auto;
  font-family:'Century Gothic','Futura','游ゴシック',YuGothic,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',Osaka,sans-serif;
  font-size: 16px;
  color: #FFF;
  -webkit-box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.5);
  -moz-box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.5);
  box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.5);
  overflow: hidden;
  overflow-y: hidden;
}
main {width: 800px;margin: 0 auto;    background: #fff;  -webkit-box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.5);
  -moz-box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.5);
  box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.5);}
.flex-box {
  display: flex;
}
.mv1 {
  opacity: 0;
  transform : translate(0,70px);
  transition : 1.2s;
}

.mv1.scrollin{
  opacity: 1;
  transform: translate(0, 0);
}
.blinking{ animation:blink 1s ease-in-out infinite alternate;}
p{    margin: 0 auto;}
.mt30 {margin-top:30px;}
.mt50 {margin-top:50px;}
.mb30 {margin-bottom:30px;}
.mb50 {margin-bottom:50px;}
.pt20 {padding-top:20px;}
.pt30 {padding-top:30px;}
.pt50 {padding-top:50px;}
.pm10 {padding-bottom:10px;}
.pm20 {padding-bottom:20px;}
.pm30 {padding-bottom:30px;}
.pm50 {padding-bottom:50px;}
.mkr {
    background: linear-gradient(transparent 50%, #fff293 50%);
    font-weight: bold;
}
/***voice**/
.voice_bg{  background: #fef6e2;}
.voice_title{ font-size: 1.5rem;    margin-top: 15px;}
.voice_t{      color: #866120; font-size: 1.5rem;  font-weight: 700;margin: 10px 0;}
.v_txt{font-size: 1.2rem;  background: #f3f3f3;padding: 15px;}
.old {
    background: #866120;
    font-weight: 700;
    border-radius: 0.5em;
    color: #fff;
    padding: .5% 1%;
    margin-left: 2%;
}
.container {
  position: relative;
  width: calc(98%/1);
  display: inline-block;
  margin: 1% 8px 1% 8px;
  color: #000;
}
.sectxt{margin: 2% 5%;color: #000;font-size: 1.5rem;}
@media screen and (max-width: 640px){
.voice_title {font-size: 1.2rem; margin-top: 10px;}
.old { font-size: 17px;  padding: 1%;}
.voice_t {    font-size: 1.2rem;}
.v_txt { font-size: 1.1rem; padding: 10px;}
.container {  width: 100%;margin: 0 auto; padding: 1%;}
.sectxt{margin: 2% 5%;color: #000;font-size: 1rem;}
.mt30 {margin-top:10px;}
.mt50 {margin-top:30px;}
.mb30 {margin-bottom:10px;}
.mb50 {margin-bottom:30px;}
.pt20 {padding-top:20px;}
.pt30 {padding-top:10px;}
.pm20 {padding-bottom:5px;}
.pm30 {padding-bottom:10px;}
.pm50 {padding-bottom:50px;}
}
label.combtn  {
  position: absolute;
  z-index: 1;
  bottom: 9px;
  margin: 0 10px;
  width: 95%;
  height: 100px; /*グラデーションで隠す高さ*/
  cursor: pointer;
  text-align: center;
  background: linear-gradient(to bottom, rgba(250, 252, 252, 0) 0%, rgba(250, 252, 252, 0.95) 90%);
}
input:checked + label.combtn  {
  background: inherit; 
}
label.combtn:after {
  line-height: 2.5rem;
  position: absolute;
  z-index: 2;
  bottom: 20px;
  left: 50%;
  width: 200px;
  content: '続きをよむ';
  transform: translate(-50%, 0);
  color: #ffffff;
  border-radius: 20px;
  background-color:#866120;
}
input {
  display: none;
}
.text-wrapper {
  overflow: hidden;
  height: 600px;
  transition: all 0.5s;
  background: #fff;
  padding: 10px;
  border: 10px solid #e7d784;
}
/*今回消した部分*/
/* input:checked + label {
  display: none ;
} */
input:checked ~ .text-wrapper {
  height: auto;
  padding-bottom: 60px;
  transition: all 0.5s;
}


.wrapper_com{position: relative;margin: 0 auto;text-align: center;color: #000;}
.sec_com_space{
  position: relative;
  display: inline-grid;
  border: 0px solid #de9c08;
  margin: 2% 2%;
  padding: 10px 0 0 0;
  text-align: center;
  width: calc(100%/2.5);
}
.sec_com{
  position: relative;
  display: inline-grid;
  border: 1px solid #de9c08;
  background: #fff;
  margin: 2% 2%;
  padding: 10px 0 0 0;
  text-align: center;
  width: calc(100%/2.5);
}
.sec_com p{display: inline-block;}
.sec_com img{padding: 1%;float: right;}
.sec_com .stutxt{
  display: block;
  margin: 2% 5% 0;
  padding: 0% 5%;
  background: #f7f5e7;
  border-radius: 40px;
  color: #cc880d;
}
.sec_com .comtitle{
  display: block;
  text-align: left;
  margin: 0 auto;
  padding: 8% 3%;
  line-height: 26px;
  font-size: 18px;
}
.sec_com::before,
.sec_com::after {
  content: "";
  position: absolute;
  transform: rotate(-45deg);
  width: 70px;
  height: 25px;
  background-color: #fefefe00;
  z-index: 1;
}
.sec_com::before {
  top: -10px;
  left: -25px;
  border-bottom: 1px solid #131313;
}
/**osusume**/
.osusume {background-image: url(../images/bg_redikaku.png);background-size: cover;    background-repeat: no-repeat;}
/***end**/
.b_bg {background-image: url(../images/black_bg.png);background-size: cover;    background-repeat: no-repeat;}
.y_bg{background:#fffad0;}
/**profile**/
.koushi {
    max-width: 100%;
    background: #f6f6f6 url(../images/bg-hougan.svg);
    background-size: 14px;
}
.profile_bg {background-image: url(../images/pro_bg.png);}
.profile2_bg {
    background-image: url(../images/bg.png);
    background-size: cover;
}
.waku {
    width: 90%;margin: 0 auto;
    font-size: 21px;
}
.reason_bg{background:#f1eee2;}
.reason {    width: 90%;border: double 5px #987406;
    margin: 0 auto;
    margin-top: 40px;
    box-shadow: 0 0 20px rgb(0 0 0 / 10%);
    max-width: 800px;
    background: #fff;
}
.reason h3 {
        padding: 40px 80px 0px 80px;
}
.reason p {
    color: #000;
    padding: 1.5em;
        font-size: 1.4rem;
}
.d{    color: #000; padding: 1.5em;font-size: 1.2rem;}
.step {    width: 70%;    text-align: center;    padding: 20px 0;
    margin: 0 auto;
    margin-top: 40px;
    box-shadow: 0 0 20px rgb(0 0 0 / 10%);
    max-width: 800px;
    background: #fff;
}
.t_bg{
background: url(../images/reason_bg.png)repeat;
background-size: contain;
}
@media only screen and (max-width: 640px){
.reason p {  font-size: 1.2rem;  padding: 1em;}
.d { padding: 0.5em;font-size: 1.2rem;}
.text-wrapper {  height: 500px;border: 6px solid #e7d784;}
.step {  width: 90%;margin-top: 20px;}
.reason { width: 96%;  margin-top: 10px;}
.reason h3 { padding: 20px 10px 0px 10px;margin: 0 auto;}
/**.text-wrapper { height: 400px;}**/
label.combtn { width: 91%;bottom: 11px;  height: 122px;}
.waku {
    padding: 10px 10px ;
    width: 90% ;
    font-size: 1rem;
}}
/***end**/
a:link, a:visited, a:hover, a:active {text-decoration: none;}
.header_sec{position: relative;}

.sec06{background: #007cbd;padding-top: 0rem;}

.secbg_yp{background: url(../images/sec04_bg.png)repeat;background-size: 100%;}
.secbg_op{background: url(../images/sec01_bg.png);background-size: 100%;}

.secbg_wp {
  background-color: #ffffff;
  background-image:
   radial-gradient(#f1f1f1 4%, #f1f1f1 7%, transparent 7%),
   radial-gradient(#f1f1f1 4%, #f1f1f1 7%, transparent 7%),
   linear-gradient(#ffffff 5%,#ffffff 5%,
     transparent 15%, transparent 15%),
   linear-gradient(45deg, transparent 30%, transparent 49%,
     #f1f1f1 49%, #f1f1f1 50%,
     transparent 50%, transparent 100%),
   linear-gradient(-45deg, transparent 30%, transparent 49%,
     #f1f1f1 49%, #f1f1f1 50%,
     transparent 50%, transparent 100%);
  background-position: 50px 50px, 0px 0px, 0px 0px, 0px 0px, 0px 0px;
  background-size: 100px 100px,100px 100px,100% 4px,100px 100px,100px 100px;
}

.secbg_w{background:#fff;}
.secbg_g {background: #dceaea;}
.secbg_b{background:#007bbd;}
.secbg_lb{background: #d7edfc;}
.secbg_y{background:#fefbe1;}
.secbg_yo{background: #fff5c8;}
.secbg_ly{background: #fdfcf7;}
.secbg_main{background: #97d0d6;}

.heading_txt {position: relative;margin: -4rem auto 2rem;padding-top: 0px;padding-left: 30px;font-size: 36px;text-align: center;color: #000;}
.heading_arr {
  position: relative;
  padding-bottom: 70px;
  font-size: 50px;
  line-height: 70px;
  text-align: center;
}
.heading_arr::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 60px 36px 0 36px;
  border-color: #b99a00 rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0);
}

/*リンクの形状*/
#page-top a{
  display: flex;
  justify-content:center;
  align-items:center;
  background:#fff;
  border-radius: 5px;
  border: 1px solid #0458b5;
  width: 60px;
  height: 60px;
  color: #0458b5;
  text-align: center;
  text-transform: uppercase; 
  text-decoration: none;
  font-size:1.6rem;
  transition:all 0.3s;
  opacity: .5;
}
#page-top a:hover{background: #babee0;}
#page-top {position: fixed;right: 10px;z-index: 2;opacity: 0;transform: translateY(100px);}

/*　上に上がる動き　*/
#page-top.UpMove{animation: UpAnime 0.5s forwards;}
@keyframes UpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }
  to {
    opacity: 1;
  transform: translateY(0);
  }
}
/*　下に下がる動き　*/
#page-top.DownMove{animation: DownAnime 0.5s forwards;}
@keyframes DownAnime{
  from {
    opacity: 1;
  transform: translateY(0);
  }
  to {
    opacity: 1;
  transform: translateY(100px);
  }
}

.flex-box {display: flex;}

.noticebox{
    padding: 0 1em;
    background: #fff;
    color: #c9151e;
    font-weight: 900;
    text-align: center;
    font-size: 35px;
}
.noticebox p {
    margin: 0; 
    padding: 0;
    font-size: 52px;
    line-height: 65px;
    font-weight: 900;
}
.noticebox span.txt{
    font-size: 40px;
    line-height: 65px;
}
.noticebox p.line {
    border-bottom: 1px solid #fff;
    padding: 10px;
}
table.notice{
    background:#155c14;
    font-size: 30px;
    line-height: 180%;
    text-align: left;
    color: #000000;
    margin: 15px auto 20px;
    padding: 10px;
    border: 1px solid #ccc;
    width: 100%;
}
table.notice td{
    padding: 5px;
    width: 300px;
    text-align: center;
    background: #ffffff;
}
table.notice td{
    font-weight: 300;
    vertical-align: middle;
    color: #000;
}
table.notice td.red{
    color: #c9151e;
    font-weight: 800;
}
table.notice td.past{
    background: #84898d;
    color: #fef04b;
    font-weight: 900;
}
table.notice td.today{
    background: #c9151e;
    color: #fff;
}


ul.sec03 {
  background: white;
  padding: 0 0.5em;
  position: relative;
}
ul.sec03 li.check {
  line-height: 1.5;
  padding: 0.5em 0 0.5em 1.5em;
  border-bottom: 2px solid #b8c1c7;
  list-style-type: none!important;
}
ul.sec03 li.check:before {
  font-family: "Font Awesome 5 Free";
  content: "\f00c";/*アイコン種類*/
  font-weight: 900;
  position: absolute;
  left : 0.5em; /*左端からのアイコンまで*/
  color: #668ad8; /*アイコン色*/
}
ul.sec03 li.lightbull {
  line-height: 1.5;
  padding: 0.5em 0 0.5em 1.5em;
  border-bottom: 2px solid #b8c1c7;
  list-style-type: none!important;
}
ul.sec03 li.lightbull:before {
  font-family: "Font Awesome 5 Free";
  content: "\f0eb";/*アイコン種類*/
  font-weight: 900;
  position: absolute;
  left : 0.5em; /*左端からのアイコンまで*/
  color: #eaa652; /*アイコン色*/
}
/*ul.sec03 li:last-of-type {border-bottom: none;}*/

ol.sec08 {
  counter-reset:number; /*数字をリセット*/
  list-style-type: none!important; /*数字を一旦消す*/
  padding:0;
  margin: 1rem 10%;
}
ol.sec08 li {
  position: relative;
  padding: 0.5em;
  line-height: 1.5em;
  background: #f1f8ff;
  border-left : solid 50px #4675da;
  margin-bottom: 5px;
  color: #131313;
  font-size: 22px;
}
ol.sec08 li:before{
  /* 以下数字をつける */
  position: absolute;
  counter-increment: number;
  content: counter(number);
  /*数字のデザイン変える*/
  display:inline-block;
  color: white;
  font-family: 'Avenir','Arial Black','Arial',sans-serif;
  font-weight:bold;
  font-size: 25px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: -43px;
  width: 35px;
  height: 1em;
  line-height: 1;
  text-align: center;
}

.reflection-img{width:540px;height:145px;position:relative;overflow:hidden;display: block;margin: 0 auto;}
.reflection {
    height:100%;
    width:30px;
    position:absolute;
    top:-180px;
    left:0;
    background-color: #fef5c8;
    opacity:0;
    transform: rotate(45deg);
    animation: reflection 3s ease-in-out infinite;
    -webkit-transform: rotate(45deg);
    -webkit-animation: reflection 3s ease-in-out infinite;
    -moz-transform: rotate(45deg);
    -moz-animation: reflection 3s ease-in-out infinite;
    -ms-transform: rotate(45deg);
    -ms-animation: reflection 3s ease-in-out infinite;
    -o-transform: rotate(45deg);
    -o-animation: reflection 3s ease-in-out infinite;
}
 
@keyframes reflection {
    0% { transform: scale(0) rotate(45deg); opacity: 0; }
    80% { transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { transform: scale(4) rotate(45deg); opacity: 1; }
    100% { transform: scale(50) rotate(45deg); opacity: 0; }
}
@-webkit-keyframes reflection {
    0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-moz-keyframes reflection {
    0% { -moz-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -moz-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -moz-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -moz-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-ms-keyframes reflection {
    0% { -ms-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -ms-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -ms-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -ms-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-o-keyframes reflection {
    0% { -o-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -o-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -o-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -o-transform: scale(50) rotate(45deg); opacity: 0; }
}


.inner {
  max-width: 100%;
  overflow: hidden;
}

.ityped-cursor {
  font-size: 1em;
  opacity: 1;
  -webkit-animation: blink 0.3s infinite;
  -moz-animation: blink 0.3s infinite;
  animation: blink 0.3s infinite;
  animation-direction: alternate;
}

@keyframes blink {
  100% {
    opacity: 0;
  }
}

@-webkit-keyframes blink {
  100% {
    opacity: 0;
  }
}

@-moz-keyframes blink {
  100% {
    opacity: 0;
  }
}

.wrapper_com{position: relative;margin: 0 auto;text-align: center;color: #000;}
.sec_com_space{
  position: relative;
  display: inline-grid;
  border: 0px solid #de9c08;
  margin: 2% 2%;
  padding: 10px 0 0 0;
  text-align: center;
  width: calc(100%/2.5);
}
.sec_com{
  position: relative;
  display: inline-grid;
  border: 1px solid #de9c08;
  background: #fff;
  margin: 2% 2%;
  padding: 10px 0 0 0;
  text-align: center;
  width: calc(100%/2.5);
}
.sec_com p{display: inline-block;}
.sec_com img{padding: 1%;float: right;}
.sec_com .stutxt{
  display: block;
  margin: 2% 5% 0;
  padding: 0% 5%;
  background: #f7f5e7;
  border-radius: 40px;
  color: #cc880d;
}
.sec_com .comtitle{
  display: block;
  text-align: left;
  margin: 0 auto;
  padding: 8% 3%;
  line-height: 26px;
  font-size: 18px;
}
.sec_com::before,
.sec_com::after {
  content: "";
  position: absolute;
  transform: rotate(-45deg);
  width: 70px;
  height: 25px;
  background-color: #fefefe00;
  z-index: 1;
}
.sec_com::before {
  top: -10px;
  left: -25px;
  border-bottom: 1px solid #131313;
}
.chuui {
    background: rgb(51,51,51);
    background: radial-gradient(circle,rgba(51,51,51,1) 0%,rgba(51,51,51,1) 50%,rgba(0,0,0,1) 100%);
    max-width: 100%;
    padding-bottom: 0;
}
.movie { width:100%; padding-bottom: 56.25%; height:0px; margin: 0px auto; position: relative; }
.movie iframe{position: absolute; top: 0; left: 0; width: 100%; height: 100%;}

.com_menu {margin: 0 auto;text-align: center;}
.com_menu a {display: block;padding: 15px;text-decoration: none;color: #000;}
.com_menu label {
    width: 100%;
    display: block;
    margin: 0;
    padding : 0;
    line-height: 1;
    cursor :pointer;
    text-align:center;
}
.com_menu input {
    display: none;
}
.com_menu ul {
  width: 100%;
  margin: 0 auto;
  padding: 0 6%;
  font-size: 22px;
  color: #000;
  background: #fff;
  list-style: none;
  text-align: center;
  background: url(../images/sec04_bg.png);
  background-size: 100%;
}
.com_menu li {
    height: 0;
    overflow: hidden;
    -webkit-transition: all 0.8s;
    -moz-transition: all 0.8s;
    -ms-transition: all 0.8s;
    -o-transition: all 0.8s;
    transition: all 0.8s;
}
#change01:checked ~ #links01 li,
#change02:checked ~ #links02 li,
#change03:checked ~ #links03 li,
#change04:checked ~ #links04 li,
#change05:checked ~ #links05 li,
#change06:checked ~ #links06 li {
    height: auto;
    text-align: left;
    opacity: 1;
}


.hidden_box {
    margin: 0em 0;/*前後の余白*/
    padding: 0;
}
/*ボタン装飾*/
.hidden_box label {
    padding: 15px;
    font-weight: bold;
    cursor :pointer;
}
/*ボタンホバー時*/
.hidden_box label:hover {
    background: none;
}
/*チェックは見えなくする*/
.hidden_box input {
    display: none;
}
/*中身を非表示にしておく*/
.hidden_box .hidden_show {
    height: 0;
    padding: 10px;
    margin: -2px 54.7% 0 4.8%;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
    color: #000;
}
/*クリックで中身表示*/
.hidden_box input:checked ~ .hidden_show {
  padding: 10px;
  margin: -2px 54.7% 0 4.8%;
  height: auto;
  opacity: 1;
  text-align: left;
  border: 2px solid #f2ab00;
  border-radius: 0 0 20px 20px;
  background-color: #fff;
}

img {
  margin: 0;
  padding: 0;
  vertical-align: middle;
}
/**form**/
.relative {position: relative;}
.absolute {right: 12%; z-index: 999;width: 75%; ;position: absolute;}
.absolute2 {position: absolute;bottom: 7%; left: 12%;}
.form{    background-image: url(../images/form_pcbg.png) ;background-repeat: no-repeat;
    background-size: cover;text-align: center;    height: 587px;
}
.form p {color:#000;  text-align: center;}
.btn  a {animation: hop 2.4s infinite;}
.btn {
  margin: 0 auto;
  padding: 0;
  width: 100%;
animation: scalechange1 2.1s infinite;
    opacity: 1;
    transition: all 0.5s;
}
.form_txt{    padding: 18px 0 0px 0;}
@keyframes scalechange1 {
    0% {
        transform: scale(1);

        opacity: 1;
    }

    25% {
        transform: scale(1.03);
    }

    40% {
        transform: scale(.9);
    }

    50% {
        transform: scale(1.02);
    }

    60% {
        transform: scale(.93);
    }

    70% {
        transform: scale(1.01);

        opacity: 1;
    }

    80% {
        transform: scale(.95);
    }

    90% {
        transform: scale(1.01);
    }

    100% {
        transform: scale(1);
    }
}

@-webkit-keyframes scalechange1 {
    0% {
        transform: scale(1);

        opacity: 1;
    }

    25% {
        transform: scale(1.03);
    }

    40% {
        transform: scale(.9);
    }

    50% {
        transform: scale(1.02);
    }

    60% {
        transform: scale(.93);
    }

    70% {
        transform: scale(1.01);

        opacity: 1;
    }

    80% {
        transform: scale(.95);
    }

    90% {
        transform: scale(1.01);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes bound {
	0%, 100% { transform: translateY(0px); }
	10% { transform: translateY(-8px); }
	20% { transform: translateY(-10px); }
	30% { transform: translateY(-12px); }
	40% { transform: translateY(-14px); }
	50% { transform: translateY(-16px); }
	60% { transform: translateY(-14px); }
	70% { transform: translateY(-12px); }
	80% { transform: translateY(-10px); }
	90% { transform: translateY(-8px); }
}
@keyframes hop {
	0%, 40% { transform: skew(0deg,0deg) }
	5% { transform: skew(5deg,5deg) }
	10% { transform: skew(-4deg,-4deg) }
	15% { transform: skew(3deg,3deg) }
	20% { transform: skew(-2deg,-2deg) }
	25% { transform: skew(1deg,1deg) }
	30% { transform: skew(-0.6deg,-0.6deg) }
	35% { transform: skew(0.3deg,0.3deg) }
}
/**form end**/

@-webkit-keyframes shine {
  50% {
    left: 100%;
  }
  100% {
    left: 100%;
  }
}

@keyframes shine {
  50% {
    left: 100%;
  }
  100% {
    left: 100%;
  }
}


.youtube {
  position: relative;
  margin-top: 20px;
}

iframe {
  position: absolute;
  left: 5%;
  right: 5%;
  top: 0;
  display: block;
  text-align: center;
  margin: 0 auto;
  width: 91%;
  height: 93%;
}

.under{text-decoration: underline;}
.strong{font-weight: 900;}
.red{color: #e6240b;}
.blue{color: #155FCF;}
.green{color: #96dc28;}
.forpc { display: block;margin: 0 auto; }
.forsp { display: none; }

.marker_pink {background: linear-gradient(transparent 50%, #ffb3e4 50%);font-weight: bold;}
.marker_or {background: linear-gradient(transparent 50%, #ffd6b3 50%);font-weight: bold;}

.maru {font-family: 'M PLUS Rounded 1c', sans-serif;font-family: 'Kosugi Maru', sans-serif;}
.noto {font-family: 'Noto Sans JP', sans-serif;font-weight: 900;}
.sawa {font-family: 'Sawarabi Gothic', sans-serif;}
.kaisei {font-family: 'Kaisei Decol', serif;}
.shadow {box-shadow: 2px 2px 6px #666;}

.center{margin: 0 auto;text-align: center;}
.imgcenter{position: relative;margin: 0 auto;display: block;}
.imgright{float: right;position: relative;top: 0rem;padding: 5px;}

.linebtnSide {width: 150px; height: auto; position: fixed; right: 0; bottom:0px; z-index: 9999; }
.linebtnBottom {width: 100%; height: auto; position: fixed; bottom: 0; z-index: 9999;line-height: 0; }
.linebtnBottom img {width: 100%;}

/*  フッター
----------------------------------------------- */
footer {
  z-index:1000;
  position: relative;
  clear:both;
  font-size: 12px;
  color:#fefefe;
  padding: 5px 0 20px;
  text-align: center;
  background: #000;
  line-height: 30px;
  }

footer a {
  color:#fefefe;
  }

footer a:hover {
  color:#ffc55b;
  }

@media screen and (max-width: 780px) {
.form{    background-image: url(../images/form_bg.png) ;background-repeat: no-repeat;}
.form {  background-size: contain;  height: 350px;}
.form_txt {  padding: 5px 0 21px 0;}
.b_bg {  background-size: cover;}
.waku {  width: 100%;}
.absolute2 { bottom: 5%; left: 17%;}
.form p {  font-size: 12px;line-height: 1.2;}
  body {width: 100%;}
  main{width: 100%;}
  .flex {display: flex;flex-wrap: wrap;margin: 0;padding: 0 20px 0 20px;}
  .formbox {margin: 0 5px 0 5px;list-style: none;width: 37px;}
  .sec_com {margin: 2% auto;width: calc(95%/1);}
  .sec_com_space{display: none;}
  .sec03title {width: 100%;margin: 0% auto -10%;}
  .sec03txt{margin: 2% 3%;font-size: 1rem;padding: 1rem 3% 1rem;line-height: 28px;}
  ul.sec03 {margin: 0;}
  .reasonbox {display: block;width: calc(90%/1);margin: 1rem auto 2rem;padding: 1rem;height: auto;}
  .heading_txt {margin: -2rem auto 0rem;padding-left: 0px;font-size: 24px;}

  ul {padding: 0.5rem 1rem 0.5rem 2rem;}
  ul li:before {left: 0.5em;}
  .btn {width: 100%; padding: 0 0 6px;}
  .timetxt {font-size: 35px;}
  table.notice td{width: 100%;display: block;font-size: 24px;}
  .notice td.splaout{background: #fff;}

  .com_menu {max-width: 100%;}
  .com_menu label {width: 100%;padding: 0;}
  .com_menu ul {width: 100%;margin: 0;padding-top: 10px;font-size: 1.1rem;}
  .cp_table *, .cp_table *:before, .cp_table *:after {font-size: 20px;line-height: 30px;}
  .cp_table {width: 100%;margin: 0;}
  .cp_table tr {display: block;margin-bottom: 10px;}
  .cp_table th {display: block;width: 100%;}
  .cp_table td {
    display: list-item;
    list-style: none;
    width: 100%;
    margin-left: 0em;
    border: none;
    position: relative;
  }
  .cp_qa .cp_actab {width: 100%;margin: 1% 0%;}
  .cp_qa .cp_actab label{padding: 1em 1.25em 1em 2.5em;}
  .cp_qa .cp_actab label::after {font-size: 1.3em;line-height: 2.6em;}
  .cp_table02 {width: 100%;margin: 0;}
  .cp_table02 tr {display: block;margin-bottom: 10px;}
  .cp_table02 th {display: block;width: 100%;}
  .cp_table02 td {
    display: list-item;
    list-style: none;
    width: 100%;
    margin-left: 0em;
    border: none;
    position: relative;
  }
  .sec_graph {margin: 0 0% 3%;}
  .movie { width:100%; padding-bottom: 56.25%; height:0px; position: relative; }
  .movie iframe{position: absolute; top: 0; left: 0; width: 100%; height: 100%;}

  .p05{font-size: 8px;}
  .p06{font-size: 10px;}
  .p07{font-size: 12px;}
  .p08{font-size: 14px;}
  .p09{font-size: 16px;}
  .p10{font-size: 18px;}
  .p12{font-size: 20px;}
  .p14{font-size: 22px;}
  .p16{font-size: 24px;}
  .p20{font-size: 26px;}
  .p24{font-size: 27px;}
  .p30{font-size: 23px;}
  .p32{font-size: 29px;}
  .p36{font-size: 30px;}

  .btn_bg2 {
    height: 170px;
  }
  .q, .a {
    font-size: 16px;
    padding-left: 70px;
  }
  .q img, .a img {
    width: 40px;
    height: 40px;
  }
  .stretch {
    height: 12vw;
    transition: all 1s;
  }
  .direction {
    margin-top: -10vw;
  }
  footer {margin: 0;padding: 2% 0 3%;}
  .forpc { display: none; }
  .forsp { display: block;    margin: 0 auto;}
}


/* ポップアップウインドウの設定 */
.popup {
  background-color: #efefef;
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.8);
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 500px;
  height: 250px;
  z-index: 999;
  border: 2px #ffffff solid;
  font-size: large;
}
/* 閉じるアイコン（右上） */
.icon-close {
  color: #000;
  font-size: 40px;
  padding: 0 10px;
  position: absolute;
  top: 0%;
  right: 0;
}
/* いいえボタン */
label.btn-close {
  box-sizing: border-box;
  width: 30%;
  background: #8e8e8e;
  border-radius: 10px;
  color: #fff;
  padding: 10px;
  text-align: center;
  margin: 10px;
  display: block !important;
  min-width: 85px;
}
/* はいボタン */
a.btn-go {
  box-sizing: border-box;
  width: 30%;
  background: #00B900;
  border-radius: 10px;
  color: #fff;
  padding: 10px;
  text-align: center;
  margin: 10px;
  display: block !important;
  min-width: 85px;
  text-decoration: none;
}
a.btn-no {
  box-sizing: border-box;
  width: 30%;
  background: #CCC;
  border-radius: 10px;
  color: #fff;
  padding: 10px;
  text-align: center;
  margin: 10px;
  display: block !important;
  min-width: 85px;
  text-decoration: none;
}
.btn_box {
  display: inline-flex;
  justify-content: center;
  width: 100%;
  margin: auto;
}
/* ポップアップの内容 */
  .line_popup { width:50%; }
.popup-content {
  padding-left: 5%;
  padding-right: 5%;
  margin: 0 auto;
  color: #131313;
  line-height: 1.8rem;
  padding-top: 80px;
  width: 100%;
  height: 150px;
  text-align: center;
  display: inline-block;
  vertical-align: middle;
}
@media screen and (max-width: 900px) {
  /* ポップアップウインドウの設定 */
  .popup {
    /* display: none; */
    width: 70%;
    height: 250px;
  }
}
@media screen and (max-width: 600px) {
  .popup {
    /* display: none; */
    width: 90%;
    height: 250px;
  }
  .popup-content {
    padding-top: 20%;
    padding-bottom: 2%
    height:auto;
  }
  a.btn-go,
  label.btn-close {
    width: 50%;
  }
}
@media screen and (max-width: 320px) {
  /* ポップアップウインドウの設定 */
}