* {
	font-family: zen-maru-gothic;
	font-weight: 700;
	color: #243c4a;
}

.header-logo-inner {
	height: 110px;
}

.legalmessage {
	position: absolute;
	bottom: 20px;
	left: 20px;
	width: calc(100% - 40px);
	margin-top: 0;
	background: #243c4acc;
	border-radius: 10px;
	margin-bottom: 0;
	padding: 15px 20px;
}

.legalmessage>p {
	color: #fff !important;
}

.main-visual {
	background-position: center;
}

.main-visual-mask {
	position: relative;
}

.content-box {
	max-width: none;
	margin: 0 10%;
	width: 80%;
	position: relative;
}

.content-box-item {
	margin-top: 100px;
}

.content-box-item:first-of-type>h2.box-title:before {
	content: none;
}

.content-box-item:first-of-type>.box-title {
	font-size: 20px;
	text-align: center;
	margin-bottom: 0;
	padding-left: 0;
}

.content-box-item:first-of-type>.box-text {
	margin-bottom: 0;
}

.content-box-item:first-of-type>.box-text>p {
	font-size: 18px;
	text-align: center;
	margin-bottom: 0;
	height: 50px;
}

a.urllink {
	text-decoration: underline;
	background-color: rgba(255,255,255,.5);
	border-radius: 20px;
	padding: 5px 15px 10px;
}

h2.box-title {
	font-size: 28px;
	color: #2c4b66 !important;
	position: relative;
	padding-left: 30px;  
	margin-bottom: 30px;
	line-height: 60px;
}

h2.box-title:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 10px;
	background-color: #2c4b66;
	height: 100%;
	border-radius: 5px;
}

.box-text>p {
	font-size: 18px;
}

.content-table {
	font-size: 16px;
}

.image-box img {
	border-radius: 10px;
}

.content-box-item:nth-child(1) {
	margin-top: 0px;
	margin-bottom: 70px;
	background-color: #ddd;
	border-radius: 30px;
	padding: 0px 20px;
}

.content-box-item:nth-child(2) {
	margin-top: 30px;
}

.content-box-item:nth-child(2)>.box-text {
	display: inline-block;
	width: calc(60% - 40px);
	margin-right: 30px;
}

.content-box-item:nth-child(2)>.image-box {
	display: inline-block;
	width: 40%;
	vertical-align: top;
}

.content-box-item.form-content {
	margin: 0;
	background-color: transparent;
	text-align: center;
}

.content-box-item.form-content>section {
	text-align: left;
}

.content-box-item.form-content>section.confirm-section {
	text-align: center;
}

.rijityou_greet {
	text-align: right;
	font-size: 16px;
	margin-top: 20px;
}

