@charset "utf-8";


.fvZoom {
  position: relative;
  height: 230vh;
  background: #f5f4ef;
}

.fvZoom__sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  background: #f5f4ef;
}

.fv {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.fvImg,
.fvMainImg {
  position: absolute;
  display: block;
  object-fit: cover;
}

.fvImg01 {
  top: 120px;
  left: 150px;
  width: 210px;
}

.fvImg02 {
  top: 180px;
  left: 590px;
  width: 210px;
}

.fvMainImg {
  left: 36px;
  bottom: 180px;
  width: 440px;
  height: 280px;
  border-radius: 4px;
}

.fvCopy {
  position: absolute;
  top: 150px;
  right: 180px;
  writing-mode: vertical-rl;
  font-size: 28px;
  line-height: 2;
  letter-spacing: 0.18em;
  z-index: 5;
}

.fvLead {
  position: absolute;
  right: 210px;
  bottom: 220px;
  font-size: 13px;
  color: #aaa;
  text-align: center;
  z-index: 5;
}

/* 拡大する背景 */
.zoomBg {
  position: absolute;
  z-index: 3;
  overflow: hidden;
  border-radius: 4px;
  pointer-events: none;
  opacity: 0;
}

.zoomBg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.zoomBg__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.48);
  opacity: 0;
}

.zoomContent {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 160px;
  color: #fff;
  opacity: 0;
  pointer-events: none;
}

.zoomContent h2 {
  writing-mode: vertical-rl;
  font-size: 28px;
  line-height: 2;
  letter-spacing: 0.18em;
}

.zoomContent p {
  width: 420px;
  font-size: 14px;
  line-height: 2;
}

.topics {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  background: #f5f4ef;
  padding: 120px 40px;
}

/* ---------------------------------------
* common
------------------------------------------ */

.btn.sp,.sp{
	display: none;
}

svg{
	width: 100%;
	height: 100%;
}

:root {
	--primary: #FF7184;
	--primary02: #242A2F;
	--bg-b: #403F3E;
	--font-w: #FFFCFA;
	--font-g:#B3AFAB;
	--border:#E6E6E6;
	--border-w40: rgba(255,252,250,.4);
	--border-w20: rgba(255,252,250,.2);
}

.tac{
	text-align: center;
}

.barTop,.barBottom{
	position: absolute;
	left: 0;
}

.barTop{
	top: 0;
}

.barBottom{
	bottom: -.5px;
}

.bg-g{
	background-color: var(--bg-g);
}

.bg-b{
	background-color: var(--primary02);
}

/* ---------------------------------------
* TOP
------------------------------------------ */

.mv{
	padding-top: 14rem;
}

.mvWrap{
	padding-right: 11.7rem;
}

