@charset "UTF-8";
/* 
  css設定 @charsetが消されるsass仕様へのハック用コメントです。削除しないでください。新規作成時も必須！
 */
.lower {
  background: url(../images/common/lower-bg.jpg);
  background-size: cover;
}

.lower main {
  padding-top: 0;
}

.lower .mv {
  margin-bottom: 290rem;
  position: relative;
  z-index: 2;
}

.lower .mv .inner {
  position: relative;
  overflow: hidden;
}

.lower .mv .mv-texts {
  position: absolute;
  top: 100%;
  left: 50%;
  margin-top: 50rem;
  transform: translateX(-50%);
  width: 80%;
  text-align: center;
  opacity: 0;
  transition: opacity 1s;
}

.lower .mv .mv-texts .page-title {
  font-size: 40rem;
  color: #A58954;
  font-weight: normal;
  padding-bottom: 8rem;
}

.lower .mv .mv-texts .ja {
  font-size: 14rem;
  line-height: 1.5;
  padding-bottom: 3rem;
}

.lower .mv .mv-texts::after {
  content: "";
  display: block;
  position: absolute;
  top: 100%;
  left: 50%;
  margin-top: 20rem;
  width: 1px;
  height: 0rem;
  background-color: #A58954;
  transition: height 1.2s 1.2s;
}

.lower .mv .image {
  position: relative;
  overflow: hidden;
}

.lower .mv .image img {
  display: block;
  transform: scale(1.12);
  filter: blur(10px);
  transition: transform 1s,filter 1s;
}

.lower .mv.on .image img {
  transform: scale(1);
  filter: blur(0px);
}

.lower .mv.on .mv-texts {
  opacity: 1;
}

.lower .mv.on .mv-texts::after {
  height: 80rem;
}

.lower .swipeArea {
  overflow-x: auto;
}

.lower .swipeArea img {
  min-width: 710px;
}

.lower .click-btn {
  max-width: 320px;
  margin: 20px auto 40px;
  text-align: center;
  clear: both;
}

.lower .click-btn a {
  position: relative;
}

.lower .click-btn a:hover {
  opacity: 0.8;
}

.lower .modal-wrapper {
  z-index: 29999;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  padding: 200px 10px;
  text-align: center;
}

.lower .modal-wrapper:not(:target) {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}

.lower .modal-wrapper:target {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.4s, visibility 0.4s;
  background: #fff !important;
}

.lower .modal-wrapper::after {
  display: inline-block;
  margin-left: -0.05em;
  vertical-align: middle;
  content: "";
}

.lower .modal-window {
  box-sizing: border-box;
  display: inline-block;
  z-index: 20;
  position: relative;
  width: 94%;
  max-width: 100%;
  padding: 0;
  border-radius: 2px;
  vertical-align: middle;
}

.lower .modal-window .modal-content {
  max-height: 80vh;
  overflow-y: auto;
  text-align: left;
}

.lower .modal-window .modal-content .swipe-img img {
  width: 560px !important;
}

.lower .modal-overlay {
  z-index: 10;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  border-radius: 0 !important;
  background: rgba(0, 0, 0, 0.8) !important;
}

.lower .modal-overlay.overlay01 {
  background: rgba(225, 225, 225, 0.8) !important;
}

.lower .modal-overlay:hover {
  opacity: 1 !important;
}

.lower .modal-close {
  z-index: 20;
  position: absolute !important;
  top: -35px;
  left: 0;
  width: 36px;
  color: #000 !important;
  font-size: 36px;
  font-weight: 700;
  line-height: 36px;
  text-align: center;
  text-decoration: none;
  text-indent: 0;
  padding: 0;
}

.lower .modal-close:hover {
  color: #ccc !important;
}

/*----------------
map
----------------*/
#map .maps {
  margin: 0 auto;
  width: 90%;
  max-width: 800rem;
  padding-bottom: 200rem;
}

#map .maps .map-title {
  text-align: center;
  font-size: 20rem;
  line-height: 2;
  padding-bottom: 20rem;
}

#map .maps .links {
  margin: 0 auto;
  display: flex;
  justify-content: center;
  gap: 20rem;
  padding-top: 40rem;
}

#map .maps .links li {
  width: 49%;
}

#map .salon {
  padding: 105rem 0 100rem;
  background-color: #3C2903;
  color: #fff;
}

#map .salon .title {
  font-size: 22rem;
  line-height: 1.3;
  text-align: center;
  font-weight: normal;
  padding-bottom: 50rem;
}

#map .salon .box {
  display: flex;
  justify-content: space-between;
}

#map .salon .box .images {
  width: 55%;
}

#map .salon .box .texts {
  width: 40%;
}

#map .salon .box dl {
  display: flex;
  padding-bottom: 15rem;
  border-bottom: 1px solid #fff;
  margin-bottom: 20rem;
}

#map .salon .box dl + dl {
  padding-top: 30rem;
}

#map .salon .box dt {
  width: 120rem;
  font-weight: normal;
  font-size: 16rem;
  line-height: 2;
}

#map .salon .box dd {
  font-size: 14rem;
  line-height: 2.2;
}

#map .salon .box .txt01 {
  padding-bottom: 20rem;
  font-size: 16rem;
  line-height: 2;
}

#map .salon .box li {
  font-size: 14rem;
  line-height: 2.2;
}

/*----------------
outline
----------------*/
#outline .site-header {
  opacity: 1;
  background-color: #fff;
}

#outline .commonTitle02 {
  padding-bottom: 50rem;
  line-height: 1;
  text-align: center;
  font-size: 40rem;
  font-weight: normal;
}

#outline .contents {
  text-align: center;
}

#outline .contents .page-content {
  padding: 120rem 0 170rem;
}

#outline .contents .info-area h3 {
  text-align: center;
  font-size: 26px;
  line-height: 1.8;
  letter-spacing: .3em;
  font-weight: normal;
  margin-bottom: 50px;
}

#outline .contents .info-area table {
  margin: auto;
  max-width: 1000px;
  border-collapse: separate;
  border-spacing: 10px 0;
}

#outline .contents .info-area table .info_terms td {
  border-bottom: none;
}

#outline .contents .info-area table .info_terms + .row_detail td {
  border-top: 1px solid rgba(150, 132, 99, 0.6);
}

#outline .contents .info-area table th,
#outline .contents .info-area table td {
  padding: 15px;
  vertical-align: middle;
  line-height: 1.4;
  font-size: 14px;
}

#outline .contents .info-area table th {
  border: none;
  text-align: center;
  border-bottom: 1px solid #fff;
  color: #fff;
  background: #3C2903;
}

#outline .contents .info-area table td {
  text-align: left;
  border-bottom: 1px solid rgba(150, 132, 99, 0.6);
}

#outline .contents .info-area .row_detail + .info_terms h3 {
  padding-top: 60px;
}

#outline .contents .info-area .buken_comment {
  padding-top: 60px;
  line-height: 1.7;
  font-size: 11px;
}

#outline .contents .info-area .buken_comment p {
  line-height: 1.7;
  font-size: 11px;
}

#outline .contents .info-area .buken_comment + .buken_comment {
  padding-top: 0;
}

@media (max-width: 768px) {
  #outline .contents .commonTitle02 {
    padding-top: 50rem;
  }
  #outline .contents .info-area h3 {
    font-size: 22px;
    margin-bottom: 20px;
  }
  #outline .contents .info-area table {
    display: block;
    border-collapse: collapse;
    border-spacing: 0;
  }
  #outline .contents .info-area table colgroup {
    display: block;
  }
  #outline .contents .info-area table .info_terms + .row_detail td {
    border-top: none;
    margin-bottom: 2px;
  }
  #outline .contents .info-area table th,
  #outline .contents .info-area table td {
    box-sizing: border-box;
    display: block;
    padding: 10px;
    font-size: 13px;
    width: 100%;
    margin-bottom: 2px;
  }
  #outline .contents .info-area .row_detail + .info_terms h3 {
    padding-top: 40px;
  }
  #outline .contents .info-area .buken_comment {
    padding-top: 40px;
    line-height: 1.4;
  }
  #outline .contents .info-area .buken_comment p {
    line-height: 1.4;
  }
}

/* ========================================================
 brand
======================================================== */
#brand.lower {
  background: #fff;
}

#brand .mv .movie {
  width: 100%;
  height: 100%;
  z-index: 20;
  background-color: #000;
}

#brand .mv video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#brand .contents .image {
  position: relative;
}

#brand .intro {
  text-align: center;
  padding-top: 100px;
  margin-bottom: 100px;
}

#brand .intro .tit {
  font-size: 33px;
  margin-bottom: 20px;
}

#brand .intro .sub {
  font-size: 18px;
  margin-bottom: 100px;
}

#brand .intro .image {
  max-width: 360px;
  margin: 0 auto 80px;
}

#brand .intro .txt01 {
  font-size: 57px;
  line-height: 1.8;
  letter-spacing: .2em;
  margin-bottom: 80px;
}

#brand .intro .txt02 {
  font-size: 26px;
  line-height: 1.6;
  margin-bottom: 30px;
}

#brand .intro .lead {
  font-size: 16px;
  line-height: 2;
}

#brand .slick-slider {
  margin-bottom: 200px;
}

#brand .slick-dots {
  display: flex;
  justify-content: center;
  gap: 0 5rem;
  position: static;
  padding-top: 20px;
}

#brand .slick-dots li {
  width: 34rem;
  height: 4rem;
}

#brand .slick-dots li.slick-active button {
  background: #595757;
}

#brand .slick-dots li button {
  appearance: none;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 0;
  background: #EAEAEA;
}

#brand .slick-dots li button:before {
  display: none;
}

#brand .promise {
  text-align: center;
  margin-bottom: 200px;
}

#brand .promise .tit {
  font-size: 26px;
  line-height: 1.8;
  margin-bottom: 30px;
}

#brand .promise .sub {
  font-size: 18px;
  margin-bottom: 100px;
}

#brand .promise .lists {
  background: #B6CBCF;
  margin-bottom: 50px;
}

#brand .promise .lists li {
  vertical-align: middle;
  display: inline-block;
  width: 30%;
}

#brand .promise .lists li:last-child {
  width: 69%;
}

#brand .promise .lists .txt01 {
  font-size: 30px;
  margin-bottom: 18px;
}

#brand .promise .lists .txt02 {
  font-size: 18px;
  margin-bottom: 50px;
}

#brand .promise .lists .lead {
  text-align: left;
  width: 76%;
  margin: auto;
  font-size: 14px;
  line-height: 2;
}

#brand .promise .list02 {
  background: #BDC1B1;
}

#brand .promise .list03 {
  background: #DBD1C1;
}

#brand .promise .list04 {
  background: #C7BBC8;
  margin-bottom: auto;
}

#brand .salon {
  text-align: center;
  margin-bottom: 200px;
}

#brand .salon .tit {
  font-size: 32px;
  margin-bottom: 50px;
}

#brand .salon .lead {
  font-size: 18px;
  line-height: 2;
  margin: 80px auto;
}

#brand .salon .image {
  max-width: 1200px;
  margin: auto;
}

#brand .cafe {
  text-align: center;
  margin-bottom: 200px;
}

#brand .cafe .tit {
  font-size: 32px;
  margin-bottom: 50px;
}

#brand .cafe .lead {
  font-size: 18px;
  line-height: 2;
  margin: 0 auto 80px;
}

#brand .cafe .img01 {
  max-width: 1200px;
  margin: auto;
}

#brand .cafe .img01 .caption {
  color: #404040;
}

#brand .cafe .img02 {
  max-width: 1000px;
  width: 90%;
  margin: 80px auto 0;
}

#brand .achievement {
  text-align: center;
  background: #2E2E2E;
  padding: 140px 0;
  color: #fff;
  margin-bottom: 200px;
}

#brand .achievement .tit {
  font-size: 36px;
  margin-bottom: 10px;
}

#brand .achievement .sub {
  font-size: 20px;
  margin-bottom: 50px;
}

#brand .achievement li {
  display: inline-block;
  width: 48%;
  margin-right: 2%;
}

#brand .achievement li:last-child {
  margin-right: auto;
}

#brand .achievement .caps {
  text-align: right;
  font-size: 11px;
  line-height: 1.4;
  margin-top: 10px;
  color: #fff;
}

#brand .ginza {
  text-align: center;
  display: none;
}

#brand .ginza .logo {
  max-width: 385px;
  margin: 0 auto 80px;
}

#brand .ginza ul {
  max-width: 1200px;
  margin: auto;
}

#brand .ginza li {
  display: inline-block;
  vertical-align: top;
  width: 40%;
  margin-right: 3%;
}

