/* ===========================================
   Dashboard - Premium Boutique Design
   Elevated with subtle animations & luxury feel
   =========================================== */

/* ===========================================
   Entry Animations
   =========================================== */
@keyframes dashboardReveal {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

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

@keyframes slideInRight {
	from {
		opacity: 0;
		transform: translateX(-15px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes scaleIn {
	from {
		opacity: 0;
		transform: scale(0.95);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

@keyframes shimmer {
	0% { left: -100%; }
	100% { left: 100%; }
}

.krpice-dashboard {
	max-width: 100%;
	animation: dashboardReveal 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) backwards;
}

/* ===========================================
   Header - Welcome Section
   =========================================== */
.dashboard-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding-bottom: var(--spacing-lg);
	margin-bottom: var(--spacing-lg);
	border-bottom: 1px solid var(--color-border);
	position: relative;
	animation: fadeInUp 0.5s ease 0.1s backwards;
}

/* Decorative accent line */
.dashboard-header::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 60px;
	height: 2px;
	background: linear-gradient(90deg, var(--color-accent), transparent);
}

.header-user {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
}

.user-avatar {
	position: relative;
}

.user-avatar img {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	object-fit: cover;
	border: 3px solid #fff;
	box-shadow:
		0 4px 12px rgba(86, 66, 51, 0.12),
		0 0 0 1px rgba(212, 163, 115, 0.2);
	transition: transform var(--transition-bounce), box-shadow var(--transition-base);
}

.user-avatar:hover img {
	transform: scale(1.05);
	box-shadow:
		0 6px 16px rgba(86, 66, 51, 0.18),
		0 0 0 2px rgba(212, 163, 115, 0.3);
}

/* Status indicator */
.user-avatar::after {
	content: '';
	position: absolute;
	bottom: 4px;
	right: 4px;
	width: 14px;
	height: 14px;
	background: var(--color-success, #27ae60);
	border: 2px solid #fff;
	border-radius: 50%;
}

.user-info h1 {
	font-size: 1.5rem;
	font-weight: 500;
	margin: 0 0 4px 0;
	color: var(--color-text);
	letter-spacing: -0.02em;
	font-family: var(--font-heading);
}

.member-since {
	font-size: 0.875rem;
	color: var(--color-text-light);
	margin: 0;
	display: flex;
	align-items: center;
	gap: 6px;
}

.member-since::before {
	content: '✦';
	color: var(--color-accent);
	font-size: 0.6rem;
}

/* ===========================================
   New Listing Button - Premium Gradient
   =========================================== */
.btn-new-listing {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 28px;
	background: linear-gradient(135deg, var(--color-primary) 0%, #4a3729 100%);
	color: #fff;
	border-radius: var(--radius-md);
	text-decoration: none;
	font-weight: 500;
	font-size: 0.95rem;
	font-family: var(--font-heading);
	position: relative;
	overflow: hidden;
	transition:
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
	animation: fadeInUp 0.5s ease 0.2s backwards;
}

/* Shimmer effect */
.btn-new-listing::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;
}

.btn-new-listing span {
	font-size: 1.2rem;
	font-weight: 300;
	transition: transform var(--transition-bounce);
}

.btn-new-listing:hover {
	color: #fff;
	transform: translateY(-3px);
	box-shadow:
		0 8px 20px rgba(86, 66, 51, 0.25),
		0 4px 8px rgba(86, 66, 51, 0.15);
}

.btn-new-listing:hover::before {
	left: 100%;
}

.btn-new-listing:hover span {
	transform: rotate(90deg);
}

.btn-new-listing:active {
	transform: translateY(-1px);
}

/* ===========================================
   Stats Grid - Elevated Cards
   =========================================== */
.dashboard-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-lg);
	animation: fadeInUp 0.5s ease 0.25s backwards;
}

.stat-item {
	background: #fff;
	padding: var(--spacing-lg);
	text-align: center;
	text-decoration: none;
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
	position: relative;
	overflow: hidden;
	transition:
		transform var(--transition-bounce),
		box-shadow var(--transition-base),
		border-color var(--transition-fast);
}

/* Staggered animations for stats */
.stat-item:nth-child(1) { animation: scaleIn 0.4s ease 0.3s backwards; }
.stat-item:nth-child(2) { animation: scaleIn 0.4s ease 0.35s backwards; }
.stat-item:nth-child(3) { animation: scaleIn 0.4s ease 0.4s backwards; }
.stat-item:nth-child(4) { animation: scaleIn 0.4s ease 0.45s backwards; }

/* Decorative top accent */
.stat-item::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 2px;
	background: var(--color-accent);
	transition: width var(--transition-base);
}

.stat-item:hover {
	transform: translateY(-4px);
	box-shadow:
		0 8px 24px rgba(86, 66, 51, 0.1),
		0 4px 8px rgba(86, 66, 51, 0.06);
	border-color: var(--color-accent);
}

.stat-item:hover::before {
	width: 40px;
}

.stat-item:hover .stat-number {
	transform: scale(1.08);
}

.stat-number {
	display: block;
	font-size: 2.2rem;
	font-weight: 600;
	color: var(--color-primary);
	line-height: 1;
	margin-bottom: 8px;
	letter-spacing: -0.02em;
	position: relative;
	font-family: var(--font-heading);
	transition: transform var(--transition-bounce);
}

.stat-item.has-badge .stat-number {
	display: inline-flex;
	align-items: flex-start;
	gap: 4px;
}

.badge {
	width: 10px;
	height: 10px;
	background: linear-gradient(135deg, #e74c3c, #c0392b);
	border-radius: 50%;
	flex-shrink: 0;
	animation: pulse 2s infinite;
}

@keyframes pulse {
	0%, 100% { transform: scale(1); opacity: 1; }
	50% { transform: scale(1.2); opacity: 0.8; }
}

.stat-label {
	display: block;
	font-size: 0.75rem;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 500;
}

/* ===========================================
   Quick Actions - Interactive Cards
   =========================================== */
.dashboard-actions {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-xl);
	animation: fadeInUp 0.5s ease 0.5s backwards;
}

.action-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--spacing-lg) var(--spacing-xl);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	text-decoration: none;
	position: relative;
	overflow: hidden;
	transition:
		border-color var(--transition-fast),
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
}

