@charset "utf-8";


/*---------------------------------

1:common

----------------------------------*/
.header-main-in {
    background: rgba(255, 255, 255, 0.9);
}

#page-fv {
    background-size: cover;
    background-position: center;
}
#page-fv .inner {
    height: 600px;
}
.page-fv-in {
	color: #fff;
	position: absolute;
	left: 15px;
	bottom: 20px;
}
.page-fv-in h2 {
	font-size: 75px;
    font-family: var(--font-en);
    line-height: 1;
}
.page-fv-in p {
	font-size: 22px;
	font-weight:bold;
}


/* パン屑ナビ */
#bread-nav {
    font-size: 14px;
    padding: 40px 0 0;
}
#bread-nav li {
    display:inline-block;
	margin-left: 10px;
}
#bread-nav li:before {
    content: '>';
	margin-right: 10px;
}
#bread-nav li:first-child {
    margin-left:0;
}
#bread-nav li:first-child:before {
    display: none;
}
#bread-nav li a {
    color: #111;
}

/* page-title */
.page-title {
    line-height: 1;
	text-align:center;
	margin-bottom: 80px;
}
.page-title h3 {
    font-size: 40px;
    font-family:var(--font-en);
}
.page-title p {
    margin-top: 10px;
}

/* page-contents */
#page-contents {
	overflow: hidden;
	/* margin-bottom: 220px; */
}


/*---------------------------------

2:message

----------------------------------*/

.message-con {
    display: table;
    width: 100%;
    margin-bottom: 80px;
}
.message-con--img {
    display: table-cell;
    width: 46%;
    vertical-align: top;
}
.message-con--info {
    display: table-cell;
    padding-left: 8%;
	padding-top: 30px;
	line-height: 1.8;
}
.message-con--info .text01 {
    font-size: 30px;
    font-weight: bold;
    margin-bottom: 30px;
}
.message-con--info .text02 {
    font-size: 18px;
    font-weight: bold;
	margin-bottom: 30px;
}
.message-con--info .text02 span {
    font-size: 22px;
}
.message-con--info .text03 {
    line-height: 2.4;
}

#philosophy .page-title {
	margin-bottom: 110px;
}
.philosophy-main {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 80px;
}
.philosophy-main .page-logo {
	margin-bottom: 70px;
}
.philosophy-main h4 {
    font-size: 30px;
    padding: 10px 0;
    margin-bottom: 50px;
    border-top: solid 2px;
    border-bottom: solid 2px;
}
.philosophy-main h4 span {
    font-size: 24px;
    color: #0281c3;
    margin-right: 20px;
}
.philosophy-main .text01 {
    font-size: 17px;
    line-height: 2.4;
}
.philosophy-main .text02 {
    font-size: 22px;
    font-weight: bold;
    line-height: 2.4;
    margin: 40px 0;
}


#message-workplace {
    padding: 70px 0;
    background: #f2f2ee;
}
#message-workplace .copy {
	font-size: 30px;
	font-weight:bold;
	margin-bottom: 60px;
	text-align:center;
}
#message-workplace .copy span {
    color: #df5358;
}
.workplace-step > ul {
    margin-bottom: 60px;
}
.workplace-step > ul > li {
    display: table;
    width: 100%;
    background: #fff;
    margin: 0 auto 60px;
    border: solid 1px #cf5c5c;
    border-radius: 10px;
    position: relative;
}
.workplace-step > ul > li:after {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 25px 25px 0 25px;
    border-color: #cf5c5c transparent transparent transparent;
    margin-left: -25px;
    position: absolute;
    left: 50%;
    bottom: -45px;
}
.workplace-step > ul > li:last-child:after {
	display: none;
}
.workplace-step .img {
    display: table-cell;
    width: 47%;
    border-radius: 10px 0 0 0;
    overflow: hidden;
}
.workplace-step .info {
    display: table-cell;
    vertical-align: top;
    border-radius: 0 10px 0 0;
    overflow: hidden;
}
.workplace-step .info h3 {
	color: #cf5c5c;
	font-size: 22px;
	padding: 10px 0 10px 40px;
    background: #f9f3f4;
}
.workplace-step .info h3 span {
    font-size: 25px;
    vertical-align: -2px;
    margin-right: 5px;
}
.workplace-step .info ul {
    padding: 20px 20px 0 40px;
}
.workplace-step .info ul li {
	font-weight: bold;
	padding-left: 25px;
    margin-bottom: 15px;
	position: relative;
}
.workplace-step .info ul li:last-child {
	margin-bottom: 0;
}
.workplace-step .info ul li:before {
	color: #cf5c5c;
	content: '■';
	position: absolute;
	left:0;
	top: 0;
}
.workplace-step .info.no-list {
    vertical-align: middle;
    background: #f8f3f4;
    border-radius: 0 10px 10px 0;
}
.workplace-step .info.no-list h3 {
    display: inline;
}
.workplace-step .text01 {
    line-height: 2.2;
    font-size: 15px;
}

.workplace-award {
    display: table;
    width: 100%;
    margin-top: 80px;
    padding: 30px;
    background: #fff;
    border-radius: 10px;
}
.workplace-award .img {
    display: table-cell;
    width: 50%;
    vertical-align: top;
}
.workplace-award .info {
    display: table-cell;
    padding-left: 50px;
}
.workplace-award .info h3 {
    font-size: 20px;
    border-left: solid 5px #cf5c5c;
    padding-left: 10px;
    margin-bottom: 20px;
}
.workplace-award .info h4,
.workplace-award .info p {
    font-size: 16px;
    font-weight: normal;
    line-height: 2.2;
}
.workplace-award .info p {
    font-weight: bold;
}

.message-concept--image > ul > li {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
	margin-bottom: 120px;
}
.message-concept--image ul li .img {
    width: 50%;
}
.message-concept--image ul li .info {
    width: 50%;
	padding: 40px 0 0 40px;
}
.message-concept--image ul li .info h3 {
    font-size: 25px;
	line-height: 2;
    margin-bottom: 40px;
}
.message-concept--image ul li .info p {
	line-height: 2.2;
	margin-bottom: 30px;
}
.message-concept--image ul li .info p:last-child {
	margin-bottom:0;
}
.message-concept--image > ul > li:nth-child(even) {
    flex-direction: row-reverse;
}
.message-concept--image > ul > li:nth-child(even) .info {
	padding: 40px 40px 0 0;
}

.earnings {
    display: inline-block;
    border: solid 2px var(--main-color);
    border-radius: 10px;
    overflow: hidden;
}
.earnings h4 {
    font-size: 20px;
    color: var(--main-color);
    text-align: center;
    background: #edf0f5;
    padding: 10px 20px;
}
.earnings ul li {
	font-weight: bold;
    padding: 10px 25px;
    border-bottom: solid 2px var(--main-color);
}
.earnings ul li:last-child {
    border-bottom: none;
}
.earnings ul li .year {
    font-size: 20px;
	margin-right:20px;
}
.earnings ul li .t1 {
    font-size: 22px;
}
.earnings ul li .t1 span {
    font-size: 18px;
}
.earnings ul li b {
	color: var(--main-color);
}

.action-main ul {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.action-main ul li {
    width: 46%;
    margin: 0 0 100px 8%;
}
.action-main ul li:nth-child(odd) {
    margin-left: 0;
}
.action-main ul li .thumb {
    text-align: center;
    margin-bottom: 50px;
}
.action-main ul li h4 {
    font-size: 23px;
    margin-bottom: 30px;
}
.action-main ul li p {
    line-height: 2.2;
}

#message-large01 {
	background-image:url(../img/pages/message/large_01.jpg);
}
#message-large02 {
	background-image:url(../img/pages/message/large_02.jpg);
}
#message-large03 {
	background-image:url(../img/pages/message/large_03.jpg);
}


