@charset "utf-8";

/* CSS Document */


/*-------------------------------------------------

　   COMMON

--------------------------------------------------*/

header.show {
    background: #fff;
}

.blank {
    padding-top: 10rem;
    padding-bottom: 10rem;
}

#breadcrumb {
    padding-top: 4rem;
}

#breadcrumb ul {
    overflow: hidden;
}

#breadcrumb li {
    display: inline;
    position: relative;
    float: left;
    margin: 0 1rem 1rem 0;
    font-size: 1.2rem;
    line-height: 1;
}

#breadcrumb li a {
    padding-right: 1.8rem;
}

#breadcrumb li a::after {
    content: "";
    width: 6px;
    height: 6px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    position: absolute;
    right: 0;
    bottom: 50%;
    transform: translate(0, 50%) rotate(-45deg);
}

#breadcrumb li a:hover {
    text-decoration: underline;
}

.pages {
    display: none;
}

.wp-pagenavi {
    display: flex;
    justify-content: center;
    margin-top: 5rem;
}

.wp-pagenavi a,
.wp-pagenavi span {
    display: block;
    margin: 0 15px!important;
    padding: 15px 20px!important;
    border: solid 1px #0078BE!important;
    background: #fff;
    color: #0078BE;
    font-size: 1.6rem;
}

.wp-pagenavi span {
    background: #0078BE;
    color: #fff;
}

.wp-pagenavi a:hover,
.wp-pagenavi span.current {
    border-color: #0078BE!important;
    background: #0078BE;
    color: #fff;
    line-height: 1;
}

.pagebox {
    position: relative;
    max-width: 45rem;
    margin: 0 auto;
    text-align: center;
}

.pagebox a {
    position: relative;
    width: 100%;
    max-width: 13rem;
    padding: 1.5rem 0;
    border: 1px solid #0078BE;
    background: #fff;
    color: #0078BE;
    text-align: center;
}

.pagebox a.prev {
    position: absolute;
    right: 0;
}

.pagebox a.next {
    position: absolute;
    left: 0;
}

.pagebox a.next::before,
.pagebox a.prev::after {
    content: "";
    position: absolute;
    bottom: 50%;
    transform: translate(0, 50%) rotate(-45deg);
    width: 7px;
    height: 7px;
}

.pagebox a.next::before {
    left: 1.2rem;
    border-left: 1px solid #0078BE;
    border-top: 1px solid #0078BE;
}

.pagebox a.prev::after {
    right: 1.2rem;
    border-right: 1px solid #0078BE;
    border-bottom: 1px solid #0078BE;
}

.pagebox a.all {
    background: #0078BE;
    color: #fff;
}

@media only screen and ( max-width: 768px) {
    .blank {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }
    .wp-pagenavi a,
    .wp-pagenavi span {
        margin: 0 7px!important;
        padding: 10px 14px!important;
    }
    .pagebox {
        max-width: 48rem;
    }
    .pagebox a {
        font-size: 1.4rem;
    }
    .pagebox .all img {
        width: 2.3rem;
    }
}

@media only screen and ( max-width: 500px) {
    .pagebox a {
        font-size: 1.2rem;
    }
    .pagebox .prev {
        padding-left: 1rem;
    }
    .pagebox .next {
        padding-right: 1rem;
    }
    .pagebox .prev::before {
        border-top: 6px solid transparent;
        border-right: 7px solid #030E80;
        border-bottom: 6px solid transparent;
    }
    .pagebox .next::after {
        border-top: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-left: 7px solid #030E80;
    }
    .pagebox .all img {
        width: 1.5rem;
    }
    .pagebox .all span {
        padding: 0 5px;
    }
}


/*-------------------------------------------------

　   MAIN VISIUAL

--------------------------------------------------*/

#mv {
    position: relative;
    height: 37.5rem;
    background: no-repeat center / cover;
}

#mv.updates {
    background-image: url("../img/updates/mv.jpg");
}

#mv.employment {
    background-image: url("../img/employment/mv.jpg");
}

#mv.solutions {
    background-image: url("../img/solutions/mv.jpg");
}

#mv.about {
    background-image: url("../img/about/mv.jpg");
}

#mv.privacy {
    background-image: url("../img/privacy/mv.jpg");
}

#mv.contact {
    background-image: url("../img/contact/mv.jpg");
}

#mv.job {
    background-image: url("../img/careerup/mv.jpg");
}

#mv h1 {
    position: absolute;
    left: 50%;
    bottom: 40%;
    transform: translate(-50%, 50%);
    width: 100%;
    color: #fff;
    font-size: 4.8rem;
    text-align: center;
}

#mv p.ttl {
    position: absolute;
    left: 50%;
    bottom: 40%;
    transform: translate(-50%, 50%);
    width: 100%;
    color: #fff;
    font-size: 4.8rem;
    text-align: center;
}

@media only screen and ( max-width: 1024px) {
    #mv h1 {
        font-size: 4.4rem;
        text-align: center;
    }
    #mv h1 span {
        display: block;
        margin: 0 0 2rem;
        padding-right: 0;
        border-right: none;
        text-align: center;
    }
}

@media only screen and ( max-width: 768px) {
    #mv {
        height: 30rem;
    }
    #mv h1 {
        font-size: 3.4rem;
    }
}

@media only screen and ( max-width: 500px) {}


/*-------------------------------------------------

	IT SOLUTIONS

--------------------------------------------------*/

