@charset "utf-8";
/* spot css */

#page_spot .page_titlebox::before,
#page_spot_dtl .page_titlebox::before {
content: "SIGHTSEEING";
}

/* スポット一覧ページ
-------------------------------------------------- */

/*-------------------------------------------------
intro
-------------------------------------------------*/

.intro_txt {
font-size: 1.5rem;
line-height: 200%;
letter-spacing: 0.2em;
display: block;
text-align: center;
margin-bottom: 50px;
}

@media all and (max-width : 767px ){
.intro_txt {
font-size: 1.2rem;
line-height: 180%;
letter-spacing: 0.15em;
margin-bottom: 30px;
}
}
.generic {
display: none;
}

@media all and (max-width : 1200px ){
.generic {
display: block;
}
}

@media all and (max-width : 767px ){
.generic {
display: none;
}
}

/*-------------------------------------------------
spot_box
-------------------------------------------------*/

.spot_box {
width: calc(33.3333333% - 60px / 3);
margin-right: 30px;
margin-bottom: 40px;
}
.spot_box:nth-child(3n) {
margin-right: 0px;
}
.spot_imgbox {
width: 100%;
overflow: hidden;
background: #000;
margin-bottom: 20px;
height:250px;
}
.spot_imgbox img {
width: 100%;
transition-duration: 0.7s;
}
.spot_box a:hover .spot_imgbox img {
transform: scale(1.05);
transition-duration: 0.7s;
opacity: .8;
}
.spot_box .spot_title {
font-family: "Noto Serif JP", serif;
font-size: 1.8rem;
font-weight: 500;
letter-spacing: 0.2em;
transition-duration: 0.7s;
color: #fff;
display: block;
text-align: center;
}
.spot_box a:hover .spot_title {
color: #B29458;
transition-duration: 0.7s;
}
.spot_box_wrap {
display: flex;
flex-wrap: wrap;
}

@media all and (max-width : 1024px ){
.spot_box {
width: calc(33.3333333% - 40px / 3);
margin-right: 20px;
margin-bottom: 30px;
}
.spot_box .spot_title {
font-size: 1.6rem;
letter-spacing: 0.15em;
}
}

@media all and (max-width : 820px ){
.spot_box .spot_title {
font-size: 1.4rem;
letter-spacing: 0.1em;
}
}

@media all and (max-width : 767px ){
.spot_box {
width: calc(50% - 15px / 2);
margin-right: 15px;
margin-bottom: 20px;
}
.spot_box:nth-child(3n) {
margin-right: 15px;
}
.spot_box:nth-child(2n) {
margin-right: 0px;
}
.spot_imgbox {
margin-bottom: 10px;
}
.spot_box .spot_title {
font-size: 1.2rem;
letter-spacing: 0.15em;
}
}


/* スポット詳細ページ
-------------------------------------------------- */

#page_spot_dtl .spot_title {
font-family: "Noto Serif JP", serif;
font-weight: 500;
font-size: 2.2rem;
padding: 0 10px 10px 5px;
border-bottom: solid 1px #999;
letter-spacing: 0.2em;
margin-bottom: 30px;
}
#page_spot_dtl .intro_box {
padding: 15px 50px;
border: solid 1px #B29458;
margin-bottom: 40px;
}
#page_spot_dtl .intro_box dl {
display: flex;
align-items: center;
color: #B29458;
font-size: 1.6rem;
padding: 20px 10px;
border-bottom: solid 1px #B29458;
}
#page_spot_dtl .intro_box dl:last-of-type {
border-bottom: none;
}
#page_spot_dtl .intro_box dl dt {
padding-left: 30px;
}
#page_spot_dtl .intro_box dl dt.time {
background-image: url("../img/spot/icon_time.svg");
background-repeat: no-repeat;
background-position: left center;
}
#page_spot_dtl .intro_box dl dt.access {
background-image: url("../img/spot/icon_pin.svg");
background-repeat: no-repeat;
background-position: left center;
}
#page_spot_dtl .intro_box dl dd {
padding-left: 10px;
}




/*-------------------------------------------------
	 swiper
-------------------------------------------------*/

.item-slider {
overflow: hidden;
}
.item-slider .swiper-container {
width: 100%;
height: 100%;
}
.item-slider-wrap {
max-width: 98rem;
}

@media screen and (min-width: 768px) {
.item-slider-wrap {
display: flex;
align-items: stretch;
}
}

.item-slider-image {
position: relative;
width: 100%;
height: 100%;
overflow: hidden;
cursor: pointer;
}
.item-slider-image img {
width: 100%;
height: 520px;
object-fit: contain;
}
.item-slider-image figcaption {
position: absolute;
bottom: 0;
left: 0;
width: 100%;
padding: 1rem;
background-color: rgba(0, 0, 0, 0.7);
font-size: 1.5rem;
color: #fff;
line-height: 1.6;
text-align: center;
}

@media screen and (max-width: 767px) {
.item-slider-images {
width: 100%;
}
.item-slider-image img {
height: 233px;
}
.item-slider-image figcaption {
font-size: 1.2rem;
padding: 0.6rem;
}
}

