/*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.4s;}
a:hover{text-decoration: none !important;}



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

:root {
scroll-behavior: smooth;
scroll-padding:100px;
--font-body:clamp(13px, calc(12.24px + 0.196vw), 16px);
--font-copy:clamp(16px, calc(13.96px + 0.523vw), 24px);
--font-sub-copy: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-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-gr:#E7F9BF;
--color-primary-gy:#AFAFAF;
--color-text:#3F3F3F;
--color-base:#FCFCFC;


/* Layout */
--container-max: 1556px;
--container-max-s: 1200px;
}


.pc{
    display: none;
}

.font-en-s{
font-family: "minion-pro", serif;
font-weight: 600;/*500*/
font-style: normal;
font-size: clamp(16px, calc(14.98px + 0.261vw), 20px);
letter-spacing: 0.1em;
}


.font-en{
    font-family: "acumin-pro-semi-condensed", sans-serif;
    font-weight: 700;
    font-style: normal;
    letter-spacing: 0.15em;
}

.grid-fluid {
    display: grid;
    gap: var(--space-md);
    grid-template-columns: repeat(
    auto-fit,
    minmax(min(280px, 100%), 1fr)
    );
}

@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;
    letter-spacing: .05em;
    color:var(--color-text) !important;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    background:var(--color-base);
}


.l-container{
    /* width: min(100% - var(--space-4xl), var(--container-max)); */
    padding:0 var(--space-xl);
    margin-inline: auto;
}



@media (min-width: 768px) {


.l-container{
    /* width: min(100% - var(--space-6xl), var(--container-max)); */
    padding:0 var(--space-4xl);
}


}

@media (min-width: 1920px) {
    .l-container{
    padding:0 var(--space-8xl);
    /* padding:0 var(--space-xl); */
}
}



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

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

.intro{
    width:100%;
    padding:var(--space-7xl) 0;
}

.intro__main-ttl{
    text-align: center;
    width: fit-content;
    padding:var(--space-lg) var(--space-xl);
    position: relative;
    margin:0 auto;
    border-right:1px solid var(--color-primary-gy);
    border-left:1px solid var(--color-primary-gy);
    margin-bottom:var(--space-3xl);
}

.intro__main-ttl span,.intro__main-ttl::before,.intro__main-ttl::after{
    display: block;
    width:12px ;
    height:1px;
    background:var(--color-primary-gy);
    position: absolute;
}

.intro__main-ttl span{
    top:0;
}

.intro__main-ttl::before,.intro__main-ttl::after{
    content:"";
    bottom:0;
}

.intro__main-ttl::before{
    left:0;
}

.intro__main-ttl::after{
    right: 0;
}

.intro__main-ttl span:first-of-type{
    left:0;
}


.intro__main-ttl span:last-of-type{
    right:0;
    left: inherit;
}

.intro__main-ttl p:first-of-type{
font-size:clamp(22px, calc(18.43px + 0.915vw), 36px);
margin-bottom:var(--space-sm);
}

.intro__main-ttl p:last-of-type{
    font-size: var(--font-body);
    letter-spacing: 0.1em;
}

.intro__theme-ttl p{
    font-size: clamp(24px, calc(21.96px + 0.523vw), 32px);
    margin:var(--space-md) 0 var(--space-xl);
}


.intro__txt{
    font-size:clamp(14px, calc(12.98px + 0.261vw), 18px);
    line-height:1.8;
    letter-spacing: 0.1em;
}

@media (min-width: 768px) {

    .mainVisual__wrapper{
        margin-inline: auto;
        padding:var(--space-xl) var(--space-4xl) 0;
    }

    .intro{
    padding:var(--space-8xl) 0;
}

    .intro .l-container{
        display: grid;
        grid-template-columns: repeat(2,1fr);
        align-items: flex-start;
    }

    .intro__txt{
        line-height:2.8;
    }

    .intro__main-ttl{
    padding:var(--space-lg) var(--space-2xl);
    margin-bottom:0;
}

.intro__main-ttl span,.intro__main-ttl::before,.intro__main-ttl::after{
    width:20px ;
}


}

@media (min-width: 768px) {

    .mainVisual__wrapper{
        padding:var(--space-xl) var(--space-8xl) 0;
    }
}

/*item ******************************/
.item-wrapper{
    background:var(--color-primary-gr);
    max-width:1920px;
    margin:0 auto;
    padding-bottom:var(--space-7xl);
}

.item{
    padding-top:var(--space-7xl);
}


.item__num span{
    display: inline-block;
    font-size:170%;
    font-weight: 500;
    margin-left:var(--space-sm);
}

.item__copy{
    font-size: var(--font-copy);
    width:fit-content;
    background:var(--color-base);
    padding:var(--space-xs) var(--space-sm);
    margin:var(--space-2xl) 0 var(--space-lg);
}

.item__name-en{
    font-size:clamp(28px, calc(22.39px + 1.438vw), 50px);
    margin-bottom:var(--space-xl);

}

.item__sub-image{
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap:var(--space-lg);
    margin-top:var(--space-lg);
}

.item__cont{
    margin-top:var(--space-2xl);
}

.item__txt__wrapper{
    display: grid;
    gap:var(--space-md);
    margin-bottom:var(--space-2xl);
}