.mvTtl{
	margin-left: auto;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

.mvTtl p{
	font-size: clamp(18px,2.4rem,28px);
	letter-spacing: 0.1em;
	line-height: 120%;
	font-weight: 500;
}

.mvTtl p:last-of-type{
	padding-right: 0.8rem;
}

.mvTxt>p{
	font-size: clamp(10px,1.4rem,16px);
	line-height: 120%;
	color: #B3AFAB;
	text-align: right;
	padding-top: 20rem;
}

.service-l{
	width: 31.8%;
	height: auto;
}

.serviceTtl{
	position: sticky;
	left: 0;
	top: 6rem;
}

.service-r{
	width: 57.3%;
}

.service-listItem{
	padding: 6rem 4rem 4rem;
	border-radius: 5px;
	background-color: #E67F1F;
}

.service-listItem:nth-of-type(2){
	background-color: #4FA162;
}

.service-listItem:last-of-type{
	background-color: #CD3D3D;
}

.service-listItem:not(:last-of-type){
	margin-bottom: 3rem;
}

.service-listTtl{
	align-items: flex-end;
	padding-bottom: 2.4rem;
	margin-bottom: 6rem;
	border-bottom: solid 1px var(--border-w40);
}

.service-listTtl h4{
	font-size: clamp(24px,3.6rem,44px);
	line-height: 1;
	letter-spacing: normal;
	font-weight: 500;
}

.service-listTtl p{
	font-size: clamp(12px,1.4rem,16px);
	line-height: 1.6;
	letter-spacing: normal;
	font-weight: 500;
}

.service-listContent{
	align-items: flex-end;
}

.service-listImg{
	width: 50.5%;
}

.service-listTxt{
	width: 40.02%;
}

.service-listTxt>p{
	font-size: clamp(12px,1.4rem,16px);
	letter-spacing: 0.02em;
	line-height: 1.6;
	padding-bottom: 2.4rem;
}

.section-recruit{
	margin-top: 18rem;
}

.recruitWrap{
	padding: 14rem 0;
	position: relative;
}

.recruitImgWrap{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.recruitImg{
	position: absolute;
}

.recruitImg01,.recruitImg04{
	width: 16.9%;
}

.recruitImg02,.recruitImg03{
	width: 14.8%;
}

.recruitImg01{
	left: 3rem;
	top: 2rem;
}

.recruitImg02{
	right: 11.7rem;
	top: 0;
}

.recruitImg03{
	left: 11.7rem;
	bottom: 0;
}

.recruitImg04{
	right: 3rem;
	bottom: 2rem;
}

.recruitTxt>p{
	padding-top: 3.2rem;
}

/* ---------------------------------------
* About
------------------------------------------ */

.missionCont{
	width: 31.8%;
	margin: 0 auto;
}

.missionWrap{
	position: relative;
	padding: 6rem 0 7.2rem;
}

.missionImgWrap{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.missionImg{
	position: absolute;
}

.missionImg01{
	width: 20.2%;
	left: 3rem;
	top: 0;
}

.missionImg02{
	width: 30.4%;
	right: 0;
	bottom: 0;
}

.missionTxt{
	padding-top: 4.8rem;
}

.missionTxt p{
	line-height: 1.8;
}

.missionTxt p:not(:last-of-type){
	padding-bottom: 2.3rem;
}

.aboutBannerWrap{
	position: relative;
	background-repeat: no-repeat;
	background-size: cover;
	background-image: url(../img/about/about.png);
	border-radius: 5px;
}

.aboutBannerWrap::before{
	content: "";
	display: block;
	padding-top: 47.8%;
}

.aboutBannerCont{
	position: absolute;
	left: 0;
	bottom: 4.8rem;
	width: 100%;
	padding: 0 8rem;
	align-items: flex-end;
}

.aboutBannerCont h3{
	line-height: 1.2;
	letter-spacing: normal;
	font-size: clamp(24px,3.2rem,40px);
	font-weight: 500;
}

.aboutBannerCont p{
	line-height: 1.4;
	letter-spacing: normal;
	font-weight: 500;
	font-size: clamp(16px,2.4rem,24px);
}

.memberWrap{
	width: 74.3%;
	margin-left: auto;
}

.member-list{
	column-gap: 3rem;
	row-gap: 4.8rem;
}

.member-listItem{
	width: calc((100% - (3rem * 2)) / 3);
}

.member-listTtx{
	padding-top: 1.6rem;
}

.member-listTtx .position{
	font-size: clamp(10px,1.2rem,14px);
	color: var(--font-g);
	line-height: 1.4;
	letter-spacing: normal;
	padding-bottom: 0.4rem;
}

.member-listTtx .name{
	font-size: clamp(10px,1.6rem,18px);
	line-height: 1.4;
	letter-spacing: normal;
	font-weight: 500;
}

.outlineCont{
	width: 74.4%;
	margin-left: auto;
}

.outline-defList{
	padding-bottom: 2.4rem;
	margin-bottom: 2.4rem;
	border-bottom: solid 1px var(--border);
}

.outline-defTtl,.outline-defDesc{
	font-size: clamp(10px,1.4rem,16px);
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: normal;
}

.outline-defTtl{
	flex: 0 0 22.8%;
	width: 22.8%;
}

.outline-defDesc{
	flex: 1 1 auto;
}

/* ---------------------------------------
* Recruit
------------------------------------------ */

.messWrap{
	position: relative;
	padding-bottom: 6rem;
	align-items: flex-start;
}

.messPhoto{
	position: absolute;
	left: 0;
	top: 0;
	width: 51.09%;
	height: 100%;
	z-index: -1;
}

.messImg{
	position: absolute;
}

.messImg01{
	width: 40.17%;
	left: 0;
	top: 15rem;
}

.messImg02{
	width: 39.8%;
	right: 0;
	bottom: 0;
}

.mess-r{
	padding-top: 4rem;
	width: 38.45%;
}

.messTxt p:not(:last-of-type){
	padding-bottom: 3.2rem;
}

.value-l{
	height: auto;
}

.value-l .ttlWrap{
	position: sticky;
	left: 0;
	top: 4rem;
}

.value-r{
	width: 57.3%;
}

.value-listItem{
	padding: 4rem 3rem 3rem 4rem;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	background-image: url(../img/recruit/val01.png);
}

.value-listItem:nth-of-type(2){
	background-image: url(../img/recruit/val02.png);
}

.value-listItem:last-of-type{
	background-image: url(../img/recruit/val03.png);
}

.value-listItem:not(:last-of-type){
	margin-bottom: 2rem;
}

.value-listTtl p{
	opacity: .8;
	font-size: clamp(12px,1.4rem,16px);
	font-weight: 500;
	line-height: 1.2;
	padding-bottom: 0.4em;
}

.value-listItem h3{
	font-size: clamp(20px,2.8rem,32px);
	font-weight: 500;
	line-height: 1.2;
}

.value-listItem>p{
	padding-top: 24rem;
	text-align: right;
	font-size: clamp(12px,2rem,24px);
	font-weight: 500;
}

.job-l>p{
	font-size: clamp(12px,2rem,24px);
	font-weight: 500;
	padding-top: 4rem;
}

.job-r{
	width: 57.3%;
}

.job-listItem{
	border-radius: 5px;
	cursor: pointer;
	position: relative;
	padding: 2.4rem 3rem 2.4rem 4rem;
	background-color: var(--bg-b);
}

.job-listItem:not(:last-of-type){
	margin-bottom: 2rem;
}

.jobIcon{
	width: 1.6rem;
	height: 1.6rem;
	position: absolute;
	right: 2.4rem;
	top: 50%;
	transform: translateY(-50%);
}

.jobIcon svg{
	position: absolute;
	left: 0;
	top: 0;
}

.jobPop{
    visibility: hidden;
    pointer-events: none;
    position: fixed;
    width: 100%;
    height: 100%;
    overflow: scroll;
    left: 0;
    top: 0;
    z-index: 4000;
}

.jobPop.is-open{
    visibility: visible;
    pointer-events: auto;
}

.jobPopBg{
	position: fixed;
    opacity: 0;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background-color: rgba(64, 63, 63, .8);
    transition: all .4s;
    z-index: 3100;
	cursor: pointer;
}

.jobPop.is-open .jobPopBg{
    animation: jobPopBg .3s forwards;
}

@keyframes jobPopBg {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.jobDetail{
	background-color: #E8E5E1;
    width: 65.2%;
	overflow: scroll;
	padding: 8rem 6rem;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 3500;
	transition: transform .6s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
    transform: translate(120%);
}

.jobPop.is-open .jobDetail{
	transition: transform .6s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
    transform: translate(0);
}

.jobPop.is-closing .jobDetail{
	transition: transform .6s cubic-bezier(0.22, 1, 0.36, 1);
	will-change: transform;
    transform: translate(120%);
}

.jobDetail h3{
	font-size: clamp(16px,2rem,24px);
	font-weight: 500;
	padding-bottom: 3rem;
}

.jobDetail-defList{
	padding-bottom: 2.4rem;
	margin-bottom: 2.4rem;
	border-bottom: solid 1px rgba(179,175,171,.4);
}

.jobDetail-defList:first-of-type{
	border-top: solid 1px rgba(179,175,171,.4);
	padding-top: 2.4rem;
}

.jobDetail-defList:last-of-type{
	padding-bottom: 0;
	border-bottom: unset;
}

.jobDetail-defTtl{
	flex: 0 0 20.12%;
	width: 20.12%;
	font-weight: 500;
	font-size: clamp(10px,1.4rem,14px);
}

.jobDetail-defDesc{
	flex: 1 1 auto;
	font-size: clamp(10px,1.4rem,14px);
}

.closeBtn{
	cursor: pointer;
	position: fixed;
	top: 3rem;
	right: 3rem;
}

.closeBtnIcon{
	width: 1.6rem;
	height: 1.6rem;
	position: relative;
	margin-left: .8rem;
}

.closeBtnIcon svg{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

@media screen and (max-width:768px) {

	/* ---------------------------------------
	* common
	------------------------------------------ */

	.btn.sp{
		display: block;
	}

	.sp{
		display: block;
	}

	.pc{
		display: none;
	}

	.bg-b{
		background-repeat: repeat-y;
		background-size: 100% auto;
	}

/* ---------------------------------------
* TOP
------------------------------------------ */

.mv{
	padding-top: 12rem;
}

.mvWrap{
	padding-right: 0;
}

.mvTtl{
	margin-left: auto;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

.mvTtl p{
	font-size: 2rem;
}

.mvTtl p:last-of-type{
	padding-right: 0.8rem;
}

.mvTxt>p{
	font-size: 1.2rem;
	padding-top: 16rem;
}

.service-l{
	width: 100%;
}

.serviceTtl{
	position: unset;
}

.service-r{
	width: 100%;
	padding-top: 4rem;
}

.service-listItem{
	padding: 4rem 2rem 3rem;
}

.service-listItem:not(:last-of-type){
	margin-bottom: 2.4rem;
}

.service-listTtl{
	padding-bottom: 1.6rem;
	margin-bottom: 4.8rem;
}

.service-listTtl h4{
	font-size: 2.4rem;
}

.service-listTtl p{
	font-size: 1.2rem;
}

.service-listContent{
	align-items: flex-end;
}

.service-listImg{
	width: 100%;
}

.service-listTxt{
	width: 100%;
	padding-top: 2.4rem;
}

.service-listTxt>p{
	font-size: 1.4rem;
	padding-bottom: 2.4rem;
}

.service-listTxt .btn{
	margin:  0 auto;
}

.section-recruit{
	margin-top: 12rem;
}

.recruitWrap{
	padding: 14rem 0;
}

.recruitImgWrap{
	z-index: -1;
}

.recruitImg01,.recruitImg04{
	width: 45%;
}

.recruitImg02,.recruitImg03{
	width: 30%;
}

.recruitImg01{
	left: -2rem;
	top: 0rem;
}

.recruitImg02{
	right: -2rem;
	top: -2rem;
}

.recruitImg03{
	left: -2rem;
	bottom: -2rem;
}

.recruitImg04{
	right: -2rem;
	bottom: 0;
}

.recruitTxt>p{
	padding-top: 2.4rem;
}

/* ---------------------------------------
* About
------------------------------------------ */

.missionCont{
	width: 100%;
	margin: 0 auto;
	padding-top: 4rem;
}

.missionWrap{
	position: relative;
	padding: 0 ;
}

.missionImgWrap{
	display: flex;
	position: unset;
	width: 100%;
	height: auto;
	justify-content: space-between;
	align-items: flex-end;
}

.missionImg{
	position: unset;
}

.missionImg01{
	width: 45%;
}

.missionImg02{
	width: 40%;
}

.missionTxt{
	padding-top: 3.2rem;
}

.missionTxt p:not(:last-of-type){
	padding-bottom: 1.6rem;
}

.section-aboutBanner{
	padding-top: 8rem;
}

.aboutBannerWrap{
	background-position: center;
	border-radius: 5px;
}

.aboutBannerWrap::before{
	padding-top: 95%;
}

.aboutBannerCont{
	position: absolute;
	left: 0;
	bottom: 2.4rem;
	width: 100%;
	padding: 0 2rem;
	align-items: flex-end;
}

.aboutBannerCont h3{
	font-size: 2.4rem;
}

.aboutBannerCont p{
	padding-top: 0.8rem;
	font-size: 1.4rem;
}

.memberWrap{
	width: 100%;
	margin-left: auto;
}

.member-list{
	column-gap: 1rem;
	row-gap: 2.4rem;
}

.member-listItem{
	width: calc((100% - (1rem * 1)) / 2);
}

.member-listTtx .position{
	font-size: 1.2rem;
}

.member-listTtx .name{
	font-size: 1.6rem;
}

.outlineCont{
	padding-top: 4rem;
	width: 100%;
}

.outline-defList{
	padding-bottom: 2rem;
	margin-bottom: 2rem;
}

.outline-defTtl,.outline-defDesc{
	font-size: 1.4rem;
}

.outline-defTtl{
	width: 100%;
	color: #B3AFAB;
}

.outline-defDesc{
	padding-top: 0.8rem;
}

/* ---------------------------------------
* Recruit
------------------------------------------ */

.messWrap{
	padding-bottom: 6rem;
}

.messPhoto{
	padding-top: 3rem;
	display: flex;
	justify-content: space-between;
	position: unset;
	width: 100%;
	height: auto;
}

.messImg{
	position: unset;
}

.messImg01{
	padding-top: 2.4rem;
	width: 45%;
}

.messImg02{
	width: 35%;
}

.mess-r{
	/* display: flex;
	flex-direction: column-reverse; */
	padding-top: 0;
	width: 100%;
}

.messmainImg{
	padding-top: 3.2rem;
	width: 45%;
	margin: 0 auto;
}

.messTxt p:not(:last-of-type){
	padding-bottom: 3.2rem;
}


.value-l .ttlWrap{
	position: unset;
}

.value-r{
	width: 100%;
	padding-top: 4rem;
}

.value-listItem{
	padding: 3rem 2rem 2rem 2rem;
}

.value-listItem:not(:last-of-type){
	margin-bottom: 2rem;
}

.value-listTtl p{
	font-size: 1.2rem;
}

.value-listItem h3{
	font-size: 2.4rem;
}

.value-listItem>p{
	padding-top: 12rem;
	font-size: 1.8rem;
}

.job-l>p{
	font-size: 1.6rem;
	padding-top: 3.2rem;
}

.job-r{
	width: 100%;
	padding-top: 3rem;
}

.job-listItem{
	border-radius: 5px;
	cursor: pointer;
	position: relative;
	padding: 2rem 2rem 2rem 2.4rem;
	background-color: var(--bg-b);
}

.job-listItem:not(:last-of-type){
	margin-bottom: 1rem;
}

.jobIcon{
	width: 1.2rem;
	height: 1.2rem;
	right: 2rem;
}


.jobDetail{
    width:100%;
	padding: 6rem 2rem;
    height: 100%;
}

.jobDetail h3{
	font-size: 1.8rem;
	padding-bottom: 3rem;
}

.jobDetail-defList{
	padding-bottom: 2.4rem;
	margin-bottom: 2.4rem;
}

.jobDetail-defList:first-of-type{
	padding-top: 2.4rem;
}

.jobDetail-defList:last-of-type{
	padding-bottom: 0;
	border-bottom: unset;
}

.jobDetail-defTtl{
	width: 100%;
	font-size: 1.4rem;
}

.jobDetail-defDesc{
	font-size: 1.4rem;
	padding-top: 0.8rem;
}

}