#solutions .inner {
    max-width: 1301px;
}

#solutions .title_common h2 {
    margin-bottom: 4.5rem;
}

#solutions .title_common p {
    max-width: 952px;
    margin: 0 auto;
}

#solutions .ttlbox {
    display: flex;
    align-items: center;
    margin-bottom: 3.5rem;
}

#solutions .ttlbox img {
    width: auto;
    margin-right: 2.5rem;
}

#solutions .ttlbox h2 {
    font-size: 2rem;
}

#solutions .ttlbox h2 span {
    display: block;
    margin-bottom: 1rem;
    font-size: 2.1em;
}

#solutions .areas_box .bg {
    position: relative;
    width: 50%;
    margin-bottom: 5.6rem;
    padding: 3.8rem 2rem 1rem;
    background: linear-gradient(to bottom, #fff, #E4E5ED 47%, #C8C9CF 50%, #FFF);
}

#solutions .areas_box .wht_bg {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 50%;
    background: #fff;
}

#solutions .areas_box .bg ul {
    display: flex;
    justify-content: center;
    max-width: 460px;
}

#solutions .areas_box .bg:nth-of-type(1) ul {
    margin-left: auto;
}

#solutions .areas_box .bg:nth-of-type(2) ul {
    margin-right: auto;
}

#solutions .areas_box .bg ul li {
    max-width: 204px;
    margin-left: 15%;
    text-align: center;
}

#solutions .areas_box .bg ul li:nth-of-type(1) {
    margin-left: 0;
}

#solutions .areas_box .bg ul li h3 {
    margin-bottom: 1.6rem;
    font-size: 2.2rem;
    text-align: center;
}

#solutions .areas_box .bg ul li a {
    position: relative;
    width: 167px;
    margin-bottom: 2rem;
    padding-top: 3.4rem;
    background: no-repeat top center / 167px;
    text-align: center;
}

#solutions .areas_box .bg ul li a::before,
#solutions .areas_box .bg ul li a::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 0);
}

#solutions .areas_box .bg ul li a::before {
    bottom: 24px;
    width: 3px;
    height: 40px;
}

#solutions .areas_box .bg ul li a::after {
    width: 18px;
    height: 18px;
    border: 3px solid #000;
    border-radius: 50%;
}

#solutions .areas_box .bg:nth-of-type(1) ul li:nth-of-type(1) a::before {
    background: #4B9FD7;
}

#solutions .areas_box .bg:nth-of-type(1) ul li:nth-of-type(2) a::before {
    background: #0F81C4;
}

#solutions .areas_box .bg:nth-of-type(2) ul li:nth-of-type(1) a::before {
    background: #0A62AD;
}

#solutions .areas_box .bg:nth-of-type(2) ul li:nth-of-type(2) a::before {
    background: #164F9E;
}

#solutions .areas_box .bg:nth-of-type(1) ul li:nth-of-type(1) a::after {
    border-color: #4B9FD7;
}

#solutions .areas_box .bg:nth-of-type(1) ul li:nth-of-type(2) a::after {
    border-color: #0F81C4;
}

#solutions .areas_box .bg:nth-of-type(2) ul li:nth-of-type(1) a::after {
    border-color: #0A62AD;
}

#solutions .areas_box .bg:nth-of-type(2) ul li:nth-of-type(2) a::after {
    border-color: #164F9E;
}

#solutions .areas_box .bg:nth-of-type(1) ul li:nth-of-type(1) a {
    background-image: url("../img/solutions/areas/button/bg01.png");
}

#solutions .areas_box .bg:nth-of-type(1) ul li:nth-of-type(2) a {
    background-image: url("../img/solutions/areas/button/bg02.png");
}

#solutions .areas_box .bg:nth-of-type(2) ul li:nth-of-type(1) a {
    background-image: url("../img/solutions/areas/button/bg03.png");
}

#solutions .areas_box .bg:nth-of-type(2) ul li:nth-of-type(2) a {
    background-image: url("../img/solutions/areas/button/bg04.png");
}

#solutions .areas_box .bg ul li a img {
    width: 129px;
    margin-bottom: 6.4rem;
    filter: drop-shadow(8px 8px 5px rgba(0, 0, 0, .3));
    transition: .3s;
}

#solutions .areas_box .bg ul li a img:hover {
    transform: translateY(5px);
    filter: drop-shadow(4px 4px 4px rgba(0, 0, 0, .3));
}

#solutions .areas_box .bg ul li p {
    text-align: center;
}

#solutions .areas_box .gray_bg .inner {
    position: relative;
    margin-bottom: 8.5rem;
    padding: 7.5rem 2rem;
}

#solutions .areas_box .gray_bg:last-child .inner {
    margin-bottom: 0;
}

#solutions .areas_box .container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#solutions .areas_box .container figure {
    width: 45%;
}

#solutions .areas_box .container .content {
    width: 51.5%;
}

#solutions .areas_box .container .content p {
    margin-bottom: 4rem;
}

#solutions .areas_box .container .content h3 {
    margin-bottom: 1rem;
    font-size: 2.3rem;
}

#solutions .areas_box .container .content ul li {
    position: relative;
    padding-left: 2rem;
}

#solutions .areas_box .container .content ul li::before {
    content: '';
    position: absolute;
    top: 8px;
    left: 0;
    width: 13px;
    height: 100%;
    background: url("../img/logo_mark_blue.svg") no-repeat top left / 13px;
}

