@charset "utf-8";

@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);
/* ----------------------------------------------------------------------------------------------------
  base
* --------------------------------------------------------------------------------------------------*/
body {
	/*min-width: 980px;*/
	min-width: 1260px;
	background: #fff;
	text-align: justify;
	text-justify: inter-ideograph;
	-webkit-text-size-adjust: 100%;
	font-family: "Noto Sans Japanese", serif;
	color: #404040;
	font-size: 14px;
	font-weight: 300;
	line-height: 1.75;
	padding-top: 153px;
	position: relative;
}

body.header_static{
	padding-top: 0;
}

@media screen and (max-width: 768px) {
	body {
		min-width: 0;
		font-size: 13px;
		padding-top: 48px;
	}
}

a {
	-webkit-transition: 0.3s;
	transition: 0.3s;
	color: inherit;
	text-decoration: none;
}

a:hover {
	opacity: 0.8;
}

img {
	max-width: 100%;
}

@media screen and (max-width: 768px) {
	img {
		max-width: 100%;
		height: auto;
	}
}

/* ----------------------------------------------------------------------------------------------------
  inner
* --------------------------------------------------------------------------------------------------*/
.headerIn,
.footerIn,
.contentIn {
	width: 980px;
	margin: 0 auto;
	position: relative;
}

.headerIn:after,
.footerIn:after,
.contentIn:after {
	content: "";
	display: block;
	clear: both;
}

@media screen and (max-width: 768px) {
	.headerIn,
	.footerIn,
	.contentIn {
		width: auto;
		padding: 0 2.666%;
	}
}

/* ----------------------------------------------------------------------------------------------------
  breadcrumb
* --------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 768px) {
	#breadcrumb {
		display: none;
	}
}

#breadcrumb ul {
	max-width: 980px;
	margin: 0 auto;
	padding: 6px 0 5px;
	text-align: right;
}

#breadcrumb li {
	display: inline-block;
	color: #24396e;
	position: relative;
}

#breadcrumb li::before {
	position: absolute;
	content: "";
}

#breadcrumb li:first-child {
	padding-left: 1.2em;
}

#breadcrumb li:first-child:before {
	width: 13px;
	height: 11px;
	margin: auto;
	top: 0;
	left: 0;
	bottom: 0;
	background: url(../../_asset/img/common/cmn_ico_arrow01.svg) no-repeat;
	background-size: 100%;
}

#breadcrumb li + li {
	padding-left: .8em;
}

#breadcrumb li + li:before {
	content: '\f105';
	color: #24396e;
	font-family: FontAwesome;
	left: 2px;
}

#breadcrumb li > a {
	position: relative;
	display: inline-block;
	-webkit-transition: 0.3s;
	transition: 0.3s;
}

#breadcrumb li > a:hover {
	opacity: 1.0;
}

#breadcrumb li > a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	content: '';
	width: 0;
	height: 1px;
	-webkit-transition: 0.3s;
	transition: 0.3s;
}

#breadcrumb li > a:hover::after {
	width: 100%;
}

#breadcrumb li > a:after {
	background-color: #24396e;
}

/* ----------------------------------------------------------------------------------------------------
  lNavi
* --------------------------------------------------------------------------------------------------*/
.lNavi {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px 0;
	background-color: #f5f5f5;
	transition: background-color .3s;
	position: relative;
	z-index: 1;
}

.lNavi.is-fixed{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 999;
	background: #d6232c;
}
.ttlArea01.hazardpro+.lNavi.is-fixed{
	background: #3f729b;
}
.hazardpro .lNavi.is-fixed{
	background: #3f729b;
}
.ttlArea01.searchme+.lNavi.is-fixed{
	background: #27599e;
}
.searchme .lNavi.is-fixed{
	background: #27599e;
}
.dewsKyoten .lNavi.is-fixed{
	background: #24396e;
}

.lNavi ul {
	width: 1025px;
	/*margin: 0 auto;*/
	margin: 0;
	text-align: center;
}

.lNavi li {
	display: inline-block;
}

.lNavi li + li {
	margin-left: 18px;
}

.lNavi li.current > a {
	font-weight: bold;
}

.lNavi li > a {
	font-size: 15px;
	position: relative;
	display: inline-block;
	-webkit-transition: 0.3s;
	transition: 0.3s;
}

.lNavi.is-fixed li > a{
	color: #fff;
}

.lNavi li > a:hover {
	opacity: 1.0;
}

.lNavi li > a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	content: '';
	width: 0;
	height: 1px;
	-webkit-transition: 0.3s;
	transition: 0.3s;
}


.lNavi li > a:hover::after {
	width: 100%;
}

