@charset "utf-8";

html{scroll-behavior: smooth;}
#rt_special_popup .rtTmplHeadingTextImgBtnVertical_heading{margin-top: 15px !important;}
.tokyo, .osaka {
    display: none;
}

article > section:nth-of-type(odd){background: url(../images/washi_bg.jpg) repeat;}
article > section:nth-of-type(even){background: #FFF;}
/*#dep_contents:nth-of-type(odd) > div > section:nth-of-type(odd) {background: url(../images/washi_bg.jpg) repeat;}
#dep_contents:nth-of-type(odd) > div > section:nth-of-type(even) {background: #FFF;}
#dep_contents:nth-of-type(even) > div > section:nth-of-type(odd) {background: #FFF;}
#dep_contents:nth-of-type(even) > div > section:nth-of-type(even) {background: url(../images/washi_bg.jpg) repeat;}*/
article > section.bk_washi {background: url(../images/washi_bg_gradation.jpg) repeat 50%;}

/*PCSP共通設定*/
.IDnewyear{
/*font-family: 'Noto Sans JP', sans-serif;*/
font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
font-size: 14px;
line-height: 1.5;
}
.IDnewyear strong{font-weight: bold;}
.IDfaq a{
text-decoration: underline;
transition: 0.2s;
}
.IDfaq a:hover{
color: #e1806e;
transition: 0.2s;
}
.IDnewyear a{
color:#000;
transition: 0.2s ;
}
.ItemSection .ItemBox .ItemBoxContent .ItemBoxContentInner .ItemBoxItemWrap .ItemBoxItem .ItemSetWrap a .ItemSet .ItemCard .ItemCardText .ItemCardSubText {
    font-size: 0.75rem;
}
.divlink:hover{
cursor: pointer;
transform: translate(2px,2px);
transition: 0.2s ;
}
/*#tripaBOX {
display: block;
background: url(../images/washi_bg_gradation.jpg) repeat;
}*/	
p.kaigai_info_txt {
    text-align: center;
    background: #f5eee5;
    padding: 10px;
    border-radius: 5px;
    font-weight: bold;
}

/* ------------------------------------------
	calendar
------------------------------------------ */
.calendar h3 {
    padding: 0 45px;
    font-size: 1.42em;
    font-weight: bold;
    line-height: 1.2;
    letter-spacing: 0.1em;
}
.calendar h3 span {
    font-size: 2.5em;
    color: #e1806e;
}
.calendar ul {
    width: 860px;
    margin: 15px auto 0;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    /*justify-content: space-between;*/
}
.calendar ul li {
    font-size: 2.57em;
    box-sizing: border-box;
    width: 95px;
    margin-right: 20px;
}
.calendar ul li a {
    position: relative;
    display: block;
    width: 100%;
    padding: 10px 0 5px;
    background: #fff;
    border: 1px solid #e1806e;
    border-radius: 10px;
    color: #000;
    line-height: 1.5;
}
.calendar ul li a:hover {
    background: #e1806e;
    opacity: 100;
    color: #fff;
}
.calendar ul li a span.month {
    display: inline-block;
    position: absolute;
    font-size: 0.5em;
    width: 1em;
    top: 10px;
    left: 8px;
    transition: transform .3s;
}
.calendar ul li a span.month::after {
    position: absolute;
    display: block;
    content: "";
    width: 30px;
    height: 0;
    border-bottom: 1px solid #000;
    transform: rotate(-50deg);
    transform-origin: 0% 0%;
    left: 3px;
    bottom: -3px;
    transition: transform .3s;
}
.calendar ul li a:hover span.month::after {
    border-color: #fff;
    transition: transform .3s;
}
.calendar ul li a span.day {
    display: inline-block;
    padding-left: 27px;
}
.calendar ul li a span.weekday,
.calendar ul li a span.holiday {
    display: inline-block;
    font-size: .38em;
    width: 1.6em;
    height: 1.6em;
    margin-left: 4px;
    background-color: #e1806e;
    border-radius: 50%;
    text-align: center;
    line-height: 1.6em;
    color: #fff;
    transition: transform .3s;
}
.calendar ul li a span.holiday { background-color: #f07272;}
.calendar ul li a:hover span.weekday,
.calendar ul li a:hover span.holiday { 
    background-color: #fff;
    color: #e1806e;
    transition: transform .3s;
}
.calendar ul li a:hover span.month::after { border-color: #fff;}

/* ------------------------------------------
	more button
------------------------------------------ */
/*.more_box {
    position: relative;
}
.more_box label {
    height: 80px;  グラデーションの高さ 
    cursor: pointer;
    text-align: center;
    font-size: 12px;
    position: absolute;
    bottom: 0;
    width: 100%;

     以下グラデーションは「背景が白」に併せて設定しています  
    background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.95) 90%);
    background: -moz-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.95) 90%);
    background: -o-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.95) 90%);
    background: -ms-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.95) 90%);
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.95) 90%);
}
.more_box input:checked + label {
    background: inherit;  開いた時には背景グラデーションを消す 
}
.more_box label:after {
    content: "もっと見る";  ラベルの文字 
    letter-spacing: .05em;
    line-height: 2.5rem;
    position: absolute;
    bottom: 20px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    color: #fff;
    background-color: #e1806e;
    width: 18.75rem;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    border-radius: 20px;
}
.more_box label:before {
    content: "↓";
    font-weight: bold;
    position: absolute;
    bottom: 30px;
    left: 50%;
    -webkit-transform: translate(-140px, 0);
    transform: translate(-140px, 0);
    background-color: #fff;
    z-index: 1;
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
    width: 20px;
    height: 20px;
    line-height: 20px;
    color: #e1806e;
}*/
.more_box input {
    display: none;
}
/*.more_box .more_area {
    overflow: hidden;
    height: 180px;  開く前に見えている部分の高さ 
    -webkit-transition: all 0.1s;
    -moz-transition: all 0.1s;
    -ms-transition: all 0.1s;
    -o-transition: all 0.1s;
    transition: all 0.1s;
}
.more_box .more_area.kansai {
    height: 230px;  開く前に見えている部分の高さ 
}
.more_box .more_area.chugoku {
    height: 125px;  開く前に見えている部分の高さ 
}
.more_box input:checked + label {
     display: none ; 閉じるボタンは要らないとき 
}
.more_box input:checked + label:after {
    content: "閉じる";
}
.more_box input:checked + label:before {
    content: "↑";
}
.more_box input:checked ~ .more_area {
    height: auto;
    padding-bottom: 80px;  閉じるボタンのbottomからの位置 
    -webkit-transition: all 0.1s;
    -moz-transition: all 0.1s;
    -ms-transition: all 0.1s;
    -o-transition: all 0.1s;
    transition: all 0.1s;
}*/

.scrollbox > ul,
.scrollbox .ItemBoxItem {
	width: fit-content !important;
    display: flex !important;
    margin: 0 auto 15px !important;
}
.scrollbox > ul > li {
    width: calc(1040px / 4);
    margin: 0 5px 15px !important;
}

/* ============================================================
add 20240604
============================================================ */

/* div.under_menu
-------------------------------------------------------------*/
.under_menu {
    margin-top: -30px;
}
.under_menu ul {
    display: flex;
    justify-content: space-between;
    margin: 30px 0 80px;
}
.under_menu ul li {
    width: calc(100% / 7);
    border-right: 1px dashed #333;
    text-align: center;
}
.under_menu ul li:last-child {
    border-right: none;
}
.under_menu.nk_menu ul {
    width: 65%;
    margin-left: auto;
    margin-right: auto;
}
.under_menu.nk_menu ul li {
    width: calc(100% / 3);
}

/*article > section:nth-of-type(odd){background-color:#fff!important;}
article > section:nth-of-type(even){background: url(../images/washi_bg.jpg) repeat!important;}
#dep_contents div > section:nth-of-type(odd){background-color:#fff!important;}
#dep_contents div > section:nth-of-type(even){background: url(../images/washi_bg.jpg) repeat!important;}*/

/* ul.area */
main ul.area {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
main ul.area.verCenter {
    justify-content: center;
}
main ul.area li {
	width: calc((100% - 40px)/5);
}
main ul.area a {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
	height: auto;
	aspect-ratio: 3 / 1;
	padding-left: 1.5em;
	color: #FFF;
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.50);
	border-radius: 6px;
	background-size: 102% auto !important;
	background-position: center center !important;
	font-size: 20px;
	font-weight: bold;
}
main ul.area a.a01 {background: url(../images/area_01.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a02 {background: url(../images/area_02.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a03 {background: url(../images/area_03.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a04 {background: url(../images/area_04.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a05 {background: url(../images/area_05.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a06 {background: url(../images/area_06.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a07 {background: url(../images/area_07.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a08 {background: url(../images/area_08.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a09 {background: url(../images/area_09.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a10 {background: url(../images/area_10.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a11 {background: url(../images/area_11.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a12 {background: url(../images/area_12.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a13 {background: url(../images/area_13.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a14 {background: url(../images/area_14.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}
main ul.area a.a15 {background: url(../images/area_15.jpg);background-color: rgba(0, 0, 0, 0.1);background-blend-mode: color;}

main ul.area a span.small {
	display: inline-block;
	padding-top: 0.4em;
	font-size: 65%;
}

/*発地選択なし*/
/*#dep .nav_common_db {display: none!important;}
#dep nav.newyearNav ul li:nth-last-of-type(2) a {border-right: none!important;}*/
nav.newyearNav.commonNav {background: #bc3c02}

/* 
 sp　759px以下
================================================================================================ 
*/
@media screen and (max-width: 759.9px) {
#wrapper {line-height: 1.4;}
.spnone{display:none;}

/* CSS */
#dirPathBlock {
	overflow-x: scroll;
	overflow-y: hidden;
	margin: 2px;
}
#dirPathBlock p {
	width: max-content;
	font-size: 10px;
}
#anchorLinkBlock {margin: 0 1%;}
#anchorLinkBlock a{font-size: 12px;}

h1 {
	font-size: 10px;
	margin: 0 2px 2px 2px;
}
.inner{
	width: 96%;
	margin: 0 2%;
	padding: 24px 0;
	box-sizing: border-box;
}
.inner.nopdt_sp {
	padding: 0 0 20px;
}
.opacity0 { display: none !important;}

/* ------------------------------------------
	btn
------------------------------------------ */
.btn,.widebtn {padding: 0;}
.btn a,.widebtn a{
position: relative;
display: flex;
justify-content: center;
align-items: center;
text-align:center;
background:#e1806e;
padding:10px;
-webkit-border-radius: 5px;
border-radius: 5px;
border:solid 1px #e1806e;
color: #fff !important;
width:90%;
margin:20px auto 0;
transition: 0.2s ;
}
.btn a::after,.widebtn a::after {
position: absolute;
right:15px;
content: '';
width: 6px;
height: 6px;
border-top: 2px solid #fff;
border-right: 2px solid #fff;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

/* ------------------------------------------
	headline
------------------------------------------ */
h2.headline{
position: relative;
display: flex;
flex-direction: column;
text-align: center;
font-weight: bold;
padding: 30px 0;
font-size: 1.05rem;
}
h2 .sideline{
display: flex;
justify-content: center;
align-items: center;
text-align: center;
}
h2 .sideline::before,
h2 .sideline::after {
	content: '';
	width: 10px;
	height: 2px;
	background-color: #000;
}
h2 .sideline::before {
	margin-right: 20px;
}
h2 .sideline::after {
	margin-left: 20px;
}

/*icon*/
h2.headline::before{
content:'';
position: absolute;
top:0;
left: 50%;
transform: translateX(-50%);
}
	
.IDreco_plan h2.headline::before{
width: 20px;
height: 24px;
background: url("../images/ico_ranking.png") no-repeat;
background-size: 20px;
}
	
.IDranking h2.headline::before{
width: 20px;
height: 24px;
background: url("../images/ico_ranking.png") no-repeat;
background-size: 20px;
}
.IDlocation h2.headline::before{
width: 16px;
height: 25px;
background: url("../images/ico_location.png") no-repeat;
background-size: 16px;
}
.IDkaigai_area h2.headline::before{
width: 24px;
height: 18px;
background: url("../images/ico_camera.png") no-repeat;
background-size: 24px;
}
.keyword h2.headline::before,
.IDsearch h2.headline::before,
#plansearch h2.headline::before{
width: 24px;
height: 24px;
background: url("../images/ico_search.png") no-repeat;
background-size: 26px;
}
.IDfaq h2.headline::before,
#contact h2.headline::before{
width: 26px;
height: 24px;
background: url("../images/ico_faq.png") no-repeat;
background-size: 26px;
}
#tripaBOX h2.headline::before{
width: 27px;
height: 21px;
background: url("../images/ico_book.png") no-repeat;
background-size: 27px;
}


.keyword h2,
.IDranking h2,
.IDlocation h2,
.IDreco_plan h2,
.IDkaigai_area h2,
.IDsearch h2,
#tripaBOX h2,
.IDfaq h2,
#contact h2,
#plansearch h2{
margin-bottom: 20px;
padding: 30px 0 0;
font-size: 1.8rem;
text-align: center;
line-height: 1.2;
}
.keyword h2 span,
.IDranking h2 span,
.IDlocation h2 span,
.IDreco_plan h2 span,
.IDkaigai_area h2 span,
.IDsearch h2 span,
#tripaBOX h2 span,
.IDfaq h2 span,
#contact h2 span,
#plansearch h2 span{
display: block;
font-size: 1rem;
}


.titleH3 {
    margin: 15px 0;
    font-size: 1.2rem;
    text-align: center;
    font-weight: bold;
}
.titleH4 {
    margin: 15px 0;
    font-size: 1rem;
    text-align: center;
    font-weight: bold;
}

/* ------------------------------------------
	fixNav
------------------------------------------ */
.fixNav {
  position: fixed;
  top:5px;
  width: 100%;
  z-index: 998;
}

/* ------------------------------------------
	title
------------------------------------------ */
#title{
position: relative;
width:100%;
height:60vh;
overflow: hidden;
text-align: center;
background-size: cover;
background-image: url(../images/bg_mv_sp.jpg);
background-position: center center;
}
#title .inner{
position: relative;
width: 100%;
height:100%;
margin: 0;
padding:0;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
#title #title_mv img{
width: calc(100% - 200px);
min-width: 200px;
min-width: 220px;
}
#title #title_menu {
	width: 90%;
	position: absolute;
	bottom: 25px;
	display: flex;
}
#title #title_menu li {
width: 45%;
margin: 0 auto 3%;
background: #f4ebe2;
border: 1px solid #8d3d19;
box-shadow: 1px 1px 2px #8d3d19, 3px 3px 5px #8d3d19;
font-size: 16px;
border-radius: 5px;
position: relative;
}
#title #title_menu li a{
	width: 100%;
	display: block;
	padding: 8px 0;
	font-weight: bold;
	color: #333;
	position: relative;
}
#title #title_menu li:first-child a span,
#title #title_menu li:last-child a span {
	transform: scale(0.70, 1.5);
	font-size: 15px;
	color:#E1806E;
}
#title #title_menu li:first-child a span {
	position: absolute;
	left: 10px;
}
#title #title_menu li:last-child a span {
	position: absolute;
	right: 5px;
}
/*閲覧中*/
#title #title_menu li.now-browsing {
pointer-events: none;
background: #8d3d19;
}
#title #title_menu li.now-browsing a {color: #fff;}
#title #title_menu li.now-browsing a span {
	transform: rotate(90deg) scale(0.70, 1.5);
	top: 25%;
	color: #FFF;
}

.selectbox {
display: inline-flex;
align-items: center;
position: relative;
width: 100%;
}
.selectbox::after {
position: absolute;
right: 5px;
width: 13px;
height: 7px;
background-color: #e1806e;
clip-path: polygon(0 0, 100% 0, 50% 100%);
content: '';
pointer-events: none;
}
.selectbox select {
appearance: none;
	min-width: 100%;
	padding: 10px 0 12px 10px;
	background-color: #fff;
	color: #000;
	font-size: 0.75rem;
	cursor: pointer;
	border-radius: 5px;
	font-weight: bold;
}
.btnKaigai a{
position: absolute;
right:0;
bottom: 1.5%;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
width: 80px;
height: 70px;
border-radius: 50%;
background: #fff;
padding-bottom: 10px;
}
.btnKaigai a::after{
content:'';
position: absolute;
left: 46%;
bottom: 10px;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

/* ------------------------------------------
	nav
------------------------------------------ */
nav.newyearNav .inner{padding:0 0 30px;}
nav.newyearNav.commonNav .inner {
	width: 100%;
	margin: 0;
	padding: 5px;
}
nav.newyearNav ul{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 1%;
	background: #FFF;
	border-radius: 5px;
	box-shadow: 0 0 2px #888;
}
nav.newyearNav ul li{
	width:calc(97% / 4);
}
nav.newyearNav ul li a{
	font-size: 0.75rem;
	display: block;
	position: relative;
	margin: 8px 0 18px 0;
	background: #fff;
	border-right: 1px solid #ddd;
	font-weight: bold;
	text-align: center;
	color: #000;
}
nav.newyearNav ul li a:hover{opacity: 100;}
nav.newyearNav ul li a::after{
	content:'';
	position: absolute;
	left: 48%;
	bottom:-8px;
	width: 6px;
	height: 6px;
	border-top: 2px solid #e1806e;
	border-right: 2px solid #e1806e;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}
/*
.IDnewyear nav.newyearNav ul li:last-of-type a{
background: #be3c00;
color: #fff;
}
nav.newyearNav ul li:last-of-type a::after{
border-top: 2px solid #fff;
border-right: 2px solid #fff;
}
*/

/*nav.newyearNav.fixNav ul{
justify-content: space-between;
flex-wrap:wrap;
gap:0;
}
nav.newyearNav.indexNav.fixNav ul,
nav.newyearNav.syutokenNav.fixNav ul,
nav.newyearNav.chubuNav.fixNav ul,
nav.newyearNav.hokurikuNav.fixNav ul,
nav.newyearNav.kansaiNav.fixNav ul,
nav.newyearNav.chugokuNav.fixNav ul,
nav.newyearNav.kyushuNav.fixNav ul{
margin-top: 48px;
}
nav.newyearNav.fixNav ul li {
    width: 31%;
    letter-spacing: -0.05em;
    margin-bottom: 5px
}
nav.newyearNav.fixNav ul li a {
padding: 10px 0 20px 0;
}
nav.newyearNav.commonNav.fixNav ul li {
    width: 100%;
    margin-bottom: 0;
}*/
nav.newyearNav.commonNav.fixNav{
    z-index: 999;
}
/*
nav.newyearNav.fixNav ul li:nth-of-type(2) {
    width: 30%;
}

nav.newyearNav.fixNav ul li:nth-of-type(4),
nav.newyearNav.fixNav ul li:nth-of-type(5){
    display: none;
}

nav.newyearNav.fixNav ul li a{
background: #e1806e;
color: #fff;
}
*/

span.anchorlink {
    position: relative;
    top: -20px;
    display: block;
}


/* ------------------------------------------
	news
------------------------------------------ */
.news  h2{
margin-bottom: 20px;
padding: 0;
text-align: center;
font-size: 1.8rem;
}
.news  h2 span{
display: block;
font-size: 1rem;
}
.list_news li{
padding: 10px 20px 10px 5px;
border-bottom:1px dotted #ccc;
position: relative;
display: flex;
}
.list_news li:last-child{border-bottom: none;}
.list_news a{
	width:100%;
	position: relative;
	display: inline-block;
	color: #000;
	vertical-align: middle;
	text-decoration: none;
	font-size: 14px;
}
.list_news a:hover{color:#e1806e !important;}
.list_news li .icon {
	background: #e1806e;
	color: #FFF;
	margin-right: 10px;
	padding: 2px 10px;
	display: inline-block;
	height: 24px;
	box-sizing: border-box;
}
.list_news a::before,
.list_news a::after{
	position: absolute;
	top: 0;
	bottom: 0;
	right: -18px;
	margin: auto;
	content: "";
	vertical-align: middle;
}
.list_news a:before{
	box-sizing: border-box;
	width: 16px;
	height: 16px;
	background: #e1806e;
	-webkit-border-radius: 50%;
	border-radius: 50%;
}
.list_news a:after{
	right: -12px;
	width: 5px;
	height: 5px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

/* ------------------------------------------
	keyword
------------------------------------------ */
/*.keyword { border-bottom:solid 1px #e2e2e2;}
.keyword.last { border-bottom:none;}*/
.list_keyword{
display: flex;
flex-wrap:wrap;
justify-content: center;
gap:10px;
padding: 30px 0 0 0;
}
.list_keyword li a{
display: block;
padding: 6px 15px;
border-radius: 100vh;
border:solid 1px #e1806e;
background: #fff;
color: #000 !important;
}
.list_keyword li a:hover{
border:solid 1px #e1806e;
background: #e1806e;
color: #fff !important;
}

/* ------------------------------------------
	recommend_bnr
------------------------------------------ */
.recommend_bnr li{
margin: 10px 0;
text-align: center;
}
.recommend_bnr img{
width: 100%;
max-width: 640px;
}
.recommend_bnr li p{
text-align: center;
}

/* ------------------------------------------
	ranking
------------------------------------------ */
/*.IDranking{
display: block;
background: url(../images/washi_bg.jpg) repeat;
}*/
.IDranking .inner{
width:100%;
margin:0;
padding-top: 40px;
}
.IDreco_plan{
position: relative;
}
.IDreco_plan .inner{
width:100%;
margin:0;
padding-top: 40px;
}

/*wave*/
.custom-shape-divider-top-1682026297 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1682026297 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 30px;
	vertical-align: bottom;
}
.custom-shape-divider-top-1682026297 .shape-fill {
    fill: #FFFFFF;
}

/*rankBox*/
.rankBox{
position: relative;
/*background:#fff;*/
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox > ul > li.sliderBox.linkbox {
	background: -moz-linear-gradient(top, #f0e6d7, #f7f2eb) !important;
	background: -webkit-gradient(linear, center top, center bottom, from(#f0e6d7), to(#f7f2eb));
}
.rankBox .rankNo{
display: flex;
align-items: center;
line-height: 1.3;
}
.kaigai_rankingbox .rankBox .rankNo {height: 90px;}
.IDlocation .rankBox .rankNo {visibility: hidden;}
.rankBox .rankNo .no{
padding: 0 0 0 13px;
font-size: clamp(14px,3.5vw,24px);
color: #ffcfc6;
border-bottom: solid 1px #ffcfc6;
}
.rankBox .rankNo .number{
padding: 0 0 0 2px;
font-size: clamp(3.25rem, 3.068rem + 0.91vw, 3.75rem);
color: #ffcfc6;
}
.rankBox h3 {
position: absolute;
top:15px;
left: 50%;
transform: translateX(-50%);
display: flex;
flex-direction: column;
text-align: center;
line-height: 1.2;
}
.rankBox h3 .area_rank{
font-size: 20px;
font-weight: bold;
line-height: 1;
}
.rankBox h3 .read_rank{
font-size: 14px;
color: #999999;
letter-spacing: 2px;
}
	
	
.name_rank{
		/*width: calc(100% - 40px);*/
    font-weight: bold;
		font-size: 15px;
    max-width: 520px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
		padding: 10px 0 10px 0;

	}
	
	.area_rank2{
		text-align: right;
		width: calc(100% - 20px);
		/*font-size: 12px;*/
		margin: 0 15px 0 0;
		max-width: 520px;
	}
	
	.money_rank{
	color: #CC0000;
    text-align: right;
    width: calc(100% - 20px);
    font-size: 18px;
    padding: 0 0 15px 0;
    font-weight: bold;
		max-width: 520px;

	}
	
	.money_rank span{
		font-size: 14px;
		color: black;
	}

	
.img_rank2 {
	margin: 0px auto 15px;
    text-align: center;
    width: calc(100% - 40px);
    padding: 0px 0 0 0;
}
.img_rank2 img{
width: 100%;
max-width: 520px;
}
	
.img_rank {
margin: 0 auto;
text-align: center;
width: calc(100% - 40px);
}
.img_rank img{
width: 100%;
max-width: 520px;
}
.txt_rank {
margin: 15px auto;
width: calc(100% - 40px);
max-width: 520px;
text-align: justify;
}
.planlist_rank{
margin: 0 auto;
width: calc(100% - 5px);
max-width: 520px;
}
.planlist_rank .btn a{
width: calc(100% - 20px);
margin-top: 10px;
}
.planlist_rank .btn.noplan{display:none;}
.link_area a{
position: relative;
display: flex;
justify-content: flex-end;
align-items: center;
margin: 10px auto 0 auto;
width: calc(100% - 40px);
max-width: 520px;
padding:5px 2em 20px 0;
text-decoration: underline;
}
.link_area a::after {
content: '';
position: absolute;
top:12px;
right:1em;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

/*slider*/
.IDranking .slider {
  margin: 0 auto;
  width: 100%;
}
.IDranking .sliderBox {
  margin: 0 10px;
}
.IDreco_plan .slider {
  margin: 0 auto;
  width: 100%;
}
.IDreco_plan .sliderBox {
  margin: 0 10px;
}

/* ------------------------------------------
	location
------------------------------------------ */
/*.IDlocation{
position: relative;
background: #fff;
}
.IDlocation .inner{
padding-top: 40px;
}*/

/*wave*/
.custom-shape-divider-top-1682026220 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1682026220 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 30px;
    transform: rotateY(180deg);
}
.custom-shape-divider-top-1682026220 .shape-fill {
    fill: #e1806e;
}

/*shape*/
.custom-shape-divider-bottom-1682006032 {
    display: none;
}


/*locationBox*/
.locationBox{
position: relative;
background: -moz-linear-gradient(top, #f0e6d7, #f7f2eb);
background: -webkit-gradient(linear, center top, center bottom, from(#f0e6d7), to(#f7f2eb));
border-top:solid 4px #e1806e;
}
.locationBox h3 {
display: flex;
flex-direction: column;
text-align: center;
line-height: 1.2;
padding: 17px 0;
min-height: 110px;
}
.locationBox h3 .area_loca{
font-size: 24px;
font-weight: bold;
}
.locationBox h3 .read_loca{
font-size: 14px;
color: #999999;
letter-spacing: 2px;
}
.img_loca {
margin: 0 auto;
text-align: center;
width: calc(100% - 40px);
}
.img_loca img{
width: 100%;
max-width: 520px;
}
.txt_loca {
margin: 15px auto;
width: calc(100% - 40px);
max-width: 520px;
}
.planlist_loca{
margin: 0 auto;
width: calc(100% - 5px);
max-width: 520px;
}
.IDreco_plan .planlist_loca{
width: calc(100% - 5px);
padding-bottom: 15px;
}
.planlist_loca .btn a{
width: calc(100% - 20px);
margin-top: 10px;
}
.link_area a{
position: relative;
display: flex;
justify-content: flex-end;
align-items: center;
margin: 10px auto 0 auto;
width: calc(100% - 40px);
max-width: 520px;
padding:5px 2em 20px 0;
text-decoration: underline;
}
.link_area a::after {
content: '';
position: absolute;
top:12px;
right:1em;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

/*slider*/
.IDlocation .slider {
  margin: 0 auto;
  width: 100%;
}
.IDlocation .sliderBox {
  margin: 0 10px;
}


.txt_fami{
/*margin: 40px auto 15px;*/
margin: 15px auto 40px;
text-align: center;
width: 90%;
}
.read_fami{
display: flex;
justify-content: center;
align-items: center;
text-align: center;
margin-bottom: 15px;
font-size: 1.3em;
font-weight:500;
}
.txt_fami p{
margin-bottom: 10px;
}
.deco_fami{
display: inline;
font-size: 1.1em;
background-image: linear-gradient(#fff 70%, #e1806e 70%);
}

/* ------------------------------------------
	search
------------------------------------------ */
.custom-shape-divider-top-1683555261 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1683555261 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 30px;
}
.custom-shape-divider-top-1683555261 .shape-fill {
    fill: #FFFFFF;
}
/*/*.IDsearch{
display: block;
background: url(../images/washi_bg.jpg) repeat;
}*/
.IDsearch .inner{
width:100%;
margin:0;
padding-top: 40px;
}*/

/*slider*/
.IDsearch .slider {
  margin: 0 auto;
  width: 100%;
}
.IDsearch .slider2 {
  margin: 0 auto;
  width: 100%;
}
.IDsearch .sliderBox {
  margin: 0 10px;
}
.head_search{
display: flex;
flex-direction: column;
align-items: center;
margin: 20px 0;
padding: 0;
font-size: 1rem;
text-align: center;
line-height: 1.2;
font-weight: bold;
}
.head_search span{
font-size: 2rem;
color: #e1806e;
display: block;
padding-bottom: 5px;
}
.read_search p{
text-align: center;
padding: 3px 0;
}
.sizeL{
font-size: 1.1rem;
}
.deco_search{
display: inline;
background-image: linear-gradient(transparent 70%, #e1806e 70%);
}

/*cp_ipselect*/
.cp_ipselect {
	position: relative;
	display: block;
	overflow: hidden;
	width: 90%;
	height: 100%;
	margin: 2em auto;
	border-radius: 3px;
	color: #ffffff;
}
.cp_ipselect > i.toggle {
	position: absolute;
	z-index: 4;
	top: 1.6em;
	right: 1.5em;
	color: #ffffff;
}
.cp_ipselect .cp_arrowup:before {
	position: absolute;
	top: 0;
	right: 0;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	pointer-events: none;
	border-right: 6px solid transparent;
	border-bottom: 6px solid #ffffff;
	border-left: 6px solid transparent;
	-webkit-transition: all 250ms cubic-bezier(.4,.25,.3,1);
	transition: all 250ms cubic-bezier(.4,.25,.3,1);
}
.cp_ipselect .cp_arrowdown:before {
	position: absolute;
	top: 0;
	right: 0;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	pointer-events: none;
	border-top: 6px solid #ffffff;
	border-right: 6px solid transparent;
	border-left: 6px solid transparent;
	-webkit-transition: all 250ms cubic-bezier(.4,.25,.3,1);
	transition: all 250ms cubic-bezier(.4,.25,.3,1);
}
.cp_ipselect .cp_title, .cp_ipselect .cp_selectlabel {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	padding: 1em 0;
	cursor: pointer;
	border-top: 1px solid #cbf2f7;
	background: #e1806e;
	text-align: center;
}
.cp_ipselect > input {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	cursor: pointer;
	opacity: 0;
}
.cp_ipselect > input:checked ~ i.toggle.cp_arrowdown {
	display: none;
}
.cp_ipselect > input:checked ~ i.toggle.cp_arrowup {
	display: block;
}
.cp_ipselect > input:checked div.options label.option .cp_title {
	display: none !important;
}
.cp_ipselect > input:not(:checked) {
	z-index: 4;
}
.cp_ipselect > input:not(:checked) ~ label.option > span.cp_title {
	display: none;
}
.cp_ipselect > input:not(:checked) ~ i.toggle.cp_arrowup {
	display: none;
}
.cp_ipselect > input:not(:checked) ~ i.toggle.cp_arrowdown {
	display: block;
}
.cp_ipselect > span.cp_selectlabel {
	position: relative;
	z-index: 0;
	display: inline-block;
	width: 100%;
	color: #ffffff;
	border-top: 0;
}
.cp_ipselect label.option {
	z-index: 1;
	display: block;
	overflow: hidden;
	width: 100%;
	transition: all 1s ease-out;
}
.cp_ipselect label.option span.cp_title {
	position: relative;
	z-index: 2;
	transition: 0.3s ease-out;
}
.cp_ipselect label.option span.cp_title:hover {
	color: #ffffff;
	background: #e1806e;
}
.cp_ipselect label.option input {
	display: none;
}
.cp_ipselect label.option input:checked ~ span.cp_title {
	position: absolute;
	z-index: 3;
	top: 0;
	display: block;
	width: 100%;
	color: inherit;
	border-top: 0;
	background: #e1806e;
	box-shadow: none;
}
.cp_ipselect label.theme {
display: none;
}

/*searchBox*/
.searchBox{
display: flex;
flex-direction: column;
position: relative;
background: #fff;
padding-bottom: 20px;
}
.searchBox h3 {
display: flex;
flex-direction: column;
text-align: center;
line-height: 1.2;
padding: 17px 0;
}
.searchBox h3 .title_search{
font-size: 16px;
font-weight: bold;
}
.img_search {
margin: 0 auto;
text-align: center;
width: calc(100% - 40px);
}
.img_search img{
width: 100%;
max-width: 520px;
}
.txt_search {
margin: 15px auto;
width: calc(100% - 40px);
max-width: 520px;
}
.planlist_search{
margin: auto auto 0 auto;
width: calc(100% - 40px);
max-width: 520px;
}
.planlist_search .btn a{
width: calc(100% - 20px);
margin-top: 10px;
}
.recohotel{
width: calc(100% - 40px);
margin:30px auto 0 auto;
}
.read_recohotel{
display: flex;
justify-content: center;
align-items: center;
text-align: center;
margin-bottom: 5px;
font-size: 14px;
font-weight:500;
}
.read_recohotel::before,
.read_recohotel::after {
	content: '';
  flex-grow: 1;
	height: 1px;
	background-color: #000;
}
.read_recohotel::before {
	margin-right: 10px;
}
.read_recohotel::after {
	margin-left: 10px;
}
.recohotel ul{
display: flex;
flex-direction: column;
gap:0 1em;
}
.recohotel ul li a{
display: flex;
align-items: baseline;
margin:5px 0;
padding: 0;
text-decoration: underline;
}
.recohotel ul li a::before {
content: '';
margin-right: 7px;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.recohotel ul li a:hover{
color:#e1806e !important;
text-decoration: underline;
}
.otherSearch{
display: flex;
justify-content: center;
margin:0 auto;
padding:20px 0;
width:100%;
}
.otherSearch li{
width:50%;
}
.otherSearch .btn a{
padding:10px 10px;
margin:10px auto;
}

/* ------------------------------------------
	feature article / tripa
------------------------------------------ */
.IDfeature,
#tripa{
display: block;
background: url(../images/washi_bg_gradation.jpg) repeat;
}
.IDfeature .inner,
#tripa .inner{
width:100%;
margin:0;
padding-top: 40px;
}

/*rowboxBox*/
.rowBox{
position: relative;
background:#fff;
padding-top: 15px;
}
.img_rowbox {
margin: 0 auto;
text-align: center;
width: calc(100% - 30px);
max-width: 320px;
}
.img_rowbox img{
width: 100%;
max-width: 320px;
margin: 0 auto;
}
.read_rowbox {
margin: 10px auto;
width: calc(100% - 30px);
max-width: 320px;
font-weight: bold;
}
.txt_rowbox {
margin: 15px auto;
width: calc(100% - 30px);
max-width: 320px;
}
.link_rowbox a{
position: relative;
display: flex;
justify-content: flex-end;
align-items: center;
margin: 10px auto 0 auto;
max-width: 320px;
padding:5px 2em 15px 0;
text-decoration: underline;
}
.link_rowbox a::after {
content: '';
position: absolute;
top:12px;
right:1em;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

/*slider*/
.IDfeature .slider,
#tripa .slider {
  margin: 0 auto;
  width: 100%;
}
.IDfeature .sliderBox,
#tripa .sliderBox{
  margin: 0 10px;
}

/* feature
------------------------------------------ */
.custom-shape-divider-top-1682027088 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1682027088 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 30px;
}
.custom-shape-divider-top-1682027088 .shape-fill {
    fill: #e0f6f9;
}

/* tripa
------------------------------------------ */
.custom-shape-divider-top-1682026116 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1682026116 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 30px;
    transform: rotateY(180deg);
}
.custom-shape-divider-top-1682026116 .shape-fill {
    fill: #E8F2F3;
}
.tripaBtn.btn a{
margin:30px auto 0 auto;
background:#fff;
color: #000 !important;
}
.tripaBtn.btn a::after {
border-color: #e1806e;
}

/* ------------------------------------------
	faq
------------------------------------------ */
/*.IDfaq{
display: block;
background: url(../images/washi_bg.jpg) repeat;
}
.IDfaq .inner{
padding-bottom: 40px;
}*/
.accordion {
    background-color: #fff;
}
.accordion:not([open]) {
    margin-bottom: 2px;
}
.accordion summary {
    display: flex;
    align-items: center;
    position: relative;
    padding:1em 4em 1em 1em;
    background-color: #b49b78;
    color: #fff;
    cursor: pointer;
}
.accordion summary::-webkit-details-marker {
    display: none;
}
.accordion summary::before {
content: 'Q';
color: #fff;
font-size: clamp(1.875rem, 1.693rem + 0.91vw, 2.375rem);
margin-right: 20px;
}
.accordion summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid #fff;
    border-right: 3px solid #fff;
    content: '';
    transition: transform .3s;
    position: absolute;
    right:2em;
}
.accordion[open] summary::after {
    transform: rotate(225deg);
}
.accordion div {
display: flex;
align-items: center;
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    padding: 1.4em 1em ;
    color: #000;
    transition: transform .5s, opacity .5s;
}
.accordion div::before {
content: 'A';
color: #b49b78;
font-size: 38px;
margin-right: 20px;
}
.accordion[open] div {
    transform: none;
    opacity: 1;
}

/*------------------------------
scroll item
------------------------------*/
.scrollbox_wraper {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;
	padding: 0 calc((100% - (900px / 3)) / 2);
}
.scrollbox_wraper .scrollbox > ul > li,
.scrollbox_wraper .scrollbox .ItemBoxItem .ItemSetWrap {
	width: 270px !important;
    margin: 0 5px;
	background: #fff;
}
.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;
}

main div.calendar ol.month_tab > li a {
	font-size: 14px!important;
}
main div.calendar ol.month_tab > li a span.weekday,
main div.calendar ol.month_tab > li a span.holiday {
	font-size: 90% !important;
}
.under_menu ul {
    flex-wrap: wrap;
}
.under_menu ul li {
    width: calc(100% / 3 - 1px);
    margin-bottom: 10px;
}
.under_menu ul li:first-child,
.under_menu.nk_menu ul li:first-child {
    width: 100%;
    border-right: none; 
}
.under_menu ul li:nth-of-type(4) {
    border-right: none; 
}
.under_menu.nk_menu ul {
    width: 100%;
}
.under_menu.nk_menu ul li {
    width: calc(100% / 2 - 1px);
}

/* ------------------------------------------
	nav
------------------------------------------ */
nav.kaigai_daysNav ul{
display: flex;
justify-content: center;
flex-wrap:wrap;
gap:10px;
margin: 30px auto;
}
nav.kaigai_daysNav ul li {
width: calc( 100% / 4 - 10px);
}
nav.kaigai_daysNav ul li a{
display:block;
position: relative;
padding:15px 0 20px 0;
background: #fff;
border:solid 1px #333;
border-radius: 5px;
text-align: center;
color: #000;
}
nav.kaigai_daysNav ul li a:hover{
opacity: 100;
}
nav.kaigai_daysNav ul li a::after{
content:'';
position: absolute;
left: 0;
right: 0;
bottom: 10px;
margin: 0 auto;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(135deg);
transform: rotate(135deg);
}

/* ul.area */
main ul.area {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 4vw;
}
main ul.area li {
	width: calc(50% - 2vw);
}
main ul.area a {
	width: 100%;
	font-size: 14px;
	font-weight: bold;
}

}

/* 
 pc　760px以上
================================================================================================ 
*/
@media screen and (min-width: 760px),print {

.pcnone{display:none;}

/* CSS */
#wrapper {line-height: 1.231;}
#dirPathBlock,
h1,
.iframe_end-content_gadget,
#anchorLinkBlock{
	width: 100%;
	max-width:1080px;
	min-width:760px;
	margin: auto;
}

/*panlist&back*/
#dirPathBlock,
#anchorLinkBlock {
	width: 100%;
	max-width:1080px;
	min-width:760px;
	margin: 0 auto;
	display: block;
	font-size: 12px;
}
#dirPathBlock p,
#anchorLinkBlock a{font-size: 12px;}
h1 {
	font-size: 12px;
    width: auto;
    max-width: 1080px;
    margin: 0 auto 10px;
}
.inner{
	width: 96%;
	max-width:1080px;
	margin: 0 auto;
	padding:50px 0;
	display: block;
}
.opacity0 { display: block;opacity: 0;}

/* ------------------------------------------
	btn
------------------------------------------ */
.btn {padding: 0;}
.btn a{
position: relative;
display: flex;
justify-content: center;
align-items: center;
text-align:center;
background:#fff;
padding:10px;
-webkit-border-radius: 5px;
border-radius: 5px;
border:solid 1px #000;
width:80%;
margin:20px auto 0;
transition: 0.2s ;
}
.btn a::after {
position: absolute;
right:15px;
content: '';
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.btn a:hover{
background:#e1806e;
color: #fff !important;
border:solid 1px #e1806e;
transform: translate(0,2px);
}
.btn a:hover::after {border-color: #fff;}
.widebtn {padding: 0;}
.widebtn a{
position: relative;
display: flex;
justify-content: center;
align-items: center;
text-align:center;
padding:10px;
-webkit-border-radius: 5px;
border-radius: 5px;
width:80%;
margin:20px auto 0;
background:#e1806e;
color: #fff !important;
border:solid 1px #e1806e;
transition: 0.2s ;
}
.widebtn a::after {
position: absolute;
right:15px;
content: '';
width: 6px;
height: 6px;
border-top: 2px solid #fff;
border-right: 2px solid #fff;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.widebtn a:hover{
background:#fff;
color: #000 !important;
border:solid 1px #000;
}
.widebtn a:hover::after {border-color: #e1806e;}

/* ------------------------------------------
	headline
------------------------------------------ */
h2.headline{
position: relative;
display: flex;
flex-direction: column;
text-align: center;
font-weight: bold;
padding: 30px 0;
font-size: 20px;
}
h2 .sideline{
display: flex;
justify-content: center;
align-items: center;
text-align: center;
}
h2 .sideline::before,
h2 .sideline::after {
	content: '';
	width: 10px;
	height: 2px;
	background-color: #000;
}
h2 .sideline::before {
	margin-right: 30px;
}
h2 .sideline::after {
	margin-left: 30px;
}


/*icon*/
h2.headline::before{
content:'';
position: absolute;
top:0;
left: 50%;
transform: translateX(-50%);
}
	
.IDreco_plan h2.headline::before{
width: 20px;
height: 24px;
background: url("../images/ico_ranking.png") no-repeat;
background-size: 20px;
}
	
.IDranking h2.headline::before{
width: 20px;
height: 24px;
background: url("../images/ico_ranking.png") no-repeat;
background-size: 20px;
}
.IDlocation h2.headline::before{
width: 16px;
height: 25px;
background: url("../images/ico_location.png") no-repeat;
background-size: 16px;
}
.IDkaigai_area h2.headline::before{
width: 24px;
height: 18px;
background: url("../images/ico_camera.png") no-repeat;
background-size: 24px;
}
.keyword h2.headline::before,
.IDsearch h2.headline::before,
#plansearch h2.headline::before{
width: 24px;
height: 24px;
background: url("../images/ico_search.png") no-repeat;
background-size: 26px;
}
.IDfaq h2.headline::before,
#contact h2.headline::before{
width: 26px;
height: 24px;
background: url("../images/ico_faq.png") no-repeat;
background-size: 26px;
}
#tripaBOX h2.headline::before{
width: 27px;
height: 21px;
background: url("../images/ico_book.png") no-repeat;
background-size: 27px;
}

.keyword h2,
.IDranking h2,
.IDlocation h2,
.IDreco_plan h2,
.IDkaigai_area h2,
.IDsearch h2,
#tripaBOX h2,
.IDfaq h2,
#contact h2,
#plansearch h2{
margin-bottom: 20px;
padding: 30px 25px 0;
font-size: 38px;
text-align: center;
}
.keyword h2 span,
.IDranking h2 span,
.IDlocation h2 span,
.IDreco_plan h2 span,
.IDkaigai_area h2 span,
.IDsearch h2 span,
#tripaBOX h2 span,
.IDfaq h2 span,
#contact h2 span,
#plansearch h2 span{
display: block;
font-size: 20px;
}
.titleH3 {
    margin: 0 0 15px;
    font-size: 23px;
    text-align: center;
    font-weight: bold;
}
.titleH3.mtB.noBtn {
    margin-top: 20px;
}
.titleH4 {
    margin: 0 0 15px;
    font-size: 18px;
    text-align: center;
    font-weight: bold;
}

/* ------------------------------------------
	fixNav
------------------------------------------ */
.fixNav {
  position: fixed;
  top:0;
  width: 100%;
  z-index: 998;
}

/* ------------------------------------------
	title
------------------------------------------ */
#title{
position: relative;
width:100%;
height:500px;
overflow: hidden;
text-align: center;
background-position: center;
background-repeat: no-repeat;
background-size: cover;
background-image: url(../images/bg_mv_pc.jpg);
}
#title .inner{
position: relative;
width: 96%;
height:500px;
max-width:1080px;
background: 0;
margin: 0 auto;
padding:0;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
padding-top: 10px;
}
#title #title_mv img{
width: 235px;
min-width: 280px;
}
#title #title_menu {
	width: 440px;
	display: flex;
	position: absolute;
	bottom: 50px;
}
#title #title_menu li {
	width: 200px;
	/*margin: 0 10px;*/margin: 0 auto;
	background: #f4ebe2;
	border: 1px solid #8d3d19;
	box-shadow: 1px 1px 2px #8d3d19,3px 3px 5px #8d3d19;
	font-size: 18px;
	border-radius: 5px;
	position: relative;
	transition: 0.2s;
}
#title #title_menu li:hover {
	background: #8d3d19;
	opacity: 1;
	scale: 1.05;
}
#title #title_menu li a{
	width: 100%;
	display: block;
	padding: 10px 0;
	font-weight: bold;
	position: relative;
	color: #333;
}
#title #title_menu li:hover a{color: #FFF;}
#title #title_menu li:first-child a span,
#title #title_menu li:last-child a span {
	transform: scale(0.75, 1.6);
	font-size: 15px;
	color:#E1806E;
}
#title #title_menu li:hover a span{color: #FFF;}
#title #title_menu li:first-child a span {
	position: absolute;
	left: 10px;
}
#title #title_menu li:last-child a span {
	position: absolute;
	right: 10px;
}
/*閲覧中*/
#title #title_menu li.now-browsing {
pointer-events: none;
background: #8d3d19;
}
#title #title_menu li.now-browsing a {color: #fff;}
#title #title_menu li.now-browsing a span {
	transform: rotate(90deg) scale(0.70, 1.5);
	top: 26%;
	color: #FFF;
}

.selectbox {
display: inline-flex;
align-items: center;
position: relative;
}
.selectbox::after {
position: absolute;
right: 15px;
width: 13px;
height: 7px;
background-color: #e1806e;
clip-path: polygon(0 0, 100% 0, 50% 100%);
content: '';
pointer-events: none;
}
.selectbox select {
	appearance: none;
	min-width: 230px;
	padding: 15px 0;
	/* border: 1px solid #333; */
	background-color: #fff;
	color: #000;
	font-size: 16px;
	cursor: pointer;
font-weight: bold;
	text-align: center;
}
.btnKaigai a{
position: absolute;
right:2%;
bottom: 4%;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
width: 95px;
height: 85px;
border-radius: 50%;
background: #fff;
padding-bottom: 10px;
}
.btnKaigai a::after{
content:'';
position: absolute;
left: 46%;
bottom: 15px;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.btnKaigai a:hover{
transform: translate(0,2px);
}

/* ------------------------------------------
	nav
------------------------------------------ */
/*nav.newyearNav .inner{
padding: 30px 0;
}*/
nav.newyearNav.indexNav ul,
nav.newyearNav.syutokenNav ul,
nav.newyearNav.chubuNav ul,
nav.newyearNav.hokurikuNav ul,
nav.newyearNav.kansaiNav ul,
nav.newyearNav.chugokuNav ul,
nav.newyearNav.kyushuNav ul{
position: relative;
display: flex;
/*justify-content: space-between;*/
flex-wrap:nowrap;
width: 735px;
}

nav.newyearNav .inner{padding:0 0 30px;}
nav.newyearNav.commonNav .inner {
width: 100%;
/* margin: 0; */
padding: 10px 0;
}
nav.newyearNav ul{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 1%;
	background: #FFF;
	border-radius: 5px;
	box-shadow: 0 0 2px #888;
}
nav.newyearNav ul li{
	width:calc(97% / 4);
}
nav.newyearNav ul li a{
font-size: 16px;
	display: block;
	position: relative;
	margin: 15px 0;
	background: #fff;
	border-right: 1px solid #ddd;
font-weight: bold;
	text-align: center;
	color: #000;
}
nav.newyearNav ul li a:hover{opacity: 100;}
nav.newyearNav ul li a::after{
	content:'';
	position: absolute;
	left: 48%;
	bottom:-8px;
	width: 6px;
	height: 6px;
	border-top: 2px solid #e1806e;
	border-right: 2px solid #e1806e;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}

/*
.IDnewyear nav.newyearNav ul li:last-of-type a{
background: #be3c00;
color: #fff;
}

nav.newyearNav ul li:last-of-type a:hover{
border:solid 1px #e1806e;
background: #e1806e;
}
nav.newyearNav ul li:last-of-type a::after{
content:'';
border-top: 2px solid #fff;
border-right: 2px solid #fff;
}
*/

/*
nav.newyearNav ul{
display: flex;
justify-content: space-between;
flex-wrap:wrap;
gap:10px;
}
nav.newyearNav ul li{
flex:1;
width:100%;
}
nav.newyearNav ul li a{
display:block;
position: relative;
padding:25px 0 30px 0;
background: #fff;
border:solid 1px #333;
border-radius: 5px;
text-align: center;
color: #000;
}
nav.newyearNav ul li a::after{
content:'';
position: absolute;
left: 48%;
bottom:10px;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(135deg);
transform: rotate(135deg);
}
nav.newyearNav ul li a:hover{
background: #e1806e;
border:solid 1px #e1806e;
color: #fff !important;
opacity: 100;
}
nav.newyearNav ul li a:hover::after{
border-color:#fff;
}
.IDnewyear nav.newyearNav ul li:last-of-type a{
background: #be3c00;
color: #fff;
}
nav.newyearNav ul li:last-of-type a:hover{
border:solid 1px #e1806e;
background: #e1806e;
}
nav.newyearNav ul li:last-of-type a::after{
content:'';
border-top: 2px solid #fff;
border-right: 2px solid #fff;
}
*/

span.anchorlink {
    position: relative;
    top: 0;
    display: block;
}

/* ------------------------------------------
	news
------------------------------------------ */
.news  h2{
font-size: 38px;
text-align: center;
}
.news  h2 span{
display: block;
font-size: 20px;
}
.list_news li{
width: 100%;
padding: 12px 20px 12px 0;
border-bottom: 1px dotted #ccc;
position: relative;
display: flex;
}
.list_news li:last-child{border-bottom: none;}
.list_news a{
	width:100%;
	position: relative;
	display: inline-block;
	color: #000;
	vertical-align: middle;
	text-decoration: none;
	font-size: 16px;
}
.list_news a:hover{color:#e1806e !important;}
.list_news li .icon {
	background: #e1806e;
	color: #FFF;
	margin-right: 10px;
	padding: 2px 10px;
	display: inline-block;
	height: 24px;
	box-sizing: border-box;
}
.list_news a::before,
.list_news a::after{
	position: absolute;
	top: 0;
	bottom: 0;
	right: -18px;
	margin: auto;
	content: "";
	vertical-align: middle;
}
.list_news a:before{
	box-sizing: border-box;
	width: 16px;
	height: 16px;
	background: #e1806e;
	-webkit-border-radius: 50%;
	border-radius: 50%;
}
.list_news a:after{
	right: -12px;
	width: 5px;
	height: 5px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

/* ------------------------------------------
	keyword
------------------------------------------ */
/*.keyword { border-bottom:solid 1px #e2e2e2;}
.keyword.last { border-bottom:none;}*/
.list_keyword{
display: flex;
flex-wrap:wrap;
gap:15px;
padding: 15px 0 0 0;
}
.list_keyword li a{
display: block;
padding: 8px 20px;
border-radius: 100vh;
border:solid 1px #e1806e;
background: #fff;
color: #000 !important;
}
.list_keyword li a:hover{
border:solid 1px #e1806e;
background: #e1806e;
color: #fff !important;
}

/* ------------------------------------------
	recommend_bnr
------------------------------------------ */
.recommend_bnr {
display: flex;
justify-content: space-between;
gap: 30px;
}
.recommend_bnr.center {
display: flex;
justify-content: center;
gap: normal;
}
.recommend_bnr img:hover{
transition: 0.2s ;
transform: translate(0,2px);
}
.recommend_bnr img{
width: 100%;
}
.recommend_bnr li p{
text-align: center;
}

/* ------------------------------------------
	ranking 
------------------------------------------ */
/*.IDranking{
display: block;
background: url(../images/washi_bg.jpg) repeat;	
}*/
.IDreco_plan{
position: relative;
}

/*wave*/
.custom-shape-divider-top-1682026297 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1682026297 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 70px;
}
.custom-shape-divider-top-1682026297 .shape-fill {
    fill: #FFFFFF;
}

/*rankBox*/
.rankBox{
display: flex;
flex-direction: column;
position: relative;
/*background:#fff;
max-width: 310px;*/
}
.rankBox .rankNo{
display: flex;
align-items: center;
line-height: 1.3;
}
.IDlocation .rankBox .rankNo {visibility: hidden;}
.rankBox .rankNo .no{
padding: 0 0 0 13px;
font-size: 24px;
color: #ffcfc6;
border-bottom: solid 1px #ffcfc6;
}
.rankBox .rankNo .number{
padding: 0 0 0 2px;
font-size: 60px;
color: #ffcfc6;
}
.rankBox h3 {
position: absolute;
top:15px;
left: 50%;
transform: translateX(-50%);
display: flex;
flex-direction: column;
text-align: center;
line-height: 1.2;
}
.rankBox h3 .area_rank{
font-size: 20px;
font-weight: bold;
line-height: 1;
}
.rankBox h3 .read_rank{
font-size: 14px;
color: #999999;
letter-spacing: 2px;
}
.name_rank{
		/*width: calc(100% - 40px);*/
		font-weight: bold;
		margin: 15px auto 15px;
		font-size: 15px;
		text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	}
	
	.area_rank2{
		text-align: right;
		width: calc(100% - 20px);
		font-size: 14px;
		margin: 0 15px 0 0;
	}
	
	.money_rank{
	color: #CC0000;
   text-align: right;
    width: calc(100% - 20px);
    font-size: 18px;
    margin: 0 auto 15px;
    font-weight: bold;

	}
	
	
	.money_rank span{
		font-size: 14px;
		color: black;
	}
	
	
.img_rank2 {
margin: 0px auto 15px;
text-align: center;
width: calc(100% - 40px);
}
.img_rank2 img{
width: 100%;
max-width: 520px;
}

	
.img_rank {
margin: 0 auto;
text-align: center;
width: calc(100% - 40px);
}
.img_rank img{
width: 100%;
max-width: 520px;
}
.txt_rank {
margin: 15px auto;
width: calc(100% - 40px);
max-width: 520px;
text-align: justify;
letter-spacing: 0.08em;
}
.planlist_rank{
margin: 0 auto;
width: calc(100% - 40px);
max-width: 520px;
}
.planlist_rank .btn a{
width: calc(100% - 20px);
margin-top: 10px;
}
.planlist_rank .btn.noplan{display:none;}
.link_area a{
position: relative;
display: flex;
justify-content: flex-end;
align-items: center;
margin: 10px auto 0 auto;
width: calc(100% - 40px);
max-width: 520px;
padding:5px 2em 20px 0;
text-decoration: underline;
}
.link_area a::after {
content: '';
position: absolute;
top:12px;
right:1em;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.link_area a:hover{
color:#e1806e !important;
text-decoration: underline;
}

/*slider*/
.IDranking .slider {
display: flex;
  margin: 0 auto;
  width: 100%;
}
.IDranking .sliderBox {
  margin: 0 5px;
}
.IDreco_plan .slider {
display: flex;
  margin: 0 auto;
  width: 100%;
}
.IDreco_plan .sliderBox {
  margin: 0 5px;
}
	
.slide-arrow {
  bottom: 0;
  cursor: pointer;
  margin: auto;
  position: absolute;
  top: 0;
  width: 30px;
}
.prev-arrow {
  left: -40px;
}
.next-arrow {
  right: -40px;
}

/* ------------------------------------------
	location
------------------------------------------ */
.IDlocation{
position: relative;
background: #fff;
}
.IDlocation .slider{
display: flex;
justify-content: space-between;
}
.IDlocation .slider.ver_two{
width: 70%;
margin: 0 auto;
}

/*wave*/
.custom-shape-divider-top-1682026220 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1682026220 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 70px;
    transform: rotateY(180deg);
}
.custom-shape-divider-top-1682026220 .shape-fill {
    fill: #e1806e;
}

/*shape*/
.custom-shape-divider-bottom-1682006032 {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
    transform: rotate(180deg);
}
.custom-shape-divider-bottom-1682006032 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 241px;
    transform: rotateY(180deg);
}
.custom-shape-divider-bottom-1682006032 .shape-fill {
    fill: #e1806e;
}


/*locationBox*/
.locationBox{
display: flex;
flex-direction: column;
position: relative;
background: -moz-linear-gradient(top, #f0e6d7, #f7f2eb);
background: -webkit-gradient(linear, center top, center bottom, from(#f0e6d7), to(#f7f2eb));
border-top:solid 4px #e1806e;
/*max-width: 310px;*/
}
.locationBox h3 {
display: flex;
flex-direction: column;
text-align: center;
line-height: 1.2;
padding: 17px 0;
min-height: 110px;
}
.locationBox h3 .area_loca{
font-size: 24px;
font-weight: bold;
}
.locationBox h3 .read_loca{
font-size: 14px;
color: #999999;
letter-spacing: 2px;
}
.img_loca {
margin: 0 auto;
text-align: center;
width: calc(100% - 40px);
}
.img_loca img{
width: 100%;
max-width: 520px;
}
.txt_loca {
margin: 15px auto;
width: calc(100% - 40px);
max-width: 520px;
}
.planlist_loca{
margin: auto auto 0 auto;
width: calc(100% - 40px);
max-width: 520px;
}
.IDreco_plan .planlist_loca{
margin-bottom: 20px;
}
.planlist_loca .btn a{
width: calc(100% - 20px);
margin-top: 10px;
}
.link_area a{
position: relative;
display: flex;
justify-content: flex-end;
align-items: center;
margin: 10px auto 0 auto;
width: calc(100% - 40px);
max-width: 520px;
padding:5px 2em 20px 0;
text-decoration: underline;
}
.link_area a::after {
content: '';
position: absolute;
top:12px;
right:1em;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.link_area a:hover{
color:#e1806e !important;
text-decoration: underline;
}
.txt_fami{
/*margin: 40px auto 15px;*/
margin: 15px auto 40px;
font-size: 16px;
text-align: center;
}
.read_fami{
display: flex;
justify-content: center;
align-items: center;
margin-bottom: 20px;
font-size: 20px;
font-weight:500;
text-align: center;
}
.read_fami::before,
.read_fami::after {
	content: '';
	width: 20px;
	height: 4px;
	background-color: #e1806e;
}
.read_fami::before {
	margin-right: 20px;
}
.read_fami::after {
	margin-left: 20px;
}
.txt_fami p{
margin-bottom: 10px;
}
.deco_fami{
display: inline;
font-size: 18px;
background-image: linear-gradient(transparent 70%, #e1806e 70%);
}

/* ------------------------------------------
	search
------------------------------------------ */
.custom-shape-divider-top-1683555261 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1683555261 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 47px;
}
.custom-shape-divider-top-1683555261 .shape-fill {
    fill: #FFFFFF;
}
/*.IDsearch{
display: block;
background: url(../images/washi_bg.jpg) repeat;
}*/

/*slider*/
.IDsearch .slider {
display: flex;
  margin: 0 auto;
  width: 100%;
}
.IDsearch .slider2 {
display: flex;
  margin: 0 auto;
  width: calc(100% / 3 * 2);
}
.IDsearch .sliderBox {
  margin: 0 5px;
}
.head_search{
display: flex;
flex-direction: column;
align-items: center;
/*width: 940px;*/
margin: 20px auto;
padding: 0;
font-size: 20px;
font-weight: bold;
}
.head_search span{
margin-bottom: 5px;
padding: 0;
font-size: 38px;
color: #e1806e;
border-bottom: 2px solid #e1806e;
}
.read_search p{
text-align: center;
padding: 5px 0;
font-size: 1.1rem;
}
.deco_search{
display: inline;
background-image: linear-gradient(transparent 70%, #f0dc9b 70%);
margin: 0 1em;
}
.purpose{
display: flex;
justify-content: space-around;
margin: 30px 0;
gap: 40px;
}
.purpose p{
width: 100%;
font-size: 14px;
background: rgba(255,255,255,0.5);
}

/*cp_ipselect*/
.cp_ipselect {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap:15px;
margin-bottom: 50px;
}
.cp_selectlabel,
.cp_ipselect i,
.firstselect{
display: none !important;
}
.cp_ipselect label.option {
    display: flex;
    align-items: center;
    position: relative;
    padding: 8px 29px;
    border: 1px solid #e1806e;
    border-radius: 100vh;
    background-color: #fff;
    cursor: pointer;
	transition: 0.2s;
}
.cp_ipselect label.option:hover {
    background-color: #e1806e;
	color: #fff;
	transition: 0.2s;
}
.cp_ipselect label.option.theme:hover {
    background-color: transparent;
	color: #e1806e;
	transition: 0;
}
.cp_ipselect label.theme {
			width: 100%;
			margin: 30px 0 0 0;
    align-items: center;
    position: relative;
    padding: 8px 29px;
    border: none;
    border-radius: 0;
    background: transparent;
    cursor: default;
}
.cp_ipselect label.theme .cp_title{
margin: 0 auto;
width: 60%;
text-align: center;
font-size: 1.1rem;
color: #e1806e;
font-weight: bold;
background: rgba(255,255,255,0.7);
}
.cp_ipselect label:has(:checked) {
    background-color: #e1806e;
    color: #fff;
}
.cp_ipselect label::before,
.cp_ipselect label:has(:checked)::after {
    border-radius: 100vh;
    content: '';
}
.cp_ipselect label:has(:checked)::after {
    position: absolute;
    top: 50%;
    left: calc(7px + .7em);
    transform: translate(-50%, -50%);
    width: 7px;
    height: 7px;
    background-color: #e1806e;
}
.cp_ipselect input {
    display: none;
}
.cp_ipselect .thema{
display: block;
}

/*searchBox*/
.searchBox{
display: flex;
flex-direction: column;
position: relative;
background: #fff;
width: 100%;
/*min-width: 307px;
max-width: 310px;*/
padding-bottom: 20px;
}
.searchBox h3 {
display: flex;
flex-direction: column;
text-align: center;
line-height: 1.2;
padding: 17px 0;
}
.searchBox h3 .title_search{
font-size: 16px;
font-weight: bold;
}
.img_search {
margin: 0 auto;
text-align: center;
width: calc(100% - 40px);
}
.img_search img{
width: 100%;
max-width: 520px;
}
.txt_search {
margin: 15px auto;
width: calc(100% - 40px);
max-width: 520px;
}
.planlist_search{
margin: auto auto 0 auto;
width: calc(100% - 40px);
max-width: 520px;
}
.planlist_search .btn a{
width: calc(100% - 20px);
margin-top: 10px;
}
.recohotel{
width: calc(100% - 40px);
margin:30px auto 0 auto;
}
.read_recohotel{
display: flex;
justify-content: center;
align-items: center;
text-align: center;
margin-bottom: 5px;
font-size: 14px;
font-weight:500;
}
.read_recohotel::before,
.read_recohotel::after {
	content: '';
  flex-grow: 1;
	height: 1px;
	background-color: #000;
}
.read_recohotel::before {
	margin-right: 10px;
}
.read_recohotel::after {
	margin-left: 10px;
}
.recohotel ul{
display: flex;
flex-direction: column;
gap:0 1em;
}
.recohotel ul li{
}
.recohotel ul li a{
display: flex;
align-items: baseline;
margin: 5px 0;
padding:0;
text-decoration: underline;
}
.recohotel ul li a::before {
content: '';
width: 6px;
height: 6px;
margin-right: 5px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.recohotel ul li a:hover{
color:#e1806e !important;
text-decoration: underline;
}
.otherSearch{
display: flex;
justify-content: center;
margin:0 auto;
padding:20px 0;
width:940px;
}
.otherSearch li{
width:50%;
}
.otherSearch .btn a{
padding:15px 10px;
margin:20px auto;
}

/* ------------------------------------------
	feature article / tripa
------------------------------------------ */
.IDfeature,
#tripa{
display: block;
background: url(../images/washi_bg_gradation.jpg) repeat;
}
.IDfeature .slider .sliderBox,
#tripa .slider .sliderBox{
width: 24%;
background: #fff;
}
/*rowBox*/
.rowBox{
position: relative;
padding-top: 15px;
}
.img_rowbox {
margin: 0 auto;
text-align: center;
width: calc(100% - 30px);
}
.img_rowbox img{
width: 100%;
max-width: 240px;
height: 149px;
}
.read_rowbox {
margin: 10px auto;
width: calc(100% - 30px);
max-width: 240px;
font-weight: bold;
}
.txt_rowbox {
margin: 5px auto 15px auto;
width: calc(100% - 30px);
max-width: 240px;
}
.link_rowbox a{
position: relative;
display: flex;
justify-content: flex-end;
align-items: center;
margin: 10px auto 0 auto;
width: calc(100% - 40px);
max-width: 520px;
padding:5px 2em 20px 0;
text-decoration: underline;
}
.link_rowbox a::after {
content: '';
position: absolute;
top:12px;
right:1em;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.link_rowbox a:hover{
color:#e1806e !important;
text-decoration: underline;
}

/*slider*/
.IDfeature .slider,
#tripa .slider{
display: flex;
  margin: 0 auto;
  width: 100%;
}
.IDfeature .sliderBox,
#tripa .sliderBox{
  margin: 0 5px;
}
.slide-arrow {
  bottom: 0;
  cursor: pointer;
  margin: auto;
  position: absolute;
  top: 0;
  width: 30px;
}
.prev-arrow {
  left: -40px;
}
.next-arrow {
  right: -40px;
}

/* feature
------------------------------------------ */
.custom-shape-divider-top-1682027088 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1682027088 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 70px;
}
.custom-shape-divider-top-1682027088 .shape-fill {
    fill: #e0f6f9;
}

/* tripa
------------------------------------------ */
.custom-shape-divider-top-1682026116 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.custom-shape-divider-top-1682026116 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 70px;
    transform: rotateY(180deg);
}
.custom-shape-divider-top-1682026116 .shape-fill {
    fill: #E8F2F3;
}
.tripaBtn.btn a{
padding:15px 10px;
width:60%;
margin:50px auto 0 auto;
}
.tripaBtn.btn a:hover{
background:#fff;
color: #e1806e !important;
border:solid 1px #fff;
opacity: 1;
}
.tripaBtn.btn a:hover::after {
border-color: #e1806e;
}

/* ------------------------------------------
	faq
------------------------------------------ */
.IDfaq{
	display: block;
	background: url(../images/washi_bg.jpg) repeat;
}
.accordion {
    max-width: 1080px;
    background-color: #fff;
}
.accordion:not([open]) {
    margin-bottom: 2px;
}
.accordion summary {
    display: flex;
    align-items: center;
    position: relative;
    padding: 5px 2em;
    background-color: #b49b78;
    color: #fff;
    cursor: pointer;
}
.accordion summary::-webkit-details-marker {
    display: none;
}
.accordion summary::before {
content: 'Q';
color: #fff;
font-size: 38px;
margin-right: 25px;
}
.accordion summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid #fff;
    border-right: 3px solid #fff;
    content: '';
    transition: transform .3s;
    position: absolute;
    right:2em;
}
.accordion[open] summary::after {
    transform: rotate(225deg);
}
.accordion div {
display: flex;
align-items: center;
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    padding: 2em 2em 2em 2em;
    color: #000;
    transition: transform .5s, opacity .5s;
}
.accordion div::before {
content: 'A';
color: #b49b78;
font-size: 38px;
margin-right: 25px;
}
.accordion[open] div {
    transform: none;
    opacity: 1;
}

/* ------------------------------------------
	otherBtn
------------------------------------------ */
.otherBtn.btn a{
padding:15px 10px;
margin:20px auto;
}

/*------------------------------
scroll item
------------------------------*/
.scrollbox_wraper:not(.pc_no_slider) {position: relative;}
.scrollbox_wraper:not(.pc_no_slider) .scroll_left_btn,
.scrollbox_wraper:not(.pc_no_slider) .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:not(.pc_no_slider) .scroll_left_btn {left: -50px;}
.scrollbox_wraper:not(.pc_no_slider) .scroll_right_btn {right: -50px;}
.scrollbox_wraper:not(.pc_no_slider) .scroll_left_btn:after,
.scrollbox_wraper:not(.pc_no_slider) .scroll_right_btn:after,
.scrollbox_wraper:not(.pc_no_slider) .scroll_left_btn:before,
.scrollbox_wraper:not(.pc_no_slider) .scroll_right_btn:before {
    content: "";
    display: block;
    width: 0;
    height: 0;
}
.scrollbox_wraper:not(.pc_no_slider) .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:not(.pc_no_slider) .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:not(.pc_no_slider) .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:not(.pc_no_slider) .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:not(.pc_no_slider) .scroll_left_btn:after,
.scrollbox_wraper:not(.pc_no_slider) .scroll_right_btn:after,
.scrollbox_wraper:not(.pc_no_slider) .scroll_left_btn:before,
.scrollbox_wraper:not(.pc_no_slider) .scroll_right_btn:before {
	transition: 0.1s;
	border-color: #999;
}*/
.scrollbox_wraper:not(.pc_no_slider) .scroll_left_btn.non_scloll,
.scrollbox_wraper:not(.pc_no_slider) .scroll_right_btn.non_scloll {
	transition: 0.1s;
	display:none!important;
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox {
    overflow-x: scroll!important;
    overflow-y: hidden;
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox > ul > li.sliderBox {
	width: calc(1040px / 4) !important;
    margin: 0 5px !important;
	background: #fff;
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox > ul > li.sliderBox.linkbox {
	background: -moz-linear-gradient(top, #f0e6d7, #f7f2eb) !important;
	background: -webkit-gradient(linear, center top, center bottom, from(#f0e6d7), to(#f7f2eb));
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox .ItemBoxItem .ItemSetWrap {
	width: calc(1040px / 4) !important;
    margin: 0 5px !important;
/*	background: -moz-linear-gradient(top, #f0e6d7, #f7f2eb) !important;
	background: -webkit-gradient(linear, center top, center bottom, from(#f0e6d7), to(#f7f2eb));*/
}
.scrollbox_wraper.pc_no_slider .scrollbox > ul > li.sliderBox.divlink {
    width: calc(1040px / 4) !important;
    background: #FFF;
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox::-webkit-scrollbar {height: 5px!important;}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox::-webkit-scrollbar-track {
	margin: 0 5px !important;
	background: #eee !important;
	border-radius: 5px !important;
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox::-webkit-scrollbar-thumb {
	border-radius: 5px !important;
	background: #999 !important;
}

/* ------------------------------------------
	nav
------------------------------------------ */
nav.kaigai_daysNav ul{
position: relative;
display: flex;
flex-wrap:nowrap;
width: fit-content;
margin: 50px auto 30px;
}
nav.kaigai_daysNav ul li{
width: 150px;
margin-right: 10px;
}
nav.kaigai_daysNav ul li:last-child{
margin-right:0;
}
nav.kaigai_daysNav ul li a{
display:block;
position: relative;
padding: 18px 0 20px;
background: #fff;
border:solid 1px #333;
border-radius: 5px;
text-align: center;
color: #000;
}
nav.kaigai_daysNav ul li a::after{
content:'';
position: absolute;
left: 0;
right: 0;
bottom: 10px;
margin: 0 auto;
width: 6px;
height: 6px;
border-top: 2px solid #e1806e;
border-right: 2px solid #e1806e;
-webkit-transform: rotate(135deg);
transform: rotate(135deg);
}
nav.kaigai_daysNav ul li a:hover{
background: #e1806e;
border:solid 1px #e1806e;
color: #fff !important;
opacity: 100;
}
nav.kaigai_daysNav ul li a:hover::after{
border-color:#fff;
}

}

/*共通*/
.more_box.syutoken label,
.more_box.chubu label,
.more_box.hokuriku label,
.more_box.chugoku label {
    display: none;
}
.more_box.syutoken .more_area,
.more_box.chubu .more_area,
.more_box.hokuriku .more_area,
.more_box.chugoku .more_area {
    height: auto;
}

/* 点滅 */
.bnr_center640 span {
	-webkit-animation:blink .5s ease-in-out infinite alternate;
    -moz-animation:blink .5s ease-in-out infinite alternate;
    animation:blink .5s ease-in-out infinite alternate;
}
@-webkit-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@-moz-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
.bnr_center640 {
    margin-bottom: 2em;
    text-align: center;
}
.bnr_center640 span {
    display: block;
    margin: 0 auto;
    font-size: 16px;
    color: #FF6D00;
}
.bnr_center640 img {
    vertical-align: bottom;
}

/* ============================================================
add 20240409
============================================================ */
/* div.calendar
-------------------------------------------------------------*/
main div.calendar {
	margin-bottom: 40px;
}

main div.calendar + p.otherBtn.btn a::after {
	transform: rotate(135deg);
}

main div.calendar ol.month_btn {
	display: flex;
	justify-content: center;
	gap: 10px;
	margin: 10px 0 30px;
	border-bottom: solid 1px #e1806e;
}
main div.calendar ol.month_btn li {
	position: relative;
	bottom: -1px;
    width: 30%;
    text-align: center;
}
main div.calendar ol.month_btn p {
	display: block;
	padding: 2px 24px;
	border: solid 1px #e1806e;
	border-radius: 10px 10px 0 0;
	font-size: 16px;
	font-weight: bold;
}
main div.calendar ol.month_btn p.on,
main div.calendar ol.month_btn p:hover {
	background: #e1806e;
	color: #fff!important;
}
main div.calendar ol.month_btn p span {
	font-size: 36px;
	font-weight: bold;
}
/*
main div.calendar ol.month_tab {
	max-width: 0;
	max-height: 0;
	overflow: hidden;
	visibility: hidden;
	opacity: 0;
	transition: opacity .2s ease-in;
}
main div.calendar ol.month_tab.on {
	max-width: 100%;
	max-height: 100%;
	visibility: visible;
	opacity: 1;
}
*/
main div.calendar ol.month_tab {
	display: flex;
	justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 20px;
}
main div.calendar ol.month_tab > li {
	width: calc(100% / 6 - 10px);
	margin-bottom: 10px;
	border-radius: 10px;
	background: #FFF;
	border: solid 1px #e1806e;
}
main div.calendar ol.month_tab > li a {
	display: flex;
	justify-content: center;
	padding: 12px 0;
	font-size: 18px;
	font-size:clamp(12px, 1.54vw, 19.2px);
	line-height: 1;
}
main div.calendar ol.month_tab > li a:hover {
	background: #e1806e;
	color: #fff;
	border-radius: 8px;
}

main div.calendar ol.month_tab > li a span.month {
	font-weight: bold;
}
main div.calendar ol.month_tab > li a span.day {
	margin-left: -2px;
	font-size: 180%;
	font-weight: bold;
	letter-spacing: -0.04em;
}

main div.calendar ol.month_tab > li a span.weekday,
main div.calendar ol.month_tab > li a span.holiday {
	flex-shrink: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	top: 7px;
	width: 20px;
	height: 20px;
	margin-left: 2px;
	font-size: 70%;
	color: #fff;
	background: #b49b78;
	border-radius: 50%;
}
main div.calendar ol.month_tab > li a span.holiday {
	background: #e1806e;
}
main div.calendar ol.month_tab > li a:hover span.weekday,
main div.calendar ol.month_tab > li a:hover span.holiday {
	background: #fff;
    color: #e1806e;
}
main div.calendar ol.month_tab > li a span.holiday {
	background: #e1806e;
}


@media screen and (max-width: 900px) {
	main div.calendar ol.month_btn p {
		padding: 2px 12px;
	}
	main div.calendar ol.month_btn p span {
		font-size: 26px;
	}
	main div.calendar ol.month_tab {
		flex-wrap: wrap;
	}
	main div.calendar ol.month_tab > li a {
		justify-content: center;
		width: 14vw;
		font-size: 16px;
	}

}
@media screen and (max-width: 759.9px) {

main div.calendar ol.month_tab > li {
    width: calc(100% / 4 - 10px);
    margin-bottom: 10px;
}
main div.calendar ol.month_tab > li a{
    width: 100%;
}

}



/* ============================================================
add 202408
============================================================ */

/* ------------------------------------------
	common
------------------------------------------ */

.otoku_coupon h2 {
    text-align: center;
}
.otoku_coupon{
background: url("../images/washi_bg.jpg") repeat;
}
.bnz {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  line-height: 1;
}
.bnz::before,.bnz::after {
  width: 1px;
  height: 28px;
  content: "";
  background-color: #000;
}
.bnz::before {
  margin-right: 0.7em;
  transform: rotate(-30deg);
}
.bnz::after {
  margin-left: 0.7em;
  transform: rotate(30deg);
}

/* gadget tab */
.tab .tab_wrap {
	display: flex;
	flex-wrap: wrap;
}
.tab .tab_wrap .tab_label {
	position: relative;
	margin-right: 15px;
	padding: 7px 0;
	flex: 1;
	order: -1;
	border: 3px solid #b49b78;
	border-radius: 10px;
	background: #fff;
	transition: .5s;
	cursor: pointer;
	color: #b49b78;
	text-align: center;
	line-height: 1.2;
}
.tab .tab_wrap .tab_label:hover {
	background: #b49b78;
	color: #fff;
}
.tab .tab_wrap .tab_label:hover::after {
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
    position: absolute;
	pointer-events: none;
	border-color: rgba(136, 183, 213, 0);
	border-top-color: #b49b78;
	border-width: 14px;
	margin-left: -14px;
}
.tab .tab_wrap .tab_label:nth-last-of-type(1){ margin-right: 0; }
.tab .tab_wrap > input {
	display: none;
}
.tab .tab_wrap .tab_content {
	width: 100%;
	height: 0;
	/*overflow: hidden;*/
	opacity: 0;
}
.tab .tab_wrap > input:checked + .tab_label {
	background: #b49b78;
	color: #fff;
}
.tab .tab_wrap > input:checked + .tab_label::after { /* ▼ */
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
    position: absolute;
	pointer-events: none;
	border-color: rgba(136, 183, 213, 0);
	border-top-color: #b49b78;
	border-width: 14px;
	margin-left: -14px;
}
.tab .tab_wrap > input:checked + .tab_label + .tab_content {
	padding: 0;
	height: auto;
	/*overflow: auto;*/ /* 場合によっては復活させる */
	transition: .5s opacity;
	opacity: 1;
}

/*#contact{
background: url(../images/washi_bg_gradation.jpg) repeat;
}*/

/*  pc ====== */
@media screen and (min-width: 760px),print {
.scrollbox.float_link_padding {padding-top: 15px;}
.IDnewyear .commonBnr > li {
	background: #FFF;
	margin: 1%;
}
.IDnewyear .commonBnr > li,
.IDnewyear .floatlink{transition: 0.2s;}
.IDnewyear .commonBnr > li:hover,
.IDnewyear .floatlink:hover {
	transition: all 0.3s ease-in-out;
	scale: 1.05;
	box-shadow: 0px 2px 16px rgba(0, 0, 0, 0.25);
}
.otoku_coupon h2 {
    font-size: 38px;
}
.otoku_coupon h2 span{
display: block;
font-size: 20px;
}
.bnz {
    font-size: 20px;
}
.mgTBB {
    margin: 50px 0;
}
.mtB {
    margin-top: 50px !important;
}

/* gadget tab */
.tab .tab_wrap .tab_label {
	font-size: 28px;
}
.tab .tab_wrap > input:checked + .tab_label + .tab_content {
	margin: 35px 0 0;
}


/* contact */
#contact p.txt {
	width: 500px;
    font-size: 18px;
    margin: 0 auto 25px;
    background: #b49b78;
    padding: 20px;
    border-radius: 10px;
    color: #fff;
    text-align: center;
	position:relative;
}
#contact p.txt:after {
	content: "";
    position: absolute;
    top: 98%;
    left: 50%;
    margin-left: -10px;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-top: 15px solid #b49b78;
}
#contact .contactWrap,
#contact .contactWrap a{
	display: flex;
	padding: 15px 5px;
}
#contact .contactWrap li{
	width: calc(94% / 3);
    background: #FFF;
    border-radius: 10px;
    margin: 0 1%;
}
#contact .contactWrap img{width: 80px;}
#contact .contactWrap p{
	display: grid;
    align-items: center;
    color: #222;
    font-size: 16px;
    font-weight: bold;
}
#contact .contactWrap p small{font-weight: normal;}



}

/*  sp ====== */
@media screen and (max-width: 759.9px) {
.IDnewyear .commonBnr > li {
	background: #FFF;
	margin: 1%;
}
.IDnewyear .commonBnr > li{transition: 0.2s;}
.IDnewyear .commonBnr > li:hover {
	transition: all 0.3s ease-in-out;
	scale: 1.05;
	box-shadow: 0px 2px 16px rgba(0, 0, 0, 0.25);
}
.otoku_coupon h2 {
    margin-bottom: 20px;
    font-size: 1.8rem;
}
.otoku_coupon h2 span{
display: block;
font-size: 1rem;
}
.bnz {
    margin: 15px 0 0;
    font-size: 1rem;
}
.mgTBB {
    margin: 30px 0;
}
.mtB {
    margin-top: 70px !important;
}

/* gadget tab */
.tab .tab_wrap .tab_label {
	font-size: 18px;
}
.tab .tab_wrap .tab_content {
	overflow: hidden;
}
.tab .tab_wrap > input:checked + .tab_label + .tab_content {
	margin: 15px 0 0;
}


/* contact */
#contact p.txt {
	width: 72%;
    font-size: 16px;
    margin: 0 auto 35px;
    background: #b49b78;
    padding: 10px;
    border-radius: 10px;
    color: #fff;
    text-align: center;
    position: relative;
}
#contact p.txt:after {
	content: "";
    position: absolute;
    top: 98%;
    left: 50%;
    margin-left: -10px;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-top: 15px solid #b49b78;
}
#contact .contactWrap a{
	display: flex;
	padding: 15px 5px;
}
#contact .contactWrap li {
    width: 90%;
    background: #FFF;
    border-radius: 10px;
    margin: 0 auto 15px;
}
#contact .contactWrap img{width: 64px;}
#contact .contactWrap p{
	display: grid;
    align-items: center;
    color: #222;
    font-size: 14px;
    font-weight: bold;
}
#contact .contactWrap p small{font-weight: normal;}

}



/* ------------------------------------------
	sogo kaigai
------------------------------------------ */

.calendar ol.month_tab.mouseOnLink li {
	position: relative;
    cursor: pointer;
}
.calendar ol.month_tab.mouseOnLink li:hover > a{
	background: #e1806e;
	color: #fff;
	border-radius: 8px;
}
.calendar ol.month_tab.mouseOnLink li:hover a span.weekday,
.calendar ol.month_tab.mouseOnLink li:hover a span.holiday{
    background: #fff;
    color: #e1806e;
}
.calendar ol.month_tab.mouseOnLink li > a {
	pointer-events: none;
}
.calendar ol.month_tab.mouseOnLink li ul {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	z-index: 4;
	padding: 10px 20px;
	border-radius: 5px;
	background: rgba(0, 0, 0, 0.7);
	visibility: hidden;
	opacity: 0;
	transition: all .2s ease-in;

    display: block;
    width: 15em;
}
.calendar ol.month_tab.mouseOnLink li:hover ul {
	visibility: visible;
	opacity: 1;
    z-index: 4;
    
    display: block;
    width: 15em;
    margin-top: 5px;
}
.calendar ol.month_tab.mouseOnLink li:hover ul li {
    width: 100%;
    margin-bottom: 10px;
}
.calendar ol.month_tab.mouseOnLink li:hover ul li:last-child {
    margin-bottom: 0;
}
.calendar ol.month_tab.mouseOnLink li ul a,
.calendar ol.month_tab.mouseOnLink li:hover ul a {
	display: block;
	padding: 6px 2em 6px 0;
	font-size: 16px;
	line-height: 1;
	border: none;
	border-radius: 0;
    background: rgba(0, 0, 0, 0);
	position: relative;
	white-space: nowrap;
	color: #fff;
    pointer-events: auto;
}
.calendar ol.month_tab.mouseOnLink li:hover ul a:hover {
    background: rgba(0, 0, 0, 0);
	color: #e1806e;
}
.calendar ol.month_tab.mouseOnLink li:hover ul::before {
	content: '';
	position: absolute;
	top: -9px;
	left: calc(50% - 6px);
	background: rgba(0, 0, 0, 0.7);
	height: calc(tan(60deg) * 12px / 2);
	width: 12px;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}
.calendar ol.month_tab.mouseOnLink li:hover ul a::after {
	content: '';
	position: absolute;
	top: 0.6em;
	right: 0;
	width: 7px;
	height: 7px;
	border-top: solid 2px #fff;
	border-left: solid 2px #fff;
	transform: rotate(135deg);
}
.calendar ol.month_tab.mouseOnLink li:hover ul a:hover::after {
	border-top: solid 2px #e1806e;
	border-left: solid 2px #e1806e;
}
.SectionBanner {
    text-align: center;
}

.ItemBoxItem {
    display: flex;
    justify-content: space-between;
}
.ItemSection .ItemBox .ItemBoxContent .ItemBoxContentInner .ItemBoxItemWrap {
    padding: 0 !important;
    background-color: initial!important;
}
.IDkaigai_area .ItemSection .ItemBox .ItemBoxContent .ItemBoxContentInner .ItemBoxItemWrap .ItemBoxItem {
    max-width: fit-content !important;
}

/* gadjet */
.search_kaigaiBar .serchBox.kaigaiS .serchBox {
    border: 8px solid #3DBA00 !important;
    border-radius: 0 !important;;
}

/* DP */
.ItemSection .ItemIntroductionWrap .ItemIntroductionLine .ItemIntroductionSet .ItemIntroductionBox {
    width: 110px !important;
    min-width: auto !important;
    padding: 1em 0.5em !important;
}
.ItemSection .ItemIntroductionWrap {
    max-width: 100% !important;
    padding: 0 !important;
}
.ItemSection .ItemIntroductionWrap .ItemIntroductionLine .ItemIntroductionSet .ItemIntroductionBox .ItemIntroductionName {
    font-size: 0.9rem !important;
}
/*.ItemSection .ItemBox .ItemBoxContent .ItemBoxContentInner .ItemBoxItemWrap .ItemBoxItem .ItemSetWrap a .ItemSubTitle {
    top: auto !important;
}
.kaigai_days_choice .ItemSection .ItemBox .ItemBoxContent .ItemBoxContentInner .ItemBoxItemWrap .ItemBoxItem .ItemSetWrap a .ItemSubTitle {
    top: 0.9rem !important;
}*/
/*.ItemSection .ItemBox .ItemBoxContent .ItemBoxContentInner .ItemBoxItemWrap .ItemBoxItem .ItemSetWrap a .ItemSet .ItemCard .ItemCardText{
    display: none !important;
}*/
.kaigai_days_choice h5 {
	text-align: center;
    font-size: 20px;
    font-weight: bold;
    margin: 25px 0;
}


/*  sp ====== */
@media screen and (max-width: 759.9px) {

.calendar ol.month_tab.mouseOnLink li ul {
    width: calc(200% + 1.75em);
    left: 0;
	transform: translateX(0);
}
.calendar ol.month_tab.mouseOnLink li:hover ul {
    width: calc(200% + 1.75em);
}
.calendar ol.month_tab.mouseOnLink li:hover ul::before {
	left: 15%;
}
.calendar ol.month_tab.mouseOnLink li:nth-child(4n + 1) ul {
    left: 65%;
	transform: translateX(-50px);
}
.calendar ol.month_tab.mouseOnLink li:nth-child(4n + 3) ul {
	transform: translateX(-100px);
}
.calendar ol.month_tab.mouseOnLink li:nth-child(4n + 3):hover ul::before {
    left: 70%;
}
.calendar ol.month_tab.mouseOnLink li:nth-child(4n + 4) ul {
    left: auto;
    right: -62%;
	transform: translateX(-50px);
}
.calendar ol.month_tab.mouseOnLink li:nth-child(4n + 4):hover ul::before {
    left: auto;
    right: 15%;
}

.SectionContent {
    width: fit-content !important;
    padding: 0 0 20px !important;
}

/* gadjet */
.search_kaigaiBar .serchBox.kaigaiS .serchBox {
    border: 3px solid #3DBA00 !important;
}

/* DP */
.ItemSection .ItemIntroductionWrap .ItemIntroductionLine .ItemIntroductionSet .ItemIntroductionBox .ItemIntroductionName {
    font-size: 0.75rem !important;
}
/*.kaigai_days_choice .ItemSection .ItemBox .ItemBoxContent .ItemBoxContentInner .ItemBoxItemWrap .ItemBoxItem .ItemSetWrap a .ItemTitle {
    padding-right: 6rem !important;
}*/

}


@media (min-width: 760px) and (max-width: 900px){
/*------------------------------
for Tablet
------------------------------*/
.scrollbox_wraper:not(.pc_no_slider) .scrollbox {
	overflow-x: scroll!important;
	padding: 0;
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox > ul > li,
.scrollbox_wraper:not(.pc_no_slider) .scrollbox .ItemBoxItem .ItemSetWrap {
	width: 270px !important;
    margin: 0 5px;
	background: #fff;
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox::-webkit-scrollbar {height: 5px!important;}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox::-webkit-scrollbar-track {
	margin: 0 5px!important;
	background: #eee!important;
	border-radius: 5px!important;
}
.scrollbox_wraper:not(.pc_no_slider) .scrollbox::-webkit-scrollbar-thumb {
	border-radius: 5px!important;
	background: #999!important;
}

}

@media (min-width: 740px) and (max-width: 900px){
/*------------------------------
newyearNav
------------------------------*/
nav.newyearNav.indexNav ul,
nav.newyearNav.syutokenNav ul,
nav.newyearNav.chubuNav ul,
nav.newyearNav.hokurikuNav ul,
nav.newyearNav.kansaiNav ul,
nav.newyearNav.chugokuNav ul,
nav.newyearNav.kyushuNav ul{
/*margin-top: 90px;*/
width: 65%;
}
nav.newyearNav ul {
    width: 100%;
    /*justify-content: space-between;*/
}
nav.newyearNav ul li {
    width: 31%;
}
nav.newyearNav.commonNav ul {
    width: 100%;
}
nav.newyearNav.commonNav ul li {
    width: calc(97% / 4);
}
nav.newyearNav.commonNav ul li .selectbox select,
nav.newyearNav.commonNav ul li .selectbox {
    min-width: 100%;
    width: 100%;
}

}

/* ============================================================
gadget
============================================================ */
/*海外*/
:root {
	--gadget-accent-color: #bc3c02;
	--gadget-noactive-color: #EADADB;
	--gadget-botton-color: #e1806e;
}
.search_kaigaiBar {
	width: 100%;
	display: block;
	margin: 2% 0;
}
.search_kaigaiBar .serchBox.kaigaiS > ul {border-bottom: 2px solid var(--gadget-accent-color);}
.search_kaigaiBar .serchBox.kaigaiS > ul li.select {
	color: #FFF;
	background: var(--gadget-accent-color);
}
.search_kaigaiBar .serchBox.kaigaiS > ul li {
	color: #222;
	background: var(--gadget-noactive-color);
}
.search_kaigaiBar .serchBox.kaigaiS .serchBox {border: none!important;}
.btnSeach01,
.search_kaigaiBar button.btnSeach,
.search_kaigaiBar p.btnSeach a {
	-webkit-box-shadow: 0 -1px 0 var(--gadget-botton-color) inset;
	-moz-box-shadow: 0 -1px 0 var(--gadget-botton-color) inset;
	box-shadow: 0 -1px 0 var(--gadget-botton-color) inset;
	border: 1px solid var(--gadget-botton-color);
	background-color: var(--gadget-botton-color);

	background: url(/shared2015/common/images/ic_search_01.png) no-repeat var(--gadget-botton-color) 97% 50%;
	padding: 0.5rem;
	font-size: 1.25rem;
	max-width: 480px;
	margin: 0 auto;
	border-radius: 0.5rem;
}

/*202411015*/
.ItemBoxItem .ItemCardImage > div {
    max-height: 150px;
    overflow: hidden;
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}
@media screen and (max-width: 759.9px) {
	.ItemBoxItem .ItemCardImage > div {max-height: 130px;}
}
.ItemBoxItem .ItemCardText .ItemCardSubText {
	/*height: 106px;*/
	padding: 0 10px;
	display: -webkit-box; /* 必須 */
	-webkit-box-orient: vertical; /* 必須 */
	-webkit-line-clamp: 5; /* 行数を制限 */
	overflow: hidden; /* はみ出た部分を非表示 */
}
.ItemSection .ItemBox .ItemBoxContent .ItemBoxContentInner .ItemBoxItemWrap .ItemBoxItem .ItemSetWrap {
    width: calc(1040px / 4);
    margin: 0 5px;
}