/*=======================
  common
=======================*/

body {
  font-family: 'Noto Sans JP', sans-serif;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-size: 16px;
  font-weight: 500;
}

.title {
  margin-bottom: 20px;
  width: 30%;
  margin: 0 auto;
  margin-bottom: 20px;
}

.inner {
  padding-top: 80px;
  margin: 0 auto;
}

.section-description {
  text-align: center;
  margin-bottom: 50px;
}

.ja {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.1rem;
}

.sec-des {
  line-height: 2;
  font-size: 14px;
  margin-top: 30px;
}

.non-active {
  pointer-events: none;
}
.non-active:hover {
  opacity: 1;
}

/*=======================
  top
=======================*/

.top {
  position: relative;
}

.bredcrumb {
  display: flex;
  color: #FFF;
  padding-top: 20px;
  padding-left: 30px;
  position: absolute;
}

.bredcrumb::after {
  content: "";
  background: #FFF;
  width: 98%;
  height: 1px;
  z-index: 10;
  display: block;
  position: absolute;
  left: 0;
  top: 50px;
}

.bredcrumb-item {
  margin-right: 10px;
  margin-left: 10px;
}

.bredcrumb-item:not(:last-child)::after {
  content: '/';
  padding-left: 10px;
}


.top-title {
  width: 52%;
  margin: 0 auto;
  position: absolute;
  top: 98px;
  left: 50%;
  transform: translateY(-8%) translateX(-50%);
}

.top-pic1 {
  position: absolute;
  width: 18%;
  left: 3%;
  top: 9%;
}

.top-pic2 {
  width: 15%;
  position: absolute;
  top: 64%;
}

.top-item {
  position: absolute;
  width: 20%;
  top: 84%;
  left: 10%;
}

.top-pic3 {
  width: 23%;
  position: absolute;
  right: 0;
  top: 0;
}

.top-pic4 {
  position: absolute;
  width: 16%;
  top: 31%;
  right: 30px;
}

.top-pic5 {
  position: absolute;
  right: 12%;
  top: 63%;
  width: 8%;
}

.top-lead {
  text-align: center;
  position: absolute;
  line-height: 2;
  left: 50%;
  transform: translateX(-50%);
  top: 50%;
  width: 100%;
  font-size: 14px;
  z-index: 1;
}

.bgtext {
  background-color: #F8F6DD;
  width: 43%;
  margin: 0 auto;
}

.top-bottom2 {
  width: 20%;
  position: absolute;
  left: 78%;
  top: 80%;
}

.bottom-space {
  margin-bottom: 25px;
}

.top-bottom {
  top: 70%;
  display: block;
  position: absolute;
  width: 100%;
}

/*=======================
  video
=======================*/

.video {
  margin: 0 auto;
  display: block;
  text-align: center;

}

.video1 {
  position: absolute;
  top: 59%;
  left: 6%;
  width: 11%;
}



.video2 {
  position: absolute;
  width: 17%;
  right: 36px;
  top: 41%;
}


.movie-inner {
  padding-top: 150px;
  padding-bottom: 80px;
  position: relative;
}

/*=======================
  guides
=======================*/

.boat {
  position: absolute;
  width: 10%;
  right: 12%;
  top: 6%;
}

.guides-container {
  position: relative;
}


.section-description::after {
  content: '';
  background-image: url(../img/boat.png);
  display: inline-block;
  background-repeat: no-repeat;
  width: 100%;
  height: 100%;
}

.gudes1.gudes1--sm {
  padding-top: 50px;
  padding-left: 50px;
}

.gudes1 a {
  display: block;
  width: 100%;
  height: 100%;
}
.gudes1 a:hover {
  opacity: 0.7;
}

.gudes2 {
  width: 33%;
  padding-top: 50px;
}

.box {
  display: flex;
}

.guidetext {
  display: flex;
  gap: 10px;
  margin-top: 20px;
  font-size: 10px;
}

