﻿header {
	background: rgba(118, 230, 137, 0.5)
}
.intro {
	padding: 0
}
.content {
	width: 1100px;
	margin: 0 auto 0;
	text-align: center;
	padding: 50px 0
}
.content h2 {
	padding: 0.5em;
	background: #dcfbe0;
	border-bottom: solid 2px #348b43;
	margin-bottom: 10px
}
.content .sentence {
	text-align: left
}
.tbl_patA table {
	width: 100%;
	border-collapse: collapse
}
.tbl_patA table tr th {
	width: 25%;
	background: #30a244;
	color: #fff;
	border-top: 1px solid #fff;
	padding: 10px 0;
	font-weight: normal
}
.tbl_patA table tr td {
	text-align: left;
	padding: 10px;
	line-height: 1.5;
	border-top: 1px solid #30a244;
	border-right: 1px solid #30a244
}
.tbl_patA table tr:first-child th {
	border-top: none
}
.tbl_patA table tr:last-child th {
	border-bottom: 1px solid #30a244
}
.tbl_patA table tr:last-child td {
	border-bottom: 1px solid #30a244
}
#company .sub_title {
	background: url("../img/company/bnr_company.jpg") no-repeat;
	height: 250px
}
.greeting {
	margin-bottom: 50px
}
.greeting .sentence {
	width: 550px;
	display: inline-block;
	vertical-align: top;
	text-align: left
}
.greeting .img {
	width: 500px;
	display: inline-block;
	vertical-align: top;
	margin-left: 30px
}
.outline {
	margin-top: 50px
}
.outline table {
	width: auto;
	margin: 0 auto
}
.outline table th {
	font-weight: normal;
	width: 20%
}
.outline table td {
	padding: 10px 20px;
	text-align: left
}
#ecology .sub_title {
	background: url("../img/ecology/bnr_title.jpg") no-repeat;
	height: 250px
}
.efforts {
	margin-bottom: 50px
}
.efforts .iso {
	margin-top: 30px
}
.efforts .iso .img {
	width: 340px;
	display: inline-block;
	vertical-align: top;
	margin-left: 10px
}
#security .sub_title {
	background: url("../img/security/bnr_title.jpg") no-repeat;
	height: 250px
}
.security {
	text-align: left
}
.security h2 {
	text-align: center
}
.security .sentence.patB {
	width: 720px;
	display: inline-block;
	vertical-align: top
}
.security .sentence.patB .sub_content {
	margin-top: 30px
}
.security .sentence.patB .sub_content h3 {
	border-bottom: 1px solid #2e803b;
	font-size: 2.0rem;
	border-left: 5px solid #2e803b;
	padding-left: 3px
}
.security .sentence.patB .sub_content ul {
	padding-left: 20px;
	list-style-type: disc
}
.security .sentence.patB .sub_content ul li {
	margin-top: 10px
}
.security .iso {
	width: 320px;
	display: inline-block;
	vertical-align: top;
	margin-left: 20px
}
.security .iso .img.patB {
	width: 100%
}
#service .sub_title {
	background: url("../img/service/bnr_title.jpg") no-repeat;
	height: 250px
}
.work {
	margin-bottom: 80px
}
.work .sentence {
	width: 550px;
	display: inline-block;
	vertical-align: top;
	text-align: left
}
.work .sentence h3 {
	padding: 10px 20px;
	color: #494949;
	background: #e0fce4;
	border-left: solid 5px #348b43;
	border-bottom: solid 3px #91a594
}
.work .sentence p {
	margin-top: 20px;
	padding: 0 10px
}
.work .movie {
	width: 500px;
	display: inline-block;
	vertical-align: top;
	margin-left: 30px
}
#recruit .sub_title {
	background: url("../img/recruit/bnr_recruit.jpg") no-repeat;
	height: 250px
}
.sub_title {
	position: relative;
	min-width: 1100px
}
.sub_title .main {
	position: static
}
.sub_title .main img {
	width: auto
}
.sub_title .main .title {
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	top: 50%;
	bottom: 50%;
	color: #fff;
	font-size: 3.0rem
}
.sub_title .main .title span {
	line-height: 2.0;
	font-size: 1.8rem
}
.select_area {
	background: url("../img/recruit/back.jpg") no-repeat;
	background-size: 100% auto;
	padding: 70px 0 0 0
}
.select_area .select_recruit {
	margin-top: 30px
}
.select_area .select_recruit .tab {
	display: inline-block;
	margin-left: 50px
}
.select_area .select_recruit .tab:first-child {
	margin-left: 0
}
.select_area .select_recruit .tab a {
	padding: 30px 100px;
	display: block;
	background: #20CA6A;
	border-radius: 20px 20px 0 0;
	color: #fff
}
.select_area .select_recruit .tab a.selected {
	background-color: #fff;
	color: #555
}
.recruit_area {
	margin: 30px auto 0
}
.recruit_area .recruit_navi {
	margin-top: 30px
}
.recruit_area .recruit_navi ul li {
	display: inline-block
}
.recruit_area .recruit_navi ul li a {
	display: block;
	padding: 20px 40px;
	font-size: 2.0rem;
	border: 1px solid #31b84c;
	background-color: #fff;
	margin-left: 30px
}
.recruit_area .recruit_navi ul li a.selected {
	background-color: #20CA6A;
	color: #fff;
	border-color: #20CA6A
}
.recruit_area .back_info {
	min-height: 1000px;
}
.recruit_area .recruit_info {
	margin-top: 30px
}
.recruit_area .recruit_info table {
	width: 100%
}
.recruit_area .recruit_info table th {
	width: 25%;
	background-color: #7ce08f;
	color: #0b5a1b;
	padding: 10px 0;
	border-bottom: 1px solid #fff;
	font-weight: normal
}
.recruit_area .recruit_info table th:last-child {
	border-bottom: 1px solid #22ad3a
}
.recruit_area .recruit_info table td {
	text-align: left;
	padding: 5px 10px;
	border-top: 1px solid #a6dcb0;
	border-right: 1px solid #a6dcb0;
	background-color: #fff;
	line-height: 1.5
}
.recruit_area .recruit_info table td:last-child {
	border-bottom: 1px solid #a6dcb0
}

