@charset "UTF-8";

/* top_fv */
.top_fv {
	margin-bottom: max(120px, 7.5vw);
}

.top_fvSlider-wrap {
    position: relative;
    overflow: hidden;
}
.top_fvSlider {
    width: 100%;
    margin: 0 auto;
	position: relative;
	opacity: 0;
}
.top_fvSlider.slick-initialized{
    animation: kv_anm .3s forwards;
}
@keyframes kv_anm {
    0% {opacity: 0; visibility: hidden;}
    100% {opacity: 1; visibility: visible;}
}

.top_fvSlider_txt {
    display: flex;
    justify-content: space-between;
	align-items: end;
    position: absolute;
	bottom: min(12vw, 150px);
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - min(8vw, 8rem));
}
.top_fvSlider_txt .txt_wrap * {
	white-space: nowrap;
	color: transparent;
}
.top_fvSlider_txt .txt_wrap h2 span {
	font-size: min(3vw, var(--font-size32px));
}
.top_fvSlider_txt .txt_wrap p {
	line-height: 1;
	color: #fff;
	display: block;
	margin-top: 1em;
}
.top_fvSlider_txt .txt_wrap p span {
	font-size: min(8vw, 80px);
	font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal;
	line-height: 1;
    letter-spacing: .08em;
	color: transparent;
}
.top_fvSlider_webcatalog .top_fvSlider_txt .txt_wrap p span:nth-child(3) {
	margin-right: .2em;
}
.top_fvSlider_txt p {
	color: #fff;
    font-size: min(1.6vw, var(--font-size15px));
    /* max-width: 400px; */
    letter-spacing: 0.1em;
    line-height: 2;
    margin-right: min(2vw, 2.5rem);
}

.top_fvSlider .slick-slide {
    position: relative;
    overflow: hidden;
}

.top_fvSlider .slick-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
	animation: scale2 6s linear forwards;
}
.top_fvSlider .slick-active img {
    animation: scale 6s linear forwards;
}
@keyframes scale {
    0% {transform: scale(1);}
    100% {transform: scale(1.1);}
}
@keyframes scale2 {
    0% {transform: scale(1.1);}
    100% {transform: scale(1);}
}


/* プログレスバーのスタイル */
.top_fvprogress-dots {
    position: absolute;
    bottom: 0;
    display: flex;
    justify-content: center;
    z-index: 9;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
	padding: 0 min(4vw, 4rem);
}

.top_fvprogress-dot {
    color: #fff;
    flex: 1;
    position: relative;
    width: 33.333%;
    padding: min(2.5vw, 1.5rem) 0;
    cursor: pointer;
    transition: .3s;
    font-size: min(1.7vw, var(--font-size16px));
}

.top_fvprogress-dot:before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    height: 1px;
    width: 0;
    background: #fff;
    z-index: 2;
}
.top_fvprogress-dot::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    height: 1px;
    width: 100%;
    background: rgba(255, 255, 255, 0.3);
    z-index: 1;
}

.top_fvprogress-dot.active:before {
    animation: progress 6s linear forwards;
}
@keyframes progress {
    0% {width: 0;}
    100% {width: 100%;}
}
@media (min-width: 1024px) {
	.top_fvprogress-dot:hover {
    	color: rgba(255, 255, 255, 0.5);
	}
}
@media (max-width: 750px) {
	.top_fv {
		margin-bottom: max(64px, 17.066vw);
	}
	.top_fvSlider_txt .txt_wrap h2 span {
		font-size: max(20px, 5.333vw);
	}
	.top_fvSlider_txt .txt_wrap p span {
		font-size: max(40px, 10.666vw);
	}
	.top_fvSlider_txt {
		bottom: max(65px, 17.333vw);
	}
	.top_fvSlider_txt div.flexBox p {
		display: none;
	}
	.icon_circleBig::after {
		width: max(12px, 3.2vw);
		height: max(12px, 3.2vw);
		background-size: max(12px, 3.2vw);
	}
	.top_fvprogress-dots {
		bottom: max(40px, 10.666vw);
	}
	.top_fvprogress-dot {
		font-size: 0;
		padding: 0;
	}
}


/* news_wrap_top */
.news_wrap_top .news_inner {
	max-width: 800px;
	margin: auto;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}
