@charset "UTF-8";

@media screen and (max-width: 560px) {
    .iframe-responsive {
        position: relative;
        width: 100%;
        padding: calc(315 / 560 * 100%) 0 0 ;
    }
    .iframe-responsive iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }
}

.iframe-responsive {
    text-align: center;
    border: 1em lightgray;
}



.service {
    background-image: url("../img/DCX-Banner-02.webp");
}

.desc {
    position: relative;
    padding: 15% 5% 15%;
    text-align: center;
}

.servicePricing {
    padding: 0 5% 15%;
    text-align: center;
}
.servicePricing img {
    position: relative;
    width: 80%;
    margin: 30px auto auto;
}

.menu {
    position: relative;
    padding: 0 5% 10%;
    text-align: center;
}
.menu > label {
    position: relative;
    margin: 50px auto 20px;
    color: #ccc;
    font-size: 15px;
    letter-spacing: 0.1em;
    display: block;
}
.menu > label span {
    position: relative;
    margin-top: 10px;
    padding: 5px 20px;
    color: #fff;
    border-radius: 50px;
    background-color: #666699;
    display: inline-block;
}
.menu > div {
    position: relative;
    width: 47%;
    margin: auto 1.1% 4%;
    padding: 25% 5% 5%;
    font-size: 14px;
    color: #363f75;
    font-weight: bold;
    align-self: end;
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    background-size: 50% auto;
    background-position: center 25%;
    background-repeat: no-repeat;
    display: inline-block;
}
.menu > div:nth-of-type(1) {
    background-image: url("../img/menu-main-img-01.png");
}
.menu > div:nth-of-type(2) {
    background-image: url("../img/menu-main-img-02.png");
}
.menu > div:nth-of-type(3) {
    background-image: url("../img/menu-main-img-03.png");
}
.menu > div:nth-of-type(4) {
    background-image: url("../img/menu-main-img-04.png");
}
.menu > div:nth-of-type(5) {
    background-image: url("../img/menu-main-img-05.png");
}
.menu > div:nth-of-type(6) {
    background-image: url("../img/menu-option-img-01.png");
}
.menu > div:nth-of-type(7) {
    background-image: url("../img/menu-option-img-02.png");
}
.menu > div:nth-of-type(8) {
    background-image: url("../img/menu-option-img-03.png");
}
.menu > div:nth-of-type(9) {
    background-image: url("../img/menu-option-img-04.png");
}
.menu > div:nth-of-type(10) {
    background-image: url("../img/menu-option-img-05.png");
}

.shopify {
    padding: 0 5% 15%;
    text-align: center;
}
.shopify img {
    position: relative;
    margin: 30px auto auto;
}

.flow > div {
    position: relative;
    width: 100%;
    margin: auto auto 5%;
    padding: 5%;
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    background-size: 30% auto;
    background-position: 86% 82%;
    background-repeat: no-repeat;
    display: inline-block;
}
.flow > div:nth-of-type(1) {
    background-image: url("../img/flow-img-01.png");
}
.flow > div:nth-of-type(2) {
    background-image: url("../img/flow-img-02.png");
}
.flow > div:nth-of-type(3) {
    background-image: url("../img/flow-img-03.png");
}
.flow > div:nth-of-type(4) {
    background-image: url("../img/flow-img-04.png");
}
.flow > div h3 {
    position: relative;
    width: 100%;
    margin: 2% auto 3%;
    padding: 5px 0;
    text-align: center;
    font-size: 4vw;
    background-color: #363f75;
    color: #fff;
    border-radius: 50px;
    font-weight: bold;
    letter-spacing: 0.1em;
}
.flow > div p {
    position: relative;
    width: 55%;
    margin: 13% 0 5% 5%;
    align-self: center;
    font-size: 3.5vw;
    line-height: 1.5em;
    text-align: left;
}

.peace {
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
}
.peace > figure {
    position: relative;
    width: 100%;
    margin: auto auto 5%;
    padding: 30px;
}
.peace > figure img {
    position: relative;
    width: 100%;
}
.peace > figure p {
    position: relative;
    width: 248px;
    margin: 10px auto auto;
    font-size: 4vw;
    line-height: 1.5em;
}
.peace > img {
    position: relative;
    width: 50%;
    margin: auto auto 5%;
    padding: 3px;
}
.peace > figure:first-of-type, .peace > img:first-of-type {
    margin-top: 20px;
}

.price {
    background-image: url("../img/DCX-Banner-05-reverse.webp");
}