/*---------------------------------

3:introduction

----------------------------------*/
.introduction-group{
	margin-bottom: 210px;
	position: relative;
}
.introduction-group:last-child {
    margin-bottom: 0;
}
.introduction-group:after {
    content: '';
    display: block;
    width: 100%;
    height: calc(100% - 210px);
    background: #e6edf4;
    position: absolute;
    left: 0;
    top: 310px;
    z-index: -1;
}
.introduction-group .inner {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.introduction-img {
    width: 60%;
}
.introduction-img img {
    max-width: none;
    width: 60vw;
}
.introduction-img--sub {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 60vw;
}
.introduction-img--sub li {
    width: 48%;
    margin: 4% 0 0 4%;
}
.introduction-img--sub li:first-child {
    margin-left: 0;
}
.introduction-img--sub li img {
    max-width: 100%;
	margin:0;
}
.introduction-info {
    width: 40%;
	position: relative;
	right: -5%;
}
.introduction-info h3 {
	line-height: 1;
    margin-bottom: 40px;
}
.introduction-info h4 {
    font-size: 18px;
	font-weight:normal;
	margin-bottom: 5px;
}
.introduction-info h4 span {
    font-size: 22px;
	font-weight:bold;
}
.introduction-info--address {
    margin-bottom: 10px;
}
.introduction-info--tel {
	font-weight: bold;
	margin-bottom: 80px;
}
.introduction-info--tel span,
.introduction-info--tel a {
    font-size: 24px;
	color: var(--main-color);
	margin-left: 10px;
}
.introduction-info--desc h5 {
    font-size: 17px;
	margin-bottom: 20px;
}
.introduction-info--desc p {
	line-height:2;
	margin-bottom: 20px;
}
.introduction-info--desc p:last-child {
	margin-bottom:0;
}
.introduction-info--links li:not(:last-child) {
    margin-bottom: 20px;
}
.introduction-info--links {
	margin-top: 50px;
}
.introduction-info--links li a {
    display: block;
    max-width: 400px;
    padding: 20px;
    text-align: center;
    color: #fff;
    background: var(--main-color);
    border-radius: 100px;
}
.introduction-info--links li a:after {
    content: '';
    display: inline-block;
    width: 10px;
    height: 10px;
    margin-left: 10px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(45deg);
}
.introduction-group:nth-child(odd) .inner {
    flex-direction: row-reverse;
}
.introduction-group:nth-child(even) .introduction-img--main img {
    margin: 0 calc(100% - 60vw);
}

.introduction-group:nth-child(odd) .introduction-info {
    right:auto;
	left: -5%;
}
.introduction-group:nth-child(even) .introduction-img--sub {
	margin: 0 calc(100% - 60vw);
}


/*---------------------------------

4:job

----------------------------------*/
.job-list {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.job-list li {
    width: 30%;
    margin: 0 0 60px 5%;
    border-radius: 10px;
    overflow: hidden;
    border: solid 2px #92bce3;
}
.job-list li:nth-child(3n+1) {
    margin-left: 0;
}
.job-list li a {
	color: #2f3d45;
	display: block;
	text-align:center;
    background: #fff;
}
.job-list li .thumb {
	height: 0;
	padding-top: 75%;
	overflow: hidden;
	position: relative;
}
.job-list li .thumb img {
	width: 100%;
	position: absolute;
	left: 0;
	top:0;
}
.job-list li .info {
    padding: 15px 15px 20px;
}
.job-list li .info h3 {
    font-size: 16px;
    margin-bottom: 15px;
}
.job-list li .info p {
    font-size: 14px;
    line-height: 2;
    text-align: left;
}
.job-list .info .btn {
	color: var(--main-color);
	width: 250px;
	font-size: 14px;
    text-align: center;
	padding: 10px 0;
    margin: 20px auto 0;
	border: solid 1px var(--main-color);
	border-radius: 100px;
	   -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}
.job-list li a:hover .btn {
	color: #fff;
	background: var(--main-color);
}

/* single */
#job-detail {
    margin-bottom: 0;
}
#job-detail-relation .job-detail--list {
    margin-top:0;
}

.job-detail--top {
	margin-bottom: 100px;
}
.job-detail--top .title {
    text-align: center;
    margin-bottom: 90px;
}
.job-detail--top .title h2 {
    font-size: 28px;
}
.job-detail--top .title h3 {
    margin-top: 10px;
    color: var(--main-color);
    font-size: 24px;
    font-family: var(--font-en);
    font-weight: 100;
    line-height: 1;
}
.job-detail--top-in {
    display: table;
}
.job-detail--top-in .img {
    display: table-cell;
    width: 48%;
}
.job-detail--top-in .info {
    display: table-cell;
    padding-left: 4%;
    vertical-align: top;
}
.job-detail--top-in .info h3 {
    color: #29569b;
    font-size: 25px;
    padding: 20px 0px;
	margin-bottom: 40px;
    text-align: center;
    background: #e2e7f0;
    position: relative;
	border-radius: 100px;
}
.job-detail--top-in .info h3:after {
	content: '';
	display:block;
	width: 0;
	height: 0;
	margin-left: -10px;
	border-style: solid;
	border-width: 15px 10px 0 10px;
	border-color: #e2e7f0 transparent transparent transparent;
	position: absolute;
	left:50%;
	bottom: -13px;
}
.job-detail--top-in .info p {
    font-size: 13px;
    margin-bottom: 20px;
}
.job-detail--top-in .info ul li {
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 10px;
    padding-left: 30px;
    position: relative;
}
.job-detail--top-in .info ul li:before {
    content: '●';
    color: #2e599d;
	position: absolute;
	left:0;
	top:0;
}
.job-detail--top-in .info ul li h4 {
	font-size: 18px;
}

.job-detail--point {
    padding: 110px 0;
/*	margin-bottom: 100px;*/
    background: #e6edf4;
}
.job-detail--point h2 {
   font-size: 46px;
    font-family: var(--font-en);
    line-height: 1;
    text-align: center;
    top: -132px;
    position: relative;
}
.job-detail--point ul li {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    justify-content: space-between;
    margin-bottom: 100px;
}
.job-detail--point ul li:nth-child(even) {
	    flex-direction: row-reverse;
}
.job-detail--point ul li:last-child {
    margin-bottom: 0;
}
.job-detail--point ul li .img {
	width: 48%;
}
.job-detail--point ul li .info {
	width: 48%;
}
.job-detail--point ul li .info h3 {
	font-size: 24px;
	line-height: 1.5;
	border-left: solid 8px #2b579c;
	padding-left: 10px;
	margin-bottom: 20px;
}
.job-detail--point ul li .info p {
	font-size: 15px;
	line-height: 2.2;
}

.job-detail--flow h2 {
    font-size: 46px;
    font-family: var(--font-en);
    line-height: 1;
	margin-bottom: 30px;
    text-align: center;
}
.job-detail--flow h3 {
	font-size: 22px;
	margin-bottom: 80px;
    text-align: center;
}
.job-detail--flow h3 span {
	font-weight: bold;
    color: #29569b;
}
.job-detail--flow-in {
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	width: 100%;
    justify-content: center;
}
.flow-type {
	width: 48%;
}
.flow-type:nth-child(2) {
	margin-left: 4%;
}
.flow-type h4 {
	font-size: 22px;
	padding: 15px;
	margin-bottom: 50px;
	text-align:center;
	position: relative;
}
.flow-type h4:after {
	content: '';
	display:block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 15px 10px 0 10px;
	position: absolute;
	left:40%;
	bottom: -15px;
}
.flow-type h4 span {
	font-size: 20px;
}
.flow-type p {
	font-size: 15px;
	margin-top: 30px;
	line-height:2;
}

