@charset "UTF-8";
/* CSS Document */
.hero-img {
  background-image: url("../01_images/access-top.jpg");
  background-size: cover;
  background-position: center;
  width: 100%;
  height: 100vh;
}
.section-overview {
  display: block;
  margin: 60px auto;
  max-width: 900px;
}
.section-overview p {
  font-size: 14px;
  font-weight: 100;
  line-height: 25px;
  letter-spacing: 3px;
}
.add-block {
  display: block;
  margin: 40px auto;
}
.add-block p {
  font-size: 14px;
  font-weight: 100;
  line-height: 25px;
}
.ac {
  margin: 0px 0 15px 0;
}
iframe {
  width: 100%;
}
.section-trans {
  display: block;
  margin: 80px auto;
  max-width: 900px;
}
.shortcut-button {
  display: flex;
  justify-content: center;
  gap: 20px;
  width: 100%;
}
.shortcut-button a {
  text-decoration: none;
  color: #fff;
  font-size: 14px;
  border: solid 1px #fff;
  padding: 20px;
  width: 20%;
  text-align: center;
}
.shortcut-button a:hover {
  background-color: #333;
}
.shortcut-button li {
  list-style: none;
  width: 31%;
  text-align: center;
  border: solid 0.5px #fff;
  padding: 20px 0px;
}
.by-car,
.by-train,
.by-bus {
  margin: 60px auto;
  border-bottom: solid 1px #fff;
  padding-bottom: 60px;
}
.byt {
  margin-bottom: 40px;
  font-size: 16px;
  letter-spacing: 2px;
  font-weight: 500;
  border: 1px solid #fff;
  width: 25%;
  padding: 15px 5px;
  text-align: center;
}
.time-block {
  display: flex;
  width: 52%;
  justify-content: flex-start;
  gap: 50px;
}
.time-block li {
  list-style: none;
}
.text-l {
  font-size: 35px;
  letter-spacing: 3px;
  padding: 0 5px;
}
.time-block p {
  font-size: 14px;
  font-weight: 100;
  letter-spacing: 1px;
}
.parking {
  margin-top: 60px;
}
.parking-img {
  display: block;
  width: 100%;
  margin: 40px auto;
}
.parking h3 {
  letter-spacing: 3px;
  font-size: 20px;
  margin-bottom: 10px;
  font-weight: 500;
}
.parking p {
  font-size: 14px;
  font-weight: 100;
  line-height: 25px;
}
.sub {
  margin-top: 8px;
}
.access-flow-title-l,
.access-flow-title-lv {
  letter-spacing: 3px;
}
.time-block h3 {
  margin-bottom: 25px;
  font-size: 16px;
  font-weight: 300;
  letter-spacing: 1px;
}
.last-text {
  font-size: 14px;
  line-height: 25px;
}
/*access-----------------------------------------------------------------------------------------------------------------------*/
.googlemaps iframe {
  width: 100%;
}
.access-text {
  display: block;
  margin: 20px auto;
  max-width: 1000px;
}
.access-text p {
  margin: 5px 0;
}
.access-flow-wrapper {
  display: block;
  margin: 80px auto;
  max-width: 900px;
}
.access-flow {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
}
.access-flow-title {
  text-align: center;
  letter-spacing: 3px;
  border: solid 1px #fff;
  padding: 35px 20px;
  margin: 15px 0;
  font-weight: 100;
}
.access-flow-title-lv {
  padding: 78px 40px;
  border: solid 1px #fff;
  font-weight: 100;
}
.access-flow li {
  list-style: none;
  margin: auto 0;
  text-align: center;
}
.access-time-up {
  border-bottom: solid 1px #fff;
}
.access-li-title {
  width: 55%;
}
.access-time {
  width: 85%;
}
.access-time p {
  padding: 8px 0 8px 30px;
  text-align: left;
  line-height: 25px;
  font-weight: 100;
  font-size: 14px;
  letter-spacing: 2px;
}
.access-flow-title-l {
  padding: 87px 20px;
  border: solid 1px #fff;
  font-weight: 100;
}
.access-time-up-b {
  border-bottom: solid 1px #fff;
}
.text-wrapper01 {
  position: relative;
  top: -18px;
}
.text-wrapper02 {
  position: relative;
  top: 21px;
}
.text-wrapper03 {
  position: relative;
  top: -18px;
}
.text-wrapper04 {
  position: relative;
  top: 9px;
}
.access-wrapper {
  display: block;
  margin: 60px auto;
  max-width: 1000px;
}
.access-img {
  display: block;
  width: 60%;
  margin: 0 auto;
}
.time {
  font-size: 22px;
  font-weight: 300;
}
.sub {
  line-height: 25px;
}
.bus-b01 {
  margin-bottom: 60px;
}
.bus-text-block {
  list-style: none;
  margin: 10px 0;
}
.bus-subtext {
  margin-top: 20px;
  font-size: 14px;
  font-weight: 100;
}
.bus-text-block {
  font-size: 14px;
  font-weight: 100;
}
.bus-text-block p {
  line-height: 27px;
}
.bus-sub-title {
  font-size: 16px;
  margin-bottom: 40px;
  letter-spacing: 2px;
  font-weight: 200;
}
.fi-wrapper {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin: 30px 0;
}
.bus-img {
  display: block;
  width: 48%;
}
.bus-text-wrapper {
  display: block;
  margin: auto 0;
}

