@charset "UTF-8";

/*----------------------------------
    COMMON
-----------------------------------*/
html {
    font-size: 62.5%;
}
@media screen and (max-width: 768px) {
    html {
        font-size: 50%;
    }
}

html,
body {
  position: relative;
  font-family: "murecho", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif;  
}
*,*:before,*:after {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}
img {
    width: 100%;
}
.pc {
  display: block !important;
}
.sp {
  display: none !important;
}
@media only screen and (max-width: 750px) {
    main#main {
      overflow: hidden !important;
    }
    .pc {
      display: none !important;
    }
    .sp {
      display: block !important;
    }
}

.btn_lp,
.bnr {
  transition: opacity 0.5s ease;
}

.btn_lp:hover,
.bnr:hover {
  opacity: 0.7;
  background-color: #fff;
}

p {
  line-height: 1.7;
  letter-spacing: 0.01em;
}
h4 {
    font-size: 4rem;
    font-weight: 600;
}

@media only screen and (max-width: 750px) {
    h4 {
        font-size: calc(2rem + 20*(100vw - 320px) / 1100);
    }
}
li {list-style: none;}
a {
    text-decoration: none;
    color: unset;
}
/* .mv_decor {
  animation: drive linear;
  animation-timeline: scroll();
} */
.mv_decor {
    /* animation: drive 2s linear forwards;  タイムラインベースからdurationベースに変更 */
    opacity: 1;
}  
/* アニメーション完了時のクラス */
.mv_decor.animation-completed {
    opacity: 1;
    transform: translate(0, 0);
}
@keyframes drive {
  0% {
    translate: 0 0;
    opacity: 1;
  }
  100% {
    translate: -100vw 0;
    opacity: 1;
  }
}

/*----------------------------------
    HEADER
-----------------------------------*/
#header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1;
}
#header a.header_shop_link {
    max-width: 360px;
}
#header .mv_logo {
    max-width: 255px;
    margin: 35px 25px 0 0;
}

@media screen and (max-width:1100px) {
    #header a.header_shop_link {
        max-width: 36%;
    }
    #header .mv_logo {
        max-width: 30%;
        margin: 4% 3% 0 0;
    }
    
}


/*----------------------------------
    MAIN VISUAL
-----------------------------------*/
#mainvisual {
    background-image: url(../img/mv_bg.png);
    background-repeat: no-repeat;
    background-position: bottom;
    background-size: cover;
    max-height: 760px;
}
.mv_content {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 82.4vh;
    margin-top: 0;
    padding-top: 0;
}
.mv_title {
    position: relative;
    top: -20px;
    max-width: 271px;
}
.mv_decor {
    position: absolute;
    bottom: 167px;
    left: 210px;
    max-width: 660px;
}
.mv_footer {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 90px;
}
.mv_footer > img {
    max-width: 257px;
    position: absolute;
    top: -70px;
    left: 95px;
}
.mv_footer_inner {
    background-color: rgba(255, 255, 255, 0.75);
    height: 90px;
    position: relative;
    border-top: 10px solid #ff3333;
}
.mv_footer_inner img {
    opacity: 1;
    max-width: 127px;
    height: auto;
    position: absolute;
    top: 48%;
    right: 35px;
    transform: translateY(-50%);
}

@media screen and (max-width:1100px) {
    #mainvisual {
        max-height: 100vh;
    }
    .mv_content {
        height: 100vh;
    }
    .mv_footer > img {
        max-width: 25%;
        top: -60%;
        left: 4%;
    }
    .mv_title {
        max-width: calc(150px + 370*(100vw - 320px) / 1100);
        top: -3%;
    }
    .mv_decor {
    }
    .mv_footer {
        height: calc(60px + 70*(100vw - 320px) / 1100);
    }
    .mv_footer > img {
        max-width: calc(33% + -60*(100vw - 320px) / 1100);
        top: calc(-48% + -46*(100vw - 320px) / 1100);
    }
    .mv_footer_inner {
        height: calc(60px + 70*(100vw - 320px) / 1100);
    }
    .mv_footer_inner img {
        max-width: calc(33% + -295*(100vw - 320px) / 1100);
        right: 35%;
    }
}



/*----------------------------------
    Protein Facts
-----------------------------------*/

#protein_facts {

}
#protein_facts .bg_lightblue {
    background: radial-gradient(circle at 48% 5%, #6699cc, rgba(102, 153, 204, 0) 40%),
        radial-gradient(circle at 3% 50%, #bacde0, rgba(186, 205, 224, 0) 40%),
        radial-gradient(circle at 55% 65%, #71bcda, rgba(113, 188, 218, 0) 40%);
        background-color: #71bcda;
}

.wave {
    overflow-x: hidden;
    position: relative;
    width: 100%;
}

/* ナビゲーション */
#protein_facts .nav {
    display: flex;
    justify-content: space-around;
    align-items: center;
    width: 100%;
    max-width: 1080px;
    margin: 0 auto;
    padding-top: 35px;
}
#protein_facts .nav ul {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 0;
    margin: 0 auto;
    gap: 15px;
    max-width: 1080px;
    width: 100%;
}
#protein_facts .nav ul li {
    width: calc(100vw / 5);
}
#protein_facts .nav ul li a {
    display: block;
    text-align: center;
    padding: 19px 5px;
    border: 2px solid transparent;
    border-radius: 10px;
    font-family: Arial, sans-serif;
    font-weight: bold;
    text-decoration: none;
    position: relative;
}
#protein_facts .nav ul li:nth-child(1) a {
    border-color: #4d5daa;
    box-shadow: 4px 4px 0 #4d5daa;
    color: #4d5daa;
}
#protein_facts .nav ul li:nth-child(2) a {
    border-color: #4070b6;
    box-shadow: 4px 4px 0 #4070b6;
    color: #4070b6;
}
#protein_facts .nav ul li:nth-child(3) a {
    border-color: #71c6a2;
    box-shadow: 4px 4px 0 #71c6a2;
    color: #71c6a2;
}
#protein_facts .nav ul li:nth-child(4) a {
    border-color: #d1e094;
    box-shadow: 4px 4px 0 #d1e094;
    color: #d1e094;
}
#protein_facts .nav ul li:nth-child(5) a {
    border-color: #e8d36b;
    box-shadow: 4px 4px 0 #e8d36b;
    color: #e8d36b;
}
#protein_facts .nav ul li a p {
    margin: 0;
    font-size: 2.6rem;
    color: inherit;
}
#protein_facts .nav ul li a p span {
    display: block;
    font-size: 1.4rem;
    position: relative;
    padding-right: 30px;
}
#protein_facts .nav ul li a p span::after {
    content: '\f0d7';
    font-size: 3.6rem;
    font-family: "Font Awesome 6 Free";
    position: absolute;
    bottom: -65%;
    right: 9%;
}
#protein_facts .nav ul li:nth-child(3) a p span::after {
    right: 20%;
}
#protein_facts .nav ul li:nth-child(4) a p span::after {
    right: 26%;
}
#protein_facts .nav ul li a:hover {
    background-color: rgba(255, 255, 255, 0.1);
    transform: translateY(-3px);
    transition: 0.3s ease;
}