.flow-type table {
	font-size: 18px;
	width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border-radius: 10px;
    overflow: hidden;
}
.flow-type table th {
	width: 120px;
	padding: 15px 0;
	vertical-align: top;
}
.flow-type table td {
	color: #444444;
	padding: 15px;
	position: relative;
}

.flow-type01 h4 {
	color: #29569b;
	background: #e2e7f0;
}
.flow-type01 h4:after {
	border-color: #e2e7f0 transparent transparent transparent;
}
.flow-type01 table {
	border:solid 2px #29569b;
}
.flow-type01 table th {
	background: #e2e7f0;
}

.flow-type02 h4 {
	color: #e75c00;
	background: #fde9c9;
}
.flow-type02 h4:after {
	border-color: #fde9c9 transparent transparent transparent;
}
.flow-type02 table {
	border:solid 2px #e75c00;
}
.flow-type02 table th {
	background: #fde9c9;
}

.fuki {
    color: #e75c00;
    font-size: 14px;
    font-weight: bold;
    padding: 10px;
    background: #fde9c9;
	text-align:center;
    border-radius: 10px;
    border: solid 2px #e75c00;
}

/* job-detail--scene */
.job-detail--scene {
    margin-top: 100px;
}
.job-detail--scene .scene-main--title {
    font-size: 30px;
    text-align: center;
    color: #2b579c;
}
.job-detail--scene .scene-main--title-sub {
    font-size: 20px;
    text-align: center;
    margin-top: 10px;
    margin-bottom: 40px;
}
.job-detail--scene .scene-text {
    text-align: center;
    line-height: 2;
    margin-bottom: 50px;
}
.job-detail--scene .scene-main--subtitle {
    font-size: 24px;
    color: #fff;
    background: #2b579c;
    text-align: center;
    padding: 10px;
    margin-bottom: 50px;
}
.job-detail--scene .scene__list {
    display: flex;
    flex-wrap: wrap;
}
.job-detail--scene .scene__list > li {
    width: 48%;
    margin: 0 0 50px 4%;
    text-align: center;
}
.job-detail--scene .scene__list > li:nth-child(2n+1) {
    margin-left: 0;
}
.job-detail--scene .scene__list > li p {
    display: inline-block;
    font-size: 20px;
    font-weight: 500;
    color: #fff;
    background: #2b579c;
    padding: 8px 20px 10px;
    border-radius: 100px;
    margin-top: 20px;
}


/* job-detail--list */
.job-detail--list {
    margin-top: 140px;
}
.job-detail--list h2 {
	font-size: 22px;
	padding: 15px 0;
	margin-bottom: 70px;
	text-align:center;
	background: #eeeeee;
}
.job-detail--list h2 span {
	color: var(--main-color);
}



/*---------------------------------

6:requirements

----------------------------------*/
.requirement-list-group {
    margin-bottom: 50px;
}
.requirement-list-group .requirement-list-group-title {
    color: var(--main-color);
    font-size: 18px;
    font-weight: 500;
    padding: 8px;
    margin-bottom: 30px;
    border-top: solid 2px var(--main-color);
    border-bottom: dotted 1px var(--main-color);
}



.requirement-list {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.requirement-list > li {
    width: 32%;
    margin: 0 0 5% 2%;
	border:solid 1px #cccccc;
	border-radius: 10px;
	overflow: hidden;
}
.requirement-list > li:nth-child(3n+1) {
    margin-left: 0;
}
.requirement-list li a {
	color: #000;
	display: block;
	padding: 20px 20px 90px;
	height: 100%;
	position: relative;
}
.requirement-list .thumb {
    text-align: center;
    margin-bottom: 20px;
	position: relative;
}
.requirement-list .pr {
    font-size: 13px;
    font-weight: 600;
    padding: 2px 15px;
    color: #000;
    background: yellow;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 10;
}
.requirement-list .requirement-job {
    margin-top: 10px;
	text-align: left;
}
.requirement-list .requirement-job span {
    font-size: 12px;
    color: #fff;
    padding: 2px 10px 5px;
    margin: 5px 5px 0 0;
    background: #222;
    display: inline-block;
}
.requirement-title {
    font-size: 18px;
    padding-left: 15px;
    margin-bottom: 15px;
    border-left: solid 5px var(--main-color);
}
.requirement-desc {
    font-size: 14px;
    line-height: 1.8;
    margin-bottom: 20px;
}
.requirement-info li {
	font-size: 14px;
	line-height: 1.8;
}
.requirement-btn {
	color: var(--main-color);
	font-size: 14px;
	width: 80%;
	line-height: 40px;
	margin-left: -40%;
	text-align:center;
	border:solid 1px var(--main-color);
	border-radius: 100px;
	position: absolute;
	bottom:20px;
	left: 50%;
	   -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}
.requirement-list li a:hover .requirement-btn {
	color: #fff;
	background: var(--main-color);
}


/**/
.requirement-in {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    flex-direction: row-reverse;
    justify-content: space-between;
}
.requirement-con {
    width: calc(100% - 250px);
}


#side-nav {
    width: 220px;
}
.side-nav-in {
    margin-bottom: 50px;
}
#side-nav h3 {
    font-size: 15px;
    font-weight: normal;
    padding: 10px;
    margin-bottom: 20px;
    border-top: solid 2px #333;
    border-bottom: dashed 1px #333;
}
.search-location li {
    margin-bottom: 10px;
    border: solid 1px #eee;
}
.search-location li a {
    display: table;
    width: 100%;
    color: #333;
}
.search-location li .icon {
    display: table-cell;
    width: 50px;
}
.search-location li p {
    display: table-cell;
    font-size: 11px;
    vertical-align: middle;
    padding-left: 10px;
}
.search-type li {
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 10px;
}
.search-type li:before {
    content: '';
    display: inline-block;
    width: 5px;
    height: 5px;
    color: var(--main-color);
    border-top: solid 1px;
    border-right: solid 1px;
    vertical-align: 2px;
    transform: rotate(45deg);
    margin-right: 5px;
}
.search-type li a {
    color: #333;
}



/* detail */
.requirement-detail--main h3 {
    font-size: 22px;
    text-align: center;
    margin-bottom: 70px;
}
.requirement-detail--main table {
	font-size: 15px;
	text-align: left;
	line-height: 2;
	width: 100%;
	border-top: dotted 1px #000;
	border-collapse: collapse;
}
.requirement-detail--main table th {
	width: 220px;
	border-bottom: dotted 1px #000;
	padding: 25px;
	vertical-align: top;
	background: #f5f5f5;
}
.requirement-detail--main table td {
	border-bottom: dotted 1px #000;
	padding: 25px;
}

.requirement-detail--sub {
	margin-top: 160px;
	padding: 70px 0;
	background: #f5f4e9;
}
.requirement-detail--sub h3 {
	font-size: 22px;
	text-align:center;
	margin-bottom: 15px;
}
.requirement-detail--sub p {
	font-size: 12px;
	text-align:center;
}
.requirement-detail--sub table {
	font-size: 15px;
	width:100%;
	max-width: 560px;
	border-collapse: collapse;
	margin: 40px auto 60px;
	text-align: left;
}
.requirement-detail--sub table th {
	padding: 20px 0;
	width: 160px;
}
.requirement-detail--sub table td {
	padding: 20px 0;
}
.cmn-input-r {
    background: #fff;
    width: 100%;
    height: 50px;
    border: none;
}
#btn-entry {
    display: block;
    font-size: 18px;
    font-weight: bold;
    width: 260px;
    height: 55px;
    margin: auto;
    color: #fff;
    background: var(--main-color);
    border-radius: 100px;
    cursor: pointer;
}
#hidden-form {
    display: none;
}






