*,
*:before,
*:after {
	box-sizing: border-box;
}

html {
	font-size: 18px;
	height: 100%;
	scroll-behavior: smooth;
}

body {
	color: #383838;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	line-height: 1.75;
}

img,
video,
object {
	border: none;
	display: block;
	height: auto;
	max-width: 100%;
}

a {
	text-decoration: none;
	transition: opacity 0.3s;
}

a:hover {
	opacity: 0.7;
}

.no-auto-link-style p a,
.no-auto-link-style td a {
	color: inherit !important;
	text-decoration: none !important;
}

.no-auto-link-style.outline__table-content,
.no-auto-link-style.footer__item-address {
	pointer-events: none !important;
}

/*===================================================================
# ヘッダー
===================================================================*/

.header {
	background-color: rgba(248, 250, 249, 0.8);
	height: 80px;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 100;
}

.header__inner {
	align-items: center;
	display: grid;
	grid-template-columns: 195px 1fr;
	height: 100%;
	padding-inline-start: 30px;
}

.header__logo-link {
	align-items: center;
	display: flex;
	justify-content: space-between;
}

.header__logo-img {
	height: 40px;
	width: 23.35px;
}

.header__logo-text {
	font-size: 20px;
}

.header__nav {
	align-items: center;
	display: flex;
	justify-content: end;
	-moz-column-gap: 35px;
	column-gap: 35px;
}

.header__list {
	display: flex;
	-moz-column-gap: 35px;
	column-gap: 35px;
}

.header__list li a {
	color: #383838;
}

.header__btn {
	align-items: center;
	background-color: #63a4c2;
	border: 1px solid transparent;
	color: #FFFFFF;
	display: flex;
	height: 80px;
	justify-content: center;
	transition: background-color 0.3s ease, color 0.3s ease, border 0.3s ease;
	width: 190px;
}

/*===================================================================
# フッター
===================================================================*/

.footer {
	background-color: #f8faf9;
	padding: 30px 35px 35px 78px;
}

.footer__items {
	display: flex;
	justify-content: space-between;
}

.footer__logo-link {
	align-items: center;
	display: flex;
	gap: 20px;
}

.footer__logo-img {
	height: 60px;
	width: 35px;
}

.footer__logo-text {
	font-size: 30px;
}

.footer__item-address {
	font-size: 16px;
	margin-block-start: 19px;
}

.footer__copyright {
	display: inline-block;
	font-size: 12px;
	margin-block-start: 23px;
}

.footer__nav {
	align-items: center;
	display: flex;
	margin-block-start: 18px;
}

.footer__list {
	display: flex;
}

.footer__list li {
	position: relative;
}

.footer__list li:not(:last-child)::after {
	background-color: #383838;
	content: "";
	height: 16px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
}

.footer__list li a {
	color: #383838;
	display: block;
	position: relative;
	text-align: center;
	width: 125px;
}

.footer__list li a span {
	display: inline-block;
	position: relative;
}

.footer__list li a span::after {
	background-color: rgba(102, 106, 102, 0.9);
	bottom: 3px;
	content: "";
	height: 1px;
	left: 50%;
	opacity: 1;
	position: absolute;
	transition: opacity 0.3s ease;
	translate: -50%;
	width: 100%;
}

.footer__list li a:not(:last-child) {
	border-right: 1px solid #383838;
}

.footer__btn {
	align-items: center;
	background-color: #63a4c2;
	border: 1px solid transparent;
	color: #FFFFFF;
	display: flex;
	height: 50px;
	justify-content: center;
	transition: background-color 0.3s ease, color 0.3s ease, border 0.3s ease;
	width: 160px;
}

/*===================================================================
# ドロワー
===================================================================*/

.drawer {
	background: #f8faf9;
	height: auto;
	margin-block-start: 80px;
	overflow-y: scroll;
	padding-block: 52px 60px;
	position: fixed;
	right: 0;
	top: 0;
	transition: translate 0.5s ease;
	translate: 101%;
	width: 100%;
	z-index: 101;
}

.drawer.js-show {
	translate: 0%;
}

.drawer__inner {
	margin-inline: auto;
	width: 300px;
}

.drawer__list {
	display: flex;
	flex-direction: column;
	margin-block-end: 72px;
	row-gap: 43px;
}

.drawer__list li a {
	align-items: center;
	color: #383838;
	display: flex;
	font-size: 20px;
	justify-content: space-between;
	position: relative;
}

.drawer__list li a::after {
	background-color: #666a66;
	bottom: -21.5px;
	content: "";
	height: 1px;
	left: 0;
	position: absolute;
	width: 100%;
}

.drawer__list li img {
	height: auto;
	width: 20px;
}

.drawer__btn {
	align-items: center;
	background: #63a4c2;
	border-radius: 30px;
	color: #FFFFFF;
	display: flex;
	font-size: 20px;
	height: 60px;
	justify-content: center;
	margin-inline: auto;
	width: 220px;
}

.drawer__icon {
	align-items: center;
	background-color: #63a4c2;
	display: none;
	flex-direction: column;
	gap: 9.5px;
	height: 80px;
	justify-content: center;
	position: fixed;
	right: 0;
	width: 80px;
	z-index: 102;
}

.drawer__icon--bar {
	background-color: #f8faf9;
	height: 2px;
	transition: all 0.5s ease;
	width: 30px;
}

/* メニューが開いている時 */

.drawer__icon.js-show .drawer__icon--bar:nth-of-type(1) {
	rotate: 45deg;
	translate: 0 6px;
}

.drawer__icon.js-show .drawer__icon--bar:nth-of-type(2) {
	display: none;
}

.drawer__icon.js-show .drawer__icon--bar:nth-of-type(3) {
	rotate: -45deg;
	translate: 0 -6px;
}

/*===================================================================
# インナー幅
===================================================================*/

.inner {
	margin-inline: auto;
	max-width: 1140px; /* インナー幅は1200px */
	padding-inline: 20px;
}

.inner--about { /* Top Abou用の余白 */
}

/*===================================================================
# セクション
===================================================================*/

