#main {
  padding: 0;
  background-color: #000;
  color: #fff;
}

#main h1,
#main h2,
#main h3,
#main h4,
#main h5 {
  color: #fff;
  border: 0 none;
  padding: 0;
  margin: 0;
}

#main .row {
  max-width: none;
  width: 100%;
}

#main .column {
  padding: 0;
}

#main figure,
#main p,
#main dl,
#main dt,
#main dd {
  margin: 0;
  float: none;
  padding: 0;
}

#necessaireDeBeaute {
  letter-spacing: 0.05em;
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .pc_hide {
    display: none;
  }
}

@media screen and (min-width: 1261px) {
  #necessaireDeBeaute .pc_hide2 {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .sp_hide {
    display: none;
  }
}

#necessaireDeBeaute .content_inner {
  position: relative;
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .content_inner {
    margin: 0 40px;
  }
}

@media screen and (min-width: 1261px) {
  #necessaireDeBeaute .content_inner {
    max-width: 1220px;
    margin: auto;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .content_inner {
    padding: 0 calc(40 / 750 * 100vw);
  }
}

#necessaireDeBeaute .kv {
  text-align: center;
  background-color: #fff;
}

#necessaireDeBeaute .kv img,
#necessaireDeBeaute .kv picture {
  display: inline-block;
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .kv h1 span {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .kv {
    background: url(../images/necessaire-de-beaute/kv_sp.png) no-repeat center top;
    background-size: 100%;
    padding-top: 100vw;
    position: relative;
  }

  #necessaireDeBeaute .kv h1 {
    padding-top: calc(160 / 750 * 100vw);
  }

  #necessaireDeBeaute .kv h1 img {
    width: calc(559 / 750 * 100vw);
  }

  #necessaireDeBeaute .kv h1 span {
    display: inline-block;
    font-size: 14px;
    margin-top: 20px;
  }
}

#necessaireDeBeaute .introduction {
  text-align: center;
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .introduction {
    padding: 120px 0;
  }

  #necessaireDeBeaute .introduction h2 {
    font-size: 28px;
    font-weight: bold;
    margin-bottom: 60px;
  }

  #necessaireDeBeaute .introduction .catch {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 40px;
  }

  #necessaireDeBeaute .introduction .message {
    font-size: 16px;
    line-height: 2.85;
  }

  #necessaireDeBeaute .introduction .beaute_img {
    width: 376px;
    border: solid 1px #555;
    margin: 120px auto 0;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .introduction {
    padding: calc(120 / 750 * 100vw) 0 calc(160 / 750 * 100vw);
  }

  #necessaireDeBeaute .introduction h2 {
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 30px;
  }

  #necessaireDeBeaute .introduction .catch {
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 20px;
  }

  #necessaireDeBeaute .introduction .message {
    font-size: 14px;
    line-height: 2.85;
  }

  #necessaireDeBeaute .introduction .beaute_img {
    width: calc(536 / 750 * 100vw);
    border: solid 1px #555;
    margin: calc(100 / 750 * 100vw) auto 0;
  }
}

#necessaireDeBeaute .banner .bnr_lip {
  border-top: solid 1px #555;
}

#necessaireDeBeaute .banner .bnr_lip a {
  display: block;
  position: relative;
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .banner .bnr_lip a {
    background: url(../images/necessaire-de-beaute/bnr_lip.jpg) no-repeat center center;
    background-size: cover;
    height: 410px;
  }

  #necessaireDeBeaute .banner .bnr_lip a span {
    display: flex;
    width: calc(290 / 1260 * 100vw);
    height: calc(290 / 1260 * 100vw);
    align-items: center;
    justify-content: center;
    border: solid 1px #555;
    font-size: 18px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translateY(-50%);
    margin-left: calc(180 / 1260 * 100vw);
    opacity: 1;
  }

  #necessaireDeBeaute .banner .bnr_lip a span img {
    width: 44px;
  }

  #necessaireDeBeaute .banner .bnr_lip a:hover span {
    opacity: 0.6;
  }
}

