@charset "UTF-8";
* {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

*, h1, h2, h3, h4, h5, p {
  padding: 0;
  margin: 0; }

html {
  font-size: 10px;
  overflow-y: auto;
  overscroll-behavior: none; }

body {
  height: 100%;
  overflow: hidden;
  overscroll-behavior: none;
  background-color: #FFF;
  font-family: 'Inconsolata',"游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" , "メイリオ" , Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif;
  color: #333;
  font-size: 1.4rem;
  line-height: 1.8em;
  letter-spacing: .03em;
  -webkit-text-size-adjust: 100%; }
  @media screen and (min-width: 1080px) {
    body {
      font-size: 1.6rem;
      line-height: 2em;
      letter-spacing: .03em;
      width: 100%;
      height: 100%; } }
  @media screen and (max-width: 767px) {
    body {
      width: 100%;
      overflow-x: hidden; } }

ul, li {
  list-style: none; }

a {
  color: #ff3f6b;
  text-decoration: none; }
  a:focus {
    outline: none; }

*:focus {
  outline: none; }

img {
  vertical-align: bottom;
  border: 0px; }

section {
  position: relative;
  z-index: 100; }

.section-wrapper {
  padding: 8rem 14% 9rem; }
  @media screen and (max-width: 767px) {
    .section-wrapper {
      padding: 4rem 2.5rem 2.5rem; } }

h2 {
  color: #52c2ee;
  font-size: 4.7vw;
  font-weight: bold;
  font-style: italic;
  text-align: center;
  line-height: 1.1; }
  @media screen and (max-width: 767px) {
    h2 {
      font-size: 3.5rem; } }
  h2 span {
    display: block;
    font-size: 1.1vw;
    font-weight: normal;
    margin-top: 1px; }
    @media screen and (max-width: 767px) {
      h2 span {
        font-size: 2rem; } }

.left-box {
  flex: 1; }

.right-box {
  flex: 2; }

@media screen and (max-width: 767px) {
  br {
    display: none; } }
@media screen and (max-width: 320px) {
  br {
    display: none; } }

.txt-center {
  text-align: center; }

.txt-right {
  text-align: right; }

.txt-left {
  text-align: left; }

.gray {
  background: #f5f5f5; }

@media screen and (min-width: 1080px) {
  .pc-none {
    display: none; } }

/****************************************
1. General Setting
*****************************************/
html, body, div, span, applet, object, iframe, strong,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, legend, caption,
tbody, tfoot, thead, table, label, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
  list-style: none;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

.clearfix:before,
.clearfix:after {
  content: "";
  display: block;
  clear: both; }

html {
  background-color: #fff; }
  @media screen and (max-width: 767px) {
    html {
      width: 99%;
      margin: 0 auto; } }

img {
  vertical-align: text-bottom; }

iframe {
  width: 100% !important; }

a {
  text-decoration: none;
  color: #ff3f6b; }

a:hover {
  color: #ffa4b9; }

.clear {
  clear: both;
  line-height: 0; }

header {
  position: relative;
  width: 100%; }
  header ul {
    position: relative;
    z-index: 255;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    margin: 12px 0 0 0;
    padding: 45px 0 45px 0; }
    @media screen and (max-width: 767px) {
      header ul {
        display: block;
        padding: 0;
        margin: 0 0 15px 0; } }
    @media screen and (min-width: 768px) and (max-width: 1080px) {
      header ul {
        display: block;
        padding: 0;
        margin: 0 0 15px 0; } }
    @media screen and (max-width: 320px) {
      header ul {
        display: block;
        padding: 0;
        margin: 0 0 15px 0; } }
    header ul li {
      font-weight: 600;
      font-size: 1.75vw;
      margin: 0px 40px 0 0;
      position: relative; }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        header ul li {
          padding: 0 0 0 25px;
          background-color: rgba(255, 155, 150, 0.5);
          border-bottom: 1px solid #ccc;
          padding: 0;
          margin: 0; } }
      @media screen and (max-width: 767px) {
        header ul li {
          padding: 0 0 0 25px;
          background-color: rgba(255, 155, 150, 0.5);
          border-bottom: 1px solid #ccc;
          padding: 0;
          margin: 0; } }
      @media screen and (max-width: 320px) {
        header ul li {
          padding: 0 0 0 25px;
          background-color: rgba(255, 155, 150, 0.5);
          border-bottom: 1px solid #ccc;
          padding: 0;
          margin: 0; } }
      header ul li a {
        margin: 0 40px 0 0;
        color: crimson;
        background-color: rgba(255, 255, 255, 0.85);
        border-radius: 8px;
        padding: 9px 15px 8px 15px;
        font-size: 18px;
        flex-wrap: nowrap;
        -webkit-transform: perspective(1px) translateZ(0);
        transform: perspective(1px) translateZ(0);
        box-shadow: 0 0 1px rgba(0, 0, 0, 0);
        -webkit-transition-duration: 0.3s;
        transition-duration: 0.3s;
        -webkit-transition-property: transform;
        transition-property: transform;
        -webkit-transition-timing-function: ease-out;
        transition-timing-function: ease-out; }
        @media screen and (max-width: 767px) {
          header ul li a {
            vertical-align: top;
            line-height: 3.5;
            flex-wrap: nowrap;
            text-align: center;
            display: block;
            width: 75%;
            margin: 0 auto;
            padding: 0;
            border-radius: 100px;
            box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); } }
        @media screen and (min-width: 768px) and (max-width: 1080px) {
          header ul li a {
            vertical-align: top;
            line-height: 3.5;
            flex-wrap: nowrap;
            text-align: center;
            display: block;
            width: 75%;
            margin: 0 auto;
            padding: 0;
            border-radius: 100px;
            box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); } }
        @media screen and (max-width: 320px) {
          header ul li a {
            vertical-align: top;
            line-height: 3.5;
            flex-wrap: nowrap;
            text-align: center;
            display: block;
            width: 75%;
            margin: 0 auto;
            padding: 0;
            border-radius: 100px;
            box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); } }
      header ul li a:hover {
        -webkit-transform: translateY(8px);
        transform: translateY(8px); }
    @media screen and (max-width: 767px) {
      header ul li:nth-child(1) {
        border-top: 1px solid #ccc; } }
    @media screen and (max-width: 767px) {
      header ul li:nth-child(1) {
        border-top: 1px solid #ccc; } }
    @media screen and (max-width: 767px) {
      header ul li:nth-child(1) {
        border-top: 1px solid #ccc; } }
    header ul li:nth-child(1):before {
      content: "";
      background-image: url(../img/low_m_01_about_icon.svg);
      display: block;
      width: 80px;
      height: 80px;
      position: relative;
      left: 15%;
      bottom: 10%; }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        header ul li:nth-child(1):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 767px) {
        header ul li:nth-child(1):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 320px) {
        header ul li:nth-child(1):before {
          left: 0;
          bottom: 0;
          display: none; } }
    header ul li:nth-child(2):before {
      content: "";
      background-image: url(../img/low_m_02_user_icon.svg);
      display: block;
      width: 80px;
      height: 80px;
      position: relative;
      left: 13%;
      bottom: 10%; }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        header ul li:nth-child(2):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 767px) {
        header ul li:nth-child(2):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 320px) {
        header ul li:nth-child(2):before {
          left: 0;
          bottom: 0;
          display: none; } }
    header ul li:nth-child(3):before {
      content: "";
      background-image: url(../img/low_m_03_price_icon.svg);
      display: block;
      width: 80px;
      height: 80px;
      position: relative;
      left: -13%;
      bottom: 4%; }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        header ul li:nth-child(3):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 767px) {
        header ul li:nth-child(3):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 320px) {
        header ul li:nth-child(3):before {
          left: 0;
          bottom: 0;
          display: none; } }
    header ul li:nth-child(4):before {
      content: "";
      background-image: url(../img/low_m_04_question_icon.svg);
      display: block;
      width: 80px;
      height: 80px;
      position: relative;
      left: 16%;
      bottom: 10%; }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        header ul li:nth-child(4):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 767px) {
        header ul li:nth-child(4):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 320px) {
        header ul li:nth-child(4):before {
          left: 0;
          bottom: 0;
          display: none; } }
    header ul li:nth-child(5):before {
      content: "";
      background-image: url(../img/low_m_05_access_icon.svg);
      display: block;
      width: 80px;
      height: 80px;
      position: relative;
      left: 0%;
      bottom: 10%; }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        header ul li:nth-child(5):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 767px) {
        header ul li:nth-child(5):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 320px) {
        header ul li:nth-child(5):before {
          left: 0;
          bottom: 0;
          display: none; } }
    header ul li:nth-child(6):before {
      content: "";
      background-image: url(../img/low_m_06_contact_icon.svg);
      display: block;
      width: 80px;
      height: 80px;
      position: relative;
      left: 21%;
      bottom: 10%; }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        header ul li:nth-child(6):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 767px) {
        header ul li:nth-child(6):before {
          left: 0;
          bottom: 0;
          display: none; } }
      @media screen and (max-width: 320px) {
        header ul li:nth-child(6):before {
          left: 0;
          bottom: 0;
          display: none; } }
    header ul li:last-child {
      margin: 0; }
    header ul .contact_m {
      margin: 0;
      color: white;
      background-color: #f30056;
      padding: 10px 18px;
      box-shadow: 5px 2px 9px 1px rgba(0, 0, 0, 0.15);
      border-radius: 150px;
      font-size: 21px;
      -webkit-transform: perspective(1px) translateZ(0);
      transform: perspective(1px) translateZ(0);
      box-shadow: 0 0 1px rgba(0, 0, 0, 0);
      -webkit-transition-duration: 0.3s;
      transition-duration: 0.3s;
      -webkit-transition-property: transform;
      transition-property: transform; }
      @media screen and (max-width: 767px) {
        header ul .contact_m {
          margin: 0 auto;
          padding: 0;
          border-radius: 150px;
          box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); } }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        header ul .contact_m {
          margin: 0 auto;
          padding: 0;
          border-radius: 150px;
          box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); } }
      @media screen and (max-width: 320px) {
        header ul .contact_m {
          margin: 0 auto;
          padding: 0;
          border-radius: 150px;
          box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); } }
    header ul .contact_m:hover {
      -webkit-transform: scale(1.1);
      transform: scale(1.1); }

