/* /jp/mn/151130/assets/css/style.css
   天ぷらの素 5g 商品情報ページ
   影響範囲は .mn151130 の中だけに限定
*/

.mn151130{
  color:#24201c;
  line-height:1.9;
  letter-spacing:.02em;
  background:#fff;
}

.mn151130 *{
  box-sizing:border-box;
}

.mn151130 img{
  max-width:100%;
}

.mn151130 .l-container{
  max-width:980px;
  margin:0 auto;
  padding:0 16px;
}

.mn151130 [data-reveal]{
  opacity:0;
  transform:translateY(12px);
  transition:opacity .6s ease, transform .6s ease;
}

.mn151130 [data-reveal].is-inview{
  opacity:1;
  transform:translateY(0);
}

.mn151130 .sectionLabel{
  margin:0 0 8px;
  color:#a76517;
  font-size:12px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.mn151130 .sectionLabel--light{
  color:#f6c267;
}

.mn151130 .btn{
  display:inline-block;
  text-decoration:none;
  border-radius:999px;
  padding:10px 15px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  color:#2a241d;
  font-size:14px;
  transition:background .25s ease, color .25s ease, border-color .25s ease, transform .15s ease, box-shadow .15s ease;
}

.mn151130 .btn.primary,
.mn151130 .btn:hover{
  background:#d88919;
  color:#fff;
  border-color:#d88919;
  box-shadow:0 12px 26px rgba(216,137,25,.22);
  transform:translateY(-2px);
}

.mn151130 .btn.ghost{
  background:rgba(255,255,255,.7);
}

/* HERO */
.mn151130 .hero{
  padding:30px 0 20px;
  background:linear-gradient(135deg, #fff8e9 0%, #f6ead4 52%, #fff 100%);
  border-bottom:1px solid rgba(0,0,0,.08);
  overflow:hidden;
}

.mn151130 .hero__grid{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:20px;
  align-items:start;
}

.mn151130 .kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 10px;
  color:#76552a;
  font-size:13px;
}

.mn151130 .kicker .dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:#d88919;
  display:inline-block;
}

.mn151130 .hero__title{
  margin:0 0 12px;
  font-size:36px;
  line-height:1.14;
  letter-spacing:.03em;
}

.mn151130 .hero__title span{
  display:inline-block;
  font-size:.62em;
  color:#8a5b1d;
}

.mn151130 .hero__title small{
  display:block;
  margin-top:8px;
  font-size:15px;
  color:#6a5843;
  line-height:1.7;
}

.mn151130 .hero__lead{
  margin:0 0 14px;
  max-width:37em;
  color:#2f2a24;
  font-size:16px;
}

.mn151130 .hero__cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:14px 0;
}

.mn151130 .hero__bullets{
  margin:12px 0 0;
  padding-left:18px;
}

.mn151130 .hero__note{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:14px 0 0;
}

.mn151130 .tag{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(216,137,25,.24);
  background:rgba(216,137,25,.10);
  color:#7b4b11;
  font-size:12px;
}

.mn151130 .hero__collage{
  position:relative;
  min-height:520px;
  padding-left:36px;
}

.mn151130 .hero__spine{
  position:absolute;
  left:0;
  top:10px;
  bottom:10px;
  width:28px;
  border-right:1px solid rgba(0,0,0,.10);
  display:flex;
  align-items:center;
  justify-content:center;
}

.mn151130 .hero__spine span{
  writing-mode:vertical-rl;
  letter-spacing:.16em;
  color:rgba(0,0,0,.48);
  font-size:12px;
}

.mn151130 .shot{
  position:absolute;
  margin:0;
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 18px 44px rgba(0,0,0,.12);
}

.mn151130 .shot img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.mn151130 .shot figcaption{
  padding:8px 10px;
  background:rgba(255,255,255,.88);
  border-top:1px solid rgba(0,0,0,.06);
  color:#6b5a4d;
  font-size:12px;
}

.mn151130 .shot--main{
  left:36px;
  top:0;
  width:min(520px,100%);
  height:360px;
  transform:rotate(-.7deg);
  z-index:2;
}

