/* 共通 */

.top-contents {
	width: 1320px;
	max-width: 100%;
	margin: 0 auto;
	padding: 0 20px;
}


.top-main {
	margin-bottom: 70px;
}

/* =========================
   ファーストビュー
   ========================= */
.fv {
    position: relative;
    width: 100%;
    margin-bottom: 93px;
}

.fv-container {
    position: relative;
    height: 280vh;
}
.fv-container .common-text__word {
	position: absolute;
	right: 104px;
	top: 71px;
	z-index: 2;
	color: #fff;
}
.fv-container .common-text__word p{
	text-align: left;
}
.fv-container .common-text__word span {
    text-align: left;
    padding-left: 4px;
}
.common-text__word p {
	font-size: .34rem;
	font-weight: 500;
	text-align: center;
	letter-spacing: 0.18em;
	margin-bottom: -2px;
}

.common-text__word span {
	font-size: .24rem;
	font-family: 'Cormorant Garamond', serif;
	letter-spacing: 0;
	text-align: center;
	display: block;
}

.edge {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 2;
	content: '';
	width: 100%;
	height: 480px;
	background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, .7) 70%, rgba(255, 255, 255, 1) 100%);
	background: linear-gradient(rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 40%, rgba(255, 255, 255, .7) 75%, rgba(255, 255, 255, 1) 100%);
	pointer-events: none;
	border-radius: 200px 200px 0 0;
}


.fv-sticky-wrap {
    /*height: 200vh;*//*←こっちでもいい  スクロールとために必要*/
    height: 100%;/*←こっちでもいい  スクロールとために必要*/
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
}

