@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: transparent;
  box-sizing: border-box;
  list-style: none;
}
*::before, *::after {
  box-sizing: border-box;
}

img {
  font-size: 0;
  line-height: 0;
  width: 100%;
  max-width: 100%;
  height: auto;
}

body {
  font-family: "Noto Sans JP", Helvetica, Arial, "Hiragino Sans", YuGothic, "Yu Gothic medium", sans-serif;
  -webkit-text-size-adjust: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
  text-rendering: optimizeLegibility;
  font-feature-settings: "palt";
  font-size: 1.302vw;
  line-height: 2;
  color: #06092F;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  letter-spacing: 0.16em;
}
@supports (-webkit-touch-callout: none) {
  body {
    /* Safari用のハック */
    min-height: -webkit-fill-available;
  }
}
@media (max-width: 768px) {
  body {
    font-size: 3.646vw;
    line-height: 1.76;
    letter-spacing: 0.08em;
  }
}

small {
  font-weight: normal;
  font-size: 80%;
  letter-spacing: inherit;
}

strong {
  font-weight: bolder;
}

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

sub {
  font-size: 64%;
  font-weight: normal;
}

.btn_download, .btn_contact, .btn_form, .btn_top {
  font-weight: 500;
  text-align: center;
  display: inline-block;
  border-radius: 0.4em;
  padding: 1em 1.6em 1em 1.28em;
  position: relative;
  transition: 0.4s;
  white-space: nowrap;
  line-height: 1.44;
  box-shadow: 0 0.16em 0.32em rgba(185, 101, 76, 0.24);
}
@media (max-width: 768px) {
  .btn_download, .btn_contact, .btn_form, .btn_top {
    padding: 1.28em 3.84em 1.28em 2.56em;
  }
}
.btn_download::before, .btn_contact::before, .btn_form::before, .btn_top::before {
  content: "";
  position: absolute;
  top: 50%;
  width: 0.64em;
  height: 0.64em;
  background: url("../images/icon_arrow_1.svg") no-repeat center/contain;
  right: 0.4em;
  transform: translateY(-50%);
}
.btn_download:hover, .btn_contact:hover, .btn_form:hover, .btn_top:hover {
  opacity: 0.8;
}
.btn_download {
  background: #F69D82;
}
.btn_download .span1 {
  background: rgba(255, 255, 255, 0.32);
}
.btn_contact::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 0.4em;
  border: max(1px, min(0.26vw, 2px)) solid #F69D82;
  position: absolute;
  left: 0;
  top: 0;
}
.btn_contact .span1 {
  background: rgba(232, 80, 80, 0.16);
}
.btn_icon {
  padding-left: 3.2em;
  padding: 1.28em 1.6em 1.28em 4em;
}
.btn_icon .span1 {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 0;
  width: 3.2em;
  border-radius: 0.4em 0 0 0.4em;
}
.btn_icon .span1 img {
  width: 48%;
}
.btn_form {
  background: #044ED7;
  color: #fff;
  box-shadow: 0 0.16em 0.32em rgba(4, 78, 215, 0.24);
}
.btn_form::before {
  background-image: url("../images/icon_arrow_3.svg");
}
.btn_top {
  box-shadow: 0 0.16em 0.32em rgba(4, 78, 215, 0.24);
}
.btn_top::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 0.4em;
  border: max(1px, min(0.26vw, 2px)) solid #044ED7;
  position: absolute;
  left: 0;
  top: 0;
}

.fz_up_104 {
  font-size: 104%;
}
.fz_up_112 {
  font-size: 112%;
}
.fz_up_120 {
  font-size: 120%;
}
.fz_up_128 {
  font-size: 128%;
}
.fz_up_136 {
  font-size: 136%;
}
.fz_up_144 {
  font-size: 144%;
}
.fz_up_152 {
  font-size: 152%;
}
.fz_up_160 {
  font-size: 160%;
}
.fz_up_168 {
  font-size: 168%;
}
.fz_up_176 {
  font-size: 176%;
}
.fz_down_88 {
  font-size: 88%;
}
.fz_down_80 {
  font-size: 80%;
}
.fz_down_72 {
  font-size: 72%;
}
.fz_down_64 {
  font-size: 64%;
}

.fw_bold {
  font-weight: bolder;
}
.fw_600 {
  font-weight: 600;
}
.fw_700 {
  font-weight: 700;
}
.fw_900 {
  font-weight: 900;
}
.fw_medium {
  font-weight: 500;
}
.fw_normal {
  font-weight: normal;
}
.fw_300 {
  font-weight: 300;
}