.section__title {
	opacity: 0;
	text-align: center;
	transform: translateY(30px);
	transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.section__title.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.section__title--jp {
	display: inline-block;
	font-size: 28px;
	position: relative;
}

.section__title--jp::after {
	background-color: #63a4c2;
	bottom: -1px;
	content: "";
	height: 1px;
	left: 50%;
	position: absolute;
	translate: -50%;
	width: calc(100% + 20px);
}

.section__title--en {
	color: #63a4c2;
	display: block;
	font-size: 20px;
	margin-block-start: 3px;
}

.section__title--wh {
	color: #FFFFFF;
}

.section__title--fukidashi {
	align-items: center;
	background-color: #63a4c2;
	border-radius: 40px;
	color: #FFFFFF;
	display: flex;
	font-size: 35px;
	height: 80px;
	justify-content: center;
	margin-inline: auto;
	opacity: 0;
	position: relative;
	transform: translateY(30px);
	transition: opacity 0.8s ease-out, transform 0.8s ease-out;
	width: 750px;
}

.section__title--fukidashi.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.section__title--fukidashi::after {
	border-bottom: 0;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-style: solid;
	border-top: 20px solid #63a4c2;
	bottom: -20px;
	content: "";
	height: 0;
	left: 25%;
	position: absolute;
	width: 0;
}

.section__fukidashi {
	align-items: center;
	background-color: #63a4c2;
	border-radius: 20px;
	color: #FFFFFF;
	display: flex;
	font-size: 22px;
	height: 40px;
	justify-content: center;
	margin-inline: auto;
	padding-block-end: 3px;
	position: relative;
	width: 190px;
}

.section__fukidashi::after {
	border-bottom: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-style: solid;
	border-top: 10px solid #63a4c2;
	bottom: -10px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	translate: -50%;
	width: 0;
}

.section__link {
	align-items: center;
	display: flex;
	gap: 20px;
	justify-content: center;
	margin-block-start: 30px;
}

.section__link-text {
	color: #666a66;
	font-size: 20px;
	position: relative;
}

.section__link-text::after {
	background-color: #aaa6aa;
	bottom: -3px;
	content: "";
	height: 1px;
	left: 50%;
	opacity: 1;
	position: absolute;
	transition: opacity 0.3s ease;
	translate: -50%;
	width: 158px;
}

.section__link-arrow {
	align-items: center;
	background-color: #666a66;
	border-radius: 50px;
	display: flex;
	height: 40px;
	justify-content: center;
	transition: transform 0.3s ease;
	width: 40px;
}

.section__curve {
	height: 65px;
	left: 0;
	position: absolute; /* セクションの上下につくカーブ */
	top: -65px;
	width: 100%;
}

.section__curve--reverse {
	bottom: -65px;
	top: auto;
	transform: rotate(180deg);
}

.section__line {
	background-color: #63a4c2;
	height: 1px;
	width: 100%; /* 採用情報音のフッター上部につく区切り線 */
}

/*===================================================================
# トップへ戻るボタン
===================================================================*/

.to__top {
	bottom: 30px;
	height: 40px;
	opacity: 0;
	position: fixed;
	right: 25px;
	transition: opacity 0.3s ease, visibility 0.3s ease;
	visibility: hidden;
	width: 40px;
}

.to__top.is-visible {
	opacity: 1;
	visibility: visible;
}

/*===================================================================
# Text
===================================================================*/

.text__accent {
	color: #63a4c2;
	font-weight: 700;
}

/*===================================================================
# FV
===================================================================*/

.fv {
	background: url(../img/fv_bg.png) center right/cover no-repeat;
	background-color: #f8faf9;
	background-size: 61.7862371889%;
	height: 768px;
	padding-block-start: 283px;
	position: relative;
}

.fv__inner {
	margin-inline: auto;
	max-width: 1186px;
	padding-inline: 20px;
}

.fv__main-message {
	font-size: 35px;
}

.fv__sub-message {
	color: #63a4c2;
	font-size: 30px;
	margin-block-start: 4px;
}

.fv__arrow-wrapper {
	margin: 90px 0 0 156px;
	position: relative;
	width: 85px;
}

.fv__arrow-text {
	color: #666a66;
	font-size: 16px;
}

.fv__arrow {
	height: 60px;
	left: 50%;
	position: absolute;
	top: 37px;
	translate: -50%;
	width: 10px;
	--arrow-distance: 20px; /* アニメーションの移動距離（PC) */
	animation: target1ArrowUpDown 3s ease-in-out infinite;
}

/*===================================================================
# Top_About
===================================================================*/

.about {
	padding-block: 140px;
}

.about__items {
	display: flex;
	gap: 80px;
	margin-block-end: 102px;
}

.about__item-left {
	width: 38.3636363636%;
}

.about__item-right {
	width: 54.3636363636%;
}

.about__img {
	height: auto;
	margin-block-start: 13px;
	margin-inline-start: 12px;
	min-width: 410px;
}

.about__title {
	font-size: 28px;
}

.about__sub-message {
	color: #63a4c2;
	font-size: 24px;
	margin-block-start: 86px;
}

.about__sub-message--underline {
	text-decoration-color: #e2f3fb;
	text-decoration-line: underline;
	text-decoration-thickness: 15px;
	text-underline-offset: -3px;
	-webkit-text-decoration-skip-ink: none;
	text-decoration-skip-ink: none;
}

.about__text {
	margin-block-start: 35px;
}

.about__text--accent {
	color: #63a4c2;
}

.about__solution {
	background-color: #f9f5d3;
	border-radius: 20px;
	padding-block: 47px 43px;
}

.about__solution-title {
	font-size: 30px;
	text-align: center;
}

.about__solution-items {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	margin: 43px auto 24px;
	max-width: 920px;
}

.about__solution-item-title {
	align-items: center;
	background-color: #63a4c2;
	border-radius: 20px;
	color: #FFFFFF;
	display: flex;
	font-size: 22px;
	height: 40px;
	justify-content: center;
	margin-inline: auto;
	padding-block-end: 3px;
	position: relative;
	width: 90px;
}

.about__solution-item-title::after {
	border-bottom: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-style: solid;
	border-top: 10px solid #63a4c2;
	bottom: -10px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	translate: -50%;
	width: 0;
}

.about__solution-item-text {
	margin-block-start: 26px;
	text-align: center;
}

.about__solution-item-img {
	margin: 16px auto 0;
}

.about__solution-message {
	padding-inline-start: 54px;
}

.about__features-items {
	margin-block-start: 150px;
}

.about__features-item {
	display: flex;
	gap: 50px;
	height: 310px;
	margin-block-end: 70px;
}

.about__features-item:last-of-type {
	margin-block-end: 0;
}

.about__features-item--reverse {
	flex-direction: row-reverse;
}

.about__features-item--reverse .about__features-item-left {
	border-radius: 20px 0 0 20px;
	margin-inline: auto calc(50% - 50vw);
	padding-inline: 0 calc(50vw - 50%);
}

.about__features-item--reverse .about__features-item-title {
	margin-inline: auto 0;
	text-align: right;
}

.about__features-item-left {
	align-items: center;
	background-color: #e2f3fb;
	border-radius: 0 20px 20px 0;
	display: flex;
	margin-inline-start: calc(50% - 50vw);
	padding-inline-start: calc(50vw - 50%);
	position: relative;
	width: calc(42% + 133px);
}

.about__features-item-title {
	color: #63a4c2;
	font-size: 28px;
}

.about__features-item-title--reverse {
	margin-inline: auto 0;
	text-align: right;
}

.about__features-item-img {
	position: absolute;
}

.about__features-item-img--1 {
	right: 44px;
	top: -67px;
}

.about__features-item-img--2 {
	left: 42px;
	top: -30px;
}

.about__features-item-right {
	display: flex;
	flex: 1;
	flex-direction: column;
	justify-content: center;
}

.about__features__item-right-title {
	color: #63a4c2;
	font-size: 24px;
	font-weight: 700;
}

.about__features-item-right-text {
	margin-block-end: 32px;
}

.about__features-item-right-text:last-of-type {
	margin-block-end: 0;
}

.about__features-item-right-text--accent {
	color: #63a4c2;
	font-weight: 700;
}

/*===================================================================
# Service-intro(Topページ）
===================================================================*/

.service-intro {
	background-color: #f8faf9;
	margin-block-start: 130px;
	padding-block-end: 255px;
	position: relative;
}

.service-intro--recruit {
	margin-block-start: 0;
	padding-block-end: 90px; /* 採用情報ページの余白 */
}

.service-intro__title-wrapper {
	left: 50%;
	position: absolute;
	top: -90px;
	translate: -50%;
}

.service-intro__items {
	display: flex;
	gap: 60px;
	margin-inline: auto;
	max-width: 1000px;
	padding-block: 70px 20px;
}

.service-intro__item-text--accent {
	color: #63a4c2;
	font-size: 24px;
	text-decoration-color: #e2f3fb;
	text-decoration-line: underline;
	text-decoration-thickness: 15px;
	text-underline-offset: -6px;
	-webkit-text-decoration-skip-ink: none;
	text-decoration-skip-ink: none;
}

/*===================================================================
# Work-intro（Topページ）
===================================================================*/

.work-intro {
	background-color: #e2f3fb;
	padding-block-end: 123px;
	position: relative;
}

.work-intro--work {
	padding-block-end: 90px; /* 事業紹介ページの余白 */
}

.work-intro__title-wrapper {
	left: 50%;
	position: absolute;
	top: -90px;
	translate: -50%;
}

.work-intro__items {
	display: flex;
	gap: 60px;
	margin-inline: auto;
	max-width: 1000px;
	padding-block: 28px 34px;
}

.work-intro__item-text {
	margin-block-start: 38px;
}

.work-intro__item-text--accent {
	color: #63a4c2;
	font-size: 24px;
	text-decoration-color: #FFFFFF;
	text-decoration-line: underline;
	text-decoration-thickness: 15px;
	text-underline-offset: -6px;
	-webkit-text-decoration-skip-ink: none;
	text-decoration-skip-ink: none;
}

.work-intro__item-text--accent-top {
	display: inline-block;
	margin-block-end: 5px; /* Topページでの調整 */
}

/*===================================================================
# Top_Outline
===================================================================*/

.outline {
	background-color: #666a66;
	padding-block: 100px 70px;
}

.outline__items {
	display: flex;
	justify-content: space-between;
	margin-block-start: 70px;
	margin-inline: auto;
	max-width: 960px;
}

.outline__item--right {
	max-width: 400px;
	width: 100%;
}

.outline__table th {
	padding-block-end: 31px;
}

.outline__table td {
	padding-block-end: 31px;
}

.outline__table tr:last-of-type th,
.outline__table tr:last-of-type td {
	padding-block-end: 0;
}

.outline__table-title {
	color: #63a4c2;
	padding-inline-end: 25px;
	text-align: left;
}

.outline__table-content {
	color: #FFFFFF;
}

.outline__map-wrapper {
	margin-block-start: 10px;
	position: relative;
	width: 100%;
}

.outline__map-wrapper::before {
	content: "";
	display: block;
	padding-top: 100%;
}

.outline__map-wrapper iframe {
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

/*===================================================================
# Page-header
===================================================================*/

.page-header {
	background: url(../img/page-hader_bg.png) center center/cover no-repeat;
	height: 400px;
	padding-block-start: 183px;
}

.page-header__inner {
	margin-inline: auto;
	max-width: 1366px;
	position: relative;
}

.page-header__title {
	opacity: 0;
	text-align: center;
	transform: translateY(20px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.page-header__title.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.page-header__title--jp {
	display: block;
	font-size: 40px;
}

.page-header__title--en {
	color: #63a4c2;
	display: block;
	font-size: 20px;
}

.page-header__img {
	bottom: -161px;
	height: 230px;
	position: absolute;
	right: 65px;
	width: 414px;
}

.page-header {
	background-image: url(../img/page-header_bg.webp); /* webp対応ブラウザ用の画像設定 */
}

/*===================================================================
# Page-intro
===================================================================*/

.page-intro {
	padding-block: 100px 108px;
}

.page-intro--recruit {
	padding-block-end: 90px;
}

.page-intro__main-message {
	align-items: center;
	background-color: #e2f3fb;
	border-radius: 20px;
	color: #63a4c2;
	display: flex;
	flex-direction: column;
	font-size: 28px;
	height: 160px;
	justify-content: center;
	margin-inline: auto;
	max-width: 700px;
	text-align: center;
	width: 100%;
}

.page-intro__sub-message {
	font-size: 21px;
	margin-block: 51px 99px;
	text-align: center;
}

.page-intro__sub-message--recruit {
	margin-block-end: 75px;
}

.page-intro__items {
	display: flex;
	gap: 30px;
}

.page-intro__items--recruit {
	gap: 60px;
}

.page-intro__item-left {
	flex-shrink: 0;
	height: auto;
	width: 470px;
}

.page-intro__item-left img {
	margin-block-start: 8px;
}

.page-intro__item-left--recruit {
	width: 450px;
}

.page-intro__item-left--recruit img {
	margin-block-start: 0;
}

.page-intro__item-right {
	flex-grow: 1;
}

.page-intro__item-right--recruit {
	margin-block-start: 12px;
}

.page-intro__item-text {
	margin-block-end: 30px;
}

.page-intro__item-text--accent {
	color: #63a4c2;
	display: inline-block;
	font-size: 24px;
	text-decoration-color: #e2f3fb;
	text-decoration-line: underline;
	text-decoration-thickness: 15px;
	text-underline-offset: -8px;
	-webkit-text-decoration-skip-ink: none;
	margin-block-start: -1px;
	text-decoration-skip-ink: none;
}

.page-intro__item-text:last-of-type {
	margin-block-end: 0;
}

.char {
	opacity: 0;
}

/*===================================================================
# Service
===================================================================*/

.service {
	background-color: #f8faf9;
	margin-block-start: 130px;
	padding-block: 43px 15px;
	position: relative;
}

.service__items {
	margin-block-start: 103px;
}

.service__item {
	background-color: #fff;
	border: 3px solid #63a4c2;
	border-radius: 20px;
	display: flex;
	gap: 60px;
	justify-content: space-between;
	margin-block-end: 130px;
	padding: 80px 67px 78px 60px;
	position: relative;
	position: relative;
}

.service__item:last-of-type {
	margin-block-end: 0;
}

.service__item--bg-blue {
	background-color: #e2f3fb;
}

.service__item--no-text {
	padding-block: 70px;
}

.service__item--no-text .service__item-features {
	margin-block-start: 30px;
}

.service__item--margin {
	padding-block-end: 53px; /* 看板・空調設備工事 */
}

.service__item--margin .service__item-features {
	margin-block-start: 54px;
}

.service__item-title {
	align-items: center;
	background-color: #63a4c2;
	border-radius: 40px;
	color: #FFFFFF;
	display: flex;
	font-size: 30px;
	height: 60px;
	justify-content: center;
	left: 50%;
	padding-block-end: 2px;
	position: absolute;
	top: -30px;
	translate: -50%;
	width: 600px;
}

.service__item-left {
	width: 270px;
}

.service__item-left .service__item-text {
	margin-block: 63px 42px;
}

.service__item-right {
	flex: 1;
}

.service__item-text {
	font-size: 18px;
	margin-block-start: 13px;
}

.service__item-text--accent {
	color: #63a4c2;
	font-size: 22px;
	text-decoration-color: #e2f3fb;
	text-decoration-line: underline;
	text-decoration-thickness: 15px;
	text-underline-offset: -6px;
	-webkit-text-decoration-skip-ink: none;
	text-decoration-skip-ink: none;
}

.service__item-text--etc {
	bottom: 53px;
	font-size: 18px;
	position: absolute; /* など */
	right: 67px;
}

.service__item-text--etc-sp {
	display: none;
	margin-block-start: 39px;
	text-align: center;
}

.service__item-features {
	display: flex;
	gap: 40px;
	margin-block-start: 82px;
}

.service__item-features--no-text {
	margin-block-start: 0;
}

.service__item-feature-text {
	color: #63a4c2;
	font-size: 18px;
	line-height: 1.44;
	margin-block-start: 12px;
	text-align: center;
}

.service__message {
	font-size: 26px;
	margin-block-start: 58px;
	text-align: center;
}

/*===================================================================
# Trust
===================================================================*/

.trust {
	margin-block-start: 145px;
	padding-block-end: 230px;
}

.trust__inner {
	background-color: #f9f5d3;
	border-radius: 25px;
	padding: 50px 20px 70px;
	position: relative;
}

.trust__title {
	align-items: center;
	background-color: #63a4c2;
	border-radius: 25px;
	color: #FFFFFF;
	display: flex;
	font-size: 28px;
	height: 50px;
	justify-content: center;
	margin-inline: auto;
	padding-block-end: 2px;
	width: 200px;
}

.trust__sub-title {
	font-size: 30px;
	margin-block-start: 17px;
	text-align: center;
}

.trust__lists {
	background-color: #fff;
	border-radius: 20px;
	margin-block-start: 20px;
	margin-inline: auto;
	padding: 40px 70px;
	width: 610px;
}

.trust__list {
	font-size: 24px;
	line-height: 2.083;
	position: relative;
	z-index: 0;
}

.trust__list::before {
	border: 1px solid #383838;
	content: ""; /* チェックボックスの枠 */
	font-size: 24px;
	height: 22px;
	left: 1px;
	position: absolute;
	top: 50%;
	translate: 0 -50%;
	width: 22px;
}

.trust__list-check {
	color: #63a4c2;
	margin-inline-end: 5px;
	padding-block-start: 2px;
}

.trust__list-underline {
	display: inline-block;
	position: relative;
}

.trust__list-underline::after {
	background-color: #e2f3fb;
	bottom: 0.3em;
	content: "";
	height: 15px;
	left: -0.2em;
	position: absolute;
	right: -0.2em;
	z-index: -1;
}

.trust__img1 {
	height: 130px;
	left: 50px;
	position: absolute; /* 歯車 */
	top: -30px;
	width: 160px;
}

.trust__img2 {
	bottom: -63px;
	height: 235px;
	position: absolute; /* 作業員 */
	right: 80px;
	width: 100px;
}

/*===================================================================
# Recruit-summary
===================================================================*/

.recruit-summary {
	padding-block-end: 120px;
}

.recruit-summary__items {
	align-items: flex-start;
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
	-moz-column-gap: 40px;
	column-gap: 40px;
	row-gap: 50px;
}

.recruit-summary__item {
	background-color: #f9f5d3;
	border-radius: 20px;
	flex: 0 1 calc(50% - 20px);
	padding: 50px 30px 40px;
}

.recruit-summary__item--2,
.recruit-summary__item--4 {
	padding-block-end: 32px;
}

.recruit-summary__item:nth-child(3) {
	margin-top: -125px;
}

.recruit-summary__item-title {
	align-items: center;
	background-color: #63a4c2;
	border-radius: 25px;
	color: #FFFFFF;
	display: flex;
	font-size: 28px;
	height: 50px;
	justify-content: center;
	margin-inline: auto;
	padding-block-end: 1px;
	width: 300px;
}

.recruit-summary__item-text {
	margin-block-start: 22px;
	max-width: 440px;
	text-align: center;
}

.recruit-summary__item-lists {
	background-color: #fff;
	border-radius: 20px;
	margin-block-start: 24px;
	padding: 18px 0 18px 20px;
}

.recruit-summary__item-lists--3 {
	margin-block-start: 30px;
}

.recruit-summary__item-list {
	font-size: 20px;
	line-height: 2;
	position: relative;
	z-index: 0;
}

.recruit-summary__item-list::before {
	border: 1px solid #383838;
	content: ""; /* チェックボックスの枠 */
	height: 17px;
	left: 2px;
	position: absolute;
	top: 12px;
	width: 17px;
}

.recruit-summary__item-list-check {
	color: #63a4c2;
	margin-inline-end: 5px;
	padding-block-start: 2px;
}

.recruit-summary__item-list-underline {
	display: inline-block;
	position: relative;
}

.recruit-summary__item-list-underline::after {
	background-color: #e2f3fb;
	bottom: 0.3em;
	content: "";
	height: 12px;
	left: -0.2em;
	position: absolute;
	right: -0.2em;
	z-index: -1;
}

.recruit-summary__item-list--2nd {
	margin-inline-start: 28px; /* SP 2行目の調整 */
}

.recruit-summary__item-list--2nd.recruit-summary__item-list-underline::after {
	display: none;
}

.recruit-summary__item-list-explain {
	display: block;
	font-size: 16px;
	line-height: 1.22;
}

/*===================================================================
# Voice
===================================================================*/

.voice {
	background-color: #e2f3fb;
	margin-block-end: 385px;
	padding-block: 70px 50px;
}

.voice__title {
	align-items: center;
	background-color: #63a4c2;
	border-radius: 25px;
	color: #FFFFFF;
	display: flex;
	font-size: 28px;
	height: 50px;
	justify-content: center;
	margin-inline: auto;
	width: 300px;
}

.voice__items {
	display: flex;
	gap: 30px;
	margin: 50px auto 0;
	max-width: 730px;
	position: relative;
}

.voice__item {
	background-color: #fff;
	border: 3px solid #63a4c2;
	border-radius: 25px;
	padding: 25px;
	position: relative;
}

.voice__item::before {
	background: url(../img/voice_triangle.svg) center center/contain no-repeat;
	content: "";
	height: 14px;
	position: absolute;
	top: 30px;
	width: 20px;
}

.voice__item--left::before {
	left: -20px;
}

.voice__item--right::before {
	right: -20px;
	transform: scaleX(-1);
}

.voice__item-text {
	font-size: 16px;
}

.voice__img {
	position: absolute;
	top: -25px;
}

.voice__img--left {
	height: 250px;
	left: -105px;
	width: 69.5px;
}

.voice__img--right {
	height: 246px;
	right: -130px;
	width: 95px;
}

/*===================================================================
# Requirements
===================================================================*/

.requirements {
	background-color: #f8faf9;
	padding-block: 44px 143px;
	position: relative;
}

.requirements__table-wrapper {
	margin-block-start: 92px;
	margin-inline: auto;
	max-width: 800px;
	padding-inline: 20px;
}

.requirements__table {
	border: 3px solid #63a4c2;
	border-radius: 20px;
	display: flex;
	justify-content: center;
	margin-inline: auto;
	padding: 60px 0;
	width: 100%;
}

.requirements__table__inner {
	margin-inline: auto;
}

.requirements__table th,
.requirements__table td {
	padding-block-end: 29px;
}

.requirements__table tr:last-of-type th,
.requirements__table tr:last-of-type td {
	padding-block-end: 0;
}

.requirements__table-title {
	color: #63a4c2;
	padding-inline-end: 40px;
	text-align: left;
}

.requirements__annotation {
	font-size: 20px;
	padding-block-start: 37px;
	text-align: center;
}

/*===================================================================
# Contact
===================================================================*/

.contact {
	background-color: #e2f3fb;
	padding-block: 44px 280px;
	position: relative;
}

.contact__message {
	margin-block-start: 54px;
	text-align: center;
}

.contact__form form {
	background-color: #fff;
	border: 3px solid #63a4c2;
	border-radius: 20px;
	display: flex;
	flex-direction: column;
	margin-block-start: 43px;
	padding: 60px;
	row-gap: 15px;
}

.contact__row {
	align-items: center;
	display: grid; /* 各入力項目 */
	grid-template-columns: 220px 1fr;
}

.contact__row--license {
	margin-block: 8px;
}

.contact__head { /* 項目名 */
}

.contact__head--must {
	display: inline-flex;
	position: relative;
}

.contact__head--must::after {
	background: #e62322;
	color: #FFFFFF;
	content: "必須";
	display: inline-block;
	font-size: 16px;
	left: calc(100% + 13px);
	line-height: 1.3;
	padding: 0 6px 1px;
	position: absolute;
	top: 50%;
	translate: 0 -50%;
	white-space: nowrap;
}

.contact__birthday-wrapper {
	display: flex; /* 生年月日 */
	gap: 20px;
}

.contact__select-wrapper {
	align-items: center;
	display: flex;
	gap: 18px;
	position: relative;
}

.contact__select-wrapper::before {
	background-color: #666a66;
	content: "";
	height: 45px;
	pointer-events: none;
	position: absolute;
	right: 37px;
	top: 0;
	width: 45px;
	z-index: 1;
}

.contact__select-wrapper::after {
	background: url(../img/select_triangle.svg) center center/contain no-repeat;
	content: "";
	height: 13.45px;
	pointer-events: none;
	position: absolute;
	right: 53.5px;
	top: 50%;
	translate: 0 -50%;
	width: 12px;
	z-index: 2;
}

.contact__select { /* セレクトボックスの幅 */
}

.contact__select--w105 {
	width: 105px;
}

.contact__select--125 {
	width: 125px;
}

.contact__policy-title {
	margin-block: 12px 19px;
}

.contact__policy-text {
	border: 1px solid #c0c7c0;
	border-radius: 5px;
	font-size: 14px;
	height: 170px;
	overflow-y: scroll;
	padding: 20px 23px;
}

input[type=text],
input[type=email],
input[type=tel],
select,
textarea {
	background: #fff;
	border: 1px solid #666a66;
	border-radius: 0;
	font-size: 18px;
	padding: 8.25px 24px;
	width: 100%;
}

/* フォーカス時 */

input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus,
select:focus,
textarea:focus {
	outline: 1px solid #63a4c2;
}

textarea {
	height: 260px;
	resize: vertical;
}

select {
	-moz-appearance: none;
	appearance: none;
	-webkit-appearance: none;
	cursor: pointer;
	height: 45px;
	padding-block: 0;
}

#birth-year-select.placeholder,
#birth-month-select.placeholder,
#birth-day-select.placeholder {
	color: #ccc;
}

#birth-year-select,
#birth-month-select,
#birth-day-select {
	color: #383838;
}

input[type=radio],
input[type=checkbox] {
	height: 1px;
	position: absolute;
	width: 1px; /* デフォルトのものを消す */
	clip: rect(0, 0, 0, 0);
}

/* フォーカス時 */

input[type=radio]:focus + span::before,
input[type=checkbox]:focus + span::before {
	border: 1px solid #63a4c2;
}

/* チェックされた時の挙動 */

input[type=radio]:checked + span::after,
input[type=checkbox]:checked + span::after {
	opacity: 1;
}

.contact__data-checkbox {
	.wpcf7-radio {
		display: flex;
		gap: 77px;
	}
}

.contact__data-checkbox .wpcf7-list-item-label {
	cursor: pointer;
	display: inline-block;
	font-size: 16px;
	line-height: normal;
	padding-left: 38px;
	position: relative;
}

.contact__data-checkbox .wpcf7-list-item-label::before {
	border: 1px solid #000;
	content: ""; /* ボックス */
	height: 25px;
	left: 0;
	position: absolute;
	top: 0;
	width: 25px;
}

.contact__data-checkbox .wpcf7-list-item-label::after {
	border-bottom: 1.5px solid #000;
	border-right: 1.5px solid #000;
	content: ""; /* チェックマーク */
	height: 16px;
	left: 9px;
	opacity: 0;
	position: absolute;
	rotate: 45deg;
	top: 4px;
	transition: opacity 0.3s ease;
	width: 8px;
}

.contact__data-checkbox--acceptance .wpcf7-list-item-label {
	padding-left: 22px;
}

.contact__data-checkbox--acceptance .wpcf7-list-item-label::before {
	height: 16px;
	left: 0;
	top: 4.5px; /* ボックス */
	width: 16px;
}

.contact__data-checkbox--acceptance .wpcf7-list-item-label::after {
	height: 10px;
	left: 6px;
	top: 7px; /* チェックマーク */
	width: 5px;
}

.contact__acceptance {
	margin-block: -11px 48px;
}
.contact__acceptance .wpcf7-list-item {
	margin-left: 0;
}

.contact__acceptance-text-sp {
	display: none;
	font-size: 14px; /* 個人重宝の取り扱い sp用のかっこ書き */
	line-height: 1;
}

input[type=submit],
input[type=button] {
	border-radius: 0px;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
	-moz-appearance: button;
	appearance: button;
	background: transparent;
	border: none;
	box-sizing: border-box;
	cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
	display: none;
}

input[type=submit]:disabled {
	cursor: default;
	pointer-events: none;
}

/* フォーカス時 */

input[type=submit]:focus {
	outline: 1px solid transparent;
}

.contact__submit {
	align-items: center;
	background-color: #ccc;
	border: 2px solid transparent;
	border-radius: 30px;
	color: #fff;
	display: flex;
	font-size: 30px;
	height: 60px;
	justify-content: center;
	margin-inline: auto;
	opacity: 0.6;
	position: relative;
	transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
	width: 300px;
}

.contact__submit.is-activate {
	background: #63a4c2;
	cursor: pointer;
	pointer-events: auto;
}

.contact__submit.is-activate::after {
	display: block;
}

.contact__submit::after {
	background: url(../img/contact_btn.svg) center center/contain no-repeat;
	border: 1px solid transparent;
	border-radius: 50%;
	content: "";
	display: none;
	height: 40px;
	position: absolute;
	right: 14px;
	top: 50%;
	transition: right 0.3s ease, border-color 0.3s ease;
	translate: 0 -50%;
	width: 40px;
	z-index: 1;
}

.contact__submit:has(input:focus) {
	background-color: #e2f3fb;
	color: #63a4c2;
	outline: 1px solid #63a4c2;
}

.contact__submit:has(input:focus)::after {
	border: 1px solid #63a4c2;
}

.wpcf7-list-item.first {
	margin-left: 0;
}

.wpcf7-spinner {
	display: none !important;
}

/*===================================================================
# ブレークポイントによる表示 / 非表示
===================================================================*/

.show__sp {
	display: none; /* spのみ表示 */
}

.show__tab {
	display: none; /* tabのみ表示 */
}

.show__medium {
	display: none; /* mediumのみ表示 */
}

.show__tab-pc {
	display: block; /* tab～pc間で表示 */
}

.show__tab-pc--inline {
	display: inline-block;
}

.show__medium-pc {
	display: block; /* medium～pc間で表示 */
}

.show__sp-medium {
	display: none; /* sp～medium間で表示 */
}

.show__pc-and-tab { /* pcとtabで表示 */
}

.show__medium-and-sp {
	display: none;
}

@media (any-hover: hover) {

.header__btn:hover {
	background-color: transparent;
	border: 1px solid #63a4c2;
	color: #63a4c2;
}

.footer__list li a:hover span::after {
	opacity: 0;
}

.footer__btn:hover {
	background-color: transparent;
	border: 1px solid #63a4c2;
	color: #63a4c2;
}

.section__link:hover .section__link-text::after {
	opacity: 0;
}

.section__link:hover .section__link-arrow {
	transform: translateX(-10px);
}

.contact__submit:hover.is-activate {
	background-color: #e2f3fb;
	border: 2px solid #63a4c2;
	color: #63a4c2;
}

.contact__submit:hover::after {
	border: 1px solid #63a4c2;
	right: 25px;
}

}

@media screen and (min-width: 430px) and (max-width: 767px) {

.fv__inner {
	background-color: rgba(255, 255, 255, 0.7);
}

}

@media screen and (min-width: 451px) and (max-width: 767px) {

.about__features-item--reverse .about__features-item-left {
	margin-inline: auto 0;
	padding-inline: 0;
}

.about__features-item-left {
	margin-inline-start: 0;
	padding-inline-start: 0;
}

}

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

.footer__items {
	flex-direction: column-reverse;
	gap: 40px;
}

.footer__nav {
	justify-content: center;
}

.inner {
	padding-inline: 30px;
}

.fv {
	padding-block-start: 130px;
}

.about {
	padding-block: 80px;
}

.about__items {
	flex-direction: column;
	gap: 50px;
}

.about__item-left {
	width: 100%;
}

.about__item-right {
	width: 100%;
}

.about__img {
	margin-inline: auto;
}

.about__sub-message {
	margin-block-start: 50px;
}

.about__solution-title {
	font-size: clamp(26px, 13.9529411765px + 1.568627451vw, 30px) !important;
}

.about__solution-message {
	padding-inline: 30px;
}

.about__features-item {
	margin-block-end: 100px;
}

.work-intro__items {
	gap: 30px;
}

.work-intro__item-text--accent {
	font-size: clamp(22px, 15.9764705882px + 0.7843137255vw, 24px);
}

.outline__item--left {
	margin-inline-end: 20px;
}

.outline__item--right {
	max-width: clamp(300px, -1.1764705882px + 39.2156862745vw, 400px);
}

.outline__table-title {
	min-width: 97px;
}

.page-header__img {
	height: auto;
	width: clamp(300px, -43.3411764706px + 44.7058823529vw, 414px);
}

.page-intro__items {
	flex-direction: column;
}

.page-intro__item-left {
	width: 100%;
}

.page-intro__item-left img {
	height: auto;
	margin-inline: auto;
	width: 470px;
}

.service__item {
	flex-direction: column;
}

.service__item-left {
	width: 100%;
}

.service__item-img {
	margin-inline: auto;
}

.service__item-img--1,
.service__item-img--2,
.service__item-img--3,
.service__item-img--4 {
	height: auto;
	width: 270px;
}

.service__item-features {
	justify-content: center;
	margin-block-start: 0;
}

.recruit-summary__items {
	flex-direction: column;
}

.recruit-summary__item {
	flex: 0 1 100%;
	margin-inline: auto;
	width: 600px;
}

.recruit-summary__item:nth-child(3) {
	margin-top: 0;
}

.recruit-summary__item-text {
	margin-inline: auto;
}

.voice {
	margin-block-end: 200px;
}

.voice__items {
	gap: 20px;
	justify-content: center;
}

.voice__item {
	max-width: 250px;
	padding: 20px;
}

.voice__img--left {
	left: 0;
}

.voice__img--right {
	right: -20px;
}

.contact__form form {
	padding-inline: 30px;
}

.contact__birthday-wrapper {
	gap: 10px;
}

.contact__select-wrapper {
	gap: 5px;
}

.contact__select-wrapper::before {
	right: 24px;
}

.contact__select-wrapper::after {
	right: 40.5px;
}

.show__tab {
	display: block;
}

.show__medium-pc {
	display: none;
}

.show__sp-medium {
	display: block;
}

.show__pc-and-tab {
	display: inline-block;
}

.show__medium-and-sp {
	display: none;
}

}

@media screen and (min-width: 1024px) and (max-width: 1189px) {

.fv {
	padding-block-start: clamp(176px, -333.6186046512px + 49.7674418605vw, 283px);
}

.fv__sub-message {
	font-size: 28px;
}

.recruit-summary__item {
	padding-inline: 40px;
}

.recruit-summary__item:nth-child(3) {
	margin-top: -62px;
}

.recruit-summary__item-lists {
	padding-inline-start: 30px;
}

.recruit-summary__item-list--2nd.recruit-summary__item-list-underline::after {
	display: block;
}

.show__medium {
	display: block;
}

.show__sp-medium {
	display: block;
}

.show__pc-and-tab {
	display: none;
}

.show__medium-and-sp {
	display: block;
}

}

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

.about__features-item--reverse .about__features-item-left {
	margin-inline: auto 0;
	padding-inline: 0;
}

.about__features-item--reverse .about__features-item-title {
	margin-inline: auto;
	text-align: center;
}

.about__features-item-left {
	margin-inline-start: 0;
	padding-inline-start: 0;
}

.about__features-item-title {
	margin-inline: auto;
	text-align: center;
}

}

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

