@charset "utf-8";

/*
  BASE
*/

html {
  margin: 0;
  font-size: 62.5%;
}

body {
  color: #404044;
  font-family: 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'Yu Gothic', YuGothic, Verdana, Helvetica, 'ＭＳ Ｐゴシック', sans-serif;
  font-size: 1.6rem;
  margin: 0;
}

img {
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

p {
  line-height: 2;
}

.btn {
  align-items: center;
  background-color: #f57;
  border: 1px solid #fff;
  border-radius: 5rem;
  box-sizing: border-box;
  color: #fff;
  display: inline-flex;
  justify-content: center;
  text-decoration: none;
  width: 100%;
}

.btn:hover {
  opacity: 0.6;
}

@media screen and (max-width: 768px) {
  .only-pc {
    display: none;
  }
}


/* HEADER */

.layout_header {
  margin: 2rem 0 4rem 0;
}

.header-logo {
  width: 15.6rem;
}

#wrapper {
  margin: 0 auto;
  width: 960px;
}

.layout_main {
  display: flex;
  justify-content: space-between;
  width: auto;
  margin: 0;
  gap: 32px;
}

.layout_main > .lead {
  margin: 0;
  width: 50%;
}

.layout_main > .form {
  width: 50%;  
}

.lead .headline {
  font-size: 2.2rem;
  margin: 3.8rem 0;
}

/*
  MAIN
*/

.lead {
  margin: 0 2rem;
}

.lead .label {
  border: 1px solid #cccccf;
  border-radius: 2px;
  display: inline-block;
  font-size: 1.3rem;
  font-weight: normal;
  line-height: 1;
  margin: 0;
  padding: 1rem;
}

.lead .img,
.lead .list {
  margin: 5rem auto;
}

.header-logo {
  width: 20.9rem;
}

.lead .headline {
  font-size: 2.2rem;
  margin: 2.8rem 0 1.7rem;
}

.lead .img {
  margin: 1.7rem auto 2.7rem;
  border: solid #d5dbdf 1px;
}

.lead .img img {
  width: 100%;
}

.lead .list {
  border: 1px solid #cccccf;
  font-size: 1.5rem;
  margin: 3.4rem auto;
  padding: 3rem 2rem 3rem 3rem;
}

.lead .list li {
  margin-left: 1.8rem;
  margin-bottom: 0;
  padding-bottom: 0;
}

.lead .list li:not(:last-child) {
  margin-bottom: 10px;
}

.layout_main .lead .block .list.ol-list {
  margin-left: 20px;
}

.layout_main .lead .block .list.ol-list li {
  list-style-type: decimal;
}

.layout_main .lead .block .list.ol-list li::before {
  content: none;
}

.lead .list p {
  margin: 0;
}

.layout_main .lead a {
  color: #FC5577;
}

.layout_main .lead a:hover {
  text-decoration: none;
}

.layout_main .lead a .fa {
  margin: 0 5px;
}

.layout_main .lead .block {
  border: 1px solid #f57;
  padding: 20px;
}

.layout_main .lead .block .subheadline {
  margin: 0;
  padding: 0 0 10px 0;
  color: #f57;
  text-align: center;
  font-size: 20px;
}

.layout_main .lead .block .miniheadline {
  text-align: left;
  display: block;
  padding: 10px;
  margin: 0;
  font-size: 16px;
}

.layout_main .lead .block .list {
  border: none;
  padding: 0 0 10px 0;
  margin: 0;
}

.layout_main .lead .block .list li {
  list-style-type: none;
  position: relative;
  left: -1rem;
  line-height: 1.5em;
}

.layout_main .lead .block .list li::before {
  content: "・";
  left: -1.5rem;
  position: absolute;
}

.layout_main .discription {
  margin: 1em 0;
}

.layout_main .thumbnail {
  line-height: 0.5;
  height: auto;
  border: none;
  box-shadow: 0 0 0.5rem #98a6c14d;
  padding: 0;
}

.layout_main .thumbnail .video {
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0;
  line-height: 1;
}


@media screen and (max-width: 960px) {
  .layout_header {
    padding-left: 0;
  }

  #wrapper {
    width: auto;
    overflow-x: hidden;
    padding: 0 1rem;
  }

  .layout_main {
    width: auto;
    flex-direction: column;
    margin: 0;
  }

  .layout_main > .lead {
    width: auto;
    margin-bottom: 3rem;
  }

  .layout_main .thumbnail {
    width: auto;
    margin: 0 auto;
  }
}


/*
  FOOTER
*/

