@charset "UTF-8";
html {
	container-type: inline-size;
}
.tabi_mae {
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
		--tmcolor : #004D98;
		--yumin : "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}

.section_inner {
    width: 1200px;
    margin-inline: auto;
}
.section_title {
    text-align: center;
    margin-bottom: 40px;
}
.section_title_main {
    color: var(--tmcolor);
    font-size: 30px;
    font-weight: 700;
}
.section_title_en {
    font-family: var(--yumin);
    text-transform: uppercase;
    color: #9CCAE6;
    font-size: 12px;
    font-weight: 500;
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-top: 10px;
}
.section_title_en::before, .section_title_en::after {
    content: "";
    display: inline-block;
    width: 70px;
    height: 1px;
    background: #9CCAE6;
}
#mv img {
    width: 100%;
}
#lead {
    padding-block: 60px;
    background: #EBF7FF;
}
.lead_catch {
    text-align: center;
    color: var(--tmcolor);
    font-size: 24px;
    font-weight: 700;
    line-height: 1.5;
    margin-bottom: 30px;
}
.lead_text {
    text-align: center;
    color: var(--tmcolor);
    font-size: 19px;
    font-weight: 600;
}
#nav {
    padding-block: 60px;
    background: url(bg01.png) no-repeat left top / cover #B0E3F6;
    background-blend-mode: soft-light;
}
.nav_content {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: stretch;
    gap: 10px;
}
.nav_item {
    width: 280px;
}
.nav_item a {
    display: flex;
    flex-flow: column wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    gap: 10px;
    width: 100%;
    height: 100%;
    background: #fff;
    border: 3px solid #B4D7EC;
    border-radius: 4px;
    padding-block: 24px 16px;
    text-align: center;
    color: var(--tmcolor);
    font-size: 19px;
    font-weight: 700;
}
.nav_item a::after {
    content: "";
    display: inline-block;
    width: 14px;
    height: 7px;
    background: var(--tmcolor);
    clip-path: polygon(0 20%, 10% 0, 50% 60%, 90% 0, 100% 20%, 50% 100%);
}
#merit {
    padding-block: 80px;
}
.merit_content {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: space-between;
    align-items: stretch;
    gap: 98px 0;
    width: min(100%, 1300px);
    margin-inline: auto;
}
.merit_item {
    width: 400px;
    display: flex;
    flex-flow: column wrap;
    align-content: center;
    justify-content: space-between;
    align-items: flex-start;
}
.merit_head {
    display: flex;
    flex-flow: row wrap;
    gap: 16px;
    margin-bottom: 16px;
}
.merit_num {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    width: 54px;
    height: 54px;
    background: #E1F5FF;
    border-radius: 300px;
    font-family: var(--yumin);
    color: var(--tmcolor);
    font-size: 40px;
    font-weight: 600;
    line-height: 1;
    padding-top: 6px;
    position: relative;
}
.merit_num::after {
    content: "";
    display: inline-block;
    width: 45px;
    height: 14px;
    background: url(merit.png) no-repeat center / contain;
    position: absolute;
    top: -2px;
    left: 50%;
    translate: -50% 0;
}
.merit_textwrap {
    flex: 1;
}
.merit_catch {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
    height: 54px;
    color: var(--tmcolor);
    font-size: 20px;
    font-weight: 700;
}
.merit_text {
    font-size: 16px;
    font-weight: 600;
}
.merit_link {
    margin-top: 20px;
}
.merit_link a {
    color: var(--tmcolor);
    font-size: 16px;
    font-weight: 600;
    text-decoration: underline;
}
#pickup {
    background: #E8EFFD;
    padding-block: 80px;
}
.pickup_text {
    text-align: center;
    font-size: 19px;
    font-weight: 500;
    margin-bottom: 30px;
}
.pickup_coupon {
    margin-bottom: 30px;
    background: #94B4FE;
    border-radius: 20px;
    padding-block: 26px;
}
.pickup_coupon_inner {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    gap: 16px;
}
.tabi_mae-coupon-code {
    display: flex;
    flex-flow: row;
    justify-content: center;
    align-items: stretch;
    height: 48px;
}
.tabi_mae-coupon-code dt,
.tabi_mae-coupon-code dd {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
}
.tabi_mae-coupon-code dt {
    background: #121659;
    border-radius: 7px 0 0 7px;
    padding-inline: 20px;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
}
.tabi_mae-coupon-code dd {
    background: #fff;
    border: 1px solid #707070;
    border-radius: 0 7px 7px 0;
    padding-inline: 20px;
    font-size: 23px;
    font-weight: 500;
}
.tabi_mae-coupon-copy button {
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: stretch;
    height: 48px;
    align-content: center;
    background: #B40000;
    border: none;
    border-radius: 7px;
    padding-inline: 24px;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
}
.pickup_content {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: flex-start;
    align-items: stretch;
    gap: 24px;
    margin-bottom: 50px;
}
.pickup_item {
    width: calc((100% - 48px) / 3);
    background: #fff;
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    border-radius: 20px;
    padding-block: 18px;
}
.pickup_icon {
    width: 58px;
}
.pickup_catch {
    text-align: center;
    color: #121659;
    font-size: 20px;
    font-weight: 700;
    padding-inline: 24px;
}
.section_btn a {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    width: 480px;
    margin-inline: auto;
    padding-block: 14px;
    background: var(--tmcolor);
    border-radius: 300px;
    color: #fff;
    font-size: 19px;
    font-weight: 700;
    position: relative;
}
.section_btn a::before {
    content: "";
    display: inline;
    width: 22px;
    height: 22px;
    background: #fff;
    border-radius: 300px;
    position: absolute;
    right: 20px;
    top: 50%;
    translate: 0 -50%;
}
.section_btn a::after {
    content: "";
    display: inline-block;
    width: 6px;
    height: 10px;
    background: var(--tmcolor);
    clip-path: shape(from 52% 50%, line to 12% 76%, arc to 28% 94% of 13% 8%, line to 88% 56%, arc to 85% 44% of 10% 8%, line to 28% 6%, arc to 12% 24% of 13% 8%);
    position: absolute;
    right: 27px;
    top: 50%;
    translate: 0 -50%;
}

