@charset "utf-8";

/*MAIN
============================================*/

.pp {
	position:relative;
}

.mainTtl {
    position:fixed;
    top: 40%;
    left: 30%;
    z-index: 10000;
}

.mainTtl img{
	width:80%;
}

#main {
    width: 100%;
    height: 1000px;
	background:url(../imgs/main.jpg) no-repeat #fff;
    position: absolute;
    z-index: 1000;
    top: 0;
	display:none;
	cursor:pointer;
}



/*SLIDE
============================================*/
#slide {
    padding:100px 0 0 0;
    z-index: 0;
    position: relative;
}

#slide ul {
	overflow:hidden;
	margin:0 0 20px 0;
}

#slide li {
	float:left;
	overflow:hidden;
}

#slide li img {
	width:100%;
}


/*NEWS
============================================*/
section#news {
	overflow:hidden;
	margin:0 0 50px 0;
	position:relative;

}
/*一覧を見る*/
section#news .detail {
    clear: both;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    padding: 25px 0 0 0;
}

section#news .detail a {
	border: 1px solid #ccc;
	background: #fff;
	text-decoration:none;
	font-family: 'PT Serif', serif;
	padding: 15px;
	width: 12%;
	display: block;
	text-align: center;
	margin: 0 auto;
	color: #666;
}

section#news .detail a:hover {
	border:1px solid #999;
}

section#news .newsBox {
	overflow:hidden;
	padding:0 0 30px 0;
}


section#news .newsBox span {
    text-align: center;
    display: block;
    padding: 100px 0;
    font-size: 90%;
    letter-spacing: 1px;
}

section#news .newsBox li {
	width: 18%;
	display: inline-block;
	vertical-align: top;
	background: #fff;
	margin: 0 25px 0 0;
	box-sizing: border-box;
	position: relative;
	overflow: hidden;
	padding: 0 0 20px 0;
}

section#news .newsBox li a {
	text-decoration:none;
}

section#news .newsBox li a img {
	vertical-align:bottom;
	padding: 1px 0 0 0;
}

section#news .newsBox li:last-child {
	margin:0;
}

section#news .newsBox li dl {
    padding: 0;
    text-align: left;
    width: auto;
    vertical-align:top;
    box-sizing: border-box;
    margin: 15px 0 0 0;
}

section#news .newsBox li dt {
    padding: 0 0 5px 0;
    font-size: 110%;
    letter-spacing: 1px;
    font-weight: bold;
    color: #333;
}

section#news .newsBox li dd {
    font-size: 90%;
    line-height: 2em;
    letter-spacing: 0;
    margin: 10px 0 0 0;
    display: block;
}

section#news .newsBox p {
    position: relative;
    text-align: right;
    padding:20px 0;
    font-size: 100%;
    margin: 0 15px 0 0;
    font-family:'PT Serif', serif;
}

/*マウスオーバー処理---------------------*/

section#news .newsBox li a.more {
	width:100%;
	height:auto;
	float:left;
	color:inherit;
}

section#news .newsBox li a.more:hover {
}

section#news .newsBox li a.more span {
	width: 0%;
    height: 2px;
    margin: 0 auto;
    background: #fff;
    position: absolute;
    top: 32%;
    z-index: 100;
    left: 45%;
}
/*--------------------------------------*/

section#feature {
	margin:0 0 50px 0;
	overflow:hidden;
}

section#feature .featureBox {
    width: auto;
    padding: 0 0 30px 0;
}

section#feature .featureBox a {

	display:block;
}

section#feature .featureBox li {
	width: 32%;
	display: inline-block;
	vertical-align:top;
	margin: 0 20px 20px 0;
}

section#feature .featureBox li:nth-child(3n) {
	margin: 0 0 20px 0;
}

section#feature .featureBox li  span {
	font-size:80%;
}



/*特集バックナンバー*/
section#feature .featureBox .past {
    margin: 15px 10px 10px 0;
}

section#feature .featureBox .past a {
    border: 1px solid #ccc;
    background: #fff;
    text-decoration: none;
    font-family: 'PT Serif', serif;
    padding: 15px;
    width: 12%;
    display: block;
    text-align: center;
    margin: 0 auto;
    color: #666;
}

section#feature .featureBox .past a:hover {
    border: 1px solid #999;
}



section#feature .featureBox img {
	width:100%;
}


section#feature .featureBox .feature_slide {
	clear:both;
	overflow:hidden;
	margin:0;
}

section#feature .featureBox .feature_slide li {
	float:left;
	overflow:hidden;
}

/*BRAND
============================================*/
section#brand {
	clear:both;
    overflow: hidden;
	margin:0 0 50px 0;
}

section#brand .brandBox{
	width:90%;
	margin:0 auto;

}
section#brand .brandBox ul {
	display: flex;
	justify-content: space-between;
}
section#brand .brandBox li {
	position:relative;
	margin: 0 20px 0 0;
	width: 32%;
}
section#brand .brandBox li:last-child {
	margin: 0;
}

