/* ===== Pico CSS Overrides ===== */
body {
	margin: 0;
	padding: 0;
}

/* Prevent Pico from constraining our layout */
body > header,
body > div {
	max-width: none;
	padding-block: 0;
}

/* ===== Theme Variables ===== */
:root {
	--card-bg: #fff;
	--card-border: #e0e0e0;
	--card-shadow: rgba(0, 0, 0, 0.08);
	--header-bg: #f8f9fa;
	--header-border: #e0e0e0;
	--text-muted: #6c757d;
	--status-ok: #2e7d32;
	--status-warn: #e65100;
	--status-error: #c62828;
	--status-ok-bg: rgba(46, 125, 50, 0.08);
	--status-warn-bg: rgba(230, 81, 0, 0.08);
	--status-error-bg: rgba(198, 40, 40, 0.08);
	--log-bg: #f5f5f5;
	--log-border: #ddd;
	--loading-color: #666;
}

[data-theme="dark"] {
	--card-bg: #1e1e2e;
	--card-border: #383850;
	--card-shadow: rgba(0, 0, 0, 0.3);
	--header-bg: #181825;
	--header-border: #313145;
	--text-muted: #a0a0b0;
	--status-ok: #66bb6a;
	--status-warn: #ffa726;
	--status-error: #ef5350;
	--status-ok-bg: rgba(102, 187, 106, 0.1);
	--status-warn-bg: rgba(255, 167, 38, 0.1);
	--status-error-bg: rgba(239, 83, 80, 0.1);
	--log-bg: #252535;
	--log-border: #383850;
	--loading-color: #a0a0b0;
}

/* ===== Header ===== */
.dashboard-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.75rem 1.5rem;
	background: var(--header-bg);
	border-bottom: 1px solid var(--header-border);
	margin-bottom: 1.5rem;
}

.dashboard-header h1 {
	margin: 0;
	font-size: 1.25rem;
	font-weight: 600;
}

.theme-toggle {
	background: none;
	border: 1px solid var(--card-border);
	border-radius: 6px;
	padding: 0.4rem 0.75rem;
	cursor: pointer;
	font-size: 1rem;
	color: inherit;
	transition: border-color 0.2s;
	width: auto;
	margin: 0;
}

.theme-toggle:hover {
	border-color: var(--text-muted);
}

/* ===== Dashboard Grid ===== */
.dashboard-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.25rem;
	padding: 0 1.5rem 1.5rem;
}

@media (max-width: 700px) {
	.dashboard-grid {
		grid-template-columns: 1fr;
		padding: 0 0.75rem 0.75rem;
	}

	.dashboard-header {
		padding: 0.75rem;
	}
}

/* ===== Component Cards ===== */
.component {
	background: var(--card-bg);
	border: 1px solid var(--card-border);
	border-radius: 10px;
	padding: 1.25rem;
	box-shadow: 0 2px 8px var(--card-shadow);
	transition: box-shadow 0.2s;
	overflow: hidden;
}

.component:hover {
	box-shadow: 0 4px 16px var(--card-shadow);
}

.component-wide {
	grid-column: 1 / -1;
}

.component-title {
	margin: 0 0 1rem 0;
	font-size: 1rem;
	font-weight: 600;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--card-border);
}

/* ===== Status Colors ===== */
.status-ok {
	color: var(--status-ok);
}

.status-warn {
	color: var(--status-warn);
}

.status-error {
	color: var(--status-error);
}

.status-ok-bg {
	background: var(--status-ok-bg);
	border-radius: 6px;
	padding: 0.75rem;
}

.status-warn-bg {
	background: var(--status-warn-bg);
	border-radius: 6px;
	padding: 0.75rem;
}

.status-error-bg {
	background: var(--status-error-bg);
	border-radius: 6px;
	padding: 0.75rem;
}

/* ===== Tables inside components ===== */
.component table {
	width: 100%;
	border-collapse: collapse;
	margin: 0;
	border: none;
}

.component th,
.component td {
	text-align: left;
	padding: 0.5rem 0.75rem;
	border-bottom: 1px solid var(--card-border);
}

.component th {
	font-weight: 600;
}

.component tr:last-child td {
	border-bottom: none;
}

.component td:first-child {
	font-weight: 500;
	white-space: nowrap;
}

.component td:last-child {
	text-align: right;
	font-variant-numeric: tabular-nums;
}

