/* =========================================================
parts
========================================================= */
/* =========================================================
parking information
========================================================= */
.parking-information-nav {
  padding: 50px 0 0;
}

@media (max-width: 768px) {
  .parking-information-nav {
    padding: 30px 0 0;
  }
}

.parking-information-nav .block {
  width: 1160px;
  margin: 0 auto 20px;
}

@media (max-width: 768px) {
  .parking-information-nav .block {
    width: 100%;
    padding: 0 4vw;
    display: block;
  }
}

.parking-information-nav .block:last-child {
  margin-bottom: 0;
}

.parking-information-nav .ttl {
  width: 90px;
  font-size: 24px;
  line-height: 1;
  text-align: center;
}

@media (max-width: 768px) {
  .parking-information-nav .ttl {
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin: 0 0 10px;
    padding: 0 0 8px;
    font-size: 20px;
  }
}

.parking-information-nav .ttl .fukidashi {
  margin: 0 auto 5px;
  padding: 5px 0;
  border-radius: 2px;
  color: #fff;
  font-size: 14px;
  line-height: 1;
  position: relative;
}

@media (max-width: 768px) {
  .parking-information-nav .ttl .fukidashi {
    width: 100px;
    margin: 0 15px 0 0;
  }
}

.parking-information-nav .ttl .fukidashi:before {
  content: "";
  border-style: solid;
  border-width: 4px 2px 0 2px;
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

@media (max-width: 768px) {
  .parking-information-nav .ttl .fukidashi:before {
    border-width: 2px 0 2px 5px;
    top: 50%;
    left: 100%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
}

@media (max-width: 768px) {
  .parking-information-nav .ttl.entry {
    border-bottom: 2px solid #A2C134;
  }
}

.parking-information-nav .ttl.entry .fukidashi {
  background: #A2C134;
}

.parking-information-nav .ttl.entry .fukidashi:before {
  border-color: #A2C134 transparent transparent transparent;
}

@media (max-width: 768px) {
  .parking-information-nav .ttl.entry .fukidashi:before {
    border-color: transparent transparent transparent #A2C134;
  }
}

@media (max-width: 768px) {
  .parking-information-nav .ttl.out {
    border-bottom: 2px solid #2C893A;
  }
}

.parking-information-nav .ttl.out .fukidashi {
  background: #2C893A;
}

.parking-information-nav .ttl.out .fukidashi:before {
  border-color: #2C893A transparent transparent transparent;
}

@media (max-width: 768px) {
  .parking-information-nav .ttl.out .fukidashi:before {
    border-color: transparent transparent transparent #2C893A;
  }
}

.parking-information-nav .list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.parking-information-nav .list li {
  width: calc(50% - 10px);
  margin: 20px 20px 0 0;
}

@media (max-width: 768px) {
  .parking-information-nav .list li {
    width: calc(50% - 4px);
    margin: 20px 8px 0 0;
  }
}

.parking-information-nav .list li:nth-child(-n+2) {
  margin-top: 0;
}

.parking-information-nav .list li:nth-child(2n) {
  margin-right: 0;
}

.parking-information-nav .list a {
  height: 60px;
  padding: 0 45px 0 0;
  display: block;
  border-radius: 10px;
  color: #fff;
  font-size: 18px;
  line-height: 1;
  letter-spacing: .04em;
  text-align: center;
  position: relative;
}

@media (max-width: 768px) {
  .parking-information-nav .list a {
    height: 100%;
    padding: 15px 0 22px;
    font-size: 14px;
    line-height: 1.42857;
  }
}

@media (max-width: 374px) {
  .parking-information-nav .list a {
    font-size: 12px;
  }
}

.parking-information-nav .list a:before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  position: absolute;
  top: 22px;
  right: 20px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media (max-width: 768px) {
  .parking-information-nav .list a:before {
    top: auto;
    left: auto;
    bottom: 8px;
    left: 50%;
    -webkit-transform: rotate(45deg) translateX(-50%);
    transform: rotate(45deg) translateX(-50%);
  }
}

.parking-information-nav .list br {
  display: none;
}

@media (max-width: 768px) {
  .parking-information-nav .list br {
    display: inline;
  }
}

.parking-information-nav .list span {
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.parking-information-nav .block.entry .ttl.entry {
  border-color: #A2C134;
}

.parking-information-nav .block.entry .list a {
  background: #A2C134;
}

.parking-information-nav .block.out .ttl.out {
  border-color: #2C893A;
}

.parking-information-nav .block.out .list a {
  background: #2C893A;
}

@media (max-width: 768px) {
  .js-scrollbar {
    padding-bottom: 45px;
    overflow: hidden;
    position: relative;
  }
}

@media (max-width: 768px) {
  .js-scrollbar:before {
    content: "";
    width: 100%;
    height: calc(100% - 45px);
    background: rgba(112, 112, 112, 0.8) url("../images/parking-information/icon-scroll.png") no-repeat center;
    background-size: 134px auto;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
  }
}

.js-scrollbar.touched:before {
  display: none;
}

.parking-information00 {
  margin: 40px auto 0;
}

@media (max-width: 768px) {
  .parking-information00 {
    margin: 30px auto 0;
  }
}

.parking-information00 .information-txt {
  font-size: 18px;
  line-height: 1.66667;
}

.parking-information01 {
  margin: 80px auto 0;
  position: relative;
}

@media (max-width: 768px) {
  .parking-information01 {
    margin: 40px auto 0;
  }
}

.parking-information01 .tpl-ttl1 {
  padding: 0;
}

.parking-information01 .tpl-ttl3 {
  margin: 30px auto 0;
}

.parking-information01 .tpl-ttl3 .small {
  font-size: .8em;
}

.parking-information01 .information-txt {
  margin: 20px auto 0;
  font-size: 18px;
  line-height: 1.66667;
}

.parking-information01 .information-tbl {
  width: 100%;
  margin: 30px auto 0;
  position: relative;
}

.parking-information01 .information-tbl table {
  width: 1160px;
  table-layout: fixed;
  font-size: 16px;
  line-height: 1;
  border-collapse: collapse;
}

.parking-information01 .information-tbl tr {
  height: 60px;
}

.parking-information01 .information-tbl tr:nth-child(odd) {
  background: #E7EFCA;
}

.parking-information01 .information-tbl tr:nth-child(even) {
  background: #D4E599;
}

.parking-information01 .information-tbl tr.head {
  background: #A2C134;
  color: #fff;
}

.parking-information01 .information-tbl th, .parking-information01 .information-tbl td {
  text-align: center;
  border: 1px solid  #fff;
}

.parking-information01 .information-tbl th {
  vertical-align: middle;
}

.parking-information01 .information-tbl th:first-child {
  width: 55px;
}

.parking-information01 .information-tbl .weeks.end {
  color: #DC000C;
}

.parking-information01 .information-tbl img {
  width: 100%;
}

.parking-information01 .information-note {
  margin: 30px auto 0;
}

.parking-information01 .information-note .list {
  padding: 15px;
  background: #F6F6F6;
  border-radius: 10px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .parking-information01 .information-note .list {
    padding: 20px;
  }
}

.parking-information01 .information-note .list li {
  margin: 0 40px 0 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

@media (max-width: 768px) {
  .parking-information01 .information-note .list li {
    width: calc(33.33% - 9px);
    margin: 0 12px 0 0;
    display: block;
  }
}

.parking-information01 .information-note .list li:last-child {
  margin-right: 0;
}

.parking-information01 .information-note .list li .txt {
  color: #2C893A;
  font-size: 18px;
  line-height: 1;
  font-weight: bold;
  text-align: center;
}

@media (max-width: 768px) {
  .parking-information01 .information-note .list li .txt {
    font-size: 3.2vw;
  }
}

.parking-information01 .information-note .list li .img {
  width: 84px;
  margin: 0 0 0 20px;
}

@media (max-width: 768px) {
  .parking-information01 .information-note .list li .img {
    width: auto;
    margin: 10px auto 0;
  }
}

.parking-information01 .information-note .list li .img img {
  width: 100%;
}

.parking-information01 .information-note .list .ttl {
  font-size: 18px;
  font-weight: bold;
}

@media (max-width: 768px) {
  .parking-information01 .information-note .list .ttl {
    width: 100%;
    margin: 0 auto 10px;
  }
}

.parking-information02 {
  margin: 80px auto 190px;
}

@media (max-width: 768px) {
  .parking-information02 {
    margin: 100px auto;
  }
}

.parking-information02 .tpl-ttl1 {
  padding: 0;
}

.parking-information02 .tpl-ttl3 {
  margin: 30px auto 0;
}

.parking-information02 .tpl-ttl3 .small {
  font-size: .8em;
}

.parking-information02 .information-txt {
  margin: 20px auto 0;
  font-size: 18px;
  line-height: 1.66667;
}

.parking-information02 .exit-block {
  margin: 95px auto 0;
}

.parking-information02 .exit-block:first-of-type {
  margin-top: 50px;
}

.parking-information02 .exit-head {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

@media (max-width: 768px) {
  .parking-information02 .exit-head {
    display: block;
  }
}

.parking-information02 .exit-head .box {
  width: 400px;
  height: 80px;
  margin: 0 0 0 30px;
  border: 1px solid #333;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media (max-width: 768px) {
  .parking-information02 .exit-head .box {
    width: 100%;
    margin: 0;
  }
}

.parking-information02 .exit-head .txt01 {
  margin-right: 20px;
  font-size: 19px;
  line-height: 1;
  letter-spacing: .025em;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

.parking-information02 .exit-head .ico {
  width: 40px;
  height: 40px;
  margin-right: 8px;
  border-radius: 50%;
  background: #000;
  color: #fff;
  line-height: 0;
  letter-spacing: 0;
  font-style: normal;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.parking-information02 .exit-head .txt02 {
  -webkit-transform: translateY(-0.2em);
  transform: translateY(-0.2em);
  text-align: center;
  font-size: 34px;
  line-height: 1;
  color: #DC000C;
}

@media (max-width: 600px) {
  .parking-information02 .exit-head .txt02 {
    font-size: 7vw;
  }
}

.parking-information02 .exit-head .txt02 small {
  font-size: .5em;
}

.parking-information02 .exit-head .txt03 {
  font-size: 24px;
  line-height: 1.66667;
}

@media (max-width: 768px) {
  .parking-information02 .exit-head .txt03 {
    margin: 20px auto 0;
  }
}

.parking-information02 .time-tbl {
  width: 100%;
  margin: 20px auto 0;
}

@media (max-width: 768px) {
  .parking-information02 .time-tbl {
    margin: 10px auto 0;
  }
}

.parking-information02 .time-tbl .table {
  width: 1160px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
}

.parking-information02 .time-tbl [class*="col0"] > * {
  height: 80px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.parking-information02 .time-tbl [class*="col0"] .hd {
  height: 50px;
}

.parking-information02 .time-tbl .col01 {
  width: 120px;
  border: 1px solid #000;
  background: #F6F6F6;
}

.parking-information02 .time-tbl .col01 > * {
  border-bottom: 1px solid #000;
  font-size: 30px;
  line-height: 1;
  letter-spacing: .02em;
}

.parking-information02 .time-tbl .col01 > *:last-child {
  border-bottom: none;
}

.parking-information02 .time-tbl .col01 .hd {
  font-size: 16px;
  line-height: 1;
}

.parking-information02 .time-tbl .col02 {
  width: 380px;
  position: relative;
}

.parking-information02 .time-tbl .col02:before {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  border: 10px solid #000;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
}

.parking-information02 .time-tbl .col02 > * {
  border-bottom: 1px solid #fff;
  font-size: 45px;
  line-height: 1;
  letter-spacing: .02em;
}

.parking-information02 .time-tbl .col02 .hd {
  background: #F6F6F6;
  font-size: 24px;
}

.parking-information02 .time-tbl .col02 .level01 {
  background: #2C893A;
  color: #fff;
}

.parking-information02 .time-tbl .col02 .level02 {
  background: #FFA700;
}

.parking-information02 .time-tbl .col02 .level03 {
  background: #DC000C;
  color: #fff;
}

.parking-information02 .time-tbl .col03,
.parking-information02 .time-tbl .col04,
.parking-information02 .time-tbl .col05 {
  width: calc((100% - 500px) / 3);
  border-right: 1px solid #fff;
}

.parking-information02 .time-tbl .col03 > *,
.parking-information02 .time-tbl .col04 > *,
.parking-information02 .time-tbl .col05 > * {
  border-bottom: 1px solid #fff;
  font-size: 26px;
  line-height: 1;
  letter-spacing: .02em;
}

.parking-information02 .time-tbl .col03 > *:last-child,
.parking-information02 .time-tbl .col04 > *:last-child,
.parking-information02 .time-tbl .col05 > *:last-child {
  border-bottom: none;
}

.parking-information02 .time-tbl .col03 .hd,
.parking-information02 .time-tbl .col04 .hd,
.parking-information02 .time-tbl .col05 .hd {
  font-size: 22px;
}

.parking-information02 .time-tbl .col03 .level01,
.parking-information02 .time-tbl .col04 .level01,
.parking-information02 .time-tbl .col05 .level01 {
  background: rgba(44, 137, 58, 0.6);
  color: #fff;
}

.parking-information02 .time-tbl .col03 .level02,
.parking-information02 .time-tbl .col04 .level02,
.parking-information02 .time-tbl .col05 .level02 {
  background: rgba(255, 167, 0, 0.6);
}

.parking-information02 .time-tbl .col03 .level03,
.parking-information02 .time-tbl .col04 .level03,
.parking-information02 .time-tbl .col05 .level03 {
  background: rgba(220, 0, 12, 0.6);
  color: #fff;
}

.parking-information02 .time-tbl .col03 .hd {
  background: #C7C7C7;
}

.parking-information02 .time-tbl .col04 .hd {
  background: #aaa;
}

.parking-information02 .time-tbl .col05 {
  border: none;
}

.parking-information02 .time-tbl .col05 .hd {
  background: #8a8a8a;
}

.parking-information02 .note {
  margin: 20px auto 0;
  font-size: 14px;
  line-height: 1.42857;
}

.off-hours {
  overflow: hidden;
  position: relative;
}

.off-hours:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(112, 112, 112, 0.8);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

.off-hours .off-txt {
  width: 100%;
  color: #fff;
  font-size: 30px;
  line-height: 1.66667;
  font-weight: bold;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  letter-spacing: .02em;
  text-align: center;
  z-index: 2;
}

@media (max-width: 768px) {
  .off-hours .off-txt {
    padding: 0 25px;
  }
}

.off-hours table tr {
  background: #aaa;
}

/* =========================================================
perfect scrollbar
======================================================= */
/*
 * Container style
 */
.ps {
  overflow: hidden !important;
  overflow-anchor: none;
  -ms-overflow-style: none;
  touch-action: auto;
  -ms-touch-action: auto;
}

/*
 * Scrollbar rail styles
 */
.ps__rail-x {
  width: 100%;
  height: 25px;
  height: 15px;
  /* there must be 'bottom' or 'top' for ps__rail-x */
  bottom: 0px;
  /* please don't change 'position' */
  position: absolute;
  background: #F6F6F6;
  border-radius: 15px;
  display: none !important;
}

@media (max-width: 768px) {
  .ps__rail-x {
    display: block !important;
  }
}

.ps__rail-y {
  display: none;
  opacity: 0;
  transition: background-color .2s linear, opacity .2s linear;
  -webkit-transition: background-color .2s linear, opacity .2s linear;
  width: 15px;
  /* there must be 'right' or 'left' for ps__rail-y */
  right: 0;
  /* please don't change 'position' */
  position: absolute;
}

.ps--active-x > .ps__rail-x,
.ps--active-y > .ps__rail-y {
  display: block;
}

/*
 * Scrollbar thumb styles
 */
.ps__thumb-x {
  background-color: #A2C134;
  border-radius: 15px;
  height: 15px;
  /* there must be 'bottom' for ps__thumb-x */
  bottom: 0;
  /* please don't change 'position' */
  position: absolute;
}

.ps__thumb-y {
  background-color: #aaa;
  border-radius: 6px;
  transition: background-color .2s linear, width .2s ease-in-out;
  -webkit-transition: background-color .2s linear, width .2s ease-in-out;
  width: 6px;
  /* there must be 'right' for ps__thumb-y */
  right: 2px;
  /* please don't change 'position' */
  position: absolute;
}

.ps__rail-y:hover > .ps__thumb-y,
.ps__rail-y:focus > .ps__thumb-y,
.ps__rail-y.ps--clicking .ps__thumb-y {
  width: 11px;
}

/* MS supports */
@supports (-ms-overflow-style: none) {
  .ps {
    overflow: auto !important;
  }
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .ps {
    overflow: auto !important;
  }
}
