/* Common
---------------------------*/
html {
  font-size: 62.5%;
}

body {
  color: #323232;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 2;
  font-feature-settings: "palt";
  text-align: justify;
  letter-spacing: 0.1em;
  margin: 0;
}

@media screen and (max-width: 1099px) {
  body {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 767px) {
  body {
    letter-spacing: 0;
  }
}

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

.btn {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #FFF;
  background-color: #323232;
  width: 240px;
  height: 60px;
  line-height: 1;
  text-decoration: none;
  border: 0;
  position: relative;
  transition: all .5s ease;
}

.btn__line {
  display: block;
  position: absolute;
  top: 50%;
  right: 200px;
  width: 60px;
  height: 1px;
  overflow: hidden;
}

.btn__line::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #828282;
}

.btn.hover {
  background-color: #b8b8b8;
}

.btn.hover .btn__line::before {
  animation: btnLine 0.8s 1 cubic-bezier(0.6, 0.01, 0.46, 0.99);
}

.btn__ico {
  position: absolute;
  right: 17px;
}

@media screen and (max-width: 1099px) {
  .br--pc {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .br--tab {
    display: none;
  }
}

.br--sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .br--sp {
    display: block;
  }
}

.txt-animation .char {
  display: inline-block;
  opacity: 0;
  transform: translateY(20px);
  transition: all .5s ease;
}

.txt-animation .char.on {
  opacity: 1;
  transform: translateY(0);
}

@media screen and (max-width: 767px) {
  .txt-animation .char--tab {
    display: none;
  }
}

.loading {
  position: fixed;
  z-index: 9999;
  width: 110vw;
  height: 110vh;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #323232;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  transition: all .5s ease;
  visibility: visible;
  opacity: 1;
}

.loading.hide {
  visibility: hidden;
  opacity: 0;
}

.loading__txt {
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 2rem;
  text-align: center;
  color: #FFF;
  margin-bottom: 25px;
}

@media screen and (max-width: 767px) {
  .loading__txt {
    letter-spacing: 0.1em;
  }
}

.loading__line {
  position: relative;
  overflow: hidden;
  width: 200px;
  height: 1px;
}

.loading__line::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #FFF;
  animation: loadingLine 1.5s infinite cubic-bezier(0.6, 0.01, 0.46, 0.99);
}

.form p {
  margin: 0;
}

.form input[type="text"], .form input[type="email"], .form textarea {
  border: 0;
  padding: 16px;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .form input[type="text"], .form input[type="email"], .form textarea {
    margin-bottom: 5px;
  }
}

.form span.your-name, .form span.your-email, .form span.your-subject {
  display: inline-block;
  width: 100%;
  margin-bottom: 35px;
}

@media screen and (max-width: 767px) {
  .form span.your-name, .form span.your-email, .form span.your-subject {
    margin-bottom: 15px;
  }
}

.form__flex {
  display: flex;
  justify-content: space-between;
}

.form__flex > span.your-name, .form__flex span.your-email {
  width: 48%;
}

@media screen and (max-width: 767px) {
  .form__flex > span.your-name, .form__flex span.your-email {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .form__flex {
    display: block;
  }
}

.form .input-name, .form .input-email {
  width: 100%;
}

.form .input-subject {
  width: 100%;
}

.form .input-message {
  width: 100%;
  margin-bottom: 0;
}

@media screen and (max-width: 767px) {
  .form__sbmt {
    margin: 30px auto 0;
  }
}

.form__recaptcha-txt {
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: #b5b5b5;
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 300;
  line-height: 1.2;
  margin-top: 1em;
  margin-bottom: 50px;
}

@media screen and (max-width: 767px) {
  .form__recaptcha-txt {
    letter-spacing: 0.1em;
  }
}

.form__recaptcha-txt > a {
  color: #323232;
  font-weight: 500;
  transition: all .5s ease;
}

.form__recaptcha-txt > a.hover {
  opacity: .5;
}

.grecaptcha-badge {
  visibility: hidden !important;
}

.wpcf7-spinner {
  display:block;
  margin:15px auto 0;
}


.page-title {
  height: 468px;
  box-sizing: border-box;
  text-align: center;
  color: #FFF;
  background: #323232;
  padding-top: 240px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .page-title {
    height: 280px;
    padding-top: 160px;
  }
}

.page-title__img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1.5s ease;
}

.page-title__img.visible {
  opacity: 1;
}

@media screen and (max-width: 1340px) {
  .page-title__img {
    object-position: 80% 0;
  }
}

@media screen and (max-width: 767px) {
  .page-title__img {
    object-position: 75% 0;
  }
}

.page-title__h2 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 8rem;
  line-height: 1;
  margin: 0 0 15px;
}

@media screen and (max-width: 1099px) {
  .page-title__h2 {
    font-size: 6.6rem;
  }
}

@media screen and (max-width: 767px) {
  .page-title__h2 {
    font-size: 3.7rem;
  }
}

.page-title__txt {
  font-size: 2rem;
  margin: 0;
}

