@charset "UTF-8";
:root {
  --color-primary: #e83b2b;
  --color-secondary: #f2941d;
  --color-text: #333333;
  --color-bg: #ffffff;
  --color-blue: #004a81;
  --color-yellow: #f5c400;
  --color-green: #00993D;
  --color-cta-green: #00993d;
  --color-orange: #fb8e1f;
  --gradient-cta: linear-gradient(to right, #f2941d, #e83b2b);
  --font-family-base: 'Noto Sans JP', sans-serif;
  --font-family-heading: 'Noto Sans JP', sans-serif;
  --font-family-accent: 'Inter', sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
  font: inherit;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

input,
button,
textarea,
select {
  font: inherit;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

ol,
ul {
  list-style: none;
}

a {
  color: inherit;
  text-decoration: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

html {
  font-size: 4.2666666667vw;
  scrollbar-gutter: stable;
  scroll-behavior: smooth;
}
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}
@media screen and (min-width: 768px) {
  html {
    font-size: 1.1111111111vw;
  }
}
@media (min-width: 1440px) {
  html {
    font-size: 16px;
  }
}
html {
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-family-base);
  color: var(--color-text);
  background-color: var(--color-bg);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

address {
  font-style: normal;
  line-height: inherit;
  color: inherit;
}

.tellink {
  pointer-events: none;
}

@media screen and (max-width: 640px) {
  .tellink {
    pointer-events: auto;
  }
}
a {
  transition: opacity 0.3s ease;
}

@media (any-hover: hover) {
  a:hover {
    opacity: 0.8;
  }
}
.u-br-pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .u-br-pc {
    display: inline;
  }
}

@media screen and (min-width: 768px) {
  .u-br-sp {
    display: none;
  }
}

.header {
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #fff;
  z-index: 100;
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 3.75rem;
  max-width: 82.125rem;
  margin-inline: auto;
  padding-inline: 1.0625rem;
}
@media screen and (min-width: 768px) {
  .header__inner {
    padding-inline: 2.9375rem 5rem;
  }
}

.header__logo {
  display: inline-block;
  line-height: 0;
}

.header__logo picture,
.header__logo img {
  display: block;
}

.header__logo img {
  width: 20.25rem;
}

.header__cta {
  display: none;
  align-items: center;
  gap: 0.625rem;
  height: 3rem;
  padding-inline: 1.5rem;
  background: var(--gradient-cta);
  color: #fff;
  font-family: var(--font-family-base);
  font-weight: 700;
  font-size: 1rem;
  white-space: nowrap;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .header__cta {
    display: flex;
  }
}
.header__cta:hover {
  opacity: 0.85;
}

.header__cta-arrow {
  display: flex;
  align-items: center;
}

.header__cta-arrow img {
  transform: rotate(90deg);
  display: block;
}

.footer {
  background: #fff;
  padding: 3.5rem 1.125rem 1.5625rem;
}
@media screen and (min-width: 768px) {
  .footer {
    padding: 2rem 2.5rem;
  }
}

.footer__inner {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  max-width: 67.5rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .footer__inner {
    flex-direction: row;
    align-items: flex-end;
    gap: 0rem;
  }
}

.footer__info {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
@media screen and (min-width: 768px) {
  .footer__info {
    width: 17.5rem;
    flex-shrink: 0;
    gap: 1.25rem;
  }
}

.footer__brand {
  display: inline-block;
  line-height: 0;
  width: 20rem;
}
@media screen and (min-width: 768px) {
  .footer__brand {
    width: 20rem;
  }
}

.footer__brand picture,
.footer__brand img {
  display: block;
}

.footer__brand img {
  width: 100%;
  height: auto;
}

.footer__address {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.5;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .footer__address {
    font-size: 1rem;
    line-height: 1.6;
  }
}

.footer__lower {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
@media screen and (min-width: 768px) {
  .footer__lower {
    flex: 1;
    flex-direction: row;
    justify-content: flex-end;
    align-items: flex-end;
    gap: 4.875rem;
  }
}

.footer__nav {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
@media screen and (min-width: 768px) {
  .footer__nav {
    flex-direction: row;
    gap: 3.125rem;
  }
}

.footer__nav-link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.03em;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .footer__nav-link {
    font-size: 1rem;
  }
}
.footer__nav-link:hover {
  opacity: 0.7;
}

.footer__nav-link img {
  display: block;
  flex-shrink: 0;
  width: 0.875rem;
  height: auto;
}
@media screen and (min-width: 768px) {
  .footer__nav-link img {
    width: 1rem;
  }
}

.footer__copyright {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text);
  letter-spacing: 0.03em;
  white-space: nowrap;
  margin-top: 5rem;
}
@media screen and (min-width: 768px) {
  .footer__copyright {
    font-size: 1rem;
  }
}

.cta {
  background: var(--color-cta-green);
  clip-path: polygon(0 0, 50% 5.625rem, 100% 0, 100% 100%, 0 100%);
  padding: 7.5rem 1.25rem 2.9375rem;
}
@media screen and (min-width: 768px) {
  .cta {
    padding: 10.625rem 1.25rem 6.25rem;
  }
}

.cta__inner {
  max-width: 67.5rem;
  margin-inline: auto;
  text-align: center;
}

.cta__badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 7.0625rem;
  height: 2.5rem;
  border: 2px solid #fdfcf1;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 1.125rem;
  color: #fdfcf1;
  line-height: 1;
  margin-bottom: 0.75rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .cta__badge {
    width: 12.3125rem;
    height: 4.625rem;
    font-size: 2rem;
    margin-bottom: 1rem;
  }
}

.cta__heading {
  display: inline-block;
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 1.375rem;
  color: #fdfcf1;
  line-height: 1.3;
  margin-bottom: 0;
  transform: skewX(-8deg);
  transform-origin: center center;
}
@media screen and (min-width: 768px) {
  .cta__heading {
    font-size: 2.75rem;
    font-weight: 900;
    transform: skewX(-6deg);
  }
}

@media screen and (min-width: 768px) {
  .cta__heading-br {
    display: none;
  }
}

.cta__condition-img {
  width: 16.6875rem;
  margin-inline: auto;
  position: relative;
}
@media screen and (min-width: 768px) {
  .cta__condition-img {
    width: 22.5rem;
  }
}

.cta__condition-img img {
  width: 100%;
  height: auto;
  display: block;
}

.cta__amount-img {
  width: 17.75rem;
  margin-inline: auto;
  margin-top: -2rem;
  margin-bottom: 0.5rem;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .cta__amount-img {
    width: 22.9375rem;
    margin-top: -2.375rem;
    margin-bottom: 0.625rem;
  }
}

.cta__amount-img img {
  width: 100%;
  height: auto;
  display: block;
}

.cta__sub {
  font-family: var(--font-family-heading);
  font-weight: 900;
  font-size: 1.25rem;
  color: #fdfcf1;
  margin-bottom: 1.25rem;
}
@media screen and (min-width: 768px) {
  .cta__sub {
    font-size: 2.375rem;
    margin-bottom: 2rem;
  }
}

.cta__or {
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 0.875rem;
  color: #fdfcf1;
}
@media screen and (min-width: 768px) {
  .cta__or {
    font-size: 1.375rem;
  }
}

.cta__amount-img--sm {
  width: 13.75rem;
  margin-top: -2rem;
}
@media screen and (min-width: 768px) {
  .cta__amount-img--sm {
    width: 19.625rem;
    margin-top: -2.375rem;
  }
}

.cta__label-frame {
  box-sizing: content-box;
  background: #fff;
  clip-path: polygon(1.5rem 0, calc(100% - 1.5rem) 0, 100% 100%, 0 100%);
  width: 17.8125rem;
  height: 2.125rem;
  padding: 3px;
  margin-inline: auto;
  margin-bottom: -1.5rem;
}
@media screen and (min-width: 768px) {
  .cta__label-frame {
    box-sizing: border-box;
    width: 41.875rem;
    height: 3.75rem;
    clip-path: polygon(4% 0%, 96% 0, 99.5% 100%, 0.5% 100%);
  }
}

.cta__box {
  background: #fff;
  text-align: center;
}

.cta__label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 17.8125rem;
  height: 2.125rem;
  margin: 0;
  padding: 0;
  background: var(--gradient-cta);
  clip-path: polygon(8% 0%, 92% 0, 99% 100%, 1% 100%);
  color: #fff;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.3;
}
@media screen and (min-width: 768px) {
  .cta__label {
    width: 100%;
    height: 100%;
    font-size: 1.75rem;
    font-weight: 700;
    clip-path: polygon(4% 0%, 96% 0, 99% 100%, 1% 100%);
  }
}

.cta__box-body {
  padding: 1.25rem 0.625rem 3.125rem;
}
@media screen and (min-width: 768px) {
  .cta__box-body {
    width: 67.5rem;
    max-width: 100%;
    height: 26.25rem;
    margin-inline: auto;
    padding: 2.25rem 3.75rem 2.5rem;
  }
}

.cta__hours {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text);
  margin-top: 2.1875rem;
}
@media screen and (min-width: 768px) {
  .cta__hours {
    font-size: 1rem;
  }
}

