@charset "UTF-8";

* {
	margin:0px 0px 0px 0px;
	padding:0px 0px 0px 0px;
}

body{
	width: 100%;
	margin: 0;
	padding: 0;
	color: #000;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 15px;
	line-height:150%;
	text-align: left;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

html{     height:100%; }
body{     height:100%; } 

textarea,input {
	padding:2px;
}

img {
	border: 0;
	border-style: none;
	vertical-align: bottom;
}

ul {
	list-style-type: none;
	padding:0;
	margin:0;
}

li {
	list-style-position: outside;
     	line-height:150%;
}

form {
	margin:0;
	padding:0;
}

div{
	display:block;
}

object,
embed {
	vertical-align: top;
}

a img.fade {
	-webkit-transition: opacity 0.3s ease-out;
-moz-transition: opacity 0.3s ease-out;
-ms-transition: opacity 0.3s ease-out;
transition: opacity 0.3s ease-out;
}
a:hover img.fade{
  opacity:0.5;
  filter: alpha(opacity=50);
}


a:link ,
a:visited { 
	color:#333;
	text-decoration: underline;
}

a:active ,
a:hover {
	color:#333;
	text-decoration: none;	
}

div#wrap {
	width:100%;
	margin: 0 auto;
	text-align:center;
	padding:0;
	zoom: 1;
}
body > div#wrap{     height:auto;
	overflow-y: hidden; }





/* PC */
.spOnly {
		display: none;
}
div#wrap {
	padding-top: 0;
}


/* header 
---------------------------------------------------------*/
#header{
	margin: 0 auto;
	width: 100%;
	background-color: #FFF;
}
#header .inner{
	margin: 0 auto;
	width: 962px;
	height: 116px;
}
#header .inner h1{
	float: left;
	width: 163px;
	padding-top: 20px;
	margin-left: 35px;
}
#header .inner h1 img{
	width: 100%;
	height: auto;
	}
#header .inner .serch{
	float: right;
	margin: 60px auto 0;
	width: 162px;
	height: 28px;
	border: 2px solid #dadada;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}
#header .inner .serch input{
	float: left;
	padding: 2px 5px;
	width: 124px;
	height: 20px;
	border-style: none;
}
#header .inner .serch button{
	float: right;
	margin: 3px 2px 0 0;
	width: 18px;
	border: 0;
	border-style: none;
	background-color: #FFF;
}
#header .inner .serch img{
	width: 14px;
	height: auto;
	}






/* ナビゲーション
--------------------------------------------*/
nav{
	margin: 0 auto 20px;
	width: 962px;
	padding: 0;
	z-index: 1000;
}
nav #gNavi{
	margin: 0 auto;
	width: 100%;
	padding: 0;
	position: relative;
	z-index: 1000;
}
nav #gNavi ul{
	list-style-type: none;
	width: 100%;
	border-top: 1px solid #b5b6b6;
	border-bottom: 1px solid #b5b6b6;
}
nav #gNavi ul:last-child{
	border-top: none;
}
nav #gNavi li a{
	float: left;
	width: 25%;
	padding: 14px 0 12px;
	font-size: 16px;
	line-height: 100%;
	color: #999;
	text-align: center;
	text-decoration: none;
	display: block;
	border-left: 1px solid #b5b6b6;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	transition: .3s;
}
nav #gNavi li:last-child a{
	border-right: 1px solid #b5b6b6;
}
nav #gNavi li a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #999;
}


/* スライド 
---------------------------------------------------------*/
#topslide{
	margin: 0 auto 38px;
	width: 962px;
	height: 300px;
	position: relative;
	border: 1px solid #ccc;
}
ul.slide{
	width: 962px;
	height: 300px;
	margin: 0;
	padding: 0;
	overflow: hidden;
}
ul.slide li{
	margin: 0 31px 0 0;
	padding: 0px;
	height: 300px;
	border: 1px solid #777;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
ul.slide li img{
	width: 100%;
	height: auto;
	z-index: 9;
}

ul.slide li div{
	width: 31px;
	height: 76px;
	position: absolute;
	top: 0;
	left: 5%;
	z-index: 10;
}
ul.slide li div img{
	width: 100%;
	height: auto;
}
ul.slide li a{
	display: block;
	transition: .3s;
}
ul.slide li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
}

#arrows{
	width: 100%;
	margin: auto;
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	z-index: 100;
}
#arrows .slick-prev, #arrows .slick-next {
	width: 40px;
	height: 50px;
	transition: .3s;
	position: absolute;
}
#arrows .slick-prev:hover, #arrows .slick-next:hover{
  opacity:0.5;
  filter: alpha(opacity=50);
}
#arrows .slick-prev:before, #arrows .slick-next:before {
    content:"";
}
#arrows button.slick-prev, #arrows button.slick-next {
    z-index:2;
}
#arrows .slick-prev{
	left:0;
	top: 0;
}
#arrows .slick-next{
	right:0;
	top: 0;
}
#arrows .slick-prev img,
#arrows .slick-next img{
	width: 40px;
	height: 50px;
}
#arrows .slick-arrow{z-index:10;}


#topslide .ban{
	width: 960px;
	height: auto;
	margin: 0;
	padding: 0;
}

.contents{
	margin: 0 auto;
	padding: 0;
	width: 962px;
	min-height: 500px;
}


