@charset "UTF-8";
/* CLS対策：代替フォントをWebフォントに似せる設定 */
@font-face {
  font-family: 'Yu Gothic Adjusted';
  size-adjust: 103%;
  ascent-override: 95%;
  src: local("Yu Gothic Medium"), local("Yu Gothic");
}
@font-face {
  font-family: 'Yu Gothic Bold Adjusted';
  size-adjust: 103%;
  ascent-override: 95%;
  src: local("Yu Gothic Bold");
}
:root {
  --color-def: #464646;
  --color-title: #333333;
  --color-nav: #000;
  --color-sub: #c4c4c4;
  --color-arrow: #23211e;
  --accent: #e87db4;
  --primary: #536eb7;
  --color-link: #b1aadc;
  --bg-dark: #23211e;
  --bg-gray: #f6f6f6;
  --bg-gnav: #474365;
  --ls-wide: 0.05em;
  --title-sub-size: 2.4rem;
  --header-h: calc(140em / 32);
  --section-space: clamp(calc(100em / 64 / 1.2),calc(100% / 11.2),60px);
  --container: 1310px;
  --container-pad: calc(80% / 12.80);
--ff-gothic: 'Yu Gothic Adjusted', "yu-gothic-pr6n","游ゴシック Medium","Yu Gothic";
  --ff-mincho: "yu-mincho-pr6n","游明朝","YuMincho", "Yu Mincho", "Hiragino Mincho ProN", "MS PMincho", serif;
  --ff-en: Didot,"linotype-didot", serif;
  --ff-century: "Century Old Style Std", "yu-mincho-pr6n","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
}

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}
/* ===========================================================================

/assets/sass/common/_reset.scss
Reset

=========================================================================== */
body {
  /* webkit系のスマホで文字が拡大されるのを防ぐ */
  -webkit-text-size-adjust: 100%;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video, hr {
  margin: 0;
  padding: 0;
  border: 0;
  font-style: normal;
  font-weight: inherit;
  font-size: 100%;
  vertical-align: baseline;
  text-decoration: none;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, main {
  display: block;
}

html {
  overflow-y: scroll;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

input, button, textarea, select {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  /* 必要に応じて下記はコメントアウト */
  /*
   -webkit-appearance: none;
   -moz-appearance: none;
   appearance: none;
  */
}

ol, ul {
  list-style: none;
}

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

a:focus {
  outline: none;
}

img {
  vertical-align: bottom;
		aspect-ratio: attr(width) / attr(height);
}

a, span, small, strong {
  color: inherit;
  font-weight: inherit;
}

html {
  font-size: 0.625em;
  box-sizing: border-box;
}

img {
  max-width: 100%;
  vertical-align: bottom;
  height: auto;
}

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

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

a:hover, a:active {
  color: inherit;
  text-decoration: none;
}

.mt1 {
  margin-top: 1em;
}

.mt15 {
  margin-top: 1.5em;
}

.mt2 {
  margin-top: 2em;
}

.mb1 {
  margin-bottom: 1em;
}

.mb15 {
  margin-bottom: 1.5em;
}

.mb2 {
  margin-bottom: 2em;
}

.mb25 {
  margin-bottom: 2.5em;
}

.mb3 {
  margin-bottom: 3em;
}

.mr1 {
  margin-right: 1em;
}

.mr15 {
  margin-right: 1.5em;
}

.mr2 {
  margin-right: 2em;
}

.pl1 {
  padding-left: 1em;
}

.pl2 {
  padding-left: 2em;
}

.pl3 {
  padding-left: 3em;
}

.pl4 {
  padding-left: 4em;
}

.indent1 {
  text-indent: -1em;
  padding-left: 1em;
}

.list-indent li {
  text-indent: -1em;
  padding-left: 1em;
}

.list-decimal > li {
  padding-left: 2em;
  text-indent: -2em;
  list-style: decimal;
  list-style-position: inside;
}
.list-decimal > li::marker {
  color: var(--accent);
  font-weight: bold;
}

.ta_l {
  text-align: left;
}
.ta_r {
  text-align: right;
}
.ta_c {
  text-align: center;
}

@media print, screen and (max-width: 767px) {
  .hide-sp {
    display: none;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1020px) {
  .hide-tablet {
    display: none;
  }
}
@media print, screen and (min-width: 1021px) {
  .hide-pc {
    display: none;
  }
}

/* -----------------------------
 clearfix
----------------------------- */
.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.clearfix {
  display: inline-block;
  min-height: 1%;
}

/* for IE-mac */
* html .clearfix {
  height: 1%;
}

.clearfix {
  display: block;
}

body {
  font-family: "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
  color: var(--color-def);
  line-height: 2;
  font-feature-settings: "pkna";
  -webkit-font-smoothing: antialiased;
  font-size: clamp(1.4rem, 2.5vmin, 1.6rem);
}
@media print, screen and (min-width: 768px) {
  body {
    font-size: 1.6rem;
    --section-space: 8rem;
    background-size: auto;
  }
}
@media print, screen and (min-width: 1021px) {
  body {
    --header-h:8rem;
  }
}

.small {
  font-size: clamp(1rem, 2.1875vmin, 1.4rem);
}

.table {
  color: var(--color-def);
}

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

.en {
  font-family: var(--ff-en);
}

.mincho {
  font-family: var(--ff-mincho);
}

.gothic {
  font-family: var(--ff-gothic);
}

.century {
  font-family: var(--ff-century);
}

.helvetica {
  font-family: "Helvetica Neue";
}

b, strong, .bold {
  font-weight: 600;
}

.sup {
  position: relative;
  font-variant: all-small-caps;
}
.sup-tm {
  vertical-align: super;
}

.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
}
@media print, screen and (min-width: 768px) {
  .container {
    padding-left: 15px;
    padding-right: 15px;
    max-width: var(--container);
  }
}

h1, h2, h3, h4 {
  line-height: 1.5555555556;
}

.fc-default {
  color: var(--color-def);
}
.fc-accent {
  color: var(--accent);
}

.t-vtl {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-feature-settings: "pkna";
  white-space: nowrap;
}

video, img {
  max-width: 100%;
  height: auto;
}

a:hover {
  opacity: 0.75;
}

a img {
  transition: opacity 0.3s ease;
}
a img:hover {
  opacity: 0.75;
}
a img.js-img-on:hover {
  opacity: 1;
}

.h-alpha {
  display: inline-block;
  transition: opacity 0.3s ease;
}
.h-alpha:hover {
  opacity: 0.75;
}

.bg-dark {
  background-color: var(--bg-dark);
}

.bg-gray {
  background-color: var(--bg-gray);
}

@media print, screen and (min-width: 1021px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
.wrapper {
  overflow: hidden;
}

.ilblk {
  display: inline-block;
}

.d-flex {
  display: flex;
}

.ic-sb {
  align-items: center;
}

.jc-sb {
  justify-content: space-between;
}

.f-wrap {
  flex-wrap: wrap;
}

.ai-c {
  align-items: center;
}

@media print, screen and (min-width: 768px) {
  .row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .col {
    width: 45%;
  }
  .col-3 {
    width: 31.3235294118%;
  }
}
.js-animate.fade-in {
  opacity: 0;
}
.js-animate.fade-in.inView {
  animation: 0.8s 0.3s cubic-bezier(0.215, 0.61, 0.355, 1) both;
  animation-name: fade_in, slide_in_y;
}
.js-animate.fade-in2 {
  opacity: 0;
}
.js-animate.fade-in2.inView {
  animation: 0.8s 0.3s cubic-bezier(0.215, 0.61, 0.355, 1) both;
  animation-name: fade_in;
}
.js-animate.mask-in {
  position: relative;
  overflow: hidden;
}
.js-animate.mask-in .mask-blk {
  opacity: 0;
}
.js-animate.mask-in.inView {
  animation: maskIn 0.5s cubic-bezier(0.215, 0.61, 0.355, 1) forwards;
  opacity: 1;
}
.js-animate.mask-in.inView::before {
  animation: maskOut 0.5s 0.5s cubic-bezier(0.215, 0.61, 0.355, 1) forwards;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: var(--accent);
}
.js-animate.mask-in.inView .mask-blk {
  animation: fade_in 0.5s 0.7s cubic-bezier(0.215, 0.61, 0.355, 1) forwards;
}

@keyframes fade_in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fade_out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes sl_zoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1);
  }
}
@keyframes zoom_in {
  0% {
    transform: scale(1.25);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes blur_in {
  0% {
    filter: blur(20px);
  }
  100% {
    filter: blur(0);
  }
}
@keyframes slide_in_y {
  0% {
    transform: translateY(1.4vw);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes slide_in_x_left {
  0% {
    transform: translateX(-25vw);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes slide_in_x {
  0% {
    transform: translateX(25vw);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes slide_in_x_left2 {
  0% {
    transform: translateX(-50vw);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes slide_in_x2 {
  0% {
    transform: translateX(40px);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes bg_slide_x {
  0% {
    background-position: 100% 0;
  }
  100% {
    background-position: 0 0;
  }
}
@keyframes reveal_x {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
  }
}
.title-sec {
  color: var(--color-title);
  font-weight: normal;
  line-height: 1.5263157895;
  margin-bottom: 2em;
  text-align: var(--align, center);
  font-family: var(--family, var(--ff-mincho));
  letter-spacing: 0;
}
.title-sec-ic {
  display: inline-block;
  background: url(../../images/icon-color@2x.png) center no-repeat;
  background-size: contain;
  width: 4.347826087em;
  height: 2.6630434783em;
}
.title-sec-top {
  display: block;
  font-size: clamp(22px, 5.5vw, 38px);
  margin: 0.5em auto;
}
.title-sec-en {
  display: block;
  font-size: clamp(12px, 3vw, 14px);
  color: var(--accent);
}
.title-sec-label {
  background-color: var(--label, #acd6c8);
  color: #fff;
  display: inline-block;
  padding: 0.3em 1em;
  margin-bottom: 0.5em;
  font-size: clamp(1.6rem, 3.125vmin, 2rem);
  vertical-align: bottom;
}
.title-sec-label + span {
  display: block;
}
.title-sec .sub {
  font-size: clamp(1.3rem, 2.5vmin, 1.6rem);
  margin-top: 1em;
}
.title-num {
  color: var(--color-title);
  font-weight: normal;
  line-height: 1.1785714286;
  margin-bottom: 2em;
  text-align: var(--align, center);
  font-family: var(--family, var(--ff-mincho));
  letter-spacing: 0;
}
.title-num-top {
  color: var(--accent);
  display: block;
  font-size: clamp(40px, 12.5333333333vw, 94px);
}
.title-num-jp {
  display: block;
  font-size: clamp(20px, 5vw, 28px);
  margin-top: 0.5em;
}
@media print, screen and (min-width: 768px) {
  .title-sec-ic {
    width: 80px;
    height: 49px;
  }
}

.section {
  padding: var(--section-space) 0;
}

.btn {
  display: inline-block;
  padding: 0.5em 1em;
  position: relative;
  background-color: var(--color-link);
  color: #fff;
  text-align: center;
}
.btn:hover {
  color: #fff;
}

.marker {
  background: linear-gradient(transparent 60%, var(--marker, #fbe2ec) 60%);
}

.td_u {
  text-decoration: underline;
}

.link-arrow {
  display: flex;
  gap: 0.5em;
  align-items: center;
}
.link-arrow::before {
  content: "";
  display: inline-block;
  width: 0.625em;
  height: 0.625em;
  border-top: 1px var(--color-link, #000) solid;
  border-right: 1px var(--color-link, #000) solid;
  transform: rotate(45deg);
}

.fig {
  position: relative;
  text-align: center;
}
.fig-caption {
  position: absolute;
  bottom: 0.5em;
  width: 100%;
}

.text-sub {
  font-size: clamp(1.2rem, 2.1875vmin, 1.4rem);
  line-height: 1.7142857143;
}
.text-border {
  border-bottom: 1px var(--accent) solid;
}
.text-bigger {
  font-size: clamp(1.4rem, 2.5vmin, 1.8rem);
}
.text-link {
  color: #b1aadc;
  text-decoration: underline;
}
.text-link:hover {
  text-decoration: none;
  color: var(--accent);
}

.list-circle li {
  padding-left: 1.2em;
  text-indent: -1.2em;
}
.list-circle li::before {
  content: "●";
  color: var(--circle, var(--accent));
  margin-right: 0.2em;
}

.js-ac-cont {
  position: absolute;
  border: transparent;
  padding: 0;
  line-height: 0;
  opacity: 0;
  transition: line-height 0.4s, padding 0.4s, opacity 0.4s;
  pointer-events: none;
}
.js-ac-cont.is-open {
  position: relative;
  line-height: 2;
  opacity: 1;
  pointer-events: initial;
}
.js-ac-btn {
  cursor: pointer;
  position: relative;
}
.js-ac-btn.is-open .js-ac-icon::before {
  transform: rotate(0);
}
.js-ac-icon {
  background-color: #464646;
  width: 1.0526315789em;
  height: 1px;
  position: absolute;
  right: 0.6em;
  top: 50%;
}
.js-ac-icon::before {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background-color: #464646;
  transform: rotate(90deg);
  transition: transform 0.3s ease-in-out;
  transform-origin: center;
}
@media print, screen and (min-width: 768px) {
  .js-ac-icon {
    width: 0.7777777778em;
  }
}

.ic-x {
  display: inline-block;
  background: url(../../images/icon-x.png) center no-repeat;
  background-size: contain;
  width: 2.4em;
  height: 2.4em;
}

.ic-eq {
  display: inline-block;
  background: url(../../images/icon-eq.png) center no-repeat;
  background-size: contain;
  width: 2.4em;
  height: 2.4em;
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  --container: 1730px;
  z-index: 100;
  background-color: var(--header-bg, transparent);
  transition: background-color 0.5s;
  pointer-events: none;
  opacity: 0;
}
.header-logo {
  pointer-events: initial;
  display: flex;
 /* align-items: center;*/
  align-items: flex-end;
  gap: 0 1em;
}
.header-logo a:hover img {
  opacity: 1;
}
.header-logo-sub {
  transition: opacity 0.5s;
  font-size: clamp(11px, 2.5vmin, 16px);
  color: var(--primary);
  font-weight: bold;
}
.header-row {
  display: flex;
  justify-content: space-between;
  position: relative;
  height: var(--header-h);
  align-items: center;
}
@media print, screen and (max-width: 767px) {
  .header-logo-img {
    width: 10em;
  }
  .header-logo-sub {
    /*width: 15em;*/
    flex-shrink: 0;
    line-height: 1.25;
    font-weight: bold;
  }
}
@media print, screen and (min-width: 768px) {
  .header-logo {
    gap: 0 1em;
  }
}
@media print, screen and (min-width: 1021px) {
  .header-logo {
    flex-wrap: wrap;
    width: min(42.5%, 590px);
  }
}
.catchloaded .header {
  animation: fade_in 1s 1.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.scrolled .header {
  background-color: #fff;
}

.nav {
  position: fixed;
  z-index: 101;
  opacity: 0;
}
.nav-list {
  display: flex;
}
.nav-item {
  width: 25%;
  text-align: center;
}
.nav-link {
  color: var(--primary);
  display: block;
}
@media print, screen and (max-width: 1020px) {
  .nav {
    left: 0;
    bottom: 0;
    background-color: var(--primary);
    width: 100%;
    padding-bottom: env(safe-area-inset-bottom);
  }
  .nav-text {
    display: none;
  }
  .nav-link {
    padding: 0.8em 0.5em;
  }
  .nav-icon img {
    height: 9vmin;
    width: auto;
    object-fit: contain;
  }
}
@media print, screen and (min-width: 1021px) {
  .nav {
    right: clamp(15px, 5.5555555556vw, 5.5555555556vw);
    top: 15px;
    line-height: 1.2;
  }
  .nav-list {
    border-right: 1px var(--primary) solid;
  }
  .nav-item {
    border-left: 1px var(--primary) solid;
    display: block;
    width: auto;
  }
  .nav-link {
    padding-left: min(2vw, 2.2em);
    padding-right: min(2vw, 2.2em);
    background-color: transparent;
    transition: 0.3s background-color ease-in-out;
    display: flex;
    flex-direction: column;
    height: 50px;
    justify-content: flex-end;
    gap: 0.5em;
  }
  .nav-link:hover {
    text-decoration: none;
    opacity: 1;
    color: var(--primary);
    background-color: rgba(83, 110, 183, 0.15);
  }
  .nav-text {
    white-space: nowrap;
  }
}
.catchloaded .nav {
  animation: fade_in 1s 2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.footer {
  padding: 3em 0 8em;
}
.footer-logo {
  width: 9.7777777778em;
}
.footer-info {
  margin-bottom: 4em;
}
.footer-info-head {
  margin-bottom: 1.5em;
}
.footer-info-btn {
  margin-top: 1.5em;
}
.footer-info-btn .btn {
  width: 7.625em;
  padding: 0.05em;
  background-color: #000;
}
.footer-info-btn .btn-text {
  font-size: 12px;
}
@media print, screen and (max-width: 767px) {
  .footer .copy-logo {
    margin-top: 1em;
    width: 7em;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 768px) {
  .footer {
    padding-top: 5rem;
  }
  .footer-row {
    display: flex;
    gap: 2em 0;
    flex-wrap: wrap;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  }
  .footer-info {
    margin-bottom: 0;
    width: 360px;
  }
  .footer-info-btn .btn {
    width: 122px;
  }
  .footer-info:nth-of-type(2) {
    width: 400px;
  }
  .footer .copy {
    flex-grow: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.5em 1em;
    align-self: flex-end;
  }
}
@media print, screen and (min-width: 1021px) {
  .footer {
    padding-bottom: 2em;
  }
}

.fnav-list {
  display: flex;
  gap: 1.5em;
  line-height: 1.2;
}
.fnav-list li:nth-of-type(n+2) {
  border-left: 1px var(--color-def) solid;
  padding-left: 1.5em;
}
@media print, screen and (min-width: 768px) {
  .fnav {
    font-size: 1.8rem;
  }
}

.page-lp .catch {
  position: relative;
  margin-bottom: clamp(2em, 12%, 6em);
}
.page-lp .catch-inner {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-lp .catch-img {
  width: 100%;
  opacity: 1;
}
.page-lp .catch-img img {
  pointer-events: none;
  max-width: none;
  width: 100%;
}
.page-lp .catch-title {
  font-size: clamp(20px, 6vmin, 165px);
  line-height: 0.9090909091;
  opacity: 0;
}
.page-lp .catch-sub {
  font-size: clamp(16px, 5.52vmin, 42px);
  color: var(--primary);
/*  line-height: 1.4761904762;*/
line-height: 1.2;
  opacity: 0;
}
.page-lp .catch-labels {
  display: flex;
  gap: 1rem;
  opacity: 0;
}
.page-lp .catch-label {
  text-align: center;
  display: grid;
  align-items: center;
  justify-content: center;
  color: var(--primary);
  border: 1px var(--primary) solid;
  height: 2.0263157895em;
  width: 9.6052631579em;
  font-size: clamp(10px, 2.5333333333vmin, 26px);
}
@media print and (orientation: portrait), screen and (max-width: 1020px) and (orientation: portrait) {
  .page-lp .catch-img img {
    width: 100%;
  }
  .page-lp .catch-inner {
    align-items: flex-start;
    padding-top: calc(var(--header-h));
  }
  .page-lp .catch-sub {
    margin: 0.6em 0;
  }
}
@media print and (orientation: landscape), screen and (max-width: 1020px) and (orientation: landscape) {
  .page-lp .catch-img {
    height: auto;
  }
  .page-lp .catch-img img {
    height: auto;
    width: 100%;
  }
  .page-lp .catch-title {
    width: 47.8333333333vw;
  }
  .page-lp .catch-sub {
    margin: 0.5em 0 0.5em;
  }
  .page-lp .catch-inner {
    padding-top: var(--header-h);
  }
}
@media print, screen and (min-width: 1021px) {
  .page-lp .catch {
    --container: calc(1520vw / 18);
  }
  .page-lp .catch-img {
    height: auto;
  }
  .page-lp .catch-title {
    width: 47.8333333333vw;
  }
  .page-lp .catch-sub {
    margin: 8rem 0 4rem;
  }
  .page-lp .catch-label {
    width: 276px;
    height: 60px;
  }
}

.page-lp .catchloaded .catch-title {
  animation: fade_in 1.75s var(--delay-anime, 0.75s) cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_x_left 1.75s var(--delay-anime, 0.75s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .catchloaded .catch-sub {
  animation: fade_in 0.75s var(--delay-anime, 1.2s) cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_y 0.75s var(--delay-anime, 1.2s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .catchloaded .catch-labels {
  animation: fade_in 0.75s var(--delay-anime, 1.5s) cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_y 0.75s var(--delay-anime, 1.5s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .about {
  padding-top: 0;
}
.page-lp .about-img {
  position: relative;
  border: 1px #000 solid;
  padding: clamp(1em, 7.4626865672%, 6rem);
  margin: 3em auto 2.5em;
}
.page-lp .about-img-head {
  position: absolute;
  top: 0;
  left: 50%;
  background-color: #fff;
  transform: translate(-50%, -50%);
  font-size: clamp(16px, 2.5vmin, 33px);
  padding: 0 0.5em;
  white-space: nowrap;
}
.page-lp .about-desc {
  font-size: clamp(12px, 3vmin, 14px);
}
.page-lp .about-sub .d-flex {
  gap: 1.5em;
}
.page-lp .about-type {
  text-align: center;
  margin: 2em auto 3em;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1em;
  flex-direction: column;
}
.page-lp .about-type.inView .about-type-item {
  animation: fade_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_y 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .about-type.inView .about-type-ic {
  --delay-anime: 1s;
  animation: fade_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .about-type-item {
  background-color: #f6f6f6;
  padding: 1.5em;
  font-size: clamp(15px, 3.5vmin, 18px);
  font-weight: bold;
  width: 82.0895522388%;
  opacity: 0;
}
.page-lp .about-type-item.category {
  --type-color: #97cad5;
  --delay-anime: 0.4s;
}
.page-lp .about-type-item.type {
  --type-color: #ada1e6;
  --delay-anime: 0.75s;
}
.page-lp .about-type-item.type .about-type-label {
  grid-row: 1/span 2;
  grid-column: 1/span 2;
  display: grid;
  align-items: center;
  justify-content: center;
}
.page-lp .about-type-head {
  color: var(--type-color, #e578ac);
  margin-bottom: 1rem;
}
.page-lp .about-type-label {
  background-color: var(--type-color, #e578ac);
  color: #fff;
}
.page-lp .about-type-list {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 2.1111111111em);
}
.page-lp .about-type-ic {
  opacity: 0;
}
.page-lp .about-fusion {
  max-width: 900px;
  margin: 2.5em auto 1em;
  text-align: center;
}
.page-lp .about-fusion.inView .about-fusion-col {
  animation: fade_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards, zoom_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .about-fusion.inView .about-fusion-inner {
  animation: fade_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards, blur_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .about-fusion-top {
  display: flex;
  justify-content: center;
}
.page-lp .about-fusion-col {
  width: min(47.3333333333vw, 480px);
  height: min(47.3333333333vw, 480px);
  color: #fff;
  display: grid;
  align-items: center;
  justify-content: center;
  background-color: var(--fusion-bg, #f6b0d7);
  border-radius: 50%;
  mix-blend-mode: multiply;
  opacity: 0;
}
.page-lp .about-fusion-col.therapy {
  --fusion-bg: #9384d4;
  margin-left: min(-5.3333333333vw, 80px);
  --delay-anime: 0.4s;
}
.page-lp .about-fusion-col.fashion {
  --fusion-bg: #91dcd8;
  --delay-anime: 0.75s;
}
.page-lp .about-fusion-col.make {
  --fusion-bg: #ece15d;
  --delay-anime: 1.1s;
}
.page-lp .about-fusion-inner {
  filter: blur(20px);
  opacity: 0;
}
.page-lp .about-fusion-title {
  font-size: min(3.0784vw, 24px);
  margin-top: 1em;
}
.page-lp .about-fusion-en {
  font-size: min(5.92vw, 60px);
}
.page-lp .about-fusion-sub {
  font-size: min(3.7333333333vw, 26px);
  line-height: 1.65;
}
.page-lp .about-fusion-goal {
  font-size: min(4vw, 30px);
  line-height: 1.65;
}
.page-lp .about-fusion-below {
  display: flex;
  justify-content: center;
  position: relative;
  margin-top: min(5.3333333333vw, 50px);
}
.page-lp .about-fusion-below::before {
  content: "";
  display: block;
  background: url(../../images/icon-arrow.png) center no-repeat;
  background-size: contain;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -80%);
  width: min(12.1333333333vw, 125px);
  height: min(8.6666666667vw, 88px);
}
.page-lp .about-fusion-below .about-fusion-col {
  width: min(27.6vw, 280px);
  height: min(27.6vw, 280px);
}
.page-lp .about .title-num {
  margin-top: clamp(3em, 10vmin, 4.5em);
}
@media print, screen and (max-width: 767px) {
  .page-lp .about-type-ic .ic-x {
    width: 1.6em;
    height: 1.6em;
  }
  .page-lp .about-type-ic .ic-eq {
    width: 1.6em;
    height: 1.6em;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .about-type {
    flex-direction: row;
    margin: 3em auto;
    gap: 0.5em;
  }
  .page-lp .about-type-item {
    width: 29.6875%;
    padding: 1.5em 1.3em;
  }
  .page-lp .about-type-ic .ic-eq {
    transform: rotate(90deg);
  }
}
.page-lp .attraction {
  background-color: #f6f6f6;
  padding: var(--section-space) 0;
  --corner: calc(180em / 38.4 / 1.5);
}
.page-lp .attraction-col {
  background-color: #fff;
  position: relative;
  padding: 2.5em 2em;
  clip-path: polygon(calc(100% - var(--corner)) 0, 100% calc(0% + var(--corner)), 100% 100%, 0 100%, 0 0);
  opacity: 0;
}
.page-lp .attraction-col::before {
  content: "";
  clip-path: polygon(calc(100% - var(--corner)) 0, 100% calc(0% + var(--corner)), 100% 100%, 0 100%, 0 0);
  display: block;
  width: var(--corner);
  height: var(--corner);
  background-color: #e284c6;
  position: absolute;
  right: 0;
  top: 0;
}
.page-lp .attraction-col:nth-of-type(2) {
  --delay-anime: 0.4s;
}
.page-lp .attraction-col:nth-of-type(3) {
  --delay-anime: 0.75s;
}
.page-lp .attraction-img {
  text-align: center;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.page-lp .attraction-title {
  color: #e284c6;
  font-size: clamp(16px, 3.84vmin, 22px);
  margin: 1.5em 0 1em;
}
.page-lp .attraction-row {
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 2.5em;
}
.page-lp .attraction-row.inView .attraction-col {
  animation: fade_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_y 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@media print, screen and (max-width: 767px) {
  .page-lp .attraction-row {
    padding-left: var(--container-pad);
    padding-right: var(--container-pad);
  }
  .page-lp .attraction .img1 img {
    width: 65.5102040816%;
  }
  .page-lp .attraction .img2 img {
    width: 62.0408163265%;
  }
  .page-lp .attraction .img3 img {
    width: 52.5510204082%;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .attraction-row {
    flex-direction: row;
    justify-content: space-between;
    gap: 1em;
  }
  .page-lp .attraction-col {
    width: 29.6875%;
  }
}
.page-lp .fields {
  padding-bottom: 0;
}
.page-lp .fields-img {
  text-align: center;
}
.page-lp .fields-title {
  color: #e284c6;
  font-size: clamp(16px, 3.84vmin, 22px);
  margin: 1.25em 0 1em;
  text-align: center;
}
.page-lp .fields-col {
  opacity: 0;
}
.page-lp .fields-col:nth-of-type(2) {
  --delay-anime: 0.4s;
}
.page-lp .fields-col:nth-of-type(3) {
  --delay-anime: 0.75s;
}
.page-lp .fields-row {
  margin-bottom: var(--section-space);
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 3em;
}
.page-lp .fields-row.inView .fields-col {
  animation: fade_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_y 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@media print, screen and (max-width: 767px) {
  .page-lp .fields-row {
    padding-left: var(--container-pad);
    padding-right: var(--container-pad);
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .fields-row {
    flex-direction: row;
    justify-content: space-between;
    gap: 1em;
  }
  .page-lp .fields-col {
    width: 29.6875%;
  }
}
.page-lp .graduates-row {
  margin-top: 2.5em;
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 3em;
}
.page-lp .graduates-row.inView .graduates-col {
  animation: fade_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_y 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .graduates-col {
  background-color: var(--gra-bg, #d4f5de);
  opacity: 0;
}
.page-lp .graduates-col.first {
  --circle: #91cf91;
}
.page-lp .graduates-col.second {
  --circle: #e284c6;
  --gra-bg: #f6daee;
  --delay-anime: 0.4s;
}
.page-lp .graduates-col.third {
  --circle: #9e96d1;
  --gra-bg: #d7daf7;
  --delay-anime: 0.75s;
}
.page-lp .graduates-inner {
  padding: 1em 1.5em 1.5em;
  height: 100%;
}
.page-lp .graduates-detail {
  position: relative;
}
.page-lp .graduates-no {
  color: #fff;
  display: flex;
  line-height: 1;
  justify-content: space-between;
  align-items: flex-end;
  font-size: clamp(16px, 4vmin, 24px);
}
.page-lp .graduates-no .no {
  font-size: clamp(36px, 7.5vmin, 72px);
  line-height: 0.7;
}
.page-lp .graduates-title {
  font-size: clamp(20px, 5.5vmin, 28px);
  line-height: 1.7142857143;
  margin: 1.2em 0;
}
.page-lp .graduates-name .big {
  font-size: clamp(16px, 4vmin, 24px);
}
.page-lp .graduates .list-circle {
  font-size: clamp(13px, 3vmin, 14px);
  margin-top: 2em;
}
.page-lp .graduates-btn {
  margin-top: 1em;
  display: flex;
  width: 2.8em;
  height: 2.8em;
  border: 1px #000 solid;
  align-items: center;
  justify-content: center;
}
.page-lp .graduates-btn.is-open .graduates-line::before {
  transform: rotate(0);
}
.page-lp .graduates-line {
  width: 1em;
  height: 1px;
  background-color: #000;
  position: relative;
}
.page-lp .graduates-line::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: #000;
  position: absolute;
  left: 0;
  transform: rotate(90deg);
  transition: transform 0.3s ease-in-out;
  transform-origin: center;
}
.page-lp .graduates-desc {
  padding-top: 1em;
}
.page-lp .graduates-item {
  padding-bottom: 1px;
}
@media print, screen and (max-width: 767px) {
  .page-lp .graduates-row {
    padding-left: var(--container-pad);
    padding-right: var(--container-pad);
  }
  .page-lp .graduates-img img {
    width: 100%;
    max-width: none;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .graduates-row {
    flex-direction: row;
    justify-content: space-between;
    gap: 1em;
/*    align-items: flex-start;*/
  }

/* カード自体（.graduates-col）を縦方向のFlexboxコンテナにする */
.page-lp .graduates-col {
  display: flex;
  flex-direction: column;
}

/* 画像の下のコンテンツ全体（.graduates-inner）が残りの高さをすべて埋めるようにする */
.page-lp .graduates-inner {
  flex-grow: 1; /* 空きスペースを埋める */
  display: flex;
  flex-direction: column;
}

/* ボタンの上のテキスト部分（.graduates-item）が、さらにその中の残りの高さをすべて埋めるようにする */
.page-lp .graduates-item {
  flex-grow: 1; /* 空きスペースを埋める */
}






  .page-lp .graduates-col {
    width: 29.6875%;
  }
  .page-lp .graduates-inner {
    padding: 1em 1em 1.5em;
    max-width: calc(300px + 2em);
    margin-left: auto;
    margin-right: auto;
  }
  .page-lp .graduates-btn {
    width: 3.6em;
    height: 3.6em;
  }
}
.page-lp .movie-wrap {
  max-width: 980px;
  margin: 3em auto 0;
  position: relative;
  width: 100%;
}
.page-lp .movie-wrap::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 56.2244897959%;
}
.page-lp .movie-wrap iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}
.page-lp .course {
  --course: #e284c6;
  --course-sub: #f9e6f4;
}
.page-lp .course-row.advisor {
  --marker: #f8f4b5;
  --course: #f3ec83;
  --course-sub: #f7f2a8;
  --accent: #f3ec83;
}
.page-lp .course-row.advisor .course-label {
  --course: #efe569;
  color: #dec168;
}
.page-lp .course-row.advisor .course-label.filled {
  --course: #efe569;
  color: #fff;
}
.page-lp .course-row.advisor .course-table {
  --course: #dec168;
}
@media print, screen and (min-width: 1021px) {
  .page-lp .course-row.advisor {
    flex-direction: row-reverse;
  }
  .page-lp .course-row.advisor .course-img::before {
    left: 100px;
    right: initial;
  }
}
.page-lp .course-row.therapist {
  --marker: #e1ddf6;
  --course: #ada1e6;
  --course-sub: #e1ddf6;
  --accent: #ada1e6;
}
.page-lp .course-img {
  position: relative;
}
.page-lp .course-img img {
  position: relative;
  z-index: 1;
  opacity: 0;
  --delay-anime: 0.7s;
}
.page-lp .course-img::before {
  position: absolute;
  content: "";
  display: block;
  clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
}
.page-lp .course-img.inView img {
  animation: fade_in 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .course-img.inView::before {
  animation: reveal_x 0.75s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .course-title {
  font-size: clamp(18px, 4.5vmin, 28px);
  line-height: 1.7142857143;
  margin-bottom: 0.6em;
	}
.page-lp .course-label {
  border: 1px var(--course) solid;
  text-align: center;
  color: var(--course);
  min-width: 9.5384615385em;
  padding: 0 0.5em;
  line-height: 1;
  height: 2em;
  display: grid;
  align-items: center;
  justify-content: center;
}
.page-lp .course-label-list {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: clamp(11px, 2.75vmin, 13px);
  margin-top: 1rem;
}
.page-lp .course-label.filled {
  background-color: var(--course);
  color: #fff;
}
.page-lp .course-detail {
  border-bottom: 1px #000 solid;
}
.page-lp .course-detail:first-of-type {
  margin-top: 1.5em;
  border-top: 1px #000 solid;
}
.page-lp .course-detail-head {
  padding: 1em 0;
}
.page-lp .course-detail-body {
  padding-bottom: 2em;
}
.page-lp .course-detail-body .list-circle {
  --circle: var(--color-def);
}
.page-lp .course-detail .small {
  font-size: clamp(1rem, 2.03125vmin, 1.3rem);
}
.page-lp .course-table {
  width: 100%;
  line-height: 1.5625;
  margin: 1em auto;
}
.page-lp .course-table thead th {
  background-color: var(--course-sub);
  color: var(--course);
  border: 1px var(--course) solid;
  padding: 0.2em 1em;
}
.page-lp .course-table tbody td {
  border: 1px var(--course) solid;
  padding: 0.2em 0.5em;
  vertical-align: middle;
}
.page-lp .course-table tbody td:nth-of-type(1) {
  width: 4.375em;
  text-align: center;
}
.page-lp .course-table tbody td:nth-of-type(3) {
  width: 5em;
  text-align: center;
}
@media print, screen and (max-width: 1020px) {
  .page-lp .course-row {
    padding-top: 10vw;
    padding-left: calc(var(--container-pad) / 2);
    padding-right: calc(var(--container-pad) / 2);
    margin-bottom: 3em;
  }
  .page-lp .course-img img {
    width: 100%;
    max-width: none;
  }
  .page-lp .course-img::before {
    position: absolute;
    content: "";
    display: block;
    width: 100vw;
    height: 90.0726392252%;
    background-color: var(--course, #e284c6);
    top: -10vw;
    left: 50%;
    transform: translateX(-50vw);
  }
  .page-lp .course-title {
    margin-top: 1em;
				font-weight: 700;
				margin-bottom: 3rem;
  }
  .page-lp .course-table {
    font-size: clamp(12px, 3vmin, 16px);
  }
  .page-lp .course-detail .small {
    display: inline-block;
    line-height: 1.75;
    margin-top: 0.5em;
  }
}
@media print, screen and (min-width: 1021px) {
  .page-lp .course-row {
    display: flex;
    gap: clamp(1em, 4.6875%, 60px);
    margin-top: var(--section-space);
    padding-top: var(--section-space);
  }
  .page-lp .course-img {
    width: 54.6875%;
    align-self: flex-start;
  }
  .page-lp .course-img::before {
    position: absolute;
    content: "";
    display: block;
    width: 60vw;
    height: calc(100% - 90px);
    background-color: var(--course, #e284c6);
    top: -80px;
    right: 100px;
  }
  .page-lp .course-col {
    width: 40.625%;
  }
}
.page-lp .fees {
  background-color: #f6f6f6;
}
.page-lp .fees-block {
  background-color: #fff;
  padding: min(var(--container-pad), 6rem);
}
.page-lp .fees-table {
  width: 100%;
}
.page-lp .fees-table th, .page-lp .fees-table td {
  border: 1px #e284c6 solid;
  padding: 0.5em 1em;
  vertical-align: middle;
}
.page-lp .fees-table thead th {
  background-color: #e284c6;
  color: #fff;
  text-align: left;
  font-size: clamp(14px, 3.5vmin, 20px);
  padding: 0.2em 1em;
}
.page-lp .fees-table thead td {
  background-color: #f9e6f3;
}
.page-lp .fees-table thead td:nth-of-type(2) {
  text-align: center;
}
.page-lp .fees-table thead td:nth-of-type(3) {
  text-align: center;
}
.page-lp .fees-table tbody td:nth-of-type(1) {
  text-align: center;
  color: #e284c6;
  font-weight: bold;
}
.page-lp .fees-table tbody td:nth-of-type(3) {
  text-align: right;
}
.page-lp .fees-table tbody td:nth-of-type(4) {
  text-align: right;
}
.page-lp .fees-table .d-flex {
  gap: 0.5em;
}
.page-lp .fees-table .d-grid {
  display: grid;
}
.page-lp .fees-label {
  background-color: var(--course, #e284c6);
  min-width: 9.5384615385em;
  font-size: clamp(10px, 2.5vmin, 13px);
  text-align: center;
  color: #fff;
  padding: 0.2em;
  line-height: 1.5;
}
.page-lp .fees-label.yellow {
  --course: #efe569;
}
.page-lp .fees-label.purple {
  --course: #ada1e6;
}
.page-lp .fees-desc {
  font-size: clamp(12px, 3vmin, 14px);
  line-height: 1.7142857143;
  margin: 1.2em 0 3em;
}
.page-lp .fees-pay-title {
  font-size: clamp(16px, 4vmin, 20px);
}
.page-lp .fees-pay-table {
  width: 100%;
  margin-top: 1em;
}
.page-lp .fees-pay-table th, .page-lp .fees-pay-table td {
  border: 1px #e284c6 solid;
  padding: 0.5em 1.5em;
  vertical-align: middle;
}
@media print, screen and (max-width: 767px) {
  .page-lp .fees-table {
    font-size: clamp(12px, 3vmin, 16px);
  }
  .page-lp .fees-table .d-grid {
    gap: 0.5em;
  }
  .page-lp .fees-table .d-flex {
    justify-content: center;
    gap: 0 0.5em;
  }
  .page-lp .fees-pay-table td {
    padding: 0.5em 0.5em;
  }
  .page-lp .fees-pay-table td:nth-of-type(1) {
    width: 7em;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .fees-table .d-grid {
    grid-template-columns: 1fr 10em;
  }
  .page-lp .fees-pay-table td:nth-of-type(1) {
    width: 220px;
  }
}
@media print, screen and (min-width: 1021px) {
  .page-lp .fees-table .d-grid {
    grid-template-columns: 1fr 20em;
  }
}
.page-lp .supports {
  background-color: #f6f6f6;
  padding-top: 0;
}
.page-lp .supports-box {
  background-color: #fff;
  padding: min(var(--container-pad), 6rem);
}
.page-lp .supports-list {
  display: grid;
  gap: 1.5em;
}
.page-lp .supports-list li {
  display: flex;
  background-color: #f9e6f3;
  align-items: center;
  gap: 1em;
}
.page-lp .supports-list .no {
  font-family: var(--ff-mincho);
  font-size: clamp(16px, 4vmin, 22px);
  background-color: #e284c6;
  color: #fff;
  display: grid;
  align-items: center;
  justify-content: center;
  width: 2.7272727273em;
  height: 2.7272727273em;
}
.page-lp .supports-list .text {
  font-size: clamp(14px, 3.5vmin, 18px);
}
@media print, screen and (max-width: 767px) {
  .page-lp .supports-list {
    margin-bottom: 2em;
  }
  .page-lp .supports-img img {
    width: 9em;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .supports-box {
    display: grid;
    grid-template-columns: 1fr 280px;
  }
}
@media print, screen and (min-width: 1021px) {
  .page-lp .supports-list {
    max-width: 790px;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-flow: column;
    grid-template-rows: repeat(3, 1fr);
  }
}
.page-lp .flow {
  --flow: #e284c6;
}
.page-lp .flow-box {
  border: 1px var(--flow) solid;
}
.page-lp .flow-head {
  padding: 1.4em min(var(--container-pad), 60px);
  font-size: clamp(16px, 4vmin, 22px);
  color: var(--flow);
}
.page-lp .flow-head-ic {
  background-color: var(--flow);
  width: 2.1818181818em;
  right: min(var(--container-pad), 60px);
}
.page-lp .flow-head-ic::before {
  background-color: var(--flow);
}
.page-lp .flow-body {
  padding: 0 min(var(--container-pad), 60px);
}
.page-lp .flow-step {
  display: flex;
  gap: 1em;
  position: relative;
  align-items: center;
}
.page-lp .flow-no {
  font-size: clamp(14px, 3.5vmin, 22px);
  width: 3.6em;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
}
.page-lp .flow-no .step {
  background-color: var(--flow);
  color: #fff;
  border-radius: 50%;
  width: 3.6em;
  height: 3.6em;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.page-lp .flow-no .arrow {
  width: 2.3666666667em;
  background-color: #f9e6f3;
  height: calc(100% + 1em);
  margin-top: -1em;
  clip-path: polygon(65% 0, 65% calc(100% - 1em), 100% calc(100% - 1em), 50% 100%, 0 calc(100% - 1em), 35% calc(100% - 1em), 35% 0);
}
.page-lp .flow-detail {
  display: flex;
  gap: 1em;
}
.page-lp .flow-title {
  font-size: clamp(16px, 4vmin, 24px);
  color: var(--flow);
}
.page-lp .flow-1 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
}
.page-lp .flow-1-col {
  border: 1px var(--flow) solid;
  display: flex;
  align-items: center;
  padding: 1em;
  color: var(--flow);
  font-size: clamp(14px, 3.5vmin, 20px);
  line-height: 1.7;
}
.page-lp .flow-1-arrow {
  position: relative;
  background-color: var(--flow);
}
.page-lp .flow-1-arrow::before {
  content: "";
  width: 1em;
  height: 1em;
  border-top: 1px var(--flow) solid;
  border-right: 1px var(--flow) solid;
  position: absolute;
  display: block;
}
.page-lp .flow-2 {
  width: 100%;
}
.page-lp .flow-2-row {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.page-lp .flow-2-col {
  border: 1px var(--flow) solid;
  display: flex;
  align-items: center;
  padding: 1em;
  color: var(--flow);
  font-size: clamp(14px, 3.5vmin, 20px);
  line-height: 1.7;
  position: relative;
}
.page-lp .flow-2-or {
  font-size: clamp(18px, 4.5vmin, 24px);
  color: var(--flow);
  align-self: center;
}
.page-lp .flow-2-desc {
  font-size: clamp(12px, 3vmin, 14px);
}
.page-lp .flow-2 .free {
  position: absolute;
  background-color: var(--flow);
  color: #fff;
  font-size: clamp(12px, 3vmin, 16px);
  width: 5em;
  height: 5em;
  display: block;
  text-align: right;
  padding: 0.5em;
  right: 0;
  top: 0;
  clip-path: polygon(100% 0, 0 0, 100% 100%);
}
.page-lp .flow-ic {
  width: 4.5238095238em;
  text-align: center;
}
.page-lp .flow-btm {
  margin-top: 1.5em;
  padding-bottom: 3em;
}
@media print, screen and (max-width: 1020px) {
  .page-lp .flow-1 {
    padding-bottom: 2em;
  }
  .page-lp .flow-1-arrow {
    width: 1px;
    height: 2.5em;
    align-self: center;
    flex-shrink: 0;
  }
  .page-lp .flow-1-arrow::before {
    left: -0.45em;
    bottom: 2px;
    transform: rotate(135deg);
    transform-origin: center;
  }
  .page-lp .flow-1-col {
    padding: 0.5em;
  }
  .page-lp .flow-1 .flow-ic {
    width: 3em;
    flex-shrink: 0;
  }
  .page-lp .flow-1 .ic-pc img {
    width: 1.7em;
  }
  .page-lp .flow-1 .ic-doc img {
    width: 1.325em;
  }
  .page-lp .flow-2-row {
    align-items: center;
  }
  .page-lp .flow-2-arrow {
    width: 1px;
    height: 2.5em;
    align-self: center;
    flex-shrink: 0;
  }
  .page-lp .flow-2-arrow::before {
    left: -0.45px;
    bottom: 2px;
    transform: rotate(135deg);
    transform-origin: center;
  }
  .page-lp .flow-2-col {
    padding: 0.5em 3em 0.5em 0.5em;
    width: 100%;
    min-height: 5em;
  }
  .page-lp .flow-2-desc {
    padding: 1em 0 2em;
  }
  .page-lp .flow-2 .flow-ic {
    width: 3em;
    flex-shrink: 0;
  }
  .page-lp .flow-2 .ic-visit img {
    width: 1.7em;
  }
  .page-lp .flow-2 .ic-online img {
    width: 1.475em;
  }
  .page-lp .flow-2 .free {
    width: 4em;
    height: 4em;
    padding: 0.25em;
  }
}
@media print, screen and (min-width: 1021px) {
  .page-lp .flow-step {
    gap: 1.5em;
  }
  .page-lp .flow-detail {
    gap: 1.5em;
  }
  .page-lp .flow-ic {
    width: 5em;
  }
  .page-lp .flow-1 {
    padding-bottom: 3em;
    flex-direction: row;
  }
  .page-lp .flow-1-col {
    width: 50%;
    min-height: 7.5em;
  }
  .page-lp .flow-1-arrow {
    width: 60px;
    height: 1px;
    align-self: center;
    flex-shrink: 0;
  }
  .page-lp .flow-1-arrow::before {
    top: -0.5em;
    right: 2px;
    transform: rotate(45deg);
    transform-origin: center;
  }
  .page-lp .flow-2-row {
    flex-direction: row;
    gap: 1em;
    margin-bottom: 1.5em;
  }
  .page-lp .flow-2-col {
    width: 50%;
    min-height: 7.5em;
  }
  .page-lp .flow-2-desc {
    padding-bottom: 2em;
  }
}
.page-lp .session {
  background-color: #f6f1a2;
}
.page-lp .session-title {
  margin-bottom: 1.5em;
}
.page-lp .session-title-top {
  display: block;
  font-size: clamp(20px, 4.5vmin, 38px);
}
.page-lp .session-title-sub {
  font-size: clamp(14px, 3.5vmin, 21px);
}
.page-lp .session-intro {
  font-size: clamp(16px, 4vmin, 24px);
  margin: 1.5em 0;
}
.page-lp .session-point {
  display: flex;
  gap: 1.25em;
  justify-content: center;
  text-align: center;
}
.page-lp .session-point-item {
  position: relative;
  width: min(30%, 195px);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  font-size: clamp(14px, 3.5vmin, 18px);
  line-height: 1.5;
  padding: 0.6em 0.5em;
  gap: 0.2em;
}
.page-lp .session-point-item .no {
  font-size: clamp(18px, 4.5vmin, 24px);
  color: #536db7;
}
.page-lp .session-point-item::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  border: 1px #000 solid;
  position: absolute;
  clip-path: polygon(0 0, 1em 0, 1em 1em, calc(100% - 1em) 1em, calc(100% - 1em) 0, 100% 0, 100% 100%, calc(100% - 1em) 100%, calc(100% - 1em) calc(100% - 1em), 1em calc(100% - 1em), 1em 100%, 0 100%);
}
.page-lp .session-box {
  background-color: #fff;
  margin: 3.5em auto 2em;
  position: relative;
  max-width: 400px;
  padding-bottom: 1.25em;
}
.page-lp .session-box-head {
  background: url(../../images/ic-ribbon.png) center no-repeat;
  background-size: contain;
  color: #fff;
  padding: 0.5em 0.5em 1.5em;
  transform: translateY(-1.5em);
  margin-bottom: -1.2em;
}
.page-lp .session-box-fee {
  font-size: clamp(18px, 4.5vmin, 24px);
  line-height: 1.6;
}
.page-lp .session-box-fee .no {
  font-size: clamp(22px, 5.5vmin, 34px);
}
.page-lp .session-btm-title {
  font-size: clamp(18px, 4.5vmin, 24px);
  display: flex;
  align-items: center;
  gap: 0.5em;
  margin: 1em auto 0.5em;
  max-width: 400px;
}
.page-lp .session-btm-title::before, .page-lp .session-btm-title::after {
  content: "";
  display: block;
  width: 50%;
  height: 1px;
  background-color: #000;
}
.page-lp .session-btm-title span {
  flex-shrink: 0;
}
.page-lp .session-btns {
  display: flex;
  gap: clamp(1rem, 2.5vmin, 2rem);
  justify-content: center;
  margin-top: 1em;
}
.page-lp .session-btns .btn {
  background-color: #546eb7;
  width: min(50%, 308px);
  font-size: clamp(14px, 3.5vmin, 20px);
  height: 3.5em;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5em clamp(1.5rem, 2.5vmin, 3em) 0.5em clamp(0.5rem, 2.5vmin, 1em);
}
.page-lp .session-btns .btn::before {
  content: "";
  display: block;
  width: 0.6em;
  height: 0.6em;
  border-top: 1px #fff solid;
  border-right: 1px #fff solid;
  transform: rotate(45deg);
  position: absolute;
  right: clamp(1rem, 2.5vmin, 1.5em);
}
.page-lp .message {
  background-color: #f6f6f6;
  position: relative;
}
.page-lp .message-catch {
  color: #fff;
  line-height: 0.9361702128;
  position: absolute;
  font-size: clamp(40px, 10vmin, 94px);
  top: 0;
  left: var(--container-pad);
}
.page-lp .message-title {
  font-size: clamp(18px, 4.5vmin, 28px);
  margin: 0.5em 0 2em;
}
.page-lp .message-name {
  margin-top: 4em;
  margin-bottom: 0.5em;
}
.page-lp .message-name .small {
  margin-left: 1em;
}
.page-lp .message-text {
  position: relative;
  z-index: 1;
}
@media print, screen and (max-width: 767px) {
  .page-lp .message-img {
    width: 62.5%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2em;
    margin-top: 1.5em;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .message-row {
    display: grid;
    grid-template-columns: 31.25% 1fr;
    gap: 7.03125%;
  }
  .page-lp .message-catch {
    left: 50%;
    transform: translate(-73%, 0);
    font-size: clamp(40px, 7.34375vw, 94px);
  }
}
/* --- PageSpeed Insights 最終対策コード --- */

/* JSに頼らず、最初からヘッダーとナビを表示する */
.header, .nav {
  opacity: 1 !important;
  animation: none !important;
}

/* メイン画像も最初から表示し、アニメーションもCSSで即時開始する */
.page-lp .catch-img {
  opacity: 1 !important;
  animation: fade_in 1.25s 0.1s cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
}

/* JSが追加するクラスに依存していた他のアニメーションも、CSSで直接制御する */
.page-lp .catch-title {
  animation: fade_in 1.75s 0.75s cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_x_left 1.75s 0.75s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .catch-sub {
  animation: fade_in 0.75s 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_y 0.75s 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* JS依存の古いアニメーション指定をすべて無効化する */
.catchloaded .header,
.catchloaded .nav,
.page-lp .catchloaded .catch-title,
.page-lp .catchloaded .catch-sub {
  animation: none !important;
}


