@charset "UTF-8";
/*
see: http://html5doctor.com/html-5-reset-stylesheet/
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-SemiBold.woff2") format("woff2"), url("../fonts/NotoSansJP-SemiBold.woff") format("woff");
  font-weight: 600;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-Bold.woff2") format("woff2"), url("../fonts/NotoSansJP-Bold.woff") format("woff");
  font-weight: 700;
  font-display: swap;
}
html {
  font-size: 62.5%;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  scroll-behavior: smooth;
  font-family: "Noto Sans Jp", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: 600;
}

.body {
  margin: 0 auto;
  color: #333333;
  font-family: "Noto Sans Jp", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ ProN", "メイリオ", Meiryo, sans-serif;
  font-size: calc(1.6rem * 1);
  line-height: 1;
  text-align: center;
  position: relative;
  z-index: -9999;
}

.main {
  margin: 0 auto;
  position: relative;
  z-index: -9999;
  background-color: white;
  max-width: 750px;
  margin: 0 auto;
}

a {
  text-decoration: none;
  color: #333333;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  display: block;
}

a:hover {
  opacity: 0.5;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

span {
  line-height: 1;
  display: block;
}

img {
  vertical-align: top;
}

ol,
ul {
  list-style: none;
}

img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

#contact:before {
  display: block;
  height: 7rem;
  margin-top: -7rem;
  content: "";
}

* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  text-align: left;
}

.cta {
  position: absolute;
  left: 50%;
  bottom: min(9.4871794872vw, 71.1538461538px);
  width: 81.53846%;
  height: min(14.0128205128vw, 105.0961538462px);
  margin: 0 auto;
  background-color: #bf3859;
  border-radius: min(5.1282051282vw, 38.4615384615px);
  -webkit-filter: drop-shadow(2px 2px 0px rgba(207, 141, 157, 0.2));
          filter: drop-shadow(2px 2px 0px rgba(207, 141, 157, 0.2));
  -webkit-transform: translateX(-50%) translateY(0px) translateZ(0px);
          transform: translateX(-50%) translateY(0px) translateZ(0px);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  overflow: hidden;
}
.cta:hover {
  -webkit-transform: translateX(-50%) translateY(2px) translateZ(0px);
          transform: translateX(-50%) translateY(2px) translateZ(0px);
  -webkit-filter: drop-shadow(0px 0px 0px rgba(207, 141, 157, 0.2));
          filter: drop-shadow(0px 0px 0px rgba(207, 141, 157, 0.2));
}
@-webkit-keyframes shinyshiny {
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}
.cta:before {
  position: absolute;
  content: "";
  display: inline-block;
  top: -50px;
  left: 0;
  width: min(7.6923076923vw, 57.6923076923px);
  height: 100%;
  background-color: color-mix(in srgb, white 90%, #bf3859 10%);
  -webkit-animation: shinyshiny 3s ease-in-out infinite;
          animation: shinyshiny 3s ease-in-out infinite;
}
.cta a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
}
.cta a span {
  color: white;
  font-size: min(4.6153846154vw, 34.6153846154px);
  margin-right: min(6.1538461538vw, 46.1538461538px);
  font-weight: 600;
  margin-bottom: min(0.5128205128vw, 3.8461538462px);
}
.cta img {
  width: 6.87421%;
  aspect-ratio: 21.86/22;
  -o-object-fit: contain;
     object-fit: contain;
  margin-top: min(0.5128205128vw, 3.8461538462px);
}

.body {
  position: relative;
}

.main {
  background-color: white;
  overflow: hidden;
}

.fv {
  position: relative;
}
.fv .text {
  width: min(21.02564vw, 157.69px);
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: min(22.58205vw, 169.365px);
}

.concern {
  position: relative;
}
.concern:after {
  content: "";
  width: min(0.2564102564vw, 1.9230769231px);
  height: min(7.6153846154vw, 57.1153846154px);
  position: absolute;
  z-index: 1000;
  top: max(-3.8076923077vw, -28.5576923077px);
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background-color: #bf3859;
}

.reason {
  position: relative;
}

.contact {
  background: #fcecef;
  padding-top: min(13.8461538462vw, 103.8461538462px);
  padding-right: min(8.7179487179vw, 65.3846153846px);
  padding-bottom: min(10.7692307692vw, 80.7692307692px);
  padding-left: min(9.2307692308vw, 69.2307692308px);
  position: relative;
}
.contact:after {
  content: "CONTACT";
  color: white;
  opacity: 0.63;
  font-weight: 700;
  font-size: min(16.4102564103vw, 123.0769230769px);
  line-height: 0.6;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.contact .head {
  color: #bf3859;
  font-weight: 600;
  font-size: min(4.6153846154vw, 34.6153846154px);
  text-align: center;
  line-height: calc(22 / 18);
  margin-bottom: min(9.4871794872vw, 71.1538461538px);
  position: relative;
}
.contact .head:after {
  content: "";
  width: 11.53846%;
  height: min(0.2564102564vw, 1.9230769231px);
  background-color: #bf3859;
  position: absolute;
  top: min(8.4615384615vw, 63.4615384615px);
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.contact .para {
  color: #4b4b4b;
  font-size: min(3.5897435897vw, 26.9230769231px);
  font-weight: 600;
  line-height: calc(20 / 14);
  text-align: center;
}
.contact .para-top {
  margin-bottom: min(1.7948717949vw, 13.4615384615px);
}
.contact .para-bottom {
  margin-bottom: min(7.9487179487vw, 59.6153846154px);
}
.contact .form {
  background: white;
  width: 100%;
  padding-top: min(4.1025641026vw, 30.7692307692px);
  padding-right: min(6.9230769231vw, 51.9230769231px);
  padding-bottom: min(6.1538461538vw, 46.1538461538px);
  padding-left: min(6.1538461538vw, 46.1538461538px);
}
.contact .form input[type=text]:focus,
.contact .form textarea[type=text]:focus {
  outline: #bf3859 2px solid;
}
.contact .form__content {
  margin-bottom: min(5.3846153846vw, 40.3846153846px);
}
.contact .form__content__list {
  margin-bottom: min(2.8205128205vw, 21.1538461538px);
}
.contact .form__content__list .list__label {
  font-size: min(3.0769230769vw, 23.0769230769px);
  font-weight: 600;
  line-height: calc(22 / 12);
  color: #bf3859;
}
.contact .form__content__list .list__name {
  width: 100%;
  height: min(8.9743589744vw, 67.3076923077px);
  border-radius: min(1.0256410256vw, 7.6923076923px);
  background-color: #f5f5f5;
  border: none;
  font-size: min(4.1025641026vw, 30.7692307692px);
  padding-right: min(2.0512820513vw, 15.3846153846px);
  padding-left: min(2.0512820513vw, 15.3846153846px);
}
.contact .form input,
.contact .form textarea {
  font-weight: 600;
}
.contact .form textarea#message {
  padding: min(2.0512820513vw, 15.3846153846px);
  height: min(48.4615384615vw, 363.4615384615px);
  font-family: "Noto Sans Jp", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: normal;
}
.contact .form .caution {
  font-size: min(3.0769230769vw, 23.0769230769px);
  color: #4b4b4b;
  line-height: calc(18 / 12);
  font-weight: 600;
  margin-bottom: min(5.3846153846vw, 40.3846153846px);
  text-align: center;
}
.contact .form .caution a {
  display: inline-block;
  color: inherit;
  border-bottom: 2px solid #4b4b4b;
}
.contact .form button {
  border: none;
}
.contact .form .cta {
  width: min(68.9743589744vw, 517.3076923077px);
  height: min(12.0512820513vw, 90.3846153846px);
  position: static;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  border-radius: min(5.1282051282vw, 38.4615384615px);
  -webkit-filter: drop-shadow(2px 2px 0px rgba(207, 141, 157, 0.41));
          filter: drop-shadow(2px 2px 0px rgba(207, 141, 157, 0.41));
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
}
.contact .form .cta:hover {
  -webkit-transform: translateX(0) translateY(2px) translateZ(0px);
          transform: translateX(0) translateY(2px) translateZ(0px);
  -webkit-filter: drop-shadow(0px 0px 0px rgba(207, 141, 157, 0.41));
          filter: drop-shadow(0px 0px 0px rgba(207, 141, 157, 0.41));
  opacity: 0.5;
}
.contact .form .cta span {
  font-size: min(4.1025641026vw, 30.7692307692px);
  color: white;
  margin-right: min(6.1538461538vw, 46.1538461538px);
  font-weight: 600;
}
.contact .form .cta img {
  width: min(4.741025641vw, 35.5576923077px);
}
.contact .form #error-message {
  color: #b30f00 !important;
  border: 2px #e61300 solid;
  padding: min(2.0512820513vw, 15.3846153846px);
  text-align: center;
  font-size: min(3.5897435897vw, 26.9230769231px);
  margin-bottom: min(4.1025641026vw, 30.7692307692px);
}
.contact .form #error-message p {
  margin-bottom: min(1.0256410256vw, 7.6923076923px);
  text-align: center;
}/*# sourceMappingURL=index.css.map */