@media screen and (max-width:1100px) {
    
    #protein_facts {
    }
    .bg_lightblue {
        padding: 0 4%;
    }
    #protein_facts .nav {
        padding-top: calc(7% + 20*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul {
        width: 100%;
        flex-wrap: wrap;
        justify-content: center;
        gap: calc(12px + 20*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul li {
        width: 47%;
    }
    #protein_facts .nav ul li:nth-child(5) {
        width: calc(98% + -20*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul li a {
        padding: 10px;
    }
    #protein_facts .nav ul li:nth-child(1) a {
    }
    #protein_facts .nav ul li:nth-child(2) a {
    }
    #protein_facts .nav ul li:nth-child(3) a {
    }
    #protein_facts .nav ul li:nth-child(4) a {
    }
    #protein_facts .nav ul li:nth-child(5) a {
    }
    #protein_facts .nav ul li a p {
        font-size: calc(2rem + 40*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul li a p span {
        font-size: calc(1.1rem + 12*(100vw - 320px) / 1100);
        padding-right: calc(17% + 20*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul li a p span::after {
        font-size: calc(3rem + 32*(100vw - 320px) / 1100);
        bottom: calc(-77% + -1*(100vw - 320px) / 1100);
        right: calc(4% + 150*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul li:nth-child(3) a p span::after {
        right: calc(15% + 120*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul li:nth-child(4) a p span::after {
        right: calc(24% + 70*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul li:nth-child(5) a p span::after {
        right: calc(30% + 150*(100vw - 320px) / 1100);
    }
    #protein_facts .nav ul li a:hover {
    }
}


/* ナビゲーション以降 */
#protein_facts .facts_inner {
    max-width: 1028px;
    margin: 120px auto 0;
    padding-bottom: 180px;
}
#protein_facts .facts_lead h2 {
    max-width: 418px;
    margin: 0 auto;
}
.facts_lead_txt {
    border: 3px solid #fff;
    border-radius: 30px;
    margin: 5px auto 0;
    padding: 4% 10%;
    position: relative;
    font-size: 2.2rem;
    font-weight: 400;
    color: #f4f3f3;
    text-align: center;
    display: block;
}
.facts_lead_txt > img {
    max-width: 160px;
    position: absolute;
    top: -142px;
    right: 40px;
}
.facts_lead_txt > h4 {
    text-align: left;
    margin-bottom: 40px;
}
.facts_lead_txt > p {
    line-height: 1.6;
}
.facts_lead_txt ul,
.facts_lead_txt ol {
    margin: 40px auto;
    display: inline-block;
}
.facts_lead_txt ul li,
.facts_lead_txt ol li {
    line-height: 1.6;
    position: relative;
    text-align: left;
    padding-left: 1.8em;
    font-size: 2.4rem;
    font-weight: 500;
}
.facts_lead_txt ul.facts_lead_check li:before {
    content: '\f14a';
    font-family: "Font Awesome 6 Free";
    font-size: 3.4rem;
    font-weight: 400;
    vertical-align: middle;
    padding-right: 8px;
    position: absolute;
    top: -5px;
    left: 0;
}
.facts_lead_txt ol {
    counter-reset: list-counter;
}
  
.facts_lead_txt ol li {
    position: relative;
    padding: 4px 30px;
    margin-bottom: 10px;
    border: 1px solid #fff;
    border-radius: 40px;
    counter-increment: list-counter;
    padding-left: 60px;
}
  
.facts_lead_txt ol li::before {
    content: counter(list-counter) ".";
    position: absolute;
    top: 50%;
    left: 25px;
    transform: translateY(-50%);
    font-weight: bold;
    color: #fff;
    vertical-align: middle;
}
.read_more_btn.read_more,
.read_more_btn.close {
    border: none;
    background: none;
    font-size: 2.6rem;
    font-weight: 600;
    color: #fff;
    margin-top: 55px;
    position: relative;
    padding-left: 48px;
}
.read_more_btn.read_more::before,
.read_more_btn.close::before {
    top: -12px;
    font-size: 5.4rem;
    position: absolute;
    left: 0px;
    line-height: 1;
}
.read_more_btn.read_more::before {
    content: '+';
}
.read_more_btn.close::before {
    content: '−';
}
.facts_products {
    padding: 7% 10%;
}
.facts_products_lead {
    margin: 0 auto 5%;
}
.facts_products_item {
    display: flex;
    justify-content: center;
    align-items: center;
}
.bar_anime.js-item {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1), 
                transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    /* transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1), 
                transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); */
}
.bar_anime.js-item.show {
  opacity: 1;
  transform: translateY(0);
}

@media screen and (max-width:1100px) {
    #protein_facts .facts_inner {
        margin-top: calc(17% + 20*(100vw - 320px) / 1100);
        margin-bottom: 100px;
    }
    #protein_facts .facts_lead h2 {
        max-width: 45%;
    }
    .facts_lead_txt {
        padding: 4% 7%;
        font-size: calc(1.2rem + 20*(100vw - 320px) / 1100);
        border: calc(1px + 1*(100vw - 320px) / 1100) solid #fff;
        border-radius: calc(10px + 20*(100vw - 320px) / 1100);
    }
    .facts_lead_txt > img {
        max-width: calc(60px + 120*(100vw - 320px) / 1100);
        top: calc(-50px + -110*(100vw - 320px) / 1100);
        right: calc(2% + 20*(100vw - 320px) / 1100);
    }
    .facts_lead_txt > h4 {
        margin-bottom: calc(10% + -50*(100vw - 320px) / 1100);
    }
    .facts_lead_txt ul,
    .facts_lead_txt ol {
        margin: calc(7% + 20*(100vw - 320px) / 1100) auto calc(5% + 20*(100vw - 320px) / 1100);
    }
    .facts_lead_txt ul li,
    .facts_lead_txt ol li {
        font-size: calc(1.5rem + 20*(100vw - 320px) / 1100);
        margin-bottom: calc(3% + 20*(100vw - 320px) / 1100);
    }
    .facts_lead_txt ul.facts_lead_check li:before {
        font-size: calc(2.4rem + 20*(100vw - 320px) / 1100);
        top: calc(-8.5% + 0*(100vw - 320px) / 1100);
        line-height: 1.6;
    }
      
    .facts_lead_txt ol li {
    }
      
    .facts_lead_txt ol li::before {
    }
    .read_more_btn.read_more,
    .read_more_btn.close {
        margin-top: calc(9% + 20*(100vw - 320px) / 1100);
        font-size: calc(1.6rem + 20*(100vw - 320px) / 1100);
        padding-left: calc(9% + -40*(100vw - 320px) / 1100);
    }
    .read_more_btn.read_more::before,
    .read_more_btn.close::before {
        top: calc(-56% + 18*(100vw - 320px) / 1100);
        left: calc(-6% + 20*(100vw - 320px) / 1100);
        font-size: calc(4rem + 20*(100vw - 320px) / 1100);
    }
}


/* プロダクト */
.facts_products > h4 {
    margin-bottom: 50px;
    color: #fff;
}
.facts_feature {
    padding-bottom: 60px;
}
.facts_feature > img {
    max-width: 683px;
    margin: 0 auto;
    display: block;
}
.facts_feature_detail {
    display: flex;    width: 100%;
    margin: 0 auto;
    margin-top: 35px;
}
.facts_feature_text {
  text-align: center;
  font-size: 3rem;
  margin-top: 70px;
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1), 
              transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  /* transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1), 
              transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); */
}
.facts_feature_detail ul {
    display: flex;
    justify-content: center;
    width: 96%;
    gap: 2%;
    margin: 0 auto;
    padding: 0;
}
.facts_feature_detail ul li.js-item {
    text-align: center;
    font-size: 1.4rem;
    font-weight: 600;
    width: calc(100vw / 8);
    word-wrap: break-word;
    min-width: 0;
    /* max-width: 200px; */
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1), 
                transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    /* transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1), 
                transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); */
  
}
.facts_feature_text.js-item.show,
.facts_feature_detail ul li.js-item.show {
  opacity: 1;
  transform: translateY(0);
}
@keyframes scroll-left {
    from {
      transform: translateX(0);
    }
    to {
      transform: translateX(-100%);
    }
}