#logo {
  display: block;
  padding: 40px 0 65px 0;
  background-color: #ffe2db; }
  #logo img {
    width: 50%;
    text-align: center;
    display: block;
    margin: 0 auto; }
    @media screen and (max-width: 767px) {
      #logo img {
        width: 90%; } }
    @media screen and (min-width: 768px) and (max-width: 1080px) {
      #logo img {
        width: 75%; } }
    @media screen and (max-width: 320px) {
      #logo img {
        wifth: 100%; } }

#ReHaMo-Logo {
  text-align: center;
  margin: 50px 0; }
  @media screen and (max-width: 767px) {
    #ReHaMo-Logo {
      z-index: 1; } }

.low_wrapper {
  background-image: url(../img/z_bg_pop_pattern.svg);
  background-attachment: scroll;
  background-repeat: repeat;
  background-size: contain;
  width: 1200px;
  padding: 0;
  margin: 0 auto;
  font-family: 'Inconsolata',"游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" , "メイリオ" , Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif; }
  @media screen and (max-width: 767px) {
    .low_wrapper {
      width: 100%;
      background: none; } }
  @media screen and (min-width: 768px) and (max-width: 1080px) {
    .low_wrapper {
      width: 100%;
      background: none; } }
  .low_wrapper .co_catch {
    width: 100%; }
    .low_wrapper .co_catch img {
      width: 100%;
      margin: 45px 0; }
  .low_wrapper #ab_area01 {
    margin: 75px 0 0 0;
    background-color: rgba(255, 255, 255, 0.85);
    background-blend-mode: lighten; }
    .low_wrapper #ab_area01 h2 {
      background-color: #ff6488;
      padding: 30px 0 30px 0; }
      @media screen and (max-width: 767px) {
        .low_wrapper #ab_area01 h2 img {
          width: 100%; } }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        .low_wrapper #ab_area01 h2 img {
          width: 100%; } }
      @media screen and (max-width: 320px) {
        .low_wrapper #ab_area01 h2 img {
          width: 100%; } }
    .low_wrapper #ab_area01 .sub_text {
      line-height: 1.35;
      background-color: #ff6488;
      padding: 30px 0 30px 0;
      color: #fff;
      font-weight: 600;
      font-size: 26px;
      /* width: 1000px; */
      margin: 0 auto 0;
      padding: 12px 54px 40px; }
      @media screen and (max-width: 767px) {
        .low_wrapper #ab_area01 .sub_text {
          padding: 0px 10px 25px 15px;
          font-size: 22px; } }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        .low_wrapper #ab_area01 .sub_text {
          padding: 0px 10px 25px 15px;
          font-size: 22px; } }
      @media screen and (max-width: 767px) {
        .low_wrapper #ab_area01 .sub_text {
          padding: 0px 10px 25px 15px;
          font-size: 22px; } }
    .low_wrapper #ab_area01 .colum_box {
      display: -webkit-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      overflow: hidden;
      box-sizing: border-box; }
      @media screen and (max-width: 767px) {
        .low_wrapper #ab_area01 .colum_box {
          display: block; } }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        .low_wrapper #ab_area01 .colum_box {
          display: block; } }
      .low_wrapper #ab_area01 .colum_box .left-box {
        flex: 2;
        box-sizing: border-box;
        margin: 0 26px 0 0; }
        @media screen and (max-width: 767px) {
          .low_wrapper #ab_area01 .colum_box .left-box {
            width: 100%;
            margin: 0; } }
        @media screen and (min-width: 768px) and (max-width: 1080px) {
          .low_wrapper #ab_area01 .colum_box .left-box {
            width: 100%;
            margin: 0; } }
        @media screen and (max-width: 320px) {
          .low_wrapper #ab_area01 .colum_box .left-box {
            width: 100%;
            margin: 0; } }
        .low_wrapper #ab_area01 .colum_box .left-box .disp {
          font-weight: 600;
          line-height: 1.4;
          font-size: 20px;
          color: #111;
          background-color: rgba(255, 255, 255, 0.35);
          margin: 25px 0 35px 0; }
          @media screen and (min-width: 768px) and (max-width: 1080px) {
            .low_wrapper #ab_area01 .colum_box .left-box .disp {
              padding: 0 20px; } }
      .low_wrapper #ab_area01 .colum_box .right-box {
        flex: 1.1;
        box-sizing: border-box;
        text-align: right; }
        @media screen and (min-width: 768px) and (max-width: 1080px) {
          .low_wrapper #ab_area01 .colum_box .right-box {
            text-align: left; } }
        @media screen and (max-width: 767px) {
          .low_wrapper #ab_area01 .colum_box .right-box img {
            width: 100%; } }
    .low_wrapper #ab_area01 .r_colum_box {
      display: -webkit-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      overflow: hidden;
      box-sizing: border-box;
      margin: 60px 0 60px 0; }
      @media screen and (max-width: 767px) {
        .low_wrapper #ab_area01 .r_colum_box {
          display: flex; } }
      @media screen and (min-width: 768px) and (max-width: 1080px) {
        .low_wrapper #ab_area01 .r_colum_box {
          display: flex; } }
      @media screen and (max-width: 320px) {
        .low_wrapper #ab_area01 .r_colum_box {
          display: flex; } }
      .low_wrapper #ab_area01 .r_colum_box .right-box {
        flex: 1;
        box-sizing: border-box; }
        @media screen and (max-width: 767px) {
          .low_wrapper #ab_area01 .r_colum_box .right-box {
            order: 0;
            display: block;
            width: 100%; } }
        @media screen and (min-width: 768px) and (max-width: 1080px) {
          .low_wrapper #ab_area01 .r_colum_box .right-box {
            order: 0;
            display: block;
            width: 100%; } }
        @media screen and (max-width: 320px) {
          .low_wrapper #ab_area01 .r_colum_box .right-box {
            order: 0;
            display: block;
            width: 100%; } }
        .low_wrapper #ab_area01 .r_colum_box .right-box .disp {
          font-weight: 600;
          line-height: 1.4;
          font-size: 20px;
          color: #111;
          background-color: rgba(255, 255, 255, 0.35);
          margin: 25px 0 35px 0; }
          @media screen and (min-width: 768px) and (max-width: 1080px) {
            .low_wrapper #ab_area01 .r_colum_box .right-box .disp {
              padding: 0 20px; } }
      .low_wrapper #ab_area01 .r_colum_box .left-box {
        flex: 1.1;
        box-sizing: border-box;
        text-align: right;
        margin: 0 26px 0 0; }
        @media screen and (min-width: 768px) and (max-width: 1080px) {
          .low_wrapper #ab_area01 .r_colum_box .left-box {
            order: 1;
            display: block;
            width: 100%;
            flex: auto; } }
        @media screen and (max-width: 767px) {
          .low_wrapper #ab_area01 .r_colum_box .left-box {
            order: 1;
            display: block;
            width: 100%;
            flex: auto; } }
        @media screen and (max-width: 320px) {
          .low_wrapper #ab_area01 .r_colum_box .left-box {
            order: 1;
            display: block;
            width: 100%;
            flex: auto; } }
        @media screen and (max-width: 767px) {
          .low_wrapper #ab_area01 .r_colum_box .left-box img {
            width: 100%; } }

