.home-main {
	position: relative;
	z-index: 5;
}

.home-main:after {
	content: '';
	background-color: #f5f5f5;
	position: absolute;
	left: 0;
	right: 0;
	height: 35rem;
	bottom: 0;
	z-index: -1;
}

.home-main__bg {
	background: url("../../images/home/main.jpg") no-repeat center/cover;
	height: 80vw;
	overflow: hidden;
	position: relative;
}

.home-main__content {
	margin-top: 2rem;
	padding: 0 1.5rem;
}

.home-main__content-ttl {
	font-family: "Cormorant", serif;
	font-size: 4rem;
	font-weight: 600;
	line-height: 1.5;
	margin-bottom: 1rem;
}

.home-main__content-txt {
	font-size: 1.6rem;
	font-weight: bold;
	text-decoration: underline;
}

.home-main__content-txt .fadeText__cover,
.home-main__content-txt .fadeText__df {
	text-decoration: underline;
}

.home-main__content--clone {
	display: none;
}

.home-main .scroll {
	display: none;
}

.home-main .scroll__line {
	background-color: #fff;
	height: .1rem;
	margin-left: 1.2rem;
	position: relative;
	overflow: hidden;
	width: 9rem;
}

.home-main .scroll__line-inner {
	-webkit-animation: indicator 3s cubic-bezier(0.19, 1, 0.22, 1) infinite;
	animation: indicator 3s cubic-bezier(0.19, 1, 0.22, 1) infinite;
	background-color: #2f2f2f;
	position: absolute;
	height: .1rem;
}

.home-title {
	margin-bottom: 3rem;
	padding-top: 7vw;
	position: relative;
	text-align: center;
	z-index: 10;
}

.home-title__sub {
	color: #f5f5f5;
	font-family: "Cormorant", serif;
	font-size: 17vw;
	font-weight: bold;
	line-height: 1;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	white-space: nowrap;
	z-index: -1;
}

.home-title__ttl {
	font-size: 2.5rem;
	font-weight: bold;
}

.about-section {
	margin-bottom: 6rem;
	padding-top: 7rem;
	position: relative;
}

.about-section:after {
	content: '';
	background-color: #f5f5f5;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 10rem;
	z-index: -1;
}

.about-section .home-title__sub {
	color: #fff;
}

.about-section .about-txt {
	line-height: 2;
	margin-bottom: 5rem;
	text-align: center;
}

.about-section .about-txt p {
	margin-bottom: 3rem;
}

.about-section .about-txt p:last-child {
	margin-bottom: 0;
}

.about-section .about-img {
	overflow: hidden;
	margin: 0 -1.5rem;
	height: 60vw;
	max-height: 35rem;
}

.about-section .simpleParallax {
	height: 100%;
}

.service-section {
	padding-bottom: 7rem;
}

.service-section .home-title {
	margin-bottom: 7rem;
}

.service-section .service-list {
	margin-bottom: 7rem;
}

.service-section .service-list li {
	margin-bottom: 7rem;
	position: relative;
}

.service-section .service-list li:last-child {
	margin-bottom: 0;
}

.service-section .service-list li:nth-child(3) .service-content__num {
	margin-bottom: 3rem;
}

.service-section .service-img img {
	display: block;
	width: 100%;
}

.service-section .service-content__num {
	font-family: "Cormorant", serif;
	font-style: italic;
	font-size: 10rem;
	font-weight: 600;
	line-height: 1;
	margin: -1rem 0 .6rem;
}

.service-section .service-content__ttl {
	font-size: 2.4rem;
	font-weight: bold;
	margin-bottom: 2rem;
}

.service-section .service-content__txt {
	line-height: 2.25;
}

.service-section .service-content__txt p {
	margin-bottom: 2rem;
}

.service-section .service-content__txt p:last-child {
	margin-bottom: 0;
}

.service-section .service-content__txt .logo {
	display: flex;
}

