/*============================
#cta
============================*/
section#cta {
  display: flex;
  padding: var(--scale-56, 56px) var(--padding-inline, 20px)
    var(--scale-40, 40px) var(--padding-inline, 20px);
  flex-direction: column;
  align-items: center;
  align-self: stretch;
  background: url(../images/cta-bg-right.png) right top / 300px auto no-repeat,
    url(../images/cta-bg-left.png) left top / 300px auto no-repeat, #fff8c5;
}
section#cta div.cta__container {
  display: flex;
  max-width: 800px;
  padding: 0 var(--scale-20, 20px) var(--scale-40, 40px) var(--scale-20, 20px);
  flex-direction: column;
  align-items: center;
  gap: var(--scale-24, 24px);
  align-self: stretch;
  border-radius: var(--scale-16, 16px);
  border: var(--scale-8, 8px) solid var(--primary, #f0813b);
  background: var(--surface, #fff);
  margin-inline: auto;
  width: 100%;
}
section#cta div.cta__container div.cta__bridge {
  display: flex;
  align-items: center;
  gap: var(--scale-24, 24px);
  font-size: min(24px, 100vw / 375 * 18);
  margin-top: -1em;
}
section#cta div.cta__container div.cta__bridge div.bridge__copy {
  display: flex;
  flex-direction: column;
  align-items: center;
}
section#cta div.cta__container div.cta__bridge div.bridge__copy span {
  display: flex;
  padding: var(--scale-8, 8px) var(--scale-16, 16px);
  justify-content: center;
  align-items: center;
  border-radius: 1000px;
  background: var(--on-surface, #423527);
  color: var(--surface, #fff);
  text-align: center;
  font-family: "Zen Maru Gothic";
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
section#cta div.cta__container div.cta__bridge div.bridge__copy svg {
  width: var(--scale-20, 20px);
  aspect-ratio: 5/2;
  margin-top: -1px;
}
section#cta div.cta__container div.cta__heading {
}
section#cta div.cta__container div.cta__heading h2 {
}
section#cta div.cta__container div.cta__heading h2 span {
  display: flex;
  padding: var(--scale-4, 4px) 0;
  justify-content: center;
  align-items: center;
  border-bottom: var(--scale-4, 4px) solid var(--primary, #f0813b);
  color: var(--on-surface, #423527);
  text-align: center;
  font-family: "Zen Maru Gothic";
  font-size: min(32px, 100vw / 375 * 18);
  font-style: normal;
  font-weight: 700;
  line-height: 130%; /* 41.6px */
}
section#cta div.cta__container div.cta__tel {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--scale-8, 8px);
  align-self: stretch;
  border: 1px solid var(--on-surface, #423527);
  width: 100%;
  max-width: 520px;
  border-radius: 100000px;
  padding: var(--scale-12, 12px) var(--scale-24, 24px);
  margin-inline: auto;
}
section#cta div.cta__container div.cta__tel:before {
  content: "タップで今すぐ電話できます";
  padding: var(--scale-8) var(--scale-16);
  font-size: var(--scale-14);
  line-height: 1em;
  background: var(--on-surface);
  color: #fff;
  border-radius: 10000px;
  margin-top: -1.5em;
}
section#cta div.cta__container div.cta__tel a {
  color: var(--on-surface, #423527);
  font-family: "Zen Maru Gothic";
  font-size: var(--scale-40, 40px);
  font-style: normal;
  font-weight: 700;
  line-height: 100%; /* 40px */
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--scale-8, 8px);
  align-self: stretch;
}
section#cta div.cta__container div.cta__tel .tel__num {
  display: flex;
  gap: var(--scale-8, 8px);
  justify-content: center;
  align-items: center;
}
section#cta div.cta__container div.cta__tel a svg {
  width: calc(1em / 40 * 32);
  aspect-ratio: 1 / 1;
  flex-shrink: 0;
}

section#cta div.cta__container div.cta__tel div.tel--hours {
  color: var(--on-surface, #423527);
  font-family: "Noto Sans JP";
  font-size: var(--scale-14, 14px);
  font-style: normal;
  font-weight: 500;
  line-height: 120%; /* 16.8px */
}
section#cta div.cta__container nav.cta__buttons {
  width: 100%;
}
section#cta div.cta__container nav.cta__buttons ul {
  display: flex;
  justify-content: center;
  gap: var(--scale-20, 20px);
  align-self: stretch;
  width: 100%;
}

section#cta div.cta__container nav.cta__buttons ul li {
}
section#cta div.cta__container nav.cta__buttons a {
  display: flex;
  max-width: 280px;
  padding: var(--scale-16, 16px);
  justify-content: center;
  align-items: center;
  gap: var(--scale-8, 8px);
  flex: 1 0 0;
  color: var(--surface, #fff);
  font-family: "Zen Maru Gothic";
  font-size: var(--scale-20, 20px);
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  width: 100%;
  text-align: center;
  margin-inline: auto;
}

@media screen and (max-width: 768px) {
  section#cta div.cta__container div.cta__tel {
    flex-direction: column;
  }
  section#cta div.cta__container div.cta__tel a {
    flex-direction: column;
  }
  section#cta div.cta__container nav.cta__buttons ul {
    flex-direction: column;
  }
  section#cta div.cta__container div.cta__tel div.tel--hours {
    text-align: center;
  }
}
