/*-------------------- 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;
	}
}