@charset "utf-8";

html {
	font-size: 16px;
}
@media only screen and (max-width: 1080px) {
	html {
		font-size : calc(0.39vw + 11.8px);
	}
}
body {
	line-height: 1.6;
	color: #010101;
	font-style: normal;
	font-weight: normal;
	background-color: #ffffff;
	font-family: 'Noto Sans JP', '游ゴシック体', YuGothic, '游ゴシック', 'Yu Gothic', sans-serif;
}
main {
	width: 100%;
	background-color: #ffffff;
	overflow: hidden;
}
@media only screen and (max-width: 400px) {
	#main {
		overflow: hidden;
	}
}

/* -------------------------------------------------------------------
 clearfix
------------------------------------------------------------------- */

.clearfix:before,
.clearfix:after {
	content: "";
	display: table;
}

.clearfix:after {
	clear: both;
}

/* For IE 6/7 */
.clearfix {
	zoom: 1;
}
.pc_close {
	display: none;
}
.pc_open {
	display: block;
}

/* ヘッダー */

header {
	position: relative;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 60;
	height: 147px;
	background-color: #ffffff;
	border-top : 10px solid #d4101a;
	box-shadow: 0px 10px 10px -5px rgba(0,0,0,0.5);
}
.header {
	position : relative;
}
.headMenuInner {
	width : 100%;
	max-width : 1300px;
	margin : 0 auto;
	padding : 0 10px;
	box-sizing: border-box;
	position : relative;
}
.innerFlex {
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : space-between;
	justify-content : space-between;
}
.headLogo {
	display: inline-block;
	position: relative;
	text-align: left;
	margin: 0;
	padding: 30px 0 0 0;
	z-index: 12;
}
.headLogo img {
	width: 239px;
}
.headText {
	font-size: 36px;
	position: relative;
	padding-top : 42px;
	color : #000000;
	letter-spacing: 2px;
}
.headText br {
	display : none;
}
.headText strong {
	color: #d4101a;
	font-family: 'Noto Sans JP', '游ゴシック体', YuGothic, '游ゴシック', 'Yu Gothic', sans-serif;
}
.headMenu {
	padding-top : 20px;
}
.headMenu p {
	font-size: 18px;
	font-weight : 500;
	color : #000000;
	line-height : 1.4;
}
.headTel img {
	margin-right : 10px;
	width : 51px;
}
.headTel a {
	font-size: 48px;
	font-weight : 700;
	line-height : 1.2;
	color : #000000;
	position : relative;
	top : -4px;
}
.headTime  {
	line-height : 1.4;
}
.headTime span {
	display : inline-block;
	vertical-align: top;
	font-size : 14px;
	font-weight : 500;
	letter-spacing: 2px;
	color : #ffffff;
	background-color : #d4101a;
	line-height: 24px;
	padding : 0 12px 2px 12px;
	margin-right : 10px;
	border-radius : 20px;
}
.lineButton {
	position : absolute;
	top : 10px;
	right : 10px;
}
.lineButton img {
	width : 120px;
}
@media only screen and (max-width: 1100px) {
	.lineButton {
		right : 4px;
	}
	.lineButton img {
		width : 10vw;
	}
}
.admin_headMenuInner {
	width: 100%;
	max-width: 990px;
	margin: 0 auto;
	position: relative;
}
.smp_menu .menu-trigger {
	display: block;
	position: absolute;
	top: 20px;
	left: 30px;
	width: 44px;
	height: 40px;
	transition: all .4s;
}
.smp_menu .menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 8px;
	background-color: #ffffff;
	transition: all .4s;
}
.smp_menu .menu-trigger span:nth-of-type(1) {
	top: 0;
}
.smp_menu .menu-trigger span:nth-of-type(2) {
	top: 16px;
}
.smp_menu .menu-trigger span:nth-of-type(3) {
	bottom: 0;
}
.menu-trigger.is-open span:nth-of-type(1) {
	width: 48%;
	-webkit-transform: translate3d(2px, 8px, 0) rotate(45deg);
	transform: translate3d(2px, 8px, 0) rotate(45deg);
}
.menu-trigger.is-open span:nth-of-type(2) {
	-webkit-transform: translate3d(-1px, 0, 0) rotate(-45deg);
	transform: translate3d(-1px, 0, 0) rotate(-45deg);
}
.menu-trigger.is-open span:nth-of-type(3) {
	width: 47%;
	-webkit-transform: translate3d(18px, -8px, 0) rotate(45deg);
	transform: translate3d(18px, -8px, 0) rotate(45deg);
}
@media only screen and (max-width: 1200px) {
	header {
		height : calc(10vw + 40px);
		max-height: 147px;
		min-height : 72px;
	}
	.headLogo {
		padding: 3vw 0 0 0;
	}
	.headLogo img {
		width: 24vw;
		max-width : 238px;
	}
	.headMenu {
		padding-top : 2vw;
	}
	.headText {
		font-size : calc(2.7vw + 4.4px);
		padding-top : 3vw;
		letter-spacing: 1px;
		line-height : 1.3;
	}
	.headText br {
		display : block;
	}
	.headTel a {
		font-size: 4vw;
		top : -4px;
	}
	.headTel img {
		width : 4.2vw;
		max-width : 51px;
	}
}
@media only screen and (max-width: 800px) {
	.pc_open {
		display: none;
	}
	.headText br {
		display : none;
	}
	.headText {
		font-size : calc(2.7vw + 4.4px);
		padding-top : 3vw;
		letter-spacing: 1px;
		line-height : 1.3;
	}
	.lineButton {
		top : calc(7vw + 12px);
		right : 6px;
	}
	.lineButton img {
		width : 12vw;
		min-width : 90px;
	}
}
@media only screen and (max-width: 480px) {
	header {
		height: 60px;
	}
	.headText {
		padding-top : 2vw;
	}
	.headLogo img {
		width: 24vw;
		min-width : 100px;
	}
	.headLogo {
		padding: 13px 20px 0 0;
	}
	.lineButton {
		top : calc(5vw + 16px);
		right : 6px;
	}
	.smp_menu .menu-trigger span:nth-of-type(1) {
		top: 0;
	}
	.smp_menu .menu-trigger span:nth-of-type(2) {
		top: 13px;
	}
	.smp_menu .menu-trigger span:nth-of-type(3) {
		bottom: 0;
	}
	.menu-trigger.is-open span:nth-of-type(1) {
		width: 48%;
		-webkit-transform: translate3d(2px, 7px, 0) rotate(45deg);
		transform: translate3d(2px, 7px, 0) rotate(45deg);
	}
	.menu-trigger.is-open span:nth-of-type(2) {
		-webkit-transform: translate3d(-1px, 0, 0) rotate(-45deg);
		transform: translate3d(-1px, 0, 0) rotate(-45deg);
	}
	.menu-trigger.is-open span:nth-of-type(3) {
		width: 47%;
		-webkit-transform: translate3d(14px, -7px, 0) rotate(45deg);
		transform: translate3d(14px, -7px, 0) rotate(45deg);
	}
}
@media only screen and (max-width: 430px) {
	.headMenuInner {
		padding : 0 4px;
	}
	.headLogo {
		padding: 14px 10px 0 0;
	}
	.headText {
		padding-top : 3vw;
		font-size : 1rem;
		letter-spacing: 0;
	}
}

