@import "https://fonts.googleapis.com/css2?family=League+Spartan:wght@400;500;700&display=swap";

/*! destyle.css v1.0.15 | MIT License | https://github.com/nicolas-cusan/destyle.css */
* {
  box-sizing: border-box;
}

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

html {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  line-height: 1.15;
}

body {
  margin: 0;
}

main {
  display: block;
}

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  margin: 0;
}

ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

hr {
  border: 0;
  border-top: 1px solid;
  box-sizing: content-box;
  clear: both;
  color: inherit;
  height: 0;
  margin: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

a {
  background-color: rgba(0, 0, 0, 0);
  color: inherit;
  text-decoration: none;
}

abbr[title] {
  -webkit-text-decoration: underline dotted;
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
  vertical-align: bottom;
}

embed,
object,
iframe {
  border: 0;
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: rgba(0, 0, 0, 0);
  border: 0;
  border-radius: 0;
  color: inherit;
  font: inherit;
  margin: 0;
  outline: 0;
  padding: 0;
  text-align: inherit;
  vertical-align: middle;
}

[type="checkbox"] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox;
}

[type="radio"] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
  appearance: radio;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}

button[disabled],
[type="button"][disabled],
[type="reset"][disabled],
[type="submit"][disabled] {
  cursor: default;
}

input[type="submit"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  border-radius: 0;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  background: none;
  border: none;
}

select {
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: "";
}

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

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

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

option {
  padding: 0;
}

fieldset {
  border: 0;
  margin: 0;
  min-width: 0;
  padding: 0;
}

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

[type="search"] {
  outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable] {
  outline: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  padding: 0;
  vertical-align: top;
}

