@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Martian+Mono:wght@100..800&display=swap");
html, body {
  margin: 0;
  padding: 0;
}

html, body {
  margin: 0;
  padding: 0;
}

html p#breadCrumb {
  top: 40px;
}
@media (min-width: 992px) {
  html p#breadCrumb {
    top: 120px;
  }
}
html p#breadCrumb {
  color: #2D342C;
}
html p#breadCrumb a {
  color: #2D342C;
}
html .fade-in {
  opacity: 0;
  transform: translateY(10px);
  visibility: hidden;
  transition: opacity 0.6s ease-out, transform 1.2s ease-out;
  will-change: opacity, visibility;
}
html .fade-in.is-visible {
  opacity: 1;
  transform: none;
  visibility: visible;
}
html .fade-in.--2 {
  transition-delay: 300ms;
}
html .fade-in.--3 {
  transition-delay: 500ms;
}

#lp {
  font-family: "Noto Sans JP";
  padding-top: 120px;
  padding-bottom: 90px;
  /* pcOnly spOnly */
}
@media (max-width: 767px) {
  #lp {
    padding-top: 40px;
    padding-bottom: 60px;
  }
}
@media (max-width: 767px) {
  #lp .pcOnly {
    display: none !important;
  }
}
#lp .spOnly {
  display: none !important;
}
@media (max-width: 767px) {
  #lp .spOnly {
    display: block !important;
  }
}
#lp h1, #lp h2, #lp h3, #lp h4, #lp h5, #lp h6, #lp p, #lp span, #lp a, #lp ul, #lp li {
  margin: 0;
}
#lp * {
  box-sizing: content-box;
}
#lp .img-hover {
  position: relative;
  overflow: hidden;
}
#lp .img-hover > img:last-child {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: 0.15s;
  transform: scale(1.1);
}
#lp .img-hover:hover img:last-child,
#lp .img-hover:active img:last-child {
  opacity: 1;
  transition: 0.15s;
}
#lp img {
  max-width: 100%;
  width: 100%;
  display: block;
}
#lp .page-width {
  max-width: 1155px;
  padding: 0 30px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: content-box;
}
@media (max-width: 767px) {
  #lp .page-width {
    padding: 0 15px;
  }
}
#lp .page-width-b {
  max-width: 1200px;
  padding: 0 30px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: content-box;
}
@media (max-width: 767px) {
  #lp .page-width-b {
    padding: 0 15px;
  }
}

#lp .secA {
  overflow: hidden;
  margin-bottom: 100px;
}
@media (max-width: 767px) {
  #lp .secA {
    margin-bottom: 14px;
  }
}
#lp .secA .mvcontents {
  display: block;
  position: relative;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}
#lp .secA .img01 {
  max-width: 1000px;
  width: 100%;
}
#lp .secA .textbox_right01 {
  display: block;
  position: absolute;
  top: 40%;
  right: 5%;
  width: 40%;
  /* background: #fff; */
  color: #000;
  font-family: Noto Sans JP;
  font-size: 15px;
  font-weight: 300;
  line-height: 30px;
  text-align: left;
}
@media (max-width: 767px) {
  #lp .secA .textbox_right01 {
    display: block;
    padding: 0 15px 0px;
    position: relative;
    width: 95%;
    top: unset;
    right: unset;
  }
}
#lp .secA h1 {
  font-family: "Noto Serif JP";
  font-size: 26px;
  font-weight: 400;
  line-height: 48px;
  letter-spacing: 3px;
  text-align: left;
  margin-bottom: 27px;
}
@media (max-width: 767px) {
  #lp .secA h1 {
    font-size: 20px;
    font-weight: 400;
    line-height: 32px;
    letter-spacing: 1px;
    text-align: left;
    margin-bottom: 10px;
    margin-top: 30px;
  }
}
#lp .secA span {
  font-family: "Martian Mono";
  font-size: 16px;
  font-weight: 300;
  line-height: 34px;
  letter-spacing: 1px;
  text-align: left;
}
@media (max-width: 767px) {
  #lp .secA span {
    font-size: 12px;
    font-weight: 300;
    line-height: 34px;
    letter-spacing: 1px;
    text-align: left;
  }
}
#lp .secB {
  overflow: hidden;
}
#lp .secB .box {
  position: relative;
  padding-top: 136px;
  padding-bottom: 34px;
  padding-right: 49%;
}
@media (max-width: 767px) {
  #lp .secB {
      margin: 0 0 8rem;
  }
  #lp .secB .box {
    padding-bottom: 0;
    padding-top: 0;
    padding-right: 0;
  }
}
#lp .secB .box h3 {
  font-family: "Noto Serif JP";
  font-size: 18px;
  font-weight: 300;
  line-height: 48px;
  text-align: center;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  margin-bottom: 30px;
}
#lp .secB .box p {
  font-size: 15px;
  font-weight: 300;
  line-height: 2em;
  text-align: left;
  letter-spacing: 0.2em;
}
@media (max-width: 767px) {
  #lp .secB .box p {
    font-size: 13px;
    font-weight: 300;
    line-height: 26px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}
