@charset "UTF-8";
@media screen and (max-width:480px) {
    .btn {
        border-radius: 2.9rem;
        height: 4.5rem;
        line-height: 4rem
    }
}

.sec-header .h1:only-child {
    margin-bottom: 2rem;
}

@media screen and (max-width:767px) {
    .sec-header .h1:only-child {
        text-align: initial;
        margin-inline: auto;
        max-inline-size: max-content
    }
}

form:not(#entryForm):not(#js-module_form) input[type='email'],
form:not(#entryForm):not(#js-module_form) input[type='number'],
form:not(#entryForm):not(#js-module_form) input[type='password'],
form:not(#entryForm):not(#js-module_form) input[type='search'],
form:not(#entryForm):not(#js-module_form) input[type='tel'],
form:not(#entryForm):not(#js-module_form) input[type='text'],
form:not(#entryForm):not(#js-module_form) input[type='url'],
form:not(#entryForm):not(#js-module_form) select {
    max-width: initial;
}

@media screen and (max-width:959px) {
    #top-news .col-image img {
        height: 10rem
    }
}

.op {
    transition: all .3s ease;
}

.op:hover {
    opacity: .7;
}

.btn {
    transition: all .2s ease;
}

a.a__initial {
    color: var(--main-color-1);
    text-decoration: underline;
}

.img_border {
    border: 1px solid #ccc;
}

.acms-grid .img-responsive {
    margin-bottom: 2rem;
}

.body_404_common .page-heading {
    margin-top: 120px;
}

@media screen and (max-width:480px) {
    .body_404_common .page-heading {
        margin-top: 80px
    }
}

.js-lazy-load {
    transform: initial;
    opacity: 0;
}

.js-lazy-load.loading {
    transform: initial;
    opacity: 1;
}

@media screen and (min-width:768px) and (max-width:959px) {
    .nav-list {
        position: absolute;
        top: initial;
        left: initial;
        width: 100%;
        height: 80vh;
        display: flex;
        align-items: center;
        flex-direction: column;
        justify-content: center
    }
}

.column.column__index_style1 a:hover {
    text-decoration: none;
}

@media screen and (min-width:960px) {
    section.index_style1 h2 {
        margin-top: 10px
    }

    section#top_customer-stories .wrap__index_style1_text h2,
    section#top_user-articles .wrap__index_style1_text h2 {
        font-size: 20px;
        line-height: 1.3
    }
}

@media screen and (max-width:959px) {
    section.index_style1 a img {
        width: 10rem;
        height: 10rem;
        -o-object-fit: contain;
        object-fit: contain
    }

    section.index_style1 h2 {
        font-size: 1.6rem
    }

    section.index_style1 .a__index_style1 {
        display: flex
    }

    .wrap__index_style1_text {
        padding-left: 1rem
    }

    a.a__index_style1:hover {
        text-decoration: none
    }

    section.index_style1 .column__index_style1 {
        margin-top: 2.5rem;
        padding-top: 2.5rem
    }
}

.sec-header.h1__index_user-articles {
    padding-top: 10rem;
}

@media screen and (max-width:480px) {
    section.index_style1 .column__index_style1 {
        margin-top: 0
    }

    .index-item {
        margin-top: 0
    }

    .onlineseminar .index-item {
        margin-top: 10px
    }

    .onlineseminar .index-item:first-of-type {
        margin-top: 0
    }

    .sec-header.h1__index_user-articles {
        padding-top: 6rem
    }
}

.article-item {
    @media screen and (max-width:767px) {
        .h2 {
            line-height: 1.35
        }
    }
}

section:not(#top-feature) .acms-entry .h2 {
    margin-bottom: 2rem;
    border-left: 4px solid var(--main-color-1);
    padding: 5px 0 5px 10px;
}

.acms-entry.entry-column {

    h2,
    h3 {
        margin-bottom: 2.5rem;
        margin-top: 3rem;
        margin-right: 10px;
        margin-left: 10px
    }

    p {
        margin-bottom: 40px
    }

    h3.h4 {
        padding: .9rem 1.5rem;
        background: var(--main-color-l3);
        margin-top: 3.2rem;
        margin-bottom: 2rem;
        font-size: 2rem
    }

    .h5 {
        line-height: 1.65;
        margin-bottom: 25px;
        color: var(--main-color-1)
    }

    ul,
    ol {
        margin-left: 25px
    }

    ul.ul_bold,
    ol.ol_bold {
        font-weight: bold
    }

    blockquote {
        margin-bottom: 40px
    }

    ul:not(.pager)>li:before {
        content: '';
        width: 10px;
        height: 10px;
        display: inline-block;
        margin-right: 11.5px;
        background: var(--main-color-1);
        border-radius: 99px;
        margin-bottom: 1px
    }

    ul:not(.pager)>li {
        text-indent: -21px;
        padding-left: 1em;
        margin-bottom: 3px;
        list-style: none
    }

    ol:not(.pager)>li {
        text-indent: -1em;
        padding-left: 1em
    }

    span.text_custom1 {
        color: red
    }

    span.text_custom2 {
        color: blue
    }

    span.text_custom3 {
        font-weight: bold
    }

    p.p_center {
        text-align: center
    }

    p.p__caption {
        font-size: 14px;
        margin: -10px 10px 0;
        line-height: 1.5
    }

    span.CustomText01 {
        font-style: italic
    }

    @media screen and (min-width:768px) {
        .h5 {
            line-height: 1.85
        }
    }

    @media screen and (max-width:959px) {

        h2,
        h3,
        h4 {
            margin-right: 15px;
            margin-left: 15px
        }

        p {
            margin-right: 15px;
            margin-left: 15px;
            font-size: 15px;
            line-height: 1.75
        }

        ul:not(.pager)>li {
            margin-bottom: 5px;
            font-size: 15px
        }

        p.p__caption {
            font-size: 14px;
            margin: -10px 15px 0;
            line-height: 1.6
        }
    }

    @media screen and (max-width:767px) {

        h2,
        h3,
        h4 {
            margin-right: 10px;
            margin-left: 10px
        }

        .h5 {
            margin-bottom: 1.5em;
            line-height: 1.55
        }

        h3.h4 {
            padding: .9rem 1.35rem;
            font-size: 1.9rem
        }

        h3 {
            margin-top: 2rem
        }

        p {
            margin-bottom: 35px;
            line-height: 1.8;
            margin-right: 12px;
            margin-left: 12px
        }

        ul:not(.pager)>li {
            list-style: none
        }

        ul,
        ol {
            margin-left: 22px
        }

        blockquote {
            margin-bottom: 35px;
            line-height: 1.8
        }

        p.p__caption {
            font-size: 14px
        }
    }

    @media screen and (max-width:480px) {
        h2 {
            margin-bottom: 30px !important;
            font-size: 2.1rem;
            line-height: 1.4
        }

        .h2 {
            padding-bottom: 0;
            line-height: 1.3
        }

        h3 {
            font-size: 1.9rem;
            line-height: 1.4;
            margin-top: 2rem
        }

        h3.h4 {
            padding: .9rem 1.25rem;
            font-size: 1.7rem
        }

        ul,
        ol {
            margin-left: 20px
        }

        ul:not(.pager)>li {
            margin-bottom: 7px;
            font-size: 15px
        }

        p {
            margin-bottom: 30px
        }

        p.p__caption {
            font-size: 13px
        }
    }
}

@media screen and (min-width:960px) {
    .plan-item dt {
        min-height: 65px
    }
}

@media (max-width:420px) {
    .func-buttons .btn {
        margin: 0 .2rem;
        padding: 0 1.25rem;
        font-size: 1.1rem
    }
}

a.btn_for_cv2 {
    background-color: var(--main-color-1);
    border: .1rem solid var(--main-color-1);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 400;
    text-decoration: none;
    border-radius: 5rem;
    font-size: 1.6rem;
    height: 4.8rem;
    line-height: 1.2;
    padding: 25px 3rem;
    margin: 4.5rem auto 3rem;
    min-width: 20rem;
    _max-width: 400px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    box-sizing: border-box;
    transition: background-color .3s, border-color .3s;
}

a.btn_for_cv2:hover,
a.btn_for_cv2:focus {
    background-color: var(--main-color-d1);
    border-color: var(--main-color-d1);
}

@media screen and (max-width:767px) {
    a.btn_for_cv2 {
        font-size: 1.5rem
    }
}

@media screen and (max-width:480px) {
    a.btn_for_cv2 {
        font-size: 1.4rem
    }
}

#top-feature .col-image img {
    -webkit-box-shadow: 0 0 2rem #00000020;
    border-radius: 7px;
    box-shadow: 0 0 2rem #00000040;
}

#top-feature .col-image img {
    -webkit-box-shadow: none;
    border-radius: initial;
    box-shadow: none;
}

.personal-link a {
    font-size: 20px;
    margin-right: 2px;
}

@media screen and (max-width:480px) {
    .wrap__member-item {
        margin-bottom: 3.5rem
    }

    .wrap__member-item:last-child {
        margin-bottom: 2rem
    }

    .personal-link a {
        font-size: 22px;
        margin-right: 5px
    }

    #top-feature .col-image img {
        object-fit: contain;
        max-height: 204px
    }
}

#customers .banner .banner-item {
    width: 16.6666667%;
}

@media (min-width:960px) {
    #customers .banner {
        max-width: 116rem
    }
}

