/* spを先に記述しています */
#summergift {
    position: relative;
    width: 100%;
    margin: 0 auto;
    font-family: "Noto Serif JP", serif;
    line-height: 1.5;
    color: #002e79;
    font-weight: 500;
    background: #eff8fe url(../../../img/usr/genre/rA1/2026/bg_main.jpg)repeat-y top 10% center / 100%;
    overflow: hidden;
}

#summergift *,
#summergift ::after,
#summergift ::before {
    box-sizing: border-box;
}

#summergift .block-genre-page--header {
    display: none !important;
}

.block-genre-page-head {
    margin: 0;
    display: none;
}
#summergift .page-genre .block-top-event--goods:has(*:not(script)){
padding-top:  0;
}
#summergift .block-top-event--goods:has(*:not(script)) {
    padding:  0;
}
#summergift .block-icon {
    height: 24px;
}

/* 同階層のジャンル、「もっと見る」ボタンを非表示 */
#summergift .block-genre-page--sub.block-readmore-contents.js-readmore-contents,
#summergift .block-readmore-button.js-readmore-button {
    display: none !important;
}

#summergift .block-thumbnail-t--goods-description {
    height: 7.6rem;
}
@media screen and (min-width: 769px) {
    #summergift .block-thumbnail-t--goods-description {
        height: 8.6rem;
    }
}

#summergift img {
    width: 100%;
}

#summergift .sp {
    display: block;
}

#summergift .pc {
    display: none;
}

#summergift a {
    color: #002e79;
    text-decoration: none;
}

#summergift a:visited {
    color: #002e79;
}

#summergift a._btn:visited {
    color: white;
}

#summergift ._btn {
    display: block;
    text-align: center;
    position: relative;
    color: white;
    border: 2px solid #002e79;
    border-radius: 50vw;
    padding: 3.5%;
    background: #23519b;
    font-size: 4.5vw;
    margin: 0 auto;
    font-weight: bold;
    box-shadow: 0px 5px 5px 0px rgba(0, 32, 83, 0.2);
}

#summergift ._btn::after {
    content: "";
    position: absolute;
    width: 20px;
    padding-top: 20px;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    background: url(../../../img/usr/genre/rA1/2026/icon_arrow_white.png) no-repeat center / contain;
}

#summergift h3 a {
    color: #002e79;
}

#summergift h3 a:visited {
    color: #002e79;
}

@media screen and (min-width: 769px) {
    #summergift {
        max-width: 900px;
    }

    #summergift .sp {
        display: none;
    }

    #summergift .pc {
        display: block;
    }

    #summergift .block-thumbnail-t {
        margin: 0 20px;
    }

    #summergift .block-thumbnail-t--goods {
        width: 200px;
    }
}

/* HP用 */
.pane-left-menu {
    display: none;
}

#summergift .block-top-event--goods img {
    width: auto;
    padding-top: 0;
}

#summergift #price,
#summergift #item,
#summergift #feature,
#summergift #brand,
#summergift #opponent,
#summergift #ranking,
#summergift #guide {
    padding-top: 150px;
    margin-top: -150px;
}

/* -------- スライダー ここから -------- */
#summergift .slider1 {
    position: relative;
    margin: 1% auto 15%;
    width: 100%;
    height: fit-content;
}

#summergift .slider1 a {
    width: 100%;
    height: auto;
}

#summergift .slider2 {
    position: relative;
    margin: 5% auto 13%;
    width: 100%;
}

#summergift .top_slider {
    position: relative;
    margin: 0 auto;
    width: 100%;
}

#summergift .slider1 a,
#summergift .top_slider a {
    width: 100%;
    height: auto;
}

#summergift .top_slider a {
    color: #002c75;
    padding: 20px 0;
}

#summergift .slider1 a img,
#summergift .slider2 a img,
#summergift .top_slider a img {
    width: auto;
    max-width: 83%;
    margin: 0 auto;
    display: block;
}

#summergift .top_slider a img {
    /* margin-bottom: 15px; */
    box-shadow: 0 0 10px 5px rgba(15, 117, 161, 0.3);
}

#summergift .top_slider a p {
    width: 83%;
    margin: 0 auto;
    background: white;
    font-size: 2.9vw;
    text-align: center;
    padding: 10px 5px;
    box-shadow: 0 0 10px 5px rgba(15, 117, 161, 0.3);
}

#summergift .slider1 .slick-dots {
    bottom: -30px;
}

#summergift .slider2 .slick-dots {
    bottom: -27px;
}

#summergift .slick-dots li {
    margin: 0 5px 0 0;
}

#summergift .slick-dots li button:before {
    background-color: transparent;
    border-radius: 50%;
    width: 10px;
    height: 10px;
    opacity: 1;
    background-color: #96a8c5;
    color: unset !important;
}

#summergift .slick-dots li.slick-active button::before {
    background-color: #173372 !important;
    border-color: transparent !important;
}

#summergift .slider1 .slick-dots li.slick-active button::before {
    background-color: #173372 !important;
    border-color: transparent !important;
}

#summergift .slider1 .slick-list,
#summergift .slider2 .slick-list {
    margin-left: 0;
    margin-right: 0;
}

/* 矢印共通設定 */
#summergift .slider1 .slick-arrow,
#summergift .top_slider .slick-arrow {
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    padding: 0;
    width: 25px;
    height: 100%;
    color: transparent;
    z-index: 1;
    transition: 0.5s;
}

#summergift .slider1 .slick-arrow {
    background-color: rgba(255, 255, 255, 0.5);
}

#summergift .top_slider .slick-arrow {
    background-color: transparent;
}

/* 矢印中身の三角形（共通） */
#summergift .slider1 .slick-prev::after,
#summergift .slider1 .slick-next::after,
#summergift .top_slider .slick-prev::after,
#summergift .top_slider .slick-next::after {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    margin: auto;
    width: 15px;
    height: 15px;
    /* filter: drop-shadow(5px 2px 20px #000); */
}

#summergift .slider1 .slick-prev::after,
#summergift .slider1 .slick-next::after {
    border-top: 3.5px solid #173372;
    border-right: 3.5px solid #173372;
}

#summergift .top_slider .slick-prev::after,
#summergift .top_slider .slick-next::after {
    border-top: 3.5px solid #ffffff;
    border-right: 3.5px solid #ffffff;
}

#summergift .slick-prev:before,
#summergift .slick-next:before {
    color: transparent;
}

/* slider1 矢印位置 */
#summergift .slider1 .slick-prev {
    left: 0;
}

#summergift .slider1 .slick-next {
    right: 0;
}

#summergift .slider1 .slick-prev::after {
    left: 30%;
    transform: rotate(-135deg);
}

#summergift .slider1 .slick-next::after {
    right: 30%;
    transform: rotate(45deg);
}

#summergift .slider1 .slick-prev {
    left: 19.5vw;
}

#summergift .slider1 .slick-next {
    right: 19.1vw;
}

#summergift .top_slider .slick-prev {
    left: 19vw;
    height: 87.5%;
}

#summergift .top_slider .slick-next {
    right: 19vw;
    height: 87.5%;
}

#summergift .top_slider .slick-prev::after {
    top: -30%;
    left: 28%;
    transform: rotate(-135deg);
}

#summergift .top_slider .slick-next::after {
    top: -30%;
    right: 28%;
    transform: rotate(45deg);
}

