body {
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue",
		YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ",
		Meiryo, sans-serif;
}

.noscroll {
	overflow: hidden;
}

#condition {
	margin-bottom: 24px;
}

.btn-wrapper {
	margin-top: 8px;
	text-align: center;
}

.navbar {
	margin-bottom: 8px;
	display: none;
}

.navbar-brand {
	font-size: 150%;
}

#daytab {
	position: relative;
	list-style: none;
}

#daytab>li {
	float: left;
	border: 1px solid #e0e0e0;
	padding: 3px 0px;
	cursor: pointer;
	width: 50%;
	text-align: center;
}

#daytab>li.select {
	background-color: skyblue;
	color: white;
}

.datepicker {
	background-color: #ffffff;
}

.form-group label {
	width: 80px;
	text-align: left;
}

#route .spot {
	border: 1px solid #c0c0c0;
	padding: 8px;
	cursor: pointer;
}

.spot .time {
	display: block;
	width: 4em;
	width: 60px;
	text-align: center;
	font-size: 14px;
}

.spot .name {
	width: 192px;
	height: 70px;
	padding: 0 3px;
	overflow: hidden;
}

.spot .icon {
	width: 32px;
	float: left;
	margin: 4px 8px 4px 0;
}

.target-spot {
	border: 3px solid #FFAB00;
	font-size: 14px;
}

.move-before, .move-after {
	margin-left: 16px;
	padding: 8px;
}

.move-before {
	border-left: 4px solid #0000ff;
}

.move-after {
	border-left: 4px solid #ff0000;
}

#route {
	margin-bottom: 8px;
	background: #f2f2f2;
	font-size: 14px;
	padding: 10px 0;
	font-feature-settings: "palt";
}

#map {
	height: 740px;
}

#spotList {
	display: table;
	width: 100%;
	padding-top: 10px;
}

#spotList div.row {
	display: table-row;
}

#spotList div.cell {
	display: table-cell;
	border: 1px solid #c8c8c8;
	width: 33%;
	padding: 5px;
}

.footer {
	width: 100%;
	height: 60px;
	text-align: center;
	padding-top: 20px;
	color: #777777;
	margin-top: 8px;
}

.map-content {
	overflow: hidden;
	padding: 0;
	border-left: 1px solid #d5d5d5;
}

.zone-spot-list {
	position: absolute;
	max-height: 700px;
	top: 0;
	left: 0;
	width: 300px;
	width: 280px;
	border-left: 0;
	border-radius: 0px 5px 5px 0px;
	z-index: 100;
	margin-left: -280px;
	padding: 0;
	font-size: 0;
}

.zone-spot-list-header {
	min-height: 70px;
	width: 280px;
	font-size: 14px;
	vertical-align: middle;
	background: #fff;
	margin: 0;
	background: #fff;
	border-top: 1px solid #d5d5d5;
	border-bottom: 1px solid #d5d5d5;
	line-height: 18px;
}

.zone-spot-list-content {
	display: block;
	overflow-y: scroll;
	overflow-x: hidden;
	padding: 0;
	background: rgba(255, 255, 255, 0.8);
	-ms-overflow-style: none;
	border-bottom-right-radius: 5px;
	overflow-y: hidden;
}

.zone-spot-list-content::-webkit-scrollbar {
	display: none;
}

.zone-spot-list-content a {
	display: table;
	height: 60px;
	border-bottom: 1px solid #d5d5d5;
	padding: 0;
	margin: 0;
	overflow: hidden;
	text-decoration: none;
}

.zone-spot-list-content a:hover {
	background: rgba(200, 220, 240, 0.7);
}

.zone-spot-list-content a span {
	display: table-cell;
	vertical-align: middle;
	padding: 5px 5px 5px 10px;
	margin: 0;
	line-height: 60px;
	width: 280px;
	height: 60px;
	font-size: 14px;
	color: #333;
	line-height: 1.4;
}

