/* Excel Timetable — front-end styles (Saltwater-style defaults via CSS vars) */

.extt-container {
	--extt-filter-bg: #ea9bb6;
	--extt-header-bg: #16224c;
	--extt-header-text: #ffffff;
	--extt-row-alt: #e9f2fb;
	--extt-cell-text: #8a7355;
	--extt-accent: #16224c;
	--extt-page-active: #2e8bc0;
	max-width: 100%;
	margin: 0 0 2rem;
	font-family: inherit;
}

.extt-intro {
	text-align: center;
	font-weight: 700;
	color: var(--extt-accent);
	margin: 0 0 1.25rem;
}

/* Filter bar */
.extt-filter-bar {
	background: var(--extt-filter-bg);
	padding: 1.5rem 1.5rem;
	border-radius: 4px;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 1.5rem;
	margin-bottom: 2rem;
}

.extt-filter-group {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.extt-filter-group label {
	font-weight: 700;
	color: var(--extt-accent);
	font-size: 0.95rem;
}

.extt-filter {
	min-width: 210px;
	padding: 0.55rem 0.75rem;
	border: 1px solid rgba(255, 255, 255, 0.85);
	border-radius: 4px;
	background: rgba(255, 255, 255, 0.18);
	color: #fff;
	font-size: 0.95rem;
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23ffffff' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.75rem center;
}

.extt-filter option {
	color: #333;
}

.extt-clear {
	padding: 0.6rem 1.1rem;
	background: #ffffff;
	color: #333;
	border: 1px solid rgba(0, 0, 0, 0.12);
	border-radius: 4px;
	font-size: 0.9rem;
	cursor: pointer;
	transition: background 0.15s ease;
}

.extt-clear:hover {
	background: #f3f3f3;
}

/* Table */
.extt-table-scroll {
	width: 100%;
	overflow-x: auto;
}

.extt-table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 1rem;
}

.extt-table thead th {
	background: var(--extt-header-bg);
	color: var(--extt-header-text);
	text-align: left;
	padding: 1.1rem 1.5rem;
	font-weight: 600;
	letter-spacing: 0.02em;
}

.extt-table thead th:last-child {
	text-align: right;
}

.extt-table tbody td {
	padding: 1.1rem 1.5rem;
	color: var(--extt-cell-text);
	border-bottom: 1px solid #eef0f3;
}

.extt-table tbody td:last-child {
	text-align: right;
}

.extt-table tbody tr:nth-child(even) {
	background: var(--extt-row-alt);
}

.extt-table tbody tr.extt-hidden {
	display: none;
}

.extt-noresults {
	text-align: center;
	padding: 2rem 1rem;
	color: var(--extt-cell-text);
	font-style: italic;
}

/* Responsive */
@media (max-width: 600px) {
	.extt-filter,
	.extt-filter-group {
		min-width: 0;
		width: 100%;
	}
	.extt-filter-bar {
		flex-direction: column;
		align-items: stretch;
	}
	.extt-table thead th,
	.extt-table tbody td {
		padding: 0.8rem 0.9rem;
	}
}

/* Pagination */
.extt-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	justify-content: center;
	margin-top: 1.5rem;
}

.extt-page {
	min-width: 38px;
	height: 38px;
	padding: 0 10px;
	border: 1px solid #d4d7dc;
	background: #ffffff;
	color: #2c3338;
	font-size: 0.95rem;
	border-radius: 4px;
	cursor: pointer;
	transition: background 0.12s ease, color 0.12s ease, border-color 0.12s ease;
}

.extt-page:hover:not(:disabled):not(.is-active) {
	border-color: var(--extt-page-active);
	color: var(--extt-page-active);
}

.extt-page.is-active {
	background: var(--extt-page-active);
	border-color: var(--extt-page-active);
	color: #ffffff;
	font-weight: 600;
	cursor: default;
}

.extt-page:disabled {
	opacity: 0.4;
	cursor: default;
}

.extt-page-dots {
	min-width: 24px;
	text-align: center;
	color: #8c8f94;
	align-self: center;
}