.priceDetails {
    text-align: center;
}
.priceDetails h3 {
    position: relative;
    margin-top: 50px;
    padding: 5px 20px;
    background-color: #666699;
    color: #fff;
    border-radius: 50px;
    display: inline-block;
}
.priceDetails > div {
    position: relative;
    white-space: nowrap;
    overflow-x: auto;
}
.priceDetails table th {
    position: relative;
    min-width: 10ch;
    padding: 10px 0;
    font-size: 10px;
    line-height: 1em;
    font-weight: normal;
    vertical-align: middle;
    color: #FFF;
    background: #666699;
    border-bottom: solid 1px #FFF;
    border-right: solid 1px #FFF;
}
.priceDetails table th span, .priceDetails table td span {
    position: relative;
    font-size: 10px;
}
.priceDetails table td {
    position: relative;
    padding: 10px 0;
    font-size: 10px;
    background: #fff;
    vertical-align: middle;
    border-bottom: 1px solid #ccc;
    border-right: 1px solid #ccc;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;
}
.priceDetails table td:first-child {
    min-width: 14.3ch;
    font-size: 10px;
    font-weight: bold;
    border-left: 1px solid #ccc;
}
.priceDetails > small {
    position: relative;
    margin: 20px auto auto;
    font-size: 13px;
    line-height: 1.5em;
    text-align: left;
    display: block;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;
}

.functions {
    background-image: url("../img/DCX-Banner-03.webp");
}