.cta__tel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 2.375rem;
  color: var(--color-text);
  margin-bottom: 1.25rem;
}
@media screen and (min-width: 768px) {
  .cta__tel {
    font-size: 4.375rem;
    gap: 0.75rem;
    margin-bottom: 2rem;
    line-height: 1;
    margin-top: 0.4375rem;
  }
}

.cta__tel-icon {
  width: 2.375rem;
}
@media screen and (min-width: 768px) {
  .cta__tel-icon {
    width: 3.75rem;
    margin-top: 0.625rem;
  }
}

.cta__btns {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
@media screen and (min-width: 768px) {
  .cta__btns {
    justify-content: center;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
  }
}

.cta__contact-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  height: 2.6875rem;
  padding-inline: 0.375rem;
  color: #fff;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 1rem;
  box-shadow: 0.25rem 0.25rem 0.25rem 0 rgba(0, 0, 0, 0.25);
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .cta__contact-btn {
    flex: none;
    width: 16.5rem;
    height: 4.625rem;
    font-size: 1.5rem;
    padding-inline: 0.375rem 0.75rem;
  }
}
.cta__contact-btn:hover {
  opacity: 0.85;
}

.cta__contact-btn--mail {
  background: var(--color-primary);
}

.cta__contact-btn--line {
  background: #06C755;
}

.cta__contact-btn-icon img {
  display: block;
  width: 2.25rem;
  height: auto;
}
@media screen and (min-width: 768px) {
  .cta__contact-btn-icon img {
    width: 3.875rem;
  }
}

.cta__contact-btn--line .cta__contact-btn-icon img {
  width: 2.6875rem;
}
@media screen and (min-width: 768px) {
  .cta__contact-btn--line .cta__contact-btn-icon img {
    width: 4.625rem;
  }
}

.cta__contact-btn-text {
  text-align: center;
}

.cta__contact-btn-arrow img {
  display: block;
  width: 0.375rem;
  margin-left: 1rem;
}

.cta__disclaimer {
  font-size: 0.9375rem;
  color: var(--color-text);
  text-align: left;
  line-height: 1.3;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .cta__disclaimer {
    font-size: 1rem;
    text-align: center;
  }
}

.cta--mt-negative {
  margin-top: -6.25rem;
}

.sp-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
@media screen and (min-width: 768px) {
  .sp-cta {
    display: none;
  }
}

.sp-cta.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.sp-cta__main {
  margin-bottom: 0.3125rem;
}

.sp-cta__label {
  width: 12.5625rem;
  margin-inline: auto;
  margin-bottom: -0.625rem;
}

.sp-cta__btn {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 2.0625rem;
  width: 20.9375rem;
  height: 3.125rem;
  background: var(--gradient-cta);
  color: #fff;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 1.5rem;
  transition: opacity 0.3s ease;
  margin-inline: auto;
  padding-right: 1rem;
}
.sp-cta__btn:hover {
  opacity: 0.85;
}

.sp-cta__btn-arrow {
  width: 0.375rem;
}

.sp-cta__sub {
  display: flex;
  gap: 0.3125rem;
  padding: 0.3125rem;
}

.sp-cta__sub-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  height: 4rem;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 1.125rem;
  transition: opacity 0.3s ease;
  padding-inline: 0.5625rem 0.8125rem;
}
.sp-cta__sub-btn:hover {
  opacity: 0.85;
}

.sp-cta__sub-btn--tel {
  background: #fff;
  color: var(--color-orange);
  border: 1px solid var(--color-orange);
}

.sp-cta__sub-btn--line {
  background: #06C755;
  color: #fff;
}

.sp-cta__sub-btn-icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.sp-cta__sub-btn-icon img {
  display: block;
  height: auto;
}

.sp-cta__sub-btn--tel .sp-cta__sub-btn-icon img {
  width: 1.75rem;
}

.sp-cta__sub-btn--line .sp-cta__sub-btn-icon img {
  width: 3.5625rem;
}

.sp-cta__sub-btn-arrow {
  padding-left: 0.8125rem;
}

.sp-cta__sub-btn-arrow img {
  display: block;
}

.top-mv__hero {
  position: relative;
  background: url("../img/mv_bg_sp.jpg") center top/cover no-repeat;
  height: 39.8125rem;
}
@media screen and (min-width: 768px) {
  .top-mv__hero {
    height: 35.1875rem;
    background: url("../img/mv_bg.jpg") top/cover no-repeat;
  }
}

.top-mv__content {
  display: flex;
  flex-direction: column;
  gap: 7.625rem;
  padding-top: 3.3125rem;
}
@media screen and (min-width: 768px) {
  .top-mv__content {
    position: absolute;
    top: 50%;
    right: auto;
    bottom: auto;
    left: 50%;
    transform: translate(-74.5%, -50%);
    width: fit-content;
    justify-content: flex-end;
    gap: 1.0625rem;
    padding: 0;
  }
}

.top-mv__catch-img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .top-mv__catch-img {
    width: 60.4375rem;
  }
}

.top-mv__catch-img img {
  width: 100%;
  height: auto;
  display: block;
}

.top-mv__badges {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
  padding-inline: 1rem;
}
@media screen and (min-width: 768px) {
  .top-mv__badges {
    justify-content: flex-end;
    gap: 1.25rem;
    padding-inline: 0;
    margin-right: 1.5625rem;
  }
}

.top-mv__badge {
  flex: 1;
  max-width: 6.875rem;
}
@media screen and (min-width: 768px) {
  .top-mv__badge {
    flex: none;
    max-width: none;
    width: 8.75rem;
  }
}

.top-mv__badge img {
  width: 100%;
  height: auto;
  display: block;
}

.top-mv__cta-strip {
  display: none;
}
@media screen and (min-width: 768px) {
  .top-mv__cta-strip {
    display: block;
    padding-block: 3.125rem 6.875rem;
    background-color: #fff;
  }
}

.top-mv__cta-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  max-width: 33.75rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-mv__cta-inner {
    gap: 1.75rem;
  }
}
.top-mv__cta-inner .top-mv__cta-btn,
.top-mv__cta-inner .top-mv__contact-btn {
  box-shadow: 0.25rem 0.25rem 0.25rem 0 rgba(51, 51, 51, 0.25);
}

.top-mv__cta-label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3125rem;
  width: 100%;
  font-family: var(--font-family-heading);
  font-weight: 500;
  font-size: 2rem;
  color: var(--color-text);
  white-space: nowrap;
}

.top-mv__cta-line {
  width: 2.6875rem;
  height: 2px;
  background: currentColor;
  transform: rotate(-45deg);
  margin-top: 0.5625rem;
}
.top-mv__cta-line:first-of-type {
  transform: rotate(45deg);
}

.top-mv__cta-btn {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4.9375rem;
  width: 100%;
  height: 6.5625rem;
  background: var(--gradient-cta);
  color: #fff;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 2.25rem;
  transition: opacity 0.3s ease;
  padding-right: 1.25rem;
}
.top-mv__cta-btn:hover {
  opacity: 0.85;
}

.top-mv__cta-btn-arrow {
  margin-top: 0.1875rem;
}

.top-mv__cta-btn-arrow img {
  display: block;
  width: 0.625rem;
  height: auto;
}

.top-mv__contact-sub {
  font-family: var(--font-family-heading);
  font-weight: 500;
  color: var(--color-text);
  font-size: 1.5rem;
  margin-top: 0.9375rem;
}

.top-mv__contact-hours {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text);
  margin-top: -0.5rem;
}

.top-mv__contact-btns {
  display: flex;
  gap: 0.625rem;
  width: 100%;
}

.top-mv__contact-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  height: 3.75rem;
  font-family: var(--font-family-heading);
  font-weight: 700;
  transition: opacity 0.3s ease;
  width: 16.5rem;
  height: 4.625rem;
  font-size: 1.5rem;
  padding-right: 0.9375rem;
}
.top-mv__contact-btn:hover {
  opacity: 0.85;
}

.top-mv__contact-btn--tel {
  background: #fff;
  color: var(--color-orange);
  border: 1px solid var(--color-orange);
  gap: 2.125rem;
  justify-content: flex-end;
}

.top-mv__contact-btn--line {
  background: #06C755;
  color: #fff;
}

.top-mv__contact-btn-icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.top-mv__contact-btn--tel .top-mv__contact-btn-icon img {
  width: 3.1875rem;
}

.top-mv__contact-btn--line .top-mv__contact-btn-icon img {
  width: 4.625rem;
}

.top-mv__contact-btn-arrow {
  margin-left: 0.3125rem;
}

.top-mv__contact-btn-arrow img {
  display: block;
  transform: rotate(90deg);
}

