/* Section / CTA / Footer — FV外（critical から移動） */
:root {
  --font-size-md: 1.125rem;  /* 18px */
  --font-size-xl: 2rem;      /* 32px */
  --section-padding-desktop: 64px;
  --section-gap-desktop: 64px;
  --section-title-size-desktop: 48px;
  --cta-block-padding-desktop: 64px;
  --cta-btn-padding-y-desktop: 43px;
  --cta-btn-padding-x-desktop: 64px;
  --cta-btn-font-desktop: 32px;
  --cta-btn-max-width-desktop: 720px;
  --footer-padding-top-desktop: 133px;
  --radius-cta: 267px;
}

@media (min-width: 1025px) {
  :root {
    --section-padding-desktop: min(64px, calc(100vw * 64 / 1280));
    --section-gap-desktop: min(64px, calc(100vw * 64 / 1280));
    --section-title-size-desktop: min(48px, calc(100vw * 48 / 1280));
    --cta-block-padding-desktop: min(64px, calc(100vw * 64 / 1280));
    --cta-btn-padding-y-desktop: min(43px, calc(100vw * 43 / 1280));
    --cta-btn-padding-x-desktop: min(64px, calc(100vw * 64 / 1280));
    --cta-btn-font-desktop: min(32px, calc(100vw * 32 / 1280));
    --cta-btn-max-width-desktop: min(720px, calc(100vw * 720 / 1280));
    --radius-cta: min(267px, calc(100vw * 267 / 1280));
    --footer-padding-top-desktop: min(133px, calc(100vw * 133 / 1280));
  }
}

.section {
  padding-block: 48px;
}

@media (min-width: 769px) {
  .section {
    padding-block: 64px;
  }
}

@media (min-width: 1025px) {
  .section {
    padding-block: var(--section-padding-desktop);
  }
}

.section__inner {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

@media (min-width: 769px) {
  .section__inner {
    gap: 64px;
  }
}

@media (min-width: 1025px) {
  .section__inner {
    gap: var(--section-gap-desktop);
  }
}

.section-title {
  text-align: center;
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.5;
}

.section-title__sub {
  display: block;
  color: var(--color-text);
}

.section-title__main {
  display: block;
  color: var(--color-green-accent);
}

@media (min-width: 769px) {
  .section-title {
    font-size: 2rem;
    line-height: 1.47;
  }
}

@media (min-width: 1025px) {
  .section-title {
    font-size: var(--section-title-size-desktop);
    line-height: 1.47;
  }
}

.btn--cta {
  padding: 20px 32px;
  border-radius: var(--radius-cta);
  background-color: var(--color-red);
  color: var(--color-white);
  font-size: var(--font-size-md);
  font-weight: 700;
  text-align: center;
  width: 100%;
  max-width: 320px;
}

@media (min-width: 769px) {
  .btn--cta {
    padding: 28px 48px;
    font-size: var(--font-size-xl);
    max-width: 480px;
  }
}

@media (min-width: 1025px) {
  .btn--cta {
    padding: var(--cta-btn-padding-y-desktop) var(--cta-btn-padding-x-desktop);
    font-size: var(--cta-btn-font-desktop);
    max-width: var(--cta-btn-max-width-desktop);
    border-radius: var(--radius-cta);
  }
}

.cta-block {
  display: flex;
  justify-content: center;
  padding-block: 32px;
}

@media (min-width: 769px) {
  .cta-block {
    padding-block: 48px;
  }
}

@media (min-width: 1025px) {
  .cta-block {
    padding-block: var(--cta-block-padding-desktop);
  }
}

.footer {
  padding-block: 64px 32px;
  text-align: center;
}

@media (min-width: 1025px) {
  .footer {
    padding-block: var(--footer-padding-top-desktop) 32px;
  }
}

.footer__label {
  font-size: 1.33rem;
  font-weight: 700;
  margin-bottom: 16px;
}

.footer__logo {
  margin-bottom: 24px;
}

.footer__logo img {
  height: 20px;
  width: auto;
}

@media (min-width: 769px) {
  .footer__logo img {
    height: 20px;
  }
}

.footer__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px 32px;
  margin-bottom: 32px;
}

.footer__link {
  font-size: var(--font-size-md);
  font-weight: 400;
  color: var(--color-text-light);
  transition: color 0.2s;
}

.footer__link:hover {
  color: var(--color-text);
}

.footer__copyright {
  font-size: var(--font-size-base);
  font-weight: 400;
  color: var(--color-black);
}

@media (max-width: 768px) {
  .footer__label {
    font-size: 12px;
    margin-bottom: 12px;
  }

  .footer__link {
    font-size: 11px;
  }

  .footer__links {
    gap: 12px 20px;
    margin-bottom: 24px;
  }

  .footer__copyright {
    font-size: 10px;
  }
}

/* ========================================
   Features（ポチコの特徴）
   ======================================== */
.features .section__inner {
  gap: 26px;
}

.features__grid {
  display: grid;
  grid-template-columns: repeat(2, 160px);
  gap: 13px;
  justify-content: center;
  align-items: end;
}

.features__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 160px;
}

.features__figure {
  width: 100%;
  aspect-ratio: 320 / 260;
  margin: 0;
}

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

.features__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
  width: 100%;
}

.features__name {
  font-size: 18px;
  font-weight: 900;
  line-height: 18px;
  color: var(--color-green-accent);
}

.features__desc {
  font-size: 12px;
  font-weight: 900;
  line-height: 12px;
  color: var(--color-text);
}

/* タブレット: 上段4・下段2（中央寄せ） */
@media (min-width: 769px) {
  .features .section__inner {
    gap: 34px;
  }

  .features .section-title {
    font-size: 26px;
    line-height: 38px;
  }

  .features__grid {
    grid-template-columns: repeat(4, 160px);
  }

  .features__item:nth-child(5) {
    grid-column: 2;
  }

  .features__item:nth-child(6) {
    grid-column: 3;
  }
}

