@charset "UTF-8";

/* ==========================================================================
   AiScReam � �q����� �������� LP ������
   ========================================================================== */

:root {
    --ttl_height_pc: 105px;
    --ttl_height_sp: 39px;
}


/* Reset & Base Styles
   ========================================================================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: 62.5%;
    /* 1rem = 10px */
    scroll-behavior: smooth;
}

body {
    font-family: vdl-v7marugothic, 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 1.6rem;
    line-height: 1.8;
    color: #333;
    background-color: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "palt";
    letter-spacing: 0.12em;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

a {
    color: inherit;
    text-decoration: none;
    transition: opacity 0.3s ease;
}

a:hover {
    opacity: 0.7;
}

ul,
ol {
    list-style: none;
}

.-hirahira_top,
.-hirahira_bottom {
    height: 34px;
    background-image: url("../img/aiscream/hirahira_mint.webp");
    background-position: center;
    background-repeat: repeat-x;
    background-size: auto 34px;
}

.-hirahira_bottom {
    transform: rotate(180deg);
}

@media (min-width: 768px) {

    .-hirahira_top,
    .-hirahira_bottom {
        height: 50px;
        background-size: auto 50px;
    }
}


/* Container
   ========================================================================== */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px;
    position: relative;
}

section {
    padding: 6rem 0;
}

/* Tablet and up */
@media (min-width: 768px) {

    .container {
        padding: 0 20px;
    }

    section {
        padding: 8rem 0;
    }
}

/* Desktop and up */
@media (min-width: 1024px) {

    section {
        padding: 10rem 0;
    }
}

/* Header
   ========================================================================== */
.-header {
    background-image: url("../img/aiscream/bg_header_sp.webp");
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    width: 100%;
    position: relative;
    padding: 70px 0;
    z-index: -2;

    &::before,
    &::after {
        content: '';
        position: absolute;
        left: 0;
        width: 100%;
        height: 40px;
        background-image: url("../img/aiscream/bg_plaid_pattern.webp");
        background-position: center;
        background-repeat: repeat;
        background-size: auto 20px;
    }

    &::before {
        top: 0;
    }

    &::after {
        bottom: 0;
    }

    & .container {
        height: 100%;
    }

    & .-catch {
        color: #584124;
        text-align: center;
        font-size: 1.6rem;
        letter-spacing: 0.02em;
        line-height: 1.7;
        font-weight: 800;
        text-shadow:
            -3px -3px 0 white,
            3px -3px 0 white,
            -3px 3px 0 white,
            3px 3px 0 white,
            -3px 0 0 white,
            3px 0 0 white,
            0 -3px 0 white,
            0 3px 0 white;
        margin: 0 0 30px;
    }


    & .-members {
        height: 380px;
        position: relative;
        max-width: 100%;
        width: 900px;
        margin: 0 auto;
        z-index: -1;

        & .-ayumu,
        & .-ruby,
        & .-shiki {
            height: 71%;
            position: absolute;

            & img {
                height: 100%;
                max-width: initial;
                object-fit: cover;
                overflow: visible;
            }
        }

        & .-ruby {
            left: 50%;
            top: 0;
            transform: translate(-54%, 0%);
        }

        & .-ayumu {
            left: 0;
            bottom: 0;
        }

        & .-shiki {
            right: 0;
            bottom: 0;
        }
    }


    & .-logo_collabo {
        text-align: center;
        height: 80px;
        width: 100%;
        margin-bottom: 8px;
        margin-top: -45px;
        line-height: 1;

        & img {
            height: 100%;
            width: 67%;
            object-fit: contain;
        }
    }

    & .-title {
        height: 50px;
        width: 100%;
        text-align: center;
        margin-bottom: 20px;
        line-height: 1;

        & img {
            height: 100%;
            width: 95%;
            object-fit: contain;
        }
    }

    & .-period {
        width: 100%;
        color: #584124;
        letter-spacing: 0.1em;
        text-align: center;
        left: 0;
        font-size: 2rem;
        font-weight: 800;
        text-shadow:
            -3px -3px 0 white,
            3px -3px 0 white,
            -3px 3px 0 white,
            3px 3px 0 white,
            -3px 0 0 white,
            3px 0 0 white,
            0 -3px 0 white,
            0 3px 0 white;
        z-index: 2;
    }

    @media (min-width: 768px) {
        background-image: url("../img/aiscream/bg_header_pc.webp");
        padding: 120px 0;

        &::before,
        &::after {
            height: 60px;
            background-size: auto 30px;
        }

        & .-members {
            height: 680px;
            width: 960px;

            & .-ayumu,
            & .-ruby,
            & .-shiki {
                height: 80%;
            }

            & .-ruby {
                left: 50%;
                top: 0;
                transform: translate(-52%, 0%);
            }

            & .-ayumu {
                left: 0;
                bottom: 0;
            }

            & .-shiki {
                right: 0;
                bottom: 0;
            }
        }

        & .-catch {
            font-size: 3rem;
            letter-spacing: 0.12em;
            line-height: 1.8;
        }

        & .-logo_collabo {
            height: 120px;
            margin-top: -210px;
            margin-bottom: 20px;
            line-height: 1;
        }

        & .-title {
            height: 80px;
            margin-bottom: 20px;
        }

        & .-period {
            font-size: 3.8rem;
        }
    }
}


