@charset "UTF-8";
/* CSS Document */
.contents_inner {
    display: block;
    padding-top: 120px;
    margin-top: -120px;
}
.normal{font-weight: normal;}
/* PC版 w560以上に適応するcss ****************************************************************** */
/* PC版 w560以上に適応するcss ****************************************************************** */
/* PC版 w560以上に適応するcss ****************************************************************** */
/* PC版 w560以上に適応するcss ****************************************************************** */
/* PC版 w560以上に適応するcss ****************************************************************** */
/* PC版 w560以上に適応するcss ****************************************************************** */
.body {
	  margin: 0 auto;
      background-attachment: fixed;
	  min-height: 100vh;
	  background-size: cover;
		font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
 }
.sp1 {	width: 100%;
		margin: 0px auto;
		border-radius: 0px;
		box-shadow: 0px 0px 0px 0px;
		display: block;
		position: relative;
 }
.sp {
		width: 40%;
		margin: 0px auto;
		display: block;
		overflow: hidden;
		background-color: #fff;
		position: relative;
 }

/* ;;;;;;;; 共通項目 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; */
/* ;;;;;;;; 共通項目 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; */
a {
	text-decoration: none;	
}
p{text-align: justify;}
.overimg:hover {
	opacity: 0.5;
}
.sponly {
	display:none;
}
.spnone {
	display:block;
}
h1{font-size: 0.7em;font-weight: normal;padding: 0.2em;line-height: 1.14em;background-color: #ed6f00;margin: 0;color: #ffffff;}
h4,p{margin: 0;}
h4{margin-left: -0.5em;margin-top: 1em;}
.img100{width: 100%;vertical-align: bottom;}
.head img{vertical-align: bottom;}


/*-- section_01 --*/
.section_01{background-image: url("../img/sec_01_img_02.webp");background-size: contain;background-position: top;background-repeat:no-repeat;position: relative; z-index: 10;margin: 0;padding:1em 0 3em}
.mt-5per{margin-top: -3%;}

.w90per {
	width: 90%;
	display: block;
	margin: 0 auto;
	padding: 0px;
}
/* フレックスボックス */
.flexbox{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content:space-between;
  	flex-wrap: wrap;
	width: 100%;
	margin: 0 auto;}
.flexbox::after{
  content:"";
  display: block;
  width:31%;}
.box-item03{width: 31%;display: inline-block;margin:1% 0 3%;height: auto;}
.box-item03 img{width: 100%;}
.shadow{filter: drop-shadow(4px 4px 5px  rgba(192, 81, 29, 0.32));}
/*-- section_02 --*/
.section_02{background-image: url("../img/sec_02_back.webp");background-size: cover;background-position: top center;background-repeat: no-repeat;position: relative; z-index: 10;padding: 2em 0 2em;margin: 2em;border-radius: 10px;filter: drop-shadow(4px 4px 5px  rgba(160, 160, 160, 0.32));}
.btn{display: block;margin: 1em auto;width: 80%;}

/*-- section_03 --*/
.section_03{background-image: url("../img/sec_03_back.webp");background-size: cover;background-position: top center;background-repeat: no-repeat;position: relative; z-index: 10;padding: 2em 0 2em;margin: 2em;border-radius: 10px;filter: drop-shadow(4px 4px 5px  rgba(160, 160, 160, 0.32));}


/*-- section_04 --*/
.section_04{background-image: url("../img/sec_04_back.webp");background-size: cover;background-position: top center;background-repeat: no-repeat;position: relative; z-index: 10;padding: 2em 0 2em;margin: 1em 2em;border-radius: 10px;filter: drop-shadow(4px 4px 5px  rgba(160, 160, 160, 0.32));}



@media screen and (max-width: 1000px) {.sp{width:60%;margin:0px auto;border-radius:0px;box-shadow: 0px 0px 0px 0px;display: block;padding-top: 0px;}}

/* スマホ版 w560以下に適応するcss *************************************************************** */
/* スマホ版 w560以下に適応するcss *************************************************************** */
/* スマホ版 w560以下に適応するcss *************************************************************** */
/* スマホ版 w560以下に適応するcss *************************************************************** */
/* スマホ版 w560以下に適応するcss *************************************************************** */
/* スマホ版 w560以下に適応するcss *************************************************************** */


@media screen and (max-width: 640px) {
/* ;;;;;;;; 共通項目 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; */
/* ;;;;;;;; 共通項目 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; */
.body {padding-top: 0px;}
.sp{width:100%;margin:0px auto;border-radius:0px;box-shadow: 0px 0px 0px 0px;display: block;padding-top: 0px;}

.sponly {
	display:block;
}

.spnone {
	display:none;
}

}


.faq-section {
      max-width: 100%;
      margin: 0 auto;
      padding: 30px 24px 30px;
		background-color: #fef4f5;
		box-sizing: border-box;
    }

    .faq-heading {
      text-align: center;
      margin-bottom: 30px;
    }

    .faq-heading .en {
      display: block;
      font-size: 2em;
      color: #e65b7d;
      line-height: 1.2;
      margin-bottom: 0px;
      font-family: serif;
    }

    .faq-heading .ja {
      display: block;
      font-size: 1.4em;
      color: #e65b7d;
      line-height: 1.2;
      font-weight: 500;
    }

    .faq-list {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .faq-item {
      border-bottom: 1px solid #eb7b92;
      padding-bottom: 10px;
    }
.faq-last {
      border-bottom: none;
      padding-bottom: 26px;
    }

    .faq-question {
      width: 100%;
      border: none;
      background: #ea718b;
      color: #fff;
      border-radius: 10px;
      padding: 13px 20px 12px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      cursor: pointer;
      text-align: left;
      transition: opacity 0.25s ease;
    }

    .faq-question:hover {
      opacity: 0.92;
    }

    .faq-question-left {
      display: flex;
      align-items: center;
      gap: 10px;
      min-width: 0;
    }

    .faq-q {
      font-size: 2.2em;
      font-weight: 500;
      line-height: 1;
      flex-shrink: 0;
    }

    .faq-question-text {
      font-size: 1.4em;
      font-weight: 700;
      line-height: 1.3;
      letter-spacing: 0.02em;
    }
@media screen and (max-width: 640px) {
	.faq-question-text {
      font-size: 1.3em;
    }
}
    .faq-icon {
  font-size: 26px;
		width: 26px;
  color: #fff;
  transition: transform 0.3s ease;
		transform: rotate(180deg);
}

/* 開いたときに下向き */
.faq-item.active .faq-icon {
  transform: rotate(360deg);
}

   

    .faq-answer-wrap {
      display: grid;
      grid-template-rows: 0fr;
      transition: grid-template-rows 0.35s ease;
    }

    .faq-item.active .faq-answer-wrap {
      grid-template-rows: 1fr;
    }

    .faq-answer-inner {
      overflow: hidden;
    }

    .faq-answer {
      display: flex;
      align-items: flex-start;
      gap: 15px;
      padding: 18px 18px 0 10px;
    }

    .faq-a {
      font-size:1.74em;
      font-weight: 700;
      line-height: 1;
      color: #d83131;
      flex-shrink: 0;
      margin-left: 6px;
      margin-top: 2px;
    }

    .faq-answer-text {
      font-size: 1.0em;
      line-height: 1.6;
      color: #2f3740;
      letter-spacing: 0.02em;
		text-align: justify;
    }

    
	  
    .voice-section {
      max-width: 100%;
      margin: 0 auto;
      padding: 30px 24px 30px;
		background: #f3ece5;
      color: #333b40;
		box-sizing: border-box;
    }

    .voice-heading {
      text-align: center;
      margin-bottom: 30px;
      color: #ef6c00;
    }

    .voice-heading .en {
      display: block;
      font-family: serif;
      font-size: 2em;
      line-height: 1.1;
      margin-bottom: 0px;
      font-weight: 500;
      letter-spacing: 0.03em;
    }

    .voice-heading .ja {
      display: block;
      font-size: 1.4em;
      line-height: 1.2;
      font-weight: 500;
      letter-spacing: 0.02em;
    }

    .voice-list {
      display: flex;
      flex-direction: column;
      gap: 20px;
    }

    .voice-card {
      display: block;
      align-items: center;
      gap: 0px;
      background: #f8f8f8;
      border-radius: 10px;
      padding: 18px 20px;
      box-shadow: 8px 10px 14px rgba(176, 106, 74, 0.28);
    }

    .voice-profile {
      width: 90px;
      flex-shrink: 0;
      text-align: center;
    }

    .voice-icon {
      width: 90px;
      height: 90px;
      margin: 0 auto 10px;
      display: block;
      color: #ef7a00;
    }

    .voice-meta {
      font-size: 0.84em;
      line-height: 1.0;
      color: #394146;
      white-space: nowrap;
		margin-top: 0.4em;
    }

    .voice-text {
      flex: 1;
      font-size: 0.94em;
      line-height: 1.3;
      color: #394146;
      letter-spacing: 0.02em;
		text-align: justify;
    }


	  
	.ingredients-section {
      max-width: 100%;
      margin: 0 auto;
      padding: 42px 28px 240px;
    }

    .section-title {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 1.4em;
      font-weight: 700;
      line-height: 1.4;
      color: #1f343b;
      margin: 0 0 15px;
    }

    .section-title::before {
      content: "";
      width: 18px;
      height: 18px;
      background: #1f343b;
      flex-shrink: 0;
    }

    .ingredients-list {
      display: flex;
      flex-direction: column;
      gap: 18px;
      margin-bottom: 25px;
    }

    .ingredient-box {
      border-top: 1px solid #bdb6b2;
      border-bottom: 1px solid #bdb6b2;
      background: transparent;
    }

    .ingredient-row {
      display: grid;
      grid-template-columns: 90px 1fr;
    }

    .ingredient-row + .ingredient-row {
      border-top: 1px solid #bdb6b2;
    }

    .ingredient-label {
      background: #d8d2d0;
      padding: 10px;
      font-size: 0.84em;
      font-weight: 700;
      line-height: 1.4;
      color: #22343b;
    }

    .ingredient-value {
      background: #f5f5f5;
      padding: 10px;
      font-size: 0.74em;
      line-height: 1.6;
      color: #2d3d43;
      word-break: break-word;
    }

    .ingredient-name {
      font-size: 0.84em;
      font-weight: 700;
      line-height: 1.4;
    }

    .info-block {
      margin-top: 10px;
    }

    .info-title {
      display: flex;
      align-items: center;
      gap: 5px;
      font-size: 0.84em;
      font-weight: 700;
      line-height: 1.4;
      color: #1f343b;
      margin: 0 0 3px;
    }

    .info-title::before {
      content: "";
      width: 13px;
      height: 13px;
      background: #1f343b;
      flex-shrink: 0;
    }

    .info-text {
      margin: 0;
      padding-left: 24px;
      font-size: 0.84em;
      line-height: 1.4;
      color: #2d3d43;
    }