.fs_italic {
  font-style: italic;
}

.blue {
  color: #044ED7;
}

.orange {
  color: #EF6549;
}

.pink {
  color: #E85050;
}

.aligncenter {
  text-align: center !important;
}

@media (min-width: 769px) {
  .pc_hide {
    display: none !important;
  }
}

@media (max-width: 768px) {
  .sp_hide {
    display: none !important;
  }
}

.indent {
  display: block;
  padding-left: 1em;
  text-indent: -1em;
}

.fwh-cta {
  padding: 3.125vw 17.448vw;
  background: #044ED7;
  text-align: center;
  overflow: hidden;
}
@media (max-width: 768px) {
  .fwh-cta {
    padding: 6.25vw 5.208vw;
  }
}
.fwh-cta h2 {
  display: table;
  white-space: nowrap;
  margin: 0.8em auto;
  line-height: 1.6;
  color: #fff;
  font-size: 104%;
  font-weight: 500;
  position: relative;
  padding: 0 0.64em;
}
@media (max-width: 768px) {
  .fwh-cta h2 {
    letter-spacing: 0.2em;
  }
}
.fwh-cta h2::before, .fwh-cta h2::after, .fwh-cta h2 .span1::before, .fwh-cta h2 .span1::after {
  height: 88%;
  content: "";
  width: 1px;
  background: #fff;
  position: absolute;
  bottom: 6%;
  transform-origin: bottom;
}
@media (max-width: 768px) {
  .fwh-cta h2::before, .fwh-cta h2::after, .fwh-cta h2 .span1::before, .fwh-cta h2 .span1::after {
    display: none;
  }
}
.fwh-cta h2::before, .fwh-cta h2 .span1::before {
  left: 0;
  transform: rotate(-32deg);
}
.fwh-cta h2::after, .fwh-cta h2 .span1::after {
  right: 0;
  transform: rotate(32deg);
}
.fwh-cta h2 .span1::before, .fwh-cta h2 .span1::after {
  height: 48%;
}
.fwh-cta h2 .span1::before {
  margin-left: -0.32em;
}
.fwh-cta h2 .span1::after {
  margin-right: -0.32em;
}
@media (max-width: 768px) {
  .fwh-cta h2 .span2 {
    display: table;
    font-size: 144%;
    position: relative;
    margin: auto;
    max-width: 100%;
    padding: 0 0.32em;
  }
  .fwh-cta h2 .span2::before, .fwh-cta h2 .span2::after, .fwh-cta h2 .span2 .span3::before, .fwh-cta h2 .span2 .span3::after {
    height: 56%;
    content: "";
    width: 1px;
    background: #fff;
    position: absolute;
    bottom: 16%;
    transform-origin: bottom;
  }
  .fwh-cta h2 .span2::before, .fwh-cta h2 .span2 .span3::before {
    left: 0;
    transform: rotate(-32deg);
  }
  .fwh-cta h2 .span2::after, .fwh-cta h2 .span2 .span3::after {
    right: 0;
    transform: rotate(32deg);
  }
  .fwh-cta h2 .span2 .span3::before, .fwh-cta h2 .span2 .span3::after {
    height: 32%;
  }
  .fwh-cta h2 .span2 .span3::before {
    margin-left: -0.16em;
  }
  .fwh-cta h2 .span2 .span3::after {
    margin-right: -0.16em;
  }
}
.fwh-cta_content {
  background: #fff;
  display: flex;
  align-items: center;
  padding: 1.042vw;
}
@media (max-width: 768px) {
  .fwh-cta_content {
    display: block;
    padding: 4.167vw;
  }
}
.fwh-cta_content figure {
  width: 50%;
  margin: 1em 0;
  line-height: 0;
}
@media (max-width: 768px) {
  .fwh-cta_content figure {
    width: auto;
    margin: 0;
  }
}
.fwh-cta_content ul {
  width: 50%;
  font-size: 96%;
  padding: 0 1.6em;
}
@media (max-width: 768px) {
  .fwh-cta_content ul {
    width: auto;
    padding: 0;
    font-size: 100%;
  }
}
.fwh-cta_content ul li {
  margin: 1em 0;
}
@media (max-width: 768px) {
  .fwh-cta_content ul li {
    margin: 1em 0 0.4em;
  }
}
.fwh-cta_content ul a {
  display: block;
}
.fwh-cta_footnote {
  font-size: 72%;
  color: #fff;
  text-align: left;
}
@media (max-width: 768px) {
  .fwh-cta_footnote {
    font-size: 56%;
  }
}