#brand .ginza li:last-child {
  width: 56%;
  margin-right: auto;
}

#brand .ginza .img04 {
  max-width: 198px;
  margin: 30px 0;
}

#brand .ginza .info {
  text-align: left;
  font-size: 14px;
  letter-spacing: .12em;
  line-height: 1.6;
}

#brand .ginza .sns {
  max-width: 74px;
  margin: 80px auto 0;
}

@media screen and (max-width: 1024px) {
  #brand .promise .lists .txt01 {
    font-size: 24px;
    margin-bottom: 10px;
  }
  #brand .promise .lists .txt02 {
    font-size: 16px;
    line-height: 1.4;
    letter-spacing: 0;
    margin-bottom: 20px;
  }
  #brand .promise .lists .lead {
    width: 94%;
    line-height: 1.6;
  }
}

/* ========================================================
 entry
======================================================== */
#entry main {
  text-align: center;
  background: url("../images/entry/bg.jpg") center;
  background-size: cover;
  min-height: 100vh;
  padding: 223rem 0 0;
  color: #fff;
}

#entry .page-title {
  font-size: 40rem;
  line-height: 1.3;
  font-weight: normal;
  padding-bottom: 9rem;
}

#entry .pageTitle {
  text-align: center;
  padding-bottom: 105rem;
}

#entry .pageTitle .ja {
  font-size: 14rem;
  line-height: 1.3;
  font-weight: normal;
}

#entry .page-lead {
  font-size: 14rem;
}

#entry .error {
  font-size: 14rem;
  text-decoration: underline;
  padding-bottom: 30rem;
}

#entry .contents {
  text-align: center;
}

#entry .error {
  display: none;
}

#entry .page-content .texts .text01 {
  font-size: 24rem;
  line-height: 1.4;
  padding-bottom: 19rem;
}

#entry .page-content .texts .text02 {
  font-size: 14rem;
  line-height: 2.1;
  padding-bottom: 40rem;
}

#entry .page-content .texts .text03 {
  font-size: 18rem;
  line-height: 1.5;
  padding-bottom: 21rem;
}

#entry .page-content .forget-box {
  padding-top: 110rem;
  margin: 0 auto;
  max-width: 600rem;
}

#entry .page-content .forget-box .txt01 {
  font-size: 18rem;
  line-height: 1.4;
  padding-bottom: 25rem;
  border-bottom: 1px solid #fff;
  margin-bottom: 26rem;
}

#entry .page-content .forget-box .txt02 {
  font-size: 14rem;
  line-height: 2.2;
  padding-bottom: 20rem;
}

#entry .page-content .forget-box .lists {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 620rem;
}

#entry .page-content .forget-box .lists li {
  box-sizing: border-box;
}

#entry .page-content .forget-box .lists li a {
  display: block;
  color: #fff;
  position: relative;
  padding: 15rem 0;
  padding-left: 30rem;
  text-align: left;
}

#entry .page-content .forget-box .lists li a:after {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

#entry .page-content .forget-box .lists .list01 {
  padding-right: 25rem;
  border-right: 1px solid #fff;
  width: 50%;
  font-size: 14rem;
}

#entry .page-content .forget-box .lists .list01 a:after {
  background: url("../images/entry/mail.svg") no-repeat center;
  background-size: 25rem 17rem;
  width: 25rem;
  height: 17rem;
}

#entry .page-content .forget-box .lists .list02 {
  padding-left: 25rem;
  width: 42%;
  font-size: 22rem;
}

#entry .page-content .forget-box .lists .list02 a {
  padding-left: 27rem;
}

#entry .page-content .forget-box .lists .list02 a:after {
  background: url("../images/entry/tel.svg") no-repeat center;
  background-size: 19rem 19rem;
  width: 19rem;
  height: 19rem;
}

#entry .page-content form.login .inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto;
  width: 433rem;
}

#entry .page-content form.login input {
  display: block;
  box-sizing: border-box;
  padding: 12rem;
  width: 100%;
  font-size: 16rem;
  box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4);
  font-family: 'EB Garamond','Noto Serif JP', serif;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  -o-appearance: none;
  height: 44rem;
  line-height: 44rem;
}

#entry .page-content form.login input[type="text"] {
  width: calc(100% - 115rem);
  margin-bottom: 19rem;
  border: 1px solid #B0B7CA;
}

#entry .page-content form.login input[type="text"]::placeholder {
  color: #000;
  opacity: .2;
}

#entry .page-content form.login input[type="submit"] {
  cursor: pointer;
  width: 115rem;
  padding: 3rem;
  border: none;
  background: #AA9B80;
  color: #fff;
  border-radius: 0;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  -o-appearance: none;
}

@media (min-width: 1025px) {
  #entry .page-content form.login input[type="submit"]:hover {
    opacity: .7;
  }
}

@media screen and (max-width: 768px) {
  #entry .wrap {
    width: 84%;
  }
  #entry main {
    background-image: url("../images/entry/bg-sp.jpg");
    padding: 159rem 0 51rem;
  }
  #entry .main-header {
    padding-bottom: 61rem;
  }
  #entry .page-title {
    font-size: 30rem;
    padding-bottom: 17rem;
  }
  #entry .error {
    font-size: 14rem;
    padding-bottom: 15rem;
  }
  #entry .page-content .texts .text01 {
    font-size: 22rem;
    line-height: 1.9;
    padding-bottom: 25rem;
  }
  #entry .page-content .texts .text02 {
    line-height: 1.8;
    padding-bottom: 51rem;
  }
  #entry .page-content .texts .text03 {
    font-size: 18rem;
    line-height: 1.9;
    padding-bottom: 44rem;
  }
  #entry .page-content .forget-box {
    padding-top: 75rem;
  }
  #entry .page-content .forget-box .txt01 {
    line-height: 1.8;
    padding-bottom: 15rem;
  }
  #entry .page-content .forget-box .txt02 {
    padding-bottom: 54rem;
  }
  #entry .page-content .forget-box .lists {
    display: block;
    width: auto;
  }
  #entry .page-content .forget-box .lists li a {
    display: inline-block;
    padding: 15rem 0;
    padding-left: 30rem;
    text-align: center;
  }
  #entry .page-content .forget-box .lists .list01 {
    padding-right: 0;
    border-right: none;
    width: auto;
    font-size: 14rem;
    border-bottom: 1px solid #fff;
  }
  #entry .page-content .forget-box .lists .list01 a:after {
    background: url("../images/entry/mail.svg") no-repeat center;
    background-size: 25rem 17rem;
    width: 25rem;
    height: 17rem;
  }
  #entry .page-content .forget-box .lists .list02 {
    padding-left: 0;
    width: auto;
    font-size: 22rem;
  }
  #entry .page-content .forget-box .lists .list02 a {
    padding-left: 27rem;
  }
  #entry .page-content .forget-box .lists .list02 a:after {
    background-size: 19rem 19rem;
    width: 19rem;
    height: 19rem;
  }
  #entry .page-content form.login .inner {
    width: auto;
    display: block;
  }
  #entry .page-content form.login input[type="text"] {
    width: 100%;
    margin-bottom: 19rem;
  }
  #entry .page-content form.login input[type="submit"] {
    width: 100%;
  }
}

/*----------------
life-quality
----------------*/
#life-quality.lower {
  background: url(../images/life-quality/bg.jpg);
  background-size: cover;
}

#life-quality .image {
  position: relative;
}

#life-quality .caption.wh {
  background: none;
  color: #fff;
}

#life-quality .caption.no-bg {
  background: none;
  color: #231815;
}

#life-quality .intro {
  text-align: center;
}

#life-quality .intro .bg {
  background: url(../images/life-quality/txt-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding: 2% 0;
  margin-bottom: 50px;
}

#life-quality .intro .bg .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 50px;
}

#life-quality .intro .bg .lead {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 10px;
}

#life-quality .intro .bg .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 50px;
}

#life-quality .intro .lead {
  font-size: 14px;
  line-height: 2;
  padding-bottom: 100px;
}

#life-quality .intro .buttons {
  text-align: center;
  max-width: 1000px;
  margin: 0 auto;
}

#life-quality .intro .buttons li {
  text-align: center;
  display: inline-block;
  width: 22%;
  margin-right: 2%;
}

#life-quality .intro .buttons li:last-child {
  margin-right: 0;
}

#life-quality .intro .buttons .button {
  display: block;
  color: #fff;
  background-color: #b9aea1;
  font-size: 16rem;
  letter-spacing: .2em;
}

#life-quality .intro .buttons .button.current {
  pointer-events: none;
  color: #fff;
  background-color: #7a6a56;
}

#life-quality .intro .buttons .button span.en {
  display: inline-block;
  padding: 16px 0;
}

#life-quality .intro .buttons .button:hover {
  opacity: 1;
  color: #fff;
  background-color: #7a6a56;
  transition: .3s;
}

#life-quality .equipment {
  text-align: center;
  padding: 100px 0;
}

#life-quality .equipment .tit {
  font-size: 20px;
  margin-bottom: 20px;
  color: #221706;
}

#life-quality .equipment .txt {
  font-size: 20px;
  line-height: 2;
  margin-bottom: 50px;
}

#life-quality .equipment .kv {
  max-width: 1000px;
  margin: 0 auto 50px;
}

#life-quality .equipment .kv.dresser {
  max-width: 301px;
}

#life-quality .equipment .kv.bath {
  max-width: 1000px;
}

#life-quality .equipment ul {
  text-align: left;
  max-width: 1000px;
  margin: 0 auto 30px;
}

#life-quality .equipment ul li {
  text-align: left;
  display: inline-block;
  vertical-align: top;
  width: 31%;
  margin-right: 3%;
  margin-bottom: 60px;
}

#life-quality .equipment ul li.last {
  margin-right: auto;
}

#life-quality .equipment ul li.mr {
  margin-right: 3% !important;
}

#life-quality .equipment ul li.mr0 {
  margin-right: auto;
}

#life-quality .equipment ul li:nth-child(3n) {
  margin-right: auto;
}

#life-quality .equipment ul .name {
  font-size: 16px;
  line-height: 1.6;
  margin: 20px auto 10px;
}

#life-quality .equipment ul .info {
  text-align: left;
  font-size: 12px;
  line-height: 1.8;
}

#life-quality .equipment ul .mini {
  text-align: left;
  margin-top: 10px;
  font-size: 11px;
  line-height: 1.8;
}

#life-quality .equipment ul.half {
  text-align: center;
}

#life-quality .equipment ul.half li:nth-child(2) {
  width: 35%;
  margin-right: auto;
}

#life-quality .equipment ul.half li {
  margin-right: 4%;
}

#life-quality .equipment ul.half li .info {
  text-align: left;
}

#life-quality .equipment ul.half li .info.mb {
  margin-bottom: 10px;
}

#life-quality .equipment ul.sto {
  text-align: center;
}

#life-quality .equipment ul.sto li {
  width: 40%;
}

#life-quality .amenity {
  text-align: center;
  padding: 100px 0 40px;
}

#life-quality .amenity .tit {
  font-size: 20px;
  margin-bottom: 20px;
  color: #221706;
}

#life-quality .amenity .txt {
  font-size: 20px;
  line-height: 2;
  margin-bottom: 50px;
}

#life-quality .amenity ul {
  text-align: left;
  max-width: 1000px;
  margin: auto;
}

#life-quality .amenity ul li {
  text-align: left;
  display: inline-block;
  vertical-align: top;
  width: 31%;
  margin-right: 2%;
  margin-bottom: 60px;
}

#life-quality .amenity ul li.double {
  width: 48%;
}

#life-quality .amenity ul li:nth-child(3n),
#life-quality .amenity ul li:last-child {
  margin-right: auto;
}

#life-quality .amenity ul .name {
  font-size: 16px;
  line-height: 1.6;
  margin: 20px auto 10px;
}

#life-quality .amenity ul .info {
  text-align: left;
  font-size: 12px;
  line-height: 1.8;
}

#life-quality .amenity ul .mini {
  text-align: left;
  margin-top: 3px;
  font-size: 11px;
  line-height: 1.8;
}

#life-quality .safety {
  text-align: center;
  padding: 100px 0 40px;
}

#life-quality .safety .tit {
  font-size: 20px;
  margin-bottom: 20px;
  color: #221706;
}

#life-quality .safety .txt {
  font-size: 20px;
  line-height: 2;
  margin-bottom: 50px;
}

#life-quality .safety ul {
  text-align: left;
  max-width: 1000px;
  margin: auto;
}

#life-quality .safety ul.full li {
  width: 100%;
  margin: 0 auto 60px;
}

#life-quality .safety ul li {
  text-align: left;
  display: inline-block;
  vertical-align: top;
  width: 31%;
  margin-right: 2%;
  margin-bottom: 60px;
}

