*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

:root {
	--bg: #f0f2f5;
	--surface: #ffffff;
	--surface2: #f8f9fa;
	--border: #e0e4ea;
	--text: #1a1d23;
	--text2: #5a6072;
	--text3: #8892a4;
	--primary: #2563eb;
	--primary-h: #1d4ed8;
	--primary-s: #eff6ff;
	--accent: #0ea5e9;
	--success: #16a34a;
	--warning: #d97706;
	--danger: #dc2626;
	--radius: 10px;
	--radius-sm: 6px;
	--shadow: 0 1px 4px rgba(0, 0, 0, 0.08), 0 4px 16px rgba(0, 0, 0, 0.06);
	--shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.12);
	--transition: 0.18s ease;
	--sidebar-w: 280px;
	--header-h: 64px;
}

[data-theme="dark"] {
	--bg: #0f1117;
	--surface: #1a1d26;
	--surface2: #22263a;
	--border: #2d3247;
	--text: #e8ecf4;
	--text2: #9aa3b8;
	--text3: #5a6272;
	--primary: #3b82f6;
	--primary-h: #60a5fa;
	--primary-s: #1e3a5f;
	--shadow: 0 1px 4px rgba(0, 0, 0, 0.3), 0 4px 16px rgba(0, 0, 0, 0.25);
	--shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.4);
}

body {
	font-family: \"Inter\",
		system-ui,
		-apple-system,
		sans-serif;
	font-size: 14px;
	background: var(--bg);
	color: var(--text);
	min-height: 100vh;
	transition:
		background var(--transition),
		color var(--transition);
}

::-webkit-scrollbar {
	width: 6px;
	height: 6px;
}
::-webkit-scrollbar-track {
	background: transparent;
}
::-webkit-scrollbar-thumb {
	background: var(--border);
	border-radius: 99px;
}

/* ===== HEADER ===== */
#header {
	position: sticky;
	top: 0;
	z-index: 100;
	height: var(--header-h);
	background: var(--surface);
	border-bottom: 1px solid var(--border);
	box-shadow: var(--shadow);
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 0 20px;
}
#logo {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 22px;
	font-weight: 700;
	white-space: nowrap;
	flex-shrink: 0;
}
#logo a {
	color: var(--primary);
	text-decoration: none;
	display: flex;
	align-items: center;
	transition: opacity var(--transition);
}
#logo a:hover {
	opacity: 0.85;
}
#logo img {
	display: block;
}
#search-wrap {
	flex: 1;
	max-width: 520px;
	position: relative;
}
#search-wrap svg {
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--text3);
	pointer-events: none;
}
#globalSearch {
	width: 100%;
	padding: 9px 14px 9px 38px;
	border: 1.5px solid var(--border);
	border-radius: var(--radius);
	background: var(--surface2);
	color: var(--text);
	font-size: 14px;
	transition:
		border-color var(--transition),
		box-shadow var(--transition);
	outline: none;
}
#globalSearch:focus {
	border-color: var(--primary);
	box-shadow: 0 0 0 3px var(--primary-s);
}
#globalSearch::placeholder {
	color: var(--text3);
}
.header-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
	margin-left: auto;
}

.btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border-radius: var(--radius-sm);
	border: 1.5px solid transparent;
	cursor: pointer;
	font-size: 13px;
	font-weight: 600;
	transition: all var(--transition);
	white-space: nowrap;
	outline: none;
}
.btn:focus-visible {
	box-shadow: 0 0 0 3px var(--primary-s);
}
.btn-primary {
	background: var(--primary);
	color: #fff;
}
.btn-primary:hover {
	background: var(--primary-h);
}
.btn-ghost {
	background: transparent;
	color: var(--text2);
	border-color: var(--border);
}
.btn-ghost:hover {
	background: var(--surface2);
	color: var(--text);
}
.btn-danger {
	background: transparent;
	color: var(--danger);
	border-color: #fca5a5;
}
.btn-danger:hover {
	background: #fef2f2;
}
[data-theme="dark"] .btn-danger:hover {
	background: #3b0a0a;
}
.btn-icon {
	padding: 8px;
	border-radius: var(--radius-sm);
	background: transparent;
	border: 1.5px solid var(--border);
	color: var(--text2);
	cursor: pointer;
	transition: all var(--transition);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.btn-icon:hover {
	background: var(--surface2);
	color: var(--text);
}
#uploadLabel {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border-radius: var(--radius-sm);
	border: 1.5px solid var(--primary);
	cursor: pointer;
	font-size: 13px;
	font-weight: 600;
	color: var(--primary);
	background: var(--primary-s);
	transition: all var(--transition);
	white-space: nowrap;
}
#uploadLabel:hover {
	background: var(--primary);
	color: #fff;
}
#fileInput {
	display: none;
}

/* ===== CACHE BADGE ===== */
#cacheBadge {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 4px 10px;
	border-radius: 99px;
	font-size: 12px;
	font-weight: 600;
	border: 1.5px solid var(--border);
	background: var(--surface2);
	color: var(--text3);
	white-space: nowrap;
	flex-shrink: 0;
}
#cacheBadge.active {
	color: var(--success);
	border-color: #86efac;
	background: #f0fdf4;
}
#cacheBadge.memory {
	color: var(--warning);
	border-color: #fde68a;
	background: #fffbeb;
}
[data-theme="dark"] #cacheBadge.active {
	background: #052e16;
	border-color: #166534;
}
[data-theme="dark"] #cacheBadge.memory {
	background: #2d1a00;
	border-color: #92400e;
}

/* ===== LAYOUT ===== */
#layout {
	display: flex;
	min-height: calc(100vh - var(--header-h));
}

/* ===== SIDEBAR ===== */
#sidebar {
	width: var(--sidebar-w);
	flex-shrink: 0;
	background: var(--surface);
	border-right: 1px solid var(--border);
	padding: 16px;
	overflow-y: auto;
	height: calc(100vh - var(--header-h));
	position: sticky;
	top: var(--header-h);
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.filter-section {
	border-bottom: 1px solid var(--border);
	padding-bottom: 16px;
}
.filter-section:last-child {
	border-bottom: none;
	padding-bottom: 0;
}
.filter-title {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--text3);
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 6px;
}
.quick-search-wrap {
	position: relative;
}
.quick-search-wrap svg {
	position: absolute;
	left: 9px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--text3);
	pointer-events: none;
}
#quickSearch {
	width: 100%;
	padding: 7px 10px 7px 30px;
	border: 1.5px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface2);
	color: var(--text);
	font-size: 13px;
	outline: none;
	transition: border-color var(--transition);
}
#quickSearch:focus {
	border-color: var(--primary);
}
.checklist {
	display: flex;
	flex-direction: column;
	gap: 6px;
	max-height: 180px;
	overflow-y: auto;
}
.checklist label {
	display: flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	font-size: 13px;
	color: var(--text2);
	padding: 3px 4px;
	border-radius: var(--radius-sm);
	transition: background var(--transition);
}
.checklist label:hover {
	background: var(--surface2);
}
.checklist label input[type="checkbox"] {
	accent-color: var(--primary);
	width: 15px;
	height: 15px;
}
.checklist-count {
	margin-left: auto;
	font-size: 11px;
	background: var(--surface2);
	border: 1px solid var(--border);
	border-radius: 99px;
	padding: 1px 7px;
	color: var(--text3);
}
.date-range {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.date-range label {
	font-size: 12px;
	color: var(--text2);
}
.date-range input[type="date"] {
	width: 100%;
	padding: 7px 9px;
	border: 1.5px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface2);
	color: var(--text);
	font-size: 13px;
	outline: none;
}
.date-range input[type="date"]:focus {
	border-color: var(--primary);
}
.usd-range {
	display: flex;
	gap: 8px;
	align-items: center;
}
.usd-range input {
	width: 100%;
	padding: 7px 9px;
	border: 1.5px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface2);
	color: var(--text);
	font-size: 13px;
	outline: none;
}
.usd-range input:focus {
	border-color: var(--primary);
}
.usd-sep {
	color: var(--text3);
	font-size: 12px;
	flex-shrink: 0;
}
#pageSize {
	width: 100%;
	padding: 7px 9px;
	border: 1.5px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface2);
	color: var(--text);
	font-size: 13px;
	outline: none;
	cursor: pointer;
}
#activeChips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.chip {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 3px 8px 3px 10px;
	border-radius: 99px;
	background: var(--primary-s);
	border: 1px solid #93c5fd;
	color: var(--primary);
	font-size: 12px;
	font-weight: 600;
}
.chip button {
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	color: var(--primary);
	font-size: 14px;
	line-height: 1;
	display: flex;
	align-items: center;
}
.chip button:hover {
	color: var(--danger);
}