.layout_footer {
  margin: 5rem 2rem 6.2rem;
  text-align: center;
}

.footer-logo {
  margin: 2.5rem auto 3rem;
  width: 20.9rem;
}

.footer-copyright {
  color: #a6a6ac;
  font-size: 1.3rem;
}

@media screen and (min-width: 1600px) {
  .footer-logo {
    margin: 2vw auto;
    width: 10vw;
  }
}

/*
  FORM
*/

.layout_main > .form {
  box-shadow: 0 0 0.5rem #98a6c14d;
  margin: 0;
}

.form .form_in {
  margin: 30px auto 50px;
}

.form .form_in * {
  box-sizing: border-box;
}

.form .form_in input::placeholder {
  color: #ccc;
}

.form .form_in input:focus {
  border-color: inherit;
  outline: none;
}

.form .form_in .mktoForm {
  margin-top: -10px;
}

.form .form_in .mktoFormRow {
  display: flex;
  padding: 0 24px;
}

.form .form_in .mktoFormCol {
  width: calc(100% - 8px);
  margin-right: 16px;
}

.form .form_in .mktoFormCol:last-child {
  margin-right: 0;
}

.form .form_in .mktoForm.mktoLayoutAbove .mktoRequiredField .mktoAsterix {
  color: #f00;
  font-weight: normal;
  font-size: 20px;
}

.form .form_in .mktoForm .mktoError {
  right: inherit !important;
  bottom: -44px !important;
}

.form .form_in .mktoForm .mktoError .mktoErrorArrow {
  background: #f57;
  border: 0;
}

.form .form_in .mktoForm .mktoError .mktoErrorMsg {
  max-width: none;
  padding: 14px 15px;
  background: #f57;
  border: 0;
  color: #fff;
  font-size: 15px;
  text-shadow: none;
  box-shadow: none;
  font-weight: bold;
}

.form .form_in .mktoOffset {
  display: none;
}

.form .form_in .mktoHasWidth {
  width: 100%;
}

.form .form_in .mktoForm .mktoRadioList, .form .form_in .mktoForm .mktoCheckboxList {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.form .form_in .mktoLabel {
  margin-top: 20px;
  padding: 0 0 5px;
  font-weight: bold;
}

.form .form_in .mktoField {
  padding: 13px 20px;
  border: 1px solid #d0d0d0;
  font-size: 15px;
  border-radius: 5px;
}

.form .form_in .mktoForm .mktoRadioList > label,
.form .form_in .mktoForm .mktoCheckboxList > label {
  margin-left: 0;
  margin-top: 0;
  margin-bottom: 0;
  line-height: 1.5em;
  display: block;
  min-height: 12px;
  padding: 3px 0;
  width: 97%;
}

.form .form_in input[type="checkbox"].mktoField,
.form .form_in input[type="radio"].mktoField {
  width: 3%;
}

@media screen and (max-width: 768px) {
  .form .form_in .mktoForm .mktoRadioList > label,
  .form .form_in .mktoForm .mktoCheckboxList > label {
    width: 93%;
  }

  .form .form_in input[type="checkbox"].mktoField,
  .form .form_in input[type="radio"].mktoField {
    width: 7%;
    transform: scale(1.3);
  }
}

.form .form_in select.mktoField {
  display: block;
  font-size: 16px;
  width: 100%;
  max-width: 100%;
  margin: 0;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
  background-color: #fff;
  background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23007CB2%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E');
  background-repeat: no-repeat, repeat;
  background-position: right 0.7em top 50%, 0 0;
  background-size: 0.65em auto, 100%;
}

@media screen and (max-width: 768px) {
  .form .form_in select.mktoField {
    padding: 10px;
  }
}

.form .form_in select.mktoField::-ms-expand {
  display: none;
}

.form .form_in .mktoFieldWrap {
  width: 100%;
}

.form .form_in .mktoButtonRow {
  margin-top: 20px;
  padding: 0 10px;
  display: block;
}

.form .form_in .mktoButtonWrap {
  display: block;
}

.form #FORM_PHONE {
  height: auto;
}

.form #P_EVENT_EXTRA2 {
  height: 10em;
}

.form .form_in .mktoButtonWrap.mktoMinimal .mktoButton {
  align-items: center;
  background-color: #f57;
  border: 1px solid #fff;
  border-radius: 5rem;
  box-sizing: border-box;
  color: #fff;
  display: block;
  font-size: 16px;
  font-weight: normal;
  height: 52px;
  justify-content: center;
  letter-spacing: 0.8em;
  margin: 0 auto;
  text-decoration: none;
  width: 237px;
}

