@charset "utf-8";
/* CSS Document */
html {
  scroll-behavior: smooth;
}
footer{
	margin: 0;
}
strong{
	font-weight: bold;
}
#nav_header_sp .menugroup.fixed {
	z-index: 3;
}
.ank_link_btn{
    position: absolute;
    width: 12vw;
    height: 12vh;
    margin: auto;
    top: -12%;
    bottom: 0;
    right: 2rem;
}
.ank_link_btn:hover{
	opacity: 0.8;
	transition: all 0.5s;
}
.modaal-close{
	color: #FC7D59;
}
.this_SPon{
    display: none;
}
.contents{
	max-width: 1500px;
	margin: 0 auto;
}
.contents.grd{
	background-image: linear-gradient(90deg, #f8ce7b, #fbb38c);
}
.contents.yel{
	background: #FFF9DA;
}
.contents.light_yel{
	background: #FFFCF5;
}
.contents.gray{
	background: #E5E5E5;
}
.contents .wrapper{
	max-width: 1080px;
	margin: 0 auto;
	padding: 80px 0;
}
.title{
	text-align: center;
	padding-bottom: 20px;
	position: relative;
}
.text{
	text-align: center;
	font-size: 100%;
	line-height: 1.8;
	position: relative;
}

.entry_botan{
	position: relative;
	margin: 60px auto 0;
	text-align: center;
	font-weight: 600;
	font-size: 16px;
	max-width: 280px;
	padding: 20px 0;
	display: block;
	background-image: linear-gradient(90deg, #F49C3C, #FC7C5A);
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.25);
}

.entry_botan:hover{
	opacity: 0.8;
	box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
	transition: all 0.5s;
}

.entry_botan::before{
    position: absolute;
    content: "";
    width: 278px;
    height: 60px;
    border: 1px solid #000;
    top: -3px;
    right: 4px;
}

/*==========================================
MV
==========================================*/
.mv_main{
	max-width: 1500px;
	margin: 0 auto;
	position: relative;
}


/*==========================================
head navi
==========================================*/
.navi ul{
	max-width: 1500px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
}

.navi ul li{
	height: 56px;
	padding: 0  10px;
	width: 20%;
	text-align: center;
	border-right: 1px solid #BCBCBC;
	display: flex;
	align-items: center;
	justify-content: center;
}

.navi ul li:first-child{
	border-left: 1px solid #BCBCBC;
}

.navi ul li a{
	display: flex;
	align-items: center;
	font-size: 16px;
	font-weight: bold;
	line-height: 1.2;
	color: #000;
}

.navi ul li a:hover{
	color: #ff981f;
	transition: all 0.5s;
}


/*==========================================
動画紹介
==========================================*/
.movie_block{
	position: relative;
}

.movie_block::after{
	position: absolute;
	content: "";
	background: url("../img/video_type_right.png");
	right: 0;
	bottom: -40px;
	height: 384px;
	width: 330px;
	z-index: -1;
}

.movie_block::before{
	position: absolute;
	content: "";
	background: url("../img/video_type_left.png");
	left: 0;
	top: 70px;
	height: 424px;
	width: 356px;
	z-index: -1;
}

.movie_block video{
	max-width: 680px;
	margin: 0 auto;
	display: block;
	padding-bottom: 20px;
}


/*==========================================
About us
==========================================*/
.abt_us{
	position: relative;
}
.abt_us .abt_us_img{
	position: absolute;
	left: 0;
	top: -60px;
	height: 485px;
	max-width: 350px;
}
.abt_us .miyazaki_map{
    position: absolute;
    right: 2%;
    top: -34px;
    height: 500px;
    width: 361px;
}
.abt_us .miyazaki_map::before{
    position: absolute;
    content: "";
    background: url(../img/outside.png);
    height: 116px;
    width: 155px;
    bottom: 20px;
    right: -20px;
}
.abt_us .miyazaki_map map area{
	cursor: pointer;
}
.abt_us .abt_us{
	max-width: 515px;
	margin: 0 auto;
}

/*==========================================
event_program
==========================================*/
.contents.yel .wrapper{
	position: relative;
}
.contents.yel .wrapper::before {
	position: absolute;
	content: "";
	background: url("../img/event_type_bk_left1.png");
	background-size: contain;
	background-repeat: no-repeat;
	width: 410px;
	height: 409px;    
	left: -3vw;
    top: 10vh;
}
.contents.yel .wrapper::after {
	position: absolute;
	content: "";
	background: url(../img/event_type_bk_right1.png);
	background-size: contain;
	background-repeat: no-repeat;
	width: 158px;
	height: 204px;
    top: 20vh;
    right: -2vw;
}
.contents.yel .wrapper .container::before {
	position: absolute;
	content: "";
	background: url(../img/event_type_bk_right2.png);
	background-size: contain;
	background-repeat: no-repeat;
	width: 379px;
	height: 380px;    
    right: -2vw;
    bottom: 4vh;
}
.event_backbord{
	position: relative;
	z-index: 1;
}
.event_program {
	max-width: 860px;
	margin: 60px auto 0;
	padding: 60px;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.25);
	display: flex;
}
.event_program .t_img_block{
	width: calc(100% - 400px);
}
.event_program .t_img_block .t_img:first-child,.event_program .t_img_block .t_img:nth-child(3){
	padding-bottom: 20px;
}
.event_program .timeline{
	max-width: 400px;
}
.event_program .timeline ul li {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
}
.event_program .timeline ul li .time{
	font-size: 18px;
	font-weight: bold;
	color: #FC7D59;
	padding-right: 30px;
	width: calc(100% - 320px);
	position: relative;
}
.event_program .timeline ul li .time::before{
    position: absolute;
    content: "";
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #FC7D59;
    top: 0;
    right: -12px;
}
.event_program .timeline ul li .time_text{
	padding-left: 30px;
	width: 320px;
	border-left: 2px dotted #000;
	padding-bottom: 40px;
}
.event_program .timeline ul li:last-child .time_text{
	border-left: none;
}
.event_program .timeline ul li:nth-child(2) .time_text{
	padding-bottom: 160px;
}
.event_program .timeline ul li:nth-child(5) .time_text{
	padding-bottom: 120px;
}
.event_program .timeline ul li:nth-child(6) .time_text{
	padding-bottom: 120px;
}
.event_program .timeline ul li .time_text .title{
	font-size: 18px;
	font-weight: 600;
	text-align: left;
	line-height: 1;
}
.event_program .timeline ul li .time_text .text{
	text-align: left;
    font-size: 0.8rem;
    line-height: 1.6;
}
.event_program .timeline ul li .time_text .blank_btn{
	position: relative;
	text-align: center;
	display: block;
	background: #000;
	padding: 10px 0;
	max-width: 195px;
	margin: 20px 0 0;
	color: #fff;
    font-size: 0.8rem;
	font-weight: 600;
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.25);
}
.event_program .timeline ul li .time_text .blank_btn::after{
    position: absolute;
    content: "";
    background: url(../img/new_window_w.svg);
    width: 13px;
    height: 13px;
    right: 13px;
    top: -2px;
    bottom: 0;
    margin: auto;
}
.event_program .timeline ul li .time_text .blank_btn:hover{
	box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
	transition: all 0.5s;
}


