@charset "utf-8";
/*---------------------------
  Contact Pages
---------------------------*/
.section-container{
  gap: 56px;
}
body.contact h2.FAQ_title,
body:is(.contact,.confirm,.thanks) h2.form__section-title{
  margin: 0 auto;
}
.form__item-title,
.confirm__item-title,.confirm__note,
.thanks__name,.thanks__confirm-title,.thanks__item-title{
  font-family: var(--h-font-family);
  font-weight: var(--h-font-weight);
  line-height: var(--h-line-height);
  letter-spacing: var(--h-letter-spacing);
  font-style: normal;
  font-size: 1.8rem;
}
/* For PC */
@media (912px < width) {
  body:is(.contact,.thanks) .width-container{
    max-width: 700px;
  }
}
/*---------------------------
  Form style
---------------------------*/
form{
  text-wrap: wrap;
}
input:not([type="radio"]):not([type="button"]):not([type="submit"]){
  width: min(100%, 1200px);
  height: 3em;
  padding-left: 1em;
}
textarea{
  padding: 1em;
  width: min(100%, 900px);
}
.section__title--line{
  margin: 48px auto;
}
.section__title--line span{
  padding-left: 1.6rem;
  font-size: 1.6rem;
}
.form__item-title{
  padding-left: 2.4rem;
  margin-bottom: 3.2rem;
  border-left: 3px solid var(--accent-color);
}
.form__item-title span{
  padding-left: 1.6rem;
  font-size: 1.6rem;
}
.form__item{
  margin-bottom: 4.8rem;
}
.form__item.--zip-code,
.form__item.--building-type,
.form__item.--budget{
  display: grid;
}
.form__item.--zip-code{
  grid-template-columns: 1fr auto;
  gap: 2.4rem;
}
.form__item.--zip-code .button--mini{width: 100%;}

/* Button Loading */
.search_btn {
  cursor: pointer;
  position: relative;
  transition: all 0.3s;
}
.search_btn.--loading {
  pointer-events: none;
  color: transparent !important;
}
.search_btn.--loading::after {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
/* animation */
@keyframes spin {
  to { transform: rotate(360deg); }
}
.is-updated {
  animation: highlight-flash 1.2s ease-out;
}
@keyframes highlight-flash {
  0% {
    background-color: #fff9c4; 
    box-shadow: 0 0 8px rgba(255, 217, 0, 0.6);
  }
  100% {
    background-color: #fff;
    box-shadow: none;
  }
}

.form__item.--budget{
  grid-template-columns: 14em 3em;
  gap: 1.6em;
  align-items: last baseline;
}
/* For PC */
@media (912px < width) {
  .section__title--line{
    margin: 64px auto;
  }
  .form__item{
    padding-left: 2.4rem;
  }
  .form__item.--zip-code{
    grid-template-columns: 14em 170px;
    gap: 2.4rem;
  }
  .form__item.--building-type{
    grid-template-columns: 300px auto;
  }
}
/* notes */
.form__notes a,
.FAQ__attention_area a{
  display: inline;
  text-decoration: underline;
}
.form__notes{
  margin-top: 3.2rem;
}
.FAQ__attention_area{
  display: grid;
  gap: 1.6rem;
  text-wrap: wrap;
}

/*------Errors------*/
.wpcf7-form.init .wpcf7-not-valid-tip {
  display: none !important;
}
.wpcf7-form.init .wpcf7-not-valid {
  border-color: #ccc !important;/
}

/*---------------------------
  Confirm
---------------------------*/
.confirm__note{
  margin-bottom: 2em;
}
.confirm__list{
  display: grid;
  gap: 1em;
  padding: 2em 1em;
  background-color: var(--transparent);
  margin-bottom: 3em;
}
.confirm__item-title{
  padding-left: 1em;
  border-left: 3px solid var(--accent-color);
}
.confirm__item{
  padding-left: 2em;
  margin-bottom: 1em;
}
.form__button-group{
  display: grid;
  grid-template-columns: auto;
  gap: 1em;
}
/* For PC */
@media (912px < width) {  
  .confirm__list{
    display: grid;
    grid-template-columns: repeat(2,auto 1fr);
    grid-template-rows: 1fr;
    gap: 2em 1em;
    padding: 2em;
  }
  .mansion-reform:not([style*="display: none;"]){
    grid-column: 1/ -1;
    display: grid !important;
    grid-template-columns: subgrid;
    gap: 2em 1em;
  }
  .group-other:not([style*="display: none;"]){
    grid-column: span 2;
    display: grid !important;
    grid-template-columns: subgrid;
  }
  .confirm__item-title,
  .confirm__item{
    display: flex;
    align-items: center;
    border-bottom: 1px dashed var(--accent-color);
    padding-bottom: 1em;
  }
  .confirm__item{
    margin-bottom: 0;
  }
  .form__button-group{
    width: min(80%, 800px);
    grid-template-columns: repeat(2,auto);
    margin: 0 auto;
  }
}
/*---------------------------
  Thanks
---------------------------*/
.thanks__confirm-list{
  margin-top: 2em;
}
.thanks__item{
  padding-left: 1em;
  margin-bottom: 1em;
}
.thanks__next-step{
  display: grid;
  gap: 2em;
}
/* For PC */
@media (912px < width) {
  .thanks__item{
    padding-left: 0;
    width: 70%;
  }
  .thanks__confirm-list{
    display: flex;
    flex-wrap: wrap;
  }
}

.thanks__notice a{
  display: inline;
}