/*====================================================
////id common
====================================================*/
#contents {
	color: #393939;
}
.gray {
	color: #6e6e6e;
}
.black {
	color: #393939;
}

.flex-1 {
	flex: 1;
}
small, .small {
	font-size: .8em;
}
.sa.slideShow {
	opacity: 1;
	position: relative;
	z-index: 1;
}
.sa.slideShow:before {
	background: #f4f4f4;
	content: '';
	position: absolute;
		top: 0;
		left: 0;
		right: auto;
	transition: .5s ease-in-out;
	width: 0;
	height: 100%;
	z-index: 10;
}
.sa.slideShow.show:before {
	-webkit-animation: anim-slide 1.0s ease-in-out forwards;
	        animation: anim-slide 1.0s ease-in-out forwards;
	-webkit-animation-delay: .4s;
	        animation-delay: .4s;
}
@-webkit-keyframes anim-slide {
	0%   {}
	55%  { width: 100%; left: 0; right: 0;}
	65% { width: 100%; left: auto; right: 0; }
	100% { width: 0; left: auto; right: 0; }
}
@keyframes anim-slide {
	0%   {}
	47%  { width: 100%; left: 0; right: 0;}
	53% { width: 100%; left: auto; right: 0; }
	100% { width: 0; left: auto; right: 0; }
}

.sa.slideShow img,
.sa.slideShow > .box-inner {
	opacity: 0;
}
.sa.slideShow.show img ,
.sa.slideShow.show > .box-inner {
	opacity: 1;
	transition-delay: .9s;
}


.sa.slideShow.slide-rl {
	transform: rotate(180deg);
}
.sa.slideShow.slide-rl img {
	transform: rotate(180deg);
}

.headBox .en_jp {
	line-height: .8;
}
.headBox .en_jp .en {
	display: block;
	letter-spacing: .1em;
}
.headBox .en_jp .jp {
	line-height: 1;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 768px) {
	.innerBox {
		padding: 90px 0;
	}
	.headBox .en_jp {
		font-size: 3.0rem;
	}
	.headBox .en_jp .jp {
		font-size: .375em;
	}
}

@media screen and (max-width:480px) {
	#contents {
		font-size: 3.8vw;
	}
	.innerBox {
		padding: 17vw 0;
	}
	.headBox .en_jp {
		font-size: 1.8em;
	}
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	.innerBox {
		padding: 120px 0;
	}
	.headBox .en_jp {
		font-size: 3.6rem;
	}
	.headBox .en_jp .jp {
		font-size: .375em;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
}

@media screen and (min-width:1200px) {
	.headBox .en_jp {
		font-size: 4.0rem;
	}
}

/*====================================================
////id mv
====================================================*/
#mv {
	position: relative;
}
#mv .slider {
	margin: 0;
}
#mv .item {
	padding: 0 2px;
}
#mv .slick-prev,
#mv .slick-next {
	margin: auto;
	opacity: 1;
	top: 0;
	bottom: 0;
	width: 50px;
}

#mv .item figure {
	position: relative;
}
#mv .item figcaption {
	letter-spacing: .1em;
	position: absolute;
		left: 6%;
		bottom: 10%;
	text-shadow: 0 0 .5em rgba(0, 0, 0, .5), 0 0 .3em rgba(0, 0, 0, .5), 0 0 .2em rgba(0, 0, 0, .5);
	max-width: 90%;
	z-index: 10;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 768px) {
	#mv .item {
	}
	.slick-prev ,
	.slick-next {
	}
	#mv .slick-prev,
	#mv .slick-next {
		transform: scale(.6);
	}
	#mv .slick-prev {
		transform-origin: right;
	}
	#mv .slick-next {
		transform-origin: left;
	}
	.slick-prev {
		left: -9px;
	}
	.slick-next {
		right: -9px;
	}
	#mv .item figure {
		padding-top: 74%;
	}

}

@media screen and (max-width:580px) {
	#mv .item figure {
		padding-top: 74%;
	}
}

@media screen and (max-width:480px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	#mv {
	}
	.slick-prev {
		left: 10px;
	}
	.slick-next {
		right: 10px;
	}
	#mv .item figure {
		padding-top: 68%;
	}
	#mv .item figcaption {
		font-size: 2.2rem;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
	#mv {
		/* min-height: 71vw; */
	}
	#mv .item figure {
		padding-top: 80%;
	}
	#mv .item figcaption {
		font-size: 2.4vw;
	}
}

