@charset "utf-8";
hgroup {
		display: flex;
		flex-direction: column-reverse;
		margin: 0 0 50px;
		text-align: center;
}
.philosophy_section hgroup, .contact_section hgroup {
		text-align: left;
}
hgroup .en {
		font-size: 52px;
		font-family: "Montserrat", sans-serif;
		font-optical-sizing: auto;
		font-style: normal;
		font-weight: 900;
		color: #C3392D;
		letter-spacing: 0.07em;
		margin: 0 0 10px;
}
hgroup h2 {
		font-size: 26px;
		font-weight: 700;
}
@media(max-width: 960px) {
		hgroup {
				margin-bottom: 30px;
		}
		hgroup .en {
				font-size: 40px;
		}
		hgroup h2 {
				font-size: 20px;
		}
}
@media(max-width: 767px) {
		hgroup {
				margin: 0 0 30px;
		}
		.philosophy_section hgroup, .contact_section hgroup {
				text-align: center;
		}
		hgroup .en {
				font-size: 30px;
		}
		hgroup h2 {
				font-size: 18px;
		}
}
/* ============ */
.philosophy_section {
		padding: 140px 0 80px;
		background-repeat: no-repeat;
		background-position: center top;
		background-size: cover;
		background-image: url("../images/top_philosophy_bg_pc.jpg")
}
.philosophy_wrap {
		max-width: 1100px;
		margin: 0 auto;
		display: flex;
		align-items: center;
}
.philosophy_left {
		width: 570px;
		position: relative;
		left: -65px;
		z-index: 2;
		top: -42px;
}
.philosophy_left img {
		width: 100%;
		height: auto;
}
.philosophy_right {
		flex: 1;
		position: relative;
}
.philosophy_right::before, .philosophy_right::after {
		content: '';
		display: block;
		position: absolute;
}
.philosophy_right::before {
		top: -75px;
		left: -220px;
		width: calc(100% + 320px);
		height: calc(100% + 150px);
		background: #f3f1f1 url(../images/check_bg.png?2602);
		box-shadow: rgba(0, 0, 0, 0.02) 3px 3px 5px;
		background: #fff !important;
}
.philosophy_right::after {
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: 100%;
		background-image: url("../images/top_philosophy_illust.png?2602");
		width: 245px;
		height: 112px;
		bottom: -115px;
		right: 0;
		mix-blend-mode: multiply;
		display: none;
}
.philosophy_right_inner {
		position: relative;
		z-index: 2
}
.philosophy_caption p {
		line-height: 2.0;
}
.philosophy_caption p:first-child {
		margin-bottom: 1em;
}
@media(max-width: 1200px) {
		.philosophy_left {
				width: 45%;
				left: -10px;
				top: -42px;
				margin-right: 30px;
		}
		.philosophy_right::before {
				top: -40px;
				left: -150px;
				width: calc(100% + 150px);
				height: calc(100% + 80px);
		}
		.philosophy_right::after {
				right: 30px;
		}
}
@media(max-width: 960px) {
		.philosophy_left {
				top: -80px
		}
		.philosophy_right::after {
				width: 200px;
				height: 94px;
				bottom: -75px;
				right: 20px;
		}
}
@media(max-width: 767px) {
		.philosophy_section {
				padding-top: 40px;
				padding-bottom: 90px;
				background-image: url("../images/top_philosophy_bg_sp.jpg")
		}
		.philosophy_wrap {
				display: block;
		}
		.philosophy_left {
				width: calc(100% - 20px);
				left: 0;
				top: inherit;
				margin: 0 0 15px;
		}
		.philosophy_right {
				background: #f3f1f1 url(../images/check_bg_sp.png?2602);
				position: relative;
				width: calc(100% - 20px);
				margin-left: 20px;
				padding: 35px 0 50px;
				display: flex;
				justify-content: center;
		}
		.philosophy_right::before {
				display: none
		}
		.philosophy_right::after {
				width: 180px;
				height: 84px;
				bottom: -40px;
				right: 15px;
		}
}
/* ============ */
.service_section {
		padding: 80px 30px 120px
}
.service_wrap {
		max-width: 1040px;
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
}
.service_col {
		width: calc(50% - 20px);
		text-align: center;
		position: relative;
		box-shadow: rgba(0, 0, 0, 0.02) 3px 3px 5px;
}
.service_col::after {
		content: '';
		display: block;
		position: absolute;
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: 100%;
		pointer-events: none;
		mix-blend-mode: multiply;
		background-image: url("../images/top_service_illust-1.png?2602");
		width: 110px;
		height: 120px;
		left: -10px;
		bottom: -35px;
}
.service_wrap .service_col:last-child::after {
		background-image: url("../images/top_service_illust-2.png?2602");
		width: 85px;
		height: 65px;
		left: inherit;
		right: -40px;
		bottom: -20px;
}
@media(max-width: 960px) {
		.service_wrap .service_col:last-child::after {
				right: 10px;
				bottom: -40px;
		}
}
.service_col_hdr {
		background: #C3392D;
		color: #fff;
		padding: 17px 0 20px;
}
.service_wrap .service_col:last-child .service_col_hdr {
		background: #A52317;
}
.service_col hgroup {
		margin: 0
}
.service_col hgroup .en {
		font-size: 16px;
		color: #fff;
		margin: 0 0 5px;
}
.service_col_caption {
		padding: 40px 0px;
		background: #f3f1f1 url(../images/check_bg.png?2602);
}
.service_col p {
		line-height: 2.0;
		margin: 0;
}
.service_col .linkBtn {
		margin: 40px auto 0;
}
.service_col p .extrabr {
		display: none
}
@media(min-width: 768px) and (max-width: 960px) {
		.service_col_caption p .extrabr {
				display: block
		}
		.service_col_caption p {
				min-height: 9em;
		}
}
@media(max-width: 960px) {
		.service_col {
				width: calc(50% - 10px);
		}
		.service_col::after {
				width: 90px;
				height: 100px;
				left: -25px;
		}
		.works_left_caption p {
				font-size: 15px;
		}
		.service_col .linkBtn {
				margin: 30px auto 0;
		}
}
@media(max-width: 767px) {
		.service_section {
				padding: 60px 20px 80px
		}
		.service_wrap {
				display: block;
		}
		.service_col {
				width: auto;
				margin: 0
		}
		.service_col_hdr {
				padding: 13px 0 14px;
		}
		.service_col hgroup .en {
				font-size: 14px;
				margin: 0 0 2px;
		}
		.service_wrap .service_col:first-child {
				margin-bottom: 50px;
		}
		.service_col_caption {
				padding: 25px 0px;
				background: #f3f1f1 url(../images/check_bg_sp.png?2602);
		}
		.service_col_caption p {
				min-height: inherit;
		}
		.service_col::after {
				width: 65px;
				height: 72px;
				left: -10px;
				bottom: -25px;
		}
		.service_wrap .service_col:last-child::after {
				right: -10px;
				bottom: -20px;
				width: 60px;
				height: 47px;
		}
}
/* =============== */
.works_section {
		padding: 0 0px 130px;
}
.works_wrap {
		text-align: center;
		display: flex;
		position: relative;
		min-height: 29vw;
		box-shadow: rgba(0, 0, 0, 0.02) 0px 3px 7px;
}
.works_left {
		width: 50%;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 40px 0;
		position: relative;
		background: #f3f1f1 url(../images/check_bg.png?2602);
}
.works_left::after {
		content: '';
		display: block;
		position: absolute;
		bottom: -35px;
		right: 10vw;
		width: 155px;
		height: 260px;
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: 100%;
		background-image: url("../images/top_works_illust.png?2602");
		pointer-events: none;
		mix-blend-mode: multiply;
}
.works_left_caption p {
		line-height: 1.8;
}
.works_left_caption .linkBtn {
		margin: 50px auto 0;
		position: relative;
		z-index: 10
}
.works_right {
		flex: 1;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 30px 0;
}
.works_all_cont {
		z-index: 10;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		width: 80%;
		max-width: 800px;
}
.works_tile {
		width: 50%;
		margin: 0 0 30px;
		text-align: left;
}
.works_all_cont .works_tile:nth-child(3), .works_all_cont .works_tile:nth-child(4) {
		margin-bottom: 0;
}
.works_tile a {
		color: #222;
		text-decoration: none;
}
.works_tile_thumb {
		overflow: hidden;
		margin: 0 0 15px
}
.works_tile_thumb img {
		width: 100%;
		aspect-ratio: 10 / 6.6;
		height: auto;
		object-fit: cover;
		transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
@media (hover: hover) {
		.works_tile a:hover {
				color: #C3392D;
		}
		.works_tile a:hover img {
				transform: scale(1.08)
		}
}
.works_tile_caption {
		padding-right: 30px;
}
.works_tile_caption p {
		font-size: 16px;
		font-weight: 700;
		line-height: 1.6;
		margin: 0 0 15px
}
.category_gr {
		display: flex;
		flex-wrap: wrap;
}
.category_tag {
		display: flex;
		align-items: center;
		height: 26px;
		border: 1px solid #B32518;
		border-radius: 5px;
		color: #B32518;
		padding: 0 10px;
		box-sizing: border-box;
		font-size: 14px;
		font-weight: 500;
}
.category_tag span {
		transform: translateY(-1px)
}
@media(max-width: 1400px) {
		.works_wrap {
				min-height: 38vw;
		}
		.works_all_cont {
				width: 84%;
		}
}
@media(max-width: 1700px) {
		.works_left::after {
				right: 30px;
		}
}
@media(max-width: 1200px) {
		.works_left {
				width: 42%;
		}
		.works_left::after {
				right: 10px;
				width: 125px;
				height: 210px;
		}
}
@media(min-width: 961px) {
		.works_right .linkBtn {
				display: none
		}
}
@media(max-width: 960px) {
		.works_wrap {
				display: block;
				position: relative;
				min-height: inherit;
		}
		.works_left {
				width: 100%;
		}
		.works_right {
				padding: 40px 30px 0;
				display: block;
		}
		.works_left .linkBtn {
				display: none
		}
		.works_all_cont {
				width: 100%;
				margin: 0 auto;
		}
		.works_right .linkBtn {
				margin: 60px auto 0;
		}
}
@media(max-width: 767px) {
		.works_section {
				padding: 0 0px 80px;
		}
		.works_left {
				padding: 35px 0;
				background: #f3f1f1 url(../images/check_bg_sp.png?2602);
		}
		.works_left::after {
				top: -20px;
				left: inherit;
				right: 30px;
				width: 75px;
				height: 135px;
		}
}
.works_right {
		padding: 0;
		position: relative;
}
.works_all_cont {
		width: 100%;
}
.works_tile_caption {
		padding-left: 10px;
		padding-right: 15px;
}
.works_tile_caption p {
		font-size: 14px;
		font-weight: 500;
		margin: 0 0 10px;
}
.category_tag {
		height: 26px;
		border-radius: 4px;
		padding: 0 8px;
		font-size: 13px;
}
.works_right .linkBtn {
		margin: 40px auto 0;
}
/* =============== */
.recruit_section {
		padding: 0 0px 160px;
}
.recruit_wrap {
		background: #f3f1f1 url(../images/check_bg.png?2602);
		text-align: center;
		display: flex;
		position: relative;
		min-height: 29vw;
		box-shadow: rgba(0, 0, 0, 0.02) 0px 3px 5px;
}
.recruit_wrap::before {
		content: '';
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 50%;
		height: 100%;
		background-repeat: no-repeat;
		background-position: right center;
		background-size: cover;
		background-image: url("../images/top_recruit_photo_2.jpg")
}
.recruit_wrap p:not(.en) {
		line-height: 1.8;
		text-align: center;
}
.recruit_photo {
		width: 50%;
}
.recruit_caption {
		flex: 1;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 80px 0;
		position: relative;
}
.recruit_caption::after {
		content: '';
		display: block;
		position: absolute;
		bottom: -23px;
		right: 12vw;
		width: 120px;
		height: 185px;
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: 100%;
		background-image: url("../images/top_recruit_illust2.png");
		pointer-events: none;
		mix-blend-mode: multiply;
}
.recruit_caption .linkBtn {
		margin: 50px auto 0;
}
@media(max-width: 1700px) {
		.recruit_caption::after {
				right: 6vw;
		}
}
@media(max-width: 1400px) {
		.recruit_wrap {
				min-height: 38vw;
		}
		.recruit_caption {
				flex: 1;
				width: auto;
				display: flex;
				justify-content: center;
				align-items: center;
				padding: 0;
				margin: 0;
		}
		.recruit_caption::after {
				right: 20px;
				bottom: -85px;
		}
}
@media(max-width: 1200px) {
		.recruit_photo {
				width: 48%;
		}
		.recruit_wrap::before {
				width: 48%;
		}
		.recruit_caption {
				padding: 30px 0;
		}
}
@media(max-width: 960px) {
		.recruit_wrap {
				display: block;
				min-height: inherit;
		}
		.recruit_photo {
				width: 100%;
		}
		.recruit_wrap::before {
				position: static;
				top: inherit;
				left: inherit;
				width: 100%;
				height: 64.5vw;
				background-image: url("../images/top_recruit_photo_mid.jpg");
				background-repeat: no-repeat;
				background-position: center center;
				background-size: 100%;
		}
		.recruit_caption {
				padding: 40px 0;
		}
		.recruit_caption::after {
				bottom: -100px;
				right: 20px;
				width: 96px;
				height: 150px;
				background-size: 100%;
		}
		.recruit_caption .linkBtn {
				margin: 30px auto 0;
		}
}
@media(max-width: 767px) {
		.recruit_section {
				padding-bottom: 120px;
		}
		.recruit_wrap {
				background: #f3f1f1 url(../images/check_bg_sp.png?2602);
		}
		.recruit_wrap::before {
				height: 77vw;
		}
		.recruit_photo {
				width: 100%;
		}
		.recruit_caption::after {
				bottom: -30px;
				right: 20px;
				width: 49px;
				height: 105px;
				background-image: url("../images/top_recruit_illust2_sp.png");
		}
		.recruit_caption {
				width: auto;
				display: block;
				margin: 0;
				padding: 35px 0 40px;
				position: relative;
		}
		.recruit_caption .linkBtn {
				margin: 25px auto 0;
		}
}
/* =============== */
.contact_section {
		padding: 0 30px 80px;
}
.contact_wrap {
		max-width: 1100px;
		margin: 0 auto;
		background: #f3f1f1 url(../images/check_bg.png?2602);
		padding: 60px 120px;
		box-sizing: border-box;
		display: flex;
		align-items: flex-start;
		position: relative;
		box-shadow: rgba(0, 0, 0, 0.02) 0px 3px 5px;
}
.contact_wrap::after {
		content: '';
		display: block;
		position: absolute;
		bottom: -40px;
		right: 15px;
		width: 150px;
		height: 175px;
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: 100%;
		background-image: url("../images/top_contact_illust.png?2602");
		pointer-events: none;
		mix-blend-mode: multiply;
}
.contact_wrap_left {
		margin-right: 120px;
}
.contact_wrap_right {
		flex: 1
}
.contact_wrap_right p {
		line-height: 1.8;
		margin: 0 0 25px
}
@media(max-width: 1200px) {
		.contact_wrap {
				padding: 60px 80px;
		}
		.contact_wrap_left {
				margin-right: 80px;
		}
}
@media(max-width: 960px) {
		.contact_section {
				padding: 0 30px;
		}
		.contact_wrap {
				padding: 50px 35px;
		}
		.contact_wrap_left {
				margin-right: 40px;
		}
}
@media(max-width: 767px) {
		.contact_section {
				padding: 0;
		}
		.contact_wrap {
				background: #f3f1f1 url(../images/check_bg_sp.png?2602);
				display: block;
				padding: 35px;
		}
		.contact_wrap_left {
				margin: 0
		}
		.contact_section .linkBtn {
				margin-left: auto;
				margin-right: auto;
		}
		.contact_wrap::after {
				bottom: -18px;
				left: 20px;
				width: 70px;
				height: 84px;
		}
}
/* ============= */
.insta_section {
		padding: 0px 0 130px 80px;
		position: relative;
}
.insta_section .insta_hd {
		position: absolute;
		top: -10px;
		left: 40px;
		transform: rotate(90deg);
		transform-origin: left center;
		font-size: 26px;
		font-family: "Montserrat", sans-serif;
		font-optical-sizing: auto;
		font-style: normal;
		font-weight: 900;
		color: #C3392D;
		letter-spacing: 0.07em;
		margin: 0
}
.insta_tile_gr {
		display: grid;
		grid-template-columns: repeat(6, 1fr);
		grid-template-rows: repeat(2, 1fr);
		gap: 0px;
		width: 100%;
}
.insta_tile {
		overflow: hidden;
		aspect-ratio: 1 / 1;
}
.insta_tile img {
		width: 100%;
		height: 100%;
		object-fit: cover
}
.insta_tile img {
		width: 100%;
		height: 100%;
		object-fit: cover;
}
.insta_tile:first-child {
		grid-row: span 2;
		grid-column: span 2;
}
@media(max-width: 960px) {
		.insta_section {
				padding: 0px 0 80px 60px;
		}
		.insta_section .insta_hd {
				font-size: 20px;
		}
}
@media(max-width: 767px) {
		.insta_section {
				padding: 0px 0 80px;
		}
		.insta_section .insta_hd {
				position: static;
				transform: rotate(0deg);
				font-size: 30px;
				margin: 0 0 25px;
				text-align: center;
		}
		.insta_tile_gr {
				display: grid;
				grid-template-columns: repeat(4, 1fr);
				grid-template-rows: repeat(2, 1fr);
				gap: 0px;
				width: 100%;
		}
}
/* =============== */
.en span {
		display: inline-block;
		transform-origin: center bottom;
		opacity: 0;
		transform: rotateX(90deg) scaleY(0);
		transition: transform 0.21s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.1s;
}
hgroup .jp {
		transition: opacity 0.3s;
		transition-delay: 0.2s;
		opacity: 0;
}
hgroup .jp.isActive {
		opacity: 1;
}
.en span:nth-child(2) {
		transition-delay: 0.05s;
}
.en span:nth-child(3) {
		transition-delay: 0.1s;
}
.en span:nth-child(4) {
		transition-delay: 0.15s;
}
.en span:nth-child(5) {
		transition-delay: 0.2s;
}
.en span:nth-child(6) {
		transition-delay: 0.25s;
}
.en span:nth-child(7) {
		transition-delay: 0.3s;
}
.en span:nth-child(8) {
		transition-delay: 0.35s;
}
.en span:nth-child(9) {
		transition-delay: 0.4s;
}
.en span:nth-child(10) {
		transition-delay: 0.45s;
}
.en.isActive span {
		opacity: 1;
		transform: rotateX(0deg) scaleY(1);
}
/* ============= */
.philosophy_right::after, .service_col::after, .works_left::after, .recruit_caption::after, .contact_wrap::after {
		transition: transform 0.9s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.5s;
		transform: translateY(10px);
		transition-delay: 0.5s;
		opacity: 0;
}
.pageSectionActive .philosophy_right::after, .pageSectionActive .service_col::after, .pageSectionActive .works_left::after, .pageSectionActive .recruit_caption::after, .pageSectionActive .contact_wrap::after {
		transform: translateY(0px);
		opacity: 1;
}