.form .form_in .mktoButtonWrap.mktoMinimal .mktoButton:hover {
  background-color: #f57;
  border: 1px solid #fff;
  color: #fff;
  opacity: 0.6;
}

.form .form_in .mktoHtmlText {
  width: auto;
  margin: 5px 0 0;
  font-size: 11px;
  line-height: 1.8;
}

.form .form_in .mktoHtmlText a {
  text-decoration: underline;
}

.form .form_in .mktoHtmlText a:hover {
  text-decoration: none;
}

@media screen and (max-width: 960px) {
  .layout_main > .form {
    width: auto;
  }
  
  .layout_main > .form {
    box-shadow: none;
  }

  .form .form_in {
    width: auto;
    margin: 0;
  }

  .form .form_in .mktoForm {
    padding: 0;
  }

  .form .form_in .mktoFormRow {
    padding: 0;
  }

  .form .form_in .mktoForm.mktoLayoutAbove .mktoRequiredField .mktoAsterix::before {
    font-size: 10px;
  }

  .form .form_in .mktoLabel {
    margin-top: 15px;
  }

  .form .form_in .mktoField {
    padding: 20px 10px;
    font-size: 16px;
  }
}

.heading_01_01 {
  margin: 10px 0 20px;
  font-size: 28px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}

.service {
  font-size: 14px;
  margin: 10px 0 20px;
  text-align: center;
}

.notice {
  text-align: center;
  color: #f00;
}

.notice strong {
  display: inline-block;
  padding: 0 5px;
  font-size: 20px;
  vertical-align: middle;
}

.notice-list {
  margin: 20px auto 0;
  line-height: 1.5;
}

.notice-list li {
  margin: 10px 0 0;
}

#FORM_INQUIRY {
  height: 14rem;
  resize: vertical;
}

.for-sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .heading_01_01 {
    font-size: 18px;
    line-height: 1.5;
  }

  .notice-list {
    width: 100%;
    margin: 20px 0;
  }

  .notice-list li {
    font-size: 14px;
  }

  .for-sp {
    display: block;
  }
}

/* ----------------
送信前注意テキスト
---------------- */

.mktoForm span.submit-caution-txt {
  font-size: 12px;
  display: block;
  font-weight: normal;
  margin: 30px 0 0;
}

.mktoForm span.submit-caution-txt br {
  display: none;
}

@media screen and (max-width: 768px) {
  .mktoForm span.submit-caution-txt {
    text-align: left;
  }

  .mktoForm span.submit-caution-txt br {
    display: none;
  }
}

/* ----------------
完了画面
---------------- */

.complete {
  line-height: 1.8;
  text-align: center;
  margin: 50px 0 100px;
}

.complete-txt {
  margin: 0 0 50px;
}

@media screen and (max-width: 768px) {
  .form {
    margin: 0 20px;
  }

  .complete {
    text-align: left;
    margin: 30px 0 60px;
  }

  .complete-txt {
    margin: 0 0 30px;
  }

  .for-pc {
    display: none;
  }
}

/*
  COMPLETE SCREEN
*/

#complete .layout_main {
  margin: 0 2rem;
}

#complete .headline {
  font-size: 2.8rem;
  margin: 0 0 5.2rem;
}

#complete .back-to-page {
  margin: 3.5rem 0 0;
}

#complete .back-to-page a {
  color: #0d50d6;
  text-decoration: none;
}

#complete .back-to-page a:hover {
  text-decoration: underline;
}

@media screen and (min-width: 769px) {
  #complete .layout_main {
    margin: 14.2rem auto;
  }
}

/* マルケトのエラー吹き出しを模倣したスタイル */
#email-error {
  background-color: rgb(253, 124, 150);
  color: rgb(255, 255, 255);
  font-size: 15px;
  font-weight: bold;
  padding: 14px 15px;
  border-radius: 6px;
  position: relative;
  top: 11px;
  left: 0;
  z-index: 10;
  animation: fadeIn 0.4s ease 0s 1 normal;
}

#email-error::before {
  width: 16px;
  height: 16px;
  transform: rotate(45deg);
  display: inline-block;
  position: absolute;
  top: -3px;
  left: 11px;
  content: '';
  overflow: hidden;
  z-index: 100;
  background-color: rgb(253, 124, 150);
}

/* マルケトのエラー吹き出しをマルケト側の js による style 制御に負けず完全に非表示にする */
#email-error + .mktoError,
#Email + .mktoError {
  display: none !important;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}