/* PC: 1行6列（1280px基準でサイズ再計算） */
@media (min-width: 1025px) {
  .features .section__inner {
    gap: 64px;
  }

  .features .section-title {
    font-size: var(--section-title-size-desktop);
    line-height: 71px;
  }

  .features__grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: min(13px, calc(100vw * 13 / 1280));
    width: 100%;
    justify-content: center;
    align-items: flex-start;
  }

  .features__item {
    width: 100%;
    gap: min(22px, calc(100vw * 22 / 1280));
  }

  .features__item:nth-child(5),
  .features__item:nth-child(6) {
    grid-column: auto;
  }

  .features__body {
    gap: min(15px, calc(100vw * 15 / 1280));
  }

  .features__name {
    font-size: min(26px, calc(100vw * 26 / 1280));
    line-height: min(26px, calc(100vw * 26 / 1280));
  }

  .features__desc {
    font-size: min(13px, calc(100vw * 13 / 1280));
    line-height: min(13px, calc(100vw * 13 / 1280));
  }
}

/* ========================================
   Features — お悩み解決カード
   ======================================== */
.is-tablet-only,
.is-desktop-only {
  display: none;
}

.is-compact-only {
  display: inline;
}

.features-problems {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 19px;
  width: 100%;
  padding: 24px 16px;
  background-color: var(--color-white);
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(35, 157, 107, 0.25);
}

.features-problems__title {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  line-height: 24px;
  color: var(--color-green-accent);
  text-align: center;
}

.features-problems__list {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  width: max-content;
  max-width: 100%;
  margin: 0 auto;
  padding: 0;
  list-style: none;
}

.features-problems__item {
  display: flex;
  align-items: center;
  gap: 5px;
  width: max-content;
  max-width: 100%;
}

.features-problems__figure {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  margin: 0;
}

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

.features-problems__body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
}

.features-problems__name {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 18px;
  color: var(--color-text);
  white-space: nowrap;
}

.features-problems__desc {
  margin: 0;
  font-size: 12px;
  font-weight: 700;
  line-height: 12px;
  color: #666;
  white-space: nowrap;
}

/* タブレット以上: 横並び（PCと同レイアウト） */
@media (min-width: 769px) {
  .is-sp-only {
    display: none;
  }

  .is-tablet-only {
    display: inline;
  }

  .features-problems {
    gap: 26px;
    padding: 19px 0;
    border-radius: 11px;
    box-shadow: 0 2px 13px rgba(35, 157, 107, 0.25);
  }

  .features-problems__title-br {
    display: none;
  }

  .features-problems__list {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 26px;
    width: 100%;
    max-width: none;
    margin-inline: 0;
    padding-inline: 16px;
  }

  .features-problems__item {
    flex: 1 1 0;
    flex-direction: column;
    align-items: center;
    gap: 11px;
    width: auto;
    max-width: none;
    min-width: 0;
    text-align: center;
  }

  .features-problems__body {
    min-width: 0;
    flex-shrink: 1;
  }

  .features-problems__name,
  .features-problems__desc {
    white-space: normal;
  }

  .features-problems__figure {
    width: 80px;
    height: 80px;
  }

  .features-problems__name {
    font-size: 14px;
    font-weight: 900;
    line-height: 16px;
    color: var(--color-green-accent);
  }

  .features-problems__desc {
    display: block;
    font-size: 10px;
    font-weight: 900;
    line-height: 12px;
    color: var(--color-text);
  }
}

/* PC */
@media (min-width: 1025px) {
  .is-sp-only,
  .is-tablet-only,
  .is-compact-only {
    display: none;
  }

  .is-desktop-only {
    display: inline;
  }

  .features-problems {
    width: auto;
    gap: min(48px, calc(100vw * 48 / 1280));
    margin-inline: min(48px, calc(100vw * 48 / 1280));
    padding: min(48px, calc(100vw * 48 / 1280)) min(36px, calc(100vw * 36 / 1280));
    border-radius: min(21px, calc(100vw * 21 / 1280));
    box-shadow: var(--hero-shadow);
  }

  .features-problems__title {
    font-size: min(32px, calc(100vw * 32 / 1280));
    line-height: min(71px, calc(100vw * 71 / 1280));
    white-space: nowrap;
  }

  .features-problems__list {
    gap: min(26px, calc(100vw * 26 / 1280));
    padding-inline: 0;
  }

  .features-problems__item {
    gap: min(11px, calc(100vw * 11 / 1280));
  }

  .features-problems__figure {
    width: min(120px, calc(100vw * 120 / 1280));
    height: min(120px, calc(100vw * 120 / 1280));
  }

  .features-problems__body {
    gap: min(8px, calc(100vw * 8 / 1280));
  }

  .features-problems__name {
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(18px, calc(100vw * 18 / 1280));
  }

  .features-problems__desc {
    font-size: min(12px, calc(100vw * 12 / 1280));
    line-height: min(12px, calc(100vw * 12 / 1280));
  }
}

/* SP: 補足文（グレー行）を非表示 */
@media (max-width: 768px) {
  .features-problems .features-problems__desc {
    display: none;
  }

  .features-problems__body {
    gap: 0;
  }
}
/* ========================================
   予約受付方式
   ======================================== */
.reservation-types .section__inner {
  gap: 34px;
}

.reservation-types__header {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: center;
}

.reservation-types__title {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  line-height: 24px;
  color: var(--color-green-accent);
}

.reservation-types__lead {
  margin: 0;
  font-size: 10px;
  font-weight: 900;
  line-height: 14px;
  color: var(--color-text);
}

.reservation-types__cards {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 19px;
  width: 100%;
}

.reservation-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  width: 100%;
  max-width: 342px;
  padding: 24px 0;
  background-color: var(--color-white);
  border-radius: 11px;
  box-shadow: 0 2px 13px rgba(35, 157, 107, 0.25);
}

.reservation-card__badge {
  display: inline-block;
  padding: 4px 16px;
  border-radius: 33px;
  font-size: 14px;
  font-weight: 700;
  line-height: 24px;
  color: var(--color-white);
}

.reservation-card--simple .reservation-card__badge {
  background-color: #168ace;
}

.reservation-card--hours .reservation-card__badge {
  background-color: #c24fec;
}

.reservation-card__title {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 16px;
  color: var(--color-black);
  text-align: center;
}

.reservation-card__features {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 0;
  padding: 8px 0;
  list-style: none;
}

.reservation-card__feature {
  display: flex;
  align-items: center;
  gap: 6px;
}

.reservation-card__check {
  flex-shrink: 0;
  width: 15px;
  height: 13px;
  margin: 0;
}

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

