@charset "UTF-8";
html {
  font-size: 100%;
}
@media (max-width: 375px) {
  html {
    font-size: 4.2666666667vw;
  }
}
@media screen and (min-width: 768px) {
  html {
    font-size: 1.1111111111vw;
  }
}
@media (min-width: 1440px) {
  html {
    font-size: 100%;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #222222;
}

/*****************************
* A Modern CSS Reset (https://github.com/hankchizljaw/modern-css-reset)
* 上記に、ul要素,ol要素,a要素への記述追加
*****************************/
/* Box sizing rules */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd,
ul,
li {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul,
ol {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

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

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

button {
  border: none;
  padding: 0;
  background-color: initial;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
            transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: initial;
}

ul, ol {
  list-style: none;
}

a {
  color: inherit;
  text-decoration: none;
  word-break: break-all;
}

button {
  color: inherit;
  padding-block: 0;
  padding-inline: 0;
  text-align: justify;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
}

/* telリンクの下線＆青色を消す（共通） */
a[href^="tel:"] {
  color: inherit;
  text-decoration: none;
  /* アクセシビリティ：フォーカス可視 */
}
a[href^="tel:"]:hover, a[href^="tel:"]:active, a[href^="tel:"]:focus {
  text-decoration: none;
}
a[href^="tel:"]:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

/* 念のためのiOS系強制上書き（必要な場合のみ） */
@supports (-webkit-touch-callout: none) {
  a[href^="tel:"] {
    color: inherit !important;
    text-decoration: none !important;
  }
}
/* まず、必要な要素には明確なフォーカスリングを付ける */
:where(a, button, input, select, textarea, summary, [role=button], [role=link]):focus-visible {
  outline: 3px solid #23a5ff;
  outline-offset: 2px;
}

/* スクロール用に一時的に tabindex="-1" を付けた見出し/セクションはリングを消す */
:where(h1, h2, h3, h4, h5, h6, section, article, main, div)[id][tabindex="-1"]:focus-visible {
  outline: none;
}

/* 1) グローバル基盤 */
html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* 横スクロールを原則禁止（最新ブラウザ） */
  overflow-x: clip;
  /* Windows等でスクロールバー分の幅を確保してレイアウトのズレを防止 */
}

*, *::before, *::after {
  -webkit-box-sizing: inherit;
          box-sizing: inherit;
}

/* 2) メディア要素のはみ出し防止 */
img, svg, video, canvas, iframe, table, picture {
  display: block;
  max-width: 100%;
  width: auto;
  height: auto;
}

/* 3) 長い文字列の折返し徹底 */
:where(p, li, dd, td, th, figcaption, .c-text, .richtext) {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* 4) Flex/Grid 子要素のはみ出し防止 */
:where(.l-flex, .l-grid, [class*=__row], [class*=__list]) > * {
  min-width: 0;
}

/* 5) スライダー系の横溢れを抑止（必要に応じて） */
:where(.swiper, .swiper-wrapper, .slick-track, .slick-list) {
  overflow-x: clip;
}

/* 8) “安全な vw” 変数 (スクロールバー分を自動相殺) */
:root {
  /* 100vw - (100vw - 100%) = 実コンテンツ幅 */
  --safe-vw: calc(100vw - (100vw - 100%));
}

/* 10) 互換フォールバック（古いSafari等） */
@supports not (overflow-x: clip) {
  html {
    overflow-x: hidden;
  }
}
a[href^="tel:"] {
  pointer-events: none;
  text-decoration: none;
}
@media (hover: none) and (pointer: coarse) {
  a[href^="tel:"] {
    pointer-events: auto;
    color: inherit;
    text-decoration: underline;
  }
}

/* ------------------------------
    スクロールアニメーション
------------------------------ */
*[data-scroll], *[data-load] {
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  opacity: 0;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
  --gap: 100ms;
}
@media screen and (min-width: 768px) {
  *[data-scroll], *[data-load] {
    --gap: 100ms;
  }
}
*[data-scroll][data-scroll-delay="1"], *[data-load][data-scroll-delay="1"] {
  -webkit-transition-delay: calc(var(--gap) * 1);
          transition-delay: calc(var(--gap) * 1);
}
*[data-scroll][data-scroll-delay="2"], *[data-load][data-scroll-delay="2"] {
  -webkit-transition-delay: calc(var(--gap) * 2);
          transition-delay: calc(var(--gap) * 2);
}
*[data-scroll][data-scroll-delay="3"], *[data-load][data-scroll-delay="3"] {
  -webkit-transition-delay: calc(var(--gap) * 3);
          transition-delay: calc(var(--gap) * 3);
}
*[data-scroll][data-scroll-delay="4"], *[data-load][data-scroll-delay="4"] {
  -webkit-transition-delay: calc(var(--gap) * 4);
          transition-delay: calc(var(--gap) * 4);
}
*[data-scroll][data-scroll-delay="5"], *[data-load][data-scroll-delay="5"] {
  -webkit-transition-delay: calc(var(--gap) * 5);
          transition-delay: calc(var(--gap) * 5);
}
*[data-scroll][data-scroll-delay="6"], *[data-load][data-scroll-delay="6"] {
  -webkit-transition-delay: calc(var(--gap) * 6);
          transition-delay: calc(var(--gap) * 6);
}
*[data-scroll][data-scroll-delay="7"], *[data-load][data-scroll-delay="7"] {
  -webkit-transition-delay: calc(var(--gap) * 7);
          transition-delay: calc(var(--gap) * 7);
}
*[data-scroll][data-scroll-delay="8"], *[data-load][data-scroll-delay="8"] {
  -webkit-transition-delay: calc(var(--gap) * 8);
          transition-delay: calc(var(--gap) * 8);
}
*[data-scroll][data-scroll-delay="9"], *[data-load][data-scroll-delay="9"] {
  -webkit-transition-delay: calc(var(--gap) * 9);
          transition-delay: calc(var(--gap) * 9);
}
*[data-scroll][data-scroll-delay="10"], *[data-load][data-scroll-delay="10"] {
  -webkit-transition-delay: calc(var(--gap) * 10);
          transition-delay: calc(var(--gap) * 10);
}

*[data-scroll].scroll-show, *[data-load].scroll-show {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

*[data-scroll=fadein-top], *[data-load=fadein-top] {
  -webkit-transform: translateY(-30px);
          transform: translateY(-30px);
}

*[data-scroll=title01], *[data-load=title01] {
  -webkit-transform: translateX(30px);
          transform: translateX(30px);
}

.l-inner {
  width: 100%;
  max-width: 23.4375rem;
  padding-right: 1.25rem;
  padding-left: 1.25rem;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .l-inner {
    max-width: 65.625rem;
    padding-right: 1.5625rem;
    padding-left: 1.5625rem;
  }
}

.l-main {
  background: #F7FCFF;
  margin-top: -1px;
}
.c-btn01 {
  display: grid;
  place-content: center;
  border-radius: 0.625rem;
  width: 17.5rem;
  height: 3.375rem;
  background: #ffffff;
  border: #2EA4D9 solid 0.125rem;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media screen and (min-width: 768px) {
  .c-btn01 {
    width: 11.875rem;
  }
}
@media (hover: hover) {
  .c-btn01:where(:-moz-any-link, :enabled, summary):hover {
    background: #2EA4D9;
  }
  .c-btn01:where(:any-link, :enabled, summary):hover {
    background: #2EA4D9;
  }
}
.c-btn01--blue {
  background: #2EA4D9;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn01--blue:where(:-moz-any-link, :enabled, summary):hover {
    background: #ffffff;
  }
  .c-btn01--blue:where(:any-link, :enabled, summary):hover {
    background: #ffffff;
  }
}
.c-btn01__label {
  font-size: 1rem;
  font-weight: 800;
  line-height: 1;
  color: #00A1EB;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn01__label:is(:where(:-moz-any-link, :enabled, summary):hover *) {
    color: #ffffff;
  }
  .c-btn01__label:is(:where(:any-link, :enabled, summary):hover *) {
    color: #ffffff;
  }
}
.c-btn01__label--white {
  color: #ffffff;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn01__label--white:is(:where(:-moz-any-link, :enabled, summary):hover *) {
    color: #00A1EB;
  }
  .c-btn01__label--white:is(:where(:any-link, :enabled, summary):hover *) {
    color: #00A1EB;
  }
}

.c-btn02 {
  display: grid;
  place-content: center;
  border-radius: 624.9375rem;
  width: 100%;
  height: 4rem;
  background: #FF9300;
  border: #FF9300 solid 0.125rem;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media screen and (min-width: 768px) {
  .c-btn02 {
    width: 22.625rem;
    height: 4.8125rem;
  }
}
@media (hover: hover) {
  .c-btn02:where(:-moz-any-link, :enabled, summary):hover {
    background: #ffffff;
  }
  .c-btn02:where(:any-link, :enabled, summary):hover {
    background: #ffffff;
  }
}
.c-btn02--white {
  background: #ffffff;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02--white:where(:-moz-any-link, :enabled, summary):hover {
    background: #FF9300;
  }
  .c-btn02--white:where(:any-link, :enabled, summary):hover {
    background: #FF9300;
  }
}
.c-btn02--deep {
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02--deep:where(:-moz-any-link, :enabled, summary):hover {
    background: #EB8800;
    border: #EB8800 solid 0.125rem;
  }
  .c-btn02--deep:where(:any-link, :enabled, summary):hover {
    background: #EB8800;
    border: #EB8800 solid 0.125rem;
  }
}
.c-btn02--blue {
  background: #2EA4D9;
  border: #2EA4D9 solid 0.125rem;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02--blue:where(:-moz-any-link, :enabled, summary):hover {
    background: #ffffff;
  }
  .c-btn02--blue:where(:any-link, :enabled, summary):hover {
    background: #ffffff;
  }
}
.c-btn02--blue-rev {
  border: #2EA4D9 solid 0.125rem;
  background: #ffffff;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02--blue-rev:where(:-moz-any-link, :enabled, summary):hover {
    background: #2EA4D9;
  }
  .c-btn02--blue-rev:where(:any-link, :enabled, summary):hover {
    background: #2EA4D9;
  }
}
@media screen and (min-width: 768px) {
  .c-btn02--fixed {
    -webkit-box-shadow: 0 0 0.625rem rgba(255, 137, 2, 0.4);
            box-shadow: 0 0 0.625rem rgba(255, 137, 2, 0.4);
    width: 28.125rem;
    height: 4.5rem;
  }
}
@media screen and (min-width: 768px) {
  .c-btn02--d372 {
    width: 23.25rem;
  }
}
.c-btn02__label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  color: #ffffff;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02__label:is(:where(:-moz-any-link, :enabled, summary):hover *) {
    color: #FF9300;
  }
  .c-btn02__label:is(:where(:any-link, :enabled, summary):hover *) {
    color: #FF9300;
  }
}
.c-btn02__label--orange {
  color: #FF9300;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02__label--orange:is(:where(:-moz-any-link, :enabled, summary):hover *) {
    color: #ffffff;
  }
  .c-btn02__label--orange:is(:where(:any-link, :enabled, summary):hover *) {
    color: #ffffff;
  }
}
.c-btn02__label--blue {
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02__label--blue:is(:where(:-moz-any-link, :enabled, summary):hover *) {
    color: #2EA4D9;
  }
  .c-btn02__label--blue:is(:where(:any-link, :enabled, summary):hover *) {
    color: #2EA4D9;
  }
}
.c-btn02__label--blue-rev {
  color: #2EA4D9;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02__label--blue-rev:is(:where(:-moz-any-link, :enabled, summary):hover *) {
    color: #ffffff;
  }
  .c-btn02__label--blue-rev:is(:where(:any-link, :enabled, summary):hover *) {
    color: #ffffff;
  }
}
.c-btn02__label--deep {
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .c-btn02__label--deep:is(:where(:-moz-any-link, :enabled, summary):hover *) {
    color: #ffffff;
  }
  .c-btn02__label--deep:is(:where(:any-link, :enabled, summary):hover *) {
    color: #ffffff;
  }
}
.c-btn02__label1 {
  font-size: 1rem;
  line-height: 1;
  font-weight: 600;
}
.c-btn02__label2 {
  font-size: 1rem;
  line-height: 1;
  font-weight: 800;
}
@media screen and (min-width: 768px) {
  .c-btn02__label2 {
    font-size: 1.375rem;
  }
}

