@charset "utf-8";

/*PCSP共通設定*/
html {scroll-behavior: smooth;}
main {
    background:url(../images/allbg.png);
    color: #333
}
main * {font-family: "Noto Sans JP", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;}
article > section {padding-bottom: 5%}
section img {
	width: 100%;
	height: auto;
}
#anchorLinkBlock {padding: 10px 0;}
.disnone {display:none;}
main .select:hover,
main .select a:hover {
    opacity: 1!important;
    filter: alpha(opacity=100)!important;
    -ms-filter: "alpha(opacity=100)"!important;
    -moz-opacity: 1!important;
    cursor:auto !important
}

/* link underline */
main a.underline {
	color: #333333;
	text-decoration: underline;
}

/* accordion */
.accordion__title {
	position: relative;
	display: block;
	width: 100%;
    color: #e30035;
    border: 1px solid #e30035;
	box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.25);
	text-align: left;
	padding: 15px 0 16px 20px;
	background: #FFF;
}
.accordion__title::after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: block;
	width: 39px;
	height: 27px;
	right: 20px;
	background: url('../images/icon_under2.svg') no-repeat center / contain;
	transition: transform .3s ease-in-out;
}
.accordion__content {
	position: relative;
	max-height: 0;
	overflow: hidden;
	transition: max-height .3s ease-in-out;
	background: #fff;
}
.accordion__item.is-open .accordion__content {
	transition: max-height .3s ease-in-out;
	max-height: var(--max-height);
	margin-bottom: 62px;
}
.accordion__item.is-open .accordion__title::after {
	transform: translateY(-50%) rotate(180deg);
}

/* scrollbox */
.sliderBox a {color: #414540;}
section .scrollbox > ul > li {
	background-color: #FFF;
	border: 1px solid #e2c142;
}

/*759px以下*/
@media screen and (max-width: 759.9px) {
#wrapper {line-height: 1.4;}
.spnone {display: none;}
main article {
    background: url(../images/bg_side.png) repeat-y -1% -105px, url(../images/bg_side2.png) repeat-y 105% -55px;
    background-size: 25%;
}

/* CSS */
#dirPathBlock {
	overflow-x: scroll;
	overflow-y: hidden;
}
#dirPathBlock,
#anchorLinkBlock {margin: 0 1%;}
#dirPathBlock p,
#anchorLinkBlock a {font-size: 12px;}
#dirPathBlock p {width: max-content;}
h1 {
	font-size: 12px;
	margin: 0 1% 1%;
}
p.special_events__title{
	background: #222;
	    display: block;
	    text-align: center;
	    margin: 0 0 3%;
	    padding: 5px;
	    font-size: 18px;
	    color: #FFF;
	    font-weight: 700;
}
h2 {
	color: #e30035;
	margin-bottom: 25px;
	font-size: 22px;
	font-weight: 700;
	text-align: center;
}
h2 small{
    font-size: 0.75em;
    color: #222;
}
h3,
h4 {
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    margin: 0 auto 3%
}
.inner {
	width: 94%;
	margin: 0 3%;
	padding: 24px 0;
	box-sizing: border-box;
}

/*title*/
.mv figure {
	margin: 0;
	padding: 0;
}
figure#mainphoto img {width: 100%;}
.mv .select_wrap {
    margin: 12px auto;
    text-align: center;
    font-size: 16px;
    display: flex
}
.mv .select_wrap {
    font-size: 18px
}
.mv .select_wrap li {
    width: 48%;
    height: 40px;
    margin: 0 10px;
}
.mv .select_wrap li a {
    width: 100%;
    height: 100%;
    display: block;
    align-content: center;
    background: #FFF;
    color: #000;
    font-weight: bold;
    border-radius: 5px;
    border: 1px solid #BEA223;
    letter-spacing: 5px;
    text-indent: 10px;
    box-sizing: border-box
}
.mv .select_wrap li a.select {
    color: #FFF;
    background: #BEA223
}
#tabiwa p {
    font-size: 13px;
    text-align: right;
    margin-bottom: 5%;
}
#tabiwa p a {
    margin: 0 5px;
    padding: 5px 15px;
    background: #e30035;
    color: #FFF !important;
    border-radius: 10px;
    display: inline-block;
}

