@charset "UTF-8";

/*=======================================================
#contact 
=======================================================*/
#contact {
  padding: 10rem 0;
  background-color: var(--color_5);
}

.tab__wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  z-index: auto;
}

.tab__label {
  order: -1;
  width: 27%;
  padding: 1.6rem 0 3.2rem;
  text-align: center;
  background-color: var(--color_1);
  border: var(--color_7) solid 2px;
  border-bottom: none;
  border-radius: 1rem 1rem 0 0;
  transform: translateY(2rem);
  transition: 0.5s;
  cursor: pointer;
  z-index: 1;
}
.tab__label:first-of-type {
  width: 46%;
}

.tab__label p {
  display: inline;
  font-size: 2.4rem;
  line-height: 1.4;
}

.tab__label p span {
  display: inline-block;
}

.tab__switch:checked + .tab__label {
  background-color: var(--color_3);
  transform: translateY(0);
}

#TAB-01:checked + .tab__label + .tab__content,
#TAB-02:checked + .tab__label + .tab__content,
#TAB-03:checked + .tab__label + .tab__content {
  display: block;
}

.tab__switch {
  display: none;
}

.tab__content {
  width: 100%;
  display: none;
  border: 0.2rem solid var(--color_2);
  background: #fff;
  padding: 3.2rem 4.8rem;
  z-index: 2;
}

.tab__content > p:first-of-type {
  position: relative;
  padding: 0 0 0 1.1em;
}
.tab__content > p:first-of-type::before {
  content: "★";
  position: absolute;
  top: 0;
  left: 0;
}

.form__ttl {
  margin: 3.2rem 0 1.6rem;
  font-size: 3.2rem;
  line-height: 1.4;
}
.form__ttl span {
  display: inline-block;
}

/*プログレストラッカー*/
.smf-progress-tracker {
  justify-content: center;
  width: 60%;
  margin: 5rem auto;
}

.smf-progress-tracker__item__number {
  width: 8rem;
  height: 8rem;
  font-size: 2.4rem;
}
.smf-progress-tracker__item[aria-current="true"]
  .smf-progress-tracker__item__number {
  color: var(--color_2);
  background-color: var(--color_8);
  font-weight: 700;
}
.smf-progress-tracker__item:after,
.smf-progress-tracker__item:before {
  top: 4rem;
  background-color: var(--color_7);
}

/*フォームカスタマイズ*/
form .smf-form {
  font-size: 2rem;
  letter-spacing: 0.02em;
}

form .smf-form .smf-item {
  position: relative;
  height: 6.4rem;
  margin-bottom: 5rem;
  border: var(--color_2) 2px solid !important;
  border-radius: 5rem;
}

.smf-text-control__control::-webkit-input-placeholder,
.smf-textarea-control__control::-webkit-input-placeholder {
  color: var(--color_7);
}

.smf-text-control__control::-moz-placeholder,
.smf-textarea-control__control::-moz-placeholder {
  color: var(--color_7);
}

.smf-text-control__control:-ms-input-placeholder,
.smf-textarea-control__control:-ms-input-placeholder {
  color: var(--color_7);
}

.smf-text-control__control::-ms-input-placeholder,
.smf-textarea-control__control::-ms-input-placeholder {
  color: var(--color_7);
}

.smf-text-control__control::placeholder,
.smf-textarea-control__control::placeholder {
  color: var(--color_7);
}

form .smf-form .smf-item:not(:first-child) {
  border-top: var(--color_2) 1.5px solid;
}

.form__normal form .smf-form .smf-item:nth-of-type(6),
.form__free-design form .smf-form .smf-item:nth-of-type(7) {
  height: 22.5rem;
}

form .smf-form .smf-item__col {
  padding: 0;
  align-content: center;
}

form .smf-form .smf-item .smf-item__col--label {
  border: none;
  padding: 0;
  display: block;
  max-width: none;
  padding: 0 1.5em;
  align-content: center;
  background-color: transparent;
  position: relative;
}

form .smf-form .smf-item .smf-item__col--label::before {
  content: "必須";
  position: absolute;
  top: 50%;
  right: 2em;
  transform: translateY(-50%);
  padding: 0 0.5em 0.1em;
  font-size: 1.3rem;
  color: var(--color_1);
  background-color: #ff6d6d;
  border-radius: 5px;
}

form .smf-form .smf-item .smf-item__col--label::after {
  content: "";
  position: absolute;
  top: 1.4rem;
  right: 0;
  width: 1.5px;
  height: calc(100% - 2.8rem);
  background-color: var(--color_7);
}

/*必須を非表示*/
.form__normal
  form
  .smf-form
  .smf-item:nth-of-type(4)
  .smf-item__col--label::before,
