@charset "UTF-8";

/* MV 
-----------------------------------------------------------------*/
.photo-top-header {
	height: 860px;
}
.photo-top-mv {
	position: relative;
	height: 100%;
	background: url(/wed/photo/top/images/mv.webp) no-repeat center top;
	.h1-wrap {
		display: flex;
		flex-direction: column;
		margin-right: 0;
		margin-left: auto;
		color: #7b6446;
		font-family: "游明朝体", "Yu Mincho", YuMincho, serif;
		text-align: center;
		line-height: 1;
		white-space: nowrap;
		text-shadow: 3px 3px 10px rgba(255, 255, 255, .7),
			-3px 3px 10px rgba(255, 255, 255, .7),
			3px -3px 10px rgba(255, 255, 255, .7),
			-3px -3px 10px rgba(255, 255, 255, .7);
	}
	h1 {
		font-weight: 500;
		letter-spacing: -0.1em;
	}
	.h1-jp {
		font-size: 6.0rem;
	}
}
.photo-mv-caption {
	width: 100%;
}
@media (min-width: 1921px) {
	.photo-top-mv {
		background-size: cover;
	}
}
@media (min-width: 769px) and (min-width: 1246px) {
	.photo-top-mv {
		.h1-wrap {
			top: 190px;
			left: 50%;
		}
	}
}
@media (min-width: 769px) and (max-width: 1245px) {
	.photo-top-mv {
		.h1-wrap {
			left: auto;
			right: 2vw;
		}
	}
}
@media (min-width: 769px) {
	.photo-top-mv {
		.h1-wrap {
			position: absolute;
			top: 190px;
		}
	}
}
@media (max-width: 768px) {
	.photo-top-header {
		position: relative;
		height: auto;
	}
	.photo-top-mv {
		display: flex;
		flex-direction: column;
		background: transparent;
		aspect-ratio: 750 / 600;
		&::after {
			content: "";
			display: block;
			width: 100%;
			height: 90px;
			background-color: #ffffff;
		}
		.h1-wrap {
			position: relative;
			top: -17px;
			align-items: center;
			gap: 10px;
			margin-right: auto;
		}
		.h1-en {
			position: relative;
			left: -100px;
			width: calc(274px / 2);
		}
		.h1-jp {
			/* font-size: min(calc(68 / 750 * 100vw), 3.8rem); */
			font-size: 3.6rem;
			letter-spacing: -0.1em;
			span {
				font-size: 0.722em;
				letter-spacing: 0.05em;
			}
		}
	}
	.photo-mv-caption {
		position: absolute;
		bottom: 5px;
		color: #584b3a;
		font-weight: normal;
	}
}
@media (max-width: 375px) {
	.photo-top-mv {
		h1 {
			font-size: 3.2rem;
		}
	}
}

