@charset "UTF-8";
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, var, b, i, a, dl, dt, dd, ol, ul, li, button, input, textarea, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, main, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: none;
  outline: none;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

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

html {
  font-size: 62.5%;
}

body {
  -webkit-text-size-adjust: 100%;
  line-height: 1;
  font-size: 1.6rem;
  color: #000;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
}

img {
  border-style: none;
  max-width: 100%;
  height: auto;
}

progress {
  vertical-align: baseline;
}

svg:not(:root) {
  overflow: hidden;
}

audio, canvas, progress, video {
  display: inline-block;
}

button, [type="button"], [type="reset"], [type="submit"], [role="button"] {
  cursor: pointer;
}

[disabled] {
  cursor: default;
}

[type="number"] {
  width: auto;
}

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

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

textarea {
  overflow: auto;
  resize: vertical;
}

button, input, optgroup, select, textarea {
  font: inherit;
  margin: 0;
}

optgroup {
  font-weight: bold;
}

button, input {
  overflow: visible;
}

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

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

button, html [type="button"], [type="reset"], [type="submit"] {
  -webkit-appearance: button;
}

button, select {
  text-transform: none;
}

button, input, select, textarea {
  background-color: transparent;
  border-style: none;
  color: inherit;
}

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

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

select::-ms-value {
  color: currentColor;
}

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

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

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

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

a:active, a:hover {
  outline-width: 0;
}

a, area, button, [role="button"], input:not([type="range"]), label, select, summary, textarea {
  -ms-touch-action: manipulation;
  touch-action: manipulation;
}

ol, ul, li {
  list-style: none;
}

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

th {
  font-weight: normal;
}

hr {
  display: block;
  height: 0;
  border: 0;
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

code, kbd, pre, samp {
  font-family: Consolas, "Courier New", Courier, Monaco, monospace;
}

blockquote, q {
  quotes: none;
}

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

@media screen and (min-width: 1024px) {
  [data-tb],
  [data-sp] {
    display: none !important;
  }
  [data-pc] {
    display: inline-block !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  [data-pc],
  [data-sp] {
    display: none !important;
  }
  [data-tb] {
    display: inline-block !important;
  }
}

@media screen and (max-width: 750px) {
  [data-tb],
  [data-pc] {
    display: none !important;
  }
  [data-sp] {
    display: inline-block !important;
  }
}

html,
body {
  height: 100%;
}

body {
  background-color: var(--bg-color);
  font-family: var(--base-font-family);
  color: var(--base-font-color);
  font-size: 1.5rem;
  line-height: 1.6;
}

body.noscroll {
  overflow: hidden;
}

body img {
  vertical-align: bottom;
}

body figure {
  margin: 0;
}

body svg {
  width: 100%;
  height: 100%;
}

body [data-target-mask] {
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}

body [data-target-mask][right].action, body [data-target-mask][left].action, body [data-target-mask][up].action, body [data-target-mask][down].action {
  -webkit-clip-path: inset(0);
  clip-path: inset(0);
}

body [data-target-mask][right] {
  -webkit-clip-path: inset(0 99.9% 0 0);
  clip-path: inset(0 99.9% 0 0);
}

body [data-target-mask][left] {
  -webkit-clip-path: inset(0 0 0 99.9%);
  clip-path: inset(0 0 0 99.9%);
}

body [data-target-mask][up] {
  -webkit-clip-path: inset(99.9% 0 0 0);
  clip-path: inset(99.9% 0 0 0);
}

body [data-target-mask][down] {
  -webkit-clip-path: inset(0 0 99.9% 0);
  clip-path: inset(0 0 99.9% 0);
}

body [data-target] {
  -webkit-transition-duration: 0.6s;
  transition-duration: 0.6s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: transform, opacity;
  transition-property: transform, opacity, -webkit-transform;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform: scale(0.9);
  transform: scale(0.9);
  opacity: 0;
}

body [data-target].action {
  -webkit-transform: scale(1);
  transform: scale(1);
  opacity: 1;
}

body [data-target][slideup] {
  -webkit-transform: translateY(2.2vw) scale(1);
  transform: translateY(2.2vw) scale(1);
}

body [data-target][slideup].action {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

body [data-target][slidedown] {
  -webkit-transform: translateY(-2.2vw) scale(1);
  transform: translateY(-2.2vw) scale(1);
}

body [data-target][slidedown].action {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

body [data-target][slideleft] {
  -webkit-transform: translateX(2.2vw) scale(1);
  transform: translateX(2.2vw) scale(1);
}

body [data-target][slideleft].action {
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

body [data-target][slideright] {
  -webkit-transform: translateX(-2.2vw) scale(1);
  transform: translateX(-2.2vw) scale(1);
}

body [data-target][slideright].action {
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

body [data-lzy] {
  opacity: 0;
}

body [data-lzy].action {
  -webkit-transition-duration: 0.2s;
  transition-duration: 0.2s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: opacity;
  transition-property: opacity;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
  opacity: 1;
}

body .disable-hover {
  pointer-events: none;
}

.modal {
  -webkit-transition-duration: 1s;
  transition-duration: 1s;
  -webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform: translateX(100%);
  transform: translateX(100%);
  background-color: var(--bg-color);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99;
}

.modal.active {
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

.modal .btn_modal_close {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  position: absolute;
  top: 30px;
  right: 30px;
  width: 32px;
  height: 32px;
  cursor: pointer;
  z-index: 10;
}

.modal .btn_modal_close:before, .modal .btn_modal_close:after {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  background-color: var(--base-font-color);
  content: '';
  display: block;
  width: 44px;
  height: 2px;
  border-radius: 1px;
  position: absolute;
  top: 50%;
  left: 50%;
  opacity: 0.5;
}

.modal .btn_modal_close:before {
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
  transform: translate(-50%, -50%) rotate(-45deg);
}

.modal .btn_modal_close:after {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
  transform: translate(-50%, -50%) rotate(45deg);
}

@media screen and (min-width: 750px) {
  .modal .btn_modal_close:hover {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
}

.modal .modal_container {
  position: relative;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  margin: auto;
}

.modal .modal_contents {
  max-width: 1080px;
  margin: 0 auto;
  padding: 150px 0;
}

.modal .modal_contents.wide_l {
  max-width: 1200px;
}

.modal .modal_contents.wide_s {
  max-width: 960px;
}

.modal .modal_contents.wide_ss {
  max-width: 640px;
}

.modal .modal_contents section {
  margin-bottom: 80px;
}

.modal .modal_contents section:last-of-type {
  margin-bottom: 0;
}

.img_unit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.img_unit.reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.img_unit.reverse .img {
  margin-right: 0;
  margin-left: 40px;
}

.img_unit.bdr_btm {
  position: relative;
  padding-bottom: 50px;
  margin-bottom: 35px;
}

.img_unit.bdr_btm:after {
  background-color: var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  opacity: 0.15;
  position: absolute;
  bottom: 0;
  left: 0;
}

.img_unit.noimage .txt {
  width: 100% !important;
}

.img_unit .img {
  margin-right: 40px;
}

.img_unit .txt h2 {
  margin-bottom: 25px;
  font-weight: bold;
}

.img_unit .txt p {
  margin-bottom: 30px;
}

.img_unit .txt p:last-of-type {
  margin-bottom: 0;
}

.table_unit dl {
  position: relative;
  padding: 30px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.table_unit dl:after {
  background-color: var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  opacity: 0.15;
  position: absolute;
  bottom: 0;
  left: 0;
}

.table_unit dl dt {
  width: 210px;
  padding: 0 30px;
}

.table_unit dl dd {
  width: calc(100% - 210px);
}

.table_unit dl dd p {
  margin-bottom: 30px;
}

.table_unit dl dd p:last-of-type {
  margin-bottom: 0;
}

.thumb_unit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.thumb_unit figure {
  width: calc(33.3% - 28px);
  margin: 0 42px 40px 0;
}

.thumb_unit figure:nth-child(3n) {
  margin-right: 0;
}

.thumb_unit figure figcaption {
  margin-top: 12px;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
}

.form_unit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
}

.form_unit:before {
  background-color: var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  opacity: 0.15;
  pointer-events: none;
}

.form_unit dt {
  width: 225px;
  padding: 26px 30px 26px 0;
  font-size: 1.4rem;
  font-weight: bold;
  text-align: right;
}

.form_unit dt .required {
  margin-left: 7px;
  vertical-align: middle;
}

.form_unit dd {
  width: calc(100% - 225px);
  padding: 12px 0;
}

.form_unit .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.form_unit .row:last-of-type {
  margin-bottom: 0;
}

.form_unit .row.nowrap {
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
}

.form_unit .col {
  margin-right: 12px;
}

.form_unit .col.input_half {
  width: 50%;
}

.form_unit .col.input_mini {
  width: 25%;
}

.form_unit .radio,
.form_unit .checkbox {
  height: 44px;
}

.form_unit .radio > *,
.form_unit .checkbox > * {
  margin-right: 30px;
}

.form_unit .select {
  position: relative;
}

.form_unit .select svg {
  width: 10px;
  height: 5px;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -2.5px;
  pointer-events: none;
}

.form_unit .mwform-file-delete {
  display: none;
}

.form_unit .p-form__file_label {
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 1.4rem;
}

.form_unit .p-form__file_label .p-form__file_txt {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  background: var(--grad-color);
  color: #ffffff;
  width: 120px;
  height: 40px;
  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;
  font-weight: bold;
  border-radius: 3px;
}

@media screen and (min-width: 750px) {
  .form_unit .p-form__file_label .p-form__file_txt:hover {
    opacity: 0.6 !important;
  }
}

.form_unit .p-form__file_label .p-form__file_name {
  margin-left: 15px;
  font-weight: bold;
}

.form_unit .p-form__file_label input {
  display: none !important;
}

.form_unit .note {
  font-size: 1.4rem;
}

.form_unit input[type='text'],
.form_unit input[type='email'],
.form_unit input[type='tel'],
.form_unit input[type='url'],
.form_unit input[type='password'] {
  background-color: #ffffff;
  color: #000000;
  border: 1px solid var(--base-font-color-op);
  border-radius: 5px;
  padding: 0 18px;
  line-height: 1;
  letter-spacing: 0.08em;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  height: 44px;
  display: block;
}

.form_unit input[type='text']:focus,
.form_unit input[type='email']:focus,
.form_unit input[type='tel']:focus,
.form_unit input[type='url']:focus,
.form_unit input[type='password']:focus {
  background-color: #f5f5f5;
  border-color: var(--main-color);
  border-width: 2px;
}

.form_unit input[type='text'].error,
.form_unit input[type='email'].error,
.form_unit input[type='tel'].error,
.form_unit input[type='url'].error,
.form_unit input[type='password'].error {
  background-color: #ffdddd;
  border-color: #ec0000;
}

.form_unit select {
  background-color: #ffffff;
  color: #000000;
  border: 1px solid var(--base-font-color-op);
  border-radius: 5px;
  padding: 0 50px 0 18px;
  line-height: 1;
  letter-spacing: 0.08em;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  height: 44px;
  display: block;
}

.form_unit select:focus {
  border-color: var(--main-color);
  border-width: 2px;
}

.form_unit select option {
  background-color: #ffffff;
}

.form_unit select.error {
  background-color: #ffdddd;
  border-color: #ec0000;
}

.form_unit textarea {
  background-color: #ffffff;
  color: #000000;
  border: 1px solid var(--base-font-color-op);
  border-radius: 5px;
  width: 100%;
  height: 160px;
  padding: 18px;
}

.form_unit textarea:focus {
  background-color: #f5f5f5;
  border-color: var(--main-color);
  border-width: 2px;
}

.form_unit textarea.error {
  background-color: #ffdddd;
  border-color: #ec0000;
}

.form_unit.confirm dd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.form_unit.confirm .row {
  margin-bottom: 0;
}

.form_unit.confirm .select svg {
  display: none;
}

.form_unit.confirm .p-form__file_label,
.form_unit.confirm .p-form__file_name,
.form_unit.confirm .note {
  display: none;
}

.form_unit.privacy_check {
  display: block;
  border: none;
}

.form_unit.privacy_check:before {
  display: none;
}

.site_sns a {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (min-width: 750px) {
  .site_sns a:hover {
    opacity: 0.6 !important;
  }
}

.site_sns a.tw svg {
  width: 16px;
  height: 13px;
}

.site_sns a.fb svg {
  width: 8px;
  height: 15px;
}

.site_sns a.ig svg {
  width: 15px;
  height: 15px;
}

.site_sns a.yt svg {
  width: 16px;
  height: 11px;
}

.sec_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -webkit-transform: translateX(-100%) rotate(-90deg);
  transform: translateX(-100%) rotate(-90deg);
  -webkit-transform-origin: 100% 100%;
  transform-origin: 100% 100%;
  position: absolute;
  top: -5px;
  left: -30px;
}

.sec_title.reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
}

.sec_title.reverse strong {
  padding-left: 0;
  margin-left: 0;
  padding-right: 62px;
  margin-right: 12px;
}

.sec_title.reverse strong:before {
  left: auto;
  right: 0;
}

.sec_title strong {
  background: var(--grad-color);
  background-clip: border-box;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  display: block;
  font-size: 1.3rem;
  line-height: 1;
  position: relative;
  padding-left: 62px;
  margin-left: 12px;
}

.sec_title strong:before {
  background-color: var(--main-color);
  content: '';
  display: block;
  width: 50px;
  height: 1px;
  position: absolute;
  top: 50%;
  left: 0;
}

.sec_title span {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  color: var(--main-color);
  display: block;
  font-size: 1.2rem;
  letter-spacing: 0.18em;
  line-height: 1;
}

.page_title {
  text-align: center;
  line-height: 1;
}

.page_title strong {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  color: var(--main-color);
  display: block;
  font-size: 1.3rem;
  margin-bottom: 10px;
}

.page_title span {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  display: inline-block;
  font-size: 4.2rem;
  letter-spacing: 0.08em;
  padding-bottom: 10px;
  color: var(--main-color);
}

.unit_title {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  color: var(--main-font-color);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 70px;
  font-size: 2.2rem;
  font-weight: bold;
  padding: 0 24px;
  margin-bottom: 35px;
  position: relative;
}

.unit_title:after {
  border: 1px solid var(--main-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0.15;
  position: absolute;
  bottom: 0;
  left: 0;
  pointer-events: none;
}

.medium_title {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  font-size: 2rem;
}

.large_title {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  font-size: 3rem;
}

.mini_title {
  color: var(--base-font-color);
}

.mini_title strong {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  margin-bottom: 22px;
  font-size: 3rem;
  line-height: 1;
  letter-spacing: 0.2em;
  display: block;
}

.mini_title span {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: 0.08em;
  display: block;
}

.swiper {
  position: static;
}

.swiper .swiper-pagination .swiper-pagination-bullet {
  background-color: #ffffff;
  width: 60px;
  height: 3px;
  margin: 0 15px 0 0 !important;
  opacity: 0.5;
  border-radius: 0;
}

.swiper .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #ffffff;
  opacity: 1;
}

.swiper .swiper-button-disabled {
  display: none;
}

.swiper .swiper-button-next,
.swiper .swiper-button-prev {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  width: 12px;
  height: 24px;
}

@media screen and (min-width: 750px) {
  .swiper .swiper-button-next:hover,
  .swiper .swiper-button-prev:hover {
    opacity: 0.6 !important;
  }
}

.swiper .swiper-button-next:after,
.swiper .swiper-button-prev:after {
  display: none;
}

.swiper .swiper-button-next svg,
.swiper .swiper-button-prev svg {
  fill: var(--main-color);
}

.swiper .swiper-button-next {
  right: -60px;
}

.swiper .swiper-button-prev {
  left: -60px;
}

.swiper .swipe_controls {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 24px;
}

.swiper .swipe_controls .swiper-button-next,
.swiper .swipe_controls .swiper-button-prev {
  position: relative;
  top: 0;
  left: 0;
  margin: 0;
}

.swiper .swipe_controls .swiper-button-prev {
  margin-right: 34px;
}

.swiper[data-swiper='slider'] .swiper-slide {
  width: 372px;
}

.swiper[data-swiper='carousel'] .swiper-slide {
  width: 372px;
}

.btn a,
.btn input,
.btn button,
.btn span {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  color: var(--main-color);
  border-bottom: 1px solid var(--main-color);
  display: inline-block;
  text-align: center;
  padding: 10px 0;
  min-height: 45px;
  letter-spacing: 0.05em;
  font-weight: bold;
}

.btn a.disable,
.btn input.disable,
.btn button.disable,
.btn span.disable {
  opacity: 0.5;
  pointer-events: none;
}

.btn a svg,
.btn input svg,
.btn button svg,
.btn span svg {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  width: 6px;
  height: 10px;
  margin-left: 14px;
  fill: var(--main-color);
  z-index: 5;
}

@media screen and (min-width: 750px) {
  .btn a:hover,
  .btn input:hover,
  .btn button:hover,
  .btn span:hover {
    opacity: 0.6;
  }
  .btn a:hover svg,
  .btn input:hover svg,
  .btn button:hover svg,
  .btn span:hover svg {
    -webkit-transform: translateX(0.37vw);
    transform: translateX(0.37vw);
  }
}

@media screen and (min-width: 750px) {
  .btn span:hover {
    opacity: 1;
  }
}

.btn.center {
  text-align: center;
}

.btn.right {
  text-align: right;
}

.btn.back a svg,
.btn.back input svg,
.btn.back button svg {
  margin-left: 0;
  margin-right: 14px;
}

.btn.wide_m {
  width: 50%;
  margin-left: auto;
  margin-right: auto;
}

.btn.wide_m a,
.btn.wide_m input,
.btn.wide_m button {
  width: 100%;
}

.input_btn {
  position: relative;
  width: 100%;
  max-width: 480px;
}

.input_btn a,
.input_btn button,
.input_btn input {
  font-size: 1.5rem;
  color: var(--main-color);
  padding-bottom: 15px;
  display: block;
  width: 100%;
  border: 1px solid var(--main-color);
  height: 4.39vw;
}

.input_btn svg {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  width: 6px;
  height: 10px;
  fill: var(--main-color);
  position: absolute;
  top: 50%;
  right: 25px;
  margin-left: 0;
  margin-top: -5px;
  z-index: 2;
}

@media screen and (min-width: 750px) {
  .input_btn:hover svg {
    -webkit-transform: translateX(0.37vw);
    transform: translateX(0.37vw);
  }
}

.input_btn.back a,
.input_btn.back button,
.input_btn.back input {
  padding-right: 0;
}

.input_btn.back svg {
  right: auto;
  left: 0;
}

@media screen and (min-width: 750px) {
  .input_btn.back:hover svg {
    -webkit-transform: translateX(-0.37vw);
    transform: translateX(-0.37vw);
  }
}

.btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 60px;
  -webkit-column-gap: 2.2vw;
  -moz-column-gap: 2.2vw;
  column-gap: 2.2vw;
}

.btns .btn a,
.btns .btn input,
.btns .btn button {
  margin: 0 auto;
  display: block;
}

.btns br,
.btns p {
  display: none;
}

.btns.left {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.btns.right {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.btn_more {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 250px;
  margin: auto;
  height: 60px;
  color: var(--main-color);
  border: 1px solid var(--main-color);
  letter-spacing: 0.05em;
  font-size: 1.5rem;
  font-weight: bold;
  padding: 0 20px;
}

@media screen and (min-width: 750px) {
  .btn_more:hover {
    opacity: 0.6 !important;
  }
}

.btn_more svg {
  position: absolute;
  top: 50%;
  right: 1.32vw;
  margin-top: -0.51vw;
  width: 14px;
  height: 14px;
  fill: var(--main-color);
}

.btn_return {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 250px;
  margin: auto;
  height: 60px;
  color: var(--main-color);
  border: 1px solid var(--main-color);
  letter-spacing: 0.05em;
  font-size: 1.5rem;
  font-weight: bold;
  padding: 0 20px;
  position: relative;
}

@media screen and (min-width: 750px) {
  .btn_return:hover {
    opacity: 0.6 !important;
  }
}

.btn_return svg {
  position: absolute;
  top: 50%;
  right: 1.32vw;
  margin-top: -0.44vw;
  width: 7px;
  height: 12px;
  fill: var(--main-color);
}

.btn_readmore {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  font-size: 1.5rem;
  color: var(--main-font-color);
  border-bottom: 1px solid var(--main-color);
  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;
  letter-spacing: 0.08em;
  margin: 0 auto;
  position: relative;
  padding-bottom: 15px;
  width: 320px;
}

@media screen and (min-width: 750px) {
  .btn_readmore:hover {
    opacity: 0.6 !important;
  }
}

.acc {
  -webkit-transition-property: all !important;
  transition-property: all !important;
  background: #f1f1f1;
  color: var(--main-color);
  font-size: 1.6rem;
  cursor: pointer;
  position: relative;
}

.acc.active {
  background: none;
}

.acc.active:after {
  opacity: 1;
  border-color: var(--main-color);
}

.acc.active .q {
  color: var(--main-color);
}

.acc.active .q:before {
  color: var(--main-color);
}

.acc.active .a {
  color: var(--base-font-color);
}

.acc.active .a:before {
  color: var(--main-color);
}

.acc.is_open {
  background: none;
  cursor: initial;
  opacity: 1;
}

.acc.is_open:after {
  opacity: 1;
  border-color: var(--main-color);
}

.acc.is_open .q {
  color: var(--main-color);
}

.acc.is_open .q:before {
  color: var(--main-color);
}

.acc.is_open .a {
  color: var(--base-font-color);
}

.acc.is_open .a:before {
  color: var(--main-color);
}

@media screen and (min-width: 750px) {
  .acc.is_open:hover {
    opacity: 1 !important;
  }
}

@media screen and (min-width: 750px) {
  .acc:hover:after {
    opacity: 1;
    border-color: var(--main-color);
  }
}

.acc:after {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  content: '';
  border: 1px solid transparent;
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.acc .q {
  position: relative;
  padding: 30px 30px 30px 75px;
  font-size: 1.6rem;
  position: relative;
  color: var(--main-color);
  font-weight: 700;
}

.acc .q:before {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  content: 'Q.';
  font-size: 2.4rem;
  line-height: 1;
  position: absolute;
  top: 30px;
  left: 30px;
}

.acc .a {
  position: relative;
  padding: 0 30px 30px 75px;
  font-size: 1.5rem;
}

.acc .a:before {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  content: 'A.';
  font-size: 2.4rem;
  line-height: 1;
  position: absolute;
  top: 0;
  left: 30px;
}

.privacy {
  font-size: 1.4rem;
}

.privacy .privacy_title {
  text-align: center;
  margin-bottom: 30px;
  font-weight: bold;
}

.privacy .privacy_lead,
.privacy .privacy_footer {
  margin-bottom: 30px;
}

.privacy .privacy_contents dl {
  margin-bottom: 15px;
  padding-bottom: 15px;
  position: relative;
}

.privacy .privacy_contents dl:before {
  background-color: var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  opacity: 0.15;
  pointer-events: none;
}

.privacy .privacy_contents dl dt {
  font-weight: bold;
  margin-bottom: 10px;
}

.privacy .privacy_contents dl dd {
  font-size: 1.2rem;
}

.label {
  color: var(--main-color);
  display: inline-block;
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1;
}

.photo {
  position: relative;
  overflow: hidden;
}

@media screen and (min-width: 750px) {
  .photo:hover figcaption {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

.photo figcaption {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  background: var(--grad-color);
  color: var(--main-font-color);
  font-size: 1.2rem;
  padding: 20px;
  letter-spacing: 0.05em;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  display: block;
}

.prof_img a {
  overflow: hidden;
  display: block;
}

.prof_img a img {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}

@media screen and (min-width: 750px) {
  .prof_img a:hover img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

.prof_img figure {
  position: relative;
  overflow: hidden;
}

.prof_img figure img {
  max-width: initial;
  width: 100%;
}

.prof_img .name {
  color: var(--main-color);
  text-align: center;
  padding: 20px 0;
  line-height: 1.5;
}

.prof_img .name span {
  display: block;
  font-size: 1.1rem;
  margin-bottom: 5px;
}

.prof_img .name strong {
  display: block;
  font-size: 1.5rem;
  font-weight: normal;
}

.prof_img.square figure:before {
  content: '';
  display: block;
  padding-top: 100%;
}

.prof_img.square figure img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.card {
  padding: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  cursor: pointer;
  position: relative;
  border-radius: 4px;
}

.card:before {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  border: 1px solid var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  opacity: 0.15;
}

@media screen and (min-width: 750px) {
  .card:hover:before {
    border-color: var(--main-color);
    opacity: 1;
  }
}

.card figure {
  position: relative;
  overflow: hidden;
  width: 80px;
}

.card figure:before {
  content: '';
  display: block;
  padding-top: 100%;
}

.card figure img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.card dl {
  width: calc(100% - 100px);
}

.card dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 10px;
}

.card dl dt strong {
  font-size: 1.8rem;
  font-weight: bold;
}

.card dl dt .label {
  margin-left: 17px;
}

.card dl dd {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.required {
  background: #ec0000;
  border-radius: 10px;
  color: #ffffff;
  font-size: 1rem;
  font-weight: bold;
  display: inline-block;
  line-height: 1;
  padding: 4px 6px;
}

.txt_error {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #db0000;
  font-size: 1.2rem;
  font-weight: bold;
  margin-top: 12px;
  display: none;
}

.txt_error.active {
  display: block;
}

.txt_error svg {
  fill: #db0000;
  width: 13px;
  height: 13px;
  margin-right: 6px;
}

.wysiwyg {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  line-height: 2;
  letter-spacing: 0.08em;
  font-size: 1.02vw;
}

.module_bg {
  background: var(--grad-color);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
  z-index: -1;
}

#wrapper {
  position: relative;
  overflow: hidden;
}

#wrapper #container.under {
  padding-top: 274px;
  padding-bottom: 100px;
}

.inner_contents {
  width: calc(100% - 286px);
  position: relative;
  margin-left: auto;
  margin-right: auto;
}

.inner_contents.wide_l {
  max-width: 1200px;
}

.inner_contents.wide_m {
  max-width: 1080px;
}

.inner_contents.wide_s {
  max-width: 960px;
}

.inner_contents.wide_ss {
  max-width: 640px;
}

.inner_contents.wide_fit_right {
  width: calc(100% - 203px);
  margin-right: 0;
}

#globalHeader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 41;
}

#globalHeader.hide .site_logo,
#globalHeader.hide .header_bg {
  opacity: 0;
}

#globalHeader .inner {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  position: relative;
  padding: 0 30px;
  min-height: 105px;
}

#globalHeader a {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}

@media screen and (min-width: 750px) {
  #globalHeader a:hover {
    opacity: 0.6 !important;
  }
}

#globalHeader .site_logo {
  background-color: #ffffff;
  max-width: 180px;
  max-height: 180px;
  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;
  padding-bottom: 30px;
}

#globalHeader .site_logo a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 20px;
  text-align: center;
}

#globalHeader .site_logo figure {
  width: 100%;
  height: 100%;
}

#globalHeader .site_logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

#globalHeader .site_logo .site_txt {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  width: 100%;
  display: block;
  font-size: 1rem;
  margin-top: 15px;
}

#globalHeader .sitenavi {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 88px;
  color: var(--main-font-color);
}

#globalHeader .sitenavi .navi {
  color: var(--main-font-color);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 100%;
  padding: 0 12px;
  font-weight: bold;
  font-size: 1.4rem;
}

