@charset "utf-8";

/*==================================================
icon
================================================== */
:root {

    --icon-arrow-down: url("data:image/svg+xml,%3Csvg%20id%3D%22_Layer_2%22%20data-name%3D%22Layer_2%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2024%2015%22%3E%3Cpolygon%20fill%3D%22currentColor%22%20points%3D%2220.8%200%2012%208.6%203.2%200%200%203.2%208.6%2012%2012%2015%2015.4%2012%2024%203.2%2020.8%200%22%2F%3E%3C%2Fsvg%3E");

    --icon-check: url("data:image/svg+xml,%3Csvg%20id%3D%22_Layer_2%22%20data-name%3D%22Layer_2%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2027%2020%22%3E%3Cpolygon%20fill%3D%22currentColor%22%20points%3D%2224.8%200%209.7%2015.4%202.2%207.8%200%2010.2%207.4%2017.6%209.7%2020%2011.9%2017.6%2027%202.3%2024.8%200%22%2F%3E%3C%2Fsvg%3E");


    --icon-radio-off: url("data:image/svg+xml,%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2040%2040%22%3E%0A%20%20%3Cdefs%3E%0A%20%20%20%20%3Cstyle%3E%0A%20%20%20%20%20%20.st0%20%7B%0A%20%20%20%20%20%20%20%20fill%3A%20currentColor%3B%0A%20%20%20%20%20%20%20%20fill-rule%3A%20evenodd%3B%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%3C/style%3E%0A%20%20%3C/defs%3E%0A%20%20%3Cpath%20class%3D%22st0%22%20d%3D%22M19.1%2C0c11.9%2C0%2C20.9%2C9%2C20.9%2C20s-9%2C20-20.9%2C20S0%2C31%2C0%2C20%2C9%2C0%2C19.1%2C0Z%22/%3E%0A%3C/svg%3E");

    --icon-radio-on: url("data:image/svg+xml,%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2041%2041%22%3E%0A%20%20%3Cdefs%3E%0A%20%20%20%20%3Cstyle%3E%0A%20%20%20%20%20%20.st0%20%7B%0A%20%20%20%20%20%20%20%20fill-rule%3A%20evenodd%3B%0A%20%20%20%20%20%20%7D%0A%0A%20%20%20%20%20%20.st0%2C%20.st1%20%7B%0A%20%20%20%20%20%20%20%20fill%3A%20currentColor%3B%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%3C/style%3E%0A%20%20%3C/defs%3E%0A%20%20%3Cpath%20class%3D%22st1%22%20d%3D%22M19.6%2C41C9%2C41%2C0%2C31.6%2C0%2C20.5S9%2C0%2C19.6%2C0s21.4%2C9%2C21.4%2C20.5-9.4%2C20.5-21.4%2C20.5ZM19.6%2C1C9.5%2C1%2C1%2C9.9%2C1%2C20.5s8.5%2C19.5%2C18.6%2C19.5%2C20.4-8.6%2C20.4-19.5S31%2C1%2C19.6%2C1Z%22/%3E%0A%20%20%3Cpath%20class%3D%22st0%22%20d%3D%22M20.1%2C10.9c5.7%2C0%2C10%2C4.3%2C10%2C9.6s-4.3%2C9.6-10%2C9.6-9.2-4.3-9.2-9.6%2C4.3-9.6%2C9.2-9.6Z%22/%3E%0A%3C/svg%3E");

    --icon-hint: url("data:image/svg+xml,%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2028.9%2028.9%22%3E%0A%3Cdefs%3E%0A%20%20%20%20%3Cstyle%3E%0A%20%20%20%20%20%20.st0%20%7B%0A%20%20%20%20%20%20%20%20fill%3A%20currentColor%3B%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%3C/style%3E%0A%20%20%3C/defs%3E%0A%20%20%3Cpath%20class%3D%22st0%22%20d%3D%22M14.4%2C0C6.5%2C0%2C0%2C6.5%2C0%2C14.4s6.5%2C14.4%2C14.4%2C14.4%2C14.4-6.5%2C14.4-14.4S22.4%2C0%2C14.4%2C0ZM16.4%2C24h-3v-3.9h3v3.9ZM19.9%2C11.9c-.1%2C1.5-.5%2C2.1-1.7%2C3.6-.9%2C1.1-1.8%2C2.5-1.8%2C4h-3c0-2.5.6-3.7%2C2.1-5.3.6-.7%2C1.4-2%2C1.4-2.7%2C0-1.3-.2-1.7-.7-2.1-.3-.4-.9-.5-1.8-.5-2%2C0-2.6%2C1.3-2.6%2C3.1h-3.9c0-3.6%2C2.7-6.1%2C6.5-6.1%2C1.7%2C0%2C3%2C.5%2C3.9%2C1.5%2C1.5%2C1.5%2C1.6%2C3.1%2C1.5%2C4.6Z%22/%3E%0A%3C/svg%3E");

    --icon-close: url("data:image/svg+xml,%3Csvg%20id%3D%22_Layer_2%22%20data-name%3D%22Layer%202%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2026%2026%22%3E%3Cpolygon%20fill%3D%22currentColor%22%20points%3D%2226%202.1%2023.9%200%2013%2010.9%202.1%200%200%202.1%2010.9%2013%200%2023.9%202.1%2026%2013%2015.1%2023.9%2026%2026%2023.9%2015.1%2013%2026%202.1%22/%3E%3C/svg%3E");
    --icon-qa: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http://www.w3.org/2000/svg%22%20version%3D%221.1%22%20viewBox%3D%220%200%20121.9%2043.8%22%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M27.8%2C43.5c-1.5.2-3.1.3-4.8.3-5.2%2C0-7.1-1.3-8.6-5.2l-1-2.7C5.4%2C35.4%2C0%2C28.9%2C0%2C18.1S6.1%2C0%2C15%2C0s14.9%2C6.5%2C14.9%2C18-4.3%2C15.9-10.8%2C17.5l.6%2C1.7c.7%2C1.7%2C1.7%2C2.4%2C4.4%2C2.4s2.9-.2%2C4.4-.5l-.6%2C4.4h0ZM6.4%2C18c0%2C8.9%2C3.4%2C13.4%2C8.6%2C13.4s8.5-4.5%2C8.5-13.4-3.4-13.3-8.5-13.3-8.6%2C4.4-8.6%2C13.3Z%22/%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M75.8%2C19.2c-.4%2C4.2-1.8%2C8.3-3.9%2C10.5%2C1.8%2C2%2C3.2%2C2.4%2C6.3%2C2.4l-1.1%2C4h-1.5c-3.8%2C0-5.4-.9-7.3-2.9-2.4%2C2-5.3%2C3-9.2%2C3-6.9%2C0-11.7-4.2-11.7-10.5s2.3-7.8%2C7.4-10.2c-1.8-2.7-2.6-4.5-2.6-7%2C0-4.5%2C3.6-7.9%2C8.8-7.9s8.6%2C2.8%2C8.6%2C7.5-2.4%2C7-8.3%2C8.7c2.4%2C3.6%2C5.1%2C7.1%2C7.7%2C10.1%2C1.4-2.4%2C1.8-5.3%2C2-8.8l4.8%2C1h0ZM52.5%2C25c0%2C4.3%2C3.3%2C7.2%2C7.6%2C7.2s4.1-.6%2C5.4-1.8c-3.1-3.5-6.3-7.8-9-11.9-2.7%2C1.5-4.1%2C3.4-4.1%2C6.5h0ZM64.5%2C8.1c0-2.2-1.5-3.6-3.6-3.6s-3.7%2C1.5-3.7%2C3.9.6%2C3.2%2C2.2%2C5.6c3.9-1.3%2C5.1-3.1%2C5.1-5.8h0Z%22/%3E%3Cpath%20fill%3D%22currentColor%22%20d%3D%22M121.9%2C35.5h-6.3l-3-10.3h-10.7l-3%2C10.3h-5.8L103.8.6h7.3s10.8%2C34.9%2C10.8%2C34.9ZM109.4%2C13.7c-.8-2.7-1.3-5.3-2.1-8.6h-.4c-.8%2C3.3-1.4%2C5.8-2.2%2C8.5l-1.9%2C7.1h8.6l-2-7.1h0Z%22/%3E%3C/svg%3E");
}

:root {
    -webkit-box-direction: normal;
    -webkit-font-smoothing: antialiased;
    font-family: "微軟正黑體", "5FAE8EDF6B639ED19AD4", "Microsoft JhengHei", "PingFang TC", "Hiragino Sans CNS", sans-serif;
    color: #222222;
}


/*==================================================
Limit box-sizing to specific sections
================================================== */

/**,
*::before,
*::after {
    box-sizing: border-box;
}*/

img,
picture {
    display: inline;
}


/*==================================================
sp
================================================== */
.product_hero,
.product_purchase,
.product_nav,
.product_description,
.product_feedback,
.quality_control,
.research_team,
.product_qa,
.product_notes {
    color: #222;
}

/* ========================================================================
    [pc]product_primary
    ========================================================================= */
.nav_brands ul li.nav_all_pc.active button::before,
.nav_brands ul li.nav_platinum_pc.active button::before {
    background-color: #cfad39 !important;
}


.nav_brands ul li.nav_all_pc button:hover::before,
.nav_brands ul li.nav_platinum_pc button:hover::before,
.nav_brands ul li.nav_safty a:hover::before,
.nav_brands ul li.nav_lifestyle a:hover::before,
.nav_brands ul li.nav_faq a:hover::before,
.nav_brands ul li.nav_contact a:hover::before {
    background-color: #cfad39 !important;
}

