/* =================================
   Daily Notes Timeline
   Horizontal scrolling timeline with Fluent Design
   ================================= */

.daily-notes-timeline-wrapper {
	position: relative;
	width: 100%;
	margin: var(--space-5) 0;
	padding: var(--space-5) 0 var(--space-6);
	background: radial-gradient(circle at 15% 50%, color-mix(in srgb, var(--color-primary) 3%, transparent) 0%, transparent 40%),
		radial-gradient(circle at 85% 20%, color-mix(in srgb, var(--color-accent) 3%, transparent) 0%, transparent 35%);
	border-radius: var(--radius-lg);
}

.daily-notes-archive .timeline-controls {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-bottom: var(--space-5);
	padding: var(--space-3) 0 var(--space-5);
}

.daily-notes-archive .timeline-pills {
	display: inline-flex;
	gap: var(--space-2);
	overflow-x: auto;
	padding: var(--space-1) 0;
	scrollbar-width: thin;
	scrollbar-color: var(--color-primary) transparent;
	scroll-snap-type: x mandatory;
}

.daily-notes-archive .pill {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	padding: 0.55rem 0.95rem;
	background: color-mix(in srgb, var(--color-primary) 10%, transparent);
	border: 1px solid color-mix(in srgb, var(--color-primary) 20%, var(--color-border));
	border-radius: 999px;
	color: var(--color-text-secondary);
	font-weight: 700;
	font-size: 0.9rem;
	text-decoration: none;
	transition: all var(--transition-speed) var(--transition-easing);
	scroll-snap-align: start;
	cursor: pointer;
}

.daily-notes-archive .pill:hover {
	background: color-mix(in srgb, var(--color-primary) 18%, transparent);
	color: var(--color-primary);
	transform: translateY(-2px);
	text-decoration: none;
	box-shadow: 0 8px 20px var(--color-shadow);
}

.daily-notes-archive .pill.is-active {
	background: linear-gradient(135deg, var(--color-primary), color-mix(in srgb, var(--color-primary) 80%, var(--color-accent)));
	color: #fff;
	border-color: var(--color-primary);
	box-shadow: 0 12px 32px color-mix(in srgb, var(--color-primary) 35%, transparent);
	font-weight: 800;
}

.daily-notes-archive .pill:focus-visible {
	outline: 3px solid color-mix(in srgb, var(--color-primary) 60%, transparent);
	outline-offset: 2px;
}

.daily-notes-archive .timeline-cta .cta-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 0.65rem 1.1rem;
	border-radius: var(--radius-sm);
	background: linear-gradient(135deg, var(--color-primary), color-mix(in srgb, var(--color-primary) 70%, var(--color-accent)));
	color: #fff;
	text-decoration: none;
	box-shadow: 0 12px 30px var(--color-shadow-lg);
	transition: transform var(--transition-speed) var(--transition-easing), box-shadow var(--transition-speed) var(--transition-easing);
}

.daily-notes-archive .cta-link:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 40px var(--color-shadow-lg);
}

.daily-notes-archive .cta-link i {
	font-size: 1rem;
}

.daily-notes-timeline {
	display: flex;
	gap: 1.5rem;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-behavior: smooth;
	padding: 1rem 0 2rem;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	scrollbar-color: var(--color-primary) var(--color-border);
	scroll-snap-type: x mandatory;
	scroll-padding: 1rem;
}

.daily-notes-timeline::-webkit-scrollbar {
	height: 8px;
}

.daily-notes-timeline::-webkit-scrollbar-track {
	background: var(--color-bg-secondary);
	border-radius: 4px;
}

.daily-notes-timeline::-webkit-scrollbar-thumb {
	background: var(--color-primary);
	border-radius: 4px;
	transition: background 0.3s ease;
}

.daily-notes-timeline::-webkit-scrollbar-thumb:hover {
	background: color-mix(in srgb, var(--color-primary) 85%, var(--color-primary-light));
}

/* Daily Notes Day Container */
.daily-notes-day {
	flex: 0 0 auto;
	min-width: 320px;
	max-width: 400px;
	background: linear-gradient(135deg, var(--color-surface), color-mix(in srgb, var(--color-primary) 2%, var(--color-surface)));
	border-radius: var(--radius-lg);
	box-shadow: 0 12px 28px var(--color-shadow), inset 0 0 40px color-mix(in srgb, var(--color-primary) 1.5%, transparent);
	padding: var(--space-5);
	transition: transform var(--transition-smooth), box-shadow var(--transition-smooth), border-color var(--transition-smooth);
	border: 1px solid var(--color-border);
	scroll-snap-align: start;
	scroll-snap-stop: always;
	backdrop-filter: blur(4px);
}