.guides-text {
  padding-bottom: 20px;
  padding-right: calc(80 / 375 * 100%);
  font-size: 12px;
  text-align: right;
}

.guides-list {
  display: flex;
  justify-content: center;
  gap: 50px;
  padding-bottom: 50px;
  max-width: 1300px;
  margin: 0 auto;
  flex-wrap: wrap;
}

.guides-box {
  width: 30%;
}


.bg {
  background-color: #F4F4F4;
  width: 50px;
  margin-bottom: 10px;
  text-align: center;

}



.bg-box {
  width: 50px;
  font-size: 12px;
}

.text-box {
  font-size: 12px;
}

.text-box a{
  text-decoration: underline;
}

.text {
  display: block;
  margin-bottom: 10px;
}

.text a {
	text-decoration: underline;
}

.name {
  font-size: 24px;
  letter-spacing: 0.17rem;
  text-align: center;
  margin-top: 10px;
  font-family: 'Noto Sans JP', sans-serif;
}

.gomes {
  font-size: 22px;
  letter-spacing: 0rem;
}

.comming {
  font-size: 24px;
  letter-spacing: 0.17rem;
  text-align: center;
  margin-top: 10px;
  font-family: 'Noto Sans JP', sans-serif;
}

.commingsoon {
  width: 85%;
  padding-top: 25px;
  margin: 0 auto;
}

.en {
  text-align: center;
  margin-top: 5px;
  font-size: 10px;
  font-family: 'Noto Sans JP', sans-serif;
}

.soon {
  background-color: #F4F4F4;
  padding: 60px;
  font-family: 'Noto Sans JP', sans-serif;
  margin-top: 20px;
  line-height: 2;
  text-align: center;
  letter-spacing: 0.1rem;
}


/*=======================
  picture
=======================*/

.picture-section {
  position: relative;
}

.picture1 {
  position: relative;
  left: -50px;
  width: 60%;
  top: 100px;
}

/*
.picture-section::after{
    content: '';
    background-image: url(../img/picture2.png);
    position: absolute;
    display: inline-block;
    background-size: contain;
    vertical-align: middle;
    right: 0;
    z-index: 2;
    width: 64%;
}

*/


.picture2 {
  position: absolute;
  right: 0;
  top: 3%;
  width: 80%;
  z-index: 2;
}



/*=======================
  tours
=======================*/

.tours-section {
  margin-top: 250px;
  padding-bottom: 100px;
  background-color: #F4F4F4;
  position: relative;
}

.tours-section::after {
  content: '';
  background-image: url(../img/horse.png);
  display: inline-block;
  background-repeat: no-repeat;
  position: absolute;
  background-size: contain;
  vertical-align: middle;
  width: 25%;
  height: 14%;
  z-index: 1;
  /* top: 729px; */
  left: 30px;
  bottom: 0;
}

.tours-section::before {
  content: '';
  background-image: url(../img/picture3.png);
  display: inline-block;
  position: absolute;
  background-size: contain;
  vertical-align: middle;
  width: 27%;
  height: 100%;
  background-repeat: no-repeat;
  top: -8%;
  left: 0;
}


.tours-area {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  overflow: auto;
  padding-bottom: 50px;
}

.tours-box {
  float: left;
  width: 45%;
  margin: 0 2.5%;
  margin-bottom: 80px;
}

.to01 {
  text-align: center;
}

.to01:hover {
  opacity: 0.8;
}

.btn {
  border: 1px solid #8DCDED;
  width: 17%;
  text-align: center;
  margin: 0 auto;
  height: 50px;
  border-radius: 20px 5px 5px 5px;
  background-color: #8DCDED;
  color: #FFF;
  font-size: 18px;
  line-height: 45px;
}

.btn:hover {
  opacity: 0.8;
}

