@charset "UTF-8";

/* base
-------------------------------------------------- */
#main {
	max-width: 100%;
	box-sizing: content-box;
	padding-left: 0;
    padding-right: 0;
}
.container {
    max-width: 1414px;
    margin: 40px auto 77px;
    padding: 0 13px;
}
.base14 {
	font-size: 1em;
}
#module_titleArea {
	padding: 0;
}
#module_titleArea {
	max-width: 1440px;
}
#module_zoomFontSize {
	right: 0;
}
#title {
	padding: 13px 0 9px 13px;
	float: left;
	font-size: 1.38em;
	font-weight: bold;
	color: #333;
}
#title:before {
	content: "";
	position: absolute;
	top: 14px;
	left: 0;
	display: inline-block;
	width: 4px;
	height: 1em;
	margin-right: 6px;
	background-color: #c00;
	border-radius: 3px
}
#title:before {
	display: none;
}

@media only screen and (max-width: 767px) {
	body {
		font-size: 14px !important;
	}
	#main {
		width: auto;
		max-width: none;
		min-width: inherit;
		margin: 0;
		padding: 0;
		font-size: 100%;
	}
	.container {
		margin: 6px auto 60px;
    	padding: 0 10px;
	}
	#module_titleArea {
		width: 100%;
		min-width: 100%;
	}
	#title {
		font-size: 1.29em;
		padding: 16px 15px;
	}
	#title:before {
		top: 24px;
	}
}

/* Head Elements
-------------------------------------------------- */
.heading {
	margin-bottom: 25px;
	padding: 10px 9px 10px 34px;
	border-top: 2px solid #c00;
	border-bottom: 1px solid #bbb;
	font-size: 112.5%;
	font-weight: bold;
	background: url(../img/index/icon_oshirase_2x.png) no-repeat 9px 49.5%;
	background-size: 15px 24px;
}

@media only screen and (max-width: 767px) {
	.heading {
		font-size: 114.28%;
		padding: 9px 9px 8px 28px;
		background-position: 9px 50%;
		background-size: 13px 22px;
		margin-bottom: 20px;
	}
}

/* Other
-------------------------------------------------- */
.text_bold {
	font-weight: bold;
}
.heading + .text_bold {
	padding-left: 9px;
	padding-right: 9px;
}
.text_bold + .index_list {
	margin-top: 20px;
}
.index_list {
	padding-left: 9px;
	padding-right: 9px;
}
.index_list dl {
	line-height:1.42;
}
.index_list dl dt {
	width:9em;
	padding:5px 0 0 10px;
	background:url(../img/index/arrow_list.png) no-repeat 0 11px;
	background-size: 6px 5px
}
.index_list dl dd {
	margin:-1.42em 0 0 10.5em;
	padding:0 0 19px
}
.sp-anchor {
    display: none;
    margin: 0 0 25px;
}

@media only screen and (max-width: 767px) {
	.heading + .text_bold {
		margin-top: 0;
	}
	.text_bold + .index_list {
		margin-top: 20px;
	}
	.index_list dl dt {
		width:auto;
		padding:8px 0 0;
		background:0 0
	}
	.index_list dl dt:first-child {
		padding-top: 0;
	}
	.index_list dl dd {
		margin:0;
		padding:6px 0 10px
	}
	.index_list dl dd a {
		display:block;
		padding:0 0 0 10px;
		background:url(../img/index/arrow_list.png) no-repeat 0 .3em;
		background-size: 7px 7px;
	}
	.sp-anchor {
	    display: block;
	}
	.sp-anchor .list_anchor {
	    border-top: 1px solid #ccc;
	}
	.sp-anchor .list-item {
	    border-bottom: 1px solid #ccc;
	    line-height: 1.286;
	}
	.sp-anchor .list-item a {
	    display: block;
	    padding: 10px 20px 9px 20px;
	    background: url(../img/index/arrow_down_2x.png) no-repeat 5px 1.15em;
	    background-size: 5px 6px;
	}
}