/*nav*/
main article nav.fixed {
	position: fixed!important;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 9999;
	margin: 0;
	text-align: center;
	background: #FFF;
}
main article nav ul{width: 100%;}
main article #follow-up_nav ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
main article #follow-up_nav li {
    width: calc(97% / 3);
    background: #bea223;
    text-align: center;
    margin: 0.5%;
    border-radius: 5px;
}
main article #follow-up_nav li a {
    width: 100%;
    height: 48px;
    align-content: center;
    display: block;
    color: #fff;
    position: relative;
}
main article #follow-up_nav li a:hover{
	opacity:0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha( opacity=80 )";
	text-decoration:none!important;
}

/* btn */
.btn_wrap {
	display: grid;
	gap: 5px;
    margin-bottom: 15px;
}
.btn a {
    position: relative;
    display: block;
    color: #FFF;
    box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.5);
    font-size: 16px;
    text-align: center;
    padding: 15px 0 18px;
    background: #e30035;
    border-radius: 5px
}
#follow-up_nav a::after,
.btn a::after {
	content: "";
	position: absolute;
	top: 28%;
	transform: rotate(-90deg);
	display: block;
	width: 39px;
	height: 27px;
	right: 0;
	background: url('../images/icon_under.svg') no-repeat center / contain;
}
#follow-up_nav a::after,
.btn a.uncer::after {transform: rotate(0deg);}
#follow-up_nav a::after{
    position: absolute;
    top: 35%;
    right: -5px;
    width: 26px;
    height: 18px;
}

/* scrollbox */
.scrollbox_wraper {
	margin-bottom: 25px;
	position: relative;
}
.scrollbox_wraper .scroll_left_btn,
.scrollbox_wraper .scroll_right_btn {
	width: 32px;
	height: 32px;
	position: absolute;
	top: calc(50% - 32px);
	display: block;
	z-index: 1;
	background: #FFF;
	border-radius: 50%;
	box-shadow: 0px 0px 6px #888;
}
.scrollbox_wraper .scroll_left_btn {
	left: 0;
}
.scrollbox_wraper .scroll_right_btn {
	right: 0;
}
.scrollbox_wraper .scroll_left_btn:after,
.scrollbox_wraper .scroll_right_btn:after,
.scrollbox_wraper .scroll_left_btn:before,
.scrollbox_wraper .scroll_right_btn:before {
	content: "";
	display: block;
	width: 0;
	height: 0;
}
.scrollbox_wraper .scroll_left_btn:after {
	position: absolute;
	top: 16px;
	left: 11px;
	border-left: 2px solid;
	border-top: 10px solid;
	transform: rotate(-45deg);
	-webkit-transform-origin-y: top;
	transform-origin: top;
}
.scrollbox_wraper .scroll_right_btn:after {
	position: absolute;
	top: 16px;
	right: 11px;
	border-left: 2px solid;
	border-top: 10px solid;
	transform: rotate(45deg);
	-webkit-transform-origin-y: top;
	transform-origin: top;
}
.scrollbox_wraper .scroll_left_btn:before {
	position: absolute;
	top: 7px;
	left: 11px;
	border-left: 2px solid;
	border-top: 10px solid;
	transform: rotate(45deg);
	-webkit-transform-origin-y: bottom;
	transform-origin: bottom;
}
.scrollbox_wraper .scroll_right_btn:before {
	position: absolute;
	top: 7px;
	right: 11px;
	border-left: 2px solid;
	border-top: 10px solid;
	transform: rotate(-45deg);
	-webkit-transform-origin-y: bottom;
	transform-origin: bottom;
}
.scrollbox_wraper .scroll_left_btn.non_scloll,
.scrollbox_wraper .scroll_right_btn.non_scloll {
	transition: 0.1s;
	display: none !important;
}
.scrollbox_wraper .scrollbox {
	overflow-x: scroll !important;
}
.scrollbox_wraper .scrollbox > ul {
	width: fit-content !important;
	display: flex !important;
	margin: 0 auto 15px !important;
	padding: 0 calc(calc(100% - calc(1040px / 4)) / 2);
}
.scrollbox_wraper .scrollbox > ul > li.sliderBox {
	width: calc(1038px / 4) !important;
	margin: 0 5px !important;
	padding: 15px;
	box-sizing: border-box;
}
.scrollbox_wraper .scrollbox > ul > li h3 {
	display: grid;
	flex-direction: column;
	text-align: center;
	line-height: 1.2;
	padding: 10px 0;
	align-items: center;
	font-weight: bold;
	font-size: 18px;
}
.scrollbox_wraper .scrollbox > ul > li .txt {
	font-size: 14px;
}
.scrollbox_wraper .scrollbox::-webkit-scrollbar {
	height: 5px !important;
}
.scrollbox_wraper .scrollbox::-webkit-scrollbar-track {
	margin: 0 5px !important;
	background: #eee !important;
	border-radius: 5px !important;
}
.scrollbox_wraper .scrollbox::-webkit-scrollbar-thumb {
	border-radius: 5px !important;
	background: #999 !important;
}

