
:root {
	--dte-primary: #6CC4BF;
	--dte-primary-dark: #4e8683;
	--dte-accent: #f7fdfc;
	--dte-light: #f8f9fa;
	--dte-border: #e6f2f1;
	--dte-text: #333;
	--dte-text-light: #6c757d;
	--dte-success: #28a745;
	--dte-danger: #e74c3c;
	--dte-warning: #ffc107;
	--dte-info: #17a2b8;
	--dte-shadow: 0 2px 8px rgba(0,0,0,0.08);
	--dte-shadow-lg: 0 4px 20px rgba(0,0,0,0.1);
	--dte-radius: 12px;
	--dte-radius-sm: 8px;
}

.dte-wrapper {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	color: var(--dte-text);
}

.dte-header { 
	display: flex; 
	gap: 1.5rem; 
	align-items: center; 
	justify-content: space-between; 
	margin-bottom: 1.5rem; 
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--dte-border);
}
.dte-summary { 
	display: flex; 
	gap: 1rem; 
	flex-wrap: wrap; 
	margin-bottom: 1.5rem;
}
.dte-card { 
	background: white; 
	border-radius: var(--dte-radius); 
	padding: 1.25rem 1.5rem; 
	box-shadow: var(--dte-shadow);
	flex: 1;
	min-width: 180px;
	border-top: 4px solid var(--dte-primary);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.dte-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}