.top-price {
  background: url("../img/price_bg_sp.png") top/cover no-repeat;
  padding-bottom: 2.1875rem;
}
@media screen and (min-width: 768px) {
  .top-price {
    background-image: url("../img/price_bg.jpg");
    padding: 1.875rem 1.25rem 6.25rem;
  }
}

.top-price__inner {
  max-width: 67.5rem;
  margin-inline: auto;
  text-align: center;
}

.top-price__heading {
  width: 19.8125rem;
  padding-top: 0.5625rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-price__heading {
    width: 49.6875rem;
  }
}

.top-price__slider {
  margin-top: 1.875rem;
  margin-inline: auto;
  max-width: 20.9375rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .top-price__slider {
    margin-top: 3.125rem;
    max-width: 67.5rem;
  }
}

.top-price__track-wrap {
  overflow: hidden;
}

.top-price__track {
  display: flex;
  transition: transform 0.4s ease;
}

.top-price__card {
  flex-shrink: 0;
  width: 100%;
}
.top-price__card a[x-apple-data-detectors] {
  color: inherit;
  text-decoration: none;
  pointer-events: none;
  cursor: default;
}

.top-price__card-city {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--color-text);
  text-align: center;
  letter-spacing: 0.03em;
  margin-bottom: 0.625rem;
}
@media screen and (min-width: 768px) {
  .top-price__card-city {
    font-size: 2rem;
    margin-bottom: 1rem;
  }
}

.top-price__card-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-bottom: 2.25rem;
}
@media screen and (min-width: 768px) {
  .top-price__card-meta {
    gap: 1.25rem;
    margin-bottom: 4.0625rem;
  }
}

.top-price__card-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 5rem;
  height: 5rem;
  background: var(--color-green);
  border-radius: 50%;
  color: #fff;
  flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .top-price__card-badge {
    width: 6.875rem;
    height: 6.875rem;
  }
}

.top-price__card-badge-type {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 0.875rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .top-price__card-badge-type {
    font-size: 0.9375rem;
  }
}

.top-price__card-badge-row {
  display: flex;
  align-items: baseline;
  gap: 0.125rem;
}

.top-price__card-badge-num {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 2rem;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .top-price__card-badge-num {
    font-size: 2.5rem;
  }
}

.top-price__card-badge-unit {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 0.875rem;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .top-price__card-badge-unit {
    font-size: 0.9375rem;
  }
}

.top-price__card-price {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 0.25rem;
  color: var(--color-green);
}

.top-price__card-approx {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 1.25rem;
  line-height: 1.4;
}
@media screen and (min-width: 768px) {
  .top-price__card-approx {
    font-size: 2rem;
  }
}

.top-price__card-num {
  font-family: var(--font-family-heading);
  font-weight: 900;
  font-size: 4rem;
  line-height: 1;
  letter-spacing: -0.02em;
}
@media screen and (min-width: 768px) {
  .top-price__card-num {
    font-size: 8rem;
  }
}

.top-price__card-suffix {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 0.25rem;
}

.top-price__card-tax {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 1rem;
  line-height: 1.4;
}
@media screen and (min-width: 768px) {
  .top-price__card-tax {
    font-size: 1.25rem;
  }
}

.top-price__card-unit {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 1.25rem;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .top-price__card-unit {
    font-size: 2rem;
  }
}

.top-price__card-img {
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .top-price__card-img {
    margin-bottom: 0.75rem;
  }
}

.top-price__card-note {
  font-size: 0.875rem;
  color: var(--color-text);
  text-align: left;
  line-height: 1.5;
  margin-top: 0.9375rem;
}
@media screen and (min-width: 768px) {
  .top-price__card-note {
    font-size: 0.875rem;
  }
}

.top-price__card-note-caution {
  display: block;
  font-size: 0.75rem;
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-price__card-note-caution {
    font-size: 0.875rem;
    margin-top: 0rem;
  }
}

.top-price__btn {
  width: 1.25rem;
  position: absolute;
  top: 51%;
  z-index: 1;
  background: none;
  border: none;
  cursor: pointer;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .top-price__btn {
    top: 56%;
  }
}
.top-price__btn:hover {
  opacity: 0.7;
}

.top-price__btn--prev {
  left: -0.6875rem;
}
@media screen and (min-width: 768px) {
  .top-price__btn--prev {
    left: -3.5rem;
  }
}

.top-price__btn--next {
  right: -0.6875rem;
}
@media screen and (min-width: 768px) {
  .top-price__btn--next {
    right: -3.5rem;
  }
}

.top-review {
  background: #fff;
  padding: 3rem 1.25rem 6.25rem;
}
@media screen and (min-width: 768px) {
  .top-review {
    padding: 4.5rem 1.25rem 8rem;
  }
}

.top-review__inner {
  max-width: 67.5rem;
  margin-inline: auto;
  text-align: center;
}

.top-review__lead {
  font-size: 1.0625rem;
  font-weight: 500;
  margin-bottom: 0.5rem;
}
@media screen and (min-width: 768px) {
  .top-review__lead {
    font-size: 2rem;
  }
}

.top-review__title {
  font-family: var(--font-family-heading);
  font-weight: 500;
  font-size: 1.875rem;
  line-height: 1.4;
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .top-review__title {
    font-size: 3rem;
    margin-bottom: 3.375rem;
  }
}

.top-review__title-num {
  display: inline-block;
  font-weight: 800;
  font-size: 3.125rem;
  line-height: 1.01;
  letter-spacing: -0.03em;
  background: linear-gradient(transparent 83%, #fdfe00 83%);
}
@media screen and (min-width: 768px) {
  .top-review__title-num {
    font-size: 6rem;
  }
}

.top-review__summary {
  max-width: 40rem;
  margin-inline: auto;
  margin-bottom: 1.0625rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .top-review__summary {
    margin-bottom: 3rem;
  }
}

.top-review__company {
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--color-text);
  margin-bottom: 0.625rem;
}
@media screen and (min-width: 768px) {
  .top-review__company {
    font-size: 1.5rem;
    margin-bottom: 0.625rem;
  }
}

.top-review__address {
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1.5;
  color: #959595;
  margin-bottom: 0.625rem;
}
@media screen and (min-width: 768px) {
  .top-review__address {
    font-size: 0.875rem;
  }
}

.top-review__rating {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.5rem 0.75rem;
  text-decoration: none;
  color: inherit;
}
.top-review__rating:hover {
  opacity: 0.8;
}

.top-review__rating-num {
  font-weight: 400;
  font-size: 3.75rem;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
@media screen and (min-width: 768px) {
  .top-review__rating-num {
    font-size: 4.375rem;
  }
}

.top-review__stars {
  display: block;
  width: 6.9375rem;
  height: auto;
  flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .top-review__stars {
    width: 9.875rem;
  }
}

.top-review__count {
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1;
  color: #959595;
}
@media screen and (min-width: 768px) {
  .top-review__count {
    font-size: 1rem;
  }
}

.top-reason {
  position: relative;
  background-color: #fff;
}
.top-reason::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/reason_header_sp.png") top center/100% auto no-repeat;
  pointer-events: none;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .top-reason::before {
    background-image: url("../img/reason_header_pc.png");
  }
}

.top-reason__header {
  position: relative;
  z-index: 1;
  padding-top: 3rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .top-reason__header {
    padding: 4rem 1.25rem 0rem;
  }
}

.top-reason__header-inner {
  max-width: 67.5rem;
  margin-inline: auto;
}

.top-reason__lead {
  font-family: var(--font-family-heading);
  font-weight: 900;
  font-size: 1.25rem;
  color: #fff;
  margin-bottom: 0.75rem;
}
@media screen and (min-width: 768px) {
  .top-reason__lead {
    font-size: 1.375rem;
    margin-bottom: 1rem;
  }
}

.top-reason__heading {
  width: 18.5625rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-reason__heading {
    width: 49.0625rem;
  }
}

.top-reason__body {
  position: relative;
  z-index: 1;
  padding: 2.5rem 1.25rem 2.75rem;
}
@media screen and (min-width: 768px) {
  .top-reason__body {
    padding: 3.75rem 1.25rem 6.25rem;
  }
}

.top-reason__inner {
  max-width: 67.5rem;
  margin-inline: auto;
}

.top-reason__list {
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
@media screen and (min-width: 768px) {
  .top-reason__list {
    gap: 2.5rem;
  }
}

.top-reason__item {
  position: relative;
  padding-top: 3.125rem;
}
@media screen and (min-width: 768px) {
  .top-reason__item {
    padding-top: 0;
  }
}

.top-reason__card {
  height: 19.0625rem;
  background: #fdfcf1;
  box-shadow: 4px 4px 4px 0 rgba(0, 0, 0, 0.1);
  padding: 4rem 1.25rem 0;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .top-reason__card {
    display: flex;
    align-items: center;
    gap: 10.25rem;
    padding: 0 2.8125rem;
    height: 13.5625rem;
    text-align: left;
  }
}

.top-reason__item:nth-of-type(2) .top-reason__card {
  padding-top: 5.5rem;
}
@media screen and (min-width: 768px) {
  .top-reason__item:nth-of-type(2) .top-reason__card {
    padding-top: 0;
  }
}

.top-reason__icon {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 6.25rem;
  height: 6.25rem;
}
@media screen and (min-width: 768px) {
  .top-reason__icon {
    position: static;
    transform: none;
    flex-shrink: 0;
    width: 9.0625rem;
    height: 9.0625rem;
  }
}

.top-reason__icon img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}

