@keyframes pyonAction
{
    35%
    {
        transform: scale(.97);
    }
    100%
    {
        transform: scale(1);
    }
}
@keyframes pyonAction_large
{
    35%
    {
        transform: scale(.87);
    }
    100%
    {
        transform: scale(1);
    }
}
/* ------------------------
  Print Styles
------------------------ */
@media print
{
    *,
    *:before,
    *:after
    {
        color: #000 !important;
        background: transparent !important;
        box-shadow: none !important;
        text-shadow: none !important;
    }
    a,
    a:visited
    {
        text-decoration: underline;
    }
    tr,
    img
    {
        page-break-inside: avoid;
    }
    img
    {
        max-width: 100% !important;
    }
    p,
    h2,
    h3
    {
        orphans: 3;
        widows: 3;
    }
    h2,
    h3
    {
        page-break-after: avoid;
    }
}
.l-inner
{
    padding: 0 7.4626865672%;
}
@media screen and (max-width: 768px)
{
    .l-inner
    {
        padding: 0 6.25vw;
    }
}

/* ------------------------
  mv
------------------------ */
.mv
{
    position: relative;

    display: flex;

    padding: 40px 0;

    background: #fff;

    align-items: center;
}
@media screen and (max-width: 768px)
{
    .mv
    {
        margin-top: 0;
        padding: 0;
    }
}

@media (min-width: 769px)
{
    .mv_inner
    {
        width: max(84.7222222222vw, 999.7222222222px);
        max-width: 1626px;
        margin: auto;
    }
}

.mv_img
{
    position: relative;

    width: 100%;
}
@media (min-width: 769px)
{
    .mv_img
    {
        height: 75vh;
        min-height: 480px;
        max-height: 803px;
    }
}
@media screen and (max-width: 768px)
{
    .mv_img
    {
        height: 109.375vw;
    }
}

.mv_img_flex
{
    position: relative;
    top: 0;
    left: 0;

    overflow: hidden;

    width: max(28.5416666667vw, 336.7916666667px);
    width: 33.3333333333%;

    flex: 1;
}
@media screen and (max-width: 768px)
{
    .mv_img_flex
    {
        width: 33.28125vw;
    }
    .mv_img_flex:nth-child(2)
    {
        width: 33.4375vw;
    }
}

.mv_img_flex_item
{
    position: absolute;
    top: 0;
    left: 0;

    visibility: hidden;
    overflow: hidden;

    width: 100%;
    height: 100%;

    -webkit-clip-path: 'polygon(0 0, 0 0, 0 100%, 0 100%)';

            clip-path: 'polygon(0 0, 0 0, 0 100%, 0 100%)';
    will-change: opacity, clip-path;
}
@media screen and (max-width: 768px)
{
    .mv_img_flex_item
    {
        width: 100vw;
    }
}
.mv_img_flex_item img
{
    width: 100%;
    height: 100%;

    transform-origin: right center;

    will-change: transform;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
}
.mv_img_flex_item.mv_img_flex_item-1
{
    z-index: 1;
}
.mv_img_flex_item.mv_img_flex_item-2
{
    z-index: 2;
}
.mv_img_flex_item.mv_img_flex_item-3
{
    z-index: 3;
}
.mv_img_flex_item.mv_img_flex_item-4
{
    z-index: 4;
}

.temporary_news
{
    position: absolute;
    z-index: 4000;
    top: 70px;
    right: 0;
    left: 0;

    width: 85.0746268657%;
    margin: auto;

    border: solid 3px #e51626;
}
@media screen and (min-width: 769px)
{
    .temporary_news
    {
        font-size: 16px;
    }
}
@media screen and (max-width: 768px)
{
    .temporary_news
    {
        top: 20.3125vw;
    }
}

.temporary_list
{
    display: flex;
}
@media screen and (max-width: 768px)
{
    .temporary_list
    {
        flex-direction: column;
    }
}
.temporary_list .time
{
    position: relative;

    display: flex;

    width: 15.6140350877%;
    padding: 15px 0 15px 13px;

    color: #fff;
    background: #e60012;

    align-items: center;
}
.temporary_list .time::before
{
    position: absolute;
    top: 0;
    bottom: 0;

    display: block;

    width: 32px;
    height: 32px;
    margin: auto;

    content: '';

    background: url('/img/top/icon_attention_emergency.svg') no-repeat;
}
@media screen and (max-width: 768px)
{
    .temporary_list .time::before
    {
        width: 16px;
        height: 16px;

        background-size: contain;
    }
}
@media screen and (max-width: 768px)
{
    .temporary_list .time
    {
        font-size: 10px;

        width: 100%;
        padding: 7px 9px;
    }
}
.temporary_list .time span
{
    padding-left: 48px;
}
@media screen and (max-width: 768px)
{
    .temporary_list .time span
    {
        padding-left: 22px;
    }
}
.temporary_list .text
{
    width: 100%;

    background: rgba(255, 255, 255, .9);

    flex: 1;
}
@media screen and (max-width: 768px)
{
    .temporary_list .text
    {
        font-size: 14px;
        line-height: 1.2857142857;
    }
}
.temporary_list .link
{
    position: relative;

    display: block;

    width: 100%;
    padding: 15px 42px 15px 21px;

    cursor: pointer;
    transition: opacity .2s cubic-bezier(.215, .61, .355, 1);

    color: #e51626;
}
.temporary_list .link:hover
{
    opacity: .7;
}
@media screen and (min-width: 769px)
{
    .temporary_list .link::after
    {
        position: absolute;
        top: 0;
        right: 20px;
        bottom: 0;

        display: block;

        width: 10px;
        height: 10px;
        margin: auto;

        content: '';
        transform: rotate(45deg);

        border-top: 2px solid #e51626;
        border-right: 2px solid #e51626;
    }
}
@media screen and (max-width: 768px)
{
    .temporary_list .link
    {
        padding: 3.59375vw;
    }
}
@media screen and (max-width: 768px)
{
    .temporary_list .link span::after
    {
        display: inline-block;

        width: 9px;
        height: 9px;

        content: '';
        transform: rotate(45deg);

        border-top: 1px solid #e51626;
        border-right: 1px solid #e51626;
    }
}

