@charset "utf-8";

/***************************************************
PC用および共通設定 974px～
***************************************************/
#container {
  position: relative;
}

main {
  position: relative;
}

.main_image{
	background-size:cover;
	height:600px;
}
.main_image.setView1{
	background:url("../images/main01_pc.jpg") center top;
}
.main_image.setView2{
	background:url("../images/main02_pc.jpg") center top;
}
.main_image.setView3{
	background:url("../images/main03_pc.jpg") center top;
}
h2{
	font-weight:bold;
	margin-bottom:8% !important;
	color:#000;
	font-size:120%;
}
.wrapper{
	width:800px;
	margin:auto;
}
.box{
	width:100%;
	padding:8% 0;
}

#fixed_menu {
  width: 100%;
  z-index: 100000;
}

/*メニュー*/
.bg_menu{
	background:#FFF;
	padding:0;
	margin:0;
	z-index: 10000;
	position:relative;
	width:100%;
	text-align:center;
	height:4rem;
	box-shadow: 1px 1px 1px 1px rgb(0 0 0 / 10%);
}

#menu{
	width:1000px;
	margin:0 auto 0;
	height:4rem;

}
#menu ul{
	display:flex;
	justify-content: space-between;
	padding:0;
}

#menu ul li a{
	width:100%;
	display:inline-block;
	padding:1.5rem 0rem;
	font-weight:bold;
	position:relative;
	transition: all 0.5s ease-out;
	vertical-align:middle;

}
#menu ul li a:hover,#menu ul li.on a{
	color:#FF1493;
}
#menu ul li img{
	width:2rem;
}
#menu ul li:last-child a{
	padding:1rem 0;
}
#menu ul li{
	width:14%;
	text-align:center;
}
#menu ul li:last-child{
	margin-right:0;
}


.fixed {
    position: fixed;
    top: 0;
    width: 100%;
}

.fixed_menu_filler {
  position: relative;
  margin: 0;
  padding: 0;
  height: 0;
}

/*News*/
#box_news ul li{
	margin-bottom:1rem;
}
#box_news ul li p{
	text-align:left;
	line-height:2.0;

}
#box_news ul li p.date{
	font-size:90%;
}
.more_news{
	text-align:right;
}
.more_news a,#box_news li a{
	transition: all 0.5s ease-out;
	text-decoration:underline;
}
.more_news a:hover,#box_news li a:hover{
	color:#FF1493;
}
/*Twitter*/
#wrp_twitter{
	width:1060px;
}
#box_twitter{
	position:relative;
}
.inner_twitter{
	width:770px;
	margin:auto;
	padding:3%;
	background:#CCC;
/*	border:1px solid #ccc;*/
	position:relative;
}
.bottom_twitter{
	position:absolute;
	bottom:0;
	
}
.bottom_twitter img{
	width:100%;
}

/*Profile*/
.img_profile{
	width:30%;
	margin:5% auto;
	border:1px solid #CCC;
	padding:3% 0;
}
.img_profile img{
	width:100%;
}
#box_profile p{
	text-align:left;
	margin-bottom:1rem;
	line-height:2.0;
}
/*Books*/

#box_books ul {
	display:flex;
	flex-wrap:wrap;
    -webkit-justify-content: center;
    justify-content: center;

}
#box_books ul li{
	width:40%;
	margin:10% 5%;
	position:relative;
	cursor:pointer;

}
#box_books ul li img{
	width:100%;
}
#box_books ul li .txt_book{
	background:#FF1493;
	opacity:0;
	position:absolute;
	width:100%;
	height:100%;
	padding-top:0;
	color:#FFF;
	text-align:center;
	transition: all 0.5s ease-out;

}
#box_books ul li .txt_book p{
	text-align:center;
	top:40%;
	left:0;
	color:#FFF;
	display:inline-block;
	transition: all 0.5s ease-out;
	position:absolute;
	line-height:2.0;
	width:100%;

}

#footer{
	padding:2% 0;
}
#box_books ul li:hover .txt_book{
	opacity:1;
}
#box_books ul li:hover .txt_book p{
	color:#FFF;
	display:inline-block;
	transform:translateY(1rem);
}
/*Contact*/
#box_contact .tr{
	display:flex;
	border-bottom: 1px dashed #999;
}
#box_contact .tr:last-child{
	border-bottom:none;
}