section#brand .brandBox li a img {
	width:100%;
	vertical-align:bottom;/*隙間*/
}


section#brand .brandBox li dl {
    padding: 20px 0 40px;
    text-align: center;
    width: 100%;
	
}

section#brand .brandBox li dt {
}

section#brand .brandBox li dd {
	font-size: 80%;
	line-height:2em;
	text-align:left;
	padding:0 20px;
}


section#brand .brandBox li dd span {
	display:block;
	font-size: 100%;
	padding: 0 0 10px 0;
	color: #999;
	text-align:center;
}


/*マウスオーバー処理---------------------*/

section#brand .brandBox li a.more {
	width:100%;
	height:auto;
	display:block;
	background:url(../imgs/viewmore.png) no-repeat center 45%;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

section#brand .brandBox li a.more:hover {
	background:url(../imgs/viewmore.png) no-repeat center 50% #104c57;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

section#brand .brandBox li a.more span {
	width: 0%;
    height: 2px;
    margin: 0 auto;
    background: #fff;
    position: absolute;
    top: 32%;
    z-index: 100;
    left: 45%;
}
/*--------------------------------------*/


/*ABOUT
============================================*/
section#about {
	overflow:hidden;
    margin: 0 auto 50px;
    width: auto;
	padding:0 0 50px 0;
}

section#about .aboutBox {
	width: 90%;
	margin:0 auto;
}



section#about .ofph {
	padding:50px 70px 0 50px;
}


/*head office*/
section#about .headof {
	clear:both;
	padding:0 0 20px 0;
	overflow:hidden;
}

section#about .headof .ttl {
    float: left;
    width: 30%;
    background: #8f82bc;
    height: 397px;
    padding: 10px;
    box-sizing: border-box;
    text-align: center;
    border: 1px solid #fff;
}

section#about .headof .ttl_inner {
	border:1px solid #fff;
	height:373px;
}

section#about .headof .ttl p {
    font-size: 250%;
    color: #fff;
    letter-spacing: 1;
    padding: 100px 0 10px 0;
	font-family:'PT Serif', serif;
}

section#about .headof .ttl p span {
    border: 1px solid #fff;
    width: 10%;
    display: block;
    margin: 30px auto;
}

section#about .headof .ttl dl {
    color: #fff;
    margin: 20px 0 0 0;
    text-align: center;
}

section#about .headof .ttl dt {
	padding: 0 0 10px 0;
	font-size: 100%;
	letter-spacing: 1;
}

section#about .headof .ttl dd {
	font-family:'PT Serif', serif;
	font-size: 200%;
}

section#about .headof .ttl dd a{
	color:#fff;
	text-decoration:none;
}

section#about .headof .ttl dd a:hover {
	text-decoration:none;
}

/*地図・写真(HEAD)*/
section#about .headof ul.tab {
	border: 2px solid #fff;
	border-radius:5px;
	margin: 50px 0 0 0;
	overflow: hidden;
}
 
section#about .headof ul.tab li {
	float: left;

	width: 50%;
	box-sizing: border-box;
	background:#8f82bc;
}

section#about .headof ul.tab li a:hover{
	text-decoration:none;
}


section#about .headof ul.tab li a {
	color:#fff;
	padding: 10px;
	display:block;
}

section#about .headof ul.tab li.active a{
    background:#fff;
    color: #8f82bc;
}

section#about .headof .content {
    width: 100%;
    height: 400px;
    margin: 50px auto 0;
}

section#about .headof #map_canvas {
	height:397px;
}

/*tokyo office*/
section#about .tokyoof {
	overflow:hidden;
	padding:0 0 80px 0;
}

section#about .tokyoof .ttl {
    float: right;
    width: 30%;
    background: #8f82bc;
    height:400px;
    padding: 5px;
    box-sizing: border-box;
    text-align: center;
}

section#about .tokyoof .ttl_inner {
	border:1px solid #fff;
	height:380px;
}

section#about .tokyoof .ttl p {
    font-size: 250%;
    color: #fff;
    letter-spacing: 1;
    padding: 100px 0 10px 0;
	font-family:'PT Serif', serif;
}

section#about .tokyoof .ttl p span {
    border: 1px solid #fff;
    width: 10%;
    display: block;
    margin: 30px auto;
}

section#about .tokyoof .ttl dl {
    color: #fff;
    margin: 20px 0 0 0;
    text-align: center;
}

section#about .tokyoof .ttl dt {
	padding: 0 0 10px 0;
	font-size: 100%;
	letter-spacing: 1;
}

section#about .tokyoof .ttl dd {
	font-family:'PT Serif', serif;
	font-size: 200%;
}

section#about .tokyoof .ttl dd a{
	color:#fff;
	text-decoration:none;
}