@media screen and (max-width: 768px)
{
    .mv_img_item
    {
        height: 128.125vw;
    }
    .mv_img_item-01
    {
        background: url(/img/top/top_mv_img_01_sp.jpg) center top no-repeat;
        background-size: cover;
    }
    .mv_img_item-02
    {
        background: url(/img/top/top_mv_img_02_sp.jpg) center top no-repeat;
        background-size: cover;
    }
    .mv_img_item-03
    {
        background: url(/img/top/top_mv_img_03_sp.jpg) center top no-repeat;
        background-size: cover;
    }
    .mv_img_item-04
    {
        background: url(/img/top/top_mv_img_04_sp.jpg) center top no-repeat;
        background-size: cover;
    }
    .mv_img_item-05
    {
        background: url(/img/top/top_mv_img_05_sp.jpg) center top no-repeat;
        background-size: cover;
    }
}
.top_title
{
    position: absolute;
    z-index: 2000;
    top: max(5.9027777778vw, 69.6527777778px);
    right: 0;
    left: 0;

    width: max(69.4444444444vw, 819.4444444444px);
    max-width: 1682px;
    height: max(9.1666666667vw, 108.1666666667px);
    max-height: 222px;
    margin: auto;

    opacity: 0;
}
@media screen and (max-width: 768px)
{
    .top_title
    {
        top: 20.3125vw;
        left: 0;

        width: 99.84375vw;
        height: 16.40625vw;
    }
}
.top_title img
{
    width: 100%;
}

.top_lead
{
    position: absolute;
    z-index: 2001;
    top: min(-15.2777777778vw, -180.2777777778px);
    right: 0;
    bottom: 0;
    left: 0;

    width: max(43.3333333333vw, 511.3333333333px);
    height: max(.9027777778vw, 10.6527777778px);
    margin: auto;

    opacity: 0;
}
@media screen and (max-width: 768px)
{
    .top_lead
    {
        top: -31.25vw;

        width: 88.75vw;
        height: 2.8125vw;
    }
}
.top_lead img
{
    display: block;

    width: 100%;
}

.top_btn
{
    position: absolute;
    z-index: 2002;
    right: 0;
    bottom: 13%;
    left: 0;

    opacity: 0;
}
@media screen and (max-width: 768px)
{
    .top_btn
    {
        bottom: 3.90625vw;

        width: 70.625vw;
        margin: auto;
    }
    .top_btn span
    {
        padding-right: 4.6875vw;

        white-space: nowrap;
    }
}
.top_btn a
{
    margin-bottom: 15px;
    padding: 0 43px;

    transition: background .42s cubic-bezier(.25, .1, .25, 1);

    color: #4b4b4b;
    background: rgba(255, 255, 255, .7);
}
.top_btn a:hover
{
    animation: pyonAction .52s cubic-bezier(.165, .84, .44, 1) forwards;

    background: #fff;
}
.top_btn a::after
{
    border-color: #4b4b4b;
}
@media screen and (max-width: 768px)
{
    .top_btn a::after
    {
        right: 4.6875vw;
    }
}
@media screen and (max-width: 768px)
{
    .top_btn a
    {
        font-size: 3.125vw;

        width: -moz-fit-content;

        width: fit-content;
        padding: 2.5vw 7.8125vw;

        letter-spacing: .1em;

        border-radius: 6.25vw;
    }
}

.top_btn_lead
{
    font-size: 16px;
    font-weight: bold;

    display: block;

    margin-bottom: 8px;

    letter-spacing: 2px;

    color: #fff;

    filter: drop-shadow(0 0 7px rgba(0, 49, 101, .8));
}
@media screen and (max-width: 768px)
{
    .top_btn_lead
    {
        font-size: 3.125vw;

        margin-bottom: 1.875vw;
    }
}

.top_btn_wrap
{
    display: flex;

    flex-flow: column;
    align-items: center;
}

/* ------------------------
  campaign
------------------------ */
.campaign
{
    border-bottom: 1px solid #a5a5a5;
}
.campaign .slick-list
{
    padding: 25px !important;
}
@media screen and (max-width: 768px)
{
    .campaign .slick-list
    {
        padding: 9.375vw 25px 5.46875vw !important;
    }
}

.campaign_information
{
    margin-top: 60px;
    margin-bottom: 40px;

    text-align: center;
}
.campaign_information .en
{
    font-size: 12px;

    letter-spacing: 2px;
}
@media screen and (max-width: 768px)
{
    .campaign_information .en
    {
        font-size: 2.8125vw;
    }
}
@media screen and (max-width: 768px)
{
    .campaign_information
    {
        margin-top: 4.6875vw;
        margin-bottom: 6.25vw;
    }
}

.campaign_information_title
{
    font-size: 24px;
    font-weight: bold;
    line-height: 1;

    letter-spacing: 5px;
}
@media screen and (max-width: 768px)
{
    .campaign_information_title
    {
        font-size: 4.6875vw;

        letter-spacing: 2px;
    }
}

.campaign_list .slick-track
{
    margin: auto;
}
@media screen and (max-width: 768px)
{
    .campaign_list .slick-slide
    {
        margin: 0 10px;
    }
}

