@charset "utf-8";
/* ===================================================
	Home CSS
====================================================== */
iframe {
	max-width: 100%;
}
section {
	padding: 120px 0;
}
@media screen and (max-width: 600px) {
	#g_header {
		position: absolute;
	}
	section {
		padding: 60px 0;
	}
}

/* /// Title /// */
.tit_flex {
	display: flex;
	align-items: flex-end;
    column-gap: 25px;
    line-height: 1;
}
.tit_flex h2 {
	position: relative;
    bottom: 12px;
}
.tit_en {
	font-size: 60px;
	color: var(--color-tit);
	line-height: 1.2;
}
.tit_en span {
    display: table;
}
.tit_en .sm {
	font-size: 50px;
}
@media screen and (max-width: 600px) {
	.tit_flex {
		flex-direction: column;
		align-items: center;
		gap: 15px 0;
	}
	.tit_en {
		font-size: min(8vw, 30px);
	}
	.tit_en .sm {
		font-size: min(5.3vw, 20px);
	}
}

/* .cmn_layout */
.cmn_layout {
	display: flex;
	column-gap: 6%;
}
.cmn_layout .tit_en {
    margin-top: -0.2em;
}
.cmn_layout .txt p:not([class]) {
	line-height: 1.8;
}
.cmn_layout .cmn_color {
	margin: 20px 0;
}
.cmn_layout p:has(.cmn_link_01) {
	margin-top: 55px;
	text-align: right;
}
@media screen and (min-width: 601px) {
	.cmn_layout.re {
		flex-direction: row-reverse;
	}
	.cmn_layout .txt {
		padding: 0 0 0 max(4%, calc(50vw - 600px));
	}
	.cmn_layout.re .txt {
		padding: 0 max(4%, calc(50vw - 600px)) 0 0;
	}
	.cmn_layout .photo {
		flex-shrink: 0;
		width: 56%;
		padding: 0 max(0%, calc(50vw - 800px)) 0 0;
	}
	.cmn_layout .photo img {
		width: 100%;
		height: 100%;
	}
	.cmn_layout.re .photo {
		padding: 0 0 0 max(0%, calc(50vw - 800px));
	}
}
@media screen and (max-width: 600px) {
	.cmn_layout {
		flex-direction: column;
	}
	.cmn_layout .cmn_color {
		margin: 12px 0
	}
	.cmn_layout p:has(.cmn_link_01) {
		margin-top: 25px;
		text-align: center;
	}
	.cmn_layout .photo {
		margin-top: 30px;
	}
}

/* .cmn_layout_02 */
.cmn_layout_02 {
	display: flex;
	align-items: flex-start;
	column-gap: 7%;
}
.cmn_layout_02 .txt p:not([class]) {
	margin-top: 30px;
	line-height: 1.8;
}
.cmn_layout_02 p:has(.cmn_link_01) {
	margin-top: 40px;
	text-align: right;
}
@media screen and (min-width: 601px) {
	.cmn_layout_02.re {
		flex-direction: row-reverse;
	}
	.cmn_layout_02 .photo {
		flex-shrink: 0;
		width: 60%;
	}
}
@media screen and (max-width: 600px) {
	.cmn_layout_02 {
		flex-direction: column;
	}
	.cmn_layout_02 .txt p:not([class]) {
		margin-top: 20px;
	}
	.cmn_layout_02 p:has(.cmn_link_01) {
		text-align: center;
	}
	.cmn_layout_02 .photo {
		margin-top: 30px;
	}
}


/* ---------------------------------------------------
	#main_img
------------------------------------------------------ */
/* /// Animation /// */
@keyframes circle-in {
	0% { stroke-dashoffset: -308; stroke: #fff;}
	100% { stroke-dashoffset: 0; stroke: rgba(255 255 255/50%); }
}
@keyframes circle-out {
	0% { stroke-dashoffset: -308; stroke: rgba(255 255 255/50%); }
	100% { stroke-dashoffset: 0; stroke: #fff; }
}

#main_img .slick,
#main_img .slick .ofi {
	width: 100%;
	height: calc(100vh - 160px);
}
#main_img .slick .ofi {
	transition: transform 8s linear;
	object-position: center bottom;
}
#main_img .slick .active .ofi {
	transform: scale(1.1);
}
#main_img .item {
	vertical-align: bottom;
}
#main_img .txt_main {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1;
	width: 86%;
	font-size: 36px;
	color: #fff;
	text-shadow: 0 0 10px rgba(35 16 0 / 100%), 0 0 25px rgba(35 16 0 / 80%);
}
#main_img .txt_main p {
	margin-bottom: 25px;
}