#life-quality .safety ul li:nth-child(3n) {
  margin-right: auto;
}

#life-quality .safety ul .name {
  text-align: left;
  font-size: 16px;
  line-height: 1.6;
  margin: 20px auto 10px;
}

#life-quality .safety ul .name span {
  font-size: 12px;
}

#life-quality .safety ul .info {
  text-align: left;
  font-size: 12px;
  line-height: 1.8;
}

#life-quality .safety ul .mini {
  text-align: left;
  margin-top: 3px;
  font-size: 11px;
  line-height: 1.8;
}

#life-quality .structure {
  text-align: center;
  padding: 100px 0 40px;
}

#life-quality .structure .tit {
  font-size: 20px;
  margin-bottom: 50px;
  color: #221706;
}

#life-quality .structure .txt {
  font-size: 20px;
  line-height: 2;
  margin-bottom: 50px;
}

#life-quality .structure ul {
  text-align: left;
  max-width: 1000px;
  margin: auto;
}

#life-quality .structure ul li {
  text-align: left;
  display: inline-block;
  vertical-align: top;
  width: 31%;
  margin-right: 2%;
  margin-bottom: 60px;
}

#life-quality .structure ul li.double {
  width: 64%;
}

#life-quality .structure ul li.double.last {
  width: 32%;
  margin-right: auto;
}

#life-quality .structure ul li.last {
  margin-right: auto;
}

#life-quality .structure ul li:nth-child(3n),
#life-quality .structure ul li:last-child {
  margin-right: auto;
}

#life-quality .structure ul .name {
  font-size: 16px;
  line-height: 1.6;
  margin: 20px auto 10px;
}

#life-quality .structure ul .info {
  text-align: left;
  font-size: 12px;
  line-height: 1.8;
}

#life-quality .structure ul .mini {
  text-align: left;
  margin-top: 3px;
  font-size: 11px;
  line-height: 1.8;
}

/* ========================================================
 lgente
======================================================== */
#lgente.lower {
  background: url(../images/lgente/bg.jpg);
  background-size: cover;
}

#lgente main {
  padding-bottom: 0;
}

#lgente main .image {
  position: relative;
}

#lgente .wrap {
  max-width: 1000px;
}

#lgente .main-visual {
  margin: 0;
}

#lgente article.contents > header {
  padding-bottom: 180rem;
  max-width: 1000px;
}

#lgente article.contents > header .lead {
  padding-bottom: 100rem;
}

#lgente article.contents .image02 {
  width: 75.2%;
}

#lgente .intro {
  text-align: center;
}

#lgente .intro .bg {
  background: url(../images/lgente/txt-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding: 2% 0;
  margin-bottom: 50px;
}

#lgente .intro .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 50px;
}

#lgente .intro .lead {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 10px;
}

#lgente .voice {
  max-width: 1260px;
  width: 94%;
  margin: 0 auto 100px;
}

#lgente .voice .caption {
  right: 2%;
  bottom: 3%;
  background: none;
  color: #968463;
}

#lgente .sections .section-title {
  color: #221706;
  font-size: 20px;
  font-weight: normal;
  line-height: 1.8;
  margin: 0 auto 20rem;
}

#lgente .sections .tit01 {
  font-size: 18px;
  margin-bottom: 10px;
}

#lgente .sections .tit02 {
  font-size: 20px;
  line-height: 1.6;
  margin-bottom: 50px;
}

#lgente .sections .lead {
  font-size: 16px;
  line-height: 2;
}

#lgente article .texts .img01 {
  max-width: 1200px;
  margin: 0 auto 100px;
}

#lgente article .texts .img00 {
  max-width: 850px;
  margin: 0 auto 200px;
}

#lgente article .texts .img02 {
  margin: 0 auto 50px;
  padding: 50px 0;
  background-color: #373021;
  text-align: center;
}

#lgente article .texts .img02 img {
  max-width: 1000px;
}

#lgente .facility {
  text-align: center;
  padding: 50px 0 0;
}

#lgente .facility .inners {
  margin-bottom: 50px;
}

#lgente .facility .inners .lead {
  margin-bottom: 30px;
}

#lgente .facility .info-img {
  max-width: 600px;
  margin: 0 auto 100px;
}

#lgente .facility .info-img .caption {
  background: none;
  bottom: -20px;
  color: #221706;
}

#lgente .facility .points {
  text-align: left;
  max-width: 1000px;
  width: 94%;
  margin: auto;
}

#lgente .facility .points li {
  vertical-align: top;
  display: inline-block;
  width: 31%;
  margin-right: 2%;
  margin-bottom: 30px;
}

#lgente .facility .points li:nth-child(3n) {
  margin-right: auto;
}

#lgente .facility .points .image {
  margin-bottom: 10px;
}

#lgente .facility .points .txt {
  text-align: center;
  font-size: 16px;
  line-height: 1.4;
  margin-bottom: 10px;
}

#lgente .facility .points .txt span {
  font-size: 12px;
}

#lgente .facility .points .info {
  font-size: 14px;
  line-height: 1.4;
}

#lgente .facility .points .mini {
  margin-top: 15px;
  font-size: 11px;
}

#lgente .facility .points.half {
  text-align: center;
}

#lgente .facility .points.half li:nth-child(2) {
  width: 35%;
  margin-right: auto;
}

#lgente .facility .points.half li {
  margin-right: 4%;
}

#lgente .facility .points.half li .info {
  text-align: left;
}

#lgente .facility .points.half li .info.mb {
  margin-bottom: 10px;
}

#lgente .facility .storage .points {
  text-align: left;
  max-width: 1100px;
  width: 94%;
  margin: auto;
}

#lgente .facility .storage .points li {
  vertical-align: top;
  display: inline-block;
  width: 29%;
  margin-right: 2%;
  padding-right: 2%;
  border-right: 1px solid;
}

#lgente .facility .storage .points li:last-child {
  margin-right: auto;
  padding-right: auto;
  border-right: none;
}

#lgente .facility .storage .points .icon {
  width: 18%;
  max-width: 60px;
  height: 60px;
  margin-right: 4%;
}

#lgente .facility .storage .points .txt {
  width: 76%;
  font-size: 16px;
  line-height: 1.4;
}

#lgente .facility .storage .points .txt span {
  font-size: 11px;
}

#lgente .facility .storage .points .txt01 {
  font-size: 13px;
  margin: 20px 0;
}

#lgente .facility .storage .points .image {
  width: 100%;
  margin: 0;
}

#lgente .facility .box {
  max-width: 1000px;
  margin: 0 auto 100px;
  background: #637A5F;
  border-radius: 30px;
  padding: 30px;
  box-sizing: border-box;
}

#lgente .facility .box li {
  text-align: left;
  display: inline-block;
  vertical-align: middle;
  width: 48%;
  margin-right: 2%;
}

#lgente .facility .box li:last-child {
  margin-right: auto;
}

#lgente .facility .box .txt {
  font-size: 20px;
  line-height: 2;
  margin-bottom: 30px;
}

#lgente .facility .box .lead {
  font-size: 13px;
  line-height: 2;
}

#lgente .sections > header {
  display: flex;
  flex-direction: column;
}

#lgente .sections > header .image {
  order: -1;
}

#lgente .sections .annotation {
  max-width: 1000px;
  padding-bottom: 20rem;
}

#lgente .sections .images {
  display: flex;
  justify-content: space-between;
  gap: 0 20rem;
  max-width: 1000px;
}

#lgente .sections .images li {
  flex: 1 1 auto;
}

#lgente .sections .images .text {
  padding-top: 10rem;
  text-align: center;
  font-size: 14rem;
  line-height: 1.3;
}

#lgente .sections .images-caption {
  max-width: 1000px;
  font-size: 11rem;
}

#lgente .section02 {
  text-align: center;
  background: rgba(61, 96, 66, 0.5);
  color: #fff;
  padding-bottom: 100px;
}

#lgente .section02 .common-title01 {
  font-size: 20px;
  font-weight: normal;
  margin-bottom: 40px;
  display: flex;
  align-items: center;
}

#lgente .section02 .common-title01:before,
#lgente .section02 .common-title01:after {
  content: "";
  height: 1px;
  flex-grow: 1;
  background-color: #fff;
}

#lgente .section02 .common-title01:before {
  margin-right: 30px;
}

#lgente .section02 .common-title01:after {
  margin-left: 30px;
}

#lgente .section02 .catch {
  font-size: 20px;
  line-height: 2;
}

#lgente .section02 .lead {
  margin: 0 auto 30px;
}

#lgente .section02 .mini {
  font-size: 11px;
  line-height: 1.8;
  margin-bottom: 40px;
}

#lgente .section03 {
  text-align: center;
  background: rgba(61, 96, 66, 0.5);
  color: #fff;
}

#lgente .section03 .common-title01 {
  font-size: 20px;
  font-weight: normal;
  margin-bottom: 40px;
  display: flex;
  align-items: center;
}

#lgente .section03 .common-title01:before,
#lgente .section03 .common-title01:after {
  content: "";
  height: 1px;
  flex-grow: 1;
  background-color: #fff;
}

#lgente .section03 .common-title01:before {
  margin-right: 30px;
}

#lgente .section03 .common-title01:after {
  margin-left: 30px;
}

#lgente .section03 .catch {
  font-size: 20px;
  line-height: 2;
}

#lgente .section03 .lead {
  margin: 0 auto 30px;
}

#lgente .section03 .mini {
  font-size: 11px;
  line-height: 1.8;
  margin-bottom: 40px;
}

#lgente .section03 .images {
  max-width: 620px;
  gap: 0 20rem;
}

#lgente .section03 .images li .text {
  font-size: 14rem;
}

@media screen and (max-width: 768px) {
  #lgente.lower {
    background: url(../images/lgente/bg-sp.jpg);
    background-size: cover;
  }
  #lgente article.contents > header {
    padding-bottom: 100rem;
  }
  #lgente article.contents > header .lead {
    padding-bottom: 60rem;
  }
  #lgente article.contents .image02 {
    width: 88%;
  }
  #lgente .intro {
    margin-bottom: 60px;
  }
  #lgente .intro .bg {
    background: url(../images/lgente/txt-bg.png);
    background-size: 80%;
    background-repeat: no-repeat;
    background-position: top;
    padding: 5% 0 0;
    margin-bottom: 80px;
  }
  #lgente .intro .bg .txt {
    text-align: left;
    font-size: 22px;
    line-height: 1.6;
    margin-bottom: 50px;
  }
  #lgente .intro .bg .lead {
    text-align: left;
    margin-bottom: 0;
    font-size: 14rem;
  }
  #lgente .voice {
    margin: 0 auto 50px;
  }
  #lgente .voice .caption {
    bottom: 2%;
    right: auto;
    left: 2%;
    line-height: 1.4;
  }
  #lgente .sections .section-title {
    text-align: left;
    margin: 0 auto 20rem;
  }
  #lgente .sections .tit01 {
    font-size: 14px;
    margin-bottom: 10px;
  }
  #lgente .sections .tit02 {
    text-align: left;
    font-size: 22px;
  }
  #lgente .sections .lead {
    text-align: left;
    margin-bottom: 50px;
  }
  #lgente article .texts .img00 {
    width: 90%;
    margin: 0 auto 80px;
  }
  #lgente article .texts .img02 {
    margin: 0 auto;
  }
  #lgente article .texts .img02 .swipe-img img {
    width: 1000px !important;
  }
  #lgente .facility {
    padding: 20px 0 0;
  }
  #lgente .facility .inners {
    margin-bottom: 0px;
  }
  #lgente .facility .inners .lead {
    margin-bottom: 50px;
  }
  #lgente .facility .lead {
    width: 94%;
    margin: 0 auto 50px;
  }
  #lgente .facility .info-img {
    margin: 0 auto;
  }
  #lgente .facility .points {
    margin-top: 50px;
  }
  #lgente .facility .points li {
    display: block;
    width: 100%;
    margin-right: 0;
    margin-bottom: 30px;
  }
  #lgente .facility .points .icon {
    width: 18%;
  }
  #lgente .facility .points .txt {
    text-align: left;
    font-size: 15px;
    line-height: 1.6;
    padding-top: 10px;
  }
  #lgente .facility .points .txt.txt01 {
    width: 90%;
  }
  #lgente .facility .points .image {
    margin: 10px auto 0;
  }
  #lgente .facility .points.half li:nth-child(2) {
    width: 100%;
    margin-right: auto;
  }
  #lgente .facility .points.half li {
    margin-right: auto;
  }
  #lgente .facility .points.half li .info {
    text-align: left;
  }
  #lgente .facility .points.half li .info.mb {
    margin-bottom: 30px;
  }
  #lgente .facility .storage .points {
    margin-top: 50px;
  }
  #lgente .facility .storage .points li {
    display: block;
    width: 100%;
    margin-right: 0;
    padding-right: 0;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-right: none;
    border-bottom: 1px solid;
  }
  #lgente .facility .storage .points li:last-child {
    border: none;
  }
  #lgente .facility .storage .points .icon {
    width: 18%;
  }
  #lgente .facility .storage .points .txt {
    width: 78%;
    font-size: 14px;
    line-height: 1.6;
  }
  #lgente .facility .storage .points .txt.txt01 {
    width: 90%;
  }
  #lgente .facility .storage .points .image {
    width: 80%;
    margin: 10px auto 0;
  }
  #lgente .facility .box {
    padding: 20px;
    box-sizing: border-box;
  }
  #lgente .facility .box li {
    width: 100%;
    margin-bottom: 20px;
  }
  #lgente .facility .box li:last-child {
    margin: auto;
  }
  #lgente .facility .box .txt {
    margin-bottom: 20px;
  }
  #lgente .facility .box .lead {
    margin: auto;
  }
  #lgente .sections > header {
    padding-bottom: 0;
  }
  #lgente .sections .annotation {
    padding-bottom: 30rem;
    text-align: left;
  }
  #lgente .section02 .lead {
    text-align: left;
    margin-bottom: 20px;
  }
  #lgente .section02 .mini {
    text-align: left;
    margin-bottom: 50px;
  }
  #lgente .section02 .images {
    display: block;
  }
  #lgente .section02 .images li {
    display: inline-block;
    vertical-align: top;
    width: 32%;
    margin-right: 1%;
    margin-bottom: 20px;
  }
  #lgente .section02 .images li:nth-child(3n) {
    margin: auto;
  }
  #lgente .section02 .images .text {
    font-size: 13rem;
  }
  #lgente .section03 .lead {
    text-align: left;
    margin-bottom: 20px;
  }
  #lgente .section03 .mini {
    text-align: left;
  }
  #lgente .section03 .images {
    gap: 0 6rem;
  }
  #lgente .section03 .swipe-img img {
    width: 640px !important;
  }
}