#lp .secB .box .box__text {
  position: relative;
  z-index: 2;
}
#lp .secB .box .box__image {
  position: absolute;
  right: 0;
  bottom: 0;
  max-width: 450px;
  padding-right: 130px;
}
@media (max-width: 767px) {
  #lp .secB .box .box__image {
    position: static;
    right: -15px;
    max-width: 100%;
    top: inherit;
    bottom: 0;
    right: inherit;
    left: 0;
    margin-top: 42px;
    padding-right: 0;
  }
}
#lp .secB .box .box__image .img02 {
  /* margin-right:40px; */
}
@media (max-width: 767px) {
  #lp .secB .box .box__image .img02 {
    max-width: 70.39vw;
  }
}
#lp .secB .box .box__image .img03 {
  position: absolute;
  width: auto;
  right: 0;
  bottom: 150px;
}
@media (max-width: 767px) {
  #lp .secB .box .box__image .img03 {
    bottom: -62px;
    right: 0;
    width: 46.93vw;
    position: static;
    margin-left: auto;
    margin-bottom: -100px;
  }
}
#lp .secC {
  margin-top: 100px;
  margin-bottom: 60px;
}
@media (max-width: 767px) {
  #lp .secC {
    margin-top: 0px;
    margin-bottom: 60px;
  }
}
#lp .secC p.new{
  text-align:center;
  margin-bottom: 60px;
}
 #lp .secC .page-width{
   max-width:730px;
 }
 #lp .secC .page-width.wide{
   max-width:1055px;
 }
#lp .secC p.new span{
  background:#EBDDCF;
  padding:0.3em 4em;
  font-size:1.15em;
}
#lp .secC .about{
  margin-top:70px;
}
#lp .secC .about h3{
  text-align:center;
}
#lp .secC .layout{
  margin-top:35px;
  display:flex;
  gap: 12%;
}
#lp .secC .layout .pic{
  flex: 0 0 26%;
}
@media (max-width: 767px) {
  #lp .secC .layout{
    flex-direction:column;
  }
  #lp .secC .layout .pic{
    display:flex;
    gap: 5%;
    padding: 0 8%;
  }
  #lp .secC .layout .pic img{
    flex: 1 1 auto;
    margin: 0;
    max-width: max-content;
    height: auto;
    width: 40%;
  }
}
#lp .secC .layout .txt ul{
  margin-top:1em;
}
#lp .secC .layout .txt ul li + li{
  margin-top:0.8em;
}
#lp .secC .layout .txt ul li:before{
  content:"";
  width:0.96em;
  height:1.5em;
  background: url('./img/secC_arrow.png') no-repeat;
  background-size:contain;
  display:inline-block;
  vertical-align:middle;
  margin-right:0.6em;
}
#lp .secC .layout .txt .note{
  margin-top:3.5em;
  font-size:0.65em;
}
#lp .secC .layout .txt .tobuy{
  padding-top:2em;
}
#lp .secC .layout .txt .tobuy a{
  color:#333;
  border:1px solid #EFE6DA;
  text-decoration: none;
  display: inline-block;
  padding: 0.4em 9em;
}
@media (max-width: 767px) {
  #lp .secC .layout .txt ul{
    font-size:12px;
  }
}