/* ===== MAIN ===== */
#main {
	flex: 1;
	padding: 20px;
	overflow: hidden;
	min-width: 0;
}
#mainToolbar {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
	flex-wrap: wrap;
}
#resultCount {
	font-size: 14px;
	font-weight: 700;
	color: var(--text2);
	flex: 1;
	min-width: 140px;
}
#resultCount span {
	color: var(--primary);
}
#sortSelect {
	padding: 7px 10px;
	border: 1.5px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface);
	color: var(--text);
	font-size: 13px;
	cursor: pointer;
	outline: none;
}
#sortSelect:focus {
	border-color: var(--primary);
}

/* ===== CARDS GRID ===== */
#cardsGrid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
	gap: 14px;
}
.card {
	background: var(--surface);
	border: 1.5px solid var(--border);
	border-radius: var(--radius);
	padding: 16px;
	cursor: pointer;
	transition: all var(--transition);
	position: relative;
	overflow: hidden;
}
.card::before {
	content: \"\";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--primary), var(--accent));
	opacity: 0;
	transition: opacity var(--transition);
}
.card:hover {
	border-color: var(--primary);
	box-shadow: var(--shadow-lg);
	transform: translateY(-2px);
}
.card:hover::before {
	opacity: 1;
}
.card:active {
	transform: translateY(0);
}
.card-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 10px;
}
.card-id {
	font-size: 11px;
	font-weight: 700;
	font-family: \"Courier New\", monospace;
	color: var(--primary);
	background: var(--primary-s);
	padding: 3px 8px;
	border-radius: var(--radius-sm);
	letter-spacing: 0.03em;
}
.card-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
}
.badge {
	font-size: 11px;
	font-weight: 600;
	padding: 2px 8px;
	border-radius: 99px;
	white-space: nowrap;
}
.badge-svc {
	background: #ede9fe;
	color: #6d28d9;
	border: 1px solid #c4b5fd;
}
.badge-tramo {
	background: #e0f2fe;
	color: #0369a1;
	border: 1px solid #7dd3fc;
}
.badge-status {
	background: #fef9c3;
	color: #854d0e;
	border: 1px solid #fde047;
}
.badge-risk {
	background: #fee2e2;
	color: #b91c1c;
	border: 1px solid #fca5a5;
}
[data-theme="dark"] .badge-svc {
	background: #2e1065;
	color: #c4b5fd;
	border-color: #4c1d95;
}
[data-theme="dark"] .badge-tramo {
	background: #0c2a3d;
	color: #7dd3fc;
	border-color: #0e4163;
}
[data-theme="dark"] .badge-status {
	background: #2d1e00;
	color: #fde047;
	border-color: #713f12;
}
[data-theme="dark"] .badge-risk {
	background: #3b0a0a;
	color: #fca5a5;
	border-color: #7f1d1d;
}
.card-desc {
	font-size: 13px;
	font-weight: 500;
	color: var(--text);
	margin-bottom: 10px;
	line-height: 1.45;
	display: -webkit-box;
	line-clamp: 2;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.card-desc.empty {
	color: var(--text3);
	font-style: italic;
}
.card-meta {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 6px;
}
.card-meta-item {
	display: flex;
	flex-direction: column;
	gap: 1px;
}
.card-meta-label {
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--text3);
}
.card-meta-value {
	font-size: 12px;
	font-weight: 600;
	color: var(--text2);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.card-meta-value.usd {
	color: var(--success);
}
.card-meta-value.eta-high {
	color: var(--danger);
}
.card-meta-value.eta-mid {
	color: var(--warning);
}
.card-footer {
	margin-top: 10px;
	padding-top: 10px;
	border-top: 1px solid var(--border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}
.card-date {
	font-size: 11px;
	color: var(--text3);
	display: flex;
	align-items: center;
	gap: 5px;
}
.card-click-hint {
	font-size: 11px;
	color: var(--primary);
	font-weight: 600;
	opacity: 0;
	transition: opacity var(--transition);
	display: flex;
	align-items: center;
	gap: 4px;
}
.card:hover .card-click-hint {
	opacity: 1;
}

/* ===== EMPTY / DROP ===== */
#emptyState {
	grid-column: 1 / -1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 80px 20px;
	text-align: center;
	color: var(--text3);
	gap: 12px;
}
#emptyState .empty-icon {
	font-size: 56px;
}
#emptyState h3 {
	font-size: 18px;
	font-weight: 700;
	color: var(--text2);
}
#emptyState p {
	font-size: 14px;
	max-width: 360px;
	line-height: 1.5;
}
#dropZone {
	border: 2.5px dashed var(--border);
	border-radius: var(--radius);
	padding: 40px 20px;
	text-align: center;
	color: var(--text3);
	transition: all var(--transition);
	cursor: pointer;
	grid-column: 1 / -1;
}
#dropZone.drag-over {
	border-color: var(--primary);
	background: var(--primary-s);
	color: var(--primary);
}
#dropZone .drop-icon {
	font-size: 40px;
	margin-bottom: 12px;
}
#dropZone h3 {
	font-size: 16px;
	font-weight: 700;
	color: var(--text2);
	margin-bottom: 6px;
}
#dropZone p {
	font-size: 13px;
}