/* ========================================================
 access
======================================================== */
#access .image {
  position: relative;
}

#access .intro {
  text-align: center;
  margin-bottom: 150px;
}

#access .intro .bg {
  background: url(../images/access/txt-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding: 2% 0;
  margin-bottom: 50px;
}

#access .intro .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 50px;
}

#access .intro .lead {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 10px;
}

#access .intro .list {
  margin-bottom: 50px;
}

#access .intro .list li {
  float: left;
  width: 33.333%;
}

#access .intro .img04 {
  max-width: 1000px;
  margin: 0 auto 50px;
}

#access .intro .img05 {
  max-width: 1000px;
  margin: 0 auto;
}

#access .sections {
  text-align: center;
}

#access .sections .txt {
  font-size: 22px;
  line-height: 1.6;
  font-weight: normal;
  margin-bottom: 50px;
}

#access .sec01 {
  margin-bottom: 70px;
}

#access .sec01 .image {
  max-width: 1000px;
  margin: 0 auto 10px;
}

#access .sec01 .mini {
  font-size: 11px;
  line-height: 1.6;
  letter-spacing: 0;
}

#access .sec02 {
  margin-bottom: 150px;
}

#access .sec02 .lists {
  max-width: 1000px;
  margin: 0 auto 50px;
}

#access .sec02 .lists .texts {
  padding: 5% 0 0;
  width: 90%;
  margin: auto;
  color: #fff;
}

#access .sec02 .lists .texts .txt01 {
  text-align: left;
  font-size: 22px;
  line-height: 1.6;
  margin-bottom: 20px;
}

#access .sec02 .lists .texts .txt02 {
  font-size: 14px;
  line-height: 2;
  text-align: left;
  margin-bottom: 20px;
}

#access .sec02 .lists .texts .txt03 {
  font-size: 16px;
  line-height: 1.6;
  border: 1px solid;
  padding: 12px 0;
}

#access .sec02 .list01 {
  display: none;
}

#access .sec02 .list01 li {
  float: left;
  width: 59.5%;
}

#access .sec02 .list01 li:last-child {
  width: 40.5%;
}

#access .sec02 .list02 {
  background: #80705E;
  margin: 0 auto 10px;
}

#access .sec02 .list02 li {
  float: left;
  width: 50%;
}

#access .sec02 .mini {
  max-width: 1000px;
  margin: 0 auto 50px;
  text-align: right;
  font-size: 11px;
}

#access .sec02 .list03 {
  background: #80705E;
}

#access .sec02 .list03 li {
  float: left;
  width: 50%;
}

#access .sec02 .list03 .texts {
  padding: 15% 0 0;
}

/* ========================================================
 design
======================================================== */
#design .image {
  position: relative;
}

#design .intro {
  text-align: center;
  margin-bottom: 100px;
}

#design .intro .bg {
  background: url(../images/design/txt-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding: 2% 0;
  margin-bottom: 50px;
}

#design .intro .inner {
  padding: 40px 3%;
  box-sizing: border-box;
}

#design .intro .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 50px;
}

#design .intro .lead {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 10px;
}

#design .intro .img01 {
  max-width: 1000px;
  margin: 0 auto 100px;
}

#design .intro .list {
  max-width: 1000px;
  margin: 0 auto 100px;
}

#design .intro .list li {
  display: inline-block;
  vertical-align: top;
  width: 50%;
  margin-right: 4%;
}

#design .intro .list li:last-child {
  width: 44%;
  margin: auto;
}

#design .intro .list .txt01 {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: .5px solid;
}

#design .intro .list .txt02 {
  text-align: left;
  font-size: 14px;
  line-height: 2;
}

#design .intro .box {
  background: rgba(159, 149, 136, 0.25);
  max-width: 1000px;
  margin: auto;
}

#design .intro .box .imgs li {
  display: inline-block;
  width: 54%;
  vertical-align: top;
  margin-right: 4%;
  text-align: left;
}

#design .intro .box .imgs li:last-child {
  width: 36%;
  margin: auto;
}

#design .intro .box .imgs .obi {
  font-size: 13px;
  padding: 10px 0;
  color: #fff;
  background: #604C3F;
  margin-bottom: 20px;
  text-align: center;
}

#design .landplan {
  text-align: center;
  background: rgba(159, 149, 136, 0.25);
  padding: 100px 0;
}

#design .landplan .tit {
  font-size: 26px;
  font-weight: normal;
  margin-bottom: 20px;
}

#design .landplan .copy {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 80px;
}

#design .landplan .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: .5px solid;
  display: inline-block;
}

#design .landplan .lead {
  font-size: 14px;
  margin-bottom: 60px;
}

#design .landplan .imgs {
  text-align: left;
  max-width: 790px;
  margin: 0 auto 80px;
  display: flex;
  flex-wrap: wrap;
}

#design .landplan .imgs li {
  width: 31%;
  margin-right: 2%;
  margin-bottom: 20px;
}

#design .landplan .imgs .name {
  text-align: center;
  font-size: 11px;
  color: #fff;
  padding: 10px 0;
  background: #3C2903;
}

#design .landplan .imgs .name span {
  font-size: 75%;
}

#design .landplan .box {
  position: relative;
  max-width: 1000px;
  margin: auto;
  width: 100%;
  padding-block: 30px;
  border: 1px solid #221706;
}

#design .landplan .box::before {
  content: "";
  position: absolute;
  top: -6px;
  bottom: -6px;
  left: -6px;
  right: -6px;
  border: 2px solid #221706;
}

#design .landplan .box .texts, #design .landplan .box .images {
  display: inline-block;
  vertical-align: top;
}

#design .landplan .box .texts {
  text-align: left;
  width: 26%;
  margin-right: 4%;
}

#design .landplan .box .texts .txt01 {
  font-size: 16px;
  margin-bottom: 20px;
}

#design .landplan .box .texts .txt02 {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 20px;
}

#design .landplan .box .texts .txt03 {
  font-size: 11px;
  line-height: 1.8;
}

#design .landplan .box .images {
  width: 65%;
}

#design .landplan .box .images li {
  display: inline-block;
  vertical-align: top;
  width: 23%;
  margin-right: 2%;
  margin-bottom: 10px;
}

#design .landplan .box .images li:nth-child(4n) {
  margin: auto;
}

/* ========================================================
 plan
======================================================== */
#plan .image {
  position: relative;
}

#plan .intro {
  text-align: center;
  margin-bottom: 100px;
}

#plan .intro .bg {
  background: url(../images/plan/txt-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding: 2% 0;
  margin-bottom: 50px;
}

#plan .intro .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 50px;
}

#plan .intro .lead {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 10px;
}

#plan .intro .list {
  max-width: 1000px;
  margin: 0 auto 50px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}

#plan .intro .list li {
  width: 48%;
  margin-bottom: 50px;
}

#plan .intro .list .txt01 {
  font-size: 22px;
  line-height: 1.6;
  margin: 20px auto 10px;
}

#plan .intro .list .txt02 {
  font-size: 14px;
  line-height: 1.8;
  letter-spacing: 0;
}

#plan .intro .storage {
  background: #fff;
  padding: 40px 0;
  max-width: 1000px;
  margin: auto;
}

#plan .intro .storage ul {
  width: 94%;
  margin: auto;
}

#plan .intro .storage ul li {
  text-align: left;
  display: inline-block;
  vertical-align: top;
  width: 54%;
  margin-right: 2%;
}

#plan .intro .storage ul li:nth-child(2) {
  width: 21%;
  margin-right: 1%;
}

#plan .intro .storage ul li:last-child {
  width: 21%;
  margin: auto;
}

#plan .intro .storage ul .tit {
  font-size: 26px;
  margin-bottom: 20px;
}

#plan .intro .storage ul .copy {
  font-size: 22px;
  line-height: 1.6;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: .5px solid;
}

#plan .intro .storage ul .info {
  font-size: 14px;
  line-height: 2;
}

#plan .plan-btns {
  text-align: center;
  background: rgba(159, 149, 136, 0.25);
  padding: 100px 0;
}

#plan .plan-btns .txt {
  font-size: 24px;
  line-height: 1.6;
  font-weight: normal;
  margin-bottom: 100px;
}

#plan .plan-btns .btn-list {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

#plan .plan-btns .btn-list li {
  background: #fff;
  padding: 40px 0 30px;
}

#plan .plan-btns .btn-list .texts {
  width: 60%;
  margin: 0 auto 20px;
}

#plan .plan-btns .btn-list .type {
  font-size: 16px;
}

#plan .plan-btns .btn-list .type span {
  font-size: 40px;
}

#plan .plan-btns .btn-list .spec {
  font-size: 22px;
  margin: 8px auto 10px;
  padding-top: 8px;
  border-top: .5px solid;
}

#plan .plan-btns .btn-list .spec .big {
  font-size: 28px;
}

#plan .plan-btns .btn-list .width {
  font-size: 14px;
}

#plan .plan-btns .btn-list .width span {
  font-size: 22px;
  font-family: 'Cinzel', serif;
}

#plan .plan-btns .btn-list .image {
  width: 90%;
  margin: auto;
}

#plan .plan-btns .btn-list .button {
  width: 90%;
  margin: 14px auto 0;
}

#plan .plan-btns .btn-list.list01 {
  max-width: 700px;
  margin: 0 auto 50px;
}

#plan .plan-btns .btn-list.list01 li {
  width: 48%;
}

#plan .plan-btns .btn-list.list02 {
  max-width: 1080px;
  margin: 0 auto;
}

#plan .plan-btns .btn-list.list02 li {
  width: 32%;
}

#plan .plan-btns .btn-list.list02 .width {
  -ms-filter: blur(10px);
  filter: blur(10px);
}

#plan .plan-btns .casbee {
  max-width: 300px;
  margin: 80px auto 0;
}

/* ========================================================
 plan.detail
======================================================== */
#plan.detail .plans {
  text-align: center;
  padding-bottom: 100px;
}

#plan.detail .plans .type {
  font-size: 34px;
  margin-bottom: 20px;
}

#plan.detail .plans .type span {
  font-size: 60px;
}

#plan.detail .plans .spec {
  font-size: 25px;
  margin-bottom: 20px;
}

#plan.detail .plans .spec span {
  font-size: 30px;
}

#plan.detail .plans .width {
  font-size: 16px;
  margin-bottom: 10px;
}

#plan.detail .plans .width span {
  font-size: 26px;
}

#plan.detail .plans .balcony {
  font-size: 12px;
}

