@charset "UTF-8";


@-ms-viewport {
  width: auto;
}

/* -----------------------------------------
  for en
-------------------------------------------- */
body#en {
  word-wrap: break-word;
}




.sp {
  display: none
}

header {
  position: relative;
  top: 0;
  left: 0;
  height: 80px;
  background: #fff;
}

.header-logo {
  position: absolute;
  top: 18px;
  left: 47px;
  top: 27px;
  left: 26px;
}

.header-logo img {
  width: 136px;
  height: 57px;
  width: 192px;
  height: 21px;
  transition: all .3s ease-in-out;
}

header nav {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  height: 80px;
}

header nav ul {
  -webkit-box-lines: multiple;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

header nav ul li {
  margin: 0 28px 0 0;
}

header nav ul li a {
  position: relative;
  color: #222;
  text-decoration: none;
}

header nav .header-nav li a::before {
  display: block;
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 1px;
  margin: auto;
  background: #a69e2f;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .3s ease-in-out;
  content: "";
}

header nav ul li a:hover,
header nav ul:not(.language) li.current a {
  color: #222;
}

header nav .header-nav li a:hover::before,
header nav .header-nav li.current a::before {
  transform: scaleX(1);
  transform-origin: left;
}

header .language li {
  width: 110px;
  height: 80px;
  margin: 0;
  padding: 0;
  color: #fff;
}

header .language li a {
  width: 100%;
  height: 100%;
  transition: all .3s ease-in-out;
}

header .language li a:hover {
  color: #fff;
}

header .language a {
  background: rgba(187, 185, 170, 1);
  color: #fff;
  transition: all .3s ease-in-out;
}

header .language .current a {
  background: rgba(161, 158, 132, 1);
  transition: all .3s ease-in-out;
}

header .language li a:hover {
  background: rgba(187, 185, 170, .8);
}

header .language .current a:hover {
  background: rgba(161, 158, 132, .8);
}



/* ----- centering ------ */
header nav ul,
header .language li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
}


@media screen and (max-width: 1300px) {

  .sp {
    display: block;
  }

  header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 75px;
    background: #fff;
    z-index: 9999999;
  }

  .header-logo {
    position: absolute;
    top: 24.5px;
    left: 4vw;
    z-index: 9999999;
  }

  .header-logo img {
    width: 170px;
    height: 20px;
  }

  header nav {
    display: none;
    opacity: 0;
  }

  header nav.open {
    display: block;
    position: fixed;
    top: 75px;
    width: 100%;
    height: 100vh;
    margin: auto;
    background: #fff;
    -webkit-transition: all ease .2s;
    -o-transition: all ease .2s;
    transition: all ease .2s;
    z-index: 99999;
    opacity: 1
  }

  header nav.open .header-nav {
    margin-bottom: 30px;
    padding-top: 6vw;
  }

  header nav.open .header-nav li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-flex-direction: column;
    flex-direction: column;
    width: 70%;
    height: 60px;
    margin: 0 auto;
    border-top: 1px solid #ccc;
    text-align: center;
  }

  header nav.open .header-nav li:last-child {
    border-bottom: 1px solid #ccc;
  }

  header nav.open .language li {
    height: 75px;
  }

  header nav.open .language li a {
    width: 100%;
    height: inherit;
  }

  .hamburger-menu {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 75px;
    height: 75px;
    padding-top: 25px;
    background: #1b1817;
    z-index: 999999;
  }

  .hamburger-menu ul {
    width: 27px;
    height: 18.5px;
    margin: auto;
  }

  .hamburger-menu ul li {
    width: 27px;
    height: 2px;
    margin-bottom: 6px;
    background: #fff;
    transition: all .1s ease-in-out;
  }

  .hamburger-menu p {
    margin: auto;
    font-size: 12px;
    color: #fff;
    text-align: center;
    line-height: 1.3;
  }

  .hamburger-menu.active li:first-child {
    -webkit-transform: rotate(45deg) translate(11px, 10px);
    -ms-transform: rotate(45deg) translate(11px, 10px);
    transform: rotate(45deg) translate(11px, 10px);
  }

  .hamburger-menu.active li:nth-child(2) {
    display: none;
  }

  .hamburger-menu.active li:last-child {
    -webkit-transform: rotate(-45deg) translate(-4px, 5px);
    -ms-transform: rotate(-45deg) translate(-4px, 5px);
    transform: rotate(-45deg) translate(-4px, 5px);
  }
}


@media screen and (max-width: 768px) {

  header nav.open .header-nav {
    padding-top: 50px;
  }

}




/* ---------------------------------------------

  #mainvisual

----------------------------------------------- */
.mainvisual {
  position: relative;
  background: #a69e2f;
}

.mainvisual #slider {
  position: relative;
  width: calc(100% - 440px);
  margin-left: 220px;
}

.mainvisual #slider::before {
  display: block;
  position: absolute;
  top: 0;
  right: -220px;
  width: 220px;
  height: 100%;
  background: rgba(0, 0, 0, .5);
  content: "";
  z-index: 995
}

#slider .slide-arrow {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  position: absolute;
  bottom: 0;
  left: -140px;
  width: 70px;
  height: 70px;
  background: #90881c;
  transition: all ease-in-out .2s;
  cursor: pointer;
  z-index: 1;
}

#slider .slide-arrow.next-arrow {
  left: -70px;
  background: #111111;
}

#slider .slide-arrow:hover {
  opacity: .8;
}



#slider .slide-arrow .arrow {
  width: 10px;
  height: 10px;
  border-top: 1px solid #fff;
  border-left: 1px solid #fff;
  transform: rotate(-45deg);
  content: "";
}

#slider .slide-arrow.next-arrow .arrow {
  transform: rotate(135deg);
}

#slider .slide-dots {
  position: absolute;
  left: -220px;
  top: 0;
  width: 220px;
  height: 100%;
  padding-top: 40px;
  background: #a69e2f;
  font-family: 'Playfair Display', serif;
  font-size: 1.25rem;
}

#slider .slide-dots button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0 0 0 60px;
  appearance: none;
  color: #90881c;
  transition: all .3s ease-in-out;
}

#slider .slide-dots li {
  position: relative;
  margin-bottom: 10px;
  font-size: 1.25rem;
}

#slider .slide-dots li::before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 50px;
  height: 1px;
  margin: auto;
  background: #90881c;
  transition: all .3s ease-in-out;
  content: "";
}

#slider .slide-dots .slick-active button {
  padding-left: 130px;
  color: #000;
}

#slider .slide-dots .slick-active::before {
  width: 110px;
  background: #000;
}

/*   related-link
----------------------------------------- */

.mainvisual .related-link {
  width: 100%;
  height: 200px;
  /* min-height: 200px; */
  background: #a69e2f;
}

.mainvisual .related-link dt {
  display: inline-block;
  font-size: 1.13rem;
  font-weight: 700;

  color: #fff;
  letter-spacing: 0.1em;
}

.mainvisual .related-link dt span {
  position: relative;
}

.mainvisual .related-link dt span::before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -55px;
  width: 45px;
  height: 1px;
  margin: auto;
  background: #fff;
  content: "";
}

.mainvisual .related-link dl,
.mainvisual .related-link ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  height: inherit;
}

.mainvisual .related-link dt {
  width: calc(100% / 3);
  width: 33.333333%;
  height: 100%;
  padding-top: 25px;
  padding-right: 55px;
  text-align: right;
}

.mainvisual .related-link dd {
  width: calc(100% - 33.333333%);
  height: inherit;
}

.mainvisual .related-link li {
  position: relative;
  width: 33.3333333%;
  width: calc(100% / 2);
  height: 200px;
  background: transparent;
  overflow: hidden;
  z-index: 1;
}

.mainvisual .related-link li.shop::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 115%;
  height: 115%;
  background: url(../images/top/related-img01.jpg) no-repeat 40% 60%;
  background-size: cover;
  transition: all .2s ease-in-out;
  content: "";
  z-index: -2;
}

.mainvisual .related-link li.hall::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/top/related-img02.jpg) no-repeat 50% 40%;
  background-size: cover;
  transition: all .2s ease-in-out;
  content: "";
  z-index: -2;
}

.mainvisual .related-link li::after {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .3);
  content: "";
  z-index: -1;
}

.mainvisual .related-link li a {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  padding-top: 40px;
  font-size: 1.38rem;
  color: #fff;
  text-align: center;
  text-decoration: none;
  line-height: 1.27;
}

.mainvisual .related-link li:hover::before {
  transform: scale(1.1);
}

.link-site {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 49px;
  height: 49px;
  margin: auto;
  background: #a69e2f;
  border-radius: 50%;
  content: "";
}

.link-site::after {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  width: 12.5px;
  height: 11px;
  margin: auto;
  background: url(../images/icon-link-site.svg) no-repeat center;
  background-size: 12.5px 11px;
  content: "";
}

.mainvisual .related-link .link-site {
  bottom: -75px
}

/* ---------- related-link02 ------------ */

.related-link02 {
  position: relative;
  width: calc(100% - 440px);
  /* height: 200px; */
  height: auto;
  margin-left: 220px;
  display: flex;
  flex-direction: row;
}