#globalHeader .sitenavi .pc_navi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

#globalHeader .site_sns {
  margin-right: 36px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

#globalHeader .site_sns a {
  margin-left: 20px;
}

#globalHeader .site_sns svg {
  fill: var(--base-font-color);
  margin: 0 auto;
  opacity: 0.5;
}

#globalHeader .header_bg {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  display: none;
}

#btnMenu {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  transition-delay: 0s;
  width: 50px;
  height: 50px;
  position: fixed;
  top: 45px;
  right: 240px;
  z-index: 50;
  display: none;
}

@media screen and (min-width: 750px) {
  #btnMenu:hover {
    opacity: 0.6 !important;
  }
}

#btnMenu span {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  background-color: var(--main-color);
  display: block;
  width: 35px;
  height: 4px;
  border-radius: 4px;
  position: absolute;
  left: 7.5px;
}

#btnMenu span:nth-child(1) {
  top: 7.5px;
}

#btnMenu span:nth-child(2) {
  top: 19px;
}

#btnMenu span:nth-child(3) {
  top: 31.5px;
}

#btnMenu.active {
  background-color: transparent;
}

#btnMenu.active span:nth-child(1) {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 19px;
}

#btnMenu.active span:nth-child(2) {
  opacity: 0;
}

#btnMenu.active span:nth-child(3) {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 19px;
}

@media screen and (min-width: 750px) {
  #btnMenu.active:hover span:nth-child(1) {
    -webkit-transform: rotate(-20deg);
    transform: rotate(-20deg);
  }
  #btnMenu.active:hover span:nth-child(3) {
    -webkit-transform: rotate(20deg);
    transform: rotate(20deg);
  }
}

#globalNavi {
  -webkit-transition-duration: 1s;
  transition-duration: 1s;
  -webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform: translateX(100%);
  transform: translateX(100%);
  background-color: var(--bg-color);
  color: var(--base-font-color);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  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;
  z-index: 40;
  overflow: auto;
}

#globalNavi.active {
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

#globalNavi .inner {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  font-size: 22px;
  text-align: center;
  margin: auto;
  padding: 50px 0;
}

#globalNavi .inner li {
  margin-bottom: 25px;
  letter-spacing: 0.05em;
}

#globalNavi .inner li:last-of-type {
  margin-bottom: 0;
}

#globalNavi .inner a {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}

@media screen and (min-width: 750px) {
  #globalNavi .inner a:hover {
    opacity: 0.6 !important;
  }
}

#breadcrumb {
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  position: absolute;
  top: 130px;
  right: 40px;
}

#breadcrumb a {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}

@media screen and (min-width: 750px) {
  #breadcrumb a:hover {
    color: var(--main-color);
  }
}

#globalFooter {
  background: var(--grad-color);
  color: var(--main-font-color);
  position: relative;
}

#globalFooter .btn_pagetop {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  -webkit-transition-property: opacity;
  transition-property: opacity;
  transition-delay: 0s;
  width: 44px;
  height: 44px;
  position: absolute;
  top: -64px;
  right: 20px;
}

@media screen and (min-width: 750px) {
  #globalFooter .btn_pagetop:hover {
    opacity: 0.6 !important;
  }
}

#globalFooter .btn_pagetop.hide {
  opacity: 0;
}

#globalFooter .btn_pagetop.fixed {
  position: fixed;
  top: auto;
  bottom: 20px;
}

#globalFooter .btn_pagetop svg {
  fill: var(--main-color);
}

#globalFooter .inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 34px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

#globalFooter .main {
  font-size: 1.4rem;
  width: 70%;
}

#globalFooter .sub {
  position: relative;
  width: 30%;
}

#globalFooter .sub .site_sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  padding-bottom: 30px;
}

#globalFooter .sub .site_sns a {
  margin-left: 20px;
}

#globalFooter .sub .site_sns a:first-of-type {
  margin-left: 0;
}

#globalFooter .sub .site_sns svg {
  fill: var(--main-font-color);
}

#globalFooter .sub .copyright {
  position: absolute;
  bottom: 0;
  right: 0;
  font-size: 11px;
}

.is_under #globalHeader .header_bg {
  background-color: #ffffff;
  display: block;
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  overflow: hidden;
  height: 86px;
  -webkit-box-shadow: 0 0 12px rgba(0, 0, 0, 0.1);
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.1);
  opacity: 0;
}

.is_under #globalHeader .navi {
  color: #000000;
}

.is_under #globalHeader .site_logo .site_txt {
  color: #000000;
}

.is_scroll #globalHeader .inner {
  min-height: 86px;
}

.is_scroll #globalHeader .site_logo {
  -webkit-box-shadow: 17px 17px 34px rgba(0, 0, 0, 0.25);
  box-shadow: 17px 17px 34px rgba(0, 0, 0, 0.25);
}

.section-container {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 0 150px;
}

.section-container.wide_l {
  max-width: 1200px;
}

.section-container.wide_s {
  max-width: 960px;
}

.section-container.wide_ss {
  max-width: 640px;
}

.section-container .page_title {
  margin-bottom: 60px;
}

.section-container section {
  margin-bottom: 80px;
}

.section-container section:last-of-type {
  margin-bottom: 0;
}

#is_top #breadcrumb {
  display: none;
}

#is_top #mv {
  position: relative;
  height: calc(100vh - 125px);
  min-height: 700px;
}

#is_top #mv .ic_scroll {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  position: absolute;
  bottom: 0;
  left: 50%;
  color: #ffffff;
  font-size: 1.1rem;
  z-index: 10;
  height: 72px;
}

#is_top #mv .ic_scroll:before {
  background-color: #ffffff;
  content: '';
  display: block;
  width: 1px;
  height: 50px;
  position: absolute;
  top: 22px;
  left: 50%;
}

#is_top #mv .site_sns {
  position: absolute;
  top: calc(50% - 62.5px);
  right: 26px;
  z-index: 10;
}

#is_top #mv .site_sns a {
  margin-bottom: 20px;
}

#is_top #mv .site_sns a:last-of-type {
  margin-bottom: 0;
}

#is_top #mv .site_sns svg {
  fill: var(--main-font-color);
  margin: 0 auto;
}

#is_top #mv .mv_txt {
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  position: absolute;
  top: 50%;
  left: 83px;
  width: calc(100% - 166px);
  color: var(--main-font-color);
  z-index: 10;
  text-align: var(--mv-align);
}

#is_top #mv .mv_txt .mv_title {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  -webkit-transition-duration: 0s;
  transition-duration: 0s;
  font-size: 8rem;
  line-height: 1.2;
  margin-bottom: 20px;
}

#is_top #mv .mv_txt .mv_title.action {
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

#is_top #mv .mv_txt .mv_subtitle {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  -webkit-transition-duration: 0s;
  transition-duration: 0s;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
  font-size: 2.4rem;
  letter-spacing: 0.18em;
  line-height: 1.5;
}

#is_top #mv .mv_txt .mv_subtitle.action {
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

#is_top #mv .mv_slider {
  position: relative;
  height: 100%;
}

#is_top #mv .mv_slider .swiper {
  height: 100%;
}

#is_top #mv .mv_slider .swiper .swiper-container {
  height: 100%;
}

#is_top #mv .mv_slider .swiper-slide {
  position: relative;
  height: 100%;
  width: 100%;
}

#is_top #mv .mv_slider .swiper-slide:after {
  background-color: #000000;
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  opacity: var(--mv-overlay);
}

#is_top #mv .mv_slider .swiper-slide .mv_movie {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}

#is_top #mv .mv_slider .swiper-slide .mv_movie video {
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  pointer-events: none;
}

#is_top #mv .mv_slider .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}

#is_top #mv .mv_slider .swiper-pagination {
  bottom: 30px;
  left: 83px;
  z-index: 10;
}

#is_top .mv-news .inner_contents {
  width: 1080px;
  margin-left: auto;
  margin-right: auto;
  color: var(--main-color);
  position: relative;
}

#is_top .mv-news .title {
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
  font-size: 1.2rem;
  font-weight: bold;
  position: absolute;
  top: 50%;
  left: -60px;
}

#is_top .mv-news .content {
  position: relative;
  font-size: 1.4rem;
}

#is_top .mv-news .content:after {
  background-color: var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  opacity: 0.15;
  position: absolute;
  bottom: 0;
  left: 0;
}

#is_top .mv-news .content a {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  min-height: 125px;
}

@media screen and (min-width: 750px) {
  #is_top .mv-news .content a:hover {
    opacity: 0.6 !important;
  }
}

#is_top .mv-news .content .date {
  margin-right: 30px;
}

#is_top .mv-news .content .txt {
  font-weight: bold;
}

#is_top .mv-news .content svg {
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  position: absolute;
  top: 50%;
  right: 0;
  width: 6px;
  height: 10px;
  fill: var(--main-color);
}

#is_top .adjust_sp {
  position: relative;
}

#is_top #map {
  height: 525px;
}

#is_top #map iframe {
  width: 100%;
  height: 100%;
}

.blog_header {
  position: relative;
  margin-bottom: 100px;
}

.archive_link {
  position: absolute;
  bottom: -50px;
  right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.archive_link .select {
  margin-left: 40px;
  position: relative;
  padding-right: 18px;
}

.archive_link .select:first-child {
  margin-left: 0;
}

.archive_link .select svg {
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  position: absolute;
  top: 50%;
  right: 0;
  width: 12px;
  height: 7px;
  margin-left: 5px;
  pointer-events: none;
  fill: var(--main-color);
}

.blog .entry header .info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 10px;
}

.blog .entry header .info .label {
  margin-right: 10px;
  font-size: 1.2rem;
  border: 1px solid var(--main-color);
  border-radius: 0.15vw;
  padding: 0.37vw 0.59vw;
}

.blog .entry header .info .date {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  color: var(--base-font-color);
  opacity: 0.5;
  font-weight: bold;
  font-size: 1.2rem;
}

.blog .entry header h1 {
  font-size: 1.3rem;
  font-weight: bold;
  line-height: 1.7;
  letter-spacing: 0.08em;
}

.blog.archive {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.blog.archive .entry {
  width: calc(33.3% - 20px);
  margin-right: 30px;
  margin-bottom: 60px;
}

.blog.archive .entry:nth-child(3n) {
  margin-right: 0;
}

.blog.archive .entry a {
  overflow: hidden;
}

.blog.archive .entry a img {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}

@media screen and (min-width: 750px) {
  .blog.archive .entry a:hover img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

.blog.archive .entry figure {
  background-color: #ffffff;
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
}

.blog.archive .entry figure:before {
  content: '';
  display: block;
  padding-top: 70.5%;
}

.blog.archive .entry figure img {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  vertical-align: bottom;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.blog.detail .page_title {
  margin-bottom: 70px;
}

.blog.detail .entry {
  margin-bottom: 150px;
}

.blog.detail .mv {
  margin-bottom: 20px;
  text-align: center;
  overflow: hidden;
}

.blog.detail header {
  position: relative;
  margin-bottom: 60px;
  padding-bottom: 40px;
}

.blog.detail header:after {
  background-color: var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  opacity: 0.15;
  position: absolute;
  bottom: 0;
  left: 0;
}

.blog.detail header h1 {
  color: var(--base-font-color);
}

.blog.detail header .date {
  margin-bottom: 0;
}

.blog.detail .contents {
  letter-spacing: 0.15em;
}

.blog.detail .contents h1,
.blog.detail .contents h2,
.blog.detail .contents h3,
.blog.detail .contents h4,
.blog.detail .contents h5,
.blog.detail .contents h6 {
  font-weight: bold;
  margin-bottom: 25px;
}

.blog.detail .contents h1 {
  font-size: 2.1rem;
}

.blog.detail .contents h2 {
  font-size: 1.9rem;
}

.blog.detail .contents h3 {
  font-size: 1.7rem;
}

.blog.detail .contents h4,
.blog.detail .contents h5,
.blog.detail .contents h6 {
  font-size: 1.5rem;
}

.blog.detail .contents p,
.blog.detail .contents ol,
.blog.detail .contents ul,
.blog.detail .contents table,
.blog.detail .contents dl {
  margin-bottom: 40px;
}

.blog.detail .contents a {
  color: #ec0000;
  text-decoration: underline;
}

@media screen and (min-width: 750px) {
  .blog.detail .contents a:hover {
    text-decoration: none;
  }
}

.blog.detail .contents ul li {
  list-style: disc;
  margin-left: 20px;
}

.blog.detail .contents ol li {
  list-style: decimal;
  margin-left: 20px;
}

.blog.detail .contents img {
  border-radius: 20px;
}

#is_contact .page_title {
  margin-bottom: 70px;
}

#is_contact .message {
  margin-bottom: 70px;
  text-align: center;
}

#is_contact .message p {
  margin-bottom: 30px;
}

#is_contact .form .form_txt {
  text-align: center;
  margin-bottom: 40px;
  margin-top: 60px;
  letter-spacing: 0.08em;
  font-size: 1.2rem;
}

#is_contact .form .privacy {
  position: relative;
  margin-bottom: 65px;
}

#is_contact .form .privacy:before {
  border: 1px solid var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0.15;
  pointer-events: none;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

#is_contact .form .privacy .scroll_area {
  height: 260px;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 35px 25px;
  position: relative;
}