.mn151130 .shot--pack{
  right:-88px;
  bottom:60px;
  width:250px;
  height:300px;
  border-radius:0;
  transform:rotate(1.2deg);
  z-index:3;
}

/* BAND */
.mn151130 .band{
  padding:44px 0;
}

.mn151130 .band__head h2,
.mn151130 .howto h2,
.mn151130 .feature h2,
.mn151130 .spec h2{
  margin:0 0 10px;
  font-size:24px;
  line-height:1.35;
}

.mn151130 .band__head .sub{
  margin:0 0 18px;
  color:rgba(0,0,0,.68);
}

.mn151130 .band--warm{
  background:#fff;
}

.mn151130 .band--paper{
  background:#faf5ec;
  border-top:1px solid rgba(0,0,0,.06);
  border-bottom:1px solid rgba(0,0,0,.06);
}

.mn151130 .band--feature{
  background:#fffdf8;
}

.mn151130 .band--dark{
  background:#201914;
  color:#f7f0e6;
}

.mn151130 .band__head--light .sub{
  color:rgba(247,240,230,.74);
}

/* cards */
.mn151130 .cards{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

.mn151130 .card{
  position:relative;
  overflow:hidden;
  min-height:210px;
  padding:18px 16px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  box-shadow:0 14px 30px rgba(0,0,0,.06);
}

.mn151130 .card__num{
  display:block;
  margin:0 0 16px;
  color:rgba(216,137,25,.33);
  font-size:34px;
  font-weight:700;
  line-height:1;
}

.mn151130 .card h3{
  margin:0 0 8px;
  font-size:17px;
}

.mn151130 .card p{
  margin:0 0 8px;
}

.mn151130 .card .mini{
  margin:0;
  color:rgba(0,0,0,.60);
  font-size:12px;
}

/* howto */
.mn151130 .howto{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  gap:18px;
  align-items:start;
}

.mn151130 .howto__lead{
  margin:0 0 14px;
  color:rgba(0,0,0,.72);
}

.mn151130 .steps{
  display:grid;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}

.mn151130 .steps li{
  display:flex;
  gap:12px;
  padding:14px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:15px;
  background:#fff;
  box-shadow:0 12px 26px rgba(0,0,0,.05);
}

.mn151130 .steps .num{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:999px;
  background:#d88919;
  color:#fff;
  font-weight:700;
}

.mn151130 .steps .body h3{
  margin:0 0 4px;
  font-size:16px;
}

.mn151130 .steps .body p{
  margin:0;
}

.mn151130 .howto__figure{
  margin:0;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.10);
  border-radius:18px;
  background:#fff;
  box-shadow:0 18px 40px rgba(0,0,0,.08);
}

.mn151130 .howto__figure img{
  display:block;
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}

.mn151130 .tips{
  margin-top:14px;
  padding:14px;
  background:#fff;
  border:1px dashed rgba(0,0,0,.24);
  border-radius:15px;
}

.mn151130 .tips h3{
  margin:0 0 8px;
  font-size:16px;
}

.mn151130 .tips ul{
  margin:0;
  padding-left:18px;
}

/* feature */
.mn151130 .feature{
  display:grid;
  grid-template-columns:minmax(0,1fr) 300px;
  gap:18px;
  align-items:center;
}

.mn151130 .feature__text{
  padding:22px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(0,0,0,.07);
  box-shadow:0 14px 30px rgba(0,0,0,.05);
}

.mn151130 .feature__text p:last-child{
  margin-bottom:0;
}

.mn151130 .feature__memo{
  padding:20px;
  border-radius:18px;
  background:#2f241b;
  color:#fff7ec;
}

.mn151130 .memoTitle{
  margin:0 0 10px;
  color:#f6c267;
  font-weight:700;
}

.mn151130 .feature__memo ul{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:0;
  padding:0;
  list-style:none;
}

.mn151130 .feature__memo li{
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  font-size:13px;
}

/* recipes */
.mn151130 .recipeGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

.mn151130 .recipeCard__link{
  display:block;
  height:100%;
  color:inherit;
  text-decoration:none;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  box-shadow:0 20px 48px rgba(0,0,0,.30);
  transition:transform .18s ease, box-shadow .18s ease;
}