.related-link02 a {
  width: 100%;
  height: 100%;
  background: #857c00;
  transition: all .2s ease-in-out;
  text-decoration: none;
  overflow: hidden;
}

.related-link02 a:hover {
  background: #736b00;
}

.related-link02 dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  position: relative;
  width: 100%;
  height: inherit;
}

.related-link02 dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;

  /* -webkit-box-pack: center;
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	justify-content: center; */

  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  z-index: 1;
  position: absolute;
  width: 100%;
  height: 100%;
  padding: 10px 30px 10px 6.2vw;
  color: #fff;
  font-size: 1.3rem;
  transition: all .2s ease-in-out;
}

.related-link02 dt::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .5);
  content: "";
  z-index: -1;
}

.related-link02 dd {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.related-link02 .link-site {
  left: 0;
  right: 0;
  margin: auto;
  z-index: 9;
}

.related-link02 dd::after {
  transition: all .2s ease-in-out;
}

.related-link02 a:hover dd::after {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .4);
  content: "";
}

.related-link02 dd img {
  width: 100%;
  height: auto;
  aspect-ratio: 1002 / 400;
  object-fit: cover;
  transition: all .2s ease-in-out;
  background: url(../images/top/related-img03.jpg) no-repeat center;
  background-size: cover;
}

.related-link02 a:hover dd img {
  transform: scale(1.1);
}




/*  scroll
-------------------------------------------- */
.scroll {
  position: absolute;
  bottom: 30px;
  left: 2vw;
  width: 22px;
  transform: rotate(180deg) translateY(0);
  z-index: 99;
  cursor: pointer;
  transition: cubic-bezier(.18, .66, .92, .6);
}

.scroll p {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -webkit-text-orientation: sideways;
  text-orientation: sideways;
  font-size: 0.88rem;
  text-transform: uppercase;
  transition: transform .3s ease-in-out;
  letter-spacing: .05em;
}

.scroll span {
  display: block;
  position: absolute;
  right: 0;
  left: 0;
  top: -60px;
  width: 11px;
  height: 52px;
  margin: auto;
  transform: rotate(-180deg) translateY(0);
  transition: transform .3s ease-in-out;
  content: "";
}

.scroll span img {
  display: block;
}

.scroll:hover p {
  transition-delay: .1s;
  transform: translateY(-21px);
}

.scroll:hover span {
  transform: rotate(-180deg) translateY(21px);
}




/* for IE10 and IE11 */
@media screen and (-ms-high-contrast: active),
(-ms-high-contrast: none) {
  .scroll::before {
    top: -25px;
    left: 85px;
  }
}

/* for Edge */
@supports (-ms-ime-align:auto) {
  .scroll::before {
    top: -25px;
    left: 85px;
    /* right: -38px; */
  }
}



@media screen and (min-width: 961px) and (max-width: 1220px) {
  .mainvisual {
    margin-top: 75px;
  }

  .mainvisual #slider::before {
    display: none;
  }

  .mainvisual #slider {
    width: calc(100% - 220px);
  }

  .related-link02 {
    width: calc(100% - 220px);
  }

}


@media screen and (max-width: 1024px) {

  .mainvisual {
    margin-top: 75px;
  }

  .mainvisual #slider {
    width: calc(100% - 220px);
  }

  .mainvisual #slider::before {
    display: none;
  }

  #slider .slide-dots li {
    position: relative;
    margin-bottom: 7px;
    font-size: 1.25rem;
  }

  .related-link02 {
    width: calc(100% - 220px);
  }

}


@media screen and (max-width: 960px) {

  .mainvisual {
    height: 100%;
    min-height: auto;
  }

  .mainvisual #slider {
    width: 100%;
    height: 100%;
    min-height: auto;
    margin-left: 0;
    margin-bottom: 52.5px;
  }

  .mainvisual #slider img {
    width: 100%;
    height: auto;
    min-height: auto;
  }

  #slider .slide-arrow {
    bottom: -52.5px;
    right: 52.5px;
    left: auto;
    width: 52.5px;
    height: 52.5px;
    z-index: 999;
  }

  #slider .slide-arrow.next-arrow {
    right: 0;
    left: auto;
    background: #111111;
  }

  #slider .slide-dots {
    top: auto;
    bottom: -52.5px;
    left: 0;
    width: 100%;
    height: 52.5px;
    padding-top: 12px;
    overflow: hidden;
  }

  #slider .slide-dots li {
    position: absolute;
    left: 0;
    margin-bottom: 0;
  }

  #slider .slide-dots li:not(.slick-active) {
    opacity: 0;
  }

  .mainvisual .related-link {
    width: 100%;
    height: calc(55vw - 52.5px);
    min-height: auto;
  }

  .mainvisual .related-link dl {
    width: 100%;
  }

  .mainvisual .related-link dt {
    display: none;
  }

  .mainvisual .related-link dd {
    width: 100%;
  }

  .mainvisual .related-link li {
    height: inherit;
  }

  .mainvisual .related-link li.hall::before {
    background: url(../images/top/related-img02.jpg) no-repeat 30% 40%;
    background-size: cover;
  }

  .mainvisual .related-link li a {
    padding-top: 10vw;
    font-size: 3.75vw;
  }

  .mainvisual .related-link .link-site {
    bottom: -12vw;
  }

  .link-site::after {
    width: 40%;
    height: 35%;
    background-size: contain;
  }

  .related-link02 {
    width: 100%;
    height: auto;
    margin-left: 0;
    box-sizing: border-box;
  }

  .scroll {
    display: none;
  }
}

@media screen and (max-width: 767px) {

  .mainvisual {
    /* height: calc(50vw + 52.5px + 37vw); */
    height: 100%;
    min-height: auto;
  }

  .related-link02 {
    position: relative;
    width: 100%;
    height: auto;
    height: 220px;
    /* height: 37vw; */
    margin-left: 0;
    box-sizing: border-box;
    overflow: hidden;
    display: block;
  }

  .related-link02 a {
    height: 110px;
    display: block;
    position: relative;
  }

  .related-link02 dt {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: inherit;
    padding: 4vw;
    text-align: center;
    /* background: url(../images/top/related-img03.jpg) no-repeat center; */
    background-size: cover;
    z-index: 1;
  }

  .related-link02 dt span {
    width: 100%;
    margin-top: -35px;
    font-size: 1.12rem;
  }

  .related-link02 dd {
    width: 100%;
    z-index: 0;
  }

  .related-link02 dd a {
    width: 100%;
    height: 100%;
    background: transparent;
  }

  .related-link02 dd a img {
    display: none;
  }

  .related-link02 .link-site {
    top: auto;
    right: 0;
    left: 0;
    width: 30px;
    height: 30px;
    bottom: 3vw;
  }


}



/* for Edge */
/* @supports (-ms-ime-align:auto) and (max-width: 768px) {

    .mainvisual {
      height: calc(48vw + 37vw);
    }
    .mainvisual #slider {
      height: 48vw;
    }
  }
} */

/* for Edge */
/* @supports (-ms-ime-align:auto) and (max-width: 767px) {

    .mainvisual {
      height: calc(50vw + 52.5px + 37vw);
      min-height: auto;
    }
    .mainvisual #slider {
      height: 48vw;
    }
  }
} */



/* for IE10 and IE11 */
/* @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) and (max-width: 768px) {

  .mainvisual {
    height: calc(48vw + 37vw);
  }
  .mainvisual #slider {
    height: 48vw;
  }

} */


/* for IE10 and IE11 */
/* @media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) and (max-width: 767px) {

  .mainvisual {
    height: calc(50vw + 52.5px + 37vw);
    min-height: auto;
  }
  .mainvisual #slider {
    height: 48vw;
  }

}
 */







/*  TOP
-------------------------------------------------- */
#top .main .content {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

@media screen and (max-width: 767px) {
  #top .main .content {
    /* padding-top: 0; */
  }

}






/* --------------------------------------------------

  Otemachi now (TOP)

---------------------------------------------------- */
.main .top-otemachi {
  position: relative;
  padding-top: 80px;
  padding-bottom: 95px;
  background: #f9f9f9;
  z-index: 1;
}

.main_caption {
  margin-top: 15px;
  font-size: 0.88rem;
}

.main .top-otemachi::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 80vw 200vw 0 0;
  border-color: #f3f2e8 transparent transparent transparent;
  content: "";
  z-index: -1;
}




.main .top-otemachi .col-set,
.main .otemachi-now .col-set {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  width: calc(100% + 60px);
  max-width: 860px;
  margin: auto;
}

.main .top-otemachi .inner,
.main .otemachi-now .inner {
  max-width: 860px;
}



.main .top-otemachi .col1-2,
.main .otemachi-now .col1-2 {
  width: calc(50% - 30px);
  margin-right: 60px;
  font-size: 0.88rem;
}

.main .top-otemachi .col1-2:nth-child(2n),
.main .otemachi-now .col1-2:nth-child(2n) {
  margin-right: 0;
}

.main .top-otemachi dl dt,
.main .top-otemachi dl dd,
.main .top-otemachi .keywords dt,
.main .top-otemachi .keywords dd,
.main .otemachi-now dl dt,
.main .otemachi-now dl dd {
  width: 100%;
  margin: 0;
  padding: 0;
}