.fwh-header {
  height: 4.688vw;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 100;
  background: #fff;
  transition: 0.8s;
  padding: 0 1.042vw;
}
@media (max-width: 768px) {
  .fwh-header {
    height: 13.542vw;
    padding: 0 2.083vw;
  }
}
.fwh-header + * {
  margin-top: 4.688vw;
}
@media (max-width: 768px) {
  .fwh-header + * {
    margin-top: 13.542vw;
  }
}
.fwh-header_logo {
  line-height: 0;
  width: 7.813vw;
}
@media (max-width: 768px) {
  .fwh-header_logo {
    width: 16.667vw;
  }
}
.fwh-header_nav {
  display: flex;
  white-space: nowrap;
  font-size: 74%;
}
@media (max-width: 768px) {
  .fwh-header_nav {
    font-size: 64%;
  }
  .fwh-header_nav a {
    padding: 1em 0;
    width: 36.458vw;
  }
}
.fwh-header_nav li + li {
  margin-left: 1.6em;
}
@media (max-width: 768px) {
  .fwh-header_nav li + li {
    margin-left: 0.8em;
  }
}
.body_sticky .fwh-header {
  box-shadow: 0 0.32em 1.6em rgba(6, 9, 47, 0.16);
}

.fwh-footer {
  margin-top: auto;
  text-align: center;
  line-height: 1.44;
  background: #044ED7;
  color: #fff;
}
.fwh-form_body .fwh-footer {
  background: none;
  color: #06092F;
}
.fwh-footer_nav {
  font-size: 88%;
  display: flex;
  justify-content: center;
  white-space: nowrap;
  padding: 1em 0;
}
.fwh-footer_nav li {
  margin: 0.4em 1.6em;
}
.fwh-footer_nav a {
  text-decoration: underline;
}
.fwh-footer_nav a:hover {
  text-decoration: none;
}
.fwh-footer_product {
  margin: 1em 0;
  letter-spacing: 0.04em;
  font-size: 72%;
}
@media (max-width: 768px) {
  .fwh-footer_product {
    font-size: 56%;
  }
}
.fwh-footer_copyright {
  padding: 0.64em 0;
  letter-spacing: 0.08em;
}
.fwh-footer_copyright small {
  display: block;
  font-size: 72%;
}
@media (max-width: 768px) {
  .fwh-footer_copyright small {
    font-size: 56%;
    padding-bottom: env(safe-area-inset-bottom);
  }
}

.fwh-fv {
  position: relative;
  position: relative;
  z-index: 2;
}
.fwh-fv h1 {
  text-align: center;
  background: #044ED7;
  color: #fff;
  font-size: 112%;
  padding: 0.64em 0;
  font-weight: normal;
  line-height: 1.44;
}
@media (max-width: 768px) {
  .fwh-fv h1 {
    font-size: 128%;
    letter-spacing: 0.2em;
  }
}
.fwh-fv h1 .span1 {
  font-size: 80%;
  display: inline-block;
  color: #044ED7;
  background: #fff;
  border-radius: 16em;
  margin-right: 1em;
  vertical-align: 0.1em;
  padding: 0.2em 1em;
}
@media (max-width: 768px) {
  .fwh-fv h1 .span1 {
    display: table;
    margin: 0.2em auto;
    width: min(67.708vw, 100%);
  }
}
.fwh-fv h1 .span2 {
  font-size: 80%;
}
.fwh-fv h1 strong {
  font-size: 120%;
  display: inline-block;
  vertical-align: -0.04em;
}
.fwh-fv_content {
  padding: 4.167vw 17.448vw 0vw;
  display: flex;
  align-items: center;
  white-space: nowrap;
  justify-content: space-between;
}
@media (max-width: 768px) {
  .fwh-fv_content {
    padding: 8.333vw 5.208vw 0vw;
  }
}
@media (max-width: 768px) {
  .fwh-fv_content {
    display: block;
  }
}
.fwh-fv_content h2 {
  font-weight: normal;
  font-size: 136%;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .fwh-fv_content h2 {
    font-size: 144%;
  }
}
.fwh-fv_content h2 .span1 {
  display: block;
  font-weight: 500;
  font-size: 160%;
}
.fwh-fv_content figure {
  width: 36.458vw;
  margin-right: -2.604vw;
  line-height: 0;
}
@media (max-width: 768px) {
  .fwh-fv_content figure {
    width: auto;
    margin: 0.8em -3.125vw;
  }
}
.fwh-fv_list {
  display: flex;
  justify-content: center;
  text-align: center;
  line-height: 1.36;
  font-size: 72%;
  font-weight: bold;
  color: #044ED7;
  margin: 1.042vw 0 -4.688vw;
  letter-spacing: 0.08em;
}
@media (max-width: 768px) {
  .fwh-fv_list {
    font-size: 80%;
    margin: 0 0 -13.542vw;
  }
}
.fwh-fv_list li {
  background: #fff url("../images/img_fwh-fv_2.svg") no-repeat center/96%;
  border-radius: 50%;
  width: 9.896vw;
  height: 9.896vw;
  box-shadow: 0 0 1.042vw rgba(4, 78, 215, 0.24);
  margin: 0 0.781vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
}
@media (max-width: 768px) {
  .fwh-fv_list li {
    width: 28.125vw;
    height: 28.125vw;
    box-shadow: 0 0 2.083vw rgba(4, 78, 215, 0.24);
    margin: 0 1.563vw;
  }
}
.fwh-fv_list li::before {
  content: "";
  width: 2.4em;
  height: 2.4em;
  border-radius: 50%;
  background: rgba(232, 80, 80, 0.08);
  position: absolute;
  left: 48%;
  top: 1.28em;
}
.fwh-fv_list li img {
  width: auto;
  height: 2.344vw;
  margin-bottom: 0.781vw;
  position: relative;
  z-index: 1;
}
@media (max-width: 768px) {
  .fwh-fv_list li img {
    height: 7.292vw;
    margin-bottom: 1.563vw;
  }
}
.fwh-fv_list .span2 {
  display: inline-block;
  font-size: 128%;
  vertical-align: -0.04em;
}

