/*
Theme Name: main
Theme URI: 
Description: 
Author: ailylab
Author URI: 
Version: 1.0.0
*/

img[src=""] {
    display: block;
    position: relative;
    width: 100%;
    padding-bottom: 70%;
    border: 1px solid #eee;
}
img[src=""]:after {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    font-size: 24px;
    white-space: nowrap;
    content: "※画像準備中※";
}

/****************************************
1.Setting
*****************************************/
html, body, div, span, a, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, address, em, img, dl, dt, dd, ol, ul, li, form, label, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, figcaption, figure, footer, header, menu, nav, section, time, video {
    margin: 0px;
    padding: 0px;
    border: none;
    outline: none;
    box-sizing: border-box;
}

html {
    overflow-x: hidden;
}

body {
    color: #3e3e3e;
    font-size: 16px;
    font-family: "Noto Sans JP", "游ゴシック", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
    line-height: 1.5;
}

a {
    color: #359ddd;
}

a:hover {
    color: #76b6dd;
}

a[href="#none"] {
    color: #313131;
    text-decoration: none;
    pointer-events: none;
}

img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 0px auto;
    -webkit-backface-visibility: hidden; 
    -ms-transform: translateZ(0); /* IE 9 */
    -webkit-transform: translateZ(0); /* Chrome, Safari, Opera */
    transform: translateZ(0);
}
/* img:not([class]) {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 0px auto;
    -webkit-backface-visibility: hidden; 
    -ms-transform: translateZ(0); /* IE 9 */
    -webkit-transform: translateZ(0); /* Chrome, Safari, Opera */
    transform: translateZ(0);
} */

/* Chromeで縮小したアイコン画像がぼやける現象への対策 */
img[src$=".png"],
img[src$=".gif"] {
    -webkit-backface-visibility: hidden;
}

p {
    line-height: 2;
}

p.paragraph:nth-of-type(n + 2) {
    margin: 1.5em 0px 0px;
}

figcaption {
    padding: 0.5em;
    text-align: center;
}

a:hover > figure > img {
    opacity: 0.8;
}

table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}

table th,
table td {
    padding: 10px;
    border-bottom: 1px solid #00045b;
}

table td {
    border: 1px solid #00045b;
    color: #0c3871;
}

table th:first-of-type {
    border-left: 1px solid #00045b;
}

table th:last-of-type {
    border-left: 1px solid #00045b;
}

table th:nth-of-type(n + 2) {
    border-left: 1px solid #fff;
}

table th {
    background-color: #00045b;
    color: #fff;
}

@media screen and (max-width: 767.98px) {
    .tbl_wrapper {
        overflow-x: scroll;
    }
    .tbl_wrapper > table {
        width: 767px;
    }
}

address {
    font-style: normal;
}