/*==========================================
voice
==========================================*/
.voice_backbord{
	position: relative;
}
.voice_backbord::before{
    position: absolute;
    content: "";
    background: url(../img/event_type_bk_o_left.png);
    background-size: contain;
    background-repeat: no-repeat;
    width: 401px;
    height: 402px;
    left: -10vw;
    top: -2vh;
}
.voice_backbord::after{
	position: absolute;
	content: "";
	background: url("../img/event_type_bk_o_right.png");
	background-size: contain;
	background-repeat: no-repeat;
	width: 400px;
	height: 380px;
    right: -10vw;
    bottom: -2vh;
}
.voice{
	max-width: 860px;
	margin: 0 auto;
}
.swiper-target01 {
	position: relative;
}
.swiper-controller{
	display: flex;
	justify-content: space-between;
	height: 2.4rem;
    position: absolute;
    width: 100%;
    top: 40%;
}

.swiper-button-prev{
	left: -20px;
}

.swiper-button-next{
	right: -20px;
}
.swiper-button-prev,
.swiper-button-next {
    height: 45px;
    width: 45px;
	position: relative;
	background: #000;
	border-radius: 50%;
	z-index: 2;
	cursor: pointer;
}

.swiper-button-next::after,
.swiper-button-next::before,
.swiper-button-prev::after,
.swiper-button-prev::before {
    content: "";
    position: absolute;
    top: calc(50% - 2px);
    width: 16px;
    height: 3px;
    border-radius: 10px;
    background-color: #fff;
    transform-origin: calc(108% - 2px) 50%;
}

.swiper-button-next::after,
.swiper-button-next::before{
	left: 0;
	right: 0;
	margin: auto;
}

.swiper-button-prev::after,
.swiper-button-prev::before{
	left: 0;
}

.swiper-button-next::before {
    transform: rotate(45deg);
}

