@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Noto+Sans+JP:wght@100..900&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap');

@font-face {
  font-family: "Shippori Gothic B2";
  font-weight: 700;
  src: url('./font/ShipporiGothicB2-Bold.ttf'), format('truetype');
}

:root {
  /* color */
  --color-base: #64696E;
  --color-base_light: #949FA8;
  --color-base_dark: #2B2D2E;
  --color-primary: #5AAAE6;
  --color-bg-primary: #58A7E2;
  --color-primary_lighter: #F5F8FA;
  --color-white: #FFFFFF;
  --color-orange: #FA8B15;
  --color-border: #DFF0FC;
  --color-table-border: #dee2e6;
  /* hover */
  --animation-delay: all 0.3s;
  /* font */
  --font-mincho: "Shippori Mincho";
  --font-noto: "Noto sans JP";
  --font-gothic: "Shippori Gothic B2", sans-serif;
  --title-size: 40px;
  --heading-size: 30px;
  --fw-medium: 500;
  --fw-normal: 400;
}


/* general */
html {
  scroll-behavior: smooth;
}

body {
  line-height: 1.5;
  letter-spacing: 0.03rem;
  font-family: var(--font-noto);
  font-weight: var(--fw-medium);
  color: var(--color-base);
  background-color: var(--color-primary_lighter);
  margin: 0;
}

.is-br {
  display: inline-block;
}

/* reset */
li {
  list-style-type: none;
}

a {
  text-decoration: none;
}

summary::-webkit-details-marker {
  display: none;
}

summary {
  -webkit-tap-highlight-color: transparent;
}

/* margin */
.mla {
  margin-left: auto;
}

/* font */
.fw600 {
  font-weight: 600;
}

/* shadow */
.banner-shadow {
  box-shadow: 0px 4px 12px rgba(70, 131, 230, 0.3);
}

/* button */
.contact-btn {
  display: block;
  width: fit-content;
  padding: 20px 32px;
  border-radius: 9999px;
  background-color: var(--color-orange);
  text-align: center;
  font-size: 14px;
  color: var(--color-white);
  white-space: nowrap;
}

.contact-btn:hover {
  opacity: 0.7;
  transition: var(--animation-delay);
}

.contact-btn.middle {
  padding: 24px 124px;
  font-size: 20px;
}

.contact-btn.large {
  padding: 40px clamp(10.813rem, 8.879rem + 4.02vw, 12.5rem);
  font-size: 20px;
}

.contact-btn-strong {
  font-size: 32px;
}

/* balloon */
.balloon {
  position: relative;
  width: fit-content;
  padding: 3px 24px;
  border-radius: 9999px;
  background-color: var(--color-primary);
  letter-spacing: 0;
  font-size: 13px;
  color: var(--color-white);
}

.balloon::before {
  content: "";
  position: absolute;
  bottom: -7px;
  left: 50%;
  transform: translateX(-50%);
  height: calc(16px / 2);
  width: 16px;
  background-color: var(--color-primary);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.balloon.large {
  padding: 10px 40px;
  font-size: 20px;
  font-family: var(--font-gothic);
}

.balloon-white {
  position: relative;
  width: fit-content;
  padding: 24px 60px;
  border-radius: 9999px;
  background-color: var(--color-white);
  letter-spacing: 0;
  font-size: 26px;
  font-family: var(--font-gothic);
  color: var(--color-primary);
}

.balloon-white::before {
  content: "";
  position: absolute;
  bottom: -7px;
  left: 50%;
  transform: translateX(-50%);
  height: calc(16px / 2);
  width: 16px;
  background-color: var(--color-white);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.balloon-price {
  margin: 0 4px;
  font-size: 23px;
  font-family: var(--font-gothic);
}

/* card */
.card {
  width: fit-content;
  margin-left: auto;
}

.card.kv {
  max-width: 649px;
  width: 60vw;
}

.card.price {
  width: 100%;
}

.card-header {
  padding: 8px;
  border-radius: 8px 8px 0 0;
  background-color: var(--color-primary);
  color: var(--color-white);
  text-align: center;
}

.card-footer {
  border-radius: 0 0 8px 8px;
  background-color: var(--color-white);
  text-align: center;
}

.card-description {
  font-size: 14px;
  margin-bottom: 10px;
}

.card-footer-img {
  display: block;
  max-width: 649px;
  width: 100%;
  border-radius: 0 0 8px 8px;
}

/* asterisk */
.asterisk {
  font-size: 12px;
  font-weight: var(--fw-normal);
  color: var(--color-base_light);
}

.asterisk::before {
  content: "※ ";
}

/* intersect */
.intersect-img {
  display: block;
  width: 100%;
}

/* animation */
@keyframes slider {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-100%);
  }
}

/* Header */
.header-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 8px 40px;
  background-color: var(--color-white);
}

.header-logo img {
  display: block;
  height: 56px;
  object-fit: contain;
}

.header-nav {
  display: flex;
  align-items: center;
  justify-content: end;
  flex-wrap: wrap-reverse;
  gap: 12px 24px;
}

.header-ul {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px 24px;
}

.header-list {
  font-size: 14px;
}

.header-link {
  display: block;
  color: var(--color-base);
}

.header-link:hover {
  opacity: 0.7;
  transition: var(--animation-delay);
}

/* cta */
.cta-bg {
  background: url('./images/texture_01.png'), url('./images/texture_02.png') var(--color-primary);
}

