@charset "UTF-8";

/* ==========================================
	base
========================================== */
html {
	overflow-y: scroll;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	font-size: 62.5%;
	overflow-x: hidden;
}
body {
	color: #444444;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 16px;/* IE8 */ 
	font-size: 1.6em;
	line-height: 1.6em;
	margin:0 !important;
	width: 100%;
	transition: .8s;
	transition-delay: .8s;
}
*, *: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;
}
.contents_inner{
	width: 1000px;
	margin: 0 auto;
}
img {
	max-width: 100%;
	height: auto;
}
p {
	font-size: 1.4rem;
	line-height: 200%;
}
a, a:link, a:visited {
	color: #dc1818;
	cursor: pointer;
}
a:hover {
	text-decoration:none;
}
.sp_mode {
	display: none !important;
}
.pc_mode {
	display: block !important;
}

/* ==========================================
	clearfix
========================================== */

.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}
.clearfix {
    display: inline-block;
}
* html .clearfix {
    height: 1%;
}
.clearfix {
    display: block;
}

/* ==========================================
	lower
========================================== */

#lower_img {
	padding: 60px 0;
}
#lower_img h2 {
	color: #fff;
	font-size: 30px;
	font-weight: normal;
	text-align: center;
	letter-spacing: 0.15em;
}
#breadcrumb {
	padding-left: 15px;
	margin-top: 5px;
}
#breadcrumb p,
#breadcrumb a {
	font-size: 13px;
}
.h3_style {
	font-size: 18px;
	text-align: center;
}
.h3_style span {
	display: block;
	font-family: 'Roboto Condensed', sans-serif;
	font-size: 28px;
	letter-spacing: 0.05em;
	color: #c52016;
	margin-top: 8px;
}
.h4_style {
	font-size: 20px;
	padding: 15px 0 15px 95px;
	background: url(../img/index/news_head.png) no-repeat;
	background-position-y: 3px;
	margin-bottom: 20px;
	padding-bottom: 8px;
	position: relative;
	border-bottom: 4px solid #ca3b33;
}

/* ==========================================
	header
========================================== */

header {
	padding-bottom: 18px;
	border-top: 9px solid #c52016;
}
header .logo_contact {
	overflow: hidden !important;
}
header #logo {
	margin: 10px 0 0 10px;
}
header #logo:hover {
	opacity: 0.6;
}
header nav {
	width: 640px;
	margin: 35px 0 0 40px;
}
header nav ul li {
	float: left;
	width: 160px;
	padding: 6px 0;
	box-sizing: border-box;
	border-left: 1px solid #f2f2f2;
	position: relative;
}
header nav img {
	display: block;
	margin: 0 auto;
}
header nav a:hover img {
	opacity: 0.6;
}
header #header_btn {
	display: block;
	width: 155px;
	margin-top: 35px;
	padding: 12px 0 12px 52px;
	background: url(../img/common/icon_mail.png) #c52016 no-repeat;
	background-position: 14px center;
	font-size: 14px;
	color: #fff;
	text-decoration: none;
}
header #header_btn:hover {
	background-color: #000;
}
#sp_menu {
	display: none !important;
}

/* ==========================================
	contact_bottom
========================================== */

#contact_block {
	padding: 50px 0 60px;
	background: url(../img/common/contact_bg.jpg) #153156;
	background-position: center;
	border-top: 7px solid #dedede;
}
#contact_block .contents_inner {
	padding: 0 75px;
}
#contact_block h2 {
	margin-bottom: 40px;
}
#contact_block h2 img {
	display: block;
	margin: 0 auto;
}
#contact_block .intro_text {
	font-size: 16px;
	text-align: center;
	color: #fff;
	margin-bottom: 35px;
}
#contact_block .contact_box {
	width: 390px;
	float: left;
}
#contact_block .contact_box:last-child {
	margin-left: 70px;
}
#contact_block .contact_box h3 {
	color: #fff;
	font-size: 16px;
	font-weight: normal;
	text-align: center;
	border-top: 1px solid #fff;
	border-bottom: 1px solid #fff;
	padding: 5px 0;
}
#contact_block .contact_box a {
	display: block;
	color: #fff;
	text-decoration: none;
	font-size: 20px;
	padding: 23px 0 23px 60px;
	background: url(../img/common/arrow_red.png) #bf1314 no-repeat;
	background-position: 340px center;
	border: 2px solid #fff;
	margin-top: 35px;
}
#contact_block .contact_box a:hover {
	background-color: #9a0b0b;
}
#contact_block .contact_box img {
	display: block;
	margin: 45px auto 0;
}

