@charset "utf-8";

main {
	overflow-x: hidden;
}

body::-webkit-scrollbar {
	width: 5px;
}

body::-webkit-scrollbar-track {
	background-color: #ffffff;
}

body::-webkit-scrollbar-thumb {
	background-color: #656563;
}

body {
	font-weight: 500;
	line-height: 1.7;
	margin: 0;
	padding: 0;
	color: #ffffff;
	background: #757575;
	font-size: clamp(14px, 13px + 0.203vw, 16px);
	overflow-x: hidden;
}

section {
	z-index: 1;
	position: relative;
	padding-top:clamp(3.125rem, 2.607rem + 2.21vw, 4.375rem);
	padding-bottom:clamp(3.125rem, 2.607rem + 2.21vw, 4.375rem);
}



footer {
	z-index: 1;
	position: relative;
}

.bg {
	height: 100vh;
	width: 100%;
	position: fixed;
	z-index: -1;
	object-fit: cover;
	filter: brightness(70%);
}

#page_ja,
#footer_ja {
	font-family: "Noto Serif JP", serif;
}

#page_en,
#footer_en {
	font-family: "Noto Serif", serif;
}

#page_tc,
#footer_tc {
	font-family: "Noto Serif TC", serif;
}

#page_sc,
#footer_sc {
	font-family: "Noto Serif SC", serif;
}



.flex_nm {
	display: flex;
	flex-wrap: wrap;
}

