﻿@charset "utf-8";


/* ------------------------------
   CHAPTER ELEMENTS
------------------------------ */
.fslider {
  width: 100%;
  text-align: left;
  position: relative;
}

.fslider:after {
  content: ".";
  display: block;
  height: 0px;
  clear: both;
  visibility: hidden;
}

.fslider ul{
  display: flex;
}
.fslider li {
  overflow: hidden;
  list-style: none;
}
.fslider a {
  text-decoration: none;
}

.slideImg {
  position: relative;
}
.slideImg li {
  width: 100%;
}
.slideImg li:not(:first-child) {
  position: absolute;
  display: none;
}

.slideImg li img {
  width: auto;
  max-width: 100%;
  vertical-align: bottom;
}
.fslider .slideImg li img {
  width: 100%;
}

.fslider.w400{ max-width: 400px;}
.fslider.w500{ max-width: 500px;}
.fslider.w600{ max-width: 600px;}
.fslider.w800{ max-width: 800px;}
.fslider.w1000{ max-width: 1000px;}

.fslider.txtbox .slideImg li{
  background-color: #fff;
}

.fslider a{
  display: block;
  height: 100%;
}

.slideImg li a:focus {
	outline: 2px solid #000;
	outline-offset: -2px;
} 

/* Controller
--------------------------- */

.controller {
	position: absolute;
	right: 0;
	background: rgba(0, 0, 0, 0.6);
	top: 15%;
	padding: 27px;
	text-align: center;
	z-index: 1;
	line-height: 30px;
}


/* PagiNation
--------------------------- */

/* ページネーションを画像の下に置くパターン */
.external .pagiNation {
  position: relative;
  display: block;
  justify-content: center;
  align-items: center;
  text-align: center;
  z-index: 1;
}

.external .pagiNation li img {
	position: absolute;
} 

/* ページネーションを画像にかぶせるパターン */
.internal .pagiNation {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0.6);
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  z-index: 1;
}

.pagiNation a {
  display: inline-block;
}

.stop a:focus-visible,
.pagiNation a:focus-visible {
  border: ridge 2px #fff;
}

.stop button:focus,
	.pagiNation a:focus {
	outline: 2px solid #fff;
}

/* ページネーションの形　■パターン */
/*
.square .pagiNation .pnNav a {
  margin: 0 2px 5px;
  width: 2.5rem;
  height: 0.3rem;
  transition: all 0.2s ease-in-out;
}
*/

.square .pagiNation .pnNav a {
  margin: 0;
	width: 2px;
	height: 32px;
	overflow: hidden;
	transition: all 0.2s ease-in-out;
	padding: 0 10px;
}

.square .pagiNation .pnNav a:after {
	content: "";
	display: block;
	width: 2px;
	height: 100%;
	background: #c6bc9b;
}

.circle .pagiNation .pnNav span {color: #ddd;}

.pagiNation .pnNav a:hover {
  opacity: 0.6;
}

.pagiNation .pnNav.active a:hover {
  opacity: 1;
}

.pagiNation .pnNav.active a:after {
  background: #c7002c;
}

.circle .pagiNation .pnNav.active span {color: #fff;}



/* SideNavi
------------------------- */
.pagiNation .btnPrev a,
.pagiNation .btnNext a {
  width: 2rem;
  height: 2rem;
  color: transparent;
  position: relative;
}


.pagiNation .btnPrev a::before,
.pagiNation .btnNext a::before {
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  border: 0px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}
	
.pagiNation .btnPrev a::before {
  pointer-events: none;
  -ms-transform: rotate(-135deg);
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}
.pagiNation .btnNext a::before {
  pointer-events: none;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}



/* 停止ボタン
------------------------- */

.stop,
.pagiNation .btnPrev,
.pagiNation .btnNext {
  width: 54px;
  height: 54px;
  flex-basis: 54px;
}
.pagiNation .btnPrev button,
.pagiNation .btnNext button {
  width: 100%;
  height: 100%;
  display: block;
  text-align: center;
  color: transparent;
  position: relative;
	border: 1px solid #c6bc9b;
}

.pagiNation .btnPrev button img,
.pagiNation .btnNext button img {
  max-width: 25px;
  width: 70%;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.pagiNation .btnPrev button img {
	transform: rotate(180deg);
}

.pagiNation .btnPrev {margin-right: auto;}
.pagiNation .btnNext {margin-left: auto; margin-right: 0;}


.pagiNation .btnPrev button:hover,
.pagiNation .btnNext button:hover {border: 1px solid #f9f8f7; }

/* 停止ボタン
------------------------- */
.stop .startBtn {
  display: none;
}
.stop {
  margin: 10px 0 0;
  padding: 0;
  bottom: 0;
  right: 0;
  z-index: 3;
}

.stop button {
	display: block;
  width: 100%;
  height: 100%;
	position: relative;
	border: 1px solid #c6bc9b;
	text-align: center;
}

.stop button:hover {cursor: pointer;}

.stop button img {
	max-width: 14px;
  width: 50%;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}


@media screen and (max-width: 1536px){
	.controller {
		top: 10%;
		padding: 20px;
		line-height: 28px;
	}	
	.square .pagiNation .pnNav a {
		height: 28px;
	}
	
	.stop {
  		margin: 5px 0 0;
	}
	.stop,
	.pagiNation .btnPrev,
	.pagiNation .btnNext {
	  width: 43px;
	  height: 43px;
	  flex-basis: 43px;
	}
}

@media screen and (max-width: 1366px){
	.controller {
		top: 8%;
		padding: 18px;
		line-height: 26px;
	}
	.square .pagiNation .pnNav a {
		height: 20px;
	}
	.stop,
	.pagiNation .btnPrev,
	.pagiNation .btnNext {
	  width: 32px;
	  height: 32px;
	  flex-basis: 32px;
	}
}


@media screen and (max-width: 959px){
	.controller {
		top: 5%;
		line-height: 20px;
		padding: 18px;
	}
	.stop,
	.pagiNation .btnPrev,
	.pagiNation .btnNext {
	  width: 1.8rem;
	  height: 1.8rem;
	  flex-basis: 1.8rem;
	}
}

@media screen and (max-width: 767px){
	.stop,
	.pagiNation .btnPrev,
	.pagiNation .btnNext {
	  width: 1.5rem;
	  height: 1.5rem;
	  flex-basis: 1.5rem;
	}
}