.data-scan-text{
      position: fixed;
    top: calc(50% - 54px);/*JSの部分と一緒に変える*/
    left: 0;
    right: 0;
  margin: 0px auto 0; /*2つ目のsectionとして使う場合 margin設定をする　１つ目の場合0*/
  width: fit-content;
  text-align: center;
  font-size: .50rem;
    font-weight: 500;
  /* ここから追加（文字をグラデ塗りにする） */
  --split: 100%; /* 初期は全部黒 */
  background: linear-gradient(
    to bottom,
    #fff 0%,
    #fff var(--split),
    #000 var(--split),
    #000 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;              /* 文字色は透明にして背景を見せる */
  -webkit-text-fill-color: transparent;
    z-index: 3;
  /*stop-text__headingとセットで高さ(line-heightやフォントサイズなど*absoluteではない)を合わせる*/
  font-size:.34rem;
      letter-spacing: 0.16em;
}

.data-scan-text span {
    font-size: .24rem;
    display: block;
	font-family: "Cormorant Garamond", serif;
	    letter-spacing: 0.001em;
}

.fv1 {
    width: 100%;
    height: 150vh;
    background-repeat: no-repeat;
    background-size: cover;
}






.fv2 {
	max-width: 93%;
	width: 910px;
    margin: 0 auto;
   /* height: 35%;
     padding-bottom: 100px; */
        background-color: #ebe4d9e0;
    z-index: 2;
    position: relative;
	border-radius: 15px;
}

.stop-text {
    width: 700px;
    max-width: 100%;
    padding: 78px 0 46px;
    margin: 0 auto;
}



/* 見出し文字の箱 */
.stop-text__heading {
    padding-bottom: 115px;
    margin-bottom: 50px;
    /*data-scan-textの高さ(line-height)と合わせた方が調整しやすい*/
}

.stop-text__lead {
    text-align: center;
	font-size: .21rem;
	    line-height: 2.2;
}

.data-scan-text.is-stop {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    width: 65%;
    margin: auto;
	    z-index: 3;
}



/* =========================
   Background slider (fade + zoom-out)
   ========================= */

/* wrapper */
.top-features__contents{
	width: 1200px;
    margin: 50px auto 0;
	position: relative;
}
.background-block {
	background-image: none;
	overflow: hidden;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	clip-path: inset(0);
	z-index: 2;
}



/* fixed background container */
/*
.background-block__img {
	position: fixed;
	top: 0;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: right top;
}*/
.background-block__img {
	position: fixed;
    background-image: url(../images/top/features-back-2.jpg);
    top: 0;
	left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: right top;
}
.top-contents .background-block__img {
	max-width: 1240px;
    left: 50%;    
    transform: translateX(-50%);
}
/* each bg layer */
.background-block__img .bg {
	position: absolute;
	inset: 0;

	background-size: cover;
	background-position: right top;

	opacity: 0;
	transform: scale(1.12);
	/* 拡大状態から開始 */
	will-change: opacity, transform;

	/* フェード + ズームアウトを同期 */
	animation: bgFadeZoom 12s infinite;
}

/* 1枚目 */
.background-block__img .bg1 {
	background-image: url(../images/top/top-fv1.jpg);
	animation-delay: 0s;
}

/* 2枚目 */
.background-block__img .bg2 {
	background-image: url(../images/top/top-fv2.jpg);
	animation-delay: 4s;
}

/* 3枚目 */
.background-block__img .bg3 {
	background-image: url(../images/top/top-fv3.jpg);
	animation-delay: 8s;
}

/* fade + zoom-out keyframes
   12sの中で 0-4s が1枚の持ち時間（delayでずらして3枚回す）
   - 0〜10%: フェードイン
   - 10〜40%: 表示しながら縮小
   - 40〜50%: 等倍で少し止めてからフェードアウト
*/
@keyframes bgFadeZoom {
	0% {
		opacity: 0;
		transform: scale(1.12);
	}

	10% {
		opacity: 1;
		transform: scale(1.12);
	}

	/* フェードイン完了 */
	40% {
		opacity: 1;
		transform: scale(1.00);
	}

	/* ズームアウト完了 */
	50% {
		opacity: 0;
		transform: scale(1.00);
	}

	/* フェードアウト */
	100% {
		opacity: 0;
		transform: scale(1.00);
	}
}


/* テキストの基準位置（ここを動かせば全capが同じ場所で切替） */
.fv-caption {
  position: fixed;
  width: 300px;
  height: 100px;
  right: 52px;
  top: calc(100vh - 80px);
  z-index: 5;
  color: #fff;
  text-align: right;
  transition: opacity .1s ease;
}

.fv-caption.is-hidden {
  opacity: 0;
  pointer-events: none;
}

/* 3つのpを同じ位置に重ねる（親の左上=0,0 に固定） */
.fv-caption .cap {
  position: absolute;
  top: 0;
  right: 0;
  margin: 0;
  color: #fff;
  font-size: .15rem;
  font-weight: 500;
  opacity: 0;
  will-change: opacity;
  animation: capFadeNoOverlap 12s infinite;
}

/* delay */
.fv-caption .cap1 { animation-delay: 0s; }
.fv-caption .cap2 { animation-delay: 4s; }
.fv-caption .cap3 { animation-delay: 8s; }

/* caption fade（重なりゼロ：暗転時間を入れる） */
@keyframes capFadeNoOverlap {
  0%   { opacity: 0; }  /* 暗転 */
  8%   { opacity: 1; }  /* フェードイン */
  36%  { opacity: 1; }  /* 表示キープ */
  40%  { opacity: 0; }  /* フェードアウト */
  100% { opacity: 0; }  /* 暗転（次のcapと重ならない） */
}




/* =========================
   セカンドビュー
   ========================= */
.fv-second__intro {
    background-color: #ebe4d9e0;
    border-radius: 20px;
    width: 1200px;
    max-width: 100%;
    margin: -550px auto 230px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 66px 0 66px;
	position: relative;
	z-index: 10;
}

.fv-second__intro--left {
	position: relative;
	width: 59%;
}

.fv-second-back-text {
	width: 570px;
	height: fit-content;
	margin: auto;
	left: 0;
	    top: 60px;
    /* bottom: 0;*/
	right: 0;
	position: absolute;
	z-index: -1;
}

.fv-second__intro--left .common-text__word {
	position: relative;
	z-index: 3;
}

.fv-second__intro--right {
	width: 40%;
}

.fv-second__intro--right p {
	font-size: .19rem;
	font-weight: 500;
	line-height: 2.16;
	letter-spacing: 0.1em;
}

/* 初期：背景透明 */
.fv-second__intro{
  position: relative;
  background-color: transparent;
  border-radius: 15px;   /* 既存に合わせて */
  overflow: hidden;      /* 枠線の角丸をきれいに */
}

/* 中身は最初はふわっと用に隠す（任意） */
.fv-second__intro--left,
.fv-second__intro--right{
  opacity: 0;
  transition: opacity .6s ease, transform .6s ease;
  will-change: opacity, transform;
}

/* 枠線（4本を順番に伸ばして“描画”） */
.fv-second__intro::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  z-index: 2;

  /* 4辺をbackgroundで作る */
  --c: #ebe4d9e0;
  --t: 2px; /* 枠線太さ */
  background:
    linear-gradient(var(--c), var(--c)) 0    0 / 0 var(--t) no-repeat,         /* top */
    linear-gradient(var(--c), var(--c)) 100% 0 / var(--t) 0 no-repeat,         /* right */
    linear-gradient(var(--c), var(--c)) 100% 100% / 0 var(--t) no-repeat,      /* bottom */
    linear-gradient(var(--c), var(--c)) 0 100% / var(--t) 0 no-repeat;         /* left */

  opacity: 0; /* 非アクティブは非表示 */
}

