@charset "utf-8";

/*----------------------------
header
------------------------------*/
#esbody {
    min-width: 100vw;
}
#container {
    overflow: hidden;
}
#esbody * {
    font-family: 'Noto Sans JP', sans-serif;
}
#esbody {
    color: #333333;
}
.hidden-desktop {
    display: block;
}
.hidden-phone {
    display: none;
}
.l-header {
    top: 0;
    left: 0;
    right: 0;
    z-index: 4;
    background-color: #FFFFFF;
    height: 11.8666666667vw;
}
.header-logo {
    display: inline-block;
    width: 52.66vw;
    height: 4.5266666667vw;
}
.header-inner {
    padding: 4vw 3.4933333333vw 0 2.6666666667vw;
}
.menu-btn {
    position: fixed;
    top: 4vw;
    right: 3.4933333333vw;
    z-index: 4;
}
.menu-icon {
   width: 5.6773333333vw;
   height: 4.26vw; 
}
.header-wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.remodal-overlay {
    width: 100vw;
    height: 100vh;
}
.remodal-wrapper {
    width: 100vw;
    height: 100vh;
    padding: 0;
}
.header-remodal {
    width: 100vw;
    height: 100vh;
    padding: 6.6666666667vw 4.6vw 0 4.6vw;
    margin: 0;
}
.header-remodal-close {
    right: 0;
    left: auto;
    width: 10.1333333333vw;
    height: 10vw;
    background-color: #545454;
    color: #FFFFFF;
    font-size: 2.4vw;
    font-weight: 500;
    text-align: center;
}
.header-remodal-close::before {
    content: '';
}
.header-close-mark {
    display: block;
    color: #FFFFFF;
    font-size: 6.4vw;
    font-weight: 500;
    margin: -1.5vw 0 -1.7vw;
}
.header-modal-ttl {
    font-size: 4.2666666667vw;
    font-weight: 700;
    text-align: left;
    margin-left: 3vw;
    margin-bottom: 3.4666666667vw;
}
.header-modal-ttl::before {
    display: inline-block;
    content: '';
    width: 1.0666666667vw;
    height: 4.8vw;
    background: url(../images/menu-ttl-img.png) center/cover;
    -webkit-transform: translateY(25%);
    transform: translateY(25%);
    margin-right: 3.4666666667vw;
}
.header-modal-page-link {
    display: block;
    height: 9.9333333333vw;
    color: #333333;
    font-size: 3.2vw;
    font-weight: 500;
    text-align: left;
    line-height: 9.9333333333vw;
    padding-left: 1vw;
    border-bottom: #E5E5E5 solid 0.1333333333vw;
    position: relative;
}
.header-modal-page-link::after {
    content: '';
    display: block;
    position: absolute;
    width: 2.1333333333vw;
    height: 3.2vw;
    background: url(../images/modal-list-icon.png) center/cover;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 2.1333333333vw;
}
@media (min-width: 768px) {
    #container a:hover {
        text-decoration: none;
        opacity: 0.6;
    }
    .hidden-desktop {
        display: none;
    }
    .hidden-phone {
        display: block;
    }
    .l-header {
        border-bottom: #D6D6D6 solid 1px;
        height: 153px;
    }
    .header-logo {
        width: 349px;
        height: 30px;
    }
    .header-inner {
        max-width: 1200px;
        padding: 34px 0;
        margin: 0 auto;
    }
    .remote-support {
        display: block;
        width: 177px;
        height: 48px;
        background: url(../images/remote-support-bg.png) center/cover;
        color: #FFFFFF;
        font-size: 16px;
        font-weight: 500;
        line-height: 48px;
        padding-left: 77px;
        position: relative;
    }
    .remote-support::before,
    .remote-support::after {
      content: '';
      width: 7.94px;
      height: 12.16px;
      background: url(../images/btn-arrow.png) center/cover;
      position: absolute;
      top: 50%;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%);
      right: 12.7px;
    }
    .remote-support::after {
      opacity: 0;
      right: 1em;
    }
    .remote-support:hover::before {
      animation: arrowbefore .5s;
    }
    .remote-support:hover::after {
      animation: arrowafter .5s;
    }
    .remote-support:hover {
        color: #FFFFFF;
        text-decoration: none;
    }
    @keyframes arrowbefore {
      100% {
        right: -.1em;
        opacity: 0;
      }
    }
    @keyframes arrowafter {
      99% {
        right: 1.25em;
        opacity: 1;
      }
      100% {
        opacity: 0;
      }
    }
    .page-link-lists {
        display: flex;
        justify-content: space-between;
        max-width: 1010px;
        margin: 12px auto 0;
    }
    .page-link {
        background:
        linear-gradient(currentColor 0 0) 0    100%/var(--d, 0) 2px no-repeat,
        linear-gradient(currentColor 0 0) 100% 100%/var(--d, 0) 2px no-repeat;
      transition:0.2s;
    }    

    .page-link {
        display: block;
        height: 50px;
        color: #333333;
        font-size: 16px;
        font-weight: 500;
        line-height: 60px;
    }
    .page-link:hover {
        text-decoration: none;
        color: #333;
        --d: 51%;
    }
}
