@charset "utf-8";

/***********************************************************************************************************************
* 横サイズ925px以下
***********************************************************************************************************************/
@media screen and (max-width: 925px){

		#nav> ul>li>a::after,
		#nav> ul>li.open>a::after{
			display: none !important;
		}


/***********************************************************************************************************************
* 基本構造
***********************************************************************************************************************/
	body{
		font-size: 1.4rem;
	}

	.pc{ display:none !important; }
	.sp{ display: block !important; }


	a[href^="tel:"] {
	    pointer-events: all;
	}

	.wrap{
		padding: 0 6%;
	}


	.top-main-contents, .main-contents {
	    padding-bottom: 46px;
	}

	#all-wrap{
		overflow: visible;
	}


	header {
		display: block;
	    height: 75px;
	}

	header .logo {
	    width: auto;
	}
		header .logo  a{
			margin-top: 17px;
			padding-top: 0;
		}
		header .logo img{
			max-width: 171px;
			margin-top: 2px;
		}
			header .logo a>span{
				font-size: 1.1rem;
			}

	header #nav{
		position: absolute;
		top:60px;
		display:none ;
		opacity: 0;
		width: 100%;
		margin:0;
		padding: 0 5%;
	    overflow: auto;
		-webkit-overflow-scrolling: touch;
		-webkit-transition: all 0.3s ease;
	    -moz-transition: all 0.3s ease;
	    -ms-transition: all 0.3s ease;
	    -o-transition: all 0.3s ease;
	    transition: all 0.3s ease;
	    background: #fff;
	}

	body header #nav.block {
		display: block;
		opacity: 0;
	}

	body header #nav.block.active {
		opacity: 1;
	}


	.ch-wrap {
		position: static;
	    width: 100%;
	    padding: 0;
	    display: block !important;/*test*/
	    opacity: 1!important; 
	}

	#nav > ul {
	    margin: 0 auto;
	    display: block;
	}
		#nav > ul > li {
		    margin-right: 0;
		}
		#nav > ul >li> a{
			position: relative;
			height: auto;
    		line-height: 1em;
			padding: 1.45em 1em;
			font-size: 1.5rem;
		    display: block;
		    text-align: left;
		    border-bottom:1px solid #b5b5b5;
		}
			#nav> ul>li a::after{
				display: none;
			}

			a>span.arw{
				display: block;
				position: absolute;
				height: 1px;
				width: 29px;
				right:20px;
				top:50%;
				background: #313131;
			}
			a>span.arw::after{
				content:"";
				position: absolute;
				display: block;
				margin-top: 0px;
				bottom:0;
				right:0;
				width: 0;
				height: 0;
				border-style: solid;
				border-width: 7px 0 0 7px;
				border-color: transparent transparent transparent #313131;
			}

	#nav .ch-wrap {
		position: static;
	    width: 100%;
	    padding: 0;
	    display: block !important;
	    opacity: 1!important; 
	}

	#nav .ch-wrap .ch-inr .case-block {
	    padding-top: 10px;
	    max-width: 400px;
	    margin: 0 auto;
	}

	#nav .ch-wrap .ch-inr .case-block>.case-box {
	    padding-top: 0px;
	    display: block;
	}
	#nav .ch-wrap {
		position: static;
	    padding: 10px 0;
	    border-bottom: 1px solid #b5b5b5;
	}

	#nav .ch-wrap .ch-inr {
	    margin: 0 auto;
	    padding: 0;
	}


	#nav .ch-wrap .ch-inr .case-block>.case-box {
	}



	#nav .ch-wrap .ch-inr .case-block>.case-box>.group1 ,
	#nav .ch-wrap .ch-inr .case-block>.case-box>.group2 {
	    width: 100%;
	    margin-right: 0;
	    margin-bottom: 0px;
	}


	#nav .ch-wrap .ch-inr .case-block>.case-box>.group1 .case-list>li {
	    width: 45%;
	    margin-right: 10%;
	    margin-bottom: 20px;
	}
	#nav .ch-wrap .ch-inr .case-block>.case-box>.group2 .case-list{
		flex-wrap:wrap;
		-webkit-flex-wrap:wrap;
	}

	#nav .ch-wrap .ch-inr .case-block>.case-box>.group2 .case-list>li:nth-child(3n), 
	#nav .ch-wrap .ch-inr .case-block>.case-box>.group2 .case-list>li {
    width: 45%;
    margin-right: 10%;
    margin-bottom: 20px;
}
	#nav .ch-wrap .ch-inr .case-block>.case-box>.group2 .case-list>li:nth-child(2n){
	    margin-right: 0;
	}

	#nav .ch-wrap .ch-inr .case-block p {
	    font-size: 1.4rem;
	    margin-bottom: 18px;
	    padding-left: 1.6em;
	}

	#nav .ch-wrap .ch-inr .ch-menu {
	    display: block;
	}
	#nav .ch-wrap .ch-inr .ch-menu>li {
		width: 100%;
		border:none;
	}

	#nav .ch-wrap .ch-inr .ch-menu>li>a {
		position: relative;
	    font-size: 1.5rem;
	    max-width:unset;
	    height: auto;
	    line-height: 1em;
	    padding: 1em 2em ;
	    text-align: left;
	}
	#nav .ch-wrap .ch-inr .ch-menu>li>a>span{
		transform: scale(0.8,0.8)
	}

	.tobihito .title {
		text-align: center;
	    margin: 30px auto 0;
	}
	.tobihito .title img {
	    width: 69%;
	}


