@charset "utf-8";
/* 総合TOPPCオリジナルCSS */

/*------------------------------
nippon_travel_agency
------------------------------*/
#nippon_travel_agency{
    user-select: none;
	position: relative;
}
#nippon_travel_agency .gadget_box{
	width: 450px;
	min-height:435px;
    position: absolute;
    top: 30px;
    left: calc((100% - 900px) / 2);
    z-index: 2;
    background: #FFF;
	border-radius: 3px;
}
@media screen and (min-width: 760px) and (max-width: 969.9px){/*iPad*/
#nippon_travel_agency .gadget_box{
	width: 430px;
	position: absolute;
    top: 30px;
    left: 0;
}
#nippon_travel_agency .slider img {
    width: auto;
    height: 500px;
    display: block;
    margin: auto;
    margin-left: calc(50% - 960px);
}
}
#nippon_travel_agency .slider li a {
	position: absolute;
    top: 0;
    left: calc((100% - -50px) / 2);
    display: block;
    width: 450px;
    height: 320px;
    background: #00000055;
}
#nippon_travel_agency .slider li a span{
    position: absolute;
    bottom: -20px;
    right: calc(50% - 80px);
    display: block;
    width: 175px;
    font-size: 13px;
    background: #FFF;
    text-align: center;
    padding: 5px 10px;
    border: 1px solid #3f3f3f;
    color: #3f3f3f;
    box-sizing: border-box;
}
#nippon_travel_agency .slider img {
	width:auto;
	height:500px;
	display: block;
    margin: auto;
	margin-left: calc(50% - 960px);
}
#select_search_box{
	position: absolute;
    right: calc(50% - 404px);
    bottom: 50px;
}
#select_search_box li{
	width: 320px;
    background: #FFF;
    position: relative;
    text-align: center;
    font-size: 16px;
    line-height: 2.4;
    border-radius: 15px;
    display: block;
    cursor: pointer;
    border: 1px solid #20208c;
    box-shadow: 0px 0px 5px #FFF, 0px 0px 5px #FFF, 0px 0px 5px #FFF;
    color: #20208c;
}
#select_search_box li.select_search{display: none;}
#select_search_box li:before,
#select_search_box li:after{
    font-weight: bold;
	font-size: 16px;
}
#select_search_box li:before{
	content: "\02190";
	position: absolute;
	top:-3px;
	left: 25px;
}
#select_search_box li:after{
	content: "\02192";
	position: absolute;
	top: 5px;
    left: 32px;
}
#nippon_travel_agency .slick-dots {
	position: absolute;
	right: calc(50% - 355px);
	bottom: 145px;
	display: block;
	width: 200px;
    padding: 0 10px;
    margin: 0;
    list-style: none;
    text-align: center;
    background: rgba(255,255,255,0.9);
    border-radius: 15px;
}

#nippon_travel_agency .slick-dots li,
#main_banner .slick-dots li {margin: 0 2px;}

#nippon_travel_agency .slick-dots li button:before,
#main_banner .slick-dots li button:before {
	line-height: 12px;
	font-size:20px;
}
#nippon_travel_agency .slick-dots li.slick-active button:before,
#main_banner .slick-dots li.slick-active button:before {
	line-height: 10px;
	font-size:26px;
}

/*------------------------------
main_banner
------------------------------*/
#main_banner {margin-bottom: 15px;}
#main_banner > ul {
	position:relative;
	display: flex;
}
#main_banner > #rt_all_top_pr li[id] {
	width: 267px;
	margin:0 5px;
}
#main_banner .slick-track li{margin: 0 5px;}
#main_banner .slick-track li img{border-radius: 3px;}
#main_banner .slick-dots{
	width: 150px;
	position: absolute;
	left: calc((100% - 150px) / 2);
}