/* =========================
   c-image01（マルチ行進行バナー）
   ========================= */
.c-image01 {
  /* モダン環境（アドレスバーの出入りに強い） */
  width: 100dvw;
  margin-left: calc(50% - 50dvw);
  /* フォールバック：dvw 未対応ブラウザ */
  /* 旧式の left:50% + translate(-50%) を撤去 */
  position: relative;
  overflow: clip;
  --scroll-gap: 0;
  background: #ffffff;
  /* アニメーション（トラックを 50% 分だけ左に流す）
      ※ トラック内に「同一内容の .__inner を2セット」並べる前提 */
}
@supports not (width: 100dvw) {
  .c-image01 {
    width: var(--safe-vw);
    margin-left: calc(50% - var(--safe-vw) / 2);
  }
}
@supports not (overflow: clip) {
  .c-image01 {
    overflow: hidden;
  }
}
@-webkit-keyframes c-image01-marquee {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    /* アイテム間に gap を入れている場合は半分を相殺（両端分の折半） */
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
@keyframes c-image01-marquee {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    /* アイテム間に gap を入れている場合は半分を相殺（両端分の折半） */
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.c-image01__track {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  will-change: transform;
  -webkit-animation: c-image01-marquee 20s linear infinite;
          animation: c-image01-marquee 20s linear infinite;
  /* ホバーで停止したい場合はコメント解除 */
}
@media screen and (min-width: 768px) {
  .c-image01__track {
    -webkit-animation-duration: 30s;
            animation-duration: 30s;
  }
}
.c-image01__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  gap: 0 var(--scroll-gap);
}
.c-image01__img {
  /* 画像ははみ出しを起こさないよう block + 固定幅は flex-basis 指定 */
  display: block;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 37.0625rem;
}
@media screen and (min-width: 768px) {
  .c-image01__img {
    width: 116rem;
  }
}
.c-image01__img--2 {
  width: 37.8125rem;
  position: relative;
  /* relative の left は scrollWidth を増やさない */
  left: 2.25rem;
}

.c-title01 {
  display: inline-block;
  font-size: 1.375rem;
  line-height: 1.1818181818;
  font-weight: 800;
}
@media screen and (min-width: 768px) {
  .c-title01 {
    font-size: 2.5rem;
    line-height: 1.3;
  }
}
@media screen and (min-width: 768px) {
  .c-title01--d46 {
    font-size: 2.875rem;
    line-height: 1.1304347826;
  }
}
.c-title01--sm {
  display: inline-block;
  font-size: 1.25rem;
  line-height: 1.3;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .c-title01--sm {
    font-size: 2.5rem;
  }
}
@media screen and (min-width: 768px) {
  .c-title01--sm-d30 {
    font-size: 1.875rem;
  }
}
@media screen and (min-width: 768px) {
  .c-title01--sm-d32 {
    font-size: 2rem;
  }
}

.c-title02 {
  font-size: 1.5625rem;
  line-height: 1.48;
  font-weight: 800;
}
@media screen and (min-width: 768px) {
  .c-title02 {
    font-size: 2.5rem;
  }
}

.p-footer {
  overflow: hidden;
}
.p-footer__fixedbnr {
  display: none;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(0.5rem);
          transform: translateY(0.5rem);
  -webkit-transition: opacity 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  transition: opacity 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-footer__fixedbnr {
    display: block;
    position: fixed;
    width: 16.25rem;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    bottom: 8.75rem;
    right: 2rem;
    z-index: 100;
  }
}
@media screen and (min-width: 768px) and (hover: hover) {
  .p-footer__fixedbnr:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
  .p-footer__fixedbnr:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}
@media screen and (min-width: 768px) {
  .p-footer__fixedbnr.is-visible {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateY(0);
            transform: translateY(0);
    pointer-events: auto;
  }
  .p-footer__fixedbnr a {
    display: block;
    width: 100%;
  }
}
.p-footer__fixedbtn {
  position: fixed;
  bottom: -0.5625rem;
  left: 50%;
  translate: -50% 0;
  width: 24.6875rem;
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(0.5rem);
          transform: translateY(0.5rem);
  -webkit-transition: opacity 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  transition: opacity 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  pointer-events: none;
}
.p-footer__fixedbtn.is-visible {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  pointer-events: auto;
}
.p-footer__fixedbtn a {
  display: block;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-footer__fixedbtn {
    display: none;
  }
}
.p-footer__fixedbtn-pc {
  display: none;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(0.5rem);
          transform: translateY(0.5rem);
  -webkit-transition: opacity 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  transition: opacity 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s, -webkit-transform 0.25s ease;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-footer__fixedbtn-pc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 1.3125rem;
    background: rgba(255, 255, 255, 0.68);
    padding-block: 1.5625rem 1.5rem;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 100;
  }
  .p-footer__fixedbtn-pc.is-visible {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateY(0);
            transform: translateY(0);
    pointer-events: auto;
  }
}
.p-footer__inner {
  padding-block: 2rem 5.0625rem;
}
@media screen and (min-width: 768px) {
  .p-footer__inner {
    padding-block: 2rem 9.0625rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (min-width: 768px) {
  .p-footer__left {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
.p-footer__logo {
  width: 8.1875rem;
  display: block;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  position: relative;
}
@media (hover: hover) {
  .p-footer__logo:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
  .p-footer__logo:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}
@media screen and (min-width: 768px) {
  .p-footer__logo {
    width: 12.5625rem;
    margin-inline: 0;
    margin-top: 4.0625rem;
  }
}
.p-footer__logo img {
  width: 100%;
}
.p-footer__nav {
  margin-top: 1.875rem;
}
@media screen and (min-width: 768px) {
  .p-footer__nav {
    width: auto;
    margin-top: 0;
  }
}
.p-footer__links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1.25rem 0;
  height: 9rem;
  max-width: 23.4375rem;
}
@media screen and (min-width: 768px) {
  .p-footer__links {
    -webkit-box-orient: unset;
    -webkit-box-direction: unset;
        -ms-flex-direction: unset;
            flex-direction: unset;
    max-width: unset;
    height: auto;
    gap: 2rem;
  }
}
.p-footer__links li {
  width: 50%;
}
@media screen and (min-width: 768px) {
  .p-footer__links li {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}
.p-footer__links a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.1875rem;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.4;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.p-footer__links a[target=_blank]::after {
  content: "";
  display: block;
  -webkit-mask: url(../img/common/icon_blank.svg) no-repeat 50% 50%/contain;
          mask: url(../img/common/icon_blank.svg) no-repeat 50% 50%/contain;
  background: #222222;
  width: 1.1875rem;
  aspect-ratio: 19/20;
  -webkit-transition: background 300ms;
  transition: background 300ms;
}
@media (hover: hover) {
  .p-footer__links a:where(:-moz-any-link, :enabled, summary):hover {
    color: #00A1EB;
  }
  .p-footer__links a:where(:any-link, :enabled, summary):hover {
    color: #00A1EB;
  }
  .p-footer__links a:where(:-moz-any-link, :enabled, summary):hover[target=_blank]::after {
    background: #00A1EB;
  }
  .p-footer__links a:where(:any-link, :enabled, summary):hover[target=_blank]::after {
    background: #00A1EB;
  }
}
.p-footer__copyright {
  color: #555555;
  font-size: 0.625rem;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  display: block;
  margin-top: 2.6875rem;
}
@media screen and (min-width: 768px) {
  .p-footer__copyright {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    margin-top: 0.625rem;
    font-size: 0.75rem;
    line-height: 1.4166666667;
  }
}

.p-header {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 2000;
  overflow: visible;
}
@media screen and (min-width: 768px) {
  .p-header {
    position: fixed;
    padding-block: 2rem 0;
    padding-inline: 3.125rem;
    overflow: hidden;
  }
}
.p-header.is-fixed .p-header__logo {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-header.is-fixed .p-header__logo {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}
.p-header.is-hidden {
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
}
@media screen and (min-width: 768px) {
  .p-header__inner {
    background: #ffffff;
    border-radius: 624.9375rem;
  }
}
.p-header__bar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-block: 1.25rem;
  padding-inline: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-header__bar {
    height: 5rem;
    padding-inline: 3rem 3.5rem;
  }
}
.p-header__logo {
  width: 6.9375rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  position: relative;
  -webkit-transition: opacity 0.25s ease, visibility 0s 0.25s;
  transition: opacity 0.25s ease, visibility 0s 0.25s;
}
@media screen and (min-width: 768px) {
  .p-header__logo {
    width: 12.5625rem;
  }
}
.p-header__logo img {
  width: 100%;
}
.p-header__mobile-btn {
  position: absolute;
  right: 0;
  top: 0;
}
@media screen and (min-width: 768px) {
  .p-header__mobile-btn {
    display: none;
  }
}
.p-header__cta {
  height: 3.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: #FF9301;
  width: 11.625rem;
}
.p-header__cta-document {
  display: grid;
  place-content: center;
  width: 4rem;
  height: 100%;
  -webkit-box-shadow: 0 0 0.625rem rgba(255, 137, 2, 0.4);
          box-shadow: 0 0 0.625rem rgba(255, 137, 2, 0.4);
}
.p-header__cta-document-img {
  width: 100%;
}
.p-header__cta-contact {
  display: grid;
  place-content: center;
  width: 3.875rem;
  height: 100%;
  -webkit-box-shadow: 0 0 0.625rem rgba(255, 137, 2, 0.4);
          box-shadow: 0 0 0.625rem rgba(255, 137, 2, 0.4);
}
.p-header__cta-contact-img {
  width: 2.875rem;
}
.p-header__ham {
  position: absolute;
  top: 0;
  right: 0;
  width: 3.8125rem;
  height: 3.5625rem;
  border-bottom-left-radius: 1.25rem;
  background: #1FA8E6;
  display: grid;
  place-content: center;
  z-index: 2000;
}
.p-header__ham[data-menu=open] .p-header__ham-line span {
  width: 120%;
  left: 50%;
  translate: -50% -50%;
}
.p-header__ham[data-menu=open] .p-header__ham-line span:nth-of-type(1) {
  top: 70%;
  rotate: 35deg;
}
.p-header__ham[data-menu=open] .p-header__ham-line span:nth-of-type(2) {
  opacity: 0;
}
.p-header__ham[data-menu=open] .p-header__ham-line span:nth-of-type(3) {
  bottom: unset;
  top: 70%;
  rotate: -35deg;
}
.p-header__ham[data-menu=open] .p-header__ham-label1 {
  opacity: 0;
}
.p-header__ham[data-menu=open] .p-header__ham-label2 {
  opacity: 0;
}
.p-header__ham-inner {
  padding-top: 0.0625rem;
}
.p-header__ham-line {
  width: 1.5rem;
  height: 0.875rem;
  display: block;
  position: relative;
  margin-inline: auto;
}
.p-header__ham-line span {
  background: #ffffff;
  width: 1.125rem;
  height: 0.125rem;
  border-radius: 624.9375rem;
  display: block;
  position: absolute;
  -webkit-transition: all 300ms;
  transition: all 300ms;
}
.p-header__ham-line span:nth-of-type(1) {
  top: 0;
  right: 0;
}
.p-header__ham-line span:nth-of-type(2) {
  top: 50%;
  translate: 0 -50%;
  left: 0;
}
.p-header__ham-line span:nth-of-type(3) {
  bottom: 0;
  right: 0;
}
.p-header__ham-label {
  font-family: "M PLUS 2", sans-serif;
  color: #ffffff;
  font-size: 0.5rem;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -0.02em;
  position: relative;
  height: 1em;
  display: block;
  margin-top: 0.375rem;
}
.p-header__ham-label1, .p-header__ham-label2 {
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  display: block;
  -webkit-transition: opacity 300ms;
  transition: opacity 300ms;
}
.p-header__ham-label2 {
  opacity: 0;
}

.p-header-nav {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  background: url(../img/common/bg_drawer_object.svg) no-repeat 0% 100%/15.625rem 14.25rem #F7FCFF;
  overflow: scroll;
  translate: 100% 0;
  -webkit-transition: translate 300ms;
  transition: translate 300ms;
}
@media screen and (min-width: 768px) {
  .p-header-nav {
    display: none;
  }
}
.p-header-nav[data-menu=open] {
  translate: 0%;
}
.p-header-nav__inner {
  padding-block: 5.25rem 3rem;
  padding-inline: 3rem 2.9375rem;
}
.p-header-nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.25rem;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  max-width: 17.5rem;
  margin-inline: auto;
}
.p-header-nav__item {
  border-bottom: solid 0.1rem #F0F3F4;
  max-width: 15.3125rem;
}
.p-header-nav__link {
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  width: 100%;
  position: relative;
  padding-bottom: 0.625rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
}
@media (hover: hover) {
  .p-header-nav__link:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
  .p-header-nav__link:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}
.p-header-nav__link[target=_blank]::after {
  content: "";
  display: block;
  background: url(../img/common/icon_blank.svg) no-repeat 50% 50%/contain;
  width: 1.375rem;
  aspect-ratio: 22/24;
}
.p-header-nav__label {
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.8823529412;
  position: relative;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.p-header-nav__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.25rem;
  margin-top: 3.5rem;
  margin-inline: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.p-header-nav__logo {
  width: 11.25rem;
  margin-inline: auto;
  margin-top: 3.5rem;
}
.p-header-nav__logo img {
  width: 100%;
}
.p-header-nav__copyright {
  display: block;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.4166666667;
  text-align: center;
  margin-top: 0.75rem;
}

.p-header-pcnav {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-header-pcnav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 2.5rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
  }
}
.p-header-pcnav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.5625rem;
}
.p-header-pcnav__link {
  width: 100%;
  display: block;
  position: relative;
}
.p-header-pcnav__label {
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1;
  position: relative;
  width: 100%;
  display: block;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .p-header-pcnav__label:is(:where(:-moz-any-link, :enabled, summary):hover *) {
    color: #00A1EB;
  }
  .p-header-pcnav__label:is(:where(:any-link, :enabled, summary):hover *) {
    color: #00A1EB;
  }
}
.p-header-pcnav__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5625rem;
}

.p-top-image-wrap {
  width: 100%;
  overflow: visible;
}
@media screen and (min-width: 768px) {
  .p-top-bg1 {
    background: url(../img/top/bg_resolve_pc.svg) no-repeat 50% 0%/cover;
  }
}

.p-top-mv {
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-top-mv {
    padding-block: 10.625rem 5rem;
    background: url(../img/top/bg_mv1_pc.svg) no-repeat 0% 0%/36.4375rem 33.1875rem, url(../img/top/bg_mv2_pc.svg) no-repeat calc(100% + 15.6875rem) 6.3125rem/48.3125rem 47.25rem, url(../img/top/bg_mv3_pc.svg) no-repeat calc(0% - 36.625rem) 22.5rem/115.125rem 111.375rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv__flexbox1 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 4rem;
    max-width: 75.125rem;
    margin-inline: auto;
    padding-right: 0.5rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv__flexbox2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 5.375rem;
    max-width: 70.875rem;
    margin-inline: auto;
    margin-top: 4.25rem;
  }
}
.p-top-mv-group1 {
  background: url(../img/top/bg_mv1.svg) no-repeat 0% 0%/15.625rem 14.25rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1 {
    background: unset;
  }
}
.p-top-mv-group1__inner {
  padding-block: 7.5rem 0;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__inner {
    max-width: unset;
    padding-inline: 0;
    background: unset;
    width: 37.625rem;
    padding-block: 0;
  }
}
.p-top-mv-group1__lead1 {
  color: #00A1EB;
  font-size: 2.0625rem;
  font-weight: 800;
  line-height: 1.2424242424;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__lead1 {
    font-size: 3.9375rem;
    line-height: 1.2857142857;
  }
}
.p-top-mv-group1__lead2 {
  font-size: 1.6875rem;
  font-weight: 800;
  line-height: 1.5925925926;
  margin-left: 0.4375rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__lead2 {
    font-size: 3.375rem;
    line-height: 1.5;
    margin-left: 0;
  }
}
.p-top-mv-group1__lead3 {
  font-size: 1.8125rem;
  font-weight: 800;
  line-height: 1.3103448276;
  letter-spacing: -0.04em;
  top: -0.3125rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__lead3 {
    font-size: 3.75rem;
    line-height: 1.3;
  }
}
.p-top-mv-group1__lead4 {
  font-size: 1.8125rem;
  font-weight: 800;
  line-height: 1.4137931034;
  top: -0.3125rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__lead4 {
    font-size: 3.75rem;
    line-height: 1.3333333333;
  }
}
.p-top-mv-group1__lead5 {
  font-size: 1.8125rem;
  font-weight: 800;
  line-height: 1.3103448276;
  letter-spacing: -0.04em;
  top: -0.3125rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__lead5 {
    font-size: 3.75rem;
    line-height: 1.3;
  }
}
.p-top-mv-group1__sublead {
  font-size: 0.75rem;
  line-height: 1.8333333333;
  font-weight: 500;
  letter-spacing: -0.02em;
  margin-top: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__sublead {
    margin-top: 0.625rem;
    font-size: 1.375rem;
    line-height: 1.7727272727;
  }
}
.p-top-mv-group1__badge {
  width: 20.9375rem;
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__badge {
    width: 37rem;
    margin-top: 0.75rem;
  }
}
.p-top-mv-group1__badge img {
  width: 100%;
}
.p-top-mv-group1__anotation {
  margin-top: 0.875rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__anotation {
    margin-top: 0.75rem;
  }
}
.p-top-mv-group1__anotation-item {
  font-size: 0.625rem;
  line-height: 1.3;
  font-weight: 400;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.125rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__anotation-item {
    line-height: 1.4;
  }
}
.p-top-mv-group1__salesforce {
  width: 2.4375rem;
  margin-top: 1.4375rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__salesforce {
    width: 4.375rem;
    margin-top: 0;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__btn-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1.125rem;
    margin-top: 1.5rem;
  }
}
.p-top-mv-group1__btn {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group1__btn {
    display: block;
  }
}
.p-top-mv-group2 {
  margin-top: -1.25rem;
  background: url(../img/top/bg_mv2.svg) no-repeat calc(100% + 6.5625rem) 2.5rem/20.4375rem 19.9375rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2 {
    background: unset;
    margin-top: unset;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__inner {
    max-width: unset;
    padding-inline: 0;
  }
}
.p-top-mv-group2__inner2 {
  width: 19.6875rem;
  height: 22.5rem;
  margin-inline: auto 0;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__inner2 {
    width: 33.25rem;
    height: auto;
  }
}
.p-top-mv-group2__heading {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto 0;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__heading {
    width: 33.25rem;
    margin-inline: 0;
  }
}
.p-top-mv-group2__logo {
  width: 7.125rem;
  position: relative;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__logo {
    width: 13.0625rem;
  }
}
.p-top-mv-group2__hukidashi {
  width: 14.875rem;
  height: 7.75rem;
  background: url(../img/top/bg_mv_hukidashi01.webp) no-repeat 50% 50%/contain;
  position: relative;
  margin-top: -1.75rem;
  margin-left: 2.375rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__hukidashi {
    width: 20.625rem;
    height: 9.6875rem;
    background: url(../img/top/bg_mv_hukidashi01_pc.webp) no-repeat 50% 50%/contain;
    margin-top: -5.125rem;
    margin-inline: auto 0;
  }
}
.p-top-mv-group2__txt-wrap {
  position: absolute;
  bottom: 1.5rem;
  left: 1.375rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__txt-wrap {
    bottom: 1.625rem;
    left: 1.8125rem;
  }
}
.p-top-mv-group2__desc {
  line-height: 1.2666666667;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__desc {
    line-height: 1.5;
  }
}
.p-top-mv-group2__desc1 {
  font-size: 0.9375rem;
  font-weight: 700;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__desc1 {
    font-size: 1.125rem;
  }
}
.p-top-mv-group2__desc2 {
  font-size: 0.8125rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__desc2 {
    font-size: 1rem;
  }
}
.p-top-mv-group2__name {
  font-size: 0.6875rem;
  line-height: 1.0909090909;
  font-weight: 500;
  margin-top: 0.8125rem;
  padding-left: 0.1875rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__name {
    font-size: 0.75rem;
    line-height: 1.1666666667;
    margin-top: 0.6875rem;
  }
}
.p-top-mv-group2__photo {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group2__photo {
    margin-top: 1.5rem;
    width: 33rem;
  }
}
.p-top-mv-group3 {
  margin-top: 2.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3 {
    margin-top: 0;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__inner {
    max-width: unset;
    padding-inline: 0;
  }
}
.p-top-mv-group3__inner2 {
  width: 20.9375rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__inner2 {
    width: 32.6875rem;
  }
}
.p-top-mv-group3__heading {
  width: 19.25rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__heading {
    width: 29.125rem;
  }
}
.p-top-mv-group3__logo {
  width: 7.125rem;
  position: relative;
  z-index: 100;
  margin-inline: auto 0;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__logo {
    width: 13.4375rem;
  }
}
.p-top-mv-group3__hukidashi {
  width: 13.8125rem;
  height: 9.1875rem;
  background: url(../img/top/bg_mv_hukidashi02.webp) no-repeat 50% 50%/contain;
  position: relative;
  margin-top: -3.25rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__hukidashi {
    width: 17.1875rem;
    height: 10.9375rem;
    background: url(../img/top/bg_mv_hukidashi02_pc.webp) no-repeat 50% 50%/contain;
    margin-top: -7.9375rem;
  }
}
.p-top-mv-group3__txt-wrap {
  position: absolute;
  bottom: 1.5rem;
  left: 1.375rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__txt-wrap {
    bottom: 1.625rem;
    left: 1.8125rem;
  }
}
.p-top-mv-group3__desc {
  line-height: 1.3333333333;
}
.p-top-mv-group3__desc1 {
  font-size: 0.9375rem;
  font-weight: 700;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__desc1 {
    font-size: 1.125rem;
  }
}
.p-top-mv-group3__desc2 {
  font-size: 0.875rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__desc2 {
    font-size: 1rem;
  }
}
.p-top-mv-group3__name {
  font-size: 0.6875rem;
  line-height: 1.0909090909;
  font-weight: 500;
  margin-top: 0.8125rem;
  padding-left: 0.1875rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__name {
    font-size: 0.75rem;
    line-height: 1.1666666667;
    margin-top: 0.6875rem;
  }
}
.p-top-mv-group3__photo {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group3__photo {
    margin-top: 1.5rem;
  }
}
.p-top-mv-group4 {
  margin-top: 2.5rem;
  background: url(../img/top/bg_mv3.svg) no-repeat 0% 100%/23.4375rem 23.875rem;
  padding-bottom: 3.125rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4 {
    background: unset;
    margin-top: 5.5rem;
    padding-bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__inner {
    max-width: unset;
    padding-inline: 0;
  }
}
.p-top-mv-group4__inner2 {
  width: 20.1875rem;
  margin-inline: auto 0;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__inner2 {
    width: 32.6875rem;
    margin-inline: 0;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__heading {
    width: 33.8125rem;
  }
}
.p-top-mv-group4__logo {
  width: 7.125rem;
  position: relative;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__logo {
    width: 13.4375rem;
  }
}
.p-top-mv-group4__hukidashi {
  width: 14rem;
  height: 9.125rem;
  background: url(../img/top/bg_mv_hukidashi03.webp) no-repeat 50% 50%/contain;
  position: relative;
  margin-top: -3.625rem;
  margin-inline: auto 0;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__hukidashi {
    width: 20.5rem;
    height: 9.9375rem;
    background: url(../img/top/bg_mv_hukidashi03_pc.webp) no-repeat 50% 50%/contain;
    margin-inline: auto 0;
    margin-top: -3.9375rem;
  }
}
.p-top-mv-group4__txt-wrap {
  position: absolute;
  bottom: 1.5rem;
  left: 1.375rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__txt-wrap {
    bottom: 1.875rem;
    left: 1.6875rem;
  }
}
.p-top-mv-group4__desc {
  line-height: 1.3333333333;
}
.p-top-mv-group4__desc1 {
  font-size: 0.9375rem;
  font-weight: 700;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__desc1 {
    font-size: 1.125rem;
  }
}
.p-top-mv-group4__desc2 {
  font-size: 0.875rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__desc2 {
    font-size: 1rem;
  }
}
.p-top-mv-group4__name {
  font-size: 0.6875rem;
  line-height: 1.0909090909;
  font-weight: 500;
  margin-top: 0.8125rem;
  padding-left: 0.1875rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__name {
    font-size: 0.75rem;
    line-height: 1.1666666667;
    margin-top: 0.625rem;
  }
}
.p-top-mv-group4__photo {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-top-mv-group4__photo {
    margin-top: 1.5rem;
  }
}
.p-top-resolve {
  padding-block: 3.5rem 0;
  background: url(../img/top/bg_resolve.svg) no-repeat 50% 0%/contain;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-top-resolve {
    padding-block: 8.125rem 0;
    background: unset;
  }
}
.p-top-resolve__tit {
  text-align: center;
}
.p-top-resolve__txt {
  font-size: 0.9375rem;
  line-height: 1.6;
  font-weight: 500;
  text-align: center;
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-resolve__txt {
    font-size: 1rem;
    line-height: 1.875;
  }
}
.p-top-resolve-card {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card {
    -webkit-box-orient: unset;
    -webkit-box-direction: unset;
        -ms-flex-direction: unset;
            flex-direction: unset;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: 50.25rem;
    margin-inline: auto;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 2.5rem;
    margin-top: 3.5rem;
  }
}
.p-top-resolve-card__top-group {
  position: relative;
  width: 18.5625rem;
  height: 12.4375rem;
  margin-inline: auto;
  padding-top: 1.125rem;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__top-group {
    width: 22.5rem;
    height: 15.0625rem;
    padding-top: 1.5rem;
  }
}
.p-top-resolve-card__scrim1 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  -webkit-filter: drop-shadow(0 0 1.25rem rgba(0, 0, 0, 0.1));
          filter: drop-shadow(0 0 1.25rem rgba(0, 0, 0, 0.1));
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}
.p-top-resolve-card__scrim1 img {
  width: 100%;
}
.p-top-resolve-card__tit {
  font-size: 1.25rem;
  line-height: 1.3;
  font-weight: 700;
  text-align: center;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__tit {
    font-size: 1.5rem;
    line-height: 1.25;
  }
}
.p-top-resolve-card__img {
  margin-inline: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 0.6875rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__img {
    margin-top: 0.8125rem;
  }
  .p-top-resolve-card__img img {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__img--01 {
    width: 12.75rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__img--02 {
    width: 9rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__img--03 {
    width: 12.1875rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__img--04 {
    width: 9.375rem;
  }
}
.p-top-resolve-card__bottom-group {
  width: 19.125rem;
  margin-inline: auto;
  margin-top: -0.3125rem;
  position: relative;
  background: #5DBEE8;
  border-radius: 0.6875rem;
  padding-block: 1.8125rem 2rem;
  padding-inline: 1.6875rem;
  color: #ffffff;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__bottom-group {
    height: 16.375rem;
    width: 23.125rem;
  }
}
.p-top-resolve-card__txt1 {
  font-size: 1.0625rem;
  line-height: 1.5294117647;
  font-weight: 700;
  letter-spacing: -0.02em;
  text-align: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__txt1 {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.p-top-resolve-card__txt1::before, .p-top-resolve-card__txt1::after {
  content: "";
  display: block;
  background: #ffffff;
  width: 3rem;
  height: 0.0625rem;
  position: absolute;
  left: calc(100% + 0.9375rem);
  top: 50%;
  translate: 0 -50%;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__txt1::before, .p-top-resolve-card__txt1::after {
    width: 3.375rem;
    left: calc(100% + 0.625rem);
  }
}
.p-top-resolve-card__txt1::after {
  left: unset;
  right: calc(100% + 0.5625rem);
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__txt1::after {
    right: calc(100% + 0.625rem);
  }
}
.p-top-resolve-card__txt2 {
  font-size: 1.25rem;
  line-height: 1.3;
  font-weight: 800;
  text-align: center;
  margin-top: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__txt2 {
    font-size: 1.625rem;
    line-height: 1.1538461538;
  }
}
.p-top-resolve-card__txt3 {
  font-size: 0.9375rem;
  line-height: 1.8666666667;
  font-weight: 500;
  letter-spacing: -0.03em;
  margin-top: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-resolve-card__txt3 {
    font-size: 1rem;
    line-height: 1.875;
    margin-top: 0.75rem;
    max-width: 17.1875rem;
    margin-inline: auto;
  }
}
.p-top-overview {
  overflow: hidden;
}
.p-top-overview-cnt1 {
  padding-block: 3.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt1 {
    padding-block: 8.75rem 5rem;
  }
}
.p-top-overview-cnt1__tit {
  text-align: center;
}
.p-top-overview-cnt1__txt {
  font-size: 0.9375rem;
  line-height: 1.7333333333;
  font-weight: 500;
  text-align: center;
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt1__txt {
    font-size: 1.25rem;
    line-height: 2;
  }
}
.p-top-overview-cnt1__figure {
  width: 20.9375rem;
  margin-inline: auto;
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt1__figure {
    width: 64.75rem;
    margin-top: 3.5rem;
  }
}
.p-top-overview-cnt1__txt2 {
  font-size: 1.125rem;
  line-height: 1.5555555556;
  font-weight: 700;
  text-align: center;
  color: #ffffff;
  border-radius: 0.375rem;
  background: #41ACD9;
  -webkit-box-shadow: 0 0 1.875rem rgba(255, 255, 255, 0.3);
          box-shadow: 0 0 1.875rem rgba(255, 255, 255, 0.3);
  width: 20.6875rem;
  height: 4.5625rem;
  display: grid;
  place-content: center;
  margin-top: -2.4375rem;
  margin-inline: auto;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt1__txt2 {
    width: 38.4375rem;
    height: 3.5rem;
    font-size: 1.625rem;
    margin-top: -1.625rem;
  }
}
.p-top-overview-cnt1__arr {
  width: 17.9375rem;
  margin-inline: auto;
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt1__arr {
    width: 22rem;
    margin-top: 3.5rem;
  }
}
.p-top-overview-cnt2 {
  background: #5EBEE9;
  -webkit-box-shadow: inset 0 0 1.875rem rgba(255, 255, 255, 0.3);
          box-shadow: inset 0 0 1.875rem rgba(255, 255, 255, 0.3);
  padding-block: 3.5rem 4.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2 {
    background: unset;
    -webkit-box-shadow: unset;
            box-shadow: unset;
    padding-block: 0 10rem;
    background: unset;
    position: relative;
  }
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    overflow: hidden;
    height: calc(100% + 5rem);
  }
  .p-top-overview-cnt2__bg::before {
    content: unset;
    display: block;
    background: url(../img/top/bg_overview_pc.svg) no-repeat 50% 50%/contain;
    width: 76.625rem;
    aspect-ratio: 1226/985;
    position: absolute;
    bottom: -19.6875rem;
    right: -15.25rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__inner {
    max-width: 50.375rem;
    background: #5EBEE9;
    -webkit-box-shadow: inset 0 0 1.875rem rgba(255, 255, 255, 0.3);
            box-shadow: inset 0 0 1.875rem rgba(255, 255, 255, 0.3);
    border-radius: 1.25rem;
    padding-block: 1.5rem 2.5rem;
    padding-inline: 2.625rem;
    position: relative;
  }
}
.p-top-overview-cnt2__tit {
  text-align: center;
}
.p-top-overview-cnt2__tit span {
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__tit-1 {
    margin-left: 0.25rem;
  }
}
.p-top-overview-cnt2__txt {
  font-size: 0.9375rem;
  line-height: 1.7333333333;
  font-weight: 600;
  color: #ffffff;
  text-align: center;
  max-width: 18rem;
  margin-inline: auto;
  margin-top: 1.0625rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__txt {
    font-size: 1.25rem;
    line-height: 2;
    margin-top: 1.4375rem;
    max-width: unset;
  }
}
.p-top-overview-cnt2__list {
  background: #ffffff;
  -webkit-box-shadow: 0 0 1.25rem rgba(0, 0, 0, 0.09);
          box-shadow: 0 0 1.25rem rgba(0, 0, 0, 0.09);
  border-radius: 0.625rem;
  margin-top: 2rem;
  padding-block: 1.5rem 1.625rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.p-top-overview-cnt2__item {
  width: 50%;
  border-right: solid #EDEDED 0.125rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item {
    width: 33.3333333333%;
  }
}
.p-top-overview-cnt2__item::before {
  content: "";
  display: block;
  background: #EDEDED;
  width: 18.1875rem;
  height: 0.125rem;
  position: absolute;
  top: 100%;
  left: 1.4375rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item::before {
    width: 41.4375rem;
    left: 1.8125rem;
  }
}
.p-top-overview-cnt2__item:nth-of-type(5), .p-top-overview-cnt2__item:nth-of-type(6) {
  border-bottom: unset;
}
.p-top-overview-cnt2__item:nth-of-type(5)::before, .p-top-overview-cnt2__item:nth-of-type(6)::before {
  content: unset;
}
.p-top-overview-cnt2__item:nth-of-type(even) {
  border-right: unset;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item:nth-of-type(even) {
    border-right: solid #EDEDED 0.125rem;
  }
}
.p-top-overview-cnt2__item:nth-of-type(even)::before {
  content: unset;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item:nth-of-type(n+2)::before {
    content: unset;
  }
}
.p-top-overview-cnt2__item-inner {
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  padding-bottom: 1rem;
}
.p-top-overview-cnt2__item-inner--1 {
  max-width: 7.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item-inner--1 {
    max-width: 11rem;
  }
}
.p-top-overview-cnt2__item-inner--2 {
  max-width: 7.5625rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item-inner--2 {
    max-width: 12.5rem;
  }
}
.p-top-overview-cnt2__item-inner--3 {
  max-width: 7.5rem;
  padding-top: 1.6875rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item-inner--3 {
    max-width: 12rem;
    padding-top: 0;
  }
}
.p-top-overview-cnt2__item-inner--4 {
  max-width: 6.5625rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item-inner--4 {
    max-width: 9rem;
    padding-bottom: 0;
  }
}
.p-top-overview-cnt2__item-inner--5 {
  max-width: 7.5rem;
  padding-bottom: 0;
  padding-top: 1.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item-inner--5 {
    max-width: 8rem;
  }
}
.p-top-overview-cnt2__item-inner--6 {
  max-width: 8.3125rem;
  padding-bottom: 0;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__item-inner--6 {
    max-width: 10.5rem;
  }
}
.p-top-overview-cnt2__img {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
.p-top-overview-cnt2__img--1 {
  margin-bottom: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__img--1 {
    margin-bottom: 0.5rem;
  }
}
.p-top-overview-cnt2__img--2 {
  margin-bottom: 0.9375rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__img--2 {
    margin-bottom: 0.5rem;
  }
}
.p-top-overview-cnt2__img--3 {
  margin-bottom: 1.3125rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__img--3 {
    margin-bottom: 0.5rem;
  }
}
.p-top-overview-cnt2__img--4 {
  margin-bottom: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__img--4 {
    margin-bottom: 0.5rem;
  }
}
.p-top-overview-cnt2__img--5 {
  margin-bottom: 1.0625rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__img--5 {
    margin-bottom: 0.5rem;
  }
}
.p-top-overview-cnt2__img--6 {
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__img--6 {
    margin-bottom: 0.5rem;
  }
}
.p-top-overview-cnt2__caption {
  font-size: 0.9375rem;
  line-height: 1.6;
  font-weight: 500;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-top-overview-cnt2__caption {
    height: 4.75rem;
    display: grid;
    place-content: center;
    font-size: 1rem;
    line-height: 1.625;
  }
}
.p-top-reason {
  background: #2EA4D9;
  -webkit-box-shadow: inset 0 0 1.875rem rgba(255, 255, 255, 0.3);
          box-shadow: inset 0 0 1.875rem rgba(255, 255, 255, 0.3);
  position: relative;
  z-index: 2;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-top-reason {
    -webkit-box-shadow: inset 0 0 1.25rem rgba(255, 255, 255, 0.3);
            box-shadow: inset 0 0 1.25rem rgba(255, 255, 255, 0.3);
    border-radius: 3.625rem;
  }
}
.p-top-reason__inner {
  padding-block: 3.5rem 4.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__inner {
    padding-block: 7.5rem 10rem;
    max-width: 78.125rem;
  }
}
.p-top-reason__tit {
  text-align: center;
}
.p-top-reason__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__list {
    -webkit-box-orient: unset;
    -webkit-box-direction: unset;
        -ms-flex-direction: unset;
            flex-direction: unset;
    gap: 4.0625rem 3.1875rem;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 4rem;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.p-top-reason__item {
  position: relative;
  border-radius: 0.75rem;
  background: #EDF8FF;
  -webkit-box-shadow: inset 0 0 0.625rem rgba(0, 183, 255, 0.16);
          box-shadow: inset 0 0 0.625rem rgba(0, 183, 255, 0.16);
  padding-block: 2rem;
  padding-inline: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__item {
    width: 22.875rem;
    height: 34.5625rem;
    padding-block: 3.375rem;
    padding-inline: 0.75rem;
  }
}
.p-top-reason__num {
  color: #D5E7F4;
  font-family: "M PLUS 2", sans-serif;
  font-weight: 500;
  font-size: 3.0625rem;
  position: absolute;
  left: 0.625rem;
  top: 0;
}
@media screen and (min-width: 768px) {
  .p-top-reason__num {
    font-size: 4.5625rem;
    left: 1.25rem;
  }
}
.p-top-reason__topic {
  font-size: 1.25rem;
  line-height: 1.6;
  text-align: center;
  font-weight: 700;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-reason__topic {
    font-size: 1.5rem;
    line-height: 1.3333333333;
  }
}
.p-top-reason__topic-1 {
  font-weight: 800;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-top-reason__topic-1 {
    font-size: 1.625rem;
  }
}
.p-top-reason__img {
  margin-inline: auto;
}
.p-top-reason__img--1 {
  margin-top: 1.5rem;
  width: 17.3125rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__img--1 {
    margin-top: 2rem;
    width: 18.5rem;
  }
}
.p-top-reason__img--2 {
  margin-top: 2rem;
  width: 15.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__img--2 {
    margin-top: 3.125rem;
    width: 15.5rem;
  }
}
.p-top-reason__img--3 {
  margin-top: 1.6875rem;
  width: 17.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__img--3 {
    margin-top: 2.4375rem;
    width: 17.625rem;
  }
}
.p-top-reason__img--4 {
  margin-top: 1.6875rem;
  width: 14.75rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__img--4 {
    margin-top: 2.25rem;
    width: 14.75rem;
  }
}
.p-top-reason__img--5 {
  margin-top: 0.8125rem;
  width: 16.9375rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__img--5 {
    margin-top: 1.6875rem;
    width: 16.9375rem;
  }
}
.p-top-reason__txt {
  font-size: 0.9375rem;
  line-height: 1.7333333333;
  font-weight: 500;
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__txt {
    margin-top: 2rem;
    max-width: 17.8125rem;
    margin-inline: auto;
    font-size: 1rem;
    line-height: 1.875;
  }
}
@media screen and (min-width: 768px) {
  .p-top-reason__txt--02 {
    max-width: 15.875rem;
  }
}
.p-top-cases {
  position: relative;
  overflow: hidden;
}
.p-top-cases__bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-top-cases__bg {
    height: calc(100% + 25rem);
    top: -12.5rem;
  }
}
.p-top-cases__bg-1 {
  position: absolute;
  top: -6.9375rem;
  left: -4.6875rem;
  background: url(../img/top/bg_cases01_1.svg) no-repeat 50% 50%/contain;
  width: 20.0625rem;
  height: 16.9375rem;
}
@media screen and (min-width: 768px) {
  .p-top-cases__bg-1 {
    top: -11.5rem;
    left: -12.875rem;
    background: url(../img/top/bg_cases01_1_pc.svg) no-repeat 50% 50%/contain;
    width: 56.875rem;
    height: 47.9375rem;
  }
}
.p-top-cases__bg-2 {
  position: absolute;
  bottom: -20.625rem;
  right: -5.125rem;
  background: url(../img/top/bg_cases01_2.svg) no-repeat 50% 50%/contain;
  width: 43.1875rem;
  height: 37.1875rem;
}
@media screen and (min-width: 768px) {
  .p-top-cases__bg-2 {
    bottom: -32.375rem;
    right: -14.25rem;
    background: url(../img/top/bg_cases01_2_pc.svg) no-repeat 50% 50%/contain;
    width: 115.6875rem;
    height: 100.125rem;
  }
}
.p-top-cases__inner {
  padding-block: 4rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-cases__inner {
    padding-block: 7.875rem 10rem;
    max-width: 76.875rem;
  }
}
.p-top-cases__tit {
  text-align: center;
}
.p-top-cases__list {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-cases__list {
    -webkit-box-orient: unset;
    -webkit-box-direction: unset;
        -ms-flex-direction: unset;
            flex-direction: unset;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 2.4375rem 3rem;
    margin-top: 1.5rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-cases__item {
    width: 22.5rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-cases__item--2 {
    padding-top: 4.9375rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-cases__item--3 {
    padding-top: 2.25rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-cases__item--4 {
    padding-top: 2.25rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-cases__item--5 {
    padding-top: 6.4375rem;
  }
}
.p-top-cases__logo {
  width: 6.9375rem;
  position: relative;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .p-top-cases__logo {
    width: 9.75rem;
  }
}
.p-top-cases__logo:where(.p-top-cases__logo--2, .p-top-cases__logo--4, .p-top-cases__logo--6) {
  margin-inline: auto 0;
}
@media screen and (min-width: 768px) {
  .p-top-cases__logo--2, .p-top-cases__logo--3, .p-top-cases__logo--4, .p-top-cases__logo--5 {
    margin-inline: auto 1.3125rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-cases__logo--6 {
    margin-inline: auto 0;
  }
}
.p-top-cases__photo {
  margin-top: -1.0625rem;
}
@media screen and (min-width: 768px) {
  .p-top-cases__photo {
    margin-top: -0.875rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-cases__photo:where(.p-top-cases__photo--1, .p-top-cases__photo--6) {
    margin-top: 1.375rem;
  }
}
.p-top-cases__hukidashi {
  -webkit-filter: drop-shadow(0.1875rem 0.1875rem 0.625rem rgba(0, 0, 0, 0.12));
          filter: drop-shadow(0.1875rem 0.1875rem 0.625rem rgba(0, 0, 0, 0.12));
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-cases__hukidashi {
    margin-top: 0.25rem;
  }
}
.p-top-cases__hukidashi:where(.p-top-cases__hukidashi--2, .p-top-cases__hukidashi--4, .p-top-cases__hukidashi--6) {
  margin-inline: auto 0;
}
.p-top-cases__hukidashi--1 {
  width: 19.4375rem;
  height: 7.4375rem;
  background: url(../img/top/bg_cases_hukidashi01_1.webp) no-repeat 50% 50%/contain;
}
@media screen and (min-width: 768px) {
  .p-top-cases__hukidashi--1 {
    width: 22.375rem;
    height: 10.9375rem;
    background: url(../img/top/bg_cases_hukidashi01_175_pc.webp) no-repeat 50% 50%/contain;
  }
}
.p-top-cases__hukidashi--2 {
  width: 19.4375rem;
  height: 7.4375rem;
  background: url(../img/top/bg_cases_hukidashi01_2.webp) no-repeat 50% 50%/contain;
}
@media screen and (min-width: 768px) {
  .p-top-cases__hukidashi--2 {
    width: 22.375rem;
    height: 10.9375rem;
    background: url(../img/top/bg_cases_hukidashi01_175_pc.webp) no-repeat 50% 50%/contain;
  }
}
.p-top-cases__hukidashi--3 {
  width: 19.4375rem;
  height: 7.4375rem;
  background: url(../img/top/bg_cases_hukidashi01_3.webp) no-repeat 50% 50%/contain;
}
@media screen and (min-width: 768px) {
  .p-top-cases__hukidashi--3 {
    width: 22.375rem;
    height: 10.9375rem;
    background: url(../img/top/bg_cases_hukidashi01_175_pc.webp) no-repeat 50% 50%/contain;
  }
}
.p-top-cases__hukidashi--4 {
  width: 19.5625rem;
  height: 8.875rem;
  background: url(../img/top/bg_cases_hukidashi01_4.webp) no-repeat 50% 50%/contain;
}
@media screen and (min-width: 768px) {
  .p-top-cases__hukidashi--4 {
    width: 22.375rem;
    height: 12.875rem;
    background: url(../img/top/bg_cases_hukidashi01_206_pc.webp) no-repeat 50% 50%/contain;
  }
}
.p-top-cases__hukidashi--5 {
  width: 19.4375rem;
  height: 8.875rem;
  background: url(../img/top/bg_cases_hukidashi01_5.webp) no-repeat 50% 50%/contain;
}
@media screen and (min-width: 768px) {
  .p-top-cases__hukidashi--5 {
    width: 22.375rem;
    height: 12.875rem;
    background: url(../img/top/bg_cases_hukidashi01_206_pc.webp) no-repeat 50% 50%/contain;
  }
}
.p-top-cases__hukidashi--6 {
  width: 19.4375rem;
  height: 8.875rem;
  background: url(../img/top/bg_cases_hukidashi01_6.webp) no-repeat 50% 50%/contain;
}
@media screen and (min-width: 768px) {
  .p-top-cases__hukidashi--6 {
    width: 22.375rem;
    height: 12.875rem;
    background: url(../img/top/bg_cases_hukidashi01_206_pc.webp) no-repeat 50% 50%/contain;
  }
}
.p-top-cases__txt-wrap {
  position: absolute;
  bottom: 0.9375rem;
  left: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-cases__txt-wrap {
    bottom: 1.625rem;
    left: 1.8125rem;
  }
}
.p-top-cases__txt {
  font-size: 1rem;
  line-height: 1.375;
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  .p-top-cases__txt {
    font-size: 1.125rem;
    line-height: 1.6666666667;
  }
}
.p-top-cases__name {
  font-size: 0.6875rem;
  line-height: 1.0909090909;
  font-weight: 500;
  margin-top: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-cases__name {
    font-size: 1rem;
    line-height: 0.75;
    margin-top: 1.375rem;
  }
}
.p-top-pricing {
  overflow: hidden;
}
.p-top-pricing__inner {
  padding-block: 3.5rem 4.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing__inner {
    padding-block: 7.5rem 10rem;
    max-width: -webkit-fit-content;
    max-width: -moz-fit-content;
    max-width: fit-content;
  }
}
.p-top-pricing__tit {
  text-align: center;
  line-height: 1.2;
}
.p-top-pricing__txt1 {
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.6;
  font-weight: 500;
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing__txt1 {
    font-size: 1rem;
    line-height: 1.875;
  }
}
.p-top-pricing__txt2 {
  text-align: center;
  font-size: 1.125rem;
  line-height: 1.7777777778;
  font-weight: 500;
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing__txt2 {
    margin-top: 7.5625rem;
    font-size: 1.25rem;
    line-height: 2.1;
  }
}
.p-top-pricing-table {
  margin-top: 2.125rem;
  -webkit-box-shadow: 0.1875rem 0.1875rem 1.25rem rgba(0, 0, 0, 0.12);
          box-shadow: 0.1875rem 0.1875rem 1.25rem rgba(0, 0, 0, 0.12);
  border-radius: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table {
    width: 75rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background: #fff;
    padding-block: 1.75rem 0;
    padding-inline: 1.25rem;
    height: 29.375rem;
    margin-top: 7.125rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__card2-outer {
    width: 25%;
    margin-left: 1.8125rem;
  }
}
.p-top-pricing-table__card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.6875rem;
  padding-block: 1.5rem 1.1875rem;
  padding-inline: 1rem;
  background: #ffffff;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__card {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-inline: 0;
    padding-block: 0;
    gap: 0;
  }
}
.p-top-pricing-table__card--1 {
  border-top-left-radius: 0.625rem;
  border-top-right-radius: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__card--1 {
    width: 15.1875rem;
  }
}
.p-top-pricing-table__card--2 {
  background: #EBF8FF;
  -webkit-box-shadow: 0.1875rem 0.1875rem 0.75rem rgba(0, 0, 0, 0.16);
          box-shadow: 0.1875rem 0.1875rem 0.75rem rgba(0, 0, 0, 0.16);
  width: 23.4375rem;
  position: relative;
  left: -1.25rem;
  z-index: 2;
  padding-inline: 2.25rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__card--2 {
    width: 20.625rem;
    height: 36.5625rem;
    left: 0;
    top: -4.875rem;
    padding-block: 1rem 0;
    padding-inline: 1.375rem;
  }
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__card--3 {
    width: 15.6875rem;
    margin-left: 4.25rem;
  }
}
.p-top-pricing-table__card--4 {
  border-bottom-left-radius: 0.625rem;
  border-bottom-right-radius: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__card--4 {
    width: 15.5625rem;
    margin-left: 1.875rem;
  }
}
.p-top-pricing-table__tit {
  width: 3.6875rem;
  border-radius: 0.625rem;
  display: grid;
  place-content: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  padding-block: 2.0625rem 1.8125rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__tit {
    font-size: 1.25rem;
    line-height: 1;
    font-weight: 800;
    color: #ffffff;
    width: 100%;
    height: 3.6875rem;
    padding: 0;
  }
}
.p-top-pricing-table__tit span {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__tit span {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__tit img {
    display: none;
  }
}
.p-top-pricing-table__tit--1 {
  background: #F7E93F;
}
.p-top-pricing-table__tit--2 {
  background: linear-gradient(140deg, #00A5EF, #9BCFE6);
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__tit--2 {
    font-size: 1.625rem;
    height: 4.25rem;
  }
}
.p-top-pricing-table__tit--3 {
  background: #6FD98B;
}
.p-top-pricing-table__tit--4 {
  background: #646464;
}
.p-top-pricing-table__txt1 {
  font-size: 1.125rem;
  line-height: 1;
  font-weight: 700;
  color: #00A1EB;
  text-align: center;
  width: 13.125rem;
  height: 1.625rem;
  display: grid;
  place-content: center;
  position: relative;
  margin-bottom: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__txt1 {
    margin-inline: auto;
  }
}
.p-top-pricing-table__txt1::before, .p-top-pricing-table__txt1::after {
  content: "";
  display: block;
  background: url(../img/top/bg_pricing_line01.svg) no-repeat 50% 50%/contain;
  width: 0.5rem;
  height: 1.0625rem;
  position: absolute;
  top: 0.4375rem;
  right: 0;
}
.p-top-pricing-table__txt1::before {
  right: unset;
  left: 0;
  scale: 1 -1;
}
.p-top-pricing-table__txt2 {
  font-size: 0.9375rem;
  line-height: 1.6;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__txt2 {
    font-size: 1rem;
    line-height: 1.875;
    padding-inline: 0.625rem;
    margin-top: 1rem;
    padding-bottom: 1rem;
    border-bottom: solid 0.0625rem #CECECE;
  }
}
.p-top-pricing-table__plus {
  width: 13.6875rem;
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__plus {
    width: 100%;
    margin-top: 1.5rem;
  }
}
.p-top-pricing-table__plus-txt {
  font-size: 1.125rem;
  line-height: 1.6666666667;
  font-weight: 700;
  border: rgba(119, 210, 255, 0.49) solid 0.125rem;
  border-radius: 0.625rem;
  width: 13.6875rem;
  height: 3rem;
  display: grid;
  place-content: center;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__plus-txt {
    width: 100%;
    height: 3.875rem;
    font-size: 1.25rem;
  }
}
.p-top-pricing-table__plus-img {
  width: 1.75rem;
  -webkit-filter: drop-shadow(0.1875rem 0.1875rem 0.75rem rgba(0, 0, 0, 0.08));
          filter: drop-shadow(0.1875rem 0.1875rem 0.75rem rgba(0, 0, 0, 0.08));
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  margin-inline: auto;
  margin-top: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__plus-img {
    width: 2.25rem;
    margin-top: 1.125rem;
  }
}
.p-top-pricing-table__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0;
  margin-top: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__list {
    margin-top: 1.25rem;
  }
}
.p-top-pricing-table__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.4375rem;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__item {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.p-top-pricing-table__item::before {
  content: "";
  display: block;
  background: url(../img/top/icon_pricing_checkmark.svg) no-repeat 50% 50%/contain;
  width: 0.9375rem;
  aspect-ratio: 1/1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.p-top-pricing-table__item-txt {
  font-size: 1rem;
  line-height: 1.875;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-top-pricing-table__item-txt {
    font-size: 1.125rem;
    white-space: nowrap;
  }
}
.p-top-support {
  position: relative;
  overflow: hidden;
}
.p-top-support__bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.p-top-support__bg-1 {
  position: absolute;
  top: -5.875rem;
  left: -5.75rem;
  background: url(../img/top/bg_support01_1.svg) no-repeat 50% 50%/contain;
  width: 17.125rem;
  height: 16.75rem;
}
@media screen and (min-width: 768px) {
  .p-top-support__bg-1 {
    top: -16rem;
    left: -14.875rem;
    background: url(../img/top/bg_support01_1_pc.svg) no-repeat 50% 50%/contain;
    width: 46.1875rem;
    height: 45.125rem;
  }
}
.p-top-support__bg-2 {
  position: absolute;
  bottom: -15.6875rem;
  left: -8.625rem;
  background: url(../img/top/bg_support01_2.svg) no-repeat 50% 50%/contain;
  width: 31.75rem;
  height: 31.5625rem;
}
@media screen and (min-width: 768px) {
  .p-top-support__bg-2 {
    bottom: -43.375rem;
    left: unset;
    right: 0;
    background: url(../img/top/bg_support01_2_pc.svg) no-repeat 50% 50%/contain;
    width: 86.75rem;
    height: 86.3125rem;
  }
}
.p-top-support__inner {
  padding-block: 4.5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-support__inner {
    padding-block: 7.875rem 10rem;
  }
}
.p-top-support__tit {
  text-align: center;
  line-height: 1.2;
}
.p-top-support__txt {
  font-size: 0.9375rem;
  line-height: 1.6;
  font-weight: 500;
  text-align: center;
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-support__txt {
    font-size: 1rem;
    line-height: 1.875;
  }
}
.p-top-support__frame {
  -webkit-box-shadow: 0 0 0.625rem rgba(129, 183, 245, 0.71);
          box-shadow: 0 0 0.625rem rgba(129, 183, 245, 0.71);
  border-radius: 0.625rem;
  background: #fff;
  margin-top: 2rem;
  padding-block: 1.75rem;
  padding-inline: 1rem 0.9375rem;
}
@media screen and (min-width: 768px) {
  .p-top-support__frame {
    border-radius: 0.75rem;
    padding-block: 2.125rem 2.3125rem;
    padding-inline: 2.9375rem 2.0625rem;
  }
}
.p-top-support__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-top-support__list {
    gap: 0.8125rem;
  }
}
.p-top-support__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5625rem;
}
@media screen and (min-width: 768px) {
  .p-top-support__item {
    gap: 0.875rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.p-top-support__item::before {
  content: "";
  display: block;
  background: url(../img/top/icon_checkmark.svg) no-repeat 50% 50%/contain;
  width: 1.3125rem;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  aspect-ratio: 1/1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .p-top-support__item::before {
    width: 1.5625rem;
  }
}
.p-top-support__label {
  font-size: 0.9375rem;
  line-height: 1.4666666667;
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  .p-top-support__label {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.p-top-faq {
  background: #F7FCFF;
  overflow: hidden;
}
.p-top-faq__inner {
  padding-block: 3.5rem 4.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-faq__inner {
    padding-block: 7.5rem 10rem;
  }
}
.p-top-faq__tit {
  text-align: center;
}
.p-top-faq__list {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}
@media screen and (min-width: 768px) {
  .p-top-faq__list {
    margin-top: 4rem;
    gap: 2.5rem;
  }
}
.p-top-faq__item {
  -webkit-box-shadow: 0.1875rem 0.1875rem 0.625rem rgba(0, 0, 0, 0.08);
          box-shadow: 0.1875rem 0.1875rem 0.625rem rgba(0, 0, 0, 0.08);
  border-radius: 0.625rem;
  overflow: hidden;
}
.p-top-faq__question {
  text-align: left;
  background: #EDF8FF;
  width: 100%;
  padding-block: 1.125rem;
  padding-inline: 1rem 2.375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  position: relative;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media (hover: hover) {
  .p-top-faq__question:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
  .p-top-faq__question:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}
@media screen and (min-width: 768px) {
  .p-top-faq__question {
    gap: 1rem;
    padding-block: 1.5625rem 1.5rem;
    padding-inline: 3.5rem 4.375rem;
  }
}
.p-top-faq__question::before {
  content: "Q";
  display: block;
  font-size: 1.25rem;
  line-height: 1.18;
  font-weight: 700;
  font-family: "M PLUS 2", sans-serif;
  color: #00A1EB;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
@media screen and (min-width: 768px) {
  .p-top-faq__question::before {
    font-size: 1.375rem;
    line-height: 1.08;
  }
}
.p-top-faq__question[data-js-acc-status=open] .p-top-faq__question-icon::after {
  rotate: 0deg;
}
.p-top-faq__question-label {
  font-size: 1rem;
  line-height: 1.625;
  font-weight: 700;
  color: #222222;
}
@media screen and (min-width: 768px) {
  .p-top-faq__question-label {
    font-size: 1.125rem;
  }
}
.p-top-faq__question-icon {
  position: absolute;
  top: 50%;
  right: 1.5rem;
  translate: 0% -50%;
  width: 1rem;
  aspect-ratio: 1/1;
  display: block;
}
@media screen and (min-width: 768px) {
  .p-top-faq__question-icon {
    width: 1.25rem;
    right: 3.125rem;
  }
}
.p-top-faq__question-icon::before, .p-top-faq__question-icon::after {
  content: "";
  display: block;
  background: #00A1EB;
  width: 100%;
  height: 0.125rem;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  -webkit-transition: all 300ms;
  transition: all 300ms;
}
.p-top-faq__question-icon::after {
  rotate: 90deg;
}
.p-top-faq__answer {
  text-align: left;
  background: #ffffff;
  width: 100%;
  padding-block: 1.125rem 1.25rem;
  padding-inline: 1.125rem 4.25rem;
  position: relative;
  display: none;
}
@media screen and (min-width: 768px) {
  .p-top-faq__answer {
    padding-block: 1.375rem 1.75rem;
    padding-inline: 3.5rem 10.125rem;
  }
}
.p-top-faq__answer-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-faq__answer-inner {
    gap: 1.125rem;
  }
}
.p-top-faq__answer-inner::before {
  content: "A";
  display: block;
  font-size: 1.25rem;
  line-height: 1.18;
  font-weight: 700;
  font-family: "M PLUS 2", sans-serif;
  color: #00A1EB;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
@media screen and (min-width: 768px) {
  .p-top-faq__answer-inner::before {
    font-size: 1.375rem;
  }
}
.p-top-faq__answer-txt {
  font-size: 0.9375rem;
  line-height: 1.6;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-top-faq__answer-txt {
    font-size: 1rem;
    line-height: 1.875;
  }
}
.p-top-contact {
  background: #EDF8FF;
  overflow: hidden;
}
.p-top-contact__inner {
  padding-block: 3.5rem 4.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-contact__inner {
    padding-block: 7.5rem 10rem;
  }
}
.p-top-contact__tit {
  text-align: center;
}
.p-top-contact__txt {
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 600;
  text-align: center;
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-top-contact__txt {
    line-height: 1.875;
    margin-top: 1.5rem;
  }
}
.p-top-contact__form {
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-top-contact__form {
    margin-top: 4rem;
    max-width: 56.9375rem;
    margin-inline: auto;
  }
}
.p-top-cta {
  position: relative;
  margin-top: -1px;
  background: linear-gradient(-30deg, #164779 10%, #346EAC 50%, #1D5288 90%);
  overflow: hidden;
}
.p-top-cta__inner {
  padding-block: 2.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-cta__inner {
    padding-block: 3.5rem;
    max-width: unset;
  }
}
.p-top-cta__txt {
  font-size: 1.375rem;
  line-height: 1.4545454545;
  font-weight: 700;
  color: #ffffff;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-top-cta__txt {
    font-size: 2.25rem;
    line-height: 1.5555555556;
  }
}
.p-top-cta__txt-1 {
  font-size: 1rem;
  line-height: 1.75;
  display: block;
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-top-cta__txt-1 {
    font-size: 1.875rem;
    line-height: 1.6666666667;
    margin-top: 0;
  }
}
.p-top-cta__btn {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-cta__btn {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    margin-top: 2.6875rem;
  }
}

.p-form-contact label {
  font-size: 1rem;
  line-height: 1;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.25rem;
}
@media screen and (min-width: 768px) {
  .p-form-contact label {
    font-size: 1.125rem;
    gap: 0.625rem;
  }
}
.p-form-contact .hs-form-required {
  font-size: 0;
}
.p-form-contact .hs-form-required::before {
  content: "必須";
  background: #00A1EB;
  width: 2.1875rem;
  height: 1.1875rem;
  color: #ffffff;
  font-size: 0.75rem;
  font-weight: 500;
  display: grid;
  place-content: center;
  border-radius: 0.25rem;
}
@media screen and (min-width: 768px) {
  .p-form-contact .hs-form-required::before {
    font-size: 0.875rem;
    width: 2.625rem;
    height: 1.4375rem;
    position: relative;
    top: 0.0625rem;
  }
}
.p-form-contact .input {
  background: #ffffff;
  border-radius: 0.5rem;
  width: 100%;
  padding-block: 0.375rem;
  padding-inline: 0.625rem;
  margin-right: 0 !important;
  margin-top: 0.25rem;
}
@media screen and (min-width: 768px) {
  .p-form-contact .input {
    margin-top: 0.75rem;
    padding-block: 0.875rem;
    padding-inline: 1rem;
  }
}
.p-form-contact .hs-input {
  font-size: 1.125rem;
  line-height: 1.75;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-form-contact .hs-input {
    font-size: 1.25rem;
  }
}
.p-form-contact .hs-input::-webkit-input-placeholder {
  color: #CCCCCC;
  font-size: 1.125rem;
}
.p-form-contact .hs-input::-moz-placeholder {
  color: #CCCCCC;
  font-size: 1.125rem;
}
.p-form-contact .hs-input:-ms-input-placeholder {
  color: #CCCCCC;
  font-size: 1.125rem;
}
.p-form-contact .hs-input::-ms-input-placeholder {
  color: #CCCCCC;
  font-size: 1.125rem;
}
.p-form-contact .hs-input::placeholder {
  color: #CCCCCC;
  font-size: 1.125rem;
}
.p-form-contact .hs-error-msgs label {
  color: red;
  font-size: 0.75rem;
  margin-block: 0.25rem;
}
.p-form-contact .form-columns-1, .p-form-contact .form-columns-2, .p-form-contact .form-columns-0 {
  max-width: unset;
}
.p-form-contact .form-columns-1:nth-of-type(n+2), .p-form-contact .form-columns-2:nth-of-type(n+2), .p-form-contact .form-columns-0:nth-of-type(n+2) {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-form-contact .form-columns-1:nth-of-type(n+2), .p-form-contact .form-columns-2:nth-of-type(n+2), .p-form-contact .form-columns-0:nth-of-type(n+2) {
    margin-top: 1.875rem;
  }
}
.p-form-contact .hs_firstname {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-form-contact .hs_firstname {
    margin-top: 0;
  }
}
.p-form-contact .hs-field-desc {
  font-size: 0.75rem;
  line-height: 1.7;
  margin-top: 0.125rem;
}
@media screen and (min-width: 768px) {
  .p-form-contact .hs-field-desc {
    font-size: 0.875rem;
  }
}
.p-form-contact .hs-richtext {
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 700;
  text-align: center;
  max-width: 18.5rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-form-contact .hs-richtext {
    font-size: 1.125rem;
    line-height: 2.2222222222;
    max-width: unset;
  }
}
.p-form-contact .hs-richtext a {
  color: #00A1EB;
}
.p-form-contact .hs-button {
  width: 20.9375rem;
  height: 4rem;
  background: #00A1EB;
  border-radius: 2.5rem;
  display: grid;
  place-content: center;
  font-size: 1rem;
  line-height: 1;
  font-weight: 800;
  color: #ffffff;
  -webkit-transition: opacity 300ms;
  transition: opacity 300ms;
}
@media screen and (min-width: 768px) {
  .p-form-contact .hs-button {
    width: 17.6875rem;
    font-size: 1.125rem;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
  }
}
@media screen and (min-width: 768px) {
  .p-form-contact .hs-button:hover {
    opacity: 0.7;
  }
}
.p-form-contact .actions {
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-form-contact .actions {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    margin-top: 1.5rem;
  }
}
.p-form-contact .hs-form-field {
  width: 100% !important;
}
@media screen and (min-width: 768px) {
  .p-form-contact .form-columns-2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 2rem;
  }
}
.p-form-contact select {
  -webkit-appearance: auto;
  -moz-appearance: auto;
  appearance: auto;
  color: #222222;
}
.p-form-contact .hs_recaptcha .input {
  background: unset;
  border-radius: unset;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding-block: 0;
  padding-inline: 0;
  margin-top: 1.5rem;
  margin-inline: auto !important;
}
.p-form-contact [name=firstname], .p-form-contact [name=lastname] {
  width: 100%;
}
.p-form-contact .hs_submit {
  position: relative;
  z-index: 100;
}
.p-form-contact .hs_recaptcha {
  overflow: hidden;
}

.p-form-contact--download .input {
  background: #F5F5F5;
}
@media screen and (min-width: 768px) {
  .p-form-contact--download .form-columns-2 {
    gap: 1.125rem;
  }
}
.p-splitfade {
  position: relative;
  width: 100%;
  aspect-ratio: 7/4;
  overflow: hidden;
  -webkit-mask: var(--img) no-repeat 50% 50%/contain;
          mask: var(--img) no-repeat 50% 50%/contain;
  --dur: .9s;
  --gap: .4s;
  --easing: cubic-bezier(.2, .6, .2, 1);
  --start: 0s;
}
.p-splitfade__base {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  opacity: 0;
  -webkit-transition: opacity 0.6s var(--easing), scale 3000ms;
  transition: opacity 0.6s var(--easing), scale 3000ms;
  will-change: opacity;
  z-index: 10;
}
.p-splitfade__slice {
  position: absolute;
  inset: 0;
  background-image: var(--img);
  background-size: cover;
  background-position: center;
  opacity: 0;
  -webkit-transform: translateX(0.75rem);
          transform: translateX(0.75rem);
  -webkit-animation: splitfade-in var(--dur) var(--easing) forwards;
          animation: splitfade-in var(--dur) var(--easing) forwards;
  -webkit-animation-delay: calc(var(--start) + (var(--i) - 1) * var(--gap));
          animation-delay: calc(var(--start) + (var(--i) - 1) * var(--gap));
  will-change: opacity, transform;
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
}
.p-splitfade__slice[data-slice=top] {
  clip-path: inset(0 0 66.667% 0);
}
.p-splitfade__slice[data-slice=middle] {
  clip-path: inset(33.333% 0 33.333% 0);
}
.p-splitfade__slice[data-slice=bottom] {
  clip-path: inset(66.667% 0 0 0);
}
.p-splitfade.is-playing .p-splitfade__slice {
  -webkit-animation-play-state: running;
          animation-play-state: running;
}
.p-splitfade.is-merged .p-splitfade__base {
  opacity: 1;
  scale: 1.05;
}
@-webkit-keyframes splitfade-in {
  from {
    opacity: 0;
    -webkit-transform: translateX(0.75rem);
            transform: translateX(0.75rem);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes splitfade-in {
  from {
    opacity: 0;
    -webkit-transform: translateX(0.75rem);
            transform: translateX(0.75rem);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .p-splitfade__slice, .p-splitfade__base {
    -webkit-animation: none;
            animation: none;
    -webkit-transition: none;
    transition: none;
    -webkit-transform: none;
            transform: none;
  }
  .p-splitfade__base {
    opacity: 1;
  }
}

@media screen and (min-width: 768px) {
  .p-stack {
    position: relative;
  }
  .p-stack__panel {
    position: sticky;
    top: -15.625rem;
    min-height: 100svh;
  }
}
.p-thanks {
  background: url(../img/thanks/bg03.svg) no-repeat 50% 100%/13.375rem 7.5625rem, url(../img/thanks/bg02.svg) no-repeat calc(100% + 6.5625rem) calc(100% + 7.125rem)/20.4375rem 19.9375rem, url(../img/thanks/bg01.svg) no-repeat 0% 0%/15.625rem 14.25rem;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-thanks {
    background: url(../img/thanks/bg03.svg) no-repeat 50% 100%/23.1875rem 13.1875rem, url(../img/thanks/bg02_pc.svg) no-repeat calc(100% + 42.1875rem) calc(100% + 8.0625rem)/73.6875rem 71.875rem, url(../img/thanks/bg01_pc.svg) no-repeat calc(0% - 21.8125rem) calc(0% - 37.375rem)/69.25rem 67rem;
  }
}
.p-thanks__inner {
  padding-block: 8.75rem 11.125rem;
}
@media screen and (min-width: 768px) {
  .p-thanks__inner {
    max-width: unset;
    padding-block: 11rem 16.1875rem;
  }
}
.p-thanks__tit {
  text-align: center;
}
.p-thanks__txt1 {
  font-size: 0.9375rem;
  line-height: 1.7333333333;
  font-weight: 700;
  margin-top: 2rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-thanks__txt1 {
    font-size: 1.5rem;
    line-height: 2;
    margin-top: 4rem;
  }
}
.p-thanks__txt2 {
  font-size: 0.875rem;
  line-height: 1.6428571429;
  font-weight: 500;
  margin-top: 2rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-thanks__txt2 {
    font-size: 1.125rem;
    line-height: 1.7777777778;
    margin-top: 1.5rem;
  }
}
.p-thanks__btn1 {
  margin-top: 2.5rem;
  max-width: 17.5rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-thanks__btn1 {
    margin-top: 4rem;
    max-width: 23.25rem;
  }
}

.p-download {
  background: url(../img/thanks/bg02.svg) no-repeat calc(100% + 6.5625rem) calc(100% + 7.125rem)/20.4375rem 19.9375rem, url(../img/thanks/bg01.svg) no-repeat 0% 0%/15.625rem 14.25rem;
  padding-block: 7.5rem 4.5rem;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-download {
    background: url(../img/thanks/bg02_pc.svg) no-repeat calc(100% + 42.1875rem) calc(100% + 8.0625rem)/73.6875rem 71.875rem, url(../img/thanks/bg01_pc.svg) no-repeat calc(0% - 21.8125rem) calc(0% - 37.375rem)/69.25rem 67rem;
    padding-block: 11rem 8.75rem;
  }
}
@media screen and (min-width: 768px) {
  .p-download__inner {
    max-width: 78.125rem;
  }
}
.p-download__subtit {
  font-size: 0.9375rem;
  line-height: 1.4666666667;
  letter-spacing: -0.02em;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-download__subtit {
    font-size: 1.125rem;
    letter-spacing: 0;
  }
}
.p-download__tit {
  text-align: center;
  line-height: 1.2;
  margin-top: 0.25rem;
}
.p-download__tit-1 {
  font-size: 1.8125rem;
  font-weight: 800;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-download__tit-1 {
    font-size: 3rem;
  }
}
@media screen and (min-width: 768px) {
  .p-download__tit-1a {
    font-size: 2rem;
  }
}
.p-download__tit-2 {
  font-size: 1.4375rem;
  font-weight: 800;
}
@media screen and (min-width: 768px) {
  .p-download__tit-2 {
    font-size: 2.5rem;
  }
}
@media screen and (min-width: 768px) {
  .p-download__tit-2a {
    font-size: 2rem;
  }
}
.p-download__tit-3 {
  font-size: 1.5625rem;
  font-weight: 800;
  letter-spacing: -0.04em;
}
@media screen and (min-width: 768px) {
  .p-download__tit-3 {
    font-size: 2.5rem;
    letter-spacing: 0;
  }
}
.p-download__tit-c1 {
  font-size: 1.5625rem;
  font-weight: 800;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-download__tit-c1 {
    font-size: 2.5rem;
  }
}
.p-download__tit-p1 {
  font-size: 1.5625rem;
  font-weight: 800;
}
@media screen and (min-width: 768px) {
  .p-download__tit-p1 {
    font-size: 2.5rem;
  }
}
.p-download__tit-p2 {
  font-size: 1.5625rem;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-download__tit-p2 {
    font-size: 2.5rem;
    letter-spacing: 0;
  }
}
@media screen and (min-width: 768px) {
  .p-download__flexbox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 5rem;
  }
}
@media screen and (min-width: 768px) {
  .p-download__left {
    width: 33rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}
.p-download__img {
  margin-top: 2.5rem;
  -webkit-box-shadow: 0.1875rem 0.1875rem 1.25rem rgba(0, 0, 0, 0.12);
          box-shadow: 0.1875rem 0.1875rem 1.25rem rgba(0, 0, 0, 0.12);
}
@media screen and (min-width: 768px) {
  .p-download__img {
    margin-top: 0;
  }
}
.p-download__tit2 {
  font-size: 1rem;
  line-height: 1.625;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.25rem;
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-download__tit2 {
    margin-top: 3rem;
    font-size: 1.5rem;
    line-height: 1.25;
    gap: 0.4375rem;
  }
}
.p-download__tit2::before {
  content: "";
  display: block;
  background: #00A1EB;
  -webkit-mask: url(../img/top/icon_checkmark.svg) no-repeat 50% 50%/contain;
          mask: url(../img/top/icon_checkmark.svg) no-repeat 50% 50%/contain;
  width: 1.375rem;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  aspect-ratio: 1/1;
  position: relative;
  top: 0.125rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .p-download__tit2::before {
    width: 1.5625rem;
  }
}
.p-download__tit2--p1 {
  margin-top: 3rem;
}
@media screen and (min-width: 768px) {
  .p-download__tit2--p1 {
    margin-top: 0;
    white-space: nowrap;
  }
}
.p-download__tit2-blue {
  font-weight: 800;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-download__tit2-blue {
    font-size: 1.625rem;
  }
}
.p-download__txt {
  font-size: 0.9375rem;
  line-height: 1.6;
  font-weight: 500;
  margin-top: 1.375rem;
}
@media screen and (min-width: 768px) {
  .p-download__txt {
    font-size: 1rem;
    line-height: 1.5;
    margin-top: 1.25rem;
  }
}
@media screen and (min-width: 768px) {
  .p-download__txt--p1 {
    max-width: 32.125rem;
  }
}
.p-download__img2 {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-download__img2 {
    margin-top: 1.75rem;
    width: 32.875rem;
  }
}
.p-download-note {
  border-radius: 0.5rem;
  background: #F5F5F5;
  padding-block: 1.25rem 1.3125rem;
  padding-inline: 1.5rem 1.25rem;
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-download-note {
    padding-block: 1.5rem 2.25rem;
    padding-inline: 1.875rem;
    margin-top: 3rem;
  }
}
.p-download-note__tit {
  font-size: 1rem;
  line-height: 1.875;
  font-weight: 700;
  color: #00A1EB;
}
@media screen and (min-width: 768px) {
  .p-download-note__tit {
    font-size: 1.5rem;
    line-height: 1.25;
  }
}
.p-download-note__txt2 {
  font-size: 0.875rem;
  line-height: 1.2142857143;
  font-weight: 500;
  margin-top: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__txt2 {
    font-size: 1rem;
    line-height: 1.75;
    margin-top: 0.6875rem;
  }
}
.p-download-note__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.375rem;
  margin-top: 0.375rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__list {
    margin-top: 1.25rem;
  }
}
.p-download-note__list--p1 {
  margin-top: 0.75rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__list--p1 {
    margin-top: 1.5rem;
  }
}
.p-download-note__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.25rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__item {
    gap: 0.5rem;
  }
}
.p-download-note__item::before {
  content: "";
  display: block;
  background: #00A1EB;
  border-radius: 624.9375rem;
  width: 0.375rem;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  aspect-ratio: 1/1;
  position: relative;
  top: 0.375rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__item::before {
    width: 0.625rem;
    top: 0.5625rem;
  }
}
.p-download-note__txt {
  font-size: 0.875rem;
  line-height: 1.2142857143;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-download-note__txt {
    font-size: 1.125rem;
    line-height: 1.45;
  }
}
@media screen and (min-width: 768px) {
  .p-download-note__txt--c1 {
    font-size: 1rem;
    line-height: 1.58;
  }
}
.p-download-note__txt-1 {
  margin-top: 0.3125rem;
  display: block;
}
@media screen and (min-width: 768px) {
  .p-download-note__txt-1 {
    margin-top: 0.0625rem;
  }
}
.p-download-note__btn {
  margin-top: 1.25rem;
  max-width: 17.5rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__btn {
    width: 16.4375rem;
    margin-top: 1.75rem;
  }
}
.p-download-note__btn a {
  height: 3.375rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__btn a {
    width: 16.4375rem;
    border-width: 0.1875rem;
  }
}
@media screen and (min-width: 768px) {
  .p-download-note__btn a span {
    font-size: 0.9375rem;
  }
}
.p-download-note__corp {
  border-radius: 0.625rem;
  background: #ffffff;
  padding-block: 0.75rem 1.125rem;
  padding-inline: 0.75rem;
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__corp {
    margin-top: 1.5rem;
    padding-block: 1.4375rem 2.3125rem;
    padding-inline: 1.375rem;
  }
}
.p-download-note__corp-tit {
  font-size: 1rem;
  line-height: 1.875;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .p-download-note__corp-tit {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.p-download-note__corp-img {
  margin-top: 0.1875rem;
}
@media screen and (min-width: 768px) {
  .p-download-note__corp-img {
    margin-top: 0.25rem;
  }
}
.p-download__inner2 {
  border-radius: 0.625rem;
  background: #ffffff;
  padding-block: 3.1875rem 2.25rem;
  padding-inline: 1.25rem;
  margin-top: 2.5rem;
  max-width: unset;
  width: 23.4375rem;
  position: relative;
  left: -1.25rem;
}
@media screen and (min-width: 768px) {
  .p-download__inner2 {
    margin-top: 0;
    width: 36.3125rem;
    padding-block: 2rem 2.25rem;
    padding-inline: 2.125rem;
    left: unset;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
  }
}
.u-desktop-inline {
  display: none;
}
@media screen and (min-width: 768px) {
  .u-desktop-inline {
    display: inline-block;
  }
}

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

.u-mobile-inline {
  display: inline-block;
}
@media screen and (min-width: 768px) {
  .u-mobile-inline {
    display: none;
  }
}

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

.u-text--blue {
  color: #00A1EB;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .u-text--blue-desktop {
    color: #00A1EB;
    font-weight: 700;
  }
}
.u-text--blue2 {
  color: #77D2FF;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .u-text--blue2-desktop {
    color: #77D2FF;
    font-weight: 700;
  }
}
.u-text--white {
  color: #ffffff;
  font-weight: 700;
}
.u-text--green {
  color: #57E291;
  font-weight: 700;
}

.u-shadow {
  -webkit-filter: drop-shadow(0.1875rem 0.1875rem 0.625rem rgba(0, 0, 0, 0.12));
          filter: drop-shadow(0.1875rem 0.1875rem 0.625rem rgba(0, 0, 0, 0.12));
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}

.u-index {
  z-index: var(--z, 1);
  position: relative;
}

.u-overflow--hidden {
  overflow: hidden;
}