@charset "UTF-8";
:root {
  --color-def: #464646;
  --color-title: #d9ebef;
  --color-nav: #8a94d5;
  --color-sub: #c4c4c4;
  --color-arrow: #23211e;
  --accent: #e87db4;
  --primary: #61b7c4;
  --color-link: #b1aadc;
  --red: #cc0000;
  --bg-dark: #23211e;
  --bg-gray: #f6f6f6;
  --bg-gnav: #474365;
  --ls-wide: 0.05em;
  --title-sub-size: 2.4rem;
  --header-h: calc(90em / 32);
  --section-space: clamp(calc(100em / 64 / 1.2),calc(100% / 11.2),60px);
  --container: 1310px;
  --container-pad: calc(80% / 15);
  --btn-bg:#8a94d5;
  --btn-color:#fff;
  --btn-color-h:#8a94d5;
  --btn-bg-h:#fff;
  --size-def: clamp(14px, calc(14vmin / 4), 16px);
  --size-xs: 12px;
  --size-s: clamp(12px, calc(12vmin / 4), 14px);
  --size-l: clamp(14px, calc(15vmin / 4), 18px);
  --size-2l: clamp(14px, calc(16vmin / 4), 20px);
  --size-xl: clamp(16px, calc(18vmin / 4), 22px);
  --size-2xl: clamp(16px, calc(20vmin / 4), 28px);
  --size-3l: clamp(20px, calc(20vmin / 4), 30px);
  --size-btn: clamp(16px, calc(16vmin / 4), 24px);
  --ff-gothic: "yu-gothic-pr6n","游ゴシック Medium", yu-gothic-pr6n, "Yu Gothic", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN",sans-serif;
  --ff-mincho: "dnp-shuei-mincho-pr6n", "游明朝", yu-mincho-pr6n, "YuMincho", "Yu Mincho", "Hiragino Mincho ProN", "MS PMincho", serif;
  --ff-en: "linotype-didot", Didot, linotype-didot, aw-conqueror-didot, serif;
  --ff-helv: "Helvetica Neue" , Helvetica ,serif;
  --ff-noto: "Noto Sans JP", var(--ff-gothic);
}

.ff-en {
  font-family: var(--ff-en);
  font-weight: 400;
  font-style: normal;
}

.ff-title {
  font-family: var(--ff-mincho);
  font-weight: 500;
  font-style: normal;
}

.ff-helv {
  font-family: var(--ff-helv);
  font-weight: 400;
  font-style: normal;
}