section#about .tokyoof .ttl dd a:hover {
	text-decoration:none;
}

/*地図・写真(TOKYO)*/
section#about .tokyoof ul.tab {
	border: 2px solid #fff;
	border-radius:5px;
	margin: 50px 0 0 0;
	overflow: hidden;
}
 
section#about .tokyoof ul.tab li {
	float: left;

	width: 50%;
	box-sizing: border-box;
	background:#8f82bc;
}

section#about .tokyoof ul.tab li a:hover{
	text-decoration:none;
}


section#about .tokyoof ul.tab li a {
	color:#fff;
	padding: 10px;
	display:block;
}

section#about .tokyoof ul.tab li.active a{
    background:#fff;
    color: #8f82bc;
}

section#about .tokyoof .content02 {
    width: 100%;
    height: 400px;
    margin: 50px auto 0;
}

section#about .tokyoof #map_canvas02 {
	height:397px;
}


section#about .corporateBox {
    overflow: hidden;
    width: 60%;
    float: left;
}

/*会社概要ロゴ*/
section#about .corporate_ttl {
    padding: 10px 0;
    border-bottom: 1px solid #f3f3f3;
    margin: 0 auto;
}


/*会社概要*/
section#about .corporate {
    padding: 20px 0 40px 0;
    font-size: 90%;
    width: 50%;
    float: left;
    box-sizing: border-box;
}

section#about .corporate span {
	display:block;
	padding:30px 0 5px 0;
	font-size:100%;
}

section#about .corporate dl {
	padding:0;
	line-height: 2;
	display: flex;
	justify-content: space-between;
}

section#about .corporate dt {
	/* padding:0 30px 0px 0; */
	width: 38%;
}

section#about .corporate dd{
	width: 60%;
	line-height:1.8em;
	vertical-align:middle;
}

/*JOURNAL
============================================*/
 .journalBox {
	width: 38%;
	float: right;
	margin:0 auto;
	overflow:hidden;
	border: 1px solid #ccc;
	box-sizing: border-box;
	padding: 3px;
}

 .journalBox_inner {
 border: 1px dotted #ccc;
 overflow: hidden;
 box-sizing: border-box;
 padding: 10px;
 position:relative;
 }

.journal_left {
	float:left;
	width: 50%;
}

.journal_right {
    float: right;
    width: 48%;
}


.journal_right p {
    background: #f3f3f3;
    padding: 15px;
    font-size: 110%;
    letter-spacing: 3px;
    font-weight: bold;
    font-family: 'PT Serif', serif;
}

.journal_right dt {
	font-weight:bold;
	line-height: 2em;
	font-family: 'PT Serif', serif;
	display: block;
	letter-spacing: 1.5px;
	font-size: 120%;
	padding: 10px 0 0 5px;
}

.journal_right dd {
    padding: 0 0 0 5px;
    line-height: 2em;
    font-family: 'PT Serif', serif;
    display: block;
    letter-spacing: 1.5px;
}

.journal_right .backnum {
    position: absolute;
    bottom: 3%;
    right: 3%;
}

.journal_right .backnum a {
    border: 1px solid #ccc;
    background: #fff;
    text-decoration: none;
    font-family: 'PT Serif', serif;
    padding: 15px 50px;
    width: 100%;
    display: block;
    text-align: center;
    box-sizing: border-box;
    margin: 0 auto;
    color: #666;
}

.journal_right .backnum a:hover {
	border:1px solid #999;
}

/*LIST
============================================*/
section#list {
	background:#fff;
	padding:0 0 50px 0;
	margin:0 0 50px 0;

}

section#list .mapBox {
    overflow: hidden;
    margin: 0 auto;
    background:#fff;
	width:90%;
}

section#list .mapBox span {
	text-align:center;
	display:block;
	font-size:90%;
	font-weight:bold;
	color:#998d71;
	padding: 0 0 30px 0;
	width: 69%;
	letter-spacing: 1px;
}

section#list .left_wrap {
	width: 70%;
	margin: auto;
	overflow: hidden;
}

section#list .left_wrap ul {
    width: 72%;
    float: left;
    margin: 0;
}

section#list .left_wrap li {
    display: inline-block;
    margin: 2px 2px 8px 2px;
}

section#list .mapBox .mapimg {
	width: 24%;
	margin: -5% 30px 0 0;
	float: right;
}

section#list .right_wrap {
    float: right;
    width: 27%;
    margin: 0;
}

section#list .right_wrap .cont_banner {
    width: 100%;
    margin: 0 0 30px 0;
    border: 1px dotted #ccc;
    padding: 3px;
    box-sizing: border-box;
}

/*RECRUIT
============================================*/
section#recruit {
    text-align: center;
    padding: 10px 0 50px 0;
    margin: 0 auto 50px;
}

section#recruit img.recr {
	width:90%;
}


