@charset "UTF-8";
*:focus {
  outline: none;
}

body {
  margin: 0;
}

h1, h2, h3, h4, h5 {
  font-size: 100%;
  font-weight: inherit;
  margin: 0;
}

p {
  margin: 0;
}

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

ul, ol {
  padding: 0;
  margin: 0;
}

li {
  list-style: none;
}

dl, dt, dd {
  margin: 0;
  padding: 0;
}

button, input, select, textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: transparent;
  font-family: inherit;
  font-size: 100%;
}

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

table {
  table-layout: fixed;
  border-collapse: collapse;
}

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

sup, sub {
  font-size: 100%;
  vertical-align: baseline;
}

* {
  box-sizing: border-box;
}

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

@media screen and (max-width: 768px) {
  html {
    font-size: 2.6666666667vw;
  }
}
body {
  font-family: "FrutigerLTPro-Roman", "FP-ヒラギノUD角ゴ StdN W3";
  color: #333;
  background-color: #fff;
  position: relative;
  font-weight: 400;
  opacity: 0;
  transition: 0.3s all ease-in-out;
}
body.fixed {
  position: fixed;
}

section, main, header, footer {
  display: block;
}

img {
  display: block;
  max-width: 100%;
  margin: 0 auto;
}

* {
  box-sizing: border-box;
}

.u-ta-left {
  text-align: left !important;
}

.u-ta-center {
  text-align: center !important;
}

.u-ta-right {
  text-align: right !important;
}

.u-mt-0 {
  margin-top: 0 !important;
}

.u-mt-10 {
  margin-top: 1rem !important;
}

.u-mt-20 {
  margin-top: 2rem !important;
}

.u-mt-30 {
  margin-top: 3rem !important;
}

.u-mt-40 {
  margin-top: 4rem !important;
}

.u-mt-50 {
  margin-top: 5rem !important;
}

.u-mt-60 {
  margin-top: 6rem !important;
}

.u-mt-70 {
  margin-top: 7rem !important;
}

.u-mt-80 {
  margin-top: 8rem !important;
}

.u-mt-90 {
  margin-top: 9rem !important;
}

.u-mt-100 {
  margin-top: 10rem !important;
}

.u-mb-0 {
  margin-bottom: 0 !important;
}

.u-mb-10 {
  margin-bottom: 1rem !important;
}

.u-mb-20 {
  margin-bottom: 2rem !important;
}

.u-mb-30 {
  margin-bottom: 3rem !important;
}

.u-mb-40 {
  margin-bottom: 4rem !important;
}

.u-mb-50 {
  margin-bottom: 5rem !important;
}

.u-mb-60 {
  margin-bottom: 6rem !important;
}

.u-mb-70 {
  margin-bottom: 7rem !important;
}

.u-mb-80 {
  margin-bottom: 8rem !important;
}

.u-mb-90 {
  margin-bottom: 9rem !important;
}

.u-mb-100 {
  margin-bottom: 10rem !important;
}

.u-ml-0 {
  margin-left: 0 !important;
}

.u-ml-10 {
  margin-left: 1rem !important;
}

.u-ml-20 {
  margin-left: 2rem !important;
}

.u-ml-30 {
  margin-left: 3rem !important;
}

.u-ml-40 {
  margin-left: 4rem !important;
}

.u-ml-50 {
  margin-left: 5rem !important;
}

.u-mr-0 {
  margin-right: 0 !important;
}

.u-mr-10 {
  margin-right: 1rem !important;
}

.u-mr-20 {
  margin-right: 2rem !important;
}

.u-mr-30 {
  margin-right: 3rem !important;
}

.u-mr-40 {
  margin-right: 4rem !important;
}

.u-mr-50 {
  margin-right: 5rem !important;
}

.u-w-20p {
  width: 20% !important;
}

.u-w-25p {
  width: 25% !important;
}

.u-w-30p {
  width: 30% !important;
}