@media screen and (min-width: 768px) {
  .top-reason__content {
    flex: 1;
    min-width: 0;
  }
}

.top-reason__content-head {
  margin-bottom: 0.5rem;
}
@media screen and (min-width: 768px) {
  .top-reason__content-head {
    display: flex;
    align-items: center;
    gap: 3.125rem;
    margin-bottom: 2.1875rem;
  }
}

.top-reason__title {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--color-text);
  line-height: 1.3;
}
@media screen and (min-width: 768px) {
  .top-reason__title {
    font-size: 2.25rem;
  }
}

.top-reason__num {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 3rem;
  color: var(--color-orange);
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .top-reason__num {
    font-size: 4rem;
  }
}

.top-reason__yen {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 2rem;
  color: var(--color-orange);
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .top-reason__yen {
    font-size: 2.25rem;
  }
}

.top-reason__btn-sp {
  display: block;
  width: 12.3125rem;
  margin: 0.9375rem auto 1.875rem;
}
@media screen and (min-width: 768px) {
  .top-reason__btn-sp {
    display: none;
  }
}

.top-reason__btn-sp img {
  width: 100%;
  height: auto;
  display: block;
}

.top-reason__btn-pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .top-reason__btn-pc {
    display: block;
    flex-shrink: 0;
    width: 14.25rem;
  }
}

.top-reason__btn-pc img {
  width: 100%;
  height: auto;
  display: block;
}

.top-reason__text {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.5;
  text-align: left;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .top-reason__text {
    font-size: 1rem;
    line-height: 1.75;
  }
}

.top-reason__title-v2 {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--color-text);
  line-height: 1.3;
  margin-bottom: 0.75rem;
}
@media screen and (min-width: 768px) {
  .top-reason__title-v2 {
    font-size: 2.25rem;
    margin-bottom: 2.1875rem;
  }
}

.top-reason__banner {
  position: relative;
  z-index: 1;
  background-image: url("../img/reason_para01_sp.jpg");
  background-position: bottom;
  background-size: contain;
  background-repeat: no-repeat;
  height: 34.8125rem;
}
@media screen and (min-width: 768px) {
  .top-reason__banner {
    background-image: url("../img/reason_para01.jpg");
    height: 65.25rem;
    background-size: cover;
    background-position: left -50rem bottom -3.75rem;
    background-attachment: fixed;
  }
}
@media screen and (min-width: 1070px) {
  .top-reason__banner {
    background-position: left bottom -3.75rem;
  }
}

.top-reason__banner-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  text-align: center;
  height: 17.75rem;
  background-image: url("../img/reason_para02_sp.png");
  background-position: top center;
  background-size: 100% auto;
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .top-reason__banner-inner {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    background-image: url("../img/reason_para02.png");
  }
}
@media screen and (min-width: 2150px) {
  .top-reason__banner-inner {
    height: 72.5rem;
    background-image: url("../img/reason_para-min-1440.png");
    height: 21.25rem;
  }
}

.top-reason__banner-text-wrap {
  width: 100%;
  position: absolute;
  text-align: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .top-reason__banner-text-wrap {
    top: 10.5%;
    transform: translate(-50%, 0);
  }
}
@media screen and (min-width: 1920px) {
  .top-reason__banner-text-wrap {
    top: 18%;
  }
}
@media screen and (min-width: 768px) {
  .top-reason__banner-text-wrap::after {
    content: "";
    position: absolute;
    left: 50%;
    top: -46.5%;
    transform: translatex(-131%);
    width: 36.875rem;
    aspect-ratio: 1166/686;
    background-image: url("../img/reason__banner_01.png");
    background-repeat: no-repeat;
    background-position: bottom left;
    background-size: contain;
    pointer-events: none;
    z-index: -1;
  }
}

.top-reason__banner-lead {
  font-family: var(--font-family-heading);
  font-weight: 600;
  font-size: 1.25rem;
  color: #fff;
  margin-bottom: 0.5rem;
}
@media screen and (min-width: 768px) {
  .top-reason__banner-lead {
    font-size: 3rem;
  }
}

.top-reason__banner-lead-note {
  font-size: 1rem;
}
@media screen and (min-width: 768px) {
  .top-reason__banner-lead-note {
    font-size: 2.5rem;
  }
}

.top-reason__banner-copy {
  font-family: var(--font-family-heading);
  font-weight: 900;
  font-size: 2.5rem;
  color: #fdfcf1;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .top-reason__banner-copy {
    font-size: 4.125rem;
    line-height: 1.3;
  }
}

.top-assurance {
  position: relative;
  background: linear-gradient(180deg, #00993d 25.25%, #3cbc70 100%);
}
.top-assurance::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/assurance_header_sp.png") top center/100% auto no-repeat;
  pointer-events: none;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .top-assurance::before {
    background-image: url("../img/assurance_header_pc.png");
  }
}

.top-assurance__header {
  position: relative;
  z-index: 1;
}

.top-assurance__header-inner {
  max-width: 67.5rem;
  margin-inline: auto;
}

.top-assurance__header-label {
  font-family: var(--font-family-heading);
  font-weight: 600;
  font-size: 1rem;
  color: #fdfcf1;
  margin-bottom: 0.75rem;
}
@media screen and (min-width: 768px) {
  .top-assurance__header-label {
    font-size: 1.375rem;
    margin-bottom: 1rem;
  }
}

.top-assurance__header-title {
  width: 11.125rem;
  padding-top: 2.1875rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-assurance__header-title {
    padding-top: 0rem;
    width: 19.875rem;
  }
}

.top-assurance__body {
  position: relative;
  z-index: 1;
  padding-block: 1.3125rem 0.625rem;
}
@media screen and (min-width: 768px) {
  .top-assurance__body {
    padding: 5.8125rem 0 6.25rem;
  }
}

.top-assurance__inner {
  max-width: 80.75rem;
  margin-inline: auto;
}

.top-assurance__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
@media screen and (min-width: 768px) {
  .top-assurance__list {
    gap: 3.625rem;
  }
}

.top-assurance__item {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .top-assurance__item {
    flex-direction: row;
    align-items: center;
    min-height: 30rem;
    gap: 3.5rem;
  }
}

@media screen and (min-width: 768px) {
  .top-assurance__item--reverse {
    flex-direction: row-reverse;
  }
}

.top-assurance__img {
  flex-shrink: 0;
  width: 100%;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .top-assurance__img {
    width: 50%;
    height: 30rem;
  }
}

.top-assurance__list > li:nth-of-type(1) .top-assurance__img,
.top-assurance__list > li:nth-of-type(3) .top-assurance__img {
  width: 22.125rem;
  margin-right: auto;
}
@media screen and (min-width: 768px) {
  .top-assurance__list > li:nth-of-type(1) .top-assurance__img,
  .top-assurance__list > li:nth-of-type(3) .top-assurance__img {
    width: 40rem;
    height: 39.375rem;
    margin-right: 0;
  }
}

.top-assurance__list > li:nth-of-type(2) .top-assurance__img {
  width: 22.125rem;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .top-assurance__list > li:nth-of-type(2) .top-assurance__img {
    width: 40rem;
    height: 39.375rem;
    margin-left: 0;
  }
}

.top-assurance__img picture {
  display: block;
  width: 100%;
  height: 100%;
}

.top-assurance__img img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center;
}
@media screen and (min-width: 768px) {
  .top-assurance__img img {
    height: 100%;
  }
}

.top-assurance__text-wrap {
  flex: 1;
  padding: 1.3125rem 1.0625rem 2.5rem;
}
@media screen and (min-width: 768px) {
  .top-assurance__text-wrap {
    padding: 0;
  }
}

.top-assurance__num-wrap {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  margin-bottom: 0.75rem;
}
@media screen and (min-width: 768px) {
  .top-assurance__num-wrap {
    margin-bottom: 1rem;
  }
}

.top-assurance__point {
  writing-mode: vertical-lr;
  font-family: var(--font-family-base);
  font-weight: 800;
  font-size: 1.125rem;
  color: #fdfcf1;
  letter-spacing: 0.05em;
  line-height: 1;
}

.top-assurance__num {
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 4rem;
  color: #fdfcf1;
  letter-spacing: -0.05em;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .top-assurance__num {
    font-size: 6rem;
  }
}