.zone-spot-list-content a div {
	display: table-cell;
	margin: 0;
	width: 0;
	height: 0;
}

.zone-spot-list-content a:last-child, .zone-spot-list-content a:last-child span
	{
	border-bottom-right-radius: 5px;
	/*border: 0;*/
}

#zone-spot-list-content-inner {
	width: calc(100% + 17px);
	overflow-y: scroll;
	max-height: 730px;
	position: relative;
}

/*-----------------------------------------------
	デザイン変更　-20180822
-------------------------------------------------*/
/*ヘッダー*/
.header-line-wrap {
	letter-spacing: -.4em;
	font-size: 0;
}

.header-line {
	height: 5px;
	display: inline-block;
	letter-spacing: normal;
	width: 50%;
}

.header-line.left {
	background: #40a3e2;
}

.header-line.right {
	background: #e4546f;
}

/*メインビジュアル*/
.mainv-area {
	width: 100%;
	background: url(../img/mainv_bg.png);
	min-height: 510px;
	margin-bottom: 20px;
}

.mainv {
	margin-top: 10px;
}

.mainv-area-content {
	width: 1170px;
	background: url(../img/mainv.png) no-repeat;
	margin: 0 auto;
}

.container {
	position: relative;
	margin-bottom: 10px;
}

.top-contents {
	letter-spacing: -.4em;
	margin-top: 30px;
	padding: 0 15px;
	min-height: 455px;
}

.top-contents-left {
	display: inline-block;
	letter-spacing: normal;
	width: 610px;
	vertical-align: top;
	margin-top: 110px;
}

.top-contents h1 {
	font-size: 38px;
	font-weight: bold;
	color: #625356;
	text-align: center;
	margin-bottom: 30px;
}

.top-contents h1 img {
	vertical-align: top;
	margin-right: 10px;
}

.top-contents p {
	font-size: 17px;
	color: #625356;
	text-align: center;
	font-feature-settings: "palt";
	font-weight: bold;
	line-height: 30px;
}

.top-contents p.attention_top {
	margin-top: 156px;
	text-align: left;
	line-height: 20px;
	font-size: 16px;
	color: darkslategray;
}

.top-contents-right {
	width: 510px;
	background: rgba(255, 255, 255, 0.8);
	border-radius: 4px;
	padding: 25px 0 25px 25px;
	margin: 0 0 30px 20px;
	border: none;
	display: inline-block !important;
	letter-spacing: normal;
}

/*フォーム周り*/
.top-form-area {
	padding: 0;
}

.form-control {
	border: 1px solid #999;
	display: inline-block;
	width: auto;
	vertical-align: middle;
}

.top-form-area .form-group {
	display: block;
	margin-top: 0;
	margin-bottom: 20px;
}

.form-group img {
	margin-right: 8px;
}

.form-group.genre select {
	min-width: 135px;
}

.form-group.genre select+label {
	width: 90px;
}

.form-group.genre select+label img {
	margin-left: 20px;
}

.form-group .destination  img {
	margin-left: 2px;
	margin-right: 6px;
}

.form-group #destination {
	width: 370px;
}

.line-before-form, .line-after-form {
	position: relative;
}

.line-before-form:after, .line-after-form:after {
	content: "";
	position: absolute;
	top: 31px;
	left: 7px;
	display: block;
	width: 3px;
	height: 25px;
	border-radius: 2px;
}

.line-before-form:after {
	background: #0061c5;
}

.line-after-form:after {
	background: #ca0039;
}

.top-contents .btn-wrapper {
	margin: 30px 0 0;
}

.btn-search {
	background: #ffae00;
	font-size: 18px;
	border-radius: 4px;
	border: none;
	width: 200px;
	line-height: 34px;
	padding: 0;
	font-weight: bold;
	letter-spacing: 0.3em;
	outline: none !important;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;
	-webkit-box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.2);
	-moz-box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.2);
	box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.2);
}

