@charset "UTF-8";

.our_matcha_wrap {
  background: #F4F4F1;
}

.our_matcha_wrap.archive .container {
  max-width: 1040px;
}

.our_matcha_mv,
.our_matcha_soil,
.our_matcha_content {
  font-family: "Noto Sans JP", sans-serif;
}

.our_matcha_mv {
  padding: 60px 0 80px;
}

.our_matcha_mv_upper {
  display: flex;
  align-items: center;
  margin-bottom: -80px;
}

.our_matcha_mv_img {
  margin-left: calc(50% - 50vw);
}

.our_matcha_mv_img img {
  width: 50vw;
  height: auto;
  object-fit: cover;
}

.our_matcha_mv_txt {
  flex: 1;
  padding: 80px 120px 80px 0;
}

.our_matcha_mv_ttl {
  font-family: "Noto Serif JP", serif;
  font-size: 56px;
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: 24px;
  color: #477141;
}

.our_matcha_mv_sub {
  font-family: "Noto Serif JP", serif;
  font-size: 31px;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 20px;
}

.our_matcha_mv_desc,
.our_matcha_txt,
.our_matcha_feature_ttl,
.our_matcha_feature_list li {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 2;
}

.our_matcha_mv_lower {
  width: 100dvw;
  margin-left: calc(50% - 50dvw);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  overflow: hidden;
}

.our_matcha_mv_card img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.our_matcha_mv_card {
  padding: 8px;
}

.our_matcha_soil {
  padding: 0 0 80px;
}

.our_matcha_heading {
  border-top: 4px solid #477141;
  border-bottom: 1px solid #83aa66;
  padding: 18px 0 16px;
  margin-bottom: 32px;
}

.our_matcha_heading_main {
  font-family: "Noto Serif JP", serif;
  font-size: 25px;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: normal;
  color: #477141;

}

html[lang="ja"] .our_matcha_heading_main {
  letter-spacing: 0.08em;
}

.our_matcha_line {
  border-bottom: 1px solid #cccccc;
  margin: 34px 0;
}

.our_matcha_feature {
  display: flex;
  gap: 48px;
  align-items: flex-start;
}


.our_matcha_feature_list {
  flex: 1;
}

.our_matcha_feature_list li {
  position: relative;
  padding-left: 16px;
}

.our_matcha_feature_list li::before {
  content: "";
  width: 5px;
  height: 5px;
  background: #000;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 0.9em;
}

.our_matcha_btn_wrap {
  margin-top: 30px;
}

.our_matcha_btn a {
  display: block;
  background: #DEE0D7;
  padding: 30px 56px 30px 24px;
  color: #000;
  position: relative;
  text-align: left;
  font-family: "Inter", sans-serif;
  font-size: 17px;
  font-weight: 500;
  letter-spacing: 0.01em;
  max-width: 360px;
  margin: 0 auto;
  line-height: 1;
}

.our_matcha_btn a::before {
  position: absolute;
  content: "";
  width: 45px;
  height: 20px;
  display: inline-block;
  background: url(../img/line_mark.svg) center/100% 100% no-repeat;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
}

.our_matcha_content {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  padding-bottom: 120px;
  overflow-x: hidden;
}

.our_matcha_block {
  display: flex;
  align-items: stretch;
}

.our_matcha_block + .our_matcha_block {
  margin-top: 80px;
}

/* 画像カラム：画面の半分 */
.our_matcha_block_img {
  flex: 0 0 50%;
  max-width: 50%;
}

/* テキストカラム：残り半分 */
.our_matcha_block_txt {
  flex: 1;
  display: flex;
  align-items: center;
  min-width: 0;
}

/* コンテナー幅（1040px）基準で左右の余白を確保し、テキストを収める */
.our_matcha_block_txt_inner {
  width: 100%;
  max-width: calc(1040px / 2);
}

/* block_01: 右テキスト — 左寄せにしてコンテナー左端に揃える */
.block_01 .our_matcha_block_txt {
  justify-content: flex-start;
}