/* メディアクエリ対応 */
@media screen and (min-width: 768px) {
    #summergift ._btn {
        font-size: 25px;
        padding: 15px;
    }

    #summergift ._btn::after {
        width: 30px;
        padding-top: 30px;
        right: 20px;
    }

    #summergift a {
        transition: .3s;
    }

    #summergift a:hover {
        opacity: 0.7;
    }

    #summergift .slider1 {
        margin: 30px auto 8%;
    }

    #summergift .slider1 .slick-arrow {
        width: 31px;
    }

    #summergift .slider1 .slick-prev::after,
    #summergift .slider1 .slick-next::after {
        width: 16px;
        height: 16px;
    }

    #summergift .slider1 .slick-arrow:hover,
    #summergift .top_slider .slick-arrow:hover {
        background-color: rgba(255, 255, 255, 0.7);
    }

    #summergift .slick-dots li {
        width: 15px;
    }

    #summergift .slider1 .slick-dots {
        display: block;
    }

    #summergift .top_slider .slick-dots {
        bottom: -20px !important;
    }

    #summergift .slider1 .slick-dots {
        bottom: -40px !important;
    }

    #summergift .slider1 .slick-arrow {
        background-color: rgba(228, 228, 228, 0.5);
    }

    #summergift .slider1 .slick-prev,
    #summergift .top_slider .slick-prev {
        left: calc(32.4% + 5px);
    }

    #summergift .slider1 .slick-next,
    #summergift .top_slider .slick-next {
        right: calc(32.4% + 5px);
    }

    #summergift .top_slider .slick-next,
    #summergift .top_slider .slick-prev {
        height: 89%;
    }

    #summergift .slider1 .slick-prev::after {
        left: 10px;
        background-color: transparent;
    }

    #summergift .slider1 .slick-next::after {
        right: 10px;
        background-color: transparent;
    }

    #summergift .top_slider .slick-prev::after,
    #summergift .top_slider .slick-next::after {
        top: -15%;
    }

    #summergift .slider1 a img {
        width: 80%;
        max-width: none;
    }

    #summergift .slider1 a img {
        width: auto;
        max-width: 80%;
    }

    #summergift .top_slider a p {
        font-size: 14px;
    }
}

/* -------- スライダー ここまで -------- */


/* -------- コンテンツ -------- */
/* MV */
#summergift .mv {
    position: relative;
    width: 100%;
}

#summergift .mv .top_slider_wrap {
    /* position: absolute; */
    width: 100%;
    /* top: 30%; */
    /* left: 0; */
    padding: 0 0 20px;
    background: linear-gradient(to bottom, #c9e4f1 30%, #f0f9fe 100%);
}

/* lead リード文 */
#summergift .lead {
    position: relative;
    padding: 7% 0;
    background:
        linear-gradient(to bottom,
            #f0f9fe 0%,
            rgba(240, 249, 254, 0) 3%),
        linear-gradient(to bottom,
            rgba(243, 250, 254, 0) 90%,
            #f3fafe 100%),
        url(../../../img/usr/genre/rA1/2026/bg_lead.jpg) no-repeat top center / cover;
}

#summergift .lead .lead_line {
    width: 100%;
    margin-bottom: 5%;
}

#summergift .lead .lead_line img {
    width: 100%;
}

#summergift .lead_top {
    width: 90%;
    margin: 0 auto;
}

#summergift .lead .lead_text {
    position: relative;
    font-weight: 500;
    line-height: 1.8;
    font-size: 3.8vw;
    height: 70px;
    overflow: hidden;
    width: 85%;
    margin: 0 auto;

    -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 30%, rgba(0, 0, 0, 0));
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 30%, rgba(0, 0, 0, 0));
}

#summergift .lead .lead_text.active {
    height: auto;

    /* 展開時はマスク解除 */
    -webkit-mask-image: none;
    mask-image: none;
}

#summergift .lead_text.active::before {
    background: none;
}

#summergift .acc_button,
#summergift .acc_button_02,
#summergift .acc_button_03 {
    text-align: center;
    width: 28%;
    margin: 0 auto;
    font-weight: bold;
}

#summergift .acc_button {
    margin: 0 auto 10%;
}

#summergift .acc_button_02,
#summergift .acc_button_03 {
    position: absolute;
    bottom: 10px;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 3;
}

#summergift .acc_button img,
#summergift .acc_button_02 img,
#summergift .acc_button_03 img,
#summergift .acc_button_close img {
    width: 20%;
}

#summergift .lead .acc_button p,
#summergift .lead .acc_button_02 p,
#summergift .lead .acc_button_ p,
#summergift .lead .acc_button_close p {
    margin-top: 12px;
    /* color: #29a1a9; */
    font-weight: 500;
    font-size: 3.8vw;
}

#summergift .acc_open._none,
#summergift .acc_open_02._none,
#summergift .acc_open_03._none {
    display: none;
}

#summergift .acc_open p,
#summergift .acc_close p {
    text-align: center;
}

#summergift .acc_open p,
#summergift .acc_close p {
    position: relative;
    padding-right: 10%;
}

#summergift .acc_open p::after,
#summergift .acc_close p::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 15%;
    padding-top: 15%;
}

#summergift .acc_open p::after {
    background: url(../../../img/usr/genre/rA1/2026/icon_arrow_navy.png)no-repeat center / contain;
}

#summergift .acc_close p::after {
    background: url(../../../img/usr/genre/rA1/2026/icon_arrow_navy_up.png)no-repeat center / contain;
}

#summergift .acc_close,
#summergift .acc_close_02,
#summergift .acc_close_03 {
    display: none;
    margin-top: 20px;
}

#summergift .acc_close._active,
#summergift .acc_close_02._active,
#summergift .acc_close_03._active {
    display: block;
}

#summergift .open_acc_button_close {
    display: none;
}

#summergift .lead .open_lead_text {
    height: auto;
}

#summergift .lead .open_lead_text::before {
    display: none;
}

#summergift .anc_links {
    width: 90%;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: center;
    margin: 0 auto 8%;
    gap: 10px;
}

#summergift .anc_links li {
    position: relative;
    width: 30.5%;
    color: white;
    text-align: center;
    border-radius: 3vw;
    /* padding: 5px 5px 20px; */
    box-shadow: 0px 5px 15px 0px rgba(0, 32, 83, 0.5);
}

#summergift .anc_links ._navy {
    background: url(../../../img/usr/genre/rA1/2026/bg_anc_navy.png)no-repeat center / cover;
}

#summergift .anc_links ._blue {
    background: url(../../../img/usr/genre/rA1/2026/bg_anc_blue.png)no-repeat center / cover;
}

#summergift .anc_links li::after {
    content: "";
    position: absolute;
    bottom: 3px;
    left: 50%;
    transform: translateX(-50%);
    width: 17px;
    padding-top: 17px;
}

#summergift .anc_links ._navy::after {
    background: url(../../../img/usr/genre/rA1/2026/icon_arrow_blue.png)no-repeat center / contain;
}

#summergift .anc_links ._blue::after {
    background: url(../../../img/usr/genre/rA1/2026/icon_arrow_navy.png)no-repeat center / contain;
}

#summergift .anc_links li a {
    width: 100%;
    display: block;
    color: white;
    padding: 5px 5px 20px;
}

#summergift .anc_guide li {
    width: 100%;
    text-align: center;
}

#summergift .anc_guide li a {
    font-size: 4.5vw;
    width: 100%;
    display: block;
}

#summergift .anc_guide ._guide {
    margin-bottom: 6%;
}

#summergift .anc_guide ._guide a {
    position: relative;
    width: fit-content;
    color: #134492;
    margin: 0 auto;
    padding-right: 30px;
}

#summergift .anc_guide ._guide a::after {
    content: "";
    position: absolute;
    width: 20px;
    padding-top: 20px;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    background: url(../../../img/usr/genre/rA1/2026/icon_arrow_blue.png)no-repeat center / contain;
}

#summergift .anc_guide ._catalog {
    position: relative;
    width: 80%;
    margin: 0 auto;
    font-weight: bold;
}

#summergift .anc_guide ._catalog::after {
    content: "";
    position: absolute;
    width: 20px;
    padding-top: 20px;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    background: url(../../../img/usr/genre/rA1/2026/icon_arrow_white.png)no-repeat center / contain;
}