/* model-search
-------------------------------------------------- */
.model-search {
	margin: 5px 0 37px;
	border: 1px solid #d9d9d9;
	border-radius: 3px;
}
.model-search .form-container {
	padding: 27px 30px;
	background-color: #fafafa;
	border-radius: 3px;
}
.model-search .legend {
	margin-bottom: 10px;
	font-size: 1.1429em;
	font-weight: bold;
}
.model-search .input-area {
	float: left;
	width: 100%;
	margin-right: -20.18%;
}
.model-search input[type=text] {
	width: 100%;
	background-color: #fff;
	border: 1px solid #cbcbcb;
	font-size: 1em;
	height: 45px;
	line-height: 34px;
	padding: 0 14px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.model-search button[type=submit] {
	float: right;
	width: 15.9%;
	height: 44px;
	background-color: #666;
	font-size: 1.13em;
	font-weight: bold;
	text-align: center;
	border: none;
	color: #fff;
	line-height: 34px;
}
.model-search button[type=submit] .inner {
	display: inline-block;
	letter-spacing: .5em;
}
.model-search button[type=submit] .inner:before {
	position: relative;
	content: "";
	display: inline-block;
	width: 22px;
	height: 23px;
	margin-right: 10px;
	background: url(../img/common/icon_search_2x.png) no-repeat;
	-webkit-background-size: 22px auto;
	background-size: 22px auto;
	top: 5px;
}
.model-search .annotation {
	font-size: 0.88em;
	margin-top: 6px;
}
.model-search ::-webkit-input-placeholder{color:#b4b4b4}
.model-search :-ms-input-placeholder{color:#b4b4b4}
.model-search ::-moz-placeholder{color:#b4b4b4;opacity:1}
.model-search :-moz-placeholder{color:#b4b4b4;opacity:1}

@media only screen and (max-width: 767px) {
	.model-search {
		margin: 0 0 25px;
	}
	.model-search .form-container {
		padding: 20px 15px;
	}

	.model-search .legend {
		margin-bottom: 10px;
	}

	.model-search .input-area {
		float: none;
		width: auto;
		margin-right: 0;
	}

	.model-search input[type=text] {
		font-size: 1em;
		height: 45px;
		line-height: 45px;
		border-radius: 0;
	}

	.model-search button[type=submit] {
		float: none;
		width: 100%;
		height: 45px;
		margin-top: 10px;
		border-radius: 0;
		font-size: 1.1429em;
		line-height: 45px;
	}
	.model-search button[type=submit] .inner:before {
		content: "";
		display: inline-block;
		width: 17px;
		height: 17px;
		margin-right: 7px;
		background: url(../img/common/icon_search_2x.png) no-repeat;
		-webkit-background-size: 17px auto;
		background-size: 17px auto;
		top: 3px;
	}
	.model-search .annotation {
		margin-top: 12px;
		font-size: .8571em;
	}
}

/* pagetop
-------------------------------------------------- */
.pagetop-container {
	position: relative;
}
.pagetop {
	visibility: visible;
	opacity: 1;
	position: fixed;
	z-index: 999;
	right: 24px;
	bottom: 24px;
	cursor: pointer;
	-webkit-transition: opacity 0.3s, visibility 0.3s, background 0.3s;
	transition: opacity 0.3s, visibility 0.3s, background 0.3s;
	background: #c00;
	font-size: 0;
}
.pagetop img {
	width: 50px;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
	-webkit-transform: translateY(0px);
	-ms-transform: translateY(0px);
	transform: translateY(0px);
}
.pagetop:hover {
	background: #d11919;
}
.pagetop:hover img {
	-webkit-transform: translateY(-4px);
	-ms-transform: translateY(-4px);
	transform: translateY(-4px);
}
.pagetop.is-hidden {
	visibility: hidden;
	opacity: 0;
}
.pagetop.is-absoluted {
	position: absolute;
	bottom: 0;
}
@media only screen and (max-width: 767px) {
	.pagetop img {
		width: 37px;
	}
}
section[id]+section[id] {
	margin-top: 36px;
}