@media (max-width: 599px) {
  .giji-left {
    position: absolute;
    padding: 0 !important;
    top: 30px;
    left: 25px;
  }
  .giji-right {
    position: absolute;
    padding: 0 !important;
    top: -10px;
    right: -18%;
  }
  .shortcut-button a {
    text-decoration: none;
    color: #fff;
    font-size: 14px;
    border: solid 1px #fff;
    padding: 20px 5px;
    width: 43%;
    text-align: center;
  }
  .airplane-text {
    position: absolute;
    top: 30px;
    left: 25px;
  }
  .access-time-up-b {
    border-bottom: none;
    padding: 0 !important;
  }
  .access-flow-title-l {
    padding: 15px 20px;
    border: solid 1px #fff;
    font-weight: 100;
    width: 100%;
    background-color: #0c0c0c;
    margin-top: 120px;
    margin-bottom: 15px;
  }
  .mark01:after {
    content: "";
    position: absolute;
    left: 58%;
    top: 168px;
    background: #fff;
    width: 1px;
    height: 136px;
  }
  .text-wrapper04 {
    margin-left: 65%;
    top: -20px;
    position: relative;
  }

  .airplane02:after {
    content: "";
    position: absolute;
    left: 58%;
    top: 167px;
    background: #fff;
    width: 1px;
    height: 136px;
  }

  .airplane01 {
    margin-top: 10px !important;
  }
  .airplane02 {
    padding: 15px 20px;
    border: solid 1px #fff;
    font-weight: 100;
    width: 100%;
    background-color: #0c0c0c;
    margin-top: 120px !important;
    margin-bottom: 15px;
  }
  .airplane01:before {
    top: 58px !important;
  }
  .airplane02:before {
    top: 167px !important;
  }
  .access-flow-title-lv {
    padding: 20px 0;
    border: solid 1px #fff;
    font-weight: 100;
    width: 100%;
    margin-top: 120px;
    background-color: #0c0c0c;
  }
  .access-time-up {
    border-bottom: none;
    padding: 0 !important;
    position: absolute;
    top: 30px;
    left: 25px;
    width: 130px;
  }
  .access-flow-title:before {
    content: "";
    position: absolute;
    left: 3%;
    top: 62px;
    background: #fff;
    width: 1px;
    height: 170px;
  }
  .access-flow-title:after {
    content: "";
    position: absolute;
    left: 58%;
    top: 62px;
    background: #fff;
    width: 1px;
    height: 170px;
  }
  .access-flow-title-l:before {
    content: "";
    position: absolute;
    left: 3%;
    top: 168px;
    background: #fff;
    width: 1px;
    height: 136px;
  }
  .byt {
    margin-bottom: 40px;
    font-size: 16px;
    letter-spacing: 2px;
    font-weight: 500;
    border: 1px solid #fff;
    width: 50%;
    padding: 15px 5px;
    text-align: center;
  }
  .access-li-title {
    width: 100% !important;
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    gap: 30px;
    position: relative;
  }
  .section-overview {
    padding: 0 20px;
    margin: 40px auto;
  }
  .section-trans {
    display: block;
    margin: 40px auto;
    padding: 0 20px;
  }
  .shortcut-button {
    display: flex;
    width: 100%;
    flex-wrap: wrap;
  }
  .shortcut-button li {
    list-style: none;
    width: 46%;
    text-align: center;
    border: solid 0.5px #fff;
    padding: 20px 0px;
    margin: 0px auto;
    font-size: 14px;
  }
  .by-car,
  .by-train {
    margin: 45px auto;
    border-bottom: solid 1px #fff;
    padding-bottom: 30px;
  }
  .byt {
    margin-bottom: 20px;
    font-weight: 600;
  }
  .time-block {
    display: flex;
    width: 100%;
    justify-content: flex-start;
    gap: 50px;
  }
  .parking h3 {
    letter-spacing: 3px;
    font-size: 18px;
    margin-bottom: 10px;
    font-weight: 500;
  }
  .parking {
    margin-top: 40px;
  }
  .time-block {
    display: flex;
    width: 100%;
    justify-content: flex-start;
    gap: 25px;
  }
  .time-block p {
    font-size: 14px;
    font-weight: 100;
    letter-spacing: 0;
  }
  .access-flow-wrapper {
    padding: 0 !important;
    margin: 40px auto;
  }
  .access-flow-title {
    text-align: center;
    letter-spacing: 3px;
    border: solid 1px #fff;
    padding: 15px 15px;
    margin: 15px 0;
    font-weight: 100;
  }
  .fi-wrapper {
    display: block;
    margin: 40px 0;
  }
  .bus-img {
    display: block;
    width: 100%;
    margin: 20px 0;
  }
  .last-text {
    font-size: 14px;
    line-height: 25px;
  }
}
/*タブレット----------------------------------------------------------------------------------------------------------------------*/
@media (min-width: 600px) and (max-width: 1024px) {
  body {
    padding-left: 80px;
  }
  .section-overview,
  .section-trans {
    padding: 0 20px;
  }
  .shortcut-button {
    display: flex;
    justify-content: center;
    gap: 20px;
    width: 100%;
    flex-wrap: wrap;
  }

  .shortcut-button a {
    text-decoration: none;
    color: #fff;
    font-size: 14px;
    border: solid 1px #fff;
    padding: 20px;
    width: 41%;
    text-align: center;
  }
  .fi-wrapper {
    display: block;
    margin: 40px 0;
  }
  .bus-img {
    display: block;
    width: 100%;
    margin: 40px 0px;
  }
  .access-time p {
    padding: 8px 0 8px 15px;
    text-align: left;
    line-height: 25px;
    font-weight: 100;
    font-size: 14px;
    letter-spacing: 0px;
  }
  .access-flow-title {
    text-align: center;
    letter-spacing: 0px;
    border: solid 1px #fff;
    padding: 35px 15px;
    margin: 15px 0;
    font-weight: 100;
    font-size: 14px;
  }
  .access-flow-title-l,
  .access-flow-title-lv {
    letter-spacing: 0px;
    font-size: 14px;
  }
  .access-flow-title-l {
    padding: 87px 15px;
    border: solid 1px #fff;
    font-weight: 100;
  }
}