.reservation-card__feature-text {
  font-size: 12px;
  font-weight: 700;
  line-height: 14px;
  color: var(--color-black);
}

.reservation-card__figure {
  width: 280px;
  max-width: 100%;
  margin: 0;
  border-radius: 6px;
  overflow: hidden;
}

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

@media (min-width: 769px) {
  .reservation-types .section__inner {
    gap: 46px;
  }

  .reservation-types__lead-br {
    display: none;
  }

  .reservation-types__title {
    font-size: 17px;
    line-height: 22px;
  }

  .reservation-types__lead {
    font-size: 10px;
    line-height: 22px;
  }

  .reservation-types__cards {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 13px;
  }

  .reservation-card {
    flex: 1 1 0;
    max-width: 320px;
    min-width: 0;
    padding: 32px 0;
    gap: 11px;
    border-radius: 7px;
    box-shadow: 0 1px 9px rgba(35, 157, 107, 0.25);
  }

  .reservation-card__badge {
    padding: 4px 16px;
    font-size: 12px;
    line-height: 16px;
    border-radius: 22px;
  }

  .reservation-card__title {
    font-size: 16px;
    line-height: 20px;
  }

  .reservation-card__features {
    gap: 7px;
    padding: 8px 0;
  }

  .reservation-card__check {
    width: 15px;
    height: 12px;
  }

  .reservation-card__feature-text {
    font-size: 12px;
    line-height: 13px;
  }

  .reservation-card__figure {
    width: 214px;
    border-radius: 4px;
  }
}

/* PC */
@media (min-width: 1025px) {
  .reservation-types .section__inner {
    gap: min(86px, calc(100vw * 86 / 1280));
  }

  .reservation-types__header {
    gap: 0;
  }

  .reservation-types__title {
    font-size: min(32px, calc(100vw * 32 / 1280));
    line-height: min(42px, calc(100vw * 42 / 1280));
  }

  .reservation-types__lead {
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(42px, calc(100vw * 42 / 1280));
  }

  .reservation-types__cards {
    gap: min(19px, calc(100vw * 19 / 1280));
    max-width: min(1002px, calc(100vw * 1002 / 1280));
    margin-inline: auto;
  }

  .reservation-card {
    flex: 1 1 0;
    max-width: none;
    padding-top: min(38px, calc(100vw * 38 / 1280));
    padding-bottom: min(24px, calc(100vw * 24 / 1280));
    gap: min(16px, calc(100vw * 16 / 1280));
    border-radius: min(11px, calc(100vw * 11 / 1280));
    box-shadow: var(--hero-shadow);
  }

  .reservation-card--hours .reservation-card__badge {
    background-color: #9b4fec;
  }

  .reservation-card__badge {
    padding: min(8px, calc(100vw * 8 / 1280)) min(16px, calc(100vw * 16 / 1280));
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(24px, calc(100vw * 24 / 1280));
    border-radius: min(33px, calc(100vw * 33 / 1280));
  }

  .reservation-card__title {
    font-size: min(24px, calc(100vw * 24 / 1280));
    line-height: min(30px, calc(100vw * 30 / 1280));
  }

  .reservation-card__features {
    gap: min(11px, calc(100vw * 11 / 1280));
    padding: min(12px, calc(100vw * 12 / 1280)) 0;
  }

  .reservation-card__feature {
    gap: min(9px, calc(100vw * 9 / 1280));
  }

  .reservation-card__check {
    width: min(22px, calc(100vw * 22 / 1280));
    height: min(19px, calc(100vw * 19 / 1280));
  }

  .reservation-card__feature-text {
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(20px, calc(100vw * 20 / 1280));
  }

  .reservation-card__figure {
    width: min(320px, calc(100vw * 320 / 1280));
    border-radius: min(6px, calc(100vw * 6 / 1280));
  }
}

/* SP */
@media (max-width: 768px) {
  .reservation-types__lead {
    display: none;
  }

  .reservation-card__feature.reservation-card__feature--extra {
    display: none;
  }
}

.reservation-types + .cta-block {
  margin-top: -36px;
}
/* ========================================
   導入の流れ
   ======================================== */
.onboarding-flow.section {
  padding-block: 32px;
}

.onboarding-flow .section__inner {
  gap: 20px;
}

.onboarding-flow__header {
  text-align: center;
}

.onboarding-flow__title {
  margin: 0;
  font-size: 16px;
  font-weight: 900;
  line-height: 22px;
  color: var(--color-green-accent);
}

/* SP: 1枚のカード内に縦積み */
.onboarding-flow__cards {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  padding: 4px 16px;
  background-color: var(--color-white);
  border-radius: 8px;
  box-shadow: 0 2px 13px rgba(35, 157, 107, 0.25);
}

.onboarding-card {
  position: relative;
  display: grid;
  grid-template-columns: 72px 1fr;
  grid-template-rows: auto auto auto;
  column-gap: 8px;
  row-gap: 4px;
  align-items: start;
  width: 100%;
  padding: 12px 0 0;
  text-align: left;
}

.onboarding-card:not(:last-child)::after {
  content: "";
  grid-column: 1 / -1;
  grid-row: 3;
  height: 12px;
  margin-top: 12px;
  background:
    linear-gradient(rgba(52, 177, 87, 0.4), rgba(52, 177, 87, 0.4)) left center / calc(50% - 8px) 1px no-repeat,
    linear-gradient(rgba(52, 177, 87, 0.4), rgba(52, 177, 87, 0.4)) right center / calc(50% - 8px) 1px no-repeat;
}

.onboarding-card:not(:last-child)::before {
  content: "∨";
  grid-column: 1 / -1;
  grid-row: 3;
  justify-self: center;
  align-self: center;
  margin-top: 10px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  color: rgba(52, 177, 87, 0.55);
}

.onboarding-card:last-child {
  padding-bottom: 4px;
}

.onboarding-card__badge {
  grid-column: 1;
  grid-row: 1 / -1;
  align-self: start;
  justify-self: start;
  margin-top: 1px;
  padding: 3px 8px;
  border-radius: 100px;
  font-size: 10px;
  font-weight: 700;
  line-height: 14px;
  color: var(--color-white);
  background-color: var(--color-green-accent);
  white-space: nowrap;
}

.onboarding-card__title {
  grid-column: 2;
  grid-row: 1;
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-black);
}

