@charset "UTF-8";

@import url(./header.css);

/* reset.css */
html, body, div, span, iframe, h1, h2, h3, h4, h5, h6, 
p, a, img, dl, dt, dd, ol, ul, li, label, table, 
tbody, tr, th, td,figure,figcaption{
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 16px;
	font-weight: normal;
	vertical-align: baseline;
	box-sizing: border-box;
}

address {
	font-style: normal;
}

body {
	line-height: 1.6;
	font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color:#434242;
	overflow-x: hidden;
}

ol,ul {
	list-style: none;
	font-size:0;
}

li {
	font-size:16px;
}

table, td, th {
	white-space: nowrap;
	border: 1px solid #ddd;
	border-collapse: collapse;
	border-spacing: 0;
}

a {
	outline: none;
	text-decoration: none;
	display:block;
	color:#434242;
}

a:hover {
	text-decoration: none;
}

img {
	width:100%;
	vertical-align: top;
}

input[type="search"],input[type="button"],input[type="text"],input[type="submit"],[type="reset"],input[type="tel"],input[type="email"] {
	-webkit-appearance: none;
	border-radius:0;
	border: none;
	padding: 0;
	cursor: pointer;
}

.sp {
	display: none!important;
}

.tb {
	display: none!important;
}


/* 右寄せ */
.right {
	text-align:right;
}

/* センター寄せ */
.center {
	text-align:center;
}

.left {
	text-align: left;
}

.cf {
	overflow:hidden;
	zoom:1;
}

.floatL {
	float:left;
}

.floatR {
	float:right;
}

.flexBox {
	display: flex;
	justify-content: space-between;
}

.flexCenter {
	justify-content: center;
}

.inner {
	width:100%;
	max-width: 1120px;
	margin: 0 auto 6rem;
	text-align: center;
}

.textBig {
	font-size: 120%;
}

.textSmall {
	font-size: 80%;
}

.textBold {
	font-weight: bold;
}

.noLink a {
	opacity: 0.3;
	pointer-events: none;
}


h1 {
	display:none;
}

h2 {
	font-size: 180%;
	background: -webkit-linear-gradient(bottom, #fff 0%,#fff 37%,#000000 37%,#000000 45%,#fff 45%,#fff 100%, #fff);
	background: linear-gradient(to top, #fff 0%,#fff 37%,#000000 37%,#000000 45%,#fff 45%,#fff 100%, #fff);
	line-height: 3;
	margin: 6% auto ;
	display: inline-block;
	padding: 0 1.6rem;
}

h2 span {
	display: block;
	font-weight: bold;
	font-family: copperplate,"Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 60%;
}

#mainSuv h2,#mainTitle h2 {
    font-size: 200%;
    background: -webkit-linear-gradient(bottom, rgba(255, 255, 255, 0) 0%,rgba(255, 255, 255, 0) 37%,#000000 37%,#000000 45%,rgba(255, 255, 255, 0) 45%,rgba(255, 255, 255, 0) 100%, rgba(255, 255, 255, 0));
    background: linear-gradient(to top, rgba(255, 255, 255, 0) 0%,rgba(255, 255, 255, 0) 37%,#000000 37%,#000000 45%,rgba(255, 255, 255, 0) 45%,rgba(255, 255, 255, 0) 100%, rgba(255, 255, 255, 0));
    line-height: 3;
    margin: 1% auto;
    display: inline-block;
    padding: 0px 1.6rem;
    text-shadow: #fff 1px 1px 10px, #fff -1px 1px 10px, #fff 1px -1px 10px, #fff -1px -1px 10px;
    font-weight: bold;
    color: #231815;
}
#mainSuv.top h2 {
    margin: 10% auto;
	font-size: 250%;
}

#mainSuv h2 span {
    text-shadow: none;
}

#mainTitle h2 {
    line-height: 2.5;
	margin: 2% auto;
}

#mainTitle  h2 span {
    text-shadow: none;
	color:#B90F17;
}

#mainTitle  .whiteBg {
    background: rgba(255, 255, 255, 0.8);
	width: 50%;
	margin: 3.5% auto;
}

h3 {
	color:#666666;
	font-size: 110%;
	margin: 0 0 10% 0;
	font-weight: bold;
}

h4 {
	font-size: 110%;
	font-weight: bold;
}