#plan.detail .plans .txt {
  font-size: 24px;
  line-height: 1.6;
  margin: 80px auto 100px;
}

#plan.detail .plans .tab-inner {
  display: none;
}

#plan.detail .plans .tab-inner.current {
  display: block;
}

#plan.detail .plans .change-buttons {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 80px;
}

#plan.detail .plans .change-buttons li {
  text-align: center;
  display: inline-block;
  width: 48%;
  margin-right: 2%;
}

#plan.detail .plans .change-buttons li:last-child {
  margin-right: 0;
}

#plan.detail .plans .change-buttons .button {
  display: block;
  font-size: 16px;
  background: #fff;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.16);
  border-radius: 3px;
}

#plan.detail .plans .change-buttons .button.current {
  pointer-events: none;
  color: #fff;
  background: #3C2903;
}

#plan.detail .plans .change-buttons .button span {
  display: inline-block;
  padding: 14px 0;
}

#plan.detail .plans .change-buttons .button:hover {
  opacity: 1;
  color: #fff;
  background: #3C2903;
  transition: .3s;
}

#plan.detail .plans .rooms {
  max-width: 1100px;
  margin: auto;
}

#plan.detail .plans .rooms li {
  display: inline-block;
  vertical-align: top;
  width: 66%;
  width: 56%;
  margin-right: 5%;
}

#plan.detail .plans .rooms li .guide {
  max-width: 380px;
  width: 90%;
  margin: 30px auto 0;
}

#plan.detail .plans .rooms li:last-child {
  width: 31%;
}

#plan.detail .plans .rooms .points {
  margin-bottom: 40px;
}

#plan.detail .plans .rooms .points .num {
  position: absolute;
  top: 0;
  left: 0;
  font-size: 24px;
  color: #fff;
  background: #000;
  padding: 2px 8px 5px;
}

#plan.detail .plans .rooms .points .name {
  font-size: 18px;
  background: #80705E;
  padding: 10px 0;
  color: #fff;
  margin-bottom: 20px;
}

#plan.detail .plans .rooms .points .info {
  text-align: left;
  font-size: 14px;
  line-height: 2;
}

#plan.detail .plans .rooms .point03 {
  margin: 0 auto;
}

#plan.detail .plan-btns.normal .btn-list {
  justify-content: center;
}

/* ========================================================
 position
======================================================== */
#position .image {
  position: relative;
}

#position .intro {
  text-align: center;
  margin-bottom: 150px;
}

#position .intro .bg {
  background: url(../images/position/txt-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding: 2% 0;
  margin-bottom: 50px;
}

#position .intro .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 50px;
}

#position .intro .lead {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 10px;
}

#position .intro .box {
  background: #373022;
  padding: 60px 0;
}

#position .intro .box ul {
  max-width: 1000px;
  margin: auto;
  color: #fff;
  text-align: center;
}

#position .intro .box ul li {
  display: block;
  vertical-align: top;
  width: 100%;
  margin-right: 4%;
}

#position .intro .box ul li:last-child {
  width: 100%;
  margin: auto;
}

#position .intro .box ul .txt01 {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: .5px solid;
  display: inline-block;
}

#position .intro .box ul .txt02 {
  font-size: 16px;
  line-height: 2.4;
}

#position .intro .box ul .mini {
  text-align: right;
  font-size: 10px;
  line-height: 1.6;
  margin-top: 10px;
}

#position .sections {
  text-align: center;
  margin-bottom: 100px;
}

#position .sections .wrap {
  max-width: 1000px;
  margin: 0 auto;
}

#position .sections .tit {
  margin-bottom: 80px;
}

#position .sections .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 40px;
}

#position .sections .lead {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 60px;
}

#position .sec01 ul {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

#position .sec01 ul li {
  width: 48%;
}

#position .sec01 ul .caps {
  text-align: right;
  margin-top: 10px;
  font-size: 11px;
  line-height: 1.6;
}

#position .sec01 ul .txt01 {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: .5px solid;
}

#position .sec01 ul .txt02 {
  text-align: left;
  font-size: 14px;
  line-height: 2.6;
}

#position .sec02 .img01 {
  max-width: 580px;
  margin: 0 auto 40px;
}

#position .sec02 .img02 {
  max-width: 1000px;
  margin: auto;
}

#position .sec03 .img01 {
  max-width: 500px;
  margin: 0 auto 10px;
}

#position .sec03 .img02 {
  max-width: 468px;
  margin: 30px auto 0;
}

/* ========================================================
 limited
======================================================== */
#limited main {
  text-align: center;
  padding: 223rem 0 100rem;
}

#limited .page-title {
  font-size: 40rem;
  line-height: 1.3;
  font-weight: normal;
  padding-bottom: 9rem;
}

#limited .pageTitle {
  text-align: center;
  padding-bottom: 105rem;
}

#limited .pageTitle .ja {
  font-size: 14rem;
  line-height: 1.3;
  font-weight: normal;
}

#limited .btn-lists {
  text-align: center;
  max-width: 830px;
  margin: 0 auto;
}

#limited .btn-lists li {
  display: inline-block;
  vertical-align: top;
  width: 47%;
  margin-right: 5%;
  box-shadow: 0 3px 20px rgba(0, 0, 0, 0.16);
  background: #80705E;
  color: #fff;
}

#limited .btn-lists li:last-child {
  margin-right: auto;
}

#limited .btn-lists .texts {
  padding: 30px 0 40px;
  color: #fff;
}

#limited .btn-lists .texts .name {
  font-size: 22px;
  background: #3C2903;
  border-radius: 22px;
  padding: 7px 0;
  max-width: 280px;
  margin: 0 auto 15px;
}

#limited .btn-lists .texts .info {
  font-size: 14px;
  line-height: 2;
}

/* ========================================================
 limited.plan
======================================================== */
#limited.plan main {
  text-align: center;
  padding: 223rem 0 100rem;
}

#limited.plan .page-title {
  font-size: 40rem;
  line-height: 1.3;
  font-weight: normal;
  padding-bottom: 9rem;
}

#limited.plan .pageTitle {
  text-align: center;
  padding-bottom: 105rem;
}

#limited.plan .pageTitle .ja {
  font-size: 14rem;
  line-height: 1.3;
  font-weight: normal;
}

#limited.plan .plan-btns .box {
  width: 90%;
  font-size: 18px;
  background: #80705E;
  color: #fff;
  padding: 10px 0;
  margin: 0 auto 30px;
}

#limited.plan .plan-btns .txt {
  font-size: 24px;
  line-height: 1.6;
  font-weight: normal;
  margin-bottom: 100px;
}

#limited.plan .plan-btns .btn-list {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

#limited.plan .plan-btns .btn-list li {
  background: #fff;
  padding: 40px 0 30px;
}

#limited.plan .plan-btns .btn-list .texts {
  width: 60%;
  margin: 0 auto 20px;
}

#limited.plan .plan-btns .btn-list .type {
  font-size: 16px;
}

#limited.plan .plan-btns .btn-list .type span {
  font-size: 40px;
}

#limited.plan .plan-btns .btn-list .spec {
  font-size: 22px;
  margin: 8px auto 10px;
  padding-top: 8px;
  border-top: .5px solid;
}

#limited.plan .plan-btns .btn-list .spec .big {
  font-size: 28px;
}

#limited.plan .plan-btns .btn-list .width {
  font-size: 14px;
}

#limited.plan .plan-btns .btn-list .width span {
  font-size: 22px;
  font-family: 'Cinzel', serif;
}

#limited.plan .plan-btns .btn-list .image {
  width: 90%;
  margin: auto;
}

#limited.plan .plan-btns .btn-list .button {
  width: 90%;
  margin: 14px auto 0;
}

#limited.plan .plan-btns .btn-list.list01 {
  max-width: 700px;
  margin: 0 auto 50px;
}

#limited.plan .plan-btns .btn-list.list01 li {
  width: 48%;
}

#limited.plan .plan-btns .btn-list.list02 {
  max-width: 1080px;
  margin: 0 auto;
}

#limited.plan .plan-btns .btn-list.list02 li {
  width: 32%;
}

/* ========================================================
 special
======================================================== */
#special.lower {
  background: #fff;
  background-size: cover;
}

#special.lower .mv {
  margin-bottom: 120rem;
}

#special.lower .image {
  position: relative;
}

#special .intro {
  text-align: center;
  margin-bottom: 120px;
}

#special .intro .tit {
  max-width: 518px;
  margin: 0 auto 40px;
}

#special .intro .txt {
  font-size: 24px;
  line-height: 1.6;
}

#special .areas {
  text-align: center;
  margin-bottom: 100px;
}

#special .areas .wrap {
  max-width: 1000px;
}

#special .areas .area00 {
  margin-bottom: 150px;
}

#special .areas .area00 .caption.top {
  bottom: auto;
  top: 0;
}

#special .areas .area00 .icon {
  max-width: 28px;
  margin: 0 auto 10px;
}

#special .areas .area00 .title {
  font-size: 30px;
  color: #547BA8;
  font-weight: normal;
  margin-bottom: 10px;
}

#special .areas .area00 .sub {
  font-size: 14px;
  color: #547BA8;
  margin-bottom: 24px;
}

#special .areas .area00 .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 30px;
}

#special .areas .area00 .lead {
  font-size: 16px;
  line-height: 2;
  margin-bottom: 80px;
}

#special .areas .area00 .img01 {
  max-width: 900px;
  margin: auto;
}

#special .areas .area-wrap {
  max-width: 1100px;
  margin: auto;
}

#special .areas .area-inner .slide .slick-dots {
  bottom: -25px !important;
}

#special .areas .area-inner .slide .slick-dots li {
  width: 0% !important;
}

#special .areas .area-inner .slide .slick-dots li button {
  background: #E4E5ED !important;
  border-radius: 50px;
  width: 12px !important;
  height: 12px !important;
}

#special .areas .area-inner .slide .slick-dots li.slick-active button {
  background: #729ED5 !important;
}

#special .areas .area-inner .slide .slick-dots li button:before {
  color: transparent;
}

#special .areas .area-inner .texts {
  text-align: left;
}

#special .areas .area-inner .texts .num {
  max-width: 178px;
  margin: 0;
}

#special .areas .area-inner .texts .area-name {
  font-size: 30px;
  letter-spacing: 0.08em;
  color: #547BA8;
  margin: -20px 0 10px;
}

#special .areas .area-inner .texts .txt01 {
  font-size: 20px;
  line-height: 1.6;
  color: #547BA8;
  margin-bottom: 20px;
}

#special .areas .area-inner .texts .txt02 {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 20px;
}

#special .areas .area-inner .texts .caps {
  font-size: 11px;
  line-height: 1.8;
}

#special .areas .area01, #special .areas .area03 {
  max-width: 1000px;
  margin: 0 auto 100px 0;
}

#special .areas .area01 .list li, #special .areas .area03 .list li {
  display: inline-block;
  vertical-align: middle;
  width: 60%;
  margin-right: 5%;
}

#special .areas .area01 .list li:last-child, #special .areas .area03 .list li:last-child {
  width: 34%;
  margin: auto;
}

#special .areas .area02, #special .areas .area04 {
  max-width: 1000px;
  margin: 0 0 100px auto;
}

#special .areas .area02 .list li, #special .areas .area04 .list li {
  display: inline-block;
  vertical-align: middle;
  width: 34%;
  margin-right: 5%;
}

#special .areas .area02 .list li:last-child, #special .areas .area04 .list li:last-child {
  width: 60%;
  margin: auto;
}

#special .accordion dl {
  position: relative;
}

#special .accordion dt {
  position: relative;
}

#special .accordion dt .img00 {
  overflow: hidden;
  height: 13vh;
  z-index: 1;
}

#special .accordion dt .texts, #special .accordion dd .texts {
  position: absolute;
  top: 40px;
  right: 0;
  left: 0;
  width: 90%;
  max-width: 1200px;
  margin: auto;
  display: flex;
  justify-content: space-between;
}

#special .accordion dt .texts li, #special .accordion dd .texts li {
  width: 95%;
}

#special .accordion dt .texts li:last-child, #special .accordion dd .texts li:last-child {
  width: 2.5%;
}

#special .accordion dt .texts .tit, #special .accordion dd .texts .tit {
  color: #fff;
  font-size: 18px;
}

#special .accordion dt .texts .tit img, #special .accordion dd .texts .tit img {
  width: 28px;
  vertical-align: middle;
  padding-bottom: 10px;
}

#special .accordion dt .texts .tit .Cinzel, #special .accordion dd .texts .tit .Cinzel {
  font-size: 30px;
  padding-left: 10px;
}