.daily-notes-day:hover {
	transform: translateY(-6px);
	box-shadow: 0 20px 40px var(--color-shadow-lg), inset 0 0 40px color-mix(in srgb, var(--color-primary) 2%, transparent);
	border-color: color-mix(in srgb, var(--color-primary) 22%, var(--color-border));
}

/* Day Header */
.daily-notes-day-header {
	margin-bottom: 1.5rem;
	padding-bottom: 1.25rem;
	border-bottom: 2px solid var(--color-primary);
	position: relative;
}

.daily-notes-day-header::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--color-accent);
	transition: width var(--transition-speed);
}

.daily-notes-day:hover .daily-notes-day-header::after {
	width: 100%;
}

.daily-notes-date {
	font-size: clamp(1.3rem, 5vw, 1.75rem);
	font-weight: 700;
	color: var(--color-text-primary);
	margin: 0 0 0.5rem;
	line-height: 1.2;
	background: linear-gradient(135deg, var(--color-primary), color-mix(in srgb, var(--color-primary) 70%, var(--color-accent)));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.daily-notes-day-label {
	display: inline-block;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

/* Notes List */
.daily-notes-list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

/* Individual Note Card */
.daily-note-card {
	position: relative;
	background: linear-gradient(135deg, var(--color-bg-secondary), color-mix(in srgb, var(--color-accent) 1.5%, var(--color-bg-secondary)));
	border-radius: var(--radius-sm);
	padding: 1rem 1.1rem 2.5rem;
	border-left: 4px solid var(--color-primary);
	transition: transform var(--transition-speed) var(--transition-easing), box-shadow var(--transition-speed) var(--transition-easing), background var(--transition-speed) var(--transition-easing), border-left-color var(--transition-speed) var(--transition-easing);
	cursor: pointer;
	overflow: hidden;
	box-shadow: 0 4px 10px color-mix(in srgb, var(--color-primary) 6%, transparent);
}

.daily-note-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: radial-gradient(600px at var(--mouse-x, 0) var(--mouse-y, 0), color-mix(in srgb, var(--color-primary) 8%, transparent) 0%, transparent 80%);
	pointer-events: none;
	opacity: 0;
	transition: opacity var(--transition-speed);
}

.daily-note-card:hover::before {
	opacity: 1;
}

.daily-note-card:hover {
	background: linear-gradient(135deg, color-mix(in srgb, var(--color-primary) 3%, var(--color-bg-secondary)), color-mix(in srgb, var(--color-accent) 3%, var(--color-bg-secondary)));
	border-left-color: color-mix(in srgb, var(--color-primary) 85%, var(--color-primary-light));
	transform: translateX(4px);
	box-shadow: 0 10px 24px var(--color-shadow);
}

.daily-note-card:focus-within {
	outline: 2px solid color-mix(in srgb, var(--color-primary) 60%, transparent);
	outline-offset: 2px;
}

.daily-note-time {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--color-text-tertiary);
	margin-bottom: 0.75rem;
	font-weight: 600;
}

.daily-note-time i {
	color: var(--color-primary);
}

.daily-note-content {
	margin-bottom: 0.75rem;
}

.daily-note-title {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-text-primary);
	margin: 0 0 0.5rem;
	line-height: 1.3;
}

.daily-note-title a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.daily-note-title a:hover {
	color: var(--color-primary);
}

.daily-note-excerpt {
	font-size: 0.9375rem;
	color: var(--color-text-secondary);
	line-height: 1.5;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.daily-note-link {
	position: absolute;
	bottom: 1rem;
	right: 1rem;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-primary);
	color: white;
	border-radius: 50%;
	text-decoration: none;
	transition: all 0.2s ease;
	opacity: 0;
}

.daily-note-card:hover .daily-note-link {
	opacity: 1;
}

.daily-note-link:hover {
	background: color-mix(in srgb, var(--color-primary) 80%, var(--color-primary-light));
	transform: scale(1.1);
}

/* Navigation Controls */
.daily-notes-nav {
	display: flex;
	justify-content: center;
	gap: 1rem;
	margin-top: 1.5rem;
}

.daily-notes-nav-btn {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--color-primary);
	color: white;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s ease;
	box-shadow: 0 2px 8px rgba(0, 120, 212, 0.3);
}