@media screen and (min-width:1340px) {
	#mv {
		min-height: 0;
	}
	#mv .slick-prev {
		left: auto;
		right: calc(50vw + 585px);
	}
	#mv .slick-next {
		right: auto;
		left: calc(50vw + 585px);
	}
	#mv .item figcaption {
		font-size: 2.4rem;
	}
}

/*====================================================
////id lead_copy
====================================================*/
#lead_copy {
	overflow: hidden;
}
#lead_copy::before {
	background: url('../img/photo_wedding/pw-bg-1.jpg') no-repeat center top;
	background-size: 100% auto;
	content: '';
	display: block;
	margin: auto;
	position: absolute;
		top: 0;
		left: 0;
	width: 100%;
	height: 100%;
}
#lead_copy h2 {
	letter-spacing: .1em;
	line-height: 2;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 768px) {
	#lead_copy .itemBox {
		grid-gap: 3vw;
	}
	#lead_copy .headBox h2 {
		padding: 2em 0 1em;
		text-align: center;
		padding-top: 0;
	}
	#lead_copy .main_photo {
		margin: auto;
		width: 100%;
			max-width: 500px;
	}
	#lead_copy .main_photo .coverImg {
		padding-top: 150%;
	}
	#lead_copy .txtBox {
		text-align: center;
		padding: 2em 0;
	}
	#lead_copy .photo-1 .coverImg {
		margin-left: -5vw;
		width: calc(100% + 4vw);
	}
	#lead_copy .photo-2 .coverImg {
		margin: 0 -5vw 0 auto;
	}
}

@media screen and (max-width:480px) {
	#lead_copy .headBox h2 {
		font-size: 1.4em;
	}
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	#lead_copy .itemBox {
		grid-gap: 3vw;
		grid-template-columns: 600px 1fr;
		grid-template-rows: auto auto 1fr;
	}
	#lead_copy .headBox h2 {
		padding-top: 1em;
	}
	#lead_copy .main_photo {
		grid-column: 2;
		grid-row: 1 / 4;
	}
	#lead_copy .main_photo .coverImg {
		/* padding-top: 140%; */
		padding-top: 0;
		height: 100%;
		width: calc(100% + 3vw);
	}
	#lead_copy .txtBox {
		line-height: 2;
		padding-bottom: 4em;
	}
	#lead_copy .photo-1 {
		grid-row: span 2;
		padding-bottom: 80px;
	}
	#lead_copy .photo-1 .coverImg {
		margin-left: -3vw;
		width: calc(100% + 3vw);
	}
	#lead_copy .photo-2 {
		padding-right: 0;
	}
	#lead_copy .photo-2 .coverImg {
		min-height: 360px;
	}
	#lead_copy .photo-2 .coverImg img {
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:1080px) {
	#lead_copy .itemBox {
		grid-template-columns: 400px 1fr;
	}
	#lead_copy .main_photo {
		grid-row: 1 / 2;
	}
	#lead_copy .main_photo .coverImg {
		/* padding-top: 100%;
		height: auto; */
	}
	#lead_copy .headBox h2 {
		padding: 4em 0 3em;
	}
	#lead_copy .txtBox {
		grid-column: 1 / 3;
	}
	#lead_copy .photo-2 {
		padding-top: 80px;
	}
	#lead_copy .photo-2 .coverImg {
		min-height: 0;
	}
}

@media screen and (min-width:1280px) {
	#lead_copy .itemBox {
		grid-template-columns: 50% 1fr;
	}
	#lead_copy .headBox {
		padding-left: 3vw;
	}
	#lead_copy .headBox h2 {
		padding-top: 3em;
	}
	#lead_copy .main_photo .coverImg {
		padding-top: 140%;
	}
	#lead_copy .main_photo .coverImg ,
	#lead_copy .photo-1 .coverImg {
		margin: 0;
		width: 100%;
	}
	#lead_copy .txtBox {
		padding-bottom: 5em;
		padding-left: 3vw;
	}
	#lead_copy .photo-2 {
		padding-right: 80px;
	}
}

@media screen and (min-width:1550px) {
	#lead_copy .itemBox {
		grid-gap: 80px;
	}
	#lead_copy .headBox {
		padding-left: 120px;
	}
	#lead_copy .headBox h2 {
		font-size: 3.6rem;
	}
	#lead_copy .txtBox {
		padding-left: 120px;
	}
	#lead_copy .photo-2 {
		padding-right: 120px;
	}
}

