@charset "UTF-8";
main {
  margin: 0 auto;
  padding-top: 60px;
  padding-bottom: 0;
}

header #header-bottom nav .sns {
  display: none;
}

footer {
  margin-top: 100px;
}

/**
お問い合わせ
*/
#page-contact {
  padding-bottom: 50px;
}
#page-contact .description {
  text-align: center;
}
#page-contact .description p {
  font-size: 1.6rem;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  text-align: center;
  color: #333;
}
#page-contact .description:last-of-type {
  margin-bottom: 0;
}
#page-contact p {
  font-size: 1.6rem;
  line-height: 1.75;
}
#page-contact p + p {
  margin-top: 1em;
}
#page-contact a {
  color: #333333;
  text-decoration: none;
  border-bottom: 1px solid #7a7a7a;
}
#page-contact .tel {
  width: 400px;
  margin: 25px auto 0;
}
#page-contact .tel .title {
  background-color: #9a7d4f;
  color: #fff;
  text-align: center;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
}
#page-contact .tel .text {
  border: 1px solid #cccccc;
  border-top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 12px;
  gap: 10px;
}
#page-contact .tel .text a {
  font-size: 3.2rem;
  line-height: 1;
  text-decoration: none;
  font-weight: bold;
  border-bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
#page-contact .tel .text a:before {
  content: "";
  display: block;
  background: url(../img/common/icon-tel.png) center center no-repeat;
  background-size: contain;
  width: 21px;
  height: 26px;
  margin-top: 4px;
  margin-right: 5px;
}
#page-contact .tel .text p {
  font-size: 1.6rem;
  line-height: 1.75;
  font-weight: bold;
}
#page-contact .form {
  width: 900px;
  margin: 40px auto 0;
}
#page-contact .form h3 {
  text-align: center;
  background-color: #b3aa82;
  padding: 8px 10px;
  font-size: 2rem;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  text-align: left;
  color: #fff;
}
#page-contact .form table {
  display: block;
  margin-top: 45px;
}
#page-contact .form table tr th,
#page-contact .form table tr td {
  border: 1px solid #fff;
  font-size: 1.6rem;
  padding: 14px 12px 10px 20px;
}
#page-contact .form table tr th {
  text-align: left;
  width: 260px;
  padding-top: 25px;
  padding-bottom: 25px;
  color: #333333;
  vertical-align: top;
  background-color: #ebebeb;
}
#page-contact .form table tr th.middle {
  vertical-align: middle;
  padding-top: 0;
}
#page-contact .form table tr th:after {
  float: right;
  background: #aaaaaa;
  color: #fff;
  font-size: 1.2rem;
  line-height: 1;
  padding: 4px 11px;
  margin-top: -2px;
}
#page-contact .form table tr th.require:after {
  content: "必須";
  background: #ff0000;
}
#page-contact .form table tr td {
  background-color: #fff5eb;
}
#page-contact .form table tr .label {
  font-size: 1.4rem;
  color: #999999;
  display: block;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
#page-contact .form table tr .label:first-of-type {
  margin-top: 0;
}
#page-contact .form table tr .label:last-of-type {
  margin-bottom: 0;
}
#page-contact .form table tr .wpcf7-not-valid-tip {
  font-size: 1.6rem;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