.header__inner {
	padding-inline-start: 20px;
}

.header__nav {
	display: none;
}

.footer {
	padding: 30px 20px 18px;
}

.footer__items {
	display: block;
}

.footer__item {
	text-align: center;
}

.footer__logo-link {
	justify-content: center;
}

.footer__nav {
	display: none;
}

.drawer__icon {
	display: flex;
}

.inner {
	max-width: 390px;
	padding-inline: 15px;
}

.inner--wide {
	padding-inline: 30px;
}

.inner--no-padding {
	padding-inline: 0;
}

.inner--about {
	padding-inline: 25px;
}

.section__title--jp {
	font-size: 22px;
}

.section__title--en {
	font-size: 16px;
}

.section__title--fukidashi {
	border-radius: 24px;
	font-size: 22px;
	height: 100px;
	width: 330px;
}

.section__title--fukidashi::after {
	left: 50%;
	translate: -50%;
}

.section__fukidashi {
	font-size: 20px;
}

.to__top {
	bottom: 20px;
	right: 20px;
}

.fv {
	background: url(../img/fv_bg_sp.png) bottom center/cover no-repeat;
	height: 905px;
	padding-block-start: 135px;
}

.fv__inner {
	padding-block-end: 100px;
	padding-inline: 30px;
}

.fv__main-message {
	margin-inline: auto;
	max-width: clamp(390px, 276.2068965517px + 29.1777188329vw, 500px);
}