#solutions .areas_box .content .awsbox {
    display: flex;
    align-items: center;
    max-width: 595px;
    margin-top: 2rem;
    padding: 1rem;
    background: #fff;
}

#solutions .areas_box .content .awsbox img {
    width: 140px;
}

#solutions .areas_box .content .awsbox p {
    flex: 1;
    margin: 0 0 0 2rem;
    font-size: 1.8rem;
}

#solutions .areas_box .content .awsbox p span {
    color: #0078BE;
}

#solutions .areas_box h4 {
    position: absolute;
    right: 40px;
    bottom: -38px;
    color: #C5DAF7;
    font-size: 5.7rem;
    font-style: italic;
}

#solutions .values_box .container {
    position: relative;
    height: 650px;
    background: url("../img/solutions/values/bg.jpg") no-repeat bottom / 1920px;
}

#solutions .values_box .container .iconbox {
    display: flex;
    justify-content: space-between;
    position: absolute;
    left: 50%;
    bottom: 38px;
    transform: translate(-50%, 0);
    width: 90%;
    max-width: 1077px;
}

#solutions .values_box .container .iconbox figure a {
    display: flex;
    justify-content: center;
    width: 192px;
    height: 192px;
    margin: 0 auto 3rem;
    border-radius: 50%;
    box-shadow: 8px 8px 5px rgba(0, 0, 0, .3);
    background: #fff;
}

#solutions .values_box .container .iconbox figure a:hover {
    transform: translateY(10px);
    box-shadow: 4px 4px 4px rgba(0, 0, 0, .3);
}

#solutions .values_box .container .iconbox figure:nth-of-type(1) a img {
    width: 155px;
}

#solutions .values_box .container .iconbox figure:nth-of-type(2) a img {
    width: 106px;
}

#solutions .values_box .container .iconbox figcaption {
    font-size: 2.2rem;
    text-align: center;
}

#solutions .values_box #loop {
    padding-top: 7rem;
}

#solutions .values_box figure.loop {
    max-width: 900px;
    margin: 4rem auto 0;
}

#solutions .values_box #svc {
    padding-top: 10rem;
}

#solutions .values_box .flexbox {
    flex-direction: row-reverse;
}

#solutions .values_box .flexbox figure {
    width: 45%;
}

#solutions .values_box .flexbox .content {
    width: 51%;
}

#solutions .values_box .flexbox .content p {
    margin-bottom: 5rem;
}

#solutions .values_box .flexbox .content h5 {
    margin-bottom: 1rem;
    font-size: 2.3rem;
    line-height: 1.4;
}

#solutions .values_box .flexbox .content li {
    position: relative;
    padding-left: 1rem;
}

#solutions .values_box .flexbox .content li::before {
    content: '';
    position: absolute;
    top: 11px;
    left: 0;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: #000;
}

#solutions .solution_ttl {
    margin-bottom: 8rem;
    padding: 5.5rem 0;
    color: #fff;
    font-size: 2.6rem;
    text-align: center;
}

#solutions .solution_ttl span {
    display: block;
    margin-bottom: 1.5rem;
    font-size: 2.1em;
    text-align: center;
}

#solutions .case_box .solution_ttl {
    background: #0078BE;
}

#solutions .case_box h3 {
    margin-bottom: 4.5rem;
    font-size: 3rem;
}

#solutions .case_box h3 span {
    margin-right: 1.5rem;
    padding: 5px 1rem;
    background: #C2960B;
    color: #fff;
    font-size: 2.4rem;
}

#solutions .case_box .flexbox {
    flex-direction: row-reverse;
    margin-bottom: 15.7rem;
}

#solutions .case_box .flexbox:last-child {
    margin-bottom: 0;
}

#solutions .case_box .flexbox figure {
    width: 45%;
}

#solutions .case_box .flexbox .content {
    width: 50%;
}

#solutions .case_box .flexbox .content h5 {
    margin-bottom: 1rem;
    color: #0078BE;
    font-size: 1.8rem;
}

#solutions .case_box .flexbox .content ul {
    margin-bottom: 2rem;
}

#solutions .case_box .flexbox .content ul:last-child {
    margin-bottom: 0;
}

#solutions .case_box .flexbox .content ul li {
    position: relative;
    padding-left: 1rem;
    font-size: 1.8rem;
}

#solutions .case_box .flexbox .content ul li::before {
    content: '';
    position: absolute;
    top: 14px;
    left: 0;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: #000;
}

#solutions .voice_box .solution_ttl {
    background: #D6A60C;
}

#solutions .voice_box h3 {
    margin-bottom: 6rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid #4FA1D8;
    color: #4FA1D8;
    font-size: 3rem;
}

#solutions .voice_box h3 img {
    width: 64px;
    margin-right: 2.5rem;
}

#solutions .voice_box .flexbox {
    margin-bottom: 7.5rem;
}

#solutions .voice_box .flexbox:nth-of-type(odd) {
    flex-direction: row-reverse;
}

#solutions .voice_box .flexbox:last-child {
    margin-bottom: 0;
}

#solutions .voice_box .flexbox p {
    width: 52%;
}

#solutions .voice_box .flexbox figure {
    width: 45%;
}