.campaign_list_information
{
    margin: 0 100px 60px;
}
@media screen and (max-width: 768px)
{
    .campaign_list_information
    {
        margin: 0 3.90625vw 5.46875vw;
    }
}
.campaign_list_information > .slick-list
{
    position: relative;

    padding: 0 !important;
}
.campaign_list_information .slick-prev,
.campaign_list_information .slick-next
{
    position: absolute;
    z-index: 100;
    top: 50%;

    width: 70px;
    height: 50px;

    cursor: pointer;
    transform: translateX(-50%);
}
.campaign_list_information .slick-prev::after,
.campaign_list_information .slick-next::after
{
    position: absolute;
    top: 50%;
    left: 50%;

    width: 25px;
    height: 25px;

    content: '';

    border-right: 2px solid #cec3bd;
    border-bottom: 2px solid #cec3bd;
}
@media screen and (max-width: 768px)
{
    .campaign_list_information .slick-prev::after,
    .campaign_list_information .slick-next::after
    {
        width: 3.90625vw;
        height: 3.90625vw;

        border-right: .625vw solid #cec3bd;
        border-bottom: .625vw solid #cec3bd;
    }
}
@media screen and (max-width: 768px)
{
    .campaign_list_information .slick-prev,
    .campaign_list_information .slick-next
    {
        width: 5.46875vw;
        height: 5.46875vw;
    }
}
.campaign_list_information .slick-prev
{
    left: -15px;
}
@media screen and (max-width: 768px)
{
    .campaign_list_information .slick-prev
    {
        left: .9375vw;
    }
}
.campaign_list_information .slick-prev::after
{
    transition: left .4s;
    transform: translate(-50%, -50%) rotate(135deg);
}
@media screen and (min-width: 768px)
{
    .campaign_list_information .slick-prev:hover::after
    {
        left: 38%;
    }
}
.campaign_list_information .slick-next
{
    right: -85px;
}
@media screen and (max-width: 768px)
{
    .campaign_list_information .slick-next
    {
        right: -5vw;
    }
}
.campaign_list_information .slick-next::after
{
    transition: left .4s;
    transform: translate(-50%, -50%) rotate(-45deg);
}
@media screen and (min-width: 768px)
{
    .campaign_list_information .slick-next:hover::after
    {
        left: 62%;
    }
}

.campaign_list_information_item img
{
    width: 100%;

    border-radius: 28px;
}
@media screen and (max-width: 768px)
{
    .campaign_list_information_item img
    {
        border-radius: 5vw;
    }
}
.campaign_list_information_item a
{
    color: #4b4b4b;
}
.campaign_list_information_item a:hover
{
    animation: pyonAction .52s cubic-bezier(.165, .84, .44, 1) forwards;

    color: #094;
}
.campaign_list_information_item p
{
    font-size: 15px;

    margin-top: 22px;
    padding: 0 10px;
}
@media screen and (max-width: 768px)
{
    .campaign_list_information_item p
    {
        font-size: 4.375vw;

        margin-top: 2.34375vw;
        padding: 0;
    }
}

.campaign_list_wrap
{
    padding: 8px 0 50px;

    background: url('/img/top/campaign_list_bg.png');
    background-repeat: repeat-x;
    background-size: cover;
}
@media screen and (max-width: 768px)
{
    .campaign_list_wrap
    {
        padding: 0 0 14.84375vw;
    }
}

.campaign_link
{
    width: 340px;
    margin: 0 auto;

    text-align: center;
}
@media screen and (max-width: 768px)
{
    .campaign_link
    {
        width: 75vw;
    }
}
.campaign_link a
{
    font-size: 18px;
    font-weight: 700;

    display: inline-flex;

    width: 100%;
    min-height: 60px;

    transition: color .3s cubic-bezier(.25, .1, .25, 1);

    justify-content: center;
    align-items: center;
}
@media screen and (max-width: 768px)
{
    .campaign_link a
    {
        font-size: 14px;

        min-height: 15.3125vw;

        border-radius: 7.65625vw;
    }
}
.campaign_link a:hover .icon_news
{
    fill: #fff;
}

/* ------------------------
  news
------------------------ */
.news
{
    padding: 56px 0 60px;
}
@media screen and (max-width: 768px)
{
    .news
    {
        padding: 30px 0 50px;
    }
}

.news_title_wrap
{
    width: 16.2280701754%;
}
@media screen and (max-width: 768px)
{
    .news_title_wrap
    {
        width: 100%;
    }
}

.news_title
{
    font-size: 24px;
    line-height: 1.5;

    white-space: nowrap;
    letter-spacing: 2px;
}
.news_title .en
{
    font-size: 12px;
    font-weight: normal;

    display: block;
}
@media screen and (max-width: 768px)
{
    .news_title .en
    {
        font-size: 2.8125vw;
    }
}
@media screen and (max-width: 768px)
{
    .news_title
    {
        font-size: 4.6875vw;

        margin-bottom: 10px;
    }
}

.emergency_block
{
    margin-bottom: 60px;
}
@media screen and (max-width: 768px)
{
    .emergency_block
    {
        margin-bottom: 39px;
    }
}

.emergency_list_item
{
    background: #fff;
}
.emergency_list_item + .emergency_list_item
{
    margin-top: 2px;
}
.emergency_list_item:nth-child(1)
{
    border-top-left-radius: 24px;
    border-top-right-radius: 24px;
}
@media screen and (max-width: 768px)
{
    .emergency_list_item:nth-child(1)
    {
        border-top-left-radius: 12px;
        border-top-right-radius: 12px;
    }
}
.emergency_list_item:last-child
{
    border-bottom-right-radius: 24px;
    border-bottom-left-radius: 24px;
}
@media screen and (max-width: 768px)
{
    .emergency_list_item:last-child
    {
        border-bottom-right-radius: 12px;
        border-bottom-left-radius: 12px;
    }
}
.emergency_list_item-one
{
    border-radius: 24px;
}
@media screen and (max-width: 768px)
{
    .emergency_list_item-one
    {
        border-radius: 12px;
    }
}
.emergency_list_item a
{
    position: relative;

    display: block;

    padding: 14px 14px 14px 5.350877193%;

    transition: color .42s cubic-bezier(.25, .1, .25, 1);

    color: #4b4b4b;
}
@media screen and (max-width: 768px)
{
    .emergency_list_item a
    {
        font-size: 14px;

        padding: 3.125vw 5vw;
    }
}
.emergency_list_item a:hover
{
    color: #094;
}
.emergency_list_item a:hover .emergency_date
{
    color: #094;
}
.emergency_list_item a::before,
.emergency_list_item a::after
{
    position: absolute;
    top: 0;
    bottom: 0;

    display: block;

    margin: auto;

    content: '';
}
.emergency_list_item a::before
{
    left: 15px;

    width: 31px;
    height: 31px;

    background: url('/img/common/icon_attention.svg') no-repeat;
    background-size: cover;
}
@media screen and (max-width: 768px)
{
    .emergency_list_item a::before
    {
        top: 3.125vw;
        bottom: auto;

        width: 15px;
        height: 15px;
    }
}
.emergency_list_item a::after
{
    right: 2.1929824561%;

    width: 10px;
    height: 10px;

    transform: rotate(45deg);

    border-top: 2px solid #b4b4b4;
    border-right: 2px solid #b4b4b4;
}
@media screen and (max-width: 768px)
{
    .emergency_list_item a::after
    {
        right: 3.28125vw;

        width: 8px;
        height: 8px;

        border-width: 1px;
    }
}
@media screen and (max-width: 768px)
{
    .emergency_list_item
    {
        line-height: 1.5;

        text-align: left;
    }
}

