@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&family=Roboto+Condensed:wght@700;900&display=swap");
@media (max-width: 520px) {
  :root {
    --1px: calc(100vw / 393);
  }
}
@media (min-width: 521px) and (max-width: 768px) {
  :root {
    --1px: calc(100vw / 768);
  }
}
@media (min-width: 769px) {
  :root {
    --1px: 1px;
  }
}

:root {
  --color-orange: #FF7129;
  --color-orange-darken:#e54623;
  --color-beige: #F1EEE7;
  --color-brown:#d2c4b4;
  --color-border:#231815;
  --color-circle: #D1C4B4;
  --color-text: #1a1a1a;
  --color-text-sub: #555;
  --color-white: #fff;
  --content-max: 1200px;
  --gutter: clamp(20px, 5vw, 40px);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  color: var(--color-text);
  line-height: 1.8;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  background: var(--color-white);
}

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

.container {
  width: 85%;
  max-width: var(--content-max);
  margin-inline: auto;
}

/* ---- 既存スタイル無効 ---- */
#p-mv {
  display: none !important;
}

.p-main {
  width: 100% !important;
  padding: 0 !important;
}

/* ---- 共通：セクション見出し ---- */
.section {
  padding-block: clamp(48px, 8vw, 88px);
}
.section--beige {
  background: var(--color-beige);
}
.section--white {
  background: var(--color-white);
}

.heading-lv2 {
  font-size: calc(32 * var(--1px));
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 0 0 calc(50 * var(--1px));
}
@media (max-width: 520px) {
  .heading-lv2 {
    font-size: calc(20 * var(--1px));
    margin: 0 0 calc(21 * var(--1px));
  }
}

.heading-lv3 {
  font-size: calc(27 * var(--1px));
  font-weight: 700;
  color: var(--color-orange-darken);
  letter-spacing: 0.02em;
  margin: 0 0 calc(39 * var(--1px));
  line-height: 1.33;
}
@media (max-width: 520px) {
  .heading-lv3 {
    font-size: calc(18 * var(--1px));
    margin: 0 0 calc(26 * var(--1px));
  }
}
.heading-lv3 .sub {
  color: var(--color-text);
  display: inline-block;
  font-feature-settings: "palt";
}
.heading-lv3 .sub--summer {
  color: var(--color-text);
}
.heading-lv3 .sub--thin {
  letter-spacing: -0.025em;
}

