@charset "UTF-8";

/*----------------------------------------------------*/
/* Base style
-----------------------------------------------------*/

html {
	font-size: 62.5%; /* sets the base font to 10px for easier math */
}
a:link {
	color: #333333;
	text-decoration: underline;
}
a:visited {
	color: #333333;
	text-decoration: underline;
}
a:hover {
	color: #333333;
	text-decoration: none;
}
a:active {
	color: #333333;
	text-decoration: underline;
}

#wrap_contents h1,
#wrap_contents h2,
#wrap_contents h3,
#wrap_contents h4 {
	font-family: "I-OTF-UDゴ表示Pro M","メイリオ",Meiryo,"HiraginoKakuGothic Pro","ヒラギノ角ゴPro W3","ＭＳＰゴシック","Lucida Grande","LucidaSans Unicode",Arial,Verdana,sans-serif;
	font-weight: bold;
}

#wrap_contents {
	width: auto;
	font-family: "I-OTF-UDゴ本文Pro R","メイリオ",Meiryo,"HiraginoKakuGothic Pro","ヒラギノ角ゴPro W3","ＭＳＰゴシック","Lucida Grande","LucidaSans Unicode",Arial,Verdana,sans-serif;
}

#wrap_contents a:hover img {
	opacity: 0.65;
}

#wrap_contents #topic_path {
	width: 960px;
	margin: 0 auto;
}

#wrap_contents .kk_text {
	margin: 0 .18em 0 -.08em;
	font-size: .667em;
  letter-spacing: -.22em;
}

.sp, .spMode, .tbMode {
	display: none;
}

.red {
    color: #df0202;
}

/* #topic_path
-----------------------------------------------------*/

#wrap_contents #topic_path {
		clear:both;
		padding:10px 0;
		line-height:1;
		display:block;
		overflow:hidden;
		font-size: 77%;
}

#wrap_contents #topic_path li{
	padding:0 10px 0 10px;
	margin:0 0 0 -10px;
	display:inline;
	background:url(/shared_file/img/topicpath_icon_cursor.gif) left center no-repeat;
}

#wrap_contents #topic_path li.redtxt a{
	color:red;
}
#wrap_contents #topic_path a:link {
	text-decoration: none;
}
#wrap_contents #topic_path a:visited {
	text-decoration: none;
}
#wrap_contents #topic_path a:hover {
	text-decoration: underline;
}
#wrap_contents #topic_path a:active {
	text-decoration: underline;
}

/* gnavi_kengaku
-----------------------------------------------------*/

#gnavi_kengaku {
	background: #df0202;
	color: #fff;
	position: relative;
	z-index: 3;
	line-height: 1.6;
}

#gnavi_kengaku > ul {
	width: 960px;
	box-sizing: border-box;
	margin: 0 auto;
	border-left: solid 1px #c10202;
	position: relative;
}

#gnavi_kengaku > ul > li:not(.calendar) {
 display: table-cell;
	border-right: solid 1px #c10202;
}

#gnavi_kengaku > ul > li:not(.calendar) > a {
 display: table-cell;
	vertical-align: middle;
	height: 60px;
	font-size: 1.6rem;
	font-weight: bold;
	font-family: "I-OTF-UDゴ表示Pro M","メイリオ",Meiryo,"HiraginoKakuGothic Pro","ヒラギノ角ゴPro W3","ＭＳＰゴシック","Lucida Grande","LucidaSans Unicode",Arial,Verdana,sans-serif;
	padding: 0 40px;
	text-decoration: none;
	color: #fff;
	margin: 0;
	position: relative;
	z-index: 2;
	line-height: 1;
}

#gnavi_kengaku > ul > li:not(.calendar) > a:after {
	content: "";
	width: 25px;
	height: 16px;
	background: url(/kfb/kengaku/img/common/gnavi_footprint.png) no-repeat;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	display: none;
}

#gnavi_kengaku > ul > li:not(.calendar):hover > a,
#gnavi_kengaku > ul > li:not(.calendar).active > a {
	background: #c10202;
}

#gnavi_kengaku > ul > li:not(.calendar):hover > a:after,
#gnavi_kengaku > ul > li:not(.calendar).active > a:after {
	display: block;
}

#gnavi_kengaku > ul > li:not(.calendar).current > a {
	background: #c10202 !important;
}

#gnavi_kengaku > ul > li:not(.calendar).current > a:after {
	display: block !important;
}

#gnavi_kengaku > ul > li.calendar {
	position: absolute;
	top: 0;
	right: 0;
	height: 60px;
	font-size: 1.4rem;
}