.emergency_date
{
    font-size: 14px;

    margin-right: 18px;

    transition: color .42s cubic-bezier(.25, .1, .25, 1);

    color: #a5a5a5;
}
@media screen and (max-width: 768px)
{
    .emergency_date
    {
        font-size: 10px;

        display: block;

        padding-left: 7.03125vw;
    }
}

.news_block
{
    position: relative;

    display: flex;

    justify-content: space-between;
    align-items: flex-start;
    flex-flow: column;
}
.news_block:last-child
{
    padding-top: 20px;
}
@media screen and (max-width: 768px)
{
    .news_block
    {
        flex-direction: column;
    }
}
.news_block a
{
    font-size: 15px;
}

.news_list
{
    width: 100%;
}

.news_list_item a
{
    display: flex;

    padding-top: 20px;
    padding-bottom: 20px;

    transition: color .42s cubic-bezier(.25, .1, .25, 1);

    border-bottom: 1px solid #dfdbd3;

    align-items: center;
}
.news_list_item a:hover .news_txt
{
    color: #094;
}
.news_list_item a:hover .news_txt::after
{
    border-color: #094;
}
.news_list_item a:hover .news_date
{
    color: #094;
}
@media screen and (max-width: 768px)
{
    .news_list_item a
    {
        display: block;

        padding-bottom: 12px;
    }
}

.news_category
{
    font-size: 12px;

    display: inline-block;

    margin-right: 12px;
    padding: 2px 12px;
    padding: 1px 12px;

    text-align: center;

    color: #4b4b4b;
    border-radius: 20px;
    background: #fff;
}
@media screen and (max-width: 768px)
{
    .news_category
    {
        font-size: 10px;
        line-height: 1;

        width: auto;
        margin-right: 4px;
        padding: 1.5625vw 2.34375vw;
    }
}
.news_category.important
{
    color: #fff;
    background: #db4c1f;
}
.news_category.new_shop
{
    color: #fff;
    border: 1px solid #00a191;
    background-color: #00a191;
}
.news_category.information
{
    color: #fff;
    border: 1px solid #b37512;
    background-color: #b37512;
}
.news_category.service
{
    color: #fff;
    border: 1px solid #1380bf;
    background-color: #1380bf;
}

.news_date
{
    margin-right: 31px;

    transition: color .42s cubic-bezier(.25, .1, .25, 1);
    letter-spacing: .05em;

    color: #a5a5a5;
}
@media screen and (max-width: 768px)
{
    .news_date
    {
        font-size: 10px;
    }
}

.news_txt
{
    position: relative;

    padding-right: 12px;

    transition: color .3s cubic-bezier(.25, .1, .25, 1);

    color: #212020;

    flex: 1;
}
.news_txt::after
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;

    display: block;

    width: 6px;
    height: 6px;
    margin: auto;

    content: '';
    transition: border-color .3s cubic-bezier(.25, .1, .25, 1);
    transform: rotate(45deg);

    border-top: 1px solid #545351;
    border-right: 1px solid #545351;
}
@media screen and (max-width: 768px)
{
    .news_txt::after
    {
        right: 3.28125vw;
    }
}
@media screen and (max-width: 768px)
{
    .news_txt
    {
        font-size: 14px;

        display: block;

        margin-top: 4px;
        padding-right: 12.1875vw;
    }
}

.news_btn
{
    width: 24%;
    height: 50px;
    margin: 30px auto 0;
}
.news_btn:hover .icon_news
{
    fill: #fff;
}
@media screen and (max-width: 768px)
{
    .news_btn
    {
        position: static;

        width: 75vw;
        height: auto;
        margin-top: 20px;

        text-align: center;
    }
}

.icon_news
{
    position: relative;
    z-index: 20;

    width: 10px;
    height: 10px;
    margin: -2px 0 0 6px;

    transition: fill .4s cubic-bezier(.25, .1, .25, 1);

    fill: #97948f;
}

.news_banner
{
    margin-top: 50px;

    text-align: center;
}
@media screen and (max-width: 768px)
{
    .news_banner
    {
        width: calc(100% - 12.5vw);
        margin-right: auto;
        margin-left: auto;
    }
}
.news_banner a
{
    display: inline-block;
}
.news_banner a img
{
    border-radius: 20px;
    box-shadow: 0 3px 7px 0 rgba(0, 0, 0, .2);
}
@media screen and (min-width: 769px)
{
    .news_banner a:hover img
    {
        animation: pyonAction .52s cubic-bezier(.165, .84, .44, 1) forwards;
    }
}

@media (min-width: 769px)
{
    .un_product_linkWrapper
    {
        display: flex;

        max-width: 1140px;
        margin: auto;

        justify-content: space-between;
    }
}

