/*rest　******************************/
*{box-sizing: border-box;}
img{max-width:100%;max-height: 100%;}
a{display: block; text-decoration: none; color:var(--color-bk) !important;}
button{
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
    color:inherit;
}

body{
    line-height: 1;
}

html{
    font-size:62.5% !important;
}
a{transition: 0.2s;}
a:hover{text-decoration: none !important;}



/*root　******************************/

:root {
scroll-behavior: smooth;
scroll-padding:100px;

--font-txt:clamp(13px, calc(11.73px + 0.327vw), 18px);
--font-st-txt:clamp(14px, calc(12.47px + 0.392vw), 20px);


/* Line Height */
--line-body: 1.6;
--line-heading: 1.3;

/* Spacing (Fluid) */
--space-xs: clamp(4px, calc(2.98px + 0.261vw), 8px);
--space-sm: clamp(8px, calc(5.96px + 0.523vw), 16px);
--space-md: clamp(12px, calc(8.94px + 0.784vw), 24px);
--space-lg: clamp(16px, calc(11.92px + 1.046vw), 32px);
--space-xl: clamp(24px, calc(19.92px + 1.046vw), 40px);
--space-1xl: clamp(28px, calc(19.92px + 1.046vw), 56px);
--space-2xl: clamp(32px, calc(23.84px + 2.092vw), 64px);
--space-3xl: clamp(40px, calc(29.8px + 2.614vw), 80px);
--space-4xl: clamp(48px, calc(35.76px + 3.137vw), 96px);
--space-5xl: clamp(64px, calc(49.73px + 3.66vw), 120px);
--space-6xl: clamp(72px, calc(53.65px + 4.706vw), 144px);
--space-7xl: clamp(80px, calc(59.61px + 5.229vw), 160px);
--space-8xl: clamp(96px, calc(71.53px + 6.275vw), 192px);
--space-9xl: clamp(120px, calc(89.41px + 7.843vw), 240px);
--color-primary-lpk:#EADEDD;
--color-primary-lgr:#E6EFEA;
--color-text:#3F3F3F;
--color-base:#FDFDFD;



/* Layout */
--container-max: 1440px;
--container-max-s: 1280px;
}


.pc{
    display: none;
}


.font-en{
    font-family: "the-seasons", sans-serif;
    font-weight: 400;
    letter-spacing: 0.1em;
}

.font-en-b{
font-weight: 700;
}



@media (min-width: 768px) {

:root {
--line-body: 1.87;
--line-heading: 1.2;
}

.pc{
    display: block;
}

.sp{
    display: none;
}

}


/*common　******************************/
.l-wrapper{
    padding-bottom:var(--mg96);
}

.contentWrapper {
    overflow: hidden;
    color:var(--color-text) !important;
    font-optical-sizing: auto;
    font-weight: 400;
    font-family: "Noto Serif JP", serif;
    font-optical-sizing: auto;
    letter-spacing: 0.1em;
    background:var(--color-base);
}


.l-container{
    width: 100%;
    position: relative;
    z-index:10;
}

@media (min-width: 768px) {

.l-container{
    width: min(100% - var(--space-7xl), var(--container-max));
    margin-inline: auto;
}


}





/*　mv・intro ******************************/

.mainVisual{
    width:100%;
    position: relative;
    background:#F7F7F7;
}
.mainVisual__wrapper{
    text-align: center;
}

.intro{
    width:100%;
    padding:var(--space-6xl) 0;
    background: linear-gradient(180deg,rgba(247, 247, 247, 1) 0%, rgba(253, 253, 253, 1) 60%);
}

.intro__txt{
    font-size:var(--font-st-txt);
    font-weight: 500;
    text-align: center;
    line-height:2;
    letter-spacing: 0.1em;
}

.intro__nav{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap:var(--space-md);
    margin-top:var(--space-1xl);
}

.intro__nav li{
    width:min(80%,360px);
}

.intro__nav li a{
    font-size:clamp(20px, calc(18.98px + 0.261vw), 24px);
    text-align: center;
    border:1px solid var(--color-text);
    padding:var(--space-md) 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap:var(--space-md);
    font-weight: 700;
    letter-spacing: 0.1em;
}

.intro__nav li a span{
    display: block;
}

