@charset "UTF-8";
/* CSS Document */

/*
70.新卒採用情報(フォームのみ)
71.新卒採用情報_サンクスページ
80.中途採用情報＿一覧
81.中途採用情報＿カテゴリ一覧
82.中途採用情報＿個別
83.中途採用情報＿サンクスページ
90.お知らせ＿一覧
91.お知らせ＿カテゴリ一覧
92.お知らせ＿個別
100.お問い合わせ
101.お問い合わせ＿サンクスページ
110.個人情報保護方針
*/

/*
80.中途採用情報＿一覧
81.中途採用情報＿カテゴリ一覧
82.中途採用情報＿個別
*/
/*PC*/
@media only screen and (min-width: 1025px) {
	/*メインビジュアル*/
	#mcr_mv {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#mcr_mv::after {
		content: "";
		z-index: 1;
		position: absolute;
		bottom: 0;
		left: 0;
		width: 47%;
		height: 105px;
		background: #fff;
	}
	
	#mcr_mv img {
		display: block;
		z-index: 0;
		position: relative;
		width: 100%;
		height: 500px;
		object-fit: cover;
		object-position: center;
	}
	
	#mcr_mv .sub_title {
		z-index: 2;
		position: absolute;
		bottom: 84px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		width: 1100px;
		height: auto;
	}
	
	#mcr_mv .sub_title .subtitle_wrap {
		position: relative;
		display: inline-block;
		margin-top: 2px;
	}
	
	#mcr_mv .sub_title.is-animated .subtitle_wrap::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		transform-origin: left center;
		animation: bg 2.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
		background: linear-gradient(to top right, #278F49 0%,#66AD47 100%);
	}
	
	#mcr_mv .sub_title .subtitle_wrap .inn {
		z-index: 1;
		display: inline-block;
		position: relative;
		padding: 10px 20px 10px 20px;
		font-size: 20px;
		font-weight: 600;
		font-family: "Raleway", sans-serif;
		letter-spacing: 1px;
		line-height: 20px;
		color: #fff;
	}
 
	@keyframes bg {
  0% {
    opacity: 0;
    transform: scaleX(0) translateX(-5%);
  }
  30% {
    transform: scaleX(1) translateX(0);
  }
  100% {
    transform: scaleX(1) translateX(0);
  }
  30%, 100% {
    opacity: 1;
  }
	}
	
	#mcr_mv .title {
		z-index: 2;
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		width: 1100px;
		height: auto;
	}
	
	#mcr_mv .title h1 {
		font-size: 36px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 36px;
		text-align: left;
	}
	
	#mcr_mv .title .text_item {
		width: -webkit-fit-content;
		width: -moz-fit-content;
		width: fit-content;
		overflow: hidden;
	}
	
	#mcr_mv .text_item {
		transform: translateX(-101%);
	}
	
	#mcr_mv .text_item > font {
		display: block;
	}
	
	#mcr_mv .is-active .text_item {
		transform: translateX(0);
		transition: transform cubic-bezier(0.74, 0, 0.24, 0.99) 1.1s;
	}
	
	#mcr_mv .is-active .text_item:nth-child(1) {
		transition-delay: 0s;
	}
	
	#mcr_mv .is-active .text_item:nth-child(1) > font {
		transition-delay: 0s;
	}

	#mcr_mv .text_item > font {
		transform: translateX(101%);
	}
	
	#mcr_mv .is-active .text_item > font {
		transform: translateX(0);
		transition: transform cubic-bezier(0.74, 0, 0.24, 0.99) 1.1s;
	}
	
	/*募集情報検索*/
	#mcr_cat {
		position: relative;
		width: 1140px;
		height: auto;
		padding-top: 15px;
		margin: 110px auto 100px auto;
	}
	
	#mcr_cat h2 {
		position: relative;
		padding-left: 55px;
		font-size: 30px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 30px;
		text-align: left;
		color: #1E3C0D;
	}
	
	#mcr_cat h2 img {
		position: absolute;
		top: 60%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 40px;
		height: auto;
	}
	
	#mcr_cat ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		position: relative;
		width: 100%;
		height: auto;
		margin: 22px auto 0 auto;
		padding: 50px 65px 30px 65px;
		background: #F4F4F4;
		box-sizing: border-box;
	}
	
	#mcr_cat ul li {
		list-style: none;
		display: block;
		position: relative;
		margin: 0 60px 20px 0;
		box-sizing: border-box;
	}
	
	#mcr_cat ul li.cat-item-none {
		position: relative;
		font-size: 17px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 17px;
		text-align: left;
		color: #393939;
	}
	
	#mcr_cat ul li a {
		position: relative;
		padding-left: 35px;
		font-size: 17px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 17px;
		text-align: left;
		color: #393939;
		transition: 0.2s;
	}
	
	#mcr_cat ul li a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 25px;
		height: 25px;
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/check_grey.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		background-position: center;
		transition: 0.2s;
	}
	
	#mcr_cat ul li a.mcr_current::before {
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/check_green.png);
	}
	
	#mcr_cat ul li a:hover::before {
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/check_green.png);
	}
	
	/*記事一覧*/
	#mcr_loop {
		position: relative;
		width: 1140px;
		height: auto;
		margin: 0 auto 120px auto;
	}
	
	#mcr_loop h2 {
		margin-bottom: 55px;
		font-size: 30px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 30px;
		text-align: center;
		color: #1E3C0D;
	}
	
	#mcr_loop .loop {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#mcr_loop .loop a {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: flex-start;
		position: relative;
		width: 100%;
		height: auto;
		padding: 50px 15px 50px 15px;
		box-sizing: border-box;
	}
	
	#mcr_loop .loop a::after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 1px;
		background: linear-gradient(to right, #278F49, #66AD47);
	}
	
	#mcr_loop .loop a:first-of-type::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 1px;
		background: linear-gradient(to right, #278F49, #66AD47);
	}
	
	#mcr_loop .loop a .text {
		position: relative;
		width: 800px;
		height: auto;
	}
	
	#mcr_loop .loop a .text .cat {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 12px auto;
	}
	
	#mcr_loop .loop a .text .cat font {
		display: table;
		position: relative;
		padding: 9px 20px 9px 20px;
		font-size: 15px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 15px;
		text-align: left;
		color: #fff;
		background: linear-gradient(45deg, #278F49, #66AD47);
		border-radius: 100px;
	}
	
	#mcr_loop .loop a .text p.sub_title {
		font-weight: 500;
		color: #66AD47;
	}
	
	#mcr_loop .loop a .text h3 {
		margin: 14px auto 22px auto;
		font-size: 24px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 24px;
		text-align: left;
		color: #393939;
	}
	
	#mcr_loop .loop a .text .fee p {
		display: contents;
		font-weight: 500;
		color: #8E8E8E;
	}
	
	#mcr_loop .loop a .text .tag {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		position: relative;
		width: 100%;
		height: auto;
		margin: 5px auto 0 auto;
	}
	
	#mcr_loop .loop a .text .tag font {
		display: block;
		position: relative;
		margin: 10px 30px 0 0;
		font-size: 15px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 15px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#mcr_loop .loop a .img {
		position: relative;
		width: 270px;
		height: 205px;
		overflow: hidden;
	}
	
	#mcr_loop .loop a .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 205px;
		object-fit: cover;
		object-position: center;
		transition: 0.4s;
	}
	
	#mcr_loop .loop a:hover .img img {
		transform: scale(1.3);
	}
	
	#mcr_loop .pagination {
		margin-top: 60px;
	}
	
	#mcr_loop .nosearch {
		position: relative;
		width: 100%;
		height: auto;
		margin: 55px auto 0 auto;
	}
	
	#mcr_loop .nosearch p {
		font-size: 20px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 20px;
		text-align: center;
		color: #393939;
	}
	
	/*記事個別*/
	/*タイトル*/
	#mcr_post01 {
		position: relative;
		width: 100%;
		height: auto;
		margin: 20px auto 120px auto;
	}
	
	#mcr_post01 .title {
		z-index: 2;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		position: relative;
		width: 1280px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_post01 .title .text {
		position: relative;
		width: 660px;
		height: auto;
		margin: 25px auto 0 60px;
	}
	
	#mcr_post01 .title .text .cat {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 22px auto;
	}
	
	#mcr_post01 .title .text .cat font {
		display: table;
		position: relative;
		padding: 10px 20px 10px 20px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: left;
		color: #fff;
		background: linear-gradient(45deg, #278F49, #66AD47);
		border-radius: 100px;
	}
	
	#mcr_post01 .title .text p.sub_title {
		font-size: 20px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 20px;
		color: #66AD47;
	}
	
	#mcr_post01 .title .text h1 {
		margin: 26px auto 46px auto;
		font-size: 28px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 38px;
		text-align: left;
		color: #393939;
	}
	
	#mcr_post01 .title .text .tag {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_post01 .title .text .tag font {
		display: block;
		position: relative;
		margin: 0 30px 10px 0;
		font-size: 15px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 15px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#mcr_post01 .title .img {
		position: relative;
		width: 520px;
		height: 390px;
		margin-right: -40px;
		overflow: hidden;
	}
	
	#mcr_post01 .title .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 390px;
		object-fit: cover;
		object-position: center;
	}
	
	
	#mcr_post01 .acf_text {
		z-index: 1;
		position: relative;
		width: 100%;
		height: auto;
		padding: 55px 0 30px 0;
		margin: -55px auto 0 auto;
		background: linear-gradient(45deg, #278F49, #66AD47);
	}
	
	#mcr_post01 .acf_text .text {
		position: relative;
		width: 1120px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_post01 .acf_text .text h3 {
		position: relative;
		padding-left: 35px;
		font-size: 18px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 18px;
		text-align: left;
		color: #fff;
	}
	
	#mcr_post01 .acf_text .text h3 img {
		display: block;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 25px;
		height: auto;
	}
	
	#mcr_post01 .acf_text .text .text_box {
		margin: 18px auto 30px auto;
	}
	
	#mcr_post01 .acf_text .text .text_box p {
		color: #fff;
	}
	
	#mcr_post01 .acf_img {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		position: relative;
		width: 1020px;
		height: auto;
		margin: 60px auto 0 auto;
	}
	
	#mcr_post01 .acf_img img {
		display: block;
		position: relative;
		width: 330px;
		height: 205px;
		margin: 0 5px 0 5px;
		object-fit: cover;
		object-position: center;
	}
	
	/*3つの良いところ*/
	#mcr_post02 {
		position: relative;
		width: 100%;
		height: auto;
		padding: 95px 0 90px 0;
		background: #E4F2D4;
	}
	
	#mcr_post02 h2 {
		position: relative;
		width: 1280px;
		margin: 0 auto 62px auto;
		font-size: 30px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 30px;
		text-align: center;
		color: #1E3C0D;
	}
	
	#mcr_post02 h2 big {
		position: relative;
		margin-right: 15px;
		font-size: 70px;
		line-height: 70px;
		color: #66AD47;
	}
	
	#mcr_post02 h2 font {
		display: block;
		position: relative;
		margin-bottom: 12px;
		font-size: 18px;
		letter-spacing: 1px;
		line-height: 18px;
	}
	
	#mcr_post02 h2::before,
	#mcr_post02 h2::after {
		content: "";
		position: absolute;
		top: 50%;
		transform: translateY(-50%) translateX(0);
		width: 390px;
		height: 24px;
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/mcr_post02_h2.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		background-position: center;
	}
	
	#mcr_post02 h2::before {
		left: 0;
	}
	
	#mcr_post02 h2::after {
		right: 0;
	}
	
	#mcr_post02 .con {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		position: relative;
		width: 1240px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_post02 .con .ptn {
		position: relative;
		width: 380px;
		height: auto;
	}
	
	#mcr_post02 .con .ptn img {
		z-index: 0;
		display: block;
		position: relative;
		width: 100%;
		height: 255px;
		object-fit: cover;
		object-position: center;
	}
	
	#mcr_post02 .con .ptn h3 {
		display: table;
		position: relative;
		margin-top: -20px;
		padding: 10px 20px 10px 20px;
		font-size: 16px;
		font-family: "Raleway", sans-serif;
		font-weight: 600;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: left;
		color: #fff;
		background: linear-gradient(45deg, #278F49, #66AD47);
	}
	
	#mcr_post02 .con .ptn h4 font {
		margin-top: 4px;
		display: table;
		padding: 10px 10px 12px 10px;
		font-size: 24px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 24px;
		text-align: left;
		color: #1E3C0D;
		background: #fff;
	}
	
	#mcr_post02 .con .ptn p {
		margin-top: 20px;
		color: #4E4E4E;
	}
	
	/*募集内容*/
	#mcr_post03 {
		position: relative;
		width: 1060px;
		height: auto;
		margin: 120px auto 120px auto;
	}
	
	#mcr_post03 h2 {
		font-size: 30px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 30px;
		text-align: center;
		color: #1E3C0D;
	}
	
	#mcr_post03 table {
		position: relative;
		width: 100%;
		height: auto;
		margin: 60px auto 0 auto;
		border-collapse: collapse;
	}
	
	#mcr_post03 table tr {
		border-top: solid 1px #D9D9D9;
		border-bottom: solid 1px #D9D9D9;
	}
	
	#mcr_post03 table tr th {
		position: relative;
		width: 240px;
		padding: 35px 0 0 30px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: left;
		color: #fff;
		vertical-align: top;
		box-sizing: border-box;
		background: #278F49;
	}
	
	#mcr_post03 table tr td {
		position: relative;
		width: 820px;
		padding: 30px 45px 30px 45px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 26px;
		text-align: left;
		color: #4E4E4E;
		box-sizing: border-box;
	}
	
	/*エントリーフォーム*/
	#mcr_entry {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 120px auto;
		padding: 90px 0 90px 0;
		background: #F4F4F4;
	}
	
	#mcr_entry .form {
		position: relative;
		width: 1000px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_entry .form h2 {
		margin-bottom: 60px;
		font-size: 40px;
		font-family: "Raleway", sans-serif;
		font-weight: 600;
		letter-spacing: 4px;
		line-height: 40px;
		text-align: left;
		color: #66AD47;
	}
	
	#mcr_entry .form h2 span {
		display: block;
		position: relative;
		margin: 15px 0 0 40px;
		font-size: 20px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 2px;
		line-height: 20px;
		text-align: left;
		color: #1E3C0D;
	}
	
}