/*---------------------------------

6:voice

----------------------------------*/
.voice-header {
    text-align: center;
	margin-bottom: 120px;
}
.voice-header h2 {
	color: var(--main-color);
    font-size: 46px;
    font-family: var(--font-en);
}
.voice-header p {
    font-weight: bold;
    font-size: 22px;
    margin-bottom: 20px;
}
.voice-header p span {
    color: #345ea0;
}

.voice-group:not(:last-child) {
	margin-bottom: 80px;
}
.voice-group h3 {
	font-size: 25px;
	text-align:center;
	margin-bottom: 70px;
}

.voice-list {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.voice-list li {
    width: 32%;
    margin: 0 0 50px 2%;
}
.voice-list li:nth-child(3n+1) {
    margin-left: 0;
}
.voice-list li a {
	color: #000;
	display: block;
	height: 100%;
	text-align: center;
    padding: 10px 10px 30px;
    border: solid 2px var(--main-color);
    border-radius: 5px;
}

.voice-list .thumb {
    text-align: center;
    margin-bottom: 20px;
	position:relative;
}
.voice-list .thumb .voice-year {
    font-size: 13px;
    font-weight: 500;
    padding: 5px 10px;
    color: #fff;
    background: var(--main-color);
    position: absolute;
    right: 0;
    bottom:  0;
}
.voice-list .voice-job {
    font-size: 17px;
	font-weight:bold;
	color: var(--main-color);
	margin-bottom: 5px;
}
.voice-list .voice-name {
    font-size: 22px;
	font-weight:bold;
	margin-bottom: 10px;
}
.voice-list .voice-comment {
    font-size: 13px;
    line-height: 1.7;
	text-align: left;
}


/* -single */
.voice-detail--header {
    margin-bottom: 80px;
}
.voice-detail--header-in {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
	width: 100%;
}
.voice-detail--header-img {
    width: 55%;
	position: relative;
}
.voice-detail--header-info {
    font-weight: 500;
    width: 45%;
    padding-left: 5%;
    line-height: 2;
}
.voice-detail--header-in .voice-office {
    display: inline-block;
    font-size: 15px;
    line-height: 1;
    padding: 5px 15px 7px;
    background: var(--main-color);
    vertical-align: 3px;
    color: #fff;
}
.voice-detail--header-in .voice-job {
    font-size: 24px;
    font-weight: bold;
	color:var(--main-color);
}
.voice-detail--header-in .voice-name {
    font-size: 22px;
}
.voice-detail--header-in .voice-name .year{
    font-size: 15px;
	margin-left:20px;
}
.voice-detail--con h3 {
    font-size: 40px;
    font-family: var(--font-en);
    font-weight: 100;
    text-align: center;
    line-height: 1;
    margin-bottom: 70px;
    color: var(--main-color);
}
.interview-list >li:not(:last-child) {
	margin-bottom: 50px;
}
.interview-q {
    font-size: 18px;
    font-weight: bold;
    background: #fcf1e8;
    padding: 20px 20px 20px 80px;
    margin-bottom: 30px;
    position: relative;
    border-radius: 200px;
}
.interview-q:before {
    content: 'Q.';
    font-size: 25px;
    font-family: var(--font-en);
    color: var(--main-color);
    position: absolute;
    left: 45px;
    top: 15px;
}
.interview-a {
    font-size: 15px;
    line-height: 2.2;
    margin: 0 50px;
}


.interview-img {
	margin-top: 70px;
}
.interview-img--list {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    justify-content: space-between;
	margin-top: -4%;
}
.interview-img--list li {
    width: 48%;
	margin-top: 4%;
}


.voice-detail--link {
    text-align: center;
    margin-top: 70px;
}
.voice-detail--link a {
    display: inline-block;
    font-size: 16px;
    font-weight: 500;
    margin: auto;
    padding: 15px 30px;
    color: var(--main-color);
	border:solid 1px;
    border-radius: 200px;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.voice-detail--link a:after {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	border-top:solid 2px;
	border-right:solid 2px;
	transform: rotate(45deg);
	vertical-align: 1px;
	margin-left:10px;
}
.voice-detail--link a:hover {
	color: #fff;
    background: var(--main-color);
}


/* ------------------------
interview 
--------------------------*/
.interview__list {
	display: flex;
	flex-wrap: wrap;
}
.interview__list >li {
	width: 30%;
	margin: 0 0 50px 5%;
}
.interview__list >li:nth-child(3n+1) {
    margin-left: 0;
}
.interview__list >li a {
	display:block;
	color: var(--base-color);
}
.interview__list .interview-img {
	position:relative;
	margin-top: 0;
	margin-bottom: 15px;
}
.interview__list .interview-img img {
    border-radius: 100% 100% 0 0;
    overflow: hidden;
}
.interview__list .interview-catch {
    position: absolute;
	left: -20px;
	bottom: 50px;
}
.interview__list .interview-catch span {
	display: inline-block;
	font-size: 18px;
	color: #fff;
	background: var(--main-color);
	margin:2px 0;
	padding: 1px 5px;
}
.interview__list .interview-info-type {
	font-size: 22px;
	font-weight: 500;
	color: var(--main-color);
}
.interview__list .interview-info-office {
	font-size: 14px;
	line-height: 1.6;
	margin-top: 5px;
}


/* single */
#interview-detail {
	
}
.interview-detail--header {
    margin-bottom: 100px;
}
.interview-detail--header-in {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
}
.interview-detail--header-img {
    width: 48%;
}
.interview-detail--header-img img {
    border-radius: 10px;
    overflow: hidden;
}
.interview-detail--header-info {
    width: 48%;
    line-height: 2;
}
.interview-detail--header-info .interview-office {
    font-size: 15px;
    color: var(--main-color);
}
.interview-detail--header-info .interview-job {
    display: inline-block;
    font-size: 14px;
    color: #fff;
    background: var(--main-color);
    padding: 0 10px;
    border-radius: 1000px;
    vertical-align: middle;
    margin-right: 10px;
}
.interview-detail--header-info .interview-name {
    display: inline-block;
    font-size: 24px;
    vertical-align: middle;
}
.interview-detail--header-info .interview-catch {
    margin-top: 40px;
}
.interview-detail--header .interview-catch span {
    display: inline-block;
    font-size: 18px;
    color: #fff;
    background: var(--main-color);
    margin: 2px 0;
    padding: 1px 5px;
}


.interview-detail-title {
    font-size: 40px;
    font-weight: 100;
    text-align: center;
    margin-bottom: 70px;
    color: var(--main-color);
}

.interview-schedule {
    margin-top: 100px;
}
.interview-schedule-in {
    display: flex;
    justify-content: space-between;
}
.interview-schedule-wrap {
    width: calc(100% - 550px);
    padding: 30px;
    background: #fcf1e8;
    border-radius: 10px;
}
.interview-schedule-wrap h3 {
    color: #fff;
    font-size: 30px;
    font-weight: 100;
    text-align: center;
    padding: 10px;
    border-radius: 5px;
    margin-bottom: 30px;
    background: var(--main-color);
}
.interview-schedule__list >li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
    font-weight: 500;
    position: relative;
    z-index: 1;
    background: #fff;
    padding: 10px;
    border-radius: 5px;
}
.interview-schedule__list >li:not(:last-child):after {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-color: var(--main-color) transparent transparent transparent;
    border-width: 20px 20px 0px 20px;
    position: absolute;
    bottom: -30px;
    left: calc(50% - 20px);
}
.interview-schedule__list .sch-time {
    font-family: var(--font-en);
    font-weight: 100;
    width: 60px;
    text-align: center;
    line-height: 1;
    padding: 5px 0 2px;
    border-radius: 10px;
    background: var(--main-color);
    color: #fff;
}
.interview-schedule__list .sch-detail {
    width: calc(100% - 80px);
}


