@charset "UTF-8";
/* ---------------------------------------
  特別な旅への招待状
-----------------------------------------*/
main {
	overflow: initial;
}

@media screen and (max-width: 767px) {
	.p-map .l-header .inner {
		-webkit-box-pack: justify;
		    -ms-flex-pack: justify;
		        justify-content: space-between;
	}
	.p-map .l-header .logo_wrap {
		position: static;
	}
	.p-map .l-header .logo_wrap .logo {
		width: 6rem;
		height: 6rem;
	}
	.p-map .l-header .logo_wrap .logo img {
		width: 4.3rem;
	}
	.p-map .l-header .logo_wrap .date {
		display: none;
	}
}
.p-map-area-wrap {
	padding-top: 12.5rem;
	position: relative;
	display: -ms-grid;
	display: grid;
	-ms-grid-rows: auto 1fr;
	grid-template-rows: auto 1fr;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: start;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap {
		padding-top: 1rem;
	}
}
.p-map-area-wrap .map {
	overflow: hidden;
	margin-top: 1.5rem;
	-ms-grid-column: 1;
	-ms-grid-column-span: 1;
	grid-column: 1/2;
	-ms-grid-row: 1;
	-ms-grid-row-span: 2;
	grid-row: 1/3;
	position: sticky;
	top: -10rem;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .map {
		z-index: 2;
		width: 100%;
		height: auto;
		aspect-ratio: 780/740;
		margin-top: -1rem;
		-ms-grid-row: 1;
		-ms-grid-row-span: 1;
		grid-row: 1/2;
		top: 0;
		background-color: #fff;
	}
}
@media screen and (min-width: 768px) and (max-height: 800px) {
	.p-map-area-wrap .map {
		top: -5rem;
	}
}
.p-map-area-wrap .map .box {
	max-width: 132rem;
	margin: 0 auto;
	-webkit-transition: -webkit-transform 0.3s;
	transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
	transition: transform 0.3s, -webkit-transform 0.3s;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .map .box {
		width: 119%;
		-webkit-transform: translate(-17rem, -7rem);
		        transform: translate(-17rem, -7rem);
	}
}
@media screen and (min-width: 768px) and (max-height: 800px) {
	.p-map-area-wrap .map .box {
		max-width: 90rem;
		-webkit-transform: translate(10rem, 0);
		        transform: translate(10rem, 0);
	}
}
@media screen and (min-width: 768px) and (max-height: 600px) {
	.p-map-area-wrap .map .box {
		max-width: 70rem;
		-webkit-transform: translate(15rem, 0);
		        transform: translate(15rem, 0);
	}
}
.p-map-area-wrap .map .box.is-east {
	-webkit-transform: translate(-5rem, 10rem);
	        transform: translate(-5rem, 10rem);
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .map .box.is-east {
		-webkit-transform: translate(-20rem, 0);
		        transform: translate(-20rem, 0);
	}
}
.p-map-area-wrap .map .box.is-west {
	-webkit-transform: translate(40rem, -40rem);
	        transform: translate(40rem, -40rem);
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .map .box.is-west {
		-webkit-transform: translate(5rem, -23rem);
		        transform: translate(5rem, -23rem);
	}
}
@media screen and (min-width: 768px) and (max-height: 800px) {
	.p-map-area-wrap .map .box.is-west {
		-webkit-transform: translate(35rem, -35rem);
		        transform: translate(35rem, -35rem);
	}
}
@media screen and (min-width: 768px) and (max-height: 600px) {
	.p-map-area-wrap .map .box.is-west {
		-webkit-transform: translate(25rem, -25rem);
		        transform: translate(25rem, -25rem);
	}
}
.p-map-area-wrap .map .box .prefecture {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
.p-map-area-wrap .map .box .prefecture svg {
	width: 100%;
	height: 100%;
}
.p-map-area-wrap .map .box .prefecture svg .group {
	opacity: 0;
	-webkit-transition-duration: 0.3s;
	        transition-duration: 0.3s;
}
.p-map-area-wrap .map .box .prefecture.is-active svg .group {
	opacity: 1;
}
.p-map-area-wrap .map .box .prefecture.is-active svg .group._01 {
	-webkit-transition-delay: 0s;
	        transition-delay: 0s;
}
.p-map-area-wrap .map .box .prefecture.is-active svg .group._02 {
	-webkit-transition-delay: 0.3s;
	        transition-delay: 0.3s;
}
.p-map-area-wrap .map .box .prefecture.is-active svg .group._03 {
	-webkit-transition-delay: 0.6s;
	        transition-delay: 0.6s;
}
.p-map-area-wrap .ttl-box {
	z-index: 10;
	width: 100%;
	max-width: 108rem;
	margin: 0 auto;
	padding: 1rem 2rem 0;
	-ms-grid-column: 1;
	-ms-grid-column-span: 1;
	grid-column: 1/2;
	-ms-grid-row: 1;
	-ms-grid-row-span: 1;
	grid-row: 1/2;
	position: sticky;
	top: 0;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .ttl-box {
		pointer-events: none;
		max-width: inherit;
		padding: 1rem 7rem 25rem;
		-ms-grid-row: 1;
		-ms-grid-row-span: 2;
		grid-row: 1/3;
		top: 2rem;
	}
}
.p-map-area-wrap .ttl {
	font-size: 5rem;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .ttl {
		pointer-events: initial;
		color: #ccc;
		font-size: 7rem;
		line-height: 1.0714285714;
	}
}
.p-map-area-wrap .catch {
	margin-top: 3rem;
	font-size: 4.4rem;
	line-height: 1;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .catch {
		width: -webkit-fit-content;
		width: -moz-fit-content;
		width: fit-content;
		margin-top: 15rem;
		margin-left: auto;
		position: relative;
		font-size: 5.6rem;
		-webkit-writing-mode: vertical-lr;
		    -ms-writing-mode: tb-lr;
		        writing-mode: vertical-lr;
	}
}
.p-map-area-wrap .catch .scroll {
	font-size: 2rem;
	line-height: 1;
	color: #fff;
	font-family: "BIZ UDGothic", sans-serif;
	position: absolute;
	left: 60%;
	top: calc(100% + 3rem);
	z-index: 1;
	width: 14.9rem;
	-webkit-transform: rotate(90deg);
	        transform: rotate(90deg);
	-webkit-transform-origin: center left;
	        transform-origin: center left;
	-webkit-writing-mode: initial;
	    -ms-writing-mode: initial;
	        writing-mode: initial;
}
.p-map-area-wrap .catch .scroll_line {
	display: block;
	position: absolute;
	left: 6.9rem;
	bottom: 0.2rem;
	width: 8rem;
	height: 0.1rem;
}
.p-map-area-wrap .catch .scroll_line::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 0.1rem;
	background: #fff;
	-webkit-animation: move_line 2s ease-out infinite;
	        animation: move_line 2s ease-out infinite;
}
@-webkit-keyframes move_line {
	0% {
		left: 0;
		width: 0;
	}
	50% {
		left: 0;
		width: 100%;
	}
	50.1% {
		left: 0;
		width: 100%;
	}
	100% {
		left: 100%;
		width: 0;
	}
}
@keyframes move_line {
	0% {
		left: 0;
		width: 0;
	}
	50% {
		left: 0;
		width: 100%;
	}
	50.1% {
		left: 0;
		width: 100%;
	}
	100% {
		left: 100%;
		width: 0;
	}
}
.p-map-area-wrap .text {
	margin-top: 1em;
	font-size: 2.4rem;
	line-height: 2.0833333333;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .text {
		font-size: 3.2rem;
	}
}
.p-map-area-wrap .c-wrap {
	-ms-grid-column: 1;
	-ms-grid-column-span: 1;
	grid-column: 1/2;
	-ms-grid-row: 2;
	-ms-grid-row-span: 1;
	grid-row: 2/3;
	padding-bottom: 30.5rem;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .c-wrap {
		padding-bottom: 4rem;
		color: #fff;
		background-color: #f00;
	}
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .area-list {
		max-width: 58rem;
	}
}
.p-map-area-wrap .area-ttl {
	margin-top: 5.7rem;
	color: #f00;
	font-size: 2.4rem;
	font-weight: 700;
	text-decoration: underline;
	text-underline-offset: 0.55em;
	text-decoration-thickness: 0.2rem;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .area-ttl {
		margin-top: 3rem;
		color: #fff;
		font-size: 3.2rem;
	}
}
.p-map-area-wrap .area-ttl.is-hidden {
	opacity: 0;
}
.p-map-area-wrap .place-list {
	margin-top: 5.9rem;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .place-list {
		margin-top: 7.8rem;
		margin-bottom: 7.6rem;
	}
}
.p-map-area-wrap .place-item {
	line-height: 1.5;
	font-size: 2.4rem;
	font-weight: 400;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .place-item {
		font-size: 3.2rem;
	}
}
.p-map-area-wrap .place-item.is-hidden {
	opacity: 0;
}
.p-map-area-wrap .place-item a {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-transition: color 0.3s, -webkit-filter 0.3s;
	transition: color 0.3s, -webkit-filter 0.3s;
	transition: color 0.3s, filter 0.3s;
	transition: color 0.3s, filter 0.3s, -webkit-filter 0.3s;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .place-item a {
		-webkit-transform: translateZ(0);
		        transform: translateZ(0);
	}
	.p-map-area-wrap .place-item a.is-active {
		-webkit-filter: invert(1);
		        filter: invert(1);
	}
}
.p-map-area-wrap .place-item a:hover {
	opacity: 1;
}
@media screen and (min-width: 768px) {
	.p-map-area-wrap .place-item a:hover {
		color: #f00;
	}
	.p-map-area-wrap .place-item a:hover svg {
		fill: #f00;
	}
}
.p-map-area-wrap .place-item a svg {
	width: 1em;
	height: auto;
	margin-left: 0.2em;
	-webkit-transition: fill 0.3s;
	transition: fill 0.3s;
	vertical-align: text-bottom;
}
@media screen and (max-width: 767px) {
	.p-map-area-wrap .place-item a svg {
		fill: #fff;
	}
}
.p-map-area-wrap .place-item + .place-item {
	margin-top: 1.4rem;
}
.p-map-area-wrap .place-prefecture {
	margin-right: 1em;
	-ms-flex-negative: 0;
	    flex-shrink: 0;
	font-weight: inherit;
}
@media screen and (min-width: 768px) {
	.p-map .l-footer {
		margin-top: -20rem;
		position: relative;
		background-color: #fff;
	}
}
/*# sourceMappingURL=map.css.map */