/* MAIN 
-----------------------------------------------------------------*/
.photo-top-main {
	padding-bottom: 40px;
	background: url(/wed/photo/top/images/bg-main.webp) no-repeat center top / 100%;
}
.photo-top-lead {
	padding-block: 80px;
	text-align: center;
}
.photo-top-lead-copy {
	position: relative;
	width: fit-content;
	margin-inline: auto;
	padding: 2px 60px;
	background-image: linear-gradient(90deg, transparent, #d8d1ba 10%, #e5e2cd 30%, #f2f2df 70%, #d8d1ba 90%, transparent);
	span {
		position: relative;
		z-index: 1;
		color: #4a3c1c;
		font-family: "游明朝体", "Yu Mincho", YuMincho, serif;
		font-size: 1.111em;
		font-weight: 500;
	}
	.shadow {
		position: absolute;
		width: 100%;
		left: 0;
		color: rgba(74, 60, 28, 0.3);
		text-shadow: 0px 0px 1px #ffffff,
			0px 0px 1px #ffffff,
			0px 0px 2px #ffffff,
			0px 0px 3px #ffffff,
			0px 0px 4px #ffffff;
	}
}
@media (min-width: 769px) {
	.photo-top-main {
		min-width: 1140px;
	}
}
@media (max-width: 768px) {
	.photo-top-main {
		margin-top: 140px;
		background-image: url(/wed/photo/top/images/bg-main-sp.webp);
		font-size: 16px;
	}
	.photo-top-lead {
		line-height: 1.94;
	}
	.photo-top-lead-copy {
		padding: 10px 20px 8px;
		line-height: 1.37;
	}
}

/* overview 
--------------------------------*/
.overview {
	position: relative;
	width: 100vw;
	margin-inline: calc(50% - 50vw);
	padding: 75px 0;
	&::before {
		content: "";
		position: absolute;
		top: 0;
		left: 50%;
		transform: translateX(-50%);
		display: block;
		width: 2200px;
		height: 2000px;
		background-image: linear-gradient(180deg, #fcf9f2, #ffffff 70%, transparent);
		border-top-left-radius: 50%;
		border-top-right-radius: 50%;
	}
	.h2-en {
		width: 433px;
	}
	.h2-jp {
		margin-top: -13px;
	}
}
.overview-list {
	position: relative;
	width: fit-content;
	margin-inline: auto;
	padding: 20px 25px;
	background-color: #ffffff;
	mark {
		background: linear-gradient(transparent 50%, #f8eec4 0%);
	}
	li::before {
		content: "";
		display: inline-block;
		width: 13px;
		aspect-ratio: 1 / 1;
		background-image: url(/wed/photo/images/bullet-ster-green.webp);
		background-size: 100%;
		margin-right: 5px;
	}
}
.overview-gallery-text {
	margin-top: 10px;
	padding-left: 50px;
	font-size: 16px;
	font-weight: bold;
	text-align: left;
}
.overview-bg-decor {
	position: absolute;
	top: -65px;
	left: 0;
	right: 0;
	margin-inline: auto;
}
@media (min-width: 769px) {
	.overview {
		min-width: 1140px;
		margin-inline: 0;
	}
}
@media (max-width: 768px) {
	.overview {
		padding-bottom: 0;
		&::before {
			width: 136vw;
			height: 100vw;
		}
		.h2-en {
			width: calc(621px / 2);
		}
	}
	.overview-bg-decor {
		top: -4vw;
	}
	.overview-list {
		gap: 20px;
		padding-inline: 20px;
		li {
			padding-left: 1em;
			text-indent: -1.1em;
		}
	}
	.overview-gallery {
		width: 100vw;
		margin-inline: calc(50% - 50vw);
	}
	.overview-gallery-text {
		padding-left: 20px;
	}
	.overview-image {
		aspect-ratio: 750 / 435;
		object-fit: cover;
	}
	.overview-caption {
		padding-right: 20px;
	}
}
#thumbnail-slider {
	.splide__track--nav > .splide__list > .splide__slide {
		flex: 1;
	}
	.splide__list {
		gap: 7px;
		align-items: flex-start;
	}
	.splide__slide {
		height: 125px;
		margin-right: 0 !important;
		filter: brightness(0.6);
		border: none;
		transition: .2s ease-in-out;
		img {
			height: 100%;
			object-fit: cover;
		}
	}
	.splide__slide.is-active {
		filter: brightness(1);
	}
	.splide__arrow {
		width: 25px;
		height: 45px;
		background: #a3c3cd;
		border-radius: 0;
		svg {
			display: none;
		}
	}
	.splide__arrow--prev {
		left: 0;
		clip-path: polygon(100% 0, 100% 100%, 0% 50%);
	}
	.splide__arrow--next {
		right: 0;
		clip-path: polygon(0 0, 0% 100%, 100% 50%);
	}
}
@media (min-width: 769px) {
	#thumbnail-slider {
		.splide__slide:hover {
			filter: brightness(1);
		}
	}
}
@media (max-width: 768px) {
	#thumbnail-slider {
		.splide__list {
			gap: 2px;
		}
		.splide__slide {
			height: auto;
			aspect-ratio: 107 / 82;
		}
		.splide__arrow {
			width: 18px;
			height: 30px;
		}
	}
}