@media only screen and ( max-width: 1024px) {
    #solutions .areas_box .bg {
        width: 100%;
        margin-bottom: 4rem;
    }
    #solutions .areas_box .bg:nth-of-type(1) ul,
    #solutions .areas_box .bg:nth-of-type(2) ul {
        justify-content: space-around;
        margin: 0 auto;
    }
    #solutions .areas_box .bg ul li {
        margin-left: 0;
    }
    #solutions .areas_box .bg ul li h3 {
        font-size: 2.2rem;
    }
    #solutions .areas_box h4 {
        font-size: 4.7rem;
    }
    #solutions .areas_box .content .awsbox img {
        width: 130px;
    }
    #solutions .areas_box .content .awsbox p {
        font-size: 1.6rem;
    }
}

@media only screen and ( max-width: 768px) {
    #solutions .inner {
        padding: 0;
    }
    #solutions .title_common {
        padding: 0 2rem;
    }
    #solutions .ttlbox img {
        width: 50px;
        margin-right: 1.5rem;
    }
    #solutions .ttlbox h2 {
        font-size: 1.8rem;
    }
    #solutions .ttlbox h2 span {
        font-size: 1.6em;
        line-height: 1.2;
    }
    #solutions .areas_box .bg {
        margin-bottom: 2.6rem;
    }
    #solutions .areas_box .bg:nth-of-type(1) {
        margin-bottom: 0;
    }
    #solutions .areas_box .bg ul {
        max-width: 370px;
    }
    #solutions .areas_box .bg ul li a {
        width: 130px;
        margin-bottom: 1rem;
        padding-top: 3rem;
        background-size: 130px;
    }
    #solutions .areas_box .bg ul li a img {
        width: 103px;
    }
    #solutions .areas_box .bg ul li h3 {
        font-size: 2rem;
    }
    #solutions .areas_box .content .awsbox img {
        width: 100px;
    }
    #solutions .areas_box .content .awsbox p {
        margin-left: 1rem;
        font-size: 1.4rem;
    }
    #solutions .areas_box .gray_bg .inner {
        padding: 4.5rem 2rem;
    }
    #solutions .areas_box .container .content {
        width: 100%;
        margin-bottom: 3rem;
    }
    #solutions .areas_box .container .content h3 {
        font-size: 1.8rem;
    }
    #solutions .areas_box .container figure {
        width: 100%;
    }
    #solutions .areas_box h4 {
        right: 50%;
        bottom: -25px;
        transform: translate(50%, 0);
        width: 100%;
        font-size: 6.5vw;
        text-align: center;
    }
    #solutions .values_box .container {
        height: auto;
        padding-bottom: 54rem;
    }
    #solutions .values_box .container .iconbox {
        bottom: 338px;
        max-width: 400px;
    }
    #solutions .values_box .container .iconbox figure a {
        width: 150px;
        height: 150px;
        margin-bottom: 2rem;
    }
    #solutions .values_box .container .iconbox figure:nth-of-type(1) a img {
        width: 110px;
    }
    #solutions .values_box .container .iconbox figure:nth-of-type(2) a img {
        width: 70px;
    }
    #solutions .values_box .container .iconbox figcaption {
        font-size: 1.6rem;
    }
    #solutions .values_box #loop {
        padding: 7rem 2rem 0;
    }
    #solutions .values_box #loop .ttlbox img {
        width: 95px;
    }
    #solutions .values_box #svc {
        padding-top: 8rem;
    }
    #solutions .values_box #svc .ttlbox {
        padding: 0 2rem;
    }
    #solutions .values_box #svc .ttlbox img {
        width: 55px;
    }
    #solutions .values_box .flexbox {
        flex-direction: column-reverse;
    }
    #solutions .values_box .flexbox .content {
        width: 100%;
        margin-bottom: 5rem;
        padding: 0 2rem;
    }
    #solutions .values_box .flexbox .content p {
        margin-bottom: 4rem;
    }
    #solutions .values_box .flexbox figure {
        width: 100%;
    }
    #solutions .solution_ttl {
        margin-bottom: 5rem;
        padding: 3.5rem 0;
        font-size: 2rem;
    }
    #solutions .case_box h3 {
        padding: 0 2rem;
        font-size: 2.4rem;
    }
    #solutions .case_box h3 span {
        display: table;
        margin-bottom: 1rem;
        padding: 8px 1rem;
        font-size: 1.8rem;
    }
    #solutions .case_box .flexbox {
        flex-direction: column-reverse;
        margin-bottom: 6rem;
    }
    #solutions .case_box .flexbox figure {
        width: 100%;
    }
    #solutions .case_box .flexbox .content {
        width: 100%;
        margin-bottom: 4rem;
        padding: 0 2rem;
    }
    #solutions .case_box .flexbox .content h5 {
        font-size: 1.6rem;
    }
    #solutions .case_box .flexbox .content ul li {
        font-size: 1.6rem;
    }
    #solutions .voice_box h3 {
        display: flex;
        align-items: center;
        margin: 0 2rem 3rem;
        font-size: 2.4rem;
    }
    #solutions .voice_box h3 img {
        width: 50px;
        margin-right: 1.5rem;
    }
    #solutions .voice_box .flexbox,
    #solutions .voice_box .flexbox:nth-of-type(odd) {
        flex-direction: column-reverse;
    }
    #solutions .voice_box .flexbox p {
        width: 100%;
        margin-bottom: 3rem;
        padding: 0 2rem;
    }
    #solutions .voice_box .flexbox figure {
        width: 100%;
    }
}

