:root {
  --main-color: #0abab5;
  --sub-color: #005da4;
  --txt-color: #111;
  --broder-color: #e0e0e0;
  --red: #eb0303;
  --font-sp-3xs: clamp(0.625rem, -0.042rem + 3.33vw, 0.688rem);
  --font-sp-2xs: clamp(0.688rem, 0.021rem + 3.33vw, 0.75rem);
  --font-sp-xs: clamp(0.75rem, 0.083rem + 3.33vw, 0.813rem);
  --font-sp-s: clamp(0.813rem, 0.146rem + 3.33vw, 0.875rem);
  --font-sp-m: clamp(0.875rem, 0.208rem + 3.33vw, 0.938rem);
  --font-sp-l: clamp(0.938rem, 0.271rem + 3.33vw, 1rem);
  --font-sp-xl: clamp(1rem, -0.333rem + 6.67vw, 1.125rem);
  --font-sp-2xl: clamp(1.125rem, -0.208rem + 6.67vw, 1.25rem);
  --font-sp-3xl: clamp(1.25rem, -1.417rem + 13.33vw, 1.5rem);
  --font-sp-4xl: clamp(1.5rem, -1.167rem + 13.33vw, 1.75rem);
  --font-sp-5xl: clamp(1.75rem, -0.917rem + 13.33vw, 2rem);
  --font-4xs: clamp(0.625rem, 0.528rem + 0.2vw, 0.688rem);
  --font-3xs: clamp(0.688rem, 0.59rem + 0.2vw, 0.75rem);
  --font-2xs: clamp(0.75rem, 0.653rem + 0.2vw, 0.813rem);
  --font-xs: clamp(0.813rem, 0.715rem + 0.2vw, 0.875rem);
  --font-s: clamp(0.875rem, 0.778rem + 0.2vw, 0.938rem);
  --font-m: clamp(0.938rem, 0.84rem + 0.2vw, 1rem);
  --font-l: clamp(1rem, 0.805rem + 0.4vw, 1.125rem);
  --font-xl: clamp(1.125rem, 0.93rem + 0.4vw, 1.25rem);
  --font-2xl: clamp(1.25rem, 0.86rem + 0.8vw, 1.5rem);
  --font-3xl: clamp(1.5rem, 1.11rem + 0.8vw, 1.75rem);
  --font-4xl: clamp(1.75rem, 1.36rem + 0.8vw, 2rem);
  --font-5xl: clamp(2rem, 1.61rem + 0.8vw, 2.25rem);
  --leading-trim: calc((1em - 1lh) / 2);
}
@supports not (top: 1lh) {
  :root {
    --leading-trim: 0;
  }
}
@font-face {
  src: url(../../assets/fonts/Montserrat-Regular.woff) format('woff'),
    url(../../assets/fonts/Montserrat-Regular.woff2) format('woff2');
  font-family: Montserrat-Regular;
  font-display: swap;
}
@font-face {
  src: url(../../assets/fonts/Montserrat-Medium.woff) format('woff'),
    url(../../assets/fonts/Montserrat-Medium.woff2) format('woff2');
  font-family: Montserrat-Medium;
  font-display: swap;
}
@font-face {
  src: url(../../assets/fonts/Montserrat-Bold.woff) format('woff'),
    url(../../assets/fonts/Montserrat-Bold.woff2) format('woff2');
  font-family: Montserrat-Bold;
  font-display: swap;
}
:root {
  --Montserrat-Regular: 'Montserrat-Regular', sans-serif;
  --Montserrat-Medium: 'Montserrat-Medium', sans-serif;
  --Montserrat-Bold: 'Montserrat-Bold', sans-serif;
}
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}
*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #111;
  font-weight: 400;
  line-height: 1.1;
}
img,
video {
  max-width: 100%;
  height: auto;
  border-style: none;
  vertical-align: bottom;
}
img {
  width: 100%;
  image-rendering: optimize-contrast;
}
table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}
caption,
th,
td {
  font-weight: 400;
  text-align: left;
  vertical-align: middle;
}
ol,
ul {
  list-style: none;
}
q,
blockquote {
  quotes: none;
}
q:before,
q:after,
blockquote:before,
blockquote:after {
  content: none;
}
input[type='text'],
input[type='email'],
input[type='submit'],
button,
textarea {
  font-family: inherit;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}