.case .section-movie .movie-btn {
    position: relative;
    -webkit-border-radius: 2em;
    border-radius: 2em;
    font-size: 1.8rem;
    text-align: center;
    background: #31913c;
    max-width:250px;
    height: 53px;
    line-height: 53px;
    display: block;
    margin: 0 auto;
    font-weight: bold;
    color: #fff;
}

	.tobihito {
		display: none;
	}

	.tobihito .ch-wrap {
		position: static;
	    width: 100%;
	    padding: 0;
	    display: block !important;
	    opacity: 1!important; 
	}

	.tobihito .ch-wrap .ch-inr .case-block {
	    padding-top: 10px;
	    max-width: 400px;
	    margin: 0 auto;
	}

	.tobihito .ch-wrap .ch-inr .case-block>.case-box {
	    padding-top: 0px;
	    display: block;
	}

	.tobihito .ch-wrap {
	    position: static;
	    padding: 10px 6%;
	}

	.tobihito .ch-wrap .ch-inr {
	    margin: 0 auto;
	    padding: 0;
	}


	.tobihito .ch-wrap .ch-inr .case-block>.case-box {
	}



	.tobihito .ch-wrap .ch-inr .case-block>.case-box>.group1 ,
	.tobihito .ch-wrap .ch-inr .case-block>.case-box>.group2 {
	    width: 100%;
	    margin-right: 0;
	    margin-bottom: 0px;
	}


	.tobihito .ch-wrap .ch-inr .case-block>.case-box>.group1 .case-list>li {
	    width: 45%;
	    margin-right: 10%;
	    margin-bottom: 20px;
	}
	.tobihito .ch-wrap .ch-inr .case-block>.case-box>.group2 .case-list{
		flex-wrap:wrap;
		-webkit-flex-wrap:wrap;
	}

	.tobihito .ch-wrap .ch-inr .case-block>.case-box>.group2 .case-list>li:nth-child(3n), 
	.tobihito .ch-wrap .ch-inr .case-block>.case-box>.group2 .case-list>li {
    width: 45%;
    margin-right: 10%;
    margin-bottom: 20px;
}
	.tobihito .ch-wrap .ch-inr .case-block>.case-box>.group2 .case-list>li:nth-child(2n){
	    margin-right: 0;
	}

	.tobihito .ch-wrap .ch-inr .case-block p {
	    font-size: 1.4rem;
	    margin-bottom: 16px;
	    padding-left: 1em;
	}

	.tobihito .ch-wrap .ch-inr .ch-menu {
	    display: block;
	}
	.tobihito .ch-wrap .ch-inr .ch-menu>li {
		width: 100%;
		border:none;
	}

	.tobihito .ch-wrap .ch-inr .ch-menu>li>a {
		position: relative;
	    font-size: 1.5rem;
	    max-width:unset;
	    height: auto;
	    line-height: 1em;
	    padding: 1em 2em ;
	    text-align: left;
	}
	.tobihito .ch-wrap .ch-inr .ch-menu>li>a>span{
		transform: scale(0.8,0.8)
	}

	.corp {
		padding:25px 0;
		text-align: center;
	}

	.corp a{
		font-size: 1.6rem;
		display: inline-block;
		background: url(../img/ico-enter.jpg) 100% center no-repeat;
		padding-right: 20px;
	}
	.close{
		text-align: center;
		padding:15px 0 50px;
	}