@media only screen and ( max-width: 500px) {
    #solutions .ttlbox img {
        width: 37px;
        margin-right: 1rem;
    }
    #solutions .ttlbox h2 {
        font-size: 1.6rem;
    }
    #solutions .areas_box .title_common {
        margin-bottom: 2.6rem;
    }
    #solutions .areas_box .bg {
        padding: 2.1rem 2rem 5px;
    }
    #solutions .areas_box .bg ul li h3 {
        font-size: 1.6rem;
    }
    #solutions .areas_box .bg ul li a {
        padding-top: 2.5rem;
        background-size: 110px;
    }
    #solutions .areas_box .bg ul li a::before {
        bottom: 16px;
        height: 30px;
    }
    #solutions .areas_box .bg ul li a::after {
        width: 13px;
        height: 13px;
    }
    #solutions .areas_box .bg ul li a img {
        width: 85px;
        margin-bottom: 4.6rem;
    }
    #solutions .areas_box .bg ul li p {
        font-size: 1.2rem;
    }
    #solutions .values_box .container {
        padding-bottom: 49rem;
    }
    #solutions .values_box .container .iconbox figure a {
        width: 120px;
        height: 120px;
    }
    #solutions .values_box .container .iconbox figure:nth-of-type(1) a img {
        width: 90px;
    }
    #solutions .values_box .container .iconbox figure:nth-of-type(2) a img {
        width: 55px;
    }
    #solutions .values_box .container .iconbox figcaption {
        font-size: 1.4rem;
    }
    #solutions .case_box h3 {
        margin-bottom: 3rem;
        font-size: 2rem;
    }
    #solutions .case_box h3 span {
        font-size: 1.6rem;
    }
    #solutions .case_box .flexbox .content h5 {
        font-size: 1.4rem;
    }
    #solutions .case_box .flexbox .content ul li {
        font-size: 1.4rem;
    }
    #solutions .voice_box h3 {
        font-size: 1.8rem;
    }
}


/*-------------------------------------------------

	Employment Agency

--------------------------------------------------*/

#employment .container1 .title_common h2 {
    font-size: 3.5rem;
}

#employment .container1 figure {
    margin-bottom: 4rem;
}

#employment .container1 .content {
    position: relative;
    z-index: 1;
    width: 48%;
}

#employment .container1 .content::before {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
    transform: translate(20px, 20px);
    width: 100%;
    height: 100%;
    background-image: repeating-linear-gradient(-45deg, #D6A60C, #D6A60C .7px, transparent 0, transparent 10px);
}

#employment .container1 .txtbox {
    padding: 6rem 8rem 5rem;
    border: 1px solid #D6A60C;
    background: #fff;
}

#employment .container1 h3 {
    margin-bottom: 2.5rem;
    color: #D6A60C;
    font-size: 2.4rem;
}

#employment .container2 dl {
    overflow: hidden;
}

#employment .container2 dl dt {
    display: flex;
    align-items: center;
    width: 472px;
    height: 10rem;
    float: left;
    clear: both;
    margin: 0 2rem 2rem 0;
    padding: 5px;
    border-radius: 0 2rem 2rem 0;
    background: #FDF3D6;
    font-size: 2.4rem;
}

#employment .container2 dl dt:last-child {
    margin-bottom: 0;
}

#employment .container2 dl dt span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 88px;
    height: 88px;
    margin-right: 3rem;
    background: #fff;
    font-size: 2.4rem;
}

#employment .container2 dl dd {
    display: flex;
    align-items: center;
    position: relative;
    height: 10rem;
    margin-bottom: 2rem;
    border-bottom: 1px solid #000;
}

#employment .container2 dl dd:last-child {
    margin-bottom: 0;
    border-bottom: 0;
}

#employment .container3 .flexbox {
    position: relative;
    max-width: 90.4rem;
    margin: 0 auto;
}

#employment .container3 .flexbox::before,
#employment .container3 .flexbox::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 50%;
    transform: translate(-50%, 50%);
    background: #000;
}

#employment .container3 .flexbox::before {
    width: 100%;
    height: 1px;
}

#employment .container3 .flexbox::after {
    width: 1px;
    height: 100%;
}

#employment .container3 figure {
    width: 48%;
    margin-bottom: 7rem;
}

#employment .container3 figure:nth-last-of-type(1),
#employment .container3 figure:nth-last-of-type(2) {
    margin-bottom: 0;
}

@media only screen and ( max-width: 1024px) {
    #employment .container1 .content {
        width: 98%;
        margin-bottom: 6rem;
    }
    #employment .container1 .content::before {
        transform: translate(15px, 15px);
        background-image: repeating-linear-gradient(-45deg, #D6A60C, #D6A60C .7px, transparent 0, transparent 6px);
    }
    #employment .container1 .content:last-child {
        margin-bottom: 0;
    }
    #employment .container2 dl dt {
        float: none;
        width: 100%;
        height: 6rem;
    }
    #employment .container2 dl dt span {
        width: 52px;
        height: 52px;
        margin-right: 2rem;
    }
    #employment .container2 dl dd {
        height: auto;
        padding-bottom: 2rem;
    }
    #employment .container2 dl dd:last-child {
        padding-bottom: 0;
    }
    #employment .container3 .flexbox::before,
    #employment .container3 .flexbox::after {
        display: none;
    }
}

