@charset "UTF-8";
body {
  color: #000;
  font-size: 16px;
  background-color: #fff;
  padding-top: 68.8px;
  letter-spacing: 0.1em;
  line-height: 1.5;
  font-family: "メイリオ", "Meiryo", "ＭＳ ゴシック", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
}
@media (min-width: 480px) {
  body {
    padding-top: 76.8px;
  }
}
@media (min-width: 960px) {
  body {
    padding-top: 96px;
  }
}

a:hover, a:active, a:focus {
  color: #000;
}

img {
  max-width: 100%;
  max-height: 100%;
}

/*-----------------------
visibility
-------------------------*/
.hidden {
  display: none !important;
}

@media (min-width: 480px) {
  .hidden_xs {
    display: none !important;
  }
}
@media (min-width: 640px) {
  .hidden_s {
    display: none !important;
  }
}
@media (min-width: 769px) {
  .hidden_mm {
    display: none !important;
  }
}
@media (min-width: 960px) {
  .hidden_m {
    display: none !important;
  }
}
@media (min-width: 1200px) {
  .hidden_l {
    display: none !important;
  }
}
@media (min-width: 1600px) {
  .hidden_xl {
    display: none !important;
  }
}
@media (max-width: 479px) {
  .visible_xs {
    display: none !important;
  }
}
@media (max-width: 639px) {
  .visible_s {
    display: none !important;
  }
}
@media (max-width: 768px) {
  .visible_mm {
    display: none !important;
  }
}
@media (max-width: 959px) {
  .visible_m {
    display: none !important;
  }
}
@media (max-width: 1199px) {
  .visible_l {
    display: none !important;
  }
}
@media (max-width: 1599px) {
  .visible_xl {
    display: none !important;
  }
}
/*-----------------------
 margin
-------------------------*/
.com-mt-1em {
  margin-top: 1em;
}

/*-----------------------
section
-------------------------*/
.com-sec-01 {
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
}
@media (min-width: 640px) {
  .com-sec-01 {
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media (min-width: 960px) {
  .com-sec-01 {
    padding-left: 40px;
    padding-right: 40px;
  }
}

/*-----------------------
 bg-color
-------------------------*/
.com-bg-blue {
  background-color: #bad9eb;
}

/*-----------------------
 font-color
-------------------------*/
.com-font-red {
  color: #D81C4D;
}

/*-----------------------
 title
-------------------------*/
.com-tit-01 {
  font-weight: bold;
  font-size: 24px;
  text-align: center;
}
@media (min-width: 960px) {
  .com-tit-01 {
    font-size: 30px;
  }
}
.com-tit-01.left {
  -moz-text-align-last: left;
       text-align-last: left;
}

/*-----------------------
 block
-------------------------*/
.com-block-contact {
  padding-top: 36px;
  padding-bottom: 40.8px;
  text-align: center;
  font-weight: bold;
}
@media (min-width: 960px) {
  .com-block-contact {
    padding-top: 45px;
    padding-bottom: 51px;
  }
}
@media (max-width: 479px) {
  .com-block-contact {
    letter-spacing: 0.07em;
  }
}

.block-contact-txt-01 {
  font-size: 18px;
}
@media (min-width: 960px) {
  .block-contact-txt-01 {
    font-size: 30px;
  }
}
@media (min-width: 480px) {
  .block-contact-txt-01 {
    font-size: 24px;
  }
}
.block-contact-txt-01 .com-font-red {
  font-size: 23.4px;
}
@media (min-width: 960px) {
  .block-contact-txt-01 .com-font-red {
    font-size: 36px;
  }
}
@media (min-width: 480px) {
  .block-contact-txt-01 .com-font-red {
    font-size: 28.8px;
  }
}

.block-contact-txt-02 {
  font-size: 15.6px;
}
@media (min-width: 960px) {
  .block-contact-txt-02 {
    font-size: 24px;
  }
}
@media (min-width: 480px) {
  .block-contact-txt-02 {
    font-size: 19.2px;
  }
}
@media (max-width: 767px) {
  .block-contact-txt-02 {
    margin-top: 0.5em;
  }
}

.block-contact-btn {
  background-color: #D81C4D;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border: 1px solid #000;
  border-radius: 30px;
  max-width: 351px;
  max-height: 60px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-top: 9.5px;
  padding-bottom: 5.5px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 36.8px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media (min-width: 480px) {
  .block-contact-btn {
    max-width: 432px;
  }
}
@media (min-width: 960px) {
  .block-contact-btn {
    margin-top: 46px;
    max-width: 540px;
  }
}
.block-contact-btn:hover {
  -webkit-box-shadow: 0px 5px 0 #000;
          box-shadow: 0px 5px 0 #000;
  -webkit-transform: translateY(5px);
          transform: translateY(5px);
}
.block-contact-btn span {
  color: #fff;
  font-weight: bold;
  font-size: 19.5px;
  display: inline-block;
  position: relative;
  padding-right: 30px;
}
@media (min-width: 480px) {
  .block-contact-btn span {
    font-size: 24px;
    padding-right: 40px;
  }
}
@media (min-width: 960px) {
  .block-contact-btn span {
    font-size: 30px;
    padding-right: 50px;
  }
}
.block-contact-btn span::after {
  content: "";
  background-image: url(../images/block-contact_01.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 41.6px;
  height: 46.8px;
  position: absolute;
  bottom: -22.1px;
  right: -13px;
}
@media (min-width: 480px) {
  .block-contact-btn span::after {
    width: 51.2px;
    height: 57.6px;
    bottom: -27.2px;
    right: -20px;
  }
}
@media (min-width: 960px) {
  .block-contact-btn span::after {
    width: 64px;
    height: 72px;
    bottom: -34px;
    right: -25px;
  }
}

/*-----------------------
 header
-------------------------*/
#header {
  background-color: rgba(255, 255, 255, 0.8);
  position: fixed;
  z-index: 999;
  top: 0;
  left: 0;
  width: 100%;
  height: 68.8px;
  padding-top: 20px;
  padding-bottom: 12.8px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.05);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.05);
}
@media (min-width: 480px) {
  #header {
    height: 76.8px;
  }
}
@media (min-width: 960px) {
  #header {
    height: 96px;
    padding-top: 25px;
    padding-bottom: 16px;
  }
}