#is_contact .form .privacy_check {
  text-align: center;
}

#is_contact .form .privacy_check .mwform-checkbox-field {
  margin-bottom: 20px;
  letter-spacing: 0.08em;
}

#is_contact .form .privacy_check .error {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

#is_contact .form .mw_wp_form_send_error {
  text-align: center;
}

#sectionNews .contents ul {
  margin-bottom: 150px;
}

#sectionNews .contents .entry {
  border-bottom: 1px solid rgba(0, 0, 0, 0.15);
  padding: 40px 0;
}

#sectionNews .contents .entry:first-child {
  border-top: 1px solid rgba(0, 0, 0, 0.15);
}

#sectionNews .contents .entry .entry_header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#sectionNews .contents .entry .entry_header .date {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  width: 115px;
  font-size: 1.5rem;
  font-weight: bold;
  color: var(--base-font-color);
  opacity: 0.5;
}

#sectionNews .contents .entry .entry_header .txt {
  width: calc(100% - 115px);
  color: var(--base-font-color);
  font-size: 1.5rem;
  font-weight: bold;
}

#sectionNews .contents .entry .entry_body {
  width: calc(100% - 115px);
  margin: 30px 0 0 auto;
  font-size: 1.5rem;
}

.cover-bg {
  position: relative;
}

.cover-bg .inner_contents {
  padding-bottom: 170px;
}

.cover-bg .bg {
  position: relative;
  display: block;
  width: 100%;
}

.cover-bg .bg figure {
  position: relative;
  min-height: 32.21vw;
  display: block;
}

.cover-bg .bg figure:before {
  content: '';
  display: block;
  padding-top: 56%;
}

.cover-bg .bg figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  -o-object-fit: cover;
  object-fit: cover;
}

.cover-bg .bg .sec_title {
  -webkit-transform: translateX(-100%) rotate(-90deg);
  transform: translateX(-100%) rotate(-90deg);
  -webkit-transform-origin: 100% 100%;
  transform-origin: 100% 100%;
  position: absolute;
  top: -10px;
  left: -30px;
}

.cover-bg .contents {
  position: absolute;
  width: 36%;
  background-color: #ffffff;
  width: 380px;
  bottom: 0;
  right: 60px;
}

.cover-bg .contents .inner {
  padding: 50px;
}

.cover-bg .contents .title {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  color: var(--main-color);
  font-size: 2.4rem;
  line-height: 1.5;
  margin-bottom: 40px;
}

.cover-bg .contents .txt {
  margin-bottom: 50px;
  text-align: left;
}

.cover-bg .btn_readmore {
  color: #ffffff;
}

.image-panel {
  position: relative;
}

.image-panel:before {
  background-color: var(--main-color);
  content: '';
  display: block;
  width: 74.2vw;
  height: 100%;
  position: absolute;
  top: 0;
  opacity: 0.1;
}

.image-panel .inner_contents {
  padding-top: 120px;
  padding-bottom: 120px;
}

.image-panel .bg {
  position: relative;
  display: block;
  width: 51.24vw;
}

.image-panel .bg figure {
  position: relative;
  min-height: 39.53vw;
  display: block;
}

.image-panel .bg figure:before {
  content: '';
  display: block;
  padding-top: 56%;
}

.image-panel .bg figure img {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  -o-object-fit: cover;
  object-fit: cover;
}

.image-panel .bg .sec_title {
  -webkit-transform: translateX(-100%) rotate(-90deg);
  transform: translateX(-100%) rotate(-90deg);
  -webkit-transform-origin: 100% 100%;
  transform-origin: 100% 100%;
  position: absolute;
  top: 0;
}

.image-panel .contents {
  position: absolute;
  width: 20.5vw;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  top: 50%;
}

.image-panel .contents .title {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  color: var(--main-color);
  font-size: 2.4rem;
  line-height: 1.5;
  margin-bottom: 40px;
}

.image-panel .contents .txt {
  margin-bottom: 50px;
  text-align: left;
}

.image-panel.left:before {
  left: 0;
}

