/**
 * WooCommerce AvaTax Reconciliation Styles
 *
 * Note: Common Avalara tab styles (including .avalara-subsubsub) are loaded from
 * wc-avatax-avalara-common.css which is enqueued on all Avalara tab pages.
 *
 * @package WooCommerce_AvaTax
 */

/* Main Wrapper */
.wc-avatax-reconciliation-wrapper {
	margin-top: 20px;
}

/* Header Section (accordion head: title + Guide) */
.wc-avatax-reconciliation-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 20px;
}

.wc-avatax-reconciliation-header h2 {
	margin: 0;
}

/* Guide toggle button (extreme right): "Guide" text then icon */
.reconciliation-guide-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 2px 0;
	margin: 0;
	border: 0;
	background: none;
	color: #2271b1;
	font-size: 13px;
	line-height: 1.4;
	cursor: pointer;
	text-decoration: none !important;
}

.reconciliation-guide-toggle:hover {
	color: #135e96;
	text-decoration: underline;
}

.reconciliation-guide-toggle-label {
	display: inline-block;
	line-height: 1.4;
	vertical-align: middle;
	font-weight: bold;
}

.reconciliation-guide-toggle-icon,
.reconciliation-guide-toggle .dashicons {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	width: 16px;
	height: 16px;
	line-height: 1;
	flex-shrink: 0;
	vertical-align: middle;
	text-decoration: none;
	font-weight: bold;
}

/* Guide accordion panel */
.wc-avatax-reconciliation-guide-accordion {
	margin-bottom: 20px;
	background: #f6f7f7;
	border: 1px solid #dcdcde;
	border-radius: 4px;
}

.wc-avatax-reconciliation-guide-accordion .wc-avatax-reconciliation-support {
	background: #fff;
	padding: 20px;
	border-radius: 4px;
}



/* Tabs Navigation - Uses shared .avalara-subsubsub styles from wc-avatax-avalara-common.css */
.wc-avatax-reconciliation-wrapper .avalara-subsubsub {
	margin-bottom: 20px;
	margin-top: 0;
}

/* Tab Content - Show/Hide with JavaScript */
.wc-avatax-reconciliation-tabs-content {
	position: relative;
}

.reconciliation-tab-content {
	display: none;
	background: #fff;
	animation: fadeIn 0.3s ease-in;
}

.reconciliation-tab-content.active {
	display: block;
}

/* Loading Overlay */
.reconciliation-loading-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(255, 255, 255, 0.9);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	font-weight: 600;
	color: #1d2327;
	z-index: 100;
	border-radius: 4px;
}

.reconciliation-loading-overlay .dashicons {
	margin-right: 8px;
}

/* Loading spinner animation */
.reconciliation-spinner {
	animation: rotation 1.5s linear infinite;
	display: inline-block;
}

@keyframes rotation {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

/* Fade in animation for tab content */
@keyframes fadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

/* Tab Content - Show/Hide */
.reconciliation-tab-content {
	display: none;
}

.reconciliation-tab-content.active {
	display: block;
}

/* Content Area */
.wc-avatax-reconciliation-content {
	background: #fff;
	padding: 20px;
	border: 1px solid #c3c4c7;
	border-radius: 4px;
}

/* Filters Section */
.wc-avatax-reconciliation-filters {
	background: #f9f9f9;
	padding: 20px;
	border: 1px solid #dcdcde;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.scope-filters-title {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 10px;
	font-size: 14px;
}

.scope-filters-title .dashicons {
	color: #2271b1;
}

.wc-avatax-reconciliation-filters .description {
	margin-bottom: 15px;
	color: #646970;
	font-size: 13px;
}

.reconciliation-filter-form {
	margin-top: 15px;
}

.filter-row {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	align-items: flex-end;
	width: 100%;
}

/* Filter Group Container - for grouping related fields */
.filter-group-container {
	display: flex;
	gap: 12px;
	align-items: flex-end;
}

.filter-group {
	display: flex;
    flex-direction: column;
    gap: 5px;
    min-width: 160px;
    flex: 0 1 auto;
    box-sizing: unset;
    padding: 0px;
    border: none;
    background: transparent;
}

.filter-group label {
	font-weight: 600;
	font-size: 13px;
	color: #1d2327;
	margin-bottom: 2px;
	white-space: nowrap;
}

.filter-group input[type="date"],
.filter-group input[type="text"],
.filter-group select {
	padding: 2px 10px;
	border: 1px solid #8c8f94;
	border-radius: 3px;
	font-size: 13px;
	width: 100%;
	background: #fff;
	box-shadow: none;
	height: 34px;
}

.filter-group input[type="date"]:focus,
.filter-group input[type="text"]:focus,
.filter-group select:focus {
	border-color: #2271b1;
	outline: none;
	box-shadow: 0 0 0 1px #2271b1;
}

/* Document type select: ensure dropdown arrow is visible */
.wc-avatax-reconciliation-filters #document_type {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	padding-right: 28px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2350565b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 8px center;
}

