@charset "UTF-8";
select::-ms-expand {
  display: none;
}

html {
  height: 100%;
  font-size: 62.5%;
  background: #fff;
  overflow-y: scroll;
}
@media (max-width: 480px) {
  html {
    font-size: 1.9230769231vw;
  }
}
@media (max-width: 480px) {
  html::-webkit-scrollbar {
    display: none;
  }
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
form,
fieldset,
input,
textarea,
p,
th,
td {
  padding: 0;
  margin: 0;
}

address,
caption,
em,
strong,
th {
  font-style: normal;
}

caption,
th {
  text-align: left;
}

hr,
legend {
  display: none;
}

figure {
  margin: 0;
}

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

li {
  list-style-type: none;
}

table,
ol,
ul,
dl,
blockquote,
pre {
  margin-bottom: 0px;
}

p {
  margin-bottom: 0;
}

a img,
fieldset {
  border: none;
}

article,
aside,
footer,
header,
hgroup,
nav,
section {
  display: block;
}

*:not(:focus-visible) {
  outline: none;
}

select {
  color: #333;
}

a {
  text-decoration: none;
}

a:link {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

* {
  box-sizing: border-box;
}

img {
  width: 100%;
  display: block;
}
@media (max-width: 480px) {
  img {
    height: auto;
  }
}

button {
  font-family: "Noto Sans JP", sans-serif;
  background-color: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
button:not(:focus-visible) {
  outline: none;
}

input,
textarea {
  -webkit-appearance: none;
}

label {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

dialog::backdrop {
  background-color: rgba(0, 0, 0, 0.7019607843);
}

table {
  border-collapse: collapse;
}

/*-----------------------------------------*/
@media (max-width: 480px) {
  .only-pc {
    display: none !important;
  }
}

.only-sp {
  display: none;
}
@media (max-width: 480px) {
  .only-sp {
    display: block !important;
  }
}

/*-----------------------------------------*/
body {
  position: relative;
  -webkit-text-size-adjust: none;
  width: 100%;
  max-width: 100%;
  min-width: 1220px;
  font-size: 1.6rem;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  letter-spacing: 0.05em;
  line-height: 1.8;
  margin: 0px;
  overflow-x: hidden;
}
@media (max-width: 480px) {
  body {
    font-size: 3.5897435897vw;
    max-width: 100%;
    min-width: auto;
    letter-spacing: 0.06em;
    line-height: 1.5;
  }
}

.wrap {
  width: 1200px;
  max-width: 100%;
  margin: 0 auto;
}
@media (max-width: 480px) {
  .wrap {
    padding: 0 3.8461538462vw;
  }
}
.wrap.w1200 {
  width: 1200px;
  max-width: 100%;
}
.wrap.w1100 {
  width: 1100px;
  max-width: 100%;
}
.wrap.w1000 {
  width: 1000px;
  max-width: 100%;
}
.wrap.w928 {
  width: 928px;
  max-width: 100%;
}
.wrap.w900 {
  width: 900px;
  max-width: 100%;
}
.wrap.w800 {
  width: 800px;
  max-width: 100%;
}
.wrap.w865 {
  width: 865px;
  max-width: 100%;
}
.wrap.w736 {
  width: 736px;
  max-width: 100%;
}
.wrap.w700 {
  width: 700px;
  max-width: 100%;
}
.wrap.w650 {
  width: 650px;
  max-width: 100%;
}
.wrap.w600 {
  width: 600px;
  max-width: 100%;
}
.wrap.w544 {
  width: 544px;
  max-width: 100%;
}

/*============================
.contents
============================*/
.contents {
  background-color: #000000;
  color: #fff;
}
.contents .unit-ttl01 {
  color: #fff;
}
.contents .contents-header {
  height: 220px;
  position: relative;
}
@media (max-width: 480px) {
  .contents .contents-header {
    height: 28.2051282051vw;
  }
}
.contents .contents-header.bg01 {
  background: url(../img/title-bg01.jpg) no-repeat center/cover;
}
@media (max-width: 480px) {
  .contents .contents-header.bg01 {
    background-image: url(../img/title-bg01-sp.jpg);
  }
}
.contents .contents-header.bg02 {
  background: url(../img/title-bg02.jpg) no-repeat center/cover;
}
@media (max-width: 480px) {
  .contents .contents-header.bg02 {
    background-image: url(../img/title-bg02-sp.jpg);
  }
}
.contents .contents-header.bg03 {
  background: url(../img/title-bg03.jpg) no-repeat center/cover;
}
@media (max-width: 480px) {
  .contents .contents-header.bg03 {
    background-image: url(../img/title-bg03-sp.jpg);
  }
}
.contents .contents-header.bg04 {
  background: url(../img/title-bg04.jpg) no-repeat center/cover;
}
@media (max-width: 480px) {
  .contents .contents-header.bg04 {
    background-image: url(../img/title-bg04-sp.jpg);
  }
}
.contents .contents-header .contents-header__in {
  display: flex;
  align-items: center;
  height: 100%;
  position: relative;
}
.contents .contents-header .contents-header-ttl {
  color: #fff;
  line-height: 1.4;
}
.contents .contents-header .contents-header-ttl .sub {
  font-size: 1.6rem;
}
@media (max-width: 480px) {
  .contents .contents-header .contents-header-ttl .sub {
    font-size: 2.9487179487vw;
  }
}
.contents .contents-header .contents-header-ttl .main {
  font-weight: 500;
  font-size: 4rem;
}
@media (max-width: 480px) {
  .contents .contents-header .contents-header-ttl .main {
    font-size: 5.7692307692vw;
  }
}
.contents .contents-header .ttl-en {
  color: #fff;
  bottom: -10px;
  right: 0;
}
@media (max-width: 480px) {
  .contents .contents-header .ttl-en {
    bottom: -0.7692307692vw;
  }
}
.contents .contents-header .ttl-en .dilate {
  font-size: 22.2rem;
}
@media (max-width: 480px) {
  .contents .contents-header .ttl-en .dilate {
    font-size: 19.2307692308vw;
  }
}
.contents .contents-section {
  padding: 90px 0;
}
@media (max-width: 480px) {
  .contents .contents-section {
    padding: 11.5384615385vw 0;
  }
}
.contents .contents-section:nth-of-type(1) {
  padding-top: 180px;
}
@media (max-width: 480px) {
  .contents .contents-section:nth-of-type(1) {
    padding-top: 23.0769230769vw;
  }
}
.contents .contents-section:last-child {
  padding-bottom: 180px;
}
@media (max-width: 480px) {
  .contents .contents-section:last-child {
    padding-bottom: 23.0769230769vw;
  }
}

/*============================
#header
============================*/
#header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  padding: 13px;
  background-color: #fff;
  box-shadow: 0 -4px 10px #ccc;
}
@media (max-width: 480px) {
  #header {
    padding: 0;
  }
}
#header .header-nav {
  min-width: 1200px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  position: relative;
}
@media (max-width: 480px) {
  #header .header-nav {
    min-width: auto;
    gap: 4.8717948718vw;
    justify-content: flex-start;
    align-items: center;
    padding: 3.8461538462vw;
  }
}
#header .header-nav .header__logo {
  display: flex;
  gap: 26px;
}
#header .header-nav .header__logo .link {
  width: 197px;
  display: block;
}
@media (max-width: 480px) {
  #header .header-nav .header__logo .link {
    width: 36.0256410256vw;
  }
}
#header .header-nav .header__logo .link img {
  height: auto;
  margin-bottom: 8px;
}
@media (max-width: 480px) {
  #header .header-nav .header__logo .link img {
    margin-bottom: 1.0256410256vw;
  }
}
#header .header-nav .header__logo .link .txt {
  display: block;
  font-size: 1.5rem;
  text-align: center;
  font-weight: 500;
  color: #333;
}
@media (max-width: 480px) {
  #header .header-nav .header__logo .link .txt {
    font-size: 2.6923076923vw;
  }
}
#header .header-nav .header__logo .mark {
  width: 119px;
}
@media (max-width: 480px) {
  #header .header-nav .header__logo .mark {
    display: none;
  }
}
#header .header-nav .header-sp__contact {
  display: none;
}
@media (max-width: 480px) {
  #header .header-nav .header-sp__contact {
    display: block;
    margin-left: auto;
  }
}
#header .header-nav .header-sp__contact .inner {
  display: block;
  width: 29.6153846154vw;
  height: 10vw;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #d80c24;
  color: #fff;
  font-size: 3.5897435897vw;
  font-weight: bold;
  text-align: center;
  position: relative;
  z-index: 1;
}
#header .header-nav .header-sp__contact .inner::after {
  content: "ENTRY";
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  font-size: 8.0769230769vw;
  color: #fff;
  opacity: 0.2;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