.fv__sub-message {
	font-size: 28px;
	margin-block-start: 22px;
	margin-inline: auto;
	max-width: clamp(390px, 276.2068965517px + 29.1777188329vw, 500px);
}

.fv__arrow-wrapper {
	margin-block-start: 44px;
	margin-inline: auto;
}

.about {
	padding-block: 62px;
}

.about__items {
	flex-direction: column;
	margin-block-end: 75px;
}

.about__item-left {
	display: none;
}

.about__item-right {
	width: 100%;
}

.about__img {
	margin-block-start: 20px;
	margin-inline: auto;
	max-width: 293px;
	min-width: auto;
}

.about__title {
	font-size: 20px;
}

.about__sub-message {
	font-size: 20px;
	margin-block-start: 57px;
}

.about__text {
	margin-block-start: 31px;
}

.about__text:last-of-type {
	margin-block-start: 21px;
}

.about__solution {
	padding-block: 41px 63px;
	padding-inline: 30px;
}

.about__solution-title {
	font-size: 22px;
}

.about__solution-items {
	grid-template-columns: 1fr;
	row-gap: 55px;
}

.about__solution-item-text {
	font-size: 20px;
}

.about__solution-message {
	font-size: 16px;
	margin-block-start: 63px;
	padding-inline-start: 0;
}