.item__name{
    font-weight: 600;
    font-size: var(--font-copy);
    line-height: var(--line-heading);
}

.item__txt{
    font-size:var(--font-body);
    line-height: var(--line-body);
}

.item__price{
    font-size:var(--font-sub-copy);
    font-weight: 600;
}

.item__btn{
    background:var(--color-text);
    color:var(--color-base) !important;
    text-align: center;
    font-size:var(--font-copy);
    padding:var(--space-md);
    width:clamp(240px, calc(209.41px + 7.843vw), 360px);
    margin:0 auto;
}


.reco__item{
    padding:0 var(--space-xl);
    /* width: min(100% - var(--space-4xl), var(--container-max)); */
    margin-top:var(--space-3xl);
}

.item__reco-inner{
    border: 2px solid var(--color-primary-gy);
    padding:var(--space-2xl) var(--space-xl);
}

.reco__ttl{
    text-align: center;
}

.item__reco__image{
    margin:var(--space-lg) auto;
}

.reco__ttl p:first-child{
    font-size:clamp(20px, calc(14.9px + 1.307vw), 40px);
    margin-bottom:var(--space-sm);
}

.reco__ttl p:last-child{
    font-size:var(--font-sub-copy);
    font-weight: 500;
}






@media (min-width: 768px) {
.item__name-en{
    margin-bottom:var(--space-2xl);
}

.item__main-cont{
    display: grid;
    grid-template-columns: 1fr 50%;
    gap:0 var(--space-5xl);
}

.item__sub-image{
    gap:var(--space-2xl);
    margin-top:0;
}

.item__btn{
    padding:var(--space-md);
    margin:0;
}


.reco__item{
    padding:0 var(--space-4xl) 0 0;
}

.item__reco-inner{
    border: none;
    padding:0;
    display: flex;
    align-items: center;
    flex-direction: row-reverse;
}

.item__reco-cont{
    border-top:8px solid var(--color-primary-gy);
    border-bottom:8px solid var(--color-primary-gy);
    padding:var(--space-5xl) var(--space-4xl) var(--space-2xl);
    width:60%;
    position: relative;
}

.reco__ttl{
    width: fit-content;
    padding:0 20px;
    text-align: left;
    /* margin-top:-90px; */
    background:var(--color-primary-gr);
    position: absolute;
    top:calc(clamp(20px, calc(14.9px + 1.307vw), 40px) * -0.6);
    left:calc(var(--space-4xl) - 20px);
}

.item__reco__image{
    width:40%;
    margin:0;
}

.reco__ttl p:first-child{
    font-size:clamp(20px, calc(14.9px + 1.307vw), 40px);
    margin-bottom:var(--space-sm);
}


}

@media (min-width: 1920px) {

    .item__reco-cont{
    border-top:10px solid var(--color-primary-gy);
    border-bottom:10px solid var(--color-primary-gy);
}


.reco__item{
    padding:0 var(--space-8xl) 0 0;
}


.item__reco-cont{
    padding:var(--space-5xl) var(--space-8xl) var(--space-2xl);
}

.reco__ttl{
    left:calc(var(--space-8xl) - 20px);
}


}

/*NICI******************************/

.nici{
    background:#FFCFB5;
    padding:var(--space-7xl) 0;
    position: relative;
}

.nici::before,.nici::after{
    content:"";
}

.nici span,.nici::before,.nici::after{
    display: block;
    width:10px;
    height:10px;
    border-radius: 50%;
    background:var(--color-base);
    position: absolute;
}


.nici span:first-of-type{
    top:var(--space-xl);
    left:var(--space-xl);
}

.nici::before{
    top:var(--space-xl);
    right:var(--space-xl);
}

.nici span:last-of-type{
    bottom:var(--space-xl);
    left:var(--space-xl);
}

.nici::after{
    bottom:var(--space-xl);
    right:var(--space-xl);
}

.nici__cont{
    margin-top:var(--space-xl);
    display: grid;
    gap:var(--space-xl);
    overflow: hidden;
}

.nici__cont p:first-of-type{
    font-size:clamp(18px, calc(14.43px + 0.915vw), 32px);
    line-height: var(--line-heading);
    text-align: center;
}


.nici__cont p:last-of-type{
    font-size: var(--font-body);
    line-height: var(--line-body);
}

@media (min-width: 768px) {
    
.nici span,.nici::before,.nici::after{
    width:20px;
    height:20px;
}

.nici .l-container{
    display: grid;
    grid-template-columns: 40% 1fr;
    align-items: center;
    gap:var(--space-5xl);
}


.nici__cont{
    margin-top:0;
    gap:var(--space-2xl);
}

.nici__cont p:first-of-type{
    text-align: left;
}



}

/*lineup以降*******************************/
.btm__banner{
    padding:var(--space-6xl) 0;
    background:#fff;
}

.btm__banner__ttl-en{
    text-align: center;
    margin-bottom: var(--space-md);
    font-size: clamp(24px, calc(19.92px + 1.046vw), 40px);
}

.btm__banner__ttl{
    font-size: var(--font-body);
    text-align: center;
    margin-bottom:var(--space-3xl);
}

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

.btm__banner__lists li p{
    text-align: center;
    font-size:var(--font-body);
    line-height: var(--line-heading);
    margin-top:var(--space-sm);
}

.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-primary-gr);
    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) { 


}