.onboarding-card__desc {
  grid-column: 2;
  grid-row: 2;
  margin: 0;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--color-text);
}

.onboarding-card__link {
  color: var(--color-green-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.onboarding-card__link:hover {
  opacity: 0.8;
}

.cta-block + .onboarding-flow.section {
  padding-top: 36px;
}

/* タブレット以上: 横並びカード */
@media (min-width: 769px) {
  .onboarding-flow.section {
    padding-block: 64px;
  }

  .onboarding-flow .section__inner {
    gap: 46px;
  }

  .onboarding-flow__title {
    font-size: 17px;
    line-height: 22px;
  }

  .onboarding-flow__cards {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 13px;
    padding: 12px 0 0;
    background-color: transparent;
    border-radius: 0;
    box-shadow: none;
  }

  .onboarding-card {
    position: relative;
    display: flex;
    flex: 1 1 0;
    flex-direction: column;
    align-items: center;
    gap: 11px;
    max-width: 320px;
    min-width: 0;
    padding: 28px 16px 32px;
    overflow: visible;
    text-align: center;
    background-color: var(--color-white);
    border: none;
    border-radius: 7px;
    box-shadow: 0 1px 9px rgba(35, 157, 107, 0.25);
  }

  .onboarding-card:not(:last-child)::before,
  .onboarding-card:not(:last-child)::after {
    content: none;
  }

  .cta-block + .onboarding-flow.section {
    padding-top: 72px;
  }

  .onboarding-card__badge {
    position: absolute;
    top: 0;
    left: 50%;
    grid-column: auto;
    grid-row: auto;
    margin-top: 0;
    padding: 4px 16px;
    font-size: 12px;
    line-height: 16px;
    border-radius: 22px;
    transform: translate(-50%, -50%);
  }

  .onboarding-card__title {
    font-size: 16px;
    line-height: 20px;
  }

  .onboarding-card__desc {
    font-size: 12px;
    font-weight: 700;
    line-height: 1.6;
    color: var(--color-black);
  }
}

/* PC */
@media (min-width: 1025px) {
  .onboarding-flow.section {
    padding-block: var(--section-padding-desktop);
  }

  .cta-block + .onboarding-flow.section {
    padding-top: 72px;
  }

  .onboarding-flow .section__inner {
    gap: min(86px, calc(100vw * 86 / 1280));
  }

  .onboarding-flow__title {
    font-size: min(32px, calc(100vw * 32 / 1280));
    line-height: min(42px, calc(100vw * 42 / 1280));
  }

  .onboarding-flow__cards {
    gap: min(19px, calc(100vw * 19 / 1280));
    max-width: min(1002px, calc(100vw * 1002 / 1280));
    margin-inline: auto;
    padding-top: min(20px, calc(100vw * 20 / 1280));
  }

  .onboarding-card {
    gap: min(16px, calc(100vw * 16 / 1280));
    padding: min(40px, calc(100vw * 40 / 1280)) min(24px, calc(100vw * 24 / 1280)) min(32px, calc(100vw * 32 / 1280));
    border-radius: min(11px, calc(100vw * 11 / 1280));
    box-shadow: var(--hero-shadow);
  }

  .onboarding-card__badge {
    padding: min(8px, calc(100vw * 8 / 1280)) min(16px, calc(100vw * 16 / 1280));
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(24px, calc(100vw * 24 / 1280));
    border-radius: min(33px, calc(100vw * 33 / 1280));
  }

  .onboarding-card__title {
    font-size: min(24px, calc(100vw * 24 / 1280));
    line-height: min(30px, calc(100vw * 30 / 1280));
  }

  .onboarding-card__desc {
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(28px, calc(100vw * 28 / 1280));
  }
}
/* ========================================
   Demo modal（reservation-types.css の後に読み込む）
   ======================================== */
.demo-modal {
  border: none;
  border-radius: 12px;
  padding: 0;
  max-width: 374px;
  width: calc(100% - 32px);
  max-height: calc(100dvh - 32px);
  margin: auto;
  overflow: auto;
}

.demo-modal::backdrop {
  background-color: rgba(0, 0, 0, 0.5);
}

.demo-modal__inner {
  position: relative;
  padding: 32px 24px;
}

.demo-modal__close {
  position: absolute;
  top: 12px;
  right: 12px;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--color-text-light);
}

.demo-modal__title {
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 8px;
}

.demo-modal__desc {
  font-size: var(--font-size-sm);
  text-align: center;
  color: var(--color-text-muted);
  margin-bottom: 24px;
}

.demo-modal .reservation-card__badge {
  display: block;
  padding: 0;
  border-radius: 0;
  background: none;
  font-size: 16px;
  font-weight: 700;
  line-height: 16px;
  text-align: center;
}

.demo-modal .reservation-card--simple .reservation-card__badge {
  color: #168ace;
}

.demo-modal .reservation-card--hours .reservation-card__badge {
  color: #c24fec;
}

.demo-modal .reservation-card__demo {
  display: inline-block;
  padding: 10px 32px;
  border-radius: var(--radius-pill);
  background-color: var(--color-red);
  color: var(--color-white);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  transition: opacity 0.2s;
}

.demo-modal .reservation-card__demo:hover {
  opacity: 0.85;
}

@media (min-width: 769px) {
  .demo-modal {
    max-width: 720px;
  }

  .demo-modal .reservation-types__cards {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 13px;
  }

  .demo-modal .reservation-card {
    flex: 1 1 0;
    max-width: 320px;
    min-width: 0;
    padding: 32px 0;
    gap: 11px;
    border-radius: 7px;
    box-shadow: 0 1px 9px rgba(35, 157, 107, 0.25);
  }

  .demo-modal .reservation-card__badge {
    line-height: 20px;
  }

  .demo-modal .reservation-card__title {
    font-size: 16px;
    line-height: 20px;
  }

  .demo-modal .reservation-card__features {
    gap: 7px;
    padding: 8px 0;
  }

  .demo-modal .reservation-card__check {
    width: 15px;
    height: 12px;
  }

  .demo-modal .reservation-card__feature-text {
    font-size: 12px;
    line-height: 13px;
  }

  .demo-modal .reservation-card__figure {
    width: 214px;
    border-radius: 4px;
  }
}

@media (min-width: 1025px) {
  .demo-modal .reservation-types__cards {
    max-width: none;
    margin-inline: 0;
  }
}
/* ========================================
   お客様の声
   ======================================== */
.voices .section__inner {
  gap: 34px;
}

.voices-block {
  width: 100%;
}

/* SP: カルーセルラッパー（矢印オーバーレイ用） */
.voices-carousel {
  position: relative;
  width: 100vw;
  margin-inline: calc(50% - 50vw);
}

.voices-carousel__nav {
  position: absolute;
  top: 50%;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin: 0;
  padding: 0;
  border: 2px solid var(--color-green);
  border-radius: 50%;
  background-color: var(--color-white);
  color: var(--color-green);
  box-shadow: 0 2px 10px rgba(35, 157, 107, 0.25);
  transform: translateY(-50%);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.voices-carousel__nav[hidden] {
  display: none;
}

.voices-carousel__nav--prev {
  left: 8px;
}

.voices-carousel__nav--next {
  right: 8px;
}

.voices-carousel__nav--prev .voices-carousel__icon {
  transform: rotate(180deg);
}

.voices-carousel__nav:active {
  background-color: rgba(7, 181, 59, 0.08);
}

.voices-carousel__nav:focus-visible {
  outline: 2px solid var(--color-green);
  outline-offset: 2px;
}

.voices-block--secondary {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 26px;
}

.voices-block__title {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  line-height: 24px;
  color: var(--color-green-accent);
  text-align: center;
}

/* SP: カルーセル用レイアウト（JSは後続） */
.voices-grid {
  --voice-card-width: 70vw;
  --voice-carousel-padding: calc((100vw - var(--voice-card-width)) / 2);
  display: flex;
  flex-wrap: nowrap;
  gap: 11px;
  width: 100%;
  margin: 0;
  padding-inline: var(--voice-carousel-padding);
  padding-block: 14px;
  margin-block: -14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-inline: var(--voice-carousel-padding);
  -webkit-overflow-scrolling: touch;
  list-style: none;
  scrollbar-width: none;
}

.voices-grid::-webkit-scrollbar {
  display: none;
}

.voice-card {
  display: flex;
  flex: 0 0 var(--voice-card-width);
  flex-direction: column;
  align-items: center;
  gap: 16px;
  scroll-snap-align: center;
  scroll-snap-stop: always;
  padding: 16px;
  background-color: var(--color-white);
  border-radius: 4px;
  box-shadow: 0 2px 13px rgba(35, 157, 107, 0.25);
}

.voice-card__figure {
  width: 100%;
  height: 97px;
  margin: 0;
  overflow: hidden;
  border-radius: 2px;
}

.voice-card__figure img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.voice-card__name {
  margin: 0;
  width: 100%;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--color-text);
  text-align: center;
  letter-spacing: 0.05em;
}

.voice-card__tag {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  line-height: 18px;
  color: var(--color-green-accent);
  text-align: center;
}

.voice-card__text {
  margin: 0;
  width: 100%;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.7;
  color: var(--color-text);
  letter-spacing: 0.05em;
}

/* タブレット以上: グリッド */
@media (min-width: 769px) {
  .voices .section__inner {
    gap: 46px;
  }

  .voices-block--secondary {
    gap: 34px;
    padding-top: 34px;
  }

  .voices-block__title {
    font-size: 17px;
    line-height: 23px;
  }

  .voices-block__title-br {
    display: none;
  }

  .voices-carousel {
    width: 100%;
    margin-inline: 0;
  }

  .voices-carousel__nav {
    display: none;
  }

  .voices-grid {
    --voice-card-width: initial;
    --voice-carousel-padding: 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    width: 100%;
    margin-inline: 0;
    margin-block: 0;
    overflow: visible;
    padding: 0;
    scroll-snap-type: none;
    scroll-padding-inline: 0;
  }

  .voice-card {
    flex: initial;
    gap: 9px;
    padding: 12px;
    border-radius: 4px;
    box-shadow: 0 1px 9px rgba(35, 157, 107, 0.25);
  }

  .voice-card__figure {
    height: 92px;
    border-radius: 2px;
  }

  .voice-card__name {
    font-size: 14px;
    line-height: 1.4;
  }

  .voice-card__tag {
    font-size: 12px;
    line-height: 13px;
  }

  .voice-card__text {
    font-size: 12px;
    line-height: 1.7;
  }
}

/* PC */
@media (min-width: 1025px) {
  .voices .section__inner {
    gap: min(64px, calc(100vw * 64 / 1280));
  }

  .voices-block--secondary {
    gap: min(64px, calc(100vw * 64 / 1280));
    padding-top: min(64px, calc(100vw * 64 / 1280));
  }

  .voices-block__title {
    font-size: min(32px, calc(100vw * 32 / 1280));
    line-height: min(42px, calc(100vw * 42 / 1280));
  }

  .voices-grid {
    gap: min(15px, calc(100vw * 15 / 1280));
    max-width: min(
      min(1266px, calc(100vw * 1266 / 1280)),
      calc(100% - min(96px, calc(100vw * 96 / 1280)))
    );
    margin-inline: min(48px, calc(100vw * 48 / 1280));
  }

  .voice-card {
    gap: min(16px, calc(100vw * 16 / 1280));
    padding: min(23px, calc(100vw * 23 / 1280));
    border-radius: min(8px, calc(100vw * 8 / 1280));
    box-shadow: var(--hero-shadow);
  }

  .voice-card__figure {
    height: min(172px, calc(100vw * 172 / 1280));
    border-radius: min(4px, calc(100vw * 4 / 1280));
  }

  .voice-card__name {
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: 1.4;
  }

  .voice-card__tag {
    font-size: min(16px, calc(100vw * 16 / 1280));
    line-height: min(24px, calc(100vw * 24 / 1280));
  }

  .voice-card__text {
    font-size: min(14px, calc(100vw * 14 / 1280));
    line-height: min(24px, calc(100vw * 24 / 1280));
  }
}
/* ========================================
   機能・料金
   ======================================== */
.is-tablet-up {
  display: none;
}

.pricing .section__inner {
  gap: 26px;
}

.pricing-hero {
  width: 100%;
  margin: 0;
}

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

.pricing-block {
  width: 100%;
}

.pricing-block__title {
  margin: 0 0 16px;
  font-size: 18px;
  font-weight: 900;
  line-height: 24px;
  color: var(--color-green-accent);
  text-align: center;
}

/* 機能グリッド */
.pricing-features {
  display: flex;
  flex-direction: column;
  width: 100%;
  overflow: hidden;
  border: 3px solid var(--color-green);
  border-radius: 10px;
  background-color: var(--color-white);
}

.pricing-features__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 23px;
  border-bottom: 1px solid var(--color-green);
}