.block_01 .our_matcha_block_txt_inner {
  margin-left: 0;
  padding-left: 60px;
  padding-right: 20px;
}

/* block_02: 左テキスト — 右寄せにしてコンテナー右端に揃える */
.block_02 .our_matcha_block_txt {
  justify-content: flex-end;
}

.block_02 .our_matcha_block_txt_inner {
  margin-right: 0;
  padding-right: 60px;
  padding-left: 20px;
} 

.img_split .img_l {
  padding: 8px;
}

.img_split .img_l img {
  width: 100%;
  height: 400px;
  object-fit: cover;
}

.img_s_wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.img_s {
  padding: 8px;
}

.img_s img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.img_single p {
  padding: 8px;
}

.img_single img {
  width: 100%;
  height: 400px;
  object-fit: cover;
}

.our_matcha_block_sub {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 6px;
  color: #477141;
}

.contents_mv.no_img .mv_inner {
  padding: 0;
  background: none;
}

@media screen and (max-width: 767px) {
  .pankuzu {
    display: none;
  }

  .our_matcha_mv {
    padding: 36px 0 52px;
  }

  .our_matcha_mv_upper {
    display: block;
    margin-bottom: 24px;
  }

  .our_matcha_mv_img {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-bottom: 20px;
  }

  .our_matcha_mv_img img {
    width: 100%;
    height: auto;
  }

  .our_matcha_mv_ttl {
    font-size: 40px;
    margin-bottom: 14px;
  }

  .our_matcha_mv_txt {
    padding: 0 24px 0 24px;
  }

  .our_matcha_mv_sub {
    font-size: 24px;
    margin-bottom: 14px;
  }

  .our_matcha_mv_desc {
    font-size: 16px;
  }

  .our_matcha_mv_lower {
    grid-template-columns: 1fr;
  }

  .our_matcha_mv_card img {
    height: 240px;
  }

  .our_matcha_mv_card {
    padding: 6px 8px;
  }

  .our_matcha_soil {
    padding-bottom: 64px;
  }

  .our_matcha_heading {
    margin-bottom: 20px;
    padding: 12px 0;
  }

  .our_matcha_heading_main {
    font-size: 26px;
  }

  .our_matcha_line {
    margin: 24px 0;
  }

  .our_matcha_feature {
    display: block;
  }

  .our_matcha_feature_ttl {
    margin-bottom: 8px;
  }

  .our_matcha_btn_wrap {
    margin-top: 32px;
  }

  .our_matcha_btn a {
    max-width: 320px;
    padding: 24px 52px 24px 18px;
    font-size: 16px;
  }

  .our_matcha_content {
    padding-bottom: 72px;
  }

  .our_matcha_block {
    flex-direction: column;
  }

  .our_matcha_block + .our_matcha_block {
    margin-top: 64px;
  }

  .our_matcha_block_img {
    width: 100%;
    max-width: 100%;
    margin-bottom: 24px;
  }

  .our_matcha_block_txt {
    width: 100%;
    justify-content: flex-start !important;
  }

  .our_matcha_block_txt_inner {
    max-width: 100%;
  }

  .block_01 .our_matcha_block_txt_inner {
    padding: 0 24px 0 24px;
  }
  .block_02 .our_matcha_block_txt_inner {
    padding: 0 24px 0 24px;
  }
  .block_02 .our_matcha_block_txt {
    order: 1;
  }

  .block_02 .our_matcha_block_img {
    order: 2;
  }

  .img_split .img_l img {
    height: 220px;
  }

  .img_split .img_l {
    padding: 6px 8px;
  }

  .img_s img {
    height: 120px;
  }

  .img_s {
    padding: 6px 8px;
  }

  .img_single img {
    height: 260px;
  }

  .img_single p {
    padding: 6px 8px;
  }

  .our_matcha_block_sub {
    margin-bottom: 16px;
  }
}
