@charset "UTF-8";

.l-footer {
    padding-bottom: 15.38462vw
}

@media (min-width:768px) {
    .l-footer {
        padding-bottom: 0
    }
}

.l-main {
    --scroll-var-size: 0;
    --page-wrap-px: 12;
    --layout-px: var(--page-wrap-px);
    --header-height: 5.375rem;
    font-size: 16px;
    line-height: 1.8
}

@media (min-width:768px) {
    .l-main {
        --font-size-base: 16;
        --page-wrap-px: 40;
        --layout-px: 0;
        --content-width-base: 1200;
        --header-height: 6.75rem
    }
}

.l-main a,
.l-main abbr,
.l-main acronym,
.l-main address,
.l-main applet,
.l-main article,
.l-main aside,
.l-main audio,
.l-main b,
.l-main big,
.l-main blockquote,
.l-main canvas,
.l-main caption,
.l-main center,
.l-main cite,
.l-main code,
.l-main dd,
.l-main del,
.l-main details,
.l-main dfn,
.l-main div,
.l-main dl,
.l-main dt,
.l-main em,
.l-main fieldset,
.l-main figcaption,
.l-main figure,
.l-main footer,
.l-main form,
.l-main h1,
.l-main h2,
.l-main h3,
.l-main h4,
.l-main h5,
.l-main h6,
.l-main header,
.l-main hgroup,
.l-main i,
.l-main iframe,
.l-main img,
.l-main ins,
.l-main kbd,
.l-main label,
.l-main legend,
.l-main li,
.l-main mark,
.l-main menu,
.l-main nav,
.l-main object,
.l-main ol,
.l-main output,
.l-main p,
.l-main pre,
.l-main q,
.l-main ruby,
.l-main s,
.l-main samp,
.l-main section,
.l-main small,
.l-main span,
.l-main strike,
.l-main strong,
.l-main sub,
.l-main summary,
.l-main sup,
.l-main table,
.l-main tbody,
.l-main td,
.l-main tfoot,
.l-main th,
.l-main thead,
.l-main time,
.l-main tr,
.l-main tt,
.l-main u,
.l-main ul,
.l-main var,
.l-main video {
    border: 0;
    box-sizing: border-box;
    font-size: 3.58974vw;
    margin: 0;
    padding: 0;
    vertical-align: initial
}

@media (min-width:768px) {

    .l-main a,
    .l-main abbr,
    .l-main acronym,
    .l-main address,
    .l-main applet,
    .l-main article,
    .l-main aside,
    .l-main audio,
    .l-main b,
    .l-main big,
    .l-main blockquote,
    .l-main canvas,
    .l-main caption,
    .l-main center,
    .l-main cite,
    .l-main code,
    .l-main dd,
    .l-main del,
    .l-main details,
    .l-main dfn,
    .l-main div,
    .l-main dl,
    .l-main dt,
    .l-main em,
    .l-main fieldset,
    .l-main figcaption,
    .l-main figure,
    .l-main footer,
    .l-main form,
    .l-main h1,
    .l-main h2,
    .l-main h3,
    .l-main h4,
    .l-main h5,
    .l-main h6,
    .l-main header,
    .l-main hgroup,
    .l-main i,
    .l-main iframe,
    .l-main img,
    .l-main ins,
    .l-main kbd,
    .l-main label,
    .l-main legend,
    .l-main li,
    .l-main mark,
    .l-main menu,
    .l-main nav,
    .l-main object,
    .l-main ol,
    .l-main output,
    .l-main p,
    .l-main pre,
    .l-main q,
    .l-main ruby,
    .l-main s,
    .l-main samp,
    .l-main section,
    .l-main small,
    .l-main span,
    .l-main strike,
    .l-main strong,
    .l-main sub,
    .l-main summary,
    .l-main sup,
    .l-main table,
    .l-main tbody,
    .l-main td,
    .l-main tfoot,
    .l-main th,
    .l-main thead,
    .l-main time,
    .l-main tr,
    .l-main tt,
    .l-main u,
    .l-main ul,
    .l-main var,
    .l-main video {
        font-size: 1.6rem
    }
}

.l-main img {
    height: auto;
    max-width: 100%;
    vertical-align: bottom
}

@media (min-width:768px) {
    .l-main img {
        image-rendering: -webkit-optimize-contrast
    }
}

.l-main iframe,
.l-main svg {
    vertical-align: bottom
}

.l-main a {
    color: var(--color-text-base)
}

.l-main figure {
    line-height: 0
}

.l-main button {
    background: none;
    border: none;
    color: #000;
    cursor: pointer;
    margin: 0;
    outline: none;
    padding: 0;
    text-align: left
}

.l-main h1,
.l-main h2,
.l-main h3,
.l-main h4,
.l-main h5,
.l-main h6 {
    background-color: initial;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.5
}

.l-main em {
    font-style: normal
}

.l-main .is-border,
.l-main .is-border-b,
.l-main .is-border-t {
    border: 1px solid
}

