@charset "UTF-8";
/* リキッドレイアウト対応 */
@media screen and (max-width: 767px) {
  .u-desktop {
    display: none;
  }
}

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

html {
  font-size: 16px;
}
@media (max-width: 1600px) {
  html {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: 16px;
  }
}
@media (max-width: 393px) {
  html {
    font-size: 4.0712468193vw;
  }
}

/* pcの電話番号発信対応 */
@media screen and (max-width: 767px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

/* ホバー */
a {
  -webkit-text-decoration: none;
  color: inherit;
  text-decoration: none;
  transition: opacity 0.3s;
}
@media screen and (max-width: 767px) {
  a:hover {
    opacity: 0.8;
  }
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default padding */
ul,
ol {
  padding: 0;
}

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

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

/* Set core body defaults */
body {
  color: #323232;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5;
  min-height: 100vh;
  text-rendering: optimizeSpeed;
}

/* Remove list styles on ul, ol elements with a class attribute */
ul,
ol {
  list-style: none;
}

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

/* Make images easier to work with */
img {
  display: block;
  max-width: 100%;
  width: 100%;
}

/* Natural flow and rhythm in articles by default */
article > * + * {
  margin-top: 1em;
}

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

/* Blur images when they have no alt attribute */
img:not([alt]) {
  filter: blur(10px);
}

/* フォームリセット */
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=checkbox],
input[type=radio] {
  display: none;
}

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

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

picture {
  display: block;
}

button {
  display: block;
  padding: 0;
  width: 100%;
}

.c-btn {
  align-items: center;
  border: 0.3125rem solid #fff;
  border-radius: 2.5rem;
  box-shadow: 0.25rem 0.25rem 0.5rem rgba(27, 44, 73, 0.4);
  display: inline-flex;
  font-size: 1.25rem;
  font-weight: bold;
  justify-content: center;
  line-height: 1.2;
  padding-bottom: 1.4375rem;
  padding-left: 3.5625rem;
  padding-right: 3.5625rem;
  padding-top: 1.4375rem;
  position: relative;
  transition: all 0.45s;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .c-btn {
    padding-left: 6.25rem;
    padding-right: 1.25rem;
  }
}

@media (hover: hover) {
  .c-btn:hover {
    opacity: 0.7;
  }
}
.c-btn.u-bg-red {
  box-shadow: 0.25rem 0.25rem 1.25rem #efd7de;
}

.c-btn::after,
.c-btn::before {
  border-radius: 50%;
  content: "";
  height: 1.625rem;
  position: absolute;
  right: 1.8125rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.625rem;
}
@media screen and (max-width: 767px) {
  .c-btn::after,
  .c-btn::before {
    height: 1.25rem;
    right: 1.625rem;
    width: 1.25rem;
  }
}

@media screen and (max-width: 767px) {
  .c-btn.u-bg-red::after,
  .c-btn.u-bg-red::before {
    display: none;
  }
}

.c-btn::after {
  z-index: 1;
}

.c-btn::after {
  -webkit-mask: url(../images/arrow.svg) center center/0.4375rem no-repeat;
          mask: url(../images/arrow.svg) center center/0.4375rem no-repeat;
}
@media screen and (max-width: 767px) {
  .c-btn::after {
    -webkit-mask-size: 0.3125rem;
            mask-size: 0.3125rem;
  }
}

.c-btn.u-bg-red::before {
  background-color: #fff;
}

.c-btn.u-bg-red::after {
  background-color: #FF0C01;
}

.c-btn.u-bg-yellow {
  font-size: 1rem;
  padding-left: 7.8125rem;
}
@media screen and (max-width: 767px) {
  .c-btn.u-bg-yellow {
    padding-left: 6.25rem;
  }
}
.c-btn.u-bg-yellow::after, .c-btn.u-bg-yellow::before {
  height: 1.25rem;
  width: 1.25rem;
}
@media screen and (max-width: 767px) {
  .c-btn.u-bg-yellow::after, .c-btn.u-bg-yellow::before {
    right: 1rem;
  }
}

.c-btn.u-bg-yellow::before {
  background-color: #323232;
}

.c-btn.u-bg-yellow::after {
  background-color: #DAE470;
}

.c-btn__img {
  position: absolute;
}

.c-btn__img--01 {
  bottom: 0.125rem;
  left: 0.8125rem;
  width: 6.4375rem;
}
@media screen and (max-width: 767px) {
  .c-btn__img--01 {
    left: 0.5625rem;
    width: 5.25rem;
  }
}

.c-btn__img--02 {
  bottom: 0.3125rem;
  left: 1.875rem;
  width: 6rem;
}
@media screen and (max-width: 767px) {
  .c-btn__img--02 {
    bottom: 0;
    left: 1.5rem;
  }
}

.c-btn__img--03 {
  bottom: 0.125rem;
  left: 1.9375rem;
  width: 5.8125rem;
}
@media screen and (max-width: 767px) {
  .c-btn__img--03 {
    bottom: 0;
  }
}

.c-card {
  border-radius: 0.625rem;
  box-shadow: 0 0.25rem 1.875rem #fcd8d4;
  height: 100%;
  min-height: 11.25rem;
  padding-bottom: 0.75rem;
  padding-left: 0.25rem;
  padding-right: 0.25rem;
  padding-top: 1.5rem;
}

.c-card__title {
  font-size: 1.25rem;
  font-weight: bold;
  padding-bottom: 1.25rem;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .c-card__title {
    margin-left: auto;
    margin-right: auto;
    text-align: left;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.c-card__title::before {
  background: radial-gradient(circle farthest-side, #FF9B81, #FF9B81 40%, transparent 40%, transparent);
  background-size: 0.4375rem;
  bottom: 0;
  content: "";
  display: inline-block;
  height: 0.625rem;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 100%;
  width: 2.625rem;
}

.c-card__text {
  font-size: 1rem;
  margin-top: 1rem;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

.c-company {
  grid-gap: 0;
  border-radius: 0.625rem;
  box-shadow: 0 0.25rem 1.875rem #fcd8d4;
  display: grid;
  gap: 0;
  grid-row: span 3;
  grid-template-rows: subgrid;
  height: 100%;
  padding: 1.5rem;
  padding-top: 1.25rem;
}

.c-company__title {
  grid-gap: 0.75rem;
  align-items: center;
  display: grid;
  font-size: 1.25rem;
  gap: 0.75rem;
  grid-template-columns: 3.5625rem 1fr;
}

.c-company__title::before {
  background-image: var(--icon-url);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 3.75rem;
  width: 3.75rem;
}

.p-company__list:nth-child(1 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_01.svg);
}

.p-company__list:nth-child(2 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_02.svg);
}

.p-company__list:nth-child(3 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_03.svg);
}

.p-company__list:nth-child(4 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_04.svg);
}

.p-company__list:nth-child(5 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_05.svg);
}