/* benefit 
--------------------------------*/
.benefit {
	.h2-en {
		width: 451px;
	}
	.h2-jp {
		margin-top: -24px;
	}
}
.benefit-list {
	width: 100%;
	gap: 80px;
}
.benefit-item {
	flex: 1;
	aspect-ratio: auto;
	height: auto;
	padding: 45px 45px 45px 65px;
	background-position: left 65px top 108px;
	dd {
		padding-left: 130px;
		font-size: 20px;
		li::before {
			content: "";
			display: inline-block;
			width: 13px;
			aspect-ratio: 1 / 1;
			background-size: 100%;
			margin-right: 5px;
		}
	}
	&.-trip {
		background-size: 77px;
		&::before {
			right: -62px;
		}
		li::before {
			background-image: url(/wed/photo/images/bullet-ster-green.webp);
		}
	}
	&.-photo {
		background-size: 75px;
		li::before {
			background-image: url(/wed/photo/images/bullet-ster-pink.webp);
		}
	}
}
.benefit-item-title {
	margin-bottom: 20px;
	font-family: "游明朝体", "Yu Mincho", YuMincho, serif;
	font-size: 2.6rem;
	font-weight: 500;
}
.benefit-text {
	padding-block: 30px;
	background-color: #fcfcf7;
}
.benefit-text-list {
	width: fit-content;
	margin-inline: auto;
	li {
		height: 40px;
		font-size: 16px;
		strong {
			color: #c55e72;
		}
		&::before {
			content: "";
			display: inline-block;
			width: 13px;
			aspect-ratio: 1 / 1;
			background-image: url(/wed/photo/images/bullet-ster-pink.webp);
			background-size: 100%;
			margin-right: 5px;
		}
		&::after {
			content: "";
			display: block;
			margin-top: 5px;
			height: 1px;
			background-image: linear-gradient(to right, #d0cfcc 4px, transparent 2px);
			background-size: 6px 1px;
			/* 4px + 2px = 6px */
			background-repeat: repeat-x;
		}
	}
}
@media (min-width: 769px) {
	.benefit-item {
		&.-trip {
			&::before {
				width: 44px;
			}
		}
	}
}
@media (max-width: 768px) {
	.benefit {
		.h2-en {
			width: calc(580px / 2);
		}
	}
	.photo-top .benefit-list {
		flex-direction: column;
		gap: 40px;
	}
	.benefit-item {
		width: 100%;
		padding: 30px 25px;
		background-position: left 30px top 80px;
		background-size: 50px;
		dd {
			padding-left: 75px;
			font-size: 16px;
		}
		&.-trip {
			background-size: 50px;
			&::before {
				right: 0;
				left: 0;
				top: auto;
				bottom: -42px;
				margin: auto;
			}
		}
		&.-photo {
			background-size: 50px;
		}
	}
	.benefit-item-title {
		margin-bottom: 15px;
		font-size: 2.0rem;
	}
	.benefit-text {
		padding: 25px 20px;
	}
	.benefit-text-list {
		li {
			height: auto;
			padding-top: 7px;
			padding-left: 1em;
			text-indent: -1.1em;
			line-height: 1.5;
			&::after {
				margin-top: 10px;
			}
		}
	}
}

/* brochure 
--------------------------------*/
.brochure {
	width: 750px;
	margin: 70px auto 0;
	.button.brochure-btn {
		margin-left: 0;
		margin-top: 0;
	}
}
.brochure-heading {
	margin-bottom: 30px;
}
.brochure-inner {
	padding: 35px 40px;
	background-color: #eef9f9;
	border-radius: 10px;
	display: grid;
	grid-template-columns: 170px 1fr;
	grid-template-rows: 1fr 65px;
	gap: 50px 60px;
	grid-template-areas:
		"brochure-image brochure-text"
		"brochure-image brochure-btn";
}
.brochure-image {
	grid-area: brochure-image;
}
.brochure-text {
	grid-area: brochure-text;
	align-self: end;
}
.brochure-btn {
	grid-area: brochure-btn;
	align-self: end;
}
.brochure-text {
	font-size: 16px;
}
.brochure-btn {
	max-width: 300px;
	&::after {
		right: 30px;
	}
}
@media (min-width: 769px) {
	.brochure-btn:hover {
		&::after {
			right: 27px;
		}
	}
}
@media (max-width: 768px) {
	.brochure {
		width: 100%;
		margin-top: 60px;
		.button.brochure-btn {
			margin-inline: auto;
		}
	}
	.brochure-inner {
		padding: 20px;
		grid-template-columns: 30vw 1fr;
		grid-template-rows: 1fr;
		gap: 20px;
		grid-template-areas:
			"brochure-image brochure-text"
			"brochure-btn brochure-btn";
	}
	.brochure-image {
		height: auto;
		align-self: center;
	}
	.brochure-text {
		align-self: center;
	}
}

/* colmun 
--------------------------------*/
.colmun {
	background-color: #eef9f9;
	.h2-en {
		width: 146px;
	}
	.h2-jp {
		margin-top: 12px;
	}
}
.colmun-link {
	display: flex;
	align-items: center;
	gap: 40px;
	width: 100%;
	max-width: 890px;
	margin-inline: auto;
	padding: 15px;
	background-color: #ffffff;
	font-size: 0.88em;
}
a.colmun-link {
	color: #3a342c;
}
.colmun-image {
	flex: 0 0 203px;
}
@media (max-width: 768px) {
	.colmun {
		.h2-en {
			width: calc(243px / 2);
		}
	}
	.colmun-link {
		gap: 10px;
		p {
			line-height: 1.43;
			text-align: left;
		}
	}
	img.colmun-image {
		flex: none;
		max-width: calc(230 / 750 * 100vw);
	}
}

/* faq 
--------------------------------*/
.faq {
	.h2-en {
		width: 124px;
	}
	.h2-jp {
		margin-top: -13px;
	}
}
.faq-list {
	border-top: 2px solid #b9d2de;
}
.faq-item {
	padding-top: 22px;
	border-bottom: 2px solid #b9d2de;
	.head {
		padding-right: 5px;
		font-weight: bold;
	}
}
.faq-term {
	padding-bottom: 20px;
	font-weight: bold;
	> span {
		display: flex;
	}
	.head {
		color: #418aa0;
	}
}
.faq-description {
	display: flex;
	padding: 0 75px 20px 35px;
	text-align: justify;
	font-size: 16px;
	.head {
		color: #cc7785;
		position: relative;
		top: -2px;
	}
	.text-link {
		display: inline;
	}
}
.faq-text {
	word-break: break-all;
}
.faq-text + .faq-text {
	margin-top: 15px;
}
@media (min-width: 769px) {
	.faq-description {
		line-height: 2.5;
		.head {
			font-size: 1.125em;
		}
	}
}
@media (max-width: 768px) {
	.faq {
		padding-top: 40px;
		.h2-en {
			width: calc(208px / 2);
		}
	}
	.faq-term {
		padding-bottom: 20px;
		font-size: 1.4rem;
		> span {
			padding-right: 27px;
		}
	}
	.faq-description {
		padding: 0 50px 20px 0;
		font-size: 1.4rem;
		.head {
			top: 0;
		}
		.text-link {
			line-height: 1.4;
		}
	}
}
.faq-item {
	.js-summary-toggle {
		/* position: relative; */
		display: flex;
		justify-content: space-between;
		transition: 0.2s;
		cursor: pointer;
		&::-webkit-details-marker {
			display: none;
		}
		&::after {
			content: "\FF0B";
			display: flex;
			align-items: center;
			color: #7caac2;
			font-size: 1.6em;
			transition: 0.2s;
			line-height: 1;
		}
	}
	&.is-opened > .js-summary-toggle::after {
		content: "\FF0D";
	}
	.js-summary-content {
		position: relative;
		overflow: hidden;
		height: auto;
		opacity: 1;
		visibility: visible;
		transition: padding .25s, height .25s, opacity .25s;
	}
	&:not(.is-opened) > .js-summary-content {
		height: 0;
		opacity: 0;
		overflow: hidden;
		padding-top: 0 !important;
		padding-bottom: 0 !important;
	}
}
@media (min-width: 769px) {
	.js-summary-toggle:hover {
		color: #418aa0;
	}
}

/* plaza_and_desk 
--------------------------------*/
.plaza_and_desk {
	background-color: #fffdf7;
}