/* NE Design System — modules/admin-race-results.css — Race Results Admin (#129) */
/* Styles for admin tab on single-evento pages */
/* Extracted from components/evento/race-results/admin.php inline <style> */

/* === Debug box & sections === */
.debug-box {
	margin-top: var(--ne-space-6);
	padding: var(--ne-space-4);
	color: var(--ne-text) !important;
}

.debug-section {
	margin: var(--ne-space-4) 0;
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-sm);
}

.debug-section summary {
	padding: var(--ne-space-4);
	cursor: pointer;
	font-weight: bold;
	color: var(--ne-text);
}

.debug-content {
	padding: var(--ne-space-4);
	color: var(--ne-text);
}

.debug-table-container {
	overflow-x: auto;
	margin-bottom: var(--ne-space-4);
}

/* === Debug tables === */
.debug-table {
	width: 100%;
	border-collapse: collapse;
	margin-top: var(--ne-space-2);
	font-size: 0.9em;
	color: var(--ne-text);
}

.debug-table th,
.debug-table td {
	border: 1px solid var(--ne-border-s);
	padding: var(--ne-space-2);
	text-align: left;
}

.debug-table th {
	font-weight: 600;
	color: var(--ne-text);
}

.debug-table tr:nth-child(even) {
	background: var(--ne-bg);
}

.debug-table h4 {
	margin: var(--ne-space-4) 0 var(--ne-space-2);
	color: var(--ne-text);
}

/* === No data placeholder === */
.no-data {
	color: var(--ne-text-muted);
	font-style: italic;
	text-align: center;
	padding: var(--ne-space-4);
	background: var(--ne-bg);
	border-radius: var(--ne-radius-sm);
	border: 1px dashed var(--ne-border-s);
}

/* === Buttons (admin results context) === */
.admin-controls .button {
	padding: var(--ne-space-1) var(--ne-space-2);
	margin: 0 var(--ne-space-1);
	font-size: 0.8em;
	background: var(--ne-surface);
	color: var(--ne-text);
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-sm);
	cursor: pointer;
}

.admin-controls .button:hover {
	background: var(--ne-elevated);
	border-color: var(--ne-border-brand);
}

.admin-controls .view-json {
	border: 1px solid var(--ne-border-s);
	color: var(--ne-text);
}

.admin-controls .restore-version {
	background: rgba(0, 118, 190, 0.15);
	border: 1px solid var(--ne-blue);
	color: #ffffff;
}

.admin-controls .restore-version:hover {
	background: rgba(0, 118, 190, 0.3);
}

/* === Restore action group (button + reprocess toggle) === */
.restore-action-group {
	display: inline-flex;
	align-items: center;
	gap: var(--ne-space-2);
}

.reprocess-toggle {
	display: inline-flex;
	align-items: center;
	gap: var(--ne-space-1);
	font-size: 0.75em;
	color: var(--ne-text-muted);
	cursor: pointer;
	user-select: none;
}

.reprocess-toggle input[type="checkbox"] {
	accent-color: var(--ne-blue);
	cursor: pointer;
	width: 14px;
	height: 14px;
}

.reprocess-toggle span {
	white-space: nowrap;
}

/* === Retroactive backup section === */
.retroactive-backup-section {
	background: var(--ne-bg);
	border-left: 4px solid var(--ne-blue);
	border: 1px solid var(--ne-border-s);
}

.retroactive-backup-section h4 {
	margin: 0 0 var(--ne-space-2) 0;
	color: var(--ne-blue);
}

.retroactive-backup-section p {
	margin: 0 0 var(--ne-space-4) 0;
	color: var(--ne-text-muted);
	font-size: 0.9em;
}

#generate-retroactive-backup {
	background: var(--ne-blue);
	border-color: var(--ne-blue);
	color: white;
	padding: var(--ne-space-2) var(--ne-space-4);
	font-weight: 500;
}

#generate-retroactive-backup:hover {
	background: #005a87;
	border-color: #005a87;
}

#generate-retroactive-backup:disabled {
	background: var(--ne-elevated);
	border-color: var(--ne-elevated);
	cursor: not-allowed;
}

#retroactive-backup-status p {
	margin: var(--ne-space-1) 0;
	font-weight: 500;
}

/* === JSON files container === */
.json-files-container {
	text-align: left;
}

.json-file-actions {
	margin-top: var(--ne-space-4);
	display: flex;
	gap: var(--ne-space-2);
	flex-wrap: wrap;
}

.json-file-actions .button {
	margin: 0;
}

.no-json-file {
	color: var(--ne-text-muted);
	font-style: italic;
	text-align: center;
	padding: var(--ne-space-4);
	background: var(--ne-bg);
	border-radius: var(--ne-radius-sm);
}