#header .header-nav #menuButton {
  display: none;
}
@media (max-width: 480px) {
  #header .header-nav #menuButton {
    background: none;
    border: none;
    cursor: pointer;
    display: block;
  }
  #header .header-nav #menuButton .line {
    display: block;
    width: 9.6153846154vw;
    height: 0.5128205128vw;
    background: #293454;
    margin: 2.5641025641vw 0;
    transition: transform 0.3s, opacity 0.3s, background-color 0.3s;
    position: relative;
    z-index: 30000;
  }
  #header .header-nav #menuButton::after {
    content: none;
    background: rgba(0, 0, 0, 0.2);
    width: 100vw;
    height: 100vh;
    -webkit-backdrop-filter: blur(3px);
            backdrop-filter: blur(3px);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10000;
  }
  #header .header-nav #menuButton[aria-expanded=true] .line {
    background-color: #fff;
  }
  #header .header-nav #menuButton[aria-expanded=true] .line:nth-child(1) {
    transform: translateY(2.5641025641vw) rotate(45deg);
  }
  #header .header-nav #menuButton[aria-expanded=true] .line:nth-child(2) {
    opacity: 0;
  }
  #header .header-nav #menuButton[aria-expanded=true] .line:nth-child(3) {
    transform: translateY(-3.8461538462vw) rotate(-45deg);
  }
  #header .header-nav #menuButton[aria-expanded=true] + .header-nav-list {
    transform: translateY(0%);
    opacity: 1;
  }
  #header .header-nav #menuButton[aria-expanded=true]::after {
    content: "";
  }
}
#header .header-nav .header-nav-list {
  display: flex;
  align-items: center;
  font-weight: 400;
  font-size: 1.5rem;
}
@media (max-width: 480px) {
  #header .header-nav .header-nav-list {
    transform: translateY(-100%);
    opacity: 0;
    transition: transform 0.3s, opacity 0.3s;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    font-size: 4.7435897436vw;
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    padding: 17.9487179487vw 8.9743589744vw 12.8205128205vw 8.9743589744vw;
    background-color: #000;
    z-index: 20000;
  }
}
@media (max-width: 480px) {
  #header .header-nav .header-nav-list .header-nav-list__item {
    width: 100%;
  }
  #header .header-nav .header-nav-list .header-nav-list__item:last-child .link {
    border-bottom: 0;
  }
}
#header .header-nav .header-nav-list .header-nav-list__item .link {
  display: block;
  line-height: 1;
  transition: background-color 0.2s ease-in, color 0.2s ease-in;
  padding: 29.5px 38px;
  position: relative;
}
#header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) {
  color: #333;
  height: 100%;
}
@media (max-width: 480px) {
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) {
    padding: 7.6923076923vw 3.2051282051vw;
    color: #fff;
  }
}
#header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact)::after {
  content: "";
  width: 55px;
  height: 1px;
  background-color: transparent;
  position: absolute;
  bottom: 15px;
  left: 50%;
  transform: translateX(-50%);
  transition: background-color 0.2s ease-in;
}
@media (min-width: 480px) {
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact):hover .link__txt {
    color: #d80c24;
  }
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact):hover .link__txt .en {
    transform: translateY(-1em);
  }
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact):hover .link__txt .jp {
    transform: translateY(-1em);
  }
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact):hover::after {
    background-color: #d80c24;
  }
}
#header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) .link__txt {
  position: relative;
  display: flex;
  transition: color 0.3s;
}
#header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) .link__txt .en {
  font-family: "Roboto", sans-serif;
}
#header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) .link__txt .en, #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) .link__txt .jp {
  transition: transform 0.3s;
}
@media (min-width: 480px) {
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) .link__txt {
    align-items: center;
    flex-direction: column;
    height: 1em;
    overflow: hidden;
  }
}
@media (max-width: 480px) {
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) .link__txt {
    flex-direction: column-reverse;
    width: -moz-fit-content;
    width: fit-content;
    gap: 0.2em;
  }
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) .link__txt .en {
    font-weight: 500;
  }
  #header .header-nav .header-nav-list .header-nav-list__item .link:not(.contact) .link__txt .jp {
    font-size: 0.6em;
  }
}
@media (max-width: 480px) {
  #header .header-nav .header-nav-list .header-nav-list__item .link {
    color: #fff;
  }
}
#header .header-nav .header-nav-list .header-nav-list__item .link.contact {
  width: 229px;
  margin-left: 12px;
  padding-inline: 0;
  text-align: center;
  align-self: center;
  color: #fff;
  background-color: #d80c24;
  font-weight: 500;
  font-family: "Roboto", sans-serif;
  position: relative;
  border: 1px solid transparent;
  transition: border-color 0.2s, background-color 0.2s;
  z-index: 1;
}
@media (max-width: 480px) {
  #header .header-nav .header-nav-list .header-nav-list__item .link.contact {
    display: none;
  }
}
#header .header-nav .header-nav-list .header-nav-list__item .link.contact::after {
  content: "ENTRY";
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  font-size: 5rem;
  color: #fff;
  opacity: 0.2;
  position: absolute;
  top: 0;
  left: 0;
  transition: color 0.2s, opacity 0.2s;
  z-index: -1;
}
@media (min-width: 480px) {
  #header .header-nav .header-nav-list .header-nav-list__item .link.contact:hover {
    background-color: #fff;
    color: #d80c24;
    border-color: #d80c24;
  }
  #header .header-nav .header-nav-list .header-nav-list__item .link.contact:hover::after {
    color: #d80c24;
    opacity: 0.1;
  }
}

