@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,700;1,700&display=swap');

/* ==================================================
   nav
================================================== */
.nav {
    background-color: #5d5c5c;
}
.fixed {
	position: fixed;
	width: 100%;
	top: 0;
	z-index: 1000;
}
.c-list {
    display: flex;
	text-align: center;
}
.c-item {
    flex-grow: 1;
    border-right: solid 1px #bbb9b9;
}
.c-item a {
    color: #FFF;
	position: relative;
    display: block;
}
.right_item {
    border-right: none;
}
.c-item span {
	position: relative;
	z-index: 3;
}

@media screen and (min-width:768px){
/* ==================================================
   ページ共通
================================================== */
.contents-wrapper{
	border-bottom: solid 1px #ccc;
	background: url("/kokunai/promotion/theme/kani/_images/bg01.png") no-repeat center #f9f7ef;
	background-size: cover;
	background-attachment: fixed;
}

/* ==================================================
   h1　見出し
================================================== */
.page-title-h1{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
}
.head-wrap__title span{
	display: block;
	font-size: 1.6rem;
}

/* ==================================================
   キービジュアル
================================================== */
.mv{
	min-width: 970px;
	background: url("/kokunai/promotion/theme/kani/_images/mv_bg.jpg") no-repeat center;
	background-size: cover;
}
.mv__inner{
	position: relative;
	margin: 0 auto;
	width: 100%;
	max-width: 1246px;
	min-width: 970px;
	height: 450px;
}
.mv__inner img{
	position: relative;
	z-index: 1;
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
.mv__txt{
	position: absolute;
	left: 0;
	bottom: 0;
	padding: 15px 60px;
	width: 670px;
	font-family: 'Noto Serif JP', serif;
	background: url("/kokunai/promotion/theme/kani/_images/mv_bgtxt.png") no-repeat center;
}
.mv__txt dt{
	color: #e8c107;
	font-size: 2.2rem;
	font-weight: bold;
}
.mv__txt dd{
	color: #fff;
	font-weight: 700;
}

/* ==================================================
   nav
================================================== */
.sp-nav {
    display: none;
}
.c-inner {
    margin: 0 auto;
    max-width: 1236px;
    width: 88%;
	position: relative;
}
.c-item a::before {
    position: absolute;
    top: 0;
    left: 0;
    content: '';
    z-index: 2;
    width: 100%;
    height: 0;
    background: #555;
    transition: .3s cubic-bezier(0.8, 0, 0.2, 1) 0s;
}
.c-item a:hover:before{
	height: 100%;  
	background-color: #444;
}
.c-item a {
    color: #FFF;
	position: relative;
    display: block;
	padding: .8em 0;
}
/* ==================================================
   information
================================================== */
.information{
	padding: 30px 0;
	background: #fafafa;
}
.information__inner{
	margin: 0 auto;
	padding: 0 5px;
	width: 100%;
	min-width: 970px;
	max-width: 1246px;
}
.c-keyword__list{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	padding: 40px 40px 20px;
	justify-content: center;
}
.c-keyword__list a{
	display: inline-block;
	padding: 5px 20px;
	color: #f59000;
	border: solid 2px #ff9900;
	transition: all 0.4s;
	border-radius: 20px;
	margin: 0 5px 5px 5px;
}
.c-keyword__list a:hover{
	opacity: .6;
}

/* ==================================================
   コンテンツ
================================================== */
.page-title-h2,.page-title-h3{
	text-align: center;
}
.page-title-h2{
	position: relative;
	font-size: 3.0rem;
	font-family: 'Noto Serif JP', serif;
	line-height: 1.0;
}
.page-title-h2 em{
	position: relative;
	font-weight: 700;
}
.page-title-h2 em:before{
	position: absolute;
	left: -91px;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	transform: translateY(-50%);
	content: "";
	display: block;
	width: 67px;
	height: 54px;
	background: url("/kokunai/promotion/theme/kani/_images/title_kani.png") no-repeat 0 0;

}
.page-title-h2 span{
	display: inline-block;
	font-size: 1.6rem;
}
.page-title-h2 span:before,
.page-title-h2 span:after{
	margin: 0 5px;
	content: "－";
}
.sect-txt{
	margin-top: 25px;
	text-align: center;
}
/*  特別企画
============================================================================= */
.recommendplan-sect {
    padding-top: 50px;
    border-top: solid 1px #ccc;
}
.recommendplan-sect .in-wrapper{
	margin-top: 25px;
}
.pc-none{
    display: none;
}
.recommendplan-sect__cassette{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 0 0 0 -25px;
}
.recommendplan-sect__cassette > li{
	margin: 25px 0 0 25px;
	padding: 25px 40px;
	width: calc(100% / 2 - 25px);
	background: #fff;
}
.recommendplan-sect__cassette dt{
	font-size: 2.5rem;
	font-weight: bolder;
}
.recommendplan-sect__cassette dd{
	margin-top: 15px;
}
.recommendplan-sect__cassette img{
	width: 100%;
	height: auto;
	vertical-align: bottom;
}
figure {
    position: relative;
    margin: 0;
}
span.label {
    position: absolute;
    color: white;
    background: red;
    padding: 30px 190px;
}
span.full_bnr {
    left: 15px;
    top: 150px;
    font-size: 28px;
    transform: rotate(-20deg);
}
figcaption {
    text-align: end;
    font-size: 13px;
    padding-top: 5px;
}
p.date {
    font-size: 25px;
    font-weight: 500;
    text-align: center;
    background: #f59000;
    padding: 5px;
    margin: 0px 300px 10px 0px;
}
p.area {
    font-weight: 500;
}
p.recommendplan-sect__cassette-title {
    background: #f59000;
    margin-top: 10px;
    padding: 5px;
    font-size: 20px;
    text-align: center;
    color: white;
}
ul.cassette-txt {
    padding: 10px;
    border: 1px solid;
    border-top: transparent;
}
.cassette-txt li {
    padding: 2px;
}
p.info {
    text-align: end;
    padding: 5px;
}
p.info a {
    text-decoration: underline;
}

/* おすすめホテル */
.sec-yado .block { margin-bottom: 70px; }
.sec-yado .yado-titleblock { text-align: center; margin-top: 3em; }
.sec-yado .c-title { position: relative; display: inline-block; padding: 0 55px; font-family: 'Noto Serif JP', serif; font-weight: bold; font-size: 2rem; }
.sec-yado .c-title:before, .sec-yado .c-title:after { position: absolute; content: ''; top: 50%; display: inline-block; background-color: #323743; }
.sec-yado .yado-img {  width: 100%; height: 10em; object-fit: cover; padding: 4px; border-radius: 10px; display: block; }
.sec-yado .yado-img-small { display: flex; padding: 0 5px; column-gap: 4px; }
.sec-yado .yado-img-small figure { width: calc(100% / 2); height: 6em; }
.sec-yado .c-pic figcaption { color: #fff; background-color: #323743; padding: 0 .8em; position: absolute; right: .8rem; bottom: .5rem; font-size: 1rem; }
.sec-yado .yado-img-small img { width: 100%; height: 6em; object-fit: cover; border-radius: 4px; }
.sec-yado .hotel-item .c-txt { display: flex; flex-direction: column; padding: 8px; flex-grow: 1; }
.sec-yado .c-txt small { font-weight: 600; color: #873535; }
.sec-yado .hotel-item p { margin: 15px 0 5px; flex-grow: 1; }
.sec-yado .c-bottom__btn.c-flex { display: flex; justify-content: center; }
.sec-yado .c-bottom__btn .c-btn { height: 3.375em; }
.sec-yado .yado-sect__more { text-align: center; position: relative; font-weight: 700; margin-top: 32px; }
.sec-yado .yado-sect__more span { color: #873535; }
.sec-yado .yado-sect__more span::after { position: absolute; display: block; content: ""; border-bottom: 2px solid #db5858; border-right: 3.5px solid #db5858; transform: skew(40deg); height: 10px; margin-top: -5px; left: 0px; right: 0px; margin-left: auto; margin-right: auto; }
.sec-yado .yado-sect__more a:hover { opacity: .6; }
.sec-yado .hotel-cassette_bt { display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%; }
.sec-yado .hotel-cassette_bt-item a { position: relative; display: flex; justify-content: center; align-items: center; padding: 5px 5px; min-height: 50px; text-align: center; font-size: 1.2rem; color: #fff; letter-spacing: 0; line-height: 1.3; border-radius: 5px; }
.sec-yado .hotel-cassette_bt-item.-hotel a { border: solid 1px #db5858; background: #db5858; }
.sec-yado .hotel-cassette_bt-item.-jr a { border: solid 1px #f59000; background: #f59000; }
.sec-yado .hotel-cassette_bt-item.-air a { border: solid 1px #60a8d6; background: #60a8d6; }
.sec-yado .hotel-cassette_bt-item { margin-top: 5px; width: calc(100% / 2 - 2px); }
.sec-yado .hotel-cassette_bt-item.-hotel a:before { content: "\ea40"; }
.sec-yado .hotel-cassette_bt-item.-jr a:before { content: "\e570"; }
.sec-yado .hotel-cassette_bt-item.-air a:before { content: "\e539"; }
.sec-yado .hotel-cassette_bt-item.-jr a:hover { border: solid 1px #f59000; background: #f59000; }
.sec-yado .hotel-cassette_bt-item.-air a:hover { border: solid 1px #60a8d6; background: #60a8d6; }
.sec-yado .hotel-cassette_bt-item a:before { margin-right: 5px; font-family: 'Material Icons Round'; font-size: 2.0rem; color: #fff; line-height: 1; }
.sec-yado .hotel-cassette_bt-item em { display: block; font-size: 1.2rem; font-weight: bold; }
.sec-yado .hotel-cassette_bt-item a:after { position: absolute; right: 0; top: 50%; transform: translateY(-50%); display: inline-block; font-family: 'Material Icons Round'; content: "\e5cc"; font-size: 2.0rem; }
.sec-yado .hotel-cassette_bt-item span { padding-right: 8px; }
.sec-yado .hotel-title { font-size: 2rem; }
.sec-yado .c-title:before { width: 40px; height: 2px; left: 0; }
.sec-yado .c-title:after { width: 40px; height: 2px; right: 0; }
.sec-yado .hotel-list { display: flex; justify-content: space-between; flex-wrap: wrap; text-align: left; }
.sec-yado .hotel-item { display: flex; flex-direction: column; width: calc(calc(100% - 3em) / 3); margin: 20px 0 20px 0; background: #fff; box-shadow: 0 1px 3px rgb(0 0 0 / 20%); border-radius: 4px; }
.sec-yado .hotel-item .c-pic { text-align: end; }
.sec-yado .hotel-item a::before { background: none; }
.sec-yado .hotel-item a:hover { opacity: .6; transition: .4s; }
.sec-yado .c-bottom__btn .c-btn { width: calc(100% - .375em); }
.sec-yado .c-btn__plan .c-bnt__float { width: auto; }
.sec-yado .hotel-cassette_bt-item a:hover { border: solid 1px #ad4a4a; background: #ad4a4a; }
.sec-yado .yado-sect__more span::after { width: 28%; }
.sec-yado .carousel { overflow-x: hidden; }

/*  人気エリアから探す
============================================================================= */
.popularspot-sect {
    padding: 100px 0;
}
.popularspot-sect .in-wrapper{
	margin-top: 25px;
}
.popularspot-sect__cassette{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: space-between;
}
.popularspot-sect__cassette > li{
	padding: 10px;
	width: calc(100% / 4 - 5px);
	background: #fff;
}
.popularspot-sect__cassette dt{
	font-size: 2.5rem;
	font-weight: 700;
	font-family: 'Noto Serif JP', serif;
	text-align: center;
	letter-spacing: .5em;
}
.popularspot-sect__cassette dd{
	margin-top: 15px;
}
.popularspot-sect__cassette img{
	width: 100%;
	height: auto;
	vertical-align: bottom;
}
#area .popularspot-sect__cassette-txt{
	margin-top: 15px;
	height: 180px;
}
#brand .popularspot-sect__cassette-txt{
	margin-top: 15px;
	height: 120px;
}
.popularspot-sect__cassette-bt{
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        flex-direction: column;
}
.popularspot-sect__cassette-bt li{
	width: 100%;
	border-radius: 8px;
	background: #fff;
}
.popularspot-sect__cassette-bt li a{
    position: relative;
    display: block;
    padding: 15px 30px;
    margin: 3px;
    color: #fff;
    text-align: center;
    line-height: 1;
    font-size: 1.6rem;
    font-weight: 700;
    border-radius: 8px;
    transition: opacity .2s;
}
.popularspot-sect__cassette-bt li a:hover{
	opacity: .6;
}
.popularspot-sect__cassette-bt li a:before,
.popularspot-sect__cassette-bt li a:after{
	position: absolute;
	top: 50%;
	margin-top: -.5em;
    transition: .2s;
    
	font-family: 'kkrs-dp' !important;
	text-decoration: none;
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.popularspot-sect__cassette-bt li a:before{
	left: 10px;
	font-size: 1.8rem;
}
.popularspot-sect__cassette-bt-htl a:before{ content: "\e960"; }
.popularspot-sect__cassette-bt-jr a:before{ content: "\e969"; }
.popularspot-sect__cassette-bt-air a:before{ content: "\e918"; }

.popularspot-sect__cassette-bt li a:after{
	right: 8px;
	content: "\e902";
}
.popularspot-sect__cassette-bt-htl a{ background: #db5858; }
.popularspot-sect__cassette-bt-jr a{ background: #f59000; }
.popularspot-sect__cassette-bt-air a{ background: #60a8d6; }

.popularspot-sect__cassette-bt li em{
	display: block;
	font-size: 1.6rem;
	font-weight: 700;
}
.popularspot-sect__bt{
	margin: 30px auto -20px;
	width: 600px;
	border-radius: 35px;
	background: #fff;
}
.popularspot-sect__bt a{
	position: relative;
	display: block;
	padding: 20px 15px;
	color: #fff;
	font-weight: 700;
	text-align: center;
	line-height: 1.1;
	background: #5d5c5c;
	border-radius: 8px;
	transition: opacity .2s;
}
.popularspot-sect__bt a:before{
	position: absolute;
	right: 25px;
	top: 50%;
	margin-top: -.5em;
    transition: .2s;
    
	font-family: 'kkrs-dp' !important;
	content: "\e902";
	text-decoration: none;
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.popularspot-sect__bt a:hover{
	opacity: .6;
}
.popularspot-sect__bt em{
	font-size: 1.8rem;
	font-weight: 700;
}
.popularspot-sect__bt span{
	display: inline-block;
	font-size: 1.2rem;
}
.popularspot-sect__bt span:before,
.popularspot-sect__bt span:after{
	margin: 0 5px;
	content: "－";
}

/*  地図・人気温泉地から探す
============================================================================= */
.map-sect{
	padding-top: 50px;
	border-top: solid 1px #ccc;
}
.map-sect .in-wrapper{
	margin-top: -50px;
}
.map-sect__box{
	margin: 0 auto;
	width: 950px;
}
.map-sect__box-list{
	position: relative;
	padding-top: calc(559 / 950 * 100%);
	background: url("/kokunai/promotion/theme/kani/_images/map.png") no-repeat 0 0;
	background-size: 100% auto;
}
.map-sect__box-list li{
	position: absolute;
	-webkit-transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	-o-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	border-radius: 8px;
	background: #fff;
}
.map-sect__box-list li.-circle{
	border-radius: 50%;
	width: 100px;
	height: 100px;
}
.map-sect__box-list li a{
	display: block;
	padding: 10px 30px 10px 10px;
	color: #fff;
	font-weight: 700;
	white-space: nowrap;
	border-radius: 8px;
	transition: opacity .2s;
}
.map-sect__box-list li.-circle a{
	padding: 32px 10px 10px 10px;
	border-radius: 50%;
	width: 100px;
	height: 100px;
	text-align: center;
}
.map-sect__box-list li a:before{
	position: absolute;
	top: 50%;
	right: 8px;
	margin-top: -.5em;
	transition: .2s;
	font-family: 'kkrs-dp' !important;
	text-decoration: none;
	content: "\e903";
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.map-sect__box-list li.-circle a:before{
	content:none
}
.map-sect__box-list li.-circle a span{
	margin-top: 20px;
}
.map-sect__box-list li.-circle a:after{
	position: absolute;
	bottom: 16px;
	left: calc(50% - 0.5rem);
	margin-top: -.5em;
	transition: .2s;
	font-family: 'kkrs-dp' !important;
	text-decoration: none;
	content: "\e903";
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.map-sect__box-list li a:hover{
	opacity: .6;
}
.map-sect__box-list li.map-hokuriku a{ background: #f59000; }
.map-sect__box-list li.map-kinki a{ background: #f14e17; }
.map-sect__box-list li.map-chugoku a{ background: #fd3175; }
.map-sect__box-list li:first-child{ left: 69.26%; top: 29.79%; }
.map-sect__box-list li:nth-child(2){ left: 88.26%; top: 25.79%; }
.map-sect__box-list li:nth-child(3){ left: 87.05%; top: 42.93%; }
.map-sect__box-list li:nth-child(4){ left: 79.57%; top: 53.34%; }
.map-sect__box-list li:nth-child(5){ left: 68.42%; top: 78.89%; }
.map-sect__box-list li:nth-child(6){ left: 48.15%; top: 40.22%; }
.map-sect__box-list li:nth-child(7){ left: 60.15%; top: 64.22%; }
.map-sect__box-list li:nth-child(8){ left: 52.73%; top: 85.82%; }
.map-sect__box-list li:nth-child(9){ left: 37.57%; top: 55.74%; }
.map-sect__box-list li:nth-child(10){ left: 29.15%; top: 66.01%; }
.map-sect__box-list li:nth-child(11){ left: 39.10%; top: 77.20%; }
.map-sect__box-list li:nth-child(12){ left: 6.50%; top: 64.50%; }
.map-sect__box-list li:nth-child(13){ left: 34.73%; top: 87.65%; }
.map-sect__box-list li:nth-child(14){ left: 20.63%; top: 87.65%; }
.map-sect__box-list li:nth-child(15){ left: 17.57%; top: 54.91%; }
.map-sect__box-list li:nth-child(16){ left: 6.94%; top: 79.60%; }

/* パネル */
.map-panel{
	display: none;
	position: absolute;
	width: 280px;
	margin-top: -5px;
	padding-top: 10px;
}
.map-panel__wrapper{
	position: relative;
	padding: 15px;
	border: solid 1px #ccc;
	background: #fff;
}
.map-panel__wrapper:before {
	top: -9px;
	border-color: transparent transparent #fff transparent;
	z-index: 2;
}
.map-panel__wrapper:after {
	top: -10px;
	border-color: transparent transparent #ccc transparent;
	z-index: 1;
}
.map-panel__wrapper:before, .map-panel__wrapper:after {
	content: "";
	border-style: solid;
	border-width: 0 10px 10px 10px;
	position: absolute;
	left: 25%;
	margin-left: -10px;
}

.map-close{
	cursor: pointer;
	position: absolute;
	right: 10px;
	top: 10px;
	transition: opacity .2s;
}
.map-close:before{
	font-size: 1.2rem;
	font-family: 'kkrs-dp';
	text-decoration: none;
	content: "\e911";
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.map-close:hover{
	opacity: .6;
}
.map-panel__wrapper dt{
	font-size: 1.2rem;
	text-align: center;
}
.map-panel__wrapper dt em{
	font-size: 1.8rem;
	font-weight: 700;
}
.map-panel__wrapper dt span{
	display: inline-block;
	font-size: 1.2rem;
}
.map-panel__wrapper dt span:before,
.map-panel__wrapper dt span:after{
	margin: 0 5px;
	content: "－";
}
.map-panel__wrapper ul{
	margin-top: 15px;
}
.map-panel__wrapper li{
	margin-top: 10px;
	border-radius: 8px;
	background: #fff;
}
.map-panel__wrapper li a{
	position: relative;
	display: block;
	padding: 15px 30px;
	color: #fff;
	text-align: center;
	line-height: 1.2;
	font-size: 1.3rem;
	font-weight: 700;
	border-radius: 8px;
	transition: opacity .2s;
}
.map-panel__wrapper li a:hover{
	opacity: .6;
}
.map-panel__wrapper li a:before,
.map-panel__wrapper li a:after{
	position: absolute;
	top: 50%;
	margin-top: -.5em;
    transition: .2s;
    
	font-family: 'kkrs-dp' !important;
	text-decoration: none;
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.map-panel__wrapper li a:before{
	left: 10px;
	font-size: 1.8rem;
}
.panel-map__hotel a:before{ content: "\e960"; }
.panel-map__jr a:before{ content: "\e969"; }
.panel-map__air a:before{ content: "\e918"; }

.map-panel__wrapper li a:after{
	right: 8px;
	content: "\e902";
}
.panel-map__hotel a{ background: #db5858; }
.panel-map__jr a{ background: #f59000; }
.panel-map__air a{ background: #60a8d6; }

.map-panel__wrapper li em{
	display: block;
	font-size: 1.6rem;
	font-weight: 700;
}

/*  ブランドカニ
============================================================================= */
.brand-sect {
    padding-top: 50px;
    border-top: solid 2px #ccc;
}
ul.brand-sect__cassette {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.brand-sect__cassette em {
    font-size: 18px;
    font-weight: 900;
    letter-spacing: normal;
}
.brand-sect__cassette dt {
    font-size: 2.5rem;
    font-weight: bold;
    font-family: 'Noto Serif JP', serif;
    text-align: center;
    letter-spacing: 0em;
}
.brand-sect .in-wrapper{
	margin-top: 25px;
}
.brand-sect__cassette > li{
	padding: 10px;
	width: calc(100% / 3 - 10px);
	background: #fff;
	margin: 10px 5px;
}
.brand-sect__cassette dd{
	margin-top: 15px;
}
.brand-sect__cassette img{
	width: 100%;
	height: auto;
	vertical-align: bottom;
}
.brand-sect__cassette-txt{
	margin-top: 15px;
}

/*  おすすめ特集
============================================================================= */
.feature-sect {
    padding-top: 50px;
    border-top: solid 2px #ccc;
}
section#feature ul {
    padding-top: 60px;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-evenly;
    align-items: center;
}

/*  FAQ
============================================================================= */
.faq-sect__inner{
	position: relative;
	margin: 50px auto 0;
	padding: 0 5px;
	width: 100%;
	min-width: 970px;
	max-width: 1246px;
}
.faq-sect li:not(:first-child){
	margin-top: 5px;
}
.faq-sect dl{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
.faq-sect dt{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	padding: 15px 20px;
	width: 350px;
	background: #DBDAC5;
}
.faq-sect dd{
	margin-left: 5px;
	padding: 15px 20px;
	width: calc(100% - 355px);
	background: #fff;
}
.faq-sect dt, .faq-sect dd{
	position: relative;
	display: block;
	padding-left: 65px;
}
.faq-sect dt::before, .faq-sect dd::before {
	position: absolute;
	left: 10px;
	top: 8px;
	font-size: 1.4em;
	color: #ffffff;
	border-radius: 50%;
	display: inline-block;
	width: 2.0em;
	height: 2.0em;
	line-height: 2.0em;
	text-align: center;
}
.faq-sect dt::before {
	content: 'Q';
	background: #db5858;
}
.faq-sect dd::before {
	content: 'A';
	background: #60a8d6;
}
.faq-sect dd a{
	text-decoration: underline;
}
.faq-sect {
    padding-top: 50px;
    border-top: solid 2px #ccc;
}
/*  検索
============================================================================= */
.search-sect{
	border-top: solid 1px #ccc;
	background: #f5f5f5;
}

/*  Close
============================================================================= */
.close{
	margin: 100px auto 150px;
	width: 600px;
	text-align: center;
}
.close-txt{
	font-size: 3.0rem;
	font-weight: bold;
}
.close-bt{
	margin: 50px auto 0;
	max-width: 500px;
}
.close-bt a{
	display: block;
	padding: 20px;
	color: #fff;
	font-size: 2.0rem;
	font-weight: bold;
	border-radius: 8px;
	background: #cc0d21;
}
.close-bt a:hover{
	text-decoration: none;
	opacity: .6;
	transition: all 0.4s ease;
}
.close-bt a span:after{
	margin-left: 20px;
	font-family: 'jtb-dom' !important;
	text-decoration: none;
	content: "\e905";
	speak: none;
	color: #fff;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/*  フッター サイトマップ
============================================================================= */
.htl-sitemap{
    position: relative;
	border-top: solid 1px #e1e1e1;
	border-bottom: solid 1px #e1e1e1;
	background: #f7f7f7;
}
.htl-sitemap_dl{
    margin: 0 auto;
    width: 100%;
	font-size: 1.4rem;
}
.htl-sitemap_dl dt{
	font-weight: bold;
}

.htl-sitemap_list{
	display: flex;
	flex-wrap: wrap;
}
.htl-sitemap{
 	padding: 50px 0;
}
.htl-sitemap_dl{
	display: flex;
	flex-wrap: wrap;
    min-width: 970px;
    max-width: 1246px;
    padding: 0 5px;
}
.htl-sitemap_dl dt{
	width: 120px;
}
.htl-sitemap_dl dd{
	width: calc(100% - 120px);
}
.htl-sitemap_dl dt:not(:first-of-type), .htl-sitemap_dl dd:not(:first-of-type){
	margin-top: 20px;
}
.htl-sitemap_list{
	margin: -10px 0 0 0;
}
.htl-sitemap_list li{
	margin: 10px 0 0 10px;
	padding-left: 10px;
	border-left: dotted 1px #ccc;
}
.sp-item { display: none; }
}

@media screen and (max-width:767px){

/* ==================================================
   ページ共通
================================================== */
.contents-wrapper{
	border-bottom: solid 1px #ccc;
	background: url("/kokunai/promotion/theme/kani/_images/bg01.png") no-repeat center #f9f7ef;
	background-size: cover;
	background-attachment: fixed;
}

/* ==================================================
   h1　見出し
================================================== */
.page-title-h1{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
	font-size: 2rem;
}
.head-wrap__title span{
	display: block;
	font-size: 1.6rem;
}

/* ==================================================
   キービジュアル
================================================== */
.mv{
	margin-top: 15px;
	background: url("/kokunai/promotion/theme/kani/_images/mv_bg.jpg") no-repeat center;
	background-size: cover;
}
.mv__inner img{
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
.mv__txt{
	padding: 10px;
	width: 100%;
	font-family: 'Noto Serif JP', serif;
	background: url("/kokunai/promotion/theme/kani/_images/mv_bgtxt.png") no-repeat center;
}
.mv__txt br{
	display: none;
}
.mv__txt dt{
	color: #e8c107;
	font-size: 1.6rem;
	font-weight: bold;
}
.mv__txt dd{
	color: #fff;
	font-weight: 700;
}
/* ==================================================
   nav
================================================== */
.pc-nav {
    display: none;
}
.nav {
    padding: .3em 0;
}
.c-item a {
	padding: .5em 0;
}
.sp-nav {
	font-size: 1.2rem;
}
.c-inner {
    margin: 0 auto;
    width: 100%;
	position: relative;
}
/* ==================================================
   information
================================================== */
.information{
	padding: 20px 0;
	background: #fafafa;
}
.information__inner{
	margin: 0 5px;
}
.c-keyword__list{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	padding: 20px 20px 10px;
	justify-content: center;
}
.c-keyword__list a{
	display: inline-block;
	padding: 5px 20px;
	color: #f59000;
	border: solid 2px #ff9900;
	transition: all 0.4s;
	border-radius: 20px;
	margin: 0 3px 3px 3px;
}
.c-keyword__list a:hover{
	opacity: .6;
}

/* ==================================================
   コンテンツ
================================================== */
.page-title-h2,.page-title-h3{
	text-align: center;
}
.page-title-h2{
	position: relative;
	font-family: 'Noto Serif JP', serif;
	line-height: 1.0;
}
.sect .page-title-h2 em{
	position: relative;
	font-weight: 700;
}
.sect .page-title-h2 em:before{
	position: absolute;
	left: -60px;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	transform: translateY(-50%);
	content: "";
	display: block;
	width: 50px;
	height: 40px;
	background: url("/kokunai/promotion/theme/kani/_images/title_kani.png") no-repeat 0 0;
	background-size: 100% auto;

}
.sect .page-title-h2 span{
	display: inline-block;
	font-size: 1.3rem;
}
.sect .page-title-h2 span:before,
.sect .page-title-h2 span:after{
	margin: 0 5px;
	content: "－";
}
.sect-txt{
	margin: 20px 10px 0;
}
.sect{
padding: 40px 0;
}
/*  特別企画
============================================================================= */
.recommendplan-sect .in-wrapper{
    margin-top: 20px;
}
.recommendplan-sect__cassette{
    margin-top: 20px;
}
.pc-none{
    display: block;
}
.recommendplan-sect__cassette > li{
	padding: 15px 10px;
	border-bottom: solid 1px #ccc;
	background: #fff;
}
.recommendplan-sect__cassette > li{
	padding: 15px 10px;
	border-bottom: solid 1px #ccc;
	background: #fff;
}
.recommendplan-sect__cassette > li:first-child{
	border-top: solid 1px #ccc;
}
.recommendplan-sect__cassette dt{
	font-size: 2.0rem;
	font-weight: bolder;
	line-height: 1.2;
}
.recommendplan-sect__cassette dd{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-top: 10px;
	justify-content: center;
}
.recommendplan-sect__cassette figure{
	width: 100%;
}
.recommendplan-sect__cassette img{
	width: 100%;
	height: auto;
	vertical-align: bottom;
}
figure {
    margin: 0;
    position: relative;
}
span.label {
    position: absolute;
    color: white;
    background: red;
    padding: 10px 70px;
}
span.full_bnr {
    left: 55px;
    top: 110px;
    font-size: 25px;
    transform: rotate(-20deg);
}
figcaption {
    font-size: 10px;
    padding: 5px;
}
p.date {
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    background: #f59000;
    padding: 5px;
    margin: 0px 250px 10px 0px;
}
p.area {
    font-weight: 500;
}
.recommendplan-sect__cassette-txt{
	margin-left: 10px;
	width: calc(100% - 30% - 10px);
	line-height: 1.3;
}
p.recommendplan-sect__cassette-title {
    background: #f59000;
    width: 100%;
    padding: 5px;
    font-size: 15px;
    text-align: center;
    color: white;
}
ul.cassette-txt {
    padding: 10px;
    border: 1px solid;
    border-top: transparent;
    width: 100%;
}
p.info {
    text-align: end;
    font-size: 10px;
    padding-top: 5px;
}
p.info a {
    text-decoration: underline;
}

/* おすすめホテル */
.sec-yado .block { margin-bottom: 70px; }
.sec-yado .yado-titleblock { text-align: center; margin-top: 3em; }
.page-title-h2 em { position: relative; font-weight: 700; }
.page-title-h2 em:before { position: absolute; left: -120px; top: 50%; -webkit-transform: translateY(-50%); -moz-transform: translateY(-50%); -ms-transform: translateY(-50%); -o-transform: translateY(-50%); transform: translateY(-50%); content: ""; display: block; width: 50px; height: 40px; background: url(/kokunai/promotion/theme/kani/_images/title_kani.png) no-repeat 0 0; background-size: 100% auto; }
.sec-yado .c-title { position: relative; display: inline-block; padding: 0 55px; font-family: 'Noto Serif JP', serif; font-weight: bold; }
.sec-yado .c-title:before, .sec-yado .c-title:after { position: absolute; content: ''; top: 50%; display: inline-block; background-color: #323743; }
.sec-yado .yado-img {  width: 100%; height: 10em; object-fit: cover; padding: 4px; border-radius: 10px; display: block; }
.sec-yado .yado-img-small { display: flex; padding: 0 5px; column-gap: 4px; }
.sec-yado .yado-img-small figure { width: calc(100% / 2); height: 6em; }
.sec-yado .c-pic figcaption { color: #fff; background-color: #323743; padding: 0 .8em; position: absolute; right: .8rem; bottom: .5rem; font-size: 1rem; }
.sec-yado .yado-img-small img { width: 100%; height: 6em; object-fit: cover; border-radius: 4px; }
.sec-yado .hotel-item .c-txt { display: flex; flex-direction: column; padding: 8px; flex-grow: 1; }
.sec-yado .c-txt small { font-weight: 600; color: #873535; }
.sec-yado .hotel-item p { margin: 15px 0 5px; flex-grow: 1; }
.sec-yado .c-bottom__btn.c-flex { display: flex; justify-content: center; }
.sec-yado .c-bottom__btn .c-btn { height: 3.375em; }
.sec-yado .yado-sect__more { text-align: center; position: relative; font-weight: 700; }
.sec-yado .yado-sect__more span { color: #873535; }
.sec-yado .yado-sect__more span::after { position: absolute; display: block; content: ""; border-bottom: 2px solid #db5858; border-right: 3.5px solid #db5858; transform: skew(40deg); height: 10px; margin-top: -5px; left: 0px; right: 0px; margin-left: auto; margin-right: auto; }
.sec-yado .hotel-cassette_bt { display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%; }
.sec-yado .hotel-cassette_bt-item a { position: relative; display: flex; justify-content: center; align-items: center; padding: 5px 5px; min-height: 50px; text-align: center; font-size: 1.2rem; color: #fff; letter-spacing: 0; line-height: 1.3; border-radius: 5px; }
.sec-yado .hotel-cassette_bt-item.-hotel a { border: solid 1px #db5858; background: #db5858; }
.sec-yado .hotel-cassette_bt-item.-jr a { border: solid 1px #f59000; background: #f59000; }
.sec-yado .hotel-cassette_bt-item.-air a { border: solid 1px #60a8d6; background: #60a8d6; }
.sec-yado .hotel-cassette_bt-item { margin-top: 5px; width: calc(100% / 2 - 2px); }
.sec-yado .hotel-cassette_bt-item.-hotel a:before { content: "\ea40"; }
.sec-yado .hotel-cassette_bt-item.-jr a:before { content: "\e570"; }
.sec-yado .hotel-cassette_bt-item.-air a:before { content: "\e539"; }
.sec-yado .hotel-cassette_bt-item a:before { margin-right: 5px; font-family: 'Material Icons Round'; font-size: 2.0rem; color: #fff; line-height: 1; }
.sec-yado .hotel-cassette_bt-item em { display: block; font-size: 1.2rem; font-weight: bold; }
.sec-yado .hotel-cassette_bt-item a:after { position: absolute; right: 0; top: 50%; transform: translateY(-50%); display: inline-block; font-family: 'Material Icons Round'; content: "\e5cc"; font-size: 2.0rem; }
.sec-yado .hotel-cassette_bt-item span { padding-right: 8px; }
.sec-yado .c-title:before { width: 30px; height: 3px; left: 15px; }
.sec-yado .c-title:after { width: 30px; height: 3px; right: 15px; }
.sec-yado .c-title span { font-size: 1.8rem; }
.sec-yado .hotel-item { margin-bottom: 15px; }
.sec-yado .hotel-item { width: 90%; background: #fff; -webkit-box-shadow: 0 1px 3px rgb(0 0 0 / 20%); box-shadow: 0 1px 3px rgb(0 0 0 / 20%); border-radius: 4px; display: flex; flex-direction: column; }
.sec-yado .hotel-item .c-txt { justify-content: space-evenly; }
.sec-yado .hotel-title { font-size: 1.8rem; }
.sec-yado .c-bottom__btn .c-btn { width: 95%; }
.sec-yado .yado-sect__more { margin-top: 20px; }
.sec-yado .yado-sect__more span::after { width: 68%; }

/*  人気エリアから探す
============================================================================= */
.popularspot-sect {
    padding-top: 40px;
    border-top: solid 1px #ccc;
    border-bottom: solid 1px #ccc;
}
.popularspot-sect .in-wrapper{
	margin-top: 20px;
}
.popularspot-sect__cassette{
	margin-top: 20px;
}
.popularspot-sect__cassette > li{
	padding: 15px 10px;
	border-bottom: solid 1px #ccc;
	background: #fff;
}
.popularspot-sect__cassette > li:first-child{
	border-top: solid 1px #ccc;
}
.popularspot-sect__cassette dt{
	font-size: 2.0rem;
	font-weight: 700;
	font-family: 'Noto Serif JP', serif;
	text-align: center;
	line-height: 1.2;
	letter-spacing: .5em;
}
.popularspot-sect__cassette dd{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-top: 10px;
}
.popularspot-sect__cassette figure{
	width: 30%;
}
.popularspot-sect__cassette img{
	width: 100%;
	height: auto;
	vertical-align: bottom;
}
.popularspot-sect__cassette-txt{
	margin-left: 10px;
	width: calc(100% - 30% - 10px);
	line-height: 1.3;
}
.popularspot-sect__cassette-bt{
	clear: both;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	width: calc(100% + 5px);
	margin: 10px 0 0 -5px;
}
.popularspot-sect__cassette-bt li{
	margin-left: 5px;
	width: 100%;
	border-radius: 8px;
	background: #fff;
}
.popularspot-sect__cassette-bt li a{
	position: relative;
	display: block;
	padding: 10px 15px 10px 25px;
	color: #fff;
	text-align: center;
	line-height: 1.2;
	font-size: 1rem;
	font-weight: 700;
	border-radius: 8px;
	transition: opacity .2s;
}
.popularspot-sect__cassette-bt li a:hover{
	opacity: .6;
}
.popularspot-sect__cassette-bt li a:before,
.popularspot-sect__cassette-bt li a:after{
	position: absolute;
	top: 50%;
	margin-top: -.5em;
    transition: .2s;
    
	font-family: 'kkrs-dp' !important;
	text-decoration: none;
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.popularspot-sect__cassette-bt li a:before{
	left: 5px;
	font-size: 1.5rem;
}
.popularspot-sect__cassette-bt-htl a:before{ content: "\e960"; }
.popularspot-sect__cassette-bt-jr a:before{ content: "\e969"; }
.popularspot-sect__cassette-bt-air a:before{ content: "\e918"; }

.popularspot-sect__cassette-bt li a:after{
	right: 5px;
	content: "\e902";
}
.popularspot-sect__cassette-bt-htl a{ background: #db5858; }
.popularspot-sect__cassette-bt-jr a{ background: #f59000; }
.popularspot-sect__cassette-bt-air a{ background: #60a8d6; }

.popularspot-sect__cassette-bt li em{
	display: block;
	font-size: 1.3rem;
	font-weight: 700;
}
.popularspot-sect__bt{
	margin: 10px 40px 0;
	border-radius: 35px;
	background: #fff;
}
.popularspot-sect__bt a{
	position: relative;
	display: block;
	padding: 10px 15px;
	color: #fff;
	font-weight: 700;
	text-align: center;
	line-height: 1.1;
	background: #5d5c5c;
	border-radius: 8px;
	transition: opacity .2s;
}

.popularspot-sect__bt a:before{
	position: absolute;
	right: 25px;
	top: 50%;
	margin-top: -.5em;
    transition: .2s;
    
	font-family: 'kkrs-dp' !important;
	content: "\e902";
	text-decoration: none;
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.popularspot-sect__bt a:hover{
	opacity: .6;
}
.popularspot-sect__bt em{
	font-size: 1rem;
	font-weight: 700;
}
.popularspot-sect__bt span{
	display: inline-block;
	font-size: 1.2rem;
}
.popularspot-sect__bt span:before,
.popularspot-sect__bt span:after{
	margin: 0 5px;
	content: "－";
}

/*  地図・人気温泉地から探す
============================================================================= */
.map-sect{
	padding-top: 40px;
	border-top: solid 1px #ccc;
}
.map-sect .in-wrapper{
}
.map-sect__box{
	margin: 0 10px;
}
.map-sect__box-list-sp{
	position: relative;
	padding-top: calc(559 / 950 * 100%);
	background: url("/kokunai/promotion/theme/kani/_images/map.png") no-repeat 0 0;
	background-size: 100% auto;
}
.map-sect__box-list-sp li{
	position: absolute;
	-webkit-transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	-o-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.map-sect__box-list-sp li.-circle{
	border-radius: 50%;
	width: 36px;
	height: 36px;
}
.map-sect__box-list-sp li a{
	display: block;
	width: 20px;
	line-height: 20px;
	color: #fff;
	font-weight: 700;
	text-align: center;
	border-radius: 50%;
}
.map-sect__box-list-sp li.-circle a{
	border-radius: 50%;
	width: 36px;
	height: 36px;
	text-align: center;
	line-height: 36px;
	font-size:1.6rem
}
.map-sect__box-list-sp.-circle a span {
	margin-top: 20px;
}
.map-sect__box-list-sp.-circle a:after{
	position: absolute;
	bottom: 16px;
	left: calc(50% - 0.5rem);
	margin-top: -.5em;
	transition: .2s;
	font-family: 'kkrs-dp' !important;
	text-decoration: none;
	content: "\e903";
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.map-sect__box-list-sp li:first-child{ left: 68.26%; top: 32.79%; }
.map-sect__box-list-sp li:nth-child(2){ left: 83.26%; top: 25.79%; }
.map-sect__box-list-sp li:nth-child(3){ left: 79.05%; top: 42.93%; }
.map-sect__box-list-sp li:nth-child(4){ left: 73.57%; top: 53.34%; }
.map-sect__box-list-sp li:nth-child(5){ left: 66.42%; top: 78.89%; }
.map-sect__box-list-sp li:nth-child(6){ left: 50.15%; top: 48.22%; }
.map-sect__box-list-sp li:nth-child(7){ left: 55.15%; top: 64.22%; }
.map-sect__box-list-sp li:nth-child(8){ left: 47.73%; top: 85.82%; }
.map-sect__box-list-sp li:nth-child(9){ left: 40.57%; top: 55.74%; }
.map-sect__box-list-sp li:nth-child(10){ left: 33.15%; top: 65.01%; }
.map-sect__box-list-sp li:nth-child(11){ left: 37.10%; top: 77.20%; }
.map-sect__box-list-sp li:nth-child(12){ left: 7.20%; top: 63.65%; }
.map-sect__box-list-sp li:nth-child(13){ left: 34.73%; top: 87.65%; }
.map-sect__box-list-sp li:nth-child(14){ left: 20.63%; top: 87.65%; }
.map-sect__box-list-sp li:nth-child(15){ left: 15.57%; top: 54.91%; }
.map-sect__box-list-sp li:nth-child(16){ left: 8.94%; top: 79.60%; }

.map-sect__box-list{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.map-sect__box-list li{
	width: calc(100% / 2);
	border-top: solid 1px #ccc;
}
.map-sect__box-list li:not(:nth-child(2n+1)){
	border-left: solid 1px #ccc;
}

.map-sect__box-list li a{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	
	position: relative;
	padding: 10px 30px;
	min-height: 51px;
	height: 100%;
	color: #323743;
	font-weight: 700;
	line-height: 1.2;
	background: #fff;
}
.map-sect__box-list li a:after{
	position: absolute;
	top: 50%;
	right: 8px;
	margin-top: -.5em;
	color: #999;
    transition: .2s;
    
	font-family: 'kkrs-dp' !important;
	text-decoration: none;
	content: "\e902";
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.map-sect__box-list li a:before{
	position: absolute;
	top: 50%;
	left: 5px;
	margin-top: -10px;
	
	border-radius: 50%;
	width: 20px;
	line-height: 20px;
	color: #fff;
	text-align: center;
}
.map-sect__box-list li:first-child a:before{ content: "1"; }
.map-sect__box-list li:nth-child(2) a:before{ content: "2"; }
.map-sect__box-list li:nth-child(3) a:before{ content: "3"; }
.map-sect__box-list li:nth-child(4) a:before{ content: "4"; }
.map-sect__box-list li:nth-child(5) a:before{ content: "5"; }
.map-sect__box-list li:nth-child(6) a:before{ content: "6"; }
.map-sect__box-list li:nth-child(7) a:before{ content: "7"; }
.map-sect__box-list li:nth-child(8) a:before{ content: "8"; }
.map-sect__box-list li:nth-child(9) a:before{ content: "9"; }
.map-sect__box-list li:nth-child(10) a:before{ content: "10"; }
.map-sect__box-list li:nth-child(11) a:before{ content: "11"; }
.map-sect__box-list li:nth-child(12) a:before{ content: "12"; }
.map-sect__box-list li:nth-child(13) a:before{ content: "13"; }
.map-sect__box-list li:nth-child(14) a:before{ content: "14"; }
.map-sect__box-list li:nth-child(15) a:before{ content: "15"; }
.map-sect__box-list li:nth-child(16) a:before{ content: "16"; }
.map-sect__box-list li:nth-child(17) a:before{ content: "17"; }

.map-sect__box-list-sp li.map-hokuriku a, .map-sect__box-list li.map-hokuriku a:before{ background: #f59000; }
.map-sect__box-list-sp li.map-kinki a, .map-sect__box-list li.map-kinki a:before{ background: #f14e17; }
.map-sect__box-list-sp li.map-chugoku a, .map-sect__box-list li.map-chugoku a:before{ background: #fd3175; }


/* パネル */
.map-close:hover{
	opacity: .6;
}
.map-panel__wrapper dt{
	font-size: 1.2rem;
	text-align: center;
}
.map-panel__wrapper dt em{
	font-size: 1.8rem;
	font-weight: 700;
}
.map-panel__wrapper dt span{
	display: inline-block;
	font-size: 1.2rem;
}
.map-panel__wrapper dt span:before,
.map-panel__wrapper dt span:after{
	margin: 0 5px;
	content: "－";
}
.map-panel__wrapper ul{
	margin-top: 15px;
}
.map-panel__wrapper li{
	margin-top: 10px;
	border-radius: 8px;
	background: #fff;
}
.map-panel__wrapper li a{
	position: relative;
	display: block;
	padding: 15px 30px;
	color: #fff;
	text-align: center;
	line-height: 1.2;
	font-size: 1.3rem;
	font-weight: 700;
	border-radius: 8px;
	transition: opacity .2s;
}
.map-panel__wrapper li a:hover{
	opacity: .6;
}
.map-panel__wrapper li a:before,
.map-panel__wrapper li a:after{
	position: absolute;
	top: 50%;
	margin-top: -.5em;
    transition: .2s;
    
	font-family: 'kkrs-dp' !important;
	text-decoration: none;
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.map-panel__wrapper li a:before{
	left: 10px;
	font-size: 1.8rem;
}
.panel-map__hotel a:before{ content: "\e960"; }
.panel-map__jr a:before{ content: "\e969"; }
.panel-map__air a:before{ content: "\e918"; }

.map-panel__wrapper li a:after{
	right: 8px;
	content: "\e902";
}
.panel-map__hotel a{ background: #db5858; }
.panel-map__jr a{ background: #f59000; }
.panel-map__air a{ background: #60a8d6; }

.map-panel__wrapper li em{
	display: block;
	font-size: 1.6rem;
	font-weight: 700;
}

/*  ブランドカニ
============================================================================= */
.brand-sect {
    padding-top: 40px;
    border-top: solid 1px #ccc;
    border-bottom: solid 1px #ccc;
}
.brand-sect .in-wrapper{
	margin-top: 20px;
}
.brand-sect__cassette{
	margin-top: 20px;
}
.brand-sect__cassette > li{
	padding: 15px 10px;
	border-bottom: solid 1px #ccc;
	background: #fff;
}
.brand-sect__cassette > li:first-child{
	border-top: solid 1px #ccc;
}
.brand-sect__cassette dt{
    font-size: 2.0rem;
    font-weight: bold;
    font-family: 'Noto Serif JP', serif;
    text-align: center;
    line-height: 1.2;
}
.brand-sect__cassette em {
    font-size: 1.5rem;
    font-weight: bold;
}
.brand-sect__cassette dd{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-top: 10px;
}
.brand-sect__cassette figure{
	width: 30%;
}
.brand-sect__cassette img{
	width: 100%;
	height: auto;
	vertical-align: bottom;
}
.brand-sect__cassette-txt{
	margin-left: 10px;
	width: calc(100% - 30% - 10px);
	line-height: 1.3;
}

/*  JTBおすすめ特集
============================================================================= */.feature-sect .in-wrapper {
    position: relative;
}
.feature-sect ul {
    list-style: none;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding-top: 20px;
}
.feature-sect li {
    width: calc(100%/2);
    padding: 5px 5px;
    box-sizing: border-box;
}
.feature-sect li p {
    font-size: 12px;
    text-align: center;
}
.feature-sect img {
    width: 100%;
    height: auto;
}

/*  FAQ
============================================================================= */
.faq-sect__inner{
	margin-top: 20px;
}
.faq-sect li:not(:first-child){
	border-top: solid 1px #ccc;
}
.faq-sect dt{
	position: relative;
	padding: 15px 40px 20px 20px;
	line-height: 1.4;
	background: #fff;
}
.faq-sect dt:after {
	position: absolute;
	right: 18px;
	top: 50%;
	margin-top: -.5em;
	font-family: 'jtb-dom';
	content: "\e906";
	speak: none;
	text-decoration: none;
	text-transform: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	transition: .2s;
	-webkit-transform: rotateZ(0deg);
	transform: rotateZ(0deg);
}
.faq-sect dt.is-open:after {
	-webkit-transform: rotateZ(180deg);
	transform: rotateZ(180deg);
}
.faq-sect dd{
	padding: 15px 20px;
	display: none;
	background: #fff;
	border-top: dashed 1px #ccc;
}
.faq-sect dt, .faq-sect dd{
	position: relative;
	padding-left: 55px;
}
.faq-sect dt::before, .faq-sect dd::before {
	position: absolute;
	left: 10px;
	top: 8px;
	font-size: 1.4em;
	color: #ffffff;
	border-radius: 50%;
	display: inline-block;
	width: 2.0em;
	height: 2.0em;
	line-height: 2.0em;
	text-align: center;
}
.faq-sect dt::before {
	content: 'Q';
	background: #db5858;
}
.faq-sect dd::before {
	content: 'A';
	background: #60a8d6;
}
.faq-sect dd a{
	text-decoration: underline;
}

/*  検索
============================================================================= */
.search-sect{
	border-top: solid 1px #ccc;
	background: #f5f5f5;
}
.search-tab{
	padding-top: 0;
	box-shadow: none;
}

/*  モーダル
============================================================================= */
body.lock {
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
    overflow-y: scroll;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.modal-wrap * {
    box-sizing: border-box;
}
.map-panel {
    position: relative;
    display: none;
    width: 80%;
    margin: 30px;
    padding: 20px;
    background: #fff;
}
.modal-overlay {
    z-index: 10000;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 120%;
    background-color: rgba(0, 0, 0, 0.75);
}
.modal-wrap::-webkit-scrollbar {
    background: #ccc;
    width: 3px;
}
.modal-wrap::-webkit-scrollbar-thumb {
    background: #aaa;
}
.modal-close {
    position: absolute;
    margin-bottom: 10px;
    right: -30px;
    top: -30px;
    font-size: 2.0rem;
    font-weight: bold;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    border: 0;
    text-align: center;
    text-decoration: none;
    color: #fff;
    cursor: pointer;
    font-family: Osaka,"ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
}

.modal-content {
    margin: 40px 15px;
    width: 90%;
    height: 400px;
    padding: 15px 5px 15px 15px;
}
.modal-content-in{
    padding-right: 10px;
}
.modal-content-in::-webkit-scrollbar {
    background: #ccc;
    width: 3px;
}
.modal-content-in::-webkit-scrollbar-thumb {
    background: #aaa;
}
.modal-close {
    right: -5px;
    top: -35px;
}

/*  Close
============================================================================= */
.close{
	margin: 100px auto 150px;
	width: 600px;
	text-align: center;
}
.close-txt{
	font-size: 3.0rem;
	font-weight: bold;
}
.close-bt{
	margin: 50px auto 0;
	max-width: 500px;
}
.close-bt a{
	display: block;
	padding: 20px;
	color: #fff;
	font-size: 2.0rem;
	font-weight: bold;
	border-radius: 8px;
	background: #cc0d21;
}
.close-bt a:hover{
	text-decoration: none;
	opacity: .6;
	transition: all 0.4s ease;
}
.close-bt a span:after{
	margin-left: 20px;
	font-family: 'jtb-dom' !important;
	text-decoration: none;
	content: "\e905";
	speak: none;
	color: #fff;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	vertical-align: middle;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/*  フッター サイトマップ
============================================================================= */
.htl-sitemap{
    position: relative;
    border-top: solid 1px #e1e1e1;
    border-bottom: solid 1px #e1e1e1;
    background: #f7f7f7;
}
.htl-sitemap_dl dt{
	padding: 15px 30px 15px 15px;
}
.htl-sitemap_dl dt:not(:first-of-type){
	border-top: solid 1px #eee;
}
.htl-sitemap_dl dd{
	display: none;
	padding-bottom: 15px;
}
.htl-sitemap_list{
    display: flex;
    flex-wrap: wrap;
	margin-right: 3px;
}
.htl-sitemap_list li{
	margin: 3px 0 0 3px;
	width: calc(100% / 2 - 3px);
}
.htl-sitemap_list li a{
	display: flex;
	align-items: center;
	padding: 5px 10px;
	min-height: 50px;
	height: 100%;
	line-height: 1.3;
	border-radius: 3px;
	background: #fff;
}
.js-accordion-sp a{
    pointer-events: none;
}

/*  JS
============================================================================= */
.js-accordion-sp{
	position: relative;
}
.js-accordion-sp:after{
	position: absolute;
	right: 10px;
	top: 10px;
    font-family: 'Material Icons Round';
    content: "\e5cf";
	transition: all .2s ease;
	font-size: 1.8rem;
}
.js-accordion-sp.is-open:after{
	transform: rotateZ(-180deg);
}
}


/*  エスコート
============================================================================= */
.c-sec {
	padding: 50px 0;
}
#recommend .page-title-h2{
	position: relative;
	font-weight: 700;
	line-height: 1.2;
}
#recommend .page-title-h2:before{
	position: absolute;
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	transform: translateY(-50%);
	content: "";
	display: block;
	width: 67px;
	height: 54px;
	background: url("/kokunai/promotion/theme/kani/_images/title_kani.png") no-repeat 0 0;
}
.ranking__bt a {
  background:#db5858 !important;
}

@media screen and (min-width:768px){
	#recommend .page-title-h2:before{
		left: 190px;
		top: 50%;
		width: 67px;
		height: 54px;
	}
	.page-lead {
		margin-top: 50px !important;
	}
}

@media screen and (max-width:767px){
	#recommend .page-title-h2:before{
		left: 50px;
		top: 50%;
		width: 50px;
		height: 40px;
		background-size: 100% auto;
	}
	.page-lead {
		margin-top: 30px !important;
	}
}