input[type='submit'],
button {
  margin: 0;
  padding: 0;
  border: none;
  outline: none;
  cursor: pointer;
}
button {
  background: none;
}
::-moz-selection {
  background: none repeat scroll 0 0 #222;
  color: #fff;
  font-weight: 700;
}
::selection {
  background: none repeat scroll 0 0 #222;
  color: #fff;
  font-weight: 700;
}
:-moz-placeholder {
  color: #ccc;
}
:placeholder-shown {
  color: #ccc;
}
::input-placeholder {
  color: #ccc;
}
:placeholder {
  color: #ccc;
  opacity: 100%;
}
::-webkit-input-placeholder {
  color: #ccc;
  opacity: 100%;
}
::-moz-placeholder {
  color: #ccc;
  opacity: 100%;
}
::-ms-input-placeholder {
  color: #ccc;
  opacity: 100%;
}
::placeholder {
  color: #ccc;
  opacity: 100%;
}
[src$='.svg'],
[data$='.svg'] {
  width: 100%;
}
svg {
  width: 100%;
}
.htmlOpen {
  position: static;
  overflow: hidden;
}
.htmlOpen .hamburger__pipe {
  background: #fff;
}
.htmlOpen .hamburger__pipe:nth-of-type(1) {
  -webkit-transform: translateY(8px) rotate(-45deg);
  transform: translateY(8px) rotate(-45deg);
}
.htmlOpen .hamburger__pipe:nth-of-type(2) {
  opacity: 0%;
}
.htmlOpen .hamburger__pipe:nth-of-type(3) {
  -webkit-transform: translateY(-8px) rotate(45deg);
  transform: translateY(-8px) rotate(45deg);
}
.htmlOpen .overlay {
  visibility: visible;
  -webkit-filter: opacity(1);
  filter: opacity(1);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.htmlOpen .drower {
  visibility: visible;
  -webkit-transform: translateX(0%);
  transform: translate(0);
  -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1),
    -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1);
}
.htmlOpen .drower__item {
  -webkit-transform: translateX(0);
  transform: translate(0);
}
.htmlOpen .drower__item:nth-of-type(1) {
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.17, 0.935, 0.305, 1)
    0.1s;
  transition: -webkit-transform 0.4s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.4s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.4s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s,
    -webkit-transform 0.4s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
}
.htmlOpen .drower__item:nth-of-type(2) {
  -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1)
    0.1s;
  transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s,
    -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
}
.htmlOpen .drower__item:nth-of-type(3) {
  -webkit-transition: -webkit-transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1)
    0.1s;
  transition: -webkit-transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s,
    -webkit-transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
}
.htmlOpen .drower__item:nth-of-type(4) {
  -webkit-transition: -webkit-transform 0.7s cubic-bezier(0.17, 0.935, 0.305, 1)
    0.1s;
  transition: -webkit-transform 0.7s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.7s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.7s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s,
    -webkit-transform 0.7s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
}
.htmlOpen .drower__item:nth-of-type(5) {
  -webkit-transition: -webkit-transform 0.8s cubic-bezier(0.17, 0.935, 0.305, 1)
    0.1s;
  transition: -webkit-transform 0.8s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.8s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.8s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s,
    -webkit-transform 0.8s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
}
.htmlOpen .drower__item:nth-of-type(6) {
  -webkit-transition: -webkit-transform 0.9s cubic-bezier(0.17, 0.935, 0.305, 1)
    0.1s;
  transition: -webkit-transform 0.9s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.9s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
  transition: transform 0.9s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s,
    -webkit-transform 0.9s cubic-bezier(0.17, 0.935, 0.305, 1) 0.1s;
}
.hamburger {
  z-index: 101;
  position: absolute;
  top: 26px;
  right: 5vw;
  border-radius: 2px;
  cursor: pointer;
}
.hamburger__wrap {
  position: relative;
  width: 22px;
  height: 18px;
}
.hamburger__pipe {
  display: inline-block;
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: #fff;
  cursor: pointer;
  -webkit-transition: -webkit-transform 0.4s ease-out;
  transition: -webkit-transform 0.4s ease-out;
  transition: transform 0.4s ease-out;
  transition: transform 0.4s ease-out, -webkit-transform 0.4s ease-out;
}
.hamburger__pipe:nth-of-type(1) {
  top: 0;
}
.hamburger__pipe:nth-of-type(2) {
  top: 8px;
}
.hamburger__pipe:nth-of-type(3) {
  bottom: 0;
}
.header {
  z-index: 100;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 0;
}
.header__logo {
  display: block;
  z-index: 100;
  position: absolute;
  top: 20px;
  left: clamp(20px, 2.5vw, 30px);
  width: 140px;
}
.header__logo img {
  display: block;
}
.drower {
  visibility: visible;
  z-index: 99;
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  padding: 120px 10vw 60px;
  overflow-y: auto;
  background: var(--main-color);
  -webkit-transform: translateX(100%);
  transform: translate(100%);
  will-change: transform;
  -webkit-overflow-scrolling: touch;
}
.drower-animation {
  -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1),
    -webkit-transform 0.5s cubic-bezier(0.17, 0.935, 0.305, 1);
}
.drower__list {
  position: relative;
}
.drower__item {
  -webkit-transform: translateX(100%);
  transform: translate(100%);
  -webkit-transition: -webkit-transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: -webkit-transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1);
  transition: transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1),
    -webkit-transform 0.6s cubic-bezier(0.17, 0.935, 0.305, 1);
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.drower__listLink {
  display: block;
  position: relative;
  padding: 20px 0;
  color: #fff;
  line-height: 1.1;
}
.drower__en {
  font-size: var(--font-sp-2xl);
  line-height: 1.1;
  font-family: var(--Poppins-Regular);
}
.drower__jp {
  margin-top: 10px;
  font-size: var(--font-sp-2xs);
  line-height: 1.1;
}
.drower__footer {
  margin-top: clamp(80px, 10vw, 120px);
  color: #fff;
  font-size: var(--font-sp-2xs);
  line-height: 1.8;
}
.drower__copy {
  margin-top: clamp(60px, 7vw, 80px);
  padding-top: 20px;
  border-top: 1px solid #00aca7;
  font-size: var(--font-sp-3xs);
  font-family: var(--Montserrat-Regular);
  text-align: right;
}
.overlay {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  visibility: hidden;
  z-index: 10;
  position: fixed;
  top: 0;
  left: 0;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100vw;
  height: 100vh;
  background-color: #000000bf;
  cursor: pointer;
  -webkit-filter: opacity(0);
  filter: opacity(0);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.footer {
  z-index: 1;
  position: relative;
  padding: clamp(100px, 12.5vw, 150px) 0;
  background: #212f2f;
  color: #fff;
}
.footer__slogan {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.footer__sloganEn {
  font-weight: 700;
  font-size: clamp(2rem, -0.154rem + 10.77vw, 3.75rem);
  line-height: 1.1;
  font-family: var(--Montserrat-Bold);
}
.footer__sloganJp {
  position: absolute;
  top: 0;
  right: 0;
  font-weight: 500;
  font-size: clamp(0.813rem, 0.188rem + 3.13vw, 1.125rem);
}
.footer__sloganPlus {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 30px;
  height: 30px;
}
.footer__sloganPlus:before,
.footer__sloganPlus:after {
  display: block;
  position: absolute;
  top: 50%;
  background: #fff;
  content: '';
}
.footer__sloganPlus:before {
  left: 0;
  width: 100%;
  height: 2px;
}
.footer__sloganPlus:after {
  top: 0;
  left: 50%;
  width: 2px;
  height: 100%;
}
.footer__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-top: clamp(60px, 7vw, 80px);
  gap: clamp(40px, 5vw, 60px);
}
.footer__logo {
  width: 140px;
}
.footer__address {
  margin-top: 20px;
  color: #fff;
  font-size: var(--font-sp-2xs);
}
.footer__sub,
.footer__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(10px, 1.5vw, 20px);
}
.footer__item {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #fff;
  font-size: var(--font-sp-2xs);
  line-height: 1.5;
}
.footer__lower {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-top: clamp(60px, 8vw, 100px);
  padding-top: 20px;
  gap: 10px;
  border-top: 1px solid #374848;
  color: #fff;
  font-size: var(--font-sp-2xs);
}
.footer__copy {
  font-family: var(--Montserrat-Regular);
}
.l_layoutColumn {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  overflow: clip;
  opacity: 0;
  -webkit-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
}
.l_layout {
  padding: 0 5vw;
}
.u_mobile {
  display: block;
}
.u_pc {
  display: none;
}
.u_blur {
  opacity: 0;
}
.u_blur-active {
  -webkit-filter: blur(300px);
  filter: blur(300px);
  -webkit-transform: scale(0.5);
  transform: scale(0.5);
  -webkit-animation: mvFadeIn 2s 0.5s cubic-bezier(0.2, 1, 0.2, 1) forwards;
  animation: mvFadeIn 2s 0.5s cubic-bezier(0.2, 1, 0.2, 1) forwards;
}
.u_line {
  background-image: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#111),
    to(#111)
  );
  background-image: linear-gradient(#111, #111);
  background-position: 0 95%;
  background-size: 100% 1px;
  background-repeat: no-repeat;
  -webkit-transition: background-size 0.5s ease;
  transition: background-size 0.5s ease;
}
.u_line-white {
  background-image: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#fff),
    to(#fff)
  );
  background-image: linear-gradient(#fff, #fff);
  color: #fff;
}
.u_line:hover {
  background-position: 100% 95%;
  background-size: 0% 1px;
}
.u_lineNone {
  background-image: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#111),
    to(#111)
  );
  background-image: linear-gradient(#111, #111);
  background-position: 100% 95%;
  background-size: 0% 1px;
  background-repeat: no-repeat;
  -webkit-transition: background-size 0.5s ease;
  transition: background-size 0.5s ease;
}
.u_lineNone-white {
  background-image: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#fff),
    to(#fff)
  );
  background-image: linear-gradient(#fff, #fff);
  color: #fff;
}
.u_lineNone:hover {
  background-position: 0 95%;
  background-size: 100% 1px;
}
.u_space {
  width: 0.26em;
}
.contact {
  margin-top: clamp(100px, 12.5vw, 150px);
}
.contact__row {
  padding: clamp(20px, 2.5vw, 30px) 0;
  border-bottom: 1px solid #e0e0e0;
}
.contact__row:first-of-type {
  border-top: 1px solid #e0e0e0;
}
.contact__name {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 10px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.contact__txtSmall {
  font-size: var(--font-sp-2xs);
}
.contact__require {
  padding: 2px 5px 3px;
  border-radius: 2px;
  background: var(--main-color);
  color: #fff;
  font-size: 0.6875rem;
  line-height: 1.1;
}
.contact__col {
  margin-top: 15px;
}
.contact__flat {
  width: 100%;
  padding: 15px;
  border: 1px solid #e8e8e8;
  border-radius: 4px;
  background: #f8f8f8;
  -webkit-transition: background-color 0.4s ease-out;
  font-size: 1rem;
  line-height: 1.5;
  transition: background-color 0.4s ease-out;
}
.contact__flat-textarea {
  height: 160px;
}
.contact__flat:focus {
  background: #fff;
}
.contact .error,
.contact .wpcf7-not-valid-tip {
  display: block;
  width: 100%;
  margin-top: 10px;
  padding: 5px 10px;
  background: #ec0000;
  color: #fff;
  font-size: 0.75rem;
  line-height: 1.1;
}
.contact .error-center,
.contact .wpcf7-not-valid-tip-center {
  text-align: center;
}
.contact input[type='checkbox'],
.contact input[type='radio'] {
  display: none;
}
.contact input[type='checkbox'] + span,
.contact input[type='radio'] + span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  line-height: 1.1;
  cursor: pointer;
}
.contact input[type='checkbox'] + span:before,
.contact input[type='radio'] + span:before {
  width: 24px;
  height: 24px;
  margin-right: 10px;
  border: 1px solid #e0e0e0;
  border-radius: 2px;
  background: #fff;
  content: '';
  -webkit-transition: all 0.1s ease-out;
  transition: all 0.1s ease-out;
}
.contact input[type='checkbox']:checked + span:before,
.contact input[type='radio']:checked + span:before {
  background: var(--main-color);
  -webkit-box-shadow: inset 0 0 0 5px #fff;
  box-shadow: inset 0 0 0 5px #fff;
}
.contact input[type='radio'] + span:before {
  border-radius: 50%;
}
.send {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: clamp(30px, 3.5vw, 40px);
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: clamp(40px, 5vw, 60px);
}
.send__link {
  text-decoration: underline;
}
.send__link:hover {
  text-decoration: none;
}
.swiper-button-prev,
.swiper-button-next {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 10;
  position: absolute;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
}
.swiper-button-prev:before,
.swiper-button-next:before {
  position: absolute;
  top: calc(50% - 4px);
  width: 8px;
  height: 8px;
  border-bottom: 1px solid var(--main-color);
  border-left: 1px solid var(--main-color);
  content: '';
}
.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  cursor: auto;
  opacity: 0.8;
  pointer-events: none;
}
.swiper-button-prev.swiper-button-hidden,
.swiper-button-next.swiper-button-hidden {
  cursor: auto;
  opacity: 0;
  pointer-events: none;
}
.swiper-navigation-disabled .swiper-button-prev,
.swiper-navigation-disabled .swiper-button-next {
  display: none !important;
}
.swiper-button-prev:before {
  right: calc(50% - 6px);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.swiper-button-next:before {
  right: calc(50% - 2px);
  -webkit-transform: rotate(225deg);
  transform: rotate(225deg);
}
.swiper-button-lock {
  display: none;
}
.swiper-pages {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 30px;
  gap: 0 5px;
}
:root {
  --swiper-pagination-color: var(--main-color);
}
.swiper-pagination {
  z-index: 10;
  margin-top: 20px;
  font-size: 0;
  text-align: center;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translateZ(0);
  -webkit-transition: 0.3s opacity;
  transition: 0.3s opacity;
}
.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}
.swiper-pagination-disabled > .swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}
.swiper-pagination-custom,
.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal {
  left: 0;
  width: 100%;
}
.swiper-pagination-bullet {
  display: inline-block;
  width: var(
    --swiper-pagination-bullet-width,
    var(--swiper-pagination-bullet-size, 8px)
  );
  height: var(
    --swiper-pagination-bullet-height,
    var(--swiper-pagination-bullet-size, 8px)
  );
  border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}
button.swiper-pagination-bullet {
  margin: 0;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  -webkit-box-shadow: none;
  box-shadow: none;
}
.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}
.swiper-pagination-bullet:only-child {
  display: none !important;
}
.swiper-pagination-bullet-active {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  opacity: var(--swiper-pagination-bullet-opacity, 1);
}
.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets
  .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}