/*------------------------------
kokunai contents
------------------------------*/
.destination_section ul {display:flex;}
.destination_section li {
	width: 48%;
	margin: 0 1% 1%;
    overflow: hidden;
    position: relative;
}
.destination_section li a {
	width: 98%;
    display: inline-block;
	margin: 5px 1%;
    text-align: center;
    color: #222;
    background: #FFF;
	font-size: 14px;
	box-sizing: border-box;
}
.destination_section .picture-box li a {line-height: 0;}
.destination_section .word-box li a {
    font-size: 16px;
    padding: 15px 0;
    border: 1px solid #aaa;
    border-radius: 3px 3px 0 3px;
	position:relative;
}
.destination_section .word-box li a:before {
	content: "";
    position: absolute;
    bottom: 3px;
    right: 3px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 15px 15px;
    border-color: transparent transparent #20208c transparent;
}
.destination_section .picture-box li img {
    box-sizing: border-box;
	border-radius: 3px;
}
.destination_section .picture-box li p {
	width: 98%;
    position: absolute;
    bottom: 5px;
    left: 0px;
    color: #FFF;
    font-size: 20px;
    letter-spacing: 3px;
    display: block;
    margin: 0 1%;
    padding: 5px 5px 5px 15px;
    background: rgb(0,0,0);
    background: linear-gradient(0deg, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.4) 50%, rgba(0,0,0,0) 100%);
    border-radius: 0 0 3px 3px;
    box-sizing: border-box;
    pointer-events: none;
}
#popular_inn_section li{
	width: 200px;
    margin: 0 5px;
}
#popular_inn_section dt {
    overflow: hidden;
	position: relative;
}
#popular_inn_section dt img {border-radius: 3px;}
#popular_inn_section dt div {
    width: 100%;
	height: 72px;
	position: absolute;
    bottom: 0;
    left: 0;
    padding: 5px;
    background: rgb(0,0,0);
    background: linear-gradient(0deg, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.4) 50%, rgba(0,0,0,0) 100%);
	align-items: center;
    display: inline-grid;
    box-sizing: border-box;
	pointer-events: none;
	border-radius: 0 0 3px 3px;
}
#popular_inn_section .area_name {
	font-size: 12px;
	margin: 2% 0;
	color: #FFF;
}
#popular_inn_section h3 {
	font-size: 14px;
	font-weight: bold;
	color: #FFF;
}
#popular_inn_section .plan_price a {
	display: block;
	text-align: center;
    font-size: 18px;
    font-weight: bold;
    color: #fa6464;
    margin: 5% 0;
}
#popular_inn_section .plan_linkbtn{display:flex;}
#popular_inn_section .plan_linkbtn a{
	width: 98%;
    background: #FFF;
    display: block;
    margin: 0 1% 5%;
    padding: 5px 0;
    text-align: center;
    color: #333;
    font-size: 15px;
    border: 1px solid #d6d6d6;
    box-shadow: 1px 1px 1px #d6d6d6;
    border-radius: 3px;
}
.keyword_section {text-align: center;}
.keyword_section li {
	display: inline-block;
    border: 1px solid #d6d6d6;
    border-radius: 20px;
    margin: 0 0 10px;
	background: #FFF;
}
.keyword_section li a {
	font-size: 16px;
	display: inline-block;
    margin: 8px 15px 7px 30px;
    color: #222;
	position:relative;
}
.keyword_section li a:before {
	content:"#";
	position:absolute;
	top:0;
	left:-14px;
}
.keyword_section li.kokunai a:before {color:#F97777;}
.keyword_section li.kaigai a:before {color:#49CCD4;}

/*map*/
.map_box.dis_flex{
	width: fit-content;
    margin: auto;
}
.map_box .section {
    width: 430px;
    margin: 0 15px;
}
.map_box .placeBox {margin-bottom: 0;}
.map_box .placeBox .map {height:296px; position:relative;}
.map_box .kokunai .placeBox .map {background:url(/shared2015/common/images/bg_map_01.gif) center top no-repeat;}
.map_box .kaigai .placeBox .map {background:url(/shared2015/common/images/bg_map_02.gif) center top no-repeat;}
.map_box .placeBox .map dl {
	position: absolute;
	cursor: pointer;
}
.map_box .placeBox .map dt {
	background: rgba(250,250,255,0.6);
	padding: 2px 18px 4px;
	position:relative;
}
.map_box .placeBox .map dt:before{
	content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 5px solid #222;
    border-right: 0;
    display: block;
    position: absolute;
    top: 28%;
    left: 5px;
}
.map_box .hokkaido{
	left: 297px;
	top: 33px;
}
.map_box .tohoku{
	left:300px;
	top:135px;
}
.map_box .kanto{
	left: 285px;
	top: 197px;
}
.map_box .hokuriku{
	left: 181px;
	top: 160px;
}
.map_box .koshinetsu{
	left: 232px;
	top: 118px;
}
.map_box .tokai{
	left: 254px;
	top: 235px;
}
.map_box .kansai{
	left: 189px;
	top: 248px;
}
.map_box .chugoku{
	left: 121px;
	top: 187px;
}
.map_box .shikoku{
	left: 116px;
	top: 249px;
}
.map_box .kyushu{
	left: 57px;
	top: 221px;
}
.map_box .okinawa{
	left: 55px;
	top: 73px;
}
.map_box .europe{
	left: 83px;
	top: 67px;
}
.map_box .afreeca{
	left: 39px;
	top: 126px;
}
.map_box .asia{
	left: 194px;
	top: 80px;
}
.map_box .beech{
	left: 62px;
	top: 201px;
}
.map_box .america{
	left: 288px;
	top: 139px;
}
.map_box .oceania{
	left: 227px;
	top: 213px;
}
.map_box .pref,
.map_box .country {
    z-index: 1;
    position: absolute;
    background: #FFF;
    padding: 5px 0;
	border: 1px solid #999;
}
.map_box .pref {
	width: 105px;
    display: none;
    text-align: center;
    line-height: 1.6;
}
.map_box dl:hover .pref {display: block;}
.map_box .country {width: 200px;display: none;}
.map_box dl:hover .country {display: inline;}
.map_box .pref *,
.map_box .country * {
	display: inline;
    font-size: 12px;
    color: #222;
    margin: 2px;
    word-break: auto-phrase;
}
.map_box .placeBox .map dt a {color: #222;}

/*word link*/
.inline_word_link_box ul{
	display: flex;
    flex-wrap: wrap;
}
.inline_word_link_box li{
    width: fit-content;
    margin: 0 25px 15px;
    font-size: 16px;
	position:relative;
}
.inline_word_link_box li a{color:#222;}
.inline_word_link_box li:after{
	content: "｜";
    color: #aaa;
    position: absolute;
    right: -34px;
}
.inline_word_link_box li:last-child:after{content: "";}

/*Tripa*/
.tripa_article li {
	border-bottom: 1px dotted #ccc;
    padding: 10px;
    background: #FFF;
	font-size: 16px;
	display: flex
}
.tripa_article li:last-child {border-bottom: none;}
.tripa_article li img {
    width: 8%;
    height: auto;
	margin-right:2%
}
.tripa_article li hgroup span {font-size: 0.9em}
.tripa_article li a {
	width: 90%;
	color: #333
}
.tripa_article li a:hover {color: #20208c}

/*相互リンク*/
.mutuallink {
    background: #ebeaea;
    padding: 15px;
	text-align: center;
}
.mutuallink .bnr {display: inline;}
.mutuallink .bnr li {
	margin: 5px;
    display: inline-block;
}

/*action*/
.tab_kokunai_ga li:not(.select):hover,
.tab_kaigai_ga li:not(.select):hover{
	border-bottom: 3px solid #b4b4e9;
	transition: 0.25s ease-in;
}
#select_search_box:hover li {
    background: #20208c;
    color: #FFF;
	transition: 0.1s;
}
#select_search_box:hover li:before {
    content: "\02192";
	position: absolute;
    top: -3px;
    left: 32px;
	transition: 0.1s;
}
#select_search_box:hover li:after {
    content: "\02190";
	position: absolute;
    top: 5px;
    left: 25px;
	transition: 0.1s;
}
.destination_section .word-box li a:hover{
	opacity: 0.8;
	transition: 0.25s;
}
#popular_inn_section .plan_linkbtn a:hover {
	opacity: 0.8;
	transition: 0.25s;
}
.keyword_section li:hover {
	background-color: #eee;
	transition: 0.25s;
}
.keyword_section li:hover a{opacity: 1;}
.map_box a:hover,
.inline_word_link_box a:hover{
	color: #20208c;
	transition: 0.25s;
}

/*ガシェット調整*/
/*#p_sbox_ka .box-contents .forcia_person{
	display: none;
    width: 500px;
    padding: 15px;
    background: #FFF;
    position: fixed;
    top: calc((100% - 380px) / 2);
    left: calc((100% - 500px) / 2);
    border-radius: 5px;
	z-index: 1000;
}
#modal_dprooms {
	display: block;
    margin: 0 0 3% auto;
    border: 1px solid #20208c;
    padding: 3px 10px 5px;
    color: #20208c;
    border-radius: 15px;
}
#p_sbox_ka .box-contents .forcia_person .forcia_rooms{
    width: 48%;
    float: right;
    margin-right: 2%;
    text-indent: 10px;
}
#p_sbox_ka .box-contents .forcia_person .forcia_jinin{
	width: 100%;
	height:250px;
    clear: both;
	overflow-y: auto;
}
#p_sbox_ka .box-contents .forcia_person .forcia_jinin > .room .item .item_in {
	margin-bottom: 5%;
	display: flex;
	flex-wrap: wrap;
}
#p_sbox_ka .box-contents .forcia_person .forcia_jinin > .room .item .item_in > span{
	width: 18%;
	margin-right: 2%;
}
#p_sbox_ka .box-contents .forcia_person .forcia_jinin > .room .item .item_in > select {
	width: 25% !important;
    margin: 0 5% 2% 0;
    text-indent: 5px;
}
#overlay_dprooms {
	width: 100%;
	height: 150%;
	position: fixed;
	background: rgba(0, 0, 0, .7);
	display: none;
	left: 0;
	overflow: hidden;
	top: -1px;
	background: rgba(0, 0, 0, .7);
	z-index: 999;
}
#overlay_dprooms.open {display: block;}
#modal_dprooms_close {
	width: 24px;
    height: 24px;
    display: block;
    position: absolute;
    top: 3px;
    right: 3px;
}
#modal_dprooms_close:before{
	content: "";
	width: 20px;
	height: 2px;
	background: #20208c;
	display: block;
	margin: auto;
	position: absolute;
	left: 0;
	top: 11px;
	transform: rotate(45deg);
}
#modal_dprooms_close:after{
	content: "";
	width: 20px;
	height: 2px;
	background: #20208c;
	display: block;
	margin: auto;
	position: absolute;
	left: 0;
	bottom: 11px;
	transform: rotate(-45deg);
}
#modal_dprooms:hover, #modal_dprooms_close:hover {opacity:0.8;}
html:has(#overlay_dprooms.open),
body:has(#overlay_dprooms.open) {overflow: hidden;}
#p_sbox_ka .box-contents .forcia_person .attention span {
    margin-top: 20px;
    display: block;
}*/