body header #menu-button {
    position: absolute;
    display: block;
    right: 0;
    top: 0;
    width: 65px;
    height: 65px;
    cursor: pointer;
    z-index: 10;
    margin-top: 0;
}


		body header #menu-button>div{
			width: 30px;
			height: 1px;
			background: #1b1b1b;
			position: absolute;
			-webkit-transition: all .5s;
			   -moz-transition: all .5s;
			    -ms-transition: all .5s;
			     -o-transition: all .5s;
			        transition: all .5s;
		}
			body header.on #menu-button>div{
				background: #1b1b1b;
			}

			body header.block #menu-button>div {
			    background: #1b1b1b;
			}

		body header #menu-button>div:nth-child(1){
			top: 35%;
			left: 29%;
			-webkit-transform: translate(0%,0%);
			   -moz-transform: translate(0%,0%);
			    -ms-transform: translate(0%,0%);
			     -o-transform: translate(0%,0%);
			        transform: translate(0%,0%);
		}

		body header #menu-button.active>div{
			height: 1px;
		}

			body header #menu-button.active>div:nth-child(1) {
				top: 50%;
				left: 29%;
				-webkit-transform: translate(-5%,-50%) rotate(45deg);
				   -moz-transform: translate(-5%,-50%) rotate(45deg);
				    -ms-transform: translate(-5%,-50%) rotate(45deg);
				     -o-transform: translate(-5%,-50%) rotate(45deg);
				        transform: translate(-5%,-50%) rotate(45deg);
			}
		body header #menu-button>div:nth-child(2){
			top: 50%;
			left: 29%;
		}
			body header #menu-button.active>div:nth-child(2) {
				opacity: 0;
			}
		body header #menu-button>div:nth-child(3){
		    top: 65%;
		    left: 29%;
			-webkit-transform: translate(0%,0%);
			   -moz-transform: translate(0%,0%);
			    -ms-transform: translate(0%,0%);
			     -o-transform: translate(0%,0%);
			        transform: translate(0%,0%);
		}
			body header #menu-button.active>div:nth-child(3) {
				top: 50%;
				left: 29%;
				-webkit-transform: translate(-5%,-50%) rotate(-45deg);
				   -moz-transform: translate(-5%,-50%) rotate(-45deg);
				    -ms-transform: translate(-5%,-50%) rotate(-45deg);
				     -o-transform: translate(-5%,-50%) rotate(-45deg);
				        transform: translate(-5%,-50%) rotate(-45deg);
			}


footer .ft-block{
	display: block;
	text-align: center;
}

footer .logo-box {
	display: inline-block;
    padding: 30px 20;
    -webkit-flex-grow: 3;
    flex-grow: 3;
    text-align: center;
}

footer .logo-box img{
	display: inline-block;
	margin-left: 1em;
	margin-bottom: 10px;
}
footer .logo-box p{
	display: block;
	color:#3c3c3c;
	padding-left: 0px;
	text-align: center;
	font-weight: bold;
	font-family: Verdana, Geneva, "sans-serif";
}

	
footer .menu-box {
	width: 100%;
	display: none;
}

footer .apply-box{
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
}
footer .apply-box >a{
	width: 50%;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	align-items: center;
	justify-content: center;
	height: auto;
	padding: 35px 0;
	color:#fff;
	font-weight: bold;
	font-size: 2rem;

}
footer .apply-box >.rec{
	background: #6a1684;

}

footer .apply-box >.ent{
	background: #af61a2;
}

footer .logo-box {
    padding: 20px 40px;
}
footer .logo-box img{
	display:block;
	margin:0 auto 10px;
}

footer .logo-box p{
	display: inline-block;
	text-align: center;
	font-size: 18px;
}



#pagetop {
    position: absolute;
    display: block;
    height: 50px;
    width: 50px;
    top: -50px;
    right: 0px;
    cursor: pointer;
}
#pagetop::after {
    top: 44%;
    right: 14px;
}


.main-visual{
	position: relative;
}
.main-visual .txt-layer{
	position: absolute;
	top:auto;
	bottom:0;
	height: auto;
}

.main-visual .txt-layer .inr{
	position: relative;
	padding-left: 6.25%;
	padding-top: 4.8%;
}

.main-visual .txt-layer .inr .ttl{
	max-width: 388px;
	width: 60%;
	margin-left: -15px;
	margin-bottom: 10px;


}
.main-visual .txt-layer .inr .txt{
	width: 90%;
	margin-bottom: 20px;
}

.main-visual .txt-layer .name{
	position: static;
	max-width: unset;
	width: 100%;
	text-align: right;
	padding-right: 6%;
	margin-bottom: 35px;
}
.main-visual .txt-layer .name img{
	width: 43%;
}

.two-row-block1{}
	.two-row-block1> .img-box{
		width: 50%;
		padding-right: 40px;
	}

	.two-row-block1> .txt-box{
		width: 50%;
		padding-left: 25px;
	}

.two-img-block1{}
.two-img-block1>.img-box{
	width: 48%;
	margin-right: 4%;
}