.form__normal
  form
  .smf-form
  .smf-item:nth-of-type(5)
  .smf-item__col--label::before,
.form__free-design
  form
  .smf-form
  .smf-item:nth-of-type(4)
  .smf-item__col--label::before {
  display: none;
}
/*内容*/
.form__normal form .smf-form .smf-item:nth-of-type(6) .smf-item__col--label,
.form__free-design
  form
  .smf-form
  .smf-item:nth-of-type(7)
  .smf-item__col--label {
  padding: 1em 1.5em;
  align-content: flex-start;
}
.form__normal
  form
  .smf-form
  .smf-item:nth-of-type(6)
  .smf-item__col--label::before,
.form__free-design
  form
  .smf-form
  .smf-item:nth-of-type(7)
  .smf-item__col--label::before {
  top: 2em;
  transform: none;
}

form .smf-form .smf-item__col--controls {
  display: block;
  max-width: none;
  padding: 0 1em;
  align-content: center;
}
.form__normal form .smf-form .smf-item:nth-of-type(6) .smf-item__col--controls,
.form__free-design
  form
  .smf-form
  .smf-item:nth-of-type(7)
  .smf-item__col--controls {
  padding: 1em;
  align-content: flex-start;
}

form .smf-form .smf-text-control__control {
  width: 100%;
  padding: 0;
  line-height: 1.8;
  border: none;
  border-radius: 0;
  background-color: var(--color_1);
  box-shadow: none;
}

form .smf-form .smf-textarea-control__control {
  width: 100%;
  height: 100%;
  min-height: 100%;
  padding: 0;
  border: none;
  border-radius: 0 5rem 5rem 0;
  background-color: var(--color_1);
  box-shadow: none;
  align-content: flex-start;
  resize: none;
  overflow-y: scroll;
}
form .smf-form .smf-textarea-control__control textarea {
  max-width: 100%;
  max-height: 100%;
  resize: none;
}

.smf-error-messages {
  color: #ff6d6d;
  margin-top: 0.8em;
  margin-bottom: -2.5em;
}
.form__normal form .smf-form .smf-item:nth-of-type(6) .smf-error-messages,
.form__free-design form .smf-form .smf-item:nth-of-type(7) .smf-error-messages {
  margin-top: 1.3em;
  margin-bottom: -2.5em;
}

.check {
  width: 96%;
  margin: 0 auto 5rem;
}
.check p {
  font-size: 2rem;
}
.check ul li {
  position: relative;
  padding-left: 1em;
  font-size: 1.6rem;
}
.check ul li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}

.check ul li span {
  display: inline-block;
  margin-left: 0.5em;
}
.check ul li span a {
  padding: 0 0.2em 0.1em;
  font-size: 80%;
  border: var(--color_2) 0.5px solid;
  transition: 0.2s;
}

.check ul li a:hover {
  background-color: var(--color_3);
  border: var(--color_3) 0.5px solid;
}

.smf-form {
  text-align: center;
}

.smf-form .smf-checkbox-control {
  gap: 1rem;
  display: block;
  margin-bottom: 5rem;
  text-align: center;
  align-items: center;
}
.doui .smf-error-messages {
  display: none;
}

form .smf-action {
  display: flex;
  justify-content: center;
  gap: 8rem;
}

form .smf-action .smf-button-control button {
  position: relative;
  display: flex;
  align-items: center;
  text-align: center;
  margin: auto;
  padding: 1.5em 4em;
  font-size: 2.4rem;
  background: var(--color_1);
  border: var(--color_2) 2px solid;
  border-radius: 5rem;
  -webkit-filter: drop-shadow(var(--color_2) 0 3px 0);
  filter: drop-shadow(var(--color_2) 0 3px 0);
  transition: 0.2s;
}
form .smf-action .smf-button-control button:hover {
  color: var(--color_2);
  -webkit-filter: drop-shadow(var(--color_2) 0 0.5px 0);
  filter: drop-shadow(var(--color_2) 0 0.5px 0);
  transform: translateY(2.5px);
}
form .smf-action .smf-button-control button[data-action="back"] {
  padding: 1.5em 1em;
}

/*送信中アイコン非表示*/
.smf-sending:before {
  display: none;
}

