@charset "utf-8";
/* CSS Document */
body {
    overflow-x: hidden;
}
.contents_wrap {
    font-family: 'Noto Sans JP', sans-serif;
    letter-spacing: 0.06em;
    margin: 0 auto;
    width: 90%;
    max-width: 1024px;
    text-align: center;
    font-size: 15px;
    line-height: 1.5em;
    color: #202124;
}
.contents_wrap p {
    margin: 0;
    padding: 0;
}
.contents_wrap a {
    text-decoration: underline;
    color: #555555;
    transition: all 0.3s ease;
}
.contents_wrap h3 {
    display: flex;
    width: 100%;
    align-items: center;
    margin-bottom: 20px;
    color: #202124;
    font-size: 18px;
    font-weight: 700;
    text-align: center;
    line-height: 18px;
}
.contents_wrap h3 span { 
    padding: 0 0.8em;
}
.contents_wrap h3:before,
.contents_wrap h3:after {
    content: "";
    flex-grow: 1;
    height: 1px;
    background: #000;
    margin: 0;
}
.contents_wrap .sec-margin {
    padding-top: 65px;
    margin: 32px auto;
    max-width: 975px;
}
.contents_wrap .lp_flex_wrap {
    display: flex;
    flex-wrap: wrap;
}
.contents_wrap .brand_bg .lp_flex_wrap {
    position: relative;
    row-gap: 30px;
    column-gap: 1.025%;
    z-index: 0;
}
.contents_wrap h2 {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-size: 14px;
    color: #e9d910;
    margin: 0 auto;
    line-height: 14px;
}
.contents_wrap .title {
    color: #202124;
    font-size: 30px;
    line-height: 1.95em;
    margin: 0 auto 66px;
    font-weight: 700;
}
.contents_wrap .title span {
    display: block;
    font-size: 15px;
    font-weight: normal;
    line-height: 3;
}

/*----------リードテキスト----------*/
.contents_wrap .readtext {
    margin: 66px 0 70px;
}
.contents_wrap .readtext p {
    font-size: 16px;
    line-height: 1.73em;
}
.contents_wrap h1 {
    margin-bottom: 23px;
    font-weight: 700;
    font-size: 30px;
    letter-spacing: 1.9px;
    line-height: 1.7;
}
.contents_wrap .readtext p.info {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5em;
    margin: 0.7em auto 1.8em;
}
.contents_wrap .readtext .coupon-code-area {
    width: 78%;
    max-width: 725px;
    margin: 0 auto;
    padding: 1.2em 0;
    font-size: 18px;
    font-weight: 700;
    border-top: 1px dotted #202124;
    border-bottom: 1px dotted #202124;
}
.contents_wrap .readtext .coupon-code {
    margin-left: 2em;
}

/*----------ジェンダーリンク----------*/
.contents_wrap .gender-link.bk_g {
    width: 100vw;
    margin: 100px calc(50% - 50vw) 32px;
    background-color: #e1ded9;
    padding: 100px 0;
    max-width: none;
}
.contents_wrap .gender-link_contents {
    max-width: 646px;
    margin: 0 auto;
}