@media screen and (max-width:767px) {
    #customers .banner .banner-item {
        width: 25%
    }
}

span.icon__plan_kind {
    color: #fff;
    font-size: 13px;
    padding: 5px 10px;
    border-radius: 20px;
    margin-bottom: 10px;
    display: inline-block;
    max-width: 200px;
    text-align: center;
}

span.icon__plan_kind.icon__plan_kind_mobile {
    background: var(--main-color-1);
}

span.icon__plan_kind.icon__plan_kind_browse {
    background: var(--main-color-2);
}

.wrap__plan_kind span:nth-child(2) {
    margin-left: 5px;
}

.wrap__plan_kind__es span.icon__plan_kind {
    color: #fff;
    font-size: 11px;
    padding: 3px 10px;
    margin-top: 10px;
    margin-bottom: 0;
}

.column.column__index_style1 a:hover {
    text-decoration: none;
}

.wrap__plan_kind__es_index span.icon__plan_kind {
    color: #fff;
    font-size: 11px;
    padding: 3px 10px;
    margin-top: 0;
    margin-bottom: 5px;
}

@media screen and (max-width:959px) {
    .wrap__plan_kind__es span.icon__plan_kind {
        color: #fff;
        font-size: 11px;
        padding: 3px 10px;
        margin-top: 0;
        margin-bottom: 0
    }

    .wrap__plan_kind.wrap__plan_kind__es {
        padding-left: 1rem;
        margin-bottom: 10px
    }

    .wrap__plan_kind__es_index.wrap__plan_kind.wrap__plan_kind__es {
        padding-left: initial;
        margin-bottom: 5px
    }

    .wrap__index_style1_text p {
        margin-bottom: 0
    }

    section.index_style1 h2 {
        margin-bottom: 10px
    }

    span.case_kind_empty {
        margin-top: -10px;
        display: block
    }
}