.json-upload-section {
	margin-top: var(--ne-space-6);
	padding: var(--ne-space-4);
	border: 2px dashed var(--ne-blue);
	border-radius: var(--ne-radius-sm);
	text-align: center;
	background: var(--ne-bg);
}

.json-upload-section h4 {
	margin: 0 0 var(--ne-space-4) 0;
	color: var(--ne-blue);
}

/* === JSON content modal === */
.modal {
	position: fixed;
	z-index: -1000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.8);
}

.modal.show {
	z-index: var(--ne-z-modal);
}

.modal-content {
	background-color: var(--ne-bg);
	margin: 5% auto;
	padding: var(--ne-space-5);
	border: 1px solid var(--ne-border-s);
	width: 90%;
	max-width: 800px;
	max-height: 80vh;
	overflow-y: auto;
	border-radius: var(--ne-radius-md);
	color: var(--ne-text);
}

.close {
	color: var(--ne-text-muted);
	float: right;
	font-size: 28px;
	font-weight: bold;
	cursor: pointer;
}

.close:hover,
.close:focus {
	color: var(--ne-text);
	text-decoration: none;
	cursor: pointer;
}

#json-content-text {
	background: var(--ne-bg);
	padding: var(--ne-space-4);
	border-radius: var(--ne-radius-sm);
	overflow-x: auto;
	font-size: 0.9em;
	line-height: 1.4;
	max-height: 60vh;
	overflow-y: auto;
	color: var(--ne-text);
	border: 1px solid var(--ne-border-s);
}

#modal-title {
	margin-bottom: var(--ne-space-4);
	color: var(--ne-text);
}

/* === Source type indicators === */
.source-type {
	display: inline-block;
	padding: var(--ne-space-1) var(--ne-space-2);
	border-radius: var(--ne-radius-sm);
	font-size: 0.8em;
	font-weight: 500;
	text-transform: uppercase;
}

.source-type.archivo-local {
	background: rgba(61, 214, 140, 0.15);
	color: var(--ne-green);
	border: 1px solid var(--ne-green);
}

.source-type.url-externa {
	background: rgba(0, 118, 190, 0.15);
	color: var(--ne-accent);
	border: 1px solid var(--ne-accent);
}

/* === Session type badges === */
.session-type-badge {
	display: inline-block;
	padding: var(--ne-space-1) var(--ne-space-2);
	border-radius: var(--ne-radius-sm);
	font-size: 0.8em;
	font-weight: 500;
	text-transform: uppercase;
	color: white;
}

.session-type-badge.race {
	background: var(--ne-red);
}

.session-type-badge.quali {
	background: var(--ne-green);
}

/* === Session data container === */
.session-data-container {
	margin-top: var(--ne-space-4);
}

/* === Session type selector (tabs) === */
.session-type-selector {
	display: flex;
	gap: var(--ne-space-2);
	margin-bottom: var(--ne-space-4);
	border-bottom: 2px solid var(--ne-border-s);
	padding-bottom: var(--ne-space-2);
}

.session-tab {
	background: var(--ne-surface);
	border: 2px solid var(--ne-border-s);
	border-radius: var(--ne-radius-md);
	padding: var(--ne-space-2) var(--ne-space-4);
	cursor: pointer;
	transition: all var(--ne-duration) var(--ne-ease);
	display: flex;
	align-items: center;
	gap: var(--ne-space-2);
	font-size: 0.9em;
	font-weight: 500;
	color: var(--ne-text);
}

.session-tab:hover {
	border-color: var(--ne-blue);
	background: var(--ne-elevated);
	transform: translateY(-1px);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.session-tab.active {
	border-color: var(--ne-blue);
	background: var(--ne-blue);
	color: white;
	transform: translateY(-1px);
	box-shadow: 0 2px 8px rgba(0, 118, 190, 0.5);
}

.session-tab.active .session-type-badge {
	background: var(--ne-overlay-s);
	border: 1px solid var(--ne-border-s);
}

.version-info {
	font-size: 0.8em;
	font-weight: 500;
	opacity: 0.8;
	background: var(--ne-overlay-s);
	padding: 1px var(--ne-space-1);
	border-radius: var(--ne-radius-sm);
}

/* === Session content === */
.session-content {
	display: none;
	animation: fadeIn 0.3s ease-in-out;
}

.session-content.active {
	display: block;
}

@keyframes fadeIn {
	from { opacity: 0; transform: translateY(10px); }
	to { opacity: 1; transform: translateY(0); }
}

/* === Session info details (collapsible) === */
.session-info-details {
	margin: var(--ne-space-4) 0;
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-md);
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
	transition: box-shadow var(--ne-duration) var(--ne-ease);
	background: var(--ne-bg);
}