/* トップ 
---------------------------------------------------------*/
.main{
	float: left;
	padding: 0 0 15px 0;
	width: 630px;
	text-align: left;
}
.main section{
	padding: 0 0 5px 0;
}
.main section p{
	margin: 0;
	padding: 0 0 15px 0;
}
.main .title{
	margin: 0 0 20px;
	padding: 5px;
	width: calc(100% - 10px);
	border: 1px solid #b5b6b6;
	text-align: left;
}
.main .title p{
	padding: 7px 15px 3px;
	width: calc(100% - 30px);
	height: auto;
	border-left: 10px solid #e60012;
	font-size: 20px;
	line-height: 100%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box{
	margin: 0 0 18px;
	padding: 17px;
	width: calc(100% - 34px);
	border: 1px solid #b5b6b6;
	position: relative;
}
.main .box .left{
	float: left;
	width: 265px;
	text-align: center;
}
.main .box .left img{
	width: 100%;
	height: auto;
}
.main .box .left .book{
	margin: 0 auto;
	width: auto;
	border: 1px solid #949494;
	display: inline-block;
}
.main .box .left .book img{
	width: auto;
	height: 292px;
}
.main .box .right{
	float: right;
	width: 280px;
}
.main .box .right .rightTitle{
	padding: 0;
	font-size: 20px;
	line-height: 120%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box .right .rightTitle span{
	font-size: 15px;
}
.main .box .right p{
	margin: 0;
	padding: 15px 0 0;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .box .bt a{
	padding: 5px;
	font-size: 12px;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: absolute;
	right: 17px;
	bottom: 17px;
	transition: .3s;
}
.main .box .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}

.main ul.list2{
	margin: 0;
	padding: 0;
}
.main ul.list2 li{
	float: left;
	margin: 0 26px 16px 0;
	width: 302px;
}
.main ul.list2 li:nth-child(2n){
	margin: 0 0 16px 0;
}
.main ul.list2 li a{
	display: block;
	text-decoration: none;	
	transition: .3s;
}
ul.list2 li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
	text-decoration: none;	
}
.main ul.list2 li img{
	float: left;
	width: 126px;
	height: auto;
	border: 1px solid #949494;
}
.main ul.list2 li .right{
	float: right;
	width: 158px;
}
.main ul.list2 li .right .rightTitle{
	padding: 0;
	font-size: 20px;
	line-height: 120%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main ul.list2 li .right .rightTitle span{
	font-size: 15px;
}
.main ul.list2 li .right p{
	margin: 0;
	padding: 15px 0 25px;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}

.main .boxColumn{
	margin: 0 0 18px;
	padding: 0;
	width: 100%;
	position: relative;
}
.main .boxColumn .left{
	float: left;
	width: 300px;
}
.main .boxColumn .left img{
	width: 100%;
	height: auto;
}
.main .boxColumn .right{
	float: right;
	width: 302px;
}
.main .boxColumn .right .rightTitle{
	padding: 0;
	font-size: 20px;
	line-height: 120%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .boxColumn .right .rightTitle span{
	font-size: 15px;
}
.main .boxColumn .right .by{
	margin: 0;
	padding: 10px 0 0;
	font-size: 12px;
	line-height: 150%;
	text-align: left;
}
.main .boxColumn .right .by span{
	margin: 0 5px 0 0;
	padding: 1px 5px;
	background-color: #e60012;
	color: #FFF;
	text-align: center;
}
.main .boxColumn .right p{
	margin: 0;
	padding: 10px 0 25px;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .boxColumn .bt a{
	padding: 5px;
	font-size: 12px;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: absolute;
	right: 0;
	bottom: 0;
	transition: .3s;
}
.main .boxColumn .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}

.main ul.news{
	margin: 0;
	padding: 0;
}
.main ul.news li{
	padding: 0 0 15px;
	text-align: left;
	font-size: 14px;
	line-height: 140%;
}
.main ul.news li::before {
	margin: 0 8px 0 0;
	position: relative;
	top: 0;
	left: 0;
	display: inline-block;
	width: 12px;
	height: 12px;
	content: '';
	background-color: #b5b6b6;
}
.main ul.news li a{
	text-decoration: none;	
	transition: .3s;
}
.main ul.news li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
	text-decoration: none;	
}



/* 書籍一覧 
---------------------------------------------------------*/
.main .box.list{
	margin: 0 0 18px;
	padding: 17px;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
	position: relative;
}
.main .box.list .left{
	float: left;
	padding: 0 0 20px;
	width: 200px;
}
.main .box.list .left img{
	width: 100%;
	height: auto;
}
.main .box.left .book{
	margin: 0 0;
	width: 198px;
	border: 1px solid #949494;
}
.main .box.list .left .book img{
	width: 100%;
	height: auto;
}
.main .box.list .right{
	float: right;
	padding: 0 0 20px;
	width: 360px;
}
.main .box.list .right .rightTitle{
	padding: 0;
	font-size: 20px;
	line-height: 140%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box.list a{
	display: block;
	color: #514e4d;
	text-decoration: none;
	transition: .3s;
}
.main .box.list a:hover{
	opacity:0.5;
  filter: alpha(opacity=50);
	text-decoration: none;	
}
.main .box.list .right .rightTitle .red{
	color: #e60012;
	font-size: 20px;
	line-height: 150%;
}
.main .box.list .right .rightTitle .small{
	font-size: 20px;
	font-weight: bold;
}
.main .box.list .uLine{
	margin: 0;
	font-size: 18px;
	line-height: 150%;
	border-bottom: 1px solid #e60012;
}
.main .box.list p{
	margin: 0;
	padding: 20px 0 15px;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .box.list .bt a{
	padding: 8px 8px 5px;
	width: 210px;
	display: block;
	font-size: 20px;
	line-height: 100%;
	color: #898989;
	text-align: left;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .box.list .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}

.main .btBox{
	width: 50%;
}
.main .btBox .bt a{
	margin: 0 0 18px;
	padding: 8px 0 5px 8px ;
	width: calc(100% - 16px);
	display: block;
	font-size: 18px;
	line-height: 100%;
	color: #898989;
	text-align: left;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .btBox .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}


/* 書籍著者一覧 
---------------------------------------------------------*/
.main .box.author{
	margin: 0 0 18px;
	padding: 17px;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
	position: relative;
}
.main .box.author .authorT{
	padding: 0 0 15px;
	font-size: 20px;
	line-height: 140%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box.author .authorT .red{
	color: #e60012;
	font-size: 20px;
	line-height: 150%;
}
.main .box.author .photo{
	margin: 0 auto 15px;
	width: 234px;
	border: none;
}
.main .box.author .photo img{
	width: 100%;
	height: auto;
}
.main .box.author .title{
	margin: 0;
	padding: 0;
	font-size: 20px;
	line-height: 150%;
	display: inline;
	border-style: none;
	border-bottom: 1px solid #e60012;
	}
.main .box.author .title a{
	color: #514e4d;
	text-decoration: none;
	transition: .3s;
}
.main .box.author .title a:hover{
	opacity:0.5;
	filter: alpha(opacity=50);
	text-decoration: none;	
}
.main .box.author p{
	margin: 0;
	padding: 20px 0 15px;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .box.author .boxGray{
	margin: 0 0 0;
	padding: 0 0 17px;
	width: 100%;
	text-align: left;
	border: 1px solid #b5b6b6;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.main .box.author .boxGray .boxT{
	margin: 0 0 18px;
	padding: 8px 17px 5px;
	width: calc(100% - 34px);
	font-size: 20px;
	font-weight: bold;
	color: #FFF;
	text-align: left;
	background-color: #b5b6b6;
}
.main .box.author .boxGray .left{
	float: left;
	margin: 0 0 0 17px;
	width: 183px;
	text-align: center;
}
.main .box.author .boxGray .left img{
	margin: 0;
	width: 100%;
	height: auto;
}
.main .box.author .boxGray .right{
	float: right;
	margin: 0 17px 0 0;
	padding: 0;
	width: 340px;
	text-align: left;
}
.main .box.author .boxGray .right .rightTitle{
	padding: 0 0 15px;
	font-size: 16px;
	line-height: 140%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box.author .boxGray .right p{
	margin: 0;
	padding: 0;
	width: 100%;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}



/* コラム一覧 
---------------------------------------------------------*/
.main .box.column{
	margin: 0 0 18px;
	padding: 17px;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
	position: relative;
}
.main .box.column .left{
	float: left;
	padding: 0;
	width: 280px;
	border: 1px solid #949494;
}
.main .box.column .left img{
	width: 100%;
	height: auto;
}
.main .box.column .right{
	float: right;
	padding: 0 0 20px;
	width: 290px;
}
.main .box.column .right .red{
	margin: 0 0 8px;
	padding: 5px 6px 4px;
	width: 30px;
	color: #FFF;
	font-size: 14px;
	line-height: 100%;
	text-align: center;
	background-color: #e60012;
}
.main .box.column .right .rightTitle{
	padding: 0 0 10px;
	font-size: 20px;
	line-height: 140%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box.list .right .rightTitle .red{
	color: #e60012;
	font-size: 20px;
	line-height: 150%;
}
.main .box.column a{
	display: block;
	color: #514e4d;
	text-decoration: none;
	transition: .3s;
}
.main .box.column a:hover{
	opacity:0.5;
	filter: alpha(opacity=50);
	text-decoration: none;	
}
.main .box.column .right .date{
	font-size: 14px;
	font-weight: normal;
	text-align: right;
}



/* コラム筆者一覧 
---------------------------------------------------------*/
.main .boxGray.column_author{
	margin: 0 0 18px;
	padding: 17px;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
}
.main .boxGray.column_author .authorT{
	margin: 0 0 18px;
	padding: 0 0 15px;
	width: 100%;
	font-size: 20px;
	line-height: 150%;
	font-weight: bold;
	text-align: left;
}
.main .boxGray.column_author .title{
	margin: 0;
	padding: 0;
	font-size: 20px;
	line-height: 150%;
	display: inline;
	border-style: none;
	border-bottom: 1px solid #e60012;
	}
.main .boxGray.column_author .title a{
	color: #514e4d;
	text-decoration: none;
	transition: .3s;
}
.main .boxGray.column_author .title a:hover{
	opacity:0.5;
	filter: alpha(opacity=50);
	text-decoration: none;	
}
.main .boxGray.column_author p{
	margin: 0 auto;
	padding: 15px 0 0;
	width: 100%;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .boxGray.column_author .bt a{
	margin: 1em auto 0.2em;
	padding: 8px 0 5px 8px;
	width: 260px;
	display: block;
	font-size: 18px;
	line-height: 100%;
	color: #898989;
	text-align: left;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .boxGray.column_author .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}



/* 書籍詳細 
---------------------------------------------------------*/
.main .box.details{
	margin: 0 0 18px;
	padding: 17px;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
	position: relative;
}
.main .box.details p{
	margin: 0;
	padding: 0;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}

.main .boxGray{
	margin: 0 0 18px;
	padding: 0 0 17px;
	width: 100%;
	text-align: left;
	border: 1px solid #b5b6b6;
}
.main .boxGray .boxT{
	margin: 0 0 18px;
	padding: 8px 17px 5px;
	width: calc(100% - 34px);
	font-size: 20px;
	font-weight: bold;
	color: #FFF;
	text-align: left;
	background-color: #b5b6b6;
}
.main .boxGray .photo{
	margin: 0 auto;
	padding: 0 0 20px;
	width: 386px;
}
.main .boxGray .photo img{
	width: 100%;
	height: auto;
}
.main .boxGray p{
	margin: 0 auto;
	padding: 0;
	width: calc(100% - 34px);
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .boxGray p.data{
	font-size: 15px;
	font-weight: bold;
}
.main .boxGray .left{
	float: left;
	margin: 0 0 0 17px;
	width: 45%;
	text-align: center;
}
.main .boxGray .left img{
	margin: 0 auto;
	width: 224px;
	height: auto;
}
.main .boxGray .left .bt a{
	margin: 1em auto 0;
	padding: 8px 0 5px;
	width: 212px;
	display: block;
	font-size: 18px;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .boxGray .left .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}
.main .boxGray .right{
	float: right;
	margin: 0 17px 0 0;
	width: 45%;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .boxGray .bt a{
	margin: 1em auto 0;
	padding: 8px 0 5px;
	width: 232px;
	display: block;
	font-size: 18px;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .boxGray .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}
.main .cap{
	padding: 0 0 18px;
	width: 100%;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .banBox{
	margin: 0 0 18px;
	padding: 17px;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
	background-color: #dcdddd;
}
.main .banBox ul{
	margin: 0;
	padding: 0 0 20px;
	text-align: center;
}
.main .banBox ul:last-child{
	padding: 0 0 0;
}
.main .banBox li{
	margin: 0 70px;
	width: 139px;
	display: inline-block;
}
.main .banBox li a{
	padding: 15px 0;
	display: block;
	font-size: 15px;
	line-height: 100%;
	color: #FFF;
	text-align: center;
	text-decoration: none;
	transition: .3s;
	background-color: #e60012;
}
.main .banBox li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
	text-decoration: none;	
}

.prev .bookT{
	margin: 0;
	padding: 0 0 15px;
	text-align: left;
	font-size: 14px;
	line-height: 140%;
	font-weight: bold;
}
.prev .bookT::before {
	margin: 0 8px 0 0;
	position: relative;
	top: 0;
	left: 0;
	display: inline-block;
	width: 12px;
	height: 12px;
	content: '';
	background-color: #b5b6b6;
}
.prev p{
	margin: 0;
	padding: 0 0 20px;
	text-align: left;
	font-size: 14px;
	line-height: 140%;
}


/* コラム詳細 
---------------------------------------------------------*/
.main .box.column_details{
	margin: 0 0 25px;
	padding: 0;
	width: 100%;
	text-align: left;
	border-style: none;
}
.main .box.column_details img{
	margin: 0 0 15px;
	width: 100%;
	height: auto;
}
.main .box.column_details .main{
	width: 100%;
	height: 276px;
	overflow: hidden;
}
.main .box.column_details .main img{
	width: 100%;
	height: auto;
}
.main .box.column_details .title{
	margin: 0;
	padding: 0;
	font-size: 20px;
	line-height: 150%;
	display: inline;
	border-style: none;
	border-bottom: 1px solid #e60012;
	}
	.main .box.column_details .title a{
	color: #514e4d;
	text-decoration: none;
	transition: .3s;
}
	.main .box.column_details .title a:hover{
	opacity:0.5;
	filter: alpha(opacity=50);
	text-decoration: none;	
}
	.main .box.column_details .by{
	margin: 0;
	padding: 15px 0 0;
	font-size: 14px;
	line-height: 150%;
	text-align: left;
}
	.main .box.column_details .by span{
	margin: 0 10px 0 0;
	padding: 1px 5px 0px;
	background-color: #e60012;
	color: #FFF;
	text-align: center;
}
.main .box.column_details p{
	margin: 0;
	padding: 15px 0 0;
	font-size: 12px;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}


/* メルマガ 
---------------------------------------------------------*/
.main ul.mail_number{
	margin: 0 0 30px;
	padding: 0;
}
.main ul.mail_number li{
	padding: 0 0 10px;
	text-align: left;
	font-size: 15px;
	line-height: 140%;
}
.main ul.mail_number li::before {
	margin: 0 15px 0 0;
	position: relative;
	top: 0;
	left: 0;
	display: inline-block;
	width: 12px;
	height: 12px;
	content: '▶';
	color: #b5b6b6;
}
.main ul.mail_number li a{
	text-decoration: none;	
	transition: .3s;
}
.main ul.mail_number li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
	text-decoration: none;	
}

#step_bar_box {
	width: 100%;
	text-align: center;
	overflow: hidden;
	margin-bottom: 20px;
}
.step_bar {
	width: 100%;
	list-style: none;
	overflow: hidden;
}
.step_bar li {
	width: 24.3%;
	font-size: 18px;
	line-height: 46px;
	color: #FFF;
	font-weight: bold;
	text-decoration: none;
	padding: 0 15px 0 35px;
	background: #dcdddd;
	display: inline-block;
}
.step_bar li::after {
	position: relative;
	display: block;
	margin-top: -25px;
	margin-left: auto;
	margin-right: -25px;
	height: 22px;
	width: 20px;
	content: " ";
	-webkit-transform: skew(-30deg);
	-moz-transform: skew(-30deg);
	-ms-transform: skew(-30deg);
	-o-transform: skew(-30deg);
	transform: skew(-30deg);
	background: #dcdddd;
	border-right: 5px solid #FFF;
}
.step_bar li::before {
	float: right;
	display: block;
	margin-bottom: -25px;
	margin-left: auto;
	margin-right: -25px;
	height: 21px;
	width: 20px;
	content: " ";
	-webkit-transform: skew(30deg);
	-moz-transform: skew(30deg);
	-ms-transform: skew(30deg);
	-o-transform: skew(30deg);
	transform: skew(30deg);
	background: #dcdddd;
	border-right: 5px solid #FFF;
}
.step_bar li:first-child {
	padding-left: 20px;
}
.step_bar li:last-child {
	padding-left: 35px;
	padding-right: 40px;
}
.step_bar li:last-child::before {
	border: 0;
	background: transparent !important;
}
.step_bar li:last-child::after {
	border: 0;
	background: transparent !important;
}
.step_bar li.current {
	background: #b5b6b6;
	color: #FFF;
}
.step_bar li.current::before {
	background: #b5b6b6;
}
.step_bar li.current::after {
	background: #b5b6b6;
}
.step_bar li.current:last-child {
	margin-right: -35px;
}
.step_bar li.current:last-child::before {
	border: 0;
	background: transparent !important;
}
.step_bar li.current:last-child::after {
	border: 0;
	background: transparent !important;
}

.main .tb_mail{
	margin: 0 0 18px;
	padding: 0;
	width: 100%;
	text-align: left;
	border: 1px solid #b5b6b6;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.main .tb_mail tr.gry{
	background-color: #eeefef;
}
.main .tb_mail th,
.main .tb_mail td{
	padding: 20px;
	font-size: 15px;
	font-weight: normal;
	text-align: left;
	vertical-align: top;
}
.main .tb_mail th{
	padding: 20px 0 20px 20px;
	width: 240px;
}
.main .tb_mail th p{
	float: left;
	margin: 0;
	padding: 0;
	font-size: 15px;
	text-align: left;
}
.main .tb_mail th span{
	float: right;
	margin: 0;
	padding: 3px 5px;
	font-size: 14px;
	color: #FFF;
	text-align: center;
	line-height: 100%;
	background-color: #e60012;
}
.main .tb_mail td .txtf1{
	margin: -6px 0 0;
	padding: 8px;
	width: calc(100% - 16px);
	border: 1px solid #b5b6b6;
}
.main .tb_mail td select.txtf1{
	margin: -6px 0 0;
	padding: 8px;
	width: 100%;
	border: 1px solid #b5b6b6;
}
.main .tb_mail td label:first-child{
	margin: 0 90px 0 0;
}
.main .tb_mail td.last{
	padding: 0 20px 35px 20px;
}
.main .tb_mail td .box{
	margin: 0 auto 35px;
	padding: 20px;
	width: calc(100% - 40px);
	background-color: #eeefef;
	border: none;
}
.main .tb_mail td .box p{
	margin: 0;
	padding: 0 0 8px;
	font-size: 15px;
	text-align: left;
}
.main .tb_mail td .box .bt a{
	margin: 0 0 10px;
	padding: 8px 8px 8px;
	width: 190px;
	display: block;
	font-size: 14px;
	line-height: 100%;
	color: #898989;
	text-align: left;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	background-color: #FFF;
	position: static;
	transition: .3s;
}
.main .tb_mail td .box .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}
.main .tb_mail td .box label{
	margin: 0;
}
/* フォーム ボタン */
input[type="submit"],
input[type="button"] {
    border-radius: 0;
    -webkit-box-sizing: content-box;
    -webkit-appearance: button;
    appearance: button;
    border: none;
    box-sizing: border-box;
    cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
    display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
    outline-offset: -2px;
}
input[type="submit"], input[type="button"]{
	margin: 0 auto;
	padding: 15px 0;
	width: 184px;
	height: auto;
	font-size: 14px;
	line-height: 100%;
	font-weight: bold;
	color: #FFF;
	text-align: center;
	background-color: #0067b6;
	cursor: pointer;
	display: block;
	transition: .3s;
}
input[type="button"].wpcf7-back{
	background-color: #999;
	margin: 0 auto 1em;
}
input[type="submit"]:hover,
input[type="button"]:hover{
  opacity:0.5;
  filter: alpha(opacity=50);
}
.sendText{
	margin: 0 auto;
	padding: 0 0 1em;
	width: 90%;
	font-size: 120%;
	line-height: 140%;
}
.sendText p{
	padding: 1em 0 0;
	font-size: 90%;
	line-height: 140%;
}


/* サイドバー 
---------------------------------------------------------*/
.side{
	float: right;
	width: 300px;
}
.side .twit{
	width: 100%;
	border: 1px solid #b5b6b6;
}



/* フッター 
---------------------------------------------------------*/
.footer{
	margin: 30px auto 0;
	padding: 22px 0 0;
	width: 100%;
	background-color: #b5b6b6;
}
.footer ul{
	margin: 0 auto;
	padding: 0 0 12px;
	width: 580px;
}
.footer li{
	float: left;
	width: 125px;
	font-size: 11px;
	color: #656363;
	text-align: left;
}
.footer li:nth-child(5){
	width: 70px;
}
.footer li span{
	display: none;
}
.footer li a{
	color: #656363;
	text-decoration: none;
	transition: .3s;
}
.footer li a:hover{
	color: #000;
	text-decoration: none;
}
.footer .copyright{
	padding: 15px 0 20px;
	width: 100%;
	font-size: 11px;
	color: #555;
	text-align: center;
	background-color: #898989;
}


/* ページトップ */
#page-top {
	position: fixed;
	bottom: 460px;
	right: 20px;
	height: 62px;
	width: 62px;
}
#page-top a:hover img{
  opacity:0.5;
  filter: alpha(opacity=50);
}





@media screen and (max-width: 750px){
/* SP */
.pcOnly {
		display: none;
}
.spOnly {
	display: block;
}

div#wrap {
	padding-top: 0;
}

/* header 
---------------------------------------------------------*/
#header{
	margin: 0 auto;
	width: 100%;
	height: 105px;
	background-color: #FFF;
}
#header .inner{
	margin: 0 auto;
	width: 90%;
	height: auto;
}
#header .inner h1{
	float: left;
	width: 45%;
	padding-top: 20px;
	margin-left: 0;
	text-align: left;
}
#header .inner h1 img{
	width: 100%;
	max-width: 150px;
	height: auto;
	}
#header .inner .serch{
	float: right;
	margin: 40px 10px 0 0;
	width: 35%;
	max-width: 162px;
	height: 28px;
	border: 2px solid #dadada;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}
#header .inner .serch input{
	float: left;
	padding: 2px 5px;
	width: calc(100% - 30px);
	height: 20px;
	border-style: none;
}
#header .inner .serch button{
	float: right;
	margin: 3px 2px 0 0;
	width: 18px;
	border: 0;
	border-style: none;
	background-color: #FFF;
}
#header .inner .serch img{
	width: 14px;
	height: auto;
	}

