/* CSS Document */

@import url(https://fonts.googleapis.com/css?family=Oswald:400,700,300);

/* [ Utility and Reset css ]
===================================================================== */
html,button,input,select,textarea { color: #000; }
html { -webkit-text-size-adjust: 100%; -moz-text-size-adjust: 100%; -ms-text-size-adjust: 100%; -o-text-size-adjust: 100%; text-size-adjust: 100%; font-size: 100%; }
*, *:before, *:after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
::-moz-selection { background: #777; color: #fff; text-shadow: none; }
::selection { background: #777; color: #fff; text-shadow: none; }
input::selection, textarea::selection {  color: #000; }
hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }
audio,canvas,img,video { vertical-align: middle; }
.ie7 .title { padding-top: 20px; }
fieldset {  border: 0; margin: 0; padding: 0; }
textarea { resize: vertical; }

/* [ Reset css ] -------------------------------------------------- */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video{ margin:0; padding:0; border:0; outline:0; font-size:100%; vertical-align:baseline; background:transparent; }
table,div,ul,ol,li,dl,dt,dd{ list-style: none; margin: 0; padding: 0; }
table{ border-collapse:collapse; border-spacing:0; }
article,aside,details,figcaption,figure, footer,header,hgroup,menu,nav,section { display:block; }
nav ul,li { list-style:none; }

/* [ Helper class ] -------------------------------------------------- */
.ir { background-color: transparent; border: 0; overflow: hidden; *text-indent: -9999px; }
.ir:before { content: ""; display: block;  width: 0;  height: 150%; }
.hidden { display: none !important; visibility: hidden; }
.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute;  width: 1px; }
.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; }
.invisible { visibility: hidden; }
/* clearfix */
.cf:before, .cf:after { content: " ";  display: table; }
.cf:after { clear: both; }
.cf { *zoom: 1; }

img { max-width: 100%; height: auto; margin: 0; padding: 0; border:0; outline: none; border-style: none; vertical-align: bottom; line-height: 0; }
img,iframe,object { max-width:100%; }	/* モダンブラウザ用 */
.ie7 img,.ie8 object { width:100%; }	/* IE7用 */
.ie8 img,.ie8 object { width:auto; }	/* IE8用 */


/* [ Parts ]
===================================================================== */
/* space */
.ma0{margin: 0 !important;}.m5 {margin:5px;}.m10 {margin:10px;}.m15 {margin:15px;}.m20 {margin:20px;}.m25 {margin:25px;}.m30 {margin:30px;}.m35 {margin:35px;}.m40 {margin:40px;}.m45 {margin:45px;}.m50 {margin:50px;}.m55 {margin:55px;}.m60 {margin:60px;}.mt5 {margin-top:5px;}.mt10 {margin-top:10px;}.mt15 {margin-top:15px;}.mt20 {margin-top:20px;}.mt25 {margin-top:25px;}.mt30 {margin-top:30px;}.mt35 {margin-top:35px;}.mt40 {margin-top:40px;}.mt45 {margin-top:45px;}.mt50 {margin-top:50px;}.mt55 {margin-top:55px;}.mt60 {margin-top:60px;}.mr5 {margin-right:5px;}.mr10 {margin-right:10px;}.mr15 {margin-right:15px;}.mr20 {margin-right:20px;}.mr25 {margin-right:25px;}.mr30 {margin-right:30px;}.mr35 {margin-right:35px;}.mr40 {margin-right:40px;}.mr45 {margin-right:45px;}.mr50 {margin-right:50px;}.mr55 {margin-right:55px;}.mr60 {margin-right:60px;}.mb5 {margin-bottom:5px;}.mb10 {margin-bottom:10px;}.mb15 {margin-bottom:15px;}.mb20 {margin-bottom:20px;}.mb25 {margin-bottom:25px;}.mb30 {margin-bottom:30px;}.mb35 {margin-bottom:35px;}.mb40 {margin-bottom:40px;}.mb45 {margin-bottom:45px;}.mb50 {margin-bottom:50px;}.mb55 {margin-bottom:55px;}.mb60 {margin-bottom:60px;}.ml5 {margin-left:5px;}.ml10 {margin-left:10px;}.ml15 {margin-left:15px;}.ml20 {margin-left:20px;}.ml25 {margin-left:25px;}.ml30 {margin-left:30px;}.ml35 {margin-left:35px;}.ml40 {margin-left:40px;}.ml45 {margin-left:45px;}.ml50 {margin-left:50px;}.ml55 {margin-left:55px;}.ml60 {margin-left:60px;}.pt0{padding-top: 0 !important;}.p5 {padding:5px;}.p10 {padding:10px;}.p15 {padding:15px;}.p20 {padding:20px;}.p25 {padding:25px;}.p30 {padding:30px;}.p35 {padding:35px;}.p40 {padding:40px;}.p45 {padding:45px;}.p50 {padding:50px;}.p55 {padding:55px;}.p60 {padding:60px;}.pt5 {padding-top:5px;}.pt10 {padding-top:10px;}.pt15 {padding-top:15px;}.pt20 {padding-top:20px;}.pt25 {padding-top:25px;}.pt30 {padding-top:30px;}.pt35 {padding-top:35px;}.pt40 {padding-top:40px;}.pt45 {padding-top:45px;}.pt50 {padding-top:50px;}.pt55 {padding-top:55px;}.pt60 {padding-top:60px;}.pr5 {padding-right:5px;}.pr10 {padding-right:10px;}.pr15 {padding-right:15px;}.pr20 {padding-right:20px;}.pr25 {padding-right:25px;}.pr30 {padding-right:30px;}.pr35 {padding-right:35px;}.pr40 {padding-right:40px;}.pr45 {padding-right:45px;}.pr50 {padding-right:50px;}.pr55 {padding-right:55px;}.pr60 {padding-right:60px;}.pb5 {padding-bottom:5px;}.pb10 {padding-bottom:10px;}.pb15 {padding-bottom:15px;}.pb20 {padding-bottom:20px;}.pb25 {padding-bottom:25px;}.pb30 {padding-bottom:30px;}.pb35 {padding-bottom:35px;}.pb40 {padding-bottom:40px;}.pb45 {padding-bottom:45px;}.pb50 {padding-bottom:50px;}.pb55 {padding-bottom:55px;}.pb60 {padding-bottom:60px;}.pl5 {padding-left:5px;}.pl10 {padding-left:10px;}.pl15 {padding-left:15px;}.pl20 {padding-left:20px;}.pl25 {padding-left:25px;}.pl30 {padding-left:30px;}.pl35 {padding-left:35px;}.pl40 {padding-left:40px;}.pl45 {padding-left:45px;}.pl50 {padding-left:50px;}.pl55 {padding-left:55px;}.pl60 {padding-left:60px;}


/* [ Font Setting ]
===================================================================== */

html{ font-size: 62.5%; }
body { -webkit-text-size-adjust: 100%; text-rendering: optimizeLegibility; }

P{ margin: 0; padding: 0; }
p img{ vertical-align: middle; /*max-width: 100%;*/ }


/* [ Link ] -------------------------------------------------- */
a { -webkit-tap-highlight-color: rgba(193, 240, 231, 0.2); color: #333; text-decoration: none; }
a:visited { color: #333; }
a:hover { color: #333; text-decoration: none; }
a:active { color: #333; }

a img:hover{ opacity: 0.8; filter:alpha(opacity=80); -moz-opacity: 0.8; }
a img { text-decoration: none; outline: none; }
a img::before,a img::after { position: absolute; z-index: -1; display: block; content: ''; }
a img, a img::before, a img::after { -webkit-transition: all .2s; transition: all .2s; }

a.out_links{
	background: url(../img/common/ic_out_links.svg) right center no-repeat;
	background-size: 12px;
	padding-right: 16px;
	margin-right: 4px;
}


/* [ HTML,Body ]
===================================================================== */

html,body{
	height: 100% !important;
}
body{
	font-size: 14px; 
	line-height: 26px;
	letter-spacing: 0.05em;
	color: #343434;
	font-weight: normal;
	word-wrap: break-word;
	font-family: "Hiragino Kaku Gothic Pro", 'ヒラギノ角ゴ ProN W3', "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	background-color: #fff;
}
#wrapper{
	width: 100%;
	min-width: 1100px;
	height: auto;
	overflow: hidden;
	padding: 0;
	margin: 0 auto;
	text-align: center;
	position: relative;
}

@media screen and (max-width: 960px){
	body{
		font-size: 13px; 
		line-height: 22px;
	}
	#wrapper{
		min-width: 100%;
	}
}
@media screen and (max-width: 650px){
	body{
		font-size: 12px; 
		line-height: 20px;
	}
}

/* [ Bace ]
===================================================================== */

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

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

/* 見出し */
.font_os{
	font-family: "Oswald", sans-serif;
}

h2.headline{
	width: 900px;
	margin: 0 auto 40px;
	color: #000;
	font-size: 20px;
	text-align: left;
	position: relative;
	padding-bottom: .7em;
	border-bottom: 2px solid #ddd;
	letter-spacing: .06em;
}
h2.headline::after {
	position: absolute;
	bottom: -2px;
	left: 0;
	z-index: 2;
	content: '';
	width: 10%;
	height: 2px;
	background-color: #000;
}
h3.subhead{
	width: 900px;
	height: 42px;
	line-height: 42px;
	padding-left: 20px;
	margin: 0 auto 20px;
	color: #fff;
	background-color: #343434;
	font-size: 16px;
	text-align: left;
	position: relative;
}

/* ページトップ */
.pagetop{
	display: none;
	position: fixed;
	bottom: 10px;
	right: 10px;
	z-index: 1000;
}
.pagetop a{
	display: block;
	width: 46px;
	height: 46px;
}

/* MORE ボタン */
.btn_more a{
	display: block;
	width: 200px;
	height: 50px;
	line-height: 50px;
	padding-left: 68px;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 0.2em;
}
.btn_more a span{
	font-size: 15px;
	padding-left: 42px;
}
.btn_more a { position: relative; display: inline-block; text-align: center; text-decoration: none; outline: none; overflow: hidden; transition: all .5s; }
.btn_more a::before, .btn_more a::after { position: absolute; display: block; content: ''; width: 100%; height: 100%; transition: all .5s; }
.btn_more a::before { top: 0; left: 0; }
.btn_more a::after { right: 0; bottom: 0; }
.btn_more a:hover { transition: all .6s; }
.btn_more a:hover::before, .btn_more a:hover::after { width: 0; height: 0; opacity: 0; transition: all .6s; }

@media screen and (max-width: 960px){
	h2.headline{
		width: 100%;
		margin: 0 auto 3%;
		font-size: 18px;
	}
	h2.headline::after {
		width: 15%;
	}
	h3.subhead{
		width: 100%;
		padding-left: 10px;
		margin: 0 auto 2%;
	}
}
@media screen and (max-width: 650px){
	h2.headline{
		margin: 0 auto 5%;
		font-size: 15px;
	}
	h2.headline::after {
		width: 20%;
	}
	h3.subhead{
		height: 40px;
		line-height: 40px;
		margin: 0 auto 3%;
		font-size: 14px;
	}
	.btn_more a{
		width: 100px;
		height: 40px;
		line-height: 40px;
		padding-left: 10px;
		font-size: 12px;
	}
	.btn_more a span{
		font-size: 12px;
		padding-left: 6px;
	}
}

/* [ Header ]
===================================================================== */

/* [ index gloval nav ] -------------------------------------------------- */

#header{
	width: 100%;
	height: 110px;
	position: absolute;
	top: 0;
	z-index: 10;
}
.header_nav{
	position: relative;
	float: right;
	width: 100%;
	margin: 0 auto;
}
.header_nav .logo{
	float: left;
	width: 26%;
	text-align: left;
}
.header_nav .logo img{
	width: 250px;
	height: auto;
	margin: 36px 0 0 36px;
}
.header_nav .menu{
	float: right;
	width: 74%;
}
.header_nav li a{
	color: #fff;
	font-weight: bold;
}
.global_nav{
	float: right;
	width: auto;
	height: 110px;
	margin-right: 270px;
	display: table;
	border-collapse: separate;
	border-spacing: 8px 0;
}
.global_nav li{
	display: table-cell;
	padding-top: 44px;
}
.global_nav li a{
	padding: 10px 4px;
}
.global_nav li a:hover{ opacity: 0.5; filter:alpha(opacity=50); -moz-opacity: 0.5; }
.global_nav li a { text-decoration: none; outline: none; }
.global_nav li a::before,.global_nav li a::after { position: absolute; z-index: -1; display: block; content: ''; }
.global_nav li a, .global_nav li a::before, .global_nav li a::after { -webkit-transition: all .2s; transition: all .2s; }

.global_nav .out_link_top{
	padding-right: 12px;
	background: url(../img/common/icon_out_link_top.svg) right center no-repeat;
	background-size: 10px;
}
.contact_nav{
	position: absolute;
	right: 0;
	width: 241px;
}
.contact_nav li{
	float: left;
}
.contact_nav .list_1{
	background: url(../img/common/icon_partner.png) center 1.6em no-repeat;
	background-color: #6e6e6e;
}
.contact_nav .list_2{
	background: url(../img/common/icon_mail.png) center 2em no-repeat;
	background-color: #343434;
	margin-left: 1px;
}
.contact_nav li a{
	display: block;
	width: 120px;
	height: 110px;
	padding-top: 5em;
	font-size: 13px;
}
.contact_nav li:hover{ opacity: 0.8; filter:alpha(opacity=80); -moz-opacity: 0.8; }
.contact_nav li { text-decoration: none; outline: none; }
.contact_nav li::before, .contact_nav li::after { position: absolute; z-index: -1; display: block; content: ''; }
.contact_nav li, .contact_nav li::before, .contact_nav li::after { -webkit-transition: all .2s; transition: all .2s; }

@media screen and (max-width: 1250px){
	.global_nav{
		border-spacing: 2px 0;
	}
	.global_nav li{
		font-size: 13px;
	}
}
@media screen and (max-width: 1120px){
	.global_nav{
		border-spacing: 0;
	}
}	
@media screen and (max-width: 960px){
	#header{
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 60px;
		border-bottom: 1px solid #ddd;
	    background-color: #fff;
	}
	.header_nav{
		float: none;
		width: 100%;
		height: 100%;
	}
	.header_nav .logo{
		width: auto;
		padding-left: 3%;
	}
	.header_nav .logo img{
		width: 190px;
		margin: 14px 0 0;
	}
	.header_nav .menu{
		float: right;
		width: 74%;
	}
	.header_nav li a{
		color: #fff;
		font-weight: bold;
	}
	.global_nav{
		float: none;
		display: none;
		position: fixed;
		top: 60px;
		left: 0;
		width: 100%;
		height: 100%;
		padding: 0;
		margin: 0 auto;
		background-color: #fff;
		border-top: 1px solid #eee;
	}
	.global_nav li{
		position: relative;
		display: block;
		float: left;
		width: 50%;
		padding: 0;
		line-height: 60px;
		text-align: left;
		border-bottom: 1px solid #eee;
		border-left: 1px solid #eee;
	}
	.global_nav li a{
	    position: relative;
		display: block;
		padding: 0 0 0 16px;
		color: #333;
		background: url(../img/common/icon_menu_arrow.svg) 96% center no-repeat;
		background-size: 8px;
	}
	.global_nav .out_link_top{
		padding: 0;
		background: url(../img/common/icon_out_link.svg) 76px center no-repeat;
		background-size: 10px;
	}
	.contact_nav{
		display: none;
		position: fixed;
		top: 244px;
		width: 100%;
	}
	.contact_nav li{
		float: left;
		width: 50%;
		padding: 0;
	}
	.contact_nav .list_1{
		background: url(../img/common/icon_partner.png) center 18px no-repeat;
		background-color: #6e6e6e;
		background-size: 26px auto;
	}
	.contact_nav .list_2{
		background: url(../img/common/icon_mail.png) center 21px no-repeat;
		background-color: #343434;
		background-size: 26px auto;
		margin: 0;
	}
	.contact_nav li a{
		width: 100%;
		height: 90px;
		padding-top: 50px;
	}
	#menu_btn{
	    display: block;
	    position: fixed;
	    top: 8px;
	    right: 10px;
	    width: 42px;
	    height: 42px;
	    z-index: 9999;
	}
	#menu_btn span{
	    display: block;
	    position: absolute;
	    left: 10px;
	    width: 24px;
	    height: 2px;
	    background-color: #000;
	    transition: all 0.4s;
	    -webkit-transition: all 0.4s;
	    -moz-transition: all 0.4s;
	}
	#menu_btn p{ -webkit-transition: all 0.4s; -moz-transition: all 0.4s; transition: all 0.4s; -moz-transition-delay: 0.5s; -webkit-transition-delay: 0.5s; transition-delay: 0.5s; }
	#menu_btn span:first-child { top: 12px;}
	#menu_btn span:nth-child(2) { margin-top: -1px; top: 50%;}
	#menu_btn span:nth-child(3) { bottom: 12px;}
	#menu_btn.active span:first-child { -webkit-transform: translateY(8px) rotate(45deg);  -moz-transform: translateY(8px) rotate(45deg); transform: translateY(8px) rotate(45deg); }
	#menu_btn.active span:nth-child(2) { opacity: 0;}
	#menu_btn.active span:nth-child(3) { -webkit-transform: translateY(-8px) rotate(-45deg); -moz-transform: translateY(-8px) rotate(-45deg); transform: translateY(-8px) rotate(-45deg); }
}

