.all_item {
    position: relative;
    z-index: 1;
}
.all_item_object1 {
    width: 404px;
    bottom: -220px;
    left: 0;
    z-index: -1;
}

.all_item_container_wrap {
    background: #fff;
    padding: 155px 30px 100px;
    border-radius: 0 0 100px 100px;
    margin-top: -50px;
}

.all_item_container {
    max-width: 1100px;
    margin: 50px auto 0;
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}

.all_item_content {
    width: calc((100% - 60px) / 3);
    display: flex;
    flex-direction: column;
    gap: 20px;
    background: var(--light-gray);
    padding: 20px 10px;
    border-radius: 20px;
}
.all_item_head {
    display: flex;
    align-items: center;
    gap: 10px;
}
.all_item_head_inner {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.all_item_head_num {
    width: 50px;
    aspect-ratio: 1;
    flex-shrink: 0;
    font-size: 20px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
}
.all_item_head_sub {
    font-size: 13px;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.all_item_head_main {
    font-size: 15px;
    font-weight: bold;
    letter-spacing: 0.05em;
    line-height: 1.3;
}
.all_item_tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: -8px;
    margin-bottom: -8px;
}
.all_item_tag {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: bold;
    letter-spacing: 0.05em;
    line-height: 1.2;
}

.all_item_swiper {
    width: 100%;
}
.all_item_swiper img {
    width: 100%;
    height: auto;
    display: block;
}
.all_item_swiper .swiper-button-prev,
.all_item_swiper .swiper-button-next {
    border: 1px solid var(--accent-green);
    border-radius: 50%;
    width: 30px;
    height: 30px;
    top: unset;
    bottom: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent-green);
    background: #fff;
}
.all_item_swiper .swiper-button-next:after,
.all_item_swiper .swiper-button-prev:after {
    content: "";
    display: block;
    width: 7px;
    height: 12px;
    background: url(../../img/swiper_toggle.svg)no-repeat center center/ contain;
    position: relative;
    left: 1px;
}
.all_item_swiper .swiper-button-prev:after {
    transform: rotate(180deg);
    left: unset;
    right: 1px;
}

.all_item_size_tabs {
    width: 100%;
    display: flex;
}
.all_item_size_tabs_inner {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border: 0;
    border-radius: 3px 10px 0 0;
    gap: 8px;
    padding: 5px 0;
    color: inherit;
    font: inherit;
    cursor: pointer;
    appearance: none;
}
.all_item_size_tabs_inner.active {
    background: var(--gray);
}
.all_item_size_tabs_text {
    font-size: 10px;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.all_item_size_tabs_mark {
    min-width: 20px;
    aspect-ratio: 1;
    flex-shrink: 0;
    background: var(--accent-green);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 500;
}

.all_item_size_content {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: var(--gray);
    padding: 10px;
    border-radius: 0 0 3px 3px;
}
.all_item_size--no-tabs .all_item_size_content {
    border-radius: 3px 10px 3px 3px;
}
.all_item_size_content_item {
    display: none;
    align-items: center;
    gap: 10px;
}
.all_item_size_content_item.active {
    display: flex;
}
.all_item_size_content_inner {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.all_item_size_content_title {
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.all_item_size_content_text {
    font-size: 10px;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.all_item_size_content .components_btn {
    padding: 4px 8px 4px 14px;
    border: 1px solid var(--color-text);
}
.all_item_size_content .components_btn_line {
    height: 10px;
    margin: 0 3px 0 10px;
}
.all_item_size_content .components_btn_text {
    font-size: 10px;
}
.all_item_size_content .components_btn_icon {
    width: 9px;
}

.all_item_info {
    width: 100%;
}
.all_item_info_inner {
    display: flex;
    border: 1px solid var(--gray);
    margin-top: -1px;
}
.all_item_info_inner:nth-of-type(1) {
    border-radius: 3px 3px 0 0;
}
.all_item_info_inner:nth-of-type(2) {
    border-radius: 0 0 3px 3px;
}
.all_item_info_title {
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 0.05em;
    border-right: 1px solid var(--gray);
    padding: 10px 6px;
    text-align: center;
    flex-grow: 1;
    line-height: 1.2;
}
.all_item_info_title_small {
    font-size: 10px;
}
.all_item_info_text {
    width: clamp(100px, calc((100vw / 1440) * 106), 106px);
    flex-shrink: 0;
    font-size: 15px;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
}
.all_item_info_text_yen {
    font-family: 'Zen Kaku Gothic New', sans-serif;
    margin-right: 1px;
}
.all_item_info_text_unit {
    font-size: 8px;
    font-family: 'Zen Kaku Gothic New', sans-serif;
}

.all_item_order_btn.all_item_order_btn {
    margin: 0 auto 0;
    padding: 8px 13px 8px 28px;
}
.all_item_order_btn .components_btn_line {
    height: 25px;
    margin: 0 8px 0 20px;
}
.all_item_order_btn .components_btn_text {
    font-size: 16px;
}

@media screen and (max-width: 1024px) {
    .all_item {
        margin-top: -25px;
    }
    .all_item_container {
        gap: 20px;
    }
    .all_item_content {
        width: calc((100% - 40px) / 3);
    }
}

@media screen and (max-width: 959px) {
    .all_item_object1 {
        width: 270px;
        bottom: -160px;
    }
    .all_item_container {
        max-width: calc(330px * 2 + 30px);
        margin: 50px auto 0;
    }
    .all_item_content {
        width: calc((100% - 30px) / 2);
        max-width: 330px;
    }
}

@media screen and (max-width: 767px) {
    .all_item {
        margin-top: clamp(-80px, -10vw, -65px);
    }
    .all_item_object1 {
        width: 200px;
        bottom: -120px;
    }
    .all_item_container {
        max-width: 400px;
        margin: 30px auto 0;
        flex-direction: column;
        gap: 30px;
    }
    .all_item_content {
        width: 100%;
        max-width: none;
    }
    .all_item_order_btn.all_item_order_btn {
        padding: 8px 13px 8px 28px;
    }
    .all_item_order_btn.all_item_order_btn .components_btn_icon {
        width: 18px;
    }
}