/* Kv */
.kv-container {
  width: 100%;
  height: auto;
  padding: 64px 80px;
  background-image: url('./images/kv_pc.jpg');
  background-size: cover;
  aspect-ratio: 16/9;
  overflow: visible;
}

.kv-column {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}

.kv-title {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-family: var(--font-mincho);
  font-weight: var(--fw-medium);
  font-size: 32px;
  margin-bottom: 56px;
}

.kv-title-text {
  display: block;
  padding: 0 0 2px 14px;
  background-color: var(--color-white);
  color: var(--color-base);
  white-space: nowrap;
  margin-left: auto;
}

.kv-title-text span {
  margin-right: -0.2rem;
}

.kv-notice img {
  width: 640px;
  height: auto;
}

.kv-balloon {
  display: flex;
  flex-direction: column;
  margin-left: auto;
  gap: 23px;
  width: fit-content;
}

/* campaign */
.campaign-container {
  max-width: 992px;
  width: 100%;
  padding: 80px 16px;
  margin: 0 auto;
}

.campaign-container.middle {
  padding: 48px 16px;
}

.campaign-title {
  text-align: center;
  font-size: var(--title-size);
  font-weight: var(--fw-medium);
  color: var(--color-white);
  margin: 40px 0;
}

.campaign-footer-title {
  position: relative;
  z-index: 1;
  width: fit-content;
  height: auto;
  padding: 20px 40px;
  border-top: 1px solid var(--color-white);
  border-bottom: 1px solid var(--color-white);
  line-height: 1.5;
  text-align: center;
  font-size: 44px;
  font-weight: var(--font-mincho);
  font-family: var(--font-mincho);
  color: var(--color-white);
  margin: 0 auto 88px;
}

.campaign-sub-title {
  width: fit-content;
  padding: 4px 40px;
  border-top: 1px solid var(--color-white);
  border-bottom: 1px solid var(--color-white);
  font-size: 18px;
  font-weight: var(--fw-medium);
  font-family: var(--font-mincho);
  color: var(--color-white);
  margin: 0 auto;
}

.campaign-banner {
  display: block;
  max-width: 960px;
  width: 100%;
  border-radius: 8px;
  margin-bottom: 40px;
}

.campaign-ul {
  width: fit-content;
  font-size: 12px;
  font-weight: var(--fw-medium);
  color: var(--color-white);
  margin: -16px auto 40px;
}

.campaign-word {
  text-align: center;
  color: var(--color-white);
}

.campaign-word-strong {
  font-size: 26px;
  color: var(--color-white);
}

.campaign-contact-btn {
  width: fit-content;
  margin: 16px auto 0;
}

.campaign-description {
  text-align: center;
  font-size: 18px;
  color: var(--color-white);
  margin-bottom: 40px;
}

/* about */
.about-container {
  padding: 0 0 100px;
  background-color: var(--color-primary_lighter);
}

.about-title {
  padding-top: 48px;
  text-align: center;
  font-weight: var(--fw-medium);
  font-size: var(--title-size);
  color: var(--color-primary);
}

.about-description {
  font-weight: var(--fw-normal);
  text-align: center;
  margin-top: 40px;
}

.point-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 56px;
  margin: 80px auto 0;
}

.point-contents {
  display: flex;
  align-items: center;
  gap: 64px;
  padding: 0 clamp(16px, -9.314rem + 21.46vw, 120px) 0 0;
}

.point-contents:nth-child(even) {
  flex-direction: row-reverse;
  padding: 0 0 0 clamp(16px, -9.314rem + 21.46vw, 140px);
}

.point-img {
  flex: 0 0 auto;
  width: 47vw;
}

.point-img img {
  display: block;
  width: 100%;
  border-radius: 0 8px 8px 0;
}

.point-contents:nth-child(even) .point-img img {
  border-radius: 8px 0 0 8px;
}

.point-label {
  width: fit-content;
  padding: 1px 8px;
  background-color: var(--color-primary);
  font-size: 12px;
  font-family: 'DNP ShueiMGoStd';
  color: var(--color-white);
  margin-bottom: 16px;
}

.point-heading {
  letter-spacing: 0;
  text-align: left;
  font-weight: var(--fw-medium);
  font-size: var(--heading-size);
  color: var(--color-primary);
}

.point-description {
  line-height: 1.8;
  font-weight: var(--fw-normal);
  margin-top: 32px;
}


/* compare */
.compare-container {
  padding: 0 80px;
  margin: 176px auto 0;
}

.compare-contents {
  max-width: 1200px;
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  background-color: var(--color-white);
  margin: 0 auto;
}

.compare-title {
  width: fit-content;
  padding: 16px 72px;
  border-radius: 9999px;
  background-color: var(--color-primary);
  text-align: center;
  font-size: var(--title-size);
  font-family: var(--font-mincho);
  font-weight: var(--fw-medium);
  color: var(--color-white);
  margin: -46px auto 0;
}

.compare-ul {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: fit-content;
  margin: 74px auto 0;
}

.compare-list {
  display: flex;
  align-items: center;
  gap: 10px;
  line-height: 1.8;
  font-size: 20px;
  color: var(--color-primary);
}

.compare-check-img {
  display: flex;
}

.underline {
  display: inline;
  background: linear-gradient(to bottom,
      transparent 0%,
      transparent 70%,
      rgba(90, 170, 230, 0.2) 70%,
      rgba(90, 170, 230, 0.2) 90%,
      transparent 90%,
      transparent 100%);
}

