/* lead */
#lead {
    position: relative;
    padding: 15vw 0 7vw;
}
#lead h2 {
    font-size: 6vw;
    text-align: left;
    margin-bottom: 8vw;
    line-height: 1.6;
    letter-spacing: 0.1em;
    padding-top:80px;
}
#lead h2 span {
    font-size: 13vw;
    text-align: right;
    margin-bottom: 6vw;
    color: #5f461c;
    display: block;
    line-height: 0.9;
    letter-spacing: 0em;
}
#lead .photo {
    margin: 0 -4% 7vw -11%;
}
#lead .txt {
    margin-bottom: 3vw;
}
#lead .deco1 {
    position: absolute;
    left: 0;
    bottom: 94vw;
    width: 90%;
    z-index: -1;
}
@media only screen and (min-width: 768px) {
    #lead {
        padding: 40px 0 26px;
    }
    #lead .wrap {
        width: 1240px;
        padding: 0 20px;
    }
    #lead h2 {
        font-size: 30px;
        margin-bottom: 43px;
        width: 500px;
        margin-left: auto;
        letter-spacing: 4px;
    }
    #lead h2 span {
        font-size: 66px;
        margin-bottom: 55px;
        letter-spacing: 2px;
    }
    #lead .photo {
        margin: 0;
        position: absolute;
        left: calc(50% - 50vw);
        top: 72px;
        margin-left: -73px;
        right: 560px;
        height: 556px;
    }
    #lead .txt {
        margin-bottom: 110px;
        width: 500px;
        margin-left: auto;
    }
    #lead .deco1 {
        bottom: -202px;
        width: auto;
        left: calc(50% - 50vw);
        margin-left: -150px;
    }
}


/* ingredients */
#ingredients {
    position: relative;
    padding: 7vw 0 2vw;
}
#ingredients::before {
    content: "";
    background: url("../img/concept/ingredients_deco2.png") no-repeat;
    width: 100%;
    height: 170vw;
    position: absolute;
    top: -45vw;
    right: -39%;
    background-size: 100%;
    z-index: -1;
}
#ingredients::after {
    content: "";
    background: url("../img/concept/ingredients_deco3.png") no-repeat;
    width: 100%;
    height: 90vw;
    position: absolute;
    top: 35vw;
    right: 0;
    background-size: 100%;
    z-index: -1;
}
#ingredients .js {
    position: relative;
    margin: 0 -5% 7vw 3%;
}
#ingredients .js .slick-dots {
    position: absolute;
    display: flex !important;
    flex-direction: column;
    left: -11%;
}
#ingredients .col .ttl {
    font-size: 8vw;
    color: #5f461c;
    position: relative;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    align-items: center;
    margin-bottom: 7vw;
}
#ingredients .col .ttl::after {
    position: absolute;
    bottom: 1vw;
    left: 0;
    right: 0;
    height: 2px;
    border-bottom: 2px solid #9D5C2C;
    content: "";
}
#ingredients .col .ttl span {
    font-size: 6vw;
    margin-right: 5%;
}
#ingredients .col h2 {
    font-size: 7vw;
    line-height: 1.6;
    text-align: center;
    margin-bottom: 6vw;
}
#ingredients .col h2 span {
    position: relative;
}
#ingredients .col h2 span::after {
    content: "";
    background: url("../img/concept/ingredients_deco.png") no-repeat;
    width: 100%;
    height: 50vw;
    position: absolute;
    top: 51%;
    right: 0;
    background-size: 100%;
    z-index: -1;
}
@media only screen and (min-width: 768px) {
    #ingredients {
        padding: 33px 0 133px;
    }
    #ingredients::before {
        width: 607px;
        height: 651px;
        top: -330px;
        right: calc(50% - 50vw);
        margin-right: -120px;
    }
    #ingredients::after {
        width: 755px;
        height: 5498px;
        top: 280px;
        right: calc(50% - 50vw);
    }
    #ingredients .js {
        margin: 0;
        position: absolute;
        left: 450px;
        top: -20px;
        width: 700px;
    }
    #ingredients .js .slick-dots {
        left: -42px;
        bottom: 5px;
    }
    #ingredients .col .ttl {
        font-size: 30px;
        margin-bottom: 61px;
        margin-left: -13px;
        letter-spacing: 1px;
    }
    #ingredients .col .ttl::after {
        bottom: 4px;
        left: -110px;
        right: auto;
        width: 380px;
    }
    #ingredients .col .ttl span {
        font-size: 24px;
        margin-right: 20px;
        margin-top: -10px;
    }
    #ingredients .col h2 {
        font-size: 40px;
        margin-bottom: 66px;
        width: 280px;
        letter-spacing: 5px;
    }
    #ingredients .col h2 span::after {
        top: 42px;
    }
    #ingredients .col .txt {
        width: 331px;
    }
}