/* ===== DEBUG PANEL ===== */
#debugPanel {
	background: #1e1e2e;
	color: #cdd6f4;
	font-family: monospace;
	font-size: 12px;
	padding: 12px 16px;
	border-radius: var(--radius);
	margin-bottom: 16px;
	max-height: 180px;
	overflow-y: auto;
	display: none;
	line-height: 1.6;
	border: 1px solid #313244;
}
#debugPanel.show {
	display: block;
}
#debugPanel .log-ok {
	color: #a6e3a1;
}
#debugPanel .log-warn {
	color: #f9e2af;
}
#debugPanel .log-err {
	color: #f38ba8;
}
#debugPanel .log-info {
	color: #89dceb;
}
#debugToggle {
	font-size: 12px;
	color: var(--text3);
	cursor: pointer;
	text-decoration: underline;
}

/* ===== PAGINATION ===== */
#pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	margin-top: 24px;
	flex-wrap: wrap;
}
.page-btn {
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border-radius: var(--radius-sm);
	border: 1.5px solid var(--border);
	background: var(--surface);
	color: var(--text2);
	cursor: pointer;
	font-size: 13px;
	font-weight: 600;
	transition: all var(--transition);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.page-btn:hover:not(:disabled) {
	background: var(--primary);
	color: #fff;
	border-color: var(--primary);
}
.page-btn.active {
	background: var(--primary);
	color: #fff;
	border-color: var(--primary);
}
.page-btn:disabled {
	opacity: 0.35;
	cursor: not-allowed;
}
#pageJumpWrap {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--text2);
}
#pageJump {
	width: 60px;
	padding: 6px 8px;
	border: 1.5px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface2);
	color: var(--text);
	font-size: 13px;
	text-align: center;
	outline: none;
}
#pageJump:focus {
	border-color: var(--primary);
}