.btn-search:hover, .btn-search:active, .btn-search:focus {
	background-color: #ff9600 !important;
}
/*コンテンツエリア*/
.content-area {
	width: 1170px;
	margin: 0 auto;
	padding: 0 15px;
	display: table;
}

.content-left {
	width: 300px;
	background: #f2f2f2;
	display: table-cell;
	vertical-align: top;
}

.content-left .attention {
	margin-left: 12px;
	margin-top: 10px;
}

.content-right {
	width: 840px;
	position: relative;
	display: table-cell;
	vertical-align: top;
	background: #f2f2f2;
}

#map {
	height: 810px;
}

@media ( min-width : 992px) {
	.col-md-3 {
		width: 300px;
		padding: 0;
	}
	.col-md-9 {
		width: 840px;
	}
}
/*サイドメニュー*/
#route .spot {
	border: none;
	padding: 0;
	cursor: pointer;
	padding: 0;
	margin: -10px 0;
	height: 70px;
}

#route .spot div {
	display: table-cell;
	vertical-align: middle;
}

.spot .time span {
	font-weight: bold;
	color: #1e91d1;
	display: block;
	font-size: 16px;
}

.spot#start .time span, .spot#goal .time span {
	color: #333;
}

.spot .time .vertical-line {
	width: 2px;
	background: #999;
	height: 8px;
	margin: 0 auto;
}

.spot .spot_icon {
	position: relative;
}

.spot_icon.line-before:before {
	content: "";
	width: 4px;
	background: #0061c5;
	position: absolute;
	display: block;
	height: 125%;
	left: 23px;
}

.spot_icon.line-after:before {
	content: "";
	width: 4px;
	background: #ca0039;
	position: absolute;
	display: block;
	height: 125%;
	left: 23px;
}

.spot .spot_icon .icon {
	width: 48px;
	float: none;
	margin: 0 0 2px 0;
	position: relative;
}

#start .spot_icon .icon {
	margin-bottom: -1px;
}

.spot.target-spot .name {
	font-weight: bold;
}

.spot .name span {
	margin-left: 0.5em;
	font-size: 10px;
}

.spot.target-spot .name span {
	font-weight: normal;
	font-size: 14px;
}

.spot.target-spot .name span.spot-name {
	font-weight: bold;
	visibility: hidden;
	margin-left: 0;
}

.move-before, .move-after {
	margin-left: 83px;
	padding: 0 8px;
	font-size: 12px;
	color: #777;
	height: 35px;
	line-height: 35px;
	position: relative;
}

.transit-margin .move-before, .transit-margin .move-after {
	height: 10px;
}

.move-before {
	border-left: 4px solid #0061c5;
}

.move-after {
	border-left: 4px solid #ca0039;
}

#route .spot.active {
	background: #fff;
}

#route .spot:hover {
	background: #f9f9f9;
}

#route .spot.active .name {
	font-weight: bold;
	color: #1e91d1;
}

/* 乗換 */
#route .transit {
	cursor: pointer;
}

#route .transit.active {
	background: #fff;
	font-weight: bold;
	color: #1e91d1;
}

#route .transit:hover {
	background: #f9f9f9;
}

#route .transit span:after {
	content: url(../img/arrow-right.png);
	margin: 6px;
}

.transit-detail {
	position: absolute;
	max-height: 700px;
	top: 0;
	left: 0;
	width: 280px;
	margin-left: -280px;
	z-index: 100;
	padding: 0;
	overflow-x: hidden;
	overflow-y: hidden;
}

.transit-detail-header {
	width: 280px;
	font-size: 14px;
	vertical-align: middle;
	background: #fff;
	margin: 0;
	border-top: 1px solid #d5d5d5;
	border-bottom: 1px solid #d5d5d5;
	line-height: 18px;
	border-top-right-radius: 5px;
}

.transit-detail-header-inner {
	display: table;
	padding: 0 10px;
	position: relative;
	min-height: 70px;
	vertical-align: middle;
}