.pricing-features__item:last-child {
  border-bottom: none;
}

.pricing-features__item--calendar {
  display: none;
}

.pricing-features__name {
  margin: 0;
  width: 100%;
  font-size: 18px;
  font-weight: 700;
  line-height: 24px;
  color: var(--color-green);
  text-align: center;
  letter-spacing: 0.05em;
}

.pricing-features__desc {
  margin: 0;
  width: 100%;
  font-size: 12px;
  font-weight: 400;
  line-height: 16px;
  color: var(--color-text);
  letter-spacing: 0.05em;
}

/* ご利用可能上限（SP: FV訴求カードと同体裁の2×2） */
.pricing-limits {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
  overflow: visible;
  border: none;
  background-color: transparent;
}

.pricing-limits__row {
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: visible;
  border: none;
  border-radius: 11px;
  box-shadow: 0 2px 13px rgba(35, 157, 107, 0.25);
}

.pricing-limits__row:last-child {
  border-bottom: none;
}

.pricing-limits__cell {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  border: none;
  font-size: 14px;
  line-height: 1.3;
  text-align: center;
}

.pricing-limits__cell:last-child {
  border-right: none;
}

.pricing-limits__cell--name {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-text);
  white-space: normal;
  background-color: var(--color-white);
  border-radius: 11px 11px 0 0;
}

