/* CSS Document */

@media screen and (max-width: 768px) {
html body {
	font-family: Yu Gothic , ‘游ゴシック’ , ‘Hiragino Kaku Gothic ProN’ , ‘ヒラギノ角ゴ ProN’ , Meiryo , メイリオ , sans-serif ;
	background:#FFF;
	background-image:none;
}
/*-----------------------------------------------------
レスポンシブ画像
------------------------------------------------------*/

  img {
    max-width: 100%;
    height: auto;
  }
  html body #wrapper .head {
    width: 100%;
    height: 0;
    padding-top: 71%;
    background: url("../images/sphead.png") no-repeat center top;
    -webkit-background-size: 100%;
    -o-background-size: 100%;
    background-size: 100%;
  }
  html body #wrapper .head2 {
    width: 100%;
    height: 0;
    padding-top: 74%;
    background: url("../images/sphead2.png") no-repeat center top;
    -webkit-background-size: 100%;
    -o-background-size: 100%;
    background-size: 100%;
  }
/*-----------------------------------------------------
ヘッダー
------------------------------------------------------*/

  html body #wrapper .headbg {
    width: 100%;
    height: 900px;
    background: url("../images/spbg.png")#1a2f64 no-repeat center top;
    background-size: cover;
  }
	
html body #wrapper .head_area{
	width: 100%;
}


html body #wrapper .head_text01{
	text-align: center;
	margin: 0 auto;
    width: auto;
	color: #fff;
	padding: 20px 0 0;
	float: none;
}

html body #wrapper .head_text02{
	text-align: center;
	margin: 0 auto;
    width: auto;
	color: #fff;
	padding:  0;
	float: none;
}
html body #wrapper .head_text02 p {
    text-align: center;
    color: #fff;
    font-size: 16px;
}
html body #wrapper .head_text03 {
    text-align: left;
    font-size: 12px;
    line-height: 18px;
	padding: 10px 20px;
}

html body #wrapper .head_line{
	border-top: 1px solid #ffffff;
	width: 85%;
	margin: 20px auto;
}
html body #wrapper .voice_lp{
	margin: 14px auto;
    width: 90%;
    display: block;
}
html body #wrapper .voice {
    margin: 20px auto ;
    border: solid 3px #e7e2e2;
    padding: 10px 0;
    width: 90%;
}

html body #wrapper .voice-text {
    margin: 0;
    font-size: 13px;
    line-height: 1.5;
	padding: 1% 3.125%;
}

html body #wrapper .copy01{
	font-size: 28px;
	font-weight: 900;
	font-family: Lato;
	padding: 0 0 40px;
	line-height: 34px;

}

html body #wrapper .copy02{
	font-size: 20px;
	font-weight: 900;
	font-family: Lato;
	padding: 0 0 10px;
	line-height: 28px;

}

html body #wrapper .copy03{
	font-size: 18px;
	font-weight: 600;
	font-family: Lato;
	padding: 0 0 10px;
	line-height: 24px;

}

html body #wrapper .head_text h1{
	font-size: 30px;
	font-weight: bold;
	padding: 0 0 24px;
	line-height: 34px;
}
html body #wrapper .head_text h2{
	font-size: 14px;
	font-weight: bold;
	padding: 4px 0;
}
html body #wrapper .head_text h3{
	font-size: 14px;
	font-weight: bold;
	padding: 12px 0;
}
html body #wrapper .head_text h4{
	font-size: 14px;
	font-weight: bold;
	padding: 10px 0 5px;
}
html body #wrapper .head_text p{
	font-size: 12px;
	line-height: 20px;
}
html body #wrapper .head_text .kakaku{
	padding: 10px 0;
	line-height: 48px;
}
html body #wrapper .head_text .kakaku-sale{
	font-size: 24px;
	font-weight: bold;
}
  html body #wrapper #mask,
  html body #wrapper #mask_in,
  html body #wrapper .main,
  html body #wrapper .main2,
  html body #wrapper #footer .content,
  html body #wrapper form.bottom,
  html body #wrapper form.bottom div .text,
  html body #wrapper iframe,
  html body #wrapper #tokuten {
    width: 100%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
	box-shadow: none;
  }

/*-----------------------------------------------------
youtube
------------------------------------------------------*/

  html body #wrapper .youtube {
    position: relative;
    width: 90%;
    height: 0;
    margin: 0 auto 16px;
    padding-top: 50%;
  }
  html body #wrapper .youtube iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
  }
.youtubebg {
  background: #fff;
    padding-bottom: 5px;
		width: auto;
	margin: 0 auto;
	padding: 10px 0 5px;
}


