@charset 'UTF-8';

.brandSiteHeader {
    background-color: #fff;
}

.fLink {
    transition: all 1s ease-out;
}

.fLink:hover {
    opacity: 0.5;
}

.contents03 a {
    text-decoration: underline;
}

@media screen and (max-width: 767px) {

    .sp_none {
        display: none;
    }

    .max-area-cp {
        width: 100%;
        margin: 0 auto;
    }

    .max-area-cp:before {
        content: "";
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100vh;
        background-image: radial-gradient(#fff3c2 69%, #ffe791 70%);
        background-size: 24px 24px;
    }

    .bg-area-cp {
        margin: 0 auto;
        width: 100%;
    }

    .bg-area-cp:before {
        content: "";
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100vh;
        background-image: url("../images/bg-kuri_sp.webp");
        background-size: contain;
        background-repeat: repeat;
        background-position: top center;
    }

    .main-area {
        margin: 0 0 0;
    }

    .contents {
        width: 100%;
    }

    .bg-area-01 {
        width: 100%;
        margin: 0 auto;
        background-image: url("../images/bg-01.webp");
        background-repeat: repeat;
    }

    .main {
        width: 96%;
        margin: 0 auto 0;
        padding: 2vh 0 40px;
    }

    .main-bnr {
        width: 90%;
        margin: 20px auto 40px;
        filter: drop-shadow(3px 6px 3px rgba(0, 0, 0, 0.2));
    }

    #campaign {
        margin: 0 0 10vh;
    }

    .campaign-main-border {
        height: 10px;
        background-color: #df2014;
    }

    .campaign-main {
        width: 100%;
        margin: 0 auto 0;
    }

    .campaign-term {
        width: 100%;
        padding: 20px 30px 15px;
        background-color: #df2014;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
    }

    .term-title {
        margin: 0 30% 5px;
        padding: 5px 20px;
        background-color: #ffffff;
        border-radius: 8px;
        font-size: 1.25rem;
        font-weight: 700;
    }

    .term-day {
        font-size: 1rem;
        font-weight: 700;
        color: #ffffff;
    }

    .term-day span {
        font-size: 1.5rem;
    }

    .bg-area-02 {
        width: 100%;
        margin: 0 auto;
        background-color: #6a3419;
    }

    .contents02 {
        width: 100%;
        padding: 2.5vw;
        background-color: #fffab8;
    }

    .contents-area {
        width: 90%;
        margin: 0 auto;
        padding: 2rem 0 2rem;
    }

    .campaign-title-con {
        width: 100%;
        margin: 0 auto 1rem;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .title-border {
        flex-grow: 2;
        max-height: 10px;
        background-image: url(../images/title-border.png);
        background-size: 10px;
        background-repeat: round;
    }

    .campaign-title {
        padding: 0 5%;
        font-family: "Noto Sans JP";
        font-weight: 700;
        font-size: 1.5rem;
        color: #ffffff;
    }

    .brown .title-border {
        background-image: url(../images/title-border-brown.png);
    }

    .brown .campaign-title {
        color: #6a3419;
    }

    .contents02-center {
        padding: 0 5vw 0;
        display: flex;
        flex-direction: column;
        background-image: url(../images/contents02-bg-center.png);
        background-size: 100%;
        background-position: bottom;
        background-repeat: repeat;
    }

    .contents02-center-L {
        width: 100%;
    }

    .contents02-text01 {
        font-size: 1.125rem;
        text-align: center;
    }

    .contents02-text02 {
        margin: 2rem 0;
        font-size: 1rem;
    }

    .contents02-btn {
        width: 100%;
    }

    .contents02-btn a {
        height: 60px;
        display: flex;
        justify-content: center;
        align-items: center;
        background: #00acee;
        border-radius: 36px;
        color: #fff;
        font-size: 1.25rem;
        font-weight: 600;
        text-decoration: none;
        transition: 0.5s;
    }

    /*.contents02-btn span::before {
        content: "";
        display: inline-block;
        width: 30px;
        height: 30px;
        margin-right: 10px;
        background-image: url(../images/tw-logo.svg);
        background-size: contain;
        background-repeat: no-repeat;
        vertical-align: middle;
    }*/

    .contents02-btn a:hover {
        opacity: 0.8;
    }

    .contents02-copy01 {
        margin: 1.5rem 0;
        padding: 1rem 0;
        border-top: 3px solid #8ec21f;
        border-bottom: 3px solid #8ec21f;
        text-align: center;
        font-size: 1.25rem;
        font-weight: 900;
        color: #00903a;
    }

    .contents02-copy01 span {
        font-size: 1rem;
        color: #000;
    }

    .contents02-copy02 {
        margin: 1.5rem 0 0;
        padding: 0 0;
        text-align: center;
        font-size: 1.25rem;
        font-weight: 700;
        color: #6a3419;
    }

    .contents02-center-R {
        width: 100%;
    }

    .tweet-box {
        width: 100%;
        margin-top: 1rem;
    }

    .uc {
        width: 100%;
        padding: 4rem 2rem;
        text-align: center;
        font-size: 1.25rem;
        background-color: #fff;
        border-radius: 12px;
        border: 1px solid #ccc;
    }

    .post-img {
        width: 100%;
        border: 1px solid #ccc;
    }

    .post-img img {
        width: 100%;
    }

    .bg-area-03 {
        width: 100%;
        margin: 0 auto;
        background-color: #ffffe4;
    }

    .contents03 {
        margin: 0 0 0;
        border: 2px solid #6a3419;
        background: #fff;
    }

    .contents03-inner {
        height: 50vh;
        margin: 15px 10px 15px;
        overflow-y: scroll;
        background: #fff;
    }

    .contents03-inner::-webkit-scrollbar {
        width: 20px;
    }

    .contents03-inner::-webkit-scrollbar-track {
        background: #fff;
        border-radius: 10px;
    }

    .contents03-inner::-webkit-scrollbar-thumb {
        background: #986d58;
        border-radius: 10px;
    }

    .contents03-part-tit {
        margin: 20px 10px 10px;
        padding: 0 0 0.25em;
        border-bottom: 1px solid #000;
    }

    .contents03-part {
        margin-bottom: 1em;
        padding: 0 10px 0;
    }

    .contents03-part2 {
        margin-bottom: 1em;
        padding: 20px 10px 0;
    }

    .contents03-tit {
        margin: 1em 0 0;
        font-size: 1.1em;
    }

    .contents03-tit2 {
        margin: 1em 0 0;
        font-size: 1em;
        text-indent: -1em;
        padding-left: 1em;
    }

    .contents03-text {
        font-size: 0.9em;
    }

    .contents03-text2 {
        font-size: 0.9em;
        text-indent: -1em;
        padding-left: 1em;
    }

    .contents03-text3 {
        font-size: 0.9em;
        text-indent: -1em;
        padding-left: 2em;
    }

    #package {
        margin: 5vh 0 0;
    }

    #package .bg-area-01 {
        padding: 0 0 10px;
    }

    .white-area {
        width: 100%;
        margin: 0 auto 0;
        background-color: #ffffff;
    }

    .story-main-top,
    .story-main-bottom {
        width: 100%;
        margin: 0 auto 0;
    }

    .story-main-top img,
    .story-main-bottom img {
        width: 100%;
    }

    .story-tit-area {
        width: 90%;
        margin: 15px auto 5px;
    }

    .story-tit {
        margin: 0 auto 0;
        padding: 10px 20px;
        background-color: #000000;
        border-radius: 32px;
        color: #ffffff;
        font-size: 1.125rem;
        font-weight: 600;
        text-align: center;
    }

    .story-arrow {
        font-family: "Noto Sans JP";
        font-weight: 700;
        font-size: 1.75rem;
        text-align: center;
    }


    .story-slider {
        width: 94%;
        margin: 0 auto 0;
        padding: 0 3%;
    }

    .story-pic {
        width: 100%;
    }

    .story-pic img {
        width: 100%;
    }


    /* Arrows上書き */
    .slick-prev,
    .slick-next {
        top: calc(50% - 18px) !important;
        width: 36px !important;
        height: 36px !important;
    }

    .slick-prev:before,
    .slick-next:before {
        font-size: 36px !important;
    }

    .slick-prev {
        left: -3% !important;
    }

    [dir='rtl'] .slick-prev {
        right: -3% !important;
    }

    .slick-next {
        right: -3% !important;
    }

    [dir='rtl'] .slick-next {
        left: -3% !important;
    }


    button {
        margin: 0;
        padding: 0;
        background: none;
        border: none;
        border-radius: 0;
        outline: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
    }

    .slide-dots2 {
        width: 100%;
        max-width: 310px;
        margin: 8px auto 0;
        padding-right: 0.375rem;
        text-align: center;
    }

    .slide-dots2 li {
        display: inline-block;
        margin: 0 0.75rem;
    }

    .slide-dots2 li button {
        position: relative;
        text-indent: -9999px;
        cursor: pointer;
    }

    .slide-dots2 li button:before {
        content: "●";
        font-size: 10px;
        text-indent: 0;
        position: absolute;
        color: #ff6666;
        top: 0;
        left: 0;
    }

    .slide-dots2 li.slick-active button:before {
        font-size: 14px;
        text-indent: 0;
        content: "●";
        color: #ed1c24;
        top: -4px;
        left: -2px;
    }

    .bottom-bnr {
        width: 90%;
        margin: 40px auto 40px;
        filter: drop-shadow(3px 6px 3px rgba(0, 0, 0, 0.2));
    }

}


