/* リセットCSS */

* {
    margin: 0;
    padding: 0;
}

*,
 ::before,
 ::after {
    border-style: solid;
    box-sizing: border-box;
    border-width: 0;
}

body {
    font-family: "Noto Sans JP", sans-serif!important;
    font-weight: 400;
    line-height: 1.5;
    font-size: 16px;
    text-align: justify;
    text-rendering: optimizeSpeed;
    color: #222222;
    overflow-x: hidden;
    letter-spacing: 0!important;
}

.is-fixed body {
    overflow: hidden;
}

html {
    height: 100%;
    margin: 0!important;
    scroll-behavior: smooth;
    overflow-x: hidden;
}

ul,
ol {
    list-style: none;
}

a {
    background-color: transparent;
    text-decoration: none;
    text-decoration-skip-ink: auto;
}

img {
    width: 100%;
    display: block;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

@media screen and (max-width: 1188px) {
    html {
        font-size: 1.4134275618vw;
    }
}

.pc-dn {
    display: none;
}

.sp-dn {
    display: block;
}

@media screen and (max-width: 1024px) {
    body {
        overflow-x: hidden;
    }
    html {
        font-size: 16px;
    }
}

@media screen and (max-width: 480px) {
    .pc-dn {
        display: block;
    }
    .sp-dn {
        display: none;
    }
}

@media screen and (max-width: 380px) {
    html {
        font-size: 4.2105263158vw;
    }
    body {
        overflow-x: hidden;
    }
}

a,
button,
.btn {
    cursor: pointer;
    transition: 0.3s;
}

a:hover,
button:hover,
.btn:hover {
    opacity: 0.5;
}

@media screen and (max-width: 768px) {
    a:hover,
    button:hover,
    .btn:hover {
        opacity: 1;
    }
}

h2.title {
    color: #00AD46;
    text-align: center;
    font-family: "Barlow Semi Condensed";
    font-size: clamp(2.5rem, 4.9vw, 4.375rem);
    font-weight: 700;
    line-height: 100%;
    text-transform: uppercase;
}

.title_label {
    text-align: center !important;
    font-family: "Noto Sans JP";
    font-size: clamp(1rem, 1.4vw, 1.25rem);
    font-weight: 500;
    color: #000;
}

.title_text {
    margin-top: clamp(1.4rem, 3.2vw, 2.12rem);
    text-align: center !important;
}


/*-----共通のCSS-----*/


/*コンテンツ幅*/

.wrap {
    max-width: calc(1188px + clamp(2rem, 6vw, 3rem));
    margin: 0 auto;
    padding: 0 clamp(1rem, 3vw, 1.5rem);
}

@media screen and (1440px > width) {}

@media screen and (430px > width) {
    .wrap {
        padding: 0 1rem;
    }
}


/*-----ファーストビュー-----*/

section.fv_sec {
    margin-top: 86px;
    background: #00AD46;
    position: relative;
    height: 40.1875rem;
    overflow: hidden;
}

section.fv_sec .fv_bk {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
}

section.fv_sec .fv_img {
    position: relative;
    z-index: 1;
}

section.fv_sec h2 {
    color: #FFF;
    text-align: center;
    text-shadow: 0 0 30px #000;
    font-family: "Noto Sans JP";
    font-size: clamp(1.8rem, 3.2vw, 3.125rem);
    font-weight: 900;
}

section.fv_sec h1 {
    position: relative;
    top: 25rem;
}

section.fv_sec h1 span.first,
section.fv_sec h1 span.last {
    position: relative;
    display: inline-block;
    font-size: clamp(1.5rem, 2.78vw, 2.5rem);
    padding: clamp(10px, 1.2vw, 18px) clamp(14px, 1.8vw, 26px);
    font-weight: 900;
    line-height: 150%;
    background: #fff;
    box-shadow: 0 10px 25px rgba(0, 0, 0, .15);
    z-index: 1;
}

section.fv_sec h1 span.last {
    top: 1rem;
}

section.fv_sec .img_bk {
    border-radius: 0.88063rem 0 0 0.88063rem;
    background: #FFF;
    padding: 1.5rem 1.5rem 1.5rem 1.5rem;
    display: inline-block;
    position: absolute;
    right: 0%;
    top: 9rem;
    width: min(570px, 51vw);
    max-width: 570px;
}

section.fv_sec .img_bk img {
    height: auto;
    display: block;
}


/*スマホ*/

@media (max-width: 1000px) {
    section.fv_sec {
        margin-top: 60px;
    }
}

@media (max-width: 480px) {
    section.fv_sec .fv_bk {
        width: 115%;
        height: auto;
        object-position: -2rem;
    }
    section.fv_sec h2 {
        text-shadow: 0 0 15px #000;
        line-height: 120%;
        font-size: 1.7rem;
    }
    section.fv_sec .fv_img {
        top: -6.5rem;
    }
    section.fv_sec .img_bk {
        border-radius: 0.5rem 0 0 0.5rem;
        padding: 0.5rem 0.5rem 0.5rem 0.5rem;
        top: 15rem;
        width: auto;
    }
    section.fv_sec h1 span.first,
    section.fv_sec h1 span.last {
        font-size: 1.47375rem;
        box-shadow: 0 8px 10px rgba(0, 0, 0, .15);
    }
    section.fv_sec {
        padding-bottom: 11rem;
        height: auto;
    }
    section.fv_sec h1 {
        top: 6.5rem;
    }
    section.fv_sec h1 span.last {
        top: 0.5rem;
        line-height: 110%;
    }
    section.fv_sec .img_bk img {
        width: clamp(250px, 48vw, 570px);
        height: auto;
        display: block;
    }
}


/*-----プロジェクトについて-----*/

section.project_sec {
    background: url("./img/project.webp") top/cover no-repeat;
    padding: clamp(3rem, 7.7vw, 6.25rem) 0;
}

section.project_sec h3 {
    color: #222;
    text-align: center;
    font-size: clamp(1.1rem, 2.2vw, 1.5625rem);
    font-weight: 500;
    line-height: 150%;
    margin-top: clamp(2rem, 5vw, 3.58rem);
    margin-bottom: clamp(1rem, 2.5vw, 1.5rem);
}

section.project_sec h3 span {
    color: #00AD46;
    font-size: clamp(1.2rem, 2.6vw, 1.875rem);
    font-weight: 900;
    line-height: 150%;
}

section.project_sec p {
    text-align: center;
    line-height: 180%;
}


/*スマホ*/

@media (max-width: 768px) {
    section.project_sec p {
        text-align: justify;
        line-height: 140%;
    }
    section.project_sec h3 {
        text-align: justify;
        letter-spacing: normal;
    }
}


/*-----支援内容-----*/

section.support_sec {
    padding: clamp(3rem, 7.7vw, 6.25rem) 0;
}

section.support_sec .support_box {
    font-size: clamp(2.2rem, 4.5vw, 3.5rem);
}

section.support_sec .title_text {
    margin-top: clamp(1.4rem, 3.2vw, 2.12rem);
    margin-bottom: 1.5rem;
}

section.support_sec .support_box .gold_box {
    border-radius: 0.9375rem;
    box-shadow: 0 4px 14px 0 rgba(0, 0, 0, 0.25);
    margin: 0 auto;
    background: #fff;
    max-width: 46.625rem;
}

section.support_sec .support_box .gold_box .support_head {
    position: relative;
    padding: 1rem 0;
    background: #b07d2c;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.9375rem 0.9375rem 0 0;
}

section.support_sec .support_box .gold_box .support_title {
    color: #fff;
    font-size: clamp(1.5rem, 2.78vw, 2.5rem);
    font-weight: 700;
    letter-spacing: .05em;
}

section.support_sec .support_box .gold_box .gold_mark {
    position: absolute;
    left: 5%;
    top: 50%;
    transform: translateY(-50%);
    width: clamp(5rem, 8vw, 8.50075rem);
    height: clamp(5rem, 8vw, 8.50075rem);
}

section.support_sec .support_box .gold_box .support_body {
    padding: clamp(1.4rem, 2.8vw, 2.12rem);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
}

section.support_sec .support_box .gold_box .support_body .money {
    flex: 1 1 0;
}

section.support_sec .support_box .gold_box .support_body .money img {
    display: block;
    max-width: 100%;
    height: auto;
    margin-top: .6rem;
}


/* 右：アルプロン商品 */

section.support_sec .support_box .gold_box .support_body .protein {
    flex: 1 1 0;
    text-align: center;
}

section.support_sec .support_box .gold_box .support_body .protein img {
    display: block;
    width: min(352.03px, 100%);
    height: auto;
    margin: .6rem auto 0;
}

section.support_sec .support_box .gold_box .support_body .money_text {
    color: #876E3A;
    font-size: clamp(1.5rem, 2.6vw, 1.875rem);
    font-weight: 700;
    line-height: 100%;
}

section.support_sec .support_box .gold_box .support_body .protein_text {
    text-align: center;
    font-size: clamp(1.5rem, 2.6vw, 1.875rem);
    font-style: normal;
    font-weight: 700;
    line-height: 120%;
}

section.support_sec .support_box .gold_box .support_body .protein_text span {
    font-size: clamp(1.2rem, 2.3vw, 1.625rem);
}

section.support_sec .support_box .gold_box .support_body .plus {
    position: relative;
    flex: 0 0 44px;
    width: 30px;
    height: 30px;
    margin: 0 5px;
}

section.support_sec .support_box .gold_box .support_body .plus::before,
section.support_sec .support_box .gold_box .support_body .plus::after {
    display: block;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    background-color: #362C25;
}

section.support_sec .support_box .gold_box .support_body .plus:before {
    width: 6px;
    height: 44px;
}

section.support_sec .support_box .gold_box .support_body .plus:after {
    width: 44px;
    height: 6px;
}


/*ここからシルバーブロンズ*/

section.support_sec .support_box .flex_box {
    display: flex;
    font-size: clamp(1.5rem, 2.5vw, 1.875rem);
    margin-top: 5.31rem;
    gap: clamp(1.2rem, 4vw, 2.8rem);
}

section.support_sec .support_box .flex_box>div {
    flex: 1;
}

section.support_sec .support_box .gold_box .support_head.silver {
    background: #7A7673;
    justify-content: flex-end;
    padding-right: 2.5rem;
}

section.support_sec .support_box .gold_box .support_head.bronze {
    background: #905B30;
    justify-content: flex-end;
    padding-right: 2.5rem;
}

section.support_sec .support_box .flex_box .gold_box .support_body .money {
    flex: 0.7 1 0;
}

section.support_sec .support_box .flex_box .gold_box .support_body .protein {
    flex: 1.3 1 0;
}


/*スマホ*/

@media (max-width: 769px) {
    section.support_sec .support_box .flex_box {
        flex-direction: column;
        margin-top: 2rem;
    }
    section.support_sec .support_box .gold_box .support_head.silver,
    section.support_sec .support_box .gold_box .support_head.bronze {
        justify-content: center;
        padding-right: 0;
    }
    section.support_sec .support_box .gold_box {
        margin: 0;
        background: #fff;
        max-width: 100%;
    }
}

@media (max-width: 480px) {
    section.support_sec .support_box .gold_box {
        margin: 0;
        background: #fff;
        max-width: 100%;
    }
    section.support_sec .support_box .gold_box .support_title {
        letter-spacing: 0;
        text-align: center;
        line-height: 110%;
    }
    section.support_sec .support_box .gold_box .support_head {
        justify-content: end;
        padding-right: 2.5rem;
    }
    section.support_sec .support_box .gold_box .support_body {
        flex-direction: column;
    }
    section.support_sec .support_box .flex_box {
        flex-direction: column;
    }
    section.support_sec .support_box .flex_box {
        margin-top: 1.8rem;
    }
    section.support_sec .support_box .gold_box .support_body .money img {
        width: 80%;
        margin: auto;
        margin-top: .6rem;
    }
    section.support_sec .support_box .gold_box .support_body .plus::before,
    section.support_sec .support_box .gold_box .support_body .plus::after {
        left: -11px;
    }
}


/*-----対象商品-----*/

section.item_sec {
    padding-bottom: clamp(3rem, 7.7vw, 6.25rem);
}

section.item_sec h2 {
    color: #222;
    text-align: center;
    font-size: clamp(1.8rem, 3.1vw, 2.1875rem);
    font-weight: 700;
    line-height: 150%;
}

.product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 28px;
    max-width: 1100px;
    margin: 0 auto;
}