.fwh {
  /*&-toggle{
      overflow: hidden;
      &_btn{
          &.toggle_js{
              position: relative;
              cursor: pointer;
              z-index: 1;
              &::after{
                  content: '▼';
                  color: $blue;
                  position: absolute;
                  top: $mar-base/2;
                  right: $mar-base/1.25;
                  transition: .4s;
              }
              &.show{
                  &::after{
                      transform: scale(-1,-1);
                  }
              }
          }
      }
      &_panel{
          &.toggle_js{
              >*,&::before,&::after{
                  transition: .8s .24s;
                  opacity: 0;
              }
          }
          &.show{
              >*,&::before,&::after{
                  opacity: 1;
              }
          }
      }
  }*/
}

input[type=text],
input[type=tel],
input[type=email],
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  display: block;
  width: 100%;
  max-width: 100%;
  font-family: "Noto Sans JP", Helvetica, Arial, "Hiragino Sans", YuGothic, "Yu Gothic medium", sans-serif;
  font-size: 96%;
  border: max(1px, min(0.26vw, 2px)) solid #DAD7D6;
  padding: 0.64em;
  margin: 0 0 0.4em;
  transition: 0.4s;
  line-height: 1.6;
  background: #fff;
  border-radius: 0;
  font-weight: normal;
  position: static;
  letter-spacing: inherit;
}
input[type=text][required],
input[type=tel][required],
input[type=email][required],
textarea[required] {
  background: rgba(232, 80, 80, 0.08);
}

label, button {
  cursor: pointer;
  letter-spacing: inherit;
}