#summergift .anc_guide ._catalog a {
    color: white;
    border: 2px solid #002e79;
    border-radius: 50vw;
    padding: 4%;
    background: #23519b;
    box-shadow: 0px 5px 5px 0px rgba(0, 32, 83, 0.2);
}

#summergift .anc_guide li:hover {
    opacity: 0.7;
}

@media screen and (min-width: 769px) {
    .block-icon {
        height: 19px;
    }

    #summergift .mv .top_slider_wrap {
        padding: 0 0 40px;
    }

    #summergift .lead .lead_line {
        margin-bottom: 3%;
    }

    #summergift .acc_button {
        margin: 0 auto 7%;
    }

    #summergift .anc_guide li {
        width: 100%;
        background-size: 100%;
        padding: 0;
    }

    #summergift .anc_guide li a {
        /* padding: 9% 5% 12%; */
        font-size: 25px;
    }

    #summergift .anc_guide ._catalog a {
        padding: 15px;
    }

    #summergift .anc_guide {
        width: 100%;
        margin: 0 auto;
    }

    #summergift .lead .acc_button p,
    #summergift .lead .acc_button_02 p,
    #summergift .lead .acc_button_ p,
    #summergift .lead .acc_button_close p {
        font-size: 20px;
    }

    #summergift .anc_guide ._guide a {
        margin-bottom: 6.5%;
    }

    #summergift .anc_links {
        width: 100%;
        gap: 20px;
    }

    #summergift .anc_links li {
        border-radius: 20px;
        transition: .3s;
    }

    #summergift .anc_links li:hover {
        opacity: 0.7;
    }

    #summergift .anc_links li a {
        font-size: 20px;
        padding: 6.5% 10px 16%;
    }

    #summergift .anc_links li::after {
        width: 10%;
        padding-top: 10%;
        bottom: 12%;
    }

    #summergift .anc_guide ._catalog {
        width: 53%;
    }

    #summergift .anc_guide ._catalog::after {
        width: 30px;
        padding-top: 30px;
        right: 20px;
    }
}

/* sec01 */
#summergift .sec01 {
    padding: 0 0 10%;
}

#summergift .ttl_deco {
    position: relative;
    width: 97%;
    margin: 0 auto;
    font-size: 7.8vw;
    display: flex;
    text-align: center;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    padding-bottom: 4%;
    line-height: 1.2;
}

#summergift .ttl_deco._1line {
    background: url(../../../img/usr/genre/rA1/2026/bg_h2_1line.png)no-repeat right center / contain;
    aspect-ratio: 745 / 193;
}

#summergift .ttl_deco._2line {
    background: url(../../../img/usr/genre/rA1/2026/bg_h2_2line.png)no-repeat right center / contain;
    aspect-ratio: 745 / 247;
}

#summergift .ttl_deco .ranking_deco {
    position: relative;
    z-index: 1;
}

#summergift .ttl_deco .ranking_deco::before,
#summergift .ttl_deco .ranking_deco::after {
    content: "";
    position: absolute;
    width: 20%;
    padding-top: 19%;
    top: 55%;
    transform: translateY(-50%);
    background: url(../../../img/usr/genre/rA1/2026/icon_ranking.png)no-repeat center / contain;
}

#summergift .ttl_deco .ranking_deco::before {
    left: -25%;
}

#summergift .ttl_deco .ranking_deco::after {
    right: -25%;
}

#summergift .ttl_deco .ranking_deco #summergift .ttl_deco span {
    position: relative;
    width: 100%;
    display: inline-block;
}

#summergift .ttl_deco small {
    font-size: 80%;
    vertical-align: 0.1rem;
}

#summergift .sec01 .ttl_deco {
    margin-bottom: 2%;
}

#summergift .btn_deco a {
    width: fit-content;
    margin: 0 auto;
    font-family: "Noto Serif JP", serif;
    font-size: 23px;
    text-align: center;
    font-weight: 500;
    color: #ffffff;
    display: block;
    padding: 35px 120px 20px;
}

#summergift .btn_deco a:hover {
    opacity: 1;
}

#summergift .sec01_list_rel {
    position: relative;
    padding-bottom: 20%;
}

#summergift .sec01_list_wrap {
    width: 100%;
    height: 166vw;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(to bottom,
            rgba(0, 0, 0, 1) 75%,
            rgba(0, 0, 0, 0) 100%);
    mask-image: linear-gradient(to bottom,
            rgba(0, 0, 0, 1) 75%,
            rgba(0, 0, 0, 0) 100%);
}

#summergift .acc_button_wrap {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    margin: 0 auto;
    z-index: 3;
    font-size: 4.5vw;
}

#summergift .acc_button_wrap p {
    position: relative;
    padding-right: 30px;
}

#summergift .sec01_list_rel .acc_button_wrap p::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 20px;
    padding-top: 20px;
    background: url(../../../img/usr/genre/rA1/2026/icon_blue_plus.png)no-repeat center / contain;
}

#summergift .sec01_list_rel.open .acc_button_wrap p::after {
    background: url(../../../img/usr/genre/rA1/2026/icon_blue_minus.png)no-repeat center / contain;
}

#summergift .sec01_list_rel.open .sec01_list_wrap {
    height: auto;
    -webkit-mask-image: none;
    mask-image: none;
}

#summergift .acc_close_box {
    display: none;
}

#summergift .sec01_list {
    width: 90%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
    padding-bottom: 10px;
    gap: 20px 0;
}

#summergift .sec01_list li {
    width: 48%;
}

#summergift .sec01_list .sec01_list_ttl {
    width: 100%;
    text-align: center;
    margin-bottom: 5px;
    font-size: 3.8vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 5rem;
    font-weight: bold;
    background: url(../../../img/usr/genre/rA1/2026/bg_sec01_listttl.jpg)repeat-y top / 100%;
    box-shadow: 0px 6px 6px 0px rgba(0, 54, 79, 0.2);
}

#summergift .sec01_list .sec01_list_ttl span {
    font-size: 75%;
}

#summergift .sec01_list li img {
    box-shadow: 0px 6px 6px 0px rgba(0, 54, 79, 0.2);
}

#summergift .sec01 ._btn {
    width: 75%;
    margin: 0 auto;
}

/* ranking */
#summergift .ranking h2 {
    margin-bottom: 5%;
}

/* sec02 */
#summergift .sec02 {
    padding: 0 0 10%;
    background:
        linear-gradient(to bottom,
            #f3fafe 0%,
            rgba(243, 250, 254, 0) 5%);
}

#summergift .banner_box {
    width: 90%;
    margin: 0 auto 5%;
}

#summergift .banner_box._01 {
    background-color: #eb6d8e;
    padding: 15px;
    border-radius: 5px;
    color: #ffffff;
}

#summergift .banner_box .flex_ttl {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 98%;
    margin: 0 auto;
}

#summergift .banner_box._01 .txt {
    font-family: "Noto Serif JP", serif;
    font-weight: bold;
}

#summergift .banner_box._01 .day {
    width: fit-content;
    font-size: 15px;
    background-color: #ffffff;
    color: #da5066;
    border-radius: 50vw;
    padding: 3px 10px;
    font-weight: bold;
}

#summergift .banner_box._01 .ttl {
    color: #e73357;
    background-color: #fffce2;
    text-align: center;
    font-weight: bold;
    font-size: 60px;
    margin: 10px auto;
    width: 98%;
}

#summergift .banner_box._01 .flex_wh_box {
    display: flex;
    width: 98%;
    margin: 0 auto 5px;
}

#summergift .banner_box._01 .flex_wh_box .left {
    width: 45%;
    border: 1px solid #ffffff;
    font-size: 11px;
    text-align: center;
    border-radius: 5px 0 0 5px;
}