/* トップ画像 */

.topimage {
	width: 100%;
	max-width: 1920px;
	margin: 0px auto 0 auto;
	position: relative;
}
.hrslider img {
	width: 100%;
	max-width: 1920px;
}
.noslider img {
	width: 100%;
	max-width: 1920px;
}
.overlay02 {
	width: 100%;
	position: absolute;
	bottom : 0px;
	left : 0;
	z-index : 99;
	padding : 30px 40px;
}
.overlay02 h2 {
	font-size: 40px;
	font-weight : 900;
	line-height : 1.2;
	color : #ffffff;
}
.overlay02 img {
	margin-right : 10px;
	width : 60px;
}
.overlay02 a {
	font-size: 72px;
	font-weight : 700;
	line-height : 1.2;
	color : #fdf45b;
	position : relative;
	top : -4px;
}
.overlay02 p {
	display : inline-block;
	vertical-align: top;
	font-size: 18px;
	font-weight : 400;
	line-height : 1.2;
	color : #ffffff;
	position : relative;
	top : 0px;
	padding : 18px 0 0 14px;
}
.overlay02 p br {
	display : inline;
}
.overlay02 p span {
	display : inline-block;
	vertical-align: top;
	font-size : 14px;
	font-weight : 500;
	letter-spacing: 2px;
	color : #d4101a;
	background-color : #ffffff;
	line-height: 24px;
	padding : 0 12px 2px 12px;
	margin-bottom : 6px;
	border-radius : 20px;
}
@media only screen and (max-width: 1770px) {
	.overlay02 {
		padding : 3vw 4vw 0 4vw;
		bottom : 1.5vw;
	}
	.overlay02 h2 {
		font-size : calc(2.12vw + 2.5px);
	}
	.overlay02 img {
		width : 3.9vw;
	}
	.overlay02 a {
		font-size : 4.07vw;
	}
	.overlay02 p {
		display : block;
		font-size : calc(0.47vw + 10.0px);
		padding : 0;
	}
	.overlay02 p br {
		display : none;
	}
	.overlay02 p span {
		font-size : 13px;
		letter-spacing: 1px;
		line-height: 22px;
		padding : 0 12px 2px 12px;
		margin-bottom : 0px;
		margin-right : 8px;
	}
}
@media only screen and (max-width: 880px) {
	.overlay02 p span {
		font-size : 10px;
		letter-spacing: 1px;
		line-height: 14px;
		padding : 0 10px 2px 10px;
	}
}
@media only screen and (max-width: 640px) {
	.overlay02 {
		padding : 3vw 4vw 0 4vw;
		bottom : 4vw;
	}
	.overlay02 h2 {
		font-size : calc(1.88vw + 8.0px);
		margin-bottom : 2vw;
	}
	.overlay02 img {
		width : calc(3.75vw + 9.0px);
	}
	.overlay02 a {
		font-size : calc(3.75vw + 8.0px);
	}
	.overlay02 p {
		display : block;
		font-size : calc(0.47vw + 10.0px);
		padding : 2vw 0 0 0;
	}
	.overlay02 p br {
		display : none;
	}
	.overlay02 p span {
		font-size : 13px;
		letter-spacing: 1px;
		line-height: 22px;
		padding : 0 12px 2px 12px;
		margin-bottom : 0px;
		margin-right : 8px;
	}
}
@media only screen and (max-width: 480px) {
	.overlay02 {
		padding : 3vw 4vw 0 0;
		bottom : 4vw;
	}
	.overlay02 h2 {
		font-size : calc(2.5vw + 4.0px);
		margin-bottom : 1.5vw;
	}
	.overlay02 p {
		font-size : calc(0.47vw + 10.0px);
		padding : 1vw 0 0 0;
	}
	.overlay02 p span {
		font-size : 10px;
		letter-spacing: 0;
		line-height: 12px;
		padding : 0 7px 2px 7px;
		margin-right : 6px;
	}
}
.subtopimage {
	width: 100%;
	max-width: 1900px;
	margin: 0 auto;
	position: relative;
}