#page-contact .form table tr select,
#page-contact .form table tr textarea,
#page-contact .form table tr input[type=text],
#page-contact .form table tr input[type=email] {
  border: 1px solid #cccccc;
  padding: 0.32em 0.65em;
  font-size: 1.6rem;
  max-width: 450px;
  font-family: "Noto Sans JP", sans-serif;
  border-radius: 5px;
}
#page-contact .form table tr input[type=checkbox],
#page-contact .form table tr input[type=radio] {
  accent-color: #575757;
}
#page-contact .form table tr textarea {
  width: 100%;
}
#page-contact .form table tr input[type=file]::file-selector-button {
  cursor: pointer;
  font-size: 1.4rem;
  margin-top: 12px;
}
#page-contact .form table tr ::placeholder {
  color: #333;
}
#page-contact .form table tr [name=name-sei],
#page-contact .form table tr [name=name-mei],
#page-contact .form table tr [name=kana-sei],
#page-contact .form table tr [name=kana-mei] {
  width: 248px;
}
#page-contact .form table tr .search_address {
  margin-left: 12px;
  color: #9a7d4f;
  border-color: #9a7d4f;
  font-weight: bold;
}
#page-contact .form table tr .wpcf7-acceptance .wpcf7-list-item {
  margin-left: 0;
}
#page-contact .form table tr .wpcf7-checkbox {
  display: flex;
  flex-direction: column;
  margin-top: 0.75em;
}
#page-contact .form table tr .wpcf7-checkbox .wpcf7-list-item {
  margin-left: 0;
}
#page-contact .form table tr .wpcf7-radio {
  display: flex;
  align-items: center;
  gap: 15px;
  padding-top: 10px;
}
#page-contact .form table tr .wpcf7-radio .wpcf7-list-item {
  margin-left: 0;
}
#page-contact .form table tr .wpcf7-radio .wpcf7-list-item label {
  display: flex;
  align-items: center;
}
#page-contact .form table tr .wpcf7-radio .wpcf7-list-item:last-of-type {
  margin-bottom: 0;
}
#page-contact .form table tr .line {
  margin-top: 0.25em;
  margin-bottom: 0.5em;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}
#page-contact .form table tr dl dt {
  display: flex;
  align-items: center;
  margin-top: 0.75em;
  margin-bottom: 0.25em;
}
#page-contact .form table tr dl dd {
  margin-top: 0.5em;
  margin-bottom: 0.25em;
}
#page-contact .form table tr .boxes {
  display: flex;
  align-items: center;
  gap: 25px;
}
#page-contact .form table tr .boxes .box {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 1.6rem;
}
#page-contact .form table tr .boxes .box .name {
  color: #333333;
}
#page-contact .form table tr .boxes .box .name span {
  font-size: 1.2rem;
  display: block;
  margin-top: 4px;
}
#page-contact .form table tr .boxes .box label input {
  font-size: 1.6rem;
  width: 3.25em;
  padding: 8px 8px;
  margin-right: 4px;
}
#page-contact .form .check {
  display: flex;
  height: 100%;
  align-items: center;
  padding-top: 4px;
}
#page-contact .form .check label {
  padding: 5px;
}
#page-contact .form .wpcf7-response-output {
  width: 700px;
  margin: 50px auto 0;
}
#page-contact .form .btns {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  margin-top: 48px;
  gap: 50px;
  transform: translateX(-50px);
}
#page-contact .form [type=reset] {
  font-size: 1.6rem;
  background: transparent;
  border: 0;
  border-bottom: 1px solid #333;
  padding: 0 0 4px;
  margin: 0;
  color: #333;
  cursor: pointer;
}
#page-contact .form [type=reset]:hover {
  opacity: 0.65;
}
#page-contact .form .submit {
  display: flex;
  align-items: center;
  position: relative;
}
#page-contact .form .submit .ajax-loader {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateX(-50%);
}
#page-contact .form .submit [type=submit] {
  display: block;
  border: 0;
  font-size: 1.8rem;
  color: #fff;
  width: 278px;
  height: 50px;
  cursor: pointer;
  font-weight: bold;
  border-radius: 25px;
  background-color: #ee7700;
  font-family: "Noto Sans JP", sans-serif;
}
#page-contact .form .submit [type=submit]:hover {
  opacity: 0.5;
}
#page-contact .form .submit [type=submit]:disabled {
  opacity: 1;
  background-color: #ccc;
  cursor: not-allowed;
}

