#key {
  background-image: url("../img/access/key.jpg");
  background-position: 80%;
}

#sec1 {
  padding: 18vw 0;
}
#sec1 h2 {
  letter-spacing: 0.12em;
  position: relative;
  margin-bottom: 10vw;
}
#sec1 h2:before {
  content: "";
  width: 50%;
  height: 52vw;
  background-image: url("../img/access/s1-dc.png");
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  left: 23%;
  top: -16vw;
  z-index: -1;
}
#sec1 .info {
  line-height: 20px;
}
#sec1 .info dl {
  margin-bottom: 20px;
  width: 100%;
  display: table;
  position: relative;
}
#sec1 .info dl:after {
  content: "";
  height: 1px;
  background: #6d624d;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -10px;
}
#sec1 .info dl dt {
  width: 85px;
  display: table-cell;
  vertical-align: middle;
}
#sec1 .info dl dd {
  display: table-cell;
}
#sec1 .row {
  margin-top: 12vw;
}
#sec1 .row .tel {
  font-size: 5vw;
  letter-spacing: 0.05em;
  line-height: 10vw;
  margin: 8vw 0 5vw;
}
#sec1 .row .tel span {
  display: block;
  font-size: 9vw;
  letter-spacing: 0;
}
#sec1 .row .tel span img {
  width: 7vw;
  margin: -0.5vw 1% 0 0;
}
#sec1 .row .btn {
  width: 80%;
  margin: 0 auto;
}
#sec1 .row .btn a {
  display: block;
  border: 1px solid #fff;
  font-size: 5vw;
  letter-spacing: 0.05em;
  line-height: 7vw;
  padding: 3.5vw 0 4vw;
  text-align: center;
}
#sec1 .row .btn a img {
  width: 5.5vw;
  margin: -1vw 3% 0 0;
}
#sec1 .row2 {
  padding: 0 3%;
  margin-top: 15vw;
}
#sec1 .row2 .gmap {
  height: 480px;
  position: relative;
  margin-bottom: 8vw;
}
#sec1 .row2 .gmap iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  border: none;
}
#sec1 .row2 .btn-grp .btn,
#sec1 .row2 .btn-grp .copy {
  width: 50%;
  margin: 0 auto;
}
#sec1 .row2 .btn-grp .btn a,
#sec1 .row2 .btn-grp .copy {
  display: block;
  border-bottom: 1px solid;
  padding-bottom: 2vw;
  position: relative;
}
#sec1 .row2 .btn-grp .btn a:after,
#sec1 .row2 .btn-grp .copy:after {
  content: "";
  width: 3vw;
  height: 4vw;
  background-image: url("../img/shared/arrow.png");
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  right: 0;
  top: 2.2vw;
}
@media only screen and (min-width: 768px) {
  #sec1 {
    padding: 135px 0 80px;
  }
  #sec1 h2 {
    margin-bottom: 94px;
  }
  #sec1 h2:before {
    width: 288px;
    height: 308px;
    left: 360px;
    top: -132px;
  }
  #sec1 .info {
    line-height: 30px;
    margin: 0 -46px 0 -30px;
  }
  #sec1 .info .col {
    width: 510px;
  }
  #sec1 .info dl {
    margin-bottom: 31px;
  }
  #sec1 .info dl:after {
    bottom: -17px;
    right: 10px;
  }
  #sec1 .info dl dt {
    width: 141px;
  }
  #sec1 .info .col2 {
    width: 520px;
  }
  #sec1 .info .col2 dl {
    margin-bottom: 54px;
  }
  #sec1 .info .col2 dl:after {
    right: 10px;
  }
  #sec1 .info .col2 dl dt {
    width: 178px;
  }
  #sec1 .info .col2 dl.two:after {
    bottom: -26px;
  }
  #sec1 .row {
    margin-top: 13px;
  }
  #sec1 .row .tel {
    font-size: 27.47px;
    line-height: 50px;
    margin: 0px 0 40px;
  }
  #sec1 .row .tel span {
    font-size: 55.72px;
    margin-top: 16px;
  }
  #sec1 .row .tel span img {
    width: 43px;
    margin: -3px 4px 0 4px;
  }
  #sec1 .row .btn {
    width: 390px;
    margin: 0 auto;
  }
  #sec1 .row .btn a {
    font-size: 29.72px;
    line-height: 35px;
    padding: 23px 27px 24px 0;
  }
  #sec1 .row .btn a img {
    width: 33px;
    margin: -6px 27px 0 0;
  }
  #sec1 .row .btn a:hover {
    opacity: 0.8;
  }
  #sec1 .row .btn a:hover img {
    opacity: 1 !important;
  }
  #sec1 .row2 {
    padding: 0 20px;
    margin-top: 63px;
  }
  #sec1 .row2 .gmap {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto 40px;
    height: 500px;
  }
  #sec1 .row2 .btn-grp .col {
    width: 215px;
    margin-right: 167px;
  }
  #sec1 .row2 .btn-grp .btn,
  #sec1 .row2 .btn-grp .copy {
    width: 215px;
    margin: 0;
  }
  #sec1 .row2 .btn-grp .btn a,
  #sec1 .row2 .btn-grp .copy {
    padding-bottom: 8px;
    letter-spacing: 0.05em;
    cursor: pointer;
    transition: 0.3s all ease-in-out;
  }
  #sec1 .row2 .btn-grp .btn a:after,
  #sec1 .row2 .btn-grp .copy:after {
    width: 18px;
    height: 20px;
    top: 8px;
  }
  #sec1 .row2 .btn-grp .btn a:hover,
  #sec1 .row2 .btn-grp .copy:hover {
    opacity: 0.8;
  }
  #sec1 .row2 .btn-grp .copy.copied {
    pointer-events: none;
  }
  #sec1 .row2 .btn-grp .print {
    margin-top: 4px;
  }
  #sec1 .row2 .btn-grp .print a:hover {
    text-decoration: underline;
  }
}