/*SMP*/
@media only screen and (max-width: 1024px) {
	/*メインビジュアル*/
	#mcr_mv {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#mcr_mv::after {
		content: "";
		z-index: 1;
		position: absolute;
		bottom: 0;
		left: 0;
		width: 60%;
		height: 52px;
		background: #fff;
	}
	
	#mcr_mv img {
		display: block;
		z-index: 0;
		position: relative;
		width: 100%;
		height: 220px;
		object-fit: cover;
		object-position: center;
	}
	
	#mcr_mv .sub_title {
		z-index: 2;
		position: absolute;
		bottom: 38px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		width: 320px;
		height: auto;
	}
	
	#mcr_mv .sub_title .subtitle_wrap {
		position: relative;
		display: inline-block;
		margin-top: 1px;
	}
	
	#mcr_mv .sub_title.is-animated .subtitle_wrap::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		transform-origin: left center;
		animation: bg 2.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
		background: linear-gradient(to top right, #278F49 0%,#66AD47 100%);
	}
	
	#mcr_mv .sub_title .subtitle_wrap .inn {
		z-index: 1;
		display: inline-block;
		position: relative;
		padding: 5px 10px 8px 10px;
		font-size: 12px;
		font-weight: 600;
		font-family: "Raleway", sans-serif;
		letter-spacing: 1px;
		line-height: 12px;
		color: #fff;
	}
	
	@keyframes bg {
		0% {
			opacity: 0;
			transform: scaleX(0) translateX(-5%);
		}
		30% {
			transform: scaleX(1) translateX(0);
		}
		100% {
			transform: scaleX(1) translateX(0);
		}
		30%, 100% {
			opacity: 1;
		}
	}
	
	#mcr_mv .title {
		z-index: 2;
		position: absolute;
		bottom: 4px;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		width: 320px;
		height: auto;
	}
	
	#mcr_mv .title h1 {
		font-size: 20px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 20px;
		text-align: left;
	}
	
	#mcr_mv .title .text_item {
		width: -webkit-fit-content;
		width: -moz-fit-content;
		width: fit-content;
		overflow: hidden;
	}
	
	#mcr_mv .text_item {
		transform: translateX(-101%);
	}
	
	#mcr_mv .text_item > font {
		display: block;
	}
	
	#mcr_mv .is-active .text_item {
		transform: translateX(0);
		transition: transform cubic-bezier(0.74, 0, 0.24, 0.99) 1.1s;
	}
	
	#mcr_mv .is-active .text_item:nth-child(1) {
		transition-delay: 0s;
	}
	
	#mcr_mv .is-active .text_item:nth-child(1) > font {
		transition-delay: 0s;
	}

	#mcr_mv .text_item > font {
		transform: translateX(101%);
	}
	
	#mcr_mv .is-active .text_item > font {
		transform: translateX(0);
		transition: transform cubic-bezier(0.74, 0, 0.24, 0.99) 1.1s;
	}
	
	/*募集情報検索*/
	#mcr_cat {
		position: relative;
		width: 380px;
		height: auto;
		padding-top: 5px;
		margin: 43px auto 50px auto;
	}
	
	#mcr_cat h2 {
		position: relative;
		margin-left: 20px;
		padding-left: 28px;
		font-size: 16px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: left;
		color: #1E3C0D;
	}
	
	#mcr_cat h2 img {
		position: absolute;
		top: 60%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 20px;
		height: auto;
	}
	
	#mcr_cat ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		position: relative;
		width: 100%;
		height: auto;
		margin: 17px auto 0 auto;
		padding: 20px 20px 10px 20px;
		background: #F4F4F4;
		box-sizing: border-box;
	}
	
	#mcr_cat ul li {
		list-style: none;
		position: relative;
		box-sizing: border-box;
	}
	
	#mcr_cat ul li.cat-item-none {
		display: block;
		position: relative;
		padding-left: 0;
		margin: 0 28px 14px 0;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 0.5px;
		line-height: 12px;
		text-align: left;
		color: #393939;
	}
	
	#mcr_cat ul li a {
		display: block;
		position: relative;
		padding-left: 18px;
		margin: 0 28px 14px 0;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 0.5px;
		line-height: 12px;
		text-align: left;
		color: #393939;
	}
	
	#mcr_cat ul li:nth-of-type(3) a,
	#mcr_cat ul li:nth-of-type(5) a {
		margin-right: 0;
	}
	
	#mcr_cat ul li a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 12.5px;
		height: 12.5px;
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/check_grey.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		background-position: center;
	}
	
	#mcr_cat ul li a.mcr_current::before {
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/check_green.png);
	}
	
	/*記事一覧*/
	#mcr_loop {
		position: relative;
		width: 350px;
		height: auto;
		margin: 0 auto 46px auto;
	}
	
	#mcr_loop h2 {
		margin-bottom: 32px;
		font-size: 16px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: center;
		color: #1E3C0D;
	}
	
	#mcr_loop .loop {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#mcr_loop .loop a {
		display: block;
		position: relative;
		width: 100%;
		height: auto;
		padding: 25px 5px 25px 5px;
		box-sizing: border-box;
	}
	
	#mcr_loop .loop a::after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 1px;
		background: linear-gradient(to right, #278F49, #66AD47);
	}
	
	#mcr_loop .loop a:first-of-type::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 1px;
		background: linear-gradient(to right, #278F49, #66AD47);
	}
	
	#mcr_loop .loop a .text {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#mcr_loop .loop a .text .cat {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 7px auto;
	}
	
	#mcr_loop .loop a .text .cat font {
		display: table;
		position: relative;
		padding: 6px 12px 6px 12px;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 12px;
		text-align: left;
		color: #fff;
		background: linear-gradient(45deg, #278F49, #66AD47);
		border-radius: 100px;
	}
	
	#mcr_loop .loop a .text p.sub_title {
		font-weight: 500;
		color: #66AD47;
	}
	
	#mcr_loop .loop a .text h3 {
		margin: 9px auto 10px auto;
		font-size: 15px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 22px;
		text-align: left;
		color: #393939;
	}
	
	#mcr_loop .loop a .text .fee p {
		display: contents;
		font-weight: 500;
		color: #8E8E8E;
	}
	
	#mcr_loop .loop a .text .tag {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		position: relative;
		width: 100%;
		height: auto;
		margin: 5px auto 0 auto;
	}
	
	#mcr_loop .loop a .text .tag font {
		display: block;
		position: relative;
		margin: 9px 15px 0 0;
		font-size: 11px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 0.5px;
		line-height: 11px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#mcr_loop .loop a .img {
		position: relative;
		width: 180px;
		height: 135px;
		margin: 20px auto 0 auto;
		overflow: hidden;
	}
	
	#mcr_loop .loop a .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 135px;
		object-fit: cover;
		object-position: center;
	}
	
	#mcr_loop .pagination {
		margin-top: 36px;
	}
	
	#mcr_loop .nosearch {
		position: relative;
		width: 100%;
		height: auto;
		margin: 30px auto 0 auto;
	}
	
	#mcr_loop .nosearch p {
		font-size: 12px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 12px;
		text-align: center;
		color: #393939;
	}
	
	/*記事個別*/
	/*タイトル*/
	#mcr_post01 {
		position: relative;
		width: 100%;
		height: auto;
		margin: 30px auto 45px auto;
	}
	
	#mcr_post01 .title {
		z-index: 2;
		position: relative;
		width: 350px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_post01 .title .text {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 25px auto;
	}
	
	#mcr_post01 .title .text .cat {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 10px auto;
	}
	
	#mcr_post01 .title .text .cat font {
		display: table;
		position: relative;
		padding: 7px 13px 7px 13px;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 12px;
		text-align: left;
		color: #fff;
		background: linear-gradient(45deg, #278F49, #66AD47);
		border-radius: 100px;
	}
	
	#mcr_post01 .title .text p.sub_title {
		font-size: 12px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 18px;
		color: #66AD47;
	}
	
	#mcr_post01 .title .text h1 {
		margin: 12px auto 20px auto;
		font-size: 18px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 28px;
		text-align: left;
		color: #393939;
	}
	
	#mcr_post01 .title .text .tag {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_post01 .title .text .tag font {
		display: block;
		position: relative;
		margin: 0 15px 5px 0;
		font-size: 11px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 11px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#mcr_post01 .title .img {
		position: relative;
		width: 260px;
		height: 195px;
		margin: 0 auto 0 auto;
		overflow: hidden;
	}
	
	#mcr_post01 .title .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 195px;
		object-fit: cover;
		object-position: center;
	}
	
	
	#mcr_post01 .acf_text {
		z-index: 1;
		position: relative;
		width: 100%;
		height: auto;
		padding: 90px 0 5px 0;
		margin: -60px auto 0 auto;
		background: linear-gradient(45deg, #278F49, #66AD47);
	}
	
	#mcr_post01 .acf_text .text {
		position: relative;
		width: 320px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_post01 .acf_text .text h3 {
		position: relative;
		padding-left: 22px;
		font-size: 13px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 13px;
		text-align: left;
		color: #fff;
	}
	
	#mcr_post01 .acf_text .text h3 img {
		display: block;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 15px;
		height: auto;
	}
	
	#mcr_post01 .acf_text .text .text_box {
		margin: 9px auto 25px auto;
	}
	
	#mcr_post01 .acf_text .text .text_box p {
		color: #fff;
	}
	
	#mcr_post01 .acf_img {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		position: relative;
		width: 340px;
		height: auto;
		margin: 30px auto 0 auto;
	}
	
	#mcr_post01 .acf_img img {
		display: block;
		position: relative;
		width: 165px;
		height: 102px;
		margin: 0 2.5px 5px 2.5px;
		object-fit: cover;
		object-position: center;
	}
	
	/*3つの良いところ*/
	#mcr_post02 {
		position: relative;
		width: 100%;
		height: auto;
		padding: 48px 0 45px 0;
		background: #E4F2D4;
	}
	
	#mcr_post02 h2 {
		position: relative;
		width: 370px;
		margin: 0 auto 30px auto;
		font-size: 16px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: center;
		color: #1E3C0D;
	}
	
	#mcr_post02 h2 big {
		position: relative;
		margin-right: 8px;
		font-size: 40px;
		line-height: 40px;
		color: #66AD47;
	}
	
	#mcr_post02 h2 font {
		display: block;
		position: relative;
		margin-bottom: 7px;
		font-size: 12px;
		letter-spacing: 1px;
		line-height: 12px;
	}
	
	#mcr_post02 h2::before,
	#mcr_post02 h2::after {
		content: "";
		position: absolute;
		top: 60%;
		transform: translateY(-50%) translateX(0);
		width: 80px;
		height: 12px;
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/mcr_post02_h2_smp.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		background-position: center;
	}
	
	#mcr_post02 h2::before {
		left: 0;
	}
	
	#mcr_post02 h2::after {
		right: 0;
	}
	
	#mcr_post02 .con {
		position: relative;
		width: 240px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_post02 .con .ptn {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 25px auto;
	}
	
	#mcr_post02 .con .ptn:nth-of-type(3) {
		margin-bottom: 0;
	}
	
	#mcr_post02 .con .ptn img {
		z-index: 0;
		display: block;
		position: relative;
		width: 100%;
		height: 160px;
		object-fit: cover;
		object-position: center;
	}
	
	#mcr_post02 .con .ptn h3 {
		display: table;
		position: relative;
		margin-top: -11px;
		padding: 5px 10px 5px 10px;
		font-size: 11px;
		font-family: "Raleway", sans-serif;
		font-weight: 600;
		letter-spacing: 1px;
		line-height: 11px;
		text-align: left;
		color: #fff;
		background: linear-gradient(45deg, #278F49, #66AD47);
	}
	
	#mcr_post02 .con .ptn h4 font {
		margin-top: 2.5px;
		display: table;
		padding: 5px 10px 6px 10px;
		font-size: 14px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 14px;
		text-align: left;
		color: #1E3C0D;
		background: #fff;
	}
	
	#mcr_post02 .con .ptn p {
		margin-top: 10px;
		color: #4E4E4E;
	}
	
	/*募集内容*/
	#mcr_post03 {
		position: relative;
		width: 350px;
		height: auto;
		margin: 50px auto 25px auto;
	}
	
	#mcr_post03 h2 {
		font-size: 16px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: center;
		color: #1E3C0D;
	}
	
	#mcr_post03 table {
		position: relative;
		width: 100%;
		height: auto;
		margin: 27px auto 0 auto;
		border-collapse: collapse;
	}
	
	#mcr_post03 table tr {
		
	}
	
	#mcr_post03 table tr th {
		display: block;
		position: relative;
		width: 100%;
		padding: 13px 0 13px 20px;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 12px;
		text-align: left;
		color: #fff;
		box-sizing: border-box;
		background: #278F49;
	}
	
	#mcr_post03 table tr td {
		display: block;
		position: relative;
		width: 100%;
		padding: 15px 20px 20px 20px;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 18px;
		text-align: left;
		color: #4E4E4E;
		box-sizing: border-box;
	}
	
	/*エントリーフォーム*/
	#mcr_entry {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 48px auto;
		padding: 45px 0 48px 0;
		background: #F4F4F4;
	}
	
	#mcr_entry .form {
		position: relative;
		width: 320px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#mcr_entry .form h2 {
		margin-bottom: 32px;
		font-size: 25px;
		font-family: "Raleway", sans-serif;
		font-weight: 600;
		letter-spacing: 2px;
		line-height: 25px;
		text-align: center;
		color: #66AD47;
	}
	
	#mcr_entry .form h2 span {
		display: block;
		position: relative;
		margin: 8px auto 0 auto;
		font-size: 13px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 13px;
		color: #1E3C0D;
	}
	
	#mcr_entry .form .cf7 table tr td font {
		display: block;
		position: relative;
		margin-bottom: 10px;
	}
}

