@charset "UTF-8";
* {
  padding: 0;
  margin: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html {
  font-size: 62.5%;
}

body {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #333;
  font-family: "Noto Sans JP", serif;
  font-weight: 400;
  padding-bottom: 7rem;
}
@media screen and (min-width: 768px) {
  body {
    padding-bottom: 0;
  }
}
@media screen and (min-width: 1024px) {
  body {
    font-size: 1.6rem;
  }
}

a {
  color: inherit;
  text-decoration: none;
}

ul {
  list-style-type: none;
}

h1, h2, h3, h4, li, dt, input {
  line-height: 1.4;
}

img {
  max-width: 100%;
}

.ff_oswald {
  font-family: "Oswald", serif;
  font-style: normal;
}

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

.sp_hidden {
  display: none;
}
@media screen and (min-width: 768px) {
  .sp_hidden {
    display: block;
  }
}

.pc_only {
  display: none;
}
@media screen and (min-width: 1024px) {
  .pc_only {
    display: block;
  }
}

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

.content {
  width: 100rem;
  max-width: 94%;
  margin: 0 auto;
  padding: 4rem 0;
}
@media screen and (min-width: 768px) {
  .content {
    padding: 6.4rem 0;
  }
}
@media screen and (min-width: 1024px) {
  .content {
    padding: 8rem 0;
  }
}

header {
  border-bottom: solid 0.2rem #F4A000;
}
header .header_inner {
  padding: 1.2rem;
  width: 100rem;
  max-width: 94%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  header .header_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
header .header_inner .co_logo {
  width: 16rem;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  header .header_inner .co_logo {
    margin: 0;
  }
}
header .header_inner .co_logo img {
  display: block;
}
header .header_inner .header_btn {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1.2rem;
  background-color: #fff;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.4);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.4);
  z-index: 5;
}
@media screen and (min-width: 768px) {
  header .header_inner .header_btn {
    position: static;
    -webkit-box-shadow: none;
            box-shadow: none;
    padding: 0;
    width: auto;
  }
}
header .header_inner .header_btn li {
  width: 80%;
  text-align: center;
}
@media screen and (min-width: 768px) {
  header .header_inner .header_btn li {
    width: auto;
  }
}
header .header_inner .header_btn li a {
  display: block;
  padding: 1.2rem;
  border: solid 0.1rem #EB7600;
  border-radius: 10rem;
}
header .header_inner .header_btn li a img {
  position: relative;
  top: 2px;
}
@media screen and (min-width: 768px) {
  header .header_inner .header_btn .to_contact a {
    padding: 0;
    border: none;
    border-radius: 0;
  }
}
header .header_inner .header_btn .to_contact a img {
  width: 8px;
}
header .header_inner .header_btn .to_buy a {
  background-color: #EB7600;
  color: #fff;
}
header .header_inner .header_btn .to_buy a img {
  width: 16px;
}

.fv {
  background: url(/memorun/asset/img/fv_synapse.svg) no-repeat center 20%;
  background-size: 150%;
}
@media screen and (min-width: 768px) {
  .fv {
    background-size: 108%;
  }
}
@media screen and (min-width: 1280px) {
  .fv {
    background-size: 120rem;
  }
}
.fv .fv_content {
  position: relative;
  padding-top: 1.2rem;
  width: 100rem;
  max-width: 94%;
  margin: 0 auto;
}
@media screen and (min-width: 1024px) {
  .fv .fv_content {
    padding-top: 2.4rem;
  }
}
.fv .fv_content .worries {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 2.4rem;
}
.fv .fv_content .worries li {
  width: 32%;
  margin: 0.5%;
  background-color: #E65305;
  border-radius: 0.8rem;
  padding: 0.8rem;
  color: #fff;
  text-align: center;
}
@media screen and (min-width: 1024px) {
  .fv .fv_content .worries li {
    padding: 1.2rem;
    font-size: 2rem;
  }
}
.fv .fv_content h1 {
  width: 80%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .fv .fv_content h1 {
    width: 60%;
  }
}
.fv .fv_content h1 img {
  display: block;
}
.fv .fv_content h2 {
  position: absolute;
  top: 80px;
  right: 0;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  font-size: 3.2rem;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .fv .fv_content h2 {
    font-size: 4.8rem;
    top: 10rem;
    right: 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .fv .fv_content h2 {
    font-size: 5.2rem;
    top: 16rem;
    right: 0;
  }
}
.fv .fv_content h2 span {
  color: #E85416;
}
.fv .fv_content .fv_elements li {
  position: absolute;
  width: 8rem;
}
@media screen and (min-width: 768px) {
  .fv .fv_content .fv_elements li {
    width: 12rem;
  }
}
@media screen and (min-width: 1024px) {
  .fv .fv_content .fv_elements li {
    width: 14.4rem;
  }
}
.fv .fv_content .fv_elements .fv_element01 {
  top: 8rem;
  left: 0;
}
@media screen and (min-width: 768px) {
  .fv .fv_content .fv_elements .fv_element01 {
    top: 10rem;
    left: 12rem;
  }
}
@media screen and (min-width: 1024px) {
  .fv .fv_content .fv_elements .fv_element01 {
    top: 16rem;
    left: 14rem;
  }
}
.fv .fv_content .fv_elements .fv_element02 {
  top: 16.4rem;
  left: 0;
}
@media screen and (min-width: 768px) {
  .fv .fv_content .fv_elements .fv_element02 {
    top: 17.4rem;
    left: 0.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .fv .fv_content .fv_elements .fv_element02 {
    top: 22rem;
    left: -1.2rem;
  }
}
.fv .fv_content .fv_elements .fv_element03 {
  top: 24.8rem;
  left: 0;
}
@media screen and (min-width: 768px) {
  .fv .fv_content .fv_elements .fv_element03 {
    top: 30rem;
    left: 5rem;
  }
}
@media screen and (min-width: 1024px) {
  .fv .fv_content .fv_elements .fv_element03 {
    top: 36rem;
    left: 6rem;
  }
}
.fv .fv_bar {
  background-color: #F4A000;
}
.fv .fv_bar .fv_bar_inner {
  width: 100rem;
  max-width: 94%;
  margin: 0 auto;
  padding: 1.2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .fv .fv_bar .fv_bar_inner {
    display: block;
    position: relative;
    padding: 1.2rem 18rem;
  }
}
@media screen and (min-width: 1024px) {
  .fv .fv_bar .fv_bar_inner {
    padding: 1.2rem 26rem;
  }
}
.fv .fv_bar .fv_bar_inner figure {
  width: 36%;
}
@media screen and (min-width: 768px) {
  .fv .fv_bar .fv_bar_inner figure {
    position: absolute;
    width: 16rem;
    z-index: 1;
  }
}
@media screen and (min-width: 1024px) {
  .fv .fv_bar .fv_bar_inner figure {
    width: 23rem;
  }
}
@media screen and (min-width: 768px) {
  .fv .fv_bar .fv_bar_inner .fv_product_img {
    left: 0;
    top: 50%;
    translate: 0 -60%;
  }
}
@media screen and (min-width: 768px) {
  .fv .fv_bar .fv_bar_inner .fv_badge {
    right: 0;
    top: 50%;
    translate: 0 -50%;
  }
}
.fv .fv_bar .fv_bar_inner .fv_price {
  text-align: center;
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (min-width: 768px) {
  .fv .fv_bar .fv_bar_inner .fv_price {
    text-align: left;
  }
}
.fv .fv_bar .fv_bar_inner .fv_price em {
  font-size: 4.8rem;
}

.sec01 {
  background-image: -webkit-gradient(linear, left top, left bottom, from(#F6B802), to(#F4A000));
  background-image: linear-gradient(to bottom, #F6B802, #F4A000);
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .sec01 {
    background-image: url(/memorun/asset/img/sec01_synapse.svg), -webkit-gradient(linear, left top, left bottom, from(#F6B802), to(#F4A000));
    background-image: url(/memorun/asset/img/sec01_synapse.svg), linear-gradient(to bottom, #F6B802, #F4A000);
    background-repeat: no-repeat, no-repeat;
    background-position: right top;
    background-size: 16rem, 100%;
  }
}
@media screen and (min-width: 1024px) {
  .sec01 {
    background-size: 20rem, 100%;
  }
}
.sec01 .content {
  position: relative;
  padding-bottom: 0;
}
@media screen and (min-width: 768px) {
  .sec01 .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding-bottom: 6.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec01 .content {
    padding-bottom: 8rem;
  }
}
.sec01 h2 {
  color: #F4A000;
  margin-bottom: 2.4rem;
  font-size: 2.4rem;
}
@media screen and (min-width: 768px) {
  .sec01 h2 {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 1024px) {
  .sec01 h2 {
    font-size: 3.2rem;
  }
}
.sec01 h3 {
  margin-bottom: 2.4rem;
  font-size: 2rem;
}
@media screen and (min-width: 768px) {
  .sec01 h3 {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    margin: 0 2.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec01 h3 {
    font-size: 2.4rem;
    margin: 0 2.8rem 0 1.2rem;
  }
}
.sec01 p {
  margin-bottom: 1.2rem;
}
@media screen and (min-width: 768px) {
  .sec01 p {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    margin-bottom: 0;
    margin-right: 0.8rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec01 p {
    margin-right: 1.6rem;
  }
}
.sec01 .image_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
@media screen and (min-width: 768px) {
  .sec01 .image_area {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .sec01 .image_area .sec01_bg01, .sec01 .image_area .sec01_bg02 {
    position: absolute;
    bottom: 0;
  }
}
.sec01 .image_area .sec01_bg01 img, .sec01 .image_area .sec01_bg02 img {
  display: block;
}
.sec01 .image_area .sec01_bg01 {
  width: 12rem;
}
@media screen and (min-width: 768px) {
  .sec01 .image_area .sec01_bg01 {
    right: -3.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec01 .image_area .sec01_bg01 {
    width: 16rem;
    right: -4rem;
  }
}
.sec01 .image_area .sec01_bg02 {
  width: 18rem;
}
@media screen and (min-width: 768px) {
  .sec01 .image_area .sec01_bg02 {
    left: -3.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec01 .image_area .sec01_bg02 {
    width: 26rem;
    left: -4.8rem;
  }
}
.sec01::before {
  content: "";
  display: block;
  width: 180vw;
  height: 180vw;
  background-color: #fff;
  border-radius: 100%;
  position: absolute;
  top: -24%;
  left: 50%;
  translate: -50% 0;
  display: block;
}
@media screen and (min-width: 768px) {
  .sec01::before {
    width: 60rem;
    height: 60rem;
    top: 50%;
    translate: -50% -50%;
  }
}
@media screen and (min-width: 1024px) {
  .sec01::before {
    width: 80rem;
    height: 80rem;
  }
}

.sec02 {
  background-image: url(/memorun/asset/img/sec02_synapse01.svg), url(/memorun/asset/img/sec02_synapse02.svg), url(/memorun/asset/img/sec02_synapse03.svg), url(/memorun/asset/img/sec02_synapse04.svg), -webkit-gradient(linear, left top, left bottom, from(#EB7A01), to(#F4A000));
  background-image: url(/memorun/asset/img/sec02_synapse01.svg), url(/memorun/asset/img/sec02_synapse02.svg), url(/memorun/asset/img/sec02_synapse03.svg), url(/memorun/asset/img/sec02_synapse04.svg), linear-gradient(to bottom, #EB7A01, #F4A000);
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
  background-position: left top, right 30%, left 75%, right bottom;
  background-size: 124px, 100px, 128px, 110px, 100%;
}
@media screen and (min-width: 768px) {
  .sec02 {
    background-size: 186px, 150px, 192px, 165px, 100%;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 {
    background-size: 248px, 200px, 256px, 220px, 100%;
  }
}
.sec02 .features {
  background-color: #fff;
  border-radius: 0.8rem;
  padding: 1.2rem;
  margin-bottom: 2.4rem;
}
@media screen and (min-width: 768px) {
  .sec02 .features {
    padding: 2.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features {
    padding: 4rem;
  }
}
.sec02 .features h2 {
  background-image: -webkit-gradient(linear, left top, right top, from(#E65305), to(#EF9400));
  background-image: linear-gradient(to right, #E65305, #EF9400);
  color: #fff;
  padding: 0.8rem;
  border-radius: 0.4rem;
  margin-bottom: 2.4rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .sec02 .features h2 {
    padding-left: 10rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features h2 {
    font-size: 3.2rem;
    padding-left: 12rem;
  }
}
.sec02 .features h2::before {
  content: "クリアな毎日を支える秘密";
  display: block;
  font-size: 1.2rem;
}
@media screen and (min-width: 768px) {
  .sec02 .features h2::before {
    content: "クリアな毎日\aを支える秘密";
    white-space: pre;
    position: absolute;
    top: 50%;
    left: 1.2rem;
    translate: 0 -50%;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features h2::before {
    left: 1.6rem;
    font-size: 1.4rem;
  }
}
.sec02 .features h3 {
  background: url(/memorun/asset/img/pen.png) no-repeat bottom left;
  background-size: contain;
  padding-left: 4rem;
  position: relative;
  margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .sec02 .features h3 {
    font-size: 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features h3 {
    font-size: 2.4rem;
  }
}
.sec02 .features h3 span {
  font-size: 1.2rem;
  display: block;
}
@media screen and (min-width: 1024px) {
  .sec02 .features h3 span {
    font-size: 1.4rem;
  }
}
.sec02 .features h3::before {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: -webkit-gradient(linear, left top, right top, from(#E65305), to(#EF9400));
  background-image: linear-gradient(to right, #E65305, #EF9400);
  position: absolute;
  bottom: -0.4rem;
  left: 0;
}
.sec02 .features .row {
  margin-bottom: 4rem;
}
@media screen and (min-width: 768px) {
  .sec02 .features .row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .sec02 .features .row figure {
    width: 48%;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features .row figure {
    position: relative;
  }
}
.sec02 .features .row figure figcaption {
  background-color: #FDEACC;
  padding: 1.2rem;
  border-radius: 0.8rem;
  margin-top: 0.8rem;
  margin-bottom: 2.4rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .sec02 .features .row figure figcaption {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features .row figure figcaption {
    font-size: 1.4rem;
    width: 100%;
    position: absolute;
    left: 108%;
    bottom: 1.6rem;
    text-align: center;
  }
}
.sec02 .features .row figure figcaption::before {
  content: "";
  display: block;
  width: 2.4rem;
  height: 2.4rem;
  background-color: #FDEACC;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  position: absolute;
  top: -2.4rem;
  left: 2.4rem;
}
@media screen and (min-width: 1024px) {
  .sec02 .features .row figure figcaption::before {
    clip-path: polygon(100% 0, 100% 100%, 0 50%);
    top: 50%;
    left: -2.4rem;
    translate: 0 -50%;
    height: 2rem;
  }
}
@media screen and (min-width: 768px) {
  .sec02 .features .row .features_body {
    width: 48%;
  }
}
.sec02 .features .component_module {
  margin-bottom: 4rem;
}
.sec02 .features .component_module figure {
  width: 80%;
  margin: 0 auto 2.4rem;
}
@media screen and (min-width: 768px) {
  .sec02 .features .component_module figure {
    width: 24rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features .component_module figure {
    width: 28rem;
  }
}
.sec02 .features .component_module p span {
  color: #EB7203;
}
@media screen and (min-width: 768px) {
  .sec02 .features .component_module01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .sec02 .features .component_module01 p {
    width: calc(100% - 32rem);
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features .component_module01 p {
    width: calc(100% - 42rem);
  }
}
@media screen and (min-width: 768px) {
  .sec02 .features .component_row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .sec02 .features .component_row .component_module {
    width: 48%;
    margin-bottom: 0;
  }
}
.sec02 .features .about_shape {
  margin-top: 2.4rem;
  background-color: #FEF7EA;
  padding: 1.6rem;
  position: relative;
}
@media screen and (min-width: 1024px) {
  .sec02 .features .about_shape {
    padding: 2.4rem;
  }
}
.sec02 .features .about_shape dt {
  color: #EB7203;
  font-weight: 700;
  font-size: 2rem;
  margin-bottom: 1.2rem;
}
.sec02 .features .about_shape dd {
  margin-bottom: 2.4rem;
}
@media screen and (min-width: 768px) {
  .sec02 .features .about_shape dd {
    margin-bottom: 0;
    width: calc(100% - 22rem);
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features .about_shape dd {
    font-size: 1.4rem;
  }
}
.sec02 .features .about_shape figure {
  width: 64%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .sec02 .features .about_shape figure {
    position: absolute;
    width: 20rem;
    margin: 0;
    right: 1.2rem;
    top: 50%;
    translate: 0 -50%;
  }
}
@media screen and (min-width: 1024px) {
  .sec02 .features .about_shape figure {
    width: 22rem;
  }
}
.sec02 .features .about_shape figure img {
  display: block;
}

.sec03 {
  background-image: url(/memorun/asset/img/sec03_synapse01.svg), url(/memorun/asset/img/sec03_synapse01.svg);
  background-repeat: no-repeat, no-repeat;
  background-position: -8% -8%, right 60%;
  background-size: 20rem, 20rem;
}
@media screen and (min-width: 768px) {
  .sec03 {
    background-position: -8% -8%, right bottom;
  }
}
@media screen and (min-width: 1024px) {
  .sec03 {
    background-size: 24rem, 24rem;
    background-position: left top, right bottom;
  }
}
.sec03 h2 {
  text-align: center;
  padding-bottom: 1.6rem;
  position: relative;
  font-size: 2.4rem;
  margin-bottom: 2.4rem;
}
@media screen and (min-width: 768px) {
  .sec03 h2 {
    margin-bottom: 4rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec03 h2 {
    font-size: 3.6rem;
  }
}
.sec03 h2::before {
  content: "";
  display: block;
  width: 8rem;
  height: 0.6rem;
  background-color: #F29B02;
  border-radius: 0.3rem;
  position: absolute;
  bottom: 0;
  left: 50%;
  translate: -50%;
}
@media screen and (min-width: 768px) {
  .sec03 .message_row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
.sec03 .message_body {
  margin-bottom: 4rem;
}
@media screen and (min-width: 768px) {
  .sec03 .message_body {
    margin-bottom: 0;
    width: 60%;
  }
}
@media screen and (min-width: 1024px) {
  .sec03 .message_body {
    width: 66%;
  }
}
.sec03 .message_body h3 {
  font-size: 2rem;
  margin-bottom: 2.4rem;
}
@media screen and (min-width: 768px) {
  .sec03 .message_body h3 {
    font-size: 2.4rem;
  }
}
.sec03 .message_body .signature {
  margin-top: 2.4rem;
  font-size: 1.6rem;
  font-weight: 700;
}
@media screen and (min-width: 1024px) {
  .sec03 .message_body .signature {
    font-size: 1.8rem;
  }
}
.sec03 .message_body .signature span {
  display: block;
  font-size: 1.2rem;
}
.sec03 .message_img {
  width: 64%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .sec03 .message_img {
    width: 36%;
    margin: 0;
  }
}
@media screen and (min-width: 1024px) {
  .sec03 .message_img {
    width: 30%;
  }
}

.sec04 {
  background: url(/memorun/asset/img/sec04_bg.jpg) no-repeat center center;
  background-size: cover;
}
.sec04 h2 {
  color: #fff;
  text-align: center;
  font-size: 2.4rem;
  margin-bottom: 2.4rem;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .sec04 h2 {
    width: 90%;
    border: solid 0.1rem #fff;
    border-radius: 10rem;
    padding: 0.8rem;
    margin: 0 auto 4rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec04 h2 {
    width: 72%;
  }
}
.sec04 h3 {
  color: #fff;
  text-align: center;
  font-size: 1.6rem;
  margin-bottom: 2rem;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .sec04 h3 {
    font-size: 2rem;
    margin-bottom: 4rem;
  }
}
.sec04 .contanct_info {
  background-color: #fff;
  border-radius: 0.8rem;
  padding: 1.2rem 2.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (min-width: 1024px) {
  .sec04 .contanct_info {
    padding: 2rem 4rem;
    max-width: 81%;
    margin: 0 auto;
  }
}
.sec04 .contanct_info figure {
  width: 40%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .sec04 .contanct_info figure {
    width: 16%;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin: 0;
  }
}
.sec04 .contanct_info .contact_module {
  text-align: center;
  font-weight: 700;
  margin-bottom: 4rem;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .sec04 .contanct_info .contact_module {
    margin-bottom: 0;
    width: 40%;
  }
}
@media screen and (min-width: 1024px) {
  .sec04 .contanct_info .contact_module {
    width: 38%;
  }
}
.sec04 .contanct_info .contact_module .txt_main {
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 0.8rem;
}
.sec04 .contanct_info .contact_module .txt_main img {
  width: 2.8rem;
  margin-right: 0.8rem;
  position: relative;
}
@media screen and (min-width: 1024px) {
  .sec04 .contanct_info .contact_module .txt_main img {
    width: 3.2rem;
  }
}
.sec04 .contanct_info .contact_module .txt_main span {
  font-size: 3.6rem;
}
@media screen and (min-width: 1024px) {
  .sec04 .contanct_info .contact_module .txt_main span {
    font-size: 4rem;
  }
}
.sec04 .contanct_info .contact_module .txt_sub {
  line-height: 1;
  font-size: 1.6rem;
}
.sec04 .contanct_info .contact_module .contact_btn a {
  display: block;
  color: #F29B02;
  background-color: #FFF;
  border: solid 0.1rem #F29B02;
  padding: 1.2rem 0;
  font-size: 2rem;
  -webkit-transition: background-color 0.4s ease 0s;
  transition: background-color 0.4s ease 0s;
}
@media screen and (min-width: 768px) {
  .sec04 .contanct_info .contact_module .contact_btn a {
    font-size: 1.6rem;
  }
  .sec04 .contanct_info .contact_module .contact_btn a:hover {
    background-color: #F29B02;
    color: #fff;
    fill: #fff;
  }
  .sec04 .contanct_info .contact_module .contact_btn a:hover svg path {
    fill: #fff !important;
  }
}
.sec04 .contanct_info .contact_module .contact_btn a img, .sec04 .contanct_info .contact_module .contact_btn a svg {
  width: 2rem;
  margin-right: 0.4rem;
  position: relative;
}
.sec04 .contanct_info .contact_module .contact_btn a .btn_icon_mail {
  top: 0.1rem;
}
@media screen and (min-width: 768px) {
  .sec04 .contanct_info .contact_module .contact_btn a .btn_icon_mail {
    top: 0.1rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec04 .contanct_info .contact_module .contact_btn a .btn_icon_mail {
    top: 0.2rem;
  }
}
.sec04 .contanct_info .contact_module .contact_btn a .btn_icon_cart {
  top: 0.1rem;
}
@media screen and (min-width: 768px) {
  .sec04 .contanct_info .contact_module .contact_btn a .btn_icon_cart {
    top: 0.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec04 .contanct_info .contact_module .contact_btn a .btn_icon_cart {
    top: 0.4rem;
  }
}
.sec04 .contanct_info .contact_module:last-of-type {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .sec04 .contanct_info .contact_module.price-text {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}
.sec04 .contanct_info .contact_module.price-text .txt_main {
  margin-top: 0.8rem;
}
@media screen and (min-width: 1024px) {
  .sec04 .contanct_info .contact_module.price-text .txt_main {
    font-size: 2.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .sec04 .contanct_info .contact_module.price-text .txt_main span {
    font-size: 5.6rem;
  }
}

.sec05 {
  background-color: #FEF7EA;
}
.sec05 h2 {
  text-align: center;
}
.sec05 .term_table {
  margin-top: 4rem;
  border-collapse: collapse;
  width: 100%;
}
.sec05 .term_table th, .sec05 .term_table td {
  font-size: 1.4rem;
}
.sec05 .term_table th {
  width: 36%;
  background-color: #C7DFF0;
  border-top: solid 0.1rem #7CA6C4;
  border-bottom: solid 0.1rem #7CA6C4;
  padding: 1.2rem 0;
}
@media screen and (min-width: 768px) {
  .sec05 .term_table th {
    width: 24%;
  }
}
@media screen and (min-width: 768px) {
  .sec05 .term_table th br {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .sec05 .term_table th br.sp_hidden {
    display: block;
  }
}
.sec05 .term_table td {
  width: 64%;
  background-color: #fff;
  border-top: solid 0.1rem #7CA6C4;
  border-bottom: solid 0.1rem #7CA6C4;
  padding: 1.2rem;
}
@media screen and (min-width: 768px) {
  .sec05 .term_table td {
    width: 76%;
    padding: 1.2rem 1.6rem;
  }
}

footer .footer_inner {
  width: 100rem;
  max-width: 94%;
  margin: 0 auto;
  padding: 1.2rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
footer .footer_inner a {
  font-size: 1.2rem;
  position: relative;
}
footer .footer_inner a::after {
  content: "";
  position: absolute;
  right: -15px;
  top: 50%;
  translate: 0 -50%;
  width: 11px;
  height: 10px;
  background: url(/memorun/asset/img/icon-outer.svg) center no-repeat;
  background-size: cover;
}
footer .footer_inner .copyright {
  font-size: 1.2rem;
  margin-left: auto;
}
/*# sourceMappingURL=style.css.map */