/*============================
#footer
============================*/
#footer {
  background-color: #d80c24;
}
#footer .footer-inner {
  padding: 80px 67px;
  display: flex;
  align-items: center;
}
@media (max-width: 480px) {
  #footer .footer-inner {
    flex-direction: column;
    padding: 10.2564102564vw 5.1282051282vw 6.4102564103vw;
  }
}
#footer .footer-inner .footer__logo {
  width: 294px;
  margin-right: 60px;
}
@media (max-width: 480px) {
  #footer .footer-inner .footer__logo {
    width: 56.6666666667vw;
    margin: 0 auto 7.6923076923vw;
  }
}
#footer .footer-inner .footer__logo img {
  margin-bottom: 8px;
}
@media (max-width: 480px) {
  #footer .footer-inner .footer__logo img {
    margin-bottom: 2.0512820513vw;
  }
}
#footer .footer-inner .footer__logo .txt {
  color: #fff;
  font-weight: 500;
  text-align: center;
}
#footer .footer-inner .footer-link {
  margin-right: 175px;
}
@media (max-width: 480px) {
  #footer .footer-inner .footer-link {
    margin-right: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    gap: 5.1282051282vw;
    margin-bottom: 7.6923076923vw;
  }
}
#footer .footer-inner .footer-link .footer-link__item:not(:last-child) {
  margin-bottom: 10px;
}
@media (max-width: 480px) {
  #footer .footer-inner .footer-link .footer-link__item:not(:last-child) {
    margin-bottom: 0;
  }
}
#footer .footer-inner .footer-link .footer-link__item > a {
  color: #fff;
  width: 130px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid;
  border-radius: 50px;
  font-size: 1.2rem;
  font-weight: 500;
  transition: background-color 0.2s;
}
@media (max-width: 480px) {
  #footer .footer-inner .footer-link .footer-link__item > a {
    width: 34.6153846154vw;
    height: 8.0769230769vw;
    font-size: 2.5641025641vw;
  }
}
@media (min-width: 480px) {
  #footer .footer-inner .footer-link .footer-link__item > a:hover {
    background-color: #b40105;
  }
}
#footer .footer-inner .footer-nav {
  flex-shrink: 0;
  margin-left: auto;
}
@media (max-width: 480px) {
  #footer .footer-inner .footer-nav {
    width: 100%;
  }
}
#footer .footer-inner .footer-nav .footer-nav-list {
  display: flex;
}
@media (max-width: 480px) {
  #footer .footer-inner .footer-nav .footer-nav-list {
    gap: 5.1282051282vw;
  }
}
@media (max-width: 480px) {
  #footer .footer-inner .footer-nav .footer-nav-list .footer-nav-list__item {
    width: 100%;
    text-align: center;
  }
}
#footer .footer-inner .footer-nav .footer-nav-list .footer-nav-list__item .link {
  padding: 10px 20px;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: background-color 0.2s;
}
@media (max-width: 480px) {
  #footer .footer-inner .footer-nav .footer-nav-list .footer-nav-list__item .link {
    padding: 0;
    font-size: 2.5641025641vw;
  }
}
@media (min-width: 480px) {
  #footer .footer-inner .footer-nav .footer-nav-list .footer-nav-list__item .link:hover {
    background-color: #b40105;
  }
}
#footer .footer__copy {
  font-size: 1.3rem;
  letter-spacing: 0.02em;
  text-align: center;
  color: #fff;
  background-color: #111111;
  padding: 12px;
}
@media (max-width: 480px) {
  #footer .footer__copy {
    font-size: 1.6666666667vw;
    padding: 1.6666666667vw;
  }
}

/*============================
section
============================*/
section.py01 {
  padding: 100px 0;
  position: relative;
}
@media (max-width: 480px) {
  section.py01 {
    padding: 6.4102564103vw 0;
  }
}
section.py01:first-child {
  padding-top: 110px;
}
@media (max-width: 480px) {
  section.py01:first-child {
    padding-top: 12.8205128205vw;
  }
}

/*============================
共通パーツ
============================*/
.bold {
  font-weight: bold;
}

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

.fc-red01 {
  color: #d80c24;
}

.fc-yel01 {
  color: #efb121;
}

.fc-wht01 {
  color: #fff;
}

.f-jost {
  font-family: "Jost", sans-serif;
}

.sup {
  vertical-align: super;
  font-size: 0.5em;
}

.unit-txt-link01 {
  color: #3d70c4;
  text-decoration: underline;
}
@media (min-width: 480px) {
  .unit-txt-link01:hover {
    text-decoration: none;
    opacity: 0.7;
  }
}
.unit-txt-link01 i {
  margin-left: 0.2em;
  font-size: 0.7em;
}
.unit-txt-link01 .blank {
  display: inline-block;
  margin-left: 0.2em;
  width: 0.7em;
}

.unit-note01 {
  text-indent: -1em;
  padding-left: 1em;
}

.unit-figure01 {
  position: relative;
}
.unit-figure01::before {
  content: "";
  width: 100%;
  height: 100%;
  border: 1px solid #293454;
  position: absolute;
  top: 5px;
  right: -6px;
}
@media (max-width: 480px) {
  .unit-figure01::before {
    border-width: 0.2564102564vw;
    top: 1.2820512821vw;
    right: -1.5384615385vw;
  }
}

.unit-blank-link01 {
  width: 1em;
  height: auto;
  aspect-ratio: 1/1;
  display: inline-block;
  -webkit-mask: url(../img/mark_blank.svg) no-repeat center/contain;
          mask: url(../img/mark_blank.svg) no-repeat center/contain;
  background-color: #333;
}

.tel {
  pointer-events: none;
}
@media (max-width: 480px) {
  .tel {
    pointer-events: all;
  }
}

.mt10 {
  margin-top: 10px;
}
@media (max-width: 480px) {
  .mt10 {
    margin-top: 1.2820512821vw;
  }
}

.mt20 {
  margin-top: 20px;
}
@media (max-width: 480px) {
  .mt20 {
    margin-top: 2.5641025641vw;
  }
}

.mt30 {
  margin-top: 30px;
}
@media (max-width: 480px) {
  .mt30 {
    margin-top: 3.8461538462vw;
  }
}

.mt40 {
  margin-top: 40px;
}
@media (max-width: 480px) {
  .mt40 {
    margin-top: 5.1282051282vw;
  }
}

.mt50 {
  margin-top: 50px;
}
@media (max-width: 480px) {
  .mt50 {
    margin-top: 6.4102564103vw;
  }
}

.mt60 {
  margin-top: 60px;
}
@media (max-width: 480px) {
  .mt60 {
    margin-top: 7.6923076923vw;
  }
}

.mt70 {
  margin-top: 70px;
}
@media (max-width: 480px) {
  .mt70 {
    margin-top: 8.9743589744vw;
  }
}

.mt80 {
  margin-top: 80px;
}
@media (max-width: 480px) {
  .mt80 {
    margin-top: 10.2564102564vw;
  }
}

.mt90 {
  margin-top: 90px;
}
@media (max-width: 480px) {
  .mt90 {
    margin-top: 11.5384615385vw;
  }
}

.mt100 {
  margin-top: 100px;
}
@media (max-width: 480px) {
  .mt100 {
    margin-top: 12.8205128205vw;
  }
}

.mt110 {
  margin-top: 110px;
}
@media (max-width: 480px) {
  .mt110 {
    margin-top: 14.1025641026vw;
  }
}

.mt120 {
  margin-top: 120px;
}
@media (max-width: 480px) {
  .mt120 {
    margin-top: 15.3846153846vw;
  }
}

.mt130 {
  margin-top: 130px;
}
@media (max-width: 480px) {
  .mt130 {
    margin-top: 16.6666666667vw;
  }
}

.mt140 {
  margin-top: 140px;
}
@media (max-width: 480px) {
  .mt140 {
    margin-top: 17.9487179487vw;
  }
}

.mt150 {
  margin-top: 150px;
}
@media (max-width: 480px) {
  .mt150 {
    margin-top: 19.2307692308vw;
  }
}

.mt160 {
  margin-top: 160px;
}
@media (max-width: 480px) {
  .mt160 {
    margin-top: 20.5128205128vw;
  }
}

.mt170 {
  margin-top: 170px;
}
@media (max-width: 480px) {
  .mt170 {
    margin-top: 21.7948717949vw;
  }
}

.mt180 {
  margin-top: 180px;
}
@media (max-width: 480px) {
  .mt180 {
    margin-top: 23.0769230769vw;
  }
}