#header .inner #hMenuBt{
	float: right;
	margin: 32px 0 0 0;
	width: 38px;
	height: auto;
}
#header .inner #hMenuBt img{
	width: 100%;
	height: auto;
}
#header .inner #hMenuBt span{
	font-size: 80%;
	line-height: 100%;
	color: #b5b6b6;
	display: block;
	text-align: center;
	padding-top: 0.2em;
}

/* ハンバーガー
--------------------------------------------*/
#hMenu{
	background-color: #FFF;
	width: 100%;
	position: absolute;
	z-index: 10000;
	top: 105px;
	display: block;
}
ul#hNaviSp{
	margin: 0 auto;
	width: 100%;
	padding: 0;
	box-sizing: border-box;
	border-top: 1px dotted #ccc;
}
ul#hNaviSp li a{
	margin: 0 auto;
	display: block;
	padding: 1em 5%;
	width: 90%;
	font-size: 110%;
	color: #333;
	text-align: left;
	text-decoration: none;
	border-bottom: 1px dotted #ccc;
}




/* ナビゲーション
--------------------------------------------*/
nav{
	margin: 0 auto 20px;
	width: 90%;
	padding: 0;
	z-index: 1000;
}
nav #gNavi{
	margin: 0 auto;
	width: 100%;
	padding: 0;
	position: relative;
	z-index: 1000;
}
nav #gNavi ul{
	list-style-type: none;
	width: 100%;
	border-top: 1px solid #b5b6b6;
	border-bottom: 1px solid #b5b6b6;
}
nav #gNavi ul:last-child{
	border-top: none;
}
nav #gNavi li a{
	float: left;
	width: 50%;
	padding: 14px 0 12px;
	font-size: 16px;
	line-height: 100%;
	color: #999;
	text-align: center;
	text-decoration: none;
	display: block;
	border-left: 1px solid #b5b6b6;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	transition: .3s;
}
nav #gNavi li:last-child a{
	border-right: 1px solid #b5b6b6;
}
nav #gNavi li a:hover{
	color: #000;
	text-decoration: none;
}