#sec2 h2 {
  width: 85%;
  margin: 0 auto;
}
#sec2 .tabs-switch {
  margin-top: 8vw;
}
#sec2 .tabs-switch .tab-link li {
  width: 30%;
  position: relative;
  z-index: 0;
  font-size: 11vw;
  line-height: 10vw;
  padding: 3vw 0;
}
#sec2 .tabs-switch .tab-link li:before {
  content: "";
  background: #fff;
  border-radius: 10px 10px 0 0;
  position: absolute;
  left: 0;
  right: 6px;
  top: 0;
  bottom: 0;
  z-index: -1;
}
#sec2 .tabs-switch .tab-link li:after {
  content: "";
  background: #dedede;
  border-radius: 10px 10px 0 0;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: -2;
}
#sec2 .tabs-switch .tab-link li small {
  font-size: 9vw;
}
#sec2 .tabs-switch .tab-link li.active:before {
  background: #f8eacf;
  right: 0;
}
#sec2 .tabs-switch .tab-content .tab {
  background: #f8eacf;
  padding: 8vw 3%;
}
#sec2 .tabs-switch .tab-content .tab .coll {
  position: relative;
  margin-bottom: 8vw;
}
#sec2 .tabs-switch .tab-content .tab .coll .ttl {
  font-size: 13vw;
  line-height: 10vw;
  font-weight: 500;
  color: #311f00;
  position: absolute;
  left: -3%;
  bottom: -2vw;
  z-index: 1;
  opacity: 0.8;
}
#sec2 .tabs-switch .tab-content .tab .coll .ttl small {
  font-size: 11vw;
}
#sec2 .tabs-switch .tab-content .tab .colr .row {
  margin: 0 -3% 4vw 0;
}
#sec2 .tabs-switch .tab-content .tab .colr .row .img {
  width: 42%;
}
#sec2 .tabs-switch .tab-content .tab .colr .row dl {
  width: 55%;
}
#sec2 .tabs-switch .tab-content .tab .colr .row dl dt {
  width: 9vw;
  height: 9vw;
  border-radius: 50%;
  line-height: 8vw;
  letter-spacing: 0;
  margin-right: 3%;
}
#sec2 .tabs-switch .tab-content .tab .colr .row dl dd {
  line-height: 6vw;
  letter-spacing: 0;
}
@media only screen and (min-width: 768px) {
  #sec2 {
    position: relative;
  }
  #sec2 h2 {
    width: 489px;
    margin: 0;
    position: absolute;
    left: calc(50% - 597px);
    top: 19px;
    z-index: 1;
  }
  #sec2 .tabs-switch {
    margin-top: 0;
  }
  #sec2 .tabs-switch .tab-link {
    justify-content: flex-end;
    margin-right: calc(50% - 529px);
  }
  #sec2 .tabs-switch .tab-link li {
    width: 170px;
    font-size: 69.56px;
    line-height: 60px;
    padding: 16px 0 21px;
  }
  #sec2 .tabs-switch .tab-link li:before {
    border-radius: 20px 20px 0 0;
    transition: 0.1s all ease-in-out;
  }
  #sec2 .tabs-switch .tab-link li:hover:before{
    background: #f8eacf;
  }
  #sec2 .tabs-switch .tab-link li:after {
    border-radius: 20px 20px 0 0;
  }
  #sec2 .tabs-switch .tab-link li small {
    font-size: 56.4px;
  }
  #sec2 .tabs-switch .tab-content .tab {
    padding: 81px 0 76px;
  }
  #sec2 .tabs-switch .tab-content .tab .inner {
    max-width: 1266px;
    width: 100%;
    margin: 0 auto;
    justify-content: space-between;
  }
  #sec2 .tabs-switch .tab-content .tab .coll {
    width: 591px;
    margin: 0 0 0 36px;
  }
  #sec2 .tabs-switch .tab-content .tab .coll .ttl {
    font-size: 100px;
    line-height: 60px;
    font-weight: 500;
    left: -65px;
    bottom: 16px;
  }
  #sec2 .tabs-switch .tab-content .tab .coll .ttl small {
    font-size: 80px;
  }
  #sec2 .tabs-switch .tab-content .tab .colr {
    margin-top: 1px;
  }
  #sec2 .tabs-switch .tab-content .tab .colr .row {
    margin: 0 0 26px 0;
  }
  #sec2 .tabs-switch .tab-content .tab .colr .row .img {
    width: 300px;
    margin-right: 14px;
  }
  #sec2 .tabs-switch .tab-content .tab .colr .row dl {
    width: 277px;
    padding-bottom: 10px;
  }
  #sec2 .tabs-switch .tab-content .tab .colr .row dl dt {
    width: 55px;
    height: 55px;
    line-height: 55px;
    margin-right: 13px;
  }
  #sec2 .tabs-switch .tab-content .tab .colr .row dl dd {
    line-height: 30px;
    letter-spacing: 0.05em;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1400px) {
  #sec2 .tabs-switch .tab-content .tab .coll .ttl {
    left: -20px;
    bottom: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1280px) {
  #sec2 h2 {
    left: calc(50% - 560px);
  }
  #sec2 .tabs-switch .tab-content .tab .coll {
    margin-left: 25px;
  }
  #sec2 .tabs-switch .tab-content .tab .coll .ttl {
    left: -13px;
    bottom: 0;
  }
  #sec2 .tabs-switch .tab-content .tab .coll .floor {
    width: 540px;
  }
  #sec2 .tabs-switch .tab-content .tab .coll .floor img {
    width: 100%;
    height: 450px;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 50%;
       object-position: 50%;
  }
  #sec2 .tabs-switch .tab-content .tab .colr .row dl {
    width: 290px;
  }
}