/*予告*/
#coming_soon li {
    width: 99%;
    background: #FFF;
    margin: 0 0.5% 15%;
    padding: 12% 1% 5% 1%;
    font-size: 16px;
    text-align: center;
    line-height: 1.5;
    border-radius: 10px;
    box-shadow: 1px 1px 5px #999;
    box-sizing: border-box;
    position: relative;
}
#coming_soon li > div {
    position: absolute;
    top: -12%;
    right: calc((100% - 110px) / 2);
    color: #FFF;
    background: #e30035;
    width: 110px;
    padding: 0 2% 1%;
    font-size: 1.2em;
    letter-spacing: 5px;
    font-weight: bold;
    box-shadow: 3px 3px 0 #e2c142;
    box-sizing: border-box;
}
#coming_soon li > div strong{font-size: 1.4em;}
#coming_soon li dt {
    font-size: 1.2em;
    margin-bottom: 3%;
    font-weight: bold;
}
#coming_soon li dd p {
    font-weight: bold;
    font-size: 1.2em;
    color: #e30035;
}

}

/*760px以上*/
@media screen and (min-width: 760px), print {
#wrapper {line-height: 1.231;}
.pcnone {display: none;}
main article {background:url(../images/bg_side.png) repeat-y -100px -105px,url(../images/bg_side2.png) repeat-y 109% -55px;}

/* CSS */
#dirPathBlock,
.iframe_end-content_gadget,
#anchorLinkBlock {
	width: 100%;
	max-width: 1080px;
	min-width: 760px;
	margin: auto;
}
#dirPathBlock,
#anchorLinkBlock {
	width: 100%;
	margin: 0 auto;
	display: block;
	font-size: 12px;
}
#dirPathBlock p,
#anchorLinkBlock a {
	font-size: 12px;
}
h1 {
	font-size: 12px;
	width: 100%;
	max-width: 1080px;
	min-width: 760px;
	margin: 0 auto 5px;
}
p.special_events__title{
	background: #222;
	    display: block;
	    text-align: center;
	    margin: 0 0 3%;
	    padding: 15px;
	    font-size: 28px;
	    color: #FFF;
	    font-weight: 700;
}
h2 {
	color: #e30035;
	margin-bottom: 27px;
	font-size: 35px;
	font-weight: 700;
	text-align: center;
}
h2 small{
    font-size: 0.75em;
    color: #222;
}
h3,
h4 {
    width: fit-content;
    text-align: center;
    font-size: 30px;
    font-weight: 700;
    margin: 0 auto 3%
}
.inner {
	width: 100%;
	max-width: 1080px;
	min-width: 760px;
	margin: 0 auto;
	/*padding: 50px 0;*/
	display: block;
}