.to-title {
  position: relative;
  padding-left: 20px;
  font-size: 20px;
  margin-bottom: 8px;
  height: 100px;
}
.to-title::before {
  content: '';
  background: #000;
  display: block;
  height: 70px;
  width: 2px;
  position: absolute;
  left: 0;
}
@media screen and (max-width : 768px)  {
  .to-title {
    height: 100%;
    margin-bottom: 32px;
  }
  .to-title::before {
    height: 100%;
  }
}

.to-pic {
  margin-bottom: 20px;
}

.to-des {
  height: 100px;
  padding-left: 20px;
  font-size: 12px;
}

.textarea {
  position: relative;
  display: inline-block;
  text-align: left;
  max-width: 680px;
}

/*=======================
  access
=======================*/

.house {
  position: absolute;
  top: 430%;
}


.access::before {
  content: '';
  background-image: url(../img/treatment.png);
  display: inline-block;
  position: absolute;
  background-size: contain;
  vertical-align: middle;
  width: 40%;
  height: 100%;
  background-repeat: no-repeat;
  top: -3%;
  right: 0;
  opacity: 0.5;
}

.access {
  padding-bottom: 400px;
  padding-top: 100px;
  position: relative;
  background-image: url("../img/accessbg.png");
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center bottom;
}


.map-picture {
  margin: 0 auto;
  text-align: center;
  width: 50%;
}

.ac.map {
  position: relative;
  margin-top: 50px;
}

.accesstreat {
  width: 12%;
  position: absolute;
  right: 100px;
}

.accesstitle {
  margin-bottom: 20px;
}

.airport-picture {
  margin: 0 auto;
  width: 40%;
  text-align: center;
}

.ferry-picture {
  width: 60%;
  margin: 0 auto;
}

.h3 {
  text-align: center;
  margin-bottom: 20px;
  font-size: 20px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: normal;
}

.ac {
  margin-top: 80px;
}

.bus-box {
  display: flex;
  justify-content: center;
  gap: 30px;
  width: 70%;
  margin: 0 auto;
}

.ac-btn {
  border: 1px solid #f4f4f4;
  width: 20%;
  text-align: center;
  margin: 0 auto;
  height: 60px;
  border-radius: 5px 20px 5px 20px;
  background-color: #F4F4F4;
  color: #000;
  font-size: 16px;
  line-height: 55px;
  margin-top: 100px;
  position: relative;
  letter-spacing: 0.14rem;
  font-family: 'Noto Sans JP', sans-serif;
}

.ac-btn:hover {
  opacity: 0.7;
}

.ac-btn::before {
  background: transparent no-repeat center center/contain;
  content: "";
  background-image: url("../img/arrow.png");
  display: block;
  position: absolute;
  transition: background-image 0.3s linear;
  left: -70px;
  top: 5px;
  width: 30%;
  height: 80%;
  background-repeat: no-repeat;
  background-size: contain;
}


@media screen and (min-width : 1700px) {
  .top-lead {
    font-size: 18px;
  }

  .bgtext {
    width: 45%;
  }

  .bredcrumb::after {
    width: 98%;
  }

  .movie-inner {
    padding-top: 150px;
  }

  .picture2 {
    width: 70%;

  }
}

@media screen and (max-width : 1250px) {
  .video1 {
    top: 91%;
  }

  .video2 {
    right: 11px;
    top: 85%;
  }
}


@media screen and (max-width : 1024px) {

  .bredcrumb::after {
    width: 98%;
  }


  .bottom-space {
    margin-bottom: 14px;
  }

  .top-lead {
    font-size: 12px;

  }

  .top-pic2 {
    top: 59%;
    width: 17%;
  }

  .top-pic5 {
    top: 51%;
  }

  .top-item {
    width: 20%;
    top: 82%;
    left: 10%;
  }

  .top-title {
    top: 79px;
  }

  .top-bottom2 {
    top: 63%;
    z-index: 2;
  }

  .bgtext {
    width: 58%;
  }

  .video {
    height: 400px;
  }




  .picture1 {
    top: 130px;
  }

  .picture2 {
    top: 24%;
  }

  .guides-box {
    width: 25%;
  }

  .name {
    padding-left: 0px;
  }

  .en {
    padding-left: 0px;
  }

  .soon {
    padding: 49px;
  }

  .ac-btn {
    width: 26%;
  }

  .access::before {
    width: 42%;
    top: -3%;
  }

  .tours-section::after {
    /* top: 90%; */
    bottom: -30px;
  }

  .btn {
    width: 24%;
  }
}

