@charset "UTF-8";

/*
  共通項目
------------------------------------*/
:root {
  --clr-base: #0f234d;
  --clr-sub: #7ec9cb;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 100px!important;
}

/* header {
  position: relative;
  z-index: 9;
} */

main {
  /* margin-top: -62px; */
  overflow: hidden;
}

section {
  position: relative;
  width: 100%;
}

p, ul {
  padding: 0;
  margin: 0;
}

a {
  color: inherit;
}

img {
  width: 100%;
  margin: 0;
}

.pc_none {
  display: none !important;
}
@media ( max-width : 767px ) {
  .pc_none {
    display: block !important;
  }
}
.sp_none {
  display: block !important;
}
@media ( max-width : 767px ) {
  .sp_none {
    display: none !important;
  }
}

.mw-960 {
  position: relative;
  width: 90%;
  max-width: 960px;
  margin-inline: auto;
}
.mw-1200 {
  position: relative;
  width: 90%;
  max-width: 1200px;
  margin-inline: auto;
}

.ff__en {
  font-family: brother-1816-printed, sans-serif;
  font-weight: 200;
}

.btn01 {
  display: block;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
  color: #fff;
  text-align: center;
  text-decoration: none;
  width: 100%;
  min-width: 300px;
  border-radius: 50px;
  padding: 1em;
}
.btn01:hover {
  opacity: 1;
}
.btn01.--clr_base {
  background: var(--clr-base);
  border: 2px solid var(--clr-base);
}
.btn01.--clr_base:hover {
  color: var(--clr-base);
  background: #fff;
}
.btn01.--clr_sub {
  background: var(--clr-sub);
  border: 2px solid var(--clr-sub);
}
.btn01.--clr_sub:hover {
  color: var(--clr-sub);
  background: #fff;
}

/*
  content
------------------------------------*/
#content.page {
  background-color: #ffffff;
  font-family: dnp-shuei-mgothic-std, sans-serif;
  font-weight: 400;
  line-height: 1.8;
  color: var(--clr-base);
}
@media ( max-width : 767px ) {
  #content.page {
    margin-top: 10px;
  }
}


/*
  con-mv
------------------------------------*/
.con-mv {
}


/*
  con-concept
------------------------------------*/
.con-concept {
  width: 100%;
  background: url('../img/shimatabi/about_bk_pc01.png') no-repeat top 25px right -60px / 535px 373px, url('../img/shimatabi/about_bk_pc02.png') no-repeat bottom 60px left 75px / 195px;
  padding: 125px 0 170px;
}
@media screen and (max-width: 999px) {
  .con-concept {
    background: url('../img/shimatabi/about_bk_sp.png') no-repeat top 35px left / 100% auto;
  }
}
@media screen and (max-width: 767px) {
  .con-concept {
    padding: 80px 0 40px;
  }
}
.con-concept .inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 999px) {
  .con-concept .inner {
    display: block;
  }
}
.con-concept .concept-ttl {
  position: relative;
  width: 47%;
  background: url('../img/shimatabi/about_bk_pc03.png') no-repeat bottom 60px left 60% / 165px 70px;
}
@media screen and (max-width: 999px) {
  .con-concept .concept-ttl {
    width: 100%;
    background: none;
  }
}
.con-concept .concept-ttl h2 {
  max-width: 260px;
  margin: auto;
}
@media screen and (max-width: 999px) {
  .con-concept .concept-ttl h2 {
    width: 40%;
  }
}
.con-concept .concept-txt {
  position: relative;
  width: 52%;
}
@media screen and (max-width: 999px) {
  .con-concept .concept-txt {
    width: 100%;
    max-inline-size: max-content;
    margin: 50px auto 0;
  }
}
.con-concept .concept-txt p {
  font-size: 18px;
  font-weight: 600;
  line-height: 2.6;
}
@media screen and (max-width: 767px) {
  .con-concept .concept-txt p {
    font-size: 15px;
    line-height: 2.2;
  }
}
.con-concept .concept-txt p:not(:first-child) {
  margin-top: 1em;
}
.con-concept .concept-obj {
  position: absolute;
  bottom: -120px;
  right: 0;
  width: 58px;
  aspect-ratio: 58/137.5;
  background: url('../img/shimatabi/about_obj01.png') no-repeat center / contain;
}
@media screen and (max-width: 999px) {
  .con-concept .concept-obj {
    position: relative;
    bottom: initial;
    right: initial;
    margin: 30px auto 0;
  }
}


