/* font-face
====================================================*/
@font-face {
	font-family: 'NotoSansJP';
	src: url("../fonts/NotoSansJP-Medium.woff2") format('woff2');
  font-weight: 500;
  font-display: swap;
}
@font-face {
	font-family: 'NotoSansJP';
	src: url("../fonts/NotoSansJP-SemiBold.woff2") format('woff2');
  font-weight: 600;
  font-display: swap;
}
@font-face {
	font-family: 'NotoSansJP';
	src: url("../fonts/NotoSansJP-Bold.woff2") format('woff2');
  font-weight: 700;
  font-display: swap;
}

/* animation
====================================================*/
@keyframes scrollbar {
    0% {
        height: 0;
        top: 0;
    }
    30% {
        height: 100%;
    }
    100% {
        top: 100%;
    }
}
@keyframes spin {
    to {
        rotate: y -1turn;
    }
}

/* base
====================================================*/
body {
  font-family: 'NotoSansJP';
  font-weight: 500;
  line-height: 2;
}
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
  border: none;
}
textarea {
  resize: none;
}
input[type="text"],
input[type="email"] ,
textarea {
  width: 100%;
  border: none;
  background-color: #E0E0E0;
  border-radius: .5em;
  padding: 1em 1.5em;
}

/* component
====================================================*/
.h3 {
  border-bottom: 1px solid #DEDEDE;
  padding-bottom: 1em
}
.line-wide {
  line-height: 2.2;
}

/* project
====================================================*/
@media screen and (min-width: 960px) {
  .home .l-header,
  .home .l-header__inner {
    position: fixed;
    left: 50%;
    translate: -50% 0;
  }
}
.fv-bg {
  position: relative;
  height: 110vw;
  min-height: 70vh;
}
.fv-bg::after {
  content: "";
  position: absolute;
  aspect-ratio: 19 / 22;
  width: 156.25vw;
  top: 45vw;
  right: 50%;
  translate: 50% calc(-50% - 2.5vw);
  background: url("../images/bg_logo_02.png") no-repeat center / contain;
  opacity: .2;
}
.fv-bg .swell-block-fullWide__inner {
  height: 100%;
}
.fv-image {
  position: absolute;
  aspect-ratio: 1 / 1.16;
  width: 50vw;
  top: 50vw;
  right: 50%;
  translate: 50% -50%;
  animation: spin 10s infinite;
}
@media screen and (min-width: 600px) {
  .fv-bg {
    height: 100vh;
  }
  .fv-bg::after {
    top: 36vw;
    max-width: 844px;
    translate: 50% -50%;
  }
  .fv-image {
    top: 40vw;
    max-width: 270px;
  }
}
@media screen and (min-width: 960px) {
  .fv-bg::after {  
    top: 50%;
    width: 62vw;
    max-width: unset;
  }
  .fv-image {
    top: 50%;
    width: 20vw;
    max-width: unset;
  }
}
.scroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  display: block;
  height: 100px;
  transform: translateX(-50%);
  overflow: hidden;
  padding-left: .6em;
  font-size: 1.25rem;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}