#gnavi_kengaku > ul > li.calendar > a {
	display: block;
	width: 100%;
	box-sizing: border-box;
	padding: 9px 67px 9px 34px;
	background: #fff;
	position: relative;
	border-radius: 5px;
	font-weight: bold;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
}

#gnavi_kengaku > ul > li.calendar > a:before {
	content: "";
	width: 8px;
	height: 12px;
	background: url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat;
	position: absolute;
	left: 18px;
	top: 50%;
	transform: translateY(-50%);
}

#gnavi_kengaku > ul > li.calendar > a:after {
	content: "";
	width: 55px;
	height: 54px;
	background: url(/kfb/kengaku/img/common/gnavi_ajipan.png) no-repeat;
	position: absolute;
	right: 7px;
	bottom: 0;
}

#gnavi_kengaku > ul > li > ul {
	position: absolute;
	z-index: 1;
	background: #fff;
	box-shadow:0px 0px 20px 0px #cccccc;
	min-width: 400px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
}

#gnavi_kengaku > ul.focus > li > ul {
	height: auto;
	overflow: visible;
}

#gnavi_kengaku > ul > li:hover > ul,
#gnavi_kengaku > ul > li > ul.visible {
	overflow: visible;
	height: auto;
	opacity: 1;
}

#gnavi_kengaku > ul > li > ul > li {
	border-bottom: solid 1px #eaeaea;
}

#gnavi_kengaku > ul > li > ul > li:last-child {
	border-bottom: none;
}

#gnavi_kengaku > ul > li > ul > li a {
	min-width: 400px;
	height: 60px;
	box-sizing: border-box;
	display: table-cell;
	vertical-align: middle;
	padding: 0 15px 0 47px;
	font-size: 1.6rem;
	font-weight: bold;
	color: #333;
	position: relative;
}

#gnavi_kengaku > ul > li > ul > li a:before {
	content: "";
	width: 8px;
	height: 12px;
	background: url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat;
	position: absolute;
	left: 30px;
	margin-top: 6px;
}

#gnavi_kengaku > ul > li.calendar > ul {
	top: 60px;
	right: 0;
}


/* contents
-----------------------------------------------------*/

#contents {
	font-size: 1.4rem;
	line-height: 1.6;
}

.main_contents {
	width: 960px;
	margin: 0 auto;
}


/* footer_kengaku
-----------------------------------------------------*/

#footer_kengaku {
	position: relative;
	margin-top: 60px;
	line-height: 1.6;
}

#footer_kengaku:before {
	content: "";
	width: 100%;
	height: 10px;
	background: url(/kfb/kengaku/img/common/bg_wave_top.png) repeat-x;
	position: absolute;
	z-index: 1;
}

/* factory_info */

#footer_kengaku .factory_info {
	height: 445px;
	padding-top: 185px;
	box-sizing: border-box;
	position: relative;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}

.kawasaki #footer_kengaku .factory_info {
	background-image: url(/kfb/kengaku/img/kawasaki/footer_kv.jpg);
}
.tokai #footer_kengaku .factory_info {
	background-image: url(/kfb/kengaku/img/tokai/footer_kv.jpg);
}
.kyushu #footer_kengaku .factory_info {
	background-image: url(/kfb/kengaku/img/kyushu/footer_kv.jpg);
}

#footer_kengaku .factory_info:after {
	content: "";
	width: 100%;
	height: 10px;
	background: url(/kfb/kengaku/img/common/bg_wave_btm.png) repeat-x;
	position: absolute;
	bottom: 0;
}

#footer_kengaku .factory_info .info {
	width: 960px;
	box-sizing: border-box;
	padding: 20px 30px 30px;
	margin: 0 auto;
	background: #fff;
	border-radius: 5px;
	overflow: hidden;
}

#footer_kengaku .factory_info h2 {
	font-size: 2.0rem;
	padding-bottom: 10px;
	border-bottom: solid 1px #eaeaea;
	margin-bottom: 28px;
}

#footer_kengaku .factory_info .calendar {
	width: 530px;
	float: right;
	position: relative;
}

#footer_kengaku .factory_info .calendar a {
	display: table-cell;
	vertical-align: middle;
	background: #df0202;
	width: 530px;
	height: 100px;
	box-sizing: border-box;
	color: #fff;
	padding-left: 58px;
	font-size: 2.0rem;
	font-weight: bold;
	border-radius: 5px;
}

#footer_kengaku .factory_info .calendar a:before {
	content: "";
	width: 8px;
	height: 12px;
	background: url(/kfb/kengaku/img/common/icon_arrow_02.png) no-repeat;
	position: absolute;
	left: 35px;
	top: 50%;
	transform: translateY(-50%);
}