#lp .secC .img01 {
  margin-bottom: 50px;
}
@media (max-width: 767px) {
  #lp .secC .img01 {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    max-width: 100vw;
    margin-bottom: 30px;
  }
}
#lp .secC .box {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
}
@media (max-width: 767px) {
  #lp .secC .box {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
#lp .secC .box > div:last-child {
  align-self: center;
  margin-bottom: auto;
}
#lp .secC .box.--p2 {
  margin-top: 50px;
}
@media (max-width: 767px) {
  #lp .secC .box.--p2 {
    margin-top: 40px;
  }
}
#lp .secC .box.--1 h3 {
  font-size: 18px;
  font-weight: 400;
  line-height: 28px;
  text-align: left;
}
@media (max-width: 767px) {
  #lp .secC .box.--1 h3 {
    font-size: 15px;
    font-weight: 400;
    line-height: 26px;
  }
}
#lp .secC .box span {
  font-family: Martian Mono;
  font-size: 15px;
  font-weight: 400;
  line-height: 18px;
  letter-spacing: 0.1em;
  display: block;
}
@media (max-width: 767px) {
  #lp .secC .box span {
    font-size: 13px;
    font-weight: 400;
    line-height: 15.6px;
    letter-spacing: 0.1em;
  }
}
#lp .secC .box h3 {
  font-size: 17px;
  font-weight: 400;
  line-height: 28.96px;
  margin-bottom: 40px;
  margin-top: 6px;
  display:flex;
  gap: 3%;
}
#lp .secC .box h3 {
}
@media (max-width: 767px) {
  #lp .secC .box h3 {
    font-size: 18px;
    font-weight: 400;
    line-height: 26.06px;
    margin-bottom: 20px;
    margin-top: 5px;
  }
}
#lp .secC .box p {
  font-size: 15px;
  font-weight: 300;
  line-height: 26px;
}
@media (max-width: 767px) {
  #lp .secC .box p {
    font-size: 12px;
    font-weight: 300;
    line-height: 22px;
    margin-top: 15px;
  }
}
#lp .secC .box p + span:last-child {
  font-family: Noto Sans JP;
  font-size: 12px;
  font-weight: 300;
  line-height: 17.38px;
  display: block;
  margin-top: 36px;
}
@media (max-width: 767px) {
  #lp .secC .box p + span:last-child {
    font-size: 10px;
    font-weight: 300;
    line-height: 14.48px;
    margin-top: 20px;
  }
}
#lp .secC .box + .box {
  margin-top: 50px;
}
@media (max-width: 767px) {
  #lp .secC .box + .box {
    margin-top: 40px;
  }
}
#lp .secC span.js-more {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #2D342C;
  color: #2D342C;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  cursor: pointer;
  width: 400px;
  height: 50px;
  font-size: 15px;
  font-weight: 300;
  line-height: 21.72px;
  margin-top: 30px;
}
@media (max-width: 767px) {
  #lp .secC span.js-more {
    width: 345px;
    font-size: 12px;
    font-weight: 300;
    line-height: 17.38px;
    margin-top: 20px;
  }
}
#lp .secC .js-more-content {
  display: none;
  margin-top: 50px;
}
@media (max-width: 767px) {
  #lp .secC .js-more-content {
    margin-top: 30px;
  }
}
#lp .secC .js-more-content h4 {
  font-size: 20px;
  font-weight: 400;
  line-height: 28.96px;
  text-align: center;
  margin: 0 auto 20px;
  background: #EFE6DA;
  width: fit-content;
  padding: 0.3em 2em;
}
#lp .secC .js-more-content * + h4{
  margin-top: 60px;
}
@media (max-width: 767px) {
  #lp .secC .js-more-content h4 {
    font-size: 16px;
    margin-bottom: 15px;
  }
}
#lp .secC .js-more-content h5, #lp .secC .js-more-content p {
  font-size: 15px;
  font-weight: 300;
  line-height: 26px;
}
@media (max-width: 767px) {
  #lp .secC .js-more-content h5, #lp .secC .js-more-content p {
    font-size: 12px;
    font-weight: 300;
    line-height: 22px;
  }
}
#lp .secC .js-more-content .work p{
  text-align:center;
}
#lp .secC .js-more-content .work img{
  width:auto;
  margin: 0 auto;
}
#lp .secC .js-more-content p:not(:last-child) {
  margin-bottom: 40px;
}
@media (max-width: 767px) {
  #lp .secC .js-more-content p:not(:last-child) {
    margin-bottom: 30px;
  }
}
#lp .secC .js-more-content h5 {
  font-weight: 400;
}
#lp .secC .js-more-content img {
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  #lp .secC .js-more-content img {
    margin-bottom: 15px;
  }
}
#lp .secC .js-more.open .icon::after {
  display: none;
}
#lp .secC .js-more.open .icon::after {
  display: none;
}
#lp .secC .icon {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translate(-50%, -50%);
}
#lp .secC .icon::before,
#lp .secC .icon::after {
  content: "";
  position: absolute;
  background-color: #2D342C;
}
#lp .secC .icon::before {
  width: 24px;
  height: 1px;
  top: 0;
  bottom: 0;
  right: 15px;
  margin: auto;
}
#lp .secC .icon::after {
  width: 1px;
  height: 24px;
  top: 0;
  bottom: 0;
  right: 26px;
  margin: auto;
}
#lp .secC h2 {
  margin: 0;
  font-size: 22px;
  font-weight: 400;
  line-height: 26.4px;
  text-align: left;
  color: #2C1B1B;
  margin-bottom: 30px;
}
@media (max-width: 767px) {
  #lp .secC h2 {
    font-size: 18px;
    font-weight: 400;
    line-height: 30px;
  }
}
#lp .secC .anchor {
  max-width: 596px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 60px;
}
@media (max-width: 767px) {
  #lp .secC .anchor {
    gap: 15px;
  }
}
#lp .secC .anchor a {
  font-size: 15px;
  font-weight: 400;
  line-height: 21.72px;
  text-align: center;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  text-decoration: none;
  color: #2D342C;
  position: relative;
  padding-bottom: 20px;
}
@media (max-width: 767px) {
  #lp .secC .anchor a {
    font-size: 13px;
    font-weight: 400;
    line-height: 18.82px;
    text-align: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}