.about__features-items {
	margin-block-start: 140px;
}

.about__features-item {
	flex-direction: column;
	gap: 32px;
	height: auto;
	margin-block-end: 131px;
}

.about__features-item--reverse .about__features-item-title {
	margin-inline: 35px auto;
	text-align: center;
}

.about__features-item-left {
	align-items: flex-end;
	min-height: 180px;
	padding-block-end: 23px;
	width: calc(100% - 30px);
}

.about__features-item-title {
	font-size: 22px;
	margin-inline: auto;
	text-align: center;
}

.about__features-item-img--1 {
	right: 67px;
}

.about__features-item-img--2 {
	left: 123px;
	top: -69px;
}

.about__features-item-right {
	margin-inline: auto;
	width: 330px;
}

.about__features__item-right-title {
	font-size: 20px;
	margin-block-end: 27px;
}

.about__features-item-right-text {
	font-size: 16px;
	margin-block-end: 28px;
}

.service-intro {
	padding-block-end: 179px;
}

.service-intro--recruit {
	padding-block-end: 70px;
}

.service-intro__items {
	flex-direction: column;
	gap: 43px;
	padding-block: 62px 55px;
}

.service-intro__items img {
	height: 180px;
	margin-inline: auto;
	width: 324px;
}

.service-intro__item-text {
	font-size: 16px;
}