#box_contact .tr .td span{
	vertical-align:middle;
	display:inline-block;
}
#box_contact .tr .td:first-child{
	width:28%;
   	padding: 0.2rem 0.5rem;
	margin:3% 2% 3% 0;
	text-align:left;
}
#box_contact .tr .td:last-child{
	width:70%;
	margin:3% 0 3% 0;
}
#box_contact input{
    font-family: inherit;
    border: 1px solid #999;
    border-radius: 8px;
    vertical-align: middle;
    padding: 0.2rem 0.5rem;
    height: 2rem;
    background-color: #FFF;
	width:90%;
}
#box_contact textarea {
    font-family: inherit;
    font-size: 100%;
	width:90%;
    border: 1px solid #999;
    padding: 0.2rem 0.5rem;
    border-radius: 8px;
}
#box_contact span.mandetory{
	color:#fff;
	background:#FF1493;
	padding:0.5rem 0.7rem;
	margin-right:0.8rem;
	font-size:90%;
}
#btn_contact{
	border: 1px solid #555;
	border-radius: 8px;
	padding:0.8rem 0.5rem;
	width:30%;
	margin:5% auto;
	display:block;
	cursor:pointer;
	transition: all 0.5s ease-out;

}
#btn_contact:hover{
	color:#fff;
	background:#FF1493;
	border: 1px solid #FF1493;

}
.reCaptcha{
	text-align:center;
}
.reCaptcha div{
	margin:5% auto;
}

@media only screen and (max-width: 1100px){
/*twitter*/
#wrp_twitter{
	width:100%;
}
}

/***************************************************
タブレット用 768px～973px
***************************************************/

@media only screen and (max-width: 973px){

.wrapper{
	width:100%;
	margin:auto;
}
.box{
	width:94%;
	margin:auto;
	padding:8% 0;
}

/*menu*/

.fixed_menu{
	height:100%;
}
.bg_menu{
	height:100%;
}
#menu{
	width:100%;
	height:100%;
}
#menu ul li {
	text-align:center;
}

/*Twitter*/

.inner_twitter{
	width:640px;
}

/*Book*/
#box_books ul li:hover .txt_book{
	opacity:0;
}
#box_books ul li:hover .txt_book p{
	color:#FFF;
	display:none;}

}
/***************************************************
スマートフォン用 ～767px
***************************************************/
@media only screen and (max-width: 767px){



main{
	padding-top:4rem;
}
.box{
	padding:6rem 0 1rem 0;
}
/*KV*/
.main_image{
	height:0;
	width:100%;
	padding-top:133%;
}
.main_image.setView1{
	background:url("../images/main01_sp.jpg") center top;
	background-size:contain;

}
.main_image.setView2{
	background:url("../images/main02_sp.jpg") center top;
	background-size:contain;
}
.main_image.setView3{
	background:url("../images/main03_sp.jpg") center top;
	background-size:contain;
}

.main_image{
	height:100%;
}

.main_image img{
	width:100%;
}
/*メニュー*/
	
#global_menu_sp{
	position:fixed;
	top:0;
	left:0;
	width:100%;
	z-index:100000;
}
#menu_logo_sp{
	display:flex;
	background:#fff;
	height:4rem;
	-webkit-justify-content: flex-end;
	justify-content: flex-end;
	-webkit-align-items: flex-end;
	align-items: flex-end;
	box-shadow: 1px 1px 1px 1px rgb(0 0 0 / 10%);

}
#menu_logo_sp div{
	width:2rem;
	padding:1rem;
	height:2rem;
}

#menu_pulldown{
	cursor:pointer;
}
#menu_logo_sp div img{
	width:100%;
}
.menu_sp{
	background:#FFF;
	padding-bottom:3rem;
	box-shadow: 1px 1px 1px 1px rgb(0 0 0 / 10%);

}
.menu_sp li{
	display:block;
	position:relative;
}
.menu_sp li a{
	padding:2rem 0;
	display:block;
}

.menu_sp li span{
	font-size:120%;
	font-weight:bold;
	position:relative;

}
.menu_sp li:after{
	display:inline-block;
	position:absolute;
	content:'';
	bottom:0px; /*下線の上下の位置*/
	left: 50%;
	width: 30px; /*下線の幅*/
	height: 2px; /*下線の太さ*/
	-moz-transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translate(-50%); /*位置の調整*/
	background-color: #ccc; /*下線の色*/
}




/*menu*/

.fixed_menu{
	display:none;
}
.bg_menu{
	display:none;
}
/*Twitter*/
#box_twitter{
	width:98%;
}
.inner_twitter{
	width:86%;
}
.bottom_twitter {
    position: absolute;
    bottom: -4%;
}

/*Books*/
#box_books ul {
	display:block;

}
#box_books ul li{
	width:60%;
	margin:15% auto;
}
#box_books ul li .txt_book p{
	font-size:90%;
	padding:0 3%;
	width:94%;
}
/*Contact*/
#box_contact .tr{
	display:block;
}
#box_contact .tr .td:first-child{
	width:100%;
    padding: 0.2rem 0.5rem;

	margin:3% 0 3% 0;
	text-align:left;
}
#box_contact .tr .td:last-child{
	width:100%;
	margin:3% 0 5% 0;
}
#box_contact span.mandetory{

	margin-right:0.2rem;
	font-size:90%;
}
#btn_contact{
    margin: 10% auto;
	width:70%;
}
}