/* Left accent bar */
.action-item::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: 0;
	background: var(--color-accent);
	border-radius: 0 3px 3px 0;
	transition: height var(--transition-base);
}

.action-item:hover {
	border-color: var(--color-accent);
	transform: translateY(-4px);
	box-shadow:
		0 8px 24px rgba(86, 66, 51, 0.1),
		0 4px 8px rgba(86, 66, 51, 0.06);
}

.action-item:hover::before {
	height: 60%;
}

.action-content h3 {
	font-size: 1.1rem;
	font-weight: 500;
	margin: 0 0 4px 0;
	color: var(--color-text);
	font-family: var(--font-heading);
	transition: color var(--transition-fast);
}

.action-item:hover .action-content h3 {
	color: var(--color-primary);
}

.action-content p {
	font-size: 0.875rem;
	color: var(--color-text-light);
	margin: 0;
}

.action-arrow {
	font-size: 1.5rem;
	color: var(--color-text-light);
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-surface);
	border-radius: 50%;
	transition:
		color var(--transition-fast),
		background var(--transition-base),
		transform var(--transition-bounce);
}

.action-item:hover .action-arrow {
	color: #fff;
	background: var(--color-accent);
	transform: translateX(4px);
}

/* ===========================================
   Recent Listings Section - Premium Cards
   =========================================== */
.dashboard-recent {
	padding-top: var(--spacing-xl);
	border-top: 1px solid var(--color-border);
	position: relative;
	animation: fadeInUp 0.5s ease 0.55s backwards;
}

/* Decorative accent */
.dashboard-recent::before {
	content: '';
	position: absolute;
	top: -1px;
	left: 0;
	width: 40px;
	height: 2px;
	background: linear-gradient(90deg, var(--color-accent), transparent);
}

.section-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--spacing-lg);
}

.section-header h2 {
	font-size: 1.1rem;
	font-weight: 500;
	margin: 0;
	color: var(--color-text);
	letter-spacing: -0.01em;
	font-family: var(--font-heading);
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Decorative diamond */
.section-header h2::before {
	content: '◆';
	font-size: 0.5rem;
	color: var(--color-accent);
}

.link-all {
	font-size: 0.875rem;
	color: var(--color-text-light);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: color var(--transition-fast), gap var(--transition-bounce);
}

.link-all::after {
	content: '→';
	transition: transform var(--transition-bounce);
}

.link-all:hover {
	color: var(--color-accent);
	gap: 10px;
}

.link-all:hover::after {
	transform: translateX(2px);
}

.recent-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--spacing-md);
}