/* scratch */
#scratch {
    position: relative;
    padding: 15vw 0 0vw;
	margin-bottom: -27vw;
}
#scratch .js {
    margin-bottom: 6vw;
    margin: 0 -10.6% 6vw;
}
#scratch .js li p {
    width: 250px;
    margin: 0 10px;
}
#scratch .col .ttl {
    font-size: 7vw;
    color: #5f461c;
    position: relative;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    align-items: center;
    margin-bottom: 7vw;
}
#scratch .col .ttl::after {
    position: absolute;
    bottom: 1vw;
    left: 0;
    right: 0;
    height: 1px;
    border-bottom: 2px solid #9D5C2C;
    content: "";
}
#scratch .col .ttl span {
    font-size: 6vw;
    margin-right: 5%;
}
#scratch .col h2 {
    font-size: 7vw;
    line-height: 1.6;
    text-align: center;
    margin-bottom: 6vw;
}
#scratch .col h2 span {
    position: relative;
}
#scratch .col h2 span::after {
    content: "";
    background: url("../img/concept/ingredients_deco4.png") no-repeat;
    width: 166%;
    height: 50vw;
    position: absolute;
    top: -46%;
    right: -48%;
    background-size: 100%;
    z-index: -1;
}
@media only screen and (min-width: 768px) {
    #scratch {
        padding: 20px 0 20px;
		margin-bottom: 0;
    }
    #scratch .wrap {
        width: 1240px;
        padding: 0 20px;
    }
    #scratch .js {
        margin-bottom: 20px;
        margin: 0;
        position: absolute;
        left: calc(50% - 50vw);
        right: 470px;
        top: -20px;
    }
    #scratch .js li p {
        width: 383px;
        margin: 0 2px;
    }
    #scratch .col {
        margin-left: auto;
        width: 377px;
    }
    #scratch .col .ttl {
        font-size: 30px;
        margin-bottom: 60px;
        letter-spacing: 1px;
    }
    #scratch .col .ttl::after {
        bottom: 4px;
        right: -50px;
    }
    #scratch .col .ttl span {
        font-size: 24px;
        margin-right: 20px;
    }
    #scratch .col h2 {
        font-size: 40px;
        margin-bottom: 60px;
        letter-spacing: 5px;
        text-align: left;
        width: 390px;
        margin-left: 30px;
        line-height: 69px;
    }
    #scratch .col h2 span {
        margin-left: 23px;
    }
    #scratch .col h2 span::after {
        top: -40px;
        left: 20px;
    }
    #scratch .col .txt {
        margin-left: 43px;
    }
}




/* scratch */
#scratch .set1 {
    position: relative;
    padding: 0vw 0 4vw;
    top:-30vw;
}
#scratch .set1 .photo-wrap {
    width: 100vw;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    margin-bottom: 10vw;
}
#scratch .set1 .photo-zoom {
    position: relative;
    text-align: center;
    width: 35%;
    height: 30%;
}
#scratch .set1 .photo-zoom .item {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
    width: 100%;
    height: 100%;
    display: inline-block;
    transition: opacity 0.5s;
}
#scratch .set1 .photo-zoom .item.active {
    opacity: 1;
}
#scratch .set1 .photo-zoom .item img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}
@media only screen and (min-width: 768px) {
    #scratch .set1 {
        padding: 20px 0 20px;
        top:0;
    }
    #scratch .set1 .wrap {
        width: 1240px;
        padding: 0 20px;
    }
    #scratch .set1 .photo-wrap {
        margin-bottom: 80px;
    }
    #scratch .set1 .photo-zoom {
        width: 55%;
        height: 45%;
	}
}