.swiper-button-next::after {
    transform: rotate(-45deg);
}

.swiper-button-prev::before {
    transform: rotate(135deg);
}

.swiper-button-prev::after {
    transform: rotate(-135deg);
}

.swiper-target01{
	position: relative;
}

.voice_box{
	text-align: center;
	padding: 20px;
	background: #fff;
	border-radius: 10px;
	    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.25);
}

.voice_box .voice_icon{
	margin-bottom: 20px;
}

.voice_box .voice_title{
	font-size: 16px;
	font-weight: bold;
	padding-bottom: 20px;
}

.voice_box .voice_text{
    text-align: left;
    font-size: 0.8rem;
    line-height: 1.6;
}


/*==========================================
cmp_details
==========================================*/
.cmp_details{
	max-width: 860px;
	margin: 60px auto 0;
}
.cmp_details .sub_title{
	font-size: 18px;
	font-weight: 600;
	color: #FC7D59;
    padding-bottom: 20px;
}
.cmp_details table{
	border-top: 2px solid #FC7D59;
	border-bottom: 2px solid #FC7D59;
	width: 100%;
}
.cmp_details table tr{
	border-bottom: 1px dotted #FC7D59;
}
.cmp_details table tr th{
	padding: 30px 40px;
	text-align: left;
    font-size: 0.8rem;
    line-height: 1.6;
}
.cmp_details table tr th .link{
	color: #0095FF;
	font-weight: 600;
	text-decoration: underline;
}
.cmp_details table tr td{
	background: #FFEED5;
	font-weight: 600;
	padding: 30px;
	text-align: center;
	width: 180px;
}
.cmp_details .small_text{
	font-size: 14px;
	padding-top: 20px;
}

/*==========================================
com_present
==========================================*/
.present_backbord{
	position: relative;
	z-index: 1;
}
.com_present{
	max-width: 860px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	padding-top: 40px;
	gap: 30px;
	position: relative;
}
.com_present .com_present_block{
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.25);
	border-radius: 10px;
	overflow: hidden;
}
.com_present .com_present_block:nth-child(1){
	width: 100%;
}
.com_present .com_present_block:nth-child(2),.com_present .com_present_block:nth-child(3){
	width: 48%;
}
.com_present .com_present_block .present_title{
	font-size: 20px;
	font-weight: 600;
	text-align: center;
	padding: 20px;
	line-height: 1;
	color: #fff;
	background: #FC7D59;
}
.com_present .com_present_block .present_box{
	background: #fff;
	padding: 30px;
}
.com_present .com_present_block .present_box .tit_text{
	font-size: 18px;
	font-weight: 600;
	padding-bottom: 30px;
	text-align: center;
}
.com_present .com_present_block .present_box .present_flex{
	display: flex;
	gap:20px;
}
.com_present .com_present_block .present_box .small_text{
	padding-top: 20px;
	font-size: 14px;
}
.small_text.present{
	max-width: 860px;
	margin: 20px auto 0;
	text-align: left;
    font-size: 0.8rem;
    line-height: 1.6;
}