/*ACTIVE
============================================*/
section#active {
    text-align: center;
    padding: 0 0 50px 0;
    margin: 0 auto 50px;
	overflow:hidden;
	position:relative;
}

section#active ul.activeBox {
    text-align: center;
	position:relative;
    width: 95%;
    overflow: hidden;
    margin: 0 auto;
    padding: 0 0 30px 0;
    border-bottom: 1px solid #f3f3f3;
}

section#active ul.activeBox li{
    display: inline-block;
	vertical-align: top;
    background: #f3f3f3;
    padding: 30px;
    margin: 0 50px;
}

section#active ul.activeBox li a {
	color:#333;
	outline:none;
}

section#active ul.activeBox li a:hover {
	text-decoration:none;
}

section#active ul.activeBox li a figure {
	
height: 350px;
	
overflow: hidden;
}

section#active ul.activeBox li a img {
	
width: 300px;
}

section#active ul.activeBox li dl {
	padding: 20px 0 0 0;
}


section#active ul.activeBox li dt {
	font-family:'PT Serif', serif;
	font-size: 80%;
	font-weight: bold;
	letter-spacing: 1px;
	padding: 0 0 5px 0;
}


section#active ul.activeBox li dd {
letter-spacing: 1px;
    font-weight: bold;
    color: #333;
    font-size: 0.8em;
}

section#active .detail {
    margin: 30px auto 0;
    padding: 0;

}

section#active .detail a {
	border: 1px solid #ccc;
	background: #fff;
	text-decoration:none;
	font-family: 'PT Serif', serif;
	padding: 15px;
	width: 12%;
	display: block;
	text-align: center;
	margin: 0 auto;
	color: #666;
}

section#active .detail a:hover {
	border:1px solid #999;
}


/*下部ABOUT SEO*/
.aboutcont {
	display:block;
	border-top: 1px solid #222;
	border-bottom: 1px solid #222;
	padding: 20px 0;
}

.aboutcont ul {
	display:flex;
}

.aboutcont div {
    padding: 0 0 30px 0;
}

.aboutcont p {
    font-style: italic;
    font-size: 130%;
    letter-spacing: 2px;
    font-family: 'PT Serif', serif;
    font-weight: bold;
    display: inline;
}

.aboutcont span {
    font-size: 90%;
    padding: 0 0 0 30px;
    letter-spacing: 1px;
    font-weight: bold;
}

.aboutcont li {
    font-size: 80%;
    width: 33%;
    display: inline-block;
    vertical-align: top;
    border-right: 1px solid #222;
    padding: 0 30px 0 0;
    box-sizing: border-box;
    line-height: 1.8em;
}

.aboutcont li:nth-child(2) {
	padding:0 30px;
}

.aboutcont li:last-child {
    border: none;
    padding: 0 0 0 30px;
}





/*++++++++++
aside
++++++++++*/

.rbunner {
	position: fixed;
	opacity:0;
	bottom: 0;
	height: auto;
	transition: .3s;
	z-index: 999;
	margin: 100px auto 0;
	max-width: 300px;
	width: auto;
	padding: 10px;
	border-left: none;
}

.rbunner.active {
	opacity: 1;
	transition: .3s;
}

.rbunner .close{
	background: #fff;
	position: absolute;
	right: 0;
	z-index: 10;
	width: 30px;
	height: 30px;
	border-radius: 100%;
	text-align: center;
	border: 2px solid #111;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: -3% auto 0;
	color: #111;
	cursor: pointer;
	font-weight: bold;
	transition: .3s;
}

.rbunner.active .close{ 
	transition: .3s;
}

aside.bunner.active {
	display: block;
}


aside.bunner a {
	display: block;
	width: 100% !important;
	background: none !important;
}aside.bunner a img:last-child{
    width: 100%;
}




@media screen and (max-width:1499px) {

section#news .detail a {
	width:25%;
}

/*BRAND
============================================*/
section#brand .brandBox {
    width: 90%;
    margin: 0 auto;
}

section#brand .brandBox ul {
	text-align:center;
}


/*RECRUIT
============================================*/
section#recruit {
	width:90%;
}


/*NEWS
============================================*/
section#news {
	overflow:hidden;
	margin:0 0 50px 0;
	position:relative;

}
/*一覧を見る*/
section#news .detail {
    clear: both;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    padding: 25px 0 0 0;
}

section#news .detail a {
	width: 26%;
}

section#news .detail a:hover {
	border:1px solid #999;
}


section#news .newsBox span {
    text-align: center;
    display: block;
    padding: 100px 0;
    font-size: 90%;
    letter-spacing: 1px;
}

section#news .newsBox li {
    width: 18%;
    margin: 0 15px 0 0;
}

section#news .newsBox li a {
	text-decoration:none;
}

section#news .newsBox li a img {
	vertical-align:bottom;
	padding: 1px 0 0 0;
}