@media print,
screen and (min-width: 768px) {

    .pc_none {
        display: none;
    }

    .max-area-cp {
        width: 100%;
        margin: 0 auto;
    }

    .max-area-cp:before {
        content: "";
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100vh;
        background-image: radial-gradient(#fff3c2 69%, #ffe791 70%);
        background-size: 24px 24px;
    }

    .bg-area-cp {
        margin: 0 auto;
        width: 100%;
    }

    .bg-area-cp:before {
        content: "";
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100vh;
        background-image: url("../images/bg-kuri.webp");
        background-size: contain;
        background-repeat: repeat;
        background-position: top center;
    }

    .main-area {
        margin: 0 0 0;
    }

    .contents {
        width: 100%;
        margin: 0 0 0;
    }

    .bg-area-01 {
        width: 100%;
        margin: 0 auto;
        background-image: url("../images/bg-01.webp");
        background-repeat: repeat;
    }

    .main {
        width: 90%;
        max-width: 1280px;
        margin: 0 auto 0;
        padding: 2vh 0 40px;
    }

    .main-bottom {
        width: 90%;
        max-width: 1280px;
        margin: -20vw auto 0;
    }

    @media screen and (min-width: calc(1280px / 0.9)) {

        .main-bottom {
            margin: -285px auto 0;
        }

    }

    .main-bottom img {
        width: 100%;
    }

    .main-bnr {
        width: 80%;
        max-width: 640px;
        margin: 2vh auto 0;
        filter: drop-shadow(3px 6px 3px rgba(0, 0, 0, 0.2));
    }

    #campaign {
        margin: 5vh 0 5vh;
    }

    .campaign-main-border {
        height: 20px;
        background-color: #df2014;
    }

    .campaign-main {
        width: 100%;
        max-width: 1280px;
        margin: 0 auto 0;
    }

    .campaign-term {
        width: 100%;
        padding: 15px 30px;
        background-color: #df2014;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
    }

    .term-title {
        margin-right: 20px;
        padding: 5px 20px;
        background-color: #ffffff;
        border-radius: 8px;
        font-size: 2rem;
        font-weight: 700;
    }

    .term-day {
        font-size: 1.75rem;
        font-weight: 700;
        color: #ffffff;
    }

    .term-day span {
        font-size: 2.75rem;
    }

    .bg-area-02 {
        width: 100%;
        margin: 0 auto;
        background-color: #6a3419;
    }

    .contents02 {
        width: 100%;
        padding: 20px;
        background-color: #fffab8;
    }

    .contents-area {
        width: 90%;
        max-width: 1000px;
        margin: 0 auto;
        padding: 4rem 0 4rem;
    }

    .campaign-title-con {
        width: 100%;
        margin: 0 auto 2rem;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .title-border {
        flex-grow: 2;
        max-height: 20px;
        background-image: url(../images/title-border.png);
        background-size: 20px;
        background-repeat: round;
    }

    .campaign-title {
        padding: 0 5%;
        font-family: "Noto Sans JP";
        font-weight: 700;
        font-size: 3rem;
        color: #ffffff;
    }

    .brown .title-border {
        background-image: url(../images/title-border-brown.png);
    }

    .brown .campaign-title {
        color: #6a3419;
    }

    .contents02-center {
        padding: 0 6% 0;
        display: flex;
        background-image: url(../images/contents02-bg-center.png);
        background-size: 100%;
        background-position: bottom;
        background-repeat: repeat;
    }

    .contents02-center-L {
        width: 50%;
        padding-right: 3%;
    }

    .contents02-text01 {
        font-size: 1.25rem;
        text-align: center;
    }

    .contents02-text02 {
        margin: 3rem 0;
        font-size: 1.125rem;
    }

    .contents02-btn {
        width: 100%;
    }

    .contents02-btn a {
        height: 80px;
        display: flex;
        justify-content: center;
        align-items: center;
        background: #00acee;
        border-radius: 36px;
        color: #fff;
        font-size: 1.5rem;
        font-weight: 600;
        text-decoration: none;
        transition: 0.5s;
    }

    /*.contents02-btn span::before {
        content: "";
        display: inline-block;
        width: 40px;
        height: 40px;
        margin-right: 10px;
        background-image: url(../images/tw-logo.svg);
        background-size: contain;
        background-repeat: no-repeat;
        vertical-align: middle;
    }*/
    .contents02-btn a:hover {
        opacity: 0.8;
    }

    .contents02-copy01 {
        margin: 2rem 0;
        padding: 1rem 0;
        border-top: 3px solid #8ec21f;
        border-bottom: 3px solid #8ec21f;
        text-align: center;
        font-size: 1.75rem;
        font-weight: 900;
        color: #00903a;
    }

    .contents02-copy01 span {
        font-size: 1.5rem;
        color: #000;
    }

    .contents02-copy02 {
        margin: 0 0;
        padding: 0 0;
        text-align: center;
        font-size: 1.25rem;
        font-weight: 700;
        color: #6a3419;
    }

    .contents02-center-R {
        width: 50%;
        padding-left: 3%;
    }

    .tweet-box {
        width: 100%;
        margin-top: 1.5rem;
    }

    .uc {
        width: 100%;
        padding: 8rem 2rem;
        text-align: center;
        font-size: 1.5rem;
        background-color: #fff;
        border-radius: 12px;
        border: 1px solid #ccc;
    }

    .post-img {
        width: 100%;
        border: 1px solid #ccc;
    }

    .post-img img {
        width: 100%;
    }

    .bg-area-03 {
        width: 100%;
        margin: 0 auto;
        background-color: #ffffe4;
    }

    .contents03 {
        margin: 0 0 0;
        border: 2px solid #6a3419;
        background: #fff;
    }

    .contents03-inner {
        height: 360px;
        margin: 15px 10px 15px;
        overflow-y: scroll;
        background: #fff;
    }

    .contents03-inner::-webkit-scrollbar {
        width: 20px;
    }

    .contents03-inner::-webkit-scrollbar-track {
        background: #fff;
        border-radius: 10px;
    }

    .contents03-inner::-webkit-scrollbar-thumb {
        background: #986d58;
        border-radius: 10px;
    }

    .contents03-part-tit {
        margin: 40px 20px 20px;
        padding: 0 0 0.25em;
        border-bottom: 1px solid #000;
    }

    .contents03-part {
        margin-bottom: 1em;
        padding: 0 20px 0;
    }

    .contents03-part2 {
        margin-bottom: 1em;
        padding: 20px 20px 0;
    }

    .contents03-tit {
        margin: 1em 0 0;
        font-size: 1.4em;
    }

    .contents03-tit2 {
        margin: 1em 0 0;
        font-size: 1.2em;
    }

    .contents03-text {
        font-size: 1.1em;
    }

    .contents03-text2 {
        font-size: 1.1em;
        text-indent: -1em;
        padding-left: 1em;
    }

    .contents03-text3 {
        font-size: 1.1em;
        text-indent: -1em;
        padding-left: 2em;
    }

    #package {
        /*margin: 10vh 0 0;*/
        margin: 2.5vh 0 0;
    }

    #package .bg-area-01 {
        padding: 0 0 10px;
    }

    .white-area {
        width: 100%;
        margin: 0 auto 0;
        background-color: #ffffff;
    }

    .story-main,
    .story-main-bottom {
        width: 100%;
        max-width: 1280px;
        margin: 0 auto 0;
    }

    .story-main img,
    .story-main-bottom img {
        width: 100%;
    }

    .story-tit-area {
        width: 90%;
        max-width: 1000px;
        margin: 30px auto 15px;
    }

    .story-tit {
        margin: 0 auto 0;
        padding: 10px 30px;
        background-color: #000000;
        border-radius: 32px;
        color: #ffffff;
        font-size: 1.75rem;
        font-weight: 600;
        text-align: center;
    }

    .story-arrow {
        font-family: "Noto Sans JP";
        font-weight: 700;
        font-size: 2.5rem;
        text-align: center;
    }

    .story-slider {
        width: 80%;
        max-width: 780px;
        margin: 0 auto 0;
        padding: 0 30px;
    }

    @media screen and (min-width: 768px) and (max-width: 1280px) {

        .story-slider {
            max-width: 640px;
        }

    }

    .story-pic {
        width: 100%;
    }

    .story-pic img {
        width: 100%;
    }

    button {
        margin: 0;
        padding: 0;
        background: none;
        border: none;
        border-radius: 0;
        outline: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
    }

    .slide-dots2 {
        width: 100%;
        max-width: 400px;
        margin: 16px auto 0;
        text-align: center;
    }

    .slide-dots2 li {
        display: inline-block;
        margin: 0 1rem;
    }

    .slide-dots2 li button {
        position: relative;
        text-indent: -9999px;
        cursor: pointer;
    }

    .slide-dots2 li button:before {
        content: "●";
        font-size: 12px;
        text-indent: 0;
        position: absolute;
        color: #ff6666;
        top: 0;
        left: 0;
    }

    .slide-dots2 li.slick-active button:before {
        font-size: 16px;
        text-indent: 0;
        content: "●";
        color: #ed1c24;
        top: -4px;
        left: -2px;
    }

    .bottom-bnr {
        width: 80%;
        max-width: 640px;
        margin: 40px auto 40px;
        filter: drop-shadow(3px 6px 3px rgba(0, 0, 0, 0.2));
    }

}
