@charset "utf-8";
/* CSS Document */

/* ------------------------------------------  
COMMON
------------------------------------------ */
*{
	margin:0;
	padding:0;
}

html {
	overflow-y: scroll;
	font-size: 62.5%;
}

body {
	height: 100%;
	margin: 0 auto;
	-webkit-text-size-adjust: 100%;
	color:#2C2C2C;
	text-align:center;
	font-size:1.4rem;
	font-family:-apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
	font-weight: 300;
}


a			{outline: none; color: #0d6fb8; text-decoration:none;}
a:visited	{color: #0d6fb8;}
a:hover		{opacity: 0.7;
			filter:progid:DXImageTransform.Microsoft.Alpha(Enabled=1,Style=0,Opacity=70);
			-webkit-transition:0.5s;
			-moz-transition: 0.5s;
			-o-transition: 0.5s;
			transition: 0.5s;
			}
			
a:active	{color: #b40066;}

img {
	border:none;
	max-width: 98%;
	margin:0 1% 0;
	width: auto\9;
	height: auto;
	vertical-align:bottom;
}

p img {
	max-width: 100%;
	margin:0;
}

#lookingfor img{
	width: 50%;
	text-align: center;
}


a img:hover	{
	opacity: 0.7;
	filter:progid:DXImageTransform.Microsoft.Alpha(Enabled=1,Style=0,Opacity=70);
	-webkit-transition:0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	/*-ms-transition: 0.5s; IEで変な動きする*/
	transition: 0.5s;
}

p{
	line-height:1.7em;
	margin:0 2% 20px;
	text-align:left;
}

#wrapper {
	width: 100%;
}

.sp{display: none;}

/* ------------------------------------------  
Breadcrumb NavXT
------------------------------------------ */
.breadcrumbs {
	width: 1000px;
	max-width: 98%;
	min-height: 1.6em;
	line-height: 1.6em;
	padding: 6px 0;
	margin: 0 auto;
	font-size: 1.2rem;
	color:#898989;
	text-align:left;
	box-sizing:border-box;
	border-top:1px solid #ddd;
	}
	
	.breadcrumbs p{margin:0 0 10px;}

.breadcrumbs a,
.breadcrumbs a:visited {
	color:#898989;
	}

.breadcrumbs a:hover{
	opacity: 0.7;
	filter:progid:DXImageTransform.Microsoft.Alpha(Enabled=1,Style=0,Opacity=70);
	}

.breadcrumbs a:after{
	font-family: FontAwesome;
	content: "\f0da";
	padding: 0 1.0em;
	text-decoration: none;	
	}


/* ------------------------------------------  
HEADER
------------------------------------------ */
#header{
	width: 100%;
	margin: 0 auto;
	z-index: 9998;
	position: fixed;
	background-color: rgb(255,255,255,0.9);
}

#header a,#header a:visited{color: #2C2C2C;}

#header-inner{position: relative;}

.home header{
	position: absolute;
	z-index: 102;
	padding: 30px 0 0;
	background:none;
}

	#header-inner{
		width:100%;
	}

	#header-left{
		float:left;
		width:10%;
	}

	#header-left h1 a{
		display:block;
		text-indent:-99999px;
		background-image:url(img/h1.png);
		background-image/*\**/: url(img/h1_ie.png) \9;
		background-repeat:no-repeat;
		background-size: contain;
		background-position:0;
		padding: 14px;
	}

	
	#header-right{
		float:right;
		width:90%;
		margin:0;
	}



ul#menu{padding:0;}

ul#menu li {
    display: block;
    float: right;
    list-style: none;
	box-sizing: border-box;
}



.contact_nav li a{
	padding:10px 15px;
	    box-sizing: border-box;
		display: inline-block;
		float: left;
		width: 100%;
		position: relative;
		text-decoration: none;
}

.contact_nav li {
    display: block;
    float: right;
    list-style: none;
    box-sizing: border-box;
    font-size: 1.4rem;
}

	ul#menu li a{
		padding:24px 20px;
	    box-sizing: border-box;
		display: inline-block;
		float: left;
		width: 100%;
		position: relative;
		text-decoration: none;
	}