section#news .newsBox li:last-child {
	margin:0;
}

section#news .newsBox li dl {
    padding: 0;
    text-align: left;
    width: auto;
    vertical-align:top;
    box-sizing: border-box;
    margin: 15px 0 0 0;
}

section#news .newsBox li dt {
    font-size: 95%;
    word-break: break-word;
    letter-spacing: 1px;
}

section#news .newsBox li dd {
    font-size: 80%;
}

section#news .newsBox p {
    font-size: 90%;
}

section#feature .featureBox .past a {
	width:26%;
}


/*マウスオーバー処理---------------------*/

section#news .newsBox li a.more {
	width:100%;
	height:auto;
	float:left;
	color:inherit;
}

section#news .newsBox li a.more:hover {
}

section#news .newsBox li a.more span {
	width: 0%;
    height: 2px;
    margin: 0 auto;
    background: #fff;
    position: absolute;
    top: 32%;
    z-index: 100;
    left: 45%;
}
/*--------------------------------------*/

section#feature {
	margin:0 0 50px 0;
	overflow:hidden;
}

section#feature .featureBox {
    width: auto;
    padding: 0 0 30px 0;
}

section#feature .featureBox a {

	display:block;
}

section#feature .featureBox li {
	margin:0 10px 20px 0;
}

section#feature .featureBox li:nth-child(3n) {
	margin: 0 0 20px 0;
}

section#feature .featureBox li  span {
	font-size:80%;
}





section#about .tokyoof {
	padding:0;
}


section#list .mapBox {
	padding:0;
}

/*ACTIVE
============================================*/
section#active ul.activeBox {
    width: 90%;
}

section#active ul.activeBox li{
    padding: 10px;
    margin: 0 10px;
}

section#active ul.activeBox li a figure {
	
height: 300px;
}

section#active ul.activeBox li dl {
	padding:10px 0 0 0;
}


section#active .detail {
    margin: 30px auto 0;
    padding: 0;

}

section#active .detail a {
    width: 26%;
}

section#active .detail a:hover {
	border:1px solid #999;
}


/*ABOUT
============================================*/
section#about .corporateBox {
    width: 100%;
    float: none;
    padding: 0 20px;
    box-sizing: border-box;
    margin: 0 auto;
}

.journalBox {
    width: 80%;
	float:none;
    margin: 0 auto;
    padding: 3px;
}

.journal_right .backnum a {
    padding: 15px 80px;
}


/*LIST
============================================*/
section#list {
	background:#fff;
	padding:0 0 50px 0;
	margin:0 0 50px 0;
}

section#list .mapBox {
    width: 93%;
}

section#list .mapBox span {
	padding: 0 0 10px 0;
}

section#list .left_wrap {width: 90%;}

section#list .left_wrap ul {
    margin: 0;
}

section#list .left_wrap li {
    width: 23%;
    margin: 2px;
}

section#list .mapBox .mapimg {
	/* display:none; */
}

section#list .right_wrap {
    margin: 0;
}

section#list .right_wrap .cont_banner {
    width: 100%;
    margin: 0;
}

section#about .headof .content {
	height:300px;
}


section#about .headof #map_canvas {
	height:300px;
}

section#about .headof .ttl_inner {
	height: 285px;
	padding:0;
}

section#about .headof .ttl {
	padding: 5px;
	height:300px;
}


section#about .headof .ttl p {
	font-size:150%;
	padding:80px 0 10px 0;
}

section#about .headof .ttl dd {
	font-size:120%;

}

section#about .tokyoof .content02 {
	height:300px;
}

section#about .tokyoof #map_canvas02 {
	height:300px;
}

section#about .tokyoof .ttl {
	height:300px;
}


section#about .tokyoof .ttl p {
	font-size:150%;
	padding:80px 0 10px 0;
}

section#about .tokyoof .ttl dd {
	font-size:120%;
}

section#about .tokyoof .ttl_inner {
	height:280px;
}


/*下部ABOUT SEO*/
.aboutcont {
	padding: 30px 0 20px 0;
	box-sizing: border-box;
}

.aboutcont div {
    padding: 0 0 30px 0;
}

.aboutcont p {
    display: block;
    padding: 0 0 5px 0;
    font-size: 110%;
}

.aboutcont span {
    font-size: 75%;
    padding: 0;
    letter-spacing: inherit;
}


.aboutcont li {
    font-size: 70%;
    width: 32%;
    padding: 0 20px 0 0;
}

.aboutcont li:nth-child(2) {
	padding: 0 20px;
}

.aboutcont li:last-child {
    padding: 0 0 0 20px;
}


}