/* Lead Section
   ========================================================================== */
.lead-section {
    position: relative;
    font-size: 1.6rem;
    line-height: 2;

    &::before {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: 0;
        background-image: url("../img/aiscream/dotted_mix.webp");
        background-position: center;
        background-repeat: repeat;
        background-size: auto 80px;
        opacity: 0.44;
        /* 透過度。必要に応じて調整 */
        pointer-events: none;
    }

    &>* {
        position: relative;
        z-index: 1;
    }


    & .-lead {
        padding: 40px 0;
    }

    @media (min-width: 768px) {
        font-size: 1.8rem;
        line-height: 2.3;

        &::before {
            background-size: auto 120px;
        }

        & .-lead {
            padding: 70px 0;
        }
    }
}


/* Gelato Set Section
   ========================================================================== */
.gelatoset-section {
    position: relative;
    padding-top: 90px;
    padding-bottom: 0;
    ;

    &::before {
        content: '';
        position: absolute;
        left: 0;
        width: 100%;
        height: 40px;
        background-image: url("../img/aiscream/bg_plaid_pattern.webp");
        background-position: center;
        background-repeat: repeat;
        background-size: auto 20px;
    }

    &::before {
        top: 0;
    }

    & .-logo {
        text-align: center;
        margin-bottom: 10px;

        & img {
            width: auto;
            height: 66px;
            object-fit: cover;
        }
    }

    & .-title {
        text-align: center;
        margin-bottom: 40px;

        & img {
            width: auto;
            height: var(--ttl_height_sp);
            object-fit: cover;
        }
    }

    & .-period {
        background-color: #ffff2f;
        border-radius: 10px;
        font-weight: 800;
        padding: 15px;
        text-align: center;
        margin: 20px 0;
    }

    & .-remarks {
        font-size: 1.4rem;
    }

    @media (min-width: 768px) {

        &::before {
            height: 60px;
            background-size: auto 30px;
        }

        & .-logo {
            margin-bottom: 20px;

            & img {
                height: 159px;
            }
        }

        & .-title {
            margin-bottom: 60px;

            & img {
                height: var(--ttl_height_pc);
            }
        }

        & .-period {
            margin: 30px 0;
            padding: 25px;
        }
    }
}


/* Flavor Section
   ========================================================================== */
