/* -------------------------------------------
共通パッチ
------------------------------------------- */
img {
	vertical-align: bottom;
}

/* PCとタブレットのみ改行を適用 */
@media screen and (min-width: 767.01px) {
	.pc-tab {
		display: block;
	}
}

@media screen and (max-width: 767px) {
	.pc-tab {
		display: none;
	}
}

/* 要項ページ body */
.single-post_recruit {
	color: var(--sub-txt, #333);
	word-break: break-word;
	font-weight: 500;
}

.c-headline-001__en {
	font-weight: 400;
/* text-transform: uppercase; */
}

.c-headline-001__ja {
	font-weight: 700;
	line-height: 1.6;
}

.m-footer-001__copyright {
	padding: 30px 0;
	font-family: inherit;
}

@media screen and (max-width: 767px) {
	.m-footer-001__copyright {
		padding: 20px 0;
	}
}

div[class^="m-require-"][class$="__detail-ttl"] {
	font-weight: 700;
/* color: var(--sub-txt); */
}

div[class^="m-require-"][class$="__detail-desc"] {
	font-weight: 500;
}

.m-header-001__logo {
	padding: 16px 40px;
}

@media screen and (max-width: 767px) {
	.m-header-001__logo {
		padding: 12px 15px;
	}
}

.m-header-001__logo-link-img {
	max-height: 46px;
}

@media screen and (max-width: 767px) {
	.m-header-001__logo-link-img {
		max-height: 35px;
	}
}

/* サブカラー 背景を無効化したいとき */
/* .c-module-container > section:nth-of-type(odd) {
background-color: transparent;
} */

/* 募集要項の罫線 */
div[class^="m-require-"][class$="__detail-row"] {
	border-color: var(--primary-border);
}

/* 見出し下の余白設定 */
.c-headline-001 {
	margin-bottom: 30px;
}

@media screen and (max-width: 767px) {
	.c-headline-001 {
		margin-bottom: 20px;
	}
}

/* 見出し後のコンテンツの上余白を削除 */
.c-headline-001 + * {
	padding-top: 0;
	margin-top: 0;
}

.img-headline {
	margin: 0 auto;
	height: 60px;
}

@media screen and (max-width: 767px) {
	.img-headline{
		height: 42px;
	}
}
@media screen and (max-width: 374px) {
	.img-headline.sp{
		display:none;
	}
}

.img-headline.sp320 {
	display: none;
	height: 41px;
}

@media screen and (max-width: 374px) {
	.img-headline.sp320 {
		display: inline-block;
	}
}

/* フッター */
.m-footer-001 {
	background: #80bad4;
}

@media screen and (max-width: 767px) {
	.c-headline-001__ja,
	[class$="__headline-txt"],
	[class$="__content-ttl"] {
		font-size: 2rem;
		letter-spacing: .2rem;
	}
}

@media screen and (max-width: 374px) {
	.c-headline-001__ja,
	[class$="__headline-txt"],
	[class$="__content-ttl"] {
		font-size: 1.8rem;
		letter-spacing: .1rem;
	}
}

/* -------------------------------------------
メッセージ 001
------------------------------------------- */
/* 色調整 */
.m-message-001 {
	background: #e9fafe !important;
}

.m-message-001__headline-txt {
/* color: var(--primary); */
}

.m-message-001__desc-txt {
/* color: var(--sub-txt, #333); */
}

/* その他 */
.m-message-001 {
	padding: 80px 0;
}

@media screen and (max-width: 767px) {
	.m-message-001 {
		padding: 40px 0;
	}
}

.m-message-001__detail {
	padding: 0 20px;
}

.m-message-001__headline {
	margin-bottom: 20px;
}

.m-message-001__headline-txt {
	font-weight: 700;
}

.m-message-001__headline + .m-message-001__desc {
	margin-top: -2px;
}

.m-message-001__desc-txt {
	padding-bottom: 0;
}

@media screen and (max-width: 767px) {
	.m-message-001__desc-txt {
		text-align: left;
	}
}

.m-message-001__desc-txt:first-child {
	padding-top: 0;
}

/* -------------------------------------------
仕事内容（単体） 001
------------------------------------------- */
.m-jobs-001 {
/* background: #e5f6ef; */
}

.m-jobs-001__content-desc {
/* color: #333; */
/* color: var(--primary); */
}

.m-jobs-001__list-item-detail-ttl {
	color: var(--primary);
}

.m-jobs-001 {
	padding: 80px 20px;
}

@media screen and (max-width: 767px) {
	.m-jobs-001 {
		padding: 40px 20px;
	}
}

@media screen and (max-width: 767px) {
	.m-jobs-001__content-desc {
		text-align: left;
	}
}

.m-jobs-001__list {
	padding: 0;
}

.m-jobs-001__list-item:last-child {
	padding-bottom: 0;
}

.m-jobs-001__list-item-inner {
	align-items: center;
}

.m-jobs-001__list-item-figure {
	min-height: 490px;
}

@media screen and (max-width: 767px) {
	.m-jobs-001__list-item-figure {
		min-height: auto;
	}
}

.m-jobs-001__list-item-detail {
	width: 40%;
	margin: 0 0 0 3%;
	padding: 40px 0;
}

.m-jobs-001__list-item-detail-ttl {
	display: block; /*safariバグ対策*/
	padding: 0;
	margin: 0 0 15px;
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 0.1rem;
	background: transparent;
}

@media screen and (max-width: 767px) {
	.m-jobs-001__list-item-detail-ttl {
		font-size: 1.8rem;
	}
}

.m-jobs-001__list-item-detail-desc {
	font-weight: 500;
}

/*テキストを内側に寄せたい場合は削除*/
.m-jobs-001__list-item-detail {
	width: 45%;
	margin: 0;
	padding: 40px 0% 40px 40px;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
	.m-jobs-001__list-item-detail {
		padding: 20px 0 40px 20px;
	}
}

@media screen and (max-width: 767px) {
	.m-jobs-001__list-item-detail {
		width: 100%;
		margin: 0 0 0 0%;
		padding: 20px 0 10px;
	}
}

.m-jobs-001__list-item:nth-child(even) .m-jobs-001__list-item-detail {
	margin: 0 3% 0 0;
	padding: 40px 0%;
}

/*テキストを内側に寄せたい場合は削除*/
.m-jobs-001__list-item:nth-child(even) .m-jobs-001__list-item-detail {
	margin: 0;
	padding: 40px 40px 40px 0%;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
	.m-jobs-001__list-item:nth-child(even) .m-jobs-001__list-item-detail {
		padding: 20px 20px 40px 0;
	}
}

@media screen and (max-width: 767px) {
	.m-jobs-001__list-item:nth-child(even) .m-jobs-001__list-item-detail {
		margin: 0;
		padding: 20px 0;
	}
}

@media screen and (max-width: 767px) {
	.m-jobs-001__list-item:last-child .m-jobs-001__list-item-detail {
		padding-bottom: 0;
	}
}

/*タブレットから縦並びの時*/
@media screen and (max-width: 1024px) {
	.m-jobs-001__list-item-inner,
	.m-jobs-001__list-item:nth-child(even) .m-jobs-001__list-item-inner {
		flex-direction: column;
	}
	.m-jobs-001__list-item-figure {
		width: 100%;
		min-height: 440px; /*適宜変更*/
	}
	.m-jobs-001__list-item-detail {
		width: 100%;
		margin: 0;
		padding: 20px 0px;
	}
	.m-jobs-001__list-item:nth-child(even) .m-jobs-001__list-item-detail {
		padding: 20px 0px;
	}
	.m-jobs-001__list-item:last-child .m-jobs-001__list-item-detail {
		padding-bottom: 0;
	}
}
@media screen and (max-width: 767px) {
	.m-jobs-001__list-item-figure {
		min-height: auto;
	}
}

@media screen and (max-width: 767px) {
	.m-jobs-001__list-item-detail,
    .m-jobs-001__list-item:nth-child(even) .m-jobs-001__list-item-detail {
		padding-bottom: 10px;
	}
}

/* -------------------------------------------
追加パッチ（河田）
------------------------------------------- */
/* 各見出しが「文字色＋背景色」の場合に追記 */
/* .m-jobs-001__list-item-detail-ttl {
display: inline-block;
background: var(--primary);
color: var(--primary-txt);
padding: 0.4em 0.8em;
margin: 0 0 30px;
line-height: 1.5;
}

@media screen and (max-width: 1024px) {
.m-jobs-001__list-item-detail-ttl {
margin: 0 0 20px;
}
}

@media screen and (max-width: 767px) {
.m-jobs-001__list-item-detail-ttl {
margin: 0 0 10px;
}
}

@media screen and (max-width: 1024px) {
.m-jobs-001__list-item-detail {
padding: 30px 0px 20px !important;
}
}

@media screen and (max-width: 767px) {
.m-jobs-001__list-item-detail {
padding: 15px 0px 20px !important;
}
} */

/* -------------------------------------------
社風 003
------------------------------------------- */  
.m-culture-003 {
	padding: 80px 0;
	background: #e9fafe !important;
}

@media screen and (max-width: 1024px) {
	.m-culture-003 {
		padding: 80px 20px;
	}
}

@media screen and (max-width: 767px) {
	.m-culture-003 {
		padding: 40px 20px;
	}
}

.m-culture-003__inner {
	max-width: 800px;
}

.m-culture-003 .c-headline-001__en {
/* color: #fff; */
}

.m-culture-003 .c-headline-001__ja {
/* color: #fff; */
}

.m-culture-003__list {
	padding: 0;
}

@media screen and (max-width: 1024px) {
	.m-culture-003__list {
		padding: 0;
	}
}

.m-culture-003__list-item {
	margin: 0;
	padding: 0 0 60px 0;
}

@media screen and (max-width: 1024px) {
	.m-culture-003__list-item {
		padding: 0;
	}
}

@media screen and (max-width: 767px) {
	.m-culture-003__list-item {
		padding: 0;
	}
}

.m-culture-003__list-item:last-child {
	padding-bottom: 0;
}

.m-culture-003__list-item:last-child .m-culture-003__list-item-detail {
	padding-bottom: 0;
}

@media screen and (max-width: 767px) {
	.m-culture-003__list-item:last-child .m-culture-003__list-item-detail {
		padding-bottom: 0;
	}
}

.m-culture-003__list-item-detail {
    padding: 20px 20px 0;
}

@media screen and (max-width: 1024px) {
    .m-culture-003__list-item-detail {
        padding: 20px 0 30px;
    }
}

.m-culture-003__list-item-detail-ttl {
	border: solid #ddd;
	border-width: 0 0 1px;
}

.m-culture-003__list-item-detail-ttl-txt {
	font-size: 2rem;
	font-weight: 900;
	color: var(--primary);
}

@media screen and (max-width: 767px) {
	.m-culture-003__list-item-detail-ttl-txt {
		font-size: 1.8rem;
	}
}

@media screen and (max-width: 320px) {
	.m-culture-003__list-item-detail-ttl-txt {
		font-size: 1.6rem;
	}
}

.m-culture-003__list-item-detail-desc-txt {
	font-size: 1.5rem;
}

@media screen and (max-width: 767px) {
	.m-culture-003__list-item-detail-desc-txt {
		font-size: 1.5rem;
	}
}

/* -------------------------------------------
ギャラリー 003
------------------------------------------- */
.m-gallery-003 {
}

.m-gallery-003 .c-headline-001 {
	margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
	.m-gallery-003 .c-headline-001 {
		margin-bottom: 20px;
	}
}

.m-gallery-003__inner {
	padding: 0 40px;
}

@media screen and (max-width: 1024px) {
	.m-gallery-003__inner {
		padding: 0 20px;
	}
}

.m-gallery-003__list {
	padding: 0;
	margin: -5px;
}

.m-gallery-003__list-item {
	padding: 5px;
	width: 33.33%;
}

@media screen and (max-width: 1024px) {
	.m-gallery-003__list-item {
		width: 50%;
	}
}

@media screen and (max-width: 767px) {
	.m-gallery-003__list {
		margin: -3px;
	}

	.m-gallery-003__list-item {
		padding: 3px;
	}
}


.m-require-003 {
    padding-top: 20px;
}