.service-intro__item-text--accent {
	font-size: 22px;
}

.work-intro {
	padding-block-end: 70px;
}

.work-intro__items {
	flex-direction: column;
	gap: 6px;
	padding-block: 60px 65px;
}

.work-intro__item-text {
	font-size: 16px;
}

.work-intro__item-text--accent {
	font-size: 22px;
	text-underline-offset: -7px;
}

.outline {
	padding-block: 100px 60px;
}

.outline__inner {
	padding-inline: 0;
}

.outline__items {
	flex-direction: column;
	gap: 41px;
}

.outline__item--left {
	padding-inline: 30px;
}

.outline__table tr {
	display: flex;
	flex-direction: column;
}

.outline__table th {
	padding-block-end: 0;
}

.page-header {
	background-image: url(../img/page-hader_bg_sp.png);
	height: 270px;
	margin-block-end: 60px;
	padding-block-start: 112px;
}

.page-header__img {
	bottom: -184px;
	height: 180px;
	left: 50%;
	right: auto;
	translate: -50%;
	width: 324px;
}

.page-header__img--recruit {
	bottom: -200px;
}

.page-header {
	background-image: url(../img/page-header_bg_sp.webp);
}

.page-intro {
	padding-block-end: 11px;
}

.page-intro__main-message {
	font-size: 20px;
	height: 150px;
	max-width: 330px;
}