#ranking {
    padding-block: 80px;
}
.ranking_subtitle {
    color: var(--tmcolor);
    text-align: center;
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 20px;
}
.ranking_text.section_text {
    text-align: center;
    font-size: 19px;
    font-weight: 500;
    margin-bottom: 40px;
}
.ranking_content {
    margin-bottom: 30px;
}
.swiper {
    padding-bottom: 40px;
}
.swiper-button-prev, .swiper-button-next {
    display: inline-block;
    width: 43px;
    height: 43px;
    background: var(--tmcolor);
    border-radius: 300px;
    position: absolute;
    bottom: 60%;
    z-index: 2;
    cursor: pointer;
}
.swiper-button-prev {
    inset: initial;
    right: calc(100% + 8px);
    top: 120px;
}
.swiper-button-next {
    inset: initial;
    left: calc(100% + 8px);
    top: 120px;
		rotate: y 180deg;
}
.swiper-button-prev::after, .swiper-button-next::after {
    content: "";
    display: inline-block;
    width: 15px;
    height: 6px;
    background: #fff;
    clip-path: shape(from 35% 5%, arc to 44% 16% of 5% 10% cw, line to 18% 80%, line to 95% 80%, arc to 95% 100% of 5% 10% cw, line to 8% 100%, arc to 4% 84% of 5% 10% cw, close);
    position: absolute;
    left: 50%;
    top: 50%;
    translate: -50% -50%;
}
.swiper-pagination {
    width: 100%;
    height: 4px;
    background: #EBEBEB;
    bottom: 0;
		cursor: pointer;
}
.swiper-pagination .swiper-scrollbar-drag {
    background: var(--tmcolor);
}

.block-ranking-lightningrecommend .block-ranking-r--goods-image .block-ranking-r--rank {
    font-style: normal;
    font-size: 30px;
    left: 10px;
    top: 10px;
}
.block-ranking-lightningrecommend .block-ranking-r--goods-name a {
    text-align: left;
    display: inline-block;
    color: var(--tmcolor);
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 20px;
}
.variation-name {
    display: none;
}
.block-ranking-lightningrecommend .block-ranking-r--price {
    text-align: left;
    color: var(--tmcolor);
    font-size: 18px;
    font-weight: 500;
}