@media screen and (max-width:767px) {
    span.icon__plan_kind {
        font-size: 11px
    }

    .index-item .index-item-heading {
        margin: 5px 0 0
    }
}

@media screen and (max-width:480px) {
    .wrap__plan_kind__es span.icon__plan_kind {
        font-size: 10px;
        padding: 3px 7px
    }

    .wrap__index_style1_text p {
        font-size: 13px
    }
}

p.custom_hr1 {
    text-align: center;
}

span.custom_hr4 {
    display: block;
    padding: 20px 0;
}

span.custom_hr5 {
    display: block;
    padding: 40px 0;
}

@media screen and (max-width:480px) {
    span.custom_hr4 {
        padding: 15px 0
    }

    span.custom_hr5 {
        padding: 30px 0
    }

    .index-item .index-item-heading {
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
        line-clamp: 3
    }
}

section#customers>.container {
    width: 90%;
    position: relative;
}

ul.banner {
    _position: relative;
}

button.slick-prev {
    position: absolute;
    top: 10%;
    left: -3rem;
    border: 3px solid #f0f3f5;
    background: #fff;
    color: var(--main-color-1);
    height: 75px;
    border-radius: 20px;
    width: 40px;
    font-size: 2.2rem;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transition: .5s;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

button.slick-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    right: -3rem;
    border: 3px solid #f0f3f5;
    background: #fff;
    color: var(--main-color-1);
    height: 75px;
    border-radius: 20px;
    width: 40px;
    font-size: 2.2rem;
    transition: .5s;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

button.slick-prev:hover,
button.slick-next:hover {
    background: #e6f6e8;
    border: 3px solid #c2e2c6;
}

@media screen and (min-width:1300px) {
    button.slick-prev {
        left: -6rem
    }

    button.slick-next {
        right: -6rem
    }
}

@media screen and (min-width:980px) and (max-width:1299px) {
    button.slick-prev {
        left: -4.5rem
    }

    button.slick-next {
        right: -4.5rem
    }
}

@media screen and (max-width:480px) {
    section#customers>.container {
        width: 80%
    }

    button.slick-prev {
        left: -4.2rem;
        font-size: 2rem;
        width: 35px
    }

    button.slick-next {
        right: -4.2rem;
        font-size: 2rem;
        width: 35px
    }
}