/* ==========================================
	pagetop
========================================== */

.pagetop {
    width: 65px;
    height: 58px;
    background: url(../img/common/pagetop.png) #b71a1a;
    background-repeat: no-repeat;
    background-position: center;
    position: fixed;
    right: 20px;
    bottom: 100px;
    padding: 10px;
    cursor: pointer;
    z-index: 999;
    display: block;
    border: 2px solid #fff;
}
.pagetop:hover {
	background-color: #272727;
	background-position: center;
}

/* ==========================================
	footer
========================================== */

footer .logo_area {
	margin: 15px 35px 30px 15px;
}
footer .logo_area h2 {
	margin-bottom: 15px;
}
footer .logo_area p {
	font-size: 13px;
	line-height: 150%;
	margin: 23px 0 0 15px;
}
footer #ft_menu {
	display: block;
	width: 945px;
	margin: 0 auto;
}
footer #ft_menu li {
	float: left;
	width: 135px;
	border-right: 1px solid #e2e2e2;
}
footer #ft_menu li:first-child {
	border-left: 1px solid #e2e2e2;
}
footer #ft_menu li a {
	display: block;
	color: #333;
	font-size: 11.5px;
	line-height: 120%;
	text-align: center;
	text-decoration: none;
}
footer #ft_menu li a:hover {
	text-decoration: underline;
}
footer #ft_menu li a:before {
	content: url("../img/common/arrow_white.png");
	margin-right: 5px;
}
footer .copy_area {
	margin-top: 20px;
	padding: 8px 0;
	border-top: 1px solid #c0c0c0;
}
footer .copy_area p {
	font-size: 13px;
	text-align: center;
	font-family: 'Roboto Condensed', sans-serif;
}

/* ==========================================

	sp

========================================== */

@media screen and (max-width:640px) {

	body {
		overflow: hidden;
	}
	p {
	    font-size: 1.2rem;
		line-height: 200%;
	}
	.pc_mode {
		display: none !important;
	}
	.contents_inner{
		width: 100%;
		margin: 0 auto;
		padding: 0 10px;
	}

/* ==========================================
	header
========================================== */

	header #logo {
		width: 70px;
	}

/* ==========================================
	lower
========================================== */

	#lower_img {
		padding: 20px 0;
	}
	#lower_img h2 {
		font-size: 18px;
	}
	#breadcrumb p,
	#breadcrumb a {
		font-size: 11px;
	}
	.h3_style {
		font-size: 15px;
	}
	.h3_style span {
		font-size: 20px;
		margin-top: 0;
	}
	.h4_style {
		font-size: 14px;
		line-height: 150%;
		padding: 15px 0 6px 55px;
		background-size: 50px;
		background-position-y: bottom;
	}