#special .accordion dt .texts .tit .new, #special .accordion dd .texts .tit .new {
  font-size: 14px;
  background: #C31E1E;
  padding: 3px 10px;
  box-sizing: border-box;
  margin-right: 20px;
}

#special .accordion dt .texts .arrow, #special .accordion dd .texts .arrow {
  animation: scroll 2s infinite;
}

@keyframes scroll {
  0% {
    opacity: 0;
    transform: translateY(-20px);
  }
  40% {
    opacity: 1;
  }
  80% {
    opacity: 0;
    transform: translateY(5px);
  }
  100% {
    opacity: 0;
  }
}

#special .accordion dd {
  box-sizing: border-box;
  display: none;
  margin-top: -10vh;
}

#special .accordion dd .back {
  position: absolute;
  top: 0;
  z-index: 2;
}

#special .accordion dd .inner-box {
  text-align: center;
  padding: 32% 0 120px;
  max-width: 900px;
  margin: auto;
}

#special .accordion dd .txt {
  font-size: 24px;
  line-height: 1.6;
  margin-bottom: 30px;
}

#special .accordion dd .lead {
  font-size: 16px;
  line-height: 2;
  margin-bottom: 80px;
}

#special .accordion dd .buttons {
  max-width: 60px;
  margin: 80px auto 0;
}

#special .accordion dd.on {
  display: block;
}

#special .accordion .pull01 {
  background: #609DBF;
}

#special .accordion .pull01 dd {
  color: #fff;
}

#special .accordion .pull01 .fukidashi01 {
  max-width: 176px;
  position: absolute;
  top: -50%;
  right: 0;
}

#special .accordion .pull01 .bottom {
  background: none;
}

#special .accordion .pull01 .img02 {
  margin: 40px auto;
}

#special .accordion .pull02 .inner-box {
  max-width: 1200px;
}

#special .accordion .pull02 .img01 .mini {
  font-size: 10rem;
  padding-top: 10px;
  line-height: 1.4;
  text-align: left;
}

#special .accordion .pull02 .img02 {
  max-width: 920px;
  margin: 60px auto 0;
  padding-left: 50px;
}

#special .accordion .pull03 {
  background: #EAEFF9;
}

#special .accordion .pull03 .lists {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

#special .accordion .pull03 .lists li {
  width: 48%;
  margin-bottom: 30px;
}

#special .accordion .pull03 .fukidashi02, #special .accordion .pull03 .fukidashi04 {
  max-width: 176px;
  position: absolute;
  top: -16%;
  right: -10%;
}

#special .accordion .pull03 .fukidashi03 {
  max-width: 176px;
  position: absolute;
  top: -16%;
  left: -10%;
}

#special .accordion .pull03 .name {
  text-align: left;
  font-size: 16px;
  margin: 10px 0;
}

#special .accordion .pull03 .name span {
  background: #0068B7;
  border-radius: 50px;
  color: #fff;
  padding: 0 7px 1px;
  margin-right: 10px;
}

#special .accordion .pull03 .info {
  text-align: left;
  font-size: 14px;
  line-height: 1.8;
}

#special .accordion .pull03 .buttons {
  margin: 50px auto 0;
}

#special .accordion .pull04 .lists {
  display: flex;
  justify-content: space-between;
}

#special .accordion .pull04 .lists li {
  width: 56%;
  margin-right: 2%;
}

#special .accordion .pull04 .lists li:last-child {
  margin-right: auto;
}

#special .accordion .pull04 .fukidashi05 {
  max-width: 176px;
  position: absolute;
  top: -16%;
  left: -10%;
}

#special .accordion .pull04 .fukidashi06 {
  max-width: 176px;
  position: absolute;
  top: -16%;
  right: -10%;
}

#special .accordion .pull04 .name {
  text-align: left;
  font-size: 16px;
  margin: 20px 0 10px;
}

#special .accordion .pull04 .name span {
  background: #0068B7;
  color: #fff;
  padding: 2px 4px;
  box-sizing: border-box;
  margin-right: 10px;
}

#special .accordion .pull04 .info {
  text-align: left;
  font-size: 14px;
  line-height: 1.8;
}

#special .accordion .pull05 .lovers {
  margin-bottom: 80px;
}

#special .accordion .pull05 .lovers .inner-tit {
  max-width: 145px;
  margin: 0 auto 50px;
}

#special .accordion .pull05 .lists {
  display: flex;
  justify-content: space-between;
}

#special .accordion .pull05 .lists li {
  text-align: left;
  width: 46%;
}

#special .accordion .pull05 .lists li:last-child {
  text-align: left;
  width: 49%;
}

#special .accordion .pull05 .lists .txt01 {
  font-size: 20px;
  line-height: 1.8;
  color: #2D739A;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid;
}

#special .accordion .pull05 .lists .txt02 {
  font-size: 12px;
  line-height: 1.6;
  letter-spacing: 0;
  color: #2D739A;
  margin-bottom: 30px;
}

#special .accordion .pull05 .lists .txt02 span {
  font-size: 16px;
  letter-spacing: 0;
}

#special .accordion .pull05 .lists .txt03 {
  font-size: 14px;
  line-height: 2.2;
  margin-bottom: 30px;
}

#special .accordion .pull05 .list02 li {
  text-align: left;
  width: 49%;
}

#special .accordion .pull05 .list02 li:last-child {
  text-align: left;
  width: 45%;
}

#special .accordion .pull06 .img01 {
  margin-bottom: 80px;
}

#special .accordion .pull06 .img01 .caption {
  right: 3.8%;
}

#special .accordion .pull06 .lists {
  display: flex;
  justify-content: space-between;
  margin-bottom: 80px;
}

#special .accordion .pull06 .lists li {
  position: relative;
  text-align: left;
  width: 48%;
  color: #2D739A;
}

#special .accordion .pull06 .lists .num {
  max-width: 40px;
  margin: 0 0 10px;
}

#special .accordion .pull06 .lists .name {
  font-size: 18px;
  margin-bottom: 10px;
}

#special .accordion .pull06 .lists .min {
  font-size: 11px;
  line-height: 1.8;
  margin-bottom: 20px;
}

#special .accordion .pull06 .lists .info {
  font-size: 14px;
  line-height: 1.6;
  border-bottom: 1px solid;
  border-top: 1px solid;
  padding: 10px 0;
  margin-bottom: 20px;
}

#special .accordion .pull06 .lists .dates {
  display: flex;
}

#special .accordion .pull06 .lists .dates .img {
  margin-right: 20px;
}

#special .accordion .pull06 .lists .dates .date {
  font-size: 12px;
  line-height: 2;
}

#special .accordion .pull06 .list02 .fukidashi {
  max-width: 140px;
  position: absolute;
  top: -6%;
  right: -4%;
}

#special .accordion .pull06 .list02 .dates .img {
  width: 32%;
  margin-right: 20px;
}

#special .accordion .pull06 .img05 {
  max-width: 800px;
  margin: auto;
}

#special .accordion .pull07 {
  background: #7B9ACF;
}

#special .accordion .pull07 dd {
  color: #fff;
}

#special .accordion .pull07 .img01 .mini {
  max-width: 218px;
  text-align: left;
  font-size: 12px;
  line-height: 1.6;
  position: absolute;
  right: -12%;
  bottom: -8%;
}

#special #fixed a {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none;
  transition: all 0.3s;
}

#special #fixed {
  position: fixed;
  bottom: 670px;
  right: -230px;
  z-index: 10000;
  opacity: 1;
  transform: translateY(300px);
  transition: 0.5s ease;
}

#special #fixed:hover {
  right: 0;
  transition: 0.5s ease;
}

#special #fixed:hover .shiny-btn::before {
  display: none;
}

#special #fixed a:hover {
  opacity: 1;
}

#special #fixed .shiny-btn {
  display: block;
  position: relative;
  text-align: center;
  overflow: hidden;
}

#special #fixed .shiny-btn::before {
  position: absolute;
  content: "";
  display: inline-block;
  top: -30px;
  left: -30px;
  width: 10px;
  height: 100%;
  border-radius: 15px;
  background-color: rgba(255, 255, 255, 0.8);
  transition: .3s;
  animation: shiny-btn 3s ease-in-out infinite;
  z-index: 100001;
}

#special .fixed_bnr {
  max-width: 300px;
}