.session-info-details:hover {
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}

.session-info-details summary {
	padding: var(--ne-space-4);
	background: var(--ne-surface);
	cursor: pointer;
	font-weight: 600;
	border-bottom: 1px solid var(--ne-border-s);
	transition: all var(--ne-duration) var(--ne-ease);
	position: relative;
	color: var(--ne-text);
}

.session-info-details summary:hover {
	background: var(--ne-elevated);
}

.session-info-details summary::after {
	content: '\25BC';
	position: absolute;
	right: var(--ne-space-4);
	top: 50%;
	transform: translateY(-50%);
	transition: transform var(--ne-duration) var(--ne-ease);
	font-size: 0.8em;
	opacity: 0.6;
	color: var(--ne-text);
}

.session-info-details[open] summary::after {
	transform: translateY(-50%) rotate(180deg);
}

.session-info-details[open] summary {
	background: var(--ne-blue);
	color: white;
}

.session-info-content {
	padding: var(--ne-space-4);
	background: var(--ne-bg);
	color: var(--ne-text);
}

/* === Form styles (admin results context) === */
.admin-controls .form-group {
	margin-bottom: var(--ne-space-4);
	flex: 1;
}

.admin-controls .form-row {
	display: flex;
	gap: var(--ne-space-5);
	margin-bottom: var(--ne-space-4);
}

.admin-controls .form-group label {
	display: block;
	margin-bottom: var(--ne-space-2);
	color: var(--ne-text);
	font-weight: 500;
}

.admin-controls .form-group textarea {
	height: 80px;
	resize: vertical;
}

.admin-controls .form-group input,
.admin-controls .form-group select,
.admin-controls .form-group textarea {
	width: 100%;
	padding: var(--ne-space-2);
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-sm);
	color: var(--ne-text);
	transition: border-color var(--ne-duration) var(--ne-ease);
}

.admin-controls .form-group input:focus,
.admin-controls .form-group select:focus,
.admin-controls .form-group textarea:focus {
	outline: none;
	border-color: var(--ne-blue);
	box-shadow: 0 0 0 2px rgba(0, 118, 190, 0.2);
}

.admin-controls .form-group input::placeholder,
.admin-controls .form-group textarea::placeholder {
	color: var(--ne-text-subtle);
}

/* === Multiple select === */
.admin-controls .form-group select[multiple] {
	height: 120px;
}

.admin-controls .form-group select[multiple] option {
	padding: 5px;
	color: var(--ne-text);
}

.admin-controls .form-group select[multiple] option:hover {
	background: var(--ne-elevated);
}

.admin-controls .form-group select[multiple] option:checked {
	background: var(--ne-blue);
	color: white;
}

/* === Primary/secondary buttons (admin results context) === */
.admin-controls .button-primary {
	background: var(--ne-blue) !important;
	border-color: var(--ne-blue) !important;
	color: white !important;
}

.admin-controls .button-primary:hover {
	background: #005a87 !important;
	border-color: #005a87 !important;
}

.admin-controls .button-secondary {
	background: var(--ne-elevated) !important;
	border-color: var(--ne-border-s) !important;
	color: white !important;
}

.admin-controls .button-secondary:hover {
	background: var(--ne-surface) !important;
	border-color: var(--ne-border-brand) !important;
}

/* === Debug data viewer (WP_DEBUG only) === */
.debug-data-viewer {
	margin: var(--ne-space-4) 0;
	border: 1px solid var(--ne-border-s);
	border-radius: var(--ne-radius-md);
	overflow: hidden;
	background: var(--ne-bg);
}

.debug-data-viewer summary {
	padding: var(--ne-space-3);
	background: var(--ne-surface);
	cursor: pointer;
	font-weight: 500;
	font-size: 0.85em;
	color: var(--ne-text-muted);
	border-bottom: 1px solid var(--ne-border);
}

.debug-data-viewer summary:hover {
	background: var(--ne-elevated);
}

.debug-data-viewer pre {
	background: var(--ne-bg);
	padding: var(--ne-space-4);
	border-radius: var(--ne-radius-sm);
	overflow-x: auto;
	color: var(--ne-text);
	font-size: 0.8em;
	margin: 0;
}

/* === Responsive === */
@media (max-width: 750px) {
	.session-type-selector {
		flex-direction: column;
	}

	.session-tab {
		justify-content: center;
	}

	.admin-controls .form-row {
		flex-direction: column;
		gap: 0;
	}

	.json-file-actions {
		flex-direction: column;
	}
}