/*
  map
------------------------------------*/
.con-map {
  position: relative;
}
.con-map::before,
.con-map::after {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  aspect-ratio: 1600/70;
  background-image: url(../img/shimatabi/map_wave_pc.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .con-map::before,
  .con-map::after {
    aspect-ratio: 375/30;
    background-image: url(../img/shimatabi/map_wave_sp.svg);
  }
}
.con-map::before {
  top: 0;
}
.con-map::after {
  bottom: 0;
  transform: scale(-1, -1);
}
.con-map .map-ttl {
  position: absolute;
  top: calc((60 / 375) * 100vw);
  left: 50%;
  font-size: calc((14 / 375) * 100vw);
  font-weight: 400;
  line-height: 1.4;
  text-align: center;
  color: #fff;
  background: var(--clr-sub);
  border-radius: 50px;
  width: 85%;
  padding: 0.5em;
  transform: translateX(-50%);
}
@media screen and (min-width: 1000px) {
  .con-map .map-ttl {
    display: none;
  }
}
.con-map .map-nav li {
  position: absolute;
}
.con-map .map-nav li.area01 {
  top: calc((122 / 1600) * 100vw);
  left: calc((465 / 1600) * 100vw);
}
@media screen and (max-width: 999px) {
  .con-map .map-nav li.area01 {
    top: calc((142 / 375) * 100vw);
    left: calc((120 / 375) * 100vw);
  }
}
.con-map .map-nav li.area02 {
  top: calc((330 / 1600) * 100vw);
  left: calc((582 / 1600) * 100vw);
}
@media screen and (max-width: 999px) {
  .con-map .map-nav li.area02 {
    top: calc((280 / 375) * 100vw);
    left: calc((195 / 375) * 100vw);
  }
}
.con-map .map-nav li.area03 {
  top: calc((498 / 1600) * 100vw);
  left: calc((425 / 1600) * 100vw);
}
@media screen and (max-width: 999px) {
  .con-map .map-nav li.area03 {
    top: calc((356 / 375) * 100vw);
    left: calc((91 / 375) * 100vw);
  }
}
.con-map .map-nav li.area04 {
  top: calc((550 / 1600) * 100vw);
  left: calc((425 / 1600) * 100vw);
}
@media screen and (max-width: 999px) {
  .con-map .map-nav li.area04 {
    top: calc((411 / 375) * 100vw);
    left: calc((91 / 375) * 100vw);
  }
}
.con-map .map-nav li.area05 {
  top: calc((625 / 1600) * 100vw);
  left: calc((425 / 1600) * 100vw);
}
@media screen and (max-width: 999px) {
  .con-map .map-nav li.area05 {
    top: calc((475 / 375) * 100vw);
    left: calc((91 / 375) * 100vw);
  }
}
.con-map .map-nav li.area06 {
  top: calc((692 / 1600) * 100vw);
  left: calc((322 / 1600) * 100vw);
}
@media screen and (max-width: 999px) {
  .con-map .map-nav li.area06 {
    top: calc((517 / 375) * 100vw);
    left: calc((25 / 375) * 100vw);
  }
}
.con-map .map-nav li a {
  display: block;
  color: var(--clr-base);
  text-decoration: none;
}
.con-map .map-nav li a:hover {
  color: var(--clr-sub);
  opacity: 1;
}
.con-map .map-nav li a span {
  display: inline-block;
  line-height: 1.4;
  letter-spacing: 0.05em;
}
.con-map .map-nav li a span.ja {
  font-size: calc((23 / 1600) * 100vw);
}
@media screen and (max-width: 1000px) {
  .con-map .map-nav li a span.ja {
    font-size: calc((15 / 375) * 100vw);
  }
}
.con-map .map-nav li a span.en {
  font-size: calc((14 / 1600) * 100vw);
  padding-left: 0.5em;
}
@media screen and (max-width: 1000px) {
  .con-map .map-nav li a span.en {
    font-size: calc((10 / 375) * 100vw);
  }
}


/*
  area
------------------------------------*/
.con-area {
  background: url('../img/shimatabi/area_bg_left_pc.png') no-repeat top left / 315px auto, url('../img/shimatabi/area_bg_right_pc.png') no-repeat top right / 315px auto;
  padding: 145px 0 235px;
}
@media screen and (max-width: 767px) {
  .con-area {
    background: url('../img/shimatabi/area_bg_left_sp.png') no-repeat bottom left / 155px auto, url('../img/shimatabi/area_bg_right_sp.png') no-repeat bottom right / 155px auto;
    padding: 50px 0 90px;
  }
}
.con-area .area-ttl {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
}
@media screen and (min-width: 768px) {
  .con-area .area-ttl {
    max-width: 685px;
    margin-inline: auto;
  }
}
.con-area .area-summary {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .con-area .area-summary {
    font-size: 25px;
    margin-top: 30px;
  }
}
.con-area .area-container {
  margin-top: 140px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container {
    margin-top: 80px;
  }
}
.con-area .area-container .area__item {
  position: relative;
}
.con-area .area-container .area__item:not(:first-child) {
  margin-top: 120px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item:not(:first-child) {
    margin-top: 90px;
  }
}
.con-area .area-container .area__item .item__inner {
  position: relative;
  min-height: 600px;
}
.con-area .area-container .area__item .item-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 30px;
  overflow: hidden;
}
.con-area .area-container .area__item .item-bg .item-bg__map img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.con-area .area-container .area__item .item-bg .item-bg__slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.con-area .area-container .area__item .item-bg .item-bg__slider::after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--clr-base);
  mix-blend-mode: multiply;
  opacity: 0.5;
}
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-list,
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-track,
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-slide,
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-slide > div,
.con-area .area-container .area__item .item-bg .item-bg__slider .slider__item {
  width: 100%;
  height: 100%;
}
.con-area .area-container .area__item .item-bg .item-bg__slider .slider__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-dots {
  position: absolute;
  bottom: 35px;
  left: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  z-index: 5;
}
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-dots li {
  position: relative;
  display: inline-block;
  line-height: 0;
  width: 8px;
  height: 8px;
  margin: 0;
  padding: 0;
}
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-dots li:first-child:last-child {
  display: none;
}
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-dots li button {
  position: relative;
  font-size: 0;
  line-height: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-dots li button::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--clr-base);
  border-radius: 50%;
  transform: translate(0);
  transition: .3s ease-out;
}
.con-area .area-container .area__item .item-bg .item-bg__slider .slick-dots li.slick-active button::before {
  background-color: var(--clr-sub);
}
.con-area .area-container .area__item .item-bg .item-bg__map {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 60%;
  aspect-ratio: 710/530;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  overflow: hidden;
}
@media screen and (max-width: 1000px) {
  .con-area .area-container .area__item .item-bg .item-bg__map {
    width: 100%;
    aspect-ratio: 314/215;
  }
}
.con-area .area-container .area__item.--area01 .item-bg .item-bg__map {
  background-image: url(../img/shimatabi/area01_map_pc.png);
}
@media screen and (max-width: 1000px) {
  .con-area .area-container .area__item.--area01 .item-bg .item-bg__map {
    background-image: url(../img/shimatabi/area01_map_sp.png);
  }
}
.con-area .area-container .area__item.--area02 .item-bg .item-bg__map {
  background-image: url(../img/shimatabi/area02_map_pc.png);
}
@media screen and (max-width: 1000px) {
  .con-area .area-container .area__item.--area02 .item-bg .item-bg__map {
    background-image: url(../img/shimatabi/area02_map_sp.png);
  }
}
.con-area .area-container .area__item.--area03 .item-bg .item-bg__map {
  background-image: url(../img/shimatabi/area03_map_pc.png);
}
@media screen and (max-width: 1000px) {
  .con-area .area-container .area__item.--area03 .item-bg .item-bg__map {
    background-image: url(../img/shimatabi/area03_map_sp.png);
  }
}
.con-area .area-container .area__item.--area04 .item-bg .item-bg__map {
  background-image: url(../img/shimatabi/area04_map_pc.png);
}
@media screen and (max-width: 1000px) {
  .con-area .area-container .area__item.--area04 .item-bg .item-bg__map {
    background-image: url(../img/shimatabi/area04_map_sp.png);
  }
}
.con-area .area-container .area__item.--area05 .item-bg .item-bg__map {
  background-image: url(../img/shimatabi/area05_map_pc.png);
}
@media screen and (max-width: 1000px) {
  .con-area .area-container .area__item.--area05 .item-bg .item-bg__map {
    background-image: url(../img/shimatabi/area05_map_sp.png);
  }
}
.con-area .area-container .area__item.--area06 .item-bg .item-bg__map {
  background-image: url(../img/shimatabi/area06_map_pc.png);
}
@media screen and (max-width: 1000px) {
  .con-area .area-container .area__item.--area06 .item-bg .item-bg__map {
    background-image: url(../img/shimatabi/area06_map_sp.png);
  }
}
@media screen and (min-width: 999px) {
  .con-area .area-container .area__item:nth-child(even) .item-bg .item-bg__map {
    left: 0;
  }
}
.con-area .area-container .area__item .item-content {
  position: relative;
  display: flex;
  justify-content: flex-start;
  gap: 20px;
  padding: 70px 10%;
}
@media screen and (max-width: 999px) {
  .con-area .area-container .area__item .item-content {
    display: block;
    padding: 0 5% calc(68.5% + 30px);
  }
}
@media screen and (min-width: 1000px) {
  .con-area .area-container .area__item:nth-child(odd) .item-content .item-txt01 {
    order: 3;
  }
  .con-area .area-container .area__item:nth-child(even) .item-content {
    flex-direction: row-reverse;
  }
}
.con-area .area-container .area__item .item-content .item-ttl {
  position: relative;
  transform: translateY(calc(-70px - 2.5vw));
}
@media screen and (max-width: 999px) {
  .con-area .area-container .area__item .item-content .item-ttl {
    margin: 0 auto;
    transform: translateY(-3.5vw);
  }
}
@media screen and (max-width: 599px) {
  .con-area .area-container .area__item .item-content .item-ttl {
    margin: 0 auto;
    transform: translateY(-9.5vw);
  }
}
.con-area .area-container .area__item.--area01 .item-content .item-ttl {
  width: 120px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item.--area01 .item-content .item-ttl {
    width: 72px;
  }
}
.con-area .area-container .area__item.--area02 .item-content .item-ttl {
  width: 90px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item.--area02 .item-content .item-ttl {
    width: 56px;
  }
}
.con-area .area-container .area__item.--area03 .item-content .item-ttl {
  width: 110px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item.--area03 .item-content .item-ttl {
    width: 63px;
  }
}
.con-area .area-container .area__item.--area04 .item-content .item-ttl {
  width: 95px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item.--area04 .item-content .item-ttl {
    width: 57px;
  }
}
.con-area .area-container .area__item.--area05 .item-content .item-ttl {
  width: 120px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item.--area05 .item-content .item-ttl {
    width: 72px;
  }
}
.con-area .area-container .area__item.--area06 .item-content .item-ttl {
  width: 100px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item.--area06 .item-content .item-ttl {
    width: 74px;
  }
}
.con-area .area-container .area__item .item-content p {
  letter-spacing: 0.05em;
  color: #fff;
}
@media screen and (min-width: 1000px) {
  .con-area .area-container .area__item .item-content p {
    writing-mode: vertical-rl;
    text-orientation: upright;
  }
}
@media screen and (max-width: 999px) {
  .con-area .area-container .area__item .item-content p {
    text-align: center;
  }
}
.con-area .area-container .area__item .item-content p.item-txt01 {
  font-size: 18px;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item .item-content p.item-txt01 {
    font-size: 14px;
  }
}
.con-area .area-container .area__item .item-content p.item-txt02 {
  font-size: 14px;
  font-weight: 400;
}
@media screen and (max-width: 999px) {
  .con-area .area-container .area__item .item-content p.item-txt02 {
    margin-top: 1em;
  }
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item .item-content p.item-txt02 {
    font-size: 12px;
  }
}
.con-area .area-container .area__item .item-btn {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  column-gap: 45px;
  row-gap: 15px;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .con-area .area-container .area__item .item-btn {
    margin-top: 30px;
  }
}


