@charset "UTF-8";
/* ----------------------------------------------------------
働く環境
---------------------------------------------------------- */
footer{
    background: none;
    padding-top: 0;
}
#environment [id*=content]{
    margin-top: -70px;
    padding-top: 70px;
}
/* インデックス */
.environment_Wrap aside .index_Box .index ul.index-List > li{
    font-size: 1.6rem;
    font-weight: 500;
    color: #fff;
    margin-bottom: 20px;
    transition: 0.3s;
}
.environment_Wrap aside .index_Box .index ul.index-List > li:hover{
    opacity: 0.7;
}
.environment_Wrap aside .index_Box .index ul.index-List > li > a{
    position: relative;
    display: block;
    width: 100%;
    color: #fff;
    padding-left: 1em;
    opacity: 0.3;
    transition: 0s;
}
.environment_Wrap aside .index_Box .index ul.index-List > li > a::before{
    position: absolute;
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--seablue);
    top: 0.4em;
    left: 0;
}
.environment_Wrap aside .index_Box .index ul.index-List > li > a.current{
    opacity: 1;
}

.lower_ttl_Box .main_ttl::before{
    background: var(--skyblue);
}
#environment{
    position: relative;
    width: 100%;
    background: url(../img/navy_bg.jpg) center center repeat-y;
    background-size: cover;
    background-attachment: fixed;
    transition: color .5s ease-out;
    will-change: color;
}
#environment::after{
    position: fixed;
    content: "";
    width: 100%;
    height: 100%;
    inset: 0;
    z-index: -1;
    background: #eee;
    transition: opacity .5s ease-out;
    will-change: opacity;
    backface-visibility: hidden;
    opacity: 0;
}
.environment_Wrap{
    padding: 100px 0 0;
}
.environment_Wrap .Wrap_ttl{
    padding: 10px;
    border-bottom: 1px solid var(--bluegray);
    margin-bottom: 50px;
}
.environment_Wrap .Wrap_ttl h2{
    color: #fff;
}
.environment_Wrap .Wrap_ttl .lead_txt{
    color: #fff;
    padding-bottom: 10px;
    letter-spacing: 0.1em;
}
/* 見出し */
.lower_ttl_Box .main_ttl{
    color: #fff;
}
.lower_ttl_Box h2,
.lower_ttl_Box h3{
    color: #fff;
}
.company_sub-section h3{
    color: var(--skyblue);
    font-size: 2.4rem;
    margin: 30px 0 15px;
}

/* --------------------------------
制度
----------------------------------- */
.environment_Area .system_Box{
    margin-bottom: 40px;
}
.system_List{
    margin-top: 20px;
}
.system_List li{
    display: flex;
    flex-direction: column;
    border: 1px solid var(--bluegray);
    border-radius: 8px;
    color: #fff;
    margin-bottom: 20px;
}
.system_List.col-1 li{
    width: 100%;
}
.system_List.col-2 li{
    width: 49%;
}
.system_List.col-3 li{
    width: calc((100% / 3) - 1%);
}
.system_List li .top_Box{
    padding: 20px;
}
.system_List li .top_Box h3{
    font-size: 2rem;
    line-height: 1.4;
    letter-spacing: 0.08em;
    margin-bottom: 10px;
    padding-left: 1em;
    text-indent: -0.5em;
}
.system_List li .top_Box h3 span.material-symbols-sharp{
    color: var(--skyblue);
    font-size: 3rem;
    font-weight: 200;
    vertical-align: -7px;
    margin-right: 2px;
}
.system_List li .top_Box h3 small{
    font-size: 70%;
}
.system_List li sup{
    font-size: 50%;
    vertical-align: top;
}
.system_List li .note{
    position: relative;
    margin-top: 10px;
    font-size: 1.2rem;
    line-height: 1.4;
    letter-spacing: 0.05em;
    padding-left: 1em;
}
.system_List li .note::before{
    position: absolute;
    content: "※";
    color: #fff;
    font-size: inherit;
    top: 0;
    left: 0;
}
.system_List li .bottom_Box{
    margin-top: auto;
    padding: 20px;
    border-top: 1px solid  var(--bluegray);
    text-align: center;
}
.system_List li h4{
    font-size: 2rem;
    margin-bottom: 10px;
    letter-spacing: 0.05em;
}
.system_List li .value{
    font-size: 4rem;
    line-height: 0.8;
    letter-spacing: 0.05em;
}
.system_List li .value span.js-num{
    color: var(--skyblue);
    font-family: "Montserrat", sans-serif;
    font-size: 200%;
    font-weight: bold;
    font-style: italic;
}
.system_List li dl{
    align-items: center;
    margin-bottom: 15px;
    padding: 0 5px 15px;
    border-bottom: 1px solid var(--bluegray);
}
.system_List li dl:last-child{
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}
.system_List li dl dt{
    font-size: 1.6rem;
    color: #fff;
}
.system_List li dl dd .value{
    font-size: 2rem;
}