.rijityou_greet>.sign {
	background-image: url(https://seihoukai.jpn.org/wp-content/uploads/topsign.png);
	background-repeat: no-repeat;
	background-size: contain;
	height: 40px;
	width: 150px;
	display: inline-block;
	margin-top: 10px;
}

.fukurikousei-section {
	height: 300px;
	overflow-y: hidden;
	border-radius: 10px;
	margin-bottom: 30px;
	position: relative;
}

.fukurikousei-section.open {
	overflow-y: hidden;
}

.fukurikousei-section:after {
	content: "";
	background: linear-gradient(180deg,
		transparent 0% ,
		#fff 100%
	);
	height: 10%;
	position: absolute;
	width: 100%;
	bottom: 0;
}

.fukurikousei-section.open:after {
	display: none;
}

.fukurikousei-toggle {
	height: 80px;
	width: 360px;
	background-color: #46b6a1;
	margin: 0 auto;
	border-radius: 10px;
	text-align: center;
	color: #fff;
	font-size: 140%;
	padding: 15px 0;
	cursor: pointer;
}

.fukurikousei-toggle:hover {
	background-color: #005949;
}

.fukurikousei-topics {
	width: 100%;
	background-color: #46b6a15d;
	border-radius: 10px;
	padding: 10px 0;
	margin-top: 20px;
}

.fukurikousei-topics:first-of-type {
	margin-top: 50px;
}

.fukurikousei-topics>.title {
	text-align: center;
	font-size: 180%;
	width: 80%;
	margin: 20px auto 50px;
	position: relative;
}

.fukurikousei-topics>.title:after {
	content: "";
	position: absolute;
	bottom: -25px;
	left: 50%;
	width: 40%;
	height: 5px;
	background-color: #46b6a1;
	border-radius: 5px;
	transform: translateX(-50%);
}

.fukurikousei-topics>.content {
	width: 80%;
	font-size: 120%;
	margin: 60px auto 40px;
}

.fukurikousei-topics>.content>p {
	margin-bottom: 20px;
}

.fukurikousei-topics>.content>ul {
	width: 80%;
	margin: 0 auto;
}

.fukurikousei-topics>.content>ul>li {
	list-style-type: disc;
}

.fukurikousei-topics>.content>.note {
	font-size: 80%;
	opacity: 0.8;
}

.fukurikousei-topics>.content>.note:first-of-type {
	margin-top: 30px;
}

.fukurikousei-wrap {
	display: flex;
	margin-top: 20px;
	flex-wrap: wrap;
}

.fukurikousei-item {
	width: 32%;
	background-color: #46b6a15d;
	border-radius: 10px;
	padding: 10px 0;
	margin-right: 2%;
}

.fukurikousei-item:nth-child(3n) {
	margin-right: 0;
}

.fukurikousei-item:nth-child(n+4) {
	margin-top: 20px;
}

.fukurikousei-item>.title {
	text-align: center;
	font-size: 130%;
	width: 80%;
	margin: 10px auto 30px;
	position: relative;
}

.fukurikousei-item>.title:after {
	content: "";
	position: absolute;
	bottom: -20px;
	left: 50%;
	width: 40%;
	height: 5px;
	background-color: #46b6a1;
	border-radius: 5px;
	transform: translateX(-50%);
}

.fukurikousei-item>.content {
	width: 85%;
	margin: 40px auto 20px;
}

.fukurikousei-item>.content>p {
	margin-bottom: 20px;
	font-size: 16px;
}

.fukurikousei-item>.content>ul {
	width: 85%;
	margin: 0 auto;
	font-size: 16px;
}

.fukurikousei-item>.content>ul>li {
	list-style-type: disc;
}

.fukurikousei-item>.content a {
	font-size: 16px;
}

.jinbutsu-section {
	display: block;
}

.jinbutsu-wrap {
	display: block;
}

.jinbutsu-item {
	margin: 0 20px;
	transition: 0.2s all ease-in-out;
	opacity: 0.5;
	transform: scale(0.9);
}

.jinbutsu-item>.image {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	border-radius: 10px;
	width: 100%;
	height: 30vw;
	max-height: 400px;
	min-height: 350px;
}

.jinbutsu-item>.image1 {
	background-image: url(https://seihoukai.jpn.org/wp-content/uploads/jobcan_incom.jpg);
}

.jinbutsu-item>.image2 {
	background-image: url(https://seihoukai.jpn.org/wp-content/uploads/jobcan_ncsignal.png);
}

.jinbutsu-item>.image3 {
	background-image: url(https://seihoukai.jpn.org/wp-content/uploads/youtubelive_1.jpg);
}

.jinbutsu-item>.image4 {
	background-image: url(https://seihoukai.jpn.org/wp-content/uploads/jobcan_sdgs.png);
}

.jinbutsu-item>.title {
	font-size: 110%;
	display: inline-block;
	position: relative;
	margin-top: 10px;
	margin-bottom: 30px;
	transform: rotate(-2deg);
}

.jinbutsu-item>.title:before {
	content: "";
	display: inline-block;
	position: absolute;
	left: -15px;
	bottom: -3px;
	height: 5px;
	width: 125%;
	background-color: #1877f2;
	border-radius: 0px 5px 10px 0;
	z-index: -1;
	transform: rotate(-2deg);
}

.jinbutsu-item>.content {
	font-size: 90%;
	position: relative;
	top: -15px;
	padding-left: 15px;
}

.slick-center {
	transform: scale(1.0);
	opacity: 1.0;
}

.slick-prev {
	left: 5px;
	z-index: 9999;
	transform: translateY(-300%);
}

.slick-prev:before {
	content: "\f0d9";
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	background-color: #fff;
	border-radius: 50%;
	color: #000;
	width: 50px;
	display: block;
	height: 50px;
	font-size: 28px;
	padding-top: 10px;
}

.slick-next {
	right: 35px;
	transform: translateY(-300%);
}

.slick-next:before {
	content: "\f0da";
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	background-color: #fff;
	border-radius: 50%;
	color: #000;
	width: 50px;
	display: block;
	height: 50px;
	font-size: 28px;
	padding-top: 10px;
}

.slick-dots li button::before {
	font-size: 20px;
}

.toukei-section {
	height: 300px;
	overflow-y: hidden;
	border-radius: 10px;
	margin-bottom: 30px;
	position: relative;
}

.toukei-section.open {
	overflow-y: hidden;
}

.toukei-section:after {
	content: "";
	background: linear-gradient(180deg,
		transparent 0% ,
		#fff 100%
	);
	height: 10%;
	position: absolute;
	width: 100%;
	bottom: 0;
}

.toukei-section.open:after {
	display: none;
}

.toukei-toggle {
	height: 80px;
	width: 360px;
	background-color: #ff748e;
	margin: 0 auto;
	border-radius: 10px;
	text-align: center;
	color: #fff;
	font-size: 140%;
	padding: 15px 0;
	cursor: pointer;
}

.toukei-toggle:hover {
	background-color: #c32845;
}

.toukei-wrap {
	display: flex;
	margin-top: 20px;
	flex-wrap: wrap;
}

.toukei-item {
	width: 32%;
	background-color: #c462705e;
	border-radius: 10px;
	padding: 10px 0;
	margin-right: 2%;
}

.toukei-item:nth-child(3n) {
	margin-right: 0;
}

.toukei-item:nth-child(n+4) {
	margin-top: 20px;
}

.toukei-item>.title {
	text-align: center;
	font-size: 140%;
	width: 80%;
	margin: 10px auto 30px;
	position: relative;
}

.toukei-item>.title:after {
	content: "";
	position: absolute;
	bottom: -20px;
	left: 50%;
	width: 40%;
	height: 5px;
	background-color: #ff748e;
	border-radius: 5px;
	transform: translateX(-50%);
}

.toukei-item>.content {
	width: 80%;
	margin: 40px auto 20px;
	text-align: center;
}

.toukei-item>.content>p {
	margin-bottom: 20px;
	text-align: left;
}

.toukei-item>.content>ul {
	width: 80%;
	margin: 0 auto;
}

.toukei-item>.content>ul>li {
	list-style-type: disc;
}

.toukei-value-main {
	display: inline-block;
	font-size: 60px;
	margin-right: 5px;
}

.toukei-value-unit {
	font-size: 30px;
}

.job-offer-text {
	font-size: 16px;
}

.accessmap {
	width: 100%;
}

.seihoukai-footer {
	list-style: none;
	width: auto;
	font-size: 16px;
	margin: 30px auto 0;
	display: flex;
	text-align: center;
	justify-content:center
}

.seihoukai-footer>li {
	display: inline-block;
	text-align: center;
	vertical-align: top;
	position: relative;
}

.seihoukai-footer>li>a>div {
	text-decoration: underline;
}

.seihoukai-footer>li:first-of-type {
	margin-right: 20px;
}

.seihoukai-footer>li:first-of-type:after {
	content: "";
	height: 90%;
	width: 1px;
	background-color: #243c4a;
	display: block;
	position: absolute;
	right: -10px;
	top: 0;
}

.seihoukai-footer>li:last-of-type {
	margin-left: 20px;
}

.seihoukai-footer>li:last-of-type:before {
	content: "";
	height: 90%;
	width: 1px;
	background-color: #243c4a;
	display: block;
	position: absolute;
	left: -10px;
	top: 0;
}

.seihoukai-sns {
	list-style: none;
	width: auto;
	font-size: 16px;
	margin: 30px auto;
	display: flex;
	text-align: center;
	justify-content:center;
	height: 60px
}

.seihoukai-sns>li {
	display: inline-block;
	text-align: center;
	vertical-align: top;
	position: relative;
	margin: 0 10px;
}

.seihoukai-sns>li>a>i {
	font-size: 200%;
}

.seihoukai-sns>li>a.sns-x>i {
	color: #000;
}

.seihoukai-sns>li>a.sns-fb>i {
	color: #1877f2;
}

.seihoukai-sns>li>a.sns-insta>i {
	color: rgb(193, 53, 132);
}

.job-offer-main-image-thumbnail {
	border-radius: 10px;
}

.job-offer-main-image {
	border-radius: 10px;
	object-fit: cover;
	height: 50vw;
	max-height: 300px;
}

.slider-item>img {
	border-radius: 10px;
	object-fit: cover;
	height: 120px;
}

h1.form-title {
	font-size: 24px;
	background-color: #cbdee8;
	border-radius: 10px;
	padding: 20px 15px;
}

div.form-text {
	font-size: 16px;
}

div.alert-text-box {
	font-size: 20px;
	margin: 0 0 20px;
	border-radius: 10px;
}

div.alert-text-box .heading {
	border-radius: 10px 10px 0 0;
}

div.alert-text-box .error-alert {
	font-size: 16px;
}

input.c-inputText,
input.c-inputText--narrow,
.c-radio__sex span,
.c-checkbox span,
.c-checkbox__option span {
	font-size: 16px;
}

.c-radio__sex span {
	margin-left: 12px;
}

.c-checkbox__indicator,
.c-radio__indicator {
	width: 24px;
	height: 24px;
}

.c-checkbox__indicator::after {
	top: 4px;
	left: 8px;
	width: 8px;
	height: 12px;
}

.c-radio__indicator::after {
	width: 10px;
	height: 10px;
}

.item-name span.is_required {
	font-size: 80%;
	font-weight: 900;
}

.comfirm-button {
	font-size: 16px;
}

form>.form-content>.form-item .item-name>p,
form>.form-content>.comfirm-item .item-name>p {
	color: #777;
}

form>.form-content>.comfirm-item .comfirm-value {
	margin-left: 20px;
}


@media screen and (max-width: 960px){

	.sp-header {
		padding: 10px 10px 10px 5px;
	}

	.sp-header .sp-header-img a img {
		max-height: 48px;
	}

	.js-toggle-search {
		border: none;
		background-color: #eee;
		border-radius: 20px;
		width: 40px;
		height: 40px;
	}

	.js-toggle-search>img {
		vertical-align: bottom;
	}

	.main-visual {
		min-height: 500px;
	}

	.content-box {
		margin: 0 20px;
		width: calc(100% - 40px);
	}

	.legalmessage {
		font-size: 14px;
		left: 5px;
		width: calc(100% - 10px);
	}

	.job-offer-main-image-thumbnail {
		object-fit: cover;
		height: 50vw;
		max-height: 300px;
		margin-bottom: 10px;
	}

	.jinbutsu-item {
		margin: 0 10px;
	}

}

@media screen and (max-width: 768px){

	.slider-item>img {
		height: 200px;
	}

}

@media screen and (max-width: 599px){

	.section-wide {
		padding: 10px 0;
	}

	.content-box {
		margin: 0 5px;
		padding: 0;
		width: calc(100% - 10px);
	}

	h2.box-title {
		font-size: 20px;
	}

	.box-text>p {
		font-size: 14px;
	}

	.content-box-item:nth-child(1) {
		margin-bottom: 0;
	}

	.content-box-item:first-of-type>.box-title {
		font-size: 16px;
		line-height: normal;
		padding: 10px 0;
	}

	.content-box-item:nth-child(2)>.box-text {
		display: block;
		width: 100%;
		margin-right: 0;
	}

	.content-box-item:nth-child(2)>.image-box {
		display: block;
		width: 100%;
	}

	.content-box-item:nth-child(2)>.image-box img {
		object-fit: cover;
		height: 200px;
	}

	.content-table,
	.content-table-line,
	.content-table-line>td {
		display: block;
	}

	.content-table-line>td:first-of-type {
		width: 100%;
		padding-left: 0;
		padding-bottom: 0;
	}

	.content-table-line>td:last-of-type {
		margin-left: 0px;
		padding: 20px 0 30px;
		font-size: 13.5px;
		letter-spacing: -0.8px;
		transform: scaleX(0.98);
		font-weight: 500;
	}

	.content-table-line>td:last-of-type p {
		font-weight: 500;
	}
		
	.job-offer-box {
		padding: 10px 5px;
	}

	.job-offer-detail-title {
		font-size: 20px;
	}

	.job-offer-text {
		font-size: 14px;
	}

	.slider-item>img {
		height: 150px;
	}

	.slick-prev {
		left: 0px;
	}
	
	.slick-prev:before {
		width: 30px;
		height: 30px;
		font-size: 18px;
		padding-top: 6px;
	}
	
	.slick-next {
		right: 10px;
	}
	
	.slick-next:before {
		width: 30px;
		height: 30px;
		font-size: 18px;
		padding-top: 6px;
	}

	.jinbutsu-item {
		margin: 0;
	}

	.jinbutsu-item>.image {
		height: 30vw;
		min-height: 150px;
	}

	.fukurikousei-topics>.title {
		font-size: 150%;
		margin: 10px auto 40px;
	}

	.fukurikousei-topics>.title:after {
		bottom: -20px;
	}

	.fukurikousei-topics>.content {
		font-size: 100%;
		width: 90%;
		margin: 40px auto;
	}	

	.fukurikousei-topics>.content>ul {
		width: 90%;
	}

	.fukurikousei-item {
		width: 100%;
		margin-right: 0;
		margin-bottom: 10px;
		margin-top: 0;
	}

	.fukurikousei-item:nth-child(n+4) {
		margin-top: 0;
	}

	.fukurikousei-item>.title {
		font-size: 120%;
		margin: 0 auto 20px;
	}

	.fukurikousei-item>.title::after {
		bottom: -10px;
	}

	.fukurikousei-item>.content {
		margin: 20px auto 10px;
	}

	.fukurikousei-item>.content>p,
	.fukurikousei-item>.content>ul {
		font-size: 95%;
	}

	.fukurikousei-item>.content a {
		font-size: 12px;
	}

	.fukurikousei-toggle,
	.toukei-toggle {
		width: 80%;
		height: 60px;
		font-size: 120%;
		padding-top: 10px;
	}

	.toukei-wrap {
		display: block;
	}	

	.toukei-item {
		width: 100%;
		margin-right: 0;
		margin-bottom: 10px;
	}

	.toukei-item:nth-child(n+4) {
		margin-top: 0px;
	}

	.toukei-item>.title {
		font-size: 120%;
		width: 100%;
		margin: 0px auto 20px;
		position: relative;
	}
	
	.toukei-item>.title:after {
		bottom: -10px;
		height: 3px;
	}
	
	.toukei-item>.content {
		width: 90%;
		margin: 00px auto 5px;
		text-align: center;
	}
	
	.toukei-item>.content>p {
		margin-bottom: 20px;
		text-align: left;
	}
	
	.toukei-item>.content>ul {
		width: 90%;
		margin: 0 auto;
	}

	.section-wide.entry-form-page>.content-box {
		padding: 0px;
	}

	.section-wide.entry-form-page>.content-box>.form-content {
		padding: 0px;
	}

	.section-wide.entry-form-page>.content-box>.form-content>.form-title {
		font-size: 18px;
	}

	.section-wide.entry-form-page>.content-box>.form-content>.form-text {
		font-size: 14px;
	}

	form>.form-content>.form-item .item-name>p,
	form>.form-content>.comfirm-item .item-name>p,
	form>.form-content>.comfirm-item .comfirm-value {
		font-size: 14px;
	}

	form>.form-content>.form-item .item-name>p,
	form>.form-content>.comfirm-item .item-name>p {
		color: #777;
	}

	form>.form-content>.comfirm-item .comfirm-value {
		margin-left: 20px;
	}

	input.c-inputText, 
	input.c-inputText--narrow, 
	.c-radio__sex span, 
	.c-checkbox span, 
	.c-checkbox__option span {
		font-size: 14px;
	}

	.seihoukai-footer {
		width: auto;
		font-size: 14px;
		margin: 20px auto 0;
	}
			
	.seihoukai-footer>li {
		width: 33%;
	}

	.seihoukai-footer>li:first-of-type {
		margin-right: 10px;
	}
	
	.seihoukai-footer>li:first-of-type:after {
		content: "";
		height: 90%;
		width: 1px;
		background-color: #243c4a;
		display: block;
		position: absolute;
		right: -5px;
		top: 0;
	}
	
	.seihoukai-footer>li:last-of-type {
		margin-left: 10px;
	}
	
	.seihoukai-footer>li:last-of-type:before {
		content: "";
		height: 90%;
		width: 1px;
		background-color: #243c4a;
		display: block;
		position: absolute;
		left: -5px;
		top: 0;
	}

}