#lp .secC .anchor a img {
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  #lp .secC .anchor a img {
    margin-bottom: 4px;
  }
}
#lp .secC .anchor a::before {
  position: absolute;
  content: "";
  transform: rotate(135deg);
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 16px;
  height: 16px;
  border-top: 1px solid #2D342C;
  border-right: 1px solid #2D342C;
  z-index: 2;
}
@media (max-width: 767px) {
  #lp .secC .anchor a::before {
    width: 10px;
    height: 10px;
  }
}
#lp .secC .banner {
  margin-top: 40px;
  display: block;
}
@media (max-width: 767px) {
  #lp .secC .banner {
    margin-top: 20px;
  }
}
#lp .secD {
  padding: 90px 0;
  background: #F9F8F1;
  overflow: hidden;
  max-width: 100%;
  box-sizing: content-box;
}
#lp .secD h2{
  padding-bottom:80px;
  text-align:center;
}
@media (max-width: 767px) {
  #lp .secD {
    padding: 60px 0;
  }
  #lp .secD h2{
    padding-bottom:50px;
    font-size:18px;
  }
}
#lp .secD .text-with-image2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 {
    display: block;
  }

  #lp .secD .text-with-image2 > div:first-child{
   margin-bottom: 15px; 
  }
}
#lp .secD .text-with-image2 div {
  align-self: start;
}
#lp .secD .recommendfor {
  background:#FFF;
  margin-top: 4em;
  padding:2em;
}
#lp .secD .recommendfor dl {
  width:fit-content;
  margin:0 auto;
}
#lp .secD .recommendfor dl dt {
  margin:0 auto;
  width: 80%;
  border-bottom:1px solid #333;
  padding-bottom:0.6em;
  margin-bottom: 0.6em;
  font-weight: normal;
  text-align: center;
  font-size: 1.4rem;
}
#lp .secD .recommendfor dl dd {
  width:fit-content;
  font-size: 1.3rem;
  display: flex;
}
#lp .secD .recommendfor dl dd:before{
  content:"";
  display:inline-block;
  width:2.7em;
  height:2em;
  background:url('./img/secD_icon.png') center no-repeat;
  background-size:cover;
  vertical-align: bottom;
}
@media (max-width: 767px) {
  #lp .secD .recommendfor dl dt {
    padding:0 1em;
  }
  #lp .secD .recommendfor dl dd {
    font-size:12px;
  }
}