/*
90.お知らせ＿一覧
91.お知らせ＿カテゴリ一覧
92.お知らせ＿個別
*/
/*PC*/
@media only screen and (min-width: 1025px) {
	main#news_list #common_mv .title {
		width: 1000px;
	}
	
	/*カテゴリー一覧*/
	#news_cat {
		position: relative;
		width: 100%;
		height: auto;
		margin: 95px auto 65px auto;
		padding: 60px 0 40px 0;
		background: #F4F4F4;
	}
	
	#news_cat ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		position: relative;
		width: 1000px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#news_cat ul li {
		list-style: none;
		display: block;
		position: relative;
		margin: 0 0 20px 0;
		padding: 10px 50px 10px 50px;
		box-sizing: border-box;
	}
	
	#news_cat ul li a {
		position: relative;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: left;
		color: #4E4E4E;
		transition: 0.2s;
	}
	
	#news_cat ul li::after {
		content: "";
		position: absolute;
		top: 50%;
		transform: translateY(-50%) translateX(0);
		width: 1px;
		height: 100%;
		background: #A7D095;
		transition: 0.2s;
	}
	
	#news_cat ul li::after {
		right: 0;
	}
	
	#news_cat ul li:nth-of-type(1)::before,
	#news_cat ul li:nth-of-type(6)::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 1px;
		height: 100%;
		background: #A7D095;
	}
	
	#news_cat ul li a.news_current {
		font-weight: 700;
		color: #66AD47;
	}
	
	#news_cat ul li a:hover {
		font-weight: 700;
		color: #66AD47;
	}
	
	#news_cat ul li a:hover::after {
		content: "";
		position: absolute;
		bottom: -1px;
		left: 0;
		width: 100%;
		height: 1px;
		background: #66AD47;
	}
	
	#news_cat ul li a.news_current::after {
		content: "";
		position: absolute;
		bottom: -1px;
		left: 0;
		width: 100%;
		height: 1px;
		background: #66AD47;
	}
	
	/*記事取得*/
	#news_loop {
		position: relative;
		width: 1000px;
		height: auto;
		margin: 0 auto 120px auto;
	}
	
	#news_loop .title {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 45px auto;
	}
	
	#news_loop .title h2 {
		position: relative;
		padding-left: 35px;
		font-size: 24px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 24px;
		text-align: left;
		color: #278F49;
	}
	
	#news_loop .title h2 img {
		display: block;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 25px;
		height: auto;
	}
	
	#news_loop .loop {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#news_loop .loop a {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: center;
		width: 100%;
		height: auto;
		margin: 0 auto 50px auto;
	}
	
	#news_loop .loop a:last-of-type {
		margin-bottom: 0;
	}
	
	#news_loop .loop a .img {
		position: relative;
		width: 130px;
		height: 90px;
		overflow: hidden;
	}
	
	#news_loop .loop a .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 90px;
		object-fit: cover;
		object-position: center;
		transition: 0.4s;
	}
	
	#news_loop .loop a .text {
		position: relative;
		width: 820px;
		height: auto;
		margin: 0 0 0 50px;
	}
	
	#news_loop .loop a .text p {
		margin-bottom: 22px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1.5px;
		line-height: 16px;
		text-align: left;
		color: #4E4E4E;
	}
	
	#news_loop .loop a .text p span {
		position: relative;
	}
	
	#news_loop .loop a .text p span::after {
		content: "";
		position: absolute;
		bottom: -1px;
		left: 0;
		width: 100%;
		height: 1px;
		background: #fff;
		transition: 0.2s;
	}
	
	#news_loop .loop a .text time {
		display: table;
		position: relative;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#news_loop .loop a .text font {
		position: absolute;
		bottom: 0;
		left: 140px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#news_loop .loop a:hover .img img {
		transform: scale(1.3);
	}
	
	#news_loop .loop a:hover .text p span::after {
		background: #4E4E4E;
	}
	
	#news_loop .pagination {
		margin-top: 60px;
	}
	
	/*記事個別*/
	#news_post {
		position: relative;
		width: 100%;
		height: auto;
		padding: 120px 0 120px 0;
	}
	
	#news_post .title {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: flex-start;
		position: relative;
		width: 950px;
		height: auto;
		margin: 0 auto 95px auto;
	}
	
	#news_post .title .text {
		position: relative;
		width: 630px;
		height: auto;
	}
	
	#news_post .title .text .cat {
		display: flex;
		flex-wrap: wrap;
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#news_post .title .text h1 {
		margin-bottom: 40px;
		font-size: 30px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 44px;
		text-align: left;
		color: #393939;
	}
	
	#news_post .title .text .cat font {
		display: block;
		position: relative;
		margin: 0 auto 0 0;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#news_post .title .text time {
		display: block;
		position: absolute;
		bottom: 0;
		right: 0;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: right;
		color: #8E8E8E;
	}
	
	#news_post .title .img {
		position: relative;
		width: 250px;
		height: 190px;
		overflow: hidden;
	}
	
	#news_post .title .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 190px;
		object-fit: cover;
		object-position: center;
	}
	
	#news_post .post {
		position: relative;
		width: 950px;
		height: auto;
		margin: 0 auto 100px auto;
	}
	
	#news_post .post p {
		font-size: 16px;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 26px;
		text-align: left;
		color: #4E4E4E;
	}
	
	#news_post .post div.h2_top {
		margin-top: 50px;
	}
	
	#news_post .post h2 {
		display: inline;
		position: relative;
		margin: 50px 0 50px 0;
		padding-bottom: 5px;
		font-size: 23px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 43px;
		text-align: left;
		color: #278F49;
		border-bottom: dashed 1px #707070;
	}
	
	#news_post .post h3,
	#news_post .post h4 {
		display: table;
		position: relative;
		padding-left: 25px;
		margin: 30px 0 25px 0;
		font-size: 18px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight:500;
		letter-spacing: 1px;
		line-height: 28px;
		text-align: left;
		color: #1E3C0D;
	}
	
	#news_post .post h3::before,
	#news_post .post h4::before {
		content: "";
		position: absolute;
		top: 10px;
		left: 0;
		width: 10px;
		height: 10px;
		border-radius: 100px;
		background: #99C267;
	}
	
	#news_post .post img {
		display: block;
		position: relative;
		margin: 30px auto 30px 0;
		width: auto;
		height: auto;
		object-fit: cover;
		object-position: center;
	}
	
	#news_post .post iframe {
		display: block;
		position: relative;
		width: 600px;
		height: 340px;
		margin: 30px auto 30px 0;
	}
	
	/*前後記事*/
	.post_nav {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	.post_nav::before {
		content: "";
		z-index: -1;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: #F2F2F2;
	}
	
	.post_nav .btn {
		display: block;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		width: 100px;
		height: auto;
		padding: 42px 0 0 0;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: center;
		color: #278F49;
		transition: 0.2s;
	}
	
	.post_nav .btn::before {
		content: "";
		position: absolute;
		top: 0;
		left: 50%;
		transform: translateY(0) translateX(-50%);
		width: 28px;
		height: 28px;
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/dot_before.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		background-position: center;
		transition: 0.2s;
	}
	
	.post_nav .btn:hover {
		opacity: 0.5;
	}
	
	.post_nav .con {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		position: relative;
		width: 1200px;
		height: 100px;
		margin: 0 auto 0 auto;
		padding: 80px 0 80px 0;
	}
	
	.post_nav .con a {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: center;
		position: relative;
		width: 490px;
		height: auto;
	}
	
	.post_nav .con a .img {
		position: relative;
		width: 140px;
		height: 100px;
		overflow: hidden;
	}
	
	.post_nav .con a .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 100px;
		object-fit: cover;
		object-position: center;
		transition: 0.3s;
	}
	
	.post_nav .con a .text {
		position: relative;
		width: 330px;
		height: auto;
	}
	
	.post_nav .con a .text h4 {
		position: relative;
		margin-bottom: 18px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		color: #278F49;
	}
	
	.post_nav .con a .text h4 img {
		position: absolute;
		top: 50%;
		transform: translateY(-50%) translateX(0);
		width: 12px;
		height: auto;
	}
	
	.post_nav .con a.prevpost {
		flex-direction: row;
	}
	
	.post_nav .con a.prevpost .text h4 {
		padding-left: 32px;
		text-align: left;
	}
	
	.post_nav .con a.prevpost .text h4 img {
		left: 0;
	}
	
	.post_nav .con a.nextpost {
		position: absolute;
		top: 50%;
		transform: translateY(-50%) translateX(0);
		left: 700px;
		flex-direction: row-reverse;
	}
	
	.post_nav .con a.nextpost .text h4 {
		padding-right: 32px;
		text-align: right;
	}
	
	.post_nav .con a.nextpost .text h4 img {
		right: 0;
	}
	
	.post_nav .con a:hover .text p {
		text-decoration: underline;
	}
	
	.post_nav .con a:hover .img img {
		transform: scale(1.3);
	}
}