/* ============ MV ============ */
.mv {
  position: relative;
  overflow: visible;
}
.mv__inner {
  position: relative;
  width: 100%;
  max-width: 100%;
  margin-inline: auto;
}
.mv__bg {
  width: 100%;
}
.mv__char {
  position: absolute;
  right: 11.51%;
  bottom: -4.61%;
  width: 21.92%;
  height: auto;
  z-index: 10;
  pointer-events: none;
  opacity: 0;
  --drop-from: -140px;
  --drop-b1: 28px;
  --drop-b2: -16px;
  --drop-b3: 12px;
  --drop-b4: -5px;
}
.mv__char.is-dropped {
  animation: mv-char-drop 1.2s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
@media (prefers-reduced-motion: reduce) {
  .mv__char {
    opacity: 1;
  }
  .mv__char.is-dropped {
    animation: none;
  }
}
@media (max-width: 767.98px) {
  .mv__char {
    right: 7.69%;
    bottom: -21.49%;
    width: 28.21%;
    --drop-from: -80px;
    --drop-b1: 16px;
    --drop-b2: -9px;
    --drop-b3: 7px;
    --drop-b4: -3px;
  }
}

@keyframes mv-char-drop {
  0% {
    opacity: 0;
    transform: translateY(var(--drop-from));
  }
  45% {
    opacity: 1;
    transform: translateY(var(--drop-b1));
  }
  62% {
    transform: translateY(var(--drop-b2));
  }
  78% {
    transform: translateY(var(--drop-b3));
  }
  90% {
    transform: translateY(var(--drop-b4));
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
/* ============ section01 リード ============ */
.lead__grid {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: calc(30 * var(--1px));
  align-items: center;
}
@media (max-width: 767.98px) {
  .lead__grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
}
.lead__label {
  display: inline-block;
  color: var(--color-orange);
  font-weight: 900;
  font-size: calc(24 * var(--1px));
  letter-spacing: -0.05em;
  margin-bottom: calc(16 * var(--1px));
}
@media (max-width: 520px) {
  .lead__label {
    font-size: calc(16 * var(--1px));
    margin-bottom: calc(10 * var(--1px));
  }
}
.lead__title {
  font-size: calc(29 * var(--1px));
  font-weight: 700;
  line-height: 1.125;
  padding: 0 0 calc(21 * var(--1px));
  border-bottom: solid 1px var(--color-border);
  margin-top: 0;
}
@media (max-width: 520px) {
  .lead__title {
    font-size: calc(20 * var(--1px));
    padding-bottom: calc(16 * var(--1px));
  }
}
.lead__text {
  font-size: calc(20 * var(--1px));
  color: var(--color-text);
  font-weight: 700;
  line-height: 1.5;
  margin: 0 0 calc(14 * var(--1px));
}
@media (max-width: 520px) {
  .lead__text {
    font-size: calc(16 * var(--1px));
    margin-bottom: calc(24 * var(--1px));
  }
}
.lead__badges {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(12 * var(--1px));
}
@media (max-width: 520px) {
  .lead__badges {
    grid-template-columns: 1fr;
  }
}
.lead__image img {
  width: 100%;
}
@media (max-width: 767.98px) {
  .lead__image {
    order: 2;
  }
}

.badge {
  background: var(--color-brown);
  padding: calc(6 * var(--1px)) 1.1em;
  font-size: calc(20 * var(--1px));
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
  text-align: center;
}
.badge:nth-child(3) {
  grid-column: 1/-1;
}
@media (max-width: 520px) {
  .badge {
    font-size: calc(16 * var(--1px));
  }
}

/* ============ section02 サービス概要 ============ */
/* 仕様テーブル */
.spec-card {
  padding: calc(23 * var(--1px));
  margin-bottom: calc(40 * var(--1px));
  border: solid 1px var(--color-border);
}

.spec-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: calc(16 * var(--1px));
}
@media (max-width: 1180px) {
  .spec-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}
@media (max-width: 520px) {
  .spec-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px 16px;
  }
}

.spec-item {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.spec-item__text {
  display: flex;
  align-items: center;
  gap: 0 5px;
  min-width: 0;
}
.spec-item__icon {
  height: calc(34 * var(--1px));
  flex-shrink: 0;
}
@media (max-width: 767.98px) {
  .spec-item__icon {
    height: calc(40 * var(--1px));
  }
}
.spec-item__label {
  font-weight: 700;
  font-size: calc(15 * var(--1px));
  white-space: nowrap;
}
@media (max-width: 767.98px) {
  .spec-item__label {
    font-size: calc(13 * var(--1px));
  }
}
.spec-item__value {
  font-size: calc(13 * var(--1px));
  line-height: 1.6;
  font-weight: 500;
  overflow-wrap: anywhere;
}
@media (max-width: 767.98px) {
  .spec-item__value {
    font-size: calc(11 * var(--1px));
  }
}
@media (max-width: 1180px) {
  .spec-item:nth-child(2n) {
    border-inline-end: none;
    padding-inline-end: 0;
  }
}
@media (max-width: 767.98px) {
  .spec-item {
    border-inline-end: none !important;
    padding-inline-end: 0 !important;
  }
}
@media (max-width: 520px) {
  .spec-item {
    flex-direction: column;
    gap: calc(8 * var(--1px));
    width: auto;
    text-align: center;
  }
  .spec-item__text {
    flex-direction: column;
    gap: calc(2 * var(--1px));
  }
}

/* 3つの付加価値 */
.points {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto auto;
  -moz-column-gap: clamp(20px, 2.5vw, 32px);
       column-gap: clamp(20px, 2.5vw, 32px);
  row-gap: 0;
  margin-bottom: clamp(48px, 7vw, 72px);
}
@media (max-width: 767.98px) {
  .points {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    row-gap: calc(28 * var(--1px));
  }
}

.point-card {
  display: grid;
  grid-row: span 3;
  grid-template-rows: subgrid;
}
@media (max-width: 767.98px) {
  .point-card {
    display: block;
  }
}
.point-card__image {
  position: relative;
}
.point-card__image img {
  width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
}
.point-card__num {
  position: absolute;
  top: calc(-13 * var(--1px));
  left: calc(-13 * var(--1px));
  width: calc(40 * var(--1px));
  height: calc(40 * var(--1px));
  border-radius: 50%;
  background: var(--color-orange-darken);
  color: #fff;
  font-weight: 500;
  font-size: calc(27 * var(--1px));
  line-height: 1;
  display: grid;
  place-items: center;
  z-index: 2;
}
@media (max-width: 767.98px) {
  .point-card__num {
    width: calc(35 * var(--1px));
    height: calc(35 * var(--1px));
    font-size: calc(24 * var(--1px));
    padding-bottom: calc(2 * var(--1px));
  }
}
.point-card__body {
  display: grid;
  grid-row: span 2;
  grid-template-rows: subgrid;
  margin-top: 0;
}
@media (max-width: 767.98px) {
  .point-card__body {
    display: block;
  }
}
.point-card__title {
  font-weight: 700;
  font-size: 1.25rem;
  margin: calc(18 * var(--1px)) 0 0.5em;
}
.point-card__text {
  color: var(--color-text);
  font-weight: 500;
  line-height: 1.25;
  margin: 0;
}

/* ご利用の流れ */
.flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  -moz-column-gap: clamp(20px, 2.5vw, 32px);
       column-gap: clamp(20px, 2.5vw, 32px);
  row-gap: 0;
}
@media (max-width: 767.98px) {
  .flow {
    row-gap: calc(28 * var(--1px));
  }
}
.flow__arrow {
  position: absolute;
  left: calc(100% + clamp(10px, 1.25vw, 16px));
  bottom: 50%;
  display: grid;
  place-items: center;
  transform: translate(-50%, 50%);
}
.flow__arrow::after {
  content: "";
  width: calc(16 * var(--1px));
  height: calc(36 * var(--1px));
  background: var(--color-orange);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
@media (max-width: 767.98px) {
  .flow__arrow {
    left: 50%;
    bottom: calc(-30 * var(--1px));
  }
  .flow__arrow::after {
    transform: rotate(90deg);
  }
  .flow__arrow {
    width: calc(14 * var(--1px));
    height: calc(30 * var(--1px));
  }
}
@media (max-width: 767.98px) {
  .flow {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    row-gap: calc(40 * var(--1px));
  }
}

.flow-card {
  display: grid;
  grid-row: span 2;
  grid-template-rows: subgrid;
}
@media (max-width: 767.98px) {
  .flow-card {
    display: block;
  }
}
.flow-card__image {
  position: relative;
}
.flow-card__image img {
  width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
}
.flow-card__body {
  padding: calc(18 * var(--1px)) 0 0;
}
.flow-card__head {
  display: flex;
  align-items: center;
  gap: calc(22 * var(--1px));
  margin-bottom: calc(10 * var(--1px));
}
.flow-card__step {
  position: relative;
  display: inline-flex;
  align-items: center;
  background: var(--color-orange-darken);
  color: #fff;
  font-weight: 500;
  font-size: calc(18 * var(--1px));
  letter-spacing: 0.06em;
  padding: calc(1 * var(--1px)) calc(7 * var(--1px));
  white-space: nowrap;
  line-height: 1.33;
}
.flow-card__step::after {
  content: "";
  position: absolute;
  left: 100%;
  top: 0;
  height: 100%;
  width: calc(12 * var(--1px));
  background: var(--color-orange-darken);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
@media (max-width: 520px) {
  .flow-card__step {
    font-size: calc(14 * var(--1px));
  }
}
.flow-card__title {
  font-weight: 700;
  font-size: calc(20 * var(--1px));
  margin: 0;
  line-height: 1.33;
}
@media (max-width: 520px) {
  .flow-card__title {
    font-size: calc(16 * var(--1px));
  }
}
.flow-card__text {
  font-size: calc(16 * var(--1px));
  color: var(--color-text);
  margin: 0 0 calc(10 * var(--1px));
  font-weight: 500;
  line-height: 1.25;
}

/* ============ section03 実績 ============ */
.metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  justify-items: center;
  margin-top: 0;
}
@media (max-width: 767.98px) {
  .metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: calc(24 * var(--1px));
    -moz-column-gap: calc(22 * var(--1px));
         column-gap: calc(22 * var(--1px));
  }
}

.metric {
  text-align: center;
}
.metric__circle {
  width: min(243 * var(--1px), 20vw);
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: var(--color-brown);
  color: var(--color-orange-darken);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-inline: auto;
}
@media (max-width: 767.98px) {
  .metric__circle {
    width: calc(146 * var(--1px));
  }
}
.metric__note {
  font-size: calc(18 * var(--1px));
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: calc(4 * var(--1px));
  padding-inline: calc(8 * var(--1px));
}
@media (max-width: 767.98px) {
  .metric__note {
    font-size: calc(11 * var(--1px));
  }
}
.metric__num {
  font-family: "Roboto Condensed", "Noto Sans JP", sans-serif;
  font-size: calc(110 * var(--1px));
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.01em;
}
@media (max-width: 767.98px) {
  .metric__num {
    font-size: calc(66 * var(--1px));
  }
}
.metric__label {
  font-weight: 700;
  font-size: calc(20 * var(--1px));
  color: var(--color-text);
  margin-top: calc(18 * var(--1px));
}
@media (max-width: 767.98px) {
  .metric__label {
    font-size: calc(12 * var(--1px));
    margin-top: calc(8 * var(--1px));
  }
}
.metric__sub {
  font-size: calc(12 * var(--1px));
  color: var(--color-text);
  margin-top: calc(11 * var(--1px));
  max-width: min(243 * var(--1px), 20vw);
  margin-inline: auto;
  font-weight: 500;
}
@media (max-width: 767.98px) {
  .metric__sub {
    font-size: calc(10 * var(--1px));
    max-width: calc(146 * var(--1px));
  }
}

/* ============ section04 夏号募集 ============ */
.summer__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: calc(35 * var(--1px));
  align-items: start;
}
@media (max-width: 767.98px) {
  .summer__grid {
    grid-template-columns: minmax(0, 1fr);
    gap: calc(28 * var(--1px));
  }
}
.summer__map img {
  width: calc(100% + 14 * var(--1px));
  max-width: none;
  margin-left: calc(-14 * var(--1px));
}
.summer__note {
  font-size: calc(12 * var(--1px));
  color: var(--color-text);
  font-weight: 500;
  margin-top: calc(8 * var(--1px));
}
@media (max-width: 767.98px) {
  .summer__note {
    font-size: calc(10 * var(--1px));
  }
}