.pricing-limits__cell--value {
  position: relative;
  min-width: 0;
  font-size: 21px;
  font-weight: 900;
  line-height: 1.2;
  color: var(--color-white);
  background-color: var(--color-green);
  border-radius: 0 0 11px 11px;
}

.pricing-limits__cell--value::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 1;
  transform: translate(-50%, -50%);
  border-right: 9px solid transparent;
  border-top: 8px solid var(--color-white);
  border-left: 9px solid transparent;
}

.pricing-limits__cell--note {
  display: none;
}

/* 料金カード */
.pricing-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 19px;
  width: 100%;
  padding: 42px 16px;
  background-color: var(--color-white);
  border-radius: 8px;
  box-shadow: 0 2px 13px rgba(35, 157, 107, 0.25);
}

.pricing-card__prices {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  width: 100%;
}

.pricing-price--primary {
  justify-self: center;
  gap: 12px;
}

.pricing-card__prices-sub {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 19px;
  width: 100%;
  max-width: 360px;
  margin-inline: auto;
}

.pricing-price {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
}

.pricing-price__label {
  margin: 0;
  font-weight: 700;
  color: var(--color-text);
}

.pricing-price__amount {
  margin: 0;
  font-weight: 900;
  color: var(--color-green-accent);
  white-space: nowrap;
}

.pricing-price__amount-num {
  line-height: 1;
}

.pricing-price__amount-unit {
  line-height: 1;
}

.pricing-price__amount-tax {
  line-height: 1;
}

@media (max-width: 768px) {
  .pricing-card__prices > .pricing-price--primary .pricing-price__label {
    font-size: 20px;
    line-height: 1.2;
  }

  .pricing-card__prices > .pricing-price--primary .pricing-price__amount-num {
    font-size: 56px;
  }

  .pricing-card__prices > .pricing-price--primary .pricing-price__amount-unit {
    font-size: 28px;
  }

  .pricing-card__prices > .pricing-price--primary .pricing-price__amount-tax {
    font-size: 12px;
  }

  .pricing-card__prices-sub .pricing-price__label {
    font-size: 16px;
    line-height: 14px;
  }

  .pricing-card__prices-sub .pricing-price__amount-num {
    font-size: 24px;
  }

  .pricing-card__prices-sub .pricing-price__amount-unit {
    font-size: 16px;
  }

  .pricing-card__prices-sub .pricing-price__amount-tax {
    font-size: 10px;
  }

  .pricing-card__prices > .pricing-price--primary {
    width: 100%;
    max-width: none;
    justify-self: stretch;
  }

  .pricing-card__prices > .pricing-price--primary::after {
    content: "";
    display: block;
    width: 100%;
    margin-top: 16px;
    border-top: 1px solid #e0e0e0;
  }
}

.pricing-card__notes {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  width: max-content;
  max-width: 100%;
  margin-inline: auto;
  padding: 0;
  list-style: none;
}

.pricing-card__note {
  display: flex;
  align-items: flex-start;
  gap: 4px;
  width: max-content;
  max-width: 100%;
}

.pricing-card__note-icon {
  flex-shrink: 0;
  width: 12px;
  height: 10px;
  margin-top: 1px;
}

.pricing-card__note-icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.pricing-card__note-text {
  margin: 0;
  font-size: 10px;
  font-weight: 700;
  line-height: 12px;
  color: var(--color-gray-800);
}

