@charset "utf-8";

.kaisei{
	font-family: 'Kaisei Decol', serif;
}

#main_visual{
	position: relative;
}
.mv_header{
	background: url(/static/img/ferry/campaign/island/common/bg-obi-back.png) center bottom repeat-x;
	background-size: 698px 80px;
	width: 100%;
	height: 80px;
	position: absolute;
	top: 0;
	left: 0;
	padding-top: 8px;
}
.mv_header h1{
	order: 2;
	font-weight: normal;
}
h1 span{
	display: block;
	text-align: center;
	color: #fff;
}
h1 .eng{
	font-size: 14px;
	letter-spacing: 0.1em;
}
h1 .jpn{
	font-size: 33px;
	letter-spacing: 0.06em;
}
.mv_header .island_icon{
	order: 1;
}
.mv_header .pods{
	order: 3;
}
.mv_header .pods .pod{
	display: table;
	float: right;
	background: #1c1c1c;
	color: #fff;
	padding: 3px 6px;
	margin-bottom: 4px;
	border-radius: 4px;
	font-size: 10px;
}
.mv_header .pods:after{
	content: '';
	display: block;
	width: 100%;
	height: 0;
	clear: both;
}
#main_visual > img{
	width: 100%;
	height: auto;
	max-height: 800px;
	object-fit: cover;
	object-position: center 20%;

}
.navi{
	background: #ECF1F6;
}
.localnav-island {
	overflow: hidden;
	border-radius: 4px;
	display: flex;
	width: 100%;
}
.localnav-island li {
	width: 100%;
	border-right: 1px solid rgba(0,0,0,0.5);
	border-left: 1px solid rgba(255,255,255,0.2);
}
.btn-localnav {
	padding: 10px 3px;
	font-size: 13px;
	display: block;
	text-align: center;
	background: #2a1f1b;
	color: #fff;
}
.btn-localnav:hover {
	text-decoration: none;
	background: #392c25;
	color: #fff;
}
.content{
	padding: 24px 0;
	background: #D5E5D9;
}
.content p{
	color: #28201e;
	font-size: 15px;
	line-height: 1.414;
}
.title_contents{
	color: #0a441a;
	font-size: 32px;
	position: relative;
	display: table;
	margin: 0 auto 40px;
}
.title_contents:after{
	content: '';
	position: absolute;
	display: block;
	background: #0a441a;
	width: 100%;
	height: 3px;
	bottom: -8px;
	left: 50%;
	transform: translateX(-50%);
}
.title_contents span{
	font-size: 24px;
}
#feature p{
	margin-bottom: 1em;
}
.features{
	padding: 24px 0;
}
.features.onlyshodo{
	justify-content: center;
}
.features img{
	margin-bottom: 16px;
}
.features h3{
	font-weight: bold;
	font-size: 14px;
}
.features p{
	font-size: 14px;
}
.features .reserve{
	margin-top: 16px;
	padding: 16px;
	border: 1px solid #2a1f1b;
}
.features .reserve dl{
	font-size: 14px;
}
.features .reserve dt{
	margin: 8px 0 4px;
}
.features .reserve a{
	text-decoration: underline;
}
#plan{
	background: url(/static/img/ferry/campaign/island/common/bg-plan.jpg) center center;
	background-size: cover;
}
#plan .title_contents{
	color: #1d1d1d;
}
#plan .title_contents:after{
	background: #1d1d1d;
}
#ferryonly{
	color: #1d1d1d;
	font-size: 18px;
	border-bottom: 1px solid #333;
	padding-bottom: 6px;
	margin-bottom: 24px;
	font-weight: bold;
}
.cards > div{
	margin-bottom: 16px;
}
.card {
	border-radius: 4px;
	text-align: left;
	margin-bottom: 30px !important;
	border: none;
	box-shadow: 0px 0px 6px #ccc;
}
.card.card-plan {
	display: flex;
	flex-direction: row;
	align-items: center;
	color: #444;
	position: relative;
	margin-bottom: 0 !important;
	border-radius: 8px;
	padding: 12px 36px 12px 12px;
}
.card-plan:hover {
	background: #ffebf5;
	text-decoration: none;
}
.card-plan:after {
	content: "\f0a9";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	position: absolute;
	top: 50%;
	right: 12px;
	transform: translate(0, -50%);
	color: #B50909;
}
.rosen {
	font-size: 16px;
	font-weight: bold;
	width: 60%;
}
.price {
	font-size: 16px;
	width: 40%;
	text-align: right;
}
.num {
	font-size: 140%;
	font-weight: bold;
	color: #B50909;
	line-height: 1;
}
#spot{
	background: url(/static/img/ferry/campaign/island/common/bg-spot.jpg) center center;
	background-size: cover;
}
#spot .inner-spot{
	padding: 24px;
	background: rgba(255,255,255,0.5);
}
#spot .col-12{
	padding-bottom: 16px;
}
#spot .ttl{
	margin: 12px 0 12px;
	font-size: 13px;
	font-weight: bold;
	color: #0a441a;
}
#spot .caption{
	font-size: 15px;
	display: block;
	margin-top: 0.4em;
	color: #212529;
}
#spot .maintext{
	font-size: 14px;
}
#faq{
	background: #fafafa;
	padding: 24px 0;
}
#faq .title-contents {
	font-size: 18px;
	margin-bottom: 24px;
}
#faq-accordion .card {
	margin-bottom: 20px !important;
}
#faq .card-header button {
	font-size: 16px;
	display: block;
	padding: 24px 24px;
	cursor: pointer;
	position: relative;
	line-height: 1.6;
	width: 100%;
	text-align: left;
}
.num-label {
	position: absolute;
	top: 50%;
	left: 12px;
	transform: translate(0, -50%);
	background: #333;
	color: #fff;
	margin-right: 10px;
	border-radius: 4px;
	padding: 3px 6px;
	display: inline-block;
}
#faq .card-header button.collapsed:after {
	content: "\f078";
}
#faq .card-header button:after {
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 20px;
	content: "\f077";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	color: #999;
	font-size: 16px;
}
#feature a,
#spot a{
	text-decoration: underline;
	color: #0669cf;
	font-weight: bold;
}