.mt190 {
  margin-top: 190px;
}
@media (max-width: 480px) {
  .mt190 {
    margin-top: 24.358974359vw;
  }
}

.mt200 {
  margin-top: 200px;
}
@media (max-width: 480px) {
  .mt200 {
    margin-top: 25.641025641vw;
  }
}

.mb10 {
  margin-bottom: 10px;
}
@media (max-width: 480px) {
  .mb10 {
    margin-bottom: 1.2820512821vw;
  }
}

.mb20 {
  margin-bottom: 20px;
}
@media (max-width: 480px) {
  .mb20 {
    margin-bottom: 2.5641025641vw;
  }
}

.mb30 {
  margin-bottom: 30px;
}
@media (max-width: 480px) {
  .mb30 {
    margin-bottom: 3.8461538462vw;
  }
}

.mb40 {
  margin-bottom: 40px;
}
@media (max-width: 480px) {
  .mb40 {
    margin-bottom: 5.1282051282vw;
  }
}

.mb50 {
  margin-bottom: 50px;
}
@media (max-width: 480px) {
  .mb50 {
    margin-bottom: 6.4102564103vw;
  }
}

.mb60 {
  margin-bottom: 60px;
}
@media (max-width: 480px) {
  .mb60 {
    margin-bottom: 7.6923076923vw;
  }
}

.mb70 {
  margin-bottom: 70px;
}
@media (max-width: 480px) {
  .mb70 {
    margin-bottom: 8.9743589744vw;
  }
}

.mb80 {
  margin-bottom: 80px;
}
@media (max-width: 480px) {
  .mb80 {
    margin-bottom: 10.2564102564vw;
  }
}

.mb90 {
  margin-bottom: 90px;
}
@media (max-width: 480px) {
  .mb90 {
    margin-bottom: 11.5384615385vw;
  }
}

.mb100 {
  margin-bottom: 100px;
}
@media (max-width: 480px) {
  .mb100 {
    margin-bottom: 12.8205128205vw;
  }
}

.mb110 {
  margin-bottom: 110px;
}
@media (max-width: 480px) {
  .mb110 {
    margin-bottom: 14.1025641026vw;
  }
}

.mb120 {
  margin-bottom: 120px;
}
@media (max-width: 480px) {
  .mb120 {
    margin-bottom: 15.3846153846vw;
  }
}

.mb130 {
  margin-bottom: 130px;
}
@media (max-width: 480px) {
  .mb130 {
    margin-bottom: 16.6666666667vw;
  }
}

.mb140 {
  margin-bottom: 140px;
}
@media (max-width: 480px) {
  .mb140 {
    margin-bottom: 17.9487179487vw;
  }
}

.mb150 {
  margin-bottom: 150px;
}
@media (max-width: 480px) {
  .mb150 {
    margin-bottom: 19.2307692308vw;
  }
}

.mb160 {
  margin-bottom: 160px;
}
@media (max-width: 480px) {
  .mb160 {
    margin-bottom: 20.5128205128vw;
  }
}

.mb170 {
  margin-bottom: 170px;
}
@media (max-width: 480px) {
  .mb170 {
    margin-bottom: 21.7948717949vw;
  }
}

.mb180 {
  margin-bottom: 180px;
}
@media (max-width: 480px) {
  .mb180 {
    margin-bottom: 23.0769230769vw;
  }
}

.mb190 {
  margin-bottom: 190px;
}
@media (max-width: 480px) {
  .mb190 {
    margin-bottom: 24.358974359vw;
  }
}

.mb200 {
  margin-bottom: 200px;
}
@media (max-width: 480px) {
  .mb200 {
    margin-bottom: 25.641025641vw;
  }
}

@media (max-width: 480px) {
  .sp-mt10 {
    margin-top: 1.2820512821vw;
  }
}

@media (max-width: 480px) {
  .sp-mt20 {
    margin-top: 2.5641025641vw;
  }
}

@media (max-width: 480px) {
  .sp-mt30 {
    margin-top: 3.8461538462vw;
  }
}

@media (max-width: 480px) {
  .sp-mt40 {
    margin-top: 5.1282051282vw;
  }
}

@media (max-width: 480px) {
  .sp-mt50 {
    margin-top: 6.4102564103vw;
  }
}

@media (max-width: 480px) {
  .sp-mt60 {
    margin-top: 7.6923076923vw;
  }
}

@media (max-width: 480px) {
  .sp-mt70 {
    margin-top: 8.9743589744vw;
  }
}

@media (max-width: 480px) {
  .sp-mt80 {
    margin-top: 10.2564102564vw;
  }
}

@media (max-width: 480px) {
  .sp-mt90 {
    margin-top: 11.5384615385vw;
  }
}

@media (max-width: 480px) {
  .sp-mt100 {
    margin-top: 12.8205128205vw;
  }
}

@media (max-width: 480px) {
  .sp-mt110 {
    margin-top: 14.1025641026vw;
  }
}

@media (max-width: 480px) {
  .sp-mt120 {
    margin-top: 15.3846153846vw;
  }
}

@media (max-width: 480px) {
  .sp-mt130 {
    margin-top: 16.6666666667vw;
  }
}

@media (max-width: 480px) {
  .sp-mt140 {
    margin-top: 17.9487179487vw;
  }
}

@media (max-width: 480px) {
  .sp-mt150 {
    margin-top: 19.2307692308vw;
  }
}

@media (max-width: 480px) {
  .sp-mt160 {
    margin-top: 20.5128205128vw;
  }
}

@media (max-width: 480px) {
  .sp-mt170 {
    margin-top: 21.7948717949vw;
  }
}

@media (max-width: 480px) {
  .sp-mt180 {
    margin-top: 23.0769230769vw;
  }
}

@media (max-width: 480px) {
  .sp-mt190 {
    margin-top: 24.358974359vw;
  }
}

@media (max-width: 480px) {
  .sp-mt200 {
    margin-top: 25.641025641vw;
  }
}

@media (max-width: 480px) {
  .sp-mb10 {
    margin-bottom: 1.2820512821vw;
  }
}

@media (max-width: 480px) {
  .sp-mb20 {
    margin-bottom: 2.5641025641vw;
  }
}

@media (max-width: 480px) {
  .sp-mb30 {
    margin-bottom: 3.8461538462vw;
  }
}

@media (max-width: 480px) {
  .sp-mb40 {
    margin-bottom: 5.1282051282vw;
  }
}

@media (max-width: 480px) {
  .sp-mb50 {
    margin-bottom: 6.4102564103vw;
  }
}

@media (max-width: 480px) {
  .sp-mb60 {
    margin-bottom: 7.6923076923vw;
  }
}

@media (max-width: 480px) {
  .sp-mb70 {
    margin-bottom: 8.9743589744vw;
  }
}

@media (max-width: 480px) {
  .sp-mb80 {
    margin-bottom: 10.2564102564vw;
  }
}

@media (max-width: 480px) {
  .sp-mb90 {
    margin-bottom: 11.5384615385vw;
  }
}

@media (max-width: 480px) {
  .sp-mb100 {
    margin-bottom: 12.8205128205vw;
  }
}

@media (max-width: 480px) {
  .sp-mb110 {
    margin-bottom: 14.1025641026vw;
  }
}

@media (max-width: 480px) {
  .sp-mb120 {
    margin-bottom: 15.3846153846vw;
  }
}

@media (max-width: 480px) {
  .sp-mb130 {
    margin-bottom: 16.6666666667vw;
  }
}

@media (max-width: 480px) {
  .sp-mb140 {
    margin-bottom: 17.9487179487vw;
  }
}