/*====================================================
////id point
====================================================*/
#point .itemBox {
	margin: auto;
	width: 94%;
		max-width: 1120px;
}
#point .item {
	padding: 0 1em 2em 1em;
}
#point .item::after {
	border: solid #5f5f5f;
	border-width: 0 1px 1px 0;
	content: '';
	display: block;
	margin: auto;
	position: absolute;
		right: 0;
		bottom: 0;
	width: 4em;
	height: 4em;
}
#point .noBox {
	align-items: baseline;
	justify-content: flex-start;
	margin-left: -1em;
}
#point .noBox .no {
	margin-left: -.8em;
}
#point .noBox .no img {
	filter: grayscale(10);
	width: 5em;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 960px) {
	#point .itemBox {
		font-size: 1.1em;
		grid-gap: 1.5em;
	}
	#point .item {
		width: 85%;
			max-width: 400px;
	}
	#point .item:nth-child(2) {
		margin: auto;
	}
	#point .item:nth-child(3) {
		margin: 0 0 0 auto;
	}
	#point .photo_itemBox {
		grid-gap: 2vw;
		position: relative;
	}
	#point .photoBox .img-1 {
		position: absolute;
			top: -5vw;
		width: calc(45% - 2vw);
	}
	#point .photoBox .img-2 {
		margin: 0 0 0 auto;
		width: 55%;
	}
	#point .photoBox .img-3 figure {
		margin-left: -5vw;
		width: calc(100% + 5vw);
	}
	#point .photoBox .img-4 figure {
		margin-right: -5vw;
		width: calc(100% + 5vw);
	}
}

@media screen and (max-width:480px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 960px) {
	#point .itemBox {
		grid-gap: 4vw;
		font-size: 1.8rem;
	}
	#point .item {
	}
	#point .photoBox .photo_itemBox {
		grid-gap: 3vw;
		grid-template-columns: 27% 1fr;
		grid-template-rows: auto auto auto;
	}
	#point .photoBox .img-1 {
		padding: 40px 0 0 6vw;
	}
	#point .photoBox .img-2 {
		grid-column: 1 / 2;
		grid-row: 2 / 4;
	}
	#point .photoBox .img-3 {
		grid-column: 2 / 3;
		grid-row: 3 / 4;
	}
	#point .photoBox .img-3 {
		padding-right: 6vw;
	}
	#point .photoBox .img-4 {
		grid-column: 2 / 3;
		grid-row: 1 / 3;
	}
	#point .photoBox .img-4 figure {
		width: calc(100% + 3vw);
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
}

@media screen and (min-width:1200px) {
	#point .itemBox {
		grid-gap: 50px;
		font-size: 2.0rem;
	}
	#point .photoBox .photo_itemBox {
		grid-gap: 90px;
	}
	#point .photoBox .img-1 {
		padding: 40px 0 0 100px;
	}
}

@media screen and (min-width:1550px) {
}

/*====================================================
////id plan
====================================================*/
#plan .itemBox {
}
#plan .item {
	padding: 0 1px 1px 0;
}
#plan .item .decoBox {
	position: absolute;
		bottom: 0;
		right: 0;
	width: 100%;
	height: 100%;
	z-index: -5;
}
#plan .item .decoBox::after {
	background: linear-gradient(to right bottom, rgba(255, 255, 255, 1),rgba(255, 255, 255, 0));
	content: '';
	display: block;
	margin: auto;
	position: absolute;
		top: 0;
		left: 0;
	width: 100%;
	height: 100%;
}
#plan .item .sale_text {
	background: #e3f8f5;
	border-radius: 5px;
	line-height: 1.4;
	margin-bottom: .5em;
	padding: .3em 1em .2em;
}
#plan .item .priceBox {
	padding: 0 1.2em;
}
#plan .item .priceBox * {
	line-height: 1;
}
#plan .item .sale_icon {
	position: absolute;
		top: -.5em;
		left: -.5em;
	height: 90%;
}
#plan .item .priceBox .sale_price {
	font-size: .6em;
	position: relative;
}
#plan .item .priceBox .sale_price::after {
	border: solid;
	border-width: 1px 0;
	content: '';
	display: block;
	margin: auto;
	position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	transform: rotate(5deg);
	width: 100%;
	height: 2px;
}
#plan .item .priceBox .line_arrow {
	border: solid;
	border-width: 0 0 2px 1px;
	margin: .15em auto;
	position: relative;
	transform: skewY(-60deg);
	transform-origin: bottom left;
	width: .15em;
	height: .5em;
}
/* #plan .item .priceBox .line_arrow::after {
	border-left: solid 1px;
	content: '';
	display: block;
	margin: auto;
	position: absolute;
		bottom: 1px;
		left: -1px;
	transform: rotate(35deg) scale(.95);
	transform-origin: bottom left;
	width: 0;
	height: 45%;
} */
#plan .item .priceBox .tax {
	font-size: .4em;
	margin-bottom: .2em;
}
#plan .item .set_item {
	margin-top: 1em;
}
#plan .plan_items {
	display: flex;
		flex-wrap: wrap;
		grid-gap: .4em;
		justify-content: center;
	font-size: .75em;
	line-height: 1.4;
}
#plan .plan_items li {
	border: solid 1px #adadad;
	padding: .3em 1em .2em;
}
#plan .item .txtBox {
	margin-top: 1em;
	padding: 0 .3em;
}