@media screen and (max-width: 896px) {
  .tab__label {
    width: 32%;
  }
  .tab__label:first-of-type {
    width: 36%;
  }
  .tab__label p {
    font-size: 2rem;
    line-height: 1.4;
  }
  .tab__label:first-of-type p {
    font-size: 100%;
  }
  .smf-progress-tracker {
    width: 100%;
  }
}
@media screen and (max-width: 639px) {
  form .smf-form {
    font-size: 1.8rem;
  }
  form .smf-form .smf-item {
    height: auto;
    padding: 0.5em 0 0.8em;
    margin-bottom: 3rem;
    border-radius: 3rem;
  }
  form .smf-form .smf-item .smf-item__col--label {
    padding: 0 1em 0.2em;
  }
  form .smf-form .smf-item .smf-item__col--label::before {
    top: 50%;
    transform: translateY(-55%);
  }

  form .smf-form .smf-item .smf-item__col--label::after {
    top: auto;
    bottom: -0.2em;
    right: 1em;
    height: 1.5px;
    width: calc(100% - 2em);
  }
  .form__normal form .smf-form .smf-item:nth-of-type(6) .smf-item__col--label,
  .form__free-design
    form
    .smf-form
    .smf-item:nth-of-type(7)
    .smf-item__col--label {
    padding: 0 1em;
  }
  .form__normal
    form
    .smf-form
    .smf-item:nth-of-type(6)
    .smf-item__col--label::before,
  .form__free-design
    form
    .smf-form
    .smf-item:nth-of-type(7)
    .smf-item__col--label::before {
    top: 0.5em;
  }
  form .smf-form .smf-text-control__control {
    margin-top: 0.5em;
    padding: 0;
  }
  .form__normal form .smf-form .smf-item:nth-of-type(6),
  .form__free-design form .smf-form .smf-item:nth-of-type(7) {
    height: auto;
  }
  .form__normal form .smf-form .smf-item:nth-of-type(6) .smf-error-messages,
  .form__free-design
    form
    .smf-form
    .smf-item:nth-of-type(7)
    .smf-error-messages {
    margin-top: 4em;
    margin-bottom: -3.5em;
  }
  .check {
    width: 100%;
    margin: 0 auto 5rem;
  }
  .check p {
    font-size: 1.6rem;
  }
  form .smf-action .smf-button-control button {
    display: block;
    width: 100%;
    font-size: 2rem;
    text-align: center;
  }
}
@media screen and (max-width: 600px) {
  #contact {
    padding: 5rem 0;
  }
  .tab__wrap {
    flex-direction: column;
  }
  .tab__label,
  .tab__label:first-of-type {
    width: 100%;
    padding: 0.8rem 0rem;
    transform: translateY(0);
  }
  .tab__switch:checked + .tab__label {
    padding: 2rem 0rem;
  }
  .tab__content {
    padding: 3.2rem;
  }
  .form__ttl {
    font-size: 2.2rem;
  }
  .smf-progress-tracker__item__number {
    width: 4rem;
    height: 4rem;
    font-size: 2rem;
  }
  .smf-progress-tracker__item:after,
  .smf-progress-tracker__item:before {
    top: 2rem;
  }
  .smf-progress-tracker__item__text {
    font-size: 1rem;
  }
  .smf-form .smf-checkbox-control {
    text-align: left;
    white-space: nowrap;
  }
  .smf-button-control {
    width: 90%;
  }
  form .smf-action .smf-button-control button {
    padding: 1.5em 0;
  }
}

@media screen and (max-width: 480px) {
  .tab__content {
    padding: 3.2rem 1.6rem;
  }
}

/*=======================================================
#privacy-policy
=======================================================*/
#privacy-policy {
  padding: 10rem 0;
  background-color: var(--color_5);
}

.privacy__body {
  max-width: 100rem;
  margin: 0 auto;
}

.privacy__lead {
  margin-bottom: 4rem;
  line-height: 2;
}

.privacy__block {
  margin-bottom: 4rem;
  padding-bottom: 4rem;
  border-bottom: 1px solid var(--color_7);
}

.privacy__block:last-of-type {
  border-bottom: none;
}

.privacy__ttl {
  font-size: 1.8rem;
  margin-bottom: 1.6rem;
  padding-left: 1em;
  border-left: var(--color_2) 3px solid;
}

.privacy__block p {
  line-height: 2;
  margin-bottom: 1.2rem;
}

.privacy__block p:last-child {
  margin-bottom: 0;
}

.privacy__block a {
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.2s;
}

.privacy__block a:hover {
  opacity: 0.6;
}

.privacy__list {
  margin-top: 1rem;
  padding-left: 1.6rem;
}

.privacy__list li {
  position: relative;
  padding-left: 1.2em;
  margin-bottom: 0.6rem;
  line-height: 1.8;
}

.privacy__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 0.5em;
  height: 0.5em;
  background-color: var(--color_2);
  border-radius: 50%;
}

.privacy__date {
  text-align: right;
  margin-top: 4rem;
  color: var(--color_6);
  font-size: 1.3rem;
}

@media screen and (max-width: 600px) {
  #privacy-policy {
    padding: 5rem 0;
  }

  .privacy__ttl {
    font-size: 1.6rem;
  }
}