/*SMP*/
@media only screen and (max-width: 1024px) {
	main#news_list #common_mv .title {
		width: 300px;
	}
	
	/*カテゴリー一覧*/
	#news_cat {
		position: relative;
		width: 100%;
		height: auto;
		margin: 40px auto 50px auto;
		padding: 42px 0 25px 0;
		background: #F4F4F4;
	}
	
	#news_cat ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		position: relative;
		width: 330px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#news_cat ul li {
		list-style: none;
		display: block;
		position: relative;
		margin: 0 0 17px 0;
		padding: 3px 24px 3px 24px;
		line-height: 12px;
		box-sizing: border-box;
	}
	
	#news_cat ul li a {
		position: relative;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 12px;
		text-align: left;
		color: #4E4E4E;
	}
	
	#news_cat ul li::after {
		content: "";
		position: absolute;
		top: 50%;
		transform: translateY(-50%) translateX(0);
		width: 1px;
		height: 100%;
		background: #A7D095;
	}
	
	#news_cat ul li::after {
		right: 0;
	}
	
	#news_cat ul li:nth-of-type(1)::before,
	#news_cat ul li:nth-of-type(4)::before,
	#news_cat ul li:nth-of-type(6)::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 1px;
		height: 100%;
		background: #A7D095;
	}
	
	#news_cat ul li a.news_current {
		font-weight: 700;
		color: #66AD47;
	}
	
	#news_cat ul li a.news_current::after {
		content: "";
		position: absolute;
		bottom: -1px;
		left: 0;
		width: 100%;
		height: 1px;
		background: #66AD47;
	}
	
	/*記事取得*/
	#news_loop {
		position: relative;
		width: 350px;
		height: auto;
		margin: 0 auto 46px auto;
	}
	
	#news_loop .title {
		position: relative;
		width: 320px;
		height: auto;
		margin: 0 auto 32px auto;
	}
	
	#news_loop .title h2 {
		position: relative;
		padding-left: 17px;
		font-size: 15px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 15px;
		text-align: left;
		color: #278F49;
	}
	
	#news_loop .title h2 img {
		display: block;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 12px;
		height: auto;
	}
	
	#news_loop .loop {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#news_loop .loop a {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: center;
		width: 100%;
		height: auto;
		margin: 0 auto 30px auto;
	}
	
	#news_loop .loop a:last-of-type {
		margin-bottom: 0;
	}
	
	#news_loop .loop a .img {
		position: relative;
		width: 95px;
		height: 65px;
		overflow: hidden;
	}
	
	#news_loop .loop a .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 65px;
		object-fit: cover;
		object-position: center;
	}
	
	#news_loop .loop a .text {
		position: relative;
		width: 240px;
		height: auto;
	}
	
	#news_loop .loop a .text p {
		margin-bottom: 12px;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 18px;
		text-align: left;
		color: #4E4E4E;
	}
	
	#news_loop .loop a .text p span {
		position: relative;
	}
	
	#news_loop .loop a .text time {
		display: table;
		position: relative;
		font-size: 11px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 0.5px;
		line-height: 11px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#news_loop .loop a .text font {
		position: absolute;
		bottom: 0;
		left: 85px;
		font-size: 11px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 400;
		letter-spacing: 0.5px;
		line-height: 11px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#news_loop .pagination {
		margin-top: 36px;
	}
	
	/*記事個別*/
	#news_post {
		position: relative;
		width: 100%;
		height: auto;
		padding: 35px 0 45px 0;
	}
	
	#news_post .title {
		position: relative;
		width: 320px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#news_post .title .text {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#news_post .title .text h1 {
		margin-bottom: 20px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 26px;
		text-align: left;
		color: #1E3C0D;
	}
	
	#news_post .title .text .cat {
		display: flex;
		flex-wrap: wrap;
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#news_post .title .text .cat font {
		display: block;
		position: relative;
		margin: 0 auto 0 0;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 12px;
		text-align: left;
		color: #8E8E8E;
	}
	
	#news_post .title .text time {
		display: block;
		position: absolute;
		bottom: 0;
		right: 0;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 12px;
		text-align: right;
		color: #8E8E8E;
	}
	
	#news_post .title .img {
		position: relative;
		width: 200px;
		height: 150px;
		margin: 30px auto 0 0;
		overflow: hidden;
	}
	
	#news_post .title .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 150px;
		object-fit: cover;
		object-position: center;
	}
	
	#news_post .post {
		position: relative;
		width: 320px;
		height: auto;
		margin: 45px auto 46px auto;
	}
	
	#news_post .post p {
		font-size: 12px;
		font-weight: 400;
		letter-spacing: 1px;
		line-height: 18px;
		text-align: left;
		color: #4E4E4E;
	}
	
	#news_post .post div.h2_top {
		margin-top: 20px;
	}
	
	#news_post .post h2 {
		display: inline;
		position: relative;
		margin: 20px 0 25px 0;
		padding-bottom: 3px;
		font-size: 15px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 30px;
		text-align: left;
		color: #278F49;
		border-bottom: dashed 1px #707070;
	}
	
	#news_post .post h3,
	#news_post .post h4 {
		display: table;
		position: relative;
		padding-left: 13px;
		margin: 20px 0 20px 0;
		font-size: 13px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 18px;
		text-align: left;
		color: #1E3C0D;
	}
	
	#news_post .post h3::before,
	#news_post .post h4::before {
		content: "";
		position: absolute;
		top: 7px;
		left: 0;
		width: 5px;
		height: 5px;
		border-radius: 100px;
		background: #99C267;
	}
	
	#news_post .post img {
		display: block;
		position: relative;
		margin: 20px auto 20px 0;
		width: auto;
		height: auto;
		object-fit: cover;
		object-position: center;
	}
	
	#news_post .post iframe {
		display: block;
		position: relative;
		width: 100%;
		height: 200px;
		margin: 20px auto 20px 0;
	}
	
	/*前後記事*/
	.post_nav {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
		padding: 0 0 0 0;
	}
	
	.post_nav .btn {
		display: block;
		position: relative;
		width: 100px;
		height: auto;
		margin: 33px auto 0 auto;
		font-size: 13px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 13px;
		text-align: right;
		color: #278F49;
	}
	
	.post_nav .btn::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) translateX(0);
		width: 14px;
		height: 14px;
		background-image: url(/wp-content/themes/cf_originaltheme/images/post/dot_before.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		background-position: center;
	}
	
	.post_nav .con {
		position: relative;
		width: 320px;
		height: auto;
		margin: 0 auto 0 auto;
		padding: 30px 0 10px 0;
	}
	
	.post_nav .con::before {
		content: "";
		z-index: -1;
		position: absolute;
		top: 0;
		left: -100%;
		width: 1500%;
		height: 100%;
		background: #F2F2F2;
	}
	
	.post_nav .con a {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: center;
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 20px auto;
	}
	
	.post_nav .con a .img {
		position: relative;
		width: 82px;
		height: 62px;
		overflow: hidden;
	}
	
	.post_nav .con a .img img {
		display: block;
		position: relative;
		width: 100%;
		height: 62px;
		object-fit: cover;
		object-position: center;
	}
	
	.post_nav .con a .text {
		position: relative;
		width: 220px;
		height: auto;
	}
	
	.post_nav .con a .text h4 {
		position: relative;
		margin-bottom: 9px;
		font-size: 12px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 12px;
		color: #278F49;
	}
	
	.post_nav .con a .text h4 img {
		position: absolute;
		top: 50%;
		transform: translateY(-50%) translateX(0);
		width: 9px;
		height: auto;
	}
	
	.post_nav .con a.prevpost {
		flex-direction: row;
	}
	
	.post_nav .con a.prevpost .text h4 {
		padding-left: 20px;
		text-align: left;
	}
	
	.post_nav .con a.prevpost .text h4 img {
		left: 0;
	}
	
	.post_nav .con a.nextpost .text h4 {
		text-align: left;
	}
	
	.post_nav .con a.nextpost .text h4 img {
		left: 63px;
	}
	
}