#plan .commonBox {
	margin: 40px 0;
}
#plan .commonBox .whiteBox {
	border: solid 1px #bfbfbf;
	margin: auto;
	max-width: 1120px;
	padding: 4em 1em;
}
#plan .btnBox .btn:nth-child(2) .linkBtn {
	background: #aeaeae;
	max-width: 560px;
	min-height: 60px;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 960px) {
	#plan .itemBox {
		grid-gap: 4vw;
		margin: auto;
		max-width: 600px;
	}
	#plan .item-inner {
		height: 100%;
		padding: 1em .5em 3em;
	}
	#plan .item .item_headBox {
		align-items: flex-end;
		min-height: 2em;
	}
	#plan .item .sale_text {
		font-size: .8em;
	}
	#plan .item h3 {
		font-size: 1.8rem;
	}
	#plan .item .priceBox {
		font-size: 3.2rem;
		margin-top: .3em;
	}
	#plan .item .priceBox .sale_price {
		margin-top: -.5em;
	}
	#plan .commonBox .en_jp .en {
		font-size: 1.8rem;
	}
}


@media screen and (max-width: 768px) {
}

@media screen and (max-width:480px) {
	#plan .item .priceBox {
		font-size: 7vw;
	}
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 960px) {
	#plan .itemBox {
		grid-gap: 2vw;
	}
	#plan .item-inner {
		height: 100%;
		padding: 1em .5em 3em;
	}
	#plan .item .item_headBox {
		align-items: flex-end;
		height: 4em;
	}
	#plan .item .sale_text {
		font-size: 1.3rem;
	}
	#plan .item h3 {
		font-size: 1.8rem;
	}
	#plan .item .priceBox {
		font-size: 2.5vw;
		height: 2.6em;
	}
	#plan .commonBox {
		margin: 60px 0;
	}
	#plan .commonBox .en_jp .en {
		font-size: 2.0rem;
	}
	#plan .commonBox .plan_items {
		font-size: 1.4rem;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
}

@media screen and (min-width:1550px) {
	#plan .itemBox {
		font-size: 1.8rem;
		grid-gap: 30px;
	}
	#plan .item-inner {
		padding: 1em 1.5em 3em;
	}
	#plan .item .sale_icon {
		top: 0;
		left: -1.0em;
	}
	#plan .item .priceBox {
		font-size: 3.6rem;
	}
	#plan .item .txtBox {
		padding: 0 .6em;
	}
}

/*====================================================
////id location
====================================================*/
#location {
	background: #fcfcfc;
}
#location .item .coverImg {
	padding-top: 156%;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 768px) {
	#location .itemBox {
		grid-gap: 5vw 3vw;
		grid-template-columns: repeat(2, 1fr);
		margin: auto;
		max-width: 500px;
	}
}

@media screen and (max-width:480px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	#location .itemBox {
		grid-gap: 4vw 2vw;
		grid-template-columns: repeat(5, 1fr);
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
	#location .itemBox {
		grid-template-columns: repeat(4, 1fr);
	}
}

@media screen and (min-width:1200px) {
	#location .item {
		font-size: 2.0rem;
	}
}

@media screen and (min-width:1550px) {
	#location .itemBox {
		grid-gap: 40px;
	}
}

/*====================================================
////id flow
====================================================*/
#flow .item .item-inner::before {
	border: solid #ccc;
	border-width: 0 0 1px 1px;
	content: '';
	display: block;
	margin: auto;
	position: absolute;
		bottom: 0;
		left: 0;
	width: 100%;
}
#flow .item .noBox::after {
	background: #7f7f7f;
	border: solid 2px #fff;
	content: '';
	display: block;
	margin: auto;
	position: absolute;
		top: calc(50% + 40px);
		left: 60px;
	transition: 3s ease;
	transition-delay: 1s;
	width: 1px;
	height: 0;
}
#flow .item:last-child .noBox::after {
	display: none;
}
#flow .item-inner.show .noBox::after {
	height: calc(100px + 50%);
}
/* ////////// mobile ////////// */
@media screen and (max-width: 960px) {
	#flow .itemBox {
		grid-gap: 8vw;
	}
	#flow .item-inner {
		grid-gap: 2vw;
		grid-template-columns: auto 1fr;
		padding: 1.5em;
	}
	#flow .item-inner::before {
		height: calc(50% - 15px);
	}
	#flow .item .noBox {
		grid-row: 1 / 3;
		padding-left: .5em;
		width: 80px;
	}
	#flow .item-inner .noBox::after {
		top: 90px
	}
	#flow .item-inner.show .noBox::after {
		height: calc(8vw + 100%);
	}
	#flow .item h3 {
		font-size: 1.8rem;
	}
}