.page-intro__sub-message {
	font-size: 20px;
	margin-block: 32px 35px;
	text-align: left;
}

.page-intro__sub-message--recruit {
	margin-block-end: 22px;
}

.page-intro__items {
	flex-direction: column;
}

.page-intro__items--recruit {
	gap: 31px;
}

.page-intro__item-left {
	width: 100%;
}

.page-intro__item-left img {
	height: 190px;
	margin-inline: auto;
	width: 308px;
}

.page-intro__item-left--recruit img {
	height: 210px;
	width: 242px;
}

.page-intro__item-text {
	font-size: 16px;
}

.page-intro__item-text--accent {
	font-size: 20px;
}

.service {
	padding-block-end: 9px;
}

.service__items {
	margin-block-start: 116px;
}

.service__item {
	flex-direction: column;
	gap: 11px;
	margin-block-end: 107px;
	padding: 70px 25px 41px;
}

.service__item-title {
	border-radius: 24px;
	font-size: 22px;
	height: 100px;
	text-align: center;
	top: -50px;
	width: 300px;
}

.service__item-left {
	width: 100%;
}

.service__item-left .service__item-text {
	margin-block: 3px -11px;
}

.service__item-img {
	margin-inline: auto;
}

.service__item-img--1,
.service__item-img--3,
.service__item-img--4 {
	height: 300px;
	width: 202.5px;
}