@media screen and (max-width:1100px) {
    .facts_products {
        padding: unset;
    }
    .facts_products > h4 {
        padding: calc(9% + 20*(100vw - 320px) / 1100) calc(5% + 20*(100vw - 320px) / 1100) 0;
        margin-bottom: calc(9% + 20*(100vw - 320px) / 1100);
    }
    .facts_feature {
    }
    .facts_feature > img {
        padding: 0 4%;
    }
    .facts_feature_detail {
      margin-top: calc(25px + 20*(100vw - 320px) / 1100);
    }
    .facts_feature_text {
      font-size: calc(3rem + 20*(100vw - 320px) / 1100);
      margin-top: calc(43px + 20*(100vw - 320px) / 1100);
    }
    .facts_feature_detail ul {
    }
    .facts_feature_detail ul li {
        /* width: calc(100vw / 3); */
        /* max-width: 124px; */
    }
}
@media screen and (max-width:700px) {
  .facts_feature_detail ul {
    flex-wrap: wrap;
  }
  .facts_feature_detail ul li.js-item {
    width: calc(100vw / 5);
    margin-bottom: 2%;
}
}



/*----------------------------------
    Strong Bar
-----------------------------------*/
  
.bg_blue_orange {
    background: linear-gradient(180deg, rgba(3, 110, 184, 1), rgba(56, 177, 231, 1) 20%, rgba(183, 224, 227, 1) 40%, rgba(244, 250, 251, 1) 60%, rgba(254, 241, 227, 1) 80%, rgba(247, 191, 158, 1));;
    background-color: #fff;
    height: 100%;
    margin: 0;
    padding-top: 247px;
}
#strong_bar {
    padding: 0 20px 150px;
}
#strong_bar h2 {
    margin: 0 auto 25px;
    padding-top: 100px;
    text-align: center;
    font-family: "Roboto", serif;
    font-optical-sizing: auto;
    font-weight: 900;
    font-size: 9.6rem;
    line-height: 1;
    color: #fff;
}
#strong_bar .strong_bar_box_list {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 0;
    gap: 1%;
}
#strong_bar .strong_bar_box_list li {
    position: relative;
    border: 1px solid #fff;
    border-radius: 20px;
    width: 25%;
    max-width: 304px;
}
#strong_bar .strong_bar_box_list li .strong_bar_img {
    min-height: 180px;
    display: flex;
    justify-content: center;
    align-items: center;
}
#strong_bar .strong_bar_box_list li .strong_bar_img img {
    max-width: 288px;
    margin: auto;
    display: block;
}
#strong_bar .strong_bar_box_list li .strong_bar_txt {
    color: #fff;
}
#strong_bar .strong_bar_box_list li .strong_bar_txt h3 {
    font-size: 3.2rem;
    text-align: center;
    line-height: 1.1;
    border-bottom: 1px solid #fff;
    padding-bottom: 15px;
}
#strong_bar .strong_bar_box_list li .strong_bar_txt h3 span {
    font-size: 1.2rem;
    display: block;
    font-weight: 400;
    margin: 6px auto 0;
}
#strong_bar .strong_bar_box_list li .strong_bar_txt p {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100px;
    padding-bottom: 20px;
    font-size: 1.4rem;
    text-align: center;
}
#strong_bar .strong_bar_box_list li .modal_button {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 50%);
    width: 40px;
    height: 40px;
    padding-top: 2px;
    font-size: 3.6rem;
    font-weight: bold;
    border: none;
    border-radius: 50%;
    background-color: #fff;
    color: #1e1e90;
    cursor: pointer;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
