#contents h3{
	position: relative;
	width: calc(100% - 1.7em);
	margin: 0 0 20px 1.7em;
	font-size: 21px;
	font-size: 21rem;
	line-height: 1.2;
	font-weight: bolder;
	color: #AC452B;
	border-bottom: 3px solid #AC452B;
}
#contents h3::before{
	position: absolute;
	left: -1.2em;
	font-family: "Font Awesome 5 Free";
	font-size: 1.4em;
	font-weight: 900;
	text-decoration: none !important;
}

/* ---------------------------------------------------------
	ツアーリード
--------------------------------------------------------- */
#tour_lead{
	margin-top: 20px;
}
#tour_lead #lead_title{
	width: 100%;
	position: relative;
}
#lead_title span.new{
	font-size: 14px;
	font-size: 14rem;
	color: #FFF;
	text-shadow:
		red 2px 0px,  red -2px 0px,
		red 0px -2px, red 0px 2px,
		red 2px 2px , red -2px 2px,
		red 2px -2px, red -2px -2px,
		red 1px 2px,  red -1px 2px,
		red 1px -2px, red -1px -2px,
		red 2px 1px,  red -2px 1px,
		red 2px -1px, red -2px -1px;
}
#lead_title ul{
	position: absolute;
	height: 23px;
	top: 0;
	left: 70px;
}
#lead_title ul li{
	display: inline-block;
	margin-right: 3px;
	padding: 1px 4px;
	font-size: 12px;
	font-size: 12rem;
	color: #FFF;
	border-radius: 3px;
}
#lead_title ul li.day{
	background: #FF9900;
}
#lead_title ul li.cat{
	background: #2F77FD;
}
#lead_title ul li.cls{
	background: #2AAD39;
}
#lead_title ul li.cty{
	background: #2AAD39;
}
#lead_title ul li:last-of-type{
	margin-right: 0;
}
#lead_title #lead_title_inner dl{
	text-align: center;
	border: 1px solid #000;
	-ms-flex-item-align: flex-start;
	-webkit-flex-item-align: flex-start;
	align-self: flex-start;
}
#lead_title_inner dl dt{
	padding: 0 3px;
	font-size: 10px;
	font-size: 10rem;
	color: #FFF;
	background: #000;
}
#lead_title_inner dl dd{
	padding: 0 2px;
	font-size: 12px;
	font-size: 12rem;
	font-weight: bolder;
	font-family: Verdana, Geneva, Helvetica, Arial, sans-serif;
}
#lead_title_inner h2{
	width: calc(100% - 70px);
	font-size: 24px;
	font-size: 24rem;
	font-weight: bolder;
	color: #AC452B;
	border-bottom: 3px dotted #AC452B;
}
#tour_lead #lead_explain{
	width: 100%;
	margin-top: 20px;
}
#lead_explain #slider{
	width: 65%;
	height: calc(var(--bxH) + 40px);
}
#slider .bx-wrapper,
	.bx-viewport,
	.bx-wrapper li{
	height: 100% !important;
}
.bx-wrapper li img{
	width: 100%;
	height: var(--bxH);
}
.bx-wrapper li div.caption{
	position: absolute;
	top: 100%;
	bottom: auto !important;
	background: none !important;
    padding: 5px 0 0 !important;
    color: #333 !important;
    font-size: 12px !important;
    font-size: 12rem !important;
}
.bx-wrapper .bx-caption{
	top: 100%;
	bottom: auto !important;
	background: none !important;
}
.bx-wrapper .bx-caption span{
    padding: 5px 0 0 !important;
    color: #333 !important;
    font-size: 12px !important;
    font-size: 12rem !important;
}
.bx-wrapper .bx-pager{
	padding-top: 0 !important;
}

#lead_explain dl{
	width: 32%;
	border-bottom: 1px solid #AC452B;
	-ms-flex-item-align: flex-start;
	-webkit-flex-item-align: flex-start;
	align-self: flex-start;
}
#lead_explain dl dt{
	padding: 3px 0;
	text-align: center;
	font-weight: bold;
	color: #FFF;
	background: #AC452B;
}
#lead_explain dl dd{
	padding: 5px 0;
}
#lead_explain #explain_text{
	width: 100%;
	margin-top: 50px;
}
#lead_explain.nodl #explain_text{
	width: 32%;
	margin-top: 0;
}
#lead_explain.nodl.noslide #explain_text{
	width: 100%;
}
#explain_text em{
	display: block;
	font-size: 18px;
	font-size: 18rem;
	font-weight: bold;
	margin-bottom: 1em;
}
#explain_text p{
	font-size: 16px;
	font-size: 16rem;
}

/* ---------------------------------------------------------
	申込み：その他
--------------------------------------------------------- */
.order_inner dl.order_caution{
	-webkit-box-lines: single;
	-ms-flex-wrap: nowrap;
	-webkit-flex-wrap: nowrap;
	flex-wrap: nowrap;
	width: 100%;
	margin-top: 10px;
	padding: 10px 20px;
	background: #FFF;
	border: 1px solid #E23035;
	border-radius: 5px;
}
.order_inner dl.order_caution dt{
	margin-right: 10px;
	font-weight: bolder;
	color: #E23035;
	white-space: nowrap;
}
.order_inner dl.order_caution dd{
	font-size: 12px;
	font-size: 12rem;
}

