section {
 position: relative;
 width: 100%;
}

.bg {
 position: relative;
 padding: 0 0 120px;
 background: url(/common/img/common_bg.webp) center top;
}
@media screen and (max-width: 1024px) {
 .bg {
  padding-bottom: 70px;
 }
}
@media screen and (max-width: 600px) {
 .bg {
  padding-bottom: 40px;
 }
}

.lead {
 margin-top: 100px;
}
@media screen and (max-width: 1024px) {
 .lead {
  margin-top: 50px;
 }
}
.lead--inner {
 width: 90%;
 max-width: 900px;
 margin: 0 auto;
}
.lead--txt {
 line-height: 1.875;
 margin-bottom: 60px;
 font-size: 16px;
 letter-spacing: 0.08em;
}
@media screen and (max-width: 1024px) {
 .lead--txt {
  margin-bottom: 30px;
  font-size: 14px;
 }
}
.lead--contact li:not(:last-child) {
 margin-bottom: 50px;
 padding-bottom: 50px;
 border-bottom: 1px solid #9e9e9e;
}
@media screen and (max-width: 1024px) {
 .lead--contact li:not(:last-child) {
  margin-bottom: 30px;
  padding-bottom: 30px;
 }
}
.lead--contact dl {
 display: grid;
 align-items: start;
 grid-template-columns: auto 1fr;
 gap: 10px;
}
.lead--contact dl dt {
 line-height: 1;
 padding: 5px 20px 7px;
 border-radius: 50px;
 color: var(--c_bl);
 background: var(--white);
 font-size: 14px;
 letter-spacing: 0.12em;
}
@media screen and (max-width: 1024px) {
 .lead--contact dl dt {
  font-size: 12px;

  padding-inline: 10px;
 }
}
.lead--contact dl dd {
 line-height: 1.3;
 align-self: center;
 font-size: 20px;
 letter-spacing: 0.1em;
}
@media screen and (max-width: 1024px) {
 .lead--contact dl dd {
  font-size: 16px;
 }
}
.lead--contact dl dd span {
 font-size: 0.7em;
}
.lead--contact dl dd a[href*="tel:"] {
 pointer-events: none;
}
@media screen and (max-width: 600px) {
 .lead--contact dl dd a[href*="tel:"] {
  pointer-events: auto;
 }
}
.lead--contact_ttl {
 display: flex;
 align-items: center;
 gap: 15px;
}
@media screen and (max-width: 1024px) {
 .lead--contact_ttl {
  gap: 10px;
 }
}
@media screen and (max-width: 1024px) {
 .lead--contact_ttl svg {
  width: 50px;
 }
}
.lead--contact_ttl span {
 line-height: 1;
 font-weight: 500;
 font-size: 24px;
 letter-spacing: 0.05em;
}
@media screen and (max-width: 1024px) {
 .lead--contact_ttl span {
  font-size: 20px;
 }
}
.lead--contact_tel,.lead--contact_mail {
 padding-left: 85px;
}
@media screen and (max-width: 1024px) {
 .lead--contact_tel,.lead--contact_mail {
  padding-left: 60px;
 }
}
.lead--contact_mail {
 line-height: 2;
 font-size: 16px;
 letter-spacing: 0.08em;
}
@media screen and (max-width: 1024px) {
 .lead--contact_mail {
  font-size: 14px;
 }
}
.lead--contact_mail span {
 font-size: 0.875em;
}
.lead--contact_mail span.red {
 color: #e60012;
}
.lead--contact_place {
 line-height: 1;
 margin-bottom: 10px;
 font-size: 20px;
 letter-spacing: 0.08em;
}
@media screen and (max-width: 1024px) {
 .lead--contact_place {
  font-size: 18px;
 }
}