.video_wrapper {
    position: relative;
}
.video_wrapper:not(.js_active)::before {
    position: absolute;
    top: 0px;
    left: 0px;
    right: 0px;
    bottom: 0px;
    background-color: rgba(0, 0, 0, 0.5);
    content: "";
}
.video_wrapper:not(.js_active)::after {
    position: absolute;
    top: 25%;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 60px;
    background-image: url(./images/common/icon_loading.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    content: "";
}

.video_wrapper > video {
    width: 100%;
}

ol.list,
ul.list {
    margin: 0px 0px 0px 1.5em;
}

p + ol.list,
p + ul.list {
    margin: 0.5em 0px 0px 1.5em;
}

ol.list + p,
ul.list + p {
    margin: 0.5em 0px 0px;
}

ol.list > li + li,
ul.list > li + li {
    margin: 1em 0px 0px;
}

ol.list > li > ul,
ul.list > li > ul {
    margin: 1em 0px 0px 1.5em;
}

ol.list > li > .box,
ul.list > li > .box {
    margin: 1em 0px 0px;
}

dl.list {
    border: 1px solid #dedede;
    border-top: none;
}

dl.list > dt,
dl.list > dd {
    padding: 1em;
    margin: 0px;
    border-top: 1px solid #dedede;
}

dl.list > dt {
    background-color: #ecf8fe;
    color: #231815;
    font-weight: bold;
}

.cf:after {
    display: block;
    clear: both;
    content: "";
}

.bw > span,
h1 > span,
h2 > span,
h3 > span,
h4 > span,
h5 > span,
h6 > span,
figcaption > span {
    display: inline-block;
}

@media screen and (max-width: 991px) {
    .pc {
        display: none !important;
    }
}
@media screen and (max-width: 767.98px) {
    .tb {
        display: none !important;
    }
}
@media screen and (min-width: 768px) {
    .mb {
        display: none !important;
    }
}

.center {
    text-align: center;
}

@media screen and (min-width: 768px) {
    .pc_center {
        text-align: center;
    }
}

.right {
    text-align: right;
}

.em {
    font-size: 16px;
    font-weight: bold;
}

.if_wrapper {
    position: relative;
    padding-bottom: 56.25%;
}
.if_wrapper iframe {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
}

.pagination {
    display: flex;
    justify-content: center;
    margin: 60px 0px 0px;
}

.pagination > a,
.pagination > span {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 2em;
    height: 2em;
    margin: 30px 0.5em 0px;
    border: 1px solid #0046ae;
    font-weight: bold;
}

.pagination > a:link,
.pagination > a:visited,
.pagination > a:active,
.pagination > a:hover {
    color: #034aa6;
    text-decoration: none;
}
.pagination > .prev,
.pagination > .next {
    border: 1px solid transparent;
    background-color: transparent;
}
.pagination > .prev:before,
.pagination > .next:before {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0.5em;
    height: 0.5em;
    border-right: 2px solid currentColor;
    border-top: 2px solid currentColor;
    content: "";
}
.pagination > .prev:before {
    transform: translateX(-50%) translateY(-50%) rotate(225deg);
}
.pagination > .next:before {
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
}

.pagination > .current {
    background-color: #0046ae;
    color: #fff;
}

.link_prev,
.link_next {
    position: relative;
    padding: 0px 1em;
}

.link_prev {
    float: left;
}
.link_next {
    float: right;
}

.link_prev:before,
.link_next:after {
    position: absolute;
    top: 50%;
    width: 0.5em;
    height: 0.5em;
    border-top: 2px solid currentColor;
    border-right: 2px solid currentColor;
    content: "";
}
.link_prev:before {
    left: 0px;
    transform: translateY(-50%) rotate(225deg);
}
.link_next:after {
    right: 0px;
    transform: translateY(-50%) rotate(45deg);
}

.breadcrumb {
    display: flex;
    flex-wrap: wrap;
    padding: 1em 0px;
    list-style: none;
}
.breadcrumb > li {
    position: relative;
    font-size: 14px;
}
.breadcrumb > li:nth-of-type(n + 2) {
    padding: 0px 0px 0px 2.5em;
}
.breadcrumb > li:nth-of-type(n + 2):before {
    position: absolute;
    top: 50%;
    left: 1em;
    width: 0.5em;
    height: 0.5em;
    transform: translateY(-50%) rotate(45deg);
    border-right: 2px solid #dedede;
    border-top: 2px solid #dedede;
    content: "";
}

.list_slash {
    list-style: none;
}

.list_slash > li {
    display: inline-block;
    position: relative;
}
.list_slash > li:not(:last-child)::after {
    margin: 0px 0.5em;
    content: "/";
}

.img_border {
    border: 4px solid #c2c2c2;
}

.btn_link {
    display: table;
    position: relative;
    padding: 1em 5em 1em 2em;
    margin: 50px auto 0px;
    background-color: #9e1f24;
    color: #fff;
    font-size: 1.2rem;
    text-decoration: none;
}
.btn_link:hover {
    color: #fff;
}
.btn_link::before,
.btn_link::after {
    position: absolute;
    top: 50%;
    right: 1em;
    height: 2px;
    background-color: #fff;
    content: "";
}
.btn_link::before {
    width: 3em;
    transform: translateY(-50%);
}
.btn_link::after {
    width: 1em;
    transform-origin: bottom right;
    transform: translateY(-50%) rotate(40deg);
}

.list_table {
    max-width: 900px;
    margin: auto;
    margin-top: 20px;
    margin-bottom: 20px;
}

.list_table,
.list_table > dt,
.list_table > dd {
    box-sizing: border-box;
}



.list_table > dt:nth-of-type(2n + 1),
.list_table > dd:nth-of-type(2n + 1) {
    background-color: #e8e8ec;
}

.list_table > dt:nth-of-type(2n),
.list_table > dd:nth-of-type(2n) {
    background-color: #f7f7f8;
}


@media screen and (max-width: 767px) {
    .list_table
    .recruitment_list_table {
        border-top: none;
    }
    .list_table > dt,
    .list_table > dd,
    .recruitment_list_table > dt,
    .recruitment_list_table > dd {
        text-align: center;
    }
    .list_table > dd > ul
    .recruitment_list_table > dd > ul {
        text-align: left;
    }
    .list_table > dt,
    .list_table > dd,
    .recruitment_list_table > dt,
    .recruitment_list_table > dd {
        padding: 0.7em;
        margin: 0px;
    }
}
@media print, (min-width: 768px) {
    .list_table,
    .recruitment_list_table {
        display: flex;
        flex-wrap: wrap;
        border-top: none;
    }
    .list_table > dt,
    .list_table > dd,
    .recruitment_list_table > dt,
    .recruitment_list_table > dd {
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .list_table > dt,
    .recruitment_list_table > dt {
        width: 30%;
    }
    .list_table > dd,
    .recruitment_list_table > dd {
        width: 70%;
    }

    .list_table > dt,
    .list_table > dd,
    .recruitment_list_table > dt,
    .recruitment_list_table > dd {
        padding: 2em;
        margin: 0px;
    }
}

.g-recaptcha{
    justify-content: center;
    display: flex;
}

/****************************************
2. Layout 
*****************************************/
.mt1em {
    margin-top: 1em !important;
}

.mt30 {
    margin-top: 30px !important;
}

.section,
.main_recruitment_results,
.quality_management_system,
.company_info,
.recruitment_essentials,
.recruitment_workplace {
    padding: 50px 0px 50px 0px;
}

div[class="col"],
div[class^="col-"] {
    margin-top: 60px;
}

.row.no_mt {
    margin-top: -60px;
}

.container {
    width: 100%;
}
@media print, (min-width: 992px) {
    .container {
        margin-left: auto;
        margin-right: auto;
    }
}
@media (min-width: 576px) {
    .container {
        max-width: 100%;
    }
}
@media (min-width: 768px) {
    .container {
        max-width: 100%;
    }
}
@media (min-width: 992px) {
    .container {
        max-width: 100%;
    }
}
@media (min-width: 1100px) {
    .container {
        max-width: 1100px;
    }
}
@media (min-width: 1300px) {
    .container {
        max-width: 1100px;
    }
}

.container_s {
    padding: 0px 15px;
    width: 100%;
}
@media print, (min-width: 992px) {
    .container_s {
        margin-left: auto;
        margin-right: auto;
        width: 80%;
    }
}
@media (min-width: 768px) {
    .container_s {
        max-width: 768px;
    }
}

@media print, (min-width: 768px) {
    .col2 {
        display: flex;
        padding: 0px 0px 60px;
    }
    .col2_main {
        order: 2;
        width: 75%;
    }
    .col2_side {
        order: 1;
        margin: 0px 20px 0px 0px;
        width: calc(25% - 20px);
    }
}

@media screen and (max-width: 767.98px) {
    .col2_side {
        margin: 30px 0px 0px;
    }
}

/****************************************
3. header,nav
*****************************************/
.header_menu_tel {
    text-align: right;
}

.header_menu_tel a {
    display: inline-block;
    transform: scaleY(0.9);
    color: #049595;
    font-size: 20px;
    font-weight: bold;
    text-decoration: none;
    text-indent: 0.1em;
    letter-spacing: 0.1em;
}
.header_menu_tel a:hover {
    opacity: 0.8;
}
.header_menu_tel a::before {
    display: inline-block;
    margin: 0px 0px 0px 1em;
    transform: scaleX(-1);
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f095";
}

.header_menu_tel a span {
    font-size: 14px;
    text-indent: 0px;
    letter-spacing: 0px;
}

.header_cta_contact {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    height: 60px;
    background-color: #9e1f24;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
    text-indent: 0.1em;
    letter-spacing: 0.1em;
}
.header_cta_contact:hover {
    color: #fff;
    opacity: 0.8;
}
.header_cta_contact::before {
    display: inline-block;
    width: 2em;
    height: 2em;
    margin: 0px 0.5em 0px 0px;
    background-image: url(./images/common/icon_mail.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    content: "";
}

.header_menu > .menu {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0px;
    margin: 10px 0px 0px;
}

.header_menu > .menu > li {
    position: relative;
    list-style-type: none;
    font-size: 17px;
}

.header_menu > .menu > li > a {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    color: #313131;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    line-height: 1;
}

.header_menu > .menu > .current-menu-item a,
.header_menu > .menu > li a:hover {
    color: #049595;
}

@media screen and (max-width: 767.98px) {
    .header_cta,
    .header_menu {
        display: none;
    }
}
@media screen and (min-width: 768px) {
    body {
        margin-top: 80px;
    }
    .header {
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: center;
        position: fixed;
        top: 0px;
        left: 50%;
        z-index: 9999;
        transform: translateX(-50%);
        padding: 0px 0px 20px;
        width: 100%;
        background-color: #fff;
        transition: top 0.5s;
    }
    .header::before {
        position: absolute;
        top: 0px;
        left: calc((50vw - 50%) * -1);
        right: calc((50vw - 50%) * -1);
        z-index: -1;
        bottom: 0px;
        width: 100vw;
        background-color: #fff;
        content: "";
    }
    .header_title {
        width: 200px;
    }
    .header_menu {
        margin: 0px 20px 0px 40px;
        width: calc(100% - 200px - 200px - 60px);
    }
    .header_cta {
        width: 200px;
    }
}
@media screen and (min-width: 992px) {
    .header_title {
        width: 300px;
    }
    .header_menu {
        margin: 0px 40px 0px 60px;
        width: calc(100% - 300px - 200px - 100px);
    }
    .header_cta {
        width: 200px;
    }
}
@media print, (min-width: 1100px) {
    .header {
        width: 1100px;
    }
}
@media screen and (max-width: 991px) {
    .header_menu_tel a span {
        display: none;
    }
    .header_menu > .menu > li {
        font-size: 15px;
    }
}

.page_title {
    position: relative;
    z-index: -1;
    height: 200px;
    background-image: url(./images/common/pagetitle.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.page_title_base {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
}

.page_title_base > h1 {
    padding: 1em;
    width: 100%;
    color: #fff;
    font-weight: bold;
    text-align: center;
    text-shadow: -2px -2px 6px #000, 2px -2px 6px #000, 2px 2px 6px #000, -2px 2px 6px #000;
}

.sub_title {
    position: relative;
    color: #00045b;
    border-bottom: 1px solid #00045b;
    margin: auto;
    margin-top: 2em;
    margin-bottom: 2em;
    max-width: 700px;
    padding: 0em 0.5em 0em 1em;
    border-left: solid 10px #00045b;
}

.business_table {
    max-width: 700px;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 4em;
}


/****************************************
4. sidebar
*****************************************/

/****************************************
5. contents
****************************************/
.home h2,
.content_contact_title,
.page h2:not([class]) {
    display: table;
    position: relative;
    padding: 0px 0px 0.5em;
    margin: 0px auto;
    border-bottom: 2px solid #c1c1c1;
    color: #00045b;
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
}
.home h2::before,
.content_contact_title::before,
.page h2:not([class])::before {
    position: absolute;
    bottom: -2px;
    left: 0px;
    width: 1em;
    height: 2px;
    background-color: #009696;
    content: "";
}

.sub_english {
    color: #00045b;
    font-weight: bold;
    text-align: center;
}

.top_main {
    position: relative;
}

.top_main_slider img {
    width: 100%;
}

.top_main_text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    width: 90%;
    color: #fff;
    text-align: center;
}

.top_main_text h1 {
    transform: skew(-10deg);
    font-size: 4vw;
    text-indent: 4px;
    letter-spacing: 4px;
}

.top_main_text_lead {
    margin: 30px auto 0px;
    max-width: 800px;
    font-size: 16px;
}

.top_lead {
    margin: 20px;
    text-align: center;
}

@media screen and (max-width: 767.98px) {
    .top_main_text_lead {
        display: none;
    }
}
@media screen and (min-width: 768px) {
    .top_main_text h1 {
        font-size: 32px;
    }
    .top_lead {
        display: none;
    }
}
@media screen and (min-width: 1200px) {
    .top_main_text h1 {
        font-size: 40px;
    }
    .top_main_text_lead {
        margin: 60px auto 0px;
        font-size: 18px;
    }
}

.top_recruit {
    padding: 90px 0px;
    background-image: url(./images/top/bg_recruit.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.top_recruit_main {
    margin: 60px auto 0px;
    max-width: 600px;
    text-align: center;
}

.top_feature {
    padding: 90px 0px;
}

.top_feature_text_heading {
    padding: 0px 0px 0px 20px;
    border-left: 4px solid #00045b;
    color: #00045b;
}

.top_feature_text_heading p {
    font-size: 1.8rem;
    font-style: italic;
    line-height: 1;
}

.top_feature_text_heading h3 {
    margin-top: 0.5em;
    font-size: 1.6rem;
    font-weight: bold;
}

.top_feature_text_heading + p {
    margin-top: 1em;
}

.top_feature_no {
    position: absolute;
    bottom: 0px;
    right: 15px;
    margin: 0px;
}

.top_about {
    padding: 90px 0px;
    background-image: url(./images/top/bg_about.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    color: #fff;
}

.top_about h2,
.top_about .sub_english {
    color: #fff;
}

.top_about h2 + p {
    margin-top: 30px;
}

.top_about_link {
    display: block;
    margin-top: 30px;
    color: #fff;
    text-align: center;
    text-decoration: none;
}
.top_about_link:hover {
    color: #fff;
}

.top_about_link:hover img {
    transform: scale(1.2);
}

.top_about_link p {
    margin-top: 0.5em;
    font-size: 1.25rem;
}

.top_about_link_image {
    overflow: hidden;
}

.top_about_link_image img {
    transition: transform 0.5s;
}

@media screen and (min-width: 992px) {
    .top_about h2 + p {
        padding: 0px 30px;
    }
    .top_about_slash {
        position: relative;
    }
    .top_about_slash::before {
        position: absolute;
        top: 150px;
        left: 50%;
        transform: translateX(-50%) rotate(-70deg);
        width: 200px;
        height: 2px;
        background-color: #fff;
        content: "";
    }
}

.content_contact {
    position: relative;
    z-index: 1;
    padding: 90px 30px;
    text-align: center;
}
.content_contact::before {
    position: absolute;
    top: 0px;
    left: 0px;
    right: 0px;
    bottom: 0px;
    z-index: -2;
    background-image: url(./images/common/bg_contact.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    content: "";
}
.content_contact::after {
    position: absolute;
    top: 20px;
    left: 20px;
    right: 20px;
    bottom: 20px;
    z-index: -1;
    background-color: rgba(255, 255, 255, 0.8);
    content: "";
}

.content_contact_title + p {
    margin-top: 1em;
}

.content_contact_tel a {
    display: inline-block;
    transform: scaleY(0.9);
    color: #049595;
    font-weight: bold;
    text-decoration: none;
    text-indent: 0.1em;
    letter-spacing: 0.1em;
}

@media (min-width: 768px) {
    .content_contact_tel a {
        font-size: 2.5rem;
    }
}

@media screen and (max-width: 767.98px){
    .content_contact_tel a {
        font-size: 1.5rem;
    }
}

.content_contact_tel a:hover {
    opacity: 0.8;
}
.content_contact_tel a::before {
    display: inline-block;
    margin: 0px 0px 0px 1em;
    transform: scaleX(-1);
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f095";
}

.content_contact_tel p {
    display: inline-block;
    padding: 0px 0px 0px 2em;
    color: #049595;
    line-height: 1;
}

.content_contact_btn {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    margin: 0px auto;
    width: 16em;
    height: 3em;
    border-radius: 0.2em;
    background-color: #9e1f24;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
    text-indent: 0.1em;
    letter-spacing: 0.1em;
    max-width: 85%;
}
.content_contact_btn:hover {
    color: #fff;
    opacity: 0.8;
}
.content_contact_btn::before {
    display: inline-block;
    width: 2em;
    height: 2em;
    margin: 0px 0.5em 0px 0px;
    background-image: url(./images/common/icon_mail.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    content: "";
}

@media screen and (min-width: 992px) {
    .content_contact_slash {
        position: relative;
    }
    .content_contact_slash::before {
        position: absolute;
        top: 90px;
        left: 50%;
        transform: translateX(-50%) rotate(-70deg);
        width: 100px;
        height: 2px;
        background-color: #c1c1c1;
        content: "";
    }
}

.menu-sitemap-container > .menu {
    margin: -1em 0px 0px 1.5em;
}

.menu-sitemap-container > .menu > li {
    margin: 1em 0px 0px;
    font-size: 17px;
}

.menu-sitemap-container > .menu .sub-menu {
    margin: 0px 0px 0px 2em;
}

.menu-sitemap-container > .menu .sub-menu > li {
    margin: 0.5em 0px 0px;
    font-size: 15px;
}

.main_p {
    margin: 60px auto 0px;
    max-width: 600px;
    text-align: center;
}

.page h3 {
    padding: 0px 0px 1em;
    margin: 0px auto;
    color: #00045b;
    font-weight: bold;
}

.main_recruitment_results {
    position: relative;
    color: #fff;
}

.main_recruitment_results::before {
    position: absolute;
    top: 0px;
    left: calc(-50vw + 50%);
    right: calc(-50vw + 50%);
    bottom: 0px;
    z-index: -1;
    padding: 90px 0px;
    background-image: url(./images/business/bg.jpg);
    content: "";
}

.main_recruitment_results_h2 {
    display: table;
    position: relative;
    padding: 0px 0px 0.5em;
    margin: 0px auto;
    border-bottom: 2px solid #c1c1c1;
    color: #fff;
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
}

.main_recruitment_results_h2::before {
    position: absolute;
    bottom: -2px;
    left: 0px;
    width: 1em;
    height: 2px;
    background-color: #009696;
    content: "";
}

.main_recruitment_results p {
    color: #fff;
}

.quality_management_system {
    position: relative;
}

.quality_management_system::before {
    position: absolute;
    top: 0px;
    left: calc(-50vw + 50%);
    right: calc(-50vw + 50%);
    bottom: 0px;
    z-index: -1;
    padding: 90px 0px;
    background-color: #e8e8ec;
    content: "";
}

.greeting_p {
    margin-bottom: 30px;
}

.name {
    font-size: large;
}

.company_info {
    position: relative;
}

.company_info::before {
    position: absolute;
    top: 0px;
    left: calc(-50vw + 50%);
    right: calc(-50vw + 50%);
    bottom: 0px;
    z-index: -1;
    padding: 90px 0px;
    background-color: #e8e8ec;
    content: "";
}

.page h4 {
    text-align: center;
    margin: 0px auto;
    font-weight: bold;
}

.map{
    position : relative;
    height : 0;
    padding-bottom : 75%; /* 縦横比の指定 */
    overflow : hidden;
}

.map iframe,
.map object,
.map embed{
    position : absolute;
    top : 0;
    left : 0;
    width : 100%;
    height : 100%;
}

.recruit_btn_link {
    margin : 0px auto 0px;
}

.recruitment_main_h1{
    color: #fff;
    background-color: #00045b;
    background: linear-gradient(to right, #00045b,  rgba(3, 12, 90, 0.8))
}

.recruitment_main_text p {
    color: #00045b;
    font-weight: bold;
}

.recruitment_main_text {
    position: absolute;
}

.recruitment_main {
    position: relative;
}

@media (min-width: 768px) {
    .recruitment_main_photo {
        margin-right: 0px;
        margin-left: auto;
        display: block;
        width: 75%;
    }
    .recruitment_main_text {
        left: 10%;
        top: 50%;
    }
    .recruitment_main_h1{
        letter-spacing: 0.2em;
        font-size: 3em;
        padding-right: 0.5em;
        padding-left: 0.5em;
    }
    .recruitment_main_text p {
        font-size: 1.5rem;
    }
}

@media screen and (max-width: 767.98px){
    .recruitment_main_photo {
        display: block;
        max-width: 100%;
    }
    .recruitment_main_text {
        left: 10%;
        bottom: 10%;
    }
    .recruitment_main_text p {
        color: #fff;
    }
}

.recruitment_message {
    position: relative;
}

.recruitment_message::before {
    position: absolute;
    top: 2em;
    bottom: 0px;
    z-index: -1;
    padding: 90px 0px;
    background-color: #fafafa;
    content: "";
}

@media (min-width: 768px) {
    .recruitment_message::before {
        left: calc(-50vw + 50% + 1.5em);
    right: calc(-50vw + 50%)
    }
}

@media screen and (max-width: 767.98px) {
    .recruitment_message::before {
        left: calc(-50vw + 50%);
        right: calc(-50vw + 50%);
    }
}


.recruitment_message_human {
    position: relative;
    width: 90%;
    margin-top: 3em;
}

.recruitment_message_human::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background-color: #009696;
    top: 10%;
    left: 10%;
    opacity: 0.2;
}

.recruitment_balloon {
    position: relative;
    display: inline-block;
    margin: 1.5em 0;
    padding: 0.3em 3em;
    min-width: 120px;
    max-width: 100%;
    color: #fff;
    background-color: #00045b;
}

.recruitment_balloon::before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #00045b;
}

.recruitment_balloon p {
    margin: 0;
    padding: 0;
    text-align: center;
    letter-spacing: 0.1em;
}

.recruitment_h2,
.contact_h2 {
    color: #00045b;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    margin-top: 0.3em;
    margin-bottom: 1em;
}


.recruitment_contents_photo_area {
    height: 337px;
    width: 95vw;
    height: 25vw;
}

.recruitment_contents {
    padding: 4em 2em;
}

@media (min-width: 768px) {
    .recruitment_contents {
        background-image: url(./images/recruit/sub_bg_pic.jpg);
        background-repeat: no-repeat;
        background-position: center;
    }
    .sub_bg_tb {
        display: none;
    }
}

@media screen and (max-width: 767.98px) {
    .sub_bg_tb {
        display: block;
    }
}


.recruitment_contents_section {
    position: relative;
}

.recruitment_contents_section::before {
    position: absolute;
    top: 2em;
    left: calc(-50vw + 50%);
    right: calc(-50vw + 50% + 1.5em);
    bottom: 0px;
    z-index: -1;
    padding: 90px 0px;
    background-color: #fafafa;
    content: "";
}

@media (min-width: 768px) {
    .recruitment_contents_section::before {
        left: calc(-50vw + 50%);
        right: calc(-50vw + 50% + 1.5em);
    }
}

@media screen and (max-width: 767.98px) {
    .recruitment_contents_section::before {
        left: calc(-50vw + 50%);
        right: calc(-50vw + 50%);
    }
}

.recruitment_contents_h2 {
    color: #00045b;
    font-size: 2rem;
    font-weight: bold;
    margin-top: 0.2em;
    margin-bottom: 1em;
    border-bottom: 2px solid #00045b;
    max-width: 1000px;
}

.recruitment_contents_details {
    margin-top: 4em;
    margin-bottom: 4em;
}

.recruitment_essentials {
    position: relative;
}

.recruitment_essentials::before {
    position: absolute;
    top: 2em;
    left: calc(-50vw + 50%);
    right: calc(-50vw + 50%);
    bottom: 0px;
    z-index: -1;
    padding: 90px 0px;
    background-color: #fafafa;
    content: "";
}

.recruitment_workplace {
    position: relative;
}

.recruitment_workplace::before{
    position: absolute;
    top: 2em;
    left: calc(-50vw + 50%);
    right: calc(-50vw + 50%);
    bottom: 0px;
    z-index: -1;
    background-color: #fafafa;
    content: "";
}

.recruitment_list_table {
    max-width: 900px;
    margin: auto;
    margin-top: 20px;
    margin-bottom: 20px;
}

.recruitment_list_table,
.recruitment_list_table > dt,
.recruitment_list_table > dd {
    box-sizing: border-box;
}

.recruitment_list_table > dt:nth-of-type(2n + 1),
.recruitment_list_table > dd:nth-of-type(2n + 1) {
    background-color: #e8e8ec;
}

.recruitment_list_table > dt:nth-of-type(2n),
.recruitment_list_table > dd:nth-of-type(2n) {
    background-color: #fafafa;
}

.contact_link {
    color: #009696;
}

.contact_tel {
    display: inline-block;
    color: #009696;
    border: 1px solid #009696;
    padding: 1rem 3rem;
    text-align: center;
    margin: 2.5rem;
}

.contact_tel_title {
    font-size: 1.3rem;
}

.contact_tel a {
    display: inline-block;
    color: #009696;
    text-decoration: none;
    /* font-size: 2.3rem; */
    font-weight: bold;
    letter-spacing: 0.1em;
    text-indent:  0.1em;
}

.contact_tel a::before {
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f095";
    transform: scaleX(-1);
}

.contact_tel a:hover {
    opacity: 0.8;
}

.privacy_main {
    margin: 2rem 3rem 0 3rem;
}

.sitemap_link {
    color: #009696;
    text-decoration: none;
    padding: 0.1em 0.2em;
    transition: 0.3s;
    display: inline-block;
    position: relative;
}

.sitemap_link::after {
    position: absolute;
    content: "";
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background: #009696;
    transition: all 0.3s ease 0s;
}

.sitemap_link:hover {
    cursor: pointer;
}

.sitemap_link:hover::after {
    width: 100%
}

.sitemap_list {
    text-align: left;
    display: inline-block;
    padding: 0;
}

.sitemap_link_area {
    text-align: center;
}

@media (min-width: 768px) {
    .flow_pc {
        display: block;
    }
    .flow_tb {
        display: none;
    }
}

@media screen and (max-width: 767.98px) {
    .flow_pc {
        display: none;
    }
    .flow_tb {
        display: block;
        margin-bottom: 2rem;
    }
}

.flow_ol {
    margin: 2rem 1rem 0 1rem;
    display: flex;
    align-items: center;
    flex-direction: column;
}

/****************************************
6. Footer 
****************************************/
.footer {
    padding: 60px 0px;
}

.footer_title img {
    margin: 0px;
}

.footer_title + p {
    margin-top: 1em;
}

.footer_menu ul {
    display: flex;
    flex-wrap: wrap;
    margin: -20px -10px 0px;
    list-style: none;
}

.footer_menu li {
    margin: 20px 10px 0px;
    width: calc(50% - 20px);
    min-height: 100%;
}

.footer_menu a {
    color: #00045b;
    text-decoration: none;
}
.footer_menu a:hover {
    text-decoration: underline;
}

.copyright {
    padding: 1em;
    background-color: #00045b;
    color: #fff;
    font-size: 0.75rem;
    text-align: center;
}

@media screen and (max-width: 767.98px) {
    .footer {
        display: none;
    }
}
@media screen and (min-width: 992px) {
    .footer_menu li {
        width: calc(33.3% - 20px);
    }
}

@media print, (max-width: 767.98px) {
    .mnavi {
        display: block;
        position: fixed;
        bottom: 0px;
        left: 0px;
        z-index: 9999;
        width: 100%;
        height: 80px;
        background-color: #00045b;
    }
    body {
        margin-bottom: 80px;
    }
}
@media print, (min-width: 768px) {
    .mnavi {
        display: none;
    }
}

.mnavi > ul {
    display: flex;
    justify-content: space-around;
    align-items: center;
    height: 100%;
    list-style: none;
}

.mnavi > ul > li {
    width: 40px;
    height: 40px;
}

.mnavi > ul > li > a,
.mnavi > ul > li > button {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    color: #fff;
    font-size: 2.5vw;
}
.mnavi > ul > li > a:before,
.mnavi > ul > li > button:before {
    position: absolute;
    top: 0px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 32px;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
}
.mnavi_home > a:before {
    content: "\f015";
}
.mnavi_contact > a:before {
    content: "\f0e0";
}
.mnavi_tel > a:before {
    content: "\f095";
}
.mnavi_menu > button:before {
    content: "\f0c9";
}

.mnavi > ul > li > a {
    text-decoration: none;
}

.mnavi > ul > li > button {
    border: none;
    background: none;
    outline: none;
    appearance: none;
    cursor: pointer;
}

.mnavi > ul > li span {
    position: absolute;
    bottom: -1em;
    left: 50%;
    transform: translateX(-50%);
    line-height: 1;
    white-space: nowrap;
}

.mnavi_menu_area {
    display: none;
    position: fixed;
    left: 0px;
    bottom: 80px;
    width: 100vw;
    height: calc(100vh - 80px);
    z-index: 9999;
    background-color: rgba(0, 0, 0, 0.6);
    overflow-x: hidden;
    overflow-y: scroll;
}

.mnavi_menu_area > .menu {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    width: 90%;
}

.mnavi_menu_area > .menu > li {
    list-style-type: none;
    text-align: center;
}

.mnavi_menu_area > .menu > li > a {
    display: inline-block;
    padding: 1em 2em;
    color: #fff;
    font-size: 4vw;
    text-decoration: none;
}

#btn_scroll_top {
    display: none;
    position: fixed;
    bottom: 120px;
    right: 30px;
    z-index: 9999;
    width: 50px;
    height: 50px;
    border: 2px solid #fff;
    background-color: #00045b;
    text-decoration: none;
    outline: none;
}
#btn_scroll_top:after {
    position: absolute;
    top: 40%;
    left: 50%;
    width: 20px;
    height: 20px;
    transform: translateX(-50%) rotate(-45deg);
    border-right: 2px solid #fff;
    border-top: 2px solid #fff;
    content: "";
}
@media print, (min-width: 768px) {
    #btn_scroll_top {
        bottom: 30px;
        width: 42px;
        height: 42px;
    }
    #btn_scroll_top:after {
        width: 12px;
        height: 12px;
    }
}


/****************************************
7. single
****************************************/
.single-post p + p {
    margin: 1em 0px 0px;
}

@media screen and (max-width: 767.98px) {
    .single-post img {
        margin: 1em auto 0px;
    }
}
@media print, (min-width: 768px) {
    .single-post img {
        margin: 1em 0px 0px;
    }
    
    .single-post .alignleft {
        display: inline-block;
    }
    
    .single-post .alignleft + .alignleft {
        margin: 1em 0px 0px 1em;
    }
    
    .single-post .aligncenter {
        margin: 1em auto 0px;
    }
    
    .single-post .alignright {
        margin: 1em 0px 0px 100%;
        transform: translateX(-100%);
    }
}

/****************************************
8. WP
****************************************/

/****************************************
9. Print
****************************************/

/****************************************
10. Plugin
****************************************/
.no_must {
    display: block;
    background-color: #fc0;
    padding: 4px 5px;
    font-size: 13px;
    color: #fff;
    float: left;
    margin: 0px 5px;
    border-radius: 4px;
    box-shadow: 0px 0px 5px #ccc;
}

.bx-wrapper {
    background-color: transparent;
    margin: 0px auto 0px;
    border: none;
    box-shadow: none;
}
.bx-wrapper img {
    display: block;
    margin: 0px auto;
}

.bx-wrapper .bx-controls-auto,
.bx-wrapper .bx-pager {
    bottom: 20px;
}

.bx-wrapper .bx-pager.bx-default-pager a {
    margin: 0px 20px;
    border: 1px solid #fff;
    background: none;
}

.bx-wrapper .bx-pager.bx-default-pager a:hover,
.bx-wrapper .bx-pager.bx-default-pager a.active,
.bx-wrapper .bx-pager.bx-default-pager a:focus {
    background: #fff;
}

/****************************************
10. Tweak
****************************************/

/****************************************
11. メールフォームプロ用スタイル
****************************************/
form#mailformpro .mailform {
    margin: 0px;
}

form#mailformpro dl {
    box-sizing: border-box;
}

form#mailformpro dl dt {
    display: flex;
    align-items: flex-start;
    box-sizing: border-box;
    border: none;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.5;
}

form#mailformpro dl dd {
    box-sizing: border-box;
    border: none;
}