.intro__nav li:first-child a span{
    width:16px;
    height:16px;
    background:url(/img/usr/freepage/20260410_flower_ribbon/flower-icon.png) no-repeat center center/contain;
    margin-right:2px;
}

.intro__nav li:last-child a span{
    width:18px;
    height:16px;
    background:url(/img/usr/freepage/20260410_flower_ribbon/ribbon-icon.png) no-repeat center center/contain; 
}

@media (min-width: 768px) {

    .mainVisual__wrapper{
        width: min(100% - var(--space-5xl), 1560px);
        margin-inline: auto;
    }

    .intro__nav{
    flex-direction: row;
    justify-content: center;
    gap:var(--space-2xl);
}

    .intro__txt{
    line-height:2.5;
    }

.intro__nav li a{
    gap:var(--space-sm);
}

.intro__nav li:first-child a span{
    width:20px;
    height:20px;
    margin-right:2px;
}

.intro__nav li:last-child a span{
    width:22px;
    height:20px;
}

}

/* cat &　共通 *******************************/

.cat__wrapper{
    position: relative;
}

.cat__wrapper.ribbon{
    margin-top:var(--space-8xl);
}

.cat__wrapper::before,.cat__wrapper::after{
    content:"";
    display: block;
    position: absolute;
    z-index:1;
    background:var(--color-primary-lgr);
}

.cat__wrapper::before{
    width:47vw;
    height:85vw;
    top:calc(clamp(40px, calc(25.22px + 3.791vw), 98px) / 1.7);
}

.cat__wrapper::after{
    width:56vw;
    height:80vw;
    bottom:0;
    right:0;
}

.cat__wrapper.ribbon::before,.cat__wrapper.ribbon::after{
    background:var(--color-primary-lpk);  
}

.cat__ttl{
    position: relative;
    z-index:10;
    padding:0 var(--space-xl);
    margin-bottom:var(--space-4xl);
}

.cat__ttl h2{
    font-size:clamp(40px, calc(25.22px + 3.791vw), 98px);
}

.cat__ttl p{
    font-size:var(--font-st-txt);
    font-weight: 600;
    margin-top:var(--space-lg);
}

.item__sub-ttl{
    font-size: var(--font-st-txt);
    width: fit-content;
    display: flex;
    gap:10px;
    align-items: center;
    font-weight: 700;
}

.item__sub-ttl::before{
    content:"";
    display: block;
    width:12px;
    height:12px;
    background: url(/img/usr/freepage/20260410_flower_ribbon/flower-icon.png) no-repeat center center/contain;
}

.cat__wrapper.ribbon .item__sub-ttl::before{
    width:14px;
    height:12px;
    background: url(/img/usr/freepage/20260410_flower_ribbon/ribbon-icon.png) no-repeat center center/contain;

}

.item__copy{
    font-size:var(--font-st-txt);
    font-weight: 600;
    line-height: 1.8;
}

.item__sub-ttl-sp{
    display: flex;
    flex-direction: column;
    gap:var(--space-lg);
    padding:0 var(--space-xl);
}


.item__name,.item__price{
    font-weight: 500;
    font-size:var(--font-txt);

}

.item__price{
    margin:var(--space-md) 0 var(--space-xl);
}

.btn{
    font-size: var(--font-st-txt);
    font-weight: 700;
    width:fit-content;
}

.btn::after{
    content:"";
    display: inline-block;
    width:100%;
    height:1px;
    background:var(--color-text);
}

.item__txt{
    padding:0 var(--space-xl);
    margin-top:var(--space-xl);
}

.item__sub-ttl-pc{
    display: none;
}

@media (min-width: 768px) {

/* .cat__wrapper{
    position: relative;
} */

.cat__wrapper::before{
    width:56vw;
    height:min(26vw,516px);
}

.cat__wrapper::after{
    width:68vw;
    height:min(20vw,380px);
}

.cat__ttl{
    width: min(100% - var(--space-5xl), 1560px);
    margin-inline: auto;
    padding:0;
}

    .item__sub-ttl-sp{
        display: none;
    }

    .item__sub-ttl-pc{
        display: block;
    }

    .item__sub-ttl{
        gap:15px;
        margin-bottom:var(--space-1xl);
    }

    .item__sub-ttl::before{
        width:16px;
        height:16px;
        margin-bottom:2px;
    }

    .cat__wrapper.ribbon .item__sub-ttl::before{
        width:18px;
        height:16px;
    }

    .item__txt{
        padding:0;
        margin-top:0;
    }

    .item__copy{
        line-height: 2;
        margin-bottom:var(--space-xl);
    }

    .item__price{
        margin:var(--space-md) 0 var(--space-1xl);
    }

}