.nav_brands ul li.nav_all_pc button:hover::after,
.nav_brands ul li.nav_platinum_pc button:hover::after,
.nav_brands ul li.nav_all_pc.active button::after,
.nav_brands ul li.nav_platinum_pc.active button::after,
.nav_brands ul li.nav_safty a:hover::after,
.nav_brands ul li.nav_lifestyle a:hover::after,
.nav_brands ul li.nav_faq a:hover::after,
.nav_brands ul li.nav_contact a:hover::after {
    content: '';
    width: 100%;
    height: 5px;
    background: #cfad39 !important;
    border-radius: 2px;
    position: absolute;
    bottom: 0;
    left: 0;
}



h1.pro_name {
    width: 1164px;
    margin: auto;
    font-size: 34px;
}

.product_hero .product_img img {
    width: auto;
    height: auto;
}

.product_primary {
    margin: 50px auto 45px auto;
    width: 1162px;
    display: flex;
    justify-content: space-between;
}

.product_hero {
    margin: 0;
    width: 520px;
}

.product_hero .product_img {
    margin: 0 0 40px;
    border: 1px #dddddd solid;
    height: 390px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.product_hero .product_img img {
    width: auto;
    height: auto;
    max-width: 460px;
    max-height: 330px;
}

.product_hero .product_copy {
    margin: 0;
}

.product_hero .product_copy h2+h2 {
    margin: 5px 0 0;
}

.product_hero .note {
    margin: 15px 0 0;
    font-size: 12px;
    list-style: none;
}

.product_hero .note li {
    padding: 0 0 0 25px;
    position: relative;
}

.product_hero .note li .number {
    position: absolute;
    top: 0;
    left: 0;
}

.radio_container {
    margin: 0;
    flex: 1;
}

.purchase .one_time {
    margin-bottom: 9px;
    width: auto;
    background: #f0f0f0;
    padding: 10px 10px 10px 11px;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
}

.purchase .one_time h2 {
    margin: 0;
    font-size: 20px;
    font-weight: bold;
    position: absolute;
    height: auto;
    top: 10px;
    left: 10px;
}

.purchase .regular {
    margin-bottom: 30px;
    width: 580px;
    background: #ffeecc;
    padding: 10px 10px 10px 10px;
    display: flex;
    flex-wrap: wrap;
    position: relative;
}

.purchase .regular .regular_extra_title::after {
    position: absolute;
    content: "";
    width: 10px;
    height: 52px;
    top: 0;
    right: -10px;
    clip-path: polygon(100% 0%, 0 50%, 100% 100%, 0% 100%, 0% 0%);
    background: #ff6600;
}

.purchase .regular h2 {
    margin: 0;
    width: 130px;
    font-size: 20px;
    font-weight: bold;
    position: absolute;
    top: 10px;
    left: 10px;
}

.purchase .red {
    color: #eb0000;
    font-weight: 700
}


.purchase .red_1 {
    font-size: 16px;
    margin-top: 4px;
}

.purchase_contents {
    text-align: right;
    padding: 5px 3px 2px 0px;
    flex: 1;
    width: auto;
    margin-top: 2px;
    position: relative;
}

.radio_container_div {
    display: flex;
    align-items: flex-end;
    flex-direction: row;
    gap: 0;
    margin-bottom: 10px;
    position: relative;
}

.radio_container_div .discount {
    width: 23%;
    margin-bottom: 0px;
    left: inherit;
    position: relative;
    top: inherit
}

.radio_container_div .discount p {
    color: #ff5500;
    font-weight: bold;
    flex: 1;
}

.radio_container_div .discount img {
    width: auto;
    float: right;
}

.radio_container_div .discount img:first-child {
    display: block;
    position: relative;
}

.radio_container_div .discount img:last-child {
    display: none
}

.radio_container {
    margin: 0 0 10px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.radio_container input {
    display: none;
}

.radio_container label {
    width: auto;
    padding: 6px 18px 6px 50px;
    box-shadow: 0px 0px 10px 0px rgba(221, 221, 221, 1);
    background: #fff;
    position: relative;
    text-align: left;
    display: flex;
    height: 85px;
    align-items: center;
}

.regular .radio_container label {
    box-shadow: 0px 0px 6px 0px rgba(238, 204, 136, 1);
}

.radio_container label::before {
    content: '';
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #dddddd;
    position: absolute;
    top: calc(50% - 0px);
    left: 18px;
    transform: translateY(-50%);
}

.radio_container input:checked+label::before {
    width: 24px;
    height: 24px;
    background: url(/img/goods/common/icon_radio_checked.svg) no-repeat center center;
    background-size: 24px 24px;
    top: calc(50% - 0px);
    left: 18px;
}

.radio_container label:last-child {
    margin-top: 0;
    width: 100%;
}

.radio_container label .label_group {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    flex: 1;
    gap: 16px;
}

.one_time .radio_container label .label_group {
    gap: 5px;
    display: flex;
    align-items: center;
    flex: 1 !important;
    flex-direction: row;
    margin: 0 0 0 48px;
}

.regular .radio_container {
    height: auto;
    margin: 0;
    width: 100%;
}

.one_time .radio_container {
    height: auto;
    width: 100%;
    margin: 0;
}

.purchase .notice {
    font-size: 23px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0;
    margin: 0;
    width: auto;
    text-align: left;
}

.purchase .notice>span:after {
    position: absolute;
    content: "-"
}

.purchase .notice>span:nth-child(1) {
    position: relative
}

.purchase .notice>span:nth-child(1):after {
    position: relative
}

.purchase .notice.small {
    font-size: 16px;
}

.red {
    color: #eb0000;
}

.purchase .supply {
    font-size: 24px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0;
}

.purchase .regular .supply::before {
    content: '-';
    font-size: 23px;
    margin: 0 10px;
}

.purchase .notice+.supply {
    margin: 0;
}

.purchase .label_group+.notice {
    margin-top: 10px;
}

.purchase .detail {
    font-size: 16px;
    font-weight: 500;
    line-height: 100%;
    letter-spacing: 0;
}

.purchase .price {
    margin: 0;
    font-size: 16px;
    line-height: 100%;
    text-align: right;
    white-space: nowrap;
    position: relative
}

.purchase .price .number {
    margin: 0 8px;
    font-size: 28px;
    font-weight: 700;
}

.purchase .price .number.red {
    color: #eb0000;
}

.purchase .btn_modal {
    font-size: 14px;
    line-height: 16px;
}

.purchase .link {
    font-size: 14px;
    line-height: 16px;
    margin: 0;
}

.purchase .btn_modal button,
.purchase .link a {
    background: url(/img/goods/common/icon_question.svg) no-repeat 0 center;
    background-size: 16px 16px;
    padding-left: 25px;
    text-decoration: none;
    color: #0072ef;
    cursor: pointer
}

.purchase .btn_modal button:hover,
.purchase .link a:hover {
    color: #00bbff;
    text-decoration: underline
}

.purchase .note {
    font-size: 14px;
    line-height: 1;
}

.purchase .btn_modal+.note {
    margin: 10px 0 0;
}

.purchase .btn_cart {
    ter;
    outline: none;
    padding: 0 0 0 140px;
    appearance: none;
    margin: 0 auto;
    width: 360px;
    height: 60px;
    background: #ff6000;
    background: url(/img/goods/common/icon_cart.svg) no-repeat 50px center, linear-gradient(to bottom, #ff6000 0%, #ff6000 75%, #ff4000 100%);
    background-size: 32px, auto;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 24px;
    font-weight: bold;
    color: #fff;
    box-shadow: 0 2px 2px rgba(101, 101, 101, .4);
}

.purchase .btn_cart:hover {
    background: #ff4000;
    background: url(/img/goods/common/icon_cart.svg) no-repeat 50px center, linear-gradient(to bottom, #ff4000 0%, #ff6000 75%, #ff6000 100%);
    background-size: 32px, auto;
}

.purchase .btn_link {
    margin: 0 auto 0;
    text-align: center;
}

.purchase .btn_link a span {
    background: url(/img/goods/common/icon_question.svg) no-repeat 0 center;
    background-size: 15px 15px;
    padding-left: 25px;
    display: inline-block;
    color: #0072ef;
    font-size: 14px;
    line-height: 4vw;
}

.purchase .btn_link a:hover span {
    color: #00bbff !important;
    text-decoration: underline !important;
    text-decoration-color: #00bbff !important;
}

.one_time .radio_container label {
    padding: 6px 10px 6px 0;
    height: 60px;
}

.one_time {
    margin: 0 0 10px;
    padding: 10px 10px 10px 160px;
    background: #f0f0f0;
    position: relative;
}

.one_time h2 {
    margin: 0;
    height: 60px;
    display: flex;
    align-items: center;
    font-size: 20px;
    font-weight: bold;
    position: absolute;
    top: 10px;
    left: 30px;
}

/*------------------------------------------------------------
[PC]regular_extra
------------------------------------------------------------ */
.regular_extra {
    margin: 10px auto 0;
    width: 560px;
    position: relative;
    display: none;
}

.regular_extra::after {
    content: '';
    width: 580px;
    height: 30px;
    background: linear-gradient(to bottom, #ffeecc 0%, #ffffff 100%);
    position: absolute;
    bottom: -32px;
    left: -10px;
}

.regular_extra.active {
    display: block;
}

.purchase .regular .regular_extra_title {
    width: 547px;
    background-size: 560px 40px;
    position: relative;
    display: flex;
    align-items: center;
    height: 52px;
    background: linear-gradient(to right, #ff1254 0%, #ff6600 100%);
}

.regular_extra_title::before {
    content: '';
    width: 10px;
    height: 20px;
    background: url(/img/goods/common/pc_bg_title_reqular_extra_hook.png) no-repeat 0 0;
    background-size: 10px 20px;
    position: absolute;
    bottom: -20px;
    left: 0;
}

.regular_extra_title h3 {
    margin: 0 30px;
    font-size: 21px;
    font-weight: bold;
    color: #fff;
}

.regular_extra_title .note {
    margin: 0 140px 0 0;
    font-size: 16px;
    color: #fff;
}

.regular_extra_title .badge {
    margin: 0;
    padding: 8px 0 0 15px;
    width: 46px;
    height: 31px;
    font-size: 9px;
    letter-spacing: -0.05em;
    white-space: nowrap;
    line-height: 1;
    color: #ff5c0a;
    background: url(/img/goods/common/icon_track.svg) no-repeat 0 0;
    background-size: 46px auto;
    display: block;
}

.benefit_contents {
    margin: 0 0 0 10px;
    width: 540px;
    background: #fff;
    box-shadow: 0 0 10px rgba(255, 153, 0, .4);
}

.regular_extra .benefit_list {
    margin: 0;
    padding: 0 8px;
    list-style: none;
    display: flex;
    gap: 8px;
}

.regular_extra .benefit_list li {
    padding: 6px 0;
}

.regular_extra .benefit_list .data {
    height: 44px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    margin-top: 13px;
    margin-left: 6px;
    align-items: flex-start;
    flex: 1;
}

.regular_extra .benefit_list .data_4 {
    flex: 1;
    display: flex;
    gap: 3px !important;
    height: 100%;
}

.regular_extra .benefit_list .data_4 div {
    flex: 1;
    border-radius: 4px;
    text-align: center;
    padding: 5px 4px 4px 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
}

.regular_extra .benefit_list .data_4 div:nth-child(odd) {
    background: #fff5e5;
}

.regular_extra .benefit_list .data_4 div:nth-child(even) {
    background: #fcede4;
}

.regular_extra .benefit_list .data_4 div img {
    width: 57%;
    padding-top: 5px;
    padding-bottom: 9px;
}

.regular_extra .benefit_list .data_4 div:nth-child(2) img {
    padding-top: 1px !important;
    padding-bottom: 10px !important;
    width: 60%;
}

.regular_extra .benefit_list .data_4 div:nth-child(2) p {
    padding-top: 5px;
}

.regular_extra .benefit_list .data_4 div:nth-child(3) img {
    width: 60%
}

.regular_extra .benefit_list .data_4 div:nth-child(4) img {
    padding-top: 0px !important;
    width: 91% !important;
    margin-right: -16px;
    margin-top: -5px;
    padding-bottom: 6px !important;
}

.regular_extra .benefit_list .data_4 div p {
    font-size: 10px;
    color: #994400;
    font-weight: bold;
    line-height: 1.2;
    white-space: nowrap;
    height: 23px;
}

.regular_extra .benefit_list .benefit01 {
    width: 20%;
    border-right: 1px #ebe0d6 solid;
    border-bottom: none;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.regular_extra .benefit_list .benefit01 .lf_data {
    display: grid;
    grid-template-areas:
        "a b"
        "c c";
    row-gap: 2px;
    align-items: start;
}

.regular_extra .benefit_list .benefit01 .lf_data h4 {
    grid-area: a
}

.regular_extra .benefit_list .benefit01 .lf_data .lf_1 {
    grid-area: b;
    font-size: 11px;
    font-weight: bold;
    color: #996633;
    line-height: 1.3;
    white-space: nowrap;
}

.regular_extra .benefit_list .benefit01 .lf_data .lf_1 b {
    font-size: 15px;
    font-weight: bold;
    color: #996633;
    display: block;
    line-height: 1.3;
}

.regular_extra .benefit_list .benefit01 .lf_data .lf_2 {
    grid-area: c;
    font-size: 14px;
    font-weight: bold;
    color: #ff6600;
    line-height: 1.05;
}

.regular_extra .benefit_list .benefit01 .lf_data .lf_2 b:first-child {
    font-size: 17px;
    font-weight: bold;
    color: #ff6600;
    font-family: "arial";
    padding: 0px 2px;
    vertical-align: -1px;
}

.regular_extra .benefit_list .benefit01 .lf_data .lf_2 b:last-child {
    font-size: 20px;
    vertical-align: 0px;
    line-height: 1;
}

.regular_extra .benefit_list .benefit01::after {
    width: 0;
    height: 0;
    background: none;
    display: none;
}

.regular_extra .benefit_list .benefit02::after {
    width: 0;
    height: 0;
    background: none;
    display: none;
}

.regular_extra .benefit_list .benefit02 {
    width: 22%;
    border-bottom: none;
    border-right: 1px #ebe0d6 solid;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background: url(/img/goods/common/img_benefit02.png) no-repeat 80px 7px;
    background-size: 45px auto;
    background-position: 63px 5px;
}

.regular_extra .benefit_list .benefit03 {
    flex: 1;
    border-right: none;
    display: flex;
    background-size: 48px auto;
    background-position: 67px 7px;
    flex-direction: row;
    align-items: center;
    gap: 0;
    align-content: space-between;
}

.regular_extra .benefit_list .benefit03 .data1 {
    width: 24%;
}

.regular_extra .benefit_list h4 {
    width: 52px;
    height: 22px;
    border-radius: 11px;
    background: #ff6600;
    font-size: 13px;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.regular_extra .benefit_list .conditions {
    font-size: 14px;
    font-weight: bold;
    color: #996633;
    padding: 0;
    width: auto;
    height: auto;
    position: static;
    text-align: left;
}

.regular_extra .benefit_list .offers {
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    flex: 1;
}

.regular_extra .benefit_list .offers .text {
    font-size: 14px;
    font-weight: bold;
    color: #ff6600;
}

.regular_extra .benefit_list .data1 .text {
    font-size: 14px;
    font-weight: bold;
    color: #ff6600;
    display: flex;
    align-items: flex-end;
    margin-top: 21px;
    letter-spacing: -1px;
    padding-left: 0;
    text-align: left;
}

.regular_extra .benefit_list .offers .text b {
    font-size: 24px;
    color: #ff6600;
    line-height: 31px;
    margin-bottom: -3px;
    font-family: initial;
}

.regular_extra .benefit_list .offers .note {
    font-weight: normal;
}

.regular_extra .benefit_list .offers .small {
    font-size: 10px;
    font-weight: bold;
    margin-bottom: 5px;
    color: #ff6600;
    display: block;
    white-space: nowrap;
}

.regular_extra .benefit_list .offers .code {
    font-size: 15px;
    font-weight: bold;
    color: #ff6600;
    white-space: nowrap;
    display: block;
}

.regular_extra .benefit_list .offers .number {
    margin-right: 3px;
    font-size: 40px;
    line-height: 1;
    letter-spacing: -0.075em;
    font-weight: bold;
    color: #ff6600;
}

.regular_extra .benefit_list .offers .unit_l {
    font-size: 22px;
    font-weight: bold;
    color: #ff6600;
}

.regular_extra .benefit_list .offers .unit_s {
    font-size: 12.5px;
    font-weight: normal;
    color: #ff6600;
}

.regular_extra .benefit_list .offers .add {
    font-size: 12px;
    color: #996633;
    white-space: nowrap;
}

.regular_extra_footer {
    border-top: 1px #ebe0d6 solid;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 15px 20px;
}

.regular_extra_footer .note {
    font-size: 14px;
    font-weight: bold;
    letter-spacing: -0.05em;
    color: #ff6600;
    display: block;
}

.regular_extra_footer .link {
    font-size: 14px;
    font-weight: 700;
    color: #0072ef;
}

.regular_extra_footer .link a {
    text-decoration: none;
    color: #0072ef;
    background: url(/img/goods/common/arrow_right_blue.svg) no-repeat right center;
    background-size: 7px auto;
    padding-right: 15px;
}

.purchase .price b {
    position: absolute;
    left: 0;
    top: -8px
}

/*------------------------------------------------------------
[PC]q_and_a
------------------------------------------------------------ */
.q_and_a {
    text-align: center;
    padding: 60px 0;
}

.q_and_a h2 {
    margin: 0 auto 75px auto;
    width: 100px;
    height: 35px;
    background: #222;
    -webkit-mask: var(--icon-qa);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: relative;
    text-indent: -999px
}

.q_and_a_group::after {
    content: '';
    width: 100px;
    height: 1px;
    display: block;
    background: #222;
    position: absolute;
    top: -46px;
    left: calc(50% - 50px);
    z-index: 999;
}

.q_and_a_contents h3 {
    margin-bottom: 30px;
    font-size: 20px;
    font-weight: bold;
    text-align: left;
}

.q_and_a_group {
    margin: 0 auto;
    width: 1080px;
    display: flex;
    justify-content: flex-start;
    position: relative;
}

.q_and_a_contents {
    margin: 0;
    flex: 1;
}

.q_and_a_contents+.q_and_a_contents {
    margin: 0;
}

.q_and_a_contents .q_and_a_list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.q_and_a_contents .q_and_a_list li {
    font-size: 16px;
    font-weight: bold;
    line-height: calc(22px + .5em);
    letter-spacing: -0.05em;
    text-align: left;
}

.q_and_a_contents .q_and_a_list li+li {
    margin-top: 10px;
}

.q_and_a_contents .q_and_a_list li a {
    color: #0072ef;
    text-decoration: none;
    background: url(/img/goods/common/icon_question.svg) no-repeat 0.25em;
    background-size: 22px 22px;
    padding-left: 40px;
    min-height: calc(22px + .5em);
    display: block;
    position: relative;
}

.q_and_a_contents .q_and_a_list li a:hover {
    color: #00bbff;
    text-decoration: underline
}

.q_and_a_contents .q_and_a_list li a:before {
    content: '';
    width: 20px;
    height: 20px;
    /* background-color: #0072ef; */
    /* -webkit-mask: var(--icon-hint); */
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    top: calc(50% - 11px);
    left: 0;
}



/* ========================================================================
    [pc]product_feedback
    ========================================================================= */
.product_feedback {
    margin: 0 auto;
    width: 100%;
    padding: 88px 0 50px;
    text-align: center;
    background: linear-gradient(to bottom, #fff 0%, #fee6cf 15%, #fee6cf 75%, #fee6cf 100%);
}

.product_feedback h2 {
    margin: 0 auto 36px;
    display: inline-block;
    padding: 0 0 30px;
    border-bottom: 2px #222 solid;
    font-size: 35px;
    font-weight: bold;
    /* white-space: nowrap; */
    letter-spacing: -0.025em;
    color: #222;
}

.product_feedback .sub_title {
    margin-bottom: 46px;
    font-size: 26px;
    font-weight: bold;
    color: #990000;
}

.feedback_list {
    margin: 0 auto 25px;
    width: 1080px;
    list-style: none;
}

.feedback_list li {
    background: #fff;
    width: 1080px;
    padding: 0;
    display: flex;
}

.feedback_list li+li {
    margin-top: 20px;
}

.feedback_list li .info_block {
    width: 720px;
    padding: 30px;
}

.feedback_list li .text {
    margin: 0;
    font-size: 16px;
    line-height: 1.5;
    color: #222;
    text-align: left;
}

.feedback_list li figure {
    width: 360px;
}

.feedback_list li figure img {
    width: 100%;
    height: auto;
}

.user_info {
    margin: 0 0 30px;
    padding: 0 0 0 28px;
    border-left: 2px #e03400 solid;
    text-align: left;
}

.user_info .name {
    margin-bottom: 12px;
    font-size: 22px;
    font-weight: bold;
    line-height: 1;
    color: #990000;
}

.user_info .name .position {
    margin-right: 7px;
    font-size: 18px;
}

.user_info .age {
    margin-bottom: 12px;
    font-size: 15px;
    line-height: 1;
    color: #a86800;
}

.user_info .note {
    font-size: 18px;
    line-height: 1;
    font-weight: bold;
    color: #e03400;
}

.feedback_note {
    font-size: 15px;
    text-align: center;
    color: #222;
}

/* ========================================================================
    [pc]product_nav
    ========================================================================= */
.product_nav {
    margin: 0 auto;
    width: 1070px;
}

.product_nav ul {
    list-style: none;
    display: flex;
    justify-content: space-between;
}

.product_nav li {
    width: 260px;
    box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.1);
}

.product_nav li a {
    width: 260px;
    height: 90px;
    padding-bottom: 40px;
    font-size: 19px;
    line-height: 1.25;
    font-weight: bold;
    text-decoration: none;
    color: #222;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    text-align: center;
    background: #fff;
    position: relative;
    transition: var(--transition-normal);
}

.product_nav li.product_nav_notes a {
    font-size: 19px;
}

.product_nav li a::before {
    content: '';
    width: 260px;
    height: 10px;
    background: #dc0201;
    position: absolute;
    top: 0;
    left: 0;
}

.product_nav li a::after {
    content: '';
    width: 14px;
    height: 9px;
    background-color: #dc0201;
    -webkit-mask: var(--icon-arrow-down);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    left: calc(50% - 7px);
    bottom: 13px;
}

.product_nav li a:hover {
    color: #222;
    background: linear-gradient(to bottom, #fff 0%, #fff 38%, #ffeded 100%);
}

.product_nav li a:hover::before {
    content: '';
    background: #dc0201;
}

/* ========================================================================
    [pc]recommendation
    ========================================================================= */
.recommendation {
    background: #ffeded;
    margin: -40px 0 0;
    padding: 90px 0 40px;
}

.recommendation_inner {
    margin: 0 auto;
    width: 1070px;
    padding: 35px 55px 50px;
    background: #ffdcdc;
}

.recommendation h2 {
    margin: 0 0 35px;
    font-size: 28px;
    font-weight: bold;
    text-align: center;
}

.recommendation_list {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.recommendation_list li {
    width: 460px;
    background: linear-gradient(to right, #ffffff, #ffeded);
    font-size: 16px;
    letter-spacing: -0.05em;
    line-height: 1;
    font-weight: bold;
    color: #222;
    margin-bottom: 10px;
    padding: 15px 10px 15px 80px;
    position: relative;
}

.recommendation_list li.list01 {
    order: 1;
}

.recommendation_list li.list02 {
    order: 3;
}

.recommendation_list li.list03 {
    order: 2;
}

.recommendation_list li.list04 {
    order: 4;
}

.recommendation_list li .emphasis {
    margin: 0 10px;
    font-size: 20px;
    color: #dd0000;
}

.recommendation_list li::before {
    content: '';
    width: 22px;
    height: 16px;
    background-color: #dd0000;
    -webkit-mask: var(--icon-check);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    left: 34px;
    top: calc(50% - 8px);
}

/* ========================================================================
    [pc]product_notes
    ========================================================================= */
.product_notes {
    padding: 60px 0;
    background: #fff8ee;
    text-align: center;
}

.product_notes h2 {
    margin: 0 auto 40px;
    padding: 0 0 30px;
    font-size: 35px;
    display: inline-block;
    font-weight: bold;
    text-align: center;
    border-bottom: 1px #222 solid;
}

.notes_table {
    margin: 0 auto;
    width: 1160px;
    border-collapse: collapse;
}

.notes_table th {
    font-size: 18px;
    font-weight: bold;
    white-space: nowrap;
    vertical-align: top;
    text-align: left;
    background: #fbf2e7;
    border-bottom: 1px #ece1cc solid;
    padding: 30px 40px;
}

.notes_table td {
    font-size: 16px;
    line-height: 1.5;
    text-align: left;
    background: #fff;
    border-bottom: 1px #ece1cc solid;
    padding: 30px 40px;
}

.notes_table tr:last-child th,
.notes_table tr:last-child td {
    border-bottom: none;
}

.inner_table {
    border-collapse: collapse;
}

.inner_table th {
    font-size: 16px;
    font-weight: normal;
    white-space: nowrap;
    vertical-align: top;
    text-align: left;
    background: none;
    border: none;
    padding: 10px 0 0;
}

.inner_table.width_separator td,
.inner_table.width_separator1 td {
    padding: 10px 0 0 3.5em;
    position: relative;
    border: none;
}

.inner_table.width_separator1 th {
    position: relative;
    width: 100px;
}

.inner_table td {
    font-size: 16px;
    line-height: 1.5;
    text-align: left;
    /* white-space: nowrap; */
    background: none;
    border: none;
    padding: 20px 25px;
}

.inner_table.marker_indent tr th {
    padding: 10px 0 0;
    display: table-cell;
}

.inner_table.marker_indent tr:first-child th {
    padding: 0;
    white-space: normal
}

.inner_table.marker_indent td {
    display: table-cell;
    border: none;
    padding: 10px 0 0 1em;
}

.inner_table.marker_indent tr:first-child td {
    padding: 0 0 0 1em;
}

.inner_table.width_separator th {
    padding: 10px 0 0;
}

.inner_table.width_separator1 th {
    padding: 14px 0 0 0;
}

.inner_table.width_separator tr:first-child th {
    padding: 0;
}

.inner_table.width_separator td::before {
    content: '……';
    font-size: 16px;
    font-weight: normal;
    position: absolute;
    top: 10px;
    left: 0.5em;
}

.inner_table.width_separator1 td::before {
    content: '…';
    font-size: 16px;
    font-weight: normal;
    position: absolute;
    top: 14px;
    left: 1em;
}

.inner_table.width_separator tr:first-child td::before,
.inner_table.width_separator1 tr:first-child td::before {
    top: 0.5em;
}

.inner_table.width_separator1 .indent {
    padding-left: 16px;
    padding-top: 2px;
}

.inner_table.width_separator1 .indent+td {
    padding-top: 2px;
}

.inner_table.width_separator1 .indent+td:before {
    top: 4px;
}

.indent2 {
    text-indent: -13px;
    padding-left: 13px !important;
}


/* ========================================================================
    [pc]btn_footer
    ========================================================================= */

.btn_footer {
    width: 100%;
    height: 100px;
    background: rgba(255, 238, 238, 0.8);
    box-shadow: 0 -5px 10px rgba(0, 0, 0, 0.2);
    position: fixed;
    bottom: 0;
    z-index: 1;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition-slow);
}

.btn_footer.active {
    opacity: 1;
    visibility: visible;
}

.btn_footer .inner {
    margin: 0 auto;
    width: 83%;
    max-width: 1162px;
    min-width: 600px;
    height: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.btn_select_purchase a {
    width: 360px;
    height: 60px;
    padding: 0 0 0 130px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    background: linear-gradient(to bottom, #ff6000 0%, #ff5e00 33%, #ff4200 91%, #ff4000 100%);
    color: #fff;
    text-decoration: none;
    font-size: 24px;
    font-weight: bold;
    position: relative;
    box-shadow: 0 2px 2px rgba(101, 101, 101, 0.41);
    top: auto;
    left: auto;
}

.btn_select_purchase a:hover {
    background: linear-gradient(to top, #ff6000 0%, #ff5e00 33%, #ff4200 91%, #ff4000 100%);
}

.btn_select_purchase a::before {
    content: '';
    width: 32px;
    height: 32px;
    background-color: #ffffff;
    -webkit-mask: var(--icon-cart);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    left: 51px;
    top: calc(50% - 16px);
    transition: var(--transition-normal);
}

.btn_footer .btn_close_footer {
    content: '';
    width: 20px;
    height: 20px;
    background-color: #ff6000;
    -webkit-mask: var(--icon-close);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    position: absolute;
    right: 0;
    right: calc(50% - 245px);
    top: 20px;
}

/*------------------------------------------------------------
[PC]modal_container
------------------------------------------------------------ */

.modal_container {
    background: #fff;
    width: 960px;
    height: auto;
    position: fixed;
    z-index: 10005;
    top: 80px;
    left: calc(50% - 480px);
    display: none;
    cursor: pointer;
    padding: 15px 0 30px;
    text-align: center;
}

.modal_container.active {
    display: block;
}

.modal_container .modal_title {
    font-size: 26px;
    margin-bottom: 15px;
}

.modal_container .text {
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 30px;
}

.modal_container .btn_close {
    display: block;
    margin: 30px auto 0;
    border-radius: 4px;
    width: 170px;
    height: 60px;
    background: linear-gradient(to bottom, #ffffff 0%, #eeeeee 100%);
    color: #222;
    font-size: 21px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0px 2px 10px rgb(0 0 0 / 16%);
    white-space: nowrap;
    cursor: pointer;
}

.modal_container .btn_close:hover {
    background: linear-gradient(to bottom, #eeeeee 0%, #ffffff 100%);
}

.modal_container .btn_close_x {
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: #FF6000;
    text-indent: -99999px;
    position: absolute;
    top: -30px;
    right: -15px;
    cursor: pointer;
}

.modal_container .btn_close_x:hover {
    background: #FF4000;
}

.modal_container .btn_close_x::before {
    content: "";
    width: 60px;
    height: 60px;
    background: url(/img/goods/common/icon_close_white.svg) no-repeat center center;
    background-size: 20px 20px;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 999;
}

.notes_table ul li {
    list-style-type: none;
    position: relative;
    padding-left: 16px;
    padding-bottom: 4px;
    line-height: 1.6;
}

.notes_table ul li:before {
    position: absolute;
    content: "●";
    left: 0;
}

.notes_table ul li:last-child {
    padding-bottom: 6px;
}

.notes_table td p b.indent {
    font-weight: normal;
    display: block;
    line-height: 1.2;
    padding-top: 6px;
}

.notes_table td p+p {
    margin-top: 20px;
}

.indent {
    padding-left: 16px;
}

/*------------------------------------------------------------
[PC]price_list
------------------------------------------------------------ */
.price_list {
    width: auto;
    margin: 0 4vw;
}

.price_list .price_list_table {
    width: 100%;
}

.price_list .price_list_table caption {
    text-align: center;
    caption-side: top;
    height: 40px;
    background: #ff1155;
    border-radius: 10px 10px 0 0;
    font-size: 18px;
    line-height: 40px;
    color: #fff;
}

.price_list .price_list_table th {
    font-size: 16px;
    font-weight: normal;
    text-align: center;
    padding: 10px;
    border-right: 1px dashed #999999;
    border-bottom: 1px dashed #999999;
    border-left: 1px dashed #999999;
}

.price_list .price_list_table td {
    font-size: 16px;
    padding: 10px;
    border: 1px dashed #999999;
    text-align: center;
}

.price_list .price_list_table td.number,
.price_list .price_list_table td.price {
    color: #ff3366;
}

.price_list .price_list_table td.total {
    font-weight: bold;
}

.regular_extra_title>p.note {
    margin: 0 140px 0 0 !important;
    font-size: 16px;
    color: #fff;
}

.modal_container~.overlay {
    z-index: 10000;
}

.screen_only {
    display: block;
}

.phone_only {
    display: none;
}

.mask,
.mask1,
.mask2,
.mask3,
.mask4 {
    z-index: 999
}

@media print,
screen and (max-width:768px) {
    .screen_only {
        display: none;
    }

    .phone_only {
        display: block;
    }

    h1.pro_name {
        width: calc(100% - 30px);
        margin: auto;
        font-size: 5.3333333333333vw;
    }

    .product_hero .product_copy h2 {
        font-size: 4.8vw;
        letter-spacing: -0.05em;
        font-weight: bold;
    }

    .product_primary {
        margin: 8vw auto 4vw auto;
        width: auto;
        display: flex;
        justify-content: space-between;
        flex-direction: column;
    }

    .product_hero {
        margin: 0 0 8vw;
        width: auto;
    }

    .product_hero .product_copy {
        margin: 0 6.6666666666667vw;
    }

    .product_hero .product_img {
        margin: 0 6.6666666666667vw 8vw;
        border: 0.1333333333333vw #dddddd solid;
        height: 65.333333333333333vw;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .product_hero .product_img img {
        width: auto;
        height: auto;
        max-width: 78.666666666666667vw;
        max-height: 53.333333333333333vw;
    }

    .purchase .one_time {
        background: #f0f0f0;
        padding: 4vw 2vw;
        margin-bottom: 0;
    }

    .purchase .regular {
        background: #ffeecc;
        background: linear-gradient(to bottom, #ffeecc 0%, #ffeecc 92%, #ffffff 100%);
        padding: 4vw 2vw;
        position: relative;
        width: auto;
        display: flex;
        flex-direction: column;
        margin-bottom: 2vw;
    }

    .purchase .regular h2 {
        margin-bottom: 4vw;
        font-size: 5.3333333333333vw;
        font-weight: bold;
        line-height: 1;
        top: inherit;
        left: inherit;
    }

    .purchase .banner_off {
        width: 48vw;
        height: 9.3333333333333vw;
        background: url(/img/goods/common/sp_icon_off_8.png) no-repeat 0 0;
        background-size: 48vw 9.3333333333333vw;
        text-indent: -9999px;
        position: absolute;
        top: 2vw;
        right: 4vw;
    }

    .radio_container_div {
        margin-bottom: 2.5vw;
    }

    .radio_container {
        margin-bottom: 3.3333333333333vw;
        display: flex;
        justify-content: space-between;
    }

    .radio_container input {
        display: none;
    }

    .radio_container label {
        width: 45.3333333333333vw;
        padding: 3vw 3vw 3vw 14vw;
        box-shadow: 0px 0px 1.3333333333333vw 0px rgba(221, 221, 221, 1);
        background: #fff;
        position: relative;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        height: auto;
    }

    .regular .radio_container label {
        box-shadow: 0px 0px 1.3333333333333vw 0px rgba(238, 204, 136, 1);
    }

    .radio_container label::before {
        content: '';
        width: 5.3333333333333vw;
        height: 5.3333333333333vw;
        border-radius: 50%;
        background: #dddddd;
        position: absolute;
        top: 4vw;
        left: 2.4vw;
    }

    .one_time .radio_container label {
        padding: 3vw 2vw 3vw 14vw;
        height: auto;
    }

    .one_time .purchase_contents {
        text-align: right;
        padding: 5px 3px 2px 0px;
        flex: 1;
        width: auto;
        margin-top: 3vw;
        position: relative;
    }

    .purchase_contents {
        text-align: right;
        padding: 5px 3px 2px 0px;
        flex: 1;
        width: auto;
        margin-top: 5vw;
        position: relative;
    }

    .radio_container input:checked+label {}

    .radio_container input:checked+label::before {
        width: 5.3333333333333vw;
        height: 5.3333333333333vw;
        background: url(/img/goods/common/icon_radio_checked.svg) no-repeat center center;
        background-size: 5.3333333333333vw 5.3333333333333vw;
        top: 4vw;
        left: 3.2vw;
    }

    .purchase .notice {
        font-size: 3.4666666666667vw;
        font-weight: bold;
    }

    .purchase .notice.red {
        color: #eb0000;
    }

    .purchase .supply {
        font-size: 5.0666666666667vw;
        font-weight: bold;
        line-height: 1;
        letter-spacing: -0.05em;
    }

    .purchase .notice+.supply {
        margin-top: 1.3333333333333vw;
    }

    .purchase .label_group+.notice {
        margin-top: 1.3333333333333vw;
    }

    .purchase .supply .detail {
        margin-left: 1.3333333333333vw;
        font-size: 3.7333333333333vw;
        font-weight: normal;
    }

    .purchase .price {
        margin: 1.666667vw 1vw 0 0;
        font-size: 3.7333333333333vw;
        line-height: 1;
        text-align: right;
    }

    .purchase .price b {
        top: -1vw
    }

    .purchase .price .number {
        font-size: 6.1333333333333vw;
        font-weight: bold;
    }

    .purchase .price .number.red {
        color: #eb0000;
    }

    .purchase .btn_modal {
        font-size: 2.9333333333333vw;
        line-height: 1.4;
        position: absolute;
        top: -6.5vw;
        right: 0;
        z-index: 1;
    }

    .purchase .link {
        font-size: 3.2vw;
        line-height: 4vw;
        margin: 0;
    }

    .purchase .btn_modal a,
    .purchase .link a {
        background: url(/img/goods/common/icon_question.svg) no-repeat 0 center;
        background-size: 4vw 4vw;
        padding-left: 6vw;
        text-decoration: none;
        color: #0072ef;
    }

    .purchase .note {
        font-size: 2.9333333333333vw;
    }

    .purchase .btn_modal+.note {
        margin: 0;
    }

    .purchase .btn_cart {
        border: none;
        cursor: pointer;
        outline: none;
        padding: 0 0 0 8.4vw;
        appearance: none;
        margin: 0 auto;
        width: 72vw;
        height: 15.8vw;
        background: #ff6000;
        background: url(/img/goods/common/icon_cart.svg) no-repeat 6.1333333333333vw center, linear-gradient(to bottom, #ff6000 0%, #ff6000 75%, #ff4000 100%);
        background-size: 9.6vw, auto;
        border-radius: 1.3333333333333vw;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 5.8666666666667vw;
        font-weight: bold;
        color: #fff;
        box-shadow: 0 2px 2px rgba(101, 101, 101, .4);
    }

    .purchase .btn_cart:hover {
        background: url(/img/goods/common/icon_cart.svg) no-repeat 6.1333333333333vw center, linear-gradient(to bottom, #ff4000 0%, #ff6000 75%, #ff6000 100%);
        background-size: 9.6vw, auto;
    }

    .purchase .btn_link {
        margin: 4.8vw auto;
    }

    .purchase .btn_link a {
        text-align: center;
        font-size: 2.9333333333333vw;
        line-height: 4vw;
        text-decoration: none;
        color: #0072ef;
        display: block;
    }

    .purchase .btn_link a span {
        background: url(/img/goods/common/icon_question.svg) no-repeat 0 center;
        background-size: 4vw 4vw;
        padding-left: 6vw;
        display: inline-block;
        color: #0072ef;
        font-size: 3.2vw;
    }

    .purchase .one_time h2 {
        margin: 0 0 0 3vw;
        position: relative;
        z-index: 1;
        font-size: 6vw;
        white-space: nowrap;
        top: 2vw;
        left: inherit;
    }

    .purchase .regular h2 {
        margin: 0 0 0 3vw;
        position: relative;
        z-index: 1;
        font-size: 6vw;
        white-space: nowrap;
        top: 1vw;
        left: inherit;
    }

    .purchase .one_time h2 p,
    .purchase .regular h2 p {
        font-size: 3.5vw;
        padding-bottom: 6px;
    }

    .purchase .btn_modal button,
    .purchase .link a {
        background: url(/img/goods/common/icon_question.svg) no-repeat 0 center;
        background-size: 4vw 4vw;
        padding-left: 6vw;
        text-decoration: none;
        color: #0072ef;
    }

    .radio_container_div .discount {
        width: 16%;
        /* margin-bottom: -4vw; */
        z-index: 1;
        position: absolute;
        left: -1.3vw;
        top: -4vw;
    }

    .radio_container_div .discount img {
        width: 100%;
        height: auto;
        float: none;
        position: inherit;
    }

    .radio_container label .label_group {
        gap: 0.5vw;
        display: flex;
        width: 100%;
        flex: 1 !important;
        margin: 0 0 0 1vw;
        flex-direction: column;
        align-items: stretch;
    }

    .one_time .radio_container label .label_group {
        gap: 5px;
        display: flex;
        align-items: center;
        flex: 1 !important;
        flex-direction: row;
        margin: 3px 0 3px -1vw;
    }

    .radio_container label::before {
        top: 50%;
        transform: translateY(-50%);
        left: 5.8vw;
        background-size: auto 98%;
    }

    .radio_container input:checked+label::before {
        top: 48%;
        transform: translateY(-50%);
        left: 5.8vw;
        background-size: auto 98%;
    }

    .purchase .supply .notice_red,
    .purchase .notice .notice_red {
        display: block;
    }

    .purchase .supply .notice_red,
    .purchase .notice .notice_red {
        display: block;
        font-size: 4.88vw;
        margin-bottom: 0;
        letter-spacing: normal;
        position: relative;
        padding-right: 4vw;
    }

    .purchase .supply {
        flex: 1;
        font-size: 4.88vw;
        width: 100%;
        text-align: left;
        display: flex;
        align-items: flex-end;
        row-gap: 1vw;
        flex-direction: row;
    }

    .purchase .notice {
        flex: 1;
        font-size: 4.88vw;
        width: 100%;
        text-align: left;
        display: flex;
        align-items: flex-end;
    }

    .purchase .notice_second,
    .purchase .notice_second {
        color: #222;
        display: block;
        font-size: 3.2vw;
        letter-spacing: normal;
        font-weight: bold;
        width: 100%;
    }

    .purchase .supply .notice_red:before,
    .purchase .notice .notice_red:before {
        position: absolute;
        content: "-";
        right: 1vw;
        top: 0vw;
        font-size: 4.88vw;
    }

    .radio_container input:checked+label {}

    .purchase .note {
        text-align: right;
    }

    .mb_2 {
        margin-bottom: -2vw !important
    }

    .brown_2 {
        color: #996e33 !important;
        margin: 0 !important;
    }

    .purchase .link {
        font-size: 2.9333333333333vw;
        line-height: 1.4;
        position: absolute;
        top: -6vw;
        right: 0;
        z-index: 1;
    }

    .regular_extra_footer .link {
        position: relative;
        line-height: normal;
        font-size: 3.864734299516908vw;
        top: inherit;
    }

    .red_group,
    .red_group span,
    .red_group span.detail {
        color: #eb0000 !important;
    }

    .radio_container_div .discount img:first-child {
        display: none
    }

    .radio_container_div .discount img:last-child {
        display: block;
        position: absolute;
        top: 0;
    }

    .regular_extra {
        margin: 2vw auto 0 auto;
        width: auto;
        position: relative;
        display: none;
    }

    regular_extra.active {
        display: block;
    }

    .purchase .regular .regular_extra_title {
        width: 93.096618357487923vw;
        height: 16.908212560386473vw;
        background: linear-gradient(to right, #ff1254 0%, #ff6600 100%);
        position: relative;
        display: flex;
        align-items: center;
    }

    .regular_extra_title::before {
        content: '';
        width: 2.5vw;
        height: 2.6vw;
        background: url(../../img/goods/common/pc_bg_title_reqular_extra_hook.png) no-repeat 0 0;
        background-size: 3.5vw 1.5vw;
        position: absolute;
        bottom: -2.6vw;
        left: 0;
    }

    .purchase .regular .regular_extra_title::after {
        position: absolute;
        content: "";
        width: 3.140096618357488vw;
        height: 16.908212560386473vw;
        top: 0;
        right: -3.140096618357488vw;
        clip-path: polygon(100% 0%, 0 50%, 100% 100%, 0% 100%, 0% 0%);
        background: #ff6600;
    }

    .regular_extra_title h3 {
        margin: 0 2vw 0 2.898550724637681vw;
        font-size: 5.5vw;
        font-weight: bold;
        color: #fff;
    }

    .regular_extra_title>p.note {
        margin: 0 7vw 0 0 !important;
        font-size: 3.4vw;
        color: #fff;
    }

    .regular_extra_title .badge {
        margin: 0;
        padding: 2.6vw 0 0 3.6vw;
        width: 13vw;
        height: 8vw;
        font-size: 2.3vw;
        letter-spacing: -0.05em;
        white-space: nowrap;
        line-height: 1;
        color: #ff5c0a;
        background: url(/img/goods/common/icon_track.svg) no-repeat 0 0;
        background-size: auto 100%;
        display: block;
    }

    .benefit_contents {
        margin: 0 0 0 2.5vw;
        width: calc(100% - 5vw);
        background: #fff;
        box-shadow: 0 0 1.207729468599034vw rgba(255, 153, 0, .4);
    }

    .regular_extra::after {
        position: relative
    }

    .regular_extra .benefit_list {
        margin: 0;
        padding: 0;
        list-style: none;
        display: flex;
        flex-wrap: wrap;
        gap: 0;
    }

    .regular_extra .benefit_list li {
        padding: 1vw 1vw 2vw 1vw;
        position: relative;
    }

    .regular_extra .benefit_list .data_4 div p {}

    .regular_extra .benefit_list .data_4 div:nth-child(2) img {
        padding-top: 1.3vw !important;
    }

    .regular_extra .benefit_list .data_4 div:nth-child(2) p {
        padding-top: 5px;
    }

    .regular_extra .benefit_list .data_4 div:nth-child(3) img {
        padding-top: 1.3vw;
        width: 60%;
    }

    .regular_extra .benefit_list .data_4 div:nth-child(4) img {
        padding-top: 0px !important;
        padding-bottom: 1.3vw !important;
        width: 82% !important;
        margin-right: -4.5vw;
        margin-top: inherit;
    }

    .regular_extra .benefit_list .benefit01 {
        flex: inherit;
        width: calc(50% - 0vw);
        border-right: 1px #ebe0d6 solid;
        border-bottom: 1px #ebe0d6 solid;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        position: relative;
        box-sizing: border-box;
    }

    .regular_extra .benefit_list .benefit01 .lf_data {
        display: grid;
        grid-template-areas:
            "a b"
            "c c";
        row-gap: 3.2vw;
        align-items: center;
    }

    .regular_extra .benefit_list .benefit01 .lf_data h4 {
        grid-area: a
    }

    .regular_extra .benefit_list .benefit01 .lf_data .lf_1 {
        grid-area: b;
        font-size: 3vw;
        font-weight: bold;
        color: #996633;
        line-height: 1;
        white-space: nowrap;
        text-align: center;
    }

    .regular_extra .benefit_list .benefit01 .lf_data .lf_1 b {
        font-size: 3vw;
        font-weight: bold;
        color: #996633;
        display: inline;
    }

    .regular_extra .benefit_list .benefit01 .lf_data .lf_2 {
        grid-area: c;
        font-size: 3.6vw;
        font-weight: bold;
        color: #ff6600;
        line-height: 1.2;
        text-align: center;
    }

    .regular_extra .benefit_list .benefit01 .lf_data .lf_2 b:first-child {
        grid-area: c;
        font-size: 4.2vw;
        font-weight: bold;
        color: #ff6600;
        line-height: 1.2;
        text-align: center;
        vertical-align: -o.15vw;
    }

    .regular_extra .benefit_list .benefit01 .lf_data .lf_2 b:last-child {
        grid-area: c;
        font-size: 5.2vw;
        font-weight: bold;
        color: #ff6600;
        line-height: 1.2;
        text-align: center;
        vertical-align: -1px
    }


    .regular_extra .benefit_list .benefit02 {
        flex: inherit;
        width: 50%;
        border-right: none;
        border-bottom: 1px #ebe0d6 solid;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        background: url(/img/goods/common/img_benefit02.png) no-repeat 80px 9px;
        background-size: 11.8vw auto;
        background-position-x: right;
        background-position-y: 1vw;
    }

    .regular_extra .benefit_list .benefit03 {
        flex: 1;
        border-right: 1px #ebe0d6 solid;
        display: flex;
        justify-content: space-between;
        background-size: 10vw auto;
        background-position: 32vw 2vw;
        flex-direction: row;
        gap: 1vw;
    }

    .regular_extra .benefit_list .benefit03 .data1 {
        width: 29% !important;
    }

    .regular_extra .benefit_list .benefit03 .data1 .text {
        font-size: 4.3vw;
        font-weight: bold;
        color: #ff6600;
        text-align: center;
        margin-top: 3vw;
        padding-left: 1vw;
        letter-spacing: 0;
        line-height: 1.2;
        display: flex;
        justify-content: center;
    }

    .regular_extra .benefit_list .benefit03 .offer {
        flex: 1
    }

    .regular_extra .benefit_list h4 {
        width: 12.009662vw;
        height: 4.830917874396135vw;
        border-radius: 2.415458937198068vw;
        background: #ff6600;
        font-size: 3vw;
        color: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .regular_extra .benefit_list .conditions {
        font-size: 3.8vw;
        color: #996633;
        padding: 0;
        font-weight: bold;
    }

    .regular_extra .benefit_list .offers {
        display: flex;
        align-items: flex-end;
        justify-content: center;
        flex: 1;
    }

    .regular_extra .benefit_list .offers .text {
        font-size: 4.3vw;
        font-weight: bold;
        color: #ff6600;
    }

    .regular_extra .benefit_list .offers .note {
        font-weight: bold;
    }

    .regular_extra .benefit_list .offers .small {
        font-size: 3.381642512077295vw;
        color: #ff6600;
        display: inline;
    }

    .regular_extra .benefit_list .offers .code {
        font-size: 3.381642512077295vw;
        color: #ff6600;
        display: inline;
    }

    .regular_extra .benefit_list .offers .number {
        font-size: 8.21256038647343vw;
        line-height: 1;
        font-weight: bold;
        color: #ff6600;
    }

    .regular_extra .benefit_list .offers .unit_l {
        font-size: 6.038647342995169vw;
        font-weight: bold;
        color: #ff6600;
    }

    .regular_extra .benefit_list .offers .unit_s {
        font-size: 3.381642512077295vw;
        font-weight: normal;
        color: #ff6600;
    }

    .regular_extra .benefit_list .offers .data_4 {
        display: flex;
        gap: 1vw;
    }

    .regular_extra .benefit_list .offers .data_4 div {
        border-radius: 5px;
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        padding-bottom: 2vw;
    }

    .regular_extra .benefit_list .offers .data_4 div:nth-child(odd) {
        background: #fff6e5;
    }

    .regular_extra .benefit_list .offers .data_4 div:nth-child(even) {
        background: #fcede4;
    }

    .regular_extra .benefit_list .offers .data_4 div img {
        width: 62.5%;
        padding: 2vw 0;
    }

    .regular_extra .benefit_list .offers .data_4 div p {
        color: #994400;
        font-size: 2.7vw;
        font-weight: bold;
        text-align: center;
        line-height: 1.2;
    }

    .regular_extra .benefit_list .data {
        height: 12vw;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        margin-top: 0;
        align-items: center;
        margin-top: 1.4vw;
        row-gap: 1vw;
    }

    .regular_extra .benefit_list .offers .add {
        font-size: 3.381642512077295vw;
        font-weight: normal;
        color: #996633;
    }

    .regular_extra_footer {
        border-top: 1px #ebe0d6 solid;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 4.347826086956522vw;
    }

    .regular_extra_footer .note {
        display: none;
    }

    .regular_extra_footer .link {
        font-size: 3.864734299516908vw;
        color: #0072ef;
    }

    .regular_extra_footer .link a {
        text-decoration: none;
        color: #0072ef;
        background: url(/img/goods/common/arrow_right_blue.svg) no-repeat right center;
        background-size: 2.415458937198068vw auto;
        padding-right: 5.072463768115942vw;
        font-weight: 500;
    }

    .regular_extra .benefit_list .offers .text b {
        font-size: 6vw;
        color: #ff6600;
        line-height: 0.6;
        margin-bottom: 0vw;
        font-family: initial
    }

    .purchase .detail {
        font-size: 3.6vw;
    }

    .purchase .red_1 {
        font-size: 3.6vw;
        margin-top: 1vw;
    }



    /*------------------------------------------------------------
    [SP]q_and_a
    ------------------------------------------------------------ */
    .q_and_a_group {
        width: auto;
        flex-direction: column;
        padding: 0 15px;
    }

    .q_and_a {
        text-align: center;
        padding: 8vw 0 6.6666666666667vw;
    }

    .q_and_a h2 {
        margin: 0 auto 13.3333333333333vw;
        width: 16.266666666666667vw;
        height: 6vw;
        background: #222;
        -webkit-mask: var(--icon-qa);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
    }

    .q_and_a_contents h3 {
        margin-bottom: 4vw;
        font-size: 4.5333333333333vw;
        font-weight: bold;
        text-align: center;
    }

    .q_and_a_contents {
        margin: 0;
    }

    .q_and_a_contents+.q_and_a_contents {
        margin-top: 6.6666666666666667vw;
    }

    .q_and_a_contents .q_and_a_list {
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .q_and_a_contents .q_and_a_list li {
        font-size: 3.7333333333333vw;
        font-weight: bold;
        line-height: normal;
        text-align: left;
    }

    .q_and_a_contents .q_and_a_list li+li {
        margin-top: 4vw;
    }

    .q_and_a_contents .q_and_a_list li a {
        color: #0072ef;
        text-decoration: none;
        background: url(/img/goods/common/icon_question.svg) no-repeat 0 .1em;
        background-size: 5vw 5vw;
        padding-left: 7vw;
        display: block;
        position: relative;
        min-height: 7vw;
    }

    .q_and_a_contents .q_and_a_list li a:before {
        content: '';
        width: 1.25em;
        height: 1.25em;
        /* background-color: #0065EA; */
        /* -webkit-mask: var(--icon-hint); */
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: 0.3vw;
        left: 0;
    }

    .q_and_a_group::after {
        content: '';
        width: 100px;
        height: 1px;
        display: block;
        background: #222;
        position: absolute;
        top: -10vw;
        left: calc(50% - 50px);
        z-index: 999;
    }

    /* ========================================================================
    [sp]product_feedback
    ========================================================================= */
    .product_feedback {
        margin: 0;
        padding: 8vw 0 4vw;
        text-align: center;
        background: linear-gradient(to bottom, #fff 0%, #ffe7d0 15%, #ffe7d0 75%, #fff 100%);
    }

    .product_feedback h2 {
        margin: 0 4vw 6.6666666666667vw;
        padding: 0 0 4.6666666666667vw;
        border-bottom: 1px #222 solid;
        font-size: 6vw;
        font-weight: bold;
        /* white-space: nowrap; */
        letter-spacing: -0.025em;
        color: #222;
    }

    .product_feedback .sub_title {
        margin-bottom: 7.333333333333333vw;
        font-size: 4.2666666666667vw;
        font-weight: bold;
        color: #990000;
    }

    .feedback_list {
        margin: 0 6.6666666666667vw 2.6666666666667vw;
        list-style: none;
        width: auto;
    }

    .feedback_list li {
        background: #fff;
        padding: 5.3333333333333vw;
        width: auto;
        display: flex;
        flex-direction: column;
    }

    .feedback_list li+li {
        margin-top: 4vw;
    }

    .feedback_list li .text {
        margin: 0 0 6vw;
        font-size: 3.4666666666667vw;
        line-height: 1.5;
        color: #222;
        text-align: left;
    }

    .feedback_list li figure {
        width: 100%;
    }

    .feedback_list li figure img {
        width: 100%;
        height: auto;
    }

    .user_info {
        margin: 0 0 5.3333333333333vw;
        padding: 0 0 0 5.3333333333333vw;
        border-left: 0.5333333333333vw #e03400 solid;
        text-align: left;
    }

    .user_info .name {
        margin-bottom: 3.3333333333333vw;
        font-size: 4.5333333333333vw;
        font-weight: bold;
        line-height: 1;
        color: #990000;
    }

    .user_info .name .position {
        margin-right: 2.6666666666667vw;
        font-size: 3.4666666666667vw;
    }

    .user_info .age {
        margin-bottom: 3.3333333333333vw;
        font-size: 3.4666666666667vw;
        line-height: 1;
        color: #a86800;
    }

    .user_info .note {
        font-size: 4vw;
        line-height: normal;
        font-weight: bold;
        color: #e03400;
    }

    .feedback_note {
        font-size: 2.9333333333333vw;
        text-align: center;
        color: #222;
    }

    /*------------------------------------------------------------
[SP]price_list
------------------------------------------------------------ */
    .price_list {
        margin: 0 4vw;
    }

    .price_list .price_list_table {
        width: 100%;
        border-collapse: collapse;
    }

    .price_list .price_list_table caption {
        text-align: center;
        caption-side: top;
        height: 10.666666666666667vw;
        background: #ff1155;
        font-size: 4.266666666666667vw;
        line-height: 10.666666666666667vw;
        color: #fff;
    }

    .price_list .price_list_table th {
        font-size: 3.2vw;
        font-weight: normal;
        text-align: center;
        padding: 2.4vw 1.6vw;
        border-right: 1px dashed #999999;
        border-bottom: 1px dashed #999999;
        border-left: 1px dashed #999999;
    }

    .price_list .price_list_table td {
        font-size: 3.2vw;
        padding: 2.4vw 1.6vw;
        border: 1px dashed #999999;
        text-align: center;
    }

    .price_list .price_list_table td.number,
    .price_list .price_list_table td.price {
        color: #ff3366;
    }

    .price_list .price_list_table td.total {
        font-weight: bold;
    }

    /* ========================================================================
    [sp]product_nav
    ========================================================================= */
    .product_nav {
        margin: 0 auto;
        width: 97.333333333333333vw;
    }

    .product_nav ul {
        list-style: none;
        display: flex;
        justify-content: space-between;
    }

    .product_nav li {
        width: 23.3333333333333vw;
        box-shadow: 0px 1.0666666666667vw 2.1333333333333vw 0px rgba(0, 0, 0, 0.1);
    }

    .product_nav li a {
        width: 23.3333333333333vw;
        height: 24vw;
        padding-bottom: 1.3333333333333vw;
        font-size: 4.2666666666667vw;
        line-height: 1.25;
        font-weight: bold;
        text-decoration: none;
        color: #222;
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: center;
        background: #fff;
        position: relative;
    }

    .product_nav li.product_nav_notes a {
        font-size: 3.4666666666667vw;
    }

    .product_nav li a::before {
        content: '';
        width: 23.3333333333333vw;
        height: 2vw;
        background: #dc0201;
        position: absolute;
        top: 0;
        left: 0;
    }

    .product_nav li a::after {
        content: '';
        width: 3.2vw;
        height: 2vw;
        background-color: #dc0201;
        -webkit-mask: var(--icon-arrow-down);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        left: calc(50% - 1.6vw);
        bottom: 1.3333333333333vw;
    }

    /* ========================================================================
    [sp]recommendation
    ========================================================================= */
    .recommendation {
        background: #ffeded;
        margin: -12vw 0 8vw;
        padding: 20vw 6.6666666666667vw 6.6666666666667vw;
    }

    .recommendation_inner {
        padding: 5.3333333333333vw 4vw 4vw;
        background: #ffdcdc;
        width: auto;
    }

    .recommendation h2 {
        margin: 0 0 5.3333333333333vw;
        font-size: 5.3333333333333vw;
        font-weight: bold;
        text-align: center;
    }

    .recommendation_list {
        list-style: none;
    }

    .recommendation_list li {
        background: #fff;
        font-size: 3.2vw;
        letter-spacing: -0.075em;
        line-height: 1;
        font-weight: bold;
        color: #222;
        margin-bottom: 1.3333333333333vw;
        padding: 2.6666666666667vw 3.3333333333333vw 2.6666666666667vw 12vw;
        position: relative;
        width: 100%;
        height: auto
    }

    .recommendation_list li .emphasis {
        margin: 0 0.4vw;
        font-size: 4vw;
        color: #dd0000;
    }

    .recommendation_list li::before {
        content: '';
        width: 3.6vw;
        height: 2.6666666666667vw;
        background-color: #dd0000;
        -webkit-mask: var(--icon-check);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        left: 4vw;
        top: calc(50% - 1.3333333333333vw);
    }

    .recommendation_list {
        list-style: none;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        width: auto;
        margin: auto;
    }

    .recommendation_list li.list01 {
        order: 1;
    }

    .recommendation_list li.list02 {
        order: 2;
    }

    .recommendation_list li.list03 {
        order: 3;
    }

    .recommendation_list li.list04 {
        order: 4;
    }

    .feedback_list li .info_block {
        width: auto;
        padding: 0;
    }

    /* ========================================================================
[sp]product_notes
========================================================================= */
    .product_notes {
        padding: 8vw 4vw;
        background: #fff8ee;
        text-align: center;
    }

    .product_notes h2 {
        margin: 0 auto 6vw;
        padding: 0 0 4.6666666666667vw;
        font-size: 6vw;
        display: inline-block;
        font-weight: bold;
        text-align: center;
        border-bottom: 1px #222 solid;
    }

    .notes_table {
        border-collapse: collapse;
        width: auto;
    }

    .notes_table th {
        font-size: 3.4666666666667vw;
        font-weight: bold;
        white-space: nowrap;
        vertical-align: top;
        text-align: left;
        background: #fbf2e7;
        padding: 4vw;
    }

    .inner_table.width_separator td {
        padding: 2vw 0 0 1.5em;
        position: relative;
    }

    .inner_table.marker_indent td {
        display: table-cell;
        border: none;
        padding: 1vw 0 0 1em;
    }

    .notes_table td {
        font-size: 3.4666666666667vw;
        line-height: 1.5;
        text-align: left;
        background: #fff;
        border-bottom: 1px #ece1cc solid;
        padding: 4vw;
        word-break: break-all
    }

    .inner_table.marker_indent td {
        display: block;
        border: none;
    }

    .inner_table.width_separator td::before {
        content: '…';
        font-size: 12px;
        font-weight: normal;
        position: absolute;
        top: inherit;
        bottom: 50%;
        left: 0.25em;
        transform: translateY(calc(-50% + 5vw));
    }


    .notes_table tr:last-child th,
    .notes_table tr:last-child td {
        border-bottom: none;
    }

    .inner_table {
        border-collapse: collapse;
    }

    .inner_table.width_separator th {
        padding: 2vw 0 0;
    }

    .inner_table.marker_indent tr th {
        display: block;
        padding: 1vw 0 0;
    }

    .inner_table th {
        font-size: 3.4666666666667vw;
        font-weight: normal;
        white-space: wrap;
        vertical-align: top;
        text-align: left;
        background: none;
    }

    .inner_table tr:last-child th,
    .inner_table tr:last-child td {
        border: none;
    }

    .indent2 {
        text-indent: -4vw;
        padding-left: 4vw !important;
    }

    /* ========================================================================
[sp]btn_footer
========================================================================= */
    .btn_footer {
        width: 100vw;
        height: 20vw;
        background: rgba(255, 238, 238, 0.8);
        box-shadow: 0 -0.6666666666667vw 1.3333333333333vw rgba(0, 0, 0, 0.2);
        position: fixed;
        bottom: 0;
        z-index: 100;
        opacity: 0;
        visibility: hidden;
        transition: var(--transition-slow);
    }

    .btn_footer.active {
        opacity: 1;
        visibility: visible;
    }

    .btn_footer .inner {
        width: auto;
        height: 20vw;
        display: flex;
        position: relative;
        max-width: inherit;
        min-width: inherit;
    }

    .btn_select_purchase a {
        width: 70.6666666666667vw;
        width: 50.666667vw;
        height: 12vw;
        padding: 0 0 0 14.733333vw;
        border-radius: 1.3333333333333vw;
        display: flex;
        align-items: center;
        background: linear-gradient(to bottom, #ff6000 0%, #ff5e00 33%, #ff4200 91%, #ff4000 100%);
        color: #fff;
        text-decoration: none;
        font-size: 5.3333333333333vw;
        font-weight: bold;
        box-shadow: 0 0.2666666666667vw 0.2666666666667vw rgba(101, 101, 101, 0.41);
        position: absolute;
        top: calc(50% - 6vw);
        left: calc(50% - 27.333333vw);
    }

    .btn_select_purchase a::before {
        content: '';
        width: 7.066666666666667vw;
        height: 6.8vw;
        background-color: #ffffff;
        -webkit-mask: var(--icon-cart);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        left: 4.666667vw;
        top: calc(50% - 3.4vw);
    }

    .btn_footer .btn_close_footer {
        content: '';
        width: 3.2vw;
        height: 3.2vw;
        background-color: #ff6000;
        -webkit-mask: var(--icon-close);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        -webkit-mask-size: 100% 100%;
        -webkit-mask-repeat: no-repeat;
        -webkit-mask-position: center;
        position: absolute;
        top: 4vw;
        right: 19vw;
        cursor: pointer;
        border: none;
    }

    .modal_container .btn_close {
        width: 40vw;
        height: 12vw;
        font-size: 4vw;
    }

    .modal_container .btn_close_x {
        border: none;
        cursor: pointer;
        outline: none;
        padding: 0;
        appearance: none;
        width: 16vw;
        height: 16vw;
        border-radius: 50%;
        background: #FF6000;
        text-indent: -99999px;
        position: absolute;
        top: -8vw;
        right: -2vw;
        cursor: pointer;
    }

    .modal_container .btn_close_x::before {
        content: "";
        width: 16vw;
        height: 16vw;
        background: url(/img/goods/common/icon_close_white.svg) no-repeat center center;
        background-size: 5.333333333333333vw 5.333333333333333vw;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 999;
    }

    .modal_container {
        background: #fff;
        width: 92vw;
        height: auto;
        position: fixed;
        z-index: 10005;
        top: 16vw;
        left: calc(50% - 46vw);
        display: none;
        cursor: pointer;
        padding: 4vw 0 8vw;
    }

    .inner_table.width_separator1 th {
        width: 20vw;
    }

    .inner_table.width_separator1 td {
        padding: 14px 0 0 2em;
        border: none;
    }

    .inner_table.width_separator1 td::before {
        content: '…';
        font-size: 12px;
        font-weight: normal;
        position: absolute;
        top: 1em;
        left: 0.25em;
    }

    .inner_table.width_separator1 .indent {
        padding-left: 16px;
        padding-top: 4px;
    }

    .inner_table.width_separator1 .indent+td {
        padding-top: 4px;
    }
}