@media screen and (max-width : 900px) {
  .bgtext {
    width: 94%;
  }

  .bottom-space {
    margin-bottom: -2px;
  }

  .top-lead {
    width: 70%;
  }

  .video2 {
    right: 19px;
    top: 87%;
  }

  .video1 {
    top: 92%;
  }
}



@media screen and (max-width : 768px) {

  .bredcrumb {
    position: absolute;
    font-size: 10px;
    display: flex;
    padding-left: 10px;
    padding-right: 10px;
    padding-top: 10px;
  }

  .bredcrumb::after {
    width: 95%;
    top: 30px;
  }

  .bredcrumb-item {
    margin-left: 0;
    margin-right: 5px;
  }

  .bredcrumb-item:not(:last-child)::after {
    content: '/';
    padding-left: 5px;
  }

  .top-bottom {
    top: 74%;
  }

  .top-lead {
    line-height: 1.7;
    font-size: 15px;
    top: 37%;
    width: 93%;
  }

  .top-pic1 {
    width: 24%;
    left: -1%;
    top: 5%;
  }

  .top-pic3 {
    width: 25%;
  }

  .top-pic5 {
    right: 5%;
    top: 74%;
    width: 12%;
  }

  .top-pic4 {
    top: 16%;
    right: 0px;
  }

  .top-pic2 {
    top: 78%;
  }

  .top-title {
    width: 86%;
    top: 15%;
  }

  .top-item {
    width: 31%;
    top: 88%;
    left: 10%;
    z-index: 1;
  }


  .bgtext {
    width: 69%;
  }

  .bottom-space {
    margin-bottom: 15px;
  }

  .inner {
    padding-top: 120px;
  }

  .movie-section {
    padding-top: 50px;
  }

  .movie-inner {
    padding-bottom: 0px;
    padding-top: 50px;
  }

  .video {
    display: block;
    height: 300px;
  }

  .video1 {
    top: 110%;
    width: 16%;
    left: 3%;
  }

  .video2 {
    right: 3px;
    top: 110%;
    width: 20%;
  }

  .title {
    width: 60%;
    margin-bottom: 10px;
    margin-top: 5px;
  }

  .ja {
    font-size: 14px;
  }

  .boat {
    width: 20%;
    right: 76%;
    top: 60%;
  }

  .section-description {
    margin-bottom: 20px;
  }



  .guides-list {
    /* flex-direction: column; */
    justify-content: initial;
    flex-wrap: initial;
    margin-left: 40px;
    margin-bottom: 50px;
    gap: 40px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
  }


  .sec-des {
    width: 80%;
    margin: 0 auto;
    margin-top: 20px;
  }

  .guides-box {
    flex: 0 0 auto;
    width: 60%;
    min-width: 225px;
    margin: 0 auto;
    scroll-snap-align: start;
  }

  .gudes1.gudes1--sm {
    padding-top: 30px;
    padding-left: 30px;
  }

  .name {
    padding-left: 0px;
  }

  .en {
    padding-left: 0px;
  }

  .tours-section::before {
    width: 86px;
    height: 120px;
    top: -2%;
  }

  .tours-section::after {
    width: 30%;
    height: 120px;
    top: 94%;
  }

  .btn {
    width: 55%;
  }

  .soon {
    padding: 40px;
  }

  .picture1 {
    width: 80%;
    top: -59px;
  }

  .picture2 {
    top: -5%;
    width: 85%;
  }

  .tours-section {
    margin-top: 0px;
  }

  .treatment {
    background-size: contain;
    vertical-align: middle;
    width: 54%;
    top: -2%;
  }

  .to01 {
    width: 80%;
    margin: 0 auto;
  }

  .access {
    padding-top: 50px;
    padding-bottom: 300px;
  }

  .ac {
    margin-top: 30px;
  }

  .accesstitle {
    width: 40%;
    display: block;
    margin: 0 auto;
    margin-bottom: 10px;
  }

  .access::before {
    top: -2%;
    width: 47%;
  }

  .h3 {
    font-size: 16px;
  }

  .map-picture {
    width: 70%;
  }

  .airport-picture {
    width: 70%;
  }

  .ferry-picture {
    width: 85%;
  }

  .accesstreat {
    right: 10px;
  }

  .bus-box {
    flex-direction: column;
    gap: 15px;
  }

  .ac-btn {
    width: 60%;
    font-size: 14px;
  }

  .ac-btn::before {
    left: -43px;
    width: 23%;
  }

}