@media (min-width:768px) {
	.mv_header{
		background-size: 1310px 150px;
		height: 130px;
	}
	.mv_header .island_icon img{
		max-width: 88px;
	}
	.mv_header h1{
		padding-top: 8px;
	}
	h1 .eng{
		font-size: 15px;
	}
	h1 .jpn{
		font-size: 46px;
	}
	.mv_header .pods .pod{
		float: none;
		font-size: 14px;
		margin-left: auto;
	}
	.content{
		padding: 48px 0;
	}
	.title_contents{
		font-size: 42px;
	}
	.title_contents span {
		font-size: 32px;
	}
	.card.card-plan {
		padding: 24px 36px 24px 12px;
	}
	.tbl-plan{
		display: table;
	}
	.tbl-plan tbody, .tbl-plan tr{
		display: table-row;
	}
	.tbl-plan td{
		display: table-cell;
		vertical-align: middle;
	}
	.tbl-plan td.td-price {
		width: 40%;
		text-align: right;
		display: table-cell;
		vertical-align: middle;
	}
	#faq{
		padding: 40px 0;
	}
}


@media (min-width:992px) {
	.mv_header .island_icon img{
		margin-top: 6px;
	}
	.mv_header .pods{
		padding-top: 10px;
	}
	#main_visual > img{
		max-height: 600px;
	}
	.btn-localnav{
		padding: 12px 6px;
		font-size: 14px;
	}

}



/*20240527追記*/
#feature .title-sub-contents {
    border-bottom: solid 1px #0a441a;
    color: #0a441a;
    width: fit-content;
    margin: 0 auto 10px;
}

#feature .btn{
	color: #129d62; 
	border:solid 1px #129d62; 
	background:#fff; 
	text-decoration: none;
	border-radius: 5px;
}

#feature .btn:hover{
	opacity: 0.85;
}

@media (min-width:768px) {
	#feature iframe{
		width: 500px;
	}
}