/* item1 *******************************/

.item1-main-image{
    width:76vw;
    margin:var(--space-xl) 0 0 auto;
}

.item1-sub-image{
    position: relative;
    width: fit-content;
    margin-top:calc(15vw + var(--space-xl));
}

.item1-sub-image div:first-of-type{
    width:67vw;
    position: relative;
    z-index:1;
}

.item1-sub-image div:last-of-type{
    width:43vw;
    position: absolute;
    right:-23vw;
    top:-15vw;
    z-index:10;
}

.item1 .item__txt{
    text-align: right;
}

.item1 .btn{
    margin:0 0 0 auto;
}

.cat__wrapper.ribbon .item1-sub-image{
    width:70vw;
    margin-top:var(--space-xl);
}

@media (min-width: 768px) {

.item1{
    display: flex;
    gap:var(--space-3xl);
}

.item1-main-image{
    width:42%;
    margin:0;
}

.item1-r-cont{
    width:calc((100% - var(--space-3xl)) - 42%);
    display: flex;
    justify-content: flex-end;
    flex-direction: column-reverse;
}

.item1-sub-image{
    /* position: relative;
    width: fit-content; */
    margin-top:22%;
}

.item1-sub-image div:first-of-type{
    width:75%;
}

.item1-sub-image div:last-of-type{
    width:53%;
    right:0;
    top:-32%;
}

.item1 .item__sub-ttl-pc{
    margin:0 0 0 auto;
}

.item1 .item__sub-ttl{
    margin-left: auto;
}

.item1 .item__txt{
    margin-top:var(--space-xl);
}

/* .item1 .btn{
    margin:0 0 0 auto;
} */
.cat__wrapper.ribbon .item1-sub-image{
    width:100%;
    padding:0 var(--space-2xl) 0 0;
    margin-top:var(--space-3xl);
}

}

/* item2 *******************************/

.item2{
    margin-top:var(--space-6xl);
}

.item2-main-image{
    width:54vw;
    margin:var(--space-xl) 0 0 var(--space-xl);
    position: relative;
}

.item2-main-image::after{
    content:"";
    display: block;
    width:60vw;
    height:40vw;
    background:var(--color-primary-lgr);
    position: absolute;
    bottom:-20vw;
    right:-20vw;
    z-index:1;
}

.cat__wrapper.ribbon .item2-main-image::after{
    background:var(--color-primary-lpk);
}

.item2-main-image a{
    position: relative;
    z-index:10;
}

.item2-sub-image{
    width:66vw;
    position: relative;
    z-index:10;
    margin:var(--space-xl) 0 0 auto;
}

@media (min-width: 768px) {

.item2{
    margin-top:var(--space-2xl);
    position: relative;
}

.item2 .item__txt{
    position: absolute;
    top:0;
    left:0;
    z-index:10;
}

.item2-r-cont{
    width:75%;
    display: flex;
    gap:var(--space-lg);
    margin:0 0 0 auto;
    padding:var(--space-5xl) 0 0 var(--space-8xl);
}

.item2-main-image,.item2-sub-image{
    width:calc((100% - var(--space-lg)) / 2);
    margin:0;
}

.item2-main-image::after{
    width:100%;
    height:min(17vw,328px);
    bottom:var(--space-3xl);
    right:inherit;
    left:calc(-1 * var(--space-8xl));
}

}

/* item3 item4 *******************************/

.item3{
    margin-top:var(--space-6xl);
}

.item3 .item__sub-ttl{
    margin:0 auto;
}

.item3 .item__sub-ttl-sp{
    text-align: center;
}

.item3-main-image{
    width:70vw;
    margin:var(--space-xl) auto;
}

.item3 .item__txt{
    text-align: center;
}

.item3 .btn{
    margin:0 auto;
}

.item4{
    margin-top:var(--space-6xl);
    padding-bottom:var(--space-3xl);
}

.item4-main-image{
    width:80vw;
    margin:var(--space-xl) 0 ;
}