/* 中身を枠線より上に */
.fv-second__intro > *{
  position: relative;
  z-index: 3;
}

/* 発火後：枠線をゆっくり描く */
.fv-second__intro.is-active::before{
  opacity: 1;
  animation: borderDraw .8s ease forwards; /* ← 0.8s → 1.6s */
}

/* 枠線が一周した後に背景を付ける（時間に合わせて調整） */
.fv-second__intro.is-active{
  transition: background-color .45s ease;
  transition-delay: .85s; /* ← 枠線1.6sの直後 */
  background-color: #ebe4d9e0;
}

/* 中身表示も後ろにずらす（任意） */
.fv-second__intro.is-active .fv-second__intro--left{
  opacity: 1;
  transition-delay: .85s; /* ← 枠線1.6sの直後 */
}
.fv-second__intro.is-active .fv-second__intro--right{
  opacity: 1;
  transition-delay: .85s; /* ← 枠線1.6sの直後 */
}

/* 枠線描画：上→右→下→左 */
@keyframes borderDraw{
  0%{
    background-size: 0 var(--t), var(--t) 0, 0 var(--t), var(--t) 0;
  }
  25%{
    background-size: 100% var(--t), var(--t) 0, 0 var(--t), var(--t) 0;
  }
  50%{
    background-size: 100% var(--t), var(--t) 100%, 0 var(--t), var(--t) 0;
  }
  75%{
    background-size: 100% var(--t), var(--t) 100%, 100% var(--t), var(--t) 0;
  }
  100%{
    background-size: 100% var(--t), var(--t) 100%, 100% var(--t), var(--t) 100%;
  }
}




/* =========================
   ビジネス
   ========================= */
.top-business.top-contents {
	margin-bottom: 100px;
	position: relative;
	    overflow: hidden;
}


.top-business__contents {
	display: flex;
	justify-content: space-between;
	width: 1240px;
	max-width: 100%;
	margin: 38px auto 0;
	padding: 0 20px;
}

.top-business__back-img {
	width: 48%;
	position: relative;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	padding: 53px 0 41px;
	border-radius: 15px;
	overflow: hidden;
}

.top-business__back-img::before {
	content: "";
	position: absolute;
	z-index: -1;
	inset: 0;
	background-size: cover;
	background-position: center;
	/*
  transform: scale(1.1);
  transition: transform 3.6s cubic-bezier(.2,.7,.2,1);*/
}

/*.top-business01::before {
	background-image: url(../images/top/business01.jpg);
}

.top-business02::before {
	background-image: url(../images/top/business02.jpg);
}

.top-business__contents.loaded .top-business__back-img::before {
	transform: scale(1.0);
}
*/

.top-business__back-img.top-business02 {
    width: 100%;
}

.top-business .background-block__img{
	background-image: url(../images/top/features-back-pc.jpg);
	    background-position: left top;
}

.top-business .background-block {
    top: 38%;
    width: 91%;
    right: 0;
    margin: auto;
    border-radius: 10px;
    height: 62%;
	clip-path:inset(0 round 10px)
}

.top-business .js-fade {
    position: relative;
    z-index: 2;
}


.top-business__text--wrap {
    background-color: #ffffffc7;
    padding: 21px 0 25px;
    width: 58%;
    /* margin: 0 auto; */
    margin-left: auto;
    margin-right: 50px;
    border-radius: 10px;
}