form#mailformpro dl dt:nth-of-type(n+2),
form#mailformpro dl dd:nth-of-type(n+2) {
    border-top: 1px solid #d3dad9;
}

.mfp_colored {
    background: none;
}

.mfp_element_text,
.mfp_element_number,
.mfp_element_select-one,
.mfp_element_email,
.mfp_element_tel,
.mfp_element_textarea {
    padding: 1em;
    margin: 0px;
    width: 100% !important;
    box-sizing: border-box;
    border: 1px solid #95cec7;
    background-color: #f0f8f7;
    box-shadow: none;
    outline: none;
}

.mfp_element_submit,
.mfp_element_reset,
.mfp_element_button {
    padding: 0.5em 3em;
    box-sizing: border-box;
    background: none;
    background-color: #00665b;
    box-shadow: none;
    color: #fff;
    font-size: 18px;
    text-shadow: 0px 2px 0px #00564d;
}

.mfp_element_submit:hover,
.mfp_element_reset:hover,
.mfp_element_button:hover {
    background: none;
    background-color: #267d73;
    box-shadow: none;
}

div.mfp_err {
    padding: 0.5em 0px 0.5em 1em;
    background: none;
}

.problem {
    border: 1px solid #ffd5dc;
    background-color: #ffd5dc;
}