.header-wrapper {
  max-width: 927px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
  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;
}
@media (min-width: 640px) {
  .header-wrapper {
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media (min-width: 960px) {
  .header-wrapper {
    padding-left: 40px;
    padding-right: 40px;
  }
}

.header-logo {
  text-align: center;
  max-height: 60.79px;
  margin-right: 1em;
}
.header-logo img {
  width: 244.4px;
}
@media (min-width: 960px) {
  .header-logo img {
    width: 376px;
  }
}
@media (min-width: 480px) {
  .header-logo img {
    width: 300.8px;
  }
}
.header-logo span {
  display: block;
  font-size: 11px;
  line-height: 1;
  margin-bottom: -4px;
  margin-left: 27.3px;
  letter-spacing: 0;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media (min-width: 960px) {
  .header-logo span {
    font-size: 16.58px;
    margin-left: 42px;
  }
}
@media (min-width: 480px) {
  .header-logo span {
    font-size: 13.2px;
    margin-left: 33.6px;
  }
}
.header-logo:hover {
  opacity: 0.8;
}

.header-btn-contact {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: #fff;
  font-weight: bold;
  background-color: #d81c4d;
  border: 2px solid #d81c4d;
  width: 115.2px;
  height: 34.5px;
  border-radius: 10px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.header-btn-contact:visited, .header-btn-contact:link {
  color: #fff;
}
.header-btn-contact:hover {
  background-color: #fff;
  color: #d81c4d;
}
.header-btn-contact:hover div::after {
  border-color: transparent transparent transparent #d81c4d;
}
@media (max-width: 479px) {
  .header-btn-contact {
    font-size: 14.4px;
  }
}
@media (min-width: 480px) {
  .header-btn-contact {
    width: 144.5px;
    height: 43.2px;
  }
}
@media (min-width: 640px) {
  .header-btn-contact {
    width: 260.1px;
  }
}
@media (min-width: 960px) {
  .header-btn-contact {
    width: 289px;
    height: 48px;
  }
}
.header-btn-contact div {
  position: relative;
  padding-right: 15px;
}
@media (min-width: 480px) {
  .header-btn-contact div {
    padding-right: 31px;
  }
}
.header-btn-contact div::after {
  content: "";
  width: 0;
  height: 0;
  display: block;
  border-style: solid;
  border-width: 5.25px 0 5.25px 9.8px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
@media (min-width: 480px) {
  .header-btn-contact div::after {
    border-width: 7.5px 0 7.5px 14px;
  }
}

/*-----------------------
 footer
-------------------------*/
#footer {
  font-size: 10px;
  text-align: center;
  padding-top: 50.4px;
  padding-bottom: 48.8px;
  letter-spacing: 0;
}
@media (min-width: 960px) {
  #footer {
    font-size: 12px;
    padding-top: 63px;
    padding-bottom: 61px;
  }
}

/*-----------------------
 thanks
-------------------------*/
#thanks {
  text-align: center;
  font-size: 16px;
  line-height: 1.5;
  padding-top: 65.6px;
  padding-bottom: 58px;
}
@media (min-width: 960px) {
  #thanks {
    padding-top: 82px;
    padding-bottom: 72.5px;
  }
}
#thanks h2 {
  font-weight: bold;
  font-size: 20px;
}
@media (min-width: 960px) {
  #thanks h2 {
    font-size: 24px;
  }
}
#thanks p:last-child {
  margin-top: 1em;
}

/*-----------------------
 #home-01
-------------------------*/
.home-01-wrapper {
  padding-top: 30px;
  max-width: 951.7px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 768px) {
  .home-01-wrapper {
    padding-top: 20px;
    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;
  }
}
.home-01-wrapper .left {
  z-index: 10;
}
@media (min-width: 768px) {
  .home-01-wrapper .left {
    max-width: 566px;
    width: 59.4%;
  }
}
.home-01-wrapper .right {
  z-index: 1;
}
@media (min-width: 768px) {
  .home-01-wrapper .right {
    margin-left: -8.7%;
    -ms-flex-item-align: self-end;
        -ms-grid-row-align: self-end;
        align-self: self-end;
  }
}
.home-01-wrapper p {
  text-align: center;
}