@media (max-width: 480px) {
  .sp-mb150 {
    margin-bottom: 19.2307692308vw;
  }
}

@media (max-width: 480px) {
  .sp-mb160 {
    margin-bottom: 20.5128205128vw;
  }
}

@media (max-width: 480px) {
  .sp-mb170 {
    margin-bottom: 21.7948717949vw;
  }
}

@media (max-width: 480px) {
  .sp-mb180 {
    margin-bottom: 23.0769230769vw;
  }
}

@media (max-width: 480px) {
  .sp-mb190 {
    margin-bottom: 24.358974359vw;
  }
}

@media (max-width: 480px) {
  .sp-mb200 {
    margin-bottom: 25.641025641vw;
  }
}

.fs10 {
  font-size: 1rem;
}
@media (max-width: 480px) {
  .fs10 {
    font-size: 2.5641025641vw;
  }
}

.fs11 {
  font-size: 1.1rem;
}
@media (max-width: 480px) {
  .fs11 {
    font-size: 2.8205128205vw;
  }
}

.fs12 {
  font-size: 1.2rem;
}
@media (max-width: 480px) {
  .fs12 {
    font-size: 3.0769230769vw;
  }
}

.fs13 {
  font-size: 1.3rem;
}
@media (max-width: 480px) {
  .fs13 {
    font-size: 3.3333333333vw;
  }
}

.fs14 {
  font-size: 1.4rem;
}
@media (max-width: 480px) {
  .fs14 {
    font-size: 3.5897435897vw;
  }
}

.fs15 {
  font-size: 1.5rem;
}
@media (max-width: 480px) {
  .fs15 {
    font-size: 3.8461538462vw;
  }
}

.fs16 {
  font-size: 1.6rem;
}
@media (max-width: 480px) {
  .fs16 {
    font-size: 4.1025641026vw;
  }
}

.fs17 {
  font-size: 1.7rem;
}
@media (max-width: 480px) {
  .fs17 {
    font-size: 4.358974359vw;
  }
}

.fs18 {
  font-size: 1.8rem;
}
@media (max-width: 480px) {
  .fs18 {
    font-size: 4.6153846154vw;
  }
}

.fs19 {
  font-size: 1.9rem;
}
@media (max-width: 480px) {
  .fs19 {
    font-size: 4.8717948718vw;
  }
}

.fs20 {
  font-size: 2rem;
}
@media (max-width: 480px) {
  .fs20 {
    font-size: 5.1282051282vw;
  }
}

.fs21 {
  font-size: 2.1rem;
}
@media (max-width: 480px) {
  .fs21 {
    font-size: 5.3846153846vw;
  }
}

.fs22 {
  font-size: 2.2rem;
}
@media (max-width: 480px) {
  .fs22 {
    font-size: 5.641025641vw;
  }
}

.fs23 {
  font-size: 2.3rem;
}
@media (max-width: 480px) {
  .fs23 {
    font-size: 5.8974358974vw;
  }
}

.fs24 {
  font-size: 2.4rem;
}
@media (max-width: 480px) {
  .fs24 {
    font-size: 6.1538461538vw;
  }
}

.fs25 {
  font-size: 2.5rem;
}
@media (max-width: 480px) {
  .fs25 {
    font-size: 6.4102564103vw;
  }
}

.fs26 {
  font-size: 2.6rem;
}
@media (max-width: 480px) {
  .fs26 {
    font-size: 6.6666666667vw;
  }
}

.fs27 {
  font-size: 2.7rem;
}
@media (max-width: 480px) {
  .fs27 {
    font-size: 6.9230769231vw;
  }
}

.fs28 {
  font-size: 2.8rem;
}
@media (max-width: 480px) {
  .fs28 {
    font-size: 7.1794871795vw;
  }
}

.fs29 {
  font-size: 2.9rem;
}
@media (max-width: 480px) {
  .fs29 {
    font-size: 7.4358974359vw;
  }
}

.fs30 {
  font-size: 3rem;
}
@media (max-width: 480px) {
  .fs30 {
    font-size: 7.6923076923vw;
  }
}

.fs31 {
  font-size: 3.1rem;
}
@media (max-width: 480px) {
  .fs31 {
    font-size: 7.9487179487vw;
  }
}

.fs32 {
  font-size: 3.2rem;
}
@media (max-width: 480px) {
  .fs32 {
    font-size: 8.2051282051vw;
  }
}

.fs33 {
  font-size: 3.3rem;
}
@media (max-width: 480px) {
  .fs33 {
    font-size: 8.4615384615vw;
  }
}

.fs34 {
  font-size: 3.4rem;
}
@media (max-width: 480px) {
  .fs34 {
    font-size: 8.7179487179vw;
  }
}

.fs35 {
  font-size: 3.5rem;
}
@media (max-width: 480px) {
  .fs35 {
    font-size: 8.9743589744vw;
  }
}

.fs36 {
  font-size: 3.6rem;
}
@media (max-width: 480px) {
  .fs36 {
    font-size: 9.2307692308vw;
  }
}

.fs37 {
  font-size: 3.7rem;
}
@media (max-width: 480px) {
  .fs37 {
    font-size: 9.4871794872vw;
  }
}

.fs38 {
  font-size: 3.8rem;
}
@media (max-width: 480px) {
  .fs38 {
    font-size: 9.7435897436vw;
  }
}

.fs39 {
  font-size: 3.9rem;
}
@media (max-width: 480px) {
  .fs39 {
    font-size: 10vw;
  }
}

.fs40 {
  font-size: 4rem;
}
@media (max-width: 480px) {
  .fs40 {
    font-size: 10.2564102564vw;
  }
}

.fs41 {
  font-size: 4.1rem;
}
@media (max-width: 480px) {
  .fs41 {
    font-size: 10.5128205128vw;
  }
}

.fs42 {
  font-size: 4.2rem;
}
@media (max-width: 480px) {
  .fs42 {
    font-size: 10.7692307692vw;
  }
}

.fs43 {
  font-size: 4.3rem;
}
@media (max-width: 480px) {
  .fs43 {
    font-size: 11.0256410256vw;
  }
}

.fs44 {
  font-size: 4.4rem;
}
@media (max-width: 480px) {
  .fs44 {
    font-size: 11.2820512821vw;
  }
}

.fs45 {
  font-size: 4.5rem;
}
@media (max-width: 480px) {
  .fs45 {
    font-size: 11.5384615385vw;
  }
}

.fs46 {
  font-size: 4.6rem;
}
@media (max-width: 480px) {
  .fs46 {
    font-size: 11.7948717949vw;
  }
}

.fs47 {
  font-size: 4.7rem;
}
@media (max-width: 480px) {
  .fs47 {
    font-size: 12.0512820513vw;
  }
}

.fs48 {
  font-size: 4.8rem;
}
@media (max-width: 480px) {
  .fs48 {
    font-size: 12.3076923077vw;
  }
}

.fs49 {
  font-size: 4.9rem;
}
@media (max-width: 480px) {
  .fs49 {
    font-size: 12.5641025641vw;
  }
}

.fs50 {
  font-size: 5rem;
}
@media (max-width: 480px) {
  .fs50 {
    font-size: 12.8205128205vw;
  }
}

@media (max-width: 480px) {
  .sp-fs10 {
    font-size: 1.2820512821vw;
  }
}

@media (max-width: 480px) {
  .sp-fs11 {
    font-size: 1.4102564103vw;
  }
}

@media (max-width: 480px) {
  .sp-fs12 {
    font-size: 1.5384615385vw;
  }
}

@media (max-width: 480px) {
  .sp-fs13 {
    font-size: 1.6666666667vw;
  }
}