@media screen and (min-width: 1261px) {
  #necessaireDeBeaute .banner .bnr_lip a {
    margin: auto;
  }

  #necessaireDeBeaute .banner .bnr_lip a span {
    width: 290px;
    height: 290px;
    margin-left: 180px;
  }

  #necessaireDeBeaute .banner .bnr_lip a span img {
    width: 44px;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .banner .bnr_lip a {
    background: url(../images/necessaire-de-beaute/bnr_lip_sp.jpg) no-repeat center center;
    background-size: cover;
    height: calc(540 / 750 * 100vw);
  }

  #necessaireDeBeaute .banner .bnr_lip a span {
    display: flex;
    width: calc(380 / 750 * 100vw);
    height: calc(380 / 750 * 100vw);
    align-items: center;
    justify-content: center;
    border: solid 1px #555;
    font-size: 16px;
    position: absolute;
    right: calc(40 / 750 * 100vw);
    top: 50%;
    transform: translateY(-50%);
  }

  #necessaireDeBeaute .banner .bnr_lip a span img {
    width: calc(61 / 750 * 100vw);
  }
}

#necessaireDeBeaute .banner .bnr_face {
  border-top: solid 1px #555;
}

#necessaireDeBeaute .banner .bnr_face a {
  display: block;
  position: relative;
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .banner .bnr_face a {
    background: #fff url(../images/necessaire-de-beaute/bnr_face.png) no-repeat center center;
    background-size: cover;
    height: 410px;
  }

  #necessaireDeBeaute .banner .bnr_face a span {
    display: flex;
    width: calc(290 / 1260 * 100vw);
    height: calc(290 / 1260 * 100vw);
    align-items: center;
    justify-content: center;
    border: solid 1px #555;
    font-size: 18px;
    position: absolute;
    right: 50%;
    top: 50%;
    transform: translateY(-50%);
    margin-right: calc(180 / 1260 * 100vw);
    opacity: 1;
  }

  #necessaireDeBeaute .banner .bnr_face a span img {
    width: 75px;
  }

  #necessaireDeBeaute .banner .bnr_face a:hover span {
    opacity: 0.6;
  }
}

@media screen and (min-width: 1261px) {
  #necessaireDeBeaute .banner .bnr_face a {
    margin: auto;
  }

  #necessaireDeBeaute .banner .bnr_face a span {
    width: 290px;
    height: 290px;
    margin-right: 180px;
  }

  #necessaireDeBeaute .banner .bnr_face a span img {
    width: 75px;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .banner .bnr_face a {
    background: #fff url(../images/necessaire-de-beaute/bnr_face_sp.png) no-repeat center center;
    background-size: cover;
    height: calc(540 / 750 * 100vw);
  }

  #necessaireDeBeaute .banner .bnr_face a span {
    display: flex;
    width: calc(380 / 750 * 100vw);
    height: calc(380 / 750 * 100vw);
    align-items: center;
    justify-content: center;
    border: solid 1px #555;
    font-size: 16px;
    position: absolute;
    left: calc(40 / 750 * 100vw);
    top: 50%;
    transform: translateY(-50%);
  }

  #necessaireDeBeaute .banner .bnr_face a span img {
    width: calc(105 / 750 * 100vw);
  }
}

#necessaireDeBeaute .banner .bnr_eye {
  border-top: solid 1px #555;
}

#necessaireDeBeaute .banner .bnr_eye a {
  display: block;
  position: relative;
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .banner .bnr_eye a {
    background: #fff url(../images/necessaire-de-beaute/bnr_eye.png) no-repeat center center;
    background-size: cover;
    height: 410px;
  }

  #necessaireDeBeaute .banner .bnr_eye a span {
    display: flex;
    width: calc(290 / 1260 * 100vw);
    height: calc(290 / 1260 * 100vw);
    align-items: center;
    justify-content: center;
    border: solid 1px #555;
    font-size: 18px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translateY(-50%);
    margin-left: calc(180 / 1260 * 100vw);
    opacity: 1;
  }

  #necessaireDeBeaute .banner .bnr_eye a span img {
    width: 53px;
  }

  #necessaireDeBeaute .banner .bnr_eye a:hover span {
    opacity: 0.6;
  }
}