#sec3 {
  padding: 18vw 3% 2vw;
}
#sec3 h2 {
  position: relative;
  z-index: 0;
  margin-bottom: 10vw;
  letter-spacing: 0.12em;
}
#sec3 h2:before {
  content: "";
  width: 29%;
  height: 60vw;
  background-image: url("../img/access/s3-dc.jpg");
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  left: 35%;
  top: -12vw;
  z-index: -1;
}
#sec3 .row {
  margin-bottom: 13vw;
}
#sec3 .row .col h3 {
  margin: 8vw 0 6vw;
  letter-spacing: 0.09em;
  line-height: 9vw;
}
#sec3 .row .col .btn {
  width: 60%;
  margin: 8vw auto 0;
}
#sec3 .row .col .btn a {
  display: block;
  border-bottom: 1px solid #fff;
  padding-bottom: 2vw;
  position: relative;
  font-weight: bold;
  letter-spacing: 0.05em;
}
#sec3 .row .col .btn a:after {
  content: "";
  width: 3vw;
  height: 4vw;
  background-image: url("../img/shared/arrow-wh.png");
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  right: 0;
  top: 2vw;
}
@media only screen and (min-width: 768px) {
  #sec3 {
    padding: 149px 0 47px;
  }
  #sec3 .inner {
    max-width: 1357px;
    width: 100%;
    margin: 0 auto;
  }
  #sec3 h2 {
    margin-bottom: 123px;
  }
  #sec3 h2:before {
    width: 195px;
    height: 273px;
    left: calc(50% - 97px);
    top: -92px;
  }
  #sec3 .row {
    margin-bottom: 114px;
    position: relative;
    z-index: 1;
  }
  #sec3 .row .img {
    max-width: 700px;
    width: calc(100% - 610px);
  }
  #sec3 .row .img img {
    width: 100%;
    height: 430px;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 50%;
       object-position: 50%;
  }
  #sec3 .row .col {
    width: 574px;
  }
  #sec3 .row .col h3 {
    margin: -19px 0 41px;
    line-height: 59px;
  }
  #sec3 .row .col .btn {
    width: 300px;
    margin: 78px 0 0;
  }
  #sec3 .row .col .btn a {
    padding-bottom: 8px;
  }
  #sec3 .row .col .btn a:after {
    width: 18px;
    height: 20px;
    top: 8px;
  }
  #sec3 .row .col .btn a:hover {
    opacity: 0.8;
  }
}