.main .top-otemachi dl dt,
.main .otemachi-now dl dt {
  margin-bottom: 10px;
  overflow: hidden;
}

.main .top-otemachi .img a::after,
.main .otemachi-now .img a::after {
  display: none;
}

.main .top-otemachi dl:not(.keywords) dd,
.main .otemachi-now dl dd {
  max-width: 400px;
  margin: auto;
}

.main .top-otemachi dl dd p,
.main .otemachi-now dl dd p {
  margin-bottom: 0;
}

.main .top-otemachi dl dd p:not(.date):not(.tag),
.main .otemachi-now dl dd p:not(.date):not(.tag) {
  color: #222;
  line-height: 1.7;
}

.main .top-otemachi dl dd.tag,
.main .otemachi-now dl dd.tag {
  font-weight: bold;
}

.main .top-otemachi dl dd ul,
.main .otemachi-now dl dd ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 5px;
}

.main .top-otemachi .tag li,
.main .otemachi-now .tag li {
  margin: 0 10px 0 0;
}

.main .top-otemachi .tag li a,
.main .otemachi-now .tag li a {
  padding: 5px 0;
}

.main .top-otemachi .img:after,
.main .otemachi-now .img:after {
  background-color: transparent;
  height: auto;
}

.main .top-otemachi a,
.main .otemachi-now a {
  text-decoration: none;
}

.otemachi-now-single .otemachi-now .row .col-set {
  display: flex;
}

.main .top-otemachi a p,
.main .otemachi-now a p {
  transition: color .2s linear;
  -moz-transition: opacity .2s linear;
  -webkit-transition: opacity .2s linear;
  transition: opacity .2s linear;
}

.main .top-otemachi a:hover p,
.main .otemachi-now a:hover p {
  opacity: .8;
}

/* .top-otemachi .keywords-list {
  width: 100%;
  max-width: 860px;
  margin: auto;
  text-align: center;
} */
.main .top-otemachi .keywords-list {
  width: 100%;
  max-width: 860px;
  margin: 0 auto 30px;
  text-align: center;
}

.main .top-otemachi .keywords dt {
  margin-bottom: 20px;
  font-size: 1.38rem;
  font-weight: bold;
  text-align: center;
}

.main .keywords-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-jusrify-content: center;
  justify-content: center;
  -webkit-box-lines: multiple;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.main .keywords-list li {
  margin: 0 10px 16px 0;
  padding-left: 0;
  border: 1px solid #aaaaaa;
}

.main .keywords-list li:last-of-type {
  margin-bottom: 16px;
}

.main .keywords-list li::before {
  display: none;
}

.main .keywords-list li a {
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 8px 15px;
  text-decoration: none;
  transition: all .3s ease-in-out;
}

html:not(.sp) .main .keywords-list li a:hover {
  opacity: .6;
}

.main .btn a,
.main .btn button {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: 347px;
  height: 90px;
  padding: 0;
  background: #111;
  color: #fff;
  border-radius: 0;
  font-family: 'Abel', sans-serif;
  font-size: 1.13rem;
}

.main .btn.center a {
  margin: 0;
}

.main .btn a::after,
.main .btn button::after {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 40px;
  width: 21px;
  height: 4px;
  margin: auto;
  background: url(../images/btn-arrow.svg) no-repeat center;
  content: "";
}

.main .btn a::before,
.main .btn button::before {
  display: none;
}

.main .btn a::before,
.main .btn button::before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 0;
  height: 0;
  margin: auto;
  background: rgba(255, 255, 255, 1);
  border-radius: 0;
  transform:
    transition: all .3s ease-in-out;
  content: "";
}

.main .btn a:hover::before {
  width: 100%;
  height: 100%;
}




@media screen and (min-width: 768px) and (max-width: 1199px) {

  /* .main .top-otemachi::before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 120vw 430vw 0 0;
    border-color: #f3f2e8 transparent transparent transparent;
    content: "";
    z-index: -1;
  } */
  .main .top-otemachi .col-set,
  .main .otemachi-now .col-set {
    max-width: 100%;
    width: calc(100% + 30px);
  }

  .main .top-otemachi .col1-2,
  .main .otemachi-now .col1-2 {
    width: calc(50% - 2vw);
    margin-right: 4vw;
  }


}




@media screen and (max-width: 767px) {

  .main .top-otemachi {
    padding-top: 35px;
    padding-bottom: 50px;
    overflow: hidden;
  }

  .main .top-otemachi::before {
    border-width: 200vw 650vw 0 0;
  }

  .main .top-otemachi h2 {
    margin-top: 0;
  }

  .main .top-otemachi .col-set,
  .main .otemachi-now .col-set {
    max-width: 100%;
    width: calc(100% + 30px);
  }

  .main .top-otemachi .col1-2,
  .main .otemachi-now .col1-2 {
    width: calc(50% - 2vw);
    margin-right: 4vw;
  }

  .main .keywords-list {
    font-size: .75rem;
  }

  .main .keywords-list li {
    margin: 0 8px 10px 0;
  }

  .main .keywords-list li:last-of-type {
    margin-bottom: 10px;
  }

  .main .keywords-list li a {
    padding: 7px 12px 6px;
  }


  .main .btn a {
    width: 280px;
    height: 68px;
    font-size: .94rem
  }


}













/* ----------------------------------------------------

  information（TOP）

------------------------------------------------------ */
.top-information {
  position: relative;
  padding-top: 95px;
  padding-bottom: 95px;
  z-index: 1;
}

.news.border-set {
  max-width: 820px;
  margin: 0 auto 50px;
  padding-top: 10px;
}

.main .news.border-set a {
  text-decoration: none;
}

.main .news.border-set dt {
  /* width: 10em; */
  width: 35%;
  padding: 28px 0 28px 35px;
  box-sizing: border-box;
}

.main .news.border-set .tag {
  background: none;
  clear: both;
  float: right;
  width: 7em;
  margin: 0 15px 0 0;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}



.main .news.border-set dd {
  width: calc(100% - 35%);
  padding: 28px 0 28px 10px;
  display: flex;
  justify-content: flex-end;
}

.main .news.border-set .tag a {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  background: #a69e2f;
  color: #fff;
  font-size: 0.81rem;
  line-height: 2;
  text-align: center;
}


.main .top-information a,
.main dl.news a {
  text-decoration: none;
  transition: all .3s ease-in-out;
}

.main .top-information a:hover,
.main dl.news a:hover {
  opacity: .7;
}

.main dl.news dd p.title {
  margin-right: auto;
  width: 75%;
  padding-right: 15px;
  box-sizing: border-box;
}

.main dl.news dd p.title_only {
  margin-right: auto;
  padding-right: 15px;
  box-sizing: border-box;
}

.main dl.news dd p.thumbs {
  width: 25%;
  width: 25%;
  max-height: 150px;
  overflow: hidden;
}

main dl.news a {
  display: flex;
  width: 100%;
}

.main dl.news dt .tag span {
  width: 100%;
  height: 100%;
  background: #a69e2f;
  color: #fff;
  margin: 0;
  padding: 0;
  font-size: 0.81rem;
  line-height: 2;
  text-align: center;
}

.main dl.border-set dt,
.main dl.border-set dd {
  border-top: solid 1px #e5e9e9;
  padding: 20px 0;
}












@media screen and (max-width: 768px) {

  .top-information {
    padding: 0 0 50px 0;
  }

  .news.border-set {
    max-width: 100%;
    margin: 0 auto 25px;
    padding-top: 0;
  }

  .main dl.news.border-set {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: -webkit-flex !important;
    display: flex !important;
    width: 100%;
    border: none;
  }

  .main dl.news.border-set dt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;

    width: 100% !important;
    padding: 20px 0 25px 0;
    border-top: 1px solid #e5e9e9;
    font-size: .63rem;
    letter-spacing: .03em;
    line-height: 2.2;
  }

  .main dl.news.border-set .date {
    width: 8em;
  }

  .main dl.news.border-set .tag {
    width: 6em;
    width: 10em;
    margin: 0 0 0 0;
    letter-spacing: .03em;
  }

  .main dl.news-border-set .tag a {
    font-size: .63rem;
  }

  .main dl.news.border-set dd {
    width: 100% !important;
    padding: 5px 0 25px 0;
    border-bottom: none;
  }

  .main dl.news.border-set dd p {
    margin-right: 0;
  }

}

/* @media screen and (max-width: 320px) {

  .main dl.news.border-set dt,
  .main dl.news.border-set dd {
    width: 100% !important;

  }
  .main dl.news.border-set dt {
    padding-top: 20px;
    border-bottom: none;
  }
  .main dl.news.border-set dd {
    padding: 0 0 20px 0;
    border-top: none;
  }


} */




/* ----------------------------------------------------

  shop

------------------------------------------------------ */
.top-shop {
  padding-top: 85px;
  padding-bottom: 210px;
  background: #f9f9f9;
}

.main .shop-list li::before {
  display: none;
}

.main .shop-list {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-jusrify-content: center;
  justify-content: center;
  -webkit-box-lines: multiple;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: calc(100% + 15px);
  margin-bottom: 0;
}

