@charset "UTF-8";
:root {
  --inner-value: 1000;
  --inner: 1000px;
  --inner-value-lg: 1200;
  --inner-lg: 1200px;
  --padding-pc: 25px;
  --padding-sp: 16px;
  --rem: 1rem / 16;
  --em: 1em / 16;
  --base-font: "Noto Sans JP", sans-serif;
  --second-font: "Zen Kaku Gothic Antique", sans-serif;
  --round-font: "Rounded Mplus 1c", sans-serif;
  --display-font: "Geologica", sans-serif;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-black: 900;
  --white: #fff;
  --black: #000;
  --default-color: #40B69B;
  --primary-dark: #163041;
  --pink: #FF7DA1;
  --purple: #B76AAB;
  --teal: #0FA3AF;
  --teal-pale: #B4D2D3;
  --yellow: #FFF33F;
  --gray: #D9D9D9;
  --z-index-header: 100;
  --z-index-cta: 90;
  --z-index-pagetop: 80;
  --scrollbar-width: 0;
}

@property --scrollbar {
  syntax: "<length>";
  initial-value: 0;
  inherits: true;
}
:root:has(:modal[open], .is-scroll-lock) {
  overflow: hidden;
  scrollbar-gutter: stable;
}

html {
  scroll-padding-top: var(--header-height);
}

body {
  font-family: var(--base-font);
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: var(--white);
  background-color: var(--black);
  container-type: inline-size;
  font-feature-settings: "pwid";
}

:where(h1) {
  margin: initial;
}

:where(picture) {
  display: block;
}

:where(img) {
  display: block;
  width: 100%;
}

:where(button) {
  border: none;
  padding: unset;
}

/* リキッドレイアウト対応 */
html {
  font-size: 16px;
}
@media (width <= 375px) {
  html {
    font-size: 4.2666666667cqi;
  }
}
@media screen and (min-width: 768px) {
  html {
    font-size: calc(16 / var(--inner-value) * 100cqi);
  }
}
@media (width >= 1000px) {
  html {
    font-size: 16px;
  }
}

.inner {
  width: 100%;
  max-width: 600px;
  padding-inline: var(--padding-sp);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .inner {
    max-width: calc(var(--inner) + var(--padding-pc) * 2);
    padding-inline: var(--padding-pc);
  }
}

@media screen and (min-width: 768px) {
  .inner[data-size=lg] {
    max-width: calc(var(--inner-lg) + var(--padding-pc) * 2);
  }
}

.bg-main {
  background-image: url("../images/bg_main-sp.webp");
  background-repeat: no-repeat;
  background-position: center 6.25rem;
  background-size: 100% 100%;
}
@media screen and (min-width: 768px) {
  .bg-main {
    background-image: url("../images/bg_main.webp");
    background-repeat: repeat-y;
    background-position: center top;
    background-size: 100%;
  }
}

.button {
  --_color: var(--black);
  --_bg-color: #F8AD58;
  --_duration: 0.3s;
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 0.5em;
  padding-block: 23px 24px;
  padding-inline: 32px 24px;
  background-color: var(--_bg-color);
  border-radius: 0.5rem;
  font-size: 16px;
  font-weight: var(--fw-bold);
  line-height: 1.1875;
  letter-spacing: 0.03em;
  color: var(--_color);
  transition: translate ease var(--_duration), box-shadow ease var(--_duration);
}

.button[data-color=coral] {
  --_bg-color: #FF7077;
}

.button[data-color=pink] {
  --_bg-color: var(--pink);
  padding-block: 15px 16px;
  padding-inline: 32px 24px;
}

