/* 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: 146%;
    background: url("../images/sphead.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 .head2{
	margin: 0 auto;
    max-width: 100%;
	position: absolute;
	top:630px;
}
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_book{
    width: 80%;
	float: none;
	min-height: 400px;
	/*padding: 0 20%;
	text-align: center;
    top: 230px;
	right: 0;
    position: absolute;*/
	margin: 0 auto;
    background: url(../images/book.png) no-repeat;
	background-position: center top;
	background-size: contain;
}
html body #wrapper .head_book img{
	width: 100%;
}
html body #wrapper .head_line{
	border-top: 1px solid #ffffff;
	width: 85%;
	margin: 20px auto;
}
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 #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
------------------------------------------------------*/

   html body #wrapper .main01 {
    width: 100%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
	box-shadow: none !important;
  } 

  html body #wrapper .main02 .sp_wrap {
    width: 93.75%;
    margin: auto;
  }
  html body #wrapper .main02 #tokuten {
    width: 93.75%;
    margin: 15px auto;
  }
  html body #wrapper .main02 #tokuten .text {
    padding: 15px 3.125%;
  }
  html body #wrapper .main .img1 {
    padding: 0 0 16px;
  }
  html body #wrapper .main .img2 {
    padding: 16px 0;
  }
html body #wrapper .sub-bg {
  padding: 20px 0;
  margin:  0;
}

html body #wrapper .sub {
  font-size: 20px;
}

html body #wrapper .sub-bg2 {
  padding: 20px 0;
  margin:  0;
}

html body #wrapper .sub2 {
  text-align: left;
  padding: 0 ;
  margin: 0;

}
	
html body #wrapper .bre {
    background: #eef28a;
    color: #000;
    font-size: 16px;
    font-weight: bold;
    padding: 10px;
    margin: 10px;
    width: auto;
}

html body #wrapper .riyuu h1 {
background: #e1f7ef;
padding: 10px 0 ;
margin: 0 0 0 20px;
font-size: 18px;
}

html body #wrapper .riyuu{
	margin:  10px;
	
}
html body #wrapper .riyuu-num {
line-height: 40px;
padding: 0.2em;
color: white;
background: #83c9b1;
font-size: 12px;
font-weight: bold;
width: 40px;
text-align: center;
height: 40px;
line-height: 40px;
float: left;
-moz-transform: translateY(-50%);
-webkit-transform: translateY(-50%);
-ms-transform: translateY(-50%);
transform: translateY(-50%);
border-radius: 50%;
margin: 17px 10px -10px;
clear: both;
}
	
html body #wrapper .merit{
	margin: 20px 12px ;
}
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.4;
	padding: 5% 3.125%;
  }
  html body #wrapper .main .big {
    font-size: 16px;
  }
  html body #wrapper .main .big2 {
    font-size: 24px;
	  line-height: 32px;
  }
  html body #wrapper .main .spRight {
    width: 40%;
  }
	
html body #wrapper .head_text00{
	color: #fff;
	padding: 16px 0;
	background: #000;
	text-align: center;
	font-size: 14px;
	font-weight: bold;
}
	.right { width: 120px;}
	
html body #wrapper .bt{
    padding: 10px 5px;
    font-size: 14px;
    text-align: center;
    color: #fff;
	background-color:#000436;

}
html body #wrapper .bt_text {
    padding:  10px;
    color: #fff;
    max-width: 80%;
    border: dotted #fff 1px;
    font-size: 10px;
    line-height: 24px;
    margin: 5px auto;
}
html body #wrapper .bt a:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}

html body #wrapper .bt2{
    font-size: 18px;
    text-align: center;
    color: #fff;
    width: 80%;
    margin: 10px auto 20px;
}

html body #wrapper .bt_area {
    padding: 20px 0 ;
}

html body #wrapper .bt_area2 {
    margin: 20px auto;
    text-align: center;
    background: url(../images/bg.png)#1a2f64 no-repeat;
    padding: 30px 0;
}
.book {
    width: 96%;
    margin: 0 auto;
}
.book_no {
    background: rgb(55,70,90);
    font-size: 14px;
    font-weight: 900;
    font-family: Lato;
    vertical-align: middle;
    line-height: 24px;
    color: #ffffff;
    width: 30%;
    text-align: center;
	padding: 5px 0;
}

.book_title {
    background: rgb(240,243,245);
    font-size: 16px;
    font-weight: 900;
    font-family: Lato;
    padding: 5px 10px;
    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 .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 ;
}



  .info {
    margin: 4% 2%;
    padding: 1% 1% 1% 1%;
    border: solid 1px #999999;
    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: 10px;
    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: 50%;
    height: auto;
  }
  table.outline td.item2 {
    font-weight: bold;
    width: 50%;
    height: auto;
  }
.k-right {
    margin: 5px 0 5px 5px;
    float: right;
    clear: both;
    width: 120px;
}
html body #wrapper .btarea{
	margin: 20px auto;
	text-align: center;
	width: 80%;
}
html body #wrapper .btarea p{
	font-size: 70%;
}
.cp_qa {
    margin: 20px 10px;
}
.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;
}
.cp_qa .cp_actab input:checked ~ .cp_actab-content p {
    font-size: 12px !important;
    line-height: 20px !important;
    padding: 0;
}
/*-----------------------------------------------------
footer
------------------------------------------------------*/

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