/* ===== 見出し ===== */

.sec_title {
    text-align: center;
    font-size: 32px;
    font-weight: 700;
}

.sec_lead {
    margin-top: 16px;
    text-align: center;
    font-size: 15px;
}


/* ===== 商品リスト（Flex） ===== */

.product-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.44rem;
    list-style: none;
    padding: 0;
    margin-top: 2rem;
}


/* ===== カード ===== */

.product-card {
    width: calc(100% / 4 - 1.44rem);
    min-height: 13rem;
    border-radius: 1rem;
    border: 1px solid #00AD46;
    background: #FFF;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    justify-content: flex-end;
    padding-top: 1rem;
}


/* タイトル */

.product-card h3 {
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 110%;
    margin: auto 0;
}


/* グレー文字 */

.product-card .sub-text {
    color: #919191;
    font-size: 1rem;
    font-weight: 700;
    line-height: 120%;
}


/* 説明文 */

.product-card .desc {
    font-weight: 400;
    line-height: 130%;
    text-align: justify;
    padding: 0.5rem 1rem 0.5rem 1rem;
}


/* CTA */

.product-card .btn_sec {
    display: flex;
    width: 100%;
    border-top: 1px solid #00A651;
    padding: 0.5rem;
    justify-content: center;
    border-radius: 0 0 0.9rem 0.9rem;
}