.recruit_area .bnr-mynavi{
	width: 500px;
	margin: 30px auto;
	box-shadow: 0 0 5px #bfbfbf;
}
.recruit_area .bnr-mynavi img{

}
.recruit_flow {
	margin-top: 50px
}
.recruit_flow .flow_content {
	width: 1000px;
	margin: 30px auto 0
}
.recruit_flow .flow_content .flow {
	position: relative;
	padding: 40px;
	background-color: #a0c1e2
}
.recruit_flow .flow_content .flow:after {
	position: absolute;
	content: '';
	top: 100%;
	left: 0;
	right: 0;
	margin: auto;
	border: 15px solid transparent;
	border-top: 20px solid #a0c1e2;
	width: 0;
	z-index: 1
}
.recruit_flow .flow_content .flow h3 {
	font-size: 30px;
	color: #fff
}
.recruit_flow .flow_content .flow .explain {
	font-size: 24px;
	margin-top: 30px
}
.recruit_flow .flow_content .flow a {
	text-decoration: underline;
	text-decoration-color: #04c;
	color: #04c
}
.recruit_flow .flow_content .flow.patB {
	background: #fff
}
.recruit_flow .flow_content .flow.patB h3 {
	color: #a0c1e2
}
.recruit_flow .flow_content .flow.patB:after {
	border: 15px solid transparent;
	border-top: 20px solid #fff
}
.recruit_flow .flow_content .flow.patC:after {
	border: none
}
.recruit_flow .flow_content .hosoku {
	margin-top: 20px;
	font-size: 1.6rem
}
.recruit_root {
	margin-top: 50px
}
.recruit_root .explain {
	padding-top: 30px;
	font-size: 2.0rem
}
.recruit_root .contact_link {
	margin: 27px 0
}
.recruit_root .contact_link i {
	margin-right: 5px
}
.recruit_root .contact_link a {
	border: 6px double #36ab89;
	color: #36ab89;
	display: inline-block;
	border-radius: 4px;
	font-size: 2.2rem;
	padding: 2% 3%;
	margin: 0 auto;
	box-shadow: 3px 3px 3px rgba(68, 68, 68, 0.5)
}
.recruit_root .contact_link a:hover {
	opacity: 0.8
}
.cp_ipselect {
	overflow: hidden;
	width: 40%;
	text-align: center
}
.cp_ipselect select {
	width: 100%;
	padding-right: 1em;
	font-size: 18px;
	cursor: pointer;
	text-indent: 0.01px;
	text-overflow: ellipsis;
	border: none;
	outline: none;
	background: transparent;
	background-image: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none
}
.cp_ipselect select::-ms-expand {
	display: none
}
.cp_ipselect.cp_sl02 {
	position: relative;
	border: 1px solid #bbbbbb;
	border-radius: 2px;
	background: #ffffff
}
.cp_ipselect.cp_sl02::before {
	position: absolute;
	top: 0.8em;
	right: 0.9em;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #666666;
	pointer-events: none
}
.cp_ipselect.cp_sl02:after {
	position: absolute;
	top: 0;
	right: 2.5em;
	bottom: 0;
	width: 1px;
	content: '';
	border-left: 1px solid #bbbbbb
}
.cp_ipselect.cp_sl02 select {
	padding: 8px 38px 8px 8px;
	color: #666666
}
.sitemap {
	text-align: left;
	width: 500px;
	margin: 0 auto
}
.sitemap ul li {
	margin-bottom: 30px
}
.sitemap ul li a {
	text-decoration: underline
}
.sitemap ul li a:before {
	content: "●"
}
p {
	line-height: 160%
}
a {
	text-decoration: none
}
th, td {
	text-align: center
}
#contact .sub_title {
	background: url("../img/contact/bnr_title.jpg");
	position: relative;
	height: 250px;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center
}
#position_c {
	text-align: center;
	background: rgba(118, 230, 137, 0.5)
}
#position_c .logo {
	float: none
}
#position_c .logo a {
	display: block
}
.content_view {
	margin: 0 auto 0;
	text-align: center;
	padding-top: 50px
}
.content_view .view_title {
	width: 1100px;
	padding: 0.5em;
	margin: 0 auto 0;
	background: #dcfbe0;
	border-bottom: solid 2px #348b43
}
.invite {
	margin: 30px 0
}
.visit_view {
	text-align: center
}
.visit_view h3 {
	font-size: 22px;
	font-weight: bold
}
.caution {
	margin: 20px 0
}
.visit_table {
	margin-left: auto;
	margin-right: auto;
	width: 616px;
	background: white
}
.visit_table tr th {
	width: 45%;
	padding: 10px;
	height: 60px;
	border-bottom: 1px solid #fff;
	border-collapse: collapse;
	color: #0b5a1b;
	background-color: #7ce08f
}
.visit_table tr:last-child th {
	border-bottom: 1px solid #7ce08f
}
.visit_table tr td {
	border: 1px solid #a6dcb0
}
.visit_form h2 {
	font-size: 22px;
	font-weight: bold
}
.visit_form table {
	margin: 0 auto;
	margin-top: 24px;
	display: table
}
.visit_form tr th {
	border-bottom: 1px solid #fff;
	color: #0b5a1b;
	background-color: #7ce08f;
	width: 285px;
	font-size: 1.75rem;
	line-height: 1.9
}
.visit_form tr:last-child th {
	border-bottom: 1px solid #7ce08f
}
.visit_form tr .required {
	display: table-cell;
	vertical-align: middle;
	font-size: 1.3rem;
	font-weight: 400;
	background: #f96868;
	color: #fff;
	padding: 2px 6px;
	margin-right: 15px;
	float: right
}
.visit_form tr td {
	border: 1px solid #a6dcb0
}
.visit_form .form_caution {
	font-size: 12px;
	text-align: left;
	margin: 8px;
	margin-top: 0
}
.visit_form input[type=text], .visit_form textarea, .visit_form select {
	border: 1px solid #e8e8e8;
	border-radius: 4px;
	padding: 15px 10px;
	background: #e8e8e8;
	margin: 14px 8px
}
.visit_form select {
	padding: 0;
	width: 148px;
	height: 42px
}
.visit_form textarea {
	height: 180px
}
.visit_form .error_message {
	display: block;
	color: red;
	font-size: 14px;
	margin: 14px 8px;
	text-align: left;
	margin-top: 0
}
.privacy-policy h2 {
	border: none;
	background: none
}
.privacy-policy h3 {
	font-weight: bold;
	margin-top: 15px;
	margin-bottom: 20px;
	text-align: center
}
.privacy-policy h4 {
	font-weight: bold;
	padding-left: 10px;
	margin-top: 3%;
	border-left: 4px solid #008789;
	font-size: 18px;
	text-align: left
}
.privacy-policy p {
	text-align: left;
	padding-left: 1.5rem
}
.privacy-policy ul {
	padding-left: 50px
}
.privacy-policy li {
	text-align: left;
	list-style-type: disc
}
.pop-box {
	background-color: #e8e8e8;
	line-height: 220%;
	text-align: center;
	width: 750px;
	margin: 20px auto;
	margin-bottom: 0;
	padding: 20px;
	padding-top: 32px
}
.popup {
	background-color: #efefef;
	box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.8);
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	width: 70vw;
	height: 51vw;
	height: 70%;
	overflow-y: scroll
}
#popup-on {
	display: none
}
#popup-on:checked+.popup {
	display: block
}
#doui {
	margin-top: 20px
}
.check_privacy {
	display: none
}
.agree_privacy {
	padding-left: 20px;
	position: relative;
	margin-right: 20px
}
.agree_privacy::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 15px;
	height: 15px;
	border: 1px solid #999;
	border-radius: 4px
}
.check_privacy:checked+.agree_privacy {
	color: #009a9a
}
.check_privacy:checked+.agree_privacy::after {
	content: "";
	display: block;
	position: absolute;
	top: -5px;
	left: 5px;
	width: 7px;
	height: 14px;
	transform: rotate(40deg);
	border-bottom: 3px solid #009a9a;
	border-right: 3px solid #009a9a
}
.icon-close {
	background: #000;
	color: #fff;
	font-size: 30px;
	padding: 0 10px;
	position: absolute;
	right: 0
}
.btn-close {
	background: #000;
	border-radius: 10px;
	color: #fff;
	padding: 10px;
	cursor: pointer;
	margin: 10px auto;
	width: 95%;
	text-align: center
}
.btn-open {
	border-radius: 10px;
	color: #009999;
	text-decoration: underline;
	cursor: pointer;
	margin: 10px auto;
	width: 95%;
	text-align: center;
	font-size: 16px
}
.popup-content {
	margin: 40px auto 40px auto;
	width: 90%
}
.privacy_error {
	color: red;
	font-size: 14px;
	text-align: center
}
.confirmation {
	margin-top: 44px;
	text-align: center;
	display: flex;
	justify-content: center
}
.confirmation .confirmation_button {
	background: #30a563;
	border: 1px solid silver;
	border-radius: 4px;
	padding: 18px 48px;
	font-size: 1.9rem;
	color: #fff;
	cursor: pointer
}
.confirmation .confirmation_button:hover {
	opacity: 0.8
}
.confirmation .clear_button {
	border: 1px solid silver;
	border-radius: 4px;
	padding: 18px 48px;
	margin-right: 40px;
	font-size: 1.9rem;
	background: #f1f3ec;
	cursor: pointer
}
.confirmation .clear_button:hover {
	opacity: 0.8
}
.check_page {
	margin: 0 auto
}
.check_page .check_head {
	margin: 20px;
	line-height: 1.6
}
.check_page .check_form {
	border-radius: 6px;
	padding: 20px;
	margin: 0 30px;
	margin-bottom: 36px;
	height: auto
}
.check_page table {
	margin: 0 auto
}
.check_page table:last-child {
	border-bottom: 1px solid #c1d4c5
}
.check_page tr th {
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
	color: #0b5a1b;
	background: #7ce08f;
	font-size: 1.75rem;
	font-weight: bold;
	line-height: 1.9;
	text-align: center;
	width: 285px;
	padding: 10px
}
.check_page tr:first-child th {
	border-top: #7ce08f 1px solid
}
.check_page tr td {
	border: 1px solid #a6dcb0;
	padding-bottom: 4px;
	width: 56%;
	margin: 0 auto
}
.check_page .long_txt {
	overflow: auto
}
.care_or_send {
	display: flex;
	justify-content: center
}
.care_or_send .care_button {
	border: 1px solid silver;
	border-radius: 4px;
	padding: 18px 48px;
	margin-right: 40px;
	font-size: 1.9rem;
	background: #f1f3ec;
	cursor: pointer
}
.care_or_send .care_button:hover {
	opacity: 0.8
}
.care_or_send .send_button {
	background: #30a563;
	border: 1px solid silver;
	border-radius: 4px;
	padding: 18px 48px;
	font-size: 1.9rem;
	color: #fff;
	cursor: pointer
}
.care_or_send .send_button:hover {
	opacity: 0.8
}
header .logo {
	max-width: 100%
}
header .logo img {
	max-width: 100%
}
.thanks_page {
	text-align: center;
	padding-top: 79px
}
.thanks_page h1 {
	width: 1100px;
	margin: 0 auto 10px;
	font-size: 27px;
	padding: 0.5em;
	background: #dcfbe0;
	border-bottom: solid 2px #348b43;
	margin-bottom: 10px
}
.thanks_page p {
	margin-top: 30px
}
.thanks_page .thanks_txt {
	margin-bottom: 30px
}
.thanks_page .top_to_back {
	display: inline-block;
	text-decoration: none;
	background: #30a563;
	border: 1px solid silver;
	border-radius: 4px;
	padding: 18px 16px;
	font-size: 16px;
	color: #fff
}
.thanks_page .top_to_back:hover {
	opacity: 0.8
}