.transit-detail-header-inner span {
	display: table-cell;
	vertical-align: middle;
	padding: 8px 0 4px 10px;
	width: 222px;
}

.transit-detail-header-inner span.icon {
	width: 50px;
}

.transit-detail-header-inner span .transfers-time {
	padding: 0;
	width: 100%;
	font-size: 12px;
	line-height: 2;
}

.transit-detail-content {
	display: block;
	width: 280px;
	overflow-y: scroll;
	overflow-x: hidden;
	max-height: 630px;
	padding: 0;
	background: rgba(255, 255, 255, 0.8);
	-ms-overflow-style: none;
	border-bottom: 1px solid #d5d5d5;
	border-bottom-right-radius: 5px;
	width: calc(100% + 17px);
	padding-right: 17px;
}

.transit-detail-content::-webkit-scrollbar {
	display: none;
}

.transit-detail-content-inner {
	width: calc(100% + 17px);
	padding-right: 17px;
	overflow-x: hidden;
}

.transit-detail-content-inner>div {
	display: table;
	width: 280px;
	min-height: 60px;
	background: #f2f2f2;
}

.transit-detail-content-inner .departure::before,
	.transit-detail-content-inner .transfer::before,
	.transit-detail-content-inner .arrival::before {
	content: "";
	display: inline-block;
	vertical-align: middle;
	height: 100%;
	min-height: 60px; /* 任意のmin-heightを入力 */
}

.transit-detail-content-inner>div>div {
	display: table-cell;
	vertical-align: middle;
	padding: 2px 0;
}

.transit-detail-content-inner>div:nth-child(odd) .name span {
	display: block;
	max-height: 60px;
}

.transit-detail-content-inner>div>div:first-child {
	width: 40px;
}

.transit-detail-content-inner>div>div:nth-child(2) {
	width: 76px;
}

.transit-detail-content .transportation {
	font-size: 12px;
	background: #fff;
	color: #666;
	min-height: 40px;
}

.transit-detail-content .transportation .name {
	padding: 10px 10px 10px 0;
}

.transit-detail-content .transfer.station-direct {
	background: #fff;
}

.transit-detail-content .transfer.station-direct .time {
	background: #f2f2f2;
}

.transit-detail-content .station-icon span {
	display: block;
	width: 16px;
	height: 16px;
	margin-left: 12px;
	background: url(../img/station.png);
	position: relative;
	z-index: 10;
}

.transit-detail-content .name {
	padding-right: 12px;
}

.transit-detail-content .transfer.station-direct .line {
	background-image: url(../img/left-arrow.png);
	background-position: center right -1px;
	background-size: 40% 105%;
	background-repeat: no-repeat;
}

.transit-detail-content .transfer.station-direct .name {
	background: #f2f2f2;
}

.transit-detail-content .departure .departure-time {
	font-weight: bold;
	color: #3aa6e2;
}

.transit-detail-content .arrival .arrival-time {
	font-weight: bold;
}

.transit-detail-content .line {
	padding: 0;
	position: relative;
}

.transit-detail-content .line span {
	display: block;
	position: absolute;
	left: 18px;
	top: -24px;
	height: 100%;
	height: -webkit-calc(100% + 59px);
	height: -moz-calc(100% + 59px);
	height: -o-calc(100% + 59px);
	height: calc(100% + 59px);
	border-left: 4px solid #3aa6e2;
	overflow: hidden;
	z-index: 5;
	background-clip: padding-box;
}

@media all and (-ms-high-contrast:none) {
	*::-ms-backdrop, .transit-detail-content .line span {
		min-height: 102px\0;
	}
	*::-ms-backdrop, .transit-detail-content .transportation.walk .line span
		{
		min-height: 100px\0;
	}
}

.transit-detail-content .transportation.walk .line span {
	width: 24px;
	border: none;
	background: url(../img/walk-line.png) repeat-y;
}

.transit-detail-content .reduce {
	margin-left: 1px;
	font-size: 10px;
}