.product-card .btn_sec:hover {
    background: #01A654;
    opacity: 1;
    transtion: 0.3;
}

.product-card .more {
    margin-top: auto;
    font-size: 1rem;
    font-weight: 700;
    color: #00A651;
    text-decoration: none;
}

.product-card .btn_sec:hover .more {
    color: #fff;
}


/* ===== SP ===== */

@media (max-width: 768px) {
    .product-card {
        width: calc(100% / 2 - 0.4rem);
        max-width: 100%;
    }
    .product-card .desc {
        font-size: 0.85rem;
        padding: 0.3rem 0.5rem 0.3rem 0.5rem;
    }
    .product-card h3 {
        font-size: 1.15rem;
        padding: 0 0.3rem;
    }
    .product-card .sub-text {
        font-size: 0.8rem;
    }
    .product-list {
        gap: 0.8rem;
        justify-content: space-between;
    }
}


/* ===== 商品リスト（Flex）2 ===== */

.product-list_2 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem 0;
    list-style: none;
    padding: 0;
    margin-top: 2rem;
}


/* ===== カード ===== */

.product-card_2 {
    width: calc(100% / 4 - 0.8rem);
    min-height: 13rem;
    border-right: 1px solid #00AD46;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    justify-content: flex-end;
    padding: clamp(0.6rem, 1.6vw, 1rem);
    gap: 0.625rem;
}

.product-card_2:nth-child(4),
.product-card_2:last-child {
    border-right: none;
}


/* タイトル */

.product-card_2 h3 {
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 110%;
    margin: auto 0;
}


/* グレー文字 */

.product-card_2 .sub-text {
    color: #919191;
    font-size: 1rem;
    font-weight: 700;
    line-height: 120%;
}


/* 説明文 */

.product-card_2 .desc {
    font-weight: 400;
    line-height: 130%;
    text-align: justify;
    padding: 0.5rem 0;
}


/*商品画像*/

.product-card_2 .item_img {
    padding: 0.5rem 2rem;
    background: #efeae4;
    width: 100%;
    text-align: center;
}

.product-card_2 .item_img img {
    height: clamp(3.2rem, 5.5vw, 5rem);
}


/* CTA */

.product-card_2 .btn_sec {
    display: flex;
    width: 100%;
    border: 1px solid #00A651;
    padding: 0.5rem;
    justify-content: center;
    border-radius: 0.7rem;
}

.product-card_2 .btn_sec:hover {
    background: #01A654;
    opacity: 1;
    transtion: 0.3;
}

.product-card_2 .more {
    margin-top: auto;
    font-size: 1rem;
    font-weight: 700;
    color: #00A651;
    text-decoration: none;
}

.product-card_2 .btn_sec:hover .more {
    color: #fff;
}


/* ===== SP ===== */

@media (max-width: 900px) {
    .product-list_2 {
        gap: 2rem 0rem;
        justify-content: flex-start;
        list-style: none;
    }
    .product-card_2 {
        width: calc(100% / 2 - 0.5rem);
    }
    .product-card_2:nth-child(even) {
        border-right: none;
    }
    .product-card_2 .item_img img {
        height: clamp(4rem, 8vw, 5.2rem);
        width: auto;
        margin: auto;
    }
}

@media (max-width: 480px) {
    .product-card_2 {
        width: 100%;
        max-width: 100%;
        border-right: none;
        padding: 0;
        padding-bottom: 1.5rem;
        border-bottom: 1px solid #00AD46;
    }
    .product-card_2 .desc {
        font-size: 0.85rem;
        padding: 0.3rem 0.5rem 0.3rem 0.5rem;
    }
    .product-card_2 h3 {
        font-size: 1.15rem;
        padding: 0 0.3rem;
    }
    .product-card_2 .sub-text {
        font-size: 0.8rem;
    }
    .product-list_2 {
        gap: 1.5rem;
        justify-content: space-between;
    }
    .product-card_2 .btn_sec {
        width: 80%;
    }
    .product-card_2 .item_img {
        width: 100%;
    }
    .product-card_2 .item_img img {
        margin: auto;
        height: 3.5rem;
    }
}


/*-----応募条件・対象となる方-----*/

section.info_sec {
    padding: 2.06rem 0;
    background: #EEEAE4;
}

section.info_sec h2 {
    color: #00AD46;
    text-align: center;
    font-size: clamp(1.5rem, 3.1vw, 2.1875rem);
    font-weight: 700;
    line-height: 150%;
}


/* =========================
   ベース
========================= */

section.info_sec .info_content {
    background: #fff;
    border-radius: 0.9375rem;
    padding: clamp(2rem, 4.5vw, 3.1875rem) clamp(1.8rem, 4vw, 3.125rem);
    text-align: center;
    margin-top: clamp(1.6rem, 3.4vw, 2.37rem);
    position: relative;
}

section.info_sec .info_list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: inline-flex;
    flex-direction: column;
}

section.info_sec .info_item {
    display: grid;
    grid-template-columns: 90px 1px 1fr;
    /* アイコン / 縦線 / テキスト */
    column-gap: 24px;
    align-items: stretch;
    /* ← 行の高さに揃える */
}


/* =========================
   行（アイコン＋本文）
========================= */

section.info_sec .info_item {
    display: inline-flex;
    gap: clamp(1rem, 4.2vw, 3.12rem) clamp(1rem, 2.3vw, 1.5rem);
    padding: 14px 0;
}

section.info_sec .info_icon {
    display: grid;
    border-right: 1px solid #000;
    padding-right: 1.5rem;
    align-items: center;
}

section.info_sec img {
    width: 3.4375rem;
    height: 3.8125rem;
    aspect-ratio: 55 / 61;
}

section.info_sec .info_body {
    flex: 1;
    min-width: 0;
}

section.info_sec .info_title {
    margin: 0 0 6px;
    font-weight: 700;
    font-size: clamp(1rem, 1.8vw, 1.25rem);
    line-height: 1.3;
    text-align: left;
}