/* --------------------------------
福利厚生
----------------------------------- */
.system_List.benefits{
    justify-content: flex-start;
}
.system_List.benefits li{
    margin-right: 1.5%;
    margin-bottom: 15px;
    padding: 15px;
}
.system_List.benefits li:nth-child(3n){
    margin-right: 0;
}
.system_List.benefits li figure{
    text-align: center;
    margin-bottom: 10px;
}
.system_List.benefits li figure span.material-symbols-sharp{
    font-size: 7rem;
    font-weight: 200;
    color: var(--skyblue);
}
.system_List.benefits li h3{
    font-size: 2rem;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-align: center;
    margin-bottom: 10px;
}
.system_List.benefits li .txt{
    font-size: 1.4rem;
    letter-spacing: 0.08em;
}

/* --------------------------------
データで見るMS-Japan
----------------------------------- */
.system_List.data li{
    position: relative;
    padding: 15px;
}
.system_List.data li.center{
    text-align: center;
}
.system_List.data li.graph::after{
    position: absolute;
    color: var(--skyblue);
    font-size: 6rem;
    font-weight: 200;
    font-family: "material symbols sharp";
    top: 8px;
    right: 5px;
}
.system_List.data li.graph:nth-child(3)::after{ content: "\e63d";}
.system_List.data li.graph:nth-child(4)::after{ content: "\e55e";}
.system_List.data li.graph:nth-child(5)::after{
    content: "\f233";
    top: 0;
    right: 10px;
}
.system_List.data li.graph:nth-child(6)::after{ content: "\e8f9";}

.system_List.data li.graph .graph_Box{
    align-items: center;
}
.system_List.data li.graph .graph_Box figure{
    width: 62%;
}
.system_List.data li.graph .graph_Box .hanrei{
    width: 34%;
}
.system_List.data li.graph .graph_Box .hanrei li{
    position: relative;
    display: inline-block;
    width: 100%;
    border: none;
    font-size: 1.6rem;
    font-family: "Montserrat", 'Noto Sans JP', serif;
    line-height: 1.2;
    letter-spacing: 0.05em;
    margin-bottom: 10px;
    padding: 0;
    padding-left: 1em;
}
.system_List.data li.graph .graph_Box .hanrei li::before{
    position: absolute;
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    border: 1px solid #fff;
    top: 0.3em;
    left: 0;
}
.system_List.data li.graph .graph_Box .hanrei li:nth-child(1)::before{ background: var(--blue);}
.system_List.data li.graph .graph_Box .hanrei li:nth-child(2)::before{ background: var(--skyblue);}
.system_List.data li.graph .graph_Box .hanrei li:nth-child(3)::before{ background: var(--seablue);}

/* ==============================================================
PC(1600px~)
============================================================== */
@media screen and (min-width: 1600px) {


}

/* ==============================================================
PC・TAB(~1000px)
============================================================== */
@media screen and (max-width:1000px) {

    .environment_Wrap aside,
    .environment_Wrap main{
        width: 100%;
        max-width: none;
    }
}