ul#menu li.entry a{
	color: #fff;
	background-color:#e63e4b;
	font-size: 130%;
}

ul#menu li.entry a:hover{
	background-color: #ba2d38;
}

ul#menu li a:hover{
	background-color: rgba(210,210,210,0.8)
}


ol li{margin-left: 4%;}

.contact_nav {
	display: inline-block;
	float: right;
	padding: 0 11px;
	margin:0 0 0 20px;
	font-weight: bold;
}

#header .contact_nav a{color:#f3a715;}


.smalltext{font-size:1rem;}

#remodal_menu{display: none;}

/* ------------------------------------------  
BUTTON
------------------------------------------ */


/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="reset"],
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="reset"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="reset"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}
/* iOSでのデフォルトスタイルをリセット */


.button {
    text-align: center;
    margin: 20px auto;
    clear: both;
	display: block;
	font-family: serifa-stencil-d,YuGothic,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"ＭＳ Ｐゴシック",sans-serif;
	font-size: 2rem;
}


	.button a, .button a:visited {
		min-width: 150px;
		text-align: center;
		position: relative;
		overflow: visible;
		display: inline-block;
		padding: 10px 20px;
		margin: 10px auto;
		color: #fff;
		background-color:#0d6fb8 ;
		text-decoration: none;
		cursor: pointer;
		zoom: 1;
	}

#tokuteiseikan .button a,#tokuteiseikan .button a:visited{background-color:#fff; color:#0d6fb8; }