#movie_play {
	position: relative;
	display: inline-block;
	font-size: 14px;
	color: #fff;
}
#movie_play::before {
	content: '';
	display: block;
	width: 86px;
	height: 86px;
	margin: 0 auto 12px;
	border-radius: 50%;
	background: url(../img/obj_tri.svg)no-repeat center left 55%/30px rgba(255 255 255/40%);
}
#movie_play svg {
    position: absolute;
	top: -6.5px;
    left: 50%;
    transform: translateX(-50%) scale(1, -1) rotate(90deg);
    width: 98px;
    height: 98px;
    margin-left: -0.5px;
}
#movie_play svg ellipse {
	stroke-dasharray: 308 308;
	stroke-dashoffset: 308;
	stroke-width: 1px;
}
#movie_play.anim-end svg ellipse {
	animation: circle-out 0.8s forwards;
}

#movie_area {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 15;
	background-color: #000;
	overflow: hidden;
}
#movie {
	position: static;
	width: 100%;
	height: calc(100% - 140px);
	padding: 70px 0;
	overflow: hidden;
}
#movie_close {
	position: fixed;
	top: 15px;
	right: 4%;
	z-index: 11;
}

@media screen and (hover: hover) and (min-width: 601px) {
	#movie_play:hover {
		opacity: 1;
	}
	#movie_play:hover svg ellipse {
		animation: circle-in 0.8s forwards;
	}
}
@media screen and (max-width: 600px) {
	#main_img .slick,
	#main_img .slick .ofi {
		height: calc(100svh - 70px);
	}
	#main_img .txt_main {
		font-size: clamp(16px, 5vw, 30px);
		filter: drop-shadow(0 0 6px rgba(0 0 0 / 55%));
	}
	#movie_play {
		font-size: 12px;
	}
	#movie_play::before {
		width: max(50px, 11vw);
		height: max(50px, 11vw);
		margin-top: max(5px, 1vw);
		background-size: 33%;
	}
	#movie_play svg {
		top: 0;
		width: max(60px, 13vw);
		height: max(60px, 13vw);
	}
	#movie_close {
		transform: scale(0.75);
	}
}


/* ---------------------------------------------------
	#sec_topics
------------------------------------------------------ */
#sec_topics {
	padding: 70px 0;
}
#sec_topics .slick {
	width: 1260px;
	margin-top: 35px;
}
#sec_topics .slick-prev,
#sec_topics .slick-next {
	top: calc(50% - 50px);
}
#sec_topics .slick-slide {
	margin: 0 30px
}
#sec_topics .slick-slide .ofi {
	width: 100%;
	aspect-ratio: 1 / 1.414;
	/* aspect-ratio: 23 / 36; */
}
#sec_topics .slick .item p:last-child {
	margin-top: 30px;
	overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-inline-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
	line-height: 1.8;
}

@media screen and (max-width: 600px) {
	#sec_topics .slick {
		width: 86%;
		margin-top: 25px;
	}
	#sec_topics .slick-prev,
	#sec_topics .slick-next {
		top: calc(50% - 40px);
	}
	#sec_topics .slick-slide .ofi {
		width: 100%;
	}
	#sec_topics .slick .item p:last-child {
		margin-top: 20px;
	}
}


/* ---------------------------------------------------
	#sec_lead
------------------------------------------------------ */
#sec_lead {
	padding-top: 100px;
}
#sec_lead .photo:has(p) {
	display: flex;
	gap: 10px;
}
#sec_lead .cmn_layout .tit_en {
	font-size: 76px;
}
#sec_lead [class^="lead_"]:not(.lead_1) {
	padding-top: 100px;
}
#sec_lead .lead_1 {
	text-align: center;
}
#sec_lead .lead_1 .cmn_color {
	font-size: 40px;
}
#sec_lead .lead_1 h2+p {
	margin-top: 25px;
	line-height: 1.8;
}
#sec_lead .lead_1 .photo {
	margin-top: 50px;
}
#sec_lead .lead_1 .photo img {
	aspect-ratio: 89 / 60;
}
#sec_lead .lead_2 h2 span {
	display: inline-block;
}
#sec_lead .lead_2 .photo {
	flex-wrap: wrap;
}
#sec_lead .lead_2 .photo p:first-child {
	width: 100%;
}
#sec_lead .lead_2 .photo p {
	width: calc(50% - 5px);
}
#sec_lead .lead_3 {
	text-align: center;
}
#sec_lead .lead_3>p {
	margin-top: 25px;
	line-height: 1.8;
}

