@import "default.css";
@import "standard.css";

body {
	width: 100%;
	margin: 0;
	padding: 0;
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo, Osaka", "MS P ゴシック", "MS P Gothic", "sans-Serif";
	font-size: 16px;
	color: #333333;
	-webkit-text-size-adjust: none;
}
a:hover {
	opacity: .7;
}
img {
	width: 100%;
	height: auto;
}
a {
	text-decoration: none;
}
* {
	box-sizing: border-box;
}
/* スタイル
------------------------------------------------ */
header {
	width: 100%;
	position: relative;
}
header:after {
	content: "";
	width: 58%;
	max-width: 1100px;
	height: 8px;
	background: linear-gradient(to right, #27C068, #fff);
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
}
header .inbox {
	width: 96%;
	max-width: 1750px;
	margin: 0 auto;
	padding: 25px 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
header h1 {
	font-size: 30px;
	font-weight: bold;
	color: #40CAA9;
}
header h1 img {
	width: 110px;
	margin-right: 20px;
}
/* フッター */
#banner .flex {
	width: 96%;
	margin: 100px auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 40px;
}
#banner .flex a {
	flex: 1;
	max-width: 580px;
	min-width: 450px;
	aspect-ratio: 29 / 8;
	padding: 0 60px;
	background: url(/image/top/banner_saiyo.png) right center no-repeat,#9AE3D1;
	background-size: contain,auto;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
#banner .flex a.contact {
	background: url(/image/top/banner_contact.png) right center no-repeat,#9AE3D1;
	background-size: contain,auto;
}
#banner .flex dt {
	margin-bottom: 15px;
	font-size: 32px;
	font-weight: bold;
	color: #fff;
	text-shadow: 3px 3px 3px #39AF92, -3px -3px 3px #39AF92, -3px 3px 3px #39AF92, 3px -3px 3px #39AF92, 3px 0px 3px #39AF92, -3px -0px 3px #39AF92, 0px 3px 3px #39AF92, 0px -3px 3px #39AF92;
}
#banner .flex dd {
	font-family: 'Sawarabi Mincho', serif;
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	color: #000;
}
footer {
	padding: 60px 0;
	background: #EEFCF8;
	position: relative;
}
footer::before {
	content: "";
	width: 100%;
	height: 8px;
	background: linear-gradient(to right, #27C068, #84DDC8);
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}
.footer_nav {
	margin-bottom: 60px;
}
.footer_nav > ul {
	width: 96%;
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}
.footer_nav > ul > li {
	min-width: 180px;
	margin: 0 10px;
}
.footer_nav h3 {
	margin-bottom: 10px;
	padding-bottom: 8px;
	border-bottom: 1px #008F6D solid;
	font-size: 16px;
	font-weight: bold;
}
.footer_nav h3.top {
	margin-bottom: 60px;
}
.footer_nav h3 a {
	color: #008F6D;
}
.footer_nav ul ul li {
	margin: 8px 0;
}
.footer_nav ul ul li a {
	font-size: 14px;
	color: #000;
}
.footer_nav ul ul li.h3title {
	margin-bottom: 10px;
	padding-bottom: 8px;
	border-bottom: 1px #008F6D solid;
	font-size: 16px;
	font-weight: bold;
}
.footer_nav ul ul li.h3title a {
	color: #008F6D;
}
footer .company {
	max-width: 1200px;
	margin: 0 auto;
	margin-bottom: 30px;
	padding: 20px 0;
	border-top: 1px #008F6D solid;
	border-bottom: 1px #008F6D solid;
	display: flex;
	align-items: center;
	gap: 60px;
}
footer .company .logo {
	display: flex;
	align-items: center;
	gap: 20px;
}
footer .company .logo .img {
	width: 110px;
}
footer .company .logo li {
	font-size: 30px;
	color: #40CAA9;
}
footer .company .name {
	margin-bottom: 10px;
}
footer .company a {
	color: #000;
}
#fixedTop {
	right: 30px;
	bottom: 30px;
	width: 45px;
	height: 45px;
	border-radius: 50%;
	line-height: 42px;
	color: #fff;
	font-size: 20px;
	text-align: center;
	display: none;
	background: #000;
	position: fixed;
	z-index: 9999;
}
footer .copyright {
	font-size: 12px;
	color: #40CAA9;
	text-align: center;
	letter-spacing: 0.14rem;
}
/* ナビ部分
------------------------------------------------ */
header nav {
	width: 54%;
	min-width: 750px;
}
header nav ul {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
header nav li:before {
	content: "";
	width: 1px;
	height: 50px;
	transform:rotate(30deg);
	background: #27C068;
	display: block;
}
header nav li:last-of-type::after {
	content: "";
	width: 1px;
	height: 50px;
	transform:rotate(30deg);
	background: #27C068;
	display: block;
}
header nav li {
	flex: 1;
	display: flex;
	align-items: center;
}
header nav li a {
	padding-top: 10px;
	flex: 1;
	font-size: 18px;
	font-weight: bold;
	color: #000;
	text-decoration: none;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
#p_top header nav li.top a,
#p_company header nav li.company a,
#p_overview header nav li.overview a,
#p_product header nav li.product a,
#p_contact header nav li.contact a,
#p_recruitment header nav li.recruitment a {
	color: #008F6D;
}
header nav li a span {
	font-size: 14px;
	font-weight: normal;
	color: #40CAA9;
	letter-spacing: 0.075rem;
}
/* モーダルメニュー */
#nav_wrap_sp {
	display: none;
}
.clone-nav {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 2;
	width: 100%;
	background: rgba(255, 255, 255, 0.9);
	transition: .3s;
	transform: translateY(-100%);
}
.is-show {
	transform: translateY(0);
}
/* パンくずリスト
------------------------------------------------ */
#rootlist {
	max-width: 1550px;
	min-width: 900px;
	width: 96%;
	margin: 20px auto 60px;
	padding: 0 10px;
	font-size: 12px;
}
#rootlist span {
	margin: 0 5px;
	color: #000;
}
#rootlist p {
	color: #000;
}
#rootlist a {
	color: #008F6D;
	text-decoration: none;
}
#rootlist a:hover {
	text-decoration: underline;
}
/* Hタグ
------------------------------------------------ */
h2.title {
	padding: 80px 0 60px;
	background: url(/image/common/bg_h2.jpg) center no-repeat;
	background-size: cover;
}
h2.title span {
	width: 96%;
	max-width: 1550px;
	margin: 0 auto;
	font-size: 36px;
	font-weight: bold;
	color: #18AB89;
	text-shadow: 3px 3px 3px #fff, -3px -3px 3px #fff, -3px 3px 3px #fff, 3px -3px 3px #fff, 3px 0px 3px #fff, -3px -0px 3px #fff, 0px 3px 3px #fff, 0px -3px 3px #fff;
	display: block;
}
h2.title span em {
	margin-top: 8px;
	padding: 0 10px;
	font-size: 16px;
	font-weight: normal;
	color: #008F6D;
	text-shadow: none;
	letter-spacing: 0.1rem;
	display: block;
}
h3.title {
	margin-bottom: 70px;
	font-size: 26px;
	font-weight: bold;
	text-align: center;
	position: relative;
}
h3.title::after {
	content: "";
	width: 300px;
	height: 6px;
	background: linear-gradient(to right, #27C068, #fff);
	display: block;
	position: absolute;
	bottom: -15px;
	left: calc( 50% + 20px);
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
}
h3.title2 {
	margin: 0 auto;
	margin-bottom: 70px;
	font-size: 26px;
	font-weight: bold;
	color: #008F6D;
	text-align: center;
	position: relative;
	display: block;
}
h3.title2:before {
	content: '';
	position: absolute;
	bottom: -15px;
	display: inline-block;
	width: 50px;
	height: 3px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	background-color: #008F6D;
	border-radius: 2px;
}
h3.cname {
	width: 96%;
	max-width: 1100px;
	height: 70px;
	margin: 0 auto;
	margin-bottom: 80px;
	border: 1px #D9D9D9 solid;
	font-size: 28px;
	font-weight: bold;
	color: #008F6D;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}
h3.cname:before {
	content: "";
	width: 100px;
	height: 60px;
	background: #008F6D;
	clip-path: polygon(0 0, 0% 100%, 100% 0);
	display: block;
	position: absolute;
	top: -6px;
	left: -6px;
}
h3.cname:after {
	content: "";
	width: 100px;
	height: 60px;
	background: #40CAA9;
	clip-path: polygon(0 100%, 100% 100%, 100% 0);
	display: block;
	position: absolute;
	bottom: -6px;
	right: -6px;
}
h4.d_circle {
	margin-bottom: 20px;
	font-size: 24px;
	font-weight: bold;
	color: #008F6D;
}
h4.d_circle:before {
	content: "◎";
}
/* 共通
------------------------------------------------ */
#contents {
	margin-bottom: 260px;
}
#contents p {
	margin-bottom: 20px;
	line-height: 1.6em;
}
#contents p:last-child {
	margin-bottom: 0;
}
.cbox {
	max-width: 1100px;
	min-width: 960px;
	width: 96%;
	margin: 0 auto 160px;
	box-sizing: border-box;
}
.cbox_m0 {
	max-width: 1100px;
	min-width: 960px;
	width: 96%;
	margin: 0 auto;
	box-sizing: border-box;
}
.cbox_s {
	max-width: 1040px;
	min-width: 900px;
	width: 94%;
	margin: 0 auto 140px;
	box-sizing: border-box;
}
.cbox_s_m0 {
	max-width: 1040px;
	min-width: 900px;
	width: 94%;
	margin: 0 auto;
	box-sizing: border-box;
}
.inbox {
	margin: 0 auto 80px;
	padding: 0 10px;
	box-sizing: border-box;
}
.wp-pagenavi {
	max-width: 980px;
	min-width: 880px;
	margin: 0 auto;
}
br.sp {
	display: none;
}
.pc_none {
	display: none;
}
.nowrap {
	white-space: nowrap;
}
.intro_text {
	margin-bottom: 100px;
}
.intro_text.m60 {
	margin-bottom: 60px;
}
.intro_btext {
	margin-bottom: 120px !important;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}