.daily-notes-nav-btn:hover {
	background: color-mix(in srgb, var(--color-primary) 80%, var(--color-primary-light));
	transform: scale(1.1);
	box-shadow: 0 4px 12px var(--color-shadow-lg);
}

.daily-notes-nav-btn:active {
	transform: scale(0.95);
}

.daily-notes-nav-btn:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.daily-notes-nav-btn:disabled:hover {
	transform: scale(1);
}

/* Empty State */
.daily-notes-empty {
	text-align: center;
	padding: 3rem 1rem;
	color: var(--color-text-secondary);
	font-size: 1.125rem;
}

@media (max-width: 768px) {
	.daily-notes-timeline {
		gap: 1rem;
		padding-bottom: 1.5rem;
	}

	.daily-notes-day {
		min-width: 86vw;
		max-width: 92vw;
	}

	.daily-notes-archive .timeline-cta {
		width: 100%;
	}

	.daily-notes-archive .timeline-controls {
		flex-direction: column;
		align-items: flex-start;
	}
}

@media (prefers-reduced-motion: reduce) {
	.daily-notes-timeline,
	.daily-notes-day,
	.daily-note-card,
	.daily-notes-nav-btn,
	.daily-notes-archive .pill,
	.daily-notes-archive .cta-link {
		transition: none;
	}
}

/* Dark Theme Support */
html.dark-theme .daily-notes-day-header {
	border-bottom-color: var(--fluent-yellow-50);
}

html.dark-theme .daily-notes-day {
	background: var(--fluent-grey-160);
	border-color: var(--fluent-grey-130);
}

html.dark-theme .daily-notes-day:hover {
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.4);
}

html.dark-theme .daily-notes-date {
	color: var(--fluent-grey-20);
}

html.dark-theme .daily-notes-day-label {
	color: var(--fluent-yellow-50);
}

html.dark-theme .daily-note-card {
	background: var(--fluent-grey-170);
	border-left-color: var(--fluent-yellow-50);
}

html.dark-theme .daily-note-card:hover {
	background: var(--fluent-grey-150);
	border-left-color: var(--fluent-yellow-40);
}

html.dark-theme .daily-note-time {
	color: var(--fluent-grey-60);
}

html.dark-theme .daily-note-time i {
	color: var(--fluent-yellow-50);
}

html.dark-theme .daily-note-title {
	color: var(--fluent-grey-20);
}

html.dark-theme .daily-note-title a:hover {
	color: var(--fluent-yellow-50);
}

html.dark-theme .daily-note-excerpt {
	color: var(--fluent-grey-60);
}

html.dark-theme .daily-note-link {
	background: var(--fluent-yellow-50);
	color: var(--fluent-grey-190);
}

html.dark-theme .daily-note-link:hover {
	background: var(--fluent-yellow-40);
	color: var(--fluent-grey-190);
}

html.dark-theme .daily-notes-nav-btn {
	background: var(--fluent-yellow-50);
	box-shadow: 0 2px 8px rgba(255, 185, 0, 0.4);
	color: var(--fluent-grey-190);
}

html.dark-theme .daily-notes-nav-btn:hover {
	background: var(--fluent-yellow-40);
	color: var(--fluent-grey-190);
}

html.dark-theme .daily-notes-timeline::-webkit-scrollbar-track {
	background: var(--fluent-grey-170);
}

html.dark-theme .daily-notes-timeline::-webkit-scrollbar-thumb {
	background: var(--fluent-yellow-50);
}

html.dark-theme .daily-notes-empty {
	color: var(--fluent-grey-60);
}

/* Responsive Design */
@media (max-width: 768px) {
	.daily-notes-day {
		min-width: 280px;
		max-width: 320px;
	}
	
	.daily-notes-date {
		font-size: 1.25rem;
	}
	
	.daily-note-title {
		font-size: 1rem;
	}
	
	.daily-notes-nav-btn {
		width: 40px;
		height: 40px;
	}
}

/* Loading Animation */
@keyframes shimmer {
	0% {
		background-position: -1000px 0;
	}
	100% {
		background-position: 1000px 0;
	}
}

.daily-notes-loading .daily-note-card {
	background: linear-gradient(
		90deg,
		var(--fluent-grey-30) 0%,
		var(--fluent-grey-20) 50%,
		var(--fluent-grey-30) 100%
	);
	background-size: 1000px 100%;
	animation: shimmer 2s infinite;
}