/* ==========================================
	hamburgermenu
========================================== */

	.sp_mode {
		display: block !important;
	}
	header {
		position: relative;
		z-index: 999;
	}
	header nav {
		width: 100%;
		margin: 0;
	}
	header nav ul li {
		height: auto;
	}
	header.contents_inner {
		position: fixed;
		border-bottom: 1px solid #ebebeb;
	}
	#sp_menu_block {
		position: relative;
		z-index: 99999;
	}
	#sp_menu {
		display: block !important;
	}
	#pc_menu {
		display: none;
	}
	#sp_menu ul {
		width: 100%;
		text-align: center;
		background: #c52016;
		overflow: hidden;
	}
	#sp_menu ul li {
		width: 50%;
		float: left;
		background: url(../img/common/arrow_red.png) no-repeat;
		background-position: 20px;
		border-bottom: 1px solid #fff;
		border-right: none;
	}
	.overlay li.select {
		background-color: #94170f !important;
	}
	#sp_menu ul li:nth-child(odd) {
		border-right: 1px solid #fff;
	}
	#sp_menu ul li a {
		display: block;
		width: initial;
		color: #fff;
		font-size: 12px;
		font-size: 1.2rem;
		text-decoration: none;
		margin: 0;
		padding: 10px 0;
	}
	.menu-btn {
		position: absolute;
		top: -28px;
		right: 15px;
		z-index: 999;
		display: inline;
		font-size: 32px;
	}
	.menu-btn a {
	    display: inline-block;
	    text-decoration: none;
		margin-top: 0px;
	}
	.btn-open {
		display: block;
		width: 38px;
		height: 30px;
		position: relative;
	}
	.btn-open span {
		display: block;
		width: 35px;
		height: 2px;
		background: #c52016;
		border-radius: 2px;
		-webkit-border-radius: 2px;
		-moz-border-radius: 2px;
		-o-border-radius: 2px;
		-ms-border-radius: 2px;
	}
	.btn-open span:first-child {
		position: absolute;
		top: 0;
		right: 0;
	}
	.btn-open span:nth-child(2) {
		position: absolute;
		top: 10px;
		right: 0;
	}
	.btn-open span:last-child {
		position: absolute;
		top: 20px;
		right: 0;
	}
	.btn-open:after {
		-webkit-transition: all .2s linear 0s;
		-moz-transition: all .2s linear 0s;
		-o-transition: all .2s linear 0s;
		transition-property: all .2s linear 0s;
	}
	.btn-close:after {
		content: '×';
		font-size: 50px;
		display: block;
		position: absolute;
		top: 0;
		right: -4px;
		color: #c52016;
		-webkit-transition: all .2s linear 0s;
		-moz-transition: all .2s linear 0s;
		-o-transition: all .2s linear 0s;
		transition-property: all .2s linear 0s;
	}
	.overlay {
		position: absolute;
		top: 68px;
		left: 0;
		z-index: 99;
		display: none;
		overflow: auto;
		width: 100%;
		height: auto;
		padding-bottom: 20px;
		background: #fff;
		-webkit-box-shadow: 0 9px 12px -9px #222;
		-moz-box-shadow: 0 9px 12px -9px #222;
		-ms-box-shadow: 0 9px 12px -9px #222;
		-o-box-shadow: 0 9px 12px -9px #222;
		box-shadow: 0 9px 12px -9px #222;
	}
	.overlay h1 {
		width: 210px;
		margin: 18px 0 0 8px;
		padding-bottom: 2px;
	}
	#sp_contact_area p {
		margin-top: 10px;
		text-align: center;
	}
	#sp_contact_area .btn_area {
		width: 290px;
		margin: 0 auto;
	}
	#sp_contact_area img {
		display: block;
		margin: 0 auto;
	}
	#sp_contact_area a {
		display: block;
		width: 200px;
		margin: 20px auto 0;
		padding: 15px 0 15px 20px;
		font-size: 14px;
		color: #fff;
		text-align: center;
		background: url(../img/common/icon_mail.png) #000 no-repeat;
		background-position: 30px center;
		text-decoration: none;
	}

/* ==========================================
	contact_block
========================================== */

	#contact_block .contents_inner {
		padding: 0 15px;
	}
	#contact_block h2 {
		margin-bottom: 25px;
	}
	#contact_block .intro_text {
		font-size: 14px;
		margin-bottom: 20px;
	}
	#contact_block .contact_box {
		width: 100%;
		float: none;
	}
	#contact_block .contact_box h3 {
		font-size: 14px;
	}
	#contact_block .contact_box a {
		width: 250px;
		margin: 25px auto 0;
		padding: 15px 0 15px 25px;
		font-size: 15px;
		background-position: 210px center;
	}
	#contact_block .contact_box img {
		margin-top: 25px;
	}
	#contact_block .contact_box:last-child {
		margin-left: 0;
		margin-top: 40px;
	}

/* ==========================================
	pagetop
========================================== */

	.pagetop {
		width: 100%;
		height: 35px;
		border: none;
		position: static;
		background-size: 21px;
	}

/* ==========================================
	footer
========================================== */

	footer .logo_area {
		margin: 15px auto;
	}
	footer .logo_area h1 {
		float: none !important;
	}
	footer .logo_area h1 a {
		display: block;
		width: 103px;
		margin: 0 auto;
	}
	footer .logo_area p {
		width: 280px;
		margin: 15px auto 0;
	}
	footer .sp_ft_menu ul {
		background: #fdfdfd;
	}
	footer .sp_ft_menu ul li {
		float: left;
		width: 50%;
		text-align: center;
		border-top: 1px solid #ececec;
	}
	footer .sp_ft_menu ul li:first-child {
		width: 100%;
	}
	footer .sp_ft_menu ul li:nth-child(even) {
		border-right: 1px solid #ececec;
	}
	footer .sp_ft_menu ul li:nth-child(6),
	footer .sp_ft_menu ul li:nth-child(7) {
		border-bottom: 1px solid #ececec;
	}
	footer .sp_ft_menu ul li a {
		display: block;
		font-size: 12px;
		text-decoration: none;
		padding: 5px 0;
		color: #333;
	}
	footer .copy_area {
		border-top: none;
		margin-top: 0;
	}

}