/*-----------------------------------------------------
main
------------------------------------------------------*/
.hajime {
    border: solid 1px #CCC;
	width: 90%;
    padding: 10px;
    font-size: 12px;
    line-height: 20px;
    margin: 10px auto;
}

  html body #wrapper .main .img1 {
    padding: 0 0 16px;
  }
  html body #wrapper .main .img2 {
    padding: 16px 0;
  }
html body #wrapper .sub-bg {
  padding: 5px 0;
  margin:  0px;
}
html body #wrapper .sub-bg-ar {
  padding: 5px 0;
  margin: 0px 0px 20px;
    background: #cb2a32;
    position: relative;
}
html body #wrapper .sub-bg-ar:before{
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-top: 20px solid #cb2a32;  /* 好みで色を変えてください */ 
    border-right: 20px solid transparent;
    border-left: 20px solid transparent;
}
html body #wrapper .sub-bgtop {
  padding: 5px 0;
  margin: 0px ;
}
html body #wrapper .sub {
  font-size: 24px;
  margin: 20px 0 ;
}
html body #wrapper .sub-bk {
  font-size: 24px;
  margin: 20px 0 ;
}
html body #wrapper .sub-bg2 {
  padding: 20px 0;
  margin:  0;
}

html body #wrapper .sub2 {
  font-size: 20px;
  margin: 20px 0 ;
}
	

html body #wrapper .bre {
    margin: 8px;
    padding: 0px 5px 5px 30px;
    font-size: 16px;
    line-height: 28px;
}
html body #wrapper .bre-text {
    margin: 0;
    padding: 5px 0 15px;
    font-size: 14px;
    line-height: 24px;
    font-feature-settings: "palt";
}
html body #wrapper .bre-main {
    margin: 0;
    padding: 10px 0 0 0;
    font-size: 22px;
    line-height: 28px;
    font-weight: bold;
    font-feature-settings: "palt";
}
html body #wrapper .bre-sub {
    margin: 0;
    padding: 5px;
    font-size: 18px;
    line-height: 24px;
    font-weight: bold;
    font-feature-settings: "palt";
}
html body #wrapper .bre2 {
    margin: 8px;
    padding: 10px 20px 10px 40px;
    font-size: 20px;
    line-height: 28px;
}
html body #wrapper li {
  position: relative;
  line-height: 1.4;
  margin: 10px 0 10px;
  font-size: 14px;
  font-weight: bold;
  padding: 0 0 10px 10px;
  border-bottom: solid 1px #CCC;
}
html body #wrapper li::after {
  content: '';
  display: block;
  position: absolute;
  top: .3em;
  left: -1.5em;
  width: 10px;
  height: 5px;
  border-left: 5px solid #d30f55;
  border-bottom: 5px solid #d30f55;
  transform: rotate(-45deg);
}

.che {
    margin: 0 auto 20px !important;
    width: 90%;
    margin-bottom: 2%;
    background: #FFF;
    padding: 0 0 10px;
    display: block;
	height: auto;
}
.che-sub {
    padding: 10px 0 0;
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    line-height: 38px;
    height: 80px;
    top: 0;
    bottom: 0;
    margin: auto;
}
.che-title {
    padding: 0 0 10px;
	width: 60%;
}
.che-text {
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
	padding: 0 20px 10px;
    font-feature-settings: "palt";
}
.che-img {
    padding: 10px 0 ;
    width: 90%;
}

html body #wrapper .recommend{
margin:0 auto;
width: 90%;
padding:10px 10px 5px 10px;

}

html body #wrapper .recommend-text {
  margin: 10px 4px ;
  padding: 10px 0;
  font-size: 14px;
  line-height: 24px;
  font-feature-settings: "palt";
}
html body #wrapper .recommend-sub {
    padding: 0;
    margin: 0;
    font-size: 1.2em;
    line-height: 1.3;
    font-weight: 800;
    margin: 0;
    color: #000;
    font-feature-settings: "palt";
    font-family: 'Noto Sans JP', sans-serif;
}
html body #wrapper .imgbox{
width:90px;
float:right;
margin:0 0 0 10px;
color:#666666;
}
html body #wrapper .recommend-prof {
    background: #DF5475;
    color: #fff;
    font-size: 1.0em;
    line-height: 1.3;
    border-radius: 100px;
    text-align: center;
    padding: 4px 8px;
    width: 130px;
    font-feature-settings: "palt";
    font-weight: bold;
    margin-top: 20px;
}
html body #wrapper .hr-reco{
 border-top: 1px solid #bbb;
 margin: 10px 0;
}