/*==========================================
plan
==========================================*/
.contents.light_yel .wrapper{
	max-width: 100%;
}
/*.plan{
	max-width: 860px;
	margin: 0 auto;
}*/
.plan .sub_title{
    font-size: 22px;
	text-align: center;
	font-weight: 600;
	padding: 60px 0 30px;
}
.plan .sub_title span{
	position: relative;
}
.plan .sub_title span::after{
	position: absolute;
	content: "";
	background: url("../img/hukidashi_left.png");
    width: 35px;
    height: 30px;
    left: -40px;

}
.plan .sub_title span::before{
	position: absolute;
	content: "";
	background: url("../img/hukidashi_right.png");
    width: 35px;
    height: 30px;
    right: -40px;
}
.swiper-target02{
	position: relative;
}
.swiper-target02 .swiper-button-prev{
	left: -5px;
	display: none;
}
.swiper-target02 .swiper-button-next{
	right: -5px;
	display: none;
}
.swiper-target02 .swiper-controller{
	width: 860px;
	left: 0;
	right: 0;
	margin: auto;
}
.Swiper_item02{
	padding-bottom: 5px;
}
.Swiper_item02 .swiper-wrapper .swiper-slide{
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.25);
	border-radius: 10px;
	overflow: hidden;
}
.hotel_info_block{
	background: #fff;
	padding: 30px;
}
.hotel_info_block .info_title{
	color: #FC7D59;
	font-size: 18px;
	font-weight: 600;
	text-align: left;
	display: block;
	border-bottom: 1px solid #FC7D59;
	padding-bottom: 10px;
}
.hotel_info_block .info_text{
	font-size: 14px;
	text-align: left;
	padding: 10px 0 0;
}
/*==========================================
宿泊プラン　タブ切り替え
==========================================*/
.swiper-target03,
.swiper-target04,
.swiper-target05,
.swiper-target06,
.swiper-target07,
.swiper-target08,
.swiper-target09,
.swiper-target10{
	position: relative;
}
.swiper-target03 .swiper-controller,
.swiper-target04 .swiper-controller,
.swiper-target05 .swiper-controller,
.swiper-target06 .swiper-controller,
.swiper-target07 .swiper-controller,
.swiper-target08 .swiper-controller,
.swiper-target09 .swiper-controller,
.swiper-target10 .swiper-controller{
	top: 45%;
}
.swiper-target03 .swiper-button-prev,
.swiper-target04 .swiper-button-prev,
.swiper-target05 .swiper-button-prev,
.swiper-target06 .swiper-button-prev,
.swiper-target07 .swiper-button-prev,
.swiper-target08 .swiper-button-prev,
.swiper-target09 .swiper-button-prev,
.swiper-target10 .swiper-button-prev{
	left: 0;
}
.swiper-target03 .swiper-button-next,
.swiper-target04 .swiper-button-next,
.swiper-target05 .swiper-button-next,
.swiper-target06 .swiper-button-next,
.swiper-target07 .swiper-button-next,
.swiper-target08 .swiper-button-next,
.swiper-target09 .swiper-button-next,
.swiper-target10 .swiper-button-next{
	right: 0;
}
.swiper-target03 .swiper-button-prev,.swiper-target03 .swiper-button-next,
.swiper-target04 .swiper-button-prev,.swiper-target04 .swiper-button-next,
.swiper-target05 .swiper-button-prev,.swiper-target05 .swiper-button-next,
.swiper-target06 .swiper-button-prev,.swiper-target06 .swiper-button-next,
.swiper-target07 .swiper-button-prev,.swiper-target07 .swiper-button-next,
.swiper-target08 .swiper-button-prev,.swiper-target08 .swiper-button-next,
.swiper-target09 .swiper-button-prev,.swiper-target09 .swiper-button-next,
.swiper-target10 .swiper-button-prev,.swiper-target10 .swiper-button-next{
	border-radius: 0;
	width: 35px;
	height: 35px;
	opacity: 0.8;
}
.swiper-target03 .swiper-button-next::after,
.swiper-target03 .swiper-button-next::before,
.swiper-target03 .swiper-button-prev::after,
.swiper-target03 .swiper-button-prev::before,
.swiper-target04 .swiper-button-next::after,
.swiper-target04 .swiper-button-next::before,
.swiper-target04 .swiper-button-prev::after,
.swiper-target04 .swiper-button-prev::before,
.swiper-target05 .swiper-button-next::after,
.swiper-target05 .swiper-button-next::before,
.swiper-target05 .swiper-button-prev::after,
.swiper-target05 .swiper-button-prev::before,
.swiper-target06 .swiper-button-next::after,
.swiper-target06 .swiper-button-next::before,
.swiper-target06 .swiper-button-prev::after,
.swiper-target06 .swiper-button-prev::before,
.swiper-target07 .swiper-button-next::after,
.swiper-target07 .swiper-button-next::before,
.swiper-target07 .swiper-button-prev::after,
.swiper-target07 .swiper-button-prev::before,
.swiper-target08 .swiper-button-next::after,
.swiper-target08 .swiper-button-next::before,
.swiper-target08 .swiper-button-prev::after,
.swiper-target08 .swiper-button-prev::before,
.swiper-target09 .swiper-button-next::after,
.swiper-target09 .swiper-button-next::before,
.swiper-target09 .swiper-button-prev::after,
.swiper-target09 .swiper-button-prev::before,
.swiper-target10 .swiper-button-next::after,
.swiper-target10 .swiper-button-next::before,
.swiper-target10 .swiper-button-prev::after,
.swiper-target10 .swiper-button-prev::before{
	width: 14px;
    height: 2px;
}

.none {
  display: none;
}
.tab{
	max-width: 860px;
	margin: 0 auto;
}
.tab-buttons {
    display: flex;
	justify-content: space-between;
	gap:10px;
}

.tab-buttons button {
	padding: 15px 30px;
    background: #D8D8D8;
	color: #000;
    cursor: pointer;
    border-radius: 10px 10px 0 0;
    font-size: 18px;
    font-weight: 600;
    transition: all 0.3s;
    border: none;
    line-height: 1.2;
}