@media (max-width: 767px) {
  #lp .secD .text-with-image2 img {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    max-width: 100vw;
  }
}
#lp .secD .text-with-image2 h3 {
  font-size: 22px;
  font-weight: 300;
  line-height: 26.4px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  margin-bottom: 4px;
  color: #2C1B1B;
  margin-top: 15px;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 h3 {
    font-size: 18px;
    font-weight: 300;
    line-height: 21.6px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    margin-top: 10px;
  }
}
#lp .secD .text-with-image2 span.tag {
  font-size: 13px;
  font-weight: 300;
  line-height: 18.82px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  height: 23px;
  padding: 0 6px;
  border: 1px solid #666464;
  color: #666464;
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 span.tag {
    font-size: 12px;
    font-weight: 300;
    line-height: 17.38px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    height: 21px;
  }
}
#lp .secD .text-with-image2 span.price {
  font-size: 15px;
  font-weight: 400;
  line-height: 18.15px;
  display: block;
  margin-bottom: 25px;
  color: #2C1B1B;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 span.price {
    margin-bottom: 16px;
  }
}
#lp .secD .text-with-image2 span.price small {
  font-size: 12px;
  font-weight: 400;
  line-height: 14.4px;
}
#lp .secD .text-with-image2 .p1 {
  font-size: 18px;
  font-weight: 400;
  line-height: 28px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  margin-bottom: 28px;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 .p1 {
    font-size: 15px;
    font-weight: 400;
    line-height: 26px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    margin-bottom: 26px;
  }
}
#lp .secD .text-with-image2 .p2 {
  font-size: 15px;
  font-weight: 300;
  line-height: 26px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 .p2 {
    font-size: 12px;
    font-weight: 300;
    line-height: 22px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}
#lp .secD .text-with-image2 a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 345px;
  height: 45px;
  color: #fff;
  background: #BEBA79;
  text-decoration: none;
  border-radius: 5px;
  margin-top: 30px;
  font-size: 15px;
  font-weight: 500;
  line-height: 21.72px;
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 a {
    font-size: 15px;
    font-weight: 500;
    line-height: 21.72px;
    letter-spacing: 0.1em;
    text-align: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    margin-top: 25px;
    width: 100%;
  }
}
#lp .secD .text-with-image2 a.banner {
  display: block;
  border: none;
  width: 100%;
  margin-top: 37px;
  background: transparent;
  height: fit-content;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 a.banner {
    margin-top: 20px;
    max-width: 100%;
  }
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2 a.banner img {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}
#lp .secD .text-with-image2:not(:last-child) {
  margin-bottom: 60px;
}
@media (max-width: 767px) {
  #lp .secD .text-with-image2:not(:last-child) {
    margin-bottom: 50px;
  }
}
#lp .secD ul {
  padding: 0;
  margin: 0;
  margin-top: 22px;
}
@media (max-width: 767px) {
  #lp .secD ul {
    margin-top: 8px;
  }
}
#lp .secD ul li {
  padding: 0;
  margin: 0;
  list-style: none;
  display: flex;
  font-size: 12px;
  font-weight: 300;
  line-height: 17px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
}
@media (max-width: 767px) {
  #lp .secD ul li {
    font-size: 10px;
    font-weight: 300;
    line-height: 17px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}