/*ページネーション*/
/*PC*/
@media only screen and (min-width: 1025px) {
	.pagination {
		display: table;
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
		text-align: center;
	}
		
	.pagination ul {
		display: inline-block;
		width: auto;
		height: auto;
		margin: 0 auto;
	}
		
	.pagination ul li {
		list-style: none;
		float: left;
	}
	
	.pagination ul li a {
		display: block;
		position: relative;
		width: auto;
		height: auto;
		margin: 0 20px 0 20px;
		font-size: 24px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 700;
		line-height: 24px;
		text-align: center;
		color: #B9B9B9;
		transition: 0.3s;
	}
	
	.pagination ul li a:hover {
		color: #66AD47;
		text-decoration: underline;
	}

	.pagination span {
		display: block;
		position: relative;
		width: auto;
		height: auto;
		margin: 0 20px 0 20px;
		font-size: 24px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 700;
		line-height: 24px;
		text-align: center;
		color: #66AD47;
		transition: 0.3s;
	}
		
	.pagination span.current {
		color: #66AD47;
		text-decoration: underline;
	}
	
	.pagination .prev {
		display: none;
	}
	
	.pagination .next {
		display: none;
	}
	
}
	
/*SMP*/
@media only screen and (max-width: 1024px) {
	.pagination {
		display: table;
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
		text-align: center;
	}
		
	.pagination ul {
		display: inline-block;
		width: auto;
		height: auto;
		margin: 0 auto;
	}
		
	.pagination ul li {
		list-style: none;
		float: left;
	}
	
	.pagination ul li a {
		display: block;
		position: relative;
		width: auto;
		height: auto;
		margin: 0 15px 0 15px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 700;
		line-height: 16px;
		text-align: center;
		color: #B9B9B9;
	}
	
	.pagination span {
		display: block;
		position: relative;
		width: auto;
		height: auto;
		margin: 0 15px 0 15px;
		font-size: 16px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 700;
		line-height: 16px;
		text-align: center;
		color: #66AD47;
	}
		
	.pagination span.current {
		color: #66AD47;
		text-decoration: underline;
	}
	
	.pagination .prev {
		display: none;
	}
	
	.pagination .next {
		display: none;
	}
	

}