#summergift .banner_box._01 .flex_wh_box .left span {
    font-size: 10px;
}

#summergift .banner_box._01 .flex_wh_box .right {
    width: 55%;
    border: 1px solid #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 5px 10px;
}

#summergift .banner_box._01 .flex_wh_box .right p {
    padding: 0 3px;
}

#summergift .banner_box._01 ._note {
    font-size: 10px;
}

#summergift .banner_box._02 {
    font-family: "Noto Sans JP", sans-serif;
    display: block;
    background-color: #ef858c;
    padding: 15px;
    border-radius: 5px;
    color: #ffffff;
}

#summergift .banner_box._02 .txt {
    font-family: "Noto Serif JP", serif;
    font-size: 4.8vw;
    font-weight: bold;
    margin-bottom: 10px;
}

#summergift .banner_box._02 .ttl {
    font-family: "Noto Serif JP", serif;
    font-size: 6.2vw;
    font-weight: bold;
    text-align: center;
    border-bottom: 2px solid #ffffff;
    margin-bottom: 5px;
}

#summergift .banner_box._02 .txt span {
    background-image: url(../../../img/usr/genre/rA1/2026/bannertxt_deco.png);
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
    padding: 3px 3px 10px 8px;
    font-size: 3vw;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: normal;
    margin-right: 5px;
}

#summergift .banner_box._02 .flex_ttl {
    margin-bottom: 10px;
}

#summergift .banner_box._02 .flex_ttl .left {
    font-size: 2.5vw;
    width: 84%;
}

#summergift .banner_box._02 .flex_ttl .left p {
    padding-left: 1rem;
    text-indent: -1rem;
}

#summergift .banner_box._02 .flex_ttl .left .yellow {
    color: #fdf3c7;
    letter-spacing: -0.5px
}

#summergift .banner_box._02 .flex_ttl .right {
    width: 32%;
    padding: 5px;
    text-align: center;
}

#summergift .banner_box._02 .flex_ttl .right img {
    width: 75%;
}

#summergift .banner_box._02 .flex_ttl .right p {
    font-size: 2.5vw;
    color: #fdf3c7;
}

#summergift .banner_box._02 ._note {
    font-size: 2.5vw;
}

#summergift .banner_box._02 ._btn {
    width: 80%;
    font-family: "Noto Serif JP", serif;
}

#summergift .banner_box._03 {
    font-family: "Noto Sans JP", sans-serif;
    background-color: #eb6d8e;
    padding: 10px 15px 15px;
    margin-bottom: 15%;
    border-radius: 5px;
    color: #ffffff;
}

#summergift .banner_box._03 .txt {
    width: 98%;
    font-family: "Noto Serif JP", serif;
    font-weight: bold;
    font-size: 5.5vw;
    text-align: center;
    margin: 0 auto;
}

#summergift .banner_box._03 .txt span {
    font-size: 9vw;
    margin-left: 5px;
}

#summergift .banner_box._03 .ttl {
    color: #e73357;
    background-color: #fffce2;
    text-align: center;
    font-weight: bold;
    font-size: 17vw;
    margin: 5px auto;
    width: 98%;
    padding-top: 5px;
}

#summergift .banner_box._03 .dot {
    position: relative;
}

#summergift .banner_box._03 .dot::after {
    content: "・";
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 25px;
    color: #e73357;
}

#summergift .banner_box._03 .bottom_txt {
    width: 98%;
    font-size: 3vw;
    margin: 0 auto 10px;
}

#summergift .banner_box._03 ._note {
    font-size: 2.5vw;
}

#summergift .banner_box:last-of-type {
    margin: 0 auto 5%;
}

#summergift .genre_box {
    width: 90%;
    margin: 0 auto;
}

#summergift .genre_box._w100 {
    width: 100%;
}

#summergift .genre_box a:hover {
    opacity: 0.7;
}

#summergift .genre_box h3 {
    font-weight: bold;
    color: #fff;
    padding: 2% 3%;
    font-size: 20px;
    margin: 3% 0;
    width: 100%;
    background-size: 100%;
}

#summergift .genre_box.mt1 h3 {
    margin-top: 1%;
}

#summergift h3.bg_gifttypes {
    background-image: url(../../../img/usr/genre/rA1/2026/bg_gifttypes.jpg);
    box-shadow: 0px 6px 6px 0px rgba(0, 54, 79, 0.2);
}

#summergift .flex_box {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#summergift .flex_box p {
    width: 47.5%;
    margin-bottom: 4%;
    border: 1px solid #c9c9c9;
    box-shadow: 0px 6px 6px 0px rgba(0, 54, 79, 0.2);
}

#summergift .brand_list {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 5%;
}

#summergift .brand_bottom_img {
    margin: 10% auto 15%;
}

#summergift .brand_list li {
    border: 1px solid #cccccc;
    width: 47.5%;
    margin-bottom: 4%;
    text-align: center;
    background: white;
    box-shadow: 0px 6px 6px 0px rgba(0, 54, 79, 0.2);
}

#summergift .brand_list li img {
    width: 100%;
}

#summergift .brand_list li p {
    position: relative;
}

#summergift .brand_list li p::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 2%;
    transform: translateY(-50%);
    width: 13px;
    height: 13px;
    background-image: url(../../../img/usr/genre/rA1/2026/icon_arrow_right.png);
    background-size: contain;
    background-repeat: no-repeat;
}

#summergift .price_list {
    width: 90%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 7% auto 10%;
}

#summergift .price_list li {
    font-family: "Noto Sans JP", sans-serif;
    width: 48%;
    box-shadow: 0px 6px 6px 0px rgba(0, 84, 123, 0.2);
    border-radius: 50vw;
    color: #002e79;
    text-align: center;
    padding: 3%;
    margin-bottom: 5%;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.1;
    border: 1px solid #002e79;
    background: linear-gradient(#f6feff 0%, #f6feff 30%, #bde5f2 100%);
}

#summergift .price_list li:hover {
    opacity: 0.7;
}

#summergift .price_list li a {
    color: #002e79;
    display: block;
    width: 100%;
    height: 100%;
}

#summergift .price_list li span {
    font-size: 14px;
}

#summergift .brand_list.pb {
    padding-bottom: 10%;
}