.l-main .p-button {
    background-image: linear-gradient(90deg, #fc406f 7.5%, #ca0026 50%, #ca0026 57.5%, #fc406f);
    background-size: 200%;
    border-radius: 9999px;
    color: #fff;
    display: block;
    font-weight: 700;
    transition: background-position .3s ease-out 0s
}

@media (any-hover:hover) {
    .l-main .p-button:hover {
        background-position: 100% 0
    }
}

@media (any-hover:none) {
    .l-main .p-button:active {
        background-position: 100% 0
    }
}

.l-main .p-button-white {
    background-color: #fff;
    background-image: none;
    border-radius: 9999px;
    color: #025cad;
    display: block;
    font-weight: 700;
    transition: background-color .3s ease-out 0s, color .3s ease-out 0s
}

.l-main .p-button-white svg path {
    transition: fill .3s ease-out 0s
}

@media (any-hover:hover) {
    .l-main .p-button-white:hover {
        background-color: #025cad;
        color: #fff
    }

    .l-main .p-button-white:hover svg path {
        fill: #fff
    }
}

@media (any-hover:none) {
    .l-main .p-button-white:active {
        background-color: #025cad;
        color: #fff
    }

    .l-main .p-button-white:active svg path {
        fill: #fff
    }
}

.l-main .p-button_inner {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: space-between;
    line-height: 1
}

.l-main .u-none {
    display: none
}

@media (min-width:768px) {
    .l-main .u-none-pc {
        display: none
    }
}

@media (min-width:768px) {
    .l-main .u-inline-pc {
        display: inline
    }
}

.l-main .p-wrap {
    padding: 0 3.07692vw
}

.l-main .p-wrap.is-full {
    padding-left: 0;
    padding-right: 0
}

@media (min-width:768px) {
    .l-main .p-wrap {
        padding: 0 32px
    }

    .l-main .p-wrap.is-full {
        padding-left: 0;
        padding-right: 0
    }
}

.l-main .p-content {
    margin: 0 auto;
    width: 100%
}

.l-main .p-content.p-interval {
    padding-left: 2.5641vw;
    padding-right: 2.5641vw
}

.l-main .p-content.p-interval-double {
    padding-left: 5.12821vw;
    padding-right: 5.12821vw
}

.l-main .p-content.is-w-full {
    margin-left: calc(var(--page-wrap-px)*-1/16*1rem);
    margin-right: calc(var(--page-wrap-px)*-1/16*1rem);
    width: auto
}

.l-main .p-content.is-w-max {
    max-width: none
}

.l-main .p-content.is-w-1920 {
    max-width: 120rem
}

.l-main .p-content.is-w-1440 {
    max-width: 90rem
}

.l-main .p-content.is-w-1200 {
    max-width: 75rem
}

.l-main .p-content.is-w-1000 {
    max-width: 62.5rem
}

.l-main .p-content.is-w-800 {
    max-width: 50rem
}

@media (min-width:768px) {

    .l-main .p-content.p-interval,
    .l-main .p-content.p-interval-double {
        padding-left: 0;
        padding-right: 0
    }
}

.modal {
    display: none
}

.modal.is-open {
    display: block
}

.modal-overlay {
    align-items: center;
    background: #000000b3;
    bottom: 0;
    display: flex;
    justify-content: center;
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 10000
}

.modal-box {
    box-sizing: border-box;
    margin: 0 auto;
    overflow-y: auto;
    padding: 1.25rem;
    position: relative;
    width: -webkit-fit-content;
    width: fit-content
}

@media (min-width:768px) {
    .modal-box {
        display: block;
        padding: 1.5625rem
    }
}

.is-add-scroll-y .modal-box {
    display: block
}

.m-btn-modal {
    transition: opacity .3s ease-out 0s
}

@media (any-hover:hover) {
    .m-btn-modal:hover {
        opacity: .7
    }
}

@media (any-hover:none) {
    .m-btn-modal:active {
        opacity: .7
    }
}

.modal-close {
    background-color: #000;
    border-radius: 9999px;
    display: block;
    height: 2.5rem;
    line-height: 1;
    padding: .75rem;
    position: absolute;
    right: 0;
    top: 0;
    width: 2.5rem;
    z-index: 1001
}

.modal-close svg {
    height: 100%;
    pointer-events: none;
    width: 100%
}

@media (min-width:768px) {
    .modal-close {
        height: 2.75rem;
        width: 2.75rem
    }
}

.modal[aria-hidden=false] .modal-overlay {
    animation: anime-modal-fade-in .2s ease-out 0s
}

.modal[aria-hidden=true] .modal-overlay {
    animation: anime-modal-fade-out .2s ease-out 0s
}

@keyframes anime-modal-fade-in {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes anime-modal-fade-out {
    0% {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

.floating-banner,
.l-footer-top-btn,
.l-header-ogis-nav-contact {
    display: none
}

html {
    scroll-behavior: smooth
}

@media (max-width:768px) {
    body .u-sp {
        display: block !important
    }
}

.l-main {
    --color-main: #009699;
    --color-bg: #e9f8f5;
    --color-cv: linear-gradient(90deg, #ff924e, #f20000 50%, #f20000 51%, #ff924e);
    font-family: Inter, Noto Sans JP, sans-serif;
    letter-spacing: 0;
    position: relative
}

.l-main .p-text em {
    font-weight: 700
}

.l-main .p-above-the-fold {
    padding-bottom: 66.66667vw;
    padding-top: 7.17949vw;
    position: relative
}

@media (min-width:768px) {
    .l-main .p-above-the-fold {
        align-items: center;
        display: grid;
        padding-bottom: 65px;
        padding-top: 60px
    }
}

.l-main .p-above-the-fold.is-lp02 {
    background: url(/pickup/edi/images/8689_above_the_fold_bg_sp.png) 0/auto 100% no-repeat
}

@media (min-width:768px) {
    .l-main .p-above-the-fold.is-lp02 {
        background: url(/pickup/edi/images/8689_above_the_fold_bg.png) 50%/1920px auto no-repeat
    }
}

@media (min-width:1921px) {
    .l-main .p-above-the-fold {
        background-size: 100% auto
    }
}

.l-main .p-above-the-fold-content {
    padding: 0;
    text-align: center
}

@media (min-width:768px) {
    .l-main .p-above-the-fold-content {
        margin: 0 auto;
        max-width: 1024px;
        text-align: left
    }
}

.l-main .p-page-heading {
    color: var(--color-main);
    font-weight: 700;
    line-height: 1.4;
    margin-top: 4.10256vw;
    text-align: center
}

.l-main .p-page-heading>* {
    display: block
}

.l-main .p-page-heading .p-heading_text-two {
    display: none
}

.l-main .p-page-heading .p-heading_text-one {
    background: #fff;
    display: inline-block;
    font-size: 6.15385vw;
    line-height: 1;
    padding: 3.07692vw 1.79487vw
}

@media (min-width:768px) {
    .l-main .p-page-heading {
        margin-top: 20px;
        text-align: left
    }

    .l-main .p-page-heading .p-heading_text-one {
        font-size: 4.4rem;
        padding: 15px
    }
}

.l-main .p-page-heading_logo img {
    background: #fff;
    max-height: 15.38462vw;
    padding: 2.5641vw 5.12821vw 1.28205vw
}

@media (min-width:768px) {
    .l-main .p-page-heading_logo img {
        max-height: 100%;
        padding: 10px 20px
    }
}

.l-main .p-page-heading_shoulder {
    color: #fff;
    font-weight: 700;
    line-height: 1.5
}

@media (min-width:768px) {
    .l-main .p-page-heading_shoulder {
        font-size: 2rem;
        line-height: 1.8
    }
}

.l-main .p-page-heading_caption {
    color: #fff;
    font-weight: 700;
    line-height: 1.5;
    margin-top: 6.66667vw
}

@media (min-width:768px) {
    .l-main .p-page-heading_caption {
        font-size: 2rem;
        line-height: 1.8;
        margin-top: 32px
    }
}

.l-main .p-cv-button-wrap {
    display: flex;
    flex-direction: row;
    gap: 2.5641vw;
    justify-content: center;
    margin-top: 8.20513vw
}

@media (min-width:768px) {
    .l-main .p-cv-button-wrap {
        gap: 20px;
        justify-content: normal;
        margin-top: 40px
    }
}

.l-main .p-cv-button {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: center;
    position: relative
}

@media (max-width:767px) {
    .l-main .p-cv-button {
        width: 69.23077vw
    }
}

@media (min-width:768px) {
    .l-main .p-cv-button {
        min-width: 250px
    }
}

.l-main .p-cv-button a {
    border-radius: 9999px;
    display: grid;
    height: 15.89744vw;
    place-content: center;
    position: relative;
    width: 100%;
    z-index: 0
}

.l-main .p-cv-button a span {
    font-size: 3.58974vw;
    font-weight: 700;
    line-height: 1.3;
    text-decoration: none
}

@media (min-width:768px) {
    .l-main .p-cv-button a {
        height: auto;
        max-width: 300px
    }

    .l-main .p-cv-button a span {
        font-size: 1.8rem;
        padding: 26px 1rem
    }
}

.l-main .p-cv-button.is-white a {
    background-color: #fff;
    color: #f30;
    outline: 2px solid #ff924e
}

.l-main .p-cv-button.is-white a:after {
    background-image: var(--color-cv);
    background-size: 200%;
    border-radius: 9999px;
    box-shadow: 0 3px 10px 0 #0003;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: .3s;
    width: 100%;
    z-index: -1
}

@media (any-hover:hover) {
    .l-main .p-cv-button.is-white a:hover {
        color: #fff;
        outline: 0
    }

    .l-main .p-cv-button.is-white a:hover:after {
        opacity: 1
    }
}

@media (any-hover:none) {
    .l-main .p-cv-button.is-white a:active {
        color: #fff;
        outline: 0
    }

    .l-main .p-cv-button.is-white a:active:after {
        opacity: 1
    }
}

.l-main .p-cv-button.is-color a {
    background-image: var(--color-cv);
    background-size: 200%;
    color: #fff;
    outline: 0
}

.l-main .p-cv-button.is-color a:after {
    background-color: #fff;
    border-radius: 9999px;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: .3s;
    width: 100%;
    z-index: -1
}

@media (any-hover:hover) {
    .l-main .p-cv-button.is-color a:hover {
        color: #f30;
        outline: 2px solid #f60
    }

    .l-main .p-cv-button.is-color a:hover:after {
        opacity: 1
    }
}

@media (any-hover:none) {
    .l-main .p-cv-button.is-color a:active {
        color: #f30;
        outline: 2px solid #f60
    }

    .l-main .p-cv-button.is-color a:active:after {
        opacity: 1
    }
}

.l-main .p-cv-button_message {
    align-items: center;
    color: #fff;
    display: flex;
    font-size: 1.4rem;
    font-weight: 700;
    gap: .4em;
    line-height: 1.4;
    text-align: center
}

.l-main .p-cv-button_message:after,
.l-main .p-cv-button_message:before {
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='40' fill='none'%3E%3Cpath stroke='%23fff' d='m1 1 20 38'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: inline-block;
    height: 10.25641vw;
    width: 5.64103vw
}

.l-main .p-cv-button_message:after {
    transform: scaleX(-1)
}

@media (min-width:768px) {
    .l-main .p-cv-button_message {
        line-height: 1
    }

    .l-main .p-cv-button_message:after,
    .l-main .p-cv-button_message:before {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='15' fill='none'%3E%3Cpath stroke='%23fff' d='m1 1 8 13'/%3E%3C/svg%3E");
        height: 15px;
        width: 10px
    }
}

.l-main .p-section-heading {
    font-weight: 700;
    padding-bottom: 3.84615vw;
    position: relative;
    text-align: center
}

.l-main .p-section-heading:after {
    background-color: var(--color-main);
    border-radius: 9999px;
    bottom: 0;
    content: "";
    height: .76923vw;
    left: 0;
    margin: 0 auto;
    position: absolute;
    right: 0;
    width: 10.25641vw
}

.l-main .p-section-heading .p-heading_text-one {
    font-size: 6.15385vw
}

@media (min-width:768px) {
    .l-main .p-section-heading {
        padding-bottom: 12px
    }

    .l-main .p-section-heading:after {
        height: 3px;
        width: 40px
    }

    .l-main .p-section-heading.is-align-left {
        text-align: left
    }

    .l-main .p-section-heading.is-align-left:after {
        left: 10px;
        right: auto
    }

    .l-main .p-section-heading .p-heading_text-one {
        font-size: 2.8rem
    }
}

.l-main .p-section-heading.is-solution .p-heading_text-one {
    color: var(--color-main)
}

.l-main .p-section-heading.is-solution:after {
    display: none
}

.l-main .p-cv {
    padding: 0 3.07692vw 20.51282vw
}

@media (min-width:768px) {
    .l-main .p-cv {
        padding-bottom: 100px
    }
}

.l-main .p-cv.is-bg {
    background: var(--color-bg);
    border-radius: 0 0 10.25641vw 10.25641vw
}

@media (min-width:768px) {
    .l-main .p-cv.is-bg {
        border-radius: 0 0 40px 40px
    }
}

.l-main .p-cv-content {
    background: url(/pickup/edi/images/8689_cv_bg_sp.png) 50%/auto 100% no-repeat;
    border-radius: 5.12821vw;
    padding: 15.38462vw 0 20.51282vw
}

@media (min-width:768px) {
    .l-main .p-cv-content {
        background: url(/pickup/edi/images/8689_cv_bg.png) 50%/auto 100% no-repeat;
        border-radius: 20px;
        margin: 0 auto;
        max-width: 1480px;
        padding: 60px 0 68px
    }
}

.l-main .p-cv-content .p-cv-button-wrap {
    align-items: center;
    flex-direction: column;
    gap: 5.12821vw;
    justify-content: center;
    margin-top: 6.15385vw
}

@media (min-width:768px) {
    .l-main .p-cv-content .p-cv-button-wrap {
        flex-flow: row wrap;
        gap: 20px;
        margin-top: 40px
    }
}

.l-main .p-cv-content .p-cv-button {
    min-width: 270px;
    position: relative
}

.l-main .p-cv-content .p-cv-button a span {
    font-size: 4.10256vw;
    font-weight: 700;
    line-height: 1;
    padding: 7.17949vw auto;
    text-decoration: none
}

@media (min-width:768px) {
    .l-main .p-cv-content .p-cv-button a {
        height: auto
    }

    .l-main .p-cv-content .p-cv-button a span {
        font-size: 1.8rem;
        padding: 26px 0
    }
}

.l-main .p-cv-text-wrap {
    align-items: center;
    display: flex;
    justify-content: center
}

.l-main .p-cv-text {
    color: #fff;
    font-size: 5.12821vw;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.6;
    text-align: center
}

@media (min-width:768px) {
    .l-main .p-cv-text {
        font-size: 2rem
    }
}

.l-main .p-problem {
    background: url(/pickup/edi/images/8689_problem_bg.svg) 0/100% auto no-repeat;
    padding: 17.94872vw 0 20.51282vw
}

@media (min-width:768px) {
    .l-main .p-problem {
        padding-bottom: 98px;
        padding-top: 78px
    }
}

@media (min-width:768px) {
    .l-main .p-problem-content {
        margin: 0 auto;
        max-width: 1024px
    }
}

.l-main .p-problem-list {
    display: flex;
    flex-direction: column;
    gap: 5.12821vw;
    margin-top: 10.25641vw
}

@media (min-width:768px) {
    .l-main .p-problem-list {
        display: grid;
        gap: 20px;
        grid-template-columns: repeat(3, 1fr);
        margin-top: 40px
    }
}

.l-main .p-problem_item {
    background: #fff;
    border-radius: 5.12821vw;
    box-shadow: 0 0 3.07692vw 0 #00646633;
    padding: 13.33333vw 6.15385vw
}

@media (min-width:768px) {
    .l-main .p-problem_item {
        border-radius: 20px;
        padding: 36px 30px 30px
    }
}

.l-main .p-problem_item-head {
    font-size: 6.15385vw;
    font-weight: 700;
    line-height: 1.5;
    text-align: center
}

@media (min-width:768px) {
    .l-main .p-problem_item-head {
        font-size: 2rem
    }
}

.l-main .p-problem_item-subhead {
    color: var(--color-main);
    font-weight: 700;
    line-height: 1.5;
    margin-top: 5.12821vw;
    text-align: center
}

@media (min-width:768px) {
    .l-main .p-problem_item-subhead {
        font-size: 1.4rem;
        margin-top: 12px
    }
}

.l-main .p-problem_item-img {
    background-color: var(--color-bg);
    border-radius: 5.12821vw;
    height: 48.71795vw;
    margin-top: 7.69231vw;
    overflow: hidden;
    text-align: center
}

@media (min-width:768px) {
    .l-main .p-problem_item-img {
        border-radius: 20px;
        height: 160px;
        margin-top: 20px;
        padding-top: 10px
    }
}

.l-main .p-problem_item:first-child img {
    transform: translate(14px)
}

@media (max-width:767px) {
    .l-main .p-problem_item:first-child img {
        transform: translate(2.5641vw, -1.28205vw);
        width: 75%
    }
}

@media (max-width:767px) {
    .l-main .p-problem_item:nth-child(2) img {
        transform: translateY(2.5641vw);
        width: 75%
    }
}

@media (max-width:767px) {
    .l-main .p-problem_item:nth-child(3) img {
        transform: translate(1.28205vw, 2.5641vw);
        width: 80%
    }
}

.l-main .p-problem_item-text {
    line-height: 1.8;
    margin-top: 7.69231vw
}

@media (min-width:768px) {
    .l-main .p-problem_item-text {
        margin-top: 20px
    }
}

.l-main .p-solution {
    background: var(--color-bg);
    border-radius: 10.25641vw 10.25641vw 0 0;
    padding: 15.38462vw 0
}

@media (min-width:768px) {
    .l-main .p-solution {
        border-radius: 40px 40px 0 0;
        padding-bottom: 100px;
        padding-top: 120px
    }
}

@media (min-width:768px) {
    .l-main .p-about-content {
        margin: 0 auto;
        max-width: 1024px
    }
}

.l-main .p-about {
    background-color: #fff;
    border-radius: 20px;
    box-shadow: 0 5px 10px #0000001a;
    display: grid;
    margin-top: 10.25641vw;
    padding: 13.33333vw 6.15385vw
}

@media (min-width:768px) {
    .l-main .p-about {
        gap: 40px;
        grid-template-columns: auto 1fr;
        margin-top: 36px;
        padding: 60px 50px
    }
}

.l-main .p-about_heading {
    font-size: 4.10256vw;
    line-height: 1.8;
    margin-top: 7.69231vw
}

@media (min-width:768px) {
    .l-main .p-about_heading {
        font-size: 2rem;
        line-height: 1.8;
        margin-top: 0
    }
}

.l-main .p-about_text {
    line-height: 2;
    margin-top: 5.12821vw
}

@media (min-width:768px) {
    .l-main .p-about_text {
        line-height: 1.8;
        margin-top: 24px
    }
}

.l-main .p-feature-content {
    margin: 20.51282vw 3.07692vw 0
}

@media (min-width:768px) {
    .l-main .p-feature-content {
        margin: 100px auto 0;
        max-width: 1024px
    }
}

.l-main .p-achievement {
    padding: 20.51282vw 0
}

@media (min-width:768px) {
    .l-main .p-achievement {
        padding: 100px 30px
    }
}

.l-main .p-achievement-img {
    margin-top: 10.25641vw;
    padding: 0 3.07692vw
}

.l-main .p-achievement-img img {
    max-width: none;
    width: 100%
}

@media (min-width:768px) {
    .l-main .p-achievement-img {
        margin: 60px auto 0;
        max-width: 1024px;
        padding: 0
    }
}

.l-main .p-usecase {
    background: var(--color-bg);
    border-radius: 10.25641vw;
    padding: 20.51282vw 3.07692vw
}

@media (min-width:768px) {
    .l-main .p-usecase {
        border-radius: 40px;
        padding: 80px 0
    }
}

@media (min-width:768px) {
    .l-main .p-usecase-content {
        margin: 0 auto;
        max-width: 1024px
    }
}

.l-main .p-usecase_box {
    display: flex;
    flex-direction: column;
    gap: 10.25641vw;
    margin-top: 10.25641vw
}

@media (min-width:768px) {
    .l-main .p-usecase_box {
        gap: 40px;
        margin-top: 60px
    }
}

.l-main .p-usecase_item {
    background: #fff;
    border-radius: 5.12821vw;
    padding: 10.25641vw 6.15385vw
}

@media (min-width:768px) {
    .l-main .p-usecase_item {
        border-radius: 20px;
        padding: 40px
    }
}

.l-main .p-usecase_item-head {
    align-items: center;
    display: flex;
    flex-direction: column;
    font-weight: 700;
    gap: 4.35897vw;
    justify-content: center
}

@media (min-width:768px) {
    .l-main .p-usecase_item-head {
        gap: 8px
    }
}

.l-main .p-usecase_item-head-number {
    background-color: var(--color-main);
    border-radius: 99px;
    color: #fff;
    line-height: 1.8;
    padding: 0 3.07692vw
}

@media (min-width:768px) {
    .l-main .p-usecase_item-head-number {
        padding: 0 12px
    }
}

.l-main .p-usecase_item-head-title {
    font-size: 5.12821vw;
    font-weight: 700;
    line-height: 1.5;
    text-align: center
}

@media (min-width:768px) {
    .l-main .p-usecase_item-head-title {
        font-size: 2.4rem;
        line-height: 1.25
    }
}

.l-main .p-usecase_item-inner {
    display: flex;
    flex-direction: column;
    gap: 5.12821vw;
    margin-top: 7.69231vw
}

@media (min-width:768px) {
    .l-main .p-usecase_item-inner {
        gap: 10px;
        margin-top: 40px
    }
}

.l-main .p-usecase_item-problem,
.l-main .p-usecase_item-solution {
    background: var(--color-bg);
    border-radius: 5.12821vw;
    display: flex;
    flex-direction: column;
    gap: 9.23077vw;
    padding: 7.69231vw 6.15385vw
}

@media (min-width:768px) {

    .l-main .p-usecase_item-problem,
    .l-main .p-usecase_item-solution {
        align-items: center;
        border-radius: 20px;
        display: grid;
        gap: 40px;
        grid-template-columns: 1fr 45%;
        padding: 30px 50px
    }
}

@media (min-width:959px) {

    .l-main .p-usecase_item-problem,
    .l-main .p-usecase_item-solution {
        grid-template-columns: 1fr auto
    }
}

.l-main .p-usecase_item-problem-text-wrap,
.l-main .p-usecase_item-solution-text-wrap {
    display: flex;
    flex-direction: column;
    gap: 4.10256vw
}

@media (min-width:768px) {

    .l-main .p-usecase_item-problem-text-wrap,
    .l-main .p-usecase_item-solution-text-wrap {
        gap: 20px
    }
}

.l-main .p-usecase_item-problem-title,
.l-main .p-usecase_item-solution-title {
    font-weight: 700;
    line-height: 1.8
}

@media (min-width:768px) {

    .l-main .p-usecase_item-problem-title,
    .l-main .p-usecase_item-solution-title {
        font-size: 2rem;
        line-height: 1.5
    }
}

.l-main .p-usecase_item-problem-text,
.l-main .p-usecase_item-solution-text {
    line-height: 1.8
}

.l-main .p-usecase_item-problem-text span,
.l-main .p-usecase_item-solution-text span {
    color: #df700f;
    font-weight: 700
}

.l-main .p-usecase_item-point {
    background: #fdffeb;
    border: 4px solid #fde493;
    border-radius: 5.12821vw;
    display: flex;
    flex-direction: column;
    font-weight: 700;
    gap: 4.10256vw;
    padding: 7.69231vw 6.15385vw
}

@media (min-width:768px) {
    .l-main .p-usecase_item-point {
        border-radius: 20px;
        gap: 20px;
        padding: 30px 50px
    }
}

.l-main .p-usecase_item-point-title {
    font-size: 5.12821vw;
    line-height: 1.5
}

@media (min-width:768px) {
    .l-main .p-usecase_item-point-title {
        font-size: 2rem
    }
}

.l-main .p-usecase_item-point-list {
    display: flex;
    flex-direction: column
}

.l-main .p-usecase_item-point-list li {
    align-items: flex-start;
    display: flex;
    gap: 1.02564vw
}

@media (min-width:768px) {
    .l-main .p-usecase_item-point-list li {
        gap: 4px
    }
}

.l-main .p-usecase_item-point-list li:before {
    content: "・";
    display: inline-block;
    font-size: inherit;
    line-height: 1.8
}

.l-main .p-usecase-cta {
    padding: 20.51282vw 3.07692vw 0
}

@media (min-width:768px) {
    .l-main .p-usecase-cta {
        padding: 100px 0 0
    }
}

.l-main .p-usecase-cta-content {
    background: var(--color-bg);
    border-radius: 5.12821vw;
    padding: 13.33333vw 9.23077vw;
    position: relative
}

@media (min-width:768px) {
    .l-main .p-usecase-cta-content {
        align-items: center;
        display: grid;
        gap: 40px;
        grid-template-columns: 1fr auto;
        margin: 0 auto;
        max-width: 1024px;
        padding: 40px 130px
    }
}

.l-main .p-usecase-cta-content div:first-child p {
    font-size: 5.12821vw;
    font-weight: 700;
    line-height: 1.5;
    text-align: center
}

@media (min-width:768px) {
    .l-main .p-usecase-cta-content div:first-child p {
        font-size: 2rem;
        text-align: left
    }
}

.l-main .p-usecase-cta-content .p-cv-button-wrap {
    margin-top: 84.10256vw
}

@media (min-width:768px) {
    .l-main .p-usecase-cta-content .p-cv-button-wrap {
        margin-top: 40px
    }
}

.l-main .p-usecase-cta-content .p-cv-button-wrap .p-cv-button {
    width: 100%
}

@media (min-width:768px) {
    .l-main .p-usecase-cta-content .p-cv-button-wrap .p-cv-button {
        min-width: 250px;
        width: auto
    }
}

.l-main .p-usecase-cta-img {
    height: 100%;
    padding: 0 12.30769vw;
    position: absolute;
    right: 0;
    top: 36%;
    width: 100%
}

@media (min-width:768px) {
    .l-main .p-usecase-cta-img {
        padding: 0;
        position: unset
    }
}

.l-main .p-reason {
    background: url(/pickup/edi/images/8689_reason_bg_sp.png) 0/100% auto no-repeat;
    padding: 20.51282vw 3.07692vw
}

@media (min-width:768px) {
    .l-main .p-reason {
        background: url(/pickup/edi/images/8689_reason_bg.png) 0/1920px auto no-repeat;
        padding-bottom: 120px;
        padding-top: 116px
    }
}

@media (min-width:768px) {
    .l-main .p-reason-content {
        margin: 0 auto;
        max-width: 1024px
    }
}

.l-main .p-reason-list {
    display: flex;
    flex-direction: column;
    gap: 15.38462vw;
    margin-top: 10.25641vw
}

@media (min-width:768px) {
    .l-main .p-reason-list {
        gap: 40px;
        margin-top: 60px
    }
}

.l-main .p-reason-item {
    align-items: center;
    display: grid;
    gap: 5.12821vw;
    justify-content: flex-start;
    list-style: none
}

.l-main .p-reason-item>:first-child {
    order: 1
}

.l-main .p-reason-item>:nth-child(2) {
    order: 2
}

@media (min-width:768px) {
    .l-main .p-reason-item {
        column-gap: 40px;
        grid-template-columns: 48.828125% 1fr
    }

    .l-main .p-reason-item>:first-child {
        order: 1
    }

    .l-main .p-reason-item>:nth-child(2) {
        order: 2
    }

    .l-main .p-reason-item.is-reverse {
        grid-template-columns: 1fr 48.828125%
    }

    .l-main .p-reason-item.is-reverse>:first-child {
        order: 2
    }

    .l-main .p-reason-item.is-reverse>:nth-child(2) {
        order: 1
    }
}

.l-main .p-reason_img {
    border-radius: 5.12821vw;
    box-shadow: 0 5px 10px #0000001a;
    overflow: hidden;
    width: 100%
}

@media (min-width:768px) {
    .l-main .p-reason_img {
        border-radius: 20px
    }
}

.l-main .p-reason_num {
    color: var(--color-main);
    font-size: 3.58974vw;
    font-weight: 700;
    line-height: 1
}

@media (min-width:768px) {
    .l-main .p-reason_num {
        font-size: 1.6rem
    }
}

.l-main .p-reason_heading {
    font-size: 5.12821vw;
    font-weight: 700;
    line-height: 1.5;
    margin-top: 1.53846vw
}

@media (min-width:768px) {
    .l-main .p-reason_heading {
        font-size: 2rem;
        margin-top: 10px
    }
}

.l-main .p-reason_text {
    line-height: 1.8;
    margin-top: 4.10256vw
}

@media (min-width:768px) {
    .l-main .p-reason_text {
        margin-top: 20px
    }
}

.l-main .p-reason_text.is-small {
    font-size: 3.58974vw
}

@media (min-width:768px) {
    .l-main .p-reason_text.is-small {
        font-size: 1.4rem
    }
}

.l-main .p-reason_link {
    color: #000 !important;
    line-height: 1.8;
    margin-top: 3.07692vw;
    position: relative;
    text-decoration: underline
}

@media (min-width:768px) {
    .l-main .p-reason_link {
        margin-top: 12px
    }
}

.l-main .p-reason_link:after {
    content: url(/pickup/edi/images/8689_link_arrow.svg);
    display: inline-block;
    height: 20px;
    margin-left: 10px;
    position: relative;
    top: 3px;
    vertical-align: initial;
    width: 20px
}

.l-main .p-summary {
    padding: 20.51282vw 3.07692vw 0
}

@media (min-width:768px) {
    .l-main .p-summary {
        padding: 100px 0 0
    }
}

@media (min-width:768px) {
    .l-main .p-summary-content {
        margin: 0 auto;
        max-width: 1024px
    }
}

.l-main .p-summary-content .p-inner {
    padding-bottom: 95vw;
    position: relative
}

@media (min-width:768px) {
    .l-main .p-summary-content .p-inner {
        padding-bottom: 0
    }
}

.l-main .p-summary-lead {
    margin-top: 10.25641vw
}

@media (min-width:768px) {
    .l-main .p-summary-lead {
        margin: 36px auto 0;
        max-width: 800px
    }
}

.l-main .p-summary-img {
    margin-top: 10.25641vw;
    overflow-x: scroll
}

@media (min-width:768px) {
    .l-main .p-summary-img {
        margin-top: 60px;
        overflow-x: auto
    }
}

@media (max-width:767px) {
    .l-main .p-summary-img {
        position: absolute;
        z-index: 2
    }

    .l-main .p-summary-img img {
        max-width: 200%;
        width: 250%
    }
}

.l-main .p-faq {
    padding: 20.51282vw 3.07692vw
}

@media (min-width:768px) {
    .l-main .p-faq {
        padding-bottom: 120px;
        padding-top: 116px
    }
}

@media (min-width:768px) {
    .l-main .p-faq-content {
        margin: 0 auto;
        max-width: 1000px
    }
}

.l-main .p-faq-list {
    display: grid;
    margin-top: 60px
}

.l-main .p-faq-list>li {
    border-top: 1px solid #e5e5e5
}

.l-main .p-faq-list>li:last-child {
    border-bottom: 1px solid #e5e5e5
}

.l-main .p-faq-list>li:has(.is-open) {
    border: none;
    border-radius: 2.05128vw;
    box-shadow: 0 3px 10px #0000001a;
    margin-bottom: 2.5641vw
}

@media (min-width:768px) {
    .l-main .p-faq-list>li:has(.is-open) {
        border-radius: 8px;
        box-shadow: 0 3px 8px #0000001a;
        margin-bottom: 10px
    }
}

.l-main .p-faq-item dt {
    cursor: pointer;
    position: relative
}

.l-main .p-faq-item dt button {
    display: flex;
    line-height: 2;
    padding: 5.12821vw 11.79487vw 5.12821vw 3.07692vw;
    width: 100%
}

.l-main .p-faq-item dt button svg {
    background-color: hsla(0, 0%, 100%, .502);
    background-size: contain;
    border-radius: 9999px;
    content: "";
    height: 5.64103vw;
    position: absolute;
    right: 3.07692vw;
    top: 9.23077vw;
    transform: translateY(-50%);
    width: 5.64103vw
}

.l-main .p-faq-item dt button svg path {
    transform-origin: center
}

.l-main .p-faq-item dt button svg path:nth-child(2) {
    transform: rotate(90deg);
    transition: transform .3s ease-out
}

.l-main .p-faq-item dt button.is-open svg path:first-child {
    fill: #000
}

.l-main .p-faq-item dt button.is-open svg path:nth-child(2) {
    transform: rotate(0)
}

.l-main .p-faq-item dt>* {
    display: block;
    font-size: 1rem;
    font-weight: 700
}

@media (min-width:768px) {
    .l-main .p-faq-item dt>* {
        font-size: 1.125rem
    }

    .l-main .p-faq-item dt button {
        padding: 40px 20px 40px 18px
    }

    .l-main .p-faq-item dt button svg {
        height: 26px;
        right: 42px;
        top: 50%;
        width: 26px
    }

    .l-main .p-faq-item dt button.is-open {
        padding-bottom: 32px
    }
}

.l-main .p-faq-a-text,
.l-main .p-faq-q-text {
    margin-right: 3.33333vw
}

@media (min-width:768px) {

    .l-main .p-faq-a-text,
    .l-main .p-faq-q-text {
        margin-right: 2rem
    }
}

.l-main .p-faq-a-text {
    color: var(--color-main);
    font-weight: 700;
    margin-left: .20513vw
}

@media (min-width:768px) {
    .l-main .p-faq-a-text {
        margin-left: 2px
    }
}

.l-main .p-faq-a-text_ans>ul>li {
    list-style-type: disc;
    margin-left: 5.12821vw
}

.l-main .p-faq-a-text_ans>ul>li>ul>li {
    display: flex;
    gap: 2.05128vw
}

.l-main .p-faq-a-text_ans>ul>li>ul>li:before {
    content: "-"
}

.l-main .p-faq-a-text_ans>ol>li {
    list-style-position: outside;
    margin-left: 5.12821vw
}

@media (min-width:768px) {
    .l-main .p-faq-a-text_ans>ul>li {
        margin-left: 24px
    }

    .l-main .p-faq-a-text_ans>ul>li>ul>li {
        gap: 10px
    }

    .l-main .p-faq-a-text_ans>ol>li {
        margin-left: 24px
    }
}

.l-main .p-faq-item dd {
    display: none
}

.l-main .p-faq-item dd>* {
    display: flex;
    padding: 0 12.82051vw 5.12821vw 3.07692vw
}

@media (min-width:768px) {
    .l-main .p-faq-item dd>* {
        padding: 0 60px 32px 17px
    }
}

.l-main .modal-overlay {
    padding: 0 3.07692vw;
    z-index: calc(infinity)
}

@media (min-width:768px) {
    .l-main .modal-overlay {
        padding: 0
    }
}

.l-main .modal-box {
    position: relative
}

.l-main .p-modal-content {
    background-color: #f4fbff;
    border-radius: 5.12821vw;
    max-height: calc(100vh - 25.64103vw);
    overflow-y: auto;
    padding: 15.38462vw 3.07692vw
}

@media (min-width:768px) {
    .l-main .p-modal-content {
        border-radius: 20px;
        max-height: 800px;
        padding: 80px 40px
    }
}

.l-main .p-modal-heading {
    font-weight: 700;
    line-height: 1.5;
    text-align: center
}

.l-main .p-modal-heading p {
    font-size: 5.12821vw
}

@media (min-width:768px) {
    .l-main .p-modal-heading p {
        font-size: 2.8rem;
        line-height: 1
    }
}

.l-main .p-modal-card_wrap {
    display: flex;
    flex-flow: column wrap;
    gap: 5.12821vw;
    justify-content: center;
    margin-top: 6.15385vw
}

@media (min-width:768px) {
    .l-main .p-modal-card_wrap {
        gap: 32px;
        margin-top: 60px
    }
}

.l-main .p-modal-card {
    border-radius: 2.05128vw;
    box-shadow: 0 5px 10px #0000001a;
    overflow: hidden
}

@media (min-width:768px) {
    .l-main .p-modal-card {
        border-radius: 8px
    }
}

.l-main .p-modal-card_head {
    background-color: var(--color-main);
    color: #fff;
    font-weight: 700;
    line-height: 1;
    padding: 4.10256vw 0;
    text-align: center
}

.l-main .p-modal-card_head p {
    font-size: 5.12821vw
}

@media (min-width:768px) {
    .l-main .p-modal-card_head {
        padding: 16px 0
    }

    .l-main .p-modal-card_head p {
        font-size: 2rem
    }
}

.l-main .p-modal-card_body {
    background-color: #fff;
    padding: 5.12821vw 4.10256vw
}

@media (min-width:768px) {
    .l-main .p-modal-card_body {
        padding: 32px
    }
}

.l-main .p-modal-card_list {
    display: flex;
    flex-direction: column;
    gap: 5.12821vw
}

.l-main .p-modal-card_list li {
    line-height: 1;
    list-style-type: disc;
    margin-left: 5.12821vw
}

@media (min-width:768px) {
    .l-main .p-modal-card_list {
        display: grid;
        gap: 24px 60px;
        grid-template-columns: repeat(3, auto)
    }

    .l-main .p-modal-card_list li {
        line-height: 1;
        margin-left: 18px
    }
}

.l-main .modal-close {
    position: absolute;
    right: 6.15385vw;
    top: 6.15385vw
}

@media (min-width:768px) {
    .l-main .modal-close {
        right: 24px;
        top: 24px
    }
}

.l-main .p-floating-cv {
    display: none;
    display: block;
    position: fixed;
    right: 0;
    top: 24%;
    z-index: 1000
}

.l-main .p-floating-cv .p-wrap {
    padding: 0
}

.l-main .p-floating-cv .p-cv-button-wrap {
    align-items: center;
    flex-direction: row;
    gap: 8px;
    justify-content: center;
    margin-top: 0;
    writing-mode: vertical-rl
}

.l-main .p-floating-cv .p-cv-button {
    min-height: 190px;
    min-width: 0
}

.l-main .p-floating-cv .p-cv-button a {
    border-radius: 20px 0 0 20px;
    height: 100%
}

.l-main .p-floating-cv .p-cv-button a:after {
    border-radius: 20px 0 0 20px
}

.l-main .p-floating-cv .p-cv-button a span {
    font-size: 1.6rem;
    padding: 0 26px
}

@media (max-width:767px) {
    .l-main .p-floating-cv {
        display: none
    }
}

@media(max-width: 800px) {

    #mainColumn section img,
    img {
        max-width: 100%;
        height: auto;
        width: auto;
    }
}