/*100.お問い合わせ*/
/*PC*/
@media only screen and (min-width: 1025px) {
	#contact {
		position: relative;
		width: 100%;
		height: auto;
		margin: 90px auto 120px auto;
	}
	
	#contact .t_text {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#contact .t_text p {
		text-align: center;
	}
	
	#contact .tel {
		position: relative;
		width: 100%;
		height: auto;
		margin: 100px auto 0 auto;
		padding: 90px 0 80px 0;
		background: #F7F7F7;
	}
	
	#contact .tel .text {
		position: relative;
		width: 500px;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#contact .tel .text h2 {
		margin-bottom: 30px;
		font-size: 30px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 30px;
		text-align: center;
	}
	
	#contact .tel .text p {
		text-align: center;
	}
	
	#contact .tel .text a {
		display: block;
		position: relative;
		margin: 42px auto 13px auto;
		font-size: 52px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 52px;
		text-align: center;
		color: #278F49;
	}
	
	#contact .tel .text a font {
		position: relative;
	}
	
	#contact .tel .text a img {
		display: block;
		position: absolute;
		top: 25px;
		left: -50px;
		width: 39px;
		height: auto;
	}
	
	#contact .form {
		position: relative;
		width: 1000px;
		height: auto;
		margin: 100px auto 0 auto;
	}
	
	#contact .form .text {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 30px auto;
	}
	
	#contact .form .text h2 {
		margin-bottom: 45px;
		font-size: 30px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 30px;
		text-align: left;
		color: #1E3C0D;
	}
	
}