.button::after {
  content: "";
  width: 1.125em;
  aspect-ratio: 1;
  background-color: currentcolor;
  mask-image: url("../images/icon_chevron.svg");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

@media (any-hover: hover) {
  .button:hover {
    translate: 0 -5px;
    box-shadow: 0 0 10px var(--_bg-color);
  }
}
.cta {
  position: relative;
  overflow: clip;
  padding-block: 3.5rem;
}
@media screen and (min-width: 768px) {
  .cta {
    padding-block: 5rem;
  }
}

.cta::before {
  content: "";
  position: absolute;
  top: -2.1875rem;
  left: 50%;
  translate: -50%;
  width: min(92.8vw, 532px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(50% 50% at 50% 50%, rgba(45, 78, 101, 0.8) 0%, rgba(45, 78, 101, 0) 100%);
}
@media screen and (min-width: 768px) {
  .cta::before {
    top: -5rem;
  }
}

.cta__inner.inner {
  position: relative;
}

.cta__buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .cta__buttons {
    margin-top: 3rem;
  }
}

.cta__button {
  width: min(100%, 343px);
}

.extras {
  position: relative;
  padding-block: 3.5rem;
  background-image: url("../images/bg_extras.webp");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
@media screen and (min-width: 768px) {
  .extras {
    padding-block: 5rem;
  }
}

@media screen and (min-width: 768px) {
  .extras::before {
    content: "";
    position: absolute;
    top: -5rem;
    left: 50%;
    translate: -50%;
    width: min(92.8vw, 532px);
    aspect-ratio: 1;
    border-radius: 50%;
    background: radial-gradient(50% 50% at 50% 50%, rgba(45, 78, 101, 0.8) 0%, rgba(45, 78, 101, 0) 100%);
  }
}

.extras__inner.inner {
  position: relative;
}

.extras__title {
  margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .extras__title {
    margin-bottom: 3rem;
  }
}

.extras__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem 0.8125rem;
}
@media screen and (min-width: 768px) {
  .extras__list {
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
  }
}

.extras__item {
  display: grid;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .extras__item {
    gap: 0.75rem;
  }
}

.extras__item-img img {
  aspect-ratio: 165/116;
  object-fit: contain;
}

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

.extras__item-label {
  font-size: 16px;
  font-weight: var(--fw-bold);
  line-height: 1.4375;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .extras__item-label {
    font-size: 18px;
  }
}

.extras__banner {
  --_duration: 0.3s;
  position: relative;
  display: block;
  margin-top: 2rem;
  margin-inline: auto;
  width: min(100%, 380px);
  transition: translate ease var(--_duration), filter ease var(--_duration);
}
@media screen and (min-width: 768px) {
  .extras__banner {
    margin-top: 3rem;
  }
}

.extras__banner::after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 50%;
  right: 1rem;
  translate: 0 -50%;
  width: 18px;
  aspect-ratio: 1;
  background-color: #50A2A6;
  mask-image: url("../images/icon_chevron.svg");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  transition: translate ease var(--_duration);
}

@media (any-hover: hover) {
  .extras__banner:hover {
    translate: 0 -5px;
    filter: contrast(1.1);
  }
  .extras__banner:hover::after {
    translate: 5px -50%;
  }
}
.feature {
  position: relative;
  padding-block: 3.375rem 3.5rem;
}
@media screen and (min-width: 768px) {
  .feature {
    padding-block: 0 80px;
  }
}

.feature::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50%;
  width: min(92.8vw, 532px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(50% 50% at 50% 50%, rgba(45, 78, 101, 0.8) 0%, rgba(45, 78, 101, 0) 100%);
}

.feature__inner.inner {
  position: relative;
}

.feature__sub-title {
  margin-top: 32px;
  margin-inline: auto;
  width: min(100%, 500px);
}
@media screen and (min-width: 768px) {
  .feature__sub-title {
    margin-top: 48px;
  }
}

.feature__sub-title img {
  aspect-ratio: 345/97;
  object-fit: contain;
}

.feature__container {
  display: grid;
  place-items: center;
  gap: 2rem;
  margin-top: 3rem;
}

.feature__section {
  --_color: var(--white);
  --_gap: 24px;
  display: grid;
  width: min(93.2944606414%, 510px);
  background-color: color-mix(in srgb, var(--_section-color, var(--default-color)) 80%, transparent);
  border-radius: 1rem;
  padding: 1rem 1rem 1.5rem;
}
@media screen and (min-width: 768px) {
  .feature__section {
    --_gap: 32px;
    width: 90%;
    padding: 2rem 2.5rem;
  }
}