.top-assurance__title {
  font-family: var(--font-family-heading);
  font-weight: 600;
  font-size: 2.25rem;
  color: #fdfcf1;
  line-height: 1.1;
  margin-bottom: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-assurance__title {
    font-size: 3.125rem;
    margin-bottom: 1.5rem;
  }
}

.top-assurance__title-hl {
  font-size: 3rem;
  color: #fdfe00;
  letter-spacing: -0.05em;
}
@media screen and (min-width: 768px) {
  .top-assurance__title-hl {
    font-size: 4.125rem;
  }
}

@media screen and (min-width: 768px) {
  .top-assurance__title-br {
    display: none;
  }
}

.top-assurance__check-list {
  list-style: none;
  padding: 0;
  margin-bottom: 1.625rem;
  display: flex;
  flex-direction: column;
}

.top-assurance__check-item {
  display: flex;
  align-items: flex-start;
  gap: 0.3125rem;
  font-size: 0.9375rem;
  color: #fdfcf1;
  line-height: 1.7;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .top-assurance__check-item {
    font-size: 1.375rem;
    align-items: baseline;
    gap: 0.9375rem;
  }
}

.top-assurance__check-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  margin-top: 0.25rem;
}

@media screen and (min-width: 768px) {
  .top-assurance__check-icon img {
    width: 1.0625rem;
  }
}

.top-assurance__note {
  font-size: 0.875rem;
  font-weight: 500;
  color: #fdfcf1;
  line-height: 1.5;
  padding-left: 1.3125rem;
}
@media screen and (min-width: 768px) {
  .top-assurance__note {
    font-size: 1rem;
    padding-left: 2rem;
  }
}

.top-assurance__note + .top-assurance__note {
  margin-top: 0.9375rem;
}

.top-check {
  background-image: url("../img/check-in-advance_bg_sp.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top center;
  height: 132.6875rem;
  margin-bottom: -7.5rem;
}
@media screen and (min-width: 768px) {
  .top-check {
    background-image: url("../img/check-in-advance_bg_pc.jpg");
    margin-bottom: -12.5rem;
  }
}

@media screen and (min-width: 768px) {
  .top-check__header {
    padding-top: 1.625rem;
  }
}

.top-check__header-inner {
  max-width: 67.5rem;
  margin-inline: auto;
}

.top-check__body {
  margin-top: 1.875rem;
}
@media screen and (min-width: 768px) {
  .top-check__body {
    margin-top: 3.3125rem;
  }
}

.top-check__inner {
  max-width: 67.5rem;
  margin-inline: auto;
  padding-inline: 1.25rem;
}

.top-check__heading {
  width: 15.4375rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-check__heading {
    width: 56.25rem;
  }
}

.top-check__steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .top-check__steps {
    flex-direction: row;
    align-items: flex-start;
    justify-content: center;
    gap: 2.5rem;
  }
}

.top-check__step {
  width: 100%;
}

.top-check__arrow-row {
  padding-bottom: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-check__arrow-row {
    display: flex;
    justify-content: center;
    flex-shrink: 0;
    padding-bottom: 0;
    padding-top: 5.5rem;
    margin-left: -1.625rem;
    align-self: flex-start;
  }
}

.top-check__arrow-row img {
  display: block;
}
@media screen and (min-width: 768px) {
  .top-check__arrow-row img {
    transform: rotate(-90deg);
  }
}

.top-check__hexagon-wrap {
  position: relative;
  margin-bottom: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-check__hexagon-wrap {
    display: block;
    margin-bottom: 1.5rem;
  }
}

.top-check__hexagon-clip {
  width: 18.25rem;
  margin-inline: auto;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .top-check__hexagon-clip {
    width: 18rem;
    height: 15.875rem;
  }
}

.top-check__badge {
  position: absolute;
  top: 0;
  left: -0.5625rem;
}
@media screen and (min-width: 768px) {
  .top-check__badge {
    left: -1.875rem;
  }
}

.top-check__step-label {
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 1.5rem;
  text-align: center;
  color: #333;
  margin-bottom: 0.5rem;
}
@media screen and (min-width: 768px) {
  .top-check__step-label {
    font-size: 2rem;
  }
}

.top-check__step-text {
  font-size: 0.9375rem;
  font-weight: 500;
  color: #333;
  line-height: 1.5;
  padding-inline: 0.5rem;
}
@media screen and (min-width: 768px) {
  .top-check__step-text {
    font-size: 1rem;
    line-height: 1.75;
    padding-inline: 0;
  }
}

.top-check__big-arrow {
  display: flex;
  justify-content: center;
  padding-top: 2.5rem;
}

.top-check__big-arrow img {
  display: block;
}

.top-check__license {
  padding: 2.5rem 1.1875rem 5rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .top-check__license {
    padding: 3.75rem 1.25rem 6.25rem;
  }
}

.top-check__license-inner {
  max-width: 67.5rem;
  margin-inline: auto;
}

.top-check__license-title {
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 2.25rem;
  color: #333;
  line-height: 1.3;
  margin-bottom: 1.75rem;
}
@media screen and (min-width: 768px) {
  .top-check__license-title {
    font-size: 2.625rem;
    margin-bottom: 3rem;
    white-space: nowrap;
  }
}

.top-check__license-hl {
  display: inline-block;
  font-size: 3rem;
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(transparent 86%, #fdfe00 24%);
}
@media screen and (min-width: 768px) {
  .top-check__license-hl {
    font-size: 4rem;
  }
}

.top-check__license-img {
  width: 18.5625rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-check__license-img {
    width: 60.8125rem;
  }
}

.top-cases {
  background-image: url("../img/cases_bg_sp.jpg");
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top center;
  padding: 3.5rem 0 4rem;
}
@media screen and (min-width: 768px) {
  .top-cases {
    background-image: url("../img/cases_bg_pc.jpg");
    padding: 5rem 0 4rem;
  }
}

.top-cases__inner {
  max-width: 75rem;
  margin-inline: auto;
}

.top-cases__heading {
  width: 9.25rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-cases__heading {
    width: 14.875rem;
  }
}

.top-cases__slider {
  position: relative;
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-cases__slider {
    margin-top: 2.5rem;
  }
}

.top-cases__nav {
  position: absolute;
  top: 64%;
  z-index: 1;
  width: 1.25rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .top-cases__nav {
    top: 13.25rem;
  }
}
.top-cases__nav:hover {
  opacity: 0.7;
}

.top-cases__nav--prev {
  left: 0.5rem;
}

.top-cases__nav--next {
  right: 0.5rem;
}

.top-cases__track-wrap {
  width: 100%;
  overflow: hidden;
  padding-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-cases__track-wrap {
    padding-top: 2.5rem;
  }
}

.top-cases__track {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  transition: transform 0.4s ease;
}

.top-cases__slide {
  flex: 0 0 100%;
  box-sizing: border-box;
  padding-inline: 1.25rem;
  padding-bottom: 0.625rem;
}

.top-cases__ba {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}
@media screen and (min-width: 768px) {
  .top-cases__ba {
    flex-direction: row;
    justify-content: center;
    gap: 0.3125rem;
  }
}

.top-cases__ba-figure {
  position: relative;
  width: 20.9375rem;
  height: 15.6875rem;
  flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .top-cases__ba-figure {
    width: 31.25rem;
    height: 23.375rem;
  }
}

.top-cases__ba-figure img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-cases__ba-label {
  position: absolute;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 1;
  display: inline-block;
  background-color: #333;
  color: #fff;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  width: 7.25rem;
  height: 2.5625rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .top-cases__ba-label {
    width: 11.75rem;
    height: 3.6875rem;
    font-size: 2rem;
  }
}

.top-cases__ba-figure--after .top-cases__ba-label {
  background-color: #00993d;
}

.top-cases__ba-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 4.375rem;
  padding-block: 0.4375rem 1.875rem;
}
@media screen and (min-width: 768px) {
  .top-cases__ba-arrow {
    width: 3.5rem;
    transform: rotate(-90deg);
    padding-block: 0;
  }
}

.top-cases__info {
  width: 21rem;
  height: 7.6875rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 1.25rem;
  background-color: #fff;
  border-radius: 5px;
  box-shadow: 0.3125rem 0.3125rem 0.25rem 0 rgba(0, 0, 0, 0.1);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-cases__info {
    width: 24rem;
    height: 9.0625rem;
    margin-top: 2rem;
    align-items: flex-start;
    padding-left: 3rem;
  }
}

.top-cases__info-item {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}
@media screen and (min-width: 768px) {
  .top-cases__info-item {
    gap: 0.8125rem;
  }
}

.top-cases__info-dt {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  color: #333;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .top-cases__info-dt {
    font-size: 1.5rem;
    gap: 0.8125rem;
  }
}

.top-cases__info-dt img {
  width: 1.6875rem;
}
@media screen and (min-width: 768px) {
  .top-cases__info-dt img {
    width: 2.875rem;
  }
}