#strong_bar .strong_bar_box_list li .modal_button:hover {
    transform: translate(-50%, 50%) scale(1.1);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
}


@media screen and (max-width:1100px) {
    .bg_blue_orange {
    }
    #strong_bar {
    }
    #strong_bar h2 {
      font-size: calc(8rem + 20*(100vw - 320px) / 1100);
    }
    #strong_bar .strong_bar_box_list {
    }
    #strong_bar .strong_bar_box_list li {
    }
    #strong_bar .strong_bar_box_list li:nth-child(1) {
        top: calc(0% + 20*(100vw - 320px) / 1100);
    }
    #strong_bar .strong_bar_box_list li .strong_bar_img {
        margin-top: 3%;
        min-height: 110px;
    }
    #strong_bar .strong_bar_box_list li .strong_bar_img img {
        max-width: 153px;
    }
    #strong_bar .strong_bar_box_list li .strong_bar_txt h3 {
        font-size: 2.8rem;
    }
    #strong_bar .strong_bar_box_list li .strong_bar_txt h3 span {
    }
    #strong_bar .strong_bar_box_list li .strong_bar_txt p {
        height: 80px;
        font-size: 1.2rem;
    }
    #strong_bar .strong_bar_box_list li .modal_button {
        width: 30px;
        height: 30px;
        font-size: 3.2rem;
    }
    #strong_bar .strong_bar_box_list li .modal_button:hover {
    }
}