/*
  tour
------------------------------------*/
.con-tour {
  position: relative;
  padding-bottom: 160px;
}
@media screen and (max-width: 767px) {
  .con-tour {
    padding-bottom: 80px;
  }
}
.con-tour .tour-ttl {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .con-tour .tour-ttl {
    font-size: 24px;
  }
}
.con-tour .tour-ttl::after {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 75px;
  aspect-ratio: 75/9;
  background-image: url(../img/shimatabi/tour_obj03.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transform: translateX(-50%);
}
.con-tour .tour-ttl span {
  position: relative;
  display: inline-block;
  padding: 0 80px 30px;
}
.con-tour .tour-ttl span::before,
.con-tour .tour-ttl span::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% - 2px);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transform: translateY(-50%);
}
.con-tour .tour-ttl span::before {
  left: 0;
  width: 34px;
  aspect-ratio: 34/94;
  background-image: url(../img/shimatabi/tour_obj01.png);
}
.con-tour .tour-ttl span::after {
  right: 0;
  width: 39px;
  aspect-ratio: 39/92.5;
  background-image: url(../img/shimatabi/tour_obj02.png);
}
.con-tour .tour-summary {
  position: relative;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .con-tour .tour-summary {
    font-size: 15px;
  }
}
.con-tour .tours {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .con-tour .tours {
    margin-top: 30px;
  }
}