@media screen and (max-width:550px) {


  .tours-section::after {
    width: 35%;
    height: 120px;
    top: 95%;
    left: 10px;
  }

  .picture1 {
    width: 84%;
  }

  .picture2 {
    width: 88%;
  }

  .top-lead {
    font-size: 10px;
    top: 42%;
  }

  .top-title {
    top: 18%;
  }

  .bottom-space {
    margin-bottom: 10px;
  }

  .video {
    height: 200px;
  }


}


@media screen and (max-width:375px) {
  .top-pic2 {
    top: 82%;
    z-index: 1;
  }

  .top-pic1 {
    width: 29%;
    left: -2%;
    top: 7%;
  }

}


.movie-inner {
  width: 90%;
  max-width: 900px;
  margin: 0px auto;
}




.pc {
  display: block;
}

.sp {
  display: none;
}






.special {
  padding-bottom: 100px;
}



.withbox {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  overflow: auto;
}

.with_unit {
  float: left;
  width: 30%;
  margin: 0 1.5%;
}

.with_unit img {
  border-radius: 20px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
}

.withmi {
  text-align: center;
  padding: 20px 0 15px 0;
  font-size: 20px;
  font-weight: bold;
  height: 100px;
  vertical-align: middle;
}


.map_shita {
  max-width: 700px;
  width: 90%;
  margin: 0 auto;
  padding-top: 50px;
  text-align: center;
}

.map_shita a {
  color: #5B92AB;
  font-size: 20px;
  border-bottom: solid 1px #5B92AB;
  padding-bottom: 3px;
  font-weight: bold;
}


.prof {
  font-size: 12px;
  color: gray;
}

.inter {
  padding-top: 20px;
  width: 100%;
  text-align: center;
  display: flex;
}

.inter a {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #A3D5EE;
  color: white;
  text-align: center;
  padding: 3px 20px 5px 20px;
  font-size: 12px;
  width: 100%;
}
@media screen and (max-width : 768px) {
  .inter a {
    width: 80%;
    margin-right: auto;
    margin-left: auto;
  }
}

.inter a.ki {
  background-color: #F4D22A;
  color: black;
}



@media screen and (max-width : 768px) {

  .pc {
    display: none;
  }

  .sp {
    display: block;
  }


  .special {
    padding-bottom: 30px;
    padding-top: 50px;
  }



  .withbox {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    overflow: auto;
  }

  .with_unit {
    float: left;
    width: 90%;
    margin: 0 5%;
    margin-bottom: 40px;
  }

  .with_unit img {
    border-radius: 20px;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
  }

  .withmi {
    text-align: center;
    padding: 20px 0 15px 0;
    font-size: 20px;
    font-weight: bold;
    height: auto;
    vertical-align: middle;
  }


  .tours-area {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    overflow: auto;
    padding-bottom: 50px;
  }

  .tours-box {
    float: left;
    width: 95%;
    margin: 0 2.5%;
    margin-bottom: 30px;
  }


  .guides-container {
    padding-bottom: 100px;
  }


}