#lp .secD .key {
  margin-top: 32px;
  text-align: center;
}
@media (max-width: 767px) {
  #lp .secD .key {
    margin-top: 20px;
    text-align: left;
  }
}
@media (max-width: 767px) {
  #lp .secD .key img {
    width: 100%;
    height: 100%;
    margin-right: auto;
    margin-left: 0;
    max-width: 345px;
  }
}
#lp .secD .key span {
  font-size: 15px;
  font-weight: 400;
  line-height: 18.15px;
  text-align: center;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  margin-bottom: 12px;
  display: block;
}
@media (max-width: 767px) {
  #lp .secD .key span {
    font-size: 13px;
    font-weight: 400;
    line-height: 15.73px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    margin-bottom: 10px;
  }
}
#lp .secE {
  padding: 90px 0;
}
@media (max-width: 767px) {
  #lp .secE {
    padding: 60px 0;
  }
}
#lp .secE .page-width > div:not(:last-child) {
  margin-bottom: 50px;
}
@media (max-width: 767px) {
  #lp .secE .page-width > div:not(:last-child) {
    margin-bottom: 40px;
  }
}
#lp .secE h2 {
  font-size: 22px;
  font-weight: 400;
  line-height: 31.86px;
  text-align: center;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  margin-bottom: 30px;
}
@media (max-width: 767px) {
  #lp .secE h2 {
    font-size: 18px;
    font-weight: 400;
    line-height: 30px;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    margin-bottom: 20px;
  }
}
#lp .secE p {
  font-family: "Martian Mono", "Noto Sans JP";
  font-size: 18px;
  font-weight: 400;
  line-height: 21.6px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  #lp .secE p {
    font-size: 15px;
    font-weight: 400;
    line-height: 18px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}
#lp .secF {
  margin-bottom: 100px;
}
#lp .secF h2 {
  font-size: 22px;
  font-weight: 400;
  line-height: 31.86px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
  margin-bottom: 24px;
}
@media (max-width: 767px) {
  #lp .secF h2 {
    font-size: 18px;
    font-weight: 400;
    line-height: 30px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    margin-bottom: 20px;
  }
}
#lp .secF .qa .q, #lp .secF .qa .a {
  display: flex;
  gap: 10px;
}
#lp .secF .qa .q {
  padding: 15px 28px;
  background: #F9F8F1;
}
@media (max-width: 767px) {
  #lp .secF .qa .q {
    padding: 10px 15px;
  }
}
#lp .secF .qa .q span {
  font-family: "Martian Mono";
  font-size: 18px;
  font-weight: 300;
  line-height: 32px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
}
@media (max-width: 767px) {
  #lp .secF .qa .q span {
    font-size: 13px;
    font-weight: 300;
    line-height: 24px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}
#lp .secF .qa .q p {
  font-size: 18px;
  font-weight: 400;
  line-height: 32px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
}
@media (max-width: 767px) {
  #lp .secF .qa .q p {
    font-size: 13px;
    font-weight: 400;
    line-height: 24px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}
#lp .secF .qa .a {
  padding: 15px 28px 30px;
}
@media (max-width: 767px) {
  #lp .secF .qa .a {
    padding: 15px;
  }
}
#lp .secF .qa .a span {
  font-family: "Martian Mono";
  font-size: 18px;
  font-weight: 300;
  line-height: 32px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
}
@media (max-width: 767px) {
  #lp .secF .qa .a span {
    font-size: 13px;
    font-weight: 300;
    line-height: 24px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}