.area-list__title {
  font-weight: 700;
  font-size: calc(20 * var(--1px));
  margin: 0;
  line-height: 1.2;
}
@media (max-width: 767.98px) {
  .area-list__title {
    font-size: calc(16 * var(--1px));
  }
}
.area-list__row {
  font-size: calc(20 * var(--1px));
  margin-bottom: calc(10 * var(--1px));
  font-weight: 500;
}
@media (max-width: 767.98px) {
  .area-list__row {
    font-size: calc(16 * var(--1px));
  }
}
.area-list__note {
  font-size: calc(20 * var(--1px));
  color: var(--color-text);
  margin: 0 0 calc(5 * var(--1px));
  font-weight: 500;
  line-height: 1.2;
}
@media (max-width: 767.98px) {
  .area-list__note {
    font-size: calc(16 * var(--1px));
  }
}

.area-table {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: repeat(4, auto);
  grid-auto-flow: column;
  -moz-column-gap: calc(35 * var(--1px));
       column-gap: calc(35 * var(--1px));
  font-weight: 500;
}
.area-table dl {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: calc(8 * var(--1px));
  margin: 0;
  padding: calc(14 * var(--1px)) 0;
  border-bottom: 1px solid var(--color-border);
}
.area-table dt {
  font-size: calc(20 * var(--1px));
}
.area-table dd {
  margin: 0;
  font-weight: 500;
  font-size: calc(20 * var(--1px));
}
@media (max-width: 767.98px) {
  .area-table {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    grid-auto-flow: row;
    -moz-column-gap: 0;
         column-gap: 0;
  }
  .area-table dt,
  .area-table dd {
    font-size: calc(16 * var(--1px));
  }
}

