@charset "utf-8";

/* ==========================================================================
   TLNT_News_v13: Unified News Styles (List & Detail)
   修正: 長いURLなどが画面外に突き抜けないよう折り返し設定を追加
   ========================================================================== */

/* --- Common Meta Styles (Date & Category) --- */
.nws_meta {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 8px;
}

.nws_date {
	font-family: var(--font-en);
	font-size: 12px;
	color: var(--color-text-sub);
	font-weight: var(--fw-medium);
}

.nws_cat {
	font-size: 9px;
	font-weight: var(--fw-bold);
	color: var(--color-main-wh);
	background-color: var(--color-main);
	padding: 2px 8px;
	border-radius: 2px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	line-height: 1;
}

/* Category Variants */
.nws_cat.is_info {
	background-color: var(--color-main);
}
.nws_cat.is_media {
	background-color: #888;
}
.nws_cat.is_event {
	background-color: #555;
}

/* ---------------------------------------
   1. News List Page Styles (from v11)
   --------------------------------------- */

.nws_filter_area {
	margin-bottom: 40px;
}

.nws_filter_list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	list-style: none;
	padding: 0;
}

.nws_filter_btn {
	display: inline-block;
	padding: 8px 20px;
	font-size: 13px;
	font-weight: var(--fw-bold);
	background-color: var(--color-bg-base);
	border: 1px solid var(--color-border-light);
	border-radius: var(--bd-thick);
	color: var(--color-text-main);
	text-decoration: none;
	transition: all var(--transition-base);
	cursor: pointer;
}

.nws_filter_btn:hover,
.nws_filter_btn.is_active {
	background-color: var(--color-main);
	border-color: var(--color-main);
	color: var(--color-main-wh);
}

.nws_list {
	list-style: none;
	padding: 0;
	border-top: 1px solid var(--color-border-light);
}

.nws_item {
	position: relative;
	border-bottom: 1px solid var(--color-border-light);
	overflow: hidden;
}

.nws_item::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 12px;
	height: 100%;
	background-color: var(--color-main);
	transform: translateX(100%);
	transition: transform var(--transition-base);
	z-index: 2;
}

.nws_item:hover::after {
	transform: translateX(0);
}

.nws_link {
	display: flex;
	align-items: center;
	padding: 24px 0;
	text-decoration: none;
	color: var(--color-text-main);
	gap: 32px;
	transition: background-color var(--transition-base);
}

.nws_link:hover {
	opacity: 1 !important;
	background-color: rgba(0, 0, 0, 0.015);
}

.nws_thumb {
	width: 160px;
	aspect-ratio: 16 / 9;
	flex-shrink: 0;
	border-radius: var(--bd-thick);
	overflow: hidden;
	background-color: var(--color-bg-light);
	border: 1px solid var(--color-border-light);
}

.nws_thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-base);
}

.nws_link:hover .nws_thumb img {
	transform: scale(1.05);
}

.nws_body {
	flex: 1;
}

.nws_ttl {
	font-size: 16px;
	font-weight: var(--fw-bold);
	line-height: 1.5;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ---------------------------------------
   2. News Detail Page Styles
   --------------------------------------- */
.nws_detail_inner {
	max-width: var(--width-narrow);
	margin: 0 auto;
}

.nws_detail_header {
	border-bottom: 2px solid var(--color-border-light);
	padding-bottom: 40px;
	margin-bottom: 60px;
}

.nws_detail_title {
	font-size: var(--fs-xl);
	line-height: 1.5;
	margin: 30px 0 0;
	font-weight: var(--fw-bold);
	letter-spacing: 0.05em;
	color: var(--color-text-main);
}

/* --- CMS Content Styles (Rich Text) --- */
.nws_detail_body {
	font-size: var(--fs-base);
	line-height: 2;
	color: var(--color-text-main);
	letter-spacing: 0.05em;
	/* 修正：長い英単語やURLを強制的に折り返す設定 */
	overflow-wrap: break-word;
	word-break: break-word; /* 念のため古いブラウザへの互換性 */
}

.nws_detail_body p {
	margin-bottom: 2.5em;
}

.nws_detail_body h2 {
	font-size: var(--fs-lg);
	font-weight: var(--fw-bold);
	margin: 4em 0 1.5em;
	padding-bottom: 15px;
	border-bottom: 1px solid var(--color-border-dark);
}

.nws_detail_body h3 {
	font-size: var(--fs-md);
	font-weight: var(--fw-bold);
	margin: 3em 0 1em;
	border-left: 4px solid var(--color-main);
	padding-left: 15px;
}

.nws_detail_body img {
	max-width: 100%;
	height: auto;
	border-radius: var(--bd-thick);
	margin: 3em auto;
	display: block;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}

.nws_detail_body a {
	color: var(--color-main);
	text-decoration: underline;
	transition: opacity var(--transition-base);
}

.nws_detail_body a:hover {
	opacity: 0.5;
	text-decoration: none;
}

.nws_detail_body ul,
.nws_detail_body ol {
	margin-bottom: 2.5em;
	padding-left: 1.5em;
}

.nws_detail_body li {
	margin-bottom: 0.5em;
}

/* --- Detail Footer --- */
.nws_detail_footer {
	margin-top: 100px;
	padding-top: 60px;
	border-top: 1px solid var(--color-border-light);
	text-align: center;
}

/* ---------------------------------------
   3. Pagination Styles
   --------------------------------------- */
.cm_page_link.is_disabled {
	opacity: 0.3;
	cursor: default;
	pointer-events: none;
}

.cm_page_ellipsis {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 32px;
	height: 44px;
	font-size: 14px;
	color: var(--color-text-sub);
	letter-spacing: 0.1em;
}

/* ---------------------------------------
   4. SP Responsive
   --------------------------------------- */
@media (max-width: 768px) {
	.nws_link {
		flex-direction: row;
		align-items: flex-start;
		padding: 16px 0;
		gap: 16px;
	}
	.nws_thumb {
		width: 100px;
	}
	.nws_ttl {
		font-size: 13px;
		line-height: 1.4;
	}
	.nws_date {
		font-size: 11px;
	}
	.nws_item::after {
		width: 8px;
	}

	.nws_detail_header {
		padding-bottom: 30px;
		margin-bottom: 40px;
	}
	.nws_detail_title {
		font-size: var(--fs-lg);
		margin: 20px 0 0;
	}
	.nws_detail_body {
		font-size: 13px;
		line-height: 1.8;
	}
	.nws_detail_body h2 {
		font-size: var(--fs-md);
		margin-top: 3em;
	}
	.nws_detail_body h3 {
		font-size: var(--fs-base);
		margin-top: 2.5em;
	}
	.nws_detail_footer {
		margin-top: 64px;
		padding-top: 40px;
	}

	.cm_page_ellipsis {
		height: 40px;
		min-width: 24px;
		font-size: 12px;
	}
}