.top-cases__info-dd {
  color: #333;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .top-cases__info-dd {
    font-size: 1.5rem;
  }
}

.top-cases__info-item:last-child {
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .top-cases__info-item:last-child {
    gap: 0.8125rem;
  }
}

.top-cases__info-item:last-child .top-cases__info-dt {
  font-size: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-cases__info-item:last-child .top-cases__info-dt {
    font-size: 1.5rem;
  }
}

.top-cases__info-item:last-child .top-cases__info-dd {
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .top-cases__info-item:last-child .top-cases__info-dd {
    font-size: 2.5rem;
  }
}

.top-cases__info-tax {
  font-size: inherit;
  font-weight: inherit;
}

.top-message {
  position: relative;
  background-color: #fff;
}
.top-message::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/message_header_sp.png") top center/100% auto no-repeat;
  pointer-events: none;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .top-message::before {
    background-image: url("../img/message_header_pc.png");
  }
}

.top-message__header {
  position: relative;
  z-index: 1;
}

.top-message__header-inner {
  max-width: 67.5rem;
  margin-inline: auto;
}

.top-message__heading {
  width: 15.3125rem;
  margin-inline: auto;
  padding-top: 2.8125rem;
}
@media screen and (min-width: 768px) {
  .top-message__heading {
    padding-top: 5.125rem;
    width: 27.125rem;
  }
}

.top-message__body {
  position: relative;
  z-index: 1;
  padding-top: 0.625rem;
}
@media screen and (min-width: 768px) {
  .top-message__body {
    padding-top: 1.75rem;
  }
}

.top-message__inner {
  max-width: 80.0625rem;
  margin-inline: auto;
  padding-bottom: 2.5rem;
  padding-inline: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-message__inner {
    display: flex;
    gap: 3.25rem;
    padding-inline: 0;
    margin-bottom: 3.8125rem;
  }
}

.top-message__photo {
  width: 20.9375rem;
  flex-shrink: 0;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-message__photo {
    width: 27.9375rem;
  }
}

.top-message__text {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-message__text {
    margin-top: 0;
  }
}

.top-message__text p {
  font-size: 1rem;
  line-height: 1.5;
  color: #333;
  margin-bottom: 1.25rem;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .top-message__text p {
    font-size: 1rem;
    margin-bottom: 1.5rem;
  }
}

.top-message__text p:last-child {
  margin-bottom: 0;
}

.top-message__list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  color: inherit;
}

.top-message__list li::before {
  content: "・";
}

.top-message__text p:has(+ .top-message__list) {
  margin-bottom: 0;
}

.top-message__list + p {
  margin-top: 0;
}

.top-message__text-lead {
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .top-message__text-lead {
    font-size: 1.125rem;
  }
}

.top-flow {
  position: relative;
  background: #fdfcf1;
}
.top-flow::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/flow_header_sp.png") top center/100% auto no-repeat;
}
@media screen and (min-width: 768px) {
  .top-flow::before {
    background-image: url("../img/flow_header_pc.png");
  }
}

.top-flow__header-inner {
  padding-top: 2.625rem;
}
@media screen and (min-width: 768px) {
  .top-flow__header-inner {
    padding-top: 4.0625rem;
  }
}

.top-flow__heading {
  position: relative;
  width: 19.25rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-flow__heading {
    width: 35.75rem;
  }
}

.top-flow__body {
  position: relative;
  padding: 2.1875rem 1.25rem 4rem;
}
@media screen and (min-width: 768px) {
  .top-flow__body {
    padding: 1.875rem 1.25rem 5rem;
  }
}

.top-flow__inner {
  max-width: 67.5rem;
  margin-inline: auto;
}

.top-flow__steps {
  list-style: none;
  margin: 0;
  padding: 0;
}

.top-flow__step {
  width: 20.9375rem;
  margin-inline: auto;
  background: #fff;
  box-shadow: 0.3125rem 0.3125rem 0.25rem 0 rgba(0, 0, 0, 0.1);
  padding: 1.5rem 1.375rem 2.1875rem;
}
@media screen and (min-width: 768px) {
  .top-flow__step {
    width: 100%;
    display: grid;
    grid-template-columns: 5rem 1fr 18.125rem;
    grid-template-rows: auto;
    gap: 0 1.5rem;
    align-items: start;
    padding: 1.8125rem 2.5rem;
    margin-inline: unset;
  }
}

.top-flow__step-num {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1rem;
}
@media screen and (min-width: 768px) {
  .top-flow__step-num {
    grid-column: 1;
    grid-row: 1;
    margin-bottom: 0;
    padding-top: 2.875rem;
  }
}

.top-flow__step-label {
  font-size: 0.9375rem;
  font-weight: 800;
  color: #00993d;
  line-height: 1;
  margin-bottom: 0.125rem;
}
@media screen and (min-width: 768px) {
  .top-flow__step-label {
    font-size: 1.25rem;
  }
}

.top-flow__step-no {
  font-size: 2.25rem;
  font-weight: 800;
  line-height: 1;
  color: #00993d;
}
@media screen and (min-width: 768px) {
  .top-flow__step-no {
    font-size: 3rem;
  }
}

.top-flow__step-img {
  margin-bottom: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-flow__step-img {
    grid-column: 3;
    grid-row: 1;
    margin-bottom: 0;
  }
}

@media screen and (min-width: 768px) {
  .top-flow__step-content {
    grid-column: 2;
    grid-row: 1;
  }
}

.top-flow__step-title {
  font-size: 1.125rem;
  font-weight: 800;
  color: #333;
  margin-bottom: 0.5rem;
  line-height: 1.4;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .top-flow__step-title {
    font-size: 1.5rem;
    margin-bottom: 1.375rem;
    text-align: start;
  }
}

.top-flow__step-text {
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5;
  color: #555;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .top-flow__step-text {
    font-size: 1rem;
    line-height: 1.75;
  }
}

.top-flow__step-btns {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .top-flow__step-btns {
    flex-direction: row;
    gap: 1rem;
    margin-top: 0.6875rem;
  }
}

.top-flow__step-btn {
  display: flex;
  justify-content: flex-end;
  padding: 0.625rem 1rem;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 768px) {
  .top-flow__step-btn {
    width: 13rem;
    padding: 0.25rem 0.8125rem;
    font-size: 1.25rem;
  }
}

.top-flow__step-btn-inner {
  display: flex;
  align-items: stretch;
  justify-content: center;
  width: 12.375rem;
}
@media screen and (min-width: 768px) {
  .top-flow__step-btn-inner {
    width: 100%;
    align-items: center;
  }
}

.top-flow__step-btn--tel {
  border: 1px solid #00993d;
  color: #00993d;
  background: #fff;
}
.top-flow__step-btn--tel:hover {
  opacity: 0.75;
}

.top-flow__step-btn--mail {
  background: var(--color-primary);
  color: #fff;
}
.top-flow__step-btn--mail:hover {
  opacity: 0.8;
}
.top-flow__step-btn--mail .top-flow__step-btn-inner span {
  margin-left: 0.8125rem;
}

.top-flow__step-btn-icon {
  display: block;
  flex-shrink: 0;
  height: auto;
}

.top-flow__step-btn--tel .top-flow__step-btn-icon {
  width: 1.125rem;
}
@media screen and (min-width: 768px) {
  .top-flow__step-btn--tel .top-flow__step-btn-icon {
    width: 1.5625rem;
    margin-right: 0.25rem;
  }
}

.top-flow__step-btn--mail .top-flow__step-btn-icon {
  width: 1.5rem;
}
@media screen and (min-width: 768px) {
  .top-flow__step-btn--mail .top-flow__step-btn-icon {
    width: 2.625rem;
  }
}

.top-flow__step-btn-arrow {
  margin-left: auto;
}

.top-flow__arrow {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem 0;
}

.top-flow__arrow img {
  display: block;
}

.top-area {
  position: relative;
  background: #fff;
  padding: 2.8125rem 1.25rem 2.1875rem;
}
@media screen and (min-width: 768px) {
  .top-area {
    padding: 5rem 1.25rem 6.25rem;
  }
}

.top-area::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/area_header_sp.png") top center/100% auto no-repeat;
  pointer-events: none;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .top-area::before {
    background-image: url("../img/area_header_pc.png");
  }
}

.top-area__inner {
  position: relative;
  z-index: 1;
  max-width: 56.25rem;
  margin-inline: auto;
  text-align: center;
}

.top-area__heading {
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .top-area__heading {
    margin-bottom: 1.125rem;
  }
}

.top-area__heading img {
  display: block;
  width: 11.9375rem;
  height: auto;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-area__heading img {
    width: 17.5rem;
  }
}

.top-area__text {
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.03em;
  color: #333;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .top-area__text {
    font-size: 1rem;
    margin-bottom: 0.6875rem;
  }
}

.top-area__map {
  max-width: 31.25rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-area__map {
    max-width: 29.875rem;
  }
}

