@charset "UTF-8";
/* CSS Document */
/*スマホ→左右20px*/
/*コンテンツ間上下余白→上で設定50px*/
html {
  -webkit-text-size-adjust: 100%;
  font-size: 62.5% /*1rem=10px*/
}
body {
  background-color: #fce4f4;
  /*background-color: #00f;dummy*/
  font-family: 'M PLUS Rounded 1c', sans-serif; /*日本語フォント*/
  text-align: center;
}
#wrap {
  overflow: hidden;
}
nav, h2, .btn, #heroImage p:last-child {
  font-family: 'Poppins', sans-serif; /*英語フォント*/
  letter-spacing: 0.1em; /*文字間調整*/
}
#cont_onlineStore nav{
	font-family: 'M PLUS Rounded 1c', sans-serif; /*日本語フォント*/
}
/*------------------------------------header*/
header {
  padding: 20px;
}
#home header {
  background-image: url("../images/heloImage_bg.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  width: 100%;
  height: 100vh;
}
#onlineStore header, #faq header, #company header {
  background: #84d7c8;
  width: 100%;
  height: 180px;
}
@media screen and (min-width:940px) {
  #onlineStore header, #faq header, #company header {
    height: 140px;
  }
}
h1 {
  width: 80px;
  height: auto;
  float: left;
}
@media screen and (min-width:940px) {
  h1 {
    width: 100px;
  }
}
/*------------------------------------sns_icon*/
@font-face {
  font-family: 'icomoon';
  src: url('fonts/icomoon.eot?l5ez65');
  src: url('fonts/icomoon.eot?l5ez65#iefix') format('embedded-opentype'), url('fonts/icomoon.ttf?l5ez65') format('truetype'), url('fonts/icomoon.woff?l5ez65') format('woff'), url('fonts/icomoon.svg?l5ez65#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-line:before {
  content: "\e900";
  color: #fff;
}
.icon-pencil:before {
  content: "\e905";
}
.icon-user:before {
  content: "\e971";
}
.icon-instagram:before {
  content: "\ea92";
}
.icon_sns {
  text-align: center;
  float: right;
  margin-right: 6px;
  margin-top: 10px;
}
.icon_sns li {
  display: inline-block;
}
.icon_sns a {
  display: block;
  padding: 7px;
  background: #bc679d;
  color: #fff;
  border-radius: 10px;
  text-decoration: none;
  font-size: 40px;
}
.icon_sns li:nth-of-type(2) {
  margin-right: 20px;
}
.icon_sns a:hover {
  opacity: 0.7;
}
/*------------------------------------ハンバーガーメニュー*/
#drawer-checkbox {
  display: none;
}
#drawer-icon {
  cursor: pointer;
  display: inline-block;
  height: 70px; /*メニュー全体の高さ*/
  position: relative;
  width: 70px; /*メニュー全体の幅*/
}
#drawer-icon span {
  background: #b54d98; /*線の色中央*/
  border-radius: 5px; /*線の角を丸くするかしないか*/
  display: block;
  height: 16%; /*16*/
  left: 50%;
  margin: -8% 0 0 -42%;
  position: absolute;
  top: 50%;
  transition: all 0.3s ease-in-out;
  width: 84%;
}
#drawer-icon span::before, #drawer-icon span::after {
  -webkit-transform: rotate(0);
  background: #b54d98; /*線の色上下*/
  border-radius: 5px; /*線の角を丸くするかしないか*/
  content: "";
  display: block;
  height: 100%; /*線の高さ*/
  left: 50%;
  margin: -8% 0 0 -50%;
  position: absolute;
  top: 50%;
  transform: rotate(0);
  transition: all 0.3s ease-in-out;
  width: 100%;
}
#drawer-icon span::before {
  margin-top: -38%;
}
#drawer-icon span::after {
  margin-top: 19%;
}
#drawer-checkbox:checked ~ #drawer-icon span {
  background: rgba(51, 51, 51, 0);
}
#drawer-checkbox:checked ~ #drawer-icon span::before, #drawer-checkbox:checked ~ #drawer-icon span::after {
  content: "";
  display: block;
  height: 100%;
  left: 50%;
  margin: -8% 0 0 -42%;
  position: absolute;
  top: 50%;
  width: 100%;
}
#drawer-checkbox:checked ~ #drawer-icon span::before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
#drawer-checkbox:checked ~ #drawer-icon span::after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
#drawer-content {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 40;
  width: 250px;
  max-width: 90%;
  height: 100%;
  background: #fff;
  transition: all 0.3s ease-in-out 0s;
  transform: translateX(-100%);
}
#drawer-checkbox:checked ~ #drawer-content {
  transform: translateX(0);
  box-shadow: 6px 0 25px rgba(0, 0, 0, 0.16);
}
#drawer-close {
  display: none;
  position: fixed;
  z-index: 39;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0;
  transition: all 0.3s ease-in-out 0s;
}
#drawer-checkbox:checked ~ #drawer-close {
  display: block;
  opacity: 0.3;
}
#drawer-icon {
  float: right;
  /*margin-top:60px;*/
}
header {
  overflow: hidden;
}
header nav li a {
  color: #2ac1a6;
  font-size: 3rem;
  display: block;
}
header nav li {
  width: 100%;
  line-height: 70px;
}
header nav li:hover {
  background-color: #2ac1a6;
}
header nav li a:hover {
  color: #fff;
}
#home #nav_home, #onlineStore #nav_onlineStore, #faq #nav_faq, #company #nav_company {
  text-decoration: underline;
}
/*#home #nav_home a,#onlineStore #nav_onlineStore a,#faq #nav_faq a,#company #nav_company a{
	color:#e0219d;
}*/
/*------------------------------------改行*/
.br_sp {
  display: block;
}
.br_pc {
  display: none;
}
@media screen and (min-width:940px) {
  .br_sp {
    display: none;
  }
  .br_pc {
    display: block;
  }
}
/*------------------------------------.overflow*/
.overflow {
  overflow: hidden;
}
/*------------------------------------bold*/
.bold {
  font-weight: bold;
}
/*------------------------------------flex*/
.flex {
  display: block;
}
@media screen and (min-width:768px) {}
@media screen and (min-width:940px) {
  .flex {
    display: flex;
    justify-content: space-around;
  }
}
/*------------------------------------margin,padding*/
.mb20 {
  margin-bottom: 20px;
}
.mb30 {
  margin-bottom: 30px;
}
.mt20 {
  margin-top: 20px;
}
.mt30 {
  margin-top: 30px;
}
.mt40 {
  margin-top: 40px;
}
.mt60 {
  margin-top: 60px;
}
.plr {
  padding: 0 20px; /*左右隙間20px*/
}
.pt50 {
  padding-top: 50px; /*cont間*/
}
.pb50 {
  padding-bottom: 50px;
}
/*------------------------------------h2*/
h2 {
  overflow: hidden;
  text-align: right;
  /*padding-top: 50px;*/
  font-size: 3.5rem;
  color: #e0219d;
}
@media screen and (min-width:768px) {
  h2 {
    font-size: 5rem;
  }
}
@media screen and (min-width:940px) {
  h2 {
    font-size: 8rem;
  }
}
h2 span {
  display: flex;
  align-items: center;
}
h2 span::before {
  content: '';
  height: 2px;
  background-color: #e0219d;
  flex-grow: 1;
  margin-right: 20px;
}
/*------------------------------------h3*/
h3 {
  font-size: 2rem;
  color: #4e4e4e;
}
@media screen and (min-width:940px) {
  main h3 {
    font-size: 2.5rem;
  }
}
/*------------------------------------p*/
p {
  font-size: 1.5rem;
  color: #4e4e4e;
}
/*------------------------------------btn*/
.btn {
  /*line-height: 30px;*/
}
.btn a {
  display: block;
  font-size: 2rem;
  color: #fff;
}
/*------------------------------------footer*/
footer {
  background-color: #84d7c8;
  margin-top: 50px;
}
footer p {
  font-size: 1.2rem;
  color: #e0219d;
  line-height: 100px;
}
/*------------------------------------戻るボタン*/
#pagetop {
  position: fixed;
  bottom: 20px;
  right: 10px;
  background-color: rgba(132, 215, 200, 0.5);
  width: 70px;
  border-radius: 50%;
  line-height: 66px;
  border: 2px solid #e0219d;
  cursor: pointer;
}
@media screen and (min-width:940px) {
  #pagetop {
    width: 100px;
    line-height: 90px;
  }
  #pagetop a {
    color: #e0219d;
    font-size: 2rem;
  }
}
#pagetop a {
  color: #e0219d;
}
/*------------------------------------#home cont_concept*/
#home #cont_concept {
  background-color: #84d7c8;
  padding: 50px 20px;
}
#home #cont_concept p {
  font-size: 1.7rem;
  line-height: 40px;
}
/*------------------------------------#home cont_topic*/
#home #cont_topic {
  background: linear-gradient(to bottom right, #cfacd0, #fad1ac);
  padding-bottom: 25px;
}
#home #cont_topic p img {
  width: 100%;
  height: auto;
  display: inline-block;
  margin-top: 40px;
  box-shadow: 0 0 10px rgba(226, 86, 186, 0.5);
}
#cont_topic_ca-f {
  width: 100%;
  margin: 0 auto;
  background-color: #fce4f4;
  padding: 40px 20px;
  box-shadow: 0 0 10px rgba(226, 86, 186, 0.5);
}
#cont_topic_ca-f p {
  text-align: center;
}
.topic_pricebg {
  padding-top: 15px;
  line-height: 30px;
}
#cont_topic_ca-f h3 {
  padding-bottom: 15px;
  border-bottom: 1px solid #4e4e4e;
}
@media screen and (min-width:768px) {
  #cont_topic_block {
    width: 600px;
    margin: 0 auto;
  }
  #cont_topic_ca-f {
    padding: 40px 80px;
  }
}
@media screen and (min-width:940px) {
  #home #cont_topic p img {
    margin-top: 0px;
  }
  #cont_topic_block {
    width: 900px;
    margin: 0 auto;
  }
  #home #cont_topic p img {
    width: 350px;
    height: auto;
  }
  #cont_topic_ca-f {
    width: 500px;
    padding-top: 80px;
  }
}
#cont_topic .btn a {
  width: 300px;
  background-color: #b93e8e;
  color: #caefe8;
  padding: 15px;
  margin-top: 20px;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 25px;
}
@media screen and (min-width:940px) {
  #cont_topic .btn a:hover {
    background-color: #caefe8;
    color: #b93e8e;
    transition: 0.7s;
  }
}
/*------------------------------------cont_banner*/
/*#cont_banner{
	margin-top: 50px;
}*/
#onlineStore #cont_banner {
  margin-top: 100px;
}
#cont_banner li img {
  border: 10px solid #fff;
  width: 100%;
  height: auto;
}
@media screen and (min-width:768px) {
  #cont_banner li img {
    width: 600px;
    height: auto;
  }
}
@media screen and (min-width:940px) {
  #cont_banner img:hover {
    opacity: 0.5;
  }
  #onlineStore #cont_banner {
    margin-top: 150px;
  }
}
#cont_banner li {
  margin-top: 20px;
}
#cont_banner li:first-child {
  margin: 0;
}
/*------------------------------------#onlineStore cont_onlineStore*/
@media screen and (min-width:768px) {
  #cont_onlineStore section {
    width: 700px;
    margin: 0 auto;
  }
}
@media screen and (min-width:940px) {
  #cont_onlineStore section {
    width: 900px;
    margin: 0 auto;
  }
}
#cont_onlineStore nav { /*headerの下商品に飛べるやつ*/
  margin-top: 20px;
}
#cont_onlineStore nav ul {
  border: 3px solid #84d7c8;
}
#cont_onlineStore nav li {
  font-size: 1.5rem;
  line-height: 60px;
  overflow: hidden;
  border: 3px solid #fce4f4;
  border-bottom: none;
  width: 100%;
}
@media screen and (min-width:940px) {
  #cont_onlineStore nav li {
    line-height: 40px;
  }
}
#cont_onlineStore nav li:last-child {
  border-bottom: 3px solid #fce4f4;
}
#cont_onlineStore nav li a {
  color: #b93e8e;
  display: block;
  background-color: #84d7c8;
}
@media screen and (min-width:940px) {
  #cont_onlineStore nav li a:hover {
    color: #84d7c8;
    background-color: #b93e8e;
    transition: 0.7s;
  }
}
#point {
  margin-top: 20px;
  font-size: 1.5rem;
}
#point span {
  text-decoration: underline;
  padding-left: 5px;
  padding-right: 5px;
}
#point span a {
  color: #000;
}
#cont_onlineStore h3, #cont_onlineStore h4 {
  background-color: #b93e8e;
  border-radius: 20px;
  width: 200px;
  color: #84d7c8;
  display: inline-block;
  line-height: 40px;
}
#cont_onlineStore img {
  width: 100%;
  height: auto;
}
.onlineStore_plicebg {
  background-color: #caefe8;
  padding-top: 20px;
  padding-bottom: 20px;
  line-height: 30px;
}
#cont_onlineStore .mb20 {
  box-shadow: 0 0 10px rgba(226, 86, 186, 0.5);
}
@media screen and (min-width:768px) {
  #cont_onlineStore_ca li, #cont_onlineStore_cu li, #cont_onlineStore_do li, #cont_onlineStore_ma li {
    width: 500px;
    height: auto;
    display: inline-block;
  }
}
@media screen and (min-width:940px) {
  #cont_onlineStore_ca li, #cont_onlineStore_cu li, #cont_onlineStore_do li, #cont_onlineStore_ma li {
    width: 280px;
    height: auto;
  }
  #cont_onlineStore img:hover {
    transform: scale(1.2, 1.2);
    overflow: hidden;
  }
  #cont_onlineStore img {
    transition: 0.5s;
  }
}
/*------------------------------------#faq cont_faq*/
#faq #cont_faq h3 {
  border-radius: 20px;
  padding: 15px;
  background-color: #b93e8e;
  color: #84d7c8;
}
@media screen and (min-width:768px) {
  #faq #cont_faq section {
    margin: 0 auto;
    width: 700px;
  }
}
@media screen and (min-width:940px) {
  #faq #cont_faq section {
    margin: 0 auto;
    width: 900px;
  }
}
#faq #cont_faq h4 {
  padding-bottom: 10px;
  font-size: 1.5rem;
  color: #4e4e4e;
  border-bottom: 1px solid #4e4e4e;
}
dt, dd {
  font-size: 1.5rem;
}
dt {
  background-color: #4e4e4e;
  line-height: 60px;
}
dt {
  margin-top: 10px;
}
dt a {
  color: #fff;
  display: block;
}
.close {
  background-color: #bb4391;
}
.close a {
  border: none;
  color: #fff;
  font-size: 1.5rem;
  line-height: 60px;
}
@media screen and (min-width:940px) {
  dt {
    line-height: 40px;
    margin-top: 5px;
  }
  .close a {
    line-height: 40px;
  }
}
.more2 {
  display: none;
  margin-top: 20px;
  line-height: 30px;
}
.morefix2:target + .more2 {
  display: block;
}
.morefix2 {
  position: fixed;
  top: 0;
}
#cont_faq_2 > p {
  font-size: 1.3rem;
  margin-top: 20px;
}
#cont_faq_2 p {
  line-height: 30px;
}
#cont_faq_2 .btn {
  display: inline-block;
}
#cont_faq_2 .btn a {
  font-size: 1.5rem;
  background: #7c7c7c;
  padding: 15px;
  width: 300px;
  color: #fff;
  display: block;
  border: none;
}
@media screen and (min-width:940px) {
  #cont_faq_2 .btn a:hover {
    color: #84d7c8;
    background: #b93e8e;
  }
}
/*------------------------------------#company cont_campany*/
table {
  margin: 0 auto;
  border: 1px solid #7c7c7c;
}
th, td {
  display: block;
  width: 300px;
  line-height: 80px;
  font-size: 1.5rem;
  color: #4e4e4e;
  border: 1px solid #7c7c7c;
}
@media screen and (min-width:768px) {
  th, td {
    width: 500px;
  }
}
@media screen and (min-width:940px) {
  th, td {
    display: inline-block;
  }
  th {
    width: 300px;
  }
  td {
    width: 500px;
  }
}
th {
  background-color: #d3d3d3;
  font-weight: bold;
}
td {
  background-color: #fff;
}