#feature {
    padding-block: 0 80px;
}
#feature .section_title {
    margin-bottom: 20px;
}
#feature .section_title_main {
    font-size: 26px;
}
#feature .section_title_en {
    display: none;
}
.feature_text.section_text {
    text-align: center;
    font-size: 19px;
    font-weight: 500;
    margin-bottom: 40px;
}
.feature_content {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 30px 27px;
}
.feature_item {
    width: calc((100% - 54px) / 3);
}
.feature_fukidashi {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    background: #D1EFFE;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), calc(50% + 15px) calc(100% - 10px), 50% 100%, calc(50% - 15px) calc(100% - 10px), 0 calc(100% - 10px));
    padding-block: 8px 22px;
    text-align: center;
    color: var(--tmcolor);
    font-size: 20px;
    font-weight: 500;
    line-height: 1.3;
}


#offer {
    padding-block: 80px;
    background: #EBF7FF;
}
.offer_content {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: flex-start;
    align-items: stretch;
    gap: 30px;
}
.offer_item {
    width: calc(50% - 15px);
}
.offer_item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}


#howto {
    padding-block: 80px;
}
.howto_content {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: space-between;
    align-items: stretch;
    gap: 30px;
}
.howto_item_l {
    width: calc(50% - 15px);
}
.howto_item_l a {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    background: #F1F1F6;
}
.howto_item_l_textimg {
    width: 110px;
    padding: 18px 30px 10px;
}
.howto_item_l_wrap {
    flex: 1;
}
.howto_item_l_img {
    border-radius: 0 0 0 40px;
    overflow: hidden;
}
.howto_item_l_logo {
    text-align: center;
    padding: 12px;
}
.howto_item_l_logo img {
    width: 150px;
}
.howto_item_wrap {
    display: flex;
    flex-flow: column wrap;
    align-content: center;
    justify-content: space-between;
    align-items: stretch;
    width: calc(50% - 15px);
}
.howto_item_s {
    height: 120px;
    width: 100%;
}
.howto_item_s a {
    background: #F1F1F6;
    border: 3px solid #D7D7E8;
    position: relative;
    display: inline-block;
    width: 100%;
    height: 100%;
}
.howto_item_s_img {
    width: 100%;
    height: 100%;
    clip-path: polygon(70% 0, 100% 0, 100% 100%, 40% 100%);
}
.howto_item_s_img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: right center;
}
.howto_item_s_text {
    position: absolute;
    left: 40px;
    top: 50%;
    translate: 0 -50%;
    color: #131659;
    font-size: 28px;
    font-weight: 700;
}


[data-browse-mode="P"] a img:hover {
    opacity: 1;
}
[data-browse-mode="P"] a:hover img {
    opacity: .7;
}



[data-browse-mode="S"] .section_inner {
    width: 100%;
}
[data-browse-mode="S"] .section_title {
    margin-bottom: 30px;
}
[data-browse-mode="S"] .section_title_main {
    font-size: 24px;
}
[data-browse-mode="S"] .section_title_en {
    font-size: 10px;
}


[data-browse-mode="S"] #lead {
    padding-block: 40px;
}
[data-browse-mode="S"] .lead_catch {
    font-size: 18px;
    margin-bottom: 20px;
}
[data-browse-mode="S"] .lead_text {
    font-size: 14px;
}

[data-browse-mode="S"] #nav {
    padding: 40px 15px;
}
[data-browse-mode="S"] .nav_item {
    width: calc(50% - 5px);
}
[data-browse-mode="S"] .nav_item:nth-of-type(1) {
    width: 100%;
}
[data-browse-mode="S"] .nav_item a {
    flex-flow: row wrap;
    height: 70px;
    padding-block: 0;
    font-size: 16px;
}

[data-browse-mode="S"] #merit {
    padding: 40px 15px;
}
[data-browse-mode="S"] .merit_content {
    flex-flow: column wrap;
    gap: 50px;
}
[data-browse-mode="S"] .merit_item {
    width: min(100%, 400px);
}