th {
  font-weight: bold;
  text-align: left;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

:root {
  --main-color: #1a1311;
  --sub-color: #fff;
  --text-color: #333;
  --xl: 3.2rem;
  --lg: 2.4rem;
  --md: 1.6rem;
  --sm: 1.3rem;
  --ss: 1.2rem;
  --z-index-header: 100;
  --z-index-modal: 200;
  --z-index-animation: 1000;
  --inner-large: 128rem;
  --inner-medium: 114rem;
  --inner-small: 102.4rem;
}

@font-face {
  font-family: "font";
  font-weight: bold;
  src: url("../../fonts/Spartan-Bold.woff") format("woff");
}

@font-face {
  font-family: "font";
  font-weight: 500;
  src: url("../../fonts/Spartan-Medium.woff") format("woff");
}

html {
  font-size: 0.6944444444vw;
  min-height: 100vh;
  min-height: calc(var(--vh, 1vh) * 100);
  overflow-x: hidden;
}

@media screen and (min-width: 1440px) {
  html {
    font-size: 62.5%;
  }
}

@media screen and (max-width: 700px) {
  html {
    font-size: 62.5%;
  }
}

@media screen and (max-width: 360px) {
  html {
    font-size: 58%;
  }
}

body {
  background-color: #e9e9e9;
  color: #1a1311;
  font-family: "游ゴシック体 Pr6N", "Yu Gothic Pr6N", sans-serif;
  font-size: var(--sm);
  overflow-x: hidden;
}

canvas {
  height: 100vh;
  left: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: -1;
}

@media screen and (max-width: 700px) {
  ._pc {
    display: none !important;
  }
}

._sp {
  display: none !important;
}

@media screen and (max-width: 700px) {
  ._sp {
    display: block !important;
  }
}

._en {
  font-family: "font", sans-serif;
}

._font-bold {
  font-family: "游ゴシック体 Pr6N B", "Yu Gothic Pr6N B", sans-serif;
}

.--hide {
  overflow: hidden;
  position: relative;
}

.--no-active {
  cursor: auto;
  opacity: 0.3 !important;
  pointer-events: none;
}

._fit {
  -o-object-fit: cover;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

._fit-aspect {
  -o-object-fit: cover;
  bottom: 0;
  display: block;
  height: 100%;
  left: 0;
  object-fit: cover;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
}

._inner-large {
  margin: auto;
  max-width: var(--inner-large);
}

._inner-large .mainTxt {
  font-size: 10px;
  color: #fff;
  position: absolute;
  top: 10%;
  padding: 0;
}

@media screen and (max-width: 700px) {
  ._inner-large {
    padding: 0 2.4rem;
  }
}

._inner-medium {
  margin: auto;
  max-width: var(--inner-medium);
}

@media screen and (max-width: 700px) {
  ._inner-medium {
    padding: 0 2.4rem;
  }
}

._inner-small {
  margin: auto;
  max-width: var(--inner-small);
}

@media screen and (max-width: 700px) {
  ._inner-small {
    padding: 0 2.4rem;
  }
}

._point-large {
  animation: largePoint 1.6s 0s linear infinite;
}

._point-small {
  animation: smallPoint 1.6s 0s linear infinite;
}

@keyframes smallPoint {
  0% {
    opacity: 0.1;
  }

  70% {
    opacity: 0;
  }

  100% {
    opacity: 0.1;
  }
}

@keyframes largePoint {
  0% {
    opacity: 0.05;
  }

  70% {
    opacity: 0;
  }

  100% {
    opacity: 0.05;
  }
}

.--hide {
  display: inline-block;
  overflow: hidden;
}

.--show {
  position: relative;
  top: 10rem;
}

.js-normal-fade {
  opacity: 0;
}

.--space {
  display: inline-block;
  padding-right: 1.3rem;
}

.l-header {
  position: fixed;
  top: 5.6rem;
  width: 100%;
  z-index: var(--z-index-header);
}

@media screen and (max-width: 700px) {
  .l-header {
    top: 3.14rem;
  }
}

.l-header__inner {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.l-header__logo {
  height: 2.92rem;
  width: 17.4rem;
}

@media screen and (max-width: 700px) {
  .l-header__logo {
    height: 2.309rem;
    width: 13.7rem;
  }
}

.l-header__logo a {
  display: block;
}

.l-footer {
  padding-bottom: 4.35rem;
  padding-top: 14.01rem;
}

.l-footer__logo {
  height: 2.92rem;
  margin-bottom: 8rem;
  width: 17.4rem;
}

@media screen and (max-width: 700px) {
  .l-footer__logo {
    margin-bottom: 5.59rem;
  }
}

.l-footer__ul {
  display: flex;
  flex-wrap: wrap;
  gap: 4.96rem 7.2rem;
  margin-bottom: 7.39rem;
}

@media screen and (max-width: 700px) {
  .l-footer__ul {
    gap: 3.19rem 0;
    justify-content: space-between;
    margin-bottom: 7.2rem;
  }
}

@media screen and (max-width: 700px) {
  .l-footer__list {
    min-width: 50%;
  }
}

.l-footer__list--en {
  display: block;
  font-family: "League Spartan", sans-serif;
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 0.7rem;
}

.l-footer__copyright {
  display: block;
  font-family: "League Spartan", sans-serif;
  font-size: 1.2rem;
  font-weight: bold;
  margin-left: auto;
  text-align: right;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .l-footer__copyright {
    font-size: 1rem;
    margin: 0;
  }
}

.l-nav__button {
  display: block;
  height: 2.4rem;
  position: relative;
  width: 2.6rem;
}

@media screen and (max-width: 700px) {
  .l-nav__button {
    height: 2.2rem;
    width: 2.4rem;
  }
}

.l-nav__line {
  background-color: #fff;
  border-radius: 100vmax;
  display: block;
  height: 2px;
  position: absolute;
}

.l-nav__line--top {
  right: 0;
  top: 0;
  width: 1.3rem;
}

.l-nav__line--middle {
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
}

.l-nav__line--bottom {
  left: 0;
  top: 100%;
  width: 1.3rem;
}

.c-section-title {
  align-items: center;
  display: flex;
  font-weight: bold;
  gap: 0.9rem;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}

.c-section-title::after {
  background-color: var(--main-color);
  border-radius: 0.057rem;
  bottom: 0;
  content: "";
  height: 0.5rem;
  position: absolute;
  right: -0.87rem;
  width: 0.5rem;
}

.c-section-title span {
  display: block;
}

.c-section-title--number {
  color: var(--main-color);
  font-size: 1.4rem;
  letter-spacing: 0.02em;
}

.c-section-title--name {
  border: 3px var(--main-color) solid;
  color: var(--main-color);
  font-size: 1.4rem;
  letter-spacing: 0.02em;
  padding: 0.8rem 2.16rem 0.4rem;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .c-section-title--name {
    padding: 0.6rem 1.86rem 0.3rem;
  }
}

.c-link-button {
  align-items: center;
  display: flex;
  gap: 2.7rem;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .c-link-button {
    gap: 2rem;
  }
}

.c-link-button--name {
  color: var(--main-color);
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.02em;
}

.c-link-button--round {
  align-items: center;
  background-color: var(--main-color);
  border-radius: 100vmax;
  display: flex;
  height: 6.4rem;
  justify-content: center;
  overflow: hidden;
  position: relative;
  width: 6.4rem;
}

@media screen and (max-width: 700px) {
  .c-link-button--round {
    height: 5.6rem;
    width: 5.6rem;
  }
}

.c-link-button--round img {
  display: block;
  position: relative;
  width: 1.2rem;
  z-index: 1;
}

.c-link-button--round span {
  background-color: #e9e9e9;
  border-radius: 100vmax;
  height: 5rem;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%) scale(0);
  width: 5rem;
  z-index: 0;
}

@media (hover: hover) {
  .c-link-button .c-link-button--round {
    right: 0;
    transition: all 0.2s ease;
  }

  .c-link-button .c-link-button--round span {
    transform: translate(-50%, -50%) scale(0);
    transition: all 0.4s ease;
  }

  .c-link-button:hover .c-link-button--round {
    right: -1rem;
  }

  .c-link-button:hover .c-link-button--round img {
    mix-blend-mode: difference;
  }

  .c-link-button:hover .c-link-button--round span {
    transform: translate(-50%, -50%) scale(2);
  }
}

.c-reserve {
  padding-top: 12.55rem;
}

@media screen and (max-width: 700px) {
  .c-reserve {
    padding-top: 8rem;
  }
}

.c-reserve__contents {
  display: block;
  height: 44.4rem;
  margin: auto;
  max-width: 100%;
  position: relative;
  width: 114.056rem;
}

@media screen and (max-width: 700px) {
  .c-reserve__contents {
    height: 18.9rem;
    margin: 0 calc(50% - 50vw);
    max-width: none;
    width: 100vw;
  }
}

.c-reserve__title {
  bottom: 4rem;
  color: #fff;
  font-weight: bold;
  left: 8rem;
  position: absolute;
}

@media screen and (max-width: 700px) {
  .c-reserve__title {
    bottom: 2.1rem;
    left: 2rem;
  }
}

.c-reserve__title--large {
  display: block;
  font-size: 9.5rem;
  left: -0.7rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .c-reserve__title--large {
    font-size: 3.6rem;
  }
}

.c-reserve__title--small {
  display: block;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 700px) {
  .c-reserve__title--small {
    font-size: 1.2rem;
  }
}

.c-reserve__images {
  z-index: -1;
}

.c-reserve__arrow {
  bottom: 4.83rem;
  position: absolute;
  right: 4.49rem;
  width: 8.3rem;
}

@media screen and (max-width: 700px) {
  .c-reserve__arrow {
    bottom: 1.74rem;
    right: 2.1rem;
    width: 6.6rem;
  }
}

.c-page-links__contents {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .c-page-links__contents {
    flex-direction: column;
    padding: 0 2.4rem;
  }
}

.c-page-links__link {
  align-items: center;
  display: flex;
  height: 74.9rem;
  justify-content: center;
  position: relative;
  width: 33.3333333333%;
}

@media screen and (max-width: 700px) {
  .c-page-links__link {
    border-bottom: 2px var(--main-color) solid;
    height: 16.1rem;
    justify-content: flex-start;
    width: 100%;
  }
}

.c-page-links__link-title {
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .c-page-links__link-title {
    text-align: left;
  }
}

.c-page-links__link-title--large {
  display: block;
  font-size: 5.6rem;
  letter-spacing: -0.03em;
  margin-bottom: 1rem;
}

@media screen and (max-width: 700px) {
  .c-page-links__link-title--large {
    font-size: 4rem;
  }
}

.c-page-links__link-title--small {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 700px) {
  .c-page-links__link-title--small {
    font-size: 1.3rem;
  }
}

.c-page-links__arrow {
  bottom: 3.2rem;
  position: absolute;
  right: 3.2rem;
  width: 6.8rem;
}

@media screen and (max-width: 700px) {
  .c-page-links__arrow {
    bottom: 50%;
    right: 0;
    transform: translateY(50%);
    width: 6rem;
  }
}

.c-page-links__background {
  pointer-events: none;
  z-index: -1;
}

.c-page-links__images {
  height: 26.3rem;
  margin-bottom: 8rem;
  position: relative;
  width: 95%;
}

.c-page-links__images img {
  width: 100%;
}

@media (min-width: 700px) and (hover: hover) {
  .c-page-links__link {
    transition: all 0.3s ease;
  }

  .c-page-links__arrow {
    opacity: 0;
    transition: all 0.3s ease;
  }

  .c-page-links__background {
    opacity: 0;
    transition: all 0.3s ease;
  }

  .c-page-links__link:hover {
    color: #fff;
  }

  .c-page-links__link:hover .c-page-links__arrow {
    opacity: 1;
  }

  .c-page-links__link:hover .c-page-links__background {
    opacity: 1;
  }
}

.common-page-key {
  min-height: 48rem;
  position: relative;
  width: 100%;
}

@media screen and (max-width: 700px) {
  .common-page-key {
    min-height: 44rem;
  }
}

.common-page-key__title {
  border-bottom: 5px #fff solid;
  bottom: 6.3rem;
  color: #fff;
  font-size: 12rem;
  font-weight: bold;
  line-height: 1;
  margin-left: 4rem;
  padding-bottom: 0.6rem;
  position: absolute;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .common-page-key__title {
    border-bottom: 3px #fff solid;
    bottom: 3.6rem;
    font-size: 6.4rem;
    margin-left: 0;
  }
}

.--faq {
  background: url(../img/page-kv/page-kv-faq.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--faq {
    background: url(../img/page-kv/page-kv-faq-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--topic {
  background: url(../img/page-kv/page-kv-topic.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--topic {
    background: url(../img/page-kv/page-kv-topic-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--price {
  background: url(../img/page-kv/page-kv-price.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--price {
    background: url(../img/page-kv/page-kv-price-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--program {
  background: url(../img/page-kv/page-kv-program.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--program {
    background: url(../img/page-kv/page-kv-program-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--about {
  background: url(../img/page-kv/page-kv-about.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--about {
    background: url(../img/page-kv/page-kv-about-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--team {
  background: url(../img/page-kv/page-kv-team.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--team {
    background: url(../img/page-kv/page-kv-team-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--constitution {
  background: url(../img/page-kv/page-kv-constitution.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--constitution {
    background: url(../img/page-kv/page-kv-constitution-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--privacy {
  background: url(../img/page-kv/page-kv-privacy.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--privacy {
    background: url(../img/page-kv/page-kv-privacy-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--recruit {
  background: url(../img/page-kv/page-kv-recruit.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--recruit {
    background: url(../img/page-kv/page-kv-recruit-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--contact {
  background: url(../img/page-kv/page-kv-contact.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--contact {
    background: url(../img/page-kv/page-kv-contact-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.--success {
  background: url(../img/page-kv/page-kv-contact.webp) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 700px) {
  .--success {
    background: url(../img/page-kv/page-kv-contact-sp.webp) center no-repeat;
    background-size: cover;
  }
}

.c-team-slider {
  margin-left: auto;
  min-height: 10rem;
  overflow-x: hidden;
  overflow-y: hidden;
  padding: 0 0 12vw 0;
  position: relative;
  width: 90%;
}

@media screen and (max-width: 700px) {
  .c-team-slider {
    padding: 0 0 5rem 0;
  }
}

.c-team-slider .swiper-container {
  position: relative;
}

.c-team-slider .swiper-slide {
  cursor: pointer;
  max-width: 100%;
  padding-top: 39.5%;
  position: relative;
  width: 26.4vw;
}

@media screen and (max-width: 700px) {
  .c-team-slider .swiper-slide {
    padding-top: 117.5%;
    width: 29.6rem;
  }
}

.c-team-slider .swiper-button-next {
  height: 6.4rem;
  left: auto;
  right: 10.4rem;
  top: 120%;
  width: 6.4rem;
}

@media screen and (max-width: 700px) {
  .c-team-slider .swiper-button-next {
    display: none;
  }
}

.c-team-slider .swiper-button-next::after {
  background: url(../img/topic/topic-slider-arrow-next.png) center no-repeat;
  background-size: 110%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}

.c-team-slider .swiper-button-prev {
  height: 6.4rem;
  left: auto;
  right: 17rem;
  top: 120%;
  width: 6.4rem;
}

@media screen and (max-width: 700px) {
  .c-team-slider .swiper-button-prev {
    display: none;
  }
}

.c-team-slider .swiper-button-prev::after {
  background: url(../img/topic/topic-slider-arrow-prev.png) center no-repeat;
  background-size: 110%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}

.c-team-slider .swiper-slide-active + .swiper-slide {
  position: relative;
  top: 9rem;
}

@media screen and (max-width: 700px) {
  .c-team-slider .swiper-slide-active + .swiper-slide {
    top: 4rem;
  }
}

.c-team-slider__image {
  background-color: #333;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.c-team-slider__box {
  bottom: 2.44rem;
  left: 2.8rem;
  position: absolute;
}

@media screen and (max-width: 700px) {
  .c-team-slider__box {
    left: 2.4rem;
  }
}

.c-team-slider__position {
  border: 2px #fff solid;
  color: #fff;
  font-size: 1.2rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  margin-bottom: 1rem;
  padding: 0.2rem 0.6rem 0;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .c-team-slider__position {
    font-size: 1rem;
  }
}

.c-team-slider__name {
  color: #fff;
  font-size: 2.4rem;
  font-weight: bold;
}

@media screen and (max-width: 700px) {
  .c-team-slider__name {
    font-size: 1.8rem;
  }
}

.c-team-slider__arrow {
  bottom: 1.4rem;
  position: absolute;
  right: 2.4rem;
  width: 6.8rem;
}

@media screen and (max-width: 700px) {
  .c-team-slider__arrow {
    right: 1.2rem;
    width: 6.1rem;
  }
}

.c-modal {
  display: none;
  height: 100vh;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 2000;
}

@media screen and (max-width: 700px) {
  .c-modal {
    height: calc(var(--vh, 1vh) * 100);
    height: 100vh;
  }
}

.c-modal.--active {
  display: block;
}

.c-modal__fliter {
  background-color: #000;
  cursor: pointer;
  height: 100%;
  opacity: 0.7;
  width: 100%;
}

.c-modal__body {
  background-color: #333;
  height: 80vh;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 50rem;
}

@media screen and (max-width: 700px) {
  .c-modal__body {
    height: 50.1rem;
    width: 31.1rem;
  }
}

.c-modal__box {
  bottom: 5.6rem;
  left: 6.4rem;
  max-width: 100%;
  position: absolute;
  width: 37.2rem;
}

@media screen and (max-width: 700px) {
  .c-modal__box {
    bottom: 3.2rem;
    left: 3.2rem;
    max-width: 80%;
  }
}

.c-modal__name {
  color: #fff;
  font-size: 2rem;
  letter-spacing: 0.12em;
  margin-bottom: 3.2rem;
}

@media screen and (max-width: 700px) {
  .c-modal__name {
    font-size: 1.4rem;
    margin-bottom: 2rem;
  }
}

.c-modal__text {
  color: #fff;
  letter-spacing: 0.12em;
  line-height: 1.5384615385;
}

@media screen and (max-width: 700px) {
  .c-modal__text {
    font-size: 1.1rem;
    line-height: 1.8181818182;
  }
}

.c-modal__en {
  color: #fff;
  font-size: 2.4rem;
  font-weight: bold;
  left: 50%;
  letter-spacing: 0.04em;
  line-height: 1.3333333333;
  position: absolute;
  text-align: center;
  text-transform: uppercase;
  top: 5.6rem;
  transform: translateX(-50%);
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .c-modal__en {
    top: 4.7rem;
  }
}

.c-modal__close {
  height: 1.5rem;
  position: absolute;
  right: -4rem;
  top: 0;
  width: 1.5rem;
}

@media screen and (max-width: 700px) {
  .c-modal__close {
    right: 0;
    top: -2.85rem;
  }
}

.c-modal__close-line {
  background-color: #fff;
  height: 1px;
  left: 0;
  position: absolute;
  width: 1.5rem;
}

.c-modal__close-line.--top {
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.c-modal__close-line.--bottom {
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
}

.c-menu {
  -ms-overflow-style: none;
  background: url(../img/menu-bg.webp) center no-repeat;
  background-size: cover;
  display: none;
  height: 100vh;
  left: 0;
  overflow-x: hidden;
  overflow-y: scroll;
  position: fixed;
  scrollbar-width: none;
  top: 0;
  width: 100%;
  z-index: 99;
}

.c-menu::-webkit-scrollbar {
  display: none;
}

.c-menu.--active {
  display: block;
}

.c-menu__inner {
  position: relative;
}

@media screen and (max-width: 400px) {
  .c-menu__inner {
    padding-right: 0;
  }
}

.c-menu__ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8rem 15rem;
  margin: 25vh 0 0 5rem;
  max-width: 100%;
  padding-bottom: 10rem;
  width: 75rem;
}

@media screen and (max-width: 700px) {
  .c-menu__ul {
    gap: 6vh 1.5rem;
    margin: 15vh 0 5vh 0;
    padding-bottom: 0;
  }
}

@media screen and (max-width: 370px) {
  .c-menu__ul {
    gap: 6vh 0.3rem;
  }
}

@media screen and (max-width: 360px) {
  .c-menu__ul {
    gap: 6vh 1.5rem;
  }
}

.c-menu__list {
  color: #fff;
  display: block;
  font-size: 4.4rem;
  font-weight: bold;
  overflow: hidden;
  padding-left: 0.3rem;
  position: relative;
  width: 30rem;
}

@media screen and (max-width: 700px) {
  .c-menu__list {
    font-size: 2.4rem;
    width: 16.6rem;
  }
}

.c-menu__list .--number {
  display: inline-block;
  color: #464031;
  font-size: 1.6rem;
  left: -0.4rem;
  position: relative;
  top: -2.4rem;
}

@media screen and (max-width: 700px) {
  .c-menu__list .--number {
    font-size: 1rem;
    top: -1rem;
  }
}

.c-menu__button {
  display: flex;
}

.c-menu__list .--text {
  display: inline-block;
  vertical-align: top;
}

.c-menu__list .--text .--ja {
  font-family: "游ゴシック体 Pr6N M", "Yu Gothic Pr6N M", sans-serif;
  margin-bottom: 1.1rem;
  display: block;
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.06em;
  line-height: 1.1em;
  text-align: left;
  color: #fff;
}

@media screen and (max-width: 700px) {
  .c-menu__list .--text .--ja {
    font-size: 1.2rem;
    letter-spacing: 0.06em;
    line-height: 1.2em;
  }
}

@media screen and (max-width: 400px) {
  .c-menu__others {
    margin-right: 2.4rem;
  }
}

.c-menu__topic-area {
  border: 1px #fff solid;
  bottom: 0;
  display: flex;
  height: 7.5rem;
  max-width: 100%;
  position: absolute;
  right: 0;
  width: 47.2rem;
}

@media screen and (max-width: 700px) {
  .c-menu__topic-area {
    border: none;
    flex-direction: column;
    margin-bottom: 4vh;
    position: static;
  }
}

.c-menu__topic-title {
  align-items: center;
  border-right: 1px #fff solid;
  color: #fff;
  display: flex;
  height: 100%;
  justify-content: center;
  width: 11.8rem;
}

@media screen and (max-width: 700px) {
  .c-menu__topic-title {
    border-left: 1px #fff solid;
    border-top: 1px #fff solid;
    padding: 0.8rem 0;
    width: 8.6rem;
  }
}

.c-menu__topic-flex {
  animation: shift-text 10s linear 0s infinite;
  display: flex;
  gap: 2rem;
}

.c-menu__topic-content {
  -ms-overflow-style: none;
  height: 100%;
  max-width: 100%;
  overflow-x: scroll;
  overflow-y: hidden;
  padding: 3.1rem 2rem;
  scrollbar-width: none;
  width: 42.4rem;
}

@media screen and (max-width: 700px) {
  .c-menu__topic-content {
    border: 1px #fff solid;
    padding: 1.4rem 1rem 1rem;
  }
}

.c-menu__topic-content p {
  color: #fff;
  display: inline-block;
  font-size: 1.2rem;
  letter-spacing: 0.06em;
  white-space: nowrap;
  white-space: nowrap;
}

.c-menu__topic-content::-webkit-scrollbar {
  display: none;
}

@keyframes shift-text {
  from {
    transform: translate(100%);
  }

  99%,
  to {
    transform: translate(-200%);
  }
}

.c-menu__copy {
  bottom: -4rem;
  color: #464031;
  font-size: 1rem;
  position: absolute;
  right: 4rem;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .c-menu__copy {
    display: block;
    margin: auto;
    position: static;
    text-align: center;
  }
}

.c-menu__sns {
  align-items: center;
  bottom: 10rem;
  display: flex;
  gap: 1.5rem;
  position: absolute;
  right: 0;
}

@media screen and (max-width: 700px) {
  .c-menu__sns {
    justify-content: center;
    margin-bottom: 8vh;
    position: static;
  }
}

.c-menu__sns a {
  display: block;
  width: 3.2rem;
}

.c-menu__sns img {
  width: 100%;
}

@media (hover: hover) {
  .c-menu__list {
    opacity: 1;
    transition: all 0.24s ease;
  }

  .c-menu__list:hover {
    opacity: 0.7;
  }
}

.c-noise {
  animation: noiseAnimation 7.6s steps(8, end) infinite;
  background: rgba(0, 0, 0, 0) url(../img/noise.webp) 0 0;
  bottom: -50rem;
  height: 400%;
  left: -50rem;
  pointer-events: none;
  position: fixed;
  right: -50rem;
  top: -50rem;
  width: 400%;
  z-index: -1;
}

@keyframes noiseAnimation {
  0% {
    transform: translateX(0px, 0px);
  }

  10% {
    transform: translate(-100px, 100px);
  }

  20% {
    transform: translate(150px, -100px);
  }

  30% {
    transform: translate(-100px, 100px);
  }

  40% {
    transform: translate(100px, -150px);
  }

  50% {
    transform: translate(-100px, 200px);
  }

  60% {
    transform: translate(-200px, -100px);
  }

  70% {
    transform: translateY(50px, 100px);
  }

  80% {
    transform: translate(100px, -150px);
  }

  90% {
    transform: translate(0px, 200px);
  }

  100% {
    transform: translate(-100px, 100px);
  }
}

.c-loading {
  background-color: #000;
  height: 100vh;
  height: 100svh;
  left: 0;
  overflow: hidden;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 3000;
}

.c-loading__bg {
  height: 100vh;
  height: 100svh;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}

.c-loading__counter {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 15vw;
  font-weight: bold;
  letter-spacing: -0.1em;
  line-height: 1;
  position: absolute;
  right: -5.6rem;
  top: 0;
  transform: rotate(180deg);
  writing-mode: vertical-rl;
}

@media screen and (max-width: 700px) {
  .c-loading__counter {
    font-size: 20vw;
    right: -1rem;
  }
}

.c-loading__cover {
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 700px) {
  .c-loading__cover {
    width: 100%;
  }
}

.c-loading__img {
  height: 5.066rem;
  margin-bottom: 2.4rem;
  overflow: hidden;
  position: relative;
  width: 30rem;
}

@media screen and (max-width: 700px) {
  .c-loading__img {
    height: 3.881rem;
    margin: 0 auto 2rem;
    width: 23.1rem;
  }
}

.c-loading__text {
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  height: -moz-fit-content;
  height: fit-content;
  letter-spacing: 0.16em;
  overflow: hidden;
  position: relative;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .c-loading__text {
    font-size: 1.4rem;
  }
}

.c-loading__copy {
  bottom: 3.3rem;
  color: #fff;
  font-size: 1rem;
  left: 8rem;
  overflow: hidden;
  position: absolute;
}

@media screen and (max-width: 700px) {
  .c-loading__copy {
    opacity: 0;
  }
}

.js-loading-up {
  position: relative;
}

.js-after-fade {
  opacity: 0;
  position: relative;
  top: 5rem;
}

.c-fixed-cv {
  bottom: 4rem;
  display: block;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  right: 4rem;
  text-align: center;
  transition: all 0.2s ease;
  z-index: 90;
}

@media screen and (max-width: 700px) {
  .c-fixed-cv {
    bottom: 1.6rem;
    height: 10rem;
    right: 1.6rem;
    width: 10rem;
  }
}

@media (hover: hover) {
  .c-fixed-cv:hover img {
    transform: scale(1.1);
  }
}

.c-fixed-cv.--active {
  opacity: 1;
  pointer-events: all;
  transition: all 0.2s ease;
}

.c-fixed-cv img {
  animation: rotate 15s 0s linear infinite;
  transition: transform 0.2s linear;
  width: 100%;
  z-index: 0;
}

.c-fixed-cv__text {
  color: #fff;
  font-size: 1.4rem;
  left: 50%;
  letter-spacing: 0.01em;
  line-height: 1.2142857143;
  pointer-events: none;
  position: absolute;
  top: 53%;
  transform: translate(-50%, -50%);
  z-index: 1;
}

@media screen and (max-width: 700px) {
  .c-fixed-cv__text {
    font-size: 1rem;
    letter-spacing: 0;
  }
}

@keyframes rotate {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

.breadcrumb {
  align-items: center;
  display: flex;
  font-weight: bold;
  gap: 2.4rem;
  margin-bottom: 6rem;
}

@media screen and (max-width: 700px) {
  .breadcrumb {
    flex-wrap: wrap;
    gap: 1.2rem 2.4rem;
  }
}

.breadcrumb a,
.breadcrumb li {
  font-size: 1.2rem;
}

.breadcrumb li br {
  display: none;
}

.breadcrumb a {
  display: block;
  position: relative;
  text-decoration: underline;
}

.breadcrumb a::after {
  background-color: #333;
  content: "";
  height: 2px;
  position: absolute;
  right: -1.7rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
}

.p-index-key {
  margin-bottom: 16rem;
  min-height: 100vh;
  position: relative;
  width: 100%;
}

@media screen and (max-width: 700px) {
  .p-index-key {
    /* margin-bottom: 12.5rem; */
    margin-bottom: 5.2rem;
  }
}

.p-index-key img {
  pointer-events: none;
  z-index: -1;
}

.p-index-key__inner {
  min-height: 100vh;
  position: relative;
  width: 100%;
}

.p-index-key__box {
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 700px) {
  .p-index-key__box {
    top: 55%;
  }
}

.p-index-key__title {
  margin-bottom: 6.8rem;
  width: 34.827rem;
}

@media screen and (max-width: 700px) {
  .p-index-key__title {
    margin-bottom: 5.19rem;
    width: 21.117rem;
  }
}

.p-index-key__title img {
  width: 100%;
}

.p-index-key__motion-area {
  border: 3px #fff solid;
  height: 12.02rem;
  margin-bottom: 6.18rem;
  position: relative;
  width: 39.539rem;
}

@media screen and (max-width: 700px) {
  .p-index-key__motion-area {
    height: 5.812rem;
    margin-bottom: 6.98rem;
    width: 29.557rem;
  }
}

.p-index-key__large-en {
  color: #fff;
  font-size: 4.4rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  margin-bottom: 1.1rem;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-index-key__large-en {
    font-size: 2.4rem;
    text-align: left;
  }
}

.p-index-key__large-en span {
  display: inline-block;
  margin-right: 1rem;
}

.p-index-key__sub {
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.13em;
  margin: auto;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-index-key__sub {
    font-size: 1.7rem;
    letter-spacing: 0.16em;
    line-height: 1.8;
    margin: 0;
  }
}

.p-index-key__topic-area {
  border: 1px #fff solid;
  bottom: 5.1rem;
  display: flex;
  height: 7.5rem;
  position: absolute;
  right: 0;
  width: 54.2rem;
}

@media screen and (max-width: 700px) {
  .p-index-key__topic-area {
    border: 1px var(--main-color) solid;
    bottom: -5.2rem;
    height: 5.2rem;
    width: 100%;
  }
}

@media (min-width: 900px) and (max-height: 780px) {
  .p-index-key__topic-area {
    width: 40rem;
  }
}

.p-index-key__topic-title {
  align-items: center;
  border-right: 1px #fff solid;
  color: #fff;
  display: flex;
  height: 100%;
  justify-content: center;
  width: 11.8rem;
}

@media screen and (max-width: 700px) {
  .p-index-key__topic-title {
    border-right: 1px var(--main-color) solid;
    color: var(--main-color);
    width: 20%;
  }
}

.p-index-key__topic-flex {
  animation: shift-text 10s linear 0s infinite;
  display: flex;
  gap: 2rem;
}

.p-index-key__topic-content {
  -ms-overflow-style: none;
  height: 100%;
  max-width: 100%;
  overflow-x: scroll;
  overflow-y: hidden;
  padding: 3.1rem 2rem;
  scrollbar-width: none;
  width: 42.4rem;
}

@media screen and (max-width: 700px) {
  .p-index-key__topic-content {
    padding: 2rem 1.6rem;
    width: 80%;
  }
}

.p-index-key__topic-content p {
  color: #fff;
  display: inline-block;
  font-size: 1.2rem;
  letter-spacing: 0.06em;
  white-space: nowrap;
  white-space: nowrap;
  position: relative;
  padding-right: 2rem;
}

@media screen and (max-width: 700px) {
  .p-index-key__topic-content p {
    color: var(--main-color);
  }
}

.p-index-key__topic-content p::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  width: 1px;
  height: 1.2rem;
  background: #fff;
}

@media screen and (max-width: 700px) {
  .p-index-key__topic-content p::before {
    background: var(--main-color);
  }
}

.p-index-key__topic-content::-webkit-scrollbar {
  display: none;
}

@keyframes shift-text {
  from {
    transform: translate(100%);
  }

  99%,
  to {
    transform: translate(-300%);
  }
}

.p-index-key__change-images {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}

.st0 {
  fill: #fff;
  stroke-width: 10;
}

.st1 {
  fill: none;
  stroke: #fff;
  stroke-width: 20;
  stroke-miterlimit: 10;
}

.move-svg {
  display: block;
  left: 0;
  position: absolute;
  top: -3rem;
}

@media screen and (max-width: 700px) {
  .move-svg {
    left: -1rem;
    top: -3rem;
  }
}

.p-index-key__top-banner {
  bottom: 17rem;
  position: absolute;
  right: 0;
  z-index: 5;
}

.p-index-key__top-banner img {
  width: 29.8rem;
}

.p-index-banner {
  margin-bottom: 6.6rem;
}

.p-index-banner img {
  display: block;
  margin: auto;
  width: 32rem;
}

.p-index-banner__title-cover {
  margin-bottom: 2.8rem;
}

@media screen and (max-width: 700px) {
  .p-index-banner {
    margin-bottom: 8rem;
  }

  .p-index-banner img {
    width: 100%;
  }
}

.p-index-about {
  padding-bottom: 15.03rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-index-about {
    padding-bottom: 11.2rem;
  }
}

.p-index-about__flex {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .p-index-about__flex {
    flex-direction: column;
    gap: 5.6rem;
  }
}

.p-index-about__right {
  max-width: 100%;
  width: 60rem;
}

@media screen and (max-width: 700px) {
  .p-index-about__right {
    width: 100%;
  }
}

.p-index-about__title-cover {
  margin-bottom: 7.2rem;
}

@media screen and (max-width: 700px) {
  .p-index-about__title-cover {
    margin-bottom: 4.9rem;
  }
}

.p-index-about__catchphrase {
  font-size: 5.6rem;
  font-weight: bold;
  letter-spacing: 0.11em;
  line-height: 1.3;
  margin-bottom: 6.4rem;
}

@media screen and (max-width: 700px) {
  .p-index-about__catchphrase {
    font-size: 2.8rem;
    margin-bottom: 3.2rem;
  }
}

.p-index-about__label {
  background-color: var(--main-color);
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.06em;
  padding: 1rem 1.2rem;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-index-about__label {
    font-size: 1.4rem;
    padding: 0.6rem 0.8rem;
  }
}

.p-index-about__text {
  letter-spacing: 0.04em;
  line-height: 1.9;
}

@media screen and (max-width: 700px) {
  .p-index-about__text {
    font-size: 1.4rem;
    line-height: 1.8;
  }
}

.p-index-about__large-en {
  color: #fff;
  font-size: 12.5vmax;
  font-weight: bold;
  position: absolute;
  right: -5rem;
  top: -16rem;
  z-index: -1;
}

@media screen and (max-width: 700px) {
  .p-index-about__large-en {
    font-size: 7.2rem;
    right: -10rem;
    top: 7rem;
    transform: rotate(-90deg);
  }
}

.p-index-team {
  padding-bottom: 16rem;
}

@media screen and (max-width: 700px) {
  .p-index-team {
    padding-bottom: 14rem;
  }
}

.p-index-team__inner {
  position: relative;
}

.p-index-team__title-cover {
  margin-bottom: 7.99rem;
}

@media screen and (max-width: 700px) {
  .p-index-team__title-cover {
    margin-bottom: 5.6rem;
  }
}

.p-index-team__button {
  position: relative;
  top: -7rem;
}

@media screen and (max-width: 700px) {
  .p-index-team__button {
    margin-left: auto;
    margin-top: 4rem;
    position: static;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.p-index-team__large-en {
  color: #fff;
  font-size: 18rem;
  font-weight: bold;
  left: 20rem;
  position: absolute;
  top: -3.5rem;
}

@media screen and (max-width: 700px) {
  .p-index-team__large-en {
    bottom: -54rem;
    font-size: 7.2rem;
    left: -1rem;
    top: auto;
  }
}

.p-index-benefit {
  padding-bottom: 16.1rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-index-benefit {
    padding-bottom: 13rem;
  }
}

.p-index-benefit__title-cover {
  margin-bottom: 8.17rem;
}

@media screen and (max-width: 700px) {
  .p-index-benefit__title-cover {
    margin-bottom: 4.97rem;
  }
}

.p-index-benefit__flex {
  display: flex;
  flex-wrap: wrap;
  gap: 9.75rem 8rem;
}

@media screen and (max-width: 700px) {
  .p-index-benefit__flex {
    gap: 4.24rem 3.2rem;
  }
}

.p-index-benefit__article {
  max-width: 100%;
  width: 32rem;
}

@media screen and (max-width: 700px) {
  .p-index-benefit__article {
    width: 45%;
  }
}

.p-index-benefit__icon {
  height: 13.6rem;
  margin: 0 auto 3.08rem;
  width: 100%;
}

@media screen and (max-width: 700px) {
  .p-index-benefit__icon {
    height: 10.995rem;
    margin: 0 auto 2.07rem;
  }
}

@media screen and (max-width: 700px) {
  .p-index-benefit__icon--margin-bottom {
    margin: 0 auto 3.7rem;
  }
}

.p-index-benefit__name {
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  margin-bottom: 4.2rem;
  position: relative;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-index-benefit__name {
    font-size: 1.2rem;
    line-height: 1.3333333333;
    margin-bottom: 3.4rem;
  }
}

.p-index-benefit__name::after {
  background-image: linear-gradient(to right, #000, #000 5px, transparent 5px, transparent 8px);
  background-repeat: repeat-x;
  background-size: 8px 2px;
  bottom: -1.4rem;
  content: "";
  height: 1px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 13.4rem;
}

.p-index-benefit__jp {
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.04em;
  margin-bottom: 2.4rem;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-index-benefit__jp {
    font-size: 1.3rem;
    line-height: 1.5384615385;
    margin-bottom: 1.6rem;
  }
}

.p-index-benefit__text {
  letter-spacing: 0.07em;
  line-height: 2.1538461538;
}

@media screen and (max-width: 700px) {
  .p-index-benefit__text {
    font-size: 1.1rem;
    letter-spacing: 0.04em;
    line-height: 1.8181818182;
  }
}

.p-index-benefit__large-en {
  color: #fff;
  font-size: 12.5vmax;
  font-weight: bold;
  position: absolute;
  right: -2rem;
  top: -10rem;
  z-index: -1;
}

@media screen and (max-width: 700px) {
  .p-index-benefit__large-en {
    font-size: 7.2rem;
    left: -12.5rem;
    right: auto;
    top: 16rem;
    transform: rotate(90deg);
  }
}

.svg-good {
  -webkit-animation: spin 5s linear infinite;
  -moz-animation: spin 5s linear infinite;
  animation: spin 5s linear infinite;
  display: block;
}

@keyframes spin {
  0% {
    -moz-transform: rotateY(0deg);
    -webkit-transform: rotateY(0deg);
    transform: rotateY(0deg);
  }

  100% {
    -moz-transform: rotateY(360deg);
    -webkit-transform: rotateY(360deg);
    transform: rotateY(360deg);
  }
}

#js-get01,
#js-get02,
#js-get03 {
  fill: none;
  stroke-width: 3px;
  stroke: #000;
}

.p-index-benefit path {
  fill: none;
  stroke-width: 3px;
  stroke: #000;
}

.p-index-benefit #A_2 path {
  fill: red;
}

.p-index-photos {
  padding-bottom: 16rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-index-photos {
    padding-bottom: 19.6rem;
  }
}

.p-index-photos__inner {
  position: relative;
}

.p-index-photos-left {
  padding-top: 56.25%;
  position: relative;
  width: 60%;
}

@media screen and (max-width: 700px) {
  .p-index-photos-left {
    left: -10rem;
    padding-top: 113.25%;
    width: 40vw;
  }
}

@media screen and (max-width: 480px) {
  .p-index-photos-left {
    width: 60vw;
  }
}

.p-index-photos-right {
  padding-top: 56.25%;
  position: absolute;
  right: 0;
  top: 30rem;
  width: 33%;
}

@media screen and (max-width: 700px) {
  .p-index-photos-right {
    padding-top: 113.25%;
    right: -3rem;
    top: 4rem;
    width: 62vw;
  }
}

.p-index-feature {
  padding-bottom: 20.2rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-index-feature {
    padding-bottom: 14rem;
  }
}

.p-index-feature__title-cover {
  margin-bottom: 2.8rem;
}

.p-index-feature__title-sub {
  font-size: 4rem;
  font-weight: bold;
  letter-spacing: 0.11em;
  margin-bottom: 7.7rem;
  padding-left: 3rem;
}

@media screen and (max-width: 700px) {
  .p-index-feature__title-sub {
    font-size: 2.4rem;
  }
}

.p-index-feature__flex {
  display: flex;
  gap: 9.6rem;
  margin-bottom: 12.9rem;
}

@media screen and (max-width: 700px) {
  .p-index-feature__flex {
    flex-direction: column;
    gap: 0;
    margin-bottom: 7.8rem;
  }
}

.p-index-feature__flex:last-of-type {
  margin-bottom: 0;
}

.p-index-feature__flex--right {
  margin-left: auto;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-index-feature__flex--right {
    margin-left: 0;
  }
}

.p-index-feature__left {
  max-width: 100%;
  position: relative;
  width: 20.5rem;
}

@media screen and (max-width: 700px) {
  .p-index-feature__left {
    width: 100%;
  }
}

.p-index-feature__right {
  max-width: 52.5rem;
}

.p-index-feature__right--large {
  max-width: 58.2rem;
}

.p-index-feature__en {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.4285714286;
}

@media screen and (max-width: 700px) {
  .p-index-feature__en {
    left: -1rem;
    position: relative;
    top: -2rem;
  }
}

.p-index-feature__number {
  bottom: -1rem;
  font-size: 9rem;
  font-weight: bold;
  letter-spacing: 0.04em;
  position: relative;
  right: -10rem;
}

@media screen and (max-width: 700px) {
  .p-index-feature__number {
    bottom: 2rem;
    font-size: 7.2rem;
    right: -7rem;
  }
}

.p-index-feature__number::after {
  background-color: var(--main-color);
  content: "";
  height: 2px;
  left: -2.8rem;
  position: absolute;
  top: -0.9rem;
  transform: rotate(-45deg);
  width: 3rem;
}

@media screen and (max-width: 700px) {
  .p-index-feature__number::after {
    top: 1.6rem;
  }
}

@media screen and (max-width: 700px) {
  .p-index-feature__number--left::after {
    left: -2.2rem;
  }
}

.p-index-feature__image {
  width: 10.5rem;
}

@media screen and (max-width: 700px) {
  .p-index-feature__image {
    position: absolute;
    right: 2rem;
    top: -1.3rem;
  }
}

.p-index-feature__image img {
  width: 100%;
}

.p-index-feature__sub {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.12em;
  line-height: 1.3333333333;
  margin-bottom: 2rem;
}

@media screen and (max-width: 700px) {
  .p-index-feature__sub {
    font-size: 2rem;
    margin-bottom: 1.8rem;
  }
}

.p-index-feature__text {
  letter-spacing: 0.04em;
  line-height: 1.7;
}

@media screen and (max-width: 700px) {
  .p-index-feature__text {
    line-height: 1.79;
  }
}

.p-index-feature__link {
  margin: 12.4rem 0 0 auto;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-index-feature__link {
    margin: 7.2rem 0 0 auto;
  }
}

@media screen and (max-width: 700px) {
  .p-index-feature-small {
    padding: 0;
  }
}

.p-index-feature__large-en {
  color: #fff;
  font-size: 18rem;
  font-weight: bold;
  position: absolute;
  right: -28.8rem;
  top: 10rem;
  transform: rotate(-90deg);
}

@media screen and (max-width: 700px) {
  .p-index-feature__large-en {
    font-size: 7.2rem;
    right: -13.8rem;
    top: 13rem;
    z-index: -1;
  }
}

.p-index-before-after {
  padding-bottom: 25rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-index-before-after {
    padding-bottom: 12rem;
  }
}

.p-index-before-after__title-cover {
  margin-bottom: 8rem;
}

.p-index-before-after__slider .swiper-slide {
  width: 33.4rem;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__slider .swiper-slide {
    width: 100%;
  }
}

.p-index-before-after__slider .swiper-wrapper {
  gap: 3rem;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__slider .swiper-wrapper {
    gap: 0;
  }
}

.p-index-before-after__slider .swiper-button-next {
  display: none;
  height: 4.7rem;
  left: 7.8rem;
  right: auto;
  top: 83.8%;
  width: 4.7rem;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__slider .swiper-button-next {
    display: block;
  }
}

.p-index-before-after__slider .swiper-button-next::after {
  background: url(../img/topic/topic-slider-arrow-next.png) center no-repeat;
  background-size: 110%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}

.p-index-before-after__slider .swiper-button-prev {
  display: none;
  height: 4.7rem;
  left: 2.4rem;
  right: auto;
  top: 83.8%;
  width: 4.7rem;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__slider .swiper-button-prev {
    display: block;
  }
}

.p-index-before-after__slider .swiper-button-prev::after {
  background: url(../img/topic/topic-slider-arrow-prev.png) center no-repeat;
  background-size: 110%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}

.p-index-before-after__sub {
  margin-bottom: 2.17rem;
  position: relative;
  width: 16rem;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__sub {
    margin-bottom: 1.6rem;
    width: 13rem;
  }
}

.p-index-before-after__sub img {
  width: 100%;
}

.p-index-before-after__user {
  margin-bottom: 3.1rem;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__slider .swiper-slide {
    width: 25.7rem;
  }
  .p-index-before-after__user {
    /* gap: 2rem; */
    margin-bottom: 1.5rem;
  }
}

.p-index-before-after__user img {
  width: 100%;
}

.p-index-before-after__user-box {
  margin-bottom: 2rem;
}

.p-index-before-after__user-box h3 {
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: calc(20 / 15);
  margin-bottom: 1.5rem;
  position: relative;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__user-box h3 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
  }
}

.p-index-before-after__user-box p {
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  /* line-height: 1.5384615385; */
  line-height: calc(20 / 13);
}

.p-index-before-after__user-box p:first-of-type {
  margin-bottom: 2rem;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__user-box p:first-of-type {
    margin-bottom: 1rem;
  }
}

.p-index-before-after__graph {
  margin-bottom: 3rem;
  width: 100%;
}

.p-index-before-after__details {
  align-items: center;
  display: flex;
  gap: 3.2rem;
  padding: 1.6rem 1.5rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__details {
    gap: 3.2rem;
    padding: 1.6rem 0.5rem;
    width: 100%;
  }
}

.p-index-before-after__details::before {
  background-image: linear-gradient(to right, #000000 14rem, transparent 1rem);
  background-size: 15rem 1rem;
  background-repeat: repeat-x;
  background-position: left bottom;
  top: 0;
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  width: 100%;
}

.p-index-before-after__details::after {
  background-image: linear-gradient(to right, #000000 14rem, transparent 1rem);
  background-size: 15rem 1rem;
  background-repeat: repeat-x;
  background-position: left bottom;
  bottom: 0;
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  width: 100%;
}
@media screen and (max-width: 700px) {
  .p-index-before-after__details::before {
    background-image: linear-gradient(to right, #000000 10rem, transparent 1rem);
    background-size: 11rem 1rem;
  }

  .p-index-before-after__details::after {
    background-image: linear-gradient(to right, #000000 10rem, transparent 1rem);
    background-size: 11rem 1rem;
  }
}

/* @media screen and (max-width: 700px) {
  .p-index-before-after__details::after {
    background-size: 150%;
  }
} */
.p-index-before-after__details-body {
  width: fit-content;
}
.p-index-before-after__details-body .ttl {
  font-size: 1.3rem;
  font-weight: 500;
  margin-bottom: 0.6rem;
}
.p-index-before-after__details-body .txt {
  width: fit-content;
  border: 1px var(--main-color) solid;
  font-size: 1rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  padding: 0.5rem 0.6rem 0.3rem;
}
.p-index-before-after__details-number {
  display: flex;
  align-items: center;
  width: fit-content;
}
.p-index-before-after__details-number-box {
  width: fit-content;
}
.p-index-before-after__details-number-box.before {
  position: relative;
  /* padding-right: 3rem; */
  padding-right: 2.4rem;
  margin-right: 1.4rem;
}
.p-index-before-after__details-number-box.before::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 0.9rem;
  height: 0.6rem;
  background: url(../img/program/program-arrow.svg) no-repeat center center / cover;
}
.p-index-before-after__details-number-box p {
  text-align: center;
}
.p-index-before-after__details-number-box p .ttl {
  display: block;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.02em;
  margin-bottom: 0.8em;
}
.p-index-before-after__details-number-box p .txt {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.02em;
}
.p-index-before-after__details-number-box p .txt span {
  font-size: 1.2rem;
}
@media screen and (max-width: 700px) {
  .p-index-before-after__details-number-box p .ttl {
    font-size: 1rem;
  }
  .p-index-before-after__details-number-box p .txt {
    font-size: 1.6rem;
  }
  .p-index-before-after__details-number-box p .txt span {
    font-size: 1.2rem;
  }
}

.p-index-before-after__details-down {
  border: 1px var(--main-color) solid;
  font-size: 1rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  padding: 0.5rem 0.6rem 0.3rem;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: -moz-fit-content;
  width: fit-content;
}

.p-index-before-after__link {
  margin: 12.4rem 0 0 auto;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__link {
    margin: 6.4rem 0 0 auto;
  }
}

.p-index-before-after__large-en {
  color: #fff;
  font-size: 9.5vmax;
  font-weight: bold;
  position: absolute;
  right: -3rem;
  top: -10rem;
  z-index: -1;
}

@media screen and (max-width: 700px) {
  .p-index-before-after__large-en {
    font-size: 7.2rem;
    top: -7rem;
  }
}

.p-index-access {
  padding-bottom: 14.8rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-index-access {
    margin-bottom: 0;
    padding-bottom: 10rem;
  }
}

.p-index-access__title-cover {
  margin-bottom: 6.4rem;
}

.p-index-access__text {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  margin-top: 4rem;
}

.p-index-access__blue {
  margin-bottom: 10rem;
}

.p-index-access__flex {
  display: flex;
  justify-content: space-between;
  margin-bottom: 7.2rem;
  margin-left: auto;
  min-height: 43.2rem;
  width: 90%;
}

.p-index-access__left {
  min-height: 43.2rem;
  position: relative;
  width: 49%;
}

.p-index-access__right {
  filter: grayscale(1);
  min-height: 43.2rem;
  position: relative;
  width: 49%;
}

.p-index-access__accent {
  bottom: 2rem;
  color: #fff;
  font-size: 4.2rem;
  font-weight: bold;
  left: 5.8rem;
  position: absolute;
}

.p-index-access__button {
  bottom: 3.2rem;
  position: absolute;
  right: 8rem;
}

.p-index-access__flex02 {
  display: flex;
  justify-content: space-between;
}

.p-index-access__sub {
  font-size: 6.4rem;
  font-weight: bold;
  letter-spacing: 0.02em;
}

.p-index-access__details {
  max-width: 100%;
  min-height: 10rem;
  width: 67.85rem;
}

.p-index-access__base-ul {
  display: flex;
  flex-wrap: wrap;
  gap: 3.2rem 6rem;
}

@media screen and (max-width: 700px) {
  .p-index-access__base-ul {
    margin-bottom: 4.8rem;
  }
}

.p-index-access__base-ul li {
  width: 30.4rem;
}

.p-index-access__base-main,
.p-index-access__base-sub {
  letter-spacing: 0.1em;
  line-height: 1.7;
  padding-left: 1.6rem;
  position: relative;
}

.p-index-access__base-main::after {
  border: 1px var(--main-color) solid;
  border-radius: 100vmax;
  content: "";
  height: 0.8rem;
  left: 0;
  position: absolute;
  top: 36.6%;
  transform: translateY(-50%);
  width: 0.8rem;
}

@media screen and (max-width: 700px) {
  .p-index-access__base-main::after {
    top: 36.2%;
  }
}

.p-index-access__large-text {
  color: #fff;
  font-size: 18rem;
  font-weight: bold;
  left: -6rem;
  position: absolute;
  top: 5.5rem;
  writing-mode: vertical-rl;
}

.p-index-access__route {
  margin: 6rem auto 0;
  position: relative;
  /* border-top: 1px solid #1a1311;
  border-bottom: 1px solid #1a1311; */
  width: 100%;
}
@media screen and (max-width: 700px) {
  .p-index-access__route {
    margin: 4rem auto 0;
    padding: 0;
  }
}

.p-index-access__route .pulldown {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 3rem 4rem 3rem 0;
  /* cursor: pointer; */
  position: relative;
}
@media screen and (max-width: 700px) {
  .p-index-access__route .pulldown {
    font-size: 16px;
    padding: 2rem 3.5rem 2rem 0;
    line-height: calc(24 / 15);
  }
}
/* .p-index-access__route .pulldown:after {
  content: "";
  border: solid #1a1311;
  border-width: 0 2px 2px 0;
  padding: 0.4rem;
  position: absolute;
  right: 1.5rem;
  top: 47%;
  transform: translateY(-50%) rotate(45deg);
  transition: all 0.4s;
}
@media screen and (max-width: 700px) {
  .p-index-access__route .pulldown:after {
    right: 1rem;
  }
}
.p-index-access__route .pulldown.active:after {
  top: 53%;
  transform: translateY(-50%) rotate(-135deg);
} */
.p-index-access__route .inner {
  overflow-x: scroll;
  margin-right: calc(50% - 50vw);
  /* display: none; */
}
.p-index-access__route ul {
  margin-top: 1.5rem;
  display: flex;
  width: fit-content;
  padding: 0 3rem 3rem 0;
  gap: 3rem;
}
.p-index-access__route ul li {
  width: 29.6rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.2rem 0.8rem;
  position: relative;
}
.p-index-access__route ul li .num {
  width: 2.8rem;
  height: 2.8rem;
  border: 1px solid #1a1311;
  border-radius: 50%;
  font-size: 1.2rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 0.3rem;
}
.p-index-access__route ul li .txt {
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.p-index-access__route ul li .img {
  width: 100%;
  position: relative;
}
.p-index-access__route ul li .img:after {
  content: "";
  border: 1.2rem solid transparent;
  border-left: 1.2rem solid #1a1311;
  position: absolute;
  right: -1rem;
  top: 50%;
  transform: translate(100%, -50%);
}
.p-index-access__route ul li:last-child .img:after {
  display: none;
}
.p-index-access__route ul li .img img {
  width: 100%;
}

@media screen and (max-width: 700px) {
  .p-index-studio__base-cover {
    margin: auto;
  }
}

.p-index-google {
  margin-bottom: 16rem;
}

@media screen and (max-width: 700px) {
  .p-index-google {
    margin-bottom: 8rem;
  }
}

.p-index-ggoogle__title-cover {
  margin-bottom: 4.4rem;
}

.wp-gr:not(.wp-dark) .grw-review-inner.grw-backgnd {
  background: red !important;
}

.p-index-faq__flex {
  align-items: flex-end;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .p-index-faq__flex {
    flex-direction: column;
    gap: 4.8rem;
  }
}

.p-index-faq__text {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  margin-bottom: 7.1rem;
}

@media screen and (max-width: 700px) {
  .p-index-faq__text {
    margin-bottom: 2.8rem;
  }
}

.p-index-faq__contents {
  max-width: 100%;
  width: 80rem;
}

@media screen and (max-width: 700px) {
  .p-index-faq__contents {
    width: 100%;
  }
}

.p-index-covid__title-cover {
  margin-bottom: 6.4rem;
}

@media screen and (max-width: 700px) {
  .p-index-covid__title-cover {
    margin-bottom: 5.6rem;
  }
}

.p-index-covid__sub {
  font-size: 2rem;
  letter-spacing: 0.12em;
  margin-bottom: 3.2rem;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-index-covid__sub {
    margin-bottom: 2.2rem;
    text-align: left;
  }
}

.p-index-covid__text {
  font-size: 1.3rem;
  letter-spacing: 0.04em;
  margin-bottom: 4.8rem;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-index-covid__text {
    letter-spacing: 0.1em;
    line-height: 2;
    margin-bottom: 4rem;
    text-align: left;
  }
}

.p-index-covid__flex {
  display: flex;
  margin: auto;
  max-width: 100%;
  width: 72.8rem;
}

@media screen and (max-width: 700px) {
  .p-index-covid__flex {
    flex-wrap: wrap;
    gap: 4.8rem 3.3rem;
    justify-content: center;
    width: 90%;
  }
}

.p-index-covid__item {
  margin: auto;
  text-align: center;
  width: 17rem;
}

@media screen and (max-width: 700px) {
  .p-index-covid__item {
    margin: 0;
    width: 13rem;
  }
}

.p-index-covid__item-img {
  height: 10.7rem;
  margin-bottom: 0.6rem;
  position: relative;
  width: 100%;
}

@media screen and (max-width: 700px) {
  .p-index-covid__item-img {
    height: 8rem;
  }
}

.p-index-covid__item-img img {
  -o-object-fit: scale-down;
  height: 100%;
  left: 50%;
  object-fit: scale-down;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}

@media screen and (max-width: 700px) {
  .p-index-covid__item-img img {
    transform: translate(-50%, -50%) scale(0.85);
  }
}

.p-index-covid__item-text {
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: 1.8461538462;
}

.p-index-topic {
  padding-top: 10rem;
  position: relative;
}

.p-index-topic__slider {
  margin-top: 6rem;
  margin-bottom: 5.5rem;
}
@media screen and (max-width: 700px) {
  .p-index-topic__slider {
    margin-top: 4rem;
  }
}

@media screen and (min-width: 701px) {
  .p-index-topic__slider .swiper-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 6rem 8rem;
  }
  .p-index-topic__slider .swiper-slide {
    width: calc(33.333% - (16rem / 3));
  }
}

@media screen and (max-width: 700px) {
  .p-index-topic__slider .swiper-slide {
    width: 248px !important;
  }
}

.p-index-topic__slider .img {
  position: relative;
  padding-top: 55%;
  margin-bottom: 2rem;
}
@media screen and (max-width: 700px) {
  .p-index-topic__slider .img {
    margin-bottom: 1.2rem;
  }
}

.p-index-topic__slider .ttl {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: calc(26 / 16);
  margin-bottom: 2.8rem;
}
@media screen and (max-width: 700px) {
  .p-index-topic__slider .ttl {
    font-size: 1.4rem;
  }
}

.p-index-topic__slider .in {
  display: flex;
  justify-content: flex-end;
  gap: 5.5rem;
  padding-bottom: 3.8rem;
  border-bottom: 1px solid #1a1311;
}
@media screen and (max-width: 700px) {
  .p-index-topic__slider .in {
    justify-content: flex-start;
    gap: 4rem;
    padding-bottom: 2rem;
  }
}
.p-index-topic__slider .date {
  font-size: 1.2rem;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 700px) {
  .p-index-topic__slider .date {
    font-size: 1rem;
  }
}
.p-index-topic__slider .cat {
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  position: relative;
}
@media screen and (max-width: 700px) {
  .p-index-topic__slider .cat {
    font-size: 1rem;
  }
}
.p-index-topic__slider .cat:before {
  content: "";
  width: 1px;
  height: 1.3rem;
  background: #1a1311;
  position: absolute;
  left: -2.2rem;
  top: -1px;
}
@media screen and (max-width: 700px) {
  .p-index-topic__slider .cat:before {
    left: -1.2rem;
  }
}

.p-index-topic__slider .swiper-button-next {
  display: none;
  height: 4.7rem;
  left: 7.8rem;
  right: auto;
  top: auto;
  bottom: 0;
  width: 4.7rem;
}

@media screen and (max-width: 700px) {
  .p-index-topic__slider .swiper-button-next {
    display: block;
  }
}

.p-index-topic__slider .swiper-button-next::after {
  background: url(../img/topic/topic-slider-arrow-next.png) center no-repeat;
  background-size: 110%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}

.p-index-topic__slider .swiper-button-prev {
  display: none;
  height: 4.7rem;
  left: 2.4rem;
  right: auto;
  top: auto;
  bottom: 0;
  width: 4.7rem;
}

@media screen and (max-width: 700px) {
  .p-index-topic__slider .swiper-button-prev {
    display: block;
  }
}

.p-index-topic__slider .swiper-button-prev::after {
  background: url(../img/topic/topic-slider-arrow-prev.png) center no-repeat;
  background-size: 110%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}

.p-index-topic .c-link-button {
  margin: 0 0 0 auto;
}

.p-about-philosophy {
  padding-top: 14.3rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy {
    padding-top: 14rem;
  }
}

.p-about-philosophy__flex {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__flex {
    flex-direction: column;
    gap: 4rem;
  }
}

.p-about-philosophy__right {
  max-width: 100%;
  width: 60rem;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__right {
    width: 100%;
  }
}

.p-about-philosophy__title-cover {
  margin-bottom: 7.2rem;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__title-cover {
    margin-bottom: 4.9rem;
  }
}

.p-about-philosophy__en-catchphrase {
  font-size: 7.2rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  margin-bottom: 2rem;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__en-catchphrase {
    font-size: 4rem;
  }
}

.p-about-philosophy__catchphrase {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.11em;
  line-height: 1.3;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__catchphrase {
    font-size: 1.7rem;
  }
}

.p-about-philosophy__text {
  letter-spacing: 0.04em;
  line-height: 1.9;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__text {
    line-height: 1.8;
  }
}

.p-about-philosophy__text .--space {
  display: block;
  margin-bottom: 3rem;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__text .--space {
    margin-bottom: 1.5rem;
  }
}

.p-about-philosophy__large-en {
  color: #fff;
  font-size: 12.5vmax;
  font-weight: bold;
  position: absolute;
  right: -5rem;
  top: -3rem;
  z-index: -1;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__large-en {
    display: none;
  }
}

.p-about-philosophy__update {
  border-top: 1px #1a1311 solid;
  margin: 8rem auto 0;
  max-width: 100%;
  padding-top: 8rem;
  width: 122.3rem;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__update {
    margin: 5.6rem auto 0;
    padding-top: 5.6rem;
    width: 89%;
  }
}

.p-about-philosophy__update-title {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.11em;
  margin-bottom: 5.2rem;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-about-philosophy__update-title {
    font-size: 1.8rem;
    line-height: 1.7777777778;
    margin-bottom: 4rem;
  }
}

.p-about-philosophy__update-image {
  width: 100%;
}

.p-about-data {
  padding-top: 14rem;
}

.p-about-data__title-cover {
  margin-bottom: 9.7rem;
}

.p-about-data__flex {
  display: flex;
  flex-wrap: wrap;
  gap: 7.2rem 8.35rem;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .p-about-data__flex {
    flex-direction: column;
    gap: 9.62rem;
  }
}

.p-about-data__article {
  width: 45%;
}

@media screen and (max-width: 700px) {
  .p-about-data__article {
    margin: auto;
    max-width: 100%;
    width: 35rem;
  }
}

.p-about-data__article:nth-of-type(3) {
  width: 40%;
}

@media screen and (max-width: 700px) {
  .p-about-data__article:nth-of-type(3) {
    margin: auto;
    max-width: 100%;
    width: 37.5rem;
  }
}

.p-about-data__article-en {
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  margin-bottom: 0.6rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-about-data__article-en {
    font-size: 1.4rem;
  }
}

.p-about-data__article-en::after {
  background-color: var(--main-color);
  bottom: -3rem;
  content: "";
  height: 2px;
  left: 5rem;
  position: absolute;
  transform: rotate(-50deg);
  width: 2.3rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__article-en::after {
    left: 5.5rem;
    width: 3rem;
  }
}

.p-about-data__article-jp {
  font-size: 1.4rem;
  letter-spacing: 0.12em;
}

@media screen and (max-width: 700px) {
  .p-about-data__article-jp {
    font-size: 1.2rem;
  }
}

.p-about-data__article-jp--mb {
  margin-bottom: 4rem;
}

.p-about-data__image {
  position: relative;
}

.p-about-data__image img {
  width: 100%;
}

.p-about-data__member {
  margin-top: 0.6rem;
}

.p-about-data__member h4 {
  font-size: 8.4rem;
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-about-data__member h4 {
    font-size: 6.4rem;
  }
}

.p-about-data__member span {
  font-size: 2.4rem;
}

.p-about-data__member img {
  width: 100%;
}

.p-about-data__man-woman {
  margin-top: 0.6rem;
}

.p-about-data__man-woman h4 {
  font-size: 8.4rem;
  font-weight: bold;
  margin-bottom: 3rem;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-about-data__man-woman h4 {
    font-size: 6.4rem;
    margin-bottom: 1.6rem;
  }
}

.p-about-data__man-woman img {
  width: 100%;
}

.p-about-data__course {
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-about-data__course {
    margin-bottom: 4rem;
  }
}

.p-about-data__course img {
  display: block;
  margin: auto;
  width: 26.295rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__course img {
    left: 1rem;
    position: relative;
    top: 1.6rem;
    width: 20rem;
  }
}

.p-about-data__course-item {
  position: absolute;
}

.p-about-data__course-item:nth-of-type(1) {
  left: 0;
  top: 0;
}

.p-about-data__course-item:nth-of-type(2) {
  right: 2rem;
  top: -3rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__course-item:nth-of-type(2) {
    right: 0;
    top: -1.5rem;
  }
}

.p-about-data__course-item:nth-of-type(3) {
  bottom: -4.6rem;
  left: 0;
}

.p-about-data__course-item .--text {
  font-size: 1.3rem;
  letter-spacing: 0.02em;
  margin-bottom: 0.6rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__course-item .--text {
    font-size: 1.2rem;
  }
}

.p-about-data__course-item .--number {
  font-size: 4.2rem;
  font-weight: bold;
}

@media screen and (max-width: 700px) {
  .p-about-data__course-item .--number {
    font-size: 3.2rem;
  }
}

.p-about-data__course-item .--number span {
  font-size: 3.2rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__course-item .--number span {
    font-size: 2.4rem;
  }
}

.p-about-data__course-text {
  left: 48%;
  letter-spacing: 0.08em;
  line-height: 1.4375;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 700px) {
  .p-about-data__course-text {
    font-size: 1.2rem;
    left: 51%;
    position: absolute;
    top: 60%;
  }
}

.p-about-data__age {
  position: relative;
}

.p-about-data__age img {
  width: 100%;
}

.p-about-data__age-small {
  align-items: center;
  display: flex;
  flex-direction: column;
  left: 0.8rem;
  position: absolute;
  top: 13.5rem;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-small {
    top: 8.5rem;
  }
}

.p-about-data__age-small .--age {
  align-items: center;
  border: 1px #333 dotted;
  border-radius: 100vmax;
  display: flex;
  font-size: 1.5rem;
  font-weight: bold;
  height: 2.7rem;
  justify-content: center;
  letter-spacing: 0.02em;
  margin-bottom: 1rem;
  padding-top: 0.5rem;
  width: 6.6rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-small .--age {
    font-size: 1rem;
    height: 1.6rem;
    width: 3.8rem;
  }
}

.p-about-data__age-small .--number {
  font-size: 2.5rem;
  font-weight: bold;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-small .--number {
    font-size: 1.6rem;
  }
}

.p-about-data__age-small .--number span {
  font-size: 1.9rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-small .--number span {
    font-size: 1.2rem;
  }
}

.p-about-data__age-medium {
  align-items: center;
  display: flex;
  gap: 1.2rem;
  position: absolute;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-medium {
    gap: 0.8rem;
  }
}

.p-about-data__age-medium:nth-of-type(1) {
  left: 5.5rem;
  top: 1.8rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-medium:nth-of-type(1) {
    top: 1.2rem;
  }
}

.p-about-data__age-medium:nth-of-type(2) {
  right: 1rem;
  top: 1.8rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-medium:nth-of-type(2) {
    top: 1.2rem;
  }
}

.p-about-data__age-medium .--age {
  align-items: center;
  border: 1px #333 dotted;
  border-radius: 100vmax;
  display: flex;
  font-size: 1.9rem;
  font-weight: bold;
  height: 3.5rem;
  justify-content: center;
  letter-spacing: 0.02em;
  padding-top: 0.5rem;
  width: 7rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-medium .--age {
    font-size: 1.2rem;
    height: 2.1rem;
    width: 4.1rem;
  }
}

.p-about-data__age-medium .--number {
  font-size: 4rem;
  font-weight: bold;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-medium .--number {
    font-size: 2.4rem;
  }
}

.p-about-data__age-medium .--number span {
  font-size: 2rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-medium .--number span {
    font-size: 1.8rem;
  }
}

.p-about-data__age-large {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
  position: absolute;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-large {
    gap: 1rem;
  }
}

.p-about-data__age-large--one {
  left: 10.8rem;
  top: 10rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-large--one {
    left: 7.5rem;
    top: 7rem;
  }
}

.p-about-data__age-large--two {
  right: 3.5rem;
  top: 10rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-large--two {
    right: 2rem;
    top: 7rem;
  }
}

.p-about-data__age-large .--age {
  align-items: center;
  background: #e8e8e8;
  border: 1px #333 dotted;
  border-radius: 100vmax;
  display: flex;
  font-size: 1.9rem;
  font-weight: bold;
  height: 3.5rem;
  justify-content: center;
  letter-spacing: 0.02em;
  padding-top: 0.5rem;
  width: 7rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-large .--age {
    font-size: 1.2rem;
    height: 2.1rem;
    width: 4.2rem;
  }
}

.p-about-data__age-large .--number {
  font-size: 7.8rem;
  font-weight: bold;
  letter-spacing: -0.07em;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-large .--number {
    font-size: 4.8rem;
  }
}

.p-about-data__age-large .--number span {
  font-size: 5.1rem;
}

@media screen and (max-width: 700px) {
  .p-about-data__age-large .--number span {
    font-size: 3.1rem;
  }
}

.p-about-stance {
  padding-top: 16.06rem;
}

@media screen and (max-width: 700px) {
  .p-about-stance {
    padding-top: 8rem;
  }
}

.p-about-stance__title-cover {
  margin-bottom: 8.8rem;
}

@media screen and (max-width: 700px) {
  .p-about-stance__title-cover {
    margin-bottom: 4.8rem;
  }
}

.p-about-stance__flex {
  display: flex;
  justify-content: space-between;
  margin-bottom: 7.8rem;
}

@media screen and (max-width: 700px) {
  .p-about-stance__flex {
    flex-direction: column;
    gap: 0;
    margin-bottom: 5.6rem;
  }
}

.p-about-stance__right {
  max-width: 100%;
  width: 65rem;
}

@media screen and (max-width: 700px) {
  .p-about-stance__right {
    width: 100%;
  }
}

.p-about-stance__catchphrase {
  font-size: 5.6rem;
  font-weight: bold;
  letter-spacing: 0.11em;
  line-height: 1.3;
}

@media screen and (max-width: 700px) {
  .p-about-stance__catchphrase {
    font-size: 2.8rem;
    letter-spacing: 0.1em;
    margin-bottom: 2rem;
  }
}

.p-about-stance__text {
  letter-spacing: 0.04em;
  line-height: 2.1333333333;
}

@media screen and (max-width: 700px) {
  .p-about-stance__text {
    line-height: 1.8;
  }
}

.p-about-stance__ul {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin: auto;
  margin-bottom: 8rem;
  margin-top: 4rem;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-about-stance__ul {
    gap: 1rem;
  }
}

.p-about-stance__list {
  letter-spacing: 0.04em;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-about-stance__list {
    left: -1.4rem;
  }
}

@media screen and (max-width: 700px) {
  .p-about-stance__list .js-text-trigger {
    display: inline-block;
    line-height: 1.8;
    padding-left: 3.1em;
    text-indent: -2.1em;
  }
}

.p-about-stance__list img {
  margin-right: 1rem;
  width: 1.7rem;
}

@media screen and (max-width: 700px) {
  .p-about-stance__list img {
    display: inline-block;
    position: relative;
    top: -0.2rem;
  }
}

.p-about-stance__images {
  display: flex;
  gap: 8.9rem;
  margin: auto;
  max-width: 102.4rem;
}

@media screen and (max-width: 700px) {
  .p-about-stance__images {
    flex-direction: column;
    gap: 6.4rem;
  }
}

.p-about-stance__image01 {
  max-width: 100%;
  width: 45.9rem;
}

.p-about-stance__image02 {
  max-width: 100%;
  width: 48.6rem;
}

.p-about-team {
  padding-top: 16.06rem;
}

@media screen and (max-width: 700px) {
  .p-about-team {
    padding-top: 14rem;
  }
}

.p-about-team__inner {
  position: relative;
}

.p-about-team__title-cover {
  margin-bottom: 7.99rem;
}

@media screen and (max-width: 700px) {
  .p-about-team__title-cover {
    margin-bottom: 5.6rem;
  }
}

.p-about-team__button {
  position: relative;
  top: -7rem;
}

@media screen and (max-width: 700px) {
  .p-about-team__button {
    margin-left: auto;
    margin-top: 4rem;
    position: static;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.p-about-team__large-en {
  color: #fff;
  font-size: 18rem;
  font-weight: bold;
  left: 20rem;
  position: absolute;
  top: -3.5rem;
}

@media screen and (max-width: 700px) {
  .p-about-team__large-en {
    bottom: -54rem;
    font-size: 7.2rem;
    left: -1rem;
    top: auto;
  }
}

.p-about-studio {
  padding-top: 16rem;
}

@media screen and (max-width: 700px) {
  .p-about-studio {
    padding-top: 6.6rem;
  }
}

.p-about-studio__title-cover {
  margin-bottom: 6.4rem;
}

@media screen and (max-width: 700px) {
  .p-about-studio__title-cover {
    margin-bottom: 4.8rem;
  }
}

.p-about-studio__base {
  display: flex;
  justify-content: space-between;
  position: relative;
  flex-wrap: wrap;
}

@media screen and (max-width: 700px) {
  .p-about-studio__base {
    flex-direction: column;
  }
}

.p-about-studio__base--mb {
  margin-bottom: 9.6rem;
}

.p-about-studio__base-image {
  background-color: #333;
  height: 48.9rem;
  max-width: 100%;
  position: relative;
  width: 73.3rem;
}

@media screen and (max-width: 700px) {
  .p-about-studio__base-image {
    margin-bottom: 3.2rem;
  }
}

.p-about-studio__base-large {
  bottom: 2rem;
  color: #fff;
  font-size: 4.2rem;
  font-weight: bold;
  left: 4rem;
  letter-spacing: 0.02em;
  position: absolute;
}

.p-about-studio__base-cover {
  max-width: 100%;
  width: 33rem;
}

.p-about-studio__base-title {
  font-size: 6.4rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  margin-bottom: 2.39rem;
}

@media screen and (max-width: 700px) {
  .p-about-studio__base-title {
    font-size: 4.2rem;
    margin-bottom: 1rem;
  }
}

.p-about-studio__base-label {
  border: 2px var(--main-color) solid;
  font-size: 1.3rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  margin-bottom: 3.6rem;
  padding: 0.8rem 0.8rem 0.4rem;
  width: -moz-fit-content;
  width: fit-content;
}

.p-about-studio__base-ul {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media screen and (max-width: 700px) {
  .p-about-studio__base-ul {
    margin-bottom: 3rem;
  }
}

.p-about-studio__base-main,
.p-about-studio__base-sub {
  letter-spacing: 0.1em;
  line-height: 1.7;
  padding-left: 1.6rem;
  position: relative;
}

.p-about-studio__base-main::after {
  border: 1px var(--main-color) solid;
  border-radius: 100vmax;
  content: "";
  height: 0.8rem;
  left: 0;
  position: absolute;
  top: 36.6%;
  transform: translateY(-50%);
  width: 0.8rem;
}

@media screen and (max-width: 700px) {
  .p-about-studio__base-main::after {
    top: 36.2%;
  }
}

.p-about-studio__base-button {
  margin: 3.4rem 0 0 auto;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-about-studio__base-button {
    margin: 4rem 0 0 auto;
  }
}

.p-about-studio__maps {
  background: #333;
  filter: grayscale(1);
  height: 26.2rem;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}

.p-about-studio__large-en {
  color: #fff;
  font-size: 7.2rem;
  font-weight: bold;
  position: absolute;
  right: -7.5rem;
  top: 14rem;
  transform: rotate(-90deg);
}

.p-about-studio__slider {
  margin-top: 4.5rem;
  width: 100%;
}
@media screen and (max-width: 700px) {
  .p-about-studio__slider {
    margin: 0 0 3.5rem;
  }
}
.p-about-studio__slider .swiper {
  width: 100%;
}
@media screen and (max-width: 700px) {
  .p-about-studio__slider .swiper {
    width: auto;
    margin: 0 calc(50% - 50vw) !important;
  }
}
.p-about-studio__slider .swiper-slide img {
  width: 100%;
}
@media screen and (max-width: 700px) {
  .p-about-studio__slider .swiper-wrapper {
  transition-timing-function: linear;
  }
}

.p-about-company {
  padding: 16rem 0;
}

@media screen and (max-width: 700px) {
  .p-about-company {
    padding: 12rem 0 14rem 0;
  }
}

.p-about-company__title-cover {
  margin-bottom: 6.4rem;
}

@media screen and (max-width: 700px) {
  .p-about-company__title-cover {
    margin-bottom: 5.3rem;
  }
}

.p-about-company__flex {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .p-about-company__flex {
    flex-direction: column;
  }
}

.p-about-company__table {
  max-width: 100%;
  width: 32.7rem;
}

@media screen and (max-width: 700px) {
  .p-about-company__table {
    margin-bottom: 4.8rem;
  }
}

.p-about-company__table table {
  border-collapse: separate;
  border-spacing: 1.6rem;
  width: 100%;
}

.p-about-company__table th {
  border-bottom: 1px var(--main-color) solid;
  letter-spacing: 0.1em;
  line-height: 1.5384615385;
  padding: 0.4rem 0 1.6rem 0;
  width: 40%;
}

.p-about-company__table td {
  border-bottom: 1px var(--main-color) solid;
  letter-spacing: 0.1em;
  line-height: 1.5384615385;
  padding: 0.4rem 0 1.6rem 0;
  width: 60%;
}

.p-about-company__table ._first {
  border-top: 1px var(--main-color) solid;
  padding: 1.6rem 0;
}

.p-about-company__map {
  filter: grayscale(1);
  height: 56.2rem;
  max-width: 100%;
  width: 71.7rem;
}

@media screen and (max-width: 700px) {
  .p-about-company__map {
    height: 26.2rem;
    margin: 0 calc(50% - 50vw);
    max-width: none;
    width: 100vw;
  }
}

.p-about-company__button {
  margin: 8rem 0 0 0;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-about-company__button {
    margin: 4rem 0 0 auto;
  }
}

.p-price-scroll {
  padding: 6.2rem 0 0 0;
}

.p-price-scroll__flex {
  align-items: center;
  display: flex;
  gap: 2.2rem;
  justify-content: center;
}

.p-price-scroll__link {
  display: block;
  height: 14rem;
  position: relative;
  width: 14rem;
}

.p-price-main {
  padding-top: 14.3rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-price-main {
    padding-top: 8rem;
  }
}

.p-price-main__title-cover {
  margin-bottom: 3.2rem;
}

@media screen and (max-width: 700px) {
  .p-price-main__title-cover {
    margin-bottom: 4rem;
  }
}

.p-price-main__text {
  letter-spacing: 0.1em;
  margin-bottom: 8rem;
}

@media screen and (max-width: 700px) {
  .p-price-main__text {
    margin-bottom: 5.6rem;
  }
}

.p-price-main__flex {
  align-items: flex-start;
  display: flex;
  gap: 8rem;
}

@media screen and (max-width: 700px) {
  .p-price-main__flex {
    flex-wrap: wrap;
    gap: 7.3rem;
  }
}

.p-price-article {
  max-width: 100%;
  width: 32.7rem;
}

@media screen and (max-width: 700px) {
  .p-price-article {
    margin: auto;
  }
}

.p-price-main__article-title {
  border-bottom: 2px var(--main-color) solid;
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.7083333333;
  margin-bottom: 3.2rem;
  width: -moz-fit-content;
  width: fit-content;
}

.p-price-main__article-text {
  letter-spacing: 0.1em;
  line-height: 2;
  margin-bottom: 4rem;
}

@media screen and (max-width: 700px) {
  .p-price-main__article-text {
    margin-bottom: 3.6rem;
  }
}

.p-price-main__article-table {
  border: 1px dashed var(--main-color);
  border-collapse: collapse;
  width: 100%;
}

.p-price-main__article-table--margin-bottom {
  margin-bottom: 4rem;
}

.p-price-main__article-th {
  border: 1px dashed var(--main-color);
  padding: 1.8rem 0;
  text-align: center;
  width: 50%;
}

.p-price-main__article-th--left {
  padding-left: 2.8rem;
  text-align: left;
}

.p-price-main__article-table td {
  border: 1px dashed var(--main-color);
  line-height: 1.5384615385;
  padding: 1.8rem 0;
  width: 50.2%;
}

.p-price-main__article-table ._price {
  font-size: 1.2rem;
  font-weight: bold;
}

.p-price-main__article-table ._td {
  letter-spacing: 0.007em;
}

.p-price-main__article-table ._td--large {
  letter-spacing: 0.007em;
}

.p-price-main__article-table ._td--center {
  text-align: center;
}

.p-price-main__article-table ._td--pd30 {
  padding: 1.8rem 3rem;
}

.p-price-main__article-table ._td--pd28 {
  padding: 1.8rem 2.8rem;
}

.p-price-main__article-table ._td--pd16 {
  padding: 1.8rem 1.6rem;
}

.p-price-main__article-table ._large {
  width: 65%;
}

.p-price-main__article-sub {
  letter-spacing: 0.12em;
  line-height: 2;
  margin-bottom: 1.2rem;
}

.p-price-main__large-en {
  color: #fff;
  font-size: 7.2rem;
  font-weight: bold;
  position: absolute;
  right: -8rem;
  top: 12rem;
  transform: rotate(-90deg);
  z-index: -1;
}

.p-price-main__maintenance-title {
  border-bottom: 2px var(--main-color) solid;
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.7083333333;
  margin-bottom: 3.2rem;
  width: -moz-fit-content;
  width: fit-content;
}

.p-price-main__maintenance-text {
  letter-spacing: 0.12em;
  line-height: 2;
  margin-bottom: 5.6rem;
}

.p-price-main__maintenance-flex {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 8rem;
}

@media screen and (max-width: 700px) {
  .p-price-main__maintenance-flex {
    flex-wrap: wrap;
    gap: 3.2rem;
    justify-content: center;
  }
}

.p-price-main__maintenance-item {
  max-width: 100%;
  width: 32rem;
}

.p-price-article__maintenance-sub {
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 1.9rem;
  padding-left: 1.6rem;
  position: relative;
}

.p-price-article__maintenance-sub::after {
  border: 1px var(--main-color) solid;
  border-radius: 100vmax;
  content: "";
  height: 0.8rem;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 0.8rem;
}

.p-price-article__maintenance-box {
  margin-top: 1.7rem;
}

.p-price-article__maintenance-text {
  border: 1px dashed var(--main-color);
  padding: 1.6rem;
}

.p-price-flow {
  padding: 14rem 0 16rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-price-flow {
    padding: 12.06rem 0 14rem;
  }
}

.p-price-flow__title-cover {
  margin-bottom: 3.2rem;
}

.p-price-flow__text {
  margin-bottom: 5.6rem;
}

.p-price-flow__contents {
  margin-left: auto;
  min-height: 10rem;
  overflow-x: scroll;
  overflow-y: hidden;
  padding-bottom: 3rem;
  padding-right: 4rem;
  width: 90%;
}

@media screen and (max-width: 700px) {
  .p-price-flow__contents {
    overflow-x: hidden;
    padding: 0 2.4rem;
    width: 100%;
  }
}

.p-price-flow__contents::-webkit-scrollbar {
  border-radius: 100vmax;
  cursor: pointer;
  height: 4px;
}

.p-price-flow__contents::-webkit-scrollbar-track {
  background-color: #c8c8c8;
  border-radius: 100vmax;
}

.p-price-flow__contents::-webkit-scrollbar-thumb {
  background-color: #434343;
  border-radius: 100vmax;
}

.p-price-flow__flex {
  align-items: flex-start;
  display: flex;
  gap: 9rem;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-price-flow__flex {
    flex-direction: column;
    gap: 4.05rem;
    margin: auto;
  }
}

.p-price-flow__article {
  max-width: 100%;
  width: 32rem;
}

@media screen and (max-width: 700px) {
  .p-price-flow__article {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
  }
}

.p-price-flow__article-step {
  height: 11rem;
  margin: 0 auto 3.2rem;
  position: relative;
  width: 11rem;
}

@media screen and (max-width: 700px) {
  .p-price-flow__article-step {
    margin: 0;
  }
}

.p-price-flow__article-step::after {
  background: url(../img/price/flow-line.webp) center no-repeat;
  background-size: cover;
  content: "";
  height: 1px;
  position: absolute;
  right: -30rem;
  top: 50%;
  transform: translateY(-50%);
  width: 30rem;
}

@media screen and (max-width: 700px) {
  .p-price-flow__article-step::after {
    background-size: 145%;
    bottom: -9.4rem;
    left: 50%;
    right: auto;
    top: auto;
    transform: translateX(-50%) rotate(-90deg);
    width: 18.6rem;
  }
}

.p-price-flow__article-step.--none::after {
  display: none;
}

@media screen and (max-width: 700px) {
  .p-price-flow__article:nth-of-type(2) .p-price-flow__article-step::after {
    background-size: 280%;
    bottom: -4.02rem;
    content: "";
    width: 8.3rem;
  }
}

@media screen and (max-width: 700px) {
  .p-price-flow__article:nth-of-type(3) .p-price-flow__article-step::after {
    background-size: 421%;
    bottom: -4.1rem;
    content: "";
    width: 7.5rem;
  }
}

@media screen and (max-width: 700px) {
  .p-price-flow__article:nth-of-type(4) .p-price-flow__article-step::after {
    background-size: 190%;
    bottom: -6.7rem;
    content: "";
    width: 13.2rem;
  }
}

@media screen and (max-width: 700px) {
  .p-price-flow__box {
    max-width: 100%;
    width: 18.9rem;
  }
}

.p-price-flow__article-title {
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.12em;
  line-height: 1.625;
  margin-bottom: 2.4rem;
  text-align: center;
}

@media screen and (max-width: 700px) {
  .p-price-flow__article-title {
    margin-bottom: 2rem;
    text-align: left;
  }
}

.p-price-flow__article-text {
  letter-spacing: 0.12em;
  line-height: 2;
}

.p-price-flow__link {
  margin: 4rem auto 0;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-price-flow__link {
    margin: 2.4rem 0 0 auto;
  }
}

.p-price-flow__large-en {
  color: #fff;
  font-size: 7.2rem;
  font-weight: bold;
  position: absolute;
  right: -7.3rem;
  top: 19rem;
  transform: rotate(-90deg);
  z-index: -1;
}

/* Teamページ */
.p-team-main {
  padding: 17.2rem 0 16.05rem 0;
}

@media screen and (max-width: 700px) {
  .p-team-main {
    padding: 8.3rem 0 14.4rem 0;
  }
}

@media screen and (max-width: 700px) {
  .p-team-main__inner {
    padding: 0;
  }
}

.p-team-main__member {
  align-items: center;
  display: flex;
  gap: 11.2rem;
  margin-bottom: 4.6rem;
  width: 100%;
}

@media screen and (max-width: 700px) {
  .p-team-main__member {
    flex-direction: column;
    gap: 4rem;
  }
}

.p-team-main__member-image {
  background-color: #333;
  height: 47.9rem;
  max-width: 100%;
  position: relative;
  width: 36rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member-image {
    height: 41.396rem;
    width: 31rem;
  }
}

.p-team-main__member-label {
  border: 2px #fff solid;
  bottom: 2.4rem;
  color: #fff;
  display: block;
  font-size: 1.3rem;
  font-weight: bold;
  padding: 0.4rem 1.4rem 0.3rem;
  position: absolute;
  width: -moz-fit-content;
  width: fit-content;
}

.p-team-main__member-detail {
  max-width: 100%;
  width: 42rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member-detail {
    padding: 0 2.4rem;
  }
}

.p-team-main__member-en {
  font-size: 3.6rem;
  font-weight: bold;
  line-height: 1.3333333333;
  margin-bottom: 1rem;
  text-transform: uppercase;
}

@media screen and (max-width: 700px) {
  .p-team-main__member-en {
    font-size: 2.8rem;
    line-height: 1.2;
    margin-bottom: 0.8rem;
    text-transform: capitalize;
  }
}

.p-team-main__member-jp {
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.12em;
  margin-bottom: 5.6rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member-jp {
    font-size: 1.3rem;
    margin-bottom: 3.2rem;
  }
}

.p-team-main__member-text {
  letter-spacing: 0.12em;
  line-height: 2;
  max-width: 100%;
  width: 37rem;
}

.p-team-main__member:nth-of-type(2n + 1) .p-team-main__member-text {
  margin-left: auto;
}

.p-team-main__member:nth-of-type(2n + 1) .p-team-main__member-label {
  left: 2.4rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member:nth-of-type(2n + 1) .p-team-main__member-image {
    margin-right: auto;
  }
}

.p-team-main__member:nth-of-type(2n + 1) .p-team-main__member-image::after {
  background: url(../img/team/team-photo-button.svg) center no-repeat;
  background-size: cover;
  bottom: -3rem;
  content: "";
  height: 9.1rem;
  position: absolute;
  right: -3rem;
  width: 9.1rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member:nth-of-type(2n + 1) .p-team-main__member-image::after {
    bottom: -1rem;
  }
}

.p-team-main__member:nth-of-type(2n) {
  flex-direction: row-reverse;
  gap: 1.2rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member:nth-of-type(2n) {
    flex-direction: column;
    gap: 4rem;
  }
}

.p-team-main__member:nth-of-type(2n) .p-team-main__member-text {
  left: -7rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-team-main__member:nth-of-type(2n) .p-team-main__member-text {
    position: static;
  }
}

.p-team-main__member:nth-of-type(2n) .p-team-main__member-label {
  right: 2.4rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member:nth-of-type(2n) .p-team-main__member-image {
    margin-left: auto;
  }
}

.p-team-main__member:nth-of-type(2n) .p-team-main__member-image::after {
  background: url(../img/team/team-photo-button.svg) center no-repeat;
  background-size: cover;
  bottom: -3rem;
  content: "";
  height: 9.1rem;
  left: -3rem;
  position: absolute;
  width: 9.1rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member:nth-of-type(2n) .p-team-main__member-image::after {
    bottom: -1rem;
  }
}

.p-team-main__member:nth-of-type(3) {
  padding-left: 10.7rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member:nth-of-type(3) {
    padding-left: 0;
  }
}

.p-team-main__member:nth-of-type(4) {
  padding-right: 10.7rem;
}

@media screen and (max-width: 700px) {
  .p-team-main__member:nth-of-type(4) {
    padding-right: 0;
  }
}
/* ↑ Teamページ */

/* memberページ */
.member-page-key_wrap {
  display: flex;
  align-items: flex-end;
  gap: 6rem;
  width: 80%;
  max-width: var(--inner-medium);
  margin: 18.5rem auto 0;

  @media screen and (max-width: 700px) {
    display: block;
    width: 100%;
    margin: 0;
  }
}

.member-page-key {
  position: relative;
  width: 65%;
  @media screen and (max-width: 700px) {
    width: 100%;
  }
}

.member-page-key__image {
  width: 100%;
  display: block;

  @media screen and (max-width: 700px) {
    width: 100%;
  }
}

.member-page-key__unit {
  position: absolute;
  top: 10%;
  left: 113%;
  color: #000;

  @media screen and (max-width: 700px) {
    top: auto;
    left: auto;
    bottom: 4rem;
    font-size: 4rem;
    padding: 0 2.4rem;
    color: #fff;
  }
}

.member-page-key_name {
  font-weight: bold;
  letter-spacing: 0.02em;
  font-size: 5.6rem;

  @media screen and (max-width: 1100px) {
    font-size: 4.8rem;
  }
  @media screen and (max-width: 700px) {
    font-size: 4rem;
  }
}

.member-page-key__name__jp {
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.11em;
  line-height: 1.3;
  @media screen and (max-width: 700px) {
    font-size: 1.7rem;
  }
}

/* 黒背景部分 */
.member-page-key__container {
  width: 87%;
  padding: 4rem;
  margin-top: 25.5rem;
  background: #1a1311;
  color: #fff;
  @media screen and (max-width: 700px) {
    width: 100%;
    padding: 4rem 2.4rem;
    margin: 0;
  }
}

.member-page-key__area {
  font-size: 1.6rem;
  font-weight: bold;
  @media screen and (max-width: 700px) {
  }
}

.member-page-key__box {
  display: flex;
  gap: 0.6rem;
  margin-top: 1rem;
  @media screen and (max-width: 700px) {
  }
}

.member-page-key__location {
  padding: 0.5rem 1.2rem;
  border: solid 1px;
  border-radius: 120px;
  @media screen and (max-width: 700px) {
  }
}

.member-page-key__image__sub {
  @media screen and (max-width: 700px) {
    margin-top: 2rem;
    width: 100%;
  }
}

.member-page-key__message {
  margin-top: 2.7rem;
  font-size: 3.4rem;
  font-weight: bold;
  @media screen and (max-width: 700px) {
  }
}

.member-page-key__text {
  padding: 2rem;
  margin-top: 1.7rem;
  line-height: 1.7;
  letter-spacing: 0.03em;
  border: solid 1px;
  @media screen and (max-width: 700px) {
    margin-top: 1rem;
    letter-spacing: 0.2em;
  }
}

/* プロフィール */
.member-main_profile {
  margin: 6.4rem 0 16.05rem 0;
}

.member-main_profile_inner {
  width: 56%;
  max-width: 80rem;
  margin: 0 auto 7.2rem;
  @media screen and (max-width: 700px) {
    width: 87%;
  }
}

.member-main_title {
  display: flex;
  align-items: center;
  padding-top: 2.8rem;
  font-size: 1.8rem;
  font-weight: bold;
}
.member-main_title::before {
  display: block;
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  margin-right: 0.6rem;
  border: solid 1px #000;
  border-radius: 50%;
}

.member-main_title:first-child {
  padding-top: 0;
}

.member-main_text {
  margin-top: 1.6rem;
  margin-bottom: 2.4rem;
  line-height: 1.43;
  letter-spacing: 0.2em;
}

.member-main_text::after {
  position: relative;
  bottom: -2.4rem;
  display: block;
  background-color: #000;
  content: "";
  height: 1px;
  width: 100%;
}

.member-main_button {
  margin: 7rem 0% 0 auto;
}
/* ↑ memberページ */

.p-faq {
  padding-bottom: 14rem;
  padding-top: 14.3rem;
}

.p-faq__title-cover {
  margin-bottom: 4rem;
}

.p-faq__text {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  margin-bottom: 7.1rem;
}

@media screen and (max-width: 700px) {
  .p-faq__text {
    margin-bottom: 5.6rem;
  }
}

.p-faq__contents {
  margin: auto;
  max-width: 100%;
  width: 80rem;
}

.p-faq__accordion {
  border-bottom: 1px var(--main-color) solid;
  padding: 3.2rem 0;
}

@media screen and (max-width: 700px) {
  .p-faq__accordion {
    padding: 2.8rem 0;
  }
}

.p-faq__q {
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1.5;
  padding-left: 2.4em;
  padding-right: 2rem;
  position: relative;
  text-indent: -2.4em;
  width: 100%;
}

@media screen and (max-width: 700px) {
  .p-faq__q {
    font-size: 1.3rem;
    letter-spacing: 0.03em;
    line-height: 1.8461538462;
    text-indent: -2.65em;
  }
}

.p-faq__q::after {
  background: url(../img/faq/acd-arrow.svg) no-repeat center;
  background-size: 95%;
  content: "";
  height: 0.611rem;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.2s ease;
  width: 1.069rem;
}

.p-faq__q span {
  margin-right: 1.6rem;
}

@media screen and (max-width: 700px) {
  .p-faq__q span {
    left: 0.5rem;
    position: relative;
  }
}

.p-faq__q.--active::after {
  content: "";
  transform: translateY(-50%) rotate(180deg);
}

.p-faq__a {
  height: 0;
  letter-spacing: 0.04em;
  line-height: 2.1538461538;
  opacity: 0;
  overflow-y: hidden;
  padding-left: 3.5rem;
  padding-right: 2rem;
  padding-top: 0;
  pointer-events: none;
  transition: all 0.4s ease;
}

@media screen and (max-width: 700px) {
  .p-faq__a {
    line-height: 1.8461538462;
    padding-left: 3rem;
  }
}

.p-faq__a.--active {
  height: -moz-fit-content;
  height: fit-content;
  opacity: 1;
  padding-top: 1rem;
  pointer-events: auto;
}

.p-error {
  padding: 40vh 0;
  text-align: center;
  width: 100%;
}

.p-error__text {
  font-size: var(--md);
}

.p-program-training {
  padding-top: 14.7rem;
}

@media screen and (max-width: 700px) {
  .p-program-training {
    padding-top: 12.9rem;
  }
}

.p-program-training__title-cover {
  margin-bottom: 5.6rem;
}

@media screen and (max-width: 700px) {
  .p-program-training__title-cover {
    margin-bottom: 4.8rem;
  }
}

.p-program-training__text {
  letter-spacing: 0.06em;
  line-height: 2;
  margin-bottom: 7.3rem;
}

@media screen and (max-width: 700px) {
  .p-program-training__text {
    margin-bottom: 5.6rem;
  }
}

.p-program-training__flex {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .p-program-training__flex {
    display: block;
  }
}

.p-program-training__image {
  height: 48.4rem;
  max-width: 100%;
  position: relative;
  width: 52.3rem;
}

@media screen and (max-width: 700px) {
  .p-program-training__image {
    height: auto;
    margin: 0 auto 11rem;
    width: 32.3rem;
  }
}

.p-program-training__image svg {
  -o-object-fit: cover;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.p-program-training__ul {
  display: flex;
  flex-direction: column;
  gap: 3.65rem;
  max-width: 100%;
  position: relative;
  width: 48.9rem;
}

.p-program-training__list {
  padding-left: 5.5rem;
  position: relative;
}

.p-program-training__list::before {
  background-color: var(--main-color);
  border-radius: 100vmax;
  content: "";
  height: 1.2rem;
  left: 0;
  position: absolute;
  top: 0.3rem;
  width: 1.2rem;
}

.p-program-training__list-en {
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  margin-bottom: 2rem;
  position: relative;
}

.p-program-training__list-en::after {
  background-color: var(--main-color);
  border-radius: 100vmax;
  content: "";
  height: 3.4rem;
  left: -6.6rem;
  opacity: 0.1;
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  width: 3.4rem;
}

.p-program-training__list-text {
  letter-spacing: 0.06em;
  line-height: 2;
}

.p-program-training__list-line {
  background-color: #000;
  height: 0%;
  left: 0.55rem;
  position: absolute;
  top: 0.87rem;
  width: 1px;
  z-index: -1;
}

.p-program-before-after {
  padding-bottom: 14.45rem;
  padding-top: 16.03rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-program-before-after {
    padding-bottom: 13.4rem;
    padding-top: 21.28rem;
  }
}

@media screen and (min-width: 701px) {
.p-index-before-after__slider__in a {
  transition: opacity 0.4s;
}
.p-index-before-after__slider__in a:hover {
  opacity: 0.8;
}
}

.p-program-before-after__title-cover {
  margin-bottom: 7.2rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__title-cover {
    margin-bottom: 4.8rem;
  }
}

.p-program-before-after__flex {
  display: flex;
  justify-content: space-between;
  margin-bottom: 12rem;
  margin-top: -10rem;
  padding-top: 10rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__flex {
    flex-direction: column;
    gap: 2.9rem;
  margin-bottom: 8rem;
  margin-left: auto;
  margin-right: auto;
  }
}

.p-program-before-after__flex:last-of-type {
  margin-bottom: 0;
}

.p-program-before-after__left {
  max-width: 100%;
  width: 44.2rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__left {
    margin: auto;
  }
}

.p-program-before-after__right {
  max-width: 100%;
  position: relative;
  top: 4rem;
  width: 46rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__right {
    margin: auto;
    position: static;
  }
}

.p-program-before-after__sub {
  margin-bottom: 2.17rem;
  position: relative;
  width: 16rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__sub {
    margin-bottom: 1.6rem;
    width: 13rem;
  }
}

.p-program-before-after__sub img {
  width: 100%;
}

.p-program-before-after__user {
  align-items: flex-start;
  display: flex;
  gap: 2.6rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__user {
    gap: 2rem;
  }
}

.p-program-before-after__user img {
  width: 23.3rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__user img {
    width: 17.6rem;
  }
}

.p-program-before-after__user-box {
  max-width: 100%;
  width: 17rem;
}

.p-program-before-after__user-box h4 {
  border-bottom: 1px var(--main-color) solid;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  margin-bottom: 1.7rem;
  padding-bottom: 1.1rem;
  padding-left: 1.4rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__user-box h4 {
    font-size: 1.3rem;
    margin-bottom: 1.2rem;
    padding-bottom: 0.8rem;
  }
}

.p-program-before-after__user-box h4::after {
  border: 1px var(--main-color) solid;
  border-radius: 100vmax;
  content: "";
  height: 0.8rem;
  left: 0;
  position: absolute;
  top: 34%;
  transform: translateY(-50%);
  width: 0.8rem;
}

.p-program-before-after__user-box p {
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  line-height: 1.625;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__user-box p {
    font-size: 1.3rem;
    line-height: 1.5384615385;
  }
}

.p-program-before-after__user-box p:first-of-type {
  margin-bottom: 2rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__user-box p:first-of-type {
    margin-bottom: 1rem;
  }
}

.p-program-before-after__user-box p.--small {
  font-size: 1rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__user-box p.--small {
    line-height: 1.6;
  }
}

.p-program-before-after__graph {
  width: 100%;
  margin-top: 3.1rem;
}
@media screen and (max-width: 700px) {
.p-program-before-after__graph {
  margin-top: 2.5rem;
}
}

.p-program-before-after__ba_item_ttl {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 1.7rem;
}

.p-program-before-after__ba_item_desc {
  font-size: 1.3rem;
  letter-spacing: 0.06em;
  line-height: calc(24/13);
  margin-bottom: 2rem;
}

.p-program-before-after__ba_item_comment {
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  line-height: calc(20/12);
  padding: 2.5rem 2rem 2rem;
  position: relative;
  border: 1px solid #1A1311;
  margin-top: 3.5rem;
}

.p-program-before-after__ba_item_comment:after {
  content: "”";
  font-size: 6.4rem;
  letter-spacing: 0.02em;
  line-height: 1;
  position: absolute;
  right: 0.5rem;
  top: -1.8rem;
}

.p-program-before-after__ba_item_comment span {
  font-size: 1.2rem;
  color: #fff;
  letter-spacing: 0.1em;
  background: #1A1311;
  display: inline-block;
  padding: 0 0.4rem 0 0.8rem;
  position: absolute;
  left: 2rem;
  top: 0;
  transform: translateY(-50%);
}

.p-program-before-after__details {
  align-items: center;
  display: flex;
  gap: 8rem;
  padding: 2.2rem 0;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__details {
    gap: 4.5rem;
    padding: 1.6rem 0;
  }
}

.p-program-before-after__details::after {
  background: url(../img/program/program-line.svg) no-repeat left;
  background-size: 100%;
  bottom: 0;
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  width: 100%;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__details::after {
    background-size: 150%;
  }
}

.p-program-before-after__details-main {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  min-width: 8.5rem;
  padding-left: 1.4rem;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__details-main {
    font-size: 1.3rem;
    min-width: 8rem;
  }
}

.p-program-before-after__details-main::after {
  border: 1px var(--main-color) solid;
  border-radius: 100vmax;
  content: "";
  height: 0.8rem;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 0.8rem;
}

.p-program-before-after__details-main::before {
  background-image: linear-gradient(
    to right,
    var(--main-color),
    var(--main-color) 3px,
    transparent 3px,
    transparent 8px
  );
  background-repeat: repeat-x;
  background-size: 8px 1px;
  content: "";
  height: 1px;
  position: absolute;
  right: -6rem;
  top: 50%;
  transform: translateY(-50%);
  width: 4.2rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__details-main::before {
    right: -4rem;
    width: 3rem;
  }
}

.p-program-before-after__details-number {
  width: 20.6rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__details-number {
    width: 14.4rem;
  }
}

.p-program-before-after__details-number--small {
  width: 18.5rem;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__details-number--small {
    width: 14.4rem;
  }
}

.p-program-before-after__details-number img {
  -o-object-fit: contain;
  object-fit: contain;
}

.p-program-before-after__details-down {
  border: 1px var(--main-color) solid;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  padding: 0.5rem 0.9rem 0.3rem;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  .p-program-before-after__details-down {
    font-size: 1rem;
    padding: 0.5rem 0.3rem 0.3rem;
  }
}

.p-program-before-after__large-en {
  color: #fff;
  font-size: 7.2rem;
  font-weight: bold;
  line-height: 1.0833333333;
  position: absolute;
  right: -10.5rem;
  top: 15rem;
  z-index: -1;
}

.p-topic-media {
  padding-top: 12rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-topic-media {
    padding-top: 14rem;
  }
}

@media screen and (max-width: 700px) {
  .p-topic-media__inner {
    padding: 0 0 0 2.4rem;
  }
}

.p-topic-media__title-cover {
  margin-bottom: 4.6rem;
}

@media screen and (max-width: 700px) {
  .p-topic-media__title-cover {
    margin-bottom: 4.8rem;
  }
}

.p-topic-media__slider .swiper-wrapper {
  justify-content: space-between;
}

.p-topic-media__slider .swiper-slide {
  max-width: 100%;
  width: 37.2rem !important;
}

@media screen and (max-width: 700px) {
  .p-topic-media__slider .swiper-slide {
    width: 24.1rem !important;
  }
}

.p-topic-media__slider-image {
  background-color: #333;
  height: 47rem;
  margin-bottom: 2.8rem;
  max-width: 100%;
  position: relative;
  width: 37.2rem;
}

@media screen and (max-width: 700px) {
  .p-topic-media__slider-image {
    height: 30.5rem;
    width: 24.1rem;
  }
}

.p-topic-media__slider-time {
  display: block;
  font-size: 1.4rem;
  font-weight: bold;
  margin-bottom: 1.2rem;
  padding-left: 1.4rem;
}

@media screen and (max-width: 700px) {
  .p-topic-media__slider-time {
    font-size: 1.2rem;
    letter-spacing: 0.02em;
  }
}

.p-topic-media__slider-title {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 1.25;
  padding: 0 1.4rem;
  word-break: break-all;
}

@media screen and (max-width: 700px) {
  .p-topic-media__slider-title {
    font-size: 1.3rem;
    line-height: 1.5384615385;
  }
}

.p-topic-media__slider .swiper-button-next {
  height: 5.3rem;
  left: auto;
  right: 2.4rem;
  top: 106%;
  width: 5.3rem;
}

.p-topic-media__slider .swiper-button-next::after {
  background: url(../img/topic/topic-slider-arrow-next.png) center no-repeat;
  background-size: 110%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}

.p-topic-media__slider .swiper-button-prev {
  height: 5.3rem;
  left: auto;
  right: 8rem;
  top: 106%;
  width: 5.3rem;
}

.p-topic-media__slider .swiper-button-prev::after {
  background: url(../img/topic/topic-slider-arrow-prev.png) center no-repeat;
  background-size: 110%;
  content: "";
  display: block;
  height: 100%;
  width: 100%;
}

.p-topic-media__large-en {
  color: #fff;
  font-size: 18rem;
  font-weight: bold;
  position: absolute;
  right: -3.5rem;
  top: -0.6rem;
  z-index: -1;
}

@media screen and (max-width: 700px) {
  .p-topic-media__large-en {
    font-size: 7.2rem;
    right: -3rem;
    top: 15rem;
  }
}

.p-topic-news {
  padding-bottom: 12.09rem;
  padding-top: 12.9rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-topic-news {
    padding-bottom: 16.39rem;
    padding-top: 9.6rem;
  }
}

.p-topic-news__title-cover {
  margin-bottom: 9.6rem;
}

@media screen and (max-width: 700px) {
  .p-topic-news__title-cover {
    margin-bottom: 6.4rem;
  }
}

.p-topic-news__flex {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 6.4rem 7.9rem;
}

@media screen and (max-width: 700px) {
  .p-topic-news__flex {
    gap: 4rem;
  }
}

.p-topic-news__contents {
  border-bottom: 1px var(--main-color) solid;
  max-width: 100%;
  padding-bottom: 4rem;
  width: 32.7rem;
}

@media screen and (max-width: 700px) {
  .p-topic-news__contents {
    width: 100%;
  }
}

.p-topic-news__contents-title {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 1.625;
  margin-bottom: 3.2rem;
  word-break: break-all;
}

.p-topic-news__detail {
  align-items: center;
  display: flex;
  gap: 4rem;
  justify-content: flex-end;
}

.p-topic-news__detail-time {
  display: block;
  font-size: 1.2rem;
  letter-spacing: 0.02em;
}

.p-topic-news__detail-category {
  display: block;
  font-size: 1.2rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}

.p-topic-news__detail-category::after {
  background-color: var(--main-color);
  content: "";
  height: 1.3rem;
  left: -2rem;
  position: absolute;
  top: 0;
  width: 2px;
}

.p-topic-news__large-en {
  color: #fff;
  font-size: 7.2rem;
  font-weight: bold;
  position: absolute;
  right: -1rem;
  top: 13rem;
  z-index: -1;
}

.p-topic-pagination {
  align-items: center;
  display: flex;
  gap: 2.4rem;
  justify-content: center;
  margin: 4rem auto 0;
  width: -moz-fit-content;
  width: fit-content;
}

.p-topic-pagination .next,
.p-topic-pagination .prev {
  display: none;
}

.p-topic-pagination .page-numbers.current {
  align-items: center;
  /* background: url(../img/topic/pagination-button-bg.png) center no-repeat; */
  /* background-size: cover; */
  background: #000;
  color: #fff;
  border-radius: 50%;
  display: flex;
  height: 6rem;
  justify-content: center;
  width: 6rem;
  /* padding-bottom: 0.4rem; */
}

@media screen and (max-width: 700px) {
  .p-topic-pagination .page-numbers.current {
    height: 4rem;
    width: 4rem;
  }
}

.p-single {
  padding: 18.1rem 0 29.17rem;
}

@media screen and (max-width: 700px) {
  .p-single {
    padding: 14rem 0 8.9rem 0;
  }
}

.p-single__contents {
  margin: auto;
  max-width: 100%;
  width: 64rem;
}

.p-single__head {
  border-bottom: 2px var(--main-color) solid;
  margin-bottom: 4.8rem;
  padding-bottom: 4rem;
}

@media screen and (max-width: 700px) {
  .p-single__head {
    margin-bottom: 4rem;
  }
}

.p-single__title {
  font-size: 2.4rem;
  letter-spacing: 0.1em;
  line-height: 1.6666666667;
  margin-bottom: 4.8rem;
  word-break: break-all;
}

@media screen and (max-width: 700px) {
  .p-single__title {
    font-size: 2rem;
    margin-bottom: 3.6rem;
  }
}

.p-single__detail {
  align-items: center;
  display: flex;
  gap: 4rem;
  justify-content: flex-end;
}

.p-single__detail-time {
  display: block;
  font-size: 1.2rem;
  letter-spacing: 0.02em;
}

.p-single__detail-category {
  display: block;
  font-size: 1.2rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}

.p-single__detail-category::after {
  background-color: var(--main-color);
  content: "";
  height: 1.3rem;
  left: -2rem;
  position: absolute;
  top: 0;
  width: 2px;
}

.p-single-body {
  word-break: break-all;
}

.p-single-body p {
  font-size: 1.3rem;
  letter-spacing: 0.04em;
  line-height: 2.1538461538;
  margin-bottom: 2.4rem;
  word-break: break-all;
}

.p-single-body img {
  margin-bottom: 2.4rem;
  width: 100%;
}

.p-single-body ul {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2.4rem;
}

@media screen and (max-width: 700px) {
  .p-single-body ul {
    gap: 1.6rem;
  }
}

.p-single-body ul li {
  font-size: 1.3rem;
  letter-spacing: 0.04em;
  line-height: 1.8461538462;
  padding-left: 2rem;
  position: relative;
  word-break: break-all;
}

.p-single-body ul li::after {
  border: 1px var(--main-color) solid;
  border-radius: 100vmax;
  content: "";
  height: 0.8rem;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 0.8rem;
}

.p-single-body ol {
  display: flex;
  flex-direction: column;
  gap: 3.2rem;
}

@media screen and (max-width: 700px) {
  .p-single-body ol {
    gap: 1.6rem;
  }
}

.p-single-body ol li {
  counter-increment: number;
  font-size: 1.3rem;
  letter-spacing: 0.04em;
  line-height: 1.8461538462;
  padding-left: 4.6rem;
  position: relative;
  word-break: break-all;
}

.p-single-body ol li::before {
  align-items: center;
  border: 1px var(--main-color) solid;
  border-radius: 100vmax;
  content: "0" counter(number);
  display: flex;
  font-family: "font", sans-serif;
  font-size: 1rem;
  font-weight: bold;
  height: 3.4rem;
  justify-content: center;
  left: 0;
  letter-spacing: 0.02em;
  padding-top: 0.3rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 3.4rem;
}

.p-single-body h2 {
  border-left: 2px var(--main-color) solid;
  font-size: 2rem;
  letter-spacing: 0.1em;
  line-height: 1.4;
  margin-bottom: 1.6rem;
  padding-left: 2rem;
  word-break: break-all;
}

@media screen and (max-width: 700px) {
  .p-single-body h2 {
    border-left: 1px var(--main-color) solid;
    font-size: 1.6rem;
    line-height: 1.75;
  }
}

.p-single-body a {
  line-height: 1.5;
}

.--privacy .common-page-key__title br {
  display: none;
}

@media screen and (max-width: 700px) {
  .--privacy .common-page-key__title br {
    display: block;
  }
}

.p-privacy {
  margin: 8.8rem auto;
}

.p-privacy__title-cover {
  margin-bottom: 4rem;
}

.p-privacy__contents p {
  font-size: 1.3rem;
  letter-spacing: 0.04em;
  line-height: 1.9;
  margin-bottom: 1.5em;
}

.p-privacy__contents h2 {
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  margin-bottom: 2.8rem;
}

@media screen and (max-width: 700px) {
  .p-privacy__contents h2 {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 700px) {
  .--constitution .common-page-key__title {
    font-size: 4.8rem;
  }
}

.p-constitution {
  margin: 8.8rem auto;
}

.p-constitution__title-cover {
  margin-bottom: 4rem;
}

.p-constitution__contents p {
  font-size: 1.3rem;
  letter-spacing: 0.04em;
  line-height: 1.9;
  margin-bottom: 1.5em;
}

.p-constitution__contents h2 {
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  margin-bottom: 2.8rem;
}

@media screen and (max-width: 700px) {
  .p-constitution__contents h2 {
    font-size: 1.6rem;
  }
}

.p-recruit-recruitment {
  margin-bottom: 12rem;
  padding-top: 14rem;
}

.p-recruit-recruitment__title-cover {
  margin-bottom: 5.6rem;
}

.p-recruit-recruitment__wrap {
  display: flex;
  flex-direction: column;
}

.p-recruit-recruitment__cover {
  border-top: 1px #000 solid;
  margin: auto;
  max-width: 100%;
  width: 80rem;
}

.p-recruit-recruitment__cover:last-of-type {
  border-bottom: 1px #000 solid;
}

@media screen and (max-width: 700px) {
  .p-recruit-recruitment__cover {
    width: 100%;
  }
}

.p-recruit-recruitment__acd-main {
  cursor: pointer;
  padding: 3.2rem 0;
  position: relative;
}

.p-recruit-recruitment__acd-main::after {
  background: url(../img/recruit/arrow.svg) center no-repeat;
  background-size: cover;
  content: "";
  height: 0.611rem;
  position: absolute;
  right: 1.6rem;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.2s ease;
  width: 1.069rem;
}

.p-recruit-recruitment__acd-main.--active::after {
  content: "";
  transform: translateY(-50%) rotate(180deg);
}

.p-recruit-recruitment__acd-main.--pd-bottom {
  padding: 3.2rem 0;
}

.p-recruit-recruitment__acd-sub-title {
  font-size: 1.3rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin-bottom: 1.5rem;
}

.p-recruit-recruitment__acd-sub-title span {
  display: inline-block;
  letter-spacing: 0.02em;
  margin-right: 1.6rem;
}

.p-recruit-recruitment__acd-title {
  font-size: 3.2rem;
  font-weight: bold;
}

@media screen and (max-width: 700px) {
  .p-recruit-recruitment__acd-title {
    font-size: 2.4rem;
  }
}

.p-recruit-recruitment__acd-sub {
  height: 0;
  overflow: hidden;
  transition: all 0.4s ease;
}

.p-recruit-recruitment__acd-sub.--active {
  height: auto;
  padding: 0 0 4rem;
}

.p-recruit-recruitment__acd-sub h3 {
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.03em;
  margin-bottom: 4rem;
}

.p-recruit-recruitment__acd-sub h4 {
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.06em;
  margin-bottom: 1.6rem;
}

@media screen and (max-width: 700px) {
  .p-recruit-recruitment__acd-sub h4 {
    font-size: 1.3rem;
    margin-bottom: 1.6rem;
  }
}

.p-recruit-recruitment__acd-ul01 {
  margin-bottom: 4.5rem;
}

@media screen and (max-width: 700px) {
  .p-recruit-recruitment__acd-ul01 {
    display: flex;
    flex-direction: column;
    gap: 2.4rem;
  }
}

.p-recruit-recruitment__acd-ul01 li {
  font-size: 1.3rem;
  letter-spacing: 0.06em;
  line-height: 2.4615384615;
  padding-left: 1.7rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-recruit-recruitment__acd-ul01 li {
    line-height: 1.8461538462;
  }
}

.p-recruit-recruitment__acd-ul01 li::after {
  background-color: #fff;
  border: 1px #000 solid;
  border-radius: 100vmax;
  content: "";
  height: 0.9rem;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 0.9rem;
}

@media screen and (max-width: 700px) {
  .p-recruit-recruitment__acd-ul01 li:nth-of-type(2)::after,
  .p-recruit-recruitment__acd-ul01 li:nth-of-type(3)::after,
  .p-recruit-recruitment__acd-ul01 li:nth-of-type(4)::after {
    top: 0.7rem;
    transform: translateY(0%);
  }
}

.p-recruit-recruitment__acd-ul02 {
  display: flex;
  flex-direction: column;
  gap: 4.3rem;
}

.p-recruit-recruitment__acd-ul02 ._cover {
  max-width: 100%;
  width: 68.9rem;
}

.p-recruit-recruitment__acd-ul02 li {
  counter-increment: num 1;
  padding-left: 9.4rem;
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-recruit-recruitment__acd-ul02 li {
    padding-left: 6rem;
  }
}

.p-recruit-recruitment__acd-ul02 li::after {
  align-items: center;
  background: url(../img/recruit/round-bg.webp) center no-repeat;
  background-size: cover;
  border-radius: 100vmax;
  content: "0" counter(num);
  display: flex;
  font-family: "font", sans-serif;
  font-size: 2rem;
  font-weight: bold;
  height: 7.45rem;
  justify-content: center;
  left: 0;
  letter-spacing: 0.02em;
  padding-top: 0.6rem;
  position: absolute;
  top: 0;
  width: 7.45rem;
}

@media screen and (max-width: 700px) {
  .p-recruit-recruitment__acd-ul02 li::after {
    font-size: 1.3rem;
    height: 4.429rem;
    padding-top: 0.4rem;
    width: 4.429rem;
  }
}

.p-recruit-recruitment__acd-ul02 p {
  letter-spacing: 0.06em;
  line-height: 1.8461538462;
}

.p-recruit-entry {
  margin-bottom: 15.4rem;
}

.p-recruit-entry__title-cover {
  margin-bottom: 4rem;
}

@media screen and (max-width: 700px) {
  .p-recruit-entry__title-cover {
    margin-bottom: 3.2rem;
  }
}

.p-recruit-entry__flex {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 700px) {
  .p-recruit-entry__flex {
    display: flex;
    flex-direction: column;
    gap: 4.8rem;
  }
}

.p-recruit-entry__flex p {
  font-size: 1.3rem;
  letter-spacing: 0.06em;
  line-height: 1.8461538462;
  max-width: 100%;
  width: 64.2rem;
}

.p-recruit-entry__flex a {
  align-items: center;
  background-color: #1a1311;
  color: #fff;
  display: flex;
  font-size: 1.8rem;
  font-weight: bold;
  height: 7.2rem;
  justify-content: center;
  position: relative;
  width: 32.7rem;
}

@media screen and (max-width: 700px) {
  .p-recruit-entry__flex a {
    width: 100%;
  }
}

.p-recruit-entry__flex a::after {
  background: url(../img/recruit/entry-arrow.svg) center no-repeat;
  background-size: cover;
  content: "";
  height: 0.8rem;
  position: absolute;
  right: 1.68rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.2rem;
}

/* お問い合わせ */
.p-contact {
  padding-bottom: 14rem;
  padding-top: 14.3rem;
}
@media screen and (max-width: 700px) {
  .p-contact {
    padding-bottom: 7rem;
    padding-top: 7rem;
  }
}
.p-contact__inner {
  max-width: 53.8rem;
  margin: 0 auto;
}
.p-contact__title-cover {
  margin-bottom: 4rem;
}
@media screen and (max-width: 700px) {
  .p-contact__title-cover {
    margin-bottom: 2.4rem;
  }
}

.p-contact__text {
  font-size: 1.4rem;
  letter-spacing: 0.06em;
  line-height: calc(26 / 14);
  margin-bottom: 3.5rem;
}

@media screen and (max-width: 700px) {
  .p-contact__text {
    margin-bottom: 3.5rem;
  }
}

.p-contact__contents {
  margin: auto;
  width: 100%;
}
.p-contact__list {
  margin-bottom: 2.4rem;
}
.p-contact__list .box {
  margin-bottom: 1.6rem;
}
.p-contact__list .box:last-child {
  margin-bottom: 0;
}
.p-contact__list .box .ttl {
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  margin-bottom: 0.6rem;
}
.p-contact__list .box .ttl span {
  display: inline-block;
  margin-left: 0.5rem;
  transform: translateY(-0.2rem);
}
.p-contact__list .box .input input[type="text"],
.p-contact__list .box .input input[type="email"],
.p-contact__list .box .input select,
.p-contact__list .box .input textarea {
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  border-radius: 0.4rem;
  width: 100%;
  border: 1px solid #1a1311;
  appearance: none;
  padding: 1.5rem;
  height: 4.5rem;
}
.p-contact__list .box .input select {
  font-size: 1.3rem;
  color: #1a1311;
}
.p-contact__list .box .input textarea {
  height: initial;
}
.p-contact__list .box .input .select {
  position: relative;
}
.p-contact__list .box .input .select:after {
  content: "";
  border: solid #1a1311;
  border-width: 0 1px 1px 0;
  padding: 0.3rem;
  position: absolute;
  right: 1.7rem;
  top: 1.7rem;
  transform: rotate(45deg);
}
.p-contact__privacy {
  margin-bottom: 3.1rem;
  text-align: center;
}
.p-contact__privacy input {
  accent-color: #1a1311;
  vertical-align: text-bottom;
}
.p-contact__privacy .checkbox-input {
  display: none;
}
.p-contact__privacy .check {
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  position: relative;
  padding-left: 2.6rem;
  cursor: pointer;
}
.p-contact__privacy .check:before {
  content: "";
  border: 1px solid #1a1311;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 0.4rem;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.checkbox-input:checked + .check:after {
  content: "";
  background: #1a1311;
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  position: absolute;
  left: 0.4rem;
  top: 50%;
  transform: translateY(-50%);
}
.p-contact__privacy .check a {
  text-decoration: underline;
  text-underline-offset: 0.8rem;
}
.p-contact__btn {
  font-size: 1.3rem;
  color: #fff;
  font-weight: bold;
  letter-spacing: 0.1em;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 32.7rem;
  height: 5.3rem;
  margin: 0 auto;
  background: #1a1311;
  border-radius: 0.4rem;
}

.p-contact.success {
  text-align: center;
}
.success .p-contact__title-cover {
  margin-bottom: 6rem;
}
@media screen and (max-width: 700px) {
  .success .p-contact__title-cover {
    margin-bottom: 4.7rem;
  }
}
.p-success__ttl {
  font-size: 2.8rem;
  letter-spacing: 0.1em;
  margin-bottom: 2.5rem;
}
.term__list_item {
  display: flex;
  margin-bottom: 6px;
}
.term__list_item p {
  margin-bottom: 0;
}
.term__wrap h2 {
  font-size: 18px;
  margin-bottom: 20px;
  border-bottom: 1px solid;
  padding-bottom: 10px;
  font-weight: bold;
  letter-spacing: 1px;
}
.term__wrap {
  margin-bottom: 32px;
}
@media screen and (max-width: 700px) {
  .p-success__ttl {
    font-size: 2rem;
  }
}
.p-success__text {
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  line-height: calc(24 / 13);
  margin-bottom: 4rem;
}
.p-success__btn {
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-success__btn span {
  font-size: 1.4rem;
  font-weight: bold;
  margin-right: 3rem;
}
.p-success__btn .c-page-links__arrow {
  opacity: 1;
  position: relative;
  right: auto;
  bottom: auto;
  transform: translate(0);
}

.p-index-price {
  /* padding-bottom: 20.2rem; */
  position: relative;
}

@media screen and (max-width: 700px) {
  .p-index-price {
    padding-bottom: 7rem;
  }
}

.p-index-price__title-cover {
  margin-bottom: 8rem;
}
@media screen and (max-width: 700px) {
  .p-index-price__title-cover {
    margin-bottom: 5rem;
  }
}

.p-index-price__top {
  display: flex;
  justify-content: space-between;
  margin-bottom: 7rem;
}
@media screen and (max-width: 700px) {
  .p-index-price__top {
    margin-bottom: 4.5rem;
  }
}

.p-index-price__top-item {
  /* width: calc(100/3); */
  max-width: 100%;
  width: 32rem;
}
@media screen and (max-width: 700px) {
  .p-index-price__top {
    margin-bottom: 4.5rem;
  }
}

.p-index-price__top-item-image {
  width: 10.5rem;
  margin: 0 auto 1.5rem;
}
.p-index-price__top-item-image img {
  width: 100%;
}
@media screen and (max-width: 700px) {
  .p-index-price__top-item-image {
    width: 8.5rem;
    margin: 0 auto 1rem;
  }
}

.p-index-price__top-item-ttl {
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: calc(19 / 13);
  letter-spacing: 0.04em;
}
@media screen and (max-width: 700px) {
  .p-index-price__top-item-ttl {
    text-align: center;
    font-size: 1.3rem;
  }
}

.p-index-price__txt {
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: calc(19 / 13);
  text-align: center;
  margin-bottom: 4.2rem;
}
@media screen and (max-width: 700px) {
  .p-index-price__txt {
    font-size: 1.3rem;
    margin-bottom: 2.2rem;
  }
}

.p-index-price__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 700px) {
  .p-index-price__list {
    gap: 0.6em 0;
  }
}

.p-index-price__item {
  max-width: 100%;
  width: 32rem;
  display: flex;
  align-items: center;
  border-radius: 0.8rem;
  border: 0.15rem solid #000;
  padding: 1.7rem 1.5rem;
}
@media screen and (max-width: 700px) {
  .p-index-price__item {
    width: 100%;
    border-radius: 0.4rem;
    border: 0.15rem solid #000;
    padding: 1.7rem 1.5rem;
  }
}

.p-index-price__item__ttl {
  position: relative;
  /* font-size: 1.6rem; */
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: calc(19 / 13);
  width: 50%;
}
.p-index-price__item__ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  width: 0.1rem;
  /* height: 100%; */
  height: 3.3rem;
  background: #000;
}
.p-index-price__item__ttl span {
  /* font-size: 2.2rem; */
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: calc(19 / 18);
  padding: 0 1.5rem 0 0;
}
@media screen and (max-width: 700px) {
  .p-index-price__item__ttl {
    font-size: 1.3rem;
    /* padding: 0 2.0rem 0 0; */
  }
  /* .p-index-price__item__ttl::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 0.1rem;
    height: 100%;
    background: #000;
  } */
  .p-index-price__item__ttl span {
    font-size: 1.8rem;
    padding: 0 1.5rem 0 0;
  }
}

.p-index-price__des {
  width: 50%;
  font-size: 2.4rem;
  font-weight: 600;
  padding: 0.5rem 0 0 2rem;
}
.p-index-price__des span {
  font-size: 1.6rem;
}
@media screen and (max-width: 700px) {
  .p-index-price__des {
    font-size: 2.4rem;
  }
  .p-index-price__des span {
    font-size: 1.6rem;
  }
}

.p-index-price__link {
  width: fit-content;
  margin: 12.4rem 0 0 auto;
}
@media screen and (max-width: 700px) {
  .p-index-price__link {
    margin: 4rem 0 0 auto;
  }
}