/* タブレット以上 */
@media (min-width: 769px) {
  .is-tablet-up {
    display: block;
  }

  .pricing .section__inner {
    gap: 34px;
  }

  .pricing-hero {
    max-width: 520px;
    margin-inline: auto;
  }

  .pricing-block__title {
    margin-bottom: 24px;
    font-size: 17px;
    line-height: 22px;
  }

  .pricing-features {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-template-rows: repeat(2, minmax(0, 1fr));
    border-width: 1.6px;
    border-color: var(--color-green-accent);
    border-radius: 5px;
  }

  .pricing-features__item {
    gap: 9px;
    padding: 12px;
    border-right: 0.5px solid var(--color-green-accent);
    border-bottom: 0.5px solid var(--color-green-accent);
  }

  .pricing-features__item:nth-child(4n) {
    border-right: none;
  }

  .pricing-features__item:nth-child(n + 5) {
    border-bottom: none;
  }

  .pricing-features__item:last-child {
    border-bottom: none;
  }

  .pricing-features__item--calendar {
    display: flex;
  }

  .pricing-features__name {
    font-size: 14px;
    line-height: 1.4;
    color: var(--color-text);
  }

  .pricing-features__desc {
    font-size: 12px;
    line-height: 1.7;
  }

  .pricing-limits {
    display: block;
    overflow: hidden;
    border: 1.6px solid var(--color-green-accent);
    background-color: var(--color-white);
  }

  .pricing-limits__row {
    display: grid;
    grid-template-columns: 176px 100px 1fr;
    flex-direction: row;
    overflow: hidden;
    border-bottom: 0.5px solid var(--color-green-accent);
    border-radius: 0;
    box-shadow: none;
  }

  .pricing-limits__row:last-child {
    border-bottom: none;
  }

  .pricing-limits__cell {
    min-height: 34px;
    padding: 4px 9px;
    border-right: 0.5px solid var(--color-green-accent);
    font-size: 12px;
    line-height: 11px;
  }

  .pricing-limits__cell--name {
    font-size: 12px;
    font-weight: 700;
    color: var(--color-text);
    white-space: nowrap;
    background-color: transparent;
    border-radius: 0;
  }

  .pricing-limits__cell--value {
    position: static;
    min-width: 100px;
    font-size: 12px;
    font-weight: 700;
    line-height: 9px;
    color: var(--color-green-accent);
    background-color: #eafff1;
    border-radius: 0;
  }

  .pricing-limits__cell--value::before {
    content: none;
  }

  .pricing-limits__cell--note {
    display: flex;
    justify-content: flex-start;
    min-width: 0;
    font-weight: 400;
    font-size: 10px;
    line-height: 11px;
    text-align: left;
  }

  .pricing-card {
    gap: 32px;
    max-width: 682px;
    margin-inline: auto;
    padding: 96px 94px;
    border-radius: 14px;
    box-shadow: 0 3px 17px rgba(35, 157, 107, 0.25);
  }

  .pricing-card__prices {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: flex-start;
    gap: 32px;
    width: 100%;
  }

  .pricing-card__prices-sub {
    display: contents;
  }

  .pricing-card__prices > .pricing-price--primary::after {
    content: none;
    display: none;
  }

  .pricing-price {
    flex: 0 0 auto;
    gap: 11px;
  }

  .pricing-card__prices > .pricing-price--primary {
    order: 2;
    width: 173px;
  }

  .pricing-card__prices-sub .pricing-price:nth-child(1) {
    order: 1;
    width: 129px;
  }

  .pricing-card__prices-sub .pricing-price:nth-child(2) {
    order: 3;
    width: 129px;
  }

  .pricing-card__prices .pricing-price__label {
    font-size: 24px;
    line-height: 32px;
  }

  .pricing-card__prices .pricing-price__amount-num {
    font-size: 43px;
    line-height: 48px;
  }

  .pricing-card__prices > .pricing-price--primary .pricing-price__amount-num {
    line-height: 49px;
  }

  .pricing-card__prices .pricing-price__amount-unit {
    font-size: 27px;
    line-height: 32px;
  }

  .pricing-card__prices .pricing-price__amount-tax {
    font-size: 9px;
    line-height: 32px;
  }

  .pricing-card__notes {
    gap: 0;
  }

  .pricing-card__note {
    gap: 7px;
    align-items: center;
  }

  .pricing-card__note-icon {
    width: 24px;
    height: 20px;
    margin-top: 0;
  }

  .pricing-card__note-text {
    font-size: 13px;
    line-height: 31px;
    white-space: nowrap;
  }
}

/* PC */
@media (min-width: 1025px) {
  .pricing .section__inner {
    gap: min(64px, calc(100vw * 64 / 1280));
  }

  .pricing-hero {
    max-width: min(1000px, calc(100vw * 1000 / 1280));
    margin-inline: auto;
  }

  .pricing-block__title {
    margin-bottom: min(24px, calc(100vw * 24 / 1280));
    font-size: min(32px, calc(100vw * 32 / 1280));
    line-height: min(42px, calc(100vw * 42 / 1280));
  }

  .pricing-features {
    max-width: min(
      min(1266px, calc(100vw * 1266 / 1280)),
      calc(100% - min(96px, calc(100vw * 96 / 1280)))
    );
    margin-inline: min(48px, calc(100vw * 48 / 1280));
    border-width: 3px;
    border-radius: min(10px, calc(100vw * 10 / 1280));
  }

  .pricing-features__item {
    gap: min(16px, calc(100vw * 16 / 1280));
    padding: min(23px, calc(100vw * 23 / 1280));
    border-right-width: 1px;
    border-bottom-width: 1px;
  }

  .pricing-features__name {
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(24px, calc(100vw * 24 / 1280));
  }

  .pricing-features__desc {
    font-size: min(14px, calc(100vw * 14 / 1280));
    line-height: min(24px, calc(100vw * 24 / 1280));
  }

  .pricing-limits {
    max-width: min(
      min(1266px, calc(100vw * 1266 / 1280)),
      calc(100% - min(96px, calc(100vw * 96 / 1280)))
    );
    margin-inline: min(48px, calc(100vw * 48 / 1280));
    border-width: 3px;
  }

  .pricing-limits__row {
    grid-template-columns: min(330px, calc(100vw * 330 / 1280)) min(188px, calc(100vw * 188 / 1280)) minmax(0, 1fr);
  }

  .pricing-limits__cell {
    min-height: min(64px, calc(100vw * 64 / 1280));
    padding: min(8px, calc(100vw * 8 / 1280)) min(16px, calc(100vw * 16 / 1280));
    border-width: 1px;
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(20px, calc(100vw * 20 / 1280));
  }

  .pricing-limits__cell--value {
    width: min(188px, calc(100vw * 188 / 1280));
    min-width: min(188px, calc(100vw * 188 / 1280));
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: min(16px, calc(100vw * 16 / 1280));
  }

  .pricing-limits__cell--note {
    display: flex;
    justify-content: flex-start;
    min-width: 0;
    font-size: min(14px, calc(100vw * 14 / 1280));
    line-height: min(20px, calc(100vw * 20 / 1280));
    text-align: left;
  }

  .pricing-card {
    gap: min(48px, calc(100vw * 48 / 1280));
    max-width: min(
      min(1266px, calc(100vw * 1266 / 1280)),
      calc(100% - min(96px, calc(100vw * 96 / 1280)))
    );
    margin-inline: min(48px, calc(100vw * 48 / 1280));
    padding: min(84px, calc(100vw * 84 / 1280));
    border-radius: min(21px, calc(100vw * 21 / 1280));
    box-shadow: var(--hero-shadow);
  }

  .pricing-card__prices {
    gap: min(48px, calc(100vw * 48 / 1280));
  }

  .pricing-card__prices > .pricing-price--primary {
    width: min(258px, calc(100vw * 258 / 1280));
  }

  .pricing-card__prices-sub .pricing-price:nth-child(1),
  .pricing-card__prices-sub .pricing-price:nth-child(2) {
    width: min(193px, calc(100vw * 193 / 1280));
  }

  .pricing-price {
    gap: min(16px, calc(100vw * 16 / 1280));
  }

  .pricing-card__prices .pricing-price__label {
    font-size: min(36px, calc(100vw * 36 / 1280));
    line-height: min(48px, calc(100vw * 48 / 1280));
  }

  .pricing-card__prices .pricing-price__amount-num {
    font-size: min(64px, calc(100vw * 64 / 1280));
    line-height: min(72px, calc(100vw * 72 / 1280));
  }

  .pricing-card__prices > .pricing-price--primary .pricing-price__amount-num {
    line-height: min(74px, calc(100vw * 74 / 1280));
  }

  .pricing-card__prices .pricing-price__amount-unit {
    font-size: min(40px, calc(100vw * 40 / 1280));
    line-height: min(48px, calc(100vw * 48 / 1280));
  }

  .pricing-card__prices .pricing-price__amount-tax {
    font-size: min(14px, calc(100vw * 14 / 1280));
    line-height: min(48px, calc(100vw * 48 / 1280));
  }

  .pricing-card__notes {
    gap: 0;
  }

  .pricing-card__note {
    gap: min(10px, calc(100vw * 10 / 1280));
    align-items: center;
  }

  .pricing-card__note-icon {
    width: min(36px, calc(100vw * 36 / 1280));
    height: min(30px, calc(100vw * 30 / 1280));
    margin-top: 0;
  }

  .pricing-card__note-text {
    font-size: min(20px, calc(100vw * 20 / 1280));
    line-height: min(46px, calc(100vw * 46 / 1280));
    white-space: nowrap;
  }
}
/* ========================================
   よくあるご質問
   ======================================== */