.transit-detail-content .platform {
	padding: 0;
	line-height: 0.8;
	position: relative;
}

.transit-detail-content .departure .track-number {
	position: absolute;
	top: 8px;
}

.transit-detail-content .arrival .track-number {
	position: absolute;
	bottom: 8px;
}

.transit-detail-content .estimation:after {
	margin-left: 1px;
	content: "△";
}

.transit-detail-content .comment {
	text-align: right;
	font-size: 10px;
	padding: 6px 0;
	color: #666;
	background: #fff;
}
/* ジャンル名のカラー */
#route .name span.genre {
	font-size: 13px;
	margin-left: 0;
	font-weight: bold;
}

#start .name span.genre {
	color: #0061c5;
}

#goal .name span.genre {
	color: #ca0039;
}

.target-spot .name span.genre {
	color: #1e91d1;
}

.spot .name span.zone {
	font-size: 10px;
}

.sightseeing span.genre {
	color: #2da08e;
}

.lunch span.genre {
	color: #e06807;
}

.play span.genre {
	color: #b88b00;
}

.cafe span.genre {
	color: #7b5fbb;
}

.shopping span.genre {
	color: #c56977;
}

.zone-spot-list-header-inner span.genre {
	display: inline;
	padding-left: 0;
	width: 100%;
	font-size: 12px;
}
/* スポット選択 */
span.choose_spot, .spot .name span.choose_spot, a.choose_spot span {
	margin-left: 0;
}

#route .spot .name span.ek-choose-spot {
	display: block;
	width: 180px;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}

#route .spot .name span.ek-choose-spot .choose_spot {
	font-size: 14px;
	font-weight: bold;
}

span.choose_spot:before, a.choose_spot span:before {
	margin-right: 2px;
}

a.choose_spot span:before {
	margin-left: -14px;
}

.zone-spot-list .choose_spot span {
	padding-left: 24px;
	position: relative;
}

.zone-spot-list-header-inner span.choose_spot {
	display: inline;
	margin-left: 0;
	margin-right: 0;
	padding-left: 0;
	padding-right: 0;
	width: 212px;
}

.zone-spot-list-content a.choose_spot {
	background: #fff;
}

.zone-spot-list-content.sightseeing a.choose_spot span:before {
	content: url(../img/choose_sightseeing_spot.png);
}

.zone-spot-list-content.lunch a.choose_spot span:before {
	content: url(../img/choose_lunch_spot.png);
}

.zone-spot-list-content.play a.choose_spot span:before {
	content: url(../img/choose_play_spot.png);
}

.zone-spot-list-content.cafe a.choose_spot span:before {
	content: url(../img/choose_cafe_spot.png);
}

.zone-spot-list-content.shopping a.choose_spot span:before {
	content: url(../img/choose_shopping_spot.png);
}
/* footer */
.footer {
	width: 100%;
	height: 35px;
	text-align: center;
	padding-top: 0;
	color: #333;
	margin-top: 0;
}
/*js周り追加分*/
.zone-spot-list-header-inner {
	display: table-cell;
	padding: 10px;
	position: relative;
	height: 100%;
}

.zone-spot-list-header-inner img {
	display: table-cell;
}

.zone-spot-list-header-inner span {
	display: table-cell;
	vertical-align: middle;
	padding: 0 0 0 10px;
	width: 222px;
	overflow: hidden;
}

.zone-spot-list-header-inner span .choose_spot {
	display: block;
	width: 200px;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}

.zone-spot-list-header-inner:after {
	content: "";
	width: 15px;
	background: #e18f9b;
	display: inline-block;
	height: 100%;
	position: absolute;
	top: 0;
	right: -15px;
	border-radius: 0px 5px 5px 0px;
	display: table-cell;
}

.zone-spot-list-header-inner.lunch:after {
	background: #f66e00;
	border: 1px solid #f66e00;
}