.flavor-section {
    padding-bottom: 0;

    & .-title {
        text-align: center;
        margin-bottom: 40px;

        & img {
            width: auto;
            height: var(--ttl_height_sp);
            object-fit: cover;
        }
    }

    & .-ruby_flavor,
    & .-shiki_flavor,
    & .-ayumu_flavor {
        background-size: auto 80px;
        background-position: center;
        background-repeat: repeat;
        padding: 30px 0;
    }

    & .-ruby_flavor {
        background-image: url("../img/aiscream/dotted_mint.webp");
        margin-bottom: 30px;

        & .-name {
            background-color: #69bbbb;
        }
    }

    & .-ayumu_flavor {
        background-image: url("../img/aiscream/dotted_strawberry.webp");
        margin-bottom: 30px;

        & .-name {
            background-color: #e898a6;
        }
    }

    & .-shiki_flavor {
        background-image: url("../img/aiscream/dotted_cookie.webp");

        & .-name {
            background-color: #e0cebc;
        }
    }

    & .-content {
        background-color: #fff;
        padding: 15px;
        border-radius: 10px;

        & .-title {
            text-align: left;
            margin-bottom: 15px;
            text-align: center;
        }

        & .-name {
            font-size: 1.7rem;
            font-weight: 800;
            color: #fff;
            display: inline-block;
            margin-bottom: 10px;
            padding: 10px 20px;
            border-radius: 10px;
            line-height: 1;
        }

        & .-flavorname {
            height: 38px;
            line-height: 1;

            & img {
                height: 100%;
                object-fit: cover;
            }
        }
    }

    & .-character {
        height: 280px;
        display: block;
    }

    & .-lid {
        height: 190px;
        position: absolute;
        left: 0;
        bottom: 0;
    }

    & .-left {
        & .-character {
            margin: 0 auto 0 0;
        }

        & .-lid {
            right: 0;
            left: auto;
        }
    }

    & .-right {
        & .-character {
            margin: 0 0 0 auto;
        }
    }

    @media (min-width: 768px) {
        & .-title {
            margin-bottom: 60px;

            & img {
                height: var(--ttl_height_pc);
            }
        }

        & .-ruby_flavor,
        & .-shiki_flavor,
        & .-ayumu_flavor {
            background-size: auto 120px;
            padding: 50px 0;
        }

        & .-ruby_flavor {
            margin-bottom: 50px;
        }

        & .-ayumu_flavor {
            margin-bottom: 50px;
        }


        & .-content {
            padding: 25px;

            & .-title {
                margin-bottom: 20px;
                text-align: left;
            }

            & .-name {
                font-size: 1.8rem;
                margin-bottom: 10px;
                padding: 10px 20px;
            }

            & .-flavorname {
                height: 48px;
            }
        }

        & .-character {
            height: 480px;
        }

        & .-lid {
            height: 290px;
            left: 0;
            bottom: 0;
        }
    }
}


/* Novelty Section
   ========================================================================== */
.novelty-section {
    padding-bottom: 100px;
    position: relative;

    &::after {
        content: '';
        position: absolute;
        left: 0;
        width: 100%;
        height: 40px;
        background-image: url("../img/aiscream/bg_plaid_pattern.webp");
        background-position: center;
        background-repeat: repeat;
        background-size: auto 20px;
    }

    &::after {
        bottom: 0;
    }

    & .-title {
        text-align: center;
        margin-bottom: 40px;

        & img {
            width: auto;
            height: var(--ttl_height_sp);
            object-fit: cover;
        }
    }

    & .-sticker {
        width: 90%;
        transform: rotate(10deg);
        margin-left: 5%;
    }

    & .-remarks {
        font-size: 1.3rem;
    }

    & .btn-buy {
        margin-top: 0px;
    }

    @media (min-width: 768px) {
        padding-bottom: 150px;

        &::after {
            height: 60px;
            background-size: auto 30px;
        }

        & .-title {
            margin-bottom: 80px;

            & img {
                height: var(--ttl_height_pc);
            }
        }

        & .btn-buy {
            margin-top: 70px;
        }
    }
}


/* Goods Section
   ========================================================================== */