.two-img-block1>.img-box:nth-child(2){
	margin-right: 0;
}


.three-img-block1{
	display: block;
	width: 100%;
}

.three-img-block1>.row{
	width: 100%;
	margin-right: 0%;
	margin-bottom: 10px;
}
.three-img-block1>.row:nth-child(2){
}
.three-img-block1>.row .col:nth-child(1){
	margin-bottom: 10px;
}


/***********************************************************************************************************************
* パーツ parts
***********************************************************************************************************************/
/*見出し*/
.headline-lg{
	font-size:2.2rem;
	margin-bottom: 25px;
}

.headline-m {
    text-align: center;
    font-size: 1.9rem;
    margin-bottom: 20px;
}


.btn-a.type2 {
    max-width: 280px;
    font-size: 1.7rem;
}

.btn-a::before,
.btn-a::after{
    right: 20px;
}

.two-row-block1{
	max-width: 600px;
	margin:0 auto;
	display: block;
}
	.two-row-block1> .img-box{
		width: 100%;
		padding-right: 0;
	}
	.two-row-block1> .txt-box{
		width: 100%;
		padding-left: 0;
		margin-bottom: 20px;
	}

.two-img-block1{
	max-width: 600px;
	margin:0 auto;
	display: block;
}
.two-img-block1>.img-box{
	width: 100%;
	margin-right: 0;
	margin-bottom: 20px;
}

.two-img-block1>.img-box:nth-child(2){
	margin-right: 0;
}

.txt-wide-block{
	margin-bottom: 20px;
}




.txt-img-block1 {
   display: block;
}

.txt-img-block1 .img-box{
   width: 100%;
   padding-left: 0;
}
.txt-img-block1 .txt-box{
	padding-right: 0;
	width: 100%;
	margin-bottom: 20px;
}


.section-movie {
    position: relative;
    margin-top: 52px;
    padding: 40px 20px 18px;
}

.case .section-movie {
    position: relative;
    margin-top: 52px;
    padding: 63px 20px 18px;
}
/************************************************************
* トップページ
*************************************************************/

.main,
.top-main{
	padding-top: 60px;
	padding-bottom: 30px;
}

.top-visual  .copy-layer {
    left: 4%;
    width: 90%;
    bottom: 20px;
}





.top-news {
	background: #cf3c56;
	padding: 5px 10px;
	color:#fff;
}
.top-news .news-block{
	width: 100%;
	display: block;
}
.top-news .news-block .head-box{
	width: 100%;
	padding: 0;
	height: 43px;
	padding-top: 10px;
	border-bottom: 1px solid #ffafbd ;
}



.top-news .news-block .news-box{
	width: 100%;
}

.top-news .news-block .news-box article {
    padding-left: 5%;
    padding-top: 16px;
    padding-bottom: 16px;
   	border-bottom: 1px solid #ffafbd;

}
.top-news .news-block .news-box article>time{
	font-size: 1.4rem;
}
.top-news .news-block .news-box article>p{
	padding:0 5%;
	font-size: 1.4rem;
}

.top-news .news-block .btn-box{
	border-left: 1px solid #cf3c56;
}
.top-news .news-block .head-box{
	border-left: 1px solid #cf3c56;
}





.top-news .news-block .btn-box>a {
    width: 100%;
}

.top-main-contents{
	margin: 0 auto;
	padding-bottom: 30px;
}



.section-group1{
	margin:50px 0 0;
	position: relative;
	display: block;
}
.section-group1 .txt-box .inr {
    max-width: uset;
    padding-top: 30px;
}

.section-group1 .txt-box,
.section-group1.revs .txt-box {
    padding-right: 5%;
    padding-left: 5%;
}

.section-group1 .img-box{
	position: static;
	bottom:0px;
	width: 100%;
}
.section-group1 .img-box img{
	width: 100%;
	max-width: unset;
}

.section-group1.revs{
	text-align: center;
}
.section-group1.revs .img-box{
	position: static;
}

.section-group1 .txt-box{
    padding-top: 10px;
    padding-bottom: 50px;
	text-align: right;
    min-height: unset;
}

.section-group1 .btn-area,
.section-group1.revs .btn-area{
	text-align: center;
}

.section-group1 .txt-box .inr,
.section-group1.revs .txt-box .inr {
    max-width: 315px;
    padding-top: 28px;
    display: block;
    text-align: left;
    margin: 0 auto;
}

.section-group1 .txt-box .title{
	margin-bottom: 30px;
}

.section-group1 .txt-box p {
    margin-bottom: 30px;
}