.home-01-tit {
  font-weight: bold;
  text-align: center;
  font-size: 16px;
}
@media (min-width: 768px) {
  .home-01-tit {
    white-space: nowrap;
  }
}
@media (min-width: 640px) {
  .home-01-tit {
    font-size: 23.4px;
  }
}
@media (min-width: 960px) {
  .home-01-tit {
    font-size: 26px;
  }
}
.home-01-tit .com-font-red {
  letter-spacing: 0.05em;
  font-size: 25px;
}
@media (min-width: 640px) {
  .home-01-tit .com-font-red {
    font-size: 28.8px;
  }
}
@media (min-width: 960px) {
  .home-01-tit .com-font-red {
    font-size: 36px;
  }
}

.home-01-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-left: auto;
  margin-right: auto;
  margin-top: 23px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (max-width: 959px) {
  .home-01-list {
    max-width: 452.92px;
  }
}
@media (max-width: 767px) {
  .home-01-list {
    max-width: 470px;
  }
}
@media screen and (min-width: 400px) {
  .home-01-list {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    max-width: 370px;
  }
}
@media (min-width: 480px) {
  .home-01-list {
    margin-top: 33px;
    max-width: 470px;
  }
}
@media (min-width: 640px) {
  .home-01-list {
    margin-top: 44px;
  }
}
@media (min-width: 768px) {
  .home-01-list {
    max-width: 452.92px;
  }
}
@media (min-width: 960px) {
  .home-01-list {
    margin-top: 55px;
    max-width: 100%;
  }
}
.home-01-list li {
  border: 1px solid #1AC8D0;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.55);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.2;
  font-size: 18px;
  width: 99.6px;
  height: 93.6px;
}
@media screen and (min-width: 400px) and (max-width: 479px) {
  .home-01-list li {
    width: 112.8px;
    height: 106px;
    font-size: 20.4px;
  }
}
@media screen and (min-width: 480px) and (max-width: 767px) {
  .home-01-list li {
    width: 142.7px;
    height: 134.1px;
    font-size: 25.8px;
  }
}
@media (min-width: 768px) {
  .home-01-list li {
    width: 132.8px;
    height: 124.8px;
    font-size: 24px;
  }
}
@media (min-width: 960px) {
  .home-01-list li {
    width: 166px;
    height: 156px;
    font-size: 30px;
  }
}
@media screen and (max-width: 334px) {
  .home-01-list li:last-child {
    margin-top: -13px;
  }
}
.home-01-list .small {
  font-size: 10px;
}
@media (min-width: 480px) {
  .home-01-list .small {
    font-size: 12.8px;
  }
}
@media screen and (min-width: 400px) and (max-width: 479px) {
  .home-01-list .small {
    font-size: 10.7px;
  }
}
@media screen and (min-width: 480px) and (max-width: 767px) {
  .home-01-list .small {
    font-size: 13.7px;
  }
}
@media (min-width: 768px) {
  .home-01-list .small {
    font-size: 12.8px;
  }
}
@media (min-width: 960px) {
  .home-01-list .small {
    font-size: 16px;
  }
}

.home-01-txt-01 {
  margin-top: 35px;
  font-size: 14.4px;
}
@media (min-width: 480px) {
  .home-01-txt-01 {
    margin-top: 40px;
  }
}
@media (min-width: 768px) {
  .home-01-txt-01 {
    white-space: nowrap;
  }
}
@media (min-width: 960px) {
  .home-01-txt-01 {
    margin-top: 50px;
    font-size: 18px;
  }
}

.home-01-txt-02 {
  font-weight: bold;
  font-size: 19.2px;
  padding-bottom: 30px;
  line-height: 1.3;
  margin-top: 0.15em;
}
@media (min-width: 768px) {
  .home-01-txt-02 {
    white-space: nowrap;
    padding-bottom: 67px;
  }
}
@media (min-width: 960px) {
  .home-01-txt-02 {
    font-size: 24px;
  }
}
.home-01-txt-02 .com-font-red {
  font-size: 24px;
}
@media (min-width: 960px) {
  .home-01-txt-02 .com-font-red {
    font-size: 30px;
  }
}

/*-----------------------
 #home-02
-------------------------*/
#home-02 {
  font-size: 16px;
  text-align: center;
  font-weight: bold;
  line-height: 1.3;
  padding-top: 28px;
  padding-bottom: 37.6px;
  background-color: #ebedef;
}
@media (min-width: 960px) {
  #home-02 {
    font-size: 26px;
    padding-top: 35px;
    padding-bottom: 47px;
  }
}
@media (min-width: 480px) {
  #home-02 {
    font-size: 20.8px;
  }
}
@media (max-width: 479px) {
  #home-02 {
    letter-spacing: 0.05em;
  }
}
#home-02 .big {
  font-size: 35px;
  letter-spacing: -0.05em;
}
@media (min-width: 960px) {
  #home-02 .big {
    font-size: 60px;
  }
}
@media (min-width: 480px) {
  #home-02 .big {
    font-size: 48px;
  }
}

/*-----------------------
 #home-03
-------------------------*/
#home-03 {
  padding-top: 88.8px;
  padding-bottom: 100px;
}
@media (min-width: 960px) {
  #home-03 {
    padding-top: 111px;
    padding-bottom: 125px;
  }
}