#sec4 {
  background-image: url("../img/access/s4-bg.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: 50%;
  padding: 15vw 0;
  color: #fff;
}
#sec4 h2 {
  margin: 0 auto;
  letter-spacing: 0.05em;
  position: relative;
}
#sec4 h2:before {
  content: "";
  width: 1px;
  height: 12vw;
  background: #fff;
  position: absolute;
  left: 50%;
  top: -15vw;
}
#sec4 .tel {
  font-size: 9vw;
  letter-spacing: 0;
  line-height: 9vw;
  margin: 6vw 0 4vw;
}
#sec4 .tel img {
  width: 6vw;
  margin-top: -0.5vw;
}
#sec4 .tel a:hover img {
  opacity: 1 !important;
}
#sec4 dl {
  display: table;
  margin: 0 auto;
}
#sec4 dl dt {
  width: 60px;
  display: table-cell;
}
#sec4 dl dd {
  display: table-cell;
}
#sec4 .btn {
  width: 80%;
  margin: 6vw auto 0;
}
#sec4 .btn a {
  display: block;
  background: #fff;
  color: #000;
  text-align: center;
  letter-spacing: 0.05em;
  font-weight: 500;
  padding: 2.8vw 0 3vw;
  position: relative;
}
#sec4 .btn a:before {
  content: "";
  border: 1px solid #000;
  position: absolute;
  left: 1vw;
  right: 1vw;
  top: 1vw;
  bottom: 1vw;
}
@media only screen and (min-width: 768px) {
  #sec4 {
    padding: 139px 0 174px;
  }
  #sec4 h2 {
    float: left;
    margin: 0 77px 0 -30px;
  }
  #sec4 h2:before {
    height: 116px;
    top: -139px;
  }
  #sec4 .col {
    float: left;
  }
  #sec4 .tel {
    font-size: 47.8px;
    line-height: 35px;
    margin: 12px 0 27px;
  }
  #sec4 .tel img {
    width: 38px;
    margin: -7px 6px 0 0;
  }
  #sec4 dl {
    display: table;
    margin: 0 0 0 4px;
  }
  #sec4 dl dt {
    width: 83px;
  }
  #sec4 .btn {
    width: 348px;
    margin: 29px 0 0 7px;
  }
  #sec4 .btn a {
    padding: 6px 0 9px;
  }
  #sec4 .btn a:before {
    left: 2px;
    right: 2px;
    top: 2px;
    bottom: 2px;
  }
  #sec4 .btn a:hover {
    opacity: 0.8;
  }
}/*# sourceMappingURL=access.css.map */