#features .flex {
	width: 96%;
	max-width: 1490px;
	min-width: 960px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	gap: 40px 10px;
}
#features .flex div.box {
	width: 365px;
	background: #fff;
	box-shadow: 0 0 6px rgba(0, 0, 0, .16);
	position: relative;
}
#features .flex div.box:before {
	content: "";
	width: 46px;
	height: 40px;
	background: #008F6D;
	clip-path: polygon(0 0, 50% 100%, 100% 0);
	display: block;
	position: absolute;
	top: -16px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
}
#features .flex a {
	width: 100%;
	height: 100%;
	padding: 40px 15px;
	padding-bottom: 20px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	position: relative;
}
#features .flex a:after {
	content: "";
	width: 100%;
	height: 4px;
	background: linear-gradient(to right, #27C068, #fff);
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
}
#features .flex a dl {
	color: #000;
}
#features .flex a dt {
	min-height: 60px;
	margin-bottom: 10px;
	font-size: 23px;
	font-weight: bold;
	text-align: center;
	line-height: 1.2;
	display: flex;
	justify-content: center;
	align-items: center;
}
#features .flex a .catch {
	font-size: 25px;
	font-weight: bold;
	color: #008F6D;
	text-align: center;
}
#features .flex a .img {
	margin-bottom: 20px;
}
#features .flex a ul {
	margin-top: auto;
	margin-bottom: 0;
	padding-top: 30px;
	font-weight: bold;
	color: #008F6D;
	text-align: center;
}
#list ul.link_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 30px 20px;
}
#list ul.link_list li {
	width: calc(( 100% - 20px) / 2);
	max-width: 500px;
	height: 100px;
}
#list ul.link_list li a {
	width: 100%;
	height: 100%;
	padding: 0 30px;
	background: url(/image/common/icon/arrow_red.svg) right 30px center no-repeat;
	background-size: 8px;
	border: 1px #008F6D solid;
	font-weight: bold;
	color: #008F6D;
	text-decoration: none;
	display: flex;
	align-items: center;
	gap: 20px;
}
#list ul.link_list li a i {
	width: 16px;
	height: 16px;
}
/* トップページ
------------------------------------------------ */
#p_top #main #mainimage .bg_wrap {
	min-width: 980px;
	height: 700px;
	background: url(/image/top/bg_main.webp) center no-repeat;
	background-size: cover;
}
#p_top #main .catchcopy {
	width: 100%;
	max-width: 1730px;
	height: 700px;
	margin: 0 auto;
	padding: 80px 40px;
	background: url(/image/top/bg_girl.webp) left 880px center no-repeat;
	background-size: 840px;
}
#p_top #main h2 {
	margin-bottom: 60px;
	font-family: "Source Serif 4", serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 500;
	font-size: 136px;
	color: #18AB89;
	text-shadow: 3px 3px 3px #fff, -3px -3px 3px #fff, -3px 3px 3px #fff, 3px -3px 3px #fff, 3px 0px 3px #fff, -3px -0px 3px #fff, 0px 3px 3px #fff, 0px -3px 3px #fff;
	line-height: 1.2;
}
#p_top #main h3 {
	margin-left: 20px;
	font-family: 'Sawarabi Mincho', serif;
	font-weight: 400;
	font-style: normal;
	font-size: 60px;
	color: #fff;
	text-shadow: 3px 3px 3px #166B68, -3px -3px 3px #166B68, -3px 3px 3px #166B68, 3px -3px 3px #166B68, 3px 0px 3px #166B68, -3px -0px 3px #166B68, 0px 3px 3px #166B68, 0px -3px 3px #166B68;
	line-height: 1.6;
}
#p_top #main #features .relative {
	position: relative;
}
#p_top #main #features .flex {
	position: absolute;
	top: -70px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
}
#p_top #main p.point {
	margin-top: 480px;
	margin-bottom: 60px;
	font-family: 'Sawarabi Mincho', serif;
	font-weight: 400;
	font-style: normal;
	font-size: 34px;
	color: #008F6D;
	text-align: center;
	line-height: 1.6;
}
#p_top #main p.point i {
	width: 68px;
	height: 98px;
	margin: 0 auto;
	margin-bottom: 20px;
	display: block;
}
#p_top #post_part .bg_wrap {
	margin-bottom: 100px;
	padding: 80px 0;
	background: url(/image/common/block/block_white90.png),url(/image/top/bg_post.webp) center no-repeat;
	background-size: auto,cover;
}
#p_top #post_part .picup,
#p_top #post_part .news {
	width: 96%;
	max-width: 1200px;
	margin: 0 auto;
	border: 1px #008F6D solid;
	display: flex;
}
#p_top #post_part .picup {
	margin-bottom: 60px;
}
#p_top #post_part .picup h2,
#p_top #post_part .news h2 {
	width: 300px;
	min-width: 300px;
	min-height: 300px;
	background: url(/image/common/block/sankaku_green.svg) right bottom no-repeat,#23A47C;
	font-size: 32px;
	font-weight: bold;
	color: #FFFFFF;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