.main .shop-list li {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: calc(16.6666% - 15px);
  margin: 0 15px 25px 0;
  padding: 0;
  width: 154px;
  height: 154px;
  background: #fff;
}

.main .shop-list li img {}

.main .view-more {
  position: absolute;
  right: 0;
  left: 0;
  width: 68px;
  height: 68px;
  margin: auto;
  margin-top: 40px;
  border-radius: 50%;
  background: #111;
  transition: background .1s ease-in-out;
}

.main .view-more::after {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  width: 11px;
  height: 25px;
  margin: auto;
  background: url(../images/view-more-arrow.svg) no-repeat;
  background-size: 11px 25px;
  content: "";
}

.main .view-more.open::after {
  transform: rotate(180deg);
}

.main .view-more:hover,
.main .view-more.open {
  background: #a69e2f;
}

.main .view-more span {
  position: relative;
  top: -25px;
  left: 5px;
}

.main .view-more-content {
  display: none;
}




@media screen and (max-width: 767px) {

  .top-shop {
    padding-top: 10px;
    padding-bottom: 20px;
    padding-bottom: 130px;
  }

  .main .shop-list li {
    width: calc(33.33333% - 15px);
    height: 29vw;
    height: 29vw;
    /* min-height: 109px; */
    margin-bottom: 15px;
  }

  .main .shop-list li:last-of-type {
    margin-bottom: 15px;
  }

  .main .shop-list li img {
    width: 70%;
    width: 20vw;
    height: auto;
  }

  .main .view-more {
    position: absolute;
    right: 0;
    left: 0;
    width: 45px;
    height: 45px;
    margin: auto;
    margin-top: 30px;
    border-radius: 50%;
    background: #a69e2f;
    transition: background .1s ease-in-out;
  }

  .main .view-more::after {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    width: 11px;
    height: 15px;
    margin: auto;
    background: url(../images/view-more-arrow.svg) no-repeat;
    background-size: 11px 15px;
    content: "";
  }

  .main .view-more span {
    left: 3px;
    font-size: .63em;
  }

}







/* --------------------------------------------

  Access

---------------------------------------------- */
.top-access {
  width: 100%;
  height: 600px;
  margin: 0;
  padding: 0;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  z-index: 2;
}

.top-access .box-left {
  width: 34.7%;
  height: auto;
  /* padding-top: 125px; */
  /* padding-top: 8%; */
  padding: 8vw 3vw 7vw;
  /* padding-bottom: 9%; */
  background: #a69e2f;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
  z-index: 2;
}

.main .top-access .box-left h2 {
  margin-bottom: 15px;
  color: #fff;
  text-transform: uppercase;
}

.main .top-access .box-left h2::after {
  background: #fff;
}

.top-access .box-left dl {
  margin-bottom: 40px;
}

.top-access .box-left dl dt,
.top-access .box-left dl dd {
  width: 100%;
  margin: 0;
  padding: 0;
  color: #fff;
}

.top-access .box-left dl dt {
  margin: 10px;
  font-size: 1.13rem;
}

.top-access .box-left dl dd li {
  margin-bottom: 5px;
  padding-left: 0;
}

.ja .top-access .box-left dl dd li:first-child {
  margin-bottom: 29px;
}

.top-access .box-right {
  width: 65.3%;
  height: auto;
  min-height: 300px
}

.top-access #map {
  width: 100%;
  height: 100%;
}

.main .top-access .box-left .btn a {
  margin: 0;
}





@media screen and (min-width: 1024px) and (max-width: 1199px),
print {

  .top-access {
    height: 530px;
  }

  .top-access .box-left {
    padding: 8vw 1.9vw 6vw;
  }

  .top-access .btn a {
    width: 100%;
  }


}

@media screen and (min-width: 768px) and (max-width: 1023px) {

  .top-access {
    -webkit-flex-direction: column;
    flex-direction: column;
    height: auto;
    min-height: auto;
  }


  .top-access .box-left {
    padding: 7vw 1.9vw 6vw;
  }

  .top-access .box-left,
  .top-access .box-right {
    width: 100%;
  }

  .top-access .btn a {
    width: 320px;
  }

  .top-access .box-right,
  #map {
    height: 350px;
  }

}






@media screen and (max-width: 767px) {

  .top-access {
    -webkit-flex-direction: column;
    flex-direction: column;
    min-height: auto;
    height: auto;

    margin-top: -75px;
    padding-top: 75px;
  }

  .top-access .box-left,
  .top-access .box-right {
    width: 100%;
  }

  .top-access .box-left {
    padding-top: 12vw;
    padding-bottom: 13vw;
  }

  .main .top-access .box-left h2 {
    margin-top: 0;
  }


  .main .top-access .box-left dl {
    margin-bottom: 20px;
    margin-bottom: 5vw;
  }

  .main .top-access .box-left dt {
    margin-bottom: 0;
    font-size: 1.13rem;
  }

  .top-access .box-left dd {
    font-size: 0.75rem;
  }

  .main .top-access .box-left dd li {
    margin-bottom: 0;
  }

  .main .top-access .box-left .btn a {
    width: 280px;
  }


  .top-access .box-right,
  #map {
    height: 300px;
  }

}



/* --------------------------------------------------

  under page common setting

--------------------------------------------------- */
#breadcrumb {
  width: 100%;
  height: 35px;
  background: #7c795b;
  color: #fff;
  font-size: .75rem;
}

#breadcrumb ul {
  width: 1000px;
  height: inherit;
  margin: 0 auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
}

#breadcrumb li {
  position: relative;
  margin-right: 35px;
}

#breadcrumb li:not(:last-child)::before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -19px;
  width: 6px;
  height: 6px;
  margin: auto;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  content: "";
}

#breadcrumb li a {
  color: #fff;
  text-decoration: none;
}

#breadcrumb li a:hover {
  color: #fff;
  text-decoration: underline;
}

.page-tit {
  position: relative;
  display: -webkit-box;
  display: -ms-fldisplay: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: 100%;
  height: 220px;
  background: #f7f7f3;
}

.page-tit h1 {
  font-size: 1.5rem;
  text-align: center;
  letter-spacing: .1em;
}

.main .text-box {
  font-size: 16px;
  line-height: 1.75;
}

@media screen and (max-width: 1220px) {

  #breadcrumb {
    margin-top: 75px;
  }

}

@media screen and (max-width: 767px) {

  .main .text-box {
    font-size: 13px;
  }

}








/* --------------------------------------------------

  Otemachi PLACE - about

--------------------------------------------------- */
.main .about h2::after {
  display: none;
}

.about .section01 {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;

  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;

  overflow: hidden;
  width: 100%;
  height: 100%;
  background: url(../images/about/about-bg.jpg) no-repeat top center;
  background-size: cover;
}

.about .section01 .text-box {
  width: 50%;

}

.about .section01 .text-box .inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;

  -webkit-flex-direction: column;
  flex-direction: column;

  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  min-height: 800px;
  padding: 12% 12% 5% 13%;

}

.about .section01 .img-box {
  width: 50%;
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover;
}

.about .section02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  width: 100%;
  height: 800px;
  background: url(../images/about/about-bg02.jpg) no-repeat bottom center;
  background-size: cover;
}

.main .about .section02 .txt {
  padding-left: 6.5%;
}

.about .section02 h2 {
  color: #fff;
}

.about .section02 .text-box {
  background: #fff;
  margin: 100px 0 110px 0;
  padding: 7%;
  text-align: left;
}

.about .section03 {
  position: relative;
  min-height: 800px;
  background: #f7f7f3;
  z-index: 9;
}

.about .section03 h2 {
  margin-bottom: 90px;
}

.about .section03 .txt {
  /* padding: 140px 6.5% 7%; */
  padding: 10vw 6.5% 7%;

}

.about .section03 .img {
  position: relative;
  overflow: visible;
}

.about .section03 .img .bg-img {
  background-position: bottom center;
}

/*  ---------- for test ----------*/
.about .section03 .img .sub-img01 {
  position: absolute;
  top: 70px;
  left: -7vw;
  width: 100%;
  height: auto;
}

.about .section03 .img .sub-img02 {
  position: absolute;
  top: 51%;
  left: calc(100% - (21.4vw + 7vw));
  width: 21.4vw;
  max-width: 309px;
  max-height: 309px;
}

/* --------  end test --------- */

.about .section04 {
  position: relative;
  padding-top: 140px;
  background: #f7f7f3;
  z-index: 2;
}

.about .section04 .logo {
  position: relative;
  margin-bottom: 120px;
}

.en .about .section03 h2 {
  padding-right: 120px;
}

.about .section04 .logo::after {
  display: block;
  position: absolute;
  bottom: -120px;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 45vw 150vw;
  border-color: transparent transparent #fff transparent;
  content: "";
  z-index: -1;
}

.about .section04 h2 {
  margin-bottom: 60px;
  font-size: 2.5rem;
  color: #bcb663;
  letter-spacing: .1em;
  line-height: 1.25;
}

.about .section04 h2::after {
  display: none;
}

.about .section04 .text-box {
  width: 1000px;
  margin: auto;
  padding: 0 7%;
  line-height: 1.75;
  text-align: left;
}