.un_product_link
{
    position: relative;

    width: 87.5vw;
    height: 56.25vw;
    margin: 18.125vw auto 0;

    border-radius: 3.75vw;
    background: center/contain no-repeat url(/img/top//bnr_product_sm.png);
}
@media (min-width: 769px)
{
    .un_product_link
    {
        width: 560px;
        height: 176px;
        margin-top: 50px;

        border-radius: 24px;
        background-image: url(/img/top//bnr_product_lg.png);
    }
}
.un_product_link:hover
{
    animation: pyonAction .52s cubic-bezier(.165, .84, .44, 1) forwards;
}
.un_product_link + .un_product_link
{
    margin-top: 7.8125vw;
}
@media (min-width: 769px)
{
    .un_product_link + .un_product_link
    {
        margin-top: 50px;
        margin-left: 20px;
    }
}
.un_product_link a
{
    position: relative;

    display: flex;

    height: 100%;

    color: #fff;

    justify-content: center;
    align-items: center;
}

.un_product_link_txt
{
    font-size: 5vw;

    position: relative;

    text-align: center;
    letter-spacing: 1vw;
}
@media (min-width: 769px)
{
    .un_product_link_txt
    {
        font-size: 24px;
        line-height: 1;

        letter-spacing: 4.8px;
    }
}
@media (max-width: 768.98px)
{
    .un_product_link__message .un_product_link_txt
    {
        line-height: 1.375;
    }
}
.un_product_link_txt > span
{
    font-family: 'Prompt m';
    font-size: 2.8125vw;
    line-height: 1;

    display: block;

    margin-bottom: .9375vw;

    letter-spacing: .5625vw;
}
@media (min-width: 769px)
{
    .un_product_link_txt > span
    {
        font-size: 12px;

        margin-bottom: 6px;

        letter-spacing: 2.4px;
    }
}

/* ------------------------
  journal
------------------------ */
.journal
{
    position: relative;

    padding: 60px 0 50px;

    background: url('/img/common/journal_bg.jpg');
}
@media screen and (max-width: 768px)
{
    .journal
    {
        padding: 7.96875vw 0;
    }
}

.journal_inner
{
    display: flex;

    transition: background .42s cubic-bezier(.25, .1, .25, 1);

    flex-wrap: wrap;
    justify-content: space-between;
}
@media screen and (max-width: 768px)
{
    .journal_inner
    {
        display: block;

        padding: 0;
    }
}

.journal_title_block
{
    position: relative;

    width: 32.0175438596%;

    border-radius: 12px;
    background: #fff;

    grid-area: item01;
}
.journal_title_block a
{
    display: block;

    height: 100%;
    padding: 16.97802% 13.4615384615%;

    color: #4b4b4b;
    border-radius: 12px;
}
.journal_title_block a .journal_btn
{
    color: #fff;
}
@media screen and (max-width: 768px)
{
    .journal_title_block a
    {
        padding: 12.5vw 12px;
    }
}
.journal_title_block a:hover .journal_btn .journal_btn_inner
{
    animation: pyonAction .52s cubic-bezier(.165, .84, .44, 1) forwards;

    background: #804f35;
}
@media screen and (max-width: 768px)
{
    .journal_title_block
    {
        width: calc(100% - 12.5vw);
        margin: auto;
    }
}

.journal_title
{
    margin-bottom: 54px;

    text-align: center;
}
@media screen and (max-width: 768px)
{
    .journal_title
    {
        width: 37.8125vw;
        margin: 0 auto 24px;
    }
}

@media screen and (max-width: 768px)
{
    .journal_title_txt
    {
        font-size: 15px;
        line-height: 2;
    }
}

.journal_btn
{
    margin: 15px auto 0;
}
@media screen and (max-width: 768px)
{
    .journal_btn
    {
        font-size: 14px;

        position: static;

        margin-top: 10px;
    }
}
.journal_btn .journal_btn_inner
{
    position: relative;

    display: block;
    overflow: hidden;

    padding: 12px 24px;

    transition: background .42s cubic-bezier(.25, .1, .25, 1);

    border-radius: 28px;
    background: #a67b63;
}
.journal_btn .journal_btn_inner::before
{
    position: absolute;
    top: 0;
    left: 0;

    display: block;

    width: 100%;
    height: 100%;

    content: '';
    transition: transform .4s cubic-bezier(.25, .1, .25, 1);
    transform: scale(.5);

    border-radius: 28px;
}
@media screen and (max-width: 768px)
{
    .journal_btn .journal_btn_inner
    {
        padding: 10px 24px;
    }
}

.journal_list
{
    display: flex;

    width: 100%;
    margin: 20px auto 0;
}
@media screen and (max-width: 768px)
{
    .journal_list
    {
        display: block;
    }
}

.journal_list_item
{
    width: 31.9298245614%;
}
@media screen and (min-width: 769px)
{
    .journal_list_item
    {
        margin-right: 2.1052631579%;
    }
    .journal_list_item:last-of-type
    {
        margin-right: 0;
    }
}
@media screen and (max-width: 768px)
{
    .journal_list_item
    {
        width: 100%;
    }
}

.journal_list_item-large
{
    width: 65.7894736842%;
}
@media screen and (max-width: 768px)
{
    .journal_list_item-large
    {
        display: none;
    }
}

/* ------------------------
  osusume
------------------------ */
.osusume_menu
{
    padding-top: 41px;
    padding-bottom: 25px;

    background-image: url('/img/top/osusume_menu_bg.jpg');
    background-position: center;
    background-size: cover;
}
@media screen and (max-width: 768px)
{
    .osusume_menu
    {
        overflow-x: clip;

        padding-top: 17.96875vw;
        padding-bottom: 0;
    }
}

.menu_deco
{
    position: absolute;
    z-index: 1;

    -webkit-user-select: none;

       -moz-user-select: none;

            user-select: none;
}
.menu_deco.__01
{
    top: 8px;
    left: -184px;

    -webkit-clip-path: polygon(0% 0%, 0 100%, 52% 100%, 53% 50%, 77% 61%, 72% 73%, 73% 75%, 79% 64%, 91% 56%, 88% 43%, 100% 29%, 100% 1%);

            clip-path: polygon(0% 0%, 0 100%, 52% 100%, 53% 50%, 77% 61%, 72% 73%, 73% 75%, 79% 64%, 91% 56%, 88% 43%, 100% 29%, 100% 1%);
}
@media screen and (max-width: 768px)
{
    .menu_deco.__01
    {
        top: auto;
        bottom: 5.15625vw;
        left: -9.375vw;

        width: 96.09375vw;

        -webkit-clip-path: polygon(0% 0%, 0% 49%, 5% 70%, 8% 94%, 17% 95%, 67% 99%, 100% 98%, 100% 2%, 90% 24%, 81% 32%, 65% 26%, 60% 52%, 54% 61%, 45% 38%, 36% 30%, 31% 75%, 14% 59%, 8% 12%, 7% 0%);

                clip-path: polygon(0% 0%, 0% 49%, 5% 70%, 8% 94%, 17% 95%, 67% 99%, 100% 98%, 100% 2%, 90% 24%, 81% 32%, 65% 26%, 60% 52%, 54% 61%, 45% 38%, 36% 30%, 31% 75%, 14% 59%, 8% 12%, 7% 0%);
    }
}
.menu_deco.__02
{
    top: -3px;
    right: -182px;

    -webkit-clip-path: polygon(0% 0%, 0 16%, 14% 44%, 18% 53%, 30% 69%, 19% 78%, 22% 87%, 44% 83%, 54% 100%, 100% 100%, 100% 0%);

            clip-path: polygon(0% 0%, 0 16%, 14% 44%, 18% 53%, 30% 69%, 19% 78%, 22% 87%, 44% 83%, 54% 100%, 100% 100%, 100% 0%);
}
@media screen and (max-width: 768px)
{
    .menu_deco.__02
    {
        top: -19.6875vw;
        right: auto;
        left: -10vw;

        width: 101.5625vw;

        -webkit-clip-path: none;

                clip-path: none;
    }
}
.menu_deco img
{
    width: 100%;
}

.menu_list
{
    position: relative;

    width: 910px;
    margin: 0 auto;
}
@media screen and (max-width: 768px)
{
    .menu_list
    {
        width: 85.9375vw;
    }
}
.menu_list img
{
    width: 100%;
}

.menu_list_inner
{
    position: relative;
}

.menu_lead
{
    font-size: 18px;
    line-height: 1;

    position: absolute;
    bottom: 40px;
    left: 50%;

    width: 100%;

    transform: translateX(-50%);
    text-align: center;
    letter-spacing: .2em;

    color: #4b4b4b;
}
@media screen and (max-width: 768px)
{
    .menu_lead
    {
        font-size: 4.0625vw;
        line-height: 1.538;

        top: 37.5vw;
        bottom: auto;
    }
}

.menu_list_link
{
    position: relative;
    bottom: 25px;

    display: flex;

    width: 910px;

    border-bottom-right-radius: 20px;
    border-bottom-left-radius: 20px;
    background-color: #094;

    justify-content: center;
}
@media screen and (max-width: 768px)
{
    .menu_list_link
    {
        bottom: 23.125vw;

        flex-direction: column;

        width: 100%;
    }
}

.menu_list_top
{
    position: absolute;
    bottom: 80px;
    left: 50%;

    width: 100%;
    max-width: 400px;

    transition: .3s;
    transform: translateX(-46%);
}
@media screen and (max-width: 768px)
{
    .menu_list_top
    {
        top: 24.0625vw;
        bottom: auto;

        width: 73.4375vw;
        max-width: none;

        transform: translateX(-50%);
    }
}
.menu_list_top:hover
{
    opacity: .5;
}

.menu_list_link_item
{
    position: relative;

    width: -moz-fit-content;

    width: fit-content;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item
    {
        width: 100%;
    }
}
.menu_list_link_item:first-of-type
{
    border-bottom-left-radius: 20px;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item:first-of-type
    {
        border-bottom-left-radius: 0;
    }
}
.menu_list_link_item:last-of-type
{
    border-bottom-right-radius: 20px;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item:last-of-type
    {
        border-bottom-right-radius: 3.125vw;
        border-bottom-left-radius: 3.125vw;
    }
}
.menu_list_link_item a
{
    position: relative;

    display: inline-flex;

    width: 100%;
    padding: 26px 0 29px;

    transition: .3s;
    white-space: nowrap;

    justify-content: center;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item a
    {
        padding: 0 6.25vw;

        white-space: normal;

        justify-content: left;
    }
}
.menu_list_link_item a:hover
{
    opacity: .5;
}
.menu_list_link_item:first-of-type a
{
    border-bottom-left-radius: 20px;
}
.menu_list_link_item:first-of-type a span
{
    padding-left: 65px;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item:first-of-type a
    {
        border-bottom-left-radius: 0;
    }
    .menu_list_link_item:first-of-type a span
    {
        padding-top: 6.5625vw;
        padding-left: 0;
    }
}
.menu_list_link_item:last-of-type a
{
    border-bottom-right-radius: 20px;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item:last-of-type a
    {
        border-bottom-right-radius: 3.125vw;
        border-bottom-left-radius: 3.125vw;
    }
}
.menu_list_link_item:last-of-type a span
{
    padding-right: 65px;
}
.menu_list_link_item:last-of-type a span::after
{
    background-image: none;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item:last-of-type a span
    {
        padding-right: 0;
        padding-bottom: 6.5625vw;
    }
}
.menu_list_link_item:not(:first-child) .menu_list_link_item_text::before
{
    position: absolute;
    top: 50%;
    left: 0;

    width: 1px;
    height: 100%;
    min-height: 40px;

    content: '';
    transform: translateY(-50%);

    background-image: linear-gradient(to bottom, rgba(255, 255, 255, .6), rgba(255, 255, 255, .6) 5px, transparent 5px, transparent 6px);
    background-size: 1px 6px;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item:not(:first-child) .menu_list_link_item_text::before
    {
        top: 0;

        width: 100%;
        height: 1px;
        min-height: auto;

        transform: inherit;

        border-right: none;
        background-image: linear-gradient(to right, rgba(255, 255, 255, .6), rgba(255, 255, 255, .6) 5px, transparent 5px, transparent 8px);
        background-size: 8px 1px;
    }
}

.menu_list_link_item_text
{
    font-size: 16px;
    font-weight: bold;
    line-height: .88;

    position: relative;

    width: 100%;
    padding: 0 18px;

    letter-spacing: .2em;

    color: #fff;
}
@media screen and (max-width: 768px)
{
    .menu_list_link_item_text
    {
        font-size: 14px;

        padding: 5.15625vw 0;
    }
}

/* ------------------------
  related
------------------------ */
.related
{
    padding: 60px 0 70px;
}
@media screen and (max-width: 768px)
{
    .related
    {
        padding: 40px 0 0;
    }
}

.related_list_item
{
    position: relative;
}
.related_list_item:not(:last-of-type) a
{
    display: block;

    border-radius: 22px;
}
.related_list_item:not(:last-of-type) a:hover
{
    animation: pyonAction .52s cubic-bezier(.165, .84, .44, 1) forwards;
}
.related_list_item a
{
    color: #fff;
}
@media screen and (max-width: 768px)
{
    .related_list_item:not(:first-child)
    {
        margin-top: 15px;
    }
}
.related_list_item figure
{
    border-radius: 22px;
}

.related_list_item_title
{
    font-size: 24px;

    position: absolute;
    z-index: 100;
    top: 20px;
    left: 20px;
}
.related_list_item_title span
{
    font-size: 12px;
    font-weight: normal;

    display: block;

    letter-spacing: 2px;
}
@media screen and (max-width: 768px)
{
    .related_list_item_title span
    {
        font-size: 10px;
    }
}
@media screen and (max-width: 768px)
{
    .related_list_item_title
    {
        font-size: 18px;
        line-height: 1.3333333333;
    }
}

.related_list
{
    display: grid;

    grid-template-areas: 'item01 item02' 'item03 item04' 'item05 item05';
    grid-template-rows: repeat(3, auto);
    grid-template-columns: repeat(2, 1fr);
    grid-row-gap: 19px;
    grid-column-gap: 24px;
}
@media screen and (max-width: 768px)
{
    .related_list
    {
        display: block;
    }
}

.related_list_item
{
    border-radius: 22px;
}
.related_list_item:nth-child(1)
{
    grid-area: item01;
}
.related_list_item:nth-child(2)
{
    grid-area: item02;
}
.related_list_item:nth-child(3)
{
    grid-area: item03;
}
.related_list_item:nth-child(4)
{
    grid-area: item04;
}
.related_list_item:nth-child(5)
{
    background: #4b4b4b;

    grid-area: item05;
}
.related_list_item img
{
    width: 100%;

    border-radius: 22px;
}

.related_sitemap_list
{
    display: flex;

    padding: 2.2807017544% 2.6315789474%;

    flex-wrap: wrap;
}
@media screen and (max-width: 768px)
{
    .related_sitemap_list
    {
        padding: 18px 5.625vw;

        align-items: baseline;
    }
}

.related_sitemap_list_item
{
    line-height: 1.4;

    display: flex;

    width: 100%;
    margin-right: 16px;

    align-items: baseline;
}
@media screen and (min-width: 769px)
{
    .related_sitemap_list_item:not(:first-child)
    {
        margin-top: 14px;
    }
    .related_sitemap_list_item:nth-child(n+4)
    {
        width: auto;
    }
    .related_sitemap_list_item-m
    {
        width: 35.8422939068%;
    }
    .related_sitemap_list_item-s
    {
        width: 28.6738351254%;
    }
}
@media screen and (max-width: 768px)
{
    .related_sitemap_list_item
    {
        flex-direction: column;

        width: 50%;
        margin-right: 0;
    }
    .related_sitemap_list_item:nth-child(n+3)
    {
        margin-top: 12px;
    }
}
.related_sitemap_list_item > a
{
    font-weight: bold;
}
.related_sitemap_list_item a
{
    font-size: 14px;

    transition: color .4s cubic-bezier(.25, .1, .25, 1);
}
.related_sitemap_list_item a:hover
{
    color: #93e4a0;
}
.related_sitemap_list_item a:hover .footer_icon
{
    fill: #93e4a0;
}

.related_sitemap_inner_list
{
    display: flex;
}
@media screen and (min-width: 769px)
{
    .related_sitemap_inner_list li
    {
        margin-left: 16px;
    }
}
@media screen and (max-width: 768px)
{
    .related_sitemap_inner_list li
    {
        margin-top: 7px;
    }
}
@media screen and (max-width: 768px)
{
    .related_sitemap_inner_list
    {
        flex-direction: column;

        margin-top: 5px;
    }
}

.external_link a
{
    font-weight: bold;
}

/* ------------------------
  related
------------------------ */
/* 
.related{
  padding: 60px 0 70px;
  @include small-screen{
    padding: 40px 0 0;
  }
}
.related_list_item{
  position: relative;
  &:not(:last-of-type){
    a{
      display: block;
      border-radius: 22px;
      &:hover{
        @include hoverAction;
      }
    }
  }
  a{
    color: #fff;
  }
  @include small-screen{
    &:not(:first-child){
     margin-top: 15px; 
    }
  }
  figure{
    border-radius: 22px;
  }
}
.related_list_item_wrap {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 92px;
  display: flex;
  flex-flow: row;
  align-items: center;
  justify-content: center;
  background: rgba($color: #f29b00, $alpha: 0.85);
  border-radius: 0 0 22px 22px ;
  @include small-screen{
    height: vw(140);
    border-radius: 0 0 12px 12px;
  }
}
.related_list_item_title{
  flex-basis: 45%;
  font-size: 24px;
  text-align: center;
  letter-spacing: 3px;
  span{
    display: block;
    font-size: 12px;
    font-weight: normal;
    letter-spacing: 2px;
    @include small-screen{
      font-size: 10px;
    }
  }
  @media screen and (max-width: 1240px) {
    font-size: 22px;
  }
  @include small-screen{
    flex-basis: 35%;
    padding: 0 vw(30);
    font-size: vw(28);
    line-height: lh(36, 48);
    text-align: left;
  }
}
.related_list_item_text {
  position: relative;
  flex-basis: 55%;
  padding: 0 30px;
  font-size: 15px;
  &::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 1px;
    height: calc(92px - 1.5rem);
    background: #fff;
    @include small-screen{
      height: calc(21.875vw - 1.5rem);
    }
  }
  @media screen and (max-width: 1240px) {
    font-size: 14px;
  }
  @include small-screen{
    flex-basis: 65%;
    padding: 0 vw(30);
    font-size: vw(22);
  }
}
.related_list{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(3, auto);
  grid-template-areas: 
  "item01 item02"
  "item03 item04"
  "item05 item05";
  grid-column-gap: 24px;
  grid-row-gap: 19px;
  @include small-screen{
    display: block;
  }
}
.related_list_item{
  border-radius: 22px;
  &:nth-child(1){
    grid-area: item01;
  }
  &:nth-child(2){
    grid-area: item02;
  }
  &:nth-child(3){
    grid-area: item03;
  }
  &:nth-child(4){
    grid-area: item04;
  }
  &:nth-child(5){
    grid-area: item05;
    background: #4b4b4b;
  }
  img{
    width: 100%;
    border-radius: 22px;
    @include small-screen {
      height: vw(300);
      object-fit: cover;
      border-radius: 12px;
    }
  }
}
.related_sitemap_list{
  display: flex;
  flex-wrap: wrap;
  // padding: wr(26, 558) wr(30, 558);
  padding: wr(26, 1140) wr(30, 1140);
  @include small-screen{
    padding: 18px vw(36);
    align-items: baseline;
  }
}
.related_sitemap_list_item{
  display: flex;
  align-items: baseline;
  width: 100%;
  margin-right: 16px;
  line-height: 1.4;
  @include exLarge-screen{
    &:not(:first-child){
      margin-top: 14px;
    }
    &:nth-child(n+4){
      width: auto;
    }
    &-m{
      width: wr(200, 558);
    }
    &-s{
      width: wr(160, 558);
    }
  }
  @include small-screen{
    width: 50%;
    margin-right: 0;
    flex-direction: column;
    &:nth-child(n+3){
      margin-top: 12px;
    }
  }
  > a{
    font-weight: bold;
  }
  a{
    font-size: 14px;
    transition: color .4s $ease;
    &:hover{
      color: #93e4a0;
      .footer_icon{
        fill: #93e4a0;
      }
    }
  }
}
.related_sitemap_inner_list{
  display: flex;
  li{
    @include exLarge-screen{
      margin-left: 16px;
    }
    @include small-screen{
      margin-top: 7px;
    }
  }
  @include small-screen{
    margin-top: 5px;
    flex-direction: column;
  }
}
.external_link{
  a{
    font-weight: bold;
  }
}
*/
.banner_link
{
    display: flex;
    overflow: hidden;

    width: 86.875vw;
    margin: 0 auto 10.15625vw;

    border-radius: 3.125vw;

    justify-content: center;
    align-items: center;
}
@media (min-width: 769px)
{
    .banner_link
    {
        width: 830px;
        margin: 0;

        border-radius: 20px;
    }
}
.banner_link:hover
{
    animation: pyonAction .52s cubic-bezier(.165, .84, .44, 1) forwards;
}
.banner_link.banner_link__wide
{
    margin-bottom: 7.5vw;
}
@media (min-width: 769px)
{
    .banner_link.banner_link__wide
    {
        width: 395px;
        margin-right: -9px;
        margin-bottom: 0;
    }
}
@media screen and (max-width: 768px)
{
    .banner_link.banner_link__wide a
    {
        margin-right: -2.96875vw;
    }
}

@media (min-width: 769px)
{
    .banner_link_wrapper
    {
        display: flex;

        width: 1000px;
        margin: 0 auto 32px;

        justify-content: space-between;
        gap: 25px;
    }
}

/* ------------------------
  modal
------------------------ */
.modal_body
{
    position: fixed;
    z-index: 5000;
    top: 0;
    left: 0;

    visibility: hidden;
    overflow: auto;

    width: 100%;
    height: 100%;
    padding: 180px 40px;

    transition: opacity .4s cubic-bezier(.25, .46, .45, .94), visibility .4s cubic-bezier(.25, .46, .45, .94);

    opacity: 0;
}
.modal_body.is-showModalCont
{
    visibility: visible;

    cursor: pointer;

    opacity: 1;
}
@media screen and (max-width: 768px)
{
    .modal_body
    {
        display: flex;

        padding: 10.9375vw 3.125vw;

        flex-flow: column;
        align-items: center;
    }
}

.modal_cont
{
    position: relative;
    z-index: 5001;

    width: 1020px;
    margin: auto;

    border-radius: 28px;
}
@media screen and (max-width: 768px)
{
    .modal_cont
    {
        width: 100%;
    }
}

.modal_mask
{
    position: fixed;
    z-index: 5000;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;

    background: rgba(0, 0, 0, .9);
}

.modal_colse_btn
{
    position: absolute;
    top: -31px;
    right: -31px;

    width: 60px;
    height: 60px;

    border-radius: 50%;
    background: #094;
}
@media screen and (max-width: 768px)
{
    .modal_colse_btn
    {
        top: -28px;
        right: 2.25vw;

        width: 22px;
        height: 22px;

        background: none;
    }
}
.modal_colse_btn span
{
    position: relative;

    display: block;

    width: 100%;
    height: 100%;
}
.modal_colse_btn span::before,
.modal_colse_btn span::after
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;

    display: block;

    width: 30px;
    height: 2px;
    margin: auto;

    content: '';

    background: #fff;
}
@media screen and (max-width: 768px)
{
    .modal_colse_btn span::before,
    .modal_colse_btn span::after
    {
        width: 12px;
        height: 1px;

        border-radius: 2px;
    }
}
.modal_colse_btn span::before
{
    transform: rotate(-45deg);
}
.modal_colse_btn span::after
{
    transform: rotate(45deg);
}

.modal_block
{
    width: 100%;
    height: 100%;
}

.modal_content
{
    width: 100%;
    height: 510px;
}
@media screen and (max-width: 768px)
{
    .modal_content
    {
        height: 46.875vw;
    }
}

.modalClose
{
    position: relative;
    z-index: 5001;

    margin-top: 30px;
}
.modalClose a
{
    padding: 0 4%;
}
.modalClose a::after
{
    font-size: 22px;

    width: auto;
    height: auto;

    content: '+';

    border: none;
}
@media screen and (max-width: 768px)
{
    .modalClose a::after
    {
        top: 1.25vw;
    }
}
@media screen and (max-width: 768px)
{
    .modalClose a
    {
        width: 39.0625vw;
        padding: 3%;
    }
}

.modal_title
{
    font-size: 32px;
    font-weight: bold;

    padding: 60px 0 0 60px;

    letter-spacing: 4px;

    color: #fff;
}
@media screen and (max-width: 768px)
{
    .modal_title
    {
        font-size: 14px;
        line-height: 1.7142857143;

        padding: 7.8125vw 0 0 7.8125vw;

        letter-spacing: 2px;
    }
}