.form {
 margin-top: 60px;
}
@media screen and (max-width: 1024px) {
 .form {
  margin-top: 30px;
 }
}
.form--inner {
 width: 90%;
 max-width: 1100px;
 margin: 0 auto;
 padding: 70px 5%;
 background: var(--white);
}
@media screen and (max-width: 1024px) {
 .form--inner {
  padding-block: 40px;
 }
}
.form--wrap {
 display: grid;
 grid-template-columns: 240px 1fr;
}
@media screen and (max-width: 1024px) {
 .form--wrap {
  grid-template-columns: 1fr;
  gap: 20px;
 }
}
.form--wrap +.form--wrap {
 margin-top: 80px;
 padding-top: 80px;
 border-top: 1px solid #9e9e9e;
}
@media screen and (max-width: 1024px) {
 .form--wrap +.form--wrap {
  margin-top: 40px;
  padding-top: 40px;
 }
}
.form--wrap h2 {
 line-height: 1.3333333333;
 font-weight: 500;
 font-size: 24px;
 letter-spacing: 0.03em;
}
@media screen and (max-width: 1024px) {
 .form--wrap h2 {
  font-size: 20px;
 }
}
.form--wrap dl dt {
 display: flex;
 line-height: 1.875;
 align-items: center;
 gap: 10px;
 margin-bottom: 15px;
 font-weight: 500;
 font-size: 16px;
 letter-spacing: 0.02em;
}
@media screen and (max-width: 1024px) {
 .form--wrap dl dt {
  margin-bottom: 10px;
  font-size: 14px;
 }
}
.form--wrap dl dt span {
 line-height: 1;
 padding: 1px 2px 2px;
 border-radius: 5px;
 color: var(--white);
 background: #e60012;
 font-weight: 500;
 font-size: 11px;
 letter-spacing: 0.02em;
}
.form--wrap dl dd:not(:last-child) {
 margin-bottom: 25px;
}
.form--wrap dl dd input:not([type=checkbox]) {
 width: 100%;
 padding: 18px 15px;
 border: 1px solid #9e9e9e;
 border-radius: 5px;
 background: #f7f7f7 !important;
 font-size: 16px;
}
@media screen and (max-width: 1024px) {
 .form--wrap dl dd input:not([type=checkbox]) {
  padding: 15px 10px;
  font-size: 14px;
 }
}
.form--wrap dl dd textarea {
 width: 100%;
 height: 200px;
 line-height: 1.8;
 padding: 18px 15px;
 border: 1px solid #9e9e9e;
 border-radius: 5px;
 background: #f7f7f7 !important;
 font-size: 16px;
}
@media screen and (max-width: 600px) {
 .form--wrap dl dd textarea {
  height: 150px;
 }
}
.form--wrap dl dd .postal {
 display: flex;
 align-items: center;
 gap: 10px;
 margin-bottom: 20px;
}
.form--wrap dl dd .postal input {
 width: 100px;
}
.form--wrap dl dd ul.check {
 display: flex;
 flex-wrap: wrap;
 gap: 10px 40px;
}
@media screen and (max-width: 1024px) {
 .form--wrap dl dd ul.check {
  gap: 10px 20px;
 }
}
.form--wrap dl dd ul.check li label {
 display: flex;
 align-items: center;
 gap: 10px;
 font-size: 16px;
}
.form .mfp_buttons {
 display: flex;
 flex-direction: column;
 align-items: center;
 gap: 25px;
 margin-top: 80px;
}
@media screen and (max-width: 1024px) {
 .form .mfp_buttons {
  margin-top: 40px;
 }
}
.form .mfp_buttons .agree label {
 display: flex;
 align-items: center;
}
@media screen and (max-width: 600px) {
 .form .mfp_buttons .agree label {
  font-size: 14px;
 }
}
.form .mfp_buttons .agree label input {
 margin-right: 10px;
}
@media screen and (max-width: 600px) {
 .form .mfp_buttons .agree label input {
  margin-right: 5px;
 }
}
.form .mfp_buttons .agree label a {
 color: var(--c_bl);
 text-decoration: underline;
}
.form .mfp_buttons button {
 display: flex;
 position: relative;
 width: 320px;
 height: 80px;
 line-height: 1;
 justify-content: center;
 align-items: center;
 border: 1px solid var(--c_bl);
 color: var(--c2);
 background: var(--c1);
 font-size: 24px;
 letter-spacing: 0.03em;
 transition: all 0.3s;

 --c1: var(--c_bl);
 --c2: var(--white);
}
@media screen and (max-width: 1024px) {
 .form .mfp_buttons button {
  width: 250px;
  height: 60px;
  font-size: 18px;
 }
}
@media (hover) {
 .form .mfp_buttons button:hover {
  --c1: var(--white);
  --c2: var(--c_bl);
 }
}
.form .mfp_buttons button .icon_btn_arw {
 position: absolute;
 top: 50%;
 right: 20px;
 translate: 0 -50%;
}
@media screen and (max-width: 1024px) {
 .form .mfp_buttons button .icon_btn_arw {
  width: 25px;
 }
}
.form .mfp_buttons button .icon_btn_arw .cls-1,.form .mfp_buttons button .icon_btn_arw .cls-2 {
 stroke: var(--c2);
}