#lp .secF .qa .a p {
  font-size: 15px;
  font-weight: 400;
  line-height: 28px;
  text-align: left;
  text-underline-position: from-font;
  text-decoration-skip-ink: none;
}
@media (max-width: 767px) {
  #lp .secF .qa .a p {
    font-size: 12px;
    font-weight: 400;
    line-height: 20px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
  }
}  
@media (max-width: 767px) {
  #lp .secB .box h3 {
    font-size: 20px;
    line-height: 32px;
    margin-bottom: 10px;
  }
}

#lp .secG {
  padding: 70px 0;
}
#lp .secG  .page-width{
  max-width:1057px;
}
#lp .secG h2{
  border-bottom: 1px solid #8E867B;
  text-align:center;
  padding: 0 1em 0.7em;
  width:fit-content;
  margin: 0 auto 50px;
}
#lp .secG  .condition{
  width:fit-content;
  margin: 0 auto;
}
#lp .secG  .condition li{
  width:fit-content;
  display:flex;
  align-items:flex-start;
  gap:1.5em;
  font-size:18px;
}
#lp .secG  .condition li + li{
  margin-top:1.5em;
}
#lp .secG  .condition li span{
  border: 1px solid #8E867B;
  padding:0.4em 1.2em;
  font-size:16px;
}
#lp .secG  .condition li p{
  padding:0.1em 0;
  font-size:18px;
  line-height:2.3;
}
@media (max-width: 767px) {
  #lp .secG .condition li {
    gap:1em;
  }
  #lp .secG .condition li span{
    font-size:12px;
    white-space: nowrap;
  }
  #lp .secG  .condition li p{
    font-size:14px;
  }
}
#lp .secG  .product{
  margin: 45px 0 0;
  display:flex;
  justify-content:space-between;
}
#lp .secG  .product li .tag{
  margin:1.6em 0;
  display:flex;
  gap:4%;
}
#lp .secG  .product li .tag span{
  background:#EFE6DA;
  color:#333;
  padding:0.3em 1em;
}
#lp .secG  .product li .tocart{
  margin-top:30px;
  text-align:center;
}
#lp .secG  .product li .tocart a{
  color:#333;
  border:1px solid #EFE6DA;
  text-decoration: none;
  display: inline-block;
  padding: 0.4em 9em;
}
@media (max-width: 767px) {
  #lp .secG  .product{
    flex-direction:column;
    gap: 50px;
  }
  #lp .secG  .product h3{
    font-size:16px;
  }
  #lp .secG  .product p{
    font-size:13px;
  }
}
#lp .secG  .cream{
  padding: 60px;
  display:flex;
  gap: 5%;
  align-items:center;
}
#lp .secG  .cream h3 {
  margin-top:3em;
}
#lp .secG  .cream .condition {
  margin-top:25px;
}
#lp .secG  .cream .condition li p{
  font-size:16px;
}
@media (max-width: 767px) {
  #lp .secG  .cream{
    flex-direction:column;
  }
  #lp .secG  .cream h3{
    font-size:16px;
  }
  #lp .secG .cream .condition li p{
    font-size:13px;
  }
}
@media (max-width: 767px) {
  #lp .secG {
    padding: 60px 0;
  }
}