.news_wrap_top .ttl_sec {
	order: 1;
    width: max-content;
	margin-bottom: 0;
}
.news_wrap_top .news_list {
	order: 3;
	width: 100%;
	margin-top: 2.5rem;
}
.news_wrap_top .btn_bgGr {
	order: 2;
	width: 15rem;
	display: flex;
	justify-content: end;
}
@media (max-width: 750px) {
	.news_wrap_top .news_inner {
		display: block;
	}
	.news_wrap_top .news_list {
		margin-top: 2em;
	}
	.news_wrap_top .btn_bgGr {
		width: inherit;
		justify-content: center;
		margin-top: 2rem;
	}
}


/* works_wrap */
.works_list {
	display: flex;
	flex-wrap: wrap;
	gap: 40px 40px;
}
.works_list_2col li {
	width: calc(50% - 20px);
	margin-bottom: 40px;
}
.works_list_3col li {
	width: calc(33.333% - 26.666px);
}
.works_list a {
	position: relative;
	display: block;
}
.works_list .works_img {
	overflow: hidden;
}
.works_list picture {
	display: block;
	line-height: 1;
    opacity: 0;
    transform: scale(1.05);
    filter: blur(10px);
    transition: .8s;
}
.works_list picture.visible {
  opacity: 1;
  transform: scale(1);
  filter: blur(0);
}
.works_list picture img {
	transition: 1.4s;
}
.works_list .works_txt {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: var(--color-bg);
	color: #fff;
	width: 90.732%;
    padding: 1.5rem 2rem;
}
.works_list .works_txt h3 {
	margin-bottom: 1rem;
}
.works_list .works_txt h3 span {
	font-size: var(--font-size18px);
}
.works_list .works_txt p {
	font-size: var(--font-size12px);
	display: flex;
	align-items: start;
	justify-content: space-between;
	border-top: 1px solid var(--color-border1);
	padding-top: 1rem;
	position: relative;
}
.works_list .works_txt p::after {
	content: "";
	width: 1.5rem;
	height: 1px;
	background-color: var(--color-brandGr);
	position: absolute;
	top: -1px;
	left: 0;
}
.works_list .works_txt .en {
	font-size: var(--font-size12px);
	text-decoration: underline;
	white-space: nowrap;
	margin-left: 1em;
}
@media  (max-width: 1279px) {
	.works_list .works_txt {
		width: 100%;
		position: relative;
		padding: 1.5rem 0 0;
	}
}
@media (min-width: 1024px) {
	.works_list a:hover img {
		transform: scale(1.04);
	}
}
@media (max-width: 750px) {
	.works_list_2col {
		display: block;
	}
	.works_list_2col li {
		width: 100%;
		margin-bottom: 8vw;
	}
	.works_list_3col {
    	gap: 0;
		justify-content: space-between;
	}
	.works_list_3col li {
    	width: calc(50% - 2.5vw);
		margin-bottom: 8vw;
	}
	.works_list_3col li .works_txt p {
		flex-wrap: wrap;
	}
	.works_list_3col li .works_txt p .en {
		width: 100%;
		margin: 8px 0 0;
	}
	.works_list .works_txt p {
		align-items: center;
	}
	.works_list .works_txt .en {
		font-size: 10px;
		display: flex;
		align-items: center;
	}
	.works_list .works_txt .en::after {
		content: "";
		width: 2rem;
		height: 2rem;
		background-image: url(../img/icon/icon_arw_gr.svg);
		background-size: 40%;
		background-position: center;
		background-repeat: no-repeat;
		background-color: var(--color-brandGr_thin);
		display: inline-block;
		border-radius: 50%;
		margin-left: 8px;
	}
	.works_wrap_top .btn_bgGr {
		order: 3;
	}
	.works_wrap_top .btn_bgGr a {
		margin: auto;
	}
}

.works_wrap_top {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}
.works_wrap_top .ttl_sec_wrap {
	order: 1;
	width: max-content;
	margin-bottom: 0;

}
.works_wrap_top .works_list_wrap {
	order: 3;
	margin-top: 3.5rem;
}
.works_wrap_top .btn_bgGr {
	order: 2;
}
@media (max-width: 750px) {
	.works_wrap_top .works_list_wrap {
		order: 2;
		margin-top: 2em;
	}
	.works_wrap_top {
		display: block;
	}
}