.compare-img-block {
  display: flex;
  flex-direction: column;
  gap: 88px;
  width: fit-content;
  margin: 56px auto 120px;
  padding: 0 56px;
}

.compare-img-block img {
  max-width: 960px;
  width: 100%;
  border-radius: 8px;
}

.card.compare {
  width: 100%;
}

.card.compare .card-header {
  font-size: 22px;
  font-weight: var(--fw-medium);
}
.card-header-compare-strong {
  font-size: 26px;
}

.card.compare .card-footer {
  background-color: var(--color-primary_lighter);
  padding-bottom: 64px;
}

.card.compare .card-footer-img {
  padding: 48px 0;
}

.card.compare .card-footer .asterisk {
  max-width: 839px;
  width: 100%;
  padding: 0 64px;
  text-align: left;
  margin: 0 auto;
}

.about-balloon {
  display: flex;
  flex-direction: column;
  gap: 23px;
  max-width: 776px;
  width: 100%;
  margin: 80px auto 0;
}

.pause-container {
  display: grid;
  grid-template-columns: minmax(0, 660px) minmax(0, 540px);
  justify-content: center;
  align-items: center;
  max-width: 1232px;
  width: 100%;
  height: 100%;
  border-radius: 8px;
  padding: 0 16px;
  margin: 47px auto 0;
}

.pause-sub-title {
  width: fit-content;
  padding: 4px 40px;
  border-top: 1px solid var(--color-white);
  border-bottom: 1px solid var(--color-white);
  font-size: clamp(0.875rem, 0.588rem + 0.6vw, 1.125rem);
  font-weight: var(--fw-medium);
  font-family: var(--font-mincho);
  color: var(--color-white);
  margin: 0 auto;
}

.pause-sub-title-strong {
  font-size: clamp(1.125rem, 0.695rem + 0.89vw, 1.5rem);
}

.pause-title {
  width: fit-content;
  font-size: clamp(1.625rem, 1.124rem + 1.04vw, 2.063rem);
  font-weight: var(--fw-medium);
  margin: 24px auto 0;
}

.pause-title span {
  margin: 0 auto;
}

.pause-contents {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 692px;
  width: 100%;
  height: 100%;
  padding: 0 16px;
  border-radius: 8px 0 0 8px;
  background-color: var(--color-primary);
  color: var(--color-white);
}

.pause-day {
  padding-left: 0.5rem;
  line-height: 1.05;
  font-size: 60px;
  font-family: var(--font-gothic);
}

.pause-img {
  max-width: 540px;
  width: 100%;
}

.pause-img img {
  display: block;
  width: 100%;
  border-radius: 0 8px 8px 0;
}

.pause-note {
  text-align: center;
  margin-top: 24px;
}

/* active */
.active-container {
  padding: 120px 0;
}

.active-wrap {
  max-width: 1232px;
  width: 100%;
  padding: 0 16px;
  margin: 0 auto;
}

.active-inner {
  padding: 0 40px;
}

.active-title {
  font-size: var(--title-size);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
}

/* slider */
.slider-contents {
  display: flex;
  align-items: center;
  overflow: hidden;
  margin-top: 80px;
}

.slider-wrap {
  display: flex;
  animation: slider 30s linear infinite;
}

.slide {
  width: 22vw;
  height: auto;
  margin-right: 48px;
}

.slide img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  object-fit: contain;
}

.active-top-contents {
  padding: 80px 120px;
  background-image: url('./images/active_top.jpg');
  background-size: cover;
  margin: 112px auto 80px;
}

.active-top-block {
  max-width: 672px;
  width: 100%;
  padding: 80px;
  border-radius: 8px;
  background-color: var(--color-white);
  margin-left: auto;
}

.active-heading {
  letter-spacing: 0;
  font-size: var(--heading-size);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  margin: 31px 0 0;
}

.active-heading-underline {
  position: relative;
}

.active-heading-underline::before {
  position: absolute;
  bottom: 5px;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 6px;
  background-color: var(--color-primary);
  opacity: 0.2;
  content: "";
}

.active-description {
  line-height: 1.8;
  font-weight: var(--fw-normal);
  margin-top: 40px;
}

.active-note {
  margin-top: 16px;
}

.active-contents {
  display: flex;
  align-items: center;
  gap: 80px;
  max-width: 1232px;
  width: 100%;
  padding: 0 16px;
  margin: 0 auto 56px;
}

.active-contents:last-child {
  margin: 0 auto 0;
}

.active-contents:nth-child(even) {
  flex-direction: row-reverse;
}

.active-img {
  display: block;
  flex: 0 0 auto;
  max-width: 560px;
  width: 39vw;
}

.active-img img {
  width: 100%;
  border-radius: 8px;
}

.active-other-container {
  max-width: 1232px;
  width: 100%;
  padding: 0 16px;
  margin: 155px auto 0;
}

.active-other-wrap {
  border-radius: 8px;
  border: 1px solid var(--color-border);
  background-color: var(--color-white);
}

.active-other-inner {
  padding: 80px 40px;
}

.active-other-title {
  width: fit-content;
  height: auto;
  padding: 16px 72px;
  border-top: 1px solid var(--color-primary);
  border-bottom: 1px solid var(--color-primary);
  background-color: var(--color-white);
  font-size: 36px;
  font-weight: var(--font-mincho);
  font-family: var(--font-mincho);
  color: var(--color-primary);
  margin: -43px auto 0;
}