.about .section04 .about-info-list {
  width: 100%;
  height: auto;
  padding-bottom: 75px;
  background: #f9f9f9;
}

.about .section04 .about-info-list .inner {
  width: 1000px;
  margin: 0 auto;
  padding-top: 90px;
}

.about .section04 .about-info-list::after {
  display: block;
  clear: both;
  content: "";
}

.about .section04 .about-info-list dl {
  float: left;
  width: calc(50% - 30px);
  margin-right: 60px;
  font-size: 0.88rem;
}

.about .section04 .about-info-list dl:last-child {
  margin-right: 0;
}

.about .section04 .about-info-list dt {
  width: 80px;
  padding: 20px 2px 19px .5em;
  border-top: none;
  border-right: 1px solid #dfdfdf;
  border-bottom: 1px solid #dfdfdf;
  font-weight: normal;
}

.en .about .section04 .about-info-list dt {
  width: 120px;
}

.about .section04 .about-info-list dd {
  width: calc(100% - 80px);
  padding: 20px 0 19px 15px;
  border-top: none;
  border-bottom: 1px solid #dfdfdf;
}

.en .about .section04 .about-info-list dd {
  width: calc(100% - 120px);
}

.about .section04 .about-info-list dt:first-child,
.about .section04 .about-info-list dd:first-of-type {
  border-top: 1px solid #dfdfdf;
}

.about .section04 .about-info-list dt:last-of-type,
.about .section04 .about-info-list dd:last-child {
  border-bottom: none;
}





@media screen and (min-width: 1441px) {

  .about .section01 .text-box .inner {
    min-height: 1030px;
  }

  .about .section03 .img .sub-img02 {
    position: absolute;
    top: 51%;
    left: calc(100% - (309px + 7vw));
    width: 21.4vw;
    max-width: 309px;
    max-height: 309px;
  }
}





@media screen and (min-width: 769px) and (max-width: 1260px) {

  .about .section04 .about-info-list .inner {
    width: 100%;
    padding: 90px 8vw 0;
  }

  .about .section04 .about-info-list dt:not(:first-child) {
    border-top: none;
  }
}


@media screen and (max-width: 1023px) {

  #breadcrumb ul {
    width: 100%;
    padding-left: 7vw;
  }

  .about .section04 .text-box {
    width: 100%;
  }

  .about .section04 .about-info-list .inner {
    width: 100%;
    padding: 90px 3vw 0;
  }

  .about .section04 .about-info-list dl {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    float: none;
    width: 100%;
    margin: 0;
  }

  .about .section04 .about-info-list dl:first-child {
    border-bottom: none;
  }

  .main .about .section04 .about-info-list dl.border-set {
    border-top: none;
  }

  .about .section04 .about-info-list dl:first-child dt:last-of-type,
  .about .section04 .about-info-list dl:first-child dd:last-child {
    border-bottom: none;
  }

  .about .section04 .about-info-list dl dt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
    padding: 0 !important;
    border-bottom: 1px solid #dfdfdf;
    box-sizing: border-box;
  }

  .about .section04 .about-info-list dl dd {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    box-sizing: border-box;
  }
}


@media screen and (min-width: 769px) and (max-width: 860px) {

  .main .about .section01 h2 br,
  .main .about .section03 h2 br {
    display: none;
  }

  .about .section03 .txt {
    padding: 10vw 7.5% 7% 6.5%;

  }
}


@media screen and (max-width: 768px) {

  #breadcrumb {
    display: none;
  }

  .page-tit {
    max-height: 160px;
    height: 45vw;
    margin-top: 75px;
  }

  .page-tit h1 {
    font-size: 1.31rem;
    font-size: 1.5rem;
    font-weight: normal;
  }

  .about .section01 {
    -webkit-flex-direction: column;
    flex-direction: column;
    height: auto;
    padding-top: 0;
    background: url(../images/about/sp-about-bg.png) no-repeat, #a69e2f;
    background-size: contain;
    background-position: 0 60%;
  }

  .about .section01 .txt {
    width: 100%;
    height: auto;
    min-height: auto;
    padding-top: 0;
    padding-bottom: 0;
  }

  .about .section01 .text-box .inner {
    min-height: auto;
    padding: 4% 6vw 3vw;
  }

  .about .section01 h2 {
    font-size: 1.31rem;
  }

  .about .section01 h2 br {
    display: block;
  }

  .about .section01 .img-box {
    width: 100%;
    height: 100vw;
    height: 110vw;
    min-height: auto;
    margin-top: 0;
  }

  .about .section02 {
    display: block;
    height: auto;
    padding: 0 3vw 80px;
    background-position: 5% 60%;
  }

  .about .section02 h2 {
    margin-bottom: 50px;
  }

  .about .section02 .img.text-box {
    margin: 0;
    padding: 8.5% 6% 4%;
  }

  .main .about .section02 .txt {
    padding-left: 3vw;
  }

  .about .section03 {
    height: auto;
  }

  .about .section03 .txt {
    padding: 20px 7vw 7%;
  }

  .about .section03 h2 {
    margin-bottom: 20px;
  }

  .en .about .section03 h2 {
    padding-right: 0px;
  }

  .main .about .section03.panel-horizontal .img {
    width: calc(100% - 7vw);
    height: 100%;
    margin: 0;
    background-position: bottom;
  }

  .main .about .section03.panel-horizontal .img .bg-img {
    width: 100%;
    height: auto;
    -webkit-background-size: contain;
    background-size: contain;
  }

  .main .about .panel-horizontal .img div {
    padding: 60% 0 0;
  }

  .about .section03 .img .sub-img01 {
    top: 30px;
    left: 5vw;
    width: 55%;
    padding: 0 !important;
  }

  .about .section03 .img .sub-img02 {
    width: 21.4vw;
    height: 21.4vw;
    padding-top: 0 !important;
  }

  .about .section04 {
    padding: 15px 0 0;
  }

  .about .section04 h2 {
    /* font-size: 1.63rem; */
    font-size: 1.562rem
  }

  .about .section04 .text-box {
    width: auto;
    font-size: 0.88rem;
    line-height: 1.53;
  }

  .about .section04 .logo {
    margin-bottom: 90px;
  }

  .about .section04 .logo::after {
    display: block;
    position: absolute;
    bottom: -90px;
    right: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 75vw 230vw;
    border-color: transparent transparent #fff transparent;
    content: "";
    z-index: -1;
  }

  .about .section04 .logo img {
    width: 261px;
    height: 110px;
    width: 65%;
  }

  .about .section04 .about-info-list {
    padding-bottom: 60px;
  }

  .about .section04 .about-info-list .inner {
    width: auto;
    padding: 35px 3vw 0;
  }

  .about .section04 .about-info-list dl {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    float: none;
    width: 100%;
    margin: 0;
    font-size: .81rem;
  }

  .main .about .section04 dl.border-set:last-child {
    border-bottom: 1px solid #dfdfdf;
  }

  .about .section04 .about-info-list dl dt {
    width: 90px !important;
    padding: 0 !important;
  }

  .about .section04 .about-info-list dl dd {
    width: calc(100% - 90px) !important;
  }
}




@media screen and (max-width: 480px) {

  .about .section03 .img::before {
    top: 40px;
    width: calc(100% - (45px - 7vw));
    left: -7vw;
    background-size: contain;
  }

  .about .section03 .img::after {
    right: 45px;
    bottom: 50px;
    width: 151px;
    height: 151px;
    background-size: contain;
  }

  .about .section04 .logo::after {
    display: block;
    position: absolute;
    bottom: -90px;
    right: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 150vw 460vw;
    border-color: transparent transparent #fff transparent;
    content: "";
    z-index: -1;
  }
}



/* -----------------------------------------------

  facility

------------------------------------------------- */
.en-font {
  display: block;
  margin-top: -.3em;
  font-family: 'Abel', sans-serif;
  color: #999999;
}

.floor-shop-list dd span.en-font {
  color: #999999;
}

.main .facility .tab-nav {
  overflow: visible;
}

.main .facility ul li {
  padding-left: 0;
}

.main .facility ul li::before {
  display: none;
}

.main .facility .tab .tab-element {
  position: relative;
  padding: 40px 0 10px;
}

.main .facility .floor-guide-wrapper {
  position: absolute;
  top: 30px;
  left: 0;
  z-index: 1;
}

.main .facility .floor-guide li {
  margin-bottom: 5px;
  font-size: 1.38rem;
  font-weight: bold;
}

.main .facility .floor-guide dl {
  -webkit-flex-direction: column;
  flex-direction: column;
  margin-bottom: 0;
}

.main .facility .floor-guide dt {
  width: auto;
  font-size: 1.38rem;
  font-weight: bold;
}

.facility .floor-guide li span {
  display: block;
  font-size: 1rem;
  color: #999999;
}

.main .facility .floor-guide dd {
  width: auto;
  padding-left: 0;
}

.main .facility .floor-guide dd li {
  display: inline-block;
  margin-right: 20px;
  font-size: 1rem;
}

.main .floor-guide dd li span {
  font-size: 0.75rem;
}

.floor-guide-icon li {
  display: inline-block;
  margin-right: 10px;
}