section.info_sec .info_text {
    margin: 0;
    text-align: justify;
    line-height: 150%;
}

section.info_sec .info_text.last {
    margin-top: 2rem;
}


/* =========================
   画像
========================= */

section.info_sec .info_img img {
    width: clamp(18rem, 28vw, 26.75rem);
    height: clamp(17rem, 27vw, 25.8125rem);
    position: absolute;
    top: clamp(-3rem, -4.5vw, -1.2rem);
    right: clamp(-9rem, -12vw, -3.5rem);
}


/* =========================
   SP調整
========================= */

@media (max-width: 1100px) {
    section.info_sec .info_img img {
        display: none;
    }
}

@media (max-width: 480px) {
    .info-card {
        padding: 18px 16px 14px;
    }
    .info-icon {
        width: 40px;
        height: 40px;
        flex-basis: 40px;
    }
    section.info_sec .info_icon {
        border-right: none;
        padding-right: 0;
        justify-content: center;
    }
    .info-item--divider::after {
        left: 54px;
        /* 40 + 14 */
    }
    section.info_sec .info_item {
        flex-direction: column;
    }
    section.info_sec .info_img img {
        display: none;
    }
    section.info_sec .info_body {
        border-bottom: 1px solid #000;
        padding-bottom: 2rem;
    }
    section.info_sec .info_body.last,
    section.info_sec .info_item.last {
        border-bottom: 0;
        padding-bottom: 0;
    }
}


/*-----応募ボタン-----*/

section.cta_sec {
    background: url("./img/cta_bk.webp") top/cover no-repeat;
    padding: clamp(3rem, 6vw, 7.4375rem) 0;
}

section.cta_sec .cta_box {
    border-radius: clamp(0.8rem, 2.6vw, 1.875rem);
    text-align: center;
    background: #ffffffba;
    padding: clamp(1rem, 4vw, 3.81rem);
    box-shadow: 2px 4px 16px 0 rgba(0, 0, 0, 0.60);
}

section.cta_sec .cta_box strong {
    text-align: center;
    font-size: clamp(1rem, 2.2vw, 1.5625rem);
    font-weight: 700;
    line-height: 130%;
}

section.cta_sec .cta_box h2 {
    font-size: clamp(1.375rem, 2.8vw, 1.875rem);
    font-weight: 700;
    line-height: 150%;
    margin-bottom: clamp(0.75rem, 1.6vw, 1.31rem);
}

section.cta_sec .cta_box h2 span {
    color: #00AD46;
}

section.cta_sec .cta_box img {
    max-width: 46.20563rem;
    height: 5.18681rem;
    margin: auto;
}

section.cta_sec .cta_box .note {
    font-weight: 400;
    line-height: 130%;
    margin-top: clamp(0.75rem, 1.6vw, 1.31rem);
}

section.cta_sec .deadline {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    justify-content: center;
    margin-top: clamp(0.3rem, 1vw, 0.5rem);
}

section.cta_sec .deadline .label {
    color: #FFF;
    background: #000;
    text-align: center;
    font-size: clamp(1rem, 1.9vw, 1.30169rem);
    font-weight: 700;
    line-height: 100%;
    padding: 0.5rem;
    margin-top: 0.4rem;
}

section.cta_sec .deadline .time {
    color: #000;
    font-family: "Barlow Semi Condensed";
    font-size: clamp(2.2rem, 5.5vw, 3.75rem);
    font-weight: 700;
    line-height: 120 %;
}

section.cta_sec .deadline .time span {
    font-family: "Noto Sans JP";
    font-size: clamp(1rem, 1.9vw, 1.30169rem);
    font-weight: 700;
    line-height: 100%;
}


/*スマホ*/

@media (max-width: 480px) {
    section.cta_sec .cta_box h2 {
        line-height: 120%;
        padding: 0.4rem;
    }
    section.cta_sec .cta_box .note {
        font-size: 0.8rem;
    }
    section.cta_sec .cta_box img {
        max-width: 100%;
        height: auto;
        margin: auto;
    }
}


/*-----メッセージ-----*/

section.message_sec {}


/* MESSAGE */

section.message_sec .flex_box {
    display: flex;
    align-items: stretch;
    /* 左右の“箱”の高さは揃う（中身は別） */
    gap: 2.81rem;
}


/* 左：画像 */

section.message_sec .flex_box img {
    margin-left: calc(50% - 50vw);
    width: 50vw;
    height: auto;
    max-width: 100vw;
    object-fit: cover;
    object-position: center;
    display: block;
}


/* 右：テキスト */

section.message_sec .flex_box .message_text {
    flex: 1;
    /* 残り幅を全部使う */
    padding-top: 0;
    /* ←これがズレの元なので消す */
    display: flex;
    flex-direction: column;
    justify-content: center;
    /* 高さの中で自然に中央寄せ */
}


/* 文字のスタイル（そのまま） */

section.message_sec .flex_box .message_text h3 {
    text-align: center;
    font-family: "Noto Serif JP";
    font-size: clamp(1.4rem, 4vw, 2.5rem);
    font-weight: 500;
    line-height: 120%;
    margin-top: clamp(1rem, 4.5vw, 2rem);
    margin-bottom: clamp(0.7rem, 4.5vw, 2rem);
}

section.message_sec .flex_box .message_text .strong {
    font-weight: 700;
    line-height: 170%;
    background: #F0F0F0;
    padding: clamp(1.2rem, 2.8vw, 1.94rem) clamp(1rem, 2.3vw, 1.5rem);
    margin-bottom: 1.44rem;
}

section.message_sec .flex_box .message_text p.name {
    font-family: "Noto Serif JP";
    font-size: clamp(1.4rem, 2.6vw, 1.875rem);
    font-weight: 700;
    line-height: 150%;
    text-align: right;
    margin-top: 1.56rem;
}

section.message_sec .flex_box .message_text p.name span {
    font-size: clamp(0.9rem, 1.4vw, 1rem);
    font-style: normal;
    font-weight: 600;
    padding-right: 1.5rem;
}


/* =========================
   レスポンシブ：狭くなったら縦積み
   ========================= */

@media (max-width: 1024px) {
    section.message_sec .flex_box {
        flex-direction: column;
        gap: 1.5rem;
    }
    section.message_sec .flex_box img {
        margin-left: calc(50% - 50vw);
        width: 100vw;
        z max-width: 100vw;
        height: clamp(320px, 45vw, 520px);
        object-fit: cover;
        object-position: center -55px;
    }
    /* section.message_sec .flex_box img {
        margin-left: calc(50% - 50vw);
        width: 100vw;
        max-width: 100vw;
        height: clamp(240px, 45vw, 520px);
        object-fit: cover;
        object-position: center;
    }*/
    section.message_sec .flex_box .message_text {
        justify-content: flex-start;
        padding-top: 2rem;
    }
}