.goods-section {
    background-color: #f8f9fa;
    position: relative;
    padding: 0 !important;

    & .-hirahira_top,
    & .-hirahira_bottom {
        background-image: url("../img/aiscream/hirahira_cookie.webp");
    }

    &::before {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: 0;
        background-image: url("../img/aiscream/dotted_mix.webp");
        background-position: center;
        background-repeat: repeat;
        background-size: auto 80px;
        opacity: 0.44;
        /* 透過度。必要に応じて調整 */
        pointer-events: none;
    }

    &>* {
        position: relative;
        z-index: 1;
    }

    & .container {
        padding-top: 40px;
        padding-bottom: 40px;
    }

    & .-title {
        text-align: center;
        margin-bottom: 40px;

        & img {
            width: auto;
            height: var(--ttl_height_sp);
            object-fit: cover;
        }
    }

    & .-explanation {
        margin-bottom: 40px;
    }

    & .-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 45px;
        margin: 0 auto;

        & .-item {
            font-weight: 800;
            text-align: center;
            transition: transform 0.3s ease;

            &:hover {
                transform: translateY(-5px);
            }
        }

        & .-image {
            width: 100%;
            aspect-ratio: 1 / 1;
            object-fit: contain;
            border-radius: 10px;
            border: 1px solid #ff3397;
            margin-bottom: 1.5rem;
            background-color: #f8f9fa;
        }

        .-name {
            font-weight: 800;
            margin-bottom: 5px;
        }

        .-price {
            color: #444;
            font-size: 1.4rem;
            ;
            margin-bottom: 15px;
        }
    }

    @media (min-width: 768px) {
        padding: 0;

        &::before {
            background-size: auto 120px;
        }

        & .container {
            padding-top: 70px;
            padding-bottom: 70px;
        }

        & .-title {
            margin-bottom: 60px;

            & img {
                height: var(--ttl_height_pc);
            }
        }

        & .-explanation {
            margin-bottom: 60px;
            text-align: center;
        }

        .-name {
            font-size: 1.8rem;
            margin-bottom: 5px;
        }

        .-price {
            font-size: 1.4rem;
            margin-bottom: 15px;
        }
    }

    @media (min-width: 1024px) {
        padding: 8rem 0;

        & .-grid {
            grid-template-columns: repeat(3, 1fr);
            gap: 60px 40px;
        }
    }

}

/* About Section
   ========================================================================== */
.about-section {
    & .-title {
        text-align: center;
        margin-bottom: 40px;

        & img {
            width: 70%;
        }
    }

    & .-explanation {
        margin-bottom: 40px;
    }
}


.-two_column {

    &>div {
        margin-bottom: 40px;
    }

    & .-left {
        position: relative;
    }

    & .-right {
        position: relative;
    }

    &>div:last-of-type {
        margin-bottom: 0px;
    }

    @media (min-width: 768px) {
        display: flex;
        justify-content: space-between;

        &>div {
            margin-bottom: 0px;
        }

        &.-algin_center {
            align-items: center;
        }

        & .-left {
            width: 48%;
            order: 1;
        }

        & .-right {
            width: 48%;
            order: 2;
        }
    }
}

.marugela-section {
    & .btn-marugela {
        display: block;
        margin: 0 auto;
        width: 80%;
        margin-bottom: 50px;

        & img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }

    @media (min-width: 768px) {
        & .btn-marugela {
            width: 50%;
            max-width: 400px;
            margin-bottom: 70px;
        }
    }
}

/* Footer
   ========================================================================== */
.-footer {
    padding: 20px 15px;

    background-image: url("../img/aiscream/bg_plaid_pattern.webp");
    background-position: center;
    background-repeat: repeat;
    background-size: auto 20px;

    & .copyright {
        font-family: 'Noto Sans JP', sans-serif;
        text-align: center;
        font-size: 1.3rem;
        line-height: 1;
        letter-spacing: 0.05em;
        text-shadow:
            -2px -2px 0 white,
            2px -2px 0 white,
            -2px 2px 0 white,
            2px 2px 0 white,
            -2px 0 0 white,
            2px 0 0 white,
            0 -2px 0 white,
            0 2px 0 white;
    }

    @media (min-width: 768px) {
        background-size: auto 30px;
    }
}


/* Various Styles
   ========================================================================== */


.btn-buy {
    display: inline-block;
    background-color: #69bbbb;
    color: #fff;
    font-size: 1.7rem;
    font-weight: 800;
    text-align: center;
    padding: 1rem 20px;
    border-radius: 10px;
    transition: all 0.3s ease;
    text-decoration: none;
    width: 100%;

    &:hover {
        background-color: #7ab3b2;
        transform: translateY(-2px);
        box-shadow: 0 4px 15px rgba(139, 195, 194, 0.4);
    }

    &.-big {
        font-size: 2rem;
    }
}

.sp-br {
    display: block;
}

.pc-br {
    display: none;
}

.mt-2 {
    margin-top: 20px;
}

.mt-5 {
    margin-top: 50px !important;
}

@media (min-width: 768px) {

    .btn-buy {
        font-size: 1.7rem;
        padding: 1rem 20px;

        &.-big {
            font-size: 3rem;
            margin-left: auto;
            margin-right: auto;
            display: block;
            width: 50%;
        }
    }

    .sp-br {
        display: none;
    }

    .pc-br {
        display: block;
    }
}