@media screen and (min-width: 769px) {
    #summergift .banner_box:last-of-type {
        margin: 0 auto 3.5%;
    }

    #summergift .sec01 ._btn {
        width: 45%;
    }

    #summergift .ttl_deco {
        width: 60%;
        margin-bottom: 3%;
        padding-bottom: 3%;
        font-size: 45px;
    }

    #summergift .sec02 {
        padding: 0 0 7%;
    }

    #summergift .sec01_list_rel {
        padding-bottom: 13%;
    }

    #summergift .acc_button_wrap {
        font-size: 25px;
    }

    #summergift .sec01_list .sec01_list_ttl {
        font-size: 18px;
    }

    #summergift .sec01_list {
        width: 95%;
    }

    #summergift .sec01_list li {
        width: 23%;
    }

    #summergift .sec01_list_wrap {
        height: 400px;
    }

    #summergift .ranking h2 {
        margin-bottom: 3.5%;
    }

    #summergift .ttl_deco._1line {
        background: url(../../../img/usr/genre/rA1/2026/l_bg_h2_1line.png) no-repeat center / contain;
        aspect-ratio: 505 / 135;
    }

    #summergift .ttl_deco._2line,
    #summergift .sec06 .ttl_deco {
        background: url(../../../img/usr/genre/rA1/2026/l_bg_h2_2line.png) no-repeat center / contain;
        aspect-ratio: 505 / 181;
    }

    #summergift .banner_box._02 ._btn {
        width: 60%;
    }

    #summergift .brand_list {
        margin-left: -1%;
        width: 102%;
        justify-content: flex-start;
        margin-bottom: 4%;
    }

    #summergift .banner_box {
        width: 95%;
        margin: 0 auto 3.5%;
    }

    #summergift .banner_box._01 {
        border-radius: 0;
    }

    #summergift .banner_box .flex {
        display: flex;
        width: 100%;
    }

    #summergift .banner_box._01 .ttl_box {
        display: block;
        width: 60%;
    }

    #summergift .banner_box._01 .flex_wh_box {
        display: block;
        width: 40%;
        padding-left: 15px;
    }

    #summergift .banner_box._01 .flex_ttl {
        width: 100%;
    }

    #summergift .banner_box._01 .ttl {
        width: 100%;
        font-size: 111px;
    }

    #summergift .banner_box._01 .txt {
        font-size: 27px;
    }

    #summergift .banner_box._01 .day {
        font-size: 21px;
        padding: 5px 25px;
    }

    #summergift .banner_box._01 ._note {
        font-size: 12px;
    }

    #summergift .banner_box._01 .flex_wh_box .left {
        width: 100%;
        border-radius: 8px 8px 0 0;
        border: 1px solid #ffffff;
        border-bottom: none;
        font-size: 20px;
        font-weight: 500;
        padding: 5px;
    }

    #summergift .banner_box._01 .flex_wh_box .left span {
        font-weight: normal;
        font-size: 15px;
    }

    #summergift .banner_box._01 .flex_wh_box .right {
        width: 100%;
        border-radius: 0 0 8px 8px;
        border: 1px solid #ffffff;
        flex-wrap: wrap;
        padding: 10px 15px;
    }

    #summergift .banner_box._01 .flex_wh_box .right .p100 {
        width: 100%;
    }

    #summergift .banner_box._01 .flex_wh_box .right .p100 img {
        width: 35%;
        display: block;
        margin: 0 auto;
    }

    #summergift .banner_box._01 .flex_wh_box .right .p50 {
        width: 50%;
    }

    #summergift .banner_box._01 .flex_wh_box .right .p50 img {
        padding: 5px 5px 0;
    }

    #summergift .banner_box._02 {
        padding: 2.5% 3.5%;
    }

    #summergift .banner_box._02 .txt {
        font-size: 40px;
    }

    #summergift .banner_box._02 .txt span {
        font-size: 30px;
        padding: 1% 1% 2.5%;
        margin-right: 10px;
    }

    #summergift .banner_box._02 .ttl {
        font-size: 54px;
    }

    #summergift .banner_box._02 .flex_ttl {
        width: 100%;
        margin-bottom: 20px;
    }

    #summergift .banner_box._02 .flex_ttl .left {
        font-size: 18px;
    }

    #summergift .banner_box._02 .flex_ttl .right {
        padding-left: 2%;
    }

    #summergift .banner_box._02 .flex_ttl .right p {
        font-size: 22px;
        font-weight: 500;
        text-align: left;
    }

    #summergift .banner_box._02 .flex_ttl .right .flex {
        align-items: center;
    }

    #summergift .banner_box._02 .flex_ttl .right ._txt {
        width: 50%;
        line-height: 1.3;
    }

    #summergift .banner_box._02 .flex_ttl .right ._txt img {
        max-width: 15px;
        margin-left: 8px;
        margin-bottom: -2px;
    }

    #summergift .banner_box._02 .flex_ttl .right ._img {
        width: 50%;
    }

    #summergift .banner_box._02 .flex_ttl .right img {
        width: 100%;
    }

    #summergift .banner_box._02 ._note {
        font-size: 16px;
        font-weight: normal;
    }

    #summergift .banner_box._02 ._note span {
        color: #fdf3c7;
    }

    #summergift .banner_box._03 {
        margin: 0 auto;
        padding: 0 3.5% 2%;
    }

    #summergift .banner_box._03 .txt {
        width: 100%;
        text-align: left;
        font-size: 45px;
    }

    #summergift .banner_box._03 .txt span {
        font-size: 70px;
    }

    #summergift .banner_box._03 .ttl {
        width: 100%;
        font-size: 140px;
        margin: 0 auto 5px;
        line-height: 1;
        padding: 5% 5% 2%;
    }

    #summergift .banner_box._03 .dot::after {
        top: -5%;
        font-size: 50px;
        line-height: 1;
    }

    #summergift .banner_box._03 .bottom_txt {
        width: 100%;
        font-size: 26px;
    }

    #summergift .banner_box._03 ._note {
        font-size: 16px;
    }

    #summergift .lead {
        overflow: hidden;
        /* background-size: 17%, 22%; */
        padding: 3.5% 3% 10%;
        background: linear-gradient(to bottom, #f0f9fe 0%, rgba(240, 249, 254, 0) 3%), linear-gradient(to bottom, rgba(243, 250, 254, 0) 90%, #f3fafe 100%), url(../../../img/usr/genre/rA1/2026/l_bg_lead.png) no-repeat top center / 100% 100%;
    }

    #summergift .lead .lead_line img {
        width: calc(100% + 7%);
        margin-left: -3.5%;
    }

    #summergift .anc_guide li:not(:last-of-type) {
        margin: 0;
    }

    #summergift .sec01 {
        padding: 0 0 7%;
    }

    #summergift .btn_deco a {
        width: 60%;
        font-size: 30px;
        padding: 4% 4% 2%;
    }

    #summergift .genre_box {
        width: 95%;
    }

    #summergift .genre_box h3 {
        padding: 15px 13px;
        font-size: 30px;
    }

    #summergift .flex_box p {
        width: 23%;
        margin-bottom: 25px;
    }

    #summergift .brand_list li {
        width: 23%;
        margin-bottom: 20px;
        margin: 0 1% 25px;
    }

    #summergift .brand_list.pb {
        padding-bottom: 10%;
    }

    #summergift .price_list li {
        width: 31%;
        font-size: 26px;
        padding: 15px 20px;
        margin-bottom: 3%;
        border: 2px solid #002e79;
    }

    #summergift .price_list li span {
        font-size: 18px;
    }

    #summergift .brand_bottom_img {
        margin: 1% auto 13%;
    }

    #summergift .gift_types {
        margin-bottom: 6%;
    }

    #summergift .price_list {
        width: 95%;
        margin: 0 auto;
    }

    #summergift .by_budget {
        margin-bottom: 7%;
    }
}

@media screen and (min-width: 769px) and (max-width: 880px) {
    #summergift .banner_box._01 .ttl {
        font-size: 95px;
    }

    #summergift .banner_box._01 .txt {
        font-size: 23px;
    }

    #summergift .banner_box._01 .day {
        font-size: 19px;
    }

    #summergift .banner_box._01 ._note {
        font-size: 11px;
    }

    #summergift .banner_box._02 .ttl {
        font-size: 46px;
    }

    #summergift .banner_box._02 .txt {
        font-size: 37px;
    }

    #summergift .banner_box._02 .txt span {
        font-size: 25px;
    }

    #summergift .banner_box._03 .ttl {
        font-size: 130px;
    }

    #summergift .banner_box._03 .txt {
        font-size: 38px;
    }

    #summergift .banner_box._03 .txt span {
        font-size: 60px;
    }
}

/* 品物から選ぶ */
#summergift .acc_wrap {
    width: 90%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto 10%;
}

#summergift .acc {
    margin: 8% auto 0;
    width: 100%;
}

#summergift .by_item .acc {
    background: rgba(255, 255, 255, 0.5);
    box-shadow: 0px 6px 6px 0px rgba(0, 54, 79, 0.1);
    padding: 20px;
}

#summergift .item_image._acc {
    width: 40%;
}

#summergift .nav-acc {
    display: none;
    margin: 0 auto;
}