.recent-item {
	text-decoration: none;
	display: block;
	position: relative;
	transition: transform var(--transition-bounce);
}

/* Staggered animations for recent items */
.recent-item:nth-child(1) { animation: scaleIn 0.4s ease 0.6s backwards; }
.recent-item:nth-child(2) { animation: scaleIn 0.4s ease 0.65s backwards; }
.recent-item:nth-child(3) { animation: scaleIn 0.4s ease 0.7s backwards; }
.recent-item:nth-child(4) { animation: scaleIn 0.4s ease 0.75s backwards; }

.recent-item:hover {
	transform: translateY(-8px);
}

.recent-image {
	aspect-ratio: 3/4;
	background: var(--color-background);
	border-radius: var(--radius-md);
	overflow: hidden;
	margin-bottom: var(--spacing-sm);
	position: relative;
	box-shadow: 0 2px 8px rgba(86, 66, 51, 0.08);
	transition: box-shadow var(--transition-base);
}

.recent-item:hover .recent-image {
	box-shadow:
		0 12px 28px rgba(86, 66, 51, 0.15),
		0 4px 12px rgba(86, 66, 51, 0.08);
}

/* Overlay on hover */
.recent-image::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(86, 66, 51, 0.3) 0%,
		transparent 50%
	);
	opacity: 0;
	transition: opacity var(--transition-base);
}

.recent-item:hover .recent-image::after {
	opacity: 1;
}

.recent-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition:
		transform var(--transition-slow),
		filter var(--transition-base);
}

.recent-item:hover .recent-image img {
	transform: scale(1.08);
	filter: brightness(1.02) saturate(1.05);
}