.thanks {
 margin-top: 150px;
 text-align: center;
}
@media screen and (max-width: 1024px) {
 .thanks {
  margin-top: 70px;
 }
}
.thanks h2 {
 display: flex;
 line-height: 1;
 flex-direction: column;
 justify-content: center;
 align-items: center;
 gap: 50px;
 margin-bottom: 40px;
 font-weight: 500;
 font-size: 40px;
 letter-spacing: 0.08em;
}
@media screen and (max-width: 1024px) {
 .thanks h2 {
  gap: 30px;
  font-size: 30px;
 }
}
.thanks h2 img {
 width: 65px;
}
@media screen and (max-width: 1024px) {
 .thanks h2 img {
  width: 52px;
 }
}
.thanks p {
 width: 90%;
 line-height: 2;
 margin: 0 auto;
 font-size: 16px;
 letter-spacing: 0.08em;
}
@media screen and (max-width: 1024px) {
 .thanks p {
  font-size: 14px;
  text-align: left;
 }
}
.thanks .top {
 display: flex;
 justify-content: center;
 align-items: center;
 margin-top: 70px;
}
@media screen and (max-width: 1024px) {
 .thanks .top {
  margin-top: 40px;
 }
}
.thanks .top a {
 display: flex;
 align-items: center;
 gap: 10px;
}
@media (hover) {
 .thanks .top a:hover svg {
  translate: -5px 0;
 }
}
.thanks .top a svg {
 rotate: 180deg;
}
.thanks .top a span {
 line-height: 1;
 font-size: 24px;
 letter-spacing: 0.03em;
}
@media screen and (max-width: 1024px) {
 .thanks .top a span {
  font-size: 20px;
 }
}

#mfp_overlay_inner h4 {
 margin-bottom: 20px;
 font-weight: 500;
 font-size: 20px;
}
@media screen and (max-width: 768px) {
 #mfp_overlay_inner h4 {
  font-size: 16px;
 }
}
#mfp_overlay_inner #mfp_confirm_table tr th,#mfp_overlay_inner #mfp_confirm_table tr td {
 font-size: 16px;
}
@media screen and (max-width: 768px) {
 #mfp_overlay_inner #mfp_confirm_table tr th,#mfp_overlay_inner #mfp_confirm_table tr td {
  font-size: 12px;
 }
}
#mfp_overlay_inner .mfp_buttons {
 display: flex;
 justify-content: center;
 align-items: center;
 gap: 10px;
 margin-top: 20px;
}
@media screen and (max-width: 768px) {
 #mfp_overlay_inner .mfp_buttons {
  justify-content: space-between;
  gap: 0;
 }
}
#mfp_overlay_inner .mfp_buttons button {
 display: flex;
 position: relative;
 width: 150px;
 height: 40px;
 line-height: 1;
 justify-content: center;
 align-items: center;
 border: 1px solid var(--c_bl);
 color: var(--c2);
 background: var(--c1);
 font-size: 16px;
 letter-spacing: 0.03em;
 transition: all 0.3s;

 --c1: var(--c_bl);
 --c2: var(--white);
}
@media (hover) {
 #mfp_overlay_inner .mfp_buttons button:hover {
  --c1: var(--white);
  --c2: var(--c_bl);
 }
}
@media screen and (max-width: 768px) {
 #mfp_overlay_inner .mfp_buttons button {
  width: 48%;
 }
}
#mfp_overlay_inner .mfp_buttons button#mfp_button_cancel {
 --c1: var(--white);
 --c2: var(--c_bl);
}
@media (hover) {
 #mfp_overlay_inner .mfp_buttons button#mfp_button_cancel:hover {
  --c1: var(--c_bl);
  --c2: var(--white);
 }
}
#mfp_overlay_inner .mfp_buttons button .icon_btn_arw {
 position: absolute;
 top: 50%;
 right: 20px;
 translate: 0 -50%;
}
#mfp_overlay_inner .mfp_buttons button .icon_btn_arw .cls-1,#mfp_overlay_inner .mfp_buttons button .icon_btn_arw .cls-2 {
 stroke: var(--c2);
}
/*# sourceMappingURL=layout.css.map */