.u-w-35p {
  width: 35% !important;
}

.u-w-40p {
  width: 40% !important;
}

.u-w-45p {
  width: 45% !important;
}

.u-w-50p {
  width: 50% !important;
}

.u-w-55p {
  width: 55% !important;
}

.u-w-60p {
  width: 60% !important;
}

.u-w-65p {
  width: 65% !important;
}

.u-w-70p {
  width: 70% !important;
}

.u-w-75p {
  width: 75% !important;
}

.u-w-80p {
  width: 80% !important;
}

.u-w-85p {
  width: 85% !important;
}

.u-max-w-none {
  max-width: none !important;
}

@media screen and (max-width: 768px) {
  .u-sp-d-n {
    display: none !important;
  }
  .u-sp-ta-left {
    text-align: left !important;
  }
  .u-sp-ta-center {
    text-align: center !important;
  }
  .u-sp-ta-right {
    text-align: right !important;
  }
  .u-sp-mt-0 {
    margin-top: 0 !important;
  }
  .u-sp-mt-10 {
    margin-top: 1rem !important;
  }
  .u-sp-mt-20 {
    margin-top: 2rem !important;
  }
  .u-sp-mt-30 {
    margin-top: 3rem !important;
  }
  .u-sp-mt-40 {
    margin-top: 4rem !important;
  }
  .u-sp-mt-50 {
    margin-top: 5rem !important;
  }
  .u-sp-mt-60 {
    margin-top: 6rem !important;
  }
  .u-sp-mt-70 {
    margin-top: 7rem !important;
  }
  .u-sp-mt-80 {
    margin-top: 8rem !important;
  }
  .u-sp-mt-90 {
    margin-top: 9rem !important;
  }
  .u-sp-mt-100 {
    margin-top: 10rem !important;
  }
  .u-sp-mb-0 {
    margin-bottom: 0 !important;
  }
  .u-sp-mb-10 {
    margin-bottom: 1rem !important;
  }
  .u-sp-mb-20 {
    margin-bottom: 2rem !important;
  }
  .u-sp-mb-30 {
    margin-bottom: 3rem !important;
  }
  .u-sp-mb-40 {
    margin-bottom: 4rem !important;
  }
  .u-sp-mb-50 {
    margin-bottom: 5rem !important;
  }
  .u-sp-mb-60 {
    margin-bottom: 6rem !important;
  }
  .u-sp-mb-70 {
    margin-bottom: 7rem !important;
  }
  .u-sp-mb-80 {
    margin-bottom: 8rem !important;
  }
  .u-sp-mb-90 {
    margin-bottom: 9rem !important;
  }
  .u-sp-mb-100 {
    margin-bottom: 10rem !important;
  }
  .u-sp-ml-0 {
    margin-left: 0 !important;
  }
  .u-sp-ml-10 {
    margin-left: 1rem !important;
  }
  .u-sp-ml-20 {
    margin-left: 2rem !important;
  }
  .u-sp-ml-30 {
    margin-left: 3rem !important;
  }
  .u-sp-ml-40 {
    margin-left: 4rem !important;
  }
  .u-sp-ml-50 {
    margin-left: 5rem !important;
  }
  .u-sp-mr-0 {
    margin-right: 0 !important;
  }
  .u-sp-mr-10 {
    margin-right: 1rem !important;
  }
  .u-sp-mr-20 {
    margin-right: 2rem !important;
  }
  .u-sp-mr-30 {
    margin-right: 3rem !important;
  }
  .u-sp-mr-40 {
    margin-right: 4rem !important;
  }
  .u-sp-mr-50 {
    margin-right: 5rem !important;
  }
  .u-sp-w-20p {
    width: 20% !important;
  }
  .u-sp-w-25p {
    width: 25% !important;
  }
  .u-sp-w-30p {
    width: 30% !important;
  }
  .u-sp-w-35p {
    width: 35% !important;
  }
  .u-sp-w-40p {
    width: 40% !important;
  }
  .u-sp-w-45p {
    width: 45% !important;
  }
  .u-sp-w-50p {
    width: 50% !important;
  }
  .u-sp-w-55p {
    width: 55% !important;
  }
  .u-sp-w-60p {
    width: 60% !important;
  }
  .u-sp-w-65p {
    width: 65% !important;
  }
  .u-sp-w-70p {
    width: 70% !important;
  }
  .u-sp-w-75p {
    width: 75% !important;
  }
  .u-sp-w-80p {
    width: 80% !important;
  }
  .u-sp-w-85p {
    width: 85% !important;
  }
}
@media screen and (min-width: 769px) {
  .u-pc-d-n {
    display: none !important;
  }
  .u-pc-ta-left {
    text-align: left !important;
  }
  .u-pc-ta-center {
    text-align: center !important;
  }
  .u-pc-ta-right {
    text-align: right !important;
  }
  .u-pc-mt-0 {
    margin-top: 0 !important;
  }
  .u-pc-mt-10 {
    margin-top: 1rem !important;
  }
  .u-pc-mt-20 {
    margin-top: 2rem !important;
  }
  .u-pc-mt-30 {
    margin-top: 3rem !important;
  }
  .u-pc-mt-40 {
    margin-top: 4rem !important;
  }
  .u-pc-mt-50 {
    margin-top: 5rem !important;
  }
  .u-pc-mt-60 {
    margin-top: 6rem !important;
  }
  .u-pc-mt-70 {
    margin-top: 7rem !important;
  }
  .u-pc-mt-80 {
    margin-top: 8rem !important;
  }
  .u-pc-mt-90 {
    margin-top: 9rem !important;
  }
  .u-pc-mt-100 {
    margin-top: 10rem !important;
  }
  .u-pc-mb-0 {
    margin-bottom: 0 !important;
  }
  .u-pc-mb-10 {
    margin-bottom: 1rem !important;
  }
  .u-pc-mb-20 {
    margin-bottom: 2rem !important;
  }
  .u-pc-mb-30 {
    margin-bottom: 3rem !important;
  }
  .u-pc-mb-40 {
    margin-bottom: 4rem !important;
  }
  .u-pc-mb-50 {
    margin-bottom: 5rem !important;
  }
  .u-pc-mb-60 {
    margin-bottom: 6rem !important;
  }
  .u-pc-mb-70 {
    margin-bottom: 7rem !important;
  }
  .u-pc-mb-80 {
    margin-bottom: 8rem !important;
  }
  .u-pc-mb-90 {
    margin-bottom: 9rem !important;
  }
  .u-pc-mb-100 {
    margin-bottom: 10rem !important;
  }
  .u-pc-ml-0 {
    margin-left: 0 !important;
  }
  .u-pc-ml-10 {
    margin-left: 1rem !important;
  }
  .u-pc-ml-20 {
    margin-left: 2rem !important;
  }
  .u-pc-ml-30 {
    margin-left: 3rem !important;
  }
  .u-pc-ml-40 {
    margin-left: 4rem !important;
  }
  .u-pc-ml-50 {
    margin-left: 5rem !important;
  }
  .u-pc-mr-0 {
    margin-right: 0 !important;
  }
  .u-pc-mr-10 {
    margin-right: 1rem !important;
  }
  .u-pc-mr-20 {
    margin-right: 2rem !important;
  }
  .u-pc-mr-30 {
    margin-right: 3rem !important;
  }
  .u-pc-mr-40 {
    margin-right: 4rem !important;
  }
  .u-pc-mr-50 {
    margin-right: 5rem !important;
  }
  .u-pc-w-20p {
    width: 20% !important;
  }
  .u-pc-w-25p {
    width: 25% !important;
  }
  .u-pc-w-30p {
    width: 30% !important;
  }
  .u-pc-w-35p {
    width: 35% !important;
  }
  .u-pc-w-40p {
    width: 40% !important;
  }
  .u-pc-w-45p {
    width: 45% !important;
  }
  .u-pc-w-50p {
    width: 50% !important;
  }
  .u-pc-w-55p {
    width: 55% !important;
  }
  .u-pc-w-60p {
    width: 60% !important;
  }
  .u-pc-w-65p {
    width: 65% !important;
  }
  .u-pc-w-70p {
    width: 70% !important;
  }
  .u-pc-w-75p {
    width: 75% !important;
  }
  .u-pc-w-80p {
    width: 80% !important;
  }
  .u-pc-w-85p {
    width: 85% !important;
  }
}
.contents-area {
  font-size: 1.6rem;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .contents-area {
    line-height: 1.6;
  }
}