.top-business__name {
	font-size: .30rem;
	font-weight: 500;
	/*text-align: center;*/
	letter-spacing: 0.1em;
	margin-bottom: 3px;
	    color: #fff;
		    width: 90%;
    margin: 0 auto 129px;
}

.top-business__lead {
    font-size: .16rem;
    /* text-align: center; */
    padding: 0 39px;
    line-height: 1.75;
        letter-spacing: 0.05em;
}

/* =========================
   スクロールヒント
   ========================= */
.group-scrollhint .scroll-hint-icon {
    left: 30% !important;
}
.scroll-hint-icon-white:after,
.scroll-hint-icon::after {
    opacity: 1 !important;
}
.scroll-hint-shadow-wrap {
    pointer-events: none;
}
.group-img__wrap .sc-hint-wrap {
    height: 164vw;
    width: 255%;
    margin-top: -165vw;
    transition: 1s;
}
.scroll-hint-icon-wrap {
    display: block;
}
.group-img__wrap .scroll-hint-icon {
    left: 0 !important;
	right: 0 !important;
	margin: auto;
	animation: blinking 1s ease-in-out infinite alternate;
}


/* 点滅 */
@keyframes blinking {
   0% {
   opacity: 0;
   }
   100% {
   opacity: 1;
   }
}



/* =========================
   Features
   ========================= */
   
.top-features {
	margin: 0 auto 93px;
    margin: 0 auto 110px; /*top-projects非表示時*/
	overflow: hidden;
	position: relative;
}

.top-features__contents {
	border-radius: 15px;
	overflow: hidden;
	margin-top: 50px;
}

.top-features__contents-img {
	width: 1200px;
	max-width: 100%;
	margin: 0 auto;
	/* border-radius: 15px; */
	/* overflow: hidden; */
}
/*
.top-features__contents-img::before {
	content: "";
	position: absolute;
	z-index: -1;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-image: url(../images/top/features-back.jpg);
}

.top-features__contents.loaded .top-features__contents-img::before {
	transform: scale(1.0);
	background-image: url(../images/top/features-back.jpg);
}


*/


.top-features__item--flex {
	display: flex;
	justify-content: space-between;
	/* margin-bottom: 47px; */
	padding-bottom: 1%;
}

.top-features__item {
	margin: 0 auto;
	width: 46%;
	padding: 6% 0 6.5%;
	    position: relative;
    z-index: 2;
}

.top-features .background-block {

}

.top-features__item--midashi {
    font-size: .30rem;
    text-align: center;
    letter-spacing: 0.16em;
    margin-bottom: 19px;
    padding-bottom: 15px;
    font-weight: 500;
    position: relative;
}
.top-features__item--midashi::before{
    content: "";
    position: absolute;
    bottom: 0px;
    left: 0;
	right:0;
	margin:auto;
    width: 100px;
    height: 8px;
    background-color: #006339;

}

.top-features__item__text {
	font-size: .16rem;
	text-align: center;
	line-height: 1.75;
}

.top-features__item3 {
    padding: 2.2% 0 45px;
    position: relative;
    z-index: 2;
}

.top-features-figure {
	width: 86%;
	margin: 31px auto 0;
}

/*.top-features__contents .background-block__img::before {
    content: "";
    position: absolute;
    background-color: #fff;
    left: 27px;
    right: 0;
    margin: auto;
    width: 50px;
    height: 50%;
}

.top-features__contents .background-block__img::after {
    content: "";
    position: absolute;
    background-color: #fff;
    left: 0;
    bottom:0;
	top:0;
    margin: auto;
    width: 100%;
    height: 50px;
}*/

.top-features__item--flex{
	position: relative;
}

.top-features__item--flex::before {
    content: "";
    position: absolute;
    background-color: #fff;
    left: 0;
    right: 0;
    margin: auto;
    width: 27px;
    height: 100%;
	    z-index: 2;
}

.top-features__item3:before {
    content: "";
    position: absolute;
    background-color: #fff;
    left: 0;
    top: -24px;
    margin: auto;
    width: 100%;
    height: 27px;
    z-index: 2;
}


/* =========================
   projects
   ========================= */
.top-projects {
	margin-bottom: 90px;
    margin-bottom: 132px; /*coming soon中*/
}