.tab-buttons button.is-active {
    color: #fff;
	background: #F27F5E;
}
.tab-contentst{
	background: #F27F5E;
	border-radius: 0 0 10px 10px;
	padding:30px 10px;

}

.content {
    display: none;
}

.content .cont_backbord{
    padding: 20px;
	background: #fff;
	border-radius: 10px;
	margin-bottom: 30px;
}

.content .cont_backbord:last-child{
	margin-bottom: 0;
}

.content .cont_flex{
    display: flex;
	justify-content: space-between;
	gap: 20px;
}

.content .cont_flex .cont_flex_slid_on{
    width: 370px;
}

.content .cont_flex .cont_flex_block{
    width:  calc(100% - 370px);
}

.content .cont_flex .cont_flex_block .tab_title{
	font-size: 18px;
	font-weight: 600;
	line-height: 1.2;
}

.content .cont_flex .cont_flex_block .tab_text_box{
	border-bottom: 1px solid #9E9E9E;
	padding-bottom: 20px;
}

.content .cont_flex .cont_flex_block .tab_text_box.end{
	border-bottom: none;
}

.tab_text_box .tab_text{
	font-size: 14px;
    font-weight: bold;
	line-height: 1;
    padding-top: 20px;
    display: flex;
    align-items: baseline;
}

.tab_text_box .tab_text .day_text{
	font-size: 18px;
}

.tab_text_box .tab_text .day_text .big{
	font-size: 24px;
}

.tab_text_box .tab_text .price_text{
	font-size: 14px;
}

.tab_text_box .tab_text .price_text .small{
	display: block;
    font-size: 11px;
    text-align: left;
    font-weight: 100;
	padding-top: 5px;
}

.tab_text_box .tab_text .price_text .red_price{
	font-size: 16px;
	color: red;
}

.tab_text_box .tab_text .price_text .red_price .big{
	font-size: 28px;
}

.content.is-display {
    display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.important_box{
	background: #eee;
	padding: 20px;
	border-radius: 10px;
}

.important_box .important_tit{
	font-size: 12px;
	display: flex;
    align-items: baseline;
	padding-bottom: 10px;
}

.important_box .important_tit i{
	padding-right: 5px;
}

.important_box .important_text{
	font-size: 12px;
	line-height: 1.6;
}

/*==========================================
宿泊プラン　モーダル
==========================================*/
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  padding: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s;
  pointer-events: none;
  opacity: 0;
  z-index: 100;
  background-color: rgba(120, 123, 131, 0.8);
}

.modal.is-active {
  opacity: 1;
  pointer-events: auto;
}

.modal__overlay {
  position: absolute;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.modal__content {
  position: relative;
  background-color: #fff;
  width: 100%;
  max-width: 900px;
  padding: 20px;
}

.modaal-container {
	background: none;
}
.modal_backbord{
	background: #fff;
	padding: 30px;
}
.ph_backbord h3{
	color: #fff;
	font-size: 20px;
	font-weight: bold;
	padding-top: 20px;
}
.modaal-content-container .title_box{
	display: flex;
	justify-content: space-between;
}
.modaal-content-container .title_box .inline_title{
	font-size: 18px;
	font-weight: 600;
}
.modaal-content-container .inline_tit{
	font-size: 16px;
	font-weight: 600;
	padding: 30px 0 10px;
}
.modaal-content-container .inline_text{
	font-size: 14px;
	padding-bottom: 20px;
	line-height: 1.6;
}
.modaal-content-container .inline_tit a,.modaal-content-container .inline_text a{
	text-decoration: underline;
	color: #0095FF;
}
.modaal-content-container .gray_block_info{
	background: #eee;
	border-radius: 5px;
	padding: 10px 20px;
	line-height: 1.8;
}
.modaal-content-container .gray_block_info .info_item_block{
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}
.modaal-content-container .gray_block_info .info_item_block .info-item{
	display: flex;
	gap: 10px;
	justify-content: space-between;
	align-items: center;
}
.modaal-content-container .gray_block_info .info_item_block .info-item i{
	line-height: 1;
}
.modaal-content-container .gray_block_info .gray_tit{
}
.modaal-content-container .title_box .inline_hotel{
	padding: 5px 10px;
	border: solid 1px #BCBCBC;
	display: flex;
	gap: 5px;
	align-items: center;
	font-size: 13px;
	border-radius: 3px;
}
.modaal-content-container .title_box .inline_hotel i{
	line-height: 1;
}

.modal__close-btn {
  position: absolute;
  right: 0;
  top: 0;
  width: 40px;
  height: 40px;
  background: #fff;
  border: 1px solid #ccc;
  cursor: pointer;
  z-index: 10;
}
.tab_more_botan a{
	padding: 10px;
	background: #000;
	color: #fff;
	font-weight: 600;
	display: block;
	max-width: 200px;
	margin: 20px auto 40px;
	text-align: center;
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.25);
}
.tab_more_botan a:hover{
	transition: all 0.5s;
	box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
}