.service-section .service-content__txt .logo span {
	margin-right: 1rem;
}

.service-section .service-content__txt .logo span:last-child {
	margin-right: 0;
}

@media only screen and (min-width: 769px) {

.home-main {
	padding-left: 26.8rem;
}

.home-main__bg {
	height: calc(100vh - 14rem);
}

.home-main__content {
	position: absolute;
	left: 4.8rem;
	bottom: 13.1rem;
	margin-top: 0;
	padding: 0;
	z-index: 100;
}

.home-main__content-ttl {
	font-size: 6.8rem;
}

.home-main__content-txt {
	font-size: 2rem;
}

.home-main__content--clone {
	display: block;
	color: #fff;
	left: -22rem;
	z-index: 101;
}

.home-main .scroll {
	display: flex;
	align-items: center;
	color: #fff;
	font-family: "Cormorant", serif;
	font-size: 1.2rem;
	font-weight: 600;
	position: absolute;
	right: 4.8rem;
	bottom: 6rem;
	transform: rotate(90deg);
	transform-origin: right;
}

.about-section {
	margin-bottom: 10rem;
	padding-top: 8rem;
}

.about-section:after {
	bottom: 23rem;
}

.about-section .home-title {
	margin-bottom: 3rem;
}

.about-section .about-txt {
	line-height: 2.25;
	margin-bottom: 13.5rem;
}

.about-section .about-txt p {
	margin-bottom: 5.7rem;
}

.about-section .about-img {
	height: 46rem;
	max-height: none;
	margin: 0;
}

.service-section {
	padding-bottom: 14rem;
}

.service-section .home-title {
	margin-bottom: 13.5rem;
}

.service-section .service-list {
	margin-bottom: 10rem;
}

.service-section .service-list li {
	min-height: 45.6vw;
	margin-bottom: 10rem;
}

.service-section .service-list li:nth-child(even) .service-img {
	right: 0;
}

.service-section .service-list li:nth-child(even) .service-content {
	margin-right: auto;
}

.service-section .service-list li:nth-child(odd) .service-img {
	left: 0;
}

.service-section .service-list li:nth-child(odd) .service-content {
	margin-left: auto;
}

.service-section .service-list li:nth-child(3) .service-content__num {
	margin-bottom: 5rem;
}

.service-section .service-img {
	position: absolute;
	top: 6rem;
	width: 46vw;
}

.service-section .service-content {
	width: 50%;
}

.service-section .service-content__num {
	font-size: 14.2rem;
	margin: -6rem 0 1.4rem;
}

.service-section .service-content__ttl {
	font-size: 2.8rem;
	margin-bottom: 3.6rem;
}

.service-section .service-content__txt p {
	margin-bottom: 4rem;
}

.service-section .service-content__txt .logo span {
	margin-right: 4rem;
}

}

@media only screen and (min-width: 1025px) {

.home-main__content {
	left: 10.8rem;
}

.home-main__content--clone {
	left: -16rem;
}

.home-title {
	padding-top: 11.7rem;
}

.home-title__sub {
	font-size: 20rem;
}

.home-title__ttl {
	font-size: 3.6rem;
}

.service-section .service-img {
	width: 56.15vw;
}

.service-section .service-content {
	width: 37%;
}

}

@media only screen and (min-width: 1281px) {

.service-section .service-img {
	width: 54.15vw;
}

}

@-webkit-keyframes indicator {

from {
	left: 0;
	transform-origin: left top;
	width: 10px;
}

20% {
	width: 30px;
}

80% {
	width: 30px;
}

to {
	transform-origin: left top;
	left: 100%;
	width: 0px;
}

}

@keyframes indicator {

from {
	left: 0;
	transform-origin: left top;
	width: 10px;
}

20% {
	width: 30px;
}

80% {
	width: 30px;
}

to {
	transform-origin: left top;
	left: 100%;
	width: 0px;
}

}


/*# sourceMappingURL=../sourcemap/pages/home.css.map */