.contact-form {
  max-width: 964px;
  margin-left: auto;
  margin-right: auto;
  border: 10px solid #D81C4D;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-bottom: 46.4px;
}
@media (min-width: 960px) {
  .contact-form {
    padding-bottom: 58px;
  }
}
.contact-form dl {
  margin-top: 62.4px;
  margin-left: 15px;
  margin-right: 15px;
}
@media (min-width: 960px) {
  .contact-form dl {
    margin-top: 104px;
    margin-left: 11%;
    margin-right: 23%;
  }
}
@media (min-width: 480px) {
  .contact-form dl {
    margin-top: 83.2px;
    margin-left: 7.7%;
    margin-right: 16.1%;
  }
}
@media (min-width: 768px) {
  .contact-form dl {
    margin-left: 5.5%;
    margin-right: 11.5%;
  }
}
@media (min-width: 768px) {
  .contact-form dl div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
.contact-form dl div + div {
  margin-top: 25.2px;
}
@media (min-width: 960px) {
  .contact-form dl div + div {
    margin-top: 36px;
  }
}
@media (min-width: 480px) {
  .contact-form dl div + div {
    margin-top: 28.8px;
  }
}
.contact-form dt {
  font-size: 16px;
}
@media (min-width: 960px) {
  .contact-form dt {
    width: 43%;
  }
}
@media (min-width: 768px) {
  .contact-form dt {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media (min-width: 480px) {
  .contact-form dt {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .contact-form dt {
    margin-bottom: 5px;
  }
}
@media (min-width: 768px) {
  .contact-form dt span {
    padding-left: 80px;
  }
}
.contact-form dt span::before {
  content: "●";
  color: #D81C4D;
  margin-right: 0.5em;
}
@media (max-width: 767px) {
  .contact-form dt.required {
    padding-top: 1.2em;
  }
}
.contact-form dt.required span {
  position: relative;
}
@media (max-width: 767px) {
  .contact-form dt.required span {
    padding-top: 1.2em;
  }
}
.contact-form dt.required span::after {
  content: "【必須】";
  color: #D81C4D;
  font-size: 12.3px;
  position: absolute;
  left: 0;
  top: 0;
}
@media (min-width: 960px) {
  .contact-form dt.required span::after {
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@media (min-width: 480px) {
  .contact-form dt.required span::after {
    font-size: 14px;
  }
}
@media (min-width: 768px) {
  .contact-form dd {
    width: 51.9%;
  }
}
.contact-form dd + dt {
  margin-top: 10.4px;
}
@media (min-width: 960px) {
  .contact-form dd + dt {
    margin-top: 13px;
  }
}
.contact-form dd.radio {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.contact-form dd.radio input[type=radio] {
  display: none;
  font-size: 14px;
}
.contact-form dd.radio input[type=radio]:checked + label span::before {
  opacity: 1;
}
.contact-form dd.radio label {
  white-space: nowrap;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  font-size: 16px;
}
@media (min-width: 480px) {
  .contact-form dd.radio label {
    font-size: 18px;
  }
}
.contact-form dd.radio label:not(:first-of-type) span {
  margin-left: 28px;
}
.contact-form dd.radio label span {
  display: block;
  width: 18px;
  height: 17px;
  margin-right: 1em;
  border-radius: 3px;
  border: 2px solid #D81C4D;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
}
.contact-form dd.radio label span::before {
  content: "";
  display: block;
  border-bottom: 2px solid #000;
  border-left: 2px solid #000;
  opacity: 0;
  height: 4px;
  width: 9px;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  position: absolute;
  left: 2px;
  top: 10%;
}
.contact-form .select-box {
  position: relative;
  width: 195.54px;
  height: 33.34px;
}
.contact-form .select-box::before {
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #D81C4D;
  position: absolute;
  right: 23px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.contact-form .select-box::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 3px 0 3px;
  border-color: #FFFFFF transparent transparent transparent;
  position: absolute;
  right: 26px;
  top: 43%;
}
.contact-form select {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 2px solid #D81C4D;
  color: #000;
  border-radius: 5px;
  font-weight: bold;
  padding: 5px 23px;
  width: 100%;
  height: 100%;
  background-color: #fff;
}
.contact-form select::-ms-expand {
  display: none; /* デフォルトの矢印を非表示(IE用) */
}
.contact-form input[type=text], .contact-form input[type=email] {
  font-size: 16px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-radius: 5px;
  border: 2px solid #D81C4D;
  width: 318.28px;
  height: 33.94px;
  padding: 8px 11px;
  max-width: 100%;
}
.contact-form input[type=text]::-webkit-input-placeholder, .contact-form input[type=email]::-webkit-input-placeholder {
  font-size: 12.8px;
  color: #939393;
}
.contact-form input[type=text]::-moz-placeholder, .contact-form input[type=email]::-moz-placeholder {
  font-size: 12.8px;
  color: #939393;
}
.contact-form input[type=text]:-ms-input-placeholder, .contact-form input[type=email]:-ms-input-placeholder {
  font-size: 12.8px;
  color: #939393;
}
.contact-form input[type=text]::-ms-input-placeholder, .contact-form input[type=email]::-ms-input-placeholder {
  font-size: 12.8px;
  color: #939393;
}
.contact-form input[type=text]::placeholder, .contact-form input[type=email]::placeholder {
  font-size: 12.8px;
  color: #939393;
}
@media (min-width: 480px) {
  .contact-form input[type=text]::-webkit-input-placeholder, .contact-form input[type=email]::-webkit-input-placeholder {
    font-size: 14px;
  }
  .contact-form input[type=text]::-moz-placeholder, .contact-form input[type=email]::-moz-placeholder {
    font-size: 14px;
  }
  .contact-form input[type=text]:-ms-input-placeholder, .contact-form input[type=email]:-ms-input-placeholder {
    font-size: 14px;
  }
  .contact-form input[type=text]::-ms-input-placeholder, .contact-form input[type=email]::-ms-input-placeholder {
    font-size: 14px;
  }
  .contact-form input[type=text]::placeholder, .contact-form input[type=email]::placeholder {
    font-size: 14px;
  }
}
.contact-form .privacy-policy {
  text-align: center;
  display: block;
  text-decoration: underline;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  letter-spacing: 0.2em;
  font-size: 10px;
  margin-top: 20px;
  font-weight: bold;
}
@media (min-width: 960px) {
  .contact-form .privacy-policy {
    font-size: 12px;
    margin-top: 25px;
  }
}
.contact-form .privacy-policy:hover {
  color: #D81C4D;
}

.contact-form-tit-wrapper {
  text-align: center;
  background-color: #D81C4D;
  color: #fff;
  padding-top: 14.4px;
  padding-bottom: 20px;
  position: relative;
}
@media (min-width: 960px) {
  .contact-form-tit-wrapper {
    padding-top: 18px;
    padding-bottom: 25px;
  }
}
.contact-form-tit-wrapper::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 18px 18.5px 0 18.5px;
  border-color: #D81C4D transparent transparent transparent;
  position: absolute;
  bottom: -18px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.contact-form-tit-wrapper p {
  font-size: 11.7px;
  margin-bottom: 8px;
}
@media (min-width: 960px) {
  .contact-form-tit-wrapper p {
    font-size: 18px;
  }
}
@media (min-width: 480px) {
  .contact-form-tit-wrapper p {
    font-size: 14.4px;
  }
}
.contact-form-tit-wrapper h2 {
  font-size: 22.8px;
  line-height: 1.3;
}
@media (min-width: 960px) {
  .contact-form-tit-wrapper h2 {
    font-size: 36px;
  }
}
@media (min-width: 480px) {
  .contact-form-tit-wrapper h2 {
    font-size: 28.8px;
  }
}

.contact-form-btn {
  margin-top: 44.8px;
  font-size: 18px;
  letter-spacing: 0.2em;
  border-radius: 10px;
  background-color: #D81C4D;
  color: #fff;
  max-width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 298.8px;
  height: 45.6px;
  padding-top: 12px;
  padding-bottom: 12px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  border: none;
  font-weight: bold;
  white-space: nowrap;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  cursor: pointer;
}
@media all and (-ms-high-contrast: none) {
  .contact-form-btn {
    padding-top: 5px;
    line-height: 1.2;
  }
}
@media (min-width: 960px) {
  .contact-form-btn {
    margin-top: 56px;
    font-size: 30px;
    width: 498px;
    height: 76px;
  }
}
@media (min-width: 480px) {
  .contact-form-btn {
    width: 398.4px;
    height: 60.8px;
    font-size: 24px;
  }
}
.contact-form-btn:hover {
  -webkit-box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.25);
  -webkit-transform: translateY(0.1875em);
          transform: translateY(0.1875em);
}
.contact-form-btn .small {
  font-weight: normal;
  font-size: 10px;
}
@media (min-width: 960px) {
  .contact-form-btn .small {
    font-size: 12px;
  }
}

/*-----------------------
 #home-04
-------------------------*/
#home-04.com-block-contact {
  padding-top: 40.8px;
  padding-bottom: 37.6px;
}
@media (min-width: 960px) {
  #home-04.com-block-contact {
    padding-top: 51px;
    padding-bottom: 47px;
  }
}

/*-----------------------
 #home-05
-------------------------*/
#home-05 {
  padding-top: 106.4px;
  padding-bottom: 96px;
}
@media (min-width: 960px) {
  #home-05 {
    padding-top: 133px;
    padding-bottom: 120px;
  }
}

.home-05-wrapper {
  max-width: 929.5px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 768px) {
  .home-05-content-01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.home-05-content-01 .left {
  padding-top: 49.6px;
  letter-spacing: 0.05em;
}
@media (min-width: 960px) {
  .home-05-content-01 .left {
    padding-top: 62px;
    white-space: nowrap;
  }
}
@media (max-width: 767px) {
  .home-05-content-01 .left {
    font-size: 13.5px;
  }
}
.home-05-content-01 .right {
  margin-left: -15px;
  text-align: center;
}
@media (max-width: 767px) {
  .home-05-content-01 .right {
    margin-top: 30px;
  }
}
@media (max-width: 479px) {
  .home-05-content-01 .right img {
    width: 252.8px;
  }
}

.home-05-content-02 {
  margin-top: 57.6px;
}
@media (min-width: 960px) {
  .home-05-content-02 {
    margin-top: 72px;
  }
}

.home-05-tit-02 {
  background-image: url(../images/05_02.svg);
  background-repeat: no-repeat;
  background-size: contain;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 244px;
  height: 60px;
  letter-spacing: 0.05em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-top: 12px;
  font-size: 19.2px;
  margin-bottom: 21.6px;
}
@media (min-width: 640px) {
  .home-05-tit-02 {
    width: 305px;
    height: 75px;
    padding-top: 15px;
    font-size: 24px;
    margin-bottom: 27px;
  }
}

.home-05-txt-01 {
  font-size: 11.5px;
  letter-spacing: 0;
  line-height: 2.1;
  margin-bottom: 30px;
}
@media (min-width: 960px) {
  .home-05-txt-01 {
    margin-bottom: 50px;
  }
}
@media (min-width: 640px) {
  .home-05-txt-01 {
    margin-bottom: 40px;
    font-size: 14px;
  }
}

.home-05-content-02-wrapper {
  margin-top: 52.8px;
}
@media (min-width: 768px) {
  .home-05-content-02-wrapper {
    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;
  }
}
@media (min-width: 960px) {
  .home-05-content-02-wrapper {
    margin-top: 66px;
  }
}
@media (max-width: 767px) {
  .home-05-content-02-wrapper .left {
    text-align: center;
  }
}
@media (max-width: 639px) {
  .home-05-content-02-wrapper .left img {
    width: 296px;
  }
}

.home-05-list {
  font-size: 13px;
  color: #D81C4D;
}
@media (min-width: 640px) {
  .home-05-list {
    font-size: 16px;
  }
}
@media (min-width: 768px) {
  .home-05-list {
    margin-left: 33px;
  }
}
@media (max-width: 767px) {
  .home-05-list {
    max-width: 32em;
    margin-top: 30px;
    margin-left: auto;
    margin-right: auto;
  }
}
.home-05-list li {
  padding-left: 1.8em;
  position: relative;
}
.home-05-list li.blue {
  color: #269CE0;
}
.home-05-list li.gray {
  color: #939393;
}
.home-05-list li span {
  position: absolute;
  left: 0;
  top: 0;
}

/*-----------------------
 #home-06
-------------------------*/
#home-06 {
  padding-top: 98.4px;
  padding-bottom: 96px;
}
@media (min-width: 960px) {
  #home-06 {
    padding-top: 123px;
    padding-bottom: 120px;
  }
}

.home-06-list-wrapper {
  margin-top: 68.9px;
  margin-left: auto;
  margin-right: auto;
  max-width: 432px;
}
@media (min-width: 960px) {
  .home-06-list-wrapper {
    max-width: 927px;
  }
}
@media (min-width: 960px) {
  .home-06-list-wrapper {
    margin-top: 106px;
  }
}
@media (min-width: 480px) {
  .home-06-list-wrapper {
    margin-top: 84.8px;
  }
}

.home-06-list {
  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;
  margin-left: -6.7%;
  margin-top: -15px;
}
@media (min-width: 768px) {
  .home-06-list {
    margin-top: -55px;
  }
}
@media (min-width: 480px) {
  .home-06-list {
    margin-top: -33px;
  }
}
.home-06-list li {
  width: 310px;
  height: 118.7px;
  padding-left: 6.7%;
  margin-top: 15px;
}
@media (min-width: 960px) {
  .home-06-list li {
    width: 50%;
  }
}
@media (min-width: 768px) {
  .home-06-list li {
    margin-top: 55px;
  }
}
@media (min-width: 480px) {
  .home-06-list li {
    width: 428px;
    height: 164px;
    margin-top: 33px;
  }
}
.home-06-list li .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-image: url(../images/06_01.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 100%;
  height: 100%;
  padding-left: 16.1px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media (min-width: 480px) {
  .home-06-list li .inner {
    padding-left: 23px;
  }
}
.home-06-list li:nth-child(2) .inner {
  background-image: url(../images/06_02.png);
}
.home-06-list li:nth-child(3) .inner {
  background-image: url(../images/06_03.png);
}
.home-06-list li:nth-child(4) .inner {
  background-image: url(../images/06_04.png);
}
.home-06-list li:nth-child(5) .inner {
  background-image: url(../images/06_05.png);
}
.home-06-list li:last-child .inner {
  background-image: url(../images/06_06.png);
}
.home-06-list h3 {
  font-weight: bold;
  font-size: 19.2px;
  line-height: 1.25;
  letter-spacing: 0.05em;
}
@media (min-width: 480px) {
  .home-06-list h3 {
    font-size: 24px;
  }
}
.home-06-list h3 .com-font-red {
  line-height: 1.2;
  font-size: 24px;
}
@media (min-width: 480px) {
  .home-06-list h3 .com-font-red {
    font-size: 30px;
  }
}
.home-06-list h3 .small {
  font-size: 14.4px;
}
@media (min-width: 480px) {
  .home-06-list h3 .small {
    font-size: 18px;
  }
}
.home-06-list p {
  font-weight: bold;
  word-spacing: nowrap;
  font-size: 12.8px;
  letter-spacing: 0.01em;
  margin-top: 0.8em;
}
@media (min-width: 480px) {
  .home-06-list p {
    font-size: 16px;
  }
}

/*-----------------------
 #home-07
-------------------------*/
#home-07 {
  background-color: #ebedef;
  padding-top: 59.2px;
  margin-bottom: 96px;
}
@media (min-width: 960px) {
  #home-07 {
    padding-top: 74px;
    margin-bottom: 120px;
  }
}

