@charset "UTF-8";
:root{
	--color-gold: #93845E;
	--color-white: #fff;
	--color-black: #333;
	--color-brown: #90856a;
}
.pc-none{
	display: none;
}
.sp-none{
	display: block;
}
main{
	.general-section .inner{
		padding: clamp(60px, 12vw, 120px) 0 clamp(50px, 8vw, 80px);
		&.inner-min{
			max-width: 1100px;
		}
	}
}
.copy-section{
	position: relative;
	.inner--head{
		margin-bottom: 40px;
	}
	&.general-section .inner{
		padding-bottom: 0;
	}
}
.copy-sec-bg{
    max-width: 725px;
    width: 40vw;
	position: absolute;
	top: 0;
	right: 0;
	.caption{
		top: 8px;
		bottom: auto;
		left: auto;
	}
}

.tab-container{
	margin: clamp(50px, 8vw, 80px) auto clamp(80px, 14vw, 140px);
	max-width: 800px;
	width: 90%;
	justify-content: center;
	gap: clamp(24px, 4.8vw, 48px);
}
.tab{
	padding: clamp(10px, 1.4vw, 14px);
	flex: 1;
	border: 1px solid var(--color-gold);
	font-size: 15px;
	cursor: pointer;
	transition: all .3s;
	.en-font{
		font-size: 20px;
		color: var(--color-gold);
	}
	&:hover,
	&.is-active{
		background-color: var(--color-gold);
		color: var(--color-white);
		.en-font{
			color: inherit;
		}
		a{
			opacity: 1;
		}
	}
	a{
		width: 100%;
		height: 100%;
		flex-wrap: nowrap;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		text-align: center;
	}
}
/* .content {
    display: none;
	&.is-active{
		display: block;
	}
} */
.cliping-mask{
	overflow: hidden;
}
@keyframes blurZoomIn {
  from {
    opacity: 0;
    filter: brightness(1.8) blur(20px);
    transform: scale3d(1.1, 1.1, 1.1);
  }
  50% {
    filter: brightness(1) blur(0);
    opacity: 1;
  }
}
.blurZoomIn {
  animation-name: blurZoomIn;
}
.w-full{
	margin-inline: calc(50% - 50vw);
	width: 100vw;
}

.facade-bg{
	background: url("../img/design/facade-bg.webp") no-repeat top center/ cover;
	.note{
		line-height: 2;
	}
}
.entrance-flex{
	margin-bottom: 48px;
	gap: clamp(20px, 3.2vw, 32px);
}
.entrance-contents{
	width: calc(55% - 16px);
}
.entrance-imgs{
	width: calc(45% - 16px);
}
.entrance-heading{
	font-size: clamp(18px, 2.2vw, 22px);
	font-weight: 500;
	line-height: 1.6;
}
.has-border{
	padding-bottom: clamp(14px, 1.6vw, 16px);
	position: relative;
	&::after{
		content: '';
		width: 100%;
		height: 1px;
		background-color: var(--color-gold);
		position: absolute;
		bottom: 0;
		left: 0;
	}
}
.imgs-wrap{
	gap: 12px;
	figure{
		flex: 1;
	}
}
.profile-box{
	padding: clamp(46px, 8vw, 80px) clamp(24px, 6vw, 100px);
	border: 1px solid var(--color-gold);
	background-color: var(--color-white);
}
.profile-flex{
	margin-bottom: clamp(12px, 1.6vw, 16px);
	gap: 32px;
}
.profile-contents{
	width: calc(80% - 16px);
	.job-name{
		font-size: clamp(15px, 2.2vw,22px);
		letter-spacing: .1rem;
		.en-font{
			margin-right: 12px;
			font-size: clamp(20px, 2.8vw, 28px);
		}
	}
	.person-name{
		font-size: 16px;
	}
	.note{
		font-size: 14px;
	}
}
.profile-img{
	width: calc(20% - 16px);
}
.profile-img-flex{
	margin-bottom: 80px;
	gap: clamp(16px, 4vw, 40px);
	&:last-of-type{
		margin-bottom: 0;
	}
	figure{
		width: calc(50% - 20px);
	}
}
@media screen and (max-width: 767px) {
	.pc-none{
		display: block;
	}
	.sp-none{
		display: none;
	}
	.copy-section{
		padding-top: 16px;
	}
	.copy-sec-bg{
		width: 70vw;
	}
	.note{
		font-size: 13px;
		letter-spacing: 0;
		line-height: 2;
	}
	.tab-container{
		flex-direction: column;
	}
	.general-section .inner--head{
		font-size: 19px;
		line-height: 1.8;
	}
	.general-section .inner--head{
		margin-bottom: 32px;
		& + .entrance-flex{
			margin-top: 48px;
		}
	}
	.entrance-flex{
		.entrance-contents,
		.entrance-imgs{
			width: 100%;
		}
	}
	.entrance-heading{
		text-align: center;
		letter-spacing: -.06rem;
	}
	.profile-flex{
		position: relative;
	}
	.profile-contents,
	.profile-img{
		width: 100%;
	}
	.profile-contents {
		.has-border{
			padding-bottom: 20px;
		}
		.job-name{
			margin-bottom: 10px;
		}
		.person-name{
			font-size: 13px;
		}
	}
	.profile-img{
		max-width: min(34vw, 132px);
		position: absolute;
		top: 0;
		right: 0;
	}
	.profile-img-flex{
		figure{
			width: 100%;
		}
	}
}
@media screen and (max-width: 370px) {
	.profile-contents {
		.job-name{
			.en-font{
				font-size: 19px;
			}
		}
		.person-name{
			font-size: 12px;
		}
	}
}