.subtopimage img {
	width: 100%;
	max-width: 1900px;
}

.subtopimage .pan {
	position: absolute;
	top: 40px;
	left: 100px;
	color: #000000;
	font-size: 18px;
}

.subtopimage .pan a {
	color: #000000;
}

.subtopimage h2 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);
	color: #ffffff;
	font-size: 54px;
	text-shadow: 2px 6px 20px rgba(0, 0, 0, 1), 2px 6px 20px rgba(0, 0, 0, 1);
}

.slide_all {
	height: 569px;
	margin: 0 auto;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 1;
	width: 100%;
	max-width: 1380px;
}

.slide_all2 {
	height: 569px;
	margin: 0 auto;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 9;
	width: 100%;
	max-width: 1380px;
}

.slide_wrap {}

.noslide {
	height: 569px;
	margin: 0 auto;
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	max-width: 1920px;
}

.slide img {
	width: auto;
	height: 569px;
}

/* メインコンテンツ 共用 */

.normalTitle {
	text-align : center;
}
.normalTitle img.ttlimg01 {
	width : 60%;
	max-width : 513px;
}
.normalTitle img.ttlimg02 {
	width : 10%;
	max-width : 64px;
}
.normalTitle span {
	display : block;
	font-size: 35px;
	font-weight : 900;
	line-height : 1.6;
	color : #000000;
}
@media only screen and (max-width: 1180px) {
	.normalTitle span {
		font-size : calc(2.21vw + 8.9px);
	}
}

/* メインコンテンツ 理由 */

.contensInner {
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : space-between;
	justify-content : space-between;
	flex-wrap : wrap;
	padding : 24px;
	border : 10px solid #d4101a;
}
.contensInner .innerItem {
	width : 50%;
	box-sizing: border-box;
	text-align : center;
}
.contensInner .innerItem.bdr01 {
	border-right : 1px dashed #959595;
	border-bottom : 1px dashed #959595;
	padding : 24px 50px 50px 10px;
}
.contensInner .innerItem.bdr02 {
	border-bottom : 1px dashed #959595;
	padding : 24px 10px 50px 50px;
}
.contensInner .innerItem.bdr03 {
	border-right : 1px dashed #959595;
	padding : 50px 50px 10px 10px;
}
.contensInner .innerItem.bdr04 {
	padding : 50px 10px 10px 50px;
}
.contensInner .innerItem .innerTitle img {
	width : 50%;
	max-width : 211px;
}
.contensInner .innerItem span {

	
}
.contensInner .innerItem .title {
	text-align : center;
	font-size: 36px;
	font-weight : 900;
	line-height : 1.4;
	color : #d4101a;
	margin-top : 48px;
	margin-bottom : 24px;
}
.contensInner .innerItem .image {
	
}
.contensInner .innerItem img {
	width : 100%;
	max-width : 500px;
}
.contensInner .innerItem .word {
	text-align : left;
	font-size: 1rem;
	font-weight : 400;
	line-height : 1.8;
	color : #434343;
	margin-top : 24px;
	margin-bottom : 24px;
	min-height : 180px;
}
.contensInner .innerItem .word strong {
	color : #d4101a;
	font-weight : 500;
}

