@charset "UTF-8";
.contact-section {
  background-color: #F9E3E8;
  margin-bottom: clamp(4rem, 2.8333333333rem + 3.8888888889vw, 7.5rem);
}
.contact-section .page-title {
  margin-bottom: clamp(3.875rem, 3.0833333333rem + 2.6388888889vw, 6.25rem);
}
.contact-section .page-sub-section {
  background-color: #FFFFFF;
  padding: 0 clamp(1rem, 0.5rem + 1.6666666667vw, 2.5rem) 7.5rem;
  padding-bottom: clamp(120px, 160px - (100vw - 1440px) * 0.05208, 160px);
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: clamp(1.5rem, 1.1666666667rem + 1.1111111111vw, 2.5rem);
  position: relative;
}
.contact-section .page-sub-section + .page-sub-section {
  margin-top: clamp(4rem, 3.6666666667rem + 1.1111111111vw, 5rem);
}
@media screen and (max-width: 480px) {
  .contact-section .page-sub-section {
    padding-bottom: 160px;
  }
}
.contact-section .sub-section-title {
  background-color: #E1395F;
  color: #FFFFFF;
  display: inline-block;
  font-size: clamp(1.375rem, 1.1666666667rem + 0.6944444444vw, 2rem);
  padding: clamp(0.75rem, 0.6666666667rem + 0.2777777778vw, 1rem) clamp(2rem, 1.5rem + 1.6666666667vw, 3.5rem);
  border-radius: 100vw;
  font-weight: 400;
  margin-top: calc(clamp(1rem, 0.6666666667rem + 1.1111111111vw, 2rem) * -1);
  margin-bottom: clamp(2.5rem, 2rem + 1.6666666667vw, 4rem);
}
@media screen and (max-width: 480px) {
  .contact-section {
    margin-bottom: 0;
  }
}

.tel-section__note {
  font-size: clamp(1rem, 0.8333333333rem + 0.5555555556vw, 1.5rem);
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: clamp(1.5rem, 1.1666666667rem + 1.1111111111vw, 2.5rem);
  text-align: center;
}
.tel-section__tel-number {
  font-size: clamp(2.5rem, 1.6666666667rem + 2.7777777778vw, 5rem);
  font-weight: 600;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5;
  color: #E1395F;
  margin-bottom: clamp(1.5rem, 1.1666666667rem + 1.1111111111vw, 2.5rem);
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
}
.tel-section__tel-number::before {
  content: "";
  display: inline-block;
  height: 0.8em;
  width: 0.8em;
  background: url("../../../assets/images/page/contact/tel.svg") no-repeat center/contain;
}
.tel-section .business-hours-wrapper {
  max-width: 816px;
  width: 100%;
  text-align: right;
}
.tel-section .business-hours th,
.tel-section .business-hours td {
  text-align: center;
  font-size: clamp(0.75rem, 0.5416666667rem + 0.6944444444vw, 1.375rem);
  line-height: 1.5;
  border: 1px solid #FFFFFF;
  background-color: #F9E3E8;
  font-weight: 500;
}
.tel-section .business-hours thead th {
  background-color: #E1395F;
  color: #FFFFFF;
}
.tel-section .business-hours th[scope=row] {
  white-space: nowrap;
}
.tel-section .annotation {
  display: inline-block;
  font-size: clamp(0.75rem, 0.6666666667rem + 0.2777777778vw, 1rem);
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 0.5rem;
}
.tel-section .annotation::before {
  content: "★";
  color: #E1395F;
}
.tel-section__illust {
  position: absolute;
  width: clamp(0rem, -5.2083333333rem + 17.3611111111vw, 15.625rem);
  bottom: -20px;
  right: clamp(1rem, 0.8333333333rem + 0.5555555556vw, 1.5rem);
}
@media screen and (max-width: 1024px) {
  .tel-section__illust {
    width: 10.5rem;
    right: auto;
    left: 50%;
    transform: translateX(-50%);
  }
}

.cf-section__note {
  font-size: clamp(1rem, 0.8333333333rem + 0.5555555556vw, 1.5rem);
  font-weight: 500;
  line-height: 1.66;
  text-align: center;
  margin-bottom: clamp(2rem, 1.3333333333rem + 2.2222222222vw, 4rem);
}

.thanks-section__thanks-title {
  max-width: 400px;
  width: 100%;
  text-align: center;
  color: #E1395F;
  font-size: clamp(1.5rem, 1.3333333333rem + 0.5555555556vw, 2rem);
  font-weight: 500;
  padding-bottom: clamp(0.5rem, 0.3333333333rem + 0.5555555556vw, 1rem);
  border-bottom: 1px solid #E1395F;
  margin-bottom: clamp(1.5rem, 1rem + 1.6666666667vw, 3rem);
}
.thanks-section__note {
  font-size: clamp(1rem, 0.8333333333rem + 0.5555555556vw, 1.5rem);
  font-weight: 500;
  line-height: 1.66;
  letter-spacing: -0.04em;
  text-align: center;
  margin-bottom: clamp(2rem, 1.3333333333rem + 2.2222222222vw, 4rem);
}
.thanks-section a {
  color: #E1395F;
  font-size: clamp(1rem, 0.8333333333rem + 0.5555555556vw, 1.5rem);
  font-weight: 500;
}
@media screen and (max-width: 480px) {
  .thanks-section__thanks-title {
    max-width: 280px;
  }
}

#page-exp.contact-section .page-title,
#page-exp-confirm.contact-section .page-title,
#page-exp-thanks.contact-section .page-title {
  margin-bottom: clamp(3rem, 2.6666666667rem + 1.1111111111vw, 4rem);
}
#page-exp.contact-section .exp-wrapper,
#page-exp-confirm.contact-section .exp-wrapper,
#page-exp-thanks.contact-section .exp-wrapper {
  padding-top: clamp(3rem, 2.6666666667rem + 1.1111111111vw, 4rem);
}

#page-exp.contact-section {
  padding-bottom: clamp(1.5rem, 1rem + 1.6666666667vw, 3rem);
}
#page-exp.contact-section .exp-illust {
  margin: 0 auto;
  height: clamp(10rem, 6.6666666667rem + 11.1111111111vw, 20rem);
  margin-top: clamp(1.5rem, 1rem + 1.6666666667vw, 3rem);
}