#footer_kengaku .factory_info .calendar a:after {
	content: "";
	width: 94px;
	height: 106px;
	background: url(/kfb/kengaku/img/common/footer_ajipan.png) no-repeat;
	position: absolute;
	right: 40px;
	bottom: 0;
}

#footer_kengaku .factory_info .contact {
	float: left;
}

#footer_kengaku .factory_info .contact .tel_link {
	font-size: 1.6rem;
	font-weight: bold;
	font-family: "Lucida Grande","LucidaSans Unicode",Arial,Verdana,sans-serif;
	margin-bottom: 12px;
	line-height: 1.0;
}

#footer_kengaku .factory_info .contact .tel_link a {
	text-decoration: none;
}

#footer_kengaku .factory_info .contact .tel_link .free {
	font-weight: bold;
	font-size: 4.0rem;
	display: block;
	margin-bottom: 8px;
}

#footer_kengaku .factory_info .contact .tel_link .free img {
	vertical-align: middle;
	position: relative;
	top: -2px;
	margin-right: 10px;
}

#footer_kengaku .factory_info .contact .access {
	font-size: 1.4rem;
	font-weight: bold;
}

#footer_kengaku .factory_info .contact .access a:before {
	content: "";
	width: 8px;
	height: 12px;
	background: url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat;
	display: inline-block;
	vertical-align: middle;
	margin-right: 10px;
}

/* factory_others */

#footer_kengaku .factory_others {
	width: 960px;
	margin: 0 auto;
	padding: 60px 0 55px;
}

#footer_kengaku .factory_others h2 {
	font-size: 2.0rem;
	margin-bottom: 20px;
	line-height: 1;
}

#footer_kengaku .factory_others ul {
	overflow: hidden;
}

#footer_kengaku .factory_others li {
	width: 460px;
	box-sizing: border-box;
	border: solid 2px #b0b0b0;
	border-radius: 5px;
	float: left;
	margin: 0 0 20px 40px;
}

#footer_kengaku .factory_others li:nth-child(odd) {
	margin-left: 0;
}

#footer_kengaku .factory_others li a {
	display: block;
	padding: 8px;
	text-decoration: none;
}

#footer_kengaku .factory_others li a .image {
	margin-right: 18px;
	width: 100px;
	display: inline-block;
	vertical-align: middle;
}

#footer_kengaku .factory_others li a .image img {
	width: 100%;
}

#footer_kengaku .factory_others li a p {
	font-size: 2.0rem;
	font-weight: bold;
	display: inline-block;
	vertical-align: middle;
	text-decoration: underline;
}
#footer_kengaku .factory_others li a:hover p {
	text-decoration: none;
}
#footer_kengaku .factory_others li a p:before {
	content: "";
	width: 8px;
	height: 12px;
	background: url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat;
	display: inline-block;
	vertical-align: middle;
	margin-right: 10px;
}

/*----------------------------------------------------*/
/* component
-----------------------------------------------------*/

section p {
	line-height: 2.0;
}

/* image
-----------------------------------------------------*/

.img_center {
	text-align: center;
	margin-top: 30px;
}

.img_right {
	overflow: hidden;
}

.img_right .image {
	float: right;
	width: 40%;
	box-sizing: border-box;
}

.img_right .detail {
	float: left;
	width: 58%;
}

.img_right .detail .htype03:first-child {
	margin-top: 10px;
}

.img_right .image img {
	width: 100%;
}

.img_left {
	overflow: hidden;
}

.img_left .image {
	float: left;
	width: 20%;
	box-sizing: border-box;
}

.img_left .detail {
	float: right;
	width: 78%;
}

.img_left .detail .htype03:first-child {
	margin-top: 10px;
}

.img_left .image img {
	width: 100%;
}


/* heading
-----------------------------------------------------*/

.htype01 {
	font-size: 2.0rem;
	padding-left: 25px;
	position: relative;
	margin: 60px 0 25px;
}

.htype01:before {
	content: "";
	width: 8px;
	height: 30px;
	background: url(/kfb/kengaku/img/common/icon_linehead.png) no-repeat;
	position: absolute;
	left: 1px;
	top: 0;
}

.htype02 {
	font-size: 2.0rem;
	font-weight: bold;
	color: #df0202;
	margin: 20px 0 10px;
}

.htype03 {
	font-size: 1.4rem;
	font-weight: bold;
	margin: 20px 0 10px;
	line-height: 1.3;
}

.htype04 {
	font-size: 2.4rem;
	margin-bottom:1em;
	padding-top:1.2em;
}



/* link
-----------------------------------------------------*/
.link_ic01 {
	font-size: 1.4rem;
}

