/**
 * common css
 * */
.text-decs {
  font-size: 1.5rem;
  color: #302D2C; }

.text-center {
  text-align: center; }

.mx-auto {
  margin-left: auto;
  margin-right: auto; }

.font-noto {
  font-family: 'Noto Sans JP', sans-serif; }

.flex-box {
  width: 100%;
  display: flex;
  justify-content: space-between; }
  @media screen and (max-width: 767px) {
    .flex-box {
      flex-direction: column; } }
  .flex-box__item {
    width: 100%; }
    .flex-box__item:last-child {
      align-self: center; }
    .flex-box__item.flex-item2 {
      max-width: calc(100%/2 - 20px); }
      @media screen and (max-width: 767px) {
        .flex-box__item.flex-item2 {
          max-width: none; } }

/** -------------------------------------  */
@media screen and (max-width: 767px) {
  .top-title {
    padding: 0 20px; } }

.mv-banner .mv-wrap figure {
  padding: 0 20px;
  position: relative; }
  .mv-banner .mv-wrap figure .label-inside {
    position: absolute;
    width: 30rem;
    height: 12rem;
    background-color: #159A3D;
    font-size: 3.2rem;
    font-weight: 700;
    color: #fff;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    justify-content: center; }
    @media screen and (max-width: 767px) {
      .mv-banner .mv-wrap figure .label-inside {
        width: 20rem;
        height: 6rem;
        font-size: 2.2rem; } }

.benifits {
  margin-top: 142px; }
  @media screen and (max-width: 767px) {
    .benifits {
      margin-top: 40px; } }
  .benifits-title {
    padding-bottom: 20px; }
    .benifits-title .title {
      padding-bottom: 30px; }
      @media screen and (max-width: 767px) {
        .benifits-title .title {
          padding-bottom: 0; } }
  .benifits__content {
    width: 100%;
    max-width: 80rem;
    margin: 0 auto; }

.rectangle-list {
  list-style-type: none;
  margin: 0;
  padding: 0; }
  @media screen and (max-width: 767px) {
    .rectangle-list {
      margin-bottom: 20px; } }
  .rectangle-list li {
    height: 5rem;
    background-color: #B8012E;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center; }
    .rectangle-list li:not(:last-of-type) {
      margin-bottom: 1rem; }

.cate-title {
  font-size: 1.3rem;
  font-weight: 700;
  color: #B8012E;
  display: block;
  text-align: center; }

.usecase {
  margin-top: 160px; }
  @media screen and (max-width: 767px) {
    .usecase {
      margin-top: 40px; } }
  .usecase-box {
    justify-content: space-between;
    max-width: 1000px;
    margin: 0 auto;
    margin-bottom: 20px; }
    @media screen and (max-width: 1023px) {
      .usecase-box {
        flex-direction: column; } }
    .usecase-box .flex-box__item {
      max-width: 50%;
      padding: 2rem 1.5rem;
      border: 1px solid #D3D3D3;
      background-color: #fff; }
      @media screen and (max-width: 1023px) {
        .usecase-box .flex-box__item {
          max-width: none; } }
      .usecase-box .flex-box__item:first-child {
        margin-right: 26px; }
        @media screen and (max-width: 1023px) {
          .usecase-box .flex-box__item:first-child {
            margin-right: 0;
            margin-bottom: 20px; } }
      .usecase-box .flex-box__item figure {
        margin-top: 13px; }
        @media screen and (max-width: 767px) {
          .usecase-box .flex-box__item figure {
            align-items: center; } }
        .usecase-box .flex-box__item figure img {
          max-width: 100%;
          width: auto; }
          @media screen and (max-width: 767px) {
            .usecase-box .flex-box__item figure img {
              max-width: none;
              width: 100%; } }
        .usecase-box .flex-box__item figure p {
          padding-top: 9px;
          padding-left: 13px;
          font-size: 13px;
          line-height: 1.6; }

.takex-category {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 0;
  max-width: 1000px;
  margin: 0 auto; }
  .takex-category li {
    display: block;
    list-style: none;
    max-width: 180px;
    height: 181px;
    width: 100%;
    border: 1px solid #D3D3D3;
    margin-bottom: 20px; }
    @media screen and (max-width: 1023px) {
      .takex-category li {
        max-width: calc(100%/3 - 26px); } }
    @media screen and (max-width: 767px) {
      .takex-category li {
        max-width: calc(100%/2 - 5px); } }
    @media screen and (max-width: 375px) {
      .takex-category li {
        max-width: 100%; } }
    .takex-category li a {
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      height: 100%;
      padding: 21px 0;
      text-align: center;
      text-decoration: none;
      color: #077d94;
      background-color: #fff; }
      .takex-category li a .text {
        display: block;
        font-size: 13px;
        font-weight: bold;
        color: #B8012E;
        padding: 0 11px;
        line-height: 1.6; }

.ingredients {
  margin-top: 132px;
  font-size: 13px; }
  @media screen and (max-width: 767px) {
    .ingredients {
      margin-top: 40px; } }
  .ingredients-title {
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      .ingredients-title {
        margin-bottom: 10px; } }
  .ingredients__content {
    display: flex; }
    @media screen and (max-width: 1023px) {
      .ingredients__content {
        flex-direction: column; } }
    .ingredients__content > figure {
      max-width: calc(50% - 12px);
      width: 100%;
      margin-right: 24px; }
      @media screen and (max-width: 1023px) {
        .ingredients__content > figure {
          max-width: none;
          margin-right: 0;
          margin-bottom: 10px; } }
    .ingredients__content > div {
      max-width: calc(50% - 12px);
      width: 100%; }
      @media screen and (max-width: 1023px) {
        .ingredients__content > div {
          max-width: none; } }
      .ingredients__content > div figure:first-child {
        margin-bottom: 10px; }
    .ingredients__content figure {
      display: flex;
      align-items: flex-start;
      padding: 24px 0 20px 23px;
      border: 1px solid #D3D3D3; }
      @media screen and (max-width: 767px) {
        .ingredients__content figure {
          flex-direction: column-reverse;
          padding: 24px 20px 20px 23px; } }
      .ingredients__content figure img {
        max-width: 100%;
        width: auto;
        margin-right: 21px; }
        @media screen and (max-width: 767px) {
          .ingredients__content figure img {
            margin-right: 0;
            align-self: center; } }
      .ingredients__content figure figcaption h3 {
        font-size: 16px;
        font-weight: 700;
        color: #B8012E;
        margin-bottom: 11px; }
      .ingredients__content figure figcaption p {
        margin-bottom: 13px;
        line-height: 1.6;
        font-weight: 500; }
        .ingredients__content figure figcaption p:last-child span {
          font-size: 11px; }
        .ingredients__content figure figcaption p span {
          font-weight: 400;
          display: block;
          margin-top: 4px; }

.lineup {
  margin-top: 160px;
  margin-bottom: 164px; }
  @media screen and (max-width: 767px) {
    .lineup {
      margin-top: 40px;
      margin-bottom: 44px; } }
  .lineup-title {
    margin-bottom: 30px; }
  .lineup__content {
    max-width: 813px;
    width: 100%;
    margin: 0 auto; }
    .lineup__content > figure {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 24px 35px 23px 25px;
      border: 1px solid #D3D3D3;
      margin-bottom: 21px; }
      @media screen and (max-width: 767px) {
        .lineup__content > figure {
          flex-direction: column;
          padding: 20px 20px 23px 25px; } }
      .lineup__content > figure figcaption {
        align-self: flex-start; }
        .lineup__content > figure figcaption h3 {
          margin-bottom: 15px;
          font-size: 20px;
          line-height: 1.35;
          font-weight: 600;
          color: #B8012E;
          font-family: 'Noto Serif JP', sans-serif; }
          @media screen and (max-width: 767px) {
            .lineup__content > figure figcaption h3 {
              font-size: 16px; } }
        .lineup__content > figure figcaption p {
          margin-bottom: 20px;
          font-size: 13px;
          line-height: 1.6; }
      .lineup__content > figure img {
        width: auto;
        max-width: 100%; }
    .lineup__content .lineup__content-bottom {
      display: flex; }
      @media screen and (max-width: 1023px) {
        .lineup__content .lineup__content-bottom {
          flex-direction: column; } }
      .lineup__content .lineup__content-bottom figure {
        display: flex;
        flex-direction: column;
        max-width: calc(50% - 12px);
        width: 100%;
        padding: 24px 35px 23px 25px;
        border: 1px solid #D3D3D3; }
        @media screen and (max-width: 1023px) {
          .lineup__content .lineup__content-bottom figure {
            max-width: none;
            flex-direction: row;
            justify-content: space-between; } }
        @media screen and (max-width: 767px) {
          .lineup__content .lineup__content-bottom figure {
            flex-direction: column;
            padding: 24px 15px 23px 25px; } }
        .lineup__content .lineup__content-bottom figure:first-child {
          margin-right: 24px;
          padding: 24px 15px 23px 25px; }
          @media screen and (max-width: 767px) {
            .lineup__content .lineup__content-bottom figure:first-child {
              margin-right: 0;
              margin-bottom: 23px; } }
        .lineup__content .lineup__content-bottom figure figcaption h3 {
          font-size: 20px;
          line-height: 1.35;
          font-weight: 600;
          color: #B8012E;
          font-family: 'Noto Serif JP', sans-serif; }
          @media screen and (max-width: 767px) {
            .lineup__content .lineup__content-bottom figure figcaption h3 {
              font-size: 16px; } }
        .lineup__content .lineup__content-bottom figure figcaption p {
          margin-bottom: 25px;
          font-size: 13px;
          line-height: 1.6; }
        .lineup__content .lineup__content-bottom figure img {
          width: auto;
          max-width: 100%;
          align-self: center; }