.bg-common{
	margin-top: calc(200 / 1440 * 100vw);
	padding: calc(80 / 1440 * 100vw) 0 clamp(60px, 12vw, 120px);
	background-color: var(--color-gold);
}
.common-grid{
	/* margin: calc(180 / 1440 * -100vw) auto 0 0; */
	margin: 0 auto 0 0;
	max-width: 1600px;
	width: calc(100% - 64px);
	display: grid;
	grid-template-columns: min(800px, 60vw) 1fr;
	/* align-items: end; */
	gap: 32px;
	.common-img-wrap{
		position: relative;
	}
	.common-img{
        width: 100%;
        height: 545px;
		position: absolute;
		bottom: 0;
		left: 0;
		figure{
			height: 100%;
			img{
				height: 100%;
    			object-fit: cover;
			}
		}
	}
	.common-contents{
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
		order: 2;
		.has-border{
			&::after{
				background-color: var(--color-white);
			}
		}
		.note{
			margin-bottom: 0;
		}
	}
	&.reverse{
		margin-inline: auto 0;
		grid-template-columns: 1fr min(800px, 50vw);
		.common-contents{
			order: 0;
		}
		.common-img{
			right: 0;
			left: auto;
		}
	}
}
.common{
	.facade-bg,
	.land-bg{
		.inner--head{
			margin-bottom: clamp(42px, 6vw, 60px);
		}
	}
}
.hospitality-grid{
	margin-top: clamp(35px, 6vw, 60px);
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	justify-content: center;
	align-items: center;
	gap: clamp(12px, 2.4vw, 24px);
	.grid-item{
		padding: 16px 14px;
		align-content: center;
		text-align: center;
		background-color: var(--color-white);
		border: 1px solid var(--color-gold);
		position: relative;
		font-size: clamp(14px, 1.6vw, 16px);
		&::before{
			content: '';
			width: calc(100% - 8px);
			height: calc(100% - 8px);
			position: absolute;
			top: 50%;
			left: 50%;
			transform: translate(-50%, -50%);
			border: 1px solid var(--color-gold);
		}
		.large-text{
			font-size: 120%;
			font-weight: 600;
		}
	}
}
.is-gold{
	color: var(--color-gold);
}
.trash-box{
	margin-top: 24px;
	padding: 16px 8px;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background-color: var(--color-white);
	position: relative;
	text-align: center;
	&::before{
		content: '';
		width: calc(100% - 8px);
		height: calc(100% - 8px);
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		border: 1px solid var(--color-gold);
	}
	.large-text{
		font-size: 120%;
	}
	.caption{
		margin: 0;
	}
}
.land-bg{
	background: url("../img/design/land-bg.webp") no-repeat top center/ contain;
	.note{
		line-height: 2;
	}
}
.land-img{
	img{
		mix-blend-mode: multiply;
	}
	.caption{
		bottom: 6%;
	}
}
.feature-box{
	margin-bottom: clamp(32px, 4vw, 40px);
	padding: clamp(42px, 6.4vw, 64px) 8% clamp(40px, 4.8vw, 48px);
	background-color: var(--color-brown);
	color: var(--color-white);
	position: relative;
	&::before{
		content: '';
		width: calc(100% - 20px);
		height: calc(100% - 20px);
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		border: 1px solid var(--color-white);
	}
}
.feature-flex{
	align-items: center;
	gap: clamp(32px, 7.2vw, 72px);
}
.feature-txts,
.feature-imgs{
	width: calc(50% - 36px);
}
.feature-ttl{
	font-size: clamp(.95rem, 2.24vw, 1.4rem);
	font-weight: 500;
	&.has-border::after{
		background-color: var(--color-white);
	}
}
.feature-txts{
	.note{
		margin-bottom: 0;
	}
}
.feature-imgs{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 8px clamp(12px, 2vw, 20px);
	&.col-1{
		display: block;
		.caption{
			color: var(--color-black);
		}
	}
}
/* @media screen and (max-width: 1180px) {
	.bg-common{
		margin-top: calc(60 / 1440 * 100vw);
	}
	.common-grid{
		margin-top: calc(60 / 1440 * -100vw);
	}
} */
@media screen and (max-width: 1000px) {
	.bg-common{
		margin-top: calc(146 / 390 * 100vw);
	}
	.common-grid,
	.common-grid.reverse{
		margin: calc(128 / 390 * -100vw) auto 0;
		width: 90%;
		grid-template-columns: auto;
		.common-img{
			width: 100%;
			height: auto;
			position: static;
			figure{
				margin-left: calc(50% - 50vw);
				width: 84vw;
			}
		}
		&.reverse{
			.common-contents{
				order: 2;
			}
			.common-img-wrap{
				order: 1;
			}
			.common-img{
				figure{
					margin-inline: auto calc(50% - 50vw);
				}
			}
		}
	}
	.tab-text-left{
		text-align: left;
	}
}
@media screen and (max-width: 767px) {
	.bg-common{
		margin-top: calc(120 / 390 * 100vw);
	}
	.land-bg{
		background: url("../img/design/land-bg-sp.webp") no-repeat top center/ contain;
	}
	.hospitality-grid{
		grid-template-columns: auto;
		.grid-item{
			.large-text{
				font-size: 110%;
			}
		}
	}
	.trash-box{
		.large-text{
			font-size: 110%;
		}
		.caption{
			font-size: 12px;
		}
	}
	.land-img{
		margin-inline: calc(50% - 50vw);
		width: 100vw;
		.caption{
			bottom: 0;
		}
	}
	.feature-txts,
	.feature-imgs{
		width: 100%;
	}
}