.section-group2{
	position: relative;
	margin:0 auto;
	z-index: 1;
}
	.section-group2 .img-block{
		width:100%;
		position: relative;
		z-index: 2;
		color:#fff;
	}

.section-group2 .conts-block {
    width: 100%;
    max-width: 700px;
    margin: -8% auto 0;
    padding: 0 5%;
    background: transparent;
}

.section-group2 .inr-block {
    max-width: unset;
    display: block;
    max-width: 600px;
    margin: 0 auto;
    padding: 40px;
    background: #6a1684;
}

		.section-group2 .inr-block .head-box{
			width: 100%;
			margin-bottom: 30px;
		}
		.section-group2 .inr-block .txt-box {
		    width: 100%;
		    text-align: center;
		}


		.section-group2 .inr-block p {
	    margin-bottom: 20px;
	    font-size: 1.4rem;
	}


.top-m-isum{
	color:#fff;
}

.top-whats {
    padding-top: 50px;
}

.top-whats .top-case {
    max-width: 600px;
    padding: 0 9%;
    margin: 40px auto -40px;
    flex-wrap: wrap;
}

.top-whats .top-case .box{
	width: 48%;
	margin-right: 4%;
	margin-bottom: 50px;
}
.top-whats .top-case .box:nth-child(2n){
	margin-right: 0;
}

.top-whats .top-case .box img{
	width: 100%;
}

.top-whats .top-case .box figure figcaption{
	position: relative;
	color:#6a1684;
	display: block;
	background: #fff;
	max-width: 230px;
	margin:0 auto;
	margin-top: -35px;
	padding: 5px 15px;
	text-align: center;
	line-height: 1.8em;
	font-size: 1.25rem;
}
.top-whats .top-case .box figure figcaption span{
	display: block;
	border-bottom: 1px solid #434343;
	margin-bottom: 2px;
	padding-bottom: 2px;
	font-size: 1.6rem;
}

.top-whats .top-case .box:last-child{
	margin-right:0;
}


/************************************************************
* 下層ページ
*************************************************************/

.section{
	margin:40px 0 50px;
}

/*-----------------------------------
workstyle
----------------------------------*/

.ol-img-list1{
	display: block;
	max-width: 600px;
	margin:0 auto;
}

.ol-img-list1>li{
	width: 100%;
	margin-right: 0;

	margin-bottom: 20px;
}

.ol-img-list1>li .ttl{
}

.ol-img-list1>li .ttl>.txt {
    padding-left: 1em;
    line-height: 1.5em;
    font-size: 1.3rem;
}

.ol-img-list1>li .ttl>.num{
	font-size: 2.2rem;
}

.ol-img-list1>li .ttl>.txt{
	padding-left: 1em;
	margin-right: 0;
}

.ol-img-list1>li:nth-child(even){
	margin-right: 0;
}

/*----------------------------------
wahtstobi/welcome
----------------------------------*/
.welcome .section-movie{
	margin-bottom: 40px;
}

.welcome .main-visual{
	margin-bottom: 40px;
}

.welcome .section .sub-group{
	margin-bottom: 30px;
}

.inr-link{}
.inr-link>li{
	margin: 0 15px;
	max-width: 240px;
	width: 100%;
}

.inr-link>li>a{
	padding: 15px 0;
}

.inr-link>li>a>span{
	padding:0 16px 0 10px;
}

.drwset{
	margin-bottom: 3px;
}
	.drwset .drwhead{
		padding: 12px 40px 12px 60px;
		font-size: 1.6rem;
	}
		.drwset .drwhead .qes{
			font-size: 2.2rem;
			left: 20px;
		}
		.drwset .drwconts .ans{
			font-size: 2.2rem;
		}
		.drwset .drwconts {
		    font-size: 1.5rem;
		    padding: 12px 20px 12px 60px;
		}
		.drwset .drwhead:after {
		    content: "";
		    position: absolute;
		    display: block;
		    top: 50%;
		    right: 20px;
		    width: 8px;
		    height: 8px;
		    border-bottom: solid 2px #fff;
		    border-right: solid 2px #fff;
		    margin-top: -7px;
			-webkit-transform: rotate(45deg);
			transform: rotate(45deg);
		}

		.drwset .drwhead.open:after{
			margin-top: -2px;
		    -webkit-transform: rotate(225deg);
		    transform: rotate(225deg);
		}


.welcome .photo-gallery{
	max-width: 906px;
	margin:0 auto;
}
.welcome .photo-gallery>li{
	margin-right: 3.8%;
	margin-bottom: 3.8%;
	width: 22.15%;
}
.welcome .photo-gallery>li:nth-child(4n){
	margin-right: 0;
}