/*title*/
.mv {width: 100%;}
	figure#mainphoto {
	margin: 0;
	padding: 0;
}
figure#mainphoto img {
	width: 100%;
}
.mv .select_wrap {
    width: 440px;
    margin: 25px auto;
    text-align: center;
    font-size: 20px;
    display: flex
}
.mv .select_wrap li {
    width: 220px;
    height: 50px;
    margin: 0 10px
}
.mv .select_wrap li a {
    width: 100%;
    height: 100%;
    display: block;
    align-content: center;
    background: #FFF;
    color: #000;
    font-weight: bold;
    border-radius: 5px;
    border: 2px solid #BEA223;
    letter-spacing: 15px;
    text-indent: 10px;
    box-sizing: border-box
}
.mv .select_wrap li a.select {
    color: #FFF;
    background: #BEA223
}
#tabiwa {
    width: 100%;
    max-width: 1080px;
    min-width: 760px;
    margin: auto;
}
#tabiwa p {
    font-size: 18px;
    text-align: right;
    margin-bottom: 5%;
}
#tabiwa p a {
    margin: 0 5px;
    padding: 5px 15px;
    background: #e30035;
    color: #FFF !important;
    border-radius: 10px;
    display: inline-block;
}

/*nav*/
main #follow-up_nav {height:72px;}
main article nav.fixed {
	position: fixed!important;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 9999;
	margin: 0;
	text-align: center;
	background: #FFF;
}
main article nav ul{
    width: 100%;
    max-width: 1080px;
    min-width: 760px;
    margin: auto;
    height: 72px
}
main article #follow-up_nav ul {
    display:flex;
    gap: 5px;
}
main article #follow-up_nav li {
    width: 20%;
    background: #bea223;
    text-align: center;
    margin: 1% 0;
    border-radius: 5px;
}
main article #follow-up_nav li a {
    width: 100%;
    display: block;
    line-height: 1.2;
    font-size: 15px;
    color: #fff;
    padding: 15px 0;
    position: relative
}
main article #follow-up_nav li a:hover{
	opacity:0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha( opacity=80 )";
	text-decoration:none!important;
}

/* btn */
.btn_wrap {
    display: flex;
    gap: 5px;
    margin-bottom: 25px;
}
.btn_wrap li {width: 80%;}
.btn {
    width:80%;
    margin: auto
}
.btn a {
    position: relative;
    display: block;
    color: #FFF;
    box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.5);
    font-size: 18px;
    text-align: center;
    padding: 15px 0 18px;
    background: #e30035;
    border-radius: 5px
}
#follow-up_nav a::after,
.btn a::after {
	content: "";
	position: absolute;
	top: 28%;
	right: 0;
	transform: rotate(-90deg);
	display: block;
	width: 39px;
	height: 27px;
	background: url('../images/icon_under.svg') no-repeat center / contain;
}
.recommended_area .btn a::after {
	position: absolute;
    top: 32%;
    right: -5%;
}
#follow-up_nav a::after,
.btn a.uncer::after {
    right: 0;
    transform: rotate(0deg);
}