#contact {
  background-color: rgba(255, 255, 255, 0.8); }
  #contact .disp {
    width: 80%;
    margin: 45px auto 0;
    font-size: 127%;
    font-weight: bold; }

#thanks {
  background-color: rgba(255, 255, 255, 0.85); }
  #thanks h2 {
    font-size: 3.5vw;
    text-align: center;
    padding: 65px 0; }
    @media screen and (max-width: 767px) {
      #thanks h2 {
        font-size: 28px;
        margin: 45px 0 35px 0; } }
  #thanks .disp {
    line-height: 1.5;
    font-size: 28px;
    text-align: center;
    padding: 0 0 100px 0; }
    @media screen and (max-width: 767px) {
      #thanks .disp {
        font-size: 18px;
        font-weight: 600;
        line-height: 1.35;
        margin: 30px 0 30px 0; } }

ul.check_point {
  background-color: #e3e3e3;
  padding: 18px 18px 10px 24px;
  margin: 30px 0 30px 0; }
  ul.check_point li {
    color: #222;
    font-weight: 600;
    line-height: 1.65;
    background-image: url(../img/z_check-min.png);
    background-position: left;
    background-repeat: no-repeat;
    padding: 0 0 0 30px;
    margin: 0 0 10px 0; }
  ul.check_point li.webp {
    background-image: url(../img/z_check-min.png.webp); }
    @media screen and (max-width: 767px) {
      ul.check_point li.webp {
        background-image: url(../img/z_check-min.png); } }

/*# sourceMappingURL=co_style.css.map */