/* スケジュール */
.schedule {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  -moz-column-gap: calc(12 * var(--1px));
       column-gap: calc(12 * var(--1px));
  margin-top: calc(26 * var(--1px));
}
.schedule__item {
  padding-left: calc(19 * var(--1px));
  padding-block: calc(8 * var(--1px));
  border-left: calc(4 * var(--1px)) solid var(--color-orange-darken);
}
.schedule__label {
  font-weight: 700;
  font-size: calc(20 * var(--1px));
  margin: 0;
  line-height: 1.2;
}
@media (max-width: 767.98px) {
  .schedule__label {
    font-size: calc(16 * var(--1px));
  }
}
.schedule__value {
  font-size: calc(20 * var(--1px));
  font-weight: 500;
  margin: 0;
  letter-spacing: 0.02em;
  line-height: 1.2;
}
@media (max-width: 767.98px) {
  .schedule__value {
    font-size: calc(16 * var(--1px));
  }
}
.schedule__item:nth-child(2) .schedule__label,
.schedule__item:nth-child(2) .schedule__value,
.schedule__item:nth-child(2) .schedule__value strong {
  color: var(--color-orange-darken);
}
@media (max-width: 767.98px) {
  .schedule {
    grid-template-columns: 1fr;
    row-gap: calc(18 * var(--1px));
    margin-top: calc(28 * var(--1px));
  }
}