.swiper-pagination-lock {
  display: none;
}
.floating .swiper-pages {
  z-index: 10;
  position: absolute;
  top: 50%;
  right: 0%;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 100%;
  margin-top: 0;
  padding-right: clamp(10px, 1.5vw, 20px);
  background: #fff;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.floating .swiper-button-prev,
.floating .swiper-button-next {
  position: relative;
  top: 0;
  width: 20px;
  height: 100%;
  border-radius: 0;
  background: transparent;
}
.floating .swiper-button-prev:before,
.floating .swiper-button-next:before {
  border-color: var(--main-color);
}
.floating .swiper-button-prev:after {
  z-index: -1;
  position: absolute;
  right: -4px;
  width: 1px;
  height: 30px;
  background: #e0e0e0;
  content: '';
}
.modal__target .swiper {
  overflow: hidden;
  border-radius: clamp(5px, 0.75vw, 10px);
}
.modal__target .swiper-button-prev,
.modal__target .swiper-button-next {
  display: none;
  border: 1px solid var(--main-color);
}
.modal__target .swiper-button-prev {
  top: calc(50% - 20px);
  left: -60px;
}
.modal__target .swiper-button-next {
  top: calc(50% - 20px);
  right: -60px;
}
.modal__target .swiper-button-lock {
  display: none;
}
@font-face {
  font-style: normal;
  font-weight: 400;
  src: url(data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA);
  font-family: swiper-icons;
}
:root {
  --swiper-theme-color: #007aff;
}
:host {
  display: block;
  z-index: 1;
  position: relative;
  margin-right: auto;
  margin-left: auto;
}
.swiper {
  display: block;
  z-index: 1;
  position: relative;
  margin-right: auto;
  margin-left: auto;
  padding: 0;
  list-style: none;
}
.swiper-vertical > .swiper-wrapper {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
.swiper-wrapper {
  z-index: 1;
  position: relative;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
  cursor: pointer;
  -webkit-transition-timing-function: var(
    --swiper-wrapper-transition-timing-function,
    initial
  );
  transition-timing-function: var(
    --swiper-wrapper-transition-timing-function,
    initial
  );
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
}
.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translateZ(0);
}
.swiper-horizontal {
  -ms-touch-action: pan-y;
  touch-action: pan-y;
}
.swiper-vertical {
  -ms-touch-action: pan-x;
  touch-action: pan-x;
}
.swiper-slide {
  display: block;
  position: relative;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
}
.swiper-slide-invisible-blank {
  visibility: hidden;
}
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}
.swiper-autoheight .swiper-wrapper {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-transition-property: height, -webkit-transform;
  transition-property: height, -webkit-transform;
  transition-property: transform, height;
  transition-property: transform, height, -webkit-transform;
}
.swiper-backface-hidden .swiper-slide {
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.html-open {
  position: static;
  overflow: hidden;
}
.html-open .modal__target {
  z-index: 201;
}
.html-open .modal__overlay {
  visibility: visible;
  opacity: 1;
}
.modal__name,
.modal__title {
  margin-top: clamp(15px, 1.75vw, 20px);
  font-weight: 500;
  font-size: var(--font-sp-2xl);
  line-height: 1.1;
}
.modal__target {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  visibility: hidden;
  z-index: 10;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  overflow-y: auto;
  opacity: 0;
  -webkit-transition: opacity 0.2s ease-in, visibility 0.2s ease-in;
  transition: opacity 0.2s ease-in, visibility 0.2s ease-in;
}
.modal__target-open {
  visibility: visible;
  opacity: 1;
}
.modal__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 2;
  position: relative;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  height: 100dvh;
  padding: 6vw 5vw;
  overflow-x: hidden;
  overflow-y: auto;
  cursor: pointer;
}
.modal__body {
  z-index: 5;
  position: relative;
  width: 100%;
  max-width: 900px;
  margin: auto;
  padding: clamp(20px, 5vw, 40px) clamp(20px, 5vw, 40px) clamp(40px, 5vw, 60px);
  border-radius: 10px;
  background: #fff;
  cursor: default;
}
.modal__head {
  margin-top: clamp(20px, 5vw, 40px);
  text-align: center;
}
.modal__block {
  margin-top: clamp(20px, 5vw, 40px);
}
.modal__block p + p,
.modal__block p + ul,
.modal__block p + ol,
.modal__block ul + p,
.modal__block ul + ul,
.modal__block ul + ol,
.modal__block ol + p,
.modal__block ol + ul,
.modal__block ol + ol {
  margin-top: clamp(20px, 2.5vw, 30px);
}
.modal__block ul {
  list-style-type: disc;
}
.modal__block ul li {
  margin-left: 20px;
}
.modal__block ol {
  list-style-type: decimal;
}
.modal__block ol li {
  margin-left: 20px;
}
.modal__close {
  z-index: 20;
  position: sticky;
  top: 0;
  left: 100%;
  width: 40px;
  height: 40px;
  margin: -10px -10px 0 0;
  border-radius: 50%;
  background: var(--main-color);
  line-height: 1;
  cursor: pointer;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.modal__close:before,
.modal__close:after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 1px;
  background: #fff;
  content: '';
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.modal__close:after {
  width: 1px;
  height: 12px;
}
.modal__overlay {
  visibility: hidden;
  z-index: 110;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  background-color: #000c;
  cursor: pointer;
  opacity: 0;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  -webkit-transition: opacity 0.2s ease-in, visibility 0.2s ease-in;
  transition: opacity 0.2s ease-in, visibility 0.2s ease-in;
}
.imgslider {
  position: relative;
  max-width: 500px;
  margin: auto;
}
.single {
  margin-top: clamp(100px, 12.5vw, 150px);
}
.entry h2,
.entry h3,
.entry h4 {
  font-weight: 500;
  line-height: 1.5;
}
.entry h2 + p,
.entry h2 + ol,
.entry h2 + ul,
.entry h2 + figure,
.entry h3 + p,
.entry h3 + ol,
.entry h3 + ul,
.entry h3 + figure,
.entry h4 + p,
.entry h4 + ol,
.entry h4 + ul,
.entry h4 + figure {
  margin-top: 20px;
}
.entry h2 + h3,
.entry h2 + h4,
.entry h3 + h3,
.entry h3 + h4,
.entry h4 + h3,
.entry h4 + h4 {
  margin-top: 30px;
}
.entry h2 {
  position: relative;
  padding-top: clamp(30px, 5vw, 60px);
  font-size: clamp(1.125rem, 0.375rem + 3.75vw, 1.5rem);
  letter-spacing: 0.05em;
}
.entry h2:after,
.entry h2:before {
  display: block;
  height: 1px;
  content: '';
}
.entry h2:after {
  position: absolute;
  top: -2px;
  left: 30px;
  width: calc(100% - 20px);
  background: #e5e5e5;
}
.entry h2:before {
  position: absolute;
  top: -2px;
  left: 0;
  width: 20px;
  background: var(--main-color);
}
.entry h3 {
  position: relative;
  padding-left: 15px;
  font-size: clamp(1rem, 0.5rem + 2.5vw, 1.25rem);
  letter-spacing: 0.05em;
}
.entry h3:before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 100%;
  background: var(--main-color);
  content: '';
}
.entry h4 {
  font-size: clamp(0.875rem, 0.625rem + 1.25vw, 1rem);
  letter-spacing: 0.05em;
}
.entry p + p,
.entry p + ol,
.entry p + ul,
.entry p + figure,
.entry ol + p,
.entry ol + ol,
.entry ol + ul,
.entry ol + figure,
.entry ul + p,
.entry ul + ol,
.entry ul + ul,
.entry ul + figure,
.entry figure + p,
.entry figure + ol,
.entry figure + ul,
.entry figure + figure,
.entry .wp-caption + p,
.entry .wp-caption + ol,
.entry .wp-caption + ul,
.entry .wp-caption + figure {
  margin-top: 20px;
}
.entry p + h2,
.entry ol + h2,
.entry ul + h2,
.entry figure + h2,
.entry .wp-caption + h2 {
  margin-top: 60px;
}
.entry p + h3,
.entry p + h4,
.entry ol + h3,
.entry ol + h4,
.entry ul + h3,
.entry ul + h4,
.entry figure + h3,
.entry figure + h4,
.entry .wp-caption + h3,
.entry .wp-caption + h4 {
  margin-top: 40px;
}
.entry figure + h3,
.entry figure + h4 {
  margin-top: 40px;
}
.entry ol {
  list-style-type: decimal;
}
.entry ol li {
  margin-left: 20px;
}
.entry ul {
  list-style-type: disc;
}
.entry ul li {
  margin-left: 20px;
}
.entry .aligncenter {
  display: block;
  margin: auto;
}
.entry a {
  color: var(--main-color);
  text-decoration: underline;
}
.entry a:hover {
  text-decoration: none;
}
.entry img {
  width: auto;
}
.entry p + .wp-caption {
  margin-top: 15px;
}
.entry .wp-caption {
  max-width: 100%;
  margin-top: 10px;
}
.entry .wp-caption-text {
  margin-top: 10px;
  font-size: 0.75rem;
  line-height: 1.8;
}
.pagination {
  margin-top: 40px;
}
.pagination__grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0 5px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.pagination__grid .current {
  background: var(--main-color);
  color: #fff;
}
.page-numbers {
  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;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  color: var(--main-color);
  font-size: clamp(0.813rem, 0.413rem + 2vw, 0.875rem);
  line-height: 1.1;
  font-family: var(--Montserrat-Regular);
  -webkit-transition: background-color 0.4s ease-out;
  transition: background-color 0.4s ease-out;
}
.page-numbers:hover {
  background: var(--main-color);
  color: #fff;
}
.postNav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: clamp(60px, 8vw, 100px);
  padding-top: clamp(40px, 5vw, 60px);
  border-top: 1px solid #e5e5e5;
}
.postNav__return {
  position: absolute;
  left: 50%;
  width: 26px;
  line-height: 0;
  -webkit-transform: translateX(-50%);
  transform: translate(-50%);
}
.postNav__button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 10px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 5px;
  border: 1px solid #e0e0e0;
  border-radius: 30px;
  -webkit-transition: background-color 0.4s ease-out;
  transition: background-color 0.4s ease-out;
}
.postNav__button:hover {
  border-color: var(--main-color);
  background: var(--main-color);
  color: #fff;
}
.postNav__button:hover .postNav__icon {
  background: #fff;
}
.postNav__button:hover .postNav__icon:before {
  border-color: var(--main-color);
}
.postNav__button:hover .postNav__icon:after {
  background: var(--main-color);
}
.postNav__button-left {
  margin-right: auto;
  padding-right: 30px;
}
.postNav__button-left .postNav__icon:before {
  margin-left: -6px;
}
.postNav__button-right {
  margin-left: auto;
  padding-left: 30px;
}
.postNav__button-right .postNav__icon:before {
  margin-right: -6px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.postNav__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 9;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 35px;
  height: 35px;
  border-radius: 50%;
  background: var(--main-color);
  cursor: pointer;
  -webkit-transition: background-color 0.4s ease-out, opacity 0.4s ease-out;
  transition: background-color 0.4s ease-out, opacity 0.4s ease-out;
}
.postNav__icon:before,
.postNav__icon:after {
  position: absolute;
  content: '';
}
.postNav__icon:before {
  width: 6px;
  height: 6px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}