.link_ic01 a:before {
	content: "";
	width: 8px;
	height: 12px;
	background: url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat;
	display: inline-block;
	vertical-align: middle;
	margin-right: 10px;
}

.link_ic02 {
	font-size: 1.4rem;
}

.link_ic02 a:before {
	content: "";
	width: 16px;
	height: 18px;
	background: url(/kfb/kengaku/img/common/icon_pdf.gif) no-repeat;
	display: inline-block;
	vertical-align: middle;
	margin-right: 10px;
}

.link_ic03 {
	display: inline-block;
	margin-top: 30px;
}

.link_ic03 a {
	display: block;
	border: solid 2px #b0b0b0;
	border-radius: 5px;
	background: #fff;
	padding: 16px 23px;
	font-weight: bold;
}

.link_ic03 a:before {
	content: "";
	width: 8px;
	height: 12px;
	background: url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat;
	display: inline-block;
	vertical-align: middle;
	margin-right: 10px;
}

.link_ic03 a.ext:before {
	width: 11px;
	height: 10px;
	background: url(/kfb/kengaku/img/common/icon_external.png) no-repeat;
}

.inlineIcon01 {
	display: inline-block;
	margin: 0 5px;
	vertical-align: middle;
}

.linkbtn01 {
	background:#FFF url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat 15px center;
	display: inline-block;
	border: 2px solid #b0b0b0;
	border-radius: 5px;
	font-size: 1.4rem;
	line-height: 1.3;
	margin: 1em 0;
	padding:10px 30px 10px 30px;
}

.linkbtn02 {
	border-radius: 5px;
	background:#df0202 url(/kfb/kengaku/img/common/icon_arrow_02.png) no-repeat 15px center;
	color: #FFF !important;
	display: inline-block;
	font-size: 1.4rem;
	line-height: 1.3;
	padding:12px 50px 12px 30px;
}

.linkbtn03 {
	background:#FFF url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat 15px center;
	display: inline-block;
	border: 2px solid #b0b0b0;
	border-radius: 5px;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1.3;
	margin: 0 0 25px 0;
	padding:10px 30px 10px 30px;
}

.innerlinktext01 {
	background: url(/kfb/kengaku/img/common/icon_arrow_03.png) no-repeat 0 center;
	display: inline-block;
	padding:0 0 0 15px;
}

/* modal override
-----------------------------------------------------*/

#kengaku-content .kengaku-content-modal,
#kengaku-content .modal-kengaku-reservation input.mail,
#kengaku-content .modal-kengaku-reservation-calcel input.mail {
	box-sizing: border-box;
}

#kengaku-content .kengaku-content-modal a.mkr-close:hover img {
	opacity: 1;
}

.kengaku-content-modal button {
	cursor: pointer;
}

.kengaku-content-modal button:hover {
	opacity: 0.75;
}

/* waiting
-----------------------------------------------------*/

.waiting {
	padding-top: 60px;
	min-height: 500px;
	font-size: 1.4rem;
	text-align: center;
}
.waiting h1 {
	margin-bottom: 20px;
	font-size: 2.0rem;
	font-weight: bold;
}
.waiting .loading-img {
	margin-bottom: 30px;
}
.waiting p.btn {
	margin-bottom: 15px;
}
.waiting p.btn a {
	width: 216px;
	margin: 0 auto;
	display: block;
}
.waiting p.btn a {
	display: block;
	height: 38px;
	line-height: 38px;
	text-align: center;
	background:url(/shared_file/img/btn_bg.gif) no-repeat;
}

.waiting p.btn a,
.waiting p.btn a:hover {
	color: #333;
	text-decoration: none;
}
/* covid-19対応リンク */
.p-linkbtn{
	border: 2px solid #b0b0b0;
	border-radius: 5px;
	display: flex;
	align-items: center;
	max-width: 960px;
	height: 42px;
	margin: 0 auto 50px;
}
.p-linkbtn.p-linkbtn--reservation{
	margin: 40px auto 0;
}
.p-linkbtn__col2{
	max-width: 50%;
	width: 50%;
	text-align: center;
}
.p-linkbtn__link{
	display: block;

	font-size: 1.4rem;
	line-height: 1.3;
	padding: 10px 30px 10px 30px;
}
.p-linkbtn__link::before{
	background:  url(/kfb/kengaku/img/common/icon_arrow_01.png) no-repeat 15px center;
	content: "";
	display: inline-block;
	height: 20px;
	margin-right: .5em;
	vertical-align: middle;
	width: 25px;
}
.p-linkbtn__center{
	border-left: 1px solid #b0b0b0;
	height: 18px;
}