.p-company__list:nth-child(6 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_06.svg);
}

.p-company__list:nth-child(7 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_07.svg);
}

.p-company__list:nth-child(8 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_08.svg);
}

.p-company__list:nth-child(9 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_09.svg);
}

.p-company__list:nth-child(10 of .p-company__list) .c-company__title::before {
  --icon-url: url(../images/icon-company_010.svg);
}

.c-company__lead {
  color: #D4163F;
  font-size: 1rem;
  font-weight: bold;
  line-height: 1.5;
  margin-top: 1.25rem;
}

.c-company__text {
  background-color: #F5F5F5;
  font-size: 0.875rem;
  font-weight: 500;
  margin-top: 1.25rem;
  padding: 0.5rem;
}

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

.c-title__en {
  font-size: 7.5rem;
  font-style: italic;
  font-weight: 900;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .c-title__en {
    font-size: 3rem;
  }
}

.c-title__ja {
  font-size: 2rem;
  font-weight: bold;
  margin-top: 0.5rem;
}
@media screen and (max-width: 767px) {
  .c-title__ja {
    font-size: 1.25rem;
  }
}

.l-inner {
  height: inherit;
  margin: 0 auto;
  max-width: calc(75rem + 50px);
  padding-left: 25px;
  padding-right: 25px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .l-inner {
    max-width: 33.75rem;
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

.p-about {
  background: url(../images/bg_clip.webp) center top/100% auto no-repeat, #FFF5F4 url(../images/bg_about.webp) center 5.46875vw/min(90.3125vw, 108.375rem) no-repeat;
  padding-bottom: 7.5rem;
  padding-top: 3.75rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-about {
    background: url(../images/bg_clip_sp.webp) center top/100% auto no-repeat, #FFF5F4 url(../images/bg_about_sp.webp) center 26.972vw/min(91.6vw, 33.75rem) no-repeat;
    padding-bottom: 5rem;
    padding-top: 1.875rem;
  }
}

.p-about__title {
  font-size: 3rem;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-about__title {
    font-size: 2rem;
  }
}

.p-about__title small {
  display: block;
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .p-about__title small {
    font-size: 1.5rem;
  }
}

.p-about__img {
  margin-left: auto;
  margin-right: auto;
  margin-top: 5.625rem;
  max-width: 39.25rem;
}
@media screen and (max-width: 767px) {
  .p-about__img {
    margin-top: 5.375rem;
    max-width: 91.2181303116%;
  }
}

.p-about__blocks {
  grid-gap: 3.5rem;
  display: grid;
  gap: 3.5rem;
}
@media screen and (max-width: 767px) {
  .p-about__blocks {
    gap: 2.5rem;
  }
}

.p-about__blockTitle {
  align-items: center;
  background: linear-gradient(215deg, #EE3D48, #FD564C);
  border: 0.25rem solid #323232;
  border-radius: 0.625rem 0.625rem 0 0;
  display: flex;
  font-size: 1.875rem;
  font-weight: 700;
  gap: 1.5rem;
  justify-content: center;
  padding-bottom: 0.5rem;
  padding-top: 0.5rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-about__blockTitle {
    flex-direction: column;
    font-size: 1.25rem;
    gap: 0.5rem;
    line-height: 1;
    padding-bottom: 0.75rem;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
    padding-top: 0.75rem;
    text-align: center;
  }
}

.p-about__blockTitle::before {
  background: var(--icon-url) center center/contain no-repeat;
  content: "";
  display: block;
  height: 3.75rem;
  width: 3.75rem;
}

.p-about__block:nth-child(1 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-01.svg);
}

.p-about__block:nth-child(2 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-02.svg);
}

.p-about__block:nth-child(3 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-03.svg);
}

