@charset "UTF-8";
/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  font-size: 62.5%;
  scroll-behavior: smooth;
}

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  position: relative;
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: inherit;
  /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
a:link {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

a {
  background-color: transparent;
  color: inherit;
  -webkit-transition: ease 0.2s;
  transition: ease 0.2s;
  text-decoration: underline;
}
a:hover {
  -webkit-transition: ease 0.2s;
  transition: ease 0.2s;
  text-decoration: none;
}

p {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
p a:link {
  text-decoration: underline;
}

.break_keep {
  word-break: keep-all;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: inherit;
  /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

/**
 * Reset radio and checkbox appearance to preserve their look in iOS.
 */
[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox;
}

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

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

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

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Remove arrow in IE10 & IE11
 */
select::-ms-expand {
  display: none;
}

/**
 * Remove padding
 */
option {
  padding: 0;
}

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
  padding: 0.5em;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the outline style in Safari.
 */
[type=search] {
  outline-offset: -2px;
  /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */
[contenteditable] {
  outline: none;
}

/* Table */
/* ============================================ */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  padding: 0;
}

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

/* Misc */
/* ============================================ */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

.moverbright {
  -webkit-transition: -webkit-filter 0.3s ease;
  transition: -webkit-filter 0.3s ease;
  transition: filter 0.3s ease;
  transition: filter 0.3s ease, -webkit-filter 0.3s ease;
  -webkit-filter: brightness(1);
          filter: brightness(1);
  /* デフォルト値なのでこの一行は省略してもOK */
}

.moverbright:hover {
  -webkit-filter: brightness(1.8);
          filter: brightness(1.8);
  /* 明るくする */
}

.resimg,
.responsive {
  width: 100%;
  height: auto;
  display: block;
}

.pc_content {
  display: initial;
}

.sp_content {
  display: none;
}

.pc_block {
  display: block;
}

.sp_block {
  display: none;
}

@media screen and (max-width: 960px) {
  .pc_content {
    display: none;
  }
  .sp_content {
    display: initial;
  }
  .pc_block {
    display: none;
  }
  .sp_block {
    display: block;
  }
}
ul.check {
  margin: 0 0 1em 0;
  padding: 0 0 0 12px;
}
ul.check li {
  position: relative;
  font-size: clamp(2rem, 3.1vw, 2.4rem);
  line-height: 1.6;
  list-style: none;
  padding: 0 0 0 30px;
  color: #325CD1;
  word-break: auto-phrase;
  text-autospace: no-autospace;
  text-spacing-trim: trim-auto;
}
ul.check li::after {
  content: "";
  display: block;
  position: absolute;
  top: 0.5em;
  left: 0;
  width: 20px;
  height: 10px;
  border-left: 2px solid #325CD1;
  border-bottom: 3px solid #325CD1;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

/* diamond */
ul.diamond {
  margin: 1em 1em 1.5em;
  padding: 0 0 0 0.5em;
}
ul.diamond li {
  position: relative;
  list-style: none;
  line-height: 1.72;
  padding: 0 0 0 0.3em;
}
ul.diamond li::after {
  display: block;
  content: "";
  position: absolute;
  top: 0.8em;
  left: -0.5em;
  width: 3px;
  height: 3px;
  background-color: #111;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

ul.noteList {
  margin: 1em 1em 1.5em;
  padding: 0 0 0 0.5em;
}
ul.noteList li {
  padding-left: 0;
  text-indent: -1em;
  padding: 0;
  list-style: none;
  line-height: 1.72;
}
ul.noteList li:before {
  content: "※";
}

ol.numList {
  counter-reset: item;
  list-style-type: none;
  margin: 1em 1em 1.5em;
  padding: 0 0 0 0.5em;
}
ol.numList li {
  line-height: 1.72;
  text-indent: -1.1em;
  counter-increment: cnt;
}
ol.numList li:before {
  counter-increment: item;
  content: " " counter(cnt) ". ";
  font-weight: normal;
}

a.textline {
  text-decoration: underline;
}

table {
  width: 100% !important;
  margin-bottom: 2em;
}

th,
td {
  padding: 1em;
  vertical-align: middle;
}

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

caption {
  margin-bottom: 0.5em;
  text-align: center;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  margin: 2em 0;
  margin-top: 0;
  padding: 0;
}

p {
  font-size: clamp(1.5rem, 1.254rem + 0.51vw, 1.6rem);
  line-height: 1.64;
  margin-bottom: 1.2em;
}

@media screen and (max-width: 960px) {
  p {
    line-height: 1.52;
    margin-bottom: 1em;
  }
}
.lazyload {
  opacity: 1;
}

.lazyloaded {
  opacity: 0;
  -webkit-animation-name: fade-in1;
          animation-name: fade-in1;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-direction: normal;
          animation-direction: normal;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@-webkit-keyframes fade-in1 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fade-in1 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.clf:before,
.clf:after {
  content: "";
  display: table;
}

.clf:after {
  clear: both;
}

:root {
  --width: calc(100% - 7%);
}

html {
  scroll-behavior: smooth;
}

html {
  scroll-padding-top: 150px;
}

@media screen and (max-width: 960px) {
  html {
    scroll-padding-top: 180px;
  }
}
@-webkit-keyframes DownAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(-170px);
            transform: translateY(-170px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes DownAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(-170px);
            transform: translateY(-170px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
body {
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  color: #111;
  font-size: 1.6rem;
  background-color: #fff;
}

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

body.post-type-archive-story #wrap {
  background-color: #325CD1;
}
body.no-scroll {
  overflow: hidden;
  height: 100%;
  width: 100%;
  position: fixed;
}

@media screen and (max-width: 960px) {
  body.home main {
    margin: -3.5em auto 0;
    padding-top: 2em;
  }
}
.container {
  position: relative;
  text-align: left;
  width: var(--width);
  max-width: 1200px;
  margin: 2.5em auto 2.5em;
}

@media screen and (max-width: 960px) {
  .container {
    max-width: initial;
    margin: 0 auto;
  }
}
#header {
  position: sticky;
  top: 0;
  z-index: 99;
  width: 100%;
  height: auto;
  background-color: #fff;
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
          box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
}
#header .gnav {
  width: 98%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 12px 0;
}
#header .gnav .gnav_inner {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  overflow: hidden;
  margin-bottom: 0.8em;
}
#header .gnav .logo {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: 173px 1fr;
  -webkit-column-gap: 12px;
     -moz-column-gap: 12px;
          column-gap: 12px;
}
#header .gnav .logo a {
  position: relative;
  display: block;
  text-decoration: none;
}
#header .gnav .logo a img {
  width: 100%;
  height: auto;
  display: block;
}
#header .gnav .logo .sub {
  color: rgba(0, 0, 0, 0.5019607843);
  font-size: 1.2rem;
  line-height: 1.4;
  font-weight: 500;
  white-space: nowrap;
}
#header .gnav .gnav_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  list-style: none;
}
#header .gnav .gnav_list li {
  position: relative;
  padding: 8px;
}
#header .gnav .gnav_list li a {
  position: relative;
  display: block;
  margin: 0;
  padding: 0;
  color: #111;
  text-decoration: none;
  font-size: clamp(1.35rem, 1.364rem + 0.18vw, 1.4rem);
  font-weight: 500;
  -webkit-transition: color 0.3s, -webkit-text-decoration 0.3s;
  transition: color 0.3s, -webkit-text-decoration 0.3s;
  transition: color 0.3s, text-decoration 0.3s;
  transition: color 0.3s, text-decoration 0.3s, -webkit-text-decoration 0.3s;
  white-space: nowrap;
}
#header .gnav .gnav_list li a:after {
  content: "";
  position: absolute;
  left: 0%;
  bottom: -10px;
  width: 100%;
  height: 2px;
  z-index: 1;
  background-color: #325CD1;
  -webkit-transition: -webkit-transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transition: -webkit-transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transition: transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transition: transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s, -webkit-transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
}
#header .gnav .gnav_list li a.hilight:after {
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
#header .gnav .gnav_list li a:hover:after {
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
#header .gnav .gnav_list li a:hover {
  color: #325CD1;
  -webkit-transform-origin: left top;
          transform-origin: left top;
  text-decoration: inherit;
}
#header .gnav .navs {
  width: 100%;
}
#header .gnav .entry_form {
  height: 80px;
  border-radius: 0 0 10px 10px;
  overflow: hidden;
}
#header .gnav .entry_form a {
  position: relative;
  display: block;
  color: #fff;
  text-decoration: none;
  font-size: clamp(1.35rem, 1.364rem + 0.18vw, 1.4rem);
  font-weight: 500;
  line-height: 1;
  -webkit-transition: 0.3s ease-out;
  transition: 0.3s ease-out;
  background-color: #6E8FE5;
  height: 40px;
  display: grid;
  place-content: center;
  white-space: nowrap;
}
#header .gnav .entry_form a.careers {
  background-color: #325CD1;
}
#header .gnav .entry_form a:hover {
  color: #fff;
  background-color: #01a4f4;
  text-decoration: inherit;
}
#header .secondary {
  display: grid;
  grid-template-columns: 80px 130px 180px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
}
#header .contact_lang li {
  text-align: right;
}
#header .contact_lang li a {
  font-size: 1.2rem;
  color: #325CD1;
}
#header .sns {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#header .telinfo {
  color: #325CD1;
  font-size: 2.1rem;
  line-height: 1.4;
  font-weight: 500;
  white-space: nowrap;
}
#header .telinfo span {
  font-size: 1.1rem;
}

@media screen and (max-width: 960px) {
  #header {
    position: sticky;
    top: 0;
    left: 0;
    height: 60px;
    -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.08);
            box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.08);
    overflow: hidden;
  }
  #header .gnav {
    width: 100%;
    max-width: initial;
    padding: 0;
  }
  #header .gnav .gnav_inner {
    width: 100%;
    height: auto;
    display: grid;
    grid-template-columns: 1fr;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 12px;
       -moz-column-gap: 12px;
            column-gap: 12px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #header .gnav .logo {
    position: relative;
    width: 100%;
    max-width: 120px;
    display: block;
    margin: 14px auto;
  }
  #header .gnav .logo .sub {
    display: none;
  }
  #header .gnav .navs {
    display: none;
  }
  #header .gnav .secondary {
    display: none;
  }
}
.sideticket {
  position: fixed;
  right: 0;
  bottom: 0;
  width: 115px;
  height: 253px;
  z-index: 999999;
  display: initial;
  border-radius: 10px 0 0 0;
  -webkit-box-shadow: 0 0 6px 4px rgba(165, 165, 165, 0.1);
          box-shadow: 0 0 6px 4px rgba(165, 165, 165, 0.1);
}
.sideticket a {
  display: block;
  width: 115px;
  height: 253px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  background: url(../img/global/pc_ticket.svg) no-repeat 50% 50%;
  background-size: 115px auto;
}
.sideticket a:hover {
  background: url(../img/global/pc_ticket-hover.svg) no-repeat 50% 50%;
  background-size: 115px auto;
}

#spnav {
  position: fixed;
  left: -120%;
}

.menubtn,
.btnTicket {
  display: none;
}

@media screen and (max-width: 960px) {
  .menubtn {
    position: absolute;
    top: 0px;
    left: 0;
    z-index: 11;
    cursor: pointer;
    width: 60px;
    height: 60px;
    display: inherit;
  }
  .menubtn span {
    display: inline-block;
    -webkit-transition: all 0.1s;
    transition: all 0.1s;
    position: absolute;
    left: 15px;
    height: 3px;
    background-color: #325CD1;
    width: 50%;
  }
  .menubtn span:nth-of-type(1) {
    top: 18px;
  }
  .menubtn span:nth-of-type(2) {
    top: 27px;
  }
  .menubtn span:nth-of-type(3) {
    top: 36px;
  }
  .menubtn.active {
    z-index: 12;
  }
  .menubtn.active span:nth-of-type(1) {
    top: 21px;
    left: 18px;
    -webkit-transform: translateY(6px) rotate(-45deg);
            transform: translateY(6px) rotate(-45deg);
    width: 40%;
    background-color: #325CD1;
  }
  .menubtn.active span:nth-of-type(2) {
    opacity: 0;
  }
  .menubtn.active span:nth-of-type(3) {
    top: 33px;
    left: 18px;
    -webkit-transform: translateY(-6px) rotate(45deg);
            transform: translateY(-6px) rotate(45deg);
    width: 40%;
    background-color: #325CD1;
  }
  .sideticket {
    display: none;
  }
  .btnTicket {
    position: fixed;
    top: 0;
    right: 0;
    display: inherit;
  }
  .btnTicket a {
    width: 100px;
    height: 60px;
    display: block;
    margin: 0;
    z-index: 999;
    color: #fff;
    text-align: center;
    background: #4BCEAA url(../img/global/sp_ticket.svg) no-repeat 50% 50%;
    background-size: 70px auto;
    overflow: hidden;
  }
  #spnav {
    position: fixed;
    z-index: 98;
    top: 60px;
    left: -120%;
    width: 85%;
    height: 100%;
    -webkit-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
    text-align: left;
    background-color: #fff;
    padding-bottom: 10%;
  }
  #spnav.panelactive {
    left: 0;
  }
  #spnav {
    height: 100%;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  #spnav::-webkit-scrollbar {
    display: none;
  }
  #spnav ul.sn {
    padding: 1em 2em;
  }
  #spnav ul.sn:last-child {
    border-bottom: none;
  }
  #spnav ul.sn li {
    list-style: none;
    text-align: left;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  }
  #spnav ul.sn li a {
    position: relative;
    color: #111;
    text-decoration: none;
    font-size: clamp(1.4rem, 1.364rem + 0.18vw, 1.5rem);
    display: block;
    font-weight: 400;
    padding: 1.2em 0;
  }
  .no-scroll #header .navs {
    display: none;
  }
  .no-scroll #wrapper {
    position: fixed;
    z-index: 10;
    background-image: -webkit-gradient(linear, left top, right top, color-stop(80%, rgba(16, 89, 192, 0.6)), to(rgba(16, 89, 192, 0.4)));
    background-image: linear-gradient(90deg, rgba(16, 89, 192, 0.6) 80%, rgba(16, 89, 192, 0.4));
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}
.guide_grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 40px;
  margin: 0 auto 5em;
}

.guide_link_wrap {
  display: grid;
  grid-template-columns: 38% 1fr;
  gap: 30px;
}
.guide_link_wrap .guide_box {
  position: relative;
  display: block;
  border-bottom: 1px solid rgba(50, 92, 209, 0.168627451);
  text-decoration: none;
  padding: 1em 0.5em;
}
.guide_link_wrap .guide_box .name {
  font-size: clamp(1.6rem, 1.564rem + 0.18vw, 1.7rem);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.guide_link_wrap .guide_box span {
  font-size: clamp(1.3rem, 1.264rem + 0.18vw, 1.4rem);
  color: rgba(0, 0, 0, 0.5411764706);
}

.guide_swipper {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin-right: auto;
  border-radius: 20px;
  border: 1px solid rgba(50, 92, 209, 0.2);
  background-color: #FAFAFA;
  padding: 2em;
  overflow: hidden;
}
.guide_swipper .swiper {
  overflow: visible;
}
.guide_swipper .swiper-slide {
  max-width: 137px;
}
.guide_swipper .post_length {
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 137/311;
}

@media screen and (max-width: 960px) {
  .guide_grid {
    display: block;
    gap: 0;
  }
  .guide_link_wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    margin-bottom: 2em;
  }
  .guide_swipper {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin-right: calc(50% - 50vw);
    border: 1px solid rgba(50, 92, 209, 0.2);
    background-color: #FAFAFA;
    padding: 2em;
    border-radius: 20px 0 0 20px;
    overflow: hidden;
  }
  .guide_swipper .swiper {
    overflow: visible;
  }
  .guide_swipper .post_length {
    border-radius: 10px;
    overflow: hidden;
    aspect-ratio: 137/311;
  }
}
.floor_content {
  display: grid;
  grid-template-columns: 68% 1fr;
  gap: 40px;
}
.floor_content .post_box {
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid #325CD1;
}
.floor_content .floormap_summary .title {
  margin-bottom: 1em;
}
.floor_content .floormap_summary .title .sub {
  font-size: clamp(3.5rem, 2.445rem + 5.27vw, 6.4rem);
  font-family: "Inter", sans-serif;
  font-weight: 700;
  white-space: nowrap;
  color: #325CD1;
}
.floor_content .floormap_summary .title h1 {
  font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
  font-weight: 500;
  color: #325CD1;
}
.floor_content .floormap_summary .floor_link a {
  position: relative;
  margin-bottom: 0.5em;
  color: #325CD1;
}
.floor_content .floormap_summary .floor_link a::after {
  border-top: solid 2px #325CD1;
  border-right: solid 2px #325CD1;
}