.top-projects__contents {
	width: 1240px;
	max-width: 100%;
	margin: 0 auto;
	padding: 0 20px;

	display: flex;
	justify-content: space-between;

}


.top-projects__left {
	width: 39%;
}

.top-projects__right {
	width: 56.5%;
	margin-top: 12px;
}

.top-projects__right img {
	border-radius: 15px;
}

.top-projects__title {
	letter-spacing: 0.14em;
	font-size: .30rem;
}

.top-projects__sub {
	letter-spacing: 0.14em;
	font-size: .30rem;
	line-height: 1.5;
	margin-bottom: 18px;
}

.top-projects__text {
	font-size: .16rem;
}


/* =========================
   company
   ========================= */
.top-company {
	background-color: #EBE4D9;
	padding: 60px 10px 70px;
	margin-bottom: 62px;
}

.top-company-container {
	width: 1320px;
	max-width: 100%;
	margin: 0 auto;
	padding: 0 20px;
}

.top-company__contents {
	width: 1200px;
	max-width: 100%;
	margin: 0 auto;
}

.top-company__lead {
	font-size: .30rem;
	margin-bottom: 30px;
}

.top-company__flex {
	display: flex;
	justify-content: space-between;
}

.top-company .common-title-wrap {
	margin-bottom: 53px;
}

.top-company__info {
	width: 39%;
}

.top-company__info p {
	font-size: .16rem;
    margin-top: 47px;
    padding-bottom: 44%;
}

.top-company__achievement {
	width: 56.5%;
}

.top-company__achievement p {
	font-size: .20rem;
	text-align: center;
	margin-bottom: 17px;
}

.top-company__btn {
	width: 361px;
	padding: 14px 28px 14px 28px;
	margin-bottom: 46px;
}

.top-tamakihome__btn {
	width: 361px;
}

.top-company__btn,
.top-tamakihome__btn {
	background-color: initial;
}

.top-company__btn .btn-arrow,
.top-tamakihome__btn .btn-arrow {
	margin-left: 15px;
	margin-right: 0;
	margin-top: -5px;
}

.top-company__btn.common-btn:hover,
.top-tamakihome__btn.common-btn:hover {
	background-color: inherit;
	color: #006339;
	opacity: 1;
	border: solid 1px #006339;
}

.top-company__btn:hover .btn-arrow::before,
.top-tamakihome__btn:hover .btn-arrow::before {
	border-bottom: solid 1.5px #006339;
	border-right: solid 2.5px #006339;
	width: 100px;
}

.scroll-hint-shadow-wrap::before,
.scroll-hint-shadow-wrap::after {
	content: none;

}


/* =========================
   news
   ========================= */
.top-news__contents {
	width: 1200px;
	max-width: 100%;
	margin: 0 auto;
}