/* ==============================================================
PC・TAB(~820px)
============================================================== */
@media screen and (max-width:820px) {


}

/* ==============================================================
SP(~768px)
============================================================== */
@media screen and (max-width:768px) {

    #environment{
        position: relative;
    }
    #environment::before{
        position:fixed;
        content:"";
        display:block;
        top:0;
        left:0;
        z-index:-1;
        width:100%;
        height:100vh;
        background-repeat:no-repeat;
        background-position:50% 100%;
        background-image:url(../img/navy_bg.jpg);
        background-size:cover;
    }
    #environment [id*=content] {
        margin-top: 0;
        padding-top: 0;
    }
    .environment_Wrap {
        padding: 70px 0 0;
    }
    .environment_Wrap .Wrap_ttl{
        margin-bottom: 20px;
    }
    .environment_Wrap .Wrap_ttl h2{
        margin-bottom: 10px;
    }

    .environment_Wrap aside{
        display: none;
    }
    .environment_Wrap main{
        margin-top: 0;
    }
    .environment_Wrap .lower_ttl_Box{
        margin-bottom: 10px;
        padding: 0 5px;
    }

    /* --------------------------------
    制度
    ----------------------------------- */
    .system_List {
        margin-top: 0;
    }
    .system_List.col-2 li {
        width: 100%;
        margin-bottom: 15px;
    }
    .system_List li .top_Box{
        padding: 12px;
    }
    .system_List li .bottom_Box{
        padding: 10px;
    }
    .system_List li .top_Box h3 span.material-symbols-sharp {
        font-size: 2.2rem;
        font-weight: 400;
        vertical-align: -4px;
    }
    .system_List li .top_Box h3 {
        font-size: 1.8rem;
        letter-spacing: 0.03em;
        margin-bottom: 5px;
    }
    .system_List li h4 {
        font-size: 1.6rem;
    }
    .system_List li .value {
        font-size: 2rem;
    }
    .system_List li dl {
        margin-bottom: 12px;
        padding: 0 5px 10px;
    }

    /* --------------------------------
    福利厚生
    ----------------------------------- */
    .environment_Area .system_Box {
        margin-bottom: 20px;
    }
    .system_List.benefits {
        justify-content: space-between;
    }
    .system_List.benefits li {
        width: 49%;
        margin-right: 0;
        margin-bottom: 10px;
        padding: 10px;
    }
    .system_List.benefits li figure{
        margin-bottom: 0;
    }
    .system_List.benefits li figure span.material-symbols-sharp {
        font-size: 5rem;
    }
    .system_List.benefits li h3 {
        font-size: 1.6rem;
        line-height: 1.3;
        letter-spacing: 0.05em;
        margin-bottom: 5px;
    }
    .system_List.benefits li .txt {
        font-size: 1.3rem;
        line-height: 1.3;
        letter-spacing: 0.05em;
        text-align: justify;
    }
    .system_List.benefits.col-3_02 li{
        width: 100%;
    }
    .system_List.benefits.col-3_02 li .ttl_Box{
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .system_List.benefits.col-3_02 li .ttl_Box figure span.material-symbols-sharp{
        font-size: 3rem;
        margin-right: 5px;
    }
    .system_List.benefits.col-3_02 li .ttl_Box h3{
        margin-bottom: 0;
    }
    .system_List.benefits.col-3_02 li .txt{
        padding: 5px 3px 0;
        border-top: 1px solid var(--bluegray);
    }

    /* --------------------------------
    データで見るMS-Japan
    ----------------------------------- */
    .system_List.data li{
        margin-bottom: 10px;
    }
    .system_List.data li.graph .graph_Box .hanrei li {
        font-size: 1.4rem;
        margin-bottom: 5px;
    }
    .system_List.data li.graph::after {
        font-size: 4rem;
    }
    .system_List.data li.graph .graph_Box figure{
        width: 55%;
    }
    .system_List.data li.graph .graph_Box .hanrei {
        width: 43%;
    }
}