.lNavi li > a::after {
	background: #404040;
}

.lNavi.is-fixed li > a::after{
	background: #fff;
}

.lNavi .btn{
	/*
	position: absolute;
	top: 50%;
	right: calc(((100% - 1025px) / 2) - 223px);
	*/
	width: 180px;
	text-align: center;
	line-height: 1.0;
	font-size: 15px;
	font-weight: 500;
	margin-left: 45px;
	/*
	transform: translateY(-50%);
	*/
}
.lNavi .btn a{
	display: block;
	color: #fff;
	background: #414141;
	border-radius: 3em;
	padding: 0.8em 0;
}

@media screen and (max-width: 768px) {
	.lNavi {
		display: block;
		padding: 15px 2.66%;
		background-color: #fff;
	}
	.lNavi ul {
		width: auto;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		    flex-wrap: wrap;
	}
	.lNavi li {
		width: 49.64%;
	}
	.lNavi li + li {
		margin-left: 0;
	}
	.lNavi li:nth-child(odd) {
		margin-right: 0.72%;
	}
	.lNavi li:nth-child(n+3) {
		margin-top: 0.72%;
	}
	.lNavi li > a {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		width: 100%;
		background: #f5f5f5;
		font-size: 14px;
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
		text-align: center;
		min-height: 54px;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		padding: 5px;
	}
	.lNavi li > a::after {
		content: normal;
	}
	.lNavi .btn{
		position: relative;
		top: auto;
		right: auto;
		transform: none;
		font-size: 14px;
		width: 100%;
		margin: 3vw auto 0;
	}
}

/* ----------------------------------------------------------------------------------------------------
  pageTop
* --------------------------------------------------------------------------------------------------*/
#pageTop a {
	display: block;
	padding: 15px 0;
	color: #fff;
	font-size: 15px;
	text-align: center;
	background-color: #24396e;
}

/* ----------------------------------------------------------------------------------------------------
*  header
* --------------------------------------------------------------------------------------------------*/
#hWrap {
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
}

.header_static #hWrap{
	position: relative;
}

#header {
	padding: 10px 0 16px 0;
	background: #efefef;
	-webkit-transition: 0.3s;
	transition: 0.3s;
}

#header.fixed {
	padding: 10px 0;
}
.headerLogin{
	width: 980px;
	text-align: right;
	font-size: 12px;
	line-height: 1.0;
	margin: 0 auto 10px;
}
.headerLogin a{
	display: inline-block;
	color: #24396e;
}
.headerLogin a span{
	display: flex;
	align-items: center;
}
.headerLogin a img{
	width: 1em;
	height: auto;
	margin-left: 0.2em;
}

.header_static #header{
	padding: 10px 0 16px;
}

#hLogo {
	padding-top: 8px;
}

#hLogo a:hover {
	opacity: 1.0;
}

.hdTel {
	display: block;
	padding-left: 43px;
	margin-right: -10px;
	color: #24396e;
	line-height: 1.3;
	position: relative;
}

.hdTel::before {
	position: absolute;
	content: "";
}

.hdTel::before {
	left: 0;
	content: "\f095";
	-webkit-transform: rotate(15deg);
	transform: rotate(15deg);
	font-family: FontAwesome;
	font-size: 49px;
}

.hdTel span {
	display: block;
	font-size: 28px;
	letter-spacing: 0.07em;
}

.hdShare{
	margin-right: 30px;
	margin-top: 4px;
}
.hdShare .btn{
	font-size: 15px;
	color: #fff;
	text-align: center;
	font-weight: 500;
	width: 200px;
	height: 34px;
	line-height: 34px;
	border-radius: 5px;
	display: block;
	background: #2f3c6c;
}
.hdShare a{
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.hdShare a::before {
    left: 0;
    line-height: 1;
    content: "\f108";
    font-family: FontAwesome;
    font-size: 45px;
    margin-right: 8px;
    margin-top: 6px;
	color: #2f3c6c;
}

@media screen and (max-width: 768px) {
	#header {
		padding: 10px 0 3px;
	}
	#hLogo {
		width: 120px;
		padding-top: 6px;
		font-size: 0;
	}
	.hdTel {
		padding: 0;
		margin: 0;
		text-align: center;
		line-height: 1.0;
		font-size: 0;
	}
	.hdTel::before {
		font-size: 25px;
		position: static;
	}
	.hdTel::after {
		display: block;
		content: "お問い合わせ";
		font-size: 10px;
	}
	.hdTel span {
		display: none;
	}
	.btnMenu {
		height: 35px;
		padding-top: 2px;
		margin-left: 15px;
		position: relative;
		cursor: pointer;
		line-height: 1.0;
	}
	.btnMenu span {
		position: relative;
	}
	.btnMenu span,
	.btnMenu span::after {
		display: block;
		width: 31px;
		height: 3px;
		border-radius: 2px;
		margin: auto;
		background: #24396e;
		content: "";
	}
	.btnMenu span::after {
		position: absolute;
		top: 6px;
	}
	.btnMenu span:nth-child(2) {
		margin-top: 15px;
	}
	.btnMenu span:nth-child(2)::after {
		top: auto;
		bottom: 6px;
	}
	.btnMenu::after {
		display: block;
		margin-top: 2px;
		content: "メニュー";
		color: #24396e;
		font-size: 10px;
	}

	.hdShare{
		margin-right: 10px;
		margin-top: 0;
	}
	.hdShare .btn{
		display: none;
	}
	.hdShare a{
		text-align: center;
		display: block;
	}
	.hdShare a::before {
	    font-size: 20px;
	    margin-right: 0;
	    margin-top: 6px;
	    position: static;
	}
	.hdShare a::after {
		display: block;
		margin-top: 2px;
		content: "オンライン説明希望";
		color: #24396e;
		font-size: 9px;
		line-height: 1;
	}
}