#page-complete,
#page-contact_send {
  padding: 20px 0 50px;
  position: relative;
}
#page-complete h3,
#page-contact_send h3 {
  font-size: 1.6rem;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  letter-spacing: normal;
  text-align: center;
  color: #333;
}
#page-complete .message,
#page-contact_send .message {
  margin: 35px auto 0;
  width: 720px;
}
#page-complete .message p,
#page-contact_send .message p {
  font-size: 1.6rem;
  line-height: 1.75;
  font-stretch: normal;
  font-style: normal;
  letter-spacing: normal;
  text-align: center;
}
#page-complete .message p + p,
#page-contact_send .message p + p {
  margin-top: 30px;
}
#page-complete .message p a,
#page-contact_send .message p a {
  text-decoration: none;
  border-bottom: 1px solid #ccc;
}
#page-complete .link,
#page-contact_send .link {
  display: flex;
  justify-content: center;
  margin-top: 60px;
}
#page-complete .link a,
#page-contact_send .link a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 278px;
  height: 50px;
  border-radius: 25px;
  background-color: #e70;
  font-size: 1.6rem;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  text-align: center;
  color: #fff;
  text-decoration: none;
}

/**
サイトポリシー
*/
#page-privacy,
#page-sitepolicy {
  padding: 0;
  position: relative;
}
#page-privacy .inner,
#page-sitepolicy .inner {
  width: 1000px;
  margin: 0px auto 0;
  padding-bottom: 20px;
}
#page-privacy p,
#page-sitepolicy p {
  font-size: 1.6rem;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.65;
  letter-spacing: normal;
  text-align: left;
  color: #333;
}
#page-privacy dl,
#page-sitepolicy dl {
  margin-top: 60px;
}
#page-privacy dl dt,
#page-sitepolicy dl dt {
  font-size: 2.6rem;
  font-weight: bold;
  margin-top: 50px;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.65;
  letter-spacing: normal;
  text-align: left;
  color: #333;
}
#page-privacy dl dt:first-of-type,
#page-sitepolicy dl dt:first-of-type {
  margin-top: 0;
}
#page-privacy dl dd,
#page-sitepolicy dl dd {
  margin-top: 16px;
  font-size: 1.6rem;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
#page-privacy ol,
#page-privacy ul,
#page-sitepolicy ol,
#page-sitepolicy ul {
  margin-top: 20px;
}
#page-privacy ul li,
#page-sitepolicy ul li {
  padding-left: 1em;
  position: relative;
}
#page-privacy ul li:before,
#page-sitepolicy ul li:before {
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
}
#page-privacy ol li,
#page-sitepolicy ol li {
  list-style-type: decimal;
}

/**
リンク
*/
/**
サイトマップ
*/
/**
coming_soon
*/
#page-coming_soon {
  background-color: rgb(255, 255, 255);
  padding: 220px 0 0;
  position: relative;
}
#page-coming_soon .inner {
  width: 900px;
  margin: 0 auto;
}
#page-coming_soon h3 {
  font-size: 3.8rem;
  line-height: 1;
  font-weight: bold;
  text-align: center;
  color: #000000;
}
#page-coming_soon p {
  font-size: 1.8rem;
  line-height: 1.67;
  text-align: center;
  color: #333333;
  margin-top: 30px;
}
#page-coming_soon .link a {
  width: 300px;
  height: 60px;
  margin: 40px auto 0;
  font-size: 1.8rem;
}

/**
notfound
*/
#page-notfound-page {
  padding: 60px 0 0;
  position: relative;
}
#page-notfound-page .inner {
  width: 900px;
  margin: 0 auto;
}
#page-notfound-page h3 {
  font-size: 2.8rem;
  line-height: 1.3571428571;
  font-weight: bold;
  text-align: center;
}
#page-notfound-page p {
  font-size: 1.6rem;
  line-height: 1.5;
  text-align: center;
  margin: 60px auto 0;
  width: 750px;
}
#page-notfound-page p a {
  text-decoration: none;
  border-bottom: 1px solid #ccc;
}
#page-notfound-page .link {
  display: flex;
  justify-content: center;
  margin-top: 50px;
}
#page-notfound-page .link a {
  font-size: 2rem;
  line-height: 1.2;
  text-decoration: none;
  color: #9a7d4f;
  border-bottom: 2px solid #d0c4b4;
  font-weight: bold;
  letter-spacing: 0.04em;
  padding-bottom: 5px;
}