/* ------- map ---------- */
.main .floor-map {
  /* margin-top: -25%; */
}

/* .main .floor-map dt,
.main .floor-map dd {
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
} */
.main .floor-map .floor-map-img {
  /* position: absolute;
  top: 40px;
  height: 604px; */
}

.floor-map .floor-map-img img {
  display: block;
  /* position: absolute;
  top: 40px; */
  /* height: 604px; */
  margin: auto;
  margin-right: 0;
}

.floor-map .floor-map-img img {
  transform: scale(1.6);
}

@media screen and (max-width: 354px) {
  .floor-map .floor-map-img img {
    transform: scale(1.4);
  }
}

.floor-map-guide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}

.floor-map-guide li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  margin-left: 20px;

  font-size: 0.81rem;
}

.floor-map-guide .en-font {
  font-size: 0.75rem;
}

.floor-map-guide .area {
  width: 28px;
  height: 28px;
  margin-right: 10px;
}

.floor-map-guide .area.blue {
  background: #006886;
}

.floor-map-guide .area.orenge {
  background: #a98152;
}

.floor-map-guide .area.green {
  background: #547738;
}

.floor-map-guide .area.red {
  background: #964441;
}

/* ------- floor-shop-list -------- */

.facility h2.tit {
  font-family: 'Abel', sans-serif;
  font-size: 2.1875rem;
  letter-spacing: .1em;
}

.main .facility h2.tit::after {
  display: none;
}

.main .floor-shop-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
  margin-bottom: 0;
}

.main .floor-shop-list li {
  width: 25%;
  margin-bottom: 50px;
  padding-right: 10px;
  box-sizing: border-box;
}

.main .floor-shop-list li:last-of-type {
  margin-bottom: 50px;
}

.floor-shop-list li dl {
  width: 100%;
  margin-bottom: 0;
}

.floor-shop-list li dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid #dddddd;
  font-family: 'Abel', sans-serif;
}

.floor-shop-list dd span {
  display: block;
  color: #222;
}

.floor-shop-list dd {
  width: calc(100% - 40px);
  position: relative;
  padding-left: 23px;
  font-size: 0.88rem;
  letter-spacing: 0;
}

.floor-shop-list dd::before {
  display: block;
  left: 10px;
  top: 0.45em;
  position: absolute;
  width: 7px;
  height: 7px;
  border-top: 2px solid #aca53e;
  border-right: 2px solid #aca53e;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}

/* ---------- icon ------------ */

.floor-map-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  padding-top: 50px;
  border-top: 1px solid #f1f1f1;
}

.main .facility .floor-map-icon li {
  width: calc(100% / 6);
  margin-bottom: 13px;
  padding-left: 40px;
  font-size: 0.88rem;
}

/* for Edge */
@supports (-ms-accelerator:true) {
  .main .facility .floor-map-icon li {
    width: 16%;
  }
}

_::-webkit-full-page-media,
_:future,
:root .css_selector {
  .main .facility .floor-map-icon li {
    width: 16%;
  }
}

.main .facility .floor-map-icon li:last-child {
  width: auto;
}

.floor-map-icon li {
  background-size: 33px 33px;
}