/* gNavi
--------------------------------------------------*/
#gNavi {
	color: #fff;
	line-height: 1.2;
	border-bottom: solid 0.5px #243770;
	/* navi01 */
	/* navi02 */
}

@media print, screen and (min-width: 769px) {
	#gNavi {
		display: block !important;
		background: #4b6cb3;
	}
	#gNavi a:hover {
		background: rgba(255, 255, 255, 0.2);
		opacity: 1.0;
	}
}

@media screen and (max-width: 768px) {
	#gNavi {
		display: none;
		width: 100%;
		position: absolute;
		left: 0;
		padding: 20px 7.333%;
		border-bottom: initial;
	}
}

#gNavi .navi01 {
	margin: auto;
	-webkit-transition: 0.3s;
	transition: 0.3s;
	-webkit-backface-visibility: hidden;
	        backface-visibility: hidden;
}

@media print, screen and (min-width: 769px) {
	#gNavi .navi01 {
		width: 980px;
		text-align: center;
		font-size: 0;
	}
	#gNavi .navi01 > li {
		display: inline-block;
	}
	#gNavi .navi01 > li > a {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		height: 67px;
		padding: 0 40px;
		font-size: 16px;
		-webkit-font-smoothing: subpixel-antialiased;
	}
	#gNavi .navi01 > li > a::before {
		margin-right: 0.1em;
		vertical-align: middle;
		content: "\f08b";
		font-family: FontAwesome;
		font-size: 20px;
	}
}

#gNavi .navi01.fixed > li > a {
	height: 50px;
}

@media screen and (max-width: 768px) {
	#gNavi .navi01 {
		border-bottom: solid 1px #fff;
	}
	#gNavi .navi01 > li {
		border-top: solid 1px #fff;
	}
	#gNavi .navi01 > li > a {
		display: block;
		padding: 14px 5px 13px;
		font-size: 13px;
	}
	#gNavi .navi01 > li > a::before {
		display: inline-block;
		vertical-align: middle;
		margin-right: 0.5em;
		content: "\f08e";
		font-family: FontAwesome;
	}
}

#gNavi .trigger {
	position: relative;
}

@media print, screen and (min-width: 769px) {
	#gNavi .trigger > a {
		border-left: solid 1px #4b6cb3;
		border-right: solid 1px #4b6cb3;
	}
	#gNavi .trigger > a:hover {
		border-left: solid 1px rgba(255, 255, 255, 0.5);
		border-right: solid 1px rgba(255, 255, 255, 0.5);
	}
}

@media print, screen and (min-width: 769px) {
	#gNavi .navi02 {
		width: 100%;
		padding: 0;
		margin: 0;
		position: absolute;
		top: 70%;
		-webkit-transition: 0.5s;
		transition: 0.5s;
		visibility: hidden;
		opacity: 0;
		font-size: 14px;
		z-index: 1;
	}
	#gNavi .navi02 li {
		border: solid 1px rgba(255, 255, 255, 0.5);
		border-top: none;
		background: #4b6cb3;
	}
	#gNavi .navi02 li:first-child {
		border-top: solid 1px rgba(255, 255, 255, 0.5);
	}
	#gNavi .navi02 a {
		display: block;
		padding: 10px 0;
	}
}

@media screen and (max-width: 768px) {
	#gNavi .navi02 {
		display: none;
	}
}

#gNavi .trigger:hover .navi02 {
	top: 100%;
	visibility: visible;
	opacity: 1.0;
}