html body #wrapper .riyuu{
	width: 90%;
	margin: 10px auto;
	display: block;
}
	
html body #wrapper .merit{
	width: 90%;
	margin: 10px auto;
	display: block;
}


html body #wrapper .merit-sub{
	background: #83c9b1;
    color: #fff;
    max-width: 140px;
    margin: 0 auto;
    text-align: center;
    padding: 10px;
    font-size: 14px;
	font-weight: bold;
}
html body #wrapper .merit h1{
	font-size: 18px;
    text-align: center;
    margin: 10px auto 0;
    border-bottom: solid 1px;
    padding-bottom: 10px;
	width: 80%;

}

  html body #wrapper .main p {
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
	padding: 5% 3.125%;
  }
  html body #wrapper .main .big {
    font-size: 18px;
	  line-height: 30px;
  }
  html body #wrapper .main .big2 {
	font-size: 16px;
    line-height: 24px;
  }
  html body #wrapper .main .spRight {
    width: 40%;
  }
  html body #wrapper .main2 p {
    margin: 0;
    font-size: 14px;
    line-height: 1.4;
	padding: 5% 3.125%;
  }
html body #wrapper .head_text00{
	color: #fff;
	padding: 16px 0;
	background: #000;
	text-align: center;
	font-size: 14px;
	font-weight: bold;
}
	.right { width: 80px;}
	

.joken {
    width: 96%;
    margin: 0 auto 20px;
}

.joken_title {
    font-size: 18px;
    font-weight: 800;
    padding: 5px 5px;
    line-height: 24px;
    width: 70%;
}
.service {
    margin: 20px auto 40px;
	font-size: 12px;
	width: 96%;
}
.service-01 {
    padding: 5px 10px;
}
.spbn{display:block;}
.pcbn{display:none;}
.mousikomi{width: 90%; margin: 10px auto;}


html body #wrapper .attention-text {
    padding: 10px 0;
    font-size: 14px;
    line-height: 24px;
    font-feature-settings: "palt";
}
html body #wrapper .attention {
    background: #000;
    color: #fff;
    padding: 10px 20px;
    margin: 0 auto 10px;
	width: 86%;
}
html body #wrapper .con-bg {
  background: url("../images/bg_con.jpg") #fef7f4;
  background-position: center top;
  background-repeat: no-repeat;
  background-attachment: fixed;
  padding: 4px 0;
}

html body #wrapper .con h1 {
    background: #f29b76;
    color: #000;
	font-size: 18px;
    font-weight: bold;
    padding: 10px;
    margin: 10px;
    width: auto;
	line-height: 24px;
}

html body #wrapper .con {
margin: 10px ;
	
box-shadow:0px 0px 6px 3px #eee ;
-moz-box-shadow:0px 0px 6px 3px #eee ;
-webkit-box-shadow:0px 0px 6px 3px #eee ;
}

html body #wrapper .con-text {
  padding:10px;
  font-size: 20px;
  line-height: 34px;
  background-color:#FFF;
}
	
html body #wrapper .about-sub{
	color: #fff;
	font-size: 1.4em;
	font-weight: bold;
	text-align: center;
	padding: 40px 0 20px ;
}

html body #wrapper .section_movie {
    background-image: url(../images/bg_movie.jpg);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
    padding: 20px 0;
}
html body #wrapper .movie-text {
    margin: 20px auto 0;
    display: block;
	width: 90%;
}
html body #wrapper .step {
    padding: 10px 0 10px;
    background-color: #fff;
    box-shadow: 0 0 10px #c2d5d7;
    -webkit-box-shadow: 0 0 10px #c2d5d7;
}
html body #wrapper .step-text {
    margin: 20px 10px;
    padding: 10px 0;
    font-size: 14px;
    line-height: 1.6;
    font-feature-settings: "palt";
}
html body #wrapper .section01 {
	margin: 0 auto ;
}
html body #wrapper .section02 {
    padding: 20px;
}
html body #wrapper .section02-ar {
    padding-bottom: calc(10vw + 10px);
    position: relative;
    overflow: hidden;
    background: #f3f3f3;
    padding: 0 0 60px;
}
html body #wrapper .section03 {
	width: 92%;
    padding: 4% 4% 1% 4%;
	margin: 0 auto 10px;
}