@media (max-width: 480px) {
  .sp-fs14 {
    font-size: 1.7948717949vw;
  }
}

@media (max-width: 480px) {
  .sp-fs15 {
    font-size: 1.9230769231vw;
  }
}

@media (max-width: 480px) {
  .sp-fs16 {
    font-size: 2.0512820513vw;
  }
}

@media (max-width: 480px) {
  .sp-fs17 {
    font-size: 2.1794871795vw;
  }
}

@media (max-width: 480px) {
  .sp-fs18 {
    font-size: 2.3076923077vw;
  }
}

@media (max-width: 480px) {
  .sp-fs19 {
    font-size: 2.4358974359vw;
  }
}

@media (max-width: 480px) {
  .sp-fs20 {
    font-size: 2.5641025641vw;
  }
}

@media (max-width: 480px) {
  .sp-fs21 {
    font-size: 2.6923076923vw;
  }
}

@media (max-width: 480px) {
  .sp-fs22 {
    font-size: 2.8205128205vw;
  }
}

@media (max-width: 480px) {
  .sp-fs23 {
    font-size: 2.9487179487vw;
  }
}

@media (max-width: 480px) {
  .sp-fs24 {
    font-size: 3.0769230769vw;
  }
}

@media (max-width: 480px) {
  .sp-fs25 {
    font-size: 3.2051282051vw;
  }
}

@media (max-width: 480px) {
  .sp-fs26 {
    font-size: 3.3333333333vw;
  }
}

@media (max-width: 480px) {
  .sp-fs27 {
    font-size: 3.4615384615vw;
  }
}

@media (max-width: 480px) {
  .sp-fs28 {
    font-size: 3.5897435897vw;
  }
}

@media (max-width: 480px) {
  .sp-fs29 {
    font-size: 3.7179487179vw;
  }
}

@media (max-width: 480px) {
  .sp-fs30 {
    font-size: 3.8461538462vw;
  }
}

@media (max-width: 480px) {
  .sp-fs31 {
    font-size: 3.9743589744vw;
  }
}

@media (max-width: 480px) {
  .sp-fs32 {
    font-size: 4.1025641026vw;
  }
}

@media (max-width: 480px) {
  .sp-fs33 {
    font-size: 4.2307692308vw;
  }
}

@media (max-width: 480px) {
  .sp-fs34 {
    font-size: 4.358974359vw;
  }
}

@media (max-width: 480px) {
  .sp-fs35 {
    font-size: 4.4871794872vw;
  }
}

@media (max-width: 480px) {
  .sp-fs36 {
    font-size: 4.6153846154vw;
  }
}

@media (max-width: 480px) {
  .sp-fs37 {
    font-size: 4.7435897436vw;
  }
}

@media (max-width: 480px) {
  .sp-fs38 {
    font-size: 4.8717948718vw;
  }
}

@media (max-width: 480px) {
  .sp-fs39 {
    font-size: 5vw;
  }
}

@media (max-width: 480px) {
  .sp-fs40 {
    font-size: 5.1282051282vw;
  }
}

@media (max-width: 480px) {
  .sp-fs41 {
    font-size: 5.2564102564vw;
  }
}

@media (max-width: 480px) {
  .sp-fs42 {
    font-size: 5.3846153846vw;
  }
}

@media (max-width: 480px) {
  .sp-fs43 {
    font-size: 5.5128205128vw;
  }
}

@media (max-width: 480px) {
  .sp-fs44 {
    font-size: 5.641025641vw;
  }
}

@media (max-width: 480px) {
  .sp-fs45 {
    font-size: 5.7692307692vw;
  }
}

@media (max-width: 480px) {
  .sp-fs46 {
    font-size: 5.8974358974vw;
  }
}

@media (max-width: 480px) {
  .sp-fs47 {
    font-size: 6.0256410256vw;
  }
}

@media (max-width: 480px) {
  .sp-fs48 {
    font-size: 6.1538461538vw;
  }
}

@media (max-width: 480px) {
  .sp-fs49 {
    font-size: 6.2820512821vw;
  }
}

@media (max-width: 480px) {
  .sp-fs50 {
    font-size: 6.4102564103vw;
  }
}

/*w*/
.w20 {
  width: 20%;
}

.w25 {
  width: 25%;
}

.w30 {
  width: 30%;
}

.w35 {
  width: 35%;
}

.w40 {
  width: 40%;
}
@media (max-width: 480px) {
  .w40 {
    width: 100%;
  }
}

.w45 {
  width: 45%;
}

.w50 {
  width: 50%;
}

.w55 {
  width: 55%;
}

.w60 {
  width: 60%;
}
@media (max-width: 480px) {
  .w60 {
    width: 100%;
  }
}

.w65 {
  width: 65%;
}

.w70 {
  width: 70%;
}

.w75 {
  width: 75%;
}

.w80 {
  width: 80%;
}

.w85 {
  width: 85%;
}

.w90 {
  width: 90%;
}

.w95 {
  width: 95%;
}

.w100 {
  width: 100%;
}

/*============================
title
============================*/
.unit-ttl01 {
  display: flex;
  gap: 20px;
  margin-bottom: 70px;
}
@media (max-width: 480px) {
  .unit-ttl01 {
    flex-direction: column-reverse;
    align-items: center;
    gap: 1.2820512821vw;
    margin-bottom: 11.5384615385vw;
  }
}
.unit-ttl01.pc-jc-en {
  justify-content: end;
}
@media (max-width: 480px) {
  .unit-ttl01.pc-jc-en {
    justify-content: start;
  }
}
.unit-ttl01 .main {
  font-size: 5.4rem;
  letter-spacing: 0.05em;
  line-height: 1;
  font-weight: bold;
  filter: url(#dilate);
}
@media (max-width: 480px) {
  .unit-ttl01 .main {
    font-size: 8.7179487179vw;
    line-height: 1.4;
    text-align: center;
  }
}
.unit-ttl01 .sub {
  line-height: 1.5;
}
@media (max-width: 480px) {
  .unit-ttl01 .sub {
    display: flex;
    gap: 2.5641025641vw;
  }
}
.unit-ttl01 .sub .sub-jp {
  display: block;
  font-weight: 500;
  font-size: 2.4rem;
}
@media (max-width: 480px) {
  .unit-ttl01 .sub .sub-jp {
    font-size: 3.0769230769vw;
  }
}
.unit-ttl01 .sub .sub-en {
  display: block;
  font-size: 2rem;
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  color: #a39205;
}
@media (max-width: 480px) {
  .unit-ttl01 .sub .sub-en {
    font-size: 3.0769230769vw;
  }
}

.unit-ttl02 {
  font-weight: bold;
  font-size: 2rem;
  text-align: center;
  margin-bottom: 30px;
}
@media (max-width: 480px) {
  .unit-ttl02 {
    font-size: 4.4871794872vw;
    margin-bottom: 1.9230769231vw;
  }
}

.unit-ttl03 {
  font-size: 3.2rem;
  letter-spacing: 0.05em;
  font-weight: bold;
  color: #333;
}
@media (max-width: 480px) {
  .unit-ttl03 {
    font-size: 5.1282051282vw;
  }
}

/*============================
msg
============================*/
.unit-msg01 {
  font-weight: 300;
  line-height: 1.8;
}
.unit-msg01 p:not(:last-child) {
  margin-bottom: 20px;
}
@media (max-width: 480px) {
  .unit-msg01 p:not(:last-child) {
    margin-bottom: 6.4102564103vw;
  }
}

/*============================
ボタン
============================*/
.unit-btn01 > .inner {
  width: 370px;
  max-width: 100%;
  height: 60px;
  background-color: #111;
  border: 1px solid #fff;
  color: #fff;
  font-size: 2rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  padding-left: 17px;
  padding-right: 66px;
  position: relative;
  z-index: 1;
}
@media (max-width: 480px) {
  .unit-btn01 > .inner {
    height: 11.0256410256vw;
    font-size: 3.7179487179vw;
    padding-inline: 5.641025641vw;
    background-color: #d80c24;
  }
}
.unit-btn01 > .inner::after {
  content: "";
  width: 52px;
  height: 2px;
  background: #fff;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 15px;
  transition: right 0.2s 0.1s ease-out;
}
@media (max-width: 480px) {
  .unit-btn01 > .inner::after {
    width: 9.6153846154vw;
    height: 0.3846153846vw;
    right: -4.7435897436vw;
  }
}
.unit-btn01 > .inner::before {
  content: "";
  width: 0%;
  height: 100%;
  background-color: #d80c24;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
  transition: width 0.2s ease-out;
}
@media (min-width: 480px) {
  .unit-btn01 > .inner:hover::before {
    width: 100%;
  }
  .unit-btn01 > .inner:hover::after {
    right: -30px;
  }
}

/*============================
ホバーアクション
============================*/
.hover-action01 .icon {
  overflow: hidden;
  position: relative;
}
.hover-action01 .icon::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #333;
  border-radius: 50%;
  transform: scale(0);
  transition: transform 0.3s ease;
}
@media (min-width: 480px) {
  .hover-action01:hover .icon svg {
    animation: 400ms ease-in-out 0s 1 normal forwards running overarrow;
  }
  .hover-action01:hover .icon svg polygon {
    fill: #fff;
  }
  .hover-action01:hover .icon::before {
    transform: scale(1.1);
  }
  @keyframes overarrow {
    0% {
      transform: translateX(0px);
    }
    50% {
      transform: translateX(40px);
    }
    51% {
      transform: translateX(-40px);
    }
    100% {
      transform: translateX(0px);
    }
  }
}