@media screen and (max-width:700px) {
    #strong_bar {
        overflow: hidden;
        padding: 0;
    }
    #strong_bar .strong_bar_box_list {
        display: block;
        position: relative;
        margin-bottom: calc(700px + 980*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li {
        max-width: 440px;
        width: calc(67% + 20*(100vw - 320px) / 700);
        position: absolute;
        left: calc(-5px + 0*(100vw - 320px) / 700);
        border-radius: 0 150px 150px 0;
        padding-top: calc(4% + -10*(100vw - 320px) / 700);
        padding-bottom: calc(1% + -2*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li:nth-child(1) {
        top: calc(0% + 20*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li:nth-child(2) {
        top: calc(160px + 240*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li:nth-child(3) {
        top: calc(304px + 442*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li:nth-child(4) {
        top: calc(465px + 660*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li .strong_bar_img {
        margin-top: unset;
        min-height: 0;
        position: relative;
        display: block;
    }
    #strong_bar .strong_bar_box_list li .strong_bar_img img {
        max-width: calc(330px + 260*(100vw - 320px) / 700);
        position: absolute;
        top: calc(-27px + -40*(100vw - 320px) / 700);
        right: calc(-98% + 130*(100vw - 320px) / 700);
        width: calc(130% + 20*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li .strong_bar_txt > div {
        border-bottom: 1px solid #fff;
    }
    #strong_bar .strong_bar_box_list li .strong_bar_txt h3 {
        font-size: calc(2.2rem + 25*(100vw - 320px) / 700);
        text-align: left;
        margin-left: calc(5% + 20*(100vw - 320px) / 700);
        padding-bottom: calc(3% + 20*(100vw - 320px) / 700);
        border: none;
    }
    #strong_bar .strong_bar_box_list li .strong_bar_txt h3 span {
        font-size: calc(1rem + 11*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li .strong_bar_txt p {
        height: unset;
        font-size: calc(1.2rem + 7*(100vw - 320px) / 700);
        text-align: left;
        display: block;
        margin-top: calc(4% + 0*(100vw - 320px) / 700);
        margin-left: calc(5% + 20*(100vw - 320px) / 700);
        padding-bottom: calc(3% + 20*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li .modal_button {
        width: 30px;
        height: 30px;
        font-size: 3.2rem;
        left: calc(79% + 20*(100vw - 320px) / 700);
    }
    #strong_bar .strong_bar_box_list li .modal_button:hover {
    }
}


/*---------- モーダル ------------*/

.modal {
    visibility: hidden;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    z-index: 1000;
    opacity: 0;
    transition: opacity 0.5s ease, visibility 0.5s ease;
    pointer-events: none;
    overflow: auto;
}
.modal.show {
    visibility: visible;
    opacity: 1;
    pointer-events: all;
}

.modal_content {
    position: relative;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    max-width: 643px;
    padding: 8px;
    background: #fff;
    text-align: center;
    color: #3d2614;
    transition: transform 0.5s ease;
}
.modal_content_inner {
    border: 2px solid #3d2614;
}
.modal.show .modal_content {
    transform: translate(-50%, -50%) scale(1);
}
.modal_content .close {
    display: block;
    position: absolute;
    top: 10px;
    right: 10px;
    cursor: pointer;
    transform: translate(-50%, 50%);
    width: 30px;
    height: 30px;
    font-size: 2.4rem;
    line-height: 26px;
    font-weight: bold;
    color: #fff;
    border: none;
    border-radius: 50%;
    background-color: #3d2614;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    z-index: 1;
}

.modal_content.hidden {
    transform: translate(-50%, -50%) scale(0.9);
}
.modal_content .modal_header {
    position: relative;
}
.modal_content .modal_header p {
    display: inline-block;
    margin: 15px auto 5px;
    padding-left: 24px;
    text-align: left;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.2;
}
.modal_content .modal_header img {
    max-width: 426px;
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translate(-50%, 50%);
}
.modal_content .modal_middle img {
    max-width: 328px;
}

.modal_content .modal_middle h3 {
    font-size: 2.8rem;
    margin-top: -13px;
    margin-bottom: 3px;
}
.modal_content .modal_middle h3 span {
    font-size: 1.1rem;
    font-weight: 400;
    display: block;
}
.modal_content .modal_middle p {
    font-size: 2.2rem;
}
.modal_content .modal_middle p span {
    font-size: 1.3rem;
}
.modal_content .modal_footer {
    display: flex;
    justify-content: space-around;
    align-items: flex-start;
    border-top: 2px solid #3d2614;
    margin: 12px 25px 0;
    padding: 2.5% 1%;
    text-align: left;
}
.modal_content .modal_footer p {
    font-size: 1.1rem;
    font-weight: 400;
    margin-bottom: 10px;
    line-height: 1.5;
}
.modal_content .modal_footer > div {
    width: 57%;
}
.modal_content .modal_footer p span {
    font-weight: 500;
}
.modal_content .modal_footer > ul {
    width: 38%;
}
.modal_content .modal_footer > ul li {
    position: relative;
    padding: 3.5%;
    margin-bottom: 10px;
    font-size: 1.3rem;
    font-weight: 600;
    border: 2px solid #3d2614;
    border-radius: 8px;
    text-align: center;
}
.modal_content .modal_footer > ul li a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    font-size: 1.3rem;
    font-weight: 600;
}
.modal_content .modal_footer > ul li a.amazon img {
    max-width: 56px;
    display: block;
}
.modal_content .modal_footer > ul li a.rakuten img {
    max-width: 62px;
    display: block;
}
.modal_content .online_btn_area {
  padding: 20px;
}
.modal_content .online_btn_area li {
  margin-bottom: 10px;
}
.modal_content .online_btn_area li:last-child {
  margin-bottom: 0;
}
.modal_content .online_btn_area li img {
  max-width: 233px;
} 
.modal_content .online_btn_area li span.usa_icon {
  position: absolute;
  bottom: -12px;
  right: -12px;
  width: 41px;
}
.modal_content .online_btn_area li a {
  position: relative;
}


@media screen and (max-width:1100px) {
    .modal {
    }    
    .modal_content {
    }
    .modal_content_inner {
    }
    .modal_content .close {
        width: calc(24px + 20*(100vw - 320px) / 1100);
        height: calc(24px + 20*(100vw - 320px) / 1100);
        font-size: calc(2rem + 20*(100vw - 320px) / 1100);
        line-height: calc(24px + 20*(100vw - 320px) / 1100);
    }
    
    .modal_content.hidden {
    }
    .modal_content .modal_header p {
        margin: 2.8% auto 2%;
    }
    .modal_content .modal_header img {
        max-width: 383px;
    }
    .modal_content .modal_middle img {
    }
    
    .modal_content .modal_middle h3 {
        margin-top: -8px;
    }
    .modal_content .modal_middle h3 span {
        margin-top: 0.7%;
    }
    .modal_content .modal_middle p {
    }
    .modal_content .modal_middle p span {
    }
    .modal_content .modal_footer {
        margin: 1.5% 4% 0;
    }
    .modal_content .modal_footer p {
        font-size: 1.2rem;
    }
    .modal_content .modal_footer > div {
        width: 100%;
    }
    .modal_content .modal_footer > ul {
        width: 90%;
        margin: auto;
    }
    .modal_content .modal_footer > ul li {
        height: calc(34px + 20*(100vw - 320px) / 1100);
        margin: 0 auto calc(4% + 20*(100vw - 320px) / 1100);
    }
    .modal_content .modal_footer > ul li a {
    }
    .modal_content .modal_footer > ul li a.amazon img {
    }
    .modal_content .modal_footer > ul li a.rakuten img {
    }
    .modal_content .online_btn_area li span.usa_icon {
      width: calc(30px + 20*(100vw - 320px) / 1100);
    }
}


@media screen and (max-width:700px) {
    .modal {
    }    
    .modal_content {
        width: calc(94vw + 20*(100vw - 320px) / 700);
    }
    .modal_content_inner {
    }
    .modal_content .close {
    }
    
    .modal_content.hidden {
    }
    .modal_content .modal_header p {
        margin: calc(6% + 20*(100vw - 320px) / 700) auto 2%;
        font-size: calc(1.4rem + 20*(100vw - 320px) / 700);
        padding-left: calc(3% + 20*(100vw - 320px) / 700);
    }
    .modal_content .modal_header img {
        max-width: calc(220px + 390*(100vw - 320px) / 700);
        top: calc(12% + 20*(100vw - 320px) / 700);
    }
    .modal_content .modal_middle img {
        max-width: calc(200px + 20*(100vw - 320px) / 700);
    }
    
    .modal_content .modal_middle h3 {
        margin-top: -8px;
        font-size: calc(2.4rem + 20*(100vw - 320px) / 700);
    }
    .modal_content .modal_middle h3 span {
        margin-top: 0.7%;
    }
    .modal_content .modal_middle p {
    }
    .modal_content .modal_middle p span {
    }
    .modal_content .modal_footer {
        margin: 1.5% 4% 0;
        display: block;
    }
    .modal_content .modal_footer p {
        font-size: 1.2rem;
    }
    .modal_content .modal_footer > div {
    }
    .modal_content .modal_footer > ul {
    }
    .modal_content .modal_footer > ul li {
        height: calc(34px + 40*(100vw - 320px) / 700);
        margin: 0 auto calc(4% + -14*(100vw - 320px) / 700);
        padding-top: calc(3.5% + -5*(100vw - 320px) / 700);
        padding-bottom: calc(3.5% + 0*(100vw - 320px) / 700);
    }
    .modal_content .modal_footer > ul li a {
        font-size: calc(1.3rem + 8*(100vw - 320px) / 700);
    }
    .modal_content .modal_footer > ul li a.amazon img {
    }
    .modal_content .modal_footer > ul li a.rakuten img {
    }
    .modal_content .online_btn_area {
      padding: 5%;
    }
    .modal_content .online_btn_area li {
      margin-bottom: 5%;
    }
    .modal_content .online_btn_area li img {
      max-width: 133px;
    } 
    .modal_content .online_btn_area li span.usa_icon {
      width: calc(41px + 20*(100vw - 320px) / 700);
    }
}


/*----------------------------------
    Strong People
-----------------------------------*/
#strong_people {
    margin-bottom: 130px;
    overflow: hidden;
}
#strong_people h2 {
    margin: 0 auto;
    text-align: center;
    font-family: "Roboto", serif;
    font-optical-sizing: auto;
    font-weight: 900;
    font-size: 9.6rem;
    line-height: 1;
    color: #fff;
}
#strong_people > ul {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    max-width: 1140px;
    margin: 70px auto 20px;
    list-style: none;
    padding: 0;
}
#strong_people > ul li {
    position: relative;
    width: 47%;
    padding: 22px 25px 35px 35px;
    border: 2px solid #fff;
    border-radius: 20px;
    color: #fff;
    text-align: left;
    display: flex;
    justify-content: left;
    align-items: flex-start;
}
#strong_people > ul li::before {
    font-size: 2.8rem;
    font-weight: bold;
    color: #1e1e90;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    position: absolute;
    top: -26px;
    left: -26px;
    padding-bottom: 2px;
}
#strong_people > ul li.strong_people_01::before {
    content: '1';
}
#strong_people > ul li.strong_people_02::before {
    content: '2';
}
#strong_people > ul li dl dt {
    width: 130%;
    margin: 20px 0 25px;
    padding-bottom: 11px;
    font-size: 2.2rem;
    border-bottom: 1px solid #fff;
}
#strong_people > ul li dl dt span {
    display: block;
    font-size: 1.5rem;
    line-height: 1.7;
}
#strong_people > ul li img {
    max-width: 166px;
}
#strong_people > ul li dl dd {
    font-size: 1.4rem;
    line-height: 1.7;
    letter-spacing: -0.03em;
    width: 120%;
}
#strong_people > ul li dl dd span {
    display: block;
    margin-bottom: 12px;
    font-size: 1.7rem;
}
#strong_people > ul li .strong_people_more_btn {
  position: absolute;
  bottom: 0px;
  right: 50%;
  transform: translate(50%, 50%);
}
#strong_people > ul li .strong_people_more_btn a {
  font-size: 1.5rem;
  background: #777777;
  padding: 12px 30px;
  border-radius: 100px;
  line-height: 1;
}