/* スライド 
---------------------------------------------------------*/
#topslideSp{
	margin: 0 auto 1em;
	width: 90%;
	height: auto;
	overflow: hidden;
	position: relative;
}
ul.slideSp{
	width: calc(100% + 8px);
	height: auto;
	margin: 0;
	padding: 0;
	overflow: hidden;
}
ul.slideSp li{
	margin: 0 10px 0 0;
	padding: 0px;
	height: auto;
	border: 1px solid #777;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
ul.slideSp li img{
	width: 100%;
	height: auto;
	z-index: 9;
}

ul.slideSp li div{
	width: 18px;
	height: 44px;
	position: absolute;
	top: 0;
	left: 5%;
	z-index: 10;
}
ul.slideSp li div img{
	width: 100%;
	height: auto;
}
ul.slideSp li a{
	display: block;
	transition: .3s;
}
ul.slideSp li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
}

.btCenter a{
	margin: 0 auto 1.5em;
	display: block;
	padding: 5px;
	width: 25%;
	font-size: 90%;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	transition: .3s;
}
.btCenter.play a{
	margin: 1em auto 0;
	padding: 8px 40px 8px 0;
	width: 45%;
	background-image: url(../images/play.png);
	background-position: right 15px center;
	background-repeat: no-repeat;
}
.btCenter a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}