#summergift .nav-open {
    margin: 0 auto;
    color: #ffffff;
    font-size: 28px;
    position: relative;
    text-align: center;
    font-weight: 600;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#summergift .nav-open:hover {
    cursor: pointer;
}

#summergift .nav-open_head {
    width: 55%;
    padding-right: 6%;
    color: #29a1a9;
}

#summergift .nav-open_head h3 {
    font-size: 18px;
    color: #29a1a9;
}

#summergift .nav-open_head._wh {
    color: #ffffff;
    width: 80%;
    margin-left: 3%;
    padding: 0;
    font-size: 16px;
}

#summergift .item_small {
    font-size: 16px;
}

#summergift .nav-acc ul {
    list-style: none;
    gap: 20px;
    display: grid;
    margin: 20px 0 0;
}

#summergift .nav-acc li {
    font-size: 4vw;
    position: relative;
}

#summergift .nav-acc li a {
    color: #4a4949;
    display: block;
    height: auto;
    border-radius: 50vw;
    border: 1px solid #29a1a9;
    background: white;
    padding: 3% 7%;
    box-shadow: 0px 3px 3px 0px rgba(0, 54, 79, 0.1);
}

#summergift .nav-acc li a::after {
    content: "";
    display: block;
    width: 18px;
    height: 18px;
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    background: url(../../../img/usr/genre/rA1/2026/icon_arrow_green_right.png)no-repeat center / contain;
}

#summergift .nav-open::before,
#summergift .nav-open::after {
    content: "";
    display: inline-block;
    width: 20px;
    height: 2px;
    background-color: #29a1a9;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    transition: opacity 1s;
}

#summergift .by_item .nav-open::before {
    width: 22px;
    height: 22px;
    background: url(../../../img/usr/genre/rA1/2026/icon_green_plus.png)no-repeat center / contain;
}

#summergift .by_item .nav-open::after {
    display: none;
}

#summergift .nav-open._wh::before,
#summergift .nav-open._wh::after {
    background-color: #ffffff;
}

#summergift .nav-open::after {
    transform: translateY(-50%) rotate(90deg);
}

#summergift .nav-open.active::before {
    opacity: 0;
}

#summergift .nav-open.active::before {
    opacity: 1;
    background: url(../../../img/usr/genre/rA1/2026/icon_green_minus.png)no-repeat center / contain;
}

#summergift .nav-open.active::after {
    transform: translateY(-50%) rotate(180deg);
}

#summergift .item_link._acc {
    display: none;
}

@media screen and (min-width: 769px) {
    #summergift .acc {
        width: 48%;
        margin: 8% 0 0;
    }

    #summergift .nav-open_head h3 {
        font-size: 20px;
    }

    #summergift .by_item .acc {
        margin: 0 0 3%;
        height: fit-content;
    }

    #summergift .nav-acc li {
        font-size: 16px;
    }

    #summergift .nav-acc li a::after {
        width: 20px;
        height: 20px;
    }

    #summergift .acc_wrap {
        width: 95%;
        margin: 0 auto 7%;
    }
}

/* sec03 */
#summergift .sec03 {
    border-radius: 5vw 5vw 0 0;
    padding: 8% 0 10%;
    background: rgba(255, 255, 255, 0.5);
}

#summergift .guide_link {
    width: 90%;
    margin: 5% auto 8%;
    font-family: "Noto Sans JP", sans-serif;
}

#summergift .guide_link li {
    position: relative;
    border-radius: 50vw;
    border: 1px solid #004894;
    color: #004894;
    text-align: center;
    font-size: 4.2vw;
    font-weight: 600;
    margin-bottom: 4%;
    background-repeat: no-repeat, repeat;
    background-position: center left 10%;
}

#summergift .guide_link li a {
    width: 100%;
    padding: 6%;
    display: block;
    color: #004894;
}

#summergift .guide_link ._04.sp a {
    padding-bottom: 8%;
    padding-left: 20%;
}

#summergift .guide_link ._01 {
    background-image: url(../../../img/usr/genre/rA1/2026/btn_image01.png), url(../../../img/usr/genre/rA1/2026/bg_09.jpg);
    background-size: auto 80%, cover;
}

#summergift .guide_link ._02 {
    background-image: url(../../../img/usr/genre/rA1/2026/btn_image02.png), url(../../../img/usr/genre/rA1/2026/bg_10.jpg);
    background-size: auto 80%, cover;
}

#summergift .guide_link ._03 {
    background-image: url(../../../img/usr/genre/rA1/2026/btn_image03.png), url(../../../img/usr/genre/rA1/2026/bg_11.jpg);
    background-size: auto 80%, cover;
}

#summergift .guide_link ._04 {
    background-image: url(../../../img/usr/genre/rA1/2026/btn_image04.png);
    background-size: auto 47%;
    background-repeat: no-repeat;
    background-color: #ffffff;
}

#summergift .guide_link ._01::after,
#summergift .guide_link ._02::after,
#summergift .guide_link ._03::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 7%;
    transform: translateY(-50%);
    width: 13px;
    height: 13px;
    background-image: url(../../../img/usr/genre/rA1/2026/icon_arrow_right_bl.png);
    background-size: contain;
    background-repeat: no-repeat;
}

#summergift .guide_link ._04::after {
    content: "";
    position: absolute;
    bottom: 2%;
    right: 50%;
    transform: translateY(-50%);
    width: 13px;
    height: 13px;
    background-image: url(../../../img/usr/genre/rA1/2026/icon_arrow_down_bl.png);
    background-size: contain;
    background-repeat: no-repeat;
}

#summergift .price_txt_box {
    width: 80%;
    font-family: "Noto Sans JP", sans-serif;
    background-color: #004894;
    margin: 0 auto;
    color: #ffffff;
    padding: 4%;
    text-align: center;
    font-size: 23px;
    line-height: 1.3;
}

#summergift .yl {
    color: #fed631;
}

#summergift .small {
    font-size: 14px;
    font-weight: 300;
}

@media screen and (min-width: 769px) {
    #summergift .sec03 {
        padding: 6% 0;
    }

    #summergift .guide_link {
        width: 96%;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-around;
        margin: 0 auto 3.5%;
    }

    #summergift .guide_link li:hover {
        opacity: 0.7;
    }

    #summergift .guide_link.pc {
        margin: 0 auto 5%;
    }

    #summergift .guide_link li {
        border: 2px solid #004894;
        width: 48%;
        font-size: 18px;
        margin-bottom: 20px;
    }

    #summergift .guide_link li a {
        padding: 20px;
    }

    #summergift .guide_link.pc li {
        width: 70%;
        background-position: center left 20%;
        margin-bottom: 0;
    }

    #summergift .guide_link.pc li a {
        padding-bottom: 30px;
        padding-left: 60px;
    }

    #summergift .price_txt_box {
        width: 67%;
        font-size: 30px;
        font-weight: bold;
        line-height: 1.5;
        padding: 10px;
    }
}

/* by opponent */
#summergift .by_opponent {
    padding-bottom: 0;
}

/* #summergift .by_opponent.last {
    padding-bottom: 10%;
} */

#summergift .by_opponent h3 {
    text-align: center;
    font-size: 7vw;
    margin: 7% auto 0;
    filter:
        drop-shadow(0 0 10px rgba(255, 255, 255, 1)) drop-shadow(0 0 5px rgba(255, 255, 255, 1));
}

#summergift .by_opponent h3 span {
    position: relative;
}

#summergift .by_opponent h3 span::before,
#summergift .by_opponent h3 span::after {
    content: "";
    position: absolute;
    width: 5vw;
    padding-top: 5vw;
    top: 55%;
    transform: translateY(-50%);
    background: url(../../../img/usr/genre/rA1/2026/bg_h3.png) no-repeat center / contain;
}

#summergift .by_opponent h3 span::before {
    left: -7vw;
}