/* ---------------------------------------------------------
	ツアー詳細&スケジュール
--------------------------------------------------------- */
#detail h3::before{
	content: '\f03a';
}
#schedule h3::before{
	content: '\f017';
}
#schedule dl.kigou{
	margin-top: 5px;
	-webkit-box-pack: flex-end;
	-moz-box-pack: flex-end;
	-webkit-flex-pack: flex-end;
	-moz-flex-pack: flex-end;
	-ms-flex-pack: flex-end;
	-webkit-justify-content: flex-end;
	-moz-justify-content: flex-end;
	justify-content: flex-end;
}

#detail table,
#schedule table{
	width: 100%;
	background: #FFF;
	border-top: 1px solid #AC452B;
}
#detail table tr,
#schedule table tr{
	border-bottom: 1px solid #AC452B;
}
#detail table th,
#schedule table th{
	font-size: 12px;
	font-size: 12rem;
	font-weight: normal;
	white-space: nowrap;
	border-right: 1px dotted #AC452B;
	background: #F6F6F6;
}
#detail table th,
#detail table td,
#schedule table th,
#schedule table td{
	padding: 8px 5px;
	border-right: 1px dotted #AC452B;
}
#detail table td:last-of-type,
#detail table th:nth-of-type(3),
#schedule table td:last-of-type,
#schedule table th:nth-of-type(3){
	border-right: none;
}
#detail table td.stay,
#schedule table td.stay{
	text-align: center;
	vertical-align: middle;
}
#detail table th{
	width: 10%;
}
#detail table th:nth-of-type(2n){
	border-left: 1px solid #AC452B;
}
#detail table td{
	width: 40%;
}

/* ---------------------------------------------------------
	レスポンシブ
--------------------------------------------------------- */
@media screen and (max-width: 959px){
}
@media screen and (max-width: 599px){
	#lead_title_inner h2{
		font-size: 21px;
		font-size: 21rem;
	}
	#lead_explain #slider{
		width: 100%;
		order: 1;
	}
	#lead_explain dl{
		width: 100%;
		margin-top: 20px;
		order: 3;
	}
	#lead_explain #explain_text{
		width: 100%;
		order: 2;
	}
	#explain_text em{
		font-size: 16px;
		font-size: 16rem;
	}
	#explain_text p{
		font-size: 14px;
		font-size: 14rem;
	}
	.tour_tbl{
		width: 100%;
		margin-top: 30px;
	}
	.order_inner dl.order_caution{
		display: block;
		padding: 10px;
	}
	dl.order_caution dt{
		margin-bottom: 5px;
		text-align: center;
		border-bottom: 1px dotted #F00;
	}
	.order_inner2{
		padding: 10px 20px;
	}
	.order_inner2 table{
		width: calc(calc(100% - 20px) / 2) !important;
		margin-top: 20px;
		margin-right: 20px;
	}
	.order_inner2 table:nth-of-type(2n){
		margin-right: 0;
	}
	.order_inner2 table:nth-of-type(n+3){
		margin-top: 20px;
	}
}
@media screen and (max-width:479px){
	#lead_title_inner h2{
		width: 100%;
		line-height: 1.2;
		margin-top: 5px;
	}
	#lead_title #lead_title_inner dl{
		position: absolute;
		top: -22px;
		left: 0;
		-js-display: flex;
		display: -webkit-box;
		display: -moz-box;
		display: -ms-flexbox;
		display: -webkit-flex;
		display: flex;
		-webkit-box-align: center;
		-moz-box-align: center;
		-ms-flex-align: center;
		-webkit-align-items: center;
		align-items: center;
		white-space: nowrap;
		border: none;
	}
	#lead_title_inner dl dt{
		padding-top: 2px;
		-ms-flex-item-align: stretch;
		-webkit-flex-item-align: stretch;
		align-self: stretch;
	}
	#lead_title #lead_title_inner dd{
		border: 1px solid #000;
	}
	#contents h3{
		font-size: 18px;
		font-size: 18rem;
	}
	.bx-wrapper .bx-caption span{
		padding: 5px 10px !important;
	}
	#lead_explain #slider{
		height: calc(var(--bxH) + 39px)
	}
	#detail table{
		border-top: none;
		border-bottom: 1px solid #AC452B;
	}
	#detail table tr{
		border-bottom: none;
	}
	#detail table th,
	#detail table td{
		display: block;
		width: 100%;
		padding: 5px 0;
		border-right: none;
	}
	#detail table th{
		padding: 2px 0;
		border-top: 1px solid #AC452B;
		border-bottom: 1px dotted #AC452B;
	}
	#detail table th:nth-of-type(2n){
		border-left: none;
	}
}
@media screen and (max-width:375px){
}