.interview-schedule-img {
    width: 500px;
}
.interview-schedule-img .img {
	text-align: center;
    margin-bottom: 20px;
}
.interview-schedule-img p {
    font-size: 14px;
    line-height: 2;
}

/*---------------------------------

7:benefit

----------------------------------*/
.benefit-nav--list {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.benefit-nav--list li {
    width: 31%;
	margin:0 0 20px 3.5%;
    display: -webkit-flex;
    display: flex;
    justify-content: center;
    align-items: center;
}
.benefit-nav--list li:nth-child(3n+1) {
	margin-left: 0;
}
.benefit-nav--list li a {
    color: #000;
	display: block;
	font-size: 20px;
	font-weight:bold;
    width: 100%;
    padding: 18px 0;
    text-align: center;
    border-radius: 100px;
}
.benefit-nav--list li a:after {
	content: '';
	display: inline-block;
	width:10px;
	height:10px;
	margin-left:15px;
	border-top: solid 2px #000;
	border-right: solid 2px #000;
	transform: rotate(45deg);
	vertical-align: middle;
}
.benefit-nav--list li.benefit01 a { background-color: #efecdf; }
.benefit-nav--list li.benefit02 a { background-color: #d8e0ee; }
.benefit-nav--list li.benefit03 a { background-color: #fde7ed; }
.benefit-nav--list li.benefit04 a { background-color: #fbe1d6; }
.benefit-nav--list li.benefit05 a { background-color: #d8eaee; }
.benefit-nav--list li.benefit06 a { background-color: #d8eee4; }
.benefit-nav--list li.benefit07 a { background-color: #edf3c9; }
.benefit-nav--list li.benefit08 a { background-color: #e7e7e7; }

.benefit-item {
	margin-top: 90px;
}
.benefit-item h3 {
	font-size: 22px;
	text-align:center;
	padding: 15px 0;
	margin-bottom: 55px;
}
.benefit-item table {
	width: 100%;
	max-width: 800px;
	margin: auto;
	line-height: 2;
    border-collapse: separate;
    border-spacing: 0;
	border-radius:10px;
	overflow: hidden;
}
.benefit-item table th {
	font-size: 17px;
	font-weight: bold;
	width: 210px;
	padding: 25px 20px;
	text-align: left;
	vertical-align: top;
}
.benefit-item table td {
	font-size: 15px;
	padding: 25px 20px;
}
.benefit-item table td .img {
	margin-top: 60px;
}
.benefit-item table tr:last-child th,
.benefit-item table tr:last-child td{
	border-bottom: none !important;
}
#benefit01 h3 {
	background: #f2f1ed;
}
#benefit01 table {
	border:solid 2px #958657;
}
#benefit01 table th,
#benefit01 table td {
	border-bottom:solid 1px #958657;
}
#benefit01 table th {
    background: #f2f1ed;
}

#benefit02 h3 {
	background: #d8e0ee;
}
#benefit02 table {
	border:solid 2px #778eb5;
}
#benefit02 table th,
#benefit02 table td {
	border-bottom:solid 1px #778eb5;
}
#benefit02 table th {
    background: #d8e0ee;
}

#benefit03 h3 {
	background: #fde7ed;
}
#benefit03 table {
	border:solid 2px #778eb5;
}
#benefit03 table th,
#benefit03 table td {
	border-bottom:solid 1px #778eb5;
}
#benefit03 table th {
    background: #fde7ed;
}

#benefit04 h3 {
	background: #fbe1d6;
}
#benefit04 table {
	border:solid 2px #cd7550;
}
#benefit04 table th,
#benefit04 table td {
	border-bottom:solid 1px #cd7550;
}
#benefit04 table th {
    background: #fbe1d6;
}

#benefit05 h3 {
	background: #d8eaee;
}
#benefit05 table {
	border:solid 2px #77bbc7;
}
#benefit05 table th,
#benefit05 table td {
	border-bottom:solid 1px #77bbc7;
}
#benefit05 table th {
    background: #d8eaee;
}

#benefit06 h3 {
	background: #d8eee4;
}
#benefit06 table {
	border:solid 2px #5dbb90;
}
#benefit06 table th,
#benefit06 table td {
	border-bottom:solid 1px #5dbb90;
}
#benefit06 table th {
    background: #d8eee4;
}

#benefit07 h3 {
	background: #edf3c9;
}
#benefit07 table {
	border:solid 2px #b4c25e;
}
#benefit07 table th,
#benefit07 table td {
	border-bottom:solid 1px #b4c25e;
}
#benefit07 table th {
    background: #edf3c9;
}

#benefit08 h3 {
	background: #e7e7e7;
}
#benefit08 table {
	border:solid 2px #b4b4b4;
}
#benefit08 table th,
#benefit08 table td {
	border-bottom:solid 1px #b4b4b4;
}
#benefit08 table th {
    background: #e7e7e7;
}


/*---------------------------------

8:

----------------------------------*/
.policy-list {
    margin-bottom: 60px;
}
.policy-list > li {
    padding: 70px 0;
}
.policy-list > li:first-child{
    padding-top: 0;
}
.policy-list > li:nth-child(even) {
    background: #ecf0f7;
}
.policy-list > li .inner {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
}
.policy-group--img {
    width: 48%;
    display: inline-block;
    vertical-align: top;
}
.policy-group--info {
    width: 48%;
    display: inline-block;
	margin-left: 4%;
}
.policy-group--info h3 {
	font-size: 23px;
	padding-left: 10px;
	margin-bottom: 20px;
	border-left: solid 7px #29559b;
}
.policy-group--info p {
	line-height: 2.2;
}
.policy-list > li:nth-child(even) .inner {
    flex-direction: row-reverse;
}
.policy-list > li:nth-child(even) .policy-group--info {
	margin-left:0;
	margin-right: 4%;
}

.policy-sub {
    display: table;
    margin: auto;
}
.policy-sub--img {
    display: table-cell;
    width: 190px;
    vertical-align: middle;
    padding-right: 30px;
}
.policy-sub--info  {
    display: table-cell;
    background: rgba(251,230,231,0.7);
    position: relative;
    padding: 30px 40px;
    border-radius: 20px;
}
.policy-sub--info:before  {
    content: '';
    color: #fbe6e7;
    position: absolute;
    left: -15px;
    top: 45%;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 15px 15px 0 15px;
    border-color: rgba(251,230,231,0.7) transparent transparent transparent;
}
.policy-sub--info p {
    font-size: 18px;
    font-weight: bold;
    line-height: 2.2;
}



/*---------------------------------

9:faq

----------------------------------*/
.faq-list >li:not(:last-child) {
	margin-bottom: 40px;
}
.faq-list h3 {
    font-size: 18px;
    padding: 10px 80px;
	margin-bottom: 30px;
    border-radius: 100px;
    position: relative;
    background: #e6edf4;
}
.faq-list h3 span {
    font-size: 25px;
    font-family: var(--font-en);
    color: #29569c;
    position: absolute;
    left: 40px;
    top: 3px;
}
.faq-list .faq-a {
	font-size: 15px;
	line-height: 2;
	padding: 0 40px;
}
.faq-list .faq-a h4 {
	font-size: 15px;
}
.faq-list .faq-a p:not(:last-child) {
	margin-bottom: 30px;
}