/* ===== Log Boxes (DMS style) ===== */
.log-box {
	background: var(--log-bg);
	border: 1px solid var(--log-border);
	border-radius: 6px;
	padding: 0.75rem;
	margin-top: 0.5rem;
	font-family: monospace;
	font-size: 0.85rem;
	white-space: pre-wrap;
	word-break: break-word;
	overflow-x: auto;
}

.log-label {
	font-weight: 600;
	margin-top: 1rem;
	margin-bottom: 0.25rem;
}

/* ===== Login Screen ===== */
.login-container {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 80vh;
	padding: 1rem;
}

.login-card {
	background: var(--card-bg);
	border: 1px solid var(--card-border);
	border-radius: 10px;
	padding: 2rem;
	box-shadow: 0 4px 16px var(--card-shadow);
	width: 100%;
	max-width: 360px;
}

.login-card h2 {
	margin: 0 0 1.5rem 0;
	font-size: 1.25rem;
	text-align: center;
}

.login-card label {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 500;
}

.login-card input[type="password"] {
	width: 100%;
	padding: 0.6rem 0.75rem;
	border: 1px solid var(--card-border);
	border-radius: 6px;
	font-size: 1rem;
	background: inherit;
	color: inherit;
	box-sizing: border-box;
}

.login-card input[type="password"]:focus {
	outline: 2px solid var(--status-ok);
	outline-offset: -1px;
	border-color: transparent;
}

.login-card button {
	width: 100%;
	margin-top: 1rem;
	padding: 0.6rem;
	border: none;
	border-radius: 6px;
	background: #4a6cf7;
	color: #fff;
	font-size: 1rem;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.2s;
}

.login-card button:hover {
	background: #3b5de7;
}

.login-error {
	color: var(--status-error);
	background: var(--status-error-bg);
	border-radius: 6px;
	padding: 0.5rem 0.75rem;
	margin-bottom: 1rem;
	font-size: 0.9rem;
	text-align: center;
}

/* ===== Loading State ===== */
.loading-container {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 80vh;
	color: var(--loading-color);
	font-size: 1.1rem;
}

.loading-spinner {
	display: inline-block;
	width: 1.25rem;
	height: 1.25rem;
	border: 2px solid var(--card-border);
	border-top-color: var(--text-muted);
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
	margin-right: 0.75rem;
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

.component-loading {
	color: var(--text-muted);
	font-size: 0.9rem;
	padding: 1rem 0;
}

/* ===== Links ===== */
.component a {
	color: #4a6cf7;
	text-decoration: none;
}

.component a:hover {
	text-decoration: underline;
}

/* ===== Component Header (title bar) ===== */
.component-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-bottom: 0.75rem;
	margin-bottom: 0.75rem;
	border-bottom: 1px solid var(--card-border);
}

.component-header-left {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.component-header-title {
	font-size: 1rem;
	font-weight: 600;
}

.component-status-icon {
	font-size: 1.1rem;
	line-height: 1;
}

.collapse-toggle {
	font-size: 0.8rem;
	color: var(--text-muted);
	transition: color 0.15s;
}

.component-header[style*="cursor: pointer"]:hover .collapse-toggle {
	color: inherit;
}

/* Collapsed state */
.component.collapsed .component-header {
	padding-bottom: 0;
	margin-bottom: 0;
	border-bottom: none;
}

.component.collapsed {
	padding: 0.75rem 1.25rem;
}

/* ===== Header Buttons ===== */
.header-buttons {
	display: flex;
	gap: 0.5rem;
	align-items: center;
}

.header-btn {
	background: none;
	border: 1px solid var(--card-border);
	border-radius: 6px;
	padding: 0.4rem 0.75rem;
	cursor: pointer;
	font-size: 0.9rem;
	color: inherit;
	transition: border-color 0.2s;
	width: auto;
	margin: 0;
}

.header-btn:hover {
	border-color: var(--text-muted);
}

.header-btn-save {
	background: #4a6cf7;
	color: #fff;
	border-color: #4a6cf7;
}

.header-btn-save:hover {
	background: #3b5de7;
	border-color: #3b5de7;
}

/* ===== Reorder Controls ===== */
.reorder-controls {
	display: flex;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
}

.reorder-arrow {
	background: none;
	border: 1px solid var(--card-border);
	border-radius: 6px;
	padding: 0.25rem 0.6rem;
	cursor: pointer;
	font-size: 1rem;
	color: inherit;
	width: auto;
	margin: 0;
	transition: background 0.15s, border-color 0.15s;
}

.reorder-arrow:hover {
	background: var(--status-ok-bg);
	border-color: var(--status-ok);
}