@media screen and (max-width:1023px) {

/*MAIN
============================================*/

.mainTtl {
    position:fixed;
    top: 40%;
    left: 15%;
    z-index: 10000;
    margin: 0 20px;
}

.mainTtl img{
	width:80%;
}

#main {
    width: 100%;
    height: 100%;
    background: url(../imgs/main.jpg) no-repeat center #fff;
    position: fixed;
    background-size: cover;
    z-index: 1000;
    top: 0;
    display: none; 
}

	
/*SLIDE
============================================*/
#slide {
    padding: 100px 0 50px 0;
}	


/*NEWS
============================================*/
section#news {
	overflow:hidden;
	margin:0 0 50px 0;
	position:relative;

}
/*一覧を見る*/
section#news .detail {
    clear: both;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    padding: 25px 0 0 0;
}

section#news .detail a {
	width: 40%;
}

section#news .detail a:hover {
	border:1px solid #999;
}

section#news .newsBox {
	overflow:hidden;
	padding:0 0 30px 0;
	width: 90%;
	margin: auto;
}


section#news .newsBox span {
    text-align: center;
    display: block;
    padding: 100px 0;
    font-size: 90%;
    letter-spacing: 1px;
}

section#news .newsBox li {
	width: auto;
	display: block;
	margin: 0 0 20px 0;
	border-bottom: 1px dotted #ccc;
	padding: 0;
}

section#news .newsBox li a {
	text-decoration:none;
}

section#news .newsBox li a img {
	vertical-align:bottom;
	padding: 1px 0 0 0;
	float: left;
	width: 30%;
}

section#news .newsBox li:last-child {
	margin:0;
}

section#news .newsBox li dl {float: right;width: 68%;}

section#news .newsBox li dt {
    font-size: 110%;
    letter-spacing: 1px;
}

section#news .newsBox li dd {
    font-size: 90%;
}

section#news .newsBox p {
    float: right;
    font-size: 90%;
}

/*マウスオーバー処理---------------------*/

section#news .newsBox li a.more {
	width:100%;
	height:auto;
	float:left;
	color:inherit;
}

section#news .newsBox li a.more:hover {
	text-decoration:none;
}

section#news .newsBox li a.more span {
	width: 0%;
    height: 2px;
    margin: 0 auto;
    background: #fff;
    position: absolute;
    top: 32%;
    z-index: 100;
    left: 45%;
}
/*--------------------------------------*/


section#feature {
	margin:0 0 50px 0;
	overflow:hidden;
}

section#feature .featureBox {
    width: auto;
    padding: 0 0 30px 0;
}


section#feature .featureBox li {
	margin: 0 auto 30px;
	width: 80%;
	display: block;
}

section#feature .featureBox li:nth-child(3n) {
	margin: 0 auto 30px;
}


section#feature .featureBox li  span {
	font-size:80%;
}

section#feature .featureBox .past a {
	width:40%;
}

/*BRAND
============================================*/
section#brand {
	margin:0 0 50px 0;
}

section#brand .brandBox {
	width:auto;
}

section#brand .brandBox li {
    width: 48.8%;
    margin: 0 10px 20px 0;
}

section#brand .brandBox li:nth-child(2n) {
	margin:0;
}

section#brand .brandBox li a img {
	width:100%;
}

section#brand .brandBox li dl {
}


/*ABOUT
============================================*/
section#about {
	width:auto;
	margin:0 0 50px 0;
}

section#about .aboutBox {
	width:auto;
}

section#about .corporateBox {
	width:auto;
}

.journalBox {
	width:auto;
}

section#about .headof .ttl {
    float: none;
    width: 100%;
    height: auto;
    padding: 5px;
}

section#about .headof .ttl p {
	padding:0;
}

section#about .headof .ttl dl {
	
margin: 10px 0 0 0;
}


section#about .headof .content {
	width:100%;
	float:none;
}

section#about .headof #map_canvas {
    height: 400px;
}

section#about .tokyoof .ttl {
    float: none;
    width: 100%;
    height: auto;
}

section#about .tokyoof .ttl p {
	padding:0;
}

section#about .tokyoof .ttl dl {
	
margin: 10px 0 0 0;
}

section#about .tokyoof .content02 {
	width:100%;
	float:none;
}
section#about .tokyoof #map_canvas02 {
    height: 400px;
}

section#about .corporate {
	width:auto;
	float:none;
	padding: 20px 0;
}

/*LIST
============================================*/
section#list {
	padding: 0 0 30px 0;
	margin:0 0 50px 0;
}

section#list .mapBox {
    overflow: hidden;
    margin: 0 auto;
    background:#fff;
	width:auto;
}

section#list .mapBox span {
	text-align:center;
	display:block;
	font-size:90%;
	font-weight:bold;
	color:#998d71;
	padding: 0 0 30px 0;
	width: auto;
}

section#list .left_wrap {
	width: auto;
	margin: 0 0 30px 0;
	padding: 0 0 30px 0;
	border: none;
	border-bottom: 1px dotted #ccc;
}