.floor-map-icon li.restroom {
  background: url(../images/facility/images/icon-restroom.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.accessibility {
  background: url(../images/facility/images/icon-accessibility.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.nursing {
  background: url(../images/facility/images/icon-nursing.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.smoking {
  background: url(../images/facility/images/icon-smoking.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.elevator {
  background: url(../images/facility/images/icon-elevator.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.escalator {
  background: url(../images/facility/images/icon-escalator.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.stairs {
  background: url(../images/facility/images/icon-stairs.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.parking {
  background: url(../images/facility/images/icon-parking.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.motorcycle {
  background: url(../images/facility/images/icon-motorcycle.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}

.floor-map-icon li.defibrillator {
  background: url(../images/facility/images/icon-defibrillator.svg) no-repeat 0 20%;
  background-size: 33px 33px;
}



@media screen and (max-width: 768px) {

  .main .facility {
    padding-bottom: 20px;
  }

  .main .facility .tab {
    margin-bottom: 0;
  }

  .main .tab-nav li a {
    font-size: 0.81rem;
  }

  .main .facility .floor-guide-wrapper {
    position: relative;
    top: auto;
    left: auto;
  }

  .facility .floor-guide li span {
    font-size: 0.75rem;
  }

  .main .facility .floor-guide li,
  .main .facility .floor-guide dt {
    font-size: 1rem;
  }

  .main .facility .floor-guide dd li {
    font-size: 0.81rem;
  }

  .floor-guide-icon {
    margin-top: 10px;
  }

  .floor-guide+.floor-guide-icon {
    margin-top: 0;
  }

  .floor-guide-icon li {
    margin-right: 6px;
  }

  .floor-guide-icon img {
    width: 32px;
    height: 32px;
  }

  /* ------- illust map --------- */
  .main .floor-map {
    margin-top: 0;
  }

  .main .floor-map .floor-map-img {
    position: relative;
    margin-bottom: 0;
    padding: 5vw;
    border: 1px solid #ccc;
    overflow: hidden;
  }

  .floor-map .floor-map-img img {
    margin: 15px auto 20px;
  }

  .floor-map .zoom-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    margin-bottom: 25px;

  }

  .floor-map .zoom-btn span {
    position: relative;
    display: block;
    width: 40px;
    height: 40px;
    background: #eeefef;
  }

  .floor-map .zoom-btn span:first-child {
    margin-right: 1px;
  }

  .floor-map .zoom-btn span.minus::before,
  .floor-map .zoom-btn span.plus::before {
    position: absolute;
    display: block;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 15px;
    height: 1px;
    margin: auto;
    background: #555555;
    content: "";
  }

  .floor-map .zoom-btn span.plus::after {
    position: absolute;
    display: block;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 1px;
    height: 15px;
    margin: auto;
    background: #555555;
    content: "";
  }




  .floor-map-guide {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    width: 90%;
  }

  .floor-map-guide li {
    width: calc(50% - 10px);
    margin-left: 0;
    margin-right: 10px;
    padding-left: 0 !important;
    letter-spacing: 0;
  }

  .main .floor-map-guide li p {
    font-size: 0.75rem;
    letter-spacing: 0;
    line-height: 1.25;
  }

  .main .floor-map-guide .en-font {
    margin-top: 0;
  }

  .floor-map-guide .area {
    position: relative;
    top: 0.5em;
    width: 16px;
    height: 16px;
    margin-right: 5px;
  }

  .main .facility h2.tit {
    margin-top: 20px;
    margin-bottom: 20px;
    font-size: 1.25rem;
  }

  .main .floor-shop-list {
    margin-bottom: 30px;
    margin-bottom: 0;
  }

  .main .floor-shop-list li {
    width: 50%;
    margin-bottom: 25px;
  }

  .main .floor-shop-list dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
  }

  .main .floor-shop-list li dt {
    width: 28px !important;
    /* width: 25% !important; */
    height: 28px;
    padding-bottom: 0 !important;
    font-size: 0.69rem;
  }

  .floor-shop-list dd {
    width: calc(100% - 25%) !important;
    font-size: 0.75rem;
    line-height: 1.25;
  }

  .floor-shop-list dd .en-font {
    margin-top: 0;
  }

  .main .facility .floor-map-icon {
    margin-bottom: 0;
    padding-top: 25px;
  }

  .main .facility .floor-map-icon li {
    width: calc(100% / 3);
    margin-bottom: 8px;
    padding-left: 30px;
    font-size: 0.69rem;
  }

  .main .facility .floor-map-icon .en-font {
    font-size: 0.63rem;
  }

  .floor-map-icon li.restroom,
  .floor-map-icon li.accessibility,
  .floor-map-icon li.nursing,
  .floor-map-icon li.smoking,
  .floor-map-icon li.elevator,
  .floor-map-icon li.escalator,
  .floor-map-icon li.stairs,
  .floor-map-icon li.parking,
  .floor-map-icon li.motorcycle,
  .floor-map-icon li.defibrillator {
    background-size: 24px 24px;
  }


}

@media screen and (max-width: 479px) {

  .main .floor-map dt {
    margin-bottom: 45px;
  }

  .floor-map-guide {
    width: 100%;
  }

  .floor-shop-list dd {
    font-size: 0.69rem;
  }

}


/* -------------------------------------------

  Otemachi Now

--------------------------------------------- */
#otemachinow-catch-copy .catch-copy-img {
  background-image: url(../images/otemachinow/mainvisual.jpg);
}

.catch-copy {
  position: relative;
  width: 100%;
  height: 450px;
  padding-top: 59px;
  padding-bottom: .88%;
  background: #a69e2f;
  font-size: 1.5rem;
  box-sizing: border-box;
  letter-spacing: .1em;
  overflow: hidden;
  z-index: 0;
}

.catch-copy .inner {
  position: relative;
  width: 55%;
  height: auto;
  padding: 5% 6%;
  background: #fff;

}

.catch-copy .inner h1 {
  margin-bottom: 10px;
  color: #a59f31;
  font-family: 'Abel', sans-serif;
  font-size: 2.5rem;
  letter-spacing: .1em;
}

.catch-copy-img {
  position: absolute;
  top: 0;
  left: 45%;
  width: 100%;
  max-width: 1500px;
  height: 410px;
  background-image: no-repeat;
  background-size: contain;
  z-index: -1;
}

.op_h1 {
  color: #a69e2f;
  font-size: 19px;
}

.main .otemachi-now dl dd p {
  line-height: 1.6;
}

.main .keywords-list {
  margin: 30px 0 40px;
}

.pagenation ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-jusrify-content: center;
  justify-content: center;
  width: auto;
  margin: 30px 0 50px;
  font-family: 'Abel', sans-serif;
  color: #a0a0a0;
}

.main .pagenation ul li:before {
  content: none;
}

.pagenation li.next,
.pagenation li.prev {
  position: relative;
  width: 12%;
  color: #222 !important;
}

.pagenation .next {
  padding-right: 12px;
}

.pagenation .prev {
  padding-left: 12px;
}

.pagenation .next::before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 12px;
  width: 18px;
  height: 13px;
  margin: auto;
  transition: all .2s ease-in-out;
  background: url(../images/pagenation-arrow.svg) no-repeat;
  content: "";
}

.pagenation .prev::before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 12px;
  width: 18px;
  height: 13px;
  margin: auto;
  transition: all .2s ease-in-out;
  transform: scale(-1, 1);
  -webkit-transform: scale(-1, 1);
  -moz-transform: scale(-1, 1);
  background: url(../images/pagenation-arrow.svg) no-repeat;
  content: "";
}

.pagenation li>*:not(.next) {
  border-right: none;
}

.pagenation span.current {
  background: #222;
  color: #fff !important;
}

.pagenation a:hover {
  background: #a69e2f;
  color: #fff !important;
}

.pagenation .next:hover::before {
  background: url(../images/pagenation-white-arrow.svg) no-repeat;
}

.pagenation .prev:hover::before {
  background: url(../images/pagenation-white-arrow.svg) no-repeat;
}

.main .otemachi-now h2 {
  margin: 0 0 20px;
  font-size: 1.38rem;
}

.main.archive-otemachi-now .otemachi-now h2 {
  color: #a69e2f;
}

.main .otemachi-now h2::after {
  display: none;
}


@media screen and (max-width: 963px) {

  .catch-copy br {
    display: none;
  }

}




@media screen and (max-width: 768px) {

  .catch-copy {
    position: relative;
    width: 100%;
    /* height: 450px; */
    height: auto;
    margin-top: 75px;
    padding: 5% 0 5%;
    background: #a69e2f;
    font-size: 1.13rem;
    box-sizing: border-box;
    letter-spacing: .1em;
    overflow: hidden;
    z-index: -2;
  }

  .catch-copy .inner {
    position: relative;
    width: 70%;
    height: auto;
    padding: 4.5% 5% 3.5%;
    background: #fff;
  }

  .catch-copy .inner::before {
    display: block;
    position: absolute;
    top: -59px;
    left: 70%;
    width: 2000px;
    height: 150%;
    background: url(../images/otemachinow/tit-bg.jpg) no-repeat;
    background: #ddd;
    content: "";
    z-index: -1;
  }

  .main .keywords-list {
    margin: 0px 0 30px;
  }

  .pagenation>* {
    width: 45px;
    height: 45px;
  }

  .pagenation>*.prev,
  .pagenation>*.next {
    width: 6em;
  }

}

@media screen and (max-width: 540px) {

  .pagenation>*:nth-child(4),
  .pagenation>*:nth-child(5),
  .pagenation>*:nth-child(6) {
    display: none;
  }

  .pagenation .next::before {
    right: 8px;
    width: 13px;
    height: 9px;
  }

  .pagenation .prev::before {
    left: 8px;
    width: 13px;
    height: 9px;
  }
}


/*  tag - article page
------------------------------------------ */
.article-wrapper,
.terms-wrapper {
  width: 100%;
  max-width: 820px;
  margin: auto;
  padding: 40px 0 0;

}

article {
  width: 100%;
  margin-bottom: 30px;
  /* max-width: 860px;
  margin: auto;
  padding: 0 3vw; */
}

article h2,
.terms-wrapper h2 {
  position: relative;
  margin-bottom: 40px;
  padding-bottom: 38px;
}

article h2::before,
.terms-wrapper h2::before {
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 88px;
  height: 2px;
  background: #222;
  content: "";
}

.main .terms-wrapper h2::after {
  display: none;
}

article h3,
.terms-wrapper h3 {
  font-size: 1.38rem;
}

article .img.full {
  margin-bottom: 50px;
}

article .video {
  position: relative;
  width: 100%;
  height: 100%;
  /* height: 460px; */
  margin-bottom: 50px;
  overflow: hidden;
}

article .video video {
  position: relative;
  width: 100%;
  height: auto;
}

article .video a {
  display: block;
  position: relative;
}

article .video a::after {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 88px;
  height: 88px;
  margin: auto;
  background: url(../images/otemachinow/btn-video.png) no-repeat center;
  background-size: contain;
  content: "";
}

/* article .video .bg-img{
  position: relative;
  width: 100%;
  height: 100%;
  height: 460px;
  margin-bottom: 50px;
  overflow: hidden;
}
article .video .bg-img {
  position: relative;
}
article .video .bg-img::after {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 88px;
  height: 88px;
  margin: auto;
  background: url(../images/otemachinow/btn-video.png) no-repeat center;
  background-size: contain;
  content: "";
} */
.btn-back {
  display: inline-block;
  margin-bottom: 50px;
}

.btn-back a {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  padding-left: 30px;
  text-decoration: none;
}

.btn-back a::before {
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  left: 0;
  right: auto;
  width: 20px;
  height: 4px;
  margin: auto;
  background: url(../images/btn-arrow.svg) no-repeat;
  background-size: contain;
  transform: rotateY(-180deg);
  transition: all .2s ease-in-out;
  content: "";
}

.btn-back a:hover::before {
  left: -5px;
}

.main .list01 {
  padding: 20px 0;
}

.main .list01 li {
  margin-bottom: 5px;
  padding-left: 0;
}

.main .list01 li::before {
  display: none
}

@media screen and (max-width: 768px) {

  .article-wrapper {
    padding: 15px 0 0;
  }

  .terms-wrapper {
    padding-top: 0;
  }

  article {
    width: 100%;
    margin-bottom: 30px;
  }

  article h2,
  .terms-wrapper h2 {
    position: relative;
    margin-bottom: 30px;
    padding-bottom: 28px;
    font-size: 1.38rem !important;
  }

  article h2::before,
  .terms-wrapper h2::before {
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 44px;
    height: 2px;
    background: #222;
    content: "";
  }

  .terms-wrapper>h2:first-child {
    margin-top: 0;
  }

  article h3,
  .terms-wrapper h3 {
    font-size: 1.13rem !important;
  }

  article .img.full {
    margin-bottom: 30px;
  }

  article .video {
    width: 100%;
    height: 100%;
    /* height: 52vw; */
    margin-bottom: 30px;
    overflow: hidden;
  }

  article .video a::after {
    top: 0;
    bottom: 0;
    width: 44px;
    height: 44px;
    /* width: 77px;
    height: 77px; */
    margin: auto;
  }

  .btn-back {
    display: inline-block;
    margin-bottom: 40px;
  }
}

/* -----------------------------------------

  Infromation

------------------------------------------- */
.main .information dl.news.border-set {
  padding-top: 40px;
}

.main .information-page .news.border-set {
  display: none;
}

.main .information-page #page-1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
}

@media screen and (max-width: 768px) {

  .main .information dl.news.border-set {
    padding-top: 15px;
  }

  .main dl.news a {
    display: block;
  }

  .main dl.border-set dt,
  .main dl.border-set dd {
    border-top: none;
  }
}




/* -------------------------------------------

  contact

--------------------------------------------- */
.contact.content {
  padding: 120px 0;
  background: url(../images/contact/images/contact-bg.jpg) no-repeat top center;
  background-size: cover;
}

.form-wrapper {
  width: 90%;
  max-width: 1000px;
  margin: auto;
  padding: 6% 10vw;
  background: #fff;
  box-sizing: border-box;
}

.main .form-wrapper dl.border-set {
  border-top: none;
}

.form-wrapper .tips {
  letter-spacing: 0;
}

.main .form dl.border-set>dt:last-of-type {
  display: block;
  padding-top: 35px;
}

.form-wrapper .tips .label-inline {
  margin-left: 0;
}

@media screen and (min-width: 1920px) {
  .form-wrapper {
    padding: 6% 5vw;
  }

  .top-access .box-left {
    padding: 4vw 3vw 4vw;
  }
}

@media screen and (max-width: 768px) {

  .contact.content {
    padding: 50px 0;
  }

  .form-wrapper {
    width: calc(100% - 6vw);
    padding: 4% 3vw 40px;
  }

  .form-wrapper .tips {
    margin-bottom: 5px;
  }

  .form-wrapper,
  .main .form input[type="text"],
  .main .form input[type="email"],
  .main .form textarea {
    padding: 8px 1em;
    font-size: .88rem;
  }
}

@media screen and (max-width: 520px) {

  .form-wrapper .btn a {
    width: 90%;
  }
}

.lost_property_area {
  position: absolute;
  width: 90%;
  max-width: 1000px;
  height: 100%;
}

.lost_property_innner {
  display: inline-block;
  width: auto;
  position: absolute;
  right: 0;
  top: 0;
  height: auto;
  top: 50%;
  transform: translateY(-50%);
  -webkit- transform: translateY(-50%);
  text-align: center;
}

@media screen and (max-width: 768px) {
  .lost_property_innner {
    display: inline-block;
    position: absolute;
    top: 0;
    line-height: 1.3;
    right: 0;
    text-align: center;
    font-size: 13px;
    margin-top: 8px;
    transform: none;
  }
}

.lost_property_title {
  font-weight: bold;
  text-decoration: underline;
  font-size: 1.3rem;
}

.lost_property_content {}

/* ---------------------------------------------

  404

---------------------------------------------- */
.main .not-found {
  width: 500px;
  margin: 120px auto 0;
  padding-bottom: 105px;
  color: #444;
}

.main .not-found h1 {
  color: #aaa;
  font-family: 'Abel', sans-serif;
  font-size: 245px;
  text-align: center;
  line-height: 1;
}

.main .not-found p {
  font-size: 1.5rem;
  text-align: center;
}

.main .not-found ul {
  margin-left: 2.5vw;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {

  .main .not-found {
    width: 100%;
    margin-top: 100px;
    padding: 4vw 4vw 10vw;
  }

  .main .not-found h1 {
    font-size: 36.5vw;
  }

  .main .not-found p {
    font-size: 1rem;
  }

  .main .not-found ul {
    width: 80vw;
    margin: 0 auto 20px;
    font-size: .88rem;
  }
}





/* --------------------------------------------

  footer

-------------------------------------------- */
.main ul li:before {
  content: unset;
}

footer {
  position: relative;
  width: 100%;
  height: 160px;
  background: #222222;
  color: #fff;
  font-size: 0.88rem;
  z-index: 2;
}

footer .footer-inner {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  width: 100%;
  padding: 0 3vw;
}

footer .footer-nav {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  -webkit-order: 2;
  -ms-order: 2;
  order: 1;
  /* width: 65%; */
  width: 80%;
}

footer .footer-nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;

  -webkit-box-lines: multiple;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;

  -webkit-justify-content: flex-end;
  justify-content: flex-end;

  width: 1131px;
  padding-top: 20px;

}

footer .footer-nav ul li {
  position: relative;
  margin-right: 2vw;
  margin-bottom: 12px;
  padding-left: 10px;
  transition: all .3s ease-in-out;
}

footer .footer-nav ul li:last-child {
  margin-right: 0;
}

footer .footer-nav ul li::before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 2px;
  height: 2px;
  border-radius: 50%;
  margin: auto;
  background: #9f9f9f;
  content: "";
  transition: all .2s ease-in-out;
}

footer .footer-nav ul li a,
footer .footer-policy li a {
  color: #9f9f9f;
  text-decoration: none;
  opacity: .8;
  transition: all .2s ease-in-out;
}

footer .footer-nav ul li a:hover,
footer .footer-policy li a:hover {
  color: #fff;
  opacity: 1;
}

footer .footer-nav ul li:hover::before {
  background: #fff;
}

footer .footer-policy {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  -webkit-order: 0;
  -ms-order: 0;
  order: 0;
  /* width: 35%; */
  width: 40%;
  padding-top: 20px;
}

footer .footer-policy li {
  margin-right: 1.5vw;
  transition: all .3s ease-in-out;
}

footer .footer-icon {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;

  position: absolute;
  left: 3vw;
  bottom: 30px;
}

footer .footer-icon li {
  margin-right: 30px;
}

footer .footer-icon li span {
  display: block;
  font-size: 0.625rem;
  margin: 0 auto 5px;
  text-align: center;
}

footer .footer-icon li img {
  display: block;
  margin: auto;
}

footer .footer-icon li:last-child img {
  padding-top: 26px;
}

small {
  position: absolute;
  right: 3vw;
  bottom: 25px;
  color: #9f9f9f;
  text-align: right;
  opacity: .8;
}


@media screen and (min-width: 1024px) and (max-width: 1290px) {

  footer {
    font-size: .81rem;
  }

  footer .footer-inner {
    padding: 0 2vw;
  }

  footer .footer-nav ul li {
    margin-right: 1.5vw;
    font-size:
  }

  footer .footer-policy li {
    margin-right: 1vw;
  }

  footer .footer-icon {
    left: 2vw;
  }

  footer small {
    right: 2vw;
  }

}


@media screen and (max-width: 1023px) {

  footer {
    height: auto;
    font-size: 0.81rem;
  }

  footer .footer-inner {
    -webkit-flex-direction: column;
    flex-direction: column;
    padding: 0;
  }

  footer .footer-nav {
    width: 100%;
    order: 0;
  }

  footer .footer-nav ul {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
    padding-top: 0;
    justify-content: flex-start;
  }

  footer .footer-nav ul li {
    width: 50%;
    height: 70px;
    margin: 0;
    padding: 0;
    border-right: 1px solid rgba(255, 255, 255, .2);
    border-bottom: 1px solid rgba(255, 255, 255, .2);
  }

  footer .footer-nav ul li:last-child {
    /*width: 100%;*/
  }

  footer .footer-nav ul li::before {
    display: none;
  }

  footer .footer-nav ul li a {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
    width: 100%;
    height: inherit;
    padding: 10px;
  }

  footer .footer-policy {
    display: block;
    position: inherit;
    width: 100%;
    padding: 20px 15px 50px 25px;
    order: 1;
  }

  footer .footer-policy li {
    margin-bottom: 8px;
  }

  footer .footer-icon {
    right: 15px;
    bottom: 100px;
    bottom: 68px;
    left: auto;
  }

  footer .footer-icon li {
    webkit-box-lines: multiple;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;

    width: 50%;
    margin-right: 0;

  }

  footer .footer-icon li span {
    font-size: 10px;
  }

  footer .footer-icon li:first-child {
    /* width: 35px; */
    width: 100px;
    margin-right: 10px;
  }

  footer .footer-icon li:last-child {
    /* width: 72px; */
    width: 100px;
  }

  small {
    left: 25px;
    right: auto;
    bottom: 20px;
  }

}


@media screen and (max-width: 320px) {
  footer .footer-icon {
    display: block;
    bottom: 20px;
  }

  footer .footer-icon li {
    margin-bottom: 10px;
  }

  footer .footer-icon li:first-child {
    margin-right: 0;
    margin-left: auto;
  }

  footer .footer-icon li img {
    margin: auto;
  }

  footer .footer-icon li:last-child img {
    padding-top: 0;

  }

  .footer-inner small {
    bottom: 20px;
  }

  footer .footer-policy {
    padding: 20px 15px 60px 25px;
  }

  footer .footer-icon {
    bottom: 51px;
  }
}

/* ----------------------------------------------------

 contact mw wp form

------------------------------------------------------ */
.mw_wp_form_input button[value="SUBMIT"],
.mw_wp_form_input button[value="BACK"] {
  display: none;
}

.mw_wp_form button[value="BACK"] {
  width: 200px;
  height: 60px;
  vertical-align: middle;
  align-items: center;
  background: rgb(153, 153, 153);
}

.mw_wp_form button[value="BACK"]::after {
  background: url(../images/whiteArrow2.svg) no-repeat center;
  left: -88px;
}

.contact .mw_wp_form .error {
  font-size: .69rem;
  color: #f2646e;
}

.mw_wp_form_preview button[value="Confirm"] {
  display: none;
}

.mw_wp_form_preview .btn {
  flex-wrap: wrap-reverse;
}

.main .mw_wp_form .btn.center {
  align-items: center;
}

/* -----------------------------------------
  ページネーション
-------------------------------------------- */
.pagenation li.active {
  background: #222;
  color: #fff !important;
}

.main .pagenation li {
  margin-bottom: 0px;
  padding: 0;
}

.pagenation li a,
.pagenation li span {
  border: 1px solid #e2e2e2;
}

.pagenation li>* {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: 59px;
  height: 60px;
  text-decoration: none !important;
  color: #a0a0a0 !important;
  transition: all .2s ease-in-out;
}

.pagenation .disabled {
  display: none;
}

.pagenation li.next a,
.pagenation li.prev a {
  width: 100%;
  color: #222 !important;
}

.pagenation li.next a:hover,
.pagenation li.prev a:hover {
  background: #a69e2f;
  color: #fff !important;
}

.otemachi-now .row .col-set {
  display: none;
}

.otemachi-now .row #page-1 {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
}

@media screen and (max-width: 768px) {

  .pagenation li.prev,
  .pagenation li.next {
    width: 6em;
  }

  .pagenation li {
    width: 45px;
    height: 45px;
  }

  .pagenation li>* {
    width: 100%;
    height: 45px;
  }
}

@media screen and (min-width: 1301px) {
  header nav {
    display: -webkit-flex !important;
    display: -ms-flex !important;
    display: flex !important;
  }
}