.active-other-contents {
  display: flex;
  gap: 24px;
  max-width: 960px;
  width: 100%;
  height: 100%;
  border-radius: 8px;
  background-color: var(--color-white);
  margin: 0 auto;
}

.active-other-block {
  width: calc((100% - 48px) / 3);
}

.active-other-img img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 8px 8px 0 0;
}

.active-other-description {
  padding: 12px;
  border-radius: 0 0 8px 8px;
  background-color: var(--color-primary);
  text-align: center;
  color: var(--color-white);
}

/* price */
.price-container {
  padding: 120px 0 0;
}

.price-title {
  text-align: center;
  font-size: var(--title-size);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
}

.price-description {
  text-align: center;
  font-weight: var(--fw-normal);
  margin: 24px 0;
}

.price-note {
  text-align: center;
  margin: 0 0 80px;
}

.price-contents {
  padding: 16px 0 0;
  background-color: var(--color-white);
}

.price-heading {
  width: fit-content;
  padding: 16px 72px;
  border-radius: 9999px;
  background-color: var(--color-primary);
  font-size: var(--heading-size);
  font-weight: var(--fw-medium);
  font-family: var(--font-mincho);
  color: var(--color-white);
  margin: 0 auto;
}

.price-heading-strong {
  font-size: 56px;
}

.price-heading-sub-strong {
  font-size: 46px;
}

.price-card-block {
  max-width: 1232px;
  padding: 0 16px;
  margin: 80px auto 0;
}

.price-card-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  justify-content: center;
  gap: 20px;
  margin: 0 auto;
}

.price-card-strong {
  line-height: 1;
  font-size: 49px;
  font-family: var(--font-gothic);
  color: var(--color-orange);
}

.card-footer-price-note {
  margin-top: 8px;
}

.price-card-strong.middle {
  font-size: 36px;
}

.price-card-strong.small {
  font-size: 19px;
}

.price .card-footer {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 128px;
  background-color: var(--color-primary_lighter);
}

.price .card-footer.large {
  min-height: 280px;
}

.price .card-footer.large .price-card-strong {
  font-size: 80px;
}

.price .card-footer.large .card-description {
  font-size: 19px;
  margin-bottom: 24px;
}

.price .card-footer.large .price-card-strong.small {
  font-size: 19px;
}

.price-plus-img {
  width: 36px;
  height: 36px;
  margin: 16px auto;
}

.price-card-note {
  width: fit-content;
  margin: 24px auto 0;
}

.price-conversion-title {
  position: relative;
  z-index: 1;
  width: fit-content;
  height: auto;
  padding: 16px 72px;
  border-top: 1px solid var(--color-primary);
  border-bottom: 1px solid var(--color-primary);
  background-color: var(--color-white);
  text-align: center;
  white-space: pre-line;
  font-size: 30px;
  font-weight: var(--font-mincho);
  font-family: var(--font-mincho);
  color: var(--color-primary);
  margin: 0 auto -43px;
}

.price-conversion-container {
  max-width: 1232px;
  width: 100%;
  margin: 120px auto 0;
  padding: 0 16px 120px;
}

.price-conversion-contents {
  margin: 0 auto;
}

.price-conversion-block {
  max-width: 1200px;
  width: 100%;
  padding: 64px 0 48px;
  border-radius: 9999px;
  background-color: var(--color-primary_lighter);
  margin: 0 auto;
}

.price-conversion-img img {
  width: 100%;
  padding: 0 clamp(3.75rem, -0.548rem + 8.94vw, 7.5rem) 32px;
}

.price-conversion-block .asterisk {
  max-width: 500px;
  width: 100%;
  margin: 0 auto;
}

.select-container {
  width: 100%;
  margin: 0 auto;
  padding: 120px 16px;
  text-align: center;
}

.select-title {
  font-size: var(--title-size);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  margin-bottom: 80px;
}

.select-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  max-width: 1200px;
  margin: 0 auto;
  gap: 24px;
}

.select-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 56px 32px 40px;
  border-radius: 8px;
  border: 1px solid #DFF0FC;
  background-color: var(--color-white);
}

.select-balloon {
  position: relative;
  width: 100%;
  max-width: 320px;
  padding: 10px 0;
  border-radius: 9999px;
  background-color: var(--color-primary);
  font-size: 20px;
  font-family: var(--font-gothic);
  color: var(--color-white);
  margin-bottom: 23px;
}