.flex_sb {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.flex_cn {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}

.flex_left {
	display: flex;
	gap: 20px;
}

@media only screen and (max-width: 480px) {
	.flex_left {
		gap: 16px;
	}
}


a {
	color: #fff;
	text-decoration: none;
	cursor: pointer;
}

.font_s {
	font-size: 13px;
}

/*----- clearfix -----*/
.cf:before,
.cf:after {
	content: " ";
	display: table;
}

.cf:after {
	clear: both;
}

.cf {
	*zoom: 1;
}

.clear {
	clear: both;
}

.hidden {
	display: none;
}

/*----- responsive -----*/
.respd {
	max-width: 100%;
	height: auto;
	width
	/***/
	: auto;
}

.show_1220 {
	display: none;
}

.show_960 {
	display: none;
}

.show_768 {
	display: none;
}

.show_640 {
	display: none;
}

.show_540 {
	display: none;
}

.show_480 {
	display: none;
}

.show_1000 {
	display: none;
}

@media only screen and (max-width: 1220px) {
	.show_1220 {
		display: block;
	}

	.hide_1220 {
		display: none;
	}
}

@media only screen and (max-width: 1000px) {
	.show_1000 {
		display: block;
	}

	.hide_1000 {
		display: none;
	}

}

@media only screen and (max-width: 960px) {
	.show_960 {
		display: block;
	}

	.hide_960 {
		display: none;
	}
}

@media only screen and (max-width: 768px) {
	.show_768 {
		display: block;
	}

	.hide_768 {
		display: none;
	}

	.link-button {
		background-size: 19px;
	}
}

@media only screen and (max-width: 640px) {
	.show_640 {
		display: block;
	}

	.hide_640 {
		display: none;
	}
}

@media only screen and (max-width: 540px) {
	.show_540 {
		display: block;
	}

	.hide_540 {
		display: none;
	}
}

@media only screen and (max-width: 480px) {
	.show_480 {
		display: block;
	}

	.hide_480 {
		display: none;
	}

	.link-button {
		font-size: 16px;
	}
}

/*///////////////////////////////////////////////////////////*/
/*///////////////////////共通ブロック設計//////////////////////*/
/*///////////////////////////////////////////////////////////*/

.wrapper {
	width: 100%;
	max-width: 1280px;
	margin: auto;
	text-align: left;
	padding: 0 40px;
}

.float_l {
	float: left;
}

.float_r {
	float: right;
}

::selection {
	background: #656563;
}

/* Firefox */
::-moz-selection {
	background: #656563;
}

.fa-brands,
.fa-solid {
	font-size: 1em;
}

.fa-twitter {
	color: #fff;
}

.banner-controls {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 12px;
	margin-top: 20px;
}

.banner-controls .dots-list {
	display: flex;
	gap: 6px;
	margin: 0;
	padding-bottom: 7px;
	list-style: none;
}

.banner-controls .dots-list li button {
	font-size: 0;
	/* 数字を見えなくする */
	line-height: 0;
	/* 追加：行の高さで潰れるのを防ぐ */
	padding: 0;
	/* 追加：ボタン内の余白リセット */
	width: auto;
	height: auto;
	background: none;
	border: none;
}

.banner-controls .dots-list li button::before {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: #FFF9E3;
	vertical-align: middle;
}

.banner-controls .dots-list li button {
	width: 8px;
	height: 8px;
	margin: 0 5px;
	background: #FFF9E3;
	border-radius: 50%;
	cursor: pointer;
}

.banner-controls .dots-list li.slick-active button {
	background: #FFF9E3;
	outline: solid 2px #FFF9E3;
	outline-offset: 3.3px;
}

.banner-controls .prev,
.banner-controls .next {
	background: url(../img/slick_arrow.png);
	width: 50px;
	height: auto;
	aspect-ratio: 1 / 1;
	background-size: cover;
	z-index: 3;
}



.news-controls {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 12px;
	margin-top: 20px;
}

.news-controls .dots-list {
	display: flex;
	gap: 6px;
	margin: 0;
	padding-bottom: 7px;
	list-style: none;
}

.news-controls .dots-list li button {
	font-size: 0;
	/* 数字を見えなくする */
	line-height: 0;
	/* 追加：行の高さで潰れるのを防ぐ */
	padding: 0;
	/* 追加：ボタン内の余白リセット */
	width: auto;
	height: auto;
	background: none;
	border: none;
}

.news-controls .dots-list li button::before {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: #FFF9E3;
	vertical-align: middle;
}

.news-controls .dots-list li button {
	width: 8px;
	height: 8px;
	margin: 0 5px;
	background: #FFF9E3;
	border-radius: 50%;
	cursor: pointer;
}

.news-controls .dots-list li.slick-active button {
	background: #FFF9E3;
	outline: solid 2px #FFF9E3;
	outline-offset: 3.3px;
}

.news-prev,
.news-next {
	background: url(../img/slick_arrow.png);
	width: 50px;
	height: 50px;
	background-size: cover;
	z-index: 3;
	position: absolute;
}

.news-prev {
	top: 0;
	bottom: 0;
	left: -3%;
	margin: auto;
}

.news-next {
	top: 0;
	bottom: 0;
	right: -3%;
	margin: auto;
}


.movie-controls {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 12px;
	margin-top: 20px;
	position: relative;
	z-index: 2;
}

.movie-controls .dots-list {
	display: flex;
	gap: 6px;
	margin: 0;
	padding-bottom: 7px;
	list-style: none;
}

.movie-controls .dots-list li button {
	font-size: 0;
	/* 数字を見えなくする */
	line-height: 0;
	/* 追加：行の高さで潰れるのを防ぐ */
	padding: 0;
	/* 追加：ボタン内の余白リセット */
	width: auto;
	height: auto;
	background: none;
	border: none;
}

.movie-controls .dots-list li button::before {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: #FFF9E3;
	vertical-align: middle;
}

.movie-controls .dots-list li button {
	width: 8px;
	height: 8px;
	margin: 0 5px;
	background: #FFF9E3;
	border-radius: 50%;
	cursor: pointer;
}

.movie-controls .dots-list li.slick-active button {
	background: #FFF9E3;
	outline: solid 2px #FFF9E3;
	outline-offset: 3.3px;
}

.movie-controls .movie-prev,
.movie-controls .movie-next {
	background: url(../img/slick_arrow.png);
	width: 50px;
	height: auto;
	aspect-ratio: 1 / 1;
	background-size: cover;
	z-index: 3;
}

.movie-controls .movie-prev,
.banner-controls .prev,
.news-prev {
	transform: scale(-1, 1);
}


@media only screen and (max-width: 768px) {
	.wrapper {
		padding: 0 20px;
	}

	.movie-controls .movie-prev,
	.movie-controls .movie-next {
		width: 40px;
	}

	.banner-controls .prev,
	.banner-controls .next {
		width: 40px;
	}

	.news-prev,
	.news-next {
		width: 40px;
		height: 40px;
	}

	.banner-controls .dots-list {
		gap: 1px;
	}

	.banner-controls {
		margin-top: 5px;
	}

	.movie-controls .dots-list {
		gap: 1px;
	}
}

@media only screen and (max-width: 480px) {
	.wrapper {
		padding: 0 15px;
	}
}

.single-news_inner p {
  display: flow-root;
}
.single-news_inner img.aligncenter {
  display: block;
  margin: auto;
}
.single-news_inner img.alignleft {
  float: left;
  margin: 0 1em 1em 0;
}
.single-news_inner img.alignright {
  float: right;
  margin: 0 0 1em 1em;
}