/*----------------------------------------
  Mixin
----------------------------------------*/
/*----------------------------------------
  HEADER
----------------------------------------*/
/* PC */
.header {
  width: 100%;
  max-width: 100vw;
  min-width: 100rem;
  padding: 1rem 2rem 0 2rem;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
}
.header-inner {
  width: 100%;
  height: 9rem;
  padding: 0 4rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(0, 0, 0, 0.6);
  border-radius: 5rem;
}
.header-inner .header-logo {
  width: 23.4rem;
  display: block;
}
.header-inner .header-nav {
  margin-left: auto;
  margin-right: 4rem;
}
.header-inner .header-nav .header-nav-list {
  display: flex;
  gap: 0 4rem;
  align-items: center;
}
.header-inner .header-nav .header-nav-list .header-nav_item .link {
  font-size: 1.6rem;
  color: #fff;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  .header-inner .header-nav .header-nav-list .header-nav_item .link {
    transition: 0.3s all;
  }
  .header-inner .header-nav .header-nav-list .header-nav_item .link:hover {
    opacity: 0.7;
  }
}
.header-inner .search {
  width: 4.6rem;
  height: 4.6rem;
  padding: 0 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 1rem;
  background: rgba(62, 68, 80, 0);
  border-radius: 2.3rem;
  overflow: hidden;
  transition: 0.5s all;
  display: none !important;
}
.header-inner .search:hover {
  background: #3e4450;
}
.header-inner .search input {
  width: 0;
  display: none;
}
.header-inner .search-img {
  width: 2.6rem;
  height: 2.6rem;
  flex-shrink: 1;
  cursor: pointer;
}
.header-inner .search.open {
  width: auto;
  padding: 0 1rem 0 2rem;
  background: #3e4450;
}
.header-inner .search.open input {
  width: 18rem;
  display: block;
  font-size: 1.6rem;
  color: #fff;
}
.header-inner .search.open-img {
  width: 2.6rem;
  height: 2.6rem;
  flex-shrink: 1;
}
.header-inner .menu {
  display: none;
}
.header .header-modal {
  display: none;
}
@media screen and (max-width: 768px) {
  .header {
    /* SP */
    min-width: auto;
    padding: 1rem;
  }
  .header-inner {
    height: 5rem;
    padding: 0 2rem;
    border-radius: 2.5rem;
    gap: 0 1.5rem;
  }
  .header-inner .header-logo {
    width: 15.2rem;
  }
  .header-inner .header-nav {
    display: none;
  }
  .header-inner .header-nav .header-nav-list {
    gap: 0 4rem;
  }
  .header-inner .header-nav .header-nav-list .header-nav_item .link {
    font-size: 1.6rem;
    color: #fff;
  }
  .header-inner .search {
    width: 3rem;
    height: 3rem;
    margin-left: auto;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0 1rem;
    background: none;
    border-radius: 2.3rem;
    overflow: hidden;
    transition: 0.3s all;
  }
  .header-inner .search:hover {
    background: none;
  }
  .header-inner .search input {
    display: none;
  }
  .header-inner .search-img {
    width: 2rem;
    height: 2rem;
    flex-shrink: 1;
  }
  .header-inner .search.open {
    width: 3rem;
    padding: 0;
    background: none;
  }
  .header-inner .search.open input {
    display: none;
  }
  .header-inner .menu {
    display: block;
  }
  .header-inner .menu-img {
    width: 2.7rem;
    height: 1.9rem;
  }
}
.header .header-modal {
  width: 100%;
  height: auto;
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 900;
}
.header .header-modal .modal-bg {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  background: rgba(0, 0, 0, 0);
  backdrop-filter: blur(0);
  -webkit-backdrop-filter: blur(0);
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease-in-out;
  will-change: backdrop-filter, opacity;
  z-index: 1;
}
.header .header-modal .modal-bg.is-active {
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(0.2rem);
  -webkit-backdrop-filter: blur(0.2rem);
  opacity: 1;
  visibility: visible;
}
.header .header-modal .modal-wrap {
  height: 100%;
  padding: 2.5rem 1rem 2rem;
  background: #000;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
}
.header .header-modal .modal-wrap .logo {
  width: 15.2rem;
  margin: 0 0 0 2rem;
}
.header .header-modal .modal-wrap .modal-close {
  width: 3rem;
  height: 3rem;
  position: absolute;
  top: 2rem;
  right: 2rem;
  cursor: pointer;
  transition: 0.3s all;
  z-index: 10;
}
.header .header-modal .modal-wrap .modal-close::before, .header .header-modal .modal-wrap .modal-close::after {
  width: 2.4rem;
  height: 0.3rem;
  content: "";
  background: #fff;
  position: absolute;
  left: 0.3rem;
  top: 1.3rem;
  transition: 0.3s all;
}
.header .header-modal .modal-wrap .modal-close::before {
  transform: rotate(45deg);
}
.header .header-modal .modal-wrap .modal-close::after {
  transform: rotate(-45deg);
}
.header .header-modal .modal-wrap .modal-content {
  width: 100%;
  display: none;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=search] {
  padding: 4rem 0 0;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=search] .search {
  width: 100%;
  height: 5rem;
  padding: 0 1.5rem 0 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0 1rem;
  background: #3f4451;
  border-radius: 2.5rem;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=search] .search input {
  width: 70%;
  color: #fff;
  font-size: 1.6rem;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=search] .search-img {
  width: 2rem;
  height: 2rem;
  margin: 0;
  flex-shrink: 1;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=menu] {
  padding: 6.5rem 0 0;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=menu] .nav-list {
  width: 100%;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=menu] .nav-list .nav_item {
  margin-bottom: 4rem;
  text-align: center;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=menu] .nav-list .nav_item .link {
  font-size: 2rem;
  color: #fff;
  text-align: center;
}
.header .header-modal .modal-wrap .modal-content[data-modal-content=menu] .nav-list .nav_item .link .en {
  margin: 0 auto 1rem;
  text-align: center;
  display: table;
  font-size: 2rem;
  font-family: "Smooch Sans";
  background: linear-gradient(90deg, #05c3c0 0%, #5775d6 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/*----------------------------------------
  BREADCRUMBS
----------------------------------------*/
.breadcrumbs {
  padding: 0.7rem 4rem 0.9rem;
  background: #3f4451;
}
.breadcrumbs .breadcrumbs_list {
  display: flex;
  gap: 0 1rem;
}
.breadcrumbs .breadcrumbs_list .breadcrumbs_link {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.25;
}
@media screen and (min-width: 769px) {
  .breadcrumbs .breadcrumbs_list .breadcrumbs_link {
    transition: 0.3s all;
  }
  .breadcrumbs .breadcrumbs_list .breadcrumbs_link:hover {
    opacity: 0.7;
  }
}
.breadcrumbs .breadcrumbs_list .breadcrumbs_link::after {
  width: 0.4rem;
  height: 0.8rem;
  margin-left: 0.5rem;
  background: url("/assets/img/common/shared/icon-arrow-next-wh.svg") no-repeat center center;
  background-size: cover;
  content: "";
  display: inline-block;
}
.breadcrumbs .breadcrumbs_list .breadcrumbs_current {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.25;
}
@media screen and (max-width: 768px) {
  .breadcrumbs {
    padding: 0.5rem 2rem;
    display: flex;
    flex-flow: nowrap;
  }
  .breadcrumbs .breadcrumbs_list {
    overflow: scroll;
    flex-shrink: 1;
    white-space: nowrap;
    gap: 0 1rem;
  }
  .breadcrumbs .breadcrumbs_list .breadcrumbs_item {
    display: inline-block;
  }
  .breadcrumbs .breadcrumbs_list .breadcrumbs_item .breadcrumbs_link::after {
    margin-left: 1rem;
  }
  .breadcrumbs .breadcrumbs_list .breadcrumbs_current {
    width: auto;
    display: inline-block;
  }
}

/*----------------------------------------
  FOOTER
----------------------------------------*/
.footer {
  width: 100%;
  padding: 0 2rem;
  background: #000;
}
.footer-inner {
  width: 96rem;
  max-width: 100%;
  margin: 0 auto;
  padding: 6rem 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.footer-inner .footer-logo {
  margin-right: auto;
}
.footer-inner .footer-nav-list {
  display: flex;
  gap: 0 4rem;
  align-items: center;
}
.footer-inner .footer-nav-list .footer-nav_item .link {
  font-size: 1.6rem;
  color: #fff;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  .footer-inner .footer-nav-list .footer-nav_item .link {
    transition: 0.3s all;
  }
  .footer-inner .footer-nav-list .footer-nav_item .link:hover {
    opacity: 0.7;
  }
}
.footer-inner .sns {
  width: 100%;
  margin-top: 3rem;
  padding: 5rem 0;
  border-top: 0.1rem solid #666;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 2.5rem;
}
@media screen and (min-width: 769px) {
  .footer-inner .sns .icon {
    transition: 0.3s all;
  }
  .footer-inner .sns .icon:hover {
    opacity: 0.7;
  }
}
.footer-inner .footer-link {
  width: 100%;
  margin-bottom: 2.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 6.5rem;
}
.footer-inner .footer-link .footer-link_item .link {
  font-size: 1.4rem;
  color: #fff;
}
@media screen and (min-width: 769px) {
  .footer-inner .footer-link .footer-link_item .link {
    transition: 0.3s all;
  }
  .footer-inner .footer-link .footer-link_item .link:hover {
    opacity: 0.7;
  }
}
.footer-inner .copyright-wrap {
  width: 100%;
  text-align: center;
}
.footer-inner .copyright-wrap .copyright {
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .footer {
    /* SP */
    width: 100%;
    background: #000;
  }
  .footer-inner {
    width: 100%;
    margin: 0 auto;
    padding: 4rem 0;
  }
  .footer-inner .footer-logo {
    width: 12.4rem;
    margin: 0 auto 3.5rem;
  }
  .footer-inner .footer-nav-list {
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .footer-inner .footer-nav-list .footer-nav_item:first-child {
    width: 100%;
    text-align: center;
  }
  .footer-inner .footer-nav-list .footer-nav_item .link {
    font-size: 1.4rem;
  }
  .footer-inner .sns {
    margin-top: 2.5rem;
    padding: 4rem 0 3.2rem;
    gap: 0 3rem;
  }
  .footer-inner .sns .sns-logo.youtube .icon {
    width: 3.6rem;
  }
  .footer-inner .sns .sns-logo.x .icon {
    width: 2.7rem;
  }
  .footer-inner .sns .sns-logo.linkedin .icon {
    width: 3.5rem;
  }
  .footer-inner .footer-link {
    width: 100%;
    margin-bottom: 3.5rem;
    flex-wrap: wrap;
    gap: 1.5rem 2.8rem;
  }
  .footer-inner .footer-link .footer-link_item .link {
    font-size: 1.3rem;
  }
  .footer-inner .copyright-wrap .copyright {
    font-size: 1rem;
  }
}

/*----------------------------------------
  Modal
----------------------------------------*/
.modal {
  width: 100%;
  height: auto;
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
}
.modal .modal-bg {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0);
  backdrop-filter: blur(0);
  -webkit-backdrop-filter: blur(0);
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease-in-out;
  will-change: backdrop-filter, opacity;
  z-index: 1;
}
.modal .modal-bg.is-active {
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(0.2rem);
  -webkit-backdrop-filter: blur(0.2rem);
  opacity: 1;
  visibility: visible;
}
.modal .modal-wrap {
  width: 96rem;
  height: 100dvh;
  margin: 0 auto;
  padding: 16rem 0;
  position: relative;
  z-index: 2;
}
.modal .modal-close {
  width: 6rem;
  height: 6rem;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  top: 13rem;
  right: -3rem;
  cursor: pointer;
  transition: 0.3s all;
  z-index: 10;
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.2);
}
.modal .modal-close::before, .modal .modal-close::after {
  width: 2.4rem;
  height: 0.3rem;
  content: "";
  background: #000;
  position: absolute;
  left: 1.8rem;
  top: 2.8rem;
  transition: 0.3s all;
}
.modal .modal-close::before {
  transform: rotate(45deg);
}
.modal .modal-close::after {
  transform: rotate(-45deg);
}
.modal .modal-content {
  width: 96rem;
  height: calc(100vh - 26rem);
  margin: 0 auto;
  overflow-y: scroll;
  overflow-x: hidden;
}
.modal .modal-content::-webkit-scrollbar {
  width: 0.8rem;
  background: #eee;
}
.modal .modal-content::-webkit-scrollbar-thumb {
  background-color: #b3b3b3;
  border-radius: 0.5rem;
}
@media screen and (max-width: 768px) {
  .modal {
    height: 100vh;
  }
  .modal .modal-wrap {
    width: 100%;
    height: 100dvh;
    padding: 3.5rem 2rem;
    z-index: 2;
  }
  .modal .modal-close {
    width: 4rem;
    height: 4rem;
    top: 1.5rem;
    right: 1.5rem;
  }
  .modal .modal-close::before, .modal .modal-close::after {
    width: 2.4rem;
    height: 0.3rem;
    left: 0.8rem;
    top: 1.8rem;
  }
  .modal .modal-content {
    width: 100%;
    height: 100%;
  }
}
.modal[data-modal-id=about] .modal-wrap .modal-title-area {
  padding: 9rem 6rem;
  background: url("/assets/img/common/p/bg-modal-about.png") no-repeat top center;
  background-size: cover;
}
.modal[data-modal-id=about] .modal-wrap .modal-title-area .modal-title {
  margin-bottom: 1rem;
  font-size: 4rem;
  font-family: "FrutigerLTPro-Bold", "FP-ヒラギノUD角ゴ StdN W5";
  color: #fff;
  text-align: center;
}
.modal[data-modal-id=about] .modal-wrap .modal-title-area .modal-text {
  margin: 0 auto;
  padding: 1rem;
  background: #000;
  font-size: 1.6rem;
  line-height: 1.875;
  color: #fff;
  text-align: center;
}
.modal[data-modal-id=about] .modal-wrap .modal-detail {
  padding: 6rem;
  background: #fff;
  display: flex;
  gap: 0 4rem;
}
.modal[data-modal-id=about] .modal-wrap .modal-detail .content {
  width: 40rem;
}
.modal[data-modal-id=about] .modal-wrap .modal-detail .content-img {
  margin-bottom: 3.5rem;
}
.modal[data-modal-id=about] .modal-wrap .modal-detail .content-title {
  margin-bottom: 2.5rem;
  font-size: 2.4rem;
  line-height: 1.416;
  font-family: "FrutigerLTPro-Bold", "FP-ヒラギノUD角ゴ StdN W5";
  text-align: center;
}
.modal[data-modal-id=about] .modal-wrap .modal-detail .content-text {
  margin-bottom: 2rem;
  font-size: 1.6rem;
  line-height: 1.875;
  letter-spacing: 0.04em;
  text-align: justify;
}
.modal[data-modal-id=about] .modal-wrap .modal-detail .content-link {
  margin-left: auto;
  padding-right: 2rem;
  display: table;
  font-size: 1.6rem;
  font-family: "FrutigerLTPro-Bold", "FP-ヒラギノUD角ゴ StdN W5";
  background: url("/assets/img/common/shared/icon-arrow-next-bk.svg") no-repeat 98% 52%;
}
@media screen and (min-width: 769px) {
  .modal[data-modal-id=about] .modal-wrap .modal-detail .content-link {
    transition: 0.3s all;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-detail .content-link:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 768px) {
  .modal[data-modal-id=about] .modal-wrap .modal-title-area {
    padding: 6rem 3rem;
    background: url("/assets/img/common/s/bg-modal-about.png") no-repeat top center;
    background-size: cover;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-title-area .modal-title {
    margin-bottom: 3rem;
    font-size: 2.4rem;
    letter-spacing: 0.04em;
    line-height: 1.4;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-title-area .modal-text {
    width: 100%;
    font-size: 1.4rem;
    line-height: 1.642;
    letter-spacing: 0.04em;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-detail {
    width: 100%;
    padding: 3rem 2rem;
    gap: 4.5rem 0;
    flex-wrap: wrap;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-detail .content {
    width: 100%;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-detail .content-img {
    margin-bottom: 3.5rem;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-detail .content-title {
    margin-bottom: 2rem;
    font-size: 2rem;
    line-height: 1.4;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-detail .content-text {
    margin-bottom: 1.5rem;
    font-size: 1.4rem;
    line-height: 1.642;
  }
  .modal[data-modal-id=about] .modal-wrap .modal-detail .content-link {
    font-size: 1.4rem;
  }
}

/*----------------------------------------
  mv
----------------------------------------*/
.mv {
  position: relative;
  z-index: 0;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 9vw), 0 100%);
  overflow: visible;
  /* SP */
  /*--sitepolicy--*/
}
.mv .inner {
  width: 100%;
  padding: 25rem 2rem 23rem;
  position: relative;
  z-index: 10;
}
.mv .inner .title {
  font-size: 3.2rem;
  font-family: "FrutigerLTPro-Bold", "FP-ヒラギノUD角ゴ StdN W5";
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .mv .inner {
    width: 100%;
    min-height: 25rem;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .mv .inner .title {
    font-size: 2.4rem;
    line-height: 1.458;
  }
}
.mv.sitepolicy {
  background: url("/assets/img/sitepolicy/p/bg-mv.png") no-repeat center center;
  background-size: cover;
  /* SP */
}
@media screen and (max-width: 768px) {
  .mv.sitepolicy {
    background: url("/assets/img/sitepolicy/s/bg-mv.png") no-repeat center center;
    background-size: cover;
    margin-bottom: 6.5rem;
  }
}

/*----------------------------------------
  banner
----------------------------------------*/
@media screen and (max-width: 768px) {
  .banner-area {
    padding-bottom: 10rem;
  }
  .banner-area-item {
    padding: 0 2rem;
  }
  .banner-area-item_image {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .banner-area {
    padding-top: 3.5rem;
    padding-bottom: 25rem;
  }
  .banner-area-item {
    width: 100rem;
    padding: 0 2rem;
    margin: 0 auto;
  }
  .banner-area-item_link {
    transition: 0.3s all;
  }
  .banner-area-item_link:hover {
    opacity: 0.7;
  }
  .banner-area-item_image {
    width: 100%;
  }
}