/* ===== TOAST ===== */
#toastContainer {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: 10000;
	display: flex;
	flex-direction: column;
	gap: 10px;
	pointer-events: none;
}
.toast {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 18px;
	border-radius: var(--radius);
	background: var(--surface);
	border: 1.5px solid var(--border);
	box-shadow: var(--shadow-lg);
	font-size: 13px;
	font-weight: 600;
	color: var(--text);
	pointer-events: auto;
	animation: slideUp 0.25s ease;
	min-width: 240px;
	max-width: 380px;
}
.toast.success {
	border-color: #86efac;
	background: #f0fdf4;
	color: #15803d;
}
.toast.error {
	border-color: #fca5a5;
	background: #fef2f2;
	color: #b91c1c;
}
.toast.info {
	border-color: #93c5fd;
	background: #eff6ff;
	color: #1d4ed8;
}
.toast.warn {
	border-color: #fde68a;
	background: #fffbeb;
	color: #b45309;
}
[data-theme="dark"] .toast.success {
	background: #052e16;
	color: #4ade80;
	border-color: #166534;
}
[data-theme="dark"] .toast.error {
	background: #3b0a0a;
	color: #f87171;
	border-color: #7f1d1d;
}
[data-theme="dark"] .toast.info {
	background: #1e3a5f;
	color: #93c5fd;
	border-color: #1e40af;
}
[data-theme="dark"] .toast.warn {
	background: #2d1a00;
	color: #fbbf24;
	border-color: #92400e;
}
.toast-fade-out {
	animation: fadeOut 0.4s ease forwards;
}
@keyframes slideUp {
	from {
		transform: translateY(20px);
		opacity: 0;
	}
	to {
		transform: translateY(0);
		opacity: 1;
	}
}
@keyframes fadeOut {
	to {
		opacity: 0;
		transform: translateY(10px);
	}
}

#progressBar {
	position: fixed;
	top: 0;
	left: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--primary), var(--accent));
	transition: width 0.3s ease;
	z-index: 9999;
}

/* ===== HIGHLIGHTING ===== */
mark.highlight {
	background: #fef08a;
	color: inherit;
	padding: 0 1px;
	border-radius: 2px;
}
[data-theme="dark"] mark.highlight {
	background: #854d0e;
	color: #fef9c3;
}

/* ===== VIEW TOGGLE (Lista / Grid) ===== */
#viewToggle {
	display: flex;
	border: 1.5px solid var(--border);
	border-radius: var(--radius-sm);
	overflow: hidden;
	flex-shrink: 0;
}
#viewToggle .view-btn {
	border: none;
	border-radius: 0;
	padding: 6px 10px;
	background: transparent;
	color: var(--text3);
	cursor: pointer;
	transition: all var(--transition);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
#viewToggle .view-btn:hover {
	background: var(--surface2);
	color: var(--text);
}
#viewToggle .view-btn.active {
	background: var(--primary);
	color: #fff;
}

/* ===== LIST VIEW ===== */
#cardsGrid.list-view {
	grid-template-columns: 1fr;
	gap: 8px;
}
#cardsGrid.list-view .card {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 12px 14px;
}
#cardsGrid.list-view .card::before {
	display: none;
}
#cardsGrid.list-view .card:hover {
	transform: none;
}
#cardsGrid.list-view .card-desc {
	order: -2;
	flex: none;
	margin-bottom: 0;
	line-height: 1.4;
	display: block;
	overflow: visible;
	text-overflow: clip;
	white-space: normal;
	word-break: break-word;
	font-weight: 600;
	color: var(--text);
	margin-bottom: 6px;
}
#cardsGrid.list-view .card-desc.empty {
	display: none;
}
#cardsGrid.list-view .card-header {
	order: -1;
	margin-bottom: 0;
	gap: 8px;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