.mn151130 .recipeCard__link:hover{
  transform:translateY(-2px);
  box-shadow:0 26px 60px rgba(0,0,0,.36);
}

.mn151130 .recipeCard__photo{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#f3eadc;
}

.mn151130 .recipeCard__photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.mn151130 .badge2{
  position:absolute;
  left:10px;
  top:10px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(216,137,25,.94);
  color:#fff;
  font-size:12px;
}

.mn151130 .recipeCard__body{
  padding:15px 15px 17px;
}

.mn151130 .recipeCard__serves{
  margin:0 0 4px;
  color:rgba(247,240,230,.70);
  font-size:12px;
}

.mn151130 .recipeCard__body h3{
  margin:0 0 6px;
  font-size:17px;
}

.mn151130 .recipeCard__body .meta{
  margin:0 0 8px;
  color:rgba(247,240,230,.75);
  font-size:13px;
}

.mn151130 .recipeCard__body .desc{
  margin:0 0 10px;
  color:rgba(247,240,230,.92);
}

.mn151130 .recipeCard__body .go{
  margin:0;
  color:rgba(247,240,230,.94);
  font-size:13px;
  text-decoration:underline;
  text-underline-offset:3px;
}

.mn151130 .note{
  margin-top:14px;
  font-size:13px;
}

.mn151130 .note--light{
  color:rgba(247,240,230,.70);
}

/* spec */
.mn151130 .band--spec{
  background:#fff;
}

.mn151130 .spec{
  display:grid;
  grid-template-columns:260px minmax(0,1fr);
  gap:18px;
  align-items:start;
}

.mn151130 .specList{
  margin:0;
  border-top:1px solid rgba(0,0,0,.10);
}

.mn151130 .specList div{
  display:grid;
  grid-template-columns:140px minmax(0,1fr);
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid rgba(0,0,0,.10);
}

.mn151130 .specList dt{
  font-weight:700;
  color:#6b5130;
}

.mn151130 .specList dd{
  margin:0;
}

.mn151130 .specNote{
  grid-column:2;
  margin:0;
  color:rgba(0,0,0,.62);
  font-size:13px;
}

/* end */
.mn151130 .band--end{
  background:#fbf2e2;
  border-top:1px solid rgba(0,0,0,.08);
}

.mn151130 .end__copy{
  margin:0;
  font-size:19px;
  line-height:1.8;
}

.mn151130 .end__mini{
  margin:8px 0 0;
  font-size:13px;
}

.mn151130 .end__mini a{
  color:#6c4412;
}

/* アンカーずれ対策 */
#points,
#howto,
#recipes{
  scroll-margin-top:120px;
}

@media (max-width:980px){
  .mn151130 .hero__grid{
    grid-template-columns:1fr;
  }

  .mn151130 .hero__collage{
    min-height:500px;
  }

  .mn151130 .shot--main{
    left:36px;
    right:0;
    width:calc(100% - 36px);
    height:340px;
  }

  .mn151130 .shot--pack{
    right:10px;
    bottom:80px;
    width:230px;
    height:280px;
  }
}

@media (max-width:900px){
  .mn151130 .cards,
  .mn151130 .howto,
  .mn151130 .feature,
  .mn151130 .recipeGrid,
  .mn151130 .spec{
    grid-template-columns:1fr;
  }

  .mn151130 .specNote{
    grid-column:auto;
  }
}

@media (max-width:640px){
  .mn151130 .hero__title{
    font-size:30px;
  }

  .mn151130 .hero__collage{
    min-height:420px;
    padding-left:0;
  }

  .mn151130 .hero__spine{
    display:none;
  }

  .mn151130 .shot--main{
    left:0;
    width:100%;
    height:285px;
  }

  .mn151130 .shot--pack{
    right:8px;
    bottom:38px;
    width:170px;
    height:210px;
  }

  .mn151130 .band{
    padding:34px 0;
  }

  .mn151130 .specList div{
    grid-template-columns:1fr;
    gap:2px;
  }
}