[data-browse-mode="S"] #pickup {
    padding: 40px 15px;
}
[data-browse-mode="S"] .pickup_text {
    font-size: 16px;
    margin-bottom: 24px;
}
[data-browse-mode="S"] .pickup_coupon_inner {
    gap: 10px;
}
[data-browse-mode="S"] .pickup_coupon {
    margin-bottom: 10px;
    padding: 20px 30px;
    border-radius: 10px;
}
[data-browse-mode="S"] .tabi_mae-coupon-code {
    height: 36px;
    width: 100%;
}
[data-browse-mode="S"] .tabi_mae-coupon-code dt,
[data-browse-mode="S"] .tabi_mae-coupon-code dd {
    padding-inline: 0;
    width: 50%;
}
[data-browse-mode="S"] .tabi_mae-coupon-copy button {
    height: 36px;
    width: 168px;
}
[data-browse-mode="S"] .pickup_content {
    gap: 10px;
    margin-bottom: 30px;
}
[data-browse-mode="S"] .pickup_item {
    width: calc(50% - 5px);
    border-radius: 10px;
    padding: 15px 20px;
    justify-content: space-between;
}
[data-browse-mode="S"] .pickup_catch {
    text-align: left;
    font-size: 14px;
    padding-inline: 0;
    width: calc(100% - 40px);
}
[data-browse-mode="S"] .pickup_icon {
    width: 35px;
}
[data-browse-mode="S"] .section_btn a {
    width: min(100%, 380px);
    font-size: 15px;
    padding-right: 20px;
}

[data-browse-mode="S"] #ranking {
    padding: 40px 15px;
}
[data-browse-mode="S"] .ranking_subtitle {
    font-size: 20px;
    margin-bottom: 20px;
}
[data-browse-mode="S"] .ranking_text.section_text {
    font-size: 16px;
    margin-bottom: 30px;
}
[data-browse-mode="S"] .block-ranking-lightningrecommend .block-ranking-r--items {
    overflow: visible;
}
[data-browse-mode="S"] .block-ranking-lightningrecommend .block-ranking-r--items li {
    flex-wrap: nowrap;
}
[data-browse-mode="S"] .pane-main .swiper-pagination {
    display: flex;
    justify-content: flex-start;
}

[data-browse-mode="S"] #feature {
    padding: 0 15px 40px;
}
[data-browse-mode="S"] #feature .section_title_main {
    font-size: 20px;
}
[data-browse-mode="S"] .feature_text.section_text {
    font-size: 16px;
    margin-bottom: 30px;
}
[data-browse-mode="S"] .feature_content {
    gap: 20px;
}
[data-browse-mode="S"] .feature_item {
    width: calc(50% - 10px);
}
[data-browse-mode="S"] .feature_fukidashi {
    height: 76px;
    margin-bottom: -5px;
    padding: 0 10px 10px;
    font-size: 13px;
}

[data-browse-mode="S"] #offer {
    padding: 40px 15px;
}
[data-browse-mode="S"] .offer_content {
    flex-flow: column wrap;
    gap: 16px;
}
[data-browse-mode="S"] .offer_item {
    width: min(100%, 400px);
}

[data-browse-mode="S"] #howto {
    padding: 40px 15px;
}
[data-browse-mode="S"] .howto_content {
    gap: 20px;
}
[data-browse-mode="S"] .howto_item_l {
    width: 100%;
}
[data-browse-mode="S"] .howto_item_l a {
    align-items: stretch;
}
[data-browse-mode="S"] .howto_item_l_textimg {
    width: 80px;
    padding: 16px;
}
[data-browse-mode="S"] .howto_item_l_img {
    width: 100%;
    height: calc(100% - 46px);
}
[data-browse-mode="S"] .howto_item_l_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
[data-browse-mode="S"] .howto_item_l_logo {
    display: flex;
    flex-flow: row wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    padding: 0;
    height: 46px;
}
[data-browse-mode="S"] .howto_item_l_logo img {
    width: 100px;
}
[data-browse-mode="S"] .howto_item_wrap {
    width: 100%;
    gap: 15px;
}
[data-browse-mode="S"] .howto_item_s {
    height: 70px;
}
[data-browse-mode="S"] .howto_item_s_text {
    left: 20px;
    font-size: 20px;
}
[data-browse-mode="S"] .howto_item_s_img {
    text-align: right;
}
[data-browse-mode="S"] .howto_item_s_img img {
    object-fit: cover;
    width: 60%;
}
[data-browse-mode="S"] .block-ranking-lightningrecommend .block-ranking-r--goods-description .block-ranking-r--price {
    font-size: 18px;
}