#summergift .by_opponent h3 span::after {
    right: -7vw;
}

/* sec04 */
#summergift .sec04 {
    padding: 10% 5%;
    width: 100%;
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.5);
}

#summergift .mailmagazine {
    font-family: "Noto Sans JP", sans-serif;
    position: relative;
    margin-bottom: 13%;
    background-color: #459bdf;
    text-align: center;
    padding: 15px;
}

#summergift .mailmagazine::after {
    content: "";
    position: absolute;
    border: 1px solid #fff;
    top: 5px;
    bottom: 5px;
    left: 5px;
    right: 5px;
    pointer-events: none;
}

#summergift .mailmagazine .magazine01 {
    position: absolute;
    width: 13%;
    top: 2%;
    left: 1%;
    z-index: 2;
}

#summergift .mailmagazine .magazine02 {
    position: absolute;
    width: 12%;
    top: 10%;
    right: 3%;
    z-index: 2;
}

#summergift .mailmagazine .ttl {
    color: #ffffbf;
    font-size: 18px;
    font-weight: bold;
}

#summergift .mailmagazine .txt {
    color: #ffffff;
    font-size: 12px;
    margin-bottom: 10px;
    line-height: 1.3;
}

#summergift .mailmagazine .magazine_btn {
    position: relative;
    display: block;
    width: 80%;
    margin: 0 auto;
    background-color: #ffffff;
    color: #2f5e75;
    font-size: 12px;
    border-radius: 50vw;
    font-weight: bold;
    padding: 5px 20px 5px 0;
    z-index: 2;
}

#summergift .mailmagazine .magazine_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    background-image: url(../../../img/usr/genre/rA1/2026/icon_arrow_indigo.png);
    background-size: 100%;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 3;
}

#summergift .acc._02 {
    width: 100%;
    font-family: "Noto Sans JP", sans-serif;
    border: 2px solid #002e79;
    border-radius: 20px;
    overflow: hidden;
    margin: 0 auto;
}

#summergift .acc_wrap_02 {
    padding-top: 40px;
}

#summergift .nav-open._02 {
    color: #ffffff;
    background: #607aa4;
    padding: 14px;
    position: relative;
}

#summergift .nav-open._02::before,
#summergift .nav-open._02::after {
    right: 5%;
}

#summergift .list_ttl {
    font-size: 17px;
    font-weight: bold;
    color: #002e79;
    position: relative;
    padding-left: 15px;
}

#summergift .list_ttl::before {
    content: "";
    position: absolute;
    left: 0%;
    background: #002e79;
    width: 5px;
    height: 100%;
}

#summergift .acc_contents {
    padding: 0 20px 20px;
    margin: 0;
}

#summergift .acc_contents_gray {
    padding: 0 20px 20px;
    margin: 0;
}

#summergift .list_ttl_sub {
    display: block;
    width: fit-content;
    font-size: 16px;
    font-weight: normal;
    background-color: #fbeceb;
    padding: 5px 10px;
    border-radius: 100px;
    z-index: -1;
    line-height: 1.2;
}

#summergift .acc_note._02 {
    border-bottom: none;
}

#summergift .acc_note,
#summergift .acc_note_text {
    font-size: 16px;
    margin: 2% 0 0;
    padding-bottom: 20px;
    color: #4a4949;
}

#summergift .acc_note {
    border-bottom: 1px solid #cccccc;
}

#summergift .acc_note._flex {
    display: flex;
    flex-wrap: wrap;
    padding: 0;
    margin: 0;
}

#summergift .acc_note._flex .acc_note_text {
    width: 65%;
}

#summergift .acc_note._02._flex {
    display: flex;
    align-items: center;
    width: 100%;
}

#summergift .acc_note._02._flex ._txt {
    width: 65%;
    color: #363635;
    font-weight: bold;
    font-size: 18px;
    border: none;
    box-shadow: none;
}

#summergift .acc_note._02._flex .arrow {
    max-width: 12px;
    margin-bottom: -2px;
    margin-left: 10px;
}

#summergift .acc_note._02._flex ._img {
    width: 35%;
    border: none;
    box-shadow: none;
}

#summergift ._red {
    color: #c41e08;
}

#summergift .note_box {
    border: 2px solid #cccccc;
    background: white;
    border-radius: 20px;
    padding: 20px;
}

#summergift .note_box_ttl {
    text-align: center;
    margin: 0 auto;
}

#summergift .note_box_txt {
    margin: 0px 20px 0px 0px;
    width: 60%;
}

#summergift .note_box_caution {
    text-indent: -1em;
    margin-left: 1em;
    margin-top: 10px;
}

#summergift .note_box_caution p {
    margin: 0;
    font-size: 14px;
}

#summergift .note_box_wrap {
    display: flex;
    margin: 10px 0 0;
    justify-content: space-between;
}

#summergift .note_box_image {
    width: 100%;
    margin: 0 auto;
}

#summergift .note_strong {
    font-weight: bold;
    display: block;
    margin-bottom: 10px;
}

#summergift .note_box._pkg {
    margin: 0 auto;
    width: 100%;
    padding: 0 10px;
}

#summergift .note_box_side {
    margin-top: 10px;
    text-align: center;
    color: #4a4949;
}

#summergift .note_box_inner {
    width: 48%;
}

#summergift .note_box_side p {
    font-size: 14px;
}

#summergift .note_box_side p span {
    display: block;
    font-weight: bold;
}

#summergift .acc_note._03 {
    border-bottom: none;
    text-indent: -1em;
    margin-left: 1em;
}

@media screen and (min-width: 769px) {
    #summergift .acc_note._02._flex {
        width: 50%;
        padding-left: 7%;
    }

    #summergift .acc_note._02._flex ._img img {
        width: 75%;
    }

    #summergift .note_box_wrap {
        width: 90%;
        margin: 0 auto;
    }

    #summergift .note_box_inner {
        width: 45%;
    }

    #summergift .list_ttl {
        display: flex;
        justify-content: space-between;
    }

    #summergift .list_ttl_sub {
        z-index: 1;
    }

    #summergift .acc_note_text {
        width: 50%;
    }

    #summergift .acc_note._flex {
        width: 50%;
    }

    #summergift .note_box_image._h100 img {
        max-height: 120px;
        width: auto;
        margin: 0 auto;
        display: block;
    }

    #summergift .nav-open._02 {
        padding: 20px;
    }

    #summergift .mailmagazine {
        margin-bottom: 10%;
        padding: 20px;
    }

    #summergift .mailmagazine::after {
        top: 10px;
        bottom: 10px;
        left: 10px;
        right: 10px;
    }

    #summergift .mailmagazine .ttl {
        font-size: 35px;
        line-height: 1;
        margin-bottom: 15px;
    }

    #summergift .mailmagazine .txt {
        font-size: 15px;
        line-height: 1.5;
        margin-bottom: 15px;
    }

    #summergift .mailmagazine .magazine_btn {
        width: 50%;
        font-size: 15px;
        padding: 8px 20px 8px 0;
        margin-bottom: 5px;
    }

    #summergift .mailmagazine .magazine_btn::after {
        right: 8%;
        width: 10px;
        height: 10px;
    }

    #summergift .by_opponent h3 {
        font-size: 30px;
        margin: 0 auto 0;
    }

    #summergift .by_opponent h3 span::before,
    #summergift .by_opponent h3 span::after {
        width: 25px;
        padding-top: 25px;
    }

    #summergift .by_opponent h3 span::before {
        left: -35px;
    }

    #summergift .by_opponent h3 span::after {
        right: -35px;
    }
}

/* sec05 */
#summergift .sec05 {
    font-family: "Noto Sans JP", sans-serif;
    padding: 3% 0 13%;
    background-image: url(../../../img/usr/genre/rA1/2026/bg_12.jpg);
    background-repeat: repeat;
    background-size: 100%;
    font-weight: 500;
}