#cardsGrid.list-view .card-id {
	font-size: 11px;
	flex-shrink: 0;
}
#cardsGrid.list-view .card-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
}
#cardsGrid.list-view .card-meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
	gap: 12px;
	width: 100%;
}
#cardsGrid.list-view .card-meta .card-meta-item {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
#cardsGrid.list-view .card-meta .card-meta-label {
	font-size: 10px;
	font-weight: 600;
	text-transform: uppercase;
}
#cardsGrid.list-view .card-meta .card-meta-value {
	font-size: 12px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
#cardsGrid.list-view .card-footer {
	margin-top: 6px;
	padding-top: 6px;
	border-top: 1px solid var(--border);
	width: 100%;
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}
#cardsGrid.list-view .card-date {
	font-size: 11px;
	color: var(--text3);
	display: flex;
	align-items: center;
	gap: 4px;
	flex-shrink: 0;
}
#cardsGrid.list-view .card-click-hint {
	display: flex;
}

/* ===== CONFIRMATION MODAL ===== */
.modal-overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.45);
	backdrop-filter: blur(4px);
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
}
.modal-box {
	background: var(--surface);
	border: 1.5px solid var(--border);
	border-radius: var(--radius);
	box-shadow: var(--shadow-lg);
	padding: 24px;
	max-width: 420px;
	width: 90%;
	animation: modalSlideUp 0.2s ease;
}
@keyframes modalSlideUp {
	from {
		transform: translateY(20px);
		opacity: 0;
	}
	to {
		transform: translateY(0);
		opacity: 1;
	}
}
.modal-icon {
	font-size: 32px;
	margin-bottom: 12px;
}
.modal-title {
	font-size: 16px;
	font-weight: 700;
	color: var(--text);
	margin-bottom: 8px;
}
.modal-message {
	font-size: 14px;
	color: var(--text2);
	margin-bottom: 20px;
	line-height: 1.5;
}
.modal-actions {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
	#sidebar {
		display: none;
	}
	#cardsGrid {
		grid-template-columns: 1fr;
	}
	#cardsGrid.list-view .card-meta {
		display: none;
	}
}
@media (max-width: 540px) {
	#header {
		gap: 8px;
		padding: 0 12px;
	}
	#cacheBadge {
		display: none;
	}
	#viewToggle {
		display: none;
	}
}

/* ===== SETTINGS MODAL EXTENSION ===== */
.modal-box-lg {
	max-width: 580px;
}
.modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--border);
}
.modal-header .modal-title {
	margin-bottom: 0;
	font-size: 18px;
}
.settings-section {
	background: var(--surface2);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 16px;
	margin-bottom: 16px;
}
.settings-section:last-child {
	margin-bottom: 0;
}
.settings-header {
	margin-bottom: 12px;
}
.settings-header h4 {
	font-size: 14px;
	font-weight: 700;
	color: var(--text);
	margin-bottom: 4px;
}
.settings-header p {
	font-size: 13px;
	color: var(--text2);
	margin-bottom: 0;
	line-height: 1.4;
}
#enrichmentData {
	width: 100%;
	padding: 10px;
	border: 1.5px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface);
	color: var(--text);
	font-size: 13px;
	font-family: inherit;
	resize: vertical;
	outline: none;
}
#enrichmentData:focus {
	border-color: var(--primary);
}
.btn-success {
	background: var(--success);
	color: #fff;
	border-color: transparent;
}
.btn-success:hover {
	background: #15803d;
}
[data-theme="dark"] .btn-success:hover {
	background: #14532d;
}
