@charset "utf-8";

section {
    max-width: 2040px;
}

.main {
    max-width: 2200px
}

.item-num {
    white-space: nowrap;
}

.pack-img {
    text-align: center;
}

.cont-ttl {
    height: initial;
}

.pack_container_wrap .webp-txt {
    bottom: -8px;
    background: #f2f0ecbf;
    padding: 2px 4px 2px 2px;
}

@media (max-width: 1280px) {
    .contpack-list {
        grid-template-columns: 1fr 1fr 1fr;
    }
}

@media (max-width: 1100px) {
    .contpack-list {
        grid-template-columns: 1fr 1fr 1fr;
    }

    .main {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .contpack-list {
        gap: 46px 15px;
    }

    .new {
        top: -14px;
        right: -11px;
    }

    .new img {
        width: 75%;
    }

    .pickup {
        top: -27px;
        left: -8px;
    }

    .pickup img {
        width: 70%;
    }
}

@media (max-width: 1024px) {
    .main {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .pack-item {
        max-width: 70px;
    }

    .new {
        top: -4px;
        right: -20px;
    }

    .new img {
        width: 54%;
    }

    .pickup {
        top: -5px;
        left: -3px;
    }

    .pickup img {
        width: 46%;
    }

    .contpack-list li a {
        display: block;
    }

    .pack-img {
        text-align: center;
    }

    .pack_container img,
    .pack_container img a {
        width: 60%;
    }

    .webp-txt.tsumini {
        position: absolute;
        justify-content: flex-end;
        margin: 0;
        bottom: 0px;
        padding: 4px 4px;
    }

    .lower_cont-wrap.tsumini .cont-ttl {
        font-size: 1rem;
        height: 23px;
    }

    .reset-container {
        height: 48px;
    }

    .deadline,
    .subscription,
    .reset {
        max-width: 18rem;
        font-size: 1.0rem;
    }

    .lower_cont-wrap.tsumini {
        padding: 1.0rem 0.8rem 4rem 0.8rem;
        min-height: 205px;
    }

    .container-pack[data-category~="activated"] .lower_cont-wrap.tsumini {
        padding: 1.0rem 0.8rem 1rem 0.8rem;
    }

    .activated-cont p {
        font-size: 1.0rem;
    }

    .activated-img {
        width: 10px;
    }

    .duration {
        font-size: 1.0rem;
    }

    .container-pack {
        margin-bottom: 5px;
    }

    .contpack-list {
        gap: 1rem;
    }

    .numttl {
        font-size: 1.0rem;
    }

    .numttl {
        border-left: 4px solid #333;
        padding: 0 4px;
    }

    .num-purchases {
        font-size: 1.0rem;
    }

    .corner {
        width: 14px;
        height: 15px;
    }

    .lower_cont-wrap.tsumini .price-tag.cart {
        font-size: 1.0rem;
    }

    .container-pack .add-cart {
        height: 36px;
        width: 81%;
        right: 9%;
        bottom: 16px;
    }

    .container-pack .add-cart button {
        font-size: 1.0rem;
    }

    .pack-img-wrap {
        padding-top: 0rem;
    }

    .item {
        gap: 2px;
        height: initial;
    }

    .item div .item-num {
        font-size: 0.7rem;
        margin-top: 0px;
    }

    .remainin {
        margin: 4px 0 2px 0;
    }

    .pack_container_wrap {
        padding-bottom: 0.5rem;
    }

    .pack_container .webp-txt img {
        width: 23px;
        height: auto;
    }

    .webp-txt.tsumini span {
        font-size: 1.0rem;
    }

    .txt-bold {
        font-size: 0.7rem;
    }

    .pack-line img {
        width: 56%;
        display: block;
    }

    .pack-img-wrap.pack-super .pack-img::after {
        width: 54px;
        height: 37px;
        top: 0px;
    }

    .pack-img-wrap.pack-super::before {
        width: 54px;
        height: 47px;
        bottom: -8px;
        left: -23px;
    }

    .pack-img-wrap.pack-super::after {
        width: 41px;
        height: 36px;
        top: 0px;
        right: -10px;
    }

    .item div img {
        width: 77%;
    }

    .item div img.bun-icon {
        width: 46%;
        max-width: 32px;
        top: 12px;
    }

    .container-pack .add-cart button::before,
    .container-pack .add-cart button::after {
        width: 13px;
        height: 31px;
    }
}


@media (max-width: 900px) {
    .item {
        column-gap: 0%;
    }
}


@media (max-width: 768px) {
    .main {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .sec-ttl {
        font-size: 2.0rem;
    }

    .new {
        top: -4px;
        right: -31px;
    }

    .new img {
        width: 31%;
    }

    .pickup {
        top: -5px;
        left: -3px;
    }

    .pickup img {
        width: 42%;
    }

    .selectbox-3 select {
        font-size: 1.1rem;
        height: 22px;
    }

    #sort-select {
        font-size: 10px;
    }

    .contpack-list li a {
        display: block;
    }

    .pack-img {
        text-align: center;
    }

    .pack_container img,
    .pack_container img a {
        width: 42%;
    }

    .webp-txt.tsumini {
        position: absolute;
        justify-content: center;
        padding: 0 0;
        width: 6rem;
    }

    .lower_cont-wrap.tsumini .cont-ttl {
        font-size: 1rem;
        height: 23px;
    }

    .cont-ttl {
        font-size: 1.5rem;
    }

    .reset-container {
        height: 24px;
    }

    .deadline,
    .subscription,
    .reset {
        max-width: 18rem;
        font-size: 1.0rem;
    }

    .lower_cont-wrap.tsumini {
        padding: 1.0rem 0.8rem 4rem 0.8rem;
        min-height: 117px;
    }

    .container-pack[data-category~="activated"] .lower_cont-wrap.tsumini {
        padding: 1.0rem 0.8rem 1rem 0.8rem;
    }

    .activated-cont p {
        font-size: 1.0rem;
    }

    .activated-img {
        width: 10px;
    }

    .duration {
        font-size: 1.0rem;
    }

    .container-pack {
        margin-bottom: 5px;
    }

    .contpack-list {
        gap: 1rem;
    }

    .numttl {
        font-size: 1.0rem;
    }

    .numttl {
        border-left: 4px solid #333;
        padding: 0 4px;
    }

    .num-purchases {
        font-size: 1.0rem;
    }

    .corner {
        width: 14px;
        height: 15px;
    }

    .lower_cont-wrap.tsumini .price-tag.cart {
        font-size: 1.0rem;
    }

    .container-pack .add-cart {
        height: 20px;
        width: 81%;
        right: 9%;
        bottom: 8px;
    }

    .container-pack .add-cart button {
        font-size: 1.0rem;
    }

    .pack-img-wrap {
        padding-top: 0rem;
    }

    .item {
        gap: 1px;
    }

    .item div .item-num {
        font-size: 0.8rem;
        margin-top: 0px;
    }

    .remainin {
        margin: 4px 0 2px 0;
    }

    .pack_container_wrap {
        padding-bottom: 0.5rem;
    }

    .webp-txt span {
        font-size: 1.5rem;
    }

    .pack_container .webp-txt img {
        width: 9px;
        height: auto;
    }

    .webp-txt.tsumini span {
        font-size: 1.0rem;
    }

    .txt-bold {
        font-size: 0.9rem;
    }

    .pack-line img {
        width: 56%;
        display: block;
    }

    .pack-img-wrap.pack-super .pack-img::after {
        width: 54px;
        height: 37px;
        top: 0px;
    }

    .pack-img-wrap.pack-super::before {
        width: 54px;
        height: 47px;
        bottom: -8px;
        left: -23px;
    }

    .pack-img-wrap.pack-super::after {
        width: 41px;
        height: 36px;
        top: 0px;
        right: -10px;
    }

    .item div img {
        width: 77%;
    }

    .item div img.bun-icon {
        width: 46%;
        max-width: 24px;
        top: 6px;
    }

    .container-pack .add-cart button::before,
    .container-pack .add-cart button::after {
        width: 6px;
        height: 16px;
    }

    .warning .sec-ttl {
        font-size: 2.5rem;
    }

    .content-txt {
        height: 70px;
    }

    .cart-container.foot {
        padding: 8px 2rem;
    }

}

@media (max-width: 475px) {

    .item div img.bun-icon {
        width: 45%;
        top: 6px;
    }

    .reset-container {
       align-items: center;
    }

    .deadline, .subscription {
       padding: 0 0px;
    }

    .deadline,
    .subscription,
    .reset {
        max-width: initial;
        width: 100%;
    }

    .contpack-list {
        grid-template-columns: 1fr 1fr;
    }

    .lower_cont-wrap.tsumini .cont-ttl {
        font-size: 1.2rem;
        height: 30px;
    }

}