.ff-noto {
  font-family: var(--ff-noto);
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.ff-gothic {
  font-family: var(--ff-gothic);
  font-weight: 400;
  font-style: normal;
}

/* ===========================================================================

/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;
}

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;
}

.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: var(--ff-gothic);
  color: var(--color-def);
  line-height: 2;
  font-feature-settings: "pkna";
  -webkit-font-smoothing: antialiased;
  font-size: var(--size-def);
}
@media print, screen and (min-width: 768px) {
  body {
    --section-space: 8rem;
    background-size: auto;
  }
}
@media print, screen and (min-width: 1021px) {
  body {
    --header-h:7.2rem;
  }
}
@media print, screen and (max-width: 767px) {
  body {
    --flag-w: 8em;
    --flag-h: 8em;
    --flag-cut: 1.5em;
  }
}

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: 700;
}

.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;
}

.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-gray {
  background-color: var(--bg-gray);
}

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

.ilblk {
  display: inline-block;
}

.d-flex {
  display: flex;
}

.jc-c {
  justify-content: 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.5s var(--anim-delay, 0.1s) 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.5s var(--anim-delay, 0.1s) 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 zoom {
  0% {
    transform: scale(0);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes zoom_in {
  0% {
    transform: scale(1.2);
  }
  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 slice_x {
  0% {
    transform: translateX(10%);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes slice_x_left {
  0% {
    transform: translateX(-10%);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes slide_in_x {
  0% {
    transform: translateX(25vw);
  }
  100% {
    transform: translateX(0);
  }
}
.title-sec {
  line-height: 1.05;
  margin-bottom: 1em;
  text-align: var(--align, center);
  letter-spacing: 0;
  opacity: 0;
}
.title-sec-top {
  display: block;
  font-size: clamp(32px, 17.5vw, 120px);
  line-height: 1.2;
  color: var(--color-title);
}
.title-sec-jp {
  display: block;
  font-size: clamp(20px, 5.5vw, 38px);
  line-height: 1.4032258065;
}
.title-sec::after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 4.25em;
  background-color: #95ccd5;
  margin-top: 1em;
}
.title-in.inView .title-sec {
  animation: 0.4s 0.1s cubic-bezier(0.4, 0, 0, 1) forwards;
  animation-name: fade_in, slide_in_y;
}
.title-sub {
  line-height: 1.8125;
  font-size: clamp(18px, 5vw, 32px);
  margin-bottom: 0.75em;
}

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

.btn {
  display: inline-block;
  padding: 0.8em 1em;
  position: relative;
  background-color: var(--btn-bg);
  color: var(--btn-color, #fff);
  text-align: center;
  border: 1px #fff solid;
  line-height: 1;
  transition: all 0.3s ease-in;
}
.btn:hover {
  color: var(--btn-color-h, #fff);
  opacity: 1;
  color: var(--btn-color-h);
  background-color: var(--btn-bg-h);
  border-color: var(--btn-bg);
  --btn-arrow: var(--btn-color-h);
}
.btn-arrow {
  position: absolute;
  right: 1.25em;
  top: calc(50% - 0.25em);
}
.btn-arrow::before {
  content: "";
  display: block;
  width: 0.5em;
  height: 0.5em;
  border-top: 1px var(--btn-arrow, #fff) solid;
  border-right: 1px var(--btn-arrow, #fff) solid;
  transform: rotate(45deg);
  transform-origin: center;
}

.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%;
}

.flag {
  background: rgb(130, 117, 180);
  background: linear-gradient(180deg, var(--flag-start) 0%, var(--flag-end) 100%);
  color: var(--flag-color, #fff);
  width: var(--flag-w, 200px);
  height: var(--flag-h, 240px);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 50% calc(100% - var(--flag-cut, 45px)), 0 100%);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(13px, 2.2666666667vmin, 23px);
  line-height: 1.652173913;
}
.flag-text {
  padding-bottom: 15%;
}
.flag-sub {
  font-size: clamp(11px, 1.4666666667vmin, 15px);
}

.text-sub {
  line-height: 1.7142857143;
}
.text-border {
  border-bottom: 1px var(--accent) solid;
}
.text-link {
  color: #b1aadc;
  text-decoration: underline;
}
.text-link:hover {
  text-decoration: none;
  color: var(--accent);
}
.text-xs {
  font-size: var(--size-xs);
}
.text-s {
  font-size: var(--size-s);
}
.text-l {
  font-size: var(--size-l);
}
.text-2l {
  font-size: var(--size-2l);
}
.text-xl {
  font-size: var(--size-xl);
}
.text-2xl {
  font-size: var(--size-2xl);
}
.text-3l {
  font-size: var(--size-3l);
}

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

.list-circle li {
  padding-left: 1.2em;
  text-indent: -1.2em;
}
.list-circle li::before {
  content: "●";
  color: var(--list-marker, var(--primary));
  margin-right: 0.2em;
}
.list-indent li {
  text-indent: -1em;
  padding-left: 1em;
}
.list-decimal {
  padding-left: 1.5em;
}
.list-decimal > li {
  list-style: decimal;
  list-style-position: outside;
}
.list-decimal > li::marker {
  color: var(--list-marker, var(--primary));
  font-weight: bold;
}

.gap-30 {
  gap: 3rem;
}

.accordion-inner {
  overflow: hidden;
  pointer-events: none;
  height: 0;
}
.accordionBtn {
  cursor: pointer;
  position: relative;
}
.accordion-icon {
  background-color: #464646;
  width: 1.0526315789em;
  height: 1px;
  position: absolute;
  right: 0.6em;
  top: 50%;
}
.accordion-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;
}
.accordion-wrap.active .accordion-inner {
  pointer-events: initial;
}
.accordion-wrap.active .accordion-icon::before {
  transform: rotate(0);
}
@media print, screen and (min-width: 768px) {
  .accordion-icon {
    width: 0.7777777778em;
  }
}

.header {
  width: 100%;
  --container: 1730px;
  z-index: 100;
  background-color: var(--header-bg, #fff);
  transition: background-color 0.5s;
  pointer-events: none;
  opacity: 0;
}
.header-logo {
  pointer-events: initial;
  display: flex;
  align-items: center;
  gap: 0 1em;
  line-height: 1;
}
.header-logo a:hover img {
  opacity: 1;
}
.header-logo-sub {
  transition: opacity 0.5s;
  font-size: clamp(11px, 2.5vmin, 16px);
  color: var(--color-nav);
  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 {
    position: fixed;
    top: 0;
    left: 0;
  }
  .header-logo {
    flex-wrap: wrap;
  }
}
.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(--color-nav);
  display: block;
}
@media print, screen and (max-width: 1020px) {
  .nav {
    left: 0;
    bottom: 0;
    background-color: var(--color-nav);
    width: 100%;
    padding-bottom: env(safe-area-inset-bottom);
  }
  .nav-item:nth-of-type(n + 2) {
    border-left: 1px #fff solid;
  }
  .nav-text {
    display: block;
    color: #fff;
    font-size: 2.5vmin;
    margin-top: 1em;
    line-height: 1;
  }
  .nav-link {
    padding: 0.8em 0.1em;
  }
  .nav-icon {
    line-height: 1;
  }
  .nav-icon img {
    height: 5vmin;
    width: auto;
    object-fit: contain;
  }
}
@media print, screen and (min-width: 1021px) {
  .nav {
    right: clamp(15px, 3.125vw, 3.125vw);
    top: 15px;
    line-height: 1.2;
    width: clamp(500px, 50%, 740px);
  }
  .nav-list {
    border-right: 1px var(--color-nav) solid;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
  }
  .nav-item {
    border-left: 1px var(--color-nav) solid;
    display: block;
    width: auto;
  }
  .nav-icon img {
    filter: brightness(0) saturate(100%) invert(60%) sepia(70%) saturate(252%) hue-rotate(195deg) brightness(87%) contrast(91%);
  }
  .nav-link {
    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: #B7D2E3;
  }
  .nav-link:hover img {
    opacity: 1;
    filter: none;
  }
  .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 calc(5em + env(safe-area-inset-bottom));
}
.footer-logo {
  width: 9.7777777778em;
}
.footer-info {
  margin-bottom: 4em;
}
.footer-info-head {
  margin-bottom: 1.5em;
}
.footer-info-btn {
  margin-top: 1em;
}
.footer-info-btn .btn {
  width: 7.625em;
  padding: 0.4em 0.05em;
  background-color: #000;
}
.footer-info-btn .btn-text {
  font-size: 12px;
}
.footer-info-btn .btn:hover {
  color: #000;
  background-color: #fff;
}
@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) and (max-width: 1020px) {
  .footer {
    padding-bottom: calc(13.5% + env(safe-area-inset-bottom));
  }
}
@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: 420px;
  }
  .footer .copy {
    flex-grow: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.5em 1em;
    align-self: flex-end;
    justify-content: 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;
  }
}

@media print, screen and (max-width: 1020px) {
  .gotop {
    margin-top: 2em;
    background-color: #000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5em 1em 0.5em;
  }
  .gotop .arrow {
    width: 1.5em;
    height: 1.5em;
    display: block;
  }
  .gotop .arrow::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    border-top: 1px #fff solid;
    border-right: 1px #fff solid;
    transform: rotate(-45deg);
    transform-origin: center;
  }
}
@media print, screen and (min-width: 1021px) {
  .gotop {
    display: none;
    pointer-events: none;
  }
}

.page-lp .catch {
  position: relative;
  margin-bottom: clamp(2em, 12%, 6em);
  --container: calc(1800% / 19.2);
}
.page-lp .catch-inner {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  z-index: 5;
}
.page-lp .catch-img {
  width: 100%;
  overflow: hidden;
  background: #d9ebef;
}
.page-lp .catch-img img {
  opacity: 0;
  pointer-events: none;
  max-width: none;
  width: 100%;
  height: auto;
}
.page-lp .catch-title {
  font-size: clamp(26px, 6.3533333333vmin, 52.8px);
  line-height: 1.375;
}
.page-lp .catch-title-1 {
  display: block;
}
.page-lp .catch-title-2 {
  display: inline-block;
  vertical-align: middle;
}
.page-lp .catch-sub {
  font-size: clamp(16px, 3.9713333333vmin, 33px);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.25em;
}
.page-lp .catch-sub span {
  flex-shrink: 0;
}
.page-lp .catch-sub::before, .page-lp .catch-sub::after {
  content: "";
  display: block;
  width: 50%;
  height: 1px;
  background-color: #fff;
}
@media print and (orientation: portrait), screen and (max-width: 767px) and (orientation: portrait) {
  .page-lp .catch-img img {
    width: 100%;
  }
  .page-lp .catch-inner {
    padding-top: 5%;
    text-align: center;
    align-items: flex-start;
  }
  .page-lp .catch-text {
    display: inline-block;
  }
  .page-lp .catch-title-en {
    font-size: 10px;
    transform: scale(0.8);
  }
  .page-lp .catch-title-en .scale-09 {
    display: inline-block;
    transform: scale(0.85);
    transform-origin: left center;
  }
  .page-lp .catch-sub {
    margin: 0.6em 0;
  }
}
@media print and (orientation: landscape), screen and (max-width: 767px) and (orientation: landscape) {
  .page-lp .catch-img {
    height: auto;
  }
  .page-lp .catch-img img {
    height: auto;
    width: 100%;
  }
  .page-lp .catch-text {
    display: grid;
    justify-content: flex-start;
  }
  .page-lp .catch-inner {
    padding-top: calc(var(--header-h) + 6.7708333333vw);
    align-items: flex-start;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .catch-inner {
    padding: calc(var(--header-h)) 0;
    align-items: center;
  }
  .page-lp .catch-title {
    font-size: clamp(26px, 3.1760416667vw, 100px);
  }
  .page-lp .catch-title .small {
    font-size: 53.5749426041%;
  }
  .page-lp .catch-title-2 {
    font-size: clamp(24px, 2.7791666667vw, 90px);
  }
  .page-lp .catch-text {
    display: grid;
    justify-content: flex-start;
  }
  .page-lp .catch-sub {
    font-size: clamp(18px, 2.1333333333vw, 32px);
    margin-bottom: 0.25em;
  }
}
.page-lp .catchloaded .catch-img img {
  animation: fade_in var(--catch-duration, 0.1s) 0.01s cubic-bezier(0.4, 0, 0, 1) forwards, blur_in var(--catch-duration, 0.1s) 0.01s cubic-bezier(0.4, 0, 0, 1) forwards;
}
@media print, screen and (min-width: 1021px) {
  .page-lp .catchloaded .catch-img {
    --catch-duration: 1s;
  }
}
.page-lp .style {
  padding-top: 0;
}
.page-lp .style-block {
  background: url(../../images/bg-dot.webp) center bottom no-repeat;
  padding-bottom: clamp(3em, 20%, 12rem);
  margin-bottom: clamp(1.5em, 10%, 10rem);
}
.page-lp .style-block.block-4 {
  margin-bottom: 0;
}
.page-lp .style-img {
  margin-top: clamp(1.5em, 5.5555555556%, 4rem);
}
@media print, screen and (max-width: 767px) {
  .page-lp .style-block {
    background-size: auto 50vw;
  }
}
.page-lp .attraction-block .point {
  position: relative;
  line-height: 1;
  display: flex;
  align-items: center;
}
.page-lp .attraction-block .point-no {
  font-size: clamp(18px, 13.3333333333vmin, 200px);
  flex-shrink: 0;
}
.page-lp .attraction-block-title {
  font-size: clamp(18px, 3vw, 30px);
  line-height: 1.2;
  margin-bottom: 1em;
  padding-top: 1em;
}
@media print, screen and (max-width: 767px) {
  .page-lp .attraction-block {
    padding-left: 9.5238095238%;
    padding-right: 9.5238095238%;
  }
  .page-lp .attraction-block .point {
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    flex-direction: column;
  }
  .page-lp .attraction-block .point-icon {
    width: 2.5em;
    transform: translateX(-50%);
  }
  .page-lp .attraction-block-img {
    margin-top: 1em;
    text-align: center;
  }
  .page-lp .attraction-block:nth-of-type(n + 2) {
    margin-top: 3em;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .attraction-block {
    margin-top: 6rem;
    display: flex;
    align-items: flex-start;
    margin-top: 6rem;
  }
  .page-lp .attraction-block .point {
    width: 22.65625%;
    padding-left: 1em;
    display: flex;
    align-items: center;
    gap: 0.75em;
  }
  .page-lp .attraction-block .point-icon {
    position: absolute;
    left: 0;
    bottom: 100%;
  }
  .page-lp .attraction-block .point-no {
    font-size: clamp(18px, 6.6666666667vw, 100px);
    flex-shrink: 0;
  }
  .page-lp .attraction-block .point::after {
    content: "";
    width: 100%;
    height: 2px;
    background-color: #b3b3b1;
  }
  .page-lp .attraction-block-text {
    width: 44.53125%;
    margin-left: 2.34375%;
    margin-right: 7.8125%;
  }
  .page-lp .attraction-block-title {
    margin-bottom: 1.5em;
  }
  .page-lp .attraction-block-img {
    width: 23.4375%;
  }
}
.page-lp .fields {
  padding-bottom: 0;
}
.page-lp .fields-wrap {
  padding: clamp(2em, 8.6666666667%, 8rem) 0 clamp(1.5em, 10.6666666667%, 8rem);
}
.page-lp .fields-row {
  display: grid;
  gap: 2em 6.6666666667%;
}
.page-lp .fields-title {
  font-size: clamp(18px, 2.8vw, 28px);
  margin: 1em 0 0.6em;
}
@media print and (orientation: portrait), screen and (max-width: 767px) and (orientation: portrait) {
  .page-lp .fields-row {
    padding-left: 9.5238095238%;
    padding-right: 9.5238095238%;
  }
}
@media print and (orientation: landscape), screen and (max-width: 767px) and (orientation: landscape) {
  .page-lp .fields-row {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .fields-row {
    grid-template-columns: repeat(3, 1fr);
    row-gap: 7rem;
  }
}
.page-lp .cta {
  background-color: #bfe0e6;
  position: relative;
}
.page-lp .cta::before {
  content: "";
  width: 100%;
  left: 0;
  top: 0;
  height: 100%;
  background: url(../../images/bg-stripe.webp) center repeat;
  opacity: 0.25;
  position: absolute;
  display: block;
  mix-blend-mode: multiply;
}
.page-lp .cta-title {
  background-color: var(--primary);
  color: #fff;
  text-align: center;
  font-size: clamp(18px, 2.8vmin, 28px);
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.6428571429;
  width: 79.3650793651%;
  margin-left: auto;
  margin-right: auto;
  height: 9.6428571429em;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  padding-bottom: 2em;
}
.page-lp .cta-btns {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.5em clamp(1em, 15.46875%, 198px);
}
.page-lp .cta-btns .btn {
  width: clamp(200px, 70%, 380px);
  font-size: var(--size-btn);
  border-radius: 4rem;
  border: none;
  padding: 1.17em;
}
@media print, screen and (max-width: 767px) {
  .page-lp .cta-btns {
    padding: 2em 0 3em;
  }
  .page-lp .cta-title {
    height: 9.5714285714em;
    width: 17.5892857143em;
    padding-bottom: 3em;
  }
  .page-lp .cta::before {
    background-size: 19px auto;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .cta {
    height: 40rem;
  }
  .page-lp .cta-title {
    width: 17.5714285714em;
    height: 9.5714285714em;
    padding-bottom: 3.5em;
  }
  .page-lp .cta-btns {
    margin-top: -4rem;
  }
}
.page-lp .movie {
  background: url(../../images/bg-stripe2.webp) center bottom no-repeat;
  padding-bottom: clamp(3em, 13.3333333333%, 11rem);
}
.page-lp .movie-wrap {
  max-width: 980px;
  margin: 2em 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;
}
@media print, screen and (max-width: 767px) {
  .page-lp .movie {
    background-size: auto 50vw;
  }
}
.page-lp .course-block {
  margin-top: var(--section-space);
}
.page-lp .course-sub {
  text-align: center;
  position: relative;
  font-size: clamp(18px, 5.5vw, 32px);
  padding-bottom: 0.5em;
  margin-bottom: 1.5em;
}
.page-lp .course-sub::before {
  content: "";
  display: block;
  height: 2px;
  width: 1.75em;
  background-color: var(--primary);
  position: absolute;
  left: calc(50% - 0.875em);
  top: 100%;
}
.page-lp .course-certificate-title {
  font-size: clamp(18px, 5vw, 28px);
  margin-bottom: 0.8em;
}
.page-lp .course-certificate .row {
  justify-content: center;
  gap: 2em 6.25%;
}
.page-lp .course-certificate .col {
  width: 94.4444444444%;
  border: 1px var(--primary) solid;
  padding: 0 7.731092437% 6.7226890756%;
}
.page-lp .course-certificate .col::before {
  content: "";
  display: block;
  width: 3.75em;
  height: 4.5em;
  background-color: var(--primary);
  margin-left: auto;
  margin-right: auto;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 50% calc(100% - 1em), 0 100%);
  margin-bottom: 0.5em;
}
.page-lp .course-certificate .col .img {
  text-align: center;
  margin-top: 2em;
}
.page-lp .course-select-title {
  font-size: clamp(18px, 2.8vw, 28px);
  margin-bottom: 0.8em;
}
.page-lp .course-select .row {
  justify-content: center;
  gap: 2em 6.25%;
}
.page-lp .course-select .col {
  width: 94.4444444444%;
  background-color: #eaf5f6;
  position: relative;
  padding: 7.5630252101% 7.731092437% 6.7226890756%;
}
.page-lp .course-select .col .no {
  font-size: clamp(28px, 11.7333333333vw, 176px);
  line-height: 1;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
}
.page-lp .course-select .col .img {
  text-align: center;
  margin-bottom: 2em;
  position: relative;
}
.page-lp .course-select .col .img-text {
  position: absolute;
  right: 1em;
  bottom: 0.5em;
  background-color: #95ccd5;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 8em;
  height: 8em;
  line-height: 1.2;
  text-align: center;
  border-radius: 50%;
}
.page-lp .course-select .col .img-text .big {
  font-size: 200%;
}
.page-lp .course-curriculum-text {
  font-size: clamp(18px, 2.4vw, 24px);
  margin-bottom: 0.8em;
}
.page-lp .course-curriculum .row {
  gap: 2em 6.25%;
}
.page-lp .course-curriculum .col {
  display: grid;
  grid-template-columns: 40% auto;
  column-gap: 6.6666666667%;
}
.page-lp .course-curriculum .img {
  position: relative;
  overflow: hidden;
}
.page-lp .course-curriculum .img-text {
  background-color: #95ccd5;
  color: #fff;
  clip-path: polygon(0 0, 100% 100%, 100% 0);
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 1.5em;
  padding-bottom: 1.5em;
  width: 4.1111111111em;
  height: 4.1111111111em;
  position: absolute;
  top: -1px;
  right: -1px;
}
.page-lp .course-schedule-title {
  font-size: clamp(18px, 2.8vw, 28px);
  margin-bottom: 0.8em;
}
.page-lp .course-schedule-bg {
  position: relative;
  padding: 2.5em 0;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.page-lp .course-schedule-bg::before {
  height: 100%;
  aspect-ratio: 1/1;
  content: "";
  display: block;
  background-color: #eaf5f6;
  clip-path: circle(50% at 50% 50%);
  top: 0;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
}
.page-lp .course-schedule-bg .inner {
  position: relative;
  z-index: 1;
}
.page-lp .course-fee-bg {
  background-color: #eaf5f6;
  padding: 5.46875%;
}
.page-lp .course-fee-table {
  background-color: #fff;
  width: 100%;
  line-height: 1.5555555556;
}
.page-lp .course-fee-table th {
  background-color: #95ccd5;
  color: #fff;
  vertical-align: middle;
  width: 5.5555555556em;
}
.page-lp .course-fee-table td {
  padding: 0.5em 0.5em;
  padding-left: 1em;
  border: 1px #eaf5f6 solid;
  vertical-align: middle;
}
.page-lp .course-fee-table td:first-of-type {
  width: 6.1111111111em;
}
@media print, screen and (max-width: 767px) {
  .page-lp .course-certificate .row {
    display: flex;
    justify-content: center;
  }
  .page-lp .course-certificate .img {
    width: 75%;
    margin-left: auto;
    margin-right: auto;
  }
  .page-lp .course-certificate .img2 {
    width: 50%;
  }
  .page-lp .course-select .row {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    padding-top: 2em;
    row-gap: 4em;
  }
  .page-lp .course-select .col p {
    margin-bottom: 1em;
  }
  .page-lp .course-select .col .text-xl {
    line-height: 1.4545454545;
  }
  .page-lp .course-select .col .img-text {
    width: 6.2em;
    height: 6.2em;
  }
  .page-lp .course-curriculum .row {
    display: flex;
    flex-wrap: wrap;
  }
  .page-lp .course-schedule p {
    margin-bottom: 1em;
  }
  .page-lp .course-fee .row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .page-lp .course-fee .col {
    width: 100%;
  }
}
@media print and (orientation: portrait), screen and (max-width: 767px) and (orientation: portrait) {
  .page-lp .course-certificate .row {
    flex-wrap: wrap;
  }
  .page-lp .course-select .row {
    flex-wrap: wrap;
    gap: 3em;
  }
  .page-lp .course-fee-table th, .page-lp .course-fee-table td {
    padding-left: 0.25em;
    padding-right: 0.25em;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .course-certificate .col {
    width: 46.875%;
    display: flex;
    flex-direction: column;
    padding: 0 3.90625% 3.125%;
  }
  .page-lp .course-certificate .col p {
    margin-bottom: 2em;
  }
  .page-lp .course-certificate .col .img {
    margin-top: auto;
  }
  .page-lp .course-select .row {
    margin-top: 4em;
  }
  .page-lp .course-select .col {
    width: 46.875%;
    display: flex;
    flex-direction: column;
    padding: 6rem 3.90625% 3.125%;
  }
  .page-lp .course-select .col .no {
    font-size: clamp(28px, 8.8vw, 88px);
  }
  .page-lp .course-select .col p {
    margin-bottom: 1em;
  }
  .page-lp .course-curriculum .row {
    margin-top: 6rem;
    row-gap: 6rem;
  }
  .page-lp .course-curriculum .col {
    width: 46.875%;
  }
  .page-lp .course-schedule-bg {
    padding: 4em 0;
  }
  .page-lp .course-schedule-bg p {
    margin-bottom: 2em;
  }
  .page-lp .course-schedule-bg p:last-of-type {
    margin-bottom: 0;
  }
  .page-lp .course-fee-bg {
    background-color: #eaf5f6;
    padding: 3.90625%;
  }
  .page-lp .course-fee-bg .col {
    width: 46.6101694915%;
  }
  .page-lp .course-fee-table .card-row {
    height: 5.3333333333em;
  }
}
.page-lp .support {
  padding-bottom: 0;
}
.page-lp .support-wrap {
  padding: var(--section-space) var(--container-pad);
}
.page-lp .support-row {
  display: grid;
  grid-template-columns: repeat(var(--grid, 2), 1fr);
  gap: 4em 8.59375%;
}
.page-lp .support-col {
  background-color: #fff;
  position: relative;
  display: flex;
  padding: 3.1746031746%;
  gap: 1em;
  align-items: center;
}
.page-lp .support-head {
  margin-bottom: 1em;
}
.page-lp .support-head .no {
  font-size: clamp(16px, 2.6666666667vmin, 26px);
  margin-left: 0.25em;
}
.page-lp .support-img {
  width: 31.5068493151%;
  flex-shrink: 0;
}
.page-lp .support-text {
  line-height: 1.75;
}
@media print, screen and (max-width: 767px) {
  .page-lp .support-row {
    --grid: 1;
    gap: 2em 4.7619047619%;
  }
  .page-lp .support-img {
    max-width: 120px;
  }
  .page-lp .support-head {
    margin-bottom: 0.5em;
  }
}
@media print, screen and (min-width: 1021px) {
  .page-lp .support {
    --grid: 2;
  }
  .page-lp .support-row {
    gap: 4rem 6.25%;
  }
  .page-lp .support-col {
    padding: 2rem;
    gap: 3rem;
  }
  .page-lp .support-img {
    width: 120px;
  }
}
.page-lp .flow {
  --flow: #95ccd5;
  --flow-text: #61b7c4;
}
.page-lp .flow .link-arrow:hover .td_u {
  text-decoration: none;
}
.page-lp .flow-box {
  border: 1px var(--flow) solid;
  background-color: #fff;
  margin-top: 3rem;
  padding: 1.5em clamp(1em, 3.90625%, 5rem);
}
.page-lp .flow-box.active .flow-head .text {
  opacity: 0;
}
.page-lp .flow-head {
  --flow: #61b7c4;
  font-size: clamp(16px, 4vmin, 22px);
  color: var(--flow-text);
  opacity: 1;
}
.page-lp .flow-head-ic {
  background-color: var(--flow);
  width: 1.2727272727em;
  height: 2px;
  right: 0;
}
.page-lp .flow-head-ic::before {
  background-color: var(--flow);
}
.page-lp .flow-head .text {
  transition: opacity 0.3s ease-in;
}
.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: 4.9090909091em;
  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: 4.9090909091em;
  height: 4.9090909091em;
  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: #d5ebee;
  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-text);
}
.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-text);
  font-size: clamp(14px, 3.5vmin, 20px);
  line-height: 1.7;
  gap: 0 0.25em;
}
.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-text);
  font-size: clamp(14px, 3.5vmin, 20px);
  line-height: 1.7;
  position: relative;
  gap: 0 0.5em;
}
.page-lp .flow-2-or {
  font-size: clamp(18px, 4.5vmin, 24px);
  color: var(--flow-text);
  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: 768px) {
  .page-lp .flow {
    --flag-h:200px;
  }
}
@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-top: 1em;
    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;
    padding-top: 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: #eaf5f6;
}
.page-lp .session-title .big {
  font-size: 128.5714285714%;
}
.page-lp .session-intro {
  font-size: clamp(16px, 4vmin, 24px);
  margin: 0.5em 0 1.5em;
}
.page-lp .session-intro .big {
  font-size: 133.3333333333%;
}
.page-lp .session-point {
  display: flex;
  gap: 1.25em;
  justify-content: center;
  text-align: center;
}
.page-lp .session-point-item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  font-size: clamp(14px, 3.5vmin, 18px);
  line-height: 1.5;
  padding: 0.3em 0.5em 0.6em;
  gap: 0.5em;
}
.page-lp .session-point-item .no {
  font-size: clamp(18px, 4.5vmin, 26px);
  line-height: 1;
}
.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.75em auto 0;
  position: relative;
  max-width: 640px;
  padding-bottom: 1.25em;
}
.page-lp .session-box-head {
  background: url(../../images/ic-ribbon.webp) center no-repeat;
  background-size: contain;
  color: #fff;
  padding: 0.25em 0.5em 1.1em;
  transform: translateY(-1.6em);
  margin-bottom: -0.8em;
}
.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-box-sub {
  margin: 0.5em 0;
}
@media print, screen and (min-width: 768px) {
  .page-lp .session {
    padding-top: 6rem;
  }
  .page-lp .session-point-item {
    min-width: 198px;
  }
}
.page-lp .instructor {
  padding-bottom: 0;
}
.page-lp .instructor-block {
  background-color: #eaf5f6;
  padding: 7.1428571429%;
  position: relative;
}
.page-lp .instructor-img {
  padding: 3.8461538462%;
  background-color: #fff;
}
.page-lp .instructor-head .label {
  background-color: var(--primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  width: 5em;
  height: 5em;
}
.page-lp .instructor-head .name {
  font-size: clamp(22px, 5.5vmin, 32px);
}
@media print, screen and (max-width: 767px) {
  .page-lp .instructor-block {
    margin-top: 4em;
  }
  .page-lp .instructor-head {
    text-align: center;
    padding-top: 2em;
  }
  .page-lp .instructor-head .label {
    position: absolute;
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%);
  }
  .page-lp .instructor-img {
    margin: 1em 9.4339622642% 1.5em;
  }
  .page-lp .instructor-img img {
    width: 100%;
    max-width: none;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .instructor-block {
    display: grid;
    grid-template-areas: "img head" "img text";
    grid-template-columns: 24.375% auto;
    gap: 0 4.21875%;
    margin-bottom: 6rem;
    padding: 3.125%;
  }
  .page-lp .instructor-head {
    display: flex;
    align-items: center;
    gap: 1.2em;
    margin-bottom: 1.5em;
    grid-area: head;
  }
  .page-lp .instructor-img {
    grid-area: img;
    align-self: flex-start;
  }
  .page-lp .instructor-col {
    grid-area: text;
  }
}
.page-lp .voice-row {
  margin-top: 2em;
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 1em 3em;
}
.page-lp .voice-row.inView .voice-col {
  animation: fade_in 0.35s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards, slide_in_y 0.35s var(--delay-anime, 0.15s) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.page-lp .voice-col {
  opacity: 0;
}
.page-lp .voice-col.second {
  --delay-anime: 0.3s;
}
.page-lp .voice-col.third {
  --delay-anime: 0.5s;
}
.page-lp .voice-inner {
  padding: 1em 0 2em;
  height: 100%;
}
.page-lp .voice-detail {
  position: relative;
}
.page-lp .voice-title {
  font-size: clamp(20px, 5.5vmin, 28px);
  line-height: 1.7142857143;
  margin: 1em 0;
}
.page-lp .voice-name .big {
  font-size: clamp(16px, 4.75vmin, 24px);
}
.page-lp .voice-desc {
  padding-top: 1em;
}
.page-lp .voice-item {
  padding-bottom: 1px;
}
@media print, screen and (max-width: 767px) {
  .page-lp .voice-row {
    padding-left: 14.84375%;
    padding-right: 14.84375%;
  }
  .page-lp .voice-img img {
    width: 100%;
    max-width: none;
  }
  .page-lp .voice-title {
    margin-top: 0;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .voice-row {
    flex-direction: row;
    justify-content: space-between;
    gap: 1em;
    align-items: stretch;
    margin-top: 5rem;
  }
  .page-lp .voice-col {
    width: min(33% - 1em, 380px);
  }
  .page-lp .voice-inner {
    padding: 0.1em 0 1.5em;
  }
}
.page-lp .message {
  background-color: #f6f6f6;
  position: relative;
  padding-top: 0;
}
.page-lp .message-catch {
  color: #d9ebef;
  line-height: 0.76;
  font-size: clamp(40px, 16.5333333333vmin, 248px);
}
.page-lp .message-title {
  font-size: clamp(18px, 4.5vmin, 28px);
  margin: 0 0 2em;
}
.page-lp .message-name {
  margin-top: 0.25em;
}
.page-lp .message-name .text-s {
  margin-left: 1em;
}
.page-lp .message-text {
  position: relative;
  z-index: 1;
}
.page-lp .message-desc {
  margin-bottom: 1.5em;
}
@media print, screen and (max-width: 767px) {
  .page-lp .message-img {
    width: 74.0740740741%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2em;
    margin-top: 1.5em;
  }
  .page-lp .message-title {
    margin: 1em 0;
  }
}
@media print, screen and (min-width: 768px) {
  .page-lp .message-row {
    display: grid;
    grid-template-areas: "catch catch" "text img";
    grid-template-columns: auto 31.25%;
    gap: 1em 7.03125%;
  }
  .page-lp .message-catch {
    grid-area: catch;
    font-size: clamp(40px, 14vmin, 140px);
  }
  .page-lp .message-head {
    grid-area: img;
  }
  .page-lp .message-text {
    grid-area: text;
  }
  .page-lp .message-desc {
    max-width: 700px;
    margin-bottom: 3em;
  }
}
/* ==========================================================================
   Step2 面談（PDFベース）追加レイアウト用 CSS
   ========================================================================== */

/* カテゴリ全体のマージン調整 */
.page-lp .flow-2-category {
  margin-bottom: 2em;
}

/* 「見て聞いて...」「すぐに申込みたい方」のラベルスタイル */
.page-lp .flow-2-cat-title {
  font-size: clamp(14px, 3.5vmin, 18px);
  color: #fff;
  background-color: var(--flow-text, #61b7c4); /* ページのテーマカラーを適用 */
  display: inline-block;
  padding: 0.4em 1.2em;
  border-radius: 20px;
  margin-bottom: 1em;
  font-weight: bold;
}

/* グループ2の補足テキスト */
.page-lp .flow-2-sub-text {
  font-size: clamp(14px, 3.5vmin, 16px);
  color: var(--flow-text, #61b7c4);
  font-weight: bold;
  margin-bottom: 1em;
}

/* スマホ・タブレット表示時 (1020px以下) */
@media print, screen and (max-width: 1020px) {
  .page-lp .flow-2-row.is-3col,
  .page-lp .flow-2-row.is-1col {
    display: flex;
    flex-direction: column;
    gap: 1em;
  }
  .page-lp .flow-2-row.is-3col .flow-2-col,
  .page-lp .flow-2-row.is-1col .flow-2-col {
    width: 100%;
    margin-bottom: 0;
  }
  .br-pc {
    display: none; /* PC用の改行を無効化 */
  }
}

/* PC表示 (1021px以上) */
@media print, screen and (min-width: 1021px) {
  .page-lp .flow-2-row.is-3col {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 1em 2%;
  }
  .page-lp .flow-2-row.is-3col .flow-2-col {
    width: 32% !important;
  }

  .page-lp .flow-2-row.is-1col {
    display: flex;
    flex-direction: row;
    justify-content: flex-start; /* 1カラムの場合も左揃え */
  }
  .page-lp .flow-2-row.is-1col .flow-2-col {
    width: 32% !important; /* 3列時の1つ分と同じ幅にする */
  }
  .br-sp {
    display: none; /* スマホ用の改行を無効化 */
  }
}