/*==========================================
q&a
==========================================*/
.question_main{
	max-width: 860px;
	margin: 40px auto 0;
	position: relative;
}
.qa_box {
    margin: 0 0 30px 0;
    border-radius: 5px;
    overflow: hidden;
}
.qa_box .qa_head {
    padding: 20px 30px 20px 60px;
    color: #000;
    font-weight: bold;
    position: relative;
    background: #fff;
	cursor: pointer;
	z-index: 1;
}
.qa_box .qa_head::after,
.qa_box .qa_head::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
	margin: auto;
    left: calc(100% - 30px);
    width: 2px;
    height: 9px;
    border-radius: 9999px;
    background-color: #000000;
    transform-origin: 50% calc(100% - 1px);
}
.qa_box .qa_head::after {
	transform: rotate(-45deg);
}
.qa_box .qa_head::before {
	transform: rotate(45deg);
}
.qa_box .qa_inner {
    position: relative;
    padding: 20px 30px 20px 60px;
    background: #fff;
    display: none;
}
.qa_box .qa_inner .answer {
    font-size: 14px;
	background: #fff;
	position: relative;
}
.qa_box .qa_head .question{
    position: relative;
}
.qa_box .qa_head .question::after {
    position: absolute;
    content: "Q";
    color: #FC7D59;
    font-size: 20px;
    left: -30px;
    top: -5px;
}
.qa_box .qa_inner .answer::after {
    position: absolute;
    content: "A";
    color: #FC7D59;
    font-size: 20px;
    font-weight: bold;
    left: -30px;
    top: 0;
	line-height: 1;
}


/*==========================================
important
==========================================*/
.important{
	max-width: 860px;
	margin: 0 auto;
}
.important .important_block{
	background: #fff;
	padding: 30px;
  border-radius: 10px;
	margin-top: 40px;
}
.important .important_block .important_title{
	font-size: 20px;
	font-weight: bold;
	padding-bottom: 10px;
	border-bottom: 1px solid #000;
}
.important .important_block .infotext{
	padding-top: 20px;
}
.important .important_block .infotext strong{
	display: block;
	font-size: 16px;
}
.important .important_block .infotext span{
	font-size: 14px;
}


@media screen and (max-width: 1024px) {
	/*==========================================
	MV
	==========================================*/
	.navi ul li {
	    padding: 0 18px;
	}
	.navi ul li a {
	    font-size: 14px;
	}
}


@media screen and (max-width: 768px) {
	.contents .wrapper {
    padding: 60px 0;
}
	.title {
    max-width: 320px;
    margin: 0 auto;
	}
	/*==========================================
	MV
	==========================================*/
	.mv_main img{
		width: 100%;
	}
	.navi ul li {
	    padding: 0 12px;
	}
	.navi ul li a{
	    font-size: 1.6vw;
	}

	/*==========================================
	動画紹介
	==========================================*/
	.movie_block video {
    max-width: 480px;
}
.movie_block::before {
    left: 20px;
    top: 40px;
    height: 270px;
    width: 276px;
    background-size: contain;
    background-repeat: no-repeat;
}
.movie_block::after {
    right: 30px;
    bottom: -40px;
    height: 274px;
    width: 230px;
    background-size: contain;
    background-repeat: no-repeat;
}



.abt_us .miyazaki_map {
    right: 2%;
    top: -50px;
    height: 450px;
    width: 240px;
}
.abt_us .abt_us_img {
    top: -30px;
    height: 485px;
    max-width: 260px;
}
	
.contents.yel .wrapper::before {
    width: 240px;
    height: 250px;
    left: 1vw;
    top: 12vh;
}
	
.contents.yel .wrapper::after {
    width: 88px;
    height: 110px;
    top: 20vh;
    right: 11vw;
}
	
.contents.yel .wrapper .container::before {
    width: 220px;
    height: 220px;
    right: 3vw;
    bottom: 2vh;
}
.com_present .com_present_block .present_box .tit_text{
    font-size: 14px;
}
	
.voice_backbord::before {
    left: -3vw;
    top: -2vh;
    width: 240px;
    height: 250px;
}	
	
.voice_backbord::after {
    width: 220px;
    height: 209px;
    right: -4vw;
    bottom: -4vh;
}
	
.event_program {
    margin: 40px 2% 0;
    padding: 40px;
}

.voice {
    margin: 0 5%;
}

.cmp_details {
    margin: 40px 2% 0;
}

.cmp_details table tr td {
    padding: 20px;
}

.cmp_details table tr th {
    padding: 20px 40px;
}

.com_present {
    margin: 0 2%;
		justify-content: space-between;
}

.com_present .com_present_block:nth-child(2), .com_present .com_present_block:nth-child(3) {
    width: 47%;
}

.small_text.present {
    margin: 20px 2% 0;
}

.tab {
    margin: 0 2%;
}

.tab-buttons button {
    padding: 15px 25px;
    border-radius: 10px 10px 0 0;
    font-size: 16px;
}

.content .cont_flex .cont_flex_slid_on {
    width: 320px;
}

.content .cont_flex .cont_flex_block {
    width: calc(100% - 320px);
}

.content .cont_flex .cont_flex_block .tab_title {
    font-size: 16px;
}

.tab_text_box .tab_text {
    font-size: 13px;
}

.tab_text_box .tab_text .price_text {
    font-size: 13px;
}

.tab_text_box .tab_text .price_text .red_price {
    font-size: 14px;
}

.tab_text_box .tab_text .price_text .red_price .big {
    font-size: 20px;
}

.ph_backbord .ph_img{
	width: 100%;
}

.question_main {
    margin: 40px 2% 0;
}

.important {
    margin: 0 2%;
}
}