.lum-lightbox {
    z-index: 9999 !important;
}

/*----------------------------------
requirements
----------------------------------*/



.requirements .bar-head {
    font-size: 2.2rem;
}
/*----------------------------------
entry
----------------------------------*/
.entry {
    padding-top: 35px;
}

.entry-tbl {
    width: 100%;
    margin: 40px 0 20px;
    border: 1px solid #80c269;
}
.entry-tbl>tbody,
.entry-tbl>tbody>tr,
.entry-tbl>tbody>tr>th,
.entry-tbl>tbody>tr>td{
	width: 100%;
	display: block;
}
.entry-tbl>tbody>tr:last-child>td{
	border-bottom:none;
}
.entry-tbl>tbody>tr>td>img{
		width: 100%;
	}

.entry .inter-label {
    font-size: 1.4rem;
    padding: 0 0.4em;
    vertical-align: middle;
}

.entry .input-block {
    display: block;
    width: 100%;
}


.entry .input-block>.box {
    display: block;
    width: 100%;
}

.entry .input-block>.box:nth-child(2) {
    margin-top: 15px;
    padding-left: 0;
}
.entry select {
    width: 100%;
}

.entry .input.type-a {
    max-width: 80%;
}

.entry .input.type-d {
    max-width: 58px;
}


.entry .after-label {
    font-size: 1.4rem;
    margin-top: 10px;
    display: block;
}

.entry .exp {
    font-size: 1.4rem;
}

.entry .btn-area {
    margin: 0;
}

.entry .btn-area .submit-btn {
    width: 250px;
}

.entry .current>li {
    text-align: center;
    font-size: 1.3rem;
    padding-left: 33px !important;
    white-space: nowrap;
}
/*----------------------------------
wahtstobi
----------------------------------*/

.ultipose-top-block{
	display: block;
	margin:0 auto;
	max-width: 600px;
}
.ultipose-top-block>div{
	width: 100%;
	margin-right: 0;
	margin-bottom: 20px
}