@media screen and (min-width: 768px) {
.item-slider-images {
width: 79.5918367347%;
}
}

.item-slider-thumbox {
display: flex;
flex-direction: column;
}

@media screen and (max-width: 767px) {
.item-slider-thumbox {
flex-direction: row;
align-items: center;
margin-right: 0;
margin-top: 24px;
width: 100%;
}
}

@media screen and (min-width: 768px) {
.item-slider-thumbox {
width: 18.8775510204%;
margin-left: 1.5rem;
padding: 0 1.5rem;
border: solid 1px #B29458;
}
}

.item-slider-prev, 
.item-slider-next {
display: flex;
align-items: center;
justify-content: center;
height: 4.8rem;
user-select: none;
text-align: center;
cursor: pointer;
}

@media screen and (max-width: 767px) {
.item-slider-prev,
.item-slider-next {
height: auto;
width: 2rem;
}
}

.item-slider-prev::before, 
.item-slider-next::before {
content: "";
width: 1rem;
height: 1rem;
border-bottom: 1px solid #B29458;
border-right: 1px solid #B29458;
}
.item-slider-prev:focus,
.item-slider-next:focus {
outline: none;
}
.item-slider-prev::before {
transform: rotate(135deg);
}

@media screen and (min-width: 768px) {
.item-slider-prev::before {
transform: rotate(-135deg);
}
}

.item-slider-next::before {
transform: rotate(-45deg);
}

@media screen and (min-width: 768px) {
.item-slider-next::before {
transform: rotate(45deg);
}
}

.item-slider-thumbs {
width: auto;
height: 103px;
overflow: hidden;
}
.item-slider-thumbs img {
width: 100%;
height: 100%;
object-fit: cover;
}

@media screen and (max-width: 767px) {
.item-slider-thumbs {
width: calc(100% - 50px);
height: 58px;
margin: 0 1.6rem;
}
}

@media screen and (min-width: 768px) {
.item-slider-thumbs {
height: 100%;
}
}

.item-slider-thumbs .swiper-slide {
cursor: grab;
}
.item-slider-thumbs .swiper-slide {
cursor: pointer;
opacity: 0.5;
transition: opacity 0.5s;
}
.item-slider-thumbs .swiper-slide.swiper-slide-thumb-active {
opacity: 1;
height: 58px;
}
.item-slider-thumbs .swiper-slide.swiper-slide-thumb-active img {
outline: 2px solid #B29458;
outline-offset: -2px;
}

/* スポット紹介文
-------------------------------------------------- */

#page_spot_dtl .spot_txt {
line-height: 200%;
padding-top: 30px;
margin-bottom: 80px;
}
#page_spot_dtl .menu_info {
font-family: "Noto Serif JP", serif;
font-size: 2.0rem;
font-weight: 500;
letter-spacing: 0.2em;
padding: 0 10px 10px 5px;
border-bottom: solid 1px #999;
margin-bottom: 20px;
}
#page_spot_dtl .info_box {
width: 47.96%;
padding: 20px 10px;
border-bottom: solid 1px #999;
display: flex;
align-items: center;
letter-spacing: 0.2em;
}
#page_spot_dtl .info_box dt {
width: 25%;
}
#page_spot_dtl .info_box dd {
width: 75%;
}
#page_spot_dtl .info_box_wrap {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
margin-bottom: 80px;
}

/*-------------------------------------------------
アクセスマップ
-------------------------------------------------*/

#page_spot_dtl .gmap {
height: 0;
overflow: hidden;
padding-bottom: 44.18%;
position: relative;
}
#page_spot_dtl .gmap iframe {
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 100%;
}
#page_spot_dtl .gmap_wrap {
padding-top: 10px;
margin-bottom: 50px;
}

@media all and (max-width : 767px ){
#page_spot_dtl .spot_title {
font-size: 1.5rem;
padding: 0 10px 10px 5px;
letter-spacing: 0.15em;
margin-bottom: 20px;
}
#page_spot_dtl .intro_box {
padding: 5px 20px;
}
#page_spot_dtl .intro_box dl {
font-size: 1.3rem;
padding: 15px 10px;
}
#page_spot_dtl .intro_box dl dt {
padding-left: 25px;
}
#page_spot_dtl .intro_box dl dt.time {
background-size: 15%;
}
#page_spot_dtl .intro_box dl dt.access {
background-size: 13%;
}
#page_spot_dtl .intro_box dl dd {
padding-left: 0px;
}
#page_spot_dtl .spot_txt {
font-size: 1.3rem;
line-height: 180%;
padding-top: 20px;
margin-bottom: 40px;
}
#page_spot_dtl .menu_info {
font-size: 1.6rem;
padding: 0 10px 10px 5px;
margin-bottom: 5px;
}
#page_spot_dtl .info_box {
width: 100%;
font-size: 1.3rem;
padding: 20px 10px;
display: flex;
align-items: center;
letter-spacing: 0.15em;
}
#page_spot_dtl .info_box_wrap {
margin-bottom: 40px;
}
#page_spot_dtl .gmap_wrap {
padding-top: 15px;
margin-bottom: 20px;
}
#page_spot_dtl .link_btn_box {
margin-bottom: 15px;
}
}