@media screen and (max-width:1100px) {
    #strong_people {
        padding: 0 4%;
    }
    #strong_people h2 {
      font-size: calc(6.5rem + 20*(100vw - 320px) / 1100);
    }
    #strong_people > ul {
        margin: 6.5% auto;
    }
    #strong_people > ul li {
        width: 47.5%;
        padding: 2% 2% 3% 3%;
        border: 1px solid #fff;
    }
    #strong_people > ul li::before {
        width: 40px;
        height: 40px;
        top: -7.5%;
        left: -6.3%;
        font-size: 3rem;
        padding-bottom: 1%;
    }
    #strong_people > ul li dl dt {
    }
    #strong_people > ul li dl dt span {
    }
    #strong_people > ul li img {
        max-width: 105px;
    }
    #strong_people > ul li dl dd {
        width: 153%;
    }
    #strong_people > ul li dl dd span {
    }
}

@media screen and (max-width:700px) {
    #strong_people {
        padding: unset;
    }
    #strong_people h2 {
    }
    #strong_people > ul {
        display: block;
    }
    #strong_people > ul li {
        width: 93%;
        border-radius: 180px 0 0 180px;
        padding: 0% 2% 0% 0%;
        border: 1px solid #fff;
        margin-left: calc(8% + 20*(100vw - 320px) / 700);
        height: calc(300px + 20*(100vw - 320px) / 700);
        margin-bottom: calc(20px + 20*(100vw - 320px) / 700);
    }
    #strong_people > ul li::before {
        width: 50px;
        height: 50px;
        top: calc(38% + 12*(100vw - 320px) / 700);
        left: calc(-6.3% + 30*(100vw - 320px) / 700);
        font-size: 3.5rem;
        padding-bottom: 1%;
    }
    #strong_people > ul li dl {
      width: calc(100% + -380*(100vw - 320px) / 700);
    }

    #strong_people > ul li dl dt {
      width: 100%;
        text-align: right;
        padding-right: calc(27% + -120*(100vw - 320px) / 700);
        font-size: calc(1.5rem + 20*(100vw - 320px) / 700);
        margin: calc(56% + -257*(100vw - 320px) / 700) 0 0 0;
    }
    #strong_people > ul li dl dt span {
      padding-right: calc(17% + -120*(100vw - 320px) / 700);
        font-size: calc(1rem + 20*(100vw - 320px) / 700);
    }
    #strong_people > ul li img {
        max-width: calc(120px + 210*(100vw - 320px) / 700);
        margin-top: calc(20px + 20*(100vw - 320px) / 700);
        margin-right: calc(0px + 40*(100vw - 320px) / 700);
    }
    #strong_people > ul li dl dd {
        width: calc(150% + -380*(100vw - 320px) / 700);
        margin-top: calc(10% + -20*(100vw - 320px) / 700);
        margin-right: calc(0px + 0*(100vw - 320px) / 700);
        margin-bottom: calc(3% + 20*(100vw - 320px) / 700);
        margin-left: calc(42% + -25*(100vw - 320px) / 700);
        font-size: 1.1rem;
    }
    #strong_people > ul li dl dd span {
      margin-left: calc(-10% + -90*(100vw - 320px) / 700);
    }
    #strong_people > ul li .strong_people_more_btn {
      position: absolute;
      bottom: -7px;
      right: 10%;
      transform: none;
    }
    #strong_people > ul li .strong_people_more_btn a {
      font-size: 1.5rem;
      background: #777777;
      padding: 12px 30px;
      border-radius: 100px;
      line-height: 1;
    }
}


/*----------------------------------
    Strong People
-----------------------------------*/
#ambassador {
    margin-bottom: 130px;
}
#ambassador h2 {
    margin: 0 auto 50px;
    text-align: center;
    font-family: "Roboto", serif;
    font-optical-sizing: auto;
    font-weight: 900;
    font-size: 9.6rem;
    line-height: 1;
    color: #fff;
}
#ambassador ul.ambassador_list {
    text-align: center;
}
#ambassador ul.ambassador_list li {
    position: relative;
    display: block;
    padding: 15px 50px;
    font-size: 2.6rem;
    color: #1f1b62;
    background: #fff;
    border-radius: 50px;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.2);
    z-index: 1;
    width: 40%;
    margin: 0 auto 37px;
}
#ambassador ul.ambassador_list li::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 50px;
    border: 1px solid #fff;
    transform: translate(8px, 8px);
    z-index: -1;
}