.fwh-form {
  padding: 4.167vw 17.448vw;
}
@media (max-width: 768px) {
  .fwh-form {
    padding: 8.333vw 9.375vw;
  }
}
.fwh-form_header {
  line-height: 1.76;
  text-align: center;
}
.fwh-form_header h1 {
  font-size: 176%;
  font-weight: 500;
}
@media (max-width: 768px) {
  .fwh-form_header h1 {
    font-size: 144%;
  }
}
.fwh-form_header h1 small {
  color: #E85050;
  font-size: 48%;
  display: block;
}
.fwh-form_header p {
  margin: 0.64em 0;
  font-size: 128%;
}
@media (max-width: 768px) {
  .fwh-form_header p {
    font-size: 100%;
    margin-bottom: 1.6em;
  }
}
.fwh-form dt .fwh-form01_error {
  display: inline-block;
  vertical-align: 0.2em;
  margin-left: 0.64em;
}
.fwh-form dt #text2_error {
  position: relative;
}
.fwh-form dt #text2_error .fwh-form01_error {
  position: absolute;
  left: 0;
  top: 0.4em;
}
@media (max-width: 768px) {
  .fwh-form dt #text2_error .fwh-form01_error {
    top: 0.2em;
  }
}
.fwh-form dd {
  margin: 0.4em 0 1em;
}
.fwh-form dd.input1 {
  display: flex;
}
.fwh-form dd.input1 input {
  flex: auto;
}
.fwh-form dd.input1 input + input {
  margin-left: 1em;
}
.fwh-form .select1 {
  position: relative;
}
.fwh-form .select1::before {
  content: "";
  pointer-events: none;
  background: url("../images/icon_arrow_2.svg") no-repeat center/32%;
  width: 2.4em;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
}
.fwh-form .select1 select {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  display: block;
  width: 100%;
  max-width: 100%;
  font-family: "Noto Sans JP", Helvetica, Arial, "Hiragino Sans", YuGothic, "Yu Gothic medium", sans-serif;
  font-size: 96%;
  border: max(1px, min(0.26vw, 2px)) solid #DAD7D6;
  padding: 0.64em;
  margin: 0 0 0.4em;
  transition: 0.4s;
  line-height: 1.6;
  background: #fff;
  border-radius: 0;
  font-weight: normal;
  cursor: pointer;
  background: rgba(232, 80, 80, 0.08);
  letter-spacing: inherit;
}
.fwh-form .select1 select.fwh-form_error {
  color: #06092F;
}
.fwh-form ul.radio1 label {
  display: block;
  background: rgba(232, 80, 80, 0.08);
  border: max(1px, min(0.26vw, 2px)) solid #DAD7D6;
  margin-bottom: 0.64em;
  padding: 0.4em;
}
.fwh-form ul.radio1 .span1::before {
  content: "";
  width: 1em;
  height: 1em;
  border-radius: 50%;
  display: inline-block;
  box-shadow: 0 0 0 max(1px, min(0.26vw, 2px)) #DAD7D6;
  margin-right: 0.64em;
  border: max(1px, min(0.391vw, 4px)) solid #fff;
  transition: 0.24s;
  background: #fff;
  vertical-align: -0.16em;
}
.fwh-form ul.radio1 input {
  margin: 0;
  opacity: 0;
  width: 1px;
  height: 1px;
  line-height: 0;
  font-size: 0;
  display: inline;
}
.fwh-form ul.radio1 input:checked + .span1::before {
  background: #E85050;
}
.fwh-form sup {
  color: #E85050;
}
.fwh-form_footer {
  text-align: center;
  margin-top: 3.125vw;
  white-space: nowrap;
}
@media (max-width: 768px) {
  .fwh-form_footer {
    margin-top: 6.25vw;
  }
}
.fwh-form_footer a {
  text-decoration: underline;
}
.fwh-form_footer a:hover {
  text-decoration: none;
}
.fwh-form_footer .span1::before {
  content: "";
  width: 1.28em;
  height: 1.28em;
  display: inline-block;
  margin-right: 0.64em;
  border: max(1px, min(0.26vw, 2px)) solid #DAD7D6;
  transition: 0.24s;
  background: #fff url("../images/icon_check_2.svg") no-repeat center/72%;
  vertical-align: -0.32em;
}
.fwh-form_footer input {
  margin: 0;
  opacity: 0;
  width: 1px;
  height: 1px;
  line-height: 0;
  font-size: 0;
  display: inline;
}
.fwh-form_footer input:checked + .span1::before {
  background-color: #E85050;
  border-color: #E85050;
}
.fwh-form_footer button {
  display: block;
  font-size: 120%;
  width: 28.646vw;
  margin: 0.8em auto;
}
@media (max-width: 768px) {
  .fwh-form_footer button {
    width: 88%;
    font-size: 100%;
  }
}
@media (max-width: 768px) {
  .fwh-form_footer p:first-child {
    font-size: 80%;
  }
}
.fwh-form_error {
  display: block;
  color: #e00000;
  font-size: 1.042vw;
  font-weight: 500;
  line-height: 1.36;
  white-space: nowrap;
  margin-bottom: 0.4em;
}
@media (max-width: 768px) {
  .fwh-form_error {
    font-size: 2.865vw;
  }
}
.fwh-form_error::before {
  content: "!";
  color: #fff;
  background: #e00000;
  border-radius: 50%;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 1.6em;
  height: 1.6em;
  font-size: 72%;
  text-align: center;
  vertical-align: 0.04em;
  margin-right: 0.4em;
  font-weight: bold;
  letter-spacing: 0;
}
.fwh-thanks {
  padding: 4.167vw 17.448vw;
  flex: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}