.top-faq {
  background: url("../img/faq_bg_sp.png") top center/100% auto no-repeat;
  padding: 3.5rem 1.25rem 7.5rem;
}
@media screen and (min-width: 768px) {
  .top-faq {
    background: url("../img/faq_bg_pc.png") top center/100% auto no-repeat;
    padding: 4.125rem 1.25rem 11.375rem;
  }
}

.top-faq__inner {
  max-width: 56.25rem;
  margin-inline: auto;
}

.top-faq__header {
  text-align: center;
  margin-bottom: 1.875rem;
}
@media screen and (min-width: 768px) {
  .top-faq__header {
    margin-bottom: 7rem;
  }
}

.top-faq__heading-img {
  width: 13.875rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .top-faq__heading-img {
    width: 22.3125rem;
  }
}

.top-faq__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
@media screen and (min-width: 768px) {
  .top-faq__list {
    gap: 1rem;
  }
}

.top-faq__item {
  background: #fff;
}

.top-faq__q {
  display: flex;
  align-items: center;
  gap: 1.0625rem;
  width: 100%;
  padding: 1.25rem 1.25rem 1.25rem 0.625rem;
  text-align: left;
  background: transparent;
  border: none;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .top-faq__q {
    padding: 1.1875rem 1.25rem 1.1875rem 0.75rem;
    gap: 1.5625rem;
  }
}

.top-faq__badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  font-family: var(--font-family-heading);
  font-weight: 800;
  font-size: 1.5rem;
  padding-bottom: 0.25rem;
}

.top-faq__badge--q {
  background: #00993d;
  color: #fff;
}

.top-faq__badge--a {
  background: #fff;
  border: 1px solid #00993d;
  color: #00993d;
  margin-top: 0.375rem;
}
@media screen and (min-width: 768px) {
  .top-faq__badge--a {
    margin-top: 0;
  }
}

.top-faq__q-text {
  flex: 1;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-text);
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .top-faq__q-text {
    font-size: 1rem;
  }
}

.top-faq__arrow {
  width: 1.125rem;
  transition: transform 0.3s ease;
}

.top-faq__item.is-open .top-faq__arrow {
  transform: rotate(180deg);
}

.top-faq__a {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease, padding-bottom 0.35s ease;
  padding: 0 0.75rem;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .top-faq__a {
    gap: 1.5625rem;
    padding-right: 4.75rem;
  }
}

.top-faq__item.is-open .top-faq__a {
  max-height: 18.75rem;
  padding-bottom: 1rem;
}
@media screen and (min-width: 768px) {
  .top-faq__item.is-open .top-faq__a {
    padding-bottom: 1.25rem;
    padding-right: 4.75rem;
    gap: 1.5625rem;
  }
}

.top-faq__a-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .top-faq__a-content {
    margin-top: 0.375rem;
  }
}

.top-faq__a-text {
  flex: 1;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5;
  color: #000;
}
@media screen and (min-width: 768px) {
  .top-faq__a-text {
    font-size: 1rem;
    line-height: 1.5;
  }
}

.top-faq__a-btns {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .top-faq__a-btns {
    flex-direction: row;
    gap: 0.75rem;
  }
}

.top-faq__a-btn {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  flex: 1;
  padding: 0.5rem 0.625rem 0.5rem 3.3125rem;
  font-family: var(--font-family-heading);
  font-weight: 700;
  font-size: 1rem;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .top-faq__a-btn {
    flex: none;
    width: 13rem;
    height: 3.125rem;
    font-size: 1.25rem;
    padding: 0 0.75rem;
    gap: 0.5rem;
  }
}
.top-faq__a-btn:hover {
  opacity: 0.85;
}

.top-faq__a-btn--tel {
  background: #fff;
  border: 1px solid #00993d;
  color: #00993d;
}

.top-faq__a-btn--mail {
  background: #e83b2b;
  color: #fff;
}

@media screen and (min-width: 768px) {
  .top-faq__a-btn-icon {
    display: flex;
    align-items: center;
    flex-shrink: 0;
  }
}

.top-faq__a-btn-icon img {
  display: block;
  width: 1.125rem;
  height: auto;
}

@media screen and (min-width: 768px) {
  .top-faq__a-btn--tel .top-faq__a-btn-icon img {
    width: 1.5625rem;
  }
}

@media screen and (min-width: 768px) {
  .top-faq__a-btn--mail .top-faq__a-btn-icon img {
    width: 2.625rem;
  }
}

@media screen and (min-width: 768px) {
  .top-faq__a-btn-label {
    flex: 1;
  }
}

.top-faq__a-btn-arrow {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  margin-left: auto;
}

.top-contact {
  scroll-margin-top: 3.75rem;
  background: var(--color-cta-green);
  padding: 3rem 1.25rem 3.125rem;
  margin-top: -0.125rem;
}
@media screen and (min-width: 768px) {
  .top-contact {
    padding: 5rem 2.5rem 6rem;
  }
}

.top-contact__inner {
  max-width: 56.25rem;
  margin-inline: auto;
}

.top-contact__heading {
  font-family: var(--font-family-base);
  font-weight: 800;
  font-size: 2.25rem;
  color: #fff;
  text-align: center;
  line-height: 1.4;
  letter-spacing: 0.03em;
  margin-inline: auto;
  margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .top-contact__heading {
    font-size: 3rem;
    line-height: 1.3;
    margin-bottom: 3.125rem;
  }
}

@media screen and (min-width: 768px) {
  .top-contact__heading-br {
    display: none;
  }
}

.top-contact__form .wpcf7-response-output {
  margin-top: 1rem;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  color: #fff;
  border: 1px solid #fff;
}

.top-contact__form p {
  margin: 0;
}

.contact-form__fields {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .contact-form__fields {
    gap: 1.75rem;
  }
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .contact-form__field {
    flex-direction: row;
    align-items: center;
    gap: 2.375rem;
  }
}

.contact-form__label {
  display: flex;
  align-items: center;
  gap: 0.3125rem;
  margin: 0;
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.8125rem;
  color: #fff;
  line-height: 1.5;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 768px) {
  .contact-form__label {
    flex-shrink: 0;
    width: 20.5625rem;
    font-size: 1.25rem;
    letter-spacing: 0.03em;
    gap: 0.625rem;
  }
}

.contact-form__badge {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 2.4375rem;
  height: 1.5rem;
  font-weight: 500;
  font-size: 0.8125rem;
  line-height: 1;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .contact-form__badge {
    width: 3.1875rem;
    height: 1.875rem;
    font-size: 1.0625rem;
  }
}

.contact-form__badge--required {
  background: #fb8e1f;
  color: #fff;
}

.contact-form__badge--optional {
  background: #fff;
  color: #fb8e1f;
  border: 1px solid #fb8e1f;
}

.contact-form__field .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .contact-form__field .wpcf7-form-control-wrap {
    flex: 1;
    max-width: 33.3125rem;
  }
}

.contact-form__field input[type=text],
.contact-form__field input[type=tel],
.contact-form__field input[type=email],
.contact-form__field input[type=number],
.contact-form__field textarea {
  width: 100%;
  background: #fff;
  border: 1px solid #ced4da;
  border-radius: 0.1875rem;
  padding: 0.625rem 1rem;
  font-family: var(--font-family-base);
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.5;
  letter-spacing: 0.03em;
  box-shadow: none;
  appearance: none;
  -webkit-appearance: none;
}
@media screen and (min-width: 768px) {
  .contact-form__field input[type=text],
  .contact-form__field input[type=tel],
  .contact-form__field input[type=email],
  .contact-form__field input[type=number],
  .contact-form__field textarea {
    font-size: 1rem;
  }
}
.contact-form__field input[type=text]::placeholder,
.contact-form__field input[type=tel]::placeholder,
.contact-form__field input[type=email]::placeholder,
.contact-form__field input[type=number]::placeholder,
.contact-form__field textarea::placeholder {
  color: #b3b3b3;
  opacity: 1;
}
.contact-form__field input[type=text]:focus,
.contact-form__field input[type=tel]:focus,
.contact-form__field input[type=email]:focus,
.contact-form__field input[type=number]:focus,
.contact-form__field textarea:focus {
  outline: 2px solid #fff;
  outline-offset: 0.125rem;
}

.contact-form__field input[type=text],
.contact-form__field input[type=tel],
.contact-form__field input[type=email],
.contact-form__field input[type=number] {
  height: 2.8125rem;
}

.contact-form__field textarea {
  height: 6.875rem;
  resize: vertical;
}
@media screen and (min-width: 768px) {
  .contact-form__field textarea {
    min-height: 8.25rem;
  }
}

.contact-form__field .wpcf7-not-valid-tip {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.8125rem;
  color: #ffea00;
  line-height: 1.4;
}

.contact-form__field .wpcf7-not-valid {
  border-color: #ffea00;
}