.image-panel.left .bg .sec_title {
  -webkit-transform: translateX(100%) rotate(90deg);
  transform: translateX(100%) rotate(90deg);
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
  top: -10px;
  right: -30px;
  left: auto;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.image-panel.left .contents {
  right: 0;
}

.image-panel.right:before {
  right: 0;
}

.image-panel.right .bg {
  margin-left: auto;
}

.image-panel.right .bg .sec_title {
  top: -10px;
  left: -30px;
}

.image-panel.right .contents {
  left: 0;
}

.column-banner .module_bg {
  left: auto;
  right: 0;
  width: 74.2vw;
}

.column-banner .swiper {
  margin-bottom: 80px;
}

.column-banner .swipe_controls {
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  left: 50%;
  width: 100%;
}

.column-banner .swipe_controls.wide_l {
  max-width: 1200px;
}

.column-banner .swipe_controls.wide_m {
  max-width: 1080px;
}

.column-banner .swipe_controls.wide_s {
  max-width: 960px;
}

.column-banner .swipe_controls.wide_ss {
  max-width: 640px;
}

.column-banner .btn {
  margin-top: 60px;
}

.ap-slideshow {
  position: relative;
}

.ap-slideshow .module_bg {
  left: 0;
  right: auto;
  width: 83.7vw;
}

.ap-slideshow .sec_title {
  -webkit-transform: translateX(100%) rotate(90deg);
  transform: translateX(100%) rotate(90deg);
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
  top: -10px;
  right: -45px;
  left: auto;
}

.ap-slideshow .swiper {
  width: calc(100% - 210px);
  padding-bottom: 0;
  position: relative;
}

.ap-slideshow .swiper .swiper-container {
  overflow: initial;
}

.ap-slideshow .swiper .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.ap-slideshow .swiper .swiper-slide figcaption {
  position: absolute;
  top: 85px;
  right: -210px;
  width: 180px;
  font-size: 1.3rem;
  line-height: 2;
  letter-spacing: 0.05em;
  opacity: 0;
}

.ap-slideshow .swiper .swiper-slide.swiper-slide-active figcaption {
  opacity: 1;
}

.ap-slideshow .swiper .swiper-pagination {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  color: var(--main-color);
  font-weight: bold;
  position: absolute;
  top: 40px;
  right: -55px;
  left: auto;
  width: auto;
  font-size: 1.3rem;
}

.ap-slideshow .swiper .swipe_controls {
  right: -210px;
  left: auto;
  bottom: 100px;
}

.ap-table .table-block {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  padding: 60px;
  display: block;
  position: relative;
  margin-bottom: 40px;
}

.ap-table .table-block:last-child {
  margin-bottom: 0;
}

.ap-table .table-block:before {
  background-color: #ffffff;
  border: 1px solid rgba(68, 68, 68, 0.15);
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.ap-table .table-block .lead {
  margin-bottom: 50px;
}

.ap-table .table-block .lead dt {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  color: var(--main-color);
  font-size: 2.4rem;
  line-height: 1.5;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--main-color);
  padding-bottom: 1.46vw;
}

.ap-table .table-block .lead dd {
  font-size: 1.5rem;
}

.ap-table .table-block .table_wrap {
  border: 1px solid rgba(68, 68, 68, 0.15);
}

.ap-table .table-block .unit {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 15px 30px;
  font-size: 1.5rem;
}

.ap-table .table-block .unit:before {
  border-top: 1px solid rgba(68, 68, 68, 0.15);
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.ap-table .table-block .unit:first-child:before {
  display: none;
}

.ap-table .table-block .unit dt {
  width: 155px;
  font-weight: bold;
}

.ap-table .table-block .unit dd {
  width: calc(100% - 155px);
}

@media screen and (min-width: 750px) {
  .ap-table a.table-block:hover {
    opacity: 0.7;
  }
}

.vertical-text .module_bg {
  left: 0;
  right: auto;
  width: 83.7vw;
}

.vertical-text .sec_title {
  text-align: center;
  margin-bottom: 60px;
}

.vertical-text .sec_title strong {
  margin-left: 0;
}

.vertical-text .row {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  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-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  width: 100%;
}

.vertical-text .row .title {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  color: var(--main-color);
  font-size: 2.4rem;
  line-height: 1.5;
  margin-left: 60px;
}

.vertical-text .row .txt {
  font-size: 1.4rem;
  line-height: 2;
}

.vertical-text .row .txt > * {
  margin-left: 30px;
}

.vertical-text .row .txt > *:last-child {
  margin-left: 0;
}

.freearea .module_bg {
  left: 0;
  right: auto;
  width: 83.7vw;
}

.freearea .sec_title {
  -webkit-transform: translateX(100%) rotate(90deg);
  transform: translateX(100%) rotate(90deg);
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
  top: -10px;
  right: -45px;
  left: auto;
}

.ap-blog .module_bg {
  left: auto;
  right: 0;
  width: 74.2vw;
}

.ap-blog .blog.archive {
  display: block;
}

.ap-blog .blog.archive .swiper {
  width: 100%;
}

.ap-blog .blog.archive .entry {
  width: 334px;
  margin-right: 0;
  margin-bottom: 0;
}

.ap-blog .blog.archive .entry figure {
  position: relative;
  overflow: initial;
}

.ap-blog .blog.archive .entry figure:before {
  display: none;
}

.ap-blog .blog.archive .entry figure div {
  background-color: #ffffff;
  position: relative;
  z-index: 5;
  overflow: hidden;
}

.ap-blog .blog.archive .entry figure div:before {
  content: '';
  display: block;
  padding-top: 70.5%;
}

.ap-blog .blog.archive .entry figure img {
  z-index: 5;
}

.ap-news {
  position: relative;
  z-index: 10;
}

.ap-news .module_bg {
  left: auto;
  right: 0;
  width: 74.2vw;
}

.ap-news .inner_contents {
  color: var(--base-font-color);
}

.ap-news .title {
  font-family: var(--font-family-en);
  font-weight: var(--font-weight-en);
  font-size: 2rem;
  margin-bottom: 40px;
}

.ap-news .content ul {
  margin-bottom: 20px;
}

.ap-news .content ul li {
  margin-bottom: 24px;
  padding-bottom: 24px;
  position: relative;
}

.ap-news .content ul li:after {
  background-color: var(--base-font-color);
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  opacity: 0.2;
  position: absolute;
  bottom: 0;
  left: 0;
}

.ap-news .content ul li:last-of-type {
  margin-bottom: 0;
}

.ap-news .content ul li a {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
}

@media screen and (min-width: 750px) {
  .ap-news .content ul li a:hover {
    opacity: 0.6 !important;
  }
}

.ap-news .content ul li svg {
  position: absolute;
  top: 50%;
  right: 0;
  width: 7px;
  height: 12px;
  fill: var(--main-color);
}

.ap-news .content ul li .date {
  margin-right: 30px;
  font-size: 1.5rem;
  font-weight: bold;
  color: var(--base-font-color);
  opacity: 0.5;
}

.ap-news .content ul li .txt {
  color: var(--base-font-color);
  font-size: 1.5rem;
  font-weight: bold;
}

.ap-news .btns {
  display: none;
}

.detail-section {
  position: relative;
}

.detail-anchor {
  max-width: 1080px;
  margin: 0 auto 150px;
  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;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-column-gap: 30px;
  -moz-column-gap: 30px;
  column-gap: 30px;
  row-gap: 30px;
  font-size: 1.5rem;
  line-height: 2;
  font-weight: bold;
}

.detail-anchor li a {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  position: relative;
  display: block;
  padding-bottom: 5px;
}

.detail-anchor li a:after {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: var(--main-color);
  content: '';
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 1.5px;
  position: absolute;
  bottom: 0;
  left: 50%;
  opacity: 0;
}

@media screen and (min-width: 750px) {
  .detail-anchor li a:hover:after {
    opacity: 1;
  }
}

.detail-anchor_sp {
  display: none;
}

.detail-title {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  color: var(--main-color);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 50px;
  letter-spacing: 0.08em;
  position: relative;
}

.detail-text {
  margin-bottom: 50px;
}

.detail-vertical {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  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-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  width: 100%;
  margin-bottom: 50px;
}

.detail-vertical .title {
  font-family: var(--font-family-ja);
  font-weight: var(--font-weight-ja);
  color: var(--main-color);
  font-size: 2.4rem;
  line-height: 1.5;
  margin-left: 60px;
}

.detail-vertical .txt {
  font-size: 1.5rem;
  line-height: 2;
  letter-spacing: 0.08em;
}

.detail-vertical .txt > * {
  margin-left: 30px;
}

.detail-vertical .txt > *:last-child {
  margin-left: 0;
}

.detail-list {
  margin: 0 auto 50px;
  max-width: 640px;
}

.detail-list li {
  margin-bottom: 25px;
  position: relative;
  padding-left: 20px;
}

.detail-list li:last-child {
  margin-bottom: 0;
}

ul.detail-list li:before {
  background-color: var(--main-color);
  content: '';
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: absolute;
  top: 10px;
  left: 0;
}

ol.detail-list {
  counter-reset: ol_li;
}

ol.detail-list li:before {
  counter-increment: ol_li;
  /* ol_li カウンタの値に1加える */
  content: counter(ol_li) ".";
  color: var(--main-color);
  position: absolute;
  top: 0;
  left: 0;
}

ol.detail-list svg {
  display: none;
}

.lecture_list_wrap {
  border: 1px solid rgba(68, 68, 68, 0.15);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 53px;
  padding: 50px 60px;
}

.detail-lecture {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  padding-bottom: 50px;
}

.detail-lecture:after {
  -webkit-transform: translatex(-50%);
  transform: translatex(-50%);
  background-color: rgba(68, 68, 68, 0.15);
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 50%;
}

.detail-lecture:last-of-type {
  padding-bottom: 0;
}

.detail-lecture:last-of-type:after {
  display: none;
}

.detail-lecture dt {
  width: 185px;
  padding-right: 50px;
  font-weight: bold;
}

.detail-lecture dd {
  width: calc(100% - 185px);
  position: relative;
  padding-left: 50px;
}

.detail-swiper {
  margin-bottom: 50px;
}

.detail-swiper .swiper-container {
  padding-bottom: 20px;
  width: 100%;
}

.detail-swiper .swipe_controls {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 24px;
}

.detail-swiper .swipe_controls .swiper-button-next,
.detail-swiper .swipe_controls .swiper-button-prev {
  position: relative;
  top: 0;
  left: 0;
  margin: 0;
}

.detail-swiper .swipe_controls .swiper-button-prev {
  margin-right: 34px;
}

.detail-swiper .swiper-button-disabled {
  display: none;
}

.detail-swiper .swiper-button-prev,
.detail-swiper .swiper-button-next {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: color, opacity;
  transition-property: color, opacity;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  width: 12px;
  height: 24px;
}

@media screen and (min-width: 750px) {
  .detail-swiper .swiper-button-prev:hover,
  .detail-swiper .swiper-button-next:hover {
    opacity: 0.6 !important;
  }
}

.detail-swiper .swiper-button-prev:after,
.detail-swiper .swiper-button-next:after {
  display: none;
}

.detail-swiper .swiper-button-prev svg,
.detail-swiper .swiper-button-next svg {
  fill: var(--main-color);
}

.detail-swiper .swiper-button-next {
  right: -60px;
}

.detail-swiper .swiper-button-prev {
  left: -60px;
}

.detail-swiper .swiper-pagination {
  bottom: 0;
  left: 0;
  text-align: left;
}

.detail-swiper .swiper-pagination .swiper-pagination-bullet {
  background-color: var(--main-color);
  width: 60px;
  height: 3px;
  margin: 0 15px 0 0 !important;
  opacity: 0.35;
  border-radius: 0;
}

.detail-swiper .swiper-pagination .swiper-pagination-bullet-active {
  opacity: 1;
}

.detail-swiper .swiper-slide {
  padding-bottom: 20px;
}

.detail-swiper .detail-slide-figure {
  width: 100%;
  position: relative;
}

.detail-swiper .detail-slide-figure div {
  position: relative;
  overflow: hidden;
}

.detail-swiper .detail-slide-figure div:before {
  padding-top: 63%;
  content: '';
  display: block;
}

.detail-swiper .detail-slide-figure div img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.detail-swiper .detail-slide-figure a {
  overflow: hidden;
  display: block;
  overflow: hidden;
}

.detail-swiper .detail-slide-figure a img {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}

@media screen and (min-width: 750px) {
  .detail-swiper .detail-slide-figure a:hover img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

.detail-swiper .detail-slide-figure img {
  width: 100%;
  max-width: initial;
}

.detail-swiper .detail-slide-figure figcaption {
  padding-top: 15px;
}

.detail-image-side {
  margin-bottom: 90px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.detail-image-side .img {
  width: calc(50% + 175px);
  position: relative;
}

.detail-image-side .img div {
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.detail-image-side .img img {
  max-width: initial;
  width: 100%;
}

.detail-image-side .txt {
  width: calc(50% - 25px);
}

.detail-image-side .txt .title {
  font-size: 2.4rem;
  margin-bottom: 30px;
  letter-spacing: 0.08em;
  color: var(--main-color);
}

.detail-image-side.left .img {
  margin-left: -205px;
}

.detail-image-side.right {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.detail-image-side.right .img {
  margin-right: -205px;
}

.detail-image-column {
  display: grid;
  margin-bottom: 50px;
}

.detail-image-column .detail-image-column-unit .img {
  margin-bottom: 20px;
  position: relative;
}

.detail-image-column .detail-image-column-unit .img div {
  position: relative;
  overflow: hidden;
}

.detail-image-column .detail-image-column-unit .img img {
  width: 100%;
  max-width: initial;
}

.detail-image-column .detail-image-column-unit .title {
  line-height: 1.6;
  margin-bottom: 15px;
  letter-spacing: 0.08em;
  color: var(--main-color);
}

.detail-image-column.column-2 {
  row-gap: 60px;
  -webkit-column-gap: 50px;
  -moz-column-gap: 50px;
  column-gap: 50px;
  grid-template-columns: repeat(2, 1fr);
}

.detail-image-column.column-2 .detail-image-column-unit .title {
  font-size: 2rem;
}

.detail-image-column.column-3 {
  row-gap: 30px;
  -webkit-column-gap: 30px;
  -moz-column-gap: 30px;
  column-gap: 30px;
  grid-template-columns: repeat(3, 1fr);
}

.detail-image-column.column-3 .detail-image-column-unit .title {
  font-size: 1.6rem;
}

.detail-column {
  margin-bottom: 50px;
  border: 1px solid rgba(68, 68, 68, 0.15);
  position: relative;
  padding: 60px;
}

.detail-column .title {
  font-size: 2.4rem;
  color: var(--main-color);
  border-bottom: 1px solid var(--main-color);
  margin-bottom: 35px;
  position: relative;
  padding: 0 0 20px;
}

.detail-column .contents {
  display: grid;
  -webkit-column-gap: 40px;
  -moz-column-gap: 40px;
  column-gap: 40px;
  grid-template-columns: repeat(2, 1fr);
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.detail-column .img {
  overflow: hidden;
}

.detail-baloon {
  margin-bottom: 50px;
}

.detail-baloon .detail-baloon-unit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin-bottom: 50px;
}

.detail-baloon .detail-baloon-unit:last-of-type {
  margin-bottom: 0;
}

.detail-baloon .detail-baloon-unit .img {
  width: 120px;
}

.detail-baloon .detail-baloon-unit .img div {
  width: 120px;
  height: 120px;
  border-radius: 100%;
  overflow: hidden;
}

.detail-baloon .detail-baloon-unit .img div img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.detail-baloon .detail-baloon-unit .img figcaption {
  font-size: 1.4rem;
  text-align: center;
  margin-top: 10px;
}

.detail-baloon .detail-baloon-unit .txt {
  background-color: #ffffff;
  border: 1px solid rgba(68, 68, 68, 0.15);
  padding: 35px 40px;
  width: calc(100% - 150px);
}

.detail-baloon .detail-baloon-unit.img_right {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.detail-profile {
  margin-bottom: 50px;
  display: grid;
  row-gap: 50px;
  -webkit-column-gap: 50px;
  -moz-column-gap: 50px;
  column-gap: 50px;
  grid-template-columns: repeat(3, 1fr);
}

.detail-profile.center {
  grid-template-columns: initial;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.detail-profile .detail-profile-unit {
  max-width: 280px;
}

.detail-profile .detail-profile-unit .img {
  width: 210px;
  height: 210px;
  overflow: hidden;
  margin: 0 auto 20px;
}

.detail-profile .detail-profile-unit .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.detail-profile .detail-profile-unit .txt dt {
  color: var(--main-color);
  letter-spacing: 0.08em;
  font-size: 1.6rem;
  text-align: center;
  margin-bottom: 10px;
}

.detail-profile .detail-profile-unit .txt dd {
  font-weight: 400;
}

.detail-faq {
  margin-bottom: 50px;
}

.detail-faq .detail-faq-unit {
  margin-bottom: 20px;
}

.detail-faq .detail-faq-unit:last-of-type {
  margin-bottom: 0;
}

.detail-table {
  margin-bottom: 50px;
}

.detail-table .table_header {
  margin-bottom: 40px;
}

.detail-table .table_header .title {
  font-size: 2.4rem;
  margin-bottom: 20px;
  position: relative;
  padding: 0 0 20px;
  line-height: 1.5;
  color: var(--main-color);
  letter-spacing: 0.08em;
  border-bottom: 1px solid var(--main-color);
}

.detail-table .detail-table_unit {
  border-bottom: 1px solid rgba(0, 0, 0, 0.15);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 25px 30px;
}

.detail-table .detail-table_unit:last-child {
  border: none;
}

.detail-table .detail-table_unit dt {
  width: 130px;
  font-weight: bold;
}

.detail-table .detail-table_unit dd {
  width: calc(100% - 130px);
}

.detail-button {
  margin-bottom: 50px;
}

.detail-button a {
  min-width: 480px;
}

@media screen and (min-width: 2560px) {
  body {
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  body {
    font-size: 1.46vw;
  }
  .modal {
    -webkit-transition-duration: 1s;
    transition-duration: 1s;
    -webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    background-color: var(--bg-color);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 99;
  }
  .modal.active {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  .modal .btn_modal_close {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    position: absolute;
    top: 2.93vw;
    right: 2.93vw;
    width: 3.13vw;
    height: 3.13vw;
    cursor: pointer;
    z-index: 10;
  }
  .modal .btn_modal_close:before, .modal .btn_modal_close:after {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    background-color: var(--base-font-color);
    content: '';
    display: block;
    width: 4.3vw;
    height: 0.2vw;
    border-radius: 1px;
    position: absolute;
    top: 50%;
    left: 50%;
    opacity: 0.5;
  }
  .modal .btn_modal_close:before {
    -webkit-transform: translate(-50%, -50%) rotate(-45deg);
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  .modal .btn_modal_close:after {
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
    transform: translate(-50%, -50%) rotate(45deg);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .modal .btn_modal_close:hover {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .modal .modal_container {
    position: relative;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    margin: auto;
  }
  .modal .modal_contents {
    max-width: 105.47vw;
    margin: 0 auto;
    padding: 14.65vw 0;
  }
  .modal .modal_contents.wide_l {
    max-width: 117.19vw;
  }
  .modal .modal_contents.wide_s {
    max-width: 93.75vw;
  }
  .modal .modal_contents.wide_ss {
    max-width: 62.5vw;
  }
  .modal .modal_contents section {
    margin-bottom: 7.81vw;
  }
  .modal .modal_contents section:last-of-type {
    margin-bottom: 0;
  }
  .img_unit {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .img_unit.reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
  .img_unit.reverse .img {
    margin-right: 0;
    margin-left: 3.91vw;
  }
  .img_unit.bdr_btm {
    position: relative;
    padding-bottom: 4.88vw;
    margin-bottom: 3.42vw;
  }
  .img_unit.bdr_btm:after {
    background-color: var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    opacity: 0.15;
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .img_unit.noimage .txt {
    width: 100% !important;
  }
  .img_unit .img {
    margin-right: 3.91vw;
  }
  .img_unit .txt h2 {
    margin-bottom: 2.44vw;
    font-weight: bold;
  }
  .img_unit .txt p {
    margin-bottom: 2.93vw;
  }
  .img_unit .txt p:last-of-type {
    margin-bottom: 0;
  }
  .table_unit dl {
    position: relative;
    padding: 2.93vw 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .table_unit dl:after {
    background-color: var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    opacity: 0.15;
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .table_unit dl dt {
    width: 20.51vw;
    padding: 0 2.93vw;
  }
  .table_unit dl dd {
    width: calc(100% - 20.51vw);
  }
  .table_unit dl dd p {
    margin-bottom: 2.93vw;
  }
  .table_unit dl dd p:last-of-type {
    margin-bottom: 0;
  }
  .thumb_unit {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .thumb_unit figure {
    width: calc(33.3% - 2.73vw);
    margin: 0 4.1vw 3.91vw 0;
  }
  .thumb_unit figure:nth-child(3n) {
    margin-right: 0;
  }
  .thumb_unit figure figcaption {
    margin-top: 1.17vw;
    font-size: 1.17vw;
    letter-spacing: 0.05em;
    line-height: 1.5;
  }
  .form_unit {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
  }
  .form_unit:before {
    background-color: var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    opacity: 0.15;
    pointer-events: none;
  }
  .form_unit dt {
    width: 21.97vw;
    padding: 2.54vw 2.93vw 2.54vw 0;
    font-size: 1.37vw;
    font-weight: bold;
    text-align: right;
  }
  .form_unit dt .required {
    margin-left: 0.68vw;
    vertical-align: middle;
  }
  .form_unit dd {
    width: calc(100% - 21.97vw);
    padding: 1.17vw 0;
  }
  .form_unit .row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 0.98vw;
  }
  .form_unit .row:last-of-type {
    margin-bottom: 0;
  }
  .form_unit .row.nowrap {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }
  .form_unit .col {
    margin-right: 1.17vw;
  }
  .form_unit .col.input_half {
    width: 50%;
  }
  .form_unit .col.input_mini {
    width: 25%;
  }
  .form_unit .radio,
  .form_unit .checkbox {
    height: 4.3vw;
  }
  .form_unit .radio > *,
  .form_unit .checkbox > * {
    margin-right: 2.93vw;
  }
  .form_unit .select {
    position: relative;
  }
  .form_unit .select svg {
    width: 0.98vw;
    height: 0.49vw;
    position: absolute;
    top: 50%;
    right: 0.98vw;
    margin-top: -0.24vw;
    pointer-events: none;
  }
  .form_unit .mwform-file-delete {
    display: none;
  }
  .form_unit .p-form__file_label {
    cursor: pointer;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 1.37vw;
  }
  .form_unit .p-form__file_label .p-form__file_txt {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    background: var(--grad-color);
    color: #ffffff;
    width: 11.72vw;
    height: 3.91vw;
    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;
    font-weight: bold;
    border-radius: 0.29vw;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .form_unit .p-form__file_label .p-form__file_txt:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .form_unit .p-form__file_label .p-form__file_name {
    margin-left: 1.46vw;
    font-weight: bold;
  }
  .form_unit .p-form__file_label input {
    display: none !important;
  }
  .form_unit .note {
    font-size: 1.37vw;
  }
  .form_unit input[type='text'],
  .form_unit input[type='email'],
  .form_unit input[type='tel'],
  .form_unit input[type='url'],
  .form_unit input[type='password'] {
    background-color: #ffffff;
    color: #000000;
    border: 1px solid var(--base-font-color-op);
    border-radius: 0.49vw;
    padding: 0 1.76vw;
    line-height: 1;
    letter-spacing: 0.08em;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    height: 4.3vw;
    display: block;
  }
  .form_unit input[type='text']:focus,
  .form_unit input[type='email']:focus,
  .form_unit input[type='tel']:focus,
  .form_unit input[type='url']:focus,
  .form_unit input[type='password']:focus {
    background-color: #f5f5f5;
    border-color: var(--main-color);
    border-width: 2px;
  }
  .form_unit input[type='text'].error,
  .form_unit input[type='email'].error,
  .form_unit input[type='tel'].error,
  .form_unit input[type='url'].error,
  .form_unit input[type='password'].error {
    background-color: #ffdddd;
    border-color: #ec0000;
  }
  .form_unit select {
    background-color: #ffffff;
    color: #000000;
    border: 1px solid var(--base-font-color-op);
    border-radius: 0.49vw;
    padding: 0 4.88vw 0 1.76vw;
    line-height: 1;
    letter-spacing: 0.08em;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    height: 4.3vw;
    display: block;
  }
  .form_unit select:focus {
    border-color: var(--main-color);
    border-width: 2px;
  }
  .form_unit select option {
    background-color: #ffffff;
  }
  .form_unit select.error {
    background-color: #ffdddd;
    border-color: #ec0000;
  }
  .form_unit textarea {
    background-color: #ffffff;
    color: #000000;
    border: 1px solid var(--base-font-color-op);
    border-radius: 0.49vw;
    width: 100%;
    height: 15.63vw;
    padding: 1.76vw;
  }
  .form_unit textarea:focus {
    background-color: #f5f5f5;
    border-color: var(--main-color);
    border-width: 2px;
  }
  .form_unit textarea.error {
    background-color: #ffdddd;
    border-color: #ec0000;
  }
  .form_unit.confirm dd {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .form_unit.confirm .row {
    margin-bottom: 0;
  }
  .form_unit.confirm .select svg {
    display: none;
  }
  .form_unit.confirm .p-form__file_label,
  .form_unit.confirm .p-form__file_name,
  .form_unit.confirm .note {
    display: none;
  }
  .form_unit.privacy_check {
    display: block;
    border: none;
  }
  .form_unit.privacy_check:before {
    display: none;
  }
  .site_sns a {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .site_sns a:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .site_sns a.tw svg {
    width: 1.56vw;
    height: 1.27vw;
  }
  .site_sns a.fb svg {
    width: 0.78vw;
    height: 1.46vw;
  }
  .site_sns a.ig svg {
    width: 1.46vw;
    height: 1.46vw;
  }
  .site_sns a.yt svg {
    width: 1.56vw;
    height: 1.07vw;
  }
  .sec_title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-transform: translateX(-100%) rotate(-90deg);
    transform: translateX(-100%) rotate(-90deg);
    -webkit-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
    position: absolute;
    top: -0.49vw;
    left: -2.93vw;
  }
  .sec_title.reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
  .sec_title.reverse strong {
    padding-left: 0;
    margin-left: 0;
    padding-right: 6.05vw;
    margin-right: 1.17vw;
  }
  .sec_title.reverse strong:before {
    left: auto;
    right: 0;
  }
  .sec_title strong {
    background: var(--grad-color);
    background-clip: border-box;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    display: block;
    font-size: 1.27vw;
    line-height: 1;
    position: relative;
    padding-left: 6.05vw;
    margin-left: 1.17vw;
  }
  .sec_title strong:before {
    background-color: var(--main-color);
    content: '';
    display: block;
    width: 4.88vw;
    height: 1px;
    position: absolute;
    top: 50%;
    left: 0;
  }
  .sec_title span {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    color: var(--main-color);
    display: block;
    font-size: 1.17vw;
    letter-spacing: 0.18em;
    line-height: 1;
  }
  .page_title {
    text-align: center;
    line-height: 1;
  }
  .page_title strong {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    color: var(--main-color);
    display: block;
    font-size: 1.27vw;
    margin-bottom: 0.98vw;
  }
  .page_title span {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    display: inline-block;
    font-size: 4.1vw;
    letter-spacing: 0.08em;
    padding-bottom: 0.98vw;
    color: var(--main-color);
  }
  .unit_title {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    color: var(--main-font-color);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 6.84vw;
    font-size: 2.15vw;
    font-weight: bold;
    padding: 0 2.34vw;
    margin-bottom: 3.42vw;
    position: relative;
  }
  .unit_title:after {
    border: 1px solid var(--main-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0.15;
    position: absolute;
    bottom: 0;
    left: 0;
    pointer-events: none;
  }
  .medium_title {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    font-size: 1.95vw;
  }
  .large_title {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    font-size: 2.93vw;
  }
  .mini_title {
    color: var(--base-font-color);
  }
  .mini_title strong {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    margin-bottom: 2.15vw;
    font-size: 2.93vw;
    line-height: 1;
    letter-spacing: 0.2em;
    display: block;
  }
  .mini_title span {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    font-size: 1.37vw;
    line-height: 1;
    letter-spacing: 0.08em;
    display: block;
  }
  .swiper {
    position: static;
  }
  .swiper .swiper-pagination .swiper-pagination-bullet {
    background-color: #ffffff;
    width: 5.86vw;
    height: 0.29vw;
    margin: 0 1.46vw 0 0 !important;
    opacity: 0.5;
    border-radius: 0;
  }
  .swiper .swiper-pagination .swiper-pagination-bullet-active {
    background-color: #ffffff;
    opacity: 1;
  }
  .swiper .swiper-button-disabled {
    display: none;
  }
  .swiper .swiper-button-next,
  .swiper .swiper-button-prev {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    width: 1.17vw;
    height: 2.34vw;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .swiper .swiper-button-next:hover,
  .swiper .swiper-button-prev:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .swiper .swiper-button-next:after,
  .swiper .swiper-button-prev:after {
    display: none;
  }
  .swiper .swiper-button-next svg,
  .swiper .swiper-button-prev svg {
    fill: var(--main-color);
  }
  .swiper .swiper-button-next {
    right: -5.86vw;
  }
  .swiper .swiper-button-prev {
    left: -5.86vw;
  }
  .swiper .swipe_controls {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 5;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 2.34vw;
  }
  .swiper .swipe_controls .swiper-button-next,
  .swiper .swipe_controls .swiper-button-prev {
    position: relative;
    top: 0;
    left: 0;
    margin: 0;
  }
  .swiper .swipe_controls .swiper-button-prev {
    margin-right: 3.32vw;
  }
  .swiper[data-swiper='slider'] .swiper-slide {
    width: 36.33vw;
  }
  .swiper[data-swiper='carousel'] .swiper-slide {
    width: 36.33vw;
  }
  .btn a,
  .btn input,
  .btn button,
  .btn span {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    color: var(--main-color);
    border-bottom: 1px solid var(--main-color);
    display: inline-block;
    text-align: center;
    padding: 0.98vw 0;
    min-height: 4.39vw;
    letter-spacing: 0.05em;
    font-weight: bold;
  }
  .btn a.disable,
  .btn input.disable,
  .btn button.disable,
  .btn span.disable {
    opacity: 0.5;
    pointer-events: none;
  }
  .btn a svg,
  .btn input svg,
  .btn button svg,
  .btn span svg {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    width: 0.59vw;
    height: 0.98vw;
    margin-left: 1.37vw;
    fill: var(--main-color);
    z-index: 5;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .btn a:hover,
  .btn input:hover,
  .btn button:hover,
  .btn span:hover {
    opacity: 0.6;
  }
  .btn a:hover svg,
  .btn input:hover svg,
  .btn button:hover svg,
  .btn span:hover svg {
    -webkit-transform: translateX(0.49vw);
    transform: translateX(0.49vw);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .btn span:hover {
    opacity: 1;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .btn.center {
    text-align: center;
  }
  .btn.right {
    text-align: right;
  }
  .btn.back a svg,
  .btn.back input svg,
  .btn.back button svg {
    margin-left: 0;
    margin-right: 1.37vw;
  }
  .btn.wide_m {
    width: 50%;
    margin-left: auto;
    margin-right: auto;
  }
  .btn.wide_m a,
  .btn.wide_m input,
  .btn.wide_m button {
    width: 100%;
  }
  .input_btn {
    position: relative;
    width: 100%;
    max-width: 46.88vw;
  }
  .input_btn a,
  .input_btn button,
  .input_btn input {
    font-size: 1.46vw;
    color: var(--main-color);
    padding-bottom: 1.46vw;
    display: block;
    width: 100%;
    border: 1px solid var(--main-color);
    height: 5.86vw;
  }
  .input_btn svg {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    width: 0.59vw;
    height: 0.98vw;
    fill: var(--main-color);
    position: absolute;
    top: 50%;
    right: 2.44vw;
    margin-left: 0;
    margin-top: -0.49vw;
    z-index: 2;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .input_btn:hover svg {
    -webkit-transform: translateX(0.49vw);
    transform: translateX(0.49vw);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .input_btn.back a,
  .input_btn.back button,
  .input_btn.back input {
    padding-right: 0;
  }
  .input_btn.back svg {
    right: auto;
    left: 0;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .input_btn.back:hover svg {
    -webkit-transform: translateX(-0.49vw);
    transform: translateX(-0.49vw);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .btns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 5.86vw;
    -webkit-column-gap: 2.93vw;
    -moz-column-gap: 2.93vw;
    column-gap: 2.93vw;
  }
  .btns .btn a,
  .btns .btn input,
  .btns .btn button {
    margin: 0 auto;
    display: block;
  }
  .btns br,
  .btns p {
    display: none;
  }
  .btns.left {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
  .btns.right {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
  .btn_more {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 24.41vw;
    margin: auto;
    height: 5.86vw;
    color: var(--main-color);
    border: 1px solid var(--main-color);
    letter-spacing: 0.05em;
    font-size: 1.46vw;
    font-weight: bold;
    padding: 0 1.95vw;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .btn_more:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .btn_more svg {
    position: absolute;
    top: 50%;
    right: 1.76vw;
    margin-top: -0.68vw;
    width: 1.37vw;
    height: 1.37vw;
    fill: var(--main-color);
  }
  .btn_return {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 24.41vw;
    margin: auto;
    height: 5.86vw;
    color: var(--main-color);
    border: 1px solid var(--main-color);
    letter-spacing: 0.05em;
    font-size: 1.46vw;
    font-weight: bold;
    padding: 0 1.95vw;
    position: relative;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .btn_return:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .btn_return svg {
    position: absolute;
    top: 50%;
    right: 1.76vw;
    margin-top: -0.59vw;
    width: 0.68vw;
    height: 1.17vw;
    fill: var(--main-color);
  }
  .btn_readmore {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    font-size: 1.46vw;
    color: var(--main-font-color);
    border-bottom: 1px solid var(--main-color);
    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;
    letter-spacing: 0.08em;
    margin: 0 auto;
    position: relative;
    padding-bottom: 1.46vw;
    width: 31.25vw;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .btn_readmore:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .acc {
    -webkit-transition-property: all !important;
    transition-property: all !important;
    background: #f1f1f1;
    color: var(--main-color);
    font-size: 1.56vw;
    cursor: pointer;
    position: relative;
  }
  .acc.active {
    background: none;
  }
  .acc.active:after {
    opacity: 1;
    border-color: var(--main-color);
  }
  .acc.active .q {
    color: var(--main-color);
  }
  .acc.active .q:before {
    color: var(--main-color);
  }
  .acc.active .a {
    color: var(--base-font-color);
  }
  .acc.active .a:before {
    color: var(--main-color);
  }
  .acc.is_open {
    background: none;
    cursor: initial;
    opacity: 1;
  }
  .acc.is_open:after {
    opacity: 1;
    border-color: var(--main-color);
  }
  .acc.is_open .q {
    color: var(--main-color);
  }
  .acc.is_open .q:before {
    color: var(--main-color);
  }
  .acc.is_open .a {
    color: var(--base-font-color);
  }
  .acc.is_open .a:before {
    color: var(--main-color);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .acc.is_open:hover {
    opacity: 1 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .acc:hover:after {
    opacity: 1;
    border-color: var(--main-color);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .acc:after {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    content: '';
    border: 1px solid transparent;
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .acc .q {
    position: relative;
    padding: 2.93vw 2.93vw 2.93vw 7.32vw;
    font-size: 1.56vw;
    position: relative;
    color: var(--main-color);
    font-weight: 700;
  }
  .acc .q:before {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    content: 'Q.';
    font-size: 2.34vw;
    line-height: 1;
    position: absolute;
    top: 2.93vw;
    left: 2.93vw;
  }
  .acc .a {
    position: relative;
    padding: 0 2.93vw 2.93vw 7.32vw;
    font-size: 1.46vw;
  }
  .acc .a:before {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    content: 'A.';
    font-size: 2.34vw;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 2.93vw;
  }
  .privacy {
    font-size: 1.37vw;
  }
  .privacy .privacy_title {
    text-align: center;
    margin-bottom: 2.93vw;
    font-weight: bold;
  }
  .privacy .privacy_lead,
  .privacy .privacy_footer {
    margin-bottom: 2.93vw;
  }
  .privacy .privacy_contents dl {
    margin-bottom: 1.46vw;
    padding-bottom: 1.46vw;
    position: relative;
  }
  .privacy .privacy_contents dl:before {
    background-color: var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    opacity: 0.15;
    pointer-events: none;
  }
  .privacy .privacy_contents dl dt {
    font-weight: bold;
    margin-bottom: 0.98vw;
  }
  .privacy .privacy_contents dl dd {
    font-size: 1.17vw;
  }
  .label {
    color: var(--main-color);
    display: inline-block;
    font-size: 1.17vw;
    font-weight: bold;
    line-height: 1;
  }
  .photo {
    position: relative;
    overflow: hidden;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .photo:hover figcaption {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .photo figcaption {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    -webkit-transform: translateY(100%);
    transform: translateY(100%);
    background: var(--grad-color);
    color: var(--main-font-color);
    font-size: 1.17vw;
    padding: 1.95vw;
    letter-spacing: 0.05em;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    display: block;
  }
  .prof_img a {
    overflow: hidden;
    display: block;
  }
  .prof_img a img {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .prof_img a:hover img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .prof_img figure {
    position: relative;
    overflow: hidden;
  }
  .prof_img figure img {
    max-width: initial;
    width: 100%;
  }
  .prof_img .name {
    color: var(--main-color);
    text-align: center;
    padding: 1.95vw 0;
    line-height: 1.5;
  }
  .prof_img .name span {
    display: block;
    font-size: 1.07vw;
    margin-bottom: 0.49vw;
  }
  .prof_img .name strong {
    display: block;
    font-size: 1.46vw;
    font-weight: normal;
  }
  .prof_img.square figure:before {
    content: '';
    display: block;
    padding-top: 100%;
  }
  .prof_img.square figure img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .card {
    padding: 2.44vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    cursor: pointer;
    position: relative;
    border-radius: 0.39vw;
  }
  .card:before {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    border: 1px solid var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    opacity: 0.15;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .card:hover:before {
    border-color: var(--main-color);
    opacity: 1;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .card figure {
    position: relative;
    overflow: hidden;
    width: 7.81vw;
  }
  .card figure:before {
    content: '';
    display: block;
    padding-top: 100%;
  }
  .card figure img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .card dl {
    width: calc(100% - 9.77vw);
  }
  .card dl dt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 0.98vw;
  }
  .card dl dt strong {
    font-size: 1.76vw;
    font-weight: bold;
  }
  .card dl dt .label {
    margin-left: 1.66vw;
  }
  .card dl dd {
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  .required {
    background: #ec0000;
    border-radius: 0.98vw;
    color: #ffffff;
    font-size: 0.98vw;
    font-weight: bold;
    display: inline-block;
    line-height: 1;
    padding: 0.39vw 0.59vw;
  }
  .txt_error {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #db0000;
    font-size: 1.17vw;
    font-weight: bold;
    margin-top: 1.17vw;
    display: none;
  }
  .txt_error.active {
    display: block;
  }
  .txt_error svg {
    fill: #db0000;
    width: 1.27vw;
    height: 1.27vw;
    margin-right: 0.59vw;
  }
  .wysiwyg {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    line-height: 2;
    letter-spacing: 0.08em;
    font-size: 1.37vw;
  }
  .module_bg {
    background: var(--grad-color);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
    z-index: -1;
  }
  #wrapper {
    position: relative;
    overflow: hidden;
  }
  #wrapper #container.under {
    padding-top: 26.76vw;
    padding-bottom: 9.77vw;
  }
  .inner_contents {
    width: calc(100% - 27.93vw);
    position: relative;
    margin-left: auto;
    margin-right: auto;
  }
  .inner_contents.wide_l {
    max-width: 117.19vw;
  }
  .inner_contents.wide_m {
    max-width: 105.47vw;
  }
  .inner_contents.wide_s {
    max-width: 93.75vw;
  }
  .inner_contents.wide_ss {
    max-width: 62.5vw;
  }
  .inner_contents.wide_fit_right {
    width: calc(100% - 19.82vw);
    margin-right: 0;
  }
  #globalHeader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 41;
  }
  #globalHeader.hide .site_logo,
  #globalHeader.hide .header_bg {
    opacity: 0;
  }
  #globalHeader .inner {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    position: relative;
    padding: 0 2.93vw;
    min-height: 10.25vw;
  }
  #globalHeader a {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  #globalHeader a:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  #globalHeader .site_logo {
    background-color: #ffffff;
    max-width: 17.58vw;
    max-height: 17.58vw;
    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;
    padding-bottom: 2.93vw;
  }
  #globalHeader .site_logo a {
    display: block;
    width: 100%;
    height: 100%;
    padding: 1.95vw;
    text-align: center;
  }
  #globalHeader .site_logo figure {
    width: 100%;
    height: 100%;
  }
  #globalHeader .site_logo img {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain;
  }
  #globalHeader .site_logo .site_txt {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    width: 100%;
    display: block;
    font-size: 0.98vw;
    margin-top: 1.46vw;
  }
  #globalHeader .sitenavi {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 8.59vw;
    color: var(--main-font-color);
  }
  #globalHeader .sitenavi .navi {
    color: var(--main-font-color);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%;
    padding: 0 1.17vw;
    font-weight: bold;
    font-size: 1.37vw;
  }
  #globalHeader .sitenavi .pc_navi {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #globalHeader .site_sns {
    margin-right: 3.52vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #globalHeader .site_sns a {
    margin-left: 1.95vw;
  }
  #globalHeader .site_sns svg {
    fill: var(--base-font-color);
    margin: 0 auto;
    opacity: 0.5;
  }
  #globalHeader .header_bg {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    display: none;
  }
  #btnMenu {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    transition-duration: 0.3s;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    transition-delay: 0s;
    width: 4.88vw;
    height: 4.88vw;
    position: fixed;
    top: 4.39vw;
    right: 23.44vw;
    z-index: 50;
    display: none;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  #btnMenu:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  #btnMenu span {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    background-color: var(--main-color);
    display: block;
    width: 3.42vw;
    height: 0.39vw;
    border-radius: 0.39vw;
    position: absolute;
    left: 0.73vw;
  }
  #btnMenu span:nth-child(1) {
    top: 0.73vw;
  }
  #btnMenu span:nth-child(2) {
    top: 1.86vw;
  }
  #btnMenu span:nth-child(3) {
    top: 3.08vw;
  }
  #btnMenu.active {
    background-color: transparent;
  }
  #btnMenu.active span:nth-child(1) {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    top: 1.86vw;
  }
  #btnMenu.active span:nth-child(2) {
    opacity: 0;
  }
  #btnMenu.active span:nth-child(3) {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    top: 1.86vw;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  #btnMenu.active:hover span:nth-child(1) {
    -webkit-transform: rotate(-20deg);
    transform: rotate(-20deg);
  }
  #btnMenu.active:hover span:nth-child(3) {
    -webkit-transform: rotate(20deg);
    transform: rotate(20deg);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  #globalNavi {
    -webkit-transition-duration: 1s;
    transition-duration: 1s;
    -webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    background-color: var(--bg-color);
    color: var(--base-font-color);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    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;
    z-index: 40;
    overflow: auto;
  }
  #globalNavi.active {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
  #globalNavi .inner {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    font-size: 2.15vw;
    text-align: center;
    margin: auto;
    padding: 4.88vw 0;
  }
  #globalNavi .inner li {
    margin-bottom: 2.44vw;
    letter-spacing: 0.05em;
  }
  #globalNavi .inner li:last-of-type {
    margin-bottom: 0;
  }
  #globalNavi .inner a {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  #globalNavi .inner a:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  #breadcrumb {
    font-size: 1.17vw;
    letter-spacing: 0.08em;
    position: absolute;
    top: 12.7vw;
    right: 3.91vw;
  }
  #breadcrumb a {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  #breadcrumb a:hover {
    color: var(--main-color);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  #globalFooter {
    background: var(--grad-color);
    color: var(--main-font-color);
    position: relative;
  }
  #globalFooter .btn_pagetop {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    transition-duration: 0.3s;
    transition-timing-function: ease;
    -webkit-transition-property: opacity;
    transition-property: opacity;
    transition-delay: 0s;
    width: 4.3vw;
    height: 4.3vw;
    position: absolute;
    top: -6.25vw;
    right: 1.95vw;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  #globalFooter .btn_pagetop:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  #globalFooter .btn_pagetop.hide {
    opacity: 0;
  }
  #globalFooter .btn_pagetop.fixed {
    position: fixed;
    top: auto;
    bottom: 1.95vw;
  }
  #globalFooter .btn_pagetop svg {
    fill: var(--main-color);
  }
  #globalFooter .inner {
    max-width: 105.47vw;
    margin: 0 auto;
    padding: 3.32vw 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  #globalFooter .main {
    font-size: 1.37vw;
    width: 70%;
  }
  #globalFooter .sub {
    position: relative;
    width: 30%;
  }
  #globalFooter .sub .site_sns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    padding-bottom: 2.93vw;
  }
  #globalFooter .sub .site_sns a {
    margin-left: 1.95vw;
  }
  #globalFooter .sub .site_sns a:first-of-type {
    margin-left: 0;
  }
  #globalFooter .sub .site_sns svg {
    fill: var(--main-font-color);
  }
  #globalFooter .sub .copyright {
    position: absolute;
    bottom: 0;
    right: 0;
    font-size: 1.07vw;
  }
  .is_under #globalHeader .header_bg {
    background-color: #ffffff;
    display: block;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    overflow: hidden;
    height: 8.4vw;
    -webkit-box-shadow: 0 0 1.17vw rgba(0, 0, 0, 0.1);
    box-shadow: 0 0 1.17vw rgba(0, 0, 0, 0.1);
    opacity: 0;
  }
  .is_under #globalHeader .navi {
    color: #000000;
  }
  .is_under #globalHeader .site_logo .site_txt {
    color: #000000;
  }
  .is_scroll #globalHeader .inner {
    min-height: 8.4vw;
  }
  .is_scroll #globalHeader .site_logo {
    -webkit-box-shadow: 1.66vw 1.66vw 3.32vw rgba(0, 0, 0, 0.25);
    box-shadow: 1.66vw 1.66vw 3.32vw rgba(0, 0, 0, 0.25);
  }
  .section-container {
    max-width: 105.47vw;
    margin: 0 auto;
    padding: 0 0 14.65vw;
  }
  .section-container.wide_l {
    max-width: 117.19vw;
  }
  .section-container.wide_s {
    max-width: 93.75vw;
  }
  .section-container.wide_ss {
    max-width: 62.5vw;
  }
  .section-container .page_title {
    margin-bottom: 5.86vw;
  }
  .section-container section {
    margin-bottom: 7.81vw;
  }
  .section-container section:last-of-type {
    margin-bottom: 0;
  }
  #is_top #breadcrumb {
    display: none;
  }
  #is_top #mv {
    position: relative;
    height: calc(100vh - 12.21vw);
    min-height: 68.36vw;
  }
  #is_top #mv .ic_scroll {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    position: absolute;
    bottom: 0;
    left: 50%;
    color: #ffffff;
    font-size: 1.07vw;
    z-index: 10;
    height: 7.03vw;
  }
  #is_top #mv .ic_scroll:before {
    background-color: #ffffff;
    content: '';
    display: block;
    width: 1px;
    height: 4.88vw;
    position: absolute;
    top: 2.15vw;
    left: 50%;
  }
  #is_top #mv .site_sns {
    position: absolute;
    top: calc(50% - 6.1vw);
    right: 2.54vw;
    z-index: 10;
  }
  #is_top #mv .site_sns a {
    margin-bottom: 1.95vw;
  }
  #is_top #mv .site_sns a:last-of-type {
    margin-bottom: 0;
  }
  #is_top #mv .site_sns svg {
    fill: var(--main-font-color);
    margin: 0 auto;
  }
  #is_top #mv .mv_txt {
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    left: 8.11vw;
    width: calc(100% - 16.21vw);
    color: var(--main-font-color);
    z-index: 10;
    text-align: var(--mv-align);
  }
  #is_top #mv .mv_txt .mv_title {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    -webkit-transition-duration: 0s;
    transition-duration: 0s;
    font-size: 7.81vw;
    line-height: 1.2;
    margin-bottom: 1.95vw;
  }
  #is_top #mv .mv_txt .mv_title.action {
    -webkit-transition-duration: 0.4s;
    transition-duration: 0.4s;
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
  }
  #is_top #mv .mv_txt .mv_subtitle {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    -webkit-transition-duration: 0s;
    transition-duration: 0s;
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
    font-size: 2.34vw;
    letter-spacing: 0.18em;
    line-height: 1.5;
  }
  #is_top #mv .mv_txt .mv_subtitle.action {
    -webkit-transition-duration: 0.4s;
    transition-duration: 0.4s;
    -webkit-transition-delay: 0.4s;
    transition-delay: 0.4s;
  }
  #is_top #mv .mv_slider {
    position: relative;
    height: 100%;
  }
  #is_top #mv .mv_slider .swiper {
    height: 100%;
  }
  #is_top #mv .mv_slider .swiper .swiper-container {
    height: 100%;
  }
  #is_top #mv .mv_slider .swiper-slide {
    position: relative;
    height: 100%;
    width: 100%;
  }
  #is_top #mv .mv_slider .swiper-slide:after {
    background-color: #000000;
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    opacity: var(--mv-overlay);
  }
  #is_top #mv .mv_slider .swiper-slide .mv_movie {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
  }
  #is_top #mv .mv_slider .swiper-slide .mv_movie video {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    pointer-events: none;
  }
  #is_top #mv .mv_slider .swiper-slide img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    display: block;
  }
  #is_top #mv .mv_slider .swiper-pagination {
    bottom: 2.93vw;
    left: 8.11vw;
    z-index: 10;
  }
  #is_top .mv-news .inner_contents {
    width: 105.47vw;
    margin-left: auto;
    margin-right: auto;
    color: var(--main-color);
    position: relative;
  }
  #is_top .mv-news .title {
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    font-size: 1.17vw;
    font-weight: bold;
    position: absolute;
    top: 50%;
    left: -5.86vw;
  }
  #is_top .mv-news .content {
    position: relative;
    font-size: 1.37vw;
  }
  #is_top .mv-news .content:after {
    background-color: var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    opacity: 0.15;
    position: absolute;
    bottom: 0;
    left: 0;
  }
  #is_top .mv-news .content a {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    min-height: 12.21vw;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  #is_top .mv-news .content a:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  #is_top .mv-news .content .date {
    margin-right: 2.93vw;
  }
  #is_top .mv-news .content .txt {
    font-weight: bold;
  }
  #is_top .mv-news .content svg {
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 0;
    width: 0.59vw;
    height: 0.98vw;
    fill: var(--main-color);
  }
  #is_top .adjust_sp {
    position: relative;
  }
  #is_top #map {
    height: 51.27vw;
  }
  #is_top #map iframe {
    width: 100%;
    height: 100%;
  }
  .blog_header {
    position: relative;
    margin-bottom: 9.77vw;
  }
  .archive_link {
    position: absolute;
    bottom: -4.88vw;
    right: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .archive_link .select {
    margin-left: 3.91vw;
    position: relative;
    padding-right: 1.76vw;
  }
  .archive_link .select:first-child {
    margin-left: 0;
  }
  .archive_link .select svg {
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 0;
    width: 1.17vw;
    height: 0.68vw;
    margin-left: 0.49vw;
    pointer-events: none;
    fill: var(--main-color);
  }
  .blog .entry header .info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 0.98vw;
  }
  .blog .entry header .info .label {
    margin-right: 0.98vw;
    font-size: 1.17vw;
    border: 1px solid var(--main-color);
    border-radius: 0.2vw;
    padding: 0.49vw 0.78vw;
  }
  .blog .entry header .info .date {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    color: var(--base-font-color);
    opacity: 0.5;
    font-weight: bold;
    font-size: 1.17vw;
  }
  .blog .entry header h1 {
    font-size: 1.27vw;
    font-weight: bold;
    line-height: 1.7;
    letter-spacing: 0.08em;
  }
  .blog.archive {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .blog.archive .entry {
    width: calc(33.3% - 1.95vw);
    margin-right: 2.93vw;
    margin-bottom: 5.86vw;
  }
  .blog.archive .entry:nth-child(3n) {
    margin-right: 0;
  }
  .blog.archive .entry a {
    overflow: hidden;
  }
  .blog.archive .entry a img {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .blog.archive .entry a:hover img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .blog.archive .entry figure {
    background-color: #ffffff;
    position: relative;
    overflow: hidden;
    margin-bottom: 1.95vw;
  }
  .blog.archive .entry figure:before {
    content: '';
    display: block;
    padding-top: 70.5%;
  }
  .blog.archive .entry figure img {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    vertical-align: bottom;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .blog.detail .page_title {
    margin-bottom: 6.84vw;
  }
  .blog.detail .entry {
    margin-bottom: 14.65vw;
  }
  .blog.detail .mv {
    margin-bottom: 1.95vw;
    text-align: center;
    overflow: hidden;
  }
  .blog.detail header {
    position: relative;
    margin-bottom: 5.86vw;
    padding-bottom: 3.91vw;
  }
  .blog.detail header:after {
    background-color: var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    opacity: 0.15;
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .blog.detail header h1 {
    color: var(--base-font-color);
  }
  .blog.detail header .date {
    margin-bottom: 0;
  }
  .blog.detail .contents {
    letter-spacing: 0.15em;
  }
  .blog.detail .contents h1,
  .blog.detail .contents h2,
  .blog.detail .contents h3,
  .blog.detail .contents h4,
  .blog.detail .contents h5,
  .blog.detail .contents h6 {
    font-weight: bold;
    margin-bottom: 2.44vw;
  }
  .blog.detail .contents h1 {
    font-size: 2.05vw;
  }
  .blog.detail .contents h2 {
    font-size: 1.86vw;
  }
  .blog.detail .contents h3 {
    font-size: 1.66vw;
  }
  .blog.detail .contents h4,
  .blog.detail .contents h5,
  .blog.detail .contents h6 {
    font-size: 1.46vw;
  }
  .blog.detail .contents p,
  .blog.detail .contents ol,
  .blog.detail .contents ul,
  .blog.detail .contents table,
  .blog.detail .contents dl {
    margin-bottom: 3.91vw;
  }
  .blog.detail .contents a {
    color: #ec0000;
    text-decoration: underline;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .blog.detail .contents a:hover {
    text-decoration: none;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .blog.detail .contents ul li {
    list-style: disc;
    margin-left: 1.95vw;
  }
  .blog.detail .contents ol li {
    list-style: decimal;
    margin-left: 1.95vw;
  }
  .blog.detail .contents img {
    border-radius: 1.95vw;
  }
  #is_contact .page_title {
    margin-bottom: 6.84vw;
  }
  #is_contact .message {
    margin-bottom: 6.84vw;
    text-align: center;
  }
  #is_contact .message p {
    margin-bottom: 2.93vw;
  }
  #is_contact .form .form_txt {
    text-align: center;
    margin-bottom: 3.91vw;
    margin-top: 5.86vw;
    letter-spacing: 0.08em;
    font-size: 1.17vw;
  }
  #is_contact .form .privacy {
    position: relative;
    margin-bottom: 6.35vw;
  }
  #is_contact .form .privacy:before {
    border: 1px solid var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0.15;
    pointer-events: none;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  #is_contact .form .privacy .scroll_area {
    height: 25.39vw;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 3.42vw 2.44vw;
    position: relative;
  }
  #is_contact .form .privacy_check {
    text-align: center;
  }
  #is_contact .form .privacy_check .mwform-checkbox-field {
    margin-bottom: 1.95vw;
    letter-spacing: 0.08em;
  }
  #is_contact .form .privacy_check .error {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
  #is_contact .form .mw_wp_form_send_error {
    text-align: center;
  }
  #sectionNews .contents ul {
    margin-bottom: 14.65vw;
  }
  #sectionNews .contents .entry {
    border-bottom: 1px solid rgba(0, 0, 0, 0.15);
    padding: 3.91vw 0;
  }
  #sectionNews .contents .entry:first-child {
    border-top: 1px solid rgba(0, 0, 0, 0.15);
  }
  #sectionNews .contents .entry .entry_header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  #sectionNews .contents .entry .entry_header .date {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    width: 11.23vw;
    font-size: 1.46vw;
    font-weight: bold;
    color: var(--base-font-color);
    opacity: 0.5;
  }
  #sectionNews .contents .entry .entry_header .txt {
    width: calc(100% - 11.23vw);
    color: var(--base-font-color);
    font-size: 1.46vw;
    font-weight: bold;
  }
  #sectionNews .contents .entry .entry_body {
    width: calc(100% - 11.23vw);
    margin: 2.93vw 0 0 auto;
    font-size: 1.46vw;
  }
  .cover-bg {
    position: relative;
  }
  .cover-bg .inner_contents {
    padding-bottom: 16.6vw;
  }
  .cover-bg .bg {
    position: relative;
    display: block;
    width: 100%;
  }
  .cover-bg .bg figure {
    position: relative;
    min-height: 42.97vw;
    display: block;
  }
  .cover-bg .bg figure:before {
    content: '';
    display: block;
    padding-top: 56%;
  }
  .cover-bg .bg figure img {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .cover-bg .bg .sec_title {
    -webkit-transform: translateX(-100%) rotate(-90deg);
    transform: translateX(-100%) rotate(-90deg);
    -webkit-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
    position: absolute;
    top: -0.98vw;
    left: -2.93vw;
  }
  .cover-bg .contents {
    position: absolute;
    width: 36%;
    background-color: #ffffff;
    width: 37.11vw;
    bottom: 0;
    right: 5.86vw;
  }
  .cover-bg .contents .inner {
    padding: 4.88vw;
  }
  .cover-bg .contents .title {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    color: var(--main-color);
    font-size: 2.34vw;
    line-height: 1.5;
    margin-bottom: 3.91vw;
  }
  .cover-bg .contents .txt {
    margin-bottom: 4.88vw;
    text-align: left;
  }
  .cover-bg .btn_readmore {
    color: #ffffff;
  }
  .image-panel {
    position: relative;
  }
  .image-panel:before {
    background-color: var(--main-color);
    content: '';
    display: block;
    width: 74.2vw;
    height: 100%;
    position: absolute;
    top: 0;
    opacity: 0.1;
  }
  .image-panel .inner_contents {
    padding-top: 11.72vw;
    padding-bottom: 11.72vw;
  }
  .image-panel .bg {
    position: relative;
    display: block;
    width: 68.36vw;
  }
  .image-panel .bg figure {
    position: relative;
    min-height: 52.73vw;
    display: block;
  }
  .image-panel .bg figure:before {
    content: '';
    display: block;
    padding-top: 56%;
  }
  .image-panel .bg figure img {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .image-panel .bg .sec_title {
    -webkit-transform: translateX(-100%) rotate(-90deg);
    transform: translateX(-100%) rotate(-90deg);
    -webkit-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
    position: absolute;
    top: 0;
  }
  .image-panel .contents {
    position: absolute;
    width: 27.34vw;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    top: 50%;
  }
  .image-panel .contents .title {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    color: var(--main-color);
    font-size: 2.34vw;
    line-height: 1.5;
    margin-bottom: 3.91vw;
  }
  .image-panel .contents .txt {
    margin-bottom: 4.88vw;
    text-align: left;
  }
  .image-panel.left:before {
    left: 0;
  }
  .image-panel.left .bg .sec_title {
    -webkit-transform: translateX(100%) rotate(90deg);
    transform: translateX(100%) rotate(90deg);
    -webkit-transform-origin: 0 100%;
    transform-origin: 0 100%;
    top: -0.98vw;
    right: -2.93vw;
    left: auto;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
  .image-panel.left .contents {
    right: 0;
  }
  .image-panel.right:before {
    right: 0;
  }
  .image-panel.right .bg {
    margin-left: auto;
  }
  .image-panel.right .bg .sec_title {
    top: -0.98vw;
    left: -2.93vw;
  }
  .image-panel.right .contents {
    left: 0;
  }
  .column-banner .module_bg {
    left: auto;
    right: 0;
    width: 74.2vw;
  }
  .column-banner .swiper {
    margin-bottom: 7.81vw;
  }
  .column-banner .swipe_controls {
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    left: 50%;
    width: 100%;
  }
  .column-banner .swipe_controls.wide_l {
    max-width: 117.19vw;
  }
  .column-banner .swipe_controls.wide_m {
    max-width: 105.47vw;
  }
  .column-banner .swipe_controls.wide_s {
    max-width: 93.75vw;
  }
  .column-banner .swipe_controls.wide_ss {
    max-width: 62.5vw;
  }
  .column-banner .btn {
    margin-top: 5.86vw;
  }
  .ap-slideshow {
    position: relative;
  }
  .ap-slideshow .module_bg {
    left: 0;
    right: auto;
    width: 83.7vw;
  }
  .ap-slideshow .sec_title {
    -webkit-transform: translateX(100%) rotate(90deg);
    transform: translateX(100%) rotate(90deg);
    -webkit-transform-origin: 0 100%;
    transform-origin: 0 100%;
    top: -0.98vw;
    right: -4.39vw;
    left: auto;
  }
  .ap-slideshow .swiper {
    width: calc(100% - 20.51vw);
    padding-bottom: 0;
    position: relative;
  }
  .ap-slideshow .swiper .swiper-container {
    overflow: initial;
  }
  .ap-slideshow .swiper .swiper-slide img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .ap-slideshow .swiper .swiper-slide figcaption {
    position: absolute;
    top: 8.3vw;
    right: -20.51vw;
    width: 17.58vw;
    font-size: 1.27vw;
    line-height: 2;
    letter-spacing: 0.05em;
    opacity: 0;
  }
  .ap-slideshow .swiper .swiper-slide.swiper-slide-active figcaption {
    opacity: 1;
  }
  .ap-slideshow .swiper .swiper-pagination {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    color: var(--main-color);
    font-weight: bold;
    position: absolute;
    top: 3.91vw;
    right: -5.37vw;
    left: auto;
    width: auto;
    font-size: 1.27vw;
  }
  .ap-slideshow .swiper .swipe_controls {
    right: -20.51vw;
    left: auto;
    bottom: 9.77vw;
  }
  .ap-table .table-block {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    padding: 5.86vw;
    display: block;
    position: relative;
    margin-bottom: 3.91vw;
  }
  .ap-table .table-block:last-child {
    margin-bottom: 0;
  }
  .ap-table .table-block:before {
    background-color: #ffffff;
    border: 1px solid rgba(68, 68, 68, 0.15);
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
  .ap-table .table-block .lead {
    margin-bottom: 4.88vw;
  }
  .ap-table .table-block .lead dt {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    color: var(--main-color);
    font-size: 2.34vw;
    line-height: 1.5;
    margin-bottom: 1.95vw;
    border-bottom: 1px solid var(--main-color);
    padding-bottom: 1.95vw;
  }
  .ap-table .table-block .lead dd {
    font-size: 1.46vw;
  }
  .ap-table .table-block .table_wrap {
    border: 1px solid rgba(68, 68, 68, 0.15);
  }
  .ap-table .table-block .unit {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 1.46vw 2.93vw;
    font-size: 1.46vw;
  }
  .ap-table .table-block .unit:before {
    border-top: 1px solid rgba(68, 68, 68, 0.15);
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
  .ap-table .table-block .unit:first-child:before {
    display: none;
  }
  .ap-table .table-block .unit dt {
    width: 15.14vw;
    font-weight: bold;
  }
  .ap-table .table-block .unit dd {
    width: calc(100% - 15.14vw);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .ap-table a.table-block:hover {
    opacity: 0.7;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .vertical-text .module_bg {
    left: 0;
    right: auto;
    width: 83.7vw;
  }
  .vertical-text .sec_title {
    text-align: center;
    margin-bottom: 5.86vw;
  }
  .vertical-text .sec_title strong {
    margin-left: 0;
  }
  .vertical-text .row {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    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-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    width: 100%;
  }
  .vertical-text .row .title {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    color: var(--main-color);
    font-size: 2.34vw;
    line-height: 1.5;
    margin-left: 5.86vw;
  }
  .vertical-text .row .txt {
    font-size: 1.37vw;
    line-height: 2;
  }
  .vertical-text .row .txt > * {
    margin-left: 2.93vw;
  }
  .vertical-text .row .txt > *:last-child {
    margin-left: 0;
  }
  .freearea .module_bg {
    left: 0;
    right: auto;
    width: 83.7vw;
  }
  .freearea .sec_title {
    -webkit-transform: translateX(100%) rotate(90deg);
    transform: translateX(100%) rotate(90deg);
    -webkit-transform-origin: 0 100%;
    transform-origin: 0 100%;
    top: -0.98vw;
    right: -4.39vw;
    left: auto;
  }
  .ap-blog .module_bg {
    left: auto;
    right: 0;
    width: 74.2vw;
  }
  .ap-blog .blog.archive {
    display: block;
  }
  .ap-blog .blog.archive .swiper {
    width: 100%;
  }
  .ap-blog .blog.archive .entry {
    width: 32.62vw;
    margin-right: 0;
    margin-bottom: 0;
  }
  .ap-blog .blog.archive .entry figure {
    position: relative;
    overflow: initial;
  }
  .ap-blog .blog.archive .entry figure:before {
    display: none;
  }
  .ap-blog .blog.archive .entry figure div {
    background-color: #ffffff;
    position: relative;
    z-index: 5;
    overflow: hidden;
  }
  .ap-blog .blog.archive .entry figure div:before {
    content: '';
    display: block;
    padding-top: 70.5%;
  }
  .ap-blog .blog.archive .entry figure img {
    z-index: 5;
  }
  .ap-news {
    position: relative;
    z-index: 10;
  }
  .ap-news .module_bg {
    left: auto;
    right: 0;
    width: 74.2vw;
  }
  .ap-news .inner_contents {
    color: var(--base-font-color);
  }
  .ap-news .title {
    font-family: var(--font-family-en);
    font-weight: var(--font-weight-en);
    font-size: 1.95vw;
    margin-bottom: 3.91vw;
  }
  .ap-news .content ul {
    margin-bottom: 1.95vw;
  }
  .ap-news .content ul li {
    margin-bottom: 2.34vw;
    padding-bottom: 2.34vw;
    position: relative;
  }
  .ap-news .content ul li:after {
    background-color: var(--base-font-color);
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    opacity: 0.2;
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .ap-news .content ul li:last-of-type {
    margin-bottom: 0;
  }
  .ap-news .content ul li a {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .ap-news .content ul li a:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .ap-news .content ul li svg {
    position: absolute;
    top: 50%;
    right: 0;
    width: 0.68vw;
    height: 1.17vw;
    fill: var(--main-color);
  }
  .ap-news .content ul li .date {
    margin-right: 2.93vw;
    font-size: 1.46vw;
    font-weight: bold;
    color: var(--base-font-color);
    opacity: 0.5;
  }
  .ap-news .content ul li .txt {
    color: var(--base-font-color);
    font-size: 1.46vw;
    font-weight: bold;
  }
  .ap-news .btns {
    display: none;
  }
  .detail-section {
    position: relative;
  }
  .detail-anchor {
    max-width: 105.47vw;
    margin: 0 auto 14.65vw;
    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;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-column-gap: 2.93vw;
    -moz-column-gap: 2.93vw;
    column-gap: 2.93vw;
    row-gap: 2.93vw;
    font-size: 1.46vw;
    line-height: 2;
    font-weight: bold;
  }
  .detail-anchor li a {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    position: relative;
    display: block;
    padding-bottom: 0.49vw;
  }
  .detail-anchor li a:after {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: var(--main-color);
    content: '';
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 0.15vw;
    position: absolute;
    bottom: 0;
    left: 50%;
    opacity: 0;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .detail-anchor li a:hover:after {
    opacity: 1;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .detail-anchor_sp {
    display: none;
  }
  .detail-title {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    color: var(--main-color);
    font-size: 2.34vw;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
    margin-bottom: 4.88vw;
    letter-spacing: 0.08em;
    position: relative;
  }
  .detail-text {
    margin-bottom: 4.88vw;
  }
  .detail-vertical {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    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-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    width: 100%;
    margin-bottom: 4.88vw;
  }
  .detail-vertical .title {
    font-family: var(--font-family-ja);
    font-weight: var(--font-weight-ja);
    color: var(--main-color);
    font-size: 2.34vw;
    line-height: 1.5;
    margin-left: 5.86vw;
  }
  .detail-vertical .txt {
    font-size: 1.46vw;
    line-height: 2;
    letter-spacing: 0.08em;
  }
  .detail-vertical .txt > * {
    margin-left: 2.93vw;
  }
  .detail-vertical .txt > *:last-child {
    margin-left: 0;
  }
  .detail-list {
    margin: 0 auto 4.88vw;
    max-width: 62.5vw;
  }
  .detail-list li {
    margin-bottom: 2.44vw;
    position: relative;
    padding-left: 1.95vw;
  }
  .detail-list li:last-child {
    margin-bottom: 0;
  }
  ul.detail-list li:before {
    background-color: var(--main-color);
    content: '';
    display: inline-block;
    width: 0.68vw;
    height: 0.68vw;
    border-radius: 100%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: absolute;
    top: 0.98vw;
    left: 0;
  }
  ol.detail-list {
    counter-reset: ol_li;
  }
  ol.detail-list li:before {
    counter-increment: ol_li;
    /* ol_li カウンタの値に1加える */
    content: counter(ol_li) ".";
    color: var(--main-color);
    position: absolute;
    top: 0;
    left: 0;
  }
  ol.detail-list svg {
    display: none;
  }
  .lecture_list_wrap {
    border: 1px solid rgba(68, 68, 68, 0.15);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 5.18vw;
    padding: 4.88vw 5.86vw;
  }
  .detail-lecture {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    padding-bottom: 4.88vw;
  }
  .detail-lecture:after {
    -webkit-transform: translatex(-50%);
    transform: translatex(-50%);
    background-color: rgba(68, 68, 68, 0.15);
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    position: absolute;
    bottom: 0;
    left: 50%;
  }
  .detail-lecture:last-of-type {
    padding-bottom: 0;
  }
  .detail-lecture:last-of-type:after {
    display: none;
  }
  .detail-lecture dt {
    width: 18.07vw;
    padding-right: 4.88vw;
    font-weight: bold;
  }
  .detail-lecture dd {
    width: calc(100% - 18.07vw);
    position: relative;
    padding-left: 4.88vw;
  }
  .detail-swiper {
    margin-bottom: 4.88vw;
  }
  .detail-swiper .swiper-container {
    padding-bottom: 1.95vw;
    width: 100%;
  }
  .detail-swiper .swipe_controls {
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 5;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 2.34vw;
  }
  .detail-swiper .swipe_controls .swiper-button-next,
  .detail-swiper .swipe_controls .swiper-button-prev {
    position: relative;
    top: 0;
    left: 0;
    margin: 0;
  }
  .detail-swiper .swipe_controls .swiper-button-prev {
    margin-right: 3.32vw;
  }
  .detail-swiper .swiper-button-disabled {
    display: none;
  }
  .detail-swiper .swiper-button-prev,
  .detail-swiper .swiper-button-next {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    width: 1.17vw;
    height: 2.34vw;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .detail-swiper .swiper-button-prev:hover,
  .detail-swiper .swiper-button-next:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .detail-swiper .swiper-button-prev:after,
  .detail-swiper .swiper-button-next:after {
    display: none;
  }
  .detail-swiper .swiper-button-prev svg,
  .detail-swiper .swiper-button-next svg {
    fill: var(--main-color);
  }
  .detail-swiper .swiper-button-next {
    right: -5.86vw;
  }
  .detail-swiper .swiper-button-prev {
    left: -5.86vw;
  }
  .detail-swiper .swiper-pagination {
    bottom: 0;
    left: 0;
    text-align: left;
  }
  .detail-swiper .swiper-pagination .swiper-pagination-bullet {
    background-color: var(--main-color);
    width: 5.86vw;
    height: 0.29vw;
    margin: 0 1.46vw 0 0 !important;
    opacity: 0.35;
    border-radius: 0;
  }
  .detail-swiper .swiper-pagination .swiper-pagination-bullet-active {
    opacity: 1;
  }
  .detail-swiper .swiper-slide {
    padding-bottom: 1.95vw;
  }
  .detail-swiper .detail-slide-figure {
    width: 100%;
    position: relative;
  }
  .detail-swiper .detail-slide-figure div {
    position: relative;
    overflow: hidden;
  }
  .detail-swiper .detail-slide-figure div:before {
    padding-top: 63%;
    content: '';
    display: block;
  }
  .detail-swiper .detail-slide-figure div img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .detail-swiper .detail-slide-figure a {
    overflow: hidden;
    display: block;
    overflow: hidden;
  }
  .detail-swiper .detail-slide-figure a img {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) and (min-width: 750px) {
  .detail-swiper .detail-slide-figure a:hover img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

@media screen and (min-width: 750px) and (max-width: 1024px) {
  .detail-swiper .detail-slide-figure img {
    width: 100%;
    max-width: initial;
  }
  .detail-swiper .detail-slide-figure figcaption {
    padding-top: 1.46vw;
  }
  .detail-image-side {
    margin-bottom: 8.79vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
  .detail-image-side .img {
    width: calc(50% + 17.09vw);
    position: relative;
  }
  .detail-image-side .img div {
    position: relative;
    z-index: 1;
    overflow: hidden;
  }
  .detail-image-side .img img {
    max-width: initial;
    width: 100%;
  }
  .detail-image-side .txt {
    width: calc(50% - 2.44vw);
  }
  .detail-image-side .txt .title {
    font-size: 2.34vw;
    margin-bottom: 2.93vw;
    letter-spacing: 0.08em;
    color: var(--main-color);
  }
  .detail-image-side.left .img {
    margin-left: -20.02vw;
  }
  .detail-image-side.right {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
  .detail-image-side.right .img {
    margin-right: -20.02vw;
  }
  .detail-image-column {
    display: grid;
    margin-bottom: 4.88vw;
  }
  .detail-image-column .detail-image-column-unit .img {
    margin-bottom: 1.95vw;
    position: relative;
  }
  .detail-image-column .detail-image-column-unit .img div {
    position: relative;
    overflow: hidden;
  }
  .detail-image-column .detail-image-column-unit .img img {
    width: 100%;
    max-width: initial;
  }
  .detail-image-column .detail-image-column-unit .title {
    line-height: 1.6;
    margin-bottom: 1.46vw;
    letter-spacing: 0.08em;
    color: var(--main-color);
  }
  .detail-image-column.column-2 {
    row-gap: 5.86vw;
    -webkit-column-gap: 4.88vw;
    -moz-column-gap: 4.88vw;
    column-gap: 4.88vw;
    grid-template-columns: repeat(2, 1fr);
  }
  .detail-image-column.column-2 .detail-image-column-unit .title {
    font-size: 1.95vw;
  }
  .detail-image-column.column-3 {
    row-gap: 2.93vw;
    -webkit-column-gap: 2.93vw;
    -moz-column-gap: 2.93vw;
    column-gap: 2.93vw;
    grid-template-columns: repeat(3, 1fr);
  }
  .detail-image-column.column-3 .detail-image-column-unit .title {
    font-size: 1.56vw;
  }
  .detail-column {
    margin-bottom: 4.88vw;
    border: 1px solid rgba(68, 68, 68, 0.15);
    position: relative;
    padding: 5.86vw;
  }
  .detail-column .title {
    font-size: 2.34vw;
    color: var(--main-color);
    border-bottom: 1px solid var(--main-color);
    margin-bottom: 3.42vw;
    position: relative;
    padding: 0 0 1.95vw;
  }
  .detail-column .contents {
    display: grid;
    -webkit-column-gap: 3.91vw;
    -moz-column-gap: 3.91vw;
    column-gap: 3.91vw;
    grid-template-columns: repeat(2, 1fr);
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
  .detail-column .img {
    overflow: hidden;
  }
  .detail-baloon {
    margin-bottom: 4.88vw;
  }
  .detail-baloon .detail-baloon-unit {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    margin-bottom: 4.88vw;
  }
  .detail-baloon .detail-baloon-unit:last-of-type {
    margin-bottom: 0;
  }
  .detail-baloon .detail-baloon-unit .img {
    width: 11.72vw;
  }
  .detail-baloon .detail-baloon-unit .img div {
    width: 11.72vw;
    height: 11.72vw;
    border-radius: 100%;
    overflow: hidden;
  }
  .detail-baloon .detail-baloon-unit .img div img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .detail-baloon .detail-baloon-unit .img figcaption {
    font-size: 1.37vw;
    text-align: center;
    margin-top: 0.98vw;
  }
  .detail-baloon .detail-baloon-unit .txt {
    background-color: #ffffff;
    border: 1px solid rgba(68, 68, 68, 0.15);
    padding: 3.42vw 3.91vw;
    width: calc(100% - 14.65vw);
  }
  .detail-baloon .detail-baloon-unit.img_right {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
  .detail-profile {
    margin-bottom: 4.88vw;
    display: grid;
    row-gap: 4.88vw;
    -webkit-column-gap: 4.88vw;
    -moz-column-gap: 4.88vw;
    column-gap: 4.88vw;
    grid-template-columns: repeat(3, 1fr);
  }
  .detail-profile.center {
    grid-template-columns: initial;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
  .detail-profile .detail-profile-unit {
    max-width: 27.34vw;
  }
  .detail-profile .detail-profile-unit .img {
    width: 20.51vw;
    height: 20.51vw;
    overflow: hidden;
    margin: 0 auto 1.95vw;
  }
  .detail-profile .detail-profile-unit .img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .detail-profile .detail-profile-unit .txt dt {
    color: var(--main-color);
    letter-spacing: 0.08em;
    font-size: 1.56vw;
    text-align: center;
    margin-bottom: 0.98vw;
  }
  .detail-profile .detail-profile-unit .txt dd {
    font-weight: 400;
  }
  .detail-faq {
    margin-bottom: 4.88vw;
  }
  .detail-faq .detail-faq-unit {
    margin-bottom: 1.95vw;
  }
  .detail-faq .detail-faq-unit:last-of-type {
    margin-bottom: 0;
  }
  .detail-table {
    margin-bottom: 4.88vw;
  }
  .detail-table .table_header {
    margin-bottom: 3.91vw;
  }
  .detail-table .table_header .title {
    font-size: 2.34vw;
    margin-bottom: 1.95vw;
    position: relative;
    padding: 0 0 1.95vw;
    line-height: 1.5;
    color: var(--main-color);
    letter-spacing: 0.08em;
    border-bottom: 1px solid var(--main-color);
  }
  .detail-table .detail-table_unit {
    border-bottom: 1px solid rgba(0, 0, 0, 0.15);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 2.44vw 2.93vw;
  }
  .detail-table .detail-table_unit:last-child {
    border: none;
  }
  .detail-table .detail-table_unit dt {
    width: 12.7vw;
    font-weight: bold;
  }
  .detail-table .detail-table_unit dd {
    width: calc(100% - 12.7vw);
  }
  .detail-button {
    margin-bottom: 4.88vw;
  }
  .detail-button a {
    min-width: 46.88vw;
  }
  .inner_contents {
    width: 100%;
  }
  .inner_contents.wide_l {
    max-width: 117.19vw;
  }
  .inner_contents.wide_m {
    max-width: 105.47vw;
  }
  .inner_contents.wide_s {
    max-width: 93.75vw;
  }
  .inner_contents.wide_ss {
    max-width: 62.5vw;
  }
  .inner_contents.wide_fit_right {
    width: calc(100% - 19.82vw);
    margin-right: 0;
  }
  #globalFooter .inner {
    max-width: initial;
    width: 100%;
    padding: 3.32vw 3.91vw;
  }
  #is_top #news {
    padding-left: 3.91vw;
    padding-right: 3.91vw;
  }
  #is_top #news .inner_contents {
    width: 100%;
  }
  #is_top .sec_faq .inner_contents,
  #is_top .sec_interview .inner_contents,
  #is_top .sec_voice .inner_contents,
  #is_top .sec_recruitment .inner_contents,
  #is_top .sec_blog .inner_contents {
    padding-left: 3.91vw;
    padding-right: 3.91vw;
  }
  #is_top .sec_faq .sec_title strong,
  #is_top .sec_interview .sec_title strong,
  #is_top .sec_voice .sec_title strong,
  #is_top .sec_recruitment .sec_title strong,
  #is_top .sec_blog .sec_title strong {
    margin-left: 0;
  }
  #is_top .sec_photo .sec_header {
    padding-left: 3.91vw;
    padding-right: 3.91vw;
  }
  #is_top .sec_photo .sec_title strong {
    margin-left: 0;
  }
  .panel.p_left .bg, .panel.p_right .bg {
    min-width: initial;
  }
  .modal .modal_container {
    padding-left: 3.91vw;
    padding-right: 3.91vw;
  }
}

@media screen and (max-width: 750px) {
  body {
    font-size: 3.73vw;
  }
  body [data-target][slideup] {
    -webkit-transform: translateY(5.33vw) scale(1);
    transform: translateY(5.33vw) scale(1);
  }
  body [data-target][slidedown] {
    -webkit-transform: translateY(-5.33vw) scale(1);
    transform: translateY(-5.33vw) scale(1);
  }
  body [data-target][slideleft] {
    -webkit-transform: translateX(5.33vw) scale(1);
    transform: translateX(5.33vw) scale(1);
  }
  body [data-target][slideright] {
    -webkit-transform: translateX(-5.33vw) scale(1);
    transform: translateX(-5.33vw) scale(1);
  }
  .modal .btn_modal_close {
    top: 5.33vw;
    right: 5.33vw;
    width: 8.53vw;
    height: 8.53vw;
  }
  .modal .btn_modal_close:before, .modal .btn_modal_close:after {
    width: 11.73vw;
    height: 0.53vw;
  }
  .modal .modal_contents {
    max-width: initial;
    padding: 20vw 5.33vw;
  }
  .modal .modal_contents.wide_l, .modal .modal_contents.wide_s, .modal .modal_contents.wide_ss {
    max-width: initial;
  }
  .modal .modal_contents section {
    margin-bottom: 13.33vw;
  }
  .img_unit {
    display: block;
  }
  .img_unit.reverse .img {
    margin-right: 0;
    margin-left: 0;
  }
  .img_unit.bdr_btm {
    padding-bottom: 8vw;
    margin-bottom: 8vw;
  }
  .img_unit .img {
    margin: 0 0 5.33vw 0;
  }
  .img_unit .txt h2 {
    margin-bottom: 4vw;
  }
  .img_unit .txt p {
    margin-bottom: 5.33vw;
  }
  .table_unit dl {
    padding: 4vw 0;
    display: block;
  }
  .table_unit dl dt {
    width: 100%;
    padding: 0;
    margin-bottom: 2.67vw;
    font-weight: bold;
  }
  .table_unit dl dd {
    width: 100%;
    padding: 0;
  }
  .table_unit dl dd p {
    margin-bottom: 8vw;
  }
  .table_unit dl dd p:last-of-type {
    margin-bottom: 0;
  }
  .thumb_unit {
    display: block;
  }
  .thumb_unit figure {
    width: 100%;
    margin: 0 0 8vw 0;
  }
  .thumb_unit figure figcaption {
    margin-top: 3.2vw;
    font-size: 3.2vw;
  }
  .form_unit {
    display: block;
  }
  .form_unit dt {
    width: 100%;
    padding: 4vw 0 1.33vw 0;
    font-size: 3.73vw;
    text-align: left;
  }
  .form_unit dt .required {
    margin-left: 1.87vw;
  }
  .form_unit dd {
    width: 100%;
    padding: 0 0 4vw 0;
  }
  .form_unit .row {
    margin-bottom: 2.67vw;
  }
  .form_unit .col {
    margin-right: 3.2vw;
  }
  .form_unit .col.input_half {
    width: 50%;
  }
  .form_unit .col.input_mini {
    width: 33%;
  }
  .form_unit .radio,
  .form_unit .checkbox {
    height: 11.73vw;
  }
  .form_unit .radio > *,
  .form_unit .checkbox > * {
    margin-right: 4vw;
  }
  .form_unit .select {
    width: 25%;
  }
  .form_unit .select svg {
    width: 2.67vw;
    height: 1.33vw;
    right: 2.67vw;
    margin-top: -0.67vw;
  }
  .form_unit .p-form__file_label {
    font-size: 3.73vw;
  }
  .form_unit .p-form__file_label .p-form__file_txt {
    width: 32vw;
    height: 10.67vw;
    border-radius: 0.8vw;
  }
  .form_unit .p-form__file_label .p-form__file_name {
    margin-left: 4vw;
  }
  .form_unit .note {
    font-size: 3.2vw;
  }
  .form_unit input[type='text'],
  .form_unit input[type='email'],
  .form_unit input[type='tel'],
  .form_unit input[type='url'],
  .form_unit input[type='password'] {
    border-radius: 1.33vw;
    padding: 0 4.8vw;
    height: 11.73vw;
  }
  .form_unit select {
    border-radius: 1.33vw;
    padding: 0 2.67vw 0 2.67vw;
    height: 11.73vw;
    width: 100%;
  }
  .form_unit textarea {
    border: 1px solid #e9e9e9;
    border-radius: 1.33vw;
    width: 100%;
    height: 42.67vw;
    padding: 4.8vw;
  }
  .form_unit textarea:focus {
    background-color: #f5f5f5;
    border: 2px solid #c7c7c7;
  }
  .site_sns a {
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-property: color, opacity;
    transition-property: color, opacity;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

@media screen and (max-width: 750px) and (min-width: 750px) {
  .site_sns a:hover {
    opacity: 0.6 !important;
  }
}

@media screen and (max-width: 750px) {
  .site_sns a.tw svg {
    width: 4.27vw;
    height: 3.47vw;
  }
  .site_sns a.fb svg {
    width: 2.13vw;
    height: 4vw;
  }
  .site_sns a.ig svg {
    width: 4vw;
    height: 4vw;
  }
  .site_sns a.yt svg {
    width: 4.27vw;
    height: 2.93vw;
  }
  .sec_title {
    top: -1.33vw;
    left: 7.2vw;
  }
  .sec_title.reverse strong {
    padding-right: 11.73vw;
    margin-right: 2.4vw;
  }
  .sec_title strong {
    font-size: 2.93vw;
    padding-left: 11.73vw;
    margin-left: 2.4vw;
  }
  .sec_title strong:before {
    width: 9.33vw;
  }
  .sec_title span {
    font-size: 2.67vw;
  }
  .page_title strong {
    font-size: 3.47vw;
    margin-bottom: 3.2vw;
  }
  .page_title span {
    font-size: 6.4vw;
  }
  .unit_title {
    height: auto;
    min-height: 11.73vw;
    font-size: 4.8vw;
    padding: 2.67vw 0;
    margin-bottom: 6.67vw;
  }
  .medium_title {
    font-size: 4.8vw;
  }
  .large_title {
    font-size: 5.33vw;
  }
  .mini_title strong {
    margin-bottom: 4vw;
    font-size: 5.33vw;
    display: block;
  }
  .mini_title span {
    font-size: 2.67vw;
    display: block;
  }
  .swiper .swiper-pagination .swiper-pagination-bullet {
    width: 6.13vw;
    height: 0.8vw;
    margin: 0 1.6vw 0 0 !important;
  }
  .swiper .swiper-button-next,
  .swiper .swiper-button-prev {
    display: none;
  }
  .swiper[data-swiper='slider'] .swiper-container {
    max-width: initial;
  }
  .swiper[data-swiper='slider'] .swiper-wrapper {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .swiper[data-swiper='slider'] .swiper-slide {
    width: calc(50% - 1.33vw);
    margin-bottom: 6.67vw;
  }
  .swiper[data-swiper='carousel'] .swiper-slide {
    width: calc(100% - 16vw);
  }
  .btn a,
  .btn input,
  .btn button,
  .btn span {
    padding: 2.67vw 0;
    min-height: 12vw;
  }
  .btn a svg,
  .btn input svg,
  .btn button svg,
  .btn span svg {
    width: 1.6vw;
    height: 2.67vw;
    margin-left: 3.73vw;
  }
  .btn.right {
    text-align: left;
  }
  .btns {
    margin-top: 10.67vw;
  }
  .btns .btn.wide_m {
    width: calc(50% - 2.67vw);
  }
  .btns.right {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
  .btn_more {
    width: 78.67vw;
    height: 14.13vw;
    font-size: 4vw;
    padding: 0 5.33vw;
  }
  .btn_more svg {
    right: 4.8vw;
    margin-top: -1.87vw;
    width: 3.73vw;
    height: 3.73vw;
  }
  .btn_return {
    width: 78.67vw;
    height: 14.13vw;
    font-size: 4vw;
    padding: 0 5.33vw;
  }
  .btn_return svg {
    right: 4.8vw;
    margin-top: -1.6vw;
    width: 1.87vw;
    height: 3.2vw;
  }
  .btn_readmore {
    font-size: 3.73vw;
    width: 100%;
  }
  .btn_readmore svg {
    width: 19.73vw;
    height: 2.13vw;
  }
  .acc {
    font-size: 4.27vw;
    border-width: 1px;
    border-radius: 1.07vw;
  }
  .acc:after {
    border-radius: 1.07vw;
    border: 1px solid transparent;
  }
  .acc.active:after {
    border-width: 1px;
  }
  .acc.is_open:after {
    border-width: 1px;
  }
  .acc .q {
    padding: 5.33vw 5.33vw 5.33vw 13.33vw;
    font-size: 3.73vw;
  }
  .acc .q:before {
    font-size: 4.8vw;
    top: 5.87vw;
    left: 5.33vw;
  }
  .acc .a {
    padding: 0 5.33vw 5.33vw 13.33vw;
    font-size: 3.47vw;
  }
  .acc .a:before {
    font-size: 4.8vw;
    left: 5.33vw;
  }
  .privacy {
    font-size: 3.2vw;
  }
  .privacy .privacy_title {
    margin-bottom: 8vw;
  }
  .privacy .privacy_lead,
  .privacy .privacy_footer {
    margin-bottom: 8vw;
  }
  .privacy .privacy_contents dl {
    margin-bottom: 4vw;
    padding-bottom: 4vw;
  }
  .privacy .privacy_contents dl dt {
    margin-bottom: 2.67vw;
  }
  .privacy .privacy_contents dl dd {
    font-size: 3.2vw;
  }
  .label {
    font-size: 2.67vw;
  }
  .photo figcaption {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    font-size: 2.67vw;
    padding: 4vw;
  }
  .prof_img .name {
    padding: 2.67vw;
  }
  .prof_img .name span {
    font-size: 3.2vw;
    margin-bottom: 1.33vw;
  }
  .prof_img .name strong {
    font-size: 3.2vw;
  }
  .card {
    padding: 4vw;
  }
  .card figure {
    width: 11.73vw;
  }
  .card dl {
    width: calc(100% - 15.73vw);
  }
  .card dl dt {
    margin-bottom: 1.33vw;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .card dl dt strong {
    font-size: 3.73vw;
  }
  .card dl dt .label {
    margin-left: 2.13vw;
  }
  .card dl dd {
    font-size: 3.2vw;
  }
  .required {
    border-radius: 2.67vw;
    font-size: 2.67vw;
    padding: 1.07vw 1.6vw;
  }
  .wysiwyg {
    font-size: 3.73vw;
  }
  .txt_error {
    font-size: 3.2vw;
    margin-top: 3.2vw;
  }
  .txt_error svg {
    width: 3.47vw;
    height: 3.47vw;
    margin-right: 1.6vw;
  }
  #wrapper #container.under {
    padding-top: 40vw;
    padding-bottom: 16vw;
  }
  .inner_contents {
    width: 100%;
    padding-right: 5.33vw;
    padding-left: 5.33vw;
  }
  .inner_contents.wide_l, .inner_contents.wide_m, .inner_contents.wide_s, .inner_contents.wide_ss {
    max-width: initial;
    padding-right: 5.33vw;
    padding-left: 5.33vw;
  }
  .inner_contents.wide_fit_right {
    width: 100%;
    padding-right: 8vw;
    padding-left: 8vw;
  }
  #globalHeader .inner {
    max-width: 100%;
    padding: 0 4vw;
    min-height: 18.67vw;
  }
  #globalHeader .site_logo {
    max-width: initial;
    max-height: initial;
    min-height: 100%;
    padding-bottom: 0;
    position: absolute;
    top: 0;
    left: 0;
    padding-top: 0;
  }
  #globalHeader .site_logo a {
    padding: 2.67vw 2.67vw;
  }
  #globalHeader .site_logo figure {
    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;
  }
  #globalHeader .site_logo img {
    max-width: 26.67vw;
    max-height: 26.67vw;
  }
  #globalHeader .site_logo .site_txt {
    font-size: 2.67vw;
    margin-top: 2.67vw;
  }
  #globalHeader .sitenavi {
    height: 16vw;
    margin-left: auto;
    padding-top: 0;
  }
  #globalHeader .sitenavi .contact {
    display: none;
  }
  #globalHeader .sitenavi a {
    padding-right: 5.33vw;
    font-size: 3.73vw;
  }
  #globalHeader .sitenavi a svg {
    width: 4.27vw;
    margin-right: 2.4vw;
    fill: #ffffff;
  }
  #globalHeader .sitenavi .site_sns,
  #globalHeader .sitenavi .pc_navi {
    display: none;
  }
  #globalHeader.hide .header_bg {
    -webkit-box-shadow: initial;
    box-shadow: initial;
  }
  #btnMenu {
    top: 2.67vw;
    right: 4vw;
    width: 9.33vw;
    height: 13.33vw;
    margin-right: 0;
    display: block;
  }
  #btnMenu span {
    width: 9.33vw;
    left: 0;
  }
  #btnMenu span:nth-child(1) {
    top: 2.13vw;
  }
  #btnMenu span:nth-child(2) {
    top: 5.33vw;
  }
  #btnMenu span:nth-child(3) {
    top: 8.53vw;
  }
  #btnMenu.active span:nth-child(1) {
    top: 5.33vw;
  }
  #btnMenu.active span:nth-child(3) {
    top: 5.33vw;
  }
  #globalNavi .inner {
    font-size: 3.73vw;
  }
  #breadcrumb {
    font-size: 2.67vw;
    top: 20.53vw;
    right: 4vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #breadcrumb span {
    display: inline-block;
    max-width: 26.67vw;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  #globalFooter .btn_pagetop {
    width: 11.73vw;
    height: 11.73vw;
    top: 5.33vw;
    right: 4vw;
    z-index: 20;
  }
  #globalFooter .btn_pagetop.fixed {
    bottom: 5.33vw;
  }
  #globalFooter .btn_pagetop svg {
    width: 100%;
    height: 100%;
  }
  #globalFooter .inner {
    max-width: initial;
    padding: 5.33vw;
    display: block;
  }
  #globalFooter .main {
    font-size: 3.2vw;
    width: 100%;
    font-weight: normal;
    margin-bottom: 6.67vw;
  }
  #globalFooter .sub {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  #globalFooter .sub .site_sns {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    padding-bottom: 0;
  }
  #globalFooter .sub .site_sns a {
    margin-left: 5.33vw;
  }
  #globalFooter .sub .copyright {
    position: relative;
    font-size: 2.67vw;
  }
  .is_under #globalHeader .header_bg {
    height: 17.6vw;
  }
  .is_under #globalHeader .site_logo {
    background-color: transparent;
  }
  .is_scroll #globalHeader .inner {
    min-height: 17.6vw;
  }
  .is_scroll #globalHeader .site_logo {
    -webkit-box-shadow: initial;
    box-shadow: initial;
  }
  .section-container {
    max-width: initial;
    padding: 0 5.33vw 20vw;
  }
  .section-container.wide_l, .section-container.wide_s, .section-container.wide_ss {
    max-width: initial;
  }
  .section-container section {
    margin-bottom: 13.33vw;
  }
  #is_top #globalHeader .header_bg {
    height: 17.6vw;
  }
  #is_top #mv {
    height: calc(100vh - 20.27vw);
    min-height: initial;
  }
  #is_top #mv .ic_scroll {
    font-size: 2.67vw;
    height: 19.2vw;
  }
  #is_top #mv .ic_scroll:before {
    height: 13.33vw;
    top: 5.87vw;
  }
  #is_top #mv .site_sns {
    right: 4vw;
  }
  #is_top #mv .site_sns a {
    margin-bottom: 5.33vw;
  }
  #is_top #mv .mv_txt {
    left: 17.33vw;
    width: calc(100% - 30.67vw);
  }
  #is_top #mv .mv_txt .mv_title {
    font-size: 10.67vw;
    margin-bottom: 2.67vw;
  }
  #is_top #mv .mv_txt .mv_subtitle {
    font-size: 4vw;
  }
  #is_top #mv .mv_slider .swiper-pagination {
    bottom: 4vw;
    left: 5.33vw;
  }
  #is_top .mv-news {
    padding: 5.33vw 6.67vw 0 12vw;
  }
  #is_top .mv-news .inner_contents {
    width: 100%;
  }
  #is_top .mv-news .title {
    font-size: 2.93vw;
    left: -10.67vw;
    top: 3.2vw;
  }
  #is_top .mv-news .content {
    font-size: 2.93vw;
  }
  #is_top .mv-news .content a {
    display: block;
    min-height: 14.67vw;
  }
  #is_top .mv-news .content span {
    display: block;
  }
  #is_top .mv-news .content .date {
    margin: 0 0 1.33vw 0;
  }
  #is_top .mv-news .content svg {
    width: 1.6vw;
    height: 2.67vw;
  }
  #is_top #map {
    height: 58.67vw;
  }
  .blog_header {
    margin-bottom: 9.33vw;
  }
  .archive_link {
    position: relative;
    bottom: 0;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 8vw;
    font-size: 3.47vw;
  }
  .archive_link .select {
    margin-left: 10.67vw;
    padding-right: 4.8vw;
  }
  .archive_link .select svg {
    width: 3.2vw;
    height: 1.87vw;
    margin-left: 1.33vw;
  }
  .blog .entry {
    position: relative;
  }
  .blog .entry header .info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 6.67vw;
  }
  .blog .entry header .info .label {
    margin-right: 2.67vw;
    font-size: 3.2vw;
    border-radius: 0.53vw;
    padding: 1.33vw 2.13vw;
  }
  .blog .entry header .info .date {
    font-size: 3.2vw;
  }
  .blog .entry header h1 {
    font-size: 5.87vw;
    font-weight: bold;
    letter-spacing: 0.08em;
    line-height: 1.7;
  }
  .blog.archive {
    display: block;
  }
  .blog.archive .entry {
    width: 100%;
    margin: 0 0 10.67vw 0;
    padding-bottom: 10.67vw;
  }
  .blog.archive .entry:after {
    width: 100%;
    height: 1px;
    top: auto;
    bottom: 0;
    right: 0;
  }
  .blog.archive .entry figure {
    margin-bottom: 4vw;
  }
  .blog.archive .entry header .info {
    margin-bottom: 2.67vw;
  }
  .blog.archive .entry header h1 {
    font-size: 3.73vw;
  }
  .blog.detail .mv {
    margin-bottom: 5.33vw;
    text-align: center;
  }
  .blog.detail header {
    border-bottom: 1px solid #e9e9e9;
    margin-bottom: 16vw;
    padding-bottom: 10.67vw;
  }
  .blog.detail .contents {
    letter-spacing: 0.15em;
  }
  .blog.detail .contents h1,
  .blog.detail .contents h2,
  .blog.detail .contents h3,
  .blog.detail .contents h4,
  .blog.detail .contents h5,
  .blog.detail .contents h6 {
    font-weight: bold;
    margin-bottom: 6.67vw;
  }
  .blog.detail .contents h1 {
    font-size: 5.33vw;
  }
  .blog.detail .contents h2 {
    font-size: 4.8vw;
  }
  .blog.detail .contents h3 {
    font-size: 4.27vw;
  }
  .blog.detail .contents h4,
  .blog.detail .contents h5,
  .blog.detail .contents h6 {
    font-size: 3.73vw;
  }
  .blog.detail .contents p,
  .blog.detail .contents ol,
  .blog.detail .contents ul,
  .blog.detail .contents table,
  .blog.detail .contents dl {
    margin-bottom: 10.67vw;
  }
  .blog.detail .contents a {
    color: var(--main-color);
    text-decoration: underline;
  }
}