section#list .left_wrap ul {
    width: 100%;
    float: none;
    margin: 0 50px 0 0;
}

section#list .left_wrap li {
    width: 23.9%;
}

section#list .mapBox .mapimg {
	display:none;
}

section#list .right_wrap {
    clear: both;
    float: none;
    width: 50%;
    margin: auto;
}

section#list .right_wrap .cont_banner {
}

section#about .headof .ttl dd {
	font-size:130%;
}

section#about .tokyoof .ttl dd {
	font-size:130%;
}

section#about .headof .ttl_inner {
	padding: 15px 10px 15px;
	height:auto;
}

section#about .tokyoof .ttl_inner {
	height:auto;
	padding: 15px 10px 15px;
}

/*ACTIVE
============================================*/

section#active ul.activeBox {
	width:auto;
}

/*RECRUIT
============================================*/
section#recruit {
	width:auto;
	margin:0 0 50px 0;
}

/*下部ABOUT SEO*/
.aboutcont {
	padding: 20px 0;
	margin: 50px 0 0 0;
}

.aboutcont div {
    padding: 0 0 20px 0;
}

.aboutcont p {
    display: block;
    text-align: center;
}

.aboutcont span {
    padding: 0;
    font-size: 70%;
}

.aboutcont li {
    width: 33%;
    padding: 0 10px 0 0;
}

.aboutcont li:nth-child(2) {
	padding: 0 10px;
}

.aboutcont li:last-child {
    padding: 0 0 0 10px;
}


}




@media screen and (max-width:767px){
	
/*MAIN
============================================*/

.mainTtl {
    left: 0;
}

.mainTtl img{
	width:100%;
}
	
	
/*SLIDE
============================================*/
#slide {
    padding: 100px 0 0 0;
}	

/*NEWS
============================================*/
section#news {
	overflow:hidden;
	margin:0 0 50px 0;
	position:relative;

}
/*一覧を見る*/
section#news .detail {
    clear: both;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    padding: 25px 0 0 0;
}

section#news .detail a {
width: 70%;
    padding: 10px 0;
}


section#news .newsBox {
	width:auto;
}


section#news .newsBox span {
    text-align: center;
    display: block;
    padding: 100px 0;
    font-size: 90%;
    letter-spacing: 1px;
}

section#news .newsBox li {
	width: auto;
	display: block;
	margin: 0 0 20px 0;
	border-bottom: 1px dotted #ccc;
	padding: 0;
}

section#news .newsBox li a {
	text-decoration:none;
}


section#news .newsBox li:last-child {
	margin:0;
}

section#news .newsBox li dl {
	width: 67%;
	margin:0;
}

section#news .newsBox li dt {
    font-size: 90%;
    letter-spacing: 1px;
}

section#news .newsBox li dd {
    font-size: 75%;
	line-height:1.8em;
	margin:0;
}

section#news .newsBox p {
    float: right;
    font-size: 90%;
	width:100%;
	padding:20px 0 10px 0;
}

/*マウスオーバー処理---------------------*/

section#news .newsBox li a.more {
	width:100%;
	height:auto;
	float:left;
	color:inherit;
}


section#news .newsBox li a.more:hover {
}

section#news .newsBox li a.more span {
	width: 0%;
    height: 2px;
    margin: 0 auto;
    background: #fff;
    position: absolute;
    top: 32%;
    z-index: 100;
    left: 45%;
}
/*--------------------------------------*/
section#feature {
	margin:0 0 50px 0;
	overflow:hidden;
}


section#feature .featureBox li {
	width: auto;
	margin:0 auto 10px;
}


section#feature .featureBox .past a {
	width:40%;
}

/*特集バックナンバー*/
section#feature .featureBox .past {
    margin:10px 0;
}

section#feature .featureBox .past a {
    padding: 10px 0;
    width: 70%;
    margin: 10px auto 0;
}

/*BRAND
============================================*/
section#brand {
	margin:0 0 50px 0;
	padding:0;
}

section#brand .brandBox ul {
	display:block;
}
section#brand .brandBox li {
	width:100%;
	margin:0 0 20px 0;
}

section#brand .brandBox li a img {
	width:100%;
}

/*ABOUT
============================================*/
section#about {
	width:auto;
	margin:0 0 50px 0;
	padding:0;
}

section#about .headof .content {
	height:auto;
}

section#about .headof .ttl {
    float: none;
    width: 100%;
    height: 100px;
    padding: 5px;
    font-size: 90%;
    text-align: center;
}

section#about .headof .ttl_inner {
	height:87px;
}

section#about .headof .ttl p {
	padding: 10px 0 5px 0;
	font-size: 130%;
}

section#about .headof .ttl dl {
	margin:0;
}

section#about .headof .ttl dt {
	padding:0;
	font-size:80%;
}

section#about .headof #map_canvas {
    width: 100%;
    height: 150px;
    float: none;
}

