@charset "UTF-8";


/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc { display: block !important; }
.sp { display: none !important; }
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 750px) {
.pc { display: none !important; }
.sp { display: block !important; }
}

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

body {
  background: #fff;
  color: #221814;
}

img {
  max-width: 100%;
  height: auto;
}

figure {
  margin: 0;
}

ul,ol {
  margin: 0;  
  padding: 0; 
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6, .a1 {
  font-family:  "A1 Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.container {
  max-width: 1000px;
}

.col2, .col3, .colc {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}

.col2>div {
  width: 49%;
}

.colc > div {
    width: 50%;
}

.colc:nth-child(odd) {
    flex-direction: row-reverse;
}

section {
  position: relative;
}

.inner {
  
  width: 1000px;   
  margin: 0 auto;    
}

.kv {
  width: 100%;
  height: 570px;
  background: url(/images/bg-kv.jpg) center center no-repeat;
  -webkit-background-size: cover;
  background-size: cover;
}

#contents {
  padding-top: 0;
}

.main-catch {
  position: relative;
  width: 55%;
  height: 100%;

  background-image: radial-gradient(rgba(222,175,43,.3) 21%, transparent 24%),
  radial-gradient(rgba(222,175,43,.3) 21%, transparent 24%);
  background-position: 0 0, 6px 6px;
  background-size: 12px 12px;
}

.main-catch p {
  position: relative;
  height: 100%;
  max-width: 850px;
  margin-top: auto;
  margin-left: auto;
  margin-bottom: 50px;
  margin-right: 50px;
}

.main-catch p img {
  position: absolute;
  bottom: 50px;
}

.main-catch figure {
  position: absolute;
  top: -55px;
  right: -120px;
}

.top-desc {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  background-position: right 30%;
}