#more_btn {
    width: 300px;
    border: 1px solid #fff;
    border-radius: 50px;
    padding: 15px;
    display: block;
    margin: 60px auto 0;
}
#more_btn img {
    max-width: 100px;
    margin: auto;
    display: block;
}
#ambassador ul.ambassador_list li.hidden {
    display: none;
}


@media screen and (max-width:1100px) {
    #ambassador {
    }
    #ambassador h2 {
      font-size: calc(8rem + 20*(100vw - 320px) / 1100);
    }
    #ambassador ul.ambassador_list {
    }
    #ambassador ul.ambassador_list li {
        padding: calc(4.9% + -30*(100vw - 320px) / 1100);
        width: calc(85% + -170*(100vw - 320px) / 1100);
        margin: 0 auto calc(7% + -20*(100vw - 320px) / 1100);
        font-size: calc(1.7rem + 20*(100vw - 320px) / 1100);
    }
    #ambassador ul.ambassador_list li::after {
    }
    
    #more_btn {
        width: calc(52% + 20*(100vw - 320px) / 1100);
        padding: calc(3.5% + -20*(100vw - 320px) / 1100);
        margin: calc(13.5% + -70*(100vw - 320px) / 1100) auto 0;
    }
    #more_btn img {
        max-width: calc(40% + -170*(100vw - 320px) / 1100);
    }
}


/*----------------------------------
    Instagram
-----------------------------------*/
#instagram {
    margin-bottom: 200px;
}
#instagram h2 {
    margin: auto;
    text-align: center;
    font-family: "Roboto", serif;
    font-optical-sizing: auto;
    font-weight: 900;
    font-size: 9.6rem;
    line-height: 1;
    color: #fff;
}


@media screen and (max-width:1100px) {
    #instagram {
    }
    #instagram h2 {
      font-size: calc(8rem + 20*(100vw - 320px) / 1100);
    }
}
.iframe-wrap {
  width: 947px;
  margin: 40px auto 0;
}
.iframe_instagram {
  width: 100%;
  height: 600px; /* SP */
  padding: 0;
}

@media screen and (max-width: 947px) {
  .iframe-wrap {
    width: 90%;
  }
  .iframe_instagram {
    height: 500px; /* PC */
  }
}
@media screen and (max-width:480px) {
  .iframe-wrap {
    width: 90%;
  }
  .iframe_instagram {
    height: 660px; /* PC */
  }
}
/* .iframe-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid #e6e6e6;
  margin-top: -260px;
}

@media screen and (min-width: 768px) {
  .iframe-wrap {
    padding-top: 42%;
    overflow: hidden;
    margin-top: 2%;
  }
}

.iframe-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
} */

/*----------------------------------
    NEWS
-----------------------------------*/
#news {
    margin-bottom: 160px;
}
#news h2 {
  margin: 0 auto 40px;
  text-align: center;
  font-family: "Roboto", serif;
  font-optical-sizing: auto;
  font-weight: 900;
  font-size: 9.6rem;
  line-height: 1;
  color: #709ca3;
}
#news .news_list {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  gap: 60px;
}
#news .news_list_item {
  background: #fff;
  border-radius: 20px;
  margin-bottom: 20px;
}
#news .news_list_item::after {
  content: "";
  position: absolute;
  top: 5px;
  bottom: -10px;
  left: 5px;
  right: -10px;
  border-right: solid 1px #fff;
  border-bottom: solid 1px #fff;
  z-index: -1;
  border-radius: 20px;
}
#news .news_list_item a {
  padding: 40px 30px 60px;
  display: block;
}
#news .news_list_item_img {
  text-align: center;
  margin-bottom: 40px;
}
#news .news_list_item_img img {
  max-width: 310px;
  height: 220px;
  object-fit: cover;
}
#news .news_list_item_date {
  font-size: 2.5rem;
  font-family: Arial, sans-serif;
  font-weight: bold;
  text-align: center;
}
#news .news_list_item_title {
  font-size: 2.8rem;
  text-align: center;
}
#news .news_list_item_content {
  font-size: 2.2rem;
  word-wrap: break-word;
  border-top: 1px solid #000;
  padding-top: 10px;
  margin-top: 10px;
}
.news_slider.swiper-container {
  overflow: hidden;
}
.news_list.swiper-wrapper {
  transition-timing-function: linear;
}
.news_list.swiper-wrapper .swiper-slide {
	height: auto;
}

.news_list.swiper-wrapper .swiper-slide-item {
	height: 100%;
}

@media screen and (max-width:1100px) {
    #news {
    }
    #news h2 {
      font-size: calc(8rem + 20*(100vw - 320px) / 1100);
    }
}

@media screen and (max-width:768px) {
  #news .news_list {
    flex-direction: column;
    gap: 20px;
  }
  #news .news_list_item {
    max-width: calc(320px + 300*(100vw - 320px) / 768);
    margin: 0 auto;
  }
  #news .news_list_item::after {
    bottom: -5px;
    right: -5px;
  }
  #news .news_list_item a {
    padding: calc(15px + 20*(100vw - 320px) / 768);
  }
  #news .news_list_item_contents {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  #news .news_list_item_img {
    margin-bottom: 0;
    width: calc(40% + 20*(100vw - 320px) / 768);

  }
  #news .news_list_item_img img {
    max-width: 100%;
    height: calc(80px + 100*(100vw - 320px) / 768);

  }
  #news .news_list_item_text {
    width: calc(60% + 20*(100vw - 320px) / 768);
  }
  #news .news_list_item_date {
    font-size: calc(1.5rem + 20*(100vw - 320px) / 768);

  }
  #news .news_list_item_title {
    font-size: calc(1.8rem + 20*(100vw - 320px) / 768);

  }
  #news .news_list_item_content {
    font-size: calc(1.2rem + 20*(100vw - 320px) / 768);

    padding-top: 5px;
    margin-top: 5px;
  }
}

/*----------------------------------
    Product Bnr
-----------------------------------*/
#product_bnr {
  padding-bottom: 137px;
}
#product_bnr .product_bnr_area {
  max-width: 1040px;
  margin: 0 auto;
}
#product_bnr .product_bnr_item {
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 30px;
  width: 50%;
  margin: 0 auto;
}