@media only screen and ( max-width: 768px) {
    #employment .container1 .title_common h2 {
        font-size: 2.5rem;
        text-align: left;
    }
    #employment .container1 .title_common p {
        text-align: left;
    }
    #employment .container1 figure {
        margin: -2.6rem -2rem 3rem;
    }
    #employment .container1 .txtbox {
        padding: 2rem;
    }
    #employment .container1 h3 {
        margin-bottom: 1.5rem;
        font-size: 2rem;
    }
    #employment .container2 dl dt {
        font-size: 2rem;
    }
    #employment .container3 figure {
        width: 90%;
        margin: 0 auto 3rem;
    }
    #employment .container3 figure:nth-last-of-type(2) {
        margin-bottom: 3rem;
    }
}

@media only screen and ( max-width: 500px) {
    #employment .container1 .title_common h2 {
        font-size: 2rem;
    }
    #employment .container2 dl dt {
        font-size: 1.8rem;
    }
}


/*-------------------------------------------------

	Recent Update List

--------------------------------------------------*/

#updates-ac ul {
    padding: 5rem 7rem;
    background: #fff;
}

#updates-ac ul li {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    position: relative;
    width: 100%;
    border-bottom: 1px solid #ccc;
}

#updates-ac ul li:nth-of-type(1) {
    border-top: 1px solid #ccc;
}

#updates-ac ul li::before {
    content: "";
    position: absolute;
    right: 0;
    bottom: 50%;
    transform: translate(0, 50%) rotate(-45deg);
    width: 7px;
    height: 7px;
    border-right: 1px solid #3D3D3D;
    border-bottom: 1px solid #3D3D3D;
}

#updates-ac ul li span {
    width: 100px;
    padding: 2.5rem 0;
    line-height: 1.8;
}

#updates-ac ul li a {
    flex: 1;
    display: block;
    padding: 2.5rem 0;
    line-height: 1.8;
}

#updates-ac ul li a:hover {
    color: #ccc;
}

#updates-ac ul li a h5 {
    display: block;
    width: 100%;
    max-width: 162px;
    margin-bottom: 1rem;
    padding: 5px 0;
    background: #154F9E;
    color: #fff;
    text-align: center;
}

@media only screen and ( max-width: 768px) {
    #updates-ac ul {
        position: relative;
        padding: 5rem 2rem;
    }
    #updates-ac ul li {
        display: block;
    }
    #updates-ac ul li::before {
        display: none;
    }
    #updates-ac ul li span {
        display: block;
        padding: 1rem 0 0;
    }
    #updates-ac ul li a h5 {
        position: absolute;
        top: 10px;
        left: 70px;
        max-width: 140px;
    }
}

@media only screen and ( max-width: 500px) {}


/*-------------------------------------------------

	Recent Updates

--------------------------------------------------*/

#updates-sg .container {
    margin-bottom: 5rem;
    padding: 5rem 7rem;
    background: #fff;
}

#updates-sg .container .ttlbox {
    margin-bottom: 5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid #ccc;
}

#updates-sg .container .ttlbox p.time_tag {
    margin-bottom: 2rem;
}

#updates-sg .container .ttlbox p.time_tag span {
    display: inline-block;
    width: 100%;
    max-width: 162px;
    margin-left: 2rem;
    padding: 8px 0;
    background: #154F9E;
    color: #fff;
    text-align: center;
}

#updates-sg .container .ttlbox h1 {
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 1.5;
}

#updates-sg .container p {
    margin-bottom: 2em;
}

#updates-sg .container p:last-child {
    margin-bottom: 0;
}

#updates-sg .container p img {
    width: auto;
    max-width: 100%;
}

#updates-sg .container h2 {
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 4rem;
    border-left: 4px solid #154F9E;
    padding: 0 20px 0 20px;
    margin: 1.2em -20px;
    clear: both;
}

#updates-sg .container h3 {
    font-size: 2.4rem;
    font-weight: 700;
    margin: 35px 0 0;
    padding: 10px 12px;
    background: #eff6ff;
    border-left: solid 2px #4FA0D8;
}

#updates-sg .container h4 {
    display: inline-block;
    position: relative;
    margin-bottom: 1em;
    padding: 0 1rem 0 3rem;
    background: linear-gradient(transparent 40%, #EAEAEA 40%);
    font-weight: 700;
    font-size: 2rem;
}

#updates-sg .container h4::before {
    content: "";
    position: absolute;
    left: 5px;
    bottom: 50%;
    transform: translate(0, 50%);
    width: 0;
    height: 0;
    border-top: 10px solid transparent;
    border-left: 12px solid #000;
    border-bottom: 10px solid transparent;
    border-radius: 5px;
}

#updates-sg .container h5 {
    display: inline-block;
    max-width: 150px;
    width: 100%;
    margin-bottom: 1em;
    padding: 8px 0;
    background: #154F9E;
    color: #fff;
    text-align: center;
}

#updates-sg .container h6 {
    font-weight: 700;
    color: #154F9E;
    display: inline-block;
    margin-bottom: 1em;
}

#updates-sg .container a {
    color: #154F9E;
    display: inline-block;
    text-decoration: underline;
}

#updates-sg .container a:hover {
    opacity: 0.3;
}

#updates-sg .container p strong {
    font-weight: 700;
}

#updates-sg .container ul {
    margin-bottom: 1em;
    margin-left: 20px;
    line-height: 1.6;
    list-style-type: square;
}

#updates-sg .container ol {
    margin-bottom: 1em;
    margin-left: 16px;
    list-style-type: decimal;
    line-height: 1.6;
}