.feature__section[data-color=green] {
  --_section-color: #40B69B;
  justify-self: start;
}

.feature__section[data-color=blue] {
  --_section-color: #5180E3;
}

.feature__section[data-color=purple] {
  --_section-color: #C14DA1;
  justify-self: end;
}

.feature__title {
  display: grid;
  gap: 6px;
  font-family: var(--second-font);
  color: var(--_color);
}

.feature__title-sub {
  font-size: 16px;
  font-weight: var(--fw-black);
  line-height: 1.4375;
  opacity: 0.65;
}

.feature__title-main {
  font-size: 32px;
  font-weight: var(--fw-black);
  text-box: trim-both cap alphabetic;
}

.feature__lead {
  margin-top: var(--_gap);
  font-family: var(--second-font);
  font-size: 21px;
  font-weight: var(--fw-black);
  line-height: 1.4285714286;
  color: var(--_color);
}

.feature__samples {
  display: grid;
  gap: var(--_gap);
  margin-top: var(--_gap);
  width: 100%;
}
@media screen and (min-width: 768px) {
  .feature__samples {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
}

.feature__section[data-color=blue] .feature__samples {
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
@media screen and (min-width: 768px) {
  .feature__section[data-color=blue] .feature__samples {
    gap: 24px;
  }
}

.feature__section[data-color=blue] .feature__samples[data-type=digital] {
  gap: 12px;
}
@media screen and (min-width: 768px) {
  .feature__section[data-color=blue] .feature__samples[data-type=digital] {
    gap: 24px;
  }
}

.feature__section[data-color=purple] .feature__samples {
  gap: 16px;
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .feature__section[data-color=purple] .feature__samples {
    gap: 24px;
    margin-top: 24px;
  }
}

.feature__sample img {
  object-fit: contain;
}

.feature__zoom-trigger {
  display: block;
  width: 100%;
  cursor: zoom-in;
  background: transparent;
}

.feature__sample-caption {
  margin-top: 8px;
  font-size: 16px;
  font-family: var(--second-font);
  font-weight: var(--fw-bold);
  line-height: 1.4375;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .feature__sample-caption {
    font-size: 18px;
  }
}

.feature__check-list {
  display: grid;
  gap: 8px;
  justify-self: start;
  margin-top: var(--_gap);
}

.feature__check-item {
  position: relative;
  padding-left: 1.75em;
  color: var(--_color);
}

.feature__check-item::before {
  content: "";
  position: absolute;
  top: 0.5lh;
  left: 0;
  translate: 0 -50%;
  width: 1.125em;
  aspect-ratio: 1;
  background-color: var(--white);
  mask-image: url("../images/icon_check.svg");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

.feature__check-marker {
  --_bg-start: 2px;
  position: relative;
  font-weight: var(--fw-bold);
  color: var(--_section-color);
  background-image: linear-gradient(to bottom, transparent var(--_bg-start), var(--white) var(--_bg-start));
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

.feature__content {
  display: grid;
  justify-items: center;
  margin-top: var(--_gap);
  padding: 1rem 0.5rem;
  border-radius: 8px;
  background-color: color-mix(in srgb, var(--white) 15%, transparent);
}
@media screen and (min-width: 768px) {
  .feature__content {
    padding: 2rem;
  }
}

.feature__label {
  padding-inline: 8px;
  width: fit-content;
  border-radius: 8px;
  background-color: color-mix(in srgb, var(--white) 40%, transparent);
  font-size: 18px;
  font-family: var(--second-font);
  font-weight: var(--fw-black);
  line-height: 1.4444444444;
}
@media screen and (min-width: 768px) {
  .feature__label {
    padding-inline: 10px;
    font-size: 20px;
    line-height: 1.6;
  }
}

.feature__note {
  margin-top: 16px;
  font-size: 12px;
  font-weight: var(--fw-medium);
  line-height: 1.25;
}
@media screen and (min-width: 768px) {
  .feature__note {
    font-size: 14px;
  }
}

.feature__video {
  margin-top: 16px;
  width: 100%;
  background-color: white;
}

.feature__video :where(iframe, video) {
  aspect-ratio: 272/153;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.footer {
  padding-block: 0.875rem 1.375rem;
  padding-inline: 1rem;
  background-color: var(--white);
  text-align: center;
}

.footer__copyright {
  font-size: 1.125rem;
  font-weight: var(--fw-medium);
  line-height: 1.2777777778;
  color: #333;
}

.fv {
  position: relative;
}
@media screen and (min-width: 768px) {
  .fv {
    padding-bottom: 5.25rem;
  }
}

.fv::before {
  content: "";
  position: absolute;
  inset: 0;
  height: 84.4674556213%;
  background-image: url("../images/bg_fv-sp.webp");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}
@media screen and (min-width: 768px) {
  .fv::before {
    height: 270.5882352941%;
    background-image: url("../images/bg_fv.webp");
  }
}

.fv__inner.inner {
  position: relative;
}

.fv__container {
  display: grid;
  grid-template-areas: "title" "images" "lead";
  padding-block: 2.9375rem 2rem;
}
@media screen and (min-width: 768px) {
  .fv__container {
    --_title-area: calc(620 / 1200 * 100%);
    --_images-area: 1fr;
    grid-template-columns: var(--_title-area) var(--_images-area);
    grid-template-areas: "title images" "lead images";
    gap: 4%;
    padding-block: 5rem;
  }
}

.fv__title {
  grid-area: title;
}
@media screen and (min-width: 768px) {
  .fv__title {
    padding-inline: 0.625rem;
  }
}

.fv__title img {
  aspect-ratio: 345/127;
  object-fit: contain;
}

.fv__lead {
  --_container: 375;
  --_accent-color: var(--yellow);
  grid-area: lead;
  margin-top: 24px;
  margin-inline: calc(50% - 50cqi);
  font-family: var(--second-font);
  font-weight: var(--fw-black);
  color: var(--white);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .fv__lead {
    margin-inline: initial;
  }
}

.fv__lead-first {
  font-size: min(18 / var(--_container) * 100cqi, 24px);
  line-height: 1.4444444444;
  letter-spacing: 0.03em;
}

.fv__lead-accent1 {
  font-size: min(21 / var(--_container) * 100cqi, 32px);
  font-weight: var(--fw-black);
  line-height: 1.2380952381;
  color: var(--_accent-color);
  letter-spacing: 0.03em;
}

.fv__lead-first sup {
  font-size: 0.6666666667em;
}

.fv__lead-last {
  margin-top: -3px;
  padding-left: min(0.5555555556em, 10px);
  font-size: min(18 / var(--_container) * 100cqi, 24px);
  font-weight: var(--fw-black);
  line-height: 1.2;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .fv__lead-last {
    margin-top: 0.5rem;
    padding-left: initial;
  }
}

.fv__lead-accent2 {
  font-size: min(28 / var(--_container) * 100cqi, 40px);
  font-weight: var(--fw-black);
  letter-spacing: 0.03em;
  color: var(--_accent-color);
}

.fv__lead-unit {
  font-size: min(20 / var(--_container) * 100cqi, 32px);
  letter-spacing: 0.03em;
}

.fv__lead-unit:first-of-type {
  margin-inline: -0.15em;
}

.fv__lead-unit:last-of-type {
  margin-left: -2px;
}

.fv__images {
  --_large-img: calc(161 / 338 * 100%);
  grid-area: images;
  display: grid;
  grid-template-columns: var(--_large-img) minmax(0, 1fr);
  align-items: center;
  gap: 2.915451895%;
  margin-top: 15px;
  padding-inline: 2px;
}
@media screen and (min-width: 768px) {
  .fv__images {
    gap: 1rem;
    margin-top: initial;
  }
}

.fv__large-img img {
  aspect-ratio: 161/228;
  object-fit: contain;
}

.fv__images-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 9px 15px;
}
@media screen and (min-width: 768px) {
  .fv__images-wrap {
    gap: 14px 1.5rem;
  }
}

.fv__img img {
  aspect-ratio: 76/108;
  object-fit: contain;
}

.fv__nav {
  margin-inline: calc(50% - 50cqi);
}
@media screen and (min-width: 768px) {
  .fv__nav {
    margin-inline: initial;
  }
}

.fv__nav-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2px;
  min-height: 4.5rem;
}
@media screen and (min-width: 768px) {
  .fv__nav-list {
    grid-template-columns: repeat(4, 1fr);
    min-height: 5rem;
  }
}

.fv__nav-item {
  --_container: 186.5;
  min-height: inherit;
}

.fv__nav-item[data-color=pink] {
  --_bg-color: #E85B82;
}

.fv__nav-item[data-color=purple] {
  --_bg-color: var(--purple);
}

.fv__nav-item[data-color=blue] {
  --_bg-color: #588EC7;
}

.fv__nav-item[data-color=teal] {
  --_bg-color: var(--teal);
}

.fv__nav-link {
  --_bg-opacity: 90%;
  display: grid;
  place-items: center;
  place-content: center;
  gap: 4px;
  height: 100%;
  padding-block: 1.5rem 0.25rem;
  background-color: color-mix(in srgb, var(--_bg-color, var(--black)) var(--_bg-opacity), transparent);
  font-family: var(--second-font);
  font-size: min(16 / var(--_container) * 100cqi, 18px);
  font-weight: var(--fw-black);
  line-height: 1.2;
  letter-spacing: 0.01em;
  color: var(--white);
  text-align: center;
  transition: background-color ease 0.3s;
}

.fv__nav-item:first-child .fv__nav-link {
  gap: initial;
  padding-block: 0.5rem 0;
}

.fv__nav-link::after {
  content: "";
  width: 0.7777777778em;
  aspect-ratio: 1;
  rotate: 90deg;
  background-color: currentcolor;
  mask-image: url("../images/icon_chevron.svg");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

.fv__nav-text {
  display: block;
  padding-inline: 0.5em;
}

@media (any-hover: hover) {
  .fv__nav-link:hover {
    --_bg-opacity: 70%;
  }
}
.intro {
  position: relative;
  padding-block: 5rem 3.75rem;
  background-image: url("../images/bg_intro-sp.webp");
  background-repeat: no-repeat;
  background-position: center -8px;
  background-size: 100% 100%;
}
@media screen and (min-width: 768px) {
  .intro {
    padding-block: 120px 160px;
    background-image: url("../images/bg_intro.webp");
    background-position: center center;
  }
}

.intro__inner.inner {
  display: grid;
  justify-items: center;
  gap: 2rem;
}
@media screen and (min-width: 768px) {
  .intro__inner.inner {
    gap: 3rem;
  }
}

.intro__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
@media screen and (min-width: 768px) {
  .intro__list {
    gap: 24px;
  }
}

.intro__item {
  width: 31.195335277%;
}
@media screen and (min-width: 768px) {
  .intro__item {
    width: 17.5rem;
  }
}

.intro__button {
  width: min(100%, 260px);
}

.intro__text {
  font-size: 14px;
  font-weight: var(--fw-medium);
  line-height: 1.2857142857;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .intro__text {
    font-size: 16px;
  }
}

.intro__note {
  font-size: 12px;
  font-weight: var(--fw-medium);
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .intro__note {
    font-size: 14px;
  }
}

.modal {
  --duration: 0.3s;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: auto;
  padding: 10px 16px;
  inline-size: 100%;
  block-size: 100%;
  background: transparent;
  overflow: visible;
  opacity: 0;
  scale: 0.95;
  transition: opacity var(--duration), scale var(--duration);
}
@media screen and (min-width: 768px) {
  .modal {
    padding: 24px;
  }
}

.modal[data-active=true] {
  opacity: 1;
  scale: 1;
}

.modal::backdrop {
  background-color: rgba(0, 0, 0, 0.75);
  transition: opacity var(--duration);
}

.modal:not([data-active=true])::backdrop {
  opacity: 0;
}

.modal__body {
  width: min(100%, 1200px);
  height: 100%;
  display: grid;
  grid-template-rows: 48px 1fr 48px;
  align-content: center;
}
@media screen and (min-width: 768px) {
  .modal__body {
    grid-template-rows: 50px 1fr 50px;
  }
}

.modal__close {
  position: relative;
  margin-left: auto;
  inline-size: 40px;
  block-size: 40px;
  display: grid;
  place-items: center;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
  cursor: pointer;
  transition: background-color 0.2s;
}
@media screen and (min-width: 768px) {
  .modal__close {
    inline-size: 48px;
    block-size: 48px;
  }
}

.modal__close::before,
.modal__close::after {
  content: "";
  position: absolute;
  width: 20px;
  height: 2px;
  background-color: var(--white);
}
@media screen and (min-width: 768px) {
  .modal__close::before,
  .modal__close::after {
    width: 24px;
  }
}

.modal__close::before {
  rotate: 45deg;
}

.modal__close::after {
  rotate: -45deg;
}

@media (any-hover: hover) {
  .modal__close:hover {
    background: rgba(0, 0, 0, 0.7);
  }
}
.modal__image-wrap {
  min-width: 0;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal__image {
  display: block;
  width: auto;
  height: 100%;
  object-fit: contain;
}

.pagetop {
  --_right: 15px;
  --_bottom: 40px;
  position: fixed;
  bottom: var(--_bottom);
  right: var(--_right);
  z-index: var(--z-index-pagetop);
  width: 3.6875rem;
  opacity: 0;
  visibility: hidden;
  transition: transform 0.3s ease-out, opacity 0.2s ease-out, visibility 0.2s ease-out;
}
@media screen and (min-width: 768px) {
  .pagetop {
    --_right: calc(68 / 16 * 1em);
    --_bottom: calc(24 / 16 * 1em);
    width: 4.375rem;
  }
}

.pagetop.is-visible {
  opacity: 1;
  visibility: visible;
}

.pagetop img {
  aspect-ratio: 1;
  object-fit: contain;
}

@media (any-hover: hover) {
  .pagetop:hover {
    transform: translateY(-5px);
  }
}
.section-title {
  display: grid;
  place-items: center;
  gap: 8px;
  font-size: 24px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .section-title {
    gap: 12px;
    font-size: max(24px, 2rem);
  }
}

.section-title::after {
  content: "";
  width: 3.375rem;
  height: 5px;
  background-color: var(--_line-color, var(--black));
}

.section-title[data-color=pink] {
  --_line-color: var(--pink);
}

.section-title[data-color=purple] {
  --_line-color: var(--purple);
}

.section-title[data-color=blue] {
  --_line-color: #6998CA;
}

.section-title[data-color=teal] {
  --_line-color: var(--teal);
}

.section-title__text {
  font-size: min(6.4cqi, 32px);
  font-family: var(--second-font);
  font-weight: var(--fw-black);
  line-height: 1.2;
  letter-spacing: 0.05em;
}

.js-fade-in {
  opacity: 0;
  transform: translateY(30px);
}

.container {
  container-type: inline-size;
}

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

.mark-sup {
  font-size: 0.6666666667em;
}

.pc-only {
  display: none;
}
@media screen and (min-width: 768px) {
  .pc-only {
    display: block;
  }
}

.safari {
  --size: 400px;
}

.safari__dummy {
  position: fixed;
  z-index: -1;
  transform: translate3d(0, 0, -1px);
}

.safari::before,
.safari::after {
  position: fixed;
  left: 0;
  z-index: 9999;
  width: 100%;
  height: var(--size);
  content: "";
  background-color: var(--gray5);
  transform: translate3d(0, 0, 9999px);
}

.safari::before {
  top: calc(var(--size) * -1);
}

.safari::after {
  bottom: calc(var(--size) * -1);
}

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

.text {
  font-size: 16px;
  font-weight: var(--fw-medium);
  line-height: 1.4375;
}

.visually-hidden {
  position: absolute;
  inset: 0;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}