@media screen and (min-width: 1261px) {
  #necessaireDeBeaute .banner .bnr_eye a {
    margin: auto;
  }

  #necessaireDeBeaute .banner .bnr_eye a span {
    width: 290px;
    height: 290px;
    margin-left: 180px;
  }

  #necessaireDeBeaute .banner .bnr_eye a span img {
    width: 53px;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .banner .bnr_eye a {
    background: #fff url(../images/necessaire-de-beaute/bnr_eye_sp.png) no-repeat center center;
    background-size: cover;
    height: calc(540 / 750 * 100vw);
  }

  #necessaireDeBeaute .banner .bnr_eye a span {
    display: flex;
    width: calc(380 / 750 * 100vw);
    height: calc(380 / 750 * 100vw);
    align-items: center;
    justify-content: center;
    border: solid 1px #555;
    font-size: 16px;
    position: absolute;
    right: calc(40 / 750 * 100vw);
    top: 50%;
    transform: translateY(-50%);
  }

  #necessaireDeBeaute .banner .bnr_eye a span img {
    width: calc(74 / 750 * 100vw);
  }
}

#necessaireDeBeaute .banner .bnr_nail {
  border-top: solid 1px #555;
}

#necessaireDeBeaute .banner .bnr_nail a {
  display: block;
  position: relative;
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .banner .bnr_nail a {
    background: #fff url(../images/necessaire-de-beaute/bnr_nail.png) no-repeat center center;
    background-size: cover;
    height: 410px;
  }

  #necessaireDeBeaute .banner .bnr_nail a span {
    display: flex;
    width: calc(290 / 1260 * 100vw);
    height: calc(290 / 1260 * 100vw);
    align-items: center;
    justify-content: center;
    border: solid 1px #555;
    font-size: 18px;
    position: absolute;
    right: 50%;
    top: 50%;
    transform: translateY(-50%);
    margin-right: calc(180 / 1260 * 100vw);
    opacity: 1;
  }

  #necessaireDeBeaute .banner .bnr_nail a span img {
    width: 66px;
  }

  #necessaireDeBeaute .banner .bnr_nail a:hover span {
    opacity: 0.6;
  }
}

@media screen and (min-width: 1261px) {
  #necessaireDeBeaute .banner .bnr_nail a {
    margin: auto;
  }

  #necessaireDeBeaute .banner .bnr_nail a span {
    width: 290px;
    height: 290px;
    margin-right: 180px;
  }

  #necessaireDeBeaute .banner .bnr_nail a span img {
    width: 66px;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .banner .bnr_nail a {
    background: #fff url(../images/necessaire-de-beaute/bnr_nail_sp.png) no-repeat center center;
    background-size: cover;
    height: calc(540 / 750 * 100vw);
  }

  #necessaireDeBeaute .banner .bnr_nail a span {
    display: flex;
    width: calc(380 / 750 * 100vw);
    height: calc(380 / 750 * 100vw);
    align-items: center;
    justify-content: center;
    border: solid 1px #555;
    font-size: 16px;
    position: absolute;
    left: calc(40 / 750 * 100vw);
    top: 50%;
    transform: translateY(-50%);
  }

  #necessaireDeBeaute .banner .bnr_nail a span img {
    width: calc(93 / 750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .banner .btn_all {
    margin: 80px auto;
    width: 300px;
  }

  #necessaireDeBeaute .banner .btn_all a {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #fff;
    width: 100%;
    padding: 1em 0;
    opacity: 1;
  }

  #necessaireDeBeaute .banner .btn_all a span {
    color: #000;
  }

  #necessaireDeBeaute .banner .btn_all a:hover {
    opacity: 0.6;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .banner .btn_all {
    margin: calc(80 / 750 * 100vw) auto;
    width: calc(590 / 750 * 100vw);
  }

  #necessaireDeBeaute .banner .btn_all a {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #fff;
    width: 100%;
    padding: 1em 0;
  }

  #necessaireDeBeaute .banner .btn_all a span {
    color: #000;
  }
}