@media screen and (max-width: 650px){
	.header_nav .logo img{
		width: 160px;
		margin: 18px 0 0;
	}
	.global_nav li{
		line-height: 50px;
	}
	.global_nav li a{
		background-size: 7px;
	}
	.contact_nav{
		top: 214px;
	}
	.contact_nav .list_1{
		background: url(../img/common/icon_partner.png) center 16px no-repeat;
		background-color: #6e6e6e;
		background-size: 24px auto;
	}
	.contact_nav .list_2{
		background: url(../img/common/icon_mail.png) center 19px no-repeat;
		background-color: #343434;
		background-size: 24px auto;
		margin: 0;
	}
	.contact_nav li a{
		height: 80px;
		padding-top: 46px;
		font-size: 12px;
	}
}

/* [ Footer ]
===================================================================== */

.footer{
	position: relative;
	width: 100%;
	height: auto;
	margin: 0 auto;
	color: #fff;
	background-color: #000;
}
.fooer_main{
	position: relative;
	width: 100%;
	padding-top: 44px;
	margin: 0 auto;
	text-align: left;
}
.fooer_main .company_info{
	float: left;
	width: 30%;
	height: 310px;
	padding-left: 36px;
}
.fooer_main .company_info .footer_logo img{
	width: 250px;
	height: auto;
}
.fooer_main .company_info .address{
	width: 270px;
	padding: 24px 0 0;
	font-size: 13px;
	line-height: 22px;
	color: #999;
}
.fooer_main .company_info .address a{
	color: #999;
	text-decoration: underline;
}
.fooer_main .sitemap{
	float: right;
	padding-right: 5%;
}
.sitemap .list_1, .sitemap .list_2{
	float: left;
}
.sitemap dl{
	float: left;
	width: auto;
	padding-left: 50px;
}
.sitemap dt{
	font-size: 13px;
	line-height: 38px;
}
.sitemap dt a{
	color: #fff;
	display: block;
}
.sitemap dt.out_link a{
	padding: 10px 16px 0 0;
	background: url(../img/common/icon_out_link_top.svg) right 22px no-repeat;
	background-size: 10px;
}
.sitemap dd{
	font-size: 12px;
}
.sitemap dd a{
	color: #999;
}
.footer_bottom{
	width: 100%;
	height: 100px;
	line-height: 100px;
	border-top: 1px solid #222;
}
.footer_bottom .copy{
	color: #545454;
	font-size: 11px;
	letter-spacing: 0.1em;
}

