@charset "utf-8";

/*-------------------------------------------- */
/* Base
---------------------------------------------- */

html,body {
	font-family: 'Yu Gothic Medium', '游ゴシック Medium', YuGothic, '游ゴシック体', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
	font-size: 10px;
	color: #2C2C2C;
	background-color: #fff;
	line-height: 1.75;
	padding: 0;
	margin: 0;
	width: 100%;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
	-webkit-touch-callout: none;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

div, dl, dt, dd, ul, ol, dl, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, button, label, p, span, blockquote, th, td, article, aside, footer, header, nav, section, figcaption, figure, main, a, hr {margin:0;padding:0;box-sizing: border-box;}
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;}
b,strong {font-weight: bold;}
ol,ul,dl{list-style:none;}
caption,th{text-align:left;}
th,td{vertical-align:top;}
h1,h2,h3,h4,h5,h6{font-size:100%; font-weight: normal;}
img{vertical-align:bottom; max-width:100%; border: none;}
abbr,acronym{border:0;}
:focus { outline:0; }

/* body
----------------------------------------------*/

body * {
	word-wrap : break-word;
	overflow-wrap : break-word;
}
html.is_fixed,
body.is_fixed {
	overflow: hidden;
	overflow-x: hidden;
}
body.is_fixed.os_ios {
	position: fixed;
}
body.media_tab {
	width: 1100px;
	overflow-x: hidden;
}
body.media_sp {
	width: 375px;
	overflow-x: hidden;
}

/* a
----------------------------------------------*/
a {
	text-decoration: none;
	outline: none;
	color: #1686FC;
	-webkit-text-decoration-skip: objects;
	cursor: pointer;
}
a:not([class]) {
	text-decoration: underline;
}
.blue_btn {
	color: #2C2C2C;
	text-decoration: underline;
}

/* FireFox修正 */

a img {
	box-shadow: #000 0 0 0;
}

@media screen and (max-width: 768px){
	html,body {min-width: 375px;}
	img {width: 100%;}
}

@media screen and (min-width: 769px){

	body.media_pc {
		min-width: 1100px;
	}
	.media_pc a:not(.custom_btn):not(.common_btn):not([class^="commonBtn"]) {
		transition: opacity 0.6s;
	}
	.media_pc a:not(.custom_btn):not(.common_btn):not([class^="commonBtn"]):hover {
		opacity: 0.6;
		text-decoration: none;
	}
}


/*-------------------------------------------- */
/* State：is_pc,is_sp
---------------------------------------------- */

@media screen and (max-width: 768px){
	.is_pc {display: none !important;}	
	.is_sp {/* display: block !important; */}
}

@media screen and (min-width: 769px){
	.is_pc {/* display: block !important; */}	
	.is_sp {display: none !important;}
}



/*-------------------------------------------- */
/* Base：class
---------------------------------------------- */

sup {
	position: relative;
	top: 6px;
}

/*-------------------------------------------- */
/* Base：clear
---------------------------------------------- */

.clearfix:after,
.l_header:after,
.l_bottomNav:after,
.l_globalNav:after,
.l_footpath:after,
.l_contents:after,
.l_top_contents:after,
.l_main_contents:after,
.l_main_contents_l:after,
.l_main_contents_r:after,
.l_main_module:after,
.l_bottom_contents:after,
.l_social:after,
.l_footer:after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: "";
	clear: both;
	height: 0;
}
.clearboth {
	clear: both;
}

/*-------------------------------------------- */
/* Layout
---------------------------------------------- */

.l_header,
.l_globalNav,
.l_bottomNav,
.l_footpath,
.l_contents,
.l_top_contents,
.l_main_contents,
.l_main_contents_l,
.l_main_contents_r,
.l_main_module,
.l_bottom_contents,
.l_social,
.l_footer {
	position: relative;
	display: block;
	width: 100%;
}
.l_contents {
	width: 100%;
	font-size: 1.6rem;
	overflow: hidden;
}


/*-------------------------------------------- */
/* Layout：Header
---------------------------------------------- */

.l_header {
	width: 100%;
	height: 10px;
	position: absolute;
	top: 0;
	z-index: 1002;
}
.header_wrap {
	position: relative;
	display: block;
	width: 100%;
	height: 80px;
}

/* .header_logo */

.header_logo,
.header_logo span {
	position: relative;
	display: block;
	width: 70px;
	height: 70px;
	text-indent: -9999px;
	pointer-events: initial;
}
.header_logo span {
	background: url(../images/common/logo_obunsha_red_01.svg) -3px 0 no-repeat;
	background-size: contain;
}
.header_logo.is_hide {
	pointer-events: none;
	opacity: 0;
}

/* .btn_gnav */

.btn_gnav {
	position: relative;
	display: block;
	width: 90px;
	height: 90px;
	position: fixed;
	top: -10px;
	right: -18px;
	pointer-events: initial;
	transition : all 0.6s 0s cubic-bezier(0.5, 1, 0.89, 1);
}
.btn_gnav span {
	position: relative;
	display: block;
	width: 86px;
	height: 86px;
	text-indent: -9999px;
	background: url(../images/common/btn_gnav_01_bg.png) 0 0 no-repeat;
	background-size: contain;
}
.btn_gnav::before {
	content: "";
	display: block;
	width: 86px;
	height: 86px;
	text-indent: -9999px;
	background: url(../images/common/btn_gnav_01_open.svg) 0 0 no-repeat;
	background-size: contain;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
}
.btn_gnav.is_open::before {
	background: url(../images/common/btn_gnav_01_close.svg) 0 0 no-repeat;
	background-size: contain;
}
.btn_gnav.is_open {
	transform: rotate(360deg);
	-webkit-transform: rotate(360deg);
	-moz-transform: rotate(360deg);
	-ms-transform: rotate(360deg);
}

@media screen and (min-width: 769px){

	.header_wrap {
		max-width: 1100px;
		height: 80px;
		margin: 0 auto;
	}
	
	/* .header_logo */

	.header_logo span {
		background: url(../images/common/logo_obunsha_red_01.svg) -1px 3px no-repeat;
		background-size: contain;
	}
	
	/* .btn_gnav */
	
	.btn_gnav {
		width: 90px;
		height: 90px;
		top: -10px;
		left: 50%;
		margin-left: 564px;
		margin-left: 474px;
		right: auto;
	}
	.btn_gnav span {
		width: 88px;
		height: 88px;
		transform: scale(1);
		-webkit-transform: scale(1);
		-moz-transform: scale(1);
		-ms-transform: scale(1);
		transition-duration: 0.3s;
		transition-delay: 0s;
		transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.btn_gnav::before {
		width: 88px;
		height: 88px;
	}
	.media_pc .btn_gnav:hover span {
		transform: scale(1.1);
		-webkit-transform: scale(1.1);
		-moz-transform: scale(1.1);
		-ms-transform: scale(1.1);
	}
}
@media screen and (min-width: 769px) and (max-width: 1100px) {
	.btn_gnav {
		left: auto;
		margin-left: 0;
		right: -14px;
	}
}