@media (max-width: 768px) {
  .fwh-thanks {
    padding: 8.333vw 9.375vw;
  }
}
.fwh-thanks_header {
  margin-bottom: 1.6em;
}
.fwh-thanks_header::before {
  content: "";
  display: block;
  background: url("../images/icon_mail_2.svg") no-repeat center/contain;
  height: 7.292vw;
  margin-bottom: 3.125vw;
}
@media (max-width: 768px) {
  .fwh-thanks_header::before {
    height: 19.792vw;
    margin-bottom: 6.25vw;
  }
}
.fwh-thanks_header h1 {
  color: #044ED7;
  font-weight: 500;
  font-size: 144%;
}
.fwh-thanks_content {
  background: #F8F4F1;
  padding: 1.6em 0;
  width: min(100%, 784px);
  margin: 0 auto;
}
.fwh-thanks_content .btn_download {
  margin-top: 1em;
  width: 26.042vw;
}
@media (max-width: 768px) {
  .fwh-thanks_content .btn_download {
    width: 80%;
    font-size: 88%;
  }
}
.fwh-thanks_footer p {
  margin: 1.6em 0;
}
.fwh-thanks_footer .link1 {
  display: block;
  width: min(100%, 784px);
  margin: 1em auto;
  border: max(1px, min(0.26vw, 2px)) solid #E85050;
  padding: 0.8em 0;
}
.fwh-thanks_footer .btn_top {
  width: 26.042vw;
  margin-top: 1.6em;
}
@media (max-width: 768px) {
  .fwh-thanks_footer .btn_top {
    width: 80%;
    font-size: 88%;
  }
}