@media screen and (max-width:1100px) {

} 

@media screen and (max-width:700px) {
  #product_bnr .product_bnr_item {
    width: calc(85% + 20*(100vw - 320px) / 700);
  }
}

/*----------------------------------
    Online Store
-----------------------------------*/
#online_store {
    padding-bottom: 137px;
}
#online_store h2 {
    margin: 0 auto 40px;
    text-align: center;
    font-family: "Roboto", serif;
    font-optical-sizing: auto;
    font-weight: 900;
    font-size: 9.6rem;
    line-height: 1;
    color: #FFA12B;
}
#online_store .online_store_area {
    max-width: 1040px;
    margin: 0 auto;
}
#online_store .online_store_bnr {
    display: flex;
    justify-content: center;
    gap: 30px;
}
#online_store .online_store_bnr li {
  position: relative;
}
#online_store .online_store_bnr li span.usa_icon {
  position: absolute;
  bottom: -12px;
  right: -12px;
  width: 41px;
}


@media screen and (max-width:1100px) {
    #online_store {
    }
    #online_store h2 {
      font-size: calc(8rem + 20*(100vw - 320px) / 1100);
    }
    #online_store .online_store_area {
      max-width: 90%;
      margin: 0 auto;
  }
  #online_store .online_store_bnr {
      display: flex;
      justify-content: center;
      gap: 1%;
  }
  #online_store .online_store_bnr li span.usa_icon {
    width: calc(30px + 20*(100vw - 320px) / 1100);
  }
} 

@media screen and (max-width:700px) {

  #online_store .online_store_bnr {
    flex-wrap: wrap;
  }
  #online_store .online_store_bnr li {
    max-width: calc(240px + 20*(100vw - 320px) / 700);
    margin: 0 auto 30px;
  }
  #online_store .online_store_bnr li span.usa_icon {
    width: calc(41px + 20*(100vw - 320px) / 700);
  }
}
/*----------------------------------
    Contact
-----------------------------------*/
#contact {
   padding-bottom: 200px;
}
#contact .contact_area {
  max-width: 516px;
  margin: 0 auto;
}
#contact .contact_area a {
  display: flex;
  align-items: center;
  background: #FFB340;
  color: #fff;
  text-align: center;
  justify-content: center;
  font-size: 3.0rem;
  padding: 30px 0;
  border-radius: 100px;
}
#contact .contact_area a img {
  width: 48px;
}
#contact .contact_area a p {
  line-height: 1;
  margin-left: 20px;
  margin-bottom: 5px;
}
@media screen and (max-width:700px) {
  #contact .contact_area {
    max-width: 85%;
  }
  #contact .contact_area a img {
    width: calc(28px + 20*(100vw - 320px) / 700);
  }
  #contact .contact_area a {
    font-size: calc(1.7rem + 20*(100vw - 320px) / 700);
    padding: calc(18px + 20*(100vw - 320px) / 700) 0;
  }
}

/*----------------------------------
    Footer
-----------------------------------*/
footer {
  background: #FFA12B;
  color: #fff;
}
.footer-nav {
  max-width: 1040px;
  margin: 0 auto;
  padding: 160px 0;
}
.footer-nav-col {
  display: flex;
  gap: 60px;
}
.footer-nav-item-title {
  font-size: 2.8rem;
  font-weight: bold;
  margin-bottom: 35px;
}
.footer-nav-item-list li {
  font-size: 2.4rem;
  margin-bottom: 15px;
}
.footer-nav-item-list li:last-child {
  margin-bottom: 0;
}
.footer-nav-item-list li a svg {
  width: 40px;
}
@media screen and (max-width:1100px) {
  .footer-nav {
    max-width: 100%;
    padding:  calc(160px + 20*(100vw - 320px) / 1100) 30px;
  }
  .footer-nav-col {
    gap: 40px;
  }
  .footer-nav-item-title {
    font-size: calc(1.4rem + 20*(100vw - 320px) / 1100);
    margin-bottom: calc(35px + 20*(100vw - 320px) / 1100);
  }
  .footer-nav-item-list li {
    font-size: calc(1.2rem + 20*(100vw - 320px) / 1100);
    margin-bottom: calc(15px + 20*(100vw - 320px) / 1100);
  }
} 

@media screen and (max-width:700px) {
  .footer-nav {
    max-width: 100%;
    padding:  calc(100px + 20*(100vw - 320px) / 700) 30px;
  }
  .footer-nav-col {
    flex-direction: column;
  }
  .footer-nav-item-title {
    font-size: calc(2.8rem + 20*(100vw - 320px) / 700);
    margin-bottom: calc(20px + 20*(100vw - 320px) / 700);
  }
  .footer-nav-item-list li {
    font-size: calc(2.4rem + 20*(100vw - 320px) / 700);
    margin-bottom: calc(10px + 20*(100vw - 320px) / 700);
  }
}
.card-img{
    transition: all .3s ease-in;
}

.strong_bar_box_list li:hover .card-img{
    transform: scale(1.23) rotate(-23deg);
}

.wave_top{
    position: relative !important;
    transform: translateY(-23.8rem);
    height: 30vh;
}
.wave_under{
    position: relative !important;
    transform: translateY(20rem) rotate(180deg) !important;
    height: 30vh;
}
.wave_top svg{
    height: 30vh;
    width: 100vw;
    position: absolute;
    z-index: 3;
    left: 0;
    top: 0;
}
.wave_under svg{
    height: 30vh;
    width: 100vw;
    position: absolute;
    z-index: 3;
    left: 0;
    bottom: 0;
}
.bg_white{
    margin-top: -14rem;
    margin-bottom: -25rem;
}
.ingredients_gsap{
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    font-size: 1.4rem;
    font-weight: 600;
}
@media screen and (max-width:1100px) {
    .bg_white{
        margin-bottom: -27rem;
    }
}
@media screen and (max-width:769px) {
    .wave_top{
        transform: translateY(-29rem);
    } 
    .bg_white{
        margin-top: -28rem;
        margin-bottom: -29rem;
    }
}
@media screen and (max-width:480px) {
    .wave_top{
        transform: translateY(-29rem);
    } 
    .bg_white{
        margin-top: -28rem;
    }
}