html,
body {
  width: 100%;
  height: 100%;
  overflow: hidden;
  margin: 0;
  background-color: #fff;
}

#progress {
  position: absolute;
  width: 100%;
  height: 3px;
  display: none;
}

#bar {
  background-color: #fff;
  height: 100%;
  transition: width 0.1s ease;
}

#bar.hide {
  opacity: 0;
  transition: opacity 1s ease;
}

#container {
  width: 100%;
  height: 100%;
}

/*---------------------opening---------------------*/
.opening {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 460px;
  text-align: center;
  font-family: 'Zen Old Mincho', serif;
  color: #333;
  background:url(../image/opening_bg.jpg) center center no-repeat;
  background-size: cover;
  z-index: 99999;
  transition: 0.8s;
}
.opening.close {
  opacity: 0;
}
.opening h1 {
  font-size: 40px;
  margin-bottom: 30px;
  line-height: 1.3em;
}
.opening h1 span {
  display: block;
  font-size: 20px;
}
.opening h1 + p {
  font-size: 14px;
  line-height: 2em;
  margin-bottom: 30px;
}

.opening .copy{
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translate(-50%,0);
  font-size: 12px;
  line-height: 1.75em;
}
.opening .copy a{
  text-decoration: underline;
  color: #fdd000;
}

.opening .animo {
  margin: 0 auto;
  text-align: center;

}
.opening .animo-text {
  font-size: 1.9rem;
  cursor: pointer;
  display: inline-block;
}
.opening svg {
  width: 3.75rem;
  animation: 1.5s spin2 ease infinite;
}
.opening .ring {
  fill: none;
  stroke: rgba(0, 0, 0, .15);
  stroke-width: 2.5;
}
.opening .ball {
  fill: #fdd000;
  stroke: none
}
@keyframes spin2 {
  to {
      transform: rotate(360deg);
  }
}
/*---------------------guide_map---------------------*/
.guide_map {
  position: absolute;
  bottom: 30px;
  left: 0;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: saturate(180%) blur(5px);
  padding: 25px;
  transform: translate(-100%, 0);
  -webkit-transition: 0.35s ease-in-out;
  -moz-transition: 0.35s ease-in-out;
  border-radius: 0px 5px 5px 0;
  transition: 0.35s ease-in-out;
  z-index: 7000;
}
.guide_map.open {
  transform: translate(0, 0);
}
.guide_map .oc_btn {
  position: absolute;
  right: 0;
  bottom: 10px;
  width: 30px;
  height: 40px;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: saturate(180%) blur(5px);
  border-radius: 0px 5px 5px 0;
  transform: translate(100%, 0);
  cursor: pointer;
}
.guide_map .oc_btn::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  height: 19px;
  background: url(../image/guide_map-arrow.png) center center no-repeat;
  transform: translate(-50%, -50%) rotate(0);
  -webkit-transition: 0.35s ease-in-out;
  -moz-transition: 0.35s ease-in-out;
  transition: 0.35s ease-in-out;
}
.guide_map.open .oc_btn::before {
  transform: translate(-50%, -50%) rotate(180deg);
}
.guide_map button {
  position: absolute;
  background: #888;
  border: 2px solid #fff;
  width: 20px;
  height: 20px;
  padding-block: 0;
  padding-inline: 0;
  text-indent: -9999px;
  border-radius: 1000px;
  outline: none!important;
  -moz-outline-style: none;
}
.guide_map button.active {
  background: #bb0002;
  color: #fff;
}
.guide_map button:hover {
  cursor: pointer;
}
.guide_map button.btn1 {
  top: 227px;
  left: 90px;
}
.guide_map button.btn2 {
  top: 160px;
  left: 90px;
}
.guide_map button.btn3 {
  top: 60px;
  left: 90px;
}
.guide_map button.btn4 {
  top: 58px;
  left: 45px;
}
.guide_map button.btn5 {
  top: 120px;
  left: 58px;
}
.guide_map button.btn6 {
  top: 177px;
  left: 45px;
}
/*---------------------左上indicator---------------------*/
#panolens-view-indicator-container{
  transform: rotate(-90deg);
}
#panolens-view-indicator-container g path:nth-child(2) {
  display: none;
}

/*---------------------linkspot---------------------*/
.linkspot {
  max-width: 50px;
  max-height: 50px;
  min-width: 50px;
  min-height: 50px;
  color: #000;
  overflow: hidden;
}
.linkspot p {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 50px;
  border-radius: 1000px;
  cursor: pointer;
  text-indent: -9999px;
  outline: none!important;
  -moz-outline-style: none;
}

/*---------------------infospotProfile---------------------*/
.infospotProfile {
  max-width: 50px;
  max-height: 50px;
  min-width: 50px;
  min-height: 50px;
  color: #000;
  overflow: hidden;
}
.infospotProfile a {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 50px;
  border-radius: 1000px;
  cursor: pointer;
  text-indent: -9999px;
  outline: none!important;
  -moz-outline-style: none;
}
/*---------------------Photospot---------------------*/
.photospot {
  max-width: 50px;
  max-height: 50px;
  min-width: 50px;
  min-height: 50px;
  color: #000;
  overflow: hidden;
}
.photospot a {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 50px;
  border-radius: 1000px;
  cursor: pointer;
  text-indent: -9999px;
  outline: none!important;
  -moz-outline-style: none;
}


@media screen and (orientation: portrait) {
  @media screen and (max-width: 768px) {
    /*---------デバイス縦長---------*/
    .cboxPhoto {
      width: 80vw !important;
      height: auto !important;
    }
  }
}
@media screen and (orientation: landscape) {
  @media screen and (max-width: 768px) {
    /*---------デバイス横長---------*/
    .cboxPhoto {
      height: 80vh !important;
      width: auto !important;
    }
  }
}

@media screen and (max-width: 450px) {
  /*---------------------opening---------------------*/
  .opening h1 {
    font-size: 8vw;
  }
  .opening h1 span {
    display: block;
    font-size: 4.5vw;
  }
  .opening h1 + p {
    font-size: 3.5vw;
  }
  .opening .copy{
    font-size: 3vw;
    width: 100%;
  }
}


/*--.linkspot p,
.infospotProfile a,
.photospot a {
  background: rgba(255, 0, 0, 0.3);
}
--*/