.functionsDetails {
    text-align: center;
}
.functionsDetails p {
    letter-spacing: 0.05em;
}
.functionsDetails > div {
    position: relative;
    width: 100%;
    margin: 50px auto;
    padding: 15px 15px;
    border-radius: 10px;
    background-color: #666699;
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.5);
    overflow: hidden;
}
.functionsDetails > div input {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    visibility: hidden;
    display: none;
}
.functionsDetails > div label {
    position: relative;
    padding: 15px 15px 15px 18%;
    color: #FFF;
    text-align: left;
    background-size: 12% auto;
    background-position: 3% center;
    background-repeat: no-repeat;
    display: block;
    cursor: pointer;
    cursor: hand;
}
.functionsDetails > div label:hover {
    background-color: rgba(0, 0, 0, 0.1);
}
.functionsDetails > div label::after {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 15px;
    width: 16px;
    height: 8px;
    background-image: url('data:image/svg+xml;utf8,<svg width="100" height="50" xmlns="http://www.w3.org/2000/svg"><polygon points="0,0 100,0 50,50" style="fill:%23fff;" /></svg>');
    background-size: contain;
    transition: transform 0.4s;
}
.functionsDetails > div input:checked + label::after {
    transform: translateY(-50%) rotate(0.5turn);
}
.functionsDetails > div label.warehousing { background-image: url("../img/1-ICON-arrival.png"); }
.functionsDetails > div label.shipping { background-image: url("../img/2-ICON-Shipment.png"); }
.functionsDetails > div label.stock { background-image: url("../img/3-ICON-Stock.png"); }
.functionsDetails > div label.others { background-image: url("../img/4-ICON-Setting.png"); }
.functionsDetails > div label p:first-child {
    position: relative;
    margin: auto auto 3px;
    color: #FFF;
    font-size: 4vw;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.functionsDetails > div label p:first-child span {
    position: relative;
    margin-left: 10px;
    font-size: 0.7em;
    letter-spacing: 0.1em;
    color: #ccc;
}
.functionsDetails > div label p:last-child {
    position: relative;
    margin: auto 40px auto auto;
    font-size: 3.5vw;
    line-height: 1.5em;
}
.functionsDetails > div > div div {
    position: relative;
    max-height: 0;
    padding: 0 20px;
    font-size: 14px;
    line-height: 1.6em;
    text-align: left;
    background: #FFF;
    overflow: hidden;
    transition: max-height 0.15s ease-in;
}
.functionsDetails > div input:checked ~ div {
    max-height: 800px;
}
.functionsDetails > div > div div h3 {
    position: relative;
    margin: 25px auto auto;
    font-size: 4vw;
    color: #363f75;
    letter-spacing: 0px;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;
}
.functionsDetails > div > div div h3:first-of-type {
    margin-top: 35px;
}
.functionsDetails > div > div div p {
    position: relative;
    margin: 3px auto 25px;
    font-size: 15px;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;
}
.functionsDetails > div > div div p:last-of-type {
    margin-bottom: 35px;
}

.faq {
    background-image: url("../img/DCX-Banner-04.webp");
}

.faqDetails {
    text-align: center;
}
.faqDetails > h3 {
    position: relative;
    margin: auto;
    padding-top: 20px;
    color: #363f75;
    font-size: 18px;
    text-align: left;
}
.faqDetails > p {
    margin: auto;
    padding: 5px 0 15px;
    line-height: 1.6em;
    text-align: left;
}
.faqDetails > ul {
    position: relative;
    text-align: left;
}
.faqDetails > ul li {
    line-height: 1.6em;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;
}

@media only screen and (min-width: 768px) {
    .headline img {
        width: 90%;
    }

    .desc {
        padding: 100px 2.5% 100px;
    }

    .servicePricing {
        padding: 0 2.5% 100px;
    }
    .servicePricing img {
        width: auto;
        margin-top: 30px;
    }

    .menu > label {
        font-size: 14px;
    }
    .menu > div {
        width: 18%;
        margin: auto 0.8%;
        padding: 16% 30px 30px;
        background-size: 80% auto;
    }

    .shopify {
        padding: 0 2.5% 5%;
    }
    .shopify img {
        width: 48%;
    }

    .flow {
        text-align: center;
    }
    .flow > div {
        width: 23%;
        margin: 50px 0.4% auto;
        padding: 30px 15px 19%;
        background-size: 80% auto;
        background-position: center 80%;
        display: inline-block;
    }
    .flow > div h3 {
        width: auto;
        padding: 3px 20px;
        font-size: 14px;
        display: inline-block;
    }
    .flow > div p {
        width: auto;
        margin: 5px auto auto;
        font-size: 14px;
        text-align: center;
    }

    .peace > figure {
        width: 31%;
        margin: 0px auto;
    }
    .peace > figure p {
        margin: 5px auto auto;
        font-size: 14px;
    }
    .peace > img {
        width: 25%;
        margin: auto;
    }
    .peace > img:first-of-type {
        margin-top: auto;
    }

    .priceDetails > div {
        white-space: normal;
        overflow-x: initial;
    }
    .priceDetails table {
        width: 100%;
    }
    .priceDetails table th {
        min-width: 0;
        font-size: 14px;
    }
    .priceDetails table td:first-child {
        font-size: 14px;
    }
    .priceDetails table td {
        font-size: 14px;
    }

    .functionsDetails > div {
        width: 90%;
    }
    .functionsDetails > div label {
        padding: 15px 15px 15px 15%;
        background-size: 9% auto;
    }
    .functionsDetails > div label p:first-child {
        font-size: 20px;
    }
    .functionsDetails > div label p:last-child {
        margin-right: 40px;
        font-size: 14px;
    }
    .functionsDetails > div > div div {
        padding: 0 40px;
    }
    .functionsDetails > div input:checked ~ div {
        max-height: 600px;
    }
    .functionsDetails > div > div div h3 {
        width: 26%;
        font-size: 16px;
        display: inline-block;
        vertical-align: sub;
    }
    .functionsDetails > div > div div h3:first-of-type {
        margin-top: 45px;
    }
    .functionsDetails > div > div div p {
        width: 72%;
        margin: auto;
        padding-left: 20px;
        font-size: 100%;
        display: inline-block;
        vertical-align: text-top;
    }
    .functionsDetails > div > div div p:last-of-type {
        margin-bottom: 45px;
    }
}

@media only screen and (min-width: 1201px) {
    .headline img {
        margin-top: 30px;
    }

    .desc {
        padding: 100px calc((100% - 1200px) / 2) 100px;
    }

    .servicePricing {
        padding: 0 calc((100% - 1200px) / 2) 100px;
    }

    .menu > div {
        max-width: 215px;
        padding: 14% 30px 30px;
    }

    .shopify {
        padding: 0 calc((100% - 1200px) / 2) 100px;
    }
    .shopify > p {
        font-size: 17px;
    }

    .flow {
        text-align: center;
    }
    .flow > div {
        width: 22%;
        margin: 50px 0.8% auto;
    }
    .flow > div p {
        font-size: 14px;
    }

    .priceDetails table {
        width: 1200px;
    }
    .priceDetails > small {
        font-size: 14px;
    }

    .functionsDetails > div {
        width: 70%;
    }
    .functionsDetails > div label {
        background-size: 11% auto;
        background-position: 2% center;
    }

    .faqDetails > h3 {
        font-size: 17px;
    }
}