/*============================
共通アイテム
============================*/
.breadcrumbs {
  padding: 30px 0;
}
@media (max-width: 480px) {
  .breadcrumbs {
    padding: 3.8461538462vw 0;
    overflow-x: scroll;
    overflow-y: hidden;
    direction: rtl;
  }
}
@media (max-width: 480px) {
  .breadcrumbs .wrap {
    display: contents;
  }
}
.breadcrumbs ul {
  display: flex;
}
@media (max-width: 480px) {
  .breadcrumbs ul {
    padding: 0 3.8461538462vw;
    width: -moz-fit-content;
    width: fit-content;
    white-space: nowrap;
    text-align: left;
    direction: ltr;
  }
}
.breadcrumbs ul li {
  font-size: 1.3rem;
}
@media (max-width: 480px) {
  .breadcrumbs ul li {
    font-size: 3.0769230769vw;
    direction: ltr;
  }
}
.breadcrumbs ul li:not(:last-child)::after {
  content: ">";
  margin: 0 1em;
  color: #fff;
}
.breadcrumbs ul li a {
  color: inherit;
}
@media (min-width: 480px) {
  .breadcrumbs ul li a:hover {
    text-decoration: underline;
  }
}

.unit-card {
  display: block;
  background: #fff;
  color: #333333;
  text-decoration: none;
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1) inset;
  position: relative;
}
.unit-card .unit-card__thumb {
  position: relative;
}
.unit-card .unit-card__thumb img {
  width: 100%;
  height: auto;
  display: block;
  transition: opacity 0.3s ease-out 0.15s;
}
.unit-card .unit-card__thumb img.img-after {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.unit-card .unit-card__thumb::before {
  content: "";
  width: 100%;
  height: 200%;
  background-color: rgba(255, 255, 255, 0.1803921569);
  position: absolute;
  top: 0;
  left: 100%;
  transform: rotate(0deg);
  transform-origin: top right;
  transition: transform 0s;
  z-index: 1;
}
@media (min-width: 480px) {
  .unit-card:hover .unit-card__thumb img.img-before {
    opacity: 0;
  }
  .unit-card:hover .unit-card__thumb img.img-after {
    opacity: 1;
  }
  .unit-card:hover .unit-card__thumb::before {
    transform: rotate(360deg);
    transition: transform 0.7s linear;
  }
}
.unit-card .unit-card__meta {
  padding: 25px 29px;
  line-height: 1.4;
  position: relative;
  z-index: 1;
}
@media (max-width: 480px) {
  .unit-card .unit-card__meta {
    padding: 5.3846153846vw 6.6666666667vw;
    font-size: 4.358974359vw;
  }
}
.unit-card::before {
  content: "";
  width: 68px;
  height: auto;
  aspect-ratio: 1/1;
  background-color: #111;
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  position: absolute;
  bottom: 2px;
  right: 2px;
  z-index: 1;
  transition: background-color 0.3s;
}
@media (max-width: 480px) {
  .unit-card::before {
    width: 15.3846153846vw;
  }
}
.unit-card::after {
  content: "";
  width: 50px;
  height: 2px;
  background-color: #fff;
  position: absolute;
  bottom: 26px;
  right: 10px;
  z-index: 1;
}
@media (max-width: 480px) {
  .unit-card::after {
    width: 6.4102564103vw;
    height: 0.2564102564vw;
    bottom: 6.4102564103vw;
    right: 3.8461538462vw;
  }
}
@media (min-width: 480px) {
  .unit-card:hover::before {
    background-color: #d80c24;
  }
}

.ttl-en {
  position: absolute;
  pointer-events: none;
  white-space: nowrap;
}
.ttl-en svg {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip-path: inset(50%);
}
.ttl-en .dilate {
  filter: url(#dilate);
  font-family: "Roboto", sans-serif;
  font-size: 23.8rem;
  font-weight: 700;
  line-height: 0.8;
  opacity: 0.25;
}

.ttl-en-filter {
  display: none;
}

.interview-slider .splide__track {
  position: relative;
  padding: 55px 0 80px;
}
@media (max-width: 480px) {
  .interview-slider .splide__track {
    padding: 5.1282051282vw 0 14.1025641026vw;
  }
}
.interview-slider .splide__track .splide__list .splide__slide {
  width: 340px;
  opacity: 0.4;
  transition: transform 0.2s;
}
@media (max-width: 480px) {
  .interview-slider .splide__track .splide__list .splide__slide {
    width: 84.6153846154vw;
  }
}
.interview-slider .splide__track .splide__list .splide__slide .unit-card .unit-card__thumb img {
  transition-delay: 0.2s;
}
.interview-slider .splide__track .splide__list .splide__slide.is-active {
  opacity: 1;
  transform: scale(1.1);
}
@media (max-width: 480px) {
  .interview-slider .splide__track .splide__list .splide__slide.is-active {
    transform: scale(1);
  }
}
.interview-slider .splide__track .splide__list .splide__slide.is-active .unit-card .unit-card__meta::before {
  background-color: #d80c24;
}
.interview-slider .splide__track .splide__list .splide__slide.is-active .unit-card .unit-card__thumb img.img-before {
  opacity: 0;
}
.interview-slider .splide__track .splide__list .splide__slide.is-active .unit-card .unit-card__thumb img.img-after {
  opacity: 1;
}
.interview-slider .splide__track .splide__list .splide__slide.is-active .unit-card .unit-card__thumb::before {
  transform: rotate(360deg);
  transition: transform 0.7s linear 0.15s;
}
.interview-slider .splide__track .splide__list .splide__slide.is-prev, .interview-slider .splide__track .splide__list .splide__slide.is-next {
  opacity: 1;
}
@media (max-width: 480px) {
  .interview-slider .splide__track .splide__list .splide__slide.is-prev, .interview-slider .splide__track .splide__list .splide__slide.is-next {
    opacity: 0.7;
  }
}
.interview-slider .splide__pagination {
  bottom: 0;
  gap: 6px;
  flex-wrap: wrap;
}
@media (max-width: 480px) {
  .interview-slider .splide__pagination {
    gap: 2.5641025641vw;
    width: 90%;
    margin: 0 auto;
    justify-content: flex-start;
  }
}
.interview-slider .splide__pagination li {
  width: 45px;
  height: 5px;
}
@media (max-width: 480px) {
  .interview-slider .splide__pagination li {
    width: calc(12.5% - 2.2435897436vw);
    height: 1.0256410256vw;
  }
}
.interview-slider .splide__pagination li .splide__pagination__page {
  display: block;
  width: 100%;
  height: 100%;
  background: #fff;
  opacity: 1;
  border-radius: 0;
  margin: 0;
}
.interview-slider .splide__pagination li .splide__pagination__page.is-active {
  background-color: #111111;
  transform: scale(1);
}
.interview-slider .splide__arrows {
  width: 760px;
  position: absolute;
  left: 50%;
  bottom: 3px;
  transform: translateX(-50%);
  z-index: 10;
}
@media (max-width: 480px) {
  .interview-slider .splide__arrows {
    width: 100%;
    bottom: 2.3076923077vw;
  }
}
.interview-slider .splide__arrows .splide__arrow {
  background: transparent;
  border: none;
  opacity: 1;
}
.interview-slider .splide__arrows .splide__arrow svg {
  fill: #fff;
}
@media (max-width: 480px) {
  .interview-slider .splide__arrows .splide__arrow.splide__arrow--prev {
    left: 0;
  }
}
@media (max-width: 480px) {
  .interview-slider .splide__arrows .splide__arrow.splide__arrow--next {
    right: 0;
  }
}

.culture-bnr-box01 .inner {
  display: flex;
  position: relative;
  box-shadow: 0 0 16px rgba(68, 68, 68, 0.4901960784);
}
@media (max-width: 480px) {
  .culture-bnr-box01 .inner {
    flex-direction: column;
  }
}
.culture-bnr-box01 .inner .culture-bnr-box01__img {
  width: 804px;
  overflow: hidden;
}
@media (max-width: 480px) {
  .culture-bnr-box01 .inner .culture-bnr-box01__img {
    width: 100%;
  }
}
.culture-bnr-box01 .inner .culture-bnr-box01__img img {
  transition: transform 0.3s cubic-bezier(0.33, 0.93, 0.57, 0.96), filter 0.3s cubic-bezier(0.33, 0.93, 0.57, 0.96);
}
.culture-bnr-box01 .inner .culture-bnr-box01__txt {
  flex: 1;
  background-color: #d80c24;
  color: #fff;
  transition: background-color 0.3s cubic-bezier(0.33, 0.93, 0.57, 0.96), color 0.3s cubic-bezier(0.33, 0.93, 0.57, 0.96);
}
.culture-bnr-box01 .inner .culture-bnr-box01__txt .culture-bnr-box01__txt--in {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media (max-width: 480px) {
  .culture-bnr-box01 .inner .culture-bnr-box01__txt .culture-bnr-box01__txt--in {
    padding: 5.7692307692vw 0 6.4102564103vw;
  }
}
.culture-bnr-box01 .inner .culture-bnr-box01__txt .culture-bnr-box01__txt--in .txt01 {
  font-size: 2.1rem;
  font-weight: bold;
  color: #d80c24;
  text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, -1px 0 #FFF, -1px 0 0 #FFF, 1px 0 0 #FFF;
}
.culture-bnr-box01 .inner .culture-bnr-box01__txt .culture-bnr-box01__txt--in .txt02 {
  font-size: 6.5rem;
  line-height: 1.2;
  letter-spacing: 0.05em;
  font-weight: bold;
  font-family: "Roboto", sans-serif;
}
@media (max-width: 480px) {
  .culture-bnr-box01 .inner .culture-bnr-box01__txt .culture-bnr-box01__txt--in .txt02 {
    font-size: 11.9230769231vw;
    letter-spacing: 0.1em;
  }
}
.culture-bnr-box01 .inner .culture-bnr-box01__txt .culture-bnr-box01__txt--in .txt03 {
  font-weight: 500;
}
.culture-bnr-box01 .inner::before {
  content: "";
  width: 68px;
  height: auto;
  aspect-ratio: 1/1;
  background-color: #111;
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  position: absolute;
  bottom: 5px;
  right: 5px;
  z-index: 1;
  transition: background-color 0.3s;
}
@media (max-width: 480px) {
  .culture-bnr-box01 .inner::before {
    width: 8.7179487179vw;
  }
}
.culture-bnr-box01 .inner::after {
  content: "";
  width: 50px;
  height: 2px;
  background-color: #fff;
  position: absolute;
  bottom: 29px;
  right: 13px;
  z-index: 1;
}
@media (max-width: 480px) {
  .culture-bnr-box01 .inner::after {
    width: 5.7692307692vw;
    height: 0.2564102564vw;
    bottom: 5.1282051282vw;
    right: 2.5641025641vw;
  }
}
@media (min-width: 480px) {
  .culture-bnr-box01 .inner:hover .culture-bnr-box01__img img {
    transform: scale(1.05);
    filter: brightness(0.8);
  }
  .culture-bnr-box01 .inner:hover .culture-bnr-box01__txt {
    background-color: #fff;
    color: #d80c24;
  }
  .culture-bnr-box01 .inner:hover::before {
    background-color: #d80c24;
  }
}

.stalker {
  background-color: #d80c24;
  width: -moz-fit-content;
  width: fit-content;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.5em;
  font-size: 0.7em;
  font-family: "Roboto", sans-serif;
  position: fixed;
  left: -18px;
  top: -18px;
  z-index: 499;
  pointer-events: none;
  opacity: 0;
  transition: transform 0.1s;
  mix-blend-mode: hard-light;
}
@media (max-width: 480px) {
  .stalker {
    display: none;
  }
}

@media (max-width: 480px) {
  .js-scrolltable {
    overflow-x: auto;
    white-space: nowrap;
    margin-top: 3.8461538462vw;
    position: relative;
  }
  .js-scrolltable::before {
    content: "この表は横にスクロールすることでご覧いただけます。";
    font-size: 2.3076923077vw;
    color: #000;
  }
  .js-scrolltable::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    content: " ";
    display: block;
    width: 80vw;
    height: 23vw;
    background-image: url(../img/lp/scroll.png);
    background-color: rgba(0, 0, 0, 0.3);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 64vw;
    z-index: 1000;
  }
  .js-scrolltable.scroll-none::after {
    content: none;
  }
}

#pagetop {
  position: fixed;
  width: 60px;
  aspect-ratio: 60/58;
  bottom: -100vh;
  opacity: 0;
  right: 3%;
  z-index: 100;
  background: url(../img/pagetop.svg) center no-repeat;
  transition: transform 0.2s;
  filter: drop-shadow(1px 2px 2px #fff);
}
#pagetop.fixed {
  opacity: 1;
  display: block;
  z-index: 90;
}
@media (min-width: 480px) {
  #pagetop:hover {
    transform: translateY(-10%);
  }
}
@media (max-width: 480px) {
  #pagetop {
    width: 13.9743589744vw;
  }
}/*# sourceMappingURL=common.css.map */