@charset "UTF-8";
*, ::before, ::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

html {
  block-size: 100%;
  -webkit-text-size-adjust: none;
  font-size: 62.5%;
}

body {
  min-block-size: 100%;
  -webkit-font-smoothing: antialiased;
  line-height: 1;
  text-rendering: optimizeSpeed;
}

:where(canvas, audio, iframe, embed, object, main) {
  display: block;
  max-width: 100%;
}

:where(img, svg, video) {
  block-size: auto;
  max-width: 100%;
  max-inline-size: 100%;
  height: auto;
  vertical-align: bottom;
}

:where(svg) {
  stroke: none;
  fill: currentColor;
}
:where(svg):where(:not([fill])) {
  stroke: currentColor;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
:where(svg):where(:not([width])) {
  inline-size: 5rem;
}

:where(input, button, textarea, select),
:where(input[type=file])::-webkit-file-upload-button {
  color: inherit;
  font: inherit;
  font-size: inherit;
  letter-spacing: inherit;
}

:where(textarea) {
  resize: vertical;
}

:where(a[href], area, button, input, label[for], select, summary, textarea, [tabindex]:not([tabindex*="-"])) {
  cursor: pointer;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}

:where(input[type=file]) {
  cursor: auto;
}

:where(input[type=file])::-webkit-file-upload-button {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
          user-select: none;
  text-align: center;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset]),
:where(input[type=file])::-webkit-file-upload-button,
:where(input[type=file])::file-selector-button {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
          user-select: none;
  text-align: center;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset])[disabled] {
  cursor: not-allowed;
}

:where(:not(:active)):focus-visible {
  outline-offset: 5px;
}

input[class], button[class], textarea[class] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

ul[class], ol[class] {
  list-style: none;
}

:where(h1, h2, h3, h4, h5, h6, p, span, th, td, dt, dd) {
  overflow-wrap: anywhere;
}

table {
  border-collapse: collapse;
}

a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

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

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

em, b, strong {
  background: none;
  font-weight: bold;
  font-style: normal;
}

summary {
  display: block;
  cursor: pointer;
}
summary::-webkit-details-marker {
  display: none;
}

@media (prefers-reduced-motion: no-preference) {
  html:focus-within {
    scroll-behavior: smooth;
  }
}
@supports (resize: block) {
  :where(textarea) {
    resize: block;
  }
}
@media (prefers-reduced-motion: no-preference) {
  :focus-visible {
    -webkit-transition: outline-offset 145ms cubic-bezier(0.25, 0, 0.4, 1);
    transition: outline-offset 145ms cubic-bezier(0.25, 0, 0.4, 1);
  }
  :where(:not(:active)):focus-visible {
    -webkit-transition-duration: 0.25s;
            transition-duration: 0.25s;
  }
}
a {
  color: #2680EB;
  -webkit-transition: ease-in-out 0.3s;
  transition: ease-in-out 0.3s;
}
a:hover {
  opacity: 0.75;
}

input[type=text],
input[type=password],
input[type=tel],
input[type=email],
input[type=num],
textarea {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 8px 12px;
  border: 1px solid #d4d4d4;
  border-radius: 5px;
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
  line-height: 1.3;
}

select {
  padding: 5px 12px;
  border: 1px solid #d4d4d4;
  border-radius: 5px;
  background-color: #fff;
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
  line-height: 1.3;
}

textarea {
  min-height: 90px;
}

.is-gothic {
  font-family: "Noto Sans TC", "Avenir", "Helvetica Neue", "Helvetica", "Arial", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
}
.is-mincho {
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}
.is-lato {
  font-family: "Lato", "Noto Sans TC", sans-serif;
}
.is-bold {
  font-weight: 700 !important;
}
.is-black {
  font-weight: 900 !important;
}
.is-normal {
  font-weight: normal !important;
}
.is-tal {
  text-align: left !important;
}
.is-tac {
  text-align: center !important;
}
.is-tar {
  text-align: right !important;
}
.is-imgfit {
  -o-object-fit: cover;
     object-fit: cover;
  font-family: "object-fit: cover;";
}
.is-fsizeSmallest {
  font-size: clamp(0.7rem, 2.9333333333vw, 1.7rem);
}
.is-fsizeSmaller {
  font-size: clamp(0.8rem, 3.2vw, 1.8rem);
}
.is-fsizeSmall {
  font-size: clamp(0.9rem, 3.4666666667vw, 1.9rem);
}
.is-fsizeNormal {
  font-size: clamp(1rem, 3.7333333333vw, 2rem);
}
.is-fsizeLarge {
  font-size: clamp(1.1rem, 4vw, 2.1rem);
}
.is-fsizeLarger {
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
}
.is-fsizeLargest {
  font-size: clamp(1.4rem, 4.8vw, 2.4rem);
}
.is-fcolorMain {
  color: #CB1B44 !important;
}
.is-fcolorBlack {
  color: #000 !important;
}
.is-nowrap {
  white-space: nowrap;
}
.is-round {
  border-radius: 4px;
}
.is-lineWide {
  line-height: 2;
}

.error {
  color: #c00;
  font-weight: 500;
}

div + br + span.error {
  margin-top: -1em;
  display: block;
}