#updates-sg .container dl {
    overflow: hidden;
    margin-bottom: 1em;
}

#updates-sg .container dl dt {
    float: left;
}

#updates-sg .container dl dd {
    padding-left: 80px;
}

@media only screen and ( max-width: 768px) {
    #updates-sg .container {
        padding: 4rem 2rem;
    }
    #updates-sg .container .ttlbox {
        display: block;
        margin-bottom: 3rem;
        padding: 0 0 1rem;
    }
    #updates-sg .container .ttlbox p {
        margin: 0 0 2rem;
    }
    #updates-sg .container .ttlbox h1 {
        font-size: 2rem;
    }
    #updates-sg .container h2 {
        font-size: 1.8rem;
    }
    #updates-sg .container h3 {
        padding: 5px 12px;
        font-size: 1.6rem;
    }
    #updates-sg .container p {
        margin-bottom: 2rem;
    }
    #updates-sg .container h4 {
        margin-bottom: 1.5rem;
        font-size: 1.6rem;
    }
    #updates-sg .container h5 {
        max-width: 110px;
    }
}

@media only screen and ( max-width: 500px) {}


/*-------------------------------------------------

	INGATE Overview

--------------------------------------------------*/

#about.blank {
    padding-top: 0;
}

#about .inner_s {
    max-width: 1107px;
}

#about section {
    padding-top: 12rem;
}

#about section:last-child {
    margin-bottom: 0;
}

#about .title_common {
    border-bottom: 1px solid #D6A60C;
}

#about .content {
    max-width: 897px;
    margin: 0 auto;
    padding: 3rem;
    background: url("../img/about/ms_bg.jpg") no-repeat center / cover;
}

#about .content p {
    margin-bottom: 3rem;
}

#about .content p:last-child {
    margin-bottom: 0;
    text-align: right;
}

#about ul {
    max-width: 897px;
    margin: 0 auto;
}

#about ul li {
    margin-bottom: 4rem;
    font-size: 2rem;
}

#about ul li h3 {
    margin-bottom: 1.5rem;
    color: #C2960B;
    font-size: 2.6rem;
}

#about ul li h3 span {
    text-decoration: underline;
}

#about ul li p:nth-of-type(1) {
    margin-bottom: 4rem;
}

#about dl {
    display: flex;
    flex-wrap: wrap;
    max-width: 681px;
    margin: 0 auto;
}

#about dl dt {
    width: 20%;
}

#about dl dd {
    width: 80%;
    margin-bottom: 2rem;
}

#about dl dd a {
    text-decoration: underline;
    color: #154F9E;
}

.mapbox {
    max-width: 681px;
    margin: 0 auto;
}

.mapbox h4 {
    margin-bottom: 1rem;
}

.mapbox .map {
    position: relative;
    width: 100%;
    margin-bottom: 5rem;
    padding-top: 36.25%;
}

.mapbox .map:last-child {
    margin-bottom: 0;
}

.mapbox .map iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

@media only screen and ( max-width: 768px) {
    #about section {
        padding-top: 8rem;
    }
    #about .content {
        margin: 0 -2rem;
    }
    #about ul li {
        margin-bottom: 3rem;
        font-size: 1.6rem;
    }
    #about ul li h3 {
        font-size: 2rem;
    }
    #about dl {
        margin: 0 0 0 -2rem;
        border-bottom: none;
    }
    #about dl:nth-child(2) {
        margin-bottom: 0;
    }
    #about dl dt {
        display: block;
        position: relative;
        width: 100%;
        padding: 0 0 1rem 5rem;
    }
    #about dl dt::before {
        content: '';
        position: absolute;
        top: 1px;
        left: 0;
        width: 38px;
        height: 22px;
        background: #EAEAEA;
    }
    #about dl dd {
        display: block;
        width: 100%;
        padding-left: 5rem;
    }
    .mapbox {
        padding: 0 2rem;
    }
    .map {
        margin-bottom: 3rem;
    }
}

@media only screen and ( max-width: 500px) {}


/*-------------------------------------------------

　   PRIVACY POLICY

--------------------------------------------------*/

#privacy .box {
    padding: 9rem 7.5rem 5rem;
    background: #fff;
}

#privacy .content {
    margin-bottom: 5rem;
}

#privacy .content:last-child {
    margin-bottom: 0;
}

#privacy .bottom {
    margin-bottom: 3rem;
}

#privacy h2 {
    margin-bottom: 4.5rem;
    padding-left: 1rem;
    border-left: 6px solid #000;
    font-size: 3rem;
}

#privacy h3 {
    position: relative;
    margin-bottom: 4rem;
    padding-left: 4rem;
    font-size: 2.4rem;
}

#privacy h3::before {
    content: '';
    position: absolute;
    top: 7px;
    left: 0;
    width: 20px;
    height: 20px;
    background: #000;
}

#privacy table {
    margin-bottom: 3rem;
}

#privacy th {
    width: 10rem;
}

#privacy td {
    padding-bottom: 2rem;
}

#privacy tr:last-child td {
    padding-bottom: 0;
}

#privacy .txt_r {
    margin-bottom: 4rem;
    text-align: right;
}

#privacy li {
    margin: 0 0 1rem 3rem;
    padding-left: 15px;
}

#privacy ol.numeric > li {
    list-style-type: decimal;
}

#privacy ol.alpha > li {
    margin-left: 6rem;
    list-style-type: upper-alpha;
}