/* PHILOSOPHY--------------------------------------- */
.philosophy{
	background: #4B443B;
	background: linear-gradient(134deg, rgba(75, 68, 59, 1) 0%, rgba(49, 41, 32, 1) 100%);
	.concept--head{
		margin-bottom: clamp(16px, 2.4vw, 24px);
		color: #93845e;
		font-size: 21px;
	}
	.concept--head2 {
		margin-bottom: 60px;
		font-size: 19px;
		font-weight: normal;
		line-height: 1.5;
	}
}
.philosophy-grid{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
}
.philosophy-item{
	display: grid;
    grid-template-rows: subgrid;
    grid-row: span 4;
	gap: 0;
	figure{
		margin-bottom: 16px;
	}
	.philosophy-heading{
		padding-bottom: .5em;
		font-size: 1.1rem;
		font-weight: 500;
		position: relative;
		&::before{
			content: '';
			position: absolute;
			bottom: 0;
			left: 50%;
			width: 100%;
			height: .5px;
			background-color: #93845e;
			transform: translateX(-50%);
		}
		sub{
			font-size: 60%;
			vertical-align: baseline;
		}
	}
	.note{
		font-size: 13px;
	}
}
@media screen and (max-width: 767px) {
	.philosophy{
		.inner{
			padding-bottom: 40px;
		}
		.concept--head{
			font-size: 32px;
		}
		.concept--head2 {
			margin-bottom: 36px;
			font-size: 15px;
		}
	}
	.philosophy-grid{
		grid-template-columns: auto;
		gap: 16px;
	}
	.philosophy-item{
		.note{
			margin-top: 1.8em;
		}
	}
}