@media screen and (max-width: 960px){
	.fooer_main{
		width: 94%;
		padding: 4% 0 5%;
	}
	.fooer_main .company_info{
		float: none;
		width: 100%;
		height: auto;
		padding: 0 0 4%;
	}
	.fooer_main .company_info .footer_logo img{
		width: 190px;
	}
	.fooer_main .company_info .address{
		width: 100%;
		padding: 14px 0 0;
		font-size: 12px;
		line-height: 20px;
	}
	.fooer_main .sitemap{
		float: none;
		width: 100%;
		padding: 0;
	}
	.sitemap .list_1, .sitemap .list_2{
		float: none;
	}
	.sitemap dl{
		padding: 0 8% 0 0;
	}
	.sitemap dd{
		line-height: 28px;
	}
	.footer_bottom{
		height: 80px;
		line-height: 80px;
	}
}
@media screen and (max-width: 650px){
	.fooer_main{
		padding: 6% 0;
	}
	.fooer_main .company_info .footer_logo img{
		width: 160px;
	}
	.fooer_main .company_info .address{
		font-size: 11px;
	}
	.sitemap .list_1, .sitemap .list_2{
		float: left;
		width: 50%;
	}
	.sitemap dl{
		padding: 0;
	}
	.sitemap dt{
		font-size: 12px;
		line-height: 34px;
	}
	.sitemap dd{
		line-height: 26px;
	}
	.footer_bottom{
		height: 60px;
		line-height: 60px;
	}
	.footer_bottom .copy{
		font-size: 9px;
		padding-left: 4%;
		text-align: left;
	}
}