.contact_set .button{margin: 20px 1%;}
.contact_set .button a{display: block;padding: 20px 0; color:#fff; border:none;}

.contact_set .button.contact a{background-color:#f3a715;}
.contact_set .button.tel a{background-color:#3789a4;}

.contact_set .button.tel{
	padding-bottom:10px;
	border-bottom: 1px dotted #5A5A5A;
}

.button.full a, .button.full a:visited {
	display: block;
}

.button a:hover{
	background-color:#DBDBDB;
}

/* ------------------------------------------  
TABLE
------------------------------------------ */
table {
	overflow: hidden;
	width: 96%;
	text-align: left;
	margin: 40px 2%;
	
}

table thead,table tbody{
	width: 100%;
}


table thead th,
table tbody th,
table tbody td {
	padding: 10px;
	font-weight: normal;
}

	#info table tbody th{width:35%;}
	#info table tbody td{width:7%;}
	#info table tbody td:last-child{width:23%;}

#entry table em{margin-left:10px;color:#e63e4b;font-style: normal;}

/* ------------------------------------------  
contact form
------------------------------------------ */
input {padding:5px;}

.formTable th{width:20%;}
input.test{widht:80%;}

input.input_button{
	min-width: 150px;
	text-align: center;
	position: relative;
	overflow: visible;
	display: inline-block;
	padding: 10px 20px;
	margin: 10px auto;
	text-decoration: none;
	cursor: pointer;
	color:#fff;
	border: none;
}

input.input_button.submit{background-color: #0d6fb8;}
input.input_button.reset{background-color: #aaaa;}

input[type="submit"]:hover{background-color:#e63e4b;
-webkit-transition:0.5s;
			-moz-transition: 0.5s;
			-o-transition: 0.5s;
			transition: 0.5s;}

input[type="reset"]:hover{opacity: 0.7;
			filter:progid:DXImageTransform.Microsoft.Alpha(Enabled=1,Style=0,Opacity=70);
			-webkit-transition:0.5s;
			-moz-transition: 0.5s;
			-o-transition: 0.5s;
			transition: 0.5s;}

textarea{width:80%}

dl{margin:2%;}

dl dt{
	width: 25%;
	clear:both;
	color:#0d6fb8;
	font-size:1.8rem;
	font-weight: bold;
	display: inline-block;
	float: left;
	margin: 0 2% 10px 0;
}

.scrollArea dl dt{font-size: 1.6rem;}

dl dd{
	width: 73%;
	float: left;
	margin-bottom: 10px;
}

.scrollArea{
	height: 200px;
	overflow: auto;
	padding: 2%;
	text-align: left;
	margin: 40px 2%;
	border: 1px solid #aaa;
}
/*スクロールバーの横幅指定*/
.scrollArea.deco::-webkit-scrollbar {
    width: 15px;
}
/*スクロールバーの背景色・角丸指定*/
.scrollArea.deco::-webkit-scrollbar-track {
  border-radius: 10px;
	background: #f2f2f2;
}
/*スクロールバーの色・角丸指定*/
.scrollArea.deco::-webkit-scrollbar-thumb {
  border-radius: 10px;
	background:#09C9D9;
}

/* ------------------------------------------  
CONTENTS
------------------------------------------ */

.inner{
	width: 1000px;
    margin: 0 auto;
}

#eyechach{
	position: relative;
	z-index: 3;}

#eyechach img{max-width: 100%; margin: 0;}

#about{
	position: relative;
	z-index: 5;
	padding:100px 0 150px;
	background-image: url("img/about_img.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	}

.concept{
	position: relative;
	z-index: 3;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
}

.underscore{
	background-color: #fff;
    line-height: 1.6em;
}

.emphasis{
	font-size:2.4rem;
	line-height: 1.5em;
}

#business{
	position: relative;
	z-index: 10;}

#business h2{
		display:block;
		text-indent:-99999px;
		background-image:url("img/h2_content_.jpg");
		background-image/*\**/: url("img/h2_content_ie.jpg") \9;
		background-repeat:no-repeat;
		background-size: cover;
		background-position:0;
		padding: 22%;
		margin: 0;
	}


#palette h2{
		display:block;
		text-indent:-99999px;
		background-image:url("img/h2_pallet.png");
		background-image/*\**/: url("img/h2_pallet_ie.png") \9;
		background-repeat:no-repeat;
		background-size: contain;
		background-position:0;
	    margin: 0 0 10px;
		padding: 10px 0;
	}

#tokuteiseikan h2{
		display:block;
		text-indent:-99999px;
		background-image:url("img/h2_tokuteiseikan.png");
		background-image/*\**/: url("img/h2_tokuteiseikan_ie.png") \9;
		background-repeat:no-repeat;
		background-size: contain;
		background-position:0;
	    margin: 0 0 10px;
		padding: 10px 0;
	}

#magekakou h2{
		display:block;
		text-indent:-99999px;
		background-image:url("img/h2_mage.png");
		background-image/*\**/: url("img/h2_mage_ie.png") \9;
		background-repeat:no-repeat;
		background-size: contain;
		background-position:0;
	    margin: 0 0 10px;
		padding: 10px 0;
	}


.naname {
    z-index: 3;
    bottom: -1px;
    border-width: 0 0 150px 100vw;
    position: absolute;
    width: 0;
    height: 0;
    right: 0;
    border-style: solid;
}

.naname2 {
    z-index: 3;
    bottom: -1px;
    border-width: 150px 0 0  100vw;
    position: absolute;
    width: 0;
    height: 0;
    right: 0;
    border-style: solid;
	border-color: transparent #fff  transparent ;
}



.naname_top {
    z-index: 3;
    top: 0px;
    border-width:0 0 150px 100vw;
    position: absolute;
    width: 0;
    height: 0;
    right: 0;
    border-style: solid;
}