/* flow_wrap */
.flow_wrap {
	display: flex;
	align-items: center;
	background-color: #fff;
}
.flow_wrap > div {
	width: 50%;
}
.flow_wrap .flow_wrap_img {
	height: 740px;
	position: relative;
	overflow: hidden;
}
.flow_wrap .flow_wrap_img picture {
	width: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.flow_wrap_inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	max-width: calc(576px + 160px);
	padding: 0 80px;
	margin: auto;
}
.flow_wrap_inner h2 {
	order: 1;
	width: max-content;
}
.flow_wrap_inner .flow_wrap_txt {
	order: 3;
	width: 100%;
}
.flow_wrap_inner .btn_bgGr {
	order: 2;
}
.flow_wrap_inner h3 {
	position: relative;
	text-align: center;
	margin: 2.5rem 0;
}
.flow_wrap_inner h3::before {
	content: "";
	width: 100%;
	height: 1px;
	border-bottom: 1px dotted #333;
	position: absolute;
	top: 50%;
	left: 0;
	z-index: 1;
}
.flow_wrap_inner h3 span {
	font-size: var(--font-size15px);
	padding: 0 1em;
	background-color: #fff;
	position: relative;
	z-index: 2;
}
.flow_wrap_inner p {
	font-size: var(--font-size15px);
	margin: 2.5rem 0 0;
}
#modal1_1 .modal__content {
	padding: 4rem;
	max-width: 688px;
	width: 100%;
}
#modal1_1 .modal__content iframe {
	width: 560px;
	height: 315px;
	display: block;
}


@media  (max-width: 1279px) {
	.flow_wrap {
    	padding: 4vw;
	}
	.flow_wrap .flow_wrap_img {
    	height: auto;
	}
	.flow_wrap .flow_wrap_img picture {
		position: static;
		transform: inherit;
	}
	.flow_wrap_inner {
    	padding: 0 0 0 4vw;
	}
	.flow_wrap_inner .flow_wrap_txt {
    	order: 2;
	}
	.flow_wrap_inner .btn_bgGr {
    	order: 3;
		margin: 2rem auto 0;
	}
}
@media  (max-width: 750px) {
	.flow_wrap {
		flex-wrap: wrap;
		padding: 0;
	}
	.flow_wrap > div {
		width: 100%;
	}
	.flow_wrap_inner {
		order: 1;
		padding: 6.4vw 6.4vw max(40px, 10.666vw);
	}
	.flow_wrap_inner h3 {
		margin: 2rem 0;
	}
	.flow_wrap_inner p {
		margin-top: 2rem;
	}
	.flow_wrap .flow_wrap_img {
		order: 2;
	}
	.flow_wrap .flow_wrap_img {
		display: block;
	}
	#modal1_1 .modal__content {
		padding: 7vw;
		width: 90%;
	}
	#modal1_1 .modal__content iframe {
		width: 74vw;
   		height: 42vw;
		margin: auto;
	}
}




.text_anm_wrap:hover .char {
    display: inline-block;
}
@media  (min-width: 1024px) {
	.text_anm_wrap:hover .char {
    	animation: fadeIn 0.3s forwards;
    	animation-delay: calc(var(--char-index) * 0.04s);
	}
}
@keyframes fadeIn {
	0% {
        transform: translateY(0);
    }
    25% {
        transform: translateY(-0.2em);
    }
    50% {
        transform: translateX(0.5em);
        color: transparent;
    }
    100% {
        transform: translateY(0);
    }
}

/* top anm */
.top_fvSlider_txt .char {
	color: transparent;
}
.slick-active .top_fvSlider_txt .char {
		display: inline-block;
		animation: fadeIn_2 .5s forwards;
		animation-delay: calc(.4s + (var(--char-index) * 0.04s));
	}

@keyframes fadeIn_2 {
	0% {
        transform: translate(0.2em, 0.05em);
        color: transparent;
    }
    100% {
        transform: translateX(0);
		color: #fff;
    }
}
.top_fvSlider_txt .flexBox {
	opacity: 0;
	justify-content: right;
	max-width: 530px;
	margin-left: 3%;
}
.slick-active .top_fvSlider_txt .flexBox {
	animation: fadeIn_3 .8s .8s forwards;
}
@keyframes fadeIn_3 {
	0% {
		opacity: 0;
		filter: blur(10px);
    }
    100% {
        opacity: 1;
		filter: blur(0);
    }
}