@media screen and (max-width: 600px) {
	#sec_lead {
		padding-top: 50px;
	}
	#sec_lead [class^="lead_"] {
		max-width: 88%;
		margin: 0 auto;
	}
	#sec_lead .photo:has(p) {
		gap: 5px;
	}
	#sec_lead .cmn_layout .tit_en {
		font-size: min(10vw, 38px);
	}
	#sec_lead [class^="lead_"]:not(.lead_1) {
		padding-top: 70px;
	}
	#sec_lead .lead_1 .cmn_color {
		font-size: min(8.3vw, 30px);
	}
	#sec_lead .lead_1 h2+p {
		text-align: left;
	}
	#sec_lead .lead_1 .photo {
		margin-top: 30px;
	}
	#sec_lead .lead_2 .photo {
		margin-top: 35px;
	}
	#sec_lead .lead_2 .photo p {
		width: calc(50% - 2.5px);
	}
	#sec_lead .lead_3 {
		text-align: left;
	}
	#sec_lead .lead_3>p {
		margin-top: 20px;
	}
}


/* ---------------------------------------------------
	#sec_room
------------------------------------------------------ */
#sec_room .tit_en {
	font-size: 76px;
}
#sec_room>div+div {
	margin-top: 80px;
}
#sec_room h2 span {
	display: inline-block;
}

@media screen and (max-width: 600px) {
	#sec_room .cmn_layout {
		padding: 0 6%;
	}
	#sec_room .tit_en {
		font-size: min(10.6vw, 40px);
	}
	#sec_room>div+div {
		margin-top: 50px;
	}
}


/* ---------------------------------------------------
	#sec_facility
------------------------------------------------------ */
#sec_facility .cmn_layout_02+.cmn_layout_02 {
	padding-top: 120px;
}
#sec_facility .wedding .cmn_tit_01 .en {
	margin-left: 8px;
}

@media screen and (max-width: 600px) {
	#sec_facility .cmn_layout_02+.cmn_layout_02 {
		padding-top: 50px;
	}
}


/* ---------------------------------------------------
	#sec_news
------------------------------------------------------ */
#sec_news {
	padding: 70px 0 100px;
}
#feed li {
	border-bottom: 1px solid #aaa;
}
#feed a {
	display: flex;
	align-items: center;
	column-gap: 15px;
	padding: 28px 0;
}
#feed a:hover {
	opacity: 1;
}
#feed .date {
	flex-shrink: 0;
	padding: 0 15px;
	text-align: center;
	color: #fff;
	background-color: var(--color-accent);
}
#feed .cmn_link_lr {
	overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
}
#feed .cmn_link_lr::after {
    height: 6px;
    background-color: var(--color-tit);
    opacity: 0.3;
	transition-duration: 0.8s;
}
#sec_news p:has(.cmn_link_01) {
	margin-top: 30px;
	text-align: right;
}

@media screen and (hover: hover) and (min-width: 601px) {
	#feed a:hover .cmn_link_lr::after {
		transform: scaleX(1);
	}
}
@media screen and (min-width: 601px) {
	#sec_news .wrap {
		display: flex;
	}
	#sec_news .tit_col {
		flex-shrink: 0;
		width: 270px;
	}
	#sec_news .feed_col {
		flex-grow: 1;
	}
	#feed li:first-child a {
		padding-top: 14px;
	}
}
@media screen and (max-width: 600px) {
	#sec_news {
		padding: 50px 0 60px;
	}
	#sec_news .tit_col {
		margin-bottom: 10px;
		text-align: center;
	}
	#feed a {
		flex-direction: column;
		align-items: flex-start;
		gap: 10px 0;
		padding: 20px 0;
	}
}


/* ---------------------------------------------------
	#sec_info
------------------------------------------------------ */
#sec_info {
	padding: 100px 0 140px;
}
#sec_info .slick {
	margin-top: 80px;
	padding: 0 38px;
}
#sec_info .slick-slide {
	margin: 0 12px
}
#sec_info .cmn_table {
	margin-top: 30px;
}

@media screen and (min-width: 601px) {
	#sec_info .ccl .slick-prev,
	#sec_info .ccl .slick-next {
		background-color: transparent !important;
	}
}
@media screen and (max-width: 600px) {
	#sec_info {
		padding: 50px 0 80px;
	}
	#sec_info .slick {
		margin-top: 50px;
		padding: 0;
	}
	#sec_info .slick-prev {
		left: max(-5%, calc(50vw - 240px));
	}
	#sec_info .slick-next {
		right: max(-5%, calc(50vw - 240px));
	}
	#sec_info .slick-slide {
		margin: 0 20px
	}
	#sec_info .slick-slide>div {
		text-align: center;
	}
	#sec_info .item {
		max-width: 350px;
	}
}