#privacy ul li {
    margin-left: 6rem;
    list-style-type: disc;
}

#privacy a {
    text-decoration: underline;
}

@media only screen and ( max-width: 768px) {
    #privacy .box {
        padding: 5rem 3rem 4rem;
    }
    #privacy h2 {
        font-size: 2.4rem;
    }
    #privacy h3 {
        margin-bottom: 2rem;
        font-size: 2rem;
    }
    #privacy h3::before {
        top: 5px;
    }
    #privacy th {
        width: 7rem;
    }
}

@media only screen and ( max-width: 500px) {
    #privacy .box {
        padding: 4rem 2rem 3rem;
    }
    #privacy .content {
        margin-bottom: 3rem;
    }
    #privacy h2 {
        margin-bottom: 3rem;
        font-size: 2rem;
    }
    #privacy h3 {
        font-size: 1.7rem;
        padding-left: 2.5rem;
    }
    #privacy h3::before {
        width: 15px;
        height: 15px;
    }
    #privacy th {
        width: 5rem;
    }
    #privacy li {
        margin-left: 2rem;
        padding-left: 5px;
    }
}


/*-------------------------------------------------

　   CONTACT

--------------------------------------------------*/

#contact .content {
    padding: 5rem 2rem;
    background: #fff;
}

#contact table {
    max-width: 797px;
    margin: 0 auto 4rem;
}

#contact tr {
    display: flex;
    margin-bottom: 1rem;
}

#contact th {
    width: 100%;
    max-width: 216px;
    padding: 1.5rem 4rem 1.5rem 0;
    text-align: right;
    vertical-align: top;
}

#contact tr:last-child th {
    padding-top: 0;
}

#contact td {
    width: 100%;
    vertical-align: middle;
}

#contact td a {
    text-decoration: underline;
}

#contact input[type="text"],
#contact input[type="tel"],
#contact input[type="email"],
#contact select,
#contact textarea {
    width: 100%;
    height: 6rem;
    padding: 1rem;
    border: 1px solid #000;
    border-radius: 10px;
    background: #fff;
    font-size: 1.6rem;
    line-height: 1.8;
    resize: vertical;
    vertical-align: bottom;
}

#contact select {
    font-size: 1.6rem;
    -moz-appearance: menulist;
    -webkit-appearance: menulist;
    appearance: menulist;
}

#contact textarea {
    height: auto;
}

input:focus,
input:focus {
    outline: none;
    filter: drop-shadow(0 0 2px #000);
}

span.horizontal-item input {
    display: none;
}

.mw_wp_form .error {
    margin-top: 10px;
}

.checkbox {
    display: none;
}

.mwform-checkbox-field-text {
    position: relative;
    padding: 4px 0 0 4rem;
    cursor: pointer;
    user-select: none;
}

.mwform-checkbox-field-text::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 24px;
    height: 24px;
    border: 1px solid #000;
    border-radius: 5px;
    background: #fff;
}

.checkbox:checked+.mwform-checkbox-field-text {
    color: #0078BE;
}

.checkbox:checked+.mwform-checkbox-field-text::after {
    content: "";
    display: block;
    position: absolute;
    top: 6px;
    left: 10px;
    width: 5px;
    height: 10px;
    transform: rotate(40deg);
    border-bottom: 3px solid #000;
    border-right: 3px solid #000;
}

#contact .form_btn {
    display: block;
    position: relative;
    width: 100%;
    max-width: 30rem;
    margin: 0 auto;
    padding: 1.5rem 0;
    border: 1px solid #000;
    border-radius: 10rem;
    background: #fff;
    font-size: 1.6rem;
    text-align: center;
    transition: .3s;
}

#contact .btnbox {
    position: relative;
    max-width: 30rem;
    margin: 0 auto;
}

#contact .btnbox::before,
#contact .form_btn::before {
    content: "";
    position: absolute;
    right: 2.5rem;
    bottom: 50%;
    z-index: 1;
    transform: translate(0, 50%) rotate(-45deg);
    width: 7px;
    height: 7px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    transition: .3s;
}

#contact .form_btn:hover {
    background: #000;
    color: #fff;
}

#contact .btnbox:hover::before,
#contact .form_btn:hover::before {
    border-color: #fff;
}

#contact h4 {
    margin-bottom: 4rem;
    font-weight: 700;
    font-size: 3rem;
    text-align: center;
}

.confirm td {
    padding: 1.5rem 0;
}

.complete .txtbox {
    padding: 8rem 0;
    background: #fff;
}

.complete h2 {
    margin-bottom: 5rem;
    font-weight: 700;
    font-size: 3rem;
    text-align: center;
}

.complete p {
    text-align: center;
    margin-bottom: 5rem;
}

@media only screen and ( max-width: 768px) {
    #contact .content {
        padding: 3rem 2rem;
    }
    #contact tr {
        display: block;
    }
    #contact th {
        display: block;
        padding: 0 0 1rem;
        text-align: left;
    }
    #contact td {
        display: block;
        margin-bottom: 3rem;
    }
    #contact tr:last-child td {
        margin-bottom: 0;
        padding: 0;
    }
    #contact input[type="text"],
    #contact input[type="tel"],
    #contact input[type="email"],
    #contact select,
    #contact option,
    #contact textarea {
        font-size: 1.4rem;
    }
    .confirm td {
        padding: 0;
    }
    .complete .txtbox {
        padding: 5rem 0;
    }
}