@media screen and (max-width: 550px) {
	.this_SPnone{
		display: none;
	}
	.this_SPon{
		display: block;
	}    
	.title {
        max-width: 300px;
    }
	.text{
		text-align: left;
	}
	.slider_hid{
		overflow: hidden;
	}
	.entry_botan {
		margin: 30px auto 0;
		padding: 15px 0;
	}
	.entry_botan::before {    
		height: 50px;
	}
    .ank_link_btn{
        width: 30vw;
        height: 16vh;
        top: auto;
        bottom: 0;
        right: 0.3rem;
    }
	.contents .wrapper {
		padding: 40px 0;
	}
	.wrapper .container{
		margin: 0 5%;
	}
	
	.navi ul {
	    flex-wrap: wrap;
		gap: 5px; 
		margin: 20px auto;
	}
	.navi ul li {
		height: 36px;
        padding: 0;
        border-right: none;
        width: 30%;
	}    
	.navi ul li:first-child {
		border-left: none;
	} 
	.navi ul li a {
        font-size: 2.4vw;
        border: 1px solid #BCBCBC;
        padding: 5px 15px;
        border-radius: 5px;
        height: 100%;
        width: 100%;
        text-align: center;
        margin: 0 auto;
        display: flex;
        align-items: center;
        justify-content: center;        
		box-shadow: 0 2px 3px rgba(0, 0, 0, 0.25);
    } 
	.navi ul li a:hover {      
		box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
		border: 1px solid #ff981f;
    }
	.qa_box .qa_head{
		z-index: 0;
	}
	.movie_block video {
        max-width: 320px;
    }
	
	.movie_block::before {
        display: none;
    }
	.movie_block::after {
        display: none;
    }
	.abt_us .abt_us_img {
        display: none;
    }
    .abt_us .miyazaki_map {
        position: static;
        height: auto;
        width: 100%;
        max-width: 260px;
        margin: 20px auto 0;
    }
	.abt_us .miyazaki_map::before {
	   display: none;
	}
	.event_backbord{
		z-index: 0;
	}
	.event_program .t_img_block{
		display: none;
	}
	
	.event_program .timeline {
		max-width: 100%;
	}
	
	.event_program {
        margin: 30px 0 0;
        padding: 30px 5% 0;
    }
	
	.event_program .timeline ul li .time {
		width: 23%;
		font-size: 14px;
		padding-right: 0;
	}
	
	.event_program .timeline ul li .time::before {
		width: 16px;
		height: 16px;
		right: -9px;
	}
	.event_program .timeline ul li .time_text {
		width: 77%;
		padding-left: 15px;
	}
	.event_program .timeline ul li .time_text .title{
		font-size: 16px;
	}
	.contents.yel .wrapper::before {
		width: 200px;
		height: 200px;
		left: 2vw;
		top: 5vh;
	}
	.contents.yel .wrapper::after {
		display: none;
	}
    .cmp_details .sub_title{
        font-size: 16px;
        padding-bottom: 10px;
    }
	.swiper-target01 .swiper,.swiper-target02 .swiper{
		overflow: visible;
		z-index: 0;
		padding-bottom: 0;
	}
	.swiper-target03 .swiper,.swiper-target04 .swiper,.swiper-target05 .swiper,.swiper-target06 .swiper,.swiper-target07 .swiper,.swiper-target08 .swiper,.swiper-target09 .swiper,.swiper-target10 .swiper{
		z-index: 0;
	}
	.cmp_details {
        margin: 10px 0 20px;
    }
	.cmp_details table tr td {
		padding: 15px 10px;
		width: 110px;
	}
	.cmp_details table tr th {
        padding: 15px 0 15px 20px;
    }
	.present_backbord{
		z-index: 0;
	}
	.com_present{
		gap:15px;
		margin: 0;
		padding-top: 10px;
	}
	.com_present .com_present_block .present_box .present_flex {
		flex-wrap: wrap;
	}
	.com_present .com_present_block:nth-child(2), .com_present .com_present_block:nth-child(3) {
        width: 100%;
    }
	.com_present .com_present_block .present_title{
		font-size: 18px;
        padding: 15px;
	}
	.small_text.present{
		margin: 15px 0 0;
	}
	.plan .sub_title {
		font-size: 18px;
		padding: 30px 0 15px;
	}
    .plan .sub_title span::after{
        left: -1.8rem;
        width: 1.8rem;
        height: 1.5rem;
        background-size: contain;
        background-repeat: no-repeat;
        bottom: 0.2rem;
    }
    .plan .sub_title span::before{
        right: -1.8rem;
        width: 1.8rem;
        height: 1.5rem;
        background-size: contain;
        background-repeat: no-repeat;
        bottom: 0.2rem;
    }
	.hotel_info_block{
		padding: 30px 5%;
	}
	.content .cont_flex{
		display: block;
	}
	.voice_backbord::before,.voice_backbord::after{
		display: none;
	}
    .content .cont_flex .cont_flex_block {
        width: 100%;
		padding: 15px 0;
    }
    .content .cont_flex .cont_flex_block .tab_title {
        font-size: 14px;
    }
	.tab{
		margin: 0;
	}
	.tab-contentst{
		padding: 15px 10px;
	}
	.tab_text_box .tab_text {    
		font-size: 2.17vw;
		padding-top: 15px;
    }
	.tab_text_box .tab_text .tab_tt_text{
		width: 80px;
    }
	.tab_text_box .tab_text .day_text {
		font-size: 14px;
		width: calc(100% - 80px);
	}
	.tab_text_box .tab_text .day_text .big {
		font-size: 20px;
	}
	.tab_text_box .tab_text .price_text {
		font-size: 2.17vw;
		width: calc(100% - 80px);
    }
	.tab_text_box .tab_text .price_text .red_price {
		font-size: 2.17vw;
    }
	.tab_text_box .tab_text .price_text .small {    
		font-size: 2.17vw;
	}
	.hotel_info_block .info_title{
		font-size: 16px;
		padding-bottom: 10px;
	}
	.tab-buttons {
		gap: 4px;
	}
	.tab-buttons button {
        padding: 15px 5px;
        border-radius: 10px 10px 0 0;
        font-size: 3.5vw;
		width: calc(58% - 60px);
    }
	.tab-buttons button:first-child {
		width: 60px;
    }
	
	.tab_more_botan a{
		margin: 0 auto 5px;
	}
	.qa_box {
        margin: 0 0 10px 0;
    }
	.question_main{
		margin: 10px 2% 0;
	}
	.qa_box .qa_head .question::after {
		font-size: 18px;
		left: -30px;
	}
	
	.qa_box .qa_head {
		padding: 20px 40px 20px 50px;
	}
	
	.important .important_block .important_title {
		font-size: 18px;
		padding-bottom: 5px;
	}
	
	.event_program .timeline ul li:nth-child(2) .time_text,.event_program .timeline ul li:nth-child(5) .time_text ,.event_program .timeline ul li:nth-child(6) .time_text {
        padding-bottom: 40px;
    }
	.content .cont_backbord{
		padding: 15px 10px;
		margin-bottom: 15px;
	}
	.content .cont_flex .cont_flex_slid_on {
        width: 100%;
    }
	.contents.yel .wrapper .container::before {
		width: 160px;
        height: 160px;
        right: 0;
        bottom: 0;
	}
	.important .important_block{
		padding: 15px;
		margin-top: 10px;
	}


}
@media screen and (max-width: 320px) {
    .ank_link_btn{
        bottom: -12%;
    }	
}