.top-desc:before {
  width: 100%;
  height: 100%;
  content: '';
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  background: -moz-linear-gradient(left, #F2F2F2, #D3ECFB);
  background: -webkit-linear-gradient(left, #F2F2F2, #D3ECFB);
  background: linear-gradient(to right, #F2F2F2, #D3ECFB);
  margin-right: -17%;
}

.top-desc:after {
  position: absolute;
  z-index: 2;
  display: block;
  content:'';
  width: 100%;
  height: 100%;
  background: url(/images/bg-top-desc.svg) left 50% no-repeat;
  
}

.top-desc h2, .top-desc p {
  width: 50%;
  z-index: 3;
}

.top-desc h2 {
  position: relative;
}

.top-desc h2 img {
  position: absolute;
  top: -30px;
  right: -0px;
}

.top-desc p {
  line-height: 50px;
  font-size: 1.6rem;
  padding: 60px 0 60px 0;
}

.top-desc p span {
  color: #E2211A;
}

.area-rank {
  padding: 66px 0;
}

.ranking-catch {
  margin-bottom: 40px;
}

.area-products {
  background: url(/images/bg-products.png) center bottom no-repeat;
  background-size:auto 100%;
  padding: 110px 0;    
}

.area-products .inner{
  max-width: 895px;
}

.area-products h2 {
  margin-bottom: 25px;
}

.area-products ol  {
    padding-left: 2em;
    padding-right: 1em;
    font-weight: 500;
}

.area-products li {
  position: relative;
  list-style-type:decimal;
  font-size: 1.8rem;
  line-height: 1.6;
    margin-bottom: 6px;
  padding-left: 4px;
}

/*.area-products li:before {
  position: absolute;
  left: 0;
  top: 5px;
  display: block;
  content:'';
  width: 15px;
  height: 15px;
  background: #000;
}*/

.area-trouble {
  z-index: -1;
  margin-top: -140px;
  padding: 200px 0 35px;
  background-size: auto auto;
  background-color: rgba(255, 255, 255, .1);
  background-image: repeating-linear-gradient(-45deg, transparent, transparent 9px, rgba(216, 170, 42, .1) 9px, rgba(216, 170, 42, .1) 15px );
}

.area-trouble p {
  margin-top: -155px;
}

.area-cause {
  padding: 90px 0;
}

.area-cause p {
  line-height: 1.95;
  font-size: 1.8rem;
  margin-top: 25px;
}

.area-cause figure {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: -1;  
}

.area-cause .text-center {
  margin-top: 40px; 
}

.area-reason {
    padding-top: 60px;  
}

.area-reason h2 {
  margin-bottom: 27px;
}

.area-reason .col2>div {
    width: 44%;
    font-size: 1.8rem;
}

.area-reason .col2>div:last-child {
  width: 54%;
}

.area-reason p {
  line-height: 1.5;
  font-size: 1.8rem;
}

.area-reason p.a1 {
  font-size: 3.2rem;
  color: #37abd6;
}


.area-reason:before {
  display: block; 
  height: 560px;  
  width: 98%;    
  position: absolute;
  bottom: -60px;    
  content: '';
  display: inline-block;
  vertical-align: middle;
  background: url(/images/bg-reason.png) center bottom no-repeat;
  -webkit-background-size: cover;
  background-size: cover; 
  z-index: -1;  
}

.area-reason .col2+.col2 {
  margin-top: 17px;
}

.okinawa {
  margin-top: 200px;
  padding-bottom: 55px;
  margin-bottom: 35px;
  background: url(/images/bg-okinawa.jpg) center center no-repeat;
    background-size: cover;
}

.okinawa img {
  margin-top: -87px;
}

.okinawa span {
  display: block;
  color: #fff;  
  font-weight: bold;
  margin-top: 30px;
  filter: drop-shadow(1px 1px 2px rgba(0,0,0,0.6));  
}

.col2.vitamin div {
  width: 50% !important;
}

.vitamin p {
  margin-left: 50px;
  margin-bottom: 25px;
  font-size: 1.8rem;
}

.mineral {
  margin: 60px 0;
  margin-left: 40px;
}

.area-whats {
  background: #fff url(/images/bg-whats.jpg) 0 0 no-repeat;
  -webkit-background-size: cover;
  background-size: cover;
  padding: 0 0 70px 0;
}

.area-whats h2 {
  background: #fff;
  margin-bottom: 50px;
  padding: 60px 0;
}

.area-effect {
  background: #f2f7fa;
}

.area-effect figure {
  overflow: hidden; 
  position: absolute;
  right: 55%;
  bottom: 0;
  height : 98% ; /* IE8以下とAndroid4.3以下用フォールバック */
  height : -webkit-calc(100% - 144px) ;
  height : calc(100% - 144px) ;  
  width: auto;
 
}

.area-effect figure img {
  height: 100%;
  max-width: 10000px;        
}

.area-effect h2 {
  background: #fff;
  padding: 50px 0;
  margin: 0;  
}

.area-effect ul {
  width: 61%;
  margin-left: auto;
  padding: 50px 0;  
  padding-inline-start: 0px;
}

.area-effect li {
  height: 180px;
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  line-height: 30px;
  font-size: 1.8rem;

  padding-left: 100px;
  align-items: center;
  margin: 0;  
  margin-bottom: 25px;
}

.area-effect li h3 {
  line-height: 28.8px;
  position: absolute;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
  justify-content: center;
  left: -120px;
  top: 0;
  width: 180px;
  height: 180px;
  background: #fff;
  border: 1px solid #DAAC2A;
  border-radius: 50%;
  color: #DAAC2A;
  text-align: center;
  margin: 0;
  filter: drop-shadow(5px 5px 5px rgba(0,0,0,0.1));
}

.area-commitment {
  padding: 60px 0;  
}

.area-commitment ul li {
  position: relative; 
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex; 
  flex-direction: column;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap; 
  justify-content: center;  
  height: 217px;
  overflow: hidden;   
  list-style-type: none;
  background: #F3F8FB;
  padding: 0 40px 0 300px;
  margin-top: 50px;
  font-size:  1.6rem;
  line-height: 1.8;    
}

.area-commitment ul li figure {
  height: 100%; 
  position: absolute;
  left: 0;  
  top: 0; 
}

.area-commitment img {
  height: 100%; 
}

.area-commitment ul li h3 {
  font-weight: bold;
  font-size:  3rem;
  color: #32ADF6;
  margin-bottom: 15px;
  margin-top: 0;
}

.area-commitment .a1 {
    text-align: center;
    font-size: 3.6rem;
    color: #32ADF6;
    margin-top: 25px;
}

.area-commitment .doctor {
    font-size: 1.8rem;
    margin-bottom: .5em;
    font-weight: bold;
    margin-top: .5em;
    color: #DAAC2A;
}

.area-commitment .media {
    font-size: 1.5rem;
}

.area-commitment .media p {
    line-height: 1.8;
}

.area-commitment .media strong {
    display: block;
}

.media .col2 {
    -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
        margin-top: 25px;
}

.media .col2>div {
    width: 48%;


}

.media .col2 ol {
    margin-left: 20px;
}

.media .col2>div.paper {
    padding: 40px;
    border: 1px solid #eee;
    background: #fff;
    filter: drop-shadow(5px 5px 5px rgba(0,0,0,0.2));
    border-radius: 10px;
}

.min-space {
    margin-top: -240px;
}

.area-voice {
   justify-content: center; 
}

.area-voice h2 {
  margin-bottom: 40px;  
}

.area-voice .colc {
  background: #f2f7fa; 
}

.area-voice .colc>div {
  width: 50%;
  max-height: 450px;
  overflow: hidden; 
}

.area-voice .colc>div figure {
  width: 100%;  
  overflow: hidden;
  display: -webkit-flex;
  display: table;
  vertical-align: middle; 

}

.area-voice .colc>div figure  img {
  width: 100%;
  display: table-cell;  
  vertical-align: middle;  
}

.area-voice .colc .textarea h3, .area-voice .colc .textarea p {
  max-width: 650px;  
  padding: 0 40px;  
}

.area-voice .colc .textarea h3 {
  width: 100%;
  font-size: 3.2rem;
  margin-bottom: 25px;
  color: #32ADF6;  
}

.area-voice .colc .textarea {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.area-voice p {
  line-height: 1.8; 
  font-size: 1.6rem;
}

.area-faq h2 {
  background: #fff; 
  padding: 60px 0 45px;  
  margin: 0;   
}

.area-faq {
  overflow: hidden; 
  background-size: auto auto;
  background-color: rgba(255, 255, 255, .1);
  background-image: repeating-linear-gradient(-45deg, transparent, transparent 9px, rgba(216, 170, 42, .1) 9px, rgba(216, 170, 42, .1) 15px );
}

.area-faq ul {
  list-style-type: none;
}

.faq-menu {
  padding: 70px 0 55px; 
}

.faq-menu label {
    position: relative;
    display: block;
    margin: 0;
    padding: 0.5rem;
    cursor: pointer;
    font-size: 1.6rem;
    font-weight: bold;
    background: #fff;
    border: 1px solid #DAAC2A;
    color: #DAAC2A;
    padding: 10px 20px 10px 55px;
}
.faq-menu label::before,
.faq-menu label::after {
    content: '';
    display: block;
    width: 20px;
    height: 1px;
    border-radius: 5px;
    background: #DAAC2A;
    position: absolute;
    left: 15px;  
    top: 50%;
    transform: translateY(-50%);
}

.faq-menu label::after {
      background: #DAAC2A;
      
      transition: 0.5s;
}

.faq-menu label:active::after {
  transform: translateY(-50%) rotate(90deg);
    transform: rotate(0);
    transition: 0.5s;
  }

.faq-menu input {
    display: none;
}

.faq-menu ul {
    position: relative;
    overflow: hidden;
    line-height: 0;
    padding: 0 20px;
    transition: 0.5s;
    list-style: none;
    margin: 0;
    margin-top: -1px; 
    margin-bottom: -1px;
    background: #FFF3DE;
    font-size: 1.6rem;
}

.faq-menu ul:before {
    content: '';
    display: block;
    position: absolute;
    left: 85px;
    top: 20px;
    width: 4px;
    height: 20px;
}

.faq-menu input:checked + ul {
    line-height: 1.5;
    padding: 1em 20px 1em 40px;
    border: 1px solid #DAAC2A;
}

p.trial {
  margin: 70px 0; 
}

p.satisfaction {
  text-align: center;
  background: #DAAC2A;
  padding: 25px 0;
  margin-bottom: 45px;      
}

.btn-area {
  padding: 70px 0;
  background: #f2f7fa;  
}

.btn-area img{
  filter: drop-shadow(5px 5px 5px rgba(0,0,0,0.1));
}

.postage_ex {
    margin: 3px 0 0 0;
    padding: 0 2em;
    font-weight: 500;
    font-size: 1.8rem;
}
.postage_ex::before {
    content: '※';
}
@media only screen and (max-width: 767px) {

  body {
    overflow-x: hidden;
  }

  section {

  }

  .inner {
    width: 96%; 
    margin: 0 2%; 
  }

  .kv-sp {

  }

  .kv {
    background-position:  right 40% center;
    height: 370px;  
  }

  .main-catch {
    width: 100%;
    background: none;
    margin-top: 50px;     
  }

  .main-catch p {
    margin: 0;  
  }

  .area-rank {
    padding: 25px 0 10px;  
  }

  .area-rank .col2>div {
    width: 100%;
    text-align: center;       
  }

  .area-rank .col2>div img {
    max-width: 90%;
    margin-bottom: 15px;
  }

  .ranking-catch {
    margin-bottom: 20px;  
  }

  .area-products {
    padding: 35px 0;  
  }

  .area-products li {
    font-size: 3.5vw;
    padding-left: 2px;
  }
    .postage_ex {
        font-size: 3.5vw;
    padding: 0 3vw 0 12vw;
    font-weight: 500;
    margin: 0;
    text-indent: -3vw;
    }

  .area-products li:before {
    width: 8px; 
    height: 8px;  
  }

  .area-products h2 {
    margin-bottom: 10px;  
  }

  .area-trouble {
    padding-top: 140px; 
  }

  .area-trouble p {
    margin-top: 0;  
  }

  .area-cause {
    padding: 30px 0;  
  }

  .area-cause h2 {
    max-width: 70%;
  }

  .area-cause figure {
    position: static; 
  }

  .area-cause p {
    font-size: 1.6rem;
  }

  .area-cause p br {
    display: none;  
  }

  .top-desc {
    display: block;
    padding-bottom: 30px; 
  }

  .top-desc h2 img {
    width: 80%; 
    position: static;
    margin-left: 20%;  
  }

  .top-desc h2 {
    width: 100%;  
    text-align: center; 
    margin: 0;  
  }

  .top-desc p {
    width: 100%;  
    line-height: 1.8; 
    padding: 0 2%; 
    margin-top: -60px;  
  }

  .top-desc br {
    display: none;  
  }

  .top-desc:before {
    z-index: -1;  
  }

  .top-desc:after {
    display: none;  
  }

  .area-reason {
    padding-top: 30px; 
    margin-bottom: 100px; 
  }

  .area-reason:before {
    width: 100%;  
  }

  .area-reason h2 {
    margin: 0 0 15px; 
  }

  .area-reason .col2>div, .area-reason .col2>div:last-child {
    width: 100%;  
  }

  .area-reason h3 img {
    width: 60%; 
  }

  .area-reason h3:last-child img {
    width: 30%; 
  }

  .area-reason p {
    margin-top: 100px; 
  }

  .area-reason p {
    margin-top: 0; 
    font-size: 1.4rem; 
  }

  .area-reason p.a1 {
    font-size: 2.2rem;
  }



  .area-reason p.okinawa {
    margin-top: 25px;
  }

  .okinawa img {
    margin-top: 25px; 
  }

  .col2.vitamin div {
    width: 100% !important;  
  }

  .mineral {
    margin-left: 0; 
    margin: 30px 0;
  }

  .mineral img {
    max-width: 75%;
  }
  
  .area-whats h2, .area-effect h2 {
    padding: 15px 0%; 
    padding: 15px 2%;   
  }

  .area-whats {
    padding-bottom: 30px; 
  }

  .area-effect ul {
    width: 100%;
    padding: 25px 0;   
  }

  .area-effect li {
    display: block; 
    font-size: 1.5rem;
  }

  .area-effect li br {
    display: none;  
  }

  .area-effect li {
    height: auto;
    padding-left: 0;
    margin-bottom: 15px;    
  }

  .area-effect figure img {
    display: none;  
  }

  .area-effect li h3 {
    width: 100%;  
    position: static;
    margin: 0 auto 10px; 
    height: auto;
    border-radius: 10px;
    width: 100%;
    padding: 5px 0;      
  }

  .area-commitment {
    padding: 30px 0;  
  }

  .area-commitment h2 {
    margin: 0;  
  }

  .area-commitment h2 img {
    max-width: 70%;
  }

  .area-commitment ul {
    margin-top: 15px; 
  }

  .area-commitment ul li {
    height: auto; 
    margin-top: 1px;
    display: block;
    padding: 7%;     
  }

  .area-commitment ul li figure {
    display: none;  
  }

  .area-commitment ul li h3 {
    font-size: 2rem;
    margin-top: 0;  
    margin-bottom: 7px; 
  }

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

  .area-voice h2 {
    margin: 0 0 15px; 
  }
  .area-voice h2 img {
    max-width:  50%;
    
  }

  .area-voice .colc>div {
    width: 100%;  
  }

  .area-voice .colc .textarea h3, .area-voice .colc .textarea p {
    padding: 0 2%;  
    font-size: 1.4rem;
  }

  .area-voice .colc .textarea h3 {
    margin: 10px 0;  
    font-size: 2rem;
  }

  .area-voice .colc .textarea p {
    margin-bottom: 1em; 
  }

  .area-faq h2 {
    padding: 30px 0 20px; 
  }

  .area-faq h2 img {
    max-width: 70%;
  }

  .faq-menu {
    padding: 30px 15px; 
  }

  .faq-menu label {
    padding-left: 30px;
    padding-right: 7px;
    font-size: 1.4rem;  
  }
  .faq-menu label::before, .faq-menu label::after {
    width: 7px; 
  }

  .faq-menu ul {
    font-size: 1.3rem;
  }

  .faq-menu input:checked + ul {
    padding-left: 20px; 
  }

  p.trial {
    margin: 20px 2%; 
  }

  p.satisfaction {
    padding: 25px 2%;  
  }

  p.item-last {
    overflow: hidden; 
    width: 120%;  
    margin-left: -15%; 
  }

  p.item-last img {
    width: 100%;
  }

  .btn-area {
    padding: 30px 0 15px;  
  }

  .btn-area .col2 {
    display: block; 
    text-align: center; 
  }

  .btn-area .col2 >div {
    width: 100%;
    margin-bottom: 15px;    
  }

  .main-catch figure {
    width: 70%; 
    right: 2%;  
  }

    .media .col2>div.paper {
        width: 100%;
        margin-bottom: 15px;
        padding: 20px;
    }

    .min-space {
        margin-top: 0;
    }

}

button{
        background-color: transparent;
        border: none;
        cursor: pointer;
        outline: none;
        padding: 0;
        appearance: none;
}

.text-center.buy {
  filter: drop-shadow(5px 5px 5px rgba(0,0,0,0.1));
}

.gotop {
    z-index: 100;
    position: fixed;
    width: 100%;
    text-align: center;
    left: 0;
    bottom: 0;
    background: rgba(242,247,250.7);
    display: table;
    height: 120px;
    padding: 0;
}
.gotop.unfixed {
    position: inherit;
    background: #FFF;
}
#gotopwrap {
    height: 120px;
}

#page_makelp1 .gotop {

}

.gotop img{
    height: 89px;
    margin-top: 20px;
}

#page_makelp1 #main_middle {
  display: none;
}

#page_makelp1 #footer {
  margin-top: 0;
}