.home-07-tit-01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
@media (max-width: 639px) {
  .home-07-tit-01 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.home-07-tit-01 img {
  width: 296px;
}
@media (min-width: 960px) {
  .home-07-tit-01 img {
    width: 370px;
  }
}
.home-07-tit-01 span {
  font-weight: bold;
  font-size: 19.2px;
  margin-left: 12px;
}
@media (min-width: 960px) {
  .home-07-tit-01 span {
    font-size: 24.12px;
    margin-left: 15px;
  }
}

.home-07-tit-02 {
  font-weight: bold;
  font-size: 31.6px;
  text-align: center;
}
@media (min-width: 480px) {
  .home-07-tit-02 {
    font-size: 36.17px;
  }
}
@media (min-width: 960px) {
  .home-07-tit-02 {
    font-size: 45.22px;
  }
}
.home-07-tit-02 .com-font-red {
  font-size: 37.9px;
}
@media (min-width: 480px) {
  .home-07-tit-02 .com-font-red {
    font-size: 43.4px;
  }
}
@media (min-width: 960px) {
  .home-07-tit-02 .com-font-red {
    font-size: 54.26px;
  }
}

.home-07-wrapper {
  margin-top: 64px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (min-width: 960px) {
  .home-07-wrapper {
    margin-top: 80px;
  }
}
.home-07-wrapper figure {
  -ms-flex-item-align: end;
      -ms-grid-row-align: end;
      align-self: end;
}
@media (min-width: 960px) {
  .home-07-wrapper figure {
    margin-left: -41px;
  }
}

.home-07-list {
  background-image: url(../images/07_02.svg);
  background-repeat: no-repeat;
  background-size: contain;
  margin-bottom: 60px;
  width: 320px;
  height: 347.5px;
  padding-top: 30px;
  padding-left: 18.1px;
  padding-right: 11.25px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media (min-width: 480px) {
  .home-07-list {
    width: 409.6px;
    height: 444.8px;
    padding-top: 35px;
    padding-left: 23.2px;
    padding-right: 14.4px;
  }
}
@media (min-width: 640px) {
  .home-07-list {
    width: 512px;
    height: 556px;
    padding-top: 50px;
    padding-left: 29px;
    padding-right: 18px;
  }
}
@media (min-width: 960px) {
  .home-07-list {
    margin-bottom: 75px;
  }
}
.home-07-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  letter-spacing: 0;
  text-align: center;
  font-weight: bold;
  white-space: nowrap;
}
.home-07-list li:nth-child(2) {
  margin-top: 59.3px;
}
@media (min-width: 480px) {
  .home-07-list li:nth-child(2) {
    margin-top: 76px;
  }
}
@media (min-width: 640px) {
  .home-07-list li:nth-child(2) {
    margin-top: 95px;
  }
}
.home-07-list li:nth-child(2) .com-font-red {
  margin-right: 18.7px;
}
@media (min-width: 480px) {
  .home-07-list li:nth-child(2) .com-font-red {
    margin-right: 24px;
  }
}
@media (min-width: 640px) {
  .home-07-list li:nth-child(2) .com-font-red {
    margin-right: 30px;
  }
}
.home-07-list li:last-child {
  margin-top: 53px;
}
@media (min-width: 480px) {
  .home-07-list li:last-child {
    margin-top: 68px;
  }
}
@media (min-width: 640px) {
  .home-07-list li:last-child {
    margin-top: 85px;
  }
}
.home-07-list li:last-child .com-font-red {
  margin-right: 9.3px;
}
@media (min-width: 480px) {
  .home-07-list li:last-child .com-font-red {
    margin-right: 12px;
  }
}
@media (min-width: 640px) {
  .home-07-list li:last-child .com-font-red {
    margin-right: 15px;
  }
}
.home-07-list .com-font-red {
  font-size: 21.1px;
  line-height: 1.2;
  margin-right: 21.8px;
}
@media (min-width: 480px) {
  .home-07-list .com-font-red {
    margin-right: 28px;
    font-size: 27px;
  }
}
@media (min-width: 640px) {
  .home-07-list .com-font-red {
    font-size: 33.83px;
    margin-right: 35px;
  }
}
.home-07-list .com-font-red .big {
  font-size: 30px;
  line-height: 0.84;
}
@media (min-width: 480px) {
  .home-07-list .com-font-red .big {
    font-size: 38.4px;
  }
}
@media (min-width: 640px) {
  .home-07-list .com-font-red .big {
    font-size: 48px;
  }
}
.home-07-list h4 {
  font-size: 18.7px;
}
@media (min-width: 480px) {
  .home-07-list h4 {
    font-size: 24px;
  }
}
@media (min-width: 640px) {
  .home-07-list h4 {
    font-size: 30px;
  }
}
.home-07-list p {
  margin-top: 6px;
  font-size: 11.25px;
  line-height: 1.33;
}
@media (min-width: 480px) {
  .home-07-list p {
    margin-top: 7px;
    font-size: 14.4px;
  }
}
@media (min-width: 640px) {
  .home-07-list p {
    margin-top: 12px;
    font-size: 18px;
  }
}

/*-----------------------
 #home-08
-------------------------*/
#home-08 {
  padding-top: 96px;
  padding-bottom: 117px;
}
@media (min-width: 960px) {
  #home-08 {
    padding-top: 120px;
    padding-bottom: 130px;
  }
}