@media screen and (min-width: 768px) {
  #necessaireDeBeaute .shops {
    margin: 160px 0 120px;
  }

  #necessaireDeBeaute .shops h2 {
    font-size: 28px;
    text-align: center;
    margin-bottom: 30px;
  }

  #necessaireDeBeaute .shops .lead {
    text-align: center;
    font-size: 16px;
  }

  #necessaireDeBeaute .shops .note {
    margin-top: 24px;
    text-align: center;
    font-size: 12px;
    color: #999;
  }

  #necessaireDeBeaute .shops .shop_list {
    margin-top: 74px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  #necessaireDeBeaute .shops .shop_list dl {
    width: calc(580 / 1340 * 100vw);
    border-top: solid 1px #555;
    padding-top: 20px;
  }

  #necessaireDeBeaute .shops .shop_list dl:nth-child(n + 3) {
    margin-top: 60px;
  }

  #necessaireDeBeaute .shops .shop_list dl dt {
    font-size: 16px;
    margin-bottom: 36px;
  }

  #necessaireDeBeaute .shops .shop_list dl dd .map {
    margin-top: 20px;
  }

  #necessaireDeBeaute .shops .shop_list dl dd .map a {
    display: flex;
    width: 140px;
    height: 30px;
    justify-content: center;
    align-items: center;
    border: solid 1px #fff;
    opacity: 1;
  }

  #necessaireDeBeaute .shops .shop_list dl dd .map a:hover {
    opacity: 0.6;
  }

  #necessaireDeBeaute .shops .shop_list dl dd .map a span {
    color: #fff;
  }
}

@media screen and (min-width: 1261px) {
  #necessaireDeBeaute .shops .shop_list dl {
    width: 580px;
  }

  #necessaireDeBeaute .shops .shop_list dl:nth-child(n + 3) {
    margin-top: 60px;
  }
}

@media screen and (max-width: 767px) {
  #necessaireDeBeaute .shops {
    margin: calc(240 / 750 * 100vw) 0 calc(160 / 750 * 100vw);
  }

  #necessaireDeBeaute .shops h2 {
    font-size: 23px;
    text-align: center;
    margin-bottom: calc(50 / 750 * 100vw);
  }

  #necessaireDeBeaute .shops .lead {
    text-align: center;
    font-size: 14px;
  }

  #necessaireDeBeaute .shops .note {
    margin-top: calc(30 / 750 * 100vw);
    text-align: center;
    font-size: 12px;
    color: #999;
  }

  #necessaireDeBeaute .shops .shop_list {
    margin-top: calc(120 / 750 * 100vw);
  }

  #necessaireDeBeaute .shops .shop_list dl {
    border-top: solid 1px #555;
    padding-top: calc(40 / 750 * 100vw);
  }

  #necessaireDeBeaute .shops .shop_list dl + dl {
    margin-top: 60px;
  }

  #necessaireDeBeaute .shops .shop_list dl dt {
    font-size: 14px;
    margin-bottom: 35px;
  }

  #necessaireDeBeaute .shops .shop_list dl dd {
    padding: 0 calc(20 / 750 * 100vw);
  }

  #necessaireDeBeaute .shops .shop_list dl dd .map {
    margin-top: calc(30 / 750 * 100vw);
  }

  #necessaireDeBeaute .shops .shop_list dl dd .map a {
    display: flex;
    width: calc(280 / 750 * 100vw);
    height: 40px;
    justify-content: center;
    align-items: center;
    border: solid 1px #fff;
    opacity: 1;
  }

  #necessaireDeBeaute .shops .shop_list dl dd .map a:hover {
    opacity: 0.6;
  }

  #necessaireDeBeaute .shops .shop_list dl dd .map a span {
    color: #fff;
    font-size: 12px;
  }
}