html body #wrapper .section04 {

    padding: 10px 2%;
}
html body #wrapper .section04-ar {
    padding-bottom: calc(10vw + 10px);
    position: relative;
    overflow: hidden;
    background: #fbf9e4;
    padding: 20px 2% 40px;
}
html body #wrapper .section05 {
    background: url(../images/bg_section05.jpg)#f7f2e2;
    background-repeat: no-repeat;
    background-position: center top;
    background-size: contain;
    padding: 20px 0 5px;
}
html body #wrapper .section06 {
    background: #d6f7de;
    padding: 20px 0 10px;
}
html body #wrapper .section07 {
    background: #fbf9e4;
    padding: 20px 2% 0;
}

html body #wrapper .section08 {
    background: #f3f3f3;
    padding: 20px 2% 0;
}

html body #wrapper .section09-ar {
    padding-bottom: calc(10vw + 10px);
    position: relative;
    overflow: hidden;
    background: #fbf9e4;
    padding: 0px 2% 60px;
}
html body #wrapper .section09-ar::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    border-bottom: 10vw solid #c9dadd;
    border-left: 100vw solid transparent;
}
html body #wrapper .section09-ar::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    border-bottom: 10vw solid #c9dadd;
    border-right: 100vw solid transparent;
}

html body #wrapper .section10-ar {
    padding-bottom: calc(10vw + 10px);
    position: relative;
    overflow: hidden;
    background: #f3f3f3;
    padding: 0 2% 40px;
}

html body #wrapper .section11-ar {
    padding-bottom: calc(10vw + 10px);
    position: relative;
    overflow: hidden;
    background: #c9dadd;
    padding: 20px 2% 60px;
}

html body #wrapper .section12-ar {
    padding-bottom: calc(10vw + 10px);
    position: relative;
    overflow: hidden;
    background: #fff;
    padding: 0 0 60px;
}
html body #wrapper .section12-ar::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    border-bottom: 10vw solid #fbf9e4;
    border-left: 100vw solid transparent;
}
html body #wrapper .section12-ar::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    border-bottom: 10vw solid #fbf9e4;
    border-right: 100vw solid transparent;
}
html body #wrapper .section_prof{
	color: #fff;
	padding: 20px 10px;
}
html body #wrapper .section_prof2{
	color: #fff;
	padding: 20px 10px;
}
html body #wrapper .prof {
    width: 100%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
	box-shadow: none;
  }
.prof02 {
    margin: 0 ;
}
	
.prof02txt{
    padding: 10px 15px;
    background-color: rgba(0,0,0,0.40);
    font-size: 12px;
    line-height: 18px;
	margin-left: 0;
}
.info{
margin: 0 2% 40px;
padding:1% 1% 1% 1%;
border:solid 1px #999999;
background-image: url("../images/ftitle.png") ;
background-size: 100%;
background-position:top center;
background-repeat:no-repeat;
}

table.outline{
width:100%;
border-collapse:separate;
margin:0 auto;
}
table.outline td{
font-size:12px;
line-height:150%;
border-bottom:dotted 1px #999999;
padding:2% ;
}
table.outline td.item{
font-weight:bold;
background-color:#F6F6F6;
border-bottom:solid 1px #999999;
text-align:center;
width:30%;
height: auto;
}
table.outline td.day{
font-weight:bold;
background-color:#666;
border-top:none;
border-bottom:none;
text-align:center;
vertical-align: middle;
color: #fff;
font-size: 110%;
}
.h-right {
    margin: 5px 0 5px 5px;
    float: right;
    clear: both;
    width: 120px;
}
.text_nittei {
    text-align: center;
    margin-top: 10px;
    font-size: 10px;
	width: 80%;
	line-height: 16px;
	margin: 0 auto;
	display: block;
}
html body #wrapper .btarea{
	margin: 0 auto;
	text-align: center;
	padding: 0 0 20px;
}
html body #wrapper .btarea p{
	font-size: 70%;
}
html body #wrapper .btarea img{
	width: 80%;
}
html body #wrapper .bt {
	margin: 20px 0;
}
html body #wrapper .section_qa{
    background:#f3f3f3;
	padding: 20px 2% 0px;
}