.naname.white{border-color: transparent transparent #fff;}
.naname.gray{border-color: transparent transparent #ebebeb;}
.naname.blue{border-color: transparent transparent #0d6fb8;}
.naname.blue_translucent{border-color: transparent transparent rgb(6,58,97,0.5);}
.naname_top.blue_translucent{border-color:  transparent  rgb(6,58,97,0.5) transparent ;}
.naname2.black{border-color:transparent #000 transparent ;}


#palette{
	position: relative;
	z-index: 15;}


#tokuteiseikan{
	position: relative;
	z-index: 20;
	background-color:#0d6fb8;
	color: #fff;
}

#magekakou{
	position: relative;
	z-index: 25;
}

#pagemove {
    position: fixed;
    bottom: 10px;
    right: 10px;
    width: 80px;
    height: 80px;
    text-indent: -99999px;
    background-image: url(img/pagemove.png);
    background-repeat: no-repeat;
    background-size: 100%;
    background-position: 0 0;
    z-index: 200;
}

.inner_image {
    position: absolute;
    left: calc(50% - 50px);
    bottom: 0;
    display: inline-block;
    height: auto;
	margin: 0;
}

#palette .inner_image{
	width: 500px;
}

#palette .colum, #tokuteiseikan .colum,#magekakou .colum {
    position: relative;
    top:-40px;
	/*z-index: 10;*/
}

#tokuteiseikan .inner_image {
    width: 500px;
    left: calc(50% - 520px);
    bottom: 20px;
}

#magekakou .inner_image{
	width: 500px;
}


#tokuteiseikan .inner_image {
    width: 500px;
}

#global{
	background: url(img/back_global.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    padding: 40px 0 450px;
    background-position: bottom;
	background-color: #0d6fb8;
}

#global p{color: #fff; line-height: 1.8em;}

#massage{
	position: relative;
	padding: 100px 0 20%;
}

#massage .gridphoto{
	position: absolute;
	bottom: 0;
	z-index: 40;
}

#lookingfor{
	background:url("img/back_lookingfor.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	padding: 80px 0 120px;
	position: relative;
}

#lookingfor .grid4 p{font-size:1.4rem;}

#lookingfor .grid4 p.number{
	text-align: center;
	font-size: 5rem;
	color:#0d6fb8;
	font-family: serifa-stencil-d, serif;
	font-weight: 700;
	font-style: normal;
	line-height: 1.2em;
	margin:10px 0 0;
}


#requirement{
	position: relative;
	z-index: 5;
	padding:100px 0 150px;
	background-image: url("img/requirement_img.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	}

#requirement .whitebase{
	width: 80%;
    text-align: left;
    background-color: rgba(255,255,255,0.8);
    padding: 60px;
    box-sizing: border-box;
    margin: 0 auto;
}

#entry{padding:60px 0;}

/* ------------------------------------------  
FOOT
------------------------------------------ */	
.gmap iframe {
pointer-events:none;
}

#access{margin-top:300px; margin-bottom:0;}

footer {
    background-color: #000;
    padding: 40px 0 0;
    box-sizing: border-box;
	color: #fff;
}

footer a,footer a:visited{color: #fff;}

#copy{background-color: #0d6fb8;}

#copy p {
    max-width: 1000px;
    width: 96%;
    margin: 0 auto;
    padding: 20px 0 10px;
    color: #fff;
    text-align: center;
    font-size: 1.3rem;
}

.fotter_logo{
	width:30%;
	display: inline-block;
	float: left;
	margin: 0 0 20px;
}

.fotter_logo i{font-size: 2.5rem;}
.fotter_logo a i{margin: 5px;}

.footer_contact{
	margin: 15px 2% 30px;
	text-align: right;
	display: inline-block;
	float: right;
}


.contact_set{
	padding: 20px;
	box-sizing: border-box;
	background-color: rgba(255,255,255,0.4);
}

/* ------------------------------------------  
TITLE
------------------------------------------ */
h2{
	font-size: 3.5rem;
	font-weight: bold;
	color:#2C2C2C;
	margin:20px 2% 10px;
	padding-bottom:5px;
	text-align: left;
}

.concept h2,#global h2{font-family: 'Noto Sans JP', sans-serif;font-weight: 900;}

#about h2,#global h2{
	font-size:5rem;
	margin:20px 2% 10px;
}