.must,
.no_must {
    display: block;
    padding: 0px 1em;
    border-radius: 4px;
    background: none;
    box-shadow: none;
    text-shadow: none;
    color: #fff;
    font-size: 10px;
    line-height: 1.5;
}

.must {
    border: 1px solid #009696;
    background-color: #009696;
}

.no_must {
    border: 1px solid #00045b;
    background-color: #00045b;
}

@media screen and (max-width: 767.98px) {
    form#mailformpro dl dt,
    form#mailformpro dl dd {
        padding: 1em;
        width: 100%;
    }
    .must,
    .no_must {
        margin: 2px 2em 0px 0px;
    }
}

@media print, (min-width: 768px) {
    form#mailformpro dl {
        display: flex;
        flex-wrap: wrap;
    }
    form#mailformpro dl dt {
        float: none;
        padding: 2em 0px;
        width: 280px;
    }
    form#mailformpro dl dd {
        padding: 2em 2em 2em 0px;
        width: calc(100% - 280px);
    }
    .mfp_element_text,
    .mfp_element_number,
    .mfp_element_select-one,
    .mfp_element_email,
    .mfp_element_tel,
    .mfp_element_textarea {
        max-width: 500px;
    }
    .must,
    .no_must {
        margin: 2px 2em 0px;
    }
}