.home-08-list-wrapper {
  max-width: 846px;
  margin-left: auto;
  margin-right: auto;
}

.home-08-list {
  margin-top: 60px;
  font-size: 12.8px;
  font-weight: bold;
  margin-left: 27.5px;
}
@media (min-width: 960px) {
  .home-08-list {
    margin-top: 75px;
    margin-left: 41px;
  }
}
@media (min-width: 640px) {
  .home-08-list {
    font-size: 16px;
  }
}
@media (min-width: 480px) {
  .home-08-list {
    margin-left: 32.5px;
  }
}
.home-08-list li + li {
  margin-top: 33.6px;
}
@media (min-width: 960px) {
  .home-08-list li + li {
    margin-top: 42px;
  }
}
.home-08-list h3 {
  position: relative;
  border: 2px solid #D81C4D;
  border-radius: 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 10px;
  padding-left: 35.5px;
}
@media (min-width: 960px) {
  .home-08-list h3 {
    padding-left: 53px;
    height: 44px;
  }
}
@media (min-width: 480px) {
  .home-08-list h3 {
    padding-left: 42px;
  }
}
.home-08-list h3::before {
  content: "Q";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 24px;
  color: #fff;
  background-color: #D81C4D;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: -27.5px;
  width: 55px;
  height: 55px;
}
@media (min-width: 960px) {
  .home-08-list h3::before {
    font-size: 36px;
    left: -41px;
    width: 82px;
    height: 82px;
  }
}
@media (min-width: 480px) {
  .home-08-list h3::before {
    font-size: 28.8px;
    left: -32.5px;
    width: 65px;
    height: 65px;
  }
}
.home-08-list p {
  padding-left: 35.5px;
  margin-top: 12px;
}
@media (min-width: 960px) {
  .home-08-list p {
    padding-left: 53px;
    margin-top: 15px;
    white-space: nowrap;
  }
}
@media (min-width: 480px) {
  .home-08-list p {
    padding-left: 42px;
  }
}