.zone-spot-list-header-inner.play:after {
	background: #f8af00;
	border: 1px solid #f8af00;
}

.zone-spot-list-header-inner.cafe:after {
	background: #a993f3;
	border: 1px solid #a993f3;
}

.zone-spot-list-header-inner.shopping:after {
	background: #e18f9b;
	border: 1px solid #e18f9b;
}

.zone-spot-list-header-inner.sightseeing:after {
	background: #0dc9ab;
	border: 1px solid #0dc9ab;
}

.zone-spot-list-header-content {
	display: table;
}
/* フォームエラー */
.error-content {
	background: #fce5ec;
	border-radius: 3px;
	padding: 20px;
	margin-bottom: 20px;
	text-align: center;
	margin-right: 25px;
}

.error-content p {
	font-size: 16px;
	line-height: 24px;
	display: inline-block;
	margin-bottom: 0;
	text-align: left;
	padding-left: 50px;
	position: relative;
}

.error-content p::before {
	content: url(../img/icon-exclamation.png);
	position: absolute;
	top: 50%;
	left: 0;
	margin-top: -16px;
}

.popup-bg {
	position: fixed;
	top: 0;
	z-index: 100;
	background: rgba(0, 0, 0, 0.20);
	display: block;
	width: 100%;
	height: 100%;
}

.popup {
	background: #fff;
	display: block;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	z-index: 998;
	width: 500px;
	padding: 40px;
	border-radius: 6px;
	overflow-y: auto;
	max-height: calc(100vh - 30px);
}

.popup h2 {
	font-size: 22px;
	margin-top: 0 !important;
	margin-bottom: 20px !important;
	text-align: center;
}

.popup h2.sightseeing::before {
	content: url(../img/sightseeing_5.png);
}

.popup h2.lunch::before {
	content: url(../img/lunch_5.png);
}

.popup h2.play::before {
	content: url(../img/play_5.png);
}

.popup h2.cafe::before {
	content: url(../img/cafe_5.png);
}

.popup h2.shopping::before {
	content: url(../img/shopping_5.png);
}

.popup h2 span {
	vertical-align: 8px;
	margin-left: 4px;
}

.popup table {
	width: 100%;
	border-collapse: separate;
}

.popup table th {
	border-top: 1px solid #dcdcdc;
	background-color: #f6f6f6;
	width: 120px;
	padding: 15px;
	text-align: center;
}

.popup table td {
	border-top: 1px solid #dcdcdc;
	background-color: #fff;
	padding: 15px;
}

.popup table tr:last-child td, .popup table tr:last-child th {
	border-bottom: 1px solid #dcdcdc;
}

.popup .alert {
	font-size: 14px;
	color: #de0044;
	text-indent: -3em;
	padding-left: 3em;
	padding-right: 0;
}

.btn-ok {
	background: #0098e6;
	font-size: 20px;
	border-radius: 4px;
	border: none;
	width: 240px;
	line-height: 48px;
	padding: 0;
	font-weight: bold;
	letter-spacing: 0.3em;
	outline: none !important;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;
	-webkit-box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.2);
	-moz-box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.2);
	box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.2);
}

.btn-ok:hover, .btn-ok:active, .btn-ok:focus {
	background-color: #0086ca !important;
}

.top-language-selector {
	text-align: right;
	padding-right: 20px;
	padding-bottom: 20px;
}

.disclaimer-content {
	margin-bottom: 50px;
}

.headLine01 h1 {
	font-size: 150%;
	line-height: 150%;
	padding: 0 8px;
	border-bottom: 5px solid #40a3e2;
	line-height: 120%;
	letter-spacing: 1px;
	clear: both;
}

.headLine02 h2 {
	font-size: 130%;
	line-height: 120%;
	padding: 4px 8px 3px;
	background-color: #ECECEC;
	border-left: 6px solid #40a3e2;
	letter-spacing: 1px;
	clear: both;
}

.content-left .banner {
	margin: 30px 10px auto;
}