html body #wrapper .cp_qa {
    margin: 20px 10px;
}
html body #wrapper .cp_qa .cp_actab label {
    font-weight: bold;
    line-height: 1.6;
    position: relative;
    display: block;
    margin: 0 0 0 0;
    padding: 1em 2em 1em 1em;
    cursor: pointer;
    background: #f5f5f5;
    font-size: 12px;
}
html body #wrapper .cp_qa .cp_actab input:checked ~ .cp_actab-content p {
    font-size: 12px !important;
    line-height: 20px !important;
    padding: 0;
}
html body #time {
	text-align: center;
	font-size: 18px;
	line-height: 28px;
	font-weight: bold;
	padding: 10px 0px;
	background: #000;
	color: #ffff00;
}
html body #wrapper .contents {
    padding: 0 0 10px;
    margin-bottom: 20px;
}
html body #wrapper .contents-sub {
    padding: 0;
    color: #fff;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    line-height: 30px;
}
html body #wrapper .contents p{
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
	padding: 5% 3.125%;
}
html body #wrapper .mondai {
	margin: 20px auto;
    padding: 0 0 10px;
    margin-bottom: 10px;
	width: 94%;
}
html body #wrapper .mondai-sub {
    padding: 20px 10px;
    color: #fff;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    line-height: 30px;
}
html body #wrapper .mondai p{
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
	padding: 5% 3.125%;
}
html body #wrapper .tokutyou {
	margin: 20px auto;
    padding: 0 ;
    margin-bottom: 10px;
	width: 94%;
}
html body #wrapper .tokutyou-sub {
    padding: 20px 10px;
    color: #fff;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    line-height: 30px;
}
html body #wrapper .tokutyou p{
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
	padding: 5% 3.125%;
}
.box01 {
	margin: 0 10px 10px;
	padding:  0;
    background: #f1f1f1;
}
.box {
	margin: 0 10px;
	padding: 5px 0;
    background: #f1f1f1;
}
.pcbn{display:none;}	
.spbn{display:block;}	

.flexbox {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    justify-content: space-evenly;
    font-feature-settings: "palt";
	align-items: center;
}

.img-70{width: 70%;}

html body #wrapper .img-space {
    margin: 40px 0 0;
}
html body #wrapper .img-space2 {
    margin: 20px 0 0;
}

html body #wrapper .kakaku-space {
    margin: 20px 0 ;
}

html body #wrapper .space-top {
    margin-top: 20px;
}
table {
width: 320px;
margin-bottom: 15px;
overflow-y: hidden;
overflow-x: scroll;
-ms-overflow-style: -ms-autohiding-scrollbar;
-webkit-overflow-scrolling: touch;
}
th, td {
font-size: 14px;
line-height: 20px;
padding: 14px;
}
.kanso{
margin: 0 20px 40px;
}
.faceicon img {
    width: 90px;
    height: auto;
}
.balloon_l, .balloon_r {
    margin: 15px 0;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    /* align-items: center; */
}
.says {
    max-width: 500px;
    flex-wrap: wrap;
    position: relative;
    padding: 17px 13px 15px 18px;
    border-radius: 12px;
    background: #cbf7ae;
    box-sizing: border-box;
    margin: 0 !important;
    line-height: 1.5;
    /* align-items: center; */
    font-size: 14px;
}


html body #wrapper .qa-container {
  margin: 20px auto 0;
  width: 100%;
}

html body #wrapper .qa-list{
background: #fff;
padding: 0 0 5px;
margin: 20px 0;
}

html body #wrapper .qa-list:not(:first-child) {
  margin-top: 10px;
}

html body #wrapper .question-title {
  background: #fff;
  cursor: pointer;
  font-size: 14px;
  padding: 10px 40px;
  position: relative;
  line-height: 24px;
  font-weight: bold;
}

html body #wrapper .question-title:before {
  position: absolute;
  display: block;
  content: 'Q';
  top: 9px;
  left: 12px;
  color: #6cb8c4;
  font-size: 20px;
  font-weight: bold;
  font-feature-settings: "palt";
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}

html body #wrapper .question-title:after {
  position: absolute;
  display: block;
  content: '';
  top: 45%;
  right: 22px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: rotate(135deg);
  transition: all .3s ease-in-out;
}

html body #wrapper .question-title.open:after {
  transform: rotate(-45deg);
  top: 45%;
}

html body #wrapper .answer-text {
  display: none;
	padding: 20px 10px 20px 40px;
    position: relative;
    background: #f3f3f3;
    font-size: 14px;
    margin: 0 10px 10px;
	line-height: 24px;
}

html body #wrapper .answer-text:before {
  position: absolute;
  display: block;
  content: 'A';
  top: 20px;
  left: 15px;
  color: #c92c37;
  font-size: 18px;
  font-weight: bold;
  font-feature-settings: "palt";
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}
html body .small2 {
  font-size:80%;
}
#close_button {
    position: absolute;
    top: 0;
    right: 0;
	display: block;
}

#line_banner img {
    height: auto;
    width: 100%;
	display: block;
}
/*-----------------------------------------------------
footer
------------------------------------------------------*/

  #footer{
    margin-bottom: -20px !important;
    padding-bottom: 20px;
  }
}