@media (max-width: 1024px) {
    section.message_sec {
        padding: 3rem 0;
    }
    section.cta_sec .cta_box h2 {
        line-height: 120%;
        padding: 0.4rem;
    }
    section.cta_sec .cta_box .note {
        font-size: 0.8rem;
    }
    section.message_sec .flex_box img {
        margin-left: auto;
        margin: auto;
        width: 60%;
        max-width: 100%;
        height: clamp(320px, 45vw, 520px);
        object-fit: cover;
        object-position: center -4rem;
        margin-top: 1.5rem;
    }
    section.message_sec .flex_box .message_text {
        padding-top: 0;
    }
}

@media (max-width: 480px) {
    section.message_sec .flex_box img {
        margin-left: auto;
        margin: auto;
        width: 80%;
        max-width: 100%;
        height: clamp(300px, 45vw, 520px);
        object-fit: cover;
        object-position: center -4rem;
        margin-top: 1.5rem;
    }
}


/*-----後援・協力団体------*/

section.official_support_sec {
    background: #00AD46;
    padding: 2.5rem 0;
}

section.official_support_sec .official_support_box {
    padding: clamp(2rem, 4.8vw, 3.75rem) clamp(1.8rem, 4.2vw, 3.5rem);
    border-radius: 0.9375rem;
    background: #FFF;
}

section.official_support_sec .official_support_box .flex_box {
    display: flex;
    gap: clamp(1.8rem, 3.8vw, 2.88rem);
    margin-top: 2rem;
    align-items: center;
}

section.official_support_sec .official_support_box .flex_box>img,
section.official_support_sec .official_support_box .flex_box .text {
    flex: 1 1 0;
    min-width: 0;
}


/* 画像は枠に合わせてトリミング */

section.official_support_sec .official_support_box .flex_box>img {
    width: 100%;
    height: auto;
    /* 高さ固定したいなら下のheightに変更 */
    display: block;
    object-fit: cover;
    border-radius: 1.6875rem;
}

section.official_support_sec .official_support_box .flex_box h3 {
    font-size: clamp(1.25rem, 2.1vw, 1.875rem);
    font-weight: 700;
    line-height: 110%;
    margin-bottom: clamp(0.6rem, 1.6vw, 1rem);
}

section.official_support_sec .official_support_box .flex_box h3 span {
    color: #919191;
    text-align: justify;
    font-family: "Noto Sans JP";
    font-size: 1rem;
}

section.official_support_sec .official_support_box .flex_box>img {
    border-radius: 1.6875rem;
}

section.official_support_sec .official_support_box .flex_box p {
    margin-bottom: 1rem;
}

section.official_support_sec .official_support_box .flex_box p span {
    color: #6B6969;
    font-family: "Noto Sans JP";
    font-size: 0.9375rem;
    font-style: normal;
    font-weight: 400;
}

section.official_support_sec .official_support_box .flex_box p span a {
    color: #00AD46;
    font-size: 0.9375rem;
    text-decoration: underline;
}

section.official_support_sec .official_support_box .flex_box a.btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.81rem 4rem 0.81rem 3.5rem;
    border-radius: 0.5rem;
    background: #00AD46;
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    text-decoration: none;
    border: 1px solid #00AD46;
    transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}


/* 〉を疑似要素で */

section.official_support_sec .official_support_box .flex_box a.btn::after {
    content: "〉";
    position: absolute;
    right: 0.5rem;
    font-size: 1rem;
    font-weight: 700;
    color: currentColor;
    transition: transform 0.25s ease, color 0.25s ease;
}


/* hover */

section.official_support_sec .official_support_box .flex_box a.btn:hover {
    background: #fff;
    color: #00AD46;
    border-color: #00AD46;
    opacity: 1;
}

section.official_support_sec .official_support_box .flex_box a.btn:hover::after {
    transform: translateX(4px);
}


/*スマホ*/

@media (max-width: 480px) {
    section.official_support_sec .official_support_box .flex_box {
        display: flex;
        flex-direction: column;
    }
    section.official_support_sec .official_support_box .flex_box a.btn {
        display: flex;
    }
}


/*---- 過去の受賞者 ----*/

section.past_sec {
    padding: clamp(3rem, 7.7vw, 6.25rem) 0;
}

section.past_sec strong {
    text-align: center;
    font-size: clamp(1.1rem, 2.2vw, 1.5625rem);
    font-weight: 700;
    line-height: 120%;
    display: block;
    margin-top: 1.56rem;
}

section.past_sec h3 {
    color: #C18C37;
    text-align: center;
    font-size: clamp(1.2rem, 2.6vw, 1.875rem);
    font-weight: 500;
    line-height: 120%;
    margin-top: clamp(1.4rem, 3.2vw, 2.12rem);
    margin-bottom: clamp(1.2rem, 2.8vw, 1.82rem);
}

section.past_sec .name {
    color: #919191;
    text-align: center;
    font-size: clamp(1rem, 1.8vw, 1.25rem);
    font-weight: 400;
    line-height: 150%;
}

section.past_sec .name strong {
    color: #222;
    font-size: clamp(1.2rem, 2.6vw, 1.875rem);
    font-weight: 700;
    line-height: 100%;
    text-align: center;
    display: block;
}

section.past_sec .name strong span {
    font-size: clamp(0.9rem, 1.6vw, 1.125rem);
}

section.past_sec .message_sec {
    padding: clamp(1.6rem, 3.8vw, 2.5rem) clamp(1.6rem, 3.8vw, 2.5rem) clamp(1rem, 2.6vw, 1.5rem) clamp(1.6rem, 3.8vw, 2.5rem);
    justify-content: center;
    align-items: center;
    gap: 2.5rem;
    background: #EEEAE4;
    margin-top: clamp(2.2rem, 4.8vw, 3.44rem);
}

section.past_sec .message_sec h4 {
    color: #00AD46;
    text-align: center;
    font-family: "Barlow Semi Condensed";
    font-size: clamp(1.8rem, 4vw, 2.5rem);
    font-weight: 700;
    line-height: 150%;
    text-transform: uppercase;
    margin-top: clamp(-4.5rem, -6vw, -2.8rem);
}


/*-----審査員・面接者の紹介------*/

section.judges_sec {
    padding-bottom: clamp(3rem, 7.7vw, 6.25rem);
}