/* Search field - wider */
.filter-group.filter-search {
	flex: 1 1 280px;
	min-width: 280px;
}

.filter-group.filter-search input[type="text"] {
	width: 100%;
}

/* OR Divider */
.filter-divider {
	display: flex;
	align-items: center;
	align-self: flex-end;
	padding: 0 15px;
	height: 34px;
	flex-shrink: 0;
}

.filter-divider span {
	font-weight: 600;
	font-size: 12px;
	color: #646970;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

/* Clear and Run Buttons */
.filter-actions {
	align-self: flex-end;
	flex-shrink: 0;
	margin-left: auto;
	display: flex;
	gap: 10px;
	align-items: center;
}

.filter-actions .reconciliation-clear-filters {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 6px 16px;
	height: 34px;
	white-space: nowrap;
	box-sizing: border-box;
}

.filter-actions .button-primary {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 6px 16px;
	height: 34px;
	white-space: nowrap;
}

/* Overview Section */
.overview-section-title {
	margin-bottom: 20px;
}

.overview-section-title h3 {
	margin: 0;
}

/* Summary Cards */
.wc-avatax-reconciliation-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 20px;
	margin-bottom: 25px;
}

.reconciliation-card {
	display: flex;
	gap: 15px;
	padding: 20px;
	background: #fff;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
	transition: box-shadow 0.2s;
}

.reconciliation-card:hover {
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.reconciliation-card .card-icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f0f0f1;
	border-radius: 8px;
}

.reconciliation-card .card-icon .dashicons {
	font-size: 24px;
	width: 24px;
	height: 24px;
	color: #2271b1;
}

.reconciliation-card.card-warning .card-icon {
	background: #fff8e5;
}

.reconciliation-card.card-warning .card-icon .dashicons {
	color: #d63638;
}

.reconciliation-card.card-error .card-icon {
	background: #fcf0f1;
}

.reconciliation-card.card-error .card-icon .dashicons {
	color: #d63638;
}

.reconciliation-card .card-content h4 {
	margin: 0 0 10px 0;
	font-size: 13px;
	font-weight: 600;
	color: #646970;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.reconciliation-card .card-value {
	font-size: 32px;
	font-weight: 700;
	color: #1d2327;
	line-height: 1;
	margin-bottom: 5px;
}

.reconciliation-card .card-description {
	margin: 0;
	font-size: 12px;
	color: #646970;
}

/* Results Header */
.reconciliation-results-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 20px;
	flex-wrap: wrap;
	gap: 15px;
}

.reconciliation-results-header h3 {
	margin: 0;
}

.reconciliation-results-header .description {
	color: #646970;
	font-size: 13px;
	margin-top: 5px;
}

.results-actions {
	display: flex;
	align-items: center;
	gap: 15px;
}

.results-count {
	font-weight: 600;
	color: #1d2327;
}

/* Results Table */
.wc-avatax-reconciliation-table {
	margin-top: 15px;
}

.wc-avatax-reconciliation-table th {
	font-weight: 600;
	color: #1d2327;
}

.wc-avatax-reconciliation-table .order-status {
	display: inline-block;
	padding: 4px 8px;
	border-radius: 3px;
	font-size: 12px;
	font-weight: 600;
	text-transform: capitalize;
}

.wc-avatax-reconciliation-table .order-status.status-completed {
	background: #c6e1c6;
	color: #0a5e0a;
}

.wc-avatax-reconciliation-table .order-status.status-processing {
	background: #c8d7e1;
	color: #2e4453;
}

.wc-avatax-reconciliation-table .order-status.status-pending {
	background: #f8dda7;
	color: #94660c;
}

.wc-avatax-reconciliation-table .mismatch-values {
	font-size: 13px;
}

.wc-avatax-reconciliation-table .mismatch-values .label {
	font-weight: 600;
	color: #646970;
}

.wc-avatax-reconciliation-table .mismatch-type {
	display: inline-block;
	padding: 4px 8px;
	background: #fcf0f1;
	color: #d63638;
	border-radius: 3px;
	font-size: 12px;
	font-weight: 600;
}

.wc-avatax-reconciliation-table .mismatch-details {
	font-size: 12px;
	color: #646970;
}

/* No Results */
.reconciliation-no-results {
	text-align: center;
	padding: 40px 20px;
	background: #f9f9f9;
	border: 1px dashed #dcdcde;
	border-radius: 4px;
	margin-top: 15px;
}

.reconciliation-no-results .dashicons {
	font-size: 48px;
	width: 48px;
	height: 48px;
	color: #50c878;
	margin-bottom: 10px;
}

.reconciliation-no-results p {
	margin: 0;
	color: #646970;
	font-size: 14px;
}

.reconciliation-waiting-results {
	text-align: center;
	padding: 40px 20px;
	background: #f9f9f9;
	border: 1px dashed #dcdcde;
	border-radius: 4px;
	margin-top: 15px;
}

.reconciliation-waiting-results p {
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	color: #646970;
	font-size: 14px;
}

.reconciliation-waiting-results .dashicons {
	color: #2271b1;
}