/*----------アンカーリンク----------*/
.contents_wrap .jumplink{
    width: 100vw;
    margin: 100px calc(50% - 50vw) 0;
    background-color: #e4e4e4;
}
.contents_wrap .jumplink ol {
    max-width: 1000px;
    margin: 0 auto;
    font-size: 18px;
    font-weight: 700;
    color: #202124;
    padding: 2.87em 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.contents_wrap .jumplink ol li {
    width: 33.1%;
    border-left: solid 1px #202124;
}
.contents_wrap .jumplink li:first-of-type {
    border-left: none;
}
.contents_wrap .jumplink ol li a {
    width: 100%;
    display: inline-block;
    padding: 0.917em 0;
    text-decoration: none;
    line-height: 1.5em;
    color: #000;
}
.contents_wrap .jumplink ol li.contents_wrap_arrow {
    position: relative;
}
.contents_wrap .jumplink ol li.contents_wrap_arrow::after {
    position: absolute;
    content: "";
}
/*ご利用方法を表示する際の調整*/
.contents_wrap .jumplink ol li:first-of-type.contents_wrap_arrow.arrow_how-to::after {
    right: 28%;
}
/*割引率/価格から探すを表示する際の調整*/
.contents_wrap .jumplink ol li:last-of-type.contents_wrap_arrow.arrow_price::after {
    right: 15%;
}
.contents_wrap .arrow_bottom::after {
    width: 8px;
    height: 8px;
    border-top: 2px solid #202124;
    border-right: 2px solid #202124;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
    right: 20%;
    top: 42px;
}

/*------- ご利用方法 -------*/
.contents_wrap .howto {
    max-width: 1000px;
    margin: 0 auto;
}
.contents_wrap .howto p {
    margin: 0;
}
.contents_wrap .howto img {
    width: 100%;
    margin: 0 auto;
    padding: 0 9.2%;
}
.contents_wrap .howto a {
    text-decoration: underline;
}
.contents_wrap .howto .title {
    margin-bottom: 29px;
}
.contents_wrap .howto .subtxt {
    color: #202124;
    margin-bottom: 40px;
}
.contents_wrap .howto-image {
    max-width: 975px;
    margin: 50px auto 0;
    padding: 50px 0 0;
    background-color: #f4f4f4;
    border-radius: 20px;
}
.contents_wrap .howto-image p {
    color: #202124;
    margin: 40px auto;
    padding: 0 9%;
}
.contents_wrap .howto-image p:first-child {
    display: inline-block;
    margin: 0 auto;
    padding: 0.18em 0.9em;
    color: #fff;
    background-color: #d44a26;
    font-weight: 700;
}
.contents_wrap .notice {
    display: inline-block;
    text-align: left;
    padding: 0px 22%;
    margin: 0 auto;
    font-size: 13px;
}
.contents_wrap .notice li {
    padding-left: 1em;
    text-indent: -1em;
}
.contents_wrap .notice li::before {
    content: "※";
    margin-right: 2px;
}

/*----------ブランドから----------*/
.contents_wrap .wrapper {
    margin-bottom: 76px;
}
.contents_wrap #sale_item_content h3 {
    color: #e9d910;
}
.contents_wrap .search_brand h3:before,
.contents_wrap .search_brand h3:after{
    content: none;
}
.contents_wrap .search_brand h3 span {
    margin: 0 auto;
}
.contents_wrap .search_brand a {
    border: 1px solid #c6c6c6;
    background-color: #fff;
    display: flex;
    height: 86px;
    justify-content: center;
    flex-wrap: wrap;
    align-items: center;
}
.contents_wrap .search_brand a img:hover {
    opacity: 0.4;
}
.contents_wrap .brandlist span {
    display: block;
    margin-top: 6px;
    font-size: 10px;
}
.contents_wrap .search_brand li.brandlist {
    width: 19.17%;
    color: #C6C6C6;
    font-size: 13px;
    z-index: 2;
}
.contents_wrap .search_brand li.brandlist span {
    margin: 7.5px auto 0;
    display: block;
    line-height: 14px;
}
.contents_wrap .search_brand li.brandlist img {
    width: 86%;
    max-height: 60px;
    object-fit: scale-down;
    transition: all 0.3s ease;
}
.contents_wrap .search_brand li.brandlist a.tsh_logo {
    padding: 9.5% 0
}

.contents_wrap .tabs {
    margin-top: 50px;
    padding-bottom: 40px;
    background-color: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    width: 700px;
    margin: 0 auto;
}
.contents_wrap .tab_item {
    cursor: pointer;
    width: calc(100% / 2);
    height: 50px;
    border-bottom: 1px solid #000;
    font-size: 18px;
    color: #adadad;
    display: block;
    float: left;
    text-align: center;
    font-weight: bold;
    transition: all 0.2s ease;
}
/*.contents_wrap .tab_item:hover {
    opacity: 0.4;
}*/
.contents_wrap input[name="tab_item"] {
    display: none;
}
.contents_wrap .tab_content {
    display: none;
    padding: 40px 0 0;
    clear: both;
    overflow: hidden;
}
.contents_wrap #sale_item:checked ~ #sale_item_content,
.contents_wrap #outlet_item:checked ~ #outlet_item_content{
    display: block;
}
.contents_wrap input:checked + .tab_item {
    border-bottom: 5px solid #000;
    color: #202124;
}


/*----------カテゴリから----------*/
.contents_wrap .search_item .lp_flex_wrap {
    column-gap: 0.8%;
    row-gap: 1rem;
    justify-content: center;
    margin-bottom: 20px;
}
.contents_wrap li.category {
    width: 16%;
    position: relative;
    background-color: #000;
    transition: all 0.3s ease;
}
.contents_wrap li.category img {
    opacity: .7;
}