/* ============ section05 ダウンロード / FAQ ============ */
.downloads {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  -moz-column-gap: calc(38 * var(--1px));
       column-gap: calc(38 * var(--1px));
  margin-bottom: calc(64 * var(--1px));
}
@media (max-width: 767.98px) {
  .downloads {
    grid-template-columns: 1fr;
    row-gap: calc(29 * var(--1px));
    margin-bottom: calc(40 * var(--1px));
  }
}

.dl-card {
  display: flex;
  align-items: center;
  gap: calc(13 * var(--1px));
  padding-bottom: calc(15 * var(--1px));
  border-bottom: 1px solid var(--color-border);
}
.dl-card__icon {
  width: calc(60 * var(--1px));
  flex-shrink: 0;
}
.dl-card__text {
  flex: 1;
  min-width: 0;
}
.dl-card__title {
  font-weight: 700;
  font-size: calc(20 * var(--1px));
  color: var(--color-text);
  margin: 0;
  line-height: 1.2;
}
.dl-card__desc {
  font-size: calc(20 * var(--1px));
  font-weight: 500;
  color: var(--color-text);
  margin: calc(2 * var(--1px)) 0 0;
  line-height: 1.2;
}
@media (max-width: 767.98px) {
  .dl-card {
    display: grid;
    grid-template-columns: calc(49 * var(--1px)) minmax(0, 1fr);
    -moz-column-gap: calc(8 * var(--1px));
         column-gap: calc(8 * var(--1px));
    row-gap: calc(14 * var(--1px));
    align-items: center;
    padding-bottom: calc(18 * var(--1px));
  }
  .dl-card .dl-card__icon {
    width: calc(49 * var(--1px));
    grid-column: 1;
    grid-row: 1;
  }
  .dl-card .dl-card__text {
    grid-column: 2;
    grid-row: 1;
  }
  .dl-card .btn-download {
    grid-column: 2;
    grid-row: 2;
    justify-self: start;
  }
}
@media (max-width: 520px) {
  .dl-card .dl-card__title,
  .dl-card .dl-card__desc {
    font-size: calc(16 * var(--1px));
  }
}

.btn-download {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: calc(10 * var(--1px));
  width: calc(203 * var(--1px));
  background: var(--color-orange);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: calc(20 * var(--1px));
  padding: calc(11 * var(--1px)) calc(19 * var(--1px));
  white-space: nowrap;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.btn-download:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}
.btn-download__arrow {
  width: calc(16 * var(--1px));
  height: auto;
  flex-shrink: 0;
}
@media (max-width: 767.98px) {
  .btn-download {
    width: calc(193 * var(--1px));
  }
}
@media (max-width: 520px) {
  .btn-download {
    font-size: calc(18 * var(--1px));
  }
}