.fwh-sec01 {
  padding-top: 5.729vw;
}
@media (max-width: 768px) {
  .fwh-sec01 {
    padding-top: 16.667vw;
  }
}
.fwh-sec02 {
  padding: 4.167vw 17.448vw;
  background: #F8F4F1;
}
@media (max-width: 768px) {
  .fwh-sec02 {
    padding: 8.333vw 5.208vw;
  }
}
.fwh-sec02 > h2 {
  text-align: center;
  line-height: 1.52;
  font-size: 120%;
  font-weight: 500;
}
@media (max-width: 768px) {
  .fwh-sec02 > h2 {
    font-size: 96%;
    letter-spacing: 0.2em;
  }
}
.fwh-sec02 > h2 .span1 {
  display: block;
  font-size: 160%;
}
@media (max-width: 768px) {
  .fwh-sec02 > h2 .span1 {
    font-size: 192%;
  }
}
.fwh-sec02 > h3 {
  font-size: 120%;
  font-weight: 500;
  line-height: 1.52;
  background: #044ED7 url("../images/icon_deco_1.svg") no-repeat 1.28em 1.185em/0.64em;
  color: #fff;
  display: table;
  max-width: 100%;
  padding: 0.64em 0.8em 0.64em 2.56em;
  margin: 3.2em 0 1em;
}
@media (max-width: 768px) {
  .fwh-sec02 > h3 {
    font-size: 104%;
    margin: 1.6em 0 1em -5.208vw;
  }
}
.fwh-sec02_pfs {
  background: #fff;
  margin: 2.083vw 0;
  padding: 2.083vw;
}
@media (max-width: 768px) {
  .fwh-sec02_pfs {
    margin: 5.208vw 0;
    padding: 4.167vw;
  }
}
.fwh-sec02_pfs h4 {
  text-align: center;
  font-size: 144%;
  font-weight: 500;
  color: #044ED7;
}
@media (max-width: 768px) {
  .fwh-sec02_pfs h4 {
    font-size: 100%;
  }
}
.fwh-sec02_pfs_list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  line-height: 1.68;
  letter-spacing: 0.08em;
}
.fwh-sec02_pfs_list dl {
  background: #F8F4F1 url("../images/img_fwh-sec02_1.svg") no-repeat right 0.32em bottom 0.32em/auto 3.385vw;
  width: 23%;
  font-weight: 500;
  padding: 0.4em 0 2.56em;
  margin: 1em 0 0;
}
@media (max-width: 768px) {
  .fwh-sec02_pfs_list dl {
    width: 48%;
    padding-bottom: 1em;
    background-size: auto 8.333vw;
  }
}
.fwh-sec02_pfs_list dl:nth-of-type(2) {
  background-image: url("../images/img_fwh-sec02_2.svg");
}
.fwh-sec02_pfs_list dl:nth-of-type(3) {
  background-image: url("../images/img_fwh-sec02_3.svg");
}
.fwh-sec02_pfs_list dl:nth-of-type(4) {
  background-image: url("../images/img_fwh-sec02_4.svg");
}
.fwh-sec02_pfs_list dt {
  text-align: center;
  font-size: 88%;
  background: #DAD7D6;
  margin: 0.64em 0;
}
.fwh-sec02_pfs_list dd {
  font-size: 72%;
  padding: 0 1em;
}
.fwh-sec02_pfs_list dd::before {
  content: "・";
  margin-right: 0.2em;
}
.fwh-sec02_pfs_note {
  text-align: right;
}
.fwh-sec02_pfs_note small {
  font-weight: 500;
}
.fwh-sec02 > h4 {
  text-align: center;
  color: #044ED7;
  font-weight: 500;
  font-size: 128%;
  line-height: 1.36;
  display: table;
  max-width: 100%;
  position: relative;
  padding: 0 1.28em;
  margin: 2.4em auto 1em;
}
@media (max-width: 768px) {
  .fwh-sec02 > h4 {
    font-size: 120%;
    margin: 1.6em auto 0.8em;
  }
}
.fwh-sec02 > h4::before, .fwh-sec02 > h4::after {
  content: "";
  height: calc(100% + 0.4em);
  width: 0.4em;
  border: max(1px, min(0.391vw, 2px)) solid;
  position: absolute;
  top: -0.2em;
}
.fwh-sec02 > h4::before {
  left: 0;
  border-right: none;
}
.fwh-sec02 > h4::after {
  right: 0;
  border-left: none;
}
.fwh-sec02_content {
  display: flex;
  flex-wrap: wrap;
}
.fwh-sec02_content figure, .fwh-sec02_content_text {
  width: 50%;
  margin: 0.8em 0;
}
@media (max-width: 768px) {
  .fwh-sec02_content figure, .fwh-sec02_content_text {
    width: 100%;
  }
}
.fwh-sec02_content figure {
  line-height: 0;
  padding-right: 2.083vw;
}
.fwh-sec02_content figcaption {
  line-height: 1.6;
  font-size: 80%;
  margin-top: 0.64em;
  letter-spacing: 0.08em;
}
.fwh-sec02_content_text p + p {
  margin-top: 0.8em;
}
.fwh-sec02_content_text small {
  display: block;
  line-height: 1.6;
}
.fwh-sec03 {
  padding: 7.813vw 25vw 1.563vw;
  position: relative;
  overflow: hidden;
}
@media (max-width: 768px) {
  .fwh-sec03 {
    padding: 15.625vw 5.208vw 3.125vw;
  }
}
.fwh-sec03::before, .fwh-sec03::after {
  content: "";
  width: 50.1%;
  height: 5.729vw;
  background: #F8F4F1;
  position: absolute;
  bottom: 100%;
}
@media (max-width: 768px) {
  .fwh-sec03::before, .fwh-sec03::after {
    height: 11.458vw;
  }
}
.fwh-sec03::before {
  left: 0;
  transform-origin: left bottom;
  transform: skewY(6.4deg);
}
@media (max-width: 768px) {
  .fwh-sec03::before {
    transform: skewY(9.6deg);
  }
}
.fwh-sec03::after {
  right: 0;
  transform-origin: right bottom;
  transform: skewY(-6.4deg);
}
@media (max-width: 768px) {
  .fwh-sec03::after {
    transform: skewY(-9.6deg);
  }
}
.fwh-sec03 h2 {
  text-align: center;
  font-weight: 500;
  font-size: 128%;
  line-height: 1.36;
  margin: 1.6em 0;
}
@media (max-width: 768px) {
  .fwh-sec03 h2 {
    margin: 0 0 1em;
    font-size: 136%;
    letter-spacing: 0.2em;
  }
}
.fwh-sec03 h2 .span1 {
  display: block;
  font-size: 120%;
}
.fwh-sec03 h2 .span2 {
  font-size: 136%;
  display: inline-block;
  vertical-align: -0.04em;
  margin: -0.08em 0;
}
.fwh-sec03 li {
  background: #F8F4F1 url("../images/icon_check_1.svg") no-repeat 1.28em 1.143em/1.6em;
  margin: 1em 0;
  padding: 1em 0.8em 1em 3.68em;
}
@media (max-width: 768px) {
  .fwh-sec03 li {
    font-size: 96%;
  }
}
.fwh-sec04 {
  padding: 2.083vw 17.448vw;
  text-align: center;
}
@media (max-width: 768px) {
  .fwh-sec04 {
    padding: 4.167vw 0vw;
  }
}
.fwh-sec04 h2 {
  font-weight: 500;
  font-size: 192%;
  color: #044ED7;
  margin-bottom: 0.4em;
}
.fwh-sec04_product {
  background: #F8F4F1;
  padding-bottom: 2.083vw;
}
@media (max-width: 768px) {
  .fwh-sec04_product {
    padding-bottom: 6.25vw;
  }
}
.fwh-sec04_product h3 {
  font-weight: 500;
  background: #044ED7;
  color: #fff;
  font-size: 136%;
  margin-bottom: 1.6em;
}
@media (max-width: 768px) {
  .fwh-sec04_product h3 {
    font-size: 128%;
  }
}
.fwh-sec04_product h3 .span1 {
  display: table;
  margin: auto;
  max-width: 100%;
  padding: 0.32em 1.28em;
  position: relative;
}
.fwh-sec04_product h3 .span1::before, .fwh-sec04_product h3 .span1::after {
  content: "";
  background: url("../images/icon_deco_1.svg") no-repeat center/contain;
  width: 0.64em;
  height: 0.64em;
  position: absolute;
  top: 50%;
}
.fwh-sec04_product h3 .span1::before {
  left: 0;
  transform: translateY(-40%);
}
.fwh-sec04_product h3 .span1::after {
  right: 0;
  transform: translateY(-40%) scaleX(-1);
}
@media (max-width: 768px) {
  .fwh-sec04_product h3 .span2 {
    font-size: 72%;
  }
}
.fwh-sec04_product_figure, .fwh-sec04_product > figure {
  width: 45.313vw;
  margin: 1em auto;
  line-height: 0;
}
@media (max-width: 768px) {
  .fwh-sec04_product_figure, .fwh-sec04_product > figure {
    width: 89.583vw;
  }
}
.fwh-sec04_product_figure {
  display: flex;
  justify-content: space-between;
}
.fwh-sec04_product_figure figure {
  background: #fff;
  width: 48%;
  padding: 1.563vw 1.042vw;
}
@media (max-width: 768px) {
  .fwh-sec04_product_figure figure {
    padding: 3.125vw 2.083vw;
  }
}
.fwh-sec04_product_figure figcaption {
  line-height: 1.36;
  font-size: 112%;
}
@media (max-width: 768px) {
  .fwh-sec04_product_figure figcaption {
    font-size: 88%;
  }
}
.fwh-sec04_product_figure figcaption::after {
  content: "";
  width: 1.28em;
  height: 1px;
  background: #044ED7;
  display: block;
  margin: 0.64em auto;
}
.fwh-sec04_product + .fwh-sec04_product {
  margin-top: 3.125vw;
}
@media (max-width: 768px) {
  .fwh-sec04_product + .fwh-sec04_product {
    margin: 0;
  }
}
.fwh-sec05 {
  padding: 4.167vw 17.448vw;
}
@media (max-width: 768px) {
  .fwh-sec05 {
    padding: 8.333vw 5.208vw;
  }
}
.fwh-sec05_header {
  text-align: center;
}
.fwh-sec05_header p {
  max-width: 100%;
  display: table;
  margin: auto;
  border-radius: 16em;
  position: relative;
  background: #E85050;
  color: #fff;
  font-weight: 500;
  font-size: 120%;
  padding: 0.32em 1.6em;
}
@media (max-width: 768px) {
  .fwh-sec05_header p {
    font-size: 88%;
  }
}
.fwh-sec05_header p::before {
  content: "▼";
  line-height: 1.04;
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translate(-50%, -32%) scaleX(1.5);
  font-size: 56%;
  color: #E85050;
}
.fwh-sec05_header h2 {
  font-weight: 500;
  font-size: 168%;
  margin: 0.64em 0;
  line-height: 1.52;
}
@media (max-width: 768px) {
  .fwh-sec05_header h2 {
    font-size: 136%;
    letter-spacing: 0.16em;
  }
}
.fwh-sec05_content {
  background: #fff;
  box-shadow: 0 0.26vw 1.042vw rgba(0, 0, 0, 0.16);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding: 2.604vw;
  margin: 2.604vw 0;
}
@media (max-width: 768px) {
  .fwh-sec05_content {
    box-shadow: 0 0.521vw 2.083vw rgba(0, 0, 0, 0.16);
    padding: 4.167vw;
    margin: 4.167vw 0;
  }
}
.fwh-sec05_content figure, .fwh-sec05_content_text {
  width: 50%;
}
@media (max-width: 768px) {
  .fwh-sec05_content figure, .fwh-sec05_content_text {
    width: 100%;
  }
}
.fwh-sec05_content figure {
  line-height: 0;
  padding-right: 2.083vw;
}
@media (max-width: 768px) {
  .fwh-sec05_content figure {
    padding: 0;
    margin-bottom: 1em;
  }
}
.fwh-sec05_content_text {
  font-size: 88%;
}
.fwh-sec05_content_text p + p {
  margin-top: 0.8em;
}/*# sourceMappingURL=style.css.map */