/*---------------------------------

10:contact

----------------------------------*/
#contact .text01 {
    font-size: 13px;
    text-align: center;
}
.required {
    color: #ff0000;
}
.contact-group {
	margin-top: 100px;
}
.contact-group h3 {
    font-size: 22px;
    text-align: center;
    background: #eee;
    padding: 15px 0;
    margin-bottom: 50px;
}
.contact-list {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.contact-list li {
    width: 30%;
    margin-left: 5%;
	padding-bottom: 15px;
	text-align:center;
    border: solid 2px #d8e0ee;
	border-radius: 10px;
}
.contact-list li:first-child {
	margin-left: 0;
}
.contact-list li h4 {
	font-size: 18px;
	padding: 10px 0;
	background: #d8e0ee;
	margin-bottom:20px;
}
.contact-list li .tel {
	font-size: 25px;
	font-weight: bold;
	color: var(--main-color);
    margin-bottom: 5px;
}
.contact-list li .open {
	font-size: 13px;
}
#contact-form {
    margin-top: 70px;
}
#contact-form table {
    font-size: 18px;
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 60px;
}
#contact-form table th {
    font-weight: normal;
    width: 240px;
    text-align: left;
    padding-top: 15px;
    vertical-align: top;
}
#contact-form table td {
    padding-bottom: 40px;
}
#contact-form table td.td01 {
    padding-top: 15px;
}
.check-policy {
    text-align: center;
    margin: 50px;
}
.check-policy a {
    text-decoration: underline;
	color: #444;
}
.check-policy .wpcf7-list-item-label {
    display: none;
}
.cmn-input,
.cmn-input-s,
.cmn-input-m,
.cmn-select,
.cmn-select-s,
.cmn-textarea {
	font-size: 16px;
}

.cmn-input {
    width: 64%;
    height: 60px;
    border: none;
	background: #f0f0f0;
    text-indent: 10px;
}
.cmn-input-s {
    width: 10%;
    height: 60px;
	text-align:right;
    border: none;
	background: #f0f0f0;
}
.cmn-input-m {
    width: 80%;
    height: 60px;
    border: none;
	background: #f0f0f0;
    text-indent: 10px;
}
.cmn-select {
    width: 64%;
    height: 60px;
    border: none;
	background: #f0f0f0;
}
.cmn-select-s {
    width: 30%;
    height: 60px;
    border: none;
	background: #f0f0f0;
}
.cmn-textarea {
    width: 90%;
    height: 320px;
    border: none;
	background: #f0f0f0;
    padding: 10px;
}
.btn-wrap {
	width: 100%;
    max-width: 290px;
    margin: auto;
	position: relative;
}
.btn-wrap:after {
    content: '';
    display: inline-block;
    width: 10px;
    height: 10px;
    margin-top: -5px;
    vertical-align: middle;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(45deg);
    position: absolute;
    right: 23%;
    top: 50%;
}
#btn-send {
    display: block;
    font-size: 20px;
    color: #fff;
	width:100%;
    padding: 15px 0;
    background: var(--main-color);
	border: none;
	cursor: pointer;
    border-radius: 100px;
}


/*---------------------------------

11:news

----------------------------------*/
.post-in {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
#post-contents {
    width: calc(100% - 300px);
}
.archive-title {
    margin-bottom: 20px;
}

#post-sidebar {
    width: 200px;
    margin-left: 100px;
}
#post-sidebar a {
	display: inline-block;
    color: #000;
    -webkit-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out;
    border-bottom: solid 1px transparent;
}
#post-sidebar a:hover {
	border-bottom: solid 1px #000;
}
.sideBox {
    margin-bottom: 50px;
}
.side-title {
    font-size: 21px;
    font-family: "didot";
    font-weight: normal;
    line-height: 1;
    padding-bottom: 10px;
    margin-bottom: 10px;
    border-bottom: dotted 1px #cccccc;
}
.side-category--list li {
    font-size: 13px;
    margin-bottom: 5px;
}
.side-category--list li:last-child {
	margin-bottom: 0;
}
.side-latest--list >li:not(:last-child) {
    margin-bottom: 20px;
}
.latest-date {
    font-size: 11px;
}
.latest-title {
    font-size: 13px;
}
.side-archive--list {
    font-size: 13px;
}
.archive-year {
    font-size: 13px;
}
.side-archive--list ul {
    line-height: 2;
    margin-left: 10px;
}

/* archive */
.page-post--catname {
    margin-bottom: 20px;
}
.post-list {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.post-list > li {
	width: 48%;
	margin: 0 0 4% 4%;
}
.post-list > li:nth-child(2n+1) {
	margin-left: 0;
}

.post-list > li a {
    display: block;
    height: 100%;
    background: #fff;
    border: solid 1px #eee;
    border-radius: 10px;
    overflow: hidden;
}
.post-list .post-thumb {
    padding-top: 65%;
    position: relative;
    height: 0;
    overflow: hidden;
}
.post-list .post-thumb img {
	width: 100%;
	position: absolute;
	top:0;
	left: 0;
}
.post-list .post-thumb .cat {
    font-size: 12px;
    color: #fff;
    padding: 2px 10px 4px;
    background: var(--main-color);
    position: absolute;
    right: 0;
    bottom: 0;
	z-index: 1;
}
.post-list .post-info {
	padding: 10px;
}
.post-list .post-info--date {
    color: var(--main-color);
    font-size: 18px;
    font-family: var(--font-en);
}
.post-list .post-info--title {
	color: #222;
	font-size: 16px;
    font-weight: 500;
}


#cmn-pager {
    text-align: center;
    margin-top: 130px;
}
#cmn-pager .wp-pagenavi a,
#cmn-pager .wp-pagenavi span {
    padding: 3px 10px;
    color: #000;
	border: none;
}
#cmn-pager .wp-pagenavi span.current {
	color: #fff;
	background: var(--main-color);
}
#post-header {
    margin-bottom: 30px;
    border-bottom: solid 1px #444;
}
#post-header .post-date,
#post-header .post-category {
    display: inline-block;
}
#post-header .post-date {
    margin-left: 0;
}
#post-header .post-title {
	font-size: 20px;
}
#post-header .post-category {
    font-size: 12px;
    color: #fff;
    padding: 2px 10px 4px;
	margin-left:10px;
    background: var(--main-color);
}

#cmn-pager {
    text-align: center;
    margin-top: 100px;
}
#cmn-pager .wp-pagenavi a,
#cmn-pager .wp-pagenavi span {
    padding: 3px 10px;
    color: #444;
}

#post-pager {
    margin-top: 100px;
    text-align: center;
}
#post-pager div {
    display: inline-block;
    margin: 0 20px;
}
#post-pager .prev a,
#post-pager .next a{
    color: #444;
}
#post-pager .return a {
    color: var(--main-color);
}

/*---------------------------------

12:privacy-policy

----------------------------------*/
.privacy-policy-in {
	font-size: 15px;
    line-height: 2;
}
.privacy-policy-in .text01 {
	margin-bottom: 40px;
}
.privacy-policy-in h3 {
	font-size: 17px;
	margin-bottom: 10px;
}
.privacy-policy-in .list01 > li {
    margin-bottom: 30px;
}
.privacy-policy-in .list02 > li {
	padding-left:30px;
	position: relative;
}
.privacy-policy-in .list02 > li span {
	position: absolute;
	left:0;
	top:0;
}

/*---------------------------------

13:404

----------------------------------*/
#page404 {
    text-align: center;
    margin-bottom: 100px;
}
#page404 .back a {
	color:#000524;
	text-decoration:underline;
}