.contents_wrap .item_text {
    font-size: 18px;
    font-weight: 700;
    color: #fff;
    width: 100%;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.contents_wrap li.category_text a {
    display: block;
    line-height: 68px;
    color: #fff;
    padding-right: 7px;
    margin-top: 18px;
}
.contents_wrap .search_item li.keyword_box {
    background-color: #fff;
    max-width: 155px;
    width: 100%;
    border-radius: 50px;
    font-size: 12.5px;
    font-weight: 600;
    color: #202124;
    transition: all 0.3s ease;
    border: 1px solid #000;
}

    .contents_wrap .search_item li.keyword_box:hover{
     color: #8a8a8a;
     border: 1px solid #8a8a8a;
    }
.contents_wrap .keyword_box a {
    display: flex;
    width: 100%;
    justify-content: center;
    padding: 8px 0px;
    transition: 0.3s all ease;
    text-decoration: none;
}
.contents_wrap .keyword_box a:hover{
color: #8a8a8a;
}
.contents_wrap .search_item .sale_outlet {
    max-width: 534px;
    flex-wrap: nowrap;
}
.contents_wrap .search_item .sale_outlet > li {
    max-width: 260px;
    min-width: unset;
    font-size: 13px;
}

/*----------価格から----------*/
.contents_wrap .pricesale {
    width: 32.5%;
    font-size: 18px;
    letter-spacing: 2px;
    background-color: #202124;
    color: #ffffff;
}
.contents_wrap .pricesale a {
    width: 100%;
    display: block;
    text-align: center;
    color: #ffffff;
    padding: 18px 0;
    text-decoration: none;
}
.contents_wrap .pricesale a span {
    color: #f00;
    font-size: 15px;
}
.contents_wrap .pricesale a:hover {
    background-color: #999a9c;
}


/*----------ボタン----------*/
.contents_wrap .price_list,
.contents_wrap .sale_outlet {
    margin-bottom: 100px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.contents_wrap .sale_outlet {
    margin: 0 auto 40px;
}
.contents_wrap .sale_outlet a:hover {
    /* opacity: 0.6; */
    background-color: #6a6a6a;
    border-radius: 4px;
}
.contents_wrap .sale_outlet > li {
    width: 50%;
    max-width: 316px;
    min-width: 278px;
    font-size: 18px;
    letter-spacing: 2px;
    background-color: #202124;
    border-radius: 4px;
    color: #000;
}
.contents_wrap .sale_outlet > li a {
    width: 100%;
    display: block;
    text-align: center;
    color: #fff;
    padding: 1.153em 0;
    text-decoration: none;
    font-weight: 700;
}
.contents_wrap .second_one {
    margin-top: 10%;
}
.contents_wrap ul.price_list li.contents_wrap_arrow::after{
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    margin: auto;
    vertical-align: middle;
}
.contents_wrap .contents_wrap_arrow {
    position: relative;
    display: inline-block;
    vertical-align: middle;
}
.contents_wrap .contents_wrap_arrow::after {
    position: absolute;
    top: -8%;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
.contents_wrap .arrow_r::after {
    right: 8.5%;
    width: 8px;
    height: 8px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
.contents_wrap ul.price_list li.contents_wrap_arrow::after{
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    margin: auto;
    vertical-align: middle;
}
.contents_wrap .arrow_right::after {
    right: 5%;
    width: 12px;
    height: 12px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.contents_wrap .category_text .arrow_r::after {
    right: 10%;
    width: 8px;
    height: 8px;
}

/*----------あなたにオススメ----------*/
/*.contents_wrap #search_recommend {
    margin-top: 100px;
}
.contents_wrap .section.reccomend {
    margin-top: 30px;
}
.contents_wrap .contents_wrap .recommend-main-l {
    text-align: left;
}*/
.contents_wrap #search_recommend .sale_outlet {
    justify-content: center;
    margin-top: 80px;
}

@media screen and (max-width: 870px) {

    .contents_wrap .arrow_bottom::after {
        right: 10%;
    }
    /*ご利用方法を表示する際の調整*/
    .contents_wrap .jumplink ol li:first-of-type.contents_wrap_arrow.arrow_how-to::after {
        right: 20%;
    }
    /*割引率/価格から探すを表示する際の調整*/
    .contents_wrap .jumplink ol li:last-of-type.contents_wrap_arrow.arrow_price::after {
        right: 6%;
    }
}

@media screen and (max-width: 767px) {

    .contents_wrap .brand_bg .lp_flex_wrap {
        column-gap: 0.84%;
        row-gap: 21px;
    }

    /*------- ご利用方法 -------*/
    .contents_wrap .howto ul.notice {
        padding: 0 20px;
    }

    /*----------ブランドから----------*/
    .contents_wrap .search_brand li.brandlist {
        width: 32.7%;
        font-size: 12px;
        line-height: 14px;
    }
    .contents_wrap .search_brand li.brandlist img {
        width: 72%;
        max-width: 105px;
    }

    /*----------カテゴリから----------*/
    .contents_wrap .search_item .lp_flex_wrap {
        column-gap: 1.6%;
        row-gap: 12px;
    }
    .contents_wrap .search_item .lp_flex_wrap li {
        width: 32.2%;
    }
    .contents_wrap .item_text {
        font-size: 16px;
    }

    /*----------あなたにオススメ----------*/
    /*#search_recommend {
        margin-top: 80px;
    }*/
}


@media screen and (min-width: 641px) {
    .pc {
        display: block;
    }
    .sp {
        display: none;
    }
}


@media screen and (max-width: 640px) {
    .pc {
        display: none;
    }
    .sp {
        display: block;
    }
    .contents_wrap {
        width: 100%;
        font-size: 14px;
    }
    .contents_wrap h2 {
        font-size: 12px;
        line-height: 2.2;
    }
    .contents_wrap h3 {
        font-size: 16px;
        margin: 0 auto 20px;
    }
    .contents_wrap .title {
        font-size: 22.5px;
        text-align: center;
        margin-bottom: 32px;
        line-height: 30px;
    }
    .contents_wrap .title span {
        font-size: 12px;
        line-height: 1.5;
        margin: 14px 0 34px;
    }

    /*----------リードテキスト----------*/
    .contents_wrap .readtext {
        margin: 33px 0 85px;
    }
    .contents_wrap .readtext p {
        font-size: 14px;
        line-height: 1.734em;
    }
    .contents_wrap h1 {
        font-size: 20px;
        line-height: 1.65em;
        margin-bottom: 16px;
    }
    .contents_wrap .readtext p.info {
        font-size: 15px;
        line-height: 1.9em;
        margin: 18px auto 42px;
    }
    .contents_wrap .readtext .coupon-code-area {
        width: 94%;
        line-height: 1.5;
    }
    .contents_wrap .readtext .coupon-code {
        margin-left: 0;
    }


/*----------ジェンダーリンク----------*/
    .contents_wrap .gender-link h3 {
        max-width: 284px;
    }
    .contents_wrap .gender-link.bk_g{
        padding: 70px 0 60px;
    }

    /*----------アンカーリンク----------*/
    .contents_wrap .jumplink {
        margin: 80px calc(50% - 50vw) 0;
    }
    .contents_wrap .jumplink ol {
        font-size: 12px;
        flex-direction: column;
        justify-content: center;
        padding: 15px 0;
    }
    .contents_wrap .jumplink ol li {
        width: 100%;
        max-width: 284px;
        margin: 0 auto;
        border-left: none;
        border-bottom: 1px solid #000;
    }
    .contents_wrap .jumplink ol li:last-child {
        border-bottom: none;
    }
    .contents_wrap .jumplink ol li a {
        font-size: 16px;
        padding: 1.6em 0;
    }
    .contents_wrap .jumplink ol li.contents_wrap_arrow::after {
        right: 7.5%;
    }
    /*ご利用方法を表示する際の調整*/
    .contents_wrap .jumplink ol li:first-of-type.contents_wrap_arrow.arrow_how-to::after {
        right: 7.5%;
    }
    /*割引率/価格から探すを表示する際の調整*/
    .contents_wrap .jumplink ol li:last-of-type.contents_wrap_arrow.arrow_price::after {
        right: 7.5%;
    }

    .contents_wrap #search_brand {
        margin-top: 0px;
        padding-top: 60px;
        margin-bottom: 0;
    }

    /*----------ご利用方法----------*/
    .contents_wrap .howto {
        width: 100%;
        margin-top: 20px;
    }
    .contents_wrap .howto img {
        padding: 0 4.4%;
    }
    .contents_wrap .howto h2 {
        line-height: 2.2;
        margin-top: 5px;
    }
    .contents_wrap .howto .subtxt {
        max-width: 328px;
        margin: 31px auto 40px;
    }
    .contents_wrap .howto-image {
        margin-top: 44px;
        width: 100%;
        padding: 42px 0 0;
    }
    .contents_wrap .howto-image p {
        padding: 0px 8px;
        margin: 22px auto 20px;
    }
    .contents_wrap .howto-image p:nth-child(2) {
        line-height: 1.75;
    }
    .contents_wrap .notice {
        margin: 0 0 20px;
        font-size: 14px;
        text-decoration: none;
    }

    /*----------ブランドから----------*/
    .contents_wrap .wrapper {
        margin-bottom: 24px;
    }
    .contents_wrap #search_category {
        margin-top: 0px;
    }
    .contents_wrap #search_category .wrapper {
        margin-bottom: 48px;
    }
    .contents_wrap .wrapper:last-child {
        margin-bottom: 0;
    }
    .contents_wrap .gender {
        font-size: 16px;
    }
    .contents_wrap .search_brand li.brandlist span {
        font-size: 10px;
    }
    .contents_wrap .search_brand a {
        height: 55px;
    }
    .contents_wrap .search_brand li.brandlist img.tsh_logo {
        width: 80%;
    }
    .contents_wrap .tab_item {
        font-size: 14px;
        height: 40px;
    }
    .contents_wrap .tab_content {
        padding: 40px 0 40px;
    }
    .contents_wrap input:checked + .tab_item {
        border-bottom: 3px solid #000;
    }
    .contents_wrap .search_item li.keyword_box{
        font-size: 10px;
    }

    /*----------カテゴリから----------*/
    .contents_wrap li.category:last-of-type,
    .contents_wrap li.category:nth-last-of-type(2) {
        margin-bottom: 0;
    }
    .contents_wrap li.category_text a {
        margin-top: 0;
    }
    .contents_wrap .search_item .sale_outlet {
        width: 90%;
        margin: 30px auto 30px;
    }
    .contents_wrap .search_item .sale_outlet > li {
        max-width: 284px;
        font-size: 14px;
        min-width: unset;
    }

    /*----------価格から----------*/
    .contents_wrap .pricesale {
        font-size: 16px;
        width: 100%;
        margin-bottom: 10px;
    }
    .contents_wrap .pricesale:last-of-type {
        margin-bottom: 0;
    }
    .contents_wrap .pricesale a span {
        font-size: 11px;
    }

    /*----------ボタン----------*/
    .contents_wrap .price_list,
    .contents_wrap .sale_outlet {
        display: flex;
        flex-wrap: wrap;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 7px;
    }
    .contents_wrap .sale_outlet {
        margin: 0 auto 30px;
    }
    .contents_wrap .sale_outlet > li {
        width: 100%;
        max-width: 284px;
        min-width: 240px;
        font-size: 16px;
        letter-spacing: 2px;
        color: #fff;
    }
    .contents_wrap .arrow_right::after {
        right: 5%;
        width: 10px;
        height: 10px;
        border-top: 1px solid #000;
        border-right: 1px solid #000;
    }

    /*----------あなたにオススメ----------*/
/*    .contents_wrap .section.reccomend {
        margin-bottom: 40px;
    }
    .contents_wrap .widget-recommend ul {
        margin: 20px auto 0 auto;
    }
    .contents_wrap .widget-recommend ul .col-xs-6.card-product:nth-child(odd) {
        padding-left: 4%;
    }
    .contents_wrap .widget-recommend ul .col-xs-6.card-product:nth-child(even) {
        padding-right: 4%;
    }
    .contents_wrap .reccomend_txt {
        text-align: left;
        font-size: 13px;
    }*/
}


@media screen and (max-width: 320px) {

    /*----------リードテキスト----------*/
    .contents_wrap .readtext p {
        font-size: 13px;
        line-height: 1.6em;
    }
    .contents_wrap h1 {
        font-size: 18px;
        line-height: 1.6em;
    }
    .contents_wrap .readtext p.info {
        font-size: 13px;
        line-height: 1.6em;
    }

    /*----------カテゴリから----------*/
    .contents_wrap .item_text {
        font-size: 12px;
    }

    /*----------アンカーリンク----------*/
    .contents_wrap .jumplink ol li a {
        font-size: 12px;
    }
}