.ultipose .section-case {
    position: relative;
    height: auto;
    z-index: 1;
    margin-bottom: 20px;
}

	.ultipose .section-case .back-layer,
	.ultipose .section-case.revs .back-layer {
    		-webkit-background-size: auto 300px;
			background-size: auto 300px;
	}

		.ultipose #case01.section-case .back-layer{
			background-position: 27% 0;
		}
		.ultipose #case02.section-case.revs .back-layer{
			background-position: 55% 0;
		}
		.ultipose #case03.section-case .back-layer{
			background-position: 57% 0;
		}
		.ultipose #case04.section-case.revs .back-layer{
			background-position: 55% 0;
		}




	.ultipose .section-case .back-layer {
	    z-index: 2;

	}
	.ultipose .section-case:last-child{
		margin-bottom: 0;
	}

	.ultipose .section-case .front-layer{
		padding-top: 25px;
		right:0;
		top:0;
		bottom:auto;
	    max-width: unset;
	    position: relative;
	}


	.ultipose .section-case .front-layer .head-box{
		color:#fff;
		text-align: right;
		padding-right:7.2%;
	}

	.ultipose .section-case .front-layer .head-box .case-ttl {
	    font-size: 3rem;
	    line-height: 1.1em;
	    margin-bottom: 15px;
	}

	.ultipose .section-case .front-layer .head-box .case-ttl>span {
	    font-size: 2.8rem;
	    margin-bottom: 8px;
	}

	.ultipose .section-case .front-layer .case-group {
	    width: 100%;
	    margin: 0 auto;
	    padding: 6px 22px 8px;
	    background: rgba(252,252,252,0.8);
	}

	.ultipose .section-case .front-layer .case-group {
	    width: 100%;
	    margin: 0 auto;
	    padding: 6px 7% 8px;
	    background: rgba(252,252,252,0.8);
	}

	.ultipose .section-case .front-layer .case-group ul {
	    max-width: 320px !important;
	    margin: 0 auto;
		margin-left: -5px;
	    -webkit-justify-content: flex-start;
	    justify-content: flex-start;
	    -webkit-flex-wrap: wrap;
	    flex-wrap: wrap;
	}
	.ultipose .section-case .front-layer .case-group ul>li{
		width: 46.5% !important;
		margin-right: 7% !important;
	}
	.ultipose .section-case .front-layer .case-group ul>li:nth-child(2n){
		margin-right: 0 !important;
	}


	.ultipose .section-case .front-layer .case-group ul.case02{
		max-width: unset;
	}

	.ultipose .section-case .front-layer .case-group ul>li{
		width: auto;
	}
	.ultipose .section-case .front-layer .case-group ul>li p {
	    text-align: center;
	    padding-left: 13px;
    	padding-top: 5px;
	    font-size: 1.2rem;
	    white-space: nowrap;
	}


	.ultipose .section-case .front-layer .case-group ul>li a{
		-webkit-transition: all 0.3s ease;
		-moz-transition: all 0.3s ease;
		-ms-transition: all 0.3s ease;
		-o-transition: all 0.3s ease;
		transition: all 0.3s ease;
		display: block;
	}


		.ultipose .section-case .front-layer .case-group ul>li a:hover{
			opacity: 1;
			-webkit-transform: translateY(-10px) scale(1.05,1.05);
			transform: translateY(-10px)  scale(1.05,1.05);
		}

	.ultipose .section-case.revs .front-layer{
		right:auto;
		left:0;
		text-align: left;
	}
	.ultipose .section-case.revs .front-layer .head-box {
	    padding-right: 0;
	    padding-left: 7%;
	    text-align: left;
	}

	.sup{ color:#a40000;}
	.sen{ color:#004986;}
	.leg{ color:#8a8000;}
	.rok{ color:#097c25;}

	.section-slide{
		background: #097c25;
		padding: 20px 7% 50px;
	}

	.slide-wrap{
		position: relative;
		max-width: 1100px;
		margin:0 auto;
	}
	.slide-wrap .phase-slider{
		background: #fff;
		max-width: 1000px;
		margin: 0 auto;
		display: block;
		-webkit-box-shadow: 0px 0px 10px 5px rgba(86,86,86, 0.6);
		box-shadow: 0px 0px 20px 8px rgba(86,86,86, 0.6);
	}

	.slide-wrap .phase-slider .swiper-slide{
		padding: 30px 5% 20px;
	}
	.slide-wrap .phase-slider .heading{
		max-width: 255px;
		margin:0 auto;
		text-align: center;
		background: #85c134;
		color:#fff;
		font-size: 1.8rem;
		height: 45px;
		line-height: 45px;
		-webkit-border-radius: 0.6em;
		border-radius: 0.6em;
		margin-bottom: 20px;
	}
		.slide-wrap .phase-slider .ttl{
			font-size: 2.2rem;
			margin-bottom: 0.5em;
			color:#6a1684;
		}
		.slide-wrap .phase-slider  .phase-block{
			display: block;
		}

		.slide-wrap .phase-slider  .phase-block>div{
			width: 100%;
		}

		.slide-wrap .phase-slider  .phase-block div.img-box{
			margin-bottom: 20px;
		}
		.slide-wrap .phase-slider  .phase-block div.txt-box{
			padding-left: 0px;
		}


		.slide-wrap .phase-slider  .phase-block div.txt-box p{
			margin-bottom: 1em;
			font-size: 1.3rem;
			line-height: 1.7em;
		}


	.slide-wrap .slider-area .btn-area{
		margin-bottom: 1em;
	}

	.slide-wrap .slider-area .btn-area .btn-a {
	    border: 1px solid #6a1684;
	    text-align: left;
	    padding-left: 20px;
	    font-size: 1.3rem;
	    max-width: 375px;
	    height: 40px;
	    line-height: 40px;
	}

	.slide-wrap .slider-area .btn-a::before,
	.slide-wrap .slider-area .btn-a::after {
	    right: 30px;
	}

	.slide-wrap .swiper-pagination{
		position: static;
		max-width: 1000px;
		margin:0 auto;
		display: -ms-flex;
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: flex-start;
		justify-content: flex-start;
		-webkit-flex-wrap: wrap;
		flex-wrap: wrap;
		margin-bottom: 10px;
	}

	.slide-wrap .swiper-pagination>span{

	}

	.slide-wrap .slider-area{
		position: relative;

	}



	.slide-wrap .swiper-pagination-bullet {
	    width: 46px;
	    height: 46px;
	    line-height: 46px;
	    display: inline-block;
	    border-radius: 100%;
	    color: #6a1684;
	    opacity: 1;
	    background:#fff;
	    font-family: "Arial";
	    font-size: 2.2rem;
	    margin-left: 15px;
	    margin-bottom: 10px;
	}

	.slide-wrap .swiper-pagination-bullet-active{
		background: #85c134;
		color:#fff;
	}

	.slide-wrap .slider-area .swiper-button-next,
	.slide-wrap .slider-area .swiper-button-prev {
		height: 36px;
		width: 36px;
		border:2px solid #fff;
		margin-top: 0px;
		-webkit-background-size: 10px auto;
		background-size: 10px auto;
	}


	.slide-wrap .slider-area .swiper-button-next{
	    right: -6%;
	}

	.slide-wrap .slider-area .swiper-button-prev {
	    left: -6%;
	}

		.slide-wrap .slider-area .swiper-button-prev{
			background-image:url(../img/arrow_prev.png);
			background-position: 45% center;
		}

		.slide-wrap .slider-area .swiper-button-next{
			background-image:url(../img/arrow_next.png);
			background-position: 55% center;
		}

			.slide-wrap .slider-area .swiper-button-prev:hover{
				-webkit-transform:none;
				transform:none;
			}
			.slide-wrap .slider-area .swiper-button-next:hover{
				-webkit-transform:none;
				transform:none;
			}
.case-main-visual {
    position: relative;
    height: 1022px;
    max-width: 1800px;
    margin: 0px auto 68px;
}

	.case .case-main-visual{
		position: relative;
		height: auto;
	}

	.case .case-main-visual .txt-box{
	    width: 100%;
	    height: auto;
	    bottom:0;
	    left:0;
	    background: transparent;
		padding:0 8% 25px;
	}
		.case .case-main-visual .txt-box img{
			width: 100%;
			height: auto;
		}

		.case .case-main-visual .img-box{
			position: absolute;
			left:0;
			top:0;
			width: 100%;
			height: 100%;
		}

.section-movie .headline-movie {
    top: -24px;
    width: 100%;
}
.section-movie .headline-movie img {
	 width:120px;
}



.case .section-movie .headline-movie img {
    width: 231px;
    display: block;
    margin: 0 auto;
}

.case .case-main-visual .txt-box img {
    position: static;
    height:auto;
    -webkit-transform: none;
    transform: none;
}
	.case .bottom-wide-block{
		margin-top: 20px;
	}

	.section-message{
		position: relative;
		height:auto;
		margin-top: 0px;
		margin-bottom:40px;
		background: none !important;
		overflow: visible;
		padding-bottom: 20px;
	}

		.section-message  .txt-box{
			position:relative;
			top: 0;
			max-width: 823px;
			width: 88%;
			margin-top: -10%;
			margin-left: 6%;
			padding: 30px 30px;
			right: 0;
			background: #fff;
			-webkit-box-shadow: 0px 0px 10px 5px rgba(86,86,86, 0.4);
			box-shadow: 0px 0px 20px 8px rgba(86,86,86, 0.4);
			-webkit-transform: none;
			transform: none;
			z-index: 2;
		}

			.section-message  .txt-box .title img{
				width: 140px;
			}

		.section-message .img-box{
			position: relative;
			z-index: 1;
			top:0;
		}

/*----------------------------------
topics-tbl
----------------------------------*/

.topics-tbl {
    margin: 0;
    width: 100%;
}
}


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

	.top-whats .top-case .box{
		width: 100%;
		margin-right: 0;
	}
	.top-whats .top-case .box:nth-child(2n){
		margin-right: 0;
	}
	.top-whats .top-case .box figure figcaption {
    	margin-top: -29px;
	}

	.slide-wrap .swiper-pagination{
		position: static;
		max-width: 1000px;
		margin:0 auto;
		display: -ms-flex;
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: flex-start;
		justify-content: flex-start;
		-webkit-flex-wrap: wrap;
		flex-wrap: wrap;
		margin-bottom: 10px;
	}


}
/***********************************************************************************************************************
* 横サイズ374px以下
***********************************************************************************************************************/
@media screen and (max-width: 374px){


	header .logo img {
	    max-width: 132px;
	    margin-top: 2px;
	}

	header .logo a {
    margin-top: 21px;
    margin-left: 14px;
    padding-top: 0;
}
/*	.headline-lg.sm {
	    font-size: 1.7rem;
	}
*/
	.ultipose .section-case .back-layer, .ultipose .section-case.revs .back-layer {
	    -webkit-background-size: auto 300px;
	    background-size: auto 258px;
	}

	.ultipose .section-case .front-layer .head-box .case-ttl {
	    font-size: 2.5rem;
	}

	.ultipose .section-case .front-layer .head-box .case-ttl>span {
		font-size: 2.2rem;
	}
	.slide-wrap .swiper-pagination-bullet {
	    margin-left: 8px;
	    margin-bottom: 10px;
	}

	.ultipose .section-case .front-layer .case-group ul>li p {
	    padding-left: 10px;
	    font-size: 1rem;
	}

	.slide-wrap .slider-area .btn-area .btn-a {
	    padding-left: 15px;
	    font-size: 1.1rem;
	}

	.slide-wrap .slider-area .btn-area .btn-a::after {
	    content: "";
	    position: absolute;
	    display: block;
	    width: 21px;
	    height: 1px;
	}



}