@media screen and (max-width: 768px) {
  .lower {
    background: url(../images/common/lower-bg-sp.jpg);
    background-size: cover;
  }
  .lower .site-header {
    position: fixed;
  }
  .lower main {
    padding-top: 112rem;
  }
  .lower .swipe-box {
    padding-bottom: 15rem;
    overflow-x: auto;
  }
  .lower .caption.noBg {
    color: #000;
    background: none;
  }
  .lower .swipeArea {
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .lower .swipeArea::-webkit-scrollbar {
    display: none;
  }
  .lower .swipeArea:after {
    content: '';
    display: block;
    position: sticky;
    right: 0;
    bottom: 0;
    left: 0;
    margin-top: 15rem;
    height: 57rem;
    background: url(../images/common/icon_swipe.png) no-repeat center center;
    background-size: auto 100%;
  }
  .lower .swipeArea .caption {
    position: sticky;
    left: 0;
    padding: 0 3rem 0 0;
    text-align: right;
  }
  .lower .mv {
    margin-bottom: 160rem;
  }
  .lower .mv .mv-texts {
    margin-top: 25rem;
  }
  .lower .mv .mv-texts .page-title {
    font-size: 30rem;
  }
  .lower .mv .mv-texts .ja {
    font-size: 12rem;
  }
  .lower .mv .mv-texts::after {
    margin-top: 7rem;
  }
  .lower .mv.on .mv-texts::after {
    height: 40rem;
  }
  /*----------------
map
----------------*/
  #map .maps {
    padding-bottom: 80rem;
  }
  #map .maps .map-title {
    font-size: 20rem;
    padding-bottom: 20rem;
  }
  #map .maps .links {
    width: auto;
    display: block;
    padding-top: 20rem;
  }
  #map .maps .links li {
    width: auto;
  }
  #map .maps .links li a {
    font-size: 16rem;
  }
  #map .salon {
    padding: 60rem 0 60rem;
  }
  #map .salon .wrap {
    width: 84%;
  }
  #map .salon .title {
    line-height: 1.8;
    text-align: left;
    padding-bottom: 30rem;
  }
  #map .salon .box {
    display: block;
  }
  #map .salon .box .images {
    width: auto;
    margin-bottom: 25rem;
  }
  #map .salon .box .texts {
    width: auto;
  }
  #map .salon .box dl {
    display: block;
    text-align: center;
    padding-bottom: 15rem;
    margin-bottom: 20rem;
  }
  #map .salon .box dl + dl {
    padding-top: 0rem;
  }
  #map .salon .box dt {
    width: auto;
    font-size: 16rem;
    padding-bottom: 20rem;
  }
  #map .salon .box .txt01 {
    padding-bottom: 10rem;
    font-size: 16rem;
    line-height: 2;
  }
  #map .salon .box li {
    font-size: 14rem;
    line-height: 2.2;
  }
  /* ========================================================
 brand
======================================================== */
  #brand .movie video {
    width: 100vw;
  }
  #brand .intro {
    padding-top: 60px;
    margin-bottom: 80px;
  }
  #brand .intro .sub {
    margin-bottom: 50px;
  }
  #brand .intro .image {
    max-width: 203px;
    margin: 0 auto 50px;
  }
  #brand .intro .txt01 {
    font-size: 34px;
    margin-bottom: 50px;
  }
  #brand .intro .txt02 {
    font-size: 22px;
  }
  #brand .slick-slider {
    margin-bottom: 80px;
  }
  #brand .promise {
    margin-bottom: 80px;
  }
  #brand .promise .tit {
    font-size: 22px;
  }
  #brand .promise .sub {
    margin-bottom: 50px;
  }
  #brand .promise .lists {
    padding-top: 30px;
  }
  #brand .promise .lists li {
    display: block;
    width: 86%;
    margin: 0 auto 30px;
  }
  #brand .promise .lists li:last-child {
    width: 100%;
  }
  #brand .promise .lists .txt01 {
    font-size: 22px;
  }
  #brand .promise .lists .txt02 {
    font-size: 16px;
    margin-bottom: 20px;
  }
  #brand .promise .lists .lead {
    width: 100%;
    margin: auto;
    font-size: 14px;
    line-height: 1.8;
  }
  #brand .promise .list04 {
    margin-bottom: auto;
  }
  #brand .salon {
    margin-bottom: 100px;
  }
  #brand .salon .tit {
    font-size: 22px;
  }
  #brand .salon .lead {
    text-align: left;
    font-size: 16px;
    line-height: 1.8;
    margin: 50px auto;
  }
  #brand .cafe {
    margin-bottom: 100px;
  }
  #brand .cafe .tit {
    font-size: 22px;
    margin-bottom: 50px;
  }
  #brand .cafe .lead {
    text-align: left;
    font-size: 16px;
    line-height: 1.8;
    margin: 0 auto 50px;
  }
  #brand .cafe .img02 {
    margin: 50px auto 0;
  }
  #brand .achievement {
    padding: 60px 0;
    margin-bottom: 100px;
  }
  #brand .achievement li {
    display: block;
    width: 100%;
  }
  #brand .achievement li:last-child {
    margin-top: 20px;
  }
  #brand .ginza .logo {
    max-width: 280px;
    margin: 0 auto 50px;
  }
  #brand .ginza li {
    display: block;
    width: 100%;
  }
  #brand .ginza li:last-child {
    width: 90%;
    margin: 50px auto 0;
  }
  #brand .ginza .img04 {
    margin: 50px 0 30px 3%;
  }
  #brand .ginza .sns {
    max-width: 74px;
    margin: 50px auto 0;
  }
  /*----------------
life-quality
----------------*/
  #life-quality.lower {
    background: url(../images/life-quality/bg-sp.jpg);
    background-size: cover;
  }
  #life-quality .intro {
    text-align: left;
  }
  #life-quality .intro .bg {
    background: url(../images/life-quality/txt-bg.png);
    background-size: 80%;
    background-repeat: no-repeat;
    background-position: top;
    padding: 5% 0 0;
    margin-bottom: 80px;
  }
  #life-quality .intro .bg .txt {
    text-align: left;
    font-size: 22px;
    line-height: 1.6;
    margin-bottom: 50px;
  }
  #life-quality .intro .bg .lead {
    text-align: left;
    margin-bottom: 0;
  }
  #life-quality .intro .txt {
    margin-bottom: 30px;
  }
  #life-quality .intro .lead {
    font-size: 14px;
    padding-bottom: 0px;
  }
  #life-quality .intro .buttons {
    width: 90%;
    margin: 50px auto 0;
  }
  #life-quality .intro .buttons li {
    width: 48%;
    margin-bottom: 10px;
  }
  #life-quality .intro .buttons li:nth-child(2n),
  #life-quality .intro .buttons li:last-child {
    margin: auto;
  }
  #life-quality .equipment {
    padding: 60px 0 0;
  }
  #life-quality .equipment .tit {
    text-align: left;
    margin-bottom: 40px;
  }
  #life-quality .equipment .txt {
    text-align: left;
    margin-bottom: 20px;
  }
  #life-quality .equipment ul {
    max-width: 838px;
    margin: 0 auto 60px;
  }
  #life-quality .equipment ul li {
    width: 100%;
    margin-bottom: 40px;
  }
  #life-quality .equipment ul li.double {
    width: 100%;
  }
  #life-quality .equipment ul li:last-child {
    margin: auto;
  }
  #life-quality .equipment ul .name {
    text-align: left;
  }
  #life-quality .equipment ul.half li:nth-child(2) {
    width: 100%;
    margin-right: auto;
  }
  #life-quality .equipment ul.half li {
    margin-right: auto;
  }
  #life-quality .equipment ul.half li .info {
    text-align: left;
  }
  #life-quality .equipment ul.half li .info.mb {
    margin-bottom: 30px;
  }
  #life-quality .amenity {
    padding: 60px 0;
  }
  #life-quality .amenity .tit {
    text-align: left;
    margin-bottom: 20px;
  }
  #life-quality .amenity .txt {
    text-align: left;
  }
  #life-quality .amenity ul {
    max-width: 838px;
    margin: 0 auto;
  }
  #life-quality .amenity ul li {
    width: 100%;
    margin-bottom: 40px;
  }
  #life-quality .amenity ul li.double {
    width: 100%;
  }
  #life-quality .amenity ul li:last-child {
    margin: auto;
  }
  #life-quality .amenity ul .name {
    text-align: left;
  }
  #life-quality .safety {
    padding: 60px 0;
  }
  #life-quality .safety .tit {
    text-align: left;
    margin-bottom: 20px;
  }
  #life-quality .safety .txt {
    text-align: left;
  }
  #life-quality .safety ul {
    max-width: 838px;
    margin: 0 auto;
  }
  #life-quality .safety ul li {
    width: 100%;
    margin-bottom: 40px;
  }
  #life-quality .safety ul li.two {
    width: 100%;
  }
  #life-quality .safety ul li.one {
    margin-right: auto;
  }
  #life-quality .safety ul li:last-child {
    margin: auto;
  }
  #life-quality .safety ul .name {
    text-align: left;
  }
  #life-quality .safety ul.full .info {
    margin-bottom: 40px;
  }
  #life-quality .safety ul.full .image {
    position: relative;
    margin: 0 auto 0;
    width: 90%;
    overflow: auto;
    padding: 10rem 0;
  }
  #life-quality .safety ul.full .image img {
    max-width: 1000px;
    width: 190vw;
  }
  #life-quality .structure {
    padding: 60px 0;
  }
  #life-quality .structure .tit {
    text-align: left;
    margin-bottom: 30px;
  }
  #life-quality .structure .txt {
    text-align: left;
  }
  #life-quality .structure ul {
    max-width: 838px;
    margin: 0 auto;
  }
  #life-quality .structure ul li {
    width: 100%;
    margin-bottom: 40px;
  }
  #life-quality .structure ul li.double {
    width: 100%;
    margin-bottom: 0;
  }
  #life-quality .structure ul li.double.last {
    width: 100%;
  }
  #life-quality .structure ul li.double .info {
    margin-bottom: 40px;
  }
  #life-quality .structure ul li:last-child {
    margin: auto;
  }
  #life-quality .structure ul .name {
    text-align: left;
  }
  /* ========================================================
 access
======================================================== */
  #access .intro {
    margin-bottom: 80px;
  }
  #access .intro .bg {
    background: url(../images/access/txt-bg.png);
    background-size: 80%;
    background-repeat: no-repeat;
    background-position: top;
    padding: 5% 0 0;
    margin-bottom: 80px;
  }
  #access .intro .txt {
    text-align: left;
    font-size: 22px;
    line-height: 1.6;
    margin-bottom: 50px;
  }
  #access .intro .lead {
    text-align: left;
    margin-bottom: 0;
  }
  #access .intro .list {
    margin-bottom: 40px;
  }
  #access .intro .list li {
    float: none;
    width: 90%;
    margin: auto;
  }
  #access .intro .img04 {
    margin: 0 auto 50px;
  }
  #access .sections .txt {
    text-align: left;
    margin-bottom: 50px;
  }
  #access .sec01 {
    margin-bottom: 80px;
  }
  #access .sec01 .image {
    max-width: 1000px;
    margin: 0 auto 10px;
  }
  #access .sec01 .mini {
    text-align: left;
  }
  #access .sec02 {
    margin-bottom: 30px;
  }
  #access .sec02 .lists .texts {
    padding: 30px 0;
    width: 90%;
    margin: auto;
  }
  #access .sec02 .lists .texts .txt01 {
    text-align: left;
  }
  #access .sec02 .list01 li {
    float: none;
    width: 100%;
  }
  #access .sec02 .list01 li:last-child {
    width: 100%;
  }
  #access .sec02 .list02 {
    margin: 0 auto 10px;
  }
  #access .sec02 .list02 li {
    float: none;
    width: 100%;
  }
  #access .sec02 .list03 li {
    float: none;
    width: 100%;
  }
  #access .sec02 .list03 .texts {
    padding: 30px 0;
  }
  /* ========================================================
 design
======================================================== */
  #design .intro {
    margin-bottom: 80px;
  }
  #design .intro .bg {
    background: url(../images/design/txt-bg.png);
    background-size: 80%;
    background-repeat: no-repeat;
    background-position: top;
    padding: 5% 0 0;
    margin-bottom: 80px;
  }
  #design .intro .txt {
    text-align: left;
    font-size: 22px;
    line-height: 1.6;
    margin-bottom: 50px;
  }
  #design .intro .lead {
    text-align: left;
    margin-bottom: 0;
  }
  #design .intro .list {
    margin: 0 auto 80px;
  }
  #design .intro .list li {
    display: block;
    width: 100%;
    margin: auto;
  }
  #design .intro .list li:last-child {
    width: 100%;
    margin: auto;
  }
  #design .intro .list li:last-child .image {
    margin-top: 40px;
  }
  #design .intro .list .txt01 {
    font-size: 22px;
    text-align: left;
  }
  #design .intro .box .imgs li {
    display: block;
    width: 100%;
    margin: auto;
  }
  #design .intro .box .imgs li:last-child {
    width: 100%;
    margin: 20px auto 0;
  }
  #design .intro .box .imgs .lead {
    margin: 40px auto;
  }
  #design .landplan {
    padding: 60px 0;
  }
  #design .landplan .tit {
    font-size: 22px;
    margin-bottom: 20px;
  }
  #design .landplan .copy {
    text-align: left;
    font-size: 22px;
    line-height: 1.6;
    margin-bottom: 50px;
  }
  #design .landplan .txt {
    font-size: 22px;
    text-align: left;
  }
  #design .landplan .lead {
    text-align: left;
    margin-bottom: 60px;
  }
  #design .landplan .imgs {
    max-width: inherit;
    flex-wrap: nowrap;
    width: 390vw;
    margin: 0 auto;
  }
  #design .landplan .imgs li {
    width: 95vw;
    margin-right: 5vw;
    margin-bottom: 0;
  }
  #design .landplan .box .texts, #design .landplan .box .images {
    display: block;
  }
  #design .landplan .box .texts {
    width: 90%;
    margin: 0 auto 20px;
  }
  #design .landplan .box .images {
    width: 90%;
    margin: auto;
  }
  #design .landplan .box .images li {
    display: inline-block;
    vertical-align: top;
    width: 48%;
    margin-right: 2%;
    margin-bottom: 10px;
  }
  #design .landplan .box .images li:nth-child(2n) {
    margin: auto;
  }
  /* ========================================================
 plan
======================================================== */
  #plan .intro {
    margin-bottom: 80px;
  }
  #plan .intro .bg {
    background: url(../images/plan/txt-bg.png);
    background-size: 80%;
    background-repeat: no-repeat;
    background-position: top;
    padding: 5% 0 0;
    margin-bottom: 40px;
  }
  #plan .intro .txt {
    text-align: left;
    font-size: 22px;
    line-height: 1.6;
    margin-bottom: 50px;
  }
  #plan .intro .lead {
    text-align: left;
    margin-bottom: 0;
  }
  #plan .intro .list {
    max-width: inherit;
    flex-wrap: nowrap;
    width: 340vw;
    margin: 0 auto;
  }
  #plan .intro .list li {
    width: 95vw;
    margin-right: 5vw;
    margin-bottom: 0;
  }
  #plan .intro .list .txt01 {
    text-align: left;
  }
  #plan .intro .list .txt02 {
    text-align: left;
  }
  #plan .intro .list .txt02 br {
    display: none;
  }
  #plan .intro .storage {
    padding: 30px 0;
  }
  #plan .intro .storage ul {
    width: 90%;
  }
  #plan .intro .storage ul li {
    display: inline-block;
    width: 100%;
    margin-bottom: 20px;
  }
  #plan .intro .storage ul li:nth-child(2) {
    width: 49%;
    margin-right: 1%;
  }
  #plan .intro .storage ul li:last-child {
    width: 49%;
    margin: auto;
  }
  #plan .plan-btns {
    padding: 60px 0;
  }
  #plan .plan-btns .txt {
    text-align: left;
    font-size: 22px;
    margin-bottom: 50px;
  }
  #plan .plan-btns .btn-list {
    display: block;
  }
  #plan .plan-btns .btn-list li {
    background: #fff;
    padding: 40px 0 30px;
  }
  #plan .plan-btns .btn-list.list01 {
    margin: 0 auto;
  }
  #plan .plan-btns .btn-list.list01 li {
    width: 100%;
    margin-bottom: 30px;
  }
  #plan .plan-btns .btn-list.list02 li {
    width: 100%;
    margin-bottom: 30px;
  }
  #plan .plan-btns .btn-list.list02 li:last-child {
    margin-bottom: auto;
  }
  /* ========================================================
 plan.detail
======================================================== */
  #plan.detail .plans {
    padding-bottom: 50px;
  }
  #plan.detail .plans .balcony {
    line-height: 1.8;
  }
  #plan.detail .plans .txt {
    text-align: left;
    margin: 50px auto;
  }
  #plan.detail .plans .rooms {
    max-width: 1100px;
    margin: auto;
  }
  #plan.detail .plans .rooms li {
    display: block;
    width: 100%;
  }
  #plan.detail .plans .rooms li:last-child {
    width: 100%;
  }
  #plan.detail .plans .rooms .point-box {
    width: 214vw;
    margin: 40px auto 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  #plan.detail .plans .rooms .points {
    width: 95vw;
    margin-right: 5vw;
    margin-bottom: 0;
  }
  /* ========================================================
 position
======================================================== */
  #position .intro {
    margin-bottom: 80px;
  }
  #position .intro .bg {
    background: url(../images/position/txt-bg.png);
    background-size: 80%;
    background-repeat: no-repeat;
    background-position: top;
    padding: 5% 0 0;
    margin-bottom: 80px;
  }
  #position .intro .txt {
    text-align: left;
    font-size: 22px;
    line-height: 1.6;
    margin-bottom: 50px;
  }
  #position .intro .lead {
    text-align: left;
    margin-bottom: 0;
  }
  #position .intro .box {
    padding: 40px 0;
  }
  #position .intro .box ul {
    width: 90%;
    margin: auto;
  }
  #position .intro .box ul li {
    display: block;
    width: 100%;
    margin: auto;
  }
  #position .intro .box ul li:last-child {
    width: 100%;
    margin: 20px auto 0;
  }
  #position .intro .box ul .txt01 {
    text-align: left;
    font-size: 22px;
  }
  #position .intro .box ul .txt02 {
    text-align: left;
    font-size: 14px;
    line-height: 2;
  }
  #position .intro .box ul .mini {
    text-align: left;
  }
  #position .sections {
    margin-bottom: 80px;
  }
  #position .sections .tit {
    margin-bottom: 40px;
  }
  #position .sections .txt {
    text-align: left;
    font-size: 22px;
  }
  #position .sections .lead {
    text-align: left;
    margin-bottom: 40px;
  }
  #position .sec01 ul {
    display: block;
  }
  #position .sec01 ul li {
    width: 100%;
  }
  #position .sec01 ul .caps {
    text-align: right;
    margin-top: 10px;
    font-size: 11px;
    line-height: 1.6;
  }
  #position .sec01 ul .txt01 {
    text-align: left;
    font-size: 22px;
  }
  #position .sec01 ul .txt02 {
    text-align: left;
    font-size: 14px;
    line-height: 2;
    margin-bottom: 40px;
  }
  #position .sec02 .txt {
    text-align: left;
    font-size: 18px;
  }
  #position .sec02 .img01 {
    max-width: 580px;
    margin: 0 auto 10px;
  }
  #position .sec02 .img02 {
    max-width: 1000px;
    margin: auto;
  }
  #position .sec02 .caption {
    text-align: right;
    bottom: -40px;
    line-height: 1.4;
  }
  #position .sec03 .txt {
    text-align: left;
    font-size: 18px;
  }
  /* ========================================================
 limited.plan
======================================================== */
  #limited.plan main {
    text-align: center;
    padding: 223rem 0 80rem;
  }
  #limited.plan .page-title {
    font-size: 30rem;
    padding-bottom: 17rem;
  }
  #limited.plan .plan-btns .txt {
    text-align: left;
    font-size: 22px;
    margin-bottom: 50px;
  }
  #limited.plan .plan-btns .btn-list {
    display: block;
  }
  #limited.plan .plan-btns .btn-list li {
    background: #fff;
    padding: 40px 0 30px;
  }
  #limited.plan .plan-btns .btn-list.list01 {
    margin: 0 auto;
  }
  #limited.plan .plan-btns .btn-list.list01 li {
    width: 100%;
    margin-bottom: 30px;
  }
  #limited.plan .plan-btns .btn-list.list02 li {
    width: 100%;
    margin-bottom: 30px;
  }
  #limited.plan .plan-btns .btn-list.list02 li:last-child {
    margin-bottom: auto;
  }
  /* ========================================================
 special
======================================================== */
  #special.lower .mv {
    margin-bottom: 80rem;
  }
  #special .intro {
    text-align: center;
    margin-bottom: 60px;
  }
  #special .intro .tit {
    max-width: 518px;
    margin: 0 auto 40px;
  }
  #special .intro .txt {
    text-align: left;
    font-size: 22px;
    line-height: 1.6;
  }
  #special .areas {
    text-align: center;
    margin-bottom: 20px;
  }
  #special .areas .area00 {
    margin-bottom: 100px;
  }
  #special .areas .area00 .txt {
    text-align: left;
    font-size: 22px;
  }
  #special .areas .area00 .lead {
    text-align: left;
    font-size: 14px;
    line-height: 2;
    margin-bottom: 30px;
  }
  #special .areas .area00 .img01 {
    max-width: 900px;
    margin: auto;
  }
  #special .areas .area00 .img01 .caption {
    bottom: -20px;
  }
  #special .areas .area00 .modal-button {
    margin: 30px auto 0;
  }
  #special .areas .area-inner .slide .slick-dots li {
    width: 6% !important;
    display: inline-block !important;
  }
  #special .areas .area-inner .texts {
    text-align: left;
    width: 94%;
    margin: 0 auto 20px;
  }
  #special .areas .area-inner .caps {
    text-align: right;
    font-size: 11px;
    line-height: 1.8;
  }
  #special .areas .area01, #special .areas .area03 {
    max-width: 1000px;
    margin: 0 auto 100px 0;
  }
  #special .areas .area01 .list li, #special .areas .area03 .list li {
    display: block;
    vertical-align: middle;
    width: 100%;
    margin-right: auto;
  }
  #special .areas .area01 .list li:last-child, #special .areas .area03 .list li:last-child {
    width: 100%;
    margin: auto;
  }
  #special .areas .area02, #special .areas .area04 {
    max-width: 1000px;
    margin: 0 0 100px auto;
  }
  #special .areas .area02 .list li, #special .areas .area04 .list li {
    display: block;
    vertical-align: middle;
    width: 100%;
    margin-right: auto;
  }
  #special .areas .area02 .list li:last-child, #special .areas .area04 .list li:last-child {
    width: 100%;
    margin: auto;
  }
  #special .accordion dl {
    position: relative;
  }
  #special .accordion dt .img00 {
    position: relative;
    overflow: hidden;
    height: 100%;
    z-index: 2;
  }
  #special .accordion dt .texts {
    position: absolute;
    top: auto;
    bottom: 10%;
    right: 0;
    left: 0;
    text-align: center;
    width: 90%;
    max-width: 1200px;
    margin: auto;
    display: block;
  }
  #special .accordion dt .texts li {
    width: 95%;
  }
  #special .accordion dt .texts li:last-child {
    width: 10%;
    margin: 30px auto 0;
  }
  #special .accordion dt .texts .tit {
    color: #fff;
    font-size: 18px;
    line-height: 1.4;
  }
  #special .accordion dt .texts .tit img {
    width: 28px;
    vertical-align: middle;
    padding-bottom: 10px;
  }
  #special .accordion dt .texts .tit .Cinzel {
    font-size: 28px;
    word-break: break-all;
    padding-left: 10px;
  }
  #special .accordion dt .texts .tit .new {
    display: none;
  }
  #special .accordion dd {
    box-sizing: border-box;
    display: none;
    margin-top: auto;
  }
  #special .accordion dd .back {
    position: inherit;
    top: 0;
    z-index: 1;
  }
  #special .accordion dd .inner-box {
    text-align: center;
    padding: 20% 0 80px;
    width: 90%;
    margin: auto;
  }
  #special .accordion dd .txt {
    text-align: left;
    font-size: 22px;
  }
  #special .accordion dd .lead {
    text-align: left;
    font-size: 14px;
    line-height: 2;
    margin-bottom: 50px;
  }
  #special .accordion dd .buttons {
    max-width: 60px;
    margin: 80px auto 0;
  }
  #special .accordion dd.on {
    display: block;
  }
  #special .accordion .pull01 dd .lead {
    margin-bottom: 0;
  }
  #special .accordion .pull01 .img01 {
    margin: 0 auto 30px;
  }
  #special .accordion .pull01 .img01 .swipe-img img {
    width: 1000px !important;
  }
  #special .accordion .pull01 .img02 {
    margin: 40px auto 0;
  }
  #special .accordion .pull01 .img02 .swipe-img img {
    width: 600px !important;
  }
  #special .accordion .pull01 .img02 .caption {
    bottom: 16.9%;
  }
  #special .accordion .pull02 .img01 .width {
    width: 74%;
    margin: 0 auto 20px;
  }
  #special .accordion .pull02 .img01 .swipe-img img {
    width: 1600px !important;
  }
  #special .accordion .pull02 .img01 .caption {
    text-align: right;
    line-height: 1.3;
    bottom: -34px;
  }
  #special .accordion .pull02 .swipe.bottom {
    margin-top: 40px;
  }
  #special .accordion .pull02 .img02 {
    margin: 40px auto 0;
    padding-left: 0;
  }
  #special .accordion .pull02 .img02 .swipe-img img {
    width: 600px !important;
  }
  #special .accordion .pull03 {
    background: #EAEFF9;
  }
  #special .accordion .pull03 .lists {
    flex-wrap: nowrap;
    width: 250vw;
  }
  #special .accordion .pull03 .lists li {
    width: 95vw;
    margin-right: 5vw;
    margin-bottom: 0;
  }
  #special .accordion .pull03 .lists li:first-child {
    display: none;
  }
  #special .accordion .pull03 .lists li:nth-child(2) .caption, #special .accordion .pull03 .lists li:nth-child(4) .caption {
    right: 11%;
  }
  #special .accordion .pull03 .fukidashi02, #special .accordion .pull03 .fukidashi04 {
    display: none;
  }
  #special .accordion .pull03 .fukidashi03 {
    display: none;
  }
  #special .accordion .pull03 .name {
    line-height: 1.5;
  }
  #special .accordion .pull04 .lists {
    align-items: flex-start;
    flex-wrap: nowrap;
    width: 135vw;
  }
  #special .accordion .pull04 .lists li {
    width: 95vw;
    margin-right: 5vw;
    margin-bottom: 0;
  }
  #special .accordion .pull04 .lists li:last-child {
    width: 95vw;
    margin: auto;
  }
  #special .accordion .pull04 .name {
    line-height: 1.6;
  }
  #special .accordion .pull04 .fukidashi05 {
    display: none;
  }
  #special .accordion .pull04 .fukidashi06 {
    display: none;
  }
  #special .accordion .pull05 .lovers {
    margin-bottom: 60px;
  }
  #special .accordion .pull05 .lovers .inner-tit {
    max-width: 145px;
    margin: 0 auto 30px;
  }
  #special .accordion .pull05 .lists {
    display: block;
  }
  #special .accordion .pull05 .lists li {
    width: 100%;
  }
  #special .accordion .pull05 .lists li:last-child {
    width: 100%;
  }
  #special .accordion .pull05 .lists .txt01 {
    margin-top: 30px;
  }
  #special .accordion .pull05 .lists .txt03 {
    font-size: 14px;
    line-height: 2;
    margin-bottom: 30px;
  }
  #special .accordion .pull05 .list02 li {
    width: 100%;
  }
  #special .accordion .pull05 .list02 li:last-child {
    width: 100%;
  }
  #special .accordion .pull06 .img01 {
    margin-bottom: 50px;
  }
  #special .accordion .pull06 .img01 .caption {
    right: 5.5%;
  }
  #special .accordion .pull06 .lists {
    display: block;
    margin-bottom: 50px;
  }
  #special .accordion .pull06 .lists li {
    width: 100%;
  }
  #special .accordion .pull06 .lists li:last-child {
    margin-top: 50px;
  }
  #special .accordion .pull06 .lists .num {
    max-width: 40px;
    margin: 0;
  }
  #special .accordion .pull06 .lists .name {
    line-height: 1.4;
  }
  #special .accordion .pull06 .list02 .fukidashi {
    display: none;
  }
  #special .accordion .pull06 .list02 li:last-child {
    margin: auto;
  }
  #special .accordion .pull06 .list02 .dates .img {
    width: 32%;
    margin-right: 20px;
  }
  #special .accordion .pull07 .img01 .mini {
    max-width: inherit;
    margin-top: 20px;
    position: inherit;
    right: 0;
    bottom: 0;
    font-size: 10px;
  }
  #special .accordion .pull07 .swipe-img img {
    width: 1200px !important;
  }
  #special #fixed {
    right: auto;
    left: 0;
    bottom: 295px;
  }
  #special .fixed_bnr {
    max-width: 240px;
    width: 50%;
    position: fixed;
    bottom: 50%;
    right: 0;
    transform: translate(300px);
  }
}

/*# sourceMappingURL=lower.css.map */
