@charset "UTF-8";

/* =========================================================
  body
========================================================= */
.inner {
    width: 1100px;
}

/* =========================================================
  header
========================================================= */
header {
    position: fixed;
    top: 0;
}

/* =========================================================
  section
========================================================= */
section {
    text-align: center;
    padding: 90px 0 60px;
}

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

 TOP

-------------------------------- */
/* =========================================================
  #hero
========================================================= */
#hero {
    position: relative;
    padding: 0;
    margin: 100px 0 0;
    width: 100%;
    height: auto;
    overflow: hidden;
}

#hero #loading {
    background: #fff;
    width: 100vw;
    height: 100vh;
    position: absolute;
    z-index: 100;
    top: -100px;
}

#hero #loading img {
    width: 40px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    position: absolute;
}

#hero #hero_movie {
    width: 100%;
    height: auto;
    position: absolute;
    z-index: 1;
}

#hero #hero_bg {
    position: absolute;
    opacity: 1;
    display: none;
}

#hero #hero_bg_sp {
    opacity: 0;
    /*position: absolute;*/
    display: none;
    width: 100%;
    height: auto;
}

#hero .slider_wrap {
    display: none;
}

#hero a {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    bottom: 54px;
    right: 38px;
    width: 150px;
    height: 58px;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 700;
    background: #004B9E;
    color: #fff;
    border-radius: 29px;
    z-index: 1;
}

/* =========================================================
  #news
========================================================= */
#news .sec_ttl span {
    display: block;
    position: relative;
    font-family: "Cinzel", serif;
    font-size: 16px;
    font-size: 1.6rem;
    letter-spacing: .25em;
    margin-bottom: 15px;
    line-height: 3;
    font-weight: 400;
}

#news .sec_ttl span:after {
    content: '';
    position: absolute;
    background: url(../img/top/bg_ttl.png) center center no-repeat;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
    background-size: 75.43px 47.33px;
    width: 75.43px;
    height: 47.33px;
}

#news .sec_ttl h2 {
    font-size: 35px;
    font-size: 3.5rem;
    font-weight: 700;
    line-height: 1.78;
}

#news .inner {
    width: 1100px;
}

#news .inner a.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    border: 2px solid #004B9E;
    border-radius: 35px;
    width: 405px;
    height: 70px;
    text-align: center;
    margin: auto;
    color: #004B9E;
    margin: 30px auto 0;
    box-sizing: border-box;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #news .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl@2x.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 75.43px 47.33px;
        width: 75.43px;
        height: 47.33px;
    }
}

/* =========================================================
  #about
========================================================= */
#about .sec_ttl span {
    display: block;
    position: relative;
    font-family: "Cinzel", serif;
    font-size: 16px;
    font-size: 1.6rem;
    letter-spacing: .25em;
    margin-bottom: 15px;
    line-height: 3;
    font-weight: 400;
}

#about .sec_ttl span:after {
    content: '';
    position: absolute;
    background: url(../img/top/bg_ttl.png) center center no-repeat;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
    background-size: 75.43px 47.33px;
    width: 75.43px;
    height: 47.33px;
}

#about .sec_ttl h2 {
    font-size: 35px;
    font-size: 3.5rem;
    font-weight: 700;
    line-height: 1.78;
}

#about .link_box {
    display: flex;
    flex-wrap: wrap;
    margin-top: 60px;
}

/* 210913 経営理念土屋　ここから */
#about .link_box li {
    /* width: 50%; */
    width: 100%;
    height: 300px;
    background: #f2f2f2;
    box-sizing: border-box;
    position: relative;
}

/* 210913 経営理念土屋　ここまで */

#about .link_box li .img_box {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
}

#about .link_box li .img_box img {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    max-width: inherit;
}

#about .link_box li .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width: 100%;
    height: 300px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

#about .link_box li .txt_box p {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    width: 100%;
    margin-bottom: 25px;
    line-height: 1;
    line-height: 1.7;
}

#about .link_box li .txt_box span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    padding: 15px 35px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
    min-width: 233px;
    box-sizing: border-box;
}

#about .link_box li:nth-child(2) {
    border-right: 2px solid #fff;
    background: #004B9E;
}

#about .link_box li:nth-child(2) .img_box {
    background-image: url(../img/common/frame01.png), url(../img/common/frame02.png), url(../img/common/frame03.png), url(../img/common/frame04.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 48px 48px;
    background-repeat: no-repeat;
}

#about .link_box li:first-child {
    width: 100%;
    height: 300px;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    position: relative;
}

#about .link_box li:first-child .img_box {
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-bottom: solid 2px #fff;
    position: relative;
}

#about .link_box li:first-child .img_box img {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    max-width: inherit;
}

#about .link_box li:first-child .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    height: 100%;
    width: 100%;
    position: absolute;
    left: 0;
    transform: translateY(-50%);
}

#about .link_box li:first-child .txt_box p {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    width: 310px;
    margin: 20px 0 0;
    line-height: 1.7;
}

#about .link_box li:first-child .txt_box span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    padding: 15px 35px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
    min-width: 233px;
    box-sizing: border-box;
    left: -25%;
    position: relative;
}

#about .link_box li:last-child {
    border-right: none;
}

/* 210913 経営理念土屋　ここから */
/* #about .link_box li:last-child .img_box {
  background-image: url(../img/common/frame_blue01.png), url(../img/common/frame_blue02.png), url(../img/common/frame_blue03.png), url(../img/common/frame_blue04.png);
  background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
  background-size: 48px 48px;
  background-repeat: no-repeat;
} */
#about .link_box li .img_box {
    background-image: url(../img/common/frame_blue01.png), url(../img/common/frame_blue02.png), url(../img/common/frame_blue03.png), url(../img/common/frame_blue04.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 48px 48px;
    background-repeat: no-repeat;
}

/* 210913 経営理念土屋　ここまで */

#about .link_box li:last-child .txt_box {}

#about .link_box li:last-child .txt_box span {
    color: #004B9E;
    background: #fff;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #about .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl@2x.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 75.43px 47.33px;
        width: 75.43px;
        height: 47.33px;
    }

    #about .link_box li:nth-child(2) .img_box {
        background-image: url(../img/common/frame01@2x.png), url(../img/common/frame02@2x.png), url(../img/common/frame03@2x.png), url(../img/common/frame04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 48px 48px;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここから */
    /* #about .link_box li:last-child .img_box {
    background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 48px 48px;
    background-repeat: no-repeat;
  } */
    #about .link_box li .img_box {
        background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 48px 48px;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここまで */
}

/* =========================================================
  #business
========================================================= */
#business {
    padding-bottom: 240px;
}

#business .sec_ttl span {
    display: block;
    position: relative;
    font-family: "Cinzel", serif;
    font-size: 16px;
    font-size: 1.6rem;
    letter-spacing: .25em;
    margin-bottom: 15px;
    line-height: 3;
    font-weight: 400;
}

#business .sec_ttl span:after {
    content: '';
    position: absolute;
    background: url(../img/top/bg_ttl.png) center center no-repeat;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
    background-size: 75.43px 47.33px;
    width: 75.43px;
    height: 47.33px;
}

#business .sec_ttl h2 {
    font-size: 35px;
    font-size: 3.5rem;
    font-weight: 700;
    line-height: 1.78;
}

#business .sec_ttl p {
    margin-top: 20px;
}

#business .content_box {
    display: flex;
    flex-wrap: wrap;
    margin-top: 60px;
}

#business .content_box li {
    width: 33.33%;
    height: 400px;
    background: #fff;
    border-bottom: 2px solid #fff;
    box-sizing: border-box;
}

#business .content_box li a {
    height: 100%;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
}

#business .content_box li a .img_box {
    height: 50%;
    width: 100%;
    overflow: hidden;
    position: relative;
}

#business .content_box li a .img_box img {
    width: 100%;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    max-width: inherit;
    position: relative;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
}

#business .content_box li a .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    height: 50%;
    width: 100%;
    background: #004B9E;
}

#business .content_box li a .txt_box p {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    width: 100%;
    margin-bottom: 25px;
    line-height: 1;
}

#business .content_box li a .txt_box span.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    width: 260px;
    height: 60px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
}

#business .content_box li a {
    position: relative;
}

#business .content_box li a .txt_box span.btn {
    background: #fff;
    color: #004B9E;
    border: none;
}


#business .content_box li.agency_tag a .txt_box {
    border-top: #176DE6 solid 10px;
}

#business .content_box li.retail_tag a .txt_box {
    border-top: #E9AF39 solid 10px;
}

#business .content_box li.abroad_tag a .txt_box {
    border-top: #39AFE9 solid 10px;
}

#business .content_box li.stationery_tag a .txt_box {
    border-top: #3CBE93 solid 10px;
}

#business .content_box li.contents_tag a .txt_box {
    border-top: #E987A8 solid 10px;
}

#business .content_box li.entertainment_tag a .txt_box {
    border-top: #DB5266 solid 10px;
}

#business .content_box li.newbusiness_tag a .txt_box {
    border-top: #26B4BE solid 10px;
}

#business .content_box li.shared_tag a .txt_box {
    border-top: #AE9C67 solid 10px;
}

#business .content_box li.it_tag a .txt_box {
    border-top: #937FD7 solid 10px;
}

#business .content_box li.hd_tag a .txt_box {
    border-top: #B2B2B2 solid 10px;
}

#business .content_box li.esg_tag a .txt_box {
    border-top: #BBF5B3 solid 10px;
}

#business .content_box li:first-child {
    width: 100%;
    height: 388px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    background: #004B9E;
}

#business .content_box li:first-child a {
    height: 100%;
}

#business .content_box li:first-child a:hover {
    opacity: .7;
}

#business .content_box li:first-child a .img_box {
    width: auto;
    height: 100%;
    overflow: hidden;
}

#business .content_box li:first-child .img_box img {
    height: 90%;
    width: auto;
    top: 50%;
    left: 2%;
    transform: translateY(-50%);
    min-width: unset;
    min-height: unset;
}

#business .content_box li:first-child a .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width: 50%;
    position: absolute;
    right: 0;
    height: 100%;
    top: 0;
    background: transparent;
}

#business .content_box li:first-child a .txt_box p {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    width: 252px;
    margin-bottom: 20px;
}

#business .content_box li:first-child a .txt_box span.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    width: 252px;
    height: 60px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
}

#business .content_box li:first-child a:hover .txt_box span.btn {
    opacity: .7;
}

#business .content_box li:nth-child(3n) {
    border-right: 2px solid #fff;
    border-left: 2px solid #fff;
}

#business .csr_box {
    display: flex;
    margin: 80px auto 20px;
    justify-content: space-between;
    align-self: center;
    width: 1100px;
}

#business .csr_box li {
    width: 520px;
    height: 190px;
    position: relative;
    overflow: hidden;
}

#business .csr_box li a {
    height: 100%;
    display: block;
}

#business .csr_box li a span {
    display: flex;
    align-items: center;
    justify-content: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    width: 233px;
    height: 60px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
    position: absolute;
}

#business .csr_box li a:hover span {
    opacity: .7;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #business .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl@2x.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 75.43px 47.33px;
        width: 75.43px;
        height: 47.33px;
    }
}

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

 company　ページ

-------------------------------- */
#page_company {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_company .sec_companyList {
    padding: 160px 0 230px;
}

#page_company .sec_companyList .sec_ttl {
    margin-bottom: 65px;
}

#page_company .sec_companyList .sec_ttl h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
}

#page_company .sec_companyList .sec_ttl h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_company .sec_companyList .sec_ttl h2 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_company .sec_companyList .main_box {
    display: flex;
    flex-wrap: wrap;
    margin-top: 85px;
}

/* 210913 経営理念土屋　ここから */
#page_company .sec_companyList .main_box li {
    /* width: 50%; */
    width: 100%;
    height: 300px;
    background: #fff;
    box-sizing: border-box;
    position: relative;
}

/* 210913 経営理念土屋　ここまで */

#page_company .sec_companyList .main_box li .img_box {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
}

#page_company .sec_companyList .main_box li .img_box img {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    max-width: inherit;
}

#page_company .sec_companyList .main_box li .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width: 100%;
    height: 300px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

#page_company .sec_companyList .main_box li .txt_box p {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    width: 100%;
    margin-bottom: 25px;
    line-height: 1;
    line-height: 1.7;
}

#page_company .sec_companyList .main_box li .txt_box span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    padding: 15px 35px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
    min-width: 233px;
    box-sizing: border-box;
}

#page_company .sec_companyList .main_box li:nth-child(2) {
    border-right: 2px solid #fff;
    border-left: none;
    background: #004B9E;
}

#page_company .sec_companyList .main_box li:nth-child(2) .img_box {
    background-image: url(../img/common/frame01.png), url(../img/common/frame02.png), url(../img/common/frame03.png), url(../img/common/frame04.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 48px 48px;
    background-repeat: no-repeat;
}

#page_company .sec_companyList .main_box li:first-child {
    width: 100%;
    height: 300px;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    position: relative;
}

#page_company .sec_companyList .main_box li:first-child .img_box {
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-bottom: solid 2px #fff;
    position: relative;
}

#page_company .sec_companyList .main_box li:first-child .img_box img {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    max-width: inherit;
}

#page_company .sec_companyList .main_box li:first-child .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    height: 100%;
    width: 100%;
    position: absolute;
    left: 0;
    transform: translateY(-50%);
}

#page_company .sec_companyList .main_box li:first-child .txt_box p {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    width: 310px;
    margin: 20px 0 0;
    line-height: 1.7;
}

#page_company .sec_companyList .main_box li:first-child .txt_box span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    padding: 15px 35px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
    min-width: 233px;
    box-sizing: border-box;
    position: relative;
    left: -25%;
}

#page_company .sec_companyList .main_box li:last-child {
    border-right: none;
    border-left: none;
    background: #f2f2f2;
}

/* 210913 経営理念土屋　ここから */
/* #page_company .sec_companyList .main_box li:last-child .img_box {
  background-image: url(../img/common/frame_blue01.png), url(../img/common/frame_blue02.png), url(../img/common/frame_blue03.png), url(../img/common/frame_blue04.png);
  background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
  background-size: 48px 48px;
  background-repeat: no-repeat;
} */

#page_company .sec_companyList .main_box li.img_box {
    background-image: url(../img/common/frame_blue01.png), url(../img/common/frame_blue02.png), url(../img/common/frame_blue03.png), url(../img/common/frame_blue04.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 48px 48px;
    background-repeat: no-repeat;
}

/* 210913 経営理念土屋　ここまで */

#page_company .sec_companyList .main_box li:last-child .txt_box {}

#page_company .sec_companyList .main_box li:last-child .txt_box span {
    color: #004B9E;
    background: #fff;
}

#page_company .sec_companyList .sub_box {
    display: flex;
    flex-wrap: wrap;
    border-top: 2px solid #fff;
}

#page_company .sec_companyList .sub_box li {
    width: 33.33%;
    height: 400px;
    background: #fff;
    border-bottom: 2px solid #fff;
    box-sizing: border-box;
}

#page_company .sec_companyList .sub_box li a {
    height: 100%;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
}

#page_company .sec_companyList .sub_box li a .img_box {
    height: 50%;
    width: 100%;
    overflow: hidden;
    position: relative;
}

#page_company .sec_companyList .sub_box li a .img_box img {
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    max-width: inherit;
    position: relative;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
}

#page_company .sec_companyList .sub_box li a .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    height: 50%;
    background: #004B9E;
    width: 100%;
}

#page_company .sec_companyList .sub_box li .txt_box p {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    width: 100%;
    margin-bottom: 25px;
    line-height: 1;
}

#page_company .sec_companyList .sub_box li a .txt_box span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    padding: 15px 35px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
    min-width: 233px;
    box-sizing: border-box;
}

@media only screen and (max-width: 1180px) {
    #page_company .sec_companyList .sub_box li a .txt_box span {
        font-size: 19px;
        font-size: 1.9rem;
    }
}

#page_company .sec_companyList .sub_box li:nth-child(3n-1) {
    border-right: 2px solid #fff;
    border-left: 2px solid #fff;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_company .sec_companyList .main_box li:nth-child(2) {
        background: #004B9E;
        border-right: 2px solid #fff;
    }

    #page_company .sec_companyList .main_box li:nth-child(2) .img_box {
        background-image: url(../img/common/frame01@2x.png), url(../img/common/frame02@2x.png), url(../img/common/frame03@2x.png), url(../img/common/frame04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 48px 48px;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここから */
    /* #page_company .sec_companyList .main_box li:last-child {
    border-right: none;
    background: #f2f2f2;
  } */
    #page_company .sec_companyList .main_box li {
        border-right: none;
        background: #f2f2f2;
    }

    /* #page_company .sec_companyList .main_box li:last-child .img_box {
    background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 48px 48px;
    background-repeat: no-repeat;
  } */

    #page_company .sec_companyList .main_box li .img_box {
        background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 48px 48px;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここまで */
}

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

 message　ページ

-------------------------------- */
#page_message {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_message .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/message/mv.png) top center no-repeat;
    background-size: cover;
}

#page_message .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_message .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_message .hero:after {
    content: '';
    display: none;
}

#page_message .sec_message {
    padding: 90px 0 80px;
}

#page_message .sec_message + .sec_message  {
    padding-top: 0;
    padding-bottom: 150px;
}

#page_message .sec_message .sec_ttl {
    margin-bottom: 80px;
}

#page_message .sec_message .sec_ttl h3 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin: 0 0 15px 25px;
    line-height: 1.78;
}

#page_message .sec_message .sec_ttl span {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    margin-top: 20px;
}

#page_message .sec_message .sec_ttl span.sub_ttl {  
     font-size: 30px;
     font-size: 3rem;
    margin-top: 0;
    line-height: 1;
    display: block;
}

#page_message .sec_message .inner {
    margin-bottom: 40px;
    line-height: 2;
    width: 800px;
}

#page_message .sec_message .inner h4 {
    width: 100%;
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 35px;
    text-align: justify;
}

#page_message .sec_message .inner .txt_box {
    margin-top: 55px;
}

#page_message .sec_message .inner .txt_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_message .sec_message .inner .txt_box p + p {
    margin-top: 2em;
}

#page_message .sec_message .inner .txt_box p span {
    font-weight: 700;
}

@media all and (-ms-high-contrast: none) {
    #page_message .sec_message .inner .txt_box {
        flex: 1%;
    }
}

#page_message .sec_message .inner img {
    width: 100%;
    height: auto;
}

#page_message .sec_message .inner .signature_box {
    text-align: right;
    margin-left: auto;
}


@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_message .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/message/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 group_list ページ

-------------------------------- */
#page_group_list {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_group_list .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/group_list/mv.png) top center no-repeat;
    background-size: cover;
}

#page_group_list .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_group_list .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_group_list .hero:after {
    content: '';
    display: none;
}

#page_group_list .sec_group_list {
    padding: 130px 0 175px;
}

#page_group_list .sec_group_list .tag_wrap {
    display: flex;
    margin: 0 auto 1px;
    justify-content: space-between;
    width: 1100px;
}

#page_group_list .sec_group_list .tag_wrap a {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    color: #004B9E;
    padding: 9px 25px;
    min-width: 90px;
    box-sizing: border-box;
    border: 1px solid #004B9E;
    border-radius: 30px;
}

#page_group_list .sec_group_list .tag_wrap a.agency_tag {
    background: #176DE6;
    color: #fff;
    border: 1px solid #176DE6;
}

#page_group_list .sec_group_list .tag_wrap a.retail_tag {
    background: #E9AF39;
    color: #fff;
    border: 1px solid #E9AF39;
}

#page_group_list .sec_group_list .tag_wrap a.abroad_tag {
    background: #39AFE9;
    color: #fff;
    border: 1px solid #39AFE9;
}

#page_group_list .sec_group_list .tag_wrap a.stationery_tag {
    background: #3CBE93;
    color: #fff;
    border: 1px solid #3CBE93;
}

#page_group_list .sec_group_list .tag_wrap a.contents_tag {
    background: #E987A8;
    color: #fff;
    border: 1px solid #E987A8;
}

#page_group_list .sec_group_list .tag_wrap a.entertainment_tag {
    background: #DB5266;
    color: #fff;
    border: 1px solid #DB5266;
}

#page_group_list .sec_group_list .tag_wrap a.newbusiness_tag {
    background: #26B4BE;
    color: #fff;
    border: 1px solid #26B4BE;
}

#page_group_list .sec_group_list .tag_wrap a.shared_tag {
    background: #AE9C67;
    color: #fff;
    border: 1px solid #AE9C67;
}

#page_group_list .sec_group_list .tag_wrap a.it_tag {
    background: #937FD7;
    color: #fff;
    border: 1px solid #937FD7;
}

#page_group_list .sec_group_list .inner {
    padding-top: 80px;
}

#page_group_list .sec_group_list .inner h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_group_list .sec_group_list .inner h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_group_list .sec_group_list .inner h3.agency_bar:after {
    background: #176DE6;
}

#page_group_list .sec_group_list .inner h3.retail_bar:after {
    background: #E9AF39;
}

#page_group_list .sec_group_list .inner h3.abroad_bar:after {
    background: #39AFE9;
}

#page_group_list .sec_group_list .inner h3.stationery_bar:after {
    background: #3CBE93;
}

#page_group_list .sec_group_list .inner h3.contents_bar:after {
    background: #E987A8;
}

#page_group_list .sec_group_list .inner h3.entertainment_bar:after {
    background: #DB5266;
}

#page_group_list .sec_group_list .inner h3.newbusiness_bar:after {
    background: #26B4BE;
}

#page_group_list .sec_group_list .inner h3.shared_bar:after {
    background: #AE9C67;
}

#page_group_list .sec_group_list .inner h3.it_bar:after {
    background: #937FD7;
}

#page_group_list .sec_group_list .inner ul {
    text-align: justify;
}

#page_group_list .sec_group_list .inner ul li {
    padding: 55px 0;
    border-bottom: 1px solid #ddd;
}

#page_group_list .sec_group_list .inner ul li h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin-bottom: 30px;
    line-height: 1.78;
}

#page_group_list .sec_group_list .inner ul li h4 span.note {
    display: block;
     font-size: 14px;
    font-weight: normal;
}

#page_group_list .sec_group_list .inner ul li dl {
    display: flex;
    justify-content: flex-start;
    line-height: 2;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_group_list .sec_group_list .inner ul li dl dt {
    width: 125px;
    font-weight: 700;
    margin-bottom: 2px;
}

#page_group_list .sec_group_list .inner ul li dl dd {
    margin-bottom: 2px;
    flex: 1;
}

#page_group_list .sec_group_list .inner ul li dl dd p {
    font-size: 16px;
    font-size: 1.6rem;
    text-indent: -1em;
    padding-left: 1em;
    line-height: 2.1;
    margin-top: 0;
}

#page_group_list .sec_group_list .inner ul li dl dd span {
    display: block;
}

#page_group_list .sec_group_list .inner ul li dl dd a {
    font-size: 16px;
    font-size: 1.6rem;
    color: #004B9E;
    text-decoration: underline;
}

#page_group_list .sec_group_list .inner ul li dl dd a:hover {
    color: rgba(0, 75, 158, 0.7);
    text-decoration: none;
    opacity: 1;
}

@media all and (-ms-high-contrast: none) {
    #page_group_list .sec_group_list .inner ul li dl dd {
        flex: 1%;
    }
}

#page_group_list .sec_group_list .inner ul li ul {
    margin-left: 125px;
}

#page_group_list .sec_group_list .inner ul li ul li {
    border-bottom: none;
}

#page_group_list .sec_group_list .inner ul li ul li h5 {
    font-size: 26px;
    font-size: 2.6rem;
    margin-bottom: 30px;
    line-height: 1.78;
}

#page_group_list .sec_group_list .inner ul li ul li h5:before {
    content: '';
    display: inline-block;
    width: 27px;
    height: 5px;
    margin-right: 25px;
    vertical-align: middle;
}

#page_group_list .sec_group_list .inner ul li ul li h5.agency_bar:before {
    background: #176DE6;
}

#page_group_list .sec_group_list .inner ul li ul li h5.retail_bar:before {
    background: #E9AF39;
}

#page_group_list .sec_group_list .inner ul li ul li h5.abroad_bar:before {
    background: #39AFE9;
}

#page_group_list .sec_group_list .inner ul li ul li h5.stationery_bar:before {
    background: #3CBE93;
}

#page_group_list .sec_group_list .inner ul li ul li h5.contents_bar:before {
    background: #E987A8;
}

#page_group_list .sec_group_list .inner ul li ul li h5.entertainment_bar:before {
    background: #DB5266;
}

#page_group_list .sec_group_list .inner ul li ul li h5.newbusiness_bar:before {
    background: #26B4BE;
}

#page_group_list .sec_group_list .inner ul li ul li h5.shared_bar:before {
    background: #AE9C67;
}

#page_group_list .sec_group_list .inner ul li ul li h5.it_bar:before {
    background: #937FD7;
}

#page_group_list .sec_group_list .inner ul li ul li dl {
    display: flex;
    justify-content: flex-start;
    line-height: 2;
    font-size: 16px;
    font-size: 1.6rem;
    margin-left: 53px;
}

#page_group_list .sec_group_list .inner ul li ul li dl dt {
    width: 125px;
    font-weight: 700;
    margin-bottom: 2px;
}

#page_group_list .sec_group_list .inner ul li ul li dl dd {
    margin-bottom: 2px;
    flex: 1;
}

#page_group_list .sec_group_list .inner ul li ul li dl dd p {
    font-size: 16px;
    font-size: 1.6rem;
    text-indent: -1em;
    padding-left: 1em;
    line-height: 2.1;
    margin-top: 0;
}

#page_group_list .sec_group_list .inner ul li ul li dl dd span {
    display: block;
}

#page_group_list .sec_group_list .inner ul li ul li dl dd a {
    font-size: 16px;
    font-size: 1.6rem;
    color: #004B9E;
    text-decoration: underline;
}

#page_group_list .sec_group_list .inner ul li ul li dl dd a:hover {
    color: rgba(0, 75, 158, 0.7);
    text-decoration: none;
    opacity: 1;
}

@media all and (-ms-high-contrast: none) {
    #page_group_list .sec_group_list .inner ul li ul li dd {
        flex: 1%;
    }
}

#page_group_list .sec_group_list .inner:last-child ul li:last-child {
    border-bottom: none;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_group_list .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/group_list/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

corporate ページ

-------------------------------- */
#page_corporate {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_corporate .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/corporate/mv.png) top center no-repeat;
    background-size: cover;
}

#page_corporate .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_corporate .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_corporate .hero:after {
    content: '';
    display: none;
}

#page_corporate .sec_corporate {
    padding: 130px 0 210px;
}

#page_corporate .sec_corporate .inner {
    text-align: justify;
}

#page_corporate .sec_corporate .inner dl {
    display: flex;
    justify-content: flex-start;
    line-height: 2;
    font-size: 16px;
    font-size: 1.6rem;
    width: 725px;
    margin: auto;
}

#page_corporate .sec_corporate .inner dl dt {
    width: 125px;
    font-weight: 700;
    margin-bottom: 20px;
}

#page_corporate .sec_corporate .inner dl dd {
    margin-bottom: 20px;
    flex: 1;
    letter-spacing: .03em;
}

#page_corporate .sec_corporate .inner dl dd p {
    font-size: 14px;
    font-size: 1.4rem;
    text-indent: -1em;
    padding-left: 1em;
    line-height: 2.1;
    margin: 0 0 10px;
}

#page_corporate .sec_corporate .inner dl dd span {
    font-size: 14px;
    font-size: 1.4rem;
}

#page_corporate .sec_corporate .inner dl dd a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 50px;
    width: 110px;
    border-radius: 25px;
    background: #004B9E;
    color: #fff;
    margin: 15px 0 20px;
}

@media all and (-ms-high-contrast: none) {
    #page_corporate .sec_corporate .inner dl dd {
        flex: 1%;
    }
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_corporate .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/corporate/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 philosophy　ページ

-------------------------------- */
#page_philosophy {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_philosophy .hero {
    position: relative;
    padding: 0;
    height: 300px;
    width: 100%;
    background-color: #004B9E;
    background-image: url(../img/common/frame01@2x.png), url(../img/common/frame02@2x.png), url(../img/common/frame03@2x.png), url(../img/common/frame04@2x.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 50px 50px;
    background-repeat: no-repeat;
}

#page_philosophy .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_philosophy .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_philosophy .hero:after {
    content: '';
    display: none;
}

#page_philosophy .sec_philosophy {
    padding: 160px 0 0;
}

#page_philosophy .sec_philosophy .sec_ttl {
    margin-bottom: 90px;
}

#page_philosophy .sec_philosophy .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    text-align: center;
}

#page_philosophy .sec_philosophy .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
}

#page_philosophy .sec_philosophy .inner {
    width: 1100px;
    text-align: center;
}

#page_philosophy .sec_philosophy .inner img {
    width: 650px;
    height: auto;
    margin: 0 auto;
}

#page_philosophy .sec_background {
    padding: 200px 0 0;
}

#page_philosophy .sec_background .sec_ttl {
    margin-bottom: 90px;
}

#page_philosophy .sec_background .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_philosophy .sec_background .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
}

#page_philosophy .sec_background .inner {
    width: 1100px;
}

#page_philosophy .sec_background .inner p {
    text-align: center;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    margin-bottom: 60px;
    line-height: 1.78;
}

#page_philosophy .sec_background .inner img {
    width: 100%;
    height: auto;
    margin-bottom: 230px;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_philosophy .hero {
        position: relative;
        padding: 0;
        height: 300px;
        width: 100%;
        background-color: #004B9E;
        background-image: url(../img/common/frame01@2x.png), url(../img/common/frame02@2x.png), url(../img/common/frame03@2x.png), url(../img/common/frame04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 50px 50px;
        background-repeat: no-repeat;
    }
}

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

 business_plan　ページ

-------------------------------- */
#page_business_plan {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_business_plan .hero {
    position: relative;
    padding: 0;
    height: 300px;
    width: 100%;
    background-color: #f2f2f2;
    background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 50px 50px;
    background-repeat: no-repeat;
}

#page_business_plan .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_business_plan .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #004B9E;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #fff;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_business_plan .hero:after {
    content: '';
    display: none;
}

#page_business_plan .sec_business_plan {
    padding: 120px 0 25px;
}

#page_business_plan .sec_business_plan .inner {
    width: 1100px;
}

#page_business_plan .sec_business_plan .inner p {
    text-align: center;
    font-size: 18px;
    font-size: 1.8rem;
    margin-bottom: 0;
}

#page_business_plan .sec_business_plan .inner img {
    width: 480px;
    height: auto;
    margin-bottom: 20px;
}

#page_business_plan .sec_business_plan .inner span {
    display: block;
    margin-bottom: 50px;
    font-size: 18px;
    font-size: 1.8rem;
}

#page_business_plan .sec_concept {
    padding: 175px 0 25px;
}

#page_business_plan .sec_concept .sec_ttl {
    margin-bottom: 65px;
}

#page_business_plan .sec_concept .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_business_plan .sec_concept .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_business_plan .sec_concept .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_business_plan .sec_concept .inner {
    display: block;
}

#page_business_plan .sec_concept .inner h4 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 25px;
    line-height: 2;
}

#page_business_plan .sec_concept .inner p {
    text-align: center;
    font-size: 18px;
    font-size: 1.8rem;
}

#page_business_plan .sec_basicPolicy {
    padding: 175px 0 230px;
}

#page_business_plan .sec_basicPolicy .sec_ttl {
    margin-bottom: 65px;
}

#page_business_plan .sec_basicPolicy .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_business_plan .sec_basicPolicy .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_business_plan .sec_basicPolicy .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_business_plan .sec_basicPolicy .inner {
    display: block;
}

#page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap {
    display: flex;
    justify-content: space-between;
    width: 860px;
    margin: auto;
}

#page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box {
    text-align: justify;
    width: 430px;
}

#page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 15px;
    line-height: 1.78;
    color: #004B9E;
}

#page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box ul {
    text-align: justify;
}

#page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box ul li {
    font-size: 20px;
    font-size: 2rem;
    text-indent: .5em;
    line-height: 1.6;
}

#page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box ul li:before {
    content: '';
    display: inline-block;
    width: 15px;
    height: 15px;
    background: #004B9E;
    margin-right: 10px;
}

#page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box:last-child h4 {
    text-align: right;
}

#page_business_plan .sec_basicPolicy .inner img {
    width: 650px;
    height: auto;
    margin-top: 180px;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_business_plan .hero {
        position: relative;
        padding: 0;
        height: 300px;
        width: 100%;
        background-color: #f2f2f2;
        background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 50px 50px;
        background-repeat: no-repeat;
    }
}

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

 management ページ

-------------------------------- */
#page_management {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_management .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/management/mv.png) top center no-repeat;
    background-size: cover;
}

#page_management .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_management .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_management .hero:after {
    content: '';
    display: none;
}

#page_management .date_wrap {
    width: 1100px;
    margin: auto;
    padding: 50px 0 0;
}

#page_management .date_wrap p {
    font-size: 16px;
    font-size: 1.6rem;
    text-align: right;
}

#page_management .sec_officer {
    padding: 80px 0 0;
}

#page_management .sec_officer .sec_ttl {
    margin-bottom: 65px;
}

#page_management .sec_officer .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_management .sec_officer .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_management .sec_officer .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_management .sec_officer .inner {
    padding: 10px 0 75px;
    border-bottom: 1px solid #ddd;
}

#page_management .sec_officer .inner dl {
    display: flex;
    justify-content: flex-start;
    line-height: 2;
    font-size: 16px;
    font-size: 1.6rem;
    text-align: justify;
}

#page_management .sec_officer .inner dl dt {
    width: 180px;
    font-weight: 700;
    margin-bottom: 5px;
}

#page_management .sec_officer .inner dl dd {
    margin-bottom: 5px;
    flex: 1;
    display: flex;
}

#page_management .sec_officer .inner dl dd span {
    width: 795px;
    margin-left: auto;
}

#page_management .sec_officer .inner dl dd span.is_ls {
    width: fit-content;
    margin: 0;
}

#page_management .sec_officer .inner dl dd span.is_ls > span {
    width: fit-content;
    margin: 0;
    margin-left: 1em;
}

@media all and (-ms-high-contrast: none) {
    #page_management .sec_officer .inner dl dd {
        flex: 1%;
    }
}

#page_management .sec_officer:last-of-type {
    margin-bottom: 145px;
}

#page_management .sec_officer:last-of-type .inner {
    border-bottom: none;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_management .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/management/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 history ページ

-------------------------------- */
#page_history {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_history .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/history/mv.png) top center no-repeat;
    background-size: cover;
}

#page_history .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_history .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_history .hero:after {
    content: '';
    display: none;
}

#page_history .sec_history {
    padding: 160px 0 230px;
}

#page_history .sec_history .sticky_nav {
    display: none;
}

#page_history .sec_history .sticky_nav.js_on {
    position: fixed;
    bottom: 50%;
    transform: translateY(50%);
    /* bottom: 100px; */
    right: 45px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    z-index: 90;
    /* margin-top: -40px; */
    padding-top: 28%;

    /* position: fixed;
    top: 50%;
    right: 45px;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    z-index: 90; */
}

#page_history .sec_history .sticky_nav.js_on li {
    margin: 15px 0;
    position: relative;
    width: 100%;
    text-align: right;
}

#page_history .sec_history .sticky_nav.js_on li span {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
    font-weight: 700;
    opacity: 1;
    line-height: 1;
}

#page_history .sec_history .sticky_nav.js_on li a span {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
    font-weight: 700;
    opacity: 1;
    line-height: 1;
}

#page_history .sec_history .sticky_nav.js_on li a:after {
    content: '';
    position: absolute;
    display: inline-block;
    width: 15px;
    height: 15px;
    background: #DDD;
    border-radius: 100%;
    top: 50%;
    right: -25px;
    transform: translateY(-50%);
}

#page_history .sec_history .sticky_nav.js_on li.js_on a:after {
    content: '';
    background: #004B9E;
}

#page_history .sec_history .sticky_nav_sp {
    display: none;
}

#page_history .sec_history .sticky_nav_sp.js_on {
    display: none;
}

#page_history .sec_history .sec_ttl {
    margin-bottom: 65px;
}

#page_history .sec_history .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_history .sec_history .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_history .sec_history .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_history .sec_history .inner ul {
    text-align: justify;
}

#page_history .sec_history .inner ul li dl {
    display: flex;
    justify-content: flex-start;
    line-height: 2;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_history .sec_history .inner ul li dl dt {
    width: 300px;
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    color: #004B9E;
    font-weight: 700;
    margin-bottom: 5px;
    line-height: 1;
    text-align: justify;
}

#page_history .sec_history .inner ul li dl dt span {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 40px;
    font-size: 4rem;
}

#page_history .sec_history .inner ul li dl dt span.cs08 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    letter-spacing: -.08em;
}

#page_history .sec_history .inner ul li dl dt span.cs07 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    letter-spacing: -.07em;
}

#page_history .sec_history .inner ul li dl dt span.cs05 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    letter-spacing: -.05em;
}

#page_history .sec_history .inner ul li dl dt span.cs04 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    letter-spacing: -.04em;
}

#page_history .sec_history .inner ul li dl dt span.cs03 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    letter-spacing: -.03em;
}

#page_history .sec_history .inner ul li dl dt span.cs02 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    letter-spacing: -.02em;
}

#page_history .sec_history .inner ul li dl dt span.cs01 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    letter-spacing: -.01em;
}

#page_history .sec_history .inner ul li dl dt span.cs00 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 110px;
    font-size: 11rem;
    letter-spacing: 0em;
}

#page_history .sec_history .inner ul li dl dd {
    width: 660px;
    display: flex;
    padding: 52px 0 130px;
    border-left: 1px solid #ddd;
}

#page_history .sec_history .inner ul li dl dd.multiple {
    padding-bottom: 50px;
}

#page_history .sec_history .inner ul li dl dd .month {
    width: 160px;
    margin-top: -10px;
    position: relative;
    font-family: "Roboto Condensed", sans-serif;
    font-size: 40px;
    font-size: 4rem;
    color: #004B9E;
    font-weight: 700;
    line-height: .8;
    padding-left: 30px;
}

#page_history .sec_history .inner ul li dl dd .month span {
    font-size: 22px;
    font-size: 2.2rem;
    margin-left: 0;
}

#page_history .sec_history .inner ul li dl dd .month span.cs08 {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 40px;
    font-size: 4rem;
    letter-spacing: -.08em;
}

#page_history .sec_history .inner ul li dl dd .month:after {
    content: '';
    position: absolute;
    top: 5px;
    left: -9px;
    display: block;
    width: 18px;
    height: 18px;
    border-radius: 100%;
    background: #004B9E;
}

#page_history .sec_history .inner ul li dl dd .nomonth {
    width: 160px;
    padding-left: 40px;
    margin-top: -10px;
    position: relative;
}

#page_history .sec_history .inner ul li dl dd .nomonth:after {
    content: '';
    display: none;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap {
    width: 640px;
    margin-top: -9px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: -0.4em 0 20px;
    line-height: 1.78;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap p {
    font-size: 16px;
    font-size: 1.6rem;
    margin-bottom: 20px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap img {
    margin-bottom: 20px;
    width: 100%;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_199111 {
    width: 267px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_200606 {
    width: 130px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_200701 {
    width: 165px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_201706_01 {
    width: 320px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_201910 {
    width: 360px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_202004_01 {
    width: 280px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_202004_02 {
    width: 192px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap .img_box {
    position: relative;
    margin-bottom: 130px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap .img_box img {
    width: 360px;
}

#page_history .sec_history .inner ul li dl dd .contents_wrap .img_box img:last-child {
    position: absolute;
    top: 176px;
    left: 163px;
}

#page_history .sec_history .inner ul li dl dd span {
    margin-left: 45px;
}

@media all and (-ms-high-contrast: none) {
    #page_history .sec_history .inner ul li dl .dd {
        flex: 1%;
    }

    #page_history .sec_history .inner ul li dl .contents_wrap h4 {
        padding-top: .3em;
    }
}

#page_history .sec_history .inner ul li:first-child dl dd {
    margin-top: 52px;
    padding-top: 0;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_history .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/history/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 governance　ページ

-------------------------------- */
#page_governance {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_governance .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/governance/mv.png) top center no-repeat;
    background-size: cover;
}

#page_governance .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_governance .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_governance .hero:after {
    content: '';
    display: none;
}

#page_governance .sec_governance {
    padding: 160px 0 10px;
}

#page_governance .sec_governance .sec_ttl {
    margin-bottom: 75px;
}

#page_governance .sec_governance .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_governance .sec_governance .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_governance .sec_governance .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_governance .sec_governance .inner {
    display: block;
    margin-bottom: 70px;
}

#page_governance .sec_governance .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 15px;
    line-height: 1.78;
    text-align: justify;
}

#page_governance .sec_governance .inner p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_governance .sec_governance .inner:last-child {
    margin-bottom: 220px;
}

#page_governance .sec_governance .systemDiagram_wrap {
    background: rgba(198, 237, 255, 0.31);
    padding: 80px 0;
    margin-bottom: 70px;
}

#page_governance .sec_governance .systemDiagram_wrap .inner {
    margin-bottom: 0;
}

#page_governance .sec_governance .systemDiagram_wrap .inner h5 {
    font-size: 20px;
    font-size: 2rem;
    margin-bottom: 50px;
    line-height: 1.78;
}

#page_governance .sec_governance .systemDiagram_wrap .inner picture img {
    width: 100%;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_governance .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/governance/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

business ページ

-------------------------------- */
#page_business {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_business .hero {
    position: relative;
    padding: 0;
    height: 550px;
    background: url(../img/business/mv.png) top center no-repeat;
    background-size: cover;
}

#page_business .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_business .hero .hero_ttl h2 {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    color: #fff;
    font-size: 35px;
    font-size: 3.5rem;
    font-weight: 700;
    width: 500px;
    height: 130px;
    background: #fff;
    color: #000;
    border-bottom: #004B9E 10px solid;
}

#page_business .hero:after {
    content: '';
    display: none;
}

#page_business .sec_business {
    padding: 90px 0 0;
}

#page_business .sec_business .sec_ttl {
    margin-bottom: 80px;
}

#page_business .sec_business .sec_ttl h3 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 15px;
    line-height: 2;
    color: #000;
}

#page_business .sec_business .inner {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 150px;
}

#page_business .sec_business .inner h4 {
    width: 100%;
    font-size: 26px;
    font-size: 2.6rem;
    margin-bottom: 35px;
    text-align: justify;
}

#page_business .sec_business .inner p {
    font-size: 16px;
    font-size: 1.6rem;
    width: 100%;
    margin-top: 70px;
}

#page_business .sec_business .inner.region_box picture {}

#page_business .sec_business .inner.region_box picture img {
    /* width: 670px; */
    height: 80vh;
    max-height: 675px;
}

#page_business .sec_business .inner.foundingDate picture {
    margin: auto;
}

#page_business .sec_business .inner.group_box picture:last-child {
    margin-left: 45px;
}

#page_business .sec_business .inner.amount_box {
    margin-bottom: 0;
}

#page_business .sec_business .inner.amount_box picture {
    margin-bottom: 150px;
}

#page_business .sec_businessList {
    padding: 0 0 230px;
}

#page_business .sec_businessList .content_box {
    display: flex;
    flex-wrap: wrap;
}

#page_business .sec_businessList .content_box li {
    width: 33.33%;
    height: 400px;
    background: #fff;
    border-bottom: 2px solid #fff;
    box-sizing: border-box;
}

#page_business .sec_businessList .content_box li a {
    height: 100%;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
}

#page_business .sec_businessList .content_box li a .img_box {
    height: 50%;
    width: 100%;
    overflow: hidden;
    position: relative;
}

#page_business .sec_businessList .content_box li a .img_box img {
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    max-width: inherit;
    position: relative;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
}

#page_business .sec_businessList .content_box li a .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    height: 50%;
    width: 100%;
    background: #004B9E;
}
#page_business .content_box li a .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    height: 50%;
    width: 100%;
    background: #004B9E;
}

#page_business .sec_businessList .content_box li a .txt_box p {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    width: 100%;
    margin-bottom: 25px;
    line-height: 1;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #004B9E;
    width: 260px;
    height: 60px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
}

#page_business .content_box li.agency_tag a .txt_box {
    border-top: #176DE6 solid 10px;
}

#page_business .content_box li.retail_tag a .txt_box {
    border-top: #E9AF39 solid 10px;
}

#page_business .content_box li.abroad_tag a .txt_box {
    border-top: #39AFE9 solid 10px;
}

#page_business .content_box li.stationery_tag a .txt_box {
    border-top: #3CBE93 solid 10px;
}

#page_business .content_box li.contents_tag a .txt_box {
    border-top: #E987A8 solid 10px;
}

#page_business .content_box li.entertainment_tag a .txt_box {
    border-top: #DB5266 solid 10px;
}

#page_business .content_box li.newbusiness_tag a .txt_box {
    border-top: #26B4BE solid 10px;
}

#page_business .content_box li.shared_tag a .txt_box {
    border-top: #AE9C67 solid 10px;
}

#page_business .content_box li.it_tag a .txt_box {
    border-top: #937FD7 solid 10px;
}

#page_business .content_box li.hd_tag a .txt_box {
    border-top: #B2B2B2 solid 10px;
}

#page_business .content_box li.esg_tag a .txt_box {
    border-top: #BBF5B3 solid 10px;
}

/* #page_business .sec_businessList .content_box li a .txt_box span.btn.agency_tag {
    background: #176DE6;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.retail_tag {
    background: #E9AF39;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.abroad_tag {
    background: #39AFE9;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.stationery_tag {
    background: #3CBE93;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.contents_tag {
    background: #E987A8;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.entertainment_tag {
    background: #DB5266;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.newbusiness_tag {
    background: #26B4BE;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.shared_tag {
    background: #AE9C67;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.it_tag {
    background: #937FD7;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.hd_tag {
    background: #B2B2B2;
    color: #fff;
    border: none;
}

#page_business .sec_businessList .content_box li a .txt_box span.btn.esg_tag {
    background: #BBF5B3;
    color: #007E67;
    border: none;
} */

#page_business .sec_businessList .content_box li:nth-child(3n-1) {
    border-right: 2px solid #fff;
    border-left: 2px solid #fff;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_business .hero {
        position: relative;
        padding: 0;
        height: 550px;
        background: url(../img/business/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

business下位ページ 共通

-------------------------------- */
.under_business {
    padding: 100px 0 0;
    margin-top: 0;
}

.under_business .hero {
    position: relative;
    padding: 0;
    height: 550px;
}

.under_business .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

.under_business .hero .hero_ttl h2 {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    color: #fff;
    font-size: 35px;
    font-size: 3.5rem;
    font-weight: 700;
    width: 500px;
    height: 130px;
}

.under_business .hero .hero_ttl h2 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
}

.under_business .hero:after {
    content: '';
    display: none;
}

.under_business section {
    padding: 175px 0 25px;
}

.under_business section .sec_ttl {
    margin-bottom: 65px;
}

.under_business section .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

.under_business section .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

.under_business section .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

.under_business section .inner h4 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 35px;
    line-height: 1.78;
}

.under_business section .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
}

.under_business section .inner p.lead {
    font-size: 18px;
    font-size: 1.8rem;
}

.under_business section .inner .inner_box {
    margin: 70px auto 0;
}

.under_business section .inner .inner_box h5 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 120px auto 20px;
    line-height: 1.78;
}

.under_business section .inner .inner_box img {
    margin: 30px auto 70px;
}

.under_business section .inner .inner_box p {
    text-align: justify;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

.under_business section .inner .inner_box p.ta_center {
    text-align: center;
}

.under_business section .inner .inner_box .img_wrap {
    display: flex;
    justify-content: space-between;
    align-items: top;
    flex-wrap: wrap;
    margin-top: 40px;
}

.under_business section .inner .inner_box .img_wrap .img_box_2div {
    width: 500px;
    text-align: center;
}

.under_business section .inner .inner_box .img_wrap .img_box_2div h6 {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    text-align: justify;
    margin-bottom: 5px;
}

.under_business section .inner .inner_box .img_wrap .img_box_2div img {
    margin: 0 auto 13px;
}

.under_business section .inner .inner_box .img_wrap .img_box_2div p {
    text-align: justify;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

.under_business section .inner .inner_box .img_wrap .img_box_2div p+p {
    margin-top: 20px;
}

.under_business section .inner .inner_box .img_wrap .img_box_2div a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 20px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
}

.under_business section .inner .inner_box .img_wrap .img_box_2div a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

.under_business section .inner .inner_box .img_wrap .img_box_3div {
    width: 330px;
}

.under_business section .inner .inner_box .img_wrap .img_box_3div img {
    margin: 0 auto 13px;
    background: #fff;
}

.under_business section .inner .inner_box .img_wrap .img_box_3div p {
    font-size: 16px;
    font-size: 1.6rem;
    text-align: justify;
    letter-spacing: 0;
}

.under_business section .inner .img_wrap {
    display: flex;
    justify-content: space-between;
    align-items: top;
    flex-wrap: wrap;
    margin-top: 60px;
}

.under_business section .inner .img_wrap h5 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 120px auto 20px;
    width: 100%;
}

.under_business section .inner .img_wrap .img_box_2div {
    width: 500px;
}

.under_business section .inner .img_wrap .img_box_2div h6 {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    text-align: justify;
    margin-bottom: 5px;
}

.under_business section .inner .img_wrap .img_box_2div img {
    margin: 0 auto 13px;
    background: #fff;
}

.under_business section .inner .img_wrap .img_box_2div p {
    text-align: justify;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

.under_business section .inner .img_wrap .img_box_2div p+p {
    margin-top: 20px;
}

.under_business section .inner .img_wrap .img_box_3div {
    width: 330px;
}

.under_business section .inner .img_wrap .img_box_3div h5 {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    text-align: justify;
    margin-bottom: 5px;
}

.under_business section .inner .img_wrap .img_box_3div img {
    margin: 0 auto 13px;
    background: #fff;
}

.under_business section .inner .img_wrap .img_box_3div p {
    font-size: 16px;
    font-size: 1.6rem;
    text-align: justify;
    letter-spacing: 0;
}

.under_business section .inner .img_wrap .img_box_3div a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border: 2px solid #004B9E;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #004B9E;
    line-height: 1;
    margin-top: 20px;
    box-sizing: border-box;
}

.under_business section .inner .img_wrap .img_box_3div a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

.under_business .sec_businessArea {
    padding: 160px 0 25px;
}

.under_business .sec_businessArea .sec_ttl {
    margin-bottom: 90px;
}

.under_business .sec_businessArea .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

.under_business .sec_businessArea .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
}

.under_business .sec_businessArea .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
    margin-top: 3px;
}

.under_business .sec_businessArea .inner {
    width: 1100px;
}

.under_business .sec_businessArea .inner a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    box-sizing: border-box;
    padding: 12px 23px;
    border: none;
    border-radius: 5px;
    text-align: center;
}

.under_business .sec_businessArea .inner a+a {
    margin-left: 7px;
}

.under_business .sec_ttlArea {
    padding: 120px 0 0;
}

.under_business .sec_ttlArea h3 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 35px;
    line-height: 1.78;
}

.under_business .sec_ttlArea p {
    text-align: center;
    font-size: 18px;
    font-size: 1.8rem;
}

.under_business .sec_relation {
    padding-bottom: 170px;
}

.under_business .sec_relation .sec_ttl h3:after {
    background: #004B9E;
}

.under_business .sec_relation .inner {
    display: block;
}

.under_business .sec_relation .inner ul {
    margin-top: 25px;
}

.under_business .sec_relation .inner ul li {
    text-align: justify;
    margin: 0 30px 60px 30px;
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
}

.under_business .sec_relation .inner ul li a {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    position: relative;
    padding: 0 0 2px 2em;
}

.under_business .sec_relation .inner ul li a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    transform: translateY(-50%);
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    .under_business section .inner .inner_box .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }

    .under_business section .inner .img_wrap .img_box_3div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }

    .under_business .sec_relation .inner ul li a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        transform: translateY(-50%);
    }
}

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

 agency ページ

-------------------------------- */
#page_agency .hero {
    background: url(../img/agency/mv.png) top center no-repeat;
    background-size: cover;
}

#page_agency .hero .hero_ttl h2 {
    background: #fff;
    color: #000;
    border-bottom: #176DE6 10px solid;
}

#page_agency section .sec_ttl h3:after {
    background: #176DE6;
}

#page_agency .sec_businessArea .inner a {
    background: #176DE6;
}

#page_agency .sec_publication .distribution_wrap .distribution_box {
    background: rgba(57, 130, 233, 0.06);
    padding: 60px 0 80px;
    margin: 120px auto 30px;
}

#page_agency .sec_publication .distribution_wrap .distribution_box .inner h5 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto;
    line-height: 1.78;
}

#page_agency .sec_publication .distribution_wrap .distribution_box .inner img {
    margin-top: 60px;
}

#page_agency .sec_publication .distribution_wrap .inner p {
    text-align: justify;
}

#page_agency .sec_publication .inner .inner_box p {
    text-align: center;
}

#page_agency .sec_publication .inner .inner_box .img_wrap {
    padding: 0 20px;
}

#page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div h6 {
    text-align: center;
    margin: 5px 0 7px;
    line-height: 1.78;
}

#page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div p {
    text-align: justify;
}

#page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div a {
    left: 50%;
    transform: translateX(-50%);
}

#page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div.libraryCenter {
    text-align: justify;
}

#page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div.libraryCenter h6 {
    text-align: justify;
    margin: 0 0 10px;
    line-height: 1.78;
}

#page_agency .sec_publication .inner:last-child .inner_box:nth-child(2) .img_wrap .img_box_2div a {
    left: 0;
    transform: none;
}

#page_agency .sec_publication .inner:last-child .inner_box:last-child .img_wrap .img_box_2div h6 {
    text-align: center;
    margin: 5px 0 7px;
}

#page_agency .sec_publication .inner:last-child .inner_box:last-child .img_wrap .img_box_2div p {
    text-align: center;
}

#page_agency .sec_publication .inner:last-child .inner_box:last-child .img_wrap .img_box_2div a {
    left: 0;
    transform: none;
    width: 270px;
}

#page_agency .sec_publication .inner:last-child .inner_box:last-child .img_wrap .img_box_2div:last-child a:before {
    content: '';
    left: 57px;
}

#page_agency .sec_stationery .inner .img_wrap {
    flex-wrap: wrap;
}

#page_agency .sec_stationery .inner .img_wrap .img_box_3div h5 {
    margin: 5px 0 10px;
    line-height: 1.78;
}

#page_agency .sec_stationery .inner .img_wrap .img_box_3div a {
    width: 200px;
}

#page_agency .sec_stationery .inner .img_wrap .img_box_3div a:before {
    content: '';
    left: 41px;
}

#page_agency .sec_stationery .inner .img_wrap .img_box_3div:first-child a:before {
    content: '';
    left: 55px;
}

#page_agency .sec_stationery .inner .img_wrap .img_box_3div:last-child a:before {
    content: '';
    left: 47px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap {
    padding: 0 20px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div img {
    width: 100%;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(3),
#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(4),
#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(5),
#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(6) {
    margin-top: 60px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div h5 {
    margin: 0;
    line-height: 1.78;
    font-size: 20px;
    font-size: 2rem;
    text-align: center;
    min-height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div h5 img,
#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div h5 span {
    width: auto;
    margin: 0 auto;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div p {
    text-align: center;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(4) p,
#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(5) p {
    min-height: 96px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div a {
    width: 200px;
    margin-top: 20px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div a:before {
    content: '';
    left: 50px;
}

#page_agency .sec_stationery .inner .inner_box a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border: 2px solid #004B9E;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #004B9E;
    line-height: 1;
    margin-top: 75px;
    box-sizing: border-box;
}

#page_agency .sec_stationery .inner .inner_box a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background:  url(../img/common/icon_link@2x.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:first-child a:before {
    content: '';
    left: 55px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(3) a:before {
    content: '';
    left: 42px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(4) a:before {
    content: '';
    left: 57px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(5) a {
    padding: 24px 40px 26px 65px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(5) a:before {
    content: '';
    left: 31px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(6) a {
    padding: 24px 40px 26px 74px;
}

#page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(6) a:before {
    content: '';
    left: 64px;
}

#page_agency .sec_stationery .inner +  .inner {
    margin-top: 100px;
}

#page_agency .sec_stationery .inner + .inner .inner_box .img_wrap .img_box_2div:nth-child(2) {
   margin-top: 0;
}


#page_agency .sec_direction .inner h4 {
    margin-bottom: 110px;
    letter-spacing: -.01em;
}

#page_agency .sec_direction .inner .img_ybs {
    margin-bottom: 35px;
}

#page_agency .sec_direction .inner .img_wrap {
    flex-wrap: wrap;
    justify-content: center;
}

#page_agency .sec_direction .inner .img_wrap .img_box_3div+.img_box_3div {
    margin-left: 55px;
}

#page_agency .sec_direction .inner .img_wrap .img_box_3div h5 {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    height: 48px;
    background: #176DE6;
    color: #fff;
    margin: 0 auto 10px;
    border-radius: 6px;
    line-height: 1.78;
}

#page_agency .sec_direction .inner .img_wrap .img_box_3div img {
    margin: 0 auto 5px;
    background: #fff;
}

/* 220609 ここから */
#page_agency .sec_direction .inner .img_wrap .img_box_3div p {
    text-align: left;
    margin-top: 0.5em;
}

/* 220609 ここまで */

#page_agency .sec_direction .inner a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border: 2px solid #004B9E;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #004B9E;
    line-height: 1;
    margin-top: 75px;
    box-sizing: border-box;
}

#page_agency .sec_direction .inner a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

/* 220609 ここから */
#page_agency .sec_direction .inner a.img_link {
    padding: 0;
    border: none;
    margin-top: 0;
}

#page_agency .sec_direction .inner a.img_link:before {
    display: none;
}

/* 220609 ここまで */


#page_agency .sec_relation .sec_ttl h3:after {
    background: #176DE6;
}

#page_agency .sec_relation .inner ul li:ntgh-child(5) {
    margin-left: 0;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_agency .hero {
        background: url(../img/agency/mv@2x.png) top center no-repeat;
        background-size: cover;
    }

    #page_agency .sec_direction .inner a:before {
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }
}

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

 retail ページ

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

/* 220609 ここから */
#page_retail .hero {
    background: url(../../../../uploads/2023/10/retail_mv.png) top center no-repeat;
    background-size: cover;
}

/* 220609 ここまで */

#page_retail .hero .hero_ttl h2 {
    background: #fff;
    color: #000;
    border-bottom: #E9AF39 10px solid;
}

#page_retail section .sec_ttl h3:after {
    background: #E9AF39;
}

#page_retail .sec_businessArea .inner a {
    background: #E9AF39;
}

#page_retail .sec_management .inner .img_wrap h6 {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
    text-align: justify;
    margin-bottom: 10px;
    width: 100%;
}

#page_retail .sec_management .inner .inner_box {
    padding-bottom: 20px;
}

#page_retail .sec_management .inner .inner_box p.stores_note.only_pc {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 18px;
    font-size: 1.8rem;
    margin: 70px auto 0;
    width: 875px;
    height: 60px;
    background: #FCF3E1;
    border-radius: 10px;
}

#page_retail .sec_management .inner .inner_box p.stores_note.only_sp {
    display: none;
}

#page_retail .sec_management .inner .inner_box+.inner_box {
    margin-top: 30px;
}

#page_retail .sec_management .inner .inner_box img {
    margin: 50px auto 0;
}

#page_retail .sec_management .inner .inner_box .img_wrap .img_box_2div h6 {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    text-align: justify;
    margin-bottom: 10px;
}

#page_retail .sec_management .inner .inner_box .group_wrap {
    width: 950px;
    margin: 0 auto;
}

#page_retail .sec_management .inner .inner_box .group_wrap img {
    width: 100%;
    margin: 0;
}

#page_retail .sec_management .inner .inner_box .img_wrap .img_box_2div h6 span {
    display: block;
    margin: 20px auto 10px;
}

#page_retail .sec_management .inner .inner_box .img_wrap .group_governance {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 310px;
    background: rgba(221, 221, 221, 0.4);
    padding: 60px 30px 30px;
    box-sizing: border-box;
    border-radius: 6px;
    position: relative;
}

#page_retail .sec_management .inner .inner_box .img_wrap .group_governance h6 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50px;
    font-size: 18px;
    font-size: 1.8rem;
    font-weight: 700;
    color: #fff;
    background: #E9AF39;
    margin-bottom: 0;
    border-radius: 6px 6px 0 0;
    position: absolute;
    left: 0px;
    top: 0;
    line-height: 1.78;
}

#page_retail .sec_management .inner .inner_box .img_wrap .group_governance img {
    margin: 20px 0 0 0;
}

#page_retail .sec_management .inner .inner_box .img_wrap .group_store {
    display: flex;
    justify-content: space-between;
    align-items: top;
    flex-wrap: wrap;
    width: 760px;
    background: rgba(221, 221, 221, 0.4);
    padding: 60px 30px 30px;
    position: relative;
    border-radius: 6px;
}

#page_retail .sec_management .inner .inner_box .img_wrap .group_store h6 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50px;
    font-size: 18px;
    font-size: 1.8rem;
    font-weight: 700;
    color: #fff;
    background: #E9AF39;
    border-radius: 6px 6px 0 0;
    position: absolute;
    left: 0px;
    top: 0;
}

#page_retail .sec_management .inner .inner_box .img_wrap .group_store img {
    margin-top: 20px;
}


/* 220609 ここから */
#page_retail .sec_management .newModel_wrap,
#page_retail .sec_management .reuse_wrap {
    margin-top: 120px;
    position: relative;
}

#page_retail .sec_management .newModel_wrap .inner h5,
#page_retail .sec_management .reuse_wrap .inner h5 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    line-height: 1.78;
}

#page_retail .sec_management .newModel_wrap .inner .inner_box,
#page_retail .sec_management .reuse_wrap .inner .inner_box {
    margin: 60px auto 0;
}

#page_retail .sec_management .newModel_wrap .inner .inner_box .img_wrap,
#page_retail .sec_management .reuse_wrap .inner .inner_box .img_wrap {
    padding: 0 20px;
}

#page_retail .sec_management .newModel_wrap .inner .inner_box .img_wrap .img_box_2div {
    width: 500px;
    text-align: center;
}

#page_retail .sec_management .newModel_wrap .inner .inner_box .img_wrap .img_box_2div img {
    margin: 0;
}

#page_retail .sec_management .newModel_wrap .inner .inner_box .img_wrap .img_box_2div h6 {
    text-align: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    margin-top: 10px;
}

#page_retail .sec_management .reuse_wrap .inner img {
    width: 500px;
    text-align: center;
    margin: 0;
}

#page_retail .sec_management .reuse_wrap .inner img.surugaya {
    width: 335px;
    margin-bottom: 20px;
}

/* 220609 ここまで */


#page_retail .sec_management .newModel_wrap .newModel_box {
    margin: 50px auto -140px;
    position: relative;
}

#page_retail .sec_management .newModel_wrap .newModel_box+.newModel_box {
    margin-top: 100px;
}

#page_retail .sec_management .newModel_wrap .newModel_box img {
    width: 100%;
}

#page_retail .sec_management .newModel_wrap .newModel_box .inner {
    position: relative;
    z-index: 99;
    bottom: 140px;
}

#page_retail .sec_management .newModel_wrap .newModel_box .inner .img_wrap {
    display: flex;
    justify-content: space-between;
    align-items: top;
    flex-wrap: nowrap;
    margin-top: 80px;
    width: 100%;
}

#page_retail .sec_management .newModel_wrap .newModel_box .inner .img_wrap .img_box_2div:last-child {
    margin-top: 120px;
    text-align: justify;
}

#page_retail .sec_management .newModel_wrap .newModel_box .inner .img_wrap .img_box_2div h6 {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 15px;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_retail .sec_management .newModel_wrap .newModel_box .inner .img_wrap .img_box_2div h6 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    margin-bottom: 5px;
}

#page_retail .sec_management .newModel_wrap .newModel_box .inner .img_wrap .img_box_2div a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 40px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
}

#page_retail .sec_management .newModel_wrap .newModel_box .inner .img_wrap .img_box_2div a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

#page_retail .sec_newBusiness .inner .img_wrap {
    flex-wrap: wrap;
}

#page_retail .sec_newBusiness .inner .img_wrap .img_box_2div h5 {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    height: 50px;
    background: #E9AF39;
    color: #fff;
    margin: 0 0 15px;
    border-radius: 6px;
    line-height: 1.78;
}

#page_retail .sec_newBusiness .inner .img_wrap .img_box_2div img {
    margin: 0 auto 20px;
    background: #fff;
    display: block;
}

#page_retail .sec_newBusiness .inner .img_wrap .img_box_2div a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 5px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
    width: 240px;
}

#page_retail .sec_newBusiness .inner .img_wrap .img_box_2div a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

#page_retail .sec_relation .sec_ttl h3:after {
    background: #E9AF39;
}

#page_retail area {
    border: none;
    outline: none;
}

/* -------------
retail_map
---------------- */
#page_retail .map_box .pc {
    display: block;
}

#page_retail .map_box .sp,
#page_retail .txt_area.toubu_sp,
#page_retail .txt_area.kantou_sp,
#page_retail .txt_area.kansai_sp,
#page_retail .txt_area.chubu_sp,
#page_retail .txt_area.kyushu_sp {
    display: none;
}

#page_retail .map_box {
    position: relative;
}

.toubu_area img,
.kantou_area img,
.kansai_area img,
.chubu_area img,
.kyushu_area img,
#page_retail .txt_area.toubu,
#page_retail .txt_area.kantou,
#page_retail .txt_area.kansai,
#page_retail .txt_area.chubu,
#page_retail .txt_area.kyushu {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: none;
}

.is-hover {
    display: block !important;
}

#page_retail .txt_area.toubu {
    width: 270px;
    top: 350px;
    right: 186px;
    left: auto;
    z-index: 2;
    position: absolute;
}

#page_retail .txt_area.kantou {
    width: 300px;
    top: 410px;
    right: 194px;
    left: auto;
    z-index: 2;
    position: absolute;
}

#page_retail .txt_area.kansai {
    width: 400px;
    top: 566px;
    right: 337px;
    left: auto;
    z-index: 2;
    position: absolute;
}

#page_retail .txt_area.kansai .line {
    width: 24px;
    height: 63px;
    border-left: 1px solid #E9AF39;
    border-bottom: 1px solid #E9AF39;
    background: none;
    top: 27px;
    left: 92px;
}

#page_retail .txt_area.chubu {
    width: 270px;
    top: 208px;
    right: 470px;
    left: auto;
    z-index: 2;
    position: absolute;
    padding: 0 0 130px 0;
}

#page_retail .txt_area.chubu .line {
    width: 1px;
    height: 88px;
    top: 160px;
    bottom: -88px;
    left: 50%;
}

#page_retail .txt_area.kyushu {
    width: 270px;
    top: 182px;
    right: auto;
    left: 190px;
    z-index: 2;
    position: absolute;
    padding: 0 0 220px 0;
}

#page_retail .txt_area.kyushu .line {
    width: 29px;
    height: 222px;
    bottom: 0px;
    left: 40%;
    background: url(../img/retail/retail08_kyushu_area_line_pc.png) center center no-repeat;
    background-size: cover;
    top: 182px;
}

#page_retail .txt_area.kyushu .inner {
    width: 212px;
}

#page_retail .txt_area h4 {
    color: #FFF;
    font-size: 16px;
    line-height: 1.2;
    margin: 10px auto;
}

#page_retail .txt_area h4 span {
    font-size: 20px;
    margin: 0 3px 0 0;
}

#page_retail .txt_area .line {
    display: block;
    background: #E9AF39;
    width: 76px;
    height: 1px;
    top: 50%;
    position: absolute;
}

#page_retail .txt_area .inner {
    background-color: #E9AF39;
    border-radius: 6px;
    width: 170px;
    padding: 0 8px 10px 8px;
}

#page_retail .txt_area .txt_box {
    background-color: #FFF;
    text-align: left;
    padding: 10px;
    font-size: 14px;
    font-weight: bold;
}

#page_retail .txt_area .txt_box ul {
    font-weight: normal;
}

#page_retail .txt_area .txt_box ul li:before {
    content: "■";
}






#page_retail .sec_management .inner .inner_box .img_wrap .group_store { display: flex; justify-content: flex-start; align-items: flex-start; flex-wrap: wrap; width: 760px; background: rgba(221, 221, 221, 0.4); padding: 60px 30px 30px; position: relative; border-radius: 6px; }
#page_retail .sec_management .inner .inner_box .img_wrap .group_store > img { margin: 20px 6.6px 0; }
#page_retail p.time { text-align: right; margin-top: -0.5em; margin-right: 11%; }

#page_retail .sec_management .inner .inner_box .img_wrap .group_governance { display: flex; justify-content: flex-start; align-items: center; width: 100%; background: rgba(221, 221, 221, 0.4); padding: 30px 30px 30px 370px; box-sizing: border-box; border-radius: 6px; position: relative; }
#page_retail .sec_management .inner .inner_box .img_wrap .group_governance h6 { display: flex; justify-content: center; align-items: center; width: 340px; height: 100%; font-size: 18px; font-size: 1.8rem; font-weight: 700; color: #fff; background: #E9AF39; margin-bottom: 0; border-radius: 6px 0 0 6px; position: absolute; left: 0px; top: 0; line-height: 1.78; letter-spacing: 0em; }
#page_retail .sec_management .inner .inner_box .img_wrap .group_governance img { margin: 0; }
#page_retail .sec_management .inner .inner_box .img_wrap .group_store { display: flex; justify-content: flex-start; align-items: center; width: 100%; background: rgba(221, 221, 221, 0.4); padding: 10px 20px 30px 360px; box-sizing: border-box; border-radius: 6px; position: relative; }
#page_retail .sec_management .inner .inner_box .img_wrap .group_store h6 { display: flex; justify-content: center; align-items: center; width: 340px; height: 100%; font-size: 18px; font-size: 1.8rem; font-weight: 700; color: #fff; background: #E9AF39; margin-bottom: 0; border-radius: 6px 0 0 6px; position: absolute; left: 0px; top: 0; line-height: 1.78; letter-spacing: 0em; }
#page_retail .sec_management .inner .inner_box .img_wrap .group_store > img { margin: 20px 10px 0; }
#page_retail .sec_management .inner .inner_box .img_wrap .group_governance + .group_store { margin-top: 20px; }
#page_retail .sec_management .inner .inner_box .img_wrap .group_store + .group_governance { margin-top: 20px; }

@media only screen and (max-width: 767px) {
    #page_retail .map_box .pc {
        display: none;
    }

    #page_retail .map_box .sp {
        display: block;
    }

    #page_retail .map_box img {
        margin: 0 auto;
        text-align: center;
        width: 100%;
    }

    #page_retail .txt_area h4 {
        font-size: 3.2vw;
        margin: 2.13vw auto;
        letter-spacing: 1px;
    }

    #page_retail .txt_area h4 span {
        font-size: 4vw;
    }

    #page_retail .txt_area .txt_box {
        font-size: 3.2vw;
    }

    #page_retail .txt_area .close_btn {
        cursor: pointer;
        position: absolute;
        z-index: 2;
        right: -3vw;
        top: -3vw;
        width: 7vw;
        height: 7vw;
        display: block;
    }

    #page_retail .txt_area {
        width: auto;
        top: 5.333vw;
        left: 5.333vw;
        right: auto;
        z-index: 2;
        position: absolute;
        display: none;
    }

    #page_retail .txt_area .inner {
        width: 45vw;
    }

    #page_retail .area_select {
        position: absolute;
        /*    background: #a00; */
        border-radius: 100%;
    }

    #page_retail .area_select.toubu {
        top: 35vw;
        left: 50vw;
        width: 12.5vw;
        height: 24.5vw;
        transform: rotate(1deg);
    }

    #page_retail .area_select.kantou {
        top: 58vw;
        left: 46.5vw;
        width: 9.5vw;
        height: 13.5vw;
        transform: rotate(-26deg);
    }

    #page_retail .area_select.chubu {
        top: 56vw;
        left: 33.67vw;
        width: 11.5vw;
        height: 19.5vw;
        transform: rotate(-3deg);
    }

    #page_retail .area_select.kansai {
        top: 63.5vw;
        left: 24.67vw;
        width: 9vw;
        height: 19.5vw;
        transform: rotate(-7deg);
    }

    #page_retail .area_select.kyushu {
        top: 66.5vw;
        left: 1.67vw;
        width: 13vw;
        height: 29.5vw;
        transform: rotate(19deg);
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .group_store { display: flex; justify-content: center; align-items: top; flex-wrap: wrap; width: 100%; background: rgba(221, 221, 221, 0.4); padding: 23vw 0 10.67vw; position: relative; border-radius: 6px; }
    #page_retail .sec_management .inner .inner_box .img_wrap .group_store > img { margin: 2.67vw auto 0; }
    #page_retail p.time { text-align: right; margin-top: 0; margin-right: 0; }
    #page_retail .sec_management .inner .inner_box .img_wrap .group_governance { display: flex; justify-content: center; align-items: center; width: 100%; background: rgba(221, 221, 221, 0.4); padding: 23vw 0 10.67vw;  box-sizing: border-box; border-radius: 6px;  position: relative; flex-wrap: wrap; margin-bottom: 5.33vw; }
    #page_retail .sec_management .inner .inner_box .img_wrap .group_governance h6 { display: flex; justify-content: center; align-items: center; width: 100%; height: 13.33vw; font-size: 4.27vw; font-weight: 700; color: #fff; background: #E9AF39; margin-bottom: 0; border-radius: 6px 6px 0 0; position: absolute; left: 0px; top: 0; line-height: 1.78; }
    #page_retail .sec_management .inner .inner_box .img_wrap .group_governance img { width: 58.67vw; }
    #page_retail .sec_management .inner .inner_box .img_wrap .group_store { display: flex; justify-content: center; align-items: center; width: 100%; background: rgba(221, 221, 221, 0.4); padding: 20.33vw 0 10.67vw;  box-sizing: border-box; border-radius: 6px;  position: relative; flex-wrap: wrap; margin-bottom: 5.33vw; }
    #page_retail .sec_management .inner .inner_box .img_wrap .group_store h6 { display: flex; justify-content: center; align-items: center; width: 100%; height: 13.33vw; font-size: 4.27vw; font-weight: 700; color: #fff; background: #E9AF39; margin-bottom: 0; border-radius: 6px 6px 0 0; position: absolute; left: 0px; top: 0; line-height: 1.78; }
    #page_retail .sec_management .inner .inner_box .img_wrap .group_governance + .group_store { margin-top: 0; }
    #page_retail .sec_management .inner .inner_box .img_wrap .group_store + .group_governance { margin-top: 0; }

}

/* -------------
retail_map　ここまで
---------------- */

@media only screen and (-webkit-min-device-pixel-ratio: 2) {

    /* 220609 ここから */
    #page_retail .hero {
        background: url(../../../../uploads/2023/10/retail_mv@2x.png) top center no-repeat;
        background-size: cover;
    }

    /* 220609 ここまで */

    #page_retail .sec_management .newModel_wrap .newModel_box .inner .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }
}

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

 abroad ページ

-------------------------------- */
#page_abroad .hero {
    background: url(../img/abroad/mv.png) top center no-repeat;
    background-size: cover;
}

#page_abroad .hero .hero_ttl h2 {
    background: #fff;
    color: #000;
    border-bottom: #39AFE9 10px solid;
}

#page_abroad section .sec_ttl h3:after {
    background: #39AFE9;
}

#page_abroad .sec_businessArea .inner a {
    background: #39AFE9;
}

#page_abroad .sec_ttlArea h4 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 35px;
    line-height: 1.78;
}

#page_abroad .sec_ttlArea img {
    margin-bottom: 35px;
    width: 197px;
}

#page_abroad .sec_export img {
    margin: 15px auto 40px;
    width: 100%;
}

#page_abroad .sec_export .inner img {
    margin: 15px auto 40px;
}


#page_abroad .sec_export .inner .group_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 1030px;
    text-align: justify;
    margin: auto;
}

#page_abroad .sec_export .inner .group_wrap h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin-bottom: 70px;
    line-height: 1.78;
    width: 100%;
    margin-top: 135px;
    text-align: center;
}

#page_abroad .sec_export .inner .group_wrap .group_box {
    width: 500px;
}

#page_abroad .sec_export .inner .group_wrap .group_box h5 {
    font-size: 18px;
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 0;
    letter-spacing: 0;
    line-height: 1;
    text-align: center;
    color: #fff;
    background: #39AFE9;
    border-radius: 6px 6px 0 0;
    padding: 15px;
}

#page_abroad .sec_export .inner .group_wrap .group_box dl {
    display: flex;
    font-size: 16px;
    font-size: 1.6rem;
    background: rgba(221, 221, 221, .4);
    border-radius: 0 0 6px 6px;
    padding: 20px 25px;
    min-height: 140px;
    box-sizing: border-box;
    align-items: center;
}

#page_abroad .sec_export .inner .group_wrap .group_box dl dt {
    font-weight: 700;
    padding-right: 20px;
    letter-spacing: 0em;
}

#page_abroad .sec_export .inner .group_wrap .group_box dl dd {
    width: 360px;
    padding-left: 20px;
    border-left: 1px solid #fff;
    min-height: 100px;
    display: flex;
    align-items: center;
    letter-spacing: 0em;
    line-height: 2;
}

#page_abroad .sec_export .inner a {
    display: inline-block;
    position: relative;
    padding: 36px 40px 35px 45px;
    border-radius: 50px;
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 50px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
    min-width: 395px;
    min-height: 100px;
}

#page_abroad .sec_export .inner a:before {
    content: '';
    position: relative;
    display: inline-block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background: url(/wp-content/themes/nippan/assets/img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    margin: 0.1em 0.8em -0.1em 0;
}


#page_abroad .sec_import img {
    margin: 15px auto 40px;
    width: 100%;
}

#page_abroad .sec_import .inner .group_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 1030px;
    text-align: justify;
    margin: 70px auto 0;
}

#page_abroad .sec_import .inner .group_wrap .group_box {
    width: 323px;
}

#page_abroad .sec_import .inner .group_wrap .group_box h4 {
    font-size: 18px;
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 0;
    letter-spacing: 0;
    line-height: 1;
    text-align: center;
    color: #fff;
    background: #39AFE9;
    border-radius: 6px 6px 0 0;
    padding: 15px;
}

#page_abroad .sec_import .inner .group_wrap .group_box p {
    font-size: 16px;
    font-size: 1.6rem;
    background: rgba(221, 221, 221, .4);
    border-radius: 0 0 6px 6px;
    padding: 20px 25px;
    min-height: 205px;
    box-sizing: border-box;
    text-align: left;
    letter-spacing: 0em;
    line-height: 2;
}

#page_abroad .sec_import .inner a {
    display: inline-block;
    position: relative;
    padding: 36px 40px 35px 45px;
    border-radius: 50px;
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 50px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
    min-width: 395px;
    min-height: 100px;
}

#page_abroad .sec_import .inner a:before {
    content: '';
    position: relative;
    display: inline-block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background: url(/wp-content/themes/nippan/assets/img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    margin: 0.1em 0.8em -0.1em 0;
}

#page_abroad .sec_publication .flow_wrap {
    background: rgba(57, 175, 233, 0.15);
    padding: 75px 0 40px;
    margin-top: 80px;
}

#page_abroad .sec_publication .flow_wrap .inner h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin-bottom: 10px;
    line-height: 1.78;
}

#page_abroad .sec_publication .inner p {
    margin-top: 20px;
}

#page_abroad .sec_publication .inner img {
    margin: 40px auto 20px;
}

#page_abroad .sec_publication .inner a {
    display: inline-block;
    position: relative;
    padding: 36px 40px 35px 45px;
    border-radius: 50px;
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 50px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
    min-width: 395px;
    min-height: 100px;
}

#page_abroad .sec_publication .inner a:before {
    content: '';
    position: relative;
    display: inline-block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background: url(/wp-content/themes/nippan/assets/img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    margin: 0.1em 0.8em -0.1em 0;
}

#page_abroad .sec_clubJapan .inner img {
    margin: 0 auto 40px;
}

#page_abroad .sec_clubJapan img {
    margin: 15px auto 40px;
    width: 100%;
}

#page_abroad .sec_clubJapan .inner p+p {
    margin-top: 20px;
}

#page_abroad .sec_clubJapan .inner a {
    display: inline-block;
    position: relative;
    padding: 36px 40px 35px 75px;
    border-radius: 50px;
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 50px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
    min-width: 395px;
    min-height: 100px;
}

#page_abroad .sec_clubJapan .inner a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}


#page_abroad .sec_relation .sec_ttl h3:after {
    background: #39AFE9;
}


@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_abroad .hero {
        background: url(../img/abroad/mv@2x.png) top center no-repeat;
        background-size: cover;
    }

    #page_abroad .sec_clubJapan .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }

    #page_abroad .sec_export .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        margin: 0.1em 0.8em -0.1em 0;
    }

    #page_abroad .sec_import .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        margin: 0.1em 0.8em -0.1em 0;
    }

    #page_abroad .sec_publication .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        margin: 0.1em 0.8em -0.1em 0;
    }
}

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

 stationery ページ

-------------------------------- */
#page_stationery .hero {
    background: url(../img/stationery/mv.png) top center no-repeat;
    background-size: cover;
}

#page_stationery .hero .hero_ttl h2 {
    background: #fff;
    color: #000;
    border-bottom: #3CBE93 10px solid;
}

#page_stationery section .sec_ttl h3:after {
    background: #3CBE93;
}

#page_stationery .sec_businessArea .inner a {
    background: #3CBE93;
}

#page_stationery .sec_ttlArea img {
    margin: 10px auto 35px;
}

#page_stationery .sec_planning {
    padding: 200px 0 25px;
}

#page_stationery .sec_planning img {
    margin: 25px auto 50px;
    width: 100%;
}

#page_stationery .sec_planning .inner {
    display: block;
}

#page_stationery .sec_planning .inner p {
    text-align: center;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_stationery .sec_directManagement .inner {
    display: block;
}

#page_stationery .sec_directManagement .inner p {
    text-align: center;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 15px;
}

#page_stationery .sec_directManagement .inner .img_wrap {
    margin-top: 25px;
}

#page_stationery .sec_directManagement .inner .img_wrap .img_box_2div {
    text-align: justify;
}

#page_stationery .sec_directManagement .inner .img_wrap .img_box_2div h5 {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    text-align: justify;
    margin: 0 auto 10px;
    line-height: 1.78;
}

#page_stationery .sec_directManagement .inner .img_wrap .img_box_2div h5 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    margin: 10px auto 0;
}

#page_stationery .sec_directManagement .inner .img_wrap .img_box_2div p {
    text-align: justify;
}

#page_stationery .sec_directManagement .inner .img_wrap .img_box_2div a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 40px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
}

#page_stationery .sec_directManagement .inner .img_wrap .img_box_2div a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

#page_stationery .sec_directManagement .slider_wrap {
    margin-bottom: 120px;
}

#page_stationery .sec_directManagement .slider_wrap h4 {
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    margin: 120px auto 110px;
    line-height: 1.78;
}

#page_stationery .sec_directManagement .slider_wrap .slider {
    margin: 0;
    width: 100%;
    position: relative;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide {
    margin: 0 15px;
    width: 700px;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide img {
    width: 100%;
    margin: 0 auto 20px;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide h5 {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    text-align: center;
    margin: 20px auto 0;
    opacity: 0;
    transition: .5s;
    line-height: 1.78;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide h6 {
    text-align: center;
    font-weight: 700;
    margin: 15px auto 10px;
    font-size: 16px;
    font-size: 1.6rem;
    opacity: 0;
    transition: .5s;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide p {
    text-align: center;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 16px;
    font-size: 1.6rem;
    letter-spacing: -.03em;
    margin-bottom: 0;
    opacity: 0;
    transition: .5s;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide.slick-active h5 {
    opacity: 1;
    line-height: 1.78;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide.slick-active h6 {
    opacity: 1;
    line-height: 1.78;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide.slick-active p {
    opacity: 1;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide-dots {
    text-align: center;
    position: absolute;
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    align-self: center;
    top: -60px;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li {
    display: block;
    padding: 0 35px;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li button {
    display: none;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li.slick-active:before {
    opacity: .5;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li+li {
    border-left: 1px solid #000;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li:first-child:before {
    content: 'DULTON JIYUGAOKA';
    display: block;
    position: relative;
    line-height: 1;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li:nth-child(2):before {
    content: 'DULTON MARKET STORE　グランベリーパーク店';
    display: block;
    position: relative;
    line-height: 1;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li:last-child:before {
    content: 'DULTON FACTORY SERVICE OSAKA';
    display: block;
    position: relative;
    line-height: 1;
}

#page_stationery .sec_directManagement .slider_wrap .slider .slick-next {
    z-index: 99;
    left: 50%;
    transform: translateX(311px);
}

#page_stationery .sec_directManagement .slider_wrap .slider .slick-prev {
    z-index: 100;
    left: 50%;
    transform: translateX(-350px);
}

#page_stationery .sec_directManagement .slider_wrap .slider .arrows {
    font-size: 28px;
    position: relative;
    text-align: right;
    margin: 20px 10px 10px 0;
}

#page_stationery .sec_directManagement .slider_wrap .slick-prev:before,
#page_stationery .sec_directManagement .slider_wrap .slick-next:before {
    color: #464646;
    display: none;
}

#page_stationery .sec_directManagement .slider_wrap .slick-next {
    background: url(../img/common/right-arrow.png);
    background-size: 40px 40px;
    z-index: 99;
    width: 40px;
    height: 40px;
    top: 31%;
}

#page_stationery .sec_directManagement .slider_wrap .slick-prev {
    background: url(../img/common/left-arrow.png);
    background-size: 40px 40px;
    z-index: 99;
    width: 40px;
    height: 40px;
    top: 31%;
}

#page_stationery .sec_directManagement .slider_wrap .slick-dotted.slick-slider {
    margin-bottom: 0;
}

#page_stationery .sec_contract img {
    margin: 25px auto 50px;
    width: 100%;
}

#page_stationery .sec_contract .inner {
    display: block;
}

#page_stationery .sec_contract .inner p {
    text-align: center;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_stationery .sec_relation .sec_ttl h3:after {
    background: #3CBE93;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_stationery .hero {
        background: url(../img/stationery/mv@2x.png) top center no-repeat;
        background-size: cover;
    }

    #page_stationery .sec_directManagement .inner .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }

    #page_stationery .sec_directManagement .slider_wrap .slick-next {
        background: url(../img/common/right-arrow@2x.png);
        background-size: 40px 40px;
        z-index: 99;
        width: 40px;
        height: 40px;
        top: 31%;
    }

    #page_stationery .sec_directManagement .slider_wrap .slick-prev {
        background: url(../img/common/left-arrow@2x.png);
        background-size: 40px 40px;
        z-index: 99;
        width: 40px;
        height: 40px;
        top: 31%;
    }
}

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

 contents ページ

-------------------------------- */
#page_contents .hero {
    background: url(../img/contents/mv.png) top center no-repeat;
    background-size: cover;
}

#page_contents .hero .hero_ttl h2 {
    background-color: #fff;
    color: #000;
    border-bottom: #E987A8 10px solid;
}

#page_contents section .sec_ttl h3:after {
    background: #E987A8;
}

#page_contents .sec_businessArea .inner a {
    background: #E987A8;
}

#page_contents .sec_ttlArea img {
    margin-bottom: 35px;
}

#page_contents .sec_deployment {
    padding: 60px 0 75px;
}

#page_contents .sec_deployment .label_wrap {}

#page_contents .sec_deployment .label_wrap .inner {
    padding-bottom: 60px;
    margin: 0 auto;
}

#page_contents .sec_deployment .label_wrap .inner h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 60px auto 20px;
    line-height: 1.78;
}

#page_contents .sec_ebook {
    padding: 0 0 25px;
}


#page_contents .sec_ebook .label_wrap {
    background: rgba(233, 135, 168, 0.15);
}

#page_contents .sec_ebook .label_wrap .inner {
    padding-bottom: 100px;
    margin: 0 auto;
    width: 950px;
}

#page_contents .sec_ebook .label_wrap .inner h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 100px auto 20px;
    line-height: 1.78;
}

#page_contents .sec_ebook .label_wrap .inner .img_wrap {
    margin-top: 20px;
}

#page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div {
    width: 278px;
}

#page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div img {
    margin: 30px auto 0;
    background: transparent;
    width: 100%;
}

#page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div h5 {
    margin: 20px auto 0;
    text-align: center;
}

#page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div p {
    text-align: center;
}

#page_contents .sec_ebook .label_wrap .inner > a {
    display: inline-block;
    position: relative;
    padding: 36px 40px 35px 45px;
    border-radius: 50px;
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 70px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
    min-width: 395px;
    min-height: 100px;
    background: #fff;   
}

#page_contents .sec_ebook .label_wrap .inner > a:before {
    content: '';
    position: relative;
    display: inline-block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link@2x.png) center center no-repeat;
    background: url(/wp-content/themes/nippan/assets/img/common/icon_link@2x.png) center center no-repeat;
    background-size: 20px 18px;
    margin: 0.1em 0.8em -0.1em 0;
}

#page_contents .sec_relation .sec_ttl h3:after {
    background: #E987A8;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_contents .hero {
        background: url(../img/contents/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 entertainment ページ

-------------------------------- */
#page_entertainment .hero {
    background: url(../img/entertainment/mv.png) top center no-repeat;
    background-size: cover;
}

#page_entertainment .hero .hero_ttl h2 {
    background-color: #fff;
    color: #000;
    border-bottom: #DB5266 10px solid;
}

#page_entertainment section .sec_ttl h3:after {
    background: #DB5266;
}

#page_entertainment .sec_businessArea .inner a {
    background: #DB5266;
}

#page_entertainment .sec_ttlArea img {
    margin-bottom: 35px;
    width: 260px;
}

#page_entertainment .sec_test {
    padding: 200px 0 25px;
}

#page_entertainment section .inner {
    display: block;
}

#page_entertainment section .inner p {
    text-align: center;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_entertainment section .inner .inner_box .img_wrap .img_box_3div img {
    margin: 0 auto;
}


#page_entertainment section .inner .inner_box .img_wrap .img_box_3div a {
    width: 270px;
}

#page_entertainment section .inner .inner_box .img_wrap .img_box_3div a:before {
    content: '';
    left: 40px;
}

#page_entertainment section .inner .inner_box .img_wrap .img_box_3div:first-child a:before {
    content: '';
    left: 84px;
}

#page_entertainment section .inner .inner_box .img_wrap .img_box_3div:last-child a:before {
    content: '';
    left: 65px;
}


#page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div a {
    width: 225px;
}

#page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div a:before {
    content: '';
    left: 42px;
}

#page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div:first-child a:before {
    content: '';
    left: 50px;
}

#page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div:last-child a:before {
    content: '';
    left: 50px;
}

#page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div p {
    text-align: justify;
    margin-top: 20px;
    font-size: 14px;
    font-size: 1.4rem;
}



#page_entertainment section img {
    margin: 25px auto 40px;
    width: 100%;
}

#page_entertainment .sec_relation .sec_ttl h3:after {
    background: #DB5266;
}



#page_entertainment section .inner .inner_box .portal_wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
}

#page_entertainment section .inner .inner_box .portal_wrap img {
    width: 224px;
}

#page_entertainment section .inner .inner_box .portal_wrap a {
    display: inline-block;
    position: relative;
    padding: 24px 0px 26px 40px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 20px;
    border: 2px solid #004B9E;
    color: #004B9E;
    background: #fff;
    width: 270px;
    box-sizing: border-box;
}

#page_entertainment section .inner .inner_box .portal_wrap a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 35px;
    transform: translateY(-50%);
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_entertainment .hero {
        background: url(../img/entertainment/mv@2x.png) top center no-repeat;
        background-size: cover;
    }

    #page_entertainment section .inner .inner_box .portal_wrap a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 35px;
        transform: translateY(-50%);
    }
}

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

 newbusiness ページ

-------------------------------- */
#page_newbusiness .hero {
    background: url(../img/newbusiness/mv.png) top center no-repeat;
    background-size: cover;
}

#page_newbusiness .hero .hero_ttl h2 {
    background: #fff;
    color: #000;
    border-bottom: #26B4BE 10px solid;
}

#page_newbusiness section .sec_ttl h3:after {
    background: #26B4BE;
}

#page_newbusiness .sec_businessArea .inner a {
    background: #26B4BE;
}

#page_newbusiness .sec_bookHotel {
    padding: 200px 0 25px;
}

#page_newbusiness section img {
    margin: 25px auto 40px;
    width: 100%;
}

#page_newbusiness section figure {
    margin: 25px auto 40px;
    width: 100%;
    position: relative;
}

#page_newbusiness section figure img {
    margin: 0;
}

#page_newbusiness section figure figcaption {
    position: absolute;
    font-size: 1rem;
    margin-top: .5em;
    right: 0;
}

#page_newbusiness section .inner {
    display: block;
}

#page_newbusiness section .inner img {
    width: auto;
}

#page_newbusiness section .inner p {
    text-align: center;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_newbusiness section .inner .inner_box .img_wrap .img_box_2div {
    text-align: center;
}

#page_newbusiness section .inner .inner_box .img_wrap .img_box_2div a {
    margin-top: 0;
}

#page_newbusiness .sec_relation .sec_ttl h3:after {
    background: #26B4BE;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_newbusines .hero {
        background: url(../img/newbusiness/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 shared ページ

-------------------------------- */
#page_shared .hero {
    background: url(../img/shared/mv.png) top center no-repeat;
    background-size: cover;
}

#page_shared .hero .hero_ttl h2 {
    background: #fff;
    color: #000;
    border-bottom: #AE9C67 10px solid;
}

#page_shared section .sec_ttl h3:after {
    background: #AE9C67;
}

#page_shared .sec_sharedService {
    padding: 200px 0 25px;
}

#page_shared .sec_ttlArea img {
    margin-bottom: 35px;
    width: 220px;
}

#page_shared .sec_businessArea .inner a {
    background: #AE9C67;
}

#page_shared section img {
    margin: 25px auto 40px;
    width: 100%;
}

#page_shared section .inner {
    display: block;
}

#page_shared section .inner img {
    width: auto;
}

#page_shared section .inner p {
    text-align: center;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_shared section .inner .inner_box .img_wrap .img_box_2div {
    text-align: center;
}

#page_shared section .inner .inner_box .img_wrap .img_box_2div a {
    margin-top: 0;
}

#page_shared .sec_staffService .inner a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 50px;
    border: 2px solid #004B9E;
    color: #004B9E;
    box-sizing: border-box;
}

#page_shared .sec_staffService .inner a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

#page_shared .sec_relation .sec_ttl h3:after {
    background: #AE9C67;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_shared .hero {
        background: url(../img/shared/mv@2x.png) top center no-repeat;
        background-size: cover;
    }

    #page_shared .sec_staffService .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }
}

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

 business-partners ページ

-------------------------------- */
#page_business_partners {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_business_partners .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/business_partners/mv.png) top center no-repeat;
    background-size: cover;
}

#page_business_partners section .sec_ttl h2:after {
    background: #AE9C67;
}

#page_business_partners .sec_business_partners {
    padding: 160px 0 115px;
}

#page_business_partners .sec_business_partners .sec_ttl {
    margin-bottom: 65px;
}

#page_business_partners .sec_business_partners .sec_ttl h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: bold;
}

#page_business_partners .sec_business_partners .sec_ttl h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
    background: #AE9C67;
}

#page_business_partners .sec_business_partners .companyProf_wrap .inner {
    text-align: justify;
}

#page_business_partners .sec_business_partners .companyProf_wrap .inner img {
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    margin-top: 10px;
}

#page_business_partners .sec_business_partners .companyProf_wrap .inner h3 {
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    margin: 50px auto 60px;
    text-align: center;
    line-height: 1.78;
}

#page_business_partners .sec_business_partners .companyProf_wrap .inner dl {
    display: flex;
    justify-content: flex-start;
    line-height: 2;
    font-size: 16px;
    font-size: 1.6rem;
    width: 770px;
    margin: auto;
}

#page_business_partners .sec_business_partners .companyProf_wrap .inner dl dt {
    width: 175px;
    font-weight: 700;
    margin-bottom: 10px;
}

#page_business_partners .sec_business_partners .companyProf_wrap .inner dl dd {
    margin-bottom: 10px;
    flex: 1;
    letter-spacing: 0em;
}

#page_business_partners .sec_business_partners .companyProf_wrap .inner dl dd a {
    color: #004B9E;
    margin: 10px 0 15px;
    font-size: 16px;
    font-size: 1.6rem;
    text-decoration: underline;
}

@media all and (-ms-high-contrast: none) {
    #page_business_partners .sec_business_partners .companyProf_wrap .inner dl dd {
        flex: 1%;
    }
}

#page_business_partners .sec_business_partners .access_wrap {
    background: rgba(174, 156, 103, 0.15);
    padding: 90px 0 100px;
    margin-top: 95px;
}

#page_business_partners .sec_business_partners .access_wrap .inner h3 {
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    margin: 10px auto 60px;
    text-align: center;
    line-height: 1.78;
}

#page_business_partners .sec_business_partners .access_wrap .inner .img_wrap {
    display: flex;
    justify-content: space-between;
    align-items: top;
    flex-wrap: wrap;
    margin-top: 0;
}

#page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div {
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}

#page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div h4 {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 50px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    background: #AE9C67;
    border-radius: 6px;
    margin: 0;
    width: 100%;
    line-height: 1.78;
}

#page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div .txt_box {
    height: 180px;
    display: flex;
    justify-content: center;
    align-items: center;
}

#page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div .txt_box p {
    text-align: justify;
}

#page_business_partners .sec_business_partners .dispatch_wrap {
    padding: 90px 0 100px;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner {
    text-align: justify;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner h3 {
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    margin: 10px auto 60px;
    text-align: center;
    line-height: 1.78;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner dl {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    line-height: 2;
    font-size: 16px;
    font-size: 1.6rem;
    width: 795px;
    margin: auto;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner dl dt {
    font-weight: 700;
    margin-bottom: 10px;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner dl dt:before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    background: #AE9C67;
    margin-right: .5em;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner dl dd {
    margin-bottom: 10px;
    letter-spacing: 0em;
    margin-left: 1.3em;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner dl dd p {
    text-align: justify;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner dl dd p span {
    font-weight: 700;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner dl dd p+p {
    margin-top: 20px;
}

#page_business_partners .sec_business_partners .dispatch_wrap .inner dl:nth-child(5) dd,
#page_business_partners .sec_business_partners .dispatch_wrap .inner dl:nth-child(6) dd {
    width: 100%;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_business_partners .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/business_partners/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 it ページ

-------------------------------- */
#page_it .hero {
    background: url(../img/it/mv.png) top center no-repeat;
    background-size: cover;
}

#page_it .hero .hero_ttl h2 {
    background: #fff;
    color: #000;
    border-bottom: #937FD7 10px solid;
}

#page_it section .sec_ttl h3:after {
    background: #937FD7;
}

#page_it .sec_businessArea .inner a {
    background: #937FD7;
}

#page_it .sec_itShared {
    padding: 200px 0 25px;
}

#page_it section img {
    margin: 25px auto 40px;
    width: 100%;
}

#page_it section .inner {
    display: block;
}

#page_it section .inner img {
    width: auto;
    margin: 40px auto 40px;
}

#page_it section .inner p {
    text-align: center;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_it section .inner p.lead {
    font-size: 18px;
    font-size: 1.8rem;
}

#page_it section .inner .inner_box .img_wrap .img_box_2div {
    text-align: center;
}

#page_it section .inner .inner_box .img_wrap .img_box_2div a {
    margin-top: 0;
}

#page_it section .inner .inner_box .img_wrap .img_box_2div a>br.only_sp {
    line-height: 0 !important;
}

#page_it section .inner .inner_box .img_wrap .img_box_2div:first-child a {
    letter-spacing: 0;
}

#page_it .sec_publishingSolution .conteo_wrap {
    background: rgba(147, 127, 215, 0.1);
    padding: 50px 0 60px;
    margin-top: 95px;
}

#page_it .sec_publishingSolution .conteo_wrap .inner h5 {
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    margin-bottom: 20px;
    line-height: 1.78;
}

#page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 940px;
    margin: auto;
}


#page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner .conteo_box {
    background: #FBEACB;
    width: 300px;
    padding: 30px 20px;
    text-align: justify;
    margin-bottom: 20px;
    border-radius: 6px;
}

#page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner .conteo_box img {
    width: 100%;
    margin: 0;
}

#page_it .sec_publishingSolution .conteo_wrap .inner img.conteo_logo {
    width: 452px;
    margin-top:  10px;
}

#page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner .conteo_box .conteo_ttl {
    font-size: 18px;
    font-size: 1.8rem;
    font-weight: 700;
    text-align: center;
    margin-top: 20px;
}

#page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner .conteo_box p {
    font-size: 12px;
    font-size: 1.2rem;
    margin-top: 20px;
    text-align: left;
    font-weight: normal;
    line-height: 1.67;
}



#page_it .sec_publishingSolution .conteo_wrap .inner a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 40px;
    border: 2px solid #004B9E;
    color: #004B9E;
    background: #fff;
}

#page_it .sec_publishingSolution .conteo_wrap .inner a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

#page_it .sec_newtechSolution .inner .inner_box .img_wrap .img_box_2div img {
    margin-top: 0;
}

#page_it .sec_fullscopeSolution .inner .inner_box {
    width: 100%;
}

#page_it .sec_fullscopeSolution .inner .inner_box img {
    margin-top: 0;
}

#page_it .sec_fullscopeSolution .inner a {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 75px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 30px;
    border: 2px solid #004B9E;
    color: #004B9E;
}

#page_it .sec_fullscopeSolution .inner a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

#page_it .sec_relation .sec_ttl h3:after {
    background: #937FD7;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_it .hero {
        background: url(../img/it/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
    
    #page_it .sec_publishingSolution .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }

    #page_it .sec_fullscopeSolution .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }
}

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

 news_information　ページ

-------------------------------- */
#page_news_information {
    padding: 100px 0 0;
    /* margin-top: 0; */
}

#page_news_information section.hero {
    padding: 160px 0 60px;
}

#page_news_information section.hero .hero_ttl h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
}

#page_news_information section.hero .hero_ttl h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_news_information .sec_news_information {
    padding: 120px 0 180px;
}

#page_news_information .sec_news_information .inner {
    width: 1100px;
}

#page_news_information .sec_news_information .inner h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
}

#page_news_information .sec_news_information .inner h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_news_information .sec_news_information .inner a.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    border: 2px solid #004B9E;
    border-radius: 35px;
    width: 320px;
    height: 70px;
    text-align: center;
    margin: auto;
    color: #004B9E;
    margin: 30px auto 0;
    box-sizing: border-box;
}

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

 news_information_article　ページ

-------------------------------- */
#page_news_information_article {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_news_information_article .sec_news_information_article {
    padding: 120px 0 230px;
}

#page_news_information_article .sec_news_information_article .inner {
    width: 1100px;
    text-align: justify;
}

#page_news_information_article .sec_news_information_article .inner .date_box {
    margin-bottom: 50px;
}

#page_news_information_article .sec_news_information_article .inner .date_box p {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    margin-right: 25px;
}

#page_news_information_article .sec_news_information_article .inner .date_box span {
    display: inline-block;
    padding: 3px 10px;
    font-size: 11px;
    font-size: 1.1rem;
    line-height: 1;
    text-align: center;
    min-width: 115px;
    color: #004B9E;
    border: 1px solid #004B9E;
    border-radius: 3px;
    box-sizing: border-box;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.agency_tag {
    background: #176DE6;
    color: #fff;
    border: 1px solid #176DE6;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.retail_tag {
    background: #E9AF39;
    color: #fff;
    border: 1px solid #E9AF39;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.abroad_tag {
    background: #39AFE9;
    color: #fff;
    border: 1px solid #39AFE9;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.stationery_tag {
    background: #3CBE93;
    color: #fff;
    border: 1px solid #3CBE93;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.contents_tag {
    background: #E987A8;
    color: #fff;
    border: 1px solid #E987A8;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.entertainment_tag {
    background: #DB5266;
    color: #fff;
    border: 1px solid #DB5266;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.newbusiness_tag {
    background: #26B4BE;
    color: #fff;
    border: 1px solid #26B4BE;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.shared_tag {
    background: #AE9C67;
    color: #fff;
    border: 1px solid #AE9C67;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.it_tag {
    background: #937FD7;
    color: #fff;
    border: 1px solid #937FD7;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.hd_tag {
    background: #B2B2B2;
    color: #fff;
    border: 1px solid #B2B2B2;
}

#page_news_information_article .sec_news_information_article .inner .date_box span.esg_tag {
    background: #BBF5B3;
    color: #007E67;
    border: 1px solid #BBF5B3;
}

#page_news_information_article .sec_news_information_article .inner .date_box span+span {
    margin-left: 10px;
}

#page_news_information_article .sec_news_information_article .inner h1 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
    line-height: 1.6;
}

#page_news_information_article .sec_news_information_article .inner h1:after {
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 2px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 20px auto 70px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box {
    position: relative;
    margin: 90px 0 0;
    width: 100%;
}

#page_news_information_article .sec_news_information_article .inner .inner_box h2 {
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    line-height: 1.62;
    text-indent: -2.25em;
    padding-left: 2.25em;
    margin: 70px 0 50px;
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box h2:before {
    content: '';
    display: inline-block;
    width: 22px;
    height: 22px;
    background: #004B9E;
    margin-right: .5em;
}

#page_news_information_article .sec_news_information_article .inner .inner_box h3 {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.6;
    margin-top: 50px;
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box h4 {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.6;
    margin-top: 50px;
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box p {
    margin: 30px 0 50px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box p+p {
    margin-top: -20px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box dl {
    display: flex;
    line-height: 2;
    margin: 30px 0;
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box dl+dl {
    margin-top: -20px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box dl dt {
    font-size: 16px;
    font-size: 1.6rem;
    width: 125px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box dl dd {
    font-size: 16px;
    font-size: 1.6rem;
}

#page_news_information_article .sec_news_information_article .inner .inner_box dl dd.a_hover {
    color: rgba(0, 75, 158, 0.7);
}

#page_news_information_article .sec_news_information_article .inner .inner_box a {
    font-size: 16px;
    font-size: 1.6rem;
    color: #004B9E;
    text-decoration: underline;
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box a:hover {
    color: rgba(0, 75, 158, 0.7);
    text-decoration: none;
    opacity: 1;
}

#page_news_information_article .sec_news_information_article .inner .inner_box blockquote {
    margin-top: 30px;
    border: 1px solid #ddd;
    border-radius: 6px;
    line-height: 2;
    padding: 20px;
    font-size: 16px;
    font-size: 1.6rem;
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box ol {
    list-style-type: decimal;
    padding-left: 1.5em;
    text-indent: 0em;
    line-height: 2;
    margin-top: 20px;
    font-size: 16px;
    font-size: 1.6rem;
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box ul {
    list-style-type: none;
    padding-left: 1.5em;
    text-indent: -1.2em;
    line-height: 2;
    margin-top: 20px;
    font-size: 16px;
    font-size: 1.6rem;
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box ul li:before {
    content: '';
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 100%;
    background: #000;
    margin-right: .5em;
}

#page_news_information_article .sec_news_information_article .inner .inner_box figure {
    display: table;
}

#page_news_information_article .sec_news_information_article .inner .inner_box figure.pict_large {
    margin: 0 0 40px 0;
}

#page_news_information_article .sec_news_information_article .inner .inner_box figure.pict_left {
    float: left;
    margin: 0 40px 25px 0;
}

#page_news_information_article .sec_news_information_article .inner .inner_box figure.pict_right {
    float: right;
    margin: 0 0 25px 40px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box figure figcaption {
    font-size: 14px;
    font-size: 1.4rem;
    display: table-caption;
    caption-side: bottom;
    width: 100%;
    margin-top: 15px;
    line-height: 1.57;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table {
    font-size: 16px;
    font-size: 1.6rem;
    border-collapse: separate;
    border-spacing: 0;
    table-layout: fixed;
    /* width: 100%; */
    clear: both;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr th {
    color: #fff;
    background: #004B9E;
    vertical-align: middle;
    font-weight: 700;
    text-align: center;
    border-bottom: 1px solid #ddd;
    border-collapse: separate;
    border-spacing: 0;
    padding: 15px;
    min-width: 150px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr th:last-child {
    border: none;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr td {
    vertical-align: middle;
    border-right: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    border-collapse: separate;
    border-spacing: 0;
    text-align: justify;
    line-height: 1.3;
    padding: 15px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr td p {
    margin: 0;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr:first-child th {
    border-radius: 6px 0 0 0;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr:first-child td {
    border-top: 1px solid #ddd;
    border-collapse: separate;
    border-spacing: 0;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr:first-child td:last-child {
    border-radius: 0 6px 0 0;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr:last-child th {
    border-radius: 0 0 0 6px;
}

#page_news_information_article .sec_news_information_article .inner .inner_box table tr:last-child td:last-child {
    border-radius: 0 0 6px 0;
}

#page_news_information_article .sec_news_information_article .inner a.btn {
    display: inline-block;
    position: relative;
    padding: 24px 40px 26px 70px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 120px;
    border: 2px solid #004B9E;
    color: #004B9E;
    text-decoration: none;
    left: 50%;
    transform: translateX(-50%);
}

#page_news_information_article .sec_news_information_article .inner a.btn:before {
    content: '';
    position: absolute;
    display: block;
    width: 10px;
    height: 10px;
    border-top: 2px solid #004B9E;
    border-left: 2px solid #004B9E;
    top: 50%;
    left: 40px;
    transform: translateY(-50%) rotate(-45deg);
}

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

 ir　ページ

-------------------------------- */
#page_ir {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_ir .sec_irList {
    padding: 160px 0 230px;
}

#page_ir .sec_irList .sec_ttl {
    margin-bottom: 85px;
}

#page_ir .sec_irList .sec_ttl h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
}

#page_ir .sec_irList .sec_ttl h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_ir .sec_irList .sec_ttl h2 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_ir .sec_irList .content_box {
    display: flex;
    flex-wrap: wrap;
}

#page_ir .sec_irList .content_box li {
    width: 33.33%;
    height: 400px;
    background: #fff;
    border-bottom: 2px solid #fff;
    box-sizing: border-box;
}

#page_ir .sec_irList .content_box li a {
    height: 100%;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
}

#page_ir .sec_irList .content_box li a .img_box {
    height: 50%;
    width: 100%;
    overflow: hidden;
    position: relative;
}

#page_ir .sec_irList .content_box li a .img_box img {
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    max-width: inherit;
    position: relative;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
}

#page_ir .sec_irList .content_box li a .txt_box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    height: 50%;
    width: 100%;
    background: #004B9E;
}

#page_ir .sec_irList .content_box li a .txt_box span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 600;
    color: #004B9E;
    padding: 15px 35px;
    min-width: 233px;
    background: #fff;
    border-radius: 35px;
    z-index: 1;
}

#page_ir .sec_irList .content_box li:nth-child(3n-1) {
    border-right: 2px solid #fff;
    border-left: 2px solid #fff;
}


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

 shareholders　ページ

-------------------------------- */
#page_shareholders {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_shareholders .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/shareholders/mv.png) top center no-repeat;
    background-size: cover;
}

#page_shareholders .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_shareholders .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_shareholders .hero:after {
    content: '';
    display: none;
}

#page_shareholders .lead_wrap {
    width: 1100px;
    margin: auto;
    padding: 120px 0 75px;
}

#page_shareholders .lead_wrap p {
    font-size: 16px;
    font-size: 1.6rem;
    text-align: center;
}

#page_shareholders .sec_shareholders {
    padding: 0;
}

#page_shareholders .sec_shareholders .sec_ttl {
    margin-bottom: 65px;
}

#page_shareholders .sec_shareholders .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_shareholders .sec_shareholders .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_shareholders .sec_shareholders .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_shareholders .sec_shareholders .inner {
    padding: 10px 0 80px;
}

#page_shareholders .sec_shareholders .inner dl {
    display: flex;
    justify-content: space-between;
    line-height: 2;
    text-align: justify;
}

#page_shareholders .sec_shareholders .inner dl dt {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 140px;
    font-weight: 700;
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    background: #004B9E;
}

#page_shareholders .sec_shareholders .inner dl dd {
    width: 960px;
    padding: 30px 50px;
    border: 1px solid #ddd;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_shareholders .sec_shareholders .inner dl dd a {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #004B9E;
    text-decoration: underline;
}

#page_shareholders .sec_shareholders .inner dl dd a+a {
    margin-top: 10px;
}

#page_shareholders .sec_shareholders .inner dl dd p {
    margin: 20px 0;
    text-indent: -1em;
    padding-left: 1em;
}

#page_shareholders .sec_shareholders .inner dl.dl_single dd p {
    margin: 20px 0 0;
    text-indent: -1em;
    padding-left: 1em;
}

#page_shareholders .sec_shareholders .inner dl dd p + p,
#page_shareholders .sec_shareholders .inner dl.dl_single dd p + p {
    text-indent: 0em;
    padding-left: 0em;
}

#page_shareholders .sec_shareholders .inner dl:first-child dt {
    border-radius: 6px 0 0 0;
    border-bottom: 1px solid #ddd;
}

#page_shareholders .sec_shareholders .inner dl:first-child dd {
    border-radius: 0 6px 0 0;
}

#page_shareholders .sec_shareholders .inner dl:last-child dt {
    border-radius: 0 0 0 6px;
}

#page_shareholders .sec_shareholders .inner dl:last-child dd {
    border-radius: 0 0 6px 0;
}

#page_shareholders .sec_shareholders .inner dl+dl dd {
    border-top: none;
}

#page_shareholders .sec_shareholders:last-of-type {
    margin-bottom: 85px;
}

#page_shareholders .sec_shareholders .inner dl.dl_single dt {
    border-radius: 6px 0 0 6px;
}

#page_shareholders .sec_shareholders .inner dl.dl_single dd {
    border-radius: 0 6px 6px 0;
}

#page_shareholders .note_wrap {
    margin-bottom: 230px;
}

#page_shareholders .note_wrap .inner {
    margin: auto;
    background: #eee;
    padding: 40px 50px;
    border-radius: 6px;
}

#page_shareholders .note_wrap .inner p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_shareholders .note_wrap .inner img {
    width: 159px;
    height: 39px;
    margin-top: 30px;
    left: 50%;
    position: relative;
    transform: translateX(-50%);
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_shareholders .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/shareholders/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 financial_results　ページ

-------------------------------- */
#page_financial_results {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_financial_results .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/financial_results/mv.png) top center no-repeat;
    background-size: cover;
}

#page_financial_results .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_financial_results .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_financial_results .hero:after {
    content: '';
    display: none;
}

#page_financial_results .sec_financial_results {
    padding: 160px 0 0;
}

#page_financial_results .sec_financial_results .sec_ttl {
    margin-bottom: 65px;
}

#page_financial_results .sec_financial_results .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_financial_results .sec_financial_results .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_financial_results .sec_financial_results .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_financial_results .sec_financial_results .inner {
    padding: 10px 0 20px;
}

#page_financial_results .sec_financial_results .inner table {
    font-size: 16px;
    font-size: 1.6rem;
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

#page_financial_results .sec_financial_results .inner table thead tr td {
    color: #fff;
    background: #004B9E;
    height: 70px;
    width: 550px;
    vertical-align: middle;
    font-weight: 700;
    border: none;
}

#page_financial_results .sec_financial_results .inner table thead tr td:first-child {
    border-radius: 6px 0 0 0;
    border: none;
}

#page_financial_results .sec_financial_results .inner table thead tr td:last-child {
    border-radius: 0 6px 0 0;
}

#page_financial_results .sec_financial_results .inner table thead tr td+td {
    border-left: 1px solid #ddd;
    border-collapse: separate;
    border-spacing: 0;
}

#page_financial_results .sec_financial_results .inner table tr td {
    height: 70px;
    width: 550px;
    vertical-align: middle;
    border-collapse: separate;
    border-spacing: 0;
    border-right: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
}

#page_financial_results .sec_financial_results .inner table tr td:first-child {
    font-weight: 700;
    border-left: 1px solid #ddd;
    border-collapse: separate;
    border-spacing: 0;
}

#page_financial_results .sec_financial_results .inner table tr td a {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #004B9E;
    text-decoration: underline;
}

#page_financial_results .sec_financial_results .inner table tbody tr:last-child td:first-child {
    border-radius: 0 0 0 6px;
}

#page_financial_results .sec_financial_results .inner table tbody tr:last-child td:last-child {
    border-radius: 0 0 6px 0;
}

#page_financial_results .sec_financial_results .inner table thead tr:first-child td:first-child {
    border-radius: 6px 0 0 0;
}

#page_financial_results .sec_financial_results .inner table thead tr:first-child td:last-child {
    border-radius: 0 6px 0 0;
}


#page_financial_results .sec_transition {
    padding: 60px 0 0;
    margin-bottom: 65px;
}

#page_financial_results .sec_transition .sec_ttl {
    margin-bottom: 65px;
}

#page_financial_results .sec_transition .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_financial_results .sec_transition .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_financial_results .sec_transition .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_financial_results .sec_transition .inner {
    padding: 10px 0 20px;
}

#page_financial_results .sec_transition .inner h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin-bottom: 40px;
}

#page_financial_results .sec_transition .inner .unit {
    text-align: right;
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 10px;
}

#page_financial_results .sec_transition .inner table {
    font-size: 16px;
    font-size: 1.6rem;
    border-collapse: separate;
    border-spacing: 0;
}

#page_financial_results .sec_transition .inner table thead tr td {
    color: #fff;
    background: #004B9E;
    height: 50px;
    width: 182px;
    vertical-align: middle;
    font-weight: 700;
    text-align: center;
    padding: 0;
    border-right: none;
    border-bottom: none;
}

#page_financial_results .sec_transition .inner table thead tr td:first-child {
    border-radius: 6px 0 0 0;
    background: #004B9E;
}

#page_financial_results .sec_transition .inner table thead tr td:last-child {
    border-radius: 0 6px 0 0;
}

#page_financial_results .sec_transition .inner table thead tr td+td {
    border-left: 1px solid #ddd;
    border-collapse: separate;
    border-spacing: 0;
}

#page_financial_results .sec_transition .inner table tr td {
    height: 75px;
    width: 182px;
    vertical-align: middle;
    border-right: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    border-collapse: separate;
    border-spacing: 0;
    padding-right: 40px;
    text-align: right;
}

#page_financial_results .sec_transition .inner table tbody tr td:first-child {
    background: #E5ECF5;
    font-weight: 700;
    border-left: 1px solid #ddd;
    border-collapse: separate;
    border-spacing: 0;
    padding-right: 0;
    text-align: center;
}

#page_financial_results .sec_transition .inner table tbody tr:last-child td:first-child {
    border-radius: 0 0 0 6px;
}

#page_financial_results .sec_transition .inner table tbody tr:last-child td:last-child {
    border-radius: 0 0 6px 0;
}

#page_financial_results .sec_transition .inner table thead tr:first-child td:first-child {
    border-radius: 6px 0 0 0;
}

#page_financial_results .sec_transition .inner table thead tr:first-child td:last-child {
    border-radius: 0 6px 0 0;
}

#page_financial_results .sec_transition .inner table tbody tr:first-child td:first-child {
    border-radius: 0;
}

#page_financial_results .sec_transition .inner table tbody tr:first-child td:last-child {
    border-radius: 0;
}

#page_financial_results .sec_transition .inner .link_wrap {
    text-align: justify;
    line-height: 2;
}

#page_financial_results .sec_transition .inner .link_wrap .link_box {
    margin: 30px 0 40px;
}

#page_financial_results .sec_transition .inner .link_wrap .link_box a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #004B9E;
    text-decoration: underline;
    margin-top: 5px;
}

#page_financial_results .note_wrap {
    margin-bottom: 230px;
}

#page_financial_results .note_wrap .inner {
    margin: auto;
    background: #eee;
    padding: 40px 50px;
    border-radius: 6px;
}

#page_financial_results .note_wrap .inner p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_financial_results .note_wrap .inner img {
    width: 159px;
    height: 39px;
    margin-top: 30px;
    left: 50%;
    position: relative;
    transform: translateX(-50%);
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_financial_results .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/financial_results/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 public_notice　ページ

-------------------------------- */
#page_public_notice {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_public_notice .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/public_notice/mv.png) top center no-repeat;
    background-size: cover;
}

#page_public_notice .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_public_notice .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_public_notice .hero:after {
    content: '';
    display: none;
}

#page_public_notice .sec_public_notice {
    padding: 130px 0 55px;
}

#page_public_notice .sec_public_notice .inner {
    padding: 10px 0 75px;
}

#page_public_notice .sec_public_notice .inner p {
    font-size: 14px;
    font-size: 1.4rem;
    text-align: center;
}

#page_public_notice .sec_public_notice .inner .inner_box {
    margin: 100px auto;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_public_notice .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/public_notice/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

#page_public_notice .btn_pdf {
    text-decoration: underline;
    color: #004B9E;
}

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

 esg　ページ

-------------------------------- */
#page_esg {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_esg .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/csr/mv.png) top center no-repeat;
    background-size: cover;
}

#page_esg .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_esg .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #fff;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    background: #004B9E;
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_esg .hero:after {
    content: '';
    display: none;
}

#page_esg .sec_humanResources {
    padding: 160px 0 25px;
}

#page_esg .sec_humanResources .sec_ttl {
    margin-bottom: 65px;
}

#page_esg .sec_humanResources .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_esg .sec_humanResources .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_esg .sec_humanResources .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_esg .sec_humanResources .inner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

#page_esg .sec_humanResources .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 90px;
    line-height: 1.78;
    width: 100%;
}

#page_esg .sec_humanResources .inner .inner_box {
    width: 350px;
    background: #F0F7FF;
    padding: 30px;
    border-radius: 6px;
}

#page_esg .sec_humanResources .inner .inner_box img {
    margin-bottom: 30px;
}

#page_esg .sec_humanResources .inner .inner_box h5 {
    font-size: 20px;
    font-size: 2rem;
    margin-bottom: 20px;
    line-height: 1.78;
}

#page_esg .sec_humanResources .inner .inner_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_esg .sec_environment {
    padding: 175px 0 25px;
}

#page_esg .sec_environment .sec_ttl {
    margin-bottom: 65px;
}

#page_esg .sec_environment .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_esg .sec_environment .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_esg .sec_environment .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_esg .sec_environment .inner {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

#page_esg .sec_environment .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 50px;
}

#page_esg .sec_environment .inner p a {
    color: #004B9E;
    text-decoration: underline;
}

#page_esg .sec_environment .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 90px;
    line-height: 1.78;
    width: 100%;
}

#page_esg .sec_environment .inner .inner_box {
    width: 350px;
    background: #F0F7FF;
    padding: 30px;
    border-radius: 6px;
    margin-bottom: 25px;
}

#page_esg .sec_environment .inner .inner_box img {
    margin-bottom: 30px;
}

#page_esg .sec_environment .inner .inner_box h5 {
    font-size: 20px;
    font-size: 2rem;
    margin-bottom: 20px;
}

#page_esg .sec_environment .inner .inner_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 0;
}

#page_esg .sec_environment .inner .inner_box+.inner_box {
    margin-left: 25px;
}

#page_esg .sec_environment .inner .inner_box:nth-child(5) {
    margin-left: 0;
}

#page_esg .sec_socialContributions {
    padding: 175px 0 25px;
    margin-bottom: 85px;
}

#page_esg .sec_socialContributions .sec_ttl {
    margin-bottom: 65px;
}

#page_esg .sec_socialContributions .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_esg .sec_socialContributions .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_esg .sec_socialContributions .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

#page_esg .sec_socialContributions .inner {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

#page_esg .sec_socialContributions .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 50px;
}

#page_esg .sec_socialContributions .inner p a {
    color: #004B9E;
    text-decoration: underline;
}

#page_esg .sec_socialContributions .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 90px;
    line-height: 1.78;
    width: 100%;
}

#page_esg .sec_socialContributions .inner .inner_box {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    margin-bottom: 120px;
}

#page_esg .sec_socialContributions .inner .inner_box .txt_box {
    text-align: justify;
    width: 600px;
}

#page_esg .sec_socialContributions .inner .inner_box .txt_box span {
    display: inline-block;
    background: #004B9E;
    padding: 6px 15px;
    color: #fff;
    border-radius: 6px;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_esg .sec_socialContributions .inner .inner_box .txt_box h5 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 0 15px;
    letter-spacing: 0em;
    line-height: 1.78;
}

#page_esg .sec_socialContributions .inner .inner_box .txt_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 0;
}

#page_esg .sec_socialContributions .inner .inner_box:nth-child(2) .txt_box h5 {
    margin: 25px 0 15px;
    line-height: 1.78;
}




#page_esg .sec_movie .inner {
    width: 845px;
}


#page_esg .sec_movie .inner .movie {
  margin: 45px auto 0;
  width: 100%;
  position: relative;
}

#page_esg .sec_movie .inner .movie:before {
  padding-top: 474px;
  display: block;
  content: "";
}

#page_esg .sec_movie .inner .movie video {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

#page_esg .sec_movie .inner .movie__btn {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-top: .5em;
}

#page_esg .sec_movie .inner .movie__btn button {
  font-size: 14px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  appearance: none;
  cursor: pointer;

  color: inherit;
  font-family: inherit;
  box-shadow: initial;
  appearance: none;
  border: none;
  background-color: initial;
  line-height: 2;
}

#page_esg .sec_movie .inner .movie__btn button:nth-child(1) {
    background: none;
    width: 27px;
    height: 23px;
    background: url(../img/esg/icon_mute.svg) center center no-repeat;
    background-size: 27px 23px;
}

#page_esg .sec_movie .inner .movie__btn.js_on button:nth-child(1) {
    background: none;
    width: 22px;
    height: 15px;
    background: url(../img/esg/icon_vol.svg) center center no-repeat;
    background-size: 22px 15px;
}


#page_esg .sec_movie .inner .movie__btn button#on {
    color: rgba(0, 0, 0, .3);
}

#page_esg .sec_movie .inner .movie__btn.js_on button#on {
    color: #000000;
}

#page_esg .sec_movie .inner .movie__btn.js_on button#off {
    color: rgba(0, 0, 0, .3);
}

#page_esg .sec_movie .inner .movie__btn button#off {
    color: #000000;
}


@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_esg .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/csr/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 contact ページ

-------------------------------- */
#page_contact {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_contact .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/contact/mv.png) top center no-repeat;
    background-size: cover;
}

#page_contact .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_contact .hero .hero_ttl h2 {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    color: #fff;
    font-size: 35px;
    font-size: 3.5rem;
    font-weight: 700;
    width: 500px;
    height: 130px;
    background: #fff;
    color: #000;
    border-bottom: #004B9E 10px solid;
}

#page_contact .hero:after {
    content: '';
    display: none;
}






#page_contact .sec_area {
    padding: 160px 0 25px;
}

#page_contact .sec_area .sec_ttl {
    margin-bottom: 90px;
}

#page_contact .sec_area .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_contact .sec_area .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #004B9E;
}

#page_contact .sec_area .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
    margin-top: 3px;
}

#page_contact .sec_area .inner {
    width: 1100px;
}

#page_contact .sec_area .inner a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    box-sizing: border-box;
    padding: 12px 23px;
    border: none;
    border-radius: 5px;
    text-align: center;
    background: #004B9E;
}

#page_contact .sec_area .inner a+a {
    margin-left: 7px;
}

#page_contact .sec_ttlArea {
    padding: 120px 0 0;
}

#page_contact .sec_ttlArea h3 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 35px;
    line-height: 1.78;
}

#page_contact .sec_ttlArea p {
    text-align: center;
    font-size: 18px;
    font-size: 1.8rem;
}

#page_contact .sec_contact {
    padding: 160px 0 15px;
}

#page_contact .sec_contact .inner h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_contact .sec_contact .inner h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_contact .sec_contact .inner p {
    margin-top: 75px;

}

#page_contact .sec_contact .inner ul {
    margin-top: 75px;
}

#page_contact .sec_contact .inner ul li {
    display: flex;
    align-items: center;
    border-bottom: 1px solid #ddd;
}

#page_contact .sec_contact .inner ul li .tag_box {
    width: 200px;
    text-align: justify;
}

#page_contact .sec_contact .inner ul li .tag_box span {
    display: block;
    width: 170px;
    padding: 10px 0;
    text-align: center;
    color: #fff;
    border-radius: 6px;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_contact .sec_contact .inner ul li .tag_box span.agency_tag {
    background: #176DE6;
}

#page_contact .sec_contact .inner ul li .tag_box span.retail_tag {
    background: #E9AF39;
}

#page_contact .sec_contact .inner ul li .tag_box span.abroad_tag {
    background: #39AFE9;
}

#page_contact .sec_contact .inner ul li .tag_box span.stationery_tag {
    background: #3CBE93;
}

#page_contact .sec_contact .inner ul li .tag_box span.contents_tag {
    background: #E987A8;
}

#page_contact .sec_contact .inner ul li .tag_box span.entertainment_tag {
    background: #DB5266;
}

#page_contact .sec_contact .inner ul li .tag_box span.newbusiness_tag {
    background: #26B4BE;
}

#page_contact .sec_contact .inner ul li .tag_box span.shared_tag {
    background: #AE9C67;
}

#page_contact .sec_contact .inner ul li .tag_box span.it_tag {
    background: #937FD7;
}

#page_contact .sec_contact .inner ul li dl {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    line-height: 2;
    font-size: 20px;
    font-size: 2rem;
    width: 900px;
    box-sizing: border-box;
    text-align: justify;
    padding: 40px 0 0;
}

#page_contact .sec_contact .inner ul li dl dt {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    font-weight: 700;
    margin-bottom: 40px;
    width: 360px;
    box-sizing: border-box;
}

#page_contact .sec_contact .inner ul li dl dd {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 40px;
    width: 540px;
    box-sizing: border-box;
}

#page_contact .sec_contact .inner ul li dl dd span {
    font-size: 16px;
    font-size: 1.6rem;
    padding-right: 15px;
}

#page_contact .sec_contact .inner ul li dl dd a {
    display: inline-block;
    position: relative;
    padding: 17px 40px 19px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    border: 2px solid #004B9E;
    color: #004B9E;
    background: #fff;
    margin-left: auto;
    box-sizing: border-box;
}

#page_contact .sec_contact .inner ul li dl dd a.phone,
#page_contact .sec_contact .inner ul li dl dd a.mail {
    display: inline-block;
    position: relative;
    padding: 0;
    border-radius: 0;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 400;
    line-height: 1;
    border: none;
    color: #000;
    background: #fff;
    margin-left: 0;
    pointer-events: none;
}

#page_contact .sec_contact .inner ul li dl dd+dt {
    border-top: 1px solid #ddd;
    padding-top: 40px;
}

#page_contact .sec_contact .inner ul li dl dd+dt+dd {
    border-top: 1px solid #ddd;
    padding-top: 40px;
}

#page_contact .sec_contact .inner ul li:first-of-type {
    border-top: 1px solid #ddd;
}

#page_contact .sec_contact .inner ul li dl dd .tel_wrap .tel_box p {
    letter-spacing: 0;
    font-size: 16px;
    text-align: left;
    margin: 0 0 -7px 0;
    font-weight: 700;
}

#page_contact .sec_contact .inner ul li dl dd .tel_wrap .tel_box p.mailLine {
    margin: 0;
}

#page_contact .sec_contact .inner ul li dl dd .tel_wrap .tel_box p span {
    font-weight: 400;
}

#page_contact .sec_contact .inner ul li dl dd .tel_wrap .tel_box+.tel_box {
    margin-top: 10px;
}

#page_contact .sec_recruit {
    padding: 185px 0 230px;
}

#page_contact .sec_recruit .inner h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_contact .sec_recruit .inner h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_contact .sec_recruit .inner p {
    margin-top: 75px;
}

#page_contact .sec_recruit .inner p.note {
    margin-top: 35px;
}

#page_contact .sec_recruit .inner .recruit_wrap {
    display: flex;
    justify-content: space-between;
    margin-top: 75px;
}

/* #page_contact .sec_recruit .inner .recruit_wrap .recruit_box {
  background: #F0F7FF;
  width: 650px;
  height: 390px;
  padding: 60px;
} */

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box {
    background: #F0F7FF;
    width: 430px;
    /*   height: 390px; */
    padding: 60px 40px;
}

/* #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box {
  height: 170px;
  text-align: justify;
} */

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box {
    height: 230px;
    text-align: justify;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span {
    display: inline-block;
    width: 170px;
    padding: 12px 0;
    text-align: center;
    color: #fff;
    border-radius: 6px;
    margin-bottom: 10px;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.agency_tag {
    background: #176DE6;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.retail_tag {
    background: #E9AF39;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.abroad_tag {
    background: #39AFE9;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.stationery_tag {
    background: #3CBE93;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.contents_tag {
    background: #E987A8;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.entertainment_tag {
    background: #DB5266;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.newbusiness_tag {
    background: #26B4BE;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.shared_tag {
    background: #AE9C67;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.it_tag {
    background: #937FD7;
}

/* #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span + span {
  margin-left: 10px;
} */

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span+span {
    margin-left: 0;
}

/* #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span:nth-child(3n+1) {
  margin-left: 0;
} */

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box a {
    display: inline-block;
    position: relative;
    padding: 24px 37px 26px 73px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 30px;
    border: 2px solid #004B9E;
    color: #004B9E;
    background: #fff;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:nth-child(2) a,
#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child a {
    display: flex;
    align-items: center;
    position: relative;
    padding: 24px 25px 26px 58px;
    border-radius: 35px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    margin-top: 30px;
    border: 2px solid #004B9E;
    color: #004B9E;
    background: #fff;
    min-width: 200px;
    height: 70px;
    box-sizing: border-box;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:nth-child(2) a span,
#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child a span {
    text-align: justify;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 38px;
    transform: translateY(-50%);
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:nth-child(2) a:before,
#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child a:before {
    content: '';
    position: absolute;
    display: block;
    width: 20px;
    height: 18px;
    background: url(../img/common/icon_link.png) center center no-repeat;
    background-size: 20px 18px;
    top: 50%;
    left: 24px;
    transform: translateY(-50%);
}

/* #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child {
  width: 420px;
  padding: 60px 45px;
} */

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:nth-child(2) {
    width: 300px;
    padding: 60px 40px;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child {
    width: 300px;
    padding: 60px 40px;
}

/* #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child .tag_box {
  display: flex;
  align-items: center;
  justify-content: center;
} */

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:nth-child(2) .tag_box,
#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child .tag_box {
    display: flex;
    align-items: center;
    justify-content: center;
}

#page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child .tag_box span {
    margin-bottom: 0;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_contact .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/contact/mv@2x.png) top center no-repeat;
        background-size: cover;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box a:before {
        content: '';
        position: absolute;
        display: block;
        width: 20px;
        height: 18px;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 38px;
        transform: translateY(-50%);
    }
}

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

 サイトマップ　ページ

-------------------------------- */
#page_sitemap {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_sitemap .sec_sitemap {
    padding: 160px 0 210px;
}

#page_sitemap .sec_sitemap .inner h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
}

#page_sitemap .sec_sitemap .inner h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_sitemap .sec_sitemap .inner ul {
    margin-top: 50px;
    text-align: justify;
}

#page_sitemap .sec_sitemap .inner ul li {
    font-size: 16px;
    font-size: 1.6rem;
    border-radius: 6px;
    padding: 10px 20px;
}

#page_sitemap .sec_sitemap .inner ul li a {
    position: relative;
    padding: 0 0 2px 15px;
    line-height: 1.6;
}

#page_sitemap .sec_sitemap .inner ul li a:before {
    content: '';
    display: block;
    position: absolute;
    width: 5px;
    height: 5px;
    top: 50%;
    left: 0px;
    border-top: 2px solid #004B9E;
    border-right: 2px solid #004B9E;
    transform: translateY(-50%) rotate(45deg);
}

#page_sitemap .sec_sitemap .inner ul li a+a {
    padding-left: 35px;
    margin-top: 10px;
    display: block;
}

#page_sitemap .sec_sitemap .inner ul li a+a:before {
    content: '';
    display: block;
    position: absolute;
    width: 10px;
    height: 3px;
    top: 50%;
    left: 15px;
    border: none;
    background: #004B9E;
    transform: translateY(-60%) rotate(0deg);
}

#page_sitemap .sec_sitemap .inner ul li:first-child {
    background: #004B9E;
    padding: 7px 20px 8px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 20px;
}

#page_sitemap .sec_sitemap .inner ul li:first-child a {
    font-size: 20px;
    font-size: 2rem;
    color: #fff;
    padding-left: 30px;
    line-height: 1.78;
}

#page_sitemap .sec_sitemap .inner ul li:first-child a:before {
    content: '';
    display: block;
    position: absolute;
    width: 10px;
    height: 10px;
    top: 50%;
    left: 0px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: translateY(-50%) rotate(45deg);
}

#page_sitemap .sec_sitemap .inner ul li:first-child span {
    font-size: 16px;
    font-size: 1.6rem;
    margin-left: 1.5em;
}

#page_sitemap .sec_sitemap .inner ul:first-of-type {
    margin-top: 75px;
}

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

 プライバシーポリシー　ページ

-------------------------------- */
#page_privacy {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_privacy .sec_privacy {
    padding: 160px 0 0;
}

#page_privacy .sec_privacy .sec_ttl {
    margin-bottom: 65px;
}

#page_privacy .sec_privacy .sec_ttl h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
}

#page_privacy .sec_privacy .sec_ttl h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_privacy .sec_privacy .inner {
    padding: 10px 0 230px;
}

#page_privacy .sec_privacy .inner .txt_wrap p {
    text-align: justify;
}

#page_privacy .sec_privacy .inner .txt_wrap ul {
    text-align: justify;
    margin-top: 85px;
}

#page_privacy .sec_privacy .inner .txt_wrap ul li {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
    text-indent: -2em;
    padding-left: 2em;
}

#page_privacy .sec_privacy .inner .txt_wrap ul li+li {
    margin-top: 40px;
}

#page_privacy .sec_privacy .inner .txt_wrap .date_box {
    margin-top: 70px;
}

#page_privacy .sec_privacy .inner .txt_wrap .date_box p {
    text-align: right;
}

#page_privacy .sec_privacy .inner .txt_wrap .signature_box {
    margin-top: 30px;
}

#page_privacy .sec_privacy .inner .txt_wrap .signature_box p {
    text-align: right;
}

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

 ウェブアクセシビリティポリシー　ページ

-------------------------------- */
#page_accessibility {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_accessibility .sec_accessibility {
    padding: 160px 0 0;
}

#page_accessibility .sec_accessibility .sec_ttl {
    margin-bottom: 65px;
}

#page_accessibility .sec_accessibility .sec_ttl h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
}

#page_accessibility .sec_accessibility .sec_ttl h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_accessibility .sec_accessibility .inner {
    padding: 10px 0 180px;
}

#page_accessibility .sec_accessibility .inner + .inner {
    padding-bottom: 230px;
}


#page_accessibility .sec_accessibility .inner .txt_wrap p {
    text-align: justify;
}

#page_accessibility .sec_accessibility .inner .txt_wrap .date_box {
    margin-top: 70px;
}

#page_accessibility .sec_accessibility .inner .txt_wrap .date_box p {
    text-align: right;
}

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

 search ページ

-------------------------------- */
body.search {
    padding: 100px 0 0;
}

body.search .sec_searchList {
    padding: 160px 0 155px;
}

body.search .sec_searchList .sec_ttl {
    margin-bottom: 65px;
}

body.search .sec_searchList .sec_ttl h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 700;
}

body.search .sec_searchList .sec_ttl h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

body.search .sec_searchList .sec_ttl h2 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
}

body.search .sec_searchList .inner {
    padding: 10px 0 75px;
}

body.search .sec_searchList .inner p {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
}

body.search .sec_searchList .inner .inner_box {
    margin: 0 auto !important;
}

body.search .sec_searchList .inner .inner_box .result_wrap {
    margin-bottom: 55px;
}

body.search .sec_searchList .inner .inner_box .result_wrap p {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
    margin-top: 0;
    text-align: center !important;
}

body.search .sec_searchList .inner .inner_box form {
    position: relative;
    padding: 0;
    width: 100%;
}

body.search .sec_searchList .inner .inner_box form input[type="text"] {
    width: 100%;
    padding: 19px 110px 19px 30px;
    box-sizing: border-box;
    border: none;
    border-radius: 40px;
    font-size: 16px;
    font-size: 1.6rem;
    border: 1px solid #ddd;
}

body.search .sec_searchList .inner .inner_box form input[type="submit"] {
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px;
    border: none;
    width: 30px;
    height: 30px;
    background: url(../img/common/icon_search.svg) no-repeat 0 0;
    background-size: 30px 30px;
    cursor: pointer;
}

body.search .sec_searchList .inner .inner_box form .clear {
    position: absolute;
    right: 85px;
    top: 50%;
    transform: translateY(-50%);
    background-color: #fff;
    border-style: none;
    outline: none;
}

body.search .sec_searchList .inner .inner_box form .clear:before {
    content: '';
    display: block;
    width: 18px;
    height: 2px;
    background: #000;
    transform: rotate(45deg);
    position: absolute;
}

body.search .sec_searchList .inner .inner_box form .clear:after {
    content: '';
    display: block;
    width: 18px;
    height: 2px;
    background: #000;
    transform: rotate(-45deg);
    position: absolute;
}

body.search .sec_searchList .inner .result_box .result_note {
    margin-top: 70px;
}

body.search .sec_searchList .inner .result_box ul li {
    padding: 70px 0;
    border-bottom: 1px solid #ddd;
}

body.search .sec_searchList .inner .result_box ul li dl {
    text-align: justify;
}

body.search .sec_searchList .inner .result_box ul li dl dt {
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 700;
    margin-bottom: 25px;
    line-height: 1.62;
}

body.search .sec_searchList .inner .result_box ul li dl dd {
    margin-bottom: 5px;
}

body.search .sec_searchList .inner .result_box ul li dl dd p {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
    margin-bottom: 25px;
    text-align: justify !important;
}

body.search .sec_searchList .inner .result_box ul li dl dd p span {
    font-weight: 700;
}

body.search .sec_searchList .inner .result_box ul li dl dd a {
    font-size: 16px;
    font-size: 1.6rem;
    color: #004B9E;
    text-decoration: underline;
}

body.search .sec_searchList .inner .result_box ul li dl dd a:hover {
    color: rgba(0, 75, 158, 0.7);
    text-decoration: none;
    opacity: 1;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    body.search .sec_searchList .inner .inner_box form input[type="submit"] {
        display: block;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 30px;
        border: none;
        width: 30px;
        height: 30px;
        background: url(../img/common/icon_search.svg) no-repeat 0 0;
        background-size: 30px 30px;
        cursor: pointer;
    }
}

.no-results {
    margin-top: 40px;
}


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

    /* =========================================================
  section
  ========================================================= */
    section {
        text-align: center;
        padding: 16vw 0;
    }

    .inner {
        max-width: 100%;
        padding: 0 3.47vw;
    }

    /* =========================================================
  #hero
========================================================= */
    #hero {
        position: relative;
        padding: 0;
        height: auto;
        bottom: 0;
        left: 0;
        margin-top: 16vw;
    }

    #hero #loading {
        background: #fff;
        width: 100%;
        height: 100vh;
        position: absolute;
        z-index: 100;
        top: 50%;
        transform: translateY(-50%);
    }

    #hero #loading img {
        width: 8vw;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        position: absolute;
    }

    #hero #hero_movie {
        display: none;
    }

    #hero #hero_bg {
        opacity: 0;
    }

    #hero #hero_bg_sp {
        opacity: 1;
    }

    #hero .slider_wrap {
        display: block;
        /* height: 100%; */
        padding: 0;
    }

    #hero .slider_wrap .slider_top.slick-slider {
        /* height: 100%; */
        padding: 0;
    }

    #hero .slider_wrap .slider_top.slick-slider .slick-list {
        /* height: 100%; */
    }

    #hero .slider_wrap .slider_top.slick-slider .slick-list .slick-track {
        /* height: 100%; */
    }

    #hero .slider_wrap .slider_top.slick-slider .slick-list .slick-track .slide.slick-slide {
        /* height: 100%; */
    }

    #hero .slider_wrap .slider_top.slick-slider .slick-list .slick-track .slide.slick-slide img {
        /* height: 100%; */
        position: relative;
        left: 50%;
        transform: translateX(-50%);
        width: 100%;
    }

    #hero a {
        display: flex;
        align-items: center;
        justify-content: center;
        position: absolute;
        bottom: 5%;
        right: 10px;
        width: 25vw;
        height: 11.2vw;
        font-size: 3.2vw;
        font-weight: 700;
        background: #004B9E;
        color: #fff;
        border-radius: 100px;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {}

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

    /* =========================================================
  #news
========================================================= */
    #news .sec_ttl span {
        position: relative;
        font-family: "Cinzel", serif;
        font-size: 3.2vw;
        letter-spacing: .12em;
        margin-bottom: 4.33vw;
        line-height: 3;
        /* letter-spacing: normal; */
    }

    #news .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 14.67vw 9.87vw;
        width: 14.67vw;
        height: 9.87vw;
    }

    #news .sec_ttl h2 {
        font-size: 6.4vw;
        font-weight: 700;
        line-height: 1.78;
    }

    #news .inner {
        width: 100%;
    }

    #news .inner a.btn {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 3.73vw;
        font-weight: 700;
        border: 2px solid #004B9E;
        border-radius: 100px;
        width: 92vw;
        height: 16vw;
        text-align: center;
        margin: auto;
        color: #004B9E;
        margin: 5.67vw auto 0;
        /* letter-spacing: 0em; */
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #news .sec_ttl span {
        position: relative;
        font-family: "Cinzel", serif;
        font-size: 3.2vw;
        letter-spacing: .12em;
        margin-bottom: 4.33vw;
        line-height: 3;
    }

    #news .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl@2x.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 14.67vw 9.87vw;
        width: 14.67vw;
        height: 9.87vw;
    }
}

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

    /* =========================================================
  #about
========================================================= */
    #about .sec_ttl span {
        position: relative;
        font-family: "Cinzel", serif;
        font-size: 3.2vw;
        letter-spacing: .12em;
        margin-bottom: 4.33vw;
        line-height: 3;
        /* letter-spacing: normal; */
    }

    #about .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 14.67vw 9.87vw;
        width: 14.67vw;
        height: 9.87vw;
    }

    #about .sec_ttl h2 {
        font-size: 6.4vw;
        font-weight: 700;
        line-height: 1.78;
    }

    #about .link_box {
        display: flex;
        flex-wrap: wrap;
        margin-top: 15vw;
    }

    #about .link_box li {
        width: 100%;
        height: 90.13vw;
        background: #004B9E;
        box-sizing: border-box;
        position: relative;
    }

    #about .link_box li .img_box {
        width: 100%;
        height: 100%;
        overflow: hidden;
        position: relative;
    }

    #about .link_box li .img_box img {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%, 0);
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
        max-width: inherit;
    }

    #about .link_box li .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: 100%;
        width: 100%;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    #about .link_box li .txt_box p {
        font-size: 3.73vw;
        font-weight: 700;
        color: #fff;
        width: 100%;
        margin-bottom: 4vw;
        line-height: 1;
        line-height: 1.7;
    }

    #about .link_box li .txt_box a {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 58.13vw;
        box-sizing: border-box;
    }

    #about .link_box li .txt_box span {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 58.13vw;
        box-sizing: border-box;
    }

    #about .link_box li:nth-child(2) {
        border-right: none;
        order: 0;
    }

    #about .link_box li:nth-child(2) .img_box {
        background-image: url(../img/common/frame01.png), url(../img/common/frame02.png), url(../img/common/frame03.png), url(../img/common/frame04.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 12.8vw 12.8vw;
        background-repeat: no-repeat;
    }

    #about .link_box li:nth-child(2) .txt_box p {
        font-size: 4.27vw;
    }

    /* 210913 経営理念土屋　ここから */
    /* #about .link_box li:last-child {
    order: 1;
    border-top: 2px solid #fff;
    border-right: none;
    background: #f2f2f2;
  } */

    #about .link_box li {
        border-right: none;
        background: #f2f2f2;
    }

    /* 210913 経営理念土屋　ここまで */
    #about .link_box li:last-child .img_box {
        background-image: url(../img/common/frame_blue01.png), url(../img/common/frame_blue02.png), url(../img/common/frame_blue03.png), url(../img/common/frame_blue04.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 12.8vw 12.8vw;
        background-repeat: no-repeat;
    }

    #about .link_box li:last-child .txt_box p {
        font-size: 4.27vw;
    }

    #about .link_box li:first-child {
        width: 100%;
        height: 90.13vw;
        display: flex;
        justify-content: center;
        align-items: center;
        box-sizing: border-box;
        position: relative;
    }

    #about .link_box li:first-child .img_box {
        width: 100%;
        height: 100%;
        overflow: hidden;
        border-bottom: solid 2px #fff;
        position: relative;
    }

    #about .link_box li:first-child .img_box img {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%, 0);
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
        max-width: inherit;
    }

    #about .link_box li:first-child .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: 100%;
        width: 100%;
        position: absolute;
        left: 0;
        transform: translateY(-50%);
    }

    #about .link_box li:first-child .txt_box p {
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        width: 100%;
        margin: 4vw 0 0;
        line-height: 1.7;
    }

    #about .link_box li:first-child .txt_box span {
        left: 0;
        font-size: 4.27vw;
        padding: 4.67vw 12vw;
        border-radius: 100px;
    }


    #about .link_box li:first-child .txt_box a {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 58.13vw;
        box-sizing: border-box;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #about .sec_ttl span {
        position: relative;
        font-family: "Cinzel", serif;
        font-size: 3.2vw;
        letter-spacing: .12em;
        margin-bottom: 4.33vw;
        line-height: 3;
    }

    #about .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl@2x.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 14.67vw 9.87vw;
        width: 14.67vw;
        height: 9.87vw;
    }

    #about .link_box li:nth-child(2) .img_box {
        background-image: url(../img/common/frame01@2x.png), url(../img/common/frame02@2x.png), url(../img/common/frame03@2x.png), url(../img/common/frame04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 12.8vw 12.8vw;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここから */
    /* #about .link_box li:last-child .img_box {
    background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
    background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
    background-size: 12.8vw 12.8vw;
    background-repeat: no-repeat;
  } */
    #about .link_box li .img_box {
        background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 12.8vw 12.8vw;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここまで */
}

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

    /* =========================================================
  #business
========================================================= */
    #business {
        padding-bottom: 38.4vw;
    }

    #business .sec_ttl {
        padding: 0 3.47vw;
    }

    #business .sec_ttl span {
        position: relative;
        font-family: "Cinzel", serif;
        font-size: 3.2vw;
        letter-spacing: .12em;
        margin-bottom: 4.33vw;
        line-height: 3;
        /* letter-spacing: normal; */
    }

    #business .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 14.67vw 9.87vw;
        width: 14.67vw;
        height: 9.87vw;
    }

    #business .sec_ttl h2 {
        font-size: 6.4vw;
        font-weight: 700;
        line-height: 1.78;
    }

    #business .sec_ttl p {
        margin-top: 8vw;
        font-size: 3.73vw;
        text-align: justify;
    }

    #business .content_box {
        display: flex;
        flex-wrap: wrap;
        margin-top: 60px;
    }

    #business .content_box li {
        width: 100%;
        height: auto;
        background: #fff;
        border-bottom: 2px solid #fff;
        box-sizing: border-box;
    }

    #business .content_box li a {
        height: 100%;
        width: 100%;
        display: flex;
        flex-wrap: wrap;
    }

    #business .content_box li a .img_box {
        height: auto;
        width: 100%;
        overflow: hidden;
        position: relative;
    }

    #business .content_box li a .img_box img {
        width: 100%;
        position: relative;
        top: 0;
        left: 0;
        transform: none;
    }

    #business .content_box li a .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: auto;
        padding: 10.67vw 0;
    }

    #business .content_box li a .txt_box p {
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        width: 100%;
        margin-bottom: 5vw;
    }

    #business .content_box li a .txt_box span.btn {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        width: 58.13vw;
        height: 15.47vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
    }

    #business .content_box li:first-child {
        width: 100%;
        height: auto;
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-direction: column;
    }

    #business .content_box li:first-child a {
        height: 100%;
    }

    #business .content_box li:first-child a:hover {
        opacity: .7;
    }

    #business .content_box li:first-child a .img_box {
        width: 100%;
        height: auto;
        overflow: hidden;
    }

    #business .content_box li:first-child a .img_box img {
        width: 100%;
        height: auto;
        top: 0;
        left: 0;
        transform: none;
    }

    #business .content_box li:first-child a .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: auto;
        width: 100%;
        padding: 10.67vw 0;
        position: relative;
    }

    #business .content_box li:first-child a .txt_box p {
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        width: auto;
        margin-bottom: 5vw;
    }

    #business .content_box li:first-child a .txt_box span.btn {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        width: 58.13vw;
        height: 15.47vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
    }

    #business .content_box li:first-child a:hover .txt_box span.btn {
        opacity: .7;
    }

    #business .content_box li:nth-child(3n) {
        border-right: none;
        border-left: none;
    }

    #business .csr_box {
        display: flex;
        margin: 8vw auto 0;
        justify-content: space-between;
        align-self: center;
        flex-wrap: wrap;
        width: 100%;
        padding: 0 3.47vw;
    }

    #business .csr_box li {
        width: 100%;
        height: auto;
        position: relative;
        overflow: hidden;
        margin-bottom: 8vw;
    }

    #business .csr_box li a {
        height: 100%;
        display: block;
    }

    #business .csr_box li a img {
        width: 100%;
    }

    #business .csr_box li a span {
        display: flex;
        align-items: center;
        justify-content: center;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        width: 58.13vw;
        height: 15.47vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        position: absolute;
    }

    #business .csr_box li a:hover span {
        opacity: .7;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #business .sec_ttl span {
        position: relative;
        font-family: "Cinzel", serif;
        font-size: 3.2vw;
        letter-spacing: .12em;
        margin-bottom: 4.33vw;
        line-height: 3;
    }

    #business .sec_ttl span:after {
        content: '';
        position: absolute;
        background: url(../img/top/bg_ttl@2x.png) center center no-repeat;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: -1;
        background-size: 14.67vw 9.87vw;
        width: 14.67vw;
        height: 9.87vw;
    }
}

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

    /* --------------------------------
  
   company　ページ
  
  -------------------------------- */
    #page_company {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_company .sec_companyList {
        padding: 21.33vw 0 38vw;
    }

    #page_company .sec_companyList .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_company .sec_companyList .sec_ttl h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_company .sec_companyList .sec_ttl h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_company .sec_companyList .sec_ttl h2 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_company .sec_companyList .main_box {
        display: flex;
        flex-wrap: wrap;
        margin-top: 15vw;
    }

    #page_company .sec_companyList .main_box li {
        width: 100%;
        height: 90.13vw;
        background: #004B9E;
        box-sizing: border-box;
        position: relative;
    }

    #page_company .sec_companyList .main_box li .img_box {
        width: 100%;
        height: 100%;
        overflow: hidden;
        position: relative;
    }

    #page_company .sec_companyList .main_box li .img_box img {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%, 0);
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
        max-width: inherit;
    }

    #page_company .sec_companyList .main_box li .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: 100%;
        width: 100%;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    #page_company .sec_companyList .main_box li .txt_box p {
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        width: 100%;
        margin-bottom: 4vw;
        line-height: 1;
        line-height: 1.7;
    }

    #page_company .sec_companyList .main_box li .txt_box a {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 56vw;
        box-sizing: border-box;
    }

    #page_company .sec_companyList .main_box li .txt_box span {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 56vw;
        box-sizing: border-box;
    }

    #page_company .sec_companyList .main_box li:nth-child(2) {
        border-right: none;
        order: 0;
    }

    #page_company .sec_companyList .main_box li:nth-child(2) .img_box {
        background-image: url(../img/common/frame01.png), url(../img/common/frame02.png), url(../img/common/frame03.png), url(../img/common/frame04.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 12.8vw 12.8vw;
        background-repeat: no-repeat;
    }

    #page_company .sec_companyList .main_box li:nth-child(2) .txt_box p {
        font-size: 4.27vw;
    }

    /* 210913 経営理念土屋　ここから */
    /* #page_company .sec_companyList .main_box li:last-child {
      order: 1;
      border-top: 2px solid #fff;
      background: #f2f2f2;
    } */
    #page_company .sec_companyList .main_box li {
        background: #f2f2f2;
    }

    /* #page_company .sec_companyList .main_box li:last-child .img_box {
      background-image: url(../img/common/frame_blue01.png), url(../img/common/frame_blue02.png), url(../img/common/frame_blue03.png), url(../img/common/frame_blue04.png);
      background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
      background-size: 12.8vw 12.8vw;
      background-repeat: no-repeat;
    } */
    #page_company .sec_companyList .main_box li .img_box {
        background-image: url(../img/common/frame_blue01.png), url(../img/common/frame_blue02.png), url(../img/common/frame_blue03.png), url(../img/common/frame_blue04.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 12.8vw 12.8vw;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここまで */
    #page_company .sec_companyList .main_box li:last-child .txt_box p {
        font-size: 4.27vw;
    }

    #page_company .sec_companyList .main_box li:first-child {
        width: 100%;
        height: 90.13vw;
        display: flex;
        justify-content: center;
        align-items: center;
        box-sizing: border-box;
        position: relative;
    }

    #page_company .sec_companyList .main_box li:first-child .img_box {
        width: 100%;
        height: 100%;
        overflow: hidden;
        border-bottom: solid 2px #fff;
        position: relative;
    }

    #page_company .sec_companyList .main_box li:first-child .img_box img {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%, 0);
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
        max-width: inherit;
    }

    #page_company .sec_companyList .main_box li:first-child .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: 100%;
        width: 100%;
        position: absolute;
        left: 0;
        transform: translateY(-50%);
    }

    #page_company .sec_companyList .main_box li:first-child .txt_box p {
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        width: 100%;
        margin: 4vw 0 0;
        line-height: 1.7;
    }

    #page_company .sec_companyList .main_box li:first-child .txt_box span {
        left: 0;
        font-size: 4.27vw;
        padding: 4.67vw 12vw;
        border-radius: 100px;
    }

    #page_company .sec_companyList .main_box li:first-child .txt_box a {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 56vw;
        box-sizing: border-box;
    }

    #page_company .sec_companyList .sub_box {
        display: flex;
        flex-wrap: wrap;
        margin-top: 0;
    }

    #page_company .sec_companyList .sub_box li {
        width: 100%;
        height: auto;
        background: #004B9E;
        border-bottom: 2px solid #fff;
        box-sizing: border-box;
    }

    #page_company .sec_companyList .sub_box li .img_box {
        height: auto;
        width: 100%;
        overflow: hidden;
        position: relative;
    }

    #page_company .sec_companyList .sub_box li .img_box img {
        width: 100%;
        position: relative;
        top: 0;
        left: 0;
        transform: none;
    }

    #page_company .sec_companyList .sub_box li .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: auto;
        padding: 10.67vw 0;
    }

    #page_company .sec_companyList .sub_box li .txt_box p {
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        width: 100%;
        margin-bottom: 4vw;
    }

    #page_company .sec_companyList .sub_box li .txt_box span {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 56vw;
        box-sizing: border-box;
    }

    #page_company .sec_companyList .sub_box li a .txt_box span {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 56vw;
        box-sizing: border-box;
    }

    #page_company .sec_companyList .sub_box li:nth-child(2) .txt_box span {
        padding: 4.7vw 6vw;
        letter-spacing: 0em;
    }

    #page_company .sec_companyList .sub_box li:nth-child(3n-1) {
        border-right: none;
        border-left: none;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_company .sec_companyList .main_box li:nth-child(2) .img_box {
        background-image: url(../img/common/frame01@2x.png), url(../img/common/frame02@2x.png), url(../img/common/frame03@2x.png), url(../img/common/frame04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 12.8vw 12.8vw;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここから */
    /* #page_company .sec_companyList .main_box li:last-child .img_box {
      background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
      background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
      background-size: 12.8vw 12.8vw;
      background-repeat: no-repeat;
    } */
    #page_company .sec_companyList .main_box li .img_box {
        background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 12.8vw 12.8vw;
        background-repeat: no-repeat;
    }

    /* 210913 経営理念土屋　ここまで */
}

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

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

 message　ページ

-------------------------------- */
    #page_message {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_message .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/message/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_message .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_message .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_message .hero:after {
        content: '';
        display: none;
    }

    #page_message .sec_message {
        padding: 21.33vw 0 16vw;
    }

    #page_message .sec_message + .sec_message  {
        padding-top: 4vw;
    }

    #page_message .sec_message .sec_ttl {
        margin-bottom: 8vw;
    }

    #page_message .sec_message .sec_ttl h3 {
        position: relative;
        font-size: 5.87vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin: 0 0 8vw 0;
        line-height: 1.6;
        letter-spacing: normal;
    }

    #page_message .sec_message .sec_ttl h3 span {
        margin-left: .75em;
    }
    
     #page_message .sec_message .sec_ttl span.sub_ttl {
        font-size:  4.27vw;
        margin-top: 2.67vw;
    }

    #page_message .sec_message .sec_ttl span {
        font-size: 4.27vw;
        font-weight: 700;
        margin-top: 0;
    }

    #page_message .sec_message .sec_ttl span br {
        margin-right: 1em;
    }

    #page_message .sec_message .inner {
        width: 100%;
        margin-bottom: 8vw;
        line-height: 2;
        padding: 0 5.33vw;
    }

    #page_message .sec_message .inner h4 {
        width: 100%;
        font-size: 5.33vw;
        margin-bottom: 8vw;
        text-align: center;
    }

    #page_message .sec_message .inner:nth-child(2) h4 {
        margin-top: 100%;
    }

    #page_message .sec_message .inner .txt_box {
        flex: 1;
        order: 1;
        margin-top: 8vw;
    }

    #page_message .sec_message .inner .txt_box p {
        text-align: justify;
        font-size: 3.73vw;
    }

    #page_message .sec_message .inner .txt_box p span {
        font-weight: 700;
    }

    #page_message .sec_message .inner img {
        width: 100%;
        height: auto;
        margin-left: 0;
        order: 0;
    }

    #page_message .sec_message .inner .signature_box {
        text-align: right;
        margin-left: auto;
    }

    #page_message .sec_message .inner .signature_box p {
        font-size: 3.73vw;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_message .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/message/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 group_list ページ

-------------------------------- */
    #page_group_list {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_group_list .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/group_list/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_group_list .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_group_list .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_group_list .hero:after {
        content: '';
        display: none;
    }

    #page_group_list .sec_group_list {
        padding: 21.33vw 0 25.33vw;
    }

    #page_group_list .sec_group_list .tag_wrap {
        display: flex;
        flex-wrap: wrap;
        margin-bottom: 0;
        width: 100%;
        padding: 0 3.47vw;
    }

    #page_group_list .sec_group_list .tag_wrap a {
        display: block;
        font-size: 3.2vw;
        color: #004B9E;
        padding: 1.2vw 2vw;
        min-width: 17vw;
        box-sizing: border-box;
        border: 1px solid #004B9E;
        border-radius: 100px;
        margin: 0 0 1.6vw 0;
    }

    #page_group_list .sec_group_list .tag_wrap a.agency_tag {
        background: #176DE6;
        color: #fff;
        border: 1px solid #176DE6;
    }

    #page_group_list .sec_group_list .tag_wrap a.retail_tag {
        background: #E9AF39;
        color: #fff;
        border: 1px solid #E9AF39;
    }

    #page_group_list .sec_group_list .tag_wrap a.abroad_tag {
        background: #39AFE9;
        color: #fff;
        border: 1px solid #39AFE9;
    }

    #page_group_list .sec_group_list .tag_wrap a.stationery_tag {
        background: #3CBE93;
        color: #fff;
        border: 1px solid #3CBE93;
    }

    #page_group_list .sec_group_list .tag_wrap a.contents_tag {
        background: #E987A8;
        color: #fff;
        border: 1px solid #E987A8;
    }

    #page_group_list .sec_group_list .tag_wrap a.entertainment_tag {
        background: #DB5266;
        color: #fff;
        border: 1px solid #DB5266;
    }

    #page_group_list .sec_group_list .tag_wrap a.newbusiness_tag {
        background: #26B4BE;
        color: #fff;
        border: 1px solid #26B4BE;
    }

    #page_group_list .sec_group_list .tag_wrap a.shared_tag {
        background: #AE9C67;
        color: #fff;
        border: 1px solid #AE9C67;
    }

    #page_group_list .sec_group_list .tag_wrap a.it_tag {
        background: #937FD7;
        color: #fff;
        border: 1px solid #937FD7;
        min-width: 14vw;
    }

    #page_group_list .sec_group_list .inner {
        padding-top: 16vw;
    }

    #page_group_list .sec_group_list .inner h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_group_list .sec_group_list .inner h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_group_list .sec_group_list .inner h3.retail_bar:after {
        background: #E9AF39;
    }

    #page_group_list .sec_group_list .inner h3.abroad_bar:after {
        background: #39AFE9;
    }

    #page_group_list .sec_group_list .inner h3.stationery_bar:after {
        background: #3CBE93;
    }

    #page_group_list .sec_group_list .inner h3.contents_bar:after {
        background: #E987A8;
    }

    #page_group_list .sec_group_list .inner h3.entertainment_bar:after {
        background: #DB5266;
    }

    #page_group_list .sec_group_list .inner h3.newbusiness_bar:after {
        background: #26B4BE;
    }

    #page_group_list .sec_group_list .inner h3.shared_bar:after {
        background: #AE9C67;
    }

    #page_group_list .sec_group_list .inner h3.it_bar:after {
        background: #937FD7;
    }

    #page_group_list .sec_group_list .inner ul {
        text-align: justify;
    }

    #page_group_list .sec_group_list .inner ul li {
        padding: 10.67vw 0;
        border-bottom: 1px solid #ddd;
    }

    #page_group_list .sec_group_list .inner ul li:first-child {
        padding-top: 15vw;
    }

    #page_group_list .sec_group_list .inner ul li h4 {
        font-size: 4.8vw;
        margin-bottom: 5vw;
        /* letter-spacing: 0em; */
        text-align: left;
        line-height: 1.78;
    }
    
    #page_group_list .sec_group_list .inner ul li h4 span.note {
        font-size: 3.2vw;
    }

    #page_group_list .sec_group_list .inner ul li dl {
        display: flex;
        justify-content: flex-start;
        line-height: 2;
        font-size: 3.73vw;
        margin-bottom: 1vw;
    }

    #page_group_list .sec_group_list .inner ul li dl dt {
        width: 25.33vw;
        font-weight: 700;
        margin-bottom: 0;
    }

    #page_group_list .sec_group_list .inner ul li dl dd {
        margin-bottom: 0;
        flex: 1;
        /* letter-spacing: 0em; */
    }

    #page_group_list .sec_group_list .inner ul li dl dd p {
        font-size: 3.73vw;
        text-indent: -1em;
        padding-left: 1em;
        line-height: 2;
        margin-top: 0;
    }

    #page_group_list .sec_group_list .inner ul li dl dd span {
        display: block;
        margin-top: 3vw;
    }

    #page_group_list .sec_group_list .inner ul li dl dd span:first-child {
        margin-top: 0;
        line-height: 2;
    }

    #page_group_list .sec_group_list .inner ul li dl dd a {
        font-size: 3.73vw;
        color: #004B9E;
        text-decoration: underline;
        word-break: break-all;
    }

    #page_group_list .sec_group_list .inner ul li dl dd a:hover {
        color: rgba(0, 75, 158, 0.7);
        text-decoration: none;
        opacity: 1;
    }

    #page_group_list .sec_group_list .inner ul li ul {
        margin-left: 25.33vw;
    }

    #page_group_list .sec_group_list .inner ul li ul li {
        border-bottom: none;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5 {
        font-size: 4.8vw;
        margin-bottom: 30px;
        text-indent: -1.4em;
        padding-left: 1.4em;
        line-height: 1.78;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.ls {
        letter-spacing: -.02em;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5:before {
        content: '';
        display: inline-block;
        width: 3.73vw;
        height: 4px;
        margin-right: 2.67vw;
        vertical-align: middle;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.agency_bar:before {
        background: #176DE6;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.retail_bar:before {
        background: #E9AF39;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.abroad_bar:before {
        background: #39AFE9;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.stationery_bar:before {
        background: #3CBE93;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.contents_bar:before {
        background: #E987A8;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.entertainment_bar:before {
        background: #DB5266;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.newbusiness_bar:before {
        background: #26B4BE;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.shared_bar:before {
        background: #AE9C67;
    }

    #page_group_list .sec_group_list .inner ul li ul li h5.it_bar:before {
        background: #937FD7;
    }

    #page_group_list .sec_group_list .inner ul li ul li dl {
        display: flex;
        justify-content: flex-start;
        line-height: 2;
        font-size: 3.73vw;
        margin-left: 0;
    }

    #page_group_list .sec_group_list .inner ul li ul li dl dt {
        width: 25.33vw;
        font-weight: 700;
        margin-bottom: 2px;
    }

    #page_group_list .sec_group_list .inner ul li ul li dl dd {
        margin-bottom: 2px;
        flex: 1;
        font-size: 3.73vw;
        /* letter-spacing: 0em; */
    }

    #page_group_list .sec_group_list .inner ul li ul li dl dd p {
        font-size: 3.73vw;
        text-indent: -1em;
        padding-left: 1em;
        line-height: 2.1;
        margin-top: 0;
    }

    #page_group_list .sec_group_list .inner ul li ul li dl dd span {
        display: block;
    }

    #page_group_list .sec_group_list .inner ul li ul li dl dd a {
        font-size: 3.73vw;
        color: #004B9E;
        text-decoration: underline;
        word-break: break-all;
    }

    #page_group_list .sec_group_list .inner ul li ul li dl dd a:hover {
        color: rgba(0, 75, 158, 0.7);
        text-decoration: none;
        opacity: 1;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_group_list .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/group_list/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 corporate ページ

-------------------------------- */
    #page_corporate {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_corporate .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/corporate/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_corporate .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_corporate .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 3.67vw;
        line-height: 1;
        /* letter-spacing: 0em; */
    }

    #page_corporate .hero:after {
        content: '';
        display: none;
    }

    #page_corporate .sec_corporate {
        padding: 21.33vw 0 32vw;
    }

    #page_corporate .sec_corporate .inner dl {
        display: flex;
        justify-content: flex-start;
        line-height: 2;
        font-size: 3.73vw;
        width: 100%;
        margin-bottom: 5vw;
        /* letter-spacing: 0em; */
    }

    #page_corporate .sec_corporate .inner dl dt {
        width: 24vw;
        font-weight: 700;
        margin-bottom: 0;
    }

    #page_corporate .sec_corporate .inner dl dd {
        margin-bottom: 0;
        flex: 1;
        /* letter-spacing: .01em; */
        letter-spacing: normal;
    }

    #page_corporate .sec_corporate .inner dl dd p {
        font-size: 3.73vw;
        text-indent: -1em;
        padding-left: 1em;
        line-height: 2;
        margin-top: 0;
    }

    #page_corporate .sec_corporate .inner dl dd span {
        font-size: 3.73vw;
    }

    #page_corporate .sec_corporate .inner dl dd a {
        display: flex;
        justify-content: center;
        align-items: center;
        height: 8vw;
        width: 16vw;
        border-radius: 100px;
        background: #004B9E;
        color: #fff;
        margin: 10px 0 15px;
        font-size: 3.2vw;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_corporate .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/corporate/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 philosophy　ページ

-------------------------------- */
    #page_philosophy {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_philosophy .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        width: 100%;
        background-color: #004B9E;
        background-image: url(../img/common/frame01@2x.png), url(../img/common/frame02@2x.png), url(../img/common/frame03@2x.png), url(../img/common/frame04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 10.67vw 10.67vw;
        background-repeat: no-repeat;
    }

    #page_philosophy .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_philosophy .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_philosophy .hero:after {
        content: '';
        display: none;
    }

    #page_philosophy .sec_philosophy {
        padding: 21.33vw 0 0;
    }

    #page_philosophy .sec_philosophy .sec_ttl {
        margin-bottom: 16vw;
    }

    #page_philosophy .sec_philosophy .sec_ttl h3 {
        position: relative;
        font-size: 5.33vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 8vw;
        line-height: 1.69;
    }

    #page_philosophy .sec_philosophy .inner {
        width: 100%;
        text-align: center;
    }

    #page_philosophy .sec_philosophy .inner img {
        width: 100%;
        height: auto;
        margin: 4.33vw auto 11vw;
    }

    #page_philosophy .sec_background {
        padding: 21vw 0 38.67vw;
    }

    #page_philosophy .sec_background .sec_ttl {
        margin-bottom: 16vw;
    }

    #page_philosophy .sec_background .sec_ttl h3 {
        position: relative;
        font-size: 5.33vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 8vw;
        line-height: 1.69;
    }

    #page_philosophy .sec_background .inner {
        width: 100%;
        padding: 0;
    }

    #page_philosophy .sec_background .inner p {
        text-align: center;
        font-size: 4.8vw;
        font-weight: 700;
        margin-bottom: 13.33vw;
        /* letter-spacing: .02em; */
        line-height: 1.78;
    }

    #page_philosophy .sec_background .inner img {
        width: 100%;
        height: auto;
        margin-bottom: 0;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_philosophy .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        width: 100%;
        background-color: #004B9E;
        background-image: url(../img/common/frame01@2x.png), url(../img/common/frame02@2x.png), url(../img/common/frame03@2x.png), url(../img/common/frame04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 10.67vw 10.67vw;
        background-repeat: no-repeat;
    }
}

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

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

 business_plan　ページ

-------------------------------- */
    #page_business_plan {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_business_plan .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        width: 100%;
        background-color: #f2f2f2;
        background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 10.67vw 10.67vw;
        background-repeat: no-repeat;
    }

    #page_business_plan .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_business_plan .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #004B9E;
        font-size: 5.33vw;
        font-weight: 700;
        background: #fff;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_business_plan .hero:after {
        content: '';
        display: none;
    }

    #page_business_plan .sec_business_plan {
        padding: 21.33vw 0 7vw;
    }

    #page_business_plan .sec_business_plan .inner {
        width: 100%;
    }

    #page_business_plan .sec_business_plan .inner p {
        text-align: center;
        font-size: 3.73vw;
        margin-bottom: 0;
    }

    #page_business_plan .sec_business_plan .inner img {
        width: 80vw;
        height: auto;
        margin: 4vw auto;
    }

    #page_business_plan .sec_business_plan .inner span {
        display: block;
        margin-bottom: 8vw;
        font-size: 3.73vw;
    }

    #page_business_plan .sec_concept {
        padding: 25vw 0 7vw;
    }

    #page_business_plan .sec_concept .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_business_plan .sec_concept .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_business_plan .sec_concept .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_business_plan .sec_concept .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_business_plan .sec_concept .inner {
        display: block;
    }

    #page_business_plan .sec_concept .inner h4 {
        width: 100%;
        font-size: 5.8vw;
        margin-bottom: 8vw;
        text-align: center;
        line-height: 1.69;
        letter-spacing: normal;
    }

    #page_business_plan .sec_concept .inner p {
        text-align: center;
        font-size: 3.73vw;
    }

    #page_business_plan .sec_basicPolicy {
        padding: 25vw 0 38.33vw;
    }

    #page_business_plan .sec_basicPolicy .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_business_plan .sec_basicPolicy .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_business_plan .sec_basicPolicy .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_business_plan .sec_basicPolicy .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_business_plan .sec_basicPolicy .inner {
        display: block;
    }

    #page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        width: 100%;
    }

    #page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box {
        text-align: justify;
        width: 100%;
    }

    #page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box+.basicPolicy_box {
        margin-top: 8vw;
        width: 100%;
    }

    #page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box h4 {
        position: relative;
        font-size: 4.8vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 5vw;
        line-height: 1.75;
        color: #004B9E;
        text-indent: -1.7em;
        padding-left: 1.7em;
        letter-spacing: normal;
    }

    #page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box ul {
        text-align: justify;
        margin-left: 8vw;
    }

    #page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box ul li {
        font-size: 3.73vw;
        text-indent: .5em;
        line-height: 2;
    }

    #page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box ul li:before {
        content: '';
        display: inline-block;
        width: 3vw;
        height: 3vw;
        background: #004B9E;
        margin-right: 10px;
    }

    #page_business_plan .sec_basicPolicy .inner .basicPolicy_wrap .basicPolicy_box:last-child h4 {
        text-align: justify;
    }

    #page_business_plan .sec_basicPolicy .inner img {
        width: 100%;
        height: auto;
        margin-top: 12.67vw;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_business_plan .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        width: 100%;
        background-color: #f2f2f2;
        background-image: url(../img/common/frame_blue01@2x.png), url(../img/common/frame_blue02@2x.png), url(../img/common/frame_blue03@2x.png), url(../img/common/frame_blue04@2x.png);
        background-position: left 0 top 0, right 0 top 0, left 0 bottom 0, right 0 bottom 0;
        background-size: 10.67vw 10.67vw;
        background-repeat: no-repeat;
    }
}

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

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

 management ページ

-------------------------------- */
    #page_management {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_management .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/management/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_management .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_management .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_management .hero:after {
        content: '';
        display: none;
    }

    #page_management .date_wrap {
        width: 100%;
        margin: auto;
        padding: 10.67vw 3.47vw 0;
    }

    #page_management .date_wrap p {
        font-size: 3.73vw;
        text-align: right;
    }

    #page_management .sec_officer {
        padding: 16vw 3.47vw 0;
    }

    #page_management .sec_officer .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_management .sec_officer .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_management .sec_officer .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_management .sec_officer .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_management .sec_officer .inner {
        border-bottom: 1px solid #ddd;
        width: 100%;
        padding: 2.67vw 0 7vw;
    }

    #page_management .sec_officer .inner dl {
        display: flex;
        justify-content: flex-start;
        line-height: 2;
        font-size: 3.73vw;
        margin-bottom: 5vw;
        text-align: justify;
    }

    #page_management .sec_officer .inner dl dt {
        width: 36vw;
        font-weight: 700;
        margin-bottom: 0;
    }

    #page_management .sec_officer .inner dl dd {
        margin-bottom: 0;
        flex: 1;
        display: flex;
        flex-wrap: wrap;
        /* letter-spacing: 0; */
    }

    #page_management .sec_officer .inner dl dd span {
        margin-left: 0;
        width: 100%;
        /* letter-spacing: -.04em; */
    }

    #page_management .sec_officer:nth-of-type(2) {
        padding: 16vw 3.47vw 0;
    }

    /*#page_management .sec_officer:nth-of-type(3) .inner dl dt {
    width: 24vw;
  }
  #page_management .sec_officer:nth-of-type(4) .inner dl dt {
    width: 17.33vw;
  }*/
    #page_management .sec_officer:last-of-type {
        margin-bottom: 25vw;
    }

    /*#page_management .sec_officer:last-of-type .inner dl dt {
    width: 20vw;
  }*/
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_management .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/management/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 history ページ

-------------------------------- */
    #page_history {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_history .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/history/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_history .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_history .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_history .hero:after {
        content: '';
        display: none;
    }

    #page_history .sec_history {
        padding: 21.33vw 0 38vw;
    }

    #page_history .sec_history .sticky_nav {
        display: none;
    }

    #page_history .sec_history .sticky_nav.js_on {
        display: none;
    }

    #page_history .sec_history .sticky_nav_sp {
        display: none;
    }

    #page_history .sec_history .sticky_nav_sp.js_on {
        display: flex;
        justify-content: space-between;
        align-items: center;
        position: fixed;
        top: 16vw;
        z-index: 99;
        width: 100%;
        height: 10.67vw;
        background: #004B9E;
        box-sizing: border-box;
    }

    #page_history .sec_history .sticky_nav_sp.js_on li {
        box-sizing: border-box;
    }

    #page_history .sec_history .sticky_nav_sp.js_on li a {
        color: #fff;
        font-family: "Roboto Condensed", sans-serif;
        font-weight: 700;
        width: 100%;
        font-size: 3.73vw;
        padding: 0 6.33vw;
        line-height: 1;
    }

    #page_history .sec_history .sticky_nav_sp.js_on li a span {
        font-size: 3.2vw;
    }

    #page_history .sec_history .sticky_nav_sp.js_on li+li a {
        border-left: 1px solid #fff;
    }

    #page_history .sec_history .sec_ttl {
        margin-bottom: 18.67vw;
    }

    #page_history .sec_history .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_history .sec_history .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 3px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_history .sec_history .inner ul {
        text-align: justify;
    }

    #page_history .sec_history .inner ul li {
        padding-top: 17vw;
        margin-top: -17vw;
    }

    #page_history .sec_history .inner ul li dl {
        display: flex;
        justify-content: flex-start;
        line-height: 2;
        font-size: 3.73vw;
    }

    #page_history .sec_history .inner ul li dl dt {
        width: 26.67vw;
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        color: #004B9E;
        font-weight: 700;
        margin-bottom: 0;
        line-height: 1;
        text-align: justify;
    }

    #page_history .sec_history .inner ul li dl dt span {
        font-family: "Noto Sans JP", sans-serif;
        font-size: 4.53vw;
    }

    #page_history .sec_history .inner ul li dl dt span.cs08 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        /* letter-spacing: -.08em; */
    }

    #page_history .sec_history .inner ul li dl dt span.cs07 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        /* letter-spacing: -.07em; */
    }

    #page_history .sec_history .inner ul li dl dt span.cs05 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        /* letter-spacing: -.05em; */
    }

    #page_history .sec_history .inner ul li dl dt span.cs04 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        /* letter-spacing: -.04em; */
    }

    #page_history .sec_history .inner ul li dl dt span.cs03 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        /* letter-spacing: -.03em; */
    }

    #page_history .sec_history .inner ul li dl dt span.cs02 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        /* letter-spacing: -.02em; */
    }

    #page_history .sec_history .inner ul li dl dt span.cs01 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        /* letter-spacing: -.01em; */
    }

    #page_history .sec_history .inner ul li dl dt span.cs00 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 8.8vw;
        /* letter-spacing: 0em; */
    }

    #page_history .sec_history .inner ul li dl dd {
        flex: 1;
        display: flex;
        flex-wrap: wrap;
        padding: 5vw 0 25.33vw;
        border-left: 1px solid #ddd;
        width: 66.67vw;
    }

    #page_history .sec_history .inner ul li dl dd.multiple {
        padding-bottom: 10.66vw;
    }

    #page_history .sec_history .inner ul li dl dd .month {
        width: 100%;
        margin: -3vw auto 5vw;
        position: relative;
        font-family: "Roboto Condensed", sans-serif;
        font-size: 6.13vw;
        color: #004B9E;
        font-weight: 700;
        line-height: .8;
        text-align: justify;
        padding: 0 0 0 5.33vw;
    }

    #page_history .sec_history .inner ul li dl dd .month span {
        font-size: 3.73vw;
        margin-left: 0;
    }

    #page_history .sec_history .inner ul li dl dd .month span.cs08 {
        font-family: "Roboto Condensed", sans-serif;
        font-size: 6.13vw;
        /* letter-spacing: -.08em; */
    }

    #page_history .sec_history .inner ul li dl dd .month:after {
        content: '';
        position: absolute;
        top: 5px;
        left: -1.2vw;
        display: block;
        width: 2.4vw;
        height: 2.4vw;
        border-radius: 100%;
        background: #004B9E;
    }

    #page_history .sec_history .inner ul li dl dd .nomonth {
        width: 100%;
        margin: -3vw auto 5vw;
        position: relative;
    }

    #page_history .sec_history .inner ul li dl dd .nomonth:after {
        content: '';
        display: none;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap {
        width: 100%;
        margin-top: 0;
        padding: 0 1.33vw 0 5.33vw;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap h4 {
        font-size: 4.8vw;
        margin: -.4em 0 5.33vw;
        line-height: 1.78;
        /* letter-spacing: -.02em; */
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap p {
        font-size: 3.73vw;
        margin-bottom: 5.33vw;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap img {
        margin-bottom: 2.67vw;
        width: 100%;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_199111 {
        width: 100%;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_200606 {
        width: 34.67vw;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_200701 {
        width: 44vw;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_201706_01 {
        width: 100%;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_201910 {
        width: 100%;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_202004_01 {
        width: 48vw;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap img.pict_202004_02 {
        width: 32vw;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap .img_box {
        position: relative;
        margin-bottom: 0;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap .img_box img {
        width: 100%;
    }

    #page_history .sec_history .inner ul li dl dd .contents_wrap .img_box img:last-child {
        position: relative;
        top: 0;
        left: 0;
    }

    #page_history .sec_history .inner ul li dl dd span {
        margin-left: 0;
    }

    #page_history .sec_history .inner ul li:first-child dl dd {
        margin-top: 5vw;
        padding-top: 0;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_history .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/history/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 governance　ページ

-------------------------------- */
    #page_governance {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_governance .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/governance/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_governance .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_governance .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_governance .hero:after {
        content: '';
        display: none;
    }

    #page_governance .sec_governance {
        padding: 21.3vw 0 0;
    }

    #page_governance .sec_governance .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_governance .sec_governance .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_governance .sec_governance .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_governance .sec_governance .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_governance .sec_governance .inner {
        display: block;
        margin-bottom: 17.33vw;
    }

    #page_governance .sec_governance .inner h4 {
        position: relative;
        font-size: 4.8vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 4vw;
        line-height: 1.78;
        text-align: justify;
        text-indent: -2em;
        padding-left: 2em;
        letter-spacing: normal;
    }

    #page_governance .sec_governance .inner p {
        text-align: justify;
        font-size: 3.73vw;
    }

    #page_governance .sec_governance .inner:last-child {
        margin-bottom: 37vw;
    }

    #page_governance .sec_governance .systemDiagram_wrap {
        background: rgba(198, 237, 255, 0.31);
        padding: 13.33vw 0;
        margin-bottom: 17.33vw;
    }

    #page_governance .sec_governance .systemDiagram_wrap .inner {
        margin-bottom: 0;
    }

    #page_governance .sec_governance .systemDiagram_wrap .inner h5 {
        font-size: 4.8vw;
        margin-bottom: 6.67vw;
        line-height: 1.78;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_governance .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/governance/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

business ページ

-------------------------------- */
    #page_business {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_business .hero {
        position: relative;
        padding: 0;
        height: 80vw;
        background-size: 100%;
        background: url(../img/business/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_business .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
    }

    #page_business .hero .hero_ttl h2 {
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 5.33vw;
        font-weight: 700;
        width: 64vw;
        height: 20.8vw;
        line-height: 1;
    }

    #page_business .hero .hero_ttl h2 span {
        display: block;
        font-size: 2.93vw;
    }

    #page_business .hero:after {
        content: '';
        display: none;
    }

    #page_business .sec_business {
        padding: 21.33vw 0 0;
    }

    #page_business .sec_business .sec_ttl {
        margin-bottom: 8vw;
    }

    #page_business .sec_business .sec_ttl h3 {
        position: relative;
        font-size: 5.87vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 4vw;
        line-height: 1.69;
        color: #000;
        letter-spacing: normal;
    }

    #page_business .sec_business .sec_ttl h3 span {
        margin-left: .7em;
    }

    #page_business .sec_business .inner {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        margin-bottom: 30vw;
    }

    #page_business .sec_business .inner h4 {
        width: 100%;
        font-size: 5.33vw;
        margin-bottom: 9.33vw;
        text-align: justify;
    }

    #page_business .sec_business .inner p {
        font-size: 3.73vw;
        width: 100%;
        margin: 16vw 0 10vw;
        text-align: justify;
    }

    #page_business .sec_business .inner.region_box {
        margin-top: 15vw;
    }

    #page_business .sec_business .inner.region_box picture {
        margin-left: 0;
        width: 100%;
    }

    #page_business .sec_business .inner.region_box picture img {
        width: 100%;
        height: auto;
        max-height: auto;
    }

    #page_business .sec_business .inner.region_box p {
        margin: 8vw 0 0;
    }

    #page_business .sec_business .inner.foundingDate {
        position: relative;
        padding: 0 1.87vw;
    }

    #page_business .sec_business .inner.foundingDate picture {
        position: relative;
        margin: 0;
        width: 100%;
    }

    #page_business .sec_business .inner.foundingDate picture img {
        margin: auto;
        width: 100%;
    }

    #page_business .sec_business .inner.employees {
        margin-bottom: 20vw;
    }

    #page_business .sec_business .inner.employees picture {
        width: 100%;
    }

    #page_business .sec_business .inner.employees picture img {
        width: 100%;
    }

    #page_business .sec_business .inner.group_box picture:first-child {
        order: 1;
        width: 100%;
        margin-top: -11vw;
    }

    #page_business .sec_business .inner.group_box picture:first-child img {
        margin: 17vw auto 1vw;
        width: 100%;
    }

    #page_business .sec_business .inner.group_box picture:last-child {
        order: 0;
        width: 100%;
        margin-left: 0;
        z-index: -99;
    }

    #page_business .sec_business .inner.group_box picture:last-child img {
        width: 100%;
        margin-top: 10vw;
    }

    #page_business .sec_business .inner.amount_box {
        margin-bottom: 0;
    }

    #page_business .sec_business .inner.amount_box picture {
        margin-bottom: 30vw;
        width: 100%;
    }

    #page_business .sec_business .inner.amount_box picture img {
        width: 100%;
    }

    #page_business .sec_businessList {
        padding: 0 0 37.67vw;
    }

    #page_business .sec_businessList .content_box {
        display: flex;
        flex-wrap: wrap;
        margin-top: 0;
    }

    #page_business .sec_businessList .content_box li {
        width: 100%;
        height: auto;
        background: #004B9E;
        border-bottom: 2px solid #fff;
        box-sizing: border-box;
    }

    #page_business .sec_businessList .content_box li a {
        height: 100%;
        width: 100%;
        display: flex;
        flex-wrap: wrap;
    }

    #page_business .sec_businessList .content_box li a .img_box {
        height: auto;
        width: 100%;
        overflow: hidden;
        position: relative;
    }

    #page_business .sec_businessList .content_box li a .img_box img {
        width: 100%;
        position: relative;
        top: 0;
        left: 0;
        transform: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: auto;
        padding: 10.67vw 0;
    }

    #page_business .sec_businessList .content_box li a .txt_box p {
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        width: 100%;
        margin-bottom: 5vw;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        color: #004B9E;
        width: 58.13vw;
        height: 15.47vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.agency_tag {
        background: #176DE6;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.retail_tag {
        background: #E9AF39;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.abroad_tag {
        background: #39AFE9;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.stationery_tag {
        background: #3CBE93;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.contents_tag {
        background: #E987A8;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.entertainment_tag {
        background: #DB5266;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.newbusiness_tag {
        background: #26B4BE;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.shared_tag {
        background: #AE9C67;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.it_tag {
        background: #937FD7;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.hd_tag {
        background: #B2B2B2;
        color: #fff;
        border: none;
    }

    #page_business .sec_businessList .content_box li a .txt_box span.btn.esg_tag {
        background: #BBF5B3;
        color: #007E67;
        border: none;
    }

    #page_business .sec_businessList .content_box li:nth-child(3n-1) {
        border-right: none;
        border-left: none;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_business .hero {
        position: relative;
        padding: 0;
        height: 80vw;
        background-size: 100%;
        background: url(../img/business/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

business下位ページ 共通

-------------------------------- */
    .under_business {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    .under_business .hero {
        position: relative;
        padding: 0;
        height: 80vw;
        background-size: 100%;
    }

    .under_business .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
    }

    .under_business .hero .hero_ttl h2 {
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        width: 64vw;
        height: 20.8vw;
        line-height: 1;
    }

    .under_business .hero .hero_ttl h2 span {
        display: block;
        font-size: 2.93vw;
        margin-bottom: 2.67vw;
    }

    .under_business .hero:after {
        content: '';
        display: none;
    }

    .under_business section {
        padding: 28vw 0 2.67vw;
    }

    .under_business section .sec_ttl {
        margin-bottom: 13.33vw;
    }

    .under_business section .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 0;
        position: relative;
    }

    .under_business section .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        left: 50%;
        transform: translateX(-50%);
        margin: 2.67vw auto 9.33vw;
    }

    .under_business section .sec_ttl h3 span {
        display: block;
        font-size: 4.27vw;
        font-weight: 400;
    }

    .under_business section .inner h4 {
        position: relative;
        font-size: 5.87vw;
        font-weight: 700;
        letter-spacing: -.01em;
        margin-bottom: 5.33vw;
        line-height: 1.78;
        /* letter-spacing: normal; */
    }

    .under_business section .inner p {
        text-align: justify;
        font-size: 3.73vw;
        line-height: 2;
    }

    .under_business section .inner p.lead {
        font-size: 3.73vw;
    }

    .under_business section .inner .inner_box {
        margin: 18.67vw auto 0;
    }

    .under_business section .inner .inner_box h5 {
        font-size: 4.8vw;
        margin: 17.33vw auto 8vw;
        line-height: 1.78;
    }

    .under_business section .inner .inner_box img {
        margin: 8vw auto 18.67vw;
    }

    .under_business section .inner .inner_box p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        letter-spacing: normal;
    }

    .under_business section .inner .inner_box p.ta_center {
        text-align: justify;
    }

    .under_business section .inner .inner_box .img_wrap {
        display: flex;
        justify-content: space-between;
        align-items: top;
        flex-wrap: wrap;
        margin-top: 8vw;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_2div {
        width: 100%;
        text-align: center;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_2div h6 {
        font-size: 4.27vw;
        font-weight: 700;
        text-align: justify;
        margin-bottom: 1.33vw;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_2div img {
        margin: 0 auto 4vw;
        width: 100%;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_2div p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        line-height: 2;
        letter-spacing: normal;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_2div p+p {
        margin-top: 5.33vw;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_2div a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 6.67vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        left: 50%;
        transform: translateX(-50%);
    }

    .under_business section .inner .inner_box .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    .under_business section .inner .inner_box .img_wrap .img_box_2div+.img_box_2div {
        margin-top: 8vw;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_3div {
        width: 100%;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_3div img {
        margin: 0 auto 4vw;
        background: #fff;
        width: 100%;
    }

    .under_business section .inner .inner_box .img_wrap .img_box_3div p {
        font-size: 3.73vw;
        text-align: justify;
        /* letter-spacing: 0; */
        letter-spacing: normal;
    }

    .under_business section .inner .img_wrap {
        display: flex;
        justify-content: space-between;
        align-items: top;
        flex-wrap: wrap;
        margin-top: 8vw;
    }

    .under_business section .inner .img_wrap h5 {
        font-size: 5.33vw;
        margin: 32vw auto 5.33vw;
        width: 100%;
    }

    .under_business section .inner .img_wrap .img_box_2div {
        width: 100%;
    }

    .under_business section .inner .img_wrap .img_box_2div h6 {
        font-size: 4.27vw;
        font-weight: 700;
        text-align: justify;
        margin-bottom: 1.33vw;
    }

    .under_business section .inner .img_wrap .img_box_2div img {
        margin: 0 auto 4vw;
        width: 100%;
    }

    .under_business section .inner .img_wrap .img_box_2div p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        line-height: 2;
        letter-spacing: normal;
    }

    .under_business section .inner .img_wrap .img_box_2div p+p {
        margin-top: 5.33vw;
    }

    .under_business section .inner .img_wrap .img_box_3div {
        width: 100%;
    }

    .under_business section .inner .img_wrap .img_box_3div h5 {
        font-size: 4.27vw;
        font-weight: 700;
        text-align: justify;
        margin-bottom: 1.33vw;
    }

    .under_business section .inner .img_wrap .img_box_3div img {
        margin: 0 auto 4vw;
        width: 100%;
    }

    .under_business section .inner .img_wrap .img_box_3div p {
        font-size: 3.73vw;
        text-align: justify;
        /* letter-spacing: 0; */
        letter-spacing: normal;
    }

    .under_business section .inner .img_wrap .img_box_3div a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 6.67vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
    }

    .under_business .sec_businessArea {
        padding: 21.33vw 0 2.67vw;
    }

    .under_business section .inner .img_wrap .img_box_3div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    .under_business section .inner .img_wrap .img_box_3div+.img_box_3div {
        margin-top: 8vw;
    }

    .under_business .sec_businessArea .sec_ttl {
        margin-bottom: 13.33vw;
    }

    .under_business .sec_businessArea .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 0;
        position: relative;
    }

    .under_business .sec_businessArea .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        left: 50%;
        transform: translateX(-50%);
        margin: 2.67vw auto 9.33vw;
    }

    .under_business .sec_businessArea .sec_ttl h3 span {
        display: block;
        font-size: 4.27vw;
        font-weight: 400;
    }

    .under_business .sec_businessArea .inner {
        width: 100%;
        display: flex;
        justify-content: space-around;
        flex-wrap: wrap;
        margin: 17vw auto 0;
    }

    .under_business .sec_businessArea .inner a {
        display: inline-block;
        font-size: 3.73vw;
        color: #fff;
        box-sizing: border-box;
        padding: 2.33vw 4vw;
        border: none;
        border-radius: 5px;
        text-align: center;
        margin-bottom: 1.67vw;
    }

    .under_business .sec_businessArea .inner a+a {
        margin-left: 0;
    }

    .under_business .sec_ttlArea {
        padding: 21.33vw 3.47vw 4vw;
    }

    .under_business .sec_ttlArea h3 {
        position: relative;
        font-size: 8vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 9.33vw;
        line-height: 1.78;
        letter-spacing: normal;
    }

    .under_business .sec_ttlArea p {
        text-align: center;
        font-size: 4.8vw;
    }

    .under_business .sec_relation {
        padding-bottom: 29.67vw;
    }

    .under_business .sec_relation .sec_ttl h3:after {
        background: #004B9E;
    }

    .under_business .sec_relation .inner {
        display: flex;
        position: relative;
        align-items: center;
        justify-content: center;
    }

    .under_business .sec_relation .inner ul {
        margin-top: 3.67vw;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        margin-left: 2em;
    }

    .under_business .sec_relation .inner ul li {
        text-align: justify;
        margin: 0 2.2vw 8vw 2.2vw;
        display: inline;
        font-size: 3.73vw;
    }

    .under_business .sec_relation .inner ul li a {
        font-size: 3.73vw;
        font-weight: 700;
        position: relative;
        margin-left: 0;
        margin-left: -2em;
    }

    .under_business .sec_relation .inner ul li a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 0;
        transform: translateY(-50%);
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    .under_business section .inner .inner_box .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    .under_business section .inner .img_wrap .img_box_3div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    .under_business .sec_relation .inner ul li a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        transform: translateY(-50%);
    }
}

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

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

 agency ページ

-------------------------------- */
    #page_agency .hero {
        background: url(../img/agency/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_agency .hero .hero_ttl h2 {
    }

    #page_agency section .sec_ttl h3:after {
        background: #176DE6;
    }

    #page_agency .sec_businessArea .inner {
        width: 61.33vw;
    }

    /* 220609 ここから */
    #page_agency .sec_businessArea .inner a {
        background: #176DE6;
        flex-shrink: 0;
    }

    /* 220609 ここまで */

    #page_agency .sec_publication .distribution_wrap .distribution_box {
        background: rgba(57, 130, 233, 0.06);
        padding: 14.67vw 0;
        margin: 14.67vw auto 9.33vw;
    }

    #page_agency .sec_publication .distribution_wrap .distribution_box .inner h5 {
        font-size: 4.8vw;
        margin: 0 auto;
        line-height: 1.78;
    }

    #page_agency .sec_publication .distribution_wrap .distribution_box .inner img {
        margin-top: 10.67vw;
        width: 100%;
    }

    #page_agency .sec_publication .distribution_wrap .inner p {
        text-align: justify;
    }

    #page_agency .sec_publication .inner .inner_box p {
        text-align: justify;
    }

    #page_agency .sec_publication .inner .inner_box .img_wrap {
        padding: 0;
    }

    #page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div h6 {
        text-align: justify;
        margin: 0 0 1.67vw;
        line-height: 1.78;
    }

    #page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div p {
        text-align: justify;
    }

    #page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div a {
        left: 50%;
        transform: translateX(-50%);
    }

    #page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div.libraryCenter {
        text-align: justify;
    }

    #page_agency .sec_publication .inner .inner_box .img_wrap .img_box_2div.libraryCenter h6 {
        text-align: justify;
        margin: 0 0 10px;
        line-height: 1.78;
    }

    #page_agency .sec_publication .inner:last-child .inner_box:nth-child(2) .img_wrap .img_box_2div a {
        left: 50%;
        transform: translateX(-50%);
    }

    #page_agency .sec_publication .inner:last-child .inner_box:nth-child(2) .img_wrap .img_box_2div+.img_box_2div {
        margin-top: 0;
    }

    #page_agency .sec_publication .inner:last-child .inner_box:last-child .img_wrap .img_box_2div h6 {
        text-align: justify;
        margin: 0 0 1.67vw;
        line-height: 1.78;
    }

    #page_agency .sec_publication .inner:last-child .inner_box:last-child .img_wrap .img_box_2div p {
        text-align: justify;
    }

    #page_agency .sec_publication .inner:last-child .inner_box:last-child .img_wrap .img_box_2div a {
        left: 0;
        transform: none;
        width: 59vw;
    }

    #page_agency .sec_publication .inner:last-child .inner_box:last-child .img_wrap .img_box_2div:last-child a:before {
        content: '';
        left: 12vw;
    }

    #page_agency .sec_stationery .inner h4 {
        /* letter-spacing: -.05em; */
    }

    #page_agency .sec_stationery .inner .img_wrap {
        flex-wrap: wrap;
    }

    #page_agency .sec_stationery .inner .img_wrap .img_box_3div h5 {
        margin-top: 0;
        line-height: 1.78;
    }

    #page_agency .sec_stationery .inner .img_wrap .img_box_3div a {
        width: 42.67vw;
    }

    #page_agency .sec_stationery .inner .img_wrap .img_box_3div a:before {
        content: '';
        left: 8.07vw;
    }

    #page_agency .sec_stationery .inner .img_wrap .img_box_3div:first-child a:before {
        content: '';
        left: 11.5vw;
    }

    #page_agency .sec_stationery .inner .img_wrap .img_box_3div:last-child a:before {
        content: '';
        left: 9.67vw;
    }

    #page_agency .sec_stationery .inner .inner_box {
        margin: 0 auto;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap {
        padding: 0;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div img {
        width: 100%;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(3),
    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(4),
    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(5),
    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(6) {
        margin-top: 8vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div h5 {
        line-height: 1.78;
        font-size: 4.27vw;
        font-weight: 700;
        margin: 0 0 1.67vw;
        text-align: justify;
        min-height: 9vw;
        display: flex;
        align-items: center;
        justify-content: flex-start;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div h5 img,
    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div h5 span {
        width: auto;
        margin: 0;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translate(0, -50%);
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:first-child h5 img {
        width: 24vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(2) h5 img {
        width: 28.8vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(4) h5 img {
        width: 14.47vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div p {
        text-align: justify;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(4) p,
    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(5) p {
        min-height: auto;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div a {
        width: 42.67vw;
        text-align: center;
        display: block;
        padding: 5.33vw 8vw 5.33vw 14vw;
           margin: 6.67vw 0 1.33vw;
           font-size: 3.73vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div a:before {
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 10vw;
        transform: translateY(-50%);
    }
    
        #page_agency .sec_stationery .inner .inner_box a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 10.67vw auto 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
      }

      #page_agency .sec_stationery .inner .inner_box a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 10vw;
        transform: translateY(-50%);
      }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:first-child a:before {
        content: '';
        left: 11vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(3) a:before {
        content: '';
        left: 8.33vw;
    }
    
    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(4) a:before {
        content: '';
        left: 11.67vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(5) a {
        padding: 5.33vw 8vw 5.33vw 12.67vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(5) a:before {
        content: '';
        left: 6vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(6) a {
        padding: 5.33vw 8vw 5.33vw 14vw;
    }

    #page_agency .sec_stationery .inner .inner_box .img_wrap .img_box_2div:nth-child(6) a:before {
        content: '';
        left: 13.33vw;
    }

    #page_agency .sec_stationery .inner +  .inner {
        margin-top: 16vw;
    }

    #page_agency .sec_stationery .inner + .inner .inner_box .img_wrap .img_box_2div:nth-child(2) {
        margin-top: 8vw;
    }
    


    #page_agency .sec_direction .inner h4 {
        /* letter-spacing: -.05em; */
        margin-bottom: 15.33vw;
        letter-spacing: normal;
    }

    /* 220609 ここから */
    #page_agency .sec_direction .inner .img_ybs {
        margin: 0 auto 9.33vw;
        width: 31.47vw;
    }

    /* 220609 ここまで */

    #page_agency .sec_direction .inner .img_wrap {
        flex-wrap: wrap;
    }

    #page_agency .sec_direction .inner .img_wrap .img_box_3div+.img_box_3div {
        margin-left: 0;
    }

    #page_agency .sec_direction .inner .img_wrap .img_box_3div h5 {
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 4.27vw;
        font-weight: 700;
        height: 12vw;
        background: #176DE6;
        color: #fff;
        margin: 0 auto 2.67vw;
        border-radius: 6px;
        line-height: 1.78;
    }

    #page_agency .sec_direction .inner .img_wrap .img_box_3div img {
        margin: 0 auto 3.33vw;
        background: #fff;
    }


    /* 220609 ここから */
    #page_agency .sec_direction .inner .img_wrap .img_box_3div p {
        text-align: left;
        margin-top: 0;
    }

    /* 220609 ここまで */

    #page_agency .sec_direction .inner a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 10.67vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
    }

    #page_agency .sec_direction .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    /* 220609 ここから */
    #page_agency .sec_direction .inner a.img_link {
        width: 100%;
    }

    #page_agency .sec_direction .inner a.img_link:before {
        display: none;
    }

    /* 220609 ここまで */

    #page_agency .sec_relation .sec_ttl h3:after {
        background: #176DE6;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_agency .hero {
        background: url(../img/agency/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }

    #page_agency .sec_direction .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }
}

@media only screen and (max-width: 767px) {
    /* --------------------------------

 retail ページ

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

    /* 220609 ここから */
    #page_retail .hero {
        background: url(../../../../uploads/2023/10/retail_mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    /* 220609 ここまで */

    #page_retail .hero .hero_ttl h2 {
    }

    #page_retail section .sec_ttl h3:after {
        background: #E9AF39;
    }

    #page_retail .sec_businessArea .inner {
        width: 68.93vw;
    }

    #page_retail .sec_businessArea .inner a {
        background: #E9AF39;
    }

    #page_retail .sec_management .inner h4 {
        /* letter-spacing: -.04em; */
    }

    #page_retail .sec_management .inner .img_wrap h6 {
        font-size: 4.27vw;
        font-weight: 400;
        text-align: justify;
        margin-bottom: 2.67vw;
        width: 100%;
    }

    #page_retail .sec_management .inner .inner_box {
        padding-bottom: 5.33vw;
    }

    #page_retail .sec_management .inner .inner_box p.stores_note.only_pc {
        display: none;
    }

    #page_retail .sec_management .inner .inner_box p.stores_note.only_sp {
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 3.73vw;
        margin: 10.67vw auto 0;
        width: 100%;
        height: 14.67vw;
        background: #FCF3E1;
        border-radius: 6px;
        text-align: center;
        line-height: 1.5;
    }

    #page_retail .sec_management .inner .inner_box+.inner_box {
        margin-top: 20vw;
    }

    #page_retail .sec_management .inner .inner_box img {
        margin: 0 auto;
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .img_box_2div h6 {
        font-size: 4.27vw;
        font-weight: 700;
        text-align: justify;
        margin-bottom: 2.67vw;
    }
    
    #page_retail .sec_management .inner .inner_box .group_wrap {
        width: 100%;
        margin: 0 auto;
    }

    #page_retail .sec_management .inner .inner_box .group_wrap img {
        width: 100%;
        margin: 0;
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .img_box_2div h6 span {
        display: block;
        margin: 5.33vw auto 2.67vw;
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .group_governance {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        background: rgba(221, 221, 221, 0.4);
        padding: 23vw 0 10.67vw;
        box-sizing: border-box;
        border-radius: 6px;
        position: relative;
        margin-bottom: 5.33vw;
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .group_governance h6 {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 13.33vw;
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        background: #E9AF39;
        margin-bottom: 0;
        border-radius: 6px 6px 0 0;
        position: absolute;
        left: 0;
        top: 0;
        line-height: 1.78;
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .group_governance img {
        margin: 0;
        width: 66.67vw;
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .group_store {
        display: flex;
        justify-content: center;
        align-items: top;
        flex-wrap: wrap;
        width: 100%;
        background: rgba(221, 221, 221, 0.4);
        padding: 23vw 0 10.67vw;
        position: relative;
        border-radius: 6px;
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .group_store h6 {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 13.33vw;
        font-size: 4.27vw;
        font-weight: 700;
        color: #fff;
        background: #E9AF39;
        border-radius: 6px 6px 0 0;
        position: absolute;
        left: 0;
        top: 0;
    }

    #page_retail .sec_management .inner .inner_box .img_wrap .group_store img {
        margin: 2.67vw auto 0;
        width: 58.67vw;
    }


    /* 220609 ここから */
    #page_retail .sec_management .newModel_wrap,
    #page_retail .sec_management .reuse_wrap {
        margin-top: 18.67vw;
        position: relative;
    }

    #page_retail .sec_management .newModel_wrap .inner h5,
    #page_retail .sec_management .reuse_wrap .inner h5 {
        font-size: 4.8vw;
        margin: 0 auto 5.33vw;
        line-height: 1.78;
    }

    #page_retail .sec_management .newModel_wrap .inner .inner_box,
    #page_retail .sec_management .reuse_wrap .inner .inner_box {
        margin: 0 auto;
        padding-bottom: 0;
    }

    #page_retail .sec_management .newModel_wrap .inner .inner_box .img_wrap,
    #page_retail .sec_management .reuse_wrap .inner .inner_box .img_wrap {
        padding: 0;
    }

    #page_retail .sec_management .newModel_wrap .inner .inner_box .img_wrap .img_box_2div {
        width: 100%;
        text-align: center;
    }

    #page_retail .sec_management .newModel_wrap .inner .inner_box .img_wrap .img_box_2div img {
        margin: 0;
    }

    #page_retail .sec_management .newModel_wrap .inner .inner_box .img_wrap .img_box_2div h6 {
        text-align: left;
        font-size: 4.27vw;
        font-weight: 700;
        margin-top: 1em;
    }

    #page_retail .sec_management .reuse_wrap .inner img {
        width: 100%;
        text-align: center;
        margin: 8vw auto 0;
    }

    #page_retail .sec_management .reuse_wrap .inner img.surugaya {
        width: 66.93vw;
        margin: 0 auto 5.33vw;
    }

    /* 220609 ここまで */






    #page_retail .sec_newBusiness .inner .img_wrap {
        flex-wrap: wrap;
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div h5 {
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 4.27vw;
        font-weight: 700;
        height: 12.27vw;
        background: #E9AF39;
        color: #fff;
        margin: 0 0 2.67vw;
        border-radius: 6px;
        line-height: 1.78;
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div img {
        margin: 0 auto 5.33vw;
        background: #fff;
        display: block;
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div img:last-of-type {
        width: 60.27vw;
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 1.67vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        width: 53.2vw;
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div:last-child img:last-of-type {
        width: 66.93vw;
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div+.img_box_2div {
        margin-top: 9.33vw;
    }

    #page_retail .sec_relation .sec_ttl h3:after {
        background: #E9AF39;
    }

    #page_retail .sec_relation .inner ul li a {
        /* letter-spacing: -.02em; */
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {

    /* 220609 ここから */
    #page_retail .hero {
        background: url(../../../../uploads/2023/10/retail_mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }

    /* 220609 ここまで */

    #page_retail .sec_management .newModel_wrap .newModel_box .inner .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_retail .sec_newBusiness .inner .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }
}

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

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

 abroad ページ

-------------------------------- */
    #page_abroad .hero {
        background: url(../img/abroad/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_abroad .hero .hero_ttl h2 {
    }

    #page_abroad section .sec_ttl h3:after {
        background: #39AFE9;
    }

    #page_abroad .sec_businessArea .inner {
        width: 100%;
        justify-content: center;
    }

    #page_abroad .sec_businessArea .inner a {
        background: #39AFE9;
    }

    #page_abroad .sec_businessArea .inner a+a {
        margin-left: 1.33vw;
    }

    #page_abroad .sec_businessArea .inner a:nth-child(3),
    #page_abroad .sec_businessArea .inner a:nth-child(4) {
        margin-left: 0;
    }

    #page_abroad .sec_ttlArea h4 {
        margin-bottom: 0;
        font-size: 5.87vw;
    }

    #page_abroad .sec_ttlArea img {
        margin: 7vw auto 8vw;
        width: 40vw;
    }

    #page_abroad .sec_ttlArea p {
        text-align: justify;
        font-size: 3.73vw;
    }

    #page_abroad .sec_export {
        padding: 28vw 0 4vw;
    }

    #page_abroad .sec_export .inner img {
        margin: 0 auto 9.33vw;
        width: 100%;
    }

    #page_abroad .sec_export img {
        margin: 4vw auto 9.33vw;
        width: 100%;
    }

    #page_abroad .sec_export .inner a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 7vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1.43;
        margin: 8vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        width: 53.2vw;
        min-width: auto;
        min-height: auto;
    }

    #page_abroad .sec_export .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        margin: 0.08em 0.8em -0.08em 0;
    }

    #page_abroad .sec_export .inner .group_wrap {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-around;
        width: 100%;
        text-align: justify;
    }

    #page_abroad .sec_export .inner .group_wrap h4 {
        font-size: 4.8vw;
        margin-bottom: 10.67vw;
        line-height: 1.78;
        width: 100%;
        margin-top: 21.33vw;
    }

    #page_abroad .sec_export .inner .group_wrap .group_box {
        width: 100%;
    }

    #page_abroad .sec_export .inner .group_wrap .group_box+.group_box {
        margin-top: 6.33vw;
    }

    #page_abroad .sec_export .inner .group_wrap .group_box h5 {
        font-size: 4.27vw;
        font-weight: 700;
        margin-bottom: 0;
        line-height: 1;
        letter-spacing: normal;
        padding: 4vw;
    }

    #page_abroad .sec_export .inner .group_wrap .group_box dl {
        display: flex;
        font-size: 3.73vw;
        padding: 4vw 5.33vw;
        min-height: 32vw;
        min-height: auto;
    }

    #page_abroad .sec_export .inner .group_wrap .group_box dl dt {
        padding-right: 4vw;
    }

    #page_abroad .sec_export .inner .group_wrap .group_box dl dd {
        width: 75%;
        line-height: 2;
        padding-left: 4vw;
        min-height: auto;
    }

    #page_abroad .sec_import .inner .group_wrap {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-around;
        width: 100%;
        text-align: justify;
        margin: 10.67vw auto 0;
    }

    #page_abroad .sec_import .inner .group_wrap .group_box {
        width: 100%;
    }

    #page_abroad .sec_import .inner .group_wrap .group_box+.group_box {
        margin-top: 5.33vw;
    }

    #page_abroad .sec_import .inner .group_wrap .group_box h4 {
        font-size: 4.27vw;
        font-weight: 700;
        margin-bottom: 0;
        line-height: 1;
        letter-spacing: normal;
        padding: 4vw;
    }

    #page_abroad .sec_import .inner .group_wrap .group_box p {
        font-size: 3.73vw;
        background: rgba(221, 221, 221, .4);
        border-radius: 0 0 6px 6px;
        padding: 4vw 5.33vw;
        min-height: auto;
        box-sizing: border-box;
        text-align: left;
        letter-spacing: 0em;
        line-height: 2;
    }

    #page_abroad .sec_import .inner a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 7vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1.43;
        margin: 8vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        width: 53.2vw;
        min-width: auto;
        min-height: auto;
    }

    #page_abroad .sec_import .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        margin: 0.08em 0.8em -0.08em 0;
    }

    #page_abroad .sec_import img {
        margin: 4vw auto 9.33vw;
        width: 100%;
    }

    #page_abroad .sec_publication .flow_wrap {
        background: rgba(57, 175, 233, 0.15);
        padding: 13.33vw 0 10.67vw;
        margin-top: 13.33vw;
    }

    #page_abroad .sec_publication .flow_wrap .inner h4 {
        font-size: 4.8vw;
        margin-bottom: 0;
        line-height: 1.78;
    }

    #page_abroad .sec_publication .flow_wrap .inner picture {
        width: 100%;
    }

    #page_abroad .sec_publication .flow_wrap .inner picture img {
        width: 100%;
    }

    #page_abroad .sec_publication .inner p {
        margin-top: 1.67vw;
    }

    #page_abroad .sec_publication .inner img {
        width: 100%;
        margin: 4vw auto 5.33vw;
    }

    #page_abroad .sec_publication .inner a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 7vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1.43;
        margin: 8vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        width: 57.2vw;
        min-width: auto;
        min-height: auto;
    }

    #page_abroad .sec_publication .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        margin: 0.08em 0.8em -0.08em 0;
    }

    #page_abroad .sec_clubJapan .sec_ttl {
        padding: 0 3.47vw;
    }

    #page_abroad .sec_clubJapan .inner img {
        margin: 2vw auto 9.33vw;
        width: 100%;
    }

    #page_abroad .sec_clubJapan img {
        width: 100%;
        margin: 4vw auto 5.33vw;
    }

    #page_abroad .sec_clubJapan .inner p+p {
        margin-top: 5.33vw;
    }

    #page_abroad .sec_clubJapan .inner a {
        display: inline-block;
        position: relative;
        padding: 2.33vw 8vw 2.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1.43;
        margin: 8vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        letter-spacing: 0;
        text-align: left;
        min-width: auto;
        min-height: auto;
    }

    #page_abroad .sec_clubJapan .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_abroad .sec_relation .sec_ttl h3:after {
        background: #39AFE9;
    }

    #page_abroad .sec_relation .inner ul li a {
        /* letter-spacing: -.02em; */
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_abroad .hero {
        background: url(../img/abroad/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }

    #page_abroad .sec_clubJapan .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_abroad .sec_export .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        margin: 0.08em 0.8em -0.08em 0;
    }

    #page_abroad .sec_import .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        margin: 0.08em 0.8em -0.08em 0;
    }

    #page_abroad .sec_publication .inner a:before {
        content: '';
        position: relative;
        display: inline-block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background: url(/wp-content/themes/nippan/assets/img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        margin: 0.08em 0.8em -0.08em 0;
    }
}

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

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

 stationery ページ

-------------------------------- */
    #page_stationery .hero {
        background: url(../img/stationery/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_stationery .hero .hero_ttl h2 {
    }

    #page_stationery section .sec_ttl h3:after {
        background: #3CBE93;
    }

    #page_stationery .sec_businessArea .inner {
        width: 100vw;
    }

    #page_stationery .sec_businessArea .inner a {
        background: #3CBE93;
    }

    #page_stationery .sec_ttlArea h3 {
        margin-bottom: 0;
        font-size: 5.87vw;
    }

    #page_stationery .sec_ttlArea img {
        width: 40vw;
        margin: 9vw auto 8vw;
    }

    #page_stationery .sec_planning {
        padding: 28vw 0 2.67vw;
    }

    #page_stationery .sec_ttlArea p {
        text-align: justify;
        font-size: 3.73vw;
    }

    #page_stationery .sec_planning img {
        margin: 4vw auto 9.33vw;
        width: 100%;
    }

    #page_stationery .sec_planning .inner {
        display: block;
    }

    #page_stationery .sec_planning .inner p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        letter-spacing: normal;
    }

    #page_stationery .sec_directManagement .inner {
        display: block;
    }

    #page_stationery .sec_directManagement .inner p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        margin-top: 1vw;
        letter-spacing: normal;
    }

    #page_stationery .sec_directManagement .inner .img_wrap {
        margin-top: 6.67vw;
    }

    #page_stationery .sec_directManagement .inner .img_wrap .img_box_2div {
        text-align: justify;
    }

    #page_stationery .sec_directManagement .inner .img_wrap .img_box_2div h5 {
        font-size: 4.27vw;
        font-weight: 700;
        text-align: justify;
        margin: 1vw auto 0;
        line-height: 1.78;
    }

    #page_stationery .sec_directManagement .inner .img_wrap .img_box_2div h5 span {
        display: block;
        font-size: 3.73vw;
        margin: 4vw auto 0vw;
    }

    #page_stationery .sec_directManagement .inner .img_wrap .img_box_2div p {
        text-align: justify;
        margin-top: 2vw;
    }

    #page_stationery .sec_directManagement .inner .img_wrap .img_box_2div a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 8vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        left: 50%;
        transform: translateX(-50%);
    }

    #page_stationery .sec_directManagement .inner .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_stationery .sec_directManagement .slider_wrap {
        margin-bottom: 15.33vw;
    }

    #page_stationery .sec_directManagement .slider_wrap h4 {
        font-size: 4.8vw;
        font-weight: 700;
        margin: 18.67vw auto 40vw;
        line-height: 1.78;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider {
        margin: 0;
        width: 100%;
        position: relative;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide {
        margin: 0 3vw;
        width: 94vw;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide img {
        width: 100%;
        margin: 0 auto 5.33vw;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide h5 {
        font-size: 4.27vw;
        font-weight: 700;
        text-align: center;
        margin: 5.33vw auto 0;
        opacity: 0;
        transition: .5s;
        line-height: 1.78;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide h6 {
        text-align: center;
        font-weight: 700;
        margin: 4vw auto 2.67vw;
        font-size: 3.73vw;
        opacity: 0;
        transition: .5s;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide p {
        text-align: justify;
        font-family: "Noto Sans JP", sans-serif;
        font-size: 3.73vw;
        /* letter-spacing: 0em; */
        margin-bottom: 0;
        opacity: 0;
        transition: .5s;
        letter-spacing: normal;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide.slick-active h5 {
        opacity: 1;
        line-height: 1.78;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide.slick-active h6 {
        opacity: 1;
        line-height: 1.78;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide.slick-active p {
        opacity: 1;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide-dots {
        text-align: center;
        position: absolute;
        width: 100%;
        height: auto;
        display: flex;
        justify-content: center;
        align-self: center;
        flex-wrap: wrap;
        top: -30vw;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li {
        display: block;
        padding: 0 2.67vw;
        font-size: 3.73vw;
        line-height: 1;
        border-left: 1px solid #000;
        border-right: 1px solid #000;
        /* letter-spacing: 0; */
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li button {
        display: none;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li+li {
        margin-top: 4vw;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li:first-child:before {
        content: 'DULTON JIYUGAOKA';
        display: block;
        position: relative;
        line-height: 1;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li:nth-child(2):before {
        content: 'DULTON MARKET STORE　グランベリーパーク店';
        display: block;
        position: relative;
        line-height: 1;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slide-dots li:last-child:before {
        content: 'DULTON FACTORY SERVICE OSAKA';
        display: block;
        position: relative;
        line-height: 1;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slick-next {
        z-index: 99;
        right: 2.67vw;
        transform: none;
        left: unset;
    }

    #page_stationery .sec_directManagement .slider_wrap .slider .slick-prev {
        z-index: 99;
        left: 50%;
        transform: translateX(-47.33vw);
    }

    #page_stationery .sec_directManagement .slider_wrap .slick-prev:before,
    #page_stationery .sec_directManagement .slider_wrap .slick-next:before {
        color: #464646;
        display: none;
    }

    #page_stationery .sec_directManagement .slider_wrap .slick-next {
        background: url(../img/common/right-arrow.png);
        background-size: 8vw 8vw;
        z-index: 99;
        width: 8vw;
        height: 8vw;
        top: 19%;
    }

    #page_stationery .sec_directManagement .slider_wrap .slick-prev {
        background: url(../img/common/left-arrow.png);
        background-size: 8vw 8vw;
        z-index: 99;
        width: 8vw;
        height: 8vw;
        top: 19%;
    }

    #page_stationery .sec_directManagement .slider_wrap .slick-dotted.slick-slider {
        margin-bottom: 0;
    }

    #page_stationery .sec_contract img {
        margin: 5.33vw auto 9.33vw;
        width: 100%;
    }

    #page_stationery .sec_contract .inner {
        display: block;
    }

    #page_stationery .sec_contract .inner p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        letter-spacing: normal;
    }

    #page_stationery .sec_relation .sec_ttl h3:after {
        background: #3CBE93;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_stationery .hero {
        background: url(../img/stationery/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }

    #page_stationery .sec_directManagement .inner .img_wrap .img_box_2div a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_stationery .sec_directManagement .slider_wrap .slick-next {
        background: url(../img/common/right-arrow@2x.png);
        background-size: 8vw 8vw;
        z-index: 99;
        width: 8vw;
        height: 8vw;
        top: 19%;
    }

    #page_stationery .sec_directManagement .slider_wrap .slick-prev {
        background: url(../img/common/left-arrow@2x.png);
        background-size: 8vw 8vw;
        z-index: 99;
        width: 8vw;
        height: 8vw;
        top: 19%;
    }
}

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

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

 contents ページ

-------------------------------- */
    #page_contents .hero {
        background: url(../img/contents/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_contents .hero .hero_ttl h2 {
    }

    #page_contents section .sec_ttl h3:after {
        background: #E987A8;
    }

    #page_contents .sec_businessArea .inner {
        width: 100vw;
    }

    #page_contents .sec_businessArea .inner a {
        background: #E987A8;
    }

    #page_contents .sec_ttlArea h3 {
        margin-bottom: 0;
        font-size: 5.87vw;
    }

    #page_contents .sec_ttlArea img {
        width: 41vw;
        margin: 7vw auto 8vw;
    }

    #page_contents .sec_ttlArea p {
        text-align: justify;
        font-size: 3.73vw;
    }

    #page_contents .sec_deployment {
        padding: 0 0 6.67vw;
    }

    #page_contents .sec_deployment .label_wrap .inner {
        padding-bottom: 0;
        margin: 0 auto;
    }

    #page_contents .sec_deployment .label_wrap .inner h4 {
        font-size: 4.8vw;
        margin: 10.67vw auto 6.33vw;
        line-height: 1.78;
    }

    #page_contents .sec_deployment .label_wrap .inner img {
        width: 100%;
    }

    #page_contents .sec_ebook {
        padding-top: 11.33vw;
    }

    #page_contents .sec_ebook .label_wrap {
        background: rgba(233, 135, 168, 0.15);
    }

    #page_contents .sec_ebook .label_wrap .inner {
        padding-bottom: 16vw;
        margin: 0 auto;
        width: 100%;        
    }

    #page_contents .sec_ebook .label_wrap .inner h4 {
        font-size: 4.8vw;
        margin: 14.67vw auto 8.33vw;
        line-height: 1.78;
    }

    #page_contents .sec_ebook .label_wrap .inner .img_wrap {
        margin-top: 8.33vw;
    }
    
    #page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div {
    width: 45.33vw;
}
    
    #page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div img {
        margin: 0 auto;
        width: 100%;
        background: transparent;
    }

    #page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div h5 {
        margin: 4vw auto 0;
        text-align: center;
        font-size: 3.73vw;
    }

    #page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div p {
        text-align: center;
    }

    #page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div+.img_box_3div {
        margin-top: 3.2vw;
    }
    
    #page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div:nth-child(1),
     #page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div:nth-child(2){
        margin-top: 0;
    }
    
     #page_contents .sec_ebook .label_wrap .inner .img_wrap .img_box_3div:last-child {
        margin: 3.2vw auto 0;
    }
    
     #page_contents .sec_ebook .label_wrap .inner > a {
         display: inline-block;
         position: relative;
         padding: 5.33vw 8vw 5.33vw 7vw;
         border-radius: 100px;
         font-size: 3.73vw;
         font-weight: 700;
         line-height: 1.43;
         margin: 12vw 0 1.33vw;
         border: 2px solid #004B9E;
         color: #004B9E;
         width: 73.2vw;
         min-width: auto;
         min-height: auto;
     }
    
     #page_contents .sec_ebook .label_wrap .inner > a:before {
         content: '';
         position: relative;
         display: inline-block;
         width: 3.73vw;
         height: 3.33vw;
         background: url(../img/common/icon_link@2x.png) center center no-repeat;
         background: url(/wp-content/themes/nippan/assets/img/common/icon_link@2x.png) center center no-repeat;
         background-size: 3.73vw 3.33vw;
         margin: 0.08em 0.8em -0.08em 0;
     }

    #page_contents .sec_relation .sec_ttl h3:after {
        background: #E987A8;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_contents .hero {
        background: url(../img/contents/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 entertainment ページ

-------------------------------- */
    #page_entertainment .hero {
        background: url(../img/entertainment/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_entertainment .hero .hero_ttl h2 {
    }

    #page_entertainment section .sec_ttl h3:after {
        background: #DB5266;
    }

    #page_entertainment .sec_businessArea .inner {
        width: 64vw;
    }

    #page_entertainment .sec_businessArea .inner a {
        background: #DB5266;
    }

    #page_entertainment .sec_ttlArea h3 {
        margin-bottom: 0;
        font-size: 5.87vw;
        letter-spacing: -.02em;
    }

    #page_entertainment .sec_ttlArea img {
        width: 45.33vw;
        margin: 7vw auto 8vw;
    }

    #page_entertainment .sec_ttlArea p {
        text-align: justify;
        font-size: 3.73vw;
    }

    #page_entertainment .sec_test {
        padding: 28vw 0 2.67vw;
    }

    #page_entertainment section .inner {
        display: block;
    }

    #page_entertainment section .inner h4 {
        letter-spacing: -.01em;
        margin-top: 2vw;
        /* letter-spacing: normal; */
    }

    #page_entertainment section .inner p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        letter-spacing: normal;
    }

    #page_entertainment section .inner .inner_box .img_wrap .img_box_3div img {
        margin: 0 auto;
    }

    #page_entertainment section .inner .inner_box .img_wrap .img_box_3div a {
        margin: 8vw auto 6vw;
        width: 59.67vw;
    }

    #page_entertainment section .inner .inner_box .img_wrap .img_box_3div a:before {
        content: '';
        left: 8vw;
    }

    #page_entertainment section .inner .inner_box .img_wrap .img_box_3div:first-child a:before {
        content: '';
        left: 17.8vw;
    }

    #page_entertainment section .inner .inner_box .img_wrap .img_box_3div:last-child a:before {
        content: '';
        left: 13.8vw;
    }

    #page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div a {
        width: 48vw;
    }

    #page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div a:before {
        content: '';
        left: 8.5vw;
    }

    #page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div:first-child a:before {
        content: '';
        left: 10vw;
    }

    #page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div:last-child a:before {
        content: '';
        left: 10vw;
    }

    #page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div p {
        font-size: 3.73vw;
        margin-top: 0;
        margin-bottom: 5.33vw;
    }

    #page_entertainment .sec_event .inner:last-child .inner_box .img_wrap .img_box_3div:last-child p {
        margin-bottom: 0;
    }

    #page_entertainment section .inner .inner_box .img_wrap .img_box_3div+.img_box_3div {
        margin-top: 5.33vw;
    }

    #page_entertainment section .inner .inner_box .img_wrap.points .img_box_3div img {
        width: 84.8vw;
    }

    #page_entertainment section img {
        margin: 5.33vw auto 9.33vw;
        width: 100%;
    }

    #page_entertainment .sec_relation .sec_ttl h3:after {
        background: #DB5266;
    }

    #page_entertainment .sec_relation .inner {
        display: flex;
        position: relative;
        align-items: center;
        justify-content: center;
    }

    #page_entertainment .sec_event {
        padding: 23.33vw 0 2.67vw;
    }

    #page_entertainment .sec_relation {
        padding-top: 23.33vw;
    }

    #page_entertainment section .inner .inner_box .portal_wrap {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    #page_entertainment section .inner .inner_box .portal_wrap img {
        width: 40vw;
        margin-top: 0;
    }

    #page_entertainment section .inner .inner_box .portal_wrap a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 0 5.33vw 8vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 0 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        width: 59.67vw;
    }

    #page_entertainment section .inner .inner_box .portal_wrap a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 7vw;
        transform: translateY(-50%);
    }

}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_entertainment .hero {
        background: url(../img/entertainment/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }

    #page_entertainment section .inner .inner_box .portal_wrap a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 7vw;
        transform: translateY(-50%);
    }
}

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

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

 newbusiness ページ

-------------------------------- */
    #page_newbusiness .hero {
        background: url(../img/newbusiness/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_newbusiness .hero .hero_ttl h2 {
    }

    #page_newbusiness section .sec_ttl h3:after {
        background: #26B4BE;
    }

    #page_newbusiness .sec_businessArea .inner {
        width: 79vw;
    }

    #page_newbusiness .sec_businessArea .inner a {
        background: #26B4BE;
    }

    #page_newbusiness .sec_ttlArea h3 {
        /* letter-spacing: -.03em; */
        font-size: 5.87vw;
    }

    #page_newbusiness .sec_ttlArea p {
        font-size: 3.73vw;
        text-align: justify;
    }

    #page_newbusiness .sec_bookHotel {
        padding: 28vw 0 2.67vw;
    }

    #page_newbusiness section img {
        margin: 5.33vw auto 9.33vw;
        width: 100%;
    }
    
    #page_newbusiness section figure {
        margin: 5.33vw auto 9.33vw;
    }
    
    #page_newbusiness section figure figcaption {
        font-size: 2.67vw;
    }

    #page_newbusiness section .inner {
        display: block;
    }

    #page_newbusiness section .inner h4 {
        /* letter-spacing: -.1em; */
        margin-top: 2vw;
    }

    #page_newbusiness section .inner img {
        width: 42.67vw;
        margin-top: 2vw;
    }

    #page_newbusiness section .inner p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        letter-spacing: normal;
    }

    #page_newbusiness section .inner .inner_box .img_wrap .img_box_2div {
        text-align: center;
    }

    #page_newbusiness section .inner .inner_box .img_wrap .img_box_2div img {
        width: 100%;
    }

    #page_newbusiness section .inner .inner_box .img_wrap .img_box_2div a {
        margin-top: 0;
        left: 0;
        transform: none;
        letter-spacing: .02em;
    }

    #page_newbusiness .sec_green .inner {
        display: block;
    }

    #page_newbusiness .sec_green .inner h4 {
        /* letter-spacing: 0em; */
    }

    #page_newbusiness .sec_green .inner img {
        width: 26.67vw;
    }

    #page_newbusiness .sec_relation .sec_ttl h3:after {
        background: #26B4BE;
    }

    #page_newbusiness .sec_relation .inner {
        display: flex;
        position: relative;
        align-items: center;
        justify-content: center;
    }

    #page_newbusiness .sec_relation .inner ul li a {
        /* letter-spacing: -.03em; */
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_newbusines .hero {
        background: url(../img/newbusines/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 shared ページ

-------------------------------- */
    #page_shared .hero {
        background: url(../img/shared/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_shared .hero .hero_ttl h2 {
    }

    #page_shared section .sec_ttl h3:after {
        background: #AE9C67;
    }

    #page_shared .sec_businessArea .inner {
        width: 87vw;
    }

    #page_shared .sec_businessArea .inner a {
        background: #AE9C67;
    }

    #page_shared .sec_ttlArea h3 {
        /* letter-spacing: 0; */
        font-size: 5.87vw;
    }

    #page_shared .sec_ttlArea p {
        font-size: 3.73vw;
        text-align: justify;
    }

    #page_shared .sec_ttlArea img {
        margin: 0 auto 8vw;
        width: 34.67vw;
    }

    #page_shared .sec_sharedService {
        padding: 28vw 0 2.67vw;
    }

    #page_shared section img {
        margin: 5.33vw auto 9.33vw;
        width: 100%;
    }

    #page_shared section .inner {
        display: block;
    }

    #page_shared section .inner h4 {
        margin-top: 2vw;
    }

    #page_shared section .inner img {
        width: auto;
    }

    #page_shared section .inner p {
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        text-align: justify;
        letter-spacing: normal;
    }

    #page_shared section .inner .inner_box .img_wrap .img_box_2div {
        text-align: center;
    }

    #page_shared section .inner .inner_box .img_wrap .img_box_2div a {
        margin-top: 0;
    }

    #page_shared .sec_staffService .inner a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 8vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
    }

    #page_shared .sec_staffService .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_shared .sec_relation .sec_ttl h3:after {
        background: #AE9C67;
    }

    #page_shared .sec_relation .inner {
        display: flex;
        position: relative;
        align-items: center;
        justify-content: center;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_shared .hero {
        background: url(../img/shared/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }

    #page_shared .sec_staffService .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }
}

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

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

 business-partners ページ

-------------------------------- */
    #page_business_partners {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_business_partners .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/business_partners/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_business_partners .sec_business_partners .sec_ttl h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_business_partners .sec_business_partners .sec_ttl h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #AE9C67;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_business_partners section .sec_ttl h2:after {
        background: #AE9C67;
    }

    #page_business_partners .sec_businessArea .inner {
        width: 87vw;
    }

    #page_business_partners .sec_businessArea .inner a {
        background: #AE9C67;
    }

    #page_business_partners .sec_ttlArea h2 {
        /* letter-spacing: -.11em; */
    }

    #page_business_partners .sec_ttlArea p {
        font-size: 3.73vw;
        text-align: justify;
    }

    #page_business_partners .sec_business_partners {
        margin-bottom: 0;
        padding: 21.33vw 0 14.33vw;
    }

    #page_business_partners .sec_business_partners .companyProf_wrap .inner {
        text-align: justify;
    }

    #page_business_partners .sec_business_partners .companyProf_wrap .inner img {
        position: relative;
        left: 50%;
        transform: translateX(-50%);
        margin-top: 2.67vw;
        width: 34.67vw;
    }

    #page_business_partners .sec_business_partners .companyProf_wrap .inner h3 {
        font-size: 4.8vw;
        font-weight: 700;
        margin: 11.67vw auto 10.67vw;
        text-align: center;
        line-height: 1.78;
    }

    #page_business_partners .sec_business_partners .companyProf_wrap .inner dl {
        display: flex;
        justify-content: flex-start;
        line-height: 2;
        font-size: 3.73vw;
        width: 100%;
        margin: auto;
    }

    #page_business_partners .sec_business_partners .companyProf_wrap .inner dl dt {
        width: 33.33vw;
        font-weight: 700;
        margin-bottom: 5.33vw;
        /* letter-spacing: 0em; */
    }

    #page_business_partners .sec_business_partners .companyProf_wrap .inner dl dd {
        margin-bottom: 5.33vw;
        flex: 1;
        text-align: left;
        /* letter-spacing: 0em; */
        letter-spacing: normal;
    }

    #page_business_partners .sec_business_partners .companyProf_wrap .inner dl dd a {
        color: #004B9E;
        margin: 1vw 0 2vw;
        font-size: 3.73vw;
        text-decoration: underline;
    }

    #page_business_partners .sec_business_partners .access_wrap {
        background: rgba(174, 156, 103, 0.15);
        padding: 13.33vw 0 16vw;
        margin-top: 17.33vw;
    }

    #page_business_partners .sec_business_partners .access_wrap .inner {
        padding: 0 3.47vw;
    }

    #page_business_partners .sec_business_partners .access_wrap .inner h3 {
        font-size: 4.8vw;
        font-weight: 700;
        margin: 2vw auto 10.67vw;
        text-align: center;
        line-height: 1.78;
    }

    #page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div {
        display: flex;
        justify-content: center;
        flex-direction: column;
        align-items: center;
        width: 100%;
    }

    #page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div h4 {
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 10.67vw;
        height: auto;
        font-size: 3.73vw;
        font-weight: 700;
        color: #fff;
        background: #AE9C67;
        border-radius: 6px;
        margin: 0;
        padding: 2vw 0;
        line-height: 1.78;
    }

    #page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div .txt_box {
        height: auto;
        padding: 8vw 0;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    #page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div .txt_box p {
        font-size: 3.73vw;
        line-height: 1.57;
        text-align: justify;
        /* letter-spacing: 0em; */
    }

    #page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div iframe {
        width: 100%;
        height: 56vw;
    }

    #page_business_partners .sec_business_partners .access_wrap .inner .img_wrap .img_box_2div+.img_box_2div {
        margin-top: 16vw;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap {
        padding: 13.33vw 0 15vw;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner {
        text-align: justify;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner h3 {
        font-size: 4.8vw;
        font-weight: 700;
        margin: 2vw auto 10.67vw;
        text-align: center;
        line-height: 1.78;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner dl {
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        line-height: 2;
        font-size: 3.73vw;
        width: 100%;
        margin: auto;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner dl dt {
        font-weight: 700;
        margin-bottom: 3.33vw;
        line-height: 1.75;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner dl dt:before {
        content: '';
        display: inline-block;
        width: 2.67vw;
        height: 2.67vw;
        background: #AE9C67;
        margin-right: .5em;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner dl dd {
        margin-bottom: 3.33vw;
        /* letter-spacing: 0em; */
        margin-left: 1.3em;
        line-height: 1.75;
        letter-spacing: normal;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner dl dd p {
        text-align: justify;
        line-height: 1.75;
        font-size: 3.73vw;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner dl dd p span {
        font-weight: 700;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner dl dd p+p {
        margin-top: 2vw;
    }

    #page_business_partners .sec_business_partners .dispatch_wrap .inner dl:nth-child(5) dd {
        width: 100%;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_business_partners .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/business_partners/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 it ページ

-------------------------------- */
    #page_it .hero {
        background: url(../img/it/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_it .hero .hero_ttl h2 {
    }

    #page_it section .sec_ttl h3:after {
        background: #937FD7;
    }

    #page_it .sec_businessArea .inner {
        width: 87vw;
    }

    #page_it .sec_businessArea .inner a {
        background: #937FD7;
    }

    #page_it .sec_ttlArea h3 {
        /* letter-spacing: -.04em; */
        font-size: 5.87vw;
    }

    #page_it .sec_ttlArea p {
        font-size: 3.73vw;
        text-align: justify;
    }

    #page_it .sec_itShared {
        padding: 28vw 0 2.67vw;
    }

    #page_it section img {
        margin: 5.33vw auto 9.33vw;
        width: 100%;
    }

    #page_it section .inner {
        display: block;
    }

    #page_it section .inner h4 {
        margin-top: 2vw;
    }

    #page_it section .inner img {
        margin: 5.33vw auto 9.33vw;
        width: 100%;
    }

    #page_it section .inner p {
        text-align: justify;
        /* letter-spacing: .03em; */
        font-size: 3.73vw;
        letter-spacing: normal;
    }

    #page_it section .inner p.lead {
        font-size: 3.73vw;
    }

    #page_it section .inner .inner_box {
        margin-top: 14.67vw;
    }

    #page_it section .inner .inner_box .img_wrap .img_box_2div {
        text-align: center;
    }

    #page_it section .inner .inner_box .img_wrap .img_box_2div a {
        margin-top: 0;
    }

    #page_it section .inner .inner_box .img_wrap .img_box_2div:first-child a {
        letter-spacing: 0;
    }

    #page_it .sec_publishingSolution .conteo_wrap {
        background: rgba(147, 127, 215, 0.1);
        padding: 14.67vw 0;
        margin-top: 16vw;
    }

    #page_it .sec_publishingSolution .conteo_wrap .inner h5 {
        font-size: 4.8vw;
        font-weight: 700;
        margin-bottom: 2.67vw;
        line-height: 1.78;
    }

    #page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        width: 100%;
        margin: auto;
    }
    
    #page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner .conteo_box {
        width: 100%;
        margin-bottom: 2.67vw;
        padding: 8vw 6.67vw;
    }

#page_it .sec_publishingSolution .conteo_wrap .inner img.conteo_logo {
    width: 83.47vw;
    margin-top:  5.33vw;
}

#page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner .conteo_box .conteo_ttl {
    font-size: 4.27vw;
    text-align: center;
    margin-top: 4vw;
}

#page_it .sec_publishingSolution .conteo_wrap .inner .conteo_inner .conteo_box p {
    font-size: 3.73vw;
    margin-top: 4vw;
}

    #page_it .sec_publishingSolution .conteo_wrap .inner a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 8vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
    }

    #page_it .sec_publishingSolution .conteo_wrap .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_it .sec_newtechSolution .inner .inner_box .img_wrap .img_box_2div img {
        margin-top: 0;
    }

    #page_it .sec_newtechSolution .inner .inner_box .img_wrap .img_box_2div a {
        padding: 2.33vw 8vw 2.33vw 15vw;
        line-height: 1.43;
        border-radius: 100px;
        text-align: justify;
        left: 0;
        transform: none;
    }

    #page_it .sec_newtechSolution .inner .inner_box .img_wrap .img_box_2div a br.only-sp {
        line-height: 0;
    }

    #page_it .sec_fullscopeSolution .inner .inner_box {
        width: 100%;
        margin-top: 7.67vw;
    }

    #page_it .sec_fullscopeSolution .inner .inner_box img {
        margin: 7vw auto 2.33vw;
    }

    #page_it .sec_fullscopeSolution .inner a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 8vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
    }

    #page_it .sec_fullscopeSolution .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_it .sec_relation .sec_ttl h3:after {
        background: #937FD7;
    }

    #page_it .sec_relation .inner {
        display: flex;
        position: relative;
        align-items: center;
        justify-content: center;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_it .hero {
        background: url(../img/it/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }

    #page_it .sec_publishingSolution .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    #page_it .sec_fullscopeSolution .inner a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }
}

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

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

 news_information　ページ

-------------------------------- */
    #page_news_information {
        padding: 16vw 0 0;
        /* margin-top: 0; */
    }

    #page_news_information section.hero {
        padding: 21.33vw 0 60px;
    }

    #page_news_information section.hero .hero_ttl h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_news_information section.hero .hero_ttl h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_news_information .sec_news_information {
        padding: 21.33vw 0 40vw;
    }

    #page_news_information .sec_news_information .inner {
        width: 100%;
    }

    #page_news_information .sec_news_information .inner h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
        /* letter-spacing: -.05em; */
    }

    #page_news_information .sec_news_information .inner h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_news_information .sec_news_information .inner a.btn {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 700;
        border: 2px solid #004B9E;
        border-radius: 100px;
        width: 80vw;
        height: 16vw;
        text-align: center;
        margin: auto;
        color: #004B9E;
        margin: 5.67vw auto 0;
    }

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

 news_information_article　ページ

-------------------------------- */
    #page_news_information_article {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_news_information_article .sec_news_information_article {
        padding: 21.33vw 0 29vw;
    }

    #page_news_information_article .sec_news_information_article .inner {
        width: 100%;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box {
        margin-bottom: 8vw;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box p {
        display: inline-block;
        font-size: 3.73vw;
        margin-right: 4vw;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span {
        display: inline-block;
        padding: .5vw 1vw;
        min-width: 25.33vw;
        font-size: 2.67vw;
        line-height: 1;
        text-align: center;
        min-width: 24vw;
        color: #004B9E;
        border: 1px solid #004B9E;
        border-radius: 3px;
        box-sizing: border-box;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.agency_tag {
        background: #176DE6;
        color: #fff;
        border: 1px solid #176DE6;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.retail_tag {
        background: #E9AF39;
        color: #fff;
        border: 1px solid #E9AF39;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.abroad_tag {
        background: #39AFE9;
        color: #fff;
        border: 1px solid #39AFE9;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.stationery_tag {
        background: #3CBE93;
        color: #fff;
        border: 1px solid #3CBE93;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.contents_tag {
        background: #E987A8;
        color: #fff;
        border: 1px solid #E987A8;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.entertainment_tag {
        background: #DB5266;
        color: #fff;
        border: 1px solid #DB5266;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.newbusiness_tag {
        background: #26B4BE;
        color: #fff;
        border: 1px solid #26B4BE;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.shared_tag {
        background: #AE9C67;
        color: #fff;
        border: 1px solid #AE9C67;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.it_tag {
        background: #937FD7;
        color: #fff;
        border: 1px solid #937FD7;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.hd_tag {
        background: #B2B2B2;
        color: #fff;
        border: 1px solid #B2B2B2;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span.esg_tag {
        background: #BBF5B3;
        color: #007E67;
        border: 1px solid #BBF5B3;
    }

    #page_news_information_article .sec_news_information_article .inner .date_box span+span {
        margin-left: 1.07vw;
    }

    #page_news_information_article .sec_news_information_article .inner h1 {
        font-size: 5.33vw;
        margin-bottom: 8vw;
        position: relative;
        font-weight: 700;
        line-height: 1.6;
    }

    #page_news_information_article .sec_news_information_article .inner h1:after {
        content: '';
        display: block;
        position: absolute;
        width: 100%;
        height: 2px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 8vw auto 20vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box {
        position: relative;
        margin: 24vw 0 0;
        width: 100%;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box h2 {
        font-size: 4.8vw;
        font-weight: 700;
        line-height: 1.62;
        text-indent: -2.25em;
        padding-left: 2.25em;
        margin: 21.33vw 0 13.33vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box h2:before {
        content: '';
        display: inline-block;
        width: 4vw;
        height: 4vw;
        background: #004B9E;
        margin-right: .5em;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box h3 {
        font-size: 4.27vw;
        font-weight: 700;
        line-height: 1.6;
        margin-top: 13.33vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box h4 {
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1.6;
        margin-top: 13.33vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box p {
        margin: 5.33vw 0 13.33vw;
        font-size: 3.73vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box p+p {
        margin-top: -5.33vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box dl {
        display: flex;
        line-height: 2;
        margin-top: 5.33vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box dl dt {
        font-size: 3.73vw;
        width: 33.33vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box dl dd {
        font-size: 3.73vw;
        flex: 1;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box dl dd.a_hover {
        color: rgba(0, 75, 158, 0.7);
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box a {
        font-size: 3.73vw;
        color: #004B9E;
        text-decoration: underline;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box a:hover {
        color: rgba(0, 75, 158, 0.7);
        text-decoration: none;
        opacity: 1;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box blockquote {
        margin-top: 5.33vw;
        border: 1px solid #ddd;
        border-radius: 6px;
        line-height: 2;
        padding: 4vw;
        font-size: 3.73vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box ol {
        list-style-type: decimal;
        padding-left: 1.5em;
        text-indent: 0em;
        line-height: 2;
        margin-top: 5.33vw;
        font-size: 3.73vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box ul {
        list-style-type: none;
        padding-left: 1.5em;
        text-indent: -1.2em;
        line-height: 2;
        margin-top: 5.33vw;
        font-size: 3.73vw;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box ul li:before {
        content: '';
        display: inline-block;
        width: 2.67vw;
        height: 2.67vw;
        border-radius: 100%;
        background: #000;
        margin-right: .5em;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box img {
        display: table;
        max-width: 100%;
        height: auto;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box figure {
        display: table;
        width: 100%;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box figure img {
        width: 100%;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box figure.pict_large {
        margin: 0 0 8vw 0;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box figure.pict_left {
        float: left;
        margin: 0 0 8vw 0;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box figure.pict_right {
        float: right;
        margin: 0 0 8vw 0;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box figure figcaption {
        font-size: 3.2vw;
        display: table-caption;
        caption-side: bottom;
        width: 100%;
        margin-top: 3 2.67vw;
        line-height: 1.57;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table {
        font-size: 3.73vw;
        border-collapse: separate;
        border-spacing: 0;
        table-layout: fixed;
        width: 100%;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table tr th {
        color: #fff;
        background: #004B9E;
        vertical-align: middle;
        font-weight: 700;
        text-align: center;
        border-bottom: 1px solid #ddd;
        border-collapse: separate;
        border-spacing: 0;
        padding: 4vw 0;
        width: 100%;
        display: block;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table tr th:last-child {
        border: none;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table tr td {
        vertical-align: middle;
        border-right: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
        border-left: 1px solid #ddd;
        border-collapse: separate;
        border-spacing: 0;
        text-align: justify;
        line-height: 1.3;
        padding: 4vw;
        width: 100%;
        display: block;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table tr:first-child th {
        border-radius: 6px 6px 0 0;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table tr:first-child td {
        border-top: none;
        border-collapse: separate;
        border-spacing: 0;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table tr:first-child td:last-child {
        border-radius: 0;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table tr:last-child th {
        border-radius: 0;
    }

    #page_news_information_article .sec_news_information_article .inner .inner_box table tr:last-child td:last-child {
        border-radius: 0 0 6px 6px;
    }

    #page_news_information_article .sec_news_information_article .inner a.btn {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 21.33vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        left: 50%;
        transform: translateX(-50%);
    }

    #page_news_information_article .sec_news_information_article .inner a.btn:before {
        content: '';
        position: absolute;
        display: block;
        width: 2vw;
        height: 2vw;
        border-top: 2px solid #004B9E;
        border-left: 2px solid #004B9E;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%) rotate(-45deg);
    }

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

 ir　ページ

-------------------------------- */
    #page_ir {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_ir .sec_irList {
        padding: 21.33vw 0 38vw;
    }

    #page_ir .sec_irList .sec_ttl {
        margin-bottom: 20vw;
    }

    #page_ir .sec_irList .sec_ttl h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_ir .sec_irList .sec_ttl h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_ir .sec_irList .sec_ttl h2 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_ir .sec_irList .content_box {
        display: flex;
        flex-wrap: wrap;
        margin-top: 0;
    }

    #page_ir .sec_irList .content_box li {
        width: 100%;
        height: auto;
        background: #004B9E;
        border-bottom: 2px solid #fff;
        box-sizing: border-box;
    }

    #page_ir .sec_irList .content_box li .img_box {
        height: auto;
        width: 100%;
        overflow: hidden;
        position: relative;
    }

    #page_ir .sec_irList .content_box li .img_box img {
        width: 100%;
        position: relative;
        top: 0;
        left: 0;
        transform: none;
    }

    #page_ir .sec_irList .content_box li .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: auto;
        padding: 10.67vw 0;
    }

    #page_ir .sec_irList .content_box li .txt_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        height: auto;
        padding: 10.67vw 0;
    }

    #page_ir .sec_irList .content_box li .txt_box span {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 600;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 56vw;
        box-sizing: border-box;
    }

    #page_ir .sec_irList .content_box li a .txt_box span {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 600;
        color: #004B9E;
        padding: 4.7vw 6.67vw;
        background: #fff;
        border-radius: 100px;
        z-index: 1;
        min-width: 56vw;
        box-sizing: border-box;
    }

    #page_ir .sec_irList .content_box li:nth-child(2) .txt_box span {
        padding: 4.7vw 6vw;
        letter-spacing: 0em;
    }

    #page_ir .sec_irList .content_box li:nth-child(3n-1) {
        border-right: none;
        border-left: none;
    }

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

 shareholders　ページ

-------------------------------- */
    #page_shareholders {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_shareholders .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/shareholders/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_shareholders .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_shareholders .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_shareholders .hero:after {
        content: '';
        display: none;
    }

    #page_shareholders .lead_wrap {
        width: 100%;
        margin: auto;
        padding: 21.33vw 3.47vw 0;
    }

    #page_shareholders .lead_wrap p {
        font-size: 3.73vw;
        text-align: center;
        line-height: 1.57;
    }

    #page_shareholders .sec_shareholders {
        padding: 16vw 3.47vw 0;
    }

    #page_shareholders .sec_shareholders .sec_ttl {
        margin-bottom: 20vw;
    }

    #page_shareholders .sec_shareholders .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_shareholders .sec_shareholders .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_shareholders .sec_shareholders .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_shareholders .sec_shareholders .inner {
        padding: 0;
    }

    #page_shareholders .sec_shareholders .inner dl {
        display: flex;
        justify-content: space-between;
        line-height: 2;
        text-align: justify;
    }

    #page_shareholders .sec_shareholders .inner dl dt {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
        width: 21.33vw;
        font-weight: 700;
        font-size: 3.2vw;
        color: #fff;
        background: #004B9E;
    }

    #page_shareholders .sec_shareholders .inner dl dd {
        width: 72vw;
        padding: 8vw 4vw;
        border: 1px solid #ddd;
        font-size: 3.73vw;
        line-height: 1.57;
    }

    #page_shareholders .sec_shareholders .inner dl dd a {
        display: block;
        font-size: 3.73vw;
        font-weight: 700;
        color: #004B9E;
        text-decoration: underline;
        line-height: 1.57;
    }

    #page_shareholders .sec_shareholders .inner dl dd a+a {
        margin-top: 6.67vw;
    }

    #page_shareholders .sec_shareholders .inner dl dd p {
        margin: 6.67vw 0;
        text-indent: -1em;
        padding-left: 1em;
        line-height: 1.57;
        font-size: 3.73vw;
    }

    #page_shareholders .sec_shareholders .inner dl.dl_single dd p {
        margin: 6.67vw 0 0;
        text-indent: -1em;
        padding-left: 1em;
        line-height: 1.57;
        font-size: 3.73vw;
    }

    #page_shareholders .sec_shareholders .inner dl:first-child dt {
        border-radius: 6px 0 0 0;
        border-bottom: 1px solid #ddd;
    }

    #page_shareholders .sec_shareholders .inner dl:first-child dd {
        border-radius: 0 6px 0 0;
    }

    #page_shareholders .sec_shareholders .inner dl:last-child dt {
        border-radius: 0 0 0 6px;
    }

    #page_shareholders .sec_shareholders .inner dl:last-child dd {
        border-radius: 0 0 6px 0;
    }

    #page_shareholders .sec_shareholders .inner dl+dl dd {
        border-top: none;
    }

    #page_shareholders .sec_shareholders .inner dl.dl_single dt {
        border-radius: 6px 0 0 6px;
    }

    #page_shareholders .sec_shareholders .inner dl.dl_single dd {
        border-radius: 0 6px 6px 0;
    }

    #page_shareholders .sec_shareholders:last-of-type {
        margin-bottom: 24.33vw;
    }

    #page_shareholders .note_wrap {
        margin-bottom: 38.67vw;
        padding: 0 3.47vw;
    }

    #page_shareholders .note_wrap .inner {
        margin: auto;
        background: #eee;
        padding: 8vw 8vw 11vw;
        border-radius: 6px;
    }

    #page_shareholders .note_wrap .inner p {
        text-align: justify;
        font-size: 3.73vw;
        line-height: 1.57;
    }

    #page_shareholders .note_wrap .inner img {
        width: 42.7vw;
        height: 10.4vw;
        margin-top: 30px;
        left: 50%;
        position: relative;
        transform: translateX(-50%);
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_shareholders .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/shareholders/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 financial_results　ページ

-------------------------------- */
    #page_financial_results {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_financial_results .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/financial_results/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_financial_results .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_financial_results .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_financial_results .hero:after {
        content: '';
        display: none;
    }

    #page_financial_results .sec_financial_results {
        padding: 21.33vw 3.47vw 0;
    }

    #page_financial_results .sec_financial_results .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_financial_results .sec_financial_results .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_financial_results .sec_financial_results .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_financial_results .sec_financial_results .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_financial_results .sec_financial_results .inner {
        padding: 2vw 0 0;
    }

    #page_financial_results .sec_financial_results .inner table {
        font-size: 3.73vw;
        width: 100%;
        border-collapse: separate;
        border-spacing: 0;
    }

    #page_financial_results .sec_financial_results .inner table thead tr td {
        color: #fff;
        background: #004B9E;
        height: 18.67vw;
        width: 46.67vw;
        vertical-align: middle;
        font-weight: 700;
    }

    #page_financial_results .sec_financial_results .inner table thead tr td:first-child {
        border-radius: 6px 0 0 0;
    }

    #page_financial_results .sec_financial_results .inner table thead tr td:last-child {
        border-radius: 0 6px 0 0;
    }

    #page_financial_results .sec_financial_results .inner table thead tr td+td {
        border-left: 1px solid #ddd;
        border-collapse: separate;
        border-spacing: 0;
    }

    #page_financial_results .sec_financial_results .inner table tr td {
        height: 21.33vw;
        width: 46.67vw;
        vertical-align: middle;
        border-collapse: separate;
        border-spacing: 0;
        border-right: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
    }

    #page_financial_results .sec_financial_results .inner table tr td:first-child {
        font-weight: 700;
        border-left: 1px solid #ddd;
        border-collapse: separate;
        border-spacing: 0;
    }

    #page_financial_results .sec_financial_results .inner table tr td a {
        display: block;
        font-size: 3.73vw;
        font-weight: 700;
        color: #004B9E;
        text-decoration: underline;
    }

    #page_financial_results .sec_financial_results .inner table tbody tr:last-child td:first-child {
        border-radius: 0 0 0 6px;
    }

    #page_financial_results .sec_financial_results .inner table tbody tr:last-child td:last-child {
        border-radius: 0 0 6px 0;
    }

    #page_financial_results .sec_financial_results .inner table thead tr:first-child td:first-child {
        border-radius: 6px 0 0 0;
    }

    #page_financial_results .sec_financial_results .inner table thead tr:first-child td:last-child {
        border-radius: 0 6px 0 0;
    }

    #page_financial_results .sec_transition {
        padding: 16vw 3.47vw 0;
        margin-bottom: 12vw;
    }

    #page_financial_results .sec_transition .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_financial_results .sec_transition .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_financial_results .sec_transition .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_financial_results .sec_transition .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_financial_results .sec_transition .inner {
        padding: 0 0 8vw;
    }

    #page_financial_results .sec_transition .inner h4 {
        font-size: 4.8vw;
        margin-bottom: 10.67vw;
        line-height: 1.72;
    }

    #page_financial_results .sec_transition .inner .unit {
        text-align: right;
        font-size: 3.2vw;
    }

    #page_financial_results .sec_transition .inner table {
        font-size: 2.93vw;
        border-collapse: separate;
        border-spacing: 0;
    }

    #page_financial_results .sec_transition .inner table thead tr td {
        color: #fff;
        background: #004B9E;
        height: 10.4vw;
        width: 16vw;
        vertical-align: middle;
        font-weight: 700;
    }

    #page_financial_results .sec_transition .inner table thead tr td:first-child {
        border-radius: 6px 0 0 0;
        border: none;
    }

    #page_financial_results .sec_transition .inner table thead tr td:last-child {
        border-radius: 0 6px 0 0;
    }

    #page_financial_results .sec_transition .inner table thead tr td+td {
        border-left: 1px solid #ddd;
        border-collapse: separate;
        border-spacing: 0;
    }

    #page_financial_results .sec_transition .inner table tr td {
        height: 14.67vw;
        width: 16vw;
        vertical-align: middle;
        border-right: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
        border-collapse: separate;
        border-spacing: 0;
        padding-right: 1vw;
        text-align: right;
        line-height: 1.3;
    }

    #page_financial_results .sec_transition .inner table tr td:first-child {
        background: #E5ECF5;
        font-weight: 700;
        border-left: 1px solid #ddd;
        border-collapse: separate;
        border-spacing: 0;
        padding-right: 0;
        text-align: center;
    }

    /* #page_financial_results .sec_transition .inner table tr:nth-child(2) td {
        padding-right: 0;
        text-align: center;
    } */

    #page_financial_results .sec_transition .inner table tbody tr:first-child td {
        text-align: center;
        padding: 0;
    }

    #page_financial_results .sec_transition .inner .link_wrap {
        text-align: justify;
        line-height: 2;
    }

    #page_financial_results .sec_transition .inner .link_wrap .link_box {
        margin: 5.33vw 0 8vw;
    }

    #page_financial_results .sec_transition .inner .link_wrap .link_box p {
        font-size: 3.73vw;
        line-height: 1.57;
    }

    #page_financial_results .sec_transition .inner .link_wrap .link_box a {
        display: inline-block;
        font-size: 3.73vw;
        font-weight: 700;
        color: #004B9E;
        text-decoration: underline;
        margin: 1.33vw 0;
    }

    #page_financial_results .sec_transition .inner .link_wrap .link_box:last-child p {
        text-indent: -1em;
        padding-left: 1em;
    }

    #page_financial_results .note_wrap {
        margin-bottom: 38.67vw;
        padding: 0 3.47vw;
    }

    #page_financial_results .note_wrap .inner {
        margin: auto;
        background: #eee;
        padding: 8vw 8vw 11vw;
        border-radius: 6px;
    }

    #page_financial_results .note_wrap .inner p {
        text-align: justify;
        font-size: 3.73vw;
        line-height: 1.57;
    }

    #page_financial_results .note_wrap .inner img {
        width: 42.7vw;
        height: 10.4vw;
        margin-top: 30px;
        left: 50%;
        position: relative;
        transform: translateX(-50%);
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_financial_results .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/financial_results/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 public_notice　ページ

-------------------------------- */
    #page_public_notice {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_public_notice .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/public_notice/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_public_notice .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_public_notice .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_public_notice .hero:after {
        content: '';
        display: none;
    }

    #page_public_notice .sec_public_notice {
        padding: 21.33vw 3.47vw 0;
        margin-bottom: 30vw;
    }

    #page_public_notice .sec_public_notice .inner {
        padding: 0 0 8vw;
    }

    #page_public_notice .sec_public_notice .inner p {
        font-size: 4.26vw;
        text-align: center;
        line-height: 1.57;
    }

    #page_public_notice .sec_public_notice .inner .inner_box {
        margin: 15vw auto 0;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_public_notice .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/public_notice/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 esg　ページ

-------------------------------- */
    #page_esg {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_esg .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/csr/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_esg .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_esg .hero .hero_ttl h2 {
        position: relative;
        display: inline-block;
        color: #fff;
        font-size: 5.33vw;
        font-weight: 700;
        background: #004B9E;
        min-width: 64vw;
        max-width: 94.67vw;
        padding: 4.8vw 7vw;
        line-height: 1;
    }

    #page_esg .hero:after {
        content: '';
        display: none;
    }

    #page_esg .sec_humanResources {
        padding: 21.33vw 0 0;
    }

    #page_esg .sec_humanResources .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_esg .sec_humanResources .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_esg .sec_humanResources .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_esg .sec_humanResources .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_esg .sec_humanResources .inner {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
    }

    #page_esg .sec_humanResources .inner h4 {
        position: relative;
        font-size: 4.8vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 14.67vw;
        line-height: 1.78;
        width: 100%;
        letter-spacing: normal;
    }

    #page_esg .sec_humanResources .inner .inner_box {
        width: 100%;
        background: #F0F7FF;
        padding: 8vw;
        border-radius: 6px;
        margin-bottom: 4vw;
    }

    #page_esg .sec_humanResources .inner .inner_box:last-child {
        margin-bottom: 0;
    }

    #page_esg .sec_humanResources .inner .inner_box img {
        margin-bottom: 8vw;
    }

    #page_esg .sec_humanResources .inner .inner_box h5 {
        font-size: 4.27vw;
        margin-bottom: 5.33vw;
        line-height: 1.78;
    }

    #page_esg .sec_humanResources .inner .inner_box p {
        text-align: justify;
        font-size: 3.73vw;
        /* letter-spacing: 0em; */
    }

    #page_esg .sec_environment {
        padding: 32vw 0 0;
    }

    #page_esg .sec_environment .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_esg .sec_environment .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_esg .sec_environment .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_esg .sec_environment .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_esg .sec_environment .inner {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
    }

    #page_esg .sec_environment .inner p {
        text-align: justify;
        font-size: 3.73vw;
        margin-top: 1.33vw;
    }

    #page_esg .sec_environment .inner p a {
        color: #004B9E;
        text-decoration: underline;
    }

    #page_esg .sec_environment .inner h4 {
        position: relative;
        font-size: 4.8vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 14.67vw;
        line-height: 1.78;
        width: 100%;
        letter-spacing: normal;
    }

    #page_esg .sec_environment .inner .inner_box {
        width: 100%;
        background: #F0F7FF;
        padding: 8vw;
        border-radius: 6px;
        margin-bottom: 4vw;
    }

    #page_esg .sec_environment .inner .inner_box img {
        margin-bottom: 8vw;
        width: 34.67vw;
    }

    #page_esg .sec_environment .inner .inner_box h5 {
        font-size: 4.27vw;
        margin-bottom: 5.33vw;
    }

    #page_esg .sec_environment .inner .inner_box p {
        text-align: justify;
        font-size: 3.73vw;
        /* letter-spacing: 0em; */
    }

    #page_esg .sec_environment .inner .inner_box+.inner_box {
        margin-left: 0;
    }

    #page_esg .sec_environment .inner .inner_box:nth-child(5) {
        margin-left: 0;
    }

    #page_esg .sec_socialContributions {
        padding: 32vw 0 24vw;
        margin-bottom: 0;
    }

    #page_esg .sec_socialContributions .sec_ttl {
        margin-bottom: 18vw;
    }

    #page_esg .sec_socialContributions .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_esg .sec_socialContributions .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_esg .sec_socialContributions .sec_ttl h3 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    #page_esg .sec_socialContributions .inner {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
    }

    #page_esg .sec_socialContributions .inner h4 {
        position: relative;
        font-size: 4.8vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 14.67vw;
        line-height: 1.78;
        width: 100%;
        letter-spacing: normal;
    }

    #page_esg .sec_socialContributions .inner .inner_box {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        flex-wrap: wrap;
        width: 100%;
        margin-bottom: 14.67vw;
    }

    #page_esg .sec_socialContributions .inner .inner_box .txt_box {
        text-align: justify;
        width: 100%;
    }

    #page_esg .sec_socialContributions .inner .inner_box .txt_box span {
        display: inline-block;
        background: #004B9E;
        padding: 1.33vw 4vw;
        color: #fff;
        border-radius: 6px;
        font-size: 3.73vw;
    }

    #page_esg .sec_socialContributions .inner .inner_box .txt_box h5 {
        font-size: 4.8vw;
        margin: 0 0 2vw;
        /* letter-spacing: 0em; */
        line-height: 1.78;
        letter-spacing: normal;
    }

    #page_esg .sec_socialContributions .inner .inner_box .txt_box p {
        text-align: justify;
        font-size: 3.73vw;
        margin-top: 0;
    }

    #page_esg .sec_socialContributions .inner .inner_box img {
        width: 100%;
        margin-top: 6.67vw;
    }

    #page_esg .sec_socialContributions .inner .inner_box:nth-child(2) .txt_box h5 {
        margin: 3.67vw 0 2vw;
        line-height: 1.78;
    }


    #page_esg .sec_movie {
        padding: 0 0 16vw;
    }

    #page_esg .sec_movie .inner {
        width: 89.33vw;
        padding: 0;
    }

    #page_esg .sec_movie .inner h3 {
        font-size: 5.33vw;
        margin-bottom: 5.33vw;
        position: relative;
        font-weight: 600;
    }

    #page_esg .sec_movie .inner .movie {
        margin: 8vw auto 0;
    }

    #page_esg .sec_movie .inner .movie:before {
        padding-top: 50.1vw;
    }

    #page_esg .sec_movie .inner .movie__btn {
        justify-content: center;
    }

  #page_esg .sec_movie .inner .movie__btn button {
    font-size: 3.73vw;
  }
  #page_esg .sec_movie .inner .movie__btn button:nth-child(1) {
    background: none;
    width: 7.2vw;
    height: 6.13vw;
    background: url(../img/esg/icon_mute.svg) center center no-repeat;
    background-size: 7.2vw 6.13vw;
  }
  #page_esg .sec_movie .inner .movie__btn.js_on button:nth-child(1) {
    background: none;
    width: 5.87vw;
    height: 4vw;
    background: url(../img/esg/icon_vol.svg) center center no-repeat;
    background-size: 5.87vw 4vw;
  }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_esg .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/csr/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }
}

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

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

 contact ページ

-------------------------------- */
    #page_contact {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_contact .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/contact/mv_sp.png) top center no-repeat;
        background-size: 100%;
    }

    #page_contact .hero .hero_ttl {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        width: 100%;
    }

    #page_contact .hero .hero_ttl h2 {
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 5.33vw;
        font-weight: 700;
        width: 64vw;
        height: 20.8vw;
        line-height: 1;
    }

    #page_contact .hero:after {
        content: '';
        display: none;
    }

    #page_contact .sec_area {
        padding: 21.33vw 0 2.67vw;
    }

    #page_contact .sec_area .sec_ttl {
        margin-bottom: 13.33vw;
    }

    #page_contact .sec_area .sec_ttl h3 {
        font-size: 5.33vw;
        margin-bottom: 0;
        position: relative;
    }

    #page_contact .sec_area .sec_ttl h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        left: 50%;
        transform: translateX(-50%);
        margin: 2.67vw auto 9.33vw;
    }

    #page_contact .sec_area .sec_ttl h3 span {
        display: block;
        font-size: 4.27vw;
        font-weight: 400;
    }

    #page_contact .sec_area .inner {
        width: 57vw;
        display: flex;
        justify-content: space-around;
        flex-wrap: wrap;
        margin: 0 auto;
    }

    #page_contact .sec_area .inner a {
        display: inline-block;
        font-size: 3.73vw;
        color: #fff;
        box-sizing: border-box;
        padding: 2.33vw 4vw;
        border: none;
        border-radius: 5px;
        text-align: center;
        margin-bottom: 1.67vw;
    }

    #page_contact .sec_area .inner a+a {
        margin-left: 0;
    }

    #page_contact .sec_ttlArea {
        padding: 21.33vw 3.47vw 4vw;
    }

    #page_contact .sec_ttlArea h3 {
        position: relative;
        font-size: 8vw;
        font-weight: 700;
        /* letter-spacing: 0; */
        margin-bottom: 9.33vw;
        line-height: 1.78;
        letter-spacing: normal;
    }

    #page_contact .sec_ttlArea p {
        text-align: center;
        font-size: 4.8vw;
    }

    #page_contact .sec_contact {
        padding: 21.33vw 0 1px;
    }

    #page_contact .sec_contact .inner h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_contact .sec_contact .inner h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_contact .sec_contact .inner p {
        margin-top: 18.33vw;
        font-size: 3.73vw;
        line-height: 1.75;
    }

    #page_contact .sec_contact .inner ul {
        margin-top: 14.67vw;
    }

    #page_contact .sec_contact .inner ul li {
        display: flex;
        align-items: center;
        border-bottom: 1px solid #ddd;
        box-sizing: border-box;
    }

    #page_contact .sec_contact .inner ul li .tag_box {
        width: 26.67vw;
        text-align: justify;
    }

    #page_contact .sec_contact .inner ul li .tag_box span {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 19.73vw;
        height: 12vw;
        padding: 0;
        text-align: center;
        color: #fff;
        border-radius: 6px;
        font-size: 3.2vw;
        font-weight: 700;
        line-height: 1.33;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.agency_tag {
        background: #176DE6;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.retail_tag {
        background: #E9AF39;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.abroad_tag {
        background: #39AFE9;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.stationery_tag {
        background: #3CBE93;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.contents_tag {
        background: #E987A8;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.entertainment_tag {
        background: #DB5266;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.newbusiness_tag {
        background: #26B4BE;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.shared_tag {
        background: #AE9C67;
    }

    #page_contact .sec_contact .inner ul li .tag_box span.it_tag {
        background: #937FD7;
    }

    #page_contact .sec_contact .inner ul li dl {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        line-height: 2;
        font-size: 4.27vw;
        width: 66.67vw;
        box-sizing: border-box;
        text-align: justify;
        padding: 8vw 0 0;
    }

    #page_contact .sec_contact .inner ul li dl dt {
        display: flex;
        justify-content: flex-start;
        align-items: center;
        font-weight: 700;
        margin-bottom: 1vw;
        width: 66.67vw;
        box-sizing: border-box;
        font-size: 4.27vw;
        /* letter-spacing: .01em; */
        box-sizing: border-box;
    }

    #page_contact .sec_contact .inner ul li dl dd {
        display: flex;
        justify-content: flex-start;
        align-items: center;
        flex-wrap: wrap;
        margin-bottom: 8vw;
        width: 66.67vw;
        box-sizing: border-box;
        font-size: 4.27vw;
    }

    #page_contact .sec_contact .inner ul li dl dd span {
        font-size: 3.73vw;
        padding-right: 2.33vw;
    }

    #page_contact .sec_contact .inner ul li dl dd a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 8vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 3vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
        /* letter-spacing: -.01em; */
    }

    #page_contact .sec_contact .inner ul li dl dd a.phone,
    #page_contact .sec_contact .inner ul li dl dd a.mail {
        display: inline-block;
        position: relative;
        padding: 0;
        border-radius: 0;
        font-size: 4.27vw;
        font-weight: 400;
        line-height: 1;
        margin: 0;
        border: none;
        color: #000;
        background: #fff;
        margin-left: 0;
        pointer-events: auto;
    }

    #page_contact .sec_contact .inner ul li dl dd+dt {
        border-top: 1px solid #ddd;
        padding-top: 8vw;
    }

    #page_contact .sec_contact .inner ul li dl dd+dt+dd {
        border-top: none;
        padding-top: 1vw;
    }

    #page_contact .sec_contact .inner ul li:first-of-type {
        border-top: 1px solid #ddd;
    }

    #page_contact .sec_contact .inner ul li dl dd .tel_wrap .tel_box p {
        letter-spacing: 0;
        font-size: 3.73vw;
        text-align: left;
        margin: 0 0 -7px 0;
        font-weight: 700;
    }

    #page_contact .sec_contact .inner ul li dl dd .tel_wrap .tel_box p.mailLine {
        margin: 0;
    }

    #page_contact .sec_contact .inner ul li dl dd .tel_wrap .tel_box p span {
        font-weight: 400;
    }

    #page_contact .sec_contact .inner ul li dl dd .tel_wrap .tel_box+.tel_box {
        margin-top: 10px;
    }


    #page_contact .sec_recruit {
        padding: 32vw 0 37.33vw;
    }

    #page_contact .sec_recruit .inner h3 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_contact .sec_recruit .inner h3:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_contact .sec_recruit .inner p {
        margin-top: 18.33vw;
        font-size: 3.73vw;
        line-height: 1.75;
    }

    #page_contact .sec_recruit .inner p.note {
        margin-top: 4vw;
    }

    #page_contact .sec_recruit .inner .recruit_wrap {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        margin-top: 14.67vw;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box {
        background: #F0F7FF;
        width: 100%;
        height: auto;
        padding: 8vw 5vw;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box {
        display: flex;
        flex-wrap: wrap;
        height: auto;
        text-align: justify;
        justify-content: flex-start;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 19.73vw;
        height: 12vw;
        padding: 0;
        text-align: center;
        color: #fff;
        border-radius: 6px;
        font-size: 3.2vw;
        line-height: 1.33;
        margin-bottom: 1.33vw;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.agency_tag {
        background: #176DE6;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.retail_tag {
        background: #E9AF39;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.abroad_tag {
        background: #39AFE9;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.stationery_tag {
        background: #3CBE93;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.contents_tag {
        background: #E987A8;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.entertainment_tag {
        background: #DB5266;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.newbusiness_tag {
        background: #26B4BE;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.shared_tag {
        background: #AE9C67;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span.it_tag {
        background: #937FD7;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span+span {
        margin-left: 1.33vw;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span:nth-child(3n+1) {
        margin-left: 1.33vw;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box .tag_box span:nth-child(4n+1) {
        margin-left: 0;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box a {
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 5.33vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:nth-child(2) a,
    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child a {
        min-width: auto;
        height: auto;
        box-sizing: border-box;
        display: inline-block;
        position: relative;
        padding: 5.33vw 8vw 5.33vw 15vw;
        border-radius: 100px;
        font-size: 3.73vw;
        font-weight: 700;
        line-height: 1;
        margin: 5.33vw 0 1.33vw;
        border: 2px solid #004B9E;
        color: #004B9E;
    }


    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }

    /*   #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child {
    width: 100%;
    margin-top: 5.33vw;
    padding: 8vw 5vw;
  } */

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:nth-child(2),
    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child {
        width: 100%;
        margin-top: 5.33vw;
        padding: 8vw 5vw;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child .tag_box {
        display: flex;
        align-items: center;
        justify-content: center;
    }

    #page_contact .sec_recruit .inner .recruit_wrap .recruit_box:last-child .tag_box span {
        margin-bottom: 0;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    #page_contact .hero {
        position: relative;
        padding: 0;
        height: 53.33vw;
        background: url(../img/contact/mv_sp@2x.png) top center no-repeat;
        background-size: 100%;
    }

    #page_contact .recruit_wrap .recruit_box a:before {
        content: '';
        position: absolute;
        display: block;
        width: 3.73vw;
        height: 3.33vw;
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 3.73vw 3.33vw;
        top: 50%;
        left: 8vw;
        transform: translateY(-50%);
    }
}

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

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

 プライバシーポリシー　ページ

-------------------------------- */
    #page_privacy {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_privacy .sec_privacy {
        padding: 21.33vw 0 38vw;
    }

    #page_privacy .sec_privacy .sec_ttl {
        margin-bottom: 18.67vw;
    }

    #page_privacy .sec_privacy .sec_ttl h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_privacy .sec_privacy .sec_ttl h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_privacy .sec_privacy .inner {
        padding: 0 3.47vw;
    }

    #page_privacy .sec_privacy .inner .txt_wrap p {
        text-align: justify;
        font-size: 3.73vw;
        line-height: 1.75;
    }

    #page_privacy .sec_privacy .inner .txt_wrap ul {
        text-align: justify;
        margin-top: 14.67vw;
    }

    #page_privacy .sec_privacy .inner .txt_wrap ul li {
        font-size: 3.73vw;
        font-weight: 700;
        text-indent: -2em;
        padding-left: 2em;
    }

    #page_privacy .sec_privacy .inner .txt_wrap ul li+li {
        margin-top: 8vw;
    }

    #page_privacy .sec_privacy .inner .txt_wrap .date_box {
        margin-top: 12vw;
    }

    #page_privacy .sec_privacy .inner .txt_wrap .date_box p {
        text-align: right;
    }

    #page_privacy .sec_privacy .inner .txt_wrap .signature_box {
        margin-top: 5.33vw;
    }

    #page_privacy .sec_privacy .inner .txt_wrap .signature_box p {
        text-align: right;
    }
    
            /* --------------------------------

 ウェブアクセシビリティポリシー　ページ

-------------------------------- */
    #page_accessibility {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_accessibility .sec_accessibility {
        padding: 21.33vw 0 38vw;
    }

    #page_accessibility .sec_accessibility .sec_ttl {
        margin-bottom: 18.67vw;
    }

    #page_accessibility .sec_accessibility .sec_ttl h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_accessibility .sec_accessibility .sec_ttl h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_accessibility .sec_accessibility .inner {
        padding: 0 3.47vw 26.67vw;
    }
    
        #page_accessibility .sec_accessibility .inner + .inner {
        padding-bottom: 0;
    }

    #page_accessibility .sec_accessibility .inner .txt_wrap p {
        text-align: justify;
        font-size: 3.73vw;
        line-height: 1.75;
    }

    #page_accessibility .sec_accessibility .inner .txt_wrap .date_box {
        margin-top: 12vw;
    }

    #page_accessibility .sec_accessibility .inner .txt_wrap .date_box p {
        text-align: right;
    }
    
    
    /* --------------------------------

 サイトマップ　ページ

-------------------------------- */
    #page_sitemap {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_sitemap .sec_sitemap {
        padding: 21.33vw 0 34vw;
    }

    #page_sitemap .sec_sitemap .inner h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    #page_sitemap .sec_sitemap .inner h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    #page_sitemap .sec_sitemap .inner ul {
        margin-top: 11.33vw;
        text-align: justify;
    }

    #page_sitemap .sec_sitemap .inner ul li {
        font-size: 3.73vw;
        border-radius: 6px;
        padding: 2.33vw 3.33vw;
    }

    #page_sitemap .sec_sitemap .inner ul li a {
        position: relative;
        padding: 0 0 0.7vw 4vw;
    }

    #page_sitemap .sec_sitemap .inner ul li a:before {
        content: '';
        display: block;
        position: absolute;
        width: 1.33vw;
        height: 1.33vw;
        top: 50%;
        left: 0px;
        border-top: 2px solid #004B9E;
        border-right: 2px solid #004B9E;
        transform: translateY(-60%) rotate(45deg);
    }

    #page_sitemap .sec_sitemap .inner ul li a+a {
        padding-left: 9.33vw;
        margin: 2.67vw 0;
        display: block;
    }

    #page_sitemap .sec_sitemap .inner ul li a+a:before {
        content: '';
        display: block;
        position: absolute;
        width: 2.67vw;
        height: 2px;
        top: 50%;
        left: 4vw;
        border: none;
        background: #004B9E;
        transform: translateY(-60%) rotate(0deg);
    }

    #page_sitemap .sec_sitemap .inner ul li:first-child {
        background: #004B9E;
        padding: 1.7vw 3.2vw 1.87vw;
        font-weight: 700;
        color: #fff;
        margin-bottom: 4vw;
    }

    #page_sitemap .sec_sitemap .inner ul li:first-child a {
        font-size: 4.27vw;
        color: #fff;
        padding: 0 0 .3vw 5vw;
        line-height: 1.78;
    }

    #page_sitemap .sec_sitemap .inner ul li:first-child a:before {
        content: '';
        display: block;
        position: absolute;
        width: 1.8vw;
        height: 1.8vw;
        top: 50%;
        left: 0px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        transform: translateY(-50%) rotate(45deg);
    }

    #page_sitemap .sec_sitemap .inner ul li:first-child span {
        font-size: 3.2vw;
        margin-left: .5em;
        font-weight: 400;
    }

    #page_sitemap .sec_sitemap .inner ul:first-of-type {
        margin-top: 20vw;
    }

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

 search ページ

-------------------------------- */
    body.search {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    body.search .sec_searchList {
        padding: 21.33vw 3.47vw 29vw;
    }

    body.search .sec_searchList .sec_ttl {
        margin-bottom: 18vw;
    }

    body.search .sec_searchList .sec_ttl h2 {
        font-size: 5.33vw;
        margin-bottom: 3vw;
        position: relative;
    }

    body.search .sec_searchList .sec_ttl h2:after {
        content: '';
        display: block;
        position: absolute;
        width: 21.33vw;
        height: 4px;
        background: #004B9E;
        left: 50%;
        transform: translateX(-50%);
        margin: 4vw auto 13.33vw;
    }

    body.search .sec_searchList .sec_ttl h2 span {
        font-size: 3.73vw;
        font-weight: 700;
        margin: 1vw auto;
    }

    body.search .sec_searchList .inner {
        padding: 0 0 8vw;
    }

    body.search .sec_searchList .inner p {
        font-size: 3.73vw;
        margin-top: 30vw;
        line-height: 2;
    }

    body.search .sec_searchList .inner .inner_box {
        margin: 0 auto !important;
    }

    body.search .sec_searchList .inner .inner_box .result_wrap {
        margin-bottom: 4vw;
    }

    body.search .sec_searchList .inner .inner_box .result_wrap p {
        font-size: 3.73vw;
        line-height: 2;
        margin-top: 0;
    }

    body.search .sec_searchList .inner .inner_box form {
        padding: 5.33vw 0;
        position: absolute;
        width: 100%;
    }

    body.search .sec_searchList .inner .inner_box form input[type="text"] {
        width: 100%;
        padding: 3.5vw 19vw 3.5vw 6vw;
        box-sizing: border-box;
        border-radius: 100px;
        border: 1px solid #ddd;
        font-size: 4.27vw;
    }

    body.search .sec_searchList .inner .inner_box form input[type="submit"] {
        display: block;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 5.5vw;
        border: none;
        width: 5.33vw;
        height: 5.33vw;
        background: url(../img/common/icon_search.svg) no-repeat 0 0;
        background-size: 5.33vw 5.33vw;
        cursor: pointer;
    }

    body.search .sec_searchList .inner .inner_box form .clear {
        position: absolute;
        right: 14.5vw;
        top: 50%;
        transform: translateY(-50%);
        background-color: #fff;
        border-style: none;
        outline: none;
    }

    body.search .sec_searchList .inner .inner_box form.form.search_form .clear_header {
        position: absolute;
        left: 84%;
        top: 50%;
        transform: translate(-50%, -50%);
        background-color: #fff;
        border-style: none;
        outline: none;
    }

    body.search .sec_searchList .inner .inner_box form .clear:before {
        content: '';
        display: block;
        width: 12px;
        height: 2px;
        background: #000;
        transform: rotate(45deg);
        position: absolute;
    }

    body.search .sec_searchList .inner .inner_box form .clear:after {
        content: '';
        display: block;
        width: 12px;
        height: 2px;
        background: #000;
        transform: rotate(-45deg);
        position: absolute;
    }

    body.search .sec_searchList .inner .inner_box form.form.search_form .clear_header:before {
        content: '';
        display: block;
        width: 3.33vw;
        height: 2px;
        background: #000;
        transform: rotate(45deg);
        position: absolute;
    }

    body.search .sec_searchList .inner .inner_box form.form.search_form .clear_header:after {
        content: '';
        display: block;
        width: 3.33vw;
        height: 2px;
        background: #000;
        transform: rotate(-45deg);
        position: absolute;
    }

    /* body.search .sec_searchList .inner .inner_box form .clear {
    position: absolute;
    left: 84%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-style: none;
    border: none;
    outline: none;
    background: transparent;
    width: 16px;
    height: 16px;
    padding: 0;
  } */
    body.search .sec_searchList .inner .result_box .result_note {
        margin-top: 30vw;
    }

    body.search .sec_searchList .inner .result_box ul {
        margin-top: 22vw;
    }

    body.search .sec_searchList .inner .result_box ul li {
        padding: 10.67vw 0;
        border-bottom: 1px solid #ddd;
    }

    body.search .sec_searchList .inner .result_box ul li dl {
        text-align: justify;
    }

    body.search .sec_searchList .inner .result_box ul li dl dt {
        font-size: 4.8vw;
        font-weight: 700;
        margin-bottom: 25px;
        line-height: 1.61;
    }

    body.search .sec_searchList .inner .result_box ul li dl dd {
        margin-bottom: 5px;
    }

    body.search .sec_searchList .inner .result_box ul li dl dd p {
        font-size: 3.73vw;
        line-height: 2;
        margin-bottom: 25px;
        margin-top: 0;
        text-align: justify !important;
    }

    body.search .sec_searchList .inner .result_box ul li dl dd p span {
        font-weight: 700;
    }

    body.search .sec_searchList .inner .result_box ul li dl dd a {
        font-size: 3.73vw;
        color: #004B9E;
        text-decoration: underline;
        word-break: break-all;
    }

    body.search .sec_searchList .inner .result_box ul li dl dd a:hover {
        color: rgba(0, 75, 158, 0.7);
        text-decoration: none;
        opacity: 1;
    }
}

@media only screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 2) {
    body.search .sec_searchList .inner .inner_box form input[type="submit"] {
        display: block;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 5.5vw;
        border: none;
        width: 5.33vw;
        height: 5.33vw;
        background: url(../img/common/icon_search.svg) no-repeat 0 0;
        background-size: 5.33vw 5.33vw;
        cursor: pointer;
    }
}




/*
ここから
*/
/* =========================================================
  #news
========================================================= */
section#news {
    padding: 0 0 180px;
}

.home section#news {
    padding: 13.33vw 0 16vw;
}

.home section#news .sec_ttl {
    margin-bottom: 6.67vw;
}

#news .inner {
    max-width: 1100px;
    width: 100%;
}

/* =========================================================
  .news_wrap
========================================================= */
.news_wrap {
    position: relative;
    margin: 40px auto 0;
}

.news_wrap .select_box {
    display: flex;
    width: 180px;
    margin-left: auto;
}

.news_wrap .select_box .select_year,
.news_wrap .select_box .select_month {
    overflow: hidden;
    width: 100px;
    margin: 0 auto 20px;
    text-align: left;
    position: relative;
    border: 1px solid #004B9E;
    border-radius: 3px;
    background: #004B9E;
}

.news_wrap .select_box .select_year select,
.news_wrap .select_box .select_month select {
    width: 100%;
    box-sizing: border-box;
    outline: none;
    background: transparent;
    /* padding: 6px 0px 6px 15px; */
    color: #004B9E;
    background: #fff;
    background: linear-gradient(to left, #004B9E 20px, #fff 20px, #fff);

    height: 100%;
    vertical-align: middle;
    /* text-align: right; */
    padding: 0 30% 0 12%;
}

.news_wrap .select_box .select_year select:-ms-expand,
.news_wrap .select_box .select_month select:-ms-expand {
    display: none;
}

.news_wrap .select_box .select_year:before,
.news_wrap .select_box .select_month:before {
    position: absolute;
    top: 5.5px;
    right: 5px;
    width: 0;
    height: 0;
    padding: 0;
    content: '';
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 6px solid #fff;
    pointer-events: none;
}

.news_wrap .select_box .select_year:after,
.news_wrap .select_box .select_month:after {
    position: absolute;
    bottom: 5.5px;
    right: 5px;
    width: 0;
    height: 0;
    padding: 0;
    content: '';
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 6px solid #fff;
    pointer-events: none;
}

.news_wrap .select_box .select_month {
    width: 80px;
}

.news_wrap .tab_wrap {
    width: 100%;
}

.news_wrap .tab_wrap .tab_box {
    border-bottom: #004B9E solid 4px;
    display: flex;
    justify-content: space-between;
}

.news_wrap .tab_wrap .tab_box li {
    width: 33%;
    padding: 10px 0;
    color: #000;
    background: #EDEDED;
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    cursor: pointer;
    transition: ease 0.2s opacity;
}

.news_wrap .tab_panel {
    width: 100%;
    padding: 30px 0;
    display: none;
}

.news_wrap .tab_panel.active {
    display: block;
}

.news_wrap .tab_panel ul {
    text-align: left;
}

.panel_box .tab_panel ul li dl dt a,
.panel_box .tab_panel ul li dl dt span {
    display: inline-block;
    font-size: 14px;
    font-size: 1.4rem;
    color: #004B9E;
    width: 130px;
    box-sizing: border-box;
    padding: 0 10px;
    border: 1px solid #004B9E;
    border-radius: 3px;
    text-align: center;
    margin-left: 10px;
}

.news_wrap .tag_box {
    display: block;
}

.news_wrap .tag_box_cat {
    display: flex;
    flex-wrap: wrap;
}

.news_wrap .tag_box_tag {
    display: flex;
    flex-wrap: wrap;
}

.news_wrap .tag_box_cat a,
.news_wrap .tag_box_tag a {
    display: block;
    font-size: 14px;
    font-size: 1.4rem;
    padding: 9px 25px;
    min-width: 95px;
    box-sizing: border-box;
    border-radius: 100px;
    margin: 0 10px 20px 0;
    border: 1px solid #004B9E;
}

.news_wrap .tag_box_tag a {
    color: #004B9E;
}

/*
  category, tag color
--------------------------------*/
.panel_box .tab_panel a.cat_agency,
.panel_box .tab_panel span.cat_agency {
    background: #3982E9;
    color: #fff;
    border: 1px solid #3982E9;
}

.panel_box .tab_panel a.cat_retail,
.panel_box .tab_panel span.cat_retail {
    background: #E9AF39;
    color: #fff;
    border: 1px solid #E9AF39;
}

.panel_box .tab_panel a.cat_abroad,
.panel_box .tab_panel span.cat_abroad {
    background: #39AFE9;
    color: #fff;
    border: 1px solid #39AFE9;
}

.panel_box .tab_panel a.cat_stationery,
.panel_box .tab_panel span.cat_stationery {
    background: #3CBE93;
    color: #fff;
    border: 1px solid #3CBE93;
}

.panel_box .tab_panel a.cat_contents,
.panel_box .tab_panel span.cat_contents {
    background: #E987A8;
    color: #fff;
    border: 1px solid #E987A8;
}

.panel_box .tab_panel a.cat_entertainment,
.panel_box .tab_panel span.cat_entertainment {
    background: #e8626a;
    color: #fff;
    border: 1px solid #DB5266;
}

.panel_box .tab_panel a.cat_newbusiness,
.panel_box .tab_panel span.cat_newbusiness {
    background: #26B4BE;
    color: #fff;
    border: 1px solid #26B4BE;
}

.panel_box .tab_panel a.cat_shared,
.panel_box .tab_panel span.cat_shared {
    background: #AE9C67;
    color: #fff;
    border: 1px solid #AE9C67;
}

.panel_box .tab_panel a.cat_it,
.panel_box .tab_panel span.cat_it {
    background: #937FD7;
    color: #fff;
    border: 1px solid #937FD7;
}

.panel_box .tab_panel a.tag_hd,
.panel_box .tab_panel span.tag_hd {
    background: #004b9e;
    color: #fff;
    border: 1px solid #004b9e;
}

.panel_box .tab_panel a.tag_esg,
.panel_box .tab_panel span.tag_esg {
    background: #BBF5B3;
    color: #007E67;
    border: 1px solid #BBF5B3;
}

.panel_box .tab_panel a.cat_esg,
.panel_box .tab_panel span.cat_esg {
    background: #BBF5B3;
    color: #007E67;
    border: 1px solid #BBF5B3;
}

.panel_box .tab_panel a.cat_hd,
.panel_box .tab_panel span.cat_hd {
    background: #004b9e;
    color: #fff;
    border: 1px solid #004b9e;
}

.panel_box .tab_panel ul li dl dt a,
.panel_box .tab_panel ul li dl dt span {
    font-size: 11px;
    font-size: 1.1rem;
    width: 130px;
}

.panel_box .tab_panel ul {
    margin-top: 19px;
}

.panel_box .tab_panel ul li {
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: solid 1px #ddd;
}

.panel_box .tab_panel dt {
    font-size: 16px;
    font-size: 1.6rem;
}

.panel_box .tab_panel dd {
    /*  font-size: 16px;
  font-size: 1.6rem;*/
    line-height: 2;
    margin-top: 10px;
}

.panel_box .tab_panel dd a {
    font-size: 16px;
    font-size: 1.6rem;
}

.news_wrap .tab_wrap .tab_box li.active {
    background: #004B9E;
    color: #fff;
}

.news_wrap .tab_wrap .tab_box li+li {
    margin-left: 10px;
}

.news_wrap .select_box {
    width: 100%;
    justify-content: flex-end;
    margin-bottom: 20px;
}

.news_wrap .select_box .select_year,
.news_wrap .select_box .select_month {
    margin: 0 0 0 10px;
}

#all_tab.loading,
#hd_tab.loading,
#group_tab.loading {
    height: 300px;
    background: url(../img/common/preloader.gif) 50% 50% no-repeat;
    background-size: 64px auto;
}

/* ----- search_btn ----- */
#search_btn {
    width: 4em;
    height: 32px;
    margin-left: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #999;
    color: #fff;
    border-radius: 3px;
    pointer-events: none;
}

#search_btn.active {
    background: #004B9E;
    pointer-events: all;
}

/* ----- pager ----- */
.pager {
    display: flex;
    justify-content: center;
    margin: 20px 0;
}

.pager a,
.pager span {
    width: 3em;
    height: 3em;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100%;
    background: #004B9E;
    color: #fff;
    margin: 0 5px;
}

.pager a {
    background: #eee;
    color: #000;
    box-sizing: border-box;
}

a.first,
a.prev,
a.next,
a.last {
    padding-bottom: 3px;
    box-sizing: border-box;
}

.nopost {
    padding: 100px 0;
}

@media only screen and (max-width: 767px) {
    section#news {
        padding: 0 0 25vw;
    }

    .news_wrap {
        margin: 0 auto;
    }

    .news_wrap .tab_wrap .tab_box li {
        font-size: 12px;
        font-size: 1.2rem;
    }

    .news_wrap .tag_box_cat a,
    .news_wrap .tag_box_tag a {
        font-size: 12px;
        font-size: 1.2rem;
        margin: 0 4px 4px 0;
        padding: 5px 12px;
    }

    /* .panel_box .tab_panel ul li dl dt span + span {
    margin-left: 10px;
  } */

    .panel_box .tab_panel ul li dl dt span {
        margin-right: 10px;
    }

    .panel_box .tab_panel ul li dl dt span:first-child {
        margin-right: 0;
    }

    .panel_box .tab_panel ul li dl dt a,
    .panel_box .tab_panel ul li dl dt span {
        font-size: 10px;
        font-size: 1.0rem;
        margin-left: 0;
        width: 130px;
    }

    .panel_box .tab_panel dt {
        font-size: 3.73vw;
    }

    .panel_box .tab_panel dd {
        font-size: 3.73vw;
    }

    .panel_box .tab_panel dd a {
        font-size: 3.73vw;
    }

    .news_wrap .tag_box_cat {
        margin-bottom: 16px;
    }

    .pager a,
    .pager span {
        width: 2.2em;
        height: 2.2em;
    }
}


/* =========================================================
  visual editor
========================================================= */

.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.alignright {
    float: right;
    margin-left: 1.5em;
}

.alignleft {
    float: left;
    margin-right: 1.5em;
}

#page_news_information_article .sec_news_information_article .inner .inner_box p.wp-caption-text {
    margin-top: .5em;
}

@media (max-width: 480px) {
    .alignright {
        float: none;
        margin-left: 0;
    }

    .alignleft {
        float: none;
        margin-right: 0;
    }
}


/*  220224 ESG追加　ここから */

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

 esg ページ

-------------------------------- */
.sec_index_list {
    padding: 80px 0;
    background: rgba(186, 218, 255, 0.3);
    margin-bottom: 230px;
}

.sec_index_list .inner .inner_box {
    display: flex;
    margin: 0;
}

.sec_index_list .inner .inner_box img {
    margin: 0;
    width: 400px;
}

.sec_index_list .inner .inner_box .list_box {
    background: #fff;
    padding: 20px 40px 35px;
    text-align: left;
    width: 100%;
}

.sec_index_list .inner .inner_box .list_box>a {
    border: none;
    width: 100%;
    height: auto;
    margin-top: 0;
    padding: 0;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 600;
}

.sec_index_list .inner .inner_box .list_box ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    width: 100%;
    top: 41%;
    position: relative;
    transform: translateY(-50%);
}

.sec_index_list .inner .inner_box .list_box ul li {
  width: 46.77%;
  text-align: left;
  height: 50px;
  margin-top: 15px;
  display: block;
}

/*.sec_index_list .inner .inner_box .list_box.col_s ul li {
  height: 80px;
}*/

.sec_index_list .inner .inner_box .list_box ul li a {
    display: flex;
    align-items: center;
    height: 100%;
    box-sizing: border-box;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 600;
    position: relative;
}

.sec_index_list .inner .inner_box .list_box.col_s ul li a {
  display: flex;
  align-items: flex-end;
  padding-bottom: 0.5em;
}

.sec_index_list .inner .inner_box .list_box ul li a:after {
    content: '';
    position: absolute;
    top: 50%;
    right: 10px;
    width: 8px;
    height: 8px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    transform: translateY(-50%) rotate(45deg);
}

.sec_index_list .inner .inner_box .list_box.col_s ul li a:after {
  bottom: 1em;
  top: unset;
  transform: translateY(0) rotate(45deg);
}


.sec_index_list .inner .inner_box .list_box.col_e>a {
    color: #00A98A;
}

.sec_index_list .inner .inner_box .list_box.col_e ul li {
    border-bottom: 1px solid #00A98A;
}

.sec_index_list .inner .inner_box .list_box.col_e ul li a:after {
    border-top: 1px solid #00A98A;
    border-right: 1px solid #00A98A;
}

.sec_index_list .inner .inner_box .list_box.col_s>a {
    color: #F6AD4F;
}

.sec_index_list .inner .inner_box .list_box.col_s ul li {
    border-bottom: 1px solid #F6AD4F;
}

.sec_index_list .inner .inner_box .list_box.col_s ul li a:after {
    border-top: 1px solid #F6AD4F;
    border-right: 1px solid #F6AD4F;
}

.sec_index_list .inner .inner_box .list_box.col_g>a {
    color: #0092D7;
}

.sec_index_list .inner .inner_box .list_box.col_g ul li {
    border-bottom: 1px solid #0092D7;
}

.sec_index_list .inner .inner_box .list_box.col_g ul li a:after {
    border-top: 1px solid #0092D7;
    border-right: 1px solid #0092D7;
}

.sec_index_list .inner .inner_box+.inner_box {
    margin-top: 30px;
}

#page_esg .sec_index_list {
    padding: 80px 0;
    margin-bottom: 230px;
}

#page_esg .sec_index_list .inner {
    margin: 0 auto;
}

#page_esg .sec_index_list .inner .inner_box {
    margin: 0 auto;
}

#page_esg .sec_index_list .inner .inner_box picture img {
    margin: 0;
}

#page_esg .sec_index_list .inner .inner_box+.inner_box {
    margin-top: 30px;
}

#page_esg {
    padding: 100px 0 0;
    margin-top: 0;
}

/* #page_esg .hero {
  position: relative;
  padding: 0;
  height: 550px;
  background: url(../img/esg/mv.png) top center no-repeat;
  background-size: cover;
  text-align: left;
} */

#page_esg .hero {
    position: relative;
    padding: 0;
    height: 550px;
    background: none;
    max-width: 1300px;
    margin: auto;
    text-align: right;
}

#page_esg .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(0, -50%);
    z-index: 1;
}

#page_esg .hero .hero_ttl h2 {
    display: flex;
    justify-content: center;
    flex-direction: column;
    font-size: 35px;
    font-size: 3.5rem;
    font-weight: 600;
    align-items: flex-start;
    width: 640px;
    height: 370px;
    background: rgba(0, 112, 192, 0.77);
    color: #fff;
    padding: 0 0 0 100px;
    text-align: left;
}

#page_esg .hero .hero_ttl h2 span {
    color: #fff;
    font-size: 35px;
    font-size: 3.5rem;
    margin-top: .5em;
    font-family: 'Noto Serif JP', serif;
    line-height: 1.49;
}

#page_esg .hero .hero_ttl h2 span.small {
    font-size: 1.8rem;
    line-height: 1.78;
    margin-top: 1em;
}

#page_esg .hero a {
    height: 100%;
}

#page_esg .hero a img {
    height: 100%;
}

#page_esg .sec_index {
    padding-top: 80px;
}

#page_esg .sec_index .inner ul {
    display: flex;
    justify-content: space-between;
}

#page_esg .sec_index .inner ul li {
    position: relative;
    width: 250px;
}

#page_esg .sec_index .inner ul li span {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 70px;
    width: 100%;
    background: rgba(255, 255, 255, 0.8);
    left: 0;
    bottom: 0;
    color: #004B9E;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 600;
}

#page_esg .sec_news_information {
    padding: 120px 0 150px;
}

#page_esg .sec_news_information .inner h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 600;
}

#page_esg .sec_news_information .inner .inner_box {
    position: relative;
    margin: 45px auto 0;
}

#page_esg .sec_news_information .inner .inner_box ul li {
    padding: 15px 0;
    text-align: justify;
    border-bottom: 1px solid #DDDDDD;
}

#page_esg .sec_news_information .inner .inner_box ul li dl dt {
    color: #666666;
    margin-bottom: 10px;
}

#page_esg .sec_news_information .inner .inner_box ul li dl dt span {
    display: inline-block;
    font-size: 14px;
    font-size: 1.4rem;
    color: #004B9E;
    min-width: 100px;
    box-sizing: border-box;
    padding: 3px 10px;
    border: 1px solid #004B9E;
    border-radius: 3px;
    text-align: center;
    margin-left: 20px;
    box-sizing: border-box;
}

#page_esg .sec_news_information .inner .inner_box ul li dl dt span+span {
    margin-left: 7px;
}

#page_esg .sec_news_information .inner .inner_box ul li dl dt span.esg_tag {
    background: #BBF5B3;
    color: #007E67;
    border: none;
}

#page_esg .sec_news_information .inner .inner_box ul li dl dd a {
    line-height: 2;
}

#page_esg .sec_news_information .inner a.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 600;
    border: 2px solid #004B9E;
    border-radius: 35px;
    width: 320px;
    height: 70px;
    text-align: center;
    margin: auto;
    color: #004B9E;
    margin: 60px auto 0;
    box-sizing: border-box;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    /*   #page_esg .hero {
    background: url(../img/esg/mv@2x.png) top center no-repeat;
    background-size: cover;
    background: none;
  } */

    #page_esg .sec_direction .inner a:before {
        background: url(../img/common/icon_link@2x.png) center center no-repeat;
        background-size: 20px 18px;
        top: 50%;
        left: 40px;
        transform: translateY(-50%);
    }
}

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

 policy　ページ

-------------------------------- */
#page_policy {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_policy .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/policy/mv.png) top center no-repeat;
    background-size: cover;
}

#page_policy .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_policy .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #004B9E;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 600;
    background: rgba(255, 255, 255, 0.8);
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_policy .hero:after {
    content: '';
    display: none;
}

#page_policy .sec_basicPolicy {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_policy .sec_basicPolicy .sec_ttl {
    margin-bottom: 65px;
}

#page_policy .sec_basicPolicy .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_policy .sec_basicPolicy .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_policy .sec_basicPolicy .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
}

#page_policy .sec_businessArea {
    padding: 160px 0 25px;
}

#page_policy .sec_businessArea .sec_ttl {
    margin-bottom: 90px;
}

#page_policy .sec_businessArea .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_policy .sec_businessArea .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
}

#page_policy .sec_businessArea .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
    margin-top: 3px;
}

#page_policy .sec_businessArea .inner {
    width: 1100px;
}

#page_policy .sec_businessArea .inner a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    box-sizing: border-box;
    padding: 12px 23px;
    border: none;
    border-radius: 5px;
    text-align: center;
    background: #004B9E;
}

#page_policy .sec_businessArea .inner a+a {
    margin-left: 7px;
}

#page_policy .sec_basicPolicy .inner {
    display: block;
}

#page_policy .sec_basicPolicy .inner h4 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 600;
    letter-spacing: 0;
    margin-bottom: 25px;
    line-height: 2;
}

#page_policy .sec_basicPolicy .inner p {
    text-align: center;
    font-size: 18px;
    font-size: 1.8rem;
}

#page_policy .sec_basicPolicy .inner p+p {
    margin-top: 50px;
}

#page_policy .sec_basicPolicy .inner img {
    width: 655px;
    height: auto;
    margin-top: 120px;
}

#page_policy .sec_basicPolicy .inner .esg_detail_wrap {
    display: flex;
    justify-content: space-between;
    margin-top: 60px;
}

#page_policy .sec_basicPolicy .inner .esg_detail_wrap li {
    width: 320px;
}

#page_policy .sec_basicPolicy .inner .esg_detail_wrap li h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin-bottom: 5px;
}

#page_policy .sec_basicPolicy .inner .esg_detail_wrap li h4.col_e {
    color: #00A98A;
}

#page_policy .sec_basicPolicy .inner .esg_detail_wrap li h4.col_s {
    color: #F6AD4F;
}

#page_policy .sec_basicPolicy .inner .esg_detail_wrap li h4.col_g {
    color: #0092D7;
}

#page_policy .sec_basicPolicy .inner .esg_detail_wrap li p {
    font-size: 16px;
    font-size: 1.6rem;
    text-align: justify;
}

#page_policy .sec_slogan {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_policy .sec_slogan .sec_ttl {
    margin-bottom: 65px;
}

#page_policy .sec_slogan .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_policy .sec_slogan .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_policy .sec_slogan .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
}

#page_policy .sec_slogan .inner {
    display: block;
}

#page_policy .sec_slogan .inner h4 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 600;
    letter-spacing: 0;
    margin-bottom: 25px;
    line-height: 2;
    font-family: 'Noto Serif JP', serif;
}

#page_policy .sec_slogan .inner p {
    text-align: center;
    font-size: 20px;
    font-size: 2rem;
    font-family: 'Noto Serif JP', serif;
}

#page_policy .sec_slogan .inner .slogan_wrap {
    border: 1px solid #004B9E;
    margin-top: 80px;
    padding: 35px;
    border-radius: 6px;
}

#page_policy .sec_slogan .inner .slogan_wrap h4 {
    font-family: "Noto Sans JP", sans-serif;
    color: #004B9E;
    margin-bottom: 1em;
    font-size: 18px;
    font-size: 1.8rem;
}

#page_policy .sec_slogan .inner .slogan_wrap p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
}

#page_policy .sec_organization {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_policy .sec_organization .sec_ttl {
    margin-bottom: 65px;
}

#page_policy .sec_organization .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_policy .sec_organization .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #004B9E;
}

#page_policy .sec_organization .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_policy .sec_organization .inner.mt {
    margin-top: 40px;
}

#page_policy .sec_organization .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_policy .sec_organization .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_policy .sec_organization .inner p.lead {
    font-size: 18px;
    font-size: 1.8rem;
}

#page_policy .sec_organization .inner .inner_box .box_wrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    margin-bottom: 120px;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box {
    text-align: justify;
    width: 600px;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 0 15px;
    letter-spacing: 0em;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box h5 {
    font-size: 20px;
    font-size: 2.0rem;
    background: #004B9E;
    color: #fff;
    padding: 10px 30px;
    min-height: 50px;
    border-radius: 25px;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box ol {
    flex-direction: column;
    align-items: flex-start;
    list-style-type: none !important;
    counter-reset: cnt;
    margin: 25px 0 35px;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box ol li {
    display: list-item;
    text-indent: 0em;
    padding: 0 0 0 35px;
    box-sizing: border-box;
    list-style-position: inside;
    position: relative;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.75;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box ol li+li {
    margin-top: 15px;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box ol li:before {
    content: counter(cnt);
    counter-increment: cnt;
    background-color: #004B9E;
    border-radius: 50%;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 25px;
    width: 25px;
    font-size: 12px;
    color: #fff;
    position: absolute;
    top: 5%;
    left: 0;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box dl {
    margin: 25px 0;
    font-size: 16px;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box dl .dl_inner {
    display: flex;
    justify-content: flex-start;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box dl .dl_inner+.dl_inner {
    margin-top: 15px;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box dl dt {
    font-weight: bold;
    width: 4em;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box dl dd {
    flex: 1;
}

#page_policy .sec_organization .inner .inner_box .box_wrap .txt_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 0;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_policy .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/policy/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 report　ページ

-------------------------------- */
#page_report {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_report .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/report/mv.png) top center no-repeat;
    background-size: cover;
}

#page_report .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_report .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #004B9E;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 600;
    background: rgba(255, 255, 255, 0.8);
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_report .hero:after {
    content: '';
    display: none;
}

#page_report .sec_editPolicy {
    padding: 120px 0 200px;
}

#page_report .sec_editPolicy .sec_ttl {
    margin-bottom: 65px;
}

#page_report .sec_editPolicy .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_report .sec_editPolicy .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #004B9E;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_report .sec_editPolicy .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
}

#page_report .sec_editPolicy .inner {
    display: block;
}

#page_report .sec_editPolicy .inner h4 {
    position: relative;
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 600;
    letter-spacing: 0;
    margin-bottom: 25px;
    line-height: 2;
}

#page_report .sec_editPolicy .inner p {
    text-align: center;
    font-size: 18px;
    font-size: 1.8rem;
}

#page_report .sec_editPolicy .inner p+p {
    margin-top: 50px;
}

#page_report .sec_editPolicy .inner dl {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    line-height: 2;
    text-align: justify;
    border-radius: 6px;
    overflow: hidden;
    margin-top: 65px;
}

#page_report .sec_editPolicy .inner dl dt {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 140px;
    font-weight: 600;
    font-size: 16px;
    font-size: 1.6rem;
    background: #BADAFF;
    border-top: 1px solid #fff;
}

#page_report .sec_editPolicy .inner dl dt:first-child {
    border-top: none;
}

#page_report .sec_editPolicy .inner dl dd {
    width: 960px;
    padding: 35px;
    border-top: 1px solid #fff;
    font-size: 16px;
    font-size: 1.6rem;
    background: #EFF6FF;
    line-height: 1.63;
}

#page_report .sec_editPolicy .inner dl dd:first-child {
    border-top: none;
}

#page_report .sec_editPolicy .inner img {
    width: 490px;
    height: auto;
    margin-top: 60px;
}

#page_report .sec_editPolicy .inner a.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 600;
    border: 2px solid #004B9E;
    border-radius: 35px;
    width: 350px;
    height: 70px;
    text-align: center;
    color: #004B9E;
    margin: 25px auto 0;
    box-sizing: border-box;
    position: relative;
    padding-left: 35px;
}

#page_report .sec_editPolicy .inner a.btn:before {
    content: '';
    position: absolute;
    display: block;
    width: 20.33px;
    height: 25.98px;
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
    background: url(../img/common/icon_pdf02.svg);
    background-size: 20.33px 25.98px;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_report .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/report/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 environment　ページ

-------------------------------- */
#page_environment {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_environment .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/environment/mv.png) top center no-repeat;
    background-size: cover;
}

#page_environment .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_environment .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #00A98A;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 600;
    background: rgba(255, 255, 255, 0.8);
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_environment .hero:after {
    content: '';
    display: none;
}

#page_environment .sec_businessArea {
    padding-top: 170px;
}

#page_environment .sec_businessArea .sec_ttl {
    margin-bottom: 90px;
}

#page_environment .sec_businessArea .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_environment .sec_businessArea .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #00A98A;
}

#page_environment .sec_businessArea .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_environment .sec_businessArea .inner {
    width: 1100px;
}

#page_environment .sec_businessArea .inner a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    box-sizing: border-box;
    padding: 12px 23px;
    border: none;
    border-radius: 5px;
    text-align: center;
    background: #00A98A;
}

#page_environment .sec_businessArea .inner a+a {
    margin-left: 7px;
}

#page_environment .txt-img_column {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_environment .txt-img_column .sec_ttl {
    margin-bottom: 65px;
}

#page_environment .txt-img_column .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_environment .txt-img_column .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #00A98A;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_environment .txt-img_column .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
}

#page_environment .txt-img_column .inner {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

#page_environment .txt-img_column .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 50px;
}

#page_environment .txt-img_column .inner p.note {
    margin-top: 120px;
}

#page_environment .txt-img_column .inner p a {
    color: #004B9E;
    text-decoration: underline;
}

#page_environment .txt-img_column .inner .inner_box {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
}

#page_environment .inner .inner_box+.inner_box {
    margin-top: 120px;
}

#page_environment .txt-img_column .inner .inner_box .txt_box {
    text-align: justify;
    width: 600px;
}

#page_environment .txt-img_column .inner .inner_box .txt_box h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 0 15px;
    letter-spacing: 0em;
}

#page_environment .txt-img_column .inner .inner_box .txt_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 0;
}

/* 20250804 ここから */
#page_environment .txt-img_column .inner .inner_box .txt_box p + p {
    margin-top: 1em;
}
/* 20250804 ここまで */

#page_environment .txt-img_column .inner .inner_box .txt_box dl {
    margin-top: 35px;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_environment .txt-img_column .inner .inner_box .txt_box dl dt {
    line-height: 2;
}

#page_environment .txt-img_column .inner .inner_box .txt_box dl dd ul li {
    line-height: 2;
    text-indent: -1em;
    padding-left: 1em;
}

#page_environment .txt-img_column .inner .inner_box figure {
    position: relative;
}

#page_environment .txt-img_column .inner .inner_box figure figcaption {
    text-align: right;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: .5em;
}

/* 20250804 ここから */
#page_environment .sec_deoxygenization .logistics_base_wrap .logistics_base_img_wrap figure + figure {
    margin-top: 40px;
}
/* 20250804 ここまで */

#page_environment .txt-img_column .inner .inner_box figure figcaption.relocation_cap {
    position: absolute;
    top: calc(250px + 1em);
    right: 0;
}

#page_environment .sec_deoxygenization .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_environment .txt-img_column.sec_deoxygenization .inner .inner_box:nth-of-type(1) {
    margin-top: 120px;
}

#page_environment .sec_deoxygenization .inner p {
    margin-top: 0;
}

#page_environment .sec_challenge {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_environment .sec_challenge .sec_ttl {
    margin-bottom: 65px;
}

#page_environment .sec_challenge .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_environment .sec_challenge .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #00A98A;
}

#page_environment .sec_challenge .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_environment .sec_challenge .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_environment .sec_challenge .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_environment .sec_challenge .inner p.lead {
    font-size: 18px;
    font-size: 1.8rem;
}

#page_environment .sec_challenge .inner img {
    margin: 55px auto 140px;
}

#page_environment .sec_challenge .inner .inner_box {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    margin-bottom: 120px;
}

#page_environment .sec_challenge .inner .inner_box .txt_box {
    text-align: justify;
    width: 600px;
}

#page_environment .sec_challenge .inner .inner_box .txt_box h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 0 15px;
    letter-spacing: 0em;
}

#page_environment .sec_challenge .inner .inner_box .txt_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 0;
}

#page_environment .sec_challenge .inner .inner_box img {
    margin: 0;
}

#page_environment .sec_challenge .inner .inner_box:last-child {
    margin-bottom: 0px;
}

#page_environment .sec_enlightenment {
    margin-bottom: 200px;
}

#page_environment .materiality_btn {
    position: fixed;
    right: 10px;
    top: 110px;
    display: flex;
    align-items: center;
    width: 284px;
    background: #fff;
    color: #004B9E;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 600;
    border: 1px solid #004B9E;
    border-radius: 6px;
    z-index: 1;
}

#page_environment .materiality_btn img {
    width: 90px;
}

#page_environment .materiality_btn span {
    margin: auto;
}

#page_environment .sec_symbiosis {
    margin-bottom: 190px;
}

#page_environment .sec_index_list .inner .inner_box+.inner_box {
    margin-top: 30px;
}



#page_environment .sec_recyclingBasedSociety .development_wrap {
    position: relative;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    line-height: 1.78;
    width: 100%;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner p {
    margin: 0;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap {
     display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 40px;
    padding: 0 60px;
    width: 100%;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div {
    width: 450px;
    text-align: center;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div img,
#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div figure img {
    margin: 0;
     width: 100%;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div figure figcaption {
    text-align: left;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div h5 {
    text-align: center;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    margin-top: 10px;
}

#page_environment .sec_recyclingBasedSociety .plafree_wrap {
    margin-top: 120px;
}

#page_environment .sec_recyclingBasedSociety .plafree_wrap .plafree_img_wrap figure + figure {
    margin-top: 40px;
}


@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_environment .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/environment/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 society　ページ

-------------------------------- */
#page_society {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_society .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/society/mv.png) top center no-repeat;
    background-size: cover;
}

#page_society .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_society .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #F6AD4F;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 600;
    background: rgba(255, 255, 255, 0.8);
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_society .hero:after {
    content: '';
    display: none;
}

#page_society .hero .materiality_btn {
    position: absolute;
    right: 10px;
    top: 10px;
    display: flex;
    align-items: center;
    width: 373px;
    background: #fff;
    color: #004B9E;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 600;
    border: 1px solid #004B9E;
    border-radius: 6px;
}

#page_society .hero .materiality_btn img {
    width: 127px;
}

#page_society .hero .materiality_btn span {
    margin: auto;
}

#page_society .sec_businessArea {
    padding-top: 170px;
}

#page_society .sec_businessArea .sec_ttl {
    margin-bottom: 90px;
}

#page_society .sec_businessArea .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_society .sec_businessArea .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #F6AD4F;
}

#page_society .sec_businessArea .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_society .sec_businessArea .inner {
    width: 1100px;
}

#page_society .sec_businessArea .inner a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    box-sizing: border-box;
    padding: 12px 23px;
    border: none;
    border-radius: 5px;
    text-align: center;
    background: #F6AD4F;
}

#page_society .sec_businessArea .inner a+a {
    margin-left: 7px;
}

#page_society .sec_diversity,
#page_society .sec_workStyles,
#page_society .sec_training {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_society .sec_training {
    margin-bottom: 190px;
}

#page_society .sec_diversity .sec_ttl,
#page_society .sec_workStyles .sec_ttl,
#page_society .sec_training .sec_ttl {
    margin-bottom: 65px;
}

#page_society .sec_diversity .sec_ttl h3,
#page_society .sec_workStyles .sec_ttl h3,
#page_society .sec_training .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_society .sec_diversity .sec_ttl h3:after,
#page_society .sec_workStyles .sec_ttl h3:after,
#page_society .sec_training .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #F6AD4F;
}

#page_society .sec_diversity .sec_ttl h3 span,
#page_society .sec_workStyles .sec_ttl h3 span,
#page_society .sec_training .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_society .sec_diversity .inner h4,
#page_society .sec_workStyles .inner h4,
#page_society .sec_training .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_society .sec_diversity .inner p,
#page_society .sec_workStyles .inner p,
#page_society .sec_training .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_society .sec_diversity .inner p.lead,
#page_society .sec_workStyles .inner p.lead,
#page_society .sec_training .inner p.lead {
    font-size: 18px;
    font-size: 1.8rem;
}

#page_society .sec_diversity .inner img,
#page_society .sec_workStyles .inner img,
#page_society .sec_training .inner img {
    margin: 55px auto 140px;
}

#page_society .sec_diversity .inner .inner_box,
#page_society .sec_workStyles .inner .inner_box,
#page_society .sec_training .inner .inner_box {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    margin-bottom: 120px;
}

#page_society .sec_workStyles .inner .inner_box.multi {
    margin-bottom: 1em;
}

#page_society .sec_workStyles .inner .inner_box.note_wrap figure {
    align-self: center;
}

#page_society .sec_diversity .inner .inner_box .txt_box,
#page_society .sec_workStyles .inner .inner_box .txt_box,
#page_society .sec_training .inner .inner_box .txt_box {
    text-align: justify;
    width: 600px;
}

#page_society .sec_diversity .inner .inner_box .txt_box h4,
#page_society .sec_workStyles .inner .inner_box .txt_box h4,
#page_society .sec_training .inner .inner_box .txt_box h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 0 15px;
    letter-spacing: 0em;
}

#page_society .sec_diversity .inner .inner_box .txt_box p,
#page_society .sec_workStyles .inner .inner_box .txt_box p,
#page_society .sec_training .inner .inner_box .txt_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 0;
}

#page_society .sec_workStyles .inner .inner_box .txt_box p.note {
    text-align: justify;
    font-size: 13px;
    font-size: 1.3rem;
    margin-top: 0;
    line-height: 1.77;
}

#page_society .sec_workStyles .inner .inner_box .txt_box p.note + p.note {
    margin-top: 1em;
}

#page_society .sec_diversity .inner .inner_box .txt_box p+p,
#page_society .sec_workStyles .inner .inner_box .txt_box p+p,
#page_society .sec_training .inner .inner_box .txt_box p+p {
    margin-top: 35px;
}

#page_society .sec_diversity .inner .inner_box img,
#page_society .sec_workStyles .inner .inner_box img,
#page_society .sec_training .inner .inner_box img {
    margin: 0;
}

#page_society .sec_diversity .inner .inner_box figure,
#page_society .sec_workStyles .inner .inner_box figure,
#page_society .sec_training .inner .inner_box figure {
    position: relative;
}

#page_society .sec_diversity .inner .inner_box figure figcaption,
#page_society .sec_workStyles .inner .inner_box figure figcaption,
#page_society .sec_training .inner .inner_box figure figcaption {
    text-align: right;
    font-size: 13px;
    font-size: 1.3rem;
    margin-top: 1em;
}

#page_society .sec_diversity .inner .inner_box figure figcaption.relocation_cap,
#page_society .sec_workStyles .inner .inner_box figure figcaption.relocation_cap,
#page_society .sec_training .inner .inner_box figure figcaption.relocation_cap {
    position: absolute;
    top: calc(250px + 1em);
    right: 0;
}

#page_society .sec_diversity .inner .inner_box:last-child,
#page_society .sec_workStyles .inner .inner_box:last-child,
#page_society .sec_training .inner .inner_box:last-child {
    margin-bottom: 0px;
}

#page_society .sec_diversity .inner .img_wrap picture+picture img,
#page_society .sec_diversity .inner .img_wrap img+img,
#page_society .sec_workStyles .inner .img_wrap picture+picture img,
#page_society .sec_workStyles .inner .img_wrap img+img,
#page_society .sec_training .inner .img_wrap picture+picture img,
#page_society .sec_training .inner .img_wrap img+img {
    margin-left: 20px;
}

#page_society .sec_diversity .inner .inner_box .group_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    text-align: justify;
    margin: 50px auto 0;
    width: 100%;
}

#page_society .sec_diversity .inner .inner_box .group_wrap .group_box {
    width: 525px;
}

#page_society .sec_diversity .inner .inner_box .group_wrap .group_box h5 {
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: 700;
    margin-bottom: 0;
    letter-spacing: 0;
    line-height: 1;
    text-align: center;
    color: #fff;
    background: #F6AD4F;
    border-radius: 6px 6px 0 0;
    padding: 15px;
}

#page_society .sec_diversity .inner .inner_box .group_wrap .group_box ol,
#page_society .sec_diversity .inner .inner_box .group_wrap .group_box p {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-size: 1.6rem;
    background: #FFF7DE;
    border-radius: 0 0 6px 6px;
    padding: 15px 30px;
    min-height: 155px;
    box-sizing: border-box;
    text-align: left;
    line-height: 2;
    font-weight: bold;
}

#page_society .sec_diversity .inner .inner_box .group_wrap .group_box ol {
    flex-direction: column;
    align-items: flex-start;
    list-style-type: none !important;
    counter-reset: cnt;
}

#page_society .sec_diversity .inner .inner_box .group_wrap .group_box ol li {
    display: list-item;
    text-indent: 0em;
    padding: 0 0 0 35px;
    box-sizing: border-box;
    list-style-position: inside;
    position: relative;
}

#page_society .sec_diversity .inner .inner_box .group_wrap .group_box ol li:before {
    content: counter(cnt);
    counter-increment: cnt;
    background-color: #F6AD4F;
    border-radius: 50%;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 25px;
    width: 25px;
    font-size: 12px;
    color: #fff;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}

#page_society .sec_attempt .inner .inner_box.support,
#page_society .sec_attempt .inner .inner_box.bunko {
    display: block;
}

#page_society .sec_attempt .inner .inner_box.support h4,
#page_society .sec_attempt .inner .inner_box.bunko h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 15px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_society .sec_attempt .inner .inner_box.support h4+p,
#page_society .sec_attempt .inner .inner_box.bunko h4+p {
    margin-top: 0;
}

#page_society .sec_attempt .inner .inner_box.support p,
#page_society .sec_attempt .inner .inner_box.bunko p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_society .sec_attempt .inner .inner_box.support p+p,
#page_society .sec_attempt .inner .inner_box.bunko p+p {
    margin-top: 50px;
}

#page_society .sec_attempt .inner .inner_box.support dl {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    line-height: 2;
    text-align: justify;
    border-radius: 6px;
    overflow: hidden;
    margin-top: 25px;
}

#page_society .sec_attempt .inner .inner_box.support dl dt {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 140px;
    font-weight: 600;
    font-size: 16px;
    font-size: 1.6rem;
    background: #FFD9A8;
    border-top: 1px solid #fff;
}

#page_society .sec_attempt .inner .inner_box.support dl dt:first-child {
    border-top: none;
}

#page_society .sec_attempt .inner .inner_box.support dl dd {
    width: 960px;
    padding: 35px;
    border-top: 1px solid #fff;
    font-size: 16px;
    font-size: 1.6rem;
    background: #FFF7DE;
    line-height: 1.63;
}

#page_society .sec_attempt .inner .inner_box.support dl dd:first-child {
    border-top: none;
}

#page_society .sec_attempt .inner .inner_box.support dl dd h5 {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
}

/* 20250804 ここから */
#page_society .sec_attempt .bookstore_img_wrap figure + figure {
    margin-top: 40px;
}
/* 20250804 ここまで */

#page_society .txt-img_column {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_society .txt-img_column .sec_ttl {
    margin-bottom: 65px;
}

#page_society .txt-img_column .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_society .txt-img_column .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    background: #F6AD4F;
    left: 50%;
    transform: translateX(-50%);
    margin: 10px auto 70px;
}

#page_society .txt-img_column .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
}

#page_society .txt-img_column .inner {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

#page_society .txt-img_column .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 50px;
}

#page_society .txt-img_column .inner p a {
    color: #004B9E;
    text-decoration: underline;
}

#page_society .txt-img_column .inner .inner_box {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    margin-bottom: 120px;
}

#page_society .txt-img_column .inner .inner_box .txt_box {
    text-align: justify;
    width: 600px;
}

#page_society .txt-img_column .inner .inner_box .txt_box h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 0 15px;
    letter-spacing: 0em;
}

#page_society .txt-img_column .inner .inner_box .txt_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 0;
}

/* 20250804 ここから */
#page_society .txt-img_column .inner .inner_box .txt_box p + p {
    margin-top: 1em;
}
/* 20250804 ここまで */

#page_society .txt-img_column .inner .inner_box .txt_box dl {
    margin-top: 35px;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_society .txt-img_column .inner .inner_box .txt_box dl dt {
    line-height: 2;
}

#page_society .txt-img_column .inner .inner_box .txt_box dl dd ul li {
    line-height: 2;
}

#page_society .txt-img_column .inner .inner_box figure {
    position: relative;
}

#page_society .txt-img_column .inner .inner_box figure figcaption {
    text-align: right;
    font-size: 13px;
    font-size: 1.3rem;
    margin-top: .8em;
}

#page_society .txt-img_column .inner .inner_box figure figcaption.relocation_cap {
    position: absolute;
    top: calc(250px + 1em);
    right: 0;
}

#page_society .txt-img_column .inner .inner_box:last-child {
    margin-bottom: 0px;
}

#page_society .txt-img_column .inner .inner_box figure {
    width: 450px;
}

#page_society .sec_workStyles .balance_img_wrap figure + figure,
#page_society .sec_attempt .eco_img_wrap figure + figure {
    margin-top: 40px;
}


#page_society .sec_workStyles .inner .inner_box .group_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    text-align: justify;
    margin: 50px auto 120px;
    width: 100%;
    padding: 0 90px;
}

#page_society .sec_workStyles .inner .inner_box .group_wrap .group_box {
    width: 440px;
}


@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_society .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/society/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 esg配下のgovernance　ページ

-------------------------------- */
#page_governance.under_esg {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_governance.under_esg .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/esg_governance/mv.png) top center no-repeat;
    background-size: cover;
}

#page_governance.under_esg .hero .hero_ttl {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

#page_governance.under_esg .hero .hero_ttl h2 {
    position: relative;
    display: block;
    color: #0092D7;
    font-size: 26px;
    font-size: 2.6rem;
    font-weight: 600;
    background: rgba(255, 255, 255, 0.8);
    min-width: 300px;
    padding: 18px 30px;
    line-height: 1;
}

#page_governance.under_esg .hero:after {
    content: '';
    display: none;
}

#page_governance.under_esg .hero .materiality_btn {
    position: absolute;
    right: 10px;
    top: 10px;
    display: flex;
    align-items: center;
    width: 373px;
    background: #fff;
    color: #004B9E;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 600;
    border: 1px solid #004B9E;
    border-radius: 6px;
}

#page_governance.under_esg .hero .materiality_btn img {
    width: 127px;
}

#page_governance.under_esg .hero .materiality_btn span {
    margin: auto;
}

#page_governance.under_esg .sec_businessArea {
    padding-top: 170px;
}

#page_governance.under_esg .sec_businessArea .sec_ttl {
    margin-bottom: 90px;
}

#page_governance.under_esg .sec_businessArea .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_governance.under_esg .sec_businessArea .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #0092D7;
}

#page_governance.under_esg .sec_businessArea .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_governance.under_esg .sec_businessArea .inner {
    width: 1100px;
}

#page_governance.under_esg .sec_businessArea .inner a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    box-sizing: border-box;
    padding: 12px 23px;
    border: none;
    border-radius: 5px;
    text-align: center;
    background: #0092D7;
}

#page_governance.under_esg .sec_businessArea .inner a+a {
    margin-left: 7px;
}

#page_governance.under_esg .sec_corporateGovernance {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_governance.under_esg .sec_corporateGovernance .sec_ttl {
    margin-bottom: 65px;
}

#page_governance.under_esg .sec_corporateGovernance .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_governance.under_esg .sec_corporateGovernance .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #0092D7;
}

#page_governance.under_esg .sec_corporateGovernance .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_governance.under_esg .sec_corporateGovernance .inner.mt {
    margin-top: 140px;
}

#page_governance.under_esg .sec_corporateGovernance .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_governance.under_esg .sec_corporateGovernance .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_governance.under_esg .sec_corporateGovernance .inner p.lead {
    font-size: 18px;
    font-size: 1.8rem;
}

#page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap {
    display: flex;
    justify-content: space-between;
    align-items: top;
    flex-wrap: wrap;
}

#page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div {
    width: 525px;
    text-align: center;
    padding: 55px 50px;
    border: 1px solid #0092D7;
    border-radius: 6px;
}

#page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div h5 {
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: 600;
    text-align: center;
    margin-bottom: 1em;
}

#page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div p {
    text-align: justify;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div p+p {
    margin-top: 20px;
}

#page_governance.under_esg .sec_corporateGovernance .diagram_wrap .diagram_box {
    background: rgba(198, 237, 255, 0.31);
    padding: 70px 0 80px;
    margin: 50px auto 30px;
}

#page_governance.under_esg .sec_corporateGovernance .diagram_wrap .diagram_box .inner h5 {
    font-size: 20px;
    font-size: 2rem;
    margin: 0 auto;
}

#page_governance.under_esg .sec_corporateGovernance .diagram_wrap .diagram_box .inner img {
    margin-top: 50px;
    width: 100%;
}

#page_governance.under_esg .sec_corporateGovernance .diagram_wrap .inner p {
    text-align: justify;
}

#page_governance.under_esg .sec_riskManagement,
#page_governance.under_esg .sec_compliance {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_governance.under_esg .sec_compliance {
    margin-bottom: 190px;
}

#page_governance.under_esg .sec_riskManagement .sec_ttl,
#page_governance.under_esg .sec_compliance .sec_ttl {
    margin-bottom: 65px;
}

#page_governance.under_esg .sec_riskManagement .sec_ttl h3,
#page_governance.under_esg .sec_compliance .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_governance.under_esg .sec_riskManagement .sec_ttl h3:after,
#page_governance.under_esg .sec_compliance .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #0092D7;
}

#page_governance.under_esg .sec_riskManagement .sec_ttl h3 span,
#page_governance.under_esg .sec_compliance .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_governance.under_esg .sec_riskManagement .inner.mt,
#page_governance.under_esg .sec_compliance .inner.mt {
    margin-top: 140px;
}

#page_governance.under_esg .sec_riskManagement .inner h4,
#page_governance.under_esg .sec_compliance .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_governance.under_esg .sec_riskManagement .inner p,
#page_governance.under_esg .sec_compliance .inner p {
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_governance.under_esg .sec_riskManagement .inner .inner_box {
     margin-top: 50px;
}

#page_governance.under_esg .sec_compliance .inner p.note {
    margin-top: 120px;
}


#page_governance.under_esg .sec_riskManagement .inner p.lead,
#page_governance.under_esg .sec_compliance .inner p.lead {
    font-size: 18px;
    font-size: 1.8rem;
}

#page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    margin-bottom: 120px;
}

#page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap {
    margin-bottom: 0;
}

#page_governance.under_esg .sec_riskManagement .inner .inner_box .box_wrap .txt_box,
#page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap .txt_box {
    text-align: justify;
    width: 600px;
}

#page_governance.under_esg .sec_riskManagement .inner .inner_box .box_wrap .txt_box h4,
#page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap .txt_box h4 {
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 0 15px;
    letter-spacing: 0em;
}

#page_governance.under_esg .sec_riskManagement .inner .inner_box .box_wrap .txt_box p,
#page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap .txt_box p {
    text-align: justify;
    font-size: 16px;
    font-size: 1.6rem;
    margin-top: 0;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_governance.under_esg .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/esg_governance/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

 materiality　ページ

-------------------------------- */
#page_materiality {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_materiality .hero {
    position: relative;
    padding: 0;
    height: 300px;
    background: url(../img/materiality/mv.png) top center no-repeat;
    background-size: cover;
}

#page_materiality .hero .hero_ttl {
    position: absolute;
    bottom: -25%;
    left: 50%;
    transform: translate(-50%, 0);
    z-index: 1;
}

#page_materiality .hero .hero_ttl h2 {
    display: flex;
    justify-content: center;
    flex-direction: column;
    font-size: 30px;
    font-size: 3.0rem;
    font-weight: 600;
    align-items: center;
    color: #fff;
    width: 600px;
    height: 170px;
    background: #fff;
    color: #004B9E;
    padding: 0 30px;
}

#page_materiality .hero .hero_ttl h2 span {
    display: block;
    color: #000;
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 2;
    margin-top: .5em;
}

#page_materiality .hero:after {
    content: '';
    display: none;
}

#page_materiality .sec_m_environment .inner p.sec_subttl,
#page_materiality .sec_m_society .inner p.sec_subttl {
    font-size: 46px;
    font-size: 4.6rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 45px;
    line-height: 1.78;
 }

#page_materiality .sec_businessArea {
    padding-top: 170px;
    width: 870px;
    margin: auto;
}

#page_materiality .sec_businessArea .sec_ttl {
    margin-bottom: 90px;
}

#page_materiality .sec_businessArea .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_materiality .sec_businessArea .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #004B9E;
}

#page_materiality .sec_businessArea .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_materiality .sec_businessArea .inner {
    width: 100%;
}

#page_materiality .sec_businessArea .inner a {
    display: inline-block;
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    box-sizing: border-box;
    padding: 12px 23px;
    border: none;
    border-radius: 5px;
    text-align: center;
    background: #004B9E;
    margin-bottom: 7px;
}

#page_materiality .sec_businessArea .inner a+a {
    margin-left: 7px;
}

#page_materiality .sec_m_environment,
#page_materiality .sec_m_society {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_materiality .sec_m_society {
    margin-bottom: 200px;
}

#page_materiality .sec_m_environment .sec_ttl,
#page_materiality .sec_m_society .sec_ttl {
    margin-bottom: 65px;
}

#page_materiality .sec_m_environment .sec_ttl h3,
#page_materiality .sec_m_society .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_materiality .sec_m_environment .sec_ttl h3:after,
#page_materiality .sec_m_society .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #004B9E;
}

#page_materiality .sec_m_environment .sec_ttl h3 span,
#page_materiality .sec_m_society .sec_ttl h3 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_materiality .sec_m_environment .inner+.inner,
#page_materiality .sec_m_society .inner+.inner {
    margin-top: 100px;
}

#page_materiality .sec_m_environment .inner.mt,
#page_materiality .sec_m_society .inner.mt {
    margin-top: 140px;
}

#page_materiality .sec_m_environment .inner h4,
#page_materiality .sec_m_society .inner h4 {
    position: relative;
    font-size: 26px;
    font-size: 2.6rem;
    margin: 0 auto 20px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
}

#page_materiality .sec_m_environment .inner p,
#page_materiality .sec_m_society .inner p{
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_materiality .sec_m_society .inner .resolve_wrap {
    display: flex;
    justify-content: space-between;
    width: 860px;
    margin: 30px auto 0;
}

#page_materiality .sec_m_society .inner .resolve_wrap ol {
    flex: 1;
    line-height: 3;
    font-weight: 700;
    text-align: left;
}

#page_materiality .sec_m_society .inner .resolve_wrap img {
    width: 220px;
    align-self: center;
    margin: 0;
}

#page_materiality .sec_m_environment .inner ol,
#page_materiality .sec_m_society .inner ol  {
    font-size: 16px;
    font-size: 1.6rem;
    flex-direction: column;
    align-items: flex-start;
    list-style-type: none !important;
    counter-reset: cnt;
}

#page_materiality .sec_m_environment .inner ol li,
#page_materiality .sec_m_society .inner ol li {
    display: list-item;
    text-indent: 0em;
    padding: 0 0 0 35px;
    box-sizing: border-box;
    list-style-position: inside;
    position: relative;
}

#page_materiality .sec_m_environment .inner ol li:before,
#page_materiality .sec_m_society .inner ol li:before {
    content: counter(cnt);
    counter-increment: cnt;
    background-color: #00A98A;
    border-radius: 50%;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 25px;
    width: 25px;
    font-size: 12px;
    color: #fff;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}

#page_materiality .sec_m_environment .inner p.lead,
#page_materiality .sec_m_society .inner p.lead {
    font-size: 18px;
    font-size: 1.8rem;
}

#page_materiality .sec_m_environment .inner p+p,
#page_materiality .sec_m_society .inner p+p,
#page_materiality .sec_m_environment .inner p+ol,
#page_materiality .sec_m_society .inner p+ol {
    margin-top: 20px;
}

#page_materiality .sec_m_society .inner p.sec_subttl + p {
   margin-top: 0;
 }

#page_materiality .sec_m_environment .inner .inner_box .img_wrap,
#page_materiality .sec_m_society .inner .inner_box .img_wrap {
    margin-top: 50px;
}

#page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div,
#page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div {
    width: 525px;
    text-align: center;
    padding: 55px 50px;
    border: 1px solid #004B9E;
    border-radius: 6px;
}

#page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div h5,
#page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div h5 {
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: 600;
    text-align: center;
    margin-bottom: 1em;
}

#page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div p,
#page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div p {
    text-align: justify;
    letter-spacing: .03em;
    font-size: 16px;
    font-size: 1.6rem;
}

#page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div p+p,
#page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div p+p {
    margin-top: 20px;
}

#page_materiality .sec_task {
    padding: 120px 0 0;
    margin-bottom: 80px;
}

#page_materiality .sec_task .sec_ttl {
    margin-bottom: 65px;
}

#page_materiality .sec_task .sec_ttl h3 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
}

#page_materiality .sec_task .sec_ttl h3:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #004B9E;
}

#page_materiality .sec_task .inner h4 {
    position: relative;
    font-size: 44px;
    font-size: 4.4rem;
    margin: 0 auto;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.78;
    color: #004B9E;
}

#page_materiality .goals.inner .group_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    text-align: justify;
    margin: 45px auto 0;
}

#page_materiality .goals.inner .group_wrap h4 {
    position: relative;
    font-size: 20px;
    font-size: 2.0rem;
    margin: 0 auto 15px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.2;
    width: 100%;
    text-align: center;
}

#page_materiality .goals.inner .group_wrap sub {
    vertical-align: sub;
    font-size: smaller;
}

#page_materiality .goals.inner .group_wrap p.note {
    position: relative;
    font-size: 14px;
    font-size: 1.4rem;
    margin: 15px auto 30px;
    line-height: 1.43;
    width: 100%;
    text-align: center;
}

#page_materiality .goals.inner .group_wrap .group_box {
    width: 360px;
    border: solid 2px #00A98A;
    border-radius: 6px;
}

#page_materiality .goals.inner .group_wrap .group_box h5 {
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: 600;
    margin-bottom: 0;
    letter-spacing: 0;
    line-height: 1;
    text-align: center;
    color: #fff;
    background: #00A98A;
    padding: 15px;
}

#page_materiality .goals.inner .group_wrap .group_box .group_box_inner {
    border-radius: 0 0 6px 6px;
    padding: 15px;
    min-height: 115px;
    box-sizing: border-box;
}

#page_materiality .goals.inner .group_wrap .group_box .group_box_inner p {
    font-size: 34px;
    font-size: 3.4rem;
    text-align: center;
    letter-spacing: 0em;
    color: #FF0031;
    line-height: 1.2;
    font-weight: bold;
}

#page_materiality .goals.inner .group_wrap .group_box .group_box_inner p + p {
    margin-top: 0;
}

#page_materiality .goals.inner .group_wrap .group_box .group_box_inner p.c_bk {
    color: #000;
}

#page_materiality .goals.inner .group_wrap .group_box .group_box_inner p span {
    font-size: 50px;
    font-size: 5.0rem;
}

#page_materiality .goals.inner .group_wrap .group_box .group_box_inner p span.mark_minus {
    font-size: 25px;
    font-size: 2.5rem;
}

#page_materiality .goals.inner .group_wrap .group_box .group_box_inner p.specific_num {
    font-size: 18px;
    font-size: 1.8rem;
}

#page_materiality .goals.inner .group_wrap .group_box .group_box_inner p small {
    font-size: 20px;
    font-size: 2.0rem;
}


@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    #page_materiality .hero {
        position: relative;
        padding: 0;
        height: 300px;
        background: url(../img/materiality/mv@2x.png) top center no-repeat;
        background-size: cover;
    }
}

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

esg配下の news　ページ

-------------------------------- */
#page_news {
    padding: 100px 0 0;
    margin-top: 0;
}

#page_news .sec_esgNews {
    padding: 120px 0 150px;
}

#page_news .sec_esgNews .sec_ttl {
    margin-bottom: 65px;
}

#page_news .sec_esgNews .sec_ttl h2 {
    font-size: 30px;
    font-size: 3rem;
    margin-bottom: 25px;
    position: relative;
    font-weight: 600;
}

#page_news .sec_esgNews .sec_ttl h2:after {
    content: '';
    display: block;
    position: absolute;
    width: 80px;
    height: 4px;
    left: 50%;
    transform: translateX(-50%);
    margin: 13px auto 70px;
    background: #004B9E;
}

#page_news .sec_esgNews .sec_ttl h2 span {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 300;
    margin-top: 3px;
}

#page_news .sec_esgNews .inner .inner_box {
    position: relative;
    margin: 45px auto 0;
}

#page_news .sec_esgNews .inner .inner_box ul li {
    padding: 15px 0;
    text-align: justify;
    border-bottom: 1px solid #DDDDDD;
}

#page_news .sec_esgNews .inner .inner_box ul li dl dt {
    color: #666666;
    margin-bottom: 10px;
}

#page_news .sec_esgNews .inner .inner_box ul li dl dt span {
    display: inline-block;
    font-size: 14px;
    font-size: 1.4rem;
    color: #004B9E;
    min-width: 100px;
    box-sizing: border-box;
    padding: 3px 10px;
    border: 1px solid #004B9E;
    border-radius: 3px;
    text-align: center;
    margin-left: 20px;
    box-sizing: border-box;
}

#page_news .sec_esgNews .inner .inner_box ul li dl dt span+span {
    margin-left: 7px;
}

#page_news .sec_esgNews .inner .inner_box ul li dl dt span.esg_tag {
    background: #BBF5B3;
    color: #007E67;
    border: none;
}

#page_news .sec_esgNews .inner .inner_box ul li dl dd a {
    line-height: 2;
}

.pager {
    display: flex;
    justify-content: center;
    margin: 20px 0;
}

.pager a,
.pager span {
    width: 3em;
    height: 3em;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100%;
    background: #004B9E;
    color: #fff;
    margin: 0 5px;
}

.pager a {
    background: #eee;
    color: #000;
    box-sizing: border-box;
}

a.first,
a.prev,
a.next,
a.last {
    padding-bottom: 3px;
    box-sizing: border-box;
}

.nopost {
    padding: 100px 0;
}


/*  220224 ESG追加　ここまで */


/*  220224 ESG追加　ここから */


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

    /* --------------------------------
  
   esg ページ
  
  -------------------------------- */
    .sec_index_list {
        padding: 13.33vw 0;
        background: rgba(186, 218, 255, 0.3);
        margin-bottom: 17.33vw;
    }

    .sec_index_list .inner .inner_box {
        display: flex;
        margin: 0;
        align-items: center;
        flex-wrap: wrap;
    }

    .sec_index_list .inner .inner_box picture {
        width: 100%;
    }

    .sec_index_list .inner .inner_box img {
        margin: 0;
        width: 100%;
    }

    .sec_index_list .inner .inner_box .list_box {
        background: #fff;
        padding: 6.67vw 8vw;
        text-align: left;
    }

    .sec_index_list .inner .inner_box .list_box>a {
        display: block;
        padding: 0;
        font-size: 5.33vw;
        font-weight: 600;
        width: 100%;
        height: auto;
        margin-top: 0;
        margin-bottom: 1.33vw;
    }

    .sec_index_list .inner .inner_box .list_box ul {
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-wrap: wrap;
        background: #fff;
        width: 100%;
        top: 0;
        position: relative;
        transform: unset;
    }

    .sec_index_list .inner .inner_box .list_box ul li {
        width: 100%;
        text-align: left;
        height: 12vw;
        margin-top: 0;
        display: block;
    }

    .sec_index_list .inner .inner_box .list_box.col_s ul li {
      height: 12vw;
    }

    .sec_index_list .inner .inner_box .list_box ul li a {
        display: flex;
        align-items: center;
        height: 100%;
        box-sizing: border-box;
        font-size: 3.73vw;
        font-weight: 600;
    }

    .sec_index_list .inner .inner_box .list_box.col_s ul li a {
        display: flex;
        align-items: center;
        height: 100%;
        box-sizing: border-box;
        font-size: 3.73vw;
        font-weight: 600;
        padding-bottom: 0;
    }

    .sec_index_list .inner .inner_box .list_box ul li a:after {
        content: '';
        position: absolute;
        top: 50%;
        right: 10px;
        width: .5em;
        height: .5em;
        border-top: 1px solid #000;
        border-right: 1px solid #000;
        transform: translateY(-50%) rotate(45deg);
    }

    .sec_index_list .inner .inner_box .list_box.col_s ul li a:after {
      content: '';
        position: absolute;
        top: 50%;
        bottom: unset;
        right: 10px;
        width: .5em;
        height: .5em;
        transform: translateY(-50%) rotate(45deg);
    }

    .sec_index_list .inner .inner_box+.inner_box {
        margin-top: 2.67vw;
    }

    #page_esg .sec_index_list {
        padding: 13.33vw 0;
        margin-bottom: 17.33vw;
    }

    #page_esg .sec_index_list .inner {
        margin: 0 auto;
    }

    #page_esg .sec_index_list .inner .inner_box {
        margin: 0 auto;
    }

    #page_esg .sec_index_list .inner .inner_box picture img {
        margin: 0;
    }

    #page_esg .sec_index_list .inner .inner_box+.inner_box {
        margin-top: 2.67vw;
    }

    #page_esg {
        padding: 16vw 0 0;
        margin-top: 0;
    }

    #page_esg .hero {
        position: relative;
        padding: 0;
        height: 80vw;
        /*     background: url(../img/esg/mv_sp.png) top center no-repeat; */
        /*     background-size: 100%; */
    }

    #page_esg .hero .hero_ttl {
        position: absolute;
        top: 96%;
        left: 0;
        transform: translate(0, -50%);
        z-index: 1;
    }

    #page_esg .hero .hero_ttl h2 {
        display: flex;
        align-items: flex-start;
        color: #fff;
        width: 94.67vw;
        height: 45.47vw;
        background: rgba(0, 112, 192, 0.77);
        color: #fff;
        padding: 0 0 0 5.33vw;
        font-size: 5.33vw;
        text-align: left;
    }

    #page_esg .hero .hero_ttl h2 span {
        color: #fff;
        font-size: 4.8vw;
        line-height: 2;
        margin: 1.67vw 0 0;
        display: block;
    }

    #page_esg .hero .hero_ttl h2 span.small {
        font-size: 3.2vw;
        line-height: 1.78;
        margin-top: 0;
        letter-spacing: 0em;
    }

    #page_esg .hero a,
    #page_esg .hero a picture {
        width: 100%;
    }

    #page_esg .hero a img {
        height: auto;
        width: 100%;
    }

    #page_esg .sec_index {
        padding-top: 32vw;
    }

    #page_esg .sec_index .inner ul {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        padding: 0 1.87vw;
    }

    #page_esg .sec_index .inner ul li {
        position: relative;
        width: 42.13vw;
        margin-bottom: 5.33vw;
    }

    #page_esg .sec_index .inner ul li img {
        width: 100%;
    }

    #page_esg .sec_index .inner ul li span {
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        height: 13.33vw;
        width: 100%;
        background: rgba(255, 255, 255, 0.8);
        left: 0;
        bottom: 0;
        color: #004B9E;
        font-size: 4.27vw;
        font-weight: 600;
    }

    #page_esg .sec_news_information {
        padding: 5.33vw 0 32vw;
    }

    #page_esg .sec_news_information .inner h3 {
        font-size: 5.33vw;
        margin-bottom: 5.33vw;
        position: relative;
        font-weight: 600;
    }

    #page_esg .sec_news_information .inner .inner_box {
        position: relative;
        margin: 5.33vw auto 0;
    }

    #page_esg .sec_news_information .inner .inner_box ul li {
        padding: 4vw 0;
        text-align: justify;
        border-bottom: 1px solid #DDDDDD;
    }

    #page_esg .sec_news_information .inner .inner_box ul li dl dt {
        color: #666666;
        margin-bottom: 2.67vw;
        font-size: 3.73vw;
        text-align: left;
    }

    #page_esg .sec_news_information .inner .inner_box ul li dl dt span {
        display: inline-block;
        font-size: 3.2vw;
        color: #004B9E;
        min-width: 22vw;
        box-sizing: border-box;
        padding: 3px 10px;
        border: 1px solid #004B9E;
        border-radius: 3px;
        text-align: center;
        margin-left: 20px;
        letter-spacing: -.1em;
    }

    #page_esg .sec_news_information .inner .inner_box ul li dl dt span+span {
        margin-left: 7px;
    }

    #page_esg .sec_news_information .inner .inner_box ul li dl dt span.esg_tag {
        background: #BBF5B3;
        color: #007E67;
        border: none;
    }

    #page_esg .sec_news_information .inner .inner_box ul li dl dd {
        word-break: break-all;
    }

    #page_esg .sec_news_information .inner .inner_box ul li dl dd a {
        line-height: 2;
        font-size: 3.73vw;
    }

    #page_esg .sec_news_information .inner a.btn {
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 4.27vw;
        font-weight: 600;
        border: 2px solid #004B9E;
        border-radius: 35px;
        width: 94.4vw;
        height: 16vw;
        text-align: center;
        margin: auto;
        color: #004B9E;
        margin: 8vw auto 0;
        letter-spacing: 0em;
    }

    @media only screen and (max-width: 768px) and (-webkit-min-device-pixel-ratio: 2) {
        #page_esg .hero {
            position: relative;
            padding: 0;
            height: 80vw;
            background: url(../img/esg/mv_sp@2x.png) top center no-repeat;
            background-size: 100%;
        }
    }

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

        /* --------------------------------
  
   policy　ページ
  
  -------------------------------- */
        #page_policy {
            padding: 16vw 0 0;
            margin-top: 0;
        }

        #page_policy .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/policy/mv_sp.png) top center no-repeat;
            background-size: 100%;
        }

        #page_policy .hero .hero_ttl {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            z-index: 1;
            width: 100%;
        }

        #page_policy .hero .hero_ttl h2 {
            position: relative;
            display: inline-block;
            color: #004B9E;
            font-size: 5.33vw;
            font-weight: 600;
            background: rgba(255, 255, 255, 0.8);
            min-width: 64vw;
            max-width: 94.67vw;
            padding: 4.8vw 7vw;
            line-height: 1;
        }

        #page_policy .hero:after {
            content: '';
            display: none;
        }


        #page_policy .sec_businessArea {
            padding: 16vw 0;
        }

        #page_policy .sec_businessArea .sec_ttl {
            margin-bottom: 13.33vw;
        }

        #page_policy .sec_businessArea .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 0;
            position: relative;
        }

        #page_policy .sec_businessArea .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            left: 50%;
            transform: translateX(-50%);
            margin: 2.67vw auto 9.33vw;
        }

        #page_policy .sec_businessArea .sec_ttl h3 span {
            display: block;
            font-size: 4.27vw;
            font-weight: 400;
        }

        #page_policy .sec_businessArea .inner {
            width: 69vw;
            display: flex;
            justify-content: space-around;
            flex-wrap: wrap;
            margin: 0 auto;
        }

        #page_policy .sec_businessArea .inner a {
            display: inline-block;
            font-size: 3.73vw;
            color: #fff;
            box-sizing: border-box;
            padding: 2.33vw 4vw;
            border: none;
            border-radius: 5px;
            text-align: center;
            margin-bottom: 1.67vw;
        }

        #page_policy .sec_businessArea .inner a+a {
            margin-left: 0;
        }



        #page_policy .sec_basicPolicy {
            padding: 5.33vw 0 16vw;
            margin-bottom: 0;
        }

        #page_policy .sec_basicPolicy .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_policy .sec_basicPolicy .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_policy .sec_basicPolicy .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #004B9E;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_policy .sec_basicPolicy .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_policy .sec_basicPolicy .inner {
            display: block;
        }

        #page_policy .sec_basicPolicy .inner h4 {
            width: 100%;
            font-size: 5.8vw;
            margin-bottom: 8vw;
            text-align: center;
            line-height: 1.69;
        }

        #page_policy .sec_basicPolicy .inner p {
            text-align: justify;
            font-size: 3.73vw;
        }

        #page_policy .sec_basicPolicy .inner p+p {
            margin-top: 9.33vw;
        }

        #page_policy .sec_basicPolicy .inner img {
            width: 100%;
            height: auto;
            margin-top: 16vw;
        }

        #page_policy .sec_basicPolicy .inner .esg_detail_wrap {
            display: flex;
            justify-content: space-between;
            margin-top: 16vw;
            flex-wrap: wrap;
        }

        #page_policy .sec_basicPolicy .inner .esg_detail_wrap li {
            width: 100%;
        }

        #page_policy .sec_basicPolicy .inner .esg_detail_wrap li h4 {
            font-size: 4.8vw;
            margin-bottom: 1em;
        }

        #page_policy .sec_basicPolicy .inner .esg_detail_wrap li h4.col_e {
            color: #00A98A;
        }

        #page_policy .sec_basicPolicy .inner .esg_detail_wrap li h4.col_s {
            color: #F6AD4F;
        }

        #page_policy .sec_basicPolicy .inner .esg_detail_wrap li h4.col_g {
            color: #0092D7;
        }

        #page_policy .sec_basicPolicy .inner .esg_detail_wrap li p {
            font-size: 3.73vw;
            text-align: justify;
        }

        #page_policy .sec_basicPolicy .inner .esg_detail_wrap li+li {
            margin-top: 10.67vw;
        }

        #page_policy .sec_slogan {
            padding: 5.33vw 0 16vw;
            margin-bottom: 0;
        }

        #page_policy .sec_slogan .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_policy .sec_slogan .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_policy .sec_slogan .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #004B9E;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_policy .sec_slogan .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_policy .sec_slogan .inner {
            display: block;
        }

        #page_policy .sec_slogan .inner img {
            width: 80vw;
        }

        #page_policy .sec_slogan .inner h4 {
            width: 100%;
            font-size: 5.33vw;
            margin-bottom: 8vw;
            text-align: center;
            line-height: 1.69;
        }

        #page_policy .sec_slogan .inner p {
            font-size: 3.73vw;
            letter-spacing: 0em;
        }

        #page_policy .sec_slogan .inner .slogan_wrap {
            border: 1px solid #004B9E;
            margin-top: 16vw;
            padding: 5.33vw;
        }

        #page_policy .sec_slogan .inner .slogan_wrap h4 {
            font-family: "Noto Sans JP", sans-serif;
            color: #004B9E;
            margin-bottom: 1em;
            font-size: 4.8vw;
        }

        #page_policy .sec_slogan .inner .slogan_wrap p {
            text-align: justify;
            font-size: 3.73vw;
            font-family: "Noto Sans JP", sans-serif;
        }

        #page_policy .sec_organization {
            padding: 5.33vw 0 16vw;
            margin-bottom: 18vw;
        }

        #page_policy .sec_organization .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_policy .sec_organization .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_policy .sec_organization .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #004B9E;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_policy .sec_organization .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_policy .sec_organization .inner {
            margin-top: 13.33vw;
        }

        #page_policy .sec_organization .inner.mt {
            margin-top: 13.33vw;
        }

        #page_policy .sec_organization .inner h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_policy .sec_organization .inner p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap {
            display: flex;
            justify-content: space-between;
            align-items: top;
            flex-wrap: wrap;
            margin-bottom: 0;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box {
            text-align: justify;
            width: 100%;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box h5 {
            display: flex;
            justify-content: flex-start;
            align-items: center;
            font-size: 4.27vw;
            padding: 2.67vw 5.33vw;
            min-height: 19.2vw;
            border-radius: 9.6vw;
            width: 100%;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box h5 span.colon {
            display: none;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box h5 span:last-child {
            margin-left: 1em;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box ol {
            margin: 5.33vw 2.67vw 6.67vw;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box ol li {
            display: list-item;
            padding: 0 0 0 8vw;
            font-size: 3.73vw;
            line-height: 1.57;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box ol li+li {
            margin-top: 2.67vw;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box ol li:before {
            height: 6.67vw;
            width: 6.67vw;
            font-size: 3.2vw;
            top: -3%;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box dl {
            margin: 5.33vw 2.67vw;
            font-size: 3.73vw;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box dl .dl_inner {
            display: flex;
            justify-content: flex-start;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box dl .dl_inner+.dl_inner {
            margin-top: 4vw;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap .txt_box p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_policy .sec_organization .inner .inner_box .box_wrap img {
            width: 100%;
            margin-top: 8vw;
        }

        #page_policy .sec_organization .inner p.note {
            margin-top: 14.67vw;
            text-align: center;
        }

        #page_policy .sec_index_list {
            margin-bottom: 17.33vw;
        }
    }

    @media only screen and (max-width: 768px) and (-webkit-min-device-pixel-ratio: 2) {
        #page_policy .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/policy/mv_sp@2x.png) top center no-repeat;
            background-size: 100%;
        }
    }

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

        /* --------------------------------
  
   report　ページ
  
  -------------------------------- */
        #page_report {
            padding: 16vw 0 0;
            margin-top: 0;
        }

        #page_report .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/report/mv_sp.png) top center no-repeat;
            background-size: 100%;
        }

        #page_report .hero .hero_ttl {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            z-index: 1;
            width: 100%;
        }

        #page_report .hero .hero_ttl h2 {
            position: relative;
            display: inline-block;
            color: #004B9E;
            font-size: 5.33vw;
            font-weight: 600;
            background: rgba(255, 255, 255, 0.8);
            min-width: 64vw;
            max-width: 94.67vw;
            padding: 4.8vw 7vw;
            line-height: 1;
        }

        #page_report .hero:after {
            content: '';
            display: none;
        }

        #page_report .sec_editPolicy {
            padding: 21.33vw 0 32vw;
        }

        #page_report .sec_editPolicy .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_report .sec_editPolicy .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_report .sec_editPolicy .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #004B9E;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_report .sec_editPolicy .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_report .sec_editPolicy .inner {
            display: block;
        }

        #page_report .sec_editPolicy .inner h4 {
            width: 100%;
            font-size: 5.8vw;
            margin-bottom: 8vw;
            text-align: center;
            line-height: 1.69;
        }

        #page_report .sec_editPolicy .inner p {
            text-align: justify;
            font-size: 3.73vw;
        }

        #page_report .sec_editPolicy .inner p+p {
            margin-top: 9.33vw;
        }

        #page_report .sec_editPolicy .inner dl {
            display: flex;
            justify-content: space-between;
            line-height: 2;
            text-align: justify;
            flex-wrap: wrap;
            margin-top: 6.67vw;
        }

        #page_report .sec_editPolicy .inner dl dt {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            justify-content: center;
            width: 21.33vw;
            font-weight: 600;
            font-size: 3.2vw;
            background: #BADAFF;
            border-top: 1px solid #fff;
            text-align: center;
            line-height: 1.25;
        }

        #page_report .sec_editPolicy .inner dl dt:first-child {
            border-top: none;
        }

        #page_report .sec_editPolicy .inner dl dd {
            width: 71.73vw;
            padding: 9.33vw 4vw;
            border-top: 1px solid #fff;
            font-size: 3.73vw;
            line-height: 1.57;
        }

        #page_report .sec_editPolicy .inner dl dd:first-child {
            border-top: none;
        }

        #page_report .sec_editPolicy .inner img {
            width: 100%;
            height: auto;
            margin-top: 10.67vw;
        }

        #page_report .sec_editPolicy .inner a.btn {
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 4.27vw;
            font-weight: 600;
            border: 2px solid #004B9E;
            border-radius: 35px;
            width: 80vw;
            height: 16vw;
            text-align: center;
            margin: auto;
            color: #004B9E;
            margin: 8vw auto 0;
            letter-spacing: 0em;
        }

        #page_report .sec_editPolicy .inner a.btn span {
            display: none;
        }

        #page_report .sec_editPolicy .inner a.btn:before {
            content: '';
            position: absolute;
            display: block;
            width: 5.22vw;
            height: 6.66vw;
            top: 50%;
            left: 7.2vw;
            transform: translateY(-50%);
            background: url(../img/common/icon_pdf02.svg);
            background-size: 5.22vw 6.66vw;
        }

        #page_report .sec_index_list {
            margin-bottom: 17.33vw;
        }
    }

    @media only screen and (max-width: 768px) and (-webkit-min-device-pixel-ratio: 2) {
        #page_report .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/report/mv_sp@2x.png) top center no-repeat;
            background-size: 100%;
        }
    }

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

        /* --------------------------------
  
   environment　ページ
  
  -------------------------------- */
        #page_environment {
            padding: 16vw 0 0;
            margin-top: 0;
        }

        #page_environment .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/environment/mv_sp.png) top center no-repeat;
            background-size: 100%;
        }

        #page_environment .hero .hero_ttl {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            z-index: 1;
            width: 100%;
        }

        #page_environment .hero .hero_ttl h2 {
            position: relative;
            display: inline-block;
            color: #00A98A;
            font-size: 5.33vw;
            font-weight: 600;
            background: rgba(255, 255, 255, 0.8);
            min-width: 64vw;
            max-width: 94.67vw;
            padding: 4.8vw 7vw;
            line-height: 1;
        }

        #page_environment .hero:after {
            content: '';
            display: none;
        }

        #page_environment .sec_businessArea {
            padding-top: 16vw;
        }

        #page_environment .sec_businessArea .sec_ttl {
            margin-bottom: 13.33vw;
        }

        #page_environment .sec_businessArea .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 0;
            position: relative;
        }

        #page_environment .sec_businessArea .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            left: 50%;
            transform: translateX(-50%);
            margin: 2.67vw auto 9.33vw;
            background: #00A98A;
        }

        #page_environment .sec_businessArea .sec_ttl h3 span {
            display: block;
            font-size: 4.27vw;
            font-weight: 300;
        }

        #page_environment .sec_businessArea .inner {
            width: 85vw;
            display: flex;
            justify-content: space-around;
            flex-wrap: wrap;
            margin: 0 auto;
        }

        #page_environment .sec_businessArea .inner a {
            display: inline-block;
            font-size: 3.73vw;
            color: #fff;
            box-sizing: border-box;
            padding: 2.33vw 4vw;
            border: none;
            border-radius: 5px;
            text-align: center;
            margin-bottom: 1.67vw;
        }

        #page_environment .sec_businessArea .inner a+a {
            margin-left: 0;
        }

        #page_environment .txt-img_column {
            padding: 5.33vw 0 24.67vw;
            margin-bottom: 0;
        }

        #page_environment .txt-img_column .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_environment .txt-img_column .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_environment .txt-img_column .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #00A98A;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_environment .txt-img_column .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_environment .txt-img_column .inner {
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
            width: 100%;
            padding: 0 3.47vw;
        }

        #page_environment .txt-img_column .inner p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_environment .txt-img_column .inner p.note {
            margin-top: 14.67vw;
            text-align: center;
        }

        #page_environment .txt-img_column .inner .inner_box {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            flex-wrap: wrap;
            width: 100%;
            margin-bottom: 0;
        }

        #page_environment .inner .inner_box+.inner_box {
            margin-top: 14.67vw;
        }

        #page_environment .txt-img_column .inner .inner_box picture {
            width: 100%;
        }

        #page_environment .txt-img_column .inner .inner_box picture img {
            width: 100%;
        }

        #page_environment .txt-img_column .inner .inner_box figure {
            width: 100%;
        }

        #page_environment .txt-img_column .inner .inner_box figure img {
            width: 100%;
        }

        #page_environment .txt-img_column .inner .inner_box img {
            width: 100%;
        }

        #page_environment .txt-img_column .inner .inner_box .txt_box {
            text-align: justify;
            width: 100%;
        }

        #page_environment .txt-img_column .inner .inner_box .txt_box h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_environment .txt-img_column .inner .inner_box .txt_box p {
            text-align: justify;
            font-size: 3.73vw;
            margin-bottom: 1.5em;
        }

        #page_environment .txt-img_column .inner .inner_box .txt_box dl {
            margin: 0 0 1.5em;
            font-size: 3.73vw;
        }

        #page_environment .txt-img_column .inner .inner_box .txt_box dl dt {
            line-height: 2;
        }

        #page_environment .txt-img_column .inner .inner_box .txt_box dl dd ul li {
            line-height: 2;
            text-indent: -1em;
            padding-left: 1em;
        }

        #page_environment .txt-img_column .inner .inner_box figure figcaption {
            text-align: right;
            font-size: 3.73vw;
            margin-top: .5em;
        }
        
        /* 20250804 ここから */
        #page_environment .sec_deoxygenization .logistics_base_wrap .logistics_base_img_wrap figure + figure {
            margin-top: 6.67vw;
        }
        /* 20250804 ここまで */

        #page_environment .txt-img_column .inner .inner_box figure figcaption.relocation_cap {
            position: absolute;
            top: 56vw;
            right: 0;
        }

        #page_environment .sec_challenge {
            padding: 5.33vw 0 24.67vw;
            margin-bottom: 0;
        }

        #page_environment .sec_challenge .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_environment .sec_challenge .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_environment .sec_challenge .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #00A98A;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_environment .sec_challenge .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_environment .sec_challenge .inner {
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
        }

        #page_environment .sec_challenge .inner h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_environment .sec_challenge .inner p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_environment .sec_challenge .inner picture {
            width: 100%;
        }

        #page_environment .sec_challenge .inner picture img {
            width: 100%;
        }

        #page_environment .sec_challenge .inner img {
            margin: 9.33vw auto 13.33vw;
            width: 100%;
        }

        #page_environment .sec_challenge .inner .inner_box {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            flex-wrap: wrap;
            width: 100%;
            margin-bottom: 14.67vw;
        }

        #page_environment .sec_challenge .inner .inner_box .txt_box {
            text-align: justify;
            width: 100%;
        }

        #page_environment .sec_challenge .inner .inner_box .txt_box h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_environment .sec_challenge .inner .inner_box .txt_box p {
            text-align: justify;
            font-size: 3.73vw;
            margin-bottom: 1.5em;
        }

        #page_environment .sec_challenge .inner .inner_box .txt_box dl {
            margin: 0 0 1.5em;
            font-size: 3.73vw;
        }

        #page_environment .sec_challenge .inner .inner_box .txt_box dl dt {
            line-height: 2;
        }

        #page_environment .sec_challenge .inner .inner_box .txt_box dl dd ul li {
            line-height: 2;
            text-indent: -1em;
            padding-left: 1em;
        }

        #page_environment .sec_challenge .inner .inner_box img {
            width: 100%;
        }

        #page_environment .sec_challenge .inner .inner_box figure {
            position: relative;
        }

        #page_environment .sec_challenge .inner .inner_box figure figcaption {
            text-align: right;
            font-size: 3.73vw;
            margin-top: .5em;
        }

        #page_environment .sec_challenge .inner .inner_box figure figcaption.relocation_cap {
            position: absolute;
            top: 56vw;
            right: 0;
        }

        #page_environment .sec_challenge .inner .inner_box:last-child {
            margin-bottom: 0;
        }

        #page_environment .sec_deoxygenization .inner h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_environment .txt-img_column.sec_deoxygenization .inner .inner_box:nth-of-type(1) {
            margin-top: 14.67vw;
        }

        #page_environment .sec_enlightenment {
            margin-bottom: 7.33vw;
        }

        #page_environment .sec_index_list {
            margin-bottom: 17.33vw;
        }

        #page_environment .materiality_btn {
            position: fixed;
            right: 3.47vw;
            top: 19vw;
            display: flex;
            align-items: center;
            width: 43.47vw;
            background: #fff;
            color: #004B9E;
            font-size: 2.67vw;
            font-weight: 600;
            border: 1px solid #004B9E;
            border-radius: 3px;
        }

        #page_environment .materiality_btn img {
            width: 16.8vw;
        }

        #page_environment .materiality_btn span {
            margin: auto;
            text-align: left;
        }

        #page_environment .sec_index_list .inner .inner_box+.inner_box {
            margin-top: 2.67vw;
        }

        
        
        #page_environment .sec_recyclingBasedSociety .development_wrap {
            margin-top: 18.67vw;
            position: relative;
        }

        #page_environment .sec_recyclingBasedSociety .development_wrap .inner h4 {
            font-size: 4.8vw;
        margin: 0 auto 5.33vw;
        }

#page_environment .sec_recyclingBasedSociety .development_wrap .inner p {
    margin: 0;
}
        
        
    #page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box {
        margin: 0 auto;
        padding-bottom: 0;
    }

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap {
    margin-top: 0;
    padding: 0;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div {
     width: 100%;
     text-align: center;
     margin-top: 5.33vw;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div img,
#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div figure img {
    margin: 0;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div figure figcaption {
    text-align: left;
}

#page_environment .sec_recyclingBasedSociety .development_wrap .inner .inner_box .img_wrap .img_box_2div h5 {
    text-align: left;
     font-size: 4.27vw;
     font-weight: 700;
     margin-top: 1em;
}

#page_environment .sec_recyclingBasedSociety .plafree_wrap {
        margin-top: 14.67vw;
}

#page_environment .sec_recyclingBasedSociety .plafree_wrap .plafree_img_wrap figure + figure {
    margin-top: 6.67vw;
}
        
        
        
        
        





        
        
        
        
        
        
        
        
        
    }

    @media only screen and (max-width: 768px) and (-webkit-min-device-pixel-ratio: 2) {
        #page_environment .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/environment/mv_sp@2x.png) top center no-repeat;
            background-size: cover;
        }
    }

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

        /* --------------------------------
  
   society　ページ
  
  -------------------------------- */
        #page_society {
            padding: 16vw 0 0;
            margin-top: 0;
        }

        #page_society .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/society/mv_sp.png) top center no-repeat;
            background-size: 100%;
        }

        #page_society .hero .hero_ttl {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            z-index: 1;
            width: 100%;
        }

        #page_society .hero .hero_ttl h2 {
            position: relative;
            display: inline-block;
            color: #F6AD4F;
            font-size: 5.33vw;
            font-weight: 600;
            background: rgba(255, 255, 255, 0.8);
            min-width: 64vw;
            max-width: 94.67vw;
            padding: 4.8vw 7vw;
            line-height: 1;
        }

        #page_society .hero:after {
            content: '';
            display: none;
        }

        #page_society .sec_businessArea {
            padding-top: 16vw;
        }

        #page_society .sec_businessArea .sec_ttl {
            margin-bottom: 13.33vw;
        }

        #page_society .sec_businessArea .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 0;
            position: relative;
        }

        #page_society .sec_businessArea .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            left: 50%;
            transform: translateX(-50%);
            margin: 2.67vw auto 9.33vw;
            background: #F6AD4F;
        }

        #page_society .sec_businessArea .sec_ttl h3 span {
            display: block;
            font-size: 4.27vw;
            font-weight: 300;
        }

        #page_society .sec_businessArea .inner {
            width: 76vw;
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
            margin: 0 auto;
        }

        #page_society .sec_businessArea .inner a {
            display: inline-block;
            font-size: 3.73vw;
            color: #fff;
            box-sizing: border-box;
            padding: 2.33vw 4vw;
            border: none;
            border-radius: 5px;
            text-align: center;
            margin-bottom: 1.67vw;
        }

        #page_society .sec_businessArea .inner a+a {
            margin-left: 0;
        }

        #page_society .sec_businessArea .inner a:nth-child(even) {
            margin-left: 1.33vw;
        }

        #page_society .sec_diversity,
        #page_society .sec_workStyles,
        #page_society .sec_training {
            padding: 5.33vw 0 16vw;
            margin-bottom: 0;
        }

        #page_society .sec_training {
            margin-bottom: 13.33vw;
        }

        #page_society .sec_diversity .sec_ttl,
        #page_society .sec_workStyles .sec_ttl,
        #page_society .sec_training .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_society .sec_diversity .sec_ttl h3,
        #page_society .sec_workStyles .sec_ttl h3,
        #page_society .sec_training .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_society .sec_diversity .sec_ttl h3:after,
        #page_society .sec_workStyles .sec_ttl h3:after,
        #page_society .sec_training .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #F6AD4F;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_society .sec_diversity .sec_ttl h3 span,
        #page_society .sec_workStyles .sec_ttl h3 span,
        #page_society .sec_training .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_society .sec_diversity .inner,
        #page_society .sec_workStyles .inner,
        #page_society .sec_training .inner {
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
        }

        #page_society .sec_diversity .inner h4,
        #page_society .sec_workStyles .inner h4,
        #page_society .sec_training .inner h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_society .sec_diversity .inner p,
        #page_society .sec_workStyles .inner p,
        #page_society .sec_training .inner p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_society .sec_diversity .inner img,
        #page_society .sec_workStyles .inner img,
        #page_society .sec_training .inner img {
            margin: 9.33vw auto 13.33vw;
        }

        #page_society .sec_diversity .inner .img_wrap img {
            margin-bottom: 12vw;
        }

        #page_society .sec_diversity .inner .inner_box,
        #page_society .sec_workStyles .inner .inner_box,
        #page_society .sec_training .inner .inner_box {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            flex-wrap: wrap;
            width: 100%;
            margin-bottom: 14.67vw;
        }

        #page_society .sec_diversity .inner .inner_box .txt_box,
        #page_society .sec_workStyles .inner .inner_box .txt_box,
        #page_society .sec_training .inner .inner_box .txt_box {
            text-align: justify;
            width: 100%;
        }

        #page_society .sec_diversity .inner .inner_box .txt_box h4,
        #page_society .sec_workStyles .inner .inner_box .txt_box h4,
        #page_society .sec_training .inner .inner_box .txt_box h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_society .sec_diversity .inner .inner_box .txt_box p,
        #page_society .sec_workStyles .inner .inner_box .txt_box p,
        #page_society .sec_training .inner .inner_box .txt_box p {
            text-align: justify;
            font-size: 3.73vw;
            margin-bottom: 1.5em;
        }
        
        #page_society .sec_workStyles .inner .inner_box .txt_box p.note {
            text-align: justify;
            font-size: 3.47vw;
            margin-top: 0;
            line-height: 1.85;
        }

        #page_society .sec_diversity .inner .inner_box .txt_box dl,
        #page_society .sec_workStyles .inner .inner_box .txt_box dl,
        #page_society .sec_training .inner .inner_box .txt_box dl {
            margin: 0 0 1.5em;
            font-size: 3.73vw;
        }

        #page_society .sec_diversity .inner .inner_box .txt_box dl dt,
        #page_society .sec_workStyles .inner .inner_box .txt_box dl dt,
        #page_society .sec_training .inner .inner_box .txt_box dl dt {
            line-height: 2;
        }

        #page_society .sec_diversity .inner .inner_box .txt_box dl dd ul li,
        #page_society .sec_workStyles .inner .inner_box .txt_box dl dd ul li,
        #page_society .sec_training .inner .inner_box .txt_box dl dd ul li {
            line-height: 2;
            text-indent: -1em;
            padding-left: 1em;
        }

        #page_society .sec_diversity .inner .inner_box img,
        #page_society .sec_workStyles .inner .inner_box img,
        #page_society .sec_training .inner .inner_box img {
            width: 100%;
        }

        #page_society .sec_diversity .inner .inner_box figure,
        #page_society .sec_workStyles .inner .inner_box figure,
        #page_society .sec_training .inner .inner_box figure {
            position: relative;
        }

        #page_society .sec_diversity .inner .inner_box figure figcaption,
        #page_society .sec_workStyles .inner .inner_box figure figcaption,
        #page_society .sec_training .inner .inner_box figure figcaption {
            text-align: right;
            font-size: 3.73vw;
            margin-top: .5em;
        }

        #page_society .sec_diversity .inner .inner_box figure figcaption.relocation_cap,
        #page_society .sec_workStyles .inner .inner_box figure figcaption.relocation_cap,
        #page_society .sec_training .inner .inner_box figure figcaption.relocation_cap {
            position: absolute;
            top: 56vw;
            right: 0;
        }

        #page_society .sec_diversity .inner .inner_box:last-child,
        #page_society .sec_workStyles .inner .inner_box:last-child,
        #page_society .sec_training .inner .inner_box:last-child {
            margin-bottom: 0;
        }

        #page_society .sec_diversity .inner .img_wrap,
        #page_society .sec_workStyles .inner .img_wrap,
        #page_society .sec_training .inner .img_wrap {
            width: 100%;
        }

        #page_society .sec_diversity .inner .img_wrap picture img,
        #page_society .sec_diversity .inner .img_wrap img,
        #page_society .sec_workStyles .inner .img_wrap picture img,
        #page_society .sec_workStyles .inner .img_wrap img,
        #page_society .sec_training .inner .img_wrap picture img,
        #page_society .sec_training .inner .img_wrap img {
            margin: 6.67vw 0 0 0;
            width: 100%;
        }

        #page_society .sec_diversity .inner .img_wrap picture+picture img,
        #page_society .sec_diversity .inner .img_wrap img+img,
        #page_society .sec_workStyles .inner .img_wrap picture+picture img,
        #page_society .sec_workStyles .inner .img_wrap img+img,
        #page_society .sec_training .inner .img_wrap picture+picture img,
        #page_society .sec_training .inner .img_wrap img+img {
            margin: 2.67vw 0 12vw 0;
        }

        #page_society .sec_diversity .inner .inner_box .group_wrap {
            display: flex;
            flex-wrap: wrap;
            justify-content: space-around;
            width: 100%;
            text-align: justify;
            margin: 5.33vw auto 0;
        }

        #page_society .sec_diversity .inner .inner_box .group_wrap .group_box {
            width: 100%;
        }

        #page_society .sec_diversity .inner .inner_box .group_wrap .group_box+.group_box {
            margin-top: 2.67vw;
        }

        #page_society .sec_diversity .inner .inner_box .group_wrap .group_box h5 {
            font-size: 4.27vw;
            font-weight: 700;
            margin-bottom: 0;
            line-height: 1;
            letter-spacing: normal;
            padding: 2.67vw;
        }

        #page_society .sec_diversity .inner .inner_box .group_wrap .group_box ol,
        #page_society .sec_diversity .inner .inner_box .group_wrap .group_box p {
            font-size: 3.73vw;
            padding: 4vw 5.33vw;
            min-height: auto;
            line-height: 1.57;
        }

        #page_society .sec_diversity .inner .inner_box .group_wrap .group_box ol li {
            padding: 0 0 0 8vw;
        }

        #page_society .sec_diversity .inner .inner_box .group_wrap .group_box ol li:before {
            height: 6.67vw;
            width: 6.67vw;
            font-size: 3.2vw;
            top: 0;
            transform: unset;
        }

        #page_society .sec_workStyles .inner:last-child picture {
            width: 100%;
        }
        
        #page_society .sec_workStyles .inner .inner_box .group_wrap {
            display: flex;
            flex-wrap: wrap;
            justify-content: space-between;
            text-align: justify;
            margin: 5.33vw auto 14.67vw;
            width: 100%;
            padding: 0;
        }

        #page_society .sec_workStyles .inner .inner_box .group_wrap .group_box {
            width: 48%;
        }
        
        #page_society .sec_attempt .inner .inner_box.support,
        #page_society .sec_attempt .inner .inner_box.bunko {
            display: block;
        }

        #page_society .sec_attempt .inner .inner_box.support h4,
        #page_society .sec_attempt .inner .inner_box.bunko h4 {
            position: relative;
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_society .sec_attempt .inner .inner_box.support h4+p,
        #page_society .sec_attempt .inner .inner_box.bunko h4+p {
            margin-top: 0;
        }

        #page_society .sec_attempt .inner .inner_box.support p,
        #page_society .sec_attempt .inner .inner_box.bunko p {
            text-align: left;
            font-size: 3.73vw;
        }

        #page_society .sec_attempt .inner .inner_box.support p+p,
        #page_society .sec_attempt .inner .inner_box.bunko p+p {
            margin-top: 50px;
        }

        #page_society .sec_attempt .inner .inner_box.support dl {
            display: flex;
            justify-content: space-between;
            line-height: 2;
            text-align: justify;
            flex-wrap: wrap;
            margin-top: 6.67vw;
        }

        #page_society .sec_attempt .inner .inner_box.support dl dt {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            justify-content: center;
            width: 21.33vw;
            font-weight: 600;
            font-size: 3.73vw;
            background: #FFD9A8;
            border-top: 1px solid #fff;
            text-align: center;
            line-height: 1.25;
        }

        #page_society .sec_attempt .inner .inner_box.support dl dt:first-child {
            border-top: none;
        }

        #page_society .sec_attempt .inner .inner_box.support dl dd {
            width: 71.73vw;
            padding: 9.33vw 4vw;
            border-top: 1px solid #fff;
            font-size: 3.73vw;
            line-height: 1.57;
            background: #FFF7DE;
        }

        #page_society .sec_attempt .inner .inner_box.support dl dd:first-child {
            border-top: none;
        }

        #page_society .sec_attempt .inner .inner_box.support dl dd h5 {
            font-size: 3.73vw;
            line-height: 1.57;
        }
        
        /* 20250804 ここから */
        #page_society .sec_attempt .bookstore_img_wrap figure + figure {
            margin-top: 6.67vw;
        }
        /* 20250804 ここまで */

        #page_society .txt-img_column {
            padding: 5.33vw 0 24.67vw;
            margin-bottom: 0;
        }

        #page_society .txt-img_column .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_society .txt-img_column .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_society .txt-img_column .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #F6AD4F;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_society .txt-img_column .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_society .txt-img_column .inner {
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
        }

        #page_society .txt-img_column .inner p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_society .txt-img_column .inner .inner_box {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            flex-wrap: wrap;
            width: 100%;
            margin-bottom: 14.67vw;
        }

        #page_society .txt-img_column .inner .inner_box .txt_box {
            text-align: justify;
            width: 100%;
        }

        #page_society .txt-img_column .inner .inner_box .txt_box h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_society .txt-img_column .inner .inner_box .txt_box p {
            text-align: justify;
            font-size: 3.73vw;
            margin-bottom: 1.5em;
        }

        #page_society .txt-img_column .inner .inner_box .txt_box dl {
            margin: 0 0 1.5em;
            font-size: 3.73vw;
        }

        #page_society .txt-img_column .inner .inner_box .txt_box dl dt {
            line-height: 2;
        }

        #page_society .txt-img_column .inner .inner_box .txt_box dl dd ul li {
            line-height: 2;
            text-indent: -1em;
            padding-left: 1em;
        }

        #page_society .txt-img_column .inner .inner_box picture {
            width: 100%;
        }

        #page_society .txt-img_column .inner .inner_box picture img {
            width: 100%;
        }

        #page_society .txt-img_column .inner .inner_box img {
            width: 100%;
        }

        #page_society .txt-img_column .inner .inner_box figure {
            position: relative;
        }

        #page_society .txt-img_column .inner .inner_box figure figcaption {
            text-align: right;
            font-size: 3.73vw;
            margin-top: .5em;
        }

        #page_society .txt-img_column .inner .inner_box figure figcaption.relocation_cap {
            position: absolute;
            top: 56vw;
            right: 0;
        }

        #page_society .txt-img_column .inner .inner_box:last-child {
            margin-bottom: 0;
        }

        #page_society .sec_attempt.txt-img_column {
            padding: 5.33vw 0 16vw;
            margin-bottom: 0;
        }

        #page_society .sec_training .inner p.note {
            text-align: center;
        }

        #page_society .sec_index_list {
            margin-bottom: 17.33vw;
        }
        
            #page_society .txt-img_column .inner .inner_box figure {
            width: 100%;
        }
        
        #page_society .sec_workStyles .balance_img_wrap figure + figure,
        #page_society .sec_attempt .eco_img_wrap figure + figure {
            margin-top:6.67vw;
        }
    }

    @media only screen and (max-width: 768px) and (-webkit-min-device-pixel-ratio: 2) {
        #page_society .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/society/mv_sp@2x.png) top center no-repeat;
            background-size: cover;
        }
    }

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

        /* --------------------------------
  
   esg配下のgovernance　ページ
  
  -------------------------------- */
        #page_governance.under_esg {
            padding: 16vw 0 0;
            margin-top: 0;
        }

        #page_governance.under_esg .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/esg_governance/mv_sp.png) top center no-repeat;
            background-size: 100%;
        }

        #page_governance.under_esg .hero .hero_ttl {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            z-index: 1;
            width: 100%;
        }

        #page_governance.under_esg .hero .hero_ttl h2 {
            position: relative;
            display: inline-block;
            color: #0092D7;
            font-size: 5.33vw;
            font-weight: 600;
            background: rgba(255, 255, 255, 0.8);
            min-width: 64vw;
            max-width: 94.67vw;
            padding: 4.8vw 7vw;
            line-height: 1;
        }

        #page_governance.under_esg .hero:after {
            content: '';
            display: none;
        }

        #page_governance.under_esg .sec_businessArea {
            padding-top: 16vw;
        }

        #page_governance.under_esg .sec_businessArea .sec_ttl {
            margin-bottom: 13.33vw;
        }

        #page_governance.under_esg .sec_businessArea .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 0;
            position: relative;
        }

        #page_governance.under_esg .sec_businessArea .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            left: 50%;
            transform: translateX(-50%);
            margin: 2.67vw auto 9.33vw;
            background: #0092D7;
        }

        #page_governance.under_esg .sec_businessArea .sec_ttl h3 span {
            display: block;
            font-size: 4.27vw;
            font-weight: 300;
        }

        #page_governance.under_esg .sec_businessArea .inner {
            width: 90.47vw;
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
            margin: 0 auto;
        }

        #page_governance.under_esg .sec_businessArea .inner a {
            display: inline-block;
            font-size: 3.73vw;
            color: #fff;
            box-sizing: border-box;
            padding: 2.33vw 4vw;
            border: none;
            border-radius: 5px;
            text-align: center;
            margin-bottom: 1.67vw;
        }

        #page_governance.under_esg .sec_businessArea .inner a+a {
            margin-left: 0;
        }

        #page_governance.under_esg .sec_businessArea .inner a:nth-child(3) {
            margin-left: 1.33vw;
        }

        #page_governance.under_esg .sec_corporateGovernance {
            padding: 5.33vw 0 16vw;
            margin-bottom: 0;
        }

        #page_governance.under_esg .sec_corporateGovernance .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_governance.under_esg .sec_corporateGovernance .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_governance.under_esg .sec_corporateGovernance .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #0092D7;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_governance.under_esg .sec_corporateGovernance .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner.mt {
            margin-top: 13.33vw;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap {
            display: flex;
            justify-content: space-between;
            align-items: top;
            flex-wrap: wrap;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div {
            width: 100%;
            text-align: center;
            padding: 8vw 5.33vw;
            border: 1px solid #0092D7;
            border-radius: 6px;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div h5 {
            font-size: 4.27vw;
            font-weight: 600;
            text-align: center;
            margin-bottom: 1em;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div p {
            text-align: justify;
            letter-spacing: .03em;
            font-size: 3.73vw;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div p+p {
            margin-top: 20px;
        }

        #page_governance.under_esg .sec_corporateGovernance .inner .inner_box .box_wrap .box_2div+.box_2div {
            margin-top: 2.67vw;
        }

        #page_governance.under_esg .sec_corporateGovernance .diagram_wrap .diagram_box {
            background: rgba(198, 237, 255, 0.31);
            padding: 13.33vw 0;
            margin: 8vw auto 30px;
        }

        #page_governance.under_esg .sec_corporateGovernance .diagram_wrap .diagram_box .inner h5 {
            font-size: 4.27vw;
            margin: 0 auto;
        }

        #page_governance.under_esg .sec_corporateGovernance .diagram_wrap .diagram_box .inner img {
            margin-top: 8vw;
            width: 100%;
        }

        #page_governance.under_esg .sec_corporateGovernance .diagram_wrap .inner p {
            text-align: justify;
        }

        #page_governance.under_esg .sec_riskManagement,
        #page_governance.under_esg .sec_compliance {
            padding: 16vw 0 0;
            margin-bottom: 16vw;
        }

        #page_governance.under_esg .sec_riskManagement .sec_ttl,
        #page_governance.under_esg .sec_compliance .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_governance.under_esg .sec_riskManagement .sec_ttl h3,
        #page_governance.under_esg .sec_compliance .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_governance.under_esg .sec_riskManagement .sec_ttl h3:after,
        #page_governance.under_esg .sec_compliance .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #0092D7;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_governance.under_esg .sec_riskManagement .sec_ttl h3 span,
        #page_governance.under_esg .sec_compliance .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_governance.under_esg .sec_riskManagement .inner,
        #page_governance.under_esg .sec_compliance .inner {
            margin-top: 13.33vw;
        }

        #page_governance.under_esg .sec_riskManagement .inner.mt,
        #page_governance.under_esg .sec_compliance .inner.mt {
            margin-top: 13.33vw;
        }

        #page_governance.under_esg .sec_riskManagement .inner h4,
        #page_governance.under_esg .sec_compliance .inner h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_governance.under_esg .sec_riskManagement .inner p,
        #page_governance.under_esg .sec_compliance .inner p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_governance.under_esg .sec_riskManagement .inner .inner_box .box_wrap,
        #page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap {
            display: flex;
            justify-content: space-between;
            align-items: top;
            flex-wrap: wrap;
            margin-bottom: 0;
        }

        #page_governance.under_esg .sec_riskManagement .inner .inner_box .box_wrap .txt_box,
        #page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap .txt_box {
            text-align: justify;
            width: 600px;
        }

        #page_governance.under_esg .sec_riskManagement .inner .inner_box .box_wrap .txt_box h4,
        #page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap .txt_box h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_governance.under_esg .sec_riskManagement .inner .inner_box .box_wrap .txt_box p,
        #page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap .txt_box p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_governance.under_esg .sec_riskManagement .inner .inner_box .box_wrap img,
        #page_governance.under_esg .sec_compliance .inner .inner_box .box_wrap img {
            width: 100%;
            margin-top: 8vw;
        }
        
        #page_governance.under_esg .sec_riskManagement .inner .inner_box {
            margin-top: 6.67vw;
        }

        #page_governance.under_esg .sec_compliance {
            margin-bottom: 32vw;
        }

        #page_governance.under_esg .sec_compliance .inner p.note {
            margin-top: 14.67vw;
            text-align: center;
        }
    }

    @media only screen and (max-width: 768px) and (-webkit-min-device-pixel-ratio: 2) {
        #page_governance.under_esg .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/esg_governance/mv_sp@2x.png) top center no-repeat;
            background-size: cover;
        }
    }

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

        /* --------------------------------
  
   materiality　ページ
  
  -------------------------------- */
        #page_materiality {
            padding: 16vw 0 0;
            margin-top: 0;
        }

        #page_materiality .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/materiality/mv_sp.png) top center no-repeat;
            background-size: 100%;
        }

        #page_materiality .hero .hero_ttl {
            position: absolute;
            bottom: -25%;
            left: 50%;
            transform: translate(-50%, 0);
            z-index: 1;
        }

        #page_materiality .hero .hero_ttl h2 {
            align-items: center;
            color: #fff;
            width: 82.67vw;
            height: 36.67vw;
            background: #FFF;
            color: #004B9E;
            padding: 0 6.67vw;
            font-size: 5.87vw;
        }

        #page_materiality .hero .hero_ttl h2 span {
            color: #000;
            font-size: 3.2vw;
            line-height: 2;
            margin: 1.67vw 0 0;
            display: block;
        }

        #page_materiality .hero:after {
            content: '';
            display: none;
        }
        
        #page_materiality .sec_m_environment .inner p.sec_subttl,
        #page_materiality .sec_m_society .inner p.sec_subttl {
            font-size: 5.87vw;
            font-weight: 700;
            letter-spacing: -.01em;
            margin-bottom: 7vw;
            line-height: 1.78;
            text-align: center;
        }

        #page_materiality .sec_businessArea {
            padding-top: 21.33vw;
            width: 100%;
        }

        #page_materiality .sec_businessArea .sec_ttl {
            margin-bottom: 13.33vw;
        }

        #page_materiality .sec_businessArea .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 0;
            position: relative;
        }

        #page_materiality .sec_businessArea .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            left: 50%;
            transform: translateX(-50%);
            margin: 2.67vw auto 9.33vw;
            background: #004B9E;
        }

        #page_materiality .sec_businessArea .sec_ttl h3 span {
            display: block;
            font-size: 4.27vw;
            font-weight: 300;
        }

        #page_materiality .sec_businessArea .inner {
            width: 93.33vw;
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
            margin: 0 auto;
            padding: 0;
        }

        #page_materiality .sec_businessArea .inner a {
            display: inline-block;
            font-size: 3.73vw;
            color: #fff;
            box-sizing: border-box;
            padding: 2.33vw 4vw;
            border: none;
            border-radius: 5px;
            text-align: center;
            margin-bottom: 1.67vw;
        }

        #page_materiality .sec_businessArea .inner a+a {
            margin-left: 1.33vw;
        }

        #page_materiality .sec_businessArea .inner a:last-child {
            margin-left: 0;
        }

        #page_materiality .sec_m_environment,
        #page_materiality .sec_m_society {
            padding: 5.33vw 0 0;
            margin-bottom: 32vw;
        }
        
        #page_materiality .sec_m_environment {
            margin-bottom: 16vw;
        }

        #page_materiality .sec_m_environment .sec_ttl,
        #page_materiality .sec_m_society .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_materiality .sec_m_environment .sec_ttl h3,
        #page_materiality .sec_m_society .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_materiality .sec_m_environment .sec_ttl h3:after,
        #page_materiality .sec_m_society .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #004B9E;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_materiality .sec_m_environment .sec_ttl h3 span,
        #page_materiality .sec_m_society .sec_ttl h3 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_materiality .sec_m_environment .inner+.inner,
        #page_materiality .sec_m_society .inner+.inner {
            margin-top: 13.33vw;
        }

        #page_materiality .sec_m_environment .inner.mt,
        #page_materiality .sec_m_society .inner.mt {
            margin-top: 13.33vw;
        }

        #page_materiality .sec_m_environment .inner h4,
        #page_materiality .sec_m_society .inner h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_materiality .sec_m_environment .inner p,
        #page_materiality .sec_m_society .inner p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }
        
        #page_materiality .sec_m_society .inner .resolve_wrap {
            flex-wrap: wrap;
            width: 100%;
            margin: 6.67vw auto 0;
        }

        #page_materiality .sec_m_society .inner .resolve_wrap img {
            width: 58.67vw;
            margin: 5.33vw auto 0;
        }

        #page_materiality .sec_m_society .inner .resolve_wrap ol {
            flex: auto;
            width: 100%;
            line-height: 2;
        }

        #page_materiality .sec_m_society .inner .resolve_wrap ol li {
            padding: 0 0 0 8vw;
        }

        #page_materiality .sec_m_society .inner .resolve_wrap ol li:before {
            height: 4.8vw;
            width: 4.8vw;
            font-size: 2.93vw;
            top: .5em;
            transform: unset;
        }
        
        #page_materiality .sec_m_environment .inner ol,
        #page_materiality .sec_m_society .inner ol  {
            font-size: 3.73vw;
        }

        #page_materiality .sec_m_environment .inner p+p,
        #page_materiality .sec_m_society .inner p+p,
        #page_materiality .sec_m_environment .inner p+ol,
        #page_materiality .sec_m_society .inner p+ol {
            margin-top: 1.5em;
        }

        #page_materiality .sec_m_environment .inner .inner_box .img_wrap,
        #page_materiality .sec_m_society .inner .inner_box .img_wrap {
            margin-top: 6.67vw;
        }

        #page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div,
        #page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div {
            width: 100%;
            text-align: center;
            padding: 8vw 5.33vw;
            border: 1px solid #004B9E;
            border-radius: 6px;
        }

        #page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div h5,
        #page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div h5 {
            font-size: 4.27vw;
            font-weight: 600;
            text-align: center;
            margin-bottom: 1em;
        }

        #page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div p,
        #page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div p {
            text-align: justify;
            letter-spacing: .03em;
            font-size: 3.73vw;
        }

        #page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div p+p,
        #page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div p+p {
            margin-top: 1.5em;
        }

        #page_materiality .sec_m_environment .inner .inner_box .box_wrap .box_2div+.box_2div,
        #page_materiality .sec_m_society .inner .inner_box .box_wrap .box_2div+.box_2div {
            margin-top: 2.67vw;
        }

        #page_materiality .sec_m_environment .diagram_wrap .diagram_box,
        #page_materiality .sec_m_society .diagram_wrap .diagram_box {
            background: rgba(198, 237, 255, 0.31);
            padding: 13.33vw 0;
            margin: 8vw auto 30px;
        }

        #page_materiality .sec_m_environment .diagram_wrap .diagram_box .inner h5,
        #page_materiality .sec_m_society .diagram_wrap .diagram_box .inner h5 {
            font-size: 4.27vw;
            margin: 0 auto;
        }

        #page_materiality .sec_m_environment .diagram_wrap .diagram_box .inner img,
        #page_materiality .sec_m_society .diagram_wrap .diagram_box .inner img {
            margin-top: 8vw;
            width: 100%;
        }

        #page_materiality .sec_m_environment .diagram_wrap .inner p,
        #page_materiality .sec_m_society .diagram_wrap .inner p {
            text-align: justify;
        }

        #page_materiality .sec_task {
            padding: 5.33vw 0 0;
            margin-bottom: 16vw;
        }

        #page_materiality .sec_task .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_materiality .sec_task .sec_ttl h3 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
        }

        #page_materiality .sec_task .sec_ttl h3:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #004B9E;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_materiality .sec_task .inner {
            margin-top: 13.33vw;
        }

        #page_materiality .sec_task .inner h4 {
            font-size: 7.47vw;
            margin: 0;
            letter-spacing: 0em;
            text-align: center;
            line-height: 1.5;
        }

        #page_materiality .sec_task .inner {
            width: 100%;
        }

        #page_materiality .sec_task .inner .inner_box .img_wrap {
            margin: 0 calc(50% - 50vw);
            width: 100vw;
        }

        #page_materiality .sec_task .inner .inner_box .img_wrap img,
        #page_materiality .sec_m_environment .inner .inner_box .img_wrap img,
        #page_materiality .sec_m_society .inner .inner_box .img_wrap img {
            width: 100%;
        }

        #page_materiality .goals.inner .group_wrap {
            display: flex;
            flex-wrap: wrap;
            justify-content: space-around;
            width: 100%;
            text-align: justify;
            margin: 4vw auto 0;
        }

        #page_materiality .goals.inner .group_wrap h4 {
            font-size: 4.27vw;
            margin: 0 auto 4vw;
        }

        #page_materiality .goals.inner .group_wrap p.note {
            font-size: 3.2vw;
            margin: 4vw auto 8vw;
            letter-spacing: 0;
        }

        #page_materiality .goals.inner .group_wrap .group_box {
            width: 100%;
        }

        #page_materiality .goals.inner .group_wrap .group_box+.group_box {
            margin-top: 2.67vw;
        }

        #page_materiality .goals.inner .group_wrap .group_box h5 {
            font-size: 4.27vw;
            font-weight: 700;
            margin-bottom: 0;
            line-height: 1;
            letter-spacing: normal;
            padding: 4vw;
        }

        #page_materiality .goals.inner .group_wrap .group_box .group_box_inner {
            padding: 2.67vw 0 4vw;
            min-height: auto;
        }

        #page_materiality .goals.inner .group_wrap .group_box .group_box_inner p {
            font-size: 9.07vw;
        }

        #page_materiality .goals.inner .group_wrap .group_box .group_box_inner p span {
            font-size: 13.33vw;
        }

        #page_materiality .goals.inner .group_wrap .group_box .group_box_inner p span.mark_minus {
            font-size: 6.67vw;
        }

        #page_materiality .goals.inner .group_wrap .group_box .group_box_inner p.specific_num {
            font-size: 3.73vw;
        }

        #page_materiality .goals.inner .group_wrap .group_box .group_box_inner p small {
            font-size: 5.33vw;
        }

        #page_materiality .goals.inner,
        #page_materiality .sec_task .inner {
            width: 100%;
        }

        #page_materiality .goals.inner .inner_box {
            width: 100%;
        }

        #page_materiality .sec_task .inner .inner_box .img_wrap {
            margin: 0 calc(50% - 50vw);
            width: 100vw;
        }

        #page_materiality .sec_task .inner .inner_box .img_wrap img,
        #page_materiality .sec_m_environment .inner .inner_box .img_wrap img,
        #page_materiality .goals.inner .img_wrap img,
        #page_materiality .sec_m_society .inner .inner_box .img_wrap img, {
            width: 100%;
        }

        #page_materiality .goals.inner .inner_box .box_wrap {
            display: flex;
            justify-content: space-between;
            align-items: center;
            flex-wrap: wrap;
            margin-bottom: 0;
            width: 100%;
        }

        #page_materiality .goals.inner .inner_box .box_wrap .box_2div {
            width: 100%;
        }

        #page_materiality .goals.inner .inner_box .box_wrap .box_2div+.box_2div {
            margin-top: 2.67vw;
        }

        #page_materiality .goals.inner .inner_box .box_wrap .box_2div picture {
            width: 100%;
        }

        #page_materiality .goals.inner .inner_box .box_wrap .box_2div picture img {
            width: 100%;
        }

        #page_materiality .goals.inner .inner_box .box_wrap .txt_box {
            text-align: justify;
            width: 600px;
        }

        #page_materiality .goals.inner .inner_box .box_wrap .txt_box h4 {
            font-size: 4.8vw;
            margin: 0 0 1em;
            letter-spacing: 0em;
            text-align: center;
        }

        #page_materiality .goals.inner .inner_box .box_wrap .txt_box p {
            text-align: justify;
            font-size: 3.73vw;
            margin-top: 0;
        }

        #page_materiality .goals.inner .inner_box .box_wrap img {
            width: 100%;
            margin-top: 0;
        }
    }

    @media only screen and (max-width: 768px) and (-webkit-min-device-pixel-ratio: 2) {
        #page_materiality .hero {
            position: relative;
            padding: 0;
            height: 53.33vw;
            background: url(../img/materiality/mv_sp@2x.png) top center no-repeat;
            background-size: cover;
        }
    }

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

        /* --------------------------------
  
  esg配下の news　ページ
  
  -------------------------------- */
        #page_news {
            padding: 16vw 0 0;
            margin-top: 0;
        }

        #page_news .sec_esgNews {
            padding: 21.33vw 0 40vw;
        }

        #page_news .sec_esgNews .sec_ttl {
            margin-bottom: 18vw;
        }

        #page_news .sec_esgNews .sec_ttl h2 {
            font-size: 5.33vw;
            margin-bottom: 3vw;
            position: relative;
            font-weight: 600;
        }

        #page_news .sec_esgNews .sec_ttl h2:after {
            content: '';
            display: block;
            position: absolute;
            width: 21.33vw;
            height: 4px;
            background: #004B9E;
            left: 50%;
            transform: translateX(-50%);
            margin: 4vw auto 13.33vw;
        }

        #page_news .sec_esgNews .sec_ttl h2 span {
            font-size: 3.73vw;
            font-weight: 600;
            margin: 1vw auto;
        }

        #page_news .sec_esgNews .inner {
            width: 100%;
        }

        #page_news .sec_esgNews .inner .inner_box {
            position: relative;
            margin: 0 auto;
        }

        #page_news .sec_esgNews .inner .inner_box ul li {
            padding: 4vw 0;
            text-align: justify;
            border-bottom: 1px solid #DDDDDD;
        }

        #page_news .sec_esgNews .inner .inner_box ul li dl dt {
            color: #666666;
            margin-bottom: 2.67vw;
            font-size: 3.73vw;
        }

        #page_news .sec_esgNews .inner .inner_box ul li dl dt span {
            display: inline-block;
            font-size: 3.2vw;
            color: #004B9E;
            min-width: 24vw;
            box-sizing: border-box;
            padding: 3px 10px;
            border: 1px solid #004B9E;
            border-radius: 3px;
            text-align: center;
            margin-left: 0;
        }

        #page_news .sec_esgNews .inner .inner_box ul li dl dt span+span {
            margin-left: 7px;
        }

        #page_news .sec_esgNews .inner .inner_box ul li dl dt span.esg_tag {
            background: #BBF5B3;
            color: #007E67;
            border: none;
        }

        #page_news .sec_esgNews .inner .inner_box ul li dl dd {
            word-break: break-all;
        }

        #page_news .sec_esgNews .inner .inner_box ul li dl dd a {
            line-height: 2;
            font-size: 3.73vw;
        }
    }

    /*  220224 ESG追加　ここまで */