.contact-form__submit-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  margin-top: 1.5rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .contact-form__submit-wrap {
    margin-top: 3rem;
  }
}

.contact-form__submit-wrap .wpcf7-submit,
.contact-form__submit-wrap input[type=submit] {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 20.9375rem;
  height: 3.125rem;
  padding: 0 2.5rem;
  background: #fb8e1f;
  border: none;
  border-radius: 0;
  font-family: var(--font-family-base);
  font-weight: 700;
  font-size: 1.25rem;
  color: #fff;
  letter-spacing: 0.03em;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .contact-form__submit-wrap .wpcf7-submit,
  .contact-form__submit-wrap input[type=submit] {
    max-width: 25rem;
    height: 5rem;
    font-size: 2rem;
  }
}
.contact-form__submit-wrap .wpcf7-submit:hover,
.contact-form__submit-wrap input[type=submit]:hover {
  opacity: 0.8;
}

.contact-form__submit-wrap::after,
.contact-confirm__submit-wrap::after {
  content: "";
  position: absolute;
  top: 50%;
  right: calc(50% - 9.46875rem);
  transform: translateY(-50%);
  width: 0.375rem;
  height: 0.8125rem;
  background: url("../img/form_arrow.svg") no-repeat center/contain;
  pointer-events: none;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .contact-form__submit-wrap::after,
  .contact-confirm__submit-wrap::after {
    right: calc(50% - 11rem);
    width: 1.5rem;
    height: 1.375rem;
  }
}

.contact-form__submit-wrap .wpcf7-spinner {
  display: none;
}

.top-contact__form .wpcf7-response-output.wpcf7-mail-sent-ok {
  display: none;
}

.grecaptcha-badge {
  visibility: hidden;
}

.contact-form__recaptcha-notice {
  font-family: var(--font-family-base);
  font-weight: 400;
  font-size: 0.6875rem;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.6;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .contact-form__recaptcha-notice {
    margin-top: 1.5rem;
    font-size: 0.75rem;
  }
}
.contact-form__recaptcha-notice a {
  color: inherit;
  text-decoration: none;
}
.contact-form__recaptcha-notice a:hover {
  opacity: 0.8;
}

p.contact-form__recaptcha-notice {
  margin: 1rem 0 0;
}

.contact-confirm__list {
  margin: 0 0 2rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
@media screen and (min-width: 768px) {
  .contact-confirm__list {
    max-width: 56.25rem;
    margin: 0 auto 3rem;
    gap: 1.75rem;
  }
}

.contact-confirm__item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
@media screen and (min-width: 768px) {
  .contact-confirm__item {
    flex-direction: row;
    align-items: flex-start;
    gap: 2.375rem;
  }
}

.contact-confirm__label {
  margin: 0;
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.8125rem;
  color: #fff;
  line-height: 1.5;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .contact-confirm__label {
    flex-shrink: 0;
    width: 18.125rem;
    font-size: 1.25rem;
  }
}

.contact-confirm__value {
  margin: 0;
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.875rem;
  color: #fff;
  line-height: 1.5;
  letter-spacing: 0.03em;
  word-break: break-word;
}
@media screen and (min-width: 768px) {
  .contact-confirm__value {
    flex: 1;
    font-size: 1.25rem;
  }
}

.contact-confirm__value:empty::before {
  content: "—";
  opacity: 0.6;
}

.contact-confirm__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .contact-confirm__actions {
    gap: 1.5rem;
  }
}

.contact-confirm__submit-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
}

.contact-confirm__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20.9375rem;
  height: 3.125rem;
  padding: 0 2.5rem;
  background: #ff7b00;
  border: none;
  border-radius: 0;
  font-family: var(--font-family-base);
  font-weight: 700;
  font-size: 1.25rem;
  color: #fff;
  letter-spacing: 0.03em;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .contact-confirm__submit {
    width: 25rem;
    height: 5rem;
    font-size: 2rem;
  }
}
.contact-confirm__submit:hover {
  opacity: 0.85;
}
.contact-confirm__submit:disabled {
  cursor: wait;
  opacity: 0.6;
}

.contact-confirm__back {
  background: transparent;
  border: none;
  padding: 0.25rem 0.5rem;
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.875rem;
  color: #fff;
  text-decoration: underline;
  cursor: pointer;
  appearance: none;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .contact-confirm__back {
    font-size: 1rem;
  }
}
.contact-confirm__back:hover {
  opacity: 0.7;
}

.thanks {
  background: var(--color-cta-green);
  padding: 3.125rem 1.25rem 3.75rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .thanks {
    padding: 5rem 2.5rem 6rem;
  }
}

.thanks__inner {
  max-width: 56.25rem;
  margin-inline: auto;
  width: 100%;
}

.thanks__heading {
  font-family: var(--font-family-base);
  font-weight: 800;
  font-size: 2.25rem;
  color: #fff;
  line-height: 1.4;
  letter-spacing: 0.03em;
  margin-bottom: 2.5rem;
}
@media screen and (min-width: 768px) {
  .thanks__heading {
    font-size: 3rem;
    line-height: 1.3;
    margin-bottom: 3.75rem;
  }
}

@media screen and (min-width: 768px) {
  .thanks__heading-br {
    display: none;
  }
}

.thanks__text {
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 1rem;
  color: #fff;
  line-height: 1.5;
  letter-spacing: 0.03em;
  margin-bottom: 2.5rem;
}
@media screen and (min-width: 768px) {
  .thanks__text {
    font-size: 1.625rem;
    margin-bottom: 4rem;
  }
}

@media screen and (min-width: 768px) {
  .thanks__text-br {
    display: none;
  }
}

.thanks__btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 20.9375rem;
  height: 3.125rem;
  padding: 0 2.5rem;
  background: #ff7b00;
  color: #fff;
  font-family: var(--font-family-base);
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: 0.03em;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .thanks__btn {
    max-width: 25rem;
    height: 5rem;
    font-size: 2rem;
  }
}
.thanks__btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1rem;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 10px;
  border-color: transparent transparent transparent #fff;
}
@media screen and (min-width: 768px) {
  .thanks__btn::after {
    right: 1.5rem;
    border-width: 8px 0 8px 14px;
  }
}
.thanks__btn:hover {
  opacity: 0.85;
}

.legal {
  padding: 2.5rem 1.25rem 3.75rem;
  background: #fff;
}
@media screen and (min-width: 768px) {
  .legal {
    padding: 5rem 2.5rem 6.25rem;
  }
}

.legal__inner {
  max-width: 67.5rem;
  margin-inline: auto;
  color: var(--color-text);
}

.legal__heading {
  font-family: var(--font-family-base);
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .legal__heading {
    font-size: 1.25rem;
    margin-bottom: 2rem;
  }
}

.legal__lead {
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.7;
  letter-spacing: 0.03em;
  margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .legal__lead {
    font-size: 1rem;
    line-height: 1.8;
    margin-bottom: 2.5rem;
  }
}

.legal__section {
  margin-bottom: 1.75rem;
}
@media screen and (min-width: 768px) {
  .legal__section {
    margin-bottom: 2.25rem;
  }
}

.legal__section-title {
  font-family: var(--font-family-base);
  font-weight: 700;
  font-size: 0.9375rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  margin-bottom: 0.5rem;
}
@media screen and (min-width: 768px) {
  .legal__section-title {
    font-size: 1rem;
    margin-bottom: 0.625rem;
  }
}

.legal__text {
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.7;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .legal__text {
    font-size: 1rem;
    line-height: 1.8;
  }
}

.legal__list {
  list-style: disc;
  padding-left: 1.25rem;
  margin: 0.5rem 0 0;
}
@media screen and (min-width: 768px) {
  .legal__list {
    padding-left: 1.5rem;
    margin-top: 0.625rem;
  }
}

.legal__list-item {
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.7;
  letter-spacing: 0.03em;
  padding-left: 0.25rem;
}
.legal__list-item + .legal__list-item {
  margin-top: 0.25rem;
}
@media screen and (min-width: 768px) {
  .legal__list-item {
    font-size: 1rem;
    line-height: 1.8;
  }
}

.legal__address {
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.7;
  letter-spacing: 0.03em;
  font-style: normal;
  margin-top: 0.5rem;
}
@media screen and (min-width: 768px) {
  .legal__address {
    font-size: 1rem;
    line-height: 1.8;
    margin-top: 0.625rem;
  }
}

.legal__address-tel {
  color: inherit;
  text-decoration: none;
}

.legal__closing,
.legal__date {
  font-family: var(--font-family-base);
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.7;
  letter-spacing: 0.03em;
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .legal__closing,
  .legal__date {
    font-size: 1rem;
    margin-top: 2.5rem;
  }
}

.legal__divider {
  margin: 2.5rem 0 0;
  border: none;
  border-top: 1px solid #d9d9d9;
}
@media screen and (min-width: 768px) {
  .legal__divider {
    margin-top: 4rem;
  }
}