/*main {
	margin-bottom: 10%;
}*/
.gothic {
	font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.mincho {
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.copper {
	font-family: copperplate;
}

.mark {
	margin-top:1rem; 
}

.mark a {
	background: url(../../image/common/arrow_red01.png)no-repeat 96% 50%;
	background-size: 25px;
	display: inline-block;
	padding: 0 40px 0 0;
	color:#C90010;
	line-height: 25px;
}
.mark2 a {
	background: url(../image/common/arrow01.png)no-repeat 0 50%;
	background-size: 18px;
	display: inline-block;
	padding: 0 40px 0 0;
	color:#C90010;
	line-height: 25px;
}

a.tel {
	pointer-events: none;
	display: inline-block;
} 

.btn {
    width: 50%;
    margin: 0 auto;
}

p.btn a{
	background: #18813F;
	color: #fff;
	width: 100%;
	margin: 8% auto 0;
	padding: 0.8rem 2rem;
	border-radius: 100px;
	font-size: 16px;
}

p.btn.red a{
	background: #b7241a;
}

.mb2 {
	margin-bottom: 2%;
}

.mb2rem {
	margin-bottom: 2rem;
}

.mb4 {
	margin-bottom: 4%;
}

.mb6 {
	margin-bottom: 6%;
}

.mb8 {
	margin-bottom: 8%;
}

.mb10 {
	margin-bottom: 10%;
}

.textColor {
	color: #C90010;
}

.auto {
	width: auto;
}

/*＝＝＝＝＝＝header＝＝＝＝＝＝＝＝*/
header,#spNav {
	background: #fff;
}


/*＝＝＝＝＝＝#infoBox＝＝＝＝＝＝＝＝*/
#infoBox dl {
	overflow-y: auto;
	height: 700px;
	text-align: left;
}
#infoBox dl dt {
	font-weight: bold;
	color:#040000;
	margin: 0 0 1em;
	padding: 2% 0 0;
	font-size: 16px;
} 
#infoBox dl span {
	padding: 0 0.8em;
	display: inline-block;
	color: #fff;
	width: 16%;
	margin-left: 0.5em;
	font-weight: normal;
	text-align: center;
	font-size: 85%;
	line-height: 1.7;
	vertical-align: top;
}
#infoBox dl span.info {
	background: #2F9FDA;
} 
#infoBox span.jinjya {
	background: #7379B9;
} 
#infoBox span.campaign {
	background: #F5A517;
} 
#infoBox span.bukken {
	background: #75A143;
} 
#infoBox span.event {
	background: #ef9090;
} 
#infoBox span.media {
	background: #f37db7;
} 

#infoBox dl dd {
	margin: 0 0 1.8em;
} 
#infoBox dl dd a {
	font-size: 14px;
	text-decoration: underline;
	color: #d81418;
	display: inline-block;
} 

/*＝＝＝＝＝＝youtubeの動画埋め込み＝＝＝＝＝＝＝＝*/
.movie {
	width:70%;
	margin: 0 auto;
}

.youtube {
	position: relative;
	width: 100%;
	padding: 56.2% 0 0 0;
	margin: 10px auto;
}

.youtube iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/*＝＝＝＝＝＝footer＝＝＝＝＝＝＝＝*/

footer {
	width:100%;
}

footer #bgColor {
	background: #333233;
	padding: 2rem 0;
}

footer .inner {
	margin: 0 auto 0;
}

footer #bgColor .inner {
	margin: 0 auto 40px;
}


footer p,footer a {
	font-size: 14px;
}

footer nav {
	position: relative;
	padding-bottom: 35px;
}

footer nav,footer nav a {
	color: #fff;
	text-align: left;
}

footer nav > .flexBox {
	width:100%;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	margin-bottom: 40px;
}

footer nav .flexBox li {
	width: 20%;
	margin-bottom: 20px;
}

footer nav .flexBox h4,footer nav .flexBox h4 a {
	font-size: 14px;
	margin-bottom: 1em;
	line-height: 1.4;
	font-weight: bold;
}

footer nav .flexBox p {
	margin: 0 0 5px 0.3rem;
	border-left: 1px solid #fff;
	padding-left:0.5em;
	line-height: 1.4;
}

footer #footIcon {
	margin-top: 25px;
	position: absolute;
	bottom: 0;
	right: 0;
	width: auto;
}

footer #footIcon li.icon {
	float: left;
	width: 40px;
	margin: 0 5px;
}

footer .bunjoLink.button,footer .corporateLink.button {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 0;
    margin: 0;
	width: auto;
}

footer .bunjoLink.button a {
	color:#435764;
	background-color:#EAE6DA;
}