/*---------------------------------

14:welfare

----------------------------------*/
.welfare-nav {
    text-align: center;
}
.welfare-nav__list {
    display: inline-block;
    background: #ffefe9;
    border-radius: 1000px;
    padding: 10px 50px;
}
.welfare-nav__list >li {
    display: inline-block;
}
.welfare-nav__list >li:not(:first-child) {
    margin-left: 15px;
}
.welfare-nav__list >li:not(:first-child):before {
    content: '|';
    margin-right: 15px;
}
.welfare-nav__list >li a {
    display: inline-block;
    padding: 5px 30px;
    color: var(--base-color);
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.welfare-nav__list >li.active a,
.welfare-nav__list >li a:hover {
    color: #fff;
    background: var(--main-color);
}

.welfare-box {
    margin-top: 70px;
}
.welfare-box h3 {
    font-size: 24px;
    color: var(--main-color);
    margin-bottom: 30px;
}
.welfare-box h3:before {
    content: '●';
    margin-right: 10px;
}

.welfare01-detail-in {
    display: flex;
	justify-content: space-between;
    margin-bottom: 30px;
}
.welfare01-detail-img {
    width: 400px;
}
.welfare01-detail-img img {
    border-radius: 10px;
	overflow: hidden;
}
.welfare01-detail-text {
    width: calc(100% - 450px);
}
.welfare01-detail-text h4 {
    color: var(--main-color);
    font-size: 24px;
}
.welfare01-detail-text p {
    font-size: 15px;
    line-height: 1.6;
    margin-top: 10px;
}

.welfare01-detail {
	margin-bottom: 100px;
}

.welfare-box table {
    font-size: 14px;
    width: 100%;
    line-height: 2;
    border-top: solid 1px #ccc;
    border-left: solid 1px #ccc;
    border-collapse: collapse;
}
.welfare-box table th {
    padding: 15px;
    border-right: solid 1px #ccc;
    border-bottom: solid 1px #ccc;
    vertical-align: top;
	text-align: left;
	width: 400px;
    background: #ffefe9;
}
.welfare-box table td {
    padding: 15px;
    border-right: solid 1px #ccc;
    border-bottom: solid 1px #ccc;
    vertical-align: top;
}
/*
#welfare02 h3 {
    color: #43a56a;
}
#welfare02 table th {
	background: #daf1e3;
}
#welfare03 h3 {
    color: #7f9cd2;
}
#welfare03 table th {
	background: #cfdbf2;
}
*/


.welfare-img__list {
    display: flex;
    justify-content: space-between;
    margin-top: 50px;
}
.welfare-img__list >li {
    width: 33%;
}

/* -----------------------------------

media query

------------------------------------- */
@media (max-width: 815px) {

	#page-fv .inner {
		height: 300px;
	}
	.page-fv-in h2 {
		font-size: 35px;
	}
	.page-fv-in p {
		font-size: 16px;
	}
	#page-contents {
		margin-bottom: 0;
	}

	.message-con {
		display: block;
		width: 100%;
		margin-bottom: 40px;
	}
	.message-con--img {
		display: block;
		width: 100%;
		margin-bottom: 30px;
		text-align:center;
	}
	.message-con--info {
		display: block;
		padding-left: 0;
		padding-top: 0;
	}
	.message-con--info .text01 {
		font-size: 21px;
	}
	.message-con--info .text02 {
		font-size: 14px;
		font-weight: bold;
	}
	.message-con--info .text02 span {
		font-size: 18px;
	}
	.philosophy-main h4 {
		font-size: 21px;
		margin-bottom: 30px;
	}
	.philosophy-main h4 span {
		font-size: 16px;
	}
	.philosophy-main .text01 {
		font-size: 13px;
		text-align: left;
	}
	.philosophy-main .text02 {
		font-size: 16px;
		margin: 20px 0;
		text-align: left;
	}
	#message-workplace .copy {
		font-size: 26px;
		margin-bottom: 40px;
	}
	.workplace-step > ul > li {
		display: block;
		width: 100%;
	}
	.workplace-step .img {
		display: block;
		width: 100%;
		border-radius: 10px 10px 0 0;
		overflow: hidden;
	}
	.workplace-step .info {
		display: block;
		width: 100%;
		border-radius: 0;
	}
	.workplace-step .info h3 {
		padding: 10px 0 10px 20px;
	}
	.workplace-step .info ul {
		padding: 20px 10px;
	}
	.workplace-award {
		display: block;
	}
	.workplace-award .img {
		display: block;
		width: 100%;
		margin-bottom: 30px;
	}
	.workplace-award .info {
		display: block;
		padding-left: 0;
	}

	.message-concept--image > ul > li {
		display: block;
	}
	.message-concept--image ul li .img {
		width: 100%;
	}
	.message-concept--image ul li .info,
	.message-concept--image > ul > li:nth-child(even) .info {
		width: auto;
		padding: 20px;
		background: #fff;
		margin: -100px 20px 0;
		position: relative;
	}
	.message-concept--image ul li .info h3 {
		font-size: 24px;
		margin-bottom: 20px;
	}
	.earnings {
		display: block;
		text-align: center;
	}
	.action-main ul li h4 {
		font-size: 16px;
		margin-bottom: 20px;
	}
	.action-main ul li p {
		font-size: 12px;
	}

	.introduction-group .inner {
		display: block;
	}
	.introduction-img {
		width: 100%;
		margin-bottom:30px;
	}
	.introduction-group .introduction-img img {
		margin: 0;
		width: auto;
		max-width: 100%;
	}
	.introduction-group:nth-child(even) .introduction-img--main img {
		margin: 0;
	}
	.introduction-img--sub {
		width: 100%;
	}
	.introduction-group:nth-child(even) .introduction-img--sub {
		margin: 0;
	}

	.introduction-info {
		width: 100%;
		right: auto !important;
		left: auto !important;
	}
	.introduction-info--tel {
		margin-bottom: 40px;
	}

	.job-list li {
		width: 100%;
		max-width: 600px;
		margin: 0 auto 50px !important;
	}

	.job-detail--top-in .img {
		display: block;
		width: 100%;
		text-align: center;
		margin-bottom: 30px;
	}
	.job-detail--top-in .info {
		display: block;
		padding-left: 0;
	}
	.job-detail--top-in .info h3 {
		font-size: 16px;
		padding: 10px 0px;
		margin-bottom: 30px;
	}
	.job-detail--top-in .info ul li {
		font-size: 12px;
	}
	.job-detail--top-in .info ul li h4 {
		font-size: 15px;
	}
	.job-detail--point ul li {
		display: block;
		width: 100%;
        margin-bottom: 50px;
	}
	.job-detail--point ul li .img {
		display: block;
		width: 100%;
		text-align: center;
		margin-bottom: 20px;
	}
	.job-detail--point ul li .info {
		display: block;
		padding-left: 0;
		width: auto;
	}
	.job-detail--point ul li .info h3 {
		font-size: 18px;
		border-left: solid 5px #2b579c;
	}
	.job-detail--point ul li .info p {
		font-size: 13px;
	}
	.job-detail--flow h3 {
		font-size: 18px;
	}
	.flow-type {
		width: 100%;
		margin-bottom: 50px;
	}
	.flow-type:nth-child(2) {
		margin-left: 0;
	}

    .job-detail--scene {
        margin-top: 70px;
    }
    .job-detail--scene .scene-main--title {
        font-size: 18px;
    }
    .job-detail--scene .scene-main--title-sub {
        font-size: 15px;
        margin-bottom: 30px;
    }
    .job-detail--scene .scene-text {
        text-align: left;
    }
    .job-detail--scene .scene-main--subtitle {
        font-size: 14px;
        margin-bottom: 30px;
    }
    .job-detail--scene .scene__list > li p {
        display: block;
        font-size: 12px;
        padding: 3px 5px 5px;
        margin-top: 10px;
    }

	.job-detail--list {
		margin-top: 70px;
    }

