/* Frontend Styles */
:root {
	--mci-primary: #2271b1;
	--mci-primary-hover: #135e96;
	--mci-success: #00a32a;
	--mci-warning: #dba617;
	--mci-error: #d63638;
	--mci-border: #c3c4c7;
	--mci-bg: #f0f0f1;
	--mci-radius: 4px;
	--mci-shadow: 0 1px 3px rgba(0,0,0,0.08);
}

.mci-invoice-dashboard {
	max-width: 100%;
	margin: 0 auto;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	color: #1d2327;
}

.mci-title {
	margin-bottom: 1.5rem;
	font-size: 1.5rem;
	color: #1d2327;
}

.mci-empty {
	padding: 2rem;
	text-align: center;
	background: var(--mci-bg);
	border-radius: var(--mci-radius);
	color: #646970;
}

.mci-table-wrapper {
	overflow-x: auto;
	margin-bottom: 1rem;
	border: 1px solid var(--mci-border);
	border-radius: var(--mci-radius);
	box-shadow: var(--mci-shadow);
}

.mci-invoice-table {
	width: 100%;
	border-collapse: collapse;
	margin: 0;
}

.mci-invoice-table thead th {
	background: var(--mci-bg);
	padding: 12px 14px;
	text-align: left;
	font-size: 0.85rem;
	font-weight: 600;
	text-transform: uppercase;
	color: #50575e;
	border-bottom: 2px solid var(--mci-border);
	white-space: nowrap;
}

.mci-invoice-table tbody td {
	padding: 12px 14px;
	border-bottom: 1px solid #e5e5e5;
	vertical-align: middle;
}

.mci-invoice-table tbody tr:hover {
	background: #f6f7f7;
}

.mci-status-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 12px;
	font-size: 0.8rem;
	font-weight: 500;
	white-space: nowrap;
}

.mci-status-pending {
	background: #fff8e5;
	color: #916a00;
}

.mci-status-generated {
	background: #edfaef;
	color: #006e2e;
}

.mci-status-error {
	background: #fde8e8;
	color: #a00;
}

.mci-status-cancelled {
	background: #f0f0f1;
	color: #646970;
}

.mci-status-processing {
	background: #e5f0ff;
	color: #124382;
}

.mci-action-buttons {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}

.mci-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 14px;
	border: 1px solid var(--mci-border);
	border-radius: var(--mci-radius);
	background: #fff;
	color: #1d2327;
	font-size: 0.85rem;
	cursor: pointer;
	text-decoration: none;
	transition: all 0.15s ease;
	white-space: nowrap;
}

.mci-btn:hover {
	background: var(--mci-bg);
	text-decoration: none;
	color: #1d2327;
}

.mci-btn-generate {
	background: var(--mci-primary);
	color: #fff;
	border-color: var(--mci-primary);
}

.mci-btn-generate:hover {
	background: var(--mci-primary-hover);
	color: #fff;
}

.mci-btn-retry {
	background: var(--mci-warning);
	color: #fff;
	border-color: var(--mci-warning);
}

.mci-btn-retry:hover {
	background: #c49316;
	color: #fff;
}

.mci-btn-download {
	background: var(--mci-success);
	color: #fff;
	border-color: var(--mci-success);
}

.mci-btn-download:hover {
	background: #008a20;
	color: #fff;
}

.mci-btn-primary {
	background: var(--mci-primary);
	color: #fff;
	border-color: var(--mci-primary);
}

.mci-btn-primary:hover {
	background: var(--mci-primary-hover);
	color: #fff;
}

.mci-processing {
	color: #646970;
	font-style: italic;
	font-size: 0.85rem;
}

.mci-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 1rem 0;
}

.mci-pagination .mci-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.mci-page-info {
	font-size: 0.85rem;
	color: #50575e;
}

.mci-form-row {
	margin-bottom: 1rem;
}

.mci-form-row label {
	display: block;
	margin-bottom: 4px;
	font-weight: 600;
	font-size: 0.9rem;
}