@media screen and (max-width: 1099px) {
  .page-title__txt {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .page-title__txt {
    font-size: 1.4rem;
  }
}

/* Header
---------------------------*/
.main-header {
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  display: flex;
  justify-content: space-between;
  width: 100%;
  padding: 50px 50px 50px 45px;
  box-sizing: border-box;
  transition: all 1s ease;
}

@media screen and (max-width: 767px) {
  .main-header {
    padding: 20px 28px;
  }
}

.main-header.on {
  background-color: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(8px);
  padding-top: 20px;
  padding-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .main-header.on {
    padding-top: 10px;
    padding-bottom: 10px;
  }
}

.main-header__h1 {
  margin: 0;
  font-size: 0;
}

.main-header.on .main-header__h1 {
  height: 40px;
}

.main-header__h1 a {
  opacity: 1;
  transition: opacity .5s ease;
}

.main-header__h1 a.hover {
  opacity: .7;
}

.main-header__link {
  text-decoration: none;
}

.main-header .site-logo, .main-header .site-logo--sp-menu {
  height: auto;
  vertical-align: top;
  margin-top: 20px;
  transition: all 1s ease;
}

@media screen and (max-width: 767px) {
  .main-header .site-logo, .main-header .site-logo--sp-menu {
    width: 83px;
    margin-top: 10px;
  }
}

.main-header .site-logo path, .main-header .site-logo--sp-menu path {
  transition: all 1s ease;
}

.main-header.on .site-logo {
  width: 74px;
  margin-top: 4px;
}

.main-header.on .site-logo path {
  fill: #323232;
}

.main-header .site-name, .main-header .site-name--sp-menu {
  width: 128px;
  height: auto;
  vertical-align: top;
  margin-left: 35px;
  transition: all 1s ease;
}

@media screen and (max-width: 767px) {
  .main-header .site-name, .main-header .site-name--sp-menu {
    width: 72px;
    margin-left: 16px;
  }
}

.main-header.on .site-name {
  width: 0px;
  opacity: 0;
}

.main-header__menu {
  list-style: none;
  padding-left: 0;
  margin: 0;
  display: flex;
}

@media screen and (max-width: 1099px) {
  .main-header__menu {
    display: none;
  }
}

.main-header.on .main-header__menu {
  height: 40px;
}

.main-header__menu-item {
  margin-left: 35px;
}

.main-header__menu-item--mr0 {
  margin-left: 0;
}

.main-header__menu-item--sp {
  width: 319px;
  margin: 0 auto;
}

@media screen and (max-width: 374px) {
  .main-header__menu-item--sp {
    width: 85%;
  }
}

.main-header__menu-item--sp-logo {
  position: fixed;
  top: 50px;
  left: 45px;
}

@media screen and (max-width: 767px) {
  .main-header__menu-item--sp-logo {
    top: 20px;
    left: 28px;
  }
}

.main-header__menu-link {
  color: #FFF;
  text-decoration: none;
  display: block;
  position: relative;
}

.main-header__menu-link::after {
  content: "";
  display: block;
  width: 0;
  height: 1px;
  background-color: #FFF;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: all .3s ease;
}

.main-header__menu-link.hover::after {
  width: 100%;
}

.main-header.on .main-header__menu-link {
  color: #323232;
}

.main-header.on .main-header__menu-link::after {
  background-color: #323232;
}

.main-header__menu-link--sp {
  color: #FFF;
  text-decoration: none;
  display: block;
  position: relative;
  padding: 10px 0;
}

.main-header__menu-link--sp::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #6E6E6E;
  position: absolute;
  bottom: 0;
  left: 0;
}

.main-header__menu-link--sp::after {
  content: "";
  display: block;
  width: 0;
  height: 1px;
  background-color: #FFF;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: all .5s ease;
}

.main-header__menu-link--sp.hover::after {
  width: 100%;
}

.main-header__menu-link--sp-logo {
  text-decoration: none;
}

.main-header__menu--sp {
  display: none;
}

@media screen and (max-width: 1099px) {
  .main-header__menu--sp {
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    list-style: none;
    padding-left: 0;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    box-sizing: border-box;
    background-color: #323232;
    margin: 0;
    opacity: 0;
    visibility: hidden;
    transform: scale(1.2);
    transition: all .5s ease;
  }
  .main-header__menu--sp.on {
    opacity: 1;
    visibility: visible;
    transform: scale(1);
  }
}

@media screen and (max-width: 767px) {
  .main-header__menu--sp {
    padding: 20px 28px;
  }
}

.menu-btn {
  display: none;
  width: 42px;
  height: 42px;
  position: absolute;
  top: 20px;
  right: 55px;
  color: #FFF;
}

@media screen and (max-width: 767px) {
  .menu-btn {
    width: 28px;
    height: 28px;
    top: 16px;
    right: 25px;
  }
}

.main-header.on .menu-btn {
  color: #323232;
}

.menu-btn.close {
  color: #FFF !important;
}

@media screen and (max-width: 1099px) {
  .menu-btn {
    display: block;
  }
}

.menu-btn__line {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-color: #FFF;
  transition: all .5s ease;
}

.main-header.on .menu-btn__line {
  background-color: #323232;
}

.close .menu-btn__line {
  transform: translateY(7px) rotate(-28deg);
  background-color: #FFF !important;
}

@media screen and (max-width: 767px) {
  .close .menu-btn__line {
    transform: translateY(5px) rotate(-28deg);
  }
}

.menu-btn__line--s {
  width: 30px;
  top: 35%;
}

@media screen and (max-width: 767px) {
  .menu-btn__line--s {
    width: 20px;
  }
}

.close .menu-btn__line--s {
  transform: translateY(-7px) rotate(28deg);
  width: 100%;
}

@media screen and (max-width: 767px) {
  .close .menu-btn__line--s {
    transform: translateY(-5px) rotate(28deg);
  }
}

.menu-btn__txt {
  position: absolute;
  bottom: 0;
  right: 0;
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 1.2rem;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .menu-btn__txt {
    letter-spacing: 0.1em;
  }
}

@media screen and (max-width: 767px) {
  .menu-btn__txt {
    font-size: 0.9rem;
  }
}

/* Footer
---------------------------*/
.main-footer {
  background-color: #323232;
  color: #FFF;
  padding: 0 0 85px 0;
}

@media screen and (max-width: 767px) {
  .main-footer {
    padding: 0 0 45px 0;
  }
}