#overlay {
	display: none;
	width: 100%;
	height: 100%;
	background: rgba(75, 108, 179, 0.95);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 999;
}

/* ----------------------------------------------------------------------------------------------------
*  footer
* --------------------------------------------------------------------------------------------------*/
#footer {
	padding: 31px 0 20px;
	background: #4b6cb3;
	color: #fff;
	font-size: 13px;
}

@media screen and (max-width: 768px) {
	#footer {
		padding: 16px 0 10px;
	}
	#footer .footerIn {
		padding: 0 7.333%;
	}
}

/* fCon01
--------------------------------------------------*/
.fCon01 {
	padding-bottom: 52px;
}

.fCon01:after {
	content: "";
	display: block;
	clear: both;
}

@media screen and (max-width: 768px) {
	.fCon01 {
		padding-bottom: 0;
	}
}

#fLogo {
	margin-top: 59px;
}

#fLogo a:hover {
	opacity: 1.0;
}

#fNavi01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

#fNavi01 ul + ul {
	margin-left: 65px;
}

#fNavi01 li + li {
	margin-top: 10px;
}

#fNavi01 a {
	margin-left: 18px;
	font-weight: 400;
	position: relative;
}

#fNavi01 a::before {
	position: absolute;
	content: "";
}

#fNavi01 a::before {
	top: 1px;
	left: -18px;
	content: "\f08e";
	font-family: FontAwesome;
}

@media print, screen and (min-width: 769px) {
	#fNavi01 a {
		position: relative;
		display: inline-block;
		-webkit-transition: 0.3s;
		transition: 0.3s;
	}
	#fNavi01 a:hover {
		opacity: 1.0;
	}
	#fNavi01 a::after {
		position: absolute;
		bottom: 0;
		left: 0;
		content: '';
		width: 0;
		height: 1px;
		-webkit-transition: 0.3s;
		transition: 0.3s;
	}
	#fNavi01 a:hover::after {
		width: 100%;
	}
	#fNavi01 a::after {
		background: #fff;
	}
}

#fNavi01 .nestItem {
	padding-left: 0;
	margin: 5px 0 0 0;
}

#fNavi01 .nestItem a {
	font-weight: inherit;
}

#fNavi01 .nestItem a::before {
	display: none;
}

@media screen and (max-width: 768px) {
	#fNavi01 {
		display: block;
	}
	#fNavi01 ul + ul {
		margin: 0;
	}
	#fNavi01 li {
		border-top: solid 1px #fff;
	}
	#fNavi01 li + li {
		margin: 0;
	}
	#fNavi01 a {
		display: block;
		padding: 9px 5px 8px;
		margin: 0;
		font-size: 13px;
	}
	#fNavi01 a::before {
		display: inline-block;
		vertical-align: middle;
		margin-right: 0.5em;
		position: static;
	}
	#fNavi01 .nestItem {
		display: none;
	}
}

/* fCon02
--------------------------------------------------*/
.fCon02 {
	padding-top: 9px;
	border-top: solid 1px #adadad;
}

@media screen and (max-width: 768px) {
	.fCon02 {
		padding-top: 0;
		border-top-color: #fff;
	}
}

#fNavi02 li {
	float: left;
}

#fNavi02 li:nth-child(n+2) {
	margin-left: 1.6em;
}

@media print, screen and (min-width: 769px) {
	#fNavi02 a {
		position: relative;
		display: inline-block;
		-webkit-transition: 0.3s;
		transition: 0.3s;
	}
	#fNavi02 a:hover {
		opacity: 1.0;
	}
	#fNavi02 a::after {
		position: absolute;
		bottom: 0;
		left: 0;
		content: '';
		width: 0;
		height: 1px;
		-webkit-transition: 0.3s;
		transition: 0.3s;
	}
	#fNavi02 a:hover::after {
		width: 100%;
	}
	#fNavi02 a::after {
		background: #fff;
	}
}

@media screen and (max-width: 768px) {
	#fNavi02 li {
		margin-top: 20px;
		float: none;
	}
	#fNavi02 li:nth-child(n+2) {
		margin: 15px 0 0;
	}
	#fNavi02 a {
		display: block;
		padding: 0 5px;
		font-size: 11px;
		font-weight: 200;
	}
}

#fCopy {
	font-size: 12px;
}

@media screen and (max-width: 768px) {
	#fCopy {
		margin-top: 50px;
		text-align: center;
		font-size: 11px;
		font-weight: 200;
	}
}

/* 20210902　エマージオ追加CSS */
.emergeo .lNavi.is-fixed{
	background: #097600;
}