.c-title {
  font-weight: 700;
  line-height: 1.3;
}
.c-title.-course {
  margin-bottom: 12px;
  font-size: clamp(2.6rem, 8vw, 3.6rem);
}
.c-title.-course .ornament {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  opacity: 0.54;
  color: #CB1B44;
  font-family: "Lato", "Noto Sans TC", sans-serif;
  font-size: clamp(1.1rem, 4vw, 2.1rem);
  font-style: italic;
}
.c-title.-course .ornament::before {
  display: inline-block;
  width: 2.9333333333vw;
  height: 3.2vw;
  content: "";
  margin-right: 8px;
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="13.16" height="14.045" viewBox="0 0 13.16 14.045"><line id="線_19" data-name="線 19" x2="6.5" y2="8" transform="translate(0.805 5.339) rotate(-9)" fill="none" stroke="%23cb1b44" stroke-linecap="round" stroke-width="1"/><line id="線_21" data-name="線 21" x2="4" y2="11" transform="translate(6.755 1.359) rotate(-9)" fill="none" stroke="%23cb1b44" stroke-linecap="round" stroke-width="1"/></svg>') no-repeat center center/contain;
}
.c-title.-course .ornament::after {
  display: inline-block;
  width: 2.9333333333vw;
  height: 3.2vw;
  content: "";
  margin-left: 8px;
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="13.16" height="14.045" viewBox="0 0 13.16 14.045"><line id="線_23" data-name="線 23" y1="8" x2="6.5" transform="translate(11.104 13.24) rotate(-171)" fill="none" stroke="%23cb1b44" stroke-linecap="round" stroke-width="1"/><line id="線_22" data-name="線 22" y1="11" x2="4" transform="translate(4.684 12.223) rotate(-171)" fill="none" stroke="%23cb1b44" stroke-linecap="round" stroke-width="1"/></svg>') no-repeat center center/contain;
}
.c-title.-course .small {
  display: block;
  margin-bottom: 8px;
  font-size: 80%;
  line-height: 1.2;
}
.c-title.-skin01 {
  margin-bottom: 32px;
  font-size: clamp(2rem, 6.4vw, 3rem);
}
.c-title.-skin02 {
  margin-bottom: 8px;
  color: #CB1B44;
  font-size: clamp(1.6rem, 5.3333333333vw, 2.6rem);
}
.c-title.-skin02 ~ .c-title.-skin02 {
  margin-top: 44px;
}
.c-title.-skin03 {
  margin-bottom: 12px;
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
}
.c-title.-skin03 ~ .c-title.-skin03 {
  margin-top: 28px;
}
.c-title.-skin04 {
  margin-bottom: 12px;
  font-size: clamp(1.4rem, 4.8vw, 2.4rem);
}
.c-title.-skin04 ~ .c-title.-skin04 {
  margin-top: 32px;
}
.c-btn {
  display: inline-block;
  min-width: 58.6666666667vw;
  padding: 16px;
  border-radius: 10em;
  background-color: #CB1B44;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(50.5%, transparent), color-stop(50.1%, #a00d2f));
  background-image: linear-gradient(to right, transparent 50.5%, #a00d2f 50.1%);
  background-size: 200% 100%;
  color: #fff;
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
  font-weight: 500;
  line-height: 1.2;
  -webkit-transition: background-position 0.3s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, color 0.5s ease 0s, background-color 0.9s ease;
  transition: background-position 0.3s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, color 0.5s ease 0s, background-color 0.9s ease;
  text-align: center;
  text-decoration: none;
}
.c-btn:hover {
  opacity: 1;
  background-color: #a00d2f;
  background-position: -100% 100%;
}
button.c-btn,
input.c-btn {
  border: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.c-btn.-arrow {
  padding-right: 28px;
  position: relative;
}
.c-btn.-arrow:after {
  position: absolute;
  display: block;
  content: "";
  top: 50%;
  right: 16px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6.069" height="10" viewBox="0 0 6.069 10"><path id="Icon_awesome-chevron-right" data-name="Icon awesome-chevron-right" d="M7.841,8.036l-4.45,4.45a.55.55,0,0,1-.777,0l-.519-.519a.55.55,0,0,1,0-.776L5.62,7.648,2.093,4.1a.55.55,0,0,1,0-.776l.519-.519a.55.55,0,0,1,.777,0l4.45,4.45A.55.55,0,0,1,7.841,8.036Z" transform="translate(-1.933 -2.648)" fill="%23fff"/></svg>') no-repeat center center/contain;
  -webkit-transition: right 0.3s ease-in-out 0.1s;
  transition: right 0.3s ease-in-out 0.1s;
}
.c-btn.-arrow:hover::after {
  right: 12px;
}
.c-btn.-anchor {
  padding-right: 28px;
  position: relative;
}
.c-btn.-anchor:after {
  position: absolute;
  display: block;
  content: "";
  top: 50%;
  right: 16px;
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
  width: 10px;
  height: 10px;
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6.069" height="10" viewBox="0 0 6.069 10"><path id="Icon_awesome-chevron-right" data-name="Icon awesome-chevron-right" d="M7.841,8.036l-4.45,4.45a.55.55,0,0,1-.777,0l-.519-.519a.55.55,0,0,1,0-.776L5.62,7.648,2.093,4.1a.55.55,0,0,1,0-.776l.519-.519a.55.55,0,0,1,.777,0l4.45,4.45A.55.55,0,0,1,7.841,8.036Z" transform="translate(-1.933 -2.648)" fill="%23fff"/></svg>') no-repeat center center/contain;
  -webkit-transition: top 0.3s ease-in-out 0.1s;
  transition: top 0.3s ease-in-out 0.1s;
}
.c-btn.-anchor:hover::after {
  top: calc(50% + 4px);
}
.c-btn.-small {
  min-width: 0;
  padding: 6px 16px;
  font-size: clamp(0.8rem, 3.2vw, 1.8rem);
}
.c-btn.-small.-arrow {
  padding-right: 28px;
}
.c-btn.-small.-arrow::after {
  right: 9px;
}
.c-btn.-small.-arrow:hover::after {
  right: 6px;
}
.c-btn.-small.-anchor {
  padding-right: 28px;
}
.c-btn.-small.-anchor::after {
  right: 9px;
}
.c-btn.-small.-anchor:hover::after {
  top: calc(50% + 2px);
}
.c-btn.-middle {
  min-width: 0;
  padding-top: 8px;
  padding-bottom: 8px;
  font-size: clamp(1rem, 3.7333333333vw, 2rem);
}
.c-btn.-middle.-arrow {
  padding-right: 28px;
}
.c-btn.-middle.-arrow::after {
  right: 9px;
}
.c-btn.-middle.-arrow:hover::after {
  right: 6px;
}
.c-btn.-middle.-anchor {
  padding-right: 28px;
}
.c-btn.-middle.-anchor::after {
  right: 9px;
}
.c-btn.-middle.-anchor:hover::after {
  top: calc(50% + 2px);
}
.c-btn.-back {
  background-color: #E8E8E8;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(50.5%, transparent), color-stop(50.1%, #d8d8d8));
  background-image: linear-gradient(to right, transparent 50.5%, #d8d8d8 50.1%);
  color: #000;
}
.c-btn.-back.-arrow {
  padding-right: 16px;
  padding-left: 28px;
}
.c-btn.-back.-arrow::after {
  left: 16px;
  right: auto;
  -webkit-transform: translateY(-50%) rotate(180deg);
          transform: translateY(-50%) rotate(180deg);
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6.069" height="10" viewBox="0 0 6.069 10"><path id="Icon_awesome-chevron-right" data-name="Icon awesome-chevron-right" d="M7.841,8.036l-4.45,4.45a.55.55,0,0,1-.777,0l-.519-.519a.55.55,0,0,1,0-.776L5.62,7.648,2.093,4.1a.55.55,0,0,1,0-.776l.519-.519a.55.55,0,0,1,.777,0l4.45,4.45A.55.55,0,0,1,7.841,8.036Z" transform="translate(-1.933 -2.648)" fill="%2300"/></svg>') no-repeat center center/contain;
  -webkit-transition: left 0.3s ease-in-out 0.1s;
  transition: left 0.3s ease-in-out 0.1s;
}
.c-btn.-back.-arrow:hover::after {
  left: 12px;
  right: auto;
}
.c-btn.-back:hover {
  background-color: #d8d8d8;
  background-position: -100% 100%;
}
.c-btn[disabled] {
  background-color: #ddd;
  color: #999;
  pointer-events: none;
}
.c-btn[disabled].-arrow::after {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="6.069" height="10" viewBox="0 0 6.069 10"><path id="Icon_awesome-chevron-right" data-name="Icon awesome-chevron-right" d="M7.841,8.036l-4.45,4.45a.55.55,0,0,1-.777,0l-.519-.519a.55.55,0,0,1,0-.776L5.62,7.648,2.093,4.1a.55.55,0,0,1,0-.776l.519-.519a.55.55,0,0,1,.777,0l4.45,4.45A.55.55,0,0,1,7.841,8.036Z" transform="translate(-1.933 -2.648)" fill="%23999"/></svg>');
}
.c-btnWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 20px;
  margin-top: 24px;
}
.c-link.-pdf::after {
  -webkit-transform: translateY(-1.8px);
          transform: translateY(-1.8px);
  display: inline-block;
  content: "";
  width: 0.92em;
  height: 0.92em;
  margin-left: 0.2em;
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="14" viewBox="0 0 12 14"><path id="Icon_metro-file-pdf" data-name="Icon metro-file-pdf" d="M14.039,5.172a1.818,1.818,0,0,1,.375.594,1.8,1.8,0,0,1,.156.688v9a.747.747,0,0,1-.75.75H3.321a.747.747,0,0,1-.75-.75V2.953a.747.747,0,0,1,.75-.75h7a1.8,1.8,0,0,1,.688.156,1.818,1.818,0,0,1,.594.375ZM10.571,3.266V6.2h2.937a.854.854,0,0,0-.172-.32L10.891,3.438a.853.853,0,0,0-.32-.172Zm3,11.938v-8h-3.25a.747.747,0,0,1-.75-.75V3.2h-6v12h10ZM9.555,10.571a5.944,5.944,0,0,0,.656.438,7.752,7.752,0,0,1,.914-.055q1.148,0,1.383.383a.378.378,0,0,1,.016.406.023.023,0,0,1-.008.016l-.016.016v.008q-.047.3-.555.3a3.223,3.223,0,0,1-.9-.156,5.7,5.7,0,0,1-1.016-.414,14.068,14.068,0,0,0-3.063.648Q5.774,14.2,5.079,14.2a.454.454,0,0,1-.219-.055l-.187-.094-.047-.039a.323.323,0,0,1-.047-.281,1.7,1.7,0,0,1,.438-.715,3.776,3.776,0,0,1,1.031-.754.114.114,0,0,1,.18.047.045.045,0,0,1,.016.031q.406-.664.836-1.539a11.924,11.924,0,0,0,.813-2.047,6.315,6.315,0,0,1-.238-1.246,3.038,3.038,0,0,1,.051-1q.086-.312.328-.312H8.2a.329.329,0,0,1,.273.117.624.624,0,0,1,.07.531.169.169,0,0,1-.031.062.2.2,0,0,1,.008.062v.234a10.23,10.23,0,0,1-.109,1.5,3.953,3.953,0,0,0,1.141,1.859Zm-4.5,3.211a3.45,3.45,0,0,0,1.07-1.234,4.454,4.454,0,0,0-.684.656A2.6,2.6,0,0,0,5.055,13.782ZM8.164,6.594a2.323,2.323,0,0,0-.016,1.031q.008-.055.055-.344,0-.023.055-.336a.176.176,0,0,1,.031-.062.023.023,0,0,1-.008-.016.016.016,0,0,0,0-.012.016.016,0,0,1,0-.012.45.45,0,0,0-.1-.281.023.023,0,0,1-.008.016v.016ZM7.2,11.758a11.459,11.459,0,0,1,2.219-.633,1.178,1.178,0,0,1-.1-.074,1.4,1.4,0,0,1-.125-.105A4.138,4.138,0,0,1,8.2,9.571a10.44,10.44,0,0,1-.648,1.539q-.234.438-.352.648Zm5.047-.125a1.87,1.87,0,0,0-1.094-.187,2.955,2.955,0,0,0,.969.219.758.758,0,0,0,.141-.008q0-.008-.016-.023Z" transform="translate(-2.571 -2.203)" fill="%232680EB"/></svg>') no-repeat center center/contain;
  vertical-align: middle;
}
.c-inlineBlock {
  display: inline-block;
}
.c-block.-skin01 {
  padding-top: 20px;
  padding-bottom: 20px;
  border-top: 1px solid #d4d4d4;
  border-bottom: 1px solid #d4d4d4;
}
.c-block.-skin02 {
  padding: 12px 24px;
  border-radius: 10px;
  background-color: #fdf4f6;
}
.c-grid {
  display: grid;
  grid-auto-flow: column;
  gap: 1em;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
}
.c-overflowBox {
  max-height: 100px;
  overflow-y: auto;
  padding: 8px 12px;
  border-radius: 5px;
  border: 1px solid #d4d4d4;
}
.c-list.-disc > li {
  padding-left: 1em;
  line-height: 1.3846153846;
  position: relative;
}
.c-list.-disc > li:before {
  position: absolute;
  display: block;
  content: "";
  top: 0.5em;
  left: 0;
  width: 0.46em;
  height: 0.46em;
  border-radius: 50%;
  background-color: rgba(0, 0, 0, 0.23);
}
.c-list.-disc > li + li {
  margin-top: 8px;
}
.c-list.-circle > li {
  padding-left: 1em;
  line-height: 1.3846153846;
  position: relative;
}
.c-list.-circle > li:before {
  position: absolute;
  display: block;
  content: "";
  top: 0.5em;
  left: 0;
  width: 0.46em;
  height: 0.46em;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.23);
}
.c-list.-circle > li + li {
  margin-top: 8px;
}
.c-list.-note > li {
  padding-left: 1.2em;
  position: relative;
}
.c-list.-note > li:before {
  position: absolute;
  display: block;
  content: "";
  top: 0;
  left: 0;
  content: "※";
}
.c-list.-annotation {
  font-size: clamp(0.8rem, 3.2vw, 1.8rem);
  counter-reset: number;
}
.c-list.-annotation > li {
  padding-left: 2em;
  position: relative;
}
.c-list.-annotation > li:before {
  position: absolute;
  display: block;
  content: "";
  top: 0;
  left: 0;
  content: "※" counter(number);
  counter-increment: number;
}
.c-list.-num {
  counter-reset: num;
}
.c-list.-num > li {
  padding-left: 1.5em;
  position: relative;
}
.c-list.-num > li:before {
  position: absolute;
  display: block;
  content: "";
  top: 0;
  left: 0;
  content: counter(num) ".";
  counter-increment: num;
}
.c-list.-detail > dt {
  font-weight: 700;
}
.c-list.-detail > dt ~ dt {
  margin-top: 4px;
}
.c-list.-detail > dd {
  font-size: clamp(0.9rem, 3.4666666667vw, 1.9rem);
}
.c-list.-detail02 > dt {
  margin-bottom: 4px;
  font-weight: 700;
}
.c-list.-detail02 > dt ~ dt {
  margin-top: 15px;
}
.c-list.-horizontal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.c-list.-horizontal > li:not(:last-child)::after {
  display: inline-block;
  content: "/";
  margin: 0 2px;
}
.c-list .c-list {
  margin-top: 8px;
}
.c-table {
  width: 100%;
  margin: 8px 0;
  border-top: 1px solid #d4d4d4;
}
.c-table th, .c-table td {
  padding: 8px 4px;
  line-height: 1.25;
  text-align: center;
}
.c-table tr {
  border-bottom: 1px solid #d4d4d4;
}
.c-table th {
  background-color: rgba(0, 0, 0, 0.03);
  font-weight: normal;
}
.c-label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}
.c-label.-require {
  display: inline-block;
  margin-left: 6px;
  padding: 3px 8px;
  border-radius: 10em;
  background-color: #DC3545;
  color: #fff;
  font-size: clamp(0.8rem, 3.2vw, 1.8rem);
  font-weight: 500;
  line-height: 1.2;
  text-align: center;
}
.c-label__text {
  font-weight: 500;
}
.c-label__input {
  width: 100%;
  margin-top: 8px;
}
.c-label.-text .c-label__input {
  margin-top: 8px;
}
.c-label.-text input {
  width: 100%;
}
.c-label.-select {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}
.c-label.-radio {
  display: block;
  margin-top: 6px;
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
}
.c-label.-radio input {
  -webkit-transform: scale(1.18);
          transform: scale(1.18);
  margin-right: 4px;
}
.c-label.-checkbox {
  display: inline-block;
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
  font-weight: 500;
}
.c-label.-checkbox input {
  -webkit-transform: scale(1.18);
          transform: scale(1.18);
  margin-right: 4px;
}
.c-label.is-fsizeNormal {
  font-size: clamp(1rem, 3.7333333333vw, 2rem);
}
.c-mt0 {
  margin-top: 0px !important;
}
.c-mr0 {
  margin-right: 0px !important;
}
.c-mb0 {
  margin-bottom: 0px !important;
}
.c-ml0 {
  margin-left: 0px !important;
}
.c-pt0 {
  padding-top: 0px !important;
}
.c-pr0 {
  padding-right: 0px !important;
}
.c-pb0 {
  padding-bottom: 0px !important;
}
.c-pl0 {
  padding-left: 0px !important;
}
.c-mt5 {
  margin-top: 5px !important;
}
.c-mr5 {
  margin-right: 5px !important;
}
.c-mb5 {
  margin-bottom: 5px !important;
}
.c-ml5 {
  margin-left: 5px !important;
}
.c-pt5 {
  padding-top: 5px !important;
}
.c-pr5 {
  padding-right: 5px !important;
}
.c-pb5 {
  padding-bottom: 5px !important;
}
.c-pl5 {
  padding-left: 5px !important;
}
.c-mt10 {
  margin-top: 10px !important;
}
.c-mr10 {
  margin-right: 10px !important;
}
.c-mb10 {
  margin-bottom: 10px !important;
}
.c-ml10 {
  margin-left: 10px !important;
}
.c-pt10 {
  padding-top: 10px !important;
}
.c-pr10 {
  padding-right: 10px !important;
}
.c-pb10 {
  padding-bottom: 10px !important;
}
.c-pl10 {
  padding-left: 10px !important;
}
.c-mt15 {
  margin-top: 15px !important;
}
.c-mr15 {
  margin-right: 15px !important;
}
.c-mb15 {
  margin-bottom: 15px !important;
}
.c-ml15 {
  margin-left: 15px !important;
}
.c-pt15 {
  padding-top: 15px !important;
}
.c-pr15 {
  padding-right: 15px !important;
}
.c-pb15 {
  padding-bottom: 15px !important;
}
.c-pl15 {
  padding-left: 15px !important;
}
.c-mt20 {
  margin-top: 20px !important;
}
.c-mr20 {
  margin-right: 20px !important;
}
.c-mb20 {
  margin-bottom: 20px !important;
}
.c-ml20 {
  margin-left: 20px !important;
}
.c-pt20 {
  padding-top: 20px !important;
}
.c-pr20 {
  padding-right: 20px !important;
}
.c-pb20 {
  padding-bottom: 20px !important;
}
.c-pl20 {
  padding-left: 20px !important;
}
.c-mt25 {
  margin-top: 25px !important;
}
.c-mr25 {
  margin-right: 25px !important;
}
.c-mb25 {
  margin-bottom: 25px !important;
}
.c-ml25 {
  margin-left: 25px !important;
}
.c-pt25 {
  padding-top: 25px !important;
}
.c-pr25 {
  padding-right: 25px !important;
}
.c-pb25 {
  padding-bottom: 25px !important;
}
.c-pl25 {
  padding-left: 25px !important;
}
.c-mt30 {
  margin-top: 30px !important;
}
.c-mr30 {
  margin-right: 30px !important;
}
.c-mb30 {
  margin-bottom: 30px !important;
}
.c-ml30 {
  margin-left: 30px !important;
}
.c-pt30 {
  padding-top: 30px !important;
}
.c-pr30 {
  padding-right: 30px !important;
}
.c-pb30 {
  padding-bottom: 30px !important;
}
.c-pl30 {
  padding-left: 30px !important;
}
.c-mt35 {
  margin-top: 35px !important;
}
.c-mr35 {
  margin-right: 35px !important;
}
.c-mb35 {
  margin-bottom: 35px !important;
}
.c-ml35 {
  margin-left: 35px !important;
}
.c-pt35 {
  padding-top: 35px !important;
}
.c-pr35 {
  padding-right: 35px !important;
}
.c-pb35 {
  padding-bottom: 35px !important;
}
.c-pl35 {
  padding-left: 35px !important;
}
.c-mt40 {
  margin-top: 40px !important;
}
.c-mr40 {
  margin-right: 40px !important;
}
.c-mb40 {
  margin-bottom: 40px !important;
}
.c-ml40 {
  margin-left: 40px !important;
}
.c-pt40 {
  padding-top: 40px !important;
}
.c-pr40 {
  padding-right: 40px !important;
}
.c-pb40 {
  padding-bottom: 40px !important;
}
.c-pl40 {
  padding-left: 40px !important;
}
.c-mt45 {
  margin-top: 45px !important;
}
.c-mr45 {
  margin-right: 45px !important;
}
.c-mb45 {
  margin-bottom: 45px !important;
}
.c-ml45 {
  margin-left: 45px !important;
}
.c-pt45 {
  padding-top: 45px !important;
}
.c-pr45 {
  padding-right: 45px !important;
}
.c-pb45 {
  padding-bottom: 45px !important;
}
.c-pl45 {
  padding-left: 45px !important;
}
.c-mt50 {
  margin-top: 50px !important;
}
.c-mr50 {
  margin-right: 50px !important;
}
.c-mb50 {
  margin-bottom: 50px !important;
}
.c-ml50 {
  margin-left: 50px !important;
}
.c-pt50 {
  padding-top: 50px !important;
}
.c-pr50 {
  padding-right: 50px !important;
}
.c-pb50 {
  padding-bottom: 50px !important;
}
.c-pl50 {
  padding-left: 50px !important;
}
.c-mt55 {
  margin-top: 55px !important;
}
.c-mr55 {
  margin-right: 55px !important;
}
.c-mb55 {
  margin-bottom: 55px !important;
}
.c-ml55 {
  margin-left: 55px !important;
}
.c-pt55 {
  padding-top: 55px !important;
}
.c-pr55 {
  padding-right: 55px !important;
}
.c-pb55 {
  padding-bottom: 55px !important;
}
.c-pl55 {
  padding-left: 55px !important;
}
.c-mt60 {
  margin-top: 60px !important;
}
.c-mr60 {
  margin-right: 60px !important;
}
.c-mb60 {
  margin-bottom: 60px !important;
}
.c-ml60 {
  margin-left: 60px !important;
}
.c-pt60 {
  padding-top: 60px !important;
}
.c-pr60 {
  padding-right: 60px !important;
}
.c-pb60 {
  padding-bottom: 60px !important;
}
.c-pl60 {
  padding-left: 60px !important;
}
.c-w0 {
  width: 0% !important;
}
.c-w5 {
  width: 5% !important;
}
.c-w10 {
  width: 10% !important;
}
.c-w15 {
  width: 15% !important;
}
.c-w20 {
  width: 20% !important;
}
.c-w25 {
  width: 25% !important;
}
.c-w30 {
  width: 30% !important;
}
.c-w35 {
  width: 35% !important;
}
.c-w40 {
  width: 40% !important;
}
.c-w45 {
  width: 45% !important;
}
.c-w50 {
  width: 50% !important;
}
.c-w55 {
  width: 55% !important;
}
.c-w60 {
  width: 60% !important;
}
.c-w65 {
  width: 65% !important;
}
.c-w70 {
  width: 70% !important;
}
.c-w75 {
  width: 75% !important;
}
.c-w80 {
  width: 80% !important;
}
.c-w85 {
  width: 85% !important;
}
.c-w90 {
  width: 90% !important;
}
.c-w95 {
  width: 95% !important;
}
.c-w100 {
  width: 100% !important;
}
.c-wFit {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

:where([class*=icon-]:not(.icon-blank)) svg, :where([class*=icon-]:not(.icon-blank)) path, :where([class*=icon-]:not(.icon-blank)) fill, :where([class*=icon-]:not(.icon-blank)) stroke {
  -webkit-transition: ease-in-out 0.3s;
  transition: ease-in-out 0.3s;
}
:where([class*=icon-]:not(.icon-blank))::before {
  display: inline-block;
  content: "";
  width: 1em;
  height: 1em;
  margin-right: 0.3em;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  vertical-align: middle;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}

.icon-blank svg, .icon-blank path, .icon-blank fill, .icon-blank stroke {
  -webkit-transition: ease-in-out 0.3s;
  transition: ease-in-out 0.3s;
}
.icon-blank::after {
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-left: 0.3em;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="13" height="13" viewBox="0 0 13 13">  <path id="パス_263" data-name="パス 263" d="M13.375,2H6.858A1.6,1.6,0,0,0,5.25,3.609v6.516A1.63,1.63,0,0,0,6.875,11.75h6.5A1.63,1.63,0,0,0,15,10.125v-6.5A1.63,1.63,0,0,0,13.375,2Zm0,8.125h-6.5v-6.5h6.5ZM3.625,8.5H2v4.875A1.63,1.63,0,0,0,3.625,15H8.5V13.375H3.625Z" transform="translate(-2 -2)" fill="%23fff"/></svg>');
}
.icon-home::before {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="30" height="33" viewBox="0 0 30 33"><g id="Icon_feather-home" data-name="Icon feather-home" transform="translate(-3 -1.5)"> <path id="パス_264" data-name="パス 264" d="M4.5,13.5,18,3,31.5,13.5V30a3,3,0,0,1-3,3H7.5a3,3,0,0,1-3-3Z" fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="3"/><path id="パス_265" data-name="パス 265" d="M13.5,33V18h9V33" fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="3"/></g></svg>');
}
.icon-mail::before {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="23.185" height="18.32" viewBox="0 0 23.185 18.32"><g id="Icon_feather-mail" data-name="Icon feather-mail" transform="translate(1.393 1)"><path id="パス_236" data-name="パス 236" d="M5.04,6H21.36A2.046,2.046,0,0,1,23.4,8.04V20.28a2.046,2.046,0,0,1-2.04,2.04H5.04A2.046,2.046,0,0,1,3,20.28V8.04A2.046,2.046,0,0,1,5.04,6Z" transform="translate(-3 -6)" fill="none" stroke="%23fff" stroke-linecap="round" stroke-linejoin="round" stroke-width="2"/><path id="パス_237" data-name="パス 237" d="M23.4,9,13.2,16.14,3,9" transform="translate(-3 -6.96)" fill="none" stroke="%23fff" stroke-linecap="round" stroke-linejoin="round" stroke-width="2"/></g></svg>');
}
.icon-pagetop::before {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16.424" height="19.125" viewBox="0 0 16.424 19.125"><path id="arrow-up" d="M16.028,41.155a1.365,1.365,0,0,1-1.934,0L9.586,36.651V49.77a1.327,1.327,0,0,1-1.33,1.33,1.394,1.394,0,0,1-1.407-1.33V36.651l-4.507,4.5A1.369,1.369,0,1,1,.406,39.22L7.25,32.376a1.368,1.368,0,0,1,1.935,0l6.844,6.844A1.369,1.369,0,0,1,16.028,41.155Z" transform="translate(-0.005 -31.975)" fill="%23fff"/></svg>');
}
.icon-pdf::before {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="14" viewBox="0 0 12 14"><path id="Icon_metro-file-pdf" data-name="Icon metro-file-pdf" d="M14.039,5.172a1.818,1.818,0,0,1,.375.594,1.8,1.8,0,0,1,.156.688v9a.747.747,0,0,1-.75.75H3.321a.747.747,0,0,1-.75-.75V2.953a.747.747,0,0,1,.75-.75h7a1.8,1.8,0,0,1,.688.156,1.818,1.818,0,0,1,.594.375ZM10.571,3.266V6.2h2.937a.854.854,0,0,0-.172-.32L10.891,3.438a.853.853,0,0,0-.32-.172Zm3,11.938v-8h-3.25a.747.747,0,0,1-.75-.75V3.2h-6v12h10ZM9.555,10.571a5.944,5.944,0,0,0,.656.438,7.752,7.752,0,0,1,.914-.055q1.148,0,1.383.383a.378.378,0,0,1,.016.406.023.023,0,0,1-.008.016l-.016.016v.008q-.047.3-.555.3a3.223,3.223,0,0,1-.9-.156,5.7,5.7,0,0,1-1.016-.414,14.068,14.068,0,0,0-3.063.648Q5.774,14.2,5.079,14.2a.454.454,0,0,1-.219-.055l-.187-.094-.047-.039a.323.323,0,0,1-.047-.281,1.7,1.7,0,0,1,.438-.715,3.776,3.776,0,0,1,1.031-.754.114.114,0,0,1,.18.047.045.045,0,0,1,.016.031q.406-.664.836-1.539a11.924,11.924,0,0,0,.813-2.047,6.315,6.315,0,0,1-.238-1.246,3.038,3.038,0,0,1,.051-1q.086-.312.328-.312H8.2a.329.329,0,0,1,.273.117.624.624,0,0,1,.07.531.169.169,0,0,1-.031.062.2.2,0,0,1,.008.062v.234a10.23,10.23,0,0,1-.109,1.5,3.953,3.953,0,0,0,1.141,1.859Zm-4.5,3.211a3.45,3.45,0,0,0,1.07-1.234,4.454,4.454,0,0,0-.684.656A2.6,2.6,0,0,0,5.055,13.782ZM8.164,6.594a2.323,2.323,0,0,0-.016,1.031q.008-.055.055-.344,0-.023.055-.336a.176.176,0,0,1,.031-.062.023.023,0,0,1-.008-.016.016.016,0,0,0,0-.012.016.016,0,0,1,0-.012.45.45,0,0,0-.1-.281.023.023,0,0,1-.008.016v.016ZM7.2,11.758a11.459,11.459,0,0,1,2.219-.633,1.178,1.178,0,0,1-.1-.074,1.4,1.4,0,0,1-.125-.105A4.138,4.138,0,0,1,8.2,9.571a10.44,10.44,0,0,1-.648,1.539q-.234.438-.352.648Zm5.047-.125a1.87,1.87,0,0,0-1.094-.187,2.955,2.955,0,0,0,.969.219.758.758,0,0,0,.141-.008q0-.008-.016-.023Z" transform="translate(-2.571 -2.203)" fill="%23000"/></svg>');
}
.icon-tel::before {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="8.909" height="14" viewBox="0 0 8.909 14">  <path id="Icon_material-smartphone" data-name="Icon material-smartphone" d="M15.136,1.506,8.773,1.5A1.276,1.276,0,0,0,7.5,2.773V14.227A1.276,1.276,0,0,0,8.773,15.5h6.364a1.276,1.276,0,0,0,1.273-1.273V2.773a1.271,1.271,0,0,0-1.273-1.266Zm0,11.448H8.773V4.045h6.364Z" transform="translate(-7.5 -1.5)" fill="%23cb1b44" opacity="0.5"/></svg>') no-repeat center center/contain;
}
.icon-time::before {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="13" height="13" viewBox="0 0 13 13">  <path id="Icon_material-access-time" data-name="Icon material-access-time" d="M9.494,3A6.5,6.5,0,1,0,16,9.5,6.5,6.5,0,0,0,9.494,3ZM9.5,14.7a5.2,5.2,0,1,1,5.2-5.2A5.2,5.2,0,0,1,9.5,14.7Zm.325-8.45H8.85v3.9L12.262,12.2l.488-.8L9.825,9.663Z" transform="translate(-3 -3)" fill="%23cb1b44" opacity="0.5"/></svg>') no-repeat center center/contain;
}
.icon-map::before {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="10.5" height="14" viewBox="0 0 10.5 14">  <path id="Icon_awesome-map-marker-alt" data-name="Icon awesome-map-marker-alt" d="M4.71,13.718C.737,7.958,0,7.367,0,5.25a5.25,5.25,0,0,1,10.5,0c0,2.117-.737,2.708-4.71,8.468a.657.657,0,0,1-1.079,0Zm.54-6.28A2.187,2.187,0,1,0,3.062,5.25,2.187,2.187,0,0,0,5.25,7.437Z" fill="%23cb1b44" opacity="0.5"/></svg>') no-repeat center center/contain;
}
.icon-url::before {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="13" height="13" viewBox="0 0 13 13">  <path id="Icon_awesome-link" data-name="Icon awesome-link" d="M8.293,4.707A3.857,3.857,0,0,1,8.3,10.156l-.009.009L6.587,11.871A3.859,3.859,0,0,1,1.129,6.413l.942-.942a.406.406,0,0,1,.693.269A4.679,4.679,0,0,0,3.01,7.079a.409.409,0,0,1-.1.422l-.332.332a1.828,1.828,0,1,0,2.569,2.6L6.857,8.729a1.828,1.828,0,0,0,0-2.586,1.9,1.9,0,0,0-.263-.218.407.407,0,0,1-.176-.32,1.011,1.011,0,0,1,.3-.757l.535-.535a.408.408,0,0,1,.523-.044,3.872,3.872,0,0,1,.521.437Zm3.578-3.579a3.864,3.864,0,0,0-5.458,0L4.707,2.835,4.7,2.844a3.86,3.86,0,0,0,.53,5.885.408.408,0,0,0,.523-.044l.535-.535a1.011,1.011,0,0,0,.3-.757.407.407,0,0,0-.176-.32,1.9,1.9,0,0,1-.263-.218,1.828,1.828,0,0,1,0-2.586L7.85,2.565a1.828,1.828,0,1,1,2.569,2.6l-.332.332a.409.409,0,0,0-.1.422,4.679,4.679,0,0,1,.246,1.339.406.406,0,0,0,.693.269l.942-.942a3.863,3.863,0,0,0,0-5.458Z" transform="translate(0 0)" fill="%23cb1b44" opacity="0.5"/></svg>') no-repeat center center/contain;
}
.icon-calendar::before {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12.25" height="14" viewBox="0 0 12.25 14">  <path id="Icon_awesome-calendar-check" data-name="Icon awesome-calendar-check" d="M11.922,4.375H.328A.328.328,0,0,1,0,4.047V3.063A1.312,1.312,0,0,1,1.313,1.75H2.625V.328A.328.328,0,0,1,2.953,0H4.047a.328.328,0,0,1,.328.328V1.75h3.5V.328A.328.328,0,0,1,8.2,0H9.3a.328.328,0,0,1,.328.328V1.75h1.313A1.312,1.312,0,0,1,12.25,3.063v.984A.328.328,0,0,1,11.922,4.375ZM.328,5.25H11.922a.328.328,0,0,1,.328.328v7.109A1.312,1.312,0,0,1,10.938,14H1.313A1.312,1.312,0,0,1,0,12.688V5.578A.328.328,0,0,1,.328,5.25ZM9.442,7.874,8.671,7.1a.328.328,0,0,0-.464,0l-2.9,2.876L4.051,8.7a.328.328,0,0,0-.464,0l-.776.77a.328.328,0,0,0,0,.464l2.259,2.277a.328.328,0,0,0,.464,0L9.44,8.338a.328.328,0,0,0,0-.464Z" fill="%23cb1b44" opacity="0.5"/></svg>') no-repeat center center/contain;
}

.l-layer {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: none;
  z-index: 999;
  background-color: rgba(0, 0, 0, 0.6);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
          backdrop-filter: saturate(180%) blur(20px);
}
.l-container {
  display: grid;
  grid-auto-flow: column;
  grid-template-rows: 1fr auto;
  min-height: 100vh;
  overflow-x: hidden;
  font-family: "Noto Sans TC", "Avenir", "Helvetica Neue", "Helvetica", "Arial", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
  font-weight: 400;
  color: #000;
  font-size: clamp(1rem, 3.7333333333vw, 2rem);
  line-height: 1.5;
}
.l-wrapper {
  padding-left: 6.4vw;
  padding-right: 6.4vw;
}
.l-header {
  position: relative;
  z-index: 998;
  padding: 12px 12px 0 22px;
  height: 60px;
  background-color: #CB1B44;
  -webkit-transition: ease-in-out 0.3s;
  transition: ease-in-out 0.3s;
}
.is-navOpen .l-header {
  background-color: transparent;
}
.l-nav {
  border-top: 1px solid #d4d4d4;
}
.l-nav a {
  display: block;
  padding: 2.1333333333vw 1.6vw;
  color: #000;
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
  text-decoration: none;
}
.l-nav > li {
  border-bottom: 1px solid #d4d4d4;
}
.l-nav__sub {
  margin-left: 1.2em;
  margin-bottom: 0.5em;
}
.l-nav__sub a {
  padding: 1.0666666667vw 0.8vw;
}
.l-nav__sub > li {
  padding-left: 1em;
  position: relative;
}
.l-nav__sub > li:before {
  position: absolute;
  display: block;
  content: "";
  top: 0;
  left: 0;
  bottom: 0;
  content: "";
  width: 0.6em;
  border-left: 1px solid #d4d4d4;
  background-image: linear-gradient(to bottom, transparent 50%, #d4d4d4 50%, #d4d4d4 calc(50% + 1px), transparent calc(50% + 1px));
}
.l-nav__sub > li:last-child::before {
  bottom: 45%;
  background: none;
  border-bottom: 1px solid #d4d4d4;
}
.l-main {
  position: relative;
}
.l-footer {
  position: relative;
  z-index: 1;
  padding: 28px 6.4vw 78px;
  background-color: #2D2D2D;
  color: #fff;
  text-align: center;
}
.l-footer__pagetop {
  position: absolute;
  top: -32px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  height: 32px;
  overflow: hidden;
}
.l-footer__pagetopBtn {
  display: block;
  z-index: -1;
  width: 118px;
  height: 118px;
  padding-top: 4px;
  border-radius: 50%;
  background-color: #2D2D2D;
  font-size: 20px;
}
.l-footer__pagetopBtn::before {
  margin-right: 0;
}
.l-footer__pagetopBtn:hover {
  opacity: 1;
  padding-top: 2px;
}
.l-footer__logo {
  font-size: clamp(1.3rem, 4.5333333333vw, 2.3rem);
  font-weight: 700;
}
.l-footer__copy {
  margin-top: 12px;
  color: rgba(255, 255, 255, 0.27);
  font-size: clamp(0.6rem, 2.6666666667vw, 1.6rem);
}
.l-footer__fixed {
  position: fixed;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 900;
  display: none;
}
.l-footer__fixedBtn {
  display: block;
  min-width: 0;
  border-radius: 0;
  padding: 12px 6.4vw;
  font-size: clamp(1.4rem, 4.8vw, 2.4rem);
}
.l-footer__fixedBtn::before {
  -webkit-transform: scale(1.1) translateY(-2px);
          transform: scale(1.1) translateY(-2px);
}

.p-contact .l-footer__fixed, .p-shortForm .l-footer__fixed, .p-longForm .l-footer__fixed {
  display: none !important;
}
.p-contact .l-footer, .p-shortForm .l-footer, .p-longForm .l-footer {
  padding-bottom: 28px;
}

:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h2,
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h3,
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h4,
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h5,
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h6 {
  margin-top: 16px;
}
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + p {
  margin-top: 0.9em;
}

.mv-wrap {
  position: relative;
  height: 100svh;
  width: 100vw;
}
.mv-wrap .is-imgfit {
  width: 100%;
  height: 100%;
}
.mv-wrap .slick-slide {
  width: 100vw;
  height: 100svh;
}
.mv-wrap .slick-dots {
  position: absolute;
  inset: auto 0 0 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 1px;
  line-height: 0;
}
.mv-wrap .slick-dots > li {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.mv-wrap .slick-dots .slick-active button::before {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transition: -webkit-transform 7.3s ease-in-out;
  transition: -webkit-transform 7.3s ease-in-out;
  transition: transform 7.3s ease-in-out;
  transition: transform 7.3s ease-in-out, -webkit-transform 7.3s ease-in-out;
}
.mv-wrap .slick-dots button {
  position: relative;
  width: 100%;
  height: 6px;
  border: 0;
  background-color: rgba(255, 255, 255, 0.4);
  font-size: 0;
  color: transparent;
  line-height: 0;
}
.mv-wrap .slick-dots button::before {
  position: absolute;
  inset: 0;
  display: block;
  content: "";
  background-color: rgba(255, 255, 255, 0.8);
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transition: none;
  transition: none;
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.mv-title {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-content: center;
  color: #fff;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
  font-size: clamp(5.6rem, 16vw, 6.6rem);
  line-height: 1.2;
  text-align: center;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.mv-title .small {
  margin-top: 12px;
  font-size: clamp(2rem, 6.4vw, 3rem);
}

.top-course {
  padding-top: 40px;
  padding-bottom: 64px;
}
.top-course:nth-child(even) {
  background-color: #fdf4f6;
}
.top-course:last-child {
  padding-bottom: 115px;
}
.top-course__title {
  padding-left: 6.4vw;
  padding-right: 6.4vw;
  color: #CB1B44;
  text-align: center;
}
.top-course__image {
  position: relative;
}
.top-course__image .is-imgfit {
  width: 100%;
  height: 100%;
}
.top-course__catch {
  position: absolute;
  bottom: calc(6.6666666667vw + 58px);
  left: 8.5333333333vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 5px;
}
.top-course__catch .text {
  padding: 1px 10px 2px;
  background-color: #fff;
  font-size: clamp(2.2rem, 6.9333333333vw, 3.2rem);
  font-weight: 700;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  -webkit-transition: -webkit-clip-path 0.6s ease-in-out;
  transition: -webkit-clip-path 0.6s ease-in-out;
  transition: clip-path 0.6s ease-in-out;
  transition: clip-path 0.6s ease-in-out, -webkit-clip-path 0.6s ease-in-out;
}
.top-course__btn {
  opacity: 0;
  margin-top: -25px;
  text-align: center;
  -webkit-transition: opacity 0.4s ease-in-out;
  transition: opacity 0.4s ease-in-out;
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
.top-course.is-view .top-course__catch .text {
  -webkit-clip-path: inset(0 0 0 0);
          clip-path: inset(0 0 0 0);
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
.top-course.is-view .top-course__catch .text + .text {
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}
.top-course.is-view .top-course__btn {
  opacity: 1;
}

.page-header {
  position: absolute;
  inset: 0 0 auto 0;
  z-index: 997;
  border-bottom: 1px solid rgba(112, 112, 112, 0.3);
  background-color: #fff;
  -webkit-transition: ease-in-out 0.3s;
  transition: ease-in-out 0.3s;
}
.page-header .l-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 40px;
}
.page-header__title {
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
}
.is-scroll .page-header {
  position: fixed;
}
.is-triggerShow .page-header {
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
}
.page-body {
  padding-top: 72px;
  padding-bottom: 115px;
}
.page-wrap {
  padding-top: 40px;
  padding-bottom: 115px;
}

.introduction-wrap {
  margin-bottom: 60px;
}
.introduction-title {
  margin-bottom: 16px;
  font-size: clamp(3.2rem, 9.6vw, 4.2rem);
  font-weight: 700;
  line-height: 1.2777777778;
  text-align: center;
}
.introduction-subtitle {
  margin-bottom: 12px;
  font-size: clamp(2.4rem, 7.4666666667vw, 3.4rem);
  font-weight: 700;
  line-height: 1.2777777778;
  text-align: center;
}
.introduction-image {
  margin-bottom: 36px;
}

.summary-course {
  padding-bottom: 36px;
}
.summary-course:nth-child(even) {
  background-color: #fdf4f6;
}
.summary-course__title {
  padding-left: 6.4vw;
  padding-right: 6.4vw;
  color: #CB1B44;
  text-align: center;
}
.summary-course__image {
  position: relative;
}
.summary-course__image .is-imgfit {
  width: 100%;
  height: 100%;
}
.summary-course__catch {
  position: absolute;
  bottom: 6.4vw;
  left: 6.4vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 5px;
}
.summary-course__catch .text {
  padding: 1px 10px 2px;
  background-color: #fff;
  font-size: clamp(2rem, 6.4vw, 3rem);
  font-weight: 700;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  -webkit-transition: -webkit-clip-path 0.6s ease-in-out;
  transition: -webkit-clip-path 0.6s ease-in-out;
  transition: clip-path 0.6s ease-in-out;
  transition: clip-path 0.6s ease-in-out, -webkit-clip-path 0.6s ease-in-out;
}
.summary-course__text {
  opacity: 0;
  padding: 3.2vw 6.4vw 0;
  -webkit-transition: opacity 0.4s ease-in-out;
  transition: opacity 0.4s ease-in-out;
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
.summary-course__text p {
  font-weight: 500;
}
.summary-course__btn {
  margin-top: 24px;
  text-align: center;
}
.summary-course.is-view .summary-course__catch .text {
  -webkit-clip-path: inset(0 0 0 0);
          clip-path: inset(0 0 0 0);
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
.summary-course.is-view .summary-course__catch .text + .text {
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}
.summary-course.is-view .summary-course__text {
  opacity: 1;
}

.point-wrap {
  padding-top: 48px;
  padding-bottom: 48px;
}
.point-title {
  margin-bottom: 8px;
  font-size: clamp(2.4rem, 7.4666666667vw, 3.4rem);
  font-weight: 700;
}
.point-title .is-lato {
  font-size: clamp(2.8rem, 8.5333333333vw, 3.8rem);
}
.point-list {
  display: grid;
  grid-auto-flow: row;
  gap: 20px;
  counter-reset: num;
}
.point-list > li {
  padding: 24px;
  border-radius: 10px;
  background-color: #fdf4f6;
}
.point-list__title {
  margin-top: 12px;
  margin-bottom: 6px;
  padding-left: 1.2em;
  font-size: clamp(1.6rem, 5.3333333333vw, 2.6rem);
  font-weight: 700;
  position: relative;
}
.point-list__title:before {
  position: absolute;
  display: block;
  content: "";
  top: 0.3em;
  left: 0;
  display: grid;
  place-content: center;
  width: 1.2em;
  height: 1.2em;
  padding-bottom: 3px;
  border-radius: 50%;
  border: 1px solid #000;
  font-size: 90%;
  content: counter(num);
  counter-increment: num;
  line-height: 1;
}

.class-title .is-lato {
  font-size: clamp(3rem, 9.0666666667vw, 4rem);
}
.class-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-bottom: 16px;
}
.class-list.-col2 {
  grid-template-columns: 1fr 1fr;
}
.class-list.-row1 > li {
  grid-template-rows: 1fr;
}
.class-list.-gap0 {
  gap: 0 24px;
}
.class-list.-gap0 > li {
  margin-top: -1px;
}
.class-list__icon {
  display: grid;
  place-content: center;
  width: 140px;
  height: 140px;
  margin: 0 auto 8px;
  padding-top: 12px;
  border-radius: 50%;
  background: #f5f5f5;
  text-align: center;
}
.class-list__icon.-small {
  width: 86px;
  height: 86px;
  margin-bottom: 4px;
}
.class-list__icon.-small .class-list__term {
  font-size: 1rem;
}
.class-list__icon.-small img {
  max-width: 40px;
}
.class-list__term {
  color: rgba(0, 0, 0, 0.22);
  font-family: "Lato", "Noto Sans TC", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
}
.class-list__name {
  margin-bottom: 8px;
  font-size: clamp(1.4rem, 4.8vw, 2.4rem);
  line-height: 1.2222222222;
  text-align: center;
}
.class-list__name .is-lato {
  font-size: clamp(1.8rem, 5.8666666667vw, 2.8rem);
}
.class-list__price {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding: 0 8px;
  font-size: clamp(1.9rem, 6.1333333333vw, 2.9rem);
  background-image: -webkit-gradient(linear, left top, right top, from(#F7FF87), to(#F7FF87));
  background-image: linear-gradient(to right, #F7FF87, #F7FF87);
  background-repeat: repeat-x;
  background-size: 16px 16px;
  background-position: left bottom;
  font-family: "Lato", "Noto Sans TC", sans-serif;
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
}
.class-list__total {
  display: grid;
  grid-template-columns: auto auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-weight: 700;
}
.class-list__total > dt {
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: right;
}
.class-list__total > dd {
  padding-left: 1em;
  font-family: "Lato", "Noto Sans TC", sans-serif;
  font-size: clamp(1.6rem, 5.3333333333vw, 2.6rem);
}
.class-list__total .total {
  border-top: 1px solid #d4d4d4;
  padding-left: 12px;
  padding-right: 12px;
}
.class-list__total dt.total {
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
}
.class-list__total dd.total {
  background-image: -webkit-gradient(linear, left top, right top, from(#F7FF87), to(#F7FF87));
  background-image: linear-gradient(to right, #F7FF87, #F7FF87);
  background-repeat: repeat-x;
  background-size: 16px 16px;
  background-position: left bottom;
  font-size: clamp(1.9rem, 6.1333333333vw, 2.9rem);
}
.class-list__btnWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 12px;
  margin-top: 12px;
  margin-bottom: 20px;
  text-align: center;
}
.class-list__image {
  margin-bottom: 14px;
}
.class-list > li {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr;
}

.course-table .c-list.-horizontal {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

.flow-list {
  counter-reset: flownum;
}
.flow-list > li {
  padding: 4px 0 4px 66px;
  position: relative;
}
.flow-list > li:before {
  position: absolute;
  display: block;
  content: "";
  top: 4px;
  left: 46px;
  content: counter(flownum) ".";
  counter-increment: flownum;
}
.flow-list > li.user {
  background: #fdf4f6 url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="13" viewBox="0 0 14 13">  <path id="Icon_metro-user" data-name="Icon metro-user" d="M12.5,14.825V14a4.466,4.466,0,0,0,2-3.716c0-2.485,0-4.5-3-4.5s-3,2.015-3,4.5A4.466,4.466,0,0,0,10.5,14v.825c-3.392.277-6,1.944-6,3.959h14c0-2.015-2.608-3.682-6-3.959Z" transform="translate(-4.499 -5.784)" fill="%23cb1b44" opacity="0.5"/></svg>') no-repeat 24px 8px/auto 13px;
}
.flow-list > li.user::before {
  color: #CB1B44;
  font-weight: 700;
}
.flow-list > li.scitec {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="15" height="12.273" viewBox="0 0 15 12.273">  <path id="Icon_material-school" data-name="Icon material-school" d="M4.227,11.441v2.727L9,16.773l4.773-2.6V11.441L9,14.045ZM9,4.5,1.5,8.591,9,12.682l6.136-3.348v4.711H16.5V8.591Z" transform="translate(-1.5 -4.5)" opacity="0.5"/></svg>') no-repeat 4px 8px/auto 13px;
}
.flow-list > li.user.scitec {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="15" height="12.273" viewBox="0 0 15 12.273">  <path id="Icon_material-school" data-name="Icon material-school" d="M4.227,11.441v2.727L9,16.773l4.773-2.6V11.441L9,14.045ZM9,4.5,1.5,8.591,9,12.682l6.136-3.348v4.711H16.5V8.591Z" transform="translate(-1.5 -4.5)" opacity="0.5"/></svg>'), url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="13" viewBox="0 0 14 13">  <path id="Icon_metro-user" data-name="Icon metro-user" d="M12.5,14.825V14a4.466,4.466,0,0,0,2-3.716c0-2.485,0-4.5-3-4.5s-3,2.015-3,4.5A4.466,4.466,0,0,0,10.5,14v.825c-3.392.277-6,1.944-6,3.959h14c0-2.015-2.608-3.682-6-3.959Z" transform="translate(-4.499 -5.784)" fill="%23cb1b44" opacity="0.5"/></svg>');
  background-color: #fdf4f6;
  background-position: 4px 8px, 24px 8px;
  background-size: auto 13px;
}
.flow-thing {
  margin-top: 12px;
}
.flow-thing > dd {
  padding-left: 28px;
}
.flow-thing > dt {
  padding-left: 24px;
  font-weight: bold;
}
.flow-thing > dt.user {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="13" viewBox="0 0 14 13">  <path id="Icon_metro-user" data-name="Icon metro-user" d="M12.5,14.825V14a4.466,4.466,0,0,0,2-3.716c0-2.485,0-4.5-3-4.5s-3,2.015-3,4.5A4.466,4.466,0,0,0,10.5,14v.825c-3.392.277-6,1.944-6,3.959h14c0-2.015-2.608-3.682-6-3.959Z" transform="translate(-4.499 -5.784)" fill="%23cb1b44" opacity="0.5"/></svg>') no-repeat 4px 4px/auto 13px;
}
.flow-thing > dt.scitec {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="15" height="12.273" viewBox="0 0 15 12.273">  <path id="Icon_material-school" data-name="Icon material-school" d="M4.227,11.441v2.727L9,16.773l4.773-2.6V11.441L9,14.045ZM9,4.5,1.5,8.591,9,12.682l6.136-3.348v4.711H16.5V8.591Z" transform="translate(-1.5 -4.5)" opacity="0.5"/></svg>') no-repeat 4px 4px/auto 13px;
}

.document-list {
  font-weight: bold;
  counter-reset: docnum;
}
.document-list > li {
  padding-left: 1.2em;
  position: relative;
}
.document-list > li:before {
  position: absolute;
  display: block;
  content: "";
  top: 0;
  left: 0;
  content: counter(docnum) ".";
  counter-increment: docnum;
}
.document-list > li + li {
  margin-top: 8px;
}

.step-list {
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 24px 0 32px;
  background: #f2f2f2;
}
.step-list > li {
  -webkit-box-flex: 1;
      -ms-flex: auto;
          flex: auto;
  min-height: 42px;
  display: grid;
  place-content: center;
  padding: 6px 0px 6px 14px;
  line-height: 1.2;
  font-weight: 500;
  text-align: center;
}
.step-list > li:not(:last-child) {
  position: relative;
}
.step-list > li:not(:last-child)::before, .step-list > li:not(:last-child)::after {
  position: absolute;
  top: -2px;
  bottom: -2px;
  display: block;
  content: "";
  width: 14px;
}
.step-list > li:not(:last-child)::before {
  right: -14px;
  -webkit-clip-path: polygon(0% 0%, 100% 50%, 0 100%);
          clip-path: polygon(0% 0%, 100% 50%, 0 100%);
  background: #fff;
}
.step-list > li:not(:last-child)::after {
  right: -12px;
  z-index: 1;
  -webkit-clip-path: polygon(0% 0%, 100% 50%, 0 100%);
          clip-path: polygon(0% 0%, 100% 50%, 0 100%);
  background: #f2f2f2;
}
.step-list > li:first-child {
  padding-left: 4px;
}
.step-list > li:last-child {
  padding-right: 4px;
}
.step-list > li.is-current {
  background: #FFD2DD;
  color: #CB1B44;
  font-weight: 700;
}
.step-list > li.is-current:not(:last-child)::after {
  background: #FFD2DD;
}

.contact-wrap {
  padding: 0 16px 16px;
  border-radius: 8px;
  border: 1px solid #d4d4d4;
}
.contact-title {
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 4px;
  padding: 0 12px;
  background: #fff;
  font-size: clamp(1.2rem, 4.2666666667vw, 2.2rem);
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
}
.contact-list {
  display: grid;
  grid-template-columns: auto auto;
  gap: 4px 1em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
.contact-list .icon-mail::before {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="23.185" height="18.32" viewBox="0 0 23.185 18.32"><g id="Icon_feather-mail" data-name="Icon feather-mail" transform="translate(1.393 1)"><path id="パス_236" data-name="パス 236" d="M5.04,6H21.36A2.046,2.046,0,0,1,23.4,8.04V20.28a2.046,2.046,0,0,1-2.04,2.04H5.04A2.046,2.046,0,0,1,3,20.28V8.04A2.046,2.046,0,0,1,5.04,6Z" transform="translate(-3 -6)" fill="none" stroke="%23CB1B44" opacity="0.5" stroke-linecap="round" stroke-linejoin="round" stroke-width="2"/><path id="パス_237" data-name="パス 237" d="M23.4,9,13.2,16.14,3,9" transform="translate(-3 -6.96)" fill="none" stroke="%23CB1B44" stroke-linecap="round" stroke-linejoin="round" opacity="0.5" stroke-width="2"/></g></svg>');
}

.form-list > li + li {
  margin-top: 18px;
}
.form-date {
  margin-top: 8px;
}
.form-date .c-label {
  margin-right: 8px;
}
.form-date .c-label:last-child {
  margin-right: 0;
}
.form-date .c-label select {
  margin-right: 6px;
}
.form-totalPrice {
  display: grid;
  grid-template-columns: auto auto;
  gap: 2px 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 8px;
}
.form-totalPriceWrap {
  margin-top: 32px;
}
.form-totalPrice > dd {
  padding-left: 1.5em;
  font-weight: 700;
}
.form-totalPrice > dd.total {
  padding-left: 1em;
  font-size: clamp(1.4rem, 4.8vw, 2.4rem);
}
.form-totalPrice .total {
  display: grid;
  -ms-flex-line-pack: center;
      align-content: center;
  grid-auto-flow: column;
  margin-top: 4px;
  padding-top: 4px;
  border-top: 1px solid #d4d4d4;
  font-weight: 700;
}
.form-totalPrice__fixed {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 996;
  margin-top: 0;
  padding: 4px 3.2vw;
  border-bottom: 1px solid #d4d4d4;
  background-color: #fff;
  font-weight: 700;
  -webkit-transition: ease-in-out 0.3s;
  transition: ease-in-out 0.3s;
}
.form-totalPrice__fixed > dd {
  font-size: clamp(1.4rem, 4.8vw, 2.4rem);
}
.is-scroll .form-totalPrice__fixed {
  top: 41px;
}
.is-triggerShow .form-totalPrice__fixed {
  -webkit-transform: translateY(calc(-100% - 41px));
          transform: translateY(calc(-100% - 41px));
}
.form-confirm {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 1em;
}

.company-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 12px;
}
.company-grid__map {
  aspect-ratio: 327/200;
}
.company-grid__map iframe {
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 750.98px) {
  .is-sptal {
    text-align: left !important;
  }
  .is-sptac {
    text-align: center !important;
  }
  .is-sptar {
    text-align: right !important;
  }
  .is-showpc {
    display: none !important;
  }
  .c-spmt0 {
    margin-top: 0px !important;
  }
  .c-spmr0 {
    margin-right: 0px !important;
  }
  .c-spmb0 {
    margin-bottom: 0px !important;
  }
  .c-spml0 {
    margin-left: 0px !important;
  }
  .c-sppt0 {
    padding-top: 0px !important;
  }
  .c-sppr0 {
    padding-right: 0px !important;
  }
  .c-sppb0 {
    padding-bottom: 0px !important;
  }
  .c-sppl0 {
    padding-left: 0px !important;
  }
  .c-spmt5 {
    margin-top: 5px !important;
  }
  .c-spmr5 {
    margin-right: 5px !important;
  }
  .c-spmb5 {
    margin-bottom: 5px !important;
  }
  .c-spml5 {
    margin-left: 5px !important;
  }
  .c-sppt5 {
    padding-top: 5px !important;
  }
  .c-sppr5 {
    padding-right: 5px !important;
  }
  .c-sppb5 {
    padding-bottom: 5px !important;
  }
  .c-sppl5 {
    padding-left: 5px !important;
  }
  .c-spmt10 {
    margin-top: 10px !important;
  }
  .c-spmr10 {
    margin-right: 10px !important;
  }
  .c-spmb10 {
    margin-bottom: 10px !important;
  }
  .c-spml10 {
    margin-left: 10px !important;
  }
  .c-sppt10 {
    padding-top: 10px !important;
  }
  .c-sppr10 {
    padding-right: 10px !important;
  }
  .c-sppb10 {
    padding-bottom: 10px !important;
  }
  .c-sppl10 {
    padding-left: 10px !important;
  }
  .c-spmt15 {
    margin-top: 15px !important;
  }
  .c-spmr15 {
    margin-right: 15px !important;
  }
  .c-spmb15 {
    margin-bottom: 15px !important;
  }
  .c-spml15 {
    margin-left: 15px !important;
  }
  .c-sppt15 {
    padding-top: 15px !important;
  }
  .c-sppr15 {
    padding-right: 15px !important;
  }
  .c-sppb15 {
    padding-bottom: 15px !important;
  }
  .c-sppl15 {
    padding-left: 15px !important;
  }
  .c-spmt20 {
    margin-top: 20px !important;
  }
  .c-spmr20 {
    margin-right: 20px !important;
  }
  .c-spmb20 {
    margin-bottom: 20px !important;
  }
  .c-spml20 {
    margin-left: 20px !important;
  }
  .c-sppt20 {
    padding-top: 20px !important;
  }
  .c-sppr20 {
    padding-right: 20px !important;
  }
  .c-sppb20 {
    padding-bottom: 20px !important;
  }
  .c-sppl20 {
    padding-left: 20px !important;
  }
  .c-spmt25 {
    margin-top: 25px !important;
  }
  .c-spmr25 {
    margin-right: 25px !important;
  }
  .c-spmb25 {
    margin-bottom: 25px !important;
  }
  .c-spml25 {
    margin-left: 25px !important;
  }
  .c-sppt25 {
    padding-top: 25px !important;
  }
  .c-sppr25 {
    padding-right: 25px !important;
  }
  .c-sppb25 {
    padding-bottom: 25px !important;
  }
  .c-sppl25 {
    padding-left: 25px !important;
  }
  .c-spmt30 {
    margin-top: 30px !important;
  }
  .c-spmr30 {
    margin-right: 30px !important;
  }
  .c-spmb30 {
    margin-bottom: 30px !important;
  }
  .c-spml30 {
    margin-left: 30px !important;
  }
  .c-sppt30 {
    padding-top: 30px !important;
  }
  .c-sppr30 {
    padding-right: 30px !important;
  }
  .c-sppb30 {
    padding-bottom: 30px !important;
  }
  .c-sppl30 {
    padding-left: 30px !important;
  }
  .c-spmt35 {
    margin-top: 35px !important;
  }
  .c-spmr35 {
    margin-right: 35px !important;
  }
  .c-spmb35 {
    margin-bottom: 35px !important;
  }
  .c-spml35 {
    margin-left: 35px !important;
  }
  .c-sppt35 {
    padding-top: 35px !important;
  }
  .c-sppr35 {
    padding-right: 35px !important;
  }
  .c-sppb35 {
    padding-bottom: 35px !important;
  }
  .c-sppl35 {
    padding-left: 35px !important;
  }
  .c-spmt40 {
    margin-top: 40px !important;
  }
  .c-spmr40 {
    margin-right: 40px !important;
  }
  .c-spmb40 {
    margin-bottom: 40px !important;
  }
  .c-spml40 {
    margin-left: 40px !important;
  }
  .c-sppt40 {
    padding-top: 40px !important;
  }
  .c-sppr40 {
    padding-right: 40px !important;
  }
  .c-sppb40 {
    padding-bottom: 40px !important;
  }
  .c-sppl40 {
    padding-left: 40px !important;
  }
  .c-spmt45 {
    margin-top: 45px !important;
  }
  .c-spmr45 {
    margin-right: 45px !important;
  }
  .c-spmb45 {
    margin-bottom: 45px !important;
  }
  .c-spml45 {
    margin-left: 45px !important;
  }
  .c-sppt45 {
    padding-top: 45px !important;
  }
  .c-sppr45 {
    padding-right: 45px !important;
  }
  .c-sppb45 {
    padding-bottom: 45px !important;
  }
  .c-sppl45 {
    padding-left: 45px !important;
  }
  .c-spmt50 {
    margin-top: 50px !important;
  }
  .c-spmr50 {
    margin-right: 50px !important;
  }
  .c-spmb50 {
    margin-bottom: 50px !important;
  }
  .c-spml50 {
    margin-left: 50px !important;
  }
  .c-sppt50 {
    padding-top: 50px !important;
  }
  .c-sppr50 {
    padding-right: 50px !important;
  }
  .c-sppb50 {
    padding-bottom: 50px !important;
  }
  .c-sppl50 {
    padding-left: 50px !important;
  }
  .c-spw0 {
    width: 0% !important;
  }
  .c-spw5 {
    width: 5% !important;
  }
  .c-spw10 {
    width: 10% !important;
  }
  .c-spw15 {
    width: 15% !important;
  }
  .c-spw20 {
    width: 20% !important;
  }
  .c-spw25 {
    width: 25% !important;
  }
  .c-spw30 {
    width: 30% !important;
  }
  .c-spw35 {
    width: 35% !important;
  }
  .c-spw40 {
    width: 40% !important;
  }
  .c-spw45 {
    width: 45% !important;
  }
  .c-spw50 {
    width: 50% !important;
  }
  .c-spw55 {
    width: 55% !important;
  }
  .c-spw60 {
    width: 60% !important;
  }
  .c-spw65 {
    width: 65% !important;
  }
  .c-spw70 {
    width: 70% !important;
  }
  .c-spw75 {
    width: 75% !important;
  }
  .c-spw80 {
    width: 80% !important;
  }
  .c-spw85 {
    width: 85% !important;
  }
  .c-spw90 {
    width: 90% !important;
  }
  .c-spw95 {
    width: 95% !important;
  }
  .c-spw100 {
    width: 100% !important;
  }
  .l-container {
    position: relative;
    padding-top: 60px;
  }
  .l-container.p-top {
    padding-top: 0;
  }
  .l-container.p-top .l-header {
    background-color: transparent;
  }
  .l-header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
  }
  .l-nav {
    display: block;
    overflow-y: auto;
  }
  .l-navBtn {
    position: absolute;
    top: 15px;
    right: 12px;
    z-index: 1000;
    width: 40px;
    height: 40px;
    border: none;
    background: none;
    -webkit-transition: ease-in-out 0.3s;
    transition: ease-in-out 0.3s;
  }
  .l-navBtn::after {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 4px;
    content: "MENU";
    font-size: 1rem;
    color: #fff;
    text-align: center;
  }
  .l-navBtn span {
    position: absolute;
    left: 5px;
    display: block;
    width: 30px;
    height: 2px;
    background: #fff;
    -webkit-transition: ease-in-out 0.3s;
    transition: ease-in-out 0.3s;
  }
  .l-navBtn span:nth-child(1) {
    top: 0;
  }
  .l-navBtn span:nth-child(2) {
    top: 9px;
  }
  .l-navBtn span:nth-child(3) {
    top: 18px;
  }
  .l-navBtn.is-open::after {
    content: "CLOSE";
    font-weight: 500;
  }
  .l-navBtn.is-open span:nth-child(1) {
    top: 9px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .l-navBtn.is-open span:nth-child(3) {
    top: 9px;
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
  }
  .l-navBtn.is-open span:nth-child(2) {
    width: 0;
  }
  .l-navWrapper {
    position: fixed;
    top: 0;
    right: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    width: 70vw;
    height: 100vh;
    z-index: 1001;
    overflow-y: auto;
    padding: 16px 16px 50px;
    background: rgba(255, 255, 255, 0.9);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
            backdrop-filter: saturate(180%) blur(20px);
    -webkit-transition: -webkit-transform 0.3s ease-in-out;
    transition: -webkit-transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  }
  .is-navOpen {
    overflow: hidden;
  }
  .is-navOpen body {
    overflow-y: scroll;
  }
  .is-navOpen .l-header__logo a {
    pointer-events: none;
    opacity: 0.2;
  }
  .is-navOpen .l-navBtn {
    -webkit-transform: translateX(-70vw);
            transform: translateX(-70vw);
    right: 0;
  }
  .is-navOpen .l-navWrapper {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  .page-header .l-wrapper {
    padding-left: 3.2vw;
    padding-right: 3.2vw;
  }
}
@media screen and (min-width: 751px) {
  sup, sub {
    font-size: 10px;
  }
  input[type=text],
input[type=password],
input[type=tel],
input[type=email],
input[type=num],
textarea {
    font-size: 1.6rem;
  }
  select {
    font-size: 1.6rem;
  }
  .is-pctal {
    text-align: left !important;
  }
  .is-pctac {
    text-align: center !important;
  }
  .is-pctar {
    text-align: right !important;
  }
  .is-showsp {
    display: none !important;
  }
  .is-fsizeSmallest {
    font-size: 1.1rem;
  }
  .is-fsizeSmaller {
    font-size: 1.2rem;
  }
  .is-fsizeSmall {
    font-size: 1.4rem;
  }
  .is-fsizeNormal {
    font-size: 1.6rem;
  }
  .is-fsizeLarge {
    font-size: 1.8rem;
  }
  .is-fsizeLarger {
    font-size: 2rem;
  }
  .is-fsizeLargest {
    font-size: 2.2rem;
  }
  .is-round {
    border-radius: 8px;
  }
  .c-title.-course .ornament {
    font-size: 1.6rem;
  }
  .c-title.-course .ornament::before, .c-title.-course .ornament::after {
    width: 1.6rem;
    height: 1.6rem;
  }
  .c-title.-course .small {
    margin-top: 4px;
  }
  .c-title.-skin03 {
    margin-bottom: 20px;
  }
  .c-title.-skin03 ~ .c-title.-skin03 {
    margin-top: 36px;
  }
  .c-btn {
    min-width: 280px;
    font-size: 1.6rem;
  }
  .c-btn.-small {
    font-size: 1.3rem;
  }
  .c-btn.-middle {
    min-width: 200px;
    font-size: 1.5rem;
  }
  .c-btnWrap {
    margin-top: 40px;
  }
  .c-btnWrap.-pcreverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .c-telLink {
    pointer-events: none;
    color: inherit;
    text-decoration: none;
  }
  .c-block.-skin01 {
    padding-top: 32px;
    padding-bottom: 32px;
  }
  .c-overflowBox {
    max-height: 200px;
    padding: 20px 16px;
  }
  .c-list.-detail {
    display: grid;
    grid-template-columns: auto 1fr;
  }
  .c-list.-detail > dt ~ dt {
    margin-top: 6px;
  }
  .c-list.-detail > dd {
    padding: 1px 0 0 1em;
    font-size: 1.4rem;
  }
  .c-list.-detail > dd ~ dd {
    margin-top: 6px;
  }
  .c-list.-pcrow {
    grid-template-columns: 1fr;
  }
  .c-list.-pcrow > dd {
    padding: 4px 0 0 0;
  }
  .c-list.-annotation {
    font-size: 1.3rem;
  }
  .c-table th, .c-table td {
    padding: 12px;
  }
  .c-label.-require {
    font-size: 1.2rem;
  }
  .c-label.-radio {
    font-size: 1.6rem;
  }
  .c-label.is-fsizeNormal {
    font-size: 1.6rem;
  }
  .c-pcmt0 {
    margin-top: 0px !important;
  }
  .c-pcmr0 {
    margin-right: 0px !important;
  }
  .c-pcmb0 {
    margin-bottom: 0px !important;
  }
  .c-pcml0 {
    margin-left: 0px !important;
  }
  .c-pcpt0 {
    padding-top: 0px !important;
  }
  .c-pcpr0 {
    padding-right: 0px !important;
  }
  .c-pcpb0 {
    padding-bottom: 0px !important;
  }
  .c-pcpl0 {
    padding-left: 0px !important;
  }
  .c-pcmt5 {
    margin-top: 5px !important;
  }
  .c-pcmr5 {
    margin-right: 5px !important;
  }
  .c-pcmb5 {
    margin-bottom: 5px !important;
  }
  .c-pcml5 {
    margin-left: 5px !important;
  }
  .c-pcpt5 {
    padding-top: 5px !important;
  }
  .c-pcpr5 {
    padding-right: 5px !important;
  }
  .c-pcpb5 {
    padding-bottom: 5px !important;
  }
  .c-pcpl5 {
    padding-left: 5px !important;
  }
  .c-pcmt10 {
    margin-top: 10px !important;
  }
  .c-pcmr10 {
    margin-right: 10px !important;
  }
  .c-pcmb10 {
    margin-bottom: 10px !important;
  }
  .c-pcml10 {
    margin-left: 10px !important;
  }
  .c-pcpt10 {
    padding-top: 10px !important;
  }
  .c-pcpr10 {
    padding-right: 10px !important;
  }
  .c-pcpb10 {
    padding-bottom: 10px !important;
  }
  .c-pcpl10 {
    padding-left: 10px !important;
  }
  .c-pcmt15 {
    margin-top: 15px !important;
  }
  .c-pcmr15 {
    margin-right: 15px !important;
  }
  .c-pcmb15 {
    margin-bottom: 15px !important;
  }
  .c-pcml15 {
    margin-left: 15px !important;
  }
  .c-pcpt15 {
    padding-top: 15px !important;
  }
  .c-pcpr15 {
    padding-right: 15px !important;
  }
  .c-pcpb15 {
    padding-bottom: 15px !important;
  }
  .c-pcpl15 {
    padding-left: 15px !important;
  }
  .c-pcmt20 {
    margin-top: 20px !important;
  }
  .c-pcmr20 {
    margin-right: 20px !important;
  }
  .c-pcmb20 {
    margin-bottom: 20px !important;
  }
  .c-pcml20 {
    margin-left: 20px !important;
  }
  .c-pcpt20 {
    padding-top: 20px !important;
  }
  .c-pcpr20 {
    padding-right: 20px !important;
  }
  .c-pcpb20 {
    padding-bottom: 20px !important;
  }
  .c-pcpl20 {
    padding-left: 20px !important;
  }
  .c-pcmt25 {
    margin-top: 25px !important;
  }
  .c-pcmr25 {
    margin-right: 25px !important;
  }
  .c-pcmb25 {
    margin-bottom: 25px !important;
  }
  .c-pcml25 {
    margin-left: 25px !important;
  }
  .c-pcpt25 {
    padding-top: 25px !important;
  }
  .c-pcpr25 {
    padding-right: 25px !important;
  }
  .c-pcpb25 {
    padding-bottom: 25px !important;
  }
  .c-pcpl25 {
    padding-left: 25px !important;
  }
  .c-pcmt30 {
    margin-top: 30px !important;
  }
  .c-pcmr30 {
    margin-right: 30px !important;
  }
  .c-pcmb30 {
    margin-bottom: 30px !important;
  }
  .c-pcml30 {
    margin-left: 30px !important;
  }
  .c-pcpt30 {
    padding-top: 30px !important;
  }
  .c-pcpr30 {
    padding-right: 30px !important;
  }
  .c-pcpb30 {
    padding-bottom: 30px !important;
  }
  .c-pcpl30 {
    padding-left: 30px !important;
  }
  .c-pcmt35 {
    margin-top: 35px !important;
  }
  .c-pcmr35 {
    margin-right: 35px !important;
  }
  .c-pcmb35 {
    margin-bottom: 35px !important;
  }
  .c-pcml35 {
    margin-left: 35px !important;
  }
  .c-pcpt35 {
    padding-top: 35px !important;
  }
  .c-pcpr35 {
    padding-right: 35px !important;
  }
  .c-pcpb35 {
    padding-bottom: 35px !important;
  }
  .c-pcpl35 {
    padding-left: 35px !important;
  }
  .c-pcmt40 {
    margin-top: 40px !important;
  }
  .c-pcmr40 {
    margin-right: 40px !important;
  }
  .c-pcmb40 {
    margin-bottom: 40px !important;
  }
  .c-pcml40 {
    margin-left: 40px !important;
  }
  .c-pcpt40 {
    padding-top: 40px !important;
  }
  .c-pcpr40 {
    padding-right: 40px !important;
  }
  .c-pcpb40 {
    padding-bottom: 40px !important;
  }
  .c-pcpl40 {
    padding-left: 40px !important;
  }
  .c-pcmt45 {
    margin-top: 45px !important;
  }
  .c-pcmr45 {
    margin-right: 45px !important;
  }
  .c-pcmb45 {
    margin-bottom: 45px !important;
  }
  .c-pcml45 {
    margin-left: 45px !important;
  }
  .c-pcpt45 {
    padding-top: 45px !important;
  }
  .c-pcpr45 {
    padding-right: 45px !important;
  }
  .c-pcpb45 {
    padding-bottom: 45px !important;
  }
  .c-pcpl45 {
    padding-left: 45px !important;
  }
  .c-pcmt50 {
    margin-top: 50px !important;
  }
  .c-pcmr50 {
    margin-right: 50px !important;
  }
  .c-pcmb50 {
    margin-bottom: 50px !important;
  }
  .c-pcml50 {
    margin-left: 50px !important;
  }
  .c-pcpt50 {
    padding-top: 50px !important;
  }
  .c-pcpr50 {
    padding-right: 50px !important;
  }
  .c-pcpb50 {
    padding-bottom: 50px !important;
  }
  .c-pcpl50 {
    padding-left: 50px !important;
  }
  .c-pcmt55 {
    margin-top: 55px !important;
  }
  .c-pcmr55 {
    margin-right: 55px !important;
  }
  .c-pcmb55 {
    margin-bottom: 55px !important;
  }
  .c-pcml55 {
    margin-left: 55px !important;
  }
  .c-pcpt55 {
    padding-top: 55px !important;
  }
  .c-pcpr55 {
    padding-right: 55px !important;
  }
  .c-pcpb55 {
    padding-bottom: 55px !important;
  }
  .c-pcpl55 {
    padding-left: 55px !important;
  }
  .c-pcmt60 {
    margin-top: 60px !important;
  }
  .c-pcmr60 {
    margin-right: 60px !important;
  }
  .c-pcmb60 {
    margin-bottom: 60px !important;
  }
  .c-pcml60 {
    margin-left: 60px !important;
  }
  .c-pcpt60 {
    padding-top: 60px !important;
  }
  .c-pcpr60 {
    padding-right: 60px !important;
  }
  .c-pcpb60 {
    padding-bottom: 60px !important;
  }
  .c-pcpl60 {
    padding-left: 60px !important;
  }
  .c-pcw0 {
    width: 0% !important;
  }
  .c-pcw5 {
    width: 5% !important;
  }
  .c-pcw10 {
    width: 10% !important;
  }
  .c-pcw15 {
    width: 15% !important;
  }
  .c-pcw20 {
    width: 20% !important;
  }
  .c-pcw25 {
    width: 25% !important;
  }
  .c-pcw30 {
    width: 30% !important;
  }
  .c-pcw35 {
    width: 35% !important;
  }
  .c-pcw40 {
    width: 40% !important;
  }
  .c-pcw45 {
    width: 45% !important;
  }
  .c-pcw50 {
    width: 50% !important;
  }
  .c-pcw55 {
    width: 55% !important;
  }
  .c-pcw60 {
    width: 60% !important;
  }
  .c-pcw65 {
    width: 65% !important;
  }
  .c-pcw70 {
    width: 70% !important;
  }
  .c-pcw75 {
    width: 75% !important;
  }
  .c-pcw80 {
    width: 80% !important;
  }
  .c-pcw85 {
    width: 85% !important;
  }
  .c-pcw90 {
    width: 90% !important;
  }
  .c-pcw95 {
    width: 95% !important;
  }
  .c-pcw100 {
    width: 100% !important;
  }
  .l-container {
    grid-template-rows: auto 1fr auto;
    font-size: 1.6rem;
  }
  .l-wrapper {
    width: 96%;
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
  }
  .l-header {
    position: relative;
    z-index: 998;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 8px 4px;
  }
  .l-nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    border-top: 0;
  }
  .l-nav a {
    display: grid;
    grid-auto-flow: column;
    place-content: center;
    height: 60px;
    padding: 2px 4px;
    font-size: 1.3rem;
    color: #fff;
  }
  .l-nav > li {
    position: relative;
    border: none;
  }
  .l-nav > li:hover .l-nav__sub {
    visibility: visible;
    -webkit-transform: translateX(-50%) scale(1, 1);
            transform: translateX(-50%) scale(1, 1);
    opacity: 1;
  }
  .l-nav .icon-home::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="30" height="33" viewBox="0 0 30 33"><g id="Icon_feather-home" data-name="Icon feather-home" transform="translate(-3 -1.5)"> <path id="パス_264" data-name="パス 264" d="M4.5,13.5,18,3,31.5,13.5V30a3,3,0,0,1-3,3H7.5a3,3,0,0,1-3-3Z" fill="none" stroke="%23fff" stroke-linecap="round" stroke-linejoin="round" stroke-width="3"/><path id="パス_265" data-name="パス 265" d="M13.5,33V18h9V33" fill="none" stroke="%23fff" stroke-linecap="round" stroke-linejoin="round" stroke-width="3"/></g></svg>');
  }
  .l-navWrapper {
    margin-left: auto;
  }
  .l-nav__sub {
    position: absolute;
    top: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%) scale(1, 0.5);
            transform: translateX(-50%) scale(1, 0.5);
    -webkit-transform-origin: center top;
            transform-origin: center top;
    visibility: hidden;
    opacity: 0;
    z-index: 1;
    margin-left: 0;
    padding: 0 12px 12px;
    background-color: rgba(203, 27, 68, 0.9);
    -webkit-transition: opacity 0.2s ease-out, visibility 0.2s ease-out, -webkit-transform 0.2s ease-out;
    transition: opacity 0.2s ease-out, visibility 0.2s ease-out, -webkit-transform 0.2s ease-out;
    transition: opacity 0.2s ease-out, transform 0.2s ease-out, visibility 0.2s ease-out;
    transition: opacity 0.2s ease-out, transform 0.2s ease-out, visibility 0.2s ease-out, -webkit-transform 0.2s ease-out;
    mix-blend-mode: multiply;
  }
  .l-nav__sub > li {
    padding-left: 0;
    border-bottom: 1px dotted #D1D1D1;
    color: #fff;
    white-space: nowrap;
  }
  .l-nav__sub > li:first-child {
    border-top: 1px dotted #D1D1D1;
  }
  .l-nav__sub > li::before {
    content: none;
  }
  .l-nav__sub > li a {
    height: auto;
    padding: 6px 8px;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
  }
  .l-footer__logo {
    font-size: 1.8rem;
  }
  .l-footer__copy {
    font-size: 1.1rem;
  }
  :where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h2,
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h3,
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h4,
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h5,
:where(p, ul, ol, dl, blockquote, hr, pre, table, form, figure, div) + h6 {
    margin-top: 36px;
  }
  .mv-wrap {
    height: calc(100vh - 60px);
  }
  .mv-wrap .slick-slide {
    height: calc(100vh - 60px);
  }
  .mv-title {
    font-size: 10rem;
  }
  .mv-title .small {
    font-size: 4.5rem;
  }
  .top-course__catch {
    bottom: 52px;
    left: 36px;
  }
  .top-course__image {
    height: 600px;
  }
  .summary-course__catch {
    bottom: 40px;
    left: 36px;
  }
  .summary-course__text {
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
    padding: 32px;
  }
  .introduction-image {
    text-align: center;
  }
  .class-list {
    gap: 40px;
  }
  .class-list.-gap0 {
    gap: 0 40px;
  }
  .class-list .c-list.-detail {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
  }
  .class-list .c-list.-pcrow {
    width: auto;
    margin-left: 0;
    margin-right: 0;
  }
  .flow-list > li {
    padding: 8px 0 8px 72px;
  }
  .flow-list > li::before {
    top: 8px;
    left: 50px;
  }
  .flow-list > li.user {
    background-position: 28px 16px;
  }
  .flow-list > li.scitec {
    background-position: 8px 16px;
  }
  .flow-list > li.user.scitec {
    background-position: 8px 16px, 28px 16px;
  }
  .flow-thing {
    margin-left: 24px;
  }
  .document-list .c-grid {
    margin-top: 12px;
  }
  .step-list > li {
    min-height: 52px;
  }
  .contact-wrap {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    padding: 0 60px 20px;
  }
  .contact-title {
    margin-bottom: 8px;
  }
  .contact-list {
    gap: 8px 2em;
  }
  .form-totalPrice > dd.total {
    font-size: 2rem;
  }
  #form1,
#form2,
#form3,
#form4 {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
  }
  .company-grid {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
}
@media screen and (min-width: 960px) {
  .l-header {
    padding: 8px 20px;
  }
  .l-nav a {
    padding: 2px 8px;
    font-size: 1.5rem;
  }
  .l-nav__sub a {
    padding: 8px 12px;
    font-size: 1.4rem;
  }
  .top-course:nth-child(even) {
    position: relative;
    z-index: 1;
  }
  .top-course:nth-child(even)::after {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    z-index: -1;
    display: block;
    content: "";
    background-color: #fdf4f6;
  }
  .top-courseWrap {
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
  }
  .summary-course:nth-child(even) {
    position: relative;
    z-index: 1;
    padding-top: 20px;
    margin-bottom: 20px;
  }
  .summary-course:nth-child(even)::after {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    z-index: -1;
    display: block;
    content: "";
    background-color: #fdf4f6;
  }
  .summary-courseWrap {
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
  }
  .point-list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (min-width: 1080px) {
  .l-header {
    padding: 8px 32px;
  }
  .l-nav a {
    padding: 2px 10px;
    font-size: 1.6rem;
  }
}
/* #Print Fixes */
@media print {
  * {
    color: #000 !important;
    -webkit-box-shadow: none !important;
            box-shadow: none !important;
    text-shadow: none !important;
  }
  @page {
    margin: 1cm 1cm;
  }
  p, h2, h3 {
    orphans: 3;
    widows: 3;
  }
  h2, h3 {
    page-break-after: avoid;
  }
  thead {
    display: table-header-group;
  }
  tr, img {
    page-break-inside: avoid;
  }
  body {
    width: auto;
    -webkit-print-color-adjust: exact;
  }
  .p-print .c-table {
    font-size: 13px;
  }
  .p-print .c-closeBtn {
    display: none;
  }
}