/*SMP*/
@media only screen and (max-width: 1024px) {
	#contact {
		position: relative;
		width: 100%;
		height: auto;
		margin: 45px auto 50px auto;
	}
	
	#contact .t_text {
		position: relative;
		width: 100%;
		height: auto;
	}
	
	#contact .t_text p {
		text-align: center;
	}
	
	#contact .tel {
		position: relative;
		width: 100%;
		height: auto;
		margin: 50px auto 0 auto;
		padding: 50px 0 45px 0;
		background: #F7F7F7;
	}
	
	#contact .tel .text {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#contact .tel .text h2 {
		margin-bottom: 22px;
		font-size: 16px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: center;
	}
	
	#contact .tel .text p {
		text-align: center;
	}
	
	#contact .tel .text a {
		display: block;
		position: relative;
		margin: 32px auto 7px auto;
		font-size: 31px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 31px;
		text-align: center;
		color: #278F49;
	}
	
	#contact .tel .text a font {
		position: relative;
	}
	
	#contact .tel .text a img {
		display: block;
		position: absolute;
		top: 15px;
		left: -32px;
		width: 25px;
		height: auto;
	}
	
	#contact .form {
		position: relative;
		width: 350px;
		height: auto;
		margin: 50px auto 0 auto;
	}
	
	#contact .form .text {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 30px auto;
	}
	
	#contact .form .text h2 {
		margin-bottom: 32px;
		font-size: 16px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 16px;
		text-align: center;
		color: #1E3C0D;
	}
}