.recent-image .no-image {
	width: 100%;
	height: 100%;
	background: linear-gradient(225deg, var(--color-border) 0%, var(--color-background) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}

.recent-image .no-image::before {
	content: '✦';
	font-size: 1.5rem;
	color: var(--color-accent);
	opacity: 0.5;
}

.recent-info {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 0 4px;
}

.recent-title {
	font-size: 0.875rem;
	color: var(--color-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	font-family: var(--font-heading);
	transition: color var(--transition-fast);
}

.recent-item:hover .recent-title {
	color: var(--color-primary);
}

.recent-price {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-primary);
	letter-spacing: -0.01em;
}

/* ===========================================
   Empty State - Elegant & Inviting
   =========================================== */
.dashboard-empty {
	padding: var(--spacing-2xl) var(--spacing-xl);
	margin-bottom: var(--spacing-2xl);
	text-align: center;
	background: linear-gradient(135deg, var(--color-surface) 0%, #fff 100%);
	border-radius: var(--radius-lg);
	border: 1px dashed var(--color-border);
	position: relative;
	animation: fadeInUp 0.5s ease 0.6s backwards;
}

/* Decorative corners */
.dashboard-empty::before,
.dashboard-empty::after {
	content: '✦';
	position: absolute;
	font-size: 0.75rem;
	color: var(--color-accent);
	opacity: 0.4;
}

.dashboard-empty::before {
	top: var(--spacing-md);
	left: var(--spacing-md);
}

.dashboard-empty::after {
	bottom: var(--spacing-md);
	right: var(--spacing-md);
}

.empty-content {
	max-width: 360px;
	margin: 0 auto;
}

.empty-content p {
	color: var(--color-text-light);
	margin-bottom: var(--spacing-lg);
	font-size: 1rem;
	line-height: 1.6;
}

.btn-start {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 32px;
	background: linear-gradient(135deg, var(--color-primary) 0%, #4a3729 100%);
	color: #fff;
	border-radius: var(--radius-md);
	text-decoration: none;
	font-weight: 500;
	font-family: var(--font-heading);
	position: relative;
	overflow: hidden;
	transition:
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
}

/* Shimmer effect */
.btn-start::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;
}

.btn-start:hover {
	color: #fff;
	transform: translateY(-3px);
	box-shadow:
		0 8px 20px rgba(86, 66, 51, 0.25),
		0 4px 8px rgba(86, 66, 51, 0.15);
}

.btn-start:hover::before {
	left: 100%;
}

.btn-start:active {
	transform: translateY(-1px);
}

/* ===========================================
   Responsive - Graceful Degradation
   =========================================== */

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
	.krpice-dashboard,
	.dashboard-header,
	.btn-new-listing,
	.dashboard-stats,
	.stat-item,
	.dashboard-actions,
	.dashboard-recent,
	.recent-item,
	.dashboard-empty {
		animation: none !important;
	}

	.btn-new-listing::before,
	.btn-start::before {
		display: none;
	}

	.badge {
		animation: none;
	}
}

@media (max-width: 992px) {
	.dashboard-stats {
		grid-template-columns: repeat(2, 1fr);
	}

	.recent-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	/* Reduce animation delays on tablet */
	.stat-item:nth-child(1),
	.stat-item:nth-child(2),
	.stat-item:nth-child(3),
	.stat-item:nth-child(4) {
		animation-delay: 0.2s;
	}

	.recent-item:nth-child(1),
	.recent-item:nth-child(2),
	.recent-item:nth-child(3),
	.recent-item:nth-child(4) {
		animation-delay: 0.3s;
	}
}

@media (max-width: 768px) {
	.dashboard-header {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-md);
	}

	/* Adjust decorative accent line */
	.dashboard-header::after {
		width: 40px;
	}

	.btn-new-listing {
		width: 100%;
		justify-content: center;
	}

	.user-avatar img {
		width: 56px;
		height: 56px;
	}

	/* Smaller status indicator */
	.user-avatar::after {
		width: 12px;
		height: 12px;
		bottom: 2px;
		right: 2px;
	}

	.user-info h1 {
		font-size: 1.25rem;
	}

	.dashboard-stats {
		grid-template-columns: repeat(2, 1fr);
	}

	.stat-item {
		padding: var(--spacing-md);
	}

	.stat-number {
		font-size: 1.5rem;
	}

	.stat-label {
		font-size: 0.7rem;
	}

	.dashboard-actions {
		grid-template-columns: 1fr;
	}

	.action-item {
		padding: var(--spacing-md);
	}

	.action-arrow {
		width: 36px;
		height: 36px;
		font-size: 1.25rem;
	}

	.recent-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-sm);
	}

	/* Simplified hover effects on tablet/mobile */
	.recent-image::after {
		display: none;
	}

	/* Empty state adjustments */
	.dashboard-empty {
		padding: var(--spacing-xl) var(--spacing-md);
	}

	.dashboard-empty::before,
	.dashboard-empty::after {
		display: none;
	}

	/* Section header adjustments */
	.section-header h2::before {
		font-size: 0.4rem;
	}
}

@media (max-width: 480px) {
	.dashboard-header {
		padding-bottom: var(--spacing-md);
		margin-bottom: var(--spacing-md);
	}

	.header-user {
		gap: var(--spacing-sm);
	}

	.user-avatar img {
		width: 48px;
		height: 48px;
	}

	/* Even smaller status indicator */
	.user-avatar::after {
		width: 10px;
		height: 10px;
		border-width: 1.5px;
	}

	.user-info h1 {
		font-size: 1.1rem;
	}

	.member-since {
		font-size: 0.8rem;
	}

	.member-since::before {
		font-size: 0.5rem;
	}

	.btn-new-listing {
		padding: 12px 20px;
		font-size: 0.85rem;
	}

	.stat-item {
		padding: var(--spacing-sm) var(--spacing-xs);
	}

	/* Hide decorative accent on small screens */
	.stat-item::before {
		display: none;
	}

	.stat-number {
		font-size: 1.25rem;
		margin-bottom: 4px;
	}

	.stat-label {
		font-size: 0.65rem;
	}

	.badge {
		width: 8px;
		height: 8px;
	}

	.action-content h3 {
		font-size: 1rem;
	}

	.action-content p {
		font-size: 0.8rem;
	}

	/* Hide action left accent bar on mobile */
	.action-item::before {
		display: none;
	}

	.action-arrow {
		width: 32px;
		height: 32px;
		font-size: 1.1rem;
	}

	.section-header h2 {
		font-size: 1rem;
	}

	.link-all {
		font-size: 0.8rem;
	}

	.recent-title,
	.recent-price {
		font-size: 0.8rem;
	}

	.empty-content p {
		font-size: 0.9rem;
	}

	.btn-start {
		padding: 12px 24px;
		font-size: 0.9rem;
	}
}