/*-----------------------
 #home-09
-------------------------*/
#home-09 {
  padding-bottom: 78px;
}
@media (min-width: 960px) {
  #home-09 {
    padding-bottom: 95px;
  }
}

.home-09-wrapper {
  max-width: 893px;
  margin-left: auto;
  margin-right: auto;
}

.home-09-tit {
  font-size: 14.4px;
  margin-bottom: 23.2px;
}
@media (min-width: 960px) {
  .home-09-tit {
    font-size: 18px;
    margin-bottom: 29px;
  }
}

.home-09-list-wrapper {
  height: 208px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-top: 29.6px;
  border: 1px solid #000;
  padding: 11px 35px 16px 19px;
  font-size: 10px;
  letter-spacing: 0.05em;
}
@media (min-width: 960px) {
  .home-09-list-wrapper {
    margin-top: 37px;
  }
}
@media (min-width: 480px) {
  .home-09-list-wrapper {
    font-size: 12px;
  }
}
.home-09-list-wrapper h3 {
  line-height: 1;
  margin-bottom: 1em;
}
.home-09-list-wrapper p {
  line-height: 1.16;
}

.home-09-list > li + li {
  margin-top: 1em;
}
.home-09-list h4 {
  text-decoration: underline;
  color: #D81C4D;
  font-size: 12.8px;
  margin-bottom: 0.2em;
}
@media (min-width: 480px) {
  .home-09-list h4 {
    font-size: 14px;
  }
}

#home-09 .simplebar-scrollbar::before {
  background-color: #D81C4D;
  border: 1px solid #000;
  width: 100%;
  height: 31px;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-radius: 0;
}
#home-09 .simplebar-scrollbar.simplebar-visible {
  height: 31px !important;
}
#home-09 .simplebar-scrollbar.simplebar-visible:before {
  opacity: 1;
}
#home-09 .simplebar-track {
  height: 179px;
  background-color: #CFCACA;
  border-left: 1px solid #080103;
  width: 13px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-left: 0;
  overflow: visible;
  top: 15px;
}
#home-09 .simplebar-track:before, #home-09 .simplebar-track::after {
  content: "▲";
  color: #D81C4D;
  font-size: 12px;
  height: 15px;
  padding-top: 0.1em;
  text-align: center;
  background-size: contain;
  background-repeat: no-repeat;
  width: 100%;
  display: block;
  position: absolute;
  background-color: #CFCACA;
  border-left: 1px solid #000;
  border-right: 1px solid #000;
  right: -1px;
}
#home-09 .simplebar-track::before {
  top: -15px;
}
#home-09 .simplebar-track::after {
  -webkit-transform: rotate(-180deg);
          transform: rotate(-180deg);
  bottom: -13px;
}