#topslideSp .ban{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	border: 1px solid #ccc;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
#topslideSp .ban img{
	width: 100%;
	height: auto;
}

.contents{
	margin: 0 auto;
	padding: 0;
	width: 90%;
}


/* トップ 
---------------------------------------------------------*/
.main{
	float: none;
	margin: 0 auto;
	padding: 0 0 1em 0;
	width: 100%;
}
.main section{
	padding: 0 0 5px 0;
}
.main section p{
	margin: 0;
	padding: 0 0 1em 0;
}
.main .title{
	margin: 0 0 1em;
	padding: 5px;
	width: calc(100% - 10px);
	border: 1px solid #b5b6b6;
	text-align: left;
}
.main .title p{
	padding: 7px 15px 3px;
	width: calc(100% - 30px);
	height: auto;
	border-left: 10px solid #e60012;
	font-size: 140%;
	line-height: 100%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box{
	margin: 0 0 2em;
	padding: 0;
	width: 100%;
	border: none;
	position: relative;
}
.main .box .left{
	float: none;
	padding: 0 0 1em;
	width: 100%;
}
.main .box .left img{
	width: 100%;
	height: auto;
}
.main .box .left .book{
	margin: 0 auto;
	width: 100%;
	border: 1px solid #949494;
}
.main .box .left .book img{
	width: 100%;
	height: auto;
}
.main .box .right{
	float: none;
	width: 100%;
}
.main .box .right .rightTitle{
	padding: 0;
	font-size: 140%;
	line-height: 120%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box .right .rightTitle span{
	font-size: 70%;
}
.main .box .right p{
	margin: 0;
	padding: 15px 0 1em;
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .box .bt a{
	float: right;
	padding: 5px;
	font-size: 90%;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: relative;
	right: 0;
	bottom: 0;
	transition: .3s;
}
.main .box .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}

.mailMag{
	margin: 0 auto 2em;
	padding: 5px;
	width: calc(100% - 10px);
	border: 1px solid #b5b6b6;
	background-color: #dcdddd;
}
.mailMag .title{
	margin: 0;
	padding: 10px 0 5px;
	width: 100%;
	font-size: 110%;
	line-height: 100%;
	text-align: center;
	color: #FFF;
	background-color: #e60012;
	border: none;
}
.mailMag .title a{
	color: #FFF;
	text-decoration: none;
}
.mailMag p{
	margin: 0 auto;
	padding: 5px 0 5px;
	width: 95%;
	font-size: 80%;
	text-align: left;
}


.main .boxColumn{
	margin: 0 0 2em;
	padding: 0;
	width: 100%;
	position: relative;
}
.main .boxColumn .left{
	float: none;
	padding: 0 0 1em;
	width: 100%;
}
.main .boxColumn .left img{
	width: 100%;
	height: auto;
}
.main .boxColumn .right{
	float: none;
	width: 100%;
}
.main .boxColumn .right .rightTitle{
	padding: 0;
	font-size: 140%;
	line-height: 120%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .boxColumn .right .rightTitle span{
	font-size: 70%;
}
.main .boxColumn .right .by{
	margin: 0;
	padding: 10px 0 0;
	font-size: 100%;
	line-height: 150%;
	text-align: left;
}
.main .boxColumn .right .by span{
	margin: 0 5px 0 0;
	padding: 1px 5px 0;
	background-color: #e60012;
	color: #FFF;
	text-align: center;
}
.main .boxColumn .right p{
	margin: 0;
	padding: 10px 0 1em;
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .boxColumn .bt a{
	float: right;
	padding: 5px;
	font-size: 90%;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: relative;
	right: 0;
	bottom: 0;
	transition: .3s;
}
.main .boxColumn .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}
.main .boxColumn .link a{
	float: right;
	margin: 1em 0 0;
	padding: 5px;
	font-size: 90%;
	line-height: 100%;
	color: #898989;
	text-align: right;
	text-decoration: none;
}
.main .boxColumn .link a span{
	color: #000;
}

.main ul.news{
	margin: 0;
	padding: 0;
}
.main ul.news li{
	padding: 0 0 1em;
	text-align: left;
	font-size: 100%;
	line-height: 140%;
}
.main ul.news li::before {
	margin: 0 8px 0 0;
	position: relative;
	top: 0;
	left: 0;
	display: inline-block;
	width: 12px;
	height: 12px;
	content: '';
	background-color: #b5b6b6;
}
.main ul.news li a{
	text-decoration: none;	
	transition: .3s;
}
.main ul.news li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
	text-decoration: none;	
}



/* 書籍一覧 
---------------------------------------------------------*/
.main .box.list{
	margin: 0 0 1em;
	padding: 1em;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
	position: relative;
}
.main .box.list .left{
	float: left;
	padding: 0 0 0;
	width: 35%;
}
.main .box.list .left img{
	width: 100%;
	height: auto;
}
.main .box.left .book{
	margin: 0 0;
	width: 100%;
	border: 1px solid #949494;
}
.main .box.list .left .book img{
	width: 100%;
	height: auto;
}
.main .box.list .right{
	float: right;
	padding: 0 0 0;
	width: 60%;
}
.main .box.list .right .rightTitle{
	padding: 0;
	font-size: 140%;
	line-height: 140%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box.list .right .rightTitle .red{
	margin: 0 0 0.5em;
	padding: 0.5em 0 0.3em;
	width: 46px;
	color: #FFF;
	font-size: 65%;
	line-height: 100%;
	font-weight: normal;
	text-align: center;
	display: block;
	background-color: #e60012;
}
.main .box.list .right .rightTitle .small{
	font-size: 70%;
	font-weight: normal;
}

.main .btBox{
	width: 65%;
}
.main .btBox .bt a{
	margin: 0 0 1em;
	padding: 8px 0 5px 8px;
	width: calc(100% - 16px);
	display: block;
	font-size: 90%;
	line-height: 100%;
	color: #898989;
	text-align: left;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .btBox .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}


/* 書籍著者一覧 
---------------------------------------------------------*/
.main .box.author{
	margin: 0 0 1em;
	padding: 1em;
	width: calc(100% - 2em);
	text-align: left;
	border: 1px solid #b5b6b6;
	position: relative;
}
.main .box.author .authorT{
	padding: 0 0 0.5em;
	font-size: 140%;
	line-height: 140%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box.author .authorT .red{
	margin: 0 0 0.5em;
	padding: 0.5em 0 0.3em;
	width: 46px;
	color: #FFF;
	font-size: 65%;
	line-height: 100%;
	font-weight: normal;
	text-align: center;
	display: block;
	background-color: #e60012;
}
.main .box.author .photo{
	margin: 0 auto 1em;
	width: 90%;
	border: none;
}
.main .box.author .photo img{
	width: 100%;
	height: auto;
}
.main .box.author .title{
	margin: 0;
	padding: 0;
	font-size: 140%;
	line-height: 150%;
	display: inline;
	border-style: none;
	border-bottom: 1px solid #e60012;
	}
.main .box.author .title a{
	color: #514e4d;
	text-decoration: none;
	transition: .3s;
}
.main .box.author .title a:hover{
	opacity:0.5;
	filter: alpha(opacity=50);
	text-decoration: none;	
}
.main .box.author p{
	margin: 0;
	padding: 1em 0 1em;
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .box.author .boxGray{
	margin: 0 0 0;
	padding: 0 0 1em;
	width: 100%;
	text-align: left;
	border: 1px solid #b5b6b6;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.main .box.author .boxGray .boxT{
	margin: 0 0 1em;
	padding: 8px 17px 5px;
	width: calc(100% - 34px);
	font-size: 140%;
	font-weight: bold;
	color: #FFF;
	text-align: left;
	background-color: #b5b6b6;
}
.main .box.author .boxGray .left{
	float: none;
	margin: 0 auto;
	width: 80%;
	text-align: center;
}
.main .box.author .boxGray .left img{
	margin: 0;
	width: 100%;
	height: auto;
}
.main .box.author .boxGray .right{
	float: none;
	margin: 0 auto;
	padding: 0;
	width: 90%;
	text-align: left;
}
.main .box.author .boxGray .right .rightTitle{
	padding: 0 0 0.5em;
	font-size: 120%;
	line-height: 140%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box.author .boxGray .right p{
	margin: 0;
	padding: 0;
	width: 100%;
	font-size: 100%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}


/* コラム一覧 
---------------------------------------------------------*/
.main .box.column{
	margin: 0 0 1em;
	padding: 1em;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
	position: relative;
}
.main .box.column .left{
	float: left;
	padding: 0 0 0;
	width: 35%;
	border: 1px solid #949494;
	position: relative;
	overflow: hidden;
}
.main .box.column .left:before {
	content:"";
	display: block;
	padding-top: 100%;
}
.main .box.column .left img{
	width: auto;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}
.main .box.column .right{
	float: right;
	padding: 0 0 0;
	width: 60%;
}
.main .box.column .right .red{
	margin: 0 0 0.5em;
	padding: 0.5em 0 0.3em;
	width: 46px;
	color: #FFF;
	font-size: 65%;
	line-height: 100%;
	font-weight: normal;
	text-align: center;
	display: block;
	background-color: #e60012;
}
.main .box.column .right .rightTitle{
	padding: 0 0 0.5em;
	font-size: 140%;
	line-height: 140%;
	color: #514e4d;
	font-weight: bold;
	text-align: left;
}
.main .box.column .right .date{
	font-size: 100%;
	font-weight: normal;
	text-align: left;
}



/* コラム筆者一覧 
---------------------------------------------------------*/
.main .boxGray.column_author{
	margin: 0 0 1em;
	padding: 1em;
	width: calc(100% - 2em);
	text-align: left;
	border: 1px solid #b5b6b6;
}
.main .boxGray.column_author .authorT{
	margin: 0 0 1em;
	padding: 0 0 0;
	width: 100%;
	font-size: 120%;
	line-height: 150%;
	font-weight: bold;
	text-align: left;
}
.main .boxGray.column_author .title{
	margin: 0;
	padding: 0;
	font-size: 140%;
	line-height: 150%;
	display: inline;
	border-style: none;
	border-bottom: 1px solid #e60012;
	}
.main .boxGray.column_author .title a{
	color: #514e4d;
	text-decoration: none;
	transition: .3s;
}
.main .boxGray.column_author .title a:hover{
	opacity:0.5;
	filter: alpha(opacity=50);
	text-decoration: none;	
}
.main .boxGray.column_author p{
	margin: 0 auto;
	padding: 1em 0 0;
	width: 100%;
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .boxGray.column_author .bt a{
	margin: 1em auto 0.2em;
	padding: 8px 0 5px 8px;
	width: 60%;
	display: block;
	font-size: 90%;
	line-height: 100%;
	color: #898989;
	text-align: left;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .boxGray.column_author .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}


/* 書籍詳細 
---------------------------------------------------------*/
.main .box.details{
	margin: 0 0 1em;
	padding: 0;
	width: 100%;
	text-align: left;
	border: none;
	position: relative;
}
.main .box.details .book{
	margin: 0 auto 0.5em;
	width: 80%;
	border: 1px solid #949494;
}
.main .box.details p{
	margin: 0;
	padding: 0;
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}

.main .boxGray{
	margin: 0 0 1em;
	padding: 0 0 1em;
	width: 100%;
	text-align: left;
	border: 1px solid #b5b6b6;
}
.main .boxGray .boxT{
	margin: 0 0 1em;
	padding: 8px 17px 5px;
	width: calc(100% - 34px);
	font-size: 140%;
	font-weight: bold;
	color: #FFF;
	text-align: left;
	background-color: #b5b6b6;
}
.main .boxGray .photo{
	margin: 0 auto;
	padding: 0 0 1em;
	width: 90%;
}
.main .boxGray .photo img{
	width: 100%;
	height: auto;
}
.main .boxGray p{
	margin: 0 auto;
	padding: 0;
	width: calc(100% - 34px);
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .boxGray p.data{
	font-size: 110%;
	font-weight: bold;
}
.main .boxGray .left{
	float: none;
	margin: 0 auto;
	width: calc(100% - 34px);
}
.main .boxGray .left img{
	margin: 0 auto;
	width: 100%;
	height: auto;
}
.main .boxGray .left .bt a{
	margin: 1em auto 0;
	padding: 8px 0 5px;
	width: 50%;
	display: block;
	font-size: 90%;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .boxGray .left .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}
.main .boxGray .right{
	float: none;
	margin: 0 auto;
	padding: 1em 0 0;
	width: calc(100% - 34px);
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .boxGray .bt a{
	margin: 1em auto 0;
	padding: 8px 0 5px;
	width: 50%;
	display: block;
	font-size: 90%;
	line-height: 100%;
	color: #898989;
	text-align: center;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	position: static;
	transition: .3s;
}
.main .boxGray .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}
.main .cap{
	padding: 0 0 1em;
	width: 100%;
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}
.main .banBox{
	margin: 0 0 1em;
	padding: 17px;
	width: calc(100% - 34px);
	text-align: left;
	border: 1px solid #b5b6b6;
	background-color: #dcdddd;
}
.main .banBox ul{
	margin: 0;
	padding: 0 0 1em;
	text-align: center;
}
.main .banBox ul:last-child{
	padding: 0 0 0;
}
.main .banBox li{
	margin: 0 2%;
	width: 45%;
	display: inline-block;
}
.main .banBox li a{
	padding: 1em 0;
	display: block;
	font-size: 120%;
	line-height: 100%;
	color: #FFF;
	text-align: center;
	text-decoration: none;
	transition: .3s;
	background-color: #e60012;
}
.main .banBox li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
	text-decoration: none;	
}

.prev .bookT{
	margin: 0;
	padding: 0 0 1em;
	text-align: left;
	font-size: 100%;
	line-height: 140%;
	font-weight: bold;
}
.prev .bookT::before {
	margin: 0 8px 0 0;
	position: relative;
	top: 0;
	left: 0;
	display: inline-block;
	width: 12px;
	height: 12px;
	content: '';
	background-color: #b5b6b6;
}
.prev p{
	margin: 0;
	padding: 0 0 1.5em;
	text-align: left;
	font-size: 100%;
	line-height: 140%;
}


/* コラム詳細 
---------------------------------------------------------*/
.main .box.column_details{
	margin: 0 0 2em;
	padding: 0;
	width: 100%;
	text-align: left;
	border-style: none;
}
.main .box.column_details img{
	margin: 0 0 1em;
	width: 100%;
	height: auto;
}
.main .box.column_details .main{
	width: 100%;
	height: 160px;
	overflow: hidden;
}
.main .box.column_details .main img{
	width: 100%;
	height: auto;
	}
	.main .box.column_details .title{
	margin: 0;
	padding: 0;
	font-size: 140%;
	line-height: 140%;
	display: inline;
	border-style: none;
	border-bottom: 1px solid #e60012;
	}
	.main .box.column_details .title a{
	color: #514e4d;
	text-decoration: none;
	transition: .3s;
}
	.main .box.column_details .title a:hover{
	opacity:0.5;
	filter: alpha(opacity=50);
	text-decoration: none;	
}
	.main .box.column_details .by{
	margin: 0;
	padding: 15px 0 0;
	font-size: 100%;
	line-height: 150%;
	text-align: left;
}
	.main .box.column_details .by span{
	margin: 0 10px 0 0;
	padding: 1px 5px 0px;
	background-color: #e60012;
	color: #FFF;
	text-align: center;
}
.main .box.column_details p{
	margin: 0;
	padding: 1em 0 0;
	font-size: 90%;
	line-height: 150%;
	color: #514e4d;
	text-align: left;
}


/* メルマガ 
---------------------------------------------------------*/
.main ul.mail_number{
	margin: 0 0 2em;
	padding: 0;
}
.main ul.mail_number li{
	padding: 0 0 0.5em;
	text-align: left;
	font-size: 100%;
	line-height: 140%;
}
.main ul.mail_number li::before {
	margin: 0 8px 0 0;
	position: relative;
	top: 0;
	left: 0;
	display: inline-block;
	width: 12px;
	height: 12px;
	content: '▶';
	color: #b5b6b6;
}
.main ul.mail_number li a{
	text-decoration: none;	
	transition: .3s;
}
.main ul.mail_number li a:hover {
	opacity:0.5;
  filter: alpha(opacity=50);
	text-decoration: none;	
}

#step_bar_box {
	width: 100%;
	text-align: center;
	overflow: hidden;
	margin-bottom: 2em;
}
.step_bar {
	width: 100%;
	list-style: none;
	overflow: hidden;
}
.step_bar li {
	width: 18.8%;
	font-size: 120%;
	line-height: 46px;
	color: #FFF;
	font-weight: bold;
	text-decoration: none;
	padding: 0 15px 0 35px;
	background: #dcdddd;
	display: inline-block;
}
@media screen and (max-width: 450px){
	.step_bar li {
		width: 13.0%;
	font-size: 80%;
	}
}
.step_bar li::after {
	position: relative;
	display: block;
	margin-top: -25px;
	margin-left: auto;
	margin-right: -25px;
	height: 22px;
	width: 20px;
	content: " ";
	-webkit-transform: skew(-30deg);
	-moz-transform: skew(-30deg);
	-ms-transform: skew(-30deg);
	-o-transform: skew(-30deg);
	transform: skew(-30deg);
	background: #dcdddd;
	border-right: 5px solid #FFF;
}
.step_bar li::before {
	float: right;
	display: block;
	margin-bottom: -25px;
	margin-left: auto;
	margin-right: -25px;
	height: 21px;
	width: 20px;
	content: " ";
	-webkit-transform: skew(30deg);
	-moz-transform: skew(30deg);
	-ms-transform: skew(30deg);
	-o-transform: skew(30deg);
	transform: skew(30deg);
	background: #dcdddd;
	border-right: 5px solid #FFF;
}
.step_bar li:first-child {
	padding-left: 20px;
}
.step_bar li:last-child {
	padding-left: 35px;
	padding-right: 40px;
}
.step_bar li:last-child::before {
	border: 0;
	background: transparent !important;
}
.step_bar li:last-child::after {
	border: 0;
	background: transparent !important;
}
.step_bar li.current {
	background: #b5b6b6;
	color: #FFF;
}
.step_bar li.current::before {
	background: #b5b6b6;
}
.step_bar li.current::after {
	background: #b5b6b6;
}
.step_bar li.current:last-child {
	margin-right: -35px;
}
.step_bar li.current:last-child::before {
	border: 0;
	background: transparent !important;
}
.step_bar li.current:last-child::after {
	border: 0;
	background: transparent !important;
}

.main .tb_mail{
	margin: 0 0 1em;
	padding: 0;
	width: 100%;
	text-align: left;
	border: 1px solid #b5b6b6;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.main .tb_mail tr.gry{
	background-color: #FFF;
}
.main .tb_mail th,
.main .tb_mail td{
	padding: 10px 20px 20px;
	font-size: 100%;
	font-weight: normal;
	text-align: left;
	vertical-align: top;
	display: block;
	width: calc(100% - 40px);
}
.main .tb_mail th{
	padding: 20px 20px 0;
	width: calc(100% - 40px);
}
.main .tb_mail th p{
	float: left;
	margin: 0;
	padding: 0;
	font-size: 100%;
	text-align: left;
}
.main .tb_mail th span{
	float: left;
	margin: 0 0 0 10px;
	padding: 4px 5px 3px;
	font-size: 80%;
	color: #FFF;
	text-align: center;
	line-height: 100%;
	background-color: #e60012;
}
.main .tb_mail td .txtf1{
	margin: -6px 0 0;
	padding: 8px;
	width: calc(100% - 16px);
	border: 1px solid #b5b6b6;
}
.main .tb_mail td select.txtf1{
	margin: -6px 0 0;
	padding: 8px;
	width: 100%;
	border: 1px solid #b5b6b6;
}
.main .tb_mail td label:first-child{
	margin: 0 22%;
}
.main .tb_mail td.last{
	padding: 0 20px 35px 20px;
}
.main .tb_mail td .box{
	margin: 0 auto 35px;
	padding: 20px;
	width: calc(100% - 40px);
	background-color: #eeefef;
	border: none;
}
.main .tb_mail td .box p{
	margin: 0;
	padding: 0 0 8px;
	font-size: 100%;
	text-align: left;
}
.main .tb_mail td .box .bt a{
	margin: 0 0 10px;
	padding: 8px 8px 8px;
	width: 190px;
	display: block;
	font-size: 80%;
	line-height: 100%;
	color: #898989;
	text-align: left;
	border: 1px solid #b5b6b6;
	text-decoration: none;
	background-color: #FFF;
	position: static;
	transition: .3s;
	float: none;
}
.main .tb_mail td .box .bt a:hover{
	color: #FFF;
	text-decoration: none;
	background-color: #898989;
}
.main .tb_mail td .box label{
	margin: 0;
}



/* サイドバー 
---------------------------------------------------------*/
.side{
	float: none;
	width: 100%;
}
.side .twit{
	width: 100%;
	border: 1px solid #b5b6b6;
}




/* フッター 
---------------------------------------------------------*/
.footer{
	margin: 2em auto 0;
	padding: 1.5em 0 0;
	width: 100%;
	background-color: #b5b6b6;
}
.footer ul{
	margin: 0 auto;
	padding: 0 0 1em;
	width: 90%;
}
.footer li{
	margin: 0 0 0.5em;
	float: left;
	width: auto;
	font-size: 90%;
	color: #656363;
	text-align: left;
}
.footer li:nth-child(5){
	width: auto;
}
.footer li span{
	padding: 0 5px;
	display: inline-block;
}
.footer li a{
	color: #656363;
	text-decoration: none;
	transition: .3s;
}
.footer li a:hover{
	color: #000;
	text-decoration: none;
}
.footer .copyright{
	padding: 1em 0 1em;
	width: 100%;
	font-size: 75%;
	color: #555;
	text-align: center;
	background-color: #898989;
}


/* ページトップ */
#page-top {
	position: fixed;
	bottom: 460px;
	right: 20px;
	height: 62px;
	width: 62px;
}
#page-top a:hover img{
  opacity:0.5;
  filter: alpha(opacity=50);
}

/* ページトップ */
#page-top {
	position: fixed;
	bottom: 40px;
	right: 10px;
	height: 62px;
	width: 62px;
}
#page-top a:hover img{
  opacity:0.5;
  filter: alpha(opacity=50);
}


}



@media screen and (max-width: 763px) and (orientation: landscape) {
}


/* other
---------------------------------------------------------*/
.clearfix:after {  
  content: ".";   
  display: block;   
  height: 0;   
  clear: both;   
  visibility: hidden;  
}
.clearfix { display: inline-table; }  
/* Hides from IE-mac \*/  
* html .clearfix { height: 1%; }  
.clearfix { display: block; }  
/* End hide from IE-mac */  
  