@media screen and (max-width: 768px) {
	#flow .item-inner {
		padding: 1.5em .5em;
	}
	#flow .item .noBox {
		width: 3.5em;
	}
	#flow .item-inner .noBox::after {
		top: 5em;
		left: 2em;
	}
	#flow .item h3 {
		font-size: 1.15em;
		padding-top: .3em;
	}
}

@media screen and (max-width:480px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 960px) {
	#flow .itemBox {
		grid-gap: 100px;
	}
	#flow .item-inner {
		align-items: center;
		grid-gap: 30px;
		grid-template-columns: auto 300px 1fr;
		padding: 1.5em;
	}
	#flow .item-inner::before {
		height: calc(50% - 15px);
	}
	#flow .item .noBox {
		width: 80px;
	}
	#flow .item h3 {
		font-size: 1.8rem;
		text-align: center;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
}

@media screen and (min-width:1200px) {
	#flow .item h3 {
		font-size: 2.0rem;
	}
}

/*====================================================
////id reservation
====================================================*/
#reservation .btnBox {
	grid-gap: .5em;
	margin-top: 30px;
}
#reservation .btn:first-child .linkBtn {
	background: #99a8c4;
}
#reservation .linkBtn {
	grid-gap: .8em;
	margin: 0 auto;
}
#reservation .linkBtn img {
	margin: 0 0 .2em 0;
	width: 1.2em;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 768px) {
	#reservation .bgBox img {
		-o-object-position: top;
		   object-position: top;
	}
	#reservation .txtBox {
		font-size: 1.15em;
	}
	#reservation .btnBox {
		align-items: stretch;
	}
}

@media screen and (max-width:480px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	#reservation .txtBox {
		font-size: 2.0rem;
	}
	#reservation .btn {
		max-width: 380px;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
}

@media screen and (min-width:1550px) {
}

/*====================================================
////id gallery
====================================================*/
#gallery .innerBox {
	width: 100%;
		max-width: none;
}
#gallery h2 {
	margin-bottom: 1.5em;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 768px) {
	#gallery img {
		height: 70vw;
		 	max-height: 400px;
	}
	#gallery .gall_slider {
		margin: 1.2em 0;
	}
}

@media screen and (max-width:480px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	#gallery .gall_slider {
		margin: 20px 0;
	}
	#gallery img {
		height: 30vw;
		 	max-height: 550px;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
}

@media screen and (min-width:1550px) {
}


/*====================================================
////id #information
====================================================*/
#information .inqBox {
}
#information .tel {
	font-size: 2.8rem;
	line-height: 1.3;
	text-align: center;
}
#information .linkBtn {
	min-height: 60px;
}
#information .linkBtn img {
	width: 20px;
	margin: -2px 10px 2px 0;
}
#information .text {
	border: solid 1px;
	margin: 15px 0 25px;
	padding: 3px 5px 0;
	text-align: center;
}
#information .open_hour {
	border: solid #a7a7a7;
	border-width: 1px 0;
	font-size: 1.4rem;
	padding: .8em 2em;
}
#information .item {
	background: #fff;
	margin-bottom: 15px;
	padding: 20px 30px;
}
#information .item:last-child {
	margin-bottom: 0;
}
#information .item .addressBox {
	line-height: 1.4;
	margin: 10px 0;
}

/* ////////// mobile ////////// */
@media screen and (max-width: 768px) {
	#information .innerBox {
		flex-direction: column;
	}
	#information .inqBox {
		margin-bottom: 40px;
	}
}

@media screen and (max-width:480px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	#information .inqBox {
		width: 400px;
	}
	#information .itemBox {
		flex: 1;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
	#information .inqBox {
		width: 280px;
	}
}

@media screen and (min-width:1200px) {
}

/*====================================================
////id xxx
====================================================*/

/* ////////// mobile ////////// */
@media screen and (max-width: 768px) {
}

@media screen and (max-width:480px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:959px) {
}

@media screen and (min-width:1550px) {
}
