@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap");/* DurationInput Component Styles */

.duration-input-container {
	position: relative;
	margin-bottom: 1.5rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;
}

/* Label Styles */
.duration-input-label {
	display: block;
	margin-bottom: 0.75rem;
	font-weight: 600;
	font-size: 0.875rem;
	color: #374151;
	line-height: 1.25;
}

.duration-input-label .required-indicator {
	color: #dc2626;
	margin-left: 0.25rem;
}

/* Main Wrapper */
.duration-input-wrapper {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
}

/* Duration Field Container */
.duration-field {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	flex: 1;
}

/* Input Group with Buttons */
.duration-input-group {
	display: flex;
	align-items: center;
	background-color: #ffffff;
	border: 2px solid #d1d5db;
	border-radius: 0.5rem;
	overflow: hidden;
	transition: all 0.2s ease-in-out;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.duration-input-container.focused .duration-input-group {
	border-color: #3b82f6;
	box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.duration-input-container.has-error .duration-input-group {
	border-color: #dc2626;
	background-color: #fef2f2;
}

/* Duration Buttons */
.duration-button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 44px;
	background-color: #f3f4f6;
	border: none;
	color: #374151;
	font-size: 1.25rem;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease-in-out;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.duration-button:hover:not(:disabled) {
	background-color: #e5e7eb;
	color: #1f2937;
}

.duration-button:active:not(:disabled) {
	background-color: #d1d5db;
	transform: scale(0.95);
}

.duration-button:disabled {
	background-color: #f9fafb;
	color: #d1d5db;
	cursor: not-allowed;
}

.duration-button.decrement {
	border-right: 1px solid #e5e7eb;
}

.duration-button.increment {
	border-left: 1px solid #e5e7eb;
}

/* Duration Input */
.duration-input {
	width: 60px;
	height: 44px;
	border: none;
	outline: none;
	text-align: center;
	font-size: 1.125rem;
	font-weight: 600;
	color: #374151;
	background-color: transparent;
	font-family: "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", monospace;
	letter-spacing: 0.025em;
}

.duration-input:focus {
	background-color: #f8fafc;
}

.duration-input:disabled {
	color: #9ca3af;
	cursor: not-allowed;
}

.duration-input::placeholder {
	color: #9ca3af;
	font-weight: 400;
}

/* Remove number input arrows */
.duration-input::-webkit-outer-spin-button,
.duration-input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.duration-input[type="number"] {
	-moz-appearance: textfield;
	appearance: textfield;
}

/* Duration Labels */
.duration-label {
	font-size: 0.75rem;
	font-weight: 500;
	color: #6b7280;
	text-align: center;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Duration Display */
.duration-display {
	margin: 1rem 0;
	padding: 0.75rem 1rem;
	background-color: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 0.5rem;
	text-align: center;
}

.formatted-duration {
	font-size: 1rem;
	font-weight: 600;
	color: #1f2937;
	margin-bottom: 0.25rem;
}

.total-minutes {
	font-size: 0.875rem;
	color: #6b7280;
	font-style: italic;
}

/* Quick Presets */
.duration-presets {
	display: flex;
	gap: 0.5rem;
	justify-content: center;
	margin: 1rem 0;
	flex-wrap: wrap;
}

.preset-button {
	padding: 0.5rem 0.75rem;
	background-color: #ffffff;
	border: 1px solid #d1d5db;
	border-radius: 0.375rem;
	color: #374151;
	font-size: 0.875rem;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.2s ease-in-out;
	min-width: 44px;
}

.preset-button:hover:not(:disabled) {
	background-color: #f3f4f6;
	border-color: #9ca3af;
}

.preset-button:active:not(:disabled) {
	background-color: #e5e7eb;
	transform: scale(0.95);
}

.preset-button:disabled {
	background-color: #f9fafb;
	color: #d1d5db;
	cursor: not-allowed;
}

.preset-button.clear {
	background-color: #fef2f2;
	border-color: #fecaca;
	color: #dc2626;
}

.preset-button.clear:hover:not(:disabled) {
	background-color: #fee2e2;
	border-color: #f87171;
}

/* Error Display */
.duration-input-error {
	margin-top: 0.5rem;
	font-size: 0.875rem;
	color: #dc2626;
	display: flex;
	align-items: center;
	gap: 0.25rem;
}

.duration-input-error::before {
	content: "⚠";
	font-size: 1rem;
}

/* Help Text */
.duration-input-help {
	margin-top: 0.5rem;
	font-size: 0.75rem;
	color: #6b7280;
	text-align: center;
	line-height: 1.4;
}

/* Focus States */
.duration-input-container.focused .duration-input-label {
	color: #3b82f6;
}

.duration-input-container.focused .duration-label {
	color: #3b82f6;
}

/* Responsive Design */
@media (max-width: 640px) {
	.duration-input-wrapper {
		flex-direction: column;
		gap: 1.5rem;
		align-items: center;
	}

	.duration-field {
		width: 100%;
		max-width: 200px;
	}

	.duration-input-group {
		width: 100%;
	}

	.duration-input {
		flex: 1;
		min-width: 0;
	}

	.duration-button {
		width: 50px;
		height: 50px;
		font-size: 1.5rem;
	}

	.duration-presets {
		gap: 0.75rem;
	}

	.preset-button {
		padding: 0.75rem 1rem;
		font-size: 1rem;
		min-width: 60px;
	}
}

/* Touch-friendly adjustments */
@media (hover: none) and (pointer: coarse) {
	.duration-button {
		width: 48px;
		height: 48px;
		font-size: 1.375rem;
	}

	.duration-input {
		height: 48px;
		font-size: 1.25rem;
	}

	.preset-button {
		padding: 0.75rem 1rem;
		min-height: 44px;
	}
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
	.duration-input-group {
		border-width: 3px;
	}

	.duration-button {
		border-width: 2px;
	}

	.preset-button {
		border-width: 2px;
	}
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
	.duration-input-group,
	.duration-button,
	.preset-button {
		transition: none;
	}

	.duration-button:active:not(:disabled),
	.preset-button:active:not(:disabled) {
		transform: none;
	}
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
	.duration-input-label {
		color: #f3f4f6;
	}

	.duration-input-group {
		background-color: #374151;
		border-color: #4b5563;
	}

	.duration-input-container.focused .duration-input-group {
		border-color: #60a5fa;
		box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.1);
	}

	.duration-button {
		background-color: #4b5563;
		color: #f3f4f6;
		border-color: #6b7280;
	}

	.duration-button:hover:not(:disabled) {
		background-color: #6b7280;
		color: #ffffff;
	}

	.duration-button:active:not(:disabled) {
		background-color: #9ca3af;
	}

	.duration-button:disabled {
		background-color: #1f2937;
		color: #6b7280;
	}

	.duration-input {
		color: #f3f4f6;
	}

	.duration-input:focus {
		background-color: #1f2937;
	}

	.duration-input:disabled {
		color: #6b7280;
	}

	.duration-label {
		color: #d1d5db;
	}

	.duration-input-container.focused .duration-label {
		color: #60a5fa;
	}

	.duration-display {
		background-color: #1f2937;
		border-color: #374151;
	}

	.formatted-duration {
		color: #f3f4f6;
	}

	.total-minutes {
		color: #d1d5db;
	}

	.preset-button {
		background-color: #374151;
		border-color: #4b5563;
		color: #f3f4f6;
	}

	.preset-button:hover:not(:disabled) {
		background-color: #4b5563;
		border-color: #6b7280;
	}

	.preset-button:active:not(:disabled) {
		background-color: #6b7280;
	}

	.preset-button.clear {
		background-color: #991b1b;
		border-color: #dc2626;
		color: #fecaca;
	}

	.preset-button.clear:hover:not(:disabled) {
		background-color: #dc2626;
		border-color: #ef4444;
	}

	.duration-input-help {
		color: #d1d5db;
	}
}

/* Print Styles */
@media print {
	.duration-input-container {
		break-inside: avoid;
	}

	.duration-button,
	.preset-button {
		display: none;
	}

	.duration-input-group {
		border: 1px solid #000;
	}

	.duration-input {
		border: 1px solid #000;
	}

	.duration-input-help {
		display: none;
	}
}

/* Animation for value changes */
@keyframes bounce {
	0%,
	20%,
	50%,
	80%,
	100% {
		transform: translateY(0);
	}
	40% {
		transform: translateY(-3px);
	}
	60% {
		transform: translateY(-1px);
	}
}

.duration-button:active:not(:disabled) {
	animation: bounce 0.3s ease-in-out;
}

/* Focus ring for better accessibility */
.duration-input:focus-visible {
	outline: 2px solid #3b82f6;
	outline-offset: 2px;
}

.duration-button:focus-visible,
.preset-button:focus-visible {
	outline: 2px solid #3b82f6;
	outline-offset: 2px;
}
/* TimeInput Component Styles */

.time-input-container {
	position: relative;
	margin-bottom: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;
}

/* Label Styles */
.time-input-label {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 600;
	font-size: 0.875rem;
	color: #374151;
	line-height: 1.25;
}

.time-input-label .required-indicator {
	color: #dc2626;
	margin-left: 0.25rem;
}

/* Input Wrapper */
.time-input-wrapper {
	position: relative;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

/* Base Input Styles */
.time-input {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 2px solid #d1d5db;
	border-radius: 0.5rem;
	font-size: 1rem;
	line-height: 1.5;
	color: #374151;
	background-color: #ffffff;
	transition: all 0.2s ease-in-out;
	box-sizing: border-box;
}

.time-input:focus {
	outline: none;
	border-color: #3b82f6;
	box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.time-input:disabled {
	background-color: #f9fafb;
	color: #9ca3af;
	cursor: not-allowed;
}

.time-input::placeholder {
	color: #9ca3af;
	font-style: italic;
}

/* Custom Time Input (Desktop) */
.custom-time-input {
	font-family: "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", monospace;
	letter-spacing: 0.05em;
	text-align: center;
	max-width: 120px;
}

/* Native Time Input (Mobile) */
.native-time-input {
	max-width: 150px;
}

/* Add Time Button */
.add-time-button {
	padding: 0.75rem;
	border: 2px solid #3b82f6;
	border-radius: 0.5rem;
	background-color: #3b82f6;
	color: white;
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease-in-out;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
}

.add-time-button:hover:not(:disabled) {
	background-color: #2563eb;
	border-color: #2563eb;
	transform: translateY(-1px);
}

.add-time-button:active {
	transform: translateY(0);
}

.add-time-button:disabled {
	background-color: #d1d5db;
	border-color: #d1d5db;
	color: #9ca3af;
	cursor: not-allowed;
	transform: none;
}

.add-icon {
	font-size: 1.25rem;
	line-height: 1;
}

/* Multiple Times Display */
.multiple-times-display {
	margin-top: 0.75rem;
	padding: 1rem;
	background-color: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 0.5rem;
}

.times-label {
	font-size: 0.875rem;
	font-weight: 600;
	color: #475569;
	margin-bottom: 0.5rem;
}

.times-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.time-entry {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 0.75rem;
	background-color: #ffffff;
	border: 1px solid #cbd5e1;
	border-radius: 0.375rem;
	font-family: "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", monospace;
	font-size: 0.875rem;
}

.time-value {
	color: #1e293b;
	font-weight: 600;
	letter-spacing: 0.025em;
}

.remove-time-button {
	background: none;
	border: none;
	color: #ef4444;
	font-size: 1.25rem;
	line-height: 1;
	cursor: pointer;
	padding: 0;
	width: 20px;
	height: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	transition: all 0.2s ease-in-out;
}

.remove-time-button:hover {
	background-color: #fee2e2;
	color: #dc2626;
}

.max-entries-message {
	margin-top: 0.5rem;
	font-size: 0.75rem;
	color: #64748b;
	font-style: italic;
}

/* Error States */
.time-input-container.has-error .time-input {
	border-color: #dc2626;
	background-color: #fef2f2;
}

.time-input-container.has-error .time-input:focus {
	border-color: #dc2626;
	box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1);
}

.time-input-error {
	margin-top: 0.5rem;
	font-size: 0.875rem;
	color: #dc2626;
	display: flex;
	align-items: center;
	gap: 0.25rem;
}

.time-input-error::before {
	content: "⚠";
	font-size: 1rem;
}

/* Help Text */
.time-input-help {
	margin-top: 0.5rem;
	font-size: 0.75rem;
	color: #64748b;
	line-height: 1.4;
}

/* Focus States */
.time-input-container.focused .time-input-label {
	color: #3b82f6;
}

/* Responsive Design */
@media (max-width: 640px) {
	.time-input-wrapper {
		flex-direction: column;
		align-items: stretch;
		gap: 0.75rem;
	}

	.custom-time-input,
	.native-time-input {
		max-width: none;
	}

	.add-time-button {
		align-self: center;
		min-width: 120px;
	}

	.times-list {
		flex-direction: column;
	}

	.time-entry {
		justify-content: space-between;
	}
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
	.time-input {
		border-width: 3px;
	}

	.time-input:focus {
		box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.3);
	}
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
	.time-input,
	.add-time-button,
	.remove-time-button {
		transition: none;
	}

	.add-time-button:hover:not(:disabled) {
		transform: none;
	}
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
	.time-input-label {
		color: #f3f4f6;
	}

	.time-input {
		background-color: #374151;
		border-color: #4b5563;
		color: #f3f4f6;
	}

	.time-input:focus {
		border-color: #60a5fa;
		box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.1);
	}

	.time-input:disabled {
		background-color: #1f2937;
		color: #6b7280;
	}

	.multiple-times-display {
		background-color: #1f2937;
		border-color: #374151;
	}

	.time-entry {
		background-color: #374151;
		border-color: #4b5563;
	}

	.time-value {
		color: #f3f4f6;
	}

	.times-label {
		color: #d1d5db;
	}

	.time-input-help {
		color: #9ca3af;
	}

	.max-entries-message {
		color: #9ca3af;
	}
}

/* Animation for time entry addition */
@keyframes slideIn {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.time-entry {
	animation: slideIn 0.2s ease-out;
}

/* Accessibility improvements */
.time-input:focus-visible {
	outline: 2px solid #3b82f6;
	outline-offset: 2px;
}

/* Print styles */
@media print {
	.time-input-container {
		break-inside: avoid;
	}

	.add-time-button,
	.remove-time-button {
		display: none;
	}

	.time-entry {
		border: 1px solid #000;
	}
}
/* TinnitusScale Component Styles */

.tinnitus-scale-container {
	position: relative;
	margin-bottom: 2rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

/* Label Styles */
.tinnitus-scale-label {
	display: block;
	margin-bottom: 1rem;
	font-weight: 600;
	font-size: 1rem;
	color: #374151;
	line-height: 1.25;
}

.tinnitus-scale-label .required-indicator {
	color: #dc2626;
	margin-left: 0.25rem;
}

/* Main Wrapper */
.tinnitus-scale-wrapper {
	padding: 1.5rem;
	background-color: #ffffff;
	border: 2px solid #e5e7eb;
	border-radius: 1rem;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
}

.tinnitus-scale-container.focused .tinnitus-scale-wrapper {
	border-color: #3b82f6;
	box-shadow:
		0 0 0 3px rgba(59, 130, 246, 0.1),
		0 4px 6px rgba(0, 0, 0, 0.1);
}

.tinnitus-scale-container.has-error .tinnitus-scale-wrapper {
	border-color: #dc2626;
	background-color: #fef2f2;
}

/* Value Display */
.value-display {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	margin-bottom: 2rem;
	padding: 1rem;
	background-color: #f8fafc;
	border-radius: 0.75rem;
	border: 2px solid #e2e8f0;
}

.value-indicator {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 4rem;
	height: 4rem;
	border-radius: 50%;
	color: white;
	font-size: 1.5rem;
	font-weight: 700;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
	transition: all 0.3s ease;
	transform: scale(1);
}

.tinnitus-scale-container.dragging .value-indicator {
	transform: scale(1.1);
	box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
}

.value-description {
	font-size: 1.25rem;
	font-weight: 600;
	color: #1f2937;
	text-align: center;
	min-width: 150px;
}

/* Slider Container */
.slider-container {
	position: relative;
	margin: 2rem 0;
	padding: 1rem 0;
}

/* Custom Slider Track */
.slider-track {
	position: relative;
	width: 100%;
	height: 12px;
	background-color: #e5e7eb;
	border-radius: 6px;
	cursor: pointer;
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
	transition: all 0.2s ease;
}

.slider-track:hover {
	background-color: #d1d5db;
}

/* Progress Fill */
.slider-fill {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	border-radius: 6px;
	transition: all 0.3s ease;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Slider Thumb */
.slider-thumb {
	position: absolute;
	top: 50%;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 3px solid #ffffff;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
	transform: translate(-50%, -50%);
	transition: all 0.2s ease;
	cursor: grab;
	z-index: 10;
}

.slider-thumb:hover,
.tinnitus-scale-container.focused .slider-thumb {
	transform: translate(-50%, -50%) scale(1.2);
	box-shadow: 0 6px 12px rgba(0, 0, 0, 0.4);
}

.tinnitus-scale-container.dragging .slider-thumb {
	cursor: grabbing;
	transform: translate(-50%, -50%) scale(1.3);
	box-shadow: 0 8px 16px rgba(0, 0, 0, 0.5);
}

/* Tick Marks */
.tick-marks {
	position: absolute;
	top: -10px;
	left: 0;
	right: 0;
	height: 32px;
	pointer-events: none;
}

.tick-mark {
	position: absolute;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.25rem;
}

.tick-line {
	width: 2px;
	height: 8px;
	background-color: #9ca3af;
	border-radius: 1px;
	transition: all 0.2s ease;
}

.tick-mark.active .tick-line {
	height: 12px;
	background-color: #374151;
	width: 3px;
}

.tick-label {
	font-size: 0.75rem;
	font-weight: 600;
	color: #6b7280;
	transition: all 0.2s ease;
}

.tick-mark.active .tick-label {
	color: #374151;
	font-size: 0.875rem;
}

/* Hidden Native Slider */
.native-slider {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
	z-index: 20;
}

.native-slider:focus {
	outline: none;
}

/* Scale Labels */
.scale-labels {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 1rem;
	padding: 0 0.5rem;
}

.scale-label-start,
.scale-label-middle,
.scale-label-end {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.25rem;
	text-align: center;
}

.scale-number {
	font-size: 1rem;
	font-weight: 700;
	color: #374151;
	background-color: #f3f4f6;
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid #d1d5db;
}

.scale-text {
	font-size: 0.75rem;
	font-weight: 500;
	color: #6b7280;
	max-width: 80px;
	line-height: 1.2;
}

/* Current Description */
.current-description {
	margin-top: 1.5rem;
	padding: 1rem;
	background-color: #f0f9ff;
	border: 1px solid #bae6fd;
	border-radius: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.5;
	color: #0c4a6e;
}

.current-description strong {
	color: #075985;
}

.description-detail {
	color: #0369a1;
	font-style: italic;
}

/* Error Display */
.tinnitus-scale-error {
	margin-top: 1rem;
	padding: 0.75rem;
	background-color: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 0.5rem;
	color: #dc2626;
	font-size: 0.875rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.tinnitus-scale-error::before {
	content: "⚠";
	font-size: 1rem;
}

/* Instructions */
.scale-instructions {
	margin-top: 1rem;
	font-size: 0.75rem;
	color: #6b7280;
	text-align: center;
	font-style: italic;
	line-height: 1.4;
}

/* Responsive Design */
@media (max-width: 640px) {
	.tinnitus-scale-wrapper {
		padding: 1rem;
	}

	.value-display {
		flex-direction: column;
		gap: 0.75rem;
	}

	.value-indicator {
		width: 3rem;
		height: 3rem;
		font-size: 1.25rem;
	}

	.value-description {
		font-size: 1rem;
		min-width: auto;
	}

	.scale-labels {
		padding: 0;
	}

	.scale-text {
		font-size: 0.625rem;
		max-width: 60px;
	}

	.slider-thumb {
		width: 32px;
		height: 32px;
	}
}

/* Touch-friendly adjustments */
@media (hover: none) and (pointer: coarse) {
	.slider-thumb {
		width: 36px;
		height: 36px;
	}

	.slider-track {
		height: 16px;
		border-radius: 8px;
	}

	.tick-marks {
		top: -12px;
	}
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
	.tinnitus-scale-wrapper {
		border-width: 3px;
	}

	.slider-track {
		border: 2px solid #000;
	}

	.slider-thumb {
		border-width: 4px;
	}

	.tick-line {
		background-color: #000;
	}
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
	.tinnitus-scale-wrapper,
	.slider-fill,
	.slider-thumb,
	.value-indicator,
	.tick-line,
	.tick-label {
		transition: none;
	}

	.tinnitus-scale-container.dragging .value-indicator {
		transform: scale(1);
	}

	.slider-thumb:hover,
	.tinnitus-scale-container.focused .slider-thumb {
		transform: translate(-50%, -50%);
	}
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
	.tinnitus-scale-label {
		color: #f3f4f6;
	}

	.tinnitus-scale-wrapper {
		background-color: #1f2937;
		border-color: #374151;
	}

	.tinnitus-scale-container.focused .tinnitus-scale-wrapper {
		border-color: #60a5fa;
		box-shadow:
			0 0 0 3px rgba(96, 165, 250, 0.1),
			0 4px 6px rgba(0, 0, 0, 0.3);
	}

	.value-display {
		background-color: #374151;
		border-color: #4b5563;
	}

	.value-description {
		color: #f3f4f6;
	}

	.slider-track {
		background-color: #4b5563;
	}

	.slider-track:hover {
		background-color: #6b7280;
	}

	.tick-line {
		background-color: #9ca3af;
	}

	.tick-mark.active .tick-line {
		background-color: #f3f4f6;
	}

	.tick-label {
		color: #d1d5db;
	}

	.tick-mark.active .tick-label {
		color: #f3f4f6;
	}

	.scale-number {
		background-color: #374151;
		border-color: #4b5563;
		color: #f3f4f6;
	}

	.scale-text {
		color: #d1d5db;
	}

	.current-description {
		background-color: #1e3a8a;
		border-color: #3b82f6;
		color: #dbeafe;
	}

	.current-description strong {
		color: #93c5fd;
	}

	.description-detail {
		color: #bfdbfe;
	}

	.scale-instructions {
		color: #d1d5db;
	}
}

/* Print Styles */
@media print {
	.tinnitus-scale-container {
		break-inside: avoid;
		page-break-inside: avoid;
	}

	.tinnitus-scale-wrapper {
		border: 2px solid #000;
		box-shadow: none;
	}

	.slider-track,
	.slider-fill,
	.slider-thumb {
		-webkit-print-color-adjust: exact;
		print-color-adjust: exact;
	}

	.scale-instructions {
		display: none;
	}
}

/* Animation for value changes */
@keyframes pulse {
	0% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.05);
	}
	100% {
		transform: scale(1);
	}
}

.value-indicator.value-changed {
	animation: pulse 0.3s ease-in-out;
}

/* Focus ring for better accessibility */
.native-slider:focus-visible + .slider-track {
	outline: 2px solid #3b82f6;
	outline-offset: 4px;
}
/* Error Boundary Styles */
.error-boundary-container {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 100vh;
	padding: 20px;
	background-color: #f8f9fa;
	font-family:
		-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans",
		"Helvetica Neue", sans-serif;
}

.error-boundary-content {
	max-width: 800px;
	padding: 30px;
	background-color: white;
	border-radius: 8px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	text-align: center;
}

.error-boundary-content h2 {
	color: #e74c3c;
	margin-bottom: 20px;
}

.error-boundary-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
	margin: 25px 0;
}

.error-boundary-button {
	padding: 10px 20px;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	font-weight: 600;
	transition: all 0.2s ease;
}

.error-boundary-button.primary {
	background-color: #3498db;
	color: white;
}

.error-boundary-button.primary:hover {
	background-color: #2980b9;
}

.error-boundary-button.secondary {
	background-color: #95a5a6;
	color: white;
}

.error-boundary-button.secondary:hover {
	background-color: #7f8c8d;
}

.error-boundary-button.info {
	background-color: #f39c12;
	color: white;
}

.error-boundary-button.info:hover {
	background-color: #d35400;
}

.error-boundary-button.danger {
	background-color: #e74c3c;
	color: white;
}

.error-boundary-button.danger:hover {
	background-color: #c0392b;
}

.error-boundary-details {
	text-align: left;
	margin-top: 20px;
	padding: 20px;
	background-color: #f8f9fa;
	border-radius: 4px;
	border-left: 4px solid #e74c3c;
}

.error-message {
	color: #c0392b;
	font-weight: 600;
	margin-bottom: 15px;
	padding: 10px;
	background-color: #fadbd8;
	border-radius: 4px;
}

.error-stack {
	background-color: #2c3e50;
	color: #ecf0f1;
	padding: 15px;
	border-radius: 4px;
	overflow-x: auto;
	font-family: monospace;
	font-size: 14px;
	white-space: pre-wrap;
}

/* API Error Handler Styles */
.api-error-container {
	padding: 20px;
	margin: 20px 0;
	background-color: #fff3f3;
	border-left: 4px solid #e74c3c;
	border-radius: 4px;
}

.api-error-container h3 {
	color: #c0392b;
	margin-top: 0;
}

.error-details {
	margin-top: 15px;
}

.error-details details {
	margin-top: 10px;
}

.error-details summary {
	cursor: pointer;
	color: #3498db;
	font-weight: 600;
}

.error-details pre {
	background-color: #f8f9fa;
	padding: 10px;
	border-radius: 4px;
	overflow-x: auto;
	margin-top: 10px;
	font-family: monospace;
	font-size: 14px;
	white-space: pre-wrap;
}

.retry-button {
	margin-top: 15px;
	padding: 8px 16px;
	background-color: #3498db;
	color: white;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	font-weight: 600;
}

.retry-button:hover {
	background-color: #2980b9;
}


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

html,
body,
#root {
	height: 100%;
	width: 100%;
	font-family: "Plus Jakarta Sans", sans-serif;
	scroll-behavior: smooth;
}

body {
	font-family: "Plus Jakarta Sans", sans-serif;
	/* Match the beautiful dashboard gradient color vibe */
	background:
		radial-gradient(
			1200px 800px at 20% 15%,
			rgba(30, 118, 255, 0.25) 0%,
			rgba(0, 194, 255, 0.18) 35%,
			rgba(15, 21, 53, 0.95) 60%
		),
		#0f1535;
	color: #ffffff;
}

/* Vision UI inspired scrollbar */

::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}

::-webkit-scrollbar-track {
	background: rgba(255, 255, 255, 0.1);
	border-radius: 10px;
}

::-webkit-scrollbar-thumb {
	background: #0075ff;
	border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
	background: #00c2ff;
}

/* PnQ Health brand gradients */

.pnq-gradient-text {
	background: linear-gradient(90deg, #0075ff, #00c2ff);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	text-fill-color: transparent;
}

.pnq-bg-gradient {
	background: linear-gradient(90deg, #0075ff, #00c2ff);
}

.pnq-bg-gradient-purple {
	background: linear-gradient(90deg, #9146b8, #b254e8);
}

/* VisionUI Dashboard-inspired background  */

.blur-bg {
	-webkit-backdrop-filter: blur(120px);
	backdrop-filter: blur(120px);
}

/* Remove focus outline */

*:focus {
	outline: none;
}

a {
	text-decoration: none;
	color: inherit;
}

/* App loading spinner */

.app-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100vh;
	width: 100vw;
	background-color: #0f1535;
}

.spinner {
	width: 40px;
	height: 40px;
	border: 4px solid rgba(0, 117, 255, 0.2);
	border-radius: 50%;
	border-top-color: #0075ff;
	animation: spin 1s ease-in-out infinite;
}

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