.select-balloon::before {
  content: "";
  position: absolute;
  bottom: -7px;
  left: 50%;
  transform: translateX(-50%);
  height: calc(16px / 2);
  width: 16px;
  background-color: var(--color-primary);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.select-balloon-white {
  position: relative;
  width: fit-content;
  padding: 24px 60px;
  border-radius: 9999px;
  background-color: var(--color-white);
  font-size: 26px;
  font-family: var(--font-gothic);
  color: var(--color-primary);
}

.select-balloon-white::before {
  content: "";
  position: absolute;
  bottom: -7px;
  left: 50%;
  transform: translateX(-50%);
  height: calc(16px / 2);
  width: 16px;
  background-color: var(--color-white);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.select-image {
  max-height: 320px;
  object-fit: contain;
}

.select-description {
  font-size: 22px;
  color: var(--color-primary);
  margin-bottom: 16px;
}

.select-item_label {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 54px;
  font-size: 18px;
  color: var(--color-base_dark);
  font-weight: var(--fw-medium);
  margin-bottom: 16px;
}

.select-colors {
  display: flex;
  justify-content: center;
  padding: 24px 0;
  width: 100%;
  gap: 12px;
  padding-bottom: 20px;
  border-top: solid 1px rgba(90, 170, 230, 0.15);
  border-bottom: solid 1px rgba(90, 170, 230, 0.15);
}

.color-dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: solid 1px rgba(100, 105, 110, 0.2);
  cursor: pointer;
}

.color-dot.gray { background-color: #aaa; }
.color-dot.black { background-color: #000; }
.color-dot.pink { background-color: #f9caca; }
.color-dot.cream { background-color: #f4e0d8; }

.select-item_sezies {
  width: 100%;
  padding: 16px 0;
  border-bottom: solid 1px rgba(90, 170, 230, 0.15);
  font-size: 12px;
  color: var(--text-def);
  margin-bottom: 24px;
}

.select-price {
  font-size: 16px;
  color: var(--text-def);
}

.select-rental span {
  font-size: 16px;
  font-weight: bold;
}

.select-price-label {
  color: var(--color-base_dark);
}

.select-price-detail {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  color: var(--color-orange);
}

.select-price-detail p {
  font-family: var(--font-gothic);
  font-size: 80px;
  line-height: 1.0;
}

.select-price-detail span {
  font-size: 32px;
}


/* support */
.support-contents {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 24px;
  max-width: 1232px;
  width: 100%;
  padding: 0 16px 80px;
  margin: 0 auto;
}

.support-title {
  text-align: center;
  font-size: var(--title-size);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  padding: 120px 0 80px;
  margin: 0 auto;
}

.support-block {
  padding: 48px 32px 40px;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  background-color: var(--color-white);
}

.support-heading {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  text-align: center;
  white-space: nowrap;
  font-size: 20px;
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  margin-bottom: 26px;
}

.support-sub-heading {
  text-align: center;
  margin-bottom: 16px;
}

.support-img {
  margin-bottom: 16px;
}

.support-img img {
  display: block;
  width: 100%;
}

.support-description {
  min-height: 106px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(90, 170, 230, 0.15);
  letter-spacing: 0.02em;
  font-size: 12px;
  margin-bottom: 16px;
}

.support-price {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 130px;
  text-align: center;
}

.support-price-detail {
  font-size: 14px;
  margin-bottom: 10px;
}

.support-price-block {
  padding: 8px 0 6px;
  margin-bottom: 16px;
}

.support-price-block + .support-price-block {
  padding: 0;
  margin-bottom: 0;
}

.support-price-monthly {
  font-size: 13px;
  line-height: 0.85;
  color: var(--color-orange);
}

.support-price-strong {
  line-height: 0.85;
  font-size: 24px;
  font-family: var(--font-gothic);
  margin: 0 4px;
}

/* listen */
.listen-container {
  max-width: 1232px;
  width: 100%;
  padding: 120px 16px;
  margin: 0 auto;
}

.listen-contents {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(367px, 1fr));
  gap: 24px;
}

.listen-title {
  text-align: center;
  font-size: var(--title-size);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  margin-bottom: 40px;
}

.listen-sub-title {
  text-align: center;
  line-height: 1.8;
  font-weight: var(--fw-normal);
  margin-bottom: 80px;
}

.listen-img img {
  display: block;
  border-radius: 8px 8px 0 0;
  width: 100%;
}

.listen-description {
  padding: 36px 32px;
  border-radius: 0 0 8px 8px;
  background-color: var(--color-primary);
}

.balloon-white.listen {
  max-width: 320px;
  width: 100%;
  padding: 10px 24px;
  font-size: 20px;
  text-align: center;
  white-space: nowrap;
  margin: 0 auto 31px;
}

.listen-comment {
  line-height: 1.8;
  font-size: 14px;
  color: var(--color-white);
  margin-bottom: 16px;
}

.listen-user {
  line-height: 1.8;
  text-align: center;
  font-size: 14px;
  color: var(--color-white);
}

.listen-note {
  text-align: center;
  margin: 24px auto 0;
}

/* step */

.step-container {
  background-color: var(--color-white);
}

.step-wrap {
  max-width: 992px;
  margin: 0 auto;
  padding: 120px 16px;
}

.step-title {
  text-align: center;
  font-size: var(--title-size);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  margin-bottom: 64px;
}

.step-contents {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.step-block {
  display: flex;
  align-items: center;
  height: 100%;
  border: 1px solid var(--color-border);
  border-radius: 8px;
}

.step-heading {
  display: flex;
  flex-direction: column;
  max-width: 220px;
  width: 100%;
  padding: 22px;
  border-radius: 7px 0 0 7px;
  background-color: var(--color-primary_lighter);
  line-height: 1;
  text-align: center;
  font-size: 14px;
  font-family: var(--font-gothic);
  color: var(--color-primary);
}

.step-description {
  width: 100%;
  padding: 40px;
  color: var(--color-base_dark);
}

.step-number {
  font-size: 46px;
  font-weight: bold;
}

/* Q&A */
.qa-container {
  padding: 120px 0 0;
}

.qa-contents {
  display: flex;
  align-items: center;
  gap: 64px;
  width: 100%;
  max-width: 1232px;
  padding: 0 16px;
  margin: 0 auto 56px;
}

.qa-contents + .qa-contents {
  margin-bottom: 0;
}

.qa-contents:nth-child(even) {
  flex-direction: row-reverse;
}

.qa-title {
  text-align: center;
  font-weight: var(--fw-medium);
  font-size: var(--title-size);
  color: var(--color-primary);
  margin-bottom: 40px;
}

.qa-description {
  line-height: 1.8;
  text-align: center;
  font-weight: var(--fw-normal);
  margin-bottom: 80px;
}

.qa-img {
  flex: 0 0 auto;
  max-width: 568px;
  width: 39.4vw;
}

.qa-img img {
  display: block;
  width: 100%;
  border-radius: 8px;
}

.qa-block {
  display: flex;
  gap: 8px;
}

.qa-heading {
  letter-spacing: 0;
  font-size: var(--heading-size);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  margin-bottom: 24px;
}

.qa-heading-q {
  height: fit-content;
  line-height: 1.3;
  font-size: var(--heading-size);
  font-family: var(--font-mincho);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
}

.qa-question-answer {
  line-height: 1.8;
  font-weight: var(--fw-normal);
}

.accordion-contents {
  max-width: 1232px;
  padding: 0 16px;
  margin: 80px auto 120px;
}

.accordion-items {
  margin-bottom: 16px;
  background-color: #ffffff;
  border-radius: 46px;
  overflow: hidden;
  transition: 0.2s ease;
  outline: none;
}

.accordion-items summary {
  display: flex;
  padding: 24px 76px 24px 24px;
  border-top-left-radius: 46px;
  border-top-right-radius: 46px;
  cursor: pointer;
  position: relative;
}

.toggle-icon {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 40px;
  width: 12px;
  height: 12px;
  pointer-events: none;
}

.bar-horizontal {
  position: absolute;
  background-color: var(--color-primary);
  width: 12px;
  height: 2px;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  transform-origin: center;
}

.bar-vertical {
  position: absolute;
  background-color: var(--color-primary);
  width: 12px;
  height: 2px;
  top: 50%;
  left: 0;
  transform: translateY(-50%) rotate(-90deg);
  transform-origin: center;
  transition: transform 0.3s ease;
} 

.toggle-icon .vertical {
  transform: translateY(-50%) rotate(90deg);
}

.accordion-items.opened .bar-vertical {
  transform: translateY(-50%) rotate(0deg);
}

.accordion-items[open] .question-border {
  border-bottom: solid 1px rgba(90, 170, 230, 0.15);
}

.question-label {
  padding: 2px 0 0 12px;
  line-height: 1;
  font-family: var(--font-gothic);
  color: var(--color-primary);
  font-weight: bold;
  font-size: 20px;
  margin: 0 12px 0 0;
}

.question-text {
  font-family: var(--font-noto);
  font-weight: var(--fw-medium);
  color: var(--color-base);
  line-height: 1.8;
  word-break: break-word;
  white-space: normal;
}

.answer-content {
  display: flex;
  align-items: baseline;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  padding: 0 76px 0 24px;
  transition: max-height 0.4s ease, opacity 0.4s ease, padding 0.4s ease;
}

.accordion-items[open] .answer-content.active {
  opacity: 1;
  padding: 24px 76px 24px 24px;
}

.answer-label {
  font-family: var(--font-gothic);
  color: var(--color-orange);
  font-size: 20px;
  padding: 4px 0 0 12px;
  margin-right: 12px;
}

.answer-text {
  line-height: 1.8;
  word-break: break-word;
  white-space: normal;
}

.answer-text a {
  color: var(--color-primary);
}

.answer-text a:hover {
  opacity: 0.7;
  transition: var(--animation-delay);
}

.answer-mb {
  margin-bottom: 16px;
}

.answer-heading {
  margin-bottom: 8px;
}

.answer-heading::before {
  content: '■';
}

.answer-bold {
  font-size: 16px;
  margin-bottom: 8px;
}

.answer-link {
  color: var(--color-primary);
}

.answer-ul {
  counter-reset: listNum;
}

.answer-count-list {
  counter-reset: listCount;
}

.answer-count-list > li {
  counter-increment: listCount;
  position: relative;
  padding-left: 2.5rem;
}

.answer-count-list > li::before {
  content: counter(listCount) ". ";
  position: absolute;
  left: 1rem;
}

.answer-list-heading {
  color: var(--color-primary);
  margin-bottom: 8px;
}

.answer-ul li .answer-list-heading::before{
  counter-increment: listNum;
	content: counter(listNum) ". ";
}

.answer-ul-disc {
  margin-bottom: 16px;
}

.answer-asterisk {
  position: relative;
  padding-left: 1.5rem;
  text-indent: -1.5rem;
}
.answer-asterisk::before {
  content: "※ ";
}

.answer-list-desc {
  margin-left: 2.5rem;
}

.answer-list-desc > li {
  list-style-type: disc;
}

.answer-border {
  width: 100%;
  height: 1px;
  background-color: var(--color-border);
  margin: 16px 0;
}

.answer-table {
  width: 100%;
  border-spacing: 0;
  border: 1px solid var(--color-table-border);
  margin-bottom: 16px;
}

.answer-th {
  width: 25%;
  padding: 12px;
  background-color: var(--color-primary_lighter);
  text-align: left;
  font-weight: var(--fw-medium);
  font-size: 14px;
}

.answer-td {
  width: 75%;
  padding: 12px;
  font-size: 14px;
  color: var(--color-base_dark);
}

/* footer */
.footer-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 104px;
  padding: 24px 48px;
  background-color: var(--color-white);
  font-size: 12px;
}

.footer-logo img {
  width: 164px;
  height: auto;
}

.footer-ul {
  display: flex;
  align-items: center;
  gap: 24px;
}

.footer-list {
  letter-spacing: 0.04rem;
}

.footer-list a {
  color: var(--color-base);
}

.footer-list a:hover {
  opacity: 0.7;
  transition: var(--animation-delay);
}

.is-sp {
  display: none;
}

@media screen and (max-width:768px) {
  :root {
    --title-size: 30px;
    --heading-size: 26px;
  }

  .is-pc {
    display: none;
  }

  .contact-btn {
    padding: 12px 24px;
  }

  .contact-btn.middle {
    width: 100%;
    padding: 24px 89px;
  }

  .contact-btn.large {
    padding: 48px 35px;
  }

  .contact-btn-strong {
    font-size: 22px;
  }

  .card.kv {
    width: 100%;
  }

  .balloon.large {
    width: 100%;
    padding: 10px 21px;
    text-align: center;
  }

  .footer-container {
    height: auto;
    flex-direction: column;
    gap: 16px;
  }

  .footer-ul {
    flex-direction: column;
    gap: 8px;
  }

  /* header */
  .header-container {
    padding: 8px 16px;
  }

  .header-logo img {
    height: 40px;
  }

  /* kv */
  .kv-container {
    position: relative;
    min-height: 500px;
    padding: 16px;
    background-image: url('./images/kv_sp.jpg');
    background-size: cover;
    background-position: center;
    overflow: visible;
  }

  .kv-column {
    height: auto;
  }

  .kv-title {
    font-size: 26px;
  }

  .kv-balloon {
    position: absolute;
    bottom: -84px;
    width: calc(100% - 32px);
  }

  .campaign-container {
    padding: 152px 16px 80px;
  }

  .campaign-container.footer {
    padding: 48px 16px;
  }

  .campaign-sub-title {
    padding: 4px 16px;
    font-size: 17px;
  }

  .campaign-title {
    margin: 32px 0;
  }

  .campaign-word {
    font-size: 18px;
  }

  .campaign-word-strong {
    font-size: 26px;
  }

  /* point */
  .point-container {
    margin: 48px auto 0;
  }

  .point-contents {
    flex-direction: column;
    gap: 48px;
    padding: 0;
  }

  .point-contents:nth-child(even) {
    flex-direction: column;
    padding: 0;
  }

  .point-img {
    width: 100%;
    padding: 0 40px 0 0;
  }

  .point-contents:nth-child(even) .point-img {
    padding: 0 0 0 40px;
  }

  .point-block {
    padding: 0 16px;
  }

  .point-description {
    font-size: 14px;
    margin-top: 24px;
  }

  .point-list-underline {
    display: inline;
  }

  /* compare */
  .compare-container {
    padding: 0 16px;
    margin: 136px auto 0;
  }

  .compare-contents {
    padding: 0 16px;
  }

  .compare-title {
    padding: 24px 40px;
    line-height: 1.3;
    font-size: 28px;
    margin: -78px auto 0;
  }

  .compare-ul {
    gap: 12px;
    padding: 0 16px;
    margin: 38px auto 0;
  }

  .compare-list {
    align-items: baseline;
    gap: 8px;
    line-height: 1.5;
    font-size: 17px;
  }

  .compare-list img {
    position: relative;
    top: 5px;
    width: 22px;
    height: 22px;
    line-height: 1.8;
  }

  .compare-img-block {
    padding: 0;
    gap: 40px;
    margin: 40px auto 16px;
  }

  .card.compare .card-header {
    padding: 16px 46px;
  }

  .card.compare .card-header .card-header-text {
    font-size: 20px;
  }

  .card-header-compare-strong {
    font-size: 20px;
  }

  .card.compare .card-footer {
    padding-bottom: 24px;
  }

  .card.compare .card-footer-img {
    padding: 12px 16px 32px;
  }

  .card.compare .card-footer .asterisk {
    padding: 0 16px;
  }

  /* about */
  .about-container {
    padding: 0 0 48px;
  }

  .about-description {
    font-size: 14px;
  }

  .about-balloon {
    padding: 0 16px;
  }

  .balloon-white {
    padding: 24px 50px;
    text-align: center;
    font-size: 22px;
  }

  .pause-container {
    grid-template-columns: 1fr;
    flex-direction: column;
    padding: 0 16px;
  }

  .pause-contents {
    max-width: none;
    padding: 30px 45px 25px;
    border-radius: 8px 8px 0 0;
  }

  .pause-img {
    max-width: none;
  }

  .pause-title {
    text-align: center;
  }

  .pause-sub-title {
    padding: 4px 24px;
    letter-spacing: -0.02rem;
  }

  .pause-img img {
    border-radius: 0 0 8px 8px;
  }

  .active-container {
    padding: 48px 0;
  }

  /* slide */
  .slider-contents {
    margin-top: 40px;
  }

  .slide {
    width: 42.6vw;
    margin-right: 32px;
  }

  .active-top-contents {
    padding: 0 16px;
    background-image: none;
    margin: 64px auto 72px;
  }

  .active-top-block {
    padding: 0;
    background-color: var(--color-primary_lighter);
  }

  .active-title {
    margin-bottom: 40px;
  }

  .active-description {
    font-size: 14px;
    margin: 24px auto 0;
  }

  .active-note {
    margin: 16px auto 24px;
  }

  .active-top-sp img {
    width: 100%;
    border-radius: 8px;
  }

  .active-contents,
  .active-contents:nth-child(even) {
    flex-direction: column-reverse;
    gap: 24px;
    padding: 0 16px;
    margin: 0 auto 64px;
  }

  .active-img {
    width: 100%;
  }

  .active-other-container {
    margin: 107px auto 0;
  }

  .active-other-inner {
    padding: 20px 16px 16px;
  }

  .active-other-title {
    padding: 16px 32px;
    line-height: 1.3;
    text-align: center;
    font-size: 30px;
  }

  .active-other-contents {
    flex-direction: column;
  }

  .active-other-block {
    width: 100%;
  }

  .price-container {
    padding: 48px 0 0;
  }

  .price-title {
    padding: 0 16px;
  }

  .price-description {
    padding: 0 16px;
    line-height: 1.8;
    font-size: 14px;
    margin: 40px auto 24px;
  }

  .price-note {
    margin: 0 0 48px;
  }

  .price-heading {
    text-align: center;
    padding: 32px 20px;
  }

  .price-heading-strong {
    line-height: 1.2;
    font-size: 46px;
  }

  .price-heading-sub-strong {
    font-size: 36px;
  }

  .price-card-block {
    margin: 32px auto 0;
  }

  .price .card-footer {
    min-height: 75px;
    padding: 20px;
  }

  .price-card-row {
    gap: 16px;
  }

  .card-description {
    font-size: 12px;
  }

  .card-header-text {
    font-size: 14px;
  }

  .price-card-strong {
    font-size: 40px;
  }

  .price .card-footer.large .price-card-strong {
    font-size: 70px;
  }

  .price .card-footer.large .card-description {
    font-size: 16px;
  }

  .price .card-footer.large .price-card-strong.small {
    font-size: 15px;
  }

  .price-card-note {
    padding: 0 16px;
  }

  .price-conversion-container {
    margin: 64px auto 0;
  }

  .price-conversion-title {
    padding: 16px 32px;
    text-align: center;
    font-size: 22px;
    margin: 0 auto -64px;
  }

  .price-conversion-container {
    padding-bottom: 48px;
  }

  .price-conversion-block {
    padding: 80px 24px 32px;
    border-radius: 48px;
  }

  /* select */
  .select-container {
    padding: 48px 16px;
  }
  
  .select-title {
    margin-bottom: 48px;
  }

  .select-item {
    padding: 24px 16px;
  }

  .select-image.short {
    max-height: 226px;
  }

  .select-colors {
    padding: 16px 0;
  }

  .select-item_label {
    margin-bottom: 8px;
  }

  .select-item_sezies {
    padding: 8px 0;
    margin-bottom: 16px;
  }

  .select-price-label {
    font-size: 14px;
  }

  .select-description {
    font-size: 18px;
    margin-bottom: 8px;
  }

  .support-title {
    padding: 48px 16px 0;
    margin-bottom: 0;
  }

  .support-contents {
    grid-template-columns: 1fr;
    padding: 48px 16px;
  }

  .support-block {
    padding: 24px 16px;
  }

  .support-heading {
    height: auto;
    margin-bottom: 16px;
  }

  .support-description {
    min-height: auto;
    color: var(--color-base_light);
  }

  .support-price {
    height: auto;
    min-height: 63px;
  }

  .listen-container {
    padding: 72px 16px;
  }

  .listen-contents {
    display: flex;
    flex-direction: column;
  }

  .listen-sub-title {
    font-size: 14px;
    margin-bottom: 48px;
  }
  
  .listen-description {
    padding: 36px 12px;
  }

  .listen-comment {
    padding: 0 30px;
  }

  .listen-note {
    text-align: left;
  }

  .step-wrap {
    padding: 48px 16px;
  }

  .step-title {
    margin-bottom: 48px;
  }

  .step-heading {
    max-width: 107px;
    padding: 29px 32px;
    font-size: 12px;
  }

  .step-number {
    font-size: 34px;
  }

  .step-description {
    padding: 20px 22px;
    font-size: 14px;
  }

  .campaign-footer-title {
    padding: 20px 16px;
    line-height: 1.3;
    font-size: 27px;
    margin: 0 auto 32px;
  }

  .campaign-description {
    font-size: 16px;
    white-space: nowrap;
  }

  /* qa */
  .qa-container {
    padding: 48px 0 0;
  }

  .qa-title {
    padding: 0 16px;
  }

  .qa-description {
    padding: 0 16px;
    font-size: 14px;
    margin-bottom: 48px;
  }

  .qa-contents,
  .qa-contents:nth-child(even) {
    flex-direction: column;
    gap: 16px;
  }

  .qa-heading-q {
    font-size: 28px;
  }

  .toggle-icon {
    right: 32px;
  }

  .qa-img {
    width: 100%;
  }

  .qa-block {
    flex-direction: column;
  }

  .qa-question-answer {
    font-size: 14px;
  }

  .question-text {
    font-size: 14px;
  }

  .accordion-contents {
    margin: 48px auto;
  }

  .answer-text {
    font-size: 14px;
  }

  .accordion-items summary,
  .accordion-items[open] .answer-content.active {
    padding: 24px 68px 24px 16px;
  }

  .answer-content {
    padding: 0 68px 0 16px;
  }

  .answer-list-desc {
    margin-left: 1.5rem;
  }

  .footer-logo {
    height: 56px;
    padding: 5px 0;
  }

  .is-sp {
    display: unset;
  }
}