/* special */
#special .set1 {
    position: relative;
    padding: 0vw 0 4vw;
   
}
#special .set1 h2 {
    font-size: 8vw;
    text-align: center;
    margin-bottom: 8vw;
    line-height: 1.6;
}
#special .set1 h2 span {
    font-size: 13vw;
    text-align: center;
    display: block;
    margin-bottom: 5vw;
    color: #5f461c;
}
#special .set1 .txt {
    margin-bottom: 8vw;
}
#special .set1 .group .left {
       margin-bottom: 3vw;
    margin-left: -3%;
    margin-right: 5%;
}
#special .set1 .group .left  .slick-dots {
    position: absolute;
    display: flex !important;
    flex-direction: column;
    right: -11%;
    left: auto;
    width: 9%;
}
#special .set1 .group .left .photo {
    position: relative;
}
#special .set1 .group .left .photo .ttl {
    position: absolute;
    bottom: 5%;
    right: 5%;
    color: #fff;
    z-index: 5;
    text-align: right;
    line-height: 25px;
    font-size: 13px;
	text-shadow: 0px 0px 10px #000,0px 0px 10px #000;
}
#special .set1 .group .right {
    position: relative;
}
#special .set1 .group .right::after {
    content: "";
    background: url("../img/concept/special_deco2.png") no-repeat;
    width: 90%;
    height: 110vw;
    position: absolute;
    top: -11vw;
    right: -25%;
    background-size: 100%;
    z-index: -1;
}
#special .set1 .group .right .deco {
    width: 22%;
    margin-left: auto;
    margin-bottom: 26vw;
    position: relative;
    z-index: 5;
}
#special .set1 .group .right .deco2 {
    position: absolute;
    right: 0;
    top: 12vw;
}
#special .set1 .group .right h3 {
    font-size: 7vw;
    padding-top: 10vw;
    position: relative;
    margin-bottom: 6vw;
    line-height: 1.5;
	text-align: center;
}
#special .set1 .group .right h3::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    width: 2px;
    height: 20px;
    background: #5f461c;
}
#special .set2 {
    position: relative;
    padding: 10vw 0 5vw;
}
#special .set2 h3 {
    font-size: 7vw;
    line-height: 1.8;
    text-align: center;
    margin: 0 -2% 6vw;
    white-space: nowrap;
    position: relative;
}
#special .set2 h3::before {
    content: "";
    position: absolute;
    top: -9vw;
    left: 0;
    right: 0;
    border-left: 7px double;
    height: 18px;
    margin: 0 auto;
    width: 20px;
}
#special .set2 .txt {
    margin-bottom: 6vw;
}
#special .set2 .list-img {
    margin: 0;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 -5.6% 6vw;
}
#special .set2 .list-img .img {
    width: 45%;
    margin: 0 auto 6vw;
    position: relative;
    max-width: 45%;
}
#special .set2 .list-img .img span {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 5;
    color: #fff;
    background: #000;
    padding: 2px 15px;
}

@media only screen and (min-width: 768px) {
    #special .set1 {
        padding: 20px 0 20px;
        top:0;
    }

    #special .set1 h2 {
        font-size: 36px;
        margin-bottom: 85px;
    }
    #special .set1 h2 i {
        font-size: 48px;
    }
    #special .set1 h2 span {
        font-size: 80px;
        margin-bottom: 20px;
    }
    #special .set1 h2 small {
        font-size: 36px;
    }
    #special .set1 .txt {
        margin-bottom: 134px;
        text-align: center;
    }
    #special .set1 .group .left {
        margin-bottom: 20px;
        position: absolute;
        left: calc(50% - 50vw);
        right: calc(50% - 74px);
    }
    #special .set1 .group .left .photo .ttl {
        line-height: 36px;
        font-size: 20px;
        bottom: 30px;
        right: 22px;
        letter-spacing: -1px;
		text-shadow: none;
    }
    #special .set1 .group .left .photo .img {
        height: 900px;
    }
	#special .set1 .group .left .slick-dots{
	    bottom: 8px;
	}
    #special .set1 .group .right {
        width: 400px;
        margin-left: auto;
        padding-top: 80px;
    }
    #special .set1 .group .right::after {
        top: 80px;
        right: -370px;
        width: 615px;
        height: 630px;
    }
    #special .set1 .group .right .deco {
        margin-bottom: -25px;
        width: 140px;
        margin-right: -40px;
    }
    #special .set1 .group .right .deco2 {
        position: static;
        margin-bottom: 73px;
    }
    #special .set1 .group .right h3 {
        font-size: 30px;
        padding-top: 88px;
        margin-bottom: 51px;
        line-height: 54px;
        letter-spacing: 2px;
		text-align: left;
    }
    #special .set1 .group .right h3::before {
        left: 7px;
        height: 30px;
    }
    #special .set1 .group .right .txt {
        text-align: left;
    }
    #special .set2 {
        padding: 107px 0 157px;
    }
    #special .set2 .wrap {
        width: 1240px;
        padding: 0 20px;
    }
    #special .set2 h3 {
        font-size: 36px;
        margin: 0;
        letter-spacing: 2px;
        margin-bottom: 56px;
    }
    #special .set2 h3::before {
        top: -66px;
        height: 33px;
        width: 0px;
        border-width: 10px;
    }
    #special .set2 .txt {
        margin-bottom: 99px;
        text-align: center;
    }
    #special .set2 .list-img {
    margin: 0;
}
    #special .set2 .list-img .img {
        margin: 0;
        width: 579px;
        margin-bottom: 28px;
        max-width: 49%;
    }
    #special .set2 .list-img .img span {
        padding: 2px 20px;
    }
}