.scroll::before {
    content: "";
    position: absolute;
    display: block;
    width: 1px;
    height: 0;
    top: 0;
    left: 0;
    background: #3a3a3a;
    animation: scrollbar 2.0s ease-in-out infinite;
    margin: auto;
}
.mission-item {
  width: 100%;
  background-color: #fff;
  padding: 2.5rem 2.5rem 3rem 2.25rem;
}
.business-list {
  counter-reset: item-count;
}
.business-item {
  position: relative;
  counter-increment: item-count;
}
.business-item::before {
  content: "0"counter(item-count);
  position: absolute;
  top: 0;
  left: 0;
  padding-left: .25em;
  line-height: 1;
  color: #EA86AB;
  font-size: 4.5rem;
  font-weight: 700;
  border-top: .15em solid transparent;
  border-bottom: .15em solid transparent;
  border-left: .3em solid #EA86AB;
}
.business-item-image-sp img {
  width: 50%;
}
@media screen and (min-width: 960px) {
  .business-item::before {
    font-size: 6rem;
  }
  .business-item-odd::before {
    left: unset;
    right: 0;
    padding-left: 0;
    padding-right: .25em;
    border-left: none;
    border-right: .3em solid #EA86AB;
  }
}
.table {
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.table th,
.table td {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}
.table th {
  padding-left: 1.5rem;
}
.table td {
  padding-right: 1.5rem;
}
.table tr:first-child th,
.table tr:first-child td {
  border-top: none;
}
.table tr:last-child th,
.table tr:last-child td {
  border-bottom: none;
}
.contact-bg {
  position: relative;
}
.contact-bg::before {
  content: "";
  position: absolute;
  width: 100vw;
  height: 100%;
  top: 0;
  left: calc(50% - 50vw);
  opacity: .7;
  background: url("../images/bg_logo_02.png") no-repeat 110% / 35%;
}
.contact-content {
  background-color: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(22px);
  border-radius: 0.5rem;
  padding: 3rem 1.5rem;
}
@media screen and (min-width: 960px) {
  .contact-content {
    padding: 4.5rem;
  }
}

.p-form-container {
  max-width: 67rem;
}

.p-form__row {
  display: block;
  padding: 2.5rem 0;
  border-bottom: 1px solid #DEDEDE;
}
.p-form__row:first-of-type {
  padding-top: 0;
}
.p-form__row:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}
@media screen and (min-width: 600px) {
  .p-form__row {
    display: flex;
  gap: 5%;
  }
}
.p-form__term {
  width: 100%;
  margin-bottom: 1rem;
  font-size: 1.125rem;
}
@media screen and (min-width: 600px) {
  .p-form__term p {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 15%;
  }
}
@media screen and (min-width: 600px) {
  .p-form__term {
    width: 30%;
    margin-bottom: 0;
  }
}
.p-form__required {
  display: inline;
  color: #D60050;
  border-radius: 0.1875em;
  white-space: nowrap;
  font-size: 1rem;
}
@media screen and (min-width: 960px) {
  .p-form__required {
  display: block;
  background-color: #D60050;
  padding: 0 1.25em;  
  color: #fff;
  }
}
.p-form__description {
  width: 100%;
}
@media screen and (min-width: 600px) {
  .p-form__description {
    width: 65%;
  }
}
.p-form__name-container p {
  display: flex;
  gap: 5%;
}
.p-form__privacy-text-container {
  height: 12.125rem;
  overflow-y: scroll;
  border: 1px solid #8A8A8A;
  border-radius: 0.5em;
  padding: 1.5em 0;
}
.p-form__privacy-text {
  width: 85%;
  margin: auto;
  font-size: 0.875rem;
  line-height: 2;
  color: #8A8A8A;
  counter-reset: heading;
}
.p-form__privacy-text > p {
  margin-top: 1em;
}
.p-form__privacy-text > p:first-child {
  margin-top: 0;
}
.p-form__privacy-text > h4 {
  margin: 1em 0;
  counter-increment: heading;
}
.p-form__privacy-text > h4::before {
  content: counter(heading) ".";
}
.p-form__privacy-text > h4:first-child {
  margin-top: 0;
}
.p-form__privacy-text > hr {
  width: 2em;
  margin: 1em auto 1em 0;
}
.p-form__privacy-checkbox {
  display: block;
  margin-top: 2em;
  text-align: center;
}
@media screen and (min-width: 600px) {
  .p-form__privacy-checkbox {
    text-align: left;
  }
}
.p-form__privacy-checkbox > * {
  margin: 0;
}
.p-form__privacy-checkbox input {
  margin-right: 0.5em;
}
.p-form__submit {
  display: block;
  width: 12.25rem;
  background: linear-gradient(90deg, #F53D82 0%, #D60050 80%);
  border-radius: 0.5em;
  margin: 4rem auto 0;
  padding: 0.75em 1em;
  color: #fff;
}

.thank-you-heading {
  font-family: "crimson text", serif;
}

.thank-you-bg {
  position: relative;
}
.thank-you-bg::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: calc(50% - 50vw);
}
.thank-you-bg::before {
  opacity: 0.7;
  background: url("../images/bg_logo_02.png") no-repeat;
  background-size: 80%;
  background-position: 150% top;
}
@media screen and (min-width: 960px) {
  .thank-you-bg::before {
    background-size: 35%;
    background-position: 100% 5vw;
  }
}
.p-thanks__inner {
  max-width: 57rem;
  margin: 0 auto;
  padding: 10.125rem 2rem 10.8125rem;
}
.p-thanks__heading-container {
  font-size: 4rem;
  margin-bottom: 1.34em;
  text-align: center;
}
.p-thanks__heading {
  font-size: 0.75em;
  font-family: "crimson text", serif;
  font-weight: 700;
}
@media screen and (min-width: 600px) {
  .p-thanks__heading {
    font-size: 1em;
  }
}
.p-thanks__subheading {
  font-size: 0.25em;
}
.p-thanks__text {
  text-align: center;
  font-size: 1.125rem;
}
.p-thanks__button {
  display: block;
  width: 13.75rem;
  margin: 12.5rem auto 0;
  padding: 0.75em 1em;
  border: 1px solid #D60050;
  border-radius: 9999px;
  text-align: center;
  font-weight: 700;
  color: #D60050;
}

/* utility
====================================================*/
.u-display--pc {
  display: none;
}
@media screen and (min-width: 960px) {
  .u-display--pc {
    display: block;
  }
}
.u-display--sp {
  display: block;
}
@media screen and (min-width: 960px) {
  .u-display--sp {
    display: none;
  }
}
.u-display-flex--pc {
  display: none;
}
@media screen and (min-width: 960px) {
  .u-display-flex--pc {
    display: flex;
  }
}
.u-display-flex--sp {
  display: flex;
}
@media screen and (min-width: 960px) {
  .u-display-flex--sp {
    display: none;
  }
}

.u-display-inline--pc {
  display: none;
}
@media screen and (min-width: 960px) {
  .u-display-inline--pc {
    display: inline;
  }
}
.u-display-inline--sp {
  display: inline;
}
@media screen and (min-width: 960px) {
  .u-display-inline--sp {
    display: none;
  }
}
.u-visually-hidden {
    position: absolute!important;
    width: 1px!important;
    height: 1px!important;
    padding: 0!important;
    margin: -1px!important;
    overflow: hidden!important;
    clip: rect(0,0,0,0)!important;
    white-space: nowrap!important;
    border: 0!important;
}