/* Support Section */
.wc-avatax-reconciliation-support .support-section {
	margin-bottom: 30px;
}

.wc-avatax-reconciliation-support h3 {
	margin-top: 0;
	margin-bottom: 15px;
	color: #1d2327;
	border-bottom: 1px solid #dcdcde;
	padding-bottom: 10px;
}

.support-list {
	line-height: 1.8;
}

.support-list li {
	margin-bottom: 10px;
}

.wc-avatax-reconciliation-support ul:not(.support-links) {
	list-style: disc;
	padding-left: 20px;
}

.wc-avatax-reconciliation-support ol {
	list-style: decimal;
	padding-left: 20px;
}

/* Support Links */

.support-links {
	list-style: none;
	padding: 0;
	margin: 15px 0 0 0;
}

.support-links li {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
}

.support-links .dashicons {
	color: #2271b1;
	flex-shrink: 0;
}

.support-links a {
	text-decoration: none;
	color: #2271b1;
	font-weight: 500;
}

.support-links a:hover {
	text-decoration: underline;
}

/* Pagination */
.reconciliation-pagination {
	margin-top: 20px;
	text-align: center;
}

/* Responsive Design */
@media screen and (max-width: 1400px) {
	.filter-row {
		gap: 12px;
	}

	.filter-group-container {
		gap: 10px;
	}

	.filter-group {
		min-width: 140px;
	}

	.filter-group.filter-search {
		min-width: 240px;
	}
}

@media screen and (max-width: 1200px) {
	.filter-row {
		gap: 10px;
	}

	.filter-group-container {
		flex-wrap: wrap;
	}

	.filter-divider {
		display: none;
	}

	.filter-group.filter-search {
		flex-basis: 100%;
	}

	.filter-actions {
		flex-basis: 100%;
		margin-top: 10px;
	}
}

@media screen and (max-width: 782px) {
	.filter-row {
		flex-direction: column;
		width: 100%;
		gap: 15px;
	}

	.filter-group-container {
		width: 100%;
		flex-direction: column;
		gap: 15px;
	}

	.filter-group {
		width: 100%;
	}

	.filter-group input[type="date"],
	.filter-group input[type="text"],
	.filter-group select {
		width: 100%;
	}

	.filter-divider {
		display: flex;
		justify-content: center;
		width: 100%;
		padding: 10px 0;
		margin-top: 0;
	}

	.filter-actions {
		margin-left: 0;
		margin-top: 0;
		width: 100%;
	}

	.filter-actions .button-primary {
		width: 100%;
		justify-content: center;
	}

	.wc-avatax-reconciliation-cards {
		grid-template-columns: 1fr;
	}

	.reconciliation-results-header {
		flex-direction: column;
	}

	.results-actions {
		width: 100%;
	}

	.results-actions .button {
		flex: 1;
	}
}

/* Previous Runs Section */
.wc-avatax-reconciliation-previous-runs {
	background: #fff;
	border: 1px solid #c3c4c7;
	border-radius: 4px;
	padding: 16px 20px;
	margin-bottom: 20px;
}

.wc-avatax-reconciliation-previous-runs .previous-runs-title {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 12px;
	font-size: 14px;
}

.wc-avatax-reconciliation-previous-runs .previous-runs-title .dashicons {
	color: #2271b1;
}

.wc-avatax-reconciliation-previous-runs .previous-runs-empty {
	color: #646970;
	margin: 0;
}

.wc-avatax-reconciliation-previous-runs .previous-runs-empty .dashicons {
	color: #2271b1;
	margin-right: 4px;
	vertical-align: text-bottom;
}

#previous-runs-table .view-previous-run {
	white-space: nowrap;
}

.run-status-badge {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 3px;
	font-size: 12px;
	font-weight: 600;
	white-space: nowrap;
}

.run-status-badge.status-completed {
	background: #c6e1c6;
	color: #0a5e0a;
}

.run-status-badge.status-pending,
.run-status-badge.status-running {
	background: #f8dda7;
	color: #94660c;
}

.run-status-badge.status-failed,
.run-status-badge.status-cancelled,
.run-status-badge.status-unknown {
	background: #fcf0f1;
	color: #d63638;
}

.previous-runs-refresh {
	margin-left: auto !important;
	display: inline-flex !important;
	align-items: center;
	gap: 4px;
}

.previous-runs-refresh .dashicons {
	font-size: 16px;
	width: 16px;
	height: 16px;
	line-height: 16px;
}

#previous-runs-table tbody tr.active-run {
	background-color: #e8f0fe;
	border-left: 3px solid #2271b1;
}

#previous-runs-table tbody tr.active-run td:first-child {
	padding-left: 9px;
}

.previous-runs-info-text {
	color: #646970;
	font-size: 12px;
	font-style: italic;
	margin: 8px 0 0;
}

.previous-runs-info-text .dashicons {
	font-size: 14px;
	width: 14px;
	height: 14px;
	line-height: 14px;
	vertical-align: text-bottom;
	color: #646970;
	margin-right: 2px;
}