/* scrollbox */
.scrollbox_wraper {
	margin-bottom: 50px;
	position: relative;
}
.scrollbox_wraper .scroll_left_btn,
.scrollbox_wraper .scroll_right_btn {
	width: 32px;
	height: 32px;
	position: absolute;
	top: calc(50% - 32px);
	display: block;
	z-index: 1;
	background: #FFF;
	border-radius: 50%;
	box-shadow: 0px 0px 6px #888;
}
.scrollbox_wraper .scroll_left_btn {left: -40px;}
.scrollbox_wraper .scroll_right_btn {right: -40px;}
.scrollbox_wraper .scroll_left_btn:after,
.scrollbox_wraper .scroll_right_btn:after,
.scrollbox_wraper .scroll_left_btn:before,
.scrollbox_wraper .scroll_right_btn:before {
	content: "";
	display: block;
	width: 0;
	height: 0;
}
.scrollbox_wraper .scroll_left_btn:after {
	position: absolute;
	top: 16px;
	left: 11px;
	border-left: 2px solid;
	border-top: 10px solid;
	transform: rotate(-45deg);
	-webkit-transform-origin-y: top;
	transform-origin: top;
}
.scrollbox_wraper .scroll_right_btn:after {
	position: absolute;
	top: 16px;
	right: 11px;
	border-left: 2px solid;
	border-top: 10px solid;
	transform: rotate(45deg);
	-webkit-transform-origin-y: top;
	transform-origin: top;
}
.scrollbox_wraper .scroll_left_btn:before {
	position: absolute;
	top: 7px;
	left: 11px;
	border-left: 2px solid;
	border-top: 10px solid;
	transform: rotate(45deg);
	-webkit-transform-origin-y: bottom;
	transform-origin: bottom;
}
.scrollbox_wraper .scroll_right_btn:before {
	position: absolute;
	top: 7px;
	right: 11px;
	border-left: 2px solid;
	border-top: 10px solid;
	transform: rotate(-45deg);
	-webkit-transform-origin-y: bottom;
	transform-origin: bottom;
}
.scrollbox_wraper .scroll_left_btn.non_scloll,
.scrollbox_wraper .scroll_right_btn.non_scloll {
	transition: 0.1s;
	display: none !important;
}
.scrollbox_wraper .scrollbox {
	overflow-x: scroll !important;
}
.scrollbox_wraper .scrollbox > ul {
	width: fit-content !important;
	display: flex !important;
	margin: 0 auto 15px !important;
}
.scrollbox_wraper .scrollbox > ul > li.sliderBox {
	width: calc(1040px / 4) !important; /* 930px */
	margin: 0 5px !important;
	padding: 15px;
	box-sizing: border-box;
}
.scrollbox_wraper .scrollbox > ul > li h3 {
	display: grid;
	flex-direction: column;
	text-align: center;
	line-height: 1.2;
	padding: 10px 0;
	align-items: center;
	font-weight: bold;
	font-size: 18px;
}
.scrollbox_wraper .scrollbox > ul > li .txt {
	font-size: 14px;
}
.scrollbox_wraper .scrollbox::-webkit-scrollbar {
	height: 5px !important;
}
.scrollbox_wraper .scrollbox::-webkit-scrollbar-track {
	margin: 0 5px !important;
	background: #eee !important;
	border-radius: 5px !important;
}
.scrollbox_wraper .scrollbox::-webkit-scrollbar-thumb {
	border-radius: 5px !important;
	background: #999 !important;
}

/*スクロールなし*/
.scrollbox_wraper.pc_no_slider {
	margin-bottom: 15px;
	position: relative;
}
.scrollbox_wraper.pc_no_slider .scroll_left_btn,
.scrollbox_wraper.pc_no_slider .scroll_right_btn,
.scrollbox_wraper.pc_no_slider .scrollbox::-webkit-scrollbar,
.scrollbox_wraper.pc_no_slider .scrollbox::-webkit-scrollbar-track,
.scrollbox_wraper.pc_no_slider .scrollbox::-webkit-scrollbar-thumb {
	display: none !important;
}
.scrollbox_wraper.pc_no_slider .scrollbox > ul {
    width: 100%!important;
	flex-wrap: wrap;
}
.scrollbox_wraper.pc_no_slider .scrollbox > ul li {
	margin-bottom: 10px !important;
    border: 1px solid #e2c142;
}

/*予告*/
#coming_soon {display: flex;}
#coming_soon li {
    width: 99%;
    background: #FFF;
    margin: 1% 0.5%;
    padding: 3% 1%;
    font-size: 18px;
    text-align: center;
    line-height: 1.5;
    border-radius: 10px;
    box-shadow: 1px 1px 5px #999;
    box-sizing: border-box;
    position: relative;
}
#coming_soon li > div {
    position: absolute;
    top: -14%;
    right: calc((100% - 120px) / 2);
    color: #FFF;
    background: #e30035;
    width: 120px;
    padding: 0 2% 1%;
    font-size: 1.2em;
    letter-spacing: 5px;
    font-weight: bold;
    box-shadow: 3px 3px 0 #e2c142;
    box-sizing: border-box;
}
#coming_soon li > div strong{font-size: 1.4em;}
#coming_soon li dt {
    font-size: 1.1em;
    margin-bottom: 3%;
    font-weight: bold;
}
#coming_soon li dd p {
    font-weight: bold;
    font-size: 1.2em;
    color: #e30035;
}

}