.service__item-img--2 {
	height: 230px;
	width: 207px;
}

.service__item-text {
	font-size: 16px;
}

.service__item-text--accent {
	font-size: 20px;
}

.service__item-text--etc {
	display: none;
}

.service__item-text--etc-sp {
	display: block;
}

.service__item-features {
	flex-direction: column;
	margin-block-start: 45px;
}

.service__item-feature img {
	margin-inline: auto;
}

.service__message {
	font-size: 20px;
	margin-block-start: 50px;
}

.trust {
	margin-block-start: 115px;
}

.trust__inner {
	padding-block-end: 80px;
	padding-inline: 15px;
}

.trust__title {
	font-size: 22px;
	height: 40px;
	width: 170px;
}

.trust__sub-title {
	font-size: 22px;
}

.trust__lists {
	margin-block-start: 25px;
	padding: 20px;
	width: 100%;
}

.trust__list {
	font-size: 18px;
}

.trust__list::before {
	height: 16px;
	width: 16px;
}

.trust__list-underline::after {
	height: 11px;
}

.trust__img1 {
	height: 60px;
	left: 20px;
	top: -20px;
	width: 73px;
}

.trust__img2 {
	bottom: -105px;
	height: 200px;
	right: 34px;
	width: 85px;
}

.recruit-summary {
	margin-block-start: 69px;
}

.recruit-summary__inner {
	margin-inline: auto;
	padding-inline: 0;
}

.recruit-summary__item {
	flex: 0 1 100%;
	padding: 50px 15px 50px;
}

.recruit-summary__item:nth-child(3) {
	margin-top: 0;
}

.recruit-summary__item-title {
	font-size: 22px;
	height: 40px;
	width: 250px;
}

.recruit-summary__item-text {
	font-size: 16px;
}

.recruit-summary__item-lists {
	padding: 15px 20px;
}

.recruit-summary__item-list {
	font-size: 18px;
	line-height: 2.3;
}

.recruit-summary__item-list--2nd.recruit-summary__item-list-underline::after {
	display: block;
}

.recruit-summary__item-list-explain {
	line-height: 1.375;
	margin-inline-start: 15px;
}

.voice {
	margin-block-end: 145px;
	padding-block: 50px 80px;
}

.voice__title {
	font-size: 22px;
	height: 40px;
	width: 250px;
}

.voice__items {
	flex-direction: column;
	gap: 90px;
}

.voice__item {
	border-radius: 20px;
	max-width: 210px;
	padding: 22px;
}

.voice__item--left {
	margin-inline: auto 10px;
}

.voice__item--right {
	margin-inline: 10px auto;
}

.voice__img--left {
	left: 0;
}

.voice__img--right {
	bottom: -8px;
	right: 0;
	top: auto;
}

.requirements {
	padding-block: 5px 168px;
}

.requirements__table-wrapper {
	margin-block-start: 59px;
	padding-inline: 0;
}

.requirements__table {
	justify-content: flex-start;
	padding: 31px 35px 42px;
}

.requirements__table th,
.requirements__table td {
	display: block;
}

.requirements__table th {
	padding-block-end: 0;
}

.requirements__table-title {
	font-size: 17px;
}

.requirements__table-content {
	font-size: 17px;
}

.requirements__annotation {
	font-size: 18px;
	padding-block-start: 33px;
}

.contact {
	padding-block: 5px 153px;
}

.contact__inner {
	padding-inline: 0;
}

.contact__form form {
	border: none;
	margin-block-start: 32px;
	padding: 37px 30px;
}

.contact__row {
	grid-template-columns: 1fr;
	-moz-column-gap: 0px;
	column-gap: 0px;
	row-gap: 5px;
}

.contact__head {
	font-size: 16px;
}

.contact__head--must::after {
	font-size: 14px;
	left: calc(100% + 8px);
}

.contact__birthday-wrapper {
	gap: 0;
	justify-content: space-between;
}

.contact__select-wrapper {
	gap: 6px;
}

.contact__select-wrapper::before {
	height: 35px;
	right: 20px;
	width: 35px;
}

.contact__select-wrapper::after {
	right: 31.5px;
}

.contact__select--w105 {
	height: 35px;
	width: 73px;
}

.contact__select--125 {
	height: 35px;
	width: 87px;
}

.contact__birthday-label {
	font-size: 14px;
}

.contact__policy-title {
	font-size: 16px;
	margin-block: -5px 10px;
}

.contact__policy-text {
	padding: 15px;
}

input[type=text],
input[type=email],
input[type=tel],
select,
textarea {
	font-size: 16px;
	padding: 5px 12px;
}

select {
	font-size: 14px;
	padding-block: 3px 4px;
}

textarea {
	height: 150px;
}

.contact__data-checkbox {
	.wpcf7-radio {
		gap: 40px;
	}
}

.contact__data-checkbox .wpcf7-list-item-label {
	padding-left: 28px;
}

.contact__data-checkbox .wpcf7-list-item-label::before {
	height: 20px;
	top: 2px;
	width: 20px;
}

.contact__data-checkbox .wpcf7-list-item-label::after {
	height: 14px;
	left: 7px;
	top: 3px;
	width: 6px;
}

.contact__data-checkbox--acceptance .wpcf7-list-item-label {
	margin-block-start: 10px;
	padding-left: 18px;
}

.contact__data-checkbox--acceptance .wpcf7-list-item-label::before {
	height: 14px;
	top: 5px;
	width: 14px;
}

.contact__data-checkbox--acceptance .wpcf7-list-item-label::after {
	height: 9px;
	left: 5px;
	top: 7px;
	width: 4px;
}

.contact__acceptance {
	margin-block-end: 26px;
}

.contact__acceptance-text-sp {
	display: block;
}

.contact__submit {
	font-size: 20px;
	height: 40px;
	width: 200px;
}

.contact__submit::after {
	height: 26px;
	right: 9.5px;
	width: 26px;
}

.show__sp {
	display: block;
}

.show__tab-pc--inline {
	display: none;
}

.show__tab-pc {
	display: none;
}

.show__medium-pc {
	display: none;
}

.show__pc-and-tab {
	display: none;
}

.show__medium-and-sp {
	display: block;
}

}

@media (max-width: 390px) {

.about__solution {
	border-radius: 0;
}

.trust__inner {
	border-radius: 0;
}

.recruit-summary__item {
	border-radius: 0;
}

.contact__form form {
	border-radius: 0;
}

}

@keyframes target1ArrowUpDown {

0% {
	transform: translateY(0); /* 初期位置 */
}

/* 矢印が下に動くアニメーション */

50% {
	transform: translateY(var(--arrow-distance)); /* 下に移動（カスタムプロパティを使用） */
}

100% {
	transform: translateY(0); /* 元の位置に戻る */
}

}