.p-about__block:nth-child(4 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-04.svg);
}

.p-about__block:nth-child(5 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-05.svg);
}

.p-about__block:nth-child(6 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-06.svg);
}

.p-about__block:nth-child(7 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-07.svg);
}

.p-about__block:nth-child(8 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-08.svg);
}

.p-about__block:nth-child(9 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-09.svg);
}

.p-about__block:nth-child(10 of .p-about__block) .p-about__blockTitle::before {
  --icon-url: url(../images/icon-010.svg);
}

.p-about__body {
  --list-width: max(calc(100% / 3 - 2.5rem * 2/3), 21.25rem);
  border-radius: 0 0 0.625rem 0.625rem;
  contain: content;
  margin-top: -0.25rem;
  padding-bottom: 2.5rem;
  padding-left: 3rem;
  padding-right: 3rem;
  padding-top: 2.5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-about__body {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
}
.p-about__body::before {
  -webkit-mask-image: conic-gradient(red), conic-gradient(red);
  -webkit-mask-clip: padding-box, border-box;
  -webkit-mask-composite: xor;
  background-image: linear-gradient(215deg in oklab, #EE3D48, #FD564C);
  background-origin: border-box;
  border: 0.25rem solid transparent;
  border-radius: 0 0 0.625rem 0.625rem;
  bottom: 0;
  content: "";
  left: 0;
          mask-clip: padding-box, border-box;
          mask-composite: exclude;
          mask-image: conic-gradient(red), conic-gradient(red);
  position: absolute;
  right: 0;
  top: 0;
  z-index: -1;
}

.p-about__lists {
  display: flex;
  flex-wrap: wrap;
  gap: 2.5rem;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-about__lists {
    gap: 1.5rem;
  }
}

.p-about__lists.--grid2 {
  margin-left: auto;
  margin-right: auto;
  max-width: calc(var(--list-width) * 2 + 2.5rem);
}

.p-about__list {
  width: var(--list-width);
}

.p-about__btns {
  display: flex;
  gap: 5.3125rem;
  justify-content: center;
  margin-top: 3.5rem;
}
@media screen and (max-width: 767px) {
  .p-about__btns {
    align-items: center;
    flex-direction: column;
    gap: 2.5rem;
    margin-top: 1.875rem;
  }
}

.p-about__btn {
  width: 23.125rem;
}
@media screen and (max-width: 767px) {
  .p-about__btn {
    max-width: 29.625rem;
    width: 100%;
  }
}

.p-company {
  background: url(../images/company_vector_01.webp) top left/23.0625rem auto no-repeat, url(../images/company_vector_02.webp) bottom right/19.25rem auto no-repeat, linear-gradient(150deg, #F12860, #D51340 40%, #F44849 90%);
  padding-bottom: 4.5rem;
  padding-top: 5rem;
}
@media screen and (max-width: 767px) {
  .p-company {
    background: url(../images/company_vector_01_sp.webp) top center/100% auto no-repeat, linear-gradient(150deg, #F12860, #D51340 40%, #F44849 90%);
    padding-bottom: 4rem;
    padding-top: 2.5rem;
  }
}

@media screen and (max-width: 767px) {
  .p-company .l-inner {
    max-width: none;
    max-width: initial;
  }
}

.p-company__lists {
  grid-gap: 1.125rem;
  display: grid;
  gap: 1.125rem;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 3.375rem;
}
@media screen and (max-width: 767px) {
  .p-company__lists {
    grid-template-columns: repeat(2, 1fr);
    margin-top: 4rem;
  }
}
@media screen and (max-width: 600px) {
  .p-company__lists {
    grid-template-columns: 100%;
  }
}

.p-company__list {
  display: contents;
}

.p-footer {
  background: linear-gradient(150deg, #F12860, #D51340 40%, #F44849 90%);
  padding-bottom: 5rem;
  padding-top: 5rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-footer {
    padding-bottom: 2.5rem;
    padding-top: 2.5rem;
  }
}

.p-footer::before {
  background: url(../images/bg_dot_transparent.webp) center center/100% repeat;
  content: "";
  height: 100%;
  left: 0;
  mix-blend-mode: multiply;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
}

.p-footer__box {
  background-color: #fff;
  border-radius: 0.625rem;
  margin-left: auto;
  margin-right: auto;
  max-width: 59.875rem;
  padding-bottom: 5.1875rem;
  padding-top: 5.8125rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-footer__box {
    border-radius: 0;
    max-width: 20.5rem;
    padding-bottom: 1.5rem;
    padding-top: 1.5rem;
  }
}

.p-footer__logo {
  margin-left: auto;
  margin-right: auto;
  max-width: 26.9375rem;
}
@media screen and (max-width: 767px) {
  .p-footer__logo {
    max-width: 9.25rem;
  }
}

.p-footer__title {
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 2.0555555556;
  margin-top: 0.125rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-footer__title {
    display: none;
  }
}

.p-footer__text {
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.7222222222;
  margin-top: 1.875rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-footer__text {
    font-size: 0.875rem;
    line-height: 1.7142857143;
    margin-top: 1rem;
  }
}

.p-footer__install {
  margin-top: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-footer__install {
    margin-top: 1rem;
  }
}

.p-footer__text2 {
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 2.0555555556;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-footer__text2 {
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.7142857143;
  }
}

.p-footer__btns {
  grid-gap: 1.375rem;
  align-items: center;
  display: grid;
  gap: 1.375rem;
  grid-template-columns: 14.0625rem 1fr;
  margin-left: auto;
  margin-right: auto;
  margin-top: 0.5rem;
  max-width: 32.25rem;
}
@media screen and (max-width: 767px) {
  .p-footer__btns {
    gap: 0.5rem;
    grid-template-columns: 8.25rem 1fr;
    margin-top: 1rem;
    max-width: 18.75rem;
  }
}

.p-footer__btn a {
  transition: all 0.45s;
}

@media (hover: hover) {
  .p-footer__btn a:hover {
    opacity: 0.8;
  }
}
.p-footer__link {
  margin-top: 0.4375rem;
}

.p-footer__link a {
  align-items: center;
  border: 2px solid #2E70B5;
  color: #2E70B5;
  color: #2E70B5;
  display: flex;
  font-size: 1.25rem;
  font-size: 1.25rem;
  font-weight: 600;
  font-weight: 600;
  height: 4.6875rem;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  transition: all 0.45s;
  width: 32.25rem;
}
@media screen and (max-width: 767px) {
  .p-footer__link a {
    border-radius: 0.375rem;
    border-width: 1px;
    font-size: 0.875rem;
    height: 2.75rem;
    width: 18.625rem;
  }
}

.p-footer__link a::before {
  -webkit-mask: url(../images/arrow.svg) center center/contain no-repeat;
  background-color: #2E70B5;
  content: "";
  height: 0.9375rem;
          mask: url(../images/arrow.svg) center center/contain no-repeat;
  position: absolute;
  right: 2.5625rem;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.45s;
  width: 0.5625rem;
}
@media screen and (max-width: 767px) {
  .p-footer__link a::before {
    right: 1.3125rem;
  }
}

@media (hover: hover) {
  .p-footer__link a:hover {
    background-color: #2E70B5;
    color: #fff;
  }
  .p-footer__link a:hover::before {
    background-color: #fff;
  }
}
.p-footer__wrap {
  grid-gap: 2.9375rem;
  align-items: center;
  display: grid;
  gap: 2.9375rem;
  grid-template-columns: 13.875rem 1fr;
  margin-left: auto;
  margin-right: auto;
  margin-top: 1.4375rem;
  max-width: 33.0625rem;
}
@media screen and (max-width: 767px) {
  .p-footer__wrap {
    gap: 0.8125rem;
    grid-template-columns: 8rem 1fr;
    margin-left: auto;
    margin-right: auto;
    margin-top: 1.125rem;
    max-width: 18.75rem;
  }
}

.p-footer__tag {
  background-color: #000;
  border-radius: 0.4375rem;
  color: #fff;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  padding: 0.625rem;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-footer__tag {
    border-radius: 0.25rem;
    font-size: 0.8125rem;
    padding: 0.4375rem;
  }
}

.p-footer__lists {
  list-style: disc;
  margin-left: 1.5em;
  margin-top: 0.625rem;
}
@media screen and (max-width: 767px) {
  .p-footer__lists {
    margin-left: 1em;
    margin-top: 0.3125rem;
  }
}

.p-footer__list {
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .p-footer__list {
    line-height: 1.5;
  }
}

.p-footer-bottom {
  background-color: #000000;
  margin-left: calc(50% - 50cqi);
  margin-right: calc(50% - 50cqi);
  margin-top: 5.3125rem;
  padding-bottom: 2.75rem;
  padding-top: 2.75rem;
}
@media screen and (max-width: 767px) {
  .p-footer-bottom {
    margin-left: -1.3125rem;
    margin-top: 4.6875rem;
    padding-bottom: 1.3125rem;
    padding-top: 1.3125rem;
    width: calc(100% + 1.3125rem + 1.3125rem);
  }
}

.p-footer__bottom-logo {
  margin-left: auto;
  margin-right: auto;
  max-width: 11rem;
}
@media screen and (max-width: 767px) {
  .p-footer__bottom-logo {
    max-width: 14.3125rem;
  }
}

.p-footer__copy {
  color: rgb(255, 255, 255);
  font-size: 1.125rem;
  font-weight: 400;
  margin-top: 2.125rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-footer__copy {
    font-size: 0.625rem;
    margin-top: 1.125rem;
  }
}

.p-intro {
  background-color: #FFF5F4;
  overflow: hidden;
  padding-bottom: 11.5rem;
  padding-top: 7.5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-intro {
    padding-bottom: 0.5625rem;
    padding-top: 3.75rem;
  }
}

.p-intro::before {
  background: url(../images/bg_vector_01.webp) center center/contain no-repeat;
  bottom: -20.9375rem;
  content: "";
  height: 57.5625rem;
  left: -3.875rem;
  pointer-events: none;
  position: absolute;
  width: 57.5625rem;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .p-intro::before {
    bottom: -14.6875rem;
    height: 30.9375rem;
    left: 50%;
    transform: translateX(-50%);
    width: 30.9375rem;
  }
}

.p-intro::after {
  background: url(../images/bg_vector_02.webp) center center/contain no-repeat;
  content: "";
  height: 20.6875rem;
  pointer-events: none;
  position: absolute;
  right: -5.875rem;
  top: 3.25rem;
  width: 20.6875rem;
}

.p-intro__inner {
  max-width: calc(83.25rem + 25px + 25px);
}
@media screen and (max-width: 767px) {
  .p-intro__inner {
    max-width: 33.75rem;
    padding-left: 1.375rem;
    padding-right: 1.375rem;
  }
}

.p-intro__head {
  margin-left: auto;
  margin-right: auto;
  max-width: 21.5rem;
}
@media screen and (max-width: 767px) {
  .p-intro__head {
    max-width: 15.3125rem;
  }
}

.p-intro__wrap {
  grid-gap: 3.7537537538%;
  align-items: flex-start;
  display: grid;
  gap: 3.7537537538%;
  grid-template-columns: 53.1531531532% 1fr;
  margin-top: -2.375rem;
}
@media screen and (max-width: 767px) {
  .p-intro__wrap {
    display: block;
    margin-top: 0.625rem;
  }
}

.p-intro__title {
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.765625;
  padding-bottom: 1.8125rem;
  padding-left: 4.0625rem;
  padding-right: 4.0625rem;
  padding-top: 3.6875rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-intro__title {
    font-size: 2rem;
    line-height: 1.6875;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 0;
    padding-left: 1.6875rem;
    padding-right: 2.125rem;
    padding-top: 2.0625rem;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.p-intro__title::before {
  background: url(../images/commma.svg) center center/contain no-repeat;
  content: "";
  height: 3.625rem;
  left: 0;
  position: absolute;
  top: 0;
  transform: scale(-1, 1);
  width: 4.125rem;
}
@media screen and (max-width: 767px) {
  .p-intro__title::before {
    height: 2.1875rem;
    width: 2.5rem;
  }
}

.p-intro__title::after {
  background: url(../images/commma.svg) center center/contain no-repeat;
  bottom: 0;
  content: "";
  height: 3.625rem;
  position: absolute;
  right: 0;
  width: 4.125rem;
}
@media screen and (max-width: 767px) {
  .p-intro__title::after {
    height: 2.1875rem;
    width: 2.5rem;
  }
}

.p-intro__content {
  margin-top: 4.75rem;
  max-width: 91%;
}
@media screen and (max-width: 767px) {
  .p-intro__content {
    margin-left: auto;
    margin-right: auto;
    margin-top: 2.125rem;
    max-width: 100%;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.p-intro__text {
  font-size: 1.125rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .p-intro__text {
    word-wrap: anywhere;
    padding-left: 0.625rem;
    padding-right: 0.625rem;
    word-break: keep-all;
  }
}

.p-intro__en {
  -webkit-background-clip: text;
  background-clip: text;
  background-image: linear-gradient(to bottom, #FFA8A7, #FFEBE6, transparent);
  bottom: 18.1875rem;
  color: transparent;
  font-family: "Montserrat", sans-serif;
  font-size: 12.5rem;
  font-style: italic;
  font-weight: 900;
  left: 0;
  line-height: 1.5;
  opacity: 0.2;
  position: absolute;
  text-align: center;
  white-space: nowrap;
  width: 100vw;
  z-index: 1;
}

.p-intro__text p + p {
  margin-top: 1.4em;
}

.p-intro__bigText {
  color: #FF0C01;
  font-size: 2.1875rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.6;
  margin-top: 2.25rem;
}
@media screen and (max-width: 767px) {
  .p-intro__bigText {
    font-size: 1.5rem;
    margin-top: 1.5rem;
  }
}

.p-intro__img {
  bottom: 1.875rem;
  left: calc(50% - min(min(46.25vw, 55.5rem), 55.5rem));
  position: absolute;
  width: min(45.8333333333vw, 55rem);
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .p-intro__img {
    bottom: auto;
    bottom: initial;
    left: auto;
    left: initial;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top: 1.4375rem;
    position: relative;
    width: auto;
  }
}

.p-overview {
  background: linear-gradient(to right, #EFEFEF, #fff 25%, #fff 75%, #EFEFEF 100%);
  padding-bottom: 4.5rem;
  padding-top: 5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-overview {
    padding-bottom: 4.0625rem;
  }
}

.p-overview::before {
  background: url(../images/bg_overview.webp) center center/100% no-repeat;
  content: "";
  height: 34.3229166667vw;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 75vw;
}
@media screen and (max-width: 767px) {
  .p-overview::before {
    height: 30.8093994778vw;
    width: 65.3944020356vw;
  }
}

.p-overview::after {
  background: url(../images/bg_overview.webp) center center/100% no-repeat;
  bottom: 0;
  content: "";
  height: 34.3229166667vw;
  pointer-events: none;
  position: absolute;
  right: 0;
  transform: scale(-1, 1);
  width: 75vw;
}
@media screen and (max-width: 767px) {
  .p-overview::after {
    height: 30.8093994778vw;
    width: 65.3944020356vw;
  }
}

.p-overview__title {
  position: relative;
  z-index: 1;
}

.p-overview__main {
  grid-gap: 0 1.25rem;
  background: linear-gradient(to right, #EFEFEF, #fff 25%, #fff 75%, #EFEFEF 100%);
  display: grid;
  gap: 0 1.25rem;
  grid-template-columns: 8rem 1fr;
  margin-left: auto;
  margin-right: auto;
  margin-top: 2.5rem;
  max-width: 68.75rem;
  padding-bottom: 5rem;
  padding-left: 7.5rem;
  padding-right: 7.5rem;
  padding-top: 5rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-overview__main {
    max-width: 91.4%;
    padding-bottom: 1.5rem;
    padding-left: 0.875rem;
    padding-right: 0.875rem;
    padding-top: 1.5rem;
    row-gap: 0.5rem;
  }
}

.p-overview__label {
  align-items: center;
  display: flex;
  font-size: 1.125rem;
  font-weight: 700;
  justify-content: space-between;
  padding-bottom: 1.125rem;
  padding-top: 1.125rem;
  position: relative;
}

.p-overview__label::after {
  color: #323232;
  content: ":";
  display: block;
  font-weight: 900;
}

.p-overview__value {
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.6;
  padding-bottom: 1.125rem;
  padding-top: 1.125rem;
}
@media screen and (max-width: 767px) {
  .p-overview__value {
    font-size: 0.875rem;
    padding-bottom: 1.3125rem;
    padding-top: 1.3125rem;
  }
}

.p-overview__value span {
  display: block;
  font-size: 0.75rem;
}

.p-overview__btn {
  margin-left: auto;
  margin-right: auto;
  margin-top: 3.9375rem;
  max-width: 29.625rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-overview__btn {
    margin-top: 2.5rem;
  }
}

.p-session {
  background: url(../images/bg_dot.webp) center center/2.125rem repeat;
  padding-bottom: 10rem;
  padding-top: 5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-session {
    background-size: 0.5rem;
    padding-bottom: 5.625rem;
    padding-top: 3rem;
  }
}

.p-session::before {
  background: linear-gradient(245deg, #FF7362, #FFA98D);
  border-radius: 50%;
  content: "";
  height: 23.375rem;
  opacity: 0.1;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: -13.6875rem;
  width: 23.375rem;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-session::before {
    height: 9.875rem;
    right: 0.5625rem;
    top: 0.375rem;
    width: 9.875rem;
  }
}

.p-session__bg {
  border-radius: 50%;
  bottom: 5rem;
  contain: content;
  content: "";
  height: 68.9375rem;
  left: -6.3125rem;
  position: absolute;
  width: 68.9375rem;
}
.p-session__bg::before {
  -webkit-mask-image: conic-gradient(red), conic-gradient(red);
  -webkit-mask-clip: padding-box, border-box;
  -webkit-mask-composite: xor;
  background-image: linear-gradient(215deg in oklab, #F12860, #D51340, #F44849);
  background-origin: border-box;
  border: 12.5rem solid transparent;
  border-radius: 50%;
  bottom: 0;
  content: "";
  left: 0;
          mask-clip: padding-box, border-box;
          mask-composite: exclude;
          mask-image: conic-gradient(red), conic-gradient(red);
  opacity: 0.9;
  position: absolute;
  right: 0;
  top: 0;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-session__bg {
    display: none;
  }
}

.p-session__title {
  margin-left: auto;
  margin-right: auto;
  max-width: 63rem;
  position: relative;
}

.p-session__title .c-title__en::before {
  background: url(../images/session-title_01.webp) center center/contain no-repeat;
  content: "";
  height: 14.875rem;
  left: 2.9375rem;
  position: absolute;
  top: 1.9375rem;
  width: 12.3125rem;
}
@media screen and (max-width: 767px) {
  .p-session__title .c-title__en::before {
    height: 6.3125rem;
    left: 1.875rem;
    top: 6.0625rem;
    width: 5.25rem;
  }
}

.p-session__title .c-title__en::after {
  background: url(../images/session-title_02.webp) center center/contain no-repeat;
  content: "";
  height: 11.8125rem;
  position: absolute;
  right: 2.9375rem;
  top: 4.375rem;
  width: 12.125rem;
}
@media screen and (max-width: 767px) {
  .p-session__title .c-title__en::after {
    height: 6.0625rem;
    right: 1.625rem;
    top: 6.125rem;
    width: 6rem;
  }
}

.p-session__title .c-title__ja {
  margin-top: 0;
}

.p-session__title::before {
  -webkit-clip-path: inset(0 0 54% 0);
  background-color: #323232;
  border-radius: 0.1875rem;
  bottom: -4.375rem;
          clip-path: inset(0 0 54% 0);
  content: "";
  height: 4.375rem;
  left: 48.5%;
  position: absolute;
  transform: translateX(-50%) rotate(6.64deg);
  width: 0.25rem;
}
@media screen and (max-width: 767px) {
  .p-session__title::before {
    display: none;
  }
}

.p-session__time {
  background: linear-gradient(to right, #F12860, #D51340 40%, #F44849);
  border-radius: 3.125rem;
  font-size: 1.875rem;
  font-weight: bold;
  margin-left: auto;
  margin-right: auto;
  margin-top: 2.375rem;
  max-width: 63rem;
  padding-bottom: 0.25rem;
  padding-top: 0.25rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-session__time {
    font-size: 1.25rem;
    margin-top: 5.8125rem;
    padding-bottom: 0.375rem;
    padding-top: 0.375rem;
  }
}

.p-session__time span {
  font-size: 2.6875rem;
  font-style: italic;
}
@media screen and (max-width: 767px) {
  .p-session__time span {
    font-size: 1.25rem;
  }
}

.p-session__subTitle {
  border: 0.125rem solid #D4163F;
  border-radius: 0.625rem;
  color: #D4163F;
  font-size: 1.5rem;
  font-weight: bold;
  margin-left: auto;
  margin-right: auto;
  margin-top: 2.5rem;
  padding: 0.5rem 1.25rem;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .p-session__subTitle {
    font-size: 1.125rem;
    margin-top: 0.75rem;
    max-width: 93.4844192635%;
    padding: 0.5rem 1.375rem;
    text-align: center;
  }
}

.p-session__lead {
  font-size: 1.5rem;
  font-weight: bold;
  margin-top: 0.5rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-session__lead {
    font-size: 1.125rem;
    margin-left: auto;
    margin-right: auto;
    max-width: 93.4844192635%;
    text-align: left;
  }
}

.p-session__blocks {
  grid-gap: 2.5rem;
  display: grid;
  gap: 2.5rem;
  margin-top: 5rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-session__blocks {
    margin-left: auto;
    margin-right: auto;
    margin-top: 1.875rem;
    max-width: 25rem;
  }
}

.p-session__block {
  grid-gap: 5rem;
  align-items: center;
  border-radius: 1.25rem;
  box-shadow: 0 0.25rem 1.875rem #fcd8d4;
  display: grid;
  gap: 5rem;
  grid-template-columns: 10.875rem 1fr;
  min-height: 18.75rem;
  padding-bottom: 0.625rem;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  padding-top: 0.625rem;
}
@media screen and (max-width: 767px) {
  .p-session__block {
    border-radius: 0.625rem;
    display: block;
    padding-bottom: 1.5rem;
    padding-left: 0.875rem;
    padding-right: 0.875rem;
    padding-top: 1.5rem;
  }
}

@media screen and (max-width: 767px) {
  .p-session__number {
    margin-left: auto;
    margin-right: auto;
    max-width: 6.6875rem;
  }
}

.p-session__body {
  align-items: center;
  display: grid;
  grid-template-columns: 1fr 15.625rem;
}
@media screen and (max-width: 767px) {
  .p-session__body {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .p-session__logo {
    margin-top: 0.5rem;
    max-width: 100%;
  }
}

.p-session__logo[data-logo="01"] {
  max-width: 26.625rem;
}

.p-session__logo[data-logo="02"] {
  max-width: 33.9375rem;
}

.p-session__logo[data-logo="03"] {
  max-width: 35.1875rem;
}

.p-session__lists {
  grid-gap: 1.875rem;
  display: grid;
  gap: 1.875rem;
  margin-top: 1.875rem;
}
@media screen and (max-width: 767px) {
  .p-session__lists {
    gap: 0.5rem;
    margin-top: 1.5rem;
  }
}

.p-session__list {
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .p-session__list {
    font-size: 1.125rem;
  }
}

.p-session__list::before {
  content: "・";
  display: inline-block;
}

.p-session__img {
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .p-session__img {
    margin-left: auto;
    margin-right: auto;
    margin-top: 1.5rem;
    max-width: 15.625rem;
  }
}

.p-session__img.--small {
  max-width: 13.75rem;
}

.fadeIn {
  opacity: 0;
  position: relative;
  transform: translateY(max(10%, 1.25rem));
  transition: all 1s cubic-bezier(0.155, 0.91, 0.695, 0.95);
}

.fadeIn.is-fade {
  opacity: 1;
  transform: translateY(0);
}

main {
  overflow: clip;
}

.u-white {
  color: #fff;
}

.u-linear {
  -webkit-background-clip: text;
  background-clip: text;
  background-image: linear-gradient(150deg, #F12860, #D51340 40%, #F44849 90%);
  color: transparent;
  width: -moz-fit-content;
  width: fit-content;
}

.u-red {
  color: #FF0C01;
}

.u-main-font {
  color: "Noto Sans JP", sans-serif;
}

.u-bg-white {
  background-color: #fff;
}

.u-bg-yellow {
  background-color: #DAE470;
}

.u-bg-red {
  background-color: #FF0C01;
}

.u-en-font {
  font-family: "Montserrat", sans-serif;
}