@charset "utf-8";
/*
Copyright (c) 2009, Yahoo! Inc. All rights reserved.
Code licensed under the BSD License:
http://developer.yahoo.net/yui/license.txt
version: 3.0.0
build: 1549
*/
html{color:#000;background:#FFF;font-size:62.5%;}body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote,th,td{margin:0;padding:0;}table{border-collapse:collapse;border-spacing:0;}fieldset,img{ border:0;}address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal;}li{list-style:none;}caption,th{ text-align:left;}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal;}q:before,q:after{content:'';}abbr,acronym{border:0;font-variant:normal;}sup{vertical-align:text-top;}sub{vertical-align:text-bottom;}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}input,textarea,select{*font-size:100%;}legend{color:#000;}body{text-align:center;color:#333;cursor:auto;font:normal normal 62.5%/1.75em "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;}hr{display:none;}figure{margin: 0;}

/******************************************************************** print styles
*/ 
@media print{body { font: normal normal 62.5%/1.75em "ヒラギノ角ゴ Pro W3", Osaka, "ＭＳ Ｐゴシック", sans-serif;}}


/******************************************************************** structure
*/
html{overflow-y:scroll;}
body{
	box-sizing: border-box;
	text-align: justify;
	text-justify: inter-ideograph;
	-webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
	color: #0E0E0E;
	font-size: 1.6rem;
	line-height: 1.6;
	background: #FFF;
	width: 100%;
	overflow-x: hidden;
}
a{
	-webkit-transition: all .3s;
	transition: all .3s;
}
a:link,
a:visited{color:#0083E5;}
a:hover{opacity: 0.5;}
a[href^="tel:"] {pointer-events: none; color:inherit; text-decoration: none;}

.red{color:#D51720;}
.yellow{color: #FEF101;}
.green{color: #1DBF66;}
.orange{color: #F58021;}
.marker{background: linear-gradient(transparent 60%, #FEF101 60%);}
.full-marker{background: linear-gradient(#FEF101 60%, #FEF101 60%);}
.under-line{text-decoration: underline;}
.small{font-size: 0.8em;}
.big{font-size: 1.2em;}
.bold{font-weight: bold;}
.photo{line-height: 0;}
.photo img{max-width: 100%;}
.shadow{box-shadow:4px 4px 8px 0px rgb(0,0,0,0.2);}

.pc_none{display:none !important;}
.tb_none{display:block !important;}
.sp_none{display:block !important;}
.sp_only{display: none !important;}

.wrapper { width:92%; max-width: 1280px; text-align: left; margin: 0 auto; position: relative;}

#header {
	position: relative;
	height: auto;
	width: 100%;
}

.company_link a:link,
.company_link a:visited,
.company_link a:active {
	/* color:#0E0E0E !important; */
}

.company_link a:hover {
	opacity: 1 !important;
}

.company_link a[target="_blank"]:after {
	background: none !important;
}


/******************************************************************** header
*/
.header {position: relative;}
.mv{
	box-sizing: border-box;
	position: relative;
}
.mv .head-info{
	width:100%;
	margin: 0 auto;
	padding: 24px 4%;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	position: fixed;
	left: 0;
	z-index: 101;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
	background: rgba(0,0,0,0.5);
}
.mv .head-info .logo{margin-left: 0; margin-right: auto; line-height: 0;}
.logo a{
	display: block;
	text-align: left;
	text-decoration: none;
	color: #FFF;
}
.logo img{width: 242px;}
.head-info nav{
	width: 70%;
	max-width: 880px;
}

.catch{
	text-align: left;
	position: relative;
	padding: 200px 0 160px;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	width: 100%;
	margin: 0 auto;
}
.catch .ttl-area{
	width: 92%;
	margin: 0 auto;
	position: relative;
	z-index: 5;
	text-shadow:1px 1px 10px #000000,1px 1px 8px #000000;
	color: #FFF;
}
.catch .cover{width: 100%;}
.catch .en{
	line-height: 1.1;
	font-size: 8rem;
	font-weight: bold;
	margin-bottom: 24px;
}
.catch h2{
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1.4;
	letter-spacing: 0.16em;
}
.catch .txt{font-size: 2rem;}

.breadcrumb{
	position:absolute;
	left: 4%;
	bottom: 1em;
	z-index:1;
	margin:0;
	line-height:1.4;
	font-size: 1.4rem;
	color: #FFF;
}
.breadcrumb .wrapper{width: 100%; max-width: 100%; margin: 0 auto; text-align: center;}
.breadcrumb li{display:inline;}
.breadcrumb li:after{
	display:inline;
	content:">";
	margin:0 0.5em;
}
.breadcrumb li:last-child:after{display:none;}
.breadcrumb li a:link,
.breadcrumb li a:visited{color: #FFF;}
.breadcrumb li a:hover{text-decoration:none;}


/******************************************************************** globalNav
*/
.scroll-prevent {
  position: fixed;
  z-index: -1;
  width: 100%;
  height: 100%;
}
.fixed{
	position: fixed !important;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 100;
}
.nav-wrap .nav {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	-webkit-overflow-scrolling: touch;
	box-sizing: border-box;
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	z-index: 100;
}
.nav > li{
	text-align: left;
	border-left: none;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.nav > li.privacy{display: block;}
.nav > li > a,
.nav li.has-child .child li a{position: relative;}
.nav > li:after,
.nav > li:first-child:before{display: none;}
.nav a{
	text-decoration: none;
	font-size: 1.6rem;
	font-weight: bold;
    display: block;
	line-height: 1.4;
	color: #FFF;
	padding: 0.8em 0.5em;
	box-sizing: border-box;
}
/*.fixed .nav a{color: #0E0E0E;}*/
.nav li.has-child .child{background: #333;}
.nav li.has-child .child li{border-top: #1F1F1F 1px solid;}
.nav li.has-child .child li a br{display: none;}
.nav .contact a{
	border: #FFF 1px solid;
	padding: 0.8em 3.188em;
	padding-top: calc(0.8em - 1px);
	padding-bottom: calc(0.8em - 1px);
	border-radius: 2em;
}
.nav .contact a:after{
	content: "";
	background: url("img/common/ico_arrow_right_white.svg") no-repeat center center;
	width: 6px;
	height: 1em;
	display: inline-block;
	position: absolute;
	right: 1.6em;
	top: 50%;
	transform: translateY(-50%);
}
/*.fixed .nav .contact a{border: #0E0E0E 1px solid;}
.fixed .nav .contact a:after{background: url("img/common/ico_arrow_right_black.svg") no-repeat center center;}*/

.nav li.has-child:hover {
	-webkit-transition: all .5s;
	transition: all .5s;
}
.nav li.has-child > a:after{
	content: "";
	display: inline-block;
	background: url("img/common/ico_arrow_bottom_white.svg") no-repeat center center;
	width: 10px;
	height: 6px;
	position: absolute;
	bottom: -4px;
	left: 50%;
	transform: translateX(-50%);
}
.nav li.has-child .child {
	visibility: hidden;
	opacity: 0;
	display: flex;
	position: absolute;
	top: calc(48px + 2.4rem);
	right: 50;
	box-sizing: border-box;
	width: 25%;
	padding:16px 24px;
	background: rgba(0,0,0,0.8);
	-webkit-transition: all .2s ease;
	transition: all .2s ease;
	z-index: 10;
	flex-direction: column;
    justify-content: center;
	flex-wrap: wrap;
}
.nav li.has-child:hover .child {
	top: calc(48px + .4rem);
	visibility: visible;
	opacity: 1;
}
.nav li.has-child .child li{
	margin: 0;
	position: relative;
	border-top: none;
	box-sizing: border-box;
	padding: 0.8%;
}
.nav li.has-child .child li a{
	padding: 0.64em 0;
	line-height: 1.4;
	box-sizing: border-box;
	border-radius: 6px;
}
.nav li.has-child .child li a:hover{opacity:0.5;}
.nav li.has-child .child li a:after{display: none;}
.nav li.has-child .child li a br{display: block;}


/******************************************************************** container
*/
.catch:before{
	content: "";
	background: url("./img/common/bg_catch.jpg") no-repeat center center / cover;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
}
.catch .cover:before{
	content: "";
	background: url("img/common/p_cover.png") repeat center center / 2px auto;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	opacity: 0.2;
}
.catch .cover:after{
	content: "";
	background: rgba(14,14,14,0.2);
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	mix-blend-mode: hard-light;
	z-index: 1;
}
.index .catch .cover:after{background: rgba(14,14,14,0.5);}
.main section{
	padding:80px 0;
	position:relative;
}
.main section .en{
	line-height: 1.1;
	font-size: 9.6rem;
	font-weight: bold;
	color: #0071AB;
}
.main h1,
.main section h2{
	font-size: 2.4rem;
	font-weight: bold;
	letter-spacing: 0.08em;
	position: relative;
	z-index: 3;
	margin-bottom: 24px;
}
.main section a[target="_blank"]:after{
	content: "";
	display: inline-block;
	background: url("./img/common/ico_blank.svg") no-repeat center center;
	width: 0.8em;
	height: 0.8em;
	margin-left: 0.4em;
}

.btn{
	background: #0E0E0E;
	width:100%;
	max-width: 360px;
	border: none;
	margin: 64px 0 0;
	padding: 0;
	display: block;
	position:relative;
	line-height: 1;
	overflow: hidden;
}
.btn a{
	display: block;
	text-decoration: none;
	font-size: 1.6rem;
	font-weight: bold;
	position: relative;
	line-height: 64px;
	text-align:center;
	z-index: 2;
	overflow: hidden;
}
.btn a:before{
  display: block;
  content: " ";
	position: absolute;
	z-index:10;
	right:8%;
	top:50%;
	width:8px;
	height:12px;
	margin-top: -6px;
	background:url("./img/common/ico_arrow_right_white.svg") no-repeat center center;
	background-size:100% auto;
	box-sizing:border-box;
}
.btn,
.btn a:before,
.btn a:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.btn a:after{
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
	top:0;
	left: -116%;
	width: 120%;
	height: 100%;
	-webkit-transform-origin: 100% 0;
	transform-origin: 100% 0;
	-webkit-transform: skew(-45deg);
	transform: skew(-45deg);
	-webkit-transition: all .5s ease;
	transition: all .5s ease;
	background:#0071AB;
}
.btn a:link,
.btn a:visited{color: #FFF;}
.btn a:hover{color: #FFF; opacity:1;}
.btn a:hover:after{left: 0;}

.btn.black a:hover:before{
	background:url("./img/common/ico_arrow_right_black.svg") no-repeat center center;
	background-size:100% auto;
}
.btn.black a:after{background:#FFF;}
.btn.black a:hover{color: #0E0E0E; opacity:1;}

.btn.back-btn a:before{
	right:inherit;
	left: 8%;
	background:url("./img/common/ico_arrow_left_white.svg") no-repeat center center;
	background-size:100% auto;
}
.btn.back-btn a:after{
	-webkit-transform-origin: 0 0;
	transform-origin: 0 0;
}
.btn.back-btn a:hover:after {
  -webkit-transform-origin: 100% 0;
  transform-origin: 100% 0;
}

.btn.mail-btn a:before{
  display: inline-block;
	position: relative;
	right:auto;
	top:auto;
	width:30px;
	height:22px;
	margin-top: 0;
	margin-right: 0.64em;
	background:url("./img/common/ico_mail_green.svg") no-repeat center center;
	background-size:100% auto;
	vertical-align: -0.1em;
}
.btn.mail-btn a:hover:before{background:url("./img/common/ico_mail_white.svg") no-repeat center center;}

.entry-content table{
	width: 100%;
	margin-bottom: 1.6em;
}
.entry-content table tr th,
.entry-content table tr td{
	padding: 0.4em;
	border: #EEE 1px solid;
	text-align: center;
}
.entry-content table tr th{font-weight: bold;}

.column .wrapper{
	display: flex;
	justify-content: space-between;
}
.column .wrapper .ttl-column{width: 24%;}
.column .wrapper .main-column{width: 70%;}
.main section.column .en{
	font-size: 5.6rem;
	word-break: break-all;
}
.main section.column h2{margin-bottom: 0;}


/******************************************************************** footer
*/
footer{position: relative;}

footer .sitemap{
	background: #0071ab;
	background: -moz-linear-gradient(left,  #0071ab 0%, #194ab8 100%);
	background: -webkit-linear-gradient(left,  #0071ab 0%,#194ab8 100%);
	background: linear-gradient(to right,  #0071ab 0%,#194ab8 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0071ab', endColorstr='#194ab8',GradientType=1 );
	color: #FFF;
}
footer .wrapper{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 120px 0;
}
footer .sitemap .wrapper .footer-contact{width: 31.25%;}
footer .sitemap .wrapper .footer-contact .en{
	line-height: 1.1;
	font-size: 8rem;
	font-weight: bold;
	margin-bottom: 48px;
}
footer .sitemap .wrapper .footer-contact .contact a{
	border: #FFF 1px solid;
	padding: 0.8em 1em;
	padding-top: calc(0.7em - 1px);
	padding-bottom: calc(0.7em - 1px);
	border-radius: 2em;
	position: relative;
	color: #FFF;
	text-decoration: none;
	display: block;
	text-align: center;
	box-sizing: border-box;
	max-width: 320px;
}
footer .sitemap .wrapper .footer-contact .contact a:after{
	content: "";
	background: url("img/common/ico_arrow_right_white.svg") no-repeat center center;
	width: 6px;
	height: 1em;
	display: inline-block;
	position: absolute;
	right: 1.6em;
	top: 50%;
	transform: translateY(-50%);
}

footer .sitemap .wrapper .nav-box{
	width: 62.5%;
	max-width: 600px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}
footer .sitemap .wrapper .nav{
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	width: 100%;
	height: 13em;
}
footer .sitemap .wrapper .nav li a{
	padding: 0 0 1.2em;
	font-size: 1.6rem;
	color: #FFF;
	font-weight: bold;
}
footer .sitemap .wrapper .nav li .child{
	padding-left: 1em;
	position: relative;
}
footer .sitemap .wrapper .nav li .child:before{
	content: "";
	display: block;
	background: #9B9B9B;
	width: 1px;
	height: 100%;
	position: absolute;
	left: 0;
	top: -0.5em;
}

footer .company{
	background: #0B76AF;
	background: -moz-linear-gradient(left,  #0B76AF 0%, #2C4DBD 100%);
	background: -webkit-linear-gradient(left,  #0B76AF 0%,#2C4DBD 100%);
	background: linear-gradient(to right,  #0B76AF 0%,#2C4DBD 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0B76AF', endColorstr='#2C4DBD',GradientType=1 );
	color: #FFF;
}
.foot-copy{
	color: #AFAFAF;
	font-size: 1.4rem;
	margin-top: 48px;
}
footer .company .module{
	width: 65.625%;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
footer .company .module ul{
	display: flex;
	flex-wrap:wrap; 
}
footer .company .module ul li{
	/*width: 50%;*/
	margin-top: 2.4em;
}
footer .company .module ul li:nth-child(-n +2){margin-top: 0;}
footer .company .module ul li h3{
	font-weight: bold;
	margin-bottom: 0.4em;
}
footer .company .module .btn{margin-top: 0;}
footer .company .module .txt{
	margin-top: 48px;
	text-align: right;
}
footer .company .module .txt a{
	color: #FFF;
	text-decoration: none;
}
footer .company .module .txt a:after{
	content: "";
	background: url("img/common/ico_arrow_right_white.svg") no-repeat center center;
	width: 6px;
	height: 1em;
	display: inline-block;
	vertical-align: -0.1em;
	margin-left: 1em;
}
.pageup{
	position: absolute;
	left: 0;
	top: 0;
	text-align: center;
	width: 8%;
	height: 100%;
	background: #FFF;
}
.index .pageup{background: #EDF5F9;}
.pageup a {
	display: block;
	text-decoration: none;
	height: 100%;
	width: 100%;
	position: relative;
	padding-top: 96px;
	box-sizing: border-box;
}
.pageup a:after {
	content: "";
	background: url("img/common/ico_pageup.svg") no-repeat center center;
	width: 9px;
	height: 64px;
	display: inline-block;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-9px);
}
.pageup a img{width: 13px;}

@media screen and (max-width:1520px) {footer{padding-left: 8%;}}


/*************************************************************************************************************************

■ タブレット(1080px以下)向けスタイル

*************************************************************************************************************************/

@media screen and (max-width:1080px) {
/******************************************************************** structure
*/
a{
	-webkit-transition: none;
	transition: none;
}
a:hover{opacity: 1;}
.pc_none{display: block !important;}
.tb_none{display:none !important;}

/******************************************************************** globalNav
*/
.nav-wrap .nav{
	padding-top: 60px;
	border-radius: 0;
	background: #333;
	height: 100%;
	box-sizing: border-box;
	display: block;
}
.nav > li{border-top: #434343 1px solid;}
.nav > li:last-child{border-bottom: #434343 1px solid;}
.nav a{font-size: 1.6rem; padding: 1.078em 1em; color: #FFF;}
.nav .contact a {
	border: none;
	padding: 1.078em 1em;
	border-radius: 0;
}
.nav a:after,
.nav .contact a:after,
.nav li.has-child .child li a:after{
	display: inline-block;
	content: "";
	background:url("./img/common/ico_arrow_right_white.svg") no-repeat center center;
	background-size: 100% auto;
	width: 8px;
	height: 12px;
	position: absolute;
	right: 1.35em;
	top: 50%;
	margin-top: -6px;
	transform: none;
}
.nav li.has-child{border-top: none;}
.nav li.has-child > a{display: none;}
.nav li.has-child > a:after {display: none;}
.nav li.has-child .child{
	visibility: visible;
	opacity: 1;
	position: relative;
	top: auto;
	left: auto;
	padding: 0;
	width: 100%;
	border-radius: 0;
	display: block;
	background: transparent;
}
.nav li.has-child .child:before {display: none;}
.nav li.has-child:hover .child{top: auto;}
.nav li.has-child .child li{
	width: 100%;
	padding: 0;
	border-top: #434343 1px solid;
}
.nav li.has-child .child li a{
	font-size: inherit;
	padding: 1.078em 1em !important;
	text-align: left;
	border-radius: 0;
}
.nav li.has-child.owner .child li a:before {display: none;}

.nav-button {
	display: block;
	cursor: pointer;
}
.nav-wrap {
	position: fixed;
	left: 0;
	top: 0;
	display: none;
	z-index: 100;
	background-color:#FFF;
	width: 100%;
	height: 100%;
	overflow: auto;
}
.nav-wrap.open {display: block;}
.nav-wrap.close {display: none;}

/*メニューボタンのエフェクト*/
.nav-button,
.nav-button span {
	display: inline-block;
	transition: all 0.4s;
	box-sizing: border-box;
}
.nav-button {
	z-index: 120;
	position: fixed;
	right: 0;
	top: 0;
	width: 60px;
	height: 60px;
	background:#FBFBFB;
	text-decoration: none;
	display: flex;
	justify-content: center;
	align-items: center;
}
.nav-button div{
	position: relative;
	width: 60px;
	height: 60px;
}
.nav-button div:after {
	display: inline-block;
	content: "メニュー";
	color: #333;
	font-size: 12px;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	text-align: center;
}
.nav-button span {
	position: absolute;
	left: 20%;
	width: 60%;
	height: 3px;
	background-color: #333;
	border-radius: 2px;
}
.nav-button span:nth-of-type(1) {top: 12px;}
.nav-button span:nth-of-type(2) {top: 22px;}
.nav-button span:nth-of-type(3) {bottom: 24px;}
.nav-button.active span:nth-of-type(1) {
	-webkit-transform: translateY(10px) rotate(-45deg);
	transform: translateY(10px) rotate(-45deg);
}
.nav-button.active span:nth-of-type(2) {opacity: 0;}
.nav-button.active span:nth-of-type(3) {
	-webkit-transform: translateY(-10px) rotate(45deg);
	transform: translateY(-10px) rotate(45deg);
}
.nav-button.active div:after {content: "閉じる";}
.nav-button:hover,
.nav-button:active{opacity: 1;}

/******************************************************************** header
*/
.mv:before{width: 64%;}
.mv .head-info{
	padding: 0 4vmin;
	width: calc(100% - 60px);
	margin: 0;
	box-sizing: border-box;
	height: 60px;
}
.head-info nav {
	width: 100%;
	max-width: 100%;
}
.mv .head-info .btn{display: none;}
.search-container{
	position: absolute;
	top: 0;
	right: 0;
}

.catch{padding: 16vmin 0;}
/*.catch .ttl-area{width: 100%;}*/
.catch .en{
	font-size: 6.4vmin;
	margin-bottom: 0;
}
.single .catch{padding: 6.4vmin 0;}

/******************************************************************** container
*/
.main section{padding: 12vmin 0;}
.main section .ttl-area{margin-bottom: 4.8vmin;}
.main section .en{font-size: 8rem;}
.main h1,
.main section h2{
	font-size: 3.2rem;
	margin-bottom: 2.4vmin;
}
.main section .ttl-area:after{margin-top: 2.4vmin;}
.catch h2{font-size: 2.4rem;}
.breadcrumb{font-size: 1.6rem;}

.btn{margin-top: 4vmin;}
.btn,
.btn a:before,
.btn a:after{
	-webkit-transition: none;
	transition: none;
}

.meta .time{margin-top: 1.6vmin;}

.column .wrapper{flex-direction: column;}
.column .wrapper .ttl-column,
.column .wrapper .main-column{width: 100%;}


/******************************************************************** footer
*/

footer .wrapper{
	padding: 9.6vmin 0;
	flex-direction: column;
}
footer .sitemap .wrapper .footer-contact{
	width: 100%;
	margin-bottom: 4.8vmin;
}
footer .sitemap .wrapper .footer-contact .en{margin-bottom: 4.8vmin;}
footer .logo {margin-bottom: 4.8vmin;}
footer .sitemap .wrapper .about .tel{margin-top: 4.8vmin;}
footer .sitemap .wrapper .nav-box{
	flex-direction: column;
	width: 100%;
	max-width: 100%;
}
footer .sitemap .wrapper .nav{
	width: 100%;
	height: auto;
	flex-direction: row;
}
footer .sitemap .wrapper .nav{justify-content: space-between;}
footer .sitemap .wrapper .nav li{
	width: 100%;
	text-align: left;
	border-top: none;
	border-bottom: #007EC6 1px solid;
}
footer .sitemap .wrapper .nav li a{
	padding: 1.078em 1em;
	position: relative;
}
footer .sitemap .wrapper .nav li a:before {display: none; border: none;}
footer .sitemap .wrapper .nav li a:after {
	margin-top: 0;
	top: auto;
	bottom: 1.4em;
}
footer .sitemap .wrapper .nav li .child{padding-left: 0;}
footer .sitemap .wrapper .nav li .child:before{display: none;}
footer .sitemap .wrapper .nav li .child li{
	border-top: #007EC6 1px solid;
	border-bottom: none;
}
footer .sitemap .wrapper .nav li .child li a:before{
	content: "";
	width: 0.8em;
	height: 2px;
	background: #FFF;
	display: inline-block;
	vertical-align: middle;
	margin-right: 0.6em;
}
footer .company .wrapper{flex-direction: column-reverse;}
footer .company .head{
	width: 100%;
	text-align: center;
	margin-top: 9.6vmin;
}
footer .company .module{
	width: 100%;
	flex-direction: column;
}
footer .company .module ul{justify-content: space-between;}
footer .company .module ul li{width: 100%;}
footer .company .module .btn,
footer .company .module .txt{margin-top: 4.8vmin;}

.foot-copy{
	line-height: 1.4;
	padding: 2.4vmin 0;
	margin-top: 4vmin;
}
}




/*************************************************************************************************************************

■ スマホ(600px以下)向けスタイル

*************************************************************************************************************************/


@media screen and (max-width:600px) {
/******************************************************************** structure
*/
a[href^="tel:"] {pointer-events: auto; color:#0083E5; text-decoration: underline;}

.sp_none{display:none !important;}
.sp_only{display:block!important;}

body{font-size: 4vmin;}

/******************************************************************** header
*/
.mv .head-info{padding: 0; height: 60px;}
.mv .head-info .logo{margin-left: 4vmin;}
.mv .head-info .logo img{max-width: 100%;}
.mv .head-info .tel-box{display: none;}

.catch{padding: 20vmin 0 12vmin;}
.catch .en{font-size: 8vmin;}
.catch h2{
	font-size: 4vmin;
	line-height: 1.8;
}
.catch h2 br{display: block;}

/******************************************************************** globalNav
*/
.nav-wrap{background: #333;}
.nav-wrap .nav{display: block;}
.nav > li{width: 100%;}
.nav a,
.nav li.has-child .child li a{font-size: 4.4vmin;}


/******************************************************************** container
*/
.main section{font-size: 4vmin;}
.main section .en {font-size: 16vmin;}
.main section .ttl-area h2{font-size: 6.8vmin;}
.main h1, .main section h2 {font-size: 6.8vmin;}

button,
.btn{
	width: 92%;
	margin-left: auto;
	margin-right: auto;
}
button a,
.btn a{
	line-height: 56px;
	font-size: 4.4vmin;
}
.breadcrumb{font-size: 3.2vmin;}

.pager > *{padding: 0.435em 0;}

.contact-contents .tel-box{
	position: relative;
	z-index: 3;
	margin-top: 4.8vmin;
}
.contact-contents .wrapper{text-align: center;}
.contact-contents h2{font-size: 6.8vmin;}
.contact-contents .txt{
	font-size: 4.4vmin;
	position: relative;
	z-index: 3;
}
.contact-contents .tel-box .add{font-size: 4.4vmin;}
.contact-contents .tel-box .tel{font-size: 7.2vmin;}
.contact-contents .tel-box .tel:before{display: none;}
.contact-contents .tel-box .tel a{
	line-height: 64px;
	border-radius: 32px;
	background: #FFF;
	color: #044EAC;
	text-decoration: none;
	display: block;
}
.tel-box .tel a:before {
  content: "";
  /*background: url("./img/common/ico_freedial_blue.svg") repeat center center;*/
  background: url("./img/common/ico_tel_blue.svg") no-repeat center center;
  background-size: 100% auto;
  /*width: 37px;*/
  width: 19px;
  height: 24px;
  display: inline-block;
  margin-right: 0.2em;
  vertical-align: -0.1em;
}
.contact-contents button{
	margin-top: 6.4vmin;
	width: 100%;
}
.contact-contents button a{
	font-size: 4.8vmin;
	line-height: 64px;
}
.contact-contents button a:before {
	width: 1.4em;
	height: 1.4em;
	margin-right: 0.4em;
	vertical-align: -0.3em;
}
.contact-contents button a .free{font-size: 4.4vmin;}
.contact-contents button a span.sp_none{display: none !important;}

.meta .cat-list li{
	font-size: 4vmin;
	margin-top: 8px;
}

.main section.column .en{font-size: 9.6vmin;}
.main section .ttl-area h2{font-size: 6.4vmin;}


/******************************************************************** footer
*/
footer .sitemap .wrapper .footer-contact .en{font-size: 14.4vmin;}
footer .sitemap .wrapper{
	padding: 9.6vmin 0 0;
	width: 100%;
	display: block;
}
footer .sitemap .wrapper .footer-contact{
	width: 92%;
	margin: 0 auto;
	padding-bottom: 9.6vmin;
	text-align: center;
}
footer .sitemap .wrapper .footer-contact .contact{margin: 0 auto;}
footer .sitemap .wrapper .footer-contact .contact a{margin: 0 auto;}
footer .sitemap .wrapper .about{
	width: 92%;
	margin: 0 auto 9.6vmin;
}
footer .logo{line-height: 0;}
footer .sitemap .wrapper .about .tel{font-size: 8vmin;}
footer .sitemap .wrapper .about .tel a[href^="tel:"] {color: #FFF;}
footer .sitemap .wrapper .nav-box{width: 100%;}
footer .sitemap .wrapper .nav-box .ttl{
	background: #044EAC;
	color: #FFF;
	text-align: center;
	margin: 0;
	padding: 1em;
	font-size: 4.8vmin;
}
footer .sitemap .wrapper .nav{display: block;}
footer .sitemap .wrapper .nav li{
	width: 100%;
	text-align: left;
}
footer .sitemap .wrapper .nav:first-of-type li{background: #1a2028; border-bottom: #29323E 1px solid;}
footer .sitemap .wrapper .nav li .child li {
	border-top: none;
	border-bottom: #29323E 1px solid;
}
footer .sitemap .wrapper .nav:first-of-type li:first-child {border-top: #29323E 1px solid;}
footer .sitemap .wrapper .nav li a{font-size: 4vmin;}
footer .sitemap .wrapper .nav li a:before {
  width: 25.6vw;
  height: 16vw;
  border-radius: 6px;
	vertical-align: middle;
	margin-right: 0.5em;
}
footer .sitemap .wrapper .nav li a:after {
	top: 50%;
	margin-top: -6px;
}
footer .company .module ul li {
	width: 100%;
	margin-top: 1.6em;
}
footer .company .module ul li:nth-child(-n+2) {margin-top: 1.6em;}
footer .company .module ul li h3{font-size: 4.8vmin;}
.foot-copy{
	margin-top: 0;
	padding: 0;
	text-align: center;
	font-size: 4vmin;
	box-sizing: border-box;
}

}