section.judges_sec .judges_box {
    background: #EEEAE4;
    padding: 3.75rem 0;
    margin-top: 2.75rem;
    margin-bottom: 2.5rem;
}

section.judges_sec h3 {
    color: #222;
    text-align: center;
    font-size: clamp(1.8rem, 3.5vw, 2.5rem);
    font-weight: 700;
    line-height: 150%;
    margin-bottom: clamp(1.6rem, 3.8vw, 2.5rem);
}

section.judges_sec p.label {
    text-align: center;
    font-size: clamp(1.1rem, 1.75vw, 1.5625rem);
    font-weight: 700;
    line-height: 130%;
}

section.judges_sec .judges_box .flex_box {
    display: flex;
    justify-content: center;
    gap: clamp(3rem, 6vw, 5rem);
}

section.judges_sec .judges_box .flex_box div>img {
    width: clamp(12rem, 22vw, 20rem);
    height: clamp(12rem, 22vw, 20rem);
    margin: auto;
}

section.judges_sec .judges_box .flex_box p.text {
    margin-top: 1.13rem;
    margin-bottom: 1.06rem;
    text-align: center;
    font-size: clamp(1.05rem, 2vw, 1.4375rem);
    font-weight: 700;
    line-height: 130%;
}

section.judges_sec .judges_box .flex_box p.text span {
    color: #919191;
    font-size: clamp(1rem, 2.8vw, 1.25rem);
}

section.judges_sec .judges_box .flex_box div>h4 {
    text-align: center;
    font-size: clamp(1.5rem, 2.6vw, 1.875rem);
    font-weight: 700;
    line-height: 130%;
}

section.judges_sec .judges_box .flex_box div>h4 span {
    font-size: clamp(1.1rem, 2.2vw, 1.5625rem);
}

section.judges_sec .judges_box .flex_box div>h4 strong {
    font-size: clamp(1.05rem, 2vw, 1.4375rem);
}

section.judges_sec .interviewers_box h4 span {
    font-size: clamp(1.1rem, 2.2vw, 1.5625rem);
}

section.judges_sec .interviewers_box h4 strong {
    font-size: clamp(1.05rem, 2vw, 1.4375rem);
}

section.judges_sec .interviewers_box {
    background: #EEEAE4;
    padding: clamp(1.5rem, 4.8vw, 3.75rem);
    margin-top: clamp(1.8rem, 4vw, 2.75rem);
    display: flex;
    gap: clamp(2rem, 4.2vw, 3.12rem);
    margin-bottom: clamp(1.6rem, 3.8vw, 2.5rem);
}

section.judges_sec .interviewers_box.reverse {
    flex-direction: row-reverse;
}

section.judges_sec .interviewers_box img {
    width: clamp(12rem, 22vw, 20rem);
    height: clamp(12rem, 22vw, 20rem);
}

section.judges_sec .interviewers_box .text {
    width: calc(100% - 20rem -1.57rem);
    min-width: 0;
}

section.judges_sec .interviewers_box .text h4 {
    font-size: clamp(1.1rem, 2.2vw, 1.5625rem);
    font-weight: 700;
    line-height: 130%;
    font-size: clamp(1.5rem, 2.6vw, 1.875rem);
}

section.judges_sec .interviewers_box .text h4 span.label {
    padding-right: 1rem;
}

section.judges_sec .interviewers_box .text h4 span {
    font-size: clamp(1rem, 1.8vw, 1.25rem);
}

section.judges_sec .interviewers_box .text p {
    margin-top: 1.5rem;
}


/*スマホ*/

@media (max-width: 480px) {
    section.judges_sec p.label {
        text-align: left;
    }
    section.judges_sec .judges_box .flex_box {
        flex-direction: column;
        align-items: center;
    }
    section.judges_sec .interviewers_box,
    section.judges_sec .interviewers_box.reverse {
        flex-direction: column;
    }
    section.judges_sec .interviewers_box img {
        margin: auto;
    }
}


/*---- スケジュール -----*/

section.schedule_sec {
    padding-bottom: clamp(3rem, 7.7vw, 6.25rem);
    text-align: center;
}

section.schedule_sec .schedule_box {
    display: inline-flex;
    flex-direction: column;
    gap: 2.5rem;
    margin-top: 2.5rem;
    position: relative;
}