.main-footer__content {
  width: 90%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

@media screen and (max-width: 767px) {
  .main-footer__content {
    display: block;
    width: 85%;
  }
}

.main-footer__content--primary {
  padding-bottom: 80px;
    padding-top: 80px;
}

@media screen and (max-width: 767px) {
  .main-footer__content--primary {
    padding-bottom: 35px;
      padding-top: 35px;
  }
}

.main-footer__content--secondary {
  flex-direction: row-reverse;
  border-top: 1px solid #505050;
  padding-top: 80px;
}

@media screen and (max-width: 767px) {
  .main-footer__content--secondary {
    padding-top: 35px;
  }
}

.main-footer__logo {
  display: inline-block;
  max-width: 450px;
  width: 30%;
  opacity: 1;
  transition: opacity .5s ease;
}

@media screen and (max-width: 767px) {
  .main-footer__logo {
    width: 193px;
  }
}

.main-footer__logo.hover {
  opacity: .7;
}

@media screen and (max-width: 767px) {
  .main-footer__nav {
    margin-top: 45px;
  }
}

.main-footer__menu {
  margin: 0;
  padding-left: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  width: 500px;
}

@media screen and (max-width: 767px) {
  .main-footer__menu {
    width: 100%;
    justify-content: flex-start;
  }
}

.main-footer__menu-item {
  margin-left: 25px;
  margin-bottom: 15px;
}

@media screen and (max-width: 767px) {
  .main-footer__menu-item {
    width: 50%;
    margin-left: 0;
  }
  .main-footer__menu-item:nth-of-type(odd) {
    width: 34%;
  }
}

.main-footer__menu-link {
  color: #FFF;
  text-decoration: none;
  display: block;
  position: relative;
}

@media screen and (max-width: 767px) {
  .main-footer__menu-link {
    display: inline-block;
  }
}

.main-footer__menu-link::after {
  content: "";
  display: block;
  width: 0;
  height: 1px;
  background-color: #FFF;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: all .3s ease;
}

.main-footer__menu-link.hover::after {
  width: 100%;
}

.main-footer__company, .main-footer__copyright {
  font-size: 1.3rem;
}

@media screen and (max-width: 767px) {
  .main-footer__company, .main-footer__copyright {
    font-size: 1rem;
  }
}

.main-footer__bnrarea{
    background: #dddddd;
    padding: 80px 0;
}
@media screen and (max-width: 767px) {
  .main-footer__bnrarea{
    padding: 35px 0;
    }
}
ul.main-footer__bnrareaList{
    width: 80%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0;
    display: flex;
    justify-content: space-between;
}
@media screen and (max-width: 767px) {
    ul.main-footer__bnrareaList {
        width: 85%;
            flex-wrap: wrap;
    }
}
ul.main-footer__bnrareaList li{
    list-style: none;
    width: 23%;
}
@media screen and (max-width: 767px) {
    ul.main-footer__bnrareaList li{
    width: 48%;
    margin-bottom: 5%;
    }
}
ul.main-footer__bnrareaList li img{
    display: block;
    transition: opacity .5s ease;
}
ul.main-footer__bnrareaList li a img:hover {
    opacity: .5;
}


/* Home
---------------------------*/
.home .fv {
  position: relative;
  min-height: 100vh;
  min-height: calc(var(--vh, 1vh) * 100);
  background-color: #323232;
  color: #FFF;
}

.home .fv__img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1.5s ease;
}

.home .fv__img.visible {
  opacity: 1;
}

.home .fv__center {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  max-width: 1100px;
  width: 90%;
  height: 100%;
  margin: 0;
  padding-left: 50px;
  box-sizing: border-box;
  display: flex;
  flex-wrap: wrap;
  flex-flow: column;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .home .fv__center {
    padding-left: 4vw;
  }
}

.home .fv__h2 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 8rem;
  line-height: 1.3em;
  width: 100%;
  margin: 0 0 8px;
}

@media screen and (max-width: 767px) {
  .home .fv__h2 {
    font-size: 10.665vw;
  }
}

.home .fv__h2 > p {
  margin: 0;
}

.home .fv__txt {
  margin: 15px 0 0 10px;
  line-height: 2;
}

@media screen and (max-width: 767px) {
  .home .fv__txt {
    font-size: 1.3rem;
    margin-left: 0;
  }
}

.home .fv__scroll {
  position: absolute;
  bottom: 0;
  left: 65px;
  overflow: hidden;
  width: 1px;
  height: 150px;
}

@media screen and (max-width: 767px) {
  .home .fv__scroll {
    left: 4vw;
  }
}

@media screen and (max-height: 599px) {
  .home .fv__scroll {
    height: 100px;
  }
}

.home .fv__scroll::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #FFF;
  animation: scroll 1.5s infinite cubic-bezier(0.6, 0.01, 0.46, 0.99);
}

.home .fv__company {
  margin: 0;
  position: absolute;
  bottom: 50px;
  right: 45px;
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 1.4rem;
}

@media screen and (max-width: 767px) {
  .home .fv__company {
    letter-spacing: 0.1em;
  }
}

@media screen and (max-width: 767px) {
  .home .fv__company {
    font-size: 10px;
    bottom: 24px;
    right: 28px;
    text-align: right;
  }
}

.home .sect01 {
  margin-top: 115px;
  margin-bottom: 186px;
  background: url("../img/home/sect01_bg.jpg") right 80px/100% auto no-repeat;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .home .sect01 {
    background-image: url("../img/home/sect01_bg_sp.jpg");
    background-position: right 145px;
    margin-top: 65px;
    margin-bottom: 100px;
  }
}

@media screen and (min-width: 500px) and (max-width: 767px) {
  .home .sect01 {
    background-size: 70% auto;
  }
}

.home .sect01__p {
  max-width: 990px;
  margin: 0 auto;
  font-size: 2.7rem;
  line-height: 2.1;
}

