body {
    letter-spacing: 0
}

/* Desktop default */
.lang-switcher-pc {
    display: block;
}

.lang-switcher-mobile {
    display: none;
}

.lang-dropdown {
    position: relative;
    display: inline-block;
}

.lang-toggle {
    background: #fff;
    border: 0px !important;
    padding: 10px 12px 10px 0px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
}

.lang-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 200px;
    background-color: #f0f0f0;

    z-index: 99;
    padding: 0;
    margin: 0;
    list-style: none;
}

.lang-menu li {
    width: 100%;
}

.lang-menu li a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    text-decoration: none;
    color: black;
    font-weight: bold;
    font-size: 16px;
    width: 100%;
}

.lang-menu li a:hover {
    background-color: #ffffff;

}

.lang-dropdown:hover .lang-menu {
    display: block;
}

.flag {
    border: 1px solid #0c0c0c;
}


.flag-large {
    width: 35px;
    height: 23px;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid #0c0c0c;
    border-radius: 0px;
    box-sizing: border-box;
}

.lang-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    text-decoration: none;
    color: black;
    font-size: 16px;
    font-weight: bold;
    white-space: nowrap;
    min-width: 140px;
}


@media screen and (-ms-high-contrast: active),
(-ms-high-contrast: none) {
    header .gnav-list a span {
        padding-top: 0
    }

    header .gnav-btn a span {
        padding-top: 0
    }
}

@media only screen and (max-width: 1139px) {
    header .gnav-list {
        margin-right: 20px
    }
}

@media only screen and (max-width: 1139px) and (max-width: 767px) {
    header .gnav-list {
        margin-right: auto
    }
}

@media only screen and (max-width: 1139px) {
    header .gnav-list li:not(:first-child) {
        margin-left: 20px
    }
}

@media only screen and (max-width: 1139px) and (max-width: 767px) {
    header .gnav-list li:not(:first-child) {
        margin-left: auto
    }
}

@media only screen and (max-width: 1139px) {}

.fv__hd {
    top: 56%
}

.fv__hd span {
    margin: 0 auto;
    display: flex;
    font-size: 4px;
    font-size: 3rem;
    line-height: 60px;
    letter-spacing: .05em;
    font-weight: 800;
    font-family: "Montserrat", sans-serif;
    color: #fff;
}

@media screen and (max-width: 1280px) {
    .fv__hd span {
        text-align: left;
        font-size: 36px !important;
        font-size: 3.6rem !important;
        line-height: 72px !important;
        padding: 0 25px;
    }
}

@media (max-width: 767px) {
    .lang-switcher-pc {
        display: none;
    }

    .lang-switcher-mobile {
        display: block;
    }

    .fv__hd span {
        text-align: justify;
        font-size: 18px !important;
        font-size: 1.8rem !important;
        line-height: 36px !important;
        padding: 0 10px !important;
    }

    .fv__hd {
        font-size: 18px !important;
        font-size: 1.8rem !important;
        line-height: 36px !important;
        padding: 0 2px;
        text-align: justify;
    }
}

@media only screen and (max-width: 370px) {
    .fv__hd span {
        font-size: 15px;
        font-size: 1.5rem;
        line-height: 30px;
    }
}

.c-hd__jp {
    letter-spacing: 0.05em
}

.c-txt {
    letter-spacing: 0.05em
}

@media (max-width: 767px) {
    .c-txt {
        font-size: 14px;
        font-size: 1.4rem;
        line-height: 28px;
        letter-spacing: 0.05em
    }
}

.c-subhd {
    letter-spacing: 0.05em
}

@media screen and (-ms-high-contrast: active),
(-ms-high-contrast: none) {
    .c-btn span {
        padding-top: 25px;
        padding-bottom: 25px
    }
}

.concept__bg {
    min-height: 630px
}

@media (max-width: 1280px) {
    .concept__bg {
        min-height: auto
    }
}

.concept__ttl {
    letter-spacing: 0.05em
}

.concept .inner {
    max-width: 560px
}

@media (max-width: 1280px) {
    .concept .inner {
        max-width: 650px;
    }
}

.service .slide-item .slider-detail {
    padding-top: 0
}

.service .slide-item .slider-detail__txt {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 32px;
    letter-spacing: 0.05em;
    font-weight: 500;
    text-align: justify;
}

@media (max-width: 767px) {
    .service .slide-item .slider-detail__txt {
        font-size: 14px;
        font-size: 1.4rem;
        line-height: 28px;
    }
}

.service .slide-item .slider-detail__list li {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 32px;
    letter-spacing: 0.05em;
    font-weight: 500;
    margin-left: 17px;
    position: relative;
    padding-left: 1em
}

@media (max-width: 767px) {
    .service .slide-item .slider-detail__list li {
        font-size: 14px;
        font-size: 1.4rem;
        line-height: 28px;
    }
}

.service .slide-item .slider-detail__list li:before {
    content: "・";
    position: absolute;
    left: 0;
    top: 0
}

.company .profile-table .cell:first-child {
    width: 200px
}

@media screen and (-ms-high-contrast: active),
(-ms-high-contrast: none) {
    .company .profile-table .cell:first-child {
        padding-top: 17px
    }
}

@media (max-width: 767px) {
    .company .profile-table .cell:first-child {
        width: 100%
    }
}

.company .profile-table .cell:last-child {
    width: calc(100% - 200px)
}

@media (max-width: 767px) {
    .company .profile-table .cell:last-child {
        width: 100%
    }
}

.company .profile-images .name-box {
    display: block;
    padding: 14px 0 16px;
    padding-left: 40px
}

.company .profile-images .name-box__txt {
    margin-left: 0;
    font-size: 24px;
    font-size: 2.4rem;
    margin-top: -5px
}

.recruit {
    margin-top: 140px
}

.hiring-bg .hiring-box {
    padding: 75px 0 60px
}

.char-area__hd {
    letter-spacing: 0.05em
}

.char-area__note {
    letter-spacing: 0.05em
}

@media (max-width: 767px) {
    .char-area .char-list .detail {
        min-height: 553px
    }
}

.char-area .char-list .detail__ttl {
    font-size: 24px;
    font-size: 2.4rem;
    letter-spacing: 0.05em;
}

.char-area .char-list .detail__txt {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 32px;
    letter-spacing: 0.05em;
    text-align: justify;
}

@media (max-width: 767px) {
    .char-area .char-list .detail__txt {
        font-size: 14px;
        font-size: 1.4rem;
        line-height: 28px;
    }
}

@media only screen and (max-width: 1189px) {
    .char-area .char-list .detail .wrapper {
        padding: 30px;
        padding-left: 20px;
        padding-right: 20px
    }
}

.top-contact__note {
    letter-spacing: 0.05em
}

footer .footer-info {
    letter-spacing: 0.05em
}

/*# sourceMappingURL=maps/top-vi.min.css.map */