@media screen and (max-width: 960px) {
  .floor_content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .floor_content .post_box {
    border-radius: 0;
    overflow: hidden;
    border: none;
  }
  .floor_content .floormap_summary {
    display: contents;
  }
  .floor_content .floormap_summary .title {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
    z-index: 1;
    margin-bottom: -8em;
  }
  .floor_content .floormap_summary .floor_link {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
  }
}
.friends_wrap {
  position: relative;
  background-color: #C7E6EC;
  padding: 0 0 5em;
  background: url(../img/pages/root/friend_bg.jpg) no-repeat 50% 50%;
  background-size: cover;
  min-height: 770px;
}
.friends_wrap::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background: transparent -webkit-gradient(linear, left bottom, left top, color-stop(5%, #C7E6EC), color-stop(50%, rgba(0, 0, 0, 0))) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(0deg, #C7E6EC 5%, rgba(0, 0, 0, 0) 50%) 0% 0% no-repeat padding-box;
  z-index: 0;
}
.friends_wrap .curved_up {
  background-color: #fff;
}
.friends_wrap .friends_bg {
  position: relative;
  margin: 0 auto 3em;
  padding: 4em 0 5em;
  min-height: 500px;
}
.friends_wrap .friends_bg .title {
  color: #fff;
}
.friends_wrap .friends_bg .title .t {
  font-size: clamp(3.5rem, 2.445rem + 5.27vw, 6.4rem);
  font-family: "Inter", sans-serif;
  font-weight: 700;
  white-space: nowrap;
}
.friends_wrap .friends_bg .title h1 {
  font-weight: 700;
  white-space: nowrap;
  margin-bottom: 3em;
}
.friends_wrap .friends_swiper .overview {
  text-decoration: none;
  text-align: center;
  padding-top: 1em;
}
.friends_wrap .friends_swiper .title {
  font-size: 1.3rem;
  font-weight: 500;
}

@media screen and (max-width: 960px) {
  .friends_wrap {
    position: relative;
    background-color: #C7E6EC;
    padding: 0 0 1em;
    background: url(../img/pages/root/friend_bg.jpg) no-repeat 50% 0%;
    background-size: cover;
    height: auto;
    min-height: auto;
  }
  .friends_wrap .friends_bg {
    position: relative;
    margin: 0 auto 12em;
    padding: 2em 0 0em;
    min-height: auto;
  }
  .friends_wrap .friends_bg .title .t {
    font-size: clamp(3.5rem, 2.445rem + 5.27vw, 6.4rem);
    font-family: "Inter", sans-serif;
    font-weight: 700;
    white-space: nowrap;
  }
  .friends_wrap .friends_bg .title h1 {
    font-weight: 700;
    white-space: nowrap;
    margin-bottom: 1em;
  }
}
.cal_column {
  position: relative;
  background-color: #fff;
  width: 100%;
  margin: 0 auto;
  padding: 1em 0;
  overflow: hidden;
}
.cal_column .rec_container {
  position: relative;
  text-align: left;
  width: var(--width);
  max-width: 1000px;
  margin: 0 auto;
}

@media screen and (max-width: 960px) {
  .cal_column {
    position: relative;
    border-top: none;
    width: 100%;
    margin: 0 auto;
  }
  .cal_column .rec_container {
    position: relative;
    text-align: left;
    width: var(--width);
    max-width: initial;
    margin: 0 auto;
  }
}
.spots_wrap {
  background-color: #E4E49F;
  padding: 0;
}
.spots_wrap .container {
  padding: 0.8em 0 0;
}

.story_wrap {
  background-color: #325CD1;
  padding: 3.5% 0 1em;
}
.story_wrap .container {
  padding: 0;
  max-width: initial;
}
.story_wrap .block_one_wrap {
  position: relative;
  width: var(--width);
  max-width: 1600px;
  margin: 0 auto 1.5em;
}
.story_wrap .block_one_wrap .title {
  position: absolute;
  left: 0;
  top: 10%;
  padding: 0 5%;
  width: 100%;
  color: #fff;
  z-index: 5;
}
.story_wrap .block_one_wrap .title h1 {
  font-size: clamp(3.5rem, 2.445rem + 5.27vw, 6.4rem);
  font-family: "Inter", sans-serif;
  font-weight: 700;
  white-space: nowrap;
}
.story_wrap .block_one_wrap .story_catch {
  position: absolute;
  left: 0;
  bottom: 5%;
  z-index: 5;
  padding: 0 5%;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.story_wrap .block_one_wrap .story_catch h2 {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(1.9rem, -3.728rem + 11.72vw, 3.6rem);
  font-weight: 500;
  color: #fff;
}
.story_wrap .block_one_wrap .story_catch .arrow_link {
  color: #325CD1;
}
.story_wrap .block_one_wrap .story_catch .arrow_link::after {
  border-top: solid 2px #325CD1;
  border-right: solid 2px #325CD1;
}
.story_wrap .block_one_wrap .post_box {
  position: relative;
  margin: 0;
}
.story_wrap .block_one_wrap .post_box::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background: transparent -webkit-gradient(linear, left bottom, left top, color-stop(5%, #325cd1), color-stop(50%, rgba(0, 0, 0, 0))) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(0deg, #325cd1 5%, rgba(0, 0, 0, 0) 50%) 0% 0% no-repeat padding-box;
  z-index: 1;
}
.story_wrap .block_one_wrap .post_box .post_trim {
  border-radius: 20px 20px 0 0;
  overflow: hidden;
}

@media screen and (max-width: 960px) {
  .story_wrap {
    background-color: #E2F2F5;
    padding-top: 1.8em;
  }
  .story_wrap .container {
    padding: 0;
  }
  .story_wrap .block_one_wrap {
    position: relative;
    margin: 0 auto 1em;
    width: 100%;
    max-width: initial;
    border-radius: 20px;
    overflow: hidden;
  }
  .story_wrap .block_one_wrap .title {
    position: absolute;
    left: 20px;
    top: 10%;
  }
  .story_wrap .block_one_wrap .story_catch {
    position: absolute;
    left: 20px;
    bottom: 5%;
    z-index: 5;
    padding: 1em;
    width: 90%;
    display: grid;
    grid-template-columns: 1fr;
  }
  .story_wrap .block_one_wrap .story_catch h2 {
    margin-bottom: 1.5em;
    line-height: 1.8;
  }
  .story_wrap .block_one_wrap .story_catch .list {
    margin: 0 auto;
    width: 100%;
  }
  .story_wrap .block_one_wrap .story_catch .list a {
    width: 100%;
  }
  .story_wrap .block_one_wrap .post_box {
    position: relative;
    margin: 0 auto 0;
  }
  .story_wrap .block_one_wrap .post_box .post_trim {
    overflow: hidden;
    aspect-ratio: 308/318;
    border-radius: 20px;
    overflow: hidden;
  }
}
.social_grid {
  position: relative;
  width: calc(100% - 40px);
  max-width: 1000px;
  margin: auto;
  padding: 3em 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
.social_grid .social_column {
  background-color: #fff;
  overflow: hidden;
}
.social_grid .social_column .post_trim {
  aspect-ratio: 16/9;
}
.social_grid .social_column .icon_social {
  display: inherit;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  color: #fff;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
.social_grid .social_column .icon_social.icon_insta {
  background: url(../img/module/icon/w_insta.svg) no-repeat 50% 50%;
  background-size: 81px auto;
}
.social_grid .social_column .icon_social.icon_fb {
  background: url(../img/module/icon/w_fb.svg) no-repeat 50% 50%;
  background-size: 78px auto;
}
.social_grid .social_column .icon_social.icon_youtube {
  background: url(../img/module/icon/w_youtube.svg) no-repeat 50% 50%;
  background-size: 99px auto;
}
.social_grid .social_column .icon_social.icon_twitter {
  background: url(../img/module/icon/w_x.svg) no-repeat 50% 50%;
  background-size: 68px auto;
}
.social_grid .social_column .overview {
  padding: 2.5em 1.5em;
  border-left: 1px solid rgba(0, 0, 0, 0.062745098);
  border-bottom: 1px solid rgba(0, 0, 0, 0.062745098);
  border-right: 1px solid rgba(0, 0, 0, 0.062745098);
}
.social_grid .social_column .social_title {
  font-weight: 500;
}
.social_grid .social_column .social_title span {
  text-align: right;
  float: right;
  font-weight: 500;
  display: inherit;
}

@media screen and (max-width: 960px) {
  .social_grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .social_grid .social_column .post_trim {
    aspect-ratio: 16/9;
  }
  .social_grid .social_column .overview {
    padding: 1.5em;
  }
  .social_grid .social_column .social_title {
    font-weight: 500;
  }
  .social_grid .social_column .social_title span {
    text-align: left;
    float: none;
    font-weight: 500;
    display: inherit;
  }
}
.work_wrap {
  position: relative;
  width: 100%;
  height: calc(20vh + 20vw);
  margin: 0 auto;
  overflow: hidden;
}
.work_wrap .work_wrap_inner {
  margin: auto;
  height: calc(20vh + 20vw);
}
.work_wrap .catch {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.work_wrap .catch h2 {
  font-family: kozuka-mincho-pro, serif;
  font-size: clamp(2.1rem, 1.555rem + 2.73vw, 2.4rem);
  color: #fff;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
  margin-bottom: 1.2em;
}
.work_wrap .catch .entry_btn_wrap .entry_form {
  overflow: hidden;
}
.work_wrap .catch .entry_btn_wrap .entry_form a {
  text-align: center;
}
.work_wrap .catch .entry_btn_wrap .entry_form a.ent {
  position: relative;
  color: #50CDD9;
  text-decoration: none;
  font-size: clamp(1.35rem, 1.364rem + 0.18vw, 1.4rem);
  font-weight: 500;
  line-height: 1;
  -webkit-transition: 0.3s ease-out;
  transition: 0.3s ease-out;
  background-color: #fff;
  border-radius: 4px;
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  padding: 24px 20px 24px 20px;
  white-space: nowrap;
  text-decoration: none;
  width: 280px;
}
.work_wrap .catch .entry_btn_wrap .entry_form a::after {
  position: absolute;
  top: 50%;
  right: 12px;
  content: "";
  width: 7px;
  height: 7px;
  border-top: solid 2px #50CDD9;
  border-right: solid 2px #50CDD9;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.work_wrap .catch .entry_btn_wrap .entry_form a:hover {
  color: #fff;
  background-color: #01a4f4;
  text-decoration: inherit;
}
.work_wrap .catch .entry_btn_wrap .entry_form a:hover span {
  color: #fff;
  opacity: 0.8;
}
.work_wrap .catch .entry_btn_wrap .entry_form a span {
  color: #50CDD9;
  opacity: 0.7;
}
.work_wrap .img_sub {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
  height: 100%;
}
.work_wrap .img_sub::before {
  position: absolute;
  top: 0;
  left: 50%;
  content: url(../img/pages/recruit/lower_rt.svg);
  width: 313px;
  height: 96px;
  -webkit-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
}
.work_wrap .img_sub::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  content: url(../img/pages/recruit/upper_rt.svg);
  width: 313px;
  height: 96px;
  -webkit-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
}
.work_wrap .img_sub .item {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
.work_wrap .img_sub .item:nth-child(1) {
  background: url(../img/pages/recruit/recruit_bg_1.jpg) no-repeat 50% 50%;
  background-size: cover;
}
.work_wrap .img_sub .item:nth-child(2) {
  background: url(../img/pages/recruit/recruit_bg_2.jpg) no-repeat 50% 50%;
  background-size: cover;
}

@media screen and (max-width: 960px) {
  .work_wrap {
    position: relative;
    width: 100%;
    height: calc(50vh + 50vw);
    margin: 0 auto;
    overflow: hidden;
  }
  .work_wrap .work_wrap_inner {
    margin: auto;
    height: calc(50vh + 50vw);
  }
  .work_wrap .catch {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    height: auto;
  }
  .work_wrap .catch .entry_btn_wrap {
    position: absolute;
    bottom: -100%;
    left: 50%;
    z-index: 2;
    -webkit-transform: translate(-50%, 0%);
            transform: translate(-50%, 0%);
  }
  .work_wrap .img_sub {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
    height: 100%;
  }
  .work_wrap .img_sub::before {
    position: absolute;
    top: 0;
    left: 50%;
    content: url(../img/pages/recruit/lower_rt.svg);
    width: 313px;
    height: 96px;
    -webkit-transform: translate(-50%, 0%);
            transform: translate(-50%, 0%);
  }
  .work_wrap .img_sub::after {
    position: absolute;
    bottom: 0;
    left: 50%;
    content: url(../img/pages/recruit/upper_rt.svg);
    width: 313px;
    height: 96px;
    -webkit-transform: translate(-50%, 0%);
            transform: translate(-50%, 0%);
  }
}
footer {
  position: relative;
  width: 100%;
  background-color: #fff;
}
footer .footer_bg {
  position: relative;
  width: 100%;
  padding: 2em 0 2em;
}
footer .bnrlink_wrap {
  position: relative;
  background-color: #EFF1F8;
  padding: 3% 0;
}
footer .bnrlink_wrap .bnrlink_grid {
  width: 90%;
  max-width: 1000px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin: auto;
}
footer .bnrlink_wrap .bnrlink_grid .boxft .post_length {
  margin-bottom: 0.8em;
  overflow: hidden;
  border-radius: 10px;
}
footer .bnrlink_wrap .bnrlink_grid .boxft:nth-last-child(2n) {
  -webkit-transform: translateY(40px);
          transform: translateY(40px);
}
footer .bnrlink_wrap .bnrlink_grid .boxft .text {
  color: #325CD1;
}
footer .footer_inner {
  position: relative;
  text-align: left;
  width: 93%;
  max-width: 1000px;
  margin: 0 auto;
}
footer .footer_link {
  margin: 0 auto;
  display: grid;
  grid-template-columns: 230px 1fr;
  -webkit-column-gap: 180px;
     -moz-column-gap: 180px;
          column-gap: 180px;
  margin-bottom: 2.5em;
}
footer .footer_link .footer_logo {
  color: #325CD1;
}
footer .footer_link .footer_logo .ft_name {
  position: relative;
  width: 100%;
  margin-bottom: 2.5em;
}
footer .footer_link .footer_logo .ft_name a {
  position: relative;
  display: block;
  text-decoration: none;
}
footer .footer_link .footer_logo .ft_name a img {
  max-width: 173px;
  width: 100%;
  height: auto;
  display: block;
}
footer .footer_link .footer_logo .telinfo {
  color: #325CD1;
  font-family: "Outfit", sans-serif;
  font-size: 2.4rem;
  line-height: 1.4;
  font-weight: 500;
  white-space: nowrap;
  margin-bottom: 0.2em;
  letter-spacing: 0.08em;
}
footer .footer_link .footer_logo .telinfo span {
  font-size: 2.1rem;
}
footer .footer_link .footer_logo .info {
  font-size: 1.2rem;
  margin-bottom: 1.5em;
  font-weight: 400;
  text-align: right;
}
footer .footer_link .footer_logo .add {
  color: rgba(0, 0, 0, 0.5019607843);
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.5;
  white-space: nowrap;
}
footer .footer_link .footer_nav {
  display: grid;
  grid-template-columns: 206px 150px 170px;
  gap: 30px;
}
footer .footer_link .footer_nav .nav ul {
  border-bottom: 1px solid rgba(50, 92, 209, 0.2);
  margin-bottom: 0.8em;
  padding-bottom: 0.2em;
}
footer .footer_link .footer_nav .nav ul:last-child {
  border-bottom: none;
}
footer .footer_link .footer_nav .nav ul li {
  margin-bottom: 1.2em;
}
footer .footer_link .footer_nav .nav ul li a {
  color: rgba(0, 0, 0, 0.5019607843);
  font-size: clamp(1.2rem, 1.164rem + 0.18vw, 1.3rem);
  font-weight: 400;
  display: block;
  text-decoration: none;
}
footer .spwrap {
  display: none;
}
footer .copyright {
  margin: 0 auto;
  color: rgba(0, 0, 0, 0.5019607843);
}
footer .copyright .copyright_wrap {
  font-weight: 400;
  font-size: clamp(1.1rem, 0.991rem + 0.55vw, 1.2rem);
  text-align: left;
  margin-bottom: 1em;
}
footer .copyright .siteinfo {
  font-weight: 400;
  font-size: clamp(1.1rem, 0.991rem + 0.55vw, 1.2rem);
  line-height: 1.5;
}

@media screen and (max-width: 960px) {
  footer {
    position: relative;
    width: 100%;
  }
  footer .footer_bg {
    position: relative;
    width: 100%;
    padding: 2em 1em 2em;
    background-color: #325CD1;
  }
  footer .footer_inner {
    position: relative;
    text-align: left;
    max-width: initial;
    margin: 0 auto;
    background-color: #fff;
    border-radius: 10px;
    padding: 1.5em;
  }
  footer .footer_link {
    display: none;
  }
  footer .spwrap {
    display: initial;
  }
  footer .spwrap li {
    font-size: 1.5rem;
    text-align: left;
    border-bottom: 1px solid #dedede;
  }
  footer .spwrap li a {
    display: block;
    padding: 12px;
    color: #838282;
    text-decoration: none;
  }
  footer .spwrap .spfttel {
    font-size: 2.8rem;
    line-height: 1.2;
    color: #325cd1;
    margin: 0 auto 0.3em;
    white-space: nowrap;
    text-align: center;
    letter-spacing: 0.8px;
    display: block;
  }
  footer .spwrap .spfttel a {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    font-style: normal;
  }
  footer .spwrap .spfttel .add {
    font-weight: 300;
    font-size: 1.32rem;
    margin-bottom: 48px;
    color: #838282;
  }
  footer .spwrap #spFooter-logo {
    position: relative;
    width: 50%;
    margin: 64px auto;
  }
  footer .spwrap #spFooter-logo {
    position: relative;
    width: 60%;
    margin: 64px auto;
  }
  footer .bnrlink_wrap {
    position: relative;
    padding: 2em 0;
  }
  footer .bnrlink_wrap .bnrlink_grid {
    max-width: initial;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: auto;
  }
  footer .bnrlink_wrap .bnrlink_grid .boxft:nth-last-child(2n) {
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
  footer .bnrlink_wrap .bnrlink_grid .boxft:nth-child(2n) {
    -webkit-transform: translateY(16px);
            transform: translateY(16px);
  }
  footer .bnrlink_wrap .bnrlink_grid .boxft:nth-child(3n) {
    -webkit-transform: translateY(24px);
            transform: translateY(24px);
  }
  footer .footer_wrap {
    position: relative;
    width: calc(100% - 40px);
    max-width: initial;
    margin: 0 auto;
    padding: 20px 0 30px;
    overflow: hidden;
  }
  footer .footer_wrap .entry_btn_wrap {
    display: grid;
    grid-template-columns: 1fr;
    -webkit-column-gap: 120px;
       -moz-column-gap: 120px;
            column-gap: 120px;
  }
  footer .footer_wrap .entry_btn_wrap .entry_form {
    overflow: hidden;
  }
  footer .footer_wrap .entry_btn_wrap .entry_form a {
    display: grid;
    grid-template-columns: 90px 1fr;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 10px;
    padding: 10px;
    white-space: nowrap;
  }
  footer .footer_wrap .entry_btn_wrap .tel_wrap {
    color: #325CD1;
  }
  footer .footer_wrap .entry_btn_wrap .tel_wrap dl {
    display: grid;
    grid-template-columns: 70px 1fr;
    gap: 10px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  footer .footer_wrap .entry_btn_wrap .tel_wrap dl.tel dt {
    margin-left: 10px;
  }
  footer .footer_wrap .entry_btn_wrap .tel_wrap dl.fax dt {
    margin-left: 10px;
  }
  footer .footer_wrap .entry_btn_wrap .tel_wrap .tantou {
    border: 1px solid rgba(50, 92, 209, 0.2);
    border-radius: 10px;
    padding: 12px 10px;
    font-size: 1.2rem;
    background-color: #fff;
  }
}
.boxes_insta {
  position: relative;
  width: 100%;
  min-height: 240px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 60px;
  background-color: #fff;
  border: 1px solid #325CD1;
  margin: 0.2em auto 7em;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
  border-radius: 10px;
  overflow: hidden;
  z-index: 1;
}
.boxes_insta:link {
  text-decoration: none;
}
.boxes_insta .flex_img {
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  border-right: 1px solid rgba(50, 92, 209, 0.2);
}
.boxes_insta .flex_container {
  position: relative;
  padding: 0.5em;
  display: grid;
  grid-template-columns: 1fr 64px;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #325CD1;
}
.boxes_insta .flex_container .icon_insta {
  padding: 14px 10px 14px 100px;
  background: url("../img/module/icon/icon_insta.svg") no-repeat 0 50%;
  background-size: 76px auto;
}
.boxes_insta .flex_container .icon_insta .info {
  font-size: clamp(1.3rem, 1.227rem + 0.36vw, 1.5rem);
  font-weight: 400;
  margin-bottom: 0.5em;
  white-space: nowrap;
}
.boxes_insta .flex_container .icon_insta .user {
  font-size: clamp(1.5rem, 1.418rem + 0.91vw, 2.1rem);
  font-weight: 700;
  white-space: nowrap;
}
.boxes_insta:hover {
  background-color: #EAEFFB;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
  text-decoration: none;
}
.boxes_insta:hover .flex_container::after {
  right: 18px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.boxes_insta:hover .text {
  color: #fff;
}

@media screen and (max-width: 960px) {
  .boxes_insta {
    position: relative;
    width: 100%;
    min-height: initial;
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    margin: 0.2em auto 1em;
  }
  .boxes_insta .flex_img {
    width: 100%;
    height: 100%;
    aspect-ratio: 16/6;
  }
  .boxes_insta .flex_container {
    padding: 0em 1em 1em 1em;
    -webkit-column-gap: 10px;
       -moz-column-gap: 10px;
            column-gap: 10px;
  }
  .boxes_insta .flex_container .icon_insta {
    padding: 14px 10px 14px 40px;
    background: url("../img/module/icon/icon_insta.svg") no-repeat 0 50%;
    background-size: 30px auto;
  }
}
.footerfix {
  display: none;
}

@media screen and (max-width: 960px) {
  .footerfix {
    position: fixed;
    bottom: 0;
    display: initial;
    z-index: 3;
    width: 100%;
  }
  .footerfix ul {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 0 auto;
  }
  .footerfix ul li a {
    position: relative;
    color: #fff;
    padding: 1.5em 2em 2em;
    font-size: clamp(1.3rem, 0.562rem + 1.54vw, 1.6rem);
    font-weight: 700;
    display: grid;
    place-content: center;
  }
  .footerfix ul li a::after {
    position: absolute;
    top: 45%;
    right: 12px;
    content: "";
    width: 8px;
    height: 8px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    -webkit-transform: translate(0%, -50%) rotate(45deg);
            transform: translate(0%, -50%) rotate(45deg);
    -webkit-transition: var(--btnover);
    transition: var(--btnover);
  }
  .footerfix ul li a.freshers {
    position: relative;
    background-color: #6E8FE5;
  }
  .footerfix ul li a.careers {
    position: relative;
    background-color: #325CD1;
  }
}
.cancel {
  position: absolute;
  top: 50px;
  right: -120px;
  z-index: 99;
  cursor: pointer;
  width: 60px;
  height: 60px;
  display: inherit;
  background-color: #325CD1;
  border-radius: 9999px;
  -webkit-transition: all 0.6s ease-out;
  transition: all 0.6s ease-out;
}
.cancel span {
  display: inline-block;
  -webkit-transition: all 0.1s;
  transition: all 0.1s;
  position: absolute;
  left: 15px;
  height: 3px;
  background-color: #325CD1;
  width: 50%;
}
.cancel span:nth-of-type(1) {
  top: 18px;
}
.cancel span:nth-of-type(2) {
  top: 36px;
}
.cancel span:nth-of-type(1) {
  top: 21px;
  left: 18px;
  -webkit-transform: translateY(6px) rotate(-45deg);
          transform: translateY(6px) rotate(-45deg);
  width: 40%;
  background-color: #fff;
}
.cancel span:nth-of-type(2) {
  top: 33px;
  left: 18px;
  -webkit-transform: translateY(-6px) rotate(45deg);
          transform: translateY(-6px) rotate(45deg);
  width: 40%;
  background-color: #fff;
}

@media screen and (max-width: 960px) {
  .no-scroll .cancel {
    position: absolute;
    top: 50px;
    right: 18%;
    z-index: 99;
    cursor: pointer;
    width: 60px;
    height: 60px;
    display: inherit;
    background-color: #325CD1;
    border-radius: 9999px;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
  }
  .no-scroll .cancel span {
    display: inline-block;
    -webkit-transition: all 0.1s;
    transition: all 0.1s;
    position: absolute;
    left: 15px;
    height: 3px;
    background-color: #325CD1;
    width: 50%;
  }
  .no-scroll .cancel span:nth-of-type(1) {
    top: 18px;
  }
  .no-scroll .cancel span:nth-of-type(2) {
    top: 36px;
  }
  .no-scroll .cancel span:nth-of-type(1) {
    top: 21px;
    left: 18px;
    -webkit-transform: translateY(6px) rotate(-45deg);
            transform: translateY(6px) rotate(-45deg);
    width: 40%;
    background-color: #fff;
  }
  .no-scroll .cancel span:nth-of-type(2) {
    top: 33px;
    left: 18px;
    -webkit-transform: translateY(-6px) rotate(45deg);
            transform: translateY(-6px) rotate(45deg);
    width: 40%;
    background-color: #fff;
  }
}
:root {
  --easing: cubic-bezier(.2, 1, .2, 1);
  --transition: .8s var(--easing);
}

@-webkit-keyframes animationZoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}

@keyframes animationZoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@-webkit-keyframes fadeLeftAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(30px);
            transform: translateX(30px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes fadeLeftAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(30px);
            transform: translateX(30px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes ticker-fadeIn {
  0% {
    opacity: 0;
    -webkit-transform: translateX(20px);
            transform: translateX(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}
@keyframes ticker-fadeIn {
  0% {
    opacity: 0;
    -webkit-transform: translateX(20px);
            transform: translateX(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}
.mainvisual {
  position: relative;
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  height: calc(30vh + 30vw);
  min-height: 500px;
  background-color: #325CD1;
}
.mainvisual .swiper {
  height: 100%;
}
.mainvisual .swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.mainvisual .swiper-slide::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(50, 92, 209, 0.95)), color-stop(45%, rgba(255, 255, 255, 0)));
  background-image: linear-gradient(0deg, rgba(50, 92, 209, 0.95), rgba(255, 255, 255, 0) 45%);
  opacity: 1;
  z-index: 1;
}
.mainvisual .slide-title {
  position: absolute;
  left: 5%;
  top: 40%;
  z-index: 4;
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
  color: #fff;
  width: calc(20vw + 20vh - 40px);
  max-width: 500px;
}
.mainvisual .post_box {
  height: 100%;
}
.mainvisual .post_trim {
  aspect-ratio: 16/9;
  height: 100%;
}

@media screen and (max-width: 960px) {
  .mainvisual {
    position: relative;
    width: 100%;
    height: calc(50vh + 30vw);
  }
  .mainvisual .post_trim {
    aspect-ratio: 1/1;
  }
  .mainvisual .slide-title {
    width: calc(100% - 40px);
    max-width: initial;
    margin: 0 auto;
    position: absolute;
    top: 40%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    max-width: 360px;
    width: 36vh;
  }
}
.under_pages_visual {
  position: relative;
  width: 100%;
  height: calc(24vh + 24vw);
  margin-bottom: 0;
  overflow: hidden;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  z-index: -1;
}
.under_pages_visual.spots {
  border-bottom-left-radius: 100px;
  border-bottom-right-radius: 100px;
}
.under_pages_visual .visual_inner {
  width: 100%;
  height: calc(24vh + 24vw);
}
.under_pages_visual .visual_inner .title {
  position: absolute;
  left: 10%;
  top: 40%;
  width: 100%;
  text-align: left;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.under_pages_visual .visual_inner .title .story_catch h1 {
  font-size: clamp(3.5rem, 2.445rem + 5.27vw, 6.4rem);
  font-family: "Inter", sans-serif;
  color: #fff;
}
.under_pages_visual .visual_inner .title .sub {
  color: #fff;
}
.under_pages_visual .visual_inner .title .subtext {
  font-size: clamp(3.5rem, 2.445rem + 5.27vw, 6.4rem);
  font-family: "Inter", sans-serif;
  color: #fff;
}
.under_pages_visual .visual_inner .title h1 {
  font-size: clamp(1.9rem, 1.238rem + 1.38vw, 2.1rem);
  color: #fff;
  margin: 0 0 10px 0;
}
.under_pages_visual.blogs {
  border-bottom-left-radius: 100px;
  border-bottom-right-radius: 100px;
}
.under_pages_visual.blogs .visual_inner .title {
  top: auto;
  bottom: 0;
}
.under_pages_visual.clipvisual::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50px;
  background: #fff;
  clip-path: ellipse(50% 100% at 50% 100%);
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
  z-index: 2;
}

.under_story_visual {
  position: relative;
  width: var(--width);
  max-width: 1400px;
  margin: 4% auto 2%;
  height: calc(22vh + 22vw);
  overflow: hidden;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  border-radius: 40px 40px 0 0;
}
.under_story_visual::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background: transparent -webkit-gradient(linear, left bottom, left top, color-stop(5%, #325cd1), color-stop(50%, rgba(0, 0, 0, 0))) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(0deg, #325cd1 5%, rgba(0, 0, 0, 0) 50%) 0% 0% no-repeat padding-box;
  z-index: 1;
}
.under_story_visual .visual_inner {
  width: 100%;
  height: calc(22vh + 22vw);
}
.under_story_visual .visual_inner .title {
  position: absolute;
  left: 10%;
  top: 40%;
  width: 100%;
  text-align: left;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 1;
}
.under_story_visual .visual_inner .title .story_catch {
  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: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.under_story_visual .visual_inner .title .story_catch h1 {
  font-size: clamp(3.5rem, 2.445rem + 5.27vw, 6.4rem);
  font-family: "Inter", sans-serif;
  color: #fff;
}
.under_story_visual .visual_inner .title .story_catch h2 {
  margin-top: 6%;
  font-family: "Noto Serif JP", serif;
  font-size: clamp(1.9rem, -3.728rem + 11.72vw, 3.6rem);
  line-height: 1.5;
  font-weight: 500;
  color: #fff;
}

@media screen and (max-width: 960px) {
  .under_story_visual {
    position: relative;
    width: var(--width);
    max-width: initial;
    margin: 4% auto 2%;
    height: calc(16vh + 16vw);
  }
  .under_story_visual.blogs, .under_story_visual.spots {
    border-bottom-left-radius: 70px;
    border-bottom-right-radius: 70px;
  }
  .under_story_visual .visual_inner {
    width: 100%;
    height: calc(16vh + 16vw);
  }
}
.curved_wrap {
  overflow: hidden;
}
.curved_wrap .curved_hdbottom {
  background: #fff;
  border-top-left-radius: 50%;
  border-top-right-radius: 50%;
  height: 80px;
  margin-top: -80px;
  margin-left: -100px;
  margin-right: -100px;
  padding-left: 100px;
  padding-right: 100px;
}
.curved_wrap .curved_bottom {
  background: #fff;
  border-top-left-radius: 50%;
  border-top-right-radius: 50%;
  height: 80px;
  margin-left: -100px;
  margin-right: -100px;
  padding-left: 100px;
  padding-right: 100px;
}
.curved_wrap .curved_up {
  background: #325cd1;
  border-bottom-left-radius: 1000px 80px;
  border-bottom-right-radius: 1000px 80px;
  height: 80px;
  margin-left: -100px;
  margin-right: -100px;
  padding-left: 100px;
  padding-right: 100px;
}

@media screen and (max-width: 960px) {
  .curved_wrap .curved_up {
    background: #e2f2f5;
  }
}
.box_radius {
  position: relative;
  padding-bottom: 0;
  text-align: left;
  margin: -2.5em auto 0;
  padding-top: 2em;
  background-color: #fff;
  border-top-left-radius: 40px;
  border-top-right-radius: 40px;
  z-index: 3;
}

.OneDetail {
  border-top-left-radius: 40px;
  border-top-right-radius: 40px;
  margin-top: -80px;
  background-color: #fff;
  padding: 2% 0;
  z-index: 3;
}

@media screen and (max-width: 960px) {
  .box_radius {
    padding-top: 0.5em;
  }
  .OneDetail {
    border-top-left-radius: 40px;
    border-top-right-radius: 40px;
    margin-top: -40px;
    padding: 5% 0;
  }
}
@media screen and (max-width: 960px) {
  .mv01 .slide-title {
    position: absolute;
    top: 32%;
    left: 50%;
    z-index: 2;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  .mv01 .slide-title img {
    max-width: 100%;
  }
}
.single_wrap {
  display: grid;
  grid-template-columns: 780px 1fr;
  gap: 40px;
}
.single_wrap .single_content {
  position: relative;
}
.single_wrap .side_content {
  position: relative;
}

@media screen and (max-width: 960px) {
  .single_wrap {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .single_wrap .single_content {
    position: relative;
  }
  .single_wrap .side_content {
    position: relative;
  }
}
.mvInterview {
  margin-bottom: 8em;
}

.infor_wrap {
  background-color: #6E8FE5;
  border-radius: 20px;
  overflow: hidden;
}
.infor_wrap .infor_wrap_bg {
  position: relative;
  background: url(../img/pages/root/infor/inforbg.jpg) no-repeat 50% 100%;
  background-size: cover;
  aspect-ratio: 1.934/1;
  margin-bottom: 0.5em;
  overflow: hidden;
}
.infor_wrap .infor_wrap_bg .title {
  position: absolute;
  bottom: -12px;
  left: 5%;
  z-index: 2;
  color: #fff;
}
.infor_wrap .infor_wrap_bg .title h1 {
  font-size: clamp(2.4rem, 1.964rem + 2.18vw, 3.6rem);
  font-weight: 500;
}
.infor_wrap .infor_wrap_bg .title .sub {
  font-family: "Inter", sans-serif;
  font-size: clamp(4.5rem, -0.738rem + 8.21vw, 8rem);
  font-weight: 700;
  line-height: 1;
}
.infor_wrap .infor_wrap_bg::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background: transparent -webkit-gradient(linear, left bottom, left top, from(#0808B8), to(rgba(0, 0, 0, 0))) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(360deg, #0808B8 0%, rgba(0, 0, 0, 0) 100%) 0% 0% no-repeat padding-box;
  opacity: 0.4;
  z-index: 1;
}

.infor_inner {
  background-color: #6E8FE5;
  padding: 20px 120px 30px;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}
.infor_inner .post_info_box {
  border-radius: 20px;
  overflow: hidden;
  background-color: #fff;
  display: block;
  border: 1px solid #6E8FE5;
}
.infor_inner .post_info_box:hover {
  border: 1px solid #325CD1;
}
.infor_inner .post_info_box .overview {
  padding: 1.5em 1em 2em;
  display: grid;
  place-items: center;
}
.infor_inner .post_info_box .overview .title_rtl {
  font-size: clamp(1.7rem, 1.555rem + 0.73vw, 2.1rem);
  color: #325CD1;
  font-weight: 500;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}

@media screen and (max-width: 960px) {
  .infor_wrap .infor_wrap_bg {
    position: relative;
    background: url(../img/pages/root/infor/inforbg.jpg) no-repeat 50% 100%;
    background-size: cover;
    aspect-ratio: 1.934/1;
    margin-bottom: 0.5em;
    overflow: hidden;
  }
  .infor_wrap .infor_wrap_bg .title {
    position: absolute;
    bottom: -8px;
    left: 5%;
    z-index: 2;
    color: #fff;
  }
  .infor_inner {
    background-color: #6E8FE5;
    padding: 20px 40px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .infor_inner .post_info_box {
    border-radius: 20px;
    overflow: hidden;
    background-color: #fff;
  }
  .infor_inner .post_info_box .post_trim {
    aspect-ratio: 1/0.9;
  }
}
.tab {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 16px;
  margin: 0 auto 10px;
}
.tab li.active a {
  color: #fff;
  background: #325CD1;
}
.tab li a {
  display: block;
  color: #fff;
  font-size: clamp(1.5rem, -1.7rem + 6.67vw, 2.8rem);
  font-weight: 400;
  color: #111;
  background: #C3C3C3;
  padding: 20px 30px;
  text-align: center;
}

.area {
  display: none;
  opacity: 0;
  padding: 20px;
  margin-bottom: 50px;
}
.area.is-active {
  display: block;
  -webkit-animation-name: displayAnime;
          animation-name: displayAnime;
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@-webkit-keyframes displayAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes displayAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@media screen and (max-width: 960px) {
  .tab {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    place-content: center;
    gap: 8px;
  }
  .tab li {
    display: grid;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .tab li a {
    padding: 10px 8px;
    text-align: center;
  }
}
.cate_navi {
  width: 95%;
  max-width: 1200px;
  margin: -110px auto 4em;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  z-index: 1;
}
.cate_navi .pages_sub_navi {
  width: auto;
  max-width: 570px;
  margin: 0 0 0 auto;
  max-width: initial;
}

.anker_navi {
  width: 95%;
  max-width: 1200px;
  margin: -110px auto 4em;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  z-index: 1;
}
.anker_navi .pages_sub_navi {
  width: auto;
  max-width: 570px;
  margin: 0 0 0 auto;
  max-width: initial;
}
.anker_navi .pages_sub_navi ul {
  padding: 1.1em 1em;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.anker_navi .pages_sub_navi ul li.ank a {
  color: #325CD1;
  position: relative;
  padding-right: 24px;
  text-decoration: none;
}
.anker_navi .pages_sub_navi ul li.ank a:after {
  content: "";
  position: absolute;
  top: 29%;
  left: auto;
  right: 0;
  width: 10px;
  height: 10px;
  border-top: solid 1px #0808B8;
  border-right: solid 1px #0808B8;
  background: none;
  -webkit-transform: translate(0%, -50%) rotate(135deg);
          transform: translate(0%, -50%) rotate(135deg);
  -webkit-transform-origin: initial;
          transform-origin: initial;
}

@media screen and (max-width: 960px) {
  .cate_navi,
  .anker_navi {
    width: 100%;
    max-width: inherit;
    margin: -80px auto 4em;
    z-index: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    z-index: 1;
  }
  .cate_navi .pages_sub_navi,
  .anker_navi .pages_sub_navi {
    width: 100%;
    max-width: initial;
    margin: 0 0 0 auto;
    max-width: initial;
  }
  .cate_navi .pages_sub_navi ul,
  .anker_navi .pages_sub_navi ul {
    padding: 1.1em 1em;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}
.company_box {
  background-color: #325CD1;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 3.5em;
  padding: 3em 4em 4em;
}
.company_box .title_column {
  grid-template-columns: 1fr 216px;
}
.company_box .title_column .sub {
  font-size: clamp(3rem, 0.455rem + 12.73vw, 10rem);
  color: #fff;
}
.company_box .title_column h1 {
  font-size: clamp(2.1rem, 1.773rem + 1.64vw, 3rem);
  color: #fff;
}
.company_box .title_column .arrow_link {
  margin-bottom: 2.2em;
}
.company_box .company_grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 20px;
}
.company_box .company_linkbox {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
}
.company_box .company_linkbox::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background: transparent -webkit-gradient(linear, left bottom, left top, from(#0808B8), to(rgba(0, 0, 0, 0))) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(360deg, #0808B8 0%, rgba(0, 0, 0, 0) 100%) 0% 0% no-repeat padding-box;
  opacity: 0.4;
  z-index: 1;
}
.company_box .company_linkbox .overview {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  padding: 20px;
}
.company_box .company_linkbox .overview h2 {
  color: #fff;
  font-size: clamp(1.7rem, 1.664rem + 0.18vw, 1.8rem);
  font-weight: 500;
  margin-bottom: 1em;
}
.company_box .company_linkbox .detail {
  position: relative;
  background-color: #fff;
  border-radius: 9999px;
  overflow: hidden;
  color: #325CD1;
  font-size: clamp(1.1rem, 1.064rem + 0.18vw, 1.2rem);
  font-weight: 500;
  display: inline-block;
  padding: 10px 44px 10px 16px;
}
.company_box .company_linkbox .detail::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #325CD1;
  border-right: solid 2px #325CD1;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}

@media screen and (max-width: 960px) {
  .company_box {
    padding: 1em 2em 2em;
  }
  .company_box .title_column {
    max-width: initial;
    margin-bottom: 1.5em;
  }
  .company_box .title_column .title_column_list {
    grid-template-columns: 1fr;
  }
  .company_box .title_column .arrow_link {
    margin-bottom: 1em;
  }
  .company_box .company_grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
  .company_box .company_linkbox {
    position: relative;
    overflow: hidden;
    border-radius: 10px;
  }
  .company_box .company_linkbox .overview {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    padding: 10px;
  }
  .company_box .company_linkbox .overview h2 {
    color: #fff;
    font-size: clamp(1.7rem, 1.664rem + 0.18vw, 1.8rem);
    font-weight: 500;
    margin-bottom: 1em;
  }
  .company_box .company_linkbox .detail {
    position: relative;
    background-color: #fff;
    border-radius: 9999px;
    overflow: hidden;
    color: #325CD1;
    font-size: clamp(1.1rem, 1.064rem + 0.18vw, 1.2rem);
    font-weight: 500;
    display: inline-block;
    padding: 10px 44px 10px 16px;
  }
  .company_box .company_linkbox .detail::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    width: 8px;
    height: 8px;
    border-top: solid 2px #325CD1;
    border-right: solid 2px #325CD1;
    -webkit-transform: translate(0%, -50%) rotate(45deg);
            transform: translate(0%, -50%) rotate(45deg);
    -webkit-transition: 0.2s ease-in;
    transition: 0.2s ease-in;
  }
}
.g-recaptcha {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transform-origin: 0 0;
          transform-origin: 0 0;
}

.fixed-link {
  display: inline-block;
  padding: 0.8em 1.4em;
  border-right: 1px solid rgba(0, 0, 0, 0.1);
  background-color: #fff;
  position: sticky;
  left: 0;
  z-index: 10;
}
.fixed-link a {
  display: block;
  padding: 10px 0;
  font-size: clamp(1.35rem, 1.364rem + 0.18vw, 1.4rem);
  font-weight: 500;
  white-space: nowrap;
  color: #111;
  position: relative;
}
.fixed-link a:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #111;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: center top;
          transform-origin: center top;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.fixed-link a:hover:after, .fixed-link a.hilight:after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}

.scrollable-links {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.scrollable-links.active {
  cursor: grabbing;
  cursor: -webkit-grabbing;
}
.scrollable-links ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  padding: 0.8em 1.4em;
  margin: 0 auto;
  white-space: nowrap;
  width: 100%;
  max-width: 1200px;
  cursor: grab;
  cursor: -webkit-grab;
}
.scrollable-links ul::-webkit-scrollbar {
  display: none;
}
.scrollable-links ul li {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  list-style: none;
}
.scrollable-links ul li:last-child {
  padding-right: 1.4em;
}
.scrollable-links ul li a {
  display: block;
  padding: 10px 0;
  font-size: clamp(1.35rem, 1.364rem + 0.18vw, 1.4rem);
  font-weight: 500;
  white-space: nowrap;
  color: #111;
  position: relative;
}
.scrollable-links ul li a:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #111;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: center top;
          transform-origin: center top;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.scrollable-links ul li a:hover:after, .scrollable-links ul li a.hilight:after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}

@media screen and (max-width: 960px) {
  .fixed-link {
    display: inline-block;
    padding: 0.8em 1.4em;
    border-right: 1px solid rgba(0, 0, 0, 0.1);
    background-color: #fff;
    position: sticky;
    left: 0;
    z-index: 10;
  }
  .scrollable-links ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 12px;
    padding: 0.8em 1.4em;
    margin: 0;
    white-space: nowrap;
    width: 100%;
    max-width: initial;
    cursor: grab;
    cursor: -webkit-grab;
  }
  .scrollable-links ul::-webkit-scrollbar {
    display: none;
  }
  .scrollable-links ul li {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    list-style: none;
  }
}
.event-cal-month {
  position: relative;
  width: 100%;
  background-color: #fff;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  z-index: 3;
  overflow: hidden;
  margin: 0 auto;
}
.event-cal-month .event-inner {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.event-cal-month .event-inner::after {
  content: "";
  display: block;
  position: absolute;
  right: -10%;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 30px;
  height: calc(100% + 5px);
  background: transparent -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0)), to(#fff)) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #fff 100%) 0% 0% no-repeat padding-box;
  pointer-events: none;
  z-index: 5;
}
.event-cal-month ul {
  margin: 0 auto;
}
.event-cal-month ul li a {
  position: relative;
  display: block;
  margin: 0;
  padding: 10px 12px;
  color: #111;
  text-decoration: none;
  white-space: nowrap;
}
.event-cal-month ul .year::after {
  content: "年";
}
.event-cal-month ul .month::after {
  content: "月";
}

@media screen and (max-width: 960px) {
  .event-cal-month {
    white-space: nowrap;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
  .event-cal-month ul {
    height: 100%;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding: 1em 0em;
  }
}
.pages_sub_navi {
  position: relative;
  width: auto;
  background-color: #fff;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  z-index: 3;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.pages_sub_navi.is_center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.pages_sub_navi.is_center ul {
  gap: 30px;
}
.pages_sub_navi.mar {
  margin-bottom: 2.5em;
}
.pages_sub_navi::after {
  content: "";
  display: block;
  position: absolute;
  right: 0%;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 30px;
  height: calc(100% + 5px);
  background: transparent -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0)), to(#fff)) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #fff 100%) 0% 0% no-repeat padding-box;
  pointer-events: none;
  z-index: 5;
}

@media screen and (max-width: 960px) {
  .pages_sub_navi {
    position: relative;
    width: auto;
    background-color: #fff;
    border-radius: 10px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    z-index: 3;
    overflow: hidden;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.upon_navi {
  position: relative;
  width: 100%;
  max-width: 880px;
  margin: -30px auto 60px;
  z-index: 1;
}
.upon_navi .pages_sub_navi ul {
  gap: 28px;
}

.bottomon_navi {
  margin-top: -43px;
  z-index: 1;
}

@media screen and (max-width: 960px) {
  .upon_navi {
    width: 95%;
    margin: 1em auto 5em;
  }
  .upon_navi .pages_sub_navi ul {
    gap: 16px;
  }
  .bottomon_navi {
    margin-top: -37px;
  }
  .pages_sub_navi_ {
    width: 100%;
    overflow: hidden;
    overflow-x: scroll;
    white-space: nowrap;
    border-radius: 0;
  }
  .pages_sub_navi_::-webkit-scrollbar {
    display: none;
  }
  .pages_sub_navi_ ul {
    width: 100%;
    height: 100%;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    padding: 1em;
  }
}
.title_column {
  position: relative;
  margin: 1em auto 2.5em;
  width: 93%;
  max-width: 1200px;
}
.title_column.conout {
  margin: 4em auto 3.5em;
}
.title_column.conr {
  width: 100%;
}
.title_column .title_flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
}
.title_column .title_column_list {
  display: grid;
  grid-template-columns: 1fr auto;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
}
.title_column .list {
  margin-top: -16px;
}
.title_column .list a {
  border: 1px solid rgba(0, 0, 0, 0.1);
  padding: 14px 48px 14px 14px;
  white-space: nowrap;
  border-radius: 4px;
  font-size: clamp(1.3rem, 1.122rem + 0.37vw, 1.4rem);
}
.title_column .sub {
  font-size: clamp(3.5rem, 2.445rem + 5.27vw, 6.4rem);
  font-family: "Inter", sans-serif;
  font-weight: 700;
  white-space: nowrap;
  color: #111;
  margin-bottom: 0.1em;
  padding: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
}
.title_column .sub span {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(1.3rem, 0.638rem + 1.38vw, 1.5rem);
  font-weight: 600;
}
.title_column h1 {
  font-size: clamp(1.2rem, 1.127rem + 0.36vw, 1.4rem);
  line-height: 1.4;
  font-weight: 400;
  margin: 0;
  color: #111;
}
.title_column h1.t {
  font-size: clamp(2.8rem, 2.509rem + 1.45vw, 3.6rem);
  font-weight: 900;
}
.title_column .sub_text {
  font-size: clamp(1.5rem, 1.169rem + 0.69vw, 1.6rem);
  font-weight: 500;
}

@media screen and (max-width: 960px) {
  .title_column {
    margin: 1em auto 1em;
    max-width: initial;
  }
  .title_column.conout .title_column_list {
    display: block;
  }
  .title_column.conout .title_column_list .title {
    margin-bottom: 2em;
  }
  .title_column .title_flex {
    display: block;
  }
  .title_column .list {
    margin-top: 0;
  }
  .title_column .sub {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
  }
}
.newsticker {
  position: absolute;
  bottom: 90px;
  left: 5%;
  z-index: 3;
  width: 396px;
  background-color: #fff;
  color: #325CD1;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.04);
  display: grid;
  grid-template-columns: 66px 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 16px;
     -moz-column-gap: 16px;
          column-gap: 16px;
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
          box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
  text-decoration: none;
  padding: 1.2em 1.5em;
}
.newsticker:hover {
  border: 1px solid #325CD1;
}
.newsticker .post_box {
  border-radius: 4px;
  overflow: hidden;
}
.newsticker .pickup_summary {
  position: relative;
}
.newsticker .pickup_summary .title {
  font-size: clamp(1.3rem, 1.364rem + 0.18vw, 1.4rem);
  font-weight: 500;
  line-height: 1.4;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.newsticker .pickup_summary .data {
  font-size: 1.2rem;
  margin-top: 1em;
}

@media screen and (max-width: 960px) {
  .newsticker {
    position: absolute;
    bottom: 3%;
    right: 5%;
    left: 50%;
    width: 90%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    display: grid;
    grid-template-columns: 66px 1fr;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 16px;
       -moz-column-gap: 16px;
            column-gap: 16px;
    padding: 1.2em 1.5em;
  }
}
.Cal_flow {
  margin-top: 3em;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
}
.Cal_flow .cal_box {
  border: 1px solid rgba(0, 0, 0, 0.1254901961);
  border-radius: 10px;
  padding: 1em 2em;
}
.Cal_flow .calendar_bw {
  width: 100%;
  border-collapse: collapse;
  font-weight: 500;
  margin: 0 auto;
}
.Cal_flow .calendar_bw td,
.Cal_flow .calendar_bw th {
  font-size: 1.4rem;
  text-align: center;
  font-weight: 600;
}
.Cal_flow .calendar_bw th {
  width: 40px;
  height: 40px;
  padding: 0em;
  font-weight: 600;
}
.Cal_flow .calendar_bw td {
  width: 40px;
  height: 40px;
  padding: 0em;
  text-align: center;
}
.Cal_flow .cal_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 1em auto;
  padding: 0 1em 0 1.2em;
}
.Cal_flow .cal_title .cc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-family: "Outfit", sans-serif;
  font-weight: 600;
}
.Cal_flow .cal_title .cc .cale_month {
  font-size: 3.8rem;
  margin-right: 0.8em;
}
.Cal_flow .cal_title .cc .cale_year {
  font-size: 1.4rem;
}
.Cal_flow .cal_title .cd {
  position: relative;
  color: #325CD1;
  font-weight: 500;
}
.Cal_flow .cal_title .cd .square {
  display: inline-block;
  width: 30px;
  height: 26px;
  border-radius: 4px;
  background-color: #325CD1;
  margin-right: 1em;
  vertical-align: middle;
}

@media screen and (max-width: 960px) {
  .Cal_flow {
    margin-top: 1em;
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.dayoff.close {
  text-align: center;
  margin: auto;
}
.dayoff.close span {
  color: #fff;
  border-radius: 6px;
  background-color: #325CD1;
  color: #fff !important;
  display: grid;
  place-content: center;
  padding: 2px;
  width: 34px;
  height: 34px;
  margin: auto;
}

/* もっと見るボタン */
.cale-MoreBtn {
  margin-top: 50px;
}
.cale-MoreBtn span {
  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;
  cursor: pointer;
}
.cale-MoreBtn span::after {
  content: "";
  display: inline-block;
  height: 8px;
  width: 8px;
  border-bottom: 2px solid #000;
  border-right: 2px solid #000;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  margin-left: 20px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.cale-MoreBtn.close span::after {
  -webkit-transform: rotate(225deg);
          transform: rotate(225deg);
}

.close td {
  padding: 0;
  vertical-align: 10px;
}

.close:after {
  color: #fff;
}

.link_htm {
  font-size: 1.2rem;
  max-width: 56px;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.post_visual {
  position: relative;
  margin-bottom: 1.5em;
  border-radius: 6px;
  overflow: hidden;
}

.singleDetail {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
          box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
  width: 70%;
  margin: 3.5em auto 3em;
  padding: 3em 2.5em;
}

.blogDetail {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
          box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
  width: 70%;
  margin: 3.5em auto 3em;
  border-radius: 100px 100px 0 0;
}
.blogDetail .post_box {
  border-radius: 0 0 100px 0;
  overflow: hidden;
}
.blogDetail .inner {
  padding: 3em 2.5em;
}

@media screen and (max-width: 960px) {
  .singleDetail {
    width: 95%;
    margin: 3.5em auto 3em;
    padding: 2em 1.5em;
  }
  .blogDetail {
    width: 100%;
  }
}
.detailInfo {
  position: relative;
  margin-bottom: 3em;
}
.detailInfo h1 {
  position: relative;
  font-size: clamp(1.8rem, 1.267rem + 1.11vw, 2.1rem);
  color: #111;
  font-weight: 500;
  line-height: 1.45;
  margin: 0 0 1.4em 0;
}
.detailInfo .place {
  font-size: 1.2rem;
  color: #325CD1;
}
.detailInfo .catdata ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
}
.detailInfo .catdata ul li {
  text-align: center;
  font-size: 1.4rem;
  padding: 12px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 9999px;
  white-space: nowrap;
}

.newscate {
  position: relative;
}
.newscate::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  background-color: currentColor;
  border-radius: 9999px;
  margin-bottom: 2px;
  margin-left: 6px;
  vertical-align: middle;
}

.under_column {
  display: grid;
  grid-template-columns: 70% 24%;
  -webkit-box-align: self-start;
      -ms-flex-align: self-start;
          align-items: self-start;
  gap: 40px;
}
.under_column .idxContentDetail {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
          box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
  padding: 3em 2.5em;
}
.under_column .idxSideDetail {
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 10px;
}
.under_column .idxSideDetail ul li {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.under_column .idxSideDetail ul li:last-child {
  border-bottom: none;
}
.under_column .idxSideDetail ul li a {
  position: relative;
  display: block;
  padding: 1em;
  font-size: clamp(1.3rem, 1.264rem + 0.18vw, 1.4rem);
  font-weight: 500;
  color: #111;
}
.under_column .idxSideDetail ul li a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 6px;
  height: 6px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
}
.under_column .mainAsset {
  background-color: #fff;
  border-radius: 10px;
  border: 1px solid rgba(50, 92, 209, 0.2);
  overflow: hidden;
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
          box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
  padding: 0;
}
.under_column .mainAsset .innder {
  padding: 3em 2.5em;
}
.under_column .mainAsset .post_visual {
  border-radius: 0;
}

@media screen and (max-width: 960px) {
  .under_column {
    display: grid;
    grid-template-columns: 1fr;
    -webkit-box-align: self-start;
        -ms-flex-align: self-start;
            align-items: self-start;
    gap: 20px;
  }
  .under_column .idxContentDetail {
    background-color: #fff;
    border-radius: 10px;
    overflow: hidden;
    -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
            box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
    padding: 2em 1.5em;
  }
}
.sidebox {
  position: relative;
  display: block;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  margin-bottom: 1.5em;
  background-color: #fff;
}
.sidebox .post_trim {
  border-radius: 10px 10px 0 0;
  overflow: hidden;
  aspect-ratio: 300/155;
}
.sidebox .overview {
  padding: 1em;
  text-align: left;
}
.sidebox .overview h2 {
  font-size: clamp(1.4rem, 1.255rem + 0.73vw, 1.8rem);
  font-weight: 500;
  line-height: 1.4;
  margin-bottom: 0.8em;
}
.sidebox .overview .place,
.sidebox .overview .time {
  color: rgba(0, 0, 0, 0.5411764706);
  font-size: 1.3rem;
  line-height: 1.4;
}

.floorBox {
  position: relative;
  display: block;
  border-radius: 20px;
  margin-bottom: 2.5em;
  border: 1px solid rgba(0, 0, 0, 0.1);
  -webkit-box-shadow: 0px 2px 8px -3px rgba(0, 0, 0, 0.1);
          box-shadow: 0px 2px 8px -3px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}
.floorBox .floorguide {
  position: absolute;
  top: 0;
  left: 0;
  padding: 14px 32px;
  display: inline-block;
  color: #fff;
  background-color: #325CD1;
}
.floorBox .floorguide .perform_floor {
  font-family: "Inter", sans-serif;
}
.floorBox .floorguide .perform_eastwest {
  margin-left: 20px;
}

.friends_subBox .post_box {
  margin: auto;
  max-width: 40%;
}
.friends_subBox .post_box .post_square {
  border-radius: 10px;
  margin-bottom: 3em;
}
.friends_subBox .text {
  margin: 1em 0 0 0;
  padding: 0.5em;
}
.friends_subBox .text h3 {
  font-size: 1.4rem;
  font-weight: 500;
  margin-bottom: 0.5em;
}
.friends_subBox .text p {
  font-size: 1.4rem;
  margin: 0;
}

.single_title {
  font-size: clamp(2.4rem, -1.572rem + 8.28vw, 3.6rem);
  font-weight: 300;
  margin-bottom: 1.5em;
}

.title_typeA {
  font-size: clamp(2rem, 0.676rem + 2.76vw, 2.4rem);
  font-weight: 600;
  margin-bottom: 1.5em;
}

.title_typeB {
  font-size: clamp(1.8rem, 1.138rem + 1.38vw, 2rem);
  font-weight: 600;
  margin-bottom: 1.2em;
}

.title_typeC {
  margin-bottom: 1em;
}

.txtlink {
  position: relative;
  margin-bottom: 12px;
  background-color: #fff;
  -webkit-box-shadow: 0px 2px 8px -3px rgba(0, 0, 0, 0.1);
          box-shadow: 0px 2px 8px -3px rgba(0, 0, 0, 0.1);
}
.txtlink a {
  position: relative;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 4px;
  padding: 1em;
  display: block;
}
.txtlink a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 6px;
  height: 6px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
}

table.spec_table {
  width: 100%;
  text-align: left;
  font-size: 1.38rem;
  margin-bottom: 0;
}
table.spec_table th {
  vertical-align: top;
  text-align: left;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding: 8px;
  white-space: nowrap;
  line-height: 1.3;
  background: none;
}
table.spec_table td {
  vertical-align: top;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding: 8px;
  width: auto;
}
table.sub_table {
  width: 100%;
  text-align: left;
  font-size: 1.38rem;
  margin: 0 0 0.8em 0;
}
table.sub_table tr.sub_b {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
table.sub_table th {
  vertical-align: top;
  text-align: left;
  padding: 8px;
  white-space: nowrap;
  width: 100px;
  line-height: 1.3;
}
table.sub_table th.sub_name {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1;
}
table.sub_table td {
  vertical-align: top;
  padding: 8px;
  line-height: 1.3;
}
table.sub_table td.sub_name {
  font-size: 2rem;
  font-weight: 500;
  text-align: right;
  line-height: 1;
}

.side_scroll {
  overflow-x: scroll;
  margin-bottom: 64px;
}

.side_scroll::-webkit-scrollbar-track {
  margin: 0 2px;
  background: #dedede;
  border-radius: 5px;
}

.side_scroll::-webkit-scrollbar-thumb {
  background: #666;
}

.side_scroll table th,
.side_scroll table td {
  white-space: nowrap;
}

@media only screen and (min-width: 768px) {
  .side_scroll {
    overflow-x: inherit;
  }
}
.idxContentFloor {
  width: 100%;
  background-color: #f9f9fa;
}

.floorBtnGroup {
  padding: 24px 12px;
}

.floorLinkBox {
  background-color: #fff;
  border-radius: 6px;
  margin: 0 auto 18px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-line-pack: start;
      align-content: flex-start;
}

.floorLink {
  width: 50%;
  position: relative;
  display: inline-block;
  color: #111;
  text-decoration: none;
  background-color: #fff;
  border-radius: 4px;
  font-size: 1.4rem;
  text-align: left;
  line-height: 1.3;
}

.floorLink a {
  color: #111;
  display: block;
  text-decoration: none;
  padding: 24px 24px 24px 24px;
}

.floorLink a::after {
  position: absolute;
  top: 42%;
  right: 16px;
  content: "";
  width: 6px;
  height: 6px;
  border-top: solid 2px #848484;
  border-right: solid 2px #848484;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media only screen and (min-width: 768px) {
  .FloorDiv {
    width: 100%;
    height: 700px;
    margin: 0 auto;
  }
  .floor-thumbnail {
    width: 100%;
    height: 100%;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    border-bottom: 1px solid #dedede;
  }
}
.idxContentFloor {
  width: 100%;
  background-color: #f9f9fa;
}

.floorBtnGroup {
  padding: 24px 12px;
}

.floorLinkBox {
  background-color: #fff;
  border-radius: 6px;
  margin: 0 auto 18px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-line-pack: start;
      align-content: flex-start;
}

.floorLink {
  width: 50%;
  position: relative;
  display: inline-block;
  color: #111;
  text-decoration: none;
  background-color: #fff;
  border-radius: 4px;
  font-size: 1.4rem;
  text-align: left;
  line-height: 1.3;
}

.floorLink a {
  color: #111;
  display: block;
  text-decoration: none;
  padding: 24px 24px 24px 24px;
}

.floorLink a::after {
  position: absolute;
  top: 42%;
  right: 16px;
  content: "";
  width: 6px;
  height: 6px;
  border-top: solid 2px #848484;
  border-right: solid 2px #848484;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media only screen and (min-width: 768px) {
  .FloorDiv {
    width: 100%;
    height: 700px;
    margin: 0 auto;
  }
  .floor-thumbnail {
    width: 100%;
    height: 100%;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    border-bottom: 1px solid #dedede;
  }
}
.lity-wrap {
  overflow: auto;
}

.lity {
  z-index: 9990;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  white-space: nowrap;
  background: #0b0b0b;
  background: rgba(0, 0, 0, 0.9);
  outline: none !important;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
.lity.lity-opened {
  opacity: 1;
}
.lity.lity-closed {
  opacity: 0;
}

.lity * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.lity-wrap {
  z-index: 9990;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  text-align: center;
  outline: none !important;
}
.lity-wrap:before {
  content: "";
  display: inline-block;
  height: 100%;
  vertical-align: middle;
  margin-right: -0.25em;
}

.lity-loader {
  z-index: 9991;
  color: #fff;
  position: absolute;
  top: 50%;
  margin-top: -0.8em;
  width: 100%;
  text-align: center;
  font-size: 14px;
  font-family: Arial, Helvetica, sans-serif;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
.lity-loader .lity-loader {
  opacity: 1;
}

.lity-content {
  z-index: 9993;
  width: 100%;
  height: 100%;
  -webkit-transform: scale(1);
          transform: scale(1);
  transition: -webkit-transform 0.3s ease;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
.lity-content:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  display: block;
  right: 0;
  width: auto;
  height: auto;
  z-index: -1;
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}

.lity-loading .lity-content,
.lity-closed .lity-content {
  -webkit-transform: scale(0.8);
          transform: scale(0.8);
}

.lity-close {
  z-index: 9994;
  width: 35px;
  height: 35px;
  position: fixed;
  right: 0;
  top: 0;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  padding: 0;
  color: #fff;
  font-style: normal;
  font-size: 35px;
  font-family: Arial, Baskerville, monospace;
  line-height: 35px;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
  border: 0;
  background: none;
  outline: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.lity-close::-moz-focus-inner {
  border: 0;
  padding: 0;
}

.lity-close:hover,
.lity-close:focus,
.lity-close:active,
.lity-close:visited {
  text-decoration: none;
  text-align: center;
  padding: 0;
  color: #fff;
  font-style: normal;
  font-size: 35px;
  font-family: Arial, Baskerville, monospace;
  line-height: 35px;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
  border: 0;
  background: none;
  outline: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.lity-close:active {
  top: 1px;
}

/* Image */
.lity-image img {
  max-width: 100%;
  display: block;
  line-height: 0;
  border: 0;
}

/* iFrame */
.lity-iframe .lity-container,
.lity-youtube .lity-container,
.lity-vimeo .lity-container,
.lity-facebookvideo .lity-container,
.lity-googlemaps .lity-container {
  width: 100%;
  max-width: 964px;
}

.lity-iframe-container {
  width: 100%;
  height: 0;
  padding-top: 56.25%;
  overflow: auto;
  pointer-events: auto;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}
.lity-iframe-container iframe {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
          box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  background: #000;
}

.lity-hide {
  display: none;
}

/*
  パフォーマンス
 */
.performance_visual {
  background-color: #325CD1;
  height: calc(21vh + 21vw);
  margin: 0 auto 0;
  overflow: hidden;
}
.performance_visual .visual_inner {
  position: relative;
  width: var(--width);
  max-width: 1200px;
  height: calc(21vh + 21vw);
  margin: 0 auto;
}
.performance_visual .timetable-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #fff;
  height: calc(21vh + 21vw);
  padding: 2em;
}
.performance_visual .timetable-header .title {
  margin-bottom: auto;
  font-size: clamp(2.4rem, 1.076rem + 2.76vw, 2.8rem);
  font-weight: 500;
  margin-bottom: auto;
}
.performance_visual .timetable-header .title small {
  margin-top: 0.5em;
  display: block;
  font-size: clamp(1.8rem, 1.138rem + 1.38vw, 2rem);
  opacity: 0.5;
}
.performance_visual .timetable-header .date {
  display: block;
  font-size: clamp(2.4rem, -0.248rem + 5.52vw, 3.2rem);
  font-weight: 500;
  font-family: Century Gothic;
  line-height: 1.2;
}
.performance_visual .timetable-header .date .day {
  font-size: clamp(8rem, 1.379rem + 13.79vw, 10rem);
  letter-spacing: -0.05em;
}
.performance_visual .timetable-header .date .youbi {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(2.4rem, -0.248rem + 5.52vw, 3.2rem);
  font-weight: 500;
}
.performance_visual .timetable-header .date .kugiri {
  opacity: 0.5;
}
.performance_visual .timetable-header .period {
  display: block;
  opacity: 0.6;
}

.announce {
  position: relative;
  background-color: #325CD1;
  width: 100%;
  text-decoration: none;
  color: #fff;
  display: block;
  padding: 4px 0;
}
.announce .inner {
  margin: auto;
  width: var(--width);
  max-width: 1200px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
}
.announce .inner .title {
  font-size: clamp(1.4rem, 1.169rem + 0.69vw, 1.5rem);
  font-weight: 400;
}
.announce .inner span {
  font-size: 1.3rem;
  white-space: nowrap;
  display: inline-block;
  background-color: #fff;
  color: #325CD1;
  padding: 12px 10px;
  border-radius: 4px;
}

@media screen and (max-width: 960px) {
  .announce .inner {
    margin: auto;
    width: 98%;
    max-width: initial;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 20px;
  }
}
.timetable-main {
  position: relative;
}
.timetable-main .clock {
  position: absolute;
  top: -1.2em;
  left: 0;
  right: 0;
  display: block;
  margin: auto;
  padding: 0.6em 1.2em;
  width: 15em;
  color: #fff;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  background-color: #325cd1;
  border-radius: 5em;
  -webkit-filter: drop-shadow(0 7px 12px rgba(0, 0, 0, 0.15));
          filter: drop-shadow(0 7px 12px rgba(0, 0, 0, 0.15));
}
.timetable-main .clock::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1em;
  margin: auto;
  width: 0.8em;
  height: 0.8em;
  background-image: url(data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.991%22%20height%3D%2212.759%22%20viewBox%3D%220%200%209.991%2012.759%22%3E%3Cpath%20d%3D%22M0%2C0%2C5.2%2C6.634%2C10.4%2C0%22%20transform%3D%22translate%280.925%2011.578%29%20rotate%28-90%29%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-width%3D%222%22%2F%3E%3C%2Fsvg%3E);
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: contain;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
.timetable-main .clock small {
  position: absolute;
  left: 2em;
  opacity: 0.5;
}
.timetable-main .clock .time {
  font-family: "century-gothic", sans-serif;
}
.timetable-main .return {
  position: absolute;
  top: -1.2em;
  left: 0;
  right: 0;
  display: block;
  margin: auto;
  padding: 0.3em 0;
  width: 17em;
  color: rgba(50, 92, 209, 0.7);
  text-align: center;
  text-decoration: none;
  background-color: #fff;
  border-radius: 5em;
  -webkit-filter: drop-shadow(0 7px 12px rgba(0, 0, 0, 0.15));
          filter: drop-shadow(0 7px 12px rgba(0, 0, 0, 0.15));
}
.timetable-main .return::after {
  content: "";
  display: inline-block;
  margin-left: 0.5em;
  width: 0.8em;
  height: 0.8em;
}

.timetable_wrap_grid {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  margin-top: 5em;
}

@media screen and (max-width: 960px) {
  .timetable_wrap_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.timetable_box {
  display: grid;
  grid-template-columns: 14% 1fr;
  gap: 24px;
  padding: 2em 0 1em;
  background-color: #fff;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  overflow: hidden;
}
.timetable_box .title.past, .past + .timetable_box .title,
.timetable_box .content.past,
.past + .timetable_box .content {
  opacity: 0.2;
}
.timetable_box .past + .content,
.timetable_box .past + .title,
.timetable_box .content.past,
.timetable_box .title.past {
  opacity: 0.2;
}
.timetable_box .past + .content a {
  pointer-events: none;
}
.timetable_box .title {
  position: relative;
  color: #325CD1;
  font-size: clamp(1.5rem, 1.169rem + 0.69vw, 1.6rem);
  font-weight: 500;
  font-family: Century Gothic;
  text-align: right;
}
.timetable_box .title.past + * + .title:not(.past)::before {
  content: "";
  position: absolute;
  top: -0.6em;
  left: 0;
  width: 100vw;
  border-top: 2px solid #325CD1;
}
.timetable_box .content {
  position: relative;
}
.timetable_box .content::after {
  content: "";
  position: absolute;
  bottom: -12px;
  right: 0;
  width: 100%;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.timetable_box .content a {
  position: relative;
  display: block;
  margin-bottom: 0.4em;
  padding-right: 1em;
  text-decoration: none;
  font-size: clamp(1.4rem, 1.169rem + 0.69vw, 1.5rem);
  font-weight: 400;
  margin-bottom: 0.8em;
}
.timetable_box .content a:last-child {
  margin-bottom: 0;
}
.timetable_box .content a:hover {
  color: #325CD1;
}
.timetable_box .content a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 8px;
  width: 7px;
  height: 7px;
  border-top: solid 2px #325CD1;
  border-right: solid 2px #325CD1;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.timetable_box .content a .event_icon {
  display: grid;
  grid-template-columns: 78% 20%;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 5px;
}
.timetable_box .content a .event-title {
  line-height: 1.5;
}
.past + .timetable_box .content a {
  pointer-events: none;
}

.timetable-aside {
  background-color: #fff;
  border-radius: 10px;
  border: 1px solid #eee;
  margin-bottom: 1.5em;
}
.timetable-aside .head {
  position: relative;
  margin-bottom: 0;
  padding: 1.4em 1.5em;
  border-bottom: 1px solid #eee;
}
.timetable-aside .head .heading {
  font-size: clamp(2rem, 0.676rem + 2.76vw, 2.4rem);
  font-weight: 500;
  color: #325CD1;
  white-space: nowrap;
  margin-bottom: 0.2em;
}
.timetable-aside .head .period {
  color: rgba(0, 0, 0, 0.5019607843);
  font-size: clamp(1.2rem, 0.869rem + 0.69vw, 1.3rem);
}
.timetable-aside .timetable_list {
  position: relative;
  padding: 1em 0;
}
.timetable-aside .timetable_list .timetable_item {
  position: relative;
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 20px;
  margin-bottom: 1em;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding: 0 1em 1em;
}
.timetable-aside .timetable_list .timetable_item:last-child {
  border-bottom: none;
}
.timetable-aside .timetable_list .timetable_item::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #848484;
  border-right: solid 2px #848484;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.timetable-aside .timetable_list .timetable_item .post_square {
  border-radius: 5px;
  overflow: hidden;
}
.timetable-aside .timetable_list .timetable_item .content {
  padding-right: 1em;
}
.timetable-aside .timetable_list .timetable_item .content .title {
  font-size: clamp(1.5rem, 1.169rem + 0.69vw, 1.6rem);
  font-weight: 400;
  margin-bottom: 0.7em;
}
.timetable-aside .timetable_list .timetable_item .content .event-meta {
  font-size: 1.4rem;
  color: #aaa;
}
.timetable-aside .timetable_list .timetable_item:hover {
  color: #325CD1;
}
.timetable-aside .timetable_list .timetable_item .outline,
.timetable-aside .timetable_list .timetable_item .timetable_outline {
  display: block;
  margin: 0.5em 0;
}
.timetable-aside .timetable_list .timetable_item .outline p,
.timetable-aside .timetable_list .timetable_item .timetable_outline p {
  color: #aaa;
  font-size: 1.4rem;
  margin: 0;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.timetable-aside .timetable_list .timetable_item .hours {
  color: #aaa;
  font-size: 0.75em;
}
.timetable-aside .timetable_list .timetable_item .hours > * {
  display: inline-block;
  margin-right: 0.5em;
}

.timetable_archive {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.timetable_archive .timetable_archive_item {
  position: relative;
  padding: 1.5em;
  border-bottom: 1px solid #eee;
}
.timetable_archive .timetable_archive_item:nth-child(odd) {
  border-right: 1px solid #eee;
}
.timetable_archive .timetable_archive_item:last-child, .timetable_archive .timetable_archive_item:nth-last-child(2):not(:nth-child(even)) {
  border-bottom: none;
}
.timetable_archive .timetable_archive_item a {
  display: inline-block;
  padding-bottom: 0.5em;
  font-size: 0.85em;
  line-height: 1.5;
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.timetable_archive .timetable_archive_item a:hover {
  color: #325CD1;
}
.timetable_archive .timetable_archive_item a::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
.timetable_archive .timetable_archive_item a.current {
  border-bottom-color: #111;
}

.detail-modal .detail-modal__box--outline {
  position: relative;
  display: grid;
  grid-template-columns: 45% 1fr;
  -webkit-box-align: self-start;
      -ms-flex-align: self-start;
          align-items: self-start;
  gap: 30px;
  margin: 0 auto 1em;
}
.detail-modal blockquote {
  position: relative;
  padding: 1em;
  border: 1px solid rgba(0, 0, 0, 0.1);
  background-color: #f0f0f0;
}
.detail-modal blockquote p,
.detail-modal blockquote ul {
  margin-bottom: 0;
}
.detail-modal__box {
  position: relative;
  width: 100%;
}
.detail-modal__box .detail-modal__image {
  width: 100%;
  display: block;
  background-size: cover;
  background-position: 50% 50%;
  border-radius: 10px;
  aspect-ratio: 1/1;
}
.detail-modal__box .detail-modal__content .detail-modal__title {
  font-size: clamp(2.8rem, 1.476rem + 2.76vw, 3.2rem);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.detail-modal__box .detail-modal__content .status {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 1em;
}
.detail-modal__box .detail-modal__content .event-meta {
  display: inline-block;
  color: #111;
  font-size: clamp(1.2rem, 0.869rem + 0.69vw, 1.3rem);
}
.detail-modal__box .detail-modal__content .event-meta span {
  display: inline-block;
}
.detail-modal__box .detail-modal__content .event_caution_text_modal {
  color: #C16BC4;
  background-color: #F7EDF8;
  font-size: clamp(1.2rem, 0.869rem + 0.69vw, 1.3rem);
  padding: 1.2em;
  margin: 1.5em auto;
}
.detail-modal .detailbox_gridfwrap {
  position: relative;
  display: grid;
  grid-template-columns: 47.5% 50%;
  gap: 30px;
}
.detail-modal .detailbox_gridfwrap .detail-modal__box--floor {
  margin-top: 100px;
}
.detail-modal .detailbox_gridfwrap .detail-modal__box--friends {
  margin-top: 100px;
  padding: 0 20px 20px;
}
.detail-modal__box--friends .detail-modal__title {
  text-align: center;
  margin-bottom: 2em;
}
.detail-modal__summary {
  margin: 1em auto 2em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  border-top: 1px solid #eee;
}
.detail-modal__summary__title, .detail-modal__summary__content {
  padding: 0.8em 0.1em;
  border-bottom: 1px solid #eee;
}
.detail-modal__summary__title {
  width: 25%;
  font-size: clamp(1.3rem, 0.969rem + 0.69vw, 1.4rem);
  font-weight: 500;
}
.detail-modal__summary__content {
  width: 75%;
  font-size: clamp(1.3rem, 0.969rem + 0.69vw, 1.4rem);
  font-weight: 400;
}
.detail-modal__summary__content span {
  display: inline-block;
  margin-right: 0.5em;
}
.detail-modal__summary__content small {
  display: block;
  color: #aaa;
  font-size: 0.75em;
}
.detail-modal__outline ul {
  margin-bottom: 2em;
}
.detail-modal__outline ul li {
  font-size: clamp(1.3rem, 0.969rem + 0.69vw, 1.4rem);
}
.detail-modal__box--friends .detail-modal__outline {
  color: #717171;
  font-size: 0.875em;
}
.detail-modal__application {
  margin-top: 15px;
}
.detail-modal__box--supprement .detail-modal__application, .detail-modal__box--supprement + .detail-modal__application {
  display: none;
}
.detail-modal__dead {
  padding: 1em;
  color: #fff;
  font-size: 1.2rem;
  background-color: #6158dc;
  border-radius: 5px;
}
.detail-modal__dead .phone {
  font-size: clamp(1.8rem, 1.138rem + 1.38vw, 2rem);
}
.detail-modal__place {
  display: inline-block;
  vertical-align: bottom;
  color: #fff;
  padding: 0.2em 0.8em;
  font-size: clamp(1.8rem, 1.138rem + 1.38vw, 2rem);
  background-color: #325cd1;
  max-width: calc(100% - 20px);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  position: absolute;
  bottom: 100%;
}
.detail-modal__map {
  display: block;
  max-width: 100%;
  border-radius: 0 20px 20px;
}
.detail-modal__avatar {
  position: absolute;
  top: -79px;
  left: 0;
  right: 0;
  margin: auto;
  display: block;
  width: 142px;
  background-size: cover;
  background-position: 50% 50%;
  border-radius: 9999px;
}
.detail-modal__avatar::before {
  content: "";
  display: block;
  padding-top: 100%;
}
.detail-modal .detail-modal__avatar + * {
  margin-top: 109px;
}
.detail-modal__state {
  overflow: hidden;
  font-size: 1.2rem;
  color: rgba(0, 0, 0, 0.5);
  margin-bottom: 30px;
}
.detail-modal__badge {
  float: right;
}

@media screen and (max-width: 960px) {
  .detail-modal__box {
    position: relative;
    width: 100%;
  }
  .detail-modal__box .detail-modal__image {
    width: 100%;
    display: block;
    background-size: cover;
    background-position: 50% 50%;
    border-radius: 10px;
    aspect-ratio: 1/1;
  }
  .detail-modal__box .detail-modal__content .detail-modal__title {
    margin-bottom: 0.5em;
  }
  .detail-modal__box .detail-modal__content .status {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 1em;
  }
  .detail-modal__box .detail-modal__content .event-meta {
    display: inline-block;
  }
  .detail-modal__box .detail-modal__content .event-meta span {
    display: inline-block;
  }
  .detail-modal .detailbox_gridfwrap {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .detail-modal .detailbox_gridfwrap .detail-modal__box--floor {
    margin-top: 20px;
  }
  .detail-modal .detailbox_gridfwrap .detail-modal__box--friends {
    margin-top: 65px;
    padding: 0 0 20px;
  }
  .detail-modal .detailbox_gridfwrap .detail-modal__box--friends .detail-modal__avatar {
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    display: block;
    width: 80px;
  }
}
.lity {
  background-color: rgba(50, 92, 209, 0.9);
}

.lity-wrap {
  overflow: auto;
}

.lity-container {
  position: relative;
  z-index: 9992;
  width: 88%;
  max-width: 1200px;
  height: auto;
  max-height: 90%;
  background-color: #fff;
  border-radius: 20px;
  padding: 2em;
  margin: auto;
  text-align: left;
  vertical-align: middle;
  display: inline-block;
  white-space: normal;
  outline: none !important;
  overflow-x: scroll;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.lity-container::-webkit-scrollbar {
  display: none;
}

.lity-content {
  height: 100%;
}
.lity-content::after {
  display: none;
}

.lity-close,
.lity-close:hover {
  font-size: 0;
  border-radius: 9999px;
  -webkit-filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.16));
  background: #000 url("../img/module/icon/icon_close.svg");
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 20%;
  top: 30px;
  right: 30px;
  width: 64px;
  height: 64px;
}

@media screen and (max-width: 960px) {
  .detail-modal__box {
    position: relative;
    width: 100%;
  }
  .detail-modal__box .detail-modal__image {
    width: 100%;
    display: block;
    background-size: cover;
    background-position: 50% 50%;
    border-radius: 10px;
    aspect-ratio: 1/1;
  }
  .detail-modal .detail-modal__box--outline {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    -webkit-box-align: self-start;
        -ms-flex-align: self-start;
            align-items: self-start;
    gap: 20px;
    margin: 0 auto 1em;
  }
}
@media screen and (max-width: 960px) {
  .detail-modal .detail-modal__avatar + * {
    margin-top: 30px;
  }
}
/*
  イベント
 */
.event-cal-badge, .event-cal .badge, .event-cal-top .badge, .detail-modal__badge {
  display: inline-block;
  border-radius: 2px;
  background-color: #cb6fc2;
  color: #fff;
  font-size: 1rem;
  line-height: 1;
  padding: 0.6em 1em 0.5em;
  -webkit-transform: scale(0.8);
          transform: scale(0.8);
}

.event_table_wrap {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 40px;
}

.page_title--event-cal {
  margin: 0 auto;
  text-align: center;
}
.page_title--event-cal .year {
  display: block;
  font-size: clamp(1.3rem, 0.969rem + 0.69vw, 1.4rem);
  font-weight: 500;
}
.page_title--event-cal .num {
  display: block;
  font-size: clamp(5rem, -4.931rem + 20.69vw, 8rem);
  font-weight: 400;
  line-height: 1;
  font-family: "Inter", sans-serif;
}
.page_title--event-cal .month {
  display: block;
  font-size: clamp(1.3rem, 0.969rem + 0.69vw, 1.4rem);
  font-weight: 500;
}

.event-cal-top .slider {
  margin: 30px auto;
}
.event-cal-top .slide {
  position: relative;
  width: 100%;
  max-width: 300px;
  margin: 0 auto;
  padding: 0 10px;
}
.event-cal-top .event {
  display: block;
  border-radius: 2px;
  overflow: hidden;
  -webkit-box-shadow: 0 10px 40px rgba(0, 0, 0, 0.16);
          box-shadow: 0 10px 40px rgba(0, 0, 0, 0.16);
  position: relative;
  background: url("../img/pages/event/caret-right-keycolor.svg") right 10px center no-repeat #fff;
  background-size: 7px 10px;
  padding: 0 25px 0 85px;
  height: 85px;
  text-decoration: none;
}
.event-cal-top .event:hover {
  opacity: 0.65;
}
.event-cal-top .thumb {
  height: 85px;
  width: 85px;
  position: absolute;
  left: 0;
  top: 0;
  background-color: #f5f5f5;
  background-size: cover;
  background-position: 50% 50%;
}
.event-cal-top .lead {
  color: #325cd1;
  opacity: 0.5;
  font-size: 1.1rem;
  line-height: 1.1;
  margin: 0 0 10px;
  font-family: "メイリオ", sans-serif;
}
.event-cal-top .title {
  font-size: 1.2rem;
  line-height: 1;
  margin: 0 0 2px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.event-cal-top .date {
  display: inline-block;
  color: #325cd1;
  font-size: 1.1rem;
  line-height: 1.1;
  margin-right: 1em;
}
.event-cal-top .date__num {
  display: inline-block;
  width: 1.5em;
  font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1;
}
/*
  イベントカレンダー
 */
.event-label {
  display: inline-block;
  padding: 0.4em 0.5em;
  color: #fff;
  font-size: 1.2rem;
  line-height: 1;
  background-color: #aaa;
  border-radius: 3px;
  white-space: nowrap;
  text-align: center;
}
.event-label.close {
  background-color: #aaa;
}
.event-label.little {
  background-color: #cb6fc2;
}
.event-label.available {
  background-color: #4cb5b2;
}
.event-label.lottery {
  background-color: #6158dc;
}
.event-label.expire {
  background-color: #6158dc;
}

.events {
  position: relative;
  display: block;
  width: 100%;
}

.event-cal {
  padding: 30px 0 50px;
}
.event-cal .date {
  text-align: center;
  display: grid;
  grid-template-columns: 60px 32px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}
.event-cal .date .month {
  display: none;
}
.event-cal .date .day {
  font-size: clamp(2.4rem, 0.152rem + 5.52vw, 3.2rem);
  font-family: "Inter", sans-serif;
  font-weight: 400;
  line-height: 1;
}
.event-cal .date .week {
  font-size: clamp(1.3rem, 0.969rem + 0.69vw, 1.4rem);
  line-height: 24px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 4px;
  padding: 4px;
  min-height: 32px;
}
.event-cal .block {
  position: relative;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  overflow: hidden;
  padding: 1em 1em 1.5em 1em;
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 30px;
  -webkit-box-align: self-start;
      -ms-flex-align: self-start;
          align-items: self-start;
}
.event-cal .block.today {
  position: relative;
  border-bottom: none;
  border: 2px solid #325CD1;
  border-radius: 10px;
  margin-bottom: 1.8em;
  padding-top: 0;
  display: block;
  overflow: visible;
}
.event-cal .block.today .today_inner {
  color: #fff;
  background-color: #325CD1;
  font-size: clamp(1.3rem, 0.969rem + 0.69vw, 1.4rem);
  font-weight: 500;
  display: inline-block;
  margin-left: 24px;
  padding: 8px 16px;
  border-radius: 9999px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.event-cal .block.today .inbox {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 30px;
  -webkit-box-align: self-start;
      -ms-flex-align: self-start;
          align-items: self-start;
}
.event-cal .block--closed {
  background-color: #fafafa;
  position: relative;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  overflow: hidden;
  margin-bottom: 1em;
  padding: 1em 1em 1.5em 1em;
  display: grid;
  grid-template-columns: 92px 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
  -webkit-box-align: self-start;
      -ms-flex-align: self-start;
          align-items: self-start;
}
.event-cal .block--closed .event_detail_grid {
  margin-bottom: 0;
}
.event-cal .event_detail_grid {
  position: relative;
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 20px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 1.4em;
}
.event-cal .event_detail_grid.link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  width: 6px;
  height: 6px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.event-cal .event_detail_grid .post_box {
  overflow: hidden;
  border-radius: 5px;
}
.event-cal .event_detail_grid .post_box .post_trim {
  aspect-ratio: 90/45;
}
.event-cal .event_detail_grid .summary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
}
.event-cal .event_detail_grid .summary .event {
  font-weight: 500;
}
.event-cal .event_detail_grid .summary .event_time {
  font-size: 1.2rem;
  color: rgba(0, 0, 0, 0.5019607843);
}
.event-cal .event_modal_grid {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.event-cal .event_modal_grid.is_list .detail-modal__trigger {
  grid-template-columns: 90px 1fr;
  gap: 20px;
}
.event-cal .event_modal_grid .detail-modal__trigger {
  position: relative;
  display: grid;
  grid-template-columns: 45px 1fr;
  gap: 20px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0.8em 1.2em 0.8em 0.8em;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 4px;
  background-color: #fafafa;
}
.event-cal .event_modal_grid .detail-modal__trigger::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  width: 6px;
  height: 6px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.event-cal .event_modal_grid .detail-modal__trigger .post_box {
  overflow: hidden;
  border-radius: 5px;
}
.event-cal .event_modal_grid .detail-modal__trigger .title {
  font-size: clamp(1.6rem, 0.938rem + 1.38vw, 1.8rem);
  font-weight: 500;
  margin-bottom: 0.4em;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.event-cal .event_modal_grid .detail-modal__trigger .time {
  font-size: 1.2rem;
  color: #111;
  font-weight: 500;
  display: inline-block;
  vertical-align: middle;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.event-cal .event_modal_grid .detail-modal__trigger .day {
  font-size: clamp(1.3rem, 0.969rem + 0.69vw, 1.4rem);
  font-weight: 500;
  display: block;
  margin-bottom: 0.5em;
}
.event-cal a.event:hover .title {
  color: #325cd1;
  opacity: 1;
}
.event-cal .title {
  line-height: 1.2;
  margin-bottom: 10px;
}
.event-cal .title--performance {
  margin: 0;
  opacity: 0.5;
}
.event-cal .title--closed {
  margin: 0;
  opacity: 0.5;
}
.event-cal .badge {
  position: absolute;
  top: 10px;
  right: 0;
  margin-right: 1em;
}

@media screen and (max-width: 960px) {
  .event_table_wrap {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 2em;
  }
  .event-cal {
    padding: 30px 0 50px;
  }
  .event-cal .date {
    grid-template-columns: 80px 32px;
  }
  .event-cal .date .month {
    display: inline;
  }
  .event-cal .block {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .event-cal .block--closed {
    display: grid;
    gap: 20px;
    -webkit-box-align: self-start;
        -ms-flex-align: self-start;
            align-items: self-start;
  }
  .event-cal .block.today .inbox {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .event-cal .event_modal_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .event-cal .event_modal_grid .detail-modal__trigger {
    position: relative;
    display: grid;
  }
  .event-cal .event_modal_grid .detail-modal__trigger .title {
    margin-bottom: 0.4em;
    overflow: hidden;
    display: -webkit-box;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
}
.pager {
  margin-top: 2em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 30px;
}
.pager__btn {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 50%;
          flex: 0 1 50%;
  max-width: calc(50% - 10px);
  line-height: 4em;
  text-align: center;
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, 0.1);
  font-size: 1.4rem;
  border-radius: 3px;
  text-decoration: none;
}
.pager__btn:not([aria-disabled]):hover {
  color: #325cd1;
}
.pager__btn[aria-disabled=true] {
  color: #b7b7b7;
}

/*
  イベント申込みフォーム
 */
.application {
  margin-top: 60px;
  padding-bottom: 30px;
  background-color: #fff;
  border-radius: 20px;
}
.application > * {
  padding-left: 30px;
  padding-right: 30px;
}
.application__heading {
  margin-bottom: 30px;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
  color: #325cd1;
  border-bottom: 2px solid #325cd1;
}
.application .form-btn {
  margin: 1em auto;
}

.mw_wp_form_confirm .form-items__title::after,
.mw_wp_form_confirm input[value=""] + .form-unit,
.mw_wp_form_confirm .note {
  display: none;
}

.form-items {
  line-height: 2.8em;
  margin-bottom: 1em;
}
.form-items[aria-hidden=true] {
  display: none;
}
.form-items:not(:nth-of-type(1)) {
  border-top: 1px solid #eee;
}
input[name=post_target]:not([value=fan]) + .form-items {
  display: none;
}
.form-items__title.required::after {
  content: "必須";
  color: #cb6fc2;
  float: right;
}
.form-items__content {
  position: relative;
}
.form-items__content .form-unit {
  display: inline-block;
}
.form-items__content .note {
  position: absolute;
  top: 0;
  right: 0;
}
.form-items__content input[type=radio],
.form-items__content input[type=checkbox] {
  display: inline-block;
  vertical-align: 0.15em;
}

.inputbox {
  padding: 0.5em 1em;
  width: 100%;
  background-color: #f9f9f9;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 4px;
}
.inputbox.parsley-error {
  border-color: #cb6fc2;
}
.inputbox[name$=age] {
  max-width: 165px;
}
.inputbox[name=zip], .inputbox[name=phone], .inputbox[name^=email] {
  max-width: 235px;
}
.inputbox--select {
  position: relative;
  display: block;
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
  max-width: 255px;
}
.inputbox--select:not(:only-child) {
  margin: 0.8em 0;
}
.inputbox--select::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0.5em;
  margin: auto;
  width: 0.7em;
  height: 0.7em;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  pointer-events: none;
}
.inputbox--select select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  outline: none;
  border: none;
  background-color: transparent;
  width: 100%;
}
.inputbox--select select::-ms-expand {
  display: none;
}

.form-age {
  position: relative;
}

.btn_wrap {
  display: grid;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 auto;
}

.form-btn {
  position: relative;
  margin-bottom: 0.8em;
  padding: 1.5em 2em;
  display: block;
  color: #fff;
  text-decoration: none;
  font-size: 1.4rem;
  font-weight: 500;
  border-radius: 4px;
  -webkit-box-shadow: 0 3 10px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3 10px rgba(0, 0, 0, 0.16);
  background: #6a88cf;
  background: -webkit-gradient(linear, left top, left bottom, from(#6a88cf), to(#4a5bcb));
  background: linear-gradient(to bottom, #6a88cf 0%, #4a5bcb 100%);
  position: relative;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  outline: none;
  border: none;
  cursor: pointer;
}
.form-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.form-btn--back {
  text-align: center;
  text-decoration: underline;
}
.form-btn:link, .form-btn:visited {
  color: #fff;
  text-decoration: none;
}
.form-btn:hover {
  opacity: 0.65;
  text-decoration: none;
}

.parsley-errors-list {
  display: block;
  color: #cb6fc2;
  font-size: 0.85em;
  line-height: 1.8;
}

.errormsg {
  display: block;
}

html {
  overflow-x: hidden;
}

.floor-map-canvas {
  position: relative;
}

.map-scroll {
  width: 100%;
  overflow-x: scroll;
  display: none;
  position: relative;
}

.map-active {
  display: block;
}

.map-scroll img {
  position: relative;
}

.map-controller {
  position: fixed;
  bottom: 0px;
  left: 0;
  width: 100%;
  height: 60px;
  background-color: #fff;
  z-index: 88;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.map-controller-btn {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  height: 60px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.floor-active {
  position: relative;
}

.floor-active:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background-color: #000;
}

.floor-map-label {
  position: fixed;
  z-index: 88;
  top: 60px;
  left: 0;
  width: 100px;
  height: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #325CD1;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
}

.floor-map-label div {
  width: 30%;
  text-align: center;
}

.floor-map-floor {
  margin-left: 15%;
}

.floor-map-area {
  margin-right: 15%;
}

/* *** map-slider *****/
.map-slider {
  border: 2px #325CD1 solid;
  border-radius: 6px;
  width: 80px;
  height: 40px;
  position: fixed;
  right: 10px;
  bottom: 90px;
  background-color: #fff;
  display: grid;
  grid-template-columns: 1fr 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 100;
}

.map-slider-btn {
  position: relative;
  height: 40px;
}

.map-slider-btn:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  height: 10px;
  width: 10px;
  margin-top: -7px;
  margin-left: -5px;
}

.slider-btn-prev:after {
  border-top: 1px #000 solid;
  border-left: 1px #000 solid;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.slider-btn-next:after {
  border-top: 1px #000 solid;
  border-right: 1px #000 solid;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.slider-btn-active:after {
  border-color: #bbb;
}

.friends_wrap .curved_up {
  background: #fff;
}

.friends_grid {
  position: relative;
  text-align: left;
  width: var(--width);
  max-width: 1000px;
  margin: 2.5em auto 2.5em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 40px;
  /* アイテム間の隙間 */
}

.friends_box {
  width: 100%;
  max-width: 234px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* 1行目：4つのアイテム */
.friends_grid .friends_box:nth-child(-n+4) {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 22%;
          flex: 1 1 22%;
  /* 4つのアイテムを22%幅で表示 */
}

/* 2行目：3つのアイテム */
.friends_grid .friends_box:nth-child(n+5):nth-child(-n+7) {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 30%;
          flex: 1 1 30%;
  /* 3つのアイテムを30%幅で表示 */
}

/* 3行目：4つのアイテム */
.friends_grid .friends_box:nth-child(n+8):nth-child(-n+11) {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 22%;
          flex: 1 1 22%;
  /* 4つのアイテムを22%幅で表示 */
}

/* 4行目：2つのアイテム */
.friends_grid .friends_box:nth-child(n+12):nth-child(-n+12) {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 45%;
          flex: 1 1 45%;
  /* 2つのアイテムを45%幅で表示 */
}

.friends_grid .friends_box {
  text-decoration: none;
  text-align: center;
}
.friends_grid .friends_box .post_box {
  margin-bottom: 0.5em;
}
.friends_grid .friends_box .name {
  font-size: clamp(1.8rem, 1.138rem + 1.38vw, 2rem);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.friends_grid .friends_box .add {
  font-size: 1.2rem;
  font-weight: 500;
}

@media screen and (max-width: 960px) {
  .friends_grid {
    max-width: initial;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px;
    padding: 0 1em;
  }
  .friends_box {
    max-width: 100%;
  }
}
.friend_single {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 40px;
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
          box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
  border-radius: 20px;
  margin: 1em auto 1.5em;
}
.friend_single .thumb .post_trim {
  border-radius: 20px;
  overflow: hidden;
}
.friend_single .summary {
  padding: 1em;
}
.friend_single .summary h1 {
  font-size: clamp(2.1rem, -2.4rem + 9.38vw, 3.6rem);
  font-weight: 500;
  margin-bottom: 0.8em;
}
.friend_single .summary .textblock p {
  font-size: 1.4rem;
  line-height: 1.8;
}
.friend_single .summary .textblock p:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 960px) {
  .friend_single {
    grid-template-columns: 1fr;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    gap: 20px;
  }
  .friend_single .thumb .post_trim {
    border-radius: 20px 20px 0 0;
    overflow: hidden;
  }
  .friend_single .summary {
    padding: 1em 2em;
  }
}
.spots_grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(218px, 1fr));
  gap: 60px 20px;
  margin-top: 3em;
}
.spots_grid .spots_box {
  text-decoration: none;
}
.spots_grid .spots_box:nth-child(2n) {
  -webkit-transform: translateY(40px);
          transform: translateY(40px);
}
.spots_grid .spots_box .post_box {
  margin-bottom: 0.5em;
  border-radius: 10px;
  overflow: hidden;
}
.spots_grid .spots_box .post_box .post_length {
  aspect-ratio: 219/283;
}
.spots_grid .spots_box .post_box::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background: transparent linear-gradient(359deg, #000 0%, rgba(0, 0, 0, 0) 100%) 0% 0% no-repeat padding-box;
  opacity: 0.2;
  z-index: 1;
}
.spots_grid .spots_box .overview {
  padding: 0.4em 0;
}
.spots_grid .spots_box .overview h2 {
  font-size: clamp(1.4rem, 1.255rem + 0.73vw, 1.8rem);
  font-weight: 500;
  line-height: 1.4;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  margin-bottom: 0.5em;
}
.spots_grid .spots_box .overview .place,
.spots_grid .spots_box .overview .time {
  font-size: 1.3rem;
  line-height: 1.4;
}

@media screen and (max-width: 960px) {
  .spots_grid {
    position: relative;
    display: grid;
    gap: 30px 16px;
  }
  .spots_grid .spots_box {
    text-decoration: none;
  }
  .spots_grid .spots_box:nth-last-child(2n) {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}
.story_grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(267px, 1fr));
  gap: 34px;
  margin: 0 auto;
  padding: 5% 0;
  width: 95%;
}
.story_grid .story_box {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
}
.story_grid .story_box .post_length {
  aspect-ratio: 267/367;
}
.story_grid .story_box .overview {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  padding: 1em 2em;
  color: #fff;
}
.story_grid .story_box .overview h2 {
  font-size: clamp(1.6rem, 0.711rem + 1.85vw, 2.1rem);
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: 1em;
}

@media screen and (max-width: 960px) {
  .story_grid {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
}
.performance_s_wrap .flex_content {
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
  box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.04);
  border-radius: 20px;
  padding: 1.5em;
}
.performance_s_wrap .flex_content .spec_table {
  margin-bottom: 1em;
}
.performance_s_wrap .flex_content .flex_summary h2 {
  position: relative;
  font-size: clamp(1.8rem, 1.267rem + 1.11vw, 2.1rem);
  color: #111;
  font-weight: 500;
  line-height: 1.45;
  margin: 0 0 0.8em 0;
}
.performance_s_wrap .flex_content .flex_summary .textblock {
  margin-bottom: 1em;
}
.performance_s_wrap .flex_content .flex_summary .textblock p {
  font-size: 1.4rem;
  line-height: 1.7;
}

.box_newslink_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
}
.box_newslink_grid .box_newslink {
  background-color: #fff;
  border-radius: 10px;
  border: 1px solid rgba(50, 92, 209, 0.2);
  padding: 1.3em;
  height: 120px;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.box_newslink_grid .box_newslink:hover {
  color: #325CD1;
  border: 1px solid #325CD1;
}
.box_newslink_grid .box_newslink .title {
  font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
  font-weight: 500;
  line-height: 1.54;
  margin-bottom: 0.6em;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.box_newslink_grid .box_newslink .overview {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.2rem;
}

.box_guidelink_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 30px;
}
.box_guidelink_grid li,
.box_guidelink_grid .guide_list_box {
  position: relative;
  display: block;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  text-decoration: none;
  padding: 0.5em 1em 1em;
}
.box_guidelink_grid li:hover,
.box_guidelink_grid .guide_list_box:hover {
  color: #325CD1;
}
.box_guidelink_grid li:hover span,
.box_guidelink_grid .guide_list_box:hover span {
  color: #325CD1;
}
.box_guidelink_grid li::after,
.box_guidelink_grid .guide_list_box::after {
  position: absolute;
  top: 50%;
  right: 12px;
  content: "";
  width: 7px;
  height: 7px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.box_guidelink_grid li .name,
.box_guidelink_grid .guide_list_box .name {
  font-size: clamp(1.6rem, 1.564rem + 0.18vw, 1.7rem);
  font-weight: 500;
  margin-bottom: 0.2em;
}
.box_guidelink_grid li span,
.box_guidelink_grid .guide_list_box span {
  font-size: clamp(1.3rem, 1.264rem + 0.18vw, 1.4rem);
  color: rgba(0, 0, 0, 0.5411764706);
}

@media screen and (max-width: 960px) {
  .box_newslink_grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .box_guidelink_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px 30px;
  }
}
.box_bloglink_grid {
  margin-top: 4em;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 20px 30px;
}
.box_bloglink_grid .bloglink {
  border: 1px solid rgba(50, 92, 209, 0.2);
  border-radius: 9999px 9999px 9999px 0;
  overflow: hidden;
}
.box_bloglink_grid .swiper-item:nth-last-child(2n) {
  -webkit-transform: translateY(-40px);
          transform: translateY(-40px);
}
.box_bloglink_grid .overview {
  padding: 1em 0.1em;
  text-align: left;
}
.box_bloglink_grid .overview h2 {
  font-size: clamp(1.4rem, 1.255rem + 0.73vw, 1.8rem);
  font-weight: 500;
  line-height: 1.4;
  margin-bottom: 0.8em;
}
.box_bloglink_grid .overview .data {
  color: rgba(0, 0, 0, 0.5411764706);
  font-size: 1.2rem;
}

@media screen and (max-width: 960px) {
  .box_bloglink_grid {
    margin-top: 4em;
  }
  .box_bloglink_grid .swiper-item:nth-last-child(2n) {
    -webkit-transform: translateY(-20px);
            transform: translateY(-20px);
  }
}
.topics_archives {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  margin-bottom: 2em;
}

.topics_wrap {
  position: relative;
  width: 100%;
  height: auto;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  border-radius: 10px;
  overflow: hidden;
}
.topics_wrap .postsbox {
  position: relative;
  display: block;
  z-index: 2;
}
.topics_wrap .postsbox::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background: transparent linear-gradient(359deg, #000 0%, rgba(0, 0, 0, 0) 100%) 0% 0% no-repeat padding-box;
  opacity: 0.6;
  z-index: 1;
}
.topics_wrap .data {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: #0808B8;
  color: #fff;
  font-size: clamp(1.1rem, 1.064rem + 0.18vw, 1.2rem);
  padding: 0.6em 1.8em;
}
.topics_wrap .overview {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  padding: 1em;
}
.topics_wrap .overview h2 {
  font-size: clamp(1.4rem, 1.255rem + 0.73vw, 1.8rem);
  line-height: 1.4;
  color: #fff;
}

.interview_wrap {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 40px;
  row-gap: 80px;
  margin: 0 auto 4em;
}
.interview_wrap .title {
  font-size: clamp(1.4rem, 1.145rem + 1.27vw, 2.1rem);
  font-weight: 600;
}
.interview_wrap .job {
  font-size: clamp(1.2rem, 1.164rem + 0.18vw, 1.3rem);
  margin-bottom: 1em;
}
.interview_wrap .interview_link:nth-last-child(2n) {
  -webkit-transform: translateY(-40px);
          transform: translateY(-40px);
}
.interview_wrap .interview_link .post_box {
  position: relative;
  overflow: hidden;
  margin-bottom: 10px;
}
.interview_wrap .interview_link .post_box .year_etc {
  position: absolute;
  top: 20px;
  left: 30px;
  z-index: 2;
}
.interview_wrap .interview_link .post_box .year_etc .year {
  position: relative;
  font-size: clamp(1.4rem, 1.145rem + 1.27vw, 2.1rem);
  font-weight: 600;
  margin-bottom: 0.2em;
  padding-right: 34px;
}
.interview_wrap .interview_link .post_box .year_etc .year::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 17px;
  height: 2px;
  background-color: #325CD1;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.interview_wrap .interview_link .post_box .year_etc .year::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  width: 12px;
  height: 12px;
  border-top: solid 2px #325CD1;
  border-right: solid 2px #325CD1;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.interview_wrap .interview_link .post_box .year_etc .type {
  font-size: clamp(1.2rem, 1.164rem + 0.18vw, 1.3rem);
}

@media screen and (max-width: 960px) {
  .interview_wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    row-gap: 60px;
    margin: 0 auto 4em;
  }
  .interview_wrap .interview_link .post_box .year_etc {
    position: absolute;
    top: 0px;
    left: 0px;
    z-index: 2;
  }
  .interview_wrap .interview_link .post_box .year_etc .year {
    margin-bottom: 0.2em;
    padding-right: 34px;
  }
}
:root {
  --easing: cubic-bezier(.2, 1, .2, 1);
  --transition: .8s var(--easing);
  --btnover: .2s ease-in;
  --border: 1px solid rgba(0, 0, 0, .3);
}

.center {
  margin: 1.5em auto 3em;
  display: grid;
  place-content: center;
}

.text {
  margin-bottom: 2.5em;
}

.uptext {
  margin-bottom: 4em;
}

@media screen and (max-width: 960px) {
  .text,
  .uptext {
    margin-bottom: 1.5em;
  }
}
.boxes {
  border: 1px solid rgba(50, 92, 209, 0.2);
  border-radius: 10px;
  margin-bottom: 3em;
  padding: 2em 2.5em;
}

.boxes_other {
  border: 1px solid rgba(50, 92, 209, 0.2);
  border-radius: 10px;
  margin-bottom: 1em;
  padding: 2em 2.5em;
}
.boxes_other h2 {
  font-size: clamp(2.1rem, 1.773rem + 1.64vw, 3rem);
}
.boxes_other li {
  margin-bottom: 0.5em;
}

body {
  counter-reset: number 0;
}

.boxes_policy {
  border: 1px solid rgba(50, 92, 209, 0.2);
  border-radius: 10px;
  margin-bottom: 3em;
}
.boxes_policy h2 {
  font-size: clamp(1.8rem, 1.655rem + 0.73vw, 2.2rem);
  font-weight: 500;
  border-bottom: 1px solid rgba(50, 92, 209, 0.2);
  padding: 1em 1.5em;
}
.boxes_policy .overview {
  padding: 2em 2em;
  font-weight: 400;
}
.boxes_policy .num_policy {
  font-family: "Inter", sans-serif;
  font-size: clamp(3.2rem, 2.545rem + 3.27vw, 5rem);
  font-weight: 500;
  margin-right: 1.2em;
}
.boxes_policy .num_policy:before {
  counter-increment: number 1;
  content: counter(number) ".";
}

.block_one_wrap {
  margin: 0 auto 1.5em;
}
.block_one_wrap .post_box {
  margin: 0 -15% 0;
}
.block_one_wrap .post_box .post_trim {
  aspect-ratio: 16/6;
  border-radius: 20px 20px 0 0;
}

.storyintro_wrap {
  position: relative;
}
.storyintro_wrap .stroy_icatch {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
  width: 340px;
  height: 500px;
}
.storyintro_wrap .post_length {
  aspect-ratio: 340/500;
  overflow: hidden;
  border-radius: 20px;
}
.storyintro_wrap .storyInfo {
  position: relative;
  margin-bottom: 2em;
  padding-right: 390px;
}
.storyintro_wrap .storyInfo h1 {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(2rem, -0.133rem + 4.44vw, 3.2rem);
  line-height: 1.5;
  font-weight: 500;
}

@media screen and (max-width: 960px) {
  .storyintro_wrap {
    position: relative;
    display: grid;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    margin-bottom: 2em;
  }
  .storyintro_wrap .storyInfo {
    position: relative;
    margin-bottom: 2em;
    padding-right: 0;
  }
  .storyintro_wrap .stroy_icatch {
    position: relative;
    bottom: auto;
    right: auto;
    z-index: 1;
    width: auto;
    height: auto;
  }
  .storyintro_wrap .post_length {
    aspect-ratio: 200/210;
    overflow: hidden;
    border-radius: 20px;
  }
}
.retrun {
  margin: 3em auto 3em;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  margin-inline: auto;
}
.retrun a {
  position: relative;
  display: inline-block;
  font-weight: 500;
  color: #325CD1;
  background-color: #fff;
  padding: 16px 40px 16px 40px;
  border-radius: 9999px;
  text-decoration: none;
  -webkit-transition: var(--transition);
  transition: var(--transition);
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-align: center;
}
.retrun a::after {
  position: absolute;
  top: 50%;
  left: 16px;
  content: "";
  width: 8px;
  height: 8px;
  border-top: solid 1px #325CD1;
  border-right: solid 1px #325CD1;
  -webkit-transform: translate(0%, -50%) rotate(225deg);
          transform: translate(0%, -50%) rotate(225deg);
}
.retrun a:hover {
  color: #6E8FE5;
  border: solid 1px #6E8FE5;
}
.retrun a:hover::after {
  border-top: solid 1px #6E8FE5;
  border-right: solid 1px #6E8FE5;
}

@media screen and (max-width: 960px) {
  .retrun {
    margin: 2em auto;
  }
  .retrun a {
    width: 100%;
  }
}
.fadeUp {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.fadeLeft {
  -webkit-animation-name: fadeLeftAnime;
          animation-name: fadeLeftAnime;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@keyframes fadeLeftAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(-20px);
            transform: translateX(-20px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
.fadeRight {
  -webkit-animation-name: fadeRightAnime;
          animation-name: fadeRightAnime;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeRightAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(20px);
            transform: translateX(20px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes fadeRightAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(20px);
            transform: translateX(20px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/*　画像の拡大　*/
.zoomIn .coverFit {
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: var(--transition);
  transition: var(--transition);
}

a:hover .zoomIn .coverFit {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}

/*　画像のマスク　*/
.mask {
  display: block;
  line-height: 0;
  overflow: hidden;
}

.imgs {
  margin-bottom: 0.8em;
}

.ph_caption {
  margin: 0.6em 0;
  font-size: clamp(1.4rem, 1.069rem + 0.69vw, 1.5rem);
  line-height: 1.5;
}

.single_text {
  position: relative;
  margin-top: 0;
  margin-bottom: 3.5em;
}
.single_text h1 {
  font-size: clamp(2.8rem, 2.364rem + 2.18vw, 4rem);
  font-weight: 700;
  margin: 0 0 0.5em;
}
.single_text .textinner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}
.single_text .textinner .date {
  color: #fff;
  background-color: #325CD1;
  font-size: clamp(1.1rem, 1.064rem + 0.18vw, 1.2rem);
  border-radius: 9999px;
  padding: 8px 12px;
}
.single_text .textinner .cate {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
}
.single_text .textinner .cate li {
  color: #fff;
  background-color: #325CD1;
  font-size: clamp(1.1rem, 1.064rem + 0.18vw, 1.2rem);
  border-radius: 9999px;
  padding: 8px 12px;
}
.single_text .textinner .procate {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
}
.single_text .textinner .procate li {
  color: #fff;
  background-color: #6E8FE5;
  font-size: clamp(1.1rem, 1.064rem + 0.18vw, 1.2rem);
  border-radius: 9999px;
  padding: 8px 12px;
}

.post_info {
  position: relative;
  margin: 0 auto 3em;
}
.post_info .date {
  color: #585858;
  font-size: clamp(1.4rem, 0.908rem + 1.03vw, 1.6rem);
  line-height: 1.5;
}

.post_icatch {
  margin-bottom: 4.5em;
}
.post_icatch .post_box {
  border-radius: 0 0 20px 20px;
  overflow: hidden;
}

.grid_flex {
  display: grid;
  margin-top: 2em;
  margin-bottom: 2.2em;
}
.grid_flex .box h2 {
  position: relative;
  font-size: clamp(1.6rem, 1.527rem + 0.36vw, 2.1rem);
  font-weight: 500;
  line-height: 1.45;
  margin: 0 0 1em 0;
  color: #325CD1;
}
.grid_flex .box.bg_color {
  background-color: #EAEFFB;
  overflow: hidden;
  border-radius: 10px;
  padding: 2em;
}
.grid_flex .box.bg_color h2 {
  position: relative;
  font-size: clamp(2.4rem, 2.182rem + 1.09vw, 3rem);
  font-weight: 700;
  line-height: 1.45;
  margin: 0 0 0.8em 0;
  color: #325CD1;
}
.grid_flex .post_box {
  overflow: hidden;
  border-radius: 10px;
  margin-bottom: 0.8em;
}
.grid_flex .post_box .post_trim {
  aspect-ratio: 16/9;
}
.grid_flex .post_box .post_square {
  overflow: hidden;
  border-radius: 10px;
}
.grid_flex.ph_2column {
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.grid_flex.ph_3column {
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
}
.grid_flex.ph_friends_sub {
  grid-template-columns: 1fr 1fr 1fr;
  gap: 40px;
}
.grid_flex.ph_4column {
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 10px;
}

@media screen and (max-width: 960px) {
  .grid_flex {
    display: grid;
    margin-bottom: 2em;
  }
  .grid_flex.ph_1column {
    display: block;
  }
  .grid_flex.ph_2column {
    grid-template-columns: 1fr;
  }
  .grid_flex.ph_3column {
    grid-template-columns: 1fr;
  }
  .grid_flex.ph_friends_sub {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .grid_flex.ph_4column {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
}
.btn_grid {
  display: grid;
  margin: 1em auto 1.5em;
}
.btn_grid.is_one {
  grid-template-columns: 1fr;
  place-content: center;
  width: 100%;
  gap: 20px;
}
.btn_grid.is_one a {
  max-width: 70%;
  margin: 0 auto;
}
.btn_grid.is_two {
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.btn_one_left {
  margin: 1em auto 1em;
}
.btn_one_left a {
  max-width: 60%;
}

.btn_one_right {
  margin: 1em auto 1em;
  display: grid;
  justify-items: end;
}
.btn_one_right a {
  max-width: 60%;
}

.btn_grid:not(.btn_grid + .btn_grid) {
  margin-bottom: 1em;
}

.btn_grid + .btn_grid {
  margin-top: 0;
  margin-bottom: 2.5em;
}

@media screen and (max-width: 960px) {
  .btn_grid.is_one {
    width: 100%;
    max-width: initial;
    gap: 16px;
  }
  .btn_grid.is_one a {
    max-width: 80%;
    margin: 0 auto;
  }
  .btn_grid.is_two {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .btn_one_left {
    margin: 1em auto 1em;
  }
  .btn_one_left a {
    max-width: 80%;
  }
  .btn_one_right {
    margin: 1em auto 1em;
    display: grid;
    justify-items: end;
  }
  .btn_one_right a {
    max-width: 80%;
  }
}
.arrow_all {
  position: relative;
  display: inline-block;
  padding: 20px 130px;
  font-size: clamp(1.4rem, 0.8rem + 1.25vw, 1.6rem);
  color: #fff;
  text-decoration: none;
  outline: none;
  z-index: 1;
  font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
  font-weight: 500;
  border-radius: 10px;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
  border: 1px solid #fff;
}

.arrow_link {
  position: relative;
  display: inline-block;
  padding: 16px 50px 16px 24px;
  font-size: clamp(1.4rem, 0.8rem + 1.25vw, 1.6rem);
  font-weight: 500;
  color: #111;
  text-decoration: none;
  outline: none;
  z-index: 1;
  background-color: #fff;
  border-radius: 10px;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
  border: 1px solid rgba(0, 0, 0, 0.1);
}
.arrow_link:hover::before {
  right: 12px;
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.arrow_link:hover::after {
  right: 12px;
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.arrow_link:link {
  text-decoration: none;
}
.arrow_link.is_w100 {
  width: 100%;
}
.arrow_link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #111;
  border-right: solid 2px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.arrow_link.bg_white {
  color: #111;
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, 0.1);
}
.arrow_link.bg_white::before {
  background-color: #325CD1;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.arrow_link.bg_white::after {
  border-top: solid 2px #111;
  border-right: solid 2px #111;
}

.arrow_icon {
  position: relative;
  display: inline-block;
  padding: 16px 50px 16px 24px;
  font-size: clamp(1.4rem, 0.8rem + 1.25vw, 1.6rem);
  font-weight: 500;
  color: #111;
  text-decoration: none;
  outline: none;
  z-index: 1;
  background-color: #fff;
  border-radius: 10px;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
  border: 1px solid rgba(0, 0, 0, 0.1);
  margin-bottom: 0.5em;
}
.arrow_icon:link {
  text-decoration: none;
}
.arrow_icon::after {
  position: absolute;
  top: 50%;
  right: 18px;
  content: "";
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
  width: 29px;
  height: 29px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.arrow_icon:hover::after {
  right: 12px;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.arrow_icon.is_w100 {
  width: 100%;
}
.arrow_icon.is_site {
  position: relative;
}
.arrow_icon.is_site::after {
  background: url("../img/module/icon/icon_site.svg") no-repeat 100% 50%;
  background-size: 16px auto;
}
.arrow_icon.is_pdf {
  position: relative;
}
.arrow_icon.is_pdf::after {
  background: url("../img/module/icon/icon_pdf.svg") no-repeat 100% 50%;
  background-size: 16px auto;
}
.arrow_icon.is_doc {
  position: relative;
}
.arrow_icon.is_doc::after {
  background: url("../img/module/icon/icon_doc.svg") no-repeat 100% 50%;
  background-size: contain;
}
.arrow_icon.is_xls {
  position: relative;
}
.arrow_icon.is_xls::after {
  background: url("../img/module/icon/icon_xls.svg") no-repeat 100% 50%;
  background-size: contain;
}

.arrow_mail {
  position: relative;
  display: inline-block;
  padding: 28px 92px;
  color: #325CD1;
  background-color: #fff;
  text-decoration: none;
  border-radius: 8px;
  text-align: center;
  font-size: clamp(1.7rem, 1.454rem + 0.51vw, 1.8rem);
  font-weight: 500;
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
  border: 3px solid #fff;
  overflow: hidden;
}
.arrow_mail span {
  position: relative;
  z-index: 3;
}
.arrow_mail span::after {
  position: absolute;
  top: 50%;
  left: -38px;
  content: url(../img/module/icon/icon_mail_bl.svg);
  width: 28px;
  height: 28px;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
.arrow_mail:hover {
  border: 3px solid #000;
  background-color: #325CD1;
}
.arrow_mail:hover span {
  color: #fff;
}
.arrow_mail:hover span::after {
  content: url(../img/module/icon/icon_mail_w.svg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
  -webkit-transform: translate(0%, -50%) rotate(10deg);
          transform: translate(0%, -50%) rotate(10deg);
}

@media screen and (max-width: 960px) {
  .arrow_mail {
    position: relative;
    display: block;
  }
}
.boxes_pages {
  position: relative;
  width: 90%;
  min-height: 120px;
  display: grid;
  grid-template-columns: 180px 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, 0.1);
  margin: 0.8em auto 1.6em;
  border-radius: 10px;
  overflow: hidden;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.boxes_pages .flex_img {
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
.boxes_pages .flex_img.contain {
  background-size: auto 80%;
  background-color: #f5f5f5;
}
.boxes_pages .flex_container {
  position: relative;
  padding: 1em 2em 1em 0.5em;
}
.boxes_pages .flex_container h2 {
  font-size: clamp(1.8rem, 1.691rem + 0.55vw, 2.1rem);
  line-height: 1.5;
  font-weight: 500;
  margin-bottom: 0.5em;
}
.boxes_pages .flex_container p {
  font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
  line-height: 1.5;
  color: #707070;
  margin-bottom: 0;
}
.boxes_pages .flex_container::after {
  position: absolute;
  top: 50%;
  right: 22px;
  content: "";
  width: 12px;
  height: 12px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.boxes_pages .boxes_text h2 {
  font-size: clamp(1.8rem, 1.691rem + 0.55vw, 2.1rem);
  line-height: 1.5;
  font-weight: 500;
  margin-bottom: 0.5em;
}
.boxes_pages .boxes_text p {
  font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
  line-height: 1.5;
  margin-bottom: 0;
}
.boxes_pages:hover {
  border: 1px solid #325CD1;
}
.boxes_pages:hover .flex_container::after {
  right: 18px;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}

@media screen and (max-width: 960px) {
  .boxes_pages {
    position: relative;
    width: 100%;
    min-height: initial;
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .boxes_pages .flex_img {
    width: 100%;
    height: 100%;
    aspect-ratio: 3/2;
  }
  .boxes_pages .flex_container {
    padding: 0em 2em 1em 1em;
  }
}
.list_box a {
  display: block;
  background-color: #fff;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.list_box a .zoomIn {
  margin-bottom: 0.7em;
}
.list_box a:hover .title {
  color: #353535;
}
.list_box a:hover .text p {
  color: #353535;
}
.list_box .text {
  position: relative;
  padding-right: 2em;
}
.list_box .text p {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.list_box .text::after {
  position: absolute;
  top: 50%;
  right: 0;
  content: "";
  width: 12px;
  height: 12px;
  border-top: solid 2px #111;
  border-right: solid 2px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.list_box .title {
  position: relative;
  color: #111;
  font-size: clamp(2.2rem, 1.215rem + 2.05vw, 2.6rem);
  font-weight: 700;
  margin-bottom: 0.3em;
}

.list_box_one {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 40px;
  margin: 1em auto 2.5em;
  background-color: #fff;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.list_box_one .zoomIn {
  margin-bottom: 0.7em;
}
.list_box_one:hover .title {
  color: #353535;
}
.list_box_one:hover .text p {
  color: #353535;
}
.list_box_one .text {
  position: relative;
  padding-right: 2em;
}
.list_box_one .text p {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.list_box_one .text::after {
  position: absolute;
  top: 50%;
  right: 0;
  content: "";
  width: 12px;
  height: 12px;
  border-top: solid 2px #111;
  border-right: solid 2px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.list_box_one .title {
  color: #111;
  font-size: clamp(1.8rem, -0.169rem + 4.1vw, 2.6rem);
  font-weight: 700;
  margin-bottom: 0.3em;
}

@media screen and (max-width: 960px) {
  .list_box_one {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 30px;
    margin: 1em auto 2.5em;
  }
  .list_box_one .zoomIn {
    margin-bottom: 0.7em;
  }
  .list_box_one .title {
    color: #111;
    font-size: clamp(2.2rem, 1.215rem + 2.05vw, 2.6rem);
    font-weight: 700;
    margin-bottom: 0.3em;
  }
}
hr {
  margin: 2em auto;
  border-color: 1px solid rgba(0, 0, 0, 0.3);
}

.field {
  margin-top: 0;
  margin-bottom: 1.2em;
}
.field.is_mar {
  margin-bottom: 40px;
}
.field:last-child {
  margin-bottom: 1%;
}
.field::after {
  clear: both;
  content: "";
  display: block;
}

@media screen and (max-width: 960px) {
  .field.is_mar {
    margin-bottom: 40px;
  }
}
.inner {
  padding: 1% 4%;
}

.innerBlock {
  padding: 0 10%;
}

.innerBlockLarge {
  padding: 0% 20%;
}

.headings_center_1 {
  position: relative;
  font-size: clamp(2.8rem, 2rem + 4vw, 5rem);
  font-weight: 700;
  line-height: 1.45;
  margin: 0.6em 0 1.2em;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  margin-inline: auto;
}
.headings_center_1:after {
  content: "";
  position: absolute;
  bottom: -10px;
  display: inline-block;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  margin-inline: auto;
  width: 150px;
  height: 4px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background-color: #325CD1;
}

.headings_display_1 {
  position: relative;
  font-size: clamp(2.2rem, 1.714rem + 1.01vw, 2.6rem);
  color: #325CD1;
  font-weight: 400;
  line-height: 1.45;
  margin: 0.8em 0;
}

.headings_display_2 {
  position: relative;
  font-size: clamp(1.9rem, 1.657rem + 0.51vw, 2.1rem);
  font-weight: 500;
  line-height: 1.45;
  color: #111;
  margin: 0 0 0.8em 0;
}

.headings_display_3 {
  font-size: clamp(1.6rem, 1.527rem + 0.36vw, 1.8rem);
  font-weight: 500;
  color: #325CD1;
  margin: 0 0 1.2em 0;
}
.headings_display_3.txtblack {
  color: #111;
}

.headings_display_4 {
  font-size: clamp(1.5rem, 1.144rem + 0.74vw, 1.7rem);
  font-weight: 500;
  color: #111;
  line-height: 1.45;
  margin: 0 0 0.8em 0;
  padding: 0.8em;
  border-radius: 8px;
  border: 1px solid rgba(0, 0, 0, 0.1);
}

.headings_display_num {
  position: relative;
  font-family: "Inter", sans-serif;
  font-size: clamp(8rem, 7.273rem + 3.64vw, 10rem);
  color: #111;
  font-weight: 500;
  line-height: 1;
  margin: 0 0 0.5em 0;
}

.headings_display_table {
  font-size: clamp(2.1rem, 1.7rem + 2vw, 3.2rem);
  font-weight: 500;
  color: #325CD1;
  margin: 0 0 0.3em 0.3em;
}
.headings_display_table.faqs {
  margin: 3em 0 1.5em 0.3em;
}

.catch {
  font-size: clamp(1.8rem, 3.1vw, 2rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0.8em 0;
  letter-spacing: 0.1em;
}

.textblock {
  margin: 0.4em auto 2.5em;
}
.textblock.bold {
  font-weight: 700;
}
.textblock.text_center {
  text-align: center;
}
.textblock p:last-child {
  margin-bottom: 0;
}

/* map youtube */
.iframe_flex {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  margin: 0 auto 2.5em;
}
.iframe_flex .iframeBlock {
  border-radius: 10px;
  overflow: hidden;
  margin: 0;
}
.iframe_flex .iframe_summary h2 {
  font-size: clamp(2.4rem, 2.182rem + 1.09vw, 3rem);
}

@media screen and (max-width: 960px) {
  .iframe_flex {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.iframeBlock {
  position: relative;
  width: 100%;
  margin: 0 auto 2.5em;
  padding-bottom: 54.25%;
  padding-top: 30px;
  height: 0;
  border-radius: 10px;
  overflow: hidden;
}
.iframeBlock.ftmap {
  padding-bottom: 28.25%;
}
.iframeBlock iframe,
.iframeBlock object,
.iframeBlock embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 960px) {
  .iframeBlock {
    max-width: initial;
  }
  .iframeBlock.ftmap {
    padding-bottom: 72.25%;
  }
}
.coverFit {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 50%;
     object-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: 50% 50%;
}

.containFit {
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: 50% 50%;
     object-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50% 50%;
  background-color: #efefef;
}

.sizeFit {
  width: 100%;
  height: 50vh;
}

.post_box {
  position: relative;
}
.post_box.ci {
  border-radius: 20px;
  overflow: hidden;
}

/*横長*/
.post_trim {
  position: relative;
  display: block;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 3/2;
}

/*正方形*/
.post_square {
  position: relative;
  display: block;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 1/1;
}

.post_length {
  position: relative;
  display: block;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 2/3;
}

.post_radius {
  position: relative;
  display: block;
  overflow: hidden;
  width: 100%;
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 9999px;
}

.isRadius {
  border-radius: 6px;
  overflow: hidden;
}

.post_wide {
  position: relative;
  display: block;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16/7;
}

.is_full .post_box {
  margin: 0 -5% 1em -5%;
}

.ph_full {
  position: relative;
  display: block;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16/9;
}

@media screen and (max-width: 960px) {
  .img_center {
    margin: 0 auto 10px;
    max-width: 70%;
  }
}
/* --------------------------------
table
-------------------------------- */
table {
  position: relative;
  width: 100%;
  text-align: left;
  margin-top: 1em;
  margin-bottom: 3em;
  border: none;
  font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
}
table th,
table td {
  padding: 1em;
  line-height: 1.6;
}
table.cell2 tr {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
table.cell2 tr:last-child {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
table.cell2 th {
  vertical-align: top;
  text-align: left;
  width: auto;
  min-width: 4em;
}
table.cell3 th,
table.cell3 td {
  width: 20%;
  min-width: 130px;
  padding: 1em;
}
table.cell3 tr {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
table.cell3 tr:last-child {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
table.cell3 th {
  text-align: left;
}
table.cell3 td {
  width: auto;
  padding: 10px 20px;
}
table.free {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
table.free th,
table.free td {
  padding: 1em;
}
table.free tr {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
table.free tr:last-child {
  border-bottom: none;
}
table.free th {
  text-align: left;
  white-space: nowrap;
}
table.free td {
  width: auto;
}
table.free td:nth-last-child(2n+1) {
  background-color: #ECECEC;
  white-space: nowrap;
}

@media screen and (max-width: 960px) {
  .scroll-hint-text {
    margin-top: 0;
  }
  .js-scrollable {
    margin-bottom: 2em;
  }
  table {
    position: relative;
    width: 100%;
    text-align: left;
    border: none;
  }
  table th,
  table td {
    padding: 1em;
  }
  table.cell2 tr {
    display: block;
    width: 100%;
  }
  table.cell2 tr:last-child {
    border-bottom: none;
  }
  table.cell2 th {
    font-weight: 500;
    background-color: #f3f3f3;
  }
  table.cell2 th,
  table.cell2 td {
    display: block;
    width: 100%;
    padding: 0.4em;
  }
  table.cell3 {
    white-space: nowrap;
    margin-bottom: 1em;
  }
  table.cell3 tr:last-child {
    border-bottom: 1px solid rgba(50, 92, 209, 0.2);
  }
  table.free {
    white-space: nowrap;
    margin-bottom: 1em;
  }
  table.free tr:last-child {
    border-bottom: 1px solid rgba(50, 92, 209, 0.2);
  }
}
.textlink {
  margin: 20px auto 20px;
}
.textlink::after {
  clear: both;
  content: "";
  display: block;
}
.textlink a {
  position: relative;
  display: block;
  padding: 18px 30px 18px 18px;
  border: 1px solid rgba(0, 0, 0, 0.1019607843);
  border-radius: 4px;
  text-decoration: none;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
.textlink a::after {
  position: absolute;
  top: 50%;
  right: 14px;
  content: "";
  width: 8px;
  height: 8px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
}
.textlink .link1set {
  margin-bottom: 20px;
}
.textlink .link1set .left_more {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.textlink .link1set .center_more {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 auto;
}
.textlink .link1set .right_more {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.textlink .link2set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 10px;
}
.textlink .link2set .morelink {
  width: 49%;
}
.textlink .link3set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 10px;
}
.textlink .link3set .morelink {
  width: 32%;
}

@media screen and (max-width: 960px) {
  .textlink {
    margin: 20px auto 20px;
  }
  .textlink a {
    position: relative;
    display: block;
    padding: 14px 30px 14px 16px;
    text-decoration: none;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .textlink .link1set {
    margin-bottom: 0.5em;
  }
  .textlink .link1set .left_more {
    display: block;
    width: 100%;
  }
  .textlink .link1set .center_more {
    display: block;
    width: 100%;
  }
  .textlink .link1set .right_more {
    display: block;
    width: 100%;
  }
  .textlink .link2set {
    display: block;
    margin-bottom: 10px;
  }
  .textlink .link2set .morelink {
    width: 100%;
    margin-bottom: 0.5em;
  }
  .textlink .link3set {
    display: block;
    margin-bottom: 10px;
  }
  .textlink .link3set .morelink {
    width: 100%;
  }
}
.return {
  position: relative;
  display: block;
  text-align: center;
  position: relative;
  width: 90%;
  margin: 1em auto;
}
.return a {
  position: relative;
  padding: 12px 24px 12px 24px;
  display: block;
  border: 1px solid rgba(0, 0, 0, 0.1019607843);
  border-radius: 10px;
  background-color: #fff;
  text-decoration: none;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  font-weight: 400;
}
.return a::after {
  position: absolute;
  top: 50%;
  left: 12px;
  content: "";
  width: 8px;
  height: 8px;
  border-top: solid 2px #111;
  border-right: solid 2px #111;
  -webkit-transform: translate(0%, -50%) rotate(225deg);
          transform: translate(0%, -50%) rotate(225deg);
}

.free_layout_wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.free_layout_btn {
  position: relative;
  display: block;
  border: 1px solid rgba(0, 0, 0, 0.1019607843);
  width: 100%;
  height: auto;
  margin: 1.2em auto 1.8em;
  border-radius: 6px;
  overflow: hidden;
  color: #111;
  background-color: #fff;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
.free_layout_btn.hilight {
  border: 1px solid #325CD1;
  background-color: rgba(0, 0, 0, 0.0862745098);
}
.free_layout_btn:hover {
  background-color: rgba(59, 176, 119, 0.1215686275);
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
  border: 1px solid #325CD1;
  color: #325CD1;
}
.free_layout_btn::after {
  position: absolute;
  top: 50%;
  right: 14px;
  content: "";
  width: 8px;
  height: 8px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
}
.free_layout_btn .btn_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.free_layout_btn .btnimg {
  width: 25%;
  aspect-ratio: 3/2;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #fff;
  border-right: 1px solid rgba(0, 0, 0, 0.1);
}
.free_layout_btn .btn_container {
  width: 70%;
  padding: 3% 4%;
}
.free_layout_btn .btn_container .btn_text {
  color: #111;
  text-align: left;
}
.free_layout_btn .btn_container .btn_text .title h2 {
  font-size: clamp(1.8rem, 3.1vw, 2.2rem);
  font-weight: 500;
  margin-bottom: 1em;
}
.free_layout_btn .btn_container .btn_text .info {
  font-size: clamp(1.4rem, 3.1vw, 1.6rem);
  font-weight: 400;
  line-height: 1.6;
  color: rgba(0, 0, 0, 0.5);
}

@media screen and (max-width: 960px) {
  .free_layout_btn {
    width: 100%;
    max-width: initial;
    height: auto;
  }
  .free_layout_btn::after {
    border: none;
  }
  .free_layout_btn .btn_box {
    display: block;
  }
  .free_layout_btn .btnimg {
    width: 100%;
    padding-top: 48%;
  }
  .free_layout_btn .btn_container {
    position: relative;
    width: 100%;
    padding: 4% 24px 4% 4%;
  }
  .free_layout_btn .btn_container::after {
    position: absolute;
    top: 50%;
    right: 10px;
    content: "";
    width: 8px;
    height: 8px;
    border-top: solid 1px #111;
    border-right: solid 1px #111;
    -webkit-transform: translate(0%, -50%) rotate(45deg);
            transform: translate(0%, -50%) rotate(45deg);
  }
  .free_layout_btn .btn_container .btn_text {
    color: #111;
    text-align: left;
  }
  .free_layout_btn .btn_container .btn_text .title h2 br {
    display: none;
  }
  .free_layout_btn .btn_container .btn_text .info {
    font-size: 14px;
  }
}
.boxnolink {
  position: relative;
  border-radius: 10px;
  padding: 1em;
  border: 1px solid rgba(0, 0, 0, 0.1);
}

.boxlink a {
  position: relative;
  border-radius: 10px;
  padding: 1em;
  border: 1px solid rgba(0, 0, 0, 0.1);
  display: block;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.boxlink a:hover {
  border: 1px solid #325CD1;
  background-color: #f5f5f5;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.boxlink .ph_caption {
  font-size: 1.3rem;
  margin-bottom: 0;
}
.boxlink .linkarrow {
  position: relative;
  padding-right: 20px;
}
.boxlink .linkarrow::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 8px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #111;
  border-right: solid 2px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}

.free-layout-album {
  width: 100%;
  margin: 20px auto 40px;
}

.photo-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(112px, 1fr));
  gap: 16px;
  margin: 0;
}
.photo-list .photo-item a {
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.photo-list .photo-item a:hover {
  opacity: 0.8;
  -webkit-transition: var(--btnover);
  transition: var(--btnover);
}
.photo-list .photo-item .photo {
  border-radius: 8px;
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: 50% 50%;
}

.vbox-item {
  display: block;
  width: 100%;
  height: 100%;
}

.vbox-prev span,
.vbox-next span {
  border-top-color: #fff;
  border-right-color: #fff;
}

@media screen and (max-width: 960px) {
  .free-layout-album {
    width: 100%;
  }
  .photo-list {
    display: grid;
    gap: 16px;
    margin: 0;
  }
}
.pagenaviBox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.wp-pagenavi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 3em auto 2em;
}
.wp-pagenavi .page {
  font-size: 18px;
  font-weight: 500;
  font-family: "Outfit", sans-serif;
  line-height: 40px;
  text-align: center;
  height: 40px;
  width: 40px;
  border: 1px solid #dedede;
  background: #fff;
  display: grid;
  place-content: center;
}
.wp-pagenavi .current {
  background: #000;
  color: #fff !important;
  margin: 0 6px;
  font-size: 18px;
  font-weight: 500;
  font-family: "Outfit", sans-serif;
  line-height: 40px;
  text-align: center;
  height: 40px;
  width: 40px;
}

.nextpostslink,
.previouspostslink {
  background: none !important;
  border-top: 2px solid #111;
  border-right: 2px solid #111;
  display: block;
  height: 10px;
  margin: 20px;
  text-indent: 100%;
  overflow: hidden;
  width: 10px;
  white-space: nowrap;
}

.nextpostslink {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.previouspostslink {
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
}

.stepbar {
  margin: 0 auto;
  width: 100%;
}
.stepbar .stepbarwrap {
  margin: 2em 0 3em;
  position: relative;
}
.stepbar .gridstep {
  display: grid;
  grid-template-columns: 250px 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.stepbar .stepbarwrap .steptitle {
  display: grid;
  grid-template-columns: 80px 180px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.stepbar .stepbarwrap .steptitle .title {
  margin: 0.5em;
  font-size: clamp(2.2rem, 0.723rem + 3.08vw, 2.8rem);
  font-weight: 700;
}

.stepbar .stepbarwrap .steptitle .stepcircle {
  display: inline-block;
  width: 70px;
  height: 70px;
  content: "";
  border-radius: 50%;
  background-color: #003C85;
  color: #fff;
  text-align: center;
}
.stepbar .stepbarwrap .steptitle .stepcircle span {
  display: inline-block;
  line-height: 1;
  font-weight: 600;
  position: relative;
  top: 0.8em;
}
.stepbar .stepbarwrap .steptitle .stepcircle span.step {
  font-size: 1.6rem;
  font-weight: 400;
}
.stepbar .stepbarwrap .steptitle .stepcircle span.num {
  font-family: "Outfit", sans-serif;
  display: block;
  font-size: 3rem;
  margin-top: -10px;
}

.stepbar .stepbarwrap .steptxt {
  padding-left: 3em;
}

.stepbar .stepbarwrap .steptxt .text {
  font-size: clamp(1.5rem, 1.254rem + 0.51vw, 1.6rem);
  line-height: 1.6;
}

.stepbar .stepbarwrap .stepline {
  width: 1px;
  height: calc(100% + 6em);
  background-color: #000;
  position: absolute;
  top: 1em;
  left: 35px;
  z-index: -1;
}

.stepbarwrap:last-of-type .stepline:last-of-type {
  display: none;
}

@media screen and (max-width: 960px) {
  .stepbar {
    margin: 0 auto;
    width: 100%;
  }
  .stepbar .stepbarwrap {
    margin: 2em 0 3em;
    position: relative;
  }
  .stepbar .gridstep {
    display: block;
  }
  .stepbar .stepbarwrap .steptitle .stepcircle {
    display: inline-block;
    width: 60px;
    height: 60px;
  }
  .stepbar .stepbarwrap .steptitle .stepcircle span {
    display: inline-block;
    line-height: 1;
    font-weight: 600;
    position: relative;
    top: 0.9em;
  }
  .stepbar .stepbarwrap .steptitle .stepcircle span.step {
    font-size: 1.3rem;
    font-weight: 400;
  }
  .stepbar .stepbarwrap .steptitle .stepcircle span.num {
    font-family: "Outfit", sans-serif;
    display: block;
    font-size: 2rem;
    margin-top: -4px;
  }
  .stepbar .stepbarwrap .steptxt {
    padding-left: 94px;
  }
  .stepbar .stepbarwrap .stepline {
    left: 30px;
  }
}
.report_content {
  position: relative;
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 40px;
  margin-bottom: 2em;
  padding-bottom: 2em;
  border-bottom: 1px solid rgba(50, 92, 209, 0.2);
}
.report_content .flex_ph {
  position: relative;
}
.report_content .flex_ph .post_box {
  overflow: hidden;
  border-radius: 10px;
}
.report_content .flex_summary {
  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: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.report_content .flex_summary .title h2 {
  position: relative;
  font-size: clamp(2rem, 1.636rem + 1.82vw, 3rem);
  font-weight: 700;
  line-height: 1.42;
  margin: 0 0 1.2em 0;
}
.report_content .flex_summary .cal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.report_content .flex_summary .cal .year {
  font-family: "Inter", sans-serif;
  font-size: 1.2rem;
  font-weight: 500;
  margin-right: 1em;
  margin-bottom: 0.3em;
}
.report_content .flex_summary .cal .md {
  font-family: "Inter", sans-serif;
  font-size: clamp(2.4rem, 2.182rem + 1.09vw, 3rem);
  font-weight: 500;
}

@media screen and (max-width: 960px) {
  .report_content {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    margin-bottom: 2em;
    padding-bottom: 2em;
    border-bottom: 1px solid rgba(50, 92, 209, 0.2);
  }
}
.flex_content {
  position: relative;
  display: grid;
  grid-template-columns: 30% 1fr;
  gap: 30px;
  width: 100%;
  margin: 1em auto 3em;
}
.flex_content.reverse {
  grid-template-columns: 1fr 30%;
}
.flex_content.reverse .flex_ph {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.flex_content.reverse .flex_summary {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.flex_content.w50 {
  grid-template-columns: 1fr 1fr;
}
.flex_content.w50.reverse {
  grid-template-columns: 1fr 1fr;
}
.flex_content.w50.reverse .flex_ph {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.flex_content.w50.reverse .flex_summary {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.flex_content .flex_ph {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  position: relative;
}
.flex_content .flex_ph .post_box {
  overflow: hidden;
  border-radius: 10px;
}
.flex_content .flex_summary {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.flex_content .flex_summary .text {
  margin-bottom: 1em;
}
.flex_content .flex_summary h2 {
  position: relative;
  font-size: clamp(1.8rem, 1.557rem + 0.51vw, 2rem);
  font-weight: 400;
  line-height: 1.42;
  margin: 0 0 0.8em 0;
}
.flex_content .flex_summary h3 {
  position: relative;
  font-size: clamp(1.4rem, 1.527rem + 0.36vw, 1.6rem);
  font-weight: 400;
  line-height: 1.45;
  margin: 0 0 0.8em 0;
}

@media screen and (max-width: 960px) {
  .flex_content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    width: 100%;
    max-width: initial;
  }
  .flex_content .flex_summary {
    display: contents;
  }
  .flex_content h2 {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
  }
  .flex_content .flex_ph {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .flex_content .text {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .flex_content .arrow_link,
  .flex_content .arrow_icon {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
  }
  .flex_content.reverse {
    grid-template-columns: 1fr;
  }
  .flex_content.reverse .flex_ph {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .flex_content.w50 {
    grid-template-columns: 1fr;
  }
  .flex_content.w50.reverse {
    grid-template-columns: 1fr;
  }
  .flex_content.w50.reverse .flex_ph {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
.inverse_flex {
  position: relative;
  background-color: #EAEFFB;
  -webkit-box-shadow: 0 0 0 100vmax #EAEFFB;
          box-shadow: 0 0 0 100vmax #EAEFFB;
  clip-path: inset(0 -100vmax);
  margin: 1em auto 3em;
  padding: 2.3em 0;
}
.inverse_flex .flex_content {
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  grid-template-columns: 1fr 50%;
  gap: 60px;
  margin: 0 auto;
}
.inverse_flex.reverse .flex_summary {
  -webkit-box-ordinal-group: 0;
      -ms-flex-order: -1;
          order: -1;
}
.inverse_flex .flex_summary {
  width: 100%;
}

@media screen and (max-width: 960px) {
  .inverse_flex .flex_content {
    display: grid;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    grid-template-columns: 1fr;
    gap: 10px;
    margin: 0 auto;
  }
  .inverse_flex h2 {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
  }
  .inverse_flex .flex_ph {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .inverse_flex .text {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .inverse_flex .flex_summary {
    display: contents;
  }
}
.ph_text_block {
  position: relative;
  display: grid;
  grid-template-columns: 286px 1fr;
  gap: 60px;
  width: 100%;
  margin: 1em auto 3em;
  padding: 2em;
  background-color: #EAEFFB;
  overflow: hidden;
  border-radius: 10px;
}
.ph_text_block.reverse {
  grid-template-columns: 1fr 286px;
}
.ph_text_block.reverse .flex_ph {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.ph_text_block.reverse .flex_summary {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.ph_text_block .flex_ph {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  position: relative;
}
.ph_text_block .flex_ph .post_box {
  overflow: hidden;
  border-radius: 10px;
}
.ph_text_block .flex_summary {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.ph_text_block .flex_summary .subup {
  position: relative;
  font-size: clamp(1.4rem, 1.527rem + 0.36vw, 1.6rem);
  font-weight: 400;
  line-height: 1.45;
  margin: 0 0 0.3em 0;
}
.ph_text_block .flex_summary h2 {
  position: relative;
  font-size: clamp(2.4rem, 2.182rem + 1.09vw, 3rem);
  font-weight: 700;
  line-height: 1.42;
  margin: 0 0 0.5em 0;
}
.ph_text_block .flex_summary .subbottom {
  position: relative;
  font-size: clamp(1.4rem, 1.527rem + 0.36vw, 1.6rem);
  font-weight: 400;
  line-height: 1.45;
  margin: 0 0 2em 0;
}

@media screen and (max-width: 960px) {
  .ph_text_block {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    width: 100%;
    margin: 1em auto 3em;
    padding: 2em;
  }
  .ph_text_block.reverse {
    grid-template-columns: 1fr;
  }
  .ph_text_block.reverse .flex_ph {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .ph_text_block.reverse .flex_summary {
    display: contents;
  }
  .ph_text_block.reverse .flex_summary .subup {
    margin: 0 0 0.2em 0;
  }
  .ph_text_block.reverse .flex_summary h2 {
    margin: 0 0 0.2em 0;
  }
  .ph_text_block.reverse .flex_summary .subbottom {
    margin: 0 0 0.8em 0;
  }
  .ph_text_block.reverse .text {
    margin-top: 1em;
    margin-bottom: 0;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}
summary {
  display: block;
}

summary::-webkit-details-marker {
  /* Safariで表示されるデフォルトの三角形アイコンを消す */
  display: none;
}

details:not(:last-child) {
  margin-bottom: 1.5em;
}

details {
  margin-bottom: 4em;
  border: 1px solid rgba(50, 92, 209, 0.2);
  border-radius: 10px;
}
details summary {
  position: relative;
  list-style: none;
  cursor: pointer;
  padding: 1em;
}
details summary .summary_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
details summary h2 {
  position: relative;
  font-size: clamp(1.8rem, 1.582rem + 1.09vw, 2.2rem);
  font-weight: 400;
  margin: 0 0 0 80px;
  padding: 1em;
  color: #325CD1;
}
details summary h2:before {
  position: absolute;
  display: block;
  width: 46px;
  height: 46px;
  border-radius: 9999px;
  text-align: center;
  content: "Q.";
  font-family: "Inter", sans-serif;
  font-size: 5rem;
  font-weight: 500;
  color: #325CD1;
  top: 50%;
  left: -70px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
details .answer {
  overflow: hidden;
}
details .answer .content_inner {
  position: relative;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  padding: 2em;
}

.icon {
  display: block;
  width: 64px;
  height: 64px;
  border-radius: 9999px;
  position: relative;
  cursor: pointer;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
.icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 17px;
  height: 2px;
  background-color: #325CD1;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 10px;
  height: 10px;
  border-top: solid 2px #325CD1;
  border-right: solid 2px #325CD1;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
}

details.is-opened .icon {
  -webkit-transform: rotate(270deg);
          transform: rotate(270deg);
}

:root {
  --easing: cubic-bezier(.2, 1, .2, 1);
  --transition: .8s var(--easing);
  --color-base: #f8f8f8;
  --color-gray: #ddd;
  --color-theme: #f5695f;
  --color-theme-darken: #f12617;
  --box-shadow: .8rem .8rem 1.2rem rgba(0, 0, 0, .05), -.8rem -.8rem 1.2rem #fff;
  --box-shadow-hover: 1rem 1rem 1.5rem rgba(0, 0, 0, .08), -1rem -1rem 1.5rem #fff;
  --box-shadow-inset: inset .8rem .8rem 1.2rem rgba(0, 0, 0, .05), inset -.8rem -.8rem 1.2rem #fff;
  --box-shadow-dark: .8rem .8rem 1.2rem rgba(0, 0, 0, .1), -.8rem -.8rem 1.2rem rgba(#fff, .2);
}

[class*=swiper]:focus {
  outline: none;
}

.slide-media,
.thumb-media {
  position: relative;
  overflow: hidden;
}

.swiper-button-prev,
.swiper-button-next {
  display: grid;
  place-content: center;
  width: 6.4rem;
  height: 6.4rem;
  cursor: pointer;
  -webkit-transition: var(--transition);
  transition: var(--transition);
}

.swiper-button-prev::before,
.swiper-button-next::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
  border-radius: 50%;
  -webkit-box-shadow: var(--box-shadow);
          box-shadow: var(--box-shadow);
}

.swiper-button-prev::after,
.swiper-button-next::after {
  width: 1.2rem;
  height: 1.2rem;
  content: "";
  border: solid var(--color-gray);
  border-width: 3px 3px 0 0;
}

.swiper-button-prev::after {
  margin-left: 0.4rem;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

.swiper-button-next::after {
  margin-right: 0.4rem;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.swiper-button-disabled {
  pointer-events: none;
  opacity: 0.4 !important;
}

.news_grid {
  position: relative;
  margin-top: 1em;
}
.news_grid .swiper-controller {
  position: absolute;
  right: 40px;
  top: 30px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.news_grid .swiper-button-prev,
.news_grid .swiper-button-next {
  position: relative;
  top: initial;
  display: grid;
  place-content: center;
  width: 3.4rem;
  height: 3.4rem;
  cursor: pointer;
  background-color: #325CD1;
  right: auto;
  left: auto;
  border-radius: 9999px;
}
.news_grid .swiper-button-prev::after,
.news_grid .swiper-button-next::after {
  width: 8px;
  height: 8px;
  content: "";
  border: solid #fff;
  border-width: 2px 2px 0 0;
}
.news_grid .swiper-button-prev::after {
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
}
.news_grid .swiper-button-next::after {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

@media only screen and (max-width: 1024px) {
  .news_grid .swiper-controller {
    position: absolute;
    right: 10px;
    top: 30px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}
@media only screen and (max-width: 1024px) {
  .pc {
    display: none !important;
  }
  .mv01 .slide-media {
    height: max(80vh, 80vw);
  }
}
@media only screen and (max-width: 599px) {
  .pc-tab {
    display: none !important;
  }
}
@media only screen and (min-width: 1025px) {
  .tab-sp {
    display: none !important;
  }
  .swiper-button-prev::before,
  .swiper-button-next::before {
    -webkit-transition: var(--transition);
    transition: var(--transition);
  }
  .swiper-button-prev:hover::before,
  .swiper-button-next:hover::before {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
  }
}
@media only screen and (min-width: 600px) {
  .sp {
    display: none !important;
  }
}
.swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}

@-webkit-keyframes mv01-fadeIn {
  0% {
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
    opacity: 0;
    -webkit-filter: blur(100px);
    filter: blur(100px);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}

@keyframes mv01-fadeIn {
  0% {
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
    opacity: 0;
    -webkit-filter: blur(100px);
    filter: blur(100px);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
.mv01 .swiper-slide .post_trim {
  -webkit-transition: 7s 1s ease-out;
  transition: 7s 1s ease-out;
}

.mv01 .swiper-slide[class*=-active] .post_trim {
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
  -webkit-transform: scale(1.08);
          transform: scale(1.08);
}

.mv01 .swiper-slide[class*=-active] .cimg_l {
  -webkit-animation: mv01-fadeIn 1s 0.5s var(--easing) both;
          animation: mv01-fadeIn 1s 0.5s var(--easing) both;
}

.card_inner {
  position: relative;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  max-width: 1200px;
  margin: 0 auto;
}
.card_inner.right_fade::after {
  content: "";
  display: block;
  position: absolute;
  right: 0%;
  top: 0;
  bottom: 0;
  margin-right: calc(50% - 50vw);
  width: 50vw;
  height: calc(100% + 5px);
  background: transparent -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0)), to(#fff)) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #fff 100%) 0% 0% no-repeat padding-box;
  pointer-events: none;
  z-index: 5;
}
.card_inner.right_fade.story_fade::after {
  background: transparent -webkit-gradient(linear, left top, right top, from(rgba(50, 92, 209, 0)), to(#325CD1)) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, rgba(50, 92, 209, 0) 0%, #325CD1 100%) 0% 0% no-repeat padding-box;
}
.card_inner.right_fade.spots_fade::after {
  background: transparent -webkit-gradient(linear, left top, right top, from(rgba(228, 228, 159, 0)), to(#E4E49F)) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(90deg, rgba(228, 228, 159, 0) 0%, #E4E49F 100%) 0% 0% no-repeat padding-box;
}

.card01 .swiper-slide {
  margin-right: 20px;
}

.card01 {
  overflow: hidden;
  margin-bottom: 5em;
}
.card01 .swiper {
  overflow: visible;
  padding-top: 40px;
}
.card01 .swiper-slide {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
}
.card01 .swiper-slide:nth-last-child(2n) {
  -webkit-transform: translateY(-40px);
          transform: translateY(-40px);
}
.card01 .swiper-item {
  position: relative;
  display: block;
}
.card01 .swiper-item .slide-media {
  border: 1px solid rgba(50, 92, 209, 0.2);
  border-radius: 9999px 9999px 9999px 0;
  overflow: hidden;
}
.card01 .swiper-item .post_trim {
  overflow: hidden;
}
.card01 .swiper-item .overview {
  padding: 1em 0.1em;
  text-align: left;
}
.card01 .swiper-item .overview h2 {
  font-size: clamp(1.4rem, 1.255rem + 0.73vw, 1.8rem);
  font-weight: 500;
  line-height: 1.4;
  margin-bottom: 0.8em;
}
.card01 .swiper-item .overview .data {
  color: rgba(0, 0, 0, 0.5411764706);
  font-size: 1.2rem;
}

.Performance_swiper {
  overflow: hidden;
  margin-bottom: 5em;
}
.Performance_swiper .swiper {
  overflow: visible;
}
.Performance_swiper .swiper-item-group {
  display: grid;
  grid-template-rows: repeat(2, 1fr);
}
.Performance_swiper .swiper-item {
  width: 100%;
  height: 100%;
  display: block;
}
.Performance_swiper .swiper-slide {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
  display: grid;
}
.Performance_swiper .swiper-item {
  position: relative;
  display: block;
}
.Performance_swiper a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 6px;
  height: 6px;
  border-top: solid 1px #111;
  border-right: solid 1px #111;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.Performance_swiper a:hover {
  background-color: rgba(183, 198, 239, 0.2862745098);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.Performance_swiper .box_perlink {
  position: relative;
  border-right: 1px solid rgba(0, 0, 0, 0.1254901961);
  border-bottom: 1px solid rgba(0, 0, 0, 0.1254901961);
  display: grid !important;
  grid-template-columns: minmax(38px, 44px) 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 14px;
  padding: 1em;
}
.Performance_swiper .box_perlink.is_shiro {
  background-color: rgba(50, 92, 209, 0.0588235294);
}
.Performance_swiper .box_perlink.is_holi {
  background-color: #FCDCDC;
}
.Performance_swiper .box_perlink .post_square {
  border-radius: 8px;
  overflow: hidden;
}
.Performance_swiper .box_perlink .summary {
  padding-right: 16px;
}
.Performance_swiper .box_perlink .title {
  font-size: 1.5rem;
  line-height: 1.3;
  margin-bottom: 0;
  font-weight: 500;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.Performance_swiper .box_perlink .overview {
  padding: 0.5em 0.1em 0;
  color: rgba(0, 0, 0, 0.5411764706);
  font-size: 1.2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.Performance_swiper .box_perlink .overview .data {
  color: rgba(0, 0, 0, 0.5411764706);
  font-size: 1.2rem;
}

.news_swiper .swiper-slide {
  margin-right: 20px;
}

.news_swiper {
  overflow: hidden;
  margin-bottom: 5em;
}
.news_swiper .swiper-item-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  gap: 20px;
}
.news_swiper .swiper-item {
  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: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.news_swiper .swiper {
  overflow: visible;
}
.news_swiper .swiper-slide {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
  display: grid;
  gap: 20px;
}
.news_swiper .swiper-item {
  position: relative;
  display: block;
}
.news_swiper .box_newslink {
  background-color: #fff;
  border-radius: 4px;
  border: 1px solid rgba(50, 92, 209, 0.2);
  padding: 1.3em;
  height: 120px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.news_swiper .box_newslink:hover {
  color: #325CD1;
  border: 1px solid #325CD1;
}
.news_swiper .box_newslink .title {
  font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
  font-weight: 500;
  line-height: 1.45;
  margin-bottom: 0.6em;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.news_swiper .box_newslink .overview {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.2rem;
}

@media screen and (max-width: 960px) {
  .news_swiper .swiper-item {
    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: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .news_swiper .swiper {
    overflow: visible;
  }
  .news_swiper .swiper-slide {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
    display: grid;
    gap: 20px;
  }
  .news_swiper .swiper-item {
    position: relative;
  }
  .news_swiper .box_newslink {
    background-color: #fff;
    border-radius: 4px;
    border: 1px solid rgba(50, 92, 209, 0.2);
    padding: 0.8em;
    height: 120px;
  }
  .news_swiper .box_newslink:hover {
    color: #325CD1;
    border: 1px solid #325CD1;
  }
  .news_swiper .box_newslink .title {
    overflow: hidden;
  }
  .news_swiper .box_newslink .overview {
    display: block;
  }
  .news_swiper .box_newslink .overview .data {
    margin-bottom: 0.5em;
  }
}
.story_wrap .card02 {
  overflow: hidden;
  margin-bottom: 3em;
}
.story_wrap .card02 .swiper {
  overflow: visible;
}
.story_wrap .card02 .card_inner {
  position: relative;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  max-width: initial;
  padding: 2% 10%;
  margin: 0 auto;
}
.story_wrap .card02 .swiper-slide {
  position: relative;
  width: 100%;
  max-width: 300px;
  height: auto;
}
.story_wrap .card02 .slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: stretch !important;
      -ms-flex-align: stretch !important;
          align-items: stretch !important;
}
.story_wrap .card02 .swiper-item {
  position: relative;
  display: block;
  z-index: 2;
  overflow: hidden;
}
.story_wrap .card02 .swiper-item .slide-media {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
}
.story_wrap .card02 .swiper-item .slide-media .post_length {
  aspect-ratio: 267/367;
}
.story_wrap .card02 .swiper-item .slide-media::before {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "";
  top: 0;
  left: 0;
  background: transparent linear-gradient(359deg, #000 0%, rgba(0, 0, 0, 0) 100%) 0% 0% no-repeat padding-box;
  opacity: 0.6;
  z-index: 1;
}
.story_wrap .card02 .swiper-item .overview {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  padding: 1em 2em;
  color: #fff;
}
.story_wrap .card02 .swiper-item .overview h2 {
  font-size: clamp(1.8rem, 1.691rem + 0.55vw, 2.1rem);
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: 1em;
}

.radius_pos {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
}
.radius_pos .arrow_radius {
  width: 40px;
  height: 40px;
  background-color: #fff;
  border-radius: 9999px;
  position: relative;
  cursor: pointer;
}
.radius_pos .arrow_radius::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 7px;
  height: 7px;
  border-top: solid 2px #325CD1;
  border-right: solid 2px #325CD1;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}

@media screen and (max-width: 960px) {
  .story_wrap .card02 {
    overflow: hidden;
    margin-bottom: 3em;
  }
  .story_wrap .card02 .swiper {
    overflow: visible;
  }
  .story_wrap .card02 .card_inner {
    position: relative;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
    max-width: initial;
    padding: 2% 7%;
    margin: 0 auto;
  }
  .story_wrap .card02 .card_inner.right_fade {
    margin-right: calc(50% - 50vw);
  }
  .story_wrap .card02 .card_inner.right_fade.story_fade::after {
    background: transparent -webkit-gradient(linear, left top, right top, from(rgba(226, 242, 245, 0)), to(#E2F2F5)) 0% 0% no-repeat padding-box;
    background: transparent linear-gradient(90deg, rgba(226, 242, 245, 0) 0%, #E2F2F5 100%) 0% 0% no-repeat padding-box;
  }
  .story_wrap .card02 .swiper-slide {
    position: relative;
    width: 100%;
    max-width: 252px;
    height: auto;
  }
  .story_wrap .card02 .slide {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: stretch !important;
        -ms-flex-align: stretch !important;
            align-items: stretch !important;
  }
  .story_wrap .card02 .swiper-item {
    position: relative;
    display: block;
    z-index: 2;
    overflow: hidden;
  }
  .story_wrap .card02 .swiper-item .slide-media {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
  }
  .story_wrap .card02 .swiper-item .slide-media .post_length {
    aspect-ratio: 267/367;
  }
  .story_wrap .card02 .swiper-item .slide-media::before {
    position: absolute;
    width: 100%;
    height: 100%;
    content: "";
    top: 0;
    left: 0;
    background: transparent linear-gradient(359deg, #000 0%, rgba(0, 0, 0, 0) 100%) 0% 0% no-repeat padding-box;
    opacity: 0.6;
    z-index: 1;
  }
  .story_wrap .card02 .swiper-item .overview {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
    padding: 1em 2em;
    color: #fff;
  }
  .story_wrap .card02 .swiper-item .overview h2 {
    font-size: clamp(1.8rem, 1.691rem + 0.55vw, 2.1rem);
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 1em;
  }
}
.spots_wrap .card02 {
  overflow: hidden;
  margin-bottom: 3em;
}
.spots_wrap .card02 .swiper {
  overflow: visible;
}
.spots_wrap .card02 .card_inner {
  position: relative;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  max-width: 1200px;
  margin: 0 auto;
  padding-bottom: 40px;
}
.spots_wrap .card02 .swiper-slide {
  position: relative;
  width: 100%;
  height: auto;
}
.spots_wrap .card02 .slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: stretch !important;
      -ms-flex-align: stretch !important;
          align-items: stretch !important;
}
.spots_wrap .card02 .swiper-item {
  position: relative;
  display: block;
  z-index: 2;
}
.spots_wrap .card02 .swiper-item .slide-media {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
}
.spots_wrap .card02 .swiper-item .slide-media .post_trim {
  aspect-ratio: 250/155;
}
.spots_wrap .card02 .swiper-item .overview {
  padding: 1em 0;
}
.spots_wrap .card02 .swiper-item .overview h2 {
  font-size: clamp(1.4rem, 1.255rem + 0.73vw, 1.8rem);
  font-weight: 500;
  line-height: 1.4;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  margin-bottom: 1em;
}
.spots_wrap .card02 .swiper-item .overview .place,
.spots_wrap .card02 .swiper-item .overview .time {
  font-size: 1.3rem;
  line-height: 1.4;
}

@media screen and (max-width: 960px) {
  .card01 .swiper,
  .card02 .swiper {
    overflow: visible;
  }
  .card01 .card_inner,
  .card02 .card_inner {
    margin: 0 auto;
    max-width: initial;
    padding: 2% 7%;
  }
}
.pages_visual {
  position: relative;
  width: 100%;
  overflow: hidden;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
.pages_visual::before {
  position: absolute;
  top: 0;
  left: 50%;
  content: url(../img/pages/recruit/lower_rt.svg);
  width: 133px;
  height: 48px;
  -webkit-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
  z-index: 1;
}
.pages_visual .pages_inner {
  width: 100%;
  height: calc(12vh + 12vw);
  background: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.2)), to(transparent));
  background: linear-gradient(to right, rgba(0, 0, 0, 0.2), transparent);
}
.pages_visual .pages_inner .title {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: grid;
  place-content: center;
}
.pages_visual .pages_inner .title h1 {
  font-size: clamp(2.4rem, -1.2rem + 7.5vw, 3.6rem);
  color: #fff;
  font-weight: 500;
}

.text_visual {
  margin: auto;
  display: grid;
  place-content: center;
  color: #325CD1;
  padding: 3em;
}
.text_visual .title {
  font-weight: 700;
  font-size: 3.2rem;
  margin: 0;
  padding: 0;
  text-align: center;
}
.text_visual .sub {
  font-weight: 500;
  text-align: center;
}

.recruit_bg {
  background-color: #F5F5F5;
  padding-top: 2em;
}
.recruit_bg .container {
  margin-top: 0;
  padding-bottom: 3em;
}

.recruitment_bottom {
  position: relative;
  margin-bottom: 5em;
  display: block;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  background-color: #fff;
  color: #6ACED8;
}
.recruitment_bottom .recruitmentBox {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1.6em;
}
.recruitment_bottom .recruitmentBox .reBox_title {
  font-size: 1.8rem;
  font-weight: 500;
}
.recruitment_bottom .recruitmentBox .reBox_info {
  font-size: 1.2rem;
  line-height: 1.5;
}
.recruitment_bottom .recruitmentBox .reBox_tel {
  font-size: 2.1rem;
  font-weight: 900;
  text-align: right;
}
.recruitment_bottom .recruitmentBox .reBox_tel span {
  margin-left: 0.8em;
}

@media screen and (max-width: 960px) {
  .recruitment_bottom .recruitmentBox {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 1.6em;
  }
  .recruitment_bottom .recruitmentBox .reBox_title {
    font-size: 1.8rem;
    font-weight: 500;
  }
  .recruitment_bottom .recruitmentBox .reBox_info {
    font-size: 1.2rem;
    line-height: 1.5;
  }
  .recruitment_bottom .recruitmentBox .reBox_tel {
    font-size: 2.1rem;
    font-weight: 900;
    text-align: left;
  }
  .recruitment_bottom .recruitmentBox .reBox_tel span {
    margin-left: 0;
  }
}
.lower {
  position: relative;
  width: 100%;
  display: block;
}
.lower::after {
  position: absolute;
  bottom: -60px;
  left: 50%;
  content: url(../img/pages/recruit/lower_rt.svg);
  width: 123px;
  height: 60px;
  -webkit-transform: translate(-50%, 0%);
  transform: translate(-50%, 0%);
}

.interviewInfo h1 {
  font-size: clamp(1.9rem, 0.4rem + 3.13vw, 2.4rem);
  font-weight: 500;
  color: #6ACED8;
  margin-bottom: 0.8em;
}
.interviewInfo .staff_category {
  font-size: 1.4rem;
}
.interviewInfo .staff_join {
  font-size: 1.3rem;
}

.heading_rec_wrap {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
}
.heading_rec_wrap.is_voice {
  margin-bottom: 4.4em;
}
.heading_rec_wrap .link a {
  position: relative;
  background-color: #fff;
  color: #6ACED8;
  display: block;
  padding: 10px 40px 10px 12px;
  border-radius: 10px;
  font-size: 1.4rem;
}
.heading_rec_wrap .link a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #6ACED8;
  border-right: solid 2px #6ACED8;
  -webkit-transform: translate(0%, -50%) rotate(45deg);
          transform: translate(0%, -50%) rotate(45deg);
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}

.heading_rec_1 {
  font-size: clamp(1.9rem, 0.4rem + 3.13vw, 2.4rem);
  font-weight: 500;
  color: #6ACED8;
  margin-bottom: 1.5em;
}

.rec_wrap {
  position: relative;
  margin: 0 auto 5.5em;
}
.rec_wrap .grid_flex {
  margin-bottom: 0;
}

@media screen and (max-width: 960px) {
  .rec_wrap {
    position: relative;
    margin: 0 auto 4.5em;
  }
  .rec_wrap .grid_flex {
    margin-bottom: 0;
  }
  .rec_wrap .lower {
    position: relative;
    width: 100%;
    display: block;
  }
  .rec_wrap .lower::after {
    position: absolute;
    bottom: -40px;
  }
}
.recruitNewBox {
  position: relative;
  background-color: #fff;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  overflow: hidden;
}
.recruitNewBox .post_box {
  border-radius: 0 !important;
  margin: 0;
}
.recruitNewBox .overview {
  padding: 1em;
}
.recruitNewBox .overview .title {
  font-size: clamp(1.4rem, 1.1rem + 0.63vw, 1.5rem);
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 1em;
}
.recruitNewBox .overview .data {
  font-size: 1.3rem;
  line-height: 1.4;
  color: rgba(0, 0, 0, 0.5019607843);
}
.recruitNewBox .overview .view_catch h3 {
  font-size: clamp(1.4rem, 1.1rem + 0.63vw, 1.5rem);
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 0.5em;
}
.recruitNewBox .overview .staff_category,
.recruitNewBox .overview .staff_join,
.recruitNewBox .overview .place,
.recruitNewBox .overview .time {
  font-size: 1.3rem;
  line-height: 1.4;
}

.voice_wrap {
  position: relative;
  margin: 0 auto 5.5em;
}
.voice_wrap.lists {
  margin-top: 4em;
}
.voice_wrap .grid_flex {
  gap: 24px;
}

.blog_grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(218px, 1fr));
  gap: 40px;
  margin-top: 7em;
}
.blog_grid .blog_box {
  text-decoration: none;
}
.blog_grid .blog_box:nth-last-child(2n) {
  -webkit-transform: translateY(-40px);
          transform: translateY(-40px);
}

.blog_box .post_box {
  border: 1px solid rgba(50, 92, 209, 0.2);
  border-radius: 9999px 9999px 9999px 0;
  overflow: hidden;
}
.blog_box .overview {
  padding: 0.4em 0;
}
.blog_box .overview .title {
  font-size: clamp(1.4rem, 1.1rem + 0.63vw, 1.5rem);
  font-weight: 500;
  line-height: 1.4;
  margin-bottom: 1em;
}
.blog_box .overview .data {
  font-size: 1.3rem;
  line-height: 1.4;
  color: rgba(0, 0, 0, 0.5019607843);
}

.view_subBox {
  position: relative;
  background-color: #fff;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  margin-bottom: 50px;
}
.view_subBox .view_sub {
  width: 120px;
  height: 120px;
  margin: -60px auto 10px;
  overflow: visible;
}
.view_subBox .overview .view_catch {
  padding: 0.2em 1em 1em;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  margin-bottom: 1em;
}
.view_subBox .overview .view_catch h3,
.view_subBox .overview .view_catch .title {
  font-size: clamp(1.4rem, 1.1rem + 0.63vw, 1.5rem);
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 0;
}
.view_subBox .overview .view_inner {
  padding: 1em;
  font-size: clamp(1.4rem, 1.1rem + 0.63vw, 1.5rem);
  line-height: 1.6;
  color: rgba(0, 0, 0, 0.5019607843);
}
.view_subBox.voice {
  margin-top: 60px;
  margin-bottom: 80px;
  background-color: #fff;
}
.view_subBox.voice .view_catch {
  padding: 1em 1.5em;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.view_subBox.voice .view_catch .title {
  font-size: 1.1rem;
  font-weight: 500;
  color: #6ACED8;
  margin-bottom: 0.7em;
}
.view_subBox.voice .view_catch h2 {
  font-size: clamp(1.5rem, 1.322rem + 0.37vw, 1.6rem);
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 0.8em;
}
.view_subBox.voice .overview {
  padding: 1.5em;
  text-align: left;
  color: rgba(0, 0, 0, 0.5411764706);
  font-size: 1.4rem;
  line-height: 1.5;
}

.interviewInfo {
  position: relative;
  margin-top: -80px;
  z-index: 1;
  background-color: #fff;
  display: grid;
  grid-template-columns: 120px 1fr;
  width: 320px;
  -webkit-box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.06);
          box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.06);
}
.interviewInfo .title {
  font-size: 1.2rem;
  font-weight: 500;
  color: #fff;
  background-color: #6ACED8;
  display: grid;
  place-content: center;
  height: auto;
}
.interviewInfo .summary {
  padding: 1em;
}
.interviewInfo .summary h1 {
  font-size: 2.1rem;
  color: #111;
  font-weight: 400;
  margin-bottom: 0.8em;
}
.interviewInfo .summary .cate,
.interviewInfo .summary .join {
  font-size: 1.4rem;
  line-height: 1.5;
  color: rgba(0, 0, 0, 0.5019607843);
}

.interview_catch {
  font-size: clamp(1.9rem, 1.544rem + 0.74vw, 2.1rem);
  color: #6ACED8;
  font-weight: 500;
  margin: 2em 0 1em;
  padding: 0 1.5em 1.6em;
  border-bottom: 1px solid #6ACED8;
}

/*# sourceMappingURL=import.css.map */