h2.h2_greeting2024 {
    font-size: 3.75rem;
}

.acms-entry h2.h2_greeting2024::after {
    border-bottom: none;
}

h2.h2_greeting2024_en {
    color: #292929;
    font-weight: 600;
    font-size: 37.5px;
    margin-bottom: 20px;
    font-family: 'Montserrat', Montserrat, sans-serif;
    transition: all .3s;
    line-height: 1.25;
}

h2.h2_greeting2024_en::after {
    border-bottom: none;
}

p.p_st_greeting2024 {
    color: var(--sp-color1);
    font-weight: 600;
    font-size: 20px;
    margin-bottom: 20px;
    font-family: 'Montserrat', Montserrat, sans-serif;
    transition: all .3s;
    line-height: 1.45;
}

@media screen and (min-width:1401px) {
    h2.h2_greeting2024 {
        font-size: 4rem
    }

    p.p_st_greeting2024 {
        font-size: 23px
    }
}

@media screen and (max-width:767px) {
    h2.h2_greeting2024_en {
        font-size: 32.5px;
        line-height: 1.2
    }

    h2.h2_greeting2024 {
        font-size: 3.25rem
    }
}

@media screen and (max-width:480px) {
    h2.h2_greeting2024_en {
        font-size: 28px
    }

    h2.h2_greeting2024 {
        font-size: 3rem
    }

    p.p_st_greeting2024 {
        font-size: 18px;
        line-height: 1.35
    }
}

@media screen and (min-width:768px) {
    .acms-hide-pc {
        display: none
    }
}

@media screen and (max-width:767px) {
    .pc_only {
        display: none !important
    }
}

@media screen and (max-width:480px) {
    .pc_tb_only {
        display: none !important
    }
}

@media screen and (min-width:768px) {
    .sp_tb_only {
        display: none !important
    }
}

@media screen and (min-width:481px) {
    .sp_only {
        display: none !important
    }
}