footer .corporateLink.button a{
	color:#fff;
	background-color: #435764;
	box-shadow: none;
}

footer .bunjoLink.button a:hover,footer .corporateLink.button a:hover{
	background-color:#fff;
	color:#435764;
}

footer .bunjoLink .arrow::before { /* 長方形（棒）の表示設定 */
	background: #435764;
}
footer .bunjoLink .arrow::after  { /* 三角形（矢頭）の表示設定 */

	border-left: 5px solid #435764;
}

footer .corporateLink .arrow::before { /* 長方形（棒）の表示設定 */
	background: #fff;
}
footer .corporateLink .arrow::after  { /* 三角形（矢頭）の表示設定 */
	border-left: 5px solid #fff;
}

footer .bunjoLink.button a:hover span.arrow::before,footer .corporateLink .arrow::after {
	border-left: 5px solid #435764;
}
footer .bunjoLink.button a:hover .arrow::after,footer .corporateLink .arrow::after {
	border-left: 5px solid #435764;
}

footer .corporateLink .arrow::after {
    border-left: 5px solid #fff;
}





footer .inlineBlock {
	text-align: right;
	padding: 0.6rem 0;
}

footer .inlineBlock p {
	display: inline-block;
	vertical-align: bottom;
	line-height: 1.8;
	margin: 0 0.4rem;
}
footer .inlineBlock p#logo {
	width: 8%;
	
}


#pageTop {
	display: none;
	position: fixed;
	bottom: 20px;
	right: 5px;
	width: 40px;
	height: 40px;
	line-height: 40px;
	text-decoration:none;
	font-size: 13px;
	text-align:center;
/*20230915*/
	z-index: 999;
	color:#fff;
	background: #d1271a;
	border-radius: 50%;
}
#pageTop a {
	color:#fff;
}

/*＝＝＝＝＝＝フォーム＝＝＝＝＝＝＝＝*/
#formWrap{
	width: 80%;
	margin: 0 auto;
}

#formWrap table {
    border-collapse: collapse;
    border-spacing: 0;
    font-size: 100%;
    width: 100%;
	text-align: left;
	margin-bottom: 0.4rem;
}

input[type="search"], input[type="button"], input[type="text"],input[type="tel"],input[type="email"] {
	border: 1px solid #ececec;
	font-size:16px;
}

#formWrap table th {
	background: #eaeaea;
	padding: 1.2% 0.8em 0.8% 0.8em;
	width: 30%;
	border: 1px solid #fff;
	overflow: hidden;
	vertical-align: middle;
	line-height: 1.8;
}

#formWrap table td {
    padding: 1.5% 1rem 1.5% 1rem;
    border: 1px solid #e2e2e2;
	white-space: normal;
}

#formWrap .red {
	background: #c10000;
	padding: 0.5em 0.6em;
	margin: 0;
	float: right;
	color: #fff;
	font-size: 80%;
	box-sizing: border-box;
	line-height: 1.2;
}

input[type="text"],input[type="email"] {
	width: 80%;
	padding: 1%;
	margin: 0.4rem 0;
}

input[type="tel"] {
    width: 23.5%;
	padding: 1%;
	margin: 0.4rem 0;
}

select {
    padding: 1%;
}

input[type="text"].calendar {
	width: 20%;
}

input#zip {
    width: 20%;
}

input[type="checkbox"] {
	margin-left: 1.2rem;
}

input[type="submit"],[type="reset"],input[type="button"] {
	width: 130px;
	padding: 10px;
	background-color: #dc0011;
	margin: 4% 2%;
	font-size: 16px;
	color:#fff;
	border: 1px solid #ececec;
}

input[type="submit"]:hover,[type="reset"]:hover {
    background-color: #ff0000;
    color: #ffffff;
}

textarea {
    width: 98%;
}

#formWrap a {
	color:#dc0011;
	display: unset;
	text-decoration: underline;
}




@media screen and ( max-width:1020px) {
	.btn {
		width: 80%;
	}
}


@media screen and (min-width:768px) and ( max-width:1120px) {
	.inner {
		width:94%;
	}
	footer nav .flexBox {
		flex-wrap: wrap;
	}

	footer nav .flexBox li {
		width: 32%;
		margin-bottom: 2rem;
	}
	
	.tb {
		display: block!important;
	}
	
	#formWrap{
		width: 100%;
	}
	
	
}