@media screen and (max-width: 750px) and (min-width: 750px) {
  .blog.detail .contents a:hover {
    text-decoration: none;
  }
}

@media screen and (max-width: 750px) {
  .blog.detail .contents ul li {
    list-style: disc;
    margin-left: 5.33vw;
  }
  .blog.detail .contents ol li {
    list-style: decimal;
    margin-left: 5.33vw;
  }
  #is_contact .message {
    margin-bottom: 18.67vw;
    text-align: left;
  }
  #is_contact .message p {
    margin-bottom: 8vw;
  }
  #is_contact .form .form_txt {
    text-align: left;
    margin-bottom: 10.67vw;
    margin-top: 16vw;
    font-size: 3.2vw;
  }
  #is_contact .form .privacy {
    margin-bottom: 10.67vw;
  }
  #is_contact .form .privacy .scroll_area {
    height: 69.33vw;
    padding: 5.33vw;
  }
  #is_contact .form .privacy_check .mwform-checkbox-field {
    margin-bottom: 5.33vw;
  }
  #sectionNews .contents ul {
    margin-bottom: 20vw;
  }
  #sectionNews .contents .entry {
    padding: 5.33vw 0;
  }
  #sectionNews .contents .entry .entry_header {
    display: block;
  }
  #sectionNews .contents .entry .entry_header .date {
    width: auto;
    font-size: 3.73vw;
    margin-bottom: 2.67vw;
  }
  #sectionNews .contents .entry .entry_header .txt {
    width: auto;
    font-size: 3.73vw;
  }
  #sectionNews .contents .entry .entry_body {
    width: 100%;
    margin: 4vw 0 0 auto;
  }
  .cover-bg .inner_contents {
    width: 100%;
    padding: 0;
  }
  .cover-bg .bg figure {
    min-height: 68vw;
  }
  .cover-bg .bg .sec_title {
    top: auto;
    bottom: -4vw;
    left: 8vw;
  }
  .cover-bg .contents {
    position: relative;
    min-width: initial;
    width: calc(100% - 12vw);
    bottom: 0;
    right: 0;
    margin: -5.33vw 0 0 auto;
  }
  .cover-bg .contents .inner {
    padding: 8vw 12vw 8vw 8vw;
  }
  .cover-bg .contents .title {
    font-size: 6.4vw;
    margin-bottom: 6.67vw;
  }
  .cover-bg .contents .txt {
    margin-bottom: 8vw;
  }
  .cover-bg .btn_readmore {
    color: #ffffff;
  }
  .image-panel:before {
    width: 100vw;
    height: 60%;
  }
  .image-panel .inner_contents {
    width: 100%;
    padding-top: 10.67vw;
    padding-bottom: 10.67vw;
  }
  .image-panel .bg {
    width: calc(100% - 12vw);
    min-width: 68vw;
  }
  .image-panel .bg figure {
    min-height: 68vw;
  }
  .image-panel .contents {
    position: relative;
    min-width: initial;
    width: calc(100% - 24vw);
    margin: 0 auto;
    -webkit-transform: translateY(0);
    transform: translateY(0);
    top: 0;
    padding-top: 6.67vw;
  }
  .image-panel .contents .title {
    font-size: 6.4vw;
    margin-bottom: 6.67vw;
  }
  .image-panel .contents .txt {
    margin-bottom: 8vw;
  }
  .image-panel.left:before {
    left: 0;
  }
  .image-panel.left .bg .sec_title {
    -webkit-transform: translateX(100%) rotate(90deg);
    transform: translateX(100%) rotate(90deg);
    -webkit-transform-origin: 0 100%;
    transform-origin: 0 100%;
    top: -2.67vw;
    right: -5.33vw;
  }
  .image-panel.right .bg {
    margin-left: auto;
  }
  .image-panel.right .bg .sec_title {
    top: -2.67vw;
    left: -5.33vw;
  }
  .column-banner .module_bg {
    width: 100vw;
  }
  .column-banner .inner_contents {
    padding-left: 12vw;
    padding-right: 0;
  }
  .column-banner .swiper {
    margin-bottom: 0;
  }
  .column-banner .swipe_controls {
    display: none;
  }
  .column-banner .btn {
    margin-top: 8vw;
  }
  .ap-slideshow {
    position: static;
  }
  .ap-slideshow .module_bg {
    width: 100vw;
  }
  .ap-slideshow .inner_contents {
    padding-right: 12vw;
    padding-left: 0;
  }
  .ap-slideshow .sec_title {
    top: -2.67vw;
    right: 8vw;
  }
  .ap-slideshow .swiper {
    width: 100%;
  }
  .ap-slideshow .swiper .swiper-container {
    overflow: initial;
  }
  .ap-slideshow .swiper .swiper-slide {
    position: relative;
  }
  .ap-slideshow .swiper .swiper-slide div {
    position: relative;
  }
  .ap-slideshow .swiper .swiper-slide div:before {
    content: '';
    display: block;
    padding-top: 64.2%;
  }
  .ap-slideshow .swiper .swiper-slide img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .ap-slideshow .swiper .swiper-slide figcaption {
    position: relative;
    top: 0;
    right: 0;
    width: 48vw;
    font-size: 2.93vw;
    margin: 5.33vw 0 0 12vw;
  }
  .ap-slideshow .swiper .swiper-pagination {
    top: 62.67vw;
    right: 7.47vw;
    left: auto;
    font-size: 2.93vw;
  }
  .ap-slideshow .swiper .swipe_controls {
    right: 0;
    left: auto;
    top: 61.87vw;
  }
  .ap-slideshow .swiper .swipe_controls .swiper-button-prev,
  .ap-slideshow .swiper .swipe_controls .swiper-button-next {
    display: block;
  }
  .ap-slideshow .swiper .swipe_controls .swiper-button-prev {
    margin-right: 16vw;
  }
  .ap-table .inner_contents {
    padding-left: 12vw;
    padding-right: 5.33vw;
  }
  .ap-table .table-block {
    padding: 5.33vw;
    margin-bottom: 10.67vw;
  }
  .ap-table .table-block .lead {
    margin-bottom: 8vw;
  }
  .ap-table .table-block .lead dt {
    font-size: 5.33vw;
    margin-bottom: 5.33vw;
    padding-bottom: 5.33vw;
  }
  .ap-table .table-block .lead dd {
    font-size: 3.73vw;
  }
  .ap-table .table-block .unit {
    display: block;
    padding: 2.67vw 4vw;
    font-size: 4vw;
  }
  .ap-table .table-block .unit dt {
    width: 100%;
    margin-bottom: 1.33vw;
  }
  .ap-table .table-block .unit dd {
    width: 100%;
  }
  .vertical-text .module_bg {
    width: 100vw;
  }
  .vertical-text .inner_contents {
    padding-left: 12vw;
    padding-right: 5.33vw;
  }
  .vertical-text .sec_title {
    text-align: center;
    margin-bottom: 16vw;
  }
  .vertical-text .sec_title strong {
    margin-left: 0;
  }
  .vertical-text .row {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-writing-mode: initial;
    -ms-writing-mode: initial;
    writing-mode: initial;
  }
  .vertical-text .row .title {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-size: 5.33vw;
    margin: 0 0 13.33vw 0;
  }
  .vertical-text .row .txt {
    font-size: 3.73vw;
    line-height: 2;
    letter-spacing: 0.08em;
  }
  .vertical-text .row .txt > * {
    margin: 0 0 5.33vw 0;
  }
  .vertical-text .row .txt > *:last-child {
    margin: 0;
  }
  .vertical-text .row .txt > * br {
    display: none;
  }
  .freearea .module_bg {
    width: 100vw;
  }
  .freearea .inner_contents {
    padding-right: 12vw;
    padding-left: 5.33vw;
  }
  .freearea .sec_title {
    top: -2.67vw;
    right: 7.2vw;
  }
  .ap-blog .module_bg {
    width: 100vw;
  }
  .ap-blog .inner_contents {
    padding-left: 12vw;
    padding-right: 5.33vw;
  }
  .ap-blog .blog.archive {
    display: block;
  }
  .ap-blog .blog.archive .swiper {
    width: 100%;
  }
  .ap-blog .blog.archive .entry {
    width: 100%;
    margin-bottom: 4vw;
    padding-bottom: 0;
  }
  .ap-blog .blog.archive .entry a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .ap-blog .blog.archive .entry figure {
    width: 32vw;
    position: relative;
    margin-bottom: 0;
  }
  .ap-blog .blog.archive .entry figure div {
    background-color: #ffffff;
    position: relative;
    z-index: 5;
    overflow: hidden;
  }
  .ap-blog .blog.archive .entry figure div:before {
    content: '';
    display: block;
    padding-top: 66.7%;
  }
  .ap-blog .blog.archive .entry figure img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .ap-blog .blog.archive .entry header {
    width: calc(100% - 36vw);
  }
  .ap-blog .blog.archive .entry header h1 {
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  .ap-news {
    padding-left: 0;
    padding-right: 0;
  }
  .ap-news .inner_contents {
    padding-left: 12vw;
    padding-right: 5.33vw;
  }
  .ap-news .title {
    margin-bottom: 5.33vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 1.33vw;
  }
  .ap-news .title strong {
    font-size: 4.8vw;
  }
  .ap-news .title span {
    font-size: 2.93vw;
  }
  .ap-news .content {
    display: block;
  }
  .ap-news .content ul {
    width: 100%;
    margin-bottom: 8vw;
  }
  .ap-news .content ul li {
    margin-bottom: 3.73vw;
    padding-bottom: 3.73vw;
  }
  .ap-news .content ul li a {
    display: block;
    padding-right: 5.33vw;
  }
  .ap-news .content ul li .date {
    margin: 0 0 2.67vw 0;
    font-size: 2.93vw;
    display: block;
  }
  .ap-news .content ul li .txt {
    display: block;
    font-size: 3.47vw;
  }
  .ap-news .btn_archive {
    font-size: 3.73vw;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
  .ap-news .btn_archive svg {
    margin-left: 2.13vw;
    width: 3.73vw;
    height: 1.33vw;
  }
  .detail-anchor {
    display: none;
  }
  .detail-anchor_sp {
    display: block;
    margin-bottom: 20vw;
    border: 1px solid rgba(0, 0, 0, 0.15);
    width: 100%;
    position: relative;
    font-size: 4vw;
    font-weight: bold;
  }
  .detail-anchor_sp svg {
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 5.33vw;
    fill: #000000;
    height: 1.6vw;
    width: 2.67vw;
  }
  .detail-anchor_sp select {
    width: 100%;
    height: 100%;
    padding: 5.33vw;
  }
  .detail-title {
    font-size: 4.8vw;
    margin-bottom: 6.67vw;
  }
  .detail-text {
    margin-bottom: 13.33vw;
  }
  .detail-vertical {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-writing-mode: initial;
    -ms-writing-mode: initial;
    writing-mode: initial;
    margin-bottom: 13.33vw;
  }
  .detail-vertical .title {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-size: 5.33vw;
    margin: 0 0 13.33vw 0;
  }
  .detail-vertical .txt {
    font-size: 3.73vw;
  }
  .detail-list {
    margin: 0 auto 13.33vw;
    max-width: initial;
  }
  .detail-list li {
    margin-bottom: 5.33vw;
    padding-left: 5.33vw;
  }
  ul.detail-list svg {
    width: 3.73vw;
    height: 2.4vw;
    top: 2.13vw;
  }
  ul.detail-list li:before {
    width: 2.13vw;
    height: 2.13vw;
    top: 2.67vw;
  }
  .lecture_list_wrap {
    row-gap: 6.67vw;
    padding: 6.67vw 5.33vw;
  }
  .detail-lecture {
    padding-bottom: 6.67vw;
    display: block;
  }
  .detail-lecture dt {
    width: 100%;
    padding-right: 0;
    margin-bottom: 1.33vw;
    font-size: 4vw;
  }
  .detail-lecture dd {
    width: 100%;
    padding-left: 0;
  }
  .detail-swiper {
    margin-bottom: 13.33vw;
    position: relative;
  }
  .detail-swiper .swiper-container {
    padding-bottom: 5.33vw;
    width: 100%;
    padding: 0;
  }
  .detail-swiper .swiper-button-prev,
  .detail-swiper .swiper-button-next {
    width: 3.2vw;
    height: 6.4vw;
  }
  .detail-swiper .swiper-button-next {
    right: -16vw;
  }
  .detail-swiper .swiper-button-prev {
    left: -16vw;
  }
  .detail-swiper .swiper-pagination .swiper-pagination-bullet {
    width: 6.13vw;
    height: 0.8vw;
    margin: 0 4vw 0 0 !important;
  }
  .detail-swiper .swiper-slide {
    padding-bottom: 13.33vw;
  }
  .detail-swiper .detail-slide-figure figcaption {
    padding-top: 2.67vw;
  }
  .detail-image-side {
    margin-bottom: 10.67vw;
    display: block;
  }
  .detail-image-side .img {
    width: calc(100% + 5.33vw);
    margin-bottom: 9.33vw;
  }
  .detail-image-side .txt {
    width: 100%;
  }
  .detail-image-side .txt .title {
    font-size: 4.8vw;
    margin-bottom: 2.67vw;
  }
  .detail-image-side.left .img {
    margin-left: -5.33vw;
  }
  .detail-image-side.right .img {
    margin-right: -5.33vw;
  }
  .detail-image-column {
    display: block;
    margin-bottom: 8vw;
  }
  .detail-image-column .detail-image-column-unit {
    margin-bottom: 10.67vw;
  }
  .detail-image-column .detail-image-column-unit:last-of-type {
    margin-bottom: 0;
  }
  .detail-image-column .detail-image-column-unit .img {
    margin-bottom: 4vw;
  }
  .detail-image-column .detail-image-column-unit .title {
    margin-bottom: 2.67vw;
  }
  .detail-image-column.column-2 .detail-image-column-unit .title {
    font-size: 4.27vw;
  }
  .detail-image-column.column-3 .detail-image-column-unit .title {
    font-size: 4.27vw;
  }
  .detail-column {
    margin-bottom: 13.33vw;
    padding: 5.33vw;
  }
  .detail-column .title {
    font-size: 4.27vw;
    margin-bottom: 5.33vw;
    padding: 0 0 4vw;
  }
  .detail-column .contents {
    display: block;
    position: relative;
    z-index: 5;
  }
  .detail-column .contents .txt {
    font-size: 3.73vw;
    margin-bottom: 5.33vw;
  }
  .detail-baloon {
    margin-bottom: 13.33vw;
  }
  .detail-baloon .detail-baloon-unit {
    margin-bottom: 8vw;
  }
  .detail-baloon .detail-baloon-unit .img {
    width: 10.67vw;
  }
  .detail-baloon .detail-baloon-unit .img div {
    width: 10.67vw;
    height: 10.67vw;
  }
  .detail-baloon .detail-baloon-unit .img figcaption {
    font-size: 2.67vw;
    margin-top: 1.33vw;
  }
  .detail-baloon .detail-baloon-unit .txt {
    padding: 5.33vw;
    width: calc(100% - 13.33vw);
  }
  .detail-profile {
    margin-bottom: 13.33vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    grid-template-columns: initial;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    row-gap: 9.33vw;
  }
  .detail-profile .detail-profile-unit {
    max-width: 57.33vw;
  }
  .detail-profile .detail-profile-unit .img {
    width: 45.33vw;
    height: 45.33vw;
    margin: 0 auto 2.67vw;
  }
  .detail-profile .detail-profile-unit .txt dt {
    font-size: 4vw;
    margin-bottom: 2.67vw;
  }
  .detail-profile .detail-profile-unit .txt dd {
    font-size: 3.47vw;
  }
  .detail-faq {
    margin-bottom: 13.33vw;
  }
  .detail-faq .detail-faq-unit {
    margin-bottom: 4vw;
  }
  .detail-table {
    margin-bottom: 13.33vw;
  }
  .detail-table .table_header {
    margin-bottom: 6.67vw;
  }
  .detail-table .table_header .title {
    font-size: 4.27vw;
    padding: 0 0 3.73vw;
    margin-bottom: 5.33vw;
  }
  .detail-table .detail-table_unit {
    display: block;
    padding: 0 0 5.33vw 0;
    margin-bottom: 5.33vw;
  }
  .detail-table .detail-table_unit:last-child {
    border: none;
    margin-bottom: 0;
    padding-bottom: 0;
  }
  .detail-table .detail-table_unit dt {
    width: 100%;
  }
  .detail-table .detail-table_unit dd {
    width: 100%;
  }
  .detail-button {
    margin-bottom: 13.33vw;
  }
  .detail-button a {
    min-width: 78.67vw;
  }
}
