@charset "UTF-8";
@import url(common.css);
body {
  background: url("../images/back-fixed.jpg") no-repeat fixed top center/cover; }

main {
  padding-top: 60px; }
  @media screen and (max-width: 540px) {
    main {
      padding-top: 0; } }

/* フッター
---------------------------------------------------------------------------- */
footer {
  width: 100%;
  max-width: 540px;
  margin: 0 auto;
  text-align: center;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-size: clamp(0.938rem, 0.665rem + 1.36vw, 1.125rem);
  padding: 60px 0;
  background-color: #fafafa; }
  @media screen and (max-width: 540px) {
    footer {
      padding: 11.112% 0; } }
  footer .footer-inner {
    margin-bottom: 1.25em; }
  footer .footer-link {
    margin-bottom: 0.5em; }
  footer .copyright {
    font-size: clamp(0.75rem, 0.673rem + 0.38vw, 0.813rem);
    color: #727272; }

/* section
---------------------------------------------------------------------------- */
section {
  width: 100%;
  max-width: 540px;
  margin: 0 auto; }

/* メインビジュアル
---------------------------------------------------------------------------- */
.mainvisual {
  position: relative;
  width: 100%; }
  .mainvisual .firstview {
    border-radius: 50px 50px 0 0;
    overflow: hidden; }
    @media screen and (max-width: 540px) {
      .mainvisual .firstview {
        border-radius: 0; } }
  .mainvisual .badge {
    position: absolute;
    left: 16px;
    bottom: -24px;
    width: 508px; }
    @media screen and (max-width: 540px) {
      .mainvisual .badge {
        left: 2.962%;
        bottom: -2.75%;
        width: 94.074%; } }

/* cta
---------------------------------------------------------------------------- */
.cta {
  padding: 30px 0;
  background-color: #fff6a7; }
  @media screen and (max-width: 540px) {
    .cta {
      padding: 5.556% 0; } }
  .cta-text {
    width: 89.63%;
    max-width: 484px;
    margin: 8px auto 15px; }
    @media screen and (max-width: 540px) {
      .cta-text {
        margin: 1.5% auto 2.78%; } }
  .cta-btn {
    display: block;
    width: 87.777%;
    max-width: 474px;
    margin: 0 auto; }

/* こんなお悩みありませんか
---------------------------------------------------------------------------- */
.worries-first {
  position: relative;
  background-color: #f8f8f8; }
  .worries-first-female {
    position: absolute;
    bottom: -23.5%;
    right: 28.704%;
    width: 38.333%; }
  .worries-first::before {
    content: "";
    position: absolute;
    right: 0;
    bottom: -18.8%;
    width: 100%;
    height: 18.8%;
    background: url("../images/worries-triangle.png") no-repeat top center/contain; }
.worries-second {
  position: relative;
  background-color: #eef0f9;
  z-index: -1; }
.worries-third {
  background-color: #dde3e7; }

/* PRODUCT
---------------------------------------------------------------------------- */
.product {
  padding: 50px 0; }
  @media screen and (max-width: 540px) {
    .product {
      padding: 9.26% 0; } }
  .product-cleansing {
    background-color: #f9f9f9; }
  .product-toner {
    background-color: #f6f6f7; }
  .product-wrap {
    padding: 0 34px; }
    @media screen and (max-width: 540px) {
      .product-wrap {
        padding: 0 6.2975%; } }
  .product-feature {
    margin-bottom: 50px; }
    @media screen and (max-width: 540px) {
      .product-feature {
        margin-bottom: 10.595%; } }

/* 開発
---------------------------------------------------------------------------- */
.development {
  background-color: #ffd8da; }
  .development-photo {
    position: relative;
    z-index: 10; }
    .development-photo .badge {
      position: absolute;
      left: 16px;
      bottom: -90px;
      width: 508px; }
      @media screen and (max-width: 540px) {
        .development-photo .badge {
          left: 2.962%;
          bottom: -20.065%;
          width: 94.074%; } }

/* お喜びの声
---------------------------------------------------------------------------- */
.customer {
  background-color: #e9e4df; }

/* 特別なご案内
---------------------------------------------------------------------------- */
.cta-special {
  position: relative; }
  .cta-special-text {
    position: absolute;
    left: 28px;
    bottom: 291px;
    width: 89.63%;
    max-width: 484px; }
    @media screen and (max-width: 540px) {
      .cta-special-text {
        left: 5.185%;
        bottom: 30.25%; } }
  .cta-special-btn {
    position: absolute;
    left: 34px;
    bottom: 170px;
    width: 87.78%;
    max-width: 474px; }
    @media screen and (max-width: 540px) {
      .cta-special-btn {
        left: 6.112%;
        bottom: 17.5%;
        width: 87.78%; } }

/* よくある質問
---------------------------------------------------------------------------- */
.faq {
  padding: 80px 0 34px;
  background-color: #ffffff; }
  @media screen and (max-width: 540px) {
    .faq {
      padding: 6.37% 0 2.71%; } }
  .faq .sec-ttl {
    font-weight: 600;
    text-align: center;
    margin-bottom: 36px;
    font-size: clamp(1.75rem, 0.568rem + 5.91vw, 2.563rem);
    line-height: 1em; }
    @media screen and (max-width: 540px) {
      .faq .sec-ttl {
        margin-bottom: 7.5%; } }
  .faq-wrap {
    padding: 0 6.2975%; }
    .faq-wrap .accordion_one {
      margin-bottom: 3.39%;
      overflow: hidden; }
      .faq-wrap .accordion_one .ac_header {
        background-color: #e5f5fd;
        padding: 4.45% 37px 4.45% 4.2375%;
        position: relative;
        z-index: +1;
        cursor: pointer;
        transition: .2s; }
        .faq-wrap .accordion_one .ac_header:not(.open):hover {
          background-color: #d0f0ff; }
        .faq-wrap .accordion_one .ac_header .i_box {
          position: absolute;
          top: 50%;
          right: 3%;
          width: 22px;
          height: 22px;
          margin-top: -11px; }
          .faq-wrap .accordion_one .ac_header .i_box:before, .faq-wrap .accordion_one .ac_header .i_box:after {
            position: absolute;
            content: "";
            margin: auto;
            box-sizing: border-box;
            vertical-align: middle; }
          .faq-wrap .accordion_one .ac_header .i_box:before {
            border-top: 2px solid #1991cf;
            width: 22px;
            height: 0;
            top: 0;
            bottom: 0;
            right: 0; }
          .faq-wrap .accordion_one .ac_header .i_box:after {
            border-left: 2px solid #1991cf;
            width: 0;
            height: 22px;
            top: 0;
            bottom: 0;
            right: 10px;
            transition: .3s; }
        .faq-wrap .accordion_one .ac_header.open .i_box:after {
          transform: rotate(90deg); }
      .faq-wrap .accordion_one .ac_inner {
        position: relative;
        display: none;
        padding: 4.45% 5% 6% 4.2375%;
        box-sizing: border-box;
        background: #fff;
        color: #000; }
    .faq-wrap .p-faq__headinner {
      display: block;
      padding-left: 9.25%;
      position: relative;
      line-height: 1; }
      .faq-wrap .p-faq__headinner::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0.2em;
        width: 5.325%;
        height: 23px;
        background: url("../images/faq-q.png") no-repeat top center/contain; }
      .faq-wrap .p-faq__headinner p.p-faq__q-txt {
        font-size: clamp(0.938rem, 0.483rem + 2.27vw, 1.25rem);
        letter-spacing: 0.02em;
        line-height: 1.5em; }
    .faq-wrap .p-faq__bodyinner {
      display: block;
      padding-left: 9.25%;
      position: relative;
      line-height: 1.5; }
      .faq-wrap .p-faq__bodyinner::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0.25em;
        width: 4.63%;
        height: 22px;
        background: url("../images/faq-a.png") no-repeat top center/contain; }
      .faq-wrap .p-faq__bodyinner p.p-faq__a-txt {
        font-size: clamp(0.938rem, 0.759rem + 0.89vw, 1.188rem);
        letter-spacing: 0.02em;
        line-height: 1.5em; }

/*# sourceMappingURL=style.css.map */