.dte-card h6 { 
	margin: 0 0 0.5rem; 
	font-size: 0.85rem; 
	color: var(--dte-text-light);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.dte-card .value { 
	font-size: 1.5rem; 
	font-weight: 700; 
	color: var(--dte-primary-dark);
	line-height: 1.2;
}
/* Enhanced Filters Section */
.dte-filters { 
	background: linear-gradient(135deg, #ffffff 0%, #f8fdfc 100%);
	border-radius: var(--dte-radius); 
	padding: 1.5rem; 
	margin-bottom: 1.5rem; 
	box-shadow: var(--dte-shadow-lg);
	border: 1px solid var(--dte-border);
	position: relative;
	overflow: hidden;
}
.dte-filters::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--dte-primary) 0%, var(--dte-primary-dark) 100%);
}
.dte-filter-header {
	display: flex;
	align-items: center;
	margin-bottom: 1.25rem;
	gap: 0.75rem;
}
.dte-filter-icon {
	background: var(--dte-primary);
	color: white;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
}
.dte-filter-title {
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--dte-primary-dark);
	margin: 0;
}
.dte-filter-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 1rem;
	margin-bottom: 1rem;
}
.dte-filter-group {
	margin-bottom: 0;
}
.dte-filter-group .form-label {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 600;
	color: var(--dte-primary-dark);
	margin-bottom: 0.5rem;
	font-size: 0.9rem;
}
.dte-filter-group .form-label i {
	color: var(--dte-primary);
}
.dte-date-range {
	grid-column: 1 / -1;
	background: var(--dte-accent);
	padding: 1rem;
	border-radius: var(--dte-radius-sm);
	border: 1px solid var(--dte-border);
}
.dte-date-range-header {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
	color: var(--dte-primary-dark);
	font-weight: 600;
	font-size: 0.9rem;
}
.dte-date-range-grid {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: 0.75rem;
	align-items: end;
}
.dte-table-container {
	background: white;
	border-radius: var(--dte-radius);
	overflow: hidden;
	box-shadow: var(--dte-shadow);
	border: 1px solid var(--dte-border);
}
.dte-table {
	margin: 0;
}
.dte-table thead th { 
	vertical-align: middle;
	background-color: var(--dte-accent);
	color: var(--dte-primary-dark);
	font-weight: 600;
	padding: 1rem 0.75rem;
	border-bottom: 1px solid var(--dte-border);
}
.dte-table tbody td {
	padding: 0.875rem 0.75rem;
	vertical-align: middle;
	border-bottom: 1px solid var(--dte-border);
}
.dte-table tbody tr:last-child td {
	border-bottom: none;
}
.dte-table tbody tr:hover {
	background-color: rgba(108, 196, 191, 0.05);
}
.dte-badge-income { 
	background: rgba(108,196,191,0.15); 
	color: var(--dte-primary-dark); 
	padding: 0.35rem 0.75rem; 
	border-radius: 999px; 
	font-weight: 600;
	font-size: 0.8rem;
	display: inline-block;
}
.dte-badge-expense { 
	background: rgba(255,200,200,0.12); 
	color: #c43d3d; 
	padding: 0.35rem 0.75rem; 
	border-radius: 999px; 
	font-weight: 600;
	font-size: 0.8rem;
	display: inline-block;
}
.dte-pagination { 
	display: flex; 
	gap: 0.5rem; 
	align-items: center; 
	justify-content: flex-end; 
	margin-top: 1rem;
	padding: 1rem 1.5rem;
	background-color: var(--dte-accent);
	border-top: 1px solid var(--dte-border);
}
.dte-page-btn { 
	border: 1px solid var(--dte-border); 
	background: white; 
	padding: 0.5rem 0.75rem; 
	border-radius: var(--dte-radius-sm); 
	cursor: pointer;
	font-size: 0.875rem;
	transition: all 0.2s ease;
}
.dte-page-btn:hover:not(:disabled) {
	background-color: var(--dte-primary);
	color: white;
	border-color: var(--dte-primary);
}
.dte-page-btn.active { 
	background: var(--dte-primary); 
	color: white; 
	border-color: var(--dte-primary-dark); 
}
.dte-page-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}
.dte-small-muted { 
	font-size: 0.8rem; 
	color: var(--dte-text-light);
	margin-top: 0.25rem;
}
.dte-action-btn { 
	margin-right: 0.5rem; 
}
.dte-btn-primary {
	background: var(--dte-primary);
	color: white;
	border: none;
	border-radius: var(--dte-radius-sm);
	padding: 0.625rem 1.25rem;
	font-weight: 600;
	transition: all 0.2s ease;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.dte-btn-primary:hover {
	background: var(--dte-primary-dark);
	color: white;
	transform: translateY(-1px);
	box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}
.dte-btn-outline {
	background: transparent;
	color: var(--dte-primary-dark);
	border: 1px solid var(--dte-primary);
	border-radius: var(--dte-radius-sm);
	padding: 0.725rem 1.5rem !important;
	font-weight: 500;
	transition: all 0.2s ease;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.dte-btn-outline:hover {
	background: var(--dte-primary);
	color: white;
}
/* Enhanced Delete Button */
.dte-btn-danger {
	background: linear-gradient(135deg, #e74c3c 0%, #c0392b 100%);
	color: white;
	border: none;
	border-radius: var(--dte-radius-sm);
	padding: 0.5rem 1rem;
	font-weight: 500;
	transition: all 0.3s ease;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	position: relative;
	overflow: hidden;
}
.dte-btn-danger::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
	transition: left 0.5s ease;
}
.dte-btn-danger:hover::before {
	left: 100%;
}
.dte-btn-danger:hover {
	background: linear-gradient(135deg, #c0392b 0%, #a93226 100%);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(231, 76, 60, 0.3);
}
.dte-btn-warning {
	background: linear-gradient(135deg, var(--dte-warning) 0%, #e0a800 100%);
	color: #212529;
	border: none;
	border-radius: var(--dte-radius-sm);
	padding: 0.5rem 1rem;
	font-weight: 500;
	transition: all 0.2s ease;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.dte-btn-warning:hover {
	background: linear-gradient(135deg, #e0a800 0%, #d39e00 100%);
	transform: translateY(-1px);
	box-shadow: 0 4px 8px rgba(255, 193, 7, 0.3);
}
.dte-form-card {
	background: white;
	border-radius: var(--dte-radius);
	padding: 1.5rem;
	box-shadow: var(--dte-shadow);
	border: 1px solid var(--dte-border);
	margin-top: 1rem;
}
.dte-form-card h5 {
	color: var(--dte-primary-dark);
	margin-bottom: 1.25rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--dte-border);
	font-weight: 600;
}
.form-label {
	font-weight: 600;
	color: var(--dte-text);
	margin-bottom: 0.5rem;
	font-size: 0.9rem;
}
.form-control, .form-select {
	border: 1px solid var(--dte-border);
	border-radius: var(--dte-radius-sm);
	padding: 0.625rem 0.75rem;
	transition: all 0.2s ease;
	background: white;
}
.form-control:focus, .form-select:focus {
	border-color: var(--dte-primary);
	box-shadow: 0 0 0 0.2rem rgba(108, 196, 191, 0.25);
	background: white;
}
.sortable-header {
	cursor: pointer;
	user-select: none;
	transition: color 0.2s ease;
	display: flex;
	align-items: center;
	gap: 0.25rem;
}
.sortable-header:hover {
	color: var(--dte-primary);
}
.sort-indicator {
	font-size: 0.75rem;
	opacity: 0.7;
}
.dte-action-group {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}
/* Add these styles to your existing CSS */
.dte-btn-pdf {
    background: linear-gradient(135deg, #e74c3c 0%, #c0392b 100%);
    color: white;
    border: none;
    border-radius: var(--dte-radius-sm);
    padding: 0.725rem 1.25rem !important;
    font-weight: 600;
    transition: all 0.2s ease;
    /* display: inline-flex; */
    align-items: center;
    gap: 0.5rem;
}

.dte-btn-pdf:hover {
    background: linear-gradient(135deg, #c0392b 0%, #a93226 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(231, 76, 60, 0.3);
}

.dte-pdf-loading {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255,255,255,0.3);
    border-radius: 50%;
    border-top-color: white;
    animation: spin 1s ease-in-out infinite;
    margin-right: 8px;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* PDF Download Modal */
.dte-pdf-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
    z-index: 9999;
    justify-content: center;
    align-items: center;
}

.dte-pdf-modal-content {
    background: white;
    border-radius: var(--dte-radius);
    padding: 2rem;
    max-width: 500px;
    width: 90%;
    box-shadow: var(--dte-shadow-lg);
}

.dte-pdf-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--dte-border);
}

.dte-pdf-modal-title {
    color: var(--dte-primary-dark);
    font-weight: 600;
    font-size: 1.25rem;
    margin: 0;
}

.dte-pdf-modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--dte-text-light);
    transition: color 0.2s ease;
}

.dte-pdf-modal-close:hover {
    color: var(--dte-primary);
}

.dte-pdf-options {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.dte-pdf-option-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.dte-pdf-option-label {
    font-weight: 600;
    color: var(--dte-text);
    font-size: 0.9rem;
}

.dte-pdf-checkbox {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
}

.dte-pdf-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
}

.dte-pdf-checkbox span {
    font-size: 0.9rem;
    color: var(--dte-text);
}

@media(max-width: 767px) {
	.dte-summary { 
		flex-direction: column; 
	}
	.dte-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
	}
	.dte-pagination {
		flex-wrap: wrap;
		justify-content: center;
	}
	.dte-filter-grid {
		grid-template-columns: 1fr;
	}
	.dte-date-range-grid {
		grid-template-columns: 1fr;
	}
	.dte-action-group {
		flex-direction: column;
	}

	
}

@media(max-width: 420px){
.dt-transaction-btn {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
}