@media only screen and (max-width: 1180px) {
	.contensInner {
		padding : 2.4vw;
		border : calc(0.47vw + 4.5px) solid #d4101a;
	}
	.contensInner .innerItem .title {
		font-size : calc(2.09vw + 11.3px);
		margin-top : 4.8vw;
		margin-bottom : 2.4vw;
	}
}
@media only screen and (max-width: 640px) {
	.contensInner .innerItem {
		width : 100%;
	}
	.contensInner .innerItem.bdr01 {
		border-right : none;
		padding : 5vw 1vw 1vw 1vw;
	}
	.contensInner .innerItem.bdr02 {
		padding : 5vw 1vw 1vw 1vw;
	}
	.contensInner .innerItem.bdr03 {
		border-right : none;
		border-bottom : 1px dashed #959595;
		padding : 5vw 1vw 1vw 1vw;
	}
	.contensInner .innerItem.bdr04 {
		padding : 5vw 1vw 1vw 1vw;
	}
	.contensInner .innerItem .word {
		min-height : 10px;
	}
}

/* メインコンテンツ 会社概要 */

.parfWrap {
	
}
.parfWrap dl {
	display : -webkit-flex;
	display : flex;
	padding : 13px 0;
	box-sizing: border-box;
}
.parfWrap dt {
	width : 20%;
	color : #313131;
	font-size : 20px;
	font-weight : 400;
	line-height : 1.8;
	padding : 0 38px;
	box-sizing: border-box;
	border-right : 1px solid #a0a0a0;
}
.parfWrap dd {
	width : 80%;
	color : #313131;
	font-size : 20px;
	font-weight : 400;
	line-height : 1.8;
	padding : 0 38px;
	box-sizing: border-box;
}
.parfWrap .bgr00 {
	background-color : #ededed;
}
.parfWrap .bgr01 {
	background-color : #f4f4f4;
}

@media only screen and (max-width: 1180px) {
	.parfWrap dt {
		font-size : calc(0.81vw + 10.4px);
		padding : 0 calc(2.8vw + 5px) 0 6px;
	}
	.parfWrap dd {
		font-size : calc(0.81vw + 10.4px);
		padding : 0 calc(2.8vw + 5px) 0 6px;
	}
}
@media only screen and (max-width: 480px) {
	.parfWrap dt {
		width : 30%;
	}
	.parfWrap dd {
		width : 70%;
	}
}

/* メインコンテンツ マップ・バナー */

.mapArea iframe {
	width : 100%;
}
.bannerArea {
	width : 96%;
	max-width : 800px;
	position : relative;
}
.bannerArea img {
	width : 100%;
}
.bannerArea .button {
	position : absolute;
	bottom : 8px;
	left : 24px;
	width : 60%;
	max-width : 446px;
}
.bannerArea .button img {
	width : 100%;
}
@media only screen and (max-width: 800px) {
	.bannerArea .button {
		position : absolute;
		bottom : 1px;
		left : 2.4vw;
	}
}


/* フッター包括---------------------------*/

footer {
	margin-top: 60px;
	position: relative;
	z-index: 3;
	padding: 54px 0;
	border-top : 10px solid #d4101a;
}
.footLogo {
	text-align : center;
}
.footLogo img {
	width : 50%;
	max-width : 239px;
}
.lineFoot img {
	width : 30%;
	max-width : 160px;
}
.copyright {
	text-align: center;
	font-size: 14px;
	color: #434343;
}
.wrapPageTopPc {
	height: 0;
	position: relative;
	width: 100%;
	z-index: 9999;
	display: none;
}
.wrapPageTopPc p {
	bottom: 20px;
	cursor: pointer;
	display: block;
	margin-right: auto;
	position: fixed;
	right: 6px;
}
.wrapPageTopPc p img {
	width: 34px;
}

@media only screen and (max-width: 860px) {
	footer {
		margin-top: 16vw;
		padding: 8.5vw 0;
	}
	.copyright {
		font-size: calc(0.74vw + 7.6px);
	}
}

/* 管理画面フッター */

#admin_contener {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
.admin_footer {
	margin-top: auto;
	background-color: #474747;
	position: relative;
}
.admin_footer .footerCopy {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	text-align: right;
	color: #ffffff;
	font-size: 12px;
	padding: 32px 0;
}
.admin_footer .safety {
	position: absolute;
	top: 4px;
	left: 4px;
}
.servWrap00 {
	width: 960px;
	margin: 0 auto;
}

.servWrap01 {
	width: 1080px;
	margin: 0 auto;
}