#massage h2,#lookingfor h2,#requirement h2,#entry h2{
	line-height: 0.8em;
	font-family: 'Black Ops One', YuGothic,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"ＭＳ Ｐゴシック",sans-serif;
	letter-spacing: 2px;
	font-weight: 700;
	font-style: normal;
	color: #0d6fb8;
}

#lookingfor h2{
	text-align: center;
}

#massage h2 span,#lookingfor h2 span,#requirement h2 span,#entry h2 span{font-size: 1.4rem;}

#requirement h2{word-break: break-all;}

h3{
	text-align: left;
	font-size:2rem;
	font-weight: bold;
	color:#2C2C2C;
	margin:20px 2% 10px;
}


h4{
	text-align: left;
	font-size:1.8rem;
	font-weight: normal;
	color:#2C2C2C;
	margin:10px 2% 10px;
	padding:10px 0;
	border-top:1px solid #2C2C2C;
	border-bottom:1px solid #2C2C2C;
}

footer h3{
	text-align: center;
	color: #fff;
	margin: 0;
}

footer p{line-height: 1em;}


/* ------------------------------------------  
BOX
------------------------------------------ */
/* grid */
.grid1,
.grid2,
.grid3,
.grid4,
.half,
.colum_half{
	float: left;
	display: inline;
	margin:0 1% 40px;
}

.gridphoto img{
	float: left;
	display: inline;
	margin: 0;
	width: 25%;
}

.grid1	{width: 31.33%;}
.grid2	{width: 64.67%;}
.grid3	{width: 31.33%;}
.grid4	{width: 23.00%;}
.half,.colum_half	{width: 46%; margin:0 2% 20px;}
.grid_full {width: 96%; margin:0 2% 20px;}


#lookingfor .grid4{
	padding: 2%;
	box-sizing: border-box;
	background-color: rgba(255,255,255,0.8);
}


.right	{float:right;}
.left	{float:left;}
.center{text-align:center;}
.aligncenter{
    text-align: center;
    margin: 0 auto;
    display: block;
}


/* ------------------------------------------  
for - 1070px * important *
------------------------------------------ */
@media screen and (max-width:1070px) {
	
	#header-inner{width:100%;}
	
	#palette .inner_image{
		width:500px;
		left: calc(100% - 500px);
	}
	
	#tokuteiseikan .inner_image {
    left: calc(50% - 62%);
}
	
	#magekakou .inner_image .inner_image{
		width:500px;
		left: calc(100% - 450px);
	}
	


}

/* ------------------------------------------  
for - 979px
------------------------------------------ */
@media screen and (max-width:979px) {

	ul#menu{font-size:1.4rem;}
	
	.inner{width: 100%;}
	
	#massage {
    position: relative;
    padding: 60px 0 20%;
}
	
	#global .half{
		width: 96%;
	}
	
	#global{
    padding-bottom:250px;
	}
	
}


/* ------------------------------------------  
for - 768px
------------------------------------------ */
@media screen and (max-width:768px) {
	
.pc{display: none;}
.sp{display: block;}

	
#header-left h1 a{
	width: 160px;
    height: 35px;
    margin: 0 auto;
    top: 0;
    z-index: 5;
	}
	
	
#header-right ul {
    margin-top: 10px;
}

#header-inner{margin-top:0;}
	
	.drawer-nav ul li a {
		display: block;
		padding: 15px;
		border-bottom: 1px dotted #aaa;
		text-align: right;
	}
	
	#header .drawer-nav ul li.entry a,#header .drawer-nav ul li.entry a:visited{background-color: #e63e4b; color:#fff;}
	
	
	.drawer-nav ul li a:hover{
		background-color:#ededed;
	}

#main_nav,.contact_nav{display: none;}
	
	#remodal_menu{
		display: block;
		padding: 10px 20px;
		float: right;
		}
	
	#remodal_menu a{font-size: 3rem;}
	#remodal_menu a span{font-size:1.8rem;display: block;}
	