@media (min-width: 768px) {

.item3,.item4{
    margin-top:var(--space-7xl);
    padding:0 var(--space-2xl);
    display: grid;
    grid-template-columns: 45% 1fr;
    gap:var(--space-5xl);
}

.item3 .item__sub-ttl{
    margin:0 0 var(--space-1xl);
}

.item3-main-image,.item4-main-image{
    width:100%;
    margin:0;
}

.item3 .item__txt{
    text-align: left;
    margin-top:var(--space-xl);
}

.item3 .btn{
    margin:0 ;
}

.item4{
    padding-bottom:var(--space-7xl);
    align-items: flex-end;
    margin-top:calc(-1 * var(--space-5xl));
}

.item4-main-image{
    order:2;
}


}




/*lineup以降*******************************/


.btm__banner{
    padding:var(--space-6xl) 0;
    position: relative;
    background:#F7F7F7;
    margin-top:var(--space-7xl);
}


.btm__banner__ttl-en{
    text-align: center;
    margin-bottom: var(--space-md);
    font-size: clamp(20px, calc(16.94px + 0.784vw), 32px);
    line-height: 1.4;
}

.btm__banner__ttl{
    font-size: var(--font-txt);
    text-align: center;
    margin-bottom:var(--space-3xl);
    font-family: "Noto Sans JP", sans-serif;

}

.btm__banner__lists{
    margin-top:var(--space-lg);
}

.btm__banner__lists li p{
    text-align: center;
    font-size:var(--font-txt);
    line-height: var(--line-heading);
    margin-top:var(--space-sm);
    font-family: "Noto Sans JP", sans-serif;
}

.btm__banner__lists li:last-child{
    margin-top:var(--space-xl);
}

@media (min-width: 768px) {


.btm__banner__lists{
    display: flex;
    justify-content: center;
    align-items: center;
    gap:var(--space-5xl);
}


.btm__banner__lists li p{
    margin-top:var(--space-md);
}

.btm__banner__lists li:last-child{
    margin-top:0;
}

.btm__banner__lists li{
    max-width:680px;
}

.btm__banner__lists a:hover{
    opacity: 0.8;
}

}



/*footer ******************************/


.footer__wrapper{
    background:var(--color-base);
    padding: var(--space-5xl) 0;
}

.footer__wrapper p{
    width:clamp(240px, calc(183.92px + 14.379vw), 460px);
    margin:0 auto;
}

/*アニメーション
--------------------------------------------------------*/


.image-anime{
    transform: translateY(10px);
    opacity: 0;
    visibility: hidden;
}

.image-anime2{
    opacity: 0;
    scale: 1.15;
    visibility: hidden;
}



@media (min-width: 768px) { 

.intro__nav li a:hover{
    background:var(--color-primary-lgr);
}

.intro__nav li:last-child a:hover{
    background:var(--color-primary-lpk);
}

.item1-main-image,.item2-main-image,.item3-main-image,.item4-main-image,.item1-sub-image .hover-img,
.item2-sub-image,.cat__wrapper.ribbon .item1-sub-image{
    overflow: hidden;
}

.item1-main-image a,.item2-main-image a,.item3-main-image a,.item4-main-image a,.item1-sub-image .hover-img a,.item2-sub-image a,
.cat__wrapper.ribbon .item1-sub-image a{
    cursor: pointer;
}

.item1-main-image a img,.item2-main-image a img,.item3-main-image a img,.item4-main-image a img,.item1-sub-image .hover-img a img,.item2-sub-image a img,.cat__wrapper.ribbon .item1-sub-image a img{
    transition: 0.4s;
}

.item1-main-image a:hover img,.item2-main-image a:hover img,.item3-main-image a:hover img,.item4-main-image a:hover img,.item1-sub-image .hover-img a:hover img,.item2-sub-image a:hover img,.cat__wrapper.ribbon .item1-sub-image a:hover img{
    transform: scale(1.04);
    filter: brightness(1.1) contrast(96%);

}

.btn:hover{
    color:#87b69e !important;
}

.btn::after{
    transition: 0.3s;
}

.btn:hover::after{
    background:#87b69e;
}

.cat__wrapper.ribbon .btn:hover{
    color:#bb9695 !important;
}

.cat__wrapper.ribbon .btn:hover::after{
    background:#bb9695;
}

}