.faq .section-title__main {
  color: var(--color-text);
}

.faq .section__inner {
  gap: 26px;
}

.faq-block {
  width: 100%;
}

.faq-block__title {
  margin: 0 0 16px;
  font-size: 18px;
  font-weight: 900;
  line-height: 24px;
  color: var(--color-green-accent);
  text-align: center;
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
}

.faq-item {
  border-bottom: 1px solid #ddd;
}

.faq-item__question {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  padding: 23px;
  font: inherit;
  text-align: left;
  color: var(--color-text-muted);
  background: none;
  border: none;
  cursor: pointer;
  transition: color 0.2s ease;
}

.faq-item__question:hover,
.faq-item__question:focus-visible {
  color: var(--color-green);
}

.faq-item__icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
}

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

.faq-item__question-text {
  flex: 1;
  min-width: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
}

.faq-item__answer {
  display: none;
  align-items: flex-start;
  gap: 16px;
  padding: 0 23px 23px;
}

.faq-item.is-open .faq-item__answer {
  display: flex;
}

.faq-item.is-open .faq-item__question {
  padding-bottom: 16px;
}

.faq-item__answer-text {
  margin: 0;
  flex: 1;
  min-width: 0;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
}

.faq-item__answer-text a {
  color: inherit;
  text-decoration: underline;
}

/* SP: 常時展開・文字サイズ調整 */
@media (max-width: 768px) {
  .faq-item__question {
    pointer-events: none;
    cursor: default;
  }

  .faq-item__question:hover,
  .faq-item__question:focus-visible {
    color: var(--color-text-muted);
  }

  .faq-item__question-text,
  .faq-item__answer-text {
    font-size: 14px;
  }

  .faq-item__answer {
    display: flex;
  }
}

/* タブレット以上 */
@media (min-width: 769px) {
  .faq .section__inner {
    gap: 34px;
  }

  .faq-block__title {
    margin-bottom: 24px;
    font-size: 17px;
    line-height: 22px;
  }

  .faq-item__question {
    padding: 12px;
    gap: 9px;
  }

  .faq-item.is-open .faq-item__question {
    padding-bottom: 9px;
  }

  .faq-item__answer {
    gap: 9px;
    padding: 0 12px 12px;
  }

  .faq-item__icon {
    width: 14px;
    height: 14px;
  }

  .faq-item__question-text,
  .faq-item__answer-text {
    font-size: 14px;
    line-height: 1.4;
  }
}

/* PC */
@media (min-width: 1025px) {
  .faq .section__inner {
    gap: min(64px, calc(100vw * 64 / 1280));
  }

  .faq-block {
    max-width: min(
      min(1266px, calc(100vw * 1266 / 1280)),
      calc(100% - min(96px, calc(100vw * 96 / 1280)))
    );
    margin-inline: min(48px, calc(100vw * 48 / 1280));
  }

  .faq-block__title {
    margin-bottom: min(24px, calc(100vw * 24 / 1280));
    font-size: min(32px, calc(100vw * 32 / 1280));
    line-height: min(42px, calc(100vw * 42 / 1280));
  }

  .faq-list {
    gap: min(10px, calc(100vw * 10 / 1280));
  }

  .faq-item__question {
    gap: min(16px, calc(100vw * 16 / 1280));
    padding: min(23px, calc(100vw * 23 / 1280));
  }

  .faq-item.is-open .faq-item__question {
    padding-bottom: min(16px, calc(100vw * 16 / 1280));
  }

  .faq-item__answer {
    gap: min(16px, calc(100vw * 16 / 1280));
    padding: 0 min(23px, calc(100vw * 23 / 1280)) min(23px, calc(100vw * 23 / 1280));
  }

  .faq-item__icon {
    width: min(24px, calc(100vw * 24 / 1280));
    height: min(24px, calc(100vw * 24 / 1280));
  }

  .faq-item__question-text,
  .faq-item__answer-text {
    font-size: min(18px, calc(100vw * 18 / 1280));
    line-height: 1.4;
  }
}