.postNav__icon:after {
  width: 10px;
  height: 1px;
  background: #fff;
}
.postNav__txt {
  font-size: var(--font-sp-xs);
  font-family: var(--Montserrat-Regular);
}
.acf p + p,
.acf p + ul,
.acf p + ol,
.acf ul + p,
.acf ul + ul,
.acf ul + ol,
.acf ol + p,
.acf ol + ul,
.acf ol + ol {
  margin-top: 10px;
}
.acf ul {
  list-style-type: disc;
}
.acf ul li {
  margin-left: 20px;
}
.acf ol {
  list-style-type: decimal;
}
.acf ol li {
  margin-left: 20px;
}
html {
  -webkit-font-kerning: normal;
  font-kerning: normal;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  min-height: 100vh;
  font-size: var(--font-sp-s);
  font-family: Noto Sans JP, sans-serif;
  -webkit-font-kerning: normal;
  background: #fff;
  color: #111;
  line-height: 2;
  font-kerning: normal;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: auto;
}
a {
  color: #111;
  text-decoration: none;
}
.mainVisual {
  z-index: 10;
  position: relative;
}
.mainVisual__picture {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.mainVisual__body {
  z-index: 2;
  position: absolute;
  bottom: 25%;
  width: 100%;
  padding: 0 5vw;
}
.mainVisual__slogan {
  visibility: hidden;
  color: #fff;
  font-weight: 700;
  font-size: clamp(2rem, -0.667rem + 13.33vw, 2.25rem);
  line-height: 1.2;
  text-shadow: 0 0 15px rgba(0, 0, 0, 0.15);
}
.blur-active {
  visibility: visible;
  -webkit-filter: blur(300px);
  filter: blur(300px);
  -webkit-transform: scale(0.5);
  transform: scale(0.5);
  -webkit-animation: mvFadeIn 1.5s 0s cubic-bezier(0.2, 1, 0.2, 1) forwards;
  animation: mvFadeIn 1.5s 0s cubic-bezier(0.2, 1, 0.2, 1) forwards;
}
@-webkit-keyframes mvFadeIn {
  0% {
    opacity: 0;
    -webkit-filter: blur(300px);
    filter: blur(300px);
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
  }
  to {
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
@keyframes mvFadeIn {
  0% {
    opacity: 0;
    -webkit-filter: blur(300px);
    filter: blur(300px);
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
  }
  to {
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
.floating {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 11;
  position: absolute;
  bottom: 10px;
  left: 10px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: calc(100% - 20px);
  max-width: 650px;
  overflow: hidden;
  border-radius: 5px;
  background: #fff;
  line-height: 1.5;
}
.floating__swiper {
  width: 80%;
  overflow: hidden;
}
.floating__title {
  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;
  width: 20%;
  background: var(--main-color);
  color: #fff;
  font-family: var(--Montserrat-Medium);
}
.floating__grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  padding: clamp(15px, 1.8vw, 20px) calc(65px + clamp(15px, 1.8vw, 20px))
    clamp(15px, 1.8vw, 20px) clamp(15px, 1.8vw, 20px);
  gap: 0 clamp(15px, 1.8vw, 25px);
}
.floating__date {
  font-size: var(--font-sp-2xs);
  font-family: var(--Montserrat-Regular);
}
.floating__txt {
  font-size: var(--font-sp-xs);
}
.head-white .head__jp,
.head-white .head__en {
  color: #fff;
}
.head-white .head__jp:before,
.head-white .head__jp:after,
.head-white .head__en:before,
.head-white .head__en:after {
  background: #fff;
}
.head__title {
  display: grid;
  gap: clamp(20px, 2.5vw, 30px) 0;
}
.head__jp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-block: var(--leading-trim);
  padding-left: 22px;
  overflow: hidden;
  color: var(--main-color);
  font-size: var(--font-2xs);
}
.head__jp:before,
.head__jp:after {
  display: block;
  position: absolute;
  top: 2px;
  background: var(--main-color);
  content: '';
}
.head__jp:before {
  top: calc(50% - 0.5px);
  left: 0;
  width: 11px;
  height: 1px;
}
.head__jp:after {
  top: 2px;
  left: 5px;
  width: 1px;
  height: 11px;
}
.head__en {
  margin-block: var(--leading-trim);
  font-size: clamp(1.875rem, -2.125rem + 20vw, 2.25rem);
  font-family: var(--Montserrat-Medium);
}
.head__txt {
  margin-top: clamp(30px, 3.5vw, 40px);
}
.head__button {
  margin-top: clamp(40px, 5vw, 60px);
}
.about {
  z-index: 10;
  position: relative;
  padding: clamp(80px, 10vw, 120px) 0;
  overflow: hidden;
  background: url(../../assets/img/webp/index/about_bg.webp) no-repeat 50% 50% /
    cover;
}
.about__wrap {
  display: grid;
  gap: 20px clamp(20px, 2vw, 30px);
}
.about__body {
  margin-top: clamp(30px, 3.5vw, 40px);
}
.about__slogan {
  margin-top: clamp(30px, 3.5vw, 40px);
  font-weight: 700;
  font-size: var(--font-sp-3xl);
  line-height: 1.5;
}
.about__txt {
  margin-top: clamp(20px, 2.5vw, 30px);
  line-height: 2.5;
}
.about__sub {
  width: 100%;
  margin: auto;
}

.about__img {
  margin-top: clamp(20px, 2.5vw, 30px);
  border-radius: clamp(5px, 0.75vw, 10px);
  overflow: hidden;
}

.about__button {
  margin-top: clamp(40px, 5vw, 60px);
}
.service {
  z-index: 1;
  position: relative;
  margin-top: clamp(100px, 12.5vw, 150px);
}
.service__wrap {
  display: grid;
  gap: clamp(30px, 5vw, 60px) 0;
}
.service__img {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: clamp(5px, 0.75vw, 10px);
}
.service__body {
  margin-top: clamp(20px, 3vw, 40px);
}
.service__slogan {
  font-weight: 500;
  font-size: var(--font-sp-3xl);
  line-height: 1.5;
}
.service__txt {
  margin-top: clamp(20px, 2.5vw, 30px);
}
.service__button {
  margin-top: clamp(40px, 5vw, 60px);
}
.recruit {
  z-index: 1;
  position: relative;
  margin-top: clamp(100px, 12.5vw, 150px);
  padding: clamp(100px, 12.5vw, 150px) 0;
  color: #fff;
}
.recruit__bg {
  z-index: -1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.recruit__bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.recruit__wrap {
  display: grid;
  gap: clamp(30px, 5vw, 60px) 0;
}
.recruit__img {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: clamp(5px, 0.75vw, 10px);
}
.recruit__body {
  margin-top: clamp(20px, 3vw, 40px);
}
.recruit__slogan {
  font-weight: 500;
  font-size: var(--font-sp-3xl);
  line-height: 1.5;
}
.recruit__list {
  margin-top: clamp(20px, 2.5vw, 30px);
}
.recruit__item {
  padding: clamp(20px, 2.5vw, 30px) 0;
  border-top: 1px solid #7d7d7d;
}
.recruit__term {
  font-weight: 500;
  font-size: var(--font-sp-2xl);
  line-height: 1.5;
}
.recruit__txt {
  margin-top: 10px;
}
.recruit__button {
  margin-top: clamp(20px, 2vw, 30px);
}
.service__tickerGrid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  margin-top: clamp(30px, 3vw, 40px);
  gap: 10px;
}
.news {
  z-index: 1;
  position: relative;
  margin-top: clamp(100px, 12.5vw, 150px);
  color: #fff;
}
.news-common .news__list {
  margin-top: 0;
}
.news__list {
  display: grid;
  margin-top: clamp(30px, 4vw, 50px);
  border-top: 1px solid #e0e0e0;
  line-height: 1.8;
}
.news__item {
  padding: clamp(20px, 2.5vw, 35px) 0;
  border-bottom: 1px solid #e0e0e0;
}
.news__item:hover .u_lineNone {
  background-position: 0 95%;
  background-size: 100% 1px;
}
.news__date {
  font-size: var(--font-sp-2xs);
  font-family: var(--Montserrat-Regular);
}
.news__txt {
  margin-top: 10px;
}
.news__button {
  margin-top: clamp(40px, 5vw, 60px);
}
.conversion {
  z-index: 1;
  position: relative;
  margin-top: clamp(100px, 12.5vw, 150px);
  padding: clamp(100px, 12.5vw, 150px) 0;
  padding-bottom: clamp(140px, 17.5vw, 210px);
  background: var(--main-color);
  color: #fff;
}
.conversion__wrap {
  display: grid;
  gap: clamp(30px, 2.5vw, 40px) clamp(20px, 4vw, 60px);
}
.conversion__slogan {
  margin-top: clamp(20px, 2.5vw, 30px);
  font-weight: 500;
  font-size: var(--font-sp-xl);
  line-height: 1.5;
}
.conversion__button {
  margin: clamp(30px, 3.5vw, 40px) 0 0;
}
.conversion__txt {
  font-size: var(--font-sp-xs);
  line-height: 1.8;
}
.button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 10px 10px 10px 40px;
  border: 1px solid var(--main-color);
  border-radius: 50px;
  background: #fff;
  -webkit-transition: background-color 0.4s ease-out;
  transition: background-color 0.4s ease-out;
}
.button-conversion .button__icon {
  width: 35px;
  height: 35px;
}
.button:hover {
  border-color: #fff;
  background: var(--main-color);
}
.button:hover .button__txt {
  color: #fff;
}
.button:hover .button__icon {
  background: #fff;
}
.button:hover .button__icon:before {
  background: var(--main-color);
}
.button:hover .button__icon:after {
  border-color: var(--main-color);
}
.button-skeleton {
  border-color: #fff;
  background: transparent;
}
.button-skeleton .button__txt {
  color: #fff;
}
.button-job,
.button-contact {
  width: 300px;
  background: var(--main-color);
  text-align: center;
}
.button-job .button__txt,
.button-contact .button__txt {
  margin: auto;
  color: #fff;
  text-align: center;
}
.button-job .button__icon,
.button-contact .button__icon {
  background: #fff;
}
.button-job .button__icon:before,
.button-contact .button__icon:before {
  background: var(--main-color);
}
.button-job .button__icon:after,
.button-contact .button__icon:after {
  border-color: var(--main-color);
}
.button-job:hover,
.button-contact:hover {
  border-color: var(--main-color);
  background: #fff;
}
.button-job:hover .button__txt,
.button-contact:hover .button__txt {
  color: var(--main-color);
}
.button-job:hover .button__icon,
.button-contact:hover .button__icon {
  background: var(--main-color);
}
.button-job:hover .button__icon:before,
.button-contact:hover .button__icon:before {
  background: #fff;
}
.button-job:hover .button__icon:after,
.button-contact:hover .button__icon:after {
  border-color: #fff;
}
.button-contact {
  width: 360px;
  padding-top: 20px;
  padding-bottom: 20px;
}
.button-contact .button__txt {
  font-size: var(--font-sp-m);
}
.button__txt {
  margin-right: 20px;
  color: var(--main-color);
  line-height: 1.1;
}
.button__icon {
  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;
  width: 25px;
  height: 25px;
  border-radius: 50%;
  background: var(--main-color);
  -webkit-transition: background-color 0.4s ease-out;
  transition: background-color 0.4s ease-out;
}
.button__icon:before,
.button__icon:after {
  position: absolute;
  content: '';
}
.button__icon:before {
  width: 12px;
  height: 1px;
  background: #fff;
}
.button__icon:after {
  width: 6px;
  height: 6px;
  margin-left: 5px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  content: '';
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.commonHeader {
  position: relative;
}
.commonHeader__body {
  z-index: 1;
  position: absolute;
  left: 50%;
  width: 100%;
  height: 100%;
  padding: 0 5vw;
  -webkit-transform: translateX(-50%);
  transform: translate(-50%);
}
.commonHeader__head {
  display: grid;
  position: absolute;
  bottom: clamp(40px, 6vw, 100px);
  gap: clamp(20px, 2.5vw, 30px) 0;
}
.commonHeader__jp {
  color: #fff;
  font-size: var(--font-sp-xs);
}
.commonHeader__en {
  color: #fff;
  font-size: clamp(1.75rem, 0.417rem + 6.67vw, 2.25rem);
  font-family: var(--Montserrat-Medium);
}
.commonHeader__singleJp {
  color: #fff;
  font-size: var(--font-sp-4xl);
  line-height: 1.5;
}
.commonHeader__date {
  color: #fff;
  font-size: var(--font-sp-xs);
  font-family: var(--Montserrat-Regular);
}
.commonHeader__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.summary {
  position: relative;
  padding: clamp(100px, 12.5vw, 150px) 0;
  background: var(--main-color);
  color: #fff;
}
.summary__txt {
  margin-top: clamp(30px, 3.5vw, 40px);
  line-height: 2.5;
}
.summary__title {
  color: #fff;
  font-weight: 500;
  font-size: var(--font-sp-3xl);
}
.summary__comment {
  margin: 0 5vw;
  margin-top: clamp(15px, 1.75vw, 20px);
  padding-left: 1em;
  font-size: var(--font-sp-xs);
  line-height: 1.5;
  text-indent: -1em;
}
.tickerImg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 250%;
  margin-top: clamp(60px, 7vw, 80px);
}
.tickerImg__grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.tickerImg__grid-loop {
  -webkit-animation: reverseLoop 50s linear infinite both;
  animation: reverseLoop 50s linear infinite both;
  will-change: transform;
}
.tickerImg__item {
  width: 33.3333333333vw;
  max-width: 180px;
  margin-left: 10px;
}
.tickerImg__img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@-webkit-keyframes reverseLoop {
  0% {
    -webkit-transform: translateX(-100%);
    transform: translate(-100%);
  }
  to {
    -webkit-transform: translateX(0);
    transform: translate(0);
  }
}
@keyframes reverseLoop {
  0% {
    -webkit-transform: translateX(-100%);
    transform: translate(-100%);
  }
  to {
    -webkit-transform: translateX(0);
    transform: translate(0);
  }
}
.spirits {
  margin-top: clamp(100px, 12.5vw, 150px);
}
.spirits__figure {
  margin-top: clamp(30px, 3.5vw, 40px);
}

.spirits__figure img {
  width: 70%;
  margin: 0 auto;
  display: block;
}
.spirits__grid {
  display: grid;
  margin-top: clamp(60px, 7vw, 80px);
  gap: clamp(30px, 3.5vw, 40px) 0;
}
.spirits__en {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-image: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(var(--main-color)),
    to(var(--main-color))
  );
  background-image: linear-gradient(
    var(--main-color) 0%,
    var(--main-color) 100%
  );
  background-position: 0 85%;
  background-size: 100% 1px;
  background-repeat: no-repeat;
  color: var(--main-color);
  font-weight: 500;
  font-size: var(--font-sp-4xl);
  line-height: 1.1;
  font-family: var(--Montserrat-Medium);
}
.spirits__slogan {
  margin-top: clamp(20px, 2.5vw, 30px);
  font-weight: 500;
  font-size: var(--font-sp-2xl);
}
.spirits__txt {
  margin-top: clamp(15px, 1.75vw, 20px);
}
.spirits__img {
  overflow: hidden;
  border-radius: clamp(5px, 0.75vw, 10px);
}
.choose {
  margin-top: clamp(100px, 12.5vw, 150px);
}
.choose__grid {
  display: grid;
  margin-top: clamp(30px, 4vw, 50px);
  gap: clamp(40px, 5vw, 60px);
}
.choose__gridItem {
  display: grid;
  gap: clamp(20px, 2.5vw, 30px);
}
.choose__img {
  overflow: hidden;
  border-radius: clamp(5px, 0.75vw, 10px);
}
.choose__title {
  font-weight: 500;
  font-size: var(--font-sp-xl);
  line-height: 1.5;
}
.choose__txt {
  margin-top: clamp(10px, 1.5vw, 20px);
}
.consultation {
  margin-top: clamp(60px, 7vw, 80px);
}
.consultation__wrap {
  padding: 40px 20px 20px;
  border-radius: 5px;
  background: #f5f5f5;
}
.consultation__title {
  font-weight: 500;
  font-size: var(--font-sp-2xl);
  line-height: 1.5;
}
.consultation__list {
  display: grid;
  margin-top: clamp(20px, 2.25vw, 25px);
  gap: 10px;
}
.consultation__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-line-pack: center;
  align-content: center;
  padding: clamp(15px, 1.75vw, 20px);
  border-radius: 5px;
  background: #fff;
}
.consultation__icon {
  width: 24px;
  height: 24px;
  margin-right: 10px;
  background: url(../../assets/img/webp/service/consultation_icon.svg) no-repeat
    50% 50%/24px auto;
}
.consultation__txt {
  width: calc(100% - 34px);
  font-size: var(--font-sp-l);
  line-height: 1.5;
}
.flow {
  --gap: clamp(20px, 3vw, 40px);
  margin-top: clamp(100px, 12.5vw, 150px);
}
.flow__grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: clamp(30px, 4vw, 50px);
  gap: 30px;
}
.flow__gridItem {
  z-index: 1;
  position: relative;
  padding: 30px;
  border-radius: clamp(5px, 0.75vw, 10px);
  background: #f7f7f7;
}
.flow__gridItem:before {
  z-index: -1;
  position: absolute;
  top: 10px;
  left: 10px;
  width: calc(100% - 20px);
  height: calc(100% - 20px);
  border-radius: clamp(5px, 0.6vw, 8px);
  background: #fff;
  content: '';
}
.flow__icon {
  z-index: 2;
  position: absolute;
  right: calc(50% - 15px);
  bottom: -30px;
  width: 30px;
  margin: auto;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
.flow__icon img {
  display: block;
  width: 40px;
  height: 30px;
}
.flow__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.flow__step {
  display: grid;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 10px 15px;
  gap: 5px;
  border-radius: 5px;
  background: var(--main-color);
  color: #fff;
  line-height: 1.1;
  text-align: center;
}
.flow__en {
  font-size: var(--font-sp-2xs);
  font-family: var(--Montserrat-Regular);
}
.flow__num {
  font-size: var(--font-sp-xl);
  font-family: var(--Montserrat-Medium);
}
.flow__title {
  padding-left: 10px;
  font-weight: 500;
  font-size: var(--font-sp-xl);
  line-height: 1.5;
}
.flow__txt {
  margin-top: clamp(10px, 1.5vw, 20px);
}
.faq {
  margin-top: clamp(100px, 12.5vw, 150px);
  padding: clamp(100px, 12.5vw, 150px) 0;
  background: #f7f7f7;
}
.faq + .conversion {
  margin-top: 0;
}
.faq__block {
  margin-top: clamp(30px, 4vw, 50px);
}
.faq__block + .faq__block {
  margin-top: 10px;
}
.faq__trigger {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 100%;
  padding: clamp(15px, 2vw, 25px);
  overflow: hidden;
  border-radius: 5px;
  background: #fff;
  color: #111;
  font-weight: 500;
  font-size: var(--font-sp-m);
  line-height: 1.5;
  text-align: left;
  cursor: pointer;
  -webkit-transition: background-color 0.4s ease-out;
  transition: background-color 0.4s ease-out;
}
.faq__trigger:before,
.faq__trigger:after {
  position: absolute;
  top: calc(50% - 3px);
  right: clamp(15px, 2vw, 25px);
  width: 15px;
  height: 1px;
  background: var(--main-color);
  content: '';
  -webkit-transition: -webkit-transform 0.4s ease-out;
  transition: -webkit-transform 0.4s ease-out;
  transition: transform 0.4s ease-out;
  transition: transform 0.4s ease-out, -webkit-transform 0.4s ease-out;
}
.faq__trigger:after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
.faq__trigger-active:after,
.faq__trigger:hover:after {
  -webkit-transform: rotate(0deg);
  transform: rotate(0);
}
.faq__trigger-active {
  border-radius: 5px 5px 0 0;
}
.faq__title {
  display: block;
  position: relative;
  width: calc(100% - 55px);
  padding-right: 25px;
  font-size: var(--font-sp-l);
}
.faq__q {
  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;
  width: 40px;
  height: 40px;
  border-radius: 2px;
  background: var(--main-color);
  content: 'Q';
  color: #fff;
  font-size: var(--font-sp-xl);
  line-height: 1;
  font-family: var(--Montserrat-Medium);
}
.faq__target {
  height: 0;
  overflow: hidden;
  border-radius: 0 0 5px 5px;
  background: #fff;
  -webkit-transition: height 0.4s ease;
  transition: height 0.4s ease;
}
.faq__targetInner {
  padding: 0 clamp(15px, 2vw, 25px) clamp(15px, 2vw, 25px);
}
.faq__body {
  position: relative;
  padding: clamp(15px, 2vw, 30px);
  border-radius: 5px;
  background: #f7f7f7;
}
.faq__txt {
  line-height: 1.5;
}
.membersSlider {
  margin-top: clamp(100px, 12.5vw, 150px);
}
.membersSlider__wrap {
  display: grid;
  position: relative;
  grid-template-columns: 100%;
  gap: clamp(40px, 6vw, 60px) 0;
}
.membersSlider__main {
  display: grid;
  z-index: 2;
  position: relative;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.membersSlider__main:before {
  z-index: -1;
  position: absolute;
  top: 0;
  right: 0;
  width: 500%;
  height: 100%;
  background: #fff;
  content: '';
}
.membersSlider__slider {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 250%;
}
.membersSlider__slideGrid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-animation: loop 40s linear infinite both;
  animation: loop 40s linear infinite both;
}
.membersSlider__slideItem {
  width: 33.3333333333vw;
  max-width: 420px;
  margin-left: 10px;
  overflow: hidden;
  border-radius: clamp(5px, 0.75vw, 10px);
}
.membersSlider__img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@-webkit-keyframes loop {
  0% {
    -webkit-transform: translateX(0);
    transform: translate(0);
  }
  to {
    -webkit-transform: translateX(-100%);
    transform: translate(-100%);
  }
}
@keyframes loop {
  0% {
    -webkit-transform: translateX(0);
    transform: translate(0);
  }
  to {
    -webkit-transform: translateX(-100%);
    transform: translate(-100%);
  }
}
.job {
  margin-top: clamp(100px, 12.5vw, 150px);
}
.job__block {
  margin-top: clamp(30px, 4vw, 50px);
}
.job__block + .job__block {
  margin-top: clamp(60px, 7vw, 80px);
}
.job__title {
  line-height: 1.5;
}
.job__cell {
  margin-top: clamp(20px, 2.5vw, 30px);
  table-layout: fixed;
}
.job__name,
.job__col {
  padding: clamp(15px, 2vw, 20px);
  border: 1px solid #e0e0e0;
}
.job__name {
  width: 150px;
  background: #f7f7f7;
}
.job__button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: clamp(30px, 3.5vw, 40px);
}
.accordion .job__cell {
  margin-top: -1px;
  border: 1px solid #000;
}
.accordion__trigger {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  padding: clamp(15px, 1.75vw, 20px);
  background: #647e7d;
  color: #fff;
  text-align: left;
  cursor: pointer;
  -webkit-transition: background-color 0.4s ease-out;
  transition: background-color 0.4s ease-out;
}
.accordion__trigger-active .accordion__title:before {
  top: calc(50% - 2px);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.accordion__title {
  position: relative;
  padding-right: 20px;
  font-size: var(--font-sp-m);
  line-height: 1.5;
}
.accordion__title:before {
  position: absolute;
  top: calc(50% - 6px);
  right: 0;
  width: 10px;
  height: 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  content: '';
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  -webkit-transition: -webkit-transform 0.4s ease-out;
  transition: -webkit-transform 0.4s ease-out;
  transition: transform 0.4s ease-out;
  transition: transform 0.4s ease-out, -webkit-transform 0.4s ease-out;
}
.accordion__target {
  height: 0;
  overflow: hidden;
  -webkit-transition: height 0.4s ease;
  transition: height 0.4s ease;
}
.members {
  margin-top: clamp(60px, 7vw, 80px);
}
.members__grid {
  display: grid;
  margin-top: clamp(40px, 6vw, 80px);
  gap: clamp(20px, 3vw, 40px);
}
.members__gridItem {
  padding: clamp(10px, 1.5vw, 20px) clamp(10px, 1.5vw, 20px)
    clamp(30px, 3.5vw, 40px);
  border-radius: clamp(5px, 0.75vw, 10px);
  background: #fff;
  -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  box-shadow: 0 0 10px #0000001a;
}
.members__img {
  overflow: hidden;
  border-radius: clamp(5px, 0.75vw, 10px);
}
.members__body {
  padding: clamp(20px, 2.5vw, 30px) 10px 0;
}
.members__job,
.modal__job {
  color: var(--main-color);
  font-size: var(--font-sp-xs);
  line-height: 1.1;
}
.members__en,
.modal__en {
  margin-top: 10px;
  color: var(--main-color);
  font-size: var(--font-sp-xs);
  line-height: 1.1;
  font-family: var(--Montserrat-Regular);
}
.members__en-space,
.modal__en-space {
  margin-top: clamp(10px, 1.25vw, 15px);
}
.members__txt {
  width: 100%;
  margin-top: clamp(10px, 1.5vw, 20px);
  font-size: 16px;
}
.company {
  margin-top: clamp(100px, 12.5vw, 150px);
}
.company__cell {
  margin-top: clamp(30px, 4vw, 50px);
}
.company__row {
  padding: clamp(20px, 3vw, 35px) 0;
  border-top: 1px solid #e0e0e0;
}
.company__name {
  font-weight: 500;
}
.company__txt + .company__txt {
  margin-top: clamp(10px, 1.5vw, 20px);
}
.company__map {
  margin-top: clamp(10px, 2vw, 20px);
  overflow: hidden;
  border-radius: 5px;
}
.company__map iframe {
  display: block;
  aspect-ratio: 16/9;
  width: 100%;
  height: auto;
}
.history {
  /* margin-top: clamp(100px, 12.5vw, 150px); */
  padding: clamp(100px, 12.5vw, 150px) 0;
  background: #f5f5f5;
}
.history__grid {
  display: grid;
  position: relative;
  margin-top: clamp(30px, 4vw, 50px);
}
.history__grid:before {
  display: block;
  position: absolute;
  top: 10px;
  left: 10px;
  width: 1px;
  height: calc(100% - 20px);
  background: var(--main-color);
  content: '';
}
.history__gridItem {
  position: relative;
}
.history__gridItem + .history__gridItem {
  margin-top: clamp(25px, 3vw, 40px);
}
.history__date {
  position: relative;
  width: 100px;
  margin-left: 31px;
  padding: 5px;
  border-radius: 5px;
  background: var(--main-color);
  color: #fff;
  font-size: var(--font-sp-xs);
  line-height: 1.1;
  text-align: center;
}
.history__date:before {
  display: block;
  position: absolute;
  top: calc(50% - 10px);
  left: -31px;
  width: 21px;
  height: 21px;
  border: 5px solid #95f0ee;
  border-radius: 50%;
  background: var(--main-color);
  content: '';
}
.history__txt {
  position: relative;
  margin: 10px 0 0 31px;
}
.message {
  margin-top: clamp(100px, 12.5vw, 150px);
  margin-bottom: clamp(100px, 12.5vw, 150px);
}
.message__grid {
  display: grid;
  gap: clamp(30px, 3.5vw, 40px) 0;
}
.message__thumbnail {
  margin-top: clamp(20px, 2.5vw, 30px);
  aspect-ratio: 1/1;
  overflow: hidden;
}

.message__thumbnail.disp-sp {
  width: 70%;
  margin-left: auto;
  margin-right: auto;
}

.message__img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 5px;
}
.message__slogan {
  font-weight: 500;
  font-size: var(--font-sp-2xl);
  line-height: 1.5;
}
.message__txt {
  margin-top: clamp(20px, 2.5vw, 30px);
}
.message__mainGrid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  margin-top: clamp(20px, 2.5vw, 30px);
  font-size: var(--font-sp-xs);
}
.message__name {
  font-size: var(--font-sp-l);
}
.privacy {
  margin-top: clamp(80px, 9vw, 100px);
}
.privacy__block {
  margin-top: clamp(40px, 5vw, 60px);
}
.privacy__body {
  margin-top: clamp(20px, 2.5vw, 30px);
}
.privacy__title {
  padding-bottom: clamp(15px, 1.75vw, 20px);
  border-bottom: 1px solid #e0e0e0;
  font-weight: 500;
  font-size: var(--font-sp-xl);
  line-height: 1.5;
}
.privacy__title + .privacy__txt {
  margin-top: clamp(15px, 1.75vw, 20px);
}
.privacy__bodyTitle {
  font-weight: 500;
}
.privacy__bodyTitle + .privacy__txt {
  margin-top: 10px;
}
.privacy__txt {
  margin-top: clamp(15px, 1.75vw, 20px);
}
.privacy__list {
  margin-top: 10px;
}
.error404 {
  margin-top: clamp(100px, 12.5vw, 150px);
}
.error404__txt {
  margin-top: 10px;
}
.error404__txt + .error404__txt {
  margin-top: 20px;
}
.tickerTxt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 1;
  position: absolute;
  top: 50%;
  width: 100%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.tickerTxt__txt {
  color: #fff3;
  font-size: clamp(3.75rem, -1.25rem + 25vw, 6.25rem);
  line-height: 1;
  font-family: var(--Montserrat-Bold);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
  -webkit-animation: defaultsLoop 200s linear infinite;
  animation: defaultsLoop 200s linear infinite;
  will-change: transform;
}
@-webkit-keyframes defaultsLoop {
  0% {
    -webkit-transform: translateX(0);
    transform: translate(0);
  }
  to {
    -webkit-transform: translateX(-100%);
    transform: translate(-100%);
  }
}
@keyframes defaultsLoop {
  0% {
    -webkit-transform: translateX(0);
    transform: translate(0);
  }
  to {
    -webkit-transform: translateX(-100%);
    transform: translate(-100%);
  }
}
.bread {
  display: none;
}
.bread__link {
  color: #fff;
  text-decoration: none;
}
.bread__link:hover {
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .htmlOpen .drower {
    -webkit-transform: translateX(100%);
    transform: translate(100%);
  }
  .hamburger {
    display: none;
  }
  .header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: absolute;
    top: 0;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .header__logo {
    position: relative;
    top: 62px;
    width: clamp(140px, 20vw, 260px);
  }
  .drower {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    top: 62px;
    right: clamp(20px, 2.5vw, 30px);
    width: auto;
    height: auto;
    padding: 0;
    overflow: visible;
    background: transparent;
    -webkit-transform: none;
    transform: none;
    will-change: unset;
  }
  .drower__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: clamp(20px, 3vw, 40px);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .drower__item {
    position: relative;
    -webkit-transform: none;
    transform: none;
    -webkit-transition: background-color 0.4s ease-out;
    transition: background-color 0.4s ease-out;
  }
  .drower__item:hover .drower__jp {
    background-position: 0 95%;
    background-size: 100% 1px;
  }
  .drower__item-contact .drower__listLink {
    margin: 0;
    padding: 18px clamp(20px, 4vw, 60px);
    border-radius: 30px;
    background: var(--main-color);
    -webkit-transition: background-color 0.4s ease-out;
    transition: background-color 0.4s ease-out;
  }
  .drower__item-contact .drower__jp {
    background: none;
    color: #fff;
    font-size: var(--font-xs);
  }
  .drower__item-contact:hover .drower__listLink {
    background: #fff;
  }
  .drower__item-contact:hover .drower__jp {
    color: var(--main-color);
  }
  .drower__listLink {
    padding: 0;
  }
  .drower__en {
    display: none;
  }
  .drower__jp {
    margin-top: 0;
    background-image: -webkit-gradient(
      linear,
      left top,
      left bottom,
      from(#fff),
      to(#fff)
    );
    background-image: linear-gradient(#fff, #fff);
    background-position: 100% 95%;
    background-size: 0% 1px;
    background-repeat: no-repeat;
    font-size: clamp(0.813rem, 0.52rem + 0.6vw, 1rem);
    letter-spacing: 0.05em;
    -webkit-transition: background-size 0.5s ease;
    transition: background-size 0.5s ease;
  }
  .drower__footer {
    display: none;
  }
  .footer {
    margin-top: -60px;
  }
  .footer__sloganEn {
    font-size: clamp(4.5rem, -1.155rem + 11.6vw, 8.125rem);
  }
  .footer__sloganJp {
    top: 12%;
    font-size: var(--font-4xl);
  }
  .footer__sloganPlus {
    top: 0;
  }
  .footer__wrap {
    -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;
  }
  .footer__logo {
    width: clamp(140px, 20vw, 260px);
  }
  .footer__logo + .footer__address {
    margin-top: 30px;
  }
  .footer__address {
    font-size: var(--font-2xs);
  }
  .footer__sub {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    gap: 0 clamp(40px, 6vw, 80px);
  }
  .footer__item {
    font-size: var(--font-2xs);
  }
  .footer__lower {
    -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;
    font-size: var(--font-2xs);
  }
  .l_layout {
    max-width: calc(780px + 12vw);
    margin: auto;
    padding: 0 6vw;
  }
  .l_layout-md {
    max-width: calc(800px + 12vw);
  }
  .l_layout-lg {
    max-width: calc(1000px + 12vw);
  }
  .l_layout-xl {
    max-width: calc(1200px + 12vw);
  }
  .l_layout-xxl {
    max-width: calc(1400px + 12vw);
  }
  .l_layout-xxxl {
    max-width: calc(1600px + 12vw);
  }
  .l_layout-xxxxl {
    max-width: calc(1800px + 12vw);
  }
  .u_mobile {
    display: none;
  }
  .u_pc {
    display: block;
  }
  .contact__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .contact__name {
    width: 280px;
  }
  .contact__txtSmall {
    font-size: var(--font-2xs);
  }
  .contact__require {
    padding: 2px 10px 3px;
    font-size: 0.75rem;
  }
  .contact__col {
    width: calc(100% - 300px);
    margin-top: 0;
  }
  .contact__flat {
    padding: 18px;
    font-size: var(--font-m);
  }
  .contact__flat-textarea {
    height: 160px;
  }
  .contact input[type='checkbox'] + span:before,
  .contact input[type='radio'] + span:before {
    width: 26px;
    height: 26px;
  }
  .swiper-button-prev:before {
    right: calc(50% - 7px);
  }
  .swiper-button-next:before {
    right: calc(50% - 3px);
  }
  .floating .swiper-button-prev:before,
  .floating .swiper-button-next:before {
    top: calc(50% - 5px);
    width: 10px;
    height: 10px;
  }
  .modal__target .swiper-button-prev,
  .modal__target .swiper-button-next {
    display: block;
  }
  .modal__target .swiper-button-lock {
    display: none;
  }
  .modal__name,
  .modal__title {
    font-size: var(--font-2xl);
  }
  .modal__content {
    padding: 40px 2vw;
  }
  .modal__close {
    width: 50px;
    height: 50px;
    margin: 0;
  }
  .entry h2 {
    font-size: clamp(1.5rem, 1.057rem + 0.91vw, 1.875rem);
  }
  .entry h3 {
    padding-left: 20px;
    font-size: clamp(1.25rem, 0.955rem + 0.61vw, 1.5rem);
  }
  .entry h4 {
    font-size: clamp(1rem, 0.705rem + 0.61vw, 1.25rem);
  }
  .entry p,
  .entry ol,
  .entry ul,
  .entry figure,
  .entry .wp-caption {
    font-size: clamp(0.938rem, 0.738rem + 0.41vw, 1rem);
  }
  .entry p + p,
  .entry p + ol,
  .entry p + ul,
  .entry p + figure,
  .entry ol + p,
  .entry ol + ol,
  .entry ol + ul,
  .entry ol + figure,
  .entry ul + p,
  .entry ul + ol,
  .entry ul + ul,
  .entry ul + figure,
  .entry figure + p,
  .entry figure + ol,
  .entry figure + ul,
  .entry figure + figure,
  .entry .wp-caption + p,
  .entry .wp-caption + ol,
  .entry .wp-caption + ul,
  .entry .wp-caption + figure {
    margin-top: 40px;
  }
  .entry p + h2,
  .entry ol + h2,
  .entry ul + h2,
  .entry figure + h2,
  .entry .wp-caption + h2 {
    margin-top: 80px;
  }
  .entry p + h3,
  .entry p + h4,
  .entry ol + h3,
  .entry ol + h4,
  .entry ul + h3,
  .entry ul + h4,
  .entry figure + h3,
  .entry figure + h4,
  .entry .wp-caption + h3,
  .entry .wp-caption + h4 {
    margin-top: 60px;
  }
  .entry figure + h3,
  .entry figure + h4 {
    margin-top: 60px;
  }
  .entry p + .wp-caption {
    margin-top: 20px;
  }
  .entry .wp-caption-text {
    margin-top: 15px;
    font-size: 0.8125rem;
  }
  .pagination {
    margin-top: 60px;
  }
  .page-numbers {
    width: 60px;
    height: 60px;
    font-size: clamp(0.938rem, 0.806rem + 0.27vw, 1rem);
  }
  .postNav__return {
    width: 30px;
  }
  .postNav__button {
    padding: 10px;
    gap: 0 20px;
  }
  .postNav__button-left {
    padding-right: 40px;
  }
  .postNav__button-left .postNav__icon:before {
    margin-left: -7px;
  }
  .postNav__button-right {
    padding-left: 40px;
  }
  .postNav__button-right .postNav__icon:before {
    margin-right: -7px;
  }
  .postNav__icon {
    width: 35px;
    height: 35px;
  }
  .postNav__icon:after {
    width: 15px;
  }
  .postNav__txt {
    font-size: var(--font-s);
  }
  body {
    font-size: clamp(0.875rem, 0.68rem + 0.4vw, 1rem);
  }
  .mainVisual {
    height: 100vh;
  }
  .mainVisual__img {
    width: 100%;
    height: 110vh;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .mainVisual__body {
    bottom: 20%;
    left: 50%;
    max-width: calc(1400px + 12vw);
    -webkit-transform: translateX(-50%);
    transform: translate(-50%);
  }
  .mainVisual__slogan {
    font-size: clamp(3rem, -0.12rem + 6.4vw, 5rem);
  }
  .floating__swiper {
    width: 82%;
  }
  .floating__title {
    width: 18%;
  }
  .floating__grid {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    gap: 10px clamp(10px, 1.5vw, 20px);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: clamp(20px, 2.5vw, 30px) calc(70px + clamp(15px, 1.8vw, 20px))
      clamp(20px, 2.5vw, 30px) clamp(20px, 2.5vw, 30px);
  }
  .floating__date {
    font-size: var(--font-2xs);
  }
  .floating__txt {
    font-size: var(--font-xs);
  }
  .head__jp {
    font-size: var(--font-xs);
    letter-spacing: 0.025em;
  }
  .head__en {
    font-size: clamp(2.25rem, -0.09rem + 4.8vw, 3.75rem);
    letter-spacing: 0.03em;
  }
  .about__wrap {
    grid-template-columns: 55% 1fr;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .about__body {
    margin-top: 0;
  }
  .about__slogan {
    font-size: clamp(2rem, 1.61rem + 0.8vw, 2.25rem);
  }
  .about__txt {
    font-size: var(--font-l);
  }
  .about__sub {
    width: 120%;
  }
  .service__wrap {
    grid-template-columns: repeat(2, 1fr);
    gap: 0 clamp(20px, 5vw, 100px);
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start;
  }
  .service__slogan {
    font-size: var(--font-4xl);
  }
  .recruit__wrap {
    grid-template-columns: repeat(2, 1fr);
    gap: 0 clamp(20px, 5vw, 100px);
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start;
  }
  .recruit__sub {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }
  .recruit__slogan {
    font-size: var(--font-4xl);
  }
  .recruit__term {
    font-size: var(--font-2xl);
  }
  .service__tickerGrid {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  }
  .news__item {
    display: grid;
    grid-template-columns: clamp(60px, 7vw, 80px) 1fr;
    gap: clamp(60px, 8vw, 100px);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .news__date {
    font-size: var(--font-2xs);
  }
  .news__txt {
    margin-top: 0;
  }
  .news__button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
  .conversion__wrap {
    grid-template-columns: repeat(2, 1fr);
  }
  .conversion__slogan {
    font-size: var(--font-2xl);
  }
  .conversion__txt {
    font-size: var(--font-xs);
  }
  .button {
    padding-left: 50px;
  }
  .button-conversion {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
    padding: 20px;
    text-align: center;
  }
  .button-conversion .button__txt {
    margin: auto;
    text-align: center;
  }
  .button-contact .button__txt {
    font-size: var(--font-m);
  }
  .button__icon {
    width: 35px;
    height: 35px;
  }
  .commonHeader-single .commonHeader__body {
    max-width: calc(1200px + 12vw);
  }
  .commonHeader__body {
    max-width: calc(1400px + 12vw);
    padding: 0 6vw;
  }
  .commonHeader__jp {
    font-size: var(--font-m);
  }
  .commonHeader__en {
    font-size: clamp(2.625rem, -0.105rem + 5.6vw, 4.375rem);
  }
  .commonHeader__singleJp {
    font-size: var(--font-5xl);
  }
  .commonHeader__date {
    font-size: var(--font-s);
  }
  .commonHeader__picture {
    height: clamp(500px, 55vw, 600px);
  }
  .commonHeader__picture-gradation {
    height: clamp(300px, 35vw, 400px);
  }
  .summary {
    text-align: center;
  }
  .summary__txt {
    font-size: var(--font-l);
  }
  .summary__title {
    font-size: var(--font-5xl);
  }
  .summary__comment {
    margin-top: 30px;
    margin-left: 30px;
    font-size: var(--font-xs);
    text-align: center;
  }
  .tickerImg__item {
    width: 16.6666666667vw;
    margin-left: 20px;
  }

  .spirits__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(30px, 5vw, 100px);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .spirits__grid-reverse .spirits__img {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
  .spirits__grid-reverse .spirits__main {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }
  .spirits__en {
    font-size: clamp(2rem, 0.44rem + 3.2vw, 3rem);
  }
  .spirits__slogan {
    font-size: var(--font-2xl);
  }
  .choose__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 0 clamp(20px, 3vw, 40px);
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start;
  }
  .choose__title {
    font-size: var(--font-2xl);
  }
  .consultation__wrap {
    padding: clamp(40px, 4.5vw, 50px) clamp(20px, 3vw, 40px)
      clamp(20px, 3vw, 40px);
  }
  .consultation__title {
    font-size: var(--font-2xl);
  }
  .consultation__icon {
    width: 30px;
    height: 30px;
    margin-right: 20px;
    background-size: 30px auto;
  }
  .consultation__txt {
    width: calc(100% - 50px);
    font-size: var(--font-l);
  }
  .flow__grid {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    gap: var(--gap);
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
  .flow__gridItem {
    width: calc((100% - var(--gap) * 1) / 2);
    padding: 40px;
  }
  .flow__gridItem:nth-of-type(2) .flow__icon,
  .flow__gridItem:nth-of-type(4) .flow__icon {
    display: none;
  }
  .flow__icon {
    right: clamp(-40px, -3vw, -20px);
    bottom: calc(50% - 15px);
    width: clamp(20px, 3vw, 40px);
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  .flow__icon img {
    width: 40px;
  }
  .flow__en {
    font-size: var(--font-2xs);
  }
  .flow__num {
    font-size: var(--font-xl);
  }
  .flow__title {
    padding-left: 15px;
    font-size: var(--font-2xl);
  }
  .faq__trigger {
    padding: clamp(20px, 2.5vw, 30px) clamp(30px, 4vw, 60px);
    font-size: var(--font-sp-2xl);
  }
  .faq__trigger:before,
  .faq__trigger:after {
    right: clamp(30px, 4vw, 60px);
    width: 21px;
  }
  .faq__title {
    width: calc(100% - 70px);
    padding-right: 40px;
    font-size: var(--font-l);
  }
  .faq__q {
    width: 50px;
    height: 50px;
    font-size: var(--font-2xl);
  }
  .faq__targetInner {
    padding: 0 clamp(30px, 4vw, 60px) clamp(20px, 2.5vw, 30px);
  }
  .membersSlider__slideItem {
    width: 16.6666666667vw;
    margin-left: 20px;
  }
  .job__name {
    width: 200px;
  }
  .accordion__trigger {
    padding: clamp(20px, 2.5vw, 30px);
  }
  .accordion__title {
    font-size: var(--font-m);
  }
  .members__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .members__job,
  .modal__job,
  .members__en,
  .modal__en {
    font-size: var(--font-xs);
  }
  .company__row {
    display: grid;
    grid-template-columns: 24% 1fr;
  }
  .history__grid:before {
    left: 150px;
  }
  .history__gridItem {
    display: grid;
    grid-template-columns: calc(125px + 20%) 1fr;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .history__date {
    width: 120px;
    margin-left: 0;
    padding: 10px;
    font-size: var(--font-s);
  }
  .history__date:before {
    right: -41px;
    left: auto;
  }
  .history__txt {
    margin: 0;
    padding-left: 20px;
  }
  .history__txt:before {
    position: absolute;
    top: 50%;
    left: -20%;
    width: 20%;
    height: 1px;
    background: var(--main-color);
    content: '';
  }
  .message__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0 clamp(20px, 4vw, 60px);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .message__slogan {
    font-size: var(--font-2xl);
  }
  .message__mainGrid {
    font-size: var(--font-xs);
  }
  .message__name {
    font-size: var(--font-l);
  }
  .privacy__title {
    font-size: var(--font-xl);
  }
  .error404__txt {
    margin-top: 0;
  }
  .tickerTxt__txt {
    font-size: clamp(11.25rem, 5.4rem + 12vw, 15rem);
  }
  .bread {
    display: block;
    z-index: 1;
    position: absolute;
    top: 110px;
    right: clamp(20px, 2.5vw, 30px);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    color: #fff;
    font-size: var(--font-3xs);
    line-height: 1.1;
  }
}
@media screen and (min-width: 768px) and (min-width: 1440px) {
  .spirits__grid-reverse .spirits__main {
    padding-right: 100px;
    padding-left: 0;
  }
}
@media screen and (min-width: 1024px) {
  .footer__sloganPlus {
    top: 0;
    width: 40px;
    height: 40px;
  }
  .flow__gridItem {
    width: calc((100% - var(--gap) * 2) / 3);
  }
  .flow__gridItem:nth-of-type(2) .flow__icon,
  .flow__gridItem:nth-of-type(4) .flow__icon {
    display: block;
  }
  .flow__gridItem:nth-of-type(3) .flow__icon {
    display: none;
  }
  .membersSlider__wrap {
    grid-template-columns: 35% 70%;
  }
  .members__grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .company__map iframe {
    height: 400px;
  }
}
@media screen and (min-width: 1200px) {
  .footer__sloganJp {
    top: 14%;
  }
  .l_layout__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .l_layout__right {
    width: calc(100% - 300px);
  }
  .service__wrap,
  .recruit__wrap {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
@media screen and (min-width: 1440px) {
  .service__body {
    padding-right: 100px;
  }
  .spirits__main {
    padding-left: 100px;
  }
}

/* ===============================================
   モーダルウィンドウ(.modal__block)内のコンテンツスタイル
   =============================================== */

.modal__block {
  line-height: 2;
  color: var(--txt-color);
}

/* --- 見出し (H1-H6) --- */
.modal__block h1,
.modal__block h2,
.modal__block h3,
.modal__block h4,
.modal__block h5,
.modal__block h6 {
  font-weight: 500;
  line-height: 1.5;
  color: var(--txt-color);
  margin-top: 2em;
  margin-bottom: 1em;
}

/* 見出し1 */
.modal__block h1 {
  font-size: var(--font-3xl); /* モーダル内なので少し抑えめに */
  border-bottom: 2px solid var(--broder-color);
  padding-bottom: 0.5em;
}

/* 見出し2 */
.modal__block h2 {
  font-size: var(--font-2xl);
  padding-bottom: 0.4em;
  border-bottom: 1px solid var(--broder-color);
  position: relative;
}
.modal__block h2::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 80px;
  height: 2px;
  background-color: var(--main-color);
}

/* 見出し3 */
.modal__block h3 {
  font-size: var(--font-xl);
  padding-left: 0.8em;
  border-left: 5px solid var(--main-color);
}

/* 見出し4 */
.modal__block h4 {
  font-size: var(--font-l);
  font-weight: bold;
  color: var(--sub-color);
}

/* 見出し5 */
.modal__block h5 {
  font-size: var(--font-m);
  font-weight: bold;
}

/* 見出し6 */
.modal__block h6 {
  font-size: var(--font-s);
  font-weight: bold;
  font-style: italic;
}

/* --- 段落・リンク --- */
/* 既存の p+p のマージンスタイルと競合しないよう、margin-bottomで統一 */
.modal__block p {
  margin-top: 0;
  margin-bottom: 1.5em;
}
.modal__block p:last-child {
  margin-bottom: 0;
}

.modal__block a {
  color: var(--main-color);
  text-decoration: underline;
  transition: opacity 0.3s;
}
.modal__block a:hover {
  opacity: 0.7;
  text-decoration: none;
}

/* --- リスト --- */
/* 既存のスタイルを継承しつつ、余白を調整 */
.modal__block ul,
.modal__block ol {
  padding-left: 1.5em; /* liのmargin-leftからpadding-leftに変更 */
  margin-bottom: 1.5em;
}
.modal__block ul {
  list-style-type: disc;
}
.modal__block ol {
  list-style-type: decimal;
}
.modal__block li {
  margin-left: 0; /* liの左マージンをリセット */
  margin-bottom: 0.5em;
}
.modal__block ul ul,
.modal__block ul ol,
.modal__block ol ul,
.modal__block ol ol {
  margin-top: 0.5em;
}

/* --- その他の要素 --- */

/* 引用 */
.modal__block blockquote {
  margin: 1.5em 0;
  padding: 1em 1.5em;
  background-color: #f7f7f7;
  border-left: 5px solid var(--main-color);
}
.modal__block blockquote p:last-child {
  margin-bottom: 0;
}

/* 水平線 */
.modal__block hr {
  border: 0;
  height: 1px;
  background-color: var(--broder-color);
  margin: 2.5em 0;
}

/* 太字・斜体 */
.modal__block strong {
  font-weight: bold;
}
.modal__block em {
  font-style: italic;
}

/* テーブル */
.modal__block table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1.5em;
  border: 1px solid var(--broder-color);
}
.modal__block th,
.modal__block td {
  padding: 0.8em 1em;
  border: 1px solid var(--broder-color);
  text-align: left;
}
.modal__block th {
  background-color: #f7f7f7;
  font-weight: bold;
}

/* スライダー画像を正方形にトリミングするスタイル */
.imgslider .swiper-slide {
  /* コンテナ自体を正方形に定義します */
  aspect-ratio: 1 / 1;
  overflow: hidden; /* はみ出しを確実に隠します */
}

.modal__body .imgslider .swiper-slide img {
  /* 画像をコンテナの幅と高さに100%合わせます */
  width: 100%;
  height: 100%;

  /* 画像の比率を維持したままコンテナを埋め、はみ出す部分をトリミングします */
  object-fit: cover;

  /* 中央を基準にトリミングします */
  object-position: center;
}

/* スライダー領域のタッチ操作を明示 */
.imgslider .swiper {
  touch-action: pan-y; /* 水平スライダーの場合 */
}
/* スマホ表示時（画面幅767px以下）のみ矢印ボタンを調整 */
@media screen and (max-width: 767px) {
  /* 矢印ボタンを表示する */
  .modal__target .swiper-button-prev,
  .modal__target .swiper-button-next {
    display: block !important;
    width: 30px;
    height: 30px;
  }
  .spirits__figure img {
    width: 100%;
  }

  /* 矢印ボタンの位置とデザインを調整 */
  .modal__target .swiper-button-prev {
    left: 5px; /* 画面左端からの距離 */
    color: var(--txt-color);
    opacity: 0.7;
    background-color: #fff;
  }

  .modal__target .swiper-button-next {
    right: 5px; /* 画面右端からの距離 */
    color: var(--txt-color);
    opacity: 0.7;
    background-color: #fff;
  }

  /* 矢印アイコンのサイズ調整 */
  .modal__target .swiper-button-prev::after,
  .modal__target .swiper-button-next::after {
    font-size: 1.5em;
  }
}

/* 社員一覧の画像コンテナのスタイル */
.members__img {
  /* コンテナの縦横比を 4:5 に固定します。この比率はお好みで調整可能です */
  aspect-ratio: 6 / 7;
  overflow: hidden; /* はみ出した部分を隠します */
}

/* コンテナ内の画像自体のスタイル */
.members__img img {
  /* 画像をコンテナいっぱいに広げます */
  width: 100%;
  height: 100%;

  /* 画像の比率を維持したままコンテナを覆い、はみ出した部分をトリミングします */
  object-fit: cover;

  /* 中央を基準にトリミングします */
  object-position: center;
}

/* 追加 */
/* Mobile-first: SPで表示、PCで非表示 */
.disp-sp {
  display: block !important;
}
.disp-pc {
  display: none !important;
}

/* PC幅(>=768px)では反転 */
@media (min-width: 768px) {
  .disp-sp {
    display: none !important;
  }
  .disp-pc {
    display: block !important;
  }
}