section#about .tokyoof .content02 {
	height:auto;
}

section#about .tokyoof .ttl {
    float: none;
    width: 100%;
    height: 100px;
	padding: 5px;
    box-sizing: border-box;
	text-align:center;
	font-size:90%;
}

section#about .tokyoof .ttl_inner {
	height:87px;
}

section#about .tokyoof .ttl p {
	padding: 10px 0 5px 0;
	font-size: 130%;
}

section#about .tokyoof .ttl dl {
	margin:0;
}

section#about .tokyoof .ttl dt {
	padding:0;
	font-size:80%;
}


section#about .tokyoof #map_canvas02 {
    width: 100%;
    height: 150px;
    float: none;
}

section#about .corporateBox {
    width: 100%;
    float: none;
	padding:0;
}

/*会社概要ロゴ*/
section#about .corporate_ttl {
    padding: 10px 0;
    border-bottom: 1px solid #f3f3f3;
    margin: 0 auto;
}


/*会社概要*/
section#about .corporate {
    padding: 20px 0;
    font-size: 80%;
    width: 100%;
    float: none;
    box-sizing: border-box;
}

section#about .corporate span {
	display:block;
	padding:30px 0 5px 0;
	font-size:100%;
}

section#about .corporate dl {
	padding:0;
}

section#about .corporate dt {
	padding: 0 10px 0 0;
	width: 40%;
}

section#about .corporate dd{
	line-height:1.8em;
	vertical-align:middle;
}

/*JOURNAL
============================================*/
 .journalBox {
	width: 100%;
	float: none;
	margin:0 auto;
	overflow:hidden;
	border: 1px solid #ccc;
	box-sizing: border-box;
	padding: 3px;
}

 .journalBox_inner {
 border: 1px dotted #ccc;
 overflow: hidden;
 box-sizing: border-box;
 padding: 10px;
 position:relative;
 }

.journal_left {
	float: none;
	width: 100%;
}

.journal_right {
    float: none;
    width: 100%;
	padding:20px 0 0 0;
}


.journal_right p {
padding: 10px;
    font-size: 90%;
    text-align: center;
}

.journal_right dt {
	font-size: 100%;
	padding: 10px 0 0 0;
}

.journal_right dd {
    padding: 0 0 30px 0;
    display: block;
    font-size: 80%;
}

.journal_right .backnum {
    position: inherit;
    bottom: inherit;
    right: inherit;
}

.journal_right .backnum a {
    border: 1px solid #ccc;
    background: #fff;
    text-decoration: none;
    font-family: 'PT Serif', serif;
    padding: 15px 50px;
    width: 100%;
    display: block;
    text-align: center;
    box-sizing: border-box;
    margin: 0 auto;
    color: #666;
}

.journal_right .backnum a:hover {
	border:1px solid #999;
}

/*LIST
============================================*/
section#list {
	background:#fff;
	padding:10px 0 0 0;
	margin:0 0 50px 0;
}

section#list .mapBox {
    overflow: hidden;
    margin: 0 auto;
    background:#fff;
}

section#list .mapBox span {
	text-align:center;
	display:block;
	font-size:90%;
	font-weight:bold;
	color:#998d71;
	padding: 0 0 30px 0;
}

section#list .left_wrap {
    width: 100%;
    float: none;
    margin: 0 50px 0 0;
}

section#list .left_wrap ul {
    width: 100%;
    float: none;
    margin: 0 50px 0 0;
}

section#list .left_wrap li {
    display: inline-block;
    margin: 5px 8px 5px 0;
    width: 47%;
}

section#list .left_wrap li:nth-child(2n) {
	margin:5px 0;
}

section#list .left_wrap li img {
	width:100%;
}

section#list .mapBox .mapimg {
	display:none;
}

section#list .right_wrap {
    float: none;
    width: 95%;
    padding: 20px 0;
    margin: 0 auto;
}

section#list .right_wrap .cont_banner {
    width: 100%;
    margin: 0 0 30px 0;
    border: 1px dotted #ccc;
    padding: 3px 3px 0 3px;
    box-sizing: border-box;
}

section#list .right_wrap .cont_banner img {
	width:100%;
}

section#about .headof .ttl dd {
	font-size:130%;
}

section#about .tokyoof .ttl dd {
	font-size:130%;
}



/*RECRUIT
============================================*/

section#recruit img.recr {
	width:auto;
}

/*ACITVE
============================================*/
section#active ul.activeBox li{
    padding: 20px 0 15px 0;
    margin: 0;
}

section#active .detail a {
    width: 70%;
    padding: 10px 0;
}


/*下部ABOUT SEO*/
.aboutcont {
	display:none;
}


.rbunner {
	height: auto;
    bottom:0px;
    width: 100%;
    max-width: 200px;

}
	
	.rbunner a {
		padding: 0;
	}		
	
}