﻿
.l-recommend {
  min-width: 960px;
  /* width: 87%; */
  position: relative;
  top: 100px;
  /* background-color: #fff; */
}

.l-recommend__space {
  width: 100%;
  max-width: 1260px;
  /* height: 160px; */
  padding-bottom: 0;
  align-items: center;
  margin: 0 auto;
}

.l-recommend__img>img {
  width: 100%
}

.l-recommend__items {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  max-width: 800px;
  padding: 0 20px;
  margin: 0 auto;
  background: none;
}

.l-recommend__item {
  flex-basis: 31%;
}

.l-recommend__btn {
  background-color: #221815;
  color: #fff;
  display: inline-block;
  text-align: center;
  width: 100%;
  max-width: 300px;
  height: 60px;
  line-height: 60px;
  border-radius: 30px
}

.l-recommend__btn:hover {
  background-color: transparent;
  color: #221815;
  border: 1px solid #221815
}

.c-banner {
  width: 100%;
  height: 720px;
  background-image: url("../img/layout/banner/banner.jpg");
  background-size: cover;
  background-position: 50%;
  position: relative
}

.c-banner__group {
  position: absolute;
  top: 95px;
  left: 180px;
  color: #fff
}

.c-banner__content {
  margin-bottom: 80px
}

.c-banner__btn {
  background-color: #000;
  color: #fff;
  display: inline-block;
  width: 500px;
  height: 80px;
  line-height: 80px;
  text-align: center;
  font-size: 1.8rem;
  border-radius: 40px
}

.c-banner__btn:hover {
  background-color: transparent;
  color: #000;
  border: 1px solid #000
}

@media (max-width: 959px) {
  .c-banner {
    height: calc(360px + (100vw - 320px)/1.5)
  }
  .c-banner__group {
    left: 10%;
    top: 25%;
    width: 82%
  }
  .c-banner__content {
    margin-bottom: 9vw
  }
  .c-banner__btn {
    width: 100%;
    height: 13vw;
    line-height: 13vw;
    border-radius: 6.5vw;
    font-size: 3.2vw
  }
}

.c-applyBtn-sm {
  background-color: #221815;
  color: #fff;
  display: inline-block;
  width: 160px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  border-radius: 20px
}

.c-applyBtn-sm:hover {
  background-color: #fff;
  color: #221815;
  border: 1px solid #221815
}

.c-headerBtn {
  position: absolute;
  top: 0;
  right: 0;
  width: 60px;
  height: 60px;
  background-color: #221815;
  color: #fff;
  text-align: center;
}

.c-headerBtn>i {
  font-size: 4rem;
  line-height: 60px
}

.c-closeBtn {
  /* position: absolute; */
  /* top: 0; */
  /* right: 0; */
  /* width: 60px; */
  /* height: 60px; */
  /* background-color: #221815; */
  /* z-index: 101; */
}

.c-closeBtn>i {
  /* color: #fff; */
  /* font-size: 3.6rem; */
  /* line-height: 40px; */
}

button[disabled] {
  color: #fff;
  background-color: #c0c0c0;
  cursor: not-allowed;
  opacity: 0.65
}

@media (max-width: 959px) {
  .c-applyBtn-sp {
    margin: 0 auto;
    background-color: #221815;
    color: #fff;
    width: 80%;
    max-width: 400px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    border-radius: 25px;
    margin-bottom: 6vh
  }
}

.c-cookiearea {
  position: fixed;
  z-index: 9999;
  bottom: 0;
  width: 100%;
  box-sizing: border-box;
  background-color: rgba(0, 0, 0, 0.85);
  color: white;
  line-height: 1.5
}

.c-cookiearea__inner {
  position: relative;
  margin: 0 auto
}

.c-cookiearea__inner>p {
  max-width: 960px;
  padding: 20px 40px;
  margin: auto;
  font-size: 1.4rem
}

.c-cookiearea__inner>p>a {
  text-decoration: underline
}

.c-cookiearea__inner__close {
  position: absolute;
  top: 10px;
  right: 10px
}

.c-cookiearea__inner__close:hover {
  cursor: pointer
}

.c-divide {
  width: 0;
  height: 25px;
  vertical-align: text-bottom;
  display: inline-flex;
  max-height: 100%;
  align-self: stretch;
  position: relative;
  top: 6px;
  margin: 0 10px
}

.c-flex {
  display: flex
}

.c-flex-r {
  display: flex;
  flex-direction: row-reverse
}

.c-flexAll {
  display: flex
}

.c-flex1 {
  flex: 1 1 auto
}

.c-flex-ac {
  align-items: center
}

.c-flex-fs {
  align-items: flex-start
}

.c-flex-ab {
  align-items: baseline
}

@media (max-width: 959px) {
  .c-flex {
    flex-direction: column
  }
  .c-flex-r {
    flex-direction: column
  }
}

.c-hero {
  position: relative;
  text-align: center
}

.c-heroText {
  position: absolute;
  top: -101px;
  left: calc(5% - 15px);
  text-align: left;
  color: #fff;
  border-left: 30px solid #221815;
  padding: 60px 0 30px 53px
}

.c-heroText__title {
  font-size: 2.8rem
}

.c-heroText__content {
  margin-top: 35px;
  font-size: 1.8rem
}

.c-heroBackground {
  width: 90%;
  height: 438px;
  position: absolute;
  top: -216px;
  left: 5%;
  background-size: cover;
  background-position: 50%
}

.c-heroBackground__commitment {
  background-image: url("../img/commitment/hero.jpg")
}

.c-heroBackground__science {
  background-image: url("../img/science/hero.jpg")
}

.c-heroBackground__flow {
  background-image: url("../img/flow/hero.jpg")
}

.c-heroBackground__plan {
  background-image: url("../img/plan/hero.jpg")
}

.c-heroBackground__product {
  background-image: url("../img/product/hero.jpg")
}

.c-heroBackground__service {
  background-image: url("../img/service.jpg");
  height: calc(100vw*0.3);
  max-height: 438px
}

.c-heroBackground__sports {
  background-image: url("../img/sports.jpg");
  height: calc(100vw*0.3);
  max-height: 438px
}

.c-heroBackground__este {
  background-image: url("../img/about_head.jpg");
  height: calc(100vw*0.3);
  max-height: 438px
}

.c-heroBackground__education {
  background-image: url("../img/education.jpg");
  height: calc(100vw*0.3);
  max-height: 438px
}



.c-heroBackground__faq {
  background-image: url("../img/faq/hero.jpg")
}

.c-heroSVG {
  position: relative;
  z-index: 1;
  transform: translateY(-50%)
}

.c-heroDown {
  padding-top: 254px
}

@media (max-width: 959px) {
  .c-hero {
    background: #fff;
    padding-top: 30px
  }
  .c-heroBackground {
    left: auto;
    top: 0;
    width: 100%;
    height: 75vw;
    margin-top: 30px !important
  }
  .c-heroBackground__commitment {
    background-position: 75% 50%
  }
  .c-heroBackground__science {
    background-image: url("../img/science/hero_sp.jpg")
  }
  .c-heroBackground__productEyelashserum {
    background-position: right 20% top 0
  }
  .c-heroBackground__faq {
    background-position: 75% 50%
  }
  .c-heroText {
    top: 18vw;
    left: 0;
    border-left: 10px solid #221815;
    padding: calc(17px + (100vw - 320px)/32) 20% calc(17px + (100vw - 320px)/32) calc(17px + (100vw - 320px)/32)
  }
  .c-heroText__title {
    font-size: calc(16px + (100vw - 320px)/30)
  }
  .c-heroText__content {
    margin-top: 15px;
    font-size: calc(12px + (100vw - 320px)/50)
  }
  .c-heroSVG {
    height: auto;
    max-width: 90vw;
    transform: translateY(-38%)
  }
  .c-heroDown {
    padding-top: 0
  }
}

.c-logoutIcon {
  position: relative;
  top: 8px;
  margin-right: 5px
}

.c-shoppingCartIcon {
  position: relative;
  top: 8px;
  margin-right: 0
}

.c-headerIcon {
  margin: auto;
  display: flex;
  flex-direction: column;
  position: absolute;
  top: 65px;
  right: 5px;
  transition: 0.2s
}

.c-headerIcon>a {
  color: #333;
  flex: 1;
  font-size: 1rem;
  padding: 0;
  align-self: left
}

.c-headerIcon>a:last-child {
  padding-top: 15px
}

.c-headerIcon>a>i {
  font-size: 3rem
}

.c-msgIcon {
  color: #221815;
  opacity: .7;
  margin-right: 5px
}

.c-head {
  margin-bottom: 50px
}

.c-mypageLink {
  color: #221815
}

.c-mypageLink:hover {
  opacity: .6
}

.c-globalLink {
  color: #221815;
  padding: 10px 2px;
  transition: .3s;
  position: relative
}

.c-globalLink:before {
  position: absolute;
  top: 32px;
  left: 0;
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background: #221815;
  transition: .3s
}

.c-globalLink__active:before {
  width: 100% !important
}

.c-globalLink:hover:before {
  width: 100% !important
}

.c-globalLink_drop {
  color: #221815;
  padding: 10px 2px;
  position: relative;
  cursor: pointer
}

.c-globalLink_drop:before {
  position: absolute;
  top: 32px;
  left: 0;
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background: #221815
}

.c-globalLink_drop:after {
  content: 'expand_more';
  font-family: "Material Icons";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  right: -15px
}

@media (max-width: 1199px) {
  .c-globalLink_drop:after {
    right: -12px
  }
}

.c-linkIcon {
  position: relative;
  top: 6px
}

.c-siteLogo {
  /* width: 180px; */
  /* height: 110px; */
  /* background-image: url("../../common/img/layout/header/logo.svg"); */
  /* background-size: contain; */
  /* text-indent: 100%; */
  /* overflow: hidden; */
  /* display: block; */
  /* transition: 0.2s; */
}
/*
.c-siteLogo:hover {
  opacity: .6
}

.c-footerLogo {
  margin: 10px auto 10px;
  width: 180px;
  height: 99px;
  background-image: url("../img/layout/footer/footer_logo.svg");
  background-size: contain;
  text-indent: 100%;
  overflow: hidden;
  display: block
}

.c-footerLogo:hover {
  opacity: .6
} */

.c-mask {
  height: 101%;
  width: 45%;
  background-color: #fff;
  z-index: 1
}

.c-maskLeft {
  position: absolute;
  left: 0
}

.c-maskRight {
  position: absolute;
  right: 0
}

.c-maskContainer {
  width: 100%;
  position: relative
}

.js-maskActive {
  width: 0;
  transition: width 1.5s
}

.c-myBtn-r1 {
  background-color: #A82228;
  color: #fff;
  display: inline-block;
  width: 280px;
  height: 50px;
  font-size: 1.4rem;
  line-height: 48px;
  text-align: center;
  border-radius: 5px
}

.c-myBtn-r2 {
  border: 1px solid rgba(168, 34, 40, 0.5);
  color: #A82228;
  display: inline-block;
  width: 280px;
  height: 50px;
  font-size: 1.4rem;
  line-height: 48px;
  text-align: center;
  border-radius: 5px
}

.c-myBtn-b {
  border: 1px solid #919191;
  color: #313131;
  display: inline-block;
  width: 280px;
  height: 50px;
  font-size: 1.4rem;
  line-height: 48px;
  text-align: center;
  border-radius: 5px
}

.c-myBtn-agree {
  color: #A82228;
  text-decoration: underline
}

@media (max-width: 959px) {
  .c-myBtn-r1 {
    width: 100%;
    height: 50px;
    line-height: 48px
  }
  .c-myBtn-r2 {
    width: 100%;
    height: 50px;
    line-height: 48px
  }
  .c-myBtn-b {
    width: 100%;
    height: 50px;
    line-height: 48px
  }
}

@media (min-width: 960px) {
  .c-myBtn-r1:hover {
    opacity: .5
  }
  .c-myBtn-r2:hover {
    background-color: rgba(168, 34, 40, 0.1)
  }
  .c-myBtn-b:hover {
    background-color: #f4f4f4
  }
}

.c-mySelectBox {
  position: relative;
  cursor: pointer;
  display: inline-block;
  font-size: 1.3rem;
  border-radius: 5px;
  width: 100%;
  height: 50px
}

.c-mySelectBox::after {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 1.8em;
  height: 100%;
  pointer-events: none;
  font-size: 3.6rem;
  background: url(../img/mypage/select.svg) no-repeat;
  background-position: center;
  content: '';
  text-align: center;
  color: var(--grayscale-darker);
  vertical-align: middle;
  border-left: 1px solid transparent;
  border-radius: 5px
}

.c-mySelectBox>select {
  border: 1px solid #919191;
  border-radius: 4px;
  background-color: #fff;
  width: calc(100%);
  height: 100%;
  padding: 0 15px;
  line-height: 2.4em;
  cursor: pointer;
  font-size: 16px
}

.c-myTextInput {
  width: 100%;
  max-width: 100%;
  height: 50px;
  border: 1px solid #919191;
  border-radius: 5px;
  padding: 0 15px;
  font-size: 16px
}

.c-myTextInput:placeholder-shown {
  background-color: #fff
}

.c-myTextInput::placeholder {
  color: #919191
}

.p-shopping__grey .c-myTextInput {
  background-color: #fff
}

.c-myTextArea {
  width: 100%;
  max-width: 100%;
  height: 224px;
  border: 1px solid #919191;
  border-radius: 5px;
  padding: 15px;
  font-size: 16px;
  resize: none
}

.c-myTextArea:placeholder-shown {
  background-color: #fff
}

.c-myTextArea::placeholder {
  color: #919191
}

.c-myRadio:checked, .c-myRadio:not(:checked) {
  display: none
}

.c-myRadio:checked+label, .c-myRadio:not(:checked)+label {
  position: relative;
  padding-left: 22px;
  cursor: pointer;
  line-height: 20px;
  display: inline-block;
  color: #666
}

.c-myRadio:checked+label:before, .c-myRadio:not(:checked)+label:before {
  content: '';
  position: absolute;
  left: 0;
  top: 2px;
  width: 18px;
  height: 18px;
  border: 1px solid #919191;
  border-radius: 100%;
  background: #fff
}

.c-myRadio:checked+label:after, .c-myRadio:not(:checked)+label:after {
  content: '';
  width: 10px;
  height: 10px;
  background: #A82228;
  position: absolute;
  top: 6px;
  left: 4px;
  border-radius: 100%;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease
}

.c-myRadio:not(:checked)+label:after {
  opacity: 0;
  -webkit-transform: scale(0);
  transform: scale(0)
}

.c-myRadio:checked+label:after {
  opacity: 1;
  -webkit-transform: scale(1);
  transform: scale(1)
}

.c-myCheckbox {
  display: inline-block;
  min-height: 16px
}

.c-myCheckbox>input {
  position: absolute;
  opacity: 0;
  width: 0
}

.c-myCheckbox__text {
  box-sizing: border-box;
  position: relative;
  display: inline-block;
  padding-left: 22px;
  vertical-align: middle;
  cursor: pointer;
  line-height: 1.4rem;
  vertical-align: middle
}

.c-myCheckbox__text::before {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  margin-top: -6px;
  width: 14px;
  height: 14px;
  border: 1px solid #919191;
  border-radius: 0;
  background-color: #fff;
  content: '';
  transition: all .3s
}

.c-myCheckbox__text::after {
  font-family: "Material Icons", sans-serif;
  font-feature-settings: 'liga';
  content: 'check';
  font-size: 2.2rem;
  position: absolute;
  width: 1em;
  height: 1em;
  top: 50%;
  left: 9px;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: all .3s;
  color: #A82228;
  line-height: 1
}

.c-myCheckbox>input:checked+.c-myCheckbox__text::after {
  opacity: 1;
  transition: opacity .3s
}

.c-myCheckbox>input:checked+.c-myCheckbox__text::before {
  transition: all .3s
}

.is-invalid {
  border: 1px solid #221815;
  background-color: #FFEAEA !important
}

@media (max-width: 959px) {
  .c-mySelectBox {
    height: 50px
  }
  .c-mySelectBox::after {
    width: 1em;
    line-height: 1.4
  }
  .c-mySelectBox>select {
    padding: 0 10px
  }
  .c-myTextInput {
    height: 50px;
    padding: 0 10px
  }
  .c-myTextArea {
    height: 128px
  }
}

.c-myHeading1 {
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.5;
  border-bottom: 1px solid #919191;
  margin: 0;
  padding-bottom: 8px
}

.c-myHeading2 {
  width: 100%;
  font-size: 1.6rem;
  padding: 8px 20px;
  background-color: #f4f4f4
}

.c-myHeading3 {
  width: 100%;
  font-size: 1.6rem;
  line-height: 1.5;
  padding-bottom: 6px;
  border-bottom: 1px solid #919191
}

.c-myHeading4 {
  width: 100%;
  font-size: 1.4rem;
  padding: 6px 20px;
  background-color: #f4f4f4
}

.c-myHeading5 {
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.5;
  margin: 0;
  padding-bottom: 8px
}

.c-myHeading5>span {
  font-weight: normal
}

.c-myLink {
  color: #A82228;
  text-decoration: underline
}

.c-myLink:hover {
  color: #313131
}

.c-myCaption {
  font-size: 1.2rem
}

.c-roboto {
  font-family: "Roboto", Arial, Helvetica, sans-serif
}

.c-myDivider {
  border-width: 1px 0 0 0;
  border-top: 1px solid #e5e5e5;
  width: 100vw;
  margin: 20px auto
}

.c-myDivider-thin {
  border-width: 1px 0 0 0;
  border-top: 1px solid #e5e5e5
}

.c-myText--red {
  color: #A82228
}

.c-myText--wrap {
  white-space: pre-wrap
}

@media (max-width: 959px) {
  .c-myHeading1 {
    font-size: 1.8rem;
    line-height: 27.5px;
    margin: 0
  }
  .c-myHeading2 {
    font-size: 1.6rem;
    padding: 6.5px 10px
  }
  .c-myHeading3 {
    font-size: 1.6rem;
    line-height: 25.5px;
    margin: 0
  }
  .c-myHeading4 {
    font-size: 1.4rem;
    padding: 4.5px 10px
  }
  .c-myDivider {
    width: 100%
  }
}

.c-cart_number {
  background-color: #eee;
  border-radius: 50%;
  display: inline-block;
  width: 26px;
  height: 26px;
  line-height: 26px;
  text-align: center;
  margin-left: -5px
}

.c-pagination {
  width: 100%;
  text-align: center
}

.c-pagination>div {
  display: inline-block
}

.c-pagination>div>.c-myBtn-r1 {
  width: 36px;
  height: 36px;
  line-height: 36px;
  font-size: 14px
}

.c-pagination>div>.c-myBtn-r1>i {
  top: 7px
}

.c-pagination__numbers {
  display: inline-block
}

.c-pagination__numbers>* {
  color: #A82228;
  margin-left: 20px
}

.c-pagination__numbers>*:first-child {
  margin-left: 25px
}

.c-pagination__numbers>*:last-child {
  margin-right: 25px
}

.c-pagination__number {
  text-decoration: underline
}

.c-pagination__number.active {
  color: #919191;
  text-decoration: none
}

@media (max-width: 959px) {
  .c-pagination>div>.c-myBtn-r1 {
    width: 32px;
    height: 32px;
    line-height: 32px
  }
  .c-pagination>div>.c-myBtn-r1>i {
    top: 4px
  }
}

@media (min-width: 960px) {
  .c-pagination__number:not(.active):hover {
    opacity: .5
  }
}

.c-steps {
  max-width: 100%;
  display: flex;
  justify-content: space-between;
  list-style: none;
  position: relative
}

.c-steps:before {
  position: absolute;
  width: 90%;
  top: 26px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  height: 2px;
  background: #707070;
  z-index: 0;
  content: ""
}

.c-step {
  width: 52px;
  height: 52px;
  line-height: 50px;
  color: #707070;
  border: 1px solid #707070;
  border-radius: 26px;
  background-color: #fff;
  position: relative;
  text-align: center;
  font-size: 2.6rem
}

.c-step>span {
  position: absolute;
  top: 44px;
  left: -49px;
  font-size: 1.2rem;
  line-height: unset;
  width: 150px
}

.c-step.active {
  background-color: #A82228;
  border-color: #A82228;
  color: #fff
}

.c-step.active>span {
  color: #A82228
}

@media (max-width: 959px) {
  .c-steps {
    width: 300px;
    margin: auto
  }
  .c-steps:before {
    height: 1px;
    top: 15px
  }
  .c-step {
    width: 30px;
    height: 30px;
    line-height: 28px;
    font-size: 1.6rem
  }
  .c-step>span {
    width: 75px;
    top: 27px;
    left: -24px;
    font-size: 1rem
  }
}

@media all and (-ms-high-contrast: none) {
  .c-step:first-child {
    margin-left: -20%
  }
}

.c-heading {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: calc(30px + (100vw - 960px) / 60);
  text-align: center;
  padding: 80px 0 60px 0
}

.c-title {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: calc(22px + (100vw - 960px) / 60);
  border-bottom: 1px solid #ddd;
}

.c-title2 {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: calc(20px + (100vw - 960px) / 60)
}

.c-info {
  margin-bottom: 50px;
  font-size: calc(16px + (100vw - 960px) / 240)
}

.c-content {
  margin-top: 20px;
  font-size: calc(14px + (100vw - 960px) / 240);
  line-height: 2;
  margin-bottom: 40px;
}

.c-content2 {
  margin-top: 50px;
  font-size: calc(12px + (100vw - 960px) / 240)
}

.c-caption {
  margin-top: 50px;
  font-size: calc(10px + (100vw - 960px) / 240)
}

.c-caption2 {
  margin-top: 50px;
  font-size: calc(12px + (100vw - 960px) / 240)
}

.c-detailTitle {
  font-size: 1.8rem
}

.c-detailContent {
  margin-top: 30px;
  font-size: 1.4rem
}

.c-fontYo {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif
}

.c-font-Go {
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif
}

.c-text--bold {
  font-weight: bold
}

.c-color-red {
  color: #000000;
}

.c-text--required {
  color: #A82228;
  font-size: 1rem;
  margin-left: 10px
}

.c-text--required-next {
  color: #A82228;
  font-size: 1rem
}

label.error {
  font-size: 1.2rem;
  color: #A82228;
  display: block
}

input.error {
  background-color: #FFEAEA !important;
  border: 1px solid #A82228 !important
}

textarea.error {
  background-color: #FFEAEA !important;
  border: 1px solid #A82228 !important
}

select.error {
  background-color: #FFEAEA !important;
  border: 1px solid #A82228 !important
}

.js-liner {
  display: inline;
  position: relative;
  background-image: linear-gradient(90deg, #000000, #000000);
  background-repeat: no-repeat;
  background-position: bottom left;
  background-size: 0 1px;
  transition: all 1s ease-in-out;
  padding-bottom: 0
}

.js-liner.is-inview {
  background-size: 100% 1px
}

.js-marker {
  display: inline;
  position: relative;
  background-image: linear-gradient(90deg, #fde7e7, #fde7e7);
  background-repeat: no-repeat;
  background-position: bottom left;
  background-size: 0 90%;
  transition: all 1s ease-in-out
}

.js-marker.is-inview {
  background-size: 100% 90%
}

@media (min-width: 1601px) {
  .c-heading {
    font-size: 4rem
  }
  .c-title {
    font-size: 3.6rem
  }
  .c-title2 {
    font-size: 3.2rem
  }
  .c-info {
    font-size: 2.1rem
  }
  .c-content {
    font-size: 1.8rem
  }
  .c-content2 {
    font-size: 1.6rem
  }
  .c-caption {
    font-size: 1.4rem
  }
  .c-caption2 {
    font-size: 1.5rem
  }
}

@media (max-width: 1199px) {
  .c-content {
    margin-top: 30px
  }
  .c-content2 {
    margin-top: 30px
  }
  .c-caption {
    margin-top: 30px
  }
  .c-caption2 {
    margin-top: 30px
  }
}

@media (max-width: 959px) {
  .c-heading {
    font-size: calc(18px + (100vw - 320px) / 28);
    padding: 50px 0 25px 0
  }
  .c-title {
    font-size: calc(16px + (100vw - 320px) / 28)
  }
  .c-title2 {
    font-size: calc(16px + (100vw - 320px) / 40)
  }
  .c-info {
    margin-bottom: 4.8vw;
    font-size: calc(12px + (100vw - 320px) / 40)
  }
  .c-content {
    margin-top: 2.8vw;
    font-size: calc(12px + (100vw - 320px) / 40);
    margin-bottom: 7.8vw;
  }
  .c-content2 {
    margin-top: 4.8vw;
    font-size: calc(12px + (100vw - 320px) / 56)
  }
  .c-caption {
    margin-top: 4.8vw;
    font-size: calc(10px + (100vw - 320px) / 56)
  }
  .c-caption {
    margin-top: 4.8vw;
    font-size: calc(11px + (100vw - 320px) / 56)
  }
  .c-detailTitle {
    font-size: 1.6rem
  }
  .c-detailContent {
    margin-top: 15px;
    font-size: 1.2rem
  }
  .c-text--required-next {
    display: inline
  }
}

.p-404__title {
  color: #221815
}

.p-404__msg {
  margin-top: 30px
}

.p-404__mail {
  color: #A82228;
  text-decoration: underline
}

.p-404__mail:hover {
  color: #313131
}

.p-404__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 35px;
  display: inline-block
}

.p-404__link:hover {
  color: #313131
}

.p-404__btn {
  margin-top: 50px
}

@media (min-width: 960px) {
  .p-404 {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-404__msg {
    margin-top: 20px
  }
}

.p-application {
  background-color: #fff;
  margin: 100px auto 0
}

.p-application__header {
  margin-bottom: 0;
  background-color: #221815;
  height: 300px;
  position: relative;
  display: flex;
  align-items: center
}

.p-application__header__product {
  flex-basis: 30%
}

.p-application__header__images {
  width: 200px;
  max-width: 100%;
  position: relative;
  top: -210px;
  margin: 0 0 0 auto;
  border-radius: 45px 45px;
  box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -webkit-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -moz-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -o-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5)
}

.p-application__header__frame {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2
}

.p-application__header__screen {
  width: 97%;
  position: absolute;
  top: 3px;
  left: 3px;
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0)
}

.p-application__header__screen.js-isActive {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  filter: alpha(opacity=1)
}

.p-application__header__text {
  color: #fff;
  flex-basis: 70%
}

.p-application__header__textGroup {
  width: 100%;
  padding: 0 0 0 12.5%
}

.p-application__header__title {
  font-size: 3.2rem;
  font-weight: normal;
  margin-bottom: 0px
}

.p-application__contents {
  background-color: #eee;
  padding: 100px 0
}

.p-application__contents__msg {
  background-color: #fff;
  padding: 50px;
  width: 80%;
  max-width: 640px;
  margin: 0 auto 50px;
  text-align: left;
  font-size: 1.6rem
}

.p-application__contents__msg>h3 {
  margin-bottom: 16px;
  text-align: center
}

.p-application__contents__install {
  padding: 0 80px
}

.p-application__contents__install__inner {
  background-color: #fff;
  margin: 50px auto 150px;
  padding: 40px;
  position: relative;
  text-align: center
}

.p-application__contents__install__inner>h3 {
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  text-align: center;
  font-size: 2rem;
  width: 340px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-application__contents__install__inner>p {
  margin: 50px auto 20px;
  font-size: 1.6rem
}

.p-application__contents__install__inner>.Logo__iOS>img {
  width: 240px
}

.p-application__contents__install__inner>.Logo__iOS>img:hover {
  opacity: .8
}

.p-application__contents__install__inner>.Logo__Android>img {
  width: 240px
}

.p-application__contents__install__inner>.Logo__Android>img:hover {
  opacity: .8
}

.p-application__contents__install__innerBtn {
  width: 300px;
  margin: 20px auto 40px
}

.p-application__contents__install__innerAndroid {
  width: 80%;
  margin: auto;
  font-size: 1.6rem;
  text-align: left
}

.p-application__contents__install__innerAndroid>h4 {
  margin: 0 50px 20px;
  border-bottom: 1px solid #ccc;
  padding-bottom: 3px;
  font-size: 1.8rem
}

.p-application__contents__install__innerAndroid>p {
  padding: 0 50px;
  margin-bottom: 30px
}

.p-application__contents__install__innerAndroid__steps {
  list-style: none
}

.p-application__contents__install__innerAndroid__steps>li {
  position: relative;
  padding-left: 50px;
  margin-bottom: 50px
}

.p-application__contents__install__innerAndroid__steps>li:before {
  font-size: 2rem;
  font-family: Didot, "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  color: #fff;
  background: #A82228;
  border-radius: 30px;
  width: 30px;
  height: 30px;
  line-height: 32px;
  text-align: center;
  position: absolute;
  left: 0
}

.p-application__contents__install__innerAndroid__steps>li.step1:before {
  content: '1'
}

.p-application__contents__install__innerAndroid__steps>li.step2>ul {
  margin: 20px 0 0 20px;
  list-style-type: decimal
}

.p-application__contents__install__innerAndroid__steps>li.step2>ul>li {
  margin-bottom: 20px
}

.p-application__contents__install__innerAndroid__steps>li.step2:before {
  content: '2'
}

.p-application__contents__install__innerAndroid__steps>li.step3:before {
  content: '3'
}

@media (max-width: 959px) {
  .p-application {
    margin-top: 0px
  }
  .p-application__header {
    height: 150px;
    margin-top: 40px
  }
  .p-application__header__product {
    flex-basis: 30%
  }
  .p-application__header__images {
    width: 100px;
    top: -110px
  }
  .p-application__header__text {
    flex-basis: 65%
  }
  .p-application__header__screen {
    top: 2px;
    left: 2px
  }
  .p-application__header__title {
    font-size: 2.4rem
  }
  .p-application__contents {
    padding: 60px 0
  }
  .p-application__contents__msg {
    padding: 20px 30px;
    margin: 0 auto
  }
  .p-application__contents__install {
    padding: 0
  }
  .p-application__contents__install__inner {
    padding: 40px 20px;
    margin-bottom: 100px
  }
  .p-application__contents__install__inner>p {
    text-align: left;
    margin-top: 20px
  }
  .p-application__contents__install__inner>h3 {
    width: 260px;
    font-size: 1.4rem;
    top: -20px;
    height: 40px;
    line-height: 40px
  }
  .p-application__contents__install__innerBtn {
    font-size: 2rem;
    height: 5rem;
    line-height: 5rem
  }
  .p-application__contents__install__innerAndroid {
    width: 100%
  }
  .p-application__contents__install__innerAndroid>h4 {
    margin: 0 auto 20px
  }
  .p-application__contents__install__innerAndroid>p {
    padding: 0
  }
  .p-application__contents__install__innerAndroid__steps>li {
    position: relative;
    padding-left: 34px
  }
  .p-application__contents__install__innerAndroid__steps>li:before {
    font-size: 1.6rem;
    border-radius: 24px;
    width: 24px;
    height: 24px;
    line-height: 24px
  }
}

.p-cart>.c-flex {
  margin-top: 40px;
  align-items: flex-start;
  flex-wrap: wrap
}

.p-cart__msg {
  padding: 10px;
  margin-bottom: 10px;
  background: #fff;
  border: 4px solid rgba(168, 34, 40, 0.2);
  box-sizing: border-box
}

.p-cart__msg>i {
  font-size: 1.6rem;
  vertical-align: middle
}

.p-cart__msg__last {
  margin-bottom: 25px
}

.p-cart__info {
  width: 100%
}

.p-cart__infoHeader {
  padding-bottom: 15px;
  border-bottom: 1px solid #d8d8d8
}

.p-cart__infoItem {
  font-size: 1.4rem;
  padding: 0 0 30px;
  margin-bottom: 30px;
  border-bottom: 1px solid #d8d8d8
}

.p-cart__infoItem__col1 {
  position: relative;
  padding-left: 30px;
  margin-right: 20px
}

.p-cart__infoItem__col1>img {
  width: 120px
}

.p-cart__infoItem__col2 {
  width: 100%;
  display: flex
}

.p-cart__infoItem__col2__1 {
  flex-basis: 65%;
  padding-right: 30px;
  align-self: flex-start
}

.p-cart__infoItem__col2__1>a>div {
  color: #A82228;
  text-decoration: underline;
  margin-bottom: 5px
}

.p-cart__infoItem__col2__1 p {
  margin-bottom: 5px
}

.p-cart__infoItem__col2__1__set {
  font-size: 1.2rem;
  font-weight: normal;
  line-height: 1.2;
  padding-left: 20px
}

.p-cart__infoItem__col2__1__listprice {
  font-size: 85%;
  color: #666;
  text-decoration: line-through;
  margin-bottom: 0 !important
}

.p-cart__infoItem__col2__1__delete {
  margin-top: 30px
}

.p-cart__infoItem__col2__1__delete>button {
  color: #A82228
}

.p-cart__infoItem__col2__2 {
  flex-basis: 35%;
  text-align: right
}

.p-cart__infoItem__col2__2>label {
  width: 100px;
  height: 50px;
  margin-bottom: 20px
}

.p-cart__infoItem__col2__2>label>select {
  padding: 0 15px
}

.p-cart__infoItem__col2__2>label:after {
  width: 1.3em
}

.p-cart__infoItem__col2__2 p {
  font-size: 1.4rem
}

.p-cart__infoItem__remove {
  background-image: url("../img/mypage/close.png");
  background-size: cover;
  width: 16px;
  height: 16px;
  cursor: pointer;
  position: absolute;
  top: 22px;
  left: 0
}

.p-cart__bill {
  width: 100%;
  border: 1px solid #919191;
  padding: 2%
}

.p-cart__billFlex {
  display: flex;
  margin-bottom: 15px;
  align-items: center
}

.p-cart__billTitle {
  flex: 1 1 auto
}

.p-cart__billGrey {
  text-align: center;
  width: 100%;
  padding: 10px 20px;
  font-size: 1.4rem;
  background-color: #f8f8f8;
  margin-top: 20px
}

.p-cart__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin: 25px 0 8px
}

.p-cart__billBox {
  margin: 40px auto
}

.p-cart__billBox>a {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-cart__billBox>a>i {
  font-size: 1.8rem
}

.p-cart__billOrder {
  width: 100%;
  margin: 0 auto 10px
}

.p-cart__billOrder__notice {
  text-align: center;
  font-size: 12px;
  line-height: 1.2;
  color: #333
}

.p-cart__billBack {
  width: 100%
}

.p-cart__billMaintenance {
  margin: 50px auto 10px;
  text-align: center;
  padding: 20px 10px;
  background: #f7e9ea
}

.p-cart__billPhone {
  background: #f6f6f6;
  padding: 30px 20px
}

.p-cart__billPhone__text {
  text-align: center;
  font-size: 16px;
  font-weight: bold
}

.p-cart__billPhone__contact {
  text-align: center;
  border: 1px solid #ddd;
  border-radius: 5px;
  background: #fff;
  font-size: 30px;
  font-weight: bold;
  line-height: 1;
  color: #333;
  display: block;
  padding: 10px 5px;
  margin-bottom: 10px
}

.p-cart__billPhone__contact>i {
  font-size: 26px;
  vertical-align: middle
}

.p-cart__billPhone__contactHours {
  font-size: 12px;
  font-weight: normal;
  color: #666
}

.p-cart__faq {
  width: 100%
}

.p-cart__faq>.c-accordion {
  margin: 1px auto
}

.p-cart__faq>.c-accordion>.c-accordion__header {
  font-size: 1.6rem;
  background: #faf4f4;
  color: #000
}

.p-cart__faq>.c-accordion>.c-accordion__contents>dl>dt {
  font-size: 1.4rem;
  background: #fff
}

.p-cart__noData__text {
  margin: 20px 0 40px
}

.p-cart__noData>.p-cart__faq {
  margin-top: 6rem
}

.p-cart__modalTitle {
  font-size: 2.2rem;
  margin: 0 auto 20px;
  text-align: center;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif
}

.p-cart__modalText {
  margin-bottom: 20px
}

.p-cart__modalText2 {
  color: #221815
}

.p-cart__modalBtn {
  border-radius: 50px;
  margin-bottom: 20px
}

.p-cart__modalBtn>i {
  vertical-align: middle
}

.p-cart__modalContact {
  border: 1px solid #c5c4c4;
  padding: 10px 15px;
  margin-bottom: 20px
}

.p-cart__modalContact__num {
  font-size: 2.2rem;
  text-align: center;
  margin-bottom: 10px
}

.p-cart__modalContact__num>i {
  vertical-align: middle
}

.p-cart__modalContact__time {
  font-size: 1.2rem;
  text-align: center;
  color: #666;
  margin-bottom: 0
}

@media (min-width: 960px) {
  .p-cart__inner {
    overflow: hidden
  }
  .p-cart__info {
    width: 65%;
    padding-right: 40px;
    float: left
  }
  .p-cart__title {
    margin-bottom: 25px
  }
  .p-cart__bill {
    width: 35%;
    top: 10px;
    padding-top: 30px;
    padding-bottom: 40px;
    border-radius: 4px;
    float: right
  }
  .p-cart__faq {
    width: 65%;
    margin-top: 30px;
    padding-right: 40px;
    float: left
  }
  .p-cart__noData__btn {
    color: #A82228;
    text-decoration: underline;
    display: inline-block
  }
  .p-cart__noData__btn>.c-linkIcon {
    font-size: 20px;
    top: 5px;
    right: 3px;
    opacity: .5
  }
  .p-cart__noData>.p-cart__faq {
    width: 100%;
    margin-top: 100px;
    padding-right: 0;
    float: none
  }
}

@media (max-width: 959px) {
  .p-cart>.c-flex {
    margin-top: 20px
  }
  .p-cart__title {
    margin-bottom: 20px
  }
  .p-cart__msg__last {
    margin-bottom: 20px
  }
  .p-cart__info {
    width: 100%
  }
  .p-cart__infoItem {
    height: auto;
    padding: 20px 0;
    margin-bottom: 0px;
    display: block
  }
  .p-cart__infoItem__col1 {
    width: auto;
    margin-right: 10px;
    float: left
  }
  .p-cart__infoItem__col1>img {
    width: 60px
  }
  .p-cart__infoItem__col2 {
    display: block;
    padding: 0
  }
  .p-cart__infoItem__col2>a>div {
    line-height: 1.8rem;
    margin-bottom: 5px;
    margin-left: 95px
  }
  .p-cart__infoItem__col2__1 {
    padding-right: 0;
    min-height: 60px
  }
  .p-cart__infoItem__col2__1>a>div {
    margin-left: 95px
  }
  .p-cart__infoItem__col2__1 p {
    margin-left: 95px
  }
  .p-cart__infoItem__col2__2 {
    flex-basis: auto;
    width: 100%;
    margin-top: 15px;
    padding: 0;
    display: table
  }
  .p-cart__infoItem__col2__2>div {
    padding-right: 10px;
    font-size: 1.2rem;
    text-align: right;
    display: table-cell
  }
  .p-cart__infoItem__col2__2>label {
    margin-top: 5px;
    height: 36px;
    display: table-cell
  }
  .p-cart__infoItem__col2__2>label>select {
    font-size: 16px;
    padding: 0 10px
  }
  .p-cart__infoItem__col2__2>label:after {
    font-size: 1.5rem;
    width: 2em
  }
  .p-cart__infoItem__col2__2 p {
    display: table-cell;
    text-align: right
  }
  .p-cart__faq {
    width: 100%;
    margin-top: 4rem
  }
  .p-cart__faq>.c-accordion>.c-accordion__header {
    font-size: 1.4rem;
    padding: 15px 35px 15px 15px
  }
  .p-cart__faq>.c-accordion>.c-accordion__header:after {
    right: 5px
  }
  .p-cart__faq>.c-accordion>.c-accordion__contents>dl>dt {
    font-size: 1.2rem
  }
  .p-cart__bill {
    margin-top: 15px;
    padding: 0;
    border: none
  }
  .p-cart__billBox {
    margin: 30px auto
  }
  .p-cart__modalTitle {
    font-size: 1.8rem
  }
}

.p-commitment {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 140px
}

.p-commitment3D {
  margin-bottom: 100px
}

.p-commitment3D__group {
  display: flex;
  width: 1190px;
  max-width: 92%;
  margin: 0 auto
}

.p-commitment3D__group>.left {
  position: relative;
  flex: 1 1 auto;
  text-align: right
}

.p-commitment3D__group>.left>img {
  margin-right: 20px;
  width: 524.5px;
  max-width: 46vw
}

.p-commitment3D__group>.c-fade {
  flex: 1 1 auto
}

.p-commitment3D__group__text {
  margin-left: 20px;
  margin-top: 50px
}

.p-commitment3D__group__text>h2 {
  font-weight: normal
}

.p-commitment3D__group__btn {
  margin: 48px auto 0;
  text-align: center;
  width: 460px;
  height: 60px;
  font-size: 1.8rem;
  line-height: 60px;
  color: #fff;
  background-color: #000;
  border-radius: 30px
}

.p-commitment3D__group__btn:hover {
  color: #000;
  background-color: transparent;
  border: 1px solid #000
}

.p-commitmentTeam {
  position: relative;
  padding-bottom: 120px
}

.p-commitmentTeam__title {
  position: absolute;
  top: -40px;
  text-align: center;
  font-size: 2.4rem;
  width: 334px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-commitmentTeam>.left {
  width: 94.5%;
  left: -94.5%;
  background-color: #fff;
  height: 700px;
  position: relative
}

.p-commitmentTeam__backText {
  position: absolute;
  top: -20px;
  right: -20px;
  z-index: 1
}

.p-commitmentTeam__group {
  padding-top: 185px;
  align-items: center
}

.p-commitmentTeam__group>img {
  width: 694px;
  max-width: 50%;
  align-self: auto
}

.p-commitmentTeam__text {
  align-self: auto;
  padding-left: calc(2% + (100% - 767px)/90);
  padding-right: calc(5% + (100% - 767px)/90)
}

.p-commitmentTeam__text>h2 {
  font-weight: normal
}

.p-commitmentCounselor {
  position: relative;
  padding-bottom: 120px
}

.p-commitmentCounselor::after {
  content: '';
  display: block;
  clear: both;
  height: 0;
  visibility: hidden
}

.p-commitmentCounselor__title {
  position: absolute;
  top: -40px;
  right: 0;
  text-align: center;
  font-size: 2.4rem;
  width: 448px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-commitmentCounselor>.right {
  float: right;
  width: 94.5%;
  right: -94.5%;
  background-color: #fff;
  height: 1000px;
  position: relative
}

.p-commitmentCounselor__backText {
  width: 100%;
  max-width: 900px;
  position: absolute;
  top: -10px;
  left: -10px;
  z-index: 1
}

.p-commitmentCounselor__group {
  padding-top: 210px;
  align-items: center
}

.p-commitmentCounselor__group>img {
  width: 694px;
  max-width: 50%;
  align-self: auto
}

.p-commitmentCounselor__text {
  align-self: auto;
  padding-left: calc(5% + (100% - 767px)/60);
  padding-right: calc(5% + (100% - 767px)/60)
}

.p-commitmentCounselor__text>h2 {
  font-weight: normal
}

.p-commitmentCounselor__text>div>h3 {
  font-size: 1.6rem;
  font-weight: normal
}

.p-commitmentCounselor__text>div>p {
  font-size: 1.4rem;
  padding-left: 10px;
  margin-bottom: 30px
}

.p-commitmentStory {
  position: relative;
  padding-bottom: 120px
}

.p-commitmentStory::after {
  content: '';
  display: block;
  clear: both;
  height: 0;
  visibility: hidden
}

.p-commitmentStory__title {
  position: absolute;
  top: -40px;
  text-align: center;
  font-size: 2.4rem;
  width: 448px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-commitmentStory>.left {
  width: 94.5%;
  left: -94.5%;
  background-color: #fff;
  height: 1250px;
  position: relative
}

.p-commitmentStory__backText {
  position: absolute;
  top: -20px;
  right: -20px;
  z-index: 1
}

.p-commitmentStory__group {
  padding-top: 210px;
  align-items: center
}

.p-commitmentStory__group>img {
  width: 694px;
  max-width: 50%;
  align-self: auto
}

.p-commitmentStory__text {
  align-self: auto;
  padding-left: calc(2% + (100% - 767px)/60);
  padding-right: calc(5% + (100% - 767px)/60)
}

.p-commitmentStory__text>h2 {
  font-weight: normal
}

.p-commitmentStory__text__second {
  margin-top: 80px
}

@media (max-width: 1199px) {
  .p-commitment3D__group__btn {
    font-size: 1.6rem;
    width: 400px
  }
  .p-commitmentStory>.left {
    height: calc(1050px + (100vw - 768px)/2)
  }
}

@media (max-width: 959px) {
  .p-commitment {
    margin-top: calc(15px + (100vw - 320px)/40);
    margin-bottom: 0
  }
  .p-commitment>.c-hero {
    height: calc(75vw + (100vw - 320px)/40)
  }
  .p-commitment__heroText {
    max-width: calc(180px + (100vw - 320px)/4)
  }
  .p-commitment3D__group {
    display: block;
    max-width: 80%
  }
  .p-commitment3D__group>.left {
    text-align: center
  }
  .p-commitment3D__group>.left>img {
    margin-right: auto;
    width: 93.7%;
    max-width: none
  }
  .p-commitment3D__group__text {
    margin-left: auto;
    margin-top: 30px
  }
  .p-commitment3D__group__btn {
    width: 80vw;
    height: calc(50px + (100vw - 320px)/9);
    line-height: calc(50px + (100vw - 320px)/9);
    border-radius: calc(25px + (100vw - 320px)/18);
    font-size: calc(10px + (100vw - 320px)/40)
  }
  .p-commitmentTeam {
    padding-bottom: 60px
  }
  .p-commitmentTeam__title {
    font-size: 1.4rem;
    top: -20px;
    width: 210px;
    height: 40px;
    line-height: 40px
  }
  .p-commitmentTeam>.left {
    height: auto;
    width: 93.7%;
    left: -93.7%
  }
  .p-commitmentTeam__backText {
    width: 100%;
    top: auto;
    right: -10px;
    bottom: -10px
  }
  .p-commitmentTeam__group {
    padding-top: 35px
  }
  .p-commitmentTeam__group>img {
    width: 100%;
    max-width: none
  }
  .p-commitmentTeam__text {
    width: 100%;
    padding: 30px 10% 100px 10%
  }
  .p-commitmentCounselor {
    padding-bottom: 60px
  }
  .p-commitmentCounselor__title {
    font-size: 1.4rem;
    top: -20px;
    width: 210px;
    height: 40px;
    line-height: 40px
  }
  .p-commitmentCounselor>.right {
    height: auto;
    width: 93.7%;
    right: -93.7%
  }
  .p-commitmentCounselor__backText {
    width: 100%;
    left: -5px;
    top: -5px
  }
  .p-commitmentCounselor__group {
    padding-top: calc(50px + (100vw - 320px)/3)
  }
  .p-commitmentCounselor__group>img {
    width: 100%;
    max-width: none
  }
  .p-commitmentCounselor__text {
    width: 100%;
    padding: 30px 10% 20px 10%
  }
  .p-commitmentCounselor__text__second {
    margin-top: 40px
  }
  .p-commitmentCounselor__text>div>h3 {
    font-size: 1.4rem
  }
  .p-commitmentCounselor__text>div>p {
    font-size: 1.2rem
  }
  .p-commitmentStory {
    padding-bottom: 60px
  }
  .p-commitmentStory__title {
    font-size: 1.4rem;
    top: -20px;
    width: 280px;
    height: 40px;
    line-height: 40px
  }
  .p-commitmentStory>.left {
    height: auto;
    width: 93.7%;
    right: -93.7%
  }
  .p-commitmentStory__backText {
    width: 60%;
    left: auto;
    top: auto;
    bottom: -30px
  }
  .p-commitmentStory__group {
    padding-top: calc(50px + (100vw - 320px)/3)
  }
  .p-commitmentStory__group>img {
    width: 100%;
    max-width: none
  }
  .p-commitmentStory__text {
    width: 100%;
    padding: 30px 10% 100px 10%
  }
  .p-commitmentStory__text__second {
    margin-top: 40px
  }
}

.p-contactComp__msg {
  margin: 30px 0 35px
}

.p-contactComp__cs {
  border: 1px solid #d8d8d8;
  width: 400px;
  padding: 15px
}

.p-contactComp__csName {
  font-size: 1.2rem;
  margin-bottom: 5px
}

.p-contactComp__csPhone>i {
  font-size: 1.6rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold
}

.p-contactComp__csTime {
  font-size: 1.2rem
}

.p-contactComp__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 55px;
  display: inline-block
}

.p-contactComp__link:hover {
  color: #313131
}

.p-contactComp__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-contactComp__btn {
  margin-top: 50px
}

@media (min-width: 960px) {
  .p-contactComp {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-contactComp__msg {
    margin: 20px 0 30px
  }
  .p-contactComp__cs {
    width: 100%
  }
}

.p-contactConf__heading {
  margin-bottom: 30px
}

.p-contactConf__flex>* {
  padding: 30px 20px 0
}

.p-contactConf__flex>*:first-child {
  padding-left: 0
}

.p-contactConf__flex>*:last-child {
  padding-right: 0
}

.p-contactConf__title {
  width: 140px;
  text-align: right
}

.p-contactConf__input {
  flex: 1 1 auto
}

.p-contactConf__hr {
  padding-left: 160px
}

.p-contactConf__hr>hr {
  margin-top: 30px
}

.p-contactConf__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-contactConf {
    max-width: 980px;
    margin: auto
  }
  .p-contactConf__container {
    padding-right: 20px;
    margin: 50px auto 0
  }
  .p-contactConf__flex {
    align-items: center
  }
  .p-contactConf__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-contactConf__heading {
    margin-bottom: 20px
  }
  .p-contactConf__flex {
    margin-top: 10px
  }
  .p-contactConf__flex>* {
    padding: 5px 0
  }
  .p-contactConf__title {
    font-size: 1.4rem;
    font-weight: bold;
    text-align: left;
    width: 100%
  }
  .p-contactConf__input {
    font-size: 1.6rem;
    line-height: 1.5
  }
  .p-contactConf__save {
    margin: 25px 0 40px
  }
}

.p-contact__heading {
  margin-bottom: 20px
}

.p-contact__tel {
  padding: 10px;
  background-color: #fefefe;
  border: 1px dotted #ccc;
  text-align: center
}

.p-contact__telTitle {
  font-weight: 700
}

.p-contact__tel i {
  font-size: 1.4rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold
}

.p-contact__tel a {
  font-size: 110%;
  color: #A82228;
  text-decoration: underline
}

.p-contact__flex>* {
  padding: 30px 20px 0
}

.p-contact__flex>*:first-child {
  padding-left: 0
}

.p-contact__flex>*:last-child {
  padding-right: 0
}

.p-contact__title {
  width: 200px;
  font-size: 1.6rem;
  text-align: right;
  position: relative;
  top: 13px
}

.p-contact__input {
  flex: 1 1 auto
}

.p-contact__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-contact__hr {
  padding-left: 220px
}

.p-contact__hr>hr {
  margin-top: 30px
}

.p-contact__zipBtn {
  width: 180px
}

.p-contact__save {
  margin-top: 40px
}

.p-contact__msg {
  margin: 20px 0 0
}

@media (min-width: 960px) {
  .p-contact {
    max-width: 980px;
    margin: auto
  }
  .p-contact__flexBtn {
    width: 100%;
    text-align: center
  }
  .p-contact__tel {
    margin-left: 220px
  }
  .p-contact__telTitle {
    margin-right: 10px
  }
  .p-contact__container {
    margin: 0 auto;
    padding: 0 10px
  }
  .p-contact__container form {
    margin-bottom: 40px
  }
}

@media (max-width: 959px) {
  .p-contact__heading {
    margin-bottom: 20px
  }
  .p-contact__tel {
    text-align: left
  }
  .p-contact__telTime {
    font-size: 80%
  }
  .p-contact__flex {
    margin-top: 15px
  }
  .p-contact__flex>* {
    padding: 0 0 10px
  }
  .p-contact__flex.no-title {
    margin-top: 0
  }
  .p-contact__title {
    text-align: left;
    font-size: 1.4rem;
    font-weight: bold;
    width: 100%;
    position: static
  }
  .p-contact__title.no-top {
    padding: 0
  }
  .p-contact__zipInput {
    display: flex
  }
  .p-contact__zipIcon {
    width: 20px;
    line-height: 48px;
    font-size: 1.6rem
  }
  .p-contact__zipSelect {
    flex: 1 1 auto;
    margin-right: 20px
  }
  .p-contact__zipBtn {
    width: 120px;
    height: 50px;
    line-height: 48px;
    font-size: 1.2rem
  }
  .p-contact__save {
    margin: 10px 0 25px
  }
  .p-contact__msg {
    font-size: 1.2rem;
    margin: 0 0 20px
  }
}

.p-entryComp__order {
  margin: 30px 0
}

.p-entryComp__msg {
  max-width: 620px;
  margin-bottom: 45px
}

.p-entryComp__link {
  color: #A82228;
  text-decoration: underline;
  display: inline-block
}

.p-entryComp__link:hover {
  color: #313131
}

.p-entryComp__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-entryComp__btn {
  margin-top: 20px
}

@media (min-width: 960px) {
  .p-entryComp {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-entryComp__order {
    margin: 20px 0 30px
  }
  .p-entryComp__msg {
    margin-bottom: 35px
  }
}

.p-entryConf__heading {
  margin-bottom: 30px
}

.p-entryConf__flex>* {
  padding: 30px 20px 0
}

.p-entryConf__flex>*:first-child {
  padding-left: 0
}

.p-entryConf__flex>*:last-child {
  padding-right: 0
}

.p-entryConf__title {
  width: 140px;
  text-align: right
}

.p-entryConf__input {
  flex: 1 1 auto
}

.p-entryConf__hr {
  padding-left: 160px
}

.p-entryConf__hr>hr {
  margin-top: 30px
}

.p-entryConf__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-entryConf {
    max-width: 980px;
    margin: auto
  }
  .p-entryConf__container {
    padding-right: 20px;
    margin: 0 auto
  }
  .p-entryConf__flex {
    align-items: center
  }
  .p-entryConf__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-entryConf__heading {
    margin-bottom: 20px
  }
  .p-entryConf__flex {
    margin-top: 10px
  }
  .p-entryConf__flex>* {
    padding: 5px 0
  }
  .p-entryConf__title {
    font-size: 1.4rem;
    font-weight: bold;
    text-align: left;
    width: 100%
  }
  .p-entryConf__input {
    font-size: 1.6rem;
    line-height: 1.5
  }
  .p-entryConf__save {
    margin: 40px 0
  }
}

.p-entry__heading {
  margin-bottom: 20px
}

.p-entry__flex>* {
  padding: 30px 20px 0
}

.p-entry__flex>*:first-child {
  padding-left: 0
}

.p-entry__flex>*:last-child {
  padding-right: 0
}

.p-entry__container__msg>i {
  font-size: 1.6rem;
  font-weight: bold;
  opacity: .5;
  position: relative;
  top: 4px;
  margin-right: 2px
}

.p-entry__title {
  width: 15%;
  max-width: 200px;
  font-size: 1.4rem;
  text-align: right;
  position: relative
}

.p-entry__input {
  flex: 1 1 auto
}

.p-entry__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-entry__zipInput .p-entry__input__err {
  padding-left: 30px
}

.p-entry__hr {
  padding-left: 15%
}

.p-entry__hr>hr {
  margin-top: 30px
}

.p-entry__zipInput {
  display: flex
}

.p-entry__zipBtn {
  flex-basis: 40%;
  max-width: 40%;
  line-height: 48px;
  font-size: 1.2rem;
  padding-left: 20px
}

.p-entry__zipBtn>.c-myBtn-r1 {
  width: 100%
}

.p-entry__zipIcon {
  font-size: 1.6rem;
  margin-right: 10px;
  display: inline-block
}

.p-entry__zipCode {
  width: 90%
}

.p-entry__zipSelect {
  flex-basis: 60%;
  max-width: 60%;
  padding-right: 20px
}

.p-entry__save {
  margin-top: 70px
}

.p-entry__radio {
  display: inline-block;
  margin-right: 100px;
  margin-top: 0
}

.p-entry__birth {
  align-items: baseline
}

.p-entry__birthSelectY {
  flex-basis: 43%
}

.p-entry__birthSelect {
  flex-basis: 28.5%
}

.p-entry__birth__break {
  padding: 0 20px
}

@media (min-width: 960px) {
  .p-entry {
    max-width: 980px;
    margin: auto
  }
  .p-entry__flex {
    align-items: baseline
  }
  .p-entry__container {
    padding-right: 20px;
    margin: 0 auto
  }
  .p-entry__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-entry__heading {
    margin-bottom: 20px
  }
  .p-entry__flex {
    margin-top: 0px
  }
  .p-entry__flex>* {
    padding: 0 0 10px
  }
  .p-entry__flex.no-title {
    margin-top: 0
  }
  .p-entry__container__msg {
    margin-bottom: 2rem
  }
  .p-entry__container__msg dl dt {
    position: relative;
    padding-left: 2rem
  }
  .p-entry__container__msg dl dt:before {
    font-size: 1.8rem;
    font-family: Material Icons;
    content: "expand_more";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transition: 0.2s;
    opacity: .5
  }
  .p-entry__container__msg dl dt.open:before {
    transform: translateY(-50%) rotate(180deg);
    transition: 0.2s
  }
  .p-entry__container__msg dl dt p {
    text-decoration: underline
  }
  .p-entry__container__msg dl dd {
    display: none;
    margin-top: 0.5rem
  }
  .p-entry__container__msg dl dd>i {
    font-size: 1.6rem;
    font-weight: bold;
    opacity: .5;
    position: relative;
    top: 3px;
    margin-right: 2px
  }
  .p-entry__title {
    text-align: left;
    font-weight: bold;
    width: 100%;
    position: static
  }
  .p-entry__title.no-top {
    padding: 0
  }
  .p-entry__zipSelect {
    flex: 1.5;
    padding-right: 10px
  }
  .p-entry__zipCode {
    width: 80%
  }
  .p-entry__zipBtn {
    padding-left: 10px
  }
  .p-entry__zipBtn>.c-myBtn-r1 {
    width: 100%
  }
  .p-entry__save {
    margin: 25px 0 40px
  }
  .p-entry__radio {
    margin-right: 20px;
    margin-top: 0
  }
  .p-entry__birth__break {
    padding: 0 10px
  }
}

.p-productEyelashserum {
  /* font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif; */
  /* background-color: #fff; */
  margin-top: 254px;
  margin-bottom: 140px;
}

/* .p-productEyelashserum__intro {
  background: url("../img/product/_eyelashserum/intro_bg.jpg") center top/cover no-repeat
} */

/* .p-productEyelashserum__intro {
  background: url("../../about/img/about_haikei.jpg") center top/cover no-repeat
} */



.p-productEyelashserum__hero {
  padding-top: 350px;
}

.p-productEyelashserum__hero .c-heroBackground {
  background-position: left
}

.p-productEyelashserum__heroTitle {
  font-size: 3.5rem;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  line-height: 1.5;
  position: absolute;
  top: -50%;
  left: 10%;
  text-align: left;
  text-align: center
}

.p-productEyelashserum__heroTitle span {
  font-size: 60%;
}

.p-productEyelashserum__heroItem {
  position: absolute;
  top: -45%;
  right: 8%;
  width: 10vw;
  max-width: 189px
}

.p-productEyelashserum__release {
  padding-bottom: 300px
}

.p-productEyelashserum__releaseTitle p {
  font-size: 2.4rem;
  text-align: center;
  margin-bottom: 0
}

.p-productEyelashserum__releaseTitle p span {
  font-size: 3rem
}

.p-productEyelashserum__releaseTitle h2 {
  font-size: 4.2rem;
  font-weight: 500;
  text-align: center;
  margin-bottom: 50px
}

.p-productEyelashserum__trouble {
  padding-top: 200px;
  padding-bottom: 50px;
  position: relative;
  background: url("../img/product/_eyelashserum/trouble_bg.jpg") center top/cover no-repeat;
  box-shadow: 0px 0px 10px 4px rgba(187, 193, 195, 0.3);
  z-index: 5
}

.p-productEyelashserum__trouble::after {
  content: "";
  display: block;
  width: 120px;
  height: 50px;
  background: url("../img/product/_eyelashserum/trouble_triangle.png") center top/cover no-repeat;
  position: absolute;
  bottom: -50px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%)
}

.p-productEyelashserum__troubleDecline {
  width: 60%;
  max-width: 620px;
  background: #fff;
  text-align: center;
  position: absolute;
  top: -250px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  box-shadow: 0px 0px 10px 4px rgba(187, 193, 195, 0.6)
}

.p-productEyelashserum__troubleDecline__inner {
  position: relative;
  padding: 30px;
  height: 460px
}

.p-productEyelashserum__troubleDecline h3 {
  font-size: 2.8rem
}

.p-productEyelashserum__troubleDecline p {
  font-size: 2.8rem
}

.p-productEyelashserum__troubleDecline p .fs-lg {
  font-size: 138%
}

.p-productEyelashserum__troubleDecline p .fs-sm {
  font-size: 89%
}

.p-productEyelashserum__troubleDecline__img {
  width: 70%;
  max-width: 700px;
  display: flex;
  justify-content: space-between;
  margin: 20px auto
}

.p-productEyelashserum__troubleDecline__img div {
  flex: 1;
  padding: 0 10px
}

.p-productEyelashserum__troubleDecline__arrow {
  width: 15px;
  position: absolute;
  bottom: -35px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  z-index: 10;
  -webkit-animation: floating-arrow-anim 0.5s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0s infinite alternate;
  animation: floating-arrow-anim 0.5s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0s infinite alternate
}

.p-productEyelashserum__troubleInner {
  width: 90%;
  max-width: 860px;
  margin: 80px auto 0;
  display: flex;
  justify-content: space-around
}

.p-productEyelashserum__troubleInner .left {
  flex: 1;
  margin: 0;
  position: relative;
  text-align: left
}

.p-productEyelashserum__troubleInner .left img {
  width: 85%
}

.p-productEyelashserum__troubleInner .left p {
  font-size: 2.2rem;
  position: absolute;
  bottom: 50px;
  right: 0;
  background: #a3131c;
  color: #fff;
  padding: 10px 30px;
  margin-bottom: 0
}

.p-productEyelashserum__troubleInner .right {
  flex: 1;
  margin: 38px 0 0;
  padding-top: 50px;
  position: relative;
  text-align: right
}

.p-productEyelashserum__troubleInner .right img {
  width: 85%
}

.p-productEyelashserum__troubleInner .right p {
  font-size: 2.2rem;
  text-align: left;
  position: absolute;
  top: 0;
  left: 0;
  background: #a3131c;
  color: #fff;
  padding: 10px 30px;
  margin-bottom: 0
}

.p-productEyelashserum__troubleMsg {
  font-size: 3.2rem;
  text-align: center;
  padding-top: 40px
}

.p-productEyelashserum__reason {
  background: -moz-linear-gradient(left, #e0e4e9, #f0f3f5 15%, #fff 35%, #fff 65%, #f0f3f5 85%, #e0e4e9);
  background: -webkit-linear-gradient(left, #e0e4e9, #f0f3f5 15%, #fff 35%, #fff 65%, #f0f3f5 85%, #e0e4e9);
  background: linear-gradient(to right, #e0e4e9, #f0f3f5 15%, #fff 35%, #fff 65%, #f0f3f5 85%, #e0e4e9);
  padding: 80px 0;
  position: relative;
  box-shadow: 0px 0px 10px 4px rgba(187, 193, 195, 0.3);
  z-index: 4
}

.p-productEyelashserum__reason::after {
  content: "";
  display: block;
  width: 120px;
  height: 50px;
  background: url("../img/product/_eyelashserum/reason_triangle.png") center top/cover no-repeat;
  position: absolute;
  bottom: -50px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%)
}

.p-productEyelashserum__reason h2 {
  font-size: 4rem;
  font-weight: 600;
  font-family: "游明朝体", "Noto Serif JP", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  text-align: center;
  line-height: 1.25;
  margin-bottom: 40px
}

.p-productEyelashserum__reason h2 .three {
  font-size: 200%;
  font-family: Didot, "游明朝体", "Noto Serif JP", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif
}

.p-productEyelashserum__reasonSpeech {
  font-size: 2.4rem;
  text-align: center;
  margin-bottom: 0px
}

.p-productEyelashserum__reasonSpeech span {
  position: relative;
  display: inline-block;
  padding: 0 30px
}

.p-productEyelashserum__reasonSpeech span:before, .p-productEyelashserum__reasonSpeech span:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 30px;
  height: 1px;
  background-color: black
}

.p-productEyelashserum__reasonSpeech span:before {
  left: 0;
  -webkit-transform: rotate(70deg);
  transform: rotate(70deg)
}

.p-productEyelashserum__reasonSpeech span:after {
  right: 0;
  -webkit-transform: rotate(-70deg);
  transform: rotate(-70deg)
}

.p-productEyelashserum__reasonTitle {
  position: relative;
  width: 80%;
  max-width: 860px;
  margin: auto
}

.p-productEyelashserum__reasonTitle div {
  width: 30%;
  max-width: 320px;
  position: absolute;
  top: 50%;
  left: -18%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  line-height: 1
}

.p-productEyelashserum__reasonTitle h3 {
  width: 100%;
  font-size: 3rem;
  text-align: center;
  color: #a3131c
}

.p-productEyelashserum__reasonInner {
  width: 80%;
  max-width: 860px;
  background: #fff;
  padding: 30px;
  margin: 40px auto 80px;
  text-align: center;
  box-shadow: 0px 0px 10px 4px rgba(187, 193, 195, 0.6)
}

.p-productEyelashserum__reasonInner img {
  width: 60%;
  max-width: 590px;
  margin-bottom: 30px
}

.p-productEyelashserum__reasonInner p {
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif;
  font-size: 1.8rem;
  line-height: 2.5;
  margin-bottom: 20px
}

.p-productEyelashserum__reasonFact {
  width: 80%;
  max-width: 860px;
  margin: auto;
  border: 1px solid #a3131c
}

.p-productEyelashserum__reasonFact__title {
  font-size: 3rem;
  color: #a3131c;
  background: #f9f4f4;
  margin-bottom: 0;
  padding: 10px;
  text-align: center;
  border-bottom: 1px solid #a3131c
}

.p-productEyelashserum__reasonFact__inner {
  padding: 30px;
  background: #fff
}

.p-productEyelashserum__reasonFact__inner p {
  font-size: 1.8rem;
  line-height: 2.5;
  text-align: center
}

.p-productEyelashserum__reasonFact__innerSpiral {
  display: flex;
  margin-top: 30px
}

.p-productEyelashserum__reasonFact__innerSpiral div {
  font-size: 1.6rem;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif;
  font-weight: 600;
  line-height: 2.5;
  padding: 20px;
  text-align: center;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center
}

.p-productEyelashserum__reasonFact__innerSpiral div img {
  width: 45px;
  position: absolute;
  top: 50%;
  right: -65px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%)
}

.p-productEyelashserum__reasonFact__innerSpiral .layer_1 {
  background: #dfdfdf;
  position: relative
}

.p-productEyelashserum__reasonFact__innerSpiral .layer_2 {
  background: #dccbcb;
  margin: 0 80px;
  position: relative
}

.p-productEyelashserum__reasonFact__innerSpiral .layer_3 {
  background: #e7c2c2
}

.p-productEyelashserum__point {
  padding: 0 0 80px;
  background: #e9eff5 url("../img/product/_eyelashserum/point_bg_pc.jpg") center top/100% no-repeat;
  z-index: 10
}

.p-productEyelashserum__pointTitle {
  padding-top: 80px;
  text-align: center
}

.p-productEyelashserum__pointTitle p {
  font-size: 3rem;
  margin-bottom: 0
}

.p-productEyelashserum__pointTitle h2 {
  font-size: 4rem;
  font-weight: 500;
  color: #a3131c
}

.p-productEyelashserum__pointTitle img {
  width: 60%;
  max-width: 720px;
  margin: 40px auto
}

.p-productEyelashserum__pointTitle__glow {
  width: 70%;
  max-width: 650px;
  font-size: 3rem;
  margin: 40px auto 0;
  padding: 10px 0;
  border-top: 1px solid #a3131c;
  border-bottom: 1px solid #a3131c
}

.p-productEyelashserum__pointTitle__glow h2 {
  font-size: 4.2rem
}

.p-productEyelashserum__pointContents {
  width: 80%;
  max-width: 860px;
  margin: auto;
  box-shadow: 0px 0px 10px 4px rgba(187, 193, 195, 0.6)
}

.p-productEyelashserum__pointContents__title {
  font-size: 3rem;
  text-align: center;
  color: #fff;
  line-height: 1.5;
  background: #a3131c;
  padding: 20px 0;
  margin-bottom: 0
}

.p-productEyelashserum__pointContents__inner {
  padding: 30px 60px
}

.p-productEyelashserum__pointContents__inner h3 {
  font-size: 3rem;
  font-weight: 400;
  text-align: center;
  position: relative
}

.p-productEyelashserum__pointContents__inner h3::before {
  font-size: 10rem;
  font-family: Didot, "游明朝体", "Noto Serif JP", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  color: #a3131c;
  line-height: 1;
  position: absolute;
  top: 0;
  left: 0
}

.p-productEyelashserum__pointContents__box {
  display: flex;
  align-items: center;
  margin-top: 30px
}

.p-productEyelashserum__pointContents__box .left {
  flex: 1
}

.p-productEyelashserum__pointContents__box .right {
  flex: 1.2
}

.p-productEyelashserum__pointContents__box .right p {
  font-size: 1.8rem;
  line-height: 2.5;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif;
  text-align: center
}

.p-productEyelashserum__pointContents__box .right .kome {
  font-size: 1rem;
  text-align: right
}

.p-productEyelashserum__pointGlow {
  background: url("../img/product/_eyelashserum/point_glow_bg_pc.png") center top 40%/100% no-repeat
}

.p-productEyelashserum__pointGlow__orb {
  width: 50%;
  max-width: 620px;
  margin: 0 auto 20px;
  display: block
}

.p-productEyelashserum__pointGlow__material {
  width: 80%;
  max-width: 860px;
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center
}

.p-productEyelashserum__pointGlow__material div {
  width: 30%;
  padding: 20px;
  position: relative
}

.p-productEyelashserum__pointGlow__material div p {
  width: 100%;
  font-size: 1.4rem;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif;
  line-height: 1.5;
  margin-bottom: 0;
  position: absolute;
  left: 50%;
  bottom: 10%;
  text-shadow: 1px 1px 0 #fff, -1px -1px 0 #fff, -1px 1px 0 #fff, 1px -1px 0 #fff, 0px 1px 0 #fff, -1px 0 #fff, -1px 0 0 #fff, 1px 0 0 #fff, 1px 0 10px #fff, 0 1px 10px #fff, -1px 0 10px #fff, 0 -1px 10px #fff, 1px 0 10px #fff, 0 1px 20px #fff, -1px 0 20px #fff, 0 -1px 20px #fff;
  z-index: 3
}

.p-productEyelashserum__pointGlow__material div p span {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 10px;
  display: block
}

.p-productEyelashserum__graph {
  padding: 20px 0;
  background: -moz-linear-gradient(left, #e0e4e9, #f0f3f5 15%, #fff 35%, #fff 65%, #f0f3f5 85%, #e0e4e9);
  background: -webkit-linear-gradient(left, #e0e4e9, #f0f3f5 15%, #fff 35%, #fff 65%, #f0f3f5 85%, #e0e4e9);
  background: linear-gradient(to right, #e0e4e9, #f0f3f5 15%, #fff 35%, #fff 65%, #f0f3f5 85%, #e0e4e9)
}

.p-productEyelashserum__graphInner {
  width: 80%;
  max-width: 860px;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: center
}

.p-productEyelashserum__graphInner div {
  padding: 20px
}

.p-productEyelashserum__graph p {
  width: 90%;
  font-size: 1rem;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif;
  text-align: center;
  margin: 1rem auto
}

.p-productEyelashserum__voice {
  background-color: #fff;
  padding: 60px 0
}

.p-productEyelashserum__voiceTitle {
  text-align: center
}

.p-productEyelashserum__voiceTitle p {
  font-size: 3rem;
  margin-bottom: 0
}

.p-productEyelashserum__voiceTitle h2 {
  font-size: 4.2rem;
  font-weight: 500;
  line-height: 1.5;
  color: #a3131c
}

.p-productEyelashserum__voiceInner {
  width: 60%;
  max-width: 860px;
  margin: 40px auto 10px;
  display: flex;
  align-items: center;
  justify-content: space-between
}

.p-productEyelashserum__voiceInner .left {
  width: 22%
}

.p-productEyelashserum__voiceInner .right {
  flex: 1;
  font-size: 1.8rem;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif;
  line-height: 2.5;
  text-align: left;
  line-height: 2;
  padding-left: 30px;
  margin-bottom: 0
}

.p-productEyelashserum__voiceInner .right strong {
  font-weight: 600;
  color: #a3131c
}

.p-productEyelashserum__voiceInner .right .fs-sm {
  font-size: 1rem
}

.p-productEyelashserum__voiceInner.reverse {
  flex-direction: row-reverse
}

.p-productEyelashserum__voiceInner.reverse p {
  padding: 0 30px 0 0
}

.p-productEyelashserum__voiceInner .ba {
  width: 47%
}

.p-productEyelashserum__voice .kome {
  font-size: 1rem;
  text-align: right;
  width: 70%;
  margin: 0 auto 60px
}

.p-productEyelashserum__usage {
  padding: 40px 0;
  background-color: #ebecf0
}

.p-productEyelashserum__usageTitle {
  text-align: center;
  margin-bottom: 40px
}

.p-productEyelashserum__usageTitle p {
  font-size: 3rem;
  margin-bottom: 0
}

.p-productEyelashserum__usageTitle h2 {
  font-size: 4.2rem;
  font-weight: 500
}

.p-productEyelashserum__usageInner {
  width: 70%;
  max-width: 860px;
  margin: 0 auto 40px;
  display: flex;
  justify-content: space-between
}

.p-productEyelashserum__usageBox {
  width: 22%
}

.p-productEyelashserum__usageBox div {
  position: relative;
  text-align: center
}

.p-productEyelashserum__usageBox div .label {
  font-size: 6rem;
  font-family: Didot, "游明朝体", "Noto Serif JP", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  line-height: 1;
  color: #a3131c;
  position: absolute;
  top: -5%;
  left: 10%
}

.p-productEyelashserum__usageBox p {
  margin-top: 10px;
  font-size: 1.2rem;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif
}

.p-productEyelashserum__usageNote {
  width: 70%;
  max-width: 860px;
  margin: auto;
  font-size: 1rem;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif
}

.p-productEyelashserum__faq {
  padding: 60px 0;
  background: #fff
}

.p-productEyelashserum__faq h2 {
  font-size: 4.2rem;
  font-weight: 500;
  text-align: center
}

.p-productEyelashserum__faqAccordion {
  width: 60%;
  max-width: 860px;
  margin: 40px auto;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif
}

.p-productEyelashserum__faqAccordion dl {
  margin-bottom: 5px
}

.p-productEyelashserum__faqAccordion .acc-btn {
  width: 100%;
  margin: 0 auto;
  padding: 30px 80px;
  background: #faf4f4;
  cursor: pointer;
  position: relative;
  font-size: 1.4rem;
  font-weight: 400;
  color: #000
}

.p-productEyelashserum__faqAccordion .acc-btn:before {
  font-size: 1.4rem;
  color: #a3131c;
  content: "Q.";
  padding-right: 5px
}

.p-productEyelashserum__faqAccordion .acc-btn:after {
  font-size: 3rem;
  font-family: Material Icons;
  content: "expand_more";
  position: absolute;
  right: 40px;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transition: 0.2s
}

.p-productEyelashserum__faqAccordion .acc-btn.open:after {
  transform: translateY(-50%) rotate(180deg);
  transition: 0.2s
}

.p-productEyelashserum__faqAccordion .acc-content {
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing: 0;
  width: 100%;
  display: none;
  margin: auto;
  padding: 20px 80px 30px;
  height: auto;
  position: relative
}

.p-productEyelashserum__faqAccordion .acc-content:before {
  font-size: 1.4rem;
  color: #a3131c;
  content: "A.";
  padding-right: 5px
}

.p-productEyelashserum__cta {
  background: url("../img/product/_eyelashserum/cart_bg.jpg") center/cover no-repeat;
  padding: 5rem 0
}

.p-productEyelashserum__cart {
  width: 60%;
  max-width: 560px;
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif;
  margin: auto;
  display: flex;
  justify-content: space-around;
  align-items: center
}

.p-productEyelashserum__cartLabel {
  font-size: 1.4rem;
  margin-bottom: 0
}

.p-productEyelashserum__cartName {
  font-size: 1.6rem
}

.p-productEyelashserum__cart .left {
  flex: 1;
  text-align: center
}

.p-productEyelashserum__cart .left img {
  max-width: 50px
}

.p-productEyelashserum__cart .right {
  flex: 1.5;
  text-align: center
}

.p-productEyelashserum__cart .p-planProduct__cart {
  justify-content: center
}

.p-productEyelashserum__cart .p-planProduct__price {
  flex: inherit;
  padding-right: 10px
}

.p-productEyelashserum__cart .p-planProduct__button>a {
  background-color: #a3131c
}

.p-productEyelashserum__bnr {
  margin: 40px auto 0;
  text-align: center;
  line-height: 1
}

.pointOne {
  background: #e9eff5 url("../img/product/_eyelashserum/point_1_bg_pc.jpg") center top/cover no-repeat
}

.pointOne h3:before {
  content: "1"
}

.pointTwo {
  padding-bottom: 0 !important;
  background: #e9eff5 url("../img/product/_eyelashserum/point_2_bg_pc.jpg") center top/cover no-repeat
}

.pointTwo h3:before {
  content: "2"
}

.pointTwo img {
  vertical-align: bottom
}

.pointThree {
  padding-bottom: 60px;
  background: #e9eff5 url("../img/product/_eyelashserum/point_3_bg_pc.jpg") center top/cover no-repeat
}

.pointThree h3:before {
  content: "3"
}

@-webkit-keyframes floating-arrow-anim {
  0% {
    -webkit-transform: translateY(-15%);
    transform: translateY(-15%)
  }
  to {
    -webkit-transform: translateY(15%);
    transform: translateY(15%)
  }
}

@keyframes floating-arrow-anim {
  0% {
    -webkit-transform: translateY(-15%);
    transform: translateY(-15%)
  }
  to {
    -webkit-transform: translateY(15%);
    transform: translateY(15%)
  }
}

@media (max-width: 1199px) {
  .p-productEyelashserum {
    margin-top: 150px
  }
  .p-productEyelashserum__hero {
    padding-top: 220px
  }
  .p-productEyelashserum__hero .c-heroBackground {
    top: -150px
  }
}

@media (min-width: 1441px) {
  .p-productEyelashserum__heroTitle {
    font-size: 48px
  }
}

@media (max-width: 959px) {
  .p-productEyelashserum {
    margin-top: calc(15px + (100vw - 320px) / 40);
    margin-bottom: 0;
    margin-top: 0;
    padding-top: 90px;
  }
  .p-productEyelashserum__intro {
    background: none
  }
  .p-productEyelashserum__hero {
    padding-top: 0
  }
  .p-productEyelashserum__hero .c-heroBackground {
    height: 45vw;
    position: relative;
    margin-top: 0 !important;
    top: 0;
    background-position: right;
  }
  .p-productEyelashserum__heroTitle {
    font-size: 6vw;
    position: relative;
    display: block;
    width: 100%;
    top: inherit;
    left: inherit;
    background: url("../img/product/_eyelashserum/hero_bg_sp.jpg") center top/cover no-repeat;
    padding: 20px 0
  }
  .p-productEyelashserum__heroItem {
    top: inherit;
    top: 5%;
    right: 5%;
    width: 18vw;
    max-width: 150px
  }
  .p-productEyelashserum__release {
    padding-top: 50px;
    padding-bottom: 50vw;
    background: url("../img/product/_eyelashserum/intro_bg_sp.jpg") center top/cover no-repeat
  }
  .p-productEyelashserum__releaseTitle p {
    font-size: 3.3vw;
    line-height: 2.25
  }
  .p-productEyelashserum__releaseTitle p span {
    font-size: 4.4vw
  }
  .p-productEyelashserum__releaseTitle h2 {
    font-size: 7.1vw;
    line-height: 1.5;
    margin-bottom: 10px
  }
  .p-productEyelashserum__releaseInner {
    width: 92%;
    margin: auto;
    flex-direction: column
  }
  .p-productEyelashserum__releaseInner .right {
    padding: 0;
    text-align: center;
    font-size: 4.4vw
  }
  .p-productEyelashserum__releaseInner .right p {
    padding-top: 10px;
    font-size: 4.6vw;
    margin-bottom: 0
  }
  .p-productEyelashserum__trouble {
    padding-top: 50vw;
    padding-bottom: 0
  }
  .p-productEyelashserum__troubleDecline {
    width: 92%;
    max-width: inherit;
    padding: 0;
    top: -44vw
  }
  .p-productEyelashserum__troubleDecline__inner {
    height: auto;
    padding: 8vw 4%
  }
  .p-productEyelashserum__troubleDecline h3 {
    font-size: 4.4vw
  }
  .p-productEyelashserum__troubleDecline p {
    font-size: 4.1vw;
    margin-bottom: 0
  }
  .p-productEyelashserum__troubleDecline p .fs-lg {
    font-size: 5.8vw
  }
  .p-productEyelashserum__troubleDecline p .fs-sm {
    font-size: 3.7vw
  }
  .p-productEyelashserum__troubleDecline__img {
    width: 100%;
    max-width: 700px;
    display: flex;
    justify-content: space-between;
    margin: 10px auto
  }
  .p-productEyelashserum__troubleDecline__img div {
    flex: 1;
    padding: 0 5px
  }
  .p-productEyelashserum__troubleDecline__arrow {
    width: 3vw;
    bottom: -6vw
  }
  .p-productEyelashserum__troubleInner {
    width: 90%;
    margin: 0 auto 10%;
    flex-direction: column-reverse
  }
  .p-productEyelashserum__troubleInner .left {
    width: 100%;
    margin-top: -12%;
    z-index: 10
  }
  .p-productEyelashserum__troubleInner .left p {
    font-size: 3.8vw;
    line-height: 2;
    padding: 15px 30px;
    bottom: -35%;
    left: 6%;
    right: inherit
  }
  .p-productEyelashserum__troubleInner .left img {
    width: 60%;
    margin: 0
  }
  .p-productEyelashserum__troubleInner .right {
    width: 100%;
    margin: 0
  }
  .p-productEyelashserum__troubleInner .right p {
    font-size: 3.8vw;
    padding: 15px 30px;
    top: 10%;
    right: 6%;
    left: inherit
  }
  .p-productEyelashserum__troubleInner .right img {
    width: 60%;
    margin-right: 0
  }
  .p-productEyelashserum__troubleMsg {
    font-size: 4.6vw;
    padding: 30px 0;
    margin-bottom: 0
  }
  .p-productEyelashserum__troubleMsg .fs-lg {
    font-size: 5.8vw
  }
  .p-productEyelashserum__reason {
    padding-top: 70px
  }
  .p-productEyelashserum__reasonSpeech {
    font-size: 3.3vw;
    line-height: 2.25;
    margin-bottom: 10px
  }
  .p-productEyelashserum__reasonSpeech span {
    padding: 0 22px
  }
  .p-productEyelashserum__reasonSpeech span:before {
    width: 20px
  }
  .p-productEyelashserum__reasonSpeech span:after {
    width: 20px
  }
  .p-productEyelashserum__reason h2 {
    font-size: 6.9vw;
    font-weight: 500
  }
  .p-productEyelashserum__reasonTitle {
    width: 92%;
    display: flex;
    align-items: center
  }
  .p-productEyelashserum__reasonTitle div {
    width: 30%;
    position: relative;
    min-height: 18vw;
    top: inherit;
    left: inherit;
    transform: inherit;
    -webkit-transform: inherit;
    -ms-transform: inherit
  }
  .p-productEyelashserum__reasonTitle div img {
    width: 50vw;
    max-width: initial;
    right: 0;
    position: absolute
  }
  .p-productEyelashserum__reasonTitle h3 {
    width: 70%;
    font-size: 4.9vw;
    line-height: 1.5;
    text-align: left;
    padding-left: 1rem
  }
  .p-productEyelashserum__reasonInner {
    width: 92%;
    padding: 30px 4%;
    margin: 20px auto 40px
  }
  .p-productEyelashserum__reasonInner p {
    font-size: 3.3vw;
    line-height: 2.25
  }
  .p-productEyelashserum__reasonInner img {
    width: 100%;
    margin-bottom: 20px
  }
  .p-productEyelashserum__reasonFact {
    width: 92%
  }
  .p-productEyelashserum__reasonFact__title {
    font-size: 4.4vw
  }
  .p-productEyelashserum__reasonFact__inner {
    padding: 30px 4%
  }
  .p-productEyelashserum__reasonFact__inner p {
    font-size: 3.3vw;
    line-height: 2.25
  }
  .p-productEyelashserum__reasonFact__innerSpiral {
    flex-direction: column
  }
  .p-productEyelashserum__reasonFact__innerSpiral div {
    font-size: 3.3vw;
    line-height: 2.25;
    width: 100%;
    padding: 6vw 4%
  }
  .p-productEyelashserum__reasonFact__innerSpiral div img {
    width: 2.2vw;
    top: inherit;
    bottom: -4vw;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-productEyelashserum__reasonFact__innerSpiral .layer_2 {
    margin: 6vw auto
  }
  .p-productEyelashserum__point {
    padding: 40px 0;
    background: #e9eff5 url("../img/product/_eyelashserum/point_bg_sp.png") center top/100% no-repeat
  }
  .p-productEyelashserum__pointTitle {
    padding-top: 40px;
    text-align: left
  }
  .p-productEyelashserum__pointTitle p {
    font-size: 4.9vw;
    text-align: center
  }
  .p-productEyelashserum__pointTitle h2 {
    font-size: 7.1vw;
    text-align: center
  }
  .p-productEyelashserum__pointTitle img {
    width: 95%;
    margin: 20px auto
  }
  .p-productEyelashserum__pointTitle__glow {
    width: 92%;
    max-width: inherit;
    margin-top: 20px;
    font-size: 3.7vw;
    text-align: center
  }
  .p-productEyelashserum__pointContents {
    width: 90%
  }
  .p-productEyelashserum__pointContents__title {
    font-size: 5.8vw
  }
  .p-productEyelashserum__pointContents__inner {
    padding: 30px 4%
  }
  .p-productEyelashserum__pointContents__inner h3 {
    font-size: 4.9vw
  }
  .p-productEyelashserum__pointContents__inner h3::before {
    font-size: 16vw;
    font-weight: 800
  }
  .p-productEyelashserum__pointContents__box {
    flex-direction: column;
    margin-top: 0px
  }
  .p-productEyelashserum__pointContents__box .left {
    width: 100%;
    text-align: center;
    padding: 10px 0
  }
  .p-productEyelashserum__pointContents__box .right {
    width: 100%
  }
  .p-productEyelashserum__pointContents__box .right p {
    font-size: 3.3vw;
    line-height: 2.25
  }
  .p-productEyelashserum__pointContents__box .right .kome {
    font-size: 2.3vw
  }
  .p-productEyelashserum__pointGlow {
    background: url("../img/product/_eyelashserum/point_glow_bg_sp.jpg") center top 40%/100% no-repeat
  }
  .p-productEyelashserum__pointGlow__orb {
    width: 92%;
    margin: 30px auto
  }
  .p-productEyelashserum__pointGlow__material {
    width: 92%;
    justify-content: space-around
  }
  .p-productEyelashserum__pointGlow__material div {
    width: 45%;
    padding: 0px;
    text-align: left;
    margin-bottom: 5vw
  }
  .p-productEyelashserum__pointGlow__material div p {
    font-size: 2.6vw;
    left: 40%;
    bottom: 0
  }
  .p-productEyelashserum__pointGlow__material div p span {
    font-size: 3vw;
    margin-bottom: 5px
  }
  .p-productEyelashserum__pointGlow__material div img {
    width: 90%
  }
  .p-productEyelashserum__graphInner {
    width: 100%
  }
  .p-productEyelashserum__graphInner div {
    padding: 0
  }
  .p-productEyelashserum__graphInner div img {
    margin-left: -15%
  }
  .p-productEyelashserum__voice {
    padding: 40px 0
  }
  .p-productEyelashserum__voiceTitle p {
    font-size: 3.7vw
  }
  .p-productEyelashserum__voiceTitle h2 {
    font-size: 7.1vw
  }
  .p-productEyelashserum__voiceInner {
    width: 92%;
    margin: 40px auto 10px
  }
  .p-productEyelashserum__voiceInner .left {
    width: 30%
  }
  .p-productEyelashserum__voiceInner .right {
    font-size: 3.3vw;
    line-height: 2.25;
    padding-left: 15px
  }
  .p-productEyelashserum__voiceInner.reverse p {
    padding: 0 15px 0 0
  }
  .p-productEyelashserum__voice .kome {
    font-size: 2.3vw;
    width: 92%;
    margin-bottom: 30px
  }
  .p-productEyelashserum__usageTitle p {
    font-size: 3.7vw
  }
  .p-productEyelashserum__usageTitle h2 {
    font-size: 7.1vw
  }
  .p-productEyelashserum__usageInner {
    width: 92%;
    margin: 0 auto;
    flex-wrap: wrap
  }
  .p-productEyelashserum__usageBox {
    width: 45%;
    margin-bottom: 30px
  }
  .p-productEyelashserum__usageBox div .label {
    font-size: 14vw;
    top: -3%;
    left: 3%
  }
  .p-productEyelashserum__usageBox p {
    font-size: 2.8vw
  }
  .p-productEyelashserum__usageNote {
    width: 92%;
    font-size: 2.3vw
  }
  .p-productEyelashserum__faq {
    padding: 30px 0
  }
  .p-productEyelashserum__faq h2 {
    font-size: 7.1vw
  }
  .p-productEyelashserum__faqAccordion {
    width: 90%;
    margin: 20px auto
  }
  .p-productEyelashserum__faqAccordion .acc-btn {
    padding: 20px;
    font-size: 2.8vw
  }
  .p-productEyelashserum__faqAccordion .acc-btn:before {
    font-size: 2.8vw
  }
  .p-productEyelashserum__faqAccordion .acc-btn:after {
    font-size: 4.4vw;
    right: 6px
  }
  .p-productEyelashserum__faqAccordion .acc-content {
    font-size: 2.8vw;
    padding: 20px 20px 30px
  }
  .p-productEyelashserum__faqAccordion .acc-content:before {
    font-size: 2.8vw
  }
  .p-productEyelashserum__cart {
    width: 90%
  }
  .p-productEyelashserum__cart .left {
    flex: inherit;
    padding-left: 1rem
  }
  .p-productEyelashserum__cart .left img {
    width: 30px
  }
  .p-productEyelashserum__cart .p-planProduct__price {
    padding-right: 5px
  }
  .p-productEyelashserum__cart .p-planSection__number {
    padding: 0
  }
  .p-productEyelashserum__bnr {
    width: 90%;
    margin: 20px auto
  }
  .pointOne {
    background: #e9eff5 url("../img/product/_eyelashserum/point_1_bg_sp.jpg") center top/cover no-repeat
  }
  .pointTwo {
    padding-bottom: 30px !important;
    background: #e9eff5 url("../img/product/_eyelashserum/point_2_bg_sp.jpg") center top/cover no-repeat
  }
  .pointTwo img {
    vertical-align: baseline
  }
  .pointThree {
    padding-bottom: 30px;
    background: #e9eff5 url("../img/product/_eyelashserum/point_3_bg_sp.jpg") center top/cover no-repeat
  }
  .pointThree img {
    width: 75%
  }
}

.p-flow {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 140px
}

.p-flowSteps {
  width: 90%;
  margin: 0 auto
}

.p-flowPrograms {
  width: 90%;
  margin: 0 auto;
  padding: 80px 0 115px
}

.p-flowScroll {
  width: 100%
}

.p-flowUses {
  display: flex;
  margin-top: 80px;
  min-width: calc(960px - 10vw)
}

.p-flowUse {
  flex: 1;
  background-color: #fff;
  border-radius: 10px;
  height: 500px;
  margin-right: calc(15px + (100% - 960px) / 96);
  position: relative;
  text-align: center
}

.p-flowUse:last-child {
  margin-right: 0
}

.p-flowUse__number {
  position: absolute;
  top: -30px;
  left: 25px
}

.p-flowUse__image1 {
  height: 180px;
  margin: 70px 0 50px
}

.p-flowUse__image2 {
  height: 180px;
  margin: 70px 0 50px
}

.p-flowUse__image3 {
  width: 180px;
  margin: 92px 0 71px
}

.p-flowUse__text {
  width: 80%;
  margin: 0 auto;
  text-align: left
}

.p-flowUse__title {
  font-size: 2rem
}

.p-flowUse__content {
  margin-top: 25px;
  font-size: 1.4rem
}

.p-flowPrograms__items {
  width: 100%;
  justify-content: space-around;
  flex-wrap: wrap;
  margin-top: 80px
}

.p-flowPrograms__item {
  position: relative;
  text-align: center;
  width: 330px;
  max-width: 95%;
  height: 590px
}

.p-flowPrograms__number {
  position: absolute;
  top: 0;
  left: 0
}

.p-flowPrograms__image {
  width: 280px;
  margin: 25px 0
}

.p-flowPrograms__text {
  width: 95%;
  margin: 0 auto;
  text-align: left
}

.p-flowPrograms__title {
  font-size: 2rem
}

.p-flowPrograms__content {
  margin-top: 25px;
  font-size: 1.4rem
}

@media (max-width: 1199px) {
  .p-flowUse__text {
    width: 88%
  }
}

@media (min-width: 1441px) {
  .p-flowPrograms__item {
    flex-basis: 30%
  }
}

@media (max-width: 959px) {
  .p-flow {
    margin-top: calc(15px + (100vw - 320px) / 40);
    margin-bottom: 0
  }
  .p-flow>.c-hero {
    height: calc(75vw + (100vw - 320px) / 40)
  }
  .p-flow__title {
    text-align: center
  }
  .p-flowHero {
    background-position: 70% 50%
  }
  .p-flowSVG {
    max-width: 45vw
  }
  .p-flowSteps {
    padding-top: 50px
  }
  .p-flowScroll {
    overflow-x: scroll
  }
  .p-flowUses {
    width: 865px
  }
  .p-flowUse {
    flex: unset;
    width: 275px;
    height: 324px;
    margin-right: 20px
  }
  .p-flowUse__image1 {
    height: 115px;
    margin: 40px 0 20px
  }
  .p-flowUse__image2 {
    height: 115px;
    margin: 40px 0 20px
  }
  .p-flowUse__image3 {
    width: 115px;
    margin: 55px 0 30px
  }
  .p-flowUse__number {
    height: 44px;
    top: -22px
  }
  .p-flowUse__title {
    font-size: 1.6rem
  }
  .p-flowUse__content {
    margin-top: 10px;
    font-size: 1.2rem
  }
  .p-flowPrograms__items {
    margin-top: 30px
  }
}

.p-footerLinkUp {
  display: flex;
  width: 100%;
  margin-bottom: 60px
}

.p-footerLinkUp__flex {
  flex: 1 1 auto;
  height: 30px;
  padding-left: 30px;
  border-left: 1px solid #4d4d4d;
  position: relative
}

.p-footerLinkUp__flex:not(:first-child) {
  margin-left: 20px
}

.p-footerLinkUp__flex>a {
  color: #fff;
  line-height: 2;
  /* position: absolute; */
  bottom: 0px
}

.p-footerLinkUp__flex>a:hover {
  opacity: .6
}

.p-footerLinkDown {
  width: 100%;
  display: flex;
  bottom: 0
}

.p-footerLinkDown__flex {
  flex: 1 1 auto;
  height: 30px;
  padding-left: 30px;
  border-left: 1px solid #4d4d4d;
  position: relative
}

.p-footerLinkDown__flex:not(:first-child) {
  margin-left: 20px
}

.p-footerLinkDown__flex>a {
  color: #fff;
  line-height: 1.5;
  position: absolute;
  top: 0px
}

.p-footerLinkDown__flex>a:hover {
  opacity: .6
}

.p-footerLinkDown__block {
  flex: 1 1 auto;
  padding-left: 30px;
  margin-left: 20px
}

.p-footerLinkActive>a:before {
  position: absolute;
  top: 35px;
  left: 0;
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  background: #fff
}

@media (max-width: 959px) {
  .p-footerLinkUp {
    margin-bottom: 30px
  }
  .p-footerLinkUp__flex {
    /* height: 80px; */
    padding-left: 10px;
    font-size: 1.1rem
  }
  .p-footerLinkUp__flex:not(:first-child) {
    margin-left: 10px
  }
  .p-footerLinkDown {
    position: static
  }
  .p-footerLinkDown__flex {
    /* height: 80px; */
    padding-left: 10px;
    font-size: 1.1rem
  }
  .p-footerLinkDown__flex:not(:first-child) {
    margin-left: 10px
  }
  .p-footerLinkDown__block {
    padding-left: 10px;
    margin-left: 10px
  }
  .p-footerLinkActive>a:before {
    top: auto;
    bottom: -5px
  }
}

.p-forgetComp__msg {
  margin-top: 30px
}

.p-forgetComp__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 35px;
  display: inline-block
}

.p-forgetComp__link:hover {
  color: #313131
}

.p-forgetComp__btn {
  margin-top: 50px
}

@media (min-width: 960px) {
  .p-forgetComp {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-forgetComp__msg {
    margin-top: 20px
  }
}

.p-forget__msg {
  margin-top: 30px
}

.p-forget__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 35px;
  display: inline-block
}

.p-forget__link:hover {
  color: #313131
}

.p-forget__email {
  margin: 50px 0 30px
}

.p-forget__email__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

@media (min-width: 960px) {
  .p-forget {
    max-width: 980px;
    margin: auto
  }
  .p-forget>form {
    width: 400px;
    margin: auto
  }
  .p-forget__btn {
    width: 100%;
    margin: auto;
    display: block
  }
}

@media (max-width: 959px) {
  .p-forget__msg {
    margin-top: 20px
  }
}

.p-forgetReset__msg {
  margin: 30px auto 0;
  width: 70%
}

.p-forgetReset__row {
  margin-top: 30px
}

.p-forgetReset__msg .p-forgetReset__row {
  margin-top: 0
}

.p-forgetReset__title {
  flex-basis: 25%;
  max-width: 25%
}

.p-forgetReset__input {
  flex-basis: 75%;
  max-width: 75%
}

.p-forgetReset__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-forgetReset__sec {
  margin-top: 20px
}

@media (min-width: 960px) {
  .p-forgetReset {
    max-width: 980px;
    margin: auto
  }
  .p-forgetReset>form {
    width: 70%;
    margin: auto
  }
  .p-forgetReset__title {
    text-align: right;
    padding: 19px 40px 0 0
  }
  .p-forgetReset__btn {
    width: 100%;
    margin: 50px auto;
    display: block
  }
}

@media (max-width: 959px) {
  .p-forgetReset__msg {
    margin-top: 20px;
    width: 100%
  }
  .p-forgetReset__title {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    margin: 0 0 10px;
    font-weight: bold
  }
  .p-forgetReset__input {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto
  }
  .p-forgetReset__btn {
    margin-top: 30px
  }
}

.p-globalNav__lists {
  display: flex;
  list-style: none;
  justify-content: space-between;
  align-items: center
}

.p-globalNav__list {
  margin: 0 15px;
  line-height: 1.6
}

.p-globalNav__list:last-child {
  margin-right: 0
}

.p-globalNav__Sub {
  position: absolute;
  padding: 0;
  background: #221815;
  border-right: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
  z-index: 10000;
  list-style: none;
  display: none
}

.p-globalNav__Sub>li a {
  padding: 12px 12px;
  display: block;
  font-size: 90%;
  color: #fff;
  text-decoration: none;
  width: 160px;
  line-height: 2;
}

.p-globalNav__Sub>li a:hover {
  background: #595959;
  color: #FFF
}

@media (max-width: 1199px) {
  .p-globalNav__list {
    margin: 0 10px
  }
}

.p-helpAbout__heading {
  margin-bottom: 30px
}

.p-helpAbout__flex>* {
  padding: 30px 20px 0
}

.p-helpAbout__flex>*:first-child {
  padding-left: 0
}

.p-helpAbout__flex>*:last-child {
  padding-right: 0
}

.p-helpAbout__title {
  flex-basis: 20%;
  max-width: 20%;
  text-align: right
}

.p-helpAbout__input {
  flex-basis: 80%;
  max-width: 80%
}

.p-helpAbout__link {
  color: #A82228;
  text-decoration: underline
}

.p-helpAbout__link:hover {
  color: #313131
}

.p-helpAbout__hr {
  padding-left: 20%
}

.p-helpAbout__hr>hr {
  margin: 20px 0 0
}

.p-helpAbout__contact>span {
  font-size: 1rem
}

.p-helpAbout__contact>i {
  font-size: 1.4rem;
  color: #A82228;
  opacity: 1;
  position: relative;
  top: 3px;
  font-weight: bold
}

@media (min-width: 960px) {
  .p-helpAbout {
    max-width: 1000px;
    margin: 80px auto;
  }
  .p-helpAbout__container {
    max-width: 960px;
    margin: 50px 0 0
  }
  .p-helpAbout__flex {
    align-items: center
  }
  .p-helpAbout__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-helpAbout__heading {
    margin-bottom: 20px
  }
  .p-helpAbout__flex {
    margin-top: 0px
  }
  .p-helpAbout__flex>* {
    padding: 0 0 10px
  }
  .p-helpAbout__title {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    text-align: left;
    font-weight: bold
  }
  .p-helpAbout__input {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto
  }
  .p-helpAbout__hr {
    padding-left: 0
  }
  .p-helpAbout__hr>hr {
    margin: 10px auto 20px
  }
}

.p-helpFaqAbout__wrap {
  display: flex;
  width: 90%;
  margin: 0 auto;
  padding: 0 0 85px
}

.p-helpFaqAbout__wrapMenu {
  padding: 40px 20px;
  background-color: #fff
}

.p-helpFaqAbout__wrapMenu__title {
  margin: auto;
  text-align: center;
  padding-bottom: 30px
}

.p-helpFaqAbout__wrapMenu__title>img {
  width: 54%
}

.p-helpFaqAbout__wrapMenu__title__subtitle {
  color: #221815;
  font-size: 1.6rem;
  padding-top: 10px
}

.p-helpFaqAbout__wrapMenu__categories {
  display: flex;
  flex-direction: column
}

.p-helpFaqAbout__wrapMenu__categories__category {
  flex-basis: auto;
  max-width: 100%;
  padding: 0 20px 50px;
  text-align: center;
  min-height: 0%
}

.p-helpFaqAbout__wrapMenu__categories__category__title {
  display: flex;
  align-items: center
}

.p-helpFaqAbout__wrapMenu__categories__category__title>img {
  width: 12%;
  padding: 5px 5px 5px 0
}

.p-helpFaqAbout__wrapMenu__categories__category__title>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 1.8rem;
  text-align: left;
  margin-bottom: 0
}

.p-helpFaqAbout__wrapMenu__categories__category__title>h3>a {
  color: #000;
  display: block
}

.p-helpFaqAbout__wrapMenu__categories__category__title>h3>a:hover {
  color: #221815
}

.p-helpFaqAbout__wrapMenu__categories__category__title>h3>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqAbout__wrapMenu__categories__category>ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.6rem;
  padding-top: 20px;
  border-top: 1px solid #ccc
}

.p-helpFaqAbout__wrapMenu__categories__category>ul>li {
  width: 100%;
  text-align: left;
  margin-bottom: 16px;
  position: relative
}

.p-helpFaqAbout__wrapMenu__categories__category>ul>li>a {
  color: #000;
  display: block
}

.p-helpFaqAbout__wrapMenu__categories__category>ul>li>a:hover {
  color: #221815
}

.p-helpFaqAbout__wrapMenu__categories__category>ul>li>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqAbout__wrapMenu__categories__contact {
  flex-basis: auto;
  max-width: 100%;
  min-height: 0%;
  padding: 0 16px 100px;
  text-align: center;
  background: #eee;
  padding: 40px 30px;
  border-radius: 10px
}

.p-helpFaqAbout__wrapMenu__categories__contact>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqAbout__wrapMenu__categories__contact>h4 {
  margin: 30px auto 10px;
  font-weight: normal
}

.p-helpFaqAbout__wrapMenu__categories__contact__text {
  text-align: left
}

.p-helpFaqAbout__wrapMenu__categories__contact__number {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px
}

.p-helpFaqAbout__wrapMenu__categories__contact__number>img {
  vertical-align: middle;
  padding-right: 10px
}

.p-helpFaqAbout__wrapMenu__categories__contact__caption {
  font-size: calc(10px + (100vw - 960px) / 240)
}

.p-helpFaqAbout__wrapMenu__categories__contact__button>a {
  margin: 20px auto 10px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 320px;
  height: 60px;
  line-height: 60px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-helpFaqAbout__wrapMenu__categories__contact__button>a:hover {
  opacity: .9
}

.p-helpFaqAbout__wrapContents {
  flex-basis: 70%;
  margin-left: 40px
}

.p-helpFaqAbout__wrapContents__backlink {
  font-size: 1.2rem
}

.p-helpFaqAbout__wrapContents__backlink>a {
  color: #000;
  position: relative;
  padding-left: 36px
}

.p-helpFaqAbout__wrapContents__backlink>a:hover {
  color: #221815
}

.p-helpFaqAbout__wrapContents__backlink>a:before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 10px;
  height: 1px;
  background: #666;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg)
}

.p-helpFaqAbout__wrapContents__backlink>a:after {
  content: "";
  position: absolute;
  top: 6px;
  left: 1px;
  width: 28px;
  height: 8px;
  border-bottom: 1px solid #666
}

.p-helpFaqAbout__wrapContents__title {
  display: flex;
  align-items: center
}

.p-helpFaqAbout__wrapContents__title>img {
  width: 50px;
  padding: 5px 5px 5px 0
}

.p-helpFaqAbout__wrapContents__title>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 2.2rem;
  text-align: left;
  margin-bottom: 0
}

@media (min-width: 960px) {
  .p-helpFaqAbout__wrapMenu {
    flex-basis: 30%;
    max-width: 400px;
    min-width: 400px
  }
}

@media (max-width: 959px) {
  .p-helpFaqAbout__wrap {
    width: 90%;
    flex-direction: column-reverse;
    padding-bottom: 0
  }
  .p-helpFaqAbout__wrapMenu {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    min-height: 0%
  }
  .p-helpFaqAbout__wrapMenu__categories__category {
    padding: 0 0 50px
  }
  .p-helpFaqAbout__wrapMenu__categories__category__title>img {
    max-width: 30px
  }
  .p-helpFaqAbout__wrapContents {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    margin: 0
  }
  .p-helpFaqAbout__wrapContents__backlink {
    margin-bottom: 20px
  }
}

.p-helpFaqApp__order {
  margin: 30px 0
}

.p-helpFaqApp__msg {
  margin-bottom: 60px
}

.p-helpFaqApp__link {
  color: #A82228;
  text-decoration: underline;
  display: inline-block
}

.p-helpFaqApp__link:hover {
  color: #313131
}

.p-helpFaqApp__btn {
  margin-top: 20px
}

@media (max-width: 959px) {
  .p-helpFaqApp__order {
    margin: 20px 0
  }
  .p-helpFaqApp__msg {
    margin-bottom: 50px
  }
}

.p-helpFaqOrder__wrap {
  display: flex;
  width: 90%;
  margin: 0 auto;
  padding: 0 0 85px
}

.p-helpFaqOrder__wrapMenu {
  padding: 40px 20px;
  background-color: #fff
}

.p-helpFaqOrder__wrapMenu__title {
  margin: auto;
  text-align: center;
  padding-bottom: 30px
}

.p-helpFaqOrder__wrapMenu__title>img {
  width: 54%
}

.p-helpFaqOrder__wrapMenu__title__subtitle {
  color: #221815;
  font-size: 1.6rem;
  padding-top: 10px
}

.p-helpFaqOrder__wrapMenu__categories {
  display: flex;
  flex-direction: column
}

.p-helpFaqOrder__wrapMenu__categories__category {
  flex-basis: auto;
  max-width: 100%;
  padding: 0 20px 50px;
  text-align: center;
  min-height: 0%
}

.p-helpFaqOrder__wrapMenu__categories__category__title {
  display: flex;
  align-items: center
}

.p-helpFaqOrder__wrapMenu__categories__category__title>img {
  width: 12%;
  padding: 5px 5px 5px 0
}

.p-helpFaqOrder__wrapMenu__categories__category__title>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 1.8rem;
  text-align: left;
  margin-bottom: 0
}

.p-helpFaqOrder__wrapMenu__categories__category__title>h3>a {
  color: #000;
  display: block
}

.p-helpFaqOrder__wrapMenu__categories__category__title>h3>a:hover {
  color: #221815
}

.p-helpFaqOrder__wrapMenu__categories__category__title>h3>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqOrder__wrapMenu__categories__category>ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.6rem;
  padding-top: 20px;
  border-top: 1px solid #ccc
}

.p-helpFaqOrder__wrapMenu__categories__category>ul>li {
  width: 100%;
  text-align: left;
  margin-bottom: 16px;
  position: relative
}

.p-helpFaqOrder__wrapMenu__categories__category>ul>li>a {
  color: #000;
  display: block
}

.p-helpFaqOrder__wrapMenu__categories__category>ul>li>a:hover {
  color: #221815
}

.p-helpFaqOrder__wrapMenu__categories__category>ul>li>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqOrder__wrapMenu__categories__contact {
  flex-basis: auto;
  max-width: 100%;
  min-height: 0%;
  padding: 0 16px 100px;
  text-align: center;
  background: #eee;
  padding: 40px 30px;
  border-radius: 10px
}

.p-helpFaqOrder__wrapMenu__categories__contact>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqOrder__wrapMenu__categories__contact>h4 {
  margin: 30px auto 10px;
  font-weight: normal
}

.p-helpFaqOrder__wrapMenu__categories__contact__text {
  text-align: left
}

.p-helpFaqOrder__wrapMenu__categories__contact__number {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px
}

.p-helpFaqOrder__wrapMenu__categories__contact__number>img {
  vertical-align: middle;
  padding-right: 10px
}

.p-helpFaqOrder__wrapMenu__categories__contact__caption {
  font-size: calc(10px + (100vw - 960px) / 240)
}

.p-helpFaqOrder__wrapMenu__categories__contact__button>a {
  margin: 20px auto 10px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 320px;
  height: 60px;
  line-height: 60px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-helpFaqOrder__wrapMenu__categories__contact__button>a:hover {
  opacity: .9
}

.p-helpFaqOrder__wrapContents {
  flex-basis: 70%;
  margin-left: 40px
}

.p-helpFaqOrder__wrapContents__backlink {
  font-size: 1.2rem
}

.p-helpFaqOrder__wrapContents__backlink>a {
  color: #000;
  position: relative;
  padding-left: 36px
}

.p-helpFaqOrder__wrapContents__backlink>a:hover {
  color: #221815
}

.p-helpFaqOrder__wrapContents__backlink>a:before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 10px;
  height: 1px;
  background: #666;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg)
}

.p-helpFaqOrder__wrapContents__backlink>a:after {
  content: "";
  position: absolute;
  top: 6px;
  left: 1px;
  width: 28px;
  height: 8px;
  border-bottom: 1px solid #666
}

.p-helpFaqOrder__wrapContents__title {
  display: flex;
  align-items: center
}

.p-helpFaqOrder__wrapContents__title>img {
  width: 50px;
  padding: 5px 5px 5px 0
}

.p-helpFaqOrder__wrapContents__title>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 2.2rem;
  text-align: left;
  margin-bottom: 0
}

@media (min-width: 960px) {
  .p-helpFaqOrder__wrapMenu {
    flex-basis: 30%;
    max-width: 400px;
    min-width: 400px
  }
}

@media (max-width: 959px) {
  .p-helpFaqOrder__wrap {
    width: 90%;
    flex-direction: column-reverse;
    padding-bottom: 0
  }
  .p-helpFaqOrder__wrapMenu {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    min-height: 0%
  }
  .p-helpFaqOrder__wrapMenu__categories__category {
    padding: 0 0 50px
  }
  .p-helpFaqOrder__wrapMenu__categories__category__title>img {
    max-width: 30px
  }
  .p-helpFaqOrder__wrapContents {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    margin: 0
  }
  .p-helpFaqOrder__wrapContents__backlink {
    margin-bottom: 20px
  }
}

.p-helpFaqOther__wrap {
  display: flex;
  width: 90%;
  margin: 0 auto;
  padding: 0 0 85px
}

.p-helpFaqOther__wrapMenu {
  padding: 40px 20px;
  background-color: #fff
}

.p-helpFaqOther__wrapMenu__title {
  margin: auto;
  text-align: center;
  padding-bottom: 30px
}

.p-helpFaqOther__wrapMenu__title>img {
  width: 54%
}

.p-helpFaqOther__wrapMenu__title__subtitle {
  color: #221815;
  font-size: 1.6rem;
  padding-top: 10px
}

.p-helpFaqOther__wrapMenu__categories {
  display: flex;
  flex-direction: column
}

.p-helpFaqOther__wrapMenu__categories__category {
  flex-basis: auto;
  max-width: 100%;
  padding: 0 20px 50px;
  text-align: center;
  min-height: 0%
}

.p-helpFaqOther__wrapMenu__categories__category__title {
  display: flex;
  align-items: center
}

.p-helpFaqOther__wrapMenu__categories__category__title>img {
  width: 12%;
  padding: 5px 5px 5px 0
}

.p-helpFaqOther__wrapMenu__categories__category__title>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 1.8rem;
  text-align: left;
  margin-bottom: 0
}

.p-helpFaqOther__wrapMenu__categories__category__title>h3>a {
  color: #000;
  display: block
}

.p-helpFaqOther__wrapMenu__categories__category__title>h3>a:hover {
  color: #221815
}

.p-helpFaqOther__wrapMenu__categories__category__title>h3>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqOther__wrapMenu__categories__category>ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.6rem;
  padding-top: 20px;
  border-top: 1px solid #ccc
}

.p-helpFaqOther__wrapMenu__categories__category>ul>li {
  width: 100%;
  text-align: left;
  margin-bottom: 16px;
  position: relative
}

.p-helpFaqOther__wrapMenu__categories__category>ul>li>a {
  color: #000;
  display: block
}

.p-helpFaqOther__wrapMenu__categories__category>ul>li>a:hover {
  color: #221815
}

.p-helpFaqOther__wrapMenu__categories__category>ul>li>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqOther__wrapMenu__categories__contact {
  flex-basis: auto;
  max-width: 100%;
  min-height: 0%;
  padding: 0 16px 100px;
  text-align: center;
  background: #eee;
  padding: 40px 30px;
  border-radius: 10px
}

.p-helpFaqOther__wrapMenu__categories__contact>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqOther__wrapMenu__categories__contact>h4 {
  margin: 30px auto 10px;
  font-weight: normal
}

.p-helpFaqOther__wrapMenu__categories__contact__text {
  text-align: left
}

.p-helpFaqOther__wrapMenu__categories__contact__number {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px
}

.p-helpFaqOther__wrapMenu__categories__contact__number>img {
  vertical-align: middle;
  padding-right: 10px
}

.p-helpFaqOther__wrapMenu__categories__contact__caption {
  font-size: calc(10px + (100vw - 960px) / 240)
}

.p-helpFaqOther__wrapMenu__categories__contact__button>a {
  margin: 20px auto 10px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 320px;
  height: 60px;
  line-height: 60px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-helpFaqOther__wrapMenu__categories__contact__button>a:hover {
  opacity: .9
}

.p-helpFaqOther__wrapContents {
  flex-basis: 70%;
  margin-left: 40px
}

.p-helpFaqOther__wrapContents__backlink {
  font-size: 1.2rem
}

.p-helpFaqOther__wrapContents__backlink>a {
  color: #000;
  position: relative;
  padding-left: 36px
}

.p-helpFaqOther__wrapContents__backlink>a:hover {
  color: #221815
}

.p-helpFaqOther__wrapContents__backlink>a:before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 10px;
  height: 1px;
  background: #666;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg)
}

.p-helpFaqOther__wrapContents__backlink>a:after {
  content: "";
  position: absolute;
  top: 6px;
  left: 1px;
  width: 28px;
  height: 8px;
  border-bottom: 1px solid #666
}

.p-helpFaqOther__wrapContents__title {
  display: flex;
  align-items: center
}

.p-helpFaqOther__wrapContents__title>img {
  width: 50px;
  padding: 5px 5px 5px 0
}

.p-helpFaqOther__wrapContents__title>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 2.2rem;
  text-align: left;
  margin-bottom: 0
}

@media (min-width: 960px) {
  .p-helpFaqOther__wrapMenu {
    flex-basis: 30%;
    max-width: 400px;
    min-width: 400px
  }
}

@media (max-width: 959px) {
  .p-helpFaqOther__wrap {
    width: 90%;
    flex-direction: column-reverse;
    padding-bottom: 0
  }
  .p-helpFaqOther__wrapMenu {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    min-height: 0%
  }
  .p-helpFaqOther__wrapMenu__categories__category {
    padding: 0 0 50px
  }
  .p-helpFaqOther__wrapMenu__categories__category__title>img {
    max-width: 30px
  }
  .p-helpFaqOther__wrapContents {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    margin: 0
  }
  .p-helpFaqOther__wrapContents__backlink {
    margin-bottom: 20px
  }
}

.p-helpFaq {
  background-color: #eee;
  margin-top: 254px;
  padding-bottom: 140px
}

.p-helpFaq__hero {
  width: 176px
}

.p-helpFaqTitle {
  padding-bottom: 350px
}

.p-helpFaq hr {
  margin: 10px 0
}

.p-helpFaqSection {
  width: 84%;
  margin: 0 auto;
  background-color: #fff;
  padding: 0 7% 85px
}

.p-helpFaqSection__title {
  text-align: center;
  padding-bottom: 65px
}

.p-helpFaqSection__subtitle {
  color: #221815;
  font-size: 1.8rem
}

.p-helpFaqSection__categories {
  max-width: 1000px;
  height: 100%;
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around
}

.p-helpFaqSection__categories__category {
  flex-basis: 50%;
  max-width: 50%;
  padding: 0 16px 100px;
  text-align: center
}

.p-helpFaqSection__categories__category__title>img {
  width: 60px;
  padding-bottom: 20px
}

.p-helpFaqSection__categories__category__title>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqSection__categories__category__title>h2>a {
  color: #000;
  display: block
}

.p-helpFaqSection__categories__category__title>h2>a:hover {
  color: #221815
}

.p-helpFaqSection__categories__category__title>h2>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqSection__categories__category>ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.8rem;
  padding-top: 40px;
  border-top: 1px solid #ccc
}

.p-helpFaqSection__categories__category>ul>li {
  text-align: left;
  margin-bottom: 16px;
  position: relative
}

.p-helpFaqSection__categories__category>ul>li>a {
  color: #000;
  display: block
}

.p-helpFaqSection__categories__category>ul>li>a:hover {
  color: #221815
}

.p-helpFaqSection__categories__category>ul>li>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px;
  display: block
}

.p-helpFaqSection__categories__contact {
  flex-basis: 50%;
  max-width: 50%;
  padding: 0 16px 100px;
  text-align: center;
  background: #eee;
  padding: 40px 30px;
  border-radius: 10px
}

.p-helpFaqSection__categories__contact>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqSection__categories__contact>h3 {
  margin: 30px auto 10px;
  font-weight: normal
}

.p-helpFaqSection__categories__contact__text {
  text-align: left
}

.p-helpFaqSection__categories__contact__number {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px
}

.p-helpFaqSection__categories__contact__number>img {
  vertical-align: middle;
  padding-right: 10px
}

.p-helpFaqSection__categories__contact__caption {
  font-size: calc(10px + (100vw - 960px) / 240)
}

.p-helpFaqSection__categories__contact__button>a {
  margin: 20px auto 10px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 320px;
  height: 60px;
  line-height: 60px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-helpFaqSection__categories__contact__button>a:hover {
  opacity: .9
}

.p-helpFaqSVG {
  width: 300px;
  position: relative;
  z-index: 1;
  transform: translateY(-50%)
}

.p-helpFaqSVGSP {
  height: 64px;
  position: relative;
  z-index: 1;
  transform: translateY(-53%);
  max-width: 100%
}

@media (min-width: 960px) {
  .p-helpFaq .c-heroText__title, .p-helpFaq .c-heroText__content {
    color: #000
  }
}

@media (max-width: 1199px) {
  .p-helpFaq ul {
    flex-direction: column
  }
}

@media (max-width: 959px) {
  .p-helpFaq {
    margin-top: calc(15px + (100vw - 320px) / 40);
    margin-bottom: 0
  }
  .p-helpFaq>.c-hero {
    height: calc(75vw + (100vw - 320px) / 40)
  }
  .p-helpFaqTitle {
    padding-bottom: 70px
  }
  .p-helpFaqSection {
    width: 100%;
    margin-top: 50px
  }
  .p-helpFaqSection__title {
    padding-bottom: 40px
  }
  .p-helpFaqSection__subtitle {
    font-size: 1.2rem
  }
  .p-helpFaqSection__info {
    font-size: 1.6rem
  }
  .p-helpFaqSection__content {
    font-size: 1.2rem;
    margin: 18px 0 25px
  }
  .p-helpFaqSection__categories {
    flex-direction: column
  }
  .p-helpFaqSection__categories__category {
    flex-basis: auto;
    max-width: 100%;
    padding: 0 0 40px
  }
  .p-helpFaqSection__categories__category__title {
    display: flex;
    align-items: center
  }
  .p-helpFaqSection__categories__category__title>img {
    width: 40px;
    padding: 5px 5px 10px 0
  }
  .p-helpFaqSection__categories__category__title>h2 {
    flex: 1 1 auto;
    font-size: 1.8rem;
    text-align: left;
    margin-bottom: 0
  }
  .p-helpFaqSection__categories__category>ul {
    padding-top: 20px;
    font-size: 1.6rem
  }
  .p-helpFaqSection__categories__category>ul>li {
    margin-bottom: 20px
  }
  .p-helpFaqSection__categories__contact {
    flex-basis: auto;
    max-width: 100%
  }
}

.p-helpPrivacy__subtitle {
  margin: 60px 0 30px
}

.p-helpPrivacy__grey {
  font-size: 1.1rem;
  line-height: 1.3;
  padding: 20px;
  background-color: #f4f4f4;
  border: 1px solid #d8d8d8;
  margin: 10px 0;
  position: relative;
  display: none
}

.p-helpPrivacy__grey.active {
  display: block
}

.p-helpPrivacy__grey>button {
  position: absolute;
  top: 10px;
  right: 15px;
  width: 20px
}

.p-helpPrivacy__grey.active>button {
  transform: rotate(180deg)
}

.p-helpPrivacy__ps {
  margin: 30px 0
}

.p-helpPrivacy__link {
  color: #A82228;
  text-decoration: underline
}

.p-helpPrivacy__link:hover {
  color: #313131
}

.p-helpPrivacy__date {
  margin-top: 30px;
  color: #919191
}

.p-helpPrivacy__release {
  width: 100%;
  padding: 30px 40px;
  border: 1px solid #A82228
}

.p-helpPrivacy__release>h2 {
  color: #A82228;
  font-size: 1.8rem
}

.p-helpPrivacy__release>p {
  font-size: 1.2rem
}

@media (min-width: 960px) {
  .p-helpPrivacy {
    max-width: 980px;
    margin: auto
  }
  .p-helpPrivacy__title {
    margin: 40px 0 30px
  }
}

@media (max-width: 959px) {
  .p-helpPrivacy__title {
    margin-bottom: 20px
  }
  .p-helpPrivacy__subtitle {
    margin: 30px 0 20px
  }
  .p-helpPrivacy__grey {
    padding: 10px;
    margin: 10px 0
  }
  .p-helpPrivacy__grey>button {
    top: 1px;
    right: 5px
  }
  .p-helpPrivacy__ps {
    margin: 20px 0
  }
  .p-helpPrivacy__content, .p-helpPrivacy__date {
    font-size: 1.2rem
  }
  .p-helpPrivacy__date {
    margin-top: 20px
  }
  .p-helpPrivacy__release {
    padding: 20px;
    margin-bottom: 20px
  }
  .p-helpPrivacy__release>h2 {
    font-size: 1.6rem
  }
}

.p-helpTradelaw__heading {
  margin-bottom: 60px
}

.p-helpTradelaw__flex>* {
  padding: 0 20px
}

.p-helpTradelaw__flex>*:first-child {
  padding-left: 0
}

.p-helpTradelaw__flex>*:last-child {
  padding-right: 0
}

.p-helpTradelaw__title {
  flex-basis: 20%;
  max-width: 20%;
  text-align: right
}

.p-helpTradelaw__input {
  flex-basis: 80%;
  max-width: 80%
}

.p-helpTradelaw__input>span {
  font-size: 1.2rem
}

.p-helpTradelaw__link {
  color: #A82228;
  text-decoration: underline
}

.p-helpTradelaw__link:hover {
  color: #313131
}

.p-helpTradelaw__hr {
  padding-left: 20%
}

.p-helpTradelaw__hr>hr {
  margin: 20px 0 0
}

.p-helpTradelaw__contact>span {
  font-size: 1rem
}

.p-helpTradelaw__contact>i {
  font-size: 1.4rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold
}

@media (min-width: 960px) {
  .p-helpTradelaw {
    max-width: 980px;
    margin: auto
  }
  .p-helpTradelaw__container {
    max-width: 960px;
    margin: 20px 0 0
  }
  .p-helpTradelaw__flex {
    align-items: start
  }
  .p-helpTradelaw__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-helpTradelaw__heading {
    margin-bottom: 20px
  }
  .p-helpTradelaw__flex {
    margin-top: 0
  }
  .p-helpTradelaw__flex>* {
    padding: 0 0 10px
  }
  .p-helpTradelaw__title {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    text-align: left;
    font-weight: bold
  }
  .p-helpTradelaw__input {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto
  }
  .p-helpTradelaw__hr {
    padding-left: 0
  }
  .p-helpTradelaw__hr>hr {
    margin: 10px auto 20px
  }
}

.p-helpUseconditions__content>h2 {
  font-size: 1.6rem;
  margin: 40px 0
}

.p-helpUseconditions__content>h3 {
  font-size: 1.4rem;
  margin: 40px 0 10px
}

.p-helpUseconditions__content>p {
  font-size: 1.2rem;
  line-height: 1.5;
  margin: 10px 0
}

.p-helpUseconditions__content__date {
  text-align: right;
  margin-top: 40px !important
}

@media (min-width: 960px) {
  .p-helpUseconditions {
    max-width: 980px;
    margin: auto
  }
  .p-helpUseconditions__title {
    margin: 40px 0 30px
  }
}

@media (max-width: 959px) {
  .p-helpUseconditions__title {
    margin-bottom: 20px
  }
  .p-helpUseconditions__subtitle {
    margin: 30px 0 20px
  }
  .p-helpUseconditions__grey {
    padding: 10px;
    margin: 10px 0
  }
  .p-helpUseconditions__grey>button {
    top: 1px;
    right: 5px
  }
  .p-helpUseconditions__ps {
    margin: 20px 0
  }
  .p-helpUseconditions__content, .p-helpUseconditions__date {
    font-size: 1.2rem
  }
  .p-helpUseconditions__date {
    margin-top: 20px
  }
  .p-helpUseconditions__app {
    margin-top: 40px
  }
}

.p-indexHero {
  width: 100%;
  height: calc(100vw*0.45);
  background-image: url("../img/index/hero.jpg");
  background-size: cover;
  background-position: left center;
  position: relative
}

.p-indexHero__title {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  color: #fff;
  position: absolute;
  top: 40%;
  left: 53%;
  font-size: 4vw;
  line-height: 1.4
}

.p-indexHero__title>span {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  letter-spacing: 6px
}

.p-indexHero__bnr {
  position: absolute;
  bottom: 5%;
  left: 53%;
  width: 35vw;
  max-width: 640px
}

.p-indexAbout {
  width: 100%;
  height: 1005px;
  margin-bottom: 120px
}

.p-indexAbout__text {
  position: relative;
  z-index: 2
}

.p-indexAbout__text__title {
  color: #fff;
  width: 40%
}

.p-indexAbout__text__content {
  color: #fff;
  width: 40%;
}

.p-indexAbout__text>.left {
  position: absolute;
  top: 100px;
  left: 6%
}

.p-indexAbout__back {
  position: relative;
  height: 100%;
  background-color: #eee
}

.p-indexAbout__back>.left {
  width: 49%;
  height: 557px;
  background-color: #221815;
  position: absolute;
  left: -49%;
  z-index: 1
}

.p-indexAbout__back>.left>img {
  margin-top: 118px;
  margin-top: 60px;
}

.p-indexAbout__back>.right {
  z-index: 0;
  width: 94.5%;
  height: 100%;
  position: absolute;
  right: -94.5%;
  background-color: #eee
}

.p-indexAbout__backText {
  position: absolute;
  right: 0px;
  bottom: -10px
}



.p-indexAbout__productImg {
  position: absolute;
  top: 45px;
  right: calc(4% + (100% - 960px)/10);
  width: 525px;
  max-width: 45%
}


.p-indexAbout__productImg .more_btn{
  text-decoration: none;
  color: #000;
  /* font-family: eb-garamond, serif; */
  font-size: 13px;
  font-weight: 500;
}
.p-indexAbout__productImg .more_btn-Text{
  position: relative;
  z-index: 1;
  letter-spacing: .08em;
  font-weight: 500;
}

.p-indexAbout__productImg .more_btn-Text:before{
  font-family: 'Font Awesome 6 pro';
  content: "\f178";
/*   font-size: px; */
  padding-right: 10px;
}


.p-indexAbout__productImg .more_btn-Text:after{
  content: '';
  position: absolute;
  left: 0;
  bottom: -10px;/*テキストからの距離*/
  width: 0%;/*初期状態では下線非表示*/
  height: 1px;/*下線の高さ*/
  background: #888;/*下線の色*/
  z-index: -1;
  transition: all 0.4s;/*アニメーション速度*/
}
.p-indexAbout__productImg .more_btn:hover .more_btn-Text:after{
  width: 100%;/*hover時に表示*/
}


.p-indexAbout__links {
  position: absolute;
  left: 7.4%;
  bottom: 195px;
  display: flex;
  width: 800px;
  justify-content: space-between;
  align-items: center;
}

.p-indexAbout__links img {
  width: 195px
}

.p-indexAbout__links img:hover {
  border-radius: 5px;
  box-shadow: 0px 4px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 6px 0px rgba(0, 0, 0, 0.12)
}

.p-indexAbout__msg {
  font-size: 3rem;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  text-align: center;
  width: 80%;
  position: absolute;
  bottom: 480px
}

.p-indexAbout__spLinks {
  text-align: left;
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
  margin: 0 20px;
  position: relative;
  z-index: 3
}

.p-indexAbout__spLinks a {
  display: inline-block
}

.p-indexAbout__spLinks a img {
  width: 154px
}

.p-indexAbout__spLinks div {
  width: 154px;
}

.p-indexLinks {
  margin-bottom: 60px
}

.p-indexLinks>div {
  display: flex;
  width: 709px;
  margin: auto;
  justify-content: space-between
}

.p-indexLinks>div img {
  width: 195px;
  border-radius: 5px;
  box-shadow: 0px 4px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 6px 0px rgba(0, 0, 0, 0.12)
}

.p-indexLinks>div img:hover {
  opacity: .8
}

.p-indexValue__group {
  width: 100%;
  height: 1080px;
  position: relative;
  background-color: #eee;
  margin-bottom: 120px
}

.p-indexValue__text1 {
  position: absolute;
  top: 25%;
  right: 25%;
  z-index: 1;
  width: 38%;
  transform: translateX(50%) translateY(-50%)
}

.p-indexValue__text2 {
  position: absolute;
  bottom: 25%;
  left: 25%;
  z-index: 1;
  width: 38%;
  transform: translateX(-50%) translateY(50%)
}

.p-indexValue__images {
  width: 100%;
  height: 100%;
  position: relative
}

.p-indexValue__images>.left {
  width: 50%;
  height: 50%;
  position: absolute;
  top: 0;
  left: -50%;
  background-image: url("../img/index/value1.jpg");
  background-size: cover;
  background-position: 50%
}

.p-indexValue__images>.right {
  width: 50%;
  height: 50%;
  position: absolute;
  bottom: 0;
  right: -50%;
  background-image: url("../img/index/value2.jpg");
  background-size: cover;
  background-position: 50%
}

.p-indexValue__backText {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 2
}

.p-indexConcept {
  position: relative
}

.p-indexConcept__image {
  width: 100%;
  height: 550px;
  background-image: url("../img/index/concept.jpg");
  background-size: cover;
  background-position: 50%
}

.p-indexConcept__title {
  color: #fff;
  font-size: 4.2rem;
  position: absolute;
  top: 240px;
  left: 6%
}

.p-indexConcept__content {
  width: 50%;
  position: relative;
  top: -130px;
  left: -50%;
  background-color: #fff;
  padding: 60px 6% 0 5%
}

@media (max-width: 959px) {
  .p-index {
    background: #95252b;
    margin-top: 30px
  }
  .p-indexHero {
    background-image: url("../img/index/hero_sp.jpg");
    background-size: 100%;
    height: 140vw;
    max-height: 960px;
    background-position: bottom
  }
  .p-indexHero__title {
    width: 100%;
    text-align: center;
    font-size: calc(26px + (100vw - 320px) / 28);
    top: auto;
    left: auto;
    bottom: 5%
  }
  .p-indexHero__bnr {
    position: static;
    display: block;
    text-align: center;
    margin: 0 auto;
    width: 90%;
    padding-top: 20px
  }
  .p-indexAbout {
    height: auto;
    margin-bottom: 50px
  }
  .p-indexAbout__text__title {
    color: #fff;
    width: 85%
  }
  .p-indexAbout__text__content {
    color: #fff;
    width: 85%
  }
  .p-indexAbout__text>.left {
    left: 9%;
    top: calc(98px + (100vw - 320px)/9)
  }
  .p-indexAbout__back::after {
    content: '';
    display: block;
    clear: both;
    height: 0;
    visibility: hidden
  }
  .p-indexAbout__back>.left {
    width: 100%;
    position: static;
    /* height: calc(400px + (100vw - 320px)/2); */
  }
  .p-indexAbout__back>.left>img {
    margin-top: calc(48px + (100vw - 320px)/9)
  }
  .p-indexAbout__back>.right {
    width: 100%;
    height: 100%;
    position: static;
    float: right;
    text-align: center
  }
  .p-indexAbout__backText {
    width: 50%;
    right: 0;
    bottom: -3px;
  }
  .p-indexAbout__productImg {
    position: static;
    max-width: none;
    width: 90%;
    margin: 0 auto
  }
  .p-indexAbout__msg {
    width: 90%;
    text-align: center;
    margin: 10px auto 20px;
    font-size: 1.8rem;
    position: static
  }
  .p-indexAbout__msg>span {
    font-size: 150%
  }
  .p-indexAbout__merit {
    width: 90%;
    flex-direction: column;
    margin: auto;
    padding-bottom: 80px;
    position: static;
    left: 0;
    bottom: 0
  }
  .p-indexAbout__merit>div {
    flex-basis: 42%;
    margin: 0 10px 16px
  }
  .p-indexAbout__meritPopup__text {
    text-align: left
  }
  .p-indexAbout__meritImg {
    max-width: 100px;
    margin-bottom: 20px
  }
  .p-indexAbout__meritText {
    font-size: 1.7rem;
    padding: 10px
  }
  .p-indexLinks>div {
    width: 90%;
    flex-wrap: wrap
  }
  .p-indexLinks>div>a {
    flex-basis: 46%
  }
  .p-indexLinks>div img {
    width: 100%;
    margin: 5px
  }
  .p-indexValue {
    margin-bottom: 75px
  }
  .p-indexValue__group {
    height: auto
  }
  .p-indexValue__images {
    height: 130vw
  }
  .p-indexValue__images>.left {
    width: 91.5%;
    left: -90%
  }
  .p-indexValue__images>.right {
    width: 91.5%;
    right: -90%
  }
  .p-indexValue__text1 {
    position: static;
    width: auto;
    padding: 45px 10%;
    transform: none
  }
  .p-indexValue__text2 {
    position: static;
    width: 100%;
    padding: 45px 10%;
    transform: none
  }
  .p-indexValue__backText {
    width: 88%
  }
  .p-indexConcept__image {
    height: 70vw;
    background-position: top;
    background-image: url("../img/index/concept_sp.jpg")
  }
  .p-indexConcept__content {
    top: -12vw;
    width: 93.4%;
    padding: 45px 10%
  }
}

@media (min-width: 1441px) {
  .p-indexHero__title {
    font-size: 5rem
  }
  .p-indexAbout__productImg {
    right: calc(25.5% - 262px)
  }
  .p-indexAbout__msg {
    bottom: 450px
  }
}

@media (min-width: 960px) {
  .p-indexAbout__msg {
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-indexConcept__content>.c-content {
    margin-top: 0
  }
}

@media (min-width: 550px) {
  .p-indexAbout__spDiv {
    display: none
  }
}

.p-MediaDetail__contents {
  flex: 1
}

.p-MediaDetail__contents__lead {
  margin: 0 0 8px
}

.p-MediaDetail__contents__date {
  width: 100%;
  padding-bottom: 8px;
  font-size: 1.2rem;
  color: #707070;
  border-bottom: 1px solid #ccc
}

.p-MediaDetail__contents__body {
  margin-bottom: 50px
}

.p-MediaDetail__contents__body>p {
  font-size: 1.5rem;
  line-height: 1.5
}

.p-MediaDetail__contents__body>p>a {
  color: #A82228;
  text-decoration: underline
}

.p-MediaDetail__contents__body>img {
  width: 100%;
  max-width: 500px;
  margin-bottom: 30px
}

.p-MediaDetail__contents__body>img.mx250 {
  max-width: 250px
}

.p-MediaDetail__contents__info {
  color: #221815;
  text-align: center;
  border: 1px solid #221815;
  background: #fff;
  padding: 5px;
  margin: 0 auto 50px;
  width: 200px
}

.p-MediaDetail__contents__recommend {
  padding: 0 30px 40px;
  margin-bottom: 50px;
  background: #eee
}

.p-MediaDetail__contents__recommendTitle {
  text-align: center;
  padding-bottom: 65px
}

.p-MediaDetail__contents__recommendSubtitle {
  color: #221815;
  font-size: 1.8rem
}

.p-MediaDetail__contents__recommendImg {
  text-align: center;
  flex-basis: 40%;
  padding-right: 40px
}

.p-MediaDetail__contents__recommendItem {
  flex-basis: 60%
}

.p-MediaDetail__contents__recommendItem__title {
  font-size: 2rem
}

.p-MediaDetail__contents__recommendItem__text {
  margin: 30px 0
}

.p-MediaDetail__contents__recommendBtn {
  width: 300px;
  margin: 30px auto 40px;
  display: block
}

.p-MediaDetail__contents__recommendSVG {
  position: relative;
  z-index: 1;
  transform: translateY(-50%)
}

.p-MediaDetail__contents__recommendSVGSP {
  height: 78px;
  position: relative;
  z-index: 1;
  transform: translateY(-24%);
  max-width: 100%
}

.p-MediaDetail__contents__back {
  margin: auto;
  display: block
}

@media (min-width: 960px) {
  .p-MediaDetail {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-MediaDetail__contents__lead {
    padding: 8px 20px
  }
  .p-MediaDetail__contents__date {
    padding: 0 20px 8px
  }
  .p-MediaDetail__contents__body {
    width: calc(90vw - 22.5px);
    margin: 0 auto 40px
  }
  .p-MediaDetail__contents__info {
    margin: 0 auto 40px;
    width: 140px;
    font-size: 1.2rem
  }
  .p-MediaDetail__contents__recommendImg {
    flex: 1 1 auto;
    padding: 0 0 20px
  }
  .p-MediaDetail__contents__recommendImg>img {
    width: 100%;
    max-width: 320px
  }
  .p-MediaDetail__contents__recommendItem {
    flex: 1 1 auto
  }
  .p-MediaDetail__contents__recommendItem__title {
    font-size: 1.4rem
  }
  .p-MediaDetail__contents__recommendBtn {
    width: 95%;
    font-size: 1.3rem
  }
  .p-MediaDetail__contents__back {
    width: calc(90vw - 22.5px);
    margin: auto
  }
}

@media (max-width: 600px) {
.p-indexAbout__back>.left {
    width: 100%;
    height:75vh
  }
}
.p-Media__msg {
  font-size: 1.4rem;
  color: #707070
}

.p-Media__items {
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between
}

.p-Media__items:after {
  content: "";
  display: block;
  width: 240px;
  height: 0
}

.p-Media__items__item {
  width: 240px;
  margin: 0 20px 20px
}

.p-Media__items__item>a>img {
  width: 100%
}

.p-Media__items__item>a>img:hover {
  opacity: .9
}

.p-Media__items__item__name {
  font-size: 1.4rem;
  margin-bottom: 0
}

.p-Media__items__item__name>a {
  color: #000
}

.p-Media__items__item__name>a:hover {
  text-decoration: underline
}

.p-Media__items__item__date {
  font-size: 1.2rem;
  color: #707070
}

.p-Media__items__item.is-empty {
  height: 0;
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
  margin-bottom: 0 !important
}

@media (min-width: 960px) {
  .p-Media {
    max-width: 980px;
    margin: auto
  }
  .p-Media__title {
    margin: 0 0 30px
  }
  .p-Media>.c-pagination {
    max-width: 960px
  }
}

@media (max-width: 959px) {
  .p-Media__title {
    margin-bottom: 20px
  }
  .p-Media__items__item {
    flex-basis: 45%;
    margin: 0 0 20px
  }
}

.p-mente {
  text-align: center;
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center
}

.p-mente>div {
  width: 100%;
  text-align: center
}

.p-mente__icon {
  width: 120px
}

.p-mente__title {
  font-size: 2.2rem;
  margin: 35px 0
}

.p-mente__time {
  border: 1px solid #d8d8d8;
  padding: 20px 10px;
  font-size: 1.4rem;
  line-height: 2.2;
  margin: 0 auto
}

.p-mente__footer {
  width: 100%;
  position: fixed;
  bottom: 30px;
  text-align: center;
  font-size: 1.4rem
}

@media (min-width: 960px) {
  .p-mente__time {
    width: 400px
  }
}

@media (max-width: 959px) {
  .p-mente {
    align-items: start
  }
  .p-mente__icon {
    margin-top: 30px
  }
  .p-mente__title {
    font-size: 1.8rem;
    margin: 60px 0 25px
  }
  .p-mente__time {
    width: 90%;
    max-width: 400px
  }
  .p-mente__footer {
    bottom: 20px;
    font-size: 1.2rem
  }
}

.p-mpChangeComp__subtitle {
  margin: 25px 0 18px
}

.p-mpChangeComp__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 60px;
  display: inline-block
}

.p-mpChangeComp__link:hover {
  color: #313131
}

.p-mpChangeComp__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-mpChangeComp>p {
  margin-bottom: 60px
}

@media (max-width: 959px) {
  .p-mpChangeComp__subtitle {
    margin: 20px 0
  }
  .p-mpChangeComp__linkSP {
    margin-top: 45px
  }
}

.p-mpChange__heading {
  margin-bottom: 20px
}

.p-mpChange__flex>* {
  padding: 30px 20px 0
}

.p-mpChange__flex>*:first-child {
  padding-left: 0
}

.p-mpChange__flex>*:last-child {
  padding-right: 0
}

.p-mpChange__title {
  width: 20%;
  max-width: 200px;
  font-size: 1.4rem;
  text-align: right;
  position: relative
}

.p-mpChange__input {
  flex: 1 1 auto
}

.p-mpChange__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-mpChange__zipSelect .p-mpChange__input__err {
  padding-left: 30px
}

.p-mpChange__hr {
  padding-left: 20%
}

.p-mpChange__hr>hr {
  margin-top: 30px
}

.p-mpChange__zipInput {
  display: flex
}

.p-mpChange__zipBtn {
  flex-basis: 40%;
  max-width: 40%;
  line-height: 48px;
  font-size: 1.2rem;
  padding-left: 20px
}

.p-mpChange__zipBtn>.c-myBtn-r1 {
  width: 100%
}

.p-mpChange__zipIcon {
  font-size: 1.6rem;
  margin-right: 10px;
  display: inline-block
}

.p-mpChange__zipCode {
  width: 90%
}

.p-mpChange__zipSelect {
  flex-basis: 60%;
  max-width: 60%;
  padding-right: 20px
}

.p-mpChange__save {
  margin-top: 30px
}

.p-mpChange__radio {
  display: inline-block;
  margin-right: 100px;
  margin-top: 0
}

.p-mpChange__birth {
  flex-wrap: wrap;
  align-items: center
}

.p-mpChange__birth>label, .p-mpChange__birth>div {
  flex: 1 1 auto
}

.p-mpChange__birth>span {
  display: flex;
  align-items: flex-end;
  margin: 0 20px
}

@media (min-width: 960px) {
  .p-mpChange__flex {
    align-items: baseline
  }
}

@media (max-width: 959px) {
  .p-mpChange__heading {
    margin-bottom: 20px
  }
  .p-mpChange__flex {
    margin-top: 0px
  }
  .p-mpChange__flex>* {
    padding: 0 0 10px
  }
  .p-mpChange__flex.no-title {
    margin-top: 0
  }
  .p-mpChange__title {
    text-align: left;
    width: 100%;
    position: static;
    font-weight: bold
  }
  .p-mpChange__title.no-top {
    padding: 0
  }
  .p-mpChange__zipSelect {
    padding-right: 10px
  }
  .p-mpChange__zipCode {
    width: 80%
  }
  .p-mpChange__zipBtn {
    padding-left: 10px
  }
  .p-mpChange__save {
    margin-top: 25px
  }
  .p-mpChange__radio {
    margin-right: 20px;
    margin-top: 0
  }
  .p-mpChange__birth>label:first-child {
    flex: 1.5
  }
  .p-mpChange__birth>span {
    margin: 0 8px
  }
}

.p-mpCoupon__title {
  margin-bottom: 25px
}

.p-mpCoupon__subtitle {
  margin-bottom: 18px
}

.p-mpCoupon__subscription {
  margin-top: 60px;
  margin-bottom: 18px
}

.p-mpCoupon__caption {
  margin: 0 auto 30px
}

.p-mpCoupon__wrapper {
  width: 100%;
  max-width: 864px;
  display: flex;
  align-items: center;
  border-bottom: 2px dotted #d8d8d8;
  margin-bottom: 30px;
  padding: 0px 0 25px 0
}

.p-mpCoupon__wrapper__item {
  flex: 1 1 auto;
  position: relative
}

.p-mpCoupon__wrapper__item__name {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 0
}

.p-mpCoupon__wrapper__item__name>span {
  font-size: 1.4rem;
  font-weight: normal;
  padding-left: 10px
}

.p-mpCoupon__wrapper__item__discount {
  font-size: 3rem;
  font-weight: bold;
  line-height: 1.25;
  color: #221815;
  margin-bottom: 0
}

.p-mpCoupon__wrapper__item__discount>span {
  font-size: 1.8rem;
  padding-left: 5px
}

.p-mpCoupon__wrapper__item__code {
  font-size: 1.2rem;
  margin-bottom: 0
}

.p-mpCoupon__wrapper__item__date {
  font-size: 1.2rem;
  margin-bottom: 0
}

.p-mpCoupon__wrapper__item__btn>a {
  width: 180px;
  height: 50px;
  line-height: 48px
}

.p-mpCoupon__wrapper__item__expire {
  min-width: 80px;
  padding: 2px 8px;
  font-size: 1.2rem;
  color: #FFF;
  background: #A82228;
  text-align: center;
  border-radius: 3px;
  display: inline-block;
  margin: 0 3px 5px
}

.p-mpCoupon__wrapper__item__icon {
  min-width: 80px;
  padding: 2px 8px;
  font-size: 1.2rem;
  color: #A82228;
  background: #fff;
  text-align: center;
  border: 1px solid #A82228;
  border-radius: 3px;
  display: inline-block;
  margin: 0 3px 5px
}

.p-mpCoupon__msg {
  padding: 10px;
  margin-bottom: 20px;
  background: #fff;
  border: 4px solid rgba(168, 34, 40, 0.2);
  box-sizing: border-box
}

.p-mpCoupon__msg>i {
  font-size: 1.6rem;
  vertical-align: middle
}

.p-mpCoupon__nodata {
  padding-top: 16px
}

@media (max-width: 959px) {
  .p-mpCoupon__title {
    margin-bottom: 20px
  }
  .p-mpCoupon__subscription {
    margin-top: 20px
  }
  .p-mpCoupon__caption {
    margin: 20px auto 20px
  }
  .p-mpCoupon__wrapper {
    flex-direction: column;
    padding: 0 0 20px;
    margin-bottom: 20px
  }
  .p-mpCoupon__wrapper__item {
    width: 100%
  }
  .p-mpCoupon__wrapper__item__name {
    font-size: 1.6rem
  }
  .p-mpCoupon__wrapper__item__name>span {
    width: 100%;
    padding-left: 0;
    display: block
  }
  .p-mpCoupon__wrapper__item__code, .p-mpCoupon__wrapper__item__date {
    font-size: 1.2rem
  }
  .p-mpCoupon__wrapper__item__btn {
    position: static;
    margin: 14px 0 0;
    width: 100%;
    text-align: center
  }
  .p-mpCoupon__wrapper__item__btn>a {
    width: 140px;
    height: 36px;
    line-height: 34px
  }
  .p-mpCoupon__nodata {
    padding-top: 0;
    padding-bottom: 10px
  }
}

.p-mpDeliveryNew__heading {
  margin-bottom: 20px
}

.p-mpDeliveryNew__flex>* {
  padding: 30px 20px 0
}

.p-mpDeliveryNew__flex>*:first-child {
  padding-left: 0
}

.p-mpDeliveryNew__flex>*:last-child {
  padding-right: 0
}

.p-mpDeliveryNew__title {
  width: 20%;
  max-width: 200px;
  font-size: 1.4rem;
  text-align: right;
  position: relative
}

.p-mpDeliveryNew__input {
  flex: 1 1 auto
}

.p-mpDeliveryNew__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-mpChange__zipSelect .p-mpDeliveryNew__input__err {
  padding-left: 30px
}

.p-mpDeliveryNew__hr {
  padding-left: 20%
}

.p-mpDeliveryNew__hr>hr {
  margin-top: 30px
}

.p-mpDeliveryNew__zipInput {
  display: flex
}

.p-mpDeliveryNew__zipBtn {
  flex-basis: 40%;
  max-width: 40%;
  line-height: 48px;
  font-size: 1.2rem;
  padding-left: 20px
}

.p-mpDeliveryNew__zipBtn>.c-myBtn-r1 {
  width: 100%
}

.p-mpDeliveryNew__zipIcon {
  font-size: 1.6rem;
  margin-right: 10px;
  display: inline-block
}

.p-mpDeliveryNew__zipCode {
  width: 90%
}

.p-mpDeliveryNew__zipSelect {
  flex-basis: 60%;
  max-width: 60%;
  padding-right: 20px
}

.p-mpDeliveryNew__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-mpDeliveryNew__flex {
    align-items: baseline
  }
}

@media (max-width: 959px) {
  .p-mpDeliveryNew__heading {
    margin-bottom: 20px
  }
  .p-mpDeliveryNew__flex {
    margin-top: 10px
  }
  .p-mpDeliveryNew__flex>* {
    padding: 0 0 10px
  }
  .p-mpDeliveryNew__flex.no-title {
    margin-top: 0
  }
  .p-mpDeliveryNew__title {
    text-align: left;
    font-weight: bold;
    width: 100%;
    position: static
  }
  .p-mpDeliveryNew__title.no-top {
    padding: 0
  }
  .p-mpDeliveryNew__zipSelect {
    flex: 1.5;
    padding-right: 10px
  }
  .p-mpDeliveryNew__zipCode {
    width: 80%
  }
  .p-mpDeliveryNew__zipBtn {
    padding-left: 10px
  }
  .p-mpDeliveryNew__save {
    margin-top: 25px
  }
}

.p-mpDelivery__subtitle {
  margin: 20px 0 27px
}

.p-mpDelivery__addBtn {
  height: 50px;
  line-height: 48px
}

.p-mpDelivery__item {
  width: 100%;
  max-width: 864px;
  margin-top: 40px;
  padding-bottom: 25px;
  border-bottom: 1px dotted #d8d8d8
}

.p-mpDelivery__item__remove {
  background-image: url("../img/mypage/close.png");
  background-size: cover;
  width: 16px;
  height: 16px;
  cursor: pointer;
  position: absolute;
  top: 30px;
  left: 20px
}

.p-mpDelivery__item__remove:hover {
  transform: rotate(90deg);
  transition: all .1s
}

.p-mpDelivery__item__subscription {
  min-width: 80px;
  padding: 2px 8px;
  font-size: 1.2rem;
  color: #FFF;
  background: #A82228;
  text-align: center;
  border-radius: 3px;
  display: inline-block;
  margin: 0 3px 5px 0
}

.p-mpDelivery__item__content {
  position: relative;
  flex: 1;
  padding: 0 20px 0 60px
}

.p-mpDelivery__item__btn {
  width: 160px
}

@media (max-width: 959px) {
  .p-mpDelivery__subtitle {
    margin: 20px 0 21px
  }
  .p-mpDelivery__addBtn {
    width: 200px;
    height: 36px;
    line-height: 34px;
    font-size: 1.4rem
  }
  .p-mpDelivery__item {
    width: 100%;
    margin-top: 30px;
    padding-bottom: 20px
  }
  .p-mpDelivery__item__remove {
    left: 0
  }
  .p-mpDelivery__item__content {
    padding: 0 20px 0 36px
  }
  .p-mpDelivery__item__btn {
    width: 63px;
    height: 36px;
    line-height: 34px
  }
}

.p-mpHistory__title {
  margin-bottom: 20px
}

.p-mpHistory__info {
  width: 100%;
  flex: 1 1 auto;
  padding-right: 40px
}

.p-mpHistory__item {
  width: 100%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  justify-content: space-between
}

.p-mpHistory__item:not(:last-child) {
  border-bottom: 1px solid #d8d8d8
}

.p-mpHistory__itemImage {
  margin-right: 30px
}

.p-mpHistory__itemImage>img {
  width: 92px
}

.p-mpHistory__itemDetail {
  flex: 1 1 auto
}

.p-mpHistory__item>p {
  margin-bottom: 0.5rem
}

.p-mpHistory__itemName {
  flex-basis: 70%
}

.p-mpHistory__itemName>p {
  margin-bottom: 5px
}

.p-mpHistory__itemName_set {
  font-size: 1.2rem;
  font-weight: normal;
  padding-left: 20px
}

.p-mpHistory__itemPrice {
  margin-left: 20px;
  flex-basis: 30%;
  font-weight: bold
}

.p-mpHistory__itemPrice>p {
  margin-bottom: 0
}

.p-mpHistory__itemPrice>p>span {
  font-weight: normal
}

.p-mpHistory__divider {
  margin-top: 30px;
  margin-bottom: 30px
}

.p-mpHistory__subtitle {
  margin: 20px 0 10px
}

.p-mpHistory__content {
  margin-top: 10px
}

.p-mpHistory__content__coupon {
  padding: 18px 0 25px 0;
  border-bottom: 2px dotted #d8d8d8
}

.p-mpHistory__content__couponName {
  font-size: 1.6rem;
  font-weight: bold
}

.p-mpHistory__content__couponDiscount {
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.25;
  color: #221815;
  margin-bottom: 0
}

.p-mpHistory__content__couponDiscount>span {
  font-size: 1.8rem;
  padding-left: 5px
}

.p-mpHistory__content__couponCode, .p-mpHistory__content__couponDate {
  font-size: 1.2rem
}

.p-mpHistory__contactItem {
  color: #313131;
  padding: 16px 0;
  border-bottom: 1px dotted #d8d8d8;
  position: relative;
  align-items: center
}

.p-mpHistory__contactItem>div {
  flex: 1 1 auto
}

.p-mpHistory__contactItem>i {
  margin-right: 5px
}

.p-mpHistory__bill {
  width: 100%;
  border: 1px solid #919191;
  border-radius: 4px;
  padding: 2.5%
}

.p-mpHistory__billFlex {
  display: flex;
  margin-bottom: 15px;
  align-items: center
}

.p-mpHistory__billTitle {
  flex: 1 1 auto
}

.p-mpHistory__billCoupon {
  width: 100%;
  padding: 10px 20px;
  font-size: 1.4rem;
  background-color: #f8f8f8;
  margin-bottom: 15px
}

.p-mpHistory__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin-bottom: 8px
}

.p-mpHistory__billPrice {
  font-weight: bold;
  font-size: 1.8rem
}

.p-mpHistory__billTax {
  font-weight: bold;
  font-size: 1.2rem
}

.p-mpHistory__billOrder {
  width: 100%;
  margin: 50px auto 40px
}

.p-mpHistory__billBack {
  width: 100%
}

@media (min-width: 960px) {
  .p-mpHistory__pcBottom {
    margin-bottom: 70px
  }
  .p-mpHistory__contactItem:hover {
    background-color: #f8f8f8
  }
  .p-mpHistory__bill {
    width: 40%;
    max-width: 400px;
    min-width: 240px;
    display: sticky;
    top: 10px;
    padding-top: 30px;
    padding-bottom: 40px
  }
}

@media (max-width: 959px) {
  .p-mpHistory__info {
    padding-right: 0
  }
  .p-mpHistory__item {
    justify-content: normal
  }
  .p-mpHistory__itemImage {
    width: auto;
    margin-right: 20px
  }
  .p-mpHistory__itemImage>img {
    width: 50px
  }
  .p-mpHistory__itemPrice {
    flex: 1 1 auto;
    margin-left: 0
  }
  .p-mpHistory__itemName {
    flex: 1 1 auto
  }
  .p-mpHistory__contactItem>i {
    margin-right: 0
  }
  .p-mpHistory__bill {
    padding: 0;
    border: none
  }
}

.p-mpIndex__title {
  margin-bottom: 15px
}

.p-mpIndex__table {
  display: table;
  width: 100%;
  margin-top: 20px
}

.p-mpIndex__table-head {
  display: table-header-group;
  vertical-align: middle
}

.p-mpIndex__table-head>div {
  display: table-cell;
  width: 20%;
  height: 45px;
  vertical-align: middle;
  font-weight: bold;
  border-bottom: 1px solid #d8d8d8
}

.p-mpIndex__table-data {
  display: table-row
}

.p-mpIndex__table-data>div {
  display: table-cell;
  height: 90px;
  vertical-align: middle;
  border-bottom: 1px solid #d8d8d8;
  padding-right: 20px
}

.p-mpIndex__table-data>div>span {
  font-weight: bold
}

.p-mpIndex__table-data>div>a>div {
  width: 124px;
  height: 42px;
  line-height: 40px
}

.p-mpIndex__pagination {
  margin-top: 40px
}

@media (max-width: 959px) {
  .p-mpIndex__title {
    margin-bottom: 20px
  }
  .p-mpIndex__table {
    margin-top: 0;
    display: block
  }
  .p-mpIndex__table-data {
    padding: 20px 0 20px;
    display: block;
    border-bottom: 1px solid #d8d8d8
  }
  .p-mpIndex__table-data>div {
    display: block;
    border-bottom: none;
    height: auto
  }
  .p-mpIndex__table-data>div>a>div {
    width: 140px;
    height: 36px;
    line-height: 34px;
    margin-top: 15px
  }
  .p-mpIndex__pagination {
    margin-top: 50px
  }
}

.p-mpLogin {
  margin: 0 auto
}

.p-mpLogin__titleAuto {
  display: none
}

.p-mpLogin__row {
  margin-top: 10px;
  flex-direction: column
}

.p-forgetReset__msg .p-mpLogin__row {
  margin-top: 0
}

.p-mpLogin__input {
  flex-basis: 1 1 auto
}

.p-mpLogin__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block;
  text-align: left
}

.p-mpLogin__btn {
  max-width: 300px;
  margin: auto;
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-mpLogin__btn>i {
  font-size: 1.8rem
}

.p-mpLogin__sec {
  margin-top: 20px
}

.p-mpLogin__block {
  border: 1px solid #ddd;
  padding: 4%;
  margin: 0 auto 5rem;
  text-align: center
}

.p-mpLogin__msg {
  font-size: 1.3rem;
  line-height: 1.5;
  margin-bottom: 2rem
}

.p-mpLogin__link {
  text-align: center
}

.p-mpLogin__agree {
  text-align: center;
  margin-bottom: 20px;
  display: block
}

.p-mpLogin__agree input[type=checkbox] {
  display: none
}

.p-mpLogin__agreeText {
  font-size: 1.3rem;
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  padding-left: 30px;
  position: relative;
  width: auto
}

.p-mpLogin__agreeText::before {
  background: #f7f7f7;
  border: 1px solid #707070;
  border-radius: 3px;
  content: '';
  display: block;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%)
}

.p-mpLogin__agreeText::after {
  border-right: 3px solid #323E48;
  border-bottom: 3px solid #323E48;
  content: '';
  display: block;
  width: 8px;
  height: 18px;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  opacity: 0;
  position: absolute;
  transform: rotate(45deg) translate3d(0, 2px, 0) scale3d(0.7, 0.7, 1);
  transition: transform .2s ease-in-out, opacity .2s ease-in-out;
  margin-top: -12px
}

.p-mpLogin__popout .l-myPopout__container {
  overflow-y: scroll
}

input[type=checkbox]:checked+.p-mpLogin__agreeText::after {
  opacity: 1;
  transform: rotate(45deg) scale3d(1, 1, 1)
}

@media (min-width: 960px) {
  .p-mpLogin {
    max-width: 740px;
    margin: auto
  }
  .p-mpLogin>form {
    width: 70%;
    margin: auto
  }
  .p-mpLogin__row {
    width: 75%;
    margin: auto
  }
  .p-mpLogin__title {
    flex-basis: 100%;
    text-align: left;
    padding: 19px 40px 0 0
  }
  .p-mpLogin__input {
    flex-basis: 100%
  }
  .p-mpLogin__btn {
    width: 100%;
    margin: 0px auto 10px
  }
  .p-mpLogin__msg {
    text-align: center
  }
  .p-mpLogin__popout {
    height: 90vh
  }
}

@media (max-width: 959px) {
  .p-mpLogin {
    width: calc(90vw - 22.5px);
    margin: 0 auto
  }
  .p-mpLogin__title {
    width: 100%;
    text-align: left;
    margin: 0 auto 10px;
    font-weight: bold
  }
  .p-mpLogin__row {
    margin-bottom: 20px
  }
  .p-mpLogin__btn {
    margin: 0px auto 10px
  }
  .p-mpLogin__msg {
    text-align: left
  }
  .p-mpLogin__popout {
    height: 95vh
  }
}

.p-mpSubscription>.c-flex-r {
  margin-top: 40px
}

.p-mpSubscription__title {
  margin-bottom: 25px
}

.p-mpSubscription__msg {
  padding: 10px;
  margin-bottom: 25px;
  background: #fff;
  border: 4px solid rgba(168, 34, 40, 0.2);
  box-sizing: border-box
}

.p-mpSubscription__msg>i {
  font-size: 1.6rem;
  vertical-align: middle
}

.p-mpSubscription__faq {
  width: 40%;
  max-width: 400px;
  min-width: 240px;
  border: 1px solid #919191;
  border-radius: 4px;
  padding: 30px 2.5% 40px
}

.p-mpSubscription__faq__question {
  font-size: 1.4rem;
  margin: 20px auto 10px;
  padding-left: 50px;
  position: relative;
  min-height: 40px
}

.p-mpSubscription__faq__question:before {
  font-size: 2.2rem;
  font-family: Didot, "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  line-height: 36px;
  color: #fff;
  background: #A82228;
  width: 40px;
  height: 40px;
  text-align: center;
  content: 'Q';
  position: absolute;
  left: 0
}

.p-mpSubscription__faq__answer {
  margin: 10px auto 30px;
  padding-left: 50px;
  position: relative;
  min-height: 40px
}

.p-mpSubscription__faq__answer:before {
  font-size: 2.2rem;
  font-family: Didot, "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  line-height: 40px;
  color: #fff;
  background: #919191;
  width: 40px;
  height: 40px;
  text-align: center;
  content: 'A';
  position: absolute;
  left: 0
}

.p-mpSubscription__faq__btn {
  display: inline-block;
  margin: 0 auto;
  color: #A82228;
  text-decoration: underline;
  position: relative;
  padding-right: 20px
}

.p-mpSubscription__faq__btn:before {
  position: absolute;
  top: 50%;
  right: 10px;
  display: inline-block;
  content: "";
  width: 7px;
  height: 1px;
  background: #A82228;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: transform .3s, -webkit-transform .3s
}

.p-mpSubscription__faq__btn:after {
  position: absolute;
  top: 50%;
  right: 5px;
  display: inline-block;
  content: "";
  width: 7px;
  height: 1px;
  background: #A82228;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  transition: transform .3s, -webkit-transform .3s
}

.p-mpSubscription__faq__btn.js-isActive:before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}

.p-mpSubscription__faq__btn.js-isActive:after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}

.p-mpSubscription__faq__btn:hover {
  color: #313131
}

.p-mpSubscription__info {
  flex: 1 1 auto;
  padding-right: 40px
}

.p-mpSubscription__info__title {
  margin-top: 28px
}

.p-mpSubscription__info__content {
  margin-top: 18px
}

.p-mpSubscription__info__coupon {
  padding: 18px 0 25px 0;
  border-bottom: 2px dotted #d8d8d8
}

.p-mpSubscription__info__couponName {
  font-size: 1.6rem;
  font-weight: bold
}

.p-mpSubscription__info__couponDiscount {
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.25;
  color: #221815;
  margin-bottom: 0
}

.p-mpSubscription__info__couponDiscount>span {
  font-size: 1.8rem;
  padding-left: 5px
}

.p-mpSubscription__info__couponCode, .p-mpSubscription__info__couponDate {
  font-size: 1.2rem
}

.p-mpSubscription__info__coupons {
  margin-top: 15px
}

.p-mpSubscription__info__coupons>a {
  color: #A82228;
  text-decoration: underline
}

.p-mpSubscription__info__coupons>a:hover {
  color: #313131
}

.p-mpSubscription__info__coupons>a>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-mpSubscription__info__bill {
  border: 1px solid #d8d8d8;
  padding: 30px;
  margin-top: 25px;
  font-size: 1.4rem
}

.p-mpSubscription__info__billFlex {
  display: flex;
  margin-bottom: 9px
}

.p-mpSubscription__info__billTitle {
  flex: 1 1 auto;
  font-weight: bold
}

.p-mpSubscription__info__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin-bottom: 8px
}

.p-mpSubscription__info__billPrice {
  font-weight: bold;
  font-size: 1.8rem
}

.p-mpSubscription__info__billTax {
  font-weight: bold;
  font-size: 1.2rem
}

.p-mpSubscription__info__billCaption {
  margin-top: 20px;
  padding: 10px 20px;
  background-color: #f4f4f4
}

.p-mpSubscription__info__flex {
  display: flex;
  margin-top: 18px
}

.p-mpSubscription__info__inline {
  flex: 1 1 auto
}

.p-mpSubscription__info__btn {
  display: inline-block
}

.p-mpSubscription__info__btn>button {
  width: 120px;
  height: 42px;
  line-height: 40px
}

.p-mpSubscription__nextSelect {
  width: 320px
}

.p-mpSubscription__nextBtn {
  width: 320px;
  margin-top: 40px
}

.p-mpSubscription__addressAdd>button {
  width: 291px;
  height: 50px;
  line-height: 48px
}

.p-mpSubscription__addressFlex {
  display: flex;
  padding: 30px 0;
  border-bottom: 1px dotted #d8d8d8
}

.p-mpSubscription__addressText {
  flex: 1 1 auto;
  padding-right: 15px
}

.p-mpSubscription__addressBtn {
  width: 120px;
  height: 50px;
  line-height: 48px
}

.p-mpSubscription__payment {
  max-height: 90vh;
  overflow: overlay
}

.p-mpSubscription__paymentName {
  flex-basis: 50%;
  padding-right: 20px
}

.p-mpSubscription__paymentDate {
  flex: 1 1 auto
}

.p-mpSubscription__paymentDate>label {
  width: 70%;
  margin-right: 5px
}

.p-mpSubscription__paymentDate__break {
  padding-right: 20px
}

.p-mpSubscription__paymentCVC {
  width: 140px;
  display: block
}

.p-mpSubscription__paymentCVC__link {
  color: #A82228;
  text-decoration: underline;
  font-size: 1.2rem;
  margin-top: 12px;
  display: inline-block
}

.p-mpSubscription__paymentCVC__items {
  width: 100%;
  display: flex;
  align-items: flex-end;
  margin: 30px 0 0
}

.p-mpSubscription__paymentCVC__items__item {
  flex: 1 1 auto;
  padding: 0 20px
}

.p-mpSubscription__paymentCVC__items__item>p {
  font-size: 1rem;
  margin-bottom: 5px
}

.p-mpSubscription__paymentCVC__items__item>img {
  width: 100%;
  max-width: 160px
}

.p-mpSubscription__paymentCVC__msg {
  font-size: 1rem;
  padding-left: 20px;
  margin-bottom: 20px
}

.p-mpSubscription__payment__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

@media (max-width: 959px) {
  .p-mpSubscription__title {
    margin-bottom: 20px
  }
  .p-mpSubscription__faq {
    width: 100%;
    border: none;
    padding: 0;
    display: none
  }
  .p-mpSubscription__faq.js-isActive {
    display: block
  }
  .p-mpSubscription__faq__question {
    margin-top: 15px
  }
  .p-mpSubscription__faq__answer {
    margin-top: 10px
  }
  .p-mpSubscription__info {
    padding-right: 0
  }
  .p-mpSubscription__info__title {
    margin-top: 18px
  }
  .p-mpSubscription__info__content {
    margin-top: 8px
  }
  .p-mpSubscription__info__coupon {
    padding: 10px 0 15px
  }
  .p-mpSubscription__info__couponName {
    font-size: 1.6rem
  }
  .p-mpSubscription__info__couponCode, .p-mpSubscription__info__couponDate {
    font-size: 1.2rem
  }
  .p-mpSubscription__info__bill {
    margin-top: 0;
    padding: 0;
    border: none
  }
  .p-mpSubscription__info__billCaption {
    margin-top: 10px;
    padding: 10px;
    font-size: 1.4rem
  }
  .p-mpSubscription__info__flex {
    margin-top: 20px
  }
  .p-mpSubscription__info__btn>button {
    width: 63px;
    height: 36px;
    line-height: 34px
  }
  .p-mpSubscription__nextSelect {
    width: 160px
  }
  .p-mpSubscription__nextBtn {
    width: 270px;
    margin-top: 30px
  }
  .p-mpSubscription__addressAdd>button {
    width: 216px;
    height: 36px;
    line-height: 34px
  }
  .p-mpSubscription__addressBtn {
    width: 53px;
    height: 36px;
    line-height: 34px
  }
  .p-mpSubscription__payment {
    height: 95vh
  }
  .p-mpSubscription__payment .l-myPopout__inputTitle {
    margin-top: 5px
  }
  .p-mpSubscription__paymentName {
    width: 100%;
    margin-bottom: 15px
  }
  .p-mpSubscription__paymentDate {
    width: 81px
  }
  .p-mpSubscription__paymentCVC__items {
    margin-top: 20px
  }
}

.p-News__list {
  list-style: none;
  margin-top: 20px
}

.p-News__list__item {
  margin: 10px 0
}

.p-News__list__item__link {
  width: 100%;
  padding-bottom: 10px;
  color: #000;
  border-bottom: 1px solid #ccc
}

.p-News__list__item__date {
  display: block
}

.p-News__list__item__lead {
  margin: 0;
  padding: 0;
  color: #221815;
  text-decoration: underline;
  word-break: break-all
}

@media (min-width: 960px) {
  .p-News__list {
    padding-left: 4px
  }
  .p-News__list__item {
    margin-bottom: 10px
  }
  .p-News__list__item__link {
    display: flex
  }
  .p-News__list__item__date {
    width: 150px;
    flex-shrink: 0
  }
  .p-News__list__item__lead {
    display: block
  }
}

@media (max-width: 959px) {
  .p-News__title {
    margin-bottom: 20px
  }
  .p-News__items__item {
    flex-basis: 45%;
    margin: 0 0 20px
  }
  .p-News__items__lead {
    flex: 1
  }
}

.p-plan {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 140px
}

.p-plan table {
  width: 100%;
  border-collapse: collapse
}

.p-plan tr:not(:last-child)>td, .p-plan th {
  border-bottom: 1px solid #797979
}

.p-plan td, .p-plan th {
  width: 25%;
  padding: 30px 20px;
  text-align: center;
  font-weight: normal
}

.p-plan td:not(:last-child), .p-plan th:not(:last-child) {
  border-right: 1px solid #797979
}

.p-plan td img, .p-plan th img {
  max-width: 100%
}

.p-plan .c-heroText__title, .p-plan .c-heroText__content {
  color: #000
}

.p-planTitle {
  margin-bottom: 70px
}

.p-plan hr {
  margin: 10px 0
}

.p-planSection {
  width: 84%;
  margin: 0 auto;
  background-color: #fff;
  padding: 0 7% 85px
}

.p-planSection__title {
  text-align: center;
  padding-bottom: 65px
}

.p-planSection__subtitle {
  color: #221815;
  font-size: 1.8rem
}

.p-planSection__info {
  font-size: 2rem
}

.p-planSection__content {
  margin: 30px 0
}

.p-planSection__price {
  margin-top: 60px
}

.p-planSection__priceTitle {
  font-size: 2rem;
  margin-bottom: 10px;
  position: relative
}

.p-planSection__priceItem {
  flex-wrap: wrap;
  flex: 1
}

.p-planSection__priceItem:first-child {
  margin-right: 40px
}

.p-planSection__red {
  background-color: #221815;
  color: #fff;
  padding: 5px 12px;
  font-size: 1.2rem;
  border-radius: 17px
}

.p-planSection__redcp {
  background: linear-gradient(45deg, #f1da34 0%, #fff8c7 45%, #f1da34 70%, #fff8c3 85%, #f1da34 95% 100%);
  color: #000;
  padding: 5px 12px;
  font-size: 1.2rem;
  border-radius: 17px
}

.p-planSection__ribbon {
  display: inline-block;
  position: relative;
  height: 36px;
  line-height: 36px;
  text-align: center;
  padding: 0 25px;
  font-size: 1.6rem;
  background: linear-gradient(45deg, #f1da34 0%, #fff8c7 45%, #f1da34 70%, #fff8c3 85%, #f1da34 95% 100%);
  color: #000;
  box-sizing: border-box;
  margin-left: 10px
}

.p-planSection__ribbon:before {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
  top: 0;
  left: 0;
  border-width: 18px 0px 18px 10px;
  border-color: transparent transparent transparent #fff;
  border-style: solid
}

.p-planSection__ribbon:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
  top: 0;
  right: 0;
  border-width: 18px 10px 18px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid
}

.p-planSection__caption {
  flex-basis: 100%
}

.p-planSection__cpline {
  text-decoration: line-through;
  color: #666 !important;
  font-size: 2.2rem !important
}

.p-planSection__number {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 3.2rem;
  color: #221815;
  padding: 0 5px 0 10px
}

.p-planSection__number2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 2.4rem
}

.p-planSection__number3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 2.4rem
}

.p-planSection__number4 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 1.6rem
}

.p-planSection__value {
  flex-basis: 100%;
  display: flex;
  align-items: center
}

.p-planSection__kome {
  font-size: 60%;
  padding-left: 140px
}

.p-planSection__yen {
  font-size: 1.2rem;
  color: #221815
}

.p-planSection__yen2 {
  font-size: 1.1rem
}

.p-planSection__yen3 {
  font-size: 1.4rem;
  margin-left: 3px
}

.p-planSection__balloon {
  position: relative;
  display: inline-block;
  padding: 0 2.5rem;
  color: #221815;
  text-align: center;
  margin-bottom: 10px
}

.p-planSection__balloon:before {
  content: '';
  position: absolute;
  bottom: 40%;
  display: inline-block;
  width: 32px;
  height: 1px;
  background-color: #221815;
  -webkit-transform: rotate(70deg);
  transform: rotate(70deg);
  left: 0
}

.p-planSection__balloon:after {
  content: '';
  position: absolute;
  bottom: 40%;
  display: inline-block;
  width: 32px;
  height: 1px;
  background-color: #221815;
  -webkit-transform: rotate(-70deg);
  transform: rotate(-70deg);
  right: 0
}

.p-planSection__payment {
  margin-top: 60px
}

.p-planSection__paymentTitle {
  font-size: 2rem;
  margin-bottom: 35px
}

.p-planSection__paymentSubtitle {
  font-size: 1.4rem
}

.p-planSection__paymentMonth {
  width: 19.8%;
  border-left: 1px solid #221815;
  padding-left: 10px;
  font-size: 1.1rem;
  line-height: 30px
}

.p-planSection__paymentMonth6 {
  width: 69.8%;
  border-left: 1px solid #221815;
  padding-left: 10px;
  font-size: 1.1rem;
  line-height: 30px
}

.p-planSection__paymentArrow {
  position: relative;
  margin-bottom: 20px
}

.p-planSection__paymentArrow__balloon {
  position: relative;
  display: inline-block;
  padding: 0 1.25rem;
  color: #f1da34
}

.p-planSection__paymentArrow__balloon:before {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 16px;
  height: 1px;
  background-color: #f1da34;
  -webkit-transform: rotate(70deg);
  transform: rotate(70deg);
  left: 0
}

.p-planSection__paymentArrow__balloon:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 16px;
  height: 1px;
  background-color: #f1da34;
  -webkit-transform: rotate(-70deg);
  transform: rotate(-70deg);
  right: 0
}

.p-planSection__paymentLeft {
  height: 100px;
  width: 20%;
  background-color: #221815;
  position: relative
}

.p-planSection__paymentLeft:before {
  content: "";
  position: absolute;
  right: -50px;
  bottom: 0;
  z-index: 1;
  width: 0;
  height: 0;
  border-left: 50px solid #221815;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent
}

.p-planSection__paymentLeft6 {
  height: 100px;
  width: 70%;
  background-color: #221815;
  position: relative
}

.p-planSection__paymentLeft6:before {
  content: "";
  position: absolute;
  right: -50px;
  bottom: 0;
  z-index: 1;
  width: 0;
  height: 0;
  border-left: 50px solid #221815;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent
}

.p-planSection__paymentText1 {
  width: 165px;
  justify-content: center;
  z-index: 2;
  position: absolute;
  top: 33%;
  left: 0;
  color: #fff
}

.p-planSection__paymentText2 {
  justify-content: center;
  z-index: 2;
  position: absolute;
  top: 33%;
  left: 30%;
  color: #221815
}

.p-planSection__paymentText3 {
  z-index: 2;
  position: absolute;
  top: 20%;
  left: 350px;
  color: #221815
}

.p-planSection__paymentText4 {
  justify-content: center;
  z-index: 2;
  position: absolute;
  top: 33%;
  left: 78%;
  color: #221815
}

.p-planSection__paymentText5 {
  width: 20%;
  justify-content: center;
  z-index: 2;
  position: absolute;
  top: 10%;
  left: 0;
  color: #fff
}

.p-planSection__paymentText6 {
  justify-content: center;
  align-items: baseline;
  z-index: 2;
  position: absolute;
  top: 10%;
  left: 190px;
  text-decoration: line-through;
  color: #221815
}

.p-planSection__paymentRight {
  height: 100px;
  flex: 1;
  margin-right: 50px;
  background-color: #f9f2f2;
  position: relative
}

.p-planSection__paymentRight:before {
  content: "";
  position: absolute;
  right: -50px;
  bottom: 0;
  z-index: 1;
  width: 0;
  height: 0;
  border-left: 50px solid #f9f2f2;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent
}

.p-planSection__paymentAll {
  height: 100px;
  flex: 1;
  background-color: #221815;
  position: relative
}

.p-planSection__paymentAll:before {
  content: "";
  position: absolute;
  right: -50px;
  bottom: 0;
  z-index: 1;
  width: 0;
  height: 0;
  border-left: 50px solid #221815;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent
}

.p-planSection__paymentCaption {
  font-size: 1.1rem;
  margin-bottom: 25px
}

.p-planSection__button {
  text-align: center
}

.p-planSection__button>a {
  margin-top: 70px;
  display: inline-block;
  text-align: center;
  width: 627px;
  height: 80px;
  line-height: 80px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-planSection2 {
  width: 66%;
  margin: 0 auto
}

.p-planSection2__title {
  background-color: #000;
  color: #fff;
  height: 70px;
  line-height: 70px;
  font-size: 1.8rem;
  padding: 0 30px;
  margin-bottom: 50px
}

.p-planSVG {
  position: relative;
  z-index: 1;
  transform: translateY(-50%)
}

.p-planSVGSP {
  height: 78px;
  position: relative;
  z-index: 1;
  transform: translateY(-24%);
  max-width: 100%
}

.p-plan ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.2rem;
  display: flex
}

.p-plan ul>li {
  flex-basis: 50%;
  margin-bottom: 20px
}

.p-planIntensive {
  margin-bottom: 140px
}

.p-planIntensive__img {
  text-align: center;
  flex-basis: 40%
}

.p-planIntensive__img>img {
  width: 326px;
  max-width: 100%
}

.p-planIntensive__text {
  flex-basis: 60%
}

.p-planIntensive__logo {
  width: 126px
}

.p-planIntensive__logoSP {
  width: 81px
}

.p-planIntensive__table {
  margin-top: 75px
}

.p-planIntensive__table>table {
  margin-top: 40px;
  border-bottom: 1px solid #797979
}

.p-planIntensive__table>table td>div {
  font-size: 1.1rem;
  margin-top: 5px
}

.p-planIntensive__tableTitle {
  font-size: 2rem;
  margin-bottom: 20px
}

.p-planIntensive__tableLarge {
  font-size: 1.8rem
}

.p-planIntensive__tableRed {
  background-color: #f9f2f2
}

.p-planIntensive__tableCaption {
  font-size: 1rem;
  margin-top: 30px
}

.p-planIntensive__title {
  height: 60px;
  border-bottom: 1px solid #ccc;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 10px
}

.p-planIntensive__arrow {
  transition: all .3s;
  transform: rotate(0deg)
}

.p-planIntensive__content {
  display: none
}

.p-planIntensive__row {
  width: 100%
}

.p-planIntensive__row.active>.p-planIntensive__content {
  display: block
}

.p-planIntensive__row.active .p-planIntensive__arrow {
  transform: rotate(180deg)
}

.p-planIntensive__row:first-child {
  border-top: 1px solid #ccc
}

.p-planIntensive__spTable {
  margin-top: 25px
}

.p-planIntensive__spRow {
  border-bottom: 1px solid #ccc;
  align-items: center
}

.p-planIntensive__spRow:first-child {
  border-bottom: 1px solid #eee
}

.p-planIntensive__spCol {
  flex-basis: 50%;
  text-align: center;
  padding: 10px
}

.p-planIntensive__spContainer {
  display: flex;
  justify-content: center;
  align-items: center
}

.p-planIntensive__spLarge {
  font-size: 1.2rem
}

.p-planIntensive__spCaption {
  font-size: 0.9rem;
  margin-top: 3px
}

.p-planIntensive__spCaption2 {
  font-size: 0.9rem
}

.p-planIntensive__spHeader2 {
  line-height: 1
}

.p-planSimple {
  margin-bottom: 140px
}

.p-planSimple__img {
  text-align: center;
  flex-basis: 40%
}

.p-planSimple__img>img {
  width: 301px;
  max-width: 100%
}

.p-planSimple__text {
  flex-basis: 60%
}

.p-planSimple__cart {
  display: flex;
  justify-content: space-around;
  margin-top: 50px
}

.p-planSimple__cart__item>img {
  width: 240px
}

.p-planSimple__cart__item>p {
  font-size: 1.4rem;
  line-height: 1.5;
  margin: 10px auto
}

.p-planSimple__cart__item>a {
  width: 100%;
  max-width: 350px;
  margin-top: 20px
}

.p-planPreventive {
  margin-bottom: 120px
}

.p-planPreventive__img {
  text-align: center;
  flex-basis: 40%
}

.p-planPreventive__img>img {
  width: 203px;
  max-width: 100%
}

.p-planPreventive__text {
  flex-basis: 60%
}

.p-planPreventive .p-planSection__content {
  padding-bottom: 30px
}

.p-planTable {
  margin-bottom: 75px
}

.p-planTable__container {
  height: 215px
}

.p-planTable__img1 {
  width: 145px
}

.p-planTable__img2 {
  width: 155px
}

.p-planTable__img3 {
  width: 93px
}

.p-planTable__large {
  font-size: 1.8rem
}

.p-planTable__caption {
  margin-top: 5px
}

.p-planTable__title {
  height: 60px;
  border-bottom: 1px solid #ccc;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 10px
}

.p-planTable__arrow {
  transition: all .3s;
  transform: rotate(0deg)
}

.p-planTable__content {
  display: none
}

.p-planTable__row {
  width: 100%
}

.p-planTable__row.active>.p-planTable__content {
  display: block
}

.p-planTable__row.active .p-planTable__arrow {
  transform: rotate(180deg)
}

.p-planTable__td {
  position: relative
}

.p-planTable__tdRibbon {
  position: absolute;
  top: -10px;
  left: 0px
}

.p-planTable__tdRibbon__inner {
  display: inline-block;
  position: relative;
  height: 30px;
  line-height: 30px;
  text-align: center;
  padding: 0 30px 0 10px;
  font-size: 1.2rem;
  background: #221815;
  color: #fff;
  box-sizing: border-box
}

.p-planTable__tdRibbon__inner:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
  top: 0;
  right: 0;
  border-width: 30px 15px 15px 0px;
  border-style: solid
}

.p-planTable__tdRibbon__bg:after {
  border-color: transparent #eee transparent transparent
}

.p-planTable__tdRibbon__bgCP:after {
  border-color: transparent #f1ead8 transparent transparent
}

.p-planTable__tdBg__cp {
  background: linear-gradient(45deg, #f1e7cb 0%, #f7f3ea 35%, #f1e7cb 95% 100%)
}

.p-planTable__tdBg__cpHead {
  background: #f1ead8
}

.p-planTable__caption {
  text-align: center;
  margin: 10px 0 5px
}

.p-planTable__caption>span {
  padding: 4px 16px;
  border-radius: 30px;
  font-size: 1.1rem
}

.p-planTable__captionCP {
  background: linear-gradient(45deg, #f1da34 0%, #fff8c7 45%, #f1da34 70%, #fff8c3 85%, #f1da34 95% 100%);
  color: #000
}

.p-planTable__captionRed {
  border: 1px solid #221815;
  color: #221815
}

.p-planTable__captionBlack {
  border: 1px solid #000;
  color: #000
}

.p-planTable__spStd {
  text-decoration: line-through;
  margin: 10px 0 5px;
  font-size: 90%;
  color: #666
}

.p-planTable__spRow {
  border-bottom: 1px solid #ccc;
  padding: 10px 0 20px
}

.p-planTable__spCol {
  flex-basis: 50%;
  text-align: center
}

.p-planTable__spCol2 {
  flex-basis: 50%;
  text-align: center;
  display: flex;
  align-items: center;
  position: relative
}

.p-planTable__spCol2__inner {
  width: 100%;
  display: flex;
  flex-direction: column
}

.p-planTable__spCol2__inner>img {
  display: block;
  margin: auto
}

.p-planTable__spContainer {
  height: 110px;
  display: flex;
  justify-content: center;
  align-items: center
}

.p-planTable__spImg1 {
  width: 72px
}

.p-planTable__spImg2 {
  width: 77px
}

.p-planTable__spImg3 {
  width: 46px
}

.p-planTable__spLarge {
  font-size: 1.2rem
}

.p-planTable__spCaption {
  font-size: 0.9rem;
  margin-top: 3px
}

.p-planTable__spCaption2 {
  font-size: 0.9rem
}

.p-planTable__spHeader2 {
  line-height: 1
}

.p-planProduct select {
  -moz-appearance: none;
  -webkit-appearance: none;
  border: 1px solid #797979;
  border-radius: 5px;
  padding: 0 5px;
  background: #fff
}

.p-planProduct__items {
  justify-content: space-around
}

.p-planProduct__item {
  flex-basis: 25%;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding: 0 1rem;
  margin-bottom: 55px
}

.p-planProduct__label {
  font-size: 1.8rem;
  margin-bottom: 5px
}

.p-planProduct__caption {
  margin-bottom: 10px
}

.p-planProduct__name {
  margin-bottom: 5px
}

.p-planProduct__inner {
  margin-top: auto
}

.p-planProduct__img {
  height: 225px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  margin-bottom: 14px
}

.p-planProduct__img img {
  width: 100%;
  max-width: 85px;
  height: 225px;
  object-fit: contain
}

.p-planProduct__cart {
  display: flex;
  flex-direction: column
}

.p-planProduct__price {
  font-size: 1.6rem;
  width: 100%;
  padding-bottom: 10px
}

.p-planProduct__quantity {
  width: 100%
}

.p-planProduct__quantity>.c-mySelectBox {
  width: 60px;
  height: 36px
}

.p-planProduct__quantity>.c-mySelectBox::after {
  width: 1em
}

.p-planProduct__quantity>.c-mySelectBox>select {
  line-height: 34px;
  padding-left: 10px
}

.p-planProduct__button {
  text-align: center;
  margin-top: 20px
}

.p-planProduct__button>a {
  width: 160px;
  height: 40px;
  line-height: 40px;
  border-radius: 20px;
  background-color: #000;
  display: inline-block
}

.p-planNotice {
  margin-top: 2rem;
  padding: 0.75rem;
  border: 1px solid #000
}

.p-planNotice p {
  font-size: 1.25rem;
  font-weight: 400;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Yu Gothic", "MS Pゴシック", "MS PGothic", sans-serif;
  color: #000;
  margin-bottom: 0
}

.p-plan .disabled {
  background: #ccc;
  cursor: default
}

@media (min-width: 960px) {
  .p-planIntensive__table>ul {
    width: 850px
  }
  .p-planIntensive__table>ul>li {
    flex-basis: auto;
    min-width: 250px;
    font-size: 1.6rem;
    margin-bottom: 5px
  }
  .p-planIntensive__tableCaption {
    text-align: right
  }
  .p-planProduct__button>a:hover:hover {
    border: 1px solid #000;
    background-color: #fff;
    color: #000
  }
  .p-planProduct__cart {
    display: flex;
    align-items: baseline
  }
  .p-planSimple__cart__item {
    flex-basis: 45%;
    padding: 0 20px
  }
  .p-planSimple__cart__item>img {
    max-width: 240px
  }
  .p-planSimple__cart__item>p {
    font-size: 1.4rem
  }
  .p-planSection__button>a:hover {
    border: 1px solid #221815;
    background-color: transparent;
    color: #221815
  }
  a.disabled:hover {
    border: none;
    background-color: #ccc;
    color: #fff
  }
}

@media (min-width: 1200px) {
  .p-planSection__paymentContainer {
    width: 90%;
    margin: 0 auto
  }
}

@media (max-width: 1199px) {
  .p-plan ul {
    flex-direction: column
  }
  .p-planSection2 {
    width: 84%
  }
}

@media (max-width: 959px) {
  .p-plan {
    margin-top: calc(15px + (100vw - 320px) / 40);
    margin-bottom: 0
  }
  .p-plan>.c-hero {
    height: calc(75vw + (100vw - 320px) / 40)
  }
  .p-planTitle {
    margin-bottom: 45px
  }
  .p-planSection {
    width: 100%
  }
  .p-planSection__title {
    padding-bottom: 40px
  }
  .p-planSection__subtitle {
    font-size: 1.2rem
  }
  .p-planSection__info {
    font-size: 1.6rem
  }
  .p-planSection__content {
    font-size: 1.2rem;
    margin: 18px 0 25px
  }
  .p-planSection__price {
    margin-top: 45px
  }
  .p-planSection__priceItem {
    width: 100%;
    justify-content: space-between
  }
  .p-planSection__priceItem:first-child {
    margin-right: 0
  }
  .p-planSection__red {
    font-size: 1rem;
    border-radius: 16px
  }
  .p-planSection__ribbon {
    font-size: 1.1rem;
    padding: 0 15px;
    height: 30px;
    line-height: 30px
  }
  .p-planSection__ribbon:before {
    border-width: 15px 0px 15px 10px
  }
  .p-planSection__ribbon:after {
    border-width: 15px 10px 15px 0px
  }
  .p-planSection__number {
    font-size: 3rem
  }
  .p-planSection__number2 {
    font-size: 2rem
  }
  .p-planSection__number3 {
    font-size: 1.5rem
  }
  .p-planSection__value {
    justify-content: space-between
  }
  .p-planSection__kome {
    width: 100%;
    text-align: right;
    padding-left: 0
  }
  .p-planSection__yen {
    font-size: 1rem
  }
  .p-planSection__yen2 {
    font-size: 0.9rem
  }
  .p-planSection__yen3 {
    font-size: 0.9rem;
    line-height: 1.2
  }
  .p-planSection__payment {
    margin-top: 40px
  }
  .p-planSection__paymentMonth {
    width: 42.8%
  }
  .p-planSection__paymentMonth6 {
    width: 43.8%
  }
  .p-planSection__paymentTitle {
    font-size: 1.6rem;
    margin-bottom: 5px
  }
  .p-planSection__paymentSubtitle {
    font-size: 1.2rem;
    margin-bottom: 10px
  }
  .p-planSection__paymentLeft {
    width: 43%
  }
  .p-planSection__paymentLeft:before {
    position: absolute;
    right: -25px;
    border-left: 25px solid #221815
  }
  .p-planSection__paymentLeft6 {
    width: 44%
  }
  .p-planSection__paymentLeft6:before {
    position: absolute;
    right: -25px;
    border-left: 25px solid #221815
  }
  .p-planSection__paymentText1 {
    width: 38%
  }
  .p-planSection__paymentText2 {
    height: auto;
    left: 54%
  }
  .p-planSection__paymentText2__cp {
    top: 25px !important
  }
  .p-planSection__paymentText3 {
    height: auto;
    top: 50px;
    left: 44%
  }
  .p-planSection__paymentText3__cp {
    top: 56px !important
  }
  .p-planSection__paymentText3>img {
    width: 30px
  }
  .p-planSection__paymentText4 {
    left: 56%
  }
  .p-planSection__paymentText4>img {
    width: 30px
  }
  .p-planSection__paymentText5 {
    width: 46%
  }
  .p-planSection__paymentText6 {
    top: 5px;
    left: 44%
  }
  .p-planSection__paymentRight {
    margin-right: 25px
  }
  .p-planSection__paymentRight:before {
    right: -25px;
    border-left: 25px solid #f9f2f2
  }
  .p-planSection__paymentAll {
    margin-right: 25px
  }
  .p-planSection__paymentAll:before {
    right: -25px;
    border-left: 25px solid #221815
  }
  .p-planSection__paymentCaption {
    font-size: 1rem
  }
  .p-planSection__paymentPS {
    font-size: 1rem;
    font-weight: bold
  }
  .p-planSection__button>a {
    margin-top: 45px;
    width: 80vw;
    height: 50px;
    line-height: 50px;
    font-size: 1.2rem;
    border-radius: 25px
  }
  .p-planSection2 {
    width: 87%
  }
  .p-planSection2__title {
    text-align: center;
    height: 53px;
    line-height: 53px;
    font-size: 1.4rem;
    margin-bottom: 0
  }
  .p-plan ul>li {
    flex: 1 1 auto;
    max-width: 100%;
    margin-bottom: 5px
  }
  .p-planIntensive {
    margin-bottom: 64px
  }
  .p-planIntensive__img {
    flex: 1 1 auto;
    max-width: 100%;
    margin-bottom: 30px
  }
  .p-planIntensive__img>img {
    width: 172.5px
  }
  .p-planIntensive__text {
    flex: 1 1 auto;
    max-width: 100%
  }
  .p-planSimple {
    margin-bottom: 64px
  }
  .p-planSimple__img {
    flex: 1 1 auto;
    max-width: 100%;
    margin-bottom: 30px
  }
  .p-planSimple__img>img {
    width: 185.5px
  }
  .p-planSimple__text {
    flex: 1 1 auto;
    max-width: 100%
  }
  .p-planSimple__cart {
    flex-direction: column
  }
  .p-planSimple__cart__item {
    margin-bottom: 40px
  }
  .p-planSimple__cart__item>p {
    font-size: 1.4rem
  }
  .p-planSimple__cart__item>a {
    margin-top: 10px
  }
  .p-planPreventive {
    margin-bottom: 70px
  }
  .p-planPreventive__img {
    flex: 1 1 auto;
    max-width: 100%;
    margin-bottom: 30px
  }
  .p-planPreventive__img>img {
    width: 128.5px
  }
  .p-planPreventive__text {
    flex: 1 1 auto;
    max-width: 100%
  }
  .p-planProduct {
    padding-bottom: 70px
  }
  .p-planProduct__items {
    background-color: #fff;
    padding: 50px 0 10px
  }
  .p-planProduct__item {
    flex: 1 1 auto;
    max-width: 100%
  }
  .p-planProduct__label {
    font-size: 1.6rem
  }
  .p-planProduct__caption {
    font-size: 1.2rem
  }
  .p-planProduct__name {
    font-size: 1.4rem;
    margin-bottom: 10px
  }
  .p-planProduct__img {
    height: auto
  }
  .p-planProduct__img img {
    height: 250px
  }
  .p-planProduct__cart {
    width: 95%;
    margin: auto;
    flex-direction: row;
    align-items: center;
    justify-content: center
  }
  .p-planProduct__price {
    width: auto;
    padding-bottom: 0
  }
  .p-planProduct__quantity {
    width: auto
  }
  .p-planTable__tdRibbon {
    position: absolute;
    top: -10px;
    left: inherit;
    right: 0px
  }
  .p-planTable__tdRibbon__inner {
    padding: 0 10px 0 30px;
    height: 24px;
    line-height: 24px
  }
  .p-planTable__tdRibbon__inner:after {
    display: none
  }
  .p-planTable__tdRibbon__inner:before {
    position: absolute;
    content: '';
    width: 0px;
    height: 0px;
    z-index: 1;
    top: 0;
    left: 0;
    border-width: 25px 0px 0px 12px;
    border-style: solid
  }
  .p-planTable__tdRibbon__bg:before {
    border-color: transparent transparent transparent #eee
  }
  .p-planTable__tdRibbon__bgCP:before {
    border-color: transparent transparent transparent #f1ead8
  }
  .p-planNotice {
    margin-top: 2rem;
    padding: 0 1rem;
    background-color: #fff;
    border: none
  }
  .p-planNotice p {
    font-size: 1.25rem;
    font-weight: 400;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Yu Gothic", "MS Pゴシック", "MS PGothic", sans-serif;
    color: #000;
    margin-bottom: 0;
    padding: 0.75rem;
    border: 1px solid #000
  }
}

.p-product {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 140px
}

.p-productTop {
  padding-top: 294px;
  padding-bottom: 60px
}

.p-productTop__links {
  text-align: center
}

.p-productTop__links>li {
  display: inline-block;
  margin-left: 20px;
  position: relative
}

.p-productTop__links>li:after {
  margin-left: 20px;
  content: ' |'
}

.p-productTop__links>li:last-child:after {
  margin-left: 23px;
  content: ''
}

.p-productTop__links>li>a {
  font-size: 1.6rem;
  color: #000
}

.p-productTop__links>li>a:before {
  position: absolute;
  top: 30px;
  left: 0;
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background: #221815;
  transition: .3s
}

.p-productTop__links>li>a:hover:before {
  width: calc(100% - 25px) !important
}

.p-productTop__spLinks {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  list-style-type: none
}

.p-productTop__spLinks>li {
  flex-basis: 33.2%;
  background-color: #221815
}

.p-productTop__spLinks>li>a {
  width: 100%;
  display: block;
  text-align: center;
  line-height: 40px;
  font-size: 1.2rem
}

.p-productTop__spLinks>li:nth-child(n+4) {
  border-top: 1px solid #fff
}

.p-productTop__spLinks>li:nth-child(3n+1), .p-productTop__spLinks>li:nth-child(3n+2) {
  border-right: 1px solid #fff
}

.p-productEssence {
  position: relative;
  margin-bottom: 50px
}

.p-productEssence__title {
  position: absolute;
  top: 13px;
  text-align: center;
  font-size: 2rem;
  width: 443px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-productEssence>.left {
  width: 95%;
  left: -95%;
  background-image: url("../img/product/essence_bg.jpg");
  background-size: 100%;
  background-position: left top;
  background-color: #000;
  position: relative
}

.p-productEssence>.right {
  margin: 0 0 0 auto;
  width: 71%;
  right: -71%;
  top: -200px;
  z-index: 1;
  background-color: #fff;
  position: relative
}

.p-productEssence__product {
  flex-basis: 30%;
  max-width: 30%;
  text-align: center
}

.p-productEssence__product>img {
  width: 161px;
  position: relative;
  top: 135px
}

.p-productEssence__text {
  flex-basis: 70%;
  max-width: 70%;
  color: #fff;
  margin-top: 90px
}

.p-productEssence__text>div>h2 {
  font-size: 3.2rem;
  font-weight: normal;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productEssence__text>div>p {
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productEssence__accordion {
  position: relative;
  width: 100%;
  margin: 30px 0
}

.p-productEssence__accordion__header {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 1.6rem;
  display: block;
  position: relative;
  margin-bottom: 10px;
  padding: 0;
  color: #fff;
  cursor: pointer;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productEssence__accordion__header:after {
  content: "+";
  margin-left: 5px;
  width: 18px;
  height: 18px;
  font-size: 1.6rem;
  line-height: 14px;
  text-align: center;
  border: 1px solid #fff;
  display: inline-block
}

.p-productEssence__accordion__header.open:after {
  content: "-";
  margin-left: 5px;
  width: 18px;
  height: 18px;
  font-size: 1.6rem;
  line-height: 14px;
  text-align: center;
  border: 1px solid #fff;
  display: inline-block
}

.p-productEssence__accordion__contents {
  display: none
}

.p-productEssence__accordion__contents__inner {
  display: flex
}

.p-productEssence__accordion__contents__inner__flow {
  flex-basis: 40%
}

.p-productEssence__accordion__contents__inner__flow>img {
  width: 100%;
  max-width: 180px
}

.p-productEssence__accordion__contents__inner__flow>p {
  font-size: 1.2rem;
  background: rgba(0, 0, 0, 0.6);
  padding: 10px
}

.p-productEssence__detail {
  width: 100%;
  padding: 50px 5vw 65px 2vw;
  justify-content: space-between
}

.p-productEssence__detail>div {
  flex-basis: 30%;
  text-align: center
}

.p-productEssence__detail>div>div {
  text-align: left
}

.p-productEssence__detail>div>img {
  height: 245px
}

.p-productDevice {
  position: relative;
  margin-bottom: 50px
}

.p-productDevice__title {
  position: absolute;
  top: 140px;
  right: 0;
  text-align: center;
  font-size: 2rem;
  width: 313px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-productDevice>.right {
  margin: 0 0 0 auto;
  width: 95%;
  right: -95%;
  background-image: url("../img/product/device_bg.jpg");
  background-size: 100%;
  background-position: right top;
  background-color: #000;
  position: relative;
  padding-bottom: 70px
}

.p-productDevice>.left {
  width: 93.8%;
  left: -93.8%;
  top: -80px;
  z-index: 1;
  background-color: #fff;
  position: relative
}

.p-productDevice__product {
  flex-basis: 44%;
  max-width: 44%;
  text-align: center
}

.p-productDevice__product>img {
  width: 100%;
  max-width: 800px;
  position: relative;
  top: -130px;
  left: -30%
}

.p-productDevice__spProduct {
  width: 100%;
  text-align: center;
  padding-top: 40px
}

.p-productDevice__spProduct>img {
  width: 80%;
  max-width: 400px
}

.p-productDevice__text {
  flex-basis: 56%;
  max-width: 56%;
  color: #fff;
  margin-top: 90px;
  position: relative;
  left: 5%
}

.p-productDevice__text>div>h2 {
  font-size: 3.2rem;
  font-weight: normal;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productDevice__text>div>p {
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productDevice__accordion {
  position: relative;
  margin: 30px 0
}

.p-productDevice__accordion__header {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 1.6rem;
  display: block;
  position: relative;
  margin-bottom: 10px;
  padding: 0;
  color: #fff;
  cursor: pointer
}

.p-productDevice__accordion__header:after {
  content: "+";
  margin-left: 5px;
  width: 18px;
  height: 18px;
  font-size: 1.6rem;
  line-height: 14px;
  text-align: center;
  border: 1px solid #fff;
  display: inline-block
}

.p-productDevice__accordion__header.open:after {
  content: "-";
  margin-left: 5px;
  width: 18px;
  height: 18px;
  font-size: 1.6rem;
  line-height: 14px;
  text-align: center;
  border: 1px solid #fff;
  display: inline-block
}

.p-productDevice__accordion__contents {
  display: none
}

.p-productDevice__accordion__contents__inner {
  display: flex;
  flex-wrap: wrap
}

.p-productDevice__accordion__contents__inner__flow {
  flex-basis: 30%
}

.p-productDevice__accordion__contents__inner__flow>img {
  width: 100%;
  max-width: 180px
}

.p-productDevice__accordion__contents__inner__flow>p {
  font-size: 1.2rem;
  background: rgba(0, 0, 0, 0.6);
  padding: 10px
}

.p-productDevice__detail {
  width: 100%;
  padding: 40px 3vw 65px 5vw;
  justify-content: space-between
}

.p-productDevice__detail>div {
  flex-basis: 18%;
  text-align: center
}

.p-productDevice__detail>div>div {
  text-align: left
}

.p-productDevice__detail>div>img {
  width: 90%;
  margin-bottom: 30px
}

.p-productSupplement {
  position: relative;
  margin-bottom: -60px
}

.p-productSupplement__title {
  position: absolute;
  top: 40px;
  text-align: center;
  font-size: 2rem;
  width: 400px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-productSupplement>.left {
  width: 95%;
  left: -95%;
  background-image: url("../img/product/supplement_bg.jpg");
  background-size: cover;
  background-color: #000;
  height: 633px;
  position: relative
}

.p-productSupplement>.right {
  margin: 0 0 0 auto;
  width: 71%;
  right: -71%;
  top: -200px;
  z-index: 1;
  background-color: #fff;
  position: relative
}

.p-productSupplement__product {
  width: 29vw;
  text-align: center
}

.p-productSupplement__product>img {
  width: 207px;
  position: relative;
  top: 135px
}

.p-productSupplement__text {
  flex: 1 1 auto;
  color: #fff;
  margin-top: 90px
}

.p-productSupplement__text>div>h2 {
  font-size: 3.2rem;
  font-weight: normal;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productSupplement__text>div>p {
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productSupplement__detail {
  width: 100%;
  padding: 50px 5vw 65px 2vw;
  justify-content: space-between
}

.p-productSupplement__detail>div {
  flex-basis: 30%;
  text-align: center
}

.p-productSupplement__detail>div>div {
  text-align: left
}

.p-productSupplement__detail>div>img {
  height: 245px
}

.p-productAdvisor {
  margin-bottom: 100px
}

.p-productAdvisor>.right {
  margin: 0 0 0 auto;
  width: 95%;
  right: -95%;
  background-color: #2d2d2d;
  height: 637px;
  position: relative
}

.p-productAdvisor>.left {
  width: 71.2%;
  left: -71.2%;
  top: -110px;
  z-index: 1;
  background-color: #fff;
  position: relative
}

.p-productAdvisor__product {
  margin-right: 4%;
  width: 647px;
  text-align: center;
  position: relative;
  top: -148px
}

.p-productAdvisor__product>img {
  width: 100%;
  position: relative
}

.p-productAdvisor__spProduct {
  width: 100%;
  text-align: center
}

.p-productAdvisor__spProduct>img {
  width: 100%;
  max-width: 400px
}

.p-productAdvisor__text {
  flex: 1 1 auto;
  color: #fff;
  margin-top: 100px;
  position: relative;
  left: 5%
}

.p-productAdvisor__title {
  font-size: 1.8rem;
  margin-bottom: 20px
}

.p-productAdvisor__detail {
  width: 100%;
  padding: 40px 3vw 65px 5vw;
  justify-content: space-between
}

.p-productAdvisor__detail>div {
  flex-basis: 28%;
  text-align: center
}

.p-productAdvisor__detail>div>div {
  text-align: left
}

.p-productAdvisor__detail>div>img {
  width: 90%;
  margin-bottom: 30px
}

.p-productApp {
  margin-bottom: 250px
}

.p-productApp>.left {
  width: 95%;
  left: -95%;
  background-color: #221815;
  height: 637px;
  position: relative
}

.p-productApp__product {
  flex-basis: 43%
}

.p-productApp__images {
  width: 408px;
  max-width: 100%;
  height: 860px;
  position: relative;
  bottom: 150px;
  margin: 0 0 0 auto;
  border-radius: 45px 45px;
  box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -webkit-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -moz-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -o-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5)
}

.p-productApp__frame {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2
}

.p-productApp__screen {
  width: 96.7%;
  position: absolute;
  top: 7px;
  left: 8px;
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0)
}

.p-productApp__screen.js-isActive {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  filter: alpha(opacity=1)
}

.p-productApp__text {
  color: #fff;
  flex-basis: 57%
}

.p-productApp__textGroup {
  width: 100%;
  padding: 60px 0 45px 12.5%
}

.p-productApp__title {
  font-size: 1.8rem;
  margin-bottom: 20px
}

.p-productApp__button {
  width: 100%;
  height: 80px;
  align-items: center;
  text-align: left;
  cursor: pointer;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2)
}

.p-productApp__button.js-isActive {
  background-color: rgba(255, 255, 255, 0.1)
}

.p-productApp__buttonLeft {
  flex-basis: 44.7%;
  font-size: 1.6rem;
  padding-left: 10%;
  padding-right: 3.5%
}

.p-productApp__buttonLine {
  width: 1px;
  height: 30px;
  background-color: #fff
}

.p-productApp__buttonRight {
  flex-basis: 55.1%;
  padding-left: 3.5%;
  padding-right: 3.5%
}

.p-productApp>.right {
  margin: 0 0 0 auto;
  width: 95%;
  right: -95%;
  background-color: #221815;
  color: #fff;
  position: relative
}

.p-productApp__textSP {
  width: 80%;
  margin: 0 auto;
  padding: 90px 0 40px
}

.p-productApp__titleSP {
  font-size: 1.4rem;
  margin-bottom: 20px
}

.p-productApp__sliderText {
  text-align: center;
  display: none;
  margin-bottom: 30px
}

.p-productApp__sliderText.js-isActive {
  display: block
}

.p-productApp__sliderTitle {
  font-size: 1.6rem;
  margin-bottom: 10px
}

.p-productApp__sliderContent {
  font-size: 1.2rem
}

.p-productApp__imageContainer {
  width: 100%;
  height: 600px;
  overflow-y: hidden;
  position: relative
}

.p-productApp__imagesSP {
  width: 250px;
  margin: 0 auto;
  height: 528px;
  position: relative;
  border-radius: 40px 40px;
  box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -webkit-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -moz-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -o-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5)
}

.p-productApp__frameSP {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2
}

.p-productApp__screenSP {
  width: 96.7%;
  position: absolute;
  top: 4px;
  left: 5px;
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0)
}

.p-productApp__screenSP.js-isActive {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  filter: alpha(opacity=1)
}

.p-productApp__prev {
  position: absolute;
  top: 215px;
  left: calc(25vw - 83px);
  width: 35px;
  height: 35px;
  border-radius: 17.5px;
  background-color: #fff;
  color: #000;
  z-index: 3
}

.p-productApp__prev>i {
  font-size: 3rem;
  line-height: 0.9
}

.p-productApp__next {
  position: absolute;
  top: 215px;
  right: calc(25vw - 83px);
  width: 35px;
  height: 35px;
  border-radius: 17.5px;
  background-color: #fff;
  color: #000;
  z-index: 3
}

.p-productApp__next>i {
  font-size: 3rem;
  line-height: 0.9
}

.p-productPlan {
  position: relative
}

.p-productPlan__title {
  position: absolute;
  top: 13px;
  left: 0;
  text-align: center;
  font-size: 2rem;
  width: 250px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-productPlan>.right {
  margin: 0 0 0 auto;
  padding: 80px 13%;
  width: 95%;
  right: -95%;
  background-color: #fff;
  position: relative
}

.p-productPlan__subtitle {
  font-size: 2.6rem;
  color: #221815;
  text-align: center;
  margin-bottom: 25px
}

.p-productPlan__items {
  justify-content: space-between
}

.p-productPlan__item {
  min-width: 211px;
  flex-basis: 25%;
  text-align: center
}

.p-productPlan__item__img {
  width: 100%;
  height: 250px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  margin-bottom: 40px
}

.p-productPlan__item__img1 {
  height: 191px
}

.p-productPlan__item__img2 {
  height: 192px
}

.p-productPlan__item__img3 {
  height: 151px
}

.p-productPlan__item__title {
  font-size: 1.8rem;
  margin-bottom: 13px
}

.p-productPlan__item__caption {
  font-size: 1.3rem;
  margin-top: 13px
}

.p-productPlan__button {
  text-align: center;
  margin-top: 60px
}

.p-productPlan__button>a {
  display: inline-block;
  text-align: center;
  width: 627px;
  height: 80px;
  line-height: 80px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-productPlan__button>a:hover {
  border: 1px solid #221815;
  background-color: #fff;
  color: #221815
}

.p-productPlan>.left {
  padding: 50px 10%;
  width: 95%;
  left: -95%;
  background-color: #fff;
  position: relative;
  text-align: center
}

.p-productPlan>.left hr {
  max-width: 450px;
  margin: 0 auto
}

.p-productPlan__subtitleSP {
  font-size: 1.6rem;
  margin-bottom: 25px;
  text-align: left
}

.p-productPlan__spImg1 {
  width: 172px
}

.p-productPlan__spImg2 {
  width: 209px
}

.p-productPlan__spImg3 {
  width: 84px
}

.p-productPlan__spTitle {
  font-size: 1.6rem;
  margin: 30px 0 15px
}

.p-productPlan__spCaption {
  font-size: 1.2rem;
  margin: 15px 0 50px
}

.p-productPlan__spButton {
  width: 100%;
  height: 50px;
  line-height: 50px;
  font-size: 1.2rem;
  border-radius: 25px;
  background-color: #221815;
  display: inline-block
}

@media (min-width: 960px) {
  .p-productEssence__detail__second {
    margin-bottom: 15px
  }
  .p-productEssence__accordion__pb {
    padding-bottom: 230px
  }
  .p-productEssence__accordion__contents__inner__flow {
    margin-right: 20px
  }
  .p-productDevice__accordion {
    width: 150%
  }
  .p-productDevice__accordion__pb {
    padding-bottom: 20px
  }
  .p-productDevice__accordion__contents__inner__flow {
    margin-right: 20px
  }
  #id-essence:before {
    display: block;
    height: 50px;
    margin-top: -50px;
    content: ""
  }
  #id-device:before {
    display: block;
    height: 180px;
    margin-top: -180px;
    content: ""
  }
  #id-supplement:before {
    display: block;
    height: 80px;
    margin-top: -80px;
    content: ""
  }
  #id-advisor:before {
    display: block;
    height: 200px;
    margin-top: -200px;
    content: ""
  }
  #id-app:before {
    display: block;
    height: 200px;
    margin-top: -200px;
    content: ""
  }
  #id-plan:before {
    display: block;
    height: 50px;
    margin-top: -50px;
    content: ""
  }
}

@media (max-width: 1199px) {
  .p-productAdvisor>.right {
    height: 519px
  }
  .p-productAdvisor__product {
    width: 550px
  }
}

@media (max-width: 959px) {
  .p-product {
    margin-top: calc(15px + (100vw - 320px) / 40);
    margin-bottom: 0
  }
  .p-product>.c-hero {
    height: calc(75vw + (100vw - 320px) / 40)
  }
  .p-productSVG {
    max-width: 60vw
  }
  .p-productTop {
    padding-top: 40px;
    padding-bottom: 80px
  }
  .p-productEssence {
    padding-bottom: 60px;
    margin-bottom: -100px
  }
  .p-productEssence__title {
    font-size: 1.4rem;
    top: -21px;
    width: 315px;
    height: 42px;
    line-height: 42px
  }
  .p-productEssence>.left {
    height: auto;
    padding-bottom: 160px;
    margin-bottom: 0;
    background-size: 400%
  }
  .p-productEssence>.right {
    width: 89%;
    top: -130px
  }
  .p-productEssence__product {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto
  }
  .p-productEssence__product>img {
    width: 80px;
    top: 50px;
    margin-bottom: 70px
  }
  .p-productEssence__text {
    flex-basis: 80%;
    max-width: 80%;
    flex: 1 1 auto;
    margin: 0 auto
  }
  .p-productEssence__accordion__contents__inner {
    flex-wrap: wrap
  }
  .p-productEssence__accordion__contents__inner__flow {
    flex-basis: 100%
  }
  .p-productEssence__accordion__contents__inner__flow>img {
    display: block;
    margin: 0 auto 10px
  }
  .p-productEssence__detail {
    padding: 20px 10% 40px 10%
  }
  .p-productEssence__detail>div {
    flex-basis: auto;
    max-width: 100%;
    text-align: center
  }
  .p-productEssence__detail>div:not(:last-child) {
    margin-bottom: 30px
  }
  .p-productEssence__detail>div>img {
    height: 189px
  }
  .p-productDevice {
    margin-bottom: -50px
  }
  .p-productDevice__title {
    font-size: 1.4rem;
    top: -21px;
    width: 190px;
    height: 42px;
    line-height: 42px
  }
  .p-productDevice>.right {
    background-image: url("../img/product/deviceSP_bg.jpg");
    background-size: contain;
    padding-bottom: 170px
  }
  .p-productDevice__text {
    flex-basis: 80%;
    max-width: 80%;
    flex: 1 1 auto;
    margin: 30px auto 0;
    left: unset
  }
  .p-productDevice__accordion__contents__inner {
    flex-wrap: wrap
  }
  .p-productDevice__accordion__contents__inner__flow {
    flex-basis: 100%
  }
  .p-productDevice__accordion__contents__inner__flow>img {
    display: block;
    margin: 0 auto 10px
  }
  .p-productDevice__detail {
    padding: 40px 10% 45px
  }
  .p-productDevice__detail>div {
    flex-basis: auto;
    max-width: 100%
  }
  .p-productDevice__detail>div:not(:last-child) {
    margin-bottom: 30px
  }
  .p-productDevice__detail>div>img {
    max-width: 320px;
    width: 70%
  }
  .p-productSupplement {
    padding-bottom: 60px;
    margin-bottom: -100px;
    margin-top: 50px
  }
  .p-productSupplement__title {
    font-size: 1.4rem;
    top: -21px;
    width: 245px;
    height: 42px;
    line-height: 42px
  }
  .p-productSupplement>.left {
    height: auto;
    padding-bottom: 160px;
    margin-bottom: 0;
    background-size: auto 60%
  }
  .p-productSupplement>.right {
    width: 89%;
    top: -130px
  }
  .p-productSupplement__product {
    width: 100%
  }
  .p-productSupplement__product>img {
    width: 154px;
    top: 50px;
    margin-bottom: 70px
  }
  .p-productSupplement__text {
    width: 80%;
    margin: 0 auto
  }
  .p-productSupplement__detail {
    padding: 20px 10% 40px 10%
  }
  .p-productSupplement__detail>div {
    flex-basis: auto;
    max-width: 100%
  }
  .p-productSupplement__detail>div:not(:last-child) {
    margin-bottom: 30px
  }
  .p-productSupplement__detail>div>img {
    height: 189px
  }
  .p-productAdvisor {
    margin-bottom: -40px
  }
  .p-productAdvisor>.right {
    height: auto
  }
  .p-productAdvisor>.left {
    width: 93.8%;
    left: -93.8%
  }
  .p-productAdvisor__text {
    width: 80%;
    margin: 30px auto 180px;
    left: unset
  }
  .p-productAdvisor__title {
    font-size: 1.4rem
  }
  .p-productAdvisor__detail {
    padding: 40px 10% 45px
  }
  .p-productAdvisor__detail>div {
    flex-basis: auto;
    max-width: 100%
  }
  .p-productAdvisor__detail>div:not(:last-child) {
    margin-bottom: 30px
  }
  .p-productAdvisor__detail>div>img {
    max-width: 320px;
    width: 70%
  }
  .p-productApp {
    margin-bottom: 70px
  }
  .p-productPlan__title {
    font-size: 1.4rem;
    top: -21px;
    width: 103px;
    height: 42px;
    line-height: 42px
  }
}

.p-PromotionHead__bnr {
  max-width: 640px;
  width: 100%
}

.p-PromotionMain {
  background: #eee
}

.p-PromotionHero__text {
  width: 100%;
  height: calc(100vw*0.45);
  min-height: 500px;
  background-image: url("../img/index/hero.jpg");
  background-size: cover;
  background-position: left center;
  position: relative
}

.p-PromotionHero__text__title {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  color: #fff;
  position: absolute;
  top: 36%;
  left: 53%;
  font-size: 4vw
}

.p-PromotionHero__text__title>span {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  letter-spacing: 6px
}

.p-PromotionHero__bnr {
  position: absolute;
  bottom: 5%;
  left: 53%;
  width: 35vw;
  max-width: 640px
}

.p-PromotionHero__bnr>img {
  width: 100%
}

.p-PromotionAbout {
  width: 100%;
  height: 650px;
  margin-bottom: 120px
}

.p-PromotionAbout__text {
  position: relative;
  z-index: 2
}

.p-PromotionAbout__text__title {
  color: #fff;
  width: 40%
}

.p-PromotionAbout__text__content {
  color: #fff;
  width: 39%
}

.p-PromotionAbout__text>.left {
  position: absolute;
  top: 180px;
  left: 6%
}

.p-PromotionAbout__back {
  position: relative;
  height: 100%
}

.p-PromotionAbout__back>.left {
  width: 49%;
  height: 557px;
  background-color: #221815;
  position: absolute;
  left: -49%;
  z-index: 1
}

.p-PromotionAbout__back>.left>img {
  margin-top: 118px
}

.p-PromotionAbout__back>.right {
  z-index: 0;
  width: 94.5%;
  height: 100%;
  position: absolute;
  right: -94.5%;
  background-color: #eee
}

.p-PromotionAbout__backText {
  position: absolute;
  right: -10px;
  bottom: -10px
}

.p-PromotionAbout__productImg {
  position: absolute;
  right: calc(4% + (100% - 960px)/10);
  top: 75px;
  width: 525px;
  max-width: 45%
}

.p-PromotionAbout__links {
  position: absolute;
  left: 7.4%;
  bottom: 195px;
  display: flex;
  width: 709px;
  justify-content: space-between
}

.p-PromotionAbout__links img {
  width: 195px
}

.p-PromotionAbout__links img:hover {
  border-radius: 5px;
  box-shadow: 0px 4px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 6px 0px rgba(0, 0, 0, 0.12)
}

.p-PromotionAbout__spLinks {
  text-align: left;
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
  margin: 0 20px;
  position: relative;
  z-index: 3
}

.p-PromotionAbout__spLinks a {
  display: inline-block
}

.p-PromotionAbout__spLinks a img {
  width: 154px
}

.p-PromotionAbout__spLinks div {
  width: 154px
}

.p-PromotionCommitment__hero {
  height: 438px;
  position: relative
}

.p-PromotionCommitment__heroBackground {
  width: 90%;
  height: 438px;
  position: absolute;
  top: 0;
  left: 5%;
  background-size: cover;
  background-position: 50%
}

.p-PromotionCommitment__heroText {
  position: absolute;
  top: 115px;
  left: calc(5% - 15px);
  text-align: left;
  color: #fff;
  border-left: 30px solid #221815;
  padding: 60px 0 30px 53px
}

.p-PromotionCommitment .commitmentbnr {
  margin: 20px auto;
  max-width: 640px;
  width: 100%
}

.p-PromotionProduct__hero {
  height: 438px;
  position: relative;
  margin-bottom: 150px
}

.p-PromotionProduct__heroBackground {
  width: 90%;
  height: 438px;
  position: absolute;
  top: 0;
  left: 5%;
  background-size: cover;
  background-position: 50%
}

.p-PromotionProduct__heroText {
  position: absolute;
  top: 115px;
  left: calc(5% - 15px);
  text-align: left;
  color: #fff;
  border-left: 30px solid #221815;
  padding: 60px 0 30px 53px
}

.p-PromotionPlan__Intensive {
  padding-bottom: 120px
}

.p-PromotionPlan__Intensive hr {
  margin: 10px 0
}

.p-PromotionPlan__Intensive ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.2rem;
  display: flex
}

.p-PromotionPlan__Intensive ul>li {
  flex-basis: 50%;
  margin-bottom: 20px
}

.p-PromotionPlan__Intensive__img {
  text-align: center;
  flex-basis: 40%
}

.p-PromotionPlan__Intensive__img>img {
  width: 326px;
  max-width: 100%
}

.p-PromotionPlan__Intensive__text {
  flex-basis: 60%
}

.p-PromotionPlan__Intensive__button {
  display: block;
  margin: 60px auto 0 !important;
  text-align: center
}

.p-PromotionPlan__Intensive__button>img {
  width: 100%;
  max-width: 640px
}

.p-Promotion__counselingbnr {
  display: block
}

.p-Promotion__counselingbnr:hover {
  opacity: .8
}

.o-header__inner>img {
  width: 50vw;
  max-width: 640px
}

@media (max-width: 959px) {
  .o-header {
    height: auto
  }
  .o-header__inner {
    flex-direction: column
  }
  .o-header__inner>img {
    margin-top: 20px;
    width: 90%
  }
  .p-PromotionHero {
    background: #95252b
  }
  .p-PromotionHero__text {
    background-image: url("../img/index/hero_sp.jpg");
    background-size: 100%;
    height: 140vw;
    max-height: 960px;
    background-position: bottom
  }
  .p-PromotionHero__text__title {
    width: 100%;
    text-align: center;
    font-size: calc(26px + (100vw - 320px) / 28);
    top: auto;
    left: auto;
    bottom: 5%
  }
  .p-PromotionHero__bnr {
    position: static;
    display: block;
    text-align: center;
    margin: 0 auto;
    width: 90%;
    padding-top: 20px
  }
  .p-PromotionAbout {
    height: auto;
    margin-bottom: 0
  }
  .p-PromotionAbout__text__title {
    color: #fff;
    width: 85%
  }
  .p-PromotionAbout__text__content {
    color: #fff;
    width: 85%
  }
  .p-PromotionAbout__text>.left {
    left: 9%;
    top: calc(98px + (100vw - 320px)/9)
  }
  .p-PromotionAbout__back::after {
    content: '';
    display: block;
    clear: both;
    height: 0;
    visibility: hidden
  }
  .p-PromotionAbout__back>.left {
    width: 100%;
    position: static;
    height: calc(400px + (100vw - 320px)/2)
  }
  .p-PromotionAbout__back>.left>img {
    margin-top: calc(48px + (100vw - 320px)/9)
  }
  .p-PromotionAbout__back>.right {
    position: static;
    float: right;
    text-align: center
  }
  .p-PromotionAbout__backText {
    width: 90%
  }
  .p-PromotionAbout__productImg {
    position: static;
    max-width: none;
    width: calc(52500%/767);
    margin: 10vw auto
  }
  .p-PromotionCommitment__hero {
    text-align: center;
    height: calc(75vw + (100vw - 320px)/40)
  }
  .p-PromotionCommitment__heroBackground {
    left: auto;
    top: 0;
    width: 100%;
    height: 75vw;
    background-position: 75% 50%
  }
  .p-PromotionCommitment__heroText {
    top: 18vw;
    left: 0;
    border-left: 10px solid #221815;
    padding: calc(17px + (100vw - 320px)/32) 20% calc(17px + (100vw - 320px)/32) calc(17px + (100vw - 320px)/32)
  }
  .p-PromotionProduct__hero {
    text-align: center;
    height: calc(75vw + (100vw - 320px)/40);
    margin-bottom: 80px
  }
  .p-PromotionProduct__heroBackground {
    left: auto;
    top: 0;
    width: 100%;
    height: 75vw;
    background-position: 75% 50%
  }
  .p-PromotionProduct__heroText {
    top: 18vw;
    left: 0;
    border-left: 10px solid #221815;
    padding: calc(17px + (100vw - 320px)/32) 20% calc(17px + (100vw - 320px)/32) calc(17px + (100vw - 320px)/32)
  }
  .p-PromotionProduct .p-productEssence>.left {
    background-size: 200%
  }
  .o-footer__inner {
    padding: 30px 0 30px;
  }
}

@media (max-width: 1199px) {
  .p-PromotionPlan__Intensive ul {
    flex-direction: column
  }
}

@media (min-width: 1441px) {
  .p-PromotionHero__text__title {
    font-size: 5rem
  }
  .p-PromotionAbout__productImg {
    right: calc(25.5% - 262px)
  }
}

@media (min-width: 550px) {
  .p-PromotionAbout__spDiv {
    display: none
  }
}

#page-top {
  position: fixed;
  z-index: 20;
  bottom: 20px;
  right: 20px;
  font-size: 70%
}

#page-top a {
  background: #fff;
  text-decoration: none;
  color: #444;
  width: 60px;
  height: 60px;
  padding: 10px;
  text-align: center;
  line-height: 1;
  display: block;
  border: 1px solid #aaa;
  opacity: 0.9
}

#page-top a:hover {
  text-decoration: none;
  background: #fff;
  opacity: 0.75
}

.p-science {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 0
}

.p-scienceHeroText {
  color: #000
}

.p-scienceTopic {
  text-align: center
}

.p-scienceTopic>div {
  margin: 70px 0 96px
}

.p-scienceVersican {
  position: relative;
  padding-bottom: 120px
}

.p-scienceVersican__title {
  position: absolute;
  top: -40px;
  text-align: center;
  font-size: 2.8rem;
  width: 590px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-scienceVersican>.left {
  width: 94.5%;
  left: -94.5%;
  padding-bottom: 100px;
  background-color: #fff;
  position: relative
}

.p-scienceVersican__backText {
  position: absolute;
  top: -20px;
  right: -20px;
  z-index: 1
}

.p-scienceVersican__group {
  padding-top: 185px
}

.p-scienceVersican__images {
  width: 688px;
  max-width: 50%;
  align-self: center;
  display: flex;
  flex-direction: column
}

.p-scienceVersican__images>img {
  width: 100%
}

.p-scienceVersican__spImages {
  display: flex;
  flex-direction: column
}

.p-scienceVersican__spImages>img {
  width: 100%
}

.p-scienceVersican__text {
  width: 100%;
  flex: 1 1 auto;
  align-self: center;
  padding-left: calc(3% + (100% - 767px)/90);
  padding-right: calc(6% + (100% - 767px)/90)
}

@media (max-width: 959px) {
  .p-science {
    margin-top: calc(15px + (100vw - 320px)/40)
  }
  .p-science>.c-hero {
    height: calc(75vw + (100vw - 320px)/40)
  }
  .p-scienceSVG {
    max-width: 65vw
  }
  .p-scienceTopic {
    text-align: center;
    width: 92%;
    margin: 0 auto
  }
  .p-scienceTopic>div {
    margin: 14vw 0 20vw
  }
  .p-scienceVersican__title {
    font-size: 1.4rem;
    top: -20px;
    width: 315px;
    max-width: 85vw;
    height: 40px;
    line-height: 40px
  }
  .p-scienceVersican>.left {
    padding-bottom: 20vw
  }
  .p-scienceVersican__backText {
    width: 95%;
    top: auto;
    right: 0;
    bottom: -5px
  }
  .p-scienceVersican__group {
    padding-top: 0
  }
  .p-scienceVersican__images {
    width: 100%;
    max-width: none;
    min-height: 0%
  }
  .p-scienceVersican__text {
    padding: 40px 10% 40px 9%
  }
}

.p-shoppingComp {
  max-width: 720px
}

.p-shoppingComp__order {
  margin: 30px 0
}

.p-shoppingComp__msg {
  margin-bottom: 45px
}

.p-shoppingComp__contact {
  width: 100%;
  max-width: 980px;
  border: 1px solid #d8d8d8;
  padding: 20px 0;
  display: flex
}

.p-shoppingComp__contactWrap {
  flex: 1 1 auto;
  padding: 0 20px
}

.p-shoppingComp__contactWrap:first-child {
  border-right: 1px solid #ccc
}

.p-shoppingComp__contactWrap__name {
  font-size: 1.2rem;
  margin-bottom: 5px
}

.p-shoppingComp__contactWrap__phone {
  font-size: 1.4rem;
  margin-bottom: 5px
}

.p-shoppingComp__contactWrap__phone>i {
  font-size: 1.6rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold;
  padding-right: 4px
}

.p-shoppingComp__contactWrap__phone>span {
  font-size: 1.2rem;
  font-weight: normal
}

.p-shoppingComp__contactWrap__mail>i {
  font-size: 1.6rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold;
  padding-right: 4px
}

.p-shoppingComp__contactWrap__subtitle {
  font-size: 1.4rem;
  margin-bottom: 10px
}

.p-shoppingComp__contactWrap__address {
  font-size: 1.2rem
}

.p-shoppingComp__contactWrap__time {
  font-size: 1.2rem
}

.p-shoppingComp__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 55px;
  display: inline-block
}

.p-shoppingComp__link:hover {
  color: #313131
}

.p-shoppingComp__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-shoppingComp__btn {
  margin: 50px auto 0;
  display: block;
  cursor: pointer
}

@media (max-width: 959px) {
  .p-shoppingComp__order {
    margin: 20px 0 30px
  }
  .p-shoppingComp__msg {
    margin-bottom: 35px
  }
  .p-shoppingComp__contact {
    width: 100%;
    flex-direction: column;
    padding: 20px 15px
  }
  .p-shoppingComp__contactWrap {
    padding: 20px 0
  }
  .p-shoppingComp__contactWrap:first-child {
    padding-top: 0;
    border-right: none;
    border-bottom: 1px solid #ccc
  }
  .p-shoppingComp__contactWrap:last-child {
    padding-bottom: 0
  }
}

.p-shoppingConf__title {
  margin-bottom: 35px
}

.p-shoppingConf__info .c-myHeading4 {
  margin: 30px 0 20px
}

.p-shoppingConf__customer {
  margin-top: 20px
}

.p-shoppingConf__item {
  width: 100%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  flex-wrap: wrap;
  justify-content: space-between;
  border-bottom: 1px solid #d8d8d8
}

.p-shoppingConf__itemImage {
  width: calc(160px + (100vw - 960px)/10)
}

.p-shoppingConf__itemImage>img {
  position: relative;
  left: 40px;
  width: 80px
}

.p-shoppingConf__itemDetail {
  flex: 1 1 auto
}

.p-shoppingConf__itemName {
  flex-basis: 70%
}

.p-shoppingConf__itemName>p {
  margin-bottom: 5px
}

.p-shoppingConf__itemName_set {
  font-size: 1.2rem;
  font-weight: normal;
  padding-left: 20px
}

.p-shoppingConf__itemPrice {
  margin-left: 20px;
  flex-basis: 30%;
  font-weight: bold
}

.p-shoppingConf__itemPrice>p>span {
  font-weight: normal
}

.p-shoppingConf__itemNext {
  width: 100%;
  margin-top: 10px;
  padding: 20px;
  border: 4px solid #eee
}

.p-shoppingConf__divider {
  margin-top: 30px;
  margin-bottom: 30px
}

.p-shoppingConf__content {
  margin-top: 20px
}

.p-shoppingConf__content__coupon {
  padding: 18px 0 25px 0;
  border-bottom: 2px dotted #d8d8d8
}

.p-shoppingConf__content__couponName {
  font-size: 1.6rem;
  font-weight: bold
}

.p-shoppingConf__content__couponDiscount {
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.25;
  color: #221815;
  margin-bottom: 0
}

.p-shoppingConf__content__couponDiscount>span {
  font-size: 1.8rem;
  padding-left: 5px
}

.p-shoppingConf__content__couponCode, .p-shoppingConf__content__couponDate {
  font-size: 1.2rem
}

.p-shoppingConf__small {
  font-size: 1.2rem
}

.p-shoppingConf__bill {
  width: 100%;
  border: 1px solid #919191;
  padding: 2.5%
}

.p-shoppingConf__billFlex {
  display: flex;
  margin-bottom: 15px;
  align-items: center
}

.p-shoppingConf__billTitle {
  flex: 1 1 auto
}

.p-shoppingConf__billCoupon {
  width: 100%;
  padding: 10px 20px;
  font-size: 1.4rem;
  background-color: #f8f8f8;
  margin-bottom: 15px
}

.p-shoppingConf__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin-bottom: 8px
}

.p-shoppingConf__billPrice {
  font-weight: bold;
  font-size: 1.8rem
}

.p-shoppingConf__billTax {
  font-weight: bold;
  font-size: 1.2rem
}

.p-shoppingConf__billBox {
  margin-top: 40px;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between
}

.p-shoppingConf__billBtn {
  width: 45%
}

.p-shoppingConf__billBtn>button {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-shoppingConf__billBtn>button>i {
  font-size: 1.8rem
}

.p-shoppingConf__billBtn>a {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-shoppingConf__billBtn>a>i {
  font-size: 1.8rem
}

.p-shoppingConf__billOrder {
  width: 100%;
  margin: 0px auto 10px
}

.p-shoppingConf__billBack {
  width: 100%
}

.p-shoppingConf__attention {
  margin-bottom: 50px;
  padding: 20px;
  border: 4px solid #eee
}

.p-shoppingConf__attention .p-shopping__title {
  margin-bottom: 20px
}

.p-shoppingConf__attention p {
  margin: 10px auto 20px
}

@media (min-width: 960px) {
  .p-shoppingConf {
    max-width: 720px
  }
  .p-shoppingConf__info {
    margin-bottom: 50px
  }
  .p-shoppingConf__divider {
    opacity: 0
  }
  .p-shoppingConf__bill {
    padding: 50px 8%
  }
}

@media (max-width: 959px) {
  .p-shoppingConf__title {
    margin-bottom: 20px
  }
  .p-shoppingConf__info {
    width: 100%;
    padding-right: 0
  }
  .p-shoppingConf__info .c-myHeading4 {
    margin: 20px 0 18px
  }
  .p-shoppingConf__block {
    margin-top: 30px;
    padding-top: 20px;
    position: relative
  }
  .p-shoppingConf__block::before {
    content: "";
    width: 120%;
    height: 3px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shoppingConf__content {
    margin-top: 20px;
    min-height: 20px
  }
  .p-shoppingConf__item {
    justify-content: normal
  }
  .p-shoppingConf__itemImage {
    width: 20%
  }
  .p-shoppingConf__itemImage>img {
    width: 100%;
    left: 0
  }
  .p-shoppingConf__itemDetail {
    width: 80%;
    padding-left: 10px;
    flex: inherit
  }
  .p-shoppingConf__itemName {
    flex: 1 1 auto
  }
  .p-shoppingConf__itemPrice {
    flex: 1 1 auto;
    margin-left: 0
  }
  .p-shoppingConf__itemNext {
    margin-top: 0;
    font-size: 1.2rem
  }
  .p-shoppingConf__attention {
    width: 100%;
    margin-top: 30px;
    margin-bottom: 0;
    padding: 25px 0 0;
    border: none;
    position: relative
  }
  .p-shoppingConf__attention::before {
    content: "";
    width: 120%;
    height: 3px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shoppingConf__bill {
    margin-top: 25px;
    padding: 25px 0;
    border: none;
    position: relative
  }
  .p-shoppingConf__bill::before {
    content: "";
    width: 120%;
    height: 6px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shoppingConf__billBox {
    margin-top: 0;
    flex-direction: column
  }
  .p-shoppingConf__billBtn {
    width: 100%;
    margin: 20px auto 0
  }
  .p-shoppingConf__billCoupon {
    padding: 10px
  }
}

.p-shoppingEdit__heading {
  margin-bottom: 20px
}

.p-shoppingEdit__flex>* {
  padding: 30px 20px 0
}

.p-shoppingEdit__flex>*:first-child {
  padding-left: 0
}

.p-shoppingEdit__flex>*:last-child {
  padding-right: 0
}

.p-shoppingEdit__title {
  width: 200px;
  font-size: 1.4rem;
  text-align: right;
  position: relative;
  top: 13px
}

.p-shoppingEdit__input {
  flex: 1 1 auto
}

.p-shoppingEdit__hr {
  padding-left: 220px
}

.p-shoppingEdit__hr>hr {
  margin-top: 30px
}

.p-shoppingEdit__zipBtn {
  width: 180px
}

.p-shoppingEdit__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-shoppingEdit__container {
    max-width: 960px;
    margin: 0
  }
  .p-shoppingEdit__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-shoppingEdit__heading {
    margin-bottom: 20px
  }
  .p-shoppingEdit__flex {
    margin-top: 10px
  }
  .p-shoppingEdit__flex>* {
    padding: 0 0 10px
  }
  .p-shoppingEdit__flex.no-title {
    margin-top: 0
  }
  .p-shoppingEdit__title {
    text-align: left;
    font-weight: bold;
    width: 100%;
    position: static
  }
  .p-shoppingEdit__title.no-top {
    padding: 0
  }
  .p-shoppingEdit__zipInput {
    display: flex
  }
  .p-shoppingEdit__zipIcon {
    width: 20px;
    line-height: 48px;
    font-size: 1.6rem
  }
  .p-shoppingEdit__zipSelect {
    flex: 1 1 auto;
    margin-right: 20px
  }
  .p-shoppingEdit__zipBtn {
    width: 120px;
    height: 48px;
    line-height: 46px;
    font-size: 1.2rem
  }
  .p-shoppingEdit__save {
    margin: 25px 0 40px
  }
}

.p-shoppingErr__title {
  color: #A82228
}

.p-shoppingErr__msg {
  margin-top: 30px
}

.p-shoppingErr__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 35px;
  display: inline-block
}

.p-shoppingErr__link:hover {
  color: #313131
}

.p-shoppingErr__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-shoppingErr__btn {
  margin-top: 50px
}

@media (max-width: 959px) {
  .p-shoppingErr__msg {
    margin-top: 20px
  }
}

.p-shoppingShip__heading {
  margin-bottom: 30px
}

.p-shoppingShip__item {
  width: 80%;
  max-width: 960px;
  padding: 30px 0;
  border-bottom: 1px solid #d8d8d8;
  align-items: center
}

.p-shoppingShip__item__radio>label {
  height: 18px
}

.p-shoppingShip__item__info {
  flex: 1 1 auto;
  padding-left: 20px
}

.p-shoppingShip__item__btn {
  width: 180px;
  height: 50px;
  line-height: 48px
}

.p-shoppingShip__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-shoppingShip__item__radio {
    width: 120px;
    text-align: center
  }
  .p-shoppingShip__btns {
    padding-left: 220px
  }
  .p-shoppingShip__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-shoppingShip__heading {
    margin-bottom: 20px
  }
  .p-shoppingShip__item {
    width: 100%
  }
  .p-shoppingShip__item__btn {
    width: 68px;
    height: 44px;
    line-height: 42px
  }
  .p-shoppingShip__save {
    margin: 50px 0 40px
  }
}

.p-shopping__subtitle {
  padding: 10px 2%;
  background: #fff;
  border: 4px solid rgba(168, 34, 40, 0.2);
  box-sizing: border-box;
  margin: 20px auto 10px;
  font-size: 1.4rem;
  color: #221815
}

.p-shopping__subtitle__last {
  margin-bottom: 25px
}

.p-shopping__info .c-myHeading4 {
  margin: 30px 0 20px
}

.p-shopping__customer {
  margin-top: 10px
}

.p-shopping__item {
  width: 100%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: top;
  border-bottom: 1px solid #d8d8d8
}

.p-shopping__itemImage {
  width: calc(160px + (100vw - 960px)/10)
}

.p-shopping__itemImage>img {
  position: relative;
  left: 40px;
  width: 80px
}

.p-shopping__itemDetail {
  flex: 1 1 auto
}

.p-shopping__itemName {
  flex-basis: 70%
}

.p-shopping__itemName>p {
  margin-bottom: 5px
}

.p-shopping__itemPrice {
  margin-left: 40px;
  flex-basis: 30%
}

.p-shopping__itemPrice>p>span {
  padding-left: 10px
}

.p-shopping__itemNext {
  width: 100%;
  margin-top: 10px;
  padding: 20px;
  border: 4px solid #eee
}

.p-shopping__divider {
  margin-top: 30px;
  margin-bottom: 30px
}

.p-shopping__addressBtn {
  width: 180px;
  height: 50px;
  line-height: 48px
}

.p-shopping__contact {
  margin-top: 30px
}

.p-shopping__radio {
  margin: 30px 0 10px
}

.p-shopping__grey {
  margin-top: 30px;
  background-color: #f4f4f4;
  padding: 30px
}

.p-shopping__grey__bottom {
  margin-bottom: 30px
}

.p-shopping__grey__content {
  flex-basis: 70%
}

.p-shopping__grey__number {
  border: 1px solid #d8d8d8;
  background-color: #fff;
  padding: 10px;
  font-weight: bold;
  margin-top: 20px
}

.p-shopping__grey__hr {
  margin: 30px 10% 30px 30%
}

.p-shopping__grey__sec {
  font-size: 1.2rem;
  margin-top: 10px
}

.p-shopping__grey__date {
  flex-basis: 45%
}

.p-shopping__grey__date>label {
  width: calc(100% - 18px);
  height: 50px
}

.p-shopping__grey__slash {
  flex-basis: 10%;
  text-align: center
}

.p-shopping__bill {
  width: 100%;
  border: 1px solid #919191;
  padding: 2.5%
}

.p-shopping__billFlex {
  display: flex;
  margin-bottom: 15px
}

.p-shopping__billTitle {
  flex: 1 1 auto
}

.p-shopping__billCoupon {
  width: 100%;
  padding: 10px 20px;
  font-size: 1.4rem;
  background-color: #f8f8f8;
  margin-bottom: 15px;
  position: relative
}

.p-shopping__billCoupon__close {
  background-image: url("../img/mypage/close.png");
  background-size: cover;
  position: absolute;
  top: 16px;
  right: 12px;
  width: 12px;
  height: 12px;
  cursor: pointer
}

.p-shopping__billCoupon__close:hover {
  transform: rotate(90deg);
  transition: all .1s
}

.p-shopping__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin-bottom: 8px
}

.p-shopping__billPrice {
  font-weight: bold;
  font-size: 1.8rem
}

.p-shopping__billTax {
  font-weight: bold;
  font-size: 1.2rem
}

.p-shopping__billBox {
  margin-top: 40px;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between
}

.p-shopping__billBtn {
  width: 45%
}

.p-shopping__billBtn>button {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-shopping__billBtn>button>i {
  font-size: 1.8rem
}

.p-shopping__billBtn>a {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-shopping__billBtn>a>i {
  font-size: 1.8rem
}

.p-shopping__billOrder {
  width: 100%;
  margin: 0px auto 10px
}

.p-shopping__billBack {
  width: 100%
}

.p-shopping__select__err {
  flex-basis: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-shopping__next ul {
  margin-left: 20px
}

.p-shopping__nextDetail {
  margin-bottom: 10px
}

.p-shopping__content {
  margin-top: 10px
}

@media (min-width: 960px) {
  .p-shopping {
    max-width: 720px
  }
  .p-shopping__info {
    padding-bottom: 30px;
    margin-bottom: 30px;
    border-bottom: 1px solid #e5e5e5
  }
  .p-shopping__divider {
    opacity: 0
  }
  .p-shopping__address {
    margin-bottom: 60px
  }
  .p-shopping__selectColumn {
    align-items: center;
    margin-top: 30px;
    flex-wrap: wrap
  }
  .p-shopping__selectTitle {
    flex-basis: 27%;
    padding-right: 40px;
    text-align: right
  }
  .p-shopping__select {
    flex-basis: 48%
  }
  .p-shopping__select>label {
    height: 50px
  }
  .p-shopping__select>input {
    height: 50px
  }
  .p-shopping__delivery .p-shopping__select__err {
    padding-left: 27%
  }
  .p-shopping__selectBtn {
    flex-basis: 25%;
    text-align: right;
    padding-left: 15px
  }
  .p-shopping__selectBtn>button {
    width: 180px;
    height: 50px;
    line-height: 46px
  }
  .p-shopping__grey__number {
    text-align: center;
    max-width: 400px
  }
  .p-shopping__grey__title {
    padding-top: 13px;
    flex-basis: 30%;
    padding-right: 20px;
    text-align: right
  }
  .p-shopping__grey__content>.c-mySelectBox, .p-shopping__grey__content>input {
    max-width: 400px;
    height: 50px
  }
  .p-shopping__grey__flex {
    width: 100%;
    max-width: 400px
  }
  .p-shopping__bill {
    padding: 50px 8%
  }
  .p-shopping__Coupon {
    align-items: flex-start
  }
}

@media (max-width: 959px) {
  .p-shopping__subtitle {
    font-size: 1.4rem;
    margin: 20px 0 10px
  }
  .p-shopping__subtitle__last {
    margin-bottom: 20px
  }
  .p-shopping__info {
    width: 100%;
    padding-right: 0
  }
  .p-shopping__info .c-myHeading4 {
    margin: 20px 0 18px
  }
  .p-shopping__block {
    margin-top: 30px;
    padding-top: 20px;
    position: relative
  }
  .p-shopping__block::before {
    content: "";
    width: 120%;
    height: 2px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shopping__item {
    justify-content: normal
  }
  .p-shopping__itemImage {
    width: 20%
  }
  .p-shopping__itemImage>img {
    width: 100%;
    left: 0
  }
  .p-shopping__itemName {
    flex: 1 1 auto
  }
  .p-shopping__itemDetail {
    width: 80%;
    padding-left: 10px;
    flex: inherit
  }
  .p-shopping__itemPrice {
    flex: 1 1 auto;
    margin-left: 0
  }
  .p-shopping__itemPrice>p {
    margin-bottom: 5px
  }
  .p-shopping__itemPrice>p>span {
    padding-left: 0
  }
  .p-shopping__itemNext {
    font-size: 1.2rem
  }
  .p-shopping__addressBtn {
    width: 100%;
    margin-top: 15px
  }
  .p-shopping__selectColumn {
    margin-top: 20px
  }
  .p-shopping__select {
    margin-top: 5px
  }
  .p-shopping__select>label {
    height: 50px
  }
  .p-shopping__selectBtn {
    margin-top: 20px
  }
  .p-shopping__delivery .p-shopping__selectBtn {
    margin-top: 0
  }
  .p-shopping__selectBtn>button {
    height: 50px;
    line-height: 48px
  }
  .p-shopping__contact {
    margin-top: 20px
  }
  .p-shopping__radio {
    margin: 20px 0 10px
  }
  .p-shopping__grey {
    margin-top: 20px;
    padding: 20px
  }
  .p-shopping__grey__content {
    flex: 1 1 auto
  }
  .p-shopping__grey__title {
    margin-bottom: 10px
  }
  .p-shopping__grey__bottom {
    margin-bottom: 20px
  }
  .p-shopping__grey__number {
    margin-top: 10px
  }
  .p-shopping__grey__hr {
    margin: 20px 0
  }
  .p-shopping__grey__date {
    flex-basis: auto;
    width: 100px
  }
  .p-shopping__grey__date>.c-mySelectBox {
    width: 80px;
    height: 50px
  }
  .p-shopping__grey__slash {
    flex-basis: unset;
    width: 32px
  }
  .p-shopping__bill {
    margin-top: 25px;
    padding: 25px 0;
    border: none;
    position: relative
  }
  .p-shopping__bill::before {
    content: "";
    width: 120%;
    height: 6px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shopping__billBox {
    margin-top: 0;
    flex-direction: column
  }
  .p-shopping__billBtn {
    width: 100%;
    margin: 20px auto 0
  }
  .p-shopping__billCoupon {
    padding: 10px
  }
}

.p-sitemap__title {
  margin-bottom: 30px
}

.p-sitemap__link {
  margin-top: 5px
}

.p-sitemap__link>a {
  text-decoration: underline;
  font-size: 1.4rem;
  color: #313131
}

@media (min-width: 960px) {
  .p-sitemap__link>a:hover {
    color: #A82228
  }
}

@media (max-width: 959px) {
  .p-sitemap__title {
    margin-bottom: 25px
  }
  .p-sitemap__link>a {
    font-size: 1.2rem
  }
}

.c-accordion {
  position: relative;
  margin: 30px 0
}

.c-accordion__header {
  font-size: 1.8rem;
  display: block;
  position: relative;
  padding: 20px 30px;
  color: #fff;
  background-color: #221815;
  cursor: pointer
}

.c-accordion__header:after {
  content: 'expand_more';
  font-family: "Material Icons";
  font-size: 3rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 10px
}

.c-accordion__header.open:after {
  -webkit-transform: rotate(180deg);
  transform: translateY(-50%) rotate(180deg)
}

.c-accordion__contents {
  display: none
}

.c-accordion__contents>dl>dt {
  background-color: #faf4f4;
  padding: 20px 40px;
  font-size: 1.6rem;
  display: flex
}

.c-accordion__contents>dl>dt>span {
  font-size: 1.8rem;
  color: #221815;
  padding-right: 5px;
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif
}

.c-accordion__contents>dl>dd {
  background-color: #fff;
  padding: 20px 40px 20px 80px;
  border-bottom: 1px solid #ccc;
  font-size: 1.3rem;
  line-height: 1.6;
  position: relative
}

.c-accordion__contents>dl>dd:last-child {
  border-bottom: none
}

.c-accordion__contents>dl>dd:before {
  position: absolute;
  top: 15px;
  left: 55px;
  font-size: 2rem;
  color: #221815;
  content: 'arrow_right';
  font-family: "Material Icons"
}

.c-accordion__contents>dl>dd ul {
  list-style-type: circle;
  margin-left: 20px
}

.c-accordion__contents>dl>dd>a {
  color: #221815
}

.c-accordion__contents>dl>dd>a:hover {
  text-decoration: underline
}

@media (max-width: 959px) {
  .c-accordion {
    margin: 20px auto
  }
  .c-accordion__header {
    padding: 20px 10px
  }
  .c-accordion__contents>dl>dt {
    font-size: 1.8rem;
    padding: 20px 10px
  }
  .c-accordion__contents>dl>dd {
    font-size: 1.6rem;
    padding: 20px 10px 20px 40px
  }
  .c-accordion__contents>dl>dd:before {
    top: 14px;
    left: 10px;
    font-size: 2.5rem
  }
}

.c-heroFade {
  opacity: 0;
  margin-top: 50px
}

.c-bannerFade {
  opacity: 0;
  margin-top: 50px
}

.c-fadeText {
  padding-top: 20px;
  opacity: 0
}

.js-fadeUp {
  opacity: 1;
  margin-top: 0;
  transition: all 1.5s cubic-bezier(0.35, 1, 0.45, 1) 0s, transform 1.5s cubic-bezier(0.35, 1, 0.45, 1) 0s
}

.js-fadeUpText {
  opacity: 1;
  padding-top: 0;
  transition-duration: 2s;
  transition-delay: 1s;
  transition-property: opacity, padding-top
}

.c-fadeUp {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1.5s, transform 1.5s
}

.c-fadeUp.is-inview {
  opacity: 1;
  transform: translateY(0);
  transition-delay: .5s
}

@media (max-width: 959px) {
  .c-fadeUp {
    transform: translateY(5vw)
  }
}

@media (max-width: 959px) {
  .c-fixed {
    position: fixed;
    top: 0;
    z-index: 50;
    padding: 10px 0 !important;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 5px 0px;
    -webkit-box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 5px 0px;
    -moz-box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 5px 0px;
    overflow: hidden
  }
  .c-fixed>.o-header__inner {
    align-items: baseline
  }
  .c-fixed>.o-header__inner>h1 {
    margin: 0 0 0 10px
  }
  .c-fixed>.o-header__inner>h1>.c-siteLogo {
    width: 74px;
    height: 40px;
    transition: 0.2s
  }
  .c-fixed>.c-headerIcon {
    top: 0;
    right: 70px;
    flex-direction: row;
    width: 120px;
    transition: 0.2s
  }
  .c-fixed>.c-headerIcon>a {
    padding: 6px 0
  }
}

.c-modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100
}

.c-modal__bg {
  background: rgba(0, 0, 0, 0.35);
  height: 100vh;
  position: absolute;
  width: 100%
}

.c-modal__content {
  background: #fff;
  padding: 25px 65px 35px;
  position: absolute;
  width: 500px;
  max-width: calc(100vw - 60px);
  min-width: 260px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%)
}

.c-modal__close {
  background-image: url(../img/mypage/close.png);
  background-size: cover;
  position: absolute;
  top: 20px;
  right: 20px;
  width: 16px;
  height: 16px;
  cursor: pointer
}

@media (max-width: 959px) {
  .c-modal__content {
    padding: 50px 30px 25px
  }
}

.c-pagetop {
  position: fixed;
  z-index: 20;
  bottom: 20px;
  right: 20px;
  font-size: 70%
}

.c-pagetop>a {
  background: #222;
  text-decoration: none;
  color: #fff;
  width: 50px;
  height: 50px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: space-around;
  border-radius: 50%
}

.c-pagetop>a:hover {
  text-decoration: none;
  background: #333;
  opacity: 0.75
}

.c-move .js-insertSection__left {
  transition: left 1.5s;
  left: 0
}

.c-move .js-insertSection__right {
  transition: right 1.5s;
  right: 0
}


.more_btn{
  text-decoration: none;
  color: #fff;
  /* font-family: eb-garamond, serif; */
  font-size: 13px;
  font-weight: 500;
  background: #ddd;
}
.more_btn-Text{
  position: relative;
  z-index: 1;
  letter-spacing: .08em;
  font-weight: 500;
  padding: 10px;
  /* border: 1px solid #ddd; */
  background: #221815;
  border-radius: 50px;
}

.more_btn-Text:before{
  font-family: 'Font Awesome 6 pro';
  content: "\f178";
/*   font-size: px; */
  padding-right: 10px;
}


.more_btn-Text:after{
  content: '';
  position: absolute;
  left: 0;
  bottom: -10px;/*テキストからの距離*/
  width: 0%;/*初期状態では下線非表示*/
  height: 1px;/*下線の高さ*/
  background: #888;/*下線の色*/
  z-index: -1;
  transition: all 0.4s;/*アニメーション速度*/
}
.more_btn:hover .more_btn-Text:after{
  width: 100%;/*hover時に表示*/
}



   /* ======== table.tableOther ======== */
   table.company {border-collapse: collapse;text-align: left;font-size: 15px;letter-spacing:1px;line-height:2;width:100%;}
   table.company tr { }
   table.company th {width:25%;padding: 24px;vertical-align: 0;border: #ddd 1px solid;border-right:#ddd 1px dashed;border-right: #ddd 1px solid;}
   table.company td {padding:22px;vertical-align: 0;border: #ddd 1px solid; border-left:none;}
   table.company td .linkArea {margin-top:10px;text-align:left;}
   table.company td .linkArea a.btn {margin:0;}

   table.company td a{color:#000}

   @media only screen and (max-width: 950px) {
   table.company th {width:30%;padding:20px;}
   table.company td {padding:20px;}
   }

   @media only screen and (max-width: 800px) {
   table.company { font-size:13px;}
   }
   @media only screen and (max-width: 738px) {
     table.company {/* font-size:12px; */}
   }
   @media only screen and (max-width: 414px) {
   table.company th {width:30%;padding:15px;}
   table.company td {padding:15px;}
   }


   /* ======== table.tableOther ======== */
   table.company {border-collapse: collapse;text-align: left;font-size: 15px;letter-spacing:1px;line-height:2;width:100%;}
   table.company tr { }
   table.company th {width:25%;padding: 24px;vertical-align: 0;/* border: #ddd 1px solid; */border-right:#ddd 1px dashed;border-right: #ddd 1px solid;}
   table.company td {padding:22px;vertical-align: 0;border: #ddd 1px solid; border-left:none;}
   table.company td .linkArea {margin-top:10px;text-align:left;}
   table.company td .linkArea a.btn {margin:0;}

   /* --- #map_canvas --- */
   #map_canvas { width:100%; margin-top:70px; height:400px;position: relative; z-index: 1; border: #ededed 1px solid;}



   @media only screen and (max-width: 950px) {
   table.company th {width:30%;padding:20px;}
   table.company td {padding:20px;}
   }

   @media only screen and (max-width: 800px) {
   table.company { font-size:13px;}
   }
   @media only screen and (max-width: 738px) {
     #outline .imgArea {/* float:none; */width:100%;display: block;}
     #outline .txtArea {float:none;width:100%;/* margin-top:25px; */}
     table.company {/* font-size:12px; */}
   /*	#map_canvas { display:none; }*/
   }
   @media only screen and (max-width: 414px) {
   table.company th {width:30%;padding:15px;}
   table.company td {padding:15px;}
   }



/* --------------------------------------------------------------

----------------------------------------------------------------*/
/* views */
.spView,
.spViewInb,
.tbView {
  display: none !important;
}
@media only screen and (max-width:991px) {
  .tbView {
    display: block !important;
  }
}
@media only screen and (max-width:768px) {
  .spView {
    display: block !important;
  }
  .spViewInb {
    display: inline-block !important;
  }
  .pcView {
    display: none !important;
  }
}


   .como_inner {
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
  }

  .como_box {
    margin-top: 60px;
    border: 1px solid #d7d7d7 ;
    padding:30px 20px;
  }

  .como_title {
    position: relative;
    font-size: 26px;
    letter-spacing: 0.1em;
    font-weight: 100;
    padding-bottom: 20px;
    padding-left: 10px;
    border-bottom: 1px solid #d7d7d7 ;
  }



  .como_txt {
    font-size: 17px;
  }


  .label_title::after {
    content: 'about';
    position: absolute;
    right: 10px;
    font-size: 18px;
    padding: 4px 20px;
    border-radius: 30px;
    background-color: #000000;
    color: #fff;
  }


  .como_flex {
    display: flex;
    padding: 0 10px;
    margin-top: 30px;
    margin-bottom: 30px;
  }

  .como_flex_img {
    width: 30%;
  }

  .como_flex_text {
    width: 66%;
    margin-left: 40px;
  }

  .como_flex_title {
    font-size: 20px;
    line-height: 1.6;
    letter-spacing: 0.05em;
    font-weight: 100;
  }

  .como_flex_menu {
    margin-top: 20px;
    font-weight: 100;
    line-height: 2.5;
    font-size: 17px;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .menu_text {
    font-weight: 100;
    line-height: 1.7;
    font-size: 16px;
  }

  .como_flex_menu dt {
    width: 30px;
    text-align: left;
    color: #333;
  }

  .como_flex_menu dd {
    width: calc(100% - 40px);
    text-align: left;
    padding-left:1em;
    text-indent:-1em;
  }

  .como_link {
    margin-top: 10px;
    text-align: right;
  }

  .como_btn {
    position: relative;
    display: inline-block;
    min-width: 280px;
    background-color: #000000;
    padding: 12px 10px 12px 24px;
    line-height: 1.4;
    letter-spacing: 0.1em;
    font-size: 16px;
    color: #fff;
    text-align: left;
    margin: 0 10px;
    transition: all .5s;
    text-decoration: none;
  }

  /*--- 矢印 ---*/
  .como_btn::before{
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px;
    width: 34px;
    height: 1px;
    background:#fff;
    transition: all .5s;
  }
  .como_btn::after{
    content: '';
    position: absolute;
    top: 40%;
    right: 31px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    transition: all .5s;
  }
  .como_btn:hover {
    opacity: .8;
    color: #fff !important;
  }
  .como_btn:hover::before {
    right: 23px;
  }
  .como_btn:hover::after {
    right: 24px;
  }

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

    .como_inner {
      padding: 0;
    }

    .como_box {
      margin-top: 30px;
      padding: 20px;
    }

    .como_title {
      position: relative;
      font-size: 20px;
      padding-bottom: 14px;
      padding-left: 0;
    }

    .label_title::after {
      right: -14px;
      top: 0;
      font-size: 14px;
    }

    .como_flex {
      display: block;
      padding: 0 ;
      margin-top: 20px;
    }

    .como_flex_img {
      width: 100%;
    }

    .como_flex_text {
      width: 100%;
      margin-left: 0;
    }

    .como_flex_title {
      font-size: 16px;
      margin-top: 10px;
    }

    .como_flex_menu {
      margin-top: 10px;
      line-height: 1.7;
      font-size: 16px;
    }

    .como_flex_menu dt {
      width: 100%;
      text-align: left;
      color: #333;
    }

    .como_flex_menu dd {
      width: 100%;
      text-align: left;
    }

    .como_link {
      margin-top: 10px;
      text-align: center;
    }

    .como_btn {
      position: relative;
      display: inline-block;
      min-width: 280px;
      background-color: #185e7d;
      padding: 12px 10px 12px 24px;
      line-height: 1.4;
      letter-spacing: 0.1em;
      font-size: 16px;
      color: #fff;
      text-align: left;
      margin: 0 10px;
    }

    /*--- 矢印 ---*/
    .como_btn::before{
      content: '';
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 30px;
      width: 34px;
      height: 1px;
      background:#fff;
      transition: all .5s;
    }
    .como_btn::after{
      content: '';
      position: absolute;
      top: 40%;
      right: 31px;
      width: 10px;
      height: 10px;
      border-top: 1px solid #fff;
      border-right: 1px solid #fff;
      transform: rotate(45deg);
      transition: all .5s;
    }
    .como_btn:hover::before {
      right: 23px;
    }
    .como_btn:hover::after {
      right: 24px;
    }
  }
/*
.contents_box{display:flex;flex-wrap: wrap;width: 98%;margin: 0 auto;max-width: 1100px;justify-content: space-between;padding: 20px;}
.con_box{width:31%;border: 1px solid #ddd;}
.con_box .con_titile{font-size:18px;} */




.noa-mission {
  margin-top: 80px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  width: 1100px;
  margin: 50px auto;
  padding: 20px;
}
.noa-mission-txt {
  padding: 0px 0;
  text-align: center;
  color: #2f4f4f;
  width: 31%;
  /* border-right: 1px solid #dcdcdc; */
  border: 1px solid #ddd;
  background: #fff;
  align-self: stretch;
}
.noa-mission-txt:last-child {
/*   border-right: none; */
}
.noa-mission-txt p {
  padding-bottom: 10px;
  font-size: 1.5rem;
  font-weight: 500;
  padding: 0 20px;
}

.noa-mission-txt span {
  display: block;
  font-size: 50px;
  padding-bottom: 10px;
  border-bottom: 1px solid #ddd;
}
.sp-only {
  display: none;
}

/* --- Section Noa SP -- */
@media(max-width:499px){
  .noa {
      margin-top: 30px;
      margin-bottom: 30px;
  }
  .noa-ttl span {
      display: block;
      line-height: 1.1;
  }
  .main-ttl {
      font-size: 60px;
  }
  .noa-mission {
      margin-top: 20px;
  }
  .noa-mission-txt {
      width: 100%;
      border-right: none;
  }
  .noa-mission-txt:last-child {
      border-bottom: none;
  }
  .noa-mission-txt p {
      display: inline;
      font-size: 1.2rem;
      vertical-align: baseline;
  }
  .noa-mission-txt span {
      padding-bottom: 0;
      padding-right: 10px;
      display: inline;
      font-size: 50px;
      vertical-align: baseline;
  }
  .sp-only {
      display: block;
      width: 75%;
      border-top: 1px solid #dcdcdc;
  }

}



/* CSS Document */
/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */

/* Reset box-model and set borders */
/* ============================================ */

*,
::before,
::after {
box-sizing: border-box;
border-style: solid;
border-width: 0;
}

/* Document */
/* ============================================ */

/**
* 1. Correct the line height in all browsers.
* 2. Prevent adjustments of font size after orientation changes in iOS.
* 3. Remove gray overlay on links for iOS.
*/

html {
line-height: 1.15; /* 1 */
-webkit-text-size-adjust: 100%; /* 2 */
-webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */

/**
* Remove the margin in all browsers.
*/

body {
margin: 0;
}

/**
* Render the `main` element consistently in IE.
*/

main {
display: block;
}

/* Vertical rhythm */
/* ============================================ */

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl,
menu {
/* margin: 0; */
}

/* Headings */
/* ============================================ */

h1,
h2,
h3,
h4,
h5,
h6 {
font-size: inherit;
line-height: inherit;
font-weight: inherit;
margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */

ul,
ol {
margin: 0;
padding: 0;
list-style: none;
}

/* Lists (definition) */
/* ============================================ */

dt {
font-weight: inherit;
}

dd {
margin-left: 0;
}

/* Grouping content */
/* ============================================ */

/**
* 1. Add the correct box sizing in Firefox.
* 2. Show the overflow in Edge and IE.
*/

hr {
box-sizing: content-box; /* 1 */
height: 0; /* 1 */
overflow: visible; /* 2 */
border-top-width: 1px;
margin: 0;
clear: both;
color: inherit;
}

/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/

pre {
font-family: monospace, monospace; /* 1 */
font-size: inherit; /* 2 */
}

address {
font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */

/**
* Remove the gray background on active links in IE 10.
*/

a {
background-color: transparent;
text-decoration: none;
color: inherit;
}

/**
* 1. Remove the bottom border in Chrome 57-
* 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
*/

abbr[title] {
text-decoration: underline; /* 2 */
text-decoration: underline dotted; /* 2 */
}

/**
* Add the correct font weight in Chrome, Edge, and Safari.
*/

b,
strong {
font-weight: bolder;
}

/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp {
font-family: monospace, monospace; /* 1 */
font-size: inherit; /* 2 */
}

/**
* Add the correct font size in all browsers.
*/

small {
font-size: 80%;
}

/**
* Prevent `sub` and `sup` elements from affecting the line height in
* all browsers.
*/

sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}

sub {
bottom: -0.25em;
}

sup {
top: -0.5em;
}

/* Embedded content */
/* ============================================ */

/**
* Prevent vertical alignment issues.
*/

img,
embed,
object,
iframe {
vertical-align: bottom;
}

/* Forms */
/* ============================================ */

/**
* Reset form fields to make them styleable
*/

button,
input,
optgroup,
select,
textarea {
-webkit-appearance: none;
appearance: none;
vertical-align: middle;
color: inherit;
font: inherit;
background: transparent;
padding: 0;
margin: 0;
outline: 0;
border-radius: 0;
text-align: inherit;
}

/**
* Reset radio and checkbox appearance to preserve their look in iOS.
*/

[type="checkbox"] {
-webkit-appearance: checkbox;
appearance: checkbox;
}

[type="radio"] {
-webkit-appearance: radio;
appearance: radio;
}

/**
* Show the overflow in IE.
* 1. Show the overflow in Edge.
*/

button,
input {
/* 1 */
overflow: visible;
}

/**
* Remove the inheritance of text transform in Edge, Firefox, and IE.
* 1. Remove the inheritance of text transform in Firefox.
*/

button,
select {
/* 1 */
text-transform: none;
}

/**
* Correct the inability to style clickable types in iOS and Safari.
*/

button,
[type="button"],
[type="reset"],
[type="submit"] {
cursor: pointer;
-webkit-appearance: none;
appearance: none;
}

button[disabled],
[type="button"][disabled],
[type="reset"][disabled],
[type="submit"][disabled] {
cursor: default;
}

/**
* Remove the inner border and padding in Firefox.
*/

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
border-style: none;
padding: 0;
}

/**
* Restore the focus styles unset by the previous rule.
*/

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
outline: 1px dotted ButtonText;
}

/**
* Remove arrow in IE10 & IE11
*/

select::-ms-expand {
display: none;
}

/**
* Remove padding
*/

option {
padding: 0;
}

/**
* Reset to invisible
*/

fieldset {
margin: 0;
padding: 0;
min-width: 0;
}




details {
display: block;
}

/*
* Add the correct display in all browsers.
*/

summary {
display: list-item;
}

/*
* Remove outline for editable content.
*/

[contenteditable] {
outline: none;
}



.pickup {
    padding: 30px 0px;
    background-color: #f1efef;
    position: relative;
}


.pickup .wrap{
	max-width:1200px;
	margin:0 auto;
	width: 100%;
}




 .pickup.mt {
    margin-top: 30px;
}

 .pickup .img_pickup {
    width: 100px;
    margin-left: -50px;
    margin-bottom: 20px;
}

 .pickup .title {
    font-size: 1.4rem;
    font-weight: bold;
    margin-bottom: 20px;
    line-height: 1.5;
    display: flex;
    align-items: center;
}

 .pickup .title:before {
  font-family: 'FontAwesome';
  content: "\f097";
  padding-right: 5px;
  color: #6b0948;
  font-size: 1.2em;
}





 .pickup .title span {
    font-size: 0.8rem;
    font-size: 1.2rem;
    display: block;
    margin-left: 10px;
}

@media screen and (max-width: 1024px) {
     .pickup .title {
        flex-direction: column;
    }
}


 .pickup .title .underline {
    font-weight: bold;
}

 .pickup .title .underline::before {
    height: 10px;
}

 .pickup .txt {
    /* background: #fff; */
    padding: 20px;
    border-radius: 1em;
    margin-top: 1em;
    margin-bottom: 1em;
    /* max-width: 1000px; */
    /* width: 95%; */
    width: 100%;
    margin: 0 auto;
    text-align: center;
}

 .pickup .plan_title {
    font-size: 25px;
    line-height: 2;
    margin: 0;
    /* margin-bottom: 20px; */
    font-weight: 600;
    color: #17546b;
    }

 .pickup .name {
    font-size: 25px;
    line-height: 2;
    margin-bottom: 20px;
    font-weight: 600;
    }

 .pickup .name span{
 background:#ddd;
 border-radius:10em;
 background: #17546b;
 color:#fff;
 font-size:18px;
 padding:5px 10px;
}



 .pickup .cap {
    font-size: 16px;
    line-height: 2;
    margin-bottom: 0;
    padding: 0 20px;
    font-weight: 600;
    text-align: center;
    }

 .pickup .phone_num,
 .pickup .fax_num {
    font-size: 40px;
    /* line-height: 2; */
    padding: 10px 20px 0;
    /* border: 1px solid #ddd; */
    /* border-radius: 500px; */
    margin-bottom: 20px;
    /* display: block; */
}

 .pickup .phone_num:before {
    font-family: 'FontAwesome';
    content: "\f095";
    padding-right: 5px;
    color: #6b0948;
    font-size: 0.8em;
}

 .pickup .fax_num:before {
    font-family: 'FontAwesome';
    content: "\f1ac";
    padding-right: 5px;
    color: #666666;
    font-size: 0.7em;
line-height: 1;}


@media screen and (max-width: 500px) {
 .pickup .phone_num,
 .pickup .fax_num{
   font-size: 28px;
 }

 .pickup .phone_num:before,
 .pickup .fax_num:before{
   font-size: 0.8em;}
 .pickup .cap {
 text-align: left;
 }
}





/* Table */
/* ============================================ */

table {
border-collapse: collapse;
border-spacing: 0;
}

caption {
text-align: left;
}

td,
th {
vertical-align: top;
padding: 0;
}

th {
text-align: left;
font-weight: bold;
}

/* Misc */
/* ============================================ */

/**
* Add the correct display in IE 10+.
*/

template {
display: none;
}

/**
* Add the correct display in IE 10.
*/

[hidden] {
display: none;
}



#detail{
padding-top: 0;
overflow: hidden;
}

#detailHeader{
padding-top: 2em
}

#detailTitle{
color: #555;
}
#detailTitle h2{
display: flex;
font-size: 1.75em;
font-weight: 500;
letter-spacing: 0.1em;
line-height: 1.5em;
}
#detailTitle h2 i{
align-items: flex-start;
margin-right: 0.5em;
transform: translate(0,0.25em);
}

#detailStatus{}
#detailStatus dl{
display: flex;
padding: 1em 0;
line-height: 1.4em;
border-top: 1px solid currentColor;
}
#detailStatus dl:last-child{
border-bottom: 1px solid currentColor;
}
#detailStatus dt,
#detailStatus dd{
font-weight: 500;
line-height: 1.5em;
}
#detailStatus dt{
position: relative;
margin-right: 1em;
padding-right: 1em;
white-space: nowrap;
}
#detailStatus dt:before{
content: "";
position: absolute;
top: 0.25em;
right: 0;
height: 1em;
border-left: 1px solid currentColor;
}
#detailStatus ul{
display: flex;
margin-bottom: 1.5em;
}
#detailStatus li{
position: relative;
width: 25%;
border-radius: 8px;
}
#detailStatus li:before{
content: "";
position: absolute;
top: calc(50% - 0.5em);
left: 0;
height: 1em;
border-left: 1px solid currentColor;
}
#detailStatus li:last-child:before{
	width: 100%;
	border-right: 1px solid currentColor;
	}
#detailStatus li a{
display: block;
padding: 0.6em;
color: inherit;
font-weight: 500;
text-decoration: none;
text-align: center;
font-size: 1.1em;
}
#detailStatus li.select{
background: currentColor;
margin-right: -1px;
}
#detailStatus li.select a{
	color: #fff;
	}

#detailAreaMap{
position: relative;
border-bottom: 1px solid currentColor;
order: 1;
}

#detailLead{}
#detailLead .fr-view{
font-weight: 500;
letter-spacing: 0.05em;
line-height: 1.7em;
}

#detailTable{
background: linear-gradient(90deg,#ffe7d9,#dceced);
}
#detailTable h3{
color: #555;
font-weight: 500;
font-size: 1.5em;
letter-spacing: 0.1em;
text-align: center;
}
#detailTable h3+div{
margin-top: 2em;
}
#detailTable dl{
position: relative;
display: flex;
flex-direction: column;
width: calc(100vw - 10em);
max-width: 316px;
background: #fff;
padding: 1em;
border-radius: 8px;
box-shadow: 0 10px 10px rgba(0,0,0,0.2);
}
#detailTable dt{
padding: 0.3em 0.8em;
color: #555;
font-weight: 500;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
order: 1;
}
#detailTable dd{}
#detailTable dd a{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
opacity: 0;
}
#detailTable .wrap{
width: 100%;
}
#detailTable .slick-slider{
display: flex;
flex-wrap: wrap;
align-items: center;
justify-content: center;
overflow: hidden;
}
#detailTable .slick-list{
margin-bottom: 2em;
order: -1;
}
#detailTable .slick-next{
order: 1;
}
#detailTable .slick-dots{
width: calc(100% - 12em);
margin: 0 1em;
}
#detailTable .thumb{
border-radius: 4px;
}

#detailCourse{
counter-reset: count;
}
#detailCourse section{margin: 2em 0;padding: 1em;border: 1px solid #17546b;padding-top: 1em!important;}
#detailCourse .wrap{
position: relative;
display: flex;
flex-direction: column;
align-items: stretch;
z-index: 1;
}
#detailCourse .wrap:before{content: "";position: absolute;top: 5em;left: 0;width: 0;height: calc(100% - 10em);border-left: 2px solid #555;z-index: -1;}

#detailCourseStart,
#detailCourseGoal{position: relative;padding-left: 10px;left: -10px;background: #fff;color: #016d97;font-size: 2.1em;font-size: 25px;/* font-family: sofia-pro, sans-serif; */font-weight: 900;/* font-style: italic; */text-transform: capitalize;line-height: 2em;}

#detailCourseStart:before,
#detailCourseGoal:before{
/* content: ""; */
/* position: absolute; */
/* left: 0; */
/* width: 1em; */
/* height: 1em; */
/* border-top: 1px solid currentColor; */
}

@media only screen and (max-width: 500px) {
	#detailCourseStart,
	#detailCourseGoal{
		left: -10px;
		font-size: 1.6em;
	}
}







#detailCourseStart:before{
top: 1.5em;
transform: skewY(-45deg);
}

#detailCourseGoal{}
#detailCourseGoal:before{
bottom: 0.5em;
transform: skewY(45deg);
}

#detailFooter{
padding-top: 0;
}

#detailMap{
display: flex;
flex-direction: column;
}
#detailMap p{
margin-top: 1em;
padding-left: 1em;
text-indent: -1em;
color: #666666;
font-size: 0.875em;
line-height: 1.7em;
}
#detailMap menu{
position: relative;
align-self: center;
width: 100%;
max-width: 380px;
margin: 0;
padding: 1em 1.5em;
border: 1px solid currentColor;
border-radius: 4px;
color: #555;
fill: currentColor;
font-weight: 500;
letter-spacing: 0.1em;
text-align: center;
cursor: pointer;
order: 1;
}
#detailMap menu i{
position: absolute;
top: calc(50% - 0.5em);
right: 1.5em;
}
#detailMap menu path{
transition: opacity 0.2s ease-out;
}
#detailMap menu.open{}
#detailMap menu.open path+path{
	opacity: 0;
	}
#detailMap menu+div{
margin-bottom: 2em;
}

#detailMapBody{
position: relative;
background: #ccc;
}
#detailMapBody > div{
width: 100%;
height: 100%;
}
#detailMapBody iframe{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
#detailMapBody > .infoWin{
position: relative;
margin: 1em;
z-index: 1;
}
#detailMapBody > img{
position: relative;
margin: 1em 0;
width: 34px;
height: 50px;
z-index: 1;
}

#detailMapList{
overflow-y: auto;
}
#detailMapList ul{
counter-reset: count;
list-style: none;
}
#detailMapList li{
position: relative;
padding: 1em;
padding-left: 4em;
font-weight: 500;
letter-spacing: 0.05em;
line-height: 1.5em;
cursor: pointer;
}
#detailMapList li:before{
counter-increment: count;
content: counter(count);
position: absolute;
top: 0.6em;
left: 1em;
width: 2.4em;
height: 2.4em;
margin-right: 0.5em;
background: #555;
border-radius: 100%;
color: #fff;
font-weight: bold;
text-align: center;
line-height: 2.4em;
transform: scale(0.8);
}
#detailMapList li+li{
border-top: 1px solid #e1e1e1;
}
#detailMapList a{
color: inherit;
text-decoration: none;
}
#detailMapList a:hover{
text-decoration: none;
}

#share{
display: flex;
flex-direction: column;
align-items: center;
color: #555;
}
#share:before{
content: "Share";
position: relative;
margin-bottom: -0.4em;
padding: 0 0.6em;
background: #fff;
font-size: 1.7em;
font-family: sofia-pro, sans-serif;
font-weight: 900;
font-style: italic;
line-height: 1em;
text-align: center;
z-index: 1;
}
#share ul{
position: relative;
display: flex;
justify-content: center;
border: 1px solid currentColor;
border-radius: 4px;
padding: 2em 3em;
padding-top: 3em;
}
#share li{}
#share li a{
display: block;
}
#share li svg{
font-size: 40px;
}
#share li+li{
margin-left: 2em;
}

#recommend{
border-top: 1px solid #555;
overflow: hidden;
}
#recommend h2{
display: flex;
align-items: center;
color: #555;
fill: currentColor;
font-weight: 500;
line-height: 1.5em;
}
#recommend h2 i{
position: relative;
top: 0.1em;
display: flex;
align-items: center;
margin-right: 1em;
}
#recommend h2+div{
margin-top: 2em;
}
#recommend dl{
position: relative;
display: flex;
flex-direction: column;
}
#recommend dt{
font-weight: 500;
letter-spacing: 0.025em;
}
#recommend dt+dd{
order: -1;
}
#recommend dd{}
#recommend dd a{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
opacity: 0;
}
#recommend .thumb{
border-radius: 4px;
}
#recommend .slick-list{
margin: 0 -0.75em;
}
#recommend .slick-slide{
padding: 0 0.75em;
}
#recommend .slick-arrow{
position: absolute;
margin: -1.5em;
z-index: 1;
}
#recommend .slick-prev{
left: 0;
}
#recommend .slick-next{
right: 0;
}

.spot{
position: relative;
}
.spot.quote{}
.spot.quote{}
.spot.quote .spotText .fr-view{
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 5;
	height: calc(1.7em * 5em);
	overflow: hidden;
	}

.spotName{position: relative;color: #000;font-weight: 500;font-size: 1.65em;line-height: 1.5em;letter-spacing: 0.1em;/* background: #000; */padding-left: 10px;/* border-bottom: 1px solid #000; */}
.spotName:before{counter-increment: count;content: counter(count);position: absolute;top: 0.75em;left: -4em;display: flex;align-items: center;justify-content: center;width: 2em;height: 2em;margin: -1em;padding-bottom: 0.15em;background: #000;/* border: 3px solid #fff; */border-radius: 100%;color: #fff;letter-spacing: 0;padding-top: 5px;/* line-height: 2em; */text-align: center;box-sizing: border-box;font-family: "Century Gothic", sans-serif;}
.spotLead{margin-top: 0.3em;font-weight: 500;font-size: 1.1em;line-height: 1.5em;letter-spacing: 0.05em;padding-left: 10px;}
.spotLeadA{margin-top: 1em;font-weight: 500;font-size: 1.3em;line-height: 1.5em;letter-spacing: 0.05em;padding-left: 10px;/* margin-bottom: 1em; */color: #000;}
.spotPhoto{
margin-top: 1.5em;
}
.spotPhoto li[data-caption]{
position: relative;
}
.spotPhoto li[data-caption]:before{
content: attr(data-caption);
position: absolute;
left: 0;
bottom: 0;
display: block;
width: 100%;
padding: 1em;
background: linear-gradient(rgba(0,26,23,0), rgba(0,26,23,0.7));
color: #fff;
font-size: 0.75em;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
z-index: 1;
}
.spotPhoto .thumb{
border-radius: 4px;
}

.spotText{
margin-top: 1.5em;
}
.spotText .fr-view{
line-height: 1.7em;
font-size: 1.1rem;
}

.spotText .fr-view h2{
font-size:1.7em;
}

.kan_set{display:flex;flex-wrap: wrap;margin-top: 50px;}
.text_set{width:70%}
.text_set p{font-size: 17px;line-height:2}
.img_set{width:30%;}
.waku_top{
  /* border:1px solid #ddd; */
  background:#eee;
  padding:5px;
  position: relative;
  display: inline-block;
  margin: 1.5em 0;
  padding: 10px;
  /* min-width: 120px;
  max-width: 100%; */
  /* color: #555; */
  font-size: 16px;
}

.waku_top:before {
  /* content: ""; */
  /* position: absolute; */
  /* top: -30px; */
  /* left: 50%; */
  /* margin-left: -15px; */
  /* border: 15px solid transparent; */
  /* border-bottom: 15px solid #eee; */
  }

  .waku_top p {
    margin: 0;
    padding: 0;
  }


.spotInfo{display: flex;margin-top: 1.5em;max-width: 100%;margin: 0 auto;}
.spotInfo a,
.spotInfo menu{position: relative;display: flex;align-items: center;justify-content: center;width: 100%;padding: 1em 1em;padding-right: 1em;border: 1px solid currentColor;border-radius: 4px;background: #fff;color: #555;font-size: 0.875em;font-weight: 500;text-align: center;text-decoration: none;letter-spacing: 0.01em;line-height: 1.5em;/* border: none; */}

.spotInfo menu:after{
 font-family: 'Font Awesome 6 pro';
 content: "\f055";
 font-weight: 300;
 padding-left: 10px;
}


.spotInfo a i,
.spotInfo menu i{
position: absolute;
top: calc(50% - 0.5em);
right: 1em;
}




.spotInfo menu{
cursor: pointer;
}
.spotInfo menu.open{
background: #555;
border-color: transparent;
color: #fff;
}
.spotInfo menu.open path+path{
	opacity: 0;
	}

.spotData{}
.spotData dl{
display: flex;
border-bottom: 1px dashed #555;
font-weight: 500;
}
.spotData dt,
.spotData dd{
padding: 0.8em;
border-top: 1px dashed #555;
line-height: 1.4em;
}
.spotData dt{
color: #555;
}
.spotData dd{
color: #4d4d4d;
text-align: left;
}

a.phone_link{
border:	none;
background:	none;
justify-content: left;
}


.date{position: relative;align-self: center;margin: 1em 0;padding: 0 1em;background: #fff;color: #000;font-weight: 500;font-size: 1.8em;letter-spacing: 0.1em;}
.date:before{content: "";position: absolute;top: 50%;left: calc(50% - 50vw);width: 99vw;border-top: 1px dashed currentColor;z-index: -1;}

.move{
position: relative;
display: flex;
align-items: center;
margin: 2em 0;
line-height: 1.5em;
letter-spacing: 0.1em;
}
.move:before,
.move:after{content: "";color: #000;}
.move:before{
margin-right: 0.5em;
border-top: 2px solid currentColor;
}
.move:after{position: absolute;top: calc(50% - 12px);left: -13px;width: 20px;height: 20px;background: currentColor;border-radius: 100%;border: 3px solid #000;box-sizing: content-box;}

.column{
display: flex;
flex-direction: column;
overflow: hidden;
}
.column h4{
position: relative;
align-self: center;
padding: 0 1em;
background: #fff;
color: #555;
font-size: 1.75em;
font-family: sofia-pro, sans-serif;
font-weight: 900;
font-style: italic;
text-transform: capitalize;
line-height: 1em;
}
.column h4:before{
content: "";
position: absolute;
top: 0.5em;
left: calc(50% - 50vw);
width: 100vw;
border-top: 1px solid currentColor;
z-index: -1;
}
.column h4+div{
display: flex;
margin-top: 2em;
}
.column h5{
color: #555;
font-weight: 500;
font-size: 1.25em;
line-height: 1.5em;
letter-spacing: 0.1em;
}
.column h5+div{
margin-top: 1.5em;
color: #4d4d4d;
}
.column h5+div+div{
display: flex;
justify-content: center;
margin-top: 1.5em;
}
.column h5+div+div a{
position: relative;
display: block;
width: 100%;
max-width: 300px;
padding: 1em;
border: 1px solid currentColor;
border-radius: 4px;
background: #fff;
color: #555;
font-size: 0.875em;
font-weight: 500;
text-align: center;
text-decoration: none;
letter-spacing: 0.01em;
}
.column h5+div+div i{
position: absolute;
top: calc(50% - 0.5em);
right: 1em;
}
.column figure{
order: -1;
}
.column .fr-view{
color: #4d4d4d;
font-size: 0.875em;
line-height: 1.7em;
}
.column .thumb{
border-radius: 4px;
}




/* for all */
@media (max-width: 1199.98px) {
/*1199px以下*/
}
@media (max-width: 991.98px) {
/*991px以下*/
}


/* for mobile */
@media (max-width: 767.98px) {
/*767px以下*/
#detailAreaMap{
padding-bottom: 1em;
}
#detailLead{
margin-top: 2em;
}
#detailLead .fr-view+div{
width: 100%;
max-width: 20em;
margin: auto;
margin-top: 2em;
}
#detailTable{}
#detailTable dl{
padding: 0.75em;
}
#detailTable dt{
margin-top: 0.75em;
}
#detailTable .slick-slide{
padding: 0 0.75em;
}
#detailTable .slick-prev{
margin-left: 1.5em;
}
#detailTable .slick-next{
margin-right: 1.5em;
}
#detailCourse{
padding: 2em 0;
}
#detailCourse section{margin-left: 2em;background: #fff;}
#detailCourse .wrap{
width: calc(100% - 4em);
margin-left: 2.5em;
}
#mapList{
height: 10em;
}
#share{
margin-top: 2em;
}
#recommend{}
#recommend h2{
font-size: 1.4em;
}
.spotName{
    color: #17546b;
    background: none;
}
.spotName:before{left: -1.8em;}
.move{}
.move:before{
flex: 0 0 1.5em;
width: 1.5em;
}
.topics,
.column{
margin-top: 2em;
}
.topics{}
.topics .slick-arrow{
top: 7.6em;
}
.spotList{}
.spotList dt{
font-size: 0.875em;
}
}
@media (max-width: 767.98px) and (orientation:portrait) {
/*767px以下縦向き*/
#detailTitle{}
#detailTitle h2{
order: -1;
}
#detailTitle figure{
margin: 0 -1em;
margin-top: 1em;
order: -1;
}
#detailTitle .wrap{
display: flex;
flex-direction: column;
}
#detailStatus{
margin: 1.5em 0;
}
#detailTable{}
detailTable .slick-dots{}
#detailTable .slick-dots li{
margin: 0.8em;
}
#detailMapBody{
height: 100vw;
}
#recommend{}
#recommend .slick-arrow{
top: 4em;
}
.spotPhoto{margin: 0.5em;}
.spotPhoto ul{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.spotPhoto li{}
.spotPhoto li:first-child{
width: 100%;
}
/* .spotPhoto li:nth-of-type(n+2){
width: calc(50% - 0.5em);
margin-top: 1em;
} */
.spotPhoto li:nth-of-type(n+2){
width: 100%;
margin-top: 1em;
}
.spotInfo{
flex-direction: column;
}
.spotData{
margin: 1em 0;
}
.spotData dl{
flex-direction: column;
}
.spotData dd{
padding-top: 0;
border: none;
}
.spotLink{
margin-top: 1em;
}
.column{}
.column h4+div{
flex-direction: column;
}
.column figure{
margin-bottom: 1em;
}
}


.spotLink a:after{
 font-family:'themify';
 content: "\e732";
 font-weight: 300;
 padding-left: 10px;
}





@media (max-width: 767.98px) and (orientation:landscape) {
/*767px以下横向き*/
#detailStatus,
#detailAreaMap{
padding: 1.5em;
}
#detailMapBody{
height: 80vw;
}
#recommend{}
#recommend .slick-arrow{
top: 7.6em;
}
.topics{}
.topics .slick-list{
margin: 0;
padding: 0 29vw;
}
.topics .slick-arrow{
top: 5em;
}
}
@media (min-width: 576px) and (max-width: 767.98px) and (orientation:landscape), (min-width: 768px) {
/*576px～767px横向き, 768px以上*/
#detailTitle{}
#detailTitle h2{
position: absolute;
left: 0;
bottom: 0;
width: 60%;
padding: 1em;
background: linear-gradient(rgba(0,26,23,0), rgba(0,26,23,0.7));
color: #fff;
z-index: 2;
}
#detailTitle figure{
position: absolute;
top: 0;
left: 0;
width: 60%;
height: 100%;
}
#detailTitle .wrap{
position: relative;
display: flex;
flex-direction: column;
width: 100%;
padding-left: 60%;
}
#detailTitle .thumb{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
padding: 0;
}
#detailStatus{
border-top: 1px solid currentColor;
}
#detailStatus+#detailAreaMap{
padding-top: 0;
}
#detailTable{}
detailTable .slick-dots{}
#detailTable .slick-dots li{
margin: 1em;
}
.spotPhoto{}
.spotPhoto ul{
overflow: hidden;
}
.spotPhoto li{
float: left;
width: calc(33.3% - 0.8em);
}
.spotPhoto li:first-child{
width: 66.6%;
}
.spotPhoto li:first-child:last-child{
width: 100%;
}
.spotPhoto li:first-child:last-child .thumb{
	padding-top: 44.4%;
	}
.spotPhoto li:first-child:nth-last-of-type(2),
.spotPhoto li:last-child:nth-of-type(2){
width: calc(50% - 0.5em);
}
.spotPhoto li:first-child:nth-last-of-type(2) .thumb,
/* .spotPhoto li:last-child:nth-of-type(2) .thumb{
	padding-top: 88.8%;
	} */
.spotPhoto li:nth-of-type(n+2){
float: right;
}
.spotPhoto li:nth-of-type(3){
margin-top: 1em;
}
.spotInfo{
flex-wrap: wrap;
justify-content: center;
}
.spotInfo menu{
width: calc(50% - 0.75em);
max-width: 250px;
margin: 0 10px;
}
.spotData{
display: flex;
justify-content: center;
width: 100%;
margin-top: 1.5em;
order: 1;
}
.spotData dl{
flex-wrap: wrap;
width: 100%;
max-width: calc(600px + 1.5em);
max-width: 800px;
}
.spotData dt{
width: 8em;
}
.spotData dd{
width: calc(100% - 8em);
}
.spotLink{/* width: calc(33.333%); *//* max-width: 300px; */}
.spotLink a:hover{
   background-color: #555;
    color: #fff;
    transition: .4s;
}
menu:hover{
   background-color: #555;
   color: #fff;
   transition: .4s;
}
.spotLink:not(:first-child){
margin-left: 1.4em;
}
.column{}
.column h4+div{
justify-content: space-between;
}

a.phone_link{
border:	none;
background:	none;
justify-content: left;
}
a.map_link{
border:	none;
background:	none;
justify-content: left;
padding: 0;
}


}
@media (min-width: 576px) and (max-width: 767.98px) and (orientation:landscape), (min-width: 768px) and (max-width: 991.98px) {
/*576px～767px横向き, 768px～991px*/
#detailTable{}
#detailTable .slick-list{
padding: 0 20vw !important;
}
#detailCourse{
padding: 3em 0;
}
#detailCourse section{
flex-direction: column;
align-items: stretch;
}
.column{}
.column h4+div > div,
.column figure{
width: calc(50% - 0.75em);
}
}

/*
#detailCourse section {
    margin-left: 4em;
    border: 1px solid #9e9e9e;
    background: #ffffff;
    border-radius: 0;
}
 */


/* for tablet */
@media (min-width: 768px) {
/*768px以上*/
#detailStatus{}
#detailStatus dt,
#detailStatus dd{
font-size: 0.875em;
}
#detailLead{}
#detailLead [data-fav-id]{
display: flex;
font-size: 0.875em;
}
#detailLead .fr-view{
width: 100%;
}
#detailLead .fr-view+div{
flex: 0 0 calc(0.875em * 20);
width: calc(0.875em * 20);
}
#detailLead .wrap{
display: flex;
justify-content: space-between;
}
#detailTable{}
#detailTable dl{
padding: 1em;
}
#detailTable dt{
margin-top: 1em;
}
#detailTable .slick-slide{
padding: 0 1em;
}
#detailTable .slick-prev{
margin-left: 2em;
}
#detailTable .slick-next{
margin-right: 2em;
}
#detailCourse{}
#detailCourse section{margin-left: 4em;border: 1px solid #9e9e9e;background: #ffffff;border-radius: 0;}
#detailMap{}
#detailMap menu+div{
display: flex;
flex-wrap: wrap;
}
#detailMapList{
position: relative;
}
#detailMapList ul{
position: absolute;
top: 0;
right: 0;
width: 100%;
height: 100%;
}
#recommend{}
#recommend h2{
font-size: 1.5em;
}
.spotName{}
.spotName:after{content: "";position: absolute;top: 0.75em;left: -4em;width: 3.5em;border-top: 2px solid currentColor;z-index: -1;color: #555;}
.move{}
.move:before{
flex: 0 0 3.5em;
width: 3.5em;
}
.topics{
overflow: hidden;
}
.topics h4{
position: relative;
}
.topics h4:before{
content: "";
position: absolute;
left: -2.5em;
top: 0.75em;
width: 2em;
border-top: 1px solid currentColor;
}
.topics dt+dd+dd{
font-size: 0.75em;
}
.topics .fr-view{
font-size: 0.875em;
}
}
@media (min-width: 768px) and (max-width: 1199.98px) {
/*768px～1199px*/
}
@media (min-width: 768px) and (max-width: 991.98px) {
/*768px～991px*/
#detailStatus,
#detailAreaMap{
padding: 1.5em 2em;
}
#detailLead{
margin-top: 3em;
}
#detailLead .fr-view{
margin-right: 3em;
}
#detailCourse{
padding: 3em 0;
}
#detailMapBody{
width: calc(100% - 20em);
height: 32em;
}
#detailMapList{
width: 20em;
}
#share{
margin-top: 3em;
}
#recommend{}
#recommend .slick-arrow{
top: 5.4em;
}
.spot,
.topics,
.column{
padding: 2em;
}
.spotName{}
.spotName:before{left: -4.3em;}
.topics{}
.topics .slick-arrow{
top: 7.2em;
}
}
.iconset{position: absolute;right: 50px;top: 10px;width: 90px;}

@media (max-width: 767.98px) {
.iconset{position: absolute;right: -20px;top: -15px;width: 100px;}
}
/* for PC */
@media (min-width: 992px) {
/*992px以上*/
#detailStatus,
#detailAreaMap{
padding: 2em 3em;
}
#detailLead{
margin-top: 4em;
}
#detailLead .fr-view{
margin-right: 4em;
}
#detailTable{}
#detailTable .slick-list{}
#detailTable .slick-list{
padding: 0 30vw !important;
}
#detailCourse{padding: 0em 0;}
#share{
margin-top: 4em;
}
#detailMapBody{
width: calc(100% - 15em);
}
#detailMapList{
width: 15em;
}
.spot,
.topics,
.column{
padding: 3em;
}
.spotName{}
.spotName:before{left: -4.85em;}




.column{}
.column h4+div > div{
width: 60%;
}
.column figure{
width: calc(40% - 2em);
}
}
@media (min-width: 992px) and (max-width: 1199.98px) {
/*992px～1199px*/
#detailMapBody{
height: 34em;
}
#recommend{}
#recommend .slick-arrow{
top: 7.4em;
}
.topics{}
.topics .slick-arrow{
top: 6.2em;
}
}
@media (min-width: 1200px) {
/*1200px以上*/
#detailMapBody{
height: 38em;
}
#recommend{}
#recommend .slick-arrow{
top: 7.6em;
}
#recommend .slick-prev{
left: -2.5em;
}
#recommend .slick-next{
right: -2.5em;
}
.topics{}
.topics .slick-arrow{
top: 6.6em;
}


.iconset{position: absolute;right: 50px;top: 10px;width: 200px;}


}


/* -----------------------------------------------------------
#sub_works_area
----------------------------------------------------------- */

#sub_works_area {padding: 50px 50px;/* background: url(../images/common/noise.png) repeat #f5f5f5; *//* background: #faf9f9; *//* width: 95%; */margin: 80px auto;}

#sub_works_area .central {
width: 100%;
max-width: 1200px;
margin: 0 auto;
}

@media only screen and (max-width: 900px) {
#sub_works_area {
padding: 0;
}
}

@media only screen and (max-width: 736px) {
#sub_works_area {
padding: 0;
}
}
/* -----------------------------------------------------------
#sub_works
----------------------------------------------------------- */

#sub_works {
/* float: right; */
width: 100%;
}

@media only screen and (max-width: 900px) {
#sub_works {
width: 100%;

}
}

@media only screen and (max-width: 736px) {
#sub_works {
padding: 20px 0;
}


}


.header_area {
/* max-width:1200px; */
width:100%;
margin:0 auto;
}

.header_area img{
width:100%;
}

.On_pc{display:block}
.On_sp{display:none}

@media only screen and (max-width: 900px) {
.On_pc{display:none}
.On_sp{display:block}
}

/* --------- .worksArea --------- */

.worksArea {
z-index: 3;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: stretch;
padding:1%;
justify-content: flex-start;}

.worksArea .worksBox {
flex: 0 0 31%;
align-items: stretch;
background: #fff;
border: 1px solid #ddd;
/* border-radius: 0.5em; */
margin: 1%;
}

/*      .worksArea .worksBox:before {
position: absolute;
right: 0;
top: 0;
left: 0;
bottom: 0;
content: "";
border: #fefefe 0 solid;
-webkit-transition: all 0.2s ease;
-moz-transition: all 0.2s ease;
-o-transition: all 0.2s ease;
transition: all 0.2s ease;
z-index: -1;
}
*/
.worksBox:hover {
/* border: #f2f2f2 2px solid; */
/*  border-radius: 0.5em; */
background:#0c438a;
color:#fff;
}







/* .inner */

.worksArea .worksBox .inner {
position: relative;
padding: 10px;
z-index: 2;
/* border: 1px solid #ddd; */
border-radius: 1em;
text-align: center;
}

.worksArea .worksBox .inner:before {
position: absolute;
right: 0;
top: 0;
left: 0;
bottom: 0;
content: "";
border: #fefefe 0 solid;
-webkit-transition: all 0.2s ease;
-moz-transition: all 0.2s ease;
-o-transition: all 0.2s ease;
transition: all 0.2s ease;
z-index: -1;
}

.worksBox:hover .inner:before {
/* border: #f2f2f2 2px solid; */
/*  border-radius: 0.5em; */
background:#0c438a;
color:#fff;
}

.worksArea .worksBox .inner .imgArea {
text-align: center;
}

.worksArea .worksBox .inner .imgArea img{
width: 100%;
margin: 0 auto;
/* max-width: 150px; */
}
/*
.worksArea .worksBox .inner img {
width: 100%;
margin: 0 auto;
max-width: 150px;
text-align: center;
} */

.worksArea .worksBox .inner h2 {
text-align: center;
color: #0c438a;
margin: 10px 0;
font-weight: 600;
font-size: 18px;
display: block;
}

.worksArea .worksBox .inner h2:after {
content: '';
display: block;
width: 147px;
height: 1px;
background-color: #0c438a;
position: relative;
bottom: 0px;
left: 50%;
-webkit-transform: translateX(-50%);
transform: translateX(-50%);
color:#fff;
}

.worksArea .worksBox .inner:hover {
color:#fff;
}

.worksArea .worksBox .inner:hover h2 {
color:#fff;
}


/* ul.category */

.worksArea .worksBox ul.category {
margin-top: 20px;
list-style: none;
z-index: 2;
text-align: center;
}

.worksArea .worksBox ul.category li {
display: inline-block;
color: #fefefe;
background: #0c438a;
font-size: 13px;
font-weight: 500;
line-height: 35px;
letter-spacing: 1px;
border-radius: 1.5em;
padding: 0 35px 0 25px;
position: relative;
z-index: 1;
}

.worksArea .worksBox ul.category li:after {
position: absolute;
top: 0;
right: 10px;
bottom: 0;
font-size: 1.1em;
/* line-height: 25px; */
font-family: themify;
/* content: "\e6ad"; */
font-weight: normal;
/* font-family: 'Font Awesome 6 pro'; */
content: "\e649";
vertical-align: 0;
}


.worksArea .worksBox p.category {
margin-top: 20px;
list-style: none;
z-index: 2;
text-align: center;
}

.worksArea .worksBox p.category {
/* display: inline-block; */
color: #fefefe;
background: #0c438a;
font-size: 13px;
font-weight: 500;
line-height: 35px;
letter-spacing: 1px;
border-radius: 1.5em;
padding: 0 35px 0 25px;
position: relative;
z-index: 1;
width: 150px;
margin: 0 auto;
}

.worksArea .worksBox p.category:after {
position: absolute;
top: 0;
right: 10px;
bottom: 0;
font-size: 1.1em;
/* line-height: 25px; */
font-family: themify;
/* content: "\e6ad"; */
font-weight: normal;
/* font-family: 'Font Awesome 6 pro'; */
content: "\e649";
vertical-align: 0;
}














.worksArea .worksBox p.date {
position: absolute;
top: 20px;
left: 7.5%;
font-family: 'Poppins', sans-serif;
font-weight: 500;
line-height: 40px;
font-size: 0;
display: none;
}

.worksArea .worksBox .inner h3 {
font-size: 15px;
font-weight: 500;
line-height: 2;
letter-spacing: 1px;
padding: 0;
margin-top: 10px;
text-align: center;
}

.worksArea .worksBox .icon_award {
position: absolute;
top: 15px;
right: 7.5%;
width: 55px;
height: 55px;
content: "";
background: url(../images/common/icon_award.png) center center no-repeat;
background-size: cover;
z-index: 2;
}

@media only screen and (max-width: 900px) {
.worksArea .worksBox .inner {
padding: 50px 7.5% 50px;
}
.worksArea .worksBox .inner p{
display:block;
}

.worksArea .worksBox .inner:before {
display: none;
}


.worksArea .worksBox .inner:hover {
color:#fff;
background:#0c438a;
border-radius:0.5em;
}

.worksArea .worksBox .inner:hover h2 {
color:#fff;

}


/* ul.category */
.worksArea .worksBox ul.category {
margin-top: -35px;
list-style: none;
z-index: 2;
display: block;
}
.worksArea .worksBox ul.category li {
padding: 0 15px 0 30px;
/* margin-top: 50px; */
}
/* p.date */
.worksArea .worksBox p.date {
top: 10px;
left: 7.5%;
}
/*.worksArea .worksBox p.date span { font-size: 13px; }*/
/* h3 */
.worksArea .worksBox .inner h3 {
font-size: 14px;
display: block;
}
/* .icon_award */
.worksArea .worksBox .icon_award {
top: 10px;
right: 7.5%;
width: 50px;
height: 50px;
}
}

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

.worksArea .worksBox .inner {
padding: 40px 7.5% 30px;
}
.worksArea .worksBox .inner:before {
display: none;
}


/* ul.category */
.worksArea .worksBox ul.category {
margin-top: 0px;
list-style: none;
z-index: 2;
display: block;
}
.worksArea .worksBox ul.category li {
font-size: 11px;
line-height: 25px;
letter-spacing: 1px;
padding: 0 10px 0 20px;
}
.worksArea .worksBox ul.category li:before {
left: 5px;
font-size: 1em;
}
/* p.date */
.worksArea .worksBox p.date {
top: 10px;
left: 7.5%;
line-height: 30px;
}
/*.worksArea .worksBox p.date span { font-size: 11px; }*/
/* h3 */
.worksArea .worksBox .inner h3 {
font-size: 11px;
line-height: 1.8;
margin-top: 5px;
}

.worksArea .worksBox {
flex: 0 0 49%;
margin-bottom:10px;
}


}

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

.worksArea {z-index: 3;display: flex;flex-wrap: wrap;justify-content: space-between;align-items: stretch;padding: 0;}


.worksArea .worksBox {
flex: 0 0 100%;
margin-bottom: 20px;
}

}

@media only screen and (max-width: 414px) {
.worksArea .worksBox p.date {
letter-spacing: 0.5px;
}
.worksArea .worksBox .inner h3 {
line-height: 1.8;
display: block;
}
.worksArea .worksBox ul.category li {
font-size: 9px;
padding: 0 20px 0 20px;
}
.worksArea .worksBox .icon_award {
top: 6px;
right: 4%;
width: 30px;
height: 30px;
}
}

.center{
text-align: center;
}

.left{
text-align: left;
}

.right{
text-align: right;
}

.none{
display: none !important;
}

.thumb{}
.thumb img{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
object-fit: inherit;
object-position: inherit;
opacity: 1;
transition: opacity 0.2s ease-out;
}
.thumb:not(img){
position: relative;
display: block;
width: 100%;
margin: 0;
padding: 66.66% 0 0 0;
object-fit: cover;
object-position: center;
background: rgba(0,0,0,0.05) url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" viewBox="0 0 50 50"><path fill="rgba(0,0,0,0.2)" d="M25.251,6.461c-10.318,0-18.683,8.365-18.683,18.683h4.068c0-8.071,6.543-14.615,14.615-14.615V6.461z" transform="rotate(200.584 25 25)"><animateTransform attributeType="xml" attributeName="transform" type="rotate" from="0 25 25" to="360 25 25" dur="0.6s" repeatCount="indefinite"></animateTransform></path></svg>') center center no-repeat;
background-size: 3em;
overflow: hidden;
background: opacity 0.2s ease-out;
}
img.thumb{
opacity: 0;
}
.thumb.contain{
object-fit: contain;
}
.thumb.cover{
object-fit: cover;
}
.thumb.top{
object-position: center top;
}
.thumb.bottom{
object-position: center bottom;
}
.thumb.left{
object-position: left center;
}
.thumb.right{
object-position: right center;
}



@media (min-width: 768px) and (max-width: 991.98px) {
/*768px～991px*/
.lsb-sp:not(.lsb-tb),
.lsb-pc:not(.lsb-tb){
display: none;
}
}





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

.slide{
height: 0;
opacity: 0;
transition: opacity 0.5s ease-out;
}
.slide .slick-arrow{
position: relative;
display: inline-block;
width: 3em;
height: 3em;
background: #fff;
border: 1px solid currentColor;
border-radius: 100%;
color: #555;
fill: currentColor;
cursor: pointer;
}
.slide .slick-arrow svg{
position: absolute;
top: 30%;
left: 30%;
width: 40%;
height: 40%;
}
.slide .slick-dots{
display: flex;
flex-wrap: wrap;
justify-content: center;
}
.slide .slick-dots li{
position: relative;
flex: 0 0 10px;
width: 10px;
height: 10px;
border-radius: 100%;
background: #fff;
overflow: hidden;
}
.slide .slick-dots button{
opacity: 0;
}
.slide .slick-dots .slick-active{
background: #555;
}
.slide.slick-initialized{
height: auto;
opacity: 1;
}


.photoArea{display:flex}

.photoBox{width:33.333%}

















/* for all */
@media (max-width: 1199.98px) {

}
@media (max-width: 991.98px) {
}


/* for mobile */
@media (max-width: 767.98px) {


.wrap{
width: calc(100% - 2em);
}


}
@media (max-width: 767.98px) and (orientation:portrait) {


}


@media (min-width: 768px) and (max-width: 1199.98px) {
/*768pxï½ž1199px*/
body{
font-size: 1.4rem;
}
}
@media (min-width: 768px) and (max-width: 991.98px) {
/*768pxï½ž991px*/
main > *,
article,
article section,
article nav,
article header,
article footer{
padding-top: 3em;
padding-bottom: 3em;
}

.wrap{
width: 724px;
}

}


/* for PC */
@media (min-width: 992px) {}

@media (min-width: 992px) and (max-width: 1199.98px) {

.wrap{
width: 940px;
}
}
@media (min-width: 1200px) {
/*1200pxä»¥ä¸Š*/

.wrap{width: 1140px;margin-top: 10px;}
}

.map {
width: 90%;
margin: 0 auto;
}




@media (min-width: 751px) {
a[href^="tel:"] {
pointer-events: none;
cursor: default;
}

}

a.phone_link{
border:	none;
background:	none;
justify-content: left;
padding: 0;
}

/* ------------------------------------------
フェードインアニメーション
--------------------------------------------*/
.fadeIn {
   -webkit-transition: 1s;
   transition: 1s;
   opacity: 0;
   -webkit-transform: translatey(50px);
           transform: translatey(50px);
 }
 .fadeIn.animated {
   opacity: 1;
   -webkit-transform: translatey(0px);
           transform: translatey(0px);
 }

/* bl_serviceAbout */

.bl_serviceAbout {
   padding: 20px 10px;
   background-color: #F4F4F4;
   border-radius: 5px;
   text-align: center;
 }



 .bl_serviceAbout_body {
   display: flex;
   align-items: center;
   justify-content: center;
   flex-direction: column;
   color: #18546d;
 }

 .bl_serviceAbout_body span {
   width: 200px;
   margin-bottom: 20px;
 }

 .bl_serviceAbout_body span img {
   width: 60%;
   margin: 0 auto;
 }

 .bl_serviceAbout_ttl {
   font-size: 2.3rem;
   font-weight: 500;
 }

 .bl_serviceAbout_ttl span {
   font-size: 3rem;
  display:block;
  font-family: "Century Gothic", sans-serif;
 }


 /* .bl_service */

.ly_pageInner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 50px 50px;
}

.bl_service{}


.bl_serviceUnit {
   display: flex;
   flex-wrap: wrap;
 }

 .bl_serviceUnit.bl_serviceUnit__col3 {
   justify-content: space-between;
 }

 .bl_serviceUnit__col2 > .bl_service {
   width: 50%;
 }

 .bl_serviceUnit__col2 > .bl_service.bl_service__s {
   width: 30%;
 }

 .bl_serviceUnit__col2 > .bl_service.bl_service__l {
   width: 63%;
   margin-left: auto;
 }

 .bl_serviceUnit__col3 > .bl_service {
   width: 31%;
 }

 .bl_serviceUnit__col3 > .bl_serviceAbout {
   width: 24%;
 }





 .boxInfo {width: calc(100%);margin: 0.5%;padding: 1%;box-sizing:border-box;border: 1px solid #ddd;border-radius: 0.2em;margin-top: 60px;}


 .boxInfo .box-title {
     font-size: 16px;
     /* background: #919191; */
     border-bottom: 1px solid #ddd;
     padding: 4px 4px 4px 1.9em;
     text-align: left;
     /* color: #5d5d5d; */
     font-weight: bold;
     line-height: 2;
     letter-spacing: 0.05em;
     position:relative;
 }

 .boxInfo .box-title:before {position:relative;font-family: 'Font Awesome 6 Pro';content: "\f82e";position: absolute;left: 0.3em;color: #18546d;}


 .boxInfo p {
     padding: 15px 20px;
 }


 .boxInfo li:last-of-type {
     border-bottom: none;
 }
 .boxInfo li:before {
     font-family: "Font Awesome 6 Pro";
     content: "\f22d";
     position: relative;
     left: 0;
     color: #18546d;
     padding-right: 10px;
 }


  @media only screen and (min-width: 1000px) {
  .boxInfo {
      /* width: calc(48%); */
      margin: 50px 0;
  }
  }



   .boxInfo {
     width: 100%;
     margin: 3% auto;
     padding: 1%;
     box-sizing:
     border-box;
     border: 1px solid #ddd;
     border-radius: 0.2em;
     background: #fff;
   }


  .boxInfo .box-title {
      font-size: 18px;
      /* background: #919191; */
      border-bottom: 1px solid #ddd;
      padding: 4px 4px 4px 1.9em;
      text-align: left;
      /* color: #5d5d5d; */
      font-weight: bold;
      line-height: 2;
      letter-spacing: 0.05em;
      position:relative;
  }

  .boxInfo .box-title:before {position:relative;font-family: 'Font Awesome 6 Pro';content: "\f02b";position: absolute;left: 0.3em;color: #18546d;}


  .boxInfo p {
      padding: 5px 5px 0;
  }

  .boxInfo ul{display:flex;/* flex-direction: row; */flex-wrap: wrap;/* justify-content: space-between; */}
  .boxInfo li{}

  .boxInfo li,
  .myboxP li {
      line-height: 1.5;
      padding: 0.5em;
      /* border-bottom: dashed 1px silver; */
      list-style-type: none!important;
      font-size: 15px;
      font-weight: 400;
      margin-left: 1.4em;
      /* text-indent: -1.4em; */
      /* width: 100%; */
      text-align: left;
      /* flex: 0 0 32%; */
  }
  .boxInfo li:last-of-type {
      border-bottom: none;
  }
  .boxInfo li:before {
      font-family: "Font Awesome 6 Pro";
      content: "\f22d";
      position: relative;
      left: 0;
      color: #18546d;
      padding-right: 10px;
  }

  .boxInfo li span{
      /* position: relative; */
      /* left: 50%; */
  }

  @media only screen and (max-width: 1200px) {
 .ly_pageInner {
   width: 100%;
   margin: 0 auto;
   padding: 50px 0px;
 }

  @media only screen and (max-width: 600px) {
/*  .ly_pageInner {
   width: 100%;
   margin: 0 auto;
   padding: 50px 10px;
 } */

  .boxInfo li {
        /* flex: 0 0 90%; */
    }
  }

  @charset "utf-8";

  /*========= レイアウトのためのCSS ===============*/

  body{
    background:#ECF2FC;
  }

  h1{
    text-align: center;
    text-transform: uppercase;
    font-size: 2rem;
    margin:30px 0;
  }

  .lead{
    padding: 20px;
    text-align: center;
  }

  .suujibox{
    max-width:500px;
    width:100%;
    margin: 130px auto;
    padding: 20px;
    background:#fff;
    text-align: center;
  }

  .count-size{
    font-size: 5rem;
    font-weight: bold;
    color: #167c3b;
  }


  /* summary */

  #summary {
    position: relative;
    }


  #summary .wrap {
      width: 100%;
      max-width: 1200px;
      margin: 80px auto 0;
    }




    #summary .fv .inner {
    background-image: url(../img/qa/qa_main.jpg);
    position: relative;
    }

    #summary .fv .inner .image {
    position: absolute;
    -webkit-transition: 1s all 0s ease;
    transition: 1s all 0s ease;
    }

    #summary .fv .inner .bird {
    left: 0;
    top: 50px;
    width: 230px;
    }

    #summary .fv .inner .doctor {
    right: 50px;
    bottom: 0;
    width: 170px;
    }

    #summary .fv .inner h1 {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
    line-height: 1.5;
    z-index: 1;
    }

    #summary .fv .inner h1 span {
    display: block;
    font-size: 1rem;
    }

    @media screen and (max-width: 767px) {
    #summary .fv .inner .bird {
        width: 150px;
    }
    #summary .fv .inner .doctor {
        right: 20px;
        width: 110px;
    }
    }

    #summary .wrapper {
    background-color: #fff;
    border-radius: 10px;
    padding: 50px 40px;
    }

    @media screen and (max-width: 767px) {
    #summary .wrapper {
        padding: 10px;
    }
    }

    #summary h2::after {
    content: '';
    position: absolute;
    display: block;
    bottom: 0;
    right: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    top: 30px;
    font-size: 1rem;
    }

    #summary h2 {
    text-align: center;
    }

    #summary h3 {
    color: #3f2e16;
    font-weight: bold;
    font-size: 1.4rem;
    padding: 0 20px 12px 20px;
    border-bottom: 3px solid #022a7f;
    display: inline-block;
    line-height: 1.3;
    }

    #summary .tre-icon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 150px;
    height: 50px;
    border-radius: 5%;
    text-align: center;
    color: #fff;
    }

    #summary .disease {
    background-color: #022a7f;
    }

    #summary .symptom {
    background-color: #fcb900;
    }

    #summary .underline {
    position: relative;
    z-index: 1;
    display: inline-block;
    }

    #summary .underline::before {
    content: '';
    position: absolute;
    display: block;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 6px;
    background-color: #e7e391;
    z-index: -1;
    }

    #summary .ora {
    border-bottom: 3px solid #fcb900;
    }

    @media screen and (max-width: 767px) {
    #summary h3 {
        padding-left: 5px;
        padding-right: 0;
    }
    #summary .tre-icon {
        width: 120px;
    }
    #summary .disease {
        font-size: 0.8rem;
    }
    #summary .disease span {
        font-size: 1rem;
    }
    #summary .symptom {
        font-size: 0.8rem;
    }
    }

    #summary .tre_about {
    text-align: center;
    }

    #summary .tre_about h2::before {
    width: 200px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    }

    #summary .tre_about .txt {
    margin-top: 30px;
    }

    #summary .tre_about .to-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    }

    #summary .tre_about .to-link li {
    padding: 10px 17px;
    }

    #summary .tre_about .disease_ul {
    margin-top: 30px;
    }

    @media screen and (max-width: 1024px) {
    #summary .tre_about .to-link li {
        padding: 7px 10px;
    }
    }

    @media screen and (max-width: 767px) {
    #summary .tre_about .to-link li {
        padding: 4px;
    }
    }

    #summary .tre-sec .tips {
    position: relative;
    display: flex;
    }

    #summary .tre-sec .tre-icon {
    position: absolute;
    }

    #summary .tips {
    position: relative;
    /* padding: 30px; */
    margin-top: 40px;
    background-color: #fff;
    }

    #summary .tips.tips-dis {
    /* border: 5px solid #022a7f; */
    /* max-width: 1000px; */
    /* margin: 0 auto; */
    }

    #summary .tips.tips-sym {
    border: 5px solid #fcb900;
    }

    #summary .tips.tips-sym .mb {
    margin-bottom: 40px;
    }

    #summary .tips.tips-sym h3 {
    border-bottom: 3px solid #fcb900;
    }

    #summary .tips.tips-sym .left ul li::before {
    background-color: #fcb900;
    }

    #summary .tips .left {
    width: calc(65% - 30px);
    margin-right: 30px;
    }

    #summary .tips .left ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: 30px;
    margin-top: 15px;
    /* width: 80%; */
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    }

    #summary .tips .left ul li {
    margin-top: 20px;
    padding-left: 10px;
    margin-right: 30px;
    position: relative;
    font-size: 1.2rem;
    line-height: 1.3;
    }

    /* #summary .tips .left ul li::before {
    content: '';
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    top: 7px;
    left: 0px;
    width: 5px;
    height: 5px;
    background-color: #00913a;
    border-radius: 50%;
    } */

    #summary .tips .left p {
    margin-top: 10px;
    }

    #summary .tips .right {
    width: 25%;
    }

    #summary .tips .right img {
    border-radius: 1em;
    }

    #summary .tips .tre-icon {
    position: absolute;
    top: -30px;
    right: 10px;
    }

    #summary .often_case {
    margin-top: 30px;
    width: 100%;
    }

    #summary .often_case img {
    /* width: 100%; */
    /* max-width: 150px; */
    margin: 0 auto;
    display: block;
    }

    #summary .often_case ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    }

    #summary .often_case ul li {
    margin-top: 50px;
    margin: 50px 1%;
    padding: 45px 30px 30px;
    border: 3px solid #167c3b;
    position: relative;
    /* min-width: 33%; */
    text-align: center;
    }

    #summary .often_case ul li p{
    /* display:inline; */
    padding:10px;
    }

    #summary .often_case ul li p{
    /* display:inline; */
    padding: 0;
    margin-top: 10px;
    }

  .count-size_1{color:#167c3b}

    .rankNo1{
      color:#0d2870;
      padding:5px 15px;
      font-size:30px;
      font-weight: 600;
      background:#ffd400;
      border-radius:50%;
      margin:0 5px;
    }

    .rankNo2{
      color:#bb0000;
      padding:5px 15px;
      font-size:30px;
      font-weight: 600;
      background:#67a6bf;
      border-radius:50%;
      margin:0 5px;
    }

    .rankNo3{
      color: #fcb900;
      padding:5px 15px;
      font-size:30px;
      font-weight: 600;
      background:#022a7f;
      border-radius:50%;
      margin:0 5px;
    }


    #summary .effect {
    margin-top: 30px;
    display: flex;
    flex-flow: nowrap;
    justify-content: space-between;
    border: 2px dotted #022a7f;
    padding: 2%;
    border-radius: 1em;
    }

    #summary .effect .efect_txt {
    width: 55%;
    padding: 1%;
    /* justify-content: center; */
    justify-content: space-between;
    color: #000;
    }

    #summary .effect .efect_txt .title {
    font-size: 1.4em;
    line-height: 2;
    }

    #summary .effect .efect_txt .caption {
    line-height: 1.6;
    margin-bottom: 10px;
    }

    #summary .effect .efect_img {
    width: 40%;
    justify-content: center;
    }

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

     #summary .effect {
        flex-flow: wrap;
      }
      #summary .effect .efect_txt {
      width: 100%;
      order:2;
      }

      #summary .effect .efect_img {
      width: 90%;
      margin:0 auto;
      order:1;
      }
     }
    #summary .effect .efect_img img{
    width:100%;
    max-width: 350px;
    }

    .box_flex{
    display:flex;
    flex-flow: wrap;
    justify-content: space-between;
    }


    .pla_col_1 {
    width: 98%
    }

    .pla_col_2 {
    width: 48%;
    }

    .pla_col_3 {
    width: 31%;
    }

    .pla_col_4 {
    width: 60%;
    }
    .pla_col_5 {
    width: 20%;
    }

    .pla_col_5 p{
    display:block;
    }
    .pla_col_5 img{
    display:block;
    }

    .pla_col_6 {
    width: 25%;
    }
    .pla_col_7 {
    width: 16.6%;
    padding: 2%;
    }

    .pla_col_8 {
    width: 14.2%;
    padding: 1%;
    border-right: 1px #ddd dotted;
    }

    @media screen and (max-width: 800px) {
      .pla_col_8 {
        width: 50%;
        padding: 1%;
        border-bottom: 1px #ddd dotted;
      }

      .pla_col_8:nth-of-type(2n) {
        border-right:none;
      }

    }



    .pla_col_8:last-child {
    border-right: none;
    }

    .pla_col_8 p{
    font-size: 14px;
    }

    .pla_col_1 img
    {width:100%;}

    /* .pla_col_1 img, */
    .pla_col_2 img,
    .pla_col_3 img,
    .pla_col_4 img,
    .pla_col_5 img,
    .pla_col_6 img
    {
    /* width:90%; */
    /* max-width: 180px; */
    /* padding:5px; */
    }


    .pla_col_2 img
    {width:100%;max-width: 350px;}



    #summary .often_case ul li .title {
    top: -12px;
    left: 25px;
    min-width: 130px;
    padding: 8px 20px;
    text-align: center;
    display: inline-block;
    color: #fff;
    font-weight: bold;
    background-color: #167c3b;
    position: absolute;
    }

    #summary .often_case ul li .green {
    font-weight: bold;
    display: inline-block;
    color: #8fc767;
    }

    #summary .pickup {
    padding: 30px 40px;
    background-color: #ffeab0;
    position: relative;
    }

    #summary .pickup.mt {
    margin-top: 30px;
    }

    #summary .pickup .img_pickup {
    width: 100px;
    margin-left: -50px;
    margin-bottom: 20px;
    }

    #summary .pickup .title {
    font-size: 1.4rem;
    font-weight: bold;
    color: #3f2e16;
    margin-bottom: 20px;
    line-height: 1.5;
    }

    #summary .pickup .title:before {
    content: '\f4aa';
    font-family: 'Font Awesome 6 pro';
    padding-right: 5px;
    color: #009654;
    font-size: 1.2em
    }

    #summary .pickup .title .underline {
    font-weight: bold;
    }

    #summary .pickup .title .underline::before {
    height: 10px;
    }

    #summary .pickup .txt {
    background: #fff;
    padding: 10px;
    border-radius: 1em;
    margin-bottom: 1em;
    }

    #summary .pickup .name {}

    @media screen and (max-width: 1024px) {
    #summary .tips {
        padding: 15px;
    }
    #summary .tips.tips-dis {
        /* border: 5px solid #8fc767; */
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    }
    #summary .tips.tips-sym {
        border: 5px solid #fcb900;
    }
    #summary .tips.tips-sym .content {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    }
    #summary .tips .left {
        width: 100%;
        margin-right: 0;
        margin-top: 30px;
    }
    #summary .tips .left ul {
        width: 100%;
    }
    #summary .tips .right {
        width: 100%;
    }
    }

    @media screen and (max-width: 767px) {
    #summary .tips {
        padding: 10px;
    }
    #summary .tips .left ul {
        margin: 0 0 10px;
    }
    #summary .tips .left ul li {
        margin-right: 0;
    }
    #summary .tips .tre-icon {
        right: 10px;
    }
    #summary .often_case ul li {
        padding: 30px 10px 20px;
        margin-top: 30px;
        margin-bottom: 10px;
    }
    #summary .often_case ul li .title {
        left: 10px;
    }
    #summary .pickup {
        padding: 20px;
    }
    #summary .pickup .img_pickup {
        margin-left: -25px;
    }
    .medi_col_2 {
        width: 98%;
    }

    }


    .chart-area{
    position: relative;
    width:100%;
    height:50vh;
    }





    .lead{
    padding: 20px;
    text-align: center;
    }

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


    .pla_col_1 {
    width: 98%
    }

    .pla_col_2 {
    width: 98%

    }

    .pla_col_3 {
    width: 98%

    }

    .pla_col_4 {
    width: 98%

    }
    .pla_col_5 {
    width: 98%

    }

    .pla_col_5 p{
    display:block;
    }
    .pla_col_5 img{
    display:block;
    }

    .pla_col_6 {
    width: 98%;

    }
    .pla_col_7 {
    width: 98%;
    padding: 2%;
    }

    .pla_col_1,.pla_col_2,.pla_col_3,.pla_col_4,.pla_col_5,.pla_col_6,.pla_col_7,.pla_col_8 {
    width: 98%;
    padding: 2% 1%;
    border-bottom: 1px #167c3b solid;
    border-right:none
    }

    .pla_col_1 p,.pla_col_2 p,.pla_col_3 p,.pla_col_4 p,.pla_col_5 p,.pla_col_6 p,.pla_col_7 p,.pla_col_8 p {
    font-size:20px;
    }

    .pla_col_1 img,.pla_col_2 img,.pla_col_3 img,.pla_col_4 img,.pla_col_5 img,.pla_col_6 img,.pla_col_7 img,.pla_col_8 img {
    width: 150px;
    padding:2%;
    }



    .pla_col_2:last-child, .pla_col_8:last-child {
    width: 98%;
    padding: 2% 1%;
    border-bottom: none;
    }


    }






  /* -----------------------------------------------------------
     #service_flow
     ----------------------------------------------------------- */

     #service_flow {
      padding: 90px 5%;
      /* background: url(../images/common/noise.png) repeat #f5f5f5; */
      width: 100%;
      background: #f5f5f5;
      max-width: 1200px;
      margin: 60px auto;
  }

  @media only screen and (max-width: 900px) {
      #service_flow {
          padding: 80px 5%;
      }
  }

  @media only screen and (max-width: 736px) {
      #service_flow {
          padding: 70px 5%;
      }
  }

  @media only screen and (max-width: 500px) {
      #service_flow {
          padding: 70px 8%;
      }
  }




  /* --------- .flowArea --------- */

  #service_flow .flowArea {
      margin: -10px;
      font-size: 0;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      flex-wrap: wrap;
  }

  #service_flow .flowBox {
      /* display: inline-block; */
      margin: 0;
      border: #f5f5f5 10px solid;
      width: 33.333%;
      text-align: center;
      /* position: relative; */
      z-index: 2;
      padding: 0%;
      background: #fff;
      /* flex: 1 0 33.3333%; */
  }


  /* .inner */

  #service_flow .flowBox .inner {
      padding: 35px 5% 50px;
      /* background: #fefefe; */
  }

  #service_flow .flowBox .inner img{
    width:100%;
  }




  /* h3 */

  #service_flow .flowBox h3 {
      font-size: 18px;
      font-weight: 700;
      letter-spacing: 1px;
      position: relative;
      z-index: 3;
      line-height: 1;
      padding: 15px 0 15px;
      text-align: center;
  }


  #service_flow .flowBox h3:before {
      font-family: 'Font Awesome 6 pro';
    padding-right:10px;
    font-size:20px;
    color:#167c3b;
  }


  #service_flow .flowBox h3:before {

  /*     width: 1200px;
      height: 60px;
      line-height: 62px;
      color: #fefefe;
      font-size: 25px;
      background: #167c3b;
    border-radius:50%; */
  }


/*


  #service_flow .flowBox:nth-child(1) h3:before {
      content:'\f5c1';

  }

  #service_flow .flowBox:nth-child(2) h3:before {
      content: "2";
        content:'\f433';
  }

  #service_flow .flowBox:nth-child(3) h3:before {
      content: "\f51c";
  }

  #service_flow .flowBox:nth-child(4) h3:before {
      content: "\f685";
  }

  #service_flow .flowBox:nth-child(5) h3:before {
      content: "5";
  }

  #service_flow .flowBox:nth-child(6) h3:before {
      content: "\f1b9";
  } */

  #service_flow .flowBox h3:after {
      position: absolute;
      bottom: 0;
      left: 25px;
      right: 25px;
      height: 0;
      content: "";
      border-top: #e5e8ef 1px solid;
      z-index: 2;
  }


  /* .txtArea */

  #service_flow .flowArea .txtArea {
      display: inline-block;
      margin: 20px auto 0;
  }
  #service_flow .flowArea .txtArea img {
    width:100%;
  }

  @media only screen and (max-width: 900px) {
      #service_flow .flowBox .inner {
          padding: 30px 5% 45px;
      }
      #service_flow .flowBox h3 {
          font-size: 16px;
          padding: 55px 0 30px;
      }
      #service_flow .flowBox h3:before {
          /* margin-left: -20px; */
          width: 40px;
          height: 40px;
          line-height: 42px;
          font-size: 20px;
      }
      #service_flow .flowBox h3:after {
          left: 5%;
          right: 5%;
      }
  }

  @media only screen and (max-width: 768px) {
      #service_flow .flowBox {
          width: 50%;
      }
  }

  @media only screen and (max-width: 736px) {
      #service_flow .flowArea {
        flex-direction:column;
      }
      #service_flow .flowBox {
          display: block;
          margin-top: 50px;
          border: none;
          width: 100%;
          text-align: center;
      }
  /*     #service_flow .flowBox:after {
          position: absolute;
          bottom: -50px;
          right: 0;
          left: 0;
          height: 50px;
          line-height: 50px;
          font-size: 20px;
          font-family: themify;
          content: "\e62a";
          z-index: 1; */
      }
      #service_flow .flowBox:last-child:after {
          display: none;
      }
      /* .inner */
      #service_flow .flowBox .inner {
          padding: 35px 5%;
          /* border: #e5e8ef 1px solid; */
      }
      /* h3 */
      #service_flow .flowBox h3 {
          font-size: 18px;
          padding: 0px 0 25px;
          text-align: center;
      }
      #service_flow .flowBox h3:after {
          border-top: #e5e8ef 1px dotted
      }
      #service_flow .flowArea .txtArea {
          margin: 15px auto 0;
  /*         font-size: 15px;
          text-align: left; */
      }





  }

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

      /* margin: 10px;
      font-size: 0;
      display: flex;
  */
  }


  /* ul.circle */

  ul.circle {
      margin: 0;
      padding: 0 0 0 0px;
      /*     list-style: circle; */
      font-size: 14px;
      text-align: left;
  }

  ul.circle li {
      margin-top: 3px;
      font-size: 15px;
      font-weight: 500;
      letter-spacing: 0.3em;
      line-height: 1.4;
      font-feature-settings: "palt" 1;
  }

  ul.circle li span{font-size:0.9em; color:#167c3b}



  ul.circle li img {
      width: 90%;
      margin: 0 auto;
  }

  @media only screen and (max-width: 900px) {
      ul.circle li {
          font-size: 13px;
      }
  }

  @media only screen and (max-width: 738px) {
      ul.circle li {
          font-size: 12px;
      }
  }




/* ----------------------------------------------------------
   .headline
   ---------------------------------------------------------- */

.headline_pro {
    margin-bottom: 50px;
    text-align: center;
    position: relative;
    z-index: 1;
}

.headline_pro h2.en {
    /* font-size: 35px; */
    /* font-family: 'Poppins', sans-serif; */
    /* font-weight: 700; */
    /* letter-spacing: 2px; */
    /* line-height: 1; */
}

.headline_pro h2.jp {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 1.5;
    margin-top: 15px;
}

@media only screen and (max-width: 900px) {
    .headline_pro {
        margin-bottom: 45px;
    }
    .headline_pro h2.en {
        font-size: 30px;
    }
    .headline_pro h2.jp {
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 1px;
        line-height: 1;
        margin-top: 15px;
    }
}

@media only screen and (max-width: 736px) {
    .headline_pro {
        margin-bottom: 40px;
    }
    .headline_pro h2.en {
        font-size: 25px;
    }
    .headline_pro h2.jp {
        font-size: 13px;
        margin-top: 10px;
    }
}

@media only screen and (max-width: 414px) {
    .headline_pro h2.jp {
        font-size: 12px;
    }
}




/* -----------------------------------------------------------
   #service_flow
   ----------------------------------------------------------- */

   #service_flow {
    padding: 90px 3%;
    /* background: url(../images/common/noise.png) repeat #f5f5f5; */
    width: 100%;
    background: #f5f5f5;
    /* max-width: 1300px; */
    margin: 60px auto;
    margin-top: 0;
}

@media only screen and (max-width: 900px) {
    #service_flow {
        padding: 80px 5%;
    }
}

@media only screen and (max-width: 736px) {
    #service_flow {
        padding: 70px 5%;
    }
}

@media only screen and (max-width: 500px) {
    #service_flow {
        padding: 70px 8%;
    }
}




/* --------- .flowArea --------- */

#service_flow .flowArea {
    margin: -10px;
    font-size: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto;
}

#service_flow .flowBox {
    /* display: inline-block; */
    margin: 0;
    border: #f5f5f5 10px solid;
    width: 33.333%;
    text-align: center;
    /* position: relative; */
    z-index: 2;
    padding: 0%;
    background: #fff;
    /* flex: 1 0 33.3333%; */
}


/* .inner */

#service_flow .flowBox .inner {
    padding: 35px 5% 50px;
    /* background: #fefefe; */
}

#service_flow .flowBox .inner img{
  width:100%;
}




/* h3 */

#service_flow .flowBox h3 {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 1px;
    position: relative;
    z-index: 3;
    line-height: 1;
    padding: 15px 0 15px;
    text-align: center;
}


#service_flow .flowBox h3:before {
    font-family: 'Font Awesome 6 pro';
    padding-right:10px;
    font-size:20px;
    color: #141414;
}



#service_flow .flowBox h3:before{
  content: "\e100";
}





#service_flow .flowBox h3:before {

/*     width: 1200px;
    height: 60px;
    line-height: 62px;
    color: #fefefe;
    font-size: 25px;
    background: #167c3b;
  border-radius:50%; */
}






/* #service_flow .flowBox:nth-child(1) h3:before {
    content:'\f178';

}

#service_flow .flowBox:nth-child(2) h3:before {

      content:'\f433';
}

#service_flow .flowBox:nth-child(3) h3:before {
    content: "\f51c";
}

#service_flow .flowBox:nth-child(4) h3:before {
    content: "\f685";
  f685
}

#service_flow .flowBox:nth-child(5) h3:before {
    content: "5";
}

#service_flow .flowBox:nth-child(6) h3:before {
    content: "\f1b9";
}
 */






#service_flow .flowBox h3:after {
    position: absolute;
    bottom: 0;
    left: 25px;
    right: 25px;
    height: 0;
    content: "";
    border-top: #e5e8ef 1px solid;
    z-index: 2;
}


/* .txtArea */

#service_flow .flowArea .txtArea {
    display: inline-block;
    margin: 20px auto 0;
}
#service_flow .flowArea .txtArea img {
  width:100%;
}

@media only screen and (max-width: 900px) {
    #service_flow .flowBox .inner {
        padding: 30px 5% 45px;
    }
    #service_flow .flowBox h3 {
        font-size: 16px;
        padding: 55px 0 30px;
    }
    #service_flow .flowBox h3:before {
        /* margin-left: -20px; */
        width: 40px;
        height: 40px;
        line-height: 42px;
        font-size: 20px;
    }
    #service_flow .flowBox h3:after {
        left: 5%;
        right: 5%;
    }
}

@media only screen and (max-width: 768px) {
    #service_flow .flowBox {
        width: 50%;
    }
}

@media only screen and (max-width: 736px) {
    #service_flow .flowArea {
      flex-direction:column;
    }
    #service_flow .flowBox {
        display: block;
        margin-top: 50px;
        border: none;
        width: 100%;
        text-align: center;
    }
/*     #service_flow .flowBox:after {
        position: absolute;
        bottom: -50px;
        right: 0;
        left: 0;
        height: 50px;
        line-height: 50px;
        font-size: 20px;
        font-family: themify;
        content: "\e62a";
        z-index: 1; */
    }
    #service_flow .flowBox:last-child:after {
        display: none;
    }
    /* .inner */
    #service_flow .flowBox .inner {
        padding: 35px 5%;
        /* border: #e5e8ef 1px solid; */
    }

   /* h3 */
    #service_flow .flowBox h2 {
        font-size: 18px;
        padding: 0px 0 25px;
        text-align: center;
        font-family: "Century Gothic", sans-serif;
    }


    /* h3 */
    #service_flow .flowBox h3 {
        font-size: 18px;
        padding: 0px 0 25px;
        text-align: center;
    }
    #service_flow .flowBox h3:after {
        border-top: #e5e8ef 1px dotted
    }
    #service_flow .flowArea .txtArea {
        margin: 15px auto 0;
/*         font-size: 15px;
        text-align: left; */
    }





}

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

    /* margin: 10px;
    font-size: 0;
    display: flex;
*/
}


/* ul.circle */

ul.circle {
    margin: 0;
    padding: 0 0 0 0px;
    /*     list-style: circle; */
    font-size: 14px;
    text-align: left;
}

ul.circle li {
    margin-top: 3px;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.3em;
    line-height: 1.4;
    font-feature-settings: "palt" 1;
}

ul.circle li span{font-size:0.9em; color:#167c3b}



ul.circle li img {
    width: 90%;
    margin: 0 auto;
}

@media only screen and (max-width: 900px) {
    ul.circle li {
        font-size: 13px;
    }
}

@media only screen and (max-width: 738px) {
    ul.circle li {
        font-size: 12px;
    }
}



.l-recommend {
  min-width: 960px;
  /* width: 87%; */
  position: relative;
  top: 100px;
  /* background-color: #fff; */
}

.l-recommend__space {
  width: 100%;
  max-width: 1260px;
  /* height: 160px; */
  padding-bottom: 0;
  align-items: center;
  margin: 0 auto;
}

.l-recommend__img>img {
  width: 100%
}

.l-recommend__items {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  max-width: 800px;
  padding: 0 20px;
  margin: 0 auto;
  background: none;
}

.l-recommend__item {
  flex-basis: 31%;
}

.l-recommend__btn {
  background-color: #221815;
  color: #fff;
  display: inline-block;
  text-align: center;
  width: 100%;
  max-width: 300px;
  height: 60px;
  line-height: 60px;
  border-radius: 30px
}

.l-recommend__btn:hover {
  background-color: transparent;
  color: #221815;
  border: 1px solid #221815
}

.c-banner {
  width: 100%;
  height: 720px;
  background-image: url("../img/layout/banner/banner.jpg");
  background-size: cover;
  background-position: 50%;
  position: relative
}

.c-banner__group {
  position: absolute;
  top: 95px;
  left: 180px;
  color: #fff
}

.c-banner__content {
  margin-bottom: 80px
}

.c-banner__btn {
  background-color: #000;
  color: #fff;
  display: inline-block;
  width: 500px;
  height: 80px;
  line-height: 80px;
  text-align: center;
  font-size: 1.8rem;
  border-radius: 40px
}

.c-banner__btn:hover {
  background-color: transparent;
  color: #000;
  border: 1px solid #000
}

@media (max-width: 959px) {
  .c-banner {
    height: calc(360px + (100vw - 320px)/1.5)
  }
  .c-banner__group {
    left: 10%;
    top: 25%;
    width: 82%
  }
  .c-banner__content {
    margin-bottom: 9vw
  }
  .c-banner__btn {
    width: 100%;
    height: 13vw;
    line-height: 13vw;
    border-radius: 6.5vw;
    font-size: 3.2vw
  }
}

.c-applyBtn-sm {
  background-color: #221815;
  color: #fff;
  display: inline-block;
  width: 160px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  border-radius: 20px
}

.c-applyBtn-sm:hover {
  background-color: #fff;
  color: #221815;
  border: 1px solid #221815
}

.c-headerBtn {
  /* position: absolute; */
  /* top: 0; */
  /* right: 0; */
  /* width: 60px; */
  /* height: 60px; */
  /* background-color: #221815; */
  /* color: #fff; */
  /* text-align: center; */
}

.c-headerBtn>i {
  font-size: 4rem;
  line-height: 60px;
}

.c-closeBtn {
  /* position: absolute; */
  /* top: 0; */
  /* right: 0; */
  /* width: 60px; */
  /* height: 60px; */
  /* background-color: #221815; */
  /* z-index: 101; */
}

.c-closeBtn>i {
  /* color: #fff; */
  /* font-size: 3.6rem; */
  /* line-height: 40px; */
}

button[disabled] {
  color: #fff;
  background-color: #c0c0c0;
  cursor: not-allowed;
  opacity: 0.65
}

@media (max-width: 959px) {
  .c-applyBtn-sp {
    margin: 0 auto;
    background-color: #221815;
    color: #fff;
    width: 80%;
    max-width: 400px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    border-radius: 25px;
    margin-bottom: 6vh
  }
}

.c-cookiearea {
  position: fixed;
  z-index: 9999;
  bottom: 0;
  width: 100%;
  box-sizing: border-box;
  background-color: rgba(0, 0, 0, 0.85);
  color: white;
  line-height: 1.5
}

.c-cookiearea__inner {
  position: relative;
  margin: 0 auto
}

.c-cookiearea__inner>p {
  max-width: 960px;
  padding: 20px 40px;
  margin: auto;
  font-size: 1.4rem
}

.c-cookiearea__inner>p>a {
  text-decoration: underline
}

.c-cookiearea__inner__close {
  position: absolute;
  top: 10px;
  right: 10px
}

.c-cookiearea__inner__close:hover {
  cursor: pointer
}

.c-divide {
  width: 0;
  height: 25px;
  vertical-align: text-bottom;
  display: inline-flex;
  max-height: 100%;
  align-self: stretch;
  position: relative;
  top: 6px;
  margin: 0 10px
}

.c-flex {
  display: flex
}

.c-flex-r {
  display: flex;
  flex-direction: row-reverse
}

.c-flexAll {
  display: flex
}

.c-flex1 {
  flex: 1 1 auto
}

.c-flex-ac {
  align-items: center
}

.c-flex-fs {
  align-items: flex-start
}

.c-flex-ab {
  align-items: baseline
}

@media (max-width: 959px) {
  .c-flex {
    flex-direction: column
  }
  .c-flex-r {
    flex-direction: column
  }
}

.c-hero {
  position: relative;
  text-align: center
}

.c-heroText {
  position: absolute;
  top: -101px;
  left: calc(5% - 15px);
  text-align: left;
  color: #fff;
  border-left: 30px solid #221815;
  padding: 60px 0 30px 53px
}

.c-heroText__title {
  font-size: 2.8rem
}

.c-heroText__content {
  margin-top: 35px;
  font-size: 1.8rem
}

.c-heroBackground {
  width: 90%;
  height: 438px;
  position: absolute;
  top: -216px;
  left: 5%;
  background-size: cover;
  background-position: 50%
}

.c-heroBackground__commitment {
  background-image: url("../img/commitment/hero.jpg")
}

.c-heroBackground__science {
  background-image: url("../img/science/hero.jpg")
}

.c-heroBackground__flow {
  background-image: url("../img/flow/hero.jpg")
}

.c-heroBackground__plan {
  background-image: url("../img/plan/hero.jpg")
}

.c-heroBackground__product {
  background-image: url("../img/product/hero.jpg")
}

.c-heroBackground__service {
  background-image: url("../img/service.jpg");
  height: calc(100vw*0.3);
  max-height: 438px
}

.c-heroBackground__sports {
  background-image: url("../img/sports.jpg?202302-1");
  height: calc(100vw*0.3);
  max-height: 438px
}

.c-heroBackground__kansaibou {
  background-image: url("../img/kansaibou.jpg");
  height: calc(100vw*0.3);
  max-height: 438px
}





.c-heroBackground__este {
  background-image: url("../img/menu_head.jpg");
  height: calc(100vw*0.3);
  max-height: 438px
}

.c-heroBackground__education {
  background-image: url("../img/education.jpg");
  height: calc(100vw*0.3);
  max-height: 438px
}



.c-heroBackground__faq {
  background-image: url("../img/faq/hero.jpg")
}

.c-heroSVG {
  position: relative;
  z-index: 1;
  transform: translateY(-50%)
}

.c-heroDown {
  padding-top: 254px
}

@media (max-width: 959px) {
  .c-hero {
    background: #fff;
    padding-top: 30px
  }
  .c-heroBackground {
    left: auto;
    top: 0;
    width: 100%;
    height: 75vw;
    margin-top: 30px !important
  }
  .c-heroBackground__commitment {
    background-position: 75% 50%
  }
  .c-heroBackground__science {
    background-image: url("../img/science/hero_sp.jpg")
  }
  .c-heroBackground__productEyelashserum {
    background-position: right 20% top 0
  }
  .c-heroBackground__faq {
    background-position: 75% 50%
  }
  .c-heroText {
    top: 18vw;
    left: 0;
    border-left: 10px solid #221815;
    padding: calc(17px + (100vw - 320px)/32) 20% calc(17px + (100vw - 320px)/32) calc(17px + (100vw - 320px)/32)
  }
  .c-heroText__title {
    font-size: calc(16px + (100vw - 320px)/30)
  }
  .c-heroText__content {
    margin-top: 15px;
    font-size: calc(12px + (100vw - 320px)/50)
  }
  .c-heroSVG {
    height: auto;
    max-width: 90vw;
    transform: translateY(-38%)
  }
  .c-heroDown {
    padding-top: 0
  }
}

.c-logoutIcon {
  position: relative;
  top: 8px;
  margin-right: 5px
}

.c-shoppingCartIcon {
  position: relative;
  top: 8px;
  margin-right: 0
}

.c-headerIcon {
  margin: auto;
  display: flex;
  flex-direction: column;
  position: absolute;
  top: 65px;
  right: 5px;
  transition: 0.2s
}

.c-headerIcon>a {
  color: #333;
  flex: 1;
  font-size: 1rem;
  padding: 0;
  align-self: left
}

.c-headerIcon>a:last-child {
  padding-top: 15px
}

.c-headerIcon>a>i {
  font-size: 3rem
}

.c-msgIcon {
  color: #221815;
  opacity: .7;
  margin-right: 5px
}

.c-head {
  margin-bottom: 50px
}

.c-mypageLink {
  color: #221815
}

.c-mypageLink:hover {
  opacity: .6
}

.c-globalLink {
  color: #221815;
  padding: 10px 2px;
  transition: .3s;
  position: relative
}

.c-globalLink:before {
  position: absolute;
  top: 32px;
  left: 0;
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background: #221815;
  transition: .3s
}

.c-globalLink__active:before {
  width: 100% !important
}

.c-globalLink:hover:before {
  width: 100% !important
}

.c-globalLink_drop {
  color: #221815;
  padding: 10px 2px;
  position: relative;
  cursor: pointer
}

.c-globalLink_drop:before {
  position: absolute;
  top: 32px;
  left: 0;
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background: #221815
}

.c-globalLink_drop:after {
  content: 'expand_more';
  font-family: "Material Icons";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  right: -15px
}

@media (max-width: 1199px) {
  .c-globalLink_drop:after {
    right: -12px
  }
}

.c-linkIcon {
  position: relative;
  top: 6px
}

.c-siteLogo {
  /* width: 150px; */
  /* height: 110px; */
  /* background-image: url("../../common/img/layout/header/logo.svg"); */
  /* background-size: contain; */
  /* text-indent: 100%; */
  /* overflow: hidden; */
  /* display: block; */
  /* transition: 0.2s; */
}

.c-siteLogo:hover {
  opacity: .6
}
/*
.c-footerLogo {
  margin: 10px auto 10px;
  width: 180px;
  height: 99px;
  background-image: url("../img/layout/footer/footer_logo.svg");
  background-size: contain;
  text-indent: 100%;
  overflow: hidden;
  display: block
} */

.c-footerLogo:hover {
  opacity: .6
}

.c-mask {
  height: 101%;
  width: 45%;
  background-color: #fff;
  z-index: 1
}

.c-maskLeft {
  position: absolute;
  left: 0
}

.c-maskRight {
  position: absolute;
  right: 0
}

.c-maskContainer {
  width: 100%;
  position: relative
}

.js-maskActive {
  width: 0;
  transition: width 1.5s
}

.c-myBtn-r1 {
  background-color: #A82228;
  color: #fff;
  display: inline-block;
  width: 280px;
  height: 50px;
  font-size: 1.4rem;
  line-height: 48px;
  text-align: center;
  border-radius: 5px
}

.c-myBtn-r2 {
  border: 1px solid rgba(168, 34, 40, 0.5);
  color: #A82228;
  display: inline-block;
  width: 280px;
  height: 50px;
  font-size: 1.4rem;
  line-height: 48px;
  text-align: center;
  border-radius: 5px
}

.c-myBtn-b {
  border: 1px solid #919191;
  color: #313131;
  display: inline-block;
  width: 280px;
  height: 50px;
  font-size: 1.4rem;
  line-height: 48px;
  text-align: center;
  border-radius: 5px
}

.c-myBtn-agree {
  color: #A82228;
  text-decoration: underline
}

@media (max-width: 959px) {
  .c-myBtn-r1 {
    width: 100%;
    height: 50px;
    line-height: 48px
  }
  .c-myBtn-r2 {
    width: 100%;
    height: 50px;
    line-height: 48px
  }
  .c-myBtn-b {
    width: 100%;
    height: 50px;
    line-height: 48px
  }
}

@media (min-width: 960px) {
  .c-myBtn-r1:hover {
    opacity: .5
  }
  .c-myBtn-r2:hover {
    background-color: rgba(168, 34, 40, 0.1)
  }
  .c-myBtn-b:hover {
    background-color: #f4f4f4
  }
}

.c-mySelectBox {
  position: relative;
  cursor: pointer;
  display: inline-block;
  font-size: 1.3rem;
  border-radius: 5px;
  width: 100%;
  height: 50px
}

.c-mySelectBox::after {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 1.8em;
  height: 100%;
  pointer-events: none;
  font-size: 3.6rem;
  background: url(../img/mypage/select.svg) no-repeat;
  background-position: center;
  content: '';
  text-align: center;
  color: var(--grayscale-darker);
  vertical-align: middle;
  border-left: 1px solid transparent;
  border-radius: 5px
}

.c-mySelectBox>select {
  border: 1px solid #919191;
  border-radius: 4px;
  background-color: #fff;
  width: calc(100%);
  height: 100%;
  padding: 0 15px;
  line-height: 2.4em;
  cursor: pointer;
  font-size: 16px
}

.c-myTextInput {
  width: 100%;
  max-width: 100%;
  height: 50px;
  border: 1px solid #919191;
  border-radius: 5px;
  padding: 0 15px;
  font-size: 16px
}

.c-myTextInput:placeholder-shown {
  background-color: #fff
}

.c-myTextInput::placeholder {
  color: #919191
}

.p-shopping__grey .c-myTextInput {
  background-color: #fff
}

.c-myTextArea {
  width: 100%;
  max-width: 100%;
  height: 224px;
  border: 1px solid #919191;
  border-radius: 5px;
  padding: 15px;
  font-size: 16px;
  resize: none
}

.c-myTextArea:placeholder-shown {
  background-color: #fff
}

.c-myTextArea::placeholder {
  color: #919191
}

.c-myRadio:checked, .c-myRadio:not(:checked) {
  display: none
}

.c-myRadio:checked+label, .c-myRadio:not(:checked)+label {
  position: relative;
  padding-left: 22px;
  cursor: pointer;
  line-height: 20px;
  display: inline-block;
  color: #666
}

.c-myRadio:checked+label:before, .c-myRadio:not(:checked)+label:before {
  content: '';
  position: absolute;
  left: 0;
  top: 2px;
  width: 18px;
  height: 18px;
  border: 1px solid #919191;
  border-radius: 100%;
  background: #fff
}

.c-myRadio:checked+label:after, .c-myRadio:not(:checked)+label:after {
  content: '';
  width: 10px;
  height: 10px;
  background: #A82228;
  position: absolute;
  top: 6px;
  left: 4px;
  border-radius: 100%;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease
}

.c-myRadio:not(:checked)+label:after {
  opacity: 0;
  -webkit-transform: scale(0);
  transform: scale(0)
}

.c-myRadio:checked+label:after {
  opacity: 1;
  -webkit-transform: scale(1);
  transform: scale(1)
}

.c-myCheckbox {
  display: inline-block;
  min-height: 16px
}

.c-myCheckbox>input {
  position: absolute;
  opacity: 0;
  width: 0
}

.c-myCheckbox__text {
  box-sizing: border-box;
  position: relative;
  display: inline-block;
  padding-left: 22px;
  vertical-align: middle;
  cursor: pointer;
  line-height: 1.4rem;
  vertical-align: middle
}

.c-myCheckbox__text::before {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  margin-top: -6px;
  width: 14px;
  height: 14px;
  border: 1px solid #919191;
  border-radius: 0;
  background-color: #fff;
  content: '';
  transition: all .3s
}

.c-myCheckbox__text::after {
  font-family: "Material Icons", sans-serif;
  font-feature-settings: 'liga';
  content: 'check';
  font-size: 2.2rem;
  position: absolute;
  width: 1em;
  height: 1em;
  top: 50%;
  left: 9px;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: all .3s;
  color: #A82228;
  line-height: 1
}

.c-myCheckbox>input:checked+.c-myCheckbox__text::after {
  opacity: 1;
  transition: opacity .3s
}

.c-myCheckbox>input:checked+.c-myCheckbox__text::before {
  transition: all .3s
}

.is-invalid {
  border: 1px solid #221815;
  background-color: #FFEAEA !important
}

@media (max-width: 959px) {
  .c-mySelectBox {
    height: 50px
  }
  .c-mySelectBox::after {
    width: 1em;
    line-height: 1.4
  }
  .c-mySelectBox>select {
    padding: 0 10px
  }
  .c-myTextInput {
    height: 50px;
    padding: 0 10px
  }
  .c-myTextArea {
    height: 128px
  }
}

.c-myHeading1 {
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.5;
  border-bottom: 1px solid #919191;
  margin: 0;
  padding-bottom: 8px
}

.c-myHeading2 {
  width: 100%;
  font-size: 1.6rem;
  padding: 8px 20px;
  background-color: #f4f4f4
}

.c-myHeading3 {
  width: 100%;
  font-size: 1.6rem;
  line-height: 1.5;
  padding-bottom: 6px;
  border-bottom: 1px solid #919191
}

.c-myHeading4 {
  width: 100%;
  font-size: 1.4rem;
  padding: 6px 20px;
  background-color: #f4f4f4
}

.c-myHeading5 {
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.5;
  margin: 0;
  padding-bottom: 8px
}

.c-myHeading5>span {
  font-weight: normal
}

.c-myLink {
  color: #A82228;
  text-decoration: underline
}

.c-myLink:hover {
  color: #313131
}

.c-myCaption {
  font-size: 1.2rem
}

.c-roboto {
  font-family: "Roboto", Arial, Helvetica, sans-serif
}

.c-myDivider {
  border-width: 1px 0 0 0;
  border-top: 1px solid #e5e5e5;
  width: 100vw;
  margin: 20px auto
}

.c-myDivider-thin {
  border-width: 1px 0 0 0;
  border-top: 1px solid #e5e5e5
}

.c-myText--red {
  color: #A82228
}

.c-myText--wrap {
  white-space: pre-wrap
}

@media (max-width: 959px) {
  .c-myHeading1 {
    font-size: 1.8rem;
    line-height: 27.5px;
    margin: 0
  }
  .c-myHeading2 {
    font-size: 1.6rem;
    padding: 6.5px 10px
  }
  .c-myHeading3 {
    font-size: 1.6rem;
    line-height: 25.5px;
    margin: 0
  }
  .c-myHeading4 {
    font-size: 1.4rem;
    padding: 4.5px 10px
  }
  .c-myDivider {
    width: 100%
  }
}

.c-cart_number {
  background-color: #eee;
  border-radius: 50%;
  display: inline-block;
  width: 26px;
  height: 26px;
  line-height: 26px;
  text-align: center;
  margin-left: -5px
}

.c-pagination {
  width: 100%;
  text-align: center
}

.c-pagination>div {
  display: inline-block
}

.c-pagination>div>.c-myBtn-r1 {
  width: 36px;
  height: 36px;
  line-height: 36px;
  font-size: 14px
}

.c-pagination>div>.c-myBtn-r1>i {
  top: 7px
}

.c-pagination__numbers {
  display: inline-block
}

.c-pagination__numbers>* {
  color: #A82228;
  margin-left: 20px
}

.c-pagination__numbers>*:first-child {
  margin-left: 25px
}

.c-pagination__numbers>*:last-child {
  margin-right: 25px
}

.c-pagination__number {
  text-decoration: underline
}

.c-pagination__number.active {
  color: #919191;
  text-decoration: none
}

@media (max-width: 959px) {
  .c-pagination>div>.c-myBtn-r1 {
    width: 32px;
    height: 32px;
    line-height: 32px
  }
  .c-pagination>div>.c-myBtn-r1>i {
    top: 4px
  }
}

@media (min-width: 960px) {
  .c-pagination__number:not(.active):hover {
    opacity: .5
  }
}

.c-steps {
  max-width: 100%;
  display: flex;
  justify-content: space-between;
  list-style: none;
  position: relative
}

.c-steps:before {
  position: absolute;
  width: 90%;
  top: 26px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  height: 2px;
  background: #707070;
  z-index: 0;
  content: ""
}

.c-step {
  width: 52px;
  height: 52px;
  line-height: 50px;
  color: #707070;
  border: 1px solid #707070;
  border-radius: 26px;
  background-color: #fff;
  position: relative;
  text-align: center;
  font-size: 2.6rem
}

.c-step>span {
  position: absolute;
  top: 44px;
  left: -49px;
  font-size: 1.2rem;
  line-height: unset;
  width: 150px
}

.c-step.active {
  background-color: #A82228;
  border-color: #A82228;
  color: #fff
}

.c-step.active>span {
  color: #A82228
}

@media (max-width: 959px) {
  .c-steps {
    width: 300px;
    margin: auto
  }
  .c-steps:before {
    height: 1px;
    top: 15px
  }
  .c-step {
    width: 30px;
    height: 30px;
    line-height: 28px;
    font-size: 1.6rem
  }
  .c-step>span {
    width: 75px;
    top: 27px;
    left: -24px;
    font-size: 1rem
  }
}

@media all and (-ms-high-contrast: none) {
  .c-step:first-child {
    margin-left: -20%
  }
}

.c-heading {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: calc(30px + (100vw - 960px) / 60);
  text-align: center;
  padding: 80px 0 60px 0
}

.c-title {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: calc(22px + (100vw - 960px) / 60);
  border-bottom: 1px solid #ddd;
}

.c-title2 {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: calc(20px + (100vw - 960px) / 60)
}

.c-info {
  margin-bottom: 50px;
  font-size: calc(16px + (100vw - 960px) / 240)
}

.c-content {
  margin-top: 20px;
  font-size: calc(14px + (100vw - 960px) / 240);
  line-height: 2;
  margin-bottom: 40px;
}

.c-content2 {
  margin-top: 50px;
  font-size: calc(12px + (100vw - 960px) / 240)
}

.c-caption {
  margin-top: 50px;
  font-size: calc(10px + (100vw - 960px) / 240)
}

.c-caption2 {
  margin-top: 50px;
  font-size: calc(12px + (100vw - 960px) / 240)
}

.c-detailTitle {
  font-size: 1.8rem
}

.c-detailContent {
  margin-top: 30px;
  font-size: 1.4rem
}

.c-fontYo {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif
}

.c-font-Go {
  font-family: 'Noto Sans JP', 游ゴシック, 游ゴシック体, “Yu Gothic”, “MS Pゴシック“, “MS PGothic”, sans-serif
}

.c-text--bold {
  font-weight: bold
}

.c-color-red {
  color: #000000;
}

.c-text--required {
  color: #A82228;
  font-size: 1rem;
  margin-left: 10px
}

.c-text--required-next {
  color: #A82228;
  font-size: 1rem
}

label.error {
  font-size: 1.2rem;
  color: #A82228;
  display: block
}

input.error {
  background-color: #FFEAEA !important;
  border: 1px solid #A82228 !important
}

textarea.error {
  background-color: #FFEAEA !important;
  border: 1px solid #A82228 !important
}

select.error {
  background-color: #FFEAEA !important;
  border: 1px solid #A82228 !important
}

.js-liner {
  display: inline;
  position: relative;
  background-image: linear-gradient(90deg, #000000, #000000);
  background-repeat: no-repeat;
  background-position: bottom left;
  background-size: 0 1px;
  transition: all 1s ease-in-out;
  padding-bottom: 0
}

.js-liner.is-inview {
  background-size: 100% 1px
}

.js-marker {
  display: inline;
  position: relative;
  background-image: linear-gradient(90deg, #fde7e7, #fde7e7);
  background-repeat: no-repeat;
  background-position: bottom left;
  background-size: 0 90%;
  transition: all 1s ease-in-out
}

.js-marker.is-inview {
  background-size: 100% 90%
}

@media (min-width: 1601px) {
  .c-heading {
    font-size: 4rem
  }
  .c-title {
    font-size: 3.6rem
  }
  .c-title2 {
    font-size: 3.2rem
  }
  .c-info {
    font-size: 2.1rem
  }
  .c-content {
    font-size: 1.8rem
  }
  .c-content2 {
    font-size: 1.6rem
  }
  .c-caption {
    font-size: 1.4rem
  }
  .c-caption2 {
    font-size: 1.5rem
  }
}

@media (max-width: 1199px) {
  .c-content {
    margin-top: 30px
  }
  .c-content2 {
    margin-top: 30px
  }
  .c-caption {
    margin-top: 30px
  }
  .c-caption2 {
    margin-top: 30px
  }
}

@media (max-width: 959px) {
  .c-heading {
    font-size: calc(18px + (100vw - 320px) / 28);
    padding: 50px 0 25px 0
  }
  .c-title {
    font-size: calc(16px + (100vw - 320px) / 28)
  }
  .c-title2 {
    font-size: calc(16px + (100vw - 320px) / 40)
  }
  .c-info {
    margin-bottom: 4.8vw;
    font-size: calc(12px + (100vw - 320px) / 40)
  }
  .c-content {
    margin-top: 2.8vw;
    font-size: calc(12px + (100vw - 320px) / 40);
    margin-bottom: 7.8vw;
  }
  .c-content2 {
    margin-top: 4.8vw;
    font-size: calc(12px + (100vw - 320px) / 56)
  }
  .c-caption {
    margin-top: 4.8vw;
    font-size: calc(10px + (100vw - 320px) / 56)
  }
  .c-caption {
    margin-top: 4.8vw;
    font-size: calc(11px + (100vw - 320px) / 56)
  }
  .c-detailTitle {
    font-size: 1.6rem
  }
  .c-detailContent {
    margin-top: 15px;
    font-size: 1.2rem
  }
  .c-text--required-next {
    display: inline
  }
}

.p-404__title {
  color: #221815
}

.p-404__msg {
  margin-top: 30px
}

.p-404__mail {
  color: #A82228;
  text-decoration: underline
}

.p-404__mail:hover {
  color: #313131
}

.p-404__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 35px;
  display: inline-block
}

.p-404__link:hover {
  color: #313131
}

.p-404__btn {
  margin-top: 50px
}

@media (min-width: 960px) {
  .p-404 {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-404__msg {
    margin-top: 20px
  }
}

.p-application {
  background-color: #fff;
  margin: 100px auto 0
}

.p-application__header {
  margin-bottom: 0;
  background-color: #221815;
  height: 300px;
  position: relative;
  display: flex;
  align-items: center
}

.p-application__header__product {
  flex-basis: 30%
}

.p-application__header__images {
  width: 200px;
  max-width: 100%;
  position: relative;
  top: -210px;
  margin: 0 0 0 auto;
  border-radius: 45px 45px;
  box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -webkit-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -moz-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -o-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5)
}

.p-application__header__frame {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2
}

.p-application__header__screen {
  width: 97%;
  position: absolute;
  top: 3px;
  left: 3px;
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0)
}

.p-application__header__screen.js-isActive {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  filter: alpha(opacity=1)
}

.p-application__header__text {
  color: #fff;
  flex-basis: 70%
}

.p-application__header__textGroup {
  width: 100%;
  padding: 0 0 0 12.5%
}

.p-application__header__title {
  font-size: 3.2rem;
  font-weight: normal;
  margin-bottom: 0px
}

.p-application__contents {
  background-color: #eee;
  padding: 100px 0
}

.p-application__contents__msg {
  background-color: #fff;
  padding: 50px;
  width: 80%;
  max-width: 640px;
  margin: 0 auto 50px;
  text-align: left;
  font-size: 1.6rem
}

.p-application__contents__msg>h3 {
  margin-bottom: 16px;
  text-align: center
}

.p-application__contents__install {
  padding: 0 80px
}

.p-application__contents__install__inner {
  background-color: #fff;
  margin: 50px auto 150px;
  padding: 40px;
  position: relative;
  text-align: center
}

.p-application__contents__install__inner>h3 {
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  text-align: center;
  font-size: 2rem;
  width: 340px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-application__contents__install__inner>p {
  margin: 50px auto 20px;
  font-size: 1.6rem
}

.p-application__contents__install__inner>.Logo__iOS>img {
  width: 240px
}

.p-application__contents__install__inner>.Logo__iOS>img:hover {
  opacity: .8
}

.p-application__contents__install__inner>.Logo__Android>img {
  width: 240px
}

.p-application__contents__install__inner>.Logo__Android>img:hover {
  opacity: .8
}

.p-application__contents__install__innerBtn {
  width: 300px;
  margin: 20px auto 40px
}

.p-application__contents__install__innerAndroid {
  width: 80%;
  margin: auto;
  font-size: 1.6rem;
  text-align: left
}

.p-application__contents__install__innerAndroid>h4 {
  margin: 0 50px 20px;
  border-bottom: 1px solid #ccc;
  padding-bottom: 3px;
  font-size: 1.8rem
}

.p-application__contents__install__innerAndroid>p {
  padding: 0 50px;
  margin-bottom: 30px
}

.p-application__contents__install__innerAndroid__steps {
  list-style: none
}

.p-application__contents__install__innerAndroid__steps>li {
  position: relative;
  padding-left: 50px;
  margin-bottom: 50px
}

.p-application__contents__install__innerAndroid__steps>li:before {
  font-size: 2rem;
  font-family: Didot, "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  color: #fff;
  background: #A82228;
  border-radius: 30px;
  width: 30px;
  height: 30px;
  line-height: 32px;
  text-align: center;
  position: absolute;
  left: 0
}

.p-application__contents__install__innerAndroid__steps>li.step1:before {
  content: '1'
}

.p-application__contents__install__innerAndroid__steps>li.step2>ul {
  margin: 20px 0 0 20px;
  list-style-type: decimal
}

.p-application__contents__install__innerAndroid__steps>li.step2>ul>li {
  margin-bottom: 20px
}

.p-application__contents__install__innerAndroid__steps>li.step2:before {
  content: '2'
}

.p-application__contents__install__innerAndroid__steps>li.step3:before {
  content: '3'
}

@media (max-width: 959px) {
  .p-application {
    margin-top: 0px
  }
  .p-application__header {
    height: 150px;
    margin-top: 40px
  }
  .p-application__header__product {
    flex-basis: 30%
  }
  .p-application__header__images {
    width: 100px;
    top: -110px
  }
  .p-application__header__text {
    flex-basis: 65%
  }
  .p-application__header__screen {
    top: 2px;
    left: 2px
  }
  .p-application__header__title {
    font-size: 2.4rem
  }
  .p-application__contents {
    padding: 60px 0
  }
  .p-application__contents__msg {
    padding: 20px 30px;
    margin: 0 auto
  }
  .p-application__contents__install {
    padding: 0
  }
  .p-application__contents__install__inner {
    padding: 40px 20px;
    margin-bottom: 100px
  }
  .p-application__contents__install__inner>p {
    text-align: left;
    margin-top: 20px
  }
  .p-application__contents__install__inner>h3 {
    width: 260px;
    font-size: 1.4rem;
    top: -20px;
    height: 40px;
    line-height: 40px
  }
  .p-application__contents__install__innerBtn {
    font-size: 2rem;
    height: 5rem;
    line-height: 5rem
  }
  .p-application__contents__install__innerAndroid {
    width: 100%
  }
  .p-application__contents__install__innerAndroid>h4 {
    margin: 0 auto 20px
  }
  .p-application__contents__install__innerAndroid>p {
    padding: 0
  }
  .p-application__contents__install__innerAndroid__steps>li {
    position: relative;
    padding-left: 34px
  }
  .p-application__contents__install__innerAndroid__steps>li:before {
    font-size: 1.6rem;
    border-radius: 24px;
    width: 24px;
    height: 24px;
    line-height: 24px
  }
}

.p-cart>.c-flex {
  margin-top: 40px;
  align-items: flex-start;
  flex-wrap: wrap
}

.p-cart__msg {
  padding: 10px;
  margin-bottom: 10px;
  background: #fff;
  border: 4px solid rgba(168, 34, 40, 0.2);
  box-sizing: border-box
}

.p-cart__msg>i {
  font-size: 1.6rem;
  vertical-align: middle
}

.p-cart__msg__last {
  margin-bottom: 25px
}

.p-cart__info {
  width: 100%
}

.p-cart__infoHeader {
  padding-bottom: 15px;
  border-bottom: 1px solid #d8d8d8
}

.p-cart__infoItem {
  font-size: 1.4rem;
  padding: 0 0 30px;
  margin-bottom: 30px;
  border-bottom: 1px solid #d8d8d8
}

.p-cart__infoItem__col1 {
  position: relative;
  padding-left: 30px;
  margin-right: 20px
}

.p-cart__infoItem__col1>img {
  width: 120px
}

.p-cart__infoItem__col2 {
  width: 100%;
  display: flex
}

.p-cart__infoItem__col2__1 {
  flex-basis: 65%;
  padding-right: 30px;
  align-self: flex-start
}

.p-cart__infoItem__col2__1>a>div {
  color: #A82228;
  text-decoration: underline;
  margin-bottom: 5px
}

.p-cart__infoItem__col2__1 p {
  margin-bottom: 5px
}

.p-cart__infoItem__col2__1__set {
  font-size: 1.2rem;
  font-weight: normal;
  line-height: 1.2;
  padding-left: 20px
}

.p-cart__infoItem__col2__1__listprice {
  font-size: 85%;
  color: #666;
  text-decoration: line-through;
  margin-bottom: 0 !important
}

.p-cart__infoItem__col2__1__delete {
  margin-top: 30px
}

.p-cart__infoItem__col2__1__delete>button {
  color: #A82228
}

.p-cart__infoItem__col2__2 {
  flex-basis: 35%;
  text-align: right
}

.p-cart__infoItem__col2__2>label {
  width: 100px;
  height: 50px;
  margin-bottom: 20px
}

.p-cart__infoItem__col2__2>label>select {
  padding: 0 15px
}

.p-cart__infoItem__col2__2>label:after {
  width: 1.3em
}

.p-cart__infoItem__col2__2 p {
  font-size: 1.4rem
}

.p-cart__infoItem__remove {
  background-image: url("../img/mypage/close.png");
  background-size: cover;
  width: 16px;
  height: 16px;
  cursor: pointer;
  position: absolute;
  top: 22px;
  left: 0
}

.p-cart__bill {
  width: 100%;
  border: 1px solid #919191;
  padding: 2%
}

.p-cart__billFlex {
  display: flex;
  margin-bottom: 15px;
  align-items: center
}

.p-cart__billTitle {
  flex: 1 1 auto
}

.p-cart__billGrey {
  text-align: center;
  width: 100%;
  padding: 10px 20px;
  font-size: 1.4rem;
  background-color: #f8f8f8;
  margin-top: 20px
}

.p-cart__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin: 25px 0 8px
}

.p-cart__billBox {
  margin: 40px auto
}

.p-cart__billBox>a {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-cart__billBox>a>i {
  font-size: 1.8rem
}

.p-cart__billOrder {
  width: 100%;
  margin: 0 auto 10px
}

.p-cart__billOrder__notice {
  text-align: center;
  font-size: 12px;
  line-height: 1.2;
  color: #333
}

.p-cart__billBack {
  width: 100%
}

.p-cart__billMaintenance {
  margin: 50px auto 10px;
  text-align: center;
  padding: 20px 10px;
  background: #f7e9ea
}

.p-cart__billPhone {
  background: #f6f6f6;
  padding: 30px 20px
}

.p-cart__billPhone__text {
  text-align: center;
  font-size: 16px;
  font-weight: bold
}

.p-cart__billPhone__contact {
  text-align: center;
  border: 1px solid #ddd;
  border-radius: 5px;
  background: #fff;
  font-size: 30px;
  font-weight: bold;
  line-height: 1;
  color: #333;
  display: block;
  padding: 10px 5px;
  margin-bottom: 10px
}

.p-cart__billPhone__contact>i {
  font-size: 26px;
  vertical-align: middle
}

.p-cart__billPhone__contactHours {
  font-size: 12px;
  font-weight: normal;
  color: #666
}

.p-cart__faq {
  width: 100%
}

.p-cart__faq>.c-accordion {
  margin: 1px auto
}

.p-cart__faq>.c-accordion>.c-accordion__header {
  font-size: 1.6rem;
  background: #faf4f4;
  color: #000
}

.p-cart__faq>.c-accordion>.c-accordion__contents>dl>dt {
  font-size: 1.4rem;
  background: #fff
}

.p-cart__noData__text {
  margin: 20px 0 40px
}

.p-cart__noData>.p-cart__faq {
  margin-top: 6rem
}

.p-cart__modalTitle {
  font-size: 2.2rem;
  margin: 0 auto 20px;
  text-align: center;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif
}

.p-cart__modalText {
  margin-bottom: 20px
}

.p-cart__modalText2 {
  color: #221815
}

.p-cart__modalBtn {
  border-radius: 50px;
  margin-bottom: 20px
}

.p-cart__modalBtn>i {
  vertical-align: middle
}

.p-cart__modalContact {
  border: 1px solid #c5c4c4;
  padding: 10px 15px;
  margin-bottom: 20px
}

.p-cart__modalContact__num {
  font-size: 2.2rem;
  text-align: center;
  margin-bottom: 10px
}

.p-cart__modalContact__num>i {
  vertical-align: middle
}

.p-cart__modalContact__time {
  font-size: 1.2rem;
  text-align: center;
  color: #666;
  margin-bottom: 0
}

@media (min-width: 960px) {
  .p-cart__inner {
    overflow: hidden
  }
  .p-cart__info {
    width: 65%;
    padding-right: 40px;
    float: left
  }
  .p-cart__title {
    margin-bottom: 25px
  }
  .p-cart__bill {
    width: 35%;
    top: 10px;
    padding-top: 30px;
    padding-bottom: 40px;
    border-radius: 4px;
    float: right
  }
  .p-cart__faq {
    width: 65%;
    margin-top: 30px;
    padding-right: 40px;
    float: left
  }
  .p-cart__noData__btn {
    color: #A82228;
    text-decoration: underline;
    display: inline-block
  }
  .p-cart__noData__btn>.c-linkIcon {
    font-size: 20px;
    top: 5px;
    right: 3px;
    opacity: .5
  }
  .p-cart__noData>.p-cart__faq {
    width: 100%;
    margin-top: 100px;
    padding-right: 0;
    float: none
  }
}

@media (max-width: 959px) {
  .p-cart>.c-flex {
    margin-top: 20px
  }
  .p-cart__title {
    margin-bottom: 20px
  }
  .p-cart__msg__last {
    margin-bottom: 20px
  }
  .p-cart__info {
    width: 100%
  }
  .p-cart__infoItem {
    height: auto;
    padding: 20px 0;
    margin-bottom: 0px;
    display: block
  }
  .p-cart__infoItem__col1 {
    width: auto;
    margin-right: 10px;
    float: left
  }
  .p-cart__infoItem__col1>img {
    width: 60px
  }
  .p-cart__infoItem__col2 {
    display: block;
    padding: 0
  }
  .p-cart__infoItem__col2>a>div {
    line-height: 1.8rem;
    margin-bottom: 5px;
    margin-left: 95px
  }
  .p-cart__infoItem__col2__1 {
    padding-right: 0;
    min-height: 60px
  }
  .p-cart__infoItem__col2__1>a>div {
    margin-left: 95px
  }
  .p-cart__infoItem__col2__1 p {
    margin-left: 95px
  }
  .p-cart__infoItem__col2__2 {
    flex-basis: auto;
    width: 100%;
    margin-top: 15px;
    padding: 0;
    display: table
  }
  .p-cart__infoItem__col2__2>div {
    padding-right: 10px;
    font-size: 1.2rem;
    text-align: right;
    display: table-cell
  }
  .p-cart__infoItem__col2__2>label {
    margin-top: 5px;
    height: 36px;
    display: table-cell
  }
  .p-cart__infoItem__col2__2>label>select {
    font-size: 16px;
    padding: 0 10px
  }
  .p-cart__infoItem__col2__2>label:after {
    font-size: 1.5rem;
    width: 2em
  }
  .p-cart__infoItem__col2__2 p {
    display: table-cell;
    text-align: right
  }
  .p-cart__faq {
    width: 100%;
    margin-top: 4rem
  }
  .p-cart__faq>.c-accordion>.c-accordion__header {
    font-size: 1.4rem;
    padding: 15px 35px 15px 15px
  }
  .p-cart__faq>.c-accordion>.c-accordion__header:after {
    right: 5px
  }
  .p-cart__faq>.c-accordion>.c-accordion__contents>dl>dt {
    font-size: 1.2rem
  }
  .p-cart__bill {
    margin-top: 15px;
    padding: 0;
    border: none
  }
  .p-cart__billBox {
    margin: 30px auto
  }
  .p-cart__modalTitle {
    font-size: 1.8rem
  }
}

.p-commitment {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 140px
}

.p-commitment3D {
  margin-bottom: 100px
}

.p-commitment3D__group {
  display: flex;
  width: 1190px;
  max-width: 92%;
  margin: 0 auto
}

.p-commitment3D__group>.left {
  position: relative;
  flex: 1 1 auto;
  text-align: right
}

.p-commitment3D__group>.left>img {
  margin-right: 20px;
  width: 524.5px;
  max-width: 46vw
}

.p-commitment3D__group>.c-fade {
  flex: 1 1 auto
}

.p-commitment3D__group__text {
  margin-left: 20px;
  margin-top: 50px
}

.p-commitment3D__group__text>h2 {
  font-weight: normal
}

.p-commitment3D__group__btn {
  margin: 48px auto 0;
  text-align: center;
  width: 460px;
  height: 60px;
  font-size: 1.8rem;
  line-height: 60px;
  color: #fff;
  background-color: #000;
  border-radius: 30px
}

.p-commitment3D__group__btn:hover {
  color: #000;
  background-color: transparent;
  border: 1px solid #000
}

.p-commitmentTeam {
  position: relative;
  padding-bottom: 120px
}

.p-commitmentTeam__title {
  position: absolute;
  top: -40px;
  text-align: center;
  font-size: 2.4rem;
  width: 334px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-commitmentTeam>.left {
  width: 94.5%;
  left: -94.5%;
  background-color: #fff;
  height: 700px;
  position: relative
}

.p-commitmentTeam__backText {
  position: absolute;
  top: -20px;
  right: -20px;
  z-index: 1
}

.p-commitmentTeam__group {
  padding-top: 185px;
  align-items: center
}

.p-commitmentTeam__group>img {
  width: 694px;
  max-width: 50%;
  align-self: auto
}

.p-commitmentTeam__text {
  align-self: auto;
  padding-left: calc(2% + (100% - 767px)/90);
  padding-right: calc(5% + (100% - 767px)/90)
}

.p-commitmentTeam__text>h2 {
  font-weight: normal
}

.p-commitmentCounselor {
  position: relative;
  padding-bottom: 120px
}

.p-commitmentCounselor::after {
  content: '';
  display: block;
  clear: both;
  height: 0;
  visibility: hidden
}

.p-commitmentCounselor__title {
  position: absolute;
  top: -40px;
  right: 0;
  text-align: center;
  font-size: 2.4rem;
  width: 448px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-commitmentCounselor>.right {
  float: right;
  width: 94.5%;
  right: -94.5%;
  background-color: #fff;
  height: 1000px;
  position: relative
}

.p-commitmentCounselor__backText {
  width: 100%;
  max-width: 900px;
  position: absolute;
  top: -10px;
  left: -10px;
  z-index: 1
}

.p-commitmentCounselor__group {
  padding-top: 210px;
  align-items: center
}

.p-commitmentCounselor__group>img {
  width: 694px;
  max-width: 50%;
  align-self: auto
}

.p-commitmentCounselor__text {
  align-self: auto;
  padding-left: calc(5% + (100% - 767px)/60);
  padding-right: calc(5% + (100% - 767px)/60)
}

.p-commitmentCounselor__text>h2 {
  font-weight: normal
}

.p-commitmentCounselor__text>div>h3 {
  font-size: 1.6rem;
  font-weight: normal
}

.p-commitmentCounselor__text>div>p {
  font-size: 1.4rem;
  padding-left: 10px;
  margin-bottom: 30px
}

.p-commitmentStory {
  position: relative;
  padding-bottom: 120px
}

.p-commitmentStory::after {
  content: '';
  display: block;
  clear: both;
  height: 0;
  visibility: hidden
}

.p-commitmentStory__title {
  position: absolute;
  top: -40px;
  text-align: center;
  font-size: 2.4rem;
  width: 448px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-commitmentStory>.left {
  width: 94.5%;
  left: -94.5%;
  background-color: #fff;
  height: 1250px;
  position: relative
}

.p-commitmentStory__backText {
  position: absolute;
  top: -20px;
  right: -20px;
  z-index: 1
}

.p-commitmentStory__group {
  padding-top: 210px;
  align-items: center
}

.p-commitmentStory__group>img {
  width: 694px;
  max-width: 50%;
  align-self: auto
}

.p-commitmentStory__text {
  align-self: auto;
  padding-left: calc(2% + (100% - 767px)/60);
  padding-right: calc(5% + (100% - 767px)/60)
}

.p-commitmentStory__text>h2 {
  font-weight: normal
}

.p-commitmentStory__text__second {
  margin-top: 80px
}

@media (max-width: 1199px) {
  .p-commitment3D__group__btn {
    font-size: 1.6rem;
    width: 400px
  }
  .p-commitmentStory>.left {
    height: calc(1050px + (100vw - 768px)/2)
  }
}

@media (max-width: 959px) {
  .p-commitment {
    margin-top: calc(15px + (100vw - 320px)/40);
    margin-bottom: 0
  }
  .p-commitment>.c-hero {
    height: calc(75vw + (100vw - 320px)/40)
  }
  .p-commitment__heroText {
    max-width: calc(180px + (100vw - 320px)/4)
  }
  .p-commitment3D__group {
    display: block;
    max-width: 80%
  }
  .p-commitment3D__group>.left {
    text-align: center
  }
  .p-commitment3D__group>.left>img {
    margin-right: auto;
    width: 93.7%;
    max-width: none
  }
  .p-commitment3D__group__text {
    margin-left: auto;
    margin-top: 30px
  }
  .p-commitment3D__group__btn {
    width: 80vw;
    height: calc(50px + (100vw - 320px)/9);
    line-height: calc(50px + (100vw - 320px)/9);
    border-radius: calc(25px + (100vw - 320px)/18);
    font-size: calc(10px + (100vw - 320px)/40)
  }
  .p-commitmentTeam {
    padding-bottom: 60px
  }
  .p-commitmentTeam__title {
    font-size: 1.4rem;
    top: -20px;
    width: 210px;
    height: 40px;
    line-height: 40px
  }
  .p-commitmentTeam>.left {
    height: auto;
    width: 93.7%;
    left: -93.7%
  }
  .p-commitmentTeam__backText {
    width: 100%;
    top: auto;
    right: -10px;
    bottom: -10px
  }
  .p-commitmentTeam__group {
    padding-top: 35px
  }
  .p-commitmentTeam__group>img {
    width: 100%;
    max-width: none
  }
  .p-commitmentTeam__text {
    width: 100%;
    padding: 30px 10% 100px 10%
  }
  .p-commitmentCounselor {
    padding-bottom: 60px
  }
  .p-commitmentCounselor__title {
    font-size: 1.4rem;
    top: -20px;
    width: 210px;
    height: 40px;
    line-height: 40px
  }
  .p-commitmentCounselor>.right {
    height: auto;
    width: 93.7%;
    right: -93.7%
  }
  .p-commitmentCounselor__backText {
    width: 100%;
    left: -5px;
    top: -5px
  }
  .p-commitmentCounselor__group {
    padding-top: calc(50px + (100vw - 320px)/3)
  }
  .p-commitmentCounselor__group>img {
    width: 100%;
    max-width: none
  }
  .p-commitmentCounselor__text {
    width: 100%;
    padding: 30px 10% 20px 10%
  }
  .p-commitmentCounselor__text__second {
    margin-top: 40px
  }
  .p-commitmentCounselor__text>div>h3 {
    font-size: 1.4rem
  }
  .p-commitmentCounselor__text>div>p {
    font-size: 1.2rem
  }
  .p-commitmentStory {
    padding-bottom: 60px
  }
  .p-commitmentStory__title {
    font-size: 1.4rem;
    top: -20px;
    width: 280px;
    height: 40px;
    line-height: 40px
  }
  .p-commitmentStory>.left {
    height: auto;
    width: 93.7%;
    right: -93.7%
  }
  .p-commitmentStory__backText {
    width: 60%;
    left: auto;
    top: auto;
    bottom: -30px
  }
  .p-commitmentStory__group {
    padding-top: calc(50px + (100vw - 320px)/3)
  }
  .p-commitmentStory__group>img {
    width: 100%;
    max-width: none
  }
  .p-commitmentStory__text {
    width: 100%;
    padding: 30px 10% 100px 10%
  }
  .p-commitmentStory__text__second {
    margin-top: 40px
  }
}

.p-contactComp__msg {
  margin: 30px 0 35px
}

.p-contactComp__cs {
  border: 1px solid #d8d8d8;
  width: 400px;
  padding: 15px
}

.p-contactComp__csName {
  font-size: 1.2rem;
  margin-bottom: 5px
}

.p-contactComp__csPhone>i {
  font-size: 1.6rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold
}

.p-contactComp__csTime {
  font-size: 1.2rem
}

.p-contactComp__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 55px;
  display: inline-block
}

.p-contactComp__link:hover {
  color: #313131
}

.p-contactComp__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-contactComp__btn {
  margin-top: 50px
}

@media (min-width: 960px) {
  .p-contactComp {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-contactComp__msg {
    margin: 20px 0 30px
  }
  .p-contactComp__cs {
    width: 100%
  }
}

.p-contactConf__heading {
  margin-bottom: 30px
}

.p-contactConf__flex>* {
  padding: 30px 20px 0
}

.p-contactConf__flex>*:first-child {
  padding-left: 0
}

.p-contactConf__flex>*:last-child {
  padding-right: 0
}

.p-contactConf__title {
  width: 140px;
  text-align: right
}

.p-contactConf__input {
  flex: 1 1 auto
}

.p-contactConf__hr {
  padding-left: 160px
}

.p-contactConf__hr>hr {
  margin-top: 30px
}

.p-contactConf__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-contactConf {
    max-width: 980px;
    margin: auto
  }
  .p-contactConf__container {
    padding-right: 20px;
    margin: 50px auto 0
  }
  .p-contactConf__flex {
    align-items: center
  }
  .p-contactConf__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-contactConf__heading {
    margin-bottom: 20px
  }
  .p-contactConf__flex {
    margin-top: 10px
  }
  .p-contactConf__flex>* {
    padding: 5px 0
  }
  .p-contactConf__title {
    font-size: 1.4rem;
    font-weight: bold;
    text-align: left;
    width: 100%
  }
  .p-contactConf__input {
    font-size: 1.6rem;
    line-height: 1.5
  }
  .p-contactConf__save {
    margin: 25px 0 40px
  }
}

.p-contact__heading {
  margin-bottom: 20px
}

.p-contact__tel {
  padding: 10px;
  background-color: #fefefe;
  border: 1px dotted #ccc;
  text-align: center
}

.p-contact__telTitle {
  font-weight: 700
}

.p-contact__tel i {
  font-size: 1.4rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold
}

.p-contact__tel a {
  font-size: 110%;
  color: #A82228;
  text-decoration: underline
}

.p-contact__flex>* {
  padding: 30px 20px 0
}

.p-contact__flex>*:first-child {
  padding-left: 0
}

.p-contact__flex>*:last-child {
  padding-right: 0
}

.p-contact__title {
  width: 200px;
  font-size: 1.6rem;
  text-align: right;
  position: relative;
  top: 13px
}

.p-contact__input {
  flex: 1 1 auto
}

.p-contact__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-contact__hr {
  padding-left: 220px
}

.p-contact__hr>hr {
  margin-top: 30px
}

.p-contact__zipBtn {
  width: 180px
}

.p-contact__save {
  margin-top: 40px
}

.p-contact__msg {
  margin: 20px 0 0
}

@media (min-width: 960px) {
  .p-contact {
    max-width: 980px;
    margin: auto
  }
  .p-contact__flexBtn {
    width: 100%;
    text-align: center
  }
  .p-contact__tel {
    margin-left: 220px
  }
  .p-contact__telTitle {
    margin-right: 10px
  }
  .p-contact__container {
    margin: 0 auto;
    padding: 0 10px
  }
  .p-contact__container form {
    margin-bottom: 40px
  }
}

@media (max-width: 959px) {
  .p-contact__heading {
    margin-bottom: 20px
  }
  .p-contact__tel {
    text-align: left
  }
  .p-contact__telTime {
    font-size: 80%
  }
  .p-contact__flex {
    margin-top: 15px
  }
  .p-contact__flex>* {
    padding: 0 0 10px
  }
  .p-contact__flex.no-title {
    margin-top: 0
  }
  .p-contact__title {
    text-align: left;
    font-size: 1.4rem;
    font-weight: bold;
    width: 100%;
    position: static
  }
  .p-contact__title.no-top {
    padding: 0
  }
  .p-contact__zipInput {
    display: flex
  }
  .p-contact__zipIcon {
    width: 20px;
    line-height: 48px;
    font-size: 1.6rem
  }
  .p-contact__zipSelect {
    flex: 1 1 auto;
    margin-right: 20px
  }
  .p-contact__zipBtn {
    width: 120px;
    height: 50px;
    line-height: 48px;
    font-size: 1.2rem
  }
  .p-contact__save {
    margin: 10px 0 25px
  }
  .p-contact__msg {
    font-size: 1.2rem;
    margin: 0 0 20px
  }
}

.p-entryComp__order {
  margin: 30px 0
}

.p-entryComp__msg {
  max-width: 620px;
  margin-bottom: 45px
}

.p-entryComp__link {
  color: #A82228;
  text-decoration: underline;
  display: inline-block
}

.p-entryComp__link:hover {
  color: #313131
}

.p-entryComp__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-entryComp__btn {
  margin-top: 20px
}

@media (min-width: 960px) {
  .p-entryComp {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-entryComp__order {
    margin: 20px 0 30px
  }
  .p-entryComp__msg {
    margin-bottom: 35px
  }
}

.p-entryConf__heading {
  margin-bottom: 30px
}

.p-entryConf__flex>* {
  padding: 30px 20px 0
}

.p-entryConf__flex>*:first-child {
  padding-left: 0
}

.p-entryConf__flex>*:last-child {
  padding-right: 0
}

.p-entryConf__title {
  width: 140px;
  text-align: right
}

.p-entryConf__input {
  flex: 1 1 auto
}

.p-entryConf__hr {
  padding-left: 160px
}

.p-entryConf__hr>hr {
  margin-top: 30px
}

.p-entryConf__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-entryConf {
    max-width: 980px;
    margin: auto
  }
  .p-entryConf__container {
    padding-right: 20px;
    margin: 0 auto
  }
  .p-entryConf__flex {
    align-items: center
  }
  .p-entryConf__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-entryConf__heading {
    margin-bottom: 20px
  }
  .p-entryConf__flex {
    margin-top: 10px
  }
  .p-entryConf__flex>* {
    padding: 5px 0
  }
  .p-entryConf__title {
    font-size: 1.4rem;
    font-weight: bold;
    text-align: left;
    width: 100%
  }
  .p-entryConf__input {
    font-size: 1.6rem;
    line-height: 1.5
  }
  .p-entryConf__save {
    margin: 40px 0
  }
}

.p-entry__heading {
  margin-bottom: 20px
}

.p-entry__flex>* {
  padding: 30px 20px 0
}

.p-entry__flex>*:first-child {
  padding-left: 0
}

.p-entry__flex>*:last-child {
  padding-right: 0
}

.p-entry__container__msg>i {
  font-size: 1.6rem;
  font-weight: bold;
  opacity: .5;
  position: relative;
  top: 4px;
  margin-right: 2px
}

.p-entry__title {
  width: 15%;
  max-width: 200px;
  font-size: 1.4rem;
  text-align: right;
  position: relative
}

.p-entry__input {
  flex: 1 1 auto
}

.p-entry__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-entry__zipInput .p-entry__input__err {
  padding-left: 30px
}

.p-entry__hr {
  padding-left: 15%
}

.p-entry__hr>hr {
  margin-top: 30px
}

.p-entry__zipInput {
  display: flex
}

.p-entry__zipBtn {
  flex-basis: 40%;
  max-width: 40%;
  line-height: 48px;
  font-size: 1.2rem;
  padding-left: 20px
}

.p-entry__zipBtn>.c-myBtn-r1 {
  width: 100%
}

.p-entry__zipIcon {
  font-size: 1.6rem;
  margin-right: 10px;
  display: inline-block
}

.p-entry__zipCode {
  width: 90%
}

.p-entry__zipSelect {
  flex-basis: 60%;
  max-width: 60%;
  padding-right: 20px
}

.p-entry__save {
  margin-top: 70px
}

.p-entry__radio {
  display: inline-block;
  margin-right: 100px;
  margin-top: 0
}

.p-entry__birth {
  align-items: baseline
}

.p-entry__birthSelectY {
  flex-basis: 43%
}

.p-entry__birthSelect {
  flex-basis: 28.5%
}

.p-entry__birth__break {
  padding: 0 20px
}

@media (min-width: 960px) {
  .p-entry {
    max-width: 980px;
    margin: auto
  }
  .p-entry__flex {
    align-items: baseline
  }
  .p-entry__container {
    padding-right: 20px;
    margin: 0 auto
  }
  .p-entry__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-entry__heading {
    margin-bottom: 20px
  }
  .p-entry__flex {
    margin-top: 0px
  }
  .p-entry__flex>* {
    padding: 0 0 10px
  }
  .p-entry__flex.no-title {
    margin-top: 0
  }
  .p-entry__container__msg {
    margin-bottom: 2rem
  }
  .p-entry__container__msg dl dt {
    position: relative;
    padding-left: 2rem
  }
  .p-entry__container__msg dl dt:before {
    font-size: 1.8rem;
    font-family: Material Icons;
    content: "expand_more";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transition: 0.2s;
    opacity: .5
  }
  .p-entry__container__msg dl dt.open:before {
    transform: translateY(-50%) rotate(180deg);
    transition: 0.2s
  }
  .p-entry__container__msg dl dt p {
    text-decoration: underline
  }
  .p-entry__container__msg dl dd {
    display: none;
    margin-top: 0.5rem
  }
  .p-entry__container__msg dl dd>i {
    font-size: 1.6rem;
    font-weight: bold;
    opacity: .5;
    position: relative;
    top: 3px;
    margin-right: 2px
  }
  .p-entry__title {
    text-align: left;
    font-weight: bold;
    width: 100%;
    position: static
  }
  .p-entry__title.no-top {
    padding: 0
  }
  .p-entry__zipSelect {
    flex: 1.5;
    padding-right: 10px
  }
  .p-entry__zipCode {
    width: 80%
  }
  .p-entry__zipBtn {
    padding-left: 10px
  }
  .p-entry__zipBtn>.c-myBtn-r1 {
    width: 100%
  }
  .p-entry__save {
    margin: 25px 0 40px
  }
  .p-entry__radio {
    margin-right: 20px;
    margin-top: 0
  }
  .p-entry__birth__break {
    padding: 0 10px
  }
}
    padding-top: 50px
  }
  .p-flowScroll {
    overflow-x: scroll
  }
  .p-flowUses {
    width: 865px
  }
  .p-flowUse {
    flex: unset;
    width: 275px;
    height: 324px;
    margin-right: 20px
  }
  .p-flowUse__image1 {
    height: 115px;
    margin: 40px 0 20px
  }
  .p-flowUse__image2 {
    height: 115px;
    margin: 40px 0 20px
  }
  .p-flowUse__image3 {
    width: 115px;
    margin: 55px 0 30px
  }
  .p-flowUse__number {
    height: 44px;
    top: -22px
  }
  .p-flowUse__title {
    font-size: 1.6rem
  }
  .p-flowUse__content {
    margin-top: 10px;
    font-size: 1.2rem
  }
  .p-flowPrograms__items {
    margin-top: 30px
  }
}

.p-footerLinkUp {
  display: flex;
  width: 100%;
  margin-bottom: 60px
}

.p-footerLinkUp__flex {
  flex: 1 1 auto;
  height: 30px;
  padding-left: 30px;
  border-left: 1px solid #4d4d4d;
  position: relative
}

.p-footerLinkUp__flex:not(:first-child) {
  margin-left: 20px
}

.p-footerLinkUp__flex>a {
  color: #fff;
  line-height: 2;
  /* position: absolute; */
  bottom: 0px
}

.p-footerLinkUp__flex>a:hover {
  opacity: .6
}

.p-footerLinkDown {
  width: 100%;
  display: flex;
  bottom: 0
}

.p-footerLinkDown__flex {
  flex: 1 1 auto;
  height: 30px;
  padding-left: 30px;
  border-left: 1px solid #4d4d4d;
  position: relative
}

.p-footerLinkDown__flex:not(:first-child) {
  margin-left: 20px
}

.p-footerLinkDown__flex>a {
  color: #fff;
  line-height: 1.5;
  position: absolute;
  top: 0px
}

.p-footerLinkDown__flex>a:hover {
  opacity: .6
}

.p-footerLinkDown__block {
  flex: 1 1 auto;
  padding-left: 30px;
  margin-left: 20px
}

.p-footerLinkActive>a:before {
  position: absolute;
  top: 35px;
  left: 0;
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  background: #fff
}

@media (max-width: 959px) {
  .p-footerLinkUp {
    margin-bottom: 30px
  }
  .p-footerLinkUp__flex {
    /* height: 80px; */
    padding-left: 10px;
    font-size: 1.1rem
  }
  .p-footerLinkUp__flex:not(:first-child) {
    margin-left: 10px
  }
  .p-footerLinkDown {
    position: static
  }
  .p-footerLinkDown__flex {
    /* height: 80px; */
    padding-left: 10px;
    font-size: 1.1rem
  }
  .p-footerLinkDown__flex:not(:first-child) {
    margin-left: 10px
  }
  .p-footerLinkDown__block {
    padding-left: 10px;
    margin-left: 10px
  }
  .p-footerLinkActive>a:before {
    top: auto;
    bottom: -5px
  }
}

.p-forgetComp__msg {
  margin-top: 30px
}

.p-forgetComp__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 35px;
  display: inline-block
}

.p-forgetComp__link:hover {
  color: #313131
}

.p-forgetComp__btn {
  margin-top: 50px
}

@media (min-width: 960px) {
  .p-forgetComp {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-forgetComp__msg {
    margin-top: 20px
  }
}

.p-forget__msg {
  margin-top: 30px
}

.p-forget__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 35px;
  display: inline-block
}

.p-forget__link:hover {
  color: #313131
}

.p-forget__email {
  margin: 50px 0 30px
}

.p-forget__email__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

@media (min-width: 960px) {
  .p-forget {
    max-width: 980px;
    margin: auto
  }
  .p-forget>form {
    width: 400px;
    margin: auto
  }
  .p-forget__btn {
    width: 100%;
    margin: auto;
    display: block
  }
}

@media (max-width: 959px) {
  .p-forget__msg {
    margin-top: 20px
  }
}

.p-forgetReset__msg {
  margin: 30px auto 0;
  width: 70%
}

.p-forgetReset__row {
  margin-top: 30px
}

.p-forgetReset__msg .p-forgetReset__row {
  margin-top: 0
}

.p-forgetReset__title {
  flex-basis: 25%;
  max-width: 25%
}

.p-forgetReset__input {
  flex-basis: 75%;
  max-width: 75%
}

.p-forgetReset__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-forgetReset__sec {
  margin-top: 20px
}

@media (min-width: 960px) {
  .p-forgetReset {
    max-width: 980px;
    margin: auto
  }
  .p-forgetReset>form {
    width: 70%;
    margin: auto
  }
  .p-forgetReset__title {
    text-align: right;
    padding: 19px 40px 0 0
  }
  .p-forgetReset__btn {
    width: 100%;
    margin: 50px auto;
    display: block
  }
}

@media (max-width: 959px) {
  .p-forgetReset__msg {
    margin-top: 20px;
    width: 100%
  }
  .p-forgetReset__title {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    margin: 0 0 10px;
    font-weight: bold
  }
  .p-forgetReset__input {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto
  }
  .p-forgetReset__btn {
    margin-top: 30px
  }
}

.p-globalNav__lists {
  display: flex;
  list-style: none;
  justify-content: space-between;
  align-items: center
}

.p-globalNav__list {
  margin: 0 15px;
  line-height: 1.6
}

.p-globalNav__list:last-child {
  margin-right: 0
}

.p-globalNav__Sub {
  position: absolute;
  padding: 0;
  background: #221815;
  border-right: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
  z-index: 10000;
  list-style: none;
  display: none
}

.p-globalNav__Sub>li a {
  padding: 12px 12px;
  display: block;
  font-size: 90%;
  color: #fff;
  text-decoration: none;
  width: 160px;
  line-height: 2;
}

.p-globalNav__Sub>li a:hover {
  background: #595959;
  color: #FFF
}

@media (max-width: 1199px) {
  .p-globalNav__list {
    margin: 0 10px
  }
}

.p-helpAbout__heading {
  margin-bottom: 30px
}

.p-helpAbout__flex>* {
  padding: 30px 20px 0
}

.p-helpAbout__flex>*:first-child {
  padding-left: 0
}

.p-helpAbout__flex>*:last-child {
  padding-right: 0
}

.p-helpAbout__title {
  flex-basis: 20%;
  max-width: 20%;
  text-align: right
}

.p-helpAbout__input {
  flex-basis: 80%;
  max-width: 80%
}

.p-helpAbout__link {
  color: #A82228;
  text-decoration: underline
}

.p-helpAbout__link:hover {
  color: #313131
}

.p-helpAbout__hr {
  padding-left: 20%
}

.p-helpAbout__hr>hr {
  margin: 20px 0 0
}

.p-helpAbout__contact>span {
  font-size: 1rem
}

.p-helpAbout__contact>i {
  font-size: 1.4rem;
  color: #A82228;
  opacity: 1;
  position: relative;
  top: 3px;
  font-weight: bold
}

@media (min-width: 960px) {
  .p-helpAbout {
    max-width: 1000px;
    margin: 80px auto;
  }
  .p-helpAbout__container {
    max-width: 960px;
    margin: 50px 0 0
  }
  .p-helpAbout__flex {
    align-items: center
  }
  .p-helpAbout__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-helpAbout__heading {
    margin-bottom: 20px
  }
  .p-helpAbout__flex {
    margin-top: 0px
  }
  .p-helpAbout__flex>* {
    padding: 0 0 10px
  }
  .p-helpAbout__title {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    text-align: left;
    font-weight: bold
  }
  .p-helpAbout__input {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto
  }
  .p-helpAbout__hr {
    padding-left: 0
  }
  .p-helpAbout__hr>hr {
    margin: 10px auto 20px
  }
}

.p-helpFaqAbout__wrap {
  display: flex;
  width: 90%;
  margin: 0 auto;
  padding: 0 0 85px
}

.p-helpFaqAbout__wrapMenu {
  padding: 40px 20px;
  background-color: #fff
}

.p-helpFaqAbout__wrapMenu__title {
  margin: auto;
  text-align: center;
  padding-bottom: 30px
}

.p-helpFaqAbout__wrapMenu__title>img {
  width: 54%
}

.p-helpFaqAbout__wrapMenu__title__subtitle {
  color: #221815;
  font-size: 1.6rem;
  padding-top: 10px
}

.p-helpFaqAbout__wrapMenu__categories {
  display: flex;
  flex-direction: column
}

.p-helpFaqAbout__wrapMenu__categories__category {
  flex-basis: auto;
  max-width: 100%;
  padding: 0 20px 50px;
  text-align: center;
  min-height: 0%
}

.p-helpFaqAbout__wrapMenu__categories__category__title {
  display: flex;
  align-items: center
}

.p-helpFaqAbout__wrapMenu__categories__category__title>img {
  width: 12%;
  padding: 5px 5px 5px 0
}

.p-helpFaqAbout__wrapMenu__categories__category__title>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 1.8rem;
  text-align: left;
  margin-bottom: 0
}

.p-helpFaqAbout__wrapMenu__categories__category__title>h3>a {
  color: #000;
  display: block
}

.p-helpFaqAbout__wrapMenu__categories__category__title>h3>a:hover {
  color: #221815
}

.p-helpFaqAbout__wrapMenu__categories__category__title>h3>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqAbout__wrapMenu__categories__category>ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.6rem;
  padding-top: 20px;
  border-top: 1px solid #ccc
}

.p-helpFaqAbout__wrapMenu__categories__category>ul>li {
  width: 100%;
  text-align: left;
  margin-bottom: 16px;
  position: relative
}

.p-helpFaqAbout__wrapMenu__categories__category>ul>li>a {
  color: #000;
  display: block
}

.p-helpFaqAbout__wrapMenu__categories__category>ul>li>a:hover {
  color: #221815
}

.p-helpFaqAbout__wrapMenu__categories__category>ul>li>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqAbout__wrapMenu__categories__contact {
  flex-basis: auto;
  max-width: 100%;
  min-height: 0%;
  padding: 0 16px 100px;
  text-align: center;
  background: #eee;
  padding: 40px 30px;
  border-radius: 10px
}

.p-helpFaqAbout__wrapMenu__categories__contact>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqAbout__wrapMenu__categories__contact>h4 {
  margin: 30px auto 10px;
  font-weight: normal
}

.p-helpFaqAbout__wrapMenu__categories__contact__text {
  text-align: left
}

.p-helpFaqAbout__wrapMenu__categories__contact__number {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px
}

.p-helpFaqAbout__wrapMenu__categories__contact__number>img {
  vertical-align: middle;
  padding-right: 10px
}

.p-helpFaqAbout__wrapMenu__categories__contact__caption {
  font-size: calc(10px + (100vw - 960px) / 240)
}

.p-helpFaqAbout__wrapMenu__categories__contact__button>a {
  margin: 20px auto 10px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 320px;
  height: 60px;
  line-height: 60px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-helpFaqAbout__wrapMenu__categories__contact__button>a:hover {
  opacity: .9
}

.p-helpFaqAbout__wrapContents {
  flex-basis: 70%;
  margin-left: 40px
}

.p-helpFaqAbout__wrapContents__backlink {
  font-size: 1.2rem
}

.p-helpFaqAbout__wrapContents__backlink>a {
  color: #000;
  position: relative;
  padding-left: 36px
}

.p-helpFaqAbout__wrapContents__backlink>a:hover {
  color: #221815
}

.p-helpFaqAbout__wrapContents__backlink>a:before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 10px;
  height: 1px;
  background: #666;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg)
}

.p-helpFaqAbout__wrapContents__backlink>a:after {
  content: "";
  position: absolute;
  top: 6px;
  left: 1px;
  width: 28px;
  height: 8px;
  border-bottom: 1px solid #666
}

.p-helpFaqAbout__wrapContents__title {
  display: flex;
  align-items: center
}

.p-helpFaqAbout__wrapContents__title>img {
  width: 50px;
  padding: 5px 5px 5px 0
}

.p-helpFaqAbout__wrapContents__title>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 2.2rem;
  text-align: left;
  margin-bottom: 0
}

@media (min-width: 960px) {
  .p-helpFaqAbout__wrapMenu {
    flex-basis: 30%;
    max-width: 400px;
    min-width: 400px
  }
}

@media (max-width: 959px) {
  .p-helpFaqAbout__wrap {
    width: 90%;
    flex-direction: column-reverse;
    padding-bottom: 0
  }
  .p-helpFaqAbout__wrapMenu {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    min-height: 0%
  }
  .p-helpFaqAbout__wrapMenu__categories__category {
    padding: 0 0 50px
  }
  .p-helpFaqAbout__wrapMenu__categories__category__title>img {
    max-width: 30px
  }
  .p-helpFaqAbout__wrapContents {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    margin: 0
  }
  .p-helpFaqAbout__wrapContents__backlink {
    margin-bottom: 20px
  }
}

.p-helpFaqApp__order {
  margin: 30px 0
}

.p-helpFaqApp__msg {
  margin-bottom: 60px
}

.p-helpFaqApp__link {
  color: #A82228;
  text-decoration: underline;
  display: inline-block
}

.p-helpFaqApp__link:hover {
  color: #313131
}

.p-helpFaqApp__btn {
  margin-top: 20px
}

@media (max-width: 959px) {
  .p-helpFaqApp__order {
    margin: 20px 0
  }
  .p-helpFaqApp__msg {
    margin-bottom: 50px
  }
}

.p-helpFaqOrder__wrap {
  display: flex;
  width: 90%;
  margin: 0 auto;
  padding: 0 0 85px
}

.p-helpFaqOrder__wrapMenu {
  padding: 40px 20px;
  background-color: #fff
}

.p-helpFaqOrder__wrapMenu__title {
  margin: auto;
  text-align: center;
  padding-bottom: 30px
}

.p-helpFaqOrder__wrapMenu__title>img {
  width: 54%
}

.p-helpFaqOrder__wrapMenu__title__subtitle {
  color: #221815;
  font-size: 1.6rem;
  padding-top: 10px
}

.p-helpFaqOrder__wrapMenu__categories {
  display: flex;
  flex-direction: column
}

.p-helpFaqOrder__wrapMenu__categories__category {
  flex-basis: auto;
  max-width: 100%;
  padding: 0 20px 50px;
  text-align: center;
  min-height: 0%
}

.p-helpFaqOrder__wrapMenu__categories__category__title {
  display: flex;
  align-items: center
}

.p-helpFaqOrder__wrapMenu__categories__category__title>img {
  width: 12%;
  padding: 5px 5px 5px 0
}

.p-helpFaqOrder__wrapMenu__categories__category__title>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 1.8rem;
  text-align: left;
  margin-bottom: 0
}

.p-helpFaqOrder__wrapMenu__categories__category__title>h3>a {
  color: #000;
  display: block
}

.p-helpFaqOrder__wrapMenu__categories__category__title>h3>a:hover {
  color: #221815
}

.p-helpFaqOrder__wrapMenu__categories__category__title>h3>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqOrder__wrapMenu__categories__category>ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.6rem;
  padding-top: 20px;
  border-top: 1px solid #ccc
}

.p-helpFaqOrder__wrapMenu__categories__category>ul>li {
  width: 100%;
  text-align: left;
  margin-bottom: 16px;
  position: relative
}

.p-helpFaqOrder__wrapMenu__categories__category>ul>li>a {
  color: #000;
  display: block
}

.p-helpFaqOrder__wrapMenu__categories__category>ul>li>a:hover {
  color: #221815
}

.p-helpFaqOrder__wrapMenu__categories__category>ul>li>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqOrder__wrapMenu__categories__contact {
  flex-basis: auto;
  max-width: 100%;
  min-height: 0%;
  padding: 0 16px 100px;
  text-align: center;
  background: #eee;
  padding: 40px 30px;
  border-radius: 10px
}

.p-helpFaqOrder__wrapMenu__categories__contact>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqOrder__wrapMenu__categories__contact>h4 {
  margin: 30px auto 10px;
  font-weight: normal
}

.p-helpFaqOrder__wrapMenu__categories__contact__text {
  text-align: left
}

.p-helpFaqOrder__wrapMenu__categories__contact__number {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px
}

.p-helpFaqOrder__wrapMenu__categories__contact__number>img {
  vertical-align: middle;
  padding-right: 10px
}

.p-helpFaqOrder__wrapMenu__categories__contact__caption {
  font-size: calc(10px + (100vw - 960px) / 240)
}

.p-helpFaqOrder__wrapMenu__categories__contact__button>a {
  margin: 20px auto 10px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 320px;
  height: 60px;
  line-height: 60px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-helpFaqOrder__wrapMenu__categories__contact__button>a:hover {
  opacity: .9
}

.p-helpFaqOrder__wrapContents {
  flex-basis: 70%;
  margin-left: 40px
}

.p-helpFaqOrder__wrapContents__backlink {
  font-size: 1.2rem
}

.p-helpFaqOrder__wrapContents__backlink>a {
  color: #000;
  position: relative;
  padding-left: 36px
}

.p-helpFaqOrder__wrapContents__backlink>a:hover {
  color: #221815
}

.p-helpFaqOrder__wrapContents__backlink>a:before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 10px;
  height: 1px;
  background: #666;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg)
}

.p-helpFaqOrder__wrapContents__backlink>a:after {
  content: "";
  position: absolute;
  top: 6px;
  left: 1px;
  width: 28px;
  height: 8px;
  border-bottom: 1px solid #666
}

.p-helpFaqOrder__wrapContents__title {
  display: flex;
  align-items: center
}

.p-helpFaqOrder__wrapContents__title>img {
  width: 50px;
  padding: 5px 5px 5px 0
}

.p-helpFaqOrder__wrapContents__title>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 2.2rem;
  text-align: left;
  margin-bottom: 0
}

@media (min-width: 960px) {
  .p-helpFaqOrder__wrapMenu {
    flex-basis: 30%;
    max-width: 400px;
    min-width: 400px
  }
}

@media (max-width: 959px) {
  .p-helpFaqOrder__wrap {
    width: 90%;
    flex-direction: column-reverse;
    padding-bottom: 0
  }
  .p-helpFaqOrder__wrapMenu {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    min-height: 0%
  }
  .p-helpFaqOrder__wrapMenu__categories__category {
    padding: 0 0 50px
  }
  .p-helpFaqOrder__wrapMenu__categories__category__title>img {
    max-width: 30px
  }
  .p-helpFaqOrder__wrapContents {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    margin: 0
  }
  .p-helpFaqOrder__wrapContents__backlink {
    margin-bottom: 20px
  }
}

.p-helpFaqOther__wrap {
  display: flex;
  width: 90%;
  margin: 0 auto;
  padding: 0 0 85px
}

.p-helpFaqOther__wrapMenu {
  padding: 40px 20px;
  background-color: #fff
}

.p-helpFaqOther__wrapMenu__title {
  margin: auto;
  text-align: center;
  padding-bottom: 30px
}

.p-helpFaqOther__wrapMenu__title>img {
  width: 54%
}

.p-helpFaqOther__wrapMenu__title__subtitle {
  color: #221815;
  font-size: 1.6rem;
  padding-top: 10px
}

.p-helpFaqOther__wrapMenu__categories {
  display: flex;
  flex-direction: column
}

.p-helpFaqOther__wrapMenu__categories__category {
  flex-basis: auto;
  max-width: 100%;
  padding: 0 20px 50px;
  text-align: center;
  min-height: 0%
}

.p-helpFaqOther__wrapMenu__categories__category__title {
  display: flex;
  align-items: center
}

.p-helpFaqOther__wrapMenu__categories__category__title>img {
  width: 12%;
  padding: 5px 5px 5px 0
}

.p-helpFaqOther__wrapMenu__categories__category__title>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 1.8rem;
  text-align: left;
  margin-bottom: 0
}

.p-helpFaqOther__wrapMenu__categories__category__title>h3>a {
  color: #000;
  display: block
}

.p-helpFaqOther__wrapMenu__categories__category__title>h3>a:hover {
  color: #221815
}

.p-helpFaqOther__wrapMenu__categories__category__title>h3>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqOther__wrapMenu__categories__category>ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.6rem;
  padding-top: 20px;
  border-top: 1px solid #ccc
}

.p-helpFaqOther__wrapMenu__categories__category>ul>li {
  width: 100%;
  text-align: left;
  margin-bottom: 16px;
  position: relative
}

.p-helpFaqOther__wrapMenu__categories__category>ul>li>a {
  color: #000;
  display: block
}

.p-helpFaqOther__wrapMenu__categories__category>ul>li>a:hover {
  color: #221815
}

.p-helpFaqOther__wrapMenu__categories__category>ul>li>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqOther__wrapMenu__categories__contact {
  flex-basis: auto;
  max-width: 100%;
  min-height: 0%;
  padding: 0 16px 100px;
  text-align: center;
  background: #eee;
  padding: 40px 30px;
  border-radius: 10px
}

.p-helpFaqOther__wrapMenu__categories__contact>h3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqOther__wrapMenu__categories__contact>h4 {
  margin: 30px auto 10px;
  font-weight: normal
}

.p-helpFaqOther__wrapMenu__categories__contact__text {
  text-align: left
}

.p-helpFaqOther__wrapMenu__categories__contact__number {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px
}

.p-helpFaqOther__wrapMenu__categories__contact__number>img {
  vertical-align: middle;
  padding-right: 10px
}

.p-helpFaqOther__wrapMenu__categories__contact__caption {
  font-size: calc(10px + (100vw - 960px) / 240)
}

.p-helpFaqOther__wrapMenu__categories__contact__button>a {
  margin: 20px auto 10px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 320px;
  height: 60px;
  line-height: 60px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-helpFaqOther__wrapMenu__categories__contact__button>a:hover {
  opacity: .9
}

.p-helpFaqOther__wrapContents {
  flex-basis: 70%;
  margin-left: 40px
}

.p-helpFaqOther__wrapContents__backlink {
  font-size: 1.2rem
}

.p-helpFaqOther__wrapContents__backlink>a {
  color: #000;
  position: relative;
  padding-left: 36px
}

.p-helpFaqOther__wrapContents__backlink>a:hover {
  color: #221815
}

.p-helpFaqOther__wrapContents__backlink>a:before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 10px;
  height: 1px;
  background: #666;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg)
}

.p-helpFaqOther__wrapContents__backlink>a:after {
  content: "";
  position: absolute;
  top: 6px;
  left: 1px;
  width: 28px;
  height: 8px;
  border-bottom: 1px solid #666
}

.p-helpFaqOther__wrapContents__title {
  display: flex;
  align-items: center
}

.p-helpFaqOther__wrapContents__title>img {
  width: 50px;
  padding: 5px 5px 5px 0
}

.p-helpFaqOther__wrapContents__title>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative;
  flex: 1 1 auto;
  font-size: 2.2rem;
  text-align: left;
  margin-bottom: 0
}

@media (min-width: 960px) {
  .p-helpFaqOther__wrapMenu {
    flex-basis: 30%;
    max-width: 400px;
    min-width: 400px
  }
}

@media (max-width: 959px) {
  .p-helpFaqOther__wrap {
    width: 90%;
    flex-direction: column-reverse;
    padding-bottom: 0
  }
  .p-helpFaqOther__wrapMenu {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    min-height: 0%
  }
  .p-helpFaqOther__wrapMenu__categories__category {
    padding: 0 0 50px
  }
  .p-helpFaqOther__wrapMenu__categories__category__title>img {
    max-width: 30px
  }
  .p-helpFaqOther__wrapContents {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    margin: 0
  }
  .p-helpFaqOther__wrapContents__backlink {
    margin-bottom: 20px
  }
}

.p-helpFaq {
  background-color: #eee;
  margin-top: 254px;
  padding-bottom: 140px
}

.p-helpFaq__hero {
  width: 176px
}

.p-helpFaqTitle {
  padding-bottom: 350px
}

.p-helpFaq hr {
  margin: 10px 0
}

.p-helpFaqSection {
  width: 84%;
  margin: 0 auto;
  background-color: #fff;
  padding: 0 7% 85px
}

.p-helpFaqSection__title {
  text-align: center;
  padding-bottom: 65px
}

.p-helpFaqSection__subtitle {
  color: #221815;
  font-size: 1.8rem
}

.p-helpFaqSection__categories {
  max-width: 1000px;
  height: 100%;
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around
}

.p-helpFaqSection__categories__category {
  flex-basis: 50%;
  max-width: 50%;
  padding: 0 16px 100px;
  text-align: center
}

.p-helpFaqSection__categories__category__title>img {
  width: 60px;
  padding-bottom: 20px
}

.p-helpFaqSection__categories__category__title>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqSection__categories__category__title>h2>a {
  color: #000;
  display: block
}

.p-helpFaqSection__categories__category__title>h2>a:hover {
  color: #221815
}

.p-helpFaqSection__categories__category__title>h2>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px
}

.p-helpFaqSection__categories__category>ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.8rem;
  padding-top: 40px;
  border-top: 1px solid #ccc
}

.p-helpFaqSection__categories__category>ul>li {
  text-align: left;
  margin-bottom: 16px;
  position: relative
}

.p-helpFaqSection__categories__category>ul>li>a {
  color: #000;
  display: block
}

.p-helpFaqSection__categories__category>ul>li>a:hover {
  color: #221815
}

.p-helpFaqSection__categories__category>ul>li>a:after {
  content: 'chevron_right';
  font-family: "Material Icons";
  position: absolute;
  top: 0;
  right: 5px;
  display: block
}

.p-helpFaqSection__categories__contact {
  flex-basis: 50%;
  max-width: 50%;
  padding: 0 16px 100px;
  text-align: center;
  background: #eee;
  padding: 40px 30px;
  border-radius: 10px
}

.p-helpFaqSection__categories__contact>h2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
  position: relative
}

.p-helpFaqSection__categories__contact>h3 {
  margin: 30px auto 10px;
  font-weight: normal
}

.p-helpFaqSection__categories__contact__text {
  text-align: left
}

.p-helpFaqSection__categories__contact__number {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px
}

.p-helpFaqSection__categories__contact__number>img {
  vertical-align: middle;
  padding-right: 10px
}

.p-helpFaqSection__categories__contact__caption {
  font-size: calc(10px + (100vw - 960px) / 240)
}

.p-helpFaqSection__categories__contact__button>a {
  margin: 20px auto 10px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 320px;
  height: 60px;
  line-height: 60px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-helpFaqSection__categories__contact__button>a:hover {
  opacity: .9
}

.p-helpFaqSVG {
  width: 300px;
  position: relative;
  z-index: 1;
  transform: translateY(-50%)
}

.p-helpFaqSVGSP {
  height: 64px;
  position: relative;
  z-index: 1;
  transform: translateY(-53%);
  max-width: 100%
}

@media (min-width: 960px) {
  .p-helpFaq .c-heroText__title, .p-helpFaq .c-heroText__content {
    color: #000
  }
}

@media (max-width: 1199px) {
  .p-helpFaq ul {
    flex-direction: column
  }
}

@media (max-width: 959px) {
  .p-helpFaq {
    margin-top: calc(15px + (100vw - 320px) / 40);
    margin-bottom: 0
  }
  .p-helpFaq>.c-hero {
    height: calc(75vw + (100vw - 320px) / 40)
  }
  .p-helpFaqTitle {
    padding-bottom: 70px
  }
  .p-helpFaqSection {
    width: 100%;
    margin-top: 50px
  }
  .p-helpFaqSection__title {
    padding-bottom: 40px
  }
  .p-helpFaqSection__subtitle {
    font-size: 1.2rem
  }
  .p-helpFaqSection__info {
    font-size: 1.6rem
  }
  .p-helpFaqSection__content {
    font-size: 1.2rem;
    margin: 18px 0 25px
  }
  .p-helpFaqSection__categories {
    flex-direction: column
  }
  .p-helpFaqSection__categories__category {
    flex-basis: auto;
    max-width: 100%;
    padding: 0 0 40px
  }
  .p-helpFaqSection__categories__category__title {
    display: flex;
    align-items: center
  }
  .p-helpFaqSection__categories__category__title>img {
    width: 40px;
    padding: 5px 5px 10px 0
  }
  .p-helpFaqSection__categories__category__title>h2 {
    flex: 1 1 auto;
    font-size: 1.8rem;
    text-align: left;
    margin-bottom: 0
  }
  .p-helpFaqSection__categories__category>ul {
    padding-top: 20px;
    font-size: 1.6rem
  }
  .p-helpFaqSection__categories__category>ul>li {
    margin-bottom: 20px
  }
  .p-helpFaqSection__categories__contact {
    flex-basis: auto;
    max-width: 100%
  }
}

.p-helpPrivacy__subtitle {
  margin: 60px 0 30px
}

.p-helpPrivacy__grey {
  font-size: 1.1rem;
  line-height: 1.3;
  padding: 20px;
  background-color: #f4f4f4;
  border: 1px solid #d8d8d8;
  margin: 10px 0;
  position: relative;
  display: none
}

.p-helpPrivacy__grey.active {
  display: block
}

.p-helpPrivacy__grey>button {
  position: absolute;
  top: 10px;
  right: 15px;
  width: 20px
}

.p-helpPrivacy__grey.active>button {
  transform: rotate(180deg)
}

.p-helpPrivacy__ps {
  margin: 30px 0
}

.p-helpPrivacy__link {
  color: #A82228;
  text-decoration: underline
}

.p-helpPrivacy__link:hover {
  color: #313131
}

.p-helpPrivacy__date {
  margin-top: 30px;
  color: #919191
}

.p-helpPrivacy__release {
  width: 100%;
  padding: 30px 40px;
  border: 1px solid #A82228
}

.p-helpPrivacy__release>h2 {
  color: #A82228;
  font-size: 1.8rem
}

.p-helpPrivacy__release>p {
  font-size: 1.2rem
}

@media (min-width: 960px) {
  .p-helpPrivacy {
    max-width: 980px;
    margin: auto
  }
  .p-helpPrivacy__title {
    margin: 40px 0 30px
  }
}

@media (max-width: 959px) {
  .p-helpPrivacy__title {
    margin-bottom: 20px
  }
  .p-helpPrivacy__subtitle {
    margin: 30px 0 20px
  }
  .p-helpPrivacy__grey {
    padding: 10px;
    margin: 10px 0
  }
  .p-helpPrivacy__grey>button {
    top: 1px;
    right: 5px
  }
  .p-helpPrivacy__ps {
    margin: 20px 0
  }
  .p-helpPrivacy__content, .p-helpPrivacy__date {
    font-size: 1.2rem
  }
  .p-helpPrivacy__date {
    margin-top: 20px
  }
  .p-helpPrivacy__release {
    padding: 20px;
    margin-bottom: 20px
  }
  .p-helpPrivacy__release>h2 {
    font-size: 1.6rem
  }
}

.p-helpTradelaw__heading {
  margin-bottom: 60px
}

.p-helpTradelaw__flex>* {
  padding: 0 20px
}

.p-helpTradelaw__flex>*:first-child {
  padding-left: 0
}

.p-helpTradelaw__flex>*:last-child {
  padding-right: 0
}

.p-helpTradelaw__title {
  flex-basis: 20%;
  max-width: 20%;
  text-align: right
}

.p-helpTradelaw__input {
  flex-basis: 80%;
  max-width: 80%
}

.p-helpTradelaw__input>span {
  font-size: 1.2rem
}

.p-helpTradelaw__link {
  color: #A82228;
  text-decoration: underline
}

.p-helpTradelaw__link:hover {
  color: #313131
}

.p-helpTradelaw__hr {
  padding-left: 20%
}

.p-helpTradelaw__hr>hr {
  margin: 20px 0 0
}

.p-helpTradelaw__contact>span {
  font-size: 1rem
}

.p-helpTradelaw__contact>i {
  font-size: 1.4rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold
}

@media (min-width: 960px) {
  .p-helpTradelaw {
    max-width: 980px;
    margin: auto
  }
  .p-helpTradelaw__container {
    max-width: 960px;
    margin: 20px 0 0
  }
  .p-helpTradelaw__flex {
    align-items: start
  }
  .p-helpTradelaw__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-helpTradelaw__heading {
    margin-bottom: 20px
  }
  .p-helpTradelaw__flex {
    margin-top: 0
  }
  .p-helpTradelaw__flex>* {
    padding: 0 0 10px
  }
  .p-helpTradelaw__title {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto;
    text-align: left;
    font-weight: bold
  }
  .p-helpTradelaw__input {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto
  }
  .p-helpTradelaw__hr {
    padding-left: 0
  }
  .p-helpTradelaw__hr>hr {
    margin: 10px auto 20px
  }
}

.p-helpUseconditions__content>h2 {
  font-size: 1.6rem;
  margin: 40px 0
}

.p-helpUseconditions__content>h3 {
  font-size: 1.4rem;
  margin: 40px 0 10px
}

.p-helpUseconditions__content>p {
  font-size: 1.2rem;
  line-height: 1.5;
  margin: 10px 0
}

.p-helpUseconditions__content__date {
  text-align: right;
  margin-top: 40px !important
}

@media (min-width: 960px) {
  .p-helpUseconditions {
    max-width: 980px;
    margin: auto
  }
  .p-helpUseconditions__title {
    margin: 40px 0 30px
  }
}

@media (max-width: 959px) {
  .p-helpUseconditions__title {
    margin-bottom: 20px
  }
  .p-helpUseconditions__subtitle {
    margin: 30px 0 20px
  }
  .p-helpUseconditions__grey {
    padding: 10px;
    margin: 10px 0
  }
  .p-helpUseconditions__grey>button {
    top: 1px;
    right: 5px
  }
  .p-helpUseconditions__ps {
    margin: 20px 0
  }
  .p-helpUseconditions__content, .p-helpUseconditions__date {
    font-size: 1.2rem
  }
  .p-helpUseconditions__date {
    margin-top: 20px
  }
  .p-helpUseconditions__app {
    margin-top: 40px
  }
}

.p-indexHero {
  width: 100%;
  height: calc(100vw*0.45);
  background-image: url("../img/index/hero.jpg");
  background-size: cover;
  background-position: left center;
  position: relative
}

.p-indexHero__title {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  color: #fff;
  position: absolute;
  top: 40%;
  left: 53%;
  font-size: 4vw;
  line-height: 1.4
}

.p-indexHero__title>span {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  letter-spacing: 6px
}

.p-indexHero__bnr {
  position: absolute;
  bottom: 5%;
  left: 53%;
  width: 35vw;
  max-width: 640px
}

.p-indexAbout {
  width: 100%;
  height: 1005px;
  margin-bottom: 120px
}

.p-indexAbout__text {
  position: relative;
  z-index: 2
}

.p-indexAbout__text__title {
  color: #fff;
  width: 40%
}

.p-indexAbout__text__content {
  color: #fff;
  width: 40%;
}

.p-indexAbout__text>.left {
  position: absolute;
  top: 100px;
  left: 6%
}

.p-indexAbout__back {
  position: relative;
  height: 100%;
  background-color: #eee
}

.p-indexAbout__back>.left {
  width: 49%;
  height: 557px;
  background-color: #221815;
  position: absolute;
  left: -49%;
  z-index: 1
}

.p-indexAbout__back>.left>img {
  margin-top: 118px;
  margin-top: 60px;
}

.p-indexAbout__back>.right {
  z-index: 0;
  width: 94.5%;
  height: 100%;
  position: absolute;
  right: -94.5%;
  background-color: #eee
}

.p-indexAbout__backText {
  position: absolute;
  right: 0px;
  bottom: -10px
}



.p-indexAbout__productImg {
  position: absolute;
  top: 45px;
  right: calc(4% + (100% - 960px)/10);
  width: 525px;
  max-width: 45%
}


.p-indexAbout__productImg .more_btn{
  text-decoration: none;
  color: #000;
  /* font-family: eb-garamond, serif; */
  font-size: 13px;
  font-weight: 500;
}
.p-indexAbout__productImg .more_btn-Text{
  position: relative;
  z-index: 1;
  letter-spacing: .08em;
  font-weight: 500;
}

.p-indexAbout__productImg .more_btn-Text:before{
  font-family: 'Font Awesome 6 pro';
  content: "\f178";
/*   font-size: px; */
  padding-right: 10px;
}


.p-indexAbout__productImg .more_btn-Text:after{
  content: '';
  position: absolute;
  left: 0;
  bottom: -10px;/*テキストからの距離*/
  width: 0%;/*初期状態では下線非表示*/
  height: 1px;/*下線の高さ*/
  background: #888;/*下線の色*/
  z-index: -1;
  transition: all 0.4s;/*アニメーション速度*/
}
.p-indexAbout__productImg .more_btn:hover .more_btn-Text:after{
  width: 100%;/*hover時に表示*/
}


.p-indexAbout__links {
  position: absolute;
  left: 7.4%;
  bottom: 195px;
  display: flex;
  width: 800px;
  justify-content: space-between;
  align-items: center;
}

.p-indexAbout__links img {
  width: 195px
}

.p-indexAbout__links img:hover {
  border-radius: 5px;
  box-shadow: 0px 4px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 6px 0px rgba(0, 0, 0, 0.12)
}

.p-indexAbout__msg {
  font-size: 3rem;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  text-align: center;
  width: 80%;
  position: absolute;
  bottom: 480px
}

.p-indexAbout__spLinks {
  text-align: left;
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
  margin: 0 20px;
  position: relative;
  z-index: 3
}

.p-indexAbout__spLinks a {
  display: inline-block
}

.p-indexAbout__spLinks a img {
  width: 154px
}

.p-indexAbout__spLinks div {
  width: 154px;
}

.p-indexLinks {
  margin-bottom: 60px
}

.p-indexLinks>div {
  display: flex;
  width: 709px;
  margin: auto;
  justify-content: space-between
}

.p-indexLinks>div img {
  width: 195px;
  border-radius: 5px;
  box-shadow: 0px 4px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 6px 0px rgba(0, 0, 0, 0.12)
}

.p-indexLinks>div img:hover {
  opacity: .8
}

.p-indexValue__group {
  width: 100%;
  height: 1080px;
  position: relative;
  background-color: #eee;
  margin-bottom: 120px
}

.p-indexValue__text1 {
  position: absolute;
  top: 25%;
  right: 25%;
  z-index: 1;
  width: 38%;
  transform: translateX(50%) translateY(-50%)
}

.p-indexValue__text2 {
  position: absolute;
  bottom: 25%;
  left: 25%;
  z-index: 1;
  width: 38%;
  transform: translateX(-50%) translateY(50%)
}

.p-indexValue__images {
  width: 100%;
  height: 100%;
  position: relative
}

.p-indexValue__images>.left {
  width: 50%;
  height: 50%;
  position: absolute;
  top: 0;
  left: -50%;
  background-image: url("../img/index/value1.jpg");
  background-size: cover;
  background-position: 50%
}

.p-indexValue__images>.right {
  width: 50%;
  height: 50%;
  position: absolute;
  bottom: 0;
  right: -50%;
  background-image: url("../img/index/value2.jpg");
  background-size: cover;
  background-position: 50%
}

.p-indexValue__backText {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 2
}

.p-indexConcept {
  position: relative
}

.p-indexConcept__image {
  width: 100%;
  height: 550px;
  background-image: url("../img/index/concept.jpg");
  background-size: cover;
  background-position: 50%
}

.p-indexConcept__title {
  color: #fff;
  font-size: 4.2rem;
  position: absolute;
  top: 240px;
  left: 6%
}

.p-indexConcept__content {
  width: 50%;
  position: relative;
  top: -130px;
  left: -50%;
  background-color: #fff;
  padding: 60px 6% 0 5%
}

@media (max-width: 959px) {
  .p-index {
    background: #95252b;
    margin-top: 30px
  }
  .p-indexHero {
    background-image: url("../img/index/hero_sp.jpg");
    background-size: 100%;
    height: 140vw;
    max-height: 960px;
    background-position: bottom
  }
  .p-indexHero__title {
    width: 100%;
    text-align: center;
    font-size: calc(26px + (100vw - 320px) / 28);
    top: auto;
    left: auto;
    bottom: 5%
  }
  .p-indexHero__bnr {
    position: static;
    display: block;
    text-align: center;
    margin: 0 auto;
    width: 90%;
    padding-top: 20px
  }
  .p-indexAbout {
    height: auto;
    margin-bottom: 50px
  }
  .p-indexAbout__text__title {
    color: #fff;
    width: 85%
  }
  .p-indexAbout__text__content {
    color: #fff;
    width: 85%
  }
  .p-indexAbout__text>.left {
    left: 9%;
    top: calc(98px + (100vw - 320px)/9)
  }
  .p-indexAbout__back::after {
    content: '';
    display: block;
    clear: both;
    height: 0;
    visibility: hidden
  }
  .p-indexAbout__back>.left {
    width: 100%;
    position: static;
    /* height: calc(400px + (100vw - 320px)/2); */
  }
  .p-indexAbout__back>.left>img {
    margin-top: calc(48px + (100vw - 320px)/9)
  }
  .p-indexAbout__back>.right {
    width: 100%;
    height: 100%;
    position: static;
    float: right;
    text-align: center
  }
  .p-indexAbout__backText {
    width: 50%;
    right: 0;
    bottom: -3px;
  }
  .p-indexAbout__productImg {
    position: static;
    max-width: none;
    width: 90%;
    margin: 0 auto
  }
  .p-indexAbout__msg {
    width: 90%;
    text-align: center;
    margin: 10px auto 20px;
    font-size: 1.8rem;
    position: static
  }
  .p-indexAbout__msg>span {
    font-size: 150%
  }
  .p-indexAbout__merit {
    width: 90%;
    flex-direction: column;
    margin: auto;
    padding-bottom: 80px;
    position: static;
    left: 0;
    bottom: 0
  }
  .p-indexAbout__merit>div {
    flex-basis: 42%;
    margin: 0 10px 16px
  }
  .p-indexAbout__meritPopup__text {
    text-align: left
  }
  .p-indexAbout__meritImg {
    max-width: 100px;
    margin-bottom: 20px
  }
  .p-indexAbout__meritText {
    font-size: 1.7rem;
    padding: 10px
  }
  .p-indexLinks>div {
    width: 90%;
    flex-wrap: wrap
  }
  .p-indexLinks>div>a {
    flex-basis: 46%
  }
  .p-indexLinks>div img {
    width: 100%;
    margin: 5px
  }
  .p-indexValue {
    margin-bottom: 75px
  }
  .p-indexValue__group {
    height: auto
  }
  .p-indexValue__images {
    height: 130vw
  }
  .p-indexValue__images>.left {
    width: 91.5%;
    left: -90%
  }
  .p-indexValue__images>.right {
    width: 91.5%;
    right: -90%
  }
  .p-indexValue__text1 {
    position: static;
    width: auto;
    padding: 45px 10%;
    transform: none
  }
  .p-indexValue__text2 {
    position: static;
    width: 100%;
    padding: 45px 10%;
    transform: none
  }
  .p-indexValue__backText {
    width: 88%
  }
  .p-indexConcept__image {
    height: 70vw;
    background-position: top;
    background-image: url("../img/index/concept_sp.jpg")
  }
  .p-indexConcept__content {
    top: -12vw;
    width: 93.4%;
    padding: 45px 10%
  }
}

@media (min-width: 1441px) {
  .p-indexHero__title {
    font-size: 5rem
  }
  .p-indexAbout__productImg {
    right: calc(25.5% - 262px)
  }
  .p-indexAbout__msg {
    bottom: 450px
  }
}

@media (min-width: 960px) {
  .p-indexAbout__msg {
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-indexConcept__content>.c-content {
    margin-top: 0
  }
}

@media (min-width: 550px) {
  .p-indexAbout__spDiv {
    display: none
  }
}

.p-MediaDetail__contents {
  flex: 1
}

.p-MediaDetail__contents__lead {
  margin: 0 0 8px
}

.p-MediaDetail__contents__date {
  width: 100%;
  padding-bottom: 8px;
  font-size: 1.2rem;
  color: #707070;
  border-bottom: 1px solid #ccc
}

.p-MediaDetail__contents__body {
  margin-bottom: 50px
}

.p-MediaDetail__contents__body>p {
  font-size: 1.5rem;
  line-height: 1.5
}

.p-MediaDetail__contents__body>p>a {
  color: #A82228;
  text-decoration: underline
}

.p-MediaDetail__contents__body>img {
  width: 100%;
  max-width: 500px;
  margin-bottom: 30px
}

.p-MediaDetail__contents__body>img.mx250 {
  max-width: 250px
}

.p-MediaDetail__contents__info {
  color: #221815;
  text-align: center;
  border: 1px solid #221815;
  background: #fff;
  padding: 5px;
  margin: 0 auto 50px;
  width: 200px
}

.p-MediaDetail__contents__recommend {
  padding: 0 30px 40px;
  margin-bottom: 50px;
  background: #eee
}

.p-MediaDetail__contents__recommendTitle {
  text-align: center;
  padding-bottom: 65px
}

.p-MediaDetail__contents__recommendSubtitle {
  color: #221815;
  font-size: 1.8rem
}

.p-MediaDetail__contents__recommendImg {
  text-align: center;
  flex-basis: 40%;
  padding-right: 40px
}

.p-MediaDetail__contents__recommendItem {
  flex-basis: 60%
}

.p-MediaDetail__contents__recommendItem__title {
  font-size: 2rem
}

.p-MediaDetail__contents__recommendItem__text {
  margin: 30px 0
}

.p-MediaDetail__contents__recommendBtn {
  width: 300px;
  margin: 30px auto 40px;
  display: block
}

.p-MediaDetail__contents__recommendSVG {
  position: relative;
  z-index: 1;
  transform: translateY(-50%)
}

.p-MediaDetail__contents__recommendSVGSP {
  height: 78px;
  position: relative;
  z-index: 1;
  transform: translateY(-24%);
  max-width: 100%
}

.p-MediaDetail__contents__back {
  margin: auto;
  display: block
}

@media (min-width: 960px) {
  .p-MediaDetail {
    max-width: 980px;
    margin: auto
  }
}

@media (max-width: 959px) {
  .p-MediaDetail__contents__lead {
    padding: 8px 20px
  }
  .p-MediaDetail__contents__date {
    padding: 0 20px 8px
  }
  .p-MediaDetail__contents__body {
    width: calc(90vw - 22.5px);
    margin: 0 auto 40px
  }
  .p-MediaDetail__contents__info {
    margin: 0 auto 40px;
    width: 140px;
    font-size: 1.2rem
  }
  .p-MediaDetail__contents__recommendImg {
    flex: 1 1 auto;
    padding: 0 0 20px
  }
  .p-MediaDetail__contents__recommendImg>img {
    width: 100%;
    max-width: 320px
  }
  .p-MediaDetail__contents__recommendItem {
    flex: 1 1 auto
  }
  .p-MediaDetail__contents__recommendItem__title {
    font-size: 1.4rem
  }
  .p-MediaDetail__contents__recommendBtn {
    width: 95%;
    font-size: 1.3rem
  }
  .p-MediaDetail__contents__back {
    width: calc(90vw - 22.5px);
    margin: auto
  }
}

@media (max-width: 600px) {
.p-indexAbout__back>.left {
    width: 100%;
    height:75vh
  }
}
.p-Media__msg {
  font-size: 1.4rem;
  color: #707070
}

.p-Media__items {
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between
}

.p-Media__items:after {
  content: "";
  display: block;
  width: 240px;
  height: 0
}

.p-Media__items__item {
  width: 240px;
  margin: 0 20px 20px
}

.p-Media__items__item>a>img {
  width: 100%
}

.p-Media__items__item>a>img:hover {
  opacity: .9
}

.p-Media__items__item__name {
  font-size: 1.4rem;
  margin-bottom: 0
}

.p-Media__items__item__name>a {
  color: #000
}

.p-Media__items__item__name>a:hover {
  text-decoration: underline
}

.p-Media__items__item__date {
  font-size: 1.2rem;
  color: #707070
}

.p-Media__items__item.is-empty {
  height: 0;
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
  margin-bottom: 0 !important
}

@media (min-width: 960px) {
  .p-Media {
    max-width: 980px;
    margin: auto
  }
  .p-Media__title {
    margin: 0 0 30px
  }
  .p-Media>.c-pagination {
    max-width: 960px
  }
}

@media (max-width: 959px) {
  .p-Media__title {
    margin-bottom: 20px
  }
  .p-Media__items__item {
    flex-basis: 45%;
    margin: 0 0 20px
  }
}

.p-mente {
  text-align: center;
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center
}

.p-mente>div {
  width: 100%;
  text-align: center
}

.p-mente__icon {
  width: 120px
}

.p-mente__title {
  font-size: 2.2rem;
  margin: 35px 0
}

.p-mente__time {
  border: 1px solid #d8d8d8;
  padding: 20px 10px;
  font-size: 1.4rem;
  line-height: 2.2;
  margin: 0 auto
}

.p-mente__footer {
  width: 100%;
  position: fixed;
  bottom: 30px;
  text-align: center;
  font-size: 1.4rem
}

@media (min-width: 960px) {
  .p-mente__time {
    width: 400px
  }
}

@media (max-width: 959px) {
  .p-mente {
    align-items: start
  }
  .p-mente__icon {
    margin-top: 30px
  }
  .p-mente__title {
    font-size: 1.8rem;
    margin: 60px 0 25px
  }
  .p-mente__time {
    width: 90%;
    max-width: 400px
  }
  .p-mente__footer {
    bottom: 20px;
    font-size: 1.2rem
  }
}

.p-mpChangeComp__subtitle {
  margin: 25px 0 18px
}

.p-mpChangeComp__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 60px;
  display: inline-block
}

.p-mpChangeComp__link:hover {
  color: #313131
}

.p-mpChangeComp__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-mpChangeComp>p {
  margin-bottom: 60px
}

@media (max-width: 959px) {
  .p-mpChangeComp__subtitle {
    margin: 20px 0
  }
  .p-mpChangeComp__linkSP {
    margin-top: 45px
  }
}

.p-mpChange__heading {
  margin-bottom: 20px
}

.p-mpChange__flex>* {
  padding: 30px 20px 0
}

.p-mpChange__flex>*:first-child {
  padding-left: 0
}

.p-mpChange__flex>*:last-child {
  padding-right: 0
}

.p-mpChange__title {
  width: 20%;
  max-width: 200px;
  font-size: 1.4rem;
  text-align: right;
  position: relative
}

.p-mpChange__input {
  flex: 1 1 auto
}

.p-mpChange__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-mpChange__zipSelect .p-mpChange__input__err {
  padding-left: 30px
}

.p-mpChange__hr {
  padding-left: 20%
}

.p-mpChange__hr>hr {
  margin-top: 30px
}

.p-mpChange__zipInput {
  display: flex
}

.p-mpChange__zipBtn {
  flex-basis: 40%;
  max-width: 40%;
  line-height: 48px;
  font-size: 1.2rem;
  padding-left: 20px
}

.p-mpChange__zipBtn>.c-myBtn-r1 {
  width: 100%
}

.p-mpChange__zipIcon {
  font-size: 1.6rem;
  margin-right: 10px;
  display: inline-block
}

.p-mpChange__zipCode {
  width: 90%
}

.p-mpChange__zipSelect {
  flex-basis: 60%;
  max-width: 60%;
  padding-right: 20px
}

.p-mpChange__save {
  margin-top: 30px
}

.p-mpChange__radio {
  display: inline-block;
  margin-right: 100px;
  margin-top: 0
}

.p-mpChange__birth {
  flex-wrap: wrap;
  align-items: center
}

.p-mpChange__birth>label, .p-mpChange__birth>div {
  flex: 1 1 auto
}

.p-mpChange__birth>span {
  display: flex;
  align-items: flex-end;
  margin: 0 20px
}

@media (min-width: 960px) {
  .p-mpChange__flex {
    align-items: baseline
  }
}

@media (max-width: 959px) {
  .p-mpChange__heading {
    margin-bottom: 20px
  }
  .p-mpChange__flex {
    margin-top: 0px
  }
  .p-mpChange__flex>* {
    padding: 0 0 10px
  }
  .p-mpChange__flex.no-title {
    margin-top: 0
  }
  .p-mpChange__title {
    text-align: left;
    width: 100%;
    position: static;
    font-weight: bold
  }
  .p-mpChange__title.no-top {
    padding: 0
  }
  .p-mpChange__zipSelect {
    padding-right: 10px
  }
  .p-mpChange__zipCode {
    width: 80%
  }
  .p-mpChange__zipBtn {
    padding-left: 10px
  }
  .p-mpChange__save {
    margin-top: 25px
  }
  .p-mpChange__radio {
    margin-right: 20px;
    margin-top: 0
  }
  .p-mpChange__birth>label:first-child {
    flex: 1.5
  }
  .p-mpChange__birth>span {
    margin: 0 8px
  }
}

.p-mpCoupon__title {
  margin-bottom: 25px
}

.p-mpCoupon__subtitle {
  margin-bottom: 18px
}

.p-mpCoupon__subscription {
  margin-top: 60px;
  margin-bottom: 18px
}

.p-mpCoupon__caption {
  margin: 0 auto 30px
}

.p-mpCoupon__wrapper {
  width: 100%;
  max-width: 864px;
  display: flex;
  align-items: center;
  border-bottom: 2px dotted #d8d8d8;
  margin-bottom: 30px;
  padding: 0px 0 25px 0
}

.p-mpCoupon__wrapper__item {
  flex: 1 1 auto;
  position: relative
}

.p-mpCoupon__wrapper__item__name {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 0
}

.p-mpCoupon__wrapper__item__name>span {
  font-size: 1.4rem;
  font-weight: normal;
  padding-left: 10px
}

.p-mpCoupon__wrapper__item__discount {
  font-size: 3rem;
  font-weight: bold;
  line-height: 1.25;
  color: #221815;
  margin-bottom: 0
}

.p-mpCoupon__wrapper__item__discount>span {
  font-size: 1.8rem;
  padding-left: 5px
}

.p-mpCoupon__wrapper__item__code {
  font-size: 1.2rem;
  margin-bottom: 0
}

.p-mpCoupon__wrapper__item__date {
  font-size: 1.2rem;
  margin-bottom: 0
}

.p-mpCoupon__wrapper__item__btn>a {
  width: 180px;
  height: 50px;
  line-height: 48px
}

.p-mpCoupon__wrapper__item__expire {
  min-width: 80px;
  padding: 2px 8px;
  font-size: 1.2rem;
  color: #FFF;
  background: #A82228;
  text-align: center;
  border-radius: 3px;
  display: inline-block;
  margin: 0 3px 5px
}

.p-mpCoupon__wrapper__item__icon {
  min-width: 80px;
  padding: 2px 8px;
  font-size: 1.2rem;
  color: #A82228;
  background: #fff;
  text-align: center;
  border: 1px solid #A82228;
  border-radius: 3px;
  display: inline-block;
  margin: 0 3px 5px
}

.p-mpCoupon__msg {
  padding: 10px;
  margin-bottom: 20px;
  background: #fff;
  border: 4px solid rgba(168, 34, 40, 0.2);
  box-sizing: border-box
}

.p-mpCoupon__msg>i {
  font-size: 1.6rem;
  vertical-align: middle
}

.p-mpCoupon__nodata {
  padding-top: 16px
}

@media (max-width: 959px) {
  .p-mpCoupon__title {
    margin-bottom: 20px
  }
  .p-mpCoupon__subscription {
    margin-top: 20px
  }
  .p-mpCoupon__caption {
    margin: 20px auto 20px
  }
  .p-mpCoupon__wrapper {
    flex-direction: column;
    padding: 0 0 20px;
    margin-bottom: 20px
  }
  .p-mpCoupon__wrapper__item {
    width: 100%
  }
  .p-mpCoupon__wrapper__item__name {
    font-size: 1.6rem
  }
  .p-mpCoupon__wrapper__item__name>span {
    width: 100%;
    padding-left: 0;
    display: block
  }
  .p-mpCoupon__wrapper__item__code, .p-mpCoupon__wrapper__item__date {
    font-size: 1.2rem
  }
  .p-mpCoupon__wrapper__item__btn {
    position: static;
    margin: 14px 0 0;
    width: 100%;
    text-align: center
  }
  .p-mpCoupon__wrapper__item__btn>a {
    width: 140px;
    height: 36px;
    line-height: 34px
  }
  .p-mpCoupon__nodata {
    padding-top: 0;
    padding-bottom: 10px
  }
}

.p-mpDeliveryNew__heading {
  margin-bottom: 20px
}

.p-mpDeliveryNew__flex>* {
  padding: 30px 20px 0
}

.p-mpDeliveryNew__flex>*:first-child {
  padding-left: 0
}

.p-mpDeliveryNew__flex>*:last-child {
  padding-right: 0
}

.p-mpDeliveryNew__title {
  width: 20%;
  max-width: 200px;
  font-size: 1.4rem;
  text-align: right;
  position: relative
}

.p-mpDeliveryNew__input {
  flex: 1 1 auto
}

.p-mpDeliveryNew__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-mpChange__zipSelect .p-mpDeliveryNew__input__err {
  padding-left: 30px
}

.p-mpDeliveryNew__hr {
  padding-left: 20%
}

.p-mpDeliveryNew__hr>hr {
  margin-top: 30px
}

.p-mpDeliveryNew__zipInput {
  display: flex
}

.p-mpDeliveryNew__zipBtn {
  flex-basis: 40%;
  max-width: 40%;
  line-height: 48px;
  font-size: 1.2rem;
  padding-left: 20px
}

.p-mpDeliveryNew__zipBtn>.c-myBtn-r1 {
  width: 100%
}

.p-mpDeliveryNew__zipIcon {
  font-size: 1.6rem;
  margin-right: 10px;
  display: inline-block
}

.p-mpDeliveryNew__zipCode {
  width: 90%
}

.p-mpDeliveryNew__zipSelect {
  flex-basis: 60%;
  max-width: 60%;
  padding-right: 20px
}

.p-mpDeliveryNew__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-mpDeliveryNew__flex {
    align-items: baseline
  }
}

@media (max-width: 959px) {
  .p-mpDeliveryNew__heading {
    margin-bottom: 20px
  }
  .p-mpDeliveryNew__flex {
    margin-top: 10px
  }
  .p-mpDeliveryNew__flex>* {
    padding: 0 0 10px
  }
  .p-mpDeliveryNew__flex.no-title {
    margin-top: 0
  }
  .p-mpDeliveryNew__title {
    text-align: left;
    font-weight: bold;
    width: 100%;
    position: static
  }
  .p-mpDeliveryNew__title.no-top {
    padding: 0
  }
  .p-mpDeliveryNew__zipSelect {
    flex: 1.5;
    padding-right: 10px
  }
  .p-mpDeliveryNew__zipCode {
    width: 80%
  }
  .p-mpDeliveryNew__zipBtn {
    padding-left: 10px
  }
  .p-mpDeliveryNew__save {
    margin-top: 25px
  }
}

.p-mpDelivery__subtitle {
  margin: 20px 0 27px
}

.p-mpDelivery__addBtn {
  height: 50px;
  line-height: 48px
}

.p-mpDelivery__item {
  width: 100%;
  max-width: 864px;
  margin-top: 40px;
  padding-bottom: 25px;
  border-bottom: 1px dotted #d8d8d8
}

.p-mpDelivery__item__remove {
  background-image: url("../img/mypage/close.png");
  background-size: cover;
  width: 16px;
  height: 16px;
  cursor: pointer;
  position: absolute;
  top: 30px;
  left: 20px
}

.p-mpDelivery__item__remove:hover {
  transform: rotate(90deg);
  transition: all .1s
}

.p-mpDelivery__item__subscription {
  min-width: 80px;
  padding: 2px 8px;
  font-size: 1.2rem;
  color: #FFF;
  background: #A82228;
  text-align: center;
  border-radius: 3px;
  display: inline-block;
  margin: 0 3px 5px 0
}

.p-mpDelivery__item__content {
  position: relative;
  flex: 1;
  padding: 0 20px 0 60px
}

.p-mpDelivery__item__btn {
  width: 160px
}

@media (max-width: 959px) {
  .p-mpDelivery__subtitle {
    margin: 20px 0 21px
  }
  .p-mpDelivery__addBtn {
    width: 200px;
    height: 36px;
    line-height: 34px;
    font-size: 1.4rem
  }
  .p-mpDelivery__item {
    width: 100%;
    margin-top: 30px;
    padding-bottom: 20px
  }
  .p-mpDelivery__item__remove {
    left: 0
  }
  .p-mpDelivery__item__content {
    padding: 0 20px 0 36px
  }
  .p-mpDelivery__item__btn {
    width: 63px;
    height: 36px;
    line-height: 34px
  }
}

.p-mpHistory__title {
  margin-bottom: 20px
}

.p-mpHistory__info {
  width: 100%;
  flex: 1 1 auto;
  padding-right: 40px
}

.p-mpHistory__item {
  width: 100%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  justify-content: space-between
}

.p-mpHistory__item:not(:last-child) {
  border-bottom: 1px solid #d8d8d8
}

.p-mpHistory__itemImage {
  margin-right: 30px
}

.p-mpHistory__itemImage>img {
  width: 92px
}

.p-mpHistory__itemDetail {
  flex: 1 1 auto
}

.p-mpHistory__item>p {
  margin-bottom: 0.5rem
}

.p-mpHistory__itemName {
  flex-basis: 70%
}

.p-mpHistory__itemName>p {
  margin-bottom: 5px
}

.p-mpHistory__itemName_set {
  font-size: 1.2rem;
  font-weight: normal;
  padding-left: 20px
}

.p-mpHistory__itemPrice {
  margin-left: 20px;
  flex-basis: 30%;
  font-weight: bold
}

.p-mpHistory__itemPrice>p {
  margin-bottom: 0
}

.p-mpHistory__itemPrice>p>span {
  font-weight: normal
}

.p-mpHistory__divider {
  margin-top: 30px;
  margin-bottom: 30px
}

.p-mpHistory__subtitle {
  margin: 20px 0 10px
}

.p-mpHistory__content {
  margin-top: 10px
}

.p-mpHistory__content__coupon {
  padding: 18px 0 25px 0;
  border-bottom: 2px dotted #d8d8d8
}

.p-mpHistory__content__couponName {
  font-size: 1.6rem;
  font-weight: bold
}

.p-mpHistory__content__couponDiscount {
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.25;
  color: #221815;
  margin-bottom: 0
}

.p-mpHistory__content__couponDiscount>span {
  font-size: 1.8rem;
  padding-left: 5px
}

.p-mpHistory__content__couponCode, .p-mpHistory__content__couponDate {
  font-size: 1.2rem
}

.p-mpHistory__contactItem {
  color: #313131;
  padding: 16px 0;
  border-bottom: 1px dotted #d8d8d8;
  position: relative;
  align-items: center
}

.p-mpHistory__contactItem>div {
  flex: 1 1 auto
}

.p-mpHistory__contactItem>i {
  margin-right: 5px
}

.p-mpHistory__bill {
  width: 100%;
  border: 1px solid #919191;
  border-radius: 4px;
  padding: 2.5%
}

.p-mpHistory__billFlex {
  display: flex;
  margin-bottom: 15px;
  align-items: center
}

.p-mpHistory__billTitle {
  flex: 1 1 auto
}

.p-mpHistory__billCoupon {
  width: 100%;
  padding: 10px 20px;
  font-size: 1.4rem;
  background-color: #f8f8f8;
  margin-bottom: 15px
}

.p-mpHistory__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin-bottom: 8px
}

.p-mpHistory__billPrice {
  font-weight: bold;
  font-size: 1.8rem
}

.p-mpHistory__billTax {
  font-weight: bold;
  font-size: 1.2rem
}

.p-mpHistory__billOrder {
  width: 100%;
  margin: 50px auto 40px
}

.p-mpHistory__billBack {
  width: 100%
}

@media (min-width: 960px) {
  .p-mpHistory__pcBottom {
    margin-bottom: 70px
  }
  .p-mpHistory__contactItem:hover {
    background-color: #f8f8f8
  }
  .p-mpHistory__bill {
    width: 40%;
    max-width: 400px;
    min-width: 240px;
    display: sticky;
    top: 10px;
    padding-top: 30px;
    padding-bottom: 40px
  }
}

@media (max-width: 959px) {
  .p-mpHistory__info {
    padding-right: 0
  }
  .p-mpHistory__item {
    justify-content: normal
  }
  .p-mpHistory__itemImage {
    width: auto;
    margin-right: 20px
  }
  .p-mpHistory__itemImage>img {
    width: 50px
  }
  .p-mpHistory__itemPrice {
    flex: 1 1 auto;
    margin-left: 0
  }
  .p-mpHistory__itemName {
    flex: 1 1 auto
  }
  .p-mpHistory__contactItem>i {
    margin-right: 0
  }
  .p-mpHistory__bill {
    padding: 0;
    border: none
  }
}

.p-mpIndex__title {
  margin-bottom: 15px
}

.p-mpIndex__table {
  display: table;
  width: 100%;
  margin-top: 20px
}

.p-mpIndex__table-head {
  display: table-header-group;
  vertical-align: middle
}

.p-mpIndex__table-head>div {
  display: table-cell;
  width: 20%;
  height: 45px;
  vertical-align: middle;
  font-weight: bold;
  border-bottom: 1px solid #d8d8d8
}

.p-mpIndex__table-data {
  display: table-row
}

.p-mpIndex__table-data>div {
  display: table-cell;
  height: 90px;
  vertical-align: middle;
  border-bottom: 1px solid #d8d8d8;
  padding-right: 20px
}

.p-mpIndex__table-data>div>span {
  font-weight: bold
}

.p-mpIndex__table-data>div>a>div {
  width: 124px;
  height: 42px;
  line-height: 40px
}

.p-mpIndex__pagination {
  margin-top: 40px
}

@media (max-width: 959px) {
  .p-mpIndex__title {
    margin-bottom: 20px
  }
  .p-mpIndex__table {
    margin-top: 0;
    display: block
  }
  .p-mpIndex__table-data {
    padding: 20px 0 20px;
    display: block;
    border-bottom: 1px solid #d8d8d8
  }
  .p-mpIndex__table-data>div {
    display: block;
    border-bottom: none;
    height: auto
  }
  .p-mpIndex__table-data>div>a>div {
    width: 140px;
    height: 36px;
    line-height: 34px;
    margin-top: 15px
  }
  .p-mpIndex__pagination {
    margin-top: 50px
  }
}

.p-mpLogin {
  margin: 0 auto
}

.p-mpLogin__titleAuto {
  display: none
}

.p-mpLogin__row {
  margin-top: 10px;
  flex-direction: column
}

.p-forgetReset__msg .p-mpLogin__row {
  margin-top: 0
}

.p-mpLogin__input {
  flex-basis: 1 1 auto
}

.p-mpLogin__input__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block;
  text-align: left
}

.p-mpLogin__btn {
  max-width: 300px;
  margin: auto;
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-mpLogin__btn>i {
  font-size: 1.8rem
}

.p-mpLogin__sec {
  margin-top: 20px
}

.p-mpLogin__block {
  border: 1px solid #ddd;
  padding: 4%;
  margin: 0 auto 5rem;
  text-align: center
}

.p-mpLogin__msg {
  font-size: 1.3rem;
  line-height: 1.5;
  margin-bottom: 2rem
}

.p-mpLogin__link {
  text-align: center
}

.p-mpLogin__agree {
  text-align: center;
  margin-bottom: 20px;
  display: block
}

.p-mpLogin__agree input[type=checkbox] {
  display: none
}

.p-mpLogin__agreeText {
  font-size: 1.3rem;
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  padding-left: 30px;
  position: relative;
  width: auto
}

.p-mpLogin__agreeText::before {
  background: #f7f7f7;
  border: 1px solid #707070;
  border-radius: 3px;
  content: '';
  display: block;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%)
}

.p-mpLogin__agreeText::after {
  border-right: 3px solid #323E48;
  border-bottom: 3px solid #323E48;
  content: '';
  display: block;
  width: 8px;
  height: 18px;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  opacity: 0;
  position: absolute;
  transform: rotate(45deg) translate3d(0, 2px, 0) scale3d(0.7, 0.7, 1);
  transition: transform .2s ease-in-out, opacity .2s ease-in-out;
  margin-top: -12px
}

.p-mpLogin__popout .l-myPopout__container {
  overflow-y: scroll
}

input[type=checkbox]:checked+.p-mpLogin__agreeText::after {
  opacity: 1;
  transform: rotate(45deg) scale3d(1, 1, 1)
}

@media (min-width: 960px) {
  .p-mpLogin {
    max-width: 740px;
    margin: auto
  }
  .p-mpLogin>form {
    width: 70%;
    margin: auto
  }
  .p-mpLogin__row {
    width: 75%;
    margin: auto
  }
  .p-mpLogin__title {
    flex-basis: 100%;
    text-align: left;
    padding: 19px 40px 0 0
  }
  .p-mpLogin__input {
    flex-basis: 100%
  }
  .p-mpLogin__btn {
    width: 100%;
    margin: 0px auto 10px
  }
  .p-mpLogin__msg {
    text-align: center
  }
  .p-mpLogin__popout {
    height: 90vh
  }
}

@media (max-width: 959px) {
  .p-mpLogin {
    width: calc(90vw - 22.5px);
    margin: 0 auto
  }
  .p-mpLogin__title {
    width: 100%;
    text-align: left;
    margin: 0 auto 10px;
    font-weight: bold
  }
  .p-mpLogin__row {
    margin-bottom: 20px
  }
  .p-mpLogin__btn {
    margin: 0px auto 10px
  }
  .p-mpLogin__msg {
    text-align: left
  }
  .p-mpLogin__popout {
    height: 95vh
  }
}

.p-mpSubscription>.c-flex-r {
  margin-top: 40px
}

.p-mpSubscription__title {
  margin-bottom: 25px
}

.p-mpSubscription__msg {
  padding: 10px;
  margin-bottom: 25px;
  background: #fff;
  border: 4px solid rgba(168, 34, 40, 0.2);
  box-sizing: border-box
}

.p-mpSubscription__msg>i {
  font-size: 1.6rem;
  vertical-align: middle
}

.p-mpSubscription__faq {
  width: 40%;
  max-width: 400px;
  min-width: 240px;
  border: 1px solid #919191;
  border-radius: 4px;
  padding: 30px 2.5% 40px
}

.p-mpSubscription__faq__question {
  font-size: 1.4rem;
  margin: 20px auto 10px;
  padding-left: 50px;
  position: relative;
  min-height: 40px
}

.p-mpSubscription__faq__question:before {
  font-size: 2.2rem;
  font-family: Didot, "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  line-height: 36px;
  color: #fff;
  background: #A82228;
  width: 40px;
  height: 40px;
  text-align: center;
  content: 'Q';
  position: absolute;
  left: 0
}

.p-mpSubscription__faq__answer {
  margin: 10px auto 30px;
  padding-left: 50px;
  position: relative;
  min-height: 40px
}

.p-mpSubscription__faq__answer:before {
  font-size: 2.2rem;
  font-family: Didot, "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  line-height: 40px;
  color: #fff;
  background: #919191;
  width: 40px;
  height: 40px;
  text-align: center;
  content: 'A';
  position: absolute;
  left: 0
}

.p-mpSubscription__faq__btn {
  display: inline-block;
  margin: 0 auto;
  color: #A82228;
  text-decoration: underline;
  position: relative;
  padding-right: 20px
}

.p-mpSubscription__faq__btn:before {
  position: absolute;
  top: 50%;
  right: 10px;
  display: inline-block;
  content: "";
  width: 7px;
  height: 1px;
  background: #A82228;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: transform .3s, -webkit-transform .3s
}

.p-mpSubscription__faq__btn:after {
  position: absolute;
  top: 50%;
  right: 5px;
  display: inline-block;
  content: "";
  width: 7px;
  height: 1px;
  background: #A82228;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  transition: transform .3s, -webkit-transform .3s
}

.p-mpSubscription__faq__btn.js-isActive:before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}

.p-mpSubscription__faq__btn.js-isActive:after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}

.p-mpSubscription__faq__btn:hover {
  color: #313131
}

.p-mpSubscription__info {
  flex: 1 1 auto;
  padding-right: 40px
}

.p-mpSubscription__info__title {
  margin-top: 28px
}

.p-mpSubscription__info__content {
  margin-top: 18px
}

.p-mpSubscription__info__coupon {
  padding: 18px 0 25px 0;
  border-bottom: 2px dotted #d8d8d8
}

.p-mpSubscription__info__couponName {
  font-size: 1.6rem;
  font-weight: bold
}

.p-mpSubscription__info__couponDiscount {
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.25;
  color: #221815;
  margin-bottom: 0
}

.p-mpSubscription__info__couponDiscount>span {
  font-size: 1.8rem;
  padding-left: 5px
}

.p-mpSubscription__info__couponCode, .p-mpSubscription__info__couponDate {
  font-size: 1.2rem
}

.p-mpSubscription__info__coupons {
  margin-top: 15px
}

.p-mpSubscription__info__coupons>a {
  color: #A82228;
  text-decoration: underline
}

.p-mpSubscription__info__coupons>a:hover {
  color: #313131
}

.p-mpSubscription__info__coupons>a>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-mpSubscription__info__bill {
  border: 1px solid #d8d8d8;
  padding: 30px;
  margin-top: 25px;
  font-size: 1.4rem
}

.p-mpSubscription__info__billFlex {
  display: flex;
  margin-bottom: 9px
}

.p-mpSubscription__info__billTitle {
  flex: 1 1 auto;
  font-weight: bold
}

.p-mpSubscription__info__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin-bottom: 8px
}

.p-mpSubscription__info__billPrice {
  font-weight: bold;
  font-size: 1.8rem
}

.p-mpSubscription__info__billTax {
  font-weight: bold;
  font-size: 1.2rem
}

.p-mpSubscription__info__billCaption {
  margin-top: 20px;
  padding: 10px 20px;
  background-color: #f4f4f4
}

.p-mpSubscription__info__flex {
  display: flex;
  margin-top: 18px
}

.p-mpSubscription__info__inline {
  flex: 1 1 auto
}

.p-mpSubscription__info__btn {
  display: inline-block
}

.p-mpSubscription__info__btn>button {
  width: 120px;
  height: 42px;
  line-height: 40px
}

.p-mpSubscription__nextSelect {
  width: 320px
}

.p-mpSubscription__nextBtn {
  width: 320px;
  margin-top: 40px
}

.p-mpSubscription__addressAdd>button {
  width: 291px;
  height: 50px;
  line-height: 48px
}

.p-mpSubscription__addressFlex {
  display: flex;
  padding: 30px 0;
  border-bottom: 1px dotted #d8d8d8
}

.p-mpSubscription__addressText {
  flex: 1 1 auto;
  padding-right: 15px
}

.p-mpSubscription__addressBtn {
  width: 120px;
  height: 50px;
  line-height: 48px
}

.p-mpSubscription__payment {
  max-height: 90vh;
  overflow: overlay
}

.p-mpSubscription__paymentName {
  flex-basis: 50%;
  padding-right: 20px
}

.p-mpSubscription__paymentDate {
  flex: 1 1 auto
}

.p-mpSubscription__paymentDate>label {
  width: 70%;
  margin-right: 5px
}

.p-mpSubscription__paymentDate__break {
  padding-right: 20px
}

.p-mpSubscription__paymentCVC {
  width: 140px;
  display: block
}

.p-mpSubscription__paymentCVC__link {
  color: #A82228;
  text-decoration: underline;
  font-size: 1.2rem;
  margin-top: 12px;
  display: inline-block
}

.p-mpSubscription__paymentCVC__items {
  width: 100%;
  display: flex;
  align-items: flex-end;
  margin: 30px 0 0
}

.p-mpSubscription__paymentCVC__items__item {
  flex: 1 1 auto;
  padding: 0 20px
}

.p-mpSubscription__paymentCVC__items__item>p {
  font-size: 1rem;
  margin-bottom: 5px
}

.p-mpSubscription__paymentCVC__items__item>img {
  width: 100%;
  max-width: 160px
}

.p-mpSubscription__paymentCVC__msg {
  font-size: 1rem;
  padding-left: 20px;
  margin-bottom: 20px
}

.p-mpSubscription__payment__err {
  width: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

@media (max-width: 959px) {
  .p-mpSubscription__title {
    margin-bottom: 20px
  }
  .p-mpSubscription__faq {
    width: 100%;
    border: none;
    padding: 0;
    display: none
  }
  .p-mpSubscription__faq.js-isActive {
    display: block
  }
  .p-mpSubscription__faq__question {
    margin-top: 15px
  }
  .p-mpSubscription__faq__answer {
    margin-top: 10px
  }
  .p-mpSubscription__info {
    padding-right: 0
  }
  .p-mpSubscription__info__title {
    margin-top: 18px
  }
  .p-mpSubscription__info__content {
    margin-top: 8px
  }
  .p-mpSubscription__info__coupon {
    padding: 10px 0 15px
  }
  .p-mpSubscription__info__couponName {
    font-size: 1.6rem
  }
  .p-mpSubscription__info__couponCode, .p-mpSubscription__info__couponDate {
    font-size: 1.2rem
  }
  .p-mpSubscription__info__bill {
    margin-top: 0;
    padding: 0;
    border: none
  }
  .p-mpSubscription__info__billCaption {
    margin-top: 10px;
    padding: 10px;
    font-size: 1.4rem
  }
  .p-mpSubscription__info__flex {
    margin-top: 20px
  }
  .p-mpSubscription__info__btn>button {
    width: 63px;
    height: 36px;
    line-height: 34px
  }
  .p-mpSubscription__nextSelect {
    width: 160px
  }
  .p-mpSubscription__nextBtn {
    width: 270px;
    margin-top: 30px
  }
  .p-mpSubscription__addressAdd>button {
    width: 216px;
    height: 36px;
    line-height: 34px
  }
  .p-mpSubscription__addressBtn {
    width: 53px;
    height: 36px;
    line-height: 34px
  }
  .p-mpSubscription__payment {
    height: 95vh
  }
  .p-mpSubscription__payment .l-myPopout__inputTitle {
    margin-top: 5px
  }
  .p-mpSubscription__paymentName {
    width: 100%;
    margin-bottom: 15px
  }
  .p-mpSubscription__paymentDate {
    width: 81px
  }
  .p-mpSubscription__paymentCVC__items {
    margin-top: 20px
  }
}

.p-News__list {
  list-style: none;
  margin-top: 20px
}

.p-News__list__item {
  margin: 10px 0
}

.p-News__list__item__link {
  width: 100%;
  padding-bottom: 10px;
  color: #000;
  border-bottom: 1px solid #ccc
}

.p-News__list__item__date {
  display: block
}

.p-News__list__item__lead {
  margin: 0;
  padding: 0;
  color: #221815;
  text-decoration: underline;
  word-break: break-all
}

@media (min-width: 960px) {
  .p-News__list {
    padding-left: 4px
  }
  .p-News__list__item {
    margin-bottom: 10px
  }
  .p-News__list__item__link {
    display: flex
  }
  .p-News__list__item__date {
    width: 150px;
    flex-shrink: 0
  }
  .p-News__list__item__lead {
    display: block
  }
}

@media (max-width: 959px) {
  .p-News__title {
    margin-bottom: 20px
  }
  .p-News__items__item {
    flex-basis: 45%;
    margin: 0 0 20px
  }
  .p-News__items__lead {
    flex: 1
  }
}

.p-plan {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 140px
}

.p-plan table {
  width: 100%;
  border-collapse: collapse
}

.p-plan tr:not(:last-child)>td, .p-plan th {
  border-bottom: 1px solid #797979
}

.p-plan td, .p-plan th {
  width: 25%;
  padding: 30px 20px;
  text-align: center;
  font-weight: normal
}

.p-plan td:not(:last-child), .p-plan th:not(:last-child) {
  border-right: 1px solid #797979
}

.p-plan td img, .p-plan th img {
  max-width: 100%
}

.p-plan .c-heroText__title, .p-plan .c-heroText__content {
  color: #000
}

.p-planTitle {
  margin-bottom: 70px
}

.p-plan hr {
  margin: 10px 0
}

.p-planSection {
  width: 84%;
  margin: 0 auto;
  background-color: #fff;
  padding: 0 7% 85px
}

.p-planSection__title {
  text-align: center;
  padding-bottom: 65px
}

.p-planSection__subtitle {
  color: #221815;
  font-size: 1.8rem
}

.p-planSection__info {
  font-size: 2rem
}

.p-planSection__content {
  margin: 30px 0
}

.p-planSection__price {
  margin-top: 60px
}

.p-planSection__priceTitle {
  font-size: 2rem;
  margin-bottom: 10px;
  position: relative
}

.p-planSection__priceItem {
  flex-wrap: wrap;
  flex: 1
}

.p-planSection__priceItem:first-child {
  margin-right: 40px
}

.p-planSection__red {
  background-color: #221815;
  color: #fff;
  padding: 5px 12px;
  font-size: 1.2rem;
  border-radius: 17px
}

.p-planSection__redcp {
  background: linear-gradient(45deg, #f1da34 0%, #fff8c7 45%, #f1da34 70%, #fff8c3 85%, #f1da34 95% 100%);
  color: #000;
  padding: 5px 12px;
  font-size: 1.2rem;
  border-radius: 17px
}

.p-planSection__ribbon {
  display: inline-block;
  position: relative;
  height: 36px;
  line-height: 36px;
  text-align: center;
  padding: 0 25px;
  font-size: 1.6rem;
  background: linear-gradient(45deg, #f1da34 0%, #fff8c7 45%, #f1da34 70%, #fff8c3 85%, #f1da34 95% 100%);
  color: #000;
  box-sizing: border-box;
  margin-left: 10px
}

.p-planSection__ribbon:before {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
  top: 0;
  left: 0;
  border-width: 18px 0px 18px 10px;
  border-color: transparent transparent transparent #fff;
  border-style: solid
}

.p-planSection__ribbon:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
  top: 0;
  right: 0;
  border-width: 18px 10px 18px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid
}

.p-planSection__caption {
  flex-basis: 100%
}

.p-planSection__cpline {
  text-decoration: line-through;
  color: #666 !important;
  font-size: 2.2rem !important
}

.p-planSection__number {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 3.2rem;
  color: #221815;
  padding: 0 5px 0 10px
}

.p-planSection__number2 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 2.4rem
}

.p-planSection__number3 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 2.4rem
}

.p-planSection__number4 {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 1.6rem
}

.p-planSection__value {
  flex-basis: 100%;
  display: flex;
  align-items: center
}

.p-planSection__kome {
  font-size: 60%;
  padding-left: 140px
}

.p-planSection__yen {
  font-size: 1.2rem;
  color: #221815
}

.p-planSection__yen2 {
  font-size: 1.1rem
}

.p-planSection__yen3 {
  font-size: 1.4rem;
  margin-left: 3px
}

.p-planSection__balloon {
  position: relative;
  display: inline-block;
  padding: 0 2.5rem;
  color: #221815;
  text-align: center;
  margin-bottom: 10px
}

.p-planSection__balloon:before {
  content: '';
  position: absolute;
  bottom: 40%;
  display: inline-block;
  width: 32px;
  height: 1px;
  background-color: #221815;
  -webkit-transform: rotate(70deg);
  transform: rotate(70deg);
  left: 0
}

.p-planSection__balloon:after {
  content: '';
  position: absolute;
  bottom: 40%;
  display: inline-block;
  width: 32px;
  height: 1px;
  background-color: #221815;
  -webkit-transform: rotate(-70deg);
  transform: rotate(-70deg);
  right: 0
}

.p-planSection__payment {
  margin-top: 60px
}

.p-planSection__paymentTitle {
  font-size: 2rem;
  margin-bottom: 35px
}

.p-planSection__paymentSubtitle {
  font-size: 1.4rem
}

.p-planSection__paymentMonth {
  width: 19.8%;
  border-left: 1px solid #221815;
  padding-left: 10px;
  font-size: 1.1rem;
  line-height: 30px
}

.p-planSection__paymentMonth6 {
  width: 69.8%;
  border-left: 1px solid #221815;
  padding-left: 10px;
  font-size: 1.1rem;
  line-height: 30px
}

.p-planSection__paymentArrow {
  position: relative;
  margin-bottom: 20px
}

.p-planSection__paymentArrow__balloon {
  position: relative;
  display: inline-block;
  padding: 0 1.25rem;
  color: #f1da34
}

.p-planSection__paymentArrow__balloon:before {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 16px;
  height: 1px;
  background-color: #f1da34;
  -webkit-transform: rotate(70deg);
  transform: rotate(70deg);
  left: 0
}

.p-planSection__paymentArrow__balloon:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 16px;
  height: 1px;
  background-color: #f1da34;
  -webkit-transform: rotate(-70deg);
  transform: rotate(-70deg);
  right: 0
}

.p-planSection__paymentLeft {
  height: 100px;
  width: 20%;
  background-color: #221815;
  position: relative
}

.p-planSection__paymentLeft:before {
  content: "";
  position: absolute;
  right: -50px;
  bottom: 0;
  z-index: 1;
  width: 0;
  height: 0;
  border-left: 50px solid #221815;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent
}

.p-planSection__paymentLeft6 {
  height: 100px;
  width: 70%;
  background-color: #221815;
  position: relative
}

.p-planSection__paymentLeft6:before {
  content: "";
  position: absolute;
  right: -50px;
  bottom: 0;
  z-index: 1;
  width: 0;
  height: 0;
  border-left: 50px solid #221815;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent
}

.p-planSection__paymentText1 {
  width: 165px;
  justify-content: center;
  z-index: 2;
  position: absolute;
  top: 33%;
  left: 0;
  color: #fff
}

.p-planSection__paymentText2 {
  justify-content: center;
  z-index: 2;
  position: absolute;
  top: 33%;
  left: 30%;
  color: #221815
}

.p-planSection__paymentText3 {
  z-index: 2;
  position: absolute;
  top: 20%;
  left: 350px;
  color: #221815
}

.p-planSection__paymentText4 {
  justify-content: center;
  z-index: 2;
  position: absolute;
  top: 33%;
  left: 78%;
  color: #221815
}

.p-planSection__paymentText5 {
  width: 20%;
  justify-content: center;
  z-index: 2;
  position: absolute;
  top: 10%;
  left: 0;
  color: #fff
}

.p-planSection__paymentText6 {
  justify-content: center;
  align-items: baseline;
  z-index: 2;
  position: absolute;
  top: 10%;
  left: 190px;
  text-decoration: line-through;
  color: #221815
}

.p-planSection__paymentRight {
  height: 100px;
  flex: 1;
  margin-right: 50px;
  background-color: #f9f2f2;
  position: relative
}

.p-planSection__paymentRight:before {
  content: "";
  position: absolute;
  right: -50px;
  bottom: 0;
  z-index: 1;
  width: 0;
  height: 0;
  border-left: 50px solid #f9f2f2;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent
}

.p-planSection__paymentAll {
  height: 100px;
  flex: 1;
  background-color: #221815;
  position: relative
}

.p-planSection__paymentAll:before {
  content: "";
  position: absolute;
  right: -50px;
  bottom: 0;
  z-index: 1;
  width: 0;
  height: 0;
  border-left: 50px solid #221815;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent
}

.p-planSection__paymentCaption {
  font-size: 1.1rem;
  margin-bottom: 25px
}

.p-planSection__button {
  text-align: center
}

.p-planSection__button>a {
  margin-top: 70px;
  display: inline-block;
  text-align: center;
  width: 627px;
  height: 80px;
  line-height: 80px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-planSection2 {
  width: 66%;
  margin: 0 auto
}

.p-planSection2__title {
  background-color: #000;
  color: #fff;
  height: 70px;
  line-height: 70px;
  font-size: 1.8rem;
  padding: 0 30px;
  margin-bottom: 50px
}

.p-planSVG {
  position: relative;
  z-index: 1;
  transform: translateY(-50%)
}

.p-planSVGSP {
  height: 78px;
  position: relative;
  z-index: 1;
  transform: translateY(-24%);
  max-width: 100%
}

.p-plan ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.2rem;
  display: flex
}

.p-plan ul>li {
  flex-basis: 50%;
  margin-bottom: 20px
}

.p-planIntensive {
  margin-bottom: 140px
}

.p-planIntensive__img {
  text-align: center;
  flex-basis: 40%
}

.p-planIntensive__img>img {
  width: 326px;
  max-width: 100%
}

.p-planIntensive__text {
  flex-basis: 60%
}

.p-planIntensive__logo {
  width: 126px
}

.p-planIntensive__logoSP {
  width: 81px
}

.p-planIntensive__table {
  margin-top: 75px
}

.p-planIntensive__table>table {
  margin-top: 40px;
  border-bottom: 1px solid #797979
}

.p-planIntensive__table>table td>div {
  font-size: 1.1rem;
  margin-top: 5px
}

.p-planIntensive__tableTitle {
  font-size: 2rem;
  margin-bottom: 20px
}

.p-planIntensive__tableLarge {
  font-size: 1.8rem
}

.p-planIntensive__tableRed {
  background-color: #f9f2f2
}

.p-planIntensive__tableCaption {
  font-size: 1rem;
  margin-top: 30px
}

.p-planIntensive__title {
  height: 60px;
  border-bottom: 1px solid #ccc;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 10px
}

.p-planIntensive__arrow {
  transition: all .3s;
  transform: rotate(0deg)
}

.p-planIntensive__content {
  display: none
}

.p-planIntensive__row {
  width: 100%
}

.p-planIntensive__row.active>.p-planIntensive__content {
  display: block
}

.p-planIntensive__row.active .p-planIntensive__arrow {
  transform: rotate(180deg)
}

.p-planIntensive__row:first-child {
  border-top: 1px solid #ccc
}

.p-planIntensive__spTable {
  margin-top: 25px
}

.p-planIntensive__spRow {
  border-bottom: 1px solid #ccc;
  align-items: center
}

.p-planIntensive__spRow:first-child {
  border-bottom: 1px solid #eee
}

.p-planIntensive__spCol {
  flex-basis: 50%;
  text-align: center;
  padding: 10px
}

.p-planIntensive__spContainer {
  display: flex;
  justify-content: center;
  align-items: center
}

.p-planIntensive__spLarge {
  font-size: 1.2rem
}

.p-planIntensive__spCaption {
  font-size: 0.9rem;
  margin-top: 3px
}

.p-planIntensive__spCaption2 {
  font-size: 0.9rem
}

.p-planIntensive__spHeader2 {
  line-height: 1
}

.p-planSimple {
  margin-bottom: 140px
}

.p-planSimple__img {
  text-align: center;
  flex-basis: 40%
}

.p-planSimple__img>img {
  width: 301px;
  max-width: 100%
}

.p-planSimple__text {
  flex-basis: 60%
}

.p-planSimple__cart {
  display: flex;
  justify-content: space-around;
  margin-top: 50px
}

.p-planSimple__cart__item>img {
  width: 240px
}

.p-planSimple__cart__item>p {
  font-size: 1.4rem;
  line-height: 1.5;
  margin: 10px auto
}

.p-planSimple__cart__item>a {
  width: 100%;
  max-width: 350px;
  margin-top: 20px
}

.p-planPreventive {
  margin-bottom: 120px
}

.p-planPreventive__img {
  text-align: center;
  flex-basis: 40%
}

.p-planPreventive__img>img {
  width: 203px;
  max-width: 100%
}

.p-planPreventive__text {
  flex-basis: 60%
}

.p-planPreventive .p-planSection__content {
  padding-bottom: 30px
}

.p-planTable {
  margin-bottom: 75px
}

.p-planTable__container {
  height: 215px
}

.p-planTable__img1 {
  width: 145px
}

.p-planTable__img2 {
  width: 155px
}

.p-planTable__img3 {
  width: 93px
}

.p-planTable__large {
  font-size: 1.8rem
}

.p-planTable__caption {
  margin-top: 5px
}

.p-planTable__title {
  height: 60px;
  border-bottom: 1px solid #ccc;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 10px
}

.p-planTable__arrow {
  transition: all .3s;
  transform: rotate(0deg)
}

.p-planTable__content {
  display: none
}

.p-planTable__row {
  width: 100%
}

.p-planTable__row.active>.p-planTable__content {
  display: block
}

.p-planTable__row.active .p-planTable__arrow {
  transform: rotate(180deg)
}

.p-planTable__td {
  position: relative
}

.p-planTable__tdRibbon {
  position: absolute;
  top: -10px;
  left: 0px
}

.p-planTable__tdRibbon__inner {
  display: inline-block;
  position: relative;
  height: 30px;
  line-height: 30px;
  text-align: center;
  padding: 0 30px 0 10px;
  font-size: 1.2rem;
  background: #221815;
  color: #fff;
  box-sizing: border-box
}

.p-planTable__tdRibbon__inner:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
  top: 0;
  right: 0;
  border-width: 30px 15px 15px 0px;
  border-style: solid
}

.p-planTable__tdRibbon__bg:after {
  border-color: transparent #eee transparent transparent
}

.p-planTable__tdRibbon__bgCP:after {
  border-color: transparent #f1ead8 transparent transparent
}

.p-planTable__tdBg__cp {
  background: linear-gradient(45deg, #f1e7cb 0%, #f7f3ea 35%, #f1e7cb 95% 100%)
}

.p-planTable__tdBg__cpHead {
  background: #f1ead8
}

.p-planTable__caption {
  text-align: center;
  margin: 10px 0 5px
}

.p-planTable__caption>span {
  padding: 4px 16px;
  border-radius: 30px;
  font-size: 1.1rem
}

.p-planTable__captionCP {
  background: linear-gradient(45deg, #f1da34 0%, #fff8c7 45%, #f1da34 70%, #fff8c3 85%, #f1da34 95% 100%);
  color: #000
}

.p-planTable__captionRed {
  border: 1px solid #221815;
  color: #221815
}

.p-planTable__captionBlack {
  border: 1px solid #000;
  color: #000
}

.p-planTable__spStd {
  text-decoration: line-through;
  margin: 10px 0 5px;
  font-size: 90%;
  color: #666
}

.p-planTable__spRow {
  border-bottom: 1px solid #ccc;
  padding: 10px 0 20px
}

.p-planTable__spCol {
  flex-basis: 50%;
  text-align: center
}

.p-planTable__spCol2 {
  flex-basis: 50%;
  text-align: center;
  display: flex;
  align-items: center;
  position: relative
}

.p-planTable__spCol2__inner {
  width: 100%;
  display: flex;
  flex-direction: column
}

.p-planTable__spCol2__inner>img {
  display: block;
  margin: auto
}

.p-planTable__spContainer {
  height: 110px;
  display: flex;
  justify-content: center;
  align-items: center
}

.p-planTable__spImg1 {
  width: 72px
}

.p-planTable__spImg2 {
  width: 77px
}

.p-planTable__spImg3 {
  width: 46px
}

.p-planTable__spLarge {
  font-size: 1.2rem
}

.p-planTable__spCaption {
  font-size: 0.9rem;
  margin-top: 3px
}

.p-planTable__spCaption2 {
  font-size: 0.9rem
}

.p-planTable__spHeader2 {
  line-height: 1
}

.p-planProduct select {
  -moz-appearance: none;
  -webkit-appearance: none;
  border: 1px solid #797979;
  border-radius: 5px;
  padding: 0 5px;
  background: #fff
}

.p-planProduct__items {
  justify-content: space-around
}

.p-planProduct__item {
  flex-basis: 25%;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding: 0 1rem;
  margin-bottom: 55px
}

.p-planProduct__label {
  font-size: 1.8rem;
  margin-bottom: 5px
}

.p-planProduct__caption {
  margin-bottom: 10px
}

.p-planProduct__name {
  margin-bottom: 5px
}

.p-planProduct__inner {
  margin-top: auto
}

.p-planProduct__img {
  height: 225px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  margin-bottom: 14px
}

.p-planProduct__img img {
  width: 100%;
  max-width: 85px;
  height: 225px;
  object-fit: contain
}

.p-planProduct__cart {
  display: flex;
  flex-direction: column
}

.p-planProduct__price {
  font-size: 1.6rem;
  width: 100%;
  padding-bottom: 10px
}

.p-planProduct__quantity {
  width: 100%
}

.p-planProduct__quantity>.c-mySelectBox {
  width: 60px;
  height: 36px
}

.p-planProduct__quantity>.c-mySelectBox::after {
  width: 1em
}

.p-planProduct__quantity>.c-mySelectBox>select {
  line-height: 34px;
  padding-left: 10px
}

.p-planProduct__button {
  text-align: center;
  margin-top: 20px
}

.p-planProduct__button>a {
  width: 160px;
  height: 40px;
  line-height: 40px;
  border-radius: 20px;
  background-color: #000;
  display: inline-block
}

.p-planNotice {
  margin-top: 2rem;
  padding: 0.75rem;
  border: 1px solid #000
}

.p-planNotice p {
  font-size: 1.25rem;
  font-weight: 400;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Yu Gothic", "MS Pゴシック", "MS PGothic", sans-serif;
  color: #000;
  margin-bottom: 0
}

.p-plan .disabled {
  background: #ccc;
  cursor: default
}

@media (min-width: 960px) {
  .p-planIntensive__table>ul {
    width: 850px
  }
  .p-planIntensive__table>ul>li {
    flex-basis: auto;
    min-width: 250px;
    font-size: 1.6rem;
    margin-bottom: 5px
  }
  .p-planIntensive__tableCaption {
    text-align: right
  }
  .p-planProduct__button>a:hover:hover {
    border: 1px solid #000;
    background-color: #fff;
    color: #000
  }
  .p-planProduct__cart {
    display: flex;
    align-items: baseline
  }
  .p-planSimple__cart__item {
    flex-basis: 45%;
    padding: 0 20px
  }
  .p-planSimple__cart__item>img {
    max-width: 240px
  }
  .p-planSimple__cart__item>p {
    font-size: 1.4rem
  }
  .p-planSection__button>a:hover {
    border: 1px solid #221815;
    background-color: transparent;
    color: #221815
  }
  a.disabled:hover {
    border: none;
    background-color: #ccc;
    color: #fff
  }
}

@media (min-width: 1200px) {
  .p-planSection__paymentContainer {
    width: 90%;
    margin: 0 auto
  }
}

@media (max-width: 1199px) {
  .p-plan ul {
    flex-direction: column
  }
  .p-planSection2 {
    width: 84%
  }
}

@media (max-width: 959px) {
  .p-plan {
    margin-top: calc(15px + (100vw - 320px) / 40);
    margin-bottom: 0
  }
  .p-plan>.c-hero {
    height: calc(75vw + (100vw - 320px) / 40)
  }
  .p-planTitle {
    margin-bottom: 45px
  }
  .p-planSection {
    width: 100%
  }
  .p-planSection__title {
    padding-bottom: 40px
  }
  .p-planSection__subtitle {
    font-size: 1.2rem
  }
  .p-planSection__info {
    font-size: 1.6rem
  }
  .p-planSection__content {
    font-size: 1.2rem;
    margin: 18px 0 25px
  }
  .p-planSection__price {
    margin-top: 45px
  }
  .p-planSection__priceItem {
    width: 100%;
    justify-content: space-between
  }
  .p-planSection__priceItem:first-child {
    margin-right: 0
  }
  .p-planSection__red {
    font-size: 1rem;
    border-radius: 16px
  }
  .p-planSection__ribbon {
    font-size: 1.1rem;
    padding: 0 15px;
    height: 30px;
    line-height: 30px
  }
  .p-planSection__ribbon:before {
    border-width: 15px 0px 15px 10px
  }
  .p-planSection__ribbon:after {
    border-width: 15px 10px 15px 0px
  }
  .p-planSection__number {
    font-size: 3rem
  }
  .p-planSection__number2 {
    font-size: 2rem
  }
  .p-planSection__number3 {
    font-size: 1.5rem
  }
  .p-planSection__value {
    justify-content: space-between
  }
  .p-planSection__kome {
    width: 100%;
    text-align: right;
    padding-left: 0
  }
  .p-planSection__yen {
    font-size: 1rem
  }
  .p-planSection__yen2 {
    font-size: 0.9rem
  }
  .p-planSection__yen3 {
    font-size: 0.9rem;
    line-height: 1.2
  }
  .p-planSection__payment {
    margin-top: 40px
  }
  .p-planSection__paymentMonth {
    width: 42.8%
  }
  .p-planSection__paymentMonth6 {
    width: 43.8%
  }
  .p-planSection__paymentTitle {
    font-size: 1.6rem;
    margin-bottom: 5px
  }
  .p-planSection__paymentSubtitle {
    font-size: 1.2rem;
    margin-bottom: 10px
  }
  .p-planSection__paymentLeft {
    width: 43%
  }
  .p-planSection__paymentLeft:before {
    position: absolute;
    right: -25px;
    border-left: 25px solid #221815
  }
  .p-planSection__paymentLeft6 {
    width: 44%
  }
  .p-planSection__paymentLeft6:before {
    position: absolute;
    right: -25px;
    border-left: 25px solid #221815
  }
  .p-planSection__paymentText1 {
    width: 38%
  }
  .p-planSection__paymentText2 {
    height: auto;
    left: 54%
  }
  .p-planSection__paymentText2__cp {
    top: 25px !important
  }
  .p-planSection__paymentText3 {
    height: auto;
    top: 50px;
    left: 44%
  }
  .p-planSection__paymentText3__cp {
    top: 56px !important
  }
  .p-planSection__paymentText3>img {
    width: 30px
  }
  .p-planSection__paymentText4 {
    left: 56%
  }
  .p-planSection__paymentText4>img {
    width: 30px
  }
  .p-planSection__paymentText5 {
    width: 46%
  }
  .p-planSection__paymentText6 {
    top: 5px;
    left: 44%
  }
  .p-planSection__paymentRight {
    margin-right: 25px
  }
  .p-planSection__paymentRight:before {
    right: -25px;
    border-left: 25px solid #f9f2f2
  }
  .p-planSection__paymentAll {
    margin-right: 25px
  }
  .p-planSection__paymentAll:before {
    right: -25px;
    border-left: 25px solid #221815
  }
  .p-planSection__paymentCaption {
    font-size: 1rem
  }
  .p-planSection__paymentPS {
    font-size: 1rem;
    font-weight: bold
  }
  .p-planSection__button>a {
    margin-top: 45px;
    width: 80vw;
    height: 50px;
    line-height: 50px;
    font-size: 1.2rem;
    border-radius: 25px
  }
  .p-planSection2 {
    width: 87%
  }
  .p-planSection2__title {
    text-align: center;
    height: 53px;
    line-height: 53px;
    font-size: 1.4rem;
    margin-bottom: 0
  }
  .p-plan ul>li {
    flex: 1 1 auto;
    max-width: 100%;
    margin-bottom: 5px
  }
  .p-planIntensive {
    margin-bottom: 64px
  }
  .p-planIntensive__img {
    flex: 1 1 auto;
    max-width: 100%;
    margin-bottom: 30px
  }
  .p-planIntensive__img>img {
    width: 172.5px
  }
  .p-planIntensive__text {
    flex: 1 1 auto;
    max-width: 100%
  }
  .p-planSimple {
    margin-bottom: 64px
  }
  .p-planSimple__img {
    flex: 1 1 auto;
    max-width: 100%;
    margin-bottom: 30px
  }
  .p-planSimple__img>img {
    width: 185.5px
  }
  .p-planSimple__text {
    flex: 1 1 auto;
    max-width: 100%
  }
  .p-planSimple__cart {
    flex-direction: column
  }
  .p-planSimple__cart__item {
    margin-bottom: 40px
  }
  .p-planSimple__cart__item>p {
    font-size: 1.4rem
  }
  .p-planSimple__cart__item>a {
    margin-top: 10px
  }
  .p-planPreventive {
    margin-bottom: 70px
  }
  .p-planPreventive__img {
    flex: 1 1 auto;
    max-width: 100%;
    margin-bottom: 30px
  }
  .p-planPreventive__img>img {
    width: 128.5px
  }
  .p-planPreventive__text {
    flex: 1 1 auto;
    max-width: 100%
  }
  .p-planProduct {
    padding-bottom: 70px
  }
  .p-planProduct__items {
    background-color: #fff;
    padding: 50px 0 10px
  }
  .p-planProduct__item {
    flex: 1 1 auto;
    max-width: 100%
  }
  .p-planProduct__label {
    font-size: 1.6rem
  }
  .p-planProduct__caption {
    font-size: 1.2rem
  }
  .p-planProduct__name {
    font-size: 1.4rem;
    margin-bottom: 10px
  }
  .p-planProduct__img {
    height: auto
  }
  .p-planProduct__img img {
    height: 250px
  }
  .p-planProduct__cart {
    width: 95%;
    margin: auto;
    flex-direction: row;
    align-items: center;
    justify-content: center
  }
  .p-planProduct__price {
    width: auto;
    padding-bottom: 0
  }
  .p-planProduct__quantity {
    width: auto
  }
  .p-planTable__tdRibbon {
    position: absolute;
    top: -10px;
    left: inherit;
    right: 0px
  }
  .p-planTable__tdRibbon__inner {
    padding: 0 10px 0 30px;
    height: 24px;
    line-height: 24px
  }
  .p-planTable__tdRibbon__inner:after {
    display: none
  }
  .p-planTable__tdRibbon__inner:before {
    position: absolute;
    content: '';
    width: 0px;
    height: 0px;
    z-index: 1;
    top: 0;
    left: 0;
    border-width: 25px 0px 0px 12px;
    border-style: solid
  }
  .p-planTable__tdRibbon__bg:before {
    border-color: transparent transparent transparent #eee
  }
  .p-planTable__tdRibbon__bgCP:before {
    border-color: transparent transparent transparent #f1ead8
  }
  .p-planNotice {
    margin-top: 2rem;
    padding: 0 1rem;
    background-color: #fff;
    border: none
  }
  .p-planNotice p {
    font-size: 1.25rem;
    font-weight: 400;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Yu Gothic", "MS Pゴシック", "MS PGothic", sans-serif;
    color: #000;
    margin-bottom: 0;
    padding: 0.75rem;
    border: 1px solid #000
  }
}

.p-product {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 140px
}

.p-productTop {
  padding-top: 294px;
  padding-bottom: 60px
}

.p-productTop__links {
  text-align: center
}

.p-productTop__links>li {
  display: inline-block;
  margin-left: 20px;
  position: relative
}

.p-productTop__links>li:after {
  margin-left: 20px;
  content: ' |'
}

.p-productTop__links>li:last-child:after {
  margin-left: 23px;
  content: ''
}

.p-productTop__links>li>a {
  font-size: 1.6rem;
  color: #000
}

.p-productTop__links>li>a:before {
  position: absolute;
  top: 30px;
  left: 0;
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background: #221815;
  transition: .3s
}

.p-productTop__links>li>a:hover:before {
  width: calc(100% - 25px) !important
}

.p-productTop__spLinks {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  list-style-type: none
}

.p-productTop__spLinks>li {
  flex-basis: 33.2%;
  background-color: #221815
}

.p-productTop__spLinks>li>a {
  width: 100%;
  display: block;
  text-align: center;
  line-height: 40px;
  font-size: 1.2rem
}

.p-productTop__spLinks>li:nth-child(n+4) {
  border-top: 1px solid #fff
}

.p-productTop__spLinks>li:nth-child(3n+1), .p-productTop__spLinks>li:nth-child(3n+2) {
  border-right: 1px solid #fff
}

.p-productEssence {
  position: relative;
  margin-bottom: 50px
}

.p-productEssence__title {
  position: absolute;
  top: 13px;
  text-align: center;
  font-size: 2rem;
  width: 443px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-productEssence>.left {
  width: 95%;
  left: -95%;
  background-image: url("../img/product/essence_bg.jpg");
  background-size: 100%;
  background-position: left top;
  background-color: #000;
  position: relative
}

.p-productEssence>.right {
  margin: 0 0 0 auto;
  width: 71%;
  right: -71%;
  top: -200px;
  z-index: 1;
  background-color: #fff;
  position: relative
}

.p-productEssence__product {
  flex-basis: 30%;
  max-width: 30%;
  text-align: center
}

.p-productEssence__product>img {
  width: 161px;
  position: relative;
  top: 135px
}

.p-productEssence__text {
  flex-basis: 70%;
  max-width: 70%;
  color: #fff;
  margin-top: 90px
}

.p-productEssence__text>div>h2 {
  font-size: 3.2rem;
  font-weight: normal;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productEssence__text>div>p {
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productEssence__accordion {
  position: relative;
  width: 100%;
  margin: 30px 0
}

.p-productEssence__accordion__header {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 1.6rem;
  display: block;
  position: relative;
  margin-bottom: 10px;
  padding: 0;
  color: #fff;
  cursor: pointer;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productEssence__accordion__header:after {
  content: "+";
  margin-left: 5px;
  width: 18px;
  height: 18px;
  font-size: 1.6rem;
  line-height: 14px;
  text-align: center;
  border: 1px solid #fff;
  display: inline-block
}

.p-productEssence__accordion__header.open:after {
  content: "-";
  margin-left: 5px;
  width: 18px;
  height: 18px;
  font-size: 1.6rem;
  line-height: 14px;
  text-align: center;
  border: 1px solid #fff;
  display: inline-block
}

.p-productEssence__accordion__contents {
  display: none
}

.p-productEssence__accordion__contents__inner {
  display: flex
}

.p-productEssence__accordion__contents__inner__flow {
  flex-basis: 40%
}

.p-productEssence__accordion__contents__inner__flow>img {
  width: 100%;
  max-width: 180px
}

.p-productEssence__accordion__contents__inner__flow>p {
  font-size: 1.2rem;
  background: rgba(0, 0, 0, 0.6);
  padding: 10px
}

.p-productEssence__detail {
  width: 100%;
  padding: 50px 5vw 65px 2vw;
  justify-content: space-between
}

.p-productEssence__detail>div {
  flex-basis: 30%;
  text-align: center
}

.p-productEssence__detail>div>div {
  text-align: left
}

.p-productEssence__detail>div>img {
  height: 245px
}

.p-productDevice {
  position: relative;
  margin-bottom: 50px
}

.p-productDevice__title {
  position: absolute;
  top: 140px;
  right: 0;
  text-align: center;
  font-size: 2rem;
  width: 313px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-productDevice>.right {
  margin: 0 0 0 auto;
  width: 95%;
  right: -95%;
  background-image: url("../img/product/device_bg.jpg");
  background-size: 100%;
  background-position: right top;
  background-color: #000;
  position: relative;
  padding-bottom: 70px
}

.p-productDevice>.left {
  width: 93.8%;
  left: -93.8%;
  top: -80px;
  z-index: 1;
  background-color: #fff;
  position: relative
}

.p-productDevice__product {
  flex-basis: 44%;
  max-width: 44%;
  text-align: center
}

.p-productDevice__product>img {
  width: 100%;
  max-width: 800px;
  position: relative;
  top: -130px;
  left: -30%
}

.p-productDevice__spProduct {
  width: 100%;
  text-align: center;
  padding-top: 40px
}

.p-productDevice__spProduct>img {
  width: 80%;
  max-width: 400px
}

.p-productDevice__text {
  flex-basis: 56%;
  max-width: 56%;
  color: #fff;
  margin-top: 90px;
  position: relative;
  left: 5%
}

.p-productDevice__text>div>h2 {
  font-size: 3.2rem;
  font-weight: normal;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productDevice__text>div>p {
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productDevice__accordion {
  position: relative;
  margin: 30px 0
}

.p-productDevice__accordion__header {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  font-size: 1.6rem;
  display: block;
  position: relative;
  margin-bottom: 10px;
  padding: 0;
  color: #fff;
  cursor: pointer
}

.p-productDevice__accordion__header:after {
  content: "+";
  margin-left: 5px;
  width: 18px;
  height: 18px;
  font-size: 1.6rem;
  line-height: 14px;
  text-align: center;
  border: 1px solid #fff;
  display: inline-block
}

.p-productDevice__accordion__header.open:after {
  content: "-";
  margin-left: 5px;
  width: 18px;
  height: 18px;
  font-size: 1.6rem;
  line-height: 14px;
  text-align: center;
  border: 1px solid #fff;
  display: inline-block
}

.p-productDevice__accordion__contents {
  display: none
}

.p-productDevice__accordion__contents__inner {
  display: flex;
  flex-wrap: wrap
}

.p-productDevice__accordion__contents__inner__flow {
  flex-basis: 30%
}

.p-productDevice__accordion__contents__inner__flow>img {
  width: 100%;
  max-width: 180px
}

.p-productDevice__accordion__contents__inner__flow>p {
  font-size: 1.2rem;
  background: rgba(0, 0, 0, 0.6);
  padding: 10px
}

.p-productDevice__detail {
  width: 100%;
  padding: 40px 3vw 65px 5vw;
  justify-content: space-between
}

.p-productDevice__detail>div {
  flex-basis: 18%;
  text-align: center
}

.p-productDevice__detail>div>div {
  text-align: left
}

.p-productDevice__detail>div>img {
  width: 90%;
  margin-bottom: 30px
}

.p-productSupplement {
  position: relative;
  margin-bottom: -60px
}

.p-productSupplement__title {
  position: absolute;
  top: 40px;
  text-align: center;
  font-size: 2rem;
  width: 400px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-productSupplement>.left {
  width: 95%;
  left: -95%;
  background-image: url("../img/product/supplement_bg.jpg");
  background-size: cover;
  background-color: #000;
  height: 633px;
  position: relative
}

.p-productSupplement>.right {
  margin: 0 0 0 auto;
  width: 71%;
  right: -71%;
  top: -200px;
  z-index: 1;
  background-color: #fff;
  position: relative
}

.p-productSupplement__product {
  width: 29vw;
  text-align: center
}

.p-productSupplement__product>img {
  width: 207px;
  position: relative;
  top: 135px
}

.p-productSupplement__text {
  flex: 1 1 auto;
  color: #fff;
  margin-top: 90px
}

.p-productSupplement__text>div>h2 {
  font-size: 3.2rem;
  font-weight: normal;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productSupplement__text>div>p {
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4), -2px 2px 5px rgba(0, 0, 0, 0.4), 2px -2px 5px rgba(0, 0, 0, 0.4), -2px -2px 5px rgba(0, 0, 0, 0.4)
}

.p-productSupplement__detail {
  width: 100%;
  padding: 50px 5vw 65px 2vw;
  justify-content: space-between
}

.p-productSupplement__detail>div {
  flex-basis: 30%;
  text-align: center
}

.p-productSupplement__detail>div>div {
  text-align: left
}

.p-productSupplement__detail>div>img {
  height: 245px
}

.p-productAdvisor {
  margin-bottom: 100px
}

.p-productAdvisor>.right {
  margin: 0 0 0 auto;
  width: 95%;
  right: -95%;
  background-color: #2d2d2d;
  height: 637px;
  position: relative
}

.p-productAdvisor>.left {
  width: 71.2%;
  left: -71.2%;
  top: -110px;
  z-index: 1;
  background-color: #fff;
  position: relative
}

.p-productAdvisor__product {
  margin-right: 4%;
  width: 647px;
  text-align: center;
  position: relative;
  top: -148px
}

.p-productAdvisor__product>img {
  width: 100%;
  position: relative
}

.p-productAdvisor__spProduct {
  width: 100%;
  text-align: center
}

.p-productAdvisor__spProduct>img {
  width: 100%;
  max-width: 400px
}

.p-productAdvisor__text {
  flex: 1 1 auto;
  color: #fff;
  margin-top: 100px;
  position: relative;
  left: 5%
}

.p-productAdvisor__title {
  font-size: 1.8rem;
  margin-bottom: 20px
}

.p-productAdvisor__detail {
  width: 100%;
  padding: 40px 3vw 65px 5vw;
  justify-content: space-between
}

.p-productAdvisor__detail>div {
  flex-basis: 28%;
  text-align: center
}

.p-productAdvisor__detail>div>div {
  text-align: left
}

.p-productAdvisor__detail>div>img {
  width: 90%;
  margin-bottom: 30px
}

.p-productApp {
  margin-bottom: 250px
}

.p-productApp>.left {
  width: 95%;
  left: -95%;
  background-color: #221815;
  height: 637px;
  position: relative
}

.p-productApp__product {
  flex-basis: 43%
}

.p-productApp__images {
  width: 408px;
  max-width: 100%;
  height: 860px;
  position: relative;
  bottom: 150px;
  margin: 0 0 0 auto;
  border-radius: 45px 45px;
  box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -webkit-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -moz-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -o-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5)
}

.p-productApp__frame {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2
}

.p-productApp__screen {
  width: 96.7%;
  position: absolute;
  top: 7px;
  left: 8px;
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0)
}

.p-productApp__screen.js-isActive {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  filter: alpha(opacity=1)
}

.p-productApp__text {
  color: #fff;
  flex-basis: 57%
}

.p-productApp__textGroup {
  width: 100%;
  padding: 60px 0 45px 12.5%
}

.p-productApp__title {
  font-size: 1.8rem;
  margin-bottom: 20px
}

.p-productApp__button {
  width: 100%;
  height: 80px;
  align-items: center;
  text-align: left;
  cursor: pointer;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2)
}

.p-productApp__button.js-isActive {
  background-color: rgba(255, 255, 255, 0.1)
}

.p-productApp__buttonLeft {
  flex-basis: 44.7%;
  font-size: 1.6rem;
  padding-left: 10%;
  padding-right: 3.5%
}

.p-productApp__buttonLine {
  width: 1px;
  height: 30px;
  background-color: #fff
}

.p-productApp__buttonRight {
  flex-basis: 55.1%;
  padding-left: 3.5%;
  padding-right: 3.5%
}

.p-productApp>.right {
  margin: 0 0 0 auto;
  width: 95%;
  right: -95%;
  background-color: #221815;
  color: #fff;
  position: relative
}

.p-productApp__textSP {
  width: 80%;
  margin: 0 auto;
  padding: 90px 0 40px
}

.p-productApp__titleSP {
  font-size: 1.4rem;
  margin-bottom: 20px
}

.p-productApp__sliderText {
  text-align: center;
  display: none;
  margin-bottom: 30px
}

.p-productApp__sliderText.js-isActive {
  display: block
}

.p-productApp__sliderTitle {
  font-size: 1.6rem;
  margin-bottom: 10px
}

.p-productApp__sliderContent {
  font-size: 1.2rem
}

.p-productApp__imageContainer {
  width: 100%;
  height: 600px;
  overflow-y: hidden;
  position: relative
}

.p-productApp__imagesSP {
  width: 250px;
  margin: 0 auto;
  height: 528px;
  position: relative;
  border-radius: 40px 40px;
  box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -webkit-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -moz-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5);
  -o-box-shadow: -15px 40px 45px 2px rgba(48, 48, 48, 0.5)
}

.p-productApp__frameSP {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2
}

.p-productApp__screenSP {
  width: 96.7%;
  position: absolute;
  top: 4px;
  left: 5px;
  -webkit-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0)
}

.p-productApp__screenSP.js-isActive {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  filter: alpha(opacity=1)
}

.p-productApp__prev {
  position: absolute;
  top: 215px;
  left: calc(25vw - 83px);
  width: 35px;
  height: 35px;
  border-radius: 17.5px;
  background-color: #fff;
  color: #000;
  z-index: 3
}

.p-productApp__prev>i {
  font-size: 3rem;
  line-height: 0.9
}

.p-productApp__next {
  position: absolute;
  top: 215px;
  right: calc(25vw - 83px);
  width: 35px;
  height: 35px;
  border-radius: 17.5px;
  background-color: #fff;
  color: #000;
  z-index: 3
}

.p-productApp__next>i {
  font-size: 3rem;
  line-height: 0.9
}

.p-productPlan {
  position: relative
}

.p-productPlan__title {
  position: absolute;
  top: 13px;
  left: 0;
  text-align: center;
  font-size: 2rem;
  width: 250px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-productPlan>.right {
  margin: 0 0 0 auto;
  padding: 80px 13%;
  width: 95%;
  right: -95%;
  background-color: #fff;
  position: relative
}

.p-productPlan__subtitle {
  font-size: 2.6rem;
  color: #221815;
  text-align: center;
  margin-bottom: 25px
}

.p-productPlan__items {
  justify-content: space-between
}

.p-productPlan__item {
  min-width: 211px;
  flex-basis: 25%;
  text-align: center
}

.p-productPlan__item__img {
  width: 100%;
  height: 250px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  margin-bottom: 40px
}

.p-productPlan__item__img1 {
  height: 191px
}

.p-productPlan__item__img2 {
  height: 192px
}

.p-productPlan__item__img3 {
  height: 151px
}

.p-productPlan__item__title {
  font-size: 1.8rem;
  margin-bottom: 13px
}

.p-productPlan__item__caption {
  font-size: 1.3rem;
  margin-top: 13px
}

.p-productPlan__button {
  text-align: center;
  margin-top: 60px
}

.p-productPlan__button>a {
  display: inline-block;
  text-align: center;
  width: 627px;
  height: 80px;
  line-height: 80px;
  border-radius: 40px;
  background-color: #221815;
  font-size: 1.8rem
}

.p-productPlan__button>a:hover {
  border: 1px solid #221815;
  background-color: #fff;
  color: #221815
}

.p-productPlan>.left {
  padding: 50px 10%;
  width: 95%;
  left: -95%;
  background-color: #fff;
  position: relative;
  text-align: center
}

.p-productPlan>.left hr {
  max-width: 450px;
  margin: 0 auto
}

.p-productPlan__subtitleSP {
  font-size: 1.6rem;
  margin-bottom: 25px;
  text-align: left
}

.p-productPlan__spImg1 {
  width: 172px
}

.p-productPlan__spImg2 {
  width: 209px
}

.p-productPlan__spImg3 {
  width: 84px
}

.p-productPlan__spTitle {
  font-size: 1.6rem;
  margin: 30px 0 15px
}

.p-productPlan__spCaption {
  font-size: 1.2rem;
  margin: 15px 0 50px
}

.p-productPlan__spButton {
  width: 100%;
  height: 50px;
  line-height: 50px;
  font-size: 1.2rem;
  border-radius: 25px;
  background-color: #221815;
  display: inline-block
}

@media (min-width: 960px) {
  .p-productEssence__detail__second {
    margin-bottom: 15px
  }
  .p-productEssence__accordion__pb {
    padding-bottom: 230px
  }
  .p-productEssence__accordion__contents__inner__flow {
    margin-right: 20px
  }
  .p-productDevice__accordion {
    width: 150%
  }
  .p-productDevice__accordion__pb {
    padding-bottom: 20px
  }
  .p-productDevice__accordion__contents__inner__flow {
    margin-right: 20px
  }
  #id-essence:before {
    display: block;
    height: 50px;
    margin-top: -50px;
    content: ""
  }
  #id-device:before {
    display: block;
    height: 180px;
    margin-top: -180px;
    content: ""
  }
  #id-supplement:before {
    display: block;
    height: 80px;
    margin-top: -80px;
    content: ""
  }
  #id-advisor:before {
    display: block;
    height: 200px;
    margin-top: -200px;
    content: ""
  }
  #id-app:before {
    display: block;
    height: 200px;
    margin-top: -200px;
    content: ""
  }
  #id-plan:before {
    display: block;
    height: 50px;
    margin-top: -50px;
    content: ""
  }
}

@media (max-width: 1199px) {
  .p-productAdvisor>.right {
    height: 519px
  }
  .p-productAdvisor__product {
    width: 550px
  }
}

@media (max-width: 959px) {
  .p-product {
    margin-top: calc(15px + (100vw - 320px) / 40);
    margin-bottom: 0
  }
  .p-product>.c-hero {
    height: calc(75vw + (100vw - 320px) / 40)
  }
  .p-productSVG {
    max-width: 60vw
  }
  .p-productTop {
    padding-top: 40px;
    padding-bottom: 80px
  }
  .p-productEssence {
    padding-bottom: 60px;
    margin-bottom: -100px
  }
  .p-productEssence__title {
    font-size: 1.4rem;
    top: -21px;
    width: 315px;
    height: 42px;
    line-height: 42px
  }
  .p-productEssence>.left {
    height: auto;
    padding-bottom: 160px;
    margin-bottom: 0;
    background-size: 400%
  }
  .p-productEssence>.right {
    width: 89%;
    top: -130px
  }
  .p-productEssence__product {
    flex-basis: 100%;
    max-width: 100%;
    flex: 1 1 auto
  }
  .p-productEssence__product>img {
    width: 80px;
    top: 50px;
    margin-bottom: 70px
  }
  .p-productEssence__text {
    flex-basis: 80%;
    max-width: 80%;
    flex: 1 1 auto;
    margin: 0 auto
  }
  .p-productEssence__accordion__contents__inner {
    flex-wrap: wrap
  }
  .p-productEssence__accordion__contents__inner__flow {
    flex-basis: 100%
  }
  .p-productEssence__accordion__contents__inner__flow>img {
    display: block;
    margin: 0 auto 10px
  }
  .p-productEssence__detail {
    padding: 20px 10% 40px 10%
  }
  .p-productEssence__detail>div {
    flex-basis: auto;
    max-width: 100%;
    text-align: center
  }
  .p-productEssence__detail>div:not(:last-child) {
    margin-bottom: 30px
  }
  .p-productEssence__detail>div>img {
    height: 189px
  }
  .p-productDevice {
    margin-bottom: -50px
  }
  .p-productDevice__title {
    font-size: 1.4rem;
    top: -21px;
    width: 190px;
    height: 42px;
    line-height: 42px
  }
  .p-productDevice>.right {
    background-image: url("../img/product/deviceSP_bg.jpg");
    background-size: contain;
    padding-bottom: 170px
  }
  .p-productDevice__text {
    flex-basis: 80%;
    max-width: 80%;
    flex: 1 1 auto;
    margin: 30px auto 0;
    left: unset
  }
  .p-productDevice__accordion__contents__inner {
    flex-wrap: wrap
  }
  .p-productDevice__accordion__contents__inner__flow {
    flex-basis: 100%
  }
  .p-productDevice__accordion__contents__inner__flow>img {
    display: block;
    margin: 0 auto 10px
  }
  .p-productDevice__detail {
    padding: 40px 10% 45px
  }
  .p-productDevice__detail>div {
    flex-basis: auto;
    max-width: 100%
  }
  .p-productDevice__detail>div:not(:last-child) {
    margin-bottom: 30px
  }
  .p-productDevice__detail>div>img {
    max-width: 320px;
    width: 70%
  }
  .p-productSupplement {
    padding-bottom: 60px;
    margin-bottom: -100px;
    margin-top: 50px
  }
  .p-productSupplement__title {
    font-size: 1.4rem;
    top: -21px;
    width: 245px;
    height: 42px;
    line-height: 42px
  }
  .p-productSupplement>.left {
    height: auto;
    padding-bottom: 160px;
    margin-bottom: 0;
    background-size: auto 60%
  }
  .p-productSupplement>.right {
    width: 89%;
    top: -130px
  }
  .p-productSupplement__product {
    width: 100%
  }
  .p-productSupplement__product>img {
    width: 154px;
    top: 50px;
    margin-bottom: 70px
  }
  .p-productSupplement__text {
    width: 80%;
    margin: 0 auto
  }
  .p-productSupplement__detail {
    padding: 20px 10% 40px 10%
  }
  .p-productSupplement__detail>div {
    flex-basis: auto;
    max-width: 100%
  }
  .p-productSupplement__detail>div:not(:last-child) {
    margin-bottom: 30px
  }
  .p-productSupplement__detail>div>img {
    height: 189px
  }
  .p-productAdvisor {
    margin-bottom: -40px
  }
  .p-productAdvisor>.right {
    height: auto
  }
  .p-productAdvisor>.left {
    width: 93.8%;
    left: -93.8%
  }
  .p-productAdvisor__text {
    width: 80%;
    margin: 30px auto 180px;
    left: unset
  }
  .p-productAdvisor__title {
    font-size: 1.4rem
  }
  .p-productAdvisor__detail {
    padding: 40px 10% 45px
  }
  .p-productAdvisor__detail>div {
    flex-basis: auto;
    max-width: 100%
  }
  .p-productAdvisor__detail>div:not(:last-child) {
    margin-bottom: 30px
  }
  .p-productAdvisor__detail>div>img {
    max-width: 320px;
    width: 70%
  }
  .p-productApp {
    margin-bottom: 70px
  }
  .p-productPlan__title {
    font-size: 1.4rem;
    top: -21px;
    width: 103px;
    height: 42px;
    line-height: 42px
  }
}

.p-PromotionHead__bnr {
  max-width: 640px;
  width: 100%
}

.p-PromotionMain {
  background: #eee
}

.p-PromotionHero__text {
  width: 100%;
  height: calc(100vw*0.45);
  min-height: 500px;
  background-image: url("../img/index/hero.jpg");
  background-size: cover;
  background-position: left center;
  position: relative
}

.p-PromotionHero__text__title {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  color: #fff;
  position: absolute;
  top: 36%;
  left: 53%;
  font-size: 4vw
}

.p-PromotionHero__text__title>span {
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif;
  letter-spacing: 6px
}

.p-PromotionHero__bnr {
  position: absolute;
  bottom: 5%;
  left: 53%;
  width: 35vw;
  max-width: 640px
}

.p-PromotionHero__bnr>img {
  width: 100%
}

.p-PromotionAbout {
  width: 100%;
  height: 650px;
  margin-bottom: 120px
}

.p-PromotionAbout__text {
  position: relative;
  z-index: 2
}

.p-PromotionAbout__text__title {
  color: #fff;
  width: 40%
}

.p-PromotionAbout__text__content {
  color: #fff;
  width: 39%
}

.p-PromotionAbout__text>.left {
  position: absolute;
  top: 180px;
  left: 6%
}

.p-PromotionAbout__back {
  position: relative;
  height: 100%
}

.p-PromotionAbout__back>.left {
  width: 49%;
  height: 557px;
  background-color: #221815;
  position: absolute;
  left: -49%;
  z-index: 1
}

.p-PromotionAbout__back>.left>img {
  margin-top: 118px
}

.p-PromotionAbout__back>.right {
  z-index: 0;
  width: 94.5%;
  height: 100%;
  position: absolute;
  right: -94.5%;
  background-color: #eee
}

.p-PromotionAbout__backText {
  position: absolute;
  right: -10px;
  bottom: -10px
}

.p-PromotionAbout__productImg {
  position: absolute;
  right: calc(4% + (100% - 960px)/10);
  top: 75px;
  width: 525px;
  max-width: 45%
}

.p-PromotionAbout__links {
  position: absolute;
  left: 7.4%;
  bottom: 195px;
  display: flex;
  width: 709px;
  justify-content: space-between
}

.p-PromotionAbout__links img {
  width: 195px
}

.p-PromotionAbout__links img:hover {
  border-radius: 5px;
  box-shadow: 0px 4px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 6px 0px rgba(0, 0, 0, 0.12)
}

.p-PromotionAbout__spLinks {
  text-align: left;
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
  margin: 0 20px;
  position: relative;
  z-index: 3
}

.p-PromotionAbout__spLinks a {
  display: inline-block
}

.p-PromotionAbout__spLinks a img {
  width: 154px
}

.p-PromotionAbout__spLinks div {
  width: 154px
}

.p-PromotionCommitment__hero {
  height: 438px;
  position: relative
}

.p-PromotionCommitment__heroBackground {
  width: 90%;
  height: 438px;
  position: absolute;
  top: 0;
  left: 5%;
  background-size: cover;
  background-position: 50%
}

.p-PromotionCommitment__heroText {
  position: absolute;
  top: 115px;
  left: calc(5% - 15px);
  text-align: left;
  color: #fff;
  border-left: 30px solid #221815;
  padding: 60px 0 30px 53px
}

.p-PromotionCommitment .commitmentbnr {
  margin: 20px auto;
  max-width: 640px;
  width: 100%
}

.p-PromotionProduct__hero {
  height: 438px;
  position: relative;
  margin-bottom: 150px
}

.p-PromotionProduct__heroBackground {
  width: 90%;
  height: 438px;
  position: absolute;
  top: 0;
  left: 5%;
  background-size: cover;
  background-position: 50%
}

.p-PromotionProduct__heroText {
  position: absolute;
  top: 115px;
  left: calc(5% - 15px);
  text-align: left;
  color: #fff;
  border-left: 30px solid #221815;
  padding: 60px 0 30px 53px
}

.p-PromotionPlan__Intensive {
  padding-bottom: 120px
}

.p-PromotionPlan__Intensive hr {
  margin: 10px 0
}

.p-PromotionPlan__Intensive ul {
  list-style-type: none;
  flex-wrap: wrap;
  font-size: 1.2rem;
  display: flex
}

.p-PromotionPlan__Intensive ul>li {
  flex-basis: 50%;
  margin-bottom: 20px
}

.p-PromotionPlan__Intensive__img {
  text-align: center;
  flex-basis: 40%
}

.p-PromotionPlan__Intensive__img>img {
  width: 326px;
  max-width: 100%
}

.p-PromotionPlan__Intensive__text {
  flex-basis: 60%
}

.p-PromotionPlan__Intensive__button {
  display: block;
  margin: 60px auto 0 !important;
  text-align: center
}

.p-PromotionPlan__Intensive__button>img {
  width: 100%;
  max-width: 640px
}

.p-Promotion__counselingbnr {
  display: block
}

.p-Promotion__counselingbnr:hover {
  opacity: .8
}

.o-header__inner>img {
  width: 50vw;
  max-width: 640px
}

@media (max-width: 959px) {
  .o-header {
    height: auto
  }
  .o-header__inner {
    flex-direction: column
  }
  .o-header__inner>img {
    margin-top: 20px;
    width: 90%
  }
  .p-PromotionHero {
    background: #95252b
  }
  .p-PromotionHero__text {
    background-image: url("../img/index/hero_sp.jpg");
    background-size: 100%;
    height: 140vw;
    max-height: 960px;
    background-position: bottom
  }
  .p-PromotionHero__text__title {
    width: 100%;
    text-align: center;
    font-size: calc(26px + (100vw - 320px) / 28);
    top: auto;
    left: auto;
    bottom: 5%
  }
  .p-PromotionHero__bnr {
    position: static;
    display: block;
    text-align: center;
    margin: 0 auto;
    width: 90%;
    padding-top: 20px
  }
  .p-PromotionAbout {
    height: auto;
    margin-bottom: 0
  }
  .p-PromotionAbout__text__title {
    color: #fff;
    width: 85%
  }
  .p-PromotionAbout__text__content {
    color: #fff;
    width: 85%
  }
  .p-PromotionAbout__text>.left {
    left: 9%;
    top: calc(98px + (100vw - 320px)/9)
  }
  .p-PromotionAbout__back::after {
    content: '';
    display: block;
    clear: both;
    height: 0;
    visibility: hidden
  }
  .p-PromotionAbout__back>.left {
    width: 100%;
    position: static;
    height: calc(400px + (100vw - 320px)/2)
  }
  .p-PromotionAbout__back>.left>img {
    margin-top: calc(48px + (100vw - 320px)/9)
  }
  .p-PromotionAbout__back>.right {
    position: static;
    float: right;
    text-align: center
  }
  .p-PromotionAbout__backText {
    width: 90%
  }
  .p-PromotionAbout__productImg {
    position: static;
    max-width: none;
    width: calc(52500%/767);
    margin: 10vw auto
  }
  .p-PromotionCommitment__hero {
    text-align: center;
    height: calc(75vw + (100vw - 320px)/40)
  }
  .p-PromotionCommitment__heroBackground {
    left: auto;
    top: 0;
    width: 100%;
    height: 75vw;
    background-position: 75% 50%
  }
  .p-PromotionCommitment__heroText {
    top: 18vw;
    left: 0;
    border-left: 10px solid #221815;
    padding: calc(17px + (100vw - 320px)/32) 20% calc(17px + (100vw - 320px)/32) calc(17px + (100vw - 320px)/32)
  }
  .p-PromotionProduct__hero {
    text-align: center;
    height: calc(75vw + (100vw - 320px)/40);
    margin-bottom: 80px
  }
  .p-PromotionProduct__heroBackground {
    left: auto;
    top: 0;
    width: 100%;
    height: 75vw;
    background-position: 75% 50%
  }
  .p-PromotionProduct__heroText {
    top: 18vw;
    left: 0;
    border-left: 10px solid #221815;
    padding: calc(17px + (100vw - 320px)/32) 20% calc(17px + (100vw - 320px)/32) calc(17px + (100vw - 320px)/32)
  }
  .p-PromotionProduct .p-productEssence>.left {
    background-size: 200%
  }
  .o-footer__inner {
    padding: 30px 0 30px;
  }
}

@media (max-width: 1199px) {
  .p-PromotionPlan__Intensive ul {
    flex-direction: column
  }
}

@media (min-width: 1441px) {
  .p-PromotionHero__text__title {
    font-size: 5rem
  }
  .p-PromotionAbout__productImg {
    right: calc(25.5% - 262px)
  }
}

@media (min-width: 550px) {
  .p-PromotionAbout__spDiv {
    display: none
  }
}

#page-top {
  position: fixed;
  z-index: 20;
  bottom: 20px;
  right: 20px;
  font-size: 70%
}

#page-top a {
  background: #fff;
  text-decoration: none;
  color: #444;
  width: 60px;
  height: 60px;
  padding: 10px;
  text-align: center;
  line-height: 1;
  display: block;
  border: 1px solid #aaa;
  opacity: 0.9
}

#page-top a:hover {
  text-decoration: none;
  background: #fff;
  opacity: 0.75
}

.p-science {
  background-color: #eee;
  margin-top: 254px;
  margin-bottom: 0
}

.p-scienceHeroText {
  color: #000
}

.p-scienceTopic {
  text-align: center
}

.p-scienceTopic>div {
  margin: 70px 0 96px
}

.p-scienceVersican {
  position: relative;
  padding-bottom: 120px
}

.p-scienceVersican__title {
  position: absolute;
  top: -40px;
  text-align: center;
  font-size: 2.8rem;
  width: 590px;
  height: 80px;
  line-height: 80px;
  color: #fff;
  background-color: #221815;
  z-index: 2
}

.p-scienceVersican>.left {
  width: 94.5%;
  left: -94.5%;
  padding-bottom: 100px;
  background-color: #fff;
  position: relative
}

.p-scienceVersican__backText {
  position: absolute;
  top: -20px;
  right: -20px;
  z-index: 1
}

.p-scienceVersican__group {
  padding-top: 185px
}

.p-scienceVersican__images {
  width: 688px;
  max-width: 50%;
  align-self: center;
  display: flex;
  flex-direction: column
}

.p-scienceVersican__images>img {
  width: 100%
}

.p-scienceVersican__spImages {
  display: flex;
  flex-direction: column
}

.p-scienceVersican__spImages>img {
  width: 100%
}

.p-scienceVersican__text {
  width: 100%;
  flex: 1 1 auto;
  align-self: center;
  padding-left: calc(3% + (100% - 767px)/90);
  padding-right: calc(6% + (100% - 767px)/90)
}

@media (max-width: 959px) {
  .p-science {
    margin-top: calc(15px + (100vw - 320px)/40)
  }
  .p-science>.c-hero {
    height: calc(75vw + (100vw - 320px)/40)
  }
  .p-scienceSVG {
    max-width: 65vw
  }
  .p-scienceTopic {
    text-align: center;
    width: 92%;
    margin: 0 auto
  }
  .p-scienceTopic>div {
    margin: 14vw 0 20vw
  }
  .p-scienceVersican__title {
    font-size: 1.4rem;
    top: -20px;
    width: 315px;
    max-width: 85vw;
    height: 40px;
    line-height: 40px
  }
  .p-scienceVersican>.left {
    padding-bottom: 20vw
  }
  .p-scienceVersican__backText {
    width: 95%;
    top: auto;
    right: 0;
    bottom: -5px
  }
  .p-scienceVersican__group {
    padding-top: 0
  }
  .p-scienceVersican__images {
    width: 100%;
    max-width: none;
    min-height: 0%
  }
  .p-scienceVersican__text {
    padding: 40px 10% 40px 9%
  }
}

.p-shoppingComp {
  max-width: 720px
}

.p-shoppingComp__order {
  margin: 30px 0
}

.p-shoppingComp__msg {
  margin-bottom: 45px
}

.p-shoppingComp__contact {
  width: 100%;
  max-width: 980px;
  border: 1px solid #d8d8d8;
  padding: 20px 0;
  display: flex
}

.p-shoppingComp__contactWrap {
  flex: 1 1 auto;
  padding: 0 20px
}

.p-shoppingComp__contactWrap:first-child {
  border-right: 1px solid #ccc
}

.p-shoppingComp__contactWrap__name {
  font-size: 1.2rem;
  margin-bottom: 5px
}

.p-shoppingComp__contactWrap__phone {
  font-size: 1.4rem;
  margin-bottom: 5px
}

.p-shoppingComp__contactWrap__phone>i {
  font-size: 1.6rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold;
  padding-right: 4px
}

.p-shoppingComp__contactWrap__phone>span {
  font-size: 1.2rem;
  font-weight: normal
}

.p-shoppingComp__contactWrap__mail>i {
  font-size: 1.6rem;
  color: #A82228;
  opacity: .5;
  position: relative;
  top: 3px;
  font-weight: bold;
  padding-right: 4px
}

.p-shoppingComp__contactWrap__subtitle {
  font-size: 1.4rem;
  margin-bottom: 10px
}

.p-shoppingComp__contactWrap__address {
  font-size: 1.2rem
}

.p-shoppingComp__contactWrap__time {
  font-size: 1.2rem
}

.p-shoppingComp__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 55px;
  display: inline-block
}

.p-shoppingComp__link:hover {
  color: #313131
}

.p-shoppingComp__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-shoppingComp__btn {
  margin: 50px auto 0;
  display: block;
  cursor: pointer
}

@media (max-width: 959px) {
  .p-shoppingComp__order {
    margin: 20px 0 30px
  }
  .p-shoppingComp__msg {
    margin-bottom: 35px
  }
  .p-shoppingComp__contact {
    width: 100%;
    flex-direction: column;
    padding: 20px 15px
  }
  .p-shoppingComp__contactWrap {
    padding: 20px 0
  }
  .p-shoppingComp__contactWrap:first-child {
    padding-top: 0;
    border-right: none;
    border-bottom: 1px solid #ccc
  }
  .p-shoppingComp__contactWrap:last-child {
    padding-bottom: 0
  }
}

.p-shoppingConf__title {
  margin-bottom: 35px
}

.p-shoppingConf__info .c-myHeading4 {
  margin: 30px 0 20px
}

.p-shoppingConf__customer {
  margin-top: 20px
}

.p-shoppingConf__item {
  width: 100%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  flex-wrap: wrap;
  justify-content: space-between;
  border-bottom: 1px solid #d8d8d8
}

.p-shoppingConf__itemImage {
  width: calc(160px + (100vw - 960px)/10)
}

.p-shoppingConf__itemImage>img {
  position: relative;
  left: 40px;
  width: 80px
}

.p-shoppingConf__itemDetail {
  flex: 1 1 auto
}

.p-shoppingConf__itemName {
  flex-basis: 70%
}

.p-shoppingConf__itemName>p {
  margin-bottom: 5px
}

.p-shoppingConf__itemName_set {
  font-size: 1.2rem;
  font-weight: normal;
  padding-left: 20px
}

.p-shoppingConf__itemPrice {
  margin-left: 20px;
  flex-basis: 30%;
  font-weight: bold
}

.p-shoppingConf__itemPrice>p>span {
  font-weight: normal
}

.p-shoppingConf__itemNext {
  width: 100%;
  margin-top: 10px;
  padding: 20px;
  border: 4px solid #eee
}

.p-shoppingConf__divider {
  margin-top: 30px;
  margin-bottom: 30px
}

.p-shoppingConf__content {
  margin-top: 20px
}

.p-shoppingConf__content__coupon {
  padding: 18px 0 25px 0;
  border-bottom: 2px dotted #d8d8d8
}

.p-shoppingConf__content__couponName {
  font-size: 1.6rem;
  font-weight: bold
}

.p-shoppingConf__content__couponDiscount {
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.25;
  color: #221815;
  margin-bottom: 0
}

.p-shoppingConf__content__couponDiscount>span {
  font-size: 1.8rem;
  padding-left: 5px
}

.p-shoppingConf__content__couponCode, .p-shoppingConf__content__couponDate {
  font-size: 1.2rem
}

.p-shoppingConf__small {
  font-size: 1.2rem
}

.p-shoppingConf__bill {
  width: 100%;
  border: 1px solid #919191;
  padding: 2.5%
}

.p-shoppingConf__billFlex {
  display: flex;
  margin-bottom: 15px;
  align-items: center
}

.p-shoppingConf__billTitle {
  flex: 1 1 auto
}

.p-shoppingConf__billCoupon {
  width: 100%;
  padding: 10px 20px;
  font-size: 1.4rem;
  background-color: #f8f8f8;
  margin-bottom: 15px
}

.p-shoppingConf__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin-bottom: 8px
}

.p-shoppingConf__billPrice {
  font-weight: bold;
  font-size: 1.8rem
}

.p-shoppingConf__billTax {
  font-weight: bold;
  font-size: 1.2rem
}

.p-shoppingConf__billBox {
  margin-top: 40px;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between
}

.p-shoppingConf__billBtn {
  width: 45%
}

.p-shoppingConf__billBtn>button {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-shoppingConf__billBtn>button>i {
  font-size: 1.8rem
}

.p-shoppingConf__billBtn>a {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-shoppingConf__billBtn>a>i {
  font-size: 1.8rem
}

.p-shoppingConf__billOrder {
  width: 100%;
  margin: 0px auto 10px
}

.p-shoppingConf__billBack {
  width: 100%
}

.p-shoppingConf__attention {
  margin-bottom: 50px;
  padding: 20px;
  border: 4px solid #eee
}

.p-shoppingConf__attention .p-shopping__title {
  margin-bottom: 20px
}

.p-shoppingConf__attention p {
  margin: 10px auto 20px
}

@media (min-width: 960px) {
  .p-shoppingConf {
    max-width: 720px
  }
  .p-shoppingConf__info {
    margin-bottom: 50px
  }
  .p-shoppingConf__divider {
    opacity: 0
  }
  .p-shoppingConf__bill {
    padding: 50px 8%
  }
}

@media (max-width: 959px) {
  .p-shoppingConf__title {
    margin-bottom: 20px
  }
  .p-shoppingConf__info {
    width: 100%;
    padding-right: 0
  }
  .p-shoppingConf__info .c-myHeading4 {
    margin: 20px 0 18px
  }
  .p-shoppingConf__block {
    margin-top: 30px;
    padding-top: 20px;
    position: relative
  }
  .p-shoppingConf__block::before {
    content: "";
    width: 120%;
    height: 3px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shoppingConf__content {
    margin-top: 20px;
    min-height: 20px
  }
  .p-shoppingConf__item {
    justify-content: normal
  }
  .p-shoppingConf__itemImage {
    width: 20%
  }
  .p-shoppingConf__itemImage>img {
    width: 100%;
    left: 0
  }
  .p-shoppingConf__itemDetail {
    width: 80%;
    padding-left: 10px;
    flex: inherit
  }
  .p-shoppingConf__itemName {
    flex: 1 1 auto
  }
  .p-shoppingConf__itemPrice {
    flex: 1 1 auto;
    margin-left: 0
  }
  .p-shoppingConf__itemNext {
    margin-top: 0;
    font-size: 1.2rem
  }
  .p-shoppingConf__attention {
    width: 100%;
    margin-top: 30px;
    margin-bottom: 0;
    padding: 25px 0 0;
    border: none;
    position: relative
  }
  .p-shoppingConf__attention::before {
    content: "";
    width: 120%;
    height: 3px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shoppingConf__bill {
    margin-top: 25px;
    padding: 25px 0;
    border: none;
    position: relative
  }
  .p-shoppingConf__bill::before {
    content: "";
    width: 120%;
    height: 6px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shoppingConf__billBox {
    margin-top: 0;
    flex-direction: column
  }
  .p-shoppingConf__billBtn {
    width: 100%;
    margin: 20px auto 0
  }
  .p-shoppingConf__billCoupon {
    padding: 10px
  }
}

.p-shoppingEdit__heading {
  margin-bottom: 20px
}

.p-shoppingEdit__flex>* {
  padding: 30px 20px 0
}

.p-shoppingEdit__flex>*:first-child {
  padding-left: 0
}

.p-shoppingEdit__flex>*:last-child {
  padding-right: 0
}

.p-shoppingEdit__title {
  width: 200px;
  font-size: 1.4rem;
  text-align: right;
  position: relative;
  top: 13px
}

.p-shoppingEdit__input {
  flex: 1 1 auto
}

.p-shoppingEdit__hr {
  padding-left: 220px
}

.p-shoppingEdit__hr>hr {
  margin-top: 30px
}

.p-shoppingEdit__zipBtn {
  width: 180px
}

.p-shoppingEdit__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-shoppingEdit__container {
    max-width: 960px;
    margin: 0
  }
  .p-shoppingEdit__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-shoppingEdit__heading {
    margin-bottom: 20px
  }
  .p-shoppingEdit__flex {
    margin-top: 10px
  }
  .p-shoppingEdit__flex>* {
    padding: 0 0 10px
  }
  .p-shoppingEdit__flex.no-title {
    margin-top: 0
  }
  .p-shoppingEdit__title {
    text-align: left;
    font-weight: bold;
    width: 100%;
    position: static
  }
  .p-shoppingEdit__title.no-top {
    padding: 0
  }
  .p-shoppingEdit__zipInput {
    display: flex
  }
  .p-shoppingEdit__zipIcon {
    width: 20px;
    line-height: 48px;
    font-size: 1.6rem
  }
  .p-shoppingEdit__zipSelect {
    flex: 1 1 auto;
    margin-right: 20px
  }
  .p-shoppingEdit__zipBtn {
    width: 120px;
    height: 48px;
    line-height: 46px;
    font-size: 1.2rem
  }
  .p-shoppingEdit__save {
    margin: 25px 0 40px
  }
}

.p-shoppingErr__title {
  color: #A82228
}

.p-shoppingErr__msg {
  margin-top: 30px
}

.p-shoppingErr__link {
  color: #A82228;
  text-decoration: underline;
  margin-top: 35px;
  display: inline-block
}

.p-shoppingErr__link:hover {
  color: #313131
}

.p-shoppingErr__link>.c-linkIcon {
  font-size: 20px;
  top: 5px;
  right: 3px;
  opacity: .5
}

.p-shoppingErr__btn {
  margin-top: 50px
}

@media (max-width: 959px) {
  .p-shoppingErr__msg {
    margin-top: 20px
  }
}

.p-shoppingShip__heading {
  margin-bottom: 30px
}

.p-shoppingShip__item {
  width: 80%;
  max-width: 960px;
  padding: 30px 0;
  border-bottom: 1px solid #d8d8d8;
  align-items: center
}

.p-shoppingShip__item__radio>label {
  height: 18px
}

.p-shoppingShip__item__info {
  flex: 1 1 auto;
  padding-left: 20px
}

.p-shoppingShip__item__btn {
  width: 180px;
  height: 50px;
  line-height: 48px
}

.p-shoppingShip__save {
  margin-top: 70px
}

@media (min-width: 960px) {
  .p-shoppingShip__item__radio {
    width: 120px;
    text-align: center
  }
  .p-shoppingShip__btns {
    padding-left: 220px
  }
  .p-shoppingShip__back {
    width: 180px;
    margin-right: 40px
  }
}

@media (max-width: 959px) {
  .p-shoppingShip__heading {
    margin-bottom: 20px
  }
  .p-shoppingShip__item {
    width: 100%
  }
  .p-shoppingShip__item__btn {
    width: 68px;
    height: 44px;
    line-height: 42px
  }
  .p-shoppingShip__save {
    margin: 50px 0 40px
  }
}

.p-shopping__subtitle {
  padding: 10px 2%;
  background: #fff;
  border: 4px solid rgba(168, 34, 40, 0.2);
  box-sizing: border-box;
  margin: 20px auto 10px;
  font-size: 1.4rem;
  color: #221815
}

.p-shopping__subtitle__last {
  margin-bottom: 25px
}

.p-shopping__info .c-myHeading4 {
  margin: 30px 0 20px
}

.p-shopping__customer {
  margin-top: 10px
}

.p-shopping__item {
  width: 100%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: top;
  border-bottom: 1px solid #d8d8d8
}

.p-shopping__itemImage {
  width: calc(160px + (100vw - 960px)/10)
}

.p-shopping__itemImage>img {
  position: relative;
  left: 40px;
  width: 80px
}

.p-shopping__itemDetail {
  flex: 1 1 auto
}

.p-shopping__itemName {
  flex-basis: 70%
}

.p-shopping__itemName>p {
  margin-bottom: 5px
}

.p-shopping__itemPrice {
  margin-left: 40px;
  flex-basis: 30%
}

.p-shopping__itemPrice>p>span {
  padding-left: 10px
}

.p-shopping__itemNext {
  width: 100%;
  margin-top: 10px;
  padding: 20px;
  border: 4px solid #eee
}

.p-shopping__divider {
  margin-top: 30px;
  margin-bottom: 30px
}

.p-shopping__addressBtn {
  width: 180px;
  height: 50px;
  line-height: 48px
}

.p-shopping__contact {
  margin-top: 30px
}

.p-shopping__radio {
  margin: 30px 0 10px
}

.p-shopping__grey {
  margin-top: 30px;
  background-color: #f4f4f4;
  padding: 30px
}

.p-shopping__grey__bottom {
  margin-bottom: 30px
}

.p-shopping__grey__content {
  flex-basis: 70%
}

.p-shopping__grey__number {
  border: 1px solid #d8d8d8;
  background-color: #fff;
  padding: 10px;
  font-weight: bold;
  margin-top: 20px
}

.p-shopping__grey__hr {
  margin: 30px 10% 30px 30%
}

.p-shopping__grey__sec {
  font-size: 1.2rem;
  margin-top: 10px
}

.p-shopping__grey__date {
  flex-basis: 45%
}

.p-shopping__grey__date>label {
  width: calc(100% - 18px);
  height: 50px
}

.p-shopping__grey__slash {
  flex-basis: 10%;
  text-align: center
}

.p-shopping__bill {
  width: 100%;
  border: 1px solid #919191;
  padding: 2.5%
}

.p-shopping__billFlex {
  display: flex;
  margin-bottom: 15px
}

.p-shopping__billTitle {
  flex: 1 1 auto
}

.p-shopping__billCoupon {
  width: 100%;
  padding: 10px 20px;
  font-size: 1.4rem;
  background-color: #f8f8f8;
  margin-bottom: 15px;
  position: relative
}

.p-shopping__billCoupon__close {
  background-image: url("../img/mypage/close.png");
  background-size: cover;
  position: absolute;
  top: 16px;
  right: 12px;
  width: 12px;
  height: 12px;
  cursor: pointer
}

.p-shopping__billCoupon__close:hover {
  transform: rotate(90deg);
  transition: all .1s
}

.p-shopping__bill>hr {
  border-top: 1px solid #d8d8d8;
  margin-bottom: 8px
}

.p-shopping__billPrice {
  font-weight: bold;
  font-size: 1.8rem
}

.p-shopping__billTax {
  font-weight: bold;
  font-size: 1.2rem
}

.p-shopping__billBox {
  margin-top: 40px;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between
}

.p-shopping__billBtn {
  width: 45%
}

.p-shopping__billBtn>button {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-shopping__billBtn>button>i {
  font-size: 1.8rem
}

.p-shopping__billBtn>a {
  display: inline-flex;
  justify-content: center;
  align-items: center
}

.p-shopping__billBtn>a>i {
  font-size: 1.8rem
}

.p-shopping__billOrder {
  width: 100%;
  margin: 0px auto 10px
}

.p-shopping__billBack {
  width: 100%
}

.p-shopping__select__err {
  flex-basis: 100%;
  font-size: 1.1rem;
  color: #A82228;
  margin: 5px 0 !important;
  display: block
}

.p-shopping__next ul {
  margin-left: 20px
}

.p-shopping__nextDetail {
  margin-bottom: 10px
}

.p-shopping__content {
  margin-top: 10px
}

@media (min-width: 960px) {
  .p-shopping {
    max-width: 720px
  }
  .p-shopping__info {
    padding-bottom: 30px;
    margin-bottom: 30px;
    border-bottom: 1px solid #e5e5e5
  }
  .p-shopping__divider {
    opacity: 0
  }
  .p-shopping__address {
    margin-bottom: 60px
  }
  .p-shopping__selectColumn {
    align-items: center;
    margin-top: 30px;
    flex-wrap: wrap
  }
  .p-shopping__selectTitle {
    flex-basis: 27%;
    padding-right: 40px;
    text-align: right
  }
  .p-shopping__select {
    flex-basis: 48%
  }
  .p-shopping__select>label {
    height: 50px
  }
  .p-shopping__select>input {
    height: 50px
  }
  .p-shopping__delivery .p-shopping__select__err {
    padding-left: 27%
  }
  .p-shopping__selectBtn {
    flex-basis: 25%;
    text-align: right;
    padding-left: 15px
  }
  .p-shopping__selectBtn>button {
    width: 180px;
    height: 50px;
    line-height: 46px
  }
  .p-shopping__grey__number {
    text-align: center;
    max-width: 400px
  }
  .p-shopping__grey__title {
    padding-top: 13px;
    flex-basis: 30%;
    padding-right: 20px;
    text-align: right
  }
  .p-shopping__grey__content>.c-mySelectBox, .p-shopping__grey__content>input {
    max-width: 400px;
    height: 50px
  }
  .p-shopping__grey__flex {
    width: 100%;
    max-width: 400px
  }
  .p-shopping__bill {
    padding: 50px 8%
  }
  .p-shopping__Coupon {
    align-items: flex-start
  }
}

@media (max-width: 959px) {
  .p-shopping__subtitle {
    font-size: 1.4rem;
    margin: 20px 0 10px
  }
  .p-shopping__subtitle__last {
    margin-bottom: 20px
  }
  .p-shopping__info {
    width: 100%;
    padding-right: 0
  }
  .p-shopping__info .c-myHeading4 {
    margin: 20px 0 18px
  }
  .p-shopping__block {
    margin-top: 30px;
    padding-top: 20px;
    position: relative
  }
  .p-shopping__block::before {
    content: "";
    width: 120%;
    height: 2px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shopping__item {
    justify-content: normal
  }
  .p-shopping__itemImage {
    width: 20%
  }
  .p-shopping__itemImage>img {
    width: 100%;
    left: 0
  }
  .p-shopping__itemName {
    flex: 1 1 auto
  }
  .p-shopping__itemDetail {
    width: 80%;
    padding-left: 10px;
    flex: inherit
  }
  .p-shopping__itemPrice {
    flex: 1 1 auto;
    margin-left: 0
  }
  .p-shopping__itemPrice>p {
    margin-bottom: 5px
  }
  .p-shopping__itemPrice>p>span {
    padding-left: 0
  }
  .p-shopping__itemNext {
    font-size: 1.2rem
  }
  .p-shopping__addressBtn {
    width: 100%;
    margin-top: 15px
  }
  .p-shopping__selectColumn {
    margin-top: 20px
  }
  .p-shopping__select {
    margin-top: 5px
  }
  .p-shopping__select>label {
    height: 50px
  }
  .p-shopping__selectBtn {
    margin-top: 20px
  }
  .p-shopping__delivery .p-shopping__selectBtn {
    margin-top: 0
  }
  .p-shopping__selectBtn>button {
    height: 50px;
    line-height: 48px
  }
  .p-shopping__contact {
    margin-top: 20px
  }
  .p-shopping__radio {
    margin: 20px 0 10px
  }
  .p-shopping__grey {
    margin-top: 20px;
    padding: 20px
  }
  .p-shopping__grey__content {
    flex: 1 1 auto
  }
  .p-shopping__grey__title {
    margin-bottom: 10px
  }
  .p-shopping__grey__bottom {
    margin-bottom: 20px
  }
  .p-shopping__grey__number {
    margin-top: 10px
  }
  .p-shopping__grey__hr {
    margin: 20px 0
  }
  .p-shopping__grey__date {
    flex-basis: auto;
    width: 100px
  }
  .p-shopping__grey__date>.c-mySelectBox {
    width: 80px;
    height: 50px
  }
  .p-shopping__grey__slash {
    flex-basis: unset;
    width: 32px
  }
  .p-shopping__bill {
    margin-top: 25px;
    padding: 25px 0;
    border: none;
    position: relative
  }
  .p-shopping__bill::before {
    content: "";
    width: 120%;
    height: 6px;
    background: #e5e5e5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%)
  }
  .p-shopping__billBox {
    margin-top: 0;
    flex-direction: column
  }
  .p-shopping__billBtn {
    width: 100%;
    margin: 20px auto 0
  }
  .p-shopping__billCoupon {
    padding: 10px
  }
}

.p-sitemap__title {
  margin-bottom: 30px
}

.p-sitemap__link {
  margin-top: 5px
}

.p-sitemap__link>a {
  text-decoration: underline;
  font-size: 1.4rem;
  color: #313131
}

@media (min-width: 960px) {
  .p-sitemap__link>a:hover {
    color: #A82228
  }
}

@media (max-width: 959px) {
  .p-sitemap__title {
    margin-bottom: 25px
  }
  .p-sitemap__link>a {
    font-size: 1.2rem
  }
}

.c-accordion {
  position: relative;
  margin: 30px 0
}

.c-accordion__header {
  font-size: 1.8rem;
  display: block;
  position: relative;
  padding: 20px 30px;
  color: #fff;
  background-color: #221815;
  cursor: pointer
}

.c-accordion__header:after {
  content: 'expand_more';
  font-family: "Material Icons";
  font-size: 3rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 10px
}

.c-accordion__header.open:after {
  -webkit-transform: rotate(180deg);
  transform: translateY(-50%) rotate(180deg)
}

.c-accordion__contents {
  display: none
}

.c-accordion__contents>dl>dt {
  background-color: #faf4f4;
  padding: 20px 40px;
  font-size: 1.6rem;
  display: flex
}

.c-accordion__contents>dl>dt>span {
  font-size: 1.8rem;
  color: #221815;
  padding-right: 5px;
  font-family: "didot", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", 'Noto Sans JP', serif
}

.c-accordion__contents>dl>dd {
  background-color: #fff;
  padding: 20px 40px 20px 80px;
  border-bottom: 1px solid #ccc;
  font-size: 1.3rem;
  line-height: 1.6;
  position: relative
}

.c-accordion__contents>dl>dd:last-child {
  border-bottom: none
}

.c-accordion__contents>dl>dd:before {
  position: absolute;
  top: 15px;
  left: 55px;
  font-size: 2rem;
  color: #221815;
  content: 'arrow_right';
  font-family: "Material Icons"
}

.c-accordion__contents>dl>dd ul {
  list-style-type: circle;
  margin-left: 20px
}

.c-accordion__contents>dl>dd>a {
  color: #221815
}

.c-accordion__contents>dl>dd>a:hover {
  text-decoration: underline
}

@media (max-width: 959px) {
  .c-accordion {
    margin: 20px auto
  }
  .c-accordion__header {
    padding: 20px 10px
  }
  .c-accordion__contents>dl>dt {
    font-size: 1.8rem;
    padding: 20px 10px
  }
  .c-accordion__contents>dl>dd {
    font-size: 1.6rem;
    padding: 20px 10px 20px 40px
  }
  .c-accordion__contents>dl>dd:before {
    top: 14px;
    left: 10px;
    font-size: 2.5rem
  }
}

.c-heroFade {
  opacity: 0;
  margin-top: 50px
}

.c-bannerFade {
  opacity: 0;
  margin-top: 50px
}

.c-fadeText {
  padding-top: 20px;
  opacity: 0
}

.js-fadeUp {
  opacity: 1;
  margin-top: 0;
  transition: all 1.5s cubic-bezier(0.35, 1, 0.45, 1) 0s, transform 1.5s cubic-bezier(0.35, 1, 0.45, 1) 0s
}

.js-fadeUpText {
  opacity: 1;
  padding-top: 0;
  transition-duration: 2s;
  transition-delay: 1s;
  transition-property: opacity, padding-top
}

.c-fadeUp {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1.5s, transform 1.5s
}

.c-fadeUp.is-inview {
  opacity: 1;
  transform: translateY(0);
  transition-delay: .5s
}

@media (max-width: 959px) {
  .c-fadeUp {
    transform: translateY(5vw)
  }
}

@media (max-width: 959px) {
  .c-fixed {
    position: fixed;
    top: 0;
    z-index: 50;
    padding: 10px 0 !important;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 5px 0px;
    -webkit-box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 5px 0px;
    -moz-box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 5px 0px;
    overflow: hidden
  }
  .c-fixed>.o-header__inner {
    align-items: baseline
  }
  .c-fixed>.o-header__inner>h1 {
    margin: 0 0 0 10px
  }
  .c-fixed>.o-header__inner>h1>.c-siteLogo {
    width: 74px;
    height: 40px;
    transition: 0.2s
  }
  .c-fixed>.c-headerIcon {
    top: 0;
    right: 70px;
    flex-direction: row;
    width: 120px;
    transition: 0.2s
  }
  .c-fixed>.c-headerIcon>a {
    padding: 6px 0
  }
}

.c-modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100
}

.c-modal__bg {
  background: rgba(0, 0, 0, 0.35);
  height: 100vh;
  position: absolute;
  width: 100%
}

.c-modal__content {
  background: #fff;
  padding: 25px 65px 35px;
  position: absolute;
  width: 500px;
  max-width: calc(100vw - 60px);
  min-width: 260px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%)
}

.c-modal__close {
  background-image: url(../img/mypage/close.png);
  background-size: cover;
  position: absolute;
  top: 20px;
  right: 20px;
  width: 16px;
  height: 16px;
  cursor: pointer
}

@media (max-width: 959px) {
  .c-modal__content {
    padding: 50px 30px 25px
  }
}

.c-pagetop {
  position: fixed;
  z-index: 20;
  bottom: 20px;
  right: 20px;
  font-size: 70%
}

.c-pagetop>a {
  background: #222;
  text-decoration: none;
  color: #fff;
  width: 50px;
  height: 50px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: space-around;
  border-radius: 50%
}

.c-pagetop>a:hover {
  text-decoration: none;
  background: #333;
  opacity: 0.75
}

.c-move .js-insertSection__left {
  transition: left 1.5s;
  left: 0
}

.c-move .js-insertSection__right {
  transition: right 1.5s;
  right: 0
}


.more_btn{
  text-decoration: none;
  color: #fff;
  /* font-family: eb-garamond, serif; */
  font-size: 13px;
  font-weight: 500;
  background: #ddd;
}
.more_btn-Text{
  position: relative;
  z-index: 1;
  letter-spacing: .08em;
  font-weight: 500;
  padding: 10px;
  /* border: 1px solid #ddd; */
  background: #221815;
  border-radius: 50px;
}

.more_btn-Text:before{
  font-family: 'Font Awesome 6 pro';
  content: "\f178";
/*   font-size: px; */
  padding-right: 10px;
}


.more_btn-Text:after{
  content: '';
  position: absolute;
  left: 0;
  bottom: -10px;/*テキストからの距離*/
  width: 0%;/*初期状態では下線非表示*/
  height: 1px;/*下線の高さ*/
  background: #888;/*下線の色*/
  z-index: -1;
  transition: all 0.4s;/*アニメーション速度*/
}
.more_btn:hover .more_btn-Text:after{
  width: 100%;/*hover時に表示*/
}



   /* ======== table.tableOther ======== */
   table.company {border-collapse: collapse;text-align: left;font-size: 15px;letter-spacing:1px;line-height:2;width:100%;}
   table.company tr { }
   table.company th {width:25%;padding: 24px;vertical-align: 0;border: #ddd 1px solid;border-right:#ddd 1px dashed;border-right: #ddd 1px solid;}
   table.company td {padding:22px;vertical-align: 0;border: #ddd 1px solid; border-left:none;}
   table.company td .linkArea {margin-top:10px;text-align:left;}
   table.company td .linkArea a.btn {margin:0;}

   table.company td a{color:#000}

   @media only screen and (max-width: 950px) {
   table.company th {width:30%;padding:20px;}
   table.company td {padding:20px;}
   }

   @media only screen and (max-width: 800px) {
   table.company { font-size:13px;}
   }
   @media only screen and (max-width: 738px) {
     table.company {/* font-size:12px; */}
   }
   @media only screen and (max-width: 414px) {
   table.company th {width:30%;padding:15px;}
   table.company td {padding:15px;}
   }


   /* ======== table.tableOther ======== */
   table.company {border-collapse: collapse;text-align: left;font-size: 15px;letter-spacing:1px;line-height:2;width:100%;}
   table.company tr { }
   table.company th {width:25%;padding: 24px;vertical-align: 0;/* border: #ddd 1px solid; */border-right:#ddd 1px dashed;border-right: #ddd 1px solid;}
   table.company td {padding:22px;vertical-align: 0;border: #ddd 1px solid; border-left:none;}
   table.company td .linkArea {margin-top:10px;text-align:left;}
   table.company td .linkArea a.btn {margin:0;}

   /* --- #map_canvas --- */
   #map_canvas { width:100%; margin-top:70px; height:400px;position: relative; z-index: 1; border: #ededed 1px solid;}



   @media only screen and (max-width: 950px) {
   table.company th {width:30%;padding:20px;}
   table.company td {padding:20px;}
   }

   @media only screen and (max-width: 800px) {
   table.company { font-size:13px;}
   }
   @media only screen and (max-width: 738px) {
     #outline .imgArea {/* float:none; */width:100%;display: block;}
     #outline .txtArea {float:none;width:100%;/* margin-top:25px; */}
     table.company {/* font-size:12px; */}
   /*	#map_canvas { display:none; }*/
   }
   @media only screen and (max-width: 414px) {
   table.company th {width:30%;padding:15px;}
   table.company td {padding:15px;}
   }



/* --------------------------------------------------------------

----------------------------------------------------------------*/
/* views */
.spView,
.spViewInb,
.tbView {
  display: none !important;
}
@media only screen and (max-width:991px) {
  .tbView {
    display: block !important;
  }
}
@media only screen and (max-width:768px) {
  .spView {
    display: block !important;
  }
  .spViewInb {
    display: inline-block !important;
  }
  .pcView {
    display: none !important;
  }
}


   .como_inner {
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
  }

  .como_box {
    margin-top: 60px;
    border: 1px solid #d7d7d7 ;
    padding:30px 20px;
  }

  .como_title {
    position: relative;
    font-size: 26px;
    letter-spacing: 0.1em;
    font-weight: 100;
    padding-bottom: 20px;
    padding-left: 10px;
    border-bottom: 1px solid #d7d7d7 ;
  }



  .como_txt {
    font-size: 17px;
  }


  .label_title::after {
    content: 'about';
    position: absolute;
    right: 10px;
    font-size: 18px;
    padding: 4px 20px;
    border-radius: 30px;
    background-color: #000000;
    color: #fff;
  }


  .como_flex {
    display: flex;
    padding: 0 10px;
    margin-top: 30px;
    margin-bottom: 30px;
  }

  .como_flex_img {
    width: 30%;
  }

  .como_flex_text {
    width: 66%;
    margin-left: 40px;
  }

  .como_flex_title {
    font-size: 20px;
    line-height: 1.6;
    letter-spacing: 0.05em;
    font-weight: 100;
  }

  .como_flex_menu {
    margin-top: 20px;
    font-weight: 100;
    line-height: 2.5;
    font-size: 17px;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .menu_text {
    font-weight: 100;
    line-height: 1.7;
    font-size: 16px;
  }

  .como_flex_menu dt {
    width: 30px;
    text-align: left;
    color: #333;
  }

  .como_flex_menu dd {
    width: calc(100% - 40px);
    text-align: left;
    padding-left:1em;
    text-indent:-1em;
  }

  .como_link {
    margin-top: 10px;
    text-align: right;
  }

  .como_btn {
    position: relative;
    display: inline-block;
    min-width: 280px;
    background-color: #000000;
    padding: 12px 10px 12px 24px;
    line-height: 1.4;
    letter-spacing: 0.1em;
    font-size: 16px;
    color: #fff;
    text-align: left;
    margin: 0 10px;
    transition: all .5s;
    text-decoration: none;
  }

  /*--- 矢印 ---*/
  .como_btn::before{
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px;
    width: 34px;
    height: 1px;
    background:#fff;
    transition: all .5s;
  }
  .como_btn::after{
    content: '';
    position: absolute;
    top: 40%;
    right: 31px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    transition: all .5s;
  }
  .como_btn:hover {
    opacity: .8;
    color: #fff !important;
  }
  .como_btn:hover::before {
    right: 23px;
  }
  .como_btn:hover::after {
    right: 24px;
  }

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

    .como_inner {
      padding: 0;
    }

    .como_box {
      margin-top: 30px;
      padding: 20px;
    }

    .como_title {
      position: relative;
      font-size: 20px;
      padding-bottom: 14px;
      padding-left: 0;
    }

    .label_title::after {
      right: -14px;
      top: 0;
      font-size: 14px;
    }

    .como_flex {
      display: block;
      padding: 0 ;
      margin-top: 20px;
    }

    .como_flex_img {
      width: 100%;
    }

    .como_flex_text {
      width: 100%;
      margin-left: 0;
    }

    .como_flex_title {
      font-size: 16px;
      margin-top: 10px;
    }

    .como_flex_menu {
      margin-top: 10px;
      line-height: 1.7;
      font-size: 16px;
    }

    .como_flex_menu dt {
      width: 100%;
      text-align: left;
      color: #333;
    }

    .como_flex_menu dd {
      width: 100%;
      text-align: left;
    }

    .como_link {
      margin-top: 10px;
      text-align: center;
    }

    .como_btn {
      position: relative;
      display: inline-block;
      min-width: 280px;
      background-color: #185e7d;
      padding: 12px 10px 12px 24px;
      line-height: 1.4;
      letter-spacing: 0.1em;
      font-size: 16px;
      color: #fff;
      text-align: left;
      margin: 0 10px;
    }

    /*--- 矢印 ---*/
    .como_btn::before{
      content: '';
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 30px;
      width: 34px;
      height: 1px;
      background:#fff;
      transition: all .5s;
    }
    .como_btn::after{
      content: '';
      position: absolute;
      top: 40%;
      right: 31px;
      width: 10px;
      height: 10px;
      border-top: 1px solid #fff;
      border-right: 1px solid #fff;
      transform: rotate(45deg);
      transition: all .5s;
    }
    .como_btn:hover::before {
      right: 23px;
    }
    .como_btn:hover::after {
      right: 24px;
    }
  }
/*
.contents_box{display:flex;flex-wrap: wrap;width: 98%;margin: 0 auto;max-width: 1100px;justify-content: space-between;padding: 20px;}
.con_box{width:31%;border: 1px solid #ddd;}
.con_box .con_titile{font-size:18px;} */




.noa-mission {
  margin-top: 80px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  width: 1100px;
  margin: 50px auto;
  padding: 20px;
}
.noa-mission-txt {
  padding: 0px 0;
  text-align: center;
  color: #2f4f4f;
  width: 31%;
  /* border-right: 1px solid #dcdcdc; */
  border: 1px solid #ddd;
  background: #fff;
  align-self: stretch;
}
.noa-mission-txt:last-child {
/*   border-right: none; */
}
.noa-mission-txt p {
  padding-bottom: 10px;
  font-size: 1.5rem;
  font-weight: 500;
  padding: 0 20px;
}

.noa-mission-txt span {
  display: block;
  font-size: 50px;
  padding-bottom: 10px;
  border-bottom: 1px solid #ddd;
}
.sp-only {
  display: none;
}

/* --- Section Noa SP -- */
@media(max-width:499px){
  .noa {
      margin-top: 30px;
      margin-bottom: 30px;
  }
  .noa-ttl span {
      display: block;
      line-height: 1.1;
  }
  .main-ttl {
      font-size: 60px;
  }
  .noa-mission {
      margin-top: 20px;
  }
  .noa-mission-txt {
      width: 100%;
      border-right: none;
  }
  .noa-mission-txt:last-child {
      border-bottom: none;
  }
  .noa-mission-txt p {
      display: inline;
      font-size: 1.2rem;
      vertical-align: baseline;
  }
  .noa-mission-txt span {
      padding-bottom: 0;
      padding-right: 10px;
      display: inline;
      font-size: 50px;
      vertical-align: baseline;
  }
  .sp-only {
      display: block;
      width: 75%;
      border-top: 1px solid #dcdcdc;
  }

}



/* CSS Document */
/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */

/* Reset box-model and set borders */
/* ============================================ */

*,
::before,
::after {
box-sizing: border-box;
border-style: solid;
border-width: 0;
}

/* Document */
/* ============================================ */

/**
* 1. Correct the line height in all browsers.
* 2. Prevent adjustments of font size after orientation changes in iOS.
* 3. Remove gray overlay on links for iOS.
*/

html {
line-height: 1.15; /* 1 */
-webkit-text-size-adjust: 100%; /* 2 */
-webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */

/**
* Remove the margin in all browsers.
*/

body {
margin: 0;
}

/**
* Render the `main` element consistently in IE.
*/

main {
display: block;
}

/* Vertical rhythm */
/* ============================================ */

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl,
menu {
/* margin: 0; */
}

/* Headings */
/* ============================================ */

h1,
h2,
h3,
h4,
h5,
h6 {
font-size: inherit;
line-height: inherit;
font-weight: inherit;
margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */

ul,
ol {
margin: 0;
padding: 0;
list-style: none;
}

/* Lists (definition) */
/* ============================================ */

dt {
font-weight: inherit;
}

dd {
margin-left: 0;
}

/* Grouping content */
/* ============================================ */

/**
* 1. Add the correct box sizing in Firefox.
* 2. Show the overflow in Edge and IE.
*/

hr {
box-sizing: content-box; /* 1 */
height: 0; /* 1 */
overflow: visible; /* 2 */
border-top-width: 1px;
margin: 0;
clear: both;
color: inherit;
}

/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/

pre {
font-family: monospace, monospace; /* 1 */
font-size: inherit; /* 2 */
}

address {
font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */

/**
* Remove the gray background on active links in IE 10.
*/

a {
background-color: transparent;
text-decoration: none;
color: inherit;
}

/**
* 1. Remove the bottom border in Chrome 57-
* 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
*/

abbr[title] {
text-decoration: underline; /* 2 */
text-decoration: underline dotted; /* 2 */
}

/**
* Add the correct font weight in Chrome, Edge, and Safari.
*/

b,
strong {
font-weight: bolder;
}

/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp {
font-family: monospace, monospace; /* 1 */
font-size: inherit; /* 2 */
}

/**
* Add the correct font size in all browsers.
*/

small {
font-size: 80%;
}

/**
* Prevent `sub` and `sup` elements from affecting the line height in
* all browsers.
*/

sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}

sub {
bottom: -0.25em;
}

sup {
top: -0.5em;
}

/* Embedded content */
/* ============================================ */

/**
* Prevent vertical alignment issues.
*/

img,
embed,
object,
iframe {
vertical-align: bottom;
}

/* Forms */
/* ============================================ */

/**
* Reset form fields to make them styleable
*/

button,
input,
optgroup,
select,
textarea {
-webkit-appearance: none;
appearance: none;
vertical-align: middle;
color: inherit;
font: inherit;
background: transparent;
padding: 0;
margin: 0;
outline: 0;
border-radius: 0;
text-align: inherit;
}

/**
* Reset radio and checkbox appearance to preserve their look in iOS.
*/

[type="checkbox"] {
-webkit-appearance: checkbox;
appearance: checkbox;
}

[type="radio"] {
-webkit-appearance: radio;
appearance: radio;
}

/**
* Show the overflow in IE.
* 1. Show the overflow in Edge.
*/

button,
input {
/* 1 */
overflow: visible;
}

/**
* Remove the inheritance of text transform in Edge, Firefox, and IE.
* 1. Remove the inheritance of text transform in Firefox.
*/

button,
select {
/* 1 */
text-transform: none;
}

/**
* Correct the inability to style clickable types in iOS and Safari.
*/

button,
[type="button"],
[type="reset"],
[type="submit"] {
cursor: pointer;
-webkit-appearance: none;
appearance: none;
}

button[disabled],
[type="button"][disabled],
[type="reset"][disabled],
[type="submit"][disabled] {
cursor: default;
}

/**
* Remove the inner border and padding in Firefox.
*/

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
border-style: none;
padding: 0;
}

/**
* Restore the focus styles unset by the previous rule.
*/

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
outline: 1px dotted ButtonText;
}

/**
* Remove arrow in IE10 & IE11
*/

select::-ms-expand {
display: none;
}

/**
* Remove padding
*/

option {
padding: 0;
}

/**
* Reset to invisible
*/

fieldset {
margin: 0;
padding: 0;
min-width: 0;
}




details {
display: block;
}

/*
* Add the correct display in all browsers.
*/

summary {
display: list-item;
}

/*
* Remove outline for editable content.
*/

[contenteditable] {
outline: none;
}



.pickup {
    padding: 30px 0px;
    background-color: #f1efef;
    position: relative;
}


.pickup .wrap{
	max-width:1200px;
	margin:0 auto;
	width: 100%;
}




 .pickup.mt {
    margin-top: 30px;
}

 .pickup .img_pickup {
    width: 100px;
    margin-left: -50px;
    margin-bottom: 20px;
}

 .pickup .title {
    font-size: 1.4rem;
    font-weight: bold;
    margin-bottom: 20px;
    line-height: 1.5;
    display: flex;
    align-items: center;
}

 .pickup .title:before {
  font-family: 'FontAwesome';
  content: "\f097";
  padding-right: 5px;
  color: #6b0948;
  font-size: 1.2em;
}





 .pickup .title span {
    font-size: 0.8rem;
    font-size: 1.2rem;
    display: block;
    margin-left: 10px;
}

@media screen and (max-width: 1024px) {
     .pickup .title {
        flex-direction: column;
    }
}


 .pickup .title .underline {
    font-weight: bold;
}

 .pickup .title .underline::before {
    height: 10px;
}

 .pickup .txt {
    /* background: #fff; */
    padding: 20px;
    border-radius: 1em;
    margin-top: 1em;
    margin-bottom: 1em;
    /* max-width: 1000px; */
    /* width: 95%; */
    width: 100%;
    margin: 0 auto;
    text-align: center;
}

 .pickup .plan_title {
    font-size: 25px;
    line-height: 2;
    margin: 0;
    /* margin-bottom: 20px; */
    font-weight: 600;
    color: #17546b;
    }

 .pickup .name {
    font-size: 25px;
    line-height: 2;
    margin-bottom: 20px;
    font-weight: 600;
    }

 .pickup .name span{
 background:#ddd;
 border-radius:10em;
 background: #17546b;
 color:#fff;
 font-size:18px;
 padding:5px 10px;
}



 .pickup .cap {
    font-size: 16px;
    line-height: 2;
    margin-bottom: 0;
    padding: 0 20px;
    font-weight: 600;
    text-align: center;
    }

 .pickup .phone_num,
 .pickup .fax_num {
    font-size: 40px;
    /* line-height: 2; */
    padding: 10px 20px 0;
    /* border: 1px solid #ddd; */
    /* border-radius: 500px; */
    margin-bottom: 20px;
    /* display: block; */
}

 .pickup .phone_num:before {
    font-family: 'FontAwesome';
    content: "\f095";
    padding-right: 5px;
    color: #6b0948;
    font-size: 0.8em;
}

 .pickup .fax_num:before {
    font-family: 'FontAwesome';
    content: "\f1ac";
    padding-right: 5px;
    color: #666666;
    font-size: 0.7em;
line-height: 1;}


@media screen and (max-width: 500px) {
 .pickup .phone_num,
 .pickup .fax_num{
   font-size: 28px;
 }

 .pickup .phone_num:before,
 .pickup .fax_num:before{
   font-size: 0.8em;}
 .pickup .cap {
 text-align: left;
 }
}





/* Table */
/* ============================================ */

table {
border-collapse: collapse;
border-spacing: 0;
}

caption {
text-align: left;
}

td,
th {
vertical-align: top;
padding: 0;
}

th {
text-align: left;
font-weight: bold;
}

/* Misc */
/* ============================================ */

/**
* Add the correct display in IE 10+.
*/

template {
display: none;
}

/**
* Add the correct display in IE 10.
*/

[hidden] {
display: none;
}



#detail{
padding-top: 0;
overflow: hidden;
}

#detailHeader{
padding-top: 2em
}

#detailTitle{
color: #555;
}
#detailTitle h2{
display: flex;
font-size: 1.75em;
font-weight: 500;
letter-spacing: 0.1em;
line-height: 1.5em;
}
#detailTitle h2 i{
align-items: flex-start;
margin-right: 0.5em;
transform: translate(0,0.25em);
}

#detailStatus{}
#detailStatus dl{
display: flex;
padding: 1em 0;
line-height: 1.4em;
border-top: 1px solid currentColor;
}
#detailStatus dl:last-child{
border-bottom: 1px solid currentColor;
}
#detailStatus dt,
#detailStatus dd{
font-weight: 500;
line-height: 1.5em;
}
#detailStatus dt{
position: relative;
margin-right: 1em;
padding-right: 1em;
white-space: nowrap;
}
#detailStatus dt:before{
content: "";
position: absolute;
top: 0.25em;
right: 0;
height: 1em;
border-left: 1px solid currentColor;
}
#detailStatus ul{
display: flex;
margin-bottom: 1.5em;
}
#detailStatus li{
position: relative;
width: 25%;
border-radius: 8px;
}
#detailStatus li:before{
content: "";
position: absolute;
top: calc(50% - 0.5em);
left: 0;
height: 1em;
border-left: 1px solid currentColor;
}
#detailStatus li:last-child:before{
	width: 100%;
	border-right: 1px solid currentColor;
	}
#detailStatus li a{
display: block;
padding: 0.6em;
color: inherit;
font-weight: 500;
text-decoration: none;
text-align: center;
font-size: 1.1em;
}
#detailStatus li.select{
background: currentColor;
margin-right: -1px;
}
#detailStatus li.select a{
	color: #fff;
	}

#detailAreaMap{
position: relative;
border-bottom: 1px solid currentColor;
order: 1;
}

#detailLead{}
#detailLead .fr-view{
font-weight: 500;
letter-spacing: 0.05em;
line-height: 1.7em;
}

#detailTable{
background: linear-gradient(90deg,#ffe7d9,#dceced);
}
#detailTable h3{
color: #555;
font-weight: 500;
font-size: 1.5em;
letter-spacing: 0.1em;
text-align: center;
}
#detailTable h3+div{
margin-top: 2em;
}
#detailTable dl{
position: relative;
display: flex;
flex-direction: column;
width: calc(100vw - 10em);
max-width: 316px;
background: #fff;
padding: 1em;
border-radius: 8px;
box-shadow: 0 10px 10px rgba(0,0,0,0.2);
}
#detailTable dt{
padding: 0.3em 0.8em;
color: #555;
font-weight: 500;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
order: 1;
}
#detailTable dd{}
#detailTable dd a{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
opacity: 0;
}
#detailTable .wrap{
width: 100%;
}
#detailTable .slick-slider{
display: flex;
flex-wrap: wrap;
align-items: center;
justify-content: center;
overflow: hidden;
}
#detailTable .slick-list{
margin-bottom: 2em;
order: -1;
}
#detailTable .slick-next{
order: 1;
}
#detailTable .slick-dots{
width: calc(100% - 12em);
margin: 0 1em;
}
#detailTable .thumb{
border-radius: 4px;
}

#detailCourse{
counter-reset: count;
}
#detailCourse section{margin: 2em 0;padding: 1em;border: 1px solid #17546b;padding-top: 1em!important;}
#detailCourse .wrap{
position: relative;
display: flex;
flex-direction: column;
align-items: stretch;
z-index: 1;
}
#detailCourse .wrap:before{content: "";position: absolute;top: 5em;left: 0;width: 0;height: calc(100% - 10em);border-left: 2px solid #555;z-index: -1;}

#detailCourseStart,
#detailCourseGoal{position: relative;padding-left: 10px;left: -10px;background: #fff;color: #016d97;font-size: 2.1em;font-size: 25px;/* font-family: sofia-pro, sans-serif; */font-weight: 900;/* font-style: italic; */text-transform: capitalize;line-height: 2em;}

#detailCourseStart:before,
#detailCourseGoal:before{
/* content: ""; */
/* position: absolute; */
/* left: 0; */
/* width: 1em; */
/* height: 1em; */
/* border-top: 1px solid currentColor; */
}

@media only screen and (max-width: 500px) {
	#detailCourseStart,
	#detailCourseGoal{
		left: -10px;
		font-size: 1.6em;
	}
}







#detailCourseStart:before{
top: 1.5em;
transform: skewY(-45deg);
}

#detailCourseGoal{}
#detailCourseGoal:before{
bottom: 0.5em;
transform: skewY(45deg);
}

#detailFooter{
padding-top: 0;
}

#detailMap{
display: flex;
flex-direction: column;
}
#detailMap p{
margin-top: 1em;
padding-left: 1em;
text-indent: -1em;
color: #666666;
font-size: 0.875em;
line-height: 1.7em;
}
#detailMap menu{
position: relative;
align-self: center;
width: 100%;
max-width: 380px;
margin: 0;
padding: 1em 1.5em;
border: 1px solid currentColor;
border-radius: 4px;
color: #555;
fill: currentColor;
font-weight: 500;
letter-spacing: 0.1em;
text-align: center;
cursor: pointer;
order: 1;
}
#detailMap menu i{
position: absolute;
top: calc(50% - 0.5em);
right: 1.5em;
}
#detailMap menu path{
transition: opacity 0.2s ease-out;
}
#detailMap menu.open{}
#detailMap menu.open path+path{
	opacity: 0;
	}
#detailMap menu+div{
margin-bottom: 2em;
}

#detailMapBody{
position: relative;
background: #ccc;
}
#detailMapBody > div{
width: 100%;
height: 100%;
}
#detailMapBody iframe{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
#detailMapBody > .infoWin{
position: relative;
margin: 1em;
z-index: 1;
}
#detailMapBody > img{
position: relative;
margin: 1em 0;
width: 34px;
height: 50px;
z-index: 1;
}

#detailMapList{
overflow-y: auto;
}
#detailMapList ul{
counter-reset: count;
list-style: none;
}
#detailMapList li{
position: relative;
padding: 1em;
padding-left: 4em;
font-weight: 500;
letter-spacing: 0.05em;
line-height: 1.5em;
cursor: pointer;
}
#detailMapList li:before{
counter-increment: count;
content: counter(count);
position: absolute;
top: 0.6em;
left: 1em;
width: 2.4em;
height: 2.4em;
margin-right: 0.5em;
background: #555;
border-radius: 100%;
color: #fff;
font-weight: bold;
text-align: center;
line-height: 2.4em;
transform: scale(0.8);
}
#detailMapList li+li{
border-top: 1px solid #e1e1e1;
}
#detailMapList a{
color: inherit;
text-decoration: none;
}
#detailMapList a:hover{
text-decoration: none;
}

#share{
display: flex;
flex-direction: column;
align-items: center;
color: #555;
}
#share:before{
content: "Share";
position: relative;
margin-bottom: -0.4em;
padding: 0 0.6em;
background: #fff;
font-size: 1.7em;
font-family: sofia-pro, sans-serif;
font-weight: 900;
font-style: italic;
line-height: 1em;
text-align: center;
z-index: 1;
}
#share ul{
position: relative;
display: flex;
justify-content: center;
border: 1px solid currentColor;
border-radius: 4px;
padding: 2em 3em;
padding-top: 3em;
}
#share li{}
#share li a{
display: block;
}
#share li svg{
font-size: 40px;
}
#share li+li{
margin-left: 2em;
}

#recommend{
border-top: 1px solid #555;
overflow: hidden;
}
#recommend h2{
display: flex;
align-items: center;
color: #555;
fill: currentColor;
font-weight: 500;
line-height: 1.5em;
}
#recommend h2 i{
position: relative;
top: 0.1em;
display: flex;
align-items: center;
margin-right: 1em;
}
#recommend h2+div{
margin-top: 2em;
}
#recommend dl{
position: relative;
display: flex;
flex-direction: column;
}
#recommend dt{
font-weight: 500;
letter-spacing: 0.025em;
}
#recommend dt+dd{
order: -1;
}
#recommend dd{}
#recommend dd a{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
opacity: 0;
}
#recommend .thumb{
border-radius: 4px;
}
#recommend .slick-list{
margin: 0 -0.75em;
}
#recommend .slick-slide{
padding: 0 0.75em;
}
#recommend .slick-arrow{
position: absolute;
margin: -1.5em;
z-index: 1;
}
#recommend .slick-prev{
left: 0;
}
#recommend .slick-next{
right: 0;
}

.spot{
position: relative;
}
.spot.quote{}
.spot.quote{}
.spot.quote .spotText .fr-view{
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 5;
	height: calc(1.7em * 5em);
	overflow: hidden;
	}

.spotName{position: relative;color: #000;font-weight: 500;font-size: 1.65em;line-height: 1.5em;letter-spacing: 0.1em;/* background: #000; */padding-left: 10px;/* border-bottom: 1px solid #000; */}
.spotName:before{counter-increment: count;content: counter(count);position: absolute;top: 0.75em;left: -4em;display: flex;align-items: center;justify-content: center;width: 2em;height: 2em;margin: -1em;padding-bottom: 0.15em;background: #000;/* border: 3px solid #fff; */border-radius: 100%;color: #fff;letter-spacing: 0;padding-top: 5px;/* line-height: 2em; */text-align: center;box-sizing: border-box;font-family: "Century Gothic", sans-serif;}
.spotLead{margin-top: 0.3em;font-weight: 500;font-size: 1.1em;line-height: 1.5em;letter-spacing: 0.05em;padding-left: 10px;border-bottom: 1px solid #555;}
.spotLeadA{margin-top: 1em;font-weight: 500;font-size: 1.3em;line-height: 1.5em;letter-spacing: 0.05em;padding-left: 10px;/* margin-bottom: 1em; */color: #00189d;}
.spotPhoto{
margin-top: 1.5em;
}
.spotPhoto li[data-caption]{
position: relative;
}
.spotPhoto li[data-caption]:before{
content: attr(data-caption);
position: absolute;
left: 0;
bottom: 0;
display: block;
width: 100%;
padding: 1em;
background: linear-gradient(rgba(0,26,23,0), rgba(0,26,23,0.7));
color: #fff;
font-size: 0.75em;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
z-index: 1;
}
.spotPhoto .thumb{
border-radius: 4px;
}

.spotText{
margin-top: 1.5em;
}
.spotText .fr-view{
line-height: 1.7em;
font-size: 1.1rem;
}

.spotText .fr-view h2{
font-size:1.7em;
}

.kan_set{display:flex;flex-wrap: wrap;margin-top: 50px;}

.col_1{width:100%}
.col_7{width:70%}
.col_6{width:60%}
.col_5{width:50%}
.col_3{width:30%}
.col_4{width:40%}

.col_1 img,
.col_2 img,
.col_3 img,
.col_4 img,
.col_5 img{width:100%}


.col_1 p,
.col_2 p,
.col_3 p,
.col_4 p,
.col_5 p{font-size:17px}


.text_set{width:70%}
.text_set p{font-size: 17px;line-height:2}
.img_set{width:30%;}

.waku_gray{
  background:#eee;
  padding:5px;
  position: relative;
  display: inline-block;
  margin: 1.5em 0;
  padding: 10px;
  font-size: 16px;
}
.waku_gray span{
  font-size:18px;
  border-bottom:1px solid #555
}



.waku_top{
  /* border:1px solid #ddd; */
  background:#eee;
  padding:5px;
  position: relative;
  display: inline-block;
  margin: 1.5em 0;
  padding: 10px;
  /* min-width: 120px;
  max-width: 100%; */
  /* color: #555; */
  font-size: 16px;
}

/* .waku_top:before {
  content: "";
  position: absolute;
  top: -30px;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-bottom: 15px solid #eee;
  } */

  .waku_top p {
    margin: 0;
    padding: 0;
  }


.img_set {
    width: 30%;
}




.spotInfo{display: flex;margin-top: 1.5em;max-width: 100%;margin: 0 auto;}
.spotInfo a,
.spotInfo menu{position: relative;display: flex;align-items: center;justify-content: center;width: 100%;padding: 1em 1em;padding-right: 1em;border: 1px solid currentColor;border-radius: 4px;background: #fff;color: #555;font-size: 0.875em;font-weight: 500;text-align: center;text-decoration: none;letter-spacing: 0.01em;line-height: 1.5em;/* border: none; */}

.spotInfo menu:after{
 font-family: 'Font Awesome 6 pro';
 content: "\f055";
 font-weight: 300;
 padding-left: 10px;
}


.spotInfo a i,
.spotInfo menu i{
position: absolute;
top: calc(50% - 0.5em);
right: 1em;
}




.spotInfo menu{
cursor: pointer;
}
.spotInfo menu.open{
background: #555;
border-color: transparent;
color: #fff;
}
.spotInfo menu.open path+path{
	opacity: 0;
	}

.spotData{}
.spotData dl{
display: flex;
border-bottom: 1px dashed #555;
font-weight: 500;
}
.spotData dt,
.spotData dd{
padding: 0.8em;
border-top: 1px dashed #555;
line-height: 1.4em;
}
.spotData dt{
color: #555;
}
.spotData dd{
color: #4d4d4d;
text-align: left;
}

a.phone_link{
border:	none;
background:	none;
justify-content: left;
}


.date{position: relative;align-self: center;margin: 1em 0;padding: 0 1em;background: #fff;color: #000;font-weight: 500;font-size: 1.8em;letter-spacing: 0.1em;}
.date:before{content: "";position: absolute;top: 50%;left: calc(50% - 50vw);width: 99vw;border-top: 1px dashed currentColor;z-index: -1;}

.move{position: relative;display: flex;align-items: center;margin: 2em 0;line-height: 1.5em;letter-spacing: 0.1em;font-size: 20px;}
.move:before,
.move:after{content: "";color: #000;}
.move:before{
margin-right: 0.5em;
border-top: 2px solid currentColor;
}
.move:after{position: absolute;top: calc(50% - 12px);left: -13px;width: 20px;height: 20px;background: currentColor;border-radius: 100%;border: 3px solid #000;box-sizing: content-box;}

.column{
display: flex;
flex-direction: column;
overflow: hidden;
}
.column h4{
position: relative;
align-self: center;
padding: 0 1em;
background: #fff;
color: #555;
font-size: 1.75em;
font-family: sofia-pro, sans-serif;
font-weight: 900;
font-style: italic;
text-transform: capitalize;
line-height: 1em;
}
.column h4:before{
content: "";
position: absolute;
top: 0.5em;
left: calc(50% - 50vw);
width: 100vw;
border-top: 1px solid currentColor;
z-index: -1;
}
.column h4+div{
display: flex;
margin-top: 2em;
}
.column h5{
color: #555;
font-weight: 500;
font-size: 1.25em;
line-height: 1.5em;
letter-spacing: 0.1em;
}
.column h5+div{
margin-top: 1.5em;
color: #4d4d4d;
}
.column h5+div+div{
display: flex;
justify-content: center;
margin-top: 1.5em;
}
.column h5+div+div a{
position: relative;
display: block;
width: 100%;
max-width: 300px;
padding: 1em;
border: 1px solid currentColor;
border-radius: 4px;
background: #fff;
color: #555;
font-size: 0.875em;
font-weight: 500;
text-align: center;
text-decoration: none;
letter-spacing: 0.01em;
}
.column h5+div+div i{
position: absolute;
top: calc(50% - 0.5em);
right: 1em;
}
.column figure{
order: -1;
}
.column .fr-view{
color: #4d4d4d;
font-size: 0.875em;
line-height: 1.7em;
}
.column .thumb{
border-radius: 4px;
}




/* for all */
@media (max-width: 1199.98px) {
/*1199px以下*/
}
@media (max-width: 991.98px) {
/*991px以下*/
}


/* for mobile */
@media (max-width: 767.98px) {
/*767px以下*/
#detailAreaMap{
padding-bottom: 1em;
}
#detailLead{
margin-top: 2em;
}
#detailLead .fr-view+div{
width: 100%;
max-width: 20em;
margin: auto;
margin-top: 2em;
}
#detailTable{}
#detailTable dl{
padding: 0.75em;
}
#detailTable dt{
margin-top: 0.75em;
}
#detailTable .slick-slide{
padding: 0 0.75em;
}
#detailTable .slick-prev{
margin-left: 1.5em;
}
#detailTable .slick-next{
margin-right: 1.5em;
}
#detailCourse{
padding: 2em 0;
}
#detailCourse section{margin-left: 2em;background: #fff;}
#detailCourse .wrap{
width: calc(100% - 4em);
margin-left: 2.5em;
}
#mapList{
height: 10em;
}
#share{
margin-top: 2em;
}
#recommend{}
#recommend h2{
font-size: 1.4em;
}

.text_set p {
    font-size: 1.1em;
    line-height: 1.6;
}


.spotName{
    /* color: #17546b; */
    background: none;
    font-size: 1.3em;
}

.spotLeadA{font-size: 1.1em;}
.spotLead{
font-size: 1em;padding-bottom:10px;
}

.col_1 p, .col_2 p, .col_3 p, .col_4 p, .col_5 p {
    font-size: 1.1em;
}

.spotName:before{left: -2.3em;}
.move{}
.move:before{
flex: 0 0 1.5em;
width: 1.5em;
}
.topics,
.column{
margin-top: 2em;
}
.topics{}
.topics .slick-arrow{
top: 7.6em;
}
.spotList{}
.spotList dt{
font-size: 0.875em;
}
}
@media (max-width: 767.98px) and (orientation:portrait) {
/*767px以下縦向き*/

.img_set {
    width: 100%;
}
.text_set {
    width: 100%;
}


#detailTitle{}
#detailTitle h2{
order: -1;
}
#detailTitle figure{
margin: 0 -1em;
margin-top: 1em;
order: -1;
}
#detailTitle .wrap{
display: flex;
flex-direction: column;
}
#detailStatus{
margin: 1.5em 0;
}
#detailTable{}
detailTable .slick-dots{}
#detailTable .slick-dots li{
margin: 0.8em;
}
#detailMapBody{
height: 100vw;
}
#recommend{}
#recommend .slick-arrow{
top: 4em;
}
.spotPhoto{margin: 0.5em;}
.spotPhoto ul{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.spotPhoto li{}
.spotPhoto li:first-child{
width: 100%;
}
/* .spotPhoto li:nth-of-type(n+2){
width: calc(50% - 0.5em);
margin-top: 1em;
} */
.spotPhoto li:nth-of-type(n+2){
width: 100%;
margin-top: 1em;
}
.spotInfo{
flex-direction: column;
}
.spotData{
margin: 1em 0;
}
.spotData dl{
flex-direction: column;
}
.spotData dd{
padding-top: 0;
border: none;
}
.spotLink{
margin-top: 1em;
}
.column{}
.column h4+div{
flex-direction: column;
}
.column figure{
margin-bottom: 1em;
}
}


.spotLink a:after{
 font-family:'themify';
 content: "\e732";
 font-weight: 300;
 padding-left: 10px;
}





@media (max-width: 767.98px) and (orientation:landscape) {
/*767px以下横向き*/
#detailStatus,
#detailAreaMap{
padding: 1.5em;
}
#detailMapBody{
height: 80vw;
}
#recommend{}
#recommend .slick-arrow{
top: 7.6em;
}
.topics{}
.topics .slick-list{
margin: 0;
padding: 0 29vw;
}
.topics .slick-arrow{
top: 5em;
}
}
@media (min-width: 576px) and (max-width: 767.98px) and (orientation:landscape), (min-width: 768px) {
/*576px～767px横向き, 768px以上*/
#detailTitle{}
#detailTitle h2{
position: absolute;
left: 0;
bottom: 0;
width: 60%;
padding: 1em;
background: linear-gradient(rgba(0,26,23,0), rgba(0,26,23,0.7));
color: #fff;
z-index: 2;
}
#detailTitle figure{
position: absolute;
top: 0;
left: 0;
width: 60%;
height: 100%;
}
#detailTitle .wrap{
position: relative;
display: flex;
flex-direction: column;
width: 100%;
padding-left: 60%;
}
#detailTitle .thumb{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
padding: 0;
}
#detailStatus{
border-top: 1px solid currentColor;
}
#detailStatus+#detailAreaMap{
padding-top: 0;
}
#detailTable{}
detailTable .slick-dots{}
#detailTable .slick-dots li{
margin: 1em;
}
.spotPhoto{}
.spotPhoto ul{
overflow: hidden;
}
.spotPhoto li{
float: left;
width: calc(33.3% - 0.8em);
}
.spotPhoto li:first-child{
width: 66.6%;
}
.spotPhoto li:first-child:last-child{
width: 100%;
}
.spotPhoto li:first-child:last-child .thumb{
	padding-top: 44.4%;
	}
.spotPhoto li:first-child:nth-last-of-type(2),
.spotPhoto li:last-child:nth-of-type(2){
width: calc(50% - 0.5em);
}
.spotPhoto li:first-child:nth-last-of-type(2) .thumb,
/* .spotPhoto li:last-child:nth-of-type(2) .thumb{
	padding-top: 88.8%;
	} */
.spotPhoto li:nth-of-type(n+2){
float: right;
}
.spotPhoto li:nth-of-type(3){
margin-top: 1em;
}
.spotInfo{
flex-wrap: wrap;
justify-content: center;
}
.spotInfo menu{
width: calc(50% - 0.75em);
max-width: 250px;
margin: 0 10px;
}
.spotData{
display: flex;
justify-content: center;
width: 100%;
margin-top: 1.5em;
order: 1;
}
.spotData dl{
flex-wrap: wrap;
width: 100%;
max-width: calc(600px + 1.5em);
max-width: 800px;
}
.spotData dt{
width: 8em;
}
.spotData dd{
width: calc(100% - 8em);
}
.spotLink{/* width: calc(33.333%); *//* max-width: 300px; */}
.spotLink a:hover{
   background-color: #555;
    color: #fff;
    transition: .4s;
}
menu:hover{
   background-color: #555;
   color: #fff;
   transition: .4s;
}
.spotLink:not(:first-child){
margin-left: 1.4em;
}
.column{}
.column h4+div{
justify-content: space-between;
}

a.phone_link{
border:	none;
background:	none;
justify-content: left;
}
a.map_link{
border:	none;
background:	none;
justify-content: left;
padding: 0;
}


}
@media (min-width: 576px) and (max-width: 767.98px) and (orientation:landscape), (min-width: 768px) and (max-width: 991.98px) {
/*576px～767px横向き, 768px～991px*/
#detailTable{}
#detailTable .slick-list{
padding: 0 20vw !important;
}
#detailCourse{
padding: 3em 0;
}
#detailCourse section{
flex-direction: column;
align-items: stretch;
}
.column{}
.column h4+div > div,
.column figure{
width: calc(50% - 0.75em);
}
}

/*
#detailCourse section {
    margin-left: 4em;
    border: 1px solid #9e9e9e;
    background: #ffffff;
    border-radius: 0;
}
 */


/* for tablet */
@media (min-width: 768px) {
/*768px以上*/
#detailStatus{}
#detailStatus dt,
#detailStatus dd{
font-size: 0.875em;
}
#detailLead{}
#detailLead [data-fav-id]{
display: flex;
font-size: 0.875em;
}
#detailLead .fr-view{
width: 100%;
}
#detailLead .fr-view+div{
flex: 0 0 calc(0.875em * 20);
width: calc(0.875em * 20);
}
#detailLead .wrap{
display: flex;
justify-content: space-between;
}
#detailTable{}
#detailTable dl{
padding: 1em;
}
#detailTable dt{
margin-top: 1em;
}
#detailTable .slick-slide{
padding: 0 1em;
}
#detailTable .slick-prev{
margin-left: 2em;
}
#detailTable .slick-next{
margin-right: 2em;
}
#detailCourse{}
#detailCourse section{margin-left: 4em;border: 1px solid #9e9e9e;background: #ffffff;border-radius: 0;}
#detailMap{}
#detailMap menu+div{
display: flex;
flex-wrap: wrap;
}
#detailMapList{
position: relative;
}
#detailMapList ul{
position: absolute;
top: 0;
right: 0;
width: 100%;
height: 100%;
}
#recommend{}
#recommend h2{
font-size: 1.5em;
}
.spotName{}
.spotName:after{content: "";position: absolute;top: 0.75em;left: -4em;width: 3.5em;border-top: 2px solid currentColor;z-index: -1;color: #555;}
.move{}
.move:before{
flex: 0 0 3.5em;
width: 3.5em;
}
.topics{
overflow: hidden;
}
.topics h4{
position: relative;
}
.topics h4:before{
content: "";
position: absolute;
left: -2.5em;
top: 0.75em;
width: 2em;
border-top: 1px solid currentColor;
}
.topics dt+dd+dd{
font-size: 0.75em;
}
.topics .fr-view{
font-size: 0.875em;
}
}
@media (min-width: 768px) and (max-width: 1199.98px) {
/*768px～1199px*/
}
@media (min-width: 768px) and (max-width: 991.98px) {
/*768px～991px*/
#detailStatus,
#detailAreaMap{
padding: 1.5em 2em;
}
#detailLead{
margin-top: 3em;
}
#detailLead .fr-view{
margin-right: 3em;
}
#detailCourse{
padding: 3em 0;
}
#detailMapBody{
width: calc(100% - 20em);
height: 32em;
}
#detailMapList{
width: 20em;
}
#share{
margin-top: 3em;
}
#recommend{}
#recommend .slick-arrow{
top: 5.4em;
}
.spot,
.topics,
.column{
padding: 2em;
}
.spotName{}
.spotName:before{left: -4.3em;}
.topics{}
.topics .slick-arrow{
top: 7.2em;
}
}
.iconset{position: absolute;right: 50px;top: 10px;width: 90px;}

@media (max-width: 767.98px) {
.iconset{position: absolute;right: -20px;top: -15px;width: 100px;}
}
/* for PC */
@media (min-width: 992px) {
/*992px以上*/
#detailStatus,
#detailAreaMap{
padding: 2em 3em;
}
#detailLead{
margin-top: 4em;
}
#detailLead .fr-view{
margin-right: 4em;
}
#detailTable{}
#detailTable .slick-list{}
#detailTable .slick-list{
padding: 0 30vw !important;
}
#detailCourse{padding: 0em 0;}
#share{
margin-top: 4em;
}
#detailMapBody{
width: calc(100% - 15em);
}
#detailMapList{
width: 15em;
}
.spot,
.topics,
.column{
padding: 3em;
}

.spot Img{
padding: 3em;
}


.spot Img img{
  width:100%;
}





.spotName{}
.spotName:before{left: -4.85em;}




.column{}
.column h4+div > div{
width: 60%;
}
.column figure{
width: calc(40% - 2em);
}
}
@media (min-width: 992px) and (max-width: 1199.98px) {
/*992px～1199px*/
#detailMapBody{
height: 34em;
}
#recommend{}
#recommend .slick-arrow{
top: 7.4em;
}
.topics{}
.topics .slick-arrow{
top: 6.2em;
}
}
@media (min-width: 1200px) {
/*1200px以上*/
#detailMapBody{
height: 38em;
}
#recommend{}
#recommend .slick-arrow{
top: 7.6em;
}
#recommend .slick-prev{
left: -2.5em;
}
#recommend .slick-next{
right: -2.5em;
}
.topics{}
.topics .slick-arrow{
top: 6.6em;
}


.iconset{position: absolute;right: 50px;top: 10px;width: 200px;}


}

/* -----------------------------------------------------------
#sub_works_area
----------------------------------------------------------- */

#sub_works_area {
  padding: 90px 0%;
  /* background: url(../images/common/noise.png) repeat #f5f5f5; */
  /* background: #f7f4f4; */
  /* width: 95%; */
  margin: 0 auto;
}

#sub_works_area .central {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

@media only screen and (max-width: 900px) {
  #sub_works_area {
      padding: 0;
  }
}

@media only screen and (max-width: 736px) {
  #sub_works_area {
      padding: 0;
  }
}
/* -----------------------------------------------------------
#sub_works
----------------------------------------------------------- */

#sub_works {
  /* float: right; */
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

#sub_works .quality h3{font-size: 28px;font-weight: 700;text-align:center;margin-bottom:20px;color: #221815;}



@media only screen and (max-width: 900px) {
  #sub_works {
      width: 100%;
      padding: 0;
  }
}

@media only screen and (max-width: 736px) {
  #sub_works {
      padding: 70px 0px;
  }


}
/* --------- .worksArea --------- */

.worksArea {
  z-index: 3;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  /* padding: 2%; */
}

.worksArea .worksBox {
  flex: 0 0 31%;
  align-items: stretch;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 0.2em;
  margin-bottom: 1em;
}

.worksBox.target.text3 {}



/* .inner */

.worksArea .worksBox .inner {
  position: relative;
  padding: 20px 7.5% 20px;
  z-index: 2;
  /* border: 1px solid #ddd; */
  border-radius: 0.2em;
  text-align: center;
}

.worksArea .worksBox .inner:before {
  position: absolute;
  right: 0;
  top: 0;
  left: 0;
  bottom: 0;
  content: "";
  border: #fefefe 0 solid;
  -webkit-transition: all 0.2s ease;
  -moz-transition: all 0.2s ease;
  -o-transition: all 0.2s ease;
  transition: all 0.2s ease;
  z-index: -1;
}

.worksBox:hover .inner:before {
  border: #221815 5px solid;
  border-radius: 0.2em;
  background:#221815;
  color:#fff;
}


.worksArea .worksBox .inner .imgArea {
padding:10px;
color: #221815;
}


.worksArea .worksBox .inner img {
  width: 100%;
  margin: 0;
}

.worksArea .worksBox .inner h2 {
  text-align: center;
  color: #221815;
  margin: 10px 0 0;
  font-weight: 600;
  font-size: 18px;
  display: block;
}

.worksArea .worksBox .inner h2:after {
  content: '';
  display: block;
  width: 147px;
  height: 1px;
  background-color: #221815;
  position: relative;
  bottom: 0px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  color:#fff;
}

.worksArea .worksBox .inner:hover {
  color:#fff;
}

.worksArea .worksBox .inner:hover h2,
.worksArea .worksBox .inner:hover h3 {
  color:#fff;
}


/* ul.category */

.worksArea .worksBox ul.category {
  margin-top: 20px;
  list-style: none;
  z-index: 2;
  text-align: center;
}

.worksArea .worksBox ul.category li {
  display: inline-block;
  color: #fefefe;
  background: #221815;
  font-size: 13px;
  font-weight: 500;
  line-height: 35px;
  letter-spacing: 1px;
  border-radius: 1.5em;
  padding: 0 35px 0 25px;
  position: relative;
  z-index: 1;
}

.worksArea .worksBox ul.category li:after {
  position: absolute;
  top: 0;
  right: 10px;
  bottom: 0;
  font-size: 1.1em;
  /* line-height: 25px; */
  font-family: themify;
  /* content: "\e6ad"; */
  font-weight: normal;
  /* font-family: 'Font Awesome 6 pro'; */
  content: "\e649";
  vertical-align: 0;
}

.worksArea .worksBox p.date {
  position: absolute;
  top: 20px;
  left: 7.5%;
  font-family: 'Poppins', sans-serif;
  font-weight: 500;
  line-height: 40px;
  font-size: 0;
  display: none;
}

.worksArea .worksBox .inner h3 {
  font-size: 15px;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 1px;
  padding: 0;
  margin-top: 0;
}

.worksArea .worksBox .icon_award {
  position: absolute;
  top: 15px;
  right: 7.5%;
  width: 55px;
  height: 55px;
  content: "";
  background: url(../images/common/icon_award.png) center center no-repeat;
  background-size: cover;
  z-index: 2;
}

@media only screen and (max-width: 900px) {
  .worksArea .worksBox .inner {
      padding: 50px 7.5% 50px;
  }
  .worksArea .worksBox .inner:before {
      display: none;
  }
  /* ul.category */
  .worksArea .worksBox ul.category {
      margin-top: -35px;
      list-style: none;
      z-index: 2;
  }
  .worksArea .worksBox ul.category li {
      padding: 0 15px 0 30px;
  }
  /* p.date */
  .worksArea .worksBox p.date {
      top: 10px;
      left: 7.5%;
  }
  /*.worksArea .worksBox p.date span { font-size: 13px; }*/
  /* h3 */
  .worksArea .worksBox .inner h3 {
      font-size: 14px;
  }
  /* .icon_award */
  .worksArea .worksBox .icon_award {
      top: 10px;
      right: 7.5%;
      width: 50px;
      height: 50px;
  }
}

@media only screen and (max-width: 736px) {
  .worksArea .worksBox .inner {
      padding: 40px 7.5% 30px;
  }
  .worksArea .worksBox .inner:before {
      display: none;
  }
  /* ul.category */
  .worksArea .worksBox ul.category {
      margin-top: 0px;
      list-style: none;
      z-index: 2;
      display: block;
  }
  .worksArea .worksBox ul.category li {
      font-size: 11px;
      line-height: 25px;
      letter-spacing: 1px;
      padding: 0 10px 0 20px;
  }
  .worksArea .worksBox ul.category li:before {
      left: 5px;
      font-size: 1em;
  }
  /* p.date */
  .worksArea .worksBox p.date {
      top: 10px;
      left: 7.5%;
      line-height: 30px;
  }
  /*.worksArea .worksBox p.date span { font-size: 11px; }*/
  /* h3 */
  .worksArea .worksBox .inner h3 {
      font-size: 11px;
      line-height: 1.8;
      margin-top: 5px;
  }

   .worksArea .worksBox {
      flex: 0 0 49%;
      margin-bottom:10px;
   }
}

@media only screen and (max-width: 500px) {
  .worksArea .worksBox {
      flex: 0 0 100%;
      margin-bottom: 20px;
  }
}







@media only screen and (max-width: 414px) {
  .worksArea .worksBox p.date {
      letter-spacing: 0.5px;
  }
  .worksArea .worksBox .inner h3 {
      line-height: 1.8;
      display: block;
  }
  .worksArea .worksBox ul.category li {
      font-size: 9px;
      padding: 0 20px 0 20px;
  }
  .worksArea .worksBox .icon_award {
      top: 6px;
      right: 4%;
      width: 30px;
      height: 30px;
  }
}



.center{
text-align: center;
}

.left{
text-align: left;
}

.right{
text-align: right;
}

.none{
display: none !important;
}

.thumb{}
.thumb img{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
object-fit: inherit;
object-position: inherit;
opacity: 1;
transition: opacity 0.2s ease-out;
}
.thumb:not(img){
position: relative;
display: block;
width: 100%;
margin: 0;
padding: 66.66% 0 0 0;
object-fit: cover;
object-position: center;
background: rgba(0,0,0,0.05) url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" viewBox="0 0 50 50"><path fill="rgba(0,0,0,0.2)" d="M25.251,6.461c-10.318,0-18.683,8.365-18.683,18.683h4.068c0-8.071,6.543-14.615,14.615-14.615V6.461z" transform="rotate(200.584 25 25)"><animateTransform attributeType="xml" attributeName="transform" type="rotate" from="0 25 25" to="360 25 25" dur="0.6s" repeatCount="indefinite"></animateTransform></path></svg>') center center no-repeat;
background-size: 3em;
overflow: hidden;
background: opacity 0.2s ease-out;
}
img.thumb{
opacity: 0;
}
.thumb.contain{
object-fit: contain;
}
.thumb.cover{
object-fit: cover;
}
.thumb.top{
object-position: center top;
}
.thumb.bottom{
object-position: center bottom;
}
.thumb.left{
object-position: left center;
}
.thumb.right{
object-position: right center;
}



@media (min-width: 768px) and (max-width: 991.98px) {
/*768px～991px*/
.lsb-sp:not(.lsb-tb),
.lsb-pc:not(.lsb-tb){
display: none;
}
}





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

.slide{
height: 0;
opacity: 0;
transition: opacity 0.5s ease-out;
}
.slide .slick-arrow{
position: relative;
display: inline-block;
width: 3em;
height: 3em;
background: #fff;
border: 1px solid currentColor;
border-radius: 100%;
color: #555;
fill: currentColor;
cursor: pointer;
}
.slide .slick-arrow svg{
position: absolute;
top: 30%;
left: 30%;
width: 40%;
height: 40%;
}
.slide .slick-dots{
display: flex;
flex-wrap: wrap;
justify-content: center;
}
.slide .slick-dots li{
position: relative;
flex: 0 0 10px;
width: 10px;
height: 10px;
border-radius: 100%;
background: #fff;
overflow: hidden;
}
.slide .slick-dots button{
opacity: 0;
}
.slide .slick-dots .slick-active{
background: #555;
}
.slide.slick-initialized{
height: auto;
opacity: 1;
}


.photoArea{display:flex}

.photoBox{width:33.333%}

















/* for all */
@media (max-width: 1199.98px) {

}
@media (max-width: 991.98px) {
}


/* for mobile */
@media (max-width: 767.98px) {


.wrap{
width: calc(100% - 2em);
}


}
@media (max-width: 767.98px) and (orientation:portrait) {


}


@media (min-width: 768px) and (max-width: 1199.98px) {
/*768pxï½ž1199px*/
body{
font-size: 1.4rem;
}
}
@media (min-width: 768px) and (max-width: 991.98px) {
/*768pxï½ž991px*/
main > *,
article,
article section,
article nav,
article header,
article footer{
padding-top: 3em;
padding-bottom: 3em;
}

.wrap{
width: 724px;
}

}


/* for PC */
@media (min-width: 992px) {}

@media (min-width: 992px) and (max-width: 1199.98px) {

.wrap{width: 940px;}
}
@media (min-width: 1200px) {
/*1200pxä»¥ä¸Š*/

.wrap{width: 1140px;margin-top: 10px;}
}

.map {
width: 90%;
margin: 0 auto;
}




@media (min-width: 751px) {
a[href^="tel:"] {
pointer-events: none;
cursor: default;
}

}

a.phone_link{
border:	none;
background:	none;
justify-content: left;
padding: 0;
}

/* ------------------------------------------
フェードインアニメーション
--------------------------------------------*/
.fadeIn {
   -webkit-transition: 1s;
   transition: 1s;
   opacity: 0;
   -webkit-transform: translatey(50px);
           transform: translatey(50px);
 }
 .fadeIn.animated {
   opacity: 1;
   -webkit-transform: translatey(0px);
           transform: translatey(0px);
 }

/* bl_serviceAbout */

.bl_serviceAbout {
   padding: 20px 10px;
   background-color: #F4F4F4;
   border-radius: 5px;
   text-align: center;
 }



 .bl_serviceAbout_body {
   display: flex;
   align-items: center;
   justify-content: center;
   flex-direction: column;
   color: #18546d;
 }

 .bl_serviceAbout_body span {
   width: 200px;
   margin-bottom: 20px;
 }

 .bl_serviceAbout_body span img {
   width: 60%;
   margin: 0 auto;
 }

 .bl_serviceAbout_ttl {
   font-size: 2.3rem;
   font-weight: 500;
 }

 .bl_serviceAbout_ttl span {
   font-size: 3rem;
  display:block;
  font-family: "Century Gothic", sans-serif;
 }


 /* .bl_service */

.ly_pageInner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 50px 50px;
}

.bl_service{}


.bl_serviceUnit {
   display: flex;
   flex-wrap: wrap;
 }

 .bl_serviceUnit.bl_serviceUnit__col3 {
   justify-content: space-between;
 }

 .bl_serviceUnit__col2 > .bl_service {
   width: 50%;
 }

 .bl_serviceUnit__col2 > .bl_service.bl_service__s {
   width: 30%;
 }

 .bl_serviceUnit__col2 > .bl_service.bl_service__l {
   width: 63%;
   margin-left: auto;
 }

 .bl_serviceUnit__col3 > .bl_service {
   width: 31%;
 }

 .bl_serviceUnit__col3 > .bl_serviceAbout {
   width: 24%;
 }





 .boxInfo {width: calc(100%);margin: 0.5%;padding: 1%;box-sizing:border-box;border: 1px solid #ddd;border-radius: 0.2em;margin-top: 60px;}


 .boxInfo .box-title {
     font-size: 16px;
     /* background: #919191; */
     border-bottom: 1px solid #ddd;
     padding: 4px 4px 4px 1.9em;
     text-align: left;
     /* color: #5d5d5d; */
     font-weight: bold;
     line-height: 2;
     letter-spacing: 0.05em;
     position:relative;
 }

 .boxInfo .box-title:before {position:relative;font-family: 'Font Awesome 6 Pro';content: "\f82e";position: absolute;left: 0.3em;color: #18546d;}


 .boxInfo p {
     padding: 15px 20px;
 }


 .boxInfo li:last-of-type {
     border-bottom: none;
 }
 .boxInfo li:before {
     font-family: "Font Awesome 6 Pro";
     content: "\f22d";
     position: relative;
     left: 0;
     color: #18546d;
     padding-right: 10px;
 }


  @media only screen and (min-width: 1000px) {
  .boxInfo {
      /* width: calc(48%); */
      margin: 50px 0;
  }
  }



   .boxInfo {
     width: 100%;
     margin: 3% auto;
     padding: 1%;
     box-sizing:
     border-box;
     border: 1px solid #ddd;
     border-radius: 0.2em;
     background: #fff;
   }


  .boxInfo .box-title {
      font-size: 18px;
      /* background: #919191; */
      border-bottom: 1px solid #ddd;
      padding: 4px 4px 4px 1.9em;
      text-align: left;
      /* color: #5d5d5d; */
      font-weight: bold;
      line-height: 2;
      letter-spacing: 0.05em;
      position:relative;
  }

  .boxInfo .box-title:before {position:relative;font-family: 'Font Awesome 6 Pro';content: "\f02b";position: absolute;left: 0.3em;color: #18546d;}


  .boxInfo p {
      padding: 5px 5px 0;
  }

  .boxInfo ul{display:flex;/* flex-direction: row; */flex-wrap: wrap;/* justify-content: space-between; */}
  .boxInfo li{}

  .boxInfo li,
  .myboxP li {
      line-height: 1.5;
      padding: 0.5em;
      /* border-bottom: dashed 1px silver; */
      list-style-type: none!important;
      font-size: 15px;
      font-weight: 400;
      margin-left: 1.4em;
      /* text-indent: -1.4em; */
      /* width: 100%; */
      text-align: left;
      /* flex: 0 0 32%; */
  }
  .boxInfo li:last-of-type {
      border-bottom: none;
  }
  .boxInfo li:before {
      font-family: "Font Awesome 6 Pro";
      content: "\f22d";
      position: relative;
      left: 0;
      color: #18546d;
      padding-right: 10px;
  }

  .boxInfo li span{
      /* position: relative; */
      /* left: 50%; */
  }

  @media only screen and (max-width: 1200px) {
 .ly_pageInner {
   width: 100%;
   margin: 0 auto;
   padding: 50px 0px;
 }

  @media only screen and (max-width: 600px) {
/*  .ly_pageInner {
   width: 100%;
   margin: 0 auto;
   padding: 50px 10px;
 } */

  .boxInfo li {
        /* flex: 0 0 90%; */
    }
  }

  @charset "utf-8";

  /*========= レイアウトのためのCSS ===============*/

  body{
    background:#ECF2FC;
  }

  h1{
    text-align: center;
    text-transform: uppercase;
    font-size: 2rem;
    margin:30px 0;
  }

  .lead{
    padding: 20px;
    text-align: center;
  }

  .suujibox{
    max-width:500px;
    width:100%;
    margin: 130px auto;
    padding: 20px;
    background:#fff;
    text-align: center;
  }

  .count-size{
    font-size: 5rem;
    font-weight: bold;
    color: #167c3b;
  }


  /* summary */

  #summary {
    position: relative;
    }


  #summary .wrap {
      width: 100%;
      max-width: 1200px;
      margin: 80px auto 0;
    }




    #summary .fv .inner {
    background-image: url(../img/qa/qa_main.jpg);
    position: relative;
    }

    #summary .fv .inner .image {
    position: absolute;
    -webkit-transition: 1s all 0s ease;
    transition: 1s all 0s ease;
    }

    #summary .fv .inner .bird {
    left: 0;
    top: 50px;
    width: 230px;
    }

    #summary .fv .inner .doctor {
    right: 50px;
    bottom: 0;
    width: 170px;
    }

    #summary .fv .inner h1 {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
    line-height: 1.5;
    z-index: 1;
    }

    #summary .fv .inner h1 span {
    display: block;
    font-size: 1rem;
    }

    @media screen and (max-width: 767px) {
    #summary .fv .inner .bird {
        width: 150px;
    }
    #summary .fv .inner .doctor {
        right: 20px;
        width: 110px;
    }
    }

    #summary .wrapper {
    background-color: #fff;
    border-radius: 10px;
    padding: 50px 40px;
    }

    @media screen and (max-width: 767px) {
    #summary .wrapper {
        padding: 10px;
    }
    }

    #summary h2::after {
    content: '';
    position: absolute;
    display: block;
    bottom: 0;
    right: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    top: 30px;
    font-size: 1rem;
    }

    #summary h2 {
    text-align: center;
    }

    #summary h3 {
    color: #3f2e16;
    font-weight: bold;
    font-size: 1.4rem;
    padding: 0 20px 12px 20px;
    border-bottom: 3px solid #022a7f;
    display: inline-block;
    line-height: 1.3;
    }

    #summary .tre-icon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 150px;
    height: 50px;
    border-radius: 5%;
    text-align: center;
    color: #fff;
    }

    #summary .disease {
    background-color: #022a7f;
    }

    #summary .symptom {
    background-color: #fcb900;
    }

    #summary .underline {
    position: relative;
    z-index: 1;
    display: inline-block;
    }

    #summary .underline::before {
    content: '';
    position: absolute;
    display: block;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 6px;
    background-color: #e7e391;
    z-index: -1;
    }

    #summary .ora {
    border-bottom: 3px solid #fcb900;
    }

    @media screen and (max-width: 767px) {
    #summary h3 {
        padding-left: 5px;
        padding-right: 0;
    }
    #summary .tre-icon {
        width: 120px;
    }
    #summary .disease {
        font-size: 0.8rem;
    }
    #summary .disease span {
        font-size: 1rem;
    }
    #summary .symptom {
        font-size: 0.8rem;
    }
    }

    #summary .tre_about {
    text-align: center;
    }

    #summary .tre_about h2::before {
    width: 200px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    }

    #summary .tre_about .txt {
    margin-top: 30px;
    }

    #summary .tre_about .to-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    }

    #summary .tre_about .to-link li {
    padding: 10px 17px;
    }

    #summary .tre_about .disease_ul {
    margin-top: 30px;
    }

    @media screen and (max-width: 1024px) {
    #summary .tre_about .to-link li {
        padding: 7px 10px;
    }
    }

    @media screen and (max-width: 767px) {
    #summary .tre_about .to-link li {
        padding: 4px;
    }
    }

    #summary .tre-sec .tips {
    position: relative;
    display: flex;
    }

    #summary .tre-sec .tre-icon {
    position: absolute;
    }

    #summary .tips {
    position: relative;
    /* padding: 30px; */
    margin-top: 40px;
    background-color: #fff;
    }

    #summary .tips.tips-dis {
    /* border: 5px solid #022a7f; */
    /* max-width: 1000px; */
    /* margin: 0 auto; */
    }

    #summary .tips.tips-sym {
    border: 5px solid #fcb900;
    }

    #summary .tips.tips-sym .mb {
    margin-bottom: 40px;
    }

    #summary .tips.tips-sym h3 {
    border-bottom: 3px solid #fcb900;
    }

    #summary .tips.tips-sym .left ul li::before {
    background-color: #fcb900;
    }

    #summary .tips .left {
    width: calc(65% - 30px);
    margin-right: 30px;
    }

    #summary .tips .left ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: 30px;
    margin-top: 15px;
    /* width: 80%; */
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    }

    #summary .tips .left ul li {
    margin-top: 20px;
    padding-left: 10px;
    margin-right: 30px;
    position: relative;
    font-size: 1.2rem;
    line-height: 1.3;
    }

    /* #summary .tips .left ul li::before {
    content: '';
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    top: 7px;
    left: 0px;
    width: 5px;
    height: 5px;
    background-color: #00913a;
    border-radius: 50%;
    } */

    #summary .tips .left p {
    margin-top: 10px;
    }

    #summary .tips .right {
    width: 25%;
    }

    #summary .tips .right img {
    border-radius: 1em;
    }

    #summary .tips .tre-icon {
    position: absolute;
    top: -30px;
    right: 10px;
    }

    #summary .often_case {
    margin-top: 30px;
    width: 100%;
    }

    #summary .often_case img {
    /* width: 100%; */
    /* max-width: 150px; */
    margin: 0 auto;
    display: block;
    }

    #summary .often_case ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    }

    #summary .often_case ul li {
    margin-top: 50px;
    margin: 50px 1%;
    padding: 45px 30px 30px;
    border: 3px solid #167c3b;
    position: relative;
    /* min-width: 33%; */
    text-align: center;
    }

    #summary .often_case ul li p{
    /* display:inline; */
    padding:10px;
    }

    #summary .often_case ul li p{
    /* display:inline; */
    padding: 0;
    margin-top: 10px;
    }

  .count-size_1{color:#167c3b}

    .rankNo1{
      color:#0d2870;
      padding:5px 15px;
      font-size:30px;
      font-weight: 600;
      background:#ffd400;
      border-radius:50%;
      margin:0 5px;
    }

    .rankNo2{
      color:#bb0000;
      padding:5px 15px;
      font-size:30px;
      font-weight: 600;
      background:#67a6bf;
      border-radius:50%;
      margin:0 5px;
    }

    .rankNo3{
      color: #fcb900;
      padding:5px 15px;
      font-size:30px;
      font-weight: 600;
      background:#022a7f;
      border-radius:50%;
      margin:0 5px;
    }


    #summary .effect {
    margin-top: 30px;
    display: flex;
    flex-flow: nowrap;
    justify-content: space-between;
    border: 2px dotted #022a7f;
    padding: 2%;
    border-radius: 1em;
    }

    #summary .effect .efect_txt {
    width: 55%;
    padding: 1%;
    /* justify-content: center; */
    justify-content: space-between;
    color: #000;
    }

    #summary .effect .efect_txt .title {
    font-size: 1.4em;
    line-height: 2;
    }

    #summary .effect .efect_txt .caption {
    line-height: 1.6;
    margin-bottom: 10px;
    }

    #summary .effect .efect_img {
    width: 40%;
    justify-content: center;
    }

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

     #summary .effect {
        flex-flow: wrap;
      }
      #summary .effect .efect_txt {
      width: 100%;
      order:2;
      }

      #summary .effect .efect_img {
      width: 90%;
      margin:0 auto;
      order:1;
      }
     }
    #summary .effect .efect_img img{
    width:100%;
    max-width: 350px;
    }

    .box_flex{
    display:flex;
    flex-flow: wrap;
    justify-content: space-between;
    }


    .pla_col_1 {
    width: 98%
    }

    .pla_col_2 {
    width: 48%;
    }

    .pla_col_3 {
    width: 31%;
    }

    .pla_col_4 {
    width: 60%;
    }
    .pla_col_5 {
    width: 20%;
    }

    .pla_col_5 p{
    display:block;
    }
    .pla_col_5 img{
    display:block;
    }

    .pla_col_6 {
    width: 25%;
    }
    .pla_col_7 {
    width: 16.6%;
    padding: 2%;
    }

    .pla_col_8 {
    width: 14.2%;
    padding: 1%;
    border-right: 1px #ddd dotted;
    }

    @media screen and (max-width: 800px) {
      .pla_col_8 {
        width: 50%;
        padding: 1%;
        border-bottom: 1px #ddd dotted;
      }

      .pla_col_8:nth-of-type(2n) {
        border-right:none;
      }

    }



    .pla_col_8:last-child {
    border-right: none;
    }

    .pla_col_8 p{
    font-size: 14px;
    }

    .pla_col_1 img
    {width:100%;}

    /* .pla_col_1 img, */
    .pla_col_2 img,
    .pla_col_3 img,
    .pla_col_4 img,
    .pla_col_5 img,
    .pla_col_6 img
    {
    /* width:90%; */
    /* max-width: 180px; */
    /* padding:5px; */
    }


    .pla_col_2 img
    {width:100%;max-width: 350px;}



    #summary .often_case ul li .title {
    top: -12px;
    left: 25px;
    min-width: 130px;
    padding: 8px 20px;
    text-align: center;
    display: inline-block;
    color: #fff;
    font-weight: bold;
    background-color: #167c3b;
    position: absolute;
    }

    #summary .often_case ul li .green {
    font-weight: bold;
    display: inline-block;
    color: #8fc767;
    }

    #summary .pickup {
    padding: 30px 40px;
    background-color: #ffeab0;
    position: relative;
    }

    #summary .pickup.mt {
    margin-top: 30px;
    }

    #summary .pickup .img_pickup {
    width: 100px;
    margin-left: -50px;
    margin-bottom: 20px;
    }

    #summary .pickup .title {
    font-size: 1.4rem;
    font-weight: bold;
    color: #3f2e16;
    margin-bottom: 20px;
    line-height: 1.5;
    }

    #summary .pickup .title:before {
    content: '\f4aa';
    font-family: 'Font Awesome 6 pro';
    padding-right: 5px;
    color: #009654;
    font-size: 1.2em
    }

    #summary .pickup .title .underline {
    font-weight: bold;
    }

    #summary .pickup .title .underline::before {
    height: 10px;
    }

    #summary .pickup .txt {
    background: #fff;
    padding: 10px;
    border-radius: 1em;
    margin-bottom: 1em;
    }

    #summary .pickup .name {}

    @media screen and (max-width: 1024px) {
    #summary .tips {
        padding: 15px;
    }
    #summary .tips.tips-dis {
        /* border: 5px solid #8fc767; */
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    }
    #summary .tips.tips-sym {
        border: 5px solid #fcb900;
    }
    #summary .tips.tips-sym .content {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    }
    #summary .tips .left {
        width: 100%;
        margin-right: 0;
        margin-top: 30px;
    }
    #summary .tips .left ul {
        width: 100%;
    }
    #summary .tips .right {
        width: 100%;
    }
    }

    @media screen and (max-width: 767px) {
    #summary .tips {
        padding: 10px;
    }
    #summary .tips .left ul {
        margin: 0 0 10px;
    }
    #summary .tips .left ul li {
        margin-right: 0;
    }
    #summary .tips .tre-icon {
        right: 10px;
    }
    #summary .often_case ul li {
        padding: 30px 10px 20px;
        margin-top: 30px;
        margin-bottom: 10px;
    }
    #summary .often_case ul li .title {
        left: 10px;
    }
    #summary .pickup {
        padding: 20px;
    }
    #summary .pickup .img_pickup {
        margin-left: -25px;
    }
    .medi_col_2 {
        width: 98%;
    }

    }


    .chart-area{
    position: relative;
    width:100%;
    height:50vh;
    }





    .lead{
    padding: 20px;
    text-align: center;
    }

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


    .pla_col_1 {
    width: 98%
    }

    .pla_col_2 {
    width: 98%

    }

    .pla_col_3 {
    width: 98%

    }

    .pla_col_4 {
    width: 98%

    }
    .pla_col_5 {
    width: 98%

    }

    .pla_col_5 p{
    display:block;
    }
    .pla_col_5 img{
    display:block;
    }

    .pla_col_6 {
    width: 98%;

    }
    .pla_col_7 {
    width: 98%;
    padding: 2%;
    }

    .pla_col_1,.pla_col_2,.pla_col_3,.pla_col_4,.pla_col_5,.pla_col_6,.pla_col_7,.pla_col_8 {
    width: 98%;
    padding: 2% 1%;
    border-bottom: 1px #167c3b solid;
    border-right:none
    }

    .pla_col_1 p,.pla_col_2 p,.pla_col_3 p,.pla_col_4 p,.pla_col_5 p,.pla_col_6 p,.pla_col_7 p,.pla_col_8 p {
    font-size:20px;
    }

    .pla_col_1 img,.pla_col_2 img,.pla_col_3 img,.pla_col_4 img,.pla_col_5 img,.pla_col_6 img,.pla_col_7 img,.pla_col_8 img {
    width: 150px;
    padding:2%;
    }



    .pla_col_2:last-child, .pla_col_8:last-child {
    width: 98%;
    padding: 2% 1%;
    border-bottom: none;
    }


    }






  /* -----------------------------------------------------------
     #service_flow
     ----------------------------------------------------------- */

     #service_flow {
      padding: 90px 5%;
      /* background: url(../images/common/noise.png) repeat #f5f5f5; */
      width: 100%;
      background: #f5f5f5;
      max-width: 1200px;
      margin: 60px auto;
  }

  @media only screen and (max-width: 900px) {
      #service_flow {
          padding: 80px 5%;
      }
  }

  @media only screen and (max-width: 736px) {
      #service_flow {
          padding: 70px 5%;
      }
  }

  @media only screen and (max-width: 500px) {
      #service_flow {
          padding: 70px 8%;
      }
  }




  /* --------- .flowArea --------- */

  #service_flow .flowArea {
      margin: -10px;
      font-size: 0;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      flex-wrap: wrap;
  }

  #service_flow .flowBox {
      /* display: inline-block; */
      margin: 0;
      border: #f5f5f5 10px solid;
      width: 33.333%;
      text-align: center;
      /* position: relative; */
      z-index: 2;
      padding: 0%;
      background: #fff;
      /* flex: 1 0 33.3333%; */
  }


  /* .inner */

  #service_flow .flowBox .inner {
      padding: 35px 5% 50px;
      /* background: #fefefe; */
  }

  #service_flow .flowBox .inner img{
    width:100%;
  }




  /* h3 */

  #service_flow .flowBox h3 {
      font-size: 18px;
      font-weight: 700;
      letter-spacing: 1px;
      position: relative;
      z-index: 3;
      line-height: 1;
      padding: 15px 0 15px;
      text-align: center;
  }


  #service_flow .flowBox h3:before {
      font-family: 'Font Awesome 6 pro';
    padding-right:10px;
    font-size:20px;
    color:#167c3b;
  }


  #service_flow .flowBox h3:before {

  /*     width: 1200px;
      height: 60px;
      line-height: 62px;
      color: #fefefe;
      font-size: 25px;
      background: #167c3b;
    border-radius:50%; */
  }


/*


  #service_flow .flowBox:nth-child(1) h3:before {
      content:'\f5c1';

  }

  #service_flow .flowBox:nth-child(2) h3:before {
      content: "2";
        content:'\f433';
  }

  #service_flow .flowBox:nth-child(3) h3:before {
      content: "\f51c";
  }

  #service_flow .flowBox:nth-child(4) h3:before {
      content: "\f685";
  }

  #service_flow .flowBox:nth-child(5) h3:before {
      content: "5";
  }

  #service_flow .flowBox:nth-child(6) h3:before {
      content: "\f1b9";
  } */

  #service_flow .flowBox h3:after {
      position: absolute;
      bottom: 0;
      left: 25px;
      right: 25px;
      height: 0;
      content: "";
      border-top: #e5e8ef 1px solid;
      z-index: 2;
  }


  /* .txtArea */

  #service_flow .flowArea .txtArea {
      display: inline-block;
      margin: 20px auto 0;
  }
  #service_flow .flowArea .txtArea img {
    width:100%;
  }

  @media only screen and (max-width: 900px) {
      #service_flow .flowBox .inner {
          padding: 30px 5% 45px;
      }
      #service_flow .flowBox h3 {
          font-size: 16px;
          padding: 55px 0 30px;
      }
      #service_flow .flowBox h3:before {
          /* margin-left: -20px; */
          width: 40px;
          height: 40px;
          line-height: 42px;
          font-size: 20px;
      }
      #service_flow .flowBox h3:after {
          left: 5%;
          right: 5%;
      }
  }

  @media only screen and (max-width: 768px) {
      #service_flow .flowBox {
          width: 50%;
      }
  }

  @media only screen and (max-width: 736px) {
      #service_flow .flowArea {
        flex-direction:column;
      }
      #service_flow .flowBox {
          display: block;
          margin-top: 50px;
          border: none;
          width: 100%;
          text-align: center;
      }
  /*     #service_flow .flowBox:after {
          position: absolute;
          bottom: -50px;
          right: 0;
          left: 0;
          height: 50px;
          line-height: 50px;
          font-size: 20px;
          font-family: themify;
          content: "\e62a";
          z-index: 1; */
      }
      #service_flow .flowBox:last-child:after {
          display: none;
      }
      /* .inner */
      #service_flow .flowBox .inner {
          padding: 35px 5%;
          /* border: #e5e8ef 1px solid; */
      }
      /* h3 */
      #service_flow .flowBox h3 {
          font-size: 18px;
          padding: 0px 0 25px;
          text-align: center;
      }
      #service_flow .flowBox h3:after {
          border-top: #e5e8ef 1px dotted
      }
      #service_flow .flowArea .txtArea {
          margin: 15px auto 0;
  /*         font-size: 15px;
          text-align: left; */
      }





  }

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

      /* margin: 10px;
      font-size: 0;
      display: flex;
  */
  }


  /* ul.circle */

  ul.circle {
      margin: 0;
      padding: 0 0 0 0px;
      /*     list-style: circle; */
      font-size: 14px;
      text-align: left;
  }

  ul.circle li {
      margin-top: 3px;
      font-size: 15px;
      font-weight: 500;
      letter-spacing: 0.3em;
      line-height: 1.4;
      font-feature-settings: "palt" 1;
  }

  ul.circle li span{font-size:0.9em; color:#167c3b}



  ul.circle li img {
      width: 90%;
      margin: 0 auto;
  }

  @media only screen and (max-width: 900px) {
      ul.circle li {
          font-size: 13px;
      }
  }

  @media only screen and (max-width: 738px) {
      ul.circle li {
          font-size: 12px;
      }
  }




/* ----------------------------------------------------------
   .headline
   ---------------------------------------------------------- */

.headline_pro {
    margin-bottom: 50px;
    text-align: center;
    position: relative;
    z-index: 1;
}

.headline_pro h2.en {
    /* font-size: 35px; */
    /* font-family: 'Poppins', sans-serif; */
    /* font-weight: 700; */
    /* letter-spacing: 2px; */
    /* line-height: 1; */
}

.headline_pro h2.jp {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 1.5;
    margin-top: 15px;
}

@media only screen and (max-width: 900px) {
    .headline_pro {
        margin-bottom: 45px;
    }
    .headline_pro h2.en {
        font-size: 30px;
    }
    .headline_pro h2.jp {
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 1px;
        line-height: 1;
        margin-top: 15px;
    }
}

@media only screen and (max-width: 736px) {
    .headline_pro {
        margin-bottom: 40px;
    }
    .headline_pro h2.en {
        font-size: 25px;
    }
    .headline_pro h2.jp {
        font-size: 13px;
        margin-top: 10px;
    }
}

@media only screen and (max-width: 414px) {
    .headline_pro h2.jp {
        font-size: 12px;
    }
}




/* -----------------------------------------------------------
   #service_flow
   ----------------------------------------------------------- */

   #service_flow {
    /* padding: 90px 3%; */
    /* background: url(../images/common/noise.png) repeat #f5f5f5; */
    width: 100%;
    background: #f5f5f5;
    /* max-width: 1300px; */
    margin: 60px auto;
    margin-top: 0;
}

@media only screen and (max-width: 900px) {
    #service_flow {
        padding: 80px 5%;
    }
}

@media only screen and (max-width: 736px) {
    #service_flow {
        padding: 70px 5%;
    }
}

@media only screen and (max-width: 500px) {
    #service_flow {
        padding: 70px 8%;
    }
}




/* --------- .flowArea --------- */

#service_flow .flowArea {
    margin: -10px;
    font-size: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto;
}

#service_flow .flowBox {
    /* display: inline-block; */
    margin: 0;
    border: #f5f5f5 10px solid;
    width: 33.333%;
    text-align: center;
    /* position: relative; */
    z-index: 2;
    padding: 0%;
    background: #fff;
    /* flex: 1 0 33.3333%; */
}


/* .inner */

#service_flow .flowBox .inner {
    padding: 35px 5% 50px;
    /* background: #fefefe; */
}

#service_flow .flowBox .inner img{
  width:100%;
}




/* h3 */

#service_flow .flowBox h3 {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 1px;
    position: relative;
    z-index: 3;
    line-height: 1;
    padding: 15px 0 15px;
    text-align: center;
}


#service_flow .flowBox h3:before {
    font-family: 'Font Awesome 6 pro';
    padding-right:10px;
    font-size: 25px;
    color: #141414;
}



#service_flow .flowBox h3:before{
  content: "\e100";
}





#service_flow .flowBox h3:before {

/*     width: 1200px;
    height: 60px;
    line-height: 62px;
    color: #fefefe;
    font-size: 25px;
    background: #167c3b;
  border-radius:50%; */
}






#service_flow .flowBox:nth-child(1) h3:before {
    content:'\f70c';
    font-size: 28px;
}

#service_flow .flowBox:nth-child(2) h3:before {

      content:'\f469';
}

#service_flow .flowBox:nth-child(3) h3:before {
    content: "\e458";
}

#service_flow .flowBox:nth-child(4) h3:before {
    content: "\e021";
}

#service_flow .flowBox:nth-child(5) h3:before {
    content: "\f259";
}

#service_flow .flowBox:nth-child(6) h3:before {
    content: "\f7f2";
}







#service_flow .flowBox h3:after {
    position: absolute;
    bottom: 0;
    left: 25px;
    right: 25px;
    height: 0;
    content: "";
    border-top: #e5e8ef 1px solid;
    z-index: 2;
}


/* .txtArea */

#service_flow .flowArea .txtArea {
    display: inline-block;
    margin: 20px auto 0;
}
#service_flow .flowArea .txtArea img {
  width:100%;
}

@media only screen and (max-width: 900px) {
    #service_flow .flowBox .inner {
        padding: 30px 5% 45px;
    }
    #service_flow .flowBox h3 {
        font-size: 16px;
        padding: 55px 0 30px;
    }
    #service_flow .flowBox h3:before {
        /* margin-left: -20px; */
        width: 40px;
        height: 40px;
        line-height: 42px;
        font-size: 25px;
    }
    #service_flow .flowBox h3:after {
        left: 5%;
        right: 5%;
    }
}

@media only screen and (max-width: 768px) {
    #service_flow .flowBox {
        width: 50%;
    }
}

@media only screen and (max-width: 736px) {
    #service_flow .flowArea {
      flex-direction:column;
    }
    #service_flow .flowBox {
        display: block;
        margin-top: 50px;
        border: none;
        width: 100%;
        text-align: center;
    }
/*     #service_flow .flowBox:after {
        position: absolute;
        bottom: -50px;
        right: 0;
        left: 0;
        height: 50px;
        line-height: 50px;
        font-size: 20px;
        font-family: themify;
        content: "\e62a";
        z-index: 1; */
    }
    #service_flow .flowBox:last-child:after {
        display: none;
    }
    /* .inner */
    #service_flow .flowBox .inner {
        padding: 35px 5%;
        /* border: #e5e8ef 1px solid; */
    }

   /* h3 */
    #service_flow .flowBox h2 {
        font-size: 18px;
        padding: 0px 0 25px;
        text-align: center;
        font-family: "Century Gothic", sans-serif;
        font-weight: 500;
    }


    /* h3 */
    #service_flow .flowBox h3 {
        font-size: 18px;
        padding: 0px 0 25px;
        text-align: center;
        line-height: 1.5;
    }
    #service_flow .flowBox h3:after {
        border-top: #e5e8ef 1px dotted
    }
    #service_flow .flowArea .txtArea {
        margin: 15px auto 0;
/*         font-size: 15px;
        text-align: left; */
    }





}

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

    /* margin: 10px;
    font-size: 0;
    display: flex;
*/
}


/* ul.circle */

ul.circle {
    margin: 0;
    padding: 0 0 0 0px;
    /*     list-style: circle; */
    font-size: 14px;
    text-align: left;
}

ul.circle li {
    margin-top: 3px;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.3em;
    line-height: 1.4;
    font-feature-settings: "palt" 1;
}

ul.circle li span{font-size:0.9em; color:#167c3b}



ul.circle li img {
    width: 90%;
    margin: 0 auto;
}

@media only screen and (max-width: 900px) {
    ul.circle li {
        font-size: 13px;
    }
}

@media only screen and (max-width: 738px) {
    ul.circle li {
        font-size: 12px;
    }
}




   .sports_inner {
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    /* padding-left: 20px; */
    /* padding-right: 20px; */
  }

  .como_box {
    margin-top: 60px;
    border: 1px solid #d7d7d7 ;
    padding:30px 20px;
  }

  .como_title {
    position: relative;
    font-size: 26px;
    letter-spacing: 0.1em;
    font-weight: 100;
    padding-bottom: 20px;
    padding-left: 10px;
    border-bottom: 1px solid #d7d7d7 ;
  }



  .como_txt {
    font-size: 17px;
  }


  .label_title::after {
    content: 'about';
    position: absolute;
    right: 10px;
    font-size: 18px;
    padding: 4px 20px;
    border-radius: 30px;
    background-color: #000000;
    color: #fff;
  }


  .como_flex {
    display: flex;
    padding: 0 10px;
    margin-top: 30px;
    margin-bottom: 30px;
  }

  .como_flex_img {
    width: 30%;
  }

  .como_flex_text {
    width: 66%;
    margin-left: 40px;
  }

  .como_flex_title {
    font-size: 20px;
    line-height: 1.6;
    letter-spacing: 0.05em;
    font-weight: 100;
  }

  .como_flex_menu {
    margin-top: 20px;
    font-weight: 100;
    line-height: 2.5;
    font-size: 17px;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .menu_text {
    font-weight: 100;
    line-height: 1.7;
    font-size: 16px;
  }

  .como_flex_menu dt {
    width: 30px;
    text-align: left;
    color: #333;
  }

  .como_flex_menu dd {
    width: calc(100% - 40px);
    text-align: left;
    padding-left:1em;
    text-indent:-1em;
  }

  .como_link {
    margin-top: 10px;
    text-align: right;
  }

  .como_btn {
    position: relative;
    display: inline-block;
    min-width: 280px;
    background-color: #000000;
    padding: 12px 10px 12px 24px;
    line-height: 1.4;
    letter-spacing: 0.1em;
    font-size: 16px;
    color: #fff;
    text-align: left;
    margin: 0 10px;
    transition: all .5s;
    text-decoration: none;
  }

  /*--- 矢印 ---*/
  .como_btn::before{
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px;
    width: 34px;
    height: 1px;
    background:#fff;
    transition: all .5s;
  }
  .como_btn::after{
    content: '';
    position: absolute;
    top: 40%;
    right: 31px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    transition: all .5s;
  }
  .como_btn:hover {
    opacity: .8;
    color: #fff !important;
  }
  .como_btn:hover::before {
    right: 23px;
  }
  .como_btn:hover::after {
    right: 24px;
  }

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

    .como_inner {
      padding: 0;
    }

    .como_box {
      margin-top: 30px;
      padding: 20px;
    }

    .como_title {
      position: relative;
      font-size: 20px;
      padding-bottom: 14px;
      padding-left: 0;
    }

    .label_title::after {
      right: -14px;
      top: 0;
      font-size: 14px;
    }

    .como_flex {
      display: block;
      padding: 0 ;
      margin-top: 20px;
    }

    .como_flex_img {
      width: 100%;
    }

    .como_flex_text {
      width: 100%;
      margin-left: 0;
    }

    .como_flex_title {
      font-size: 16px;
      margin-top: 10px;
    }

    .como_flex_menu {
      margin-top: 10px;
      line-height: 1.7;
      font-size: 16px;
    }

    .como_flex_menu dt {
      width: 100%;
      text-align: left;
      color: #333;
    }

    .como_flex_menu dd {
      width: 100%;
      text-align: left;
    }

    .como_link {
      margin-top: 10px;
      text-align: center;
    }

    .como_btn {
      position: relative;
      display: inline-block;
      min-width: 280px;
      background-color: #185e7d;
      padding: 12px 10px 12px 24px;
      line-height: 1.4;
      letter-spacing: 0.1em;
      font-size: 16px;
      color: #fff;
      text-align: left;
      margin: 0 10px;
    }

    /*--- 矢印 ---*/
    .como_btn::before{
      content: '';
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 30px;
      width: 34px;
      height: 1px;
      background:#fff;
      transition: all .5s;
    }
    .como_btn::after{
      content: '';
      position: absolute;
      top: 40%;
      right: 31px;
      width: 10px;
      height: 10px;
      border-top: 1px solid #fff;
      border-right: 1px solid #fff;
      transform: rotate(45deg);
      transition: all .5s;
    }
    .como_btn:hover::before {
      right: 23px;
    }
    .como_btn:hover::after {
      right: 24px;
    }
  }


   .sports_inner {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    /* padding-left: 20px; */
    /* padding-right: 20px; */
  }

  .sports_box {
    margin-top: 60px;
    border: 1px solid #d7d7d7 ;
    padding:30px 20px;
  }

  .sports_title {
    position: relative;
    font-size: 26px;
    letter-spacing: 0.1em;
    font-weight: 100;
    padding-bottom: 20px;
    padding-left: 10px;
    border-bottom: 1px solid #d7d7d7;
    margin-bottom: 20px;
  }

  .sports_catch {
    font-size: 16px;
    letter-spacing: 0.1em;
    font-weight: 100;
    line-height: 2;
    padding-bottom: 0;
    padding-left: 10px;
  }


  .sports_txt {
    font-size: 17px;
    line-height: 1.5;
  }


  .label_title::after {
    content: 'CHECK';
    position: absolute;
    right: 10px;
    font-size: 18px;
    padding: 4px 20px;
    border-radius: 30px;
    background-color: #000000;
    color: #fff;
  }


  .sports_flex {
    display: flex;
    padding: 0 10px;
    margin-top: 30px;
    margin-bottom: 30px;
  }

  .sports_flex_img {
    width: 50%;
  }

  .sports_flex_text {
    width: 50%;
    margin-left: 40px;
  }

  .sports_flex_title {
    font-size: 20px;
    line-height: 1.6;
    letter-spacing: 0.05em;
    font-weight: 100;
  }

  .sports_flex_menu {
    margin-top: 20px;
    font-weight: 100;
    line-height: 2.5;
    font-size: 17px;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .menu_text {
    font-weight: 100;
    line-height: 1.7;
    font-size: 16px;
  }

  .sports_flex_menu dt {
    width: 30px;
    text-align: left;
    color: #333;
  }

  .sports_flex_menu dd {
    width: calc(100% - 40px);
    text-align: left;
    padding-left:1em;
    text-indent:-1em;
  }

  .sports_link {
    margin-top: 10px;
    text-align: right;
  }

  .sports_btn {
    position: relative;
    display: inline-block;
    min-width: 280px;
    background-color: #000000;
    padding: 12px 10px 12px 24px;
    line-height: 1.4;
    letter-spacing: 0.1em;
    font-size: 16px;
    color: #fff;
    text-align: left;
    margin: 0 10px;
    transition: all .5s;
    text-decoration: none;
  }

  /*--- 矢印 ---*/
  .sports_btn::before{
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px;
    width: 34px;
    height: 1px;
    background:#fff;
    transition: all .5s;
  }
  .sports_btn::after{
    content: '';
    position: absolute;
    top: 40%;
    right: 31px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    transition: all .5s;
  }
  .sports_btn:hover {
    opacity: .8;
    color: #fff !important;
  }
  .sports_btn:hover::before {
    right: 23px;
  }
  .sports_btn:hover::after {
    right: 24px;
  }

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

    .sports_inner {
      padding: 0;
    }

    .sports_box {
      margin-top: 30px;
      padding: 20px;
    }

    .sports_title {
      position: relative;
      font-size: 20px;
      padding-bottom: 14px;
      padding-left: 0;
    }

    .label_title::after {
      right: -14px;
      top: 0;
      font-size: 14px;
    }

    .sports_flex {
      display: block;
      padding: 0 ;
      margin-top: 20px;
    }

    .sports_flex_img {
      width: 100%;
    }

    .sports_flex_text {
      width: 100%;
      margin-left: 0;
    }

    .sports_flex_title {
      font-size: 16px;
      margin-top: 10px;
    }

    .sports_flex_menu {
      margin-top: 10px;
      line-height: 1.7;
      font-size: 16px;
    }

    .sports_flex_menu dt {
      width: 100%;
      text-align: left;
      color: #333;
    }

    .sports_flex_menu dd {
      width: 100%;
      text-align: left;
    }

    .sports_link {
      margin-top: 10px;
      text-align: center;
    }

    .sports_btn {
      position: relative;
      display: inline-block;
      min-width: 280px;
      background-color: #185e7d;
      padding: 12px 10px 12px 24px;
      line-height: 1.4;
      letter-spacing: 0.1em;
      font-size: 16px;
      color: #fff;
      text-align: left;
      margin: 0 10px;
    }

    /*--- 矢印 ---*/
    .sports_btn::before{
      content: '';
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 30px;
      width: 34px;
      height: 1px;
      background:#fff;
      transition: all .5s;
    }
    .sports_btn::after{
      content: '';
      position: absolute;
      top: 40%;
      right: 31px;
      width: 10px;
      height: 10px;
      border-top: 1px solid #fff;
      border-right: 1px solid #fff;
      transform: rotate(45deg);
      transition: all .5s;
    }
    .sports_btn:hover::before {
      right: 23px;
    }
    .sports_btn:hover::after {
      right: 24px;
    }
  }




/* 幹細胞 */
.stemcell_inner {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  /* padding-left: 20px; */
  /* padding-right: 20px; */
}

.stemcell_box {
  margin-top: 60px;
  border: 1px solid #d7d7d7 ;
  padding:30px 20px;
}

.stemcell_title {
  position: relative;
  font-size: 26px;
  letter-spacing: 0.1em;
  font-weight: 100;
  padding-bottom: 20px;
  padding-left: 10px;
  border-bottom: 1px solid #d7d7d7;
  margin-bottom: 20px;
}

.stemcell_catch {
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 100;
  line-height: 2;
  padding-bottom: 0;
  padding-left: 10px;
}


.stemcell_txt {
  font-size: 17px;
  line-height: 1.5;
}


.stemcell_txt .label_title::after {
  content: '幹細胞';
  position: absolute;
  right: 10px;
  font-size: 18px;
  padding: 4px 20px;
  border-radius: 30px;
  background-color: #000000;
  color: #fff;
}


.stemcell_flex {
  display: flex;
  padding: 0 10px;
  margin-top: 30px;
  margin-bottom: 30px;
}

.stemcell_flex_img {
  width: 50%;
}

.stemcell_flex_text {
  width: 50%;
  margin-left: 40px;
}

.stemcell_flex_title {
  font-size: 20px;
  line-height: 1.6;
  letter-spacing: 0.05em;
  font-weight: 100;
}

.stemcell_flex_menu {
  margin-top: 20px;
  font-weight: 100;
  line-height: 2.5;
  font-size: 17px;
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
}

.menu_text {
  font-weight: 100;
  line-height: 1.7;
  font-size: 16px;
}

.stemcell_flex_menu dt {
  width: 30px;
  text-align: left;
  color: #333;
}

.stemcell_flex_menu dd {
  width: calc(100% - 40px);
  text-align: left;
  padding-left:1em;
  text-indent:-1em;
}

.stemcell_link {
  margin-top: 10px;
  text-align: right;
}

.stemcell_btn {
  position: relative;
  display: inline-block;
  min-width: 280px;
  background-color: #000000;
  padding: 12px 10px 12px 24px;
  line-height: 1.4;
  letter-spacing: 0.1em;
  font-size: 16px;
  color: #fff;
  text-align: left;
  margin: 0 10px;
  transition: all .5s;
  text-decoration: none;
}

/*--- 矢印 ---*/
.stemcell_btn::before{
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 30px;
  width: 34px;
  height: 1px;
  background:#fff;
  transition: all .5s;
}
.stemcell_btn::after{
  content: '';
  position: absolute;
  top: 40%;
  right: 31px;
  width: 10px;
  height: 10px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: rotate(45deg);
  transition: all .5s;
}
.stemcell_btn:hover {
  opacity: .8;
  color: #fff !important;
}
.stemcell_btn:hover::before {
  right: 23px;
}
.stemcell_btn:hover::after {
  right: 24px;
}

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

  .stemcell_inner {
    padding: 0;
  }

  .stemcell_box {
    margin-top: 30px;
    padding: 20px;
  }

  .stemcell_title {
    position: relative;
    font-size: 20px;
    padding-bottom: 14px;
    padding-left: 0;
  }

  .label_title::after {
    right: -14px;
    top: -40px;
    font-size: 14px;
  }

  .stemcell_flex {
    display: block;
    padding: 0 ;
    margin-top: 20px;
  }

  .stemcell_flex_img {
    width: 100%;
  }

  .stemcell_flex_text {
    width: 100%;
    margin-left: 0;
  }

  .stemcell_flex_title {
    font-size: 16px;
    margin-top: 10px;
  }

  .stemcell_flex_menu {
    margin-top: 10px;
    line-height: 1.7;
    font-size: 16px;
  }

  .stemcell_flex_menu dt {
    width: 100%;
    text-align: left;
    color: #333;
  }

  .stemcell_flex_menu dd {
    width: 100%;
    text-align: left;
  }

  .stemcell_link {
    margin-top: 10px;
    text-align: center;
  }

  .stemcell_btn {
    position: relative;
    display: inline-block;
    min-width: 280px;
    background-color: #185e7d;
    padding: 12px 10px 12px 24px;
    line-height: 1.4;
    letter-spacing: 0.1em;
    font-size: 16px;
    color: #fff;
    text-align: left;
    margin: 0 10px;
  }

  /*--- 矢印 ---*/
  .stemcell_btn::before{
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px;
    width: 34px;
    height: 1px;
    background:#fff;
    transition: all .5s;
  }
  .stemcell_btn::after{
    content: '';
    position: absolute;
    top: 40%;
    right: 31px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    transition: all .5s;
  }
  .stemcell_btn:hover::before {
    right: 23px;
  }
  .stemcell_btn:hover::after {
    right: 24px;
  }
}

/* 幹細胞 */















.area_bui{display: flex;flex-wrap: wrap;/* justify-content: flex-start; *//* justify-content: flex-end; */}

.area_bui .wrap{width: 48%;}
.box_bui{border: 1px solid #ddd;}



.box_bui {
  position: relative;
  margin: 2em 0;
  padding: 1.5em 1em;
  border: solid 1px #18274d;
  border-radius: 0.2em;
  width: 100%;
}
.box_bui .box-title {
  position: absolute;
  display: inline-block;
  top: -13px;
  left: 10px;
  padding: 0 9px;
  line-height: 1;
  font-size: 19px;
  background: #FFF;
  color: #18274d;
  font-weight: bold;
}


.box_bui ul{display:inline}

.box_bui .item{
    width: auto;
    margin: 3px;
    padding: 5px 15px;
    border: #eee8df 1px solid;
    border: #ede4da 1px solid;
    font-size: 12px;
    letter-spacing: 0;
    border-radius: 30px;
   display:inline-block;
    }




/* -----------------------------------------------------------
   #about_philosophy
   ----------------------------------------------------------- */

   #about_philosophy {
    padding: 0px 5%;
    /* top: 100px; */
    /* position: relative; */
    /* margin-bottom: 50px; */
}

@media only screen and (max-width: 900px) {
    #about_philosophy {
        padding: 80px 5%;
    }
}

@media only screen and (max-width: 736px) {
    #about_philosophy {
        padding: 10px 5%;
    }
}


/* .catchArea */

#about_philosophy .catchArea {
    position: relative;
    z-index: 2;
    text-align: center;
}

#about_philosophy .catchArea h3 {
    font-size: 30px;
    font-weight: 700;
    line-height: 1.9;
    letter-spacing: 3px;
}

#about_philosophy .catchArea h3 span {
    position: relative;
    z-index: 1;
    padding: 0 60px;
}

#about_philosophy .catchArea h3 span:before {
    position: absolute;
    top: 50%;
    left: 0;
    width: 45px;
    height: 0;
    content: "";
    border-top: #222 1px solid;
    z-index: -1;
}

#about_philosophy .catchArea h3 span:after {
    position: absolute;
    top: 50%;
    right: 0;
    width: 45px;
    height: 0;
    content: "";
    border-top: #222 1px solid;
    z-index: -1;
}


/* .txtArea */

#about_philosophy .txtArea {
    margin: 45px auto;
    max-width: 1100px;
    border: 1px solid #eee;
    padding: 2%;
}


.p-about {
    position: relative;
    z-index: 0;
    width: 100%
}

.p-about-kv {
    position: relative;
    z-index: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.p-about-kv__image {
    -ms-flex-preferred-size: 62%;
    flex-basis: 62%;
    max-width: 62%;
    height: 43.75vw;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover
}

@media (max-width:767px) {
    .p-about-kv__image {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
        height: 70.66667vw
    }
}

.p-about-kv__heading {
    font-size: 30px;
    font-size: 3rem;
    -ms-flex-preferred-size: 38%;
    flex-basis: 38%;
    max-width: 38%;
    text-align: center;
    letter-spacing: 0.2em
}

.p-about-kv__heading span {
    color: #d0d0d0
}

@media (max-width:1280px) {
    .p-about-kv__heading {
        font-size: 20px;
        font-size: 2rem
    }
}

@media (max-width:767px) {
    .p-about-kv__heading {
        font-size: 28px;
        font-size: 2.8rem;
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
        padding-top: 70px;
        padding-bottom: 70px
    }
}

.p-about-intro {
    position: relative;
    padding: 6vw 140px 8.97222vw;
}

@media (max-width:1280px) {
    .p-about-intro {
        padding-right: 50px;
        padding-left: 50px
    }
}

@media (max-width:767px) {
    .p-about-intro {
        padding-top: 0;
        padding-right: 13.33333vw;
        padding-left: 13.33333vw;
        padding-bottom: 20px
    }
}

.p-about-intro__row {
    position: relative;
    z-index: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.p-about-intro__row--2 {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

.p-about-intro__row--3 {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

.p-about-intro__col--l {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-preferred-size: 47%;
    flex-basis: 47%;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    max-width: 47%;
    padding-right: 8vw;
}

.p-about-intro__col--r {
    -ms-flex-preferred-size: 53%;
    flex-basis: 53%;
    max-width: 53%
}

@media (max-width:767px) {
    .p-about-intro__col {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        max-width: 100%;
        padding: 0
    }
}

.p-about-intro__text {
    font-size: 14px;
    font-size: 16px;
    line-height: 1.6;
}

@media (max-width:1280px) {
    .p-about-intro__text {
        font-size: 16px;
        /* font-size: 1.3rem; */
        padding: 50px 0;
    }

    .p-about-intro__text--1 {
        padding-top: 0
    }
}

@media (max-width:767px) {
    .p-about-intro__text {
        font-size: 13px;
        font-size: 3.46667vw;
        padding: 13.33333vw 0
    }

    .p-about-intro__text--1 {
        padding-top: 0
    }
}

.p-about-intro__image--1 {
    margin-top: 1vw;
}

.p-about-intro__image--1 img {
    max-width: 41.66667vw
}

.p-about-intro__image--2 {
    margin-top: -8.33333vw
}

.p-about-intro__image--2 img {
    max-width: 30.08333vw;
}

.p-about-intro__image--3 img {
    max-width: 26.38889vw
}

@media (max-width:1280px) {
    .p-about-intro__image--1 {
        margin-top: 2.08333vw
    }

    .p-about-intro__image--1 img {
        max-width: 41.66667vw
    }

    .p-about-intro__image--2 {
        margin-top: -1.38889vw
    }
}

@media (max-width:767px) {
    .p-about-intro__image--1 img {
        max-width: 100%
    }

    .p-about-intro__image--2 img {
        max-width: 58.66667vw
    }

    .p-about-intro__image--3 {
        margin-right: -13.33333vw;
        text-align: right
    }

    .p-about-intro__image--3 img {
        max-width: 49.6vw;
        margin-top: 13.33333vw
    }
}

.p-about-intro__bg {
    position: absolute;
    z-index: 0;
    background-color: #f0f0f0
}

.p-about-intro__bg--1 {
    top: -4.86111vw;
    right: 0;
    width: 46.94444vw;
    height: 46.94444vw
}

.p-about-intro__bg--2 {
    top: 40.97222vw;
    left: 0;
    width: 29.86111vw;
    height: 58.33333vw
}

@media (max-width:767px) {
    .p-about-intro__bg--1 {
        top: 48vw;
        width: 52vw;
        height: 52vw
    }

    .p-about-intro__bg--2 {
        top: 202.66667vw;
        width: 41.86667vw;
        height: 81.86667vw
    }
}

.p-about-separate {
    z-index: 0;
    width: 100%;
    height: 25vw;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    margin-bottom: 100px;
}

@media (max-width:767px) {
    .p-about-separate {
        height: 81.33333vw
    }
}

.p-about-works {
    position: relative;
    padding: 150px 0 80px
}

@media (max-width:767px) {
    .p-about-works {
        padding: 60px 0 20px
    }
}

.p-about-works__heading {
    text-align: center
}

.p-about-works__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px
}

.p-about-works__list-item {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    -ms-flex-preferred-size: 33.333%;
    flex-basis: 33.333%;
    max-width: 33.333%;
    padding-right: 15px;
    padding-bottom: 70px;
    padding-left: 15px;
    -webkit-transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, -webkit-transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, -webkit-transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    -o-transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s, -webkit-transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    opacity: 0
}

.p-about-works__list-item.is-onscreen {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1 !important
}

.is-onscreen .p-about-works__list-item {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1 !important
}

.p-about-works__list-item:first-child {
    -webkit-transition-delay: 0.4s;
    -o-transition-delay: 0.4s;
    transition-delay: 0.4s
}

.p-about-works__list-item:nth-child(2) {
    -webkit-transition-delay: 0.5s;
    -o-transition-delay: 0.5s;
    transition-delay: 0.5s
}

.p-about-works__list-item:nth-child(3) {
    -webkit-transition-delay: 0.6s;
    -o-transition-delay: 0.6s;
    transition-delay: 0.6s
}

.p-about-works__list-item:nth-child(4) {
    -webkit-transition-delay: 0.7s;
    -o-transition-delay: 0.7s;
    transition-delay: 0.7s
}

.p-about-works__list-item:nth-child(5) {
    -webkit-transition-delay: 0.8s;
    -o-transition-delay: 0.8s;
    transition-delay: 0.8s
}

@media (max-width:1023px) {
    .p-about-works__list-item {
        padding-bottom: 50px
    }
}

@media (max-width:767px) {
    .p-about-works__list-item {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
        padding-bottom: 35px
    }
}

.p-about-works__list-inner {
    display: block
}

.p-about-works__list-image {
    position: relative;
    z-index: 0;
    overflow: hidden;
    margin-bottom: 30px
}

.p-about-works__list-image img {
    width: 100%;
    height: auto;
    -webkit-transition: 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -webkit-transform-origin: center center;
    -ms-transform-origin: center center;
    transform-origin: center center
}

a:hover .p-about-works__list-image img {
    -webkit-transform: scale(1.03);
    -ms-transform: scale(1.03);
    transform: scale(1.03)
}

.p-about-works__list-title {
    font-size: 24px;
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 15px
}

@media (max-width:1023px) {
    .p-about-works__list-title {
        font-size: 20px;
        font-size: 2rem
    }
}

.p-about-works__list-text {
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.8
}

.p-about-group {
    position: relative;
    padding: 100px 0 30px;
    background-color: #f1f1f1
}

@media (max-width:767px) {
    .p-about-group {
        padding: 60px 0 30px
    }
}

.p-about-group__heading {
    text-align: center
}

.p-about-group__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px
}

.p-about-group__list-item {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
    padding-right: 15px;
    padding-bottom: 70px;
    padding-left: 15px;
    -webkit-transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, -webkit-transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, -webkit-transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    -o-transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    transition: opacity 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.4s, transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s, -webkit-transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s;
    opacity: 0
}

.p-about-group__list-item a {
    display: block
}

.p-about-group__list-item.is-onscreen {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1 !important
}

.is-onscreen .p-about-group__list-item {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1 !important
}

.p-about-group__list-item:first-child {
    -webkit-transition-delay: 0.4s;
    -o-transition-delay: 0.4s;
    transition-delay: 0.4s
}

.p-about-group__list-item:nth-child(2) {
    -webkit-transition-delay: 0.5s;
    -o-transition-delay: 0.5s;
    transition-delay: 0.5s
}

.p-about-group__list-item:nth-child(3) {
    -webkit-transition-delay: 0.6s;
    -o-transition-delay: 0.6s;
    transition-delay: 0.6s
}

.p-about-group__list-item:nth-child(4) {
    -webkit-transition-delay: 0.7s;
    -o-transition-delay: 0.7s;
    transition-delay: 0.7s
}

.p-about-group__list-item:nth-child(5) {
    -webkit-transition-delay: 0.8s;
    -o-transition-delay: 0.8s;
    transition-delay: 0.8s
}

@media (max-width:1023px) {
    .p-about-group__list-item {
        padding-bottom: 50px
    }
}

@media (max-width:767px) {
    .p-about-group__list-item {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
        padding-bottom: 35px
    }
}

.p-about-group__list-inner {
    display: block
}

.p-about-group__list-image {
    position: relative;
    z-index: 0;
    overflow: hidden;
    margin-bottom: 30px
}

.p-about-group__list-image img {
    width: 100%;
    height: auto;
    -webkit-transition: 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -webkit-transform-origin: center center;
    -ms-transform-origin: center center;
    transform-origin: center center
}

a:hover .p-about-group__list-image img {
    -webkit-transform: scale(1.03);
    -ms-transform: scale(1.03);
    transform: scale(1.03)
}

.p-about-group__list-title {
    font-size: 24px;
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 15px
}

@media (max-width:1023px) {
    .p-about-group__list-title {
        font-size: 20px;
        font-size: 2rem
    }
}

.p-about-group__list-text {
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.8
}

.p-about-company {
    padding: 50px 0 100px;
}

@media (max-width:767px) {
    .p-about-company {
        padding: 60px 0 30px
    }
}

.p-about-company__heading {
    text-align: center;
}

.p-about-company__list {
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.8;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 30px
}

@media (max-width:1023px) {
    .p-about-company__list {
        font-size: 12px;
        font-size: 1.2rem
    }
}

.p-about-company__list-head {
    font-weight: 700;
    -ms-flex-preferred-size: 120px;
    flex-basis: 120px;
    max-width: 120px;
    margin-bottom: 20px;
    font-size: 16px;
    line-height: 1.5;
    border-bottom: 1px dashed #ddd;
}

@media (max-width:1023px) {
    .p-about-company__list-head {
        -ms-flex-preferred-size: 70px;
        flex-basis: 70px;
        max-width: 70px
    }
}

@media (max-width:767px) {
    .p-about-company__list-head {
        margin-bottom: 15px
    }
}

.p-about-company__list-body {
    -ms-flex-preferred-size: calc(100% - 120px);
    flex-basis: calc(100% - 120px);
    max-width: calc(100% - 120px);
    margin-bottom: 20px;
    font-size: 16px;
    /* line-height: 18px; */
    border-bottom: 1px dashed #ddd;
}

@media (max-width:1023px) {
    .p-about-company__list-body {
        -ms-flex-preferred-size: calc(100% - 70px);
        flex-basis: calc(100% - 70px);
        max-width: calc(100% - 70px)
    }
}

@media (max-width:767px) {
    .p-about-company__list-body {
        margin-bottom: 15px
    }
}


.p-store-floor {
    position: relative;
    margin-bottom: 120px
}

.p-store-floor__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 80px
}

.p-store-floor__item:last-child {
    margin-bottom: 0
}

.p-store-floor__item--reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

@media (max-width:1023px) {
    .p-store-floor__item {
        margin-bottom: 50px
    }
}

.p-store-floor__image {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
}

@media (max-width:1023px) {
    .p-store-floor__image {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
        margin-bottom: 30px
    }
}

.p-store-floor__discription {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    /* max-width: 50%; */
    padding: 0 0;
    text-align: left;
}

@media (max-width:1023px) {
    .p-store-floor__discription {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%
    }
}

@media (max-width:1023px) {
    .p-store-floor__discription {
        padding: 0
    }
}

.p-store-floor__num {
    font-size: 20px;
    /* font-size: 7rem; */
    font-family: futura-pt, "Helvetica Neue", Helvetica, Arial, sans-serif;
    margin-bottom: 10px;
    /* text-align: center; */
    /* color: #9E9E9E; */
    /* padding: 2%; */
    border-bottom: 1px solid #ffc107;
    /* background: #ffc107; */
}

@media (max-width:1280px) {
    .p-store-floor__num {
        font-size: 28px;
        /* font-size: 5rem; */
    }
}

@media (max-width:1023px) {
    .p-store-floor__num {
        font-size: 42px;
        font-size: 4.2rem
    }
}

@media (max-width:1023px) {
    .p-store-floor__num {
        font-size: 30px;
        font-size: 18px;
    }
}

.p-store-floor__heading {
    font-size: 18px;
    /* font-size: 3rem; */
    /* font-family: futura-pt, "Helvetica Neue", Helvetica, Arial, sans-serif; */
    line-height: 1.3;
    margin-bottom: 20px;
    /* text-align: center */
}

@media (max-width:1280px) {
    .p-store-floor__heading {
        font-size: 24px;
        font-size: 20px;
    }
}

@media (max-width:767px) {
    .p-store-floor__heading {
        font-size: 20px;
        font-size: 2rem
    }
}

.p-store-floor__text {
    font-size: 14px;
    font-size: 16px;
    line-height: 1.8;
}

.p-store-floor__text ul {
    padding-left: 0;
}

.p-store-floor__text li {
    font-size: 14px;
    font-size: 16px;
    line-height: 1.8;
}
@media (max-width:414px) {
.p-store-floor__text li {
    font-size: 14px;
    line-height: 1.8;
    padding-left:3em;
    text-indent:-2.5em;
}
}


.p-store-floor__text li:before {
        font-size: 15px;
    font-family: 'FontAwesome';
    content: "\f0fa";
    font-weight: normal;
    margin: 0 10px;
    height: 20px;
    line-height: 20px;
    color:#e38b09;
}



@media (max-width:767px) {
    .p-store-floor__text {
        font-size: 13px;
        font-size: 1.3rem
    }
}

.p-store-blackboard {
    position: relative
}

.p-store-blackboard__heading {
    font-size: 50px;
    font-size: 5rem;
    font-family: futura-pt, "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
    margin-bottom: 50px
}

@media (max-width:1023px) {
    .p-store-blackboard__heading {
        font-size: 42px;
        font-size: 4.2rem;
        margin-bottom: 40px
    }
}

@media (max-width:767px) {
    .p-store-blackboard__heading {
        font-size: 36px;
        font-size: 9.6vw;
        margin-bottom: 30px
    }
}

.p-store-blackboard__lead {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.8;
    margin-bottom: 50px
}

@media (max-width:1023px) {
    .p-store-blackboard__lead {
        margin-bottom: 40px
    }
}

@media (max-width:767px) {
    .p-store-blackboard__lead {
        font-size: 13px;
        font-size: 1.3rem;
        margin-bottom: 30px
    }
}

.p-store-blackboard__store {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 -15px
}

.p-store-blackboard__store-item {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
    padding: 0 15px
}

@media (max-width:767px) {
    .p-store-blackboard__store-item {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
        max-width: 100%;
        margin-bottom: 30px
    }

    .p-store-blackboard__store-item:last-child {
        margin-bottom: 0
    }
}

.p-store-blackboard__store-image {
    margin-bottom: 40px
}

@media (max-width:1023px) {
    .p-store-blackboard__store-image {
        margin-bottom: 30px
    }
}

.p-store-blackboard__store-heading {
    font-size: 30px;
    font-size: 3rem;
    font-family: futura-pt, "Helvetica Neue", Helvetica, Arial, sans-serif;
    margin-bottom: 40px
}

@media (max-width:1023px) {
    .p-store-blackboard__store-heading {
        margin-bottom: 30px
    }
}

@media (max-width:767px) {
    .p-store-blackboard__store-heading {
        font-size: 24px;
        font-size: 2.4rem
    }
}

.p-store-blackboard__store-info {
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.8;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

@media (max-width:1023px) {
    .p-store-blackboard__store-info {
        font-size: 12px;
        font-size: 1.2rem
    }
}

.p-store-blackboard__store-info-team {
    font-weight: 500;
    -ms-flex-preferred-size: 75px;
    flex-basis: 75px;
    max-width: 75px;
    margin-right: auto;
    margin-bottom: 5px
}

@media (max-width:1023px) {
    .p-store-blackboard__store-info-team {
        margin-bottom: 4px
    }
}

.p-store-blackboard__store-info-description {
    -ms-flex-preferred-size: calc(100% - 75px);
    flex-basis: calc(100% - 75px);
    max-width: calc(100% - 75px);
    margin-bottom: 5px
}

@media (max-width:1023px) {
    .p-store-blackboard__store-info-description {
        margin-bottom: 4px
    }
}



.box {
    display:flex;
    flex-direction: column;
    padding: 20px;
  }

  .text {
    width: 100%;
/*     text-align: center; */
  }

  h3 {
    font-size: 21px;
    margin: 0;
  }

  .pict {
    width: 100%;
    text-align: center;
    min-height: 0%;
  }

   .text p{
      text-align: left;
      font-size:15px;
    }


  .pict img {
    max-width: 500px;
    height:auto;
    margin-top: 80px;
    width: 100%;
  }
  .box:nth-child(even) {
    /* background-color: #fcf6e4; */
    padding: 20px;
  }

  @media (min-width:768px) {
    body {
      padding: 0px;
    }
    .box {
      flex-direction: row;
      justify-content: space-between;
      margin-bottom: 20px;
      border-bottom: 1px solid #eee;
      padding-top: 80px;
      padding-bottom: 80px;
    }
    .box:nth-child(even) {
      flex-direction: row-reverse;
      padding-bottom: 80px;
      padding-top: 80px;
    }

    .text {
      text-align: left;
    }

    .text h2{
      text-align: left;
    }
      .text p{
      text-align: left;
      font-size:15px;
    }

    .box:nth-child(even) .text {
      text-align: right;
    }
    .pict {
      width: 100%;
    }
    .pict img {
      width: 98%;
      height:auto;
    }
    .box:nth-child(even) .pict {
      margin-left: 0;
      margin-right: 3%;
    }
  }


/*----------------------------------------------------
FAQ
------------------*/
.boxFaq {
    margin: 3em 0;
    background: #ffffff;
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
    width: 50%;
    display: table-cell;
}
.boxFaq .box-title {
    font-size: 1.25em;
    background: #185890;
    padding: 10px;
    text-align: left;
    color: #FFF;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.boxFaq p {
    padding: 5px 20px;
    margin: 5px;
    font-size: 1.15em;
    border-bottom: 1px solid #eee;
}

.boxFaq p span{

  padding: 0 1em;

}


.boxFaq p span a {
  color:#ce0039;
  font-weight:600;
  font-size: 1.1em;

  /* line-height: 30px; */
  text-decoration: dashed;
}
.boxFaq p a:hover {
  border-bottom: 1px dashed #ce0039;
}



.meeting_area{
    display: flex;
    flex-wrap: wrap;
    /* border: 1px solid #eee; */
    padding: 0.2em;
    margin: 0 auto 4em;
    max-width: 1200px;
}

.meeting_box {
    padding: 0.1em;
    /* border-radius: 5px; */
    flex: 0 0 30%;
    margin: 0.4em 0.5%;
    position: relative;
    /* margin: 2em 0; */
    padding: 25px 10px 7px;
    border: solid 2px #FFC107;
    }
.meeting_box .box-title {
    /* FONT-WEIGHT: 600; */
    position: absolute;
    display: inline-block;
    top: -2px;
    left: -2px;
    padding: 0 5px 5px;
    height: 25px;
    line-height: 25px;
    font-size: 16px;
    background: #FFC107;
    color: #ffffff;
    font-weight: 600;
    width: 98%;
}



.meeting_box p {
   margin: 5px;
    padding: 0;
    line-height: 2;
    font-size: 16px;
    border-bottom: 1px dashed #ddd;
}

.meeting_box p:first-child {
}

.meeting_box p:last-child{

    font-size: 16px;
    border-bottom:none;
}



.boxHozon {

	width: calc(100%);
	margin: 0;
	box-sizing:border-box;
	border: 1px solid #ddd;
	border-radius: 5px;
}


.boxHozon .box-title {
	font-size: 18px;
	/* background: #919191; */
	border-bottom: 1px solid #ddd;
	padding: 1em 4px 1em 2.5em;
	text-align: left;
	color: #333;
	font-weight: 600;
	letter-spacing: 0.05em;
	position:relative;
	line-height: 20px;
}

.boxHozon .box-title:before {position:relative;font-family: 'FontAwesome';content: "\f456";font-family: 'Font Awesome 6 pro';position: absolute;left: 0.5em;color: #222222;font-size: 25px;font-weight: 400;}


.boxHozon p {
	padding: 15px 20px;
}

.boxHozon ul {
    padding: 0em 0;
    /* width: 46%; */
    width: calc(100%);
    align-items: stretch;
    flex-direction: row;
    margin: 0;
}

.boxHozon_li-line{
	border-bottom: none;
}

.boxHozon li {
	line-height: 1.5;
	padding: 1em 2em 1em 1em;
	border-bottom: dashed 1px silver;
	list-style-type: none!important;
	font-size: 16px;
	margin: 0em 0em;
	font-weight: 400;
}

.boxHozon ul:last-child {
    margin-bottom:1em;
}





@media only screen and (min-width: 1000px) {
.boxHozon {
	width: calc(100%);
	margin-bottom: 20px;
	margin: 0 0 20px;
}

.boxHozon ul {
    padding: 1em 0 2em;
    /* width: 46%; */
    /* width: calc(100% / 3); */
    align-items: stretch;
    flex-direction: row;
}


.boxHozon li {
	line-height: 1.5;
	padding: 1em 2em 1em 1em;
	border-bottom: dashed 1px silver;
	list-style-type: none!important;
	font-size: 16px;
	margin: 0em 0.5em;
	font-weight: 400;
}

.boxHozon li:last-child{
/* 	border-bottom: none; */
}


}









.boxHozon li:before {
	font-family: "FontAwesome";
	font-family: 'Font Awesome 6 pro';
	content: "\f058";
	position: relative;
	left: 0;
	color: #222222;
	padding-right: 10px;
}


.boxHozon p{
	border: 0px solid #9E9E9E;
	/* 	border-radius: 5px; */
	padding: 20px;
	background: #efefef;
	font-size: 18px;
	font-weight: 400;
	margin-top: 0;
}

.squareTxt{
	border: 0px solid #9E9E9E;
	/* 	border-radius: 5px; */
	padding: 20px;
	background: #dde6e7;
	font-size: 18px;
	font-weight: 400;
	margin-top: 0;
}


.service_catch{
    display:flex;
    flex-wrap:wrap;
    align-items: center;
}

.catch_txt{width:60%;font-size: 23px;}
.catch_img{width:36%;padding:2%;text-align: center;}
.catch_img img{width:80%;margin:0 auto;}

.service_area{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    margin: 10px;
}


.salon_area {
  margin-top: 40px;
  font-family: "ヒラギノ明朝 Pro W3","Hiragino Mincho Pro","Yu Mincho",YuMincho,"游明朝","ＭＳ Ｐ明朝","MS PMincho","Times New Roman",Times,Garamond,Georgia,serif;
}
.inner  {
  max-width: 1140px;
  padding: 0 20px;
  margin: 0 auto;
}
.salon_title {
  text-align: center;
  margin-top: 40px;
  color: #555;
  font-size: 20px;
  font-weight: 100;
}
.menu_item {
  margin: 80px 0;
}
.row_reverse {
  flex-direction: row-reverse;
}
.row_reverse .menu_flex_img {
  margin-right: 0;
  margin-left: 2%;
}
.menu_flex {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.face {
  align-items: center;
}
.face_box {
  margin-top: 40px;
}
.menu_box {
  /* margin-top: 40px; */
}
.menu_flex_img {
  width: 55%;
  margin-right: 2%;
}

.menu_flex_img {
  width: 40%;
  margin-right: 2%;
}


.menu_flex_text {
  width: 55%;
}
.face .menu_flex_img {
  width: 65%;
  margin-left: 2%;
}
.face .menu_flex_text {
  width: 34%;
}
.menu_icon {
  width: 180px;
  margin: 0 auto 22px;
}
.menu_box {
  border: 1px solid #9e9e9e;
  padding: 30px 20px 20px;
}
.con_enj .menu_title {
  text-align: center;
  margin-bottom: 40px;
  font-size: 22px;
  letter-spacing: 0.1em;
  color: #fff;
}
.con_enj .menu_title::before {
  content: none;
}
.menu_list {
  font-size: 17px;
  padding-bottom: 10px;
  color: #555;
  border-bottom: 1px solid #555;
  margin-top: 20px;
}
.face_box .menu_list:first-of-type {
  margin-top: 0;
}
.menu_text {
  font-size: 17px;
  margin-top: 20px;
  color: #555;
  line-height: 2;
}
.menu_list:last-of-type {
  border-bottom: none;
}
.border_box {
  text-align: center;
}
.border_icon img {
  width: 80%;
  margin: 0 auto;
}
.border_icon {
  margin: 0 auto;
  text-align: center;
}

@media only screen and (max-width:768px) {
  .salon_title {
    text-align: center;
    margin-top: 40px;
    /* color: #fff; */
  }
  .menu_item {
    margin: 50px 0;
  }
  .row_reverse .menu_flex_img {
    margin: 0;
  }
  .menu_flex {
    display: block;
  }
  .face {
    align-items: center;
  }
  .menu_flex_img {
    width: 100%;
    margin-right: 0;
  }
  .menu_flex_text {
    width: 100%;
    margin-top: 30px;
  }
  .face .menu_flex_img {
    width: 100%;
    margin-left: 0;
  }
  .face .menu_flex_text {
    width: 100%;
  }
  .menu_icon {
    width: 160px;
    margin: 0 auto 20px;
  }
  .face_box {
    margin-top: 0px;
  }
  .menu_box {
    /* border: 1px solid #fff; */
    padding: 30px 20px 20px;
  }
  .con_enj .menu_title {
    text-align: center;
    margin-bottom: 40px;
    font-size: 20px;
    line-height: 1.8;
    letter-spacing: 0.1em;
    color: #fff;
  }
  .menu_list {
    font-size: 15px;
    padding-bottom: 10px;
    color: #fff;
    border-bottom: 1px solid #fff;
    margin-top: 20px;
  }
  .menu_text {
    font-size: 17px;
    margin-top: 20px;
    /* color: #fff; */
    line-height: 2;
  }
  .menu_list:last-of-type {
    border-bottom: none;
  }
  .border_icon img {
    width: 100%;
    margin: 0 auto;
  }
}

/* -----------------------------------------------------------
   #service_este
   ----------------------------------------------------------- */

   #service_este {
    padding: 90px 3%;
    /* background: url(../images/common/noise.png) repeat #f5f5f5; */
    width: 100%;
    background: #fff8f8;
    /* max-width: 1300px; */
    margin: 0 auto;
}

@media only screen and (max-width: 900px) {
    #service_este {
        padding: 80px 5%;
    }
}

@media only screen and (max-width: 736px) {
    #service_este {
        padding: 70px 5%;
    }
}

@media only screen and (max-width: 500px) {
    #service_este {
        padding: 70px 8%;
    }
}




/* --------- .flowArea --------- */

#service_este .flowArea {
  margin: -10px;
  font-size: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 1200px;
  margin: 0 auto;
}

#service_este .flowBox {
  /* display: inline-block; */
  margin: 0;
  border: #fff8f8 10px solid;
  width: 33.333%;
  text-align: center;
  /* position: relative; */
  z-index: 2;
  padding: 0%;
  background: #fff;
  /* flex: 1 0 33.3333%; */
}


/* .inner */

#service_este .flowBox .inner {
  padding: 35px 5% 50px;
  /* background: #fefefe; */
}

#service_este .flowBox .inner img{
width:100%;
}




/* h3 */

#service_este .flowBox h3 {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 1px;
  position: relative;
  z-index: 3;
  line-height: 1;
  padding: 15px 0 15px;
  text-align: center;
}


#service_este .flowBox h3:before {
  font-family: 'Font Awesome 6 pro';
  padding-right:10px;
  font-size:20px;
  color: #141414;
}



#service_este .flowBox h3:before{
content: "\f06c";
}





#service_este .flowBox h3:before {

/*     width: 1200px;
  height: 60px;
  line-height: 62px;
  color: #fefefe;
  font-size: 25px;
  background: #167c3b;
border-radius:50%; */
}


/*



#service_este .flowBox:nth-child(1) h3:before {
  content:'\f70c';

}

#service_este .flowBox:nth-child(2) h3:before {

    content:'\f469';
}

#service_este .flowBox:nth-child(3) h3:before {
  content: "\e458";
}

#service_este .flowBox:nth-child(4) h3:before {
  content: "\e021";
}

#service_este .flowBox:nth-child(5) h3:before {
  content: "\f259";
}

#service_este .flowBox:nth-child(6) h3:before {
  content: "\f7f2";
}


 */




#service_este .flowBox h3:after {
  position: absolute;
  bottom: 0;
  left: 25px;
  right: 25px;
  height: 0;
  content: "";
  border-top: #e5e8ef 1px solid;
  z-index: 2;
}


/* .txtArea */

#service_este .flowArea .txtArea {
  display: inline-block;
  margin: 20px auto 0;
}
#service_este .flowArea .txtArea img {
width:100%;
}

@media only screen and (max-width: 900px) {
  #service_este .flowBox .inner {
      padding: 30px 5% 45px;
  }
  #service_este .flowBox h3 {
      font-size: 16px;
      padding: 55px 0 30px;
  }
  #service_este .flowBox h3:before {
      /* margin-left: -20px; */
      width: 40px;
      height: 40px;
      line-height: 42px;
      font-size: 20px;
  }
  #service_este .flowBox h3:after {
      left: 5%;
      right: 5%;
  }
}

@media only screen and (max-width: 768px) {
  #service_este .flowBox {
      width: 50%;
  }
}

@media only screen and (max-width: 736px) {
  #service_este .flowArea {
    flex-direction:column;
  }
  #service_este .flowBox {
      display: block;
      margin-top: 50px;
      border: none;
      width: 100%;
      text-align: center;
  }

  #service_este .flowBox:last-child:after {
      display: none;
  }
  /* .inner */
  #service_este .flowBox .inner {
      padding: 35px 5%;
      /* border: #e5e8ef 1px solid; */
  }

 /* h3 */
  #service_este .flowBox h2 {
      font-size: 18px;
      padding: 0px 0 25px;
      text-align: center;
      font-family: "Century Gothic", sans-serif;
      font-weight: 500;
  }


  /* h3 */
  #service_este .flowBox h3 {
      font-size: 18px;
      padding: 0px 0 25px;
      text-align: center;
      line-height: 1.5;
  }
  #service_este .flowBox h3:after {
      border-top: #e5e8ef 1px dotted
  }
  #service_este .flowArea .txtArea {
      margin: 15px auto 0;
/*         font-size: 15px;
      text-align: left; */
  }


}


/* -----------------------------------------------------------
   #service_education
   ----------------------------------------------------------- */

   #service_education {
    padding: 90px 3%;
    /* background: url(../images/common/noise.png) repeat #f5f5f5; */
    width: 100%;
    background: #fff8f8;
    /* max-width: 1300px; */
    margin: 0 auto;
}

@media only screen and (max-width: 900px) {
    #service_education {
        padding: 80px 5%;
    }
}

@media only screen and (max-width: 736px) {
    #service_education {
        padding: 70px 5%;
    }
}

@media only screen and (max-width: 500px) {
    #service_education {
        padding: 70px 8%;
    }
}




/* --------- .flowArea --------- */

#service_education .flowArea {
  margin: -10px;
  font-size: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 1200px;
  margin: 0 auto;
}

#service_education .flowBox {
  /* display: inline-block; */
  margin: 0;
  border: #fff8f8 10px solid;
  width: 50%;
  text-align: center;
  /* position: relative; */
  z-index: 2;
  padding: 0%;
  background: #fff;
  /* flex: 1 0 33.3333%; */
}


/* .inner */

#service_education .flowBox .inner {
  padding: 35px 5% 50px;
  /* background: #fefefe; */
}

#service_education .flowBox .inner img{
width:100%;
}




/* h3 */

#service_education .flowBox h3 {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 1px;
  position: relative;
  z-index: 3;
  line-height: 1;
  padding: 15px 0 15px;
  text-align: center;
}


#service_education .flowBox h3:before {
  font-family: 'Font Awesome 6 pro';
  padding-right:10px;
  font-size:20px;
  color: #141414;
}



#service_education .flowBox h3:before{
content: "\f06c";
}





#service_education .flowBox h3:before {
}


#service_education .flowBox h3:after {
  position: absolute;
  bottom: 0;
  left: 25px;
  right: 25px;
  height: 0;
  content: "";
  border-top: #e5e8ef 1px solid;
  z-index: 2;
}


/* .txtArea */

#service_education .flowArea .txtArea {
  display: inline-block;
  margin: 20px auto 0;
}
#service_education .flowArea .txtArea img {
width:100%;
}

@media only screen and (max-width: 900px) {
  #service_education .flowBox .inner {
      padding: 30px 5% 45px;
  }
  #service_education .flowBox h3 {
      font-size: 16px;
      padding: 55px 0 30px;
  }
  #service_education .flowBox h3:before {
      /* margin-left: -20px; */
      width: 40px;
      height: 40px;
      line-height: 42px;
      font-size: 20px;
  }
  #service_education .flowBox h3:after {
      left: 5%;
      right: 5%;
  }
}

@media only screen and (max-width: 768px) {
  #service_education .flowBox {
      width: 50%;
  }
}

@media only screen and (max-width: 736px) {
  #service_education .flowArea {
    flex-direction:column;
  }
  #service_education .flowBox {
      display: block;
      margin-top: 50px;
      border: none;
      width: 100%;
      text-align: center;
  }

  #service_education .flowBox:last-child:after {
      display: none;
  }
  /* .inner */
  #service_education .flowBox .inner {
      padding: 35px 5%;
      /* border: #e5e8ef 1px solid; */
  }

 /* h3 */
  #service_education .flowBox h2 {
      font-size: 18px;
      padding: 0px 0 25px;
      text-align: center;
      font-family: "Century Gothic", sans-serif;
      font-weight: 500;
  }


  /* h3 */
  #service_education .flowBox h3 {
      font-size: 18px;
      padding: 0px 0 25px;
      text-align: center;
      line-height: 1.5;
  }
  #service_education .flowBox h3:after {
      border-top: #e5e8ef 1px dotted
  }
  #service_education .flowArea .txtArea {
      margin: 15px auto 0;
/*         font-size: 15px;
      text-align: left; */
  }
}

/* 2023.1127 追加 */

/**********
** menu-box
***********************************/

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

.menu-box__title {
  font-size: clamp(30px, 26.479px + 0.939vw, 40px);
  font-weight: bold;
}

.menu-box__sub-title {
  font-size: clamp(14px, 13.296px + 0.188vw, 16px);
}

.menu-box__content {
  margin-top: 30px;
  display: grid;
  row-gap: 30px;
}

@media(min-width: 768px) {
  .menu-box {
    margin-top: 100px;
  }
  
  .menu-box__content {
    margin-top: 60px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 80px;
    row-gap: 40px;
  }
}

/**********
** menu
***********************************/

.menu__head {
  padding: 10px 0;
  border-top: 1px solid;
  border-bottom: 1px solid;
  display: flex;
  align-items: center;
  gap: 20px;
}

.menu__title {
  font-size: clamp(16px, 14.592px + 0.376vw, 20px);
  text-transform: uppercase;
}

.menu__title-jp {
  font-size: clamp(14px, 13.296px + 0.188vw, 16px);
  margin-bottom: 0;
}

.menu__list {
  margin-top: 40px;
}

.menu__item:nth-child(n+2) {
  margin-top: 20px;
}

.menu__btn {
  margin-top: 20px;
  text-align: center;
}

@media(min-width: 768px) {
  .menu__btn {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    height: 100%;
    margin-top: 0;
  }
}

/**********
** menu-item
***********************************/

.menu-item {
  display: flex;
}

.menu-item__yen {
  margin-left: auto;
  padding-left: 10px;
  text-align: right;
}

/**********
** link-btn
***********************************/

.link-btn {
  font-size: 16px;
  display: inline-block;
  min-width: 240px;
  padding: 6px;
  background-color: #e9e6e0;
  border-radius: 20px;
  text-align: center;
}