@media screen and (min-width:320px) and ( max-width:767px) { 
	body {
		overflow-x: hidden;
	}
	.pc {
		display: none!important;
	}

	.tb {
		display: none!important;
	}

	.sp {
		display: block!important;
	}

	.sp .tb {
		display: block!important;
	}

	main {
		width:100%;
	}

	.inner {
		width:94%;
		margin: 0 auto;
		min-width: auto;
		max-width: unset;
	}

	.floatL {
		float:none;
	}

	.floatR {
		float:none;
	}

	.flexBox {
		display: flex;
		flex-wrap: wrap;
	}
	h2 {
		font-size: 140%;
	}

	#mainSuv h2 {
		font-size: 120%;
		padding: 0;
	}

	#mainSuv.top h2 {
		margin: 10% auto;
		font-size: 200%;
	}

	h3 {
		font-size: 100%;
	}
	.mark {
		margin-right: 0;
	}

	.mark a {
		padding: 0 2.2rem 0 0;
		font-size: 90%;
		background-size: 20px;
	}

	a.tel {
		pointer-events:auto;
	} 
	.btn {
		width: 90%;
		margin: 0 auto;
	}

	p.btn a{
		width: 100%;
		font-size: 12px;
		padding: 0.4rem 0;
	}

	.auto {
		width: 100%;
	}

/*＝＝＝＝＝＝#infoBox＝＝＝＝＝＝＝＝*/
	#infoBox dl dt {
		font-weight: bold;
		font-size: 90%;
	} 
	#infoBox dl span {
		width:50%;
		font-size: 90%;
	}

	#infoBox dl dd {
		margin: 0 0 1.8em;
		font-size: 90%;
	} 
	#infoBox dl dd a {
		font-size: 90%;
	} 

/*＝＝＝＝＝＝youtubeの動画埋め込み＝＝＝＝＝＝＝＝*/
	.movie {
		width:100%;
	}
/*＝＝＝＝＝＝footer＝＝＝＝＝＝＝＝*/
	footer #copy,footer a,footer nav .flexBox h4 {
		font-size: 12px;
		font-weight: normal;
	}
	
	footer #bgColor {
		padding: 2rem 0 70px;
	}
	
	footer nav {
		padding-bottom: 50px;
	}	
	
	footer nav .flexBox {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		width:100%;
		margin-bottom: 0;
	}
	footer nav .flexBox li{
		width:50%;
		margin-bottom: 2em;
	}

	footer .inlineBlock {
		text-align: right;
		padding: 0 30px 0 0;
	}
	#pageTop {
		bottom: 65px;
		right: 10px;
		width: 30px;
		height: 30px;
		line-height: 30px;
	}
	footer .inlineBlock p#logo {
		width: 18%;
	}

	footer #footIcon {
		right: 20px;
    	width: 45%;
		bottom: -80px;
	}

	footer .bunjoLink.button,footer .corporateLink.button {
    width: 100%;
		text-align: center;
}
	footer .corporateLink.button .arrow {
	margin-left:10px;
	}



/*＝＝＝＝＝＝フォーム＝＝＝＝＝＝＝＝*/
	#formWrap{
		width: 100%;
	}

	input[type="search"], input[type="button"], input[type="text"],input[type="tel"],input[type="email"] {
		border: 1px solid #ececec;
		width: 90%;
	}
	
	input[type="tel"] {
		width: 40.5%;
		padding: 1%;
		margin: 0.4rem 0;
	}
	
	select {
		padding: 1%;
	}

	input[type="text"].calendar {
		width: 50%;
	}
	
	input#zip {
		width: 36%;
	}
	
	#formWrap table th {
		width: 100%;
		display: block;
		font-size: 90%;
	}
	
	#formWrap table td {
		width: 100%;
		display: block;
		padding: 1rem 0 1rem 1rem;
		font-size: 90%;
	}
	
	textarea {
		width: 94%;
	}

	input[type="submit"],[type="reset"],input[type="button"] {
		width: 130px;
		padding: 10px;
		background-color: #dc0011;
		margin: 4% 2%;
		font-size: 16px;
		color:#fff;
		border: 1px solid #ececec;
	}

	input[type="checkbox"] {
		margin-left:1rem;
	}	

}


/* 20230922 */

main{
padding-top: 80px;
}

/*SEOリンク*/

.seoLink {
	width: 100%;
	max-width: 1120px;
	margin: 0 auto ;
	text-align: right;
}

.seoLink a {
	margin-top: 0;
	font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	display: inline-block;
}

@media screen and (max-width : 768px) {
	.seoLink {
		display: block;
		margin: 0 0 10px;
		text-align: center;
	}
}