/**
 * 受賞者一覧表のスタイル
 */

/* テーブルラッパー（横スクロール対応・広幅表示） */
.award-table-wrapper {
	position: relative;
	margin: 20px 0;
	/* entry-contentの幅制限を超えて広く表示 */
	width: calc(100vw - 40px);
	max-width: 1200px;
	margin-left: 50%;
	transform: translateX(-50%);
}

.award-table-wrapper .award-winner-table {
	margin: 0;
}

/* スクロールコンテナの幅を親要素いっぱいに */
.award-table-wrapper .award-table-scroll {
	width: 100%;
}

/* スクロールヒント（モバイル用） */
.award-table-scroll-hint {
	display: none;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 8px 16px;
	margin-bottom: 8px;
	background: linear-gradient(90deg, #e8f4fd 0%, #d4edfc 100%);
	border-radius: 4px;
	font-size: 13px;
	color: #1a73e8;
}

.award-table-scroll-hint::before {
	content: "←";
	animation: scroll-hint-arrow 1s ease-in-out infinite alternate;
}

.award-table-scroll-hint::after {
	content: "→";
	animation: scroll-hint-arrow 1s ease-in-out infinite alternate-reverse;
}

@keyframes scroll-hint-arrow {
	from { opacity: 0.4; }
	to { opacity: 1; }
}

/* スクロールコンテナ */
.award-table-scroll {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	position: relative;
}

/* スクロール可能時の右端グラデーション */
.award-table-scroll::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 30px;
	height: 100%;
	background: linear-gradient(to left, rgba(255,255,255,0.9), transparent);
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.3s;
}

.award-table-scroll.is-scrollable::after {
	opacity: 1;
}

.award-table-scroll.is-scrolled-end::after {
	opacity: 0;
}

/* テーブル全体のスタイル */
.award-winner-table {
	width: max-content;
	min-width: 100%;
	border-collapse: collapse;
	margin: 20px 0;
	font-size: 14px;
	text-align: left;
}

/* スクロールヒント表示条件 */
.award-table-scroll.is-scrollable + .award-table-scroll-hint,
.award-table-scroll-hint.is-visible {
	display: flex;
}

/* モバイル時のスタイル */
@media screen and (max-width: 768px) {
	.award-table-scroll-hint {
		display: flex;
	}
}

.award-winner-table th,
.award-winner-table td {
	border: 1px solid #ddd;
	padding: 8px;
	white-space: nowrap;
}

.award-winner-table th {
	background-color: #f4f4f4;
	font-weight: bold;
	text-align: center;
}

.award-winner-table tr:nth-child(even) {
	background-color: #f9f9f9;
}

.award-winner-table tr:hover {
	background-color: #f1f1f1;
}

.award-winner-table td:first-child,
.award-winner-table th:first-child {
	text-align: center;
	width: 80px;
}

.award-winner-table td:last-child {
	color: #555;
	font-style: italic;
}

.award-winner-table caption {
	caption-side: top;
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 10px;
}