#lp .secH {
  padding: 70px 0;
  background:#EFE6DA;
}
#lp .secH .page-width{
  max-width:1026px;
}
#lp .secH h2 {
  text-align:center;
  padding-bottom:70px;
}
#lp .secH h2 span {
  background:#FFF;
  text-align:center;
  padding: 0.3em 4em 0.5em;
}
#lp .secH .campaign{
  display:flex;
  flex-wrap:wrap;
  gap: 30px 2%;
}
#lp .secH .campaign h3{
  flex: 0 0 100%;
}
#lp .secH .campaign dl{
  flex: 0 0 49%;
}
#lp .secH .campaign dl dt{
  font-size:20px;
  padding-bottom: 30px;
  font-weight:normal;
  display: flex;
  align-items: flex-end;
}
#lp .secH .campaign dl dt span{
  font-size:2.4em;
  color:#FFF;
  margin-right:-0.2em;
  line-height: 1;
  margin-bottom: 0.25em;
}
#lp .secH .campaign dl dd p{
  max-width:26em;
  margin-bottom:1.5em;
  color: #333;
  font-size: 16px;
}
#lp .secH .campaign .regulation li{
  display:flex;
  align-items:flex-start;
}
#lp .secH .campaign .regulation li span{
  background:#FFF;
  padding:0 0.7em;
  margin-right:0.7em;
}
#lp .secH .campaign .regulation li p{
  max-width:unset;
  font-size:16px;
  margin-bottom: 0.5em;
}
#lp .secH .campaign .instalive{
  margin-top:60px;
  padding: 60px 50px 40px;
  border:1px solid #333;
  border-radius:30px;
  background:url('./img/secH_icon.png') right 10% top 10% no-repeat;
}
#lp .secH .campaign .instalive p + p{
  margin-top: 8em;
}
#lp .secH .campaign .more {
    margin: 2em 0 0;
    text-align: center;
}
#lp .secH .campaign .more a{
    color: #000;
    border: 1px solid #000;
    border-radius:0.6em;
    text-decoration: none;
    padding:0.5em 1.2em;
    font-size:1.4rem;
}
#lp .secH .campaign .more a:hover{
    background: #ccc
}
#lp .secH .campaign .more a i{
    font-size:0.8em;
    margin-right: 0.7em;
}    
@media (max-width: 767px) {
  #lp .secH .campaign{
    flex-direction:column;
  }
  #lp .secH .campaign h3{
    text-align:center;
  }
  #lp .secH .campaign dl dt{
    font-size:16px;
  }
  #lp .secH .campaign dl dd p{
    font-size:14px;
  }
  #lp .secH .campaign .regulation li span{
    font-size:12px;
  }
  #lp .secH .campaign .regulation li p{
    font-size:12px;
  }
  #lp .secH .campaign .instalive{
    margin: 50px 40px 0;
    padding: 30px;
    background-size: 50% auto;
  }
  #lp .secH .campaign .instalive p + p{
    font-size:12px;
  }
}
#lp .secH .toinstagram{
  margin-top:5em;
  text-align:center;
  font-size:20px;
}
#lp .secH .toinstagram a{
  color:#333;
  background:url('./img/secH_arrow.png  ') center bottom no-repeat;
  background-size:contain;
  text-decoration:none;
  padding: 0.3em 3em;
}

@media (max-width: 767px) {
  #lp .secH {
    padding: 60px 0;
  }
}

#lp .secI {
  padding: 250px 0 0;
}
#lp .secI h2{
  text-align:center;
  color:#FF6E6E;
}
@media (max-width: 767px) {
  #lp .secI {
    padding: 60px 0;
  }
  #lp .secI h2{
    font-size:14px;
  }
}


#lp .secComic{
  padding:40px 0;
}
#lp .secComic ul.comic {
  max-width:800px;
  margin:0 auto;
}

#lp .secComic ul.comic .slick-arrow {
  width: 40px;
  height: 40px;
  left:-45px;
  z-index: 2;
}
#lp .secComic ul.comic .slick-next.slick-arrow {
  left:unset;
  right:-45px;
}
#lp .secComic ul.comic .slick-arrow:before {
  color:#333;
  font-size: 40px;
}

@media (max-width: 767px) {
  #lp .secComic ul.comic {
    max-width:90vw;
  }
  #lp .secComic ul.comic .slick-arrow {
    width: 10vw;
    height: 10vw;
    left:-5vw;
  }
  #lp .secComic ul.comic .slick-next.slick-arrow {
    left:unset;
    right:-5vw;
  }
  #lp .secComic ul.comic .slick-arrow:before {
    color:#333;
    font-size: 10vw;
  }
}