/* -----------------------------------------------
= main
----------------------------------------------- */
.main {
	overflow: hidden;
}
/* -----------------------------------------------
= other
----------------------------------------------- */
.other {
	scroll-margin-top: 45px;
	padding: 50px 13px;
}
.other h3 {
	margin-bottom: 25px;
	text-align: center;
}
.other h3 .en {
	display: block;
	font-family: var(--en);
	font-size: calc(2.4rem / 1.6);
	font-weight: 400;
	letter-spacing: .04em;
}
.other h3 .jp {
	display: block;
	font-family: var(--zen);
	font-size: calc(1.2rem / 1.6);
	letter-spacing: .08em;
}
.other h4 {
	margin-bottom: 30px;
	padding-block: 7px;
	color: var(--red);
	border-top: 0.5px solid #808080;
	border-bottom: 0.5px solid #808080;
	font-family: var(--zen);
	font-size: calc(1.4rem / 1.6);
	letter-spacing: .04em;
}
.other ul {
	margin: 0 20px 60px;
}
.other li {
	margin-bottom: 25px;
}
.other a {
	display: block;
}
.other .current {
	opacity: .5;
	pointer-events: none;
}
.other h5 {
	margin-block: 8px;
	font-size: calc(1.5rem / 1.6);
	font-weight: 700;
}
.other p {
	font-size: calc(1.2rem / 1.6);
	line-height: calc(18 / 12);
	letter-spacing: .12em;
}
.other .btn-more {
	position: relative;
	width: 100%;
	margin-bottom: 30px;
	padding-block: 7px;
	color: var(--red);
	border-top: 0.5px solid #808080;
	border-bottom: 0.5px solid #808080;
	font-family: var(--zen);
	font-size: calc(1.4rem / 1.6);
	letter-spacing: .04em;
}
.other .btn-more::before,
.other .btn-more::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	width: 22px;
	height: 1.5px;
	background: var(--red);
}
.other .btn-more::after {
	transform: rotate(90deg);
}
.other .btn-more[aria-expanded="true"]::after {
	display: none;
}
.other .detail-more {
	overflow: hidden;
	height: 0;
	transition: height 0.3s ease;
}
.other .more-text {
	margin-bottom: 15px;
	color: var(--red);
	font-size: calc(1.4rem / 1.6);
	font-weight: 700;
	text-align: center;
}
.other .more-index {
	position: relative;
	padding: 6px;
	color: #fff;
	background: var(--red);
	border: 0.5px solid var(--red);
	font-family: var(--en);
	font-size: calc(2.1rem / 1.6);
	font-weight: 700;
	text-align: center;
}
.other .more-index::before,
.other .more-index::after {
	content: "";
	position: absolute;
	left: 50%;
	width: .75px;
}
.other .more-index::before {
	top: -12px;
	height: 12px;
	background: var(--red);
}
.other .more-index::after {
	top: 0;
	height: 9px;
	background: #fff;
}
@media print, screen and (min-width: 768px) {/* PC */
.other {
	max-width: 1300px;
	margin-inline: auto;
	scroll-margin-top: 60px;
	padding: 160px 30px 140px;
}
.other h3 {
	margin-bottom: 25px;
}
.other h3 .en {
	font-size: calc(3.2rem / 1.6);
}
.other h3 .jp {
	font-size: calc(1.6rem / 1.6);
}
.other h4 {
	margin-bottom: 35px;
	border-top-width: 1px;
	border-bottom-width: 1px;
	font-size: calc(2.4rem / 1.6);
}
.other ul {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 50px 25px;
	margin: 0 0 60px;
}
.other li {
	margin-bottom: 0;
}
.other h5 {
	margin-block: 10px;
	font-size: calc(2rem / 1.6);
}
.other p {
	font-size: calc(1.6rem / 1.6);
	line-height: calc(24 / 16);
}
.other .btn-more {
	margin-bottom: 70px;
	border-top-width: 1px;
	border-bottom-width: 1px;
	font-size: calc(2.4rem / 1.6);
}
.other .btn-more::before,
.other .btn-more::after {
	right: 25px;
	width: 29px;
	height: 2px;
}
.other .more-text {
	margin-bottom: 20px;
	font-size: calc(2rem / 1.6);
}
.other .more-index {
	padding: 8px;
	border-width: 1px;
	font-size: calc(2.8rem / 1.6);
}
.other .more-index::before,
.other .more-index::after {
	width: 1px;
}
.other .more-index::before {
	top: -15px;
	height: 15px;
}
.other .more-index::after {
	height: 11px;
}
}/* @media */
@media (hover:hover) {
.other a {
	transition: color .3s;
}
.other a:hover {
	color: var(--red);
}
.other a .img {
	position: relative;
}
.other a .img::after {
	content: "";
	position: absolute;
	inset: 0;
	background: var(--red);
	opacity: 0;
	transition: opacity .3s;
}
.other a:hover .img::after {
	opacity: .2;
}
.other .more-index {
	transition: .3s;
}
.other .more-index:hover {
	background: #fff;
}
}/* @media */
