/*-------------------- mobile --------------------*/
@media screen and (max-width: 768px) {
	
	
	
	body:not(.home,[class*="staff"]) .pagewidth {
		width: 100%;
		max-width: 100%;
	}
	
	body.home header{
		position:relative;
	}
	#header{
		background:var(--c-white);
	}
	#header.is-top::after{
		position:absolute;
		width: 13.333%;
		right: 0;
		background: var(--c_base);
		content: '';
		top: 0;
		bottom: 0;
	}
	#header .lb{
		padding:8px 0;
	}
	body.home #header .lb{
		padding-bottom: 33px;
	}
	#header_logo,
	.header_btn{
		max-width:90px;
	}
	.header_txt{
		font-size:8px;
		padding:10px 0 7px;
	}
	.header_txt p:first-child{
		margin-bottom:4px;
	}
	.header_txt p:last-child{
		font-size:17px;
	}
	.footer_info{
		flex-direction:column;
		text-align:center;
		padding:50px 0 45px;
	}
	section.staff_greeting{
		padding-bottom:80px;
	}
	section.staff_greeting .section_inner{
		flex-direction:column-reverse;
	}
	section.staff_greeting .column{
		width:100%;
		padding:32px 0 0 8%;
	}
	section.staff_greeting .column:first-child{
		padding:20px 8% 0px;
	}
	section.staff_greeting .column:first-child article{
		max-width:none;
	}
	section.staff_greeting .column:first-child article:first-child p{
		font-size:24px;
		line-height:38.4px;
	}
	section.staff_greeting .column:first-child article:last-child > *{
		max-width:none;
	}
	section.staff_greeting .column:first-child article:last-child h1{
		font-size:23px;
		padding:28px 0 17px;
	}
	section.staff_greeting .column:first-child article:last-child h1 span{
		margin-bottom:7px;
	}
	section.staff_greeting .column:first-child article:last-child p{
		font-size:12px;
		line-height:20.4px;
		letter-spacing:0.24px;
	}
	section.staff_greeting .column:last-child:before,
	section.staff_s article,
	section.banner_entry .section_inner,
	section.top_main article:not(.top_main_txt) img:last-child{
		display:block;
	}
	section.staff_greeting .column:first-child article:first-child:before,
	section.banner_entry:before,
	section.banner_entry:after,
	section.top_main article:not(.top_main_txt) img:first-child{
		display:none;
	}
	section.staff_greeting .column:last-child article{
		min-height:auto;
	}
	section.staff_greeting .column:last-child:before{
		font-size:16px;
		padding-bottom:14px;
		margin-bottom:20px;
	}
	section.staff h2{
		font-size:22px;
		line-height:33px;
		padding-bottom:23px;
	}
	section.staff h2 div:first-child{
		font-size:16px;
	}
	section.staff h2 div:first-child:before{
		background-position:right 15px top 10px;
	}
	section.staff .caption{
		padding-bottom:55px;
	}
	section.staff .image-wrap{
		padding-top:100%;
		margin-bottom:55px;
	}
	section.staff .image-wrap img{
		transform:translate(-50%,-50%);
		width:100%;height:100%;
		object-fit:cover;
		object-position:center;
	}
	section.staff .image-wrap.scale img{
		transform:translate(-50%,-50%) scale(1.6);
	}
	section.staff_s{
		padding-bottom:55px;
	}
	section.staff_s .image-wrap{
		width:100%;
		max-width:200px;
		margin-left:auto;
		margin-right:auto;
	}
	section.staff_s h2{
		text-align:center;
	}
	section.banner_entry{
		padding:0;
	}
	section.banner_entry .section_inner{
		width:100%;
		max-width:100%;
	}
	section.banner_entry article:first-child{
		font-size:14px;
		line-height:23.8px;
		letter-spacing:0.56px;
		background:url(../../uploads/banner_entry_bg.webp)right top no-repeat;
		background-size:cover;
		padding:120px 12.226% 100px;
	}
	section.banner_entry article:first-child h2{
		font-size:24px;
		line-height:38.4px;
		letter-spacing:0.96px;
		margin-bottom:15px;
	}
	section.banner_entry article:first-child p:not(:last-child) {
		margin-bottom: 1em;
	}
	section.banner_entry article:last-child{
		padding:0 8% 40px;
		margin-top:0;
	}
	section.banner_entry article:last-child h2{
		font-size:min(13.333vw,98px);
		margin-top:-0.48em;
		margin-bottom: calc(-0.133em + 20px);
	}
	section.banner_entry article:last-child a{
		font-size:16px;
		letter-spacing:0.64px;
		max-width:280px;
		padding:28px 60px 27px;
		margin:0 auto;
	}
	section.banner_entry article:last-child a:before{
		right:17px;
		width:27px;
	}
	section.top_people{
		padding:120px 0 60px;
	}
	section.top_people section,
	section.banner_staff section{
		display:block;
		width:100%;
		padding:0 8% 15px;
	}
	section.banner_staff section{
		padding-bottom:25px;
	}
	section.top_people section:before, 
	section.banner_staff section:before{
		top:min(13.333vw,60px);
		left:0;right:29.333vw;
	}
	section.top_people section .column,
	section.banner_staff section .column{
		max-width:374px;
		margin:0 auto 15px;
	}
	section.top_people section article:after, 
	section.banner_staff section article:after{
		transform:translate(35.7143%,17.143%);
	}
	.tit_fc h2 > div:first-child span{
		display:block;
	}
	#content .tit_fc h2 > div:first-child span:first-child{
		padding:0;
	}
	section.banner_staff .tit_fc h2 > div:first-child span:first-child{
		font-size:28px;
		letter-spacing:-1.12px;
	}
	#content .tit_fc h2 > div:first-child span:last-child{
		padding:10px 0 12px;
	}
	section.top_message .tit_fc h2 > div:first-child span:last-child,
	section.top_about .tit_fc h2 > div:first-child span:last-child{
		font-size:14px;
		letter-spacing:0.56px;
	}
	section.banner_staff .tit_fc h2 > div:first-child span:last-child{
		font-size:17px;
		letter-spacing:0.68px;
	}
	#content .tit_fc h2 > div:last-child{
		font-size:36px;
		line-height:61.2px;
		padding:0;
		margin-bottom:0;
	}
	section.top_people .tit_fc{
		margin-bottom:25px;
	}
	section.top_people:before, 
	section.banner_staff:before{
		width:55.467%;
		max-width:208px;
	}
	section.top_people:before{
		top:40px;
		right:6.667%;
		transform:none;
	}
	section.banner_staff:before{
		top:64px;bottom:0;
		left:auto;right:-4vw;
		background-position:right top;
	}
	section.banner_staff{
		padding-top:75px;
		padding-bottom:60px;
	}
	section.banner_staff .section_inner{
		display:block;
		padding:0;
	}
	#content section.banner_staff .section_inner > .column{
		width:100%;
		max-width:none;
	}
	section.banner_staff .section_inner > .column:first-child{
		padding:0 8%;
	}
	section.banner_staff .section_inner > .column:first-child .tit_fc{
		margin-bottom:20px;
	}
	section.banner_staff .section_inner > .column:first-child article:not(.tit_fc) h2{
		font-size:22px;
		padding-bottom:30px;
		margin-bottom:25px;
	}
	section.top_people section article .image-content p, 
	section.banner_staff section article .image-content p{
		font-size:13px;
	}
	section.top_main{
		background:var(--c-white);
	}
	section.top_main .section_inner{
		padding:41.333% 0 45.6%;
	}
	section.top_main:before{
		width:13.333%;
	}
	section.top_main:after{
		width:100%;
		padding-top:21.133%;
	}
	section.top_main .top_main_txt{
		font-size:13.6vw;
		padding:calc(9.333vw - 0.157em) 3.5%;
	}
	section.top_main .top_main_txt p{
		letter-spacing:-0.816vw;
	}
	section.top_main .top_main_txt span{
		font-size:max(3.2vw,12px);
		line-height:max(5.44vw,20.4px);
		letter-spacing:0;
		text-align:center;
		padding:0 9.833vw;
		margin:-0.266vw 0 -0.8vw;
	}
	section.top_main article:not(.top_main_txt){
		overflow:clip;
	}
	section.top_main .top_main01{
		left:auto;right:0;
		max-width:89.333%;
		border-radius:8vw 0 0 8vw;
		padding-top:0;
	}
	section.top_main .top_main02{
		top:auto;bottom:5.333vw;
		left:0;right:auto;
		max-width:46.667%;
		border-radius:0 8vw 8vw 0;
	}
	section.top_main .top_main03{
		max-width:46.667%;
		border-radius:8vw 0 0;
	}
	section.top_message{
		padding-top:100px;
		padding-bottom:min(66.4vw,250px);
		background-position: left top;
	}
	section.top_message:before{
		top:0;bottom:max(-3vw,-11px);
		width:min(78.667%,295px);
		background-position:right bottom;
	}
	section.top_message .tit_fc{
		margin-bottom:30px;
	}
	.top_message article p{
		font-size:16px;
		line-height:36.8px;
		letter-spacing:0.64px;
	}
	.top_message article p:not(:last-child){
		margin-bottom:2.25em;
	}
	section.top_about .top_about_img img:last-child,
	section.top_about .top_about01 .top_about_num + article{
		display:block;
	}
	section.top_about .top_about_img img:first-child{
		display:none;
	}
	section.top_about{
		padding-top:53.867%;
		padding-bottom:55px;
	}
	section.top_about:before{
		z-index:1;
		width:21.333vw;height:9.6vw;
	}
	section.top_about .top_about_img{
		width:95.2%;
		max-width:none;
	}
	section.top_about .top_about01{
		width:100%;
		padding-top:30px;
	}
	section.top_about .top_about01 .tit_fc{
		margin-bottom:30px;
	}
	section.top_about .top_about01 .top_about_num{
		margin-bottom:5px;
	}
	section.top_about .top_about01 p{
		font-size:14px;
		line-height:32.2px;
		letter-spacing:0.56px;
	}
	section.top_about .top_about02{
		display:block;
		padding-top:55px;
	}
	section.top_about .top_about02 .top_about_num p{
		font-size:21px;
		line-height:48.3px;
		letter-spacing:0.84px;
		padding-bottom:3px;
	}
	section.top_about .top_about02 ul li,
	section.top_about .top_about02 .column:last-child article:not(.top_about_num) p{
		font-size:14px;
		line-height:23.8px;
		letter-spacing:0.56px;
	}
	section.top_about .top_about02 ul li{
		min-height:51px;
		padding-top:1px;
	}
	section.top_about .top_about02 ul li br{
		display:none;
	}
	section.top_about .top_about02 .column:first-child .top_about_num{
		margin-bottom:25px;
	}
	section.top_about .top_about02 .column:first-child .top_about_num h2{
		margin-bottom:7px;
	}
	section.top_about .top_about02 .column:last-child article:not(.top_about_num){
		padding:5px 0 0 25px;
		margin-bottom:25px;
	}
	section.top_about .top_about02 .column:last-child article:not(.top_about_num) strong{
		font-size:18px;
		line-height:30.6px;
		letter-spacing:0.72px;
		margin-bottom:10px;
	}
	section.top_about .top_about02 .column:last-child article:not(.top_about_num) p{
		font-size:14px;
	}
	section.top_about .top_about_num h2{
		font-size:33px;
	}
	section.top_about .top_about_num h2:before{
		font-size:44px;
	}
	section.top_business{
		padding:0 0 65px;
	}
	section.top_business:before{
		top:calc(90.4vw + 37px);
		right:max(-2.933vw,-11px);
		width:min(36.267%,136px);
	}
	section.top_business .section_inner{
		display:block;
	}
	section.top_business .column:first-child{
		width:100%;
		max-width:none;
	}
	section.top_business .column:first-child article{
		margin-top:0;
		margin-bottom:45px;
	}
	section.top_business .column:first-child article .image-wrap img:first-child{
		display:none;
	}
	section.top_business .column:first-child article .image-wrap img:last-child{
		display:block;
	}
	section.top_business .column:last-child{
		width:84%;
		max-width:none;
	}
	#content section.top_business .column:last-child .tit_fc + article{
		padding-top:0;
		margin-top:-5px;
	}
	section.top_business .column:last-child article:not(.tit_fc){
		display:block;
		padding:32px 0 18px;
	}
	section.top_business .column:last-child .image-wrap{
		width:100%;
		max-width:120px;
		margin:0 auto;
	}
	section.top_business .column:last-child .image-content h2{
		font-size:22px;
		line-height:36.6px;
		letter-spacing:0.88px;
		text-align:center;
		margin-bottom:2px;
	}
	section.top_business .column:last-child .image-content h2:before{
		font-size:13px;
		margin-bottom:11px;
	}
	section.top_sp{
		padding-top:90px;
		padding-bottom:70px;
	}
	section.top_sp:before{
		top:22px;
		right:max(-4.8%,-18px);
		width:min(38.667%,145px);
	}
	section.top_sp section{
		display:block;
		padding:0;
	}
	section.top_sp .tit_fc{
		margin-bottom:30px;
	}
	section.top_sp section .column:first-child{
		width:100%;
		min-height:auto;
		padding:26px 20px 25px;
	}
	section.top_sp section .column:first-child:before{
		left:min(1.9%,6px);
		width:min(33.65%,106px);
		background-image:url(../../uploads/top_sp_check_s.webp);
	}
	section.top_sp section .column:first-child h2{
		font-size:20px;
		line-height:1.4;
	}
	section.top_sp section .column:last-child{
		padding:30px 20px;
	}
	section.top_sp section .column:last-child article:not(:last-child){
		margin-bottom:22px;
	}
	section.top_career{
		padding-bottom:100px;
		padding-bottom:85px;
	}
	section.top_career:before{
		top:54px;
		right:max(-1.8867%,-7px);
		width:min(43.2%,162px);
	}
	section.top_career:after{
		width:55.733%;height:min(3.733vw,14px);
	}
	section.top_career .section_inner{
		width:100%;
		max-width:none;
		padding-left:8%;
	}
	section.top_career .section_inner > *:not(.bp){
		padding-right:8vw;
	}
	section.top_career .tit_fc{
		margin-bottom:27px;
	}
	section.top_career .bp{
		padding:0 6.667vw;
	}
	section.top_career .bp > article:first-child{
		padding-top:23px;
		padding-bottom:32px;
	}
	section.top_career .bp > article:first-child h2{
		font-size:22px;
		line-height:37.4px;
		letter-spacing:0.88px;
		margin-bottom:10px;
	}
	section.top_career .bp > article:first-child p,
	#content section.top_career .bp > article:last-child p{
		font-size:14px;
		line-height:23.8px;
		letter-spacing:0.56px;
	}
	section.top_career .bp > article:last-child:not(:first-child){
		padding:31px min(8vw,30px) 28px;
		margin-bottom:35px;
	}
	section.top_career section.top_step_txt{
		display:block;
	}
	section.top_step_txt{
		counter-reset:top_step_txt;
		padding:20px 0 5px;
	}
	section.top_step_txt:before{
		content:'';
		display:block;
	}
	section.top_step_txt article{
		display:flex;
		padding:0;
		margin-bottom:15px;
	}
	section.top_step_txt article h2{
		display:flex;
		align-content:center;
		align-items:center;
		justify-content:center;
		flex-wrap:wrap;
		font-size:8px;
		line-height:1;
		text-align:center;
		width:60px;
		background:#E6E6E6;
		padding:1px 0 0;
		margin-right:15px;
	}
	section.top_step_txt article h2:after{
		counter-increment:top_step_txt;
		content:counter(top_step_txt);
		font-size:13px;
		display:inline-block;
		vertical-align:bottom;
		padding-left:4px;
	}
	section.top_step_txt article .caption{
		flex:1;
		align-self:center;
		padding:1px 0 0;
	}
	section.top_step_txt article p{
		font-size:12px;
		line-height:20.4px;
		letter-spacing:0.08px;
	}
	section.top_career section{
		column-gap:2px;
	}
	section.top_step .column{
		min-height:120px;
	}
	section.top_step .column article{
		padding-top:25px;
	}
	section.top_step .column:first-child article{
		padding-top:50px;
	}
	section.top_step .column h2{
		flex-direction:column;
		justify-content:flex-start;
		font-size:15px;
		letter-spacing:0.6px;
		border-radius:8px 8px 0 0;
	}
	section.top_step .column h2 div:first-child{
		position:static;
		transform:none;
		font-size:10px;
		width:100%;
		border-radius:8px 8px 0 0;
		padding:5px 0 8px;
	}
	section.top_step .column h2 div:first-child:after{
		font-size:16px;
		margin-bottom:-2px;
	}
	section.top_step .column h2 div:last-child{
		flex:1;
		display:flex;
		align-content:center;
		align-items:center;
		justify-content:center;
		flex-wrap:wrap;
	}
	section.top_step .column:last-child h2 div:last-child span:first-child{
		font-size:17px;
		margin-top:-0px;
	}
	section.top_step .column h2 div:last-child span:last-child{
		font-size:11px;
		letter-spacing:0.44px;
		width:100%;
		padding:2px 0 0;
	}
	#content section.top_step h2:before{
		left:0;right:0;
		width:auto;height:55px;
		background-position:center top;
		background-size:auto 100%;
		padding:0;
	}
	section.top_step .column:first-child h2:before{
		height:52px;
	}
	section.top_step .column:last-child h2:before{
		height:62px;
	}
	br.pc{
		display:block;
	}
	br.sp{
		display:none;
	}
	
	
	
	/* Recruit */
	.title-page {
		 padding: 40px 50px 50px;
	}
	.title-page h1 {
		font-size: 24px;
		letter-spacing: 0.96px;
		text-align: center;
		margin: 0 0 24px;
	}
	.title-page h1 br {
		display: block;
	}
	.title-page h2 {
		font-size: 16px;
		letter-spacing: 0.64px;
		padding: 4px;
		max-width: 184px;
	}
	.grey-row  {
		padding-top: 45px;
	}
	.grey-row h3 {
    	font-size: 26px; 
	}
	.position-box {
		padding: 30px 10px 4px;
		margin-bottom: 0;
	}
	.position-box.mb0 {
		padding-bottom: 30px;
	}
	dl.dl-position dt {
		width: 100%;
		padding: 11px 20px;
        border: none;
	}
	dl.dl-position dd {
		width: 100%;
		padding: 18px 20px;
        border: none;
	}
	.btn-wrap {
		padding: 0 10px 10px;
	}
	.btn-wrap a {
		background-position: right 6px bottom 8px;
		font-size: 13px;
	}
	.btn-wrap a img {
		width: 90px;
		padding-right: 15px;
		margin-right: 15px;
	}
	
	.sec-process {
		padding: 30px 0 60px;
	}
	.sec-process .section_inner {
    	padding: 40px 10px 60px;
	}
	.process-box {
		flex-direction: column;
		gap: 27px;
		padding: 30px 20px;
	}
	.process-left {
		width: 100%;
		display: flex;
		gap: 17px;
		justify-content: center;
		align-items: center;
	}
	.process-left h3 {
		margin: 0;
	}
	.process-steps {
		flex-direction: column;
	}
	.step {
		font-size: 18px;
		padding: 15px;
		width: 100%;
		min-height: unset;
		text-align: center;
		writing-mode: inherit;
	}
	.arrow {
		width: 6px;
		transform: rotate(90deg);
	}
	ul.tab {
		margin: 0 0 45px;
		padding: 0 10px;
		flex-direction: column;
	}
	ul.tab li {
		padding: 0;
		margin: 0;
		border-right: none;
		border-bottom: 1px solid rgb(0 0 0 / 30%);
	}
	ul.tab li a {
		font-size: 16px;
		padding: 17px 10px;
	}
	ul.tab li.current a {
		background: white;
		border-bottom: 0;
		border-left: 6px solid var(--c-red);
	}
	
	.form-row {
		padding-top: 45px;
		padding-bottom: 50px;
	}
	.form-row .section_inner {
		padding: 0 15px;
	}
	.tab-contact {
		margin-bottom: 20px;
	}
	.tab-contact li {
		font-size: 14px;
		padding: 14px;
		letter-spacing: 0;
	}
	.wpcf7-form dl {
		flex-direction: column;
		gap: 20px;
		padding: 25px 20px;
		margin: 0;
	}
	.wpcf7-form dl dt {
		font-size: 16px;
		letter-spacing: 0.64px;
		width: 100%;
	}
	.wpcf7-form dl dt span {
		font-size: 12px;
	}
	.wpcf7-form dl dd {
		max-width: 100%;
		width: 100%;
	}
	.wpcf7-form input[type="text"], .wpcf7-form input[type="tel"], .wpcf7-form input[type="email"], .wpcf7-form textarea {
		font-size: 14px;
	}
	.wpcf7-form .wpcf7-radio label span {
		font-size: 14px;
		font-weight: 400;
		padding: 4px 12px;
	}
	.wpcf7-form dl dt p br {
		display: none;
	}
	input.wpcf7-submit {
		background-size: 18px;
		font-size: 16px;
		letter-spacing: 1.56px;
		padding: 24px 40px;
	}
	.policy-text {
		font-size: 14px;
		line-height: 160%;
		text-align: left;
		padding: 0 20px;
	}
	body[class*="thank"] .section_inner {
		padding: 0 15px;
	}
	.thank-message {
		padding: 70px 30px;
		margin-top: 0;
		margin-bottom: 50px; 
	}
	body .thank-message h3 {
		font-size: 24px;
		line-height: 160%;
	}
	.thank-message p {
		text-align: left;
	}
}