/* voice */
	.voice-header p {
		font-size: 16px;
	}
	.voice-list li {
		width: 100%;
		margin: 0 auto 50px;
	}
	.voice-list .voice-catch {
		max-width: 600px;
		margin: 0 auto 10px;
	}

	.voice-detail--header-img {
		width: 100%;
		text-align: center;
		margin-bottom: 20px;
	}
	.voice-detail--header-info {
		width: 100%;
		padding-left: 0;
	}
	.voice-detail--header-in .voice-job {
		font-size: 12px;
	}
	.voice-detail--header-in .voice-name {
		font-size: 14px;
	}
	.interview-q {
		font-size: 14px;
		padding: 15px 15px 15px 50px;
		margin-bottom: 20px;
	}
	.interview-q:before {
		left: 20px;
		top: 12px;
	}
	.interview-a {
		font-size: 12px;
		margin: 0 20px;
	}
	.for-blank {
		padding: 20px 20px 60px;
	}
	.for-blank h4 {
		font-size: 16px;
		margin-bottom: 20px;
	}
	.for-blank p {
		font-size: 12px;
	}
	.voice-detail--other h3 {
		font-size: 16px;
	}
	.voice-detail--other .voice-list li {
		width: 100%;
		max-width: 600px;
		margin: 0 auto 50px;
	}

	.voice-header p {
		font-size: 16px;
	}

/* interview */
	.interview__list >li {
		width: 45%;
		margin: 0px 0 30px 10%;
	}
	.interview__list >li:nth-child(3n+1) {
		margin: 0px 0 30px 10%;
	}
	.interview__list >li:nth-child(2n+1) {
		margin-left: 0;
	}

	.interview__list .interview-catch {
		left: -10px;
		bottom: 10px;
	}
	.interview__list .interview-catch span {
		font-size: 10px;
	}
	.interview__list .interview-info-type {
		font-size: 16px;
	}
	.interview__list .interview-info-office {
		font-size: 12px;
	}

	.interview-detail--header-in {
		display: block;
	}
	.interview-detail--header-img {
		width: 100%;
		text-align: center;
		margin-bottom: 20px;
		position: relative;
	}
	.interview-detail--header-img .interview-catch {
		position: absolute;
		text-align: left;
		right: 10px;
		bottom: 10px;
	}
	.interview-detail--header-img .interview-catch span {
		font-size: 14px;
	}

	.interview-detail--header-info {
		width: 100%;
	}
	#interview-detail .voice-detail--con h3 {
		font-size: 24px;
		margin-bottom: 40px;
	}
	.interview-schedule-in {
		display: block;
	}
	.interview-schedule-wrap {
		width: 100%;
		padding: 30px 20px;
	}
	.interview-schedule-wrap h3 {
		font-size: 20px;
	}
	.interview-schedule-img {
		width: 100%;
	}
	.interview-schedule-img p {
		font-size: 12px;
	}

/**/
	.benefit-nav--list li a {
		font-size: 12px;
	}
	.benefit-nav--list li a:after {
		width: 5px;
		height: 5px;
	}

	.benefit-item table th {
		font-size: 13px;
		width: 100px;
		padding: 15px;
	}
	.benefit-item table td {
		font-size: 13px;
		padding: 15px;
	}

/* requirement */
	.requirement-nav--list li {
		width: 32%;
		margin-left: 2%;
	}
	.requirement-nav--list li a {
		font-size: 12px;
	}

	.requirement-list > li {
		width: 48%;
		margin: 0 0 4% 4%;
	}
	.requirement-list > li:nth-child(3n+1) {
		margin: 0 0 4% 4%;
	}
	.requirement-list > li:nth-child(2n+1) {
		margin-left: 0;
	}
	.requirement-list li a {
		padding: 10px 10px 90px;
	}
	.requirement-title {
		font-size: 12px;
		padding-left: 10px;
		border-left: solid 2px var(--main-color);
	}
	.requirement-desc {
		font-size: 11px;
	}
	.requirement-info li {
		font-size: 11px;
	}

	.requirement-detail--main table {
		font-size: 13px;
	}
	.requirement-detail--main table th {
		width: 100%;
		padding: 10px;
		border-bottom: none;
		float: left;
	}
	.requirement-detail--main table td {
		padding: 10px;
		width: 100%;
		float: left;
	}
	.requirement-detail--sub {
		margin-top: 80px;
		padding: 40px 0;
	}
	.requirement-detail--sub h3 {
		font-size: 18px;
	}
	.requirement-detail--sub table th,
	.requirement-detail--sub table td {
		padding: 10px 0;
		width: 100%;
		float: left;
	}
	.policy-group--img {
		width: 100%;
		display: block;
		text-align: center;
		margin-bottom: 30px;
	}
	.policy-group--info {
		width: 100%;
		display: block;
		margin-left: 0;
	}
	.policy-group--info h3 {
		font-size: 18px;
		border-left: solid 4px #29559b;
	}
	.policy-sub--img {
		width: 90px;
		padding-right: 15px;
	}
	.policy-sub--info {
		padding: 20px;
	}
	.policy-sub--info p {
		font-size: 12px;
	}

	.faq-list h3 {
		font-size: 14px;
		padding: 15px 30px 15px 60px;
		margin-bottom: 20px
	}
	.faq-list h3 span {
		font-size: 25px;
		left: 30px;
		top: 10px;
	}
	.faq-list .faq-a {
		font-size: 12px;
		padding: 0px 20px;
	}

	.contact-list li {
		width: 100%;
		margin: 0 auto 20px;
	}
	#contact-form table {
		font-size: 13px;
	}
	#contact-form table th {
		width: 100%;
		float: left;
		padding-top: 0;
		font-size: 14px;
		margin-bottom: 5px;
	}
	#contact-form table td {
		width: 100%;
		float: left;
		padding-bottom: 20px;
	}
	.cmn-input {
		width: 100%;
		height: 40px;
	}
	.cmn-select {
		width: 100%;
		height: 40px;
	}
	.cmn-select-s {
		width: 20%;
		height: 40px;
	}
	.cmn-textarea {
		width: 100%;
	}


	.post-in {
		display:block;
	}
	#post-contents {
		width: 100%;
		margin-bottom: 50px;
	}
	#post-sidebar {
		width: 100%;
		margin-left: 0;
	}

	.post-list .post-thumb .cat {
		font-size: 10px;
		padding: 2px 5px 4px;
	}
	.post-list .post-info--date {
		font-size: 13px;
	}
	.post-list .post-info--title {
		font-size: 12px;
	}


	.benefit-nav--list li {
		width: 48%;
		margin: 0 0 4% 4%;
	}
	.benefit-nav--list li:nth-child(3n+1) {
		margin: 0 0 4% 4%;
	}
	.benefit-nav--list li:nth-child(2n+1) {
		margin-left: 0;
	}


	.requirement-in {
		display: block;
	}
	.requirement-con {
		width: 100%;
		margin-bottom: 50px;
	}
	#side-nav {
		width: 100%;
	}

	/* welfare */
	.welfare-nav__list {
		display: block;
		padding: 10px 0;
	}
	.welfare-nav__list >li:not(:first-child) {
		margin-left: 0;
	}
	.welfare-nav__list >li:not(:first-child):before {
		margin-right: 0;
	}
	.welfare-box h3 {
		font-size: 18px;
		margin-bottom: 20px;
	}


	.welfare01-detail {
		margin-bottom: 50px;
	}
	.welfare01-detail-in {
		display: block;
	}
	.welfare01-detail-img {
		width: 100%;
		text-align: center;
		margin-bottom: 20px;
	}
	.welfare01-detail-text {
		width: 100%;
	}
    .welfare01-detail-text h4 {
        font-size: 18px;
        text-align: center;
    }
    .welfare01-detail-text p {
        font-size: 12px;
        line-height: 2;
    }
	.welfare-box table {
        font-size: 12px;
	}
	.welfare-box table th {
		width: 30%;
	}
}