@media screen and (min-width:801px) and (max-width:1240px) {
	.top-features__contents,
	.top-features__wrap,
	.background-block{
		width: calc(100vw - 40px);
	}
	
	.fv-container .background-block{
		width: 100%;
	}
	
	.top-features__contents-img{
		width: calc(100vw - 40px);
		margin: 0;
	}
	
	.fv-second__intro {
	    padding: 66px 20px;
    	width: calc(100% - 40px);
	}
}
@media screen and (max-width:800px) {

	/*ファーストビュー*/
	.fv-container {
        position: relative;
        height: 280vh;
    }
	.background-block__img {
		height: 100vh;
	}
	.common-text__word p {
		font-size: .24rem;
		line-height: 1.5;
		margin-bottom: 7px;
	}
	.fv-container .common-text__word p {
		text-align: center;
	}
	.fv-container .common-text__word span{
		text-align: center;
	    padding-left: 0;
	}
	.common-text__word span {
		font-size: .18rem;
		line-height: 1.4;
	}

    .fv {
        margin-bottom: 70px;
    }


	.fv-container .common-text__word {
		position: absolute;
		right: 0;
		top: 7%;
		left: 0;
		margin: auto;
		width: fit-content;
		height: fit-content;
	}


	.bg p {
		bottom: 16%;
		right: 0;
		left: 0;
		margin: auto;
		width: fit-content;
		font-size: .13rem;
	}

	.fv-caption {
		left: 0;
		right: 0;
		margin: auto;
		top: calc(100dvh - 80px);
	}

	.fv-caption .cap {
		text-align: center;
		right: 0;
		left: 0;
	}
	
	
	.fv2 {
    	width: 88%;
	}	
	.data-scan-text {
    	font-size: .24rem;
		line-height: 1.6;
		width: 80%;
		top: calc(50% - 60px);
	}
	
	.data-scan-text span {
    	font-size: .18rem;
		line-height: 1.4;
	}

.stop-text__lead {
   font-size: .16rem;
   line-height: 1.9;
}
	
	.stop-text__heading {
    padding-bottom: 100px;
    margin-bottom: 50px;
}

.data-scan-text.is-stop {
    width: 87%;
}

.stop-text {
    width: 700px;
    max-width: 100%;
    padding: 35px 0 46px;
    margin: 0 auto;
}
	
	
	
	
	
	
	
	
	

    .fv-second__intro {
        margin: -54px auto 0;
        margin: -480px auto 120px;
        width: 90%;
        flex-direction: column;
        padding: 39px 0 44px;
    }

	.fv-second__intro--left {
		width: 100%;
		margin-bottom: 23px;
	}

	.fv-second__intro--right {
		width: 100%;
	}

	.fv-second__intro--right p {
		font-size: .16rem;
		line-height: 1.9;
		letter-spacing: 0.1em;
		text-align: center;
	}
	
	.fv-second-back-text {
    	width: 287px;
	}
	
	.background-block__img .bg1{
		background-image: url(../images/top/top-fv1sp.jpg);
	}
	.background-block__img .bg2{
		background-image: url(../images/top/top-fv2sp.jpg);
	}
	.background-block__img .bg3{
		background-image: url(../images/top/top-fv3sp.jpg);
	}


	/* トップビジネス */
	.top-business__contents {
		margin: 35px auto 0;
		padding: 0 0px;
		flex-direction: column;
	}

	.top-business__back-img {
		width: 100%;
		padding: 48px 0 30px;
		border-radius: 10px;
		margin-bottom: 4px;
	}

	.top-business__text--wrap {
        padding: 28px 0 28px;
        width: 82%;
        border-radius: 10px;
        margin: auto;
    }

	.top-business__name {
		font-size: .24rem;
		margin-bottom: 25px;
		text-align: center;
	}

	.top-business__lead {
		font-size: .15rem;
		line-height: 1.9;
		letter-spacing: 0.12em;
		    padding: 0 30px;
		text-align: center;
		letter-spacing: 0.008em;
	}

	.top-business.top-contents {
		margin-bottom: 60px;
	}
	
	.top-business .background-block__img {
    background-image: url(../images/top/features-back-sp.jpg);
	background-position: left top;
	
}
.top-features .background-block {

}



	/*Features*/
	.top-features__contents {
        overflow: hidden;
	    border-radius: 15px;
		width:100%;
		margin-top: 18px;
	}
	
.background-block__img {
    background-image: url(../images/top/features-bg-vertical.jpg);
}

	.top-features {
		margin: 0 auto 79px;
		overflow: hidden;
	}

	.top-features__item--midashi {
		font-size: .24rem;
		letter-spacing: 0.16em;
		margin-bottom: 15px;
		padding-bottom: 17px;
	}
	
	.top-features__item--midashi::before {
    width: 75px;
    height: 6px;
}

	.top-features__item__text {
		font-size: .14rem;
		text-align: center;
		line-height: 1.75;
	}

	.top-features__item {
		width: 100%;
		padding: 7.5% 0 13.5%;
	}
	
.top-features__item2 {
    padding: 8.5% 0 15.5%;
}
	.top-features__item3 {
		padding: 5.5% 0 6.5%;
		        overflow: hidden;
	}
	
	.top-features__item::before{
		content: "";
    	position: absolute;
    	background-color: #fff;
    	left: 0;
    	bottom: 0px;
    	width: 100%;
    	height: 20px;
    	z-index: 2;
	}

	.top-features-figure {
		width: 95%;
		margin: 25px auto 0;
	}
	
	.top-features__item--flex {
    	flex-direction: column;
	}

	.top-company__btn {
		width: 340px;
		padding: 14px 28px 14px 28px;
		margin-bottom: 46px;
	}

	.top-tamakihome__btn {
		width: 340px;
	}
	


.top-features__item--flex::before {
	width: 20px;
	display:none;
}

.top-features__item3:before {
    top: -18px;
    height: 18px;
	display:none;
}

.top-features__item--flex {
    padding-bottom: 0;
}


	/* Projects */
	.top-projects__contents {
		width: 1240px;
		max-width: 100%;
		margin: 0 auto;
		padding: 0 20px;
		display: flex;
		justify-content: space-between;
		flex-direction: column;
	}

	.top-projects__contents {
		padding: 0 0px;
	}

	.top-projects__left {
		width: 100%;
	}

	.top-projects__title {
		letter-spacing: 0.14em;
		font-size: .24rem;
	}

	.top-projects__contents {
		flex-direction: column;
	}

	.top-projects .common-title-wrap {
		margin-bottom: 33px;
	}

	.top-projects__sub {
		letter-spacing: 0.14em;
		font-size: .24rem;
	}

	.top-projects__text {
		font-size: .15rem;
	}

	.top-projects__right {
		width: 100%;
		margin-top: 35px;
	}

	.top-projects {
		margin-bottom: 72px;
        margin-bottom: 85px;/*coming soon中*/
	}

	/* Company */
	.top-company {
		padding: 57px 20px 63px;
		margin-bottom: 62px;
		overflow: hidden;
	}

	.top-company-container {
		padding: 0 0px;
	}

	.top-company__lead {
		font-size: .20rem;
		line-height: 1.8;
		margin-bottom: 13px;
        padding: 0 20px;
	}

	.top-company .common-title-wrap {
		margin-bottom: 42px;
	}

	.top-company__flex {
		flex-direction: column;
	}



	.top-company__info {
		width: 100%;
		margin-bottom: 45px;
	}

    .top-company__info p {
        font-size: .15rem;
        margin-bottom: 30px;
        margin-top: 0px;
        padding: 0 20px;
    }


	.top-company__btn {
		width: 302px;
		padding: 12px 28px 12px 28px;
		margin-bottom: 46px;
		white-space: nowrap;
	}

	.top-tamakihome__btn {
		width: 302px;
		padding: 12px 36px 12px 50px;
		white-space: nowrap;
	}

	.top-company__btn .btn-arrow,
	.top-tamakihome__btn .btn-arrow {
		margin-left: 15px;
		margin-right: 0;
		margin-top: -5px;
		width: 45px;
	}

	.top-company__btn:hover .btn-arrow::before,
	.top-tamakihome__btn:hover .btn-arrow::before {
		border-bottom: solid 1.5px #006339;
		border-right: solid 2.5px #006339;
		width: 60px;
	}

	.top-company__btn {
		width: 302px;
		padding: 12px 28px 12px 28px;
		margin-bottom: 23px;
	}

	.top-company__achievement {

		position: initial !important;
		overflow: initial !important;
		width: 100vw;
		margin-left: -20px;
	}

	.top-company__img {
		overflow-x: scroll;
		width: 100vw;
		max-width: 100vw;
		padding-bottom: 10px;
		margin-left: -20px;
	}

	.top-company__img img {
		width: 1470px;
		max-width: initial;
		margin-right: 20px;
	}

	.top-company__img::-webkit-scrollbar {
		height: 6px;
		background-color: #DBDBDB;
	}

	.top-company__img::-webkit-scrollbar-thumb {
		background-color: #000;
		border-radius: 15px;
	}

	.top-company__img::-webkit-scrollbar-track {
		background-color: #EBE4D9;
	}

	.top-company__achievement p {
		font-size: .16rem;
		text-align: center;
		margin-bottom: 20px;
	}

	.top-main {
		margin-bottom: 43px;
	}

	.slick-slide img {
		display: block;
		height: auto !important;
	}

	.slick-slide {
		margin-right: 30px;
	}

	.company-carousel01 {
		width: 361px !important;
	}

	.company-carousel02 {
		width: 189px !important;
	}

	.company-carousel03 {
		width: 391px !important;
	}

	.company-carousel04 {
		width: 451px !important;
	}
	
	.company-carousel05 {
		width: 175px !important;
	}
	
	.slick-track {
    display: flex;
    align-items: flex-end;
}

}