/* CSS Document */
.pre-inc .footnote {
  font-size: min(2svw, 10px);
  font-weight: 500;
  line-height: normal;
}
.pre-inc .pc-on {
  display: none !important;
}
@media screen and (min-width: 1024px), print {
  .pre-inc .pc-on {
    display: inline !important;
  }
}
.pre-inc .sp-on {
  display: inline !important;
}
@media screen and (min-width: 1024px), print {
  .pre-inc .sp-on {
    display: none !important;
  }
}
.pre-inc #main {
  position: relative;
  background: url(../images/access/main.webp) no-repeat 50% 100%;
  background-size: cover;
  width: 100%;
  height: 100px;
  aspect-ratio: unset;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #main {
    height: 200px;
    background: url(../images/access/main.webp) no-repeat 100% 100%;
    background-size: 100%;
  }
}
.pre-inc #main .main-title {
  font-size: min(8.2svw, 64px);
  background: none !important;
  width: 100%;
  color: #0E0000 !important;
  font-family: Arial;
  opacity: 0.15;
  padding: 0 !important;
  position: absolute;
  bottom: -0.25em;
  left: 50%;
  transform: translateX(-50%);
}
.pre-inc #main .cap {
  position: absolute;
  bottom: 0;
  left: 0;
  font-size: min(2svw, 10px);
  padding: 0.5em;
}
.pre-inc #contents {
  border-bottom: 1px solid #B7B7B7;
}
.pre-inc #contents .sec01 {
  position: relative;
  padding: 2em 0;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec01 {
    padding: 5em 0;
  }
}
.pre-inc #contents .sec01 .main {
  position: relative;
  margin: 0 0 1em;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec01 .main {
    margin: 0 0 2em;
  }
}
.pre-inc #contents .sec01 .main .cap {
  position: absolute;
  bottom: 0;
  left: 0;
  font-size: min(2svw, 10px);
  padding: 0.5em;
}
.pre-inc #contents .sec01 .lead {
  text-align: center;
  font-size: min(2.8svw, 14px);
  line-height: 2;
}
.pre-inc #contents .sec02 .wrap,
.pre-inc #contents .sec03 .wrap {
  padding: 30px 0;
  max-width: 1280px;
  width: 95%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .wrap,
  .pre-inc #contents .sec03 .wrap {
    padding: 100px 0;
  }
}
.pre-inc #contents .sec02 .wrap::after,
.pre-inc #contents .sec03 .wrap::after {
  content: "";
  position: absolute;
  top: 0;
  width: 1px;
  height: 100%;
  background: #A9976D;
  z-index: 1;
}
.pre-inc #contents .sec02 .wrap .copy,
.pre-inc #contents .sec03 .wrap .copy {
  font-size: min(4svw, 22px);
  color: #725A15;
  line-height: 2;
  margin: 0 0 30px;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .wrap .copy,
  .pre-inc #contents .sec03 .wrap .copy {
    margin: 0 0 70px;
  }
}
.pre-inc #contents .sec02 .wrap .txt,
.pre-inc #contents .sec03 .wrap .txt {
  font-size: min(2.8svw, 14px);
  line-height: 2;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .left,
  .pre-inc #contents .sec03 .left {
    width: 50%;
  }
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .right,
  .pre-inc #contents .sec03 .right {
    width: 50%;
  }
}
.pre-inc #contents .sec02 .sec-title,
.pre-inc #contents .sec03 .sec-title {
  font-family: "EB Garamond", serif;
  font-weight: normal;
  font-size: min(3.8svw, 20px);
  color: #725A15;
  position: relative;
}
.pre-inc #contents .sec02 {
  background: #F8F8F8;
}
.pre-inc #contents .sec02 .wrap::after {
  left: 0.5em;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .wrap::after {
    left: 50px;
  }
}
.pre-inc #contents .sec02 .left .sec-title {
  margin: 0 0 2em 0.5em;
  padding: 0 0 0.5em 2em;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .left .sec-title {
    margin: 0 0 55px 50px;
    padding: 0 0 0.5em 5em;
  }
}
.pre-inc #contents .sec02 .left .sec-title::after {
  content: "";
  width: 50%;
  height: 2px;
  background: #A9976D;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .left .sec-title::after {
    width: 187px;
  }
}
.pre-inc #contents .sec02 .left .photo {
  width: 100%;
  margin: 0 0 1em 0;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .left .photo {
    margin: 0;
  }
}
.pre-inc #contents .sec02 .right {
  padding: 0 5%;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .right {
    padding: 0 0 0 5%;
  }
}
.pre-inc #contents .sec02 .right .time {
  margin: 0 0 30px;
  width: 80%;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .right .time {
    max-width: 301px;
    margin: 0 0 30px;
  }
}
.pre-inc #contents .sec02 .line {
  max-width: 820px;
  margin: 2em auto;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .line {
    margin: 90px auto;
  }
}
.pre-inc #contents .sec02 .photobox {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .photobox {
    display: flex;
    gap: 30px;
  }
}
.pre-inc #contents .sec02 .photobox .photo-item {
  position: relative;
  font-size: 0;
  margin: 0 0 20px;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .photobox .photo-item {
    margin: 0;
  }
}
.pre-inc #contents .sec02 .photobox .photo-item .time {
  display: block;
  width: 80%;
  margin: 0 auto 10px;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec02 .photobox .photo-item .time {
    margin: 0 auto 20px;
  }
}
.pre-inc #contents .sec02 .photobox .photo-item .cap {
  position: absolute;
  bottom: 0;
  left: 0;
  font-size: min(2svw, 10px);
  color: #fff;
  padding: 0.5em;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.7), 0 0 10px rgba(0, 0, 0, 0.7), 0 0 10px rgba(0, 0, 0, 0.7);
  font-weight: bold;
}
.pre-inc #contents .sec03 .wrap::after {
  right: 0.5em;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap::after {
    right: 50px;
  }
}
.pre-inc #contents .sec03 .wrap {
  flex-direction: row-reverse;
}
.pre-inc #contents .sec03 .wrap .left {
  padding: 0 5%;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap .left {
    padding: 0 5% 0 0;
  }
}
.pre-inc #contents .sec03 .wrap .right .sec-title {
  text-align: right;
  margin: 0 0.5em 2em 0;
  padding: 0 2em 0.5em 0;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap .right .sec-title {
    margin: 0 50px 55px 0;
    padding: 0 5.5em 0.5em 0;
  }
}
.pre-inc #contents .sec03 .wrap .right .sec-title::after {
  content: "";
  width: 50%;
  height: 2px;
  background: #A9976D;
  position: absolute;
  bottom: 0;
  right: 0;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap .right .sec-title::after {
    width: 242px;
  }
}
.pre-inc #contents .sec03 .wrap .right .photo {
  width: 100%;
  margin: 0 0 1em 0;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap .right .photo {
    margin: 0;
  }
}
.pre-inc #contents .sec03 .wrap .flex {
  margin: 30px auto 0;
  display: flex;
  flex-wrap: wrap;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap .flex {
    margin: 80px auto 0;
  }
}
.pre-inc #contents .sec03 .wrap .flex .line {
  margin: 0 0 2em;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap .flex .line {
    width: 50%;
    margin: 0;
  }
}
.pre-inc #contents .sec03 .wrap .flex .time {
  text-align: center;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap .flex .time {
    width: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
.pre-inc #contents .sec03 .wrap .flex .time .image {
  width: 75%;
  margin: 0 auto;
}
@media screen and (min-width: 1024px), print {
  .pre-inc #contents .sec03 .wrap .flex .time .image {
    max-width: 345px;
    width: 100%;
    margin: 0;
  }
}/*# sourceMappingURL=access.css.map */