@charset "UTF-8";
@media screen and (min-width: 1024px) {
  .btn_style01 {
    width: 100%;
  }
  .btn_style01 a, .btn_style01 a:link a:visited {
    position: relative;
    width: 100%;
    height: 64px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.0;
    background-color: #ffffff;
    border: 1px solid #E1E8F0;
    border-radius: 32px;
    -webkit-border-radius: 32px;
    -moz-border-radius: 32px;
  }
  .btn_style01 a img, .btn_style01 a:link a:visited img {
    width: 18px;
    padding-left: 6px;
  }
  .btn_style01 a:hover {
    color: #111111;
    background-color: #F4F6F9;
  }
  .btn_style01 .arrow {
    overflow: hidden;
    position: absolute;
    top: 15px;
    right: 15px;
    width: 34px;
    height: 34px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
  .btn_style01 .arrow:before,
  .btn_style01 .arrow:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 34px;
    height: 34px;
    background: url(../img/arrow02.svg) no-repeat center center;
    background-size: 10px;
    -webkit-animation-fill-mode: forwards;
            animation-fill-mode: forwards;
    -webkit-animation-duration: 0.3s;
            animation-duration: 0.3s;
  }
  .btn_style01 .arrow:after {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  .btn_style01 a:hover .arrow:before {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .btn_style01 a:hover .arrow:after {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .btn_style01 {
    width: 100%;
  }
  .btn_style01 a, .btn_style01 a:link a:visited {
    position: relative;
    width: 100%;
    height: 60px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.0;
    background-color: #ffffff;
    border: 1px solid #E1E8F0;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
  }
  .btn_style01 a img, .btn_style01 a:link a:visited img {
    width: 18px;
    padding-left: 6px;
  }
  .btn_style01 a:hover {
    color: #111111;
    background-color: #F4F6F9;
  }
  .btn_style01 .arrow {
    overflow: hidden;
    position: absolute;
    top: 15px;
    right: 15px;
    width: 30px;
    height: 30px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
  .btn_style01 .arrow:before,
  .btn_style01 .arrow:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 30px;
    height: 30px;
    background: url(../img/arrow02.svg) no-repeat center center;
    background-size: 10px;
    -webkit-animation-fill-mode: forwards;
            animation-fill-mode: forwards;
    -webkit-animation-duration: 0.3s;
            animation-duration: 0.3s;
  }
  .btn_style01 .arrow:after {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  .btn_style01 a:hover .arrow:before {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .btn_style01 a:hover .arrow:after {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
}

@media screen and (max-width: 767px) {
  .btn_style01 {
    width: 100%;
  }
  .btn_style01 a {
    position: relative;
    width: 100%;
    height: 52px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.55rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.0;
    background-color: #ffffff;
    border: 1px solid #E1E8F0;
    border-radius: 26px;
    -webkit-border-radius: 26px;
    -moz-border-radius: 26px;
  }
  .btn_style01 a img {
    width: 18px;
    padding-left: 6px;
  }
  .btn_style01 a .arrow {
    display: none;
  }
  .btn_style01 a::after {
    content: '';
    position: absolute;
    top: 11px;
    right: 11px;
    width: 30px;
    height: 30px;
    background: url(../img/arrow02.svg) no-repeat center center;
    background-size: 9px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
}

@media screen and (min-width: 1024px) {
  .btn_style02 {
    width: 100%;
  }
  .btn_style02 a, .btn_style02 a:link a:visited {
    width: 100%;
    height: 60px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #ffffff;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.0;
    background: url(../img/btn_arrow_wh.svg) no-repeat right 10px center;
    background-size: 40px;
    background-color: #0054A7;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
  }
  .btn_style02 a img, .btn_style02 a:link a:visited img {
    width: 24px;
    padding-right: 8px;
  }
  .btn_style02 a:hover {
    color: #ffffff;
    background: url(../img/btn_arrow_wh.svg) no-repeat right 7px center;
    background-size: 40px;
    background-color: #124287;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .btn_style02 {
    width: 100%;
  }
  .btn_style02 a {
    width: 100%;
    height: 56px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #ffffff;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.0;
    background-color: #0054A7;
    border-radius: 28px;
    -webkit-border-radius: 28px;
    -moz-border-radius: 28px;
  }
  .btn_style02 a img {
    width: 24px;
    padding-right: 8px;
  }
  .btn_style02 a:hover {
    color: #ffffff;
    background-color: #124287;
  }
}

@media screen and (max-width: 767px) {
  .btn_style02 {
    width: 100%;
  }
  .btn_style02 a {
    width: 100%;
    height: 54px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #ffffff;
    font-size: 1.55rem;
    font-weight: 500;
    line-height: 1.0;
    background-color: #0054A7;
    border-radius: 27px;
    -webkit-border-radius: 27px;
    -moz-border-radius: 27px;
  }
  .btn_style02 a img {
    width: 24px;
    padding-right: 8px;
  }
}

@media screen and (min-width: 1024px) {
  .cta_btn_style01 {
    width: 100%;
  }
  .cta_btn_style01 a, .cta_btn_style01 a:link a:visited {
    position: relative;
    width: 100%;
    height: 78px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 1.0;
    background-color: #ffffff;
    border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
  }
  .cta_btn_style01 a:hover {
    color: #111111;
    background-color: #F4F6F9;
  }
  .cta_btn_style01 a::after {
    content: '';
    position: absolute;
    top: 13px;
    right: 13px;
    width: 52px;
    height: 52px;
    background: url(../img/search_icon.svg) no-repeat center center;
    background-size: 20px;
    background-color: #F4F6F9;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  .cta_btn_style01 a:hover::after {
    content: '';
    position: absolute;
    top: 13px;
    right: 13px;
    width: 52px;
    height: 52px;
    background: url(../img/search_icon_wh.svg) no-repeat center center;
    background-size: 20px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .cta_btn_style01 {
    width: 100%;
  }
  .cta_btn_style01 a, .cta_btn_style01 a:link a:visited {
    position: relative;
    width: 100%;
    height: 70px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1.0;
    background-color: #ffffff;
    border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
  }
  .cta_btn_style01 a:hover {
    color: #111111;
    background-color: #F4F6F9;
  }
  .cta_btn_style01 a::after {
    content: '';
    position: absolute;
    top: 11px;
    right: 11px;
    width: 48px;
    height: 48px;
    background: url(../img/search_icon.svg) no-repeat center center;
    background-size: 18px;
    background-color: #F4F6F9;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  .cta_btn_style01 a:hover::after {
    content: '';
    position: absolute;
    top: 11px;
    right: 11px;
    width: 48px;
    height: 48px;
    background: url(../img/search_icon_wh.svg) no-repeat center center;
    background-size: 18px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
}

@media screen and (max-width: 767px) {
  .cta_btn_style01 {
    width: 100%;
  }
  .cta_btn_style01 a {
    position: relative;
    width: 100%;
    height: 60px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.55rem;
    font-weight: 600;
    line-height: 1.0;
    background-color: #ffffff;
    border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
  }
  .cta_btn_style01 a::after {
    content: '';
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    background: url(../img/search_icon.svg) no-repeat center center;
    background-size: 14px;
    background-color: #F4F6F9;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
}

@media screen and (min-width: 1024px) {
  .cta_btn_style02 {
    width: 100%;
  }
  .cta_btn_style02 a, .cta_btn_style02 a:link a:visited {
    position: relative;
    width: 100%;
    height: 78px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 1.0;
    background-color: #ffffff;
    border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
  }
  .cta_btn_style02 a:hover {
    color: #111111;
    background-color: #F4F6F9;
  }
  .cta_btn_style02 a::after {
    content: '';
    position: absolute;
    top: 13px;
    right: 13px;
    width: 52px;
    height: 52px;
    background: url(../img/cta_arrow.svg) no-repeat center center;
    background-size: 20px;
    background-color: #F4F6F9;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  .cta_btn_style02 a:hover::after {
    content: '';
    position: absolute;
    top: 13px;
    right: 13px;
    width: 52px;
    height: 52px;
    background: url(../img/cta_arrow_wh.svg) no-repeat center center;
    background-size: 20px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .cta_btn_style02 {
    width: 100%;
  }
  .cta_btn_style02 a, .cta_btn_style02 a:link a:visited {
    position: relative;
    width: 100%;
    height: 70px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1.0;
    background-color: #ffffff;
    border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
  }
  .cta_btn_style02 a:hover {
    color: #111111;
    background-color: #F4F6F9;
  }
  .cta_btn_style02 a::after {
    content: '';
    position: absolute;
    top: 11px;
    right: 11px;
    width: 48px;
    height: 48px;
    background: url(../img/cta_arrow.svg) no-repeat center center;
    background-size: 16px;
    background-color: #F4F6F9;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  .cta_btn_style02 a:hover::after {
    content: '';
    position: absolute;
    top: 11px;
    right: 11px;
    width: 48px;
    height: 48px;
    background: url(../img/cta_arrow_wh.svg) no-repeat center center;
    background-size: 16px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
}

@media screen and (max-width: 767px) {
  .cta_btn_style02 {
    width: 100%;
  }
  .cta_btn_style02 a {
    position: relative;
    width: 100%;
    height: 60px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.55rem;
    font-weight: 600;
    line-height: 1.0;
    background-color: #ffffff;
    border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
  }
  .cta_btn_style02 a::after {
    content: '';
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    background: url(../img/cta_arrow.svg) no-repeat center center;
    background-size: 14px;
    background-color: #F4F6F9;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  }
}

@media screen and (min-width: 1024px) {
  .download_btn_style01 {
    width: 100%;
  }
  .download_btn_style01 button {
    cursor: pointer;
    position: relative;
    width: 100%;
    height: 56px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #ffffff;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.0;
    background-color: #0054A7;
    border-radius: 32px;
    -webkit-border-radius: 32px;
    -moz-border-radius: 32px;
    border: none;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  .download_btn_style01 button img {
    width: 22px;
    padding-right: 8px;
  }
  .download_btn_style01 button:hover {
    color: #ffffff;
    background-color: #124287;
    border: none;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .download_btn_style01 {
    width: 100%;
  }
  .download_btn_style01 button {
    position: relative;
    width: 100%;
    height: 54px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #ffffff;
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.0;
    background-color: #0054A7;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    border: none;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  .download_btn_style01 button img {
    width: 20px;
    padding-right: 8px;
  }
  .download_btn_style01 button:hover {
    color: #ffffff;
    background-color: #124287;
    border: none;
  }
}

@media screen and (max-width: 767px) {
  .download_btn_style01 {
    width: 100%;
  }
  .download_btn_style01 button {
    position: relative;
    width: 100%;
    height: 48px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #ffffff;
    font-size: 1.45rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.0;
    background-color: #0054A7;
    border-radius: 26px;
    -webkit-border-radius: 26px;
    -moz-border-radius: 26px;
    border: none;
  }
  .download_btn_style01 button img {
    width: 18px;
    padding-right: 6px;
  }
  .download_btn_style01 button .arrow {
    display: none;
  }
}

/* ########## header ########## */
@media screen and (min-width: 1024px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 80px;
    background-color: #ffffff;
    z-index: 1000;
    border-bottom: 1px solid #E1E8F0;
  }
  .header .header_detail {
    position: relative;
    width: 94%;
    height: 80px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 0 auto;
  }
  .header .header_detail__logo {
    position: relative;
    width: 180px;
  }
  .header .header_detail__logo p {
    width: 100%;
  }
  .header .header_detail__logo p img {
    width: 100%;
  }
  .header .header_detail__nav {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    height: 80px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-left: 20px;
  }
  .header .header_detail__nav__menu {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    height: 80px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    gap: 0 2.5%;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega {
    position: relative;
    font-size: min(1.0vw, 14px);
    font-weight: 600;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega p {
    position: relative;
    font-weight: 600;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega p a, .header .header_detail__nav__menu li.header_detail__nav__menu__mega p a:link a:visited {
    position: relative;
    color: #111111;
    height: 80px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega p a::after {
    position: absolute;
    bottom: 24px;
    left: 0;
    content: '';
    width: 100%;
    height: 3px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega p a:hover {
    color: #0054A7;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega p a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega p.current a {
    color: #0054A7;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega p.current::after {
    position: absolute;
    bottom: 24px;
    left: 0;
    content: '';
    width: 100%;
    height: 3px;
    background: #0054A7;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega div.header_detail__nav__menu__mega__sub {
    position: absolute;
    width: 320px;
    top: 60px;
    left: 50%;
    background-color: #ffffff;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    -webkit-box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.08);
            box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.08);
    visibility: hidden;
    opacity: 0;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    z-index: 30;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega div.header_detail__nav__menu__mega__sub ul.header_detail__nav__menu__mega__sub__list {
    position: relative;
    width: 100%;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega div.header_detail__nav__menu__mega__sub ul.header_detail__nav__menu__mega__sub__list li {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E1E8F0;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega div.header_detail__nav__menu__mega__sub ul.header_detail__nav__menu__mega__sub__list li a, .header .header_detail__nav__menu li.header_detail__nav__menu__mega div.header_detail__nav__menu__mega__sub ul.header_detail__nav__menu__mega__sub__list li a:link a:visited {
    position: relative;
    font-weight: 600;
    height: 50px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    background: url(../img/arrow01.svg) no-repeat right 15px center;
    background-size: 10px;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega div.header_detail__nav__menu__mega__sub ul.header_detail__nav__menu__mega__sub__list li a::after {
    background: none;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega div.header_detail__nav__menu__mega__sub ul.header_detail__nav__menu__mega__sub__list li a:hover {
    background: url(../img/arrow01.svg) no-repeat right 10px center;
    background-size: 10px;
    background-color: #F4F6F9;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega div.header_detail__nav__menu__mega__sub ul.header_detail__nav__menu__mega__sub__list li:last-of-type {
    border-bottom: none;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__mega:hover div.header_detail__nav__menu__mega__sub {
    visibility: visible;
    opacity: 1;
    top: 70px;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__list {
    position: relative;
    font-size: min(1.0vw, 14px);
    font-weight: 600;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__list a, .header .header_detail__nav__menu li.header_detail__nav__menu__list a:link a:visited {
    position: relative;
    color: #111111;
    height: 80px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__list a::after {
    position: absolute;
    bottom: 24px;
    left: 0;
    content: '';
    width: 100%;
    height: 3px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__list a:hover {
    color: #0054A7;
  }
  .header .header_detail__nav__menu li.header_detail__nav__menu__list a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .header .header_detail__nav__menu li.current a {
    color: #0054A7;
  }
  .header .header_detail__nav__menu li.current::after {
    position: absolute;
    bottom: 24px;
    left: 0;
    content: '';
    width: 100%;
    height: 3px;
    background: #0054A7;
  }
  .header .header_detail__nav p.header_detail__nav__menu__contact {
    position: relative;
    width: 170px;
    padding-left: 25px;
  }
  .header .header_detail__nav p.header_detail__nav__menu__contact a, .header .header_detail__nav p.header_detail__nav__menu__contact a:link a:visited {
    position: relative;
    color: #ffffff;
    width: 145px;
    height: 48px;
    font-size: min(1.0vw, 14px);
    font-weight: 500;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    background-color: #0054A7;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
  }
  .header .header_detail__nav p.header_detail__nav__menu__contact a img, .header .header_detail__nav p.header_detail__nav__menu__contact a:link a:visited img {
    width: 12px;
    margin-right: 6px;
  }
  .header .header_detail__nav p.header_detail__nav__menu__contact a:hover {
    background-color: #124287;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 70px;
    background: url(../img/tab_nav_icon_backimg.svg) no-repeat right top;
    background-size: 70px;
    background-color: #ffffff;
    z-index: 1000;
    border-bottom: 1px solid #E1E8F0;
  }
  .header .header_detail {
    position: relative;
    width: 94%;
    height: 70px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 0 auto;
  }
  .header .header_detail__logo {
    position: relative;
    width: 160px;
  }
  .header .header_detail__logo p {
    width: 100%;
  }
  .header .header_detail__logo p img {
    width: 100%;
  }
  .header .header_detail__nav {
    display: none;
  }
  .header .header_detail__nav__menu {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 56px;
    background: url(../img/sp_nav_icon_backimg.svg) no-repeat right top;
    background-size: 56px;
    background-color: #ffffff;
    z-index: 1000;
    border-bottom: 1px solid #E1E8F0;
  }
  .header .header_detail {
    position: relative;
    width: 90%;
    height: 56px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 0 auto;
  }
  .header .header_detail__logo {
    position: relative;
    width: 140px;
  }
  .header .header_detail__logo p {
    width: 100%;
  }
  .header .header_detail__logo p img {
    width: 100%;
  }
  .header .header_detail__nav {
    display: none;
  }
  .header .header_detail__nav__menu {
    display: none;
  }
}

/* ########## header ########## */
/* ########## nav_menu ########## */
@media screen and (min-width: 1024px) {
  div.nav_menu {
    display: none;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  div.nav_menu {
    position: fixed;
    top: 0;
    right: 0;
    display: block;
    width: 70px;
    height: 70px;
    z-index: 9000;
  }
  div.nav_menu a.nav_menu__icon {
    position: relative;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 70px;
    height: 70px;
    text-align: center;
    text-decoration: none;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  div.nav_menu a.nav_menu__icon .menu__line {
    display: block;
    height: 1px;
    position: absolute;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  div.nav_menu a.nav_menu__icon .menu__line--top {
    width: 32px;
    top: 20px;
    left: 19px;
    background-color: #ffffff;
  }
  div.nav_menu a.nav_menu__icon .menu__line--center {
    width: 32px;
    top: 27px;
    left: 19px;
    background-color: #ffffff;
  }
  div.nav_menu a.nav_menu__icon .menu__line--bottom {
    width: 20px;
    bottom: 35px;
    left: 19px;
    background-color: #ffffff;
  }
  div.nav_menu a.nav_menu__icon.active {
    width: 100%;
    height: 70px;
    background: url(../img/tab_gnav_backimg.svg) no-repeat right top;
    background-size: 70px;
  }
  div.nav_menu a.nav_menu__icon.active .menu__line {
    display: block;
    height: 1px;
    position: absolute;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  div.nav_menu a.nav_menu__icon.active .menu__line--top {
    width: 32px;
    top: 27px;
    left: 19px;
    background-color: #0054A7;
    -webkit-transform: rotate(30deg);
            transform: rotate(30deg);
  }
  div.nav_menu a.nav_menu__icon.active .menu__line--center {
    display: none;
  }
  div.nav_menu a.nav_menu__icon.active .menu__line--bottom {
    width: 32px;
    bottom: 42px;
    left: 19px;
    background-color: #0054A7;
    -webkit-transform: rotate(-30deg);
            transform: rotate(-30deg);
  }
}

@media screen and (max-width: 767px) {
  div.nav_menu {
    position: fixed;
    top: 0;
    right: 0;
    display: block;
    width: 56px;
    height: 56px;
    z-index: 9000;
  }
  div.nav_menu a.nav_menu__icon {
    position: relative;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 56px;
    height: 56px;
    text-align: center;
    text-decoration: none;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  div.nav_menu a.nav_menu__icon .menu__line {
    display: block;
    height: 1px;
    position: absolute;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  div.nav_menu a.nav_menu__icon .menu__line--top {
    width: 26px;
    top: 15px;
    left: 15px;
    background-color: #ffffff;
  }
  div.nav_menu a.nav_menu__icon .menu__line--center {
    width: 26px;
    top: 21px;
    left: 15px;
    background-color: #ffffff;
  }
  div.nav_menu a.nav_menu__icon .menu__line--bottom {
    width: 20px;
    bottom: 28px;
    left: 15px;
    background-color: #ffffff;
  }
  div.nav_menu a.nav_menu__icon.active {
    width: 100%;
    height: 56px;
    background: url(../img/sp_gnav_backimg.svg) no-repeat right top;
    background-size: 56px;
  }
  div.nav_menu a.nav_menu__icon.active .menu__line {
    display: block;
    height: 1px;
    position: absolute;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  div.nav_menu a.nav_menu__icon.active .menu__line--top {
    width: 26px;
    top: 21px;
    left: 15px;
    background-color: #0054A7;
    -webkit-transform: rotate(30deg);
            transform: rotate(30deg);
  }
  div.nav_menu a.nav_menu__icon.active .menu__line--center {
    display: none;
  }
  div.nav_menu a.nav_menu__icon.active .menu__line--bottom {
    width: 26px;
    bottom: 34px;
    left: 15px;
    background-color: #0054A7;
    -webkit-transform: rotate(-30deg);
            transform: rotate(-30deg);
  }
}

@media screen and (min-width: 1024px) {
  .gnav {
    display: none;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .gnav {
    background-color: #F4F6F9;
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 6000;
  }
  .gnav .gnav__wrap {
    position: relative;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 30px;
  }
  .gnav .gnav__wrap__logo {
    position: relative;
    width: 100%;
    height: 70px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0 3%;
  }
  .gnav .gnav__wrap__logo p {
    width: 160px;
  }
  .gnav .gnav__wrap__logo p img {
    width: 100%;
  }
  .gnav .gnav__wrap div.gnav__menu {
    width: 70%;
    margin: 20px auto 0;
    background-color: #ffffff;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    /*　closeというクラスがついたら形状変化　*/
    /*アコーディオンで現れるエリア*/
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__list {
    border-bottom: 1px solid #E1E8F0;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__list p {
    text-align: center;
    font-size: 1.5rem;
    letter-spacing: 0.1em;
    font-weight: 600;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__list p a {
    width: 100%;
    height: 56px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    line-height: 1.0;
    background: url(../img/arrow01.svg) no-repeat right 15px center;
    background-size: 10px;
    background-color: #ffffff;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__contact {
    font-size: 1.6rem;
    font-weight: 600;
    padding: 25px 0;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__contact a {
    position: relative;
    color: #ffffff;
    width: 60%;
    height: 60px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    background-color: #0054A7;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    margin: 0 auto;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__contact a img {
    width: 14px;
    margin-right: 6px;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-area {
    list-style: none;
    width: 100%;
    margin: 0 auto;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-area ul {
    margin: 0 10px 13px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-area ul li {
    width: 49.6%;
    margin-bottom: 3px;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-area ul li a {
    position: relative;
    width: 100%;
    height: 52px;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: 0.075em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background-color: #F4F6F9;
    padding: 0 0 0 15px;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title {
    position: relative;
    /*+マークの位置基準とするためrelative指定*/
    font-size: 1.5rem;
    height: 56px;
    font-weight: 600;
    color: #111111;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    line-height: 1.0;
    -webkit-transition: all .5s ease;
    transition: all .5s ease;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title::before,
  .gnav .gnav__wrap div.gnav__menu .accordion-title::after {
    position: absolute;
    content: '';
    width: 11px;
    height: 1px;
    background-color: #0054A7;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title::before {
    top: 48%;
    right: 15px;
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title::after {
    top: 48%;
    right: 15px;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title.close::after {
    display: none;
  }
  .gnav .gnav__wrap div.gnav__menu .box {
    display: none;
    /*はじめは非表示*/
  }
  .gnav .gnav__wrap div.gnav__menu02 {
    width: 70%;
    margin: 30px auto 0;
    background-color: #0054A7;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    padding: 30px 0;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style01 {
    width: 60%;
    margin: 0 auto;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style01 a {
    font-size: 1.5rem;
    height: 52px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style01 a::after {
    content: '';
    position: absolute;
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    background: url(../img/search_icon.svg) no-repeat center center;
    background-size: 12px;
    background-color: #F4F6F9;
    border-radius: 26px;
    -webkit-border-radius: 26px;
    -moz-border-radius: 26px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style02 {
    width: 60%;
    margin: 0 auto;
    margin-top: 15px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style02 a {
    font-size: 1.5rem;
    height: 52px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style02 a::after {
    content: '';
    position: absolute;
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    background: url(../img/cta_arrow.svg) no-repeat center center;
    background-size: 12px;
    background-color: #F4F6F9;
    border-radius: 26px;
    -webkit-border-radius: 26px;
    -moz-border-radius: 26px;
  }
}

@media screen and (max-width: 767px) {
  .gnav {
    background-color: #F4F6F9;
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 6000;
  }
  .gnav .gnav__wrap {
    position: relative;
    height: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 30px;
  }
  .gnav .gnav__wrap__logo {
    position: relative;
    width: 100%;
    height: 56px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0 5%;
  }
  .gnav .gnav__wrap__logo p {
    width: 140px;
  }
  .gnav .gnav__wrap__logo p img {
    width: 100%;
  }
  .gnav .gnav__wrap div.gnav__menu {
    width: 90%;
    margin: 15px auto 0;
    background-color: #ffffff;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    /*　closeというクラスがついたら形状変化　*/
    /*アコーディオンで現れるエリア*/
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__list {
    border-bottom: 1px solid #E1E8F0;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__list p {
    text-align: center;
    font-size: 1.45rem;
    letter-spacing: 0.1em;
    font-weight: 600;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__list p a {
    width: 100%;
    height: 50px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    line-height: 1.0;
    background: url(../img/arrow01.svg) no-repeat right 15px center;
    background-size: 10px;
    background-color: #ffffff;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__contact {
    font-size: 1.45rem;
    padding: 25px 25px;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__contact a {
    position: relative;
    color: #ffffff;
    font-weight: 500;
    width: 100%;
    height: 52px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    background-color: #0054A7;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
  }
  .gnav .gnav__wrap div.gnav__menu div.gnav__menu__contact a img {
    width: 12px;
    margin-right: 6px;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-area {
    list-style: none;
    width: 100%;
    margin: 0 auto;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-area ul {
    margin: 0 10px 13px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-area ul li {
    width: 49.6%;
    margin-bottom: 3px;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-area ul li a {
    position: relative;
    width: 100%;
    height: 44px;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: 0.075em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background-color: #F4F6F9;
    padding: 0 10px;
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title {
    position: relative;
    /*+マークの位置基準とするためrelative指定*/
    font-size: 1.45rem;
    height: 50px;
    font-weight: 600;
    color: #111111;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    line-height: 1.0;
    -webkit-transition: all .5s ease;
    transition: all .5s ease;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title::before,
  .gnav .gnav__wrap div.gnav__menu .accordion-title::after {
    position: absolute;
    content: '';
    width: 11px;
    height: 1px;
    background-color: #0054A7;
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title::before {
    top: 48%;
    right: 15px;
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title::after {
    top: 48%;
    right: 15px;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .gnav .gnav__wrap div.gnav__menu .accordion-title.close::after {
    display: none;
  }
  .gnav .gnav__wrap div.gnav__menu .box {
    display: none;
    /*はじめは非表示*/
  }
  .gnav .gnav__wrap div.gnav__menu02 {
    width: 90%;
    margin: 20px auto 0;
    background-color: #0054A7;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    padding: 25px 25px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style01 {
    width: 100%;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style01 a {
    font-size: 1.5rem;
    height: 52px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style01 a::after {
    content: '';
    position: absolute;
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    background: url(../img/search_icon.svg) no-repeat center center;
    background-size: 12px;
    background-color: #F4F6F9;
    border-radius: 26px;
    -webkit-border-radius: 26px;
    -moz-border-radius: 26px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style02 {
    width: 100%;
    margin-top: 15px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style02 a {
    font-size: 1.5rem;
    height: 52px;
  }
  .gnav .gnav__wrap div.gnav__menu02 .cta_btn_style02 a::after {
    content: '';
    position: absolute;
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    background: url(../img/cta_arrow.svg) no-repeat center center;
    background-size: 12px;
    background-color: #F4F6F9;
    border-radius: 26px;
    -webkit-border-radius: 26px;
    -moz-border-radius: 26px;
  }
}

/* ########## nav_menu ########## */
@media screen and (min-width: 1024px) {
  .page_cta {
    position: relative;
    width: 100%;
    background: url(../img/shiraiwa_mark02.svg) no-repeat right -60px bottom -140px;
    background-size: 620px;
    background-color: #0054A7;
    padding: 100px 0 110px;
  }
  .page_cta__detail {
    position: relative;
    width: 82%;
    margin: 0 auto;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .page_cta__detail__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  .page_cta__detail__txt h2 {
    font-size: 3.6rem;
    font-weight: 800;
    color: #ffffff;
  }
  .page_cta__detail__txt p {
    width: 80%;
    text-align: justify;
    font-size: 1.5rem;
    color: #ffffff;
    line-height: 2.0;
    margin-top: 30px;
  }
  .page_cta__detail__btn {
    position: relative;
    width: 450px;
  }
  .page_cta__detail__btn p {
    margin-bottom: 20px;
  }
  .page_cta ul {
    position: relative;
    width: 82%;
    margin: 60px auto 0;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .page_cta ul li {
    width: 23%;
  }
  .page_cta ul li a, .page_cta ul li a:link a:visited {
    position: relative;
    color: #ffffff;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 10px 2px;
    border-bottom: 1px solid #E1E8F0;
    background: url(../img/arrow02.svg) no-repeat right 10px top 8px;
    background-size: 10px;
  }
  .page_cta ul li a::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #ffffff;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .page_cta ul li a:hover {
    color: #ffffff;
    background: url(../img/arrow02.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .page_cta ul li a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .page_cta ul li img {
    width: 12px;
    margin-left: 6px;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .page_cta {
    position: relative;
    width: 100%;
    background: url(../img/shiraiwa_mark02.svg) no-repeat right -160px center;
    background-size: 540px;
    background-color: #0054A7;
    padding: 80px 0 90px;
  }
  .page_cta__detail {
    position: relative;
    width: 86%;
    margin: 0 auto;
  }
  .page_cta__detail__txt {
    position: relative;
    width: 100%;
  }
  .page_cta__detail__txt h2 {
    font-size: 3rem;
    font-weight: 800;
    line-height: 1.7;
    color: #ffffff;
  }
  .page_cta__detail__txt p {
    font-size: 1.5rem;
    color: #ffffff;
    line-height: 2.0;
    margin-top: 25px;
  }
  .page_cta__detail__btn {
    position: relative;
    width: 100%;
    margin-top: 40px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .page_cta__detail__btn p {
    width: 48%;
  }
  .page_cta ul {
    position: relative;
    width: 86%;
    margin: 60px auto 0;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .page_cta ul li {
    width: 47.5%;
  }
  .page_cta ul li a, .page_cta ul li a:link a:visited {
    position: relative;
    color: #ffffff;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 10px 2px;
    border-bottom: 1px solid #E1E8F0;
    background: url(../img/arrow02.svg) no-repeat right 10px top 8px;
    background-size: 10px;
  }
  .page_cta ul li a::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #ffffff;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .page_cta ul li a:hover {
    color: #ffffff;
    background: url(../img/arrow02.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .page_cta ul li a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .page_cta ul li img {
    width: 12px;
    margin-left: 6px;
  }
  .page_cta ul li:nth-child(n+3) {
    margin-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .page_cta {
    position: relative;
    width: 100%;
    background: url(../img/shiraiwa_mark02.svg) no-repeat right -200px center;
    background-size: 480px;
    background-color: #0054A7;
    padding: 60px 7% 65px;
  }
  .page_cta__detail {
    position: relative;
    width: 100%;
  }
  .page_cta__detail__txt {
    position: relative;
    width: 100%;
  }
  .page_cta__detail__txt h2 {
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 1.8;
    color: #ffffff;
  }
  .page_cta__detail__txt p {
    text-align: justify;
    font-size: 1.3rem;
    font-weight: 400;
    color: #ffffff;
    line-height: 2.0;
    margin-top: 15px;
  }
  .page_cta__detail__btn {
    position: relative;
    width: 100%;
    margin-top: 30px;
  }
  .page_cta__detail__btn p {
    margin-top: 15px;
  }
  .page_cta ul {
    position: relative;
    width: 100%;
    margin: 40px auto 0;
  }
  .page_cta ul li {
    width: 100%;
    margin-top: 20px;
  }
  .page_cta ul li a {
    position: relative;
    color: #ffffff;
    font-size: 1.45rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 8px 2px;
    border-bottom: 1px solid #ffffff;
    background: url(../img/arrow02.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .page_cta ul li img {
    width: 12px;
    margin-left: 6px;
  }
}

@media screen and (min-width: 1024px) {
  .footer {
    position: relative;
    width: 100%;
    background-color: #ffffff;
  }
  .footer__nav {
    position: relative;
    width: 100%;
    background-color: #F4F6F9;
    padding: 80px 9%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .footer__nav__list {
    position: relative;
    width: 23%;
  }
  .footer__nav__list h3 {
    color: #111111;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1.2;
    padding-bottom: 10px;
    border-bottom: 1px solid #E1E8F0;
  }
  .footer__nav__list h4 {
    color: #0054A7;
    font-size: 1.3rem;
    font-weight: 600;
    margin-top: 30px;
  }
  .footer__nav__list ul {
    margin-top: 15px;
    font-size: 1.3rem;
  }
  .footer__nav__list ul li {
    margin-top: 8px;
    font-weight: 500;
    background: url(../img/list_backimg.svg) no-repeat 3px center;
    background-size: 6px;
    padding-left: 15px;
  }
  .footer__nav__list ul li a, .footer__nav__list ul li a:link a:visited {
    position: relative;
    color: #111111;
  }
  .footer__nav__list ul li a::after {
    position: absolute;
    bottom: -2px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .footer__nav__list ul li a:hover {
    color: #0054A7;
  }
  .footer__nav__list ul li a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .footer__nav__list ul li img {
    width: 12px;
    margin-left: 6px;
    padding-bottom: 4px;
  }
  .footer__copy {
    width: 100%;
    height: 70px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    padding: 0 9%;
    border-top: 1px solid #E1E8F0;
  }
  .footer__copy p {
    position: relative;
    width: 50%;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.0;
    letter-spacing: 0.075em;
  }
  .footer__copy ul {
    position: relative;
    width: 50%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .footer__copy ul li {
    font-size: 1.2rem;
    letter-spacing: 0.075em;
    margin-left: 20px;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .footer {
    position: relative;
    width: 100%;
    background-color: #ffffff;
  }
  .footer__nav {
    position: relative;
    width: 100%;
    background-color: #F4F6F9;
    padding: 80px 7%;
  }
  .footer__nav__list {
    position: relative;
    width: 100%;
  }
  .footer__nav__list h3 {
    color: #111111;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1.2;
    padding-bottom: 10px;
    border-bottom: 1px solid #E1E8F0;
  }
  .footer__nav__list h4 {
    color: #0054A7;
    font-size: 1.4rem;
    font-weight: 600;
    margin-top: 20px;
  }
  .footer__nav__list ul {
    margin-top: 15px;
    font-size: 1.2rem;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .footer__nav__list ul li {
    width: 48%;
    margin-top: 8px;
    font-weight: 500;
    background: url(../img/list_backimg.svg) no-repeat 3px center;
    background-size: 6px;
    padding-left: 15px;
  }
  .footer__nav__list ul li a, .footer__nav__list ul li a:link a:visited {
    position: relative;
    color: #111111;
  }
  .footer__nav__list ul li a::after {
    position: absolute;
    bottom: -2px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .footer__nav__list ul li a:hover {
    color: #0054A7;
  }
  .footer__nav__list ul li a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .footer__nav__list ul li img {
    width: 12px;
    margin-left: 6px;
    padding-bottom: 3px;
  }
  .footer__nav__list:nth-child(n+2) {
    margin-top: 40px;
  }
  .footer__copy {
    width: 100%;
    height: 60px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    padding: 0 7%;
    border-top: 1px solid #E1E8F0;
  }
  .footer__copy p {
    position: relative;
    width: 50%;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.0;
    letter-spacing: 0.075em;
  }
  .footer__copy ul {
    position: relative;
    width: 50%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .footer__copy ul li {
    font-size: 1.2rem;
    letter-spacing: 0.075em;
    margin-left: 15px;
  }
}

@media screen and (max-width: 767px) {
  .footer {
    position: relative;
    width: 100%;
    background-color: #ffffff;
  }
  .footer__nav {
    position: relative;
    width: 100%;
    background-color: #F4F6F9;
    padding: 30px 7%;
  }
  .footer__nav__list {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E1E8F0;
    padding: 30px 0;
  }
  .footer__nav__list h3 {
    color: #111111;
    font-size: 1.55rem;
    font-weight: 600;
    line-height: 1.2;
  }
  .footer__nav__list h4 {
    color: #0054A7;
    font-size: 1.2rem;
    font-weight: 600;
    margin-top: 20px;
  }
  .footer__nav__list ul {
    margin-top: 8px;
    font-size: 1.2rem;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .footer__nav__list ul li {
    width: 49%;
    margin-top: 8px;
    font-weight: 500;
    line-height: 1.6;
    background: url(../img/list_backimg.svg) no-repeat 3px 8px;
    background-size: 6px;
    padding-left: 15px;
  }
  .footer__nav__list ul li a {
    position: relative;
    color: #111111;
  }
  .footer__nav__list ul li img {
    width: 10px;
    margin-left: 6px;
    padding-bottom: 5px;
  }
  .footer__nav__list:last-of-type {
    border-bottom: none;
  }
  .footer__copy {
    width: 100%;
    padding: 0 7%;
    border-top: 1px solid #E1E8F0;
  }
  .footer__copy p {
    text-align: center;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.0;
    letter-spacing: 0.075em;
    padding: 22px 0;
    border-top: 1px solid #E1E8F0;
  }
  .footer__copy ul {
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 18px 0;
  }
  .footer__copy ul li {
    font-size: 1.1rem;
    letter-spacing: 0.075em;
    margin: 0 10px;
  }
}

/* ###### title_sp ##### */
@media screen and (min-width: 1024px) {
  .title_sp {
    text-align: center;
    position: relative;
    width: 100%;
    padding-bottom: 60px;
  }
  .title_sp h2 {
    color: #111111;
    font-weight: 800;
    font-size: 4rem;
    line-height: 1.2;
  }
  .title_sp p {
    color: #0054A7;
    font-weight: 600;
    font-size: 1.5rem;
    padding-bottom: 8px;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .title_sp {
    text-align: center;
    position: relative;
    width: 100%;
    padding-bottom: 50px;
  }
  .title_sp h2 {
    color: #111111;
    font-weight: 800;
    font-size: 3.6rem;
    line-height: 1.2;
  }
  .title_sp p {
    color: #0054A7;
    font-weight: 600;
    font-size: 1.5rem;
    padding-bottom: 8px;
  }
}

@media screen and (max-width: 767px) {
  .title_sp {
    position: relative;
    width: 86%;
    margin: 0 auto;
    padding-bottom: 35px;
  }
  .title_sp h2 {
    color: #111111;
    font-weight: 800;
    font-size: 2.6rem;
    line-height: 1.2;
  }
  .title_sp p {
    color: #0054A7;
    font-weight: 600;
    font-size: 1.3rem;
    line-height: 1.2;
    letter-spacing: 0.1em;
    padding-bottom: 6px;
    padding-left: 2px;
  }
}

/* ###### title_sp ##### */
/* ###### title_sp02 ##### */
@media screen and (min-width: 1024px) {
  .title_sp02 {
    text-align: center;
    position: relative;
    width: 100%;
    padding-bottom: 45px;
  }
  .title_sp02 h2 {
    color: #111111;
    font-weight: 800;
    font-size: 3.6rem;
    line-height: 1.2;
  }
  .title_sp02 p {
    color: #0054A7;
    font-weight: 600;
    font-size: 1.5rem;
    padding-bottom: 10px;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .title_sp02 {
    text-align: center;
    position: relative;
    width: 100%;
    padding-bottom: 40px;
  }
  .title_sp02 h2 {
    color: #111111;
    font-weight: 800;
    font-size: 3rem;
    line-height: 1.2;
  }
  .title_sp02 p {
    color: #0054A7;
    font-weight: 600;
    font-size: 1.5rem;
    padding-bottom: 8px;
  }
}

@media screen and (max-width: 767px) {
  .title_sp02 {
    position: relative;
    width: 86%;
    margin: 0 auto;
    padding-bottom: 30px;
  }
  .title_sp02 h2 {
    color: #111111;
    font-weight: 800;
    font-size: 2.2rem;
    line-height: 1.2;
  }
  .title_sp02 p {
    color: #0054A7;
    font-weight: 600;
    font-size: 1.2rem;
    line-height: 1.2;
    letter-spacing: 0.1em;
    padding-bottom: 6px;
  }
}

/* ###### title_sp02 ##### */
/* ###### side_title_sp ##### */
@media screen and (min-width: 1024px) {
  .side_title_sp {
    text-align: center;
    position: relative;
    width: 100%;
  }
  .side_title_sp h2 {
    color: #111111;
    font-weight: 500;
    font-size: 1.8rem;
    letter-spacing: 0.075em;
    line-height: 1.0;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .side_title_sp {
    text-align: center;
    position: relative;
    width: 100%;
  }
  .side_title_sp h2 {
    color: #111111;
    font-weight: 500;
    font-size: 2.4rem;
    line-height: 1.0;
    letter-spacing: 0.075em;
  }
}

@media screen and (max-width: 767px) {
  .side_title_sp {
    text-align: center;
    position: relative;
    width: 100%;
  }
  .side_title_sp h2 {
    color: #111111;
    font-weight: 500;
    font-size: 1.8rem;
    letter-spacing: 0.075em;
    line-height: 1.0;
  }
}

/* ###### side_title_sp ##### */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  border: 0;
  font-family: inherit;
  font-size: 100%;
  font-style: inherit;
  font-weight: inherit;
  margin: 0;
  outline: 0;
  padding: 0;
  vertical-align: baseline;
}

* {
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (min-width: 1024px) {
  html, body {
    font-size: 62.5%;
    overflow: visible;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  html, body {
    font-size: 62.5%;
    overflow: visible;
  }
}

@media screen and (max-width: 767px) {
  html, body {
    font-size: 62.5%;
    overflow: visible;
    overflow-x: hidden;
  }
}

body {
  height: 100%;
  color: #545454;
  background-color: #ffffff;
  font-family: "Poppins", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "メイリオ", "Meiryo", sans-serif;
  font-size: 10px;
  font-size: 1.0rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

ol, ul {
  list-style: none;
  font-weight: 400;
  letter-spacing: 0.05em;
}

h1 {
  font-weight: 400;
  letter-spacing: 0.05em;
}

h2 {
  font-weight: 400;
  letter-spacing: 0.05em;
}

h3 {
  font-weight: 400;
  letter-spacing: 0.05em;
}

h4 {
  font-weight: 400;
  letter-spacing: 0.05em;
}

h5 {
  font-weight: 400;
  letter-spacing: 0.05em;
}

h6 {
  font-weight: 400;
  letter-spacing: 0.05em;
}

p {
  font-weight: 400;
  letter-spacing: 0.05em;
}

dl {
  font-weight: 400;
  letter-spacing: 0.05em;
}

caption, th, td {
  font-weight: normal;
  text-align: left;
  vertical-align: top;
}

img {
  max-width: 100%;
  height: auto;
  width: auto;
  border: 0;
  vertical-align: bottom;
}

a, a:link a:visited {
  color: #111111;
  -webkit-transition: all .3s;
  transition: all .3s;
  text-decoration: none;
}

a:hover {
  color: #0054A7;
  text-decoration: none;
}

a.imghover:link img {
  -webkit-transition: all .3s;
  transition: all .3s;
}

a.imghover:hover img {
  filter: alpha(opacity=80);
  opacity: 0.8;
}

.imghover {
  -webkit-transition: all .3s;
  transition: all .3s;
}

.imghover:hover {
  filter: alpha(opacity=80);
  opacity: 0.8;
}

input:-internal-autofill-selected {
  background-color: #ffffff;
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeIn {
  0% {
    opacity: 0;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

.fadeUp {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
  opacity: 0;
}

@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@-webkit-keyframes transformLeftRight {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes transformLeftRight {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@-webkit-keyframes transformRightLeft {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}

@keyframes transformRightLeft {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}

@-webkit-keyframes pathmove {
  0% {
    height: 0;
    top: 0;
    opacity: 0;
  }
  30% {
    height: 30px;
    opacity: 1;
  }
  100% {
    height: 0;
    top: 50px;
    opacity: 0;
  }
}

@keyframes pathmove {
  0% {
    height: 0;
    top: 0;
    opacity: 0;
  }
  30% {
    height: 30px;
    opacity: 1;
  }
  100% {
    height: 0;
    top: 50px;
    opacity: 0;
  }
}

/* ########## container ########## */
@media screen and (min-width: 1024px) {
  .container {
    position: relative;
    width: 100%;
    animation: fadeIn 2s ease 0s 1 normal;
    -webkit-animation: fadeIn 2s ease 0s 1 normal;
    -moz-animation: fadeIn 2s ease 0s 1 normal;
    -o-animation: fadeIn 2s ease 0s 1 normal;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .container {
    position: relative;
    width: 100%;
    animation: fadeIn 2s ease 0s 1 normal;
    -webkit-animation: fadeIn 2s ease 0s 1 normal;
    -moz-animation: fadeIn 2s ease 0s 1 normal;
    -o-animation: fadeIn 2s ease 0s 1 normal;
  }
}

@media screen and (max-width: 767px) {
  .container {
    position: relative;
    width: 100%;
    animation: fadeIn 2s ease 0s 1 normal;
    -webkit-animation: fadeIn 2s ease 0s 1 normal;
    -moz-animation: fadeIn 2s ease 0s 1 normal;
    -o-animation: fadeIn 2s ease 0s 1 normal;
  }
}

/* ########## container ########## */
/* ########## index_contents ########## */
@media screen and (min-width: 1024px) {
  .index_contents {
    position: relative;
    width: 100%;
    background-color: #ffffff;
    margin: 0 auto;
  }
  .index_contents__main {
    position: relative;
    width: 100%;
    height: 100vh;
    background-color: #F4F6F9;
  }
  .index_contents__main__catch {
    position: absolute;
    top: 50%;
    right: 4.5%;
    width: 500px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    z-index: 5;
  }
  .index_contents__main__catch h2 {
    color: #ffffff;
    font-size: 5.6rem;
    font-weight: 900;
    line-height: 1.5;
    text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.4);
  }
  .index_contents__main__catch p {
    position: relative;
    color: #ffffff;
    font-size: 1.4rem;
    letter-spacing: 0.075em;
    line-height: 1.8;
    margin-top: 16px;
    padding-top: 25px;
    padding-left: 3px;
    text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.4);
  }
  .index_contents__main__catch p::after {
    content: '';
    position: absolute;
    top: 0;
    left: 2px;
    width: 15px;
    height: 1px;
    background-color: #ffffff;
  }
  .index_contents__main__news {
    position: absolute;
    bottom: -40px;
    left: 9%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 82%;
    height: 80px;
    background-color: #F4F6F9;
    z-index: 10;
    padding: 0 15px 0 30px;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__main__news__desc {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    height: 80px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .index_contents__main__news__desc h3 {
    color: #0054A7;
    font-size: 1.3rem;
    font-weight: 600;
    padding-right: 30px;
    border-right: 1px solid #E1E8F0;
  }
  .index_contents__main__news__desc dl {
    padding-left: 30px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .index_contents__main__news__desc dl dt {
    color: #0054A7;
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: 0.05em;
  }
  .index_contents__main__news__desc dl dd {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__main__news__desc dl dd a, .index_contents__main__news__desc dl dd a:link a:visited {
    position: relative;
    font-size: 1.5rem;
    letter-spacing: 0.1em;
    font-weight: 500;
  }
  .index_contents__main__news__desc dl dd a::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .index_contents__main__news__desc dl dd a:hover {
    color: #0054A7;
  }
  .index_contents__main__news__desc dl dd a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .index_contents__main__news__btn {
    position: relative;
    width: 160px;
  }
  .index_contents__main__news__btn p {
    width: 100%;
  }
  .index_contents__main__news__btn p a, .index_contents__main__news__btn p a:link a:visited {
    position: relative;
    width: 100%;
    height: 50px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #111111;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1.0;
    background: url(../img/arrow01.svg) no-repeat right 15px center;
    background-size: 10px;
    background-color: #ffffff;
    border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
  }
  .index_contents__main__news__btn p a:hover {
    color: #111111;
    background: url(../img/arrow01.svg) no-repeat right 10px center;
    background-size: 10px;
    background-color: #ffffff;
  }
  .index_contents__main__slide {
    position: relative;
    width: 100%;
    height: 100vh;
  }
  .index_contents__main__slide div {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 100vh;
    margin: 0;
  }
  .index_contents__main__slide__contents01 {
    position: relative;
    background: url(../../img/index_img/slide/index_slide01.png) no-repeat center center;
    background-size: cover;
  }
  .index_contents__main__slide__contents02 {
    position: relative;
    background: url(../../img/index_img/slide/index_slide02.png) no-repeat center center;
    background-size: cover;
  }
  .index_contents__main__slide__contents03 {
    position: relative;
    background: url(../../img/index_img/slide/index_slide03.png) no-repeat center center;
    background-size: cover;
  }
  @-webkit-keyframes zoomUp {
    0% {
      -webkit-transform: scale(1);
              transform: scale(1);
    }
    100% {
      -webkit-transform: scale(1.1);
              transform: scale(1.1);
      /* 拡大率 */
    }
  }
  @keyframes zoomUp {
    0% {
      -webkit-transform: scale(1);
              transform: scale(1);
    }
    100% {
      -webkit-transform: scale(1.1);
              transform: scale(1.1);
      /* 拡大率 */
    }
  }
  .index_contents__main .slide-animation {
    -webkit-animation: zoomUp 10s linear 0s normal both;
            animation: zoomUp 10s linear 0s normal both;
  }
  .index_contents__main::after {
    content: '';
    position: absolute;
    right: -1px;
    bottom: -1px;
    width: 100px;
    height: 56px;
    background: url(../img/img_backimg.svg) no-repeat center 100%;
    background-size: 100%;
    z-index: 5;
  }
  .index_contents__detail {
    position: relative;
    width: 100%;
    padding-top: 180px;
    background-color: #ffffff;
  }
  .index_contents__detail__latest {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__latest__inner {
    position: relative;
    width: 82%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 0 3.5%;
    margin: 0 auto;
  }
  .index_contents__detail__latest__inner__list {
    position: relative;
    width: 31%;
  }
  .index_contents__detail__latest__inner__list__img {
    position: relative;
    width: 100%;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__latest__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__latest__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.1rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__latest__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__latest__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__latest__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__latest__inner__list__txt {
    position: relative;
    width: 100%;
    padding-top: 20px;
  }
  .index_contents__detail__latest__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__latest__inner__list:nth-child(4) {
    display: none;
  }
  .index_contents__detail__latest h4.btn_style01 {
    width: 360px;
    margin: 40px auto 0;
  }
  .index_contents__detail__company {
    position: relative;
    width: 100%;
    margin-top: 140px;
  }
  .index_contents__detail__company__desc {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .index_contents__detail__company__desc__img {
    position: relative;
    width: 50%;
    border-radius: 0 8px 8px 0;
    -webkit-border-radius: 0 8px 8px 0;
    -moz-border-radius: 0 8px 8px 0;
    overflow: hidden;
  }
  .index_contents__detail__company__desc__img p {
    position: relative;
    width: 100%;
    border-radius: 0 8px 8px 0;
    -webkit-border-radius: 0 8px 8px 0;
    -moz-border-radius: 0 8px 8px 0;
    overflow: hidden;
  }
  .index_contents__detail__company__desc__img p img {
    width: 100%;
    border-radius: 0 8px 8px 0;
    -webkit-border-radius: 0 8px 8px 0;
    -moz-border-radius: 0 8px 8px 0;
  }
  .index_contents__detail__company__desc__txt {
    position: relative;
    width: 50%;
    padding-left: 45px;
    padding-right: 9%;
  }
  .index_contents__detail__company__desc__txt h3 {
    color: #111111;
    font-size: 3rem;
    font-weight: 800;
    line-height: 1.6;
  }
  .index_contents__detail__company__desc__txt p {
    font-size: 1.5rem;
    margin-top: 30px;
    line-height: 2.0;
  }
  .index_contents__detail__company__desc__txt ul {
    position: relative;
    width: 280px;
    margin-top: 40px;
  }
  .index_contents__detail__company__desc__txt ul li {
    position: relative;
    width: 100%;
    margin-top: 20px;
  }
  .index_contents__detail__company__desc__txt ul li a, .index_contents__detail__company__desc__txt ul li a:link a:visited {
    position: relative;
    color: #111111;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 8px 2px;
    border-bottom: 1px solid #E1E8F0;
    background: url(../img/arrow01.svg) no-repeat right 10px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__company__desc__txt ul li a::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .index_contents__detail__company__desc__txt ul li a:hover {
    color: #0054A7;
    background: url(../img/arrow01.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__company__desc__txt ul li a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .index_contents__detail__company__desc__txt ul li img {
    width: 12px;
    margin-left: 6px;
  }
  .index_contents__detail__company__desc__txt ul li::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 30px;
    height: 1px;
    background-color: #0054A7;
  }
  .index_contents__detail__company__message {
    position: relative;
    max-width: 1000px;
    height: 280px;
    margin: 100px auto 0;
  }
  .index_contents__detail__company__message a, .index_contents__detail__company__message a:link a:visited {
    position: relative;
    width: 100%;
    height: 280px;
    color: #ffffff;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    background-color: #0054A7;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__txt {
    position: relative;
    width: 50%;
    padding: 0 35px 0 40px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt h2, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__txt h2 {
    font-size: 3rem;
    font-weight: 700;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt h6, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__txt h6 {
    font-size: 1.3rem;
    font-weight: 500;
    margin-bottom: 2px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt p, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__txt p {
    font-size: 1.5rem;
    line-height: 2.0;
    margin-top: 20px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__img {
    position: relative;
    width: 50%;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img p, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__img p {
    width: 100%;
    border-radius: 0 8px 8px 0;
    -webkit-border-radius: 0 8px 8px 0;
    -moz-border-radius: 0 8px 8px 0;
    overflow: hidden;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img p img, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__img p img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__company__message a:hover {
    background-color: #124287;
  }
  .index_contents__detail__company__message a:hover .index_contents__detail__company__message__img img {
    -webkit-transform: scale(1.07);
    transform: scale(1.07);
  }
  .index_contents__detail__company__business {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__company__business__inner {
    position: relative;
    width: 94%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 0 1.25%;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin: 0 auto;
  }
  .index_contents__detail__company__business__inner__list {
    position: relative;
    width: 32.5%;
  }
  .index_contents__detail__company__business__inner__list a {
    position: relative;
    width: 100%;
    display: block;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 10;
    padding: 40px 40px;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.7)));
    background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.7));
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt h3 {
    color: #ffffff;
    font-size: 2.4rem;
    font-weight: 700;
    text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt h6 {
    color: #ffffff;
    font-size: 1.3rem;
    font-weight: 500;
    margin-bottom: 2px;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt p {
    text-align: justify;
    color: #ffffff;
    font-size: 1.4rem;
    line-height: 2.0;
    margin-top: 20px;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img p {
    width: 100%;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img p img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__company__business__inner__list::after {
    content: '';
    position: absolute;
    bottom: -1px;
    right: -1px;
    width: 60px;
    height: 34px;
    background: url(../img/img_backimg.svg) no-repeat 0 0;
    background-size: 100%;
    z-index: 15;
  }
  .index_contents__detail__company__business__inner__list > a:hover .index_contents__detail__company__business__inner__list__img img {
    -webkit-transform: scale(1.07);
    transform: scale(1.07);
  }
  .index_contents__detail__works {
    position: relative;
    width: 100%;
    margin-top: 160px;
  }
  .index_contents__detail__works__inner {
    position: relative;
    width: 82%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0 3.5%;
    margin: 0 auto;
  }
  .index_contents__detail__works__inner__list {
    position: relative;
    width: 31%;
    border: 1px solid #E1E8F0;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__works__inner__list a {
    position: relative;
    width: 100%;
    display: block;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img {
    position: relative;
    width: 100%;
    overflow: hidden;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.1rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__txt {
    position: relative;
    width: 100%;
    height: 72px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0 20px;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__inner__list .arrow {
    overflow: hidden;
    position: absolute;
    top: 50%;
    right: 15px;
    width: 34px;
    height: 34px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    z-index: 5;
  }
  .index_contents__detail__works__inner__list .arrow:before,
  .index_contents__detail__works__inner__list .arrow:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 34px;
    height: 34px;
    background: url(../img/arrow02.svg) no-repeat center center;
    background-size: 10px;
    -webkit-animation-fill-mode: forwards;
            animation-fill-mode: forwards;
    -webkit-animation-duration: 0.3s;
            animation-duration: 0.3s;
  }
  .index_contents__detail__works__inner__list .arrow:after {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  .index_contents__detail__works__inner__list a:hover .arrow:before {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .index_contents__detail__works__inner__list a:hover .arrow:after {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
  .index_contents__detail__works__interview {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__works__interview__inner {
    position: relative;
    width: 82%;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
    -ms-grid-rows: (1fr)[3];
        grid-template-rows: repeat(3, 1fr);
    gap: 30px;
    margin: 0 auto;
  }
  .index_contents__detail__works__interview__inner__list:first-child {
    position: relative;
    grid-row: span 3 / span 3;
    padding-right: 15px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 100%;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.1rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    width: 100%;
    padding-top: 25px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.5rem;
    font-weight: 500;
    padding-bottom: 12px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 2.4rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.7;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) {
    position: relative;
    -ms-grid-column: 2;
        grid-column-start: 2;
    -ms-grid-row: 1;
        grid-row-start: 1;
    padding-bottom: 30px;
    border-bottom: 1px solid #E1E8F0;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 200px;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.1rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.4rem;
    font-weight: 500;
    padding-bottom: 10px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) {
    position: relative;
    -ms-grid-column: 2;
        grid-column-start: 2;
    -ms-grid-row: 2;
        grid-row-start: 2;
    padding-bottom: 30px;
    border-bottom: 1px solid #E1E8F0;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 200px;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.1rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.4rem;
    font-weight: 500;
    padding-bottom: 10px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) {
    position: relative;
    -ms-grid-column: 2;
        grid-column-start: 2;
    -ms-grid-row: 3;
        grid-row-start: 3;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 200px;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.1rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.4rem;
    font-weight: 500;
    padding-bottom: 10px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__dialogue {
    position: relative;
    max-width: 1000px;
    height: 280px;
    margin: 100px auto 0;
  }
  .index_contents__detail__works__dialogue a, .index_contents__detail__works__dialogue a:link a:visited {
    position: relative;
    width: 100%;
    height: 280px;
    color: #ffffff;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    background-color: #30A5E2;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__txt {
    position: relative;
    width: 50%;
    padding: 0 35px 0 40px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt h2, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__txt h2 {
    font-size: 3rem;
    font-weight: 700;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt h6, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__txt h6 {
    font-size: 1.3rem;
    font-weight: 500;
    margin-bottom: 2px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt p, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__txt p {
    font-size: 1.5rem;
    line-height: 2.0;
    margin-top: 20px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__img {
    position: relative;
    width: 50%;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img p, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__img p {
    width: 100%;
    border-radius: 0 8px 8px 0;
    -webkit-border-radius: 0 8px 8px 0;
    -moz-border-radius: 0 8px 8px 0;
    overflow: hidden;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img p img, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__img p img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__works__dialogue a:hover {
    background-color: #4d96d8;
  }
  .index_contents__detail__works__dialogue a:hover .index_contents__detail__works__dialogue__img img {
    -webkit-transform: scale(1.07);
    transform: scale(1.07);
  }
  .index_contents__detail__recruit {
    position: relative;
    width: 100%;
    background-color: #F4F6F9;
    margin-top: 160px;
    padding: 140px 0 160px;
  }
  .index_contents__detail__recruit__desc {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .index_contents__detail__recruit__desc__img {
    position: relative;
    width: 50%;
    border-radius: 8px 0 0 8px;
    -webkit-border-radius: 8px 0 0 8px;
    -moz-border-radius: 8px 0 0 8px;
    overflow: hidden;
  }
  .index_contents__detail__recruit__desc__img p {
    width: 100%;
  }
  .index_contents__detail__recruit__desc__img p img {
    width: 100%;
    border-radius: 8px 0 0 8px;
    -webkit-border-radius: 8px 0 0 8px;
    -moz-border-radius: 8px 0 0 8px;
  }
  .index_contents__detail__recruit__desc__txt {
    position: relative;
    width: 50%;
    padding-right: 45px;
    padding-left: 9%;
  }
  .index_contents__detail__recruit__desc__txt h3 {
    color: #111111;
    font-size: 3rem;
    font-weight: 800;
    line-height: 1.6;
  }
  .index_contents__detail__recruit__desc__txt p {
    font-size: 1.5rem;
    margin-top: 30px;
    line-height: 2.0;
  }
  .index_contents__detail__recruit__desc__txt ul {
    position: relative;
    width: 280px;
    margin-top: 40px;
  }
  .index_contents__detail__recruit__desc__txt ul li {
    position: relative;
    width: 100%;
    margin-top: 20px;
  }
  .index_contents__detail__recruit__desc__txt ul li a, .index_contents__detail__recruit__desc__txt ul li a:link a:visited {
    position: relative;
    color: #111111;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 8px 2px;
    border-bottom: 1px solid #E1E8F0;
    background: url(../img/arrow01.svg) no-repeat right 10px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__recruit__desc__txt ul li a::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .index_contents__detail__recruit__desc__txt ul li a:hover {
    color: #0054A7;
    background: url(../img/arrow01.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__recruit__desc__txt ul li a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .index_contents__detail__recruit__desc__txt ul li img {
    width: 12px;
    margin-left: 6px;
  }
  .index_contents__detail__recruit__desc__txt ul li::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 30px;
    height: 1px;
    background-color: #0054A7;
  }
  .index_contents__detail__recruit__inner {
    position: relative;
    width: 82%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0 3.5%;
    margin: 80px auto 0;
  }
  .index_contents__detail__recruit__inner__list {
    position: relative;
    width: 31%;
    border: 1px solid #E1E8F0;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
    background-color: #ffffff;
  }
  .index_contents__detail__recruit__inner__list a {
    position: relative;
    width: 100%;
    display: block;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img {
    position: relative;
    width: 100%;
    overflow: hidden;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.1rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__txt {
    position: relative;
    width: 100%;
    height: 72px;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0 50px 0 20px;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__recruit__inner__list .arrow {
    overflow: hidden;
    position: absolute;
    top: 50%;
    right: 15px;
    width: 34px;
    height: 34px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    z-index: 5;
  }
  .index_contents__detail__recruit__inner__list .arrow:before,
  .index_contents__detail__recruit__inner__list .arrow:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 34px;
    height: 34px;
    background: url(../img/arrow02.svg) no-repeat center center;
    background-size: 10px;
    -webkit-animation-fill-mode: forwards;
            animation-fill-mode: forwards;
    -webkit-animation-duration: 0.3s;
            animation-duration: 0.3s;
  }
  .index_contents__detail__recruit__inner__list .arrow:after {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  .index_contents__detail__recruit__inner__list a:hover .arrow:before {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .index_contents__detail__recruit__inner__list a:hover .arrow:after {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
  .index_contents__detail__recruit__wellfare {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__recruit__wellfare__inner {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 0 2%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li {
    position: relative;
    width: 15%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li a {
    position: relative;
    display: block;
    width: 100%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li a .index_contents__detail__recruit__wellfare__inner__img {
    width: 100%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li a .index_contents__detail__recruit__wellfare__inner__img img {
    position: relative;
    width: 100%;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li a h3 {
    text-align: center;
    font-size: 1.6rem;
    font-weight: 600;
    padding-top: 20px;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider .slick-slide {
    margin: 0 22px;
    /*スライド左右の余白調整*/
  }
  .index_contents__detail__recruit__wellfare h4.btn_style01 {
    width: 360px;
    margin: 40px auto 0;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .index_contents {
    position: relative;
    width: 100%;
  }
  .index_contents__main {
    position: relative;
    width: 100%;
    height: 100vh;
    background-color: #E1E8F0;
  }
  .index_contents__main__catch {
    position: absolute;
    top: 50%;
    left: 7%;
    width: 74%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    z-index: 5;
  }
  .index_contents__main__catch h2 {
    color: #ffffff;
    font-size: 5.2rem;
    font-weight: 900;
    line-height: 1.5;
    text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.4);
  }
  .index_contents__main__catch p {
    position: relative;
    color: #ffffff;
    font-size: 1.3rem;
    font-weight: 400;
    letter-spacing: 0.075em;
    line-height: 1.7;
    margin-top: 25px;
    padding-top: 25px;
    padding-left: 2px;
    text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.4);
  }
  .index_contents__main__catch p::after {
    content: '';
    position: absolute;
    top: 0;
    left: 2px;
    width: 15px;
    height: 1px;
    background-color: #ffffff;
  }
  .index_contents__main__news {
    position: absolute;
    bottom: -45px;
    left: 7%;
    width: 93%;
    background-color: #F4F6F9;
    z-index: 10;
    padding: 25px 25px;
    border-radius: 6px 0 0 6px;
    -webkit-border-radius: 6px 0 0 6px;
    -moz-border-radius: 6px 0 0 6px;
  }
  .index_contents__main__news__desc {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .index_contents__main__news__desc h3 {
    color: #0054A7;
    font-size: 0.9rem;
    font-weight: 600;
    padding-right: 25px;
  }
  .index_contents__main__news__desc dl {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  .index_contents__main__news__desc dl dt {
    width: 100%;
    color: #0054A7;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    margin-bottom: 3px;
  }
  .index_contents__main__news__desc dl dd {
    position: relative;
    width: 100%;
  }
  .index_contents__main__news__desc dl dd a {
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    font-weight: 500;
  }
  .index_contents__main__news__btn {
    display: none;
  }
  .index_contents__main__slide {
    position: relative;
    width: 100%;
    height: 100vh;
    background-color: #F4F6F9;
  }
  .index_contents__main__slide div {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 100vh;
    margin: 0;
  }
  .index_contents__main__slide__contents01 {
    position: relative;
    background: url(../../img/index_img/slide/sp_index_slide01.png) no-repeat center center;
    background-size: cover;
  }
  .index_contents__main__slide__contents02 {
    position: relative;
    background: url(../../img/index_img/slide/sp_index_slide02.png) no-repeat center center;
    background-size: cover;
  }
  .index_contents__main__slide__contents03 {
    position: relative;
    background: url(../../img/index_img/slide/sp_index_slide03.png) no-repeat center center;
    background-size: cover;
  }
  @-webkit-keyframes zoomUp {
    0% {
      -webkit-transform: scale(1);
              transform: scale(1);
    }
    100% {
      -webkit-transform: scale(1.1);
              transform: scale(1.1);
      /* 拡大率 */
    }
  }
  @keyframes zoomUp {
    0% {
      -webkit-transform: scale(1);
              transform: scale(1);
    }
    100% {
      -webkit-transform: scale(1.1);
              transform: scale(1.1);
      /* 拡大率 */
    }
  }
  .index_contents__main .slide-animation {
    -webkit-animation: zoomUp 10s linear 0s normal both;
            animation: zoomUp 10s linear 0s normal both;
  }
  .index_contents__main::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: -1px;
    width: 100%;
    height: 100px;
    background: url(../../img/index_img/sp_index_main_bottomimg.svg) no-repeat center 100%;
    background-size: 100%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    z-index: 5;
  }
  .index_contents__detail {
    position: relative;
    width: 100%;
    padding-top: 160px;
    background-color: #ffffff;
  }
  .index_contents__detail__latest {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__latest__inner {
    position: relative;
    width: 86%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 0 5%;
    margin: 0 auto;
  }
  .index_contents__detail__latest__inner__list {
    position: relative;
    width: 47.5%;
  }
  .index_contents__detail__latest__inner__list__img {
    position: relative;
    width: 100%;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__latest__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__latest__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.2rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__latest__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__latest__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__latest__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__latest__inner__list__txt {
    position: relative;
    width: 100%;
    padding-top: 15px;
  }
  .index_contents__detail__latest__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__latest__inner__list:nth-child(n+3) {
    margin-top: 30px;
  }
  .index_contents__detail__latest h4.btn_style01 {
    width: 320px;
    margin: 40px auto 0;
  }
  .index_contents__detail__company {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__company__desc {
    position: relative;
    width: 94%;
    margin: 0 auto;
  }
  .index_contents__detail__company__desc__img {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__company__desc__img p {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__company__desc__img p img {
    width: 100%;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__company__desc__txt {
    position: relative;
    width: 86%;
    background-color: #ffffff;
    z-index: 3;
    margin: -60px auto 0;
    padding: 40px 40px 0;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__company__desc__txt h3 {
    color: #111111;
    font-size: 2.4rem;
    font-weight: 800;
    line-height: 1.6;
  }
  .index_contents__detail__company__desc__txt p {
    font-size: 1.5rem;
    margin-top: 25px;
    line-height: 2.0;
  }
  .index_contents__detail__company__desc__txt ul {
    position: relative;
    width: 280px;
    margin-top: 30px;
  }
  .index_contents__detail__company__desc__txt ul li {
    position: relative;
    width: 100%;
    margin-top: 15px;
  }
  .index_contents__detail__company__desc__txt ul li a, .index_contents__detail__company__desc__txt ul li a:link a:visited {
    position: relative;
    color: #111111;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 8px 2px;
    border-bottom: 1px solid #E1E8F0;
    background: url(../img/arrow01.svg) no-repeat right 10px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__company__desc__txt ul li a::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .index_contents__detail__company__desc__txt ul li a:hover {
    color: #0054A7;
    background: url(../img/arrow01.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__company__desc__txt ul li a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .index_contents__detail__company__desc__txt ul li img {
    width: 12px;
    margin-left: 6px;
  }
  .index_contents__detail__company__desc__txt ul li::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 30px;
    height: 1px;
    background-color: #0054A7;
  }
  .index_contents__detail__company__message {
    position: relative;
    width: 94%;
    margin: 100px auto 0;
  }
  .index_contents__detail__company__message a, .index_contents__detail__company__message a:link a:visited {
    position: relative;
    width: 100%;
    color: #ffffff;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    background-color: #0054A7;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__txt {
    position: relative;
    width: 50%;
    padding: 0 30px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt h2, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__txt h2 {
    font-size: 2.4rem;
    font-weight: 700;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt h6, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__txt h6 {
    font-size: 1.2rem;
    font-weight: 500;
    margin-bottom: 2px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt p, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__txt p {
    font-size: 1.3rem;
    line-height: 2.0;
    margin-top: 15px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__img {
    position: relative;
    width: 50%;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img p, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__img p {
    width: 100%;
    border-radius: 0 8px 8px 0;
    -webkit-border-radius: 0 8px 8px 0;
    -moz-border-radius: 0 8px 8px 0;
    overflow: hidden;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img p img, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__img p img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img p img:hover, .index_contents__detail__company__message a:link a:visited .index_contents__detail__company__message__img p img:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__company__message a:hover {
    background-color: #124287;
  }
  .index_contents__detail__company__business {
    position: relative;
    width: 100%;
    margin-top: 80px;
  }
  .index_contents__detail__company__business__inner {
    position: relative;
    width: 94%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin: 0 auto;
  }
  .index_contents__detail__company__business__inner__list {
    position: relative;
    width: 49%;
  }
  .index_contents__detail__company__business__inner__list a {
    position: relative;
    width: 100%;
    display: block;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 10;
    padding: 30px 30px;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.7)));
    background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.7));
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt h3 {
    color: #ffffff;
    font-size: 2.2rem;
    font-weight: 700;
    text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt h6 {
    color: #ffffff;
    font-size: 1.2rem;
    font-weight: 500;
    margin-bottom: 2px;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt p {
    text-align: justify;
    color: #ffffff;
    font-size: 1.4rem;
    line-height: 1.8;
    margin-top: 15px;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img p {
    width: 100%;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img p img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__company__business__inner__list::after {
    content: '';
    position: absolute;
    bottom: -1px;
    right: -1px;
    width: 60px;
    height: 34px;
    background: url(../img/img_backimg.svg) no-repeat 0 0;
    background-size: 100%;
    z-index: 15;
  }
  .index_contents__detail__company__business__inner__list:nth-child(3) {
    margin-top: 15px;
  }
  .index_contents__detail__works {
    position: relative;
    width: 100%;
    margin-top: 140px;
  }
  .index_contents__detail__works__inner {
    position: relative;
    width: 86%;
    margin: 0 auto;
  }
  .index_contents__detail__works__inner__list {
    position: relative;
    width: 100%;
    border: 1px solid #E1E8F0;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__works__inner__list a {
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 20px 20px;
    background-color: #ffffff;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img {
    position: relative;
    width: 30%;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img img {
    width: 100%;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__works__inner__list a .index_contents__detail__works__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.6;
  }
  .index_contents__detail__works__inner__list .arrow {
    overflow: hidden;
    position: absolute;
    top: 50%;
    right: 0;
    width: 34px;
    height: 34px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
  }
  .index_contents__detail__works__inner__list .arrow:before,
  .index_contents__detail__works__inner__list .arrow:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 34px;
    height: 34px;
    background: url(../img/arrow02.svg) no-repeat center center;
    background-size: 10px;
    -webkit-animation-fill-mode: forwards;
            animation-fill-mode: forwards;
    -webkit-animation-duration: 0.3s;
            animation-duration: 0.3s;
  }
  .index_contents__detail__works__inner__list .arrow:after {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  .index_contents__detail__works__inner__list a:hover .arrow:before {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .index_contents__detail__works__inner__list a:hover .arrow:after {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
  .index_contents__detail__works__inner__list:nth-child(n+2) {
    margin-top: 15px;
  }
  .index_contents__detail__works__interview {
    position: relative;
    width: 100%;
    margin-top: 80px;
  }
  .index_contents__detail__works__interview__inner {
    position: relative;
    width: 86%;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
    -ms-grid-rows: (1fr)[3];
        grid-template-rows: repeat(3, 1fr);
    gap: 0 30px;
    margin: 0 auto;
  }
  .index_contents__detail__works__interview__inner__list:first-child {
    position: relative;
    grid-row: span 3 / span 3;
    padding-right: 10px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 100%;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img .caption {
    text-align: center;
    position: absolute;
    width: 100%;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    font-size: 1.1rem;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img:hover .mask {
    opacity: 1;
    /* マスクを表示する */
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    width: 100%;
    padding-top: 20px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.5rem;
    font-weight: 500;
    padding-bottom: 8px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.7;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) {
    position: relative;
    width: 100%;
    -ms-grid-column: 2;
        grid-column-start: 2;
    -ms-grid-row: 1;
        grid-row-start: 1;
    padding-bottom: 20px;
    margin-bottom: 20px;
    border-bottom: 1px solid #E1E8F0;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 40%;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.3rem;
    font-weight: 500;
    padding-bottom: 8px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(2) a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) {
    position: relative;
    width: 100%;
    -ms-grid-column: 2;
        grid-column-start: 2;
    -ms-grid-row: 2;
        grid-row-start: 2;
    padding-bottom: 20px;
    margin-bottom: 20px;
    border-bottom: 1px solid #E1E8F0;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 40%;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.3rem;
    font-weight: 500;
    padding-bottom: 8px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(3) a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) {
    position: relative;
    width: 100%;
    -ms-grid-column: 2;
        grid-column-start: 2;
    -ms-grid-row: 3;
        grid-row-start: 3;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 40%;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.3rem;
    font-weight: 500;
    padding-bottom: 8px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(4) a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__dialogue {
    position: relative;
    width: 94%;
    margin: 100px auto 0;
  }
  .index_contents__detail__works__dialogue a, .index_contents__detail__works__dialogue a:link a:visited {
    position: relative;
    width: 100%;
    color: #ffffff;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    background-color: #30A5E2;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__txt {
    position: relative;
    width: 50%;
    padding: 0 30px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt h2, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__txt h2 {
    font-size: 2.4rem;
    font-weight: 700;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt h6, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__txt h6 {
    font-size: 1.2rem;
    font-weight: 500;
    margin-bottom: 2px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt p, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__txt p {
    font-size: 1.3rem;
    line-height: 2.0;
    margin-top: 15px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__img {
    position: relative;
    width: 50%;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img p, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__img p {
    width: 100%;
    border-radius: 0 8px 8px 0;
    -webkit-border-radius: 0 8px 8px 0;
    -moz-border-radius: 0 8px 8px 0;
    overflow: hidden;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img p img, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__img p img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img p img:hover, .index_contents__detail__works__dialogue a:link a:visited .index_contents__detail__works__dialogue__img p img:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .index_contents__detail__works__dialogue a:hover {
    background-color: #4d96d8;
  }
  .index_contents__detail__recruit {
    position: relative;
    width: 100%;
    background-color: #F4F6F9;
    margin-top: 140px;
    padding: 120px 0 140px;
  }
  .index_contents__detail__recruit__desc {
    position: relative;
    width: 94%;
    margin: 0 auto;
  }
  .index_contents__detail__recruit__desc__img {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__recruit__desc__img p {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__recruit__desc__img p img {
    width: 100%;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__recruit__desc__txt {
    position: relative;
    width: 86%;
    background-color: #F4F6F9;
    z-index: 3;
    margin: -60px auto 0;
    padding: 40px 40px 0;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__recruit__desc__txt h3 {
    color: #111111;
    font-size: 2.4rem;
    font-weight: 800;
    line-height: 1.6;
  }
  .index_contents__detail__recruit__desc__txt p {
    font-size: 1.5rem;
    margin-top: 25px;
    line-height: 2.0;
  }
  .index_contents__detail__recruit__desc__txt ul {
    position: relative;
    width: 280px;
    margin-top: 30px;
  }
  .index_contents__detail__recruit__desc__txt ul li {
    position: relative;
    width: 100%;
    margin-top: 15px;
  }
  .index_contents__detail__recruit__desc__txt ul li a, .index_contents__detail__recruit__desc__txt ul li a:link a:visited {
    position: relative;
    color: #111111;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 8px 2px;
    border-bottom: 1px solid #E1E8F0;
    background: url(../img/arrow01.svg) no-repeat right 10px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__recruit__desc__txt ul li a::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #0054A7;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .index_contents__detail__recruit__desc__txt ul li a:hover {
    color: #0054A7;
    background: url(../img/arrow01.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__recruit__desc__txt ul li a:hover::after {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .index_contents__detail__recruit__desc__txt ul li img {
    width: 12px;
    margin-left: 6px;
  }
  .index_contents__detail__recruit__desc__txt ul li::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 30px;
    height: 1px;
    background-color: #0054A7;
  }
  .index_contents__detail__recruit__inner {
    position: relative;
    width: 86%;
    margin: 80px auto 0;
  }
  .index_contents__detail__recruit__inner__list {
    position: relative;
    width: 100%;
    border: 1px solid #E1E8F0;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
    overflow: hidden;
  }
  .index_contents__detail__recruit__inner__list a {
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 20px 20px;
    background-color: #ffffff;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img {
    position: relative;
    width: 30%;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img img {
    width: 100%;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__recruit__inner__list a .index_contents__detail__recruit__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.6;
  }
  .index_contents__detail__recruit__inner__list .arrow {
    overflow: hidden;
    position: absolute;
    top: 50%;
    right: 0;
    width: 34px;
    height: 34px;
    background-color: #0054A7;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
  }
  .index_contents__detail__recruit__inner__list .arrow:before,
  .index_contents__detail__recruit__inner__list .arrow:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 34px;
    height: 34px;
    background: url(../img/arrow02.svg) no-repeat center center;
    background-size: 10px;
    -webkit-animation-fill-mode: forwards;
            animation-fill-mode: forwards;
    -webkit-animation-duration: 0.3s;
            animation-duration: 0.3s;
  }
  .index_contents__detail__recruit__inner__list .arrow:after {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  .index_contents__detail__recruit__inner__list a:hover .arrow:before {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .index_contents__detail__recruit__inner__list a:hover .arrow:after {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    /* 修正: hover時のアニメーションを指定 */
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
  .index_contents__detail__recruit__inner__list:nth-child(n+2) {
    margin-top: 15px;
  }
  .index_contents__detail__recruit__wellfare {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__recruit__wellfare__inner {
    position: relative;
    width: 86%;
    margin: 0 auto;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 0 5%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li {
    position: relative;
    width: 30%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li a {
    position: relative;
    display: block;
    width: 100%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li a .index_contents__detail__recruit__wellfare__inner__img {
    width: 100%;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li a .index_contents__detail__recruit__wellfare__inner__img img {
    position: relative;
    width: 100%;
    border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li a h3 {
    text-align: center;
    font-size: 1.5rem;
    font-weight: 600;
    padding-top: 15px;
  }
  .index_contents__detail__recruit__wellfare__inner ul.slider li:nth-child(n+4) {
    margin-top: 30px;
  }
  .index_contents__detail__recruit__wellfare h4.btn_style01 {
    width: 320px;
    margin: 40px auto 0;
  }
}

@media screen and (max-width: 767px) {
  .index_contents {
    position: relative;
  }
  .index_contents__main {
    position: relative;
    width: 100%;
    height: 100vh;
    background-color: #E1E8F0;
  }
  .index_contents__main__catch {
    position: absolute;
    top: 50%;
    left: 7%;
    width: 74%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    z-index: 5;
  }
  .index_contents__main__catch h2 {
    color: #ffffff;
    font-size: 3.2rem;
    font-weight: 900;
    line-height: 1.5;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
  }
  .index_contents__main__catch p {
    position: relative;
    color: #ffffff;
    font-size: 1.2rem;
    font-weight: 400;
    letter-spacing: 0.075em;
    line-height: 1.7;
    margin-top: 20px;
    padding-top: 20px;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
  }
  .index_contents__main__catch p::after {
    content: '';
    position: absolute;
    top: 0;
    left: 2px;
    width: 10px;
    height: 1px;
    background-color: #ffffff;
  }
  .index_contents__main__news {
    position: absolute;
    bottom: -44px;
    left: 7%;
    width: 93%;
    background-color: #F4F6F9;
    z-index: 10;
    padding: 16px 25px 16px 20px;
    border-radius: 4px 0 0 4px;
    -webkit-border-radius: 4px 0 0 4px;
    -moz-border-radius: 4px 0 0 4px;
  }
  .index_contents__main__news__desc {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .index_contents__main__news__desc h3 {
    color: #0054A7;
    font-size: 0.9rem;
    font-weight: 600;
    padding-right: 20px;
  }
  .index_contents__main__news__desc dl {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  .index_contents__main__news__desc dl dt {
    width: 100%;
    color: #0054A7;
    font-size: 0.9rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.2;
    margin-bottom: 3px;
  }
  .index_contents__main__news__desc dl dd {
    position: relative;
    width: 100%;
  }
  .index_contents__main__news__desc dl dd a {
    font-size: 1.2rem;
    letter-spacing: 0.1em;
    font-weight: 500;
  }
  .index_contents__main__news__btn {
    display: none;
  }
  .index_contents__main__slide {
    position: relative;
    width: 100%;
    height: 100vh;
    background-color: #F4F6F9;
  }
  .index_contents__main__slide div {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 100vh;
    margin: 0;
  }
  .index_contents__main__slide__contents01 {
    position: relative;
    background: url(../../img/index_img/slide/sp_index_slide01.png) no-repeat center center;
    background-size: cover;
  }
  .index_contents__main__slide__contents02 {
    position: relative;
    background: url(../../img/index_img/slide/sp_index_slide02.png) no-repeat center center;
    background-size: cover;
  }
  .index_contents__main__slide__contents03 {
    position: relative;
    background: url(../../img/index_img/slide/sp_index_slide03.png) no-repeat center center;
    background-size: cover;
  }
  @-webkit-keyframes zoomUp {
    0% {
      -webkit-transform: scale(1);
              transform: scale(1);
    }
    100% {
      -webkit-transform: scale(1.15);
              transform: scale(1.15);
      /* 拡大率 */
    }
  }
  @keyframes zoomUp {
    0% {
      -webkit-transform: scale(1);
              transform: scale(1);
    }
    100% {
      -webkit-transform: scale(1.15);
              transform: scale(1.15);
      /* 拡大率 */
    }
  }
  .index_contents__main .slide-animation {
    -webkit-animation: zoomUp 10s linear 0s normal both;
            animation: zoomUp 10s linear 0s normal both;
  }
  .index_contents__detail {
    position: relative;
    width: 100%;
    padding-top: 140px;
    background-color: #ffffff;
  }
  .index_contents__detail__latest {
    position: relative;
    width: 86%;
    margin: 0 auto;
  }
  .index_contents__detail__latest__inner {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__latest__inner__list {
    position: relative;
    width: 100%;
    margin-bottom: 20px;
  }
  .index_contents__detail__latest__inner__list a {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .index_contents__detail__latest__inner__list__img {
    position: relative;
    width: 130px;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    overflow: hidden;
  }
  .index_contents__detail__latest__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__latest__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__latest__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__latest__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 15px;
  }
  .index_contents__detail__latest__inner__list__txt h3 {
    text-align: justify;
    font-size: 1.3rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__latest__inner__list:nth-child(4) {
    display: none;
  }
  .index_contents__detail__latest h4.btn_style01 {
    width: 100%;
    margin: 30px auto 0;
  }
  .index_contents__detail__company {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__company__desc {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__company__desc__img {
    position: relative;
    width: 93%;
  }
  .index_contents__detail__company__desc__img p {
    width: 100%;
  }
  .index_contents__detail__company__desc__img p img {
    width: 100%;
    border-radius: 0 6px 6px 0;
    -webkit-border-radius: 0 6px 6px 0;
    -moz-border-radius: 0 6px 6px 0;
  }
  .index_contents__detail__company__desc__txt {
    position: relative;
    width: 86%;
    margin: 0 auto;
    padding-top: 25px;
  }
  .index_contents__detail__company__desc__txt h3 {
    color: #111111;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.7;
  }
  .index_contents__detail__company__desc__txt p {
    text-align: justify;
    font-size: 1.45rem;
    margin-top: 20px;
    line-height: 2.0;
  }
  .index_contents__detail__company__desc__txt ul {
    position: relative;
    width: 220px;
    margin-top: 30px;
  }
  .index_contents__detail__company__desc__txt ul li {
    position: relative;
    width: 100%;
    margin-top: 20px;
  }
  .index_contents__detail__company__desc__txt ul li a {
    position: relative;
    color: #111111;
    font-size: 1.55rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 8px 2px;
    border-bottom: 1px solid #E1E8F0;
    background: url(../img/arrow01.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__company__desc__txt ul li img {
    width: 12px;
    margin-left: 6px;
  }
  .index_contents__detail__company__message {
    position: relative;
    width: 86%;
    margin: 60px auto 0;
  }
  .index_contents__detail__company__message a {
    position: relative;
    width: 100%;
    color: #ffffff;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background-color: #0054A7;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt {
    position: relative;
    width: 100%;
    padding: 20px 20px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt h2 {
    font-size: 2rem;
    font-weight: 700;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt h6 {
    font-size: 1.1rem;
    font-weight: 500;
    margin-bottom: 2px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__txt p {
    font-size: 1.3rem;
    line-height: 2.0;
    margin-top: 10px;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img p {
    width: 100%;
  }
  .index_contents__detail__company__message a .index_contents__detail__company__message__img p img {
    width: 100%;
    border-radius: 6px 6px 0 0;
    -webkit-border-radius: 6px 6px 0 0;
    -moz-border-radius: 6px 6px 0 0;
  }
  .index_contents__detail__company__business {
    position: relative;
    width: 100%;
    margin-top: 80px;
  }
  .index_contents__detail__company__business__inner {
    position: relative;
    width: 96%;
    margin: 0 auto;
  }
  .index_contents__detail__company__business__inner__list {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__company__business__inner__list a {
    position: relative;
    width: 100%;
    display: block;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    overflow: hidden;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 10;
    padding: 25px 25px;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.7)));
    background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.7));
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt h3 {
    color: #ffffff;
    font-size: 2rem;
    font-weight: 700;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt h6 {
    color: #ffffff;
    font-size: 1.1rem;
    font-weight: 500;
    margin-bottom: 2px;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__txt p {
    color: #ffffff;
    text-align: justify;
    font-size: 1.2rem;
    line-height: 1.9;
    margin-top: 10px;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.4);
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img {
    position: relative;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img p {
    width: 100%;
  }
  .index_contents__detail__company__business__inner__list a .index_contents__detail__company__business__inner__list__img p img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
  }
  .index_contents__detail__company__business__inner__list::after {
    content: '';
    position: absolute;
    bottom: -1px;
    right: -1px;
    width: 30px;
    height: 17px;
    background: url(../img/img_backimg.svg) no-repeat 0 0;
    background-size: 100%;
    z-index: 15;
  }
  .index_contents__detail__company__business__inner__list:nth-child(n+2) {
    margin-top: 12px;
  }
  .index_contents__detail__works {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__works__inner {
    position: relative;
    width: 86%;
    margin: 0 auto;
  }
  .index_contents__detail__works__inner__list {
    position: relative;
    width: 100%;
    border: 1px solid #E1E8F0;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__works__inner__list a {
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 15px 15px;
    background-color: #ffffff;
  }
  .index_contents__detail__works__inner__list__img {
    position: relative;
    width: 90px;
  }
  .index_contents__detail__works__inner__list__img img {
    width: 100%;
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
  }
  .index_contents__detail__works__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__works__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__works__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 15px;
  }
  .index_contents__detail__works__inner__list__txt h3 {
    font-size: 1.55rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__inner__list:nth-child(n+2) {
    margin-top: 12px;
  }
  .index_contents__detail__works__interview {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__works__interview__inner {
    position: relative;
    width: 86%;
    margin: 0 auto;
  }
  .index_contents__detail__works__interview__inner__list:first-child {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E1E8F0;
    padding-bottom: 30px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 100%;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    overflow: hidden;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    width: 100%;
    padding-top: 15px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.3rem;
    font-weight: 500;
    padding-bottom: 8px;
  }
  .index_contents__detail__works__interview__inner__list:first-child a .index_contents__detail__works__interview__inner__list__txt h3 {
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.7;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E1E8F0;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) a {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 20px 0;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) a .index_contents__detail__works__interview__inner__list__img {
    position: relative;
    width: 130px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) a .index_contents__detail__works__interview__inner__list__img img {
    width: 100%;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) a .index_contents__detail__works__interview__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) a .index_contents__detail__works__interview__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) a .index_contents__detail__works__interview__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 20px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) a .index_contents__detail__works__interview__inner__list__txt p {
    color: #545454;
    font-size: 1.1rem;
    font-weight: 500;
    padding-bottom: 6px;
  }
  .index_contents__detail__works__interview__inner__list:nth-child(n+2) a .index_contents__detail__works__interview__inner__list__txt h3 {
    text-align: justify;
    font-size: 1.45rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__works__dialogue {
    position: relative;
    width: 86%;
    margin: 60px auto 0;
  }
  .index_contents__detail__works__dialogue a {
    position: relative;
    width: 100%;
    color: #ffffff;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background-color: #30A5E2;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt {
    position: relative;
    width: 100%;
    padding: 20px 20px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt h2 {
    font-size: 2rem;
    font-weight: 700;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt h6 {
    font-size: 1.1rem;
    font-weight: 500;
    margin-bottom: 2px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__txt p {
    font-size: 1.3rem;
    line-height: 2.0;
    margin-top: 10px;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img p {
    width: 100%;
  }
  .index_contents__detail__works__dialogue a .index_contents__detail__works__dialogue__img p img {
    width: 100%;
    border-radius: 6px 6px 0 0;
    -webkit-border-radius: 6px 6px 0 0;
    -moz-border-radius: 6px 6px 0 0;
  }
  .index_contents__detail__recruit {
    position: relative;
    width: 100%;
    background-color: #F4F6F9;
    margin-top: 100px;
    padding: 80px 0 100px;
  }
  .index_contents__detail__recruit__desc {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__recruit__desc__img {
    position: relative;
    width: 93%;
    margin-left: 7%;
  }
  .index_contents__detail__recruit__desc__img p {
    width: 100%;
  }
  .index_contents__detail__recruit__desc__img p img {
    width: 100%;
    border-radius: 6px 0 0 6px;
    -webkit-border-radius: 6px 0 0 6px;
    -moz-border-radius: 6px 0 0 6px;
  }
  .index_contents__detail__recruit__desc__txt {
    position: relative;
    width: 86%;
    margin: 0 auto;
    padding-top: 25px;
  }
  .index_contents__detail__recruit__desc__txt h3 {
    color: #111111;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.7;
  }
  .index_contents__detail__recruit__desc__txt p {
    text-align: justify;
    font-size: 1.45rem;
    margin-top: 20px;
    line-height: 2.0;
  }
  .index_contents__detail__recruit__desc__txt ul {
    position: relative;
    width: 220px;
    margin-top: 30px;
  }
  .index_contents__detail__recruit__desc__txt ul li {
    position: relative;
    width: 100%;
    margin-top: 20px;
  }
  .index_contents__detail__recruit__desc__txt ul li a {
    position: relative;
    color: #111111;
    font-size: 1.55rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0 0 8px 2px;
    border-bottom: 1px solid #E1E8F0;
    background: url(../img/arrow01.svg) no-repeat right 5px top 8px;
    background-size: 10px;
  }
  .index_contents__detail__recruit__desc__txt ul li img {
    width: 12px;
    margin-left: 6px;
  }
  .index_contents__detail__recruit__inner {
    position: relative;
    width: 86%;
    margin: 60px auto 0;
  }
  .index_contents__detail__recruit__inner__list {
    position: relative;
    width: 100%;
    border: 1px solid #E1E8F0;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__recruit__inner__list a {
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 15px 15px;
    background-color: #ffffff;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
  }
  .index_contents__detail__recruit__inner__list__img {
    position: relative;
    width: 90px;
  }
  .index_contents__detail__recruit__inner__list__img img {
    width: 100%;
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
  }
  .index_contents__detail__recruit__inner__list__img .caption {
    display: none;
  }
  .index_contents__detail__recruit__inner__list__img .mask {
    display: none;
  }
  .index_contents__detail__recruit__inner__list__txt {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 15px;
  }
  .index_contents__detail__recruit__inner__list__txt h3 {
    font-size: 1.55rem;
    font-weight: 600;
    letter-spacing: 0.125em;
    line-height: 1.6;
  }
  .index_contents__detail__recruit__inner__list:nth-child(n+2) {
    margin-top: 12px;
  }
  .index_contents__detail__recruit__wellfare {
    position: relative;
    width: 100%;
    margin-top: 100px;
  }
  .index_contents__detail__recruit__wellfare__inner {
    position: relative;
    width: 86%;
    margin: 0 auto;
  }
  .index_contents__detail__recruit__wellfare__inner ul {
    position: relative;
    width: 100%;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 0 6%;
  }
  .index_contents__detail__recruit__wellfare__inner ul li {
    width: 47%;
  }
  .index_contents__detail__recruit__wellfare__inner ul li .index_contents__detail__recruit__wellfare__inner__img {
    position: relative;
    width: 100%;
  }
  .index_contents__detail__recruit__wellfare__inner ul li .index_contents__detail__recruit__wellfare__inner__img img {
    width: 100%;
    border-radius: 4px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
  }
  .index_contents__detail__recruit__wellfare__inner ul li h3 {
    text-align: center;
    padding-top: 12px;
    font-size: 1.3rem;
    font-weight: 600;
  }
  .index_contents__detail__recruit__wellfare__inner ul li:nth-child(n+3) {
    margin-top: 20px;
  }
  .index_contents__detail__recruit__wellfare h4.btn_style01 {
    width: 86%;
    margin: 30px auto 0;
  }
}

/* ########## index_contents ########## */
/* ########## class_style ########## */
@media screen and (min-width: 1024px) {
  .mt_0 {
    margin-top: 0 !important;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .mt_0 {
    margin-top: 0 !important;
  }
}

@media screen and (max-width: 767px) {
  .mt_0 {
    margin-top: 0 !important;
  }
}

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

@media screen and (min-width: 1024px) {
  .sp {
    display: none;
  }
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  .sp {
    display: none;
  }
}

@media screen and (min-width: 1024px) {
  .sticky {
    position: sticky;
    position: -webkit-sticky;
    top: 20px;
  }
}

/* ########## class_style ########## */
/* ########## recaptcha ########## */
.grecaptcha-badge {
  visibility: hidden;
}

/* ########## recaptcha ########## */
/*# sourceMappingURL=index.css.map */