.mci-form-row .required {
	color: var(--mci-error);
}

.mci-form-row input,
.mci-form-row select {
	width: 100%;
	padding: 8px 10px;
	border: 1px solid var(--mci-border);
	border-radius: var(--mci-radius);
	font-size: 0.9rem;
}

.mci-form-row input:focus,
.mci-form-row select:focus {
	border-color: var(--mci-primary);
	outline: none;
	box-shadow: 0 0 0 1px var(--mci-primary);
}

.mci-form-actions {
	margin-top: 1.5rem;
	text-align: right;
}

/* Loading overlay */
.mci-loading-overlay {
	position: fixed;
	z-index: 100000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: rgba(255,255,255,0.7);
	display: flex;
	align-items: center;
	justify-content: center;
}

.mci-spinner {
	width: 40px;
	height: 40px;
	border: 4px solid var(--mci-border);
	border-top: 4px solid var(--mci-primary);
	border-radius: 50%;
	animation: mci-spin 0.8s linear infinite;
}

@keyframes mci-spin {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}

/* Result view inside modal */
.mci-result-view {
	text-align: center;
	padding: 1rem 0;
}

.mci-result-icon {
	display: inline-block;
	width: 48px;
	height: 48px;
	line-height: 48px;
	border-radius: 50%;
	background: var(--mci-success);
	color: #fff;
	font-size: 1.5rem;
	margin-bottom: 0.5rem;
}

.mci-result-view h3 {
	margin: 0.5rem 0;
}

.mci-result-uuid {
	font-size: 0.85rem;
	color: #646970;
	word-break: break-all;
	margin-bottom: 1rem;
}

.mci-result-actions {
	display: flex;
	gap: 8px;
	justify-content: center;
}

/* Standalone fiscal form */
.mci-fiscal-form-wrapper {
	max-width: 500px;
	margin: 0 auto;
	background: #fff;
	padding: 2rem;
	border: 1px solid var(--mci-border);
	border-radius: var(--mci-radius);
	box-shadow: var(--mci-shadow);
}

.mci-fiscal-form-wrapper h3 {
	margin-top: 0;
	margin-bottom: 1.5rem;
}

.mci-form-feedback {
	padding: 8px 12px;
	border-radius: var(--mci-radius);
	font-size: 0.9rem;
	margin-top: 0.5rem;
}

.mci-form-feedback.mci-success {
	background: #edfaef;
	color: #006e2e;
	border: 1px solid #68de7c;
}

.mci-form-feedback.mci-error {
	background: #fde8e8;
	color: #a00;
	border: 1px solid #f1a2a2;
}

/* No fiscal notice */
.mci-no-fiscal-notice {
	background: #fff8e5;
	border: 1px solid #dba617;
	border-radius: var(--mci-radius);
	padding: 1.5rem;
	margin-bottom: 1.5rem;
	text-align: center;
}

.mci-no-fiscal-notice p {
	margin: 0 0 1rem 0;
	font-size: 1rem;
	color: #916a00;
}

.mci-no-fiscal-msg {
	color: #916a00;
	font-size: 0.8rem;
	font-style: italic;
}

/* Responsive */
@media screen and (max-width: 768px) {
	.mci-invoice-table thead {
		display: none;
	}

	.mci-invoice-table tbody td {
		display: block;
		text-align: right;
		padding: 8px 14px;
		position: relative;
	}

	.mci-invoice-table tbody td::before {
		content: attr(data-label);
		position: absolute;
		left: 14px;
		font-weight: 600;
		color: #50575e;
		font-size: 0.8rem;
		text-transform: uppercase;
	}

	.mci-invoice-table tbody tr {
		display: block;
		margin-bottom: 1rem;
		border: 1px solid var(--mci-border);
		border-radius: var(--mci-radius);
	}

	.mci-action-buttons {
		justify-content: flex-end;
	}
}