@media screen and (max-width: 1099px) {
  .home .sect01__p {
    width: 652px;
    font-size: 2.4rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01__p {
    width: 85%;
    font-size: 1.6rem;
  }
}

.home .sect01 .location {
  max-width: 1100px;
  margin: 100px auto 0;
  position: relative;
}

@media screen and (max-width: 1280px) {
  .home .sect01 .location {
    max-width: initial;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location {
    margin-top: 48vw;
  }
}

@media screen and (min-width: 500px) and (max-width: 767px) {
  .home .sect01 .location {
    margin-top: 30vw;
  }
}

.home .sect01 .location__h3 {
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 12rem;
  line-height: 1;
  position: absolute;
  top: 0;
  left: -0.8em;
  margin: 0;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transition: all 1.5s ease;
  opacity: 0;
  transform: scale(2);
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__h3 {
    letter-spacing: 0.1em;
  }
}

@media screen and (max-width: 1280px) {
  .home .sect01 .location__h3 {
    left: 0;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__h3 {
    font-size: 6rem;
  }
}

@media screen and (min-width: 500px) and (max-width: 767px) {
  .home .sect01 .location__h3 {
    font-size: 9rem;
  }
}

.home .sect01 .location__h3.visible {
  opacity: .1;
  transform: scale(1);
}

.home .sect01 .location__flex {
  max-width: 990px;
  margin: 0 auto;
  position: relative;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .location__flex {
    max-width: 652px;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__flex {
    display: block;
  }
}

.home .sect01 .location__left {
  padding-top: 90px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .location__left {
    width: 267px;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__left {
    padding-top: 30px;
    width: 85%;
    margin: 0 auto;
  }
}

.home .sect01 .location__h4 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 9.6rem;
  line-height: 1;
  margin: 0 0 50px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .location__h4 {
    font-size: 6.4rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__h4 {
    font-size: 5rem;
    margin-bottom: 20px;
  }
}

.home .sect01 .location__p {
  margin: 0;
  line-height: 2;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .location__p {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__p {
    font-size: 1.4rem;
  }
}

.home .sect01 .location__p--big {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2.9rem;
  line-height: 1.7;
  margin: 0 0 50px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .location__p--big {
    font-size: 2rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__p--big {
    font-size: 2.3rem;
    margin-bottom: 30px;
  }
}

.home .sect01 .location__right {
  padding-top: 50px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .location__right {
    width: 334px;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__right {
    width: 85%;
    margin: 0 auto;
    padding-top: 30px;
  }
}

.home .sect01 .location__img-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__img-sp {
    display: block;
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__img01 {
    display: none;
  }
}

.home .sect01 .location__img02 {
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__img02 {
    display: none;
  }
}

.home .sect01 .location__btn {
  margin-top: 50px;
}

@media screen and (max-width: 767px) {
  .home .sect01 .location__btn {
    margin: 25px auto 0;
  }
}

.home .sect01 .service {
  max-width: 1100px;
  margin: 100px auto 0;
  position: relative;
}

@media screen and (max-width: 1280px) {
  .home .sect01 .service {
    max-width: initial;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service {
    margin-top: 65px;
  }
}

.home .sect01 .service__h3 {
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 12rem;
  line-height: 1;
  position: absolute;
  z-index: 1;
  top: 0;
  right: -0.9em;
  margin: 0;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transition: all 1.5s ease;
  opacity: 0;
  transform: scale(2);
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__h3 {
    letter-spacing: 0.1em;
  }
}

@media screen and (max-width: 1280px) {
  .home .sect01 .service__h3 {
    right: 0;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__h3 {
    font-size: 6rem;
  }
}

@media screen and (min-width: 500px) and (max-width: 767px) {
  .home .sect01 .service__h3 {
    font-size: 9rem;
  }
}

.home .sect01 .service__h3.visible {
  opacity: .1;
  transform: scale(1);
}

.home .sect01 .service__flex {
  max-width: 990px;
  margin: 0 auto;
  position: relative;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .service__flex {
    max-width: 652px;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__flex {
    display: block;
  }
}

.home .sect01 .service__h4 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 9.6rem;
  line-height: 1;
  margin: 0 0 50px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .service__h4 {
    font-size: 6.4rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__h4 {
    font-size: 5rem;
    margin-bottom: 20px;
  }
}

.home .sect01 .service__p {
  margin: 0 0 25px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .service__p {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__p {
    font-size: 1.4rem;
  }
}

.home .sect01 .service__p--big {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2.9rem;
  line-height: 1.7;
  margin: 0 0 50px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .service__p--big {
    font-size: 2.473rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__p--big {
    font-size: 2.3rem;
  }
}

.home .sect01 .service__left {
  padding-top: 55px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .service__left {
    width: 334px;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__left {
    width: 85%;
    margin: 0 auto;
    padding-top: 30px;
  }
}

.home .sect01 .service__img-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__img-sp {
    display: block;
    width: 100%;
  }
}

.home .sect01 .service__img01 {
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__img01 {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__img02 {
    display: none;
  }
}

.home .sect01 .service__right {
  padding-top: 80px;
}

@media screen and (max-width: 1099px) {
  .home .sect01 .service__right {
    width: 267px;
  }
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__right {
    padding-top: 30px;
    width: 85%;
    margin: 0 auto;
  }
}

.home .sect01 .service__btn {
  margin-top: 50px;
}

@media screen and (max-width: 767px) {
  .home .sect01 .service__btn {
    margin: 25px auto 0;
  }
}

.home .sect02 {
  position: relative;
}

.home .sect02__h3 {
  position: absolute;
  z-index: 2;
  top: 180px;
  left: 50%;
  margin: 0 0 0 -650px;
}

@media screen and (max-width: 1536px) {
  .home .sect02__h3 {
    top: 9.35vw;
    left: 10%;
    margin-left: 0;
  }
}

@media screen and (max-width: 1099px) {
  .home .sect02__h3 {
    width: 187px;
    top: 75px;
  }
}

@media screen and (max-width: 767px) {
  .home .sect02__h3 {
    top: 45px;
    left: 45px;
  }
}

@media screen and (max-width: 1099px) {
  .home .sect02__img {
    height: 430px;
    width: 100%;
    object-fit: cover;
  }
}

@media screen and (max-width: 767px) {
  .home .sect02__img {
    height: 576px;
  }
}

.home .sect02__logo {
  display: block;
  width: 17.09vw;
}

@media screen and (max-width: 767px) {
  .home .sect02__logo {
    width: 163px;
  }
}

.home .sect02__p {
  position: absolute;
  bottom: 95px;
  left: 0;
  margin: 0;
  width: 100%;
  color: #FFF;
  text-align: center;
}

.home .sect02 .slick-dots {
  bottom: 50px;
}

.home .sect02 .slick-dots li {
  margin: 0 5px;
}

.home .sect02 .slick-dots li button {
  position: relative;
}

.home .sect02 .slick-dots li button::before {
  font-size: 0;
  display: block;
  width: 9px;
  height: 9px;
  opacity: 1;
  background-color: #bbb;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: all .3s ease;
}

.home .sect02 .slick-dots li button::after {
  content: "";
  display: block;
  width: 9px;
  height: 9px;
  background-color: #FFF;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
}

.home .sect02 .slick-dots li button:hover::before {
  transform: translate(-50%, -50%) scale(2);
}

.home .sect02 .slick-dots li button:hover::after {
  transform: translate(-50%, -50%) scale(1);
}

.home .sect02 .slick-dots li.slick-active button::before {
  transform: translate(-50%, -50%) scale(2);
}

.home .sect02 .slick-dots li.slick-active button::after {
  transform: translate(-50%, -50%) scale(1);
}

.home .sect03 {
  max-width: 1536px;
  width: 80%;
  margin: 180px auto 190px;
}

@media screen and (max-width: 1099px) {
  .home .sect03 {
    max-width: 768px;
  }
}

@media screen and (max-width: 1099px) {
  .home .sect03 {
    margin-top: 80px;
    margin-bottom: 100px;
  }
}

.home .sect03__h3 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 9.6rem;
  line-height: 1;
  margin: 0 0 50px;
  text-align: center;
}

@media screen and (max-width: 1099px) {
  .home .sect03__h3 {
    font-size: 6.416rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect03__h3 {
    font-size: 5rem;
  }
}

.home .sect03__p {
  margin: 0 0 20px;
}

@media screen and (max-width: 767px) {
  .home .sect03__p {
    border-top: 1px solid #cdcdcd;
    padding-top: 10px;
    margin-bottom: 10px;
  }
}

.home .sect03__p--primary {
  text-align: center;
  margin: 0 0 40px;
}

@media screen and (max-width: 767px) {
  .home .sect03__p--primary {
    border-top: 0;
    padding-top: 0;
  }
}

.home .sect03__p--mt30 {
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  .home .sect03__p--mt30 {
    border-top: 0;
    padding-top: 0;
  }
}

@media screen and (max-width: 767px) {
  .home .sect03__p--sp-mb30 {
    margin-bottom: 30px;
  }
}

.home .sect03__map {
  font-size: 0;
  line-height: 0;
  text-align: center;
  margin-bottom: 25px;
}

@media screen and (max-width: 1099px) {
  .home .sect03__map {
    width: 85%;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (max-width: 767px) {
  .home .sect03__map {
    width: auto;
    margin-bottom: 30px;
  }
}

.home .sect03__iframe {
  width: 100%;
  filter: grayscale(100%);
}

@media screen and (max-width: 767px) {
  .home .sect03__iframe {
    height: 216px;
  }
}

.home .sect03__flex {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 1099px) {
  .home .sect03__flex {
    width: 85%;
    margin: 0 auto;
  }
}

@media screen and (max-width: 767px) {
  .home .sect03__flex {
    width: auto;
    display: block;
  }
}

.home .sect03__left {
  width: 55.33%;
  padding-top: 30px;
}

@media screen and (max-width: 1099px) {
  .home .sect03__left {
    width: 48.31%;
  }
}

@media screen and (max-width: 767px) {
  .home .sect03__left {
    display: none;
  }
}

.home .sect03__left::after {
  content: "";
  clear: both;
}

.home .sect03__right {
  width: 41.34%;
}

@media screen and (max-width: 1099px) {
  .home .sect03__right {
    width: 46.32%;
  }
}

@media screen and (max-width: 767px) {
  .home .sect03__right {
    width: auto;
  }
}

.home .sect03__right::after {
  content: "";
  clear: both;
}

@media screen and (max-width: 1920px) {
  .home .sect03__img {
    width: 20.85vw;
  }
}

@media screen and (max-width: 1099px) {
  .home .sect03__img {
    display: block;
    width: auto;
  }
}

.home .sect03__img--right {
  float: right;
}

@media screen and (max-width: 1099px) {
  .home .sect03__img--right {
    float: none;
    margin-top: 18px;
  }
}

.home .sect03__btn {
  float: right;
}

@media screen and (max-width: 1650px) {
  .home .sect03__btn {
    float: none;
    margin-left: auto;
  }
}

@media screen and (max-width: 767px) {
  .home .sect03__btn {
    margin: 0 auto;
  }
}

.home .sect03__sp-station, .home .sect03__sp-parking {
  display: none;
}

@media screen and (max-width: 767px) {
  .home .sect03__sp-station, .home .sect03__sp-parking {
    display: block;
    border: 1px solid #323232;
    margin-top: 20px;
  }
}

.home .sect03__sp-station img, .home .sect03__sp-parking img {
  margin: 0 20px 20px;
  width: calc(100% - 40px);
}

.home .sect03__h4 {
  font-size: 1.5rem;
  font-weight: normal;
  line-height: 1;
  text-align: center;
  margin: 0;
  padding: 20px;
  cursor: pointer;
  position: relative;
}

.home .sect03__h4-ico {
  position: absolute;
  top: 12px;
  right: 20px;
  transition: transform .5s ease;
}

.home .sect03__h4-ico.close {
  transform: rotate(-180deg);
}

.home .sect03__sp-toggle {
  display: none;
}

.home .sect04 {
  background-color: #f5f5f5;
  max-width: 1536px;
  width: 80%;
  margin: 0 auto 190px;
  padding: 40px 64px 60px;
  box-sizing: border-box;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

@media screen and (max-width: 1099px) {
  .home .sect04 {
    max-width: 655px;
    padding: 45px 35px;
  }
}

@media screen and (max-width: 767px) {
  .home .sect04 {
    width: 85%;
    padding: 37px 28px;
  }
}

.home .sect04__h3 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 9.6rem;
  line-height: 1;
  margin: 0 0 30px;
}

@media screen and (max-width: 1099px) {
  .home .sect04__h3 {
    font-size: 6.416rem;
  }
}

@media screen and (max-width: 767px) {
  .home .sect04__h3 {
    font-size: 5rem;
  }
}

.home .sect04__p--rimary {
  margin: 0;
}

.home .sect04__right {
  max-width: 854px;
  width: 55.6%;
}

@media screen and (max-width: 1390px) {
  .home .sect04__right {
    max-width: initial;
    width: 100%;
  }
}

.home .sect04__p--primary{
    margin-bottom: 2em
}

@keyframes loadingLine {
  0% {
    transform: translate(-100%, 0);
  }
  100% {
    transform: translate(100%, 0);
  }
}

@keyframes btnLine {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(100%, 0);
  }
  51% {
    transform: translate(-100%, 0);
  }
  100% {
    transform: translate(0, 0);
  }
}

@keyframes scroll {
  0% {
    transform: translate(0, -100%);
  }
  100% {
    transform: translate(0, 100%);
  }
}

/* Floor Guide
---------------------------*/
.floor-guide__nav {
  margin: 80px auto 90px;
}

.floor-guide__tab {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .floor-guide__tab {
    width: 85%;
    justify-content: space-between;
  }
}

.floor-guide__tab-item {
  width: 220px;
  margin-left: 25px;
}

@media screen and (max-width: 767px) {
  .floor-guide__tab-item {
    width: 31%;
    margin-left: 0;
  }
}

.floor-guide__tab-item:first-child {
  margin-left: 0;
}

.floor-guide__tab-link {
  text-decoration: none;
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2.3rem;
  line-height: 1;
  display: block;
  border: 1px solid #323232;
  color: #323232;
  padding: 15px 0;
  text-align: center;
  transition: all .5s ease;
  position: relative;
}

@media screen and (max-width: 767px) {
  .floor-guide__tab-link {
    letter-spacing: 0.1em;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide__tab-link {
    font-size: 1.7rem;
  }
}

.floor-guide__tab-link::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-bottom: 1px solid #323232;
  border-right: 1px solid #323232;
  transform: rotate(45deg);
  position: absolute;
  top: calc(50% - 6px);
  right: 20px;
}

@media screen and (max-width: 767px) {
  .floor-guide__tab-link::after {
    right: 10px;
  }
}

.floor-guide__tab-link.hover, .floor-guide__tab-link.active {
  background-color: #323232;
  color: #FFF;
}

.floor-guide__tab-ico {
  position: absolute;
  top: 25px;
  right: 20px;
}

.floor-guide .sect {
  width: 710px;
  margin: 0 auto 170px;
  display: none;
  visibility: hidden;
  opacity: 0;
  transition: opacity .5s ease;
}

@media screen and (max-width: 1099px) {
  .floor-guide .sect {
    width: 652px;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide .sect {
    width: 85%;
  }
}

.floor-guide .sect.active {
  display: block;
  visibility: visible;
  opacity: 1;
}

.floor-guide .sect__top {
  background-color: #FFF;
  padding-bottom: 30px;
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__top {
    top: 60px;
  }
}

.floor-guide .sect__h3 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 6rem;
  line-height: 1;
  margin: 0 0 8px;
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__h3 {
    font-size: 4rem;
  }
}

.floor-guide .sect__map {
  display: block;
  width: 500px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__map {
    width: 85%;
  }
}

.floor-guide .sect__h4 {
  margin: 0;
}

.floor-guide .sect__h4--mt60 {
  margin-top: 60px;
}

.floor-guide .sect__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.floor-guide .sect__item {
  display: flex;
  align-items: center;
  border: 1px solid #323232;
  position: relative;
  margin-top: 20px;
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__item {
    align-items: flex-start;
  }
}

.floor-guide .sect__item-num {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2.8rem;
  line-height: 1;
  width: 56px;
  height: 56px;
  margin: 18px 30px 18px 18px;
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__item-num {
    letter-spacing: 0.1em;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__item-num {
    font-size: 1.5rem;
    width: 30px;
    height: 30px;
    margin: 10px 18px 10px 10px;
  }
}

.floor-guide .sect__item-num--black {
  background-color: #323232;
  color: #FFF;
}

.floor-guide .sect__item-num--gray {
  background-color: #ccc;
}

.floor-guide .sect__item-logo {
  display: block;
  width: 150px;
  text-align: center;
  margin: 18px 20px 18px 0;
  line-height: 0;
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__item-logo {
    display: none;
  }
}

.floor-guide .sect__item-name {
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 1.8rem;
  line-height: 1.4;
  letter-spacing: 0;
  margin: 18px 0;
}

@media screen and (max-width: 1099px) {
  .floor-guide .sect__item-name {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__item-name {
    width: 68%;
    font-size: 1.5rem;
    margin: 12px 0;
  }
}

.floor-guide .sect__item-subtxt {
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 1.4rem;
  color: #a0a0a0;
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__item-subtxt {
    font-size: 1.2rem;
  }
}

.floor-guide .sect__link {
  color: #323232;
  text-decoration: none;
  display: flex;
  align-items: center;
  width: 100%;
  position: relative;
  opacity: 1;
  transition: all .5s ease;
}

@media screen and (max-width: 767px) {
  .floor-guide .sect__link {
    align-items: flex-start;
  }
}

.floor-guide .sect__link::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-top: 1px solid #323232;
  border-right: 1px solid #323232;
  transform: rotate(45deg);
  position: absolute;
  top: calc(50% - 6px);
  right: 20px;
}

.floor-guide .sect__link.hover {
  opacity: .5;
}


/* Floor Guide Detail
---------------------------*/
.floor-guide.detail {
  letter-spacing: 0;
}

.floor-guide.detail .shop__header {
  max-width: 990px;
  width: 90%;
  margin: 80px auto;
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__header {
    max-width: 652px;
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__header {
    margin: 40px auto;
  }
}

.floor-guide.detail .shop__logo {
  line-height: 0;
  margin-bottom: 30px;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__logo {
    width: 260px;
  }
}

.floor-guide.detail .shop__logo-img {
  max-height: 60px;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__logo-img {
    max-height: 40px;
  }
}

.floor-guide.detail .shop__h3 {
  margin: 0;
}

.floor-guide.detail .shop__name {
  display: inline-block;
  font-size: 4.6rem;
  line-height: 1.05em;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__name {
    font-size: 2.5rem;
    line-height: 1.4;
  }
}

.floor-guide.detail .shop__name--small {
  font-size: 2.4rem;
  margin-right: 15px;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__name--small {
    font-size: 1.6rem;
    line-height: 1.4;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__name--sp-small-24 {
    font-size: 2.4rem;
  }
}

.floor-guide.detail .shop__cat {
  line-height: 1.4em;
  margin: 10px 0 0;
}

.floor-guide.detail .shop__middle {
  padding: 95px 0 0;
  background: #f5f5f5 url("../img/floor-guide/detail_middle_bg.png") calc(50% + 450px) top no-repeat;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__middle {
    padding: 70px 0 10px;
    background-image: none;
  }
}

.floor-guide.detail .shop__middle-content {
  max-width: 990px;
  width: 90%;
  margin: 0 auto;
  padding: 0 0 70px;
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__middle-content {
    max-width: 652px;
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__middle-content {
    padding: 0 0 60px;
  }
}

.floor-guide.detail .shop__flex {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__flex {
    display: block;
  }
}

.floor-guide.detail .shop__flex--reverse {
  flex-direction: row-reverse;
}

.floor-guide.detail .shop__flex--fstart {
  align-items: flex-start;
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__flex--pc {
    display: block;
  }
}

.floor-guide.detail .shop__flex--img {
  margin-bottom: 20px;
}

.floor-guide.detail .shop__left {
  width: 640px;
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__left {
    width: 365px;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__left {
    width: auto;
  }
}

.floor-guide.detail .shop__right {
  width: 300px;
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__right {
    width: 240px;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__right {
    margin: 0 auto 25px;
  }
}

.floor-guide.detail .shop__h4 {
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 2.4rem;
  margin: -0.3em 0 30px;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__h4 {
    font-size: 1.8rem;
    line-height: 1.8;
  }
}

.floor-guide.detail .shop__h4--mb0 {
  margin-bottom: 0;
}

.floor-guide.detail .shop__p {
  margin: 0 0 25px;
}

.floor-guide.detail .shop__p--mb0 {
  margin-bottom: 0;
}

.floor-guide.detail .shop__txt--red {
  color: #aa1e1e;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__pic {
    display: block;
    margin: 0 auto 15px;
  }
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__pic--tab-w200 {
    width: 200px;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__pic--tab-w200 {
    width: auto;
  }
}

.floor-guide.detail .shop__menu {
  display: inline-block;
  background-color: #a0a0a0;
  color: #FFF;
  padding: 10px 30px;
  margin: 5px 10px 5px 0;
  font-size: 1.8rem;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__menu {
    font-size: 1.4rem;
  }
}

.floor-guide.detail .shop__menu-tbl {
  border-left: 1px solid #323232;
  border-collapse: collapse;
  border-spacing: 0;
  margin-bottom: 20px;
}

.floor-guide.detail .shop__menu-th {
  padding: 34px 20px;
  width: 170px;
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 2rem;
  text-align: center;
  box-sizing: border-box;
  vertical-align: top;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__menu-th {
    display: block;
    width: auto;
    text-align: justify;
    padding-top: 0;
    font-size: 1.8rem;
    line-height: 1;
    padding-bottom: 20px;
  }
}

.floor-guide.detail .shop__menu-td {
  padding: 20px 0;
  text-align: left;
  vertical-align: top;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__menu-td {
    display: block;
    padding: 0 20px;
  }
}

.floor-guide.detail .shop__prof-pic {
  margin-right: 40px;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__prof-pic {
    display: block;
    margin: 0 auto 25px;
  }
}

.floor-guide.detail .shop__prof-txt {
  width: 80%;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__prof-txt {
    width: auto;
  }
}

.floor-guide.detail .shop__prof-name {
  font-size: 2rem;
  line-height: 1.8;
  margin: 0 0 20px;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__prof-name {
    font-size: 1.8rem;
    text-align: center;
  }
}

.floor-guide.detail .shop__prof-name--en {
  font-family: proxima-nova, sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 1.6rem;
  line-height: 1.8;
  display: block;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__prof-name--en {
    letter-spacing: 0.1em;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__prof-name--en {
    font-size: 1.4rem;
  }
}

.floor-guide.detail .shop__prof-p {
  margin: 0;
}

.floor-guide.detail .shop__prof-p--primary {
  padding-bottom: 25px;
  margin-bottom: 25px;
  border-bottom: 1px solid #323232;
}

.floor-guide.detail .shop__footer {
  max-width: 990px;
  width: 90%;
  margin: 100px auto 200px;
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__footer {
    max-width: 652px;
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__footer {
    margin-top: 75px;
  }
}

.floor-guide.detail .shop__footer-tbl {
  border-collapse: collapse;
  border-spacing: 0;
  width: 480px;
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__footer-tbl {
    width: 100%;
  }
}

.floor-guide.detail .shop__footer-th, .floor-guide.detail .shop__footer-td {
  vertical-align: top;
  border-bottom: 1px solid #ccc;
  padding: 35px 20px 35px 0;
  font-size: 1.8rem;
  font-weight: normal;
  line-height: 1.8;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__footer-th, .floor-guide.detail .shop__footer-td {
    font-size: 1.193rem;
    padding: 15px 10px 15px 0;
  }
}

.floor-guide.detail .shop__footer-th--pt0, .floor-guide.detail .shop__footer-td--pt0 {
  padding-top: 0;
}

.floor-guide.detail .shop__footer-th--brd0, .floor-guide.detail .shop__footer-td--brd0 {
  border: 0;
}

.floor-guide.detail .shop__footer-th--big, .floor-guide.detail .shop__footer-td--big {
  font-size: 2rem;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__footer-th--big, .floor-guide.detail .shop__footer-td--big {
    font-size: 1.325rem;
  }
}

.floor-guide.detail .shop__footer-th--lh1, .floor-guide.detail .shop__footer-td--lh1 {
  line-height: 1;
}

.floor-guide.detail .shop__footer-th {
  width: 120px;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__footer-th {
    width: 75px;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__footer .line-btn {
    width: 150px;
  }
}

.floor-guide.detail .shop__tel-link, .floor-guide.detail .shop__mail-link {
  color: #323232;
  text-decoration: none;
  transition: opacity .5s ease;
  opacity: 1;
}

.floor-guide.detail .shop__tel-link.hover, .floor-guide.detail .shop__mail-link.hover {
  opacity: .5;
}

.floor-guide.detail .shop__map {
  background-color: #f5f5f5;
}

@media screen and (max-width: 1099px) {
  .floor-guide.detail .shop__map {
    margin-top: 45px;
  }
}

.floor-guide.detail .shop__map-img {
  display: block;
  margin: 0 auto;
}

.floor-guide.detail .shop__btn {
  margin-left: 25px;
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__btn {
    width: 160px;
    height: 40px;
  }
}

@media screen and (max-width: 767px) {
  .floor-guide.detail .shop__btn .btn__line {
    right: 130px;
  }
}

/* Privacy Policy
---------------------------*/
@media screen and (max-width: 1099px) {
  .privacy {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .privacy {
    font-size: 1.4rem;
  }
}

.privacy__contents {
  max-width: 1100px;
  width: 90%;
  margin: 70px auto 165px;
}

@media screen and (max-width: 1099px) {
  .privacy__contents {
    max-width: 768px;
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .privacy__contents {
    margin-top: 40px;
    margin-bottom: 95px;
  }
}

.privacy__last-txt {
  text-align: right;
  margin-top: 60px;
}

.privacy .sect {
  margin-top: 50px;
}

@media screen and (max-width: 767px) {
  .privacy .sect {
    margin-top: 35px;
  }
}

.privacy .sect__h3 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2.5rem;
  margin: 0 0 15px;
}

@media screen and (max-width: 767px) {
  .privacy .sect__h3 {
    line-height: 1.7;
  }
}

.privacy .sect__p {
  margin: 0;
}

/* Company
---------------------------*/
.company__flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 710px;
  margin: 60px auto 170px;
}

@media screen and (max-width: 1099px) {
  .company__flex {
    max-width: 652px;
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .company__flex {
    width: 85%;
    margin: 30px auto 100px;
  }
}

.company__flex > * {
  padding: 20px 40px;
  border-bottom: 1px solid #323232;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .company__flex > * {
    padding-left: 0;
    padding-right: 0;
  }
}

.company__item-name {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2rem;
  line-height: 1;
  width: 170px;
  text-align: center;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .company__item-name {
    border-bottom: 0;
    padding-bottom: 0;
    width: 100%;
    text-align: justify;
    font-size: 1.6rem;
  }
}

.company__item-content {
  width: 505px;
}

@media screen and (max-width: 1099px) {
  .company__item-content {
    width: 448px;
  }
}

@media screen and (max-width: 767px) {
  .company__item-content {
    width: 100%;
    padding-top: 5px;
  }
}

/* Tenants Wanted
---------------------------*/
.tenants-wanted .sect {
  width: 710px;
  margin: 60px auto 170px;
}

@media screen and (max-width: 1099px) {
  .tenants-wanted .sect {
    max-width: 652px;
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .tenants-wanted .sect {
    width: 85%;
    margin: 30px auto 100px;
  }
}

.tenants-wanted .sect__h3 {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2rem;
  border-bottom: 1px solid #323232;
  letter-spacing: -0.008em;
  padding-bottom: 15px;
  margin: 0;
}

@media screen and (max-width: 1099px) {
  .tenants-wanted .sect__h3 {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 767px) {
  .tenants-wanted .sect__h3 {
    font-size: 1.6rem;
  }
}

.tenants-wanted .sect__p {
  margin: 0;
}

.tenants-wanted .sect__content {
  padding: 60px 60px 0;
}

@media screen and (max-width: 1099px) {
  .tenants-wanted .sect__content {
    padding: 50px 50px 0;
  }
}

@media screen and (max-width: 767px) {
  .tenants-wanted .sect__content {
    padding: 30px 0 0;
  }
}

.tenants-wanted .sect__content .btn-area {
  margin-top: 80px;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .tenants-wanted .sect__content .btn-area {
    flex-flow: column;
    justify-content: center;
    align-items: center;
    margin-top: 50px;
  }
}

.tenants-wanted .sect__content .btn-area .btn:first-child {
  margin-bottom: 40px;
}

/* 404
---------------------------*/
.error404__contents {
  max-width: 1100px;
  width: 90%;
  margin: 70px auto 165px;
}

@media screen and (max-width: 1099px) {
  .error404__contents {
    max-width: 768px;
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .error404__contents {
    margin-top: 40px;
    margin-bottom: 95px;
  }
}

.error404__txt{
    text-align: center;
    margin-bottom: 2em;
}

.error404__btn{
    margin: 0 auto;
    width: 240px;
}