/*
71.新卒採用情報_サンクスページ
83.中途採用情報＿サンクスページ
101.お問い合わせ＿サンクスページ
*/
/*PC*/
@media only screen and (min-width: 1025px) {
	#thanks {
		position: relative;
		width: 100%;
		height: auto;
		margin: 170px auto 260px auto;
	}
	
	#thanks .title {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 65px auto;
	}
	
	#thanks .title h1 {
		font-size: 50px;
		font-family: "Raleway", sans-serif;
		font-weight: 600;
		letter-spacing: 6px;
		line-height: 50px;
		color: #66AD47;
		text-align: center;
	}
	
	#thanks .title p {
		margin-top: 20px;
		font-size: 24px;
		font-weight: 500;
		letter-spacing: 3px;
		line-height: 24px;;
		color: #1E3C0D;
		text-align: center;
	}
	
	#thanks .text {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#thanks .text p {
		line-height: 32px;
		text-align: center;
	}
	
	#thanks .text p a {
		color: #4E4E4E;
	}
	
}

/*SMP*/
@media only screen and (max-width: 1024px) {
	#thanks {
		position: relative;
		width: 100%;
		height: auto;
		margin: 95px auto 100px auto;
	}
	
	#thanks .title {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 32px auto;
	}
	
	#thanks .title h1 {
		font-size: 25px;
		font-family: "Raleway", sans-serif;
		font-weight: 600;
		letter-spacing: 3px;
		line-height: 25px;
		color: #66AD47;
		text-align: center;
	}
	
	#thanks .title p {
		margin-top: 10px;
		font-size: 13px;
		font-weight: 500;
		letter-spacing: 2px;
		line-height: 13px;;
		color: #1E3C0D;
		text-align: center;
	}
	
	#thanks .text {
		position: relative;
		width: 100%;
		height: auto;
		margin: 0 auto 0 auto;
	}
	
	#thanks .text p {
		line-height: 22px;
		text-align: center;
	}
	
	#thanks .text p a {
		color: #4E4E4E;
	}
	
}

/*110.個人情報保護方針*/
/*PC*/
@media only screen and (min-width: 1025px) {
	/*メインビジュアル*/
	#pri_mv {
		position: relative;
		width: 100%;
		height: 320px;
	}
	
	#pri_mv .title {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		width: 100%;
		height: auto;
	}
	
	#pri_mv .title p {
		margin-bottom: 20px;
		font-size: 50px;
		font-family: "Raleway", sans-serif;
		font-weight: 600;
		letter-spacing: 6px;
		line-height: 50px;
		color: #66AD47;
		text-align: center;
	}
	
	#pri_mv .title h1 {
		font-size: 24px;
		font-weight: 500;
		letter-spacing: 3px;
		line-height: 24px;;
		color: #1E3C0D;
		text-align: center;
	}
	
	/*コンテンツ*/
	#pri {
		position: relative;
		width: 980px;
		height: auto;
		margin: 0 auto 120px auto;
	}
	
	#pri .text {
		position: relative;
		width: 100%;
		height: auto;
		margin: 40px auto 0 auto;
	}
	
	#pri .text:nth-of-type(1) {
		margin-top: 50px;
	}
	
	#pri .text h2 {
		margin-bottom: 25px;
		font-size: 20px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 20px;
		text-align: left;
		color: #278F49;
	}
	
}

/*SMP*/
@media only screen and (max-width: 1024px) {
	/*メインビジュアル*/
	#pri_mv {
		position: relative;
		width: 100%;
		height: 144px;
	}
	
	#pri_mv .title {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		width: 100%;
		height: auto;
	}
	
	#pri_mv .title p {
		margin-bottom: 9px;
		font-size: 25px;
		font-family: "Raleway", sans-serif;
		font-weight: 600;
		letter-spacing: 3px;
		line-height: 25px;
		color: #66AD47;
		text-align: center;
	}
	
	#pri_mv .title h1 {
		font-size: 13px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 13px;;
		color: #1E3C0D;
		text-align: center;
	}
	
	/*コンテンツ*/
	#pri {
		position: relative;
		width: 350px;
		height: auto;
		margin: 0 auto 45px auto;
	}
	
	#pri .text {
		position: relative;
		width: 100%;
		height: auto;
		margin: 25px auto 0 auto;
	}
	
	#pri .text:nth-of-type(1) {
		margin-top: 30px;
	}
	
	#pri .text h2 {
		margin-bottom: 12px;
		font-size: 14px;
		font-weight: 500;
		letter-spacing: 1px;
		line-height: 14px;
		text-align: left;
		color: #278F49;
	}
	

}