#p_top #post_part .picup h2 span,
#p_top #post_part .news h2 span {
	font-size: 16px;
	color: #C1FFF0;
	display: block;
}
#p_top #post_part .r_wrap {
	padding: 60px 40px;
	background: #fff;
	flex: 1;
}
#p_top #post_part .picup .r_wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 40px;
}
#p_top #post_part .picup ul {
	width: 240px;
}
#p_top #post_part .picup dl {
	flex: 1;
	min-width: 350px;
}
#p_top #post_part .picup dt {
	margin-bottom: 20px;
	font-size: 18px;
	font-weight: bold;
	color: #008F6D;
}
#p_top #post_part .picup dd a {
	margin-top: 20px;
	font-size: 14px;
	color: #008F6D;
	display: block;
}
#p_top #post_part .picup dd a i {
	width: 10px;
	height: 10px;
	margin-right: 5px;
	color: #FF0000;
	display: inline-block;
}
#p_top #post_part .news .r_wrap {
	position: relative;
}
.log dl {
	padding: 20px 0;
	border-bottom: 1px #D9D9D9 solid;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 0;
}
.log dl:first-of-type {
	padding-top: 0;
}
.log dl:last-of-type {
	margin-bottom: 0;
}
.log dt {
	width: 136px;
	color: #348F7A;
}
.log dd {
	flex: 1;
	min-width: 360px;
}
.log dd a {
	color: #000;
	text-decoration: underline;
}
.log dd span {
	font-weight: bold;
	display: block;
}
.log dd i {
	font-size: 12px;
	font-weight: normal;
	font-style: normal;
	color: tomato;
	position: relative;
	top: -2px;
}
#p_top #post_part .news .more {
	position: absolute;
	top: 25px;
	right: 30px;
}
#p_top #post_part .news .more a {
	font-weight: bold;
	color: #008F6D;
	display: flex;
	align-items: center;
}
#p_top #post_part .news .more i {
	width: 28px;
	height: 28px;
	margin-right: 10px;
	border: 1px #008F6D solid;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
}
#p_top #post_part .news .more i img {
	width: 6px;
}
/* お知らせ
------------------------------------------------ */
#p_news.p_single .cbox {
	padding: 80px;
	border: 1px #008F6D solid;
}
/* 会社案内
------------------------------------------------ */
#p_company #company .bg_wrap {
	margin-bottom: 160px;
	padding: 100px 0;
	background: url(/image/common/block/block_w20.png),url(/company/image/bg_concept.webp) center no-repeat;
	background-size: auto,100%;
	position: relative;
}
#p_company #company .bg_wrap h3 {
	font-family: "Source Serif 4", serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-size: 70px;
	font-style: normal;
	color: #18AB89;
	text-align: center;
	letter-spacing: 0.2rem;
	position: absolute;
	top: -50px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
}
#p_company #company p {
	margin-bottom: 30px;
	font-size: 24px;
	text-align: center;
	line-height: 2;
}
#p_company #company p:last-of-type {
	margin-bottom: 0;
}
#p_company #company p.strong {
	margin-bottom: 60px;
	font-family: 'Sawarabi Mincho', serif;
	font-weight: 400;
	font-style: normal;
	font-size: 34px;
	color: #008F6D;
}
#p_company #tagline .border {
	padding: 50px 0;
	border: 1px #008F6D solid;
}
#p_company #tagline .border h3 {
	margin-bottom: 30px;
	font-size: 32px;
	font-weight: bold;
	color: #008F6D;
	text-align: center;
}
#p_company #tagline .border p {
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}
#p_company #overview dl {
	padding: 30px 0;
	max-width: 1040px;
	border-top: 1px #E3E3E3 solid;
	margin: 0 auto;
	display: flex;
}
#p_company #overview dl:last-of-type {
	border-bottom: 1px #E3E3E3 solid;
}
#p_company #overview dt {
	width: 20%;
	max-width: 200px;
	padding: 0 20px;
	font-weight: bold;
	display: flex;
	align-items: center;
	position: relative;
}
#p_company #overview dt:before {
	content: "";
	width: 100%;
	height: 2px;
	background: #40CAA9;
	display: block;
	position: absolute;
	top: -31px;
	left: 0;
}
#p_company #overview .cbox_s dl:last-of-type dt:after {
	content: "";
	width: 100%;
	height: 2px;
	background: #40CAA9;
	display: block;
	position: absolute;
	bottom: -31px;
	left: 0;
}
#p_company #overview dt span.wide {
	flex: 2;
}
#p_company #overview dt span.narrow {
	flex: 1;
}
#p_company #overview dd {
	flex: 1;
	padding: 0 20px;
}
#p_company #overview dd.flex {
	display: flex;
	flex-wrap: wrap;
	gap: 20px 0;
}
#p_company #overview dd.flex .wrap {
	width: 50%;
}
#p_company #overview dd strong {
	margin-bottom: 10px;
	font-weight: normal;
	display: block;
}
#p_company #overview dd ul li:before {
	content: "・";
}
/* 事業概要
------------------------------------------------ */
/* ビジネスモデル */
#p_overview #model .flex {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
}
#p_overview #model .flex dl {
	width: calc((100% - 20px) / 2);
	max-width: 520px;
}
#p_overview #model .flex dt {
	height: 60px;
	margin-bottom: 30px;
	background: #E8E8E8;
	font-size: 26px;
	font-weight: bold;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
}
#p_overview #model .flex dl.our dt {
	background: #40CAA9;
	color: #fff;
}
#p_overview #model .flex dl.other dd {
	width: 92%;
	max-width: 474px;
	margin: 0 auto;
}
#p_overview #model .flex dl.our dd {
	width: 99%;
	max-width: 510px;
	margin: 0 auto;
	aspect-ratio: 51 / 56;
	display: flex;
	justify-content: center;
	align-items: center;
}
/* 商品開発 *//* 生産設備製造 */
#p_overview  #kaihatsu .box,
#p_overview  #seibi .box {
	min-height: 310px;
	margin-bottom: 50px;
	padding: 30px 40px;
	background: #fff;
	border: 1px #008F6D solid;
	display: flex;
	align-items: center;
	position: relative;
}
#p_overview #kaihatsu .box:after,
#p_overview  #seibi .box:after {
	content: "";
	width: 55%;
	aspect-ratio: 29/ 16 ;
	background: #84DDC8;
	clip-path: polygon(0 100%, 100% 100%, 100% 0);
	display: inline-block;
	position: absolute;
	bottom: -15px;
	right: -15px;
	z-index: -1;
}
#p_overview #kaihatsu .box ul {
	width: 24%;
	aspect-ratio: 1 / 1;
	position: relative;
}
#p_overview #seibi .box ul {
	width: 30%;
	aspect-ratio: 31 / 25;
	position: relative;
}
#p_overview #kaihatsu .box li,
#p_overview #seibi .box li {
	display: flex;
	justify-content: center;
	align-items: center;
}
#p_overview #kaihatsu .box li img,
#p_overview #seibi .box li img {
	width: auto;
	max-width: 200px;
	max-height: 260px;
}
#p_overview #seibi .box ul.photo2 {
	position: relative;
}
#p_overview #seibi .box ul.photo2 .p_a {
	position: absolute;
	top: 0;
	left: 0;
}
#p_overview #seibi .box ul.photo2 .p_b {
	position: absolute;
	bottom: 0;
	right: 0;
}
#p_overview #kaihatsu .box dl {
	width: 76%;
	padding:  0 40px;
}
#p_overview #seibi .box dl {
	width: 70%;
	padding:  0 60px;
}
#p_overview #kaihatsu .box dt,
#p_overview #seibi .box dt {
	margin-bottom: 40px;
	font-size: 20px;
	font-weight: bold;
	color: #008F6D;
}
/* 派遣 */
#p_overview #haken .intro_text {
	padding: 50px 0;
	background: url(/overview/image/haken/grd_white.png) right 100px top repeat-y,url(/overview/image/haken/bg_haken.jpg) right center no-repeat;
	background-size: 460px,560px;
}
#p_overview #haken .service .table dl {
	border-top: 1px #ACACAC solid;
	display: flex;
}
#p_overview #haken .service .table dl:last-of-type {
	margin-bottom: 40px;
	border-bottom: 1px #ACACAC solid;
}
#p_overview #haken .service .table dt {
	width: 25%;
	padding: 25px 15px;
	background: #E0F7F1;
	font-size: 18px;
	font-weight: bold;
	display: flex;
	align-items: center;
}
#p_overview #haken .service .table dd {
	width: 75%;
	padding: 25px 15px;
}
#p_overview #haken .service .table dd li::before {
	content: "・";
}
#p_overview #haken .service .pdd{
	width: 96%;
	margin: 0 auto;
	margin-bottom: 30px;
	display: flex;
	align-items: center;
}
#p_overview #haken .service .pdd li.company{
	width: 40%;
}
#p_overview #haken .service .pdd dt{
	margin-bottom: 10px;
	font-weight: bold;
}
#p_overview #haken .service .pdd li.button a {
	padding: 15px 80px;
	border: 2px #008F6D solid;
	border-radius: 30px;
	display: inline-block;
	font-size: 18px;
	color: #008F6D;
}
/* 製品カタログ
------------------------------------------------ */
#p_product #item_list .flex {
	display: flex;
	flex-wrap: wrap;
	gap: 30px 15px;
}
#p_product #item_list .flex .box {
	width: calc((100% - 30px) / 3);
	min-width: 330px;
	padding: 30px 2%;
	border: 1px #008F6D solid;
	display: flex;
	flex-direction: column;
}
#p_product #item_list .flex .box ul.img {
	width: 300px;
	margin-bottom: 40px;
}
#p_product #item_list .flex .box dl {
	margin-bottom: 40px;
}
#p_product #item_list .flex .box dt {
	margin-bottom: 20px;
	font-size: 24px;
	font-weight: bold;
	color: #008F6D;
}
#p_product #item_list .flex .box ul.pdf a {
	width: 200px;
	height: 40px;
	margin: 0 auto;
	border: 1px #707070 solid;
	color: #000;
	display: flex;
	justify-content: center;
	align-items: center;
}
#p_product #item_list .flex .box ul.pdf,
#p_product #item_list .flex .box ul.button {
    margin-top: auto;
}
#p_product #item_list .flex .box ul.button a {
	width: 200px;
	height: 40px;
	margin: 0 auto;
	background: #5EC2AA;
	border-radius: 5px;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
}
/* よくある質問
------------------------------------------------ */
#p_faq #faq {

}
/* お問い合わせ
------------------------------------------------ */
#p_contact #mail dl {
	padding: 20px;
	border-top: 1px #ACACAC solid;
	display: flex;
}
#p_contact #mail dl:last-of-type {
	margin-bottom: 90px;
	border-bottom: 1px #ACACAC solid;
}
#p_contact #mail dt {
	width: 210px;
	height: 36px;
	font-weight: bold;
	display: flex;
	align-items: center;
}
#p_contact #mail dd {
	flex: 1;
}
#p_contact #mail dd ul.radio li {
	display: flex;
	align-items: center;
}
#p_contact #mail dd ul.radio input {
	margin-right: 10px;
}
#p_contact #mail dd ul.file {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 10px;
}
input {
	height: 36px;
	border: none;
	background: #F5F5F5;
}
ul.radio input,
ul.file input {
	height: auto;
	background: transparent;
}
textarea {
	height: 300px;
	background: #F5F5F5;
	border: none;
}
input[type="submit"] {
	width: 300px;
	height: 60px;
	background: #fff;
	border: 2px #008F6D solid;
	border-radius: 30px;
	margin: 0 auto;
	font-size: 18px;
	color: #008F6D;
	cursor: pointer;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: .2s;
}
input[type="submit"]:hover {
	background: #008F6D;
	color: #fff;
}
/* フォーム幅
------------------------------------------------ */
form .wl {
	width: 100% !important;
}
form .wm {
	width: 50% !important;
}
form .ws {
	width: 25% !important;
}
form .wss {
	width: 10% !important;
}
/* 個人情報保護方針
------------------------------------------------ */
#p_policy h4.d_circle {
	margin-bottom: 60px;
}
#p_policy dl {
	margin-bottom: 40px;
	padding: 0 10px;
}
#p_policy dt {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px #008F6D solid;
	font-size: 20px;
	font-weight: bold;
}