#summergift .trivia_wrap {
    padding: 5% 5% 20%;
    height: 1190px;
    overflow: hidden;
    position: relative;
    -webkit-mask-image: linear-gradient(to bottom,
            rgba(0, 0, 0, 1) 60%,
            rgba(0, 0, 0, 0) 100%);
    mask-image: linear-gradient(to bottom,
            rgba(0, 0, 0, 1) 60%,
            rgba(0, 0, 0, 0) 100%);
}

#summergift .main_ttl._trivia {
    font-family: "Noto Serif JP", serif;
    text-align: center;
    border-bottom: none;
    margin: 0 auto 20px;
}

#summergift .main_ttl._trivia h2 {
    font-size: 20px;
    color: #004894;
}

#summergift .trivia_inner {
    display: flex;
    flex-wrap: wrap;
}

#summergift .lead_text._trivia {
    color: #494949;
    margin: 20px 0;
}

#summergift .sec05.open_lead_text {
    height: auto;
}

#summergift .tribia {
    position: relative;
}

#summergift .trivia_box {
    color: #494949;
    background-color: #fff;
    padding: 20px 30px 30px;
    width: 100%;
    margin: 20px 0 0;
}

#summergift .trivia_txt {
    margin: 20px 0 0;
}

#summergift .trivia_box._02 {
    margin: 0;
}

#summergift .ttl_q {
    width: 10%;
    margin-right: 2%;
}

#summergift .trivia_ttl_wrap {
    font-weight: bold;
    border-bottom: 4px dotted #004894;
    margin: 0 auto;
    color: #004894;
    padding: 0 0 10px;
    display: flex;
    align-items: center;
    line-height: 1.4;
}

#summergift .trivia_list {
    position: relative;
    padding-left: 20px;
}

#summergift .trivia_list li::before {
    display: block;
    content: "●";
    position: absolute;
    left: 0;
}

#summergift .tribia {
    position: relative;
}

#summergift .trivia_wrap.open_lead_text {
    height: auto;
    -webkit-mask-image: none;
    mask-image: none;
}

#summergift .trivia_wrap.open_lead_text::before {
    display: none;
}

@media screen and (min-width: 769px) {
    #summergift .main_ttl._trivia h2 {
        font-size: 42px;
    }

    #summergift .trivia_wrap {
        padding: 5% 2.5% 100px;
    }

    #summergift .sec04 {
        padding: 0 3% 6%;
    }

    #summergift .nav-open_head._wh {
        margin: 0 auto;
        font-size: 20px;
    }

    #summergift .ttl_q {
        width: 5%;
    }
}

/* sec06 */
#summergift .sec06 {
    width: 100%;
    margin: 0 auto 12%;
    padding: 10% 0 0;
}

#summergift .sec06 .ttl_deco {
    width: 97%;
    margin: 0 auto 5%;
}

#summergift .question_box {
    width: 90%;
    margin: 0 auto 5%;
    font-family: "Noto Serif JP", serif;
    position: relative;
    color: #ffffff;
    background-image: url(../../../img/usr/genre/rA1/2026/sec06_bg.jpg);
    background-size: 100% 100%;
    border-radius: 10px;
    padding: 7% 5%;
    text-align: center;
}

#summergift .question_box::after {
    position: absolute;
    border: 2px solid #fff;
    border-radius: 10px;
    content: "";
    top: 5px;
    bottom: 5px;
    left: 5px;
    right: 5px;
    pointer-events: none;
}

#summergift .question_box h3 {
    font-weight: 800;
    font-size: 17px;
    margin-bottom: 2%;
}

#summergift .question_box p {
    font-size: 13px;
    margin-bottom: 2%;
}

#summergift .question_box a {
    position: relative;
    color: #ffffff;
    font-weight: 800;
    font-size: 18px;
    z-index: 2;
}

#summergift .question_box a::after {
    content: "";
    position: absolute;
    top: 55%;
    right: -15%;
    transform: translateY(-50%);
    width: 10px;
    height: 15px;
    background-image: url(../../../img/usr/genre/rA1/2026/icon_arrow_right_wh.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100% auto;
}

@media screen and (min-width: 769px) {
    #summergift .sec06 {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: center;
        padding: 10% 1.5% 0;
        margin: 0 auto 10%;
    }

    #summergift .sec06 .ttl_deco {
        background: url(../../../img/usr/genre/rA1/2026/l_bg_h2_2line.png) no-repeat center / contain;
        aspect-ratio: 505 / 181;
        width: 60%;
        margin-bottom: 3%;
        padding-bottom: 3%;
        font-size: 45px;
    }

    #summergift .question_box {
        position: relative;
        width: 47%;
        min-height: 260px;
        padding: 20px;
        margin-bottom: 30px;
    }

    #summergift .question_box h3 {
        font-size: 26px;
        margin-bottom: 15px;
        width: 100%;
        min-height: 80px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    #summergift .question_box p {
        font-size: 17px;
        margin-bottom: 15px;
        width: 100%;
    }

    #summergift .question_box a {
        position: absolute;
        bottom: 25px;
        left: 50%;
        transform: translateX(-50%);
        color: #ffffff;
        font-weight: 800;
        font-size: 18px;
    }
}

/* sec11 */
#summergift .sec11 {
    margin: 0 auto;
    padding: 10% 0 14%;
    border-radius: 5vw 5vw 0 0;
    background: rgba(255, 255, 255, 0.5);
}

#summergift .sec11 .ttl {
    text-align: center;
    width: 90%;
    margin: 0 auto;
    font-size: 7vw;
}

#summergift .feature {
    padding-bottom: 90px;
}

#summergift .feature_wrap {
    font-family: "Noto Sans JP", sans-serif;
    width: 94%;
    margin: 0 auto;
    padding: 40px 0 0;
    height: 610px;
    overflow: hidden;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 30px 20px;
    -webkit-mask-image: linear-gradient(to bottom,
            rgba(0, 0, 0, 1) 70%,
            rgba(0, 0, 0, 0) 100%);
    mask-image: linear-gradient(to bottom,
            rgba(0, 0, 0, 1) 70%,
            rgba(0, 0, 0, 0) 100%);
}

#summergift .feature {
    position: relative;
}

#summergift .feature_inner {
    gap: 40px;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}

#summergift .feature_wrap.open_lead_text {
    height: auto;
    -webkit-mask-image: none;
    mask-image: none;
}

#summergift .feature_wrap.open_lead_text::before {
    display: none;
}

#summergift .feature_box {
    width: 100%;
}

#summergift .feature_ttl {
    font-size: 20px;
    font-weight: bold;
    color: #29a1a9;
}

#summergift .feature_ttl small {
    font-size: 80%;
}

#summergift .lead_more a {
    color: #409cdd;
    font-size: 14px;
}

#summergift .lead_text._feature {
    margin: 10px 0;
    color: #494949;
}

#summergift .acc_open_03 {
    font-family: "Noto Sans JP", sans-serif;
}

@media screen and (min-width: 769px) {
    #summergift .sec11 {
        padding: 60px 0 120px;
        margin: 0;
    }

    #summergift .sec11 .ttl {
        font-size: 45px;
    }

    #summergift .feature_inner {
        width: 48%;
    }

    #summergift .feature_wrap {
        height: 390px;
    }

    #summergift .feature_wrap::before {
        height: 100%;
    }

    #summergift .lead .lead_text {
        width: 70%;
        font-size: 16px;
        height: 90px;
    }

    #summergift .acc_button,
    #summergift .acc_button_02,
    #summergift .acc_button_03 {
        width: 170px;
    }

    #summergift .acc_button_03 {
        bottom: -80px;
    }

    #summergift .feature {
        padding-bottom: 30px;
    }
}