section.schedule_sec .schedule_box::before {
    content: "";
    position: absolute;
    top: 5%;
    left: clamp(3.6rem, 6.7vw, 5.8rem);
    width: 3px;
    height: 90%;
    background: repeating-linear-gradient(to bottom, #00AD46 0px, #00AD46 6px, transparent 6px, transparent 14px);
    z-index: -1;
}

section.schedule_sec .schedule_box .flex_box {
    display: inline-flex;
    gap: clamp(1.6rem, 3.6vw, 2.44rem);
    align-items: center;
}

section.schedule_sec .schedule_box .flex_box .line {}

section.schedule_sec .schedule_box .flex_box img {
    width: clamp(7.5rem, 14vw, 11.625rem);
    height: clamp(7.5rem, 14vw, 11.625rem);
}

section.schedule_sec .schedule_box .flex_box .text {
    text-align: justify;
}

section.schedule_sec .schedule_box .flex_box .text .time {
    color: #00AD46;
    font-weight: 400;
    line-height: 150%;
    display: inline-flex;
    align-items: center;
    padding: 0.3125rem 0.9375rem;
    justify-content: center;
    border: 2px solid #00AD46;
}

section.schedule_sec .schedule_box .flex_box .text h3 {
    color: #222;
    font-family: "Noto Sans JP";
    font-size: clamp(1.35rem, 2.3vw, 1.875rem);
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
    margin: 0.56rem 0 0.31rem 0;
}

section.schedule_sec .schedule_box .flex_box .text p span {
    color: #6B6969;
}

@media (max-width: 480px) {
    section.schedule_sec .schedule_box .flex_box {
        flex-direction: column;
        background: #fff;
    }
    section.schedule_sec .schedule_box .flex_box .text {
        text-align: center;
    }
    section.schedule_sec .schedule_box .flex_box .text p {
        text-align: justify;
    }
    section.schedule_sec .schedule_box::before {
        display: none;
    }
}


/*---- 応募方法 -----*/

section.howto_sec {
    background: #00AD46;
    padding: 2.5rem 0;
}

section.howto_sec h2 {
    color: #fff;
}

section.howto_sec .howto_box {
    border-radius: 0.9375rem;
    background: #FFF;
    text-align: center;
    padding: clamp(1.6rem, 3.8vw, 2.5rem);
    margin-top: clamp(1.6rem, 3.8vw, 2.5rem);
}

section.howto_sec .howto_box .howto_content {
    display: inline-flex;
    flex-direction: column;
    margin-bottom: 1.8rem;
}

section.howto_sec .howto_box .flex_box {
    display: inline-flex;
    margin-top: clamp(1.6rem, 3.8vw, 2.5rem);
    gap: clamp(1.5rem, 4vw, 2.9rem) clamp(0.7rem, 1.6vw, 1rem);
}

section.howto_sec .howto_box .flex_box .step_no {
    color: #00AD46;
    text-align: center;
    font-family: "Barlow Semi Condensed";
    font-size: clamp(2.8rem, 6.5vw, 5rem);
    font-weight: 600;
    line-height: 100%;
    text-transform: uppercase;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-right: 1rem;
    border-right: 1px solid #00AD46;
    width: 6rem;
}

section.howto_sec .note {
    font-size: clamp(0.9rem, 1.4vw, 1rem);
}

section.howto_sec .howto_box .flex_box .step_no span {
    font-size: clamp(1.2rem, 2.6vw, 1.875rem);
    line-height: 10%;
}

section.howto_sec .howto_box .flex_box .text {
    text-align: justify;
    width: calc(100% - 6rem);
}

section.howto_sec .howto_box .flex_box .text.last {
    border-bottom: none;
    padding-bottom: 0;
}

section.howto_sec .howto_box .flex_box .text h3 {
    font-size: clamp(1.25rem, 2.2vw, 1.5625rem);
    font-weight: 700;
    line-height: 150%;
}

section.howto_sec .howto_box a {
    color: #00AD46;
    text-decoration: underline;
}

section.howto_sec .howto_box .note span {
    font-weight: 700;
}

@media (max-width: 480px) {
    section.howto_sec .howto_box p {
        text-align: justify;
    }
    section.howto_sec .howto_box .flex_box {
        flex-direction: column;
        gap: 0;
    }
    section.howto_sec .howto_box .flex_box .step_no {
        text-align: left;
        padding-right: 0;
        border-right: none;
    }
    section.howto_sec .howto_box .flex_box .text {
        text-align: justify;
        border-bottom: 1px solid #00ad46;
        padding-bottom: 1rem;
        width: 100%;
    }
}


/*---- 応援コメント -----*/

section.comment_sec {
    padding: clamp(3rem, 7.7vw, 6.25rem) 0;
}

section.comment_sec h3 {
    text-align: center;
    font-size: clamp(1.5rem, 4vw, 2.1875rem);
    font-weight: 700;
    line-height: 130%;
    margin: 2.5rem 0;
}

section.comment_sec h3 span {
    color: #00AD46;
}

section.comment_sec .comment_box {
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

section.comment_sec .comment_box .flex_box {
    display: flex;
    gap: clamp(1rem, 4vw, 2rem);
}

section.comment_sec .comment_box .flex_box.reverse {
    flex-direction: row-reverse;
}

section.comment_sec .comment_box .flex_box.last {
    margin-bottom: 5.19rem;
}

section.comment_sec .comment_box .flex_box>img {
    width: clamp(12rem, 22vw, 17.9375rem);
    height: clamp(14.5rem, 26vw, 21.625rem);
    border-radius: clamp(0.6rem, 1.6vw, 0.9375rem);
}

section.comment_sec .comment_box .flex_box .text {
    display: flex;
    flex-direction: column;
    width: 100%;
}

section.comment_sec .comment_box .flex_box .text .name_sec {
    display: flex;
    gap: 0.5rem;
    align-items: end;
}

section.comment_sec .comment_box .flex_box .text .sns_sec {
    display: flex;
    gap: 1.5rem;
}

section.comment_sec .comment_box .flex_box .text h4 {
    font-size: clamp(1.2rem, 2.6vw, 1.875rem);
    font-weight: 700;
}

section.comment_sec .comment_box .flex_box .text h4 span {
    font-size: clamp(1rem, 1.8vw, 1.25rem);
    color: #919191;
    font-weight: 400;
    line-height: 150%;
    padding-left: 1rem;
}

section.comment_sec .comment_box .flex_box .text .name_sec a img {
    width: clamp(1.6rem, 3.2vw, 2.47031rem);
    flex-shrink: 0;
}

section.comment_sec .comment_box .flex_box .text ul {
    margin-bottom: clamp(2.8rem, 5.8vw, 4.38rem);
    margin-top: 0.88rem;
    display: flex;
    flex-direction: column;
}

section.comment_sec .comment_box .flex_box .text ul li {
    color: #919191;
    font-size: clamp(1rem, 1.8vw, 1.25rem);
    font-weight: 400;
    line-height: 150%;
}

section.comment_sec .comment_box .flex_box .text ul li>ul {
    margin: 0;
    padding-left: 1rem;
}

section.comment_sec .comment_box .flex_box .text .message_sec {
    border-radius: 0.9375rem;
    background: #EEEAE4;
    padding: clamp(1.4rem, 3.2vw, 2.12rem) 1rem clamp(1rem, 2.4vw, 1.5rem) 1rem;
}

section.comment_sec .comment_box .flex_box .text .message_sec h5 {
    color: #00AD46;
    font-family: "Barlow Semi Condensed";
    font-size: clamp(1.8rem, 4vw, 2.5rem);
    font-weight: 700;
    line-height: 150%;
    text-transform: uppercase;
    margin-top: clamp(-4rem, -6vw, -2.8rem);
}


/*スマホ*/

@media (max-width: 1024px) {
    section.comment_sec .comment_box .flex_box>img {
        margin: 0;
    }
}

@media (max-width: 480px) {
    section.comment_sec .comment_box .flex_box,
    section.comment_sec .comment_box .flex_box.reverse {
        flex-direction: column;
    }
    section.comment_sec .comment_box .flex_box .text {
        width: auto;
    }
    section.comment_sec .comment_box .flex_box .text h4 {
        text-align: center;
    }
    section.comment_sec .comment_box .flex_box .text h4 span {
        display: block;
        padding-left: 0;
    }
    section.comment_sec .comment_box .flex_box>img {
        margin: auto;
    }
    section.comment_sec .comment_box .flex_box .text .name_sec {
        flex-direction: column;
        align-items: center;
    }
}


/*よくある質問*/

section.faq_sec {
    padding-bottom: clamp(3rem, 7.7vw, 6.25rem);
}

.faq_list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 2rem;
}

.faq_item {
    border-radius: 0.9375rem;
    background: #F5F5F5;
    overflow: hidden;
    transition: background-color .3s ease, box-shadow .3s ease;
}


/* summaryの標準マーカー消す */

.faq_item>summary {
    list-style: none;
}

.faq_item>summary::-webkit-details-marker {
    display: none;
}

.faq_q {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: 1.1rem 1.2rem;
    cursor: pointer;
    user-select: none;
    color: #00AD46;
    font-weight: 700;
}

.faq_qMark {
    color: #00AD46;
    font-family: Montserrat;
    font-size: 1.875rem;
    font-weight: 500;
    line-height: 100%;
    flex: 0 0 auto;
}

.faq_qText {
    flex: 1 1 auto;
    color: #00AD46;
    font-size: 1rem;
    font-weight: 700;
    line-height: 150%;
}

.faq_icon {
    flex: 0 0 auto;
    width: 8px;
    height: 8px;
    margin-right: 0.5rem;
    border-right: 2px solid #00AD46;
    border-bottom: 2px solid #00AD46;
    transform: rotate(45deg);
    transition: transform .35s cubic-bezier(.4, 0, .2, 1);
}


/* 開いたら矢印を上向きに */

.faq_item[open] .faq_icon {
    transform: rotate(-135deg);
}

.faq_a {
    display: flex;
    gap: .75rem;
    margin: 0 1.2rem;
    /* ← 下余白を消す */
    padding-top: 0;
    /* ← 閉じてる時は0 */
    border-top: 0;
    /* ← 閉じてる時は0 */
    max-height: 0;
    opacity: 0;
    transform: translateY(-6px);
    overflow: hidden;
    transition: max-height .45s cubic-bezier(.2, .8, .2, 1), opacity .25s ease, transform .35s ease, padding-top .35s ease, margin-bottom .35s ease;
}

.faq_item[open] .faq_a {
    max-height: 600px;
    opacity: 1;
    transform: translateY(0);
    padding-top: 1.25rem;
    margin-bottom: 1.2rem;
    /* ← 開いた時にだけ下余白 */
    border-top: 1px solid #222;
}

.faq_aMark {
    color: #AC1414;
    font-family: Montserrat;
    font-size: 1.875rem;
    font-weight: 500;
    line-height: 100%;
}

.faq_aBody {
    line-height: 1.9;
    font-size: 0.95rem;
}


/* JSで閉じる時に付与するクラス（閉じアニメ用） */

.faq_item.is-closing .faq_a {
    max-height: 0 !important;
    opacity: 0 !important;
    transform: translateY(-6px) !important;
    padding-top: 0 !important;
    margin-bottom: 0 !important;
    border-top: 0 !important;
}


/*----SNS----*/

section.sns_sec {
    background: url("./img/sns_bk.webp") top/cover no-repeat;
    padding: clamp(3rem, 7.7vw, 6.25rem) 0;
    text-align: center;
}

section.sns_sec h2 {
    color: #FFF;
    text-align: center;
    font-size: clamp(1.3rem, 2.6vw, 1.875rem);
    font-weight: 700;
    line-height: 115%;
    letter-spacing: normal;
}

section.sns_sec .flex_box {
    display: flex;
    gap: clamp(1rem, 3vw, 3.06rem);
    justify-content: center;
    margin-top: 2.25rem;
    margin-bottom: 1.94rem;
}

section.sns_sec .flex_box img {
    filter: drop-shadow(0 4px 14px rgba(0, 0, 0, 0.35));
    width: clamp(3.5rem, 12vw, 7.375rem);
    height: clamp(3.5rem, 12vw, 7.375rem);
}

.shop-link {
    display: inline-flex;
    align-items: center;
    gap: clamp(0.6rem, 1.5vw, 1rem);
    padding: 1.3rem 3.12rem;
    background: #FFF;
    box-shadow: 0 4px 14px 0 rgba(0, 0, 0, 0.35);
    color: #000;
    text-decoration: none;
    font-weight: 600;
}


/* ロゴ */

.shop-link img {
    width: clamp(10rem, 30vw, 14.24625rem);
    height: clamp(2rem, 6vw, 2.30831rem);
}


/* テキスト */

.shop-link .text {
    font-size: clamp(1.1rem, 2.6vw, 1.85356rem);
    font-weight: 700;
    line-height: 130%;
}


/* 右の三角 */

.shop-link .triangle {
    width: 0;
    height: 0;
    border-top: 9px solid transparent;
    border-bottom: 9px solid transparent;
    border-left: 15px solid #000;
    margin-left: 1.8rem;
    margin-top: 0.2rem;
}


/*スマホ*/

@media (max-width: 1024px) {
    .shop-link .text {
        letter-spacing: -1px;
        padding-left: 0.2rem;
    }
    .shop-link .triangle {
        border-top: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-left: 12px solid #000;
        margin-left: 0.5rem;
        margin-top: 0.1rem;
    }
    .shop-link {
        padding: 1.3rem 1rem;
        gap: 0;
    }
    .shop-link img {
        width: 32%;
        height: auto;
    }
}


/*-----応募ボタン-----*/

section.cta_sec_sp {
    position: fixed;
    z-index: 999;
    bottom: 0.5rem;
    opacity: 0;
    transform: translateY(16px);
    pointer-events: none;
    transition: opacity .35s ease, transform .35s ease;
}


/* 表示状態 */

section.cta_sec_sp.is-show {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

section.cta_sec_sp .wrap {
    padding: 0 0.5rem;
}

section.cta_sec_sp .cta_box {
    border-radius: 0.8rem;
    text-align: center;
    background: #ffffffba;
    padding: 0.5rem;
    box-shadow: 2px 4px 16px 0 rgba(0, 0, 0, 0.80);
}

section.cta_sec_sp .cta_box .note {
    font-weight: 400;
    line-height: 130%;
    margin-top: clamp(0.75rem, 1.6vw, 1.31rem);
}

section.cta_sec_sp .deadline {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    justify-content: center;
    margin-top: -0.4rem;
}

section.cta_sec_sp .deadline .label {
    color: #FFF;
    background: #000;
    text-align: center;
    font-size: clamp(1rem, 1.9vw, 1.30169rem);
    font-weight: 700;
    line-height: 100%;
    padding: 0.5rem;
    margin-top: 0.4rem;
}

section.cta_sec_sp .deadline .time {
    color: #000;
    font-family: "Barlow Semi Condensed";
    font-size: clamp(2.2rem, 5.5vw, 3.75rem);
    font-weight: 700;
    line-height: 120 %;
}

section.cta_sec_sp .deadline .time span {
    font-family: "Noto Sans JP";
    font-size: clamp(1rem, 1.9vw, 1.30169rem);
    font-weight: 700;
    line-height: 100%;
}

@media (min-width: 769px) {
    section.cta_sec_sp {
        display: none;
    }
}