.contact_nav_sp{margin-top: 20px; border: 2px solid #f3a715;}
.remodal nav ul li.contact_nav_sp a{border-bottom:none;}
	
table th,table td{display: block;}
dl dt,dl dd{display: block; width: 100%;}

	
.naname,.naname_top {
    border-width: 0 0 100px 100vw;
}
	
	.naname2 {
    border-width: 100px 0 0  100vw;
	}


.inner_image{
    left: 0;
}
	
	#about br.sp_none{display: none;}
	

#about h2, #global h2 {
    font-size: 3.5rem;
	}
	
		
#business h2 {
    padding: 20% 0 80%;
	background-position: center;
    background-image: url(img/h2_content_sp.jpg);
    background-image/*\**/: url(img/h2_content_sp_ie.jpg) \9;
}

#palette .inner_image,#tokuteiseikan .inner_image,#magekakou .inner_image{
	width: 55%; 
	top: calc(50% - 0 / 2);
    left: calc(50% - 60% / 2);
	} 

#palette .half,#tokuteiseikan .half,#magekakou .half,#massage .half{
		width: 96%;
	}

#palette,#tokuteiseikan,#magekakou{
	height: 650px;
}

	
#palette h2 {
    padding: 5px 0;
}
	
#tokuteiseikan h2{background-position: right;}

#magekakou .colum {
    transform: none;
    float: left;
}

	
	#global {
    padding-bottom:200px;
}
#global h2 br{display: none;}
	
	#requirement .whitebase {
		padding: 30px;
		width:90%;
	}
	
	#lookingfor .grid4 p.number{font-size:4rem;}
	

	
	
	#massage {
		padding: 60px 0 80%;
	}
	
	#massage .inner_image{width:80%; bottom:-12%; left:10%;}
	#massage .half{margin-bottom:15%;}

	h3,h4{font-size: 1.6rem;}
	
	input.input_button{
		display: block;
		margin: 0 auto;
	}
	
.formTable th {
    width: 96%;
}
	
	
footer .half{
	float: none;
	width: 96%;
	clear:both;
	margin:0 2% 15px;
}

}

/* ------------------------------------------  
for - 680px
------------------------------------------ */
@media screen and (max-width:680px) {

	
/* grid 540 */
.grid1,
.grid2,
.grid3{
	float: none;
	width: 96%;
	clear:both;
	margin:0 2% 15px;
}

.grid4{
	width: 46%;
	margin:0 2% 15px;
}
	
#global{
    background-image: url("img/back_global_sp.jpg");
	background-size: contain;
	padding-bottom:150px;
	}


	
/* pagemove*/
#pagemove{
	right:0;
	width: 60px;
	height:60px;
}
	
#massage .inner_image{ bottom:-5%;}

}
	
		
/* ------------------------------------------  
CLEARFIX-HACK
------------------------------------------ */
section:after,
#header-inner:after,
#menu:after,
.inner:after,
#main:after,
footer:after,
#copy:after,
.grid1:after,
.grid2:after,
.grid3:after,
.grid4:after,
.half:after,
.right:after,
.box:after,
.whitebase:after,
#pagemove:after,
.clearfix:after{
content: ".";
display: block;
height: 0;
clear: both;
visibility: hidden;
font-size: 0;}

section,
#header-inner,
#menu,
.inner,
#main,
footer,
#copy,
.grid1,
.grid2,
.grid3,
.grid4,
.half,
.right,
.box,
.whitebase,
#pagemove,
.clearfix{display: inline-block;}

/* Hides from IE-mac \*/
* section,
* html #header-inner,
* html #menu,
* html .inner,
* html #main,
* html footer,
* html #copy,
* html .grid1,
* html .grid2,
* html .grid3,
* html .grid4,
* html .half,
* html .box,
* html .whitebase
* html .right,
* html #pagemove,
* html .clearfix{height: 1%;}

section,
#header-inner,
#menu,
.inner,
#main,
footer,
#copy,
.grid1,
.grid2,
.grid3,
.grid4,
.half,
.box,
.whitebase,
.right,
#pagemove,
.clearfix{display: block;}
/* End hide from IE-mac */