/* FAQ */
.faq {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  -moz-column-gap: calc(38 * var(--1px));
       column-gap: calc(38 * var(--1px));
  row-gap: calc(37 * var(--1px));
}
@media (max-width: 767.98px) {
  .faq {
    grid-template-columns: 1fr;
    row-gap: calc(18 * var(--1px));
  }
}

.faq-item__q {
  display: flex;
  gap: calc(10 * var(--1px));
  align-items: center;
  font-weight: 700;
  font-size: calc(20 * var(--1px));
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
  padding-bottom: calc(13 * var(--1px));
  font-family: "Roboto Condensed", "Noto Sans JP", sans-serif;
  line-height: 1;
}
.faq-item__a {
  display: flex;
  gap: calc(10 * var(--1px));
  align-items: center;
  font-size: calc(20 * var(--1px));
  color: var(--color-text);
  line-height: 1.5;
  margin-top: calc(15 * var(--1px));
  font-family: "Roboto Condensed", "Noto Sans JP", sans-serif;
  line-height: 1;
}
@media (max-width: 520px) {
  .faq-item__q, .faq-item__a {
    font-size: calc(16 * var(--1px));
  }
}

.faq-mark {
  flex-shrink: 0;
  width: calc(29 * var(--1px));
  height: calc(29 * var(--1px));
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: calc(22 * var(--1px));
  color: #fff;
}
.faq-mark--q {
  background: var(--color-orange-darken);
}
.faq-mark--a {
  background: var(--color-border);
}
@media (max-width: 520px) {
  .faq-mark {
    width: calc(24 * var(--1px));
    height: calc(24 * var(--1px));
    font-size: calc(18 * var(--1px));
  }
}

/* ============ インフォバー ============ */
.infobar {
  border: 1px solid var(--color-border);
  padding: calc(38 * var(--1px)) calc(40 * var(--1px));
  margin-top: calc(64 * var(--1px));
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(8 * var(--1px)) 0;
  font-size: calc(18 * var(--1px));
  color: var(--color-text);
  font-weight: 500;
}
.infobar__seg {
  padding-inline: calc(20 * var(--1px));
}
.infobar__seg:first-child {
  padding-left: 0;
}
.infobar__seg:not(:last-child) {
  border-inline-end: 1px solid var(--color-border);
}
.infobar__tel {
  font-weight: 700;
}
.infobar__hours {
  margin-left: calc(14 * var(--1px));
}
.infobar strong {
  color: var(--color-text);
  font-weight: 700;
}
@media (max-width: 767.98px) {
  .infobar {
    flex-direction: column;
    align-items: stretch;
    text-align: left;
    padding: calc(28 * var(--1px)) calc(24 * var(--1px));
    margin-top: calc(48 * var(--1px));
    font-size: calc(12 * var(--1px));
  }
  .infobar strong {
    font-size: calc(14 * var(--1px));
  }
  .infobar .infobar__seg {
    padding-inline: 0;
    padding-block: calc(12 * var(--1px));
  }
  .infobar .infobar__seg:not(:last-child) {
    border-inline-end: none;
    border-bottom: 1px solid var(--color-border);
  }
  .infobar .infobar__seg:has(strong) {
    border-bottom: none !important;
  }
  .infobar .infobar__seg:has(strong)::after {
    content: "";
    display: block;
    width: 40px;
    height: 1px;
    background: var(--color-border);
    margin-top: calc(12 * var(--1px));
  }
  .infobar .infobar__seg:last-child {
    display: flex;
    flex-direction: column;
    gap: calc(6 * var(--1px));
  }
  .infobar .infobar__tel {
    font-size: calc(24 * var(--1px));
  }
  .infobar .infobar__hours {
    margin-left: 0;
    font-size: calc(12 * var(--1px));
  }
}

/* ============ フェードイン ============ */
.js-fadein {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
  will-change: opacity, transform;
}
.js-fadein.is-visible {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .js-fadein {
    opacity: 1;
    transform: none;
    transition: none;
  }
  html {
    scroll-behavior: auto;
  }
}
/* PC, SP*/
.pc {
  display: block;
}
@media (min-width: 767.98px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media (max-width: 768px) {
  .sp {
    display: block;
  }
}