.bottom_btn{
    display: flex;
    justify-content: center;
}
.bottom_btn li {
    margin: 0 8px 16px 8px;
}
#page_makelp1 #contents_top{
    padding-bottom: 30px;
}
.lp_product-img {
    max-width: 1400px;
    width: 100%;
}
.area_free01{
    padding: 1.5em;
    border: #d5b6a8 2px dashed;
    border-radius: 10px;
    max-width: 95%;
    margin: 5em auto;
    color: #000;
    background: #fef8f5;
}
.area_free02{
    padding: 1.5em;
    border: #a8c7d5 2px dashed;
    border-radius: 10px;
    max-width: 95%;
    margin: 5em auto;
    color: #156082;
    background: #f3fbfe;
}
#customer_box__login_menu,
.entry_btn {
    width: 100%;
}
.entry_btn a{
    display: block;
    padding: 20px;
    background: #ff4859;
    font-weight: bold;
    font-size: 20px;
    width: 100%;
    color: #FFF;
    text-align: center;
    border-radius: 5px;
}

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

  .gotop {
    height: 75px;
  }
    #gotopwrap {
        height: 240px;
    }


    .gotop img {
        height: inherit;
        width: 100%;
        margin: 0;
    }
    .bottom_btn {
        display: block;
        padding: 7px;
    }
    .bottom_btn li {
        margin: 2px 0;
    }
}

.item-table th, .item-table td {
  padding: 15px;
  border: 1px solid #ddd;
  font-size: 1.3rem;
}

.item-table th {
  width: 30%;
}

.item-table td {
  width: 70%;
}
.micro {
    font-size: 60% !important;
}

.teiki_obi{
    background: #e7f2f7;
    padding: 2px;
}
.teiki_obi_img{
    max-width: 800px;
    width: 100%;
}