
@tailwind base;

/* ================ ENHANCED DARK MODE OVERRIDES ================ */

.dark .bg-white{
    --tw-bg-opacity: 1;
    background-color: rgb(17 24 39 / var(--tw-bg-opacity, 1));
}

.dark .bg-gray-50,
.dark .bg-gray-100{
    --tw-bg-opacity: 1;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}

.dark .text-gray-800{
    --tw-text-opacity: 1;
    color: rgb(229 231 235 / var(--tw-text-opacity, 1));
}

.dark .text-gray-500{
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}

.dark .border-gray-200{
    --tw-border-opacity: 1;
    border-color: rgb(55 65 81 / var(--tw-border-opacity, 1));
}

.dark .shadow-md,
.dark .shadow-sm{
    --tw-shadow: 0 4px 12px -2px rgba(0,0,0,0.3);
    --tw-shadow-colored: 0 4px 12px -2px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.dark .from-purple-600{
    --tw-gradient-from: #581c87 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(88 28 135 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.dark .to-pink-500{
    --tw-gradient-to: #be185d var(--tw-gradient-to-position);
}


  .black-background .dark .glass-morphism svg {
    color: white;
  }


  .black-background .rounded-lg.dark .glass-morphism {
    background-color: rgb(23 23 23);
    border-color: rgb(64 64 64);
  }

.dark .glass-morphism{
    border-width: 1px;
    border-color: rgb(255 255 255 / 0.1);
    background-color: rgb(255 255 255 / 0.05);
    --tw-shadow: 0 4px 12px -2px rgba(0,0,0,0.3);
    --tw-shadow-colored: 0 4px 12px -2px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
    --tw-backdrop-blur: blur(24px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}


.black-background .rounded-lg.dark .glass-morphism {
  background-color: #000000;
  border-color: rgb(64 64 64);
  color: white;
}


.black-background .dark .glass-morphism svg {
  color: white;
}



.themed-background .rounded-lg.dark .glass-morphism.p-4:not(.color-swatch):not([style*="background"]),
.themed-background .rounded-xl.dark .glass-morphism.p-4:not(.color-swatch):not([style*="background"]),
.themed-background .rounded-md.dark .glass-morphism.p-4:not(.color-swatch):not([style*="background"]) {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%));
  color: hsl(var(--theme-card-fg, 0 0% 0%));
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%));
}


:root.themed-background [role="dialog"] .dark .glass-morphism,
:root.themed-background .sheet-content .dark .glass-morphism {
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%));
}

/* ================ ENHANCED BLACK BACKGROUND MODE OVERRIDES ================ */

/* Enhanced Black Background Mode Overrides */

.black-background {
  /* Ensure all text elements use white text and pure black background */
  color: white !important;
  background-color: #000000 !important;
}

/* Main page and container backgrounds */

.black-background .bg-gray-50,
.black-background .bg-gray-100,
.black-background .bg-gray-200,
.black-background .bg-white {
  background-color: #000000 !important;
}

/* Fashion Community Post Text Overrides for Black Background */

.black-background .text-gray-800 {
  color: white !important;
}

.black-background .text-purple-600,
.black-background .text-purple-700 {
  color: white !important;
}

.black-background h1,
.black-background h2,
.black-background h3,
.black-background h4,
.black-background h5,
.black-background h6,
.black-background p,
.black-background span,
.black-background div,
.black-background label {
  color: white !important;
}

/* Button text overrides */

.black-background button {
  color: white !important;
}

.black-background .text-gray-600,
.black-background .text-gray-700,
.black-background .text-gray-800,
.black-background .text-gray-900,
.black-background .text-black {
  color: white !important;
}

/* Muted text should be light gray instead of white */

.black-background .text-muted-foreground {
  color: rgb(163 163 163) !important;
}

/* ================ OUTFIT CARD SPECIFIC FIXES FOR BLACK BACKGROUND ================ */

/* Enhanced Outfit Card Background Overrides */

.black-background .animate-fade-in .bg-white {
  background-color: rgb(17 24 39) !important; /* gray-900 */
  border-color: rgb(55 65 81) !important; /* gray-700 */
}

.black-background .animate-fade-in .bg-blue-100 {
  background-color: rgb(31 41 55) !important; /* gray-800 */
  border-color: rgb(59 130 246) !important; /* blue-500 */
}

/* Outfit card button overlays */

.black-background .bg-white\/80 {
  background-color: rgba(31, 41, 55, 0.9) !important; /* gray-800/90 */
}

.black-background .animate-fade-in button .bg-white\/80 {
  background-color: rgba(31, 41, 55, 0.9) !important;
}

/* Outfit card text colors */

.black-background .animate-fade-in .text-gray-500 {
  color: rgb(209 213 219) !important; /* gray-300 */
}

.black-background .animate-fade-in .text-gray-600 {
  color: rgb(209 213 219) !important; /* gray-300 */
}

/* Badge backgrounds in outfit cards */

.black-background .animate-fade-in .bg-gray-100 {
  background-color: rgb(55 65 81) !important; /* gray-700 */
}

.black-background .animate-fade-in .text-gray-600 {
  color: rgb(209 213 219) !important; /* gray-300 */
}

/* ================ OUTFIT CREATION CARD SPECIFIC FIXES ================ */

/* ULTRA-PRIORITY CARD BACKGROUND FIXES FOR BLACK MODE */

.black-background .bg-white:not(.color-picker-container):not(.color-swatch) {
  background-color: #000000 !important;
  border: 1px solid rgb(64 64 64) !important;
}

.black-background .card,
.black-background [class*="card"],
.black-background .rounded-lg.shadow-sm,
.black-background .rounded-lg.border,
.black-background .bg-white.rounded-lg {
  background-color: #000000 !important;
  border-color: rgb(64 64 64) !important;
  color: white !important;
}

/* Outfit creation tabs specific fixes */

.black-background .space-y-4 .bg-white,
.black-background .space-y-6 .bg-white,
.black-background .min-h-screen .bg-white {
  background-color: #000000 !important;
  border-color: rgb(64 64 64) !important;
}

/* Loading overlay fixes */

.black-background .absolute.inset-0.bg-white\/80 {
  background-color: rgba(0, 0, 0, 0.9) !important;
}

/* Additional comprehensive background overrides */

.black-background .bg-gray-50,
.black-background .bg-gray-100,
.black-background .bg-gray-200,
.black-background .bg-gray-300 {
  background-color: #000000 !important;
}

/* Main and container element overrides for black background */

.black-background main,
.black-background .container {
  background-color: #000000 !important;
}

/* Universal background override for any remaining elements */

.black-background > *,
.black-background main > *,
.black-background .container > * {
  background-color: inherit !important;
}

/* Border adjustments for visibility */

.black-background .border-gray-200,
.black-background .border-gray-300 {
  border-color: rgb(64 64 64) !important;
}

/* Input and form elements */

.black-background input,
.black-background textarea,
.black-background select {
  background-color: rgb(23 23 23) !important;
  color: white !important;
  border-color: rgb(64 64 64) !important;
}

.black-background input::-moz-placeholder, .black-background textarea::-moz-placeholder {
  color: rgb(163 163 163) !important;
}

.black-background input::placeholder,
.black-background textarea::placeholder {
  color: rgb(163 163 163) !important;
}

/* Animation and transition text colors */

.black-background .animate-fade-in,
.black-background .animate-slide-in-right,
.black-background .transition-colors {
  color: white !important;
}

/* Enhanced Badge Color Overrides for Black Background */

.black-background .bg-green-100,
.black-background .bg-yellow-100,
.black-background .bg-blue-100,
.black-background .bg-red-100,
.black-background .bg-orange-100,
.black-background .bg-purple-50,
.black-background .bg-blue-50 {
  background-color: rgb(64 64 64) !important;
}

.black-background .text-green-800,
.black-background .text-yellow-800,
.black-background .text-blue-800,
.black-background .text-red-800,
.black-background .text-orange-800,
.black-background .text-purple-700,
.black-background .text-blue-700 {
  color: white !important;
}

/* Enhanced Orange Badge Fixes for Analytics Underutilized Items */

.black-background .bg-orange-50 {
  background-color: rgb(124 58 0) !important; /* dark orange background */
}

.black-background .text-orange-700 {
  color: rgb(255 237 213) !important; /* light orange text */
}

.black-background .border-orange-300 {
  border-color: rgb(251 146 60) !important; /* orange-400 for visibility */
}

/* Enhanced Blue and Green Badge Fixes for Analytics Styles Tab */

.black-background .bg-blue-50 {
  background-color: rgb(30 58 138) !important; /* dark blue background */
}

.black-background .bg-green-50 {
  background-color: rgb(22 101 52) !important; /* dark green background */
}

/* Badge border fixes for -200 variants */

.black-background .border-purple-200,
.black-background .border-blue-200 {
  border-color: rgb(147 51 234) !important;
}

/* Dark badge variants for black background */

.black-background .dark\:bg-green-900\/20,
.black-background .dark\:bg-yellow-900\/20,
.black-background .dark\:bg-blue-900\/20,
.black-background .dark\:bg-red-900\/20,
.black-background .dark\:bg-orange-900\/20 {
  background-color: rgb(64 64 64) !important;
}

.black-background .dark\:text-green-300,
.black-background .dark\:text-yellow-300,
.black-background .dark\:text-blue-300,
.black-background .dark\:text-red-300,
.black-background .dark\:text-orange-300 {
  color: white !important;
}

/* ================ GRADIENT BACKGROUND OVERRIDES ================ */

/* Override gradient backgrounds in black mode - EXCEPT weather widgets and splash screen */

.black-background .bg-gradient-to-br.from-purple-50.to-pink-50:not(.weather-widget):not([data-splash-screen]),
.black-background .bg-gradient-to-br:not(.weather-widget):not([data-splash-screen]),
.black-background .from-purple-50:not(.weather-widget):not([data-splash-screen]),
.black-background .to-pink-50:not(.weather-widget):not([data-splash-screen]),
.black-background .bg-gradient-to-r.from-blue-50.to-purple-50:not(.weather-widget):not([data-splash-screen]),
.black-background .from-blue-50:not(.weather-widget):not([data-splash-screen]),
.black-background .to-purple-50:not(.weather-widget):not([data-splash-screen]) {
  background: #000000 !important;
}

/* Community sections specific black background overrides */

.black-background .style-communities-section {
  background: #000000 !important;
  border-color: rgb(64 64 64) !important;
}

.black-background .bg-gradient-to-r.from-purple-500.to-pink-500:not(.weather-widget):not([data-splash-screen]) {
  background: linear-gradient(to right, rgb(147 51 234), rgb(219 39 119)) !important;
}

/* Enhanced primary/secondary gradient overrides for black background */

.black-background .bg-gradient-to-r.from-primary\/10.to-secondary\/10,
.black-background .from-primary\/10,
.black-background .to-secondary\/10 {
  background: #000000 !important;
}

.black-background .bg-primary\/10 {
  background-color: #000000 !important;
}

.black-background .border-primary\/20 {
  border-color: rgb(147 51 234) !important;
}

/* Page background overrides - EXCEPT weather widgets and splash screen */

.black-background .min-h-screen.bg-gradient-to-br:not(.weather-widget):not([data-splash-screen]) {
  background: #000000 !important;
}

/* Weather widget specific rules - preserve gradients and text visibility */

.black-background .weather-widget {
  /* Weather widget keeps its dynamic gradients */
  /* Just ensure text readability */
}

.black-background .weather-widget .text-white {
  color: white !important;
}

.black-background .weather-widget svg {
  color: currentColor !important;
}

/* ================ TOAST SPECIFIC FIXES FOR BLACK BACKGROUND ================ */

/* Enhanced Toast overrides for black background mode */

.black-background .sonner-toast,
.black-background [data-sonner-toast],
.black-background .toaster,
.black-background .toaster .toast {
  background-color: rgb(23 23 23) !important;
  color: white !important;
  border-color: rgb(64 64 64) !important;
  border: 1px solid rgb(64 64 64) !important;
}

/* Sonner toast specific styling for black background */

.black-background [data-sonner-toast] {
  background: rgb(23 23 23) !important;
  border: 1px solid rgb(64 64 64) !important;
  color: white !important;
}

.black-background [data-sonner-toast] [data-title] {
  color: white !important;
}

.black-background [data-sonner-toast] [data-description] {
  color: rgb(203 213 225) !important;
}

.black-background [data-sonner-toast] [data-close-button] {
  color: white !important;
  background: rgb(64 64 64) !important;
  border-color: rgb(64 64 64) !important;
}

.black-background [data-sonner-toast] [data-close-button]:hover {
  background: rgb(96 96 96) !important;
}

/* Toast button styling in black background */

.black-background [data-sonner-toast] button {
  color: white !important;
  background: rgb(64 64 64) !important;
  border-color: rgb(64 64 64) !important;
}

.black-background [data-sonner-toast] button:hover {
  background: rgb(96 96 96) !important;
}

/* Radix UI Toast overrides for black background */

.black-background [data-radix-toast-root] {
  background-color: rgb(23 23 23) !important;
  color: white !important;
  border-color: rgb(64 64 64) !important;
}

.black-background [data-radix-toast-title] {
  color: white !important;
}

.black-background [data-radix-toast-description] {
  color: rgb(203 213 225) !important;
}

.black-background [data-radix-toast-close] {
  color: white !important;
}

/* ================ DROPDOWN AND SELECT FIXES ================ */

/* Enhanced dropdown background and z-index fixes */

.black-background [role="menu"],
.black-background [role="listbox"],
.black-background [data-radix-popper-content-wrapper],
.black-background .select-content,
.black-background [data-state="open"][data-side] {
  background-color: rgb(23 23 23) !important;
  border: 1px solid rgb(64 64 64) !important;
  color: white !important;
  z-index: 50 !important;
}

.black-background [data-radix-popper-content-wrapper] > div {
  background-color: rgb(23 23 23) !important;
  border-color: rgb(64 64 64) !important;
}

/* Select trigger and items */

.black-background .select-trigger,
.black-background .bg-white.select-trigger {
  background-color: rgb(23 23 23) !important;
  border-color: rgb(64 64 64) !important;
  color: white !important;
}

.black-background [role="option"],
.black-background .select-item {
  background-color: rgb(23 23 23) !important;
  color: white !important;
}

.black-background [role="option"]:hover,
.black-background .select-item:hover {
  background-color: rgb(64 64 64) !important;
}

/* ================ ULTRA-ENHANCED ICON COLOR FIXES ================ */

/* MAXIMUM PRIORITY PURPLE ICONS FOR LIGHT BACKGROUNDS */

/* Ultra-specific selectors with maximum CSS specificity */

/* Target ALL SVG elements with ultra-high specificity */

body svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
html svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
div svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
span svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
button svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
.card svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
.rounded-lg svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
svg[class*="lucide"]:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
  color: rgb(147 51 234) !important; /* purple-600 for consistent branding */
}

/* WHITE ICONS FOR BLACK BACKGROUND MODE */

.black-background svg:not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
  color: white !important;
}

.black-background .text-gray-500 svg,
.black-background .text-gray-600 svg,
.black-background .text-gray-700 svg,
.black-background .text-gray-500,
.black-background .text-gray-600,
.black-background .text-gray-700 {
  color: white !important;
}

.black-background button svg,
.black-background .card svg,
.black-background .rounded-lg svg,
.black-background .border svg,
.black-background div svg,
.black-background span svg {
  color: white !important;
}

/* PRESERVE SPECIAL CASES IN BLACK BACKGROUND MODE */

/* Preserve red liked hearts in black background mode */

.black-background button svg.fill-red-500,
.black-background svg.fill-red-500 {
  color: rgb(239 68 68) !important; /* keep red for liked hearts */
}

.black-background button .text-red-500 {
  color: rgb(239 68 68) !important; /* keep red for liked counts */
}

.black-background .text-red-500,
.black-background .text-red-600 {
  color: rgb(239 68 68) !important; /* keep red indicators */
}

/* ================ ITEM ACTIONS FIXES ================ */

/* Item Actions background fix for black background mode */

.black-background .item-actions-container {
  background-color: rgba(0, 0, 0, 0.95) !important;
  border-color: rgb(64 64 64) !important;
}

/* ================ COLOR SWATCH FIXES ================ */

/* Color picker container - theme-aware surface */

.color-picker-container {
  background-color: hsl(var(--card)) !important;
  border-color: hsl(var(--border)) !important;
}

.black-background .color-picker-container {
  background-color: hsl(var(--card)) !important;
  border-color: hsl(var(--border)) !important;
}

/* Color swatches - preserve their inline colors */

.color-swatch {
  /* Preserve inline background-color styles */
  border: 2px solid white !important;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2), 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

.black-background .color-swatch {
  /* Preserve inline background-color styles in black mode too */
  border: 2px solid white !important;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2), 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

/* Selected color swatch */

.color-swatch.border-primary {
  border: 3px solid rgb(168 85 247) !important;
  box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}

.black-background .color-swatch.border-primary {
  border: 3px solid rgb(168 85 247) !important;
  box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}

/* Color swatch hover states */

.color-swatch:hover {
  box-shadow: 0 0 0 2px white, 0 0 0 1px rgba(0, 0, 0, 0.3), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  transform: scale(1.05) !important;
}

.black-background .color-swatch:hover {
  box-shadow: 0 0 0 2px white, 0 0 0 1px rgba(0, 0, 0, 0.3), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  transform: scale(1.05) !important;
}

/* Color picker text visibility */

.black-background .color-picker-container .text-sm.text-gray-600 {
  color: rgb(64 64 64) !important;
}

*, ::before, ::after{
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x:  ;
    --tw-pan-y:  ;
    --tw-pinch-zoom:  ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position:  ;
    --tw-gradient-via-position:  ;
    --tw-gradient-to-position:  ;
    --tw-ordinal:  ;
    --tw-slashed-zero:  ;
    --tw-numeric-figure:  ;
    --tw-numeric-spacing:  ;
    --tw-numeric-fraction:  ;
    --tw-ring-inset:  ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / 0.5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur:  ;
    --tw-brightness:  ;
    --tw-contrast:  ;
    --tw-grayscale:  ;
    --tw-hue-rotate:  ;
    --tw-invert:  ;
    --tw-saturate:  ;
    --tw-sepia:  ;
    --tw-drop-shadow:  ;
    --tw-backdrop-blur:  ;
    --tw-backdrop-brightness:  ;
    --tw-backdrop-contrast:  ;
    --tw-backdrop-grayscale:  ;
    --tw-backdrop-hue-rotate:  ;
    --tw-backdrop-invert:  ;
    --tw-backdrop-opacity:  ;
    --tw-backdrop-saturate:  ;
    --tw-backdrop-sepia:  ;
    --tw-contain-size:  ;
    --tw-contain-layout:  ;
    --tw-contain-paint:  ;
    --tw-contain-style:  ;
}

::backdrop{
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x:  ;
    --tw-pan-y:  ;
    --tw-pinch-zoom:  ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position:  ;
    --tw-gradient-via-position:  ;
    --tw-gradient-to-position:  ;
    --tw-ordinal:  ;
    --tw-slashed-zero:  ;
    --tw-numeric-figure:  ;
    --tw-numeric-spacing:  ;
    --tw-numeric-fraction:  ;
    --tw-ring-inset:  ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / 0.5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur:  ;
    --tw-brightness:  ;
    --tw-contrast:  ;
    --tw-grayscale:  ;
    --tw-hue-rotate:  ;
    --tw-invert:  ;
    --tw-saturate:  ;
    --tw-sepia:  ;
    --tw-drop-shadow:  ;
    --tw-backdrop-blur:  ;
    --tw-backdrop-brightness:  ;
    --tw-backdrop-contrast:  ;
    --tw-backdrop-grayscale:  ;
    --tw-backdrop-hue-rotate:  ;
    --tw-backdrop-invert:  ;
    --tw-backdrop-opacity:  ;
    --tw-backdrop-saturate:  ;
    --tw-backdrop-sepia:  ;
    --tw-contain-size:  ;
    --tw-contain-layout:  ;
    --tw-contain-paint:  ;
    --tw-contain-style:  ;
}

/* ! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com */

/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

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

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/

dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/

:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */

[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}

:root {
    --background: 0 0% 100%;
    --foreground: 240 10% 3.9%;
    --card: 0 0% 100%;
    --card-foreground: 240 10% 3.9%;
    --popover: 0 0% 100%;
    --popover-foreground: 240 10% 3.9%;
    --primary: 260 80% 75%;
    --primary-foreground: 0 0% 98%;
    --secondary: 240 4.8% 95.9%;
    --secondary-foreground: 240 5.9% 10%;
    --muted: 240 4.8% 95.9%;
    --muted-foreground: 240 3.8% 46.1%;
    --accent: 240 4.8% 95.9%;
    --accent-foreground: 240 5.9% 10%;
    --destructive: 0 84.2% 60.2%;
    --destructive-foreground: 0 0% 98%;
    --border: 240 5.9% 90%;
    --input: 240 5.9% 90%;
    --ring: 260 80% 75%;
    --radius: 0.75rem;
  }

.dark {
    --background: 240 10% 3.9%;
    --foreground: 0 0% 98%;
    --card: 240 10% 3.9%;
    --card-foreground: 0 0% 98%;
    --popover: 240 10% 3.9%;
    --popover-foreground: 0 0% 98%;
    --primary: 260 80% 75%;
    --primary-foreground: 240 5.9% 10%;
    --secondary: 240 3.7% 15.9%;
    --secondary-foreground: 0 0% 98%;
    --muted: 240 3.7% 15.9%;
    --muted-foreground: 240 5% 64.9%;
    --accent: 240 3.7% 15.9%;
    --accent-foreground: 0 0% 98%;
    --destructive: 0 62.8% 30.6%;
    --destructive-foreground: 0 0% 98%;
    --border: 240 3.7% 15.9%;
    --input: 240 3.7% 15.9%;
    --ring: 260 80% 75%;
  }

:root {
    --background: 0 0% 100%;
    --foreground: 0 0% 0%;

    --card: 0 0% 100%;
    --card-foreground: 0 0% 0%;

    --popover: 0 0% 100%;
    --popover-foreground: 0 0% 0%;

    --primary: 222.2 47.4% 11.2%;
    --primary-foreground: 210 40% 98%;

    --secondary: 210 40% 96.1%;
    --secondary-foreground: 0 0% 0%;

    --muted: 210 40% 96.1%;
    --muted-foreground: 215.4 16.3% 46.9%;

    --accent: 210 40% 96.1%;
    --accent-foreground: 0 0% 0%;

    --destructive: 0 84.2% 60.2%;
    --destructive-foreground: 210 40% 98%;

    /* Always-visible unread badge colors (do not change with themes) */
    --notification-badge-bg: 0 84.2% 60.2%;
    --notification-badge-fg: 0 0% 100%;

    --border: 214.3 31.8% 91.4%;
    --input: 214.3 31.8% 91.4%;
    --ring: 222.2 84% 4.9%;

    --radius: 0.5rem;

    --sidebar-background: 0 0% 98%;

    --sidebar-foreground: 0 0% 0%;

    --sidebar-primary: 240 5.9% 10%;

    --sidebar-primary-foreground: 0 0% 98%;

    --sidebar-accent: 240 4.8% 95.9%;

    --sidebar-accent-foreground: 0 0% 0%;

    --sidebar-border: 220 13% 91%;

    --sidebar-ring: 217.2 91.2% 59.8%;

    /* Marquee */
    --marquee-bg: 269 80% 52%;
    --marquee-fg: 0 0% 100%;
  }

.dark {
    --background: 222.2 84% 4.9%;
    --foreground: 0 0% 100%;

    --card: 222.2 84% 4.9%;
    --card-foreground: 0 0% 100%;

    --popover: 222.2 84% 4.9%;
    --popover-foreground: 0 0% 100%;

    --primary: 210 40% 98%;
    --primary-foreground: 222.2 47.4% 11.2%;

    --secondary: 217.2 32.6% 17.5%;
    --secondary-foreground: 0 0% 100%;

    --muted: 217.2 32.6% 17.5%;
    --muted-foreground: 215 20.2% 65.1%;

    --accent: 217.2 32.6% 17.5%;
    --accent-foreground: 0 0% 100%;

    --destructive: 0 62.8% 30.6%;
    --destructive-foreground: 0 0% 100%;

    --border: 217.2 32.6% 17.5%;
    --input: 217.2 32.6% 17.5%;
    --ring: 212.7 26.8% 83.9%;
    --sidebar-background: 240 5.9% 10%;
    --sidebar-foreground: 0 0% 100%;
    --sidebar-primary: 224.3 76.3% 48%;
    --sidebar-primary-foreground: 0 0% 100%;
    --sidebar-accent: 240 3.7% 15.9%;
    --sidebar-accent-foreground: 0 0% 100%;
    --sidebar-border: 240 3.7% 15.9%;
    --sidebar-ring: 217.2 91.2% 59.8%;

    /* Marquee (keep purple even though --primary becomes light in dark mode) */
    --marquee-bg: 269 80% 52%;
    --marquee-fg: 0 0% 100%;
  }

/* Enhanced Black Background Toggle Override */

.black-background {
    --background: 0 0% 0%;
    --foreground: 0 0% 100%;
    --card: 0 0% 0%;
    --card-foreground: 0 0% 100%;
    --popover: 0 0% 0%;
    --popover-foreground: 0 0% 100%;
    --primary: 0 0% 100%;
    --primary-foreground: 0 0% 0%;
    --secondary: 0 0% 10%;
    --secondary-foreground: 0 0% 100%;
    --muted: 0 0% 10%;
    --muted-foreground: 0 0% 80%;
    --accent: 0 0% 10%;
    --accent-foreground: 0 0% 100%;
    --destructive: 0 84.2% 60.2%;
    --destructive-foreground: 0 0% 100%;
    --border: 0 0% 20%;
    --input: 0 0% 20%;
    --ring: 0 0% 100%;

    /* Marquee */
    --marquee-bg: 269 80% 52%;
    --marquee-fg: 0 0% 100%;
    
    /* Facebook-like shimmer animation */
    --shimmer-from: hsl(var(--muted));
    --shimmer-via: hsl(var(--muted-foreground) / 0.1);
    --shimmer-to: hsl(var(--muted));
  }

/* ================ PREMIUM ANIMATION KEYFRAMES ================ */

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

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

@keyframes slideInFromRight {
    from {
      opacity: 0;
      transform: translateX(20px);
    }
    to {
      opacity: 1;
      transform: translateX(0);
    }
  }

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

@keyframes gentleBounce {
    0%, 100% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(-2px);
    }
  }

.black-background * {
    border-color: rgb(64 64 64);
  }

*{
    border-color: hsl(var(--border));
}

:root.themed-background [role="dialog"] *,
:root.themed-background .sheet-content * {
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%));
}

* {
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -webkit-tap-highlight-color: transparent;
  }

html, body {
    /* Allow native iOS pull-to-refresh in WKWebView */
    overscroll-behavior-x: none;
    /* CRITICAL: Use 'manipulation' to enable panning/zooming while removing 300ms delay */
    /* This is more compatible across Android devices including Samsung */
    touch-action: manipulation;
    -webkit-overflow-scrolling: touch;
    /* CRITICAL: No overflow:hidden - allow document-level scroll for iOS PTR */
    overflow-x: hidden;
    overflow-y: auto;
    height: auto;
    min-height: 100%;
    /* CRITICAL: Prevent Android WebView/TWA from respecting system font scaling */
    /* This stops the "zoomed in" appearance on Android devices */
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }

/* Ensure main content area can always scroll on all Android devices */

main, [role="main"], .scrollable-content {
    touch-action: pan-y pinch-zoom;
    -webkit-overflow-scrolling: touch;
  }

/* Disable native Chrome/Android pull-to-refresh to use custom implementation */

/* CRITICAL: Only apply on Android - iOS WKWebView needs native rubber-banding for custom PTR */

.android-device body {
    overscroll-behavior-y: contain;
  }

/* Hide scrollbars throughout the app */

* {
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none;  /* IE and Edge */
  }

*::-webkit-scrollbar {
    display: none; /* Chrome, Safari, Opera */
  }

.black-background body {
    background-color: black;
  }

body{
    background-color: hsl(var(--background));
    color: hsl(var(--foreground));
}


.themed-background body {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%));
  color: hsl(var(--theme-card-fg, 0 0% 0%));
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%));
}


.themed-background headerbody {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%));
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%));
}


.themed-background buttonbody:not(.color-swatch):not([style*="background"]) {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%));
  color: hsl(var(--theme-text-primary, 0 0% 0%));
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%));
}


.themed-background body.absolute {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%));
}


.themed-background main [class*="z-"]body {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%));
}


:root.themed-background [role="dialog"] body,
:root.themed-background .sheet-content body {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%));
  color: hsl(var(--theme-card-fg, 0 0% 0%));
}

body {
    transition: background-color 0.5s ease, color 0.5s ease;
  }

/* ================ PREMIUM SMOOTH ANIMATIONS ================ */

.animate-fade-in {
    animation: fadeIn 0.3s ease-out;
  }

.animate-scale-in {
    animation: scaleIn 0.2s ease-out;
  }

/* ================ ENHANCED INTERACTIVE ELEMENTS ================ */

/* Smooth button hover effects */

button {
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  }

button:hover {
    transform: translateY(-1px);
  }

button:active {
    transform: translateY(0);
  }

/* Card hover effects */

.card, [class*="card"] {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }

.card:hover, [class*="card"]:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
  }

/* Input focus effects */

input, textarea, select {
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  }

input:focus, textarea:focus, select:focus {
    transform: translateY(-1px);
  }

/* Link hover effects */

a {
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  }

/* Navigation item animations */

/* Modal and dialog entrance animations */

[role="dialog"], .modal {
    animation: scaleIn 0.2s ease-out;
  }

/* Dropdown menu animations */

[role="menu"], [role="listbox"] {
    animation: fadeIn 0.15s ease-out;
  }

/* Toast animations */

/* Loading spinner smooth rotation */

.animate-spin {
    animation: spin 1s linear infinite;
  }

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

/* Shake animation for editable quick actions */

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    10%, 30%, 50%, 70%, 90% { transform: translateX(-2px); }
    20%, 40%, 60%, 80% { transform: translateX(2px); }
  }

.animate-shake {
    animation: shake 0.5s ease-in-out infinite;
  }

/* Stagger animation delays for lists */

/* ================ BLACK BACKGROUND MODE (TOKEN-BASED) ================ */

/* Make black-background act like a proper theme scope (no blanket overrides). */

.black-background {
    background-color: hsl(var(--background));
    color: hsl(var(--foreground));
  }

/* Fix legacy hardcoded text colors that become unreadable on dark surfaces */

.black-background .text-gray-600,
  .black-background .text-gray-700,
  .black-background .text-gray-800,
  .black-background .text-gray-900,
  .black-background .text-black {
    color: hsl(var(--foreground)) !important;
  }

/* Fix legacy hardcoded light backgrounds */

.black-background .bg-white:not(.color-picker-container):not(.color-swatch) {
    background-color: hsl(var(--background)) !important;
  }

.black-background .bg-gray-50,
  .black-background .bg-gray-100 {
    background-color: hsl(var(--muted)) !important;
  }

/* Border adjustments for visibility */

.black-background .border-gray-200,
  .black-background .border-gray-300 {
    border-color: hsl(var(--border)) !important;
  }

/* Input and form elements */

.black-background input,
  .black-background textarea,
  .black-background select {
    background-color: hsl(var(--background)) !important;
    color: hsl(var(--foreground)) !important;
    border-color: hsl(var(--border)) !important;
  }

.black-background input::-moz-placeholder, .black-background textarea::-moz-placeholder {
    color: hsl(var(--muted-foreground)) !important;
  }

.black-background input::placeholder,
  .black-background textarea::placeholder {
    color: hsl(var(--muted-foreground)) !important;
  }

/* ================ GRADIENT BACKGROUND OVERRIDES ================ */

/* Override gradient backgrounds in black mode - EXCEPT weather widgets */

.black-background .bg-gradient-to-br.from-purple-50.to-pink-50:not(.weather-widget),
  .black-background .bg-gradient-to-br:not(.weather-widget),
  .black-background .from-purple-50:not(.weather-widget),
  .black-background .to-pink-50:not(.weather-widget) {
    background: rgb(23 23 23) !important;
  }

.black-background .bg-gradient-to-r.from-purple-500.to-pink-500:not(.weather-widget) {
    background: linear-gradient(to right, rgb(147 51 234), rgb(219 39 119)) !important;
  }

/* Page background overrides - EXCEPT weather widgets */

.black-background .min-h-screen.bg-gradient-to-br:not(.weather-widget) {
    background: rgb(23 23 23) !important;
  }

/* Weather widget specific rules - preserve gradients and text visibility */

.black-background .weather-widget {
    /* Weather widget keeps its dynamic gradients */
    /* Just ensure text readability */
  }

.black-background .weather-widget .text-white {
    color: white !important;
  }

.black-background .weather-widget svg {
    color: currentColor !important;
  }

/* Magazine Cover Override - Always keep gradient purple even in black background mode */

.magazine-cover,
  .black-background .magazine-cover {
    background: linear-gradient(135deg, rgb(147, 51, 234), rgb(126, 34, 206), rgb(236, 72, 153)) !important;
    color: white !important;
  }

.magazine-cover *,
  .black-background .magazine-cover * {
    color: white !important;
  }

/* Ensure magazine layout preview is always visible */

#magazine-layout,
  .black-background #magazine-layout,
  #outfit-layout-preview,
  .black-background #outfit-layout-preview {
    background: linear-gradient(135deg, rgb(147, 51, 234), rgb(126, 34, 206), rgb(236, 72, 153)) !important;
    color: white !important;
  }

#magazine-layout *,
  .black-background #magazine-layout *,
  #outfit-layout-preview *,
  .black-background #outfit-layout-preview * {
    color: white !important;
  }

/* ================ ULTRA-ENHANCED ICON COLOR FIXES ================ */

/* MAXIMUM PRIORITY PURPLE ICONS FOR LIGHT BACKGROUNDS */

/* Ultra-specific selectors with maximum CSS specificity */

/* Target ALL SVG elements with ultra-high specificity */

body svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  html svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  div svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  span svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  button svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  .card svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  .rounded-lg svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  svg[class*="lucide"]:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 for consistent branding */
  }

/* Override ALL hardcoded color classes with ultra-high specificity */

body .text-indigo-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-indigo-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-blue-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-blue-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-orange-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-orange-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-green-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-green-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-yellow-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-yellow-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-teal-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-teal-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-cyan-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-cyan-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-violet-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-violet-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-pink-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-pink-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-purple-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-purple-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-gray-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-gray-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .text-gray-700:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }

/* Target icons within specific layout contexts with ultra-high specificity */

body [class*="grid"] svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body [class*="flex"] svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body [class*="space-"] svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .p-3 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .p-4 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .p-6 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .pt-6 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .pb-3 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .px-4 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .py-2 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }

/* Target lucide icons specifically with ultra-high specificity */

body [class*="lucide"]:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),

/* ================ MOBILE VIEWPORT FIXES ================ */

/* Mobile optimizations */
.mobile-scroll-container {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

/* Mobile viewport fixes */

.mobile-header-fixed {
  position: fixed;
  top: 0;
  top: env(safe-area-inset-top, 0px);
  left: 0;
  right: 0;
  z-index: 50;
  backface-visibility: hidden;
  isolation: isolate;
  pointer-events: auto;
}

/* ================= ANDROID SCROLL ROOT (WebView/TWA) =================
   Some Android WebViews fail to initiate document scrolling from non-fixed areas
   when there are global touch handlers + fixed headers/footers.
   This makes the content area a dedicated scroll container.
*/

.android-scroll-root {
  /* Lock the page and delegate vertical scrolling to the main container */
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  overflow: hidden;
}

.android-scroll-main {
  position: fixed;
  left: 0;
  right: 0;
  /* Header is fixed at 64px below safe-area inset */
  top: var(--android-scroll-top, calc(env(safe-area-inset-top, 0px) + 64px));
  /* Extend to bottom - use padding for nav space instead of bottom offset */
  bottom: 0;
  overflow-y: scroll;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  /* Force compositing: improves scroll gesture initiation in some Android WebViews/TWAs */
  transform: translateZ(0);
  will-change: transform, scroll-position;
  overscroll-behavior-y: auto;
  /* CRITICAL: Ensure touch events reach this element and enable vertical panning */
  touch-action: pan-y pinch-zoom;
  pointer-events: auto;
  /* Sit above any accidental overlays; header/nav are z-50 */
  z-index: 30;
  /* Padding for bottom nav - this scrolls with content, no gap when nav hides */
  padding-bottom: var(--android-scroll-bottom, calc(5rem + env(safe-area-inset-bottom, 8px)));
  transition: top 300ms ease, padding-bottom 300ms ease;
}

/* Ensure all children inside the Android scroll container allow touch passthrough */

.android-scroll-main > * {
  pointer-events: auto;
  touch-action: pan-y pinch-zoom;
}

/* Standalone Android scroll fix - for fullscreen pages without header/nav (e.g., policy, onboarding) */

.android-standalone-scroll {
  position: fixed;
  inset: 0;
  overflow-y: scroll;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  /* Force compositing for reliable scroll gesture initiation */
  transform: translateZ(0);
  will-change: transform, scroll-position;
  overscroll-behavior-y: auto;
  /* CRITICAL: Ensure touch events reach this element and enable vertical panning */
  touch-action: pan-y pinch-zoom;
  pointer-events: auto;
}

/*
 * Android scroll panel (NON-fixed):
 * Use inside a fullscreen fixed flex layout so fixed footers/header are NOT inside
 * a transformed scroll container (which breaks position: fixed).
 */

.android-scroll-panel {
  height: 100%;
  overflow-y: scroll;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  /* Force compositing for reliable scroll gesture initiation */
  transform: translateZ(0);
  will-change: transform, scroll-position;
  /* Prevent scroll chaining to parent containers (fixes "keep scrolling" moving fixed footers) */
  overscroll-behavior-y: contain;
  touch-action: pan-y pinch-zoom;
  pointer-events: auto;
}

.mobile-bottom-nav-fixed {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 50;
  backface-visibility: hidden;
  isolation: isolate;
  pointer-events: auto;
  /* Enhanced safe area padding for Samsung and other Android devices */
  padding-bottom: max(env(safe-area-inset-bottom, 0px), 8px);
}

/* Samsung-specific fix - ensure nav bar doesn't overlap scrollable content */

@supports (padding-bottom: constant(safe-area-inset-bottom)) {
  .mobile-bottom-nav-fixed {
    padding-bottom: max(constant(safe-area-inset-bottom), 8px);
  }
}

.mobile-safe-top {
  padding-top: env(safe-area-inset-top, 0px);
}

.mobile-safe-bottom {
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

/* Mobile viewport height fix - allow natural page scroll for iOS PTR */

.mobile-vh-fix {
    min-height: 100vh;
    min-height: 100dvh;
    overflow-x: hidden; /* Prevent horizontal bounce */
    /* CRITICAL: No fixed height or overflow-y:hidden - let page scroll naturally */
  }

/* Hide scrollbars */

.scrollbar-hide {
    -ms-overflow-style: none;
    scrollbar-width: none;
  }

.scrollbar-hide::-webkit-scrollbar {
    display: none;
  }

/* Prevent mobile viewport jumps */

@supports (-webkit-touch-callout: none) {
  .mobile-header-fixed {
    position: fixed;
    top: env(safe-area-inset-top, 0px);
  }
  
  .mobile-bottom-nav-fixed {
    position: fixed;
    bottom: 0;
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }
}

body .lucide:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body svg[data-lucide]:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }

/* Target specific page sections with ultra-high specificity */

body .min-h-screen svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .container svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body main svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .space-y-6 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *),
  body .space-y-4 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .\!container svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }

/* SPECIAL CASES - PRESERVE MEANINGFUL COLORS */

/* Preserve red colors for likes and important indicators */

button svg.fill-red-500,
  .text-red-500,
  .text-red-600,
  svg.fill-red-500 {
    color: rgb(239 68 68) !important; /* keep red-500 for likes */
  }

button .text-red-500 {
    color: rgb(239 68 68) !important; /* keep red for liked counts */
  }

/* Preserve destructive/error colors */

.text-destructive,
  .text-red-700,
  .text-red-800 {
    color: rgb(220 38 38) !important; /* keep red for errors */
  }

/* Preserve success colors where meaningful */

.text-green-700,
  .text-green-800,
  .text-emerald-600 {
    color: rgb(34 197 94) !important; /* keep green for success states */
  }

/* WHITE ICONS FOR BLACK BACKGROUND MODE */

.black-background svg:not(.fill-red-500):not([class*="text-red"]) {
    color: white !important;
  }

.black-background .text-gray-500 svg,
  .black-background .text-gray-600 svg,
  .black-background .text-gray-700 svg,
  .black-background .text-gray-500,
  .black-background .text-gray-600,
  .black-background .text-gray-700 {
    color: white !important;
  }

.black-background button svg,
  .black-background .card svg,
  .black-background .rounded-lg svg,
  .black-background .border svg,
  .black-background div svg,
  .black-background span svg {
    color: white !important;
  }

/* Override all color classes in black background mode */

.black-background .text-indigo-500,
  .black-background .text-indigo-600,
  .black-background .text-blue-500,
  .black-background .text-blue-600,
  .black-background .text-orange-500,
  .black-background .text-orange-600,
  .black-background .text-green-500,
  .black-background .text-green-600,
  .black-background .text-yellow-500,
  .black-background .text-yellow-600,
  .black-background .text-teal-500,
  .black-background .text-teal-600,
  .black-background .text-cyan-500,
  .black-background .text-cyan-600,
  .black-background .text-violet-500,
  .black-background .text-violet-600,
  .black-background .text-pink-500,
  .black-background .text-pink-600,
  .black-background .text-purple-500,
  .black-background .text-purple-600 {
    color: white !important;
  }

.black-background [class*="grid"] svg,
  .black-background [class*="flex"] svg,
  .black-background [class*="space-"] svg,
  .black-background .p-3 svg,
  .black-background .p-4 svg,
  .black-background .p-6 svg,
  .black-background .pt-6 svg {
    color: white !important;
  }

.black-background [class*="lucide"],
  .black-background .lucide {
    color: white !important;
  }

/* PRESERVE SPECIAL CASES IN BLACK BACKGROUND MODE */

/* Preserve red liked hearts in black background mode */

.black-background button svg.fill-red-500,
  .black-background svg.fill-red-500 {
    color: rgb(239 68 68) !important; /* keep red for liked hearts */
  }

.black-background button .text-red-500 {
    color: rgb(239 68 68) !important; /* keep red for liked counts */
  }

.black-background .text-red-500,
  .black-background .text-red-600 {
    color: rgb(239 68 68) !important; /* keep red indicators */
  }

/* ================ EXISTING OVERRIDES ================ */

/* Header specific overrides */

.black-background header {
    background-color: hsl(var(--background)) !important;
    border-color: hsl(var(--border)) !important;
  }

/* Sheet, popover, and dialog surfaces (including Radix Portals) */

.black-background [data-radix-popper-content-wrapper],
  .black-background .sheet-content,
  .black-background [role="dialog"] {
    background-color: hsl(var(--background)) !important;
    color: hsl(var(--foreground)) !important;
    border-color: hsl(var(--border)) !important;
  }

/* Fallback for browsers where the portal isn't inside the themed container */

body:has(.black-background) [role="dialog"],
  body:has(.black-background) .sheet-content,
  body:has(.black-background) [data-radix-popper-content-wrapper] > div {
    background-color: hsl(var(--background)) !important;
    color: hsl(var(--foreground)) !important;
    border-color: hsl(var(--border)) !important;
  }

/* Avatar fallback text */

.black-background .avatar-fallback {
    background-color: rgb(64 64 64) !important;
    color: white !important;
  }

/* Badge overrides */

.black-background .badge {
    background-color: rgb(64 64 64) !important;
    color: white !important;
  }

/* Ring/focus ring overrides */

.black-background .ring-purple-500,
  .black-background .ring-2 {
    ring-color: rgb(168 85 247) !important;
  }

/* Gradient overrides */

.black-background .from-purple-600 {
    --tw-gradient-from: rgb(147 51 234) !important;
  }

.black-background .to-pink-600 {
    --tw-gradient-to: rgb(219 39 119) !important;
  }

/* Shadow adjustments for dark backgrounds */

.black-background .shadow-lg,
  .black-background .shadow-md {
    box-shadow: 0 10px 15px -3px rgba(255, 255, 255, 0.1), 0 4px 6px -2px rgba(255, 255, 255, 0.05) !important;
  }

/* Skeleton overrides */

.black-background .skeleton {
    background-color: rgb(64 64 64) !important;
  }

/* Toast overrides */

.black-background .sonner-toast {
    background-color: rgb(23 23 23) !important;
    color: white !important;
    border-color: rgb(64 64 64) !important;
  }

/* ================ ENHANCED VISIBILITY FIXES ================ */

/* Bottom Navigation fixes */

.black-background .fixed.bottom-0,
  .black-background .fixed.bottom-0.bg-white {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }

/* Navigation link text colors */

.black-background .text-gray-500,
  .black-background .text-primary {
    color: white !important;
  }

/* Active navigation indicator */

.black-background .bg-primary {
    background-color: rgb(168 85 247) !important;
  }

/* Card components comprehensive overrides */

.black-background [class*="card"],
  .black-background .rounded-lg.border,
  .black-background .shadow-sm {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }

/* Button variants in black background */

.black-background .bg-purple-100 {
    background-color: rgb(64 64 64) !important;
  }

.black-background .text-purple-600,
  .black-background .text-purple-700 {
    color: rgb(196 181 253) !important;
  }

/* Progress components */

.black-background .bg-secondary {
    background-color: rgb(64 64 64) !important;
  }

/* List and menu items */

.black-background .bg-muted {
    background-color: rgb(64 64 64) !important;
  }

/* Focus and ring states */

.black-background .focus\:ring-2:focus {
    ring-color: rgb(168 85 247) !important;
  }

/* Dropdown and popover backgrounds */

.black-background [role="menu"],
  .black-background [role="listbox"],
  .black-background [data-radix-popper-content-wrapper] > div {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }

/* Radix UI components specific fixes */

.black-background [data-state="open"][data-side] {
    background-color: rgb(23 23 23) !important;
  }

/* Search and input components */

.black-background .bg-background {
    background-color: black !important;
  }

/* Status badges and indicators */

.black-background .bg-green-100,
  .black-background .bg-blue-100,
  .black-background .bg-yellow-100,
  .black-background .bg-red-100 {
    background-color: rgb(64 64 64) !important;
  }

.black-background .text-green-600,
  .black-background .text-blue-600,
  .black-background .text-yellow-600,
  .black-background .text-red-600 {
    color: white !important;
  }

/* Scrollbar styling for dark mode */

.black-background ::-webkit-scrollbar {
    background-color: rgb(23 23 23);
  }

.black-background ::-webkit-scrollbar-thumb {
    background-color: rgb(64 64 64);
  }

.black-background ::-webkit-scrollbar-thumb:hover {
    background-color: rgb(128 128 128);
  }

/* Loading states and animations */

.black-background .animate-pulse {
    background-color: rgb(64 64 64) !important;
  }

/* Table and grid components */

.black-background table,
  .black-background thead,
  .black-background tbody,
  .black-background tr,
  .black-background td,
  .black-background th {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
    color: white !important;
  }

/* Image placeholder and error states */

.black-background .bg-gray-200,
  .black-background .bg-gray-300 {
    background-color: rgb(64 64 64) !important;
  }

/* Utility classes for consistent theming */

.black-background .divide-gray-200 > * + * {
    border-color: rgb(64 64 64) !important;
  }

/* Override any remaining dark text */

.black-background .text-black {
    color: white !important;
  }

/* Comprehensive hover state fixes */

.black-background .hover\:bg-gray-100:hover,
  .black-background .hover\:bg-muted\/50:hover {
    background-color: rgb(64 64 64) !important;
  }

.black-background .hover\:text-gray-700:hover,
  .black-background .hover\:text-gray-800:hover {
    color: white !important;
  }

/* New comprehensive fixes for visibility issues */

.black-background .text-slate-600,
  .black-background .text-slate-700,
  .black-background .text-slate-800,
  .black-background .text-slate-900 {
    color: white !important;
  }

.black-background .bg-slate-50,
  .black-background .bg-slate-100,
  .black-background .bg-slate-200 {
    background-color: rgb(23 23 23) !important;
  }

/* Enhanced card and container fixes */

.black-background .bg-card {
    background-color: rgb(23 23 23) !important;
  }

.black-background .text-card-foreground {
    color: white !important;
  }

/* Enhanced button and interactive element fixes */

.black-background .bg-destructive {
    background-color: rgb(239 68 68) !important;
  }

.black-background .text-destructive {
    color: rgb(239 68 68) !important;
  }

.black-background .bg-accent {
    background-color: rgb(64 64 64) !important;
  }

.black-background .text-accent-foreground {
    color: white !important;
  }

/* Enhanced modal and dialog fixes */

.black-background .bg-popover {
    background-color: rgb(23 23 23) !important;
  }

.black-background .text-popover-foreground {
    color: white !important;
  }

/* Enhanced form and input fixes */

.black-background .bg-input {
    background-color: rgb(23 23 23) !important;
  }

.black-background .border-input {
    border-color: rgb(64 64 64) !important;
  }

/* Enhanced separator and border fixes */

.black-background .border-border {
    border-color: rgb(64 64 64) !important;
  }

.black-background .bg-border {
    background-color: rgb(64 64 64) !important;
  }

/* ================ COLOR SWATCH FIXES ================ */

/* Color picker container - theme-aware surface */

.color-picker-container {
    background-color: hsl(var(--card)) !important;
    border-color: hsl(var(--border)) !important;
  }

.black-background .color-picker-container {
    background-color: hsl(var(--card)) !important;
    border-color: hsl(var(--border)) !important;
  }

/* Color swatches - preserve their inline colors */

.color-swatch {
    /* Preserve inline background-color styles */
    border: 2px solid white !important;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2), 0 2px 4px rgba(0, 0, 0, 0.1) !important;
  }

.black-background .color-swatch {
    /* Preserve inline background-color styles in black mode too */
    border: 2px solid white !important;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2), 0 2px 4px rgba(0, 0, 0, 0.1) !important;
  }

/* Selected color swatch */

.color-swatch.border-primary {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.black-background .color-swatch.border-primary {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

/* Color swatch hover states */

.color-swatch:hover {
    box-shadow: 0 0 0 2px white, 0 0 0 1px rgba(0, 0, 0, 0.3), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
    transform: scale(1.05) !important;
  }

.black-background .color-swatch:hover {
    box-shadow: 0 0 0 2px white, 0 0 0 1px rgba(0, 0, 0, 0.3), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
    transform: scale(1.05) !important;
  }

/* Color picker text visibility */

.black-background .color-picker-container .text-sm.text-gray-600 {
    color: rgb(64 64 64) !important;
  }

/* ================ LAYOUT STABILITY & CONTAINMENT ================ */

/* CSS Containment for performance and layout stability */

.contain-layout {
    contain: layout style;
    will-change: auto;
    transform: translateZ(0); /* Force GPU layer for stability */
  }

/* Prevent image shifting in virtual grids */

/* Marquee animation */

@keyframes marquee {
    0% { transform: translateX(100%); }
    100% { transform: translateX(-100%); }
  }

.animate-marquee {
    animation: marquee 20s linear infinite;
  }

/* Simplified marquee positioning - no horizontal overflow */

.marquee-full-width {
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
    max-width: 100vw;

    /* Force a solid purple marquee bar (no gradient) across all themes */
    background-image: none !important;
    background-color: hsl(var(--marquee-bg)) !important;
  }

/* Marquee: solid purple handled by .marquee-full-width rules above */

/* Prevent horizontal scrolling on mobile */

/* PWA-specific adjustments */

@media (display-mode: standalone) {
    .marquee-full-width {
      margin-left: calc(-50vw + env(safe-area-inset-left, 0px));
      margin-right: calc(-50vw + env(safe-area-inset-right, 0px));
    }
  }

/* iOS Safari specific fixes */

@supports (-webkit-touch-callout: none) {
    .marquee-full-width {
      margin-left: calc(-50vw + env(safe-area-inset-left, 0px));
      margin-right: calc(-50vw + env(safe-area-inset-right, 0px));
    }
  }

/* Prevent layout shifts during loading */

/* Prevent bouncing and shifting */

/* ================ MOBILE LAYOUT IMPROVEMENTS ================ */

/* Mobile layout improvements */

@media (max-width: 640px) {
    .mobile-spacing {
      padding: 0.5rem;
    }
    
    .mobile-grid-gap {
      gap: 0.5rem;
    }
    
    .mobile-header-space {
      margin-top: 1rem;
    }
    
    /* Mobile viewport height fix - DO NOT lock height (prevents scrolling) */
    .mobile-vh-fix {
      min-height: 100vh;
      min-height: 100dvh;
      overflow-x: hidden;
    }

    /* Mobile safe area adjustments */
    .mobile-safe-top {
      padding-top: env(safe-area-inset-top);
    }

    .mobile-safe-bottom {
      padding-bottom: env(safe-area-inset-bottom);
    }
    
    /* Mobile-specific containment */
    .contain-layout {
      contain: layout;
      transform: translateZ(0);
    }
  }

.\!container{
    width: 100% !important;
    margin-right: auto !important;
    margin-left: auto !important;
    padding-right: 2rem !important;
    padding-left: 2rem !important;
}

.container{
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 2rem;
    padding-left: 2rem;
}

@media (min-width: 1400px){

    .\!container{
        max-width: 1400px !important;
    }

    .container{
        max-width: 1400px;
    }
}

.sr-only{
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

.pointer-events-none{
    pointer-events: none;
}

.pointer-events-auto{
    pointer-events: auto;
}

.visible{
    visibility: visible;
}

.invisible{
    visibility: hidden;
}

.collapse{
    visibility: collapse;
}

.static{
    position: static;
}

.fixed{
    position: fixed;
}

.absolute{
    position: absolute;
}

.relative{
    position: relative;
}

.sticky{
    position: sticky;
}

.inset-0{
    inset: 0px;
}

.inset-2{
    inset: 0.5rem;
}

.inset-3{
    inset: 0.75rem;
}

.inset-x-0{
    left: 0px;
    right: 0px;
}

.inset-x-4{
    left: 1rem;
    right: 1rem;
}

.inset-y-0{
    top: 0px;
    bottom: 0px;
}

.-bottom-0\.5{
    bottom: -0.125rem;
}

.-bottom-1{
    bottom: -0.25rem;
}

.-bottom-12{
    bottom: -3rem;
}

.-bottom-2{
    bottom: -0.5rem;
}

.-bottom-6{
    bottom: -1.5rem;
}

.-left-1{
    left: -0.25rem;
}

.-left-12{
    left: -3rem;
}

.-left-2{
    left: -0.5rem;
}

.-left-3{
    left: -0.75rem;
}

.-left-8{
    left: -2rem;
}

.-right-0\.5{
    right: -0.125rem;
}

.-right-1{
    right: -0.25rem;
}

.-right-1\.5{
    right: -0.375rem;
}

.-right-12{
    right: -3rem;
}

.-right-2{
    right: -0.5rem;
}

.-right-3{
    right: -0.75rem;
}

.-right-6{
    right: -1.5rem;
}

.-top-1{
    top: -0.25rem;
}

.-top-1\.5{
    top: -0.375rem;
}

.-top-12{
    top: -3rem;
}

.-top-14{
    top: -3.5rem;
}

.-top-2{
    top: -0.5rem;
}

.-top-3{
    top: -0.75rem;
}

.-top-4{
    top: -1rem;
}

.-top-6{
    top: -1.5rem;
}

.bottom-0{
    bottom: 0px;
}

.bottom-1{
    bottom: 0.25rem;
}

.bottom-1\/3{
    bottom: 33.333333%;
}

.bottom-2{
    bottom: 0.5rem;
}

.bottom-20{
    bottom: 5rem;
}

.bottom-24{
    bottom: 6rem;
}

.bottom-4{
    bottom: 1rem;
}

.bottom-6{
    bottom: 1.5rem;
}

.bottom-8{
    bottom: 2rem;
}

.left-0{
    left: 0px;
}

.left-1{
    left: 0.25rem;
}

.left-1\/2{
    left: 50%;
}

.left-2{
    left: 0.5rem;
}

.left-3{
    left: 0.75rem;
}

.left-4{
    left: 1rem;
}

.left-\[50\%\]{
    left: 50%;
}

.right-0{
    right: 0px;
}

.right-1{
    right: 0.25rem;
}

.right-1\.5{
    right: 0.375rem;
}

.right-2{
    right: 0.5rem;
}

.right-3{
    right: 0.75rem;
}

.right-4{
    right: 1rem;
}

.right-6{
    right: 1.5rem;
}

.right-8{
    right: 2rem;
}

.right-\[-25px\]{
    right: -25px;
}

.top-0{
    top: 0px;
}

.top-1{
    top: 0.25rem;
}

.top-1\.5{
    top: 0.375rem;
}

.top-1\/2{
    top: 50%;
}

.top-1\/3{
    top: 33.333333%;
}

.top-10{
    top: 2.5rem;
}

.top-14{
    top: 3.5rem;
}

.top-16{
    top: 4rem;
}

.top-2{
    top: 0.5rem;
}

.top-20{
    top: 5rem;
}

.top-3{
    top: 0.75rem;
}

.top-3\.5{
    top: 0.875rem;
}

.top-32{
    top: 8rem;
}

.top-4{
    top: 1rem;
}

.top-6{
    top: 1.5rem;
}

.top-8{
    top: 2rem;
}

.top-\[10px\]{
    top: 10px;
}

.top-\[1px\]{
    top: 1px;
}

.top-\[50\%\]{
    top: 50%;
}

.top-\[60\%\]{
    top: 60%;
}

.top-full{
    top: 100%;
}

.z-0{
    z-index: 0;
}

.z-10{
    z-index: 10;
}

.z-20{
    z-index: 20;
}

.z-30{
    z-index: 30;
}

.z-40{
    z-index: 40;
}

.z-50{
    z-index: 50;
}

.z-\[100\]{
    z-index: 100;
}

.z-\[101\]{
    z-index: 101;
}

.z-\[110\]{
    z-index: 110;
}

.z-\[120\]{
    z-index: 120;
}

.z-\[1\]{
    z-index: 1;
}

.z-\[45\]{
    z-index: 45;
}

.z-\[60\]{
    z-index: 60;
}

.z-\[9999\]{
    z-index: 9999;
}

.col-span-2{
    grid-column: span 2 / span 2;
}

.col-span-full{
    grid-column: 1 / -1;
}

.m-0{
    margin: 0px;
}

.m-2{
    margin: 0.5rem;
}

.-mx-1{
    margin-left: -0.25rem;
    margin-right: -0.25rem;
}

.-mx-4{
    margin-left: -1rem;
    margin-right: -1rem;
}

.-mx-6{
    margin-left: -1.5rem;
    margin-right: -1.5rem;
}

.mx-0\.5{
    margin-left: 0.125rem;
    margin-right: 0.125rem;
}

.mx-2{
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}

.mx-3\.5{
    margin-left: 0.875rem;
    margin-right: 0.875rem;
}

.mx-4{
    margin-left: 1rem;
    margin-right: 1rem;
}

.mx-\[2px\]{
    margin-left: 2px;
    margin-right: 2px;
}

.mx-auto{
    margin-left: auto;
    margin-right: auto;
}

.my-0\.5{
    margin-top: 0.125rem;
    margin-bottom: 0.125rem;
}

.my-1{
    margin-top: 0.25rem;
    margin-bottom: 0.25rem;
}

.my-2{
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}

.my-3{
    margin-top: 0.75rem;
    margin-bottom: 0.75rem;
}

.my-4{
    margin-top: 1rem;
    margin-bottom: 1rem;
}

.-ml-0{
    margin-left: -0px;
}

.-ml-2{
    margin-left: -0.5rem;
}

.-ml-4{
    margin-left: -1rem;
}

.-mr-1{
    margin-right: -0.25rem;
}

.-mt-0\.5{
    margin-top: -0.125rem;
}

.-mt-1{
    margin-top: -0.25rem;
}

.-mt-16{
    margin-top: -4rem;
}

.-mt-4{
    margin-top: -1rem;
}

.mb-0{
    margin-bottom: 0px;
}

.mb-0\.5{
    margin-bottom: 0.125rem;
}

.mb-1{
    margin-bottom: 0.25rem;
}

.mb-1\.5{
    margin-bottom: 0.375rem;
}

.mb-16{
    margin-bottom: 4rem;
}

.mb-2{
    margin-bottom: 0.5rem;
}

.mb-20{
    margin-bottom: 5rem;
}

.mb-3{
    margin-bottom: 0.75rem;
}

.mb-4{
    margin-bottom: 1rem;
}

.mb-5{
    margin-bottom: 1.25rem;
}

.mb-6{
    margin-bottom: 1.5rem;
}

.mb-8{
    margin-bottom: 2rem;
}

.ml-0\.5{
    margin-left: 0.125rem;
}

.ml-1{
    margin-left: 0.25rem;
}

.ml-2{
    margin-left: 0.5rem;
}

.ml-3{
    margin-left: 0.75rem;
}

.ml-4{
    margin-left: 1rem;
}

.ml-6{
    margin-left: 1.5rem;
}

.ml-8{
    margin-left: 2rem;
}

.ml-auto{
    margin-left: auto;
}

.mr-1{
    margin-right: 0.25rem;
}

.mr-1\.5{
    margin-right: 0.375rem;
}

.mr-2{
    margin-right: 0.5rem;
}

.mr-3{
    margin-right: 0.75rem;
}

.mt-0{
    margin-top: 0px;
}

.mt-0\.5{
    margin-top: 0.125rem;
}

.mt-1{
    margin-top: 0.25rem;
}

.mt-1\.5{
    margin-top: 0.375rem;
}

.mt-12{
    margin-top: 3rem;
}

.mt-2{
    margin-top: 0.5rem;
}

.mt-24{
    margin-top: 6rem;
}

.mt-3{
    margin-top: 0.75rem;
}

.mt-4{
    margin-top: 1rem;
}

.mt-6{
    margin-top: 1.5rem;
}

.mt-8{
    margin-top: 2rem;
}

.mt-auto{
    margin-top: auto;
}

.line-clamp-1{
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
}

.line-clamp-2{
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.block{
    display: block;
}

.inline-block{
    display: inline-block;
}

.inline{
    display: inline;
}

.flex{
    display: flex;
}

.inline-flex{
    display: inline-flex;
}

.table{
    display: table;
}

.grid{
    display: grid;
}

.list-item{
    display: list-item;
}

.hidden{
    display: none;
}

.aspect-\[3\/4\]{
    aspect-ratio: 3/4;
}

.aspect-\[4\/3\]{
    aspect-ratio: 4/3;
}

.aspect-square{
    aspect-ratio: 1 / 1;
}

.aspect-video{
    aspect-ratio: 16 / 9;
}

.size-4{
    width: 1rem;
    height: 1rem;
}

.h-0\.5{
    height: 0.125rem;
}

.h-1{
    height: 0.25rem;
}

.h-1\.5{
    height: 0.375rem;
}

.h-10{
    height: 2.5rem;
}

.h-11{
    height: 2.75rem;
}

.h-12{
    height: 3rem;
}

.h-14{
    height: 3.5rem;
}

.h-16{
    height: 4rem;
}

.h-2{
    height: 0.5rem;
}

.h-2\.5{
    height: 0.625rem;
}

.h-20{
    height: 5rem;
}

.h-24{
    height: 6rem;
}

.h-28{
    height: 7rem;
}

.h-3{
    height: 0.75rem;
}

.h-3\.5{
    height: 0.875rem;
}

.h-3\/4{
    height: 75%;
}

.h-32{
    height: 8rem;
}

.h-4{
    height: 1rem;
}

.h-40{
    height: 10rem;
}

.h-44{
    height: 11rem;
}

.h-48{
    height: 12rem;
}

.h-5{
    height: 1.25rem;
}

.h-56{
    height: 14rem;
}

.h-6{
    height: 1.5rem;
}

.h-64{
    height: 16rem;
}

.h-7{
    height: 1.75rem;
}

.h-8{
    height: 2rem;
}

.h-80{
    height: 20rem;
}

.h-9{
    height: 2.25rem;
}

.h-96{
    height: 24rem;
}

.h-\[100vh\]{
    height: 100vh;
}

.h-\[1px\]{
    height: 1px;
}

.h-\[280px\]{
    height: 280px;
}

.h-\[320px\]{
    height: 320px;
}

.h-\[500px\]{
    height: 500px;
}

.h-\[80vh\]{
    height: 80vh;
}

.h-\[85vh\]{
    height: 85vh;
}

.h-\[90vh\]{
    height: 90vh;
}

.h-\[var\(--radix-navigation-menu-viewport-height\)\]{
    height: var(--radix-navigation-menu-viewport-height);
}

.h-\[var\(--radix-select-trigger-height\)\]{
    height: var(--radix-select-trigger-height);
}

.h-auto{
    height: auto;
}

.h-full{
    height: 100%;
}

.h-px{
    height: 1px;
}

.h-screen{
    height: 100vh;
}

.h-svh{
    height: 100svh;
}

.max-h-0{
    max-height: 0px;
}

.max-h-32{
    max-height: 8rem;
}

.max-h-48{
    max-height: 12rem;
}

.max-h-60{
    max-height: 15rem;
}

.max-h-64{
    max-height: 16rem;
}

.max-h-80{
    max-height: 20rem;
}

.max-h-96{
    max-height: 24rem;
}

.max-h-\[1000px\]{
    max-height: 1000px;
}

.max-h-\[100vh\]{
    max-height: 100vh;
}

.max-h-\[2\.5rem\]{
    max-height: 2.5rem;
}

.max-h-\[300px\]{
    max-height: 300px;
}

.max-h-\[500px\]{
    max-height: 500px;
}

.max-h-\[600px\]{
    max-height: 600px;
}

.max-h-\[70vh\]{
    max-height: 70vh;
}

.max-h-\[80px\]{
    max-height: 80px;
}

.max-h-\[80vh\]{
    max-height: 80vh;
}

.max-h-\[85vh\]{
    max-height: 85vh;
}

.max-h-\[90vh\]{
    max-height: 90vh;
}

.max-h-\[95vh\]{
    max-height: 95vh;
}

.max-h-\[calc\(100dvh-2rem\)\]{
    max-height: calc(100dvh - 2rem);
}

.max-h-full{
    max-height: 100%;
}

.max-h-none{
    max-height: none;
}

.max-h-screen{
    max-height: 100vh;
}

.min-h-0{
    min-height: 0px;
}

.min-h-\[100px\]{
    min-height: 100px;
}

.min-h-\[120px\]{
    min-height: 120px;
}

.min-h-\[180px\]{
    min-height: 180px;
}

.min-h-\[2\.5rem\]{
    min-height: 2.5rem;
}

.min-h-\[200px\]{
    min-height: 200px;
}

.min-h-\[280px\]{
    min-height: 280px;
}

.min-h-\[300px\]{
    min-height: 300px;
}

.min-h-\[36px\]{
    min-height: 36px;
}

.min-h-\[400px\]{
    min-height: 400px;
}

.min-h-\[40px\]{
    min-height: 40px;
}

.min-h-\[44px\]{
    min-height: 44px;
}

.min-h-\[48px\]{
    min-height: 48px;
}

.min-h-\[50vh\]{
    min-height: 50vh;
}

.min-h-\[600px\]{
    min-height: 600px;
}

.min-h-\[60px\]{
    min-height: 60px;
}

.min-h-\[80px\]{
    min-height: 80px;
}

.min-h-\[calc\(100dvh-14rem\)\]{
    min-height: calc(100dvh - 14rem);
}

.min-h-screen{
    min-height: 100vh;
}

.min-h-svh{
    min-height: 100svh;
}

.w-0{
    width: 0px;
}

.w-0\.5{
    width: 0.125rem;
}

.w-1{
    width: 0.25rem;
}

.w-1\.5{
    width: 0.375rem;
}

.w-1\/2{
    width: 50%;
}

.w-1\/3{
    width: 33.333333%;
}

.w-1\/4{
    width: 25%;
}

.w-10{
    width: 2.5rem;
}

.w-11{
    width: 2.75rem;
}

.w-12{
    width: 3rem;
}

.w-14{
    width: 3.5rem;
}

.w-16{
    width: 4rem;
}

.w-2{
    width: 0.5rem;
}

.w-2\.5{
    width: 0.625rem;
}

.w-2\/3{
    width: 66.666667%;
}

.w-20{
    width: 5rem;
}

.w-24{
    width: 6rem;
}

.w-28{
    width: 7rem;
}

.w-3{
    width: 0.75rem;
}

.w-3\.5{
    width: 0.875rem;
}

.w-3\/4{
    width: 75%;
}

.w-32{
    width: 8rem;
}

.w-36{
    width: 9rem;
}

.w-4{
    width: 1rem;
}

.w-40{
    width: 10rem;
}

.w-48{
    width: 12rem;
}

.w-5{
    width: 1.25rem;
}

.w-56{
    width: 14rem;
}

.w-6{
    width: 1.5rem;
}

.w-64{
    width: 16rem;
}

.w-7{
    width: 1.75rem;
}

.w-72{
    width: 18rem;
}

.w-8{
    width: 2rem;
}

.w-80{
    width: 20rem;
}

.w-9{
    width: 2.25rem;
}

.w-96{
    width: 24rem;
}

.w-\[--radix-dropdown-menu-trigger-width\]{
    width: var(--radix-dropdown-menu-trigger-width);
}

.w-\[--sidebar-width\]{
    width: var(--sidebar-width);
}

.w-\[100px\]{
    width: 100px;
}

.w-\[100vw\]{
    width: 100vw;
}

.w-\[140px\]{
    width: 140px;
}

.w-\[1px\]{
    width: 1px;
}

.w-\[calc\(100vw-2rem\)\]{
    width: calc(100vw - 2rem);
}

.w-auto{
    width: auto;
}

.w-fit{
    width: -moz-fit-content;
    width: fit-content;
}

.w-full{
    width: 100%;
}

.w-max{
    width: -moz-max-content;
    width: max-content;
}

.w-px{
    width: 1px;
}

.w-screen{
    width: 100vw;
}

.min-w-0{
    min-width: 0px;
}

.min-w-5{
    min-width: 1.25rem;
}

.min-w-\[100px\]{
    min-width: 100px;
}

.min-w-\[120px\]{
    min-width: 120px;
}

.min-w-\[12rem\]{
    min-width: 12rem;
}

.min-w-\[280px\]{
    min-width: 280px;
}

.min-w-\[44px\]{
    min-width: 44px;
}

.min-w-\[56px\]{
    min-width: 56px;
}

.min-w-\[60px\]{
    min-width: 60px;
}

.min-w-\[70px\]{
    min-width: 70px;
}

.min-w-\[80px\]{
    min-width: 80px;
}

.min-w-\[8rem\]{
    min-width: 8rem;
}

.min-w-\[90px\]{
    min-width: 90px;
}

.min-w-\[var\(--radix-select-trigger-width\)\]{
    min-width: var(--radix-select-trigger-width);
}

.min-w-full{
    min-width: 100%;
}

.min-w-max{
    min-width: -moz-max-content;
    min-width: max-content;
}

.max-w-20{
    max-width: 5rem;
}

.max-w-2xl{
    max-width: 42rem;
}

.max-w-3xl{
    max-width: 48rem;
}

.max-w-4xl{
    max-width: 56rem;
}

.max-w-5xl{
    max-width: 64rem;
}

.max-w-6xl{
    max-width: 72rem;
}

.max-w-7xl{
    max-width: 80rem;
}

.max-w-\[--skeleton-width\]{
    max-width: var(--skeleton-width);
}

.max-w-\[100px\]{
    max-width: 100px;
}

.max-w-\[100vw\]{
    max-width: 100vw;
}

.max-w-\[120px\]{
    max-width: 120px;
}

.max-w-\[200px\]{
    max-width: 200px;
}

.max-w-\[220px\]{
    max-width: 220px;
}

.max-w-\[60px\]{
    max-width: 60px;
}

.max-w-\[70\%\]{
    max-width: 70%;
}

.max-w-\[80px\]{
    max-width: 80px;
}

.max-w-\[85\%\]{
    max-width: 85%;
}

.max-w-\[85vw\]{
    max-width: 85vw;
}

.max-w-\[90px\]{
    max-width: 90px;
}

.max-w-\[95vw\]{
    max-width: 95vw;
}

.max-w-\[min\(90vw\2c 20rem\)\]{
    max-width: min(90vw,20rem);
}

.max-w-\[min\(95vw\2c 600px\)\]{
    max-width: min(95vw,600px);
}

.max-w-full{
    max-width: 100%;
}

.max-w-lg{
    max-width: 32rem;
}

.max-w-max{
    max-width: -moz-max-content;
    max-width: max-content;
}

.max-w-md{
    max-width: 28rem;
}

.max-w-none{
    max-width: none;
}

.max-w-sm{
    max-width: 24rem;
}

.max-w-xs{
    max-width: 20rem;
}

.flex-1{
    flex: 1 1 0%;
}

.flex-shrink-0{
    flex-shrink: 0;
}

.shrink{
    flex-shrink: 1;
}

.shrink-0{
    flex-shrink: 0;
}

.flex-grow{
    flex-grow: 1;
}

.grow{
    flex-grow: 1;
}

.grow-0{
    flex-grow: 0;
}

.basis-1\/2{
    flex-basis: 50%;
}

.basis-1\/3{
    flex-basis: 33.333333%;
}

.basis-2\/3{
    flex-basis: 66.666667%;
}

.basis-\[200px\]{
    flex-basis: 200px;
}

.basis-full{
    flex-basis: 100%;
}

.caption-bottom{
    caption-side: bottom;
}

.border-collapse{
    border-collapse: collapse;
}

.origin-top{
    transform-origin: top;
}

.-translate-x-1\/2{
    --tw-translate-x: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-x-px{
    --tw-translate-x: -1px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-1\/2{
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-2{
    --tw-translate-y: -0.5rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-full{
    --tw-translate-y: -100%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-\[-50\%\]{
    --tw-translate-x: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-px{
    --tw-translate-x: 1px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-y-0{
    --tw-translate-y: 0px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-y-\[-50\%\]{
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-y-full{
    --tw-translate-y: 100%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-rotate-45{
    --tw-rotate: -45deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-180{
    --tw-rotate: 180deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-45{
    --tw-rotate: 45deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-90{
    --tw-rotate: 90deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-100{
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-105{
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-110{
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-75{
    --tw-scale-x: .75;
    --tw-scale-y: .75;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-90{
    --tw-scale-x: .9;
    --tw-scale-y: .9;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-\[0\.4\]{
    --tw-scale-x: 0.4;
    --tw-scale-y: 0.4;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-\[1\.02\]{
    --tw-scale-x: 1.02;
    --tw-scale-y: 1.02;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-x-\[-1\]{
    --tw-scale-x: -1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform{
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform-gpu{
    transform: translate3d(var(--tw-translate-x), var(--tw-translate-y), 0) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

@keyframes fadeInPulseBurst{

    0%{
        opacity: 0;
        transform: scale(0.8);
    }

    30%{
        opacity: 1;
        transform: scale(1);
    }

    50%{
        opacity: 1;
        transform: scale(1.05);
    }

    65%{
        opacity: 1;
        transform: scale(0.98);
    }

    80%{
        opacity: 1;
        transform: scale(1.02);
    }

    90%{
        opacity: 1;
        transform: scale(1.5);
    }

    100%{
        opacity: 0;
        transform: scale(2);
    }
}

.animate-\[fadeInPulseBurst_2\.5s_ease-in-out_forwards\]{
    animation: fadeInPulseBurst 2.5s ease-in-out forwards;
}

@keyframes loading{

    0%{
        width: 0%;
    }

    50%{
        width: 70%;
    }

    100%{
        width: 100%;
    }
}

.animate-\[loading_3s_ease-in-out_infinite\]{
    animation: loading 3s ease-in-out infinite;
}

@keyframes bounce{

    0%, 100%{
        transform: translateY(-25%);
        animation-timing-function: cubic-bezier(0.8,0,1,1);
    }

    50%{
        transform: none;
        animation-timing-function: cubic-bezier(0,0,0.2,1);
    }
}

.animate-bounce{
    animation: bounce 1s infinite;
}

@keyframes fade-in{

    0%{
        opacity: 0;
        transform: translateY(10px);
    }

    100%{
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade-in{
    animation: fade-in 0.5s ease-out;
}

@keyframes float{

    0%, 100%{
        transform: translateY(0);
    }

    50%{
        transform: translateY(-10px);
    }
}

.animate-float{
    animation: float 3s ease-in-out infinite;
}

@keyframes marquee{

    0%{
        transform: translateX(0);
    }

    100%{
        transform: translateX(-50%);
    }
}

.animate-marquee{
    animation: marquee 20s linear infinite;
}

@keyframes ping{

    75%, 100%{
        transform: scale(2);
        opacity: 0;
    }
}

.animate-ping{
    animation: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
}

@keyframes pulse{

    50%{
        opacity: .5;
    }
}

.animate-pulse{
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes spin{

    to{
        transform: rotate(360deg);
    }
}

.animate-spin{
    animation: spin 1s linear infinite;
}

.cursor-crosshair{
    cursor: crosshair;
}

.cursor-default{
    cursor: default;
}

.cursor-grab{
    cursor: grab;
}

.cursor-help{
    cursor: help;
}

.cursor-not-allowed{
    cursor: not-allowed;
}

.cursor-pointer{
    cursor: pointer;
}

.touch-none{
    touch-action: none;
}

.touch-pan-y{
    --tw-pan-y: pan-y;
    touch-action: var(--tw-pan-x) var(--tw-pan-y) var(--tw-pinch-zoom);
}

.touch-manipulation{
    touch-action: manipulation;
}

.select-none{
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
}

.resize-none{
    resize: none;
}

.resize{
    resize: both;
}

.list-inside{
    list-style-position: inside;
}

.list-decimal{
    list-style-type: decimal;
}

.list-disc{
    list-style-type: disc;
}

.list-none{
    list-style-type: none;
}

.grid-cols-1{
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

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

.grid-cols-3{
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-cols-4{
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.grid-cols-5{
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.flex-row{
    flex-direction: row;
}

.flex-row-reverse{
    flex-direction: row-reverse;
}

.flex-col{
    flex-direction: column;
}

.flex-col-reverse{
    flex-direction: column-reverse;
}

.flex-wrap{
    flex-wrap: wrap;
}

.items-start{
    align-items: flex-start;
}

.items-end{
    align-items: flex-end;
}

.items-center{
    align-items: center;
}

.items-baseline{
    align-items: baseline;
}

.items-stretch{
    align-items: stretch;
}

.justify-start{
    justify-content: flex-start;
}

.justify-end{
    justify-content: flex-end;
}

.justify-center{
    justify-content: center;
}

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

.gap-0{
    gap: 0px;
}

.gap-0\.5{
    gap: 0.125rem;
}

.gap-1{
    gap: 0.25rem;
}

.gap-1\.5{
    gap: 0.375rem;
}

.gap-2{
    gap: 0.5rem;
}

.gap-2\.5{
    gap: 0.625rem;
}

.gap-3{
    gap: 0.75rem;
}

.gap-4{
    gap: 1rem;
}

.gap-5{
    gap: 1.25rem;
}

.gap-6{
    gap: 1.5rem;
}

.gap-8{
    gap: 2rem;
}

.gap-\[-4px\]{
    gap: -4px;
}

.-space-x-0\.5 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(-0.125rem * var(--tw-space-x-reverse));
    margin-left: calc(-0.125rem * calc(1 - var(--tw-space-x-reverse)));
}

.-space-x-1 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(-0.25rem * var(--tw-space-x-reverse));
    margin-left: calc(-0.25rem * calc(1 - var(--tw-space-x-reverse)));
}

.-space-x-1\.5 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(-0.375rem * var(--tw-space-x-reverse));
    margin-left: calc(-0.375rem * calc(1 - var(--tw-space-x-reverse)));
}

.-space-x-2 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(-0.5rem * var(--tw-space-x-reverse));
    margin-left: calc(-0.5rem * calc(1 - var(--tw-space-x-reverse)));
}

.-space-x-3 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(-0.75rem * var(--tw-space-x-reverse));
    margin-left: calc(-0.75rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-x-1 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(0.25rem * var(--tw-space-x-reverse));
    margin-left: calc(0.25rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-x-2 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(0.5rem * var(--tw-space-x-reverse));
    margin-left: calc(0.5rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-x-3 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(0.75rem * var(--tw-space-x-reverse));
    margin-left: calc(0.75rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-x-4 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(1rem * var(--tw-space-x-reverse));
    margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-x-6 > :not([hidden]) ~ :not([hidden]){
    --tw-space-x-reverse: 0;
    margin-right: calc(1.5rem * var(--tw-space-x-reverse));
    margin-left: calc(1.5rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-y-0 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0px * var(--tw-space-y-reverse));
}

.space-y-0\.5 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.125rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.125rem * var(--tw-space-y-reverse));
}

.space-y-1 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.25rem * var(--tw-space-y-reverse));
}

.space-y-1\.5 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.375rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.375rem * var(--tw-space-y-reverse));
}

.space-y-2 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
}

.space-y-2\.5 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.625rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.625rem * var(--tw-space-y-reverse));
}

.space-y-3 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
}

.space-y-4 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}

.space-y-5 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.25rem * var(--tw-space-y-reverse));
}

.space-y-6 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}

.space-y-8 > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(2rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2rem * var(--tw-space-y-reverse));
}

.divide-y > :not([hidden]) ~ :not([hidden]){
    --tw-divide-y-reverse: 0;
    border-top-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
    border-bottom-width: calc(1px * var(--tw-divide-y-reverse));
}

.divide-border > :not([hidden]) ~ :not([hidden]){
    border-color: hsl(var(--border));
}

.overflow-auto{
    overflow: auto;
}

.overflow-hidden{
    overflow: hidden;
}

.overflow-visible{
    overflow: visible;
}

.overflow-x-auto{
    overflow-x: auto;
}

.overflow-y-auto{
    overflow-y: auto;
}

.overflow-x-hidden{
    overflow-x: hidden;
}

.overflow-y-scroll{
    overflow-y: scroll;
}

.overscroll-contain{
    overscroll-behavior: contain;
}

.truncate{
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.whitespace-normal{
    white-space: normal;
}

.whitespace-nowrap{
    white-space: nowrap;
}

.whitespace-pre-wrap{
    white-space: pre-wrap;
}

.break-words{
    overflow-wrap: break-word;
}

.break-all{
    word-break: break-all;
}

.rounded{
    border-radius: 0.25rem;
}

.rounded-2xl{
    border-radius: 1rem;
}

.rounded-\[2px\]{
    border-radius: 2px;
}

.rounded-\[inherit\]{
    border-radius: inherit;
}

.rounded-full{
    border-radius: 9999px;
}

.rounded-lg{
    border-radius: var(--radius);
}

.rounded-md{
    border-radius: calc(var(--radius) - 2px);
}

.rounded-none{
    border-radius: 0px;
}

.rounded-sm{
    border-radius: calc(var(--radius) - 4px);
}

.rounded-xl{
    border-radius: 0.75rem;
}

.rounded-b-xl{
    border-bottom-right-radius: 0.75rem;
    border-bottom-left-radius: 0.75rem;
}

.rounded-l-none{
    border-top-left-radius: 0px;
    border-bottom-left-radius: 0px;
}

.rounded-r-none{
    border-top-right-radius: 0px;
    border-bottom-right-radius: 0px;
}

.rounded-t-3xl{
    border-top-left-radius: 1.5rem;
    border-top-right-radius: 1.5rem;
}

.rounded-t-\[10px\]{
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}

.rounded-t-lg{
    border-top-left-radius: var(--radius);
    border-top-right-radius: var(--radius);
}

.rounded-t-xl{
    border-top-left-radius: 0.75rem;
    border-top-right-radius: 0.75rem;
}

.rounded-bl-lg{
    border-bottom-left-radius: var(--radius);
}

.rounded-bl-md{
    border-bottom-left-radius: calc(var(--radius) - 2px);
}

.rounded-bl-sm{
    border-bottom-left-radius: calc(var(--radius) - 4px);
}

.rounded-br-lg{
    border-bottom-right-radius: var(--radius);
}

.rounded-br-sm{
    border-bottom-right-radius: calc(var(--radius) - 4px);
}

.rounded-tl-lg{
    border-top-left-radius: var(--radius);
}

.rounded-tl-md{
    border-top-left-radius: calc(var(--radius) - 2px);
}

.rounded-tl-sm{
    border-top-left-radius: calc(var(--radius) - 4px);
}

.rounded-tr-lg{
    border-top-right-radius: var(--radius);
}

.border{
    border-width: 1px;
}

.border-0{
    border-width: 0px;
}

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

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

.border-\[1\.5px\]{
    border-width: 1.5px;
}

.border-\[6px\]{
    border-width: 6px;
}

.border-y{
    border-top-width: 1px;
    border-bottom-width: 1px;
}

.border-b{
    border-bottom-width: 1px;
}

.border-b-2{
    border-bottom-width: 2px;
}

.border-b-4{
    border-bottom-width: 4px;
}

.border-l{
    border-left-width: 1px;
}

.border-l-0{
    border-left-width: 0px;
}

.border-l-2{
    border-left-width: 2px;
}

.border-l-4{
    border-left-width: 4px;
}

.border-r{
    border-right-width: 1px;
}

.border-r-4{
    border-right-width: 4px;
}

.border-t{
    border-top-width: 1px;
}

.border-t-0{
    border-top-width: 0px;
}

.border-t-4{
    border-top-width: 4px;
}

.border-dashed{
    border-style: dashed;
}

.border-double{
    border-style: double;
}

.border-\[--color-border\]{
    border-color: var(--color-border);
}

.border-accent{
    border-color: hsl(var(--accent));
}

.border-amber-200{
    --tw-border-opacity: 1;
    border-color: rgb(253 230 138 / var(--tw-border-opacity, 1));
}

.border-amber-300{
    --tw-border-opacity: 1;
    border-color: rgb(252 211 77 / var(--tw-border-opacity, 1));
}

.border-amber-500\/30{
    border-color: rgb(245 158 11 / 0.3);
}

.border-amber-500\/50{
    border-color: rgb(245 158 11 / 0.5);
}

.border-amber-600{
    --tw-border-opacity: 1;
    border-color: rgb(217 119 6 / var(--tw-border-opacity, 1));
}

.border-background{
    border-color: hsl(var(--background));
}

.border-blue-200{
    --tw-border-opacity: 1;
    border-color: rgb(191 219 254 / var(--tw-border-opacity, 1));
}

.border-blue-300{
    --tw-border-opacity: 1;
    border-color: rgb(147 197 253 / var(--tw-border-opacity, 1));
}

.border-blue-400{
    --tw-border-opacity: 1;
    border-color: rgb(96 165 250 / var(--tw-border-opacity, 1));
}

.border-blue-500{
    --tw-border-opacity: 1;
    border-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.border-blue-500\/20{
    border-color: rgb(59 130 246 / 0.2);
}

.border-blue-500\/30{
    border-color: rgb(59 130 246 / 0.3);
}

.border-blue-500\/50{
    border-color: rgb(59 130 246 / 0.5);
}

.border-blue-600{
    --tw-border-opacity: 1;
    border-color: rgb(37 99 235 / var(--tw-border-opacity, 1));
}

.border-blue-700{
    --tw-border-opacity: 1;
    border-color: rgb(29 78 216 / var(--tw-border-opacity, 1));
}

.border-border{
    border-color: hsl(var(--border));
}

.border-border\/50{
    border-color: hsl(var(--border) / 0.5);
}

.border-current{
    border-color: currentColor;
}

.border-cyan-300{
    --tw-border-opacity: 1;
    border-color: rgb(103 232 249 / var(--tw-border-opacity, 1));
}

.border-cyan-500\/30{
    border-color: rgb(6 182 212 / 0.3);
}

.border-destructive{
    border-color: hsl(var(--destructive));
}

.border-destructive\/20{
    border-color: hsl(var(--destructive) / 0.2);
}

.border-destructive\/50{
    border-color: hsl(var(--destructive) / 0.5);
}

.border-emerald-200{
    --tw-border-opacity: 1;
    border-color: rgb(167 243 208 / var(--tw-border-opacity, 1));
}

.border-emerald-400\/30{
    border-color: rgb(52 211 153 / 0.3);
}

.border-emerald-400\/40{
    border-color: rgb(52 211 153 / 0.4);
}

.border-emerald-500\/30{
    border-color: rgb(16 185 129 / 0.3);
}

.border-gray-100{
    --tw-border-opacity: 1;
    border-color: rgb(243 244 246 / var(--tw-border-opacity, 1));
}

.border-gray-200{
    --tw-border-opacity: 1;
    border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
}

.border-gray-300{
    --tw-border-opacity: 1;
    border-color: rgb(209 213 219 / var(--tw-border-opacity, 1));
}

.border-gray-800{
    --tw-border-opacity: 1;
    border-color: rgb(31 41 55 / var(--tw-border-opacity, 1));
}

.border-green-200{
    --tw-border-opacity: 1;
    border-color: rgb(187 247 208 / var(--tw-border-opacity, 1));
}

.border-green-300{
    --tw-border-opacity: 1;
    border-color: rgb(134 239 172 / var(--tw-border-opacity, 1));
}

.border-green-400{
    --tw-border-opacity: 1;
    border-color: rgb(74 222 128 / var(--tw-border-opacity, 1));
}

.border-green-500{
    --tw-border-opacity: 1;
    border-color: rgb(34 197 94 / var(--tw-border-opacity, 1));
}

.border-green-500\/50{
    border-color: rgb(34 197 94 / 0.5);
}

.border-green-600{
    --tw-border-opacity: 1;
    border-color: rgb(22 163 74 / var(--tw-border-opacity, 1));
}

.border-green-700{
    --tw-border-opacity: 1;
    border-color: rgb(21 128 61 / var(--tw-border-opacity, 1));
}

.border-indigo-200\/50{
    border-color: rgb(199 210 254 / 0.5);
}

.border-input{
    border-color: hsl(var(--input));
}

.border-muted{
    border-color: hsl(var(--muted));
}

.border-muted-foreground\/20{
    border-color: hsl(var(--muted-foreground) / 0.2);
}

.border-muted-foreground\/25{
    border-color: hsl(var(--muted-foreground) / 0.25);
}

.border-muted-foreground\/30{
    border-color: hsl(var(--muted-foreground) / 0.3);
}

.border-muted-foreground\/50{
    border-color: hsl(var(--muted-foreground) / 0.5);
}

.border-orange-200{
    --tw-border-opacity: 1;
    border-color: rgb(254 215 170 / var(--tw-border-opacity, 1));
}

.border-orange-300{
    --tw-border-opacity: 1;
    border-color: rgb(253 186 116 / var(--tw-border-opacity, 1));
}

.border-orange-400{
    --tw-border-opacity: 1;
    border-color: rgb(251 146 60 / var(--tw-border-opacity, 1));
}

.border-orange-500\/20{
    border-color: rgb(249 115 22 / 0.2);
}

.border-orange-500\/30{
    border-color: rgb(249 115 22 / 0.3);
}

.border-orange-500\/50{
    border-color: rgb(249 115 22 / 0.5);
}

.border-orange-600{
    --tw-border-opacity: 1;
    border-color: rgb(234 88 12 / var(--tw-border-opacity, 1));
}

.border-pink-200{
    --tw-border-opacity: 1;
    border-color: rgb(251 207 232 / var(--tw-border-opacity, 1));
}

.border-primary{
    border-color: hsl(var(--primary));
}

.border-primary-foreground\/30{
    border-color: hsl(var(--primary-foreground) / 0.3);
}

.border-primary\/10{
    border-color: hsl(var(--primary) / 0.1);
}

.border-primary\/20{
    border-color: hsl(var(--primary) / 0.2);
}

.border-primary\/30{
    border-color: hsl(var(--primary) / 0.3);
}

.border-primary\/50{
    border-color: hsl(var(--primary) / 0.5);
}

.border-purple-100{
    --tw-border-opacity: 1;
    border-color: rgb(243 232 255 / var(--tw-border-opacity, 1));
}

.border-purple-200{
    --tw-border-opacity: 1;
    border-color: rgb(233 213 255 / var(--tw-border-opacity, 1));
}

.border-purple-300{
    --tw-border-opacity: 1;
    border-color: rgb(216 180 254 / var(--tw-border-opacity, 1));
}

.border-purple-400{
    --tw-border-opacity: 1;
    border-color: rgb(192 132 252 / var(--tw-border-opacity, 1));
}

.border-purple-500{
    --tw-border-opacity: 1;
    border-color: rgb(168 85 247 / var(--tw-border-opacity, 1));
}

.border-purple-500\/30{
    border-color: rgb(168 85 247 / 0.3);
}

.border-purple-500\/50{
    border-color: rgb(168 85 247 / 0.5);
}

.border-purple-600{
    --tw-border-opacity: 1;
    border-color: rgb(147 51 234 / var(--tw-border-opacity, 1));
}

.border-purple-700{
    --tw-border-opacity: 1;
    border-color: rgb(126 34 206 / var(--tw-border-opacity, 1));
}

.border-red-200{
    --tw-border-opacity: 1;
    border-color: rgb(254 202 202 / var(--tw-border-opacity, 1));
}

.border-red-300{
    --tw-border-opacity: 1;
    border-color: rgb(252 165 165 / var(--tw-border-opacity, 1));
}

.border-red-400{
    --tw-border-opacity: 1;
    border-color: rgb(248 113 113 / var(--tw-border-opacity, 1));
}

.border-red-500{
    --tw-border-opacity: 1;
    border-color: rgb(239 68 68 / var(--tw-border-opacity, 1));
}

.border-red-600{
    --tw-border-opacity: 1;
    border-color: rgb(220 38 38 / var(--tw-border-opacity, 1));
}

.border-red-700{
    --tw-border-opacity: 1;
    border-color: rgb(185 28 28 / var(--tw-border-opacity, 1));
}

.border-rose-500\/30{
    border-color: rgb(244 63 94 / 0.3);
}

.border-sidebar-border{
    border-color: hsl(var(--sidebar-border));
}

.border-transparent{
    border-color: transparent;
}

.border-white{
    --tw-border-opacity: 1;
    border-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
}

.border-white\/20{
    border-color: rgb(255 255 255 / 0.2);
}

.border-white\/30{
    border-color: rgb(255 255 255 / 0.3);
}

.border-white\/40{
    border-color: rgb(255 255 255 / 0.4);
}

.border-white\/50{
    border-color: rgb(255 255 255 / 0.5);
}

.border-white\/80{
    border-color: rgb(255 255 255 / 0.8);
}

.border-yellow-200{
    --tw-border-opacity: 1;
    border-color: rgb(254 240 138 / var(--tw-border-opacity, 1));
}

.border-yellow-300{
    --tw-border-opacity: 1;
    border-color: rgb(253 224 71 / var(--tw-border-opacity, 1));
}

.border-yellow-400\/50{
    border-color: rgb(250 204 21 / 0.5);
}

.border-yellow-500\/20{
    border-color: rgb(234 179 8 / 0.2);
}

.border-yellow-600{
    --tw-border-opacity: 1;
    border-color: rgb(202 138 4 / var(--tw-border-opacity, 1));
}

.border-l-blue-500{
    --tw-border-opacity: 1;
    border-left-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.border-l-orange-500{
    --tw-border-opacity: 1;
    border-left-color: rgb(249 115 22 / var(--tw-border-opacity, 1));
}

.border-l-pink-500{
    --tw-border-opacity: 1;
    border-left-color: rgb(236 72 153 / var(--tw-border-opacity, 1));
}

.border-l-primary{
    border-left-color: hsl(var(--primary));
}

.border-l-purple-500{
    --tw-border-opacity: 1;
    border-left-color: rgb(168 85 247 / var(--tw-border-opacity, 1));
}

.border-l-transparent{
    border-left-color: transparent;
}

.border-r-emerald-400{
    --tw-border-opacity: 1;
    border-right-color: rgb(52 211 153 / var(--tw-border-opacity, 1));
}

.border-t-emerald-500{
    --tw-border-opacity: 1;
    border-top-color: rgb(16 185 129 / var(--tw-border-opacity, 1));
}

.border-t-muted-foreground{
    border-top-color: hsl(var(--muted-foreground));
}

.border-t-primary{
    border-top-color: hsl(var(--primary));
}

.border-t-purple-600{
    --tw-border-opacity: 1;
    border-top-color: rgb(147 51 234 / var(--tw-border-opacity, 1));
}

.border-t-transparent{
    border-top-color: transparent;
}

.border-t-white{
    --tw-border-opacity: 1;
    border-top-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
}

.bg-\[--color-bg\]{
    background-color: var(--color-bg);
}

.bg-accent{
    background-color: hsl(var(--accent));
}

.bg-accent\/10{
    background-color: hsl(var(--accent) / 0.1);
}

.bg-amber-100{
    --tw-bg-opacity: 1;
    background-color: rgb(254 243 199 / var(--tw-bg-opacity, 1));
}

.bg-amber-50{
    --tw-bg-opacity: 1;
    background-color: rgb(255 251 235 / var(--tw-bg-opacity, 1));
}

.bg-amber-500{
    --tw-bg-opacity: 1;
    background-color: rgb(245 158 11 / var(--tw-bg-opacity, 1));
}

.bg-amber-500\/20{
    background-color: rgb(245 158 11 / 0.2);
}

.bg-amber-500\/30{
    background-color: rgb(245 158 11 / 0.3);
}

.bg-amber-500\/50{
    background-color: rgb(245 158 11 / 0.5);
}

.bg-amber-600{
    --tw-bg-opacity: 1;
    background-color: rgb(217 119 6 / var(--tw-bg-opacity, 1));
}

.bg-amber-900\/30{
    background-color: rgb(120 53 15 / 0.3);
}

.bg-background{
    background-color: hsl(var(--background));
}

.bg-background\/50{
    background-color: hsl(var(--background) / 0.5);
}

.bg-background\/60{
    background-color: hsl(var(--background) / 0.6);
}

.bg-background\/80{
    background-color: hsl(var(--background) / 0.8);
}

.bg-background\/95{
    background-color: hsl(var(--background) / 0.95);
}

.bg-black{
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}

.bg-black\/10{
    background-color: rgb(0 0 0 / 0.1);
}

.bg-black\/20{
    background-color: rgb(0 0 0 / 0.2);
}

.bg-black\/30{
    background-color: rgb(0 0 0 / 0.3);
}

.bg-black\/40{
    background-color: rgb(0 0 0 / 0.4);
}

.bg-black\/50{
    background-color: rgb(0 0 0 / 0.5);
}

.bg-black\/60{
    background-color: rgb(0 0 0 / 0.6);
}

.bg-black\/70{
    background-color: rgb(0 0 0 / 0.7);
}

.bg-black\/80{
    background-color: rgb(0 0 0 / 0.8);
}

.bg-black\/90{
    background-color: rgb(0 0 0 / 0.9);
}

.bg-black\/95{
    background-color: rgb(0 0 0 / 0.95);
}

.bg-blue-100{
    --tw-bg-opacity: 1;
    background-color: rgb(219 234 254 / var(--tw-bg-opacity, 1));
}

.bg-blue-50{
    --tw-bg-opacity: 1;
    background-color: rgb(239 246 255 / var(--tw-bg-opacity, 1));
}

.bg-blue-50\/50{
    background-color: rgb(239 246 255 / 0.5);
}

.bg-blue-500{
    --tw-bg-opacity: 1;
    background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}

.bg-blue-500\/10{
    background-color: rgb(59 130 246 / 0.1);
}

.bg-blue-500\/20{
    background-color: rgb(59 130 246 / 0.2);
}

.bg-blue-600{
    --tw-bg-opacity: 1;
    background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1));
}

.bg-blue-900\/30{
    background-color: rgb(30 58 138 / 0.3);
}

.bg-border{
    background-color: hsl(var(--border));
}

.bg-card{
    background-color: hsl(var(--card));
}

.bg-card\/90{
    background-color: hsl(var(--card) / 0.9);
}

.bg-card\/95{
    background-color: hsl(var(--card) / 0.95);
}

.bg-clothing-accessories{
    --tw-bg-opacity: 1;
    background-color: hsl(52 97% 90% / var(--tw-bg-opacity, 1));
}

.bg-clothing-bottoms{
    --tw-bg-opacity: 1;
    background-color: hsl(269 100% 94% / var(--tw-bg-opacity, 1));
}

.bg-clothing-dresses{
    --tw-bg-opacity: 1;
    background-color: hsl(347 100% 93% / var(--tw-bg-opacity, 1));
}

.bg-clothing-outerwear{
    --tw-bg-opacity: 1;
    background-color: hsl(218 100% 92% / var(--tw-bg-opacity, 1));
}

.bg-clothing-shoes{
    --tw-bg-opacity: 1;
    background-color: hsl(82 82% 94% / var(--tw-bg-opacity, 1));
}

.bg-clothing-tops{
    --tw-bg-opacity: 1;
    background-color: hsl(23 100% 92% / var(--tw-bg-opacity, 1));
}

.bg-current{
    background-color: currentColor;
}

.bg-cyan-100{
    --tw-bg-opacity: 1;
    background-color: rgb(207 250 254 / var(--tw-bg-opacity, 1));
}

.bg-cyan-50{
    --tw-bg-opacity: 1;
    background-color: rgb(236 254 255 / var(--tw-bg-opacity, 1));
}

.bg-cyan-500\/20{
    background-color: rgb(6 182 212 / 0.2);
}

.bg-destructive{
    background-color: hsl(var(--destructive));
}

.bg-destructive\/10{
    background-color: hsl(var(--destructive) / 0.1);
}

.bg-destructive\/20{
    background-color: hsl(var(--destructive) / 0.2);
}

.bg-destructive\/5{
    background-color: hsl(var(--destructive) / 0.05);
}

.bg-emerald-100{
    --tw-bg-opacity: 1;
    background-color: rgb(209 250 229 / var(--tw-bg-opacity, 1));
}

.bg-emerald-400{
    --tw-bg-opacity: 1;
    background-color: rgb(52 211 153 / var(--tw-bg-opacity, 1));
}

.bg-emerald-50{
    --tw-bg-opacity: 1;
    background-color: rgb(236 253 245 / var(--tw-bg-opacity, 1));
}

.bg-emerald-500{
    --tw-bg-opacity: 1;
    background-color: rgb(16 185 129 / var(--tw-bg-opacity, 1));
}

.bg-emerald-500\/20{
    background-color: rgb(16 185 129 / 0.2);
}

.bg-emerald-600{
    --tw-bg-opacity: 1;
    background-color: rgb(5 150 105 / var(--tw-bg-opacity, 1));
}

.bg-foreground{
    background-color: hsl(var(--foreground));
}

.bg-fuchsia-100{
    --tw-bg-opacity: 1;
    background-color: rgb(250 232 255 / var(--tw-bg-opacity, 1));
}

.bg-fuchsia-50{
    --tw-bg-opacity: 1;
    background-color: rgb(253 244 255 / var(--tw-bg-opacity, 1));
}

.bg-gray-100{
    --tw-bg-opacity: 1;
    background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}

.bg-gray-200{
    --tw-bg-opacity: 1;
    background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}

.bg-gray-300{
    --tw-bg-opacity: 1;
    background-color: rgb(209 213 219 / var(--tw-bg-opacity, 1));
}

.bg-gray-400{
    --tw-bg-opacity: 1;
    background-color: rgb(156 163 175 / var(--tw-bg-opacity, 1));
}

.bg-gray-50{
    --tw-bg-opacity: 1;
    background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}

.bg-gray-500{
    --tw-bg-opacity: 1;
    background-color: rgb(107 114 128 / var(--tw-bg-opacity, 1));
}

.bg-gray-600{
    --tw-bg-opacity: 1;
    background-color: rgb(75 85 99 / var(--tw-bg-opacity, 1));
}

.bg-gray-900\/90{
    background-color: rgb(17 24 39 / 0.9);
}

.bg-green-100{
    --tw-bg-opacity: 1;
    background-color: rgb(220 252 231 / var(--tw-bg-opacity, 1));
}

.bg-green-200{
    --tw-bg-opacity: 1;
    background-color: rgb(187 247 208 / var(--tw-bg-opacity, 1));
}

.bg-green-400{
    --tw-bg-opacity: 1;
    background-color: rgb(74 222 128 / var(--tw-bg-opacity, 1));
}

.bg-green-50{
    --tw-bg-opacity: 1;
    background-color: rgb(240 253 244 / var(--tw-bg-opacity, 1));
}

.bg-green-50\/50{
    background-color: rgb(240 253 244 / 0.5);
}

.bg-green-500{
    --tw-bg-opacity: 1;
    background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1));
}

.bg-green-500\/20{
    background-color: rgb(34 197 94 / 0.2);
}

.bg-green-600{
    --tw-bg-opacity: 1;
    background-color: rgb(22 163 74 / var(--tw-bg-opacity, 1));
}

.bg-green-900\/30{
    background-color: rgb(20 83 45 / 0.3);
}

.bg-indigo-100{
    --tw-bg-opacity: 1;
    background-color: rgb(224 231 255 / var(--tw-bg-opacity, 1));
}

.bg-indigo-50{
    --tw-bg-opacity: 1;
    background-color: rgb(238 242 255 / var(--tw-bg-opacity, 1));
}

.bg-indigo-500\/20{
    background-color: rgb(99 102 241 / 0.2);
}

.bg-lime-50{
    --tw-bg-opacity: 1;
    background-color: rgb(247 254 231 / var(--tw-bg-opacity, 1));
}

.bg-muted{
    background-color: hsl(var(--muted));
}

.bg-muted-foreground\/30{
    background-color: hsl(var(--muted-foreground) / 0.3);
}

.bg-muted-foreground\/50{
    background-color: hsl(var(--muted-foreground) / 0.5);
}

.bg-muted\/20{
    background-color: hsl(var(--muted) / 0.2);
}

.bg-muted\/30{
    background-color: hsl(var(--muted) / 0.3);
}

.bg-muted\/50{
    background-color: hsl(var(--muted) / 0.5);
}

.bg-muted\/80{
    background-color: hsl(var(--muted) / 0.8);
}

.bg-orange-100{
    --tw-bg-opacity: 1;
    background-color: rgb(255 237 213 / var(--tw-bg-opacity, 1));
}

.bg-orange-50{
    --tw-bg-opacity: 1;
    background-color: rgb(255 247 237 / var(--tw-bg-opacity, 1));
}

.bg-orange-50\/50{
    background-color: rgb(255 247 237 / 0.5);
}

.bg-orange-500{
    --tw-bg-opacity: 1;
    background-color: rgb(249 115 22 / var(--tw-bg-opacity, 1));
}

.bg-orange-500\/10{
    background-color: rgb(249 115 22 / 0.1);
}

.bg-orange-500\/20{
    background-color: rgb(249 115 22 / 0.2);
}

.bg-orange-500\/5{
    background-color: rgb(249 115 22 / 0.05);
}

.bg-orange-600{
    --tw-bg-opacity: 1;
    background-color: rgb(234 88 12 / var(--tw-bg-opacity, 1));
}

.bg-orange-600\/70{
    background-color: rgb(234 88 12 / 0.7);
}

.bg-orange-600\/90{
    background-color: rgb(234 88 12 / 0.9);
}

.bg-pink-100{
    --tw-bg-opacity: 1;
    background-color: rgb(252 231 243 / var(--tw-bg-opacity, 1));
}

.bg-pink-50{
    --tw-bg-opacity: 1;
    background-color: rgb(253 242 248 / var(--tw-bg-opacity, 1));
}

.bg-popover{
    background-color: hsl(var(--popover));
}

.bg-primary{
    background-color: hsl(var(--primary));
}

.bg-primary\/10{
    background-color: hsl(var(--primary) / 0.1);
}

.bg-primary\/15{
    background-color: hsl(var(--primary) / 0.15);
}

.bg-primary\/20{
    background-color: hsl(var(--primary) / 0.2);
}

.bg-primary\/30{
    background-color: hsl(var(--primary) / 0.3);
}

.bg-primary\/5{
    background-color: hsl(var(--primary) / 0.05);
}

.bg-primary\/90{
    background-color: hsl(var(--primary) / 0.9);
}

.bg-purple-100{
    --tw-bg-opacity: 1;
    background-color: rgb(243 232 255 / var(--tw-bg-opacity, 1));
}

.bg-purple-50{
    --tw-bg-opacity: 1;
    background-color: rgb(250 245 255 / var(--tw-bg-opacity, 1));
}

.bg-purple-500{
    --tw-bg-opacity: 1;
    background-color: rgb(168 85 247 / var(--tw-bg-opacity, 1));
}

.bg-purple-500\/20{
    background-color: rgb(168 85 247 / 0.2);
}

.bg-purple-600{
    --tw-bg-opacity: 1;
    background-color: rgb(147 51 234 / var(--tw-bg-opacity, 1));
}

.bg-purple-700\/20{
    background-color: rgb(126 34 206 / 0.2);
}

.bg-purple-900\/30{
    background-color: rgb(88 28 135 / 0.3);
}

.bg-red-100{
    --tw-bg-opacity: 1;
    background-color: rgb(254 226 226 / var(--tw-bg-opacity, 1));
}

.bg-red-400{
    --tw-bg-opacity: 1;
    background-color: rgb(248 113 113 / var(--tw-bg-opacity, 1));
}

.bg-red-50{
    --tw-bg-opacity: 1;
    background-color: rgb(254 242 242 / var(--tw-bg-opacity, 1));
}

.bg-red-500{
    --tw-bg-opacity: 1;
    background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}

.bg-red-500\/80{
    background-color: rgb(239 68 68 / 0.8);
}

.bg-red-600{
    --tw-bg-opacity: 1;
    background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1));
}

.bg-rose-50{
    --tw-bg-opacity: 1;
    background-color: rgb(255 241 242 / var(--tw-bg-opacity, 1));
}

.bg-rose-500\/20{
    background-color: rgb(244 63 94 / 0.2);
}

.bg-secondary{
    background-color: hsl(var(--secondary));
}

.bg-secondary\/10{
    background-color: hsl(var(--secondary) / 0.1);
}

.bg-secondary\/50{
    background-color: hsl(var(--secondary) / 0.5);
}

.bg-sidebar{
    background-color: hsl(var(--sidebar-background));
}

.bg-sidebar-border{
    background-color: hsl(var(--sidebar-border));
}

.bg-sky-50{
    --tw-bg-opacity: 1;
    background-color: rgb(240 249 255 / var(--tw-bg-opacity, 1));
}

.bg-slate-100{
    --tw-bg-opacity: 1;
    background-color: rgb(241 245 249 / var(--tw-bg-opacity, 1));
}

.bg-slate-50{
    --tw-bg-opacity: 1;
    background-color: rgb(248 250 252 / var(--tw-bg-opacity, 1));
}

.bg-teal-100{
    --tw-bg-opacity: 1;
    background-color: rgb(204 251 241 / var(--tw-bg-opacity, 1));
}

.bg-teal-50{
    --tw-bg-opacity: 1;
    background-color: rgb(240 253 250 / var(--tw-bg-opacity, 1));
}

.bg-transparent{
    background-color: transparent;
}

.bg-violet-100{
    --tw-bg-opacity: 1;
    background-color: rgb(237 233 254 / var(--tw-bg-opacity, 1));
}

.bg-violet-50{
    --tw-bg-opacity: 1;
    background-color: rgb(245 243 255 / var(--tw-bg-opacity, 1));
}

.bg-white{
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.bg-white\/10{
    background-color: rgb(255 255 255 / 0.1);
}

.bg-white\/20{
    background-color: rgb(255 255 255 / 0.2);
}

.bg-white\/30{
    background-color: rgb(255 255 255 / 0.3);
}

.bg-white\/40{
    background-color: rgb(255 255 255 / 0.4);
}

.bg-white\/5{
    background-color: rgb(255 255 255 / 0.05);
}

.bg-white\/60{
    background-color: rgb(255 255 255 / 0.6);
}

.bg-white\/80{
    background-color: rgb(255 255 255 / 0.8);
}

.bg-white\/90{
    background-color: rgb(255 255 255 / 0.9);
}

.bg-white\/95{
    background-color: rgb(255 255 255 / 0.95);
}

.bg-yellow-100{
    --tw-bg-opacity: 1;
    background-color: rgb(254 249 195 / var(--tw-bg-opacity, 1));
}

.bg-yellow-50{
    --tw-bg-opacity: 1;
    background-color: rgb(254 252 232 / var(--tw-bg-opacity, 1));
}

.bg-yellow-500{
    --tw-bg-opacity: 1;
    background-color: rgb(234 179 8 / var(--tw-bg-opacity, 1));
}

.bg-yellow-500\/20{
    background-color: rgb(234 179 8 / 0.2);
}

.bg-zinc-100{
    --tw-bg-opacity: 1;
    background-color: rgb(244 244 245 / var(--tw-bg-opacity, 1));
}

.bg-opacity-20{
    --tw-bg-opacity: 0.2;
}

.bg-opacity-50{
    --tw-bg-opacity: 0.5;
}

.bg-opacity-75{
    --tw-bg-opacity: 0.75;
}

.bg-\[conic-gradient\(from_0deg\2c rgba\(255\2c 255\2c 255\2c 0\.4\)\2c transparent_120deg\2c rgba\(255\2c 255\2c 255\2c 0\.4\)_240deg\2c transparent\)\]{
    background-image: conic-gradient(from 0deg,rgba(255,255,255,0.4),transparent 120deg,rgba(255,255,255,0.4) 240deg,transparent);
}

.bg-\[linear-gradient\(45deg\2c transparent_25\%\2c rgba\(255\2c 255\2c 255\2c 0\.4\)_25\%\2c rgba\(255\2c 255\2c 255\2c 0\.4\)_50\%\2c transparent_50\%\2c transparent_75\%\2c rgba\(255\2c 255\2c 255\2c 0\.4\)_75\%\)\]{
    background-image: linear-gradient(45deg,transparent 25%,rgba(255,255,255,0.4) 25%,rgba(255,255,255,0.4) 50%,transparent 50%,transparent 75%,rgba(255,255,255,0.4) 75%);
}

.bg-\[radial-gradient\(circle_at_50\%_120\%\2c rgba\(255\2c 255\2c 255\2c 0\.3\)\2c transparent\)\]{
    background-image: radial-gradient(circle at 50% 120%,rgba(255,255,255,0.3),transparent);
}

.bg-\[radial-gradient\(ellipse_at_top\2c rgba\(255\2c 255\2c 255\2c 0\.5\)\2c transparent_50\%\)\]{
    background-image: radial-gradient(ellipse at top,rgba(255,255,255,0.5),transparent 50%);
}

.bg-gradient-to-b{
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}

.bg-gradient-to-br{
    background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
}

.bg-gradient-to-r{
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.bg-gradient-to-t{
    background-image: linear-gradient(to top, var(--tw-gradient-stops));
}

.from-amber-300{
    --tw-gradient-from: #fcd34d var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(252 211 77 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-amber-500{
    --tw-gradient-from: #f59e0b var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(245 158 11 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-background{
    --tw-gradient-from: hsl(var(--background)) var(--tw-gradient-from-position);
    --tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-background\/50{
    --tw-gradient-from: hsl(var(--background) / 0.5) var(--tw-gradient-from-position);
    --tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-black\/20{
    --tw-gradient-from: rgb(0 0 0 / 0.2) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-black\/60{
    --tw-gradient-from: rgb(0 0 0 / 0.6) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-black\/70{
    --tw-gradient-from: rgb(0 0 0 / 0.7) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-black\/80{
    --tw-gradient-from: rgb(0 0 0 / 0.8) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-blue-200{
    --tw-gradient-from: #bfdbfe var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(191 219 254 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-blue-400{
    --tw-gradient-from: #60a5fa var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(96 165 250 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-blue-50{
    --tw-gradient-from: #eff6ff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(239 246 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-blue-500{
    --tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-blue-500\/5{
    --tw-gradient-from: rgb(59 130 246 / 0.05) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-blue-600{
    --tw-gradient-from: #2563eb var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(37 99 235 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-cyan-300{
    --tw-gradient-from: #67e8f9 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(103 232 249 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-cyan-500{
    --tw-gradient-from: #06b6d4 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(6 182 212 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-emerald-400{
    --tw-gradient-from: #34d399 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(52 211 153 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-emerald-500{
    --tw-gradient-from: #10b981 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(16 185 129 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-emerald-500\/20{
    --tw-gradient-from: rgb(16 185 129 / 0.2) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(16 185 129 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-100{
    --tw-gradient-from: #f3f4f6 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(243 244 246 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-200{
    --tw-gradient-from: #e5e7eb var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(229 231 235 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-300{
    --tw-gradient-from: #d1d5db var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(209 213 219 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-400{
    --tw-gradient-from: #9ca3af var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(156 163 175 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-50{
    --tw-gradient-from: #f9fafb var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(249 250 251 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-600{
    --tw-gradient-from: #4b5563 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(75 85 99 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-gray-800{
    --tw-gradient-from: #1f2937 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(31 41 55 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-green-400{
    --tw-gradient-from: #4ade80 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(74 222 128 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-green-50{
    --tw-gradient-from: #f0fdf4 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(240 253 244 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-green-500{
    --tw-gradient-from: #22c55e var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(34 197 94 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-green-600{
    --tw-gradient-from: #16a34a var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(22 163 74 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-indigo-500{
    --tw-gradient-from: #6366f1 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-indigo-500\/10{
    --tw-gradient-from: rgb(99 102 241 / 0.1) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-indigo-900{
    --tw-gradient-from: #312e81 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(49 46 129 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-muted{
    --tw-gradient-from: hsl(var(--muted)) var(--tw-gradient-from-position);
    --tw-gradient-to: hsl(var(--muted) / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-50\/50{
    --tw-gradient-from: rgb(255 247 237 / 0.5) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(255 247 237 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-500{
    --tw-gradient-from: #f97316 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(249 115 22 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-500\/10{
    --tw-gradient-from: rgb(249 115 22 / 0.1) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(249 115 22 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-500\/20{
    --tw-gradient-from: rgb(249 115 22 / 0.2) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(249 115 22 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-500\/5{
    --tw-gradient-from: rgb(249 115 22 / 0.05) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(249 115 22 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-orange-600{
    --tw-gradient-from: #ea580c var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(234 88 12 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-pink-400{
    --tw-gradient-from: #f472b6 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(244 114 182 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-pink-50{
    --tw-gradient-from: #fdf2f8 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(253 242 248 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-pink-50\/50{
    --tw-gradient-from: rgb(253 242 248 / 0.5) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(253 242 248 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-pink-500{
    --tw-gradient-from: #ec4899 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(236 72 153 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary{
    --tw-gradient-from: hsl(var(--primary)) var(--tw-gradient-from-position);
    --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/10{
    --tw-gradient-from: hsl(var(--primary) / 0.1) var(--tw-gradient-from-position);
    --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/20{
    --tw-gradient-from: hsl(var(--primary) / 0.2) var(--tw-gradient-from-position);
    --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-primary\/5{
    --tw-gradient-from: hsl(var(--primary) / 0.05) var(--tw-gradient-from-position);
    --tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-100{
    --tw-gradient-from: #f3e8ff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(243 232 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-400{
    --tw-gradient-from: #c084fc var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(192 132 252 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-50{
    --tw-gradient-from: #faf5ff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(250 245 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-50\/50{
    --tw-gradient-from: rgb(250 245 255 / 0.5) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(250 245 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-500{
    --tw-gradient-from: #a855f7 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(168 85 247 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-500\/20{
    --tw-gradient-from: rgb(168 85 247 / 0.2) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(168 85 247 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-600{
    --tw-gradient-from: #9333ea var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(147 51 234 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-600\/5{
    --tw-gradient-from: rgb(147 51 234 / 0.05) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(147 51 234 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-800{
    --tw-gradient-from: #6b21a8 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(107 33 168 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-red-400{
    --tw-gradient-from: #f87171 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(248 113 113 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-red-500{
    --tw-gradient-from: #ef4444 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(239 68 68 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-slate-500{
    --tw-gradient-from: #64748b var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(100 116 139 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-teal-500{
    --tw-gradient-from: #14b8a6 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(20 184 166 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-transparent{
    --tw-gradient-from: transparent var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-violet-500{
    --tw-gradient-from: #8b5cf6 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(139 92 246 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-white\/40{
    --tw-gradient-from: rgb(255 255 255 / 0.4) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-yellow-400{
    --tw-gradient-from: #facc15 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(250 204 21 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-yellow-500{
    --tw-gradient-from: #eab308 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(234 179 8 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-yellow-500\/10{
    --tw-gradient-from: rgb(234 179 8 / 0.1) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(234 179 8 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.via-black\/20{
    --tw-gradient-to: rgb(0 0 0 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), rgb(0 0 0 / 0.2) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-black\/40{
    --tw-gradient-to: rgb(0 0 0 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), rgb(0 0 0 / 0.4) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-blue-200{
    --tw-gradient-to: rgb(191 219 254 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #bfdbfe var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-blue-600{
    --tw-gradient-to: rgb(37 99 235 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #2563eb var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-emerald-400{
    --tw-gradient-to: rgb(52 211 153 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #34d399 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-gray-500{
    --tw-gradient-to: rgb(107 114 128 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #6b7280 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-green-400{
    --tw-gradient-to: rgb(74 222 128 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #4ade80 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-muted-foreground\/20{
    --tw-gradient-to: hsl(var(--muted-foreground) / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--muted-foreground) / 0.2) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-orange-400{
    --tw-gradient-to: rgb(251 146 60 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #fb923c var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-pink-500{
    --tw-gradient-to: rgb(236 72 153 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #ec4899 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-pink-500\/10{
    --tw-gradient-to: rgb(236 72 153 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), rgb(236 72 153 / 0.1) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-purple-500{
    --tw-gradient-to: rgb(168 85 247 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #a855f7 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-purple-600{
    --tw-gradient-to: rgb(147 51 234 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #9333ea var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-purple-800{
    --tw-gradient-to: rgb(107 33 168 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #6b21a8 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-purple-900{
    --tw-gradient-to: rgb(88 28 135 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #581c87 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-red-500{
    --tw-gradient-to: rgb(239 68 68 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #ef4444 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-red-500\/5{
    --tw-gradient-to: rgb(239 68 68 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), rgb(239 68 68 / 0.05) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-secondary\/5{
    --tw-gradient-to: hsl(var(--secondary) / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), hsl(var(--secondary) / 0.05) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-transparent{
    --tw-gradient-to: rgb(0 0 0 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), transparent var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-white{
    --tw-gradient-to: rgb(255 255 255 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #fff var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-yellow-400{
    --tw-gradient-to: rgb(250 204 21 / 0)  var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), #facc15 var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.to-accent{
    --tw-gradient-to: hsl(var(--accent)) var(--tw-gradient-to-position);
}

.to-accent\/10{
    --tw-gradient-to: hsl(var(--accent) / 0.1) var(--tw-gradient-to-position);
}

.to-accent\/20{
    --tw-gradient-to: hsl(var(--accent) / 0.2) var(--tw-gradient-to-position);
}

.to-accent\/5{
    --tw-gradient-to: hsl(var(--accent) / 0.05) var(--tw-gradient-to-position);
}

.to-amber-500{
    --tw-gradient-to: #f59e0b var(--tw-gradient-to-position);
}

.to-amber-500\/10{
    --tw-gradient-to: rgb(245 158 11 / 0.1) var(--tw-gradient-to-position);
}

.to-black{
    --tw-gradient-to: #000 var(--tw-gradient-to-position);
}

.to-blue-100{
    --tw-gradient-to: #dbeafe var(--tw-gradient-to-position);
}

.to-blue-300{
    --tw-gradient-to: #93c5fd var(--tw-gradient-to-position);
}

.to-blue-50{
    --tw-gradient-to: #eff6ff var(--tw-gradient-to-position);
}

.to-blue-500{
    --tw-gradient-to: #3b82f6 var(--tw-gradient-to-position);
}

.to-blue-600{
    --tw-gradient-to: #2563eb var(--tw-gradient-to-position);
}

.to-blue-600\/5{
    --tw-gradient-to: rgb(37 99 235 / 0.05) var(--tw-gradient-to-position);
}

.to-blue-900{
    --tw-gradient-to: #1e3a8a var(--tw-gradient-to-position);
}

.to-cyan-500{
    --tw-gradient-to: #06b6d4 var(--tw-gradient-to-position);
}

.to-cyan-500\/5{
    --tw-gradient-to: rgb(6 182 212 / 0.05) var(--tw-gradient-to-position);
}

.to-emerald-500{
    --tw-gradient-to: #10b981 var(--tw-gradient-to-position);
}

.to-emerald-600{
    --tw-gradient-to: #059669 var(--tw-gradient-to-position);
}

.to-emerald-600\/30{
    --tw-gradient-to: rgb(5 150 105 / 0.3) var(--tw-gradient-to-position);
}

.to-gray-100{
    --tw-gradient-to: #f3f4f6 var(--tw-gradient-to-position);
}

.to-gray-200{
    --tw-gradient-to: #e5e7eb var(--tw-gradient-to-position);
}

.to-gray-300{
    --tw-gradient-to: #d1d5db var(--tw-gradient-to-position);
}

.to-gray-400{
    --tw-gradient-to: #9ca3af var(--tw-gradient-to-position);
}

.to-gray-500{
    --tw-gradient-to: #6b7280 var(--tw-gradient-to-position);
}

.to-gray-600{
    --tw-gradient-to: #4b5563 var(--tw-gradient-to-position);
}

.to-green-500{
    --tw-gradient-to: #22c55e var(--tw-gradient-to-position);
}

.to-indigo-500{
    --tw-gradient-to: #6366f1 var(--tw-gradient-to-position);
}

.to-indigo-600{
    --tw-gradient-to: #4f46e5 var(--tw-gradient-to-position);
}

.to-muted{
    --tw-gradient-to: hsl(var(--muted)) var(--tw-gradient-to-position);
}

.to-muted-foreground\/20{
    --tw-gradient-to: hsl(var(--muted-foreground) / 0.2) var(--tw-gradient-to-position);
}

.to-muted\/20{
    --tw-gradient-to: hsl(var(--muted) / 0.2) var(--tw-gradient-to-position);
}

.to-orange-400{
    --tw-gradient-to: #fb923c var(--tw-gradient-to-position);
}

.to-orange-500{
    --tw-gradient-to: #f97316 var(--tw-gradient-to-position);
}

.to-pink-100{
    --tw-gradient-to: #fce7f3 var(--tw-gradient-to-position);
}

.to-pink-400{
    --tw-gradient-to: #f472b6 var(--tw-gradient-to-position);
}

.to-pink-50{
    --tw-gradient-to: #fdf2f8 var(--tw-gradient-to-position);
}

.to-pink-50\/50{
    --tw-gradient-to: rgb(253 242 248 / 0.5) var(--tw-gradient-to-position);
}

.to-pink-500{
    --tw-gradient-to: #ec4899 var(--tw-gradient-to-position);
}

.to-pink-500\/20{
    --tw-gradient-to: rgb(236 72 153 / 0.2) var(--tw-gradient-to-position);
}

.to-pink-600{
    --tw-gradient-to: #db2777 var(--tw-gradient-to-position);
}

.to-primary\/5{
    --tw-gradient-to: hsl(var(--primary) / 0.05) var(--tw-gradient-to-position);
}

.to-primary\/70{
    --tw-gradient-to: hsl(var(--primary) / 0.7) var(--tw-gradient-to-position);
}

.to-purple-50{
    --tw-gradient-to: #faf5ff var(--tw-gradient-to-position);
}

.to-purple-500{
    --tw-gradient-to: #a855f7 var(--tw-gradient-to-position);
}

.to-purple-500\/10{
    --tw-gradient-to: rgb(168 85 247 / 0.1) var(--tw-gradient-to-position);
}

.to-purple-500\/5{
    --tw-gradient-to: rgb(168 85 247 / 0.05) var(--tw-gradient-to-position);
}

.to-purple-600{
    --tw-gradient-to: #9333ea var(--tw-gradient-to-position);
}

.to-purple-700{
    --tw-gradient-to: #7e22ce var(--tw-gradient-to-position);
}

.to-purple-900{
    --tw-gradient-to: #581c87 var(--tw-gradient-to-position);
}

.to-red-400{
    --tw-gradient-to: #f87171 var(--tw-gradient-to-position);
}

.to-red-500\/10{
    --tw-gradient-to: rgb(239 68 68 / 0.1) var(--tw-gradient-to-position);
}

.to-red-600{
    --tw-gradient-to: #dc2626 var(--tw-gradient-to-position);
}

.to-red-700{
    --tw-gradient-to: #b91c1c var(--tw-gradient-to-position);
}

.to-rose-500{
    --tw-gradient-to: #f43f5e var(--tw-gradient-to-position);
}

.to-rose-600{
    --tw-gradient-to: #e11d48 var(--tw-gradient-to-position);
}

.to-secondary\/5{
    --tw-gradient-to: hsl(var(--secondary) / 0.05) var(--tw-gradient-to-position);
}

.to-slate-700{
    --tw-gradient-to: #334155 var(--tw-gradient-to-position);
}

.to-teal-500{
    --tw-gradient-to: #14b8a6 var(--tw-gradient-to-position);
}

.to-transparent{
    --tw-gradient-to: transparent var(--tw-gradient-to-position);
}

.to-yellow-500{
    --tw-gradient-to: #eab308 var(--tw-gradient-to-position);
}

.to-yellow-500\/5{
    --tw-gradient-to: rgb(234 179 8 / 0.05) var(--tw-gradient-to-position);
}

.to-yellow-600{
    --tw-gradient-to: #ca8a04 var(--tw-gradient-to-position);
}

.bg-\[length\:20px_20px\]{
    background-size: 20px 20px;
}

.bg-clip-text{
    -webkit-background-clip: text;
            background-clip: text;
}

.fill-amber-400{
    fill: #fbbf24;
}

.fill-amber-500{
    fill: #f59e0b;
}

.fill-current{
    fill: currentColor;
}

.fill-destructive{
    fill: hsl(var(--destructive));
}

.fill-popover{
    fill: hsl(var(--popover));
}

.fill-red-500{
    fill: #ef4444;
}

.fill-white{
    fill: #fff;
}

.fill-yellow-300{
    fill: #fde047;
}

.fill-yellow-400{
    fill: #facc15;
}

.fill-yellow-500{
    fill: #eab308;
}

.fill-yellow-950{
    fill: #422006;
}

.object-contain{
    -o-object-fit: contain;
       object-fit: contain;
}

.object-cover{
    -o-object-fit: cover;
       object-fit: cover;
}

.p-0{
    padding: 0px;
}

.p-0\.5{
    padding: 0.125rem;
}

.p-1{
    padding: 0.25rem;
}

.p-1\.5{
    padding: 0.375rem;
}

.p-12{
    padding: 3rem;
}

.p-2{
    padding: 0.5rem;
}

.p-2\.5{
    padding: 0.625rem;
}

.p-3{
    padding: 0.75rem;
}

.p-4{
    padding: 1rem;
}

.p-5{
    padding: 1.25rem;
}

.p-6{
    padding: 1.5rem;
}

.p-8{
    padding: 2rem;
}

.p-\[1px\]{
    padding: 1px;
}

.px-1{
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}

.px-1\.5{
    padding-left: 0.375rem;
    padding-right: 0.375rem;
}

.px-2{
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.px-2\.5{
    padding-left: 0.625rem;
    padding-right: 0.625rem;
}

.px-3{
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.px-4{
    padding-left: 1rem;
    padding-right: 1rem;
}

.px-5{
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.px-6{
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.px-8{
    padding-left: 2rem;
    padding-right: 2rem;
}

.py-0{
    padding-top: 0px;
    padding-bottom: 0px;
}

.py-0\.5{
    padding-top: 0.125rem;
    padding-bottom: 0.125rem;
}

.py-1{
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

.py-1\.5{
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}

.py-10{
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
}

.py-12{
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.py-16{
    padding-top: 4rem;
    padding-bottom: 4rem;
}

.py-2{
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.py-2\.5{
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
}

.py-3{
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.py-4{
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.py-6{
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

.py-8{
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.pb-0{
    padding-bottom: 0px;
}

.pb-1{
    padding-bottom: 0.25rem;
}

.pb-1\.5{
    padding-bottom: 0.375rem;
}

.pb-2{
    padding-bottom: 0.5rem;
}

.pb-20{
    padding-bottom: 5rem;
}

.pb-24{
    padding-bottom: 6rem;
}

.pb-28{
    padding-bottom: 7rem;
}

.pb-3{
    padding-bottom: 0.75rem;
}

.pb-32{
    padding-bottom: 8rem;
}

.pb-4{
    padding-bottom: 1rem;
}

.pb-6{
    padding-bottom: 1.5rem;
}

.pb-\[calc\(5rem\+env\(safe-area-inset-bottom\2c 8px\)\)\]{
    padding-bottom: calc(5rem + env(safe-area-inset-bottom,8px));
}

.pl-0{
    padding-left: 0px;
}

.pl-10{
    padding-left: 2.5rem;
}

.pl-2{
    padding-left: 0.5rem;
}

.pl-2\.5{
    padding-left: 0.625rem;
}

.pl-4{
    padding-left: 1rem;
}

.pl-6{
    padding-left: 1.5rem;
}

.pl-7{
    padding-left: 1.75rem;
}

.pl-8{
    padding-left: 2rem;
}

.pl-9{
    padding-left: 2.25rem;
}

.pr-1{
    padding-right: 0.25rem;
}

.pr-2{
    padding-right: 0.5rem;
}

.pr-2\.5{
    padding-right: 0.625rem;
}

.pr-4{
    padding-right: 1rem;
}

.pr-8{
    padding-right: 2rem;
}

.pr-9{
    padding-right: 2.25rem;
}

.pt-0{
    padding-top: 0px;
}

.pt-0\.5{
    padding-top: 0.125rem;
}

.pt-1{
    padding-top: 0.25rem;
}

.pt-16{
    padding-top: 4rem;
}

.pt-2{
    padding-top: 0.5rem;
}

.pt-3{
    padding-top: 0.75rem;
}

.pt-32{
    padding-top: 8rem;
}

.pt-4{
    padding-top: 1rem;
}

.pt-40{
    padding-top: 10rem;
}

.pt-5{
    padding-top: 1.25rem;
}

.pt-6{
    padding-top: 1.5rem;
}

.pt-8{
    padding-top: 2rem;
}

.pt-\[125\%\]{
    padding-top: 125%;
}

.text-left{
    text-align: left;
}

.text-center{
    text-align: center;
}

.text-right{
    text-align: right;
}

.align-middle{
    vertical-align: middle;
}

.font-mono{
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.text-2xl{
    font-size: 1.5rem;
    line-height: 2rem;
}

.text-3xl{
    font-size: 1.875rem;
    line-height: 2.25rem;
}

.text-4xl{
    font-size: 2.25rem;
    line-height: 2.5rem;
}

.text-5xl{
    font-size: 3rem;
    line-height: 1;
}

.text-6xl{
    font-size: 3.75rem;
    line-height: 1;
}

.text-\[0\.8rem\]{
    font-size: 0.8rem;
}

.text-\[10px\]{
    font-size: 10px;
}

.text-\[11px\]{
    font-size: 11px;
}

.text-\[13px\]{
    font-size: 13px;
}

.text-\[8px\]{
    font-size: 8px;
}

.text-\[9px\]{
    font-size: 9px;
}

.text-base{
    font-size: 1rem;
    line-height: 1.5rem;
}

.text-lg{
    font-size: 1.125rem;
    line-height: 1.75rem;
}

.text-sm{
    font-size: 0.875rem;
    line-height: 1.25rem;
}

.text-xl{
    font-size: 1.25rem;
    line-height: 1.75rem;
}

.text-xs{
    font-size: 0.75rem;
    line-height: 1rem;
}

.font-black{
    font-weight: 900;
}

.font-bold{
    font-weight: 700;
}

.font-light{
    font-weight: 300;
}

.font-medium{
    font-weight: 500;
}

.font-normal{
    font-weight: 400;
}

.font-semibold{
    font-weight: 600;
}

.uppercase{
    text-transform: uppercase;
}

.lowercase{
    text-transform: lowercase;
}

.capitalize{
    text-transform: capitalize;
}

.italic{
    font-style: italic;
}

.tabular-nums{
    --tw-numeric-spacing: tabular-nums;
    font-variant-numeric: var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);
}

.leading-none{
    line-height: 1;
}

.leading-normal{
    line-height: 1.5;
}

.leading-relaxed{
    line-height: 1.625;
}

.leading-snug{
    line-height: 1.375;
}

.leading-tight{
    line-height: 1.25;
}

.tracking-\[0\.15em\]{
    letter-spacing: 0.15em;
}

.tracking-tight{
    letter-spacing: -0.025em;
}

.tracking-wide{
    letter-spacing: 0.025em;
}

.tracking-wider{
    letter-spacing: 0.05em;
}

.tracking-widest{
    letter-spacing: 0.1em;
}

.text-accent{
    color: hsl(var(--accent));
}

.text-accent-foreground{
    color: hsl(var(--accent-foreground));
}

.text-amber-100{
    --tw-text-opacity: 1;
    color: rgb(254 243 199 / var(--tw-text-opacity, 1));
}

.text-amber-400{
    --tw-text-opacity: 1;
    color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.text-amber-500{
    --tw-text-opacity: 1;
    color: rgb(245 158 11 / var(--tw-text-opacity, 1));
}

.text-amber-600{
    --tw-text-opacity: 1;
    color: rgb(217 119 6 / var(--tw-text-opacity, 1));
}

.text-amber-700{
    --tw-text-opacity: 1;
    color: rgb(180 83 9 / var(--tw-text-opacity, 1));
}

.text-amber-800{
    --tw-text-opacity: 1;
    color: rgb(146 64 14 / var(--tw-text-opacity, 1));
}

.text-amber-900{
    --tw-text-opacity: 1;
    color: rgb(120 53 15 / var(--tw-text-opacity, 1));
}

.text-black{
    --tw-text-opacity: 1;
    color: rgb(0 0 0 / var(--tw-text-opacity, 1));
}

.text-blue-100{
    --tw-text-opacity: 1;
    color: rgb(219 234 254 / var(--tw-text-opacity, 1));
}

.text-blue-400{
    --tw-text-opacity: 1;
    color: rgb(96 165 250 / var(--tw-text-opacity, 1));
}

.text-blue-500{
    --tw-text-opacity: 1;
    color: rgb(59 130 246 / var(--tw-text-opacity, 1));
}

.text-blue-600{
    --tw-text-opacity: 1;
    color: rgb(37 99 235 / var(--tw-text-opacity, 1));
}

.text-blue-700{
    --tw-text-opacity: 1;
    color: rgb(29 78 216 / var(--tw-text-opacity, 1));
}

.text-blue-800{
    --tw-text-opacity: 1;
    color: rgb(30 64 175 / var(--tw-text-opacity, 1));
}

.text-blue-900{
    --tw-text-opacity: 1;
    color: rgb(30 58 138 / var(--tw-text-opacity, 1));
}

.text-card-foreground{
    color: hsl(var(--card-foreground));
}

.text-current{
    color: currentColor;
}

.text-cyan-500{
    --tw-text-opacity: 1;
    color: rgb(6 182 212 / var(--tw-text-opacity, 1));
}

.text-cyan-700{
    --tw-text-opacity: 1;
    color: rgb(14 116 144 / var(--tw-text-opacity, 1));
}

.text-cyan-800{
    --tw-text-opacity: 1;
    color: rgb(21 94 117 / var(--tw-text-opacity, 1));
}

.text-destructive{
    color: hsl(var(--destructive));
}

.text-destructive-foreground{
    color: hsl(var(--destructive-foreground));
}

.text-emerald-300{
    --tw-text-opacity: 1;
    color: rgb(110 231 183 / var(--tw-text-opacity, 1));
}

.text-emerald-400{
    --tw-text-opacity: 1;
    color: rgb(52 211 153 / var(--tw-text-opacity, 1));
}

.text-emerald-500{
    --tw-text-opacity: 1;
    color: rgb(16 185 129 / var(--tw-text-opacity, 1));
}

.text-emerald-600{
    --tw-text-opacity: 1;
    color: rgb(5 150 105 / var(--tw-text-opacity, 1));
}

.text-emerald-700{
    --tw-text-opacity: 1;
    color: rgb(4 120 87 / var(--tw-text-opacity, 1));
}

.text-foreground{
    color: hsl(var(--foreground));
}

.text-foreground\/50{
    color: hsl(var(--foreground) / 0.5);
}

.text-foreground\/70{
    color: hsl(var(--foreground) / 0.7);
}

.text-foreground\/90{
    color: hsl(var(--foreground) / 0.9);
}

.text-fuchsia-500{
    --tw-text-opacity: 1;
    color: rgb(217 70 239 / var(--tw-text-opacity, 1));
}

.text-fuchsia-800{
    --tw-text-opacity: 1;
    color: rgb(134 25 143 / var(--tw-text-opacity, 1));
}

.text-gray-100{
    --tw-text-opacity: 1;
    color: rgb(243 244 246 / var(--tw-text-opacity, 1));
}

.text-gray-300{
    --tw-text-opacity: 1;
    color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}

.text-gray-400{
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}

.text-gray-500{
    --tw-text-opacity: 1;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}

.text-gray-600{
    --tw-text-opacity: 1;
    color: rgb(75 85 99 / var(--tw-text-opacity, 1));
}

.text-gray-700{
    --tw-text-opacity: 1;
    color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}

.text-gray-800{
    --tw-text-opacity: 1;
    color: rgb(31 41 55 / var(--tw-text-opacity, 1));
}

.text-gray-900{
    --tw-text-opacity: 1;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1));
}

.text-green-300{
    --tw-text-opacity: 1;
    color: rgb(134 239 172 / var(--tw-text-opacity, 1));
}

.text-green-400{
    --tw-text-opacity: 1;
    color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}

.text-green-500{
    --tw-text-opacity: 1;
    color: rgb(34 197 94 / var(--tw-text-opacity, 1));
}

.text-green-600{
    --tw-text-opacity: 1;
    color: rgb(22 163 74 / var(--tw-text-opacity, 1));
}

.text-green-700{
    --tw-text-opacity: 1;
    color: rgb(21 128 61 / var(--tw-text-opacity, 1));
}

.text-green-800{
    --tw-text-opacity: 1;
    color: rgb(22 101 52 / var(--tw-text-opacity, 1));
}

.text-green-900{
    --tw-text-opacity: 1;
    color: rgb(20 83 45 / var(--tw-text-opacity, 1));
}

.text-indigo-500{
    --tw-text-opacity: 1;
    color: rgb(99 102 241 / var(--tw-text-opacity, 1));
}

.text-indigo-800{
    --tw-text-opacity: 1;
    color: rgb(55 48 163 / var(--tw-text-opacity, 1));
}

.text-lime-500{
    --tw-text-opacity: 1;
    color: rgb(132 204 22 / var(--tw-text-opacity, 1));
}

.text-muted-foreground{
    color: hsl(var(--muted-foreground));
}

.text-muted-foreground\/40{
    color: hsl(var(--muted-foreground) / 0.4);
}

.text-muted-foreground\/50{
    color: hsl(var(--muted-foreground) / 0.5);
}

.text-muted-foreground\/60{
    color: hsl(var(--muted-foreground) / 0.6);
}

.text-orange-300{
    --tw-text-opacity: 1;
    color: rgb(253 186 116 / var(--tw-text-opacity, 1));
}

.text-orange-400{
    --tw-text-opacity: 1;
    color: rgb(251 146 60 / var(--tw-text-opacity, 1));
}

.text-orange-50{
    --tw-text-opacity: 1;
    color: rgb(255 247 237 / var(--tw-text-opacity, 1));
}

.text-orange-500{
    --tw-text-opacity: 1;
    color: rgb(249 115 22 / var(--tw-text-opacity, 1));
}

.text-orange-600{
    --tw-text-opacity: 1;
    color: rgb(234 88 12 / var(--tw-text-opacity, 1));
}

.text-orange-700{
    --tw-text-opacity: 1;
    color: rgb(194 65 12 / var(--tw-text-opacity, 1));
}

.text-orange-800{
    --tw-text-opacity: 1;
    color: rgb(154 52 18 / var(--tw-text-opacity, 1));
}

.text-orange-900{
    --tw-text-opacity: 1;
    color: rgb(124 45 18 / var(--tw-text-opacity, 1));
}

.text-pink-500{
    --tw-text-opacity: 1;
    color: rgb(236 72 153 / var(--tw-text-opacity, 1));
}

.text-pink-600{
    --tw-text-opacity: 1;
    color: rgb(219 39 119 / var(--tw-text-opacity, 1));
}

.text-pink-800{
    --tw-text-opacity: 1;
    color: rgb(157 23 77 / var(--tw-text-opacity, 1));
}

.text-popover-foreground{
    color: hsl(var(--popover-foreground));
}

.text-primary{
    color: hsl(var(--primary));
}

.text-primary-foreground{
    color: hsl(var(--primary-foreground));
}

.text-primary-foreground\/70{
    color: hsl(var(--primary-foreground) / 0.7);
}

.text-primary\/80{
    color: hsl(var(--primary) / 0.8);
}

.text-purple-200{
    --tw-text-opacity: 1;
    color: rgb(233 213 255 / var(--tw-text-opacity, 1));
}

.text-purple-300{
    --tw-text-opacity: 1;
    color: rgb(216 180 254 / var(--tw-text-opacity, 1));
}

.text-purple-400{
    --tw-text-opacity: 1;
    color: rgb(192 132 252 / var(--tw-text-opacity, 1));
}

.text-purple-50{
    --tw-text-opacity: 1;
    color: rgb(250 245 255 / var(--tw-text-opacity, 1));
}

.text-purple-500{
    --tw-text-opacity: 1;
    color: rgb(168 85 247 / var(--tw-text-opacity, 1));
}

.text-purple-600{
    --tw-text-opacity: 1;
    color: rgb(147 51 234 / var(--tw-text-opacity, 1));
}

.text-purple-700{
    --tw-text-opacity: 1;
    color: rgb(126 34 206 / var(--tw-text-opacity, 1));
}

.text-purple-800{
    --tw-text-opacity: 1;
    color: rgb(107 33 168 / var(--tw-text-opacity, 1));
}

.text-purple-900{
    --tw-text-opacity: 1;
    color: rgb(88 28 135 / var(--tw-text-opacity, 1));
}

.text-red-300{
    --tw-text-opacity: 1;
    color: rgb(252 165 165 / var(--tw-text-opacity, 1));
}

.text-red-400{
    --tw-text-opacity: 1;
    color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.text-red-500{
    --tw-text-opacity: 1;
    color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}

.text-red-600{
    --tw-text-opacity: 1;
    color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}

.text-red-700{
    --tw-text-opacity: 1;
    color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}

.text-red-800{
    --tw-text-opacity: 1;
    color: rgb(153 27 27 / var(--tw-text-opacity, 1));
}

.text-red-900{
    --tw-text-opacity: 1;
    color: rgb(127 29 29 / var(--tw-text-opacity, 1));
}

.text-rose-500{
    --tw-text-opacity: 1;
    color: rgb(244 63 94 / var(--tw-text-opacity, 1));
}

.text-rose-700{
    --tw-text-opacity: 1;
    color: rgb(190 18 60 / var(--tw-text-opacity, 1));
}

.text-secondary-foreground{
    color: hsl(var(--secondary-foreground));
}

.text-sidebar-foreground{
    color: hsl(var(--sidebar-foreground));
}

.text-sidebar-foreground\/70{
    color: hsl(var(--sidebar-foreground) / 0.7);
}

.text-sky-500{
    --tw-text-opacity: 1;
    color: rgb(14 165 233 / var(--tw-text-opacity, 1));
}

.text-slate-500{
    --tw-text-opacity: 1;
    color: rgb(100 116 139 / var(--tw-text-opacity, 1));
}

.text-slate-800{
    --tw-text-opacity: 1;
    color: rgb(30 41 59 / var(--tw-text-opacity, 1));
}

.text-teal-500{
    --tw-text-opacity: 1;
    color: rgb(20 184 166 / var(--tw-text-opacity, 1));
}

.text-teal-800{
    --tw-text-opacity: 1;
    color: rgb(17 94 89 / var(--tw-text-opacity, 1));
}

.text-transparent{
    color: transparent;
}

.text-violet-500{
    --tw-text-opacity: 1;
    color: rgb(139 92 246 / var(--tw-text-opacity, 1));
}

.text-violet-800{
    --tw-text-opacity: 1;
    color: rgb(91 33 182 / var(--tw-text-opacity, 1));
}

.text-white{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.text-white\/50{
    color: rgb(255 255 255 / 0.5);
}

.text-white\/60{
    color: rgb(255 255 255 / 0.6);
}

.text-white\/70{
    color: rgb(255 255 255 / 0.7);
}

.text-white\/80{
    color: rgb(255 255 255 / 0.8);
}

.text-white\/90{
    color: rgb(255 255 255 / 0.9);
}

.text-yellow-100{
    --tw-text-opacity: 1;
    color: rgb(254 249 195 / var(--tw-text-opacity, 1));
}

.text-yellow-100\/70{
    color: rgb(254 249 195 / 0.7);
}

.text-yellow-200{
    --tw-text-opacity: 1;
    color: rgb(254 240 138 / var(--tw-text-opacity, 1));
}

.text-yellow-300{
    --tw-text-opacity: 1;
    color: rgb(253 224 71 / var(--tw-text-opacity, 1));
}

.text-yellow-400{
    --tw-text-opacity: 1;
    color: rgb(250 204 21 / var(--tw-text-opacity, 1));
}

.text-yellow-500{
    --tw-text-opacity: 1;
    color: rgb(234 179 8 / var(--tw-text-opacity, 1));
}

.text-yellow-600{
    --tw-text-opacity: 1;
    color: rgb(202 138 4 / var(--tw-text-opacity, 1));
}

.text-yellow-700{
    --tw-text-opacity: 1;
    color: rgb(161 98 7 / var(--tw-text-opacity, 1));
}

.text-yellow-800{
    --tw-text-opacity: 1;
    color: rgb(133 77 14 / var(--tw-text-opacity, 1));
}

.text-yellow-900{
    --tw-text-opacity: 1;
    color: rgb(113 63 18 / var(--tw-text-opacity, 1));
}

.text-yellow-950{
    --tw-text-opacity: 1;
    color: rgb(66 32 6 / var(--tw-text-opacity, 1));
}

.text-zinc-800{
    --tw-text-opacity: 1;
    color: rgb(39 39 42 / var(--tw-text-opacity, 1));
}

.underline{
    text-decoration-line: underline;
}

.no-underline{
    text-decoration-line: none;
}

.underline-offset-4{
    text-underline-offset: 4px;
}

.opacity-0{
    opacity: 0;
}

.opacity-10{
    opacity: 0.1;
}

.opacity-100{
    opacity: 1;
}

.opacity-20{
    opacity: 0.2;
}

.opacity-30{
    opacity: 0.3;
}

.opacity-40{
    opacity: 0.4;
}

.opacity-50{
    opacity: 0.5;
}

.opacity-60{
    opacity: 0.6;
}

.opacity-70{
    opacity: 0.7;
}

.opacity-75{
    opacity: 0.75;
}

.opacity-80{
    opacity: 0.8;
}

.opacity-90{
    opacity: 0.9;
}

.shadow{
    --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-2xl{
    --tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\]{
    --tw-shadow: 0 0 0 1px hsl(var(--sidebar-border));
    --tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_12px_hsl\(var\(--primary\)\/0\.5\)\]{
    --tw-shadow: 0 0 12px hsl(var(--primary)/0.5);
    --tw-shadow-colored: 0 0 12px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_12px_hsl\(var\(--primary\)\/0\.6\)\]{
    --tw-shadow: 0 0 12px hsl(var(--primary)/0.6);
    --tw-shadow-colored: 0 0 12px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_20px_-5px_hsl\(var\(--primary\)\)\]{
    --tw-shadow: 0 0 20px -5px hsl(var(--primary));
    --tw-shadow-colored: 0 0 20px -5px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_20px_rgba\(147\2c 51\2c 234\2c 0\.3\)\]{
    --tw-shadow: 0 0 20px rgba(147,51,234,0.3);
    --tw-shadow-colored: 0 0 20px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_20px_rgba\(var\(--primary\)\2c 0\.6\)\]{
    --tw-shadow: 0 0 20px rgba(var(--primary),0.6);
    --tw-shadow-colored: 0 0 20px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_30px_rgba\(168\2c 85\2c 247\2c 0\.8\)\]{
    --tw-shadow: 0 0 30px rgba(168,85,247,0.8);
    --tw-shadow-colored: 0 0 30px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_6px_0_0_rgba\(0\2c 0\2c 0\2c 0\.2\)\]{
    --tw-shadow: 0 6px 0 0 rgba(0,0,0,0.2);
    --tw-shadow-colored: 0 6px 0 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[inset_0_0_20px_rgba\(255\2c 255\2c 255\2c 0\.3\)\]{
    --tw-shadow: inset 0 0 20px rgba(255,255,255,0.3);
    --tw-shadow-colored: inset 0 0 20px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-inner{
    --tw-shadow: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: inset 0 2px 4px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-lg{
    --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-md{
    --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-none{
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-sm{
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-xl{
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-cyan-500\/70{
    --tw-shadow-color: rgb(6 182 212 / 0.7);
    --tw-shadow: var(--tw-shadow-colored);
}

.shadow-destructive\/50{
    --tw-shadow-color: hsl(var(--destructive) / 0.5);
    --tw-shadow: var(--tw-shadow-colored);
}

.shadow-emerald-400\/30{
    --tw-shadow-color: rgb(52 211 153 / 0.3);
    --tw-shadow: var(--tw-shadow-colored);
}

.shadow-emerald-400\/50{
    --tw-shadow-color: rgb(52 211 153 / 0.5);
    --tw-shadow: var(--tw-shadow-colored);
}

.shadow-emerald-500\/30{
    --tw-shadow-color: rgb(16 185 129 / 0.3);
    --tw-shadow: var(--tw-shadow-colored);
}

.shadow-gray-400\/50{
    --tw-shadow-color: rgb(156 163 175 / 0.5);
    --tw-shadow: var(--tw-shadow-colored);
}

.shadow-orange-600\/70{
    --tw-shadow-color: rgb(234 88 12 / 0.7);
    --tw-shadow: var(--tw-shadow-colored);
}

.shadow-purple-600\/90{
    --tw-shadow-color: rgb(147 51 234 / 0.9);
    --tw-shadow: var(--tw-shadow-colored);
}

.shadow-yellow-500\/80{
    --tw-shadow-color: rgb(234 179 8 / 0.8);
    --tw-shadow: var(--tw-shadow-colored);
}

.outline-none{
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.outline{
    outline-style: solid;
}

.ring{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-0{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-1{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-2{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-4{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.ring-inset{
    --tw-ring-inset: inset;
}

.ring-accent{
    --tw-ring-color: hsl(var(--accent));
}

.ring-background{
    --tw-ring-color: hsl(var(--background));
}

.ring-blue-200{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(191 219 254 / var(--tw-ring-opacity, 1));
}

.ring-blue-400{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(96 165 250 / var(--tw-ring-opacity, 1));
}

.ring-blue-500{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1));
}

.ring-cyan-400\/70{
    --tw-ring-color: rgb(34 211 238 / 0.7);
}

.ring-foreground\/10{
    --tw-ring-color: hsl(var(--foreground) / 0.1);
}

.ring-gray-200{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(229 231 235 / var(--tw-ring-opacity, 1));
}

.ring-gray-300{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(209 213 219 / var(--tw-ring-opacity, 1));
}

.ring-gray-400\/50{
    --tw-ring-color: rgb(156 163 175 / 0.5);
}

.ring-green-400{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(74 222 128 / var(--tw-ring-opacity, 1));
}

.ring-green-500{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(34 197 94 / var(--tw-ring-opacity, 1));
}

.ring-orange-600\/60{
    --tw-ring-color: rgb(234 88 12 / 0.6);
}

.ring-primary{
    --tw-ring-color: hsl(var(--primary));
}

.ring-primary\/20{
    --tw-ring-color: hsl(var(--primary) / 0.2);
}

.ring-primary\/30{
    --tw-ring-color: hsl(var(--primary) / 0.3);
}

.ring-purple-100{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(243 232 255 / var(--tw-ring-opacity, 1));
}

.ring-purple-200{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(233 213 255 / var(--tw-ring-opacity, 1));
}

.ring-purple-400\/50{
    --tw-ring-color: rgb(192 132 252 / 0.5);
}

.ring-purple-500{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(168 85 247 / var(--tw-ring-opacity, 1));
}

.ring-purple-500\/20{
    --tw-ring-color: rgb(168 85 247 / 0.2);
}

.ring-purple-500\/90{
    --tw-ring-color: rgb(168 85 247 / 0.9);
}

.ring-red-300{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(252 165 165 / var(--tw-ring-opacity, 1));
}

.ring-red-400{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(248 113 113 / var(--tw-ring-opacity, 1));
}

.ring-ring{
    --tw-ring-color: hsl(var(--ring));
}

.ring-sidebar-ring{
    --tw-ring-color: hsl(var(--sidebar-ring));
}

.ring-transparent{
    --tw-ring-color: transparent;
}

.ring-white{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(255 255 255 / var(--tw-ring-opacity, 1));
}

.ring-white\/30{
    --tw-ring-color: rgb(255 255 255 / 0.3);
}

.ring-yellow-300\/50{
    --tw-ring-color: rgb(253 224 71 / 0.5);
}

.ring-yellow-500\/80{
    --tw-ring-color: rgb(234 179 8 / 0.8);
}

.ring-opacity-75{
    --tw-ring-opacity: 0.75;
}

.ring-opacity-80{
    --tw-ring-opacity: 0.8;
}

.ring-offset-2{
    --tw-ring-offset-width: 2px;
}

.ring-offset-4{
    --tw-ring-offset-width: 4px;
}

.ring-offset-background{
    --tw-ring-offset-color: hsl(var(--background));
}

.ring-offset-emerald-600{
    --tw-ring-offset-color: #059669;
}

.ring-offset-red-500{
    --tw-ring-offset-color: #ef4444;
}

.blur{
    --tw-blur: blur(8px);
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-md{
    --tw-blur: blur(12px);
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-sm{
    --tw-blur: blur(4px);
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.blur-xl{
    --tw-blur: blur(24px);
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow{
    --tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / 0.1)) drop-shadow(0 1px 1px rgb(0 0 0 / 0.06));
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow-2xl{
    --tw-drop-shadow: drop-shadow(0 25px 25px rgb(0 0 0 / 0.15));
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow-lg{
    --tw-drop-shadow: drop-shadow(0 10px 8px rgb(0 0 0 / 0.04)) drop-shadow(0 4px 3px rgb(0 0 0 / 0.1));
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.grayscale{
    --tw-grayscale: grayscale(100%);
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.filter{
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.backdrop-blur{
    --tw-backdrop-blur: blur(8px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-\[2px\]{
    --tw-backdrop-blur: blur(2px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-sm{
    --tw-backdrop-blur: blur(4px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-filter{
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.transition{
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-\[left\2c right\2c width\]{
    transition-property: left,right,width;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-\[margin\2c opa\]{
    transition-property: margin,opa;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-\[width\2c height\2c padding\]{
    transition-property: width,height,padding;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-\[width\]{
    transition-property: width;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-all{
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-colors{
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-opacity{
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-shadow{
    transition-property: box-shadow;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.transition-transform{
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.delay-150{
    transition-delay: 150ms;
}

.delay-300{
    transition-delay: 300ms;
}

.duration-100{
    transition-duration: 100ms;
}

.duration-1000{
    transition-duration: 1000ms;
}

.duration-150{
    transition-duration: 150ms;
}

.duration-200{
    transition-duration: 200ms;
}

.duration-300{
    transition-duration: 300ms;
}

.duration-500{
    transition-duration: 500ms;
}

.duration-700{
    transition-duration: 700ms;
}

.ease-in-out{
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.ease-linear{
    transition-timing-function: linear;
}

.ease-out{
    transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

.contain-layout{
    --tw-contain-layout: layout;
    contain: var(--tw-contain-size) var(--tw-contain-layout) var(--tw-contain-paint) var(--tw-contain-style);
}

@keyframes enter{

    from{
        opacity: var(--tw-enter-opacity, 1);
        transform: translate3d(var(--tw-enter-translate-x, 0), var(--tw-enter-translate-y, 0), 0) scale3d(var(--tw-enter-scale, 1), var(--tw-enter-scale, 1), var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0));
    }
}

@keyframes exit{

    to{
        opacity: var(--tw-exit-opacity, 1);
        transform: translate3d(var(--tw-exit-translate-x, 0), var(--tw-exit-translate-y, 0), 0) scale3d(var(--tw-exit-scale, 1), var(--tw-exit-scale, 1), var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0));
    }
}

.animate-in{
    animation-name: enter;
    animation-duration: 150ms;
    --tw-enter-opacity: initial;
    --tw-enter-scale: initial;
    --tw-enter-rotate: initial;
    --tw-enter-translate-x: initial;
    --tw-enter-translate-y: initial;
}

.fade-in{
    --tw-enter-opacity: 0;
}

.fade-in-0{
    --tw-enter-opacity: 0;
}

.fade-in-80{
    --tw-enter-opacity: 0.8;
}

.zoom-in-95{
    --tw-enter-scale: .95;
}

.slide-in-from-top{
    --tw-enter-translate-y: -100%;
}

.duration-100{
    animation-duration: 100ms;
}

.duration-1000{
    animation-duration: 1000ms;
}

.duration-150{
    animation-duration: 150ms;
}

.duration-200{
    animation-duration: 200ms;
}

.duration-300{
    animation-duration: 300ms;
}

.duration-500{
    animation-duration: 500ms;
}

.duration-700{
    animation-duration: 700ms;
}

.delay-150{
    animation-delay: 150ms;
}

.delay-300{
    animation-delay: 300ms;
}

.ease-in-out{
    animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.ease-linear{
    animation-timing-function: linear;
}

.ease-out{
    animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

.running{
    animation-play-state: running;
}

.paused{
    animation-play-state: paused;
}

/* ================ APP THEME STYLES ================ */

/* Themed background container */

.themed-background {
  min-height: 100vh;
}

/* 
 * Apply theme colors to ALL white/light areas when a wallpaper theme is active
 * Using hsl() for theme variables that are already in "H S% L%" or "H S% L% / A" format
 */

/* Cards, white/light backgrounds (including opacity variants like bg-background/60) */

.themed-background .bg-card,
.themed-background [class*="bg-card/"],
.themed-background .bg-white,
.themed-background [class*="bg-white/"],
.themed-background .bg-gray-50,
.themed-background [class*="bg-gray-50/"],
.themed-background .bg-gray-100,
.themed-background [class*="bg-gray-100/"],
.themed-background .bg-slate-50,
.themed-background [class*="bg-slate-50/"],
.themed-background .bg-background,
.themed-background [class*="bg-background/"],
.themed-background .bg-popover,
.themed-background [class*="bg-popover/"],
.themed-background [class*="bg-neutral-"],
.themed-background [class*="bg-zinc-"],
.themed-background [class*="bg-stone-"],
/* Only apply themed backgrounds to actual card containers with explicit border classes */
.themed-background .rounded-lg.border.p-4:not(.color-swatch):not([style*="background"]),
.themed-background .rounded-xl.border.p-4:not(.color-swatch):not([style*="background"]),
.themed-background .rounded-md.border.p-4:not(.color-swatch):not([style*="background"]) {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-card-fg, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Header and navigation - critical for visibility */

.themed-background header,
.themed-background header.bg-white,
.themed-background header.bg-background,
.themed-background .mobile-header-fixed {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

.themed-background nav,
.themed-background .mobile-bottom-nav-fixed,
.themed-background .fixed.bottom-0 {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Modals, dialogs, popovers, sheets */

.themed-background [role="dialog"],
.themed-background .sheet-content,
.themed-background [data-radix-popper-content-wrapper] > div,
.themed-background [role="menu"],
.themed-background [role="listbox"],
.themed-background .bg-popover {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-card-fg, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Text colors for themed backgrounds */

.themed-background h1,
.themed-background h2,
.themed-background h3,
.themed-background h4,
.themed-background h5,
.themed-background h6,
.themed-background p,
.themed-background span,
.themed-background label,
.themed-background div {
  color: hsl(var(--theme-text-primary, 0 0% 0%));
}

.themed-background .text-muted-foreground,
.themed-background .text-gray-500,
.themed-background .text-gray-600 {
  color: hsl(var(--theme-text-secondary, 215.4 16.3% 46.9%)) !important;
}

/* Icon colors for themed backgrounds */

.themed-background svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]) {
  color: hsl(var(--theme-icon-primary, 0 0% 0%)) !important;
}

.themed-background .text-muted-foreground svg {
  color: hsl(var(--theme-icon-secondary, 215.4 16.3% 46.9%)) !important;
}

/* Secondary/muted backgrounds */

.themed-background .bg-muted,
.themed-background .bg-secondary,
.themed-background .bg-slate-50,
.themed-background .bg-slate-100 {
  background-color: hsl(var(--theme-secondary, 210 40% 96.1%)) !important;
  color: hsl(var(--theme-secondary-fg, 0 0% 0%)) !important;
}

/* Input styling for themes */

.themed-background input,
.themed-background textarea,
.themed-background select,
.themed-background .bg-input {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

.themed-background input::-moz-placeholder, .themed-background textarea::-moz-placeholder {
  color: hsl(var(--theme-muted-fg, 215.4 16.3% 46.9%)) !important;
}

.themed-background input::placeholder,
.themed-background textarea::placeholder {
  color: hsl(var(--theme-muted-fg, 215.4 16.3% 46.9%)) !important;
}

/* Button styling - comprehensive coverage */

.themed-background button {
  color: hsl(var(--theme-text-primary, 0 0% 0%));
}

/* Only apply themed backgrounds to buttons with explicit light background classes */

.themed-background button.bg-white:not(.color-swatch):not([style*="background"]),
.themed-background button.bg-secondary:not(.color-swatch):not([style*="background"]),
.themed-background button.bg-background:not(.color-swatch):not([style*="background"]),
.themed-background button.bg-muted:not(.color-swatch):not([style*="background"]) {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Preserve primary button styling */

.themed-background .bg-primary,
.themed-background button.bg-primary {
  background-color: hsl(var(--primary)) !important;
  color: hsl(var(--primary-foreground)) !important;
}

/* Preserve gradient backgrounds */

.themed-background [class*="bg-gradient"],
.themed-background [class*="from-purple"],
.themed-background [class*="to-pink"] {
  background-color: unset !important;
}

/* Fixed and sticky elements - headers, footers, navbars (only direct containers) */

.themed-background header.fixed,
.themed-background header.sticky,
.themed-background nav.fixed,
.themed-background nav.sticky,
.themed-background .mobile-header-fixed,
.themed-background .mobile-bottom-nav-fixed {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
}

/* Header child elements should be transparent - NOT have dark backgrounds */

.themed-background header .relative,
.themed-background header button:not(.bg-primary):not([class*="bg-gradient"]),
.themed-background header .flex:not(.notification-badge),
.themed-background header .inline-flex:not(.notification-badge),
.themed-background header [class*="z-10"],
.themed-background header [class*="z-20"] {
  background-color: transparent !important;
}

/* Notification bell unread badge: keep high visibility across themes */

.notification-badge,
.themed-background .notification-badge {
  background-color: hsl(var(--notification-badge-bg)) !important;
  color: hsl(var(--notification-badge-fg)) !important;
  border-color: transparent !important;
}

/* Absolute positioned containers - only if they have explicit bg classes */

.themed-background .absolute.bg-white,
.themed-background .absolute.bg-background,
.themed-background .absolute.bg-card {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
}

/* Z-indexed layers - be more selective, exclude header children */

.themed-background > [class*="z-"]:not(header *):not(nav *),
.themed-background main [class*="z-"].bg-white,
.themed-background main [class*="z-"].bg-background,
.themed-background main [class*="z-"].bg-card {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%));
}

/* Dropdowns and select menus */

.themed-background [role="combobox"],
.themed-background [role="option"],
.themed-background .dropdown-content,
.themed-background select option {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
}

/* Toggle, checkbox, switch backgrounds - enhanced visibility */

.themed-background [role="switch"],
.themed-background [role="checkbox"],
.themed-background .toggle {
  background-color: hsl(var(--theme-border, 214.3 31.8% 91.4%) / 0.8) !important;
  border: 2px solid hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.15) !important;
}

.themed-background [role="switch"][data-state="checked"],
.themed-background [role="checkbox"][data-state="checked"] {
  background-color: hsl(var(--primary)) !important;
  border-color: hsl(var(--primary)) !important;
  box-shadow: 0 0 8px hsl(var(--primary) / 0.5) !important;
}

/* Switch thumb visibility */

.themed-background [role="switch"] > span,
.themed-background [role="switch"] [data-state] {
  background-color: hsl(0 0% 100%) !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2) !important;
}

/* Slider track and thumb */

.themed-background [role="slider"],
.themed-background .slider-track {
  background-color: hsl(var(--theme-muted, 210 40% 96.1%)) !important;
}

/* Progress bar background */

.themed-background [role="progressbar"] {
  background-color: hsl(var(--theme-muted, 210 40% 96.1%)) !important;
}

/* Avatar fallback backgrounds */

.themed-background [class*="avatar"] {
  background-color: hsl(var(--theme-secondary, 210 40% 96.1%)) !important;
}

/* Table elements */

.themed-background table,
.themed-background thead,
.themed-background tbody,
.themed-background tr,
.themed-background th,
.themed-background td {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Calendar components */

.themed-background .rdp,
.themed-background .rdp-months,
.themed-background .rdp-month,
.themed-background .rdp-table,
.themed-background .rdp-head,
.themed-background .rdp-head_row,
.themed-background .rdp-row,
.themed-background .rdp-cell,
.themed-background .rdp-day {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
}

/* Tooltip */

.themed-background [role="tooltip"] {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Command palette / search */

.themed-background [cmdk-root],
.themed-background [cmdk-input],
.themed-background [cmdk-list],
.themed-background [cmdk-item],
.themed-background [cmdk-group] {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
}

/* Alerts */

.themed-background [role="alert"] {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Separators and dividers */

.themed-background [role="separator"],
.themed-background hr {
  background-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Embla carousel slides */

.themed-background .embla__slide,
.themed-background .embla__container {
  background-color: transparent !important;
}

/* Tabs and interactive elements */

.themed-background [role="tablist"],
.themed-background [role="tab"] {
  background-color: transparent !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
}

.themed-background [role="tab"][data-state="active"] {
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
}

/* Accordion and collapsible elements */

.themed-background [data-state="open"],
.themed-background [data-state="closed"] {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
}

/* Badge and tag elements - preserve colored badges but ensure visibility */

.themed-background .badge:not([class*="bg-emerald"]):not([class*="bg-blue"]):not([class*="bg-purple"]):not([class*="bg-orange"]):not([class*="bg-rose"]):not([class*="bg-cyan"]):not([class*="bg-amber"]):not([class*="bg-green"]):not([class*="bg-red"]):not([class*="bg-yellow"]):not([class*="bg-pink"]):not([class*="bg-gradient"]):not([class*="bg-destructive"]),
.themed-background [class*="badge"]:not([class*="bg-emerald"]):not([class*="bg-blue"]):not([class*="bg-purple"]):not([class*="bg-orange"]):not([class*="bg-rose"]):not([class*="bg-cyan"]):not([class*="bg-amber"]):not([class*="bg-green"]):not([class*="bg-red"]):not([class*="bg-yellow"]):not([class*="bg-pink"]):not([class*="bg-gradient"]):not([class*="bg-destructive"]) {
  background-color: hsl(var(--theme-secondary, 210 40% 96.1%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
}

/* Colored badges and indicators - preserve original styling with explicit colors */

.themed-background .bg-green-500 { background-color: rgb(34 197 94) !important; }

.themed-background .bg-green-400 { background-color: rgb(74 222 128) !important; }

.themed-background .bg-green-600 { background-color: rgb(22 163 74) !important; }

.themed-background .bg-red-500 { background-color: rgb(239 68 68) !important; }

.themed-background .bg-red-400 { background-color: rgb(248 113 113) !important; }

.themed-background .bg-red-600 { background-color: rgb(220 38 38) !important; }

.themed-background .bg-purple-500 { background-color: rgb(168 85 247) !important; }

.themed-background .bg-purple-400 { background-color: rgb(192 132 252) !important; }

.themed-background .bg-purple-600 { background-color: rgb(147 51 234) !important; }

.themed-background .bg-blue-500 { background-color: rgb(59 130 246) !important; }

.themed-background .bg-blue-400 { background-color: rgb(96 165 250) !important; }

.themed-background .bg-blue-600 { background-color: rgb(37 99 235) !important; }

.themed-background .bg-amber-500 { background-color: rgb(245 158 11) !important; }

.themed-background .bg-amber-400 { background-color: rgb(251 191 36) !important; }

.themed-background .bg-amber-600 { background-color: rgb(217 119 6) !important; }

.themed-background .bg-orange-500 { background-color: rgb(249 115 22) !important; }

.themed-background .bg-orange-400 { background-color: rgb(251 146 60) !important; }

.themed-background .bg-orange-600 { background-color: rgb(234 88 12) !important; }

.themed-background .bg-cyan-500 { background-color: rgb(6 182 212) !important; }

.themed-background .bg-pink-500 { background-color: rgb(236 72 153) !important; }

.themed-background .bg-emerald-500 { background-color: rgb(16 185 129) !important; }

.themed-background .bg-rose-500 { background-color: rgb(244 63 94) !important; }

/* Preserve colored badge backgrounds with tint variants (100/200 levels) */

.themed-background .bg-green-100 { background-color: rgb(220 252 231) !important; }

.themed-background .bg-blue-100 { background-color: rgb(219 234 254) !important; }

.themed-background .bg-purple-100 { background-color: rgb(243 232 255) !important; }

.themed-background .bg-orange-100 { background-color: rgb(255 237 213) !important; }

.themed-background .bg-amber-100 { background-color: rgb(254 243 199) !important; }

.themed-background .bg-red-100 { background-color: rgb(254 226 226) !important; }

/* Gradient backgrounds must be preserved.
   NOTE: Do NOT touch the marquee bar; it enforces its own solid purple background. */

.themed-background [class*="bg-gradient"]:not(.marquee-full-width) {
  background-color: transparent !important;
}

/* Marquee must stay solid purple across all themes */

.themed-background .marquee-full-width {
  background-image: none !important;
  background-color: hsl(var(--marquee-bg)) !important;
}

/* Ensure white text on solid colored badges stays white */

.themed-background .text-white {
  color: white !important;
}

/* Ensure colored badge text stays visible */

.themed-background .text-emerald-700,
.themed-background .text-emerald-400 {
  color: rgb(4 120 87) !important;
}

.themed-background .dark .text-emerald-400,
.themed-background.dark .text-emerald-400 {
  color: rgb(52 211 153) !important;
}

.themed-background .text-blue-700,
.themed-background .text-blue-400 {
  color: rgb(29 78 216) !important;
}

.themed-background .dark .text-blue-400,
.themed-background.dark .text-blue-400 {
  color: rgb(96 165 250) !important;
}

.themed-background .text-purple-700,
.themed-background .text-purple-400 {
  color: rgb(126 34 206) !important;
}

.themed-background .dark .text-purple-400,
.themed-background.dark .text-purple-400 {
  color: rgb(192 132 252) !important;
}

.themed-background .text-orange-700,
.themed-background .text-orange-400 {
  color: rgb(194 65 12) !important;
}

.themed-background .dark .text-orange-400,
.themed-background.dark .text-orange-400 {
  color: rgb(251 146 60) !important;
}

.themed-background .text-rose-700,
.themed-background .text-rose-400 {
  color: rgb(190 18 60) !important;
}

.themed-background .dark .text-rose-400,
.themed-background.dark .text-rose-400 {
  color: rgb(251 113 133) !important;
}

.themed-background .text-cyan-700,
.themed-background .text-cyan-400 {
  color: rgb(14 116 144) !important;
}

.themed-background .dark .text-cyan-400,
.themed-background.dark .text-cyan-400 {
  color: rgb(34 211 238) !important;
}

.themed-background .text-amber-700,
.themed-background .text-amber-400 {
  color: rgb(180 83 9) !important;
}

.themed-background .dark .text-amber-400,
.themed-background.dark .text-amber-400 {
  color: rgb(251 191 36) !important;
}

.themed-background .text-yellow-700,
.themed-background .text-yellow-400 {
  color: rgb(161 98 7) !important;
}

.themed-background .dark .text-yellow-400,
.themed-background.dark .text-yellow-400 {
  color: rgb(250 204 21) !important;
}

/* Skeleton loaders */

.themed-background .skeleton,
.themed-background .animate-pulse {
  background-color: hsl(var(--theme-muted, 210 40% 96.1%)) !important;
}

/* Dividers and separators */

.themed-background .border-gray-200,
.themed-background .border-gray-100,
.themed-background .divide-gray-200 > * + * {
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Toast notifications */

.themed-background .sonner-toast {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Hover states */

.themed-background .hover\:bg-gray-100:hover,
.themed-background .hover\:bg-gray-50:hover,
.themed-background .hover\:bg-white:hover,
.themed-background .hover\:bg-muted:hover,
.themed-background .hover\:bg-muted\/50:hover,
.themed-background .hover\:bg-secondary:hover {
  background-color: hsl(var(--theme-muted, 210 40% 96.1%)) !important;
}

/* Preserve meaningful colors */

.themed-background .text-red-500,
.themed-background .text-red-600,
.themed-background .fill-red-500 {
  color: rgb(239 68 68) !important;
}

.themed-background .text-green-500,
.themed-background .text-green-600 {
  color: rgb(34 197 94) !important;
}

/* Preserve purple/primary buttons and gradients */

.themed-background .bg-purple-600,
.themed-background .bg-purple-700,
.themed-background [class*="bg-purple-"] {
  background-color: unset !important;
  color: white !important;
}

/* Specific UI components with white backgrounds */

.themed-background .aspect-square.bg-white,
.themed-background .rounded-full.bg-white,
.themed-background .flex.bg-white,
.themed-background .inline-flex.bg-white,
.themed-background .grid.bg-white,
.themed-background .block.bg-white {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
}

/* Cover all container elements */

.themed-background .container,
.themed-background main,
.themed-background section,
.themed-background article,
.themed-background aside,
.themed-background footer:not(.fixed) {
  background-color: transparent !important;
}

/* Inner card content areas */

.themed-background .p-4.bg-white,
.themed-background .p-3.bg-white,
.themed-background .p-2.bg-white,
.themed-background .p-6.bg-white,
.themed-background .px-4.bg-white,
.themed-background .py-4.bg-white {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
}

/* Any remaining white backgrounds */

.themed-background [style*="background: white"],
.themed-background [style*="background-color: white"],
.themed-background [style*="background: #fff"],
.themed-background [style*="background-color: #fff"],
.themed-background [style*="background: rgb(255, 255, 255)"],
.themed-background [style*="background-color: rgb(255, 255, 255)"] {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
}

/* Weather widget exception - preserve its own styling */

.themed-background .weather-widget,
.themed-background .weather-widget * {
  /* Weather widget keeps its own colors */
}

/* ================ COLOR SWATCH PRESERVATION ================ */

/* 
 * Color swatches use inline style={{ backgroundColor: color }} 
 * We must NOT override this with any background-color rule.
 * The key is to add visible borders without touching background.
 */

.themed-background .color-swatch,
.themed-background button.color-swatch {
  /* DO NOT set background-color - let inline style work */
  /* Add visible border for contrast on dark themed backgrounds */
  border: 2px solid rgba(255, 255, 255, 0.5) !important;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2), inset 0 0 0 1px rgba(255, 255, 255, 0.2) !important;
}

.themed-background .color-swatch:hover,
.themed-background button.color-swatch:hover {
  border-color: rgba(255, 255, 255, 0.8) !important;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.4), 0 4px 8px rgba(0, 0, 0, 0.3) !important;
  transform: scale(1.05) !important;
}

.themed-background .color-swatch.border-primary,
.themed-background .color-swatch.ring-2,
.themed-background .color-swatch.scale-105 {
  border: 3px solid hsl(var(--primary)) !important;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.5), 0 0 0 4px hsl(var(--primary) / 0.4), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}

/* Color picker container - themed but swatches inside keep their colors */

.themed-background .color-picker-container {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Last-resort: force unread badge background above any header transparency rules */

header .notification-badge,
.themed-background header .notification-badge {
  background-color: hsl(var(--notification-badge-bg)) !important;
  color: hsl(var(--notification-badge-fg)) !important;
}

/* ================ PORTAL THEMING FOR RADIX DIALOGS/SHEETS/SELECTS ================ */

/* 
 * Radix UI portals render outside .themed-background container.
 * Theme CSS variables are now set on :root via App.tsx useEffect.
 * These rules apply theme colors to portal elements when a theme is active.
 */

/* Dialog/Sheet surfaces */

:root.themed-background [role="dialog"],
:root.themed-background .sheet-content,
:root.themed-background [data-radix-popper-content-wrapper] > div,
:root.themed-background [role="menu"],
:root.themed-background [role="listbox"] {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-card-fg, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Text elements in dialogs */

:root.themed-background [role="dialog"] h1,
:root.themed-background [role="dialog"] h2,
:root.themed-background [role="dialog"] h3,
:root.themed-background [role="dialog"] h4,
:root.themed-background [role="dialog"] p,
:root.themed-background [role="dialog"] span,
:root.themed-background [role="dialog"] label,
:root.themed-background [role="dialog"] div,
:root.themed-background .sheet-content h1,
:root.themed-background .sheet-content h2,
:root.themed-background .sheet-content h3,
:root.themed-background .sheet-content p,
:root.themed-background .sheet-content span,
:root.themed-background .sheet-content label,
:root.themed-background .sheet-content div {
  color: hsl(var(--theme-text-primary, 0 0% 0%));
}

/* Muted text in dialogs */

:root.themed-background [role="dialog"] .text-muted-foreground,
:root.themed-background .sheet-content .text-muted-foreground {
  color: hsl(var(--theme-text-secondary, 215.4 16.3% 46.9%)) !important;
}

/* Input fields in dialogs */

:root.themed-background [role="dialog"] input,
:root.themed-background [role="dialog"] textarea,
:root.themed-background [role="dialog"] select,
:root.themed-background .sheet-content input,
:root.themed-background .sheet-content textarea,
:root.themed-background .sheet-content select {
  background-color: hsl(var(--theme-muted, 210 40% 96.1%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Muted/secondary backgrounds in dialogs */

:root.themed-background [role="dialog"] .bg-muted,
:root.themed-background [role="dialog"] .bg-secondary,
:root.themed-background .sheet-content .bg-muted,
:root.themed-background .sheet-content .bg-secondary {
  background-color: hsl(var(--theme-muted, 210 40% 96.1%)) !important;
  color: hsl(var(--theme-text-primary, 0 0% 0%)) !important;
}

/* Card backgrounds in dialogs */

:root.themed-background [role="dialog"] .bg-card,
:root.themed-background [role="dialog"] .bg-background,
:root.themed-background .sheet-content .bg-card,
:root.themed-background .sheet-content .bg-background {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-card-fg, 0 0% 0%)) !important;
}

/* Borders in dialogs */

:root.themed-background [role="dialog"] .border-border,
:root.themed-background [role="dialog"] .border,
:root.themed-background .sheet-content .border-border,
:root.themed-background .sheet-content .border {
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* Buttons in dialogs (outline/secondary variants) */

:root.themed-background [role="dialog"] button:not(.bg-primary):not(.bg-destructive):not([class*="gradient"]):not([class*="bg-purple"]):not([class*="bg-green"]):not([class*="bg-red"]):not([class*="bg-blue"]),
:root.themed-background .sheet-content button:not(.bg-primary):not(.bg-destructive):not([class*="gradient"]):not([class*="bg-purple"]):not([class*="bg-green"]):not([class*="bg-red"]):not([class*="bg-blue"]) {
  color: hsl(var(--theme-text-primary, 0 0% 0%));
}

/* Icons in dialogs */

:root.themed-background [role="dialog"] svg:not(.fill-red-500):not([class*="text-red"]),
:root.themed-background .sheet-content svg:not(.fill-red-500):not([class*="text-red"]) {
  color: hsl(var(--theme-icon-primary, 0 0% 0%)) !important;
}

/* Hover states in dialogs */

:root.themed-background [role="dialog"] .hover\:bg-muted:hover,
:root.themed-background [role="dialog"] .hover\:bg-muted\/50:hover,
:root.themed-background .sheet-content .hover\:bg-muted:hover,
:root.themed-background .sheet-content .hover\:bg-muted\/50:hover {
  background-color: hsl(var(--theme-muted, 210 40% 96.1%)) !important;
}

/* Fallback for body:has (older browser support) */

body:has(.themed-background) [role="dialog"],
body:has(.themed-background) .sheet-content,
body:has(.themed-background) [data-radix-popper-content-wrapper] > div {
  background-color: hsl(var(--theme-card-bg, 0 0% 100%)) !important;
  color: hsl(var(--theme-card-fg, 0 0% 0%)) !important;
  border-color: hsl(var(--theme-border, 214.3 31.8% 91.4%)) !important;
}

/* ================ THEMED TABS STYLING ================ */

/* When a theme is active, tabs use prominent styling for better visibility */

:root.themed-background .themed-tabs-list {
  background-color: hsl(var(--theme-card-bg)) !important;
  border: 2px solid hsl(var(--theme-accent) / 0.5) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3), 0 0 0 1px hsl(var(--theme-border)) !important;
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
}

:root.themed-background .themed-tabs-trigger {
  color: hsl(var(--theme-text-primary)) !important;
  font-weight: 500;
}

:root.themed-background .themed-tabs-trigger[data-state="active"] {
  background: linear-gradient(135deg, hsl(var(--theme-accent)), hsl(var(--theme-accent) / 0.8)) !important;
  color: hsl(var(--theme-accent-fg)) !important;
  box-shadow: 0 2px 12px hsl(var(--theme-accent) / 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
  font-weight: 600;
}

:root.themed-background .themed-tabs-trigger[data-state="inactive"]:hover {
  background-color: hsl(var(--theme-muted)) !important;
  color: hsl(var(--theme-text-primary)) !important;
}

/* Ensure all hint tooltip icons have no visible box when themed */

:root.themed-background span[aria-label] {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: inherit !important;
  opacity: 0.6;
}

:root.themed-background span[aria-label]:hover {
  opacity: 1;
}

/* Logo glow animation */

@keyframes logo-glow-pulse {
  0%, 100% {
    box-shadow: 0 0 6px 2px rgba(168, 85, 247, 0.4);
  }
  50% {
    box-shadow: 0 0 14px 4px rgba(168, 85, 247, 0.7);
  }
}

.logo-glow {
  animation: logo-glow-pulse 2.5s ease-in-out infinite;
}

/* Style Assistant pulsating glow */

@keyframes style-assistant-glow-pulse {
  0%, 100% {
    box-shadow: 0 0 4px 1px rgba(59, 130, 246, 0.3), 0 0 8px 2px rgba(168, 85, 247, 0.2);
  }
  50% {
    box-shadow: 0 0 12px 4px rgba(59, 130, 246, 0.5), 0 0 20px 6px rgba(168, 85, 247, 0.35);
  }
}

.style-assistant-glow {
  animation: style-assistant-glow-pulse 2.5s ease-in-out infinite;
}

.black-background .color-picker-container .file\:text-sm.text-gray-600::file-selector-button {
    color: rgb(64 64 64) !important;
  }

.after\:text-red-500::after {
    content: var(--tw-content);
    color: rgb(239 68 68) !important; /* keep red-500 for likes */
  }

button .after\:text-red-500::after {
    content: var(--tw-content);
    color: rgb(239 68 68) !important; /* keep red for liked counts */
  }

.black-background button .after\:text-red-500::after {
    content: var(--tw-content);
    color: rgb(239 68 68) !important; /* keep red for liked counts */
  }

.black-background .after\:text-red-500::after {
    content: var(--tw-content);
    color: rgb(239 68 68) !important; /* keep red indicators */
  }

.black-background .hover\:text-gray-600:hover {
    color: hsl(var(--foreground)) !important;
  }


  .black-background .hover\:text-gray-700:hover {
    color: hsl(var(--foreground)) !important;
  }


  .black-background .hover\:text-gray-900:hover {
    color: hsl(var(--foreground)) !important;
  }

.black-background .hover\:bg-white:hover:not(.color-picker-container):not(.color-swatch) {
    background-color: hsl(var(--background)) !important;
  }

.black-background .hover\:bg-gray-50:hover {
    background-color: hsl(var(--muted)) !important;
  }


  .black-background .hover\:bg-gray-100:hover {
    background-color: hsl(var(--muted)) !important;
  }


  .black-background .hover\:border-gray-300:hover {
    border-color: hsl(var(--border)) !important;
  }

.black-background .weather-widget .hover\:text-white:hover {
    color: white !important;
  }


  body .hover\:text-blue-500:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .hover\:text-blue-600:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .hover\:text-green-500:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .hover\:text-green-600:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .hover\:text-yellow-600:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .hover\:text-purple-500:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .hover\:text-purple-600:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .hover\:text-gray-600:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .hover\:text-gray-700:hover:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }

.hover\:text-red-500:hover {
    color: rgb(239 68 68) !important; /* keep red-500 for likes */
  }

.hover\:text-red-600:hover {
    color: rgb(239 68 68) !important; /* keep red-500 for likes */
  }

button .hover\:text-red-500:hover {
    color: rgb(239 68 68) !important; /* keep red for liked counts */
  }

.hover\:text-destructive:hover {
    color: rgb(220 38 38) !important; /* keep red for errors */
  }

.hover\:text-red-700:hover {
    color: rgb(220 38 38) !important; /* keep red for errors */
  }


  .black-background .hover\:text-gray-600:hover svg,
  .black-background .hover\:text-gray-600:hover {
    color: white !important;
  }


  .black-background .hover\:text-gray-700:hover svg,
  .black-background .hover\:text-gray-700:hover {
    color: white !important;
  }


  .black-background .hover\:text-gray-600:hover svg,
  .black-background .hover\:text-gray-600:hover {
    color: white !important;
  }


  .black-background .hover\:text-gray-700:hover svg,
  .black-background .hover\:text-gray-700:hover {
    color: white !important;
  }


  .black-background .hover\:text-blue-500:hover {
    color: white !important;
  }


  .black-background .hover\:text-blue-600:hover {
    color: white !important;
  }


  .black-background .hover\:text-green-500:hover {
    color: white !important;
  }


  .black-background .hover\:text-green-600:hover {
    color: white !important;
  }


  .black-background .hover\:text-yellow-600:hover {
    color: white !important;
  }


  .black-background .hover\:text-purple-500:hover {
    color: white !important;
  }


  .black-background .hover\:text-purple-600:hover {
    color: white !important;
  }

.black-background button .hover\:text-red-500:hover {
    color: rgb(239 68 68) !important; /* keep red for liked counts */
  }

.black-background .hover\:text-red-500:hover {
    color: rgb(239 68 68) !important; /* keep red indicators */
  }


  .black-background .hover\:text-red-600:hover {
    color: rgb(239 68 68) !important; /* keep red indicators */
  }


  .black-background .hover\:ring-2:hover {
    ring-color: rgb(168 85 247) !important;
  }

.black-background .hover\:from-purple-600:hover {
    --tw-gradient-from: rgb(147 51 234) !important;
  }

.black-background .hover\:to-pink-600:hover {
    --tw-gradient-to: rgb(219 39 119) !important;
  }

.black-background .hover\:shadow-lg:hover {
    box-shadow: 0 10px 15px -3px rgba(255, 255, 255, 0.1), 0 4px 6px -2px rgba(255, 255, 255, 0.05) !important;
  }


  .black-background .hover\:shadow-md:hover {
    box-shadow: 0 10px 15px -3px rgba(255, 255, 255, 0.1), 0 4px 6px -2px rgba(255, 255, 255, 0.05) !important;
  }


  .black-background .hover\:bg-white:hover.fixed.bottom-0 {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }


  .black-background .hover\:text-primary:hover {
    color: white !important;
  }


  .black-background .hover\:shadow-sm:hover {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }

.black-background .hover\:bg-purple-100:hover {
    background-color: rgb(64 64 64) !important;
  }

.black-background .hover\:text-purple-600:hover {
    color: rgb(196 181 253) !important;
  }


  .black-background .hover\:text-purple-700:hover {
    color: rgb(196 181 253) !important;
  }

.black-background .hover\:bg-secondary:hover {
    background-color: rgb(64 64 64) !important;
  }

.black-background .hover\:bg-muted:hover {
    background-color: rgb(64 64 64) !important;
  }

.black-background .hover\:bg-background:hover {
    background-color: black !important;
  }

.black-background .hover\:bg-green-100:hover {
    background-color: rgb(64 64 64) !important;
  }


  .black-background .hover\:bg-blue-100:hover {
    background-color: rgb(64 64 64) !important;
  }


  .black-background .hover\:bg-yellow-100:hover {
    background-color: rgb(64 64 64) !important;
  }

.black-background .hover\:text-green-600:hover {
    color: white !important;
  }


  .black-background .hover\:text-blue-600:hover {
    color: white !important;
  }


  .black-background .hover\:text-yellow-600:hover {
    color: white !important;
  }


  .black-background .hover\:text-red-600:hover {
    color: white !important;
  }

.black-background .hover\:bg-gray-200:hover {
    background-color: rgb(64 64 64) !important;
  }

.black-background .hover\:bg-destructive:hover {
    background-color: rgb(239 68 68) !important;
  }

.black-background .hover\:text-destructive:hover {
    color: rgb(239 68 68) !important;
  }

.black-background .hover\:bg-accent:hover {
    background-color: rgb(64 64 64) !important;
  }

.black-background .hover\:text-accent-foreground:hover {
    color: white !important;
  }

.hover\:border-primary:hover.color-swatch {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.black-background .hover\:border-primary:hover.color-swatch {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.black-background .color-picker-container .hover\:text-gray-600:hover.text-sm {
    color: rgb(64 64 64) !important;
  }

.focus\:text-red-600:focus {
    color: rgb(239 68 68) !important; /* keep red-500 for likes */
  }

.focus\:text-destructive:focus {
    color: rgb(220 38 38) !important; /* keep red for errors */
  }

.focus\:text-red-700:focus {
    color: rgb(220 38 38) !important; /* keep red for errors */
  }


  .black-background .focus\:text-red-600:focus {
    color: rgb(239 68 68) !important; /* keep red indicators */
  }


  .black-background .focus\:ring-2:focus {
    ring-color: rgb(168 85 247) !important;
  }


  .black-background .focus\:text-primary:focus {
    color: white !important;
  }


  .black-background .focus\:text-red-600:focus {
    color: white !important;
  }

.black-background .focus\:text-destructive:focus {
    color: rgb(239 68 68) !important;
  }

.black-background .focus\:bg-accent:focus {
    background-color: rgb(64 64 64) !important;
  }

.black-background .focus\:text-accent-foreground:focus {
    color: white !important;
  }

.black-background .focus-visible\:ring-purple-500:focus-visible {
    ring-color: rgb(168 85 247) !important;
  }


  .black-background .focus-visible\:ring-2:focus-visible {
    ring-color: rgb(168 85 247) !important;
  }


  .black-background .group:hover .group-hover\:text-gray-900 {
    color: hsl(var(--foreground)) !important;
  }

.black-background .group:hover .group-hover\:bg-gray-50 {
    background-color: hsl(var(--muted)) !important;
  }

.black-background .group:hover .group-hover\:bg-gradient-to-r.from-purple-500.to-pink-500:not(.weather-widget) {
    background: linear-gradient(to right, rgb(147 51 234), rgb(219 39 119)) !important;
  }

.black-background .weather-widget .group:hover .group-hover\:text-white {
    color: white !important;
  }


  body .group:hover .group-hover\:text-blue-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .group:hover .group-hover\:text-green-500:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }


  body .group:hover .group-hover\:text-purple-600:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }

.group:hover .group-hover\:text-red-500 {
    color: rgb(239 68 68) !important; /* keep red-500 for likes */
  }

button .group:hover .group-hover\:text-red-500 {
    color: rgb(239 68 68) !important; /* keep red for liked counts */
  }

.group:hover .group-hover\:text-destructive {
    color: rgb(220 38 38) !important; /* keep red for errors */
  }


  .black-background .group:hover .group-hover\:text-blue-500 {
    color: white !important;
  }


  .black-background .group:hover .group-hover\:text-green-500 {
    color: white !important;
  }


  .black-background .group:hover .group-hover\:text-purple-600 {
    color: white !important;
  }

.black-background button .group:hover .group-hover\:text-red-500 {
    color: rgb(239 68 68) !important; /* keep red for liked counts */
  }

.black-background .group:hover .group-hover\:text-red-500 {
    color: rgb(239 68 68) !important; /* keep red indicators */
  }


  .black-background .group:hover .group-hover\:text-primary {
    color: white !important;
  }

.black-background .group:hover .group-hover\:text-purple-600 {
    color: rgb(196 181 253) !important;
  }


  .black-background .group:hover .group-hover\:text-purple-700 {
    color: rgb(196 181 253) !important;
  }

.black-background .group:hover .group-hover\:text-destructive {
    color: rgb(239 68 68) !important;
  }

.group:hover .group-hover\:border-primary.color-swatch {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.black-background .group:hover .group-hover\:border-primary.color-swatch {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.black-background .group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover {
    background-color: rgb(239 68 68) !important;
  }

.black-background .aria-selected\:bg-accent[aria-selected="true"] {
    background-color: rgb(64 64 64) !important;
  }

.black-background .aria-selected\:text-accent-foreground[aria-selected="true"] {
    color: white !important;
  }

.black-background .data-\[state\=active\]\:bg-gradient-to-r[data-state="active"].from-purple-500.to-pink-500:not(.weather-widget) {
    background: linear-gradient(to right, rgb(147 51 234), rgb(219 39 119)) !important;
  }

.black-background .data-\[state\=checked\]\:bg-gradient-to-r[data-state="checked"].from-purple-500.to-pink-500:not(.weather-widget) {
    background: linear-gradient(to right, rgb(147 51 234), rgb(219 39 119)) !important;
  }

.black-background .weather-widget .data-\[state\=active\]\:text-white[data-state="active"] {
    color: white !important;
  }


  .black-background .data-\[state\=on\]\:ring-2[data-state="on"] {
    ring-color: rgb(168 85 247) !important;
  }

.black-background .data-\[state\=checked\]\:from-purple-600[data-state="checked"] {
    --tw-gradient-from: rgb(147 51 234) !important;
  }

.black-background .data-\[state\=checked\]\:to-pink-600[data-state="checked"] {
    --tw-gradient-to: rgb(219 39 119) !important;
  }


  .black-background .data-\[state\=active\]\:shadow-md[data-state="active"] {
    box-shadow: 0 10px 15px -3px rgba(255, 255, 255, 0.1), 0 4px 6px -2px rgba(255, 255, 255, 0.05) !important;
  }

.black-background .data-\[state\=active\]\:bg-primary[data-state="active"] {
    background-color: rgb(168 85 247) !important;
  }

.black-background .data-\[state\=checked\]\:bg-primary[data-state="checked"] {
    background-color: rgb(168 85 247) !important;
  }


  .black-background .data-\[state\=on\]\:shadow-sm[data-state="on"] {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }

.black-background .data-\[state\=open\]\:bg-secondary[data-state="open"] {
    background-color: rgb(64 64 64) !important;
  }

.black-background .data-\[state\=active\]\:bg-muted[data-state="active"] {
    background-color: rgb(64 64 64) !important;
  }

.black-background .data-\[state\=selected\]\:bg-muted[data-state="selected"] {
    background-color: rgb(64 64 64) !important;
  }

.black-background .data-\[state\=unchecked\]\:bg-muted[data-state="unchecked"] {
    background-color: rgb(64 64 64) !important;
  }

.black-background .data-\[state\=active\]\:bg-background[data-state="active"] {
    background-color: black !important;
  }

.black-background .data-\[selected\=\'true\'\]\:bg-accent[data-selected='true'] {
    background-color: rgb(64 64 64) !important;
  }

.black-background .data-\[state\=on\]\:bg-accent[data-state="on"] {
    background-color: rgb(64 64 64) !important;
  }

.black-background .data-\[state\=open\]\:bg-accent[data-state="open"] {
    background-color: rgb(64 64 64) !important;
  }

.black-background .data-\[selected\=true\]\:text-accent-foreground[data-selected="true"] {
    color: white !important;
  }

.black-background .data-\[state\=on\]\:text-accent-foreground[data-state="on"] {
    color: white !important;
  }

.black-background .data-\[state\=open\]\:text-accent-foreground[data-state="open"] {
    color: white !important;
  }

.black-background .data-\[state\=unchecked\]\:border-border[data-state="unchecked"] {
    border-color: rgb(64 64 64) !important;
  }

.data-\[state\=checked\]\:border-primary[data-state="checked"].color-swatch {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.data-\[state\=on\]\:border-primary[data-state="on"].color-swatch {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.black-background .data-\[state\=checked\]\:border-primary[data-state="checked"].color-swatch {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.black-background .data-\[state\=on\]\:border-primary[data-state="on"].color-swatch {
    border: 3px solid rgb(168 85 247) !important;
    box-shadow: 0 0 0 2px white, 0 0 0 4px rgb(168 85 247), 0 4px 8px rgba(0, 0, 0, 0.2) !important;
  }

.group[data-variant="floating"] .group-data-\[variant\=floating\]\:rounded-lg svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 for consistent branding */
  }


  .black-background .group[data-variant="floating"] .group-data-\[variant\=floating\]\:rounded-lg svg {
    color: white !important;
  }


  .black-background .group[data-variant="floating"] .group-data-\[variant\=floating\]\:border svg {
    color: white !important;
  }


  .black-background .group[data-variant="floating"] .group-data-\[variant\=floating\]\:rounded-lg.border {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }


  .black-background .group[data-variant="floating"] .group-data-\[variant\=floating\]\:border.rounded-lg {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }

.black-background .weather-widget .dark\:text-white:is(.dark *) {
    color: white !important;
  }

@media (min-width: 640px){
  .sm\:rounded-lg svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 for consistent branding */
  }
  
  body .sm\:p-3 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }
  
  body .sm\:p-4 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }
  
  body .sm\:p-6 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }
  
  body .sm\:pt-6 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }
  
  body .sm\:px-4 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }
  
  body .sm\:space-y-6 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }
  
  body .sm\:space-y-4 svg:not(.weather-widget *):not(.fill-red-500):not([class*="text-red"]):not(.color-swatch):not(.color-picker-container *) {
    color: rgb(147 51 234) !important; /* purple-600 */
  }

  
  .black-background .sm\:rounded-lg svg {
    color: white !important;
  }

  
  .black-background .sm\:p-3 svg {
    color: white !important;
  }

  
  .black-background .sm\:p-4 svg {
    color: white !important;
  }

  
  .black-background .sm\:p-6 svg {
    color: white !important;
  }

  
  .black-background .sm\:pt-6 svg {
    color: white !important;
  }
  .black-background .sm\:bottom-0.fixed,
  .black-background .sm\:bottom-0.fixed.bg-white {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }
  
  .black-background .sm\:rounded-lg.border {
    background-color: rgb(23 23 23) !important;
    border-color: rgb(64 64 64) !important;
  }
  .black-background .color-picker-container .sm\:text-sm.text-gray-600 {
    color: rgb(64 64 64) !important;
  }
}

@media (min-width: 768px){
  .black-background .color-picker-container .md\:text-sm.text-gray-600 {
    color: rgb(64 64 64) !important;
  }
}

.\[\&\>svg\]\:text-destructive>svg {
    color: rgb(220 38 38) !important; /* keep red for errors */
  }

.black-background .\[\&\>svg\]\:text-destructive>svg {
    color: rgb(239 68 68) !important;
  }

.black-background .\[\&_\[role\=slider\]\]\:bg-gradient-to-r [role=slider].from-purple-500.to-pink-500:not(.weather-widget) {
    background: linear-gradient(to right, rgb(147 51 234), rgb(219 39 119)) !important;
  }

.black-background .\[\&_\[role\=slider\]\]\:from-purple-600 [role=slider] {
    --tw-gradient-from: rgb(147 51 234) !important;
  }

.black-background .\[\&_\[role\=slider\]\]\:to-pink-600 [role=slider] {
    --tw-gradient-to: rgb(219 39 119) !important;
  }

.file\:border-0::file-selector-button{
    border-width: 0px;
}

.file\:bg-transparent::file-selector-button{
    background-color: transparent;
}

.file\:text-sm::file-selector-button{
    font-size: 0.875rem;
    line-height: 1.25rem;
}

.file\:font-medium::file-selector-button{
    font-weight: 500;
}

.file\:text-foreground::file-selector-button{
    color: hsl(var(--foreground));
}

.placeholder\:text-muted-foreground::-moz-placeholder{
    color: hsl(var(--muted-foreground));
}

.placeholder\:text-muted-foreground::placeholder{
    color: hsl(var(--muted-foreground));
}

.placeholder\:text-white\/50::-moz-placeholder{
    color: rgb(255 255 255 / 0.5);
}

.placeholder\:text-white\/50::placeholder{
    color: rgb(255 255 255 / 0.5);
}

.after\:absolute::after{
    content: var(--tw-content);
    position: absolute;
}

.after\:-inset-2::after{
    content: var(--tw-content);
    inset: -0.5rem;
}

.after\:inset-y-0::after{
    content: var(--tw-content);
    top: 0px;
    bottom: 0px;
}

.after\:left-1\/2::after{
    content: var(--tw-content);
    left: 50%;
}

.after\:ml-1::after{
    content: var(--tw-content);
    margin-left: 0.25rem;
}

.after\:w-1::after{
    content: var(--tw-content);
    width: 0.25rem;
}

.after\:w-\[2px\]::after{
    content: var(--tw-content);
    width: 2px;
}

.after\:-translate-x-1\/2::after{
    content: var(--tw-content);
    --tw-translate-x: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.after\:text-red-500::after{
    content: var(--tw-content);
    --tw-text-opacity: 1;
    color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}

.after\:content-\[\"\*\"\]::after{
    --tw-content: "*";
    content: var(--tw-content);
}

.first\:ml-0:first-child{
    margin-left: 0px;
}

.first\:rounded-l-md:first-child{
    border-top-left-radius: calc(var(--radius) - 2px);
    border-bottom-left-radius: calc(var(--radius) - 2px);
}

.first\:border-l:first-child{
    border-left-width: 1px;
}

.last\:rounded-r-md:last-child{
    border-top-right-radius: calc(var(--radius) - 2px);
    border-bottom-right-radius: calc(var(--radius) - 2px);
}

.last\:border-0:last-child{
    border-width: 0px;
}

.last\:border-b-0:last-child{
    border-bottom-width: 0px;
}

.focus-within\:relative:focus-within{
    position: relative;
}

.focus-within\:z-20:focus-within{
    z-index: 20;
}

.hover\:-translate-y-2:hover{
    --tw-translate-y: -0.5rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:rotate-\[360deg\]:hover{
    --tw-rotate: 360deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:rotate-\[50deg\]:hover{
    --tw-rotate: 50deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-105:hover{
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-110:hover{
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-125:hover{
    --tw-scale-x: 1.25;
    --tw-scale-y: 1.25;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-\[1\.01\]:hover{
    --tw-scale-x: 1.01;
    --tw-scale-y: 1.01;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:scale-\[1\.02\]:hover{
    --tw-scale-x: 1.02;
    --tw-scale-y: 1.02;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:border-accent:hover{
    border-color: hsl(var(--accent));
}

.hover\:border-gray-300:hover{
    --tw-border-opacity: 1;
    border-color: rgb(209 213 219 / var(--tw-border-opacity, 1));
}

.hover\:border-gray-400:hover{
    --tw-border-opacity: 1;
    border-color: rgb(156 163 175 / var(--tw-border-opacity, 1));
}

.hover\:border-muted-foreground\/30:hover{
    border-color: hsl(var(--muted-foreground) / 0.3);
}

.hover\:border-primary:hover{
    border-color: hsl(var(--primary));
}

.hover\:border-primary\/30:hover{
    border-color: hsl(var(--primary) / 0.3);
}

.hover\:border-primary\/40:hover{
    border-color: hsl(var(--primary) / 0.4);
}

.hover\:border-primary\/50:hover{
    border-color: hsl(var(--primary) / 0.5);
}

.hover\:border-purple-300:hover{
    --tw-border-opacity: 1;
    border-color: rgb(216 180 254 / var(--tw-border-opacity, 1));
}

.hover\:border-purple-400:hover{
    --tw-border-opacity: 1;
    border-color: rgb(192 132 252 / var(--tw-border-opacity, 1));
}

.hover\:border-red-300:hover{
    --tw-border-opacity: 1;
    border-color: rgb(252 165 165 / var(--tw-border-opacity, 1));
}

.hover\:bg-accent:hover{
    background-color: hsl(var(--accent));
}

.hover\:bg-accent\/50:hover{
    background-color: hsl(var(--accent) / 0.5);
}

.hover\:bg-amber-500:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(245 158 11 / var(--tw-bg-opacity, 1));
}

.hover\:bg-amber-600:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(217 119 6 / var(--tw-bg-opacity, 1));
}

.hover\:bg-background:hover{
    background-color: hsl(var(--background));
}

.hover\:bg-black\/50:hover{
    background-color: rgb(0 0 0 / 0.5);
}

.hover\:bg-black\/70:hover{
    background-color: rgb(0 0 0 / 0.7);
}

.hover\:bg-black\/90:hover{
    background-color: rgb(0 0 0 / 0.9);
}

.hover\:bg-blue-100:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(219 234 254 / var(--tw-bg-opacity, 1));
}

.hover\:bg-blue-200:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(191 219 254 / var(--tw-bg-opacity, 1));
}

.hover\:bg-blue-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(239 246 255 / var(--tw-bg-opacity, 1));
}

.hover\:bg-blue-500:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}

.hover\:bg-blue-600:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(37 99 235 / var(--tw-bg-opacity, 1));
}

.hover\:bg-destructive:hover{
    background-color: hsl(var(--destructive));
}

.hover\:bg-destructive\/10:hover{
    background-color: hsl(var(--destructive) / 0.1);
}

.hover\:bg-destructive\/15:hover{
    background-color: hsl(var(--destructive) / 0.15);
}

.hover\:bg-destructive\/80:hover{
    background-color: hsl(var(--destructive) / 0.8);
}

.hover\:bg-destructive\/90:hover{
    background-color: hsl(var(--destructive) / 0.9);
}

.hover\:bg-gray-100:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(243 244 246 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-200:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}

.hover\:bg-gray-800:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}

.hover\:bg-green-100:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(220 252 231 / var(--tw-bg-opacity, 1));
}

.hover\:bg-green-200:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(187 247 208 / var(--tw-bg-opacity, 1));
}

.hover\:bg-green-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(240 253 244 / var(--tw-bg-opacity, 1));
}

.hover\:bg-green-500:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1));
}

.hover\:bg-muted:hover{
    background-color: hsl(var(--muted));
}

.hover\:bg-muted-foreground\/20:hover{
    background-color: hsl(var(--muted-foreground) / 0.2);
}

.hover\:bg-muted\/50:hover{
    background-color: hsl(var(--muted) / 0.5);
}

.hover\:bg-muted\/70:hover{
    background-color: hsl(var(--muted) / 0.7);
}

.hover\:bg-orange-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(255 247 237 / var(--tw-bg-opacity, 1));
}

.hover\:bg-orange-700:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(194 65 12 / var(--tw-bg-opacity, 1));
}

.hover\:bg-pink-200:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(251 207 232 / var(--tw-bg-opacity, 1));
}

.hover\:bg-primary-dark:hover{
    --tw-bg-opacity: 1;
    background-color: hsl(269 31% 55% / var(--tw-bg-opacity, 1));
}

.hover\:bg-primary\/10:hover{
    background-color: hsl(var(--primary) / 0.1);
}

.hover\:bg-primary\/15:hover{
    background-color: hsl(var(--primary) / 0.15);
}

.hover\:bg-primary\/20:hover{
    background-color: hsl(var(--primary) / 0.2);
}

.hover\:bg-primary\/80:hover{
    background-color: hsl(var(--primary) / 0.8);
}

.hover\:bg-primary\/90:hover{
    background-color: hsl(var(--primary) / 0.9);
}

.hover\:bg-purple-100:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(243 232 255 / var(--tw-bg-opacity, 1));
}

.hover\:bg-purple-200:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(233 213 255 / var(--tw-bg-opacity, 1));
}

.hover\:bg-purple-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(250 245 255 / var(--tw-bg-opacity, 1));
}

.hover\:bg-purple-500:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(168 85 247 / var(--tw-bg-opacity, 1));
}

.hover\:bg-red-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(254 242 242 / var(--tw-bg-opacity, 1));
}

.hover\:bg-red-600:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1));
}

.hover\:bg-red-700:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1));
}

.hover\:bg-secondary:hover{
    background-color: hsl(var(--secondary));
}

.hover\:bg-secondary\/80:hover{
    background-color: hsl(var(--secondary) / 0.8);
}

.hover\:bg-secondary\/90:hover{
    background-color: hsl(var(--secondary) / 0.9);
}

.hover\:bg-sidebar-accent:hover{
    background-color: hsl(var(--sidebar-accent));
}

.hover\:bg-transparent:hover{
    background-color: transparent;
}

.hover\:bg-white:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.hover\:bg-white\/10:hover{
    background-color: rgb(255 255 255 / 0.1);
}

.hover\:bg-white\/20:hover{
    background-color: rgb(255 255 255 / 0.2);
}

.hover\:bg-white\/30:hover{
    background-color: rgb(255 255 255 / 0.3);
}

.hover\:bg-yellow-100:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(254 249 195 / var(--tw-bg-opacity, 1));
}

.hover\:bg-yellow-50:hover{
    --tw-bg-opacity: 1;
    background-color: rgb(254 252 232 / var(--tw-bg-opacity, 1));
}

.hover\:from-blue-600:hover{
    --tw-gradient-from: #2563eb var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(37 99 235 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:from-green-700:hover{
    --tw-gradient-from: #15803d var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(21 128 61 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:from-orange-500\/20:hover{
    --tw-gradient-from: rgb(249 115 22 / 0.2) var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(249 115 22 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:from-pink-600:hover{
    --tw-gradient-from: #db2777 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(219 39 119 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:from-purple-600:hover{
    --tw-gradient-from: #9333ea var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(147 51 234 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:from-purple-700:hover{
    --tw-gradient-from: #7e22ce var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(126 34 206 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:from-red-600:hover{
    --tw-gradient-from: #dc2626 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(220 38 38 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:from-yellow-300:hover{
    --tw-gradient-from: #fde047 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(253 224 71 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.hover\:to-amber-400:hover{
    --tw-gradient-to: #fbbf24 var(--tw-gradient-to-position);
}

.hover\:to-blue-700:hover{
    --tw-gradient-to: #1d4ed8 var(--tw-gradient-to-position);
}

.hover\:to-indigo-700:hover{
    --tw-gradient-to: #4338ca var(--tw-gradient-to-position);
}

.hover\:to-pink-600:hover{
    --tw-gradient-to: #db2777 var(--tw-gradient-to-position);
}

.hover\:to-pink-700:hover{
    --tw-gradient-to: #be185d var(--tw-gradient-to-position);
}

.hover\:to-purple-700:hover{
    --tw-gradient-to: #7e22ce var(--tw-gradient-to-position);
}

.hover\:to-red-500\/20:hover{
    --tw-gradient-to: rgb(239 68 68 / 0.2) var(--tw-gradient-to-position);
}

.hover\:to-red-700:hover{
    --tw-gradient-to: #b91c1c var(--tw-gradient-to-position);
}

.hover\:to-rose-700:hover{
    --tw-gradient-to: #be123c var(--tw-gradient-to-position);
}

.hover\:text-accent-foreground:hover{
    color: hsl(var(--accent-foreground));
}

.hover\:text-blue-500:hover{
    --tw-text-opacity: 1;
    color: rgb(59 130 246 / var(--tw-text-opacity, 1));
}

.hover\:text-blue-600:hover{
    --tw-text-opacity: 1;
    color: rgb(37 99 235 / var(--tw-text-opacity, 1));
}

.hover\:text-destructive:hover{
    color: hsl(var(--destructive));
}

.hover\:text-destructive-foreground:hover{
    color: hsl(var(--destructive-foreground));
}

.hover\:text-foreground:hover{
    color: hsl(var(--foreground));
}

.hover\:text-gray-600:hover{
    --tw-text-opacity: 1;
    color: rgb(75 85 99 / var(--tw-text-opacity, 1));
}

.hover\:text-gray-700:hover{
    --tw-text-opacity: 1;
    color: rgb(55 65 81 / var(--tw-text-opacity, 1));
}

.hover\:text-gray-900:hover{
    --tw-text-opacity: 1;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1));
}

.hover\:text-green-500:hover{
    --tw-text-opacity: 1;
    color: rgb(34 197 94 / var(--tw-text-opacity, 1));
}

.hover\:text-green-600:hover{
    --tw-text-opacity: 1;
    color: rgb(22 163 74 / var(--tw-text-opacity, 1));
}

.hover\:text-muted-foreground:hover{
    color: hsl(var(--muted-foreground));
}

.hover\:text-orange-700:hover{
    --tw-text-opacity: 1;
    color: rgb(194 65 12 / var(--tw-text-opacity, 1));
}

.hover\:text-primary:hover{
    color: hsl(var(--primary));
}

.hover\:text-primary\/80:hover{
    color: hsl(var(--primary) / 0.8);
}

.hover\:text-purple-500:hover{
    --tw-text-opacity: 1;
    color: rgb(168 85 247 / var(--tw-text-opacity, 1));
}

.hover\:text-purple-600:hover{
    --tw-text-opacity: 1;
    color: rgb(147 51 234 / var(--tw-text-opacity, 1));
}

.hover\:text-purple-700:hover{
    --tw-text-opacity: 1;
    color: rgb(126 34 206 / var(--tw-text-opacity, 1));
}

.hover\:text-red-500:hover{
    --tw-text-opacity: 1;
    color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}

.hover\:text-red-600:hover{
    --tw-text-opacity: 1;
    color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}

.hover\:text-red-700:hover{
    --tw-text-opacity: 1;
    color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}

.hover\:text-sidebar-accent-foreground:hover{
    color: hsl(var(--sidebar-accent-foreground));
}

.hover\:text-white:hover{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.hover\:text-yellow-600:hover{
    --tw-text-opacity: 1;
    color: rgb(202 138 4 / var(--tw-text-opacity, 1));
}

.hover\:underline:hover{
    text-decoration-line: underline;
}

.hover\:opacity-100:hover{
    opacity: 1;
}

.hover\:opacity-80:hover{
    opacity: 0.8;
}

.hover\:opacity-90:hover{
    opacity: 0.9;
}

.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\]:hover{
    --tw-shadow: 0 0 0 1px hsl(var(--sidebar-accent));
    --tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_0_15px_rgba\(168\2c 85\2c 247\2c 0\.3\)\]:hover{
    --tw-shadow: 0 0 15px rgba(168,85,247,0.3);
    --tw-shadow-colored: 0 0 15px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_0_30px_-5px_hsl\(var\(--primary\)\)\]:hover{
    --tw-shadow: 0 0 30px -5px hsl(var(--primary));
    --tw-shadow-colored: 0 0 30px -5px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_0_30px_rgba\(147\2c 51\2c 234\2c 0\.5\)\]:hover{
    --tw-shadow: 0 0 30px rgba(147,51,234,0.5);
    --tw-shadow-colored: 0 0 30px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-lg:hover{
    --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-md:hover{
    --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-sm:hover{
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-xl:hover{
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:ring-2:hover{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.hover\:ring-blue-400:hover{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(96 165 250 / var(--tw-ring-opacity, 1));
}

.hover\:ring-primary:hover{
    --tw-ring-color: hsl(var(--primary));
}

.hover\:ring-purple-200:hover{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(233 213 255 / var(--tw-ring-opacity, 1));
}

.hover\:ring-purple-300:hover{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(216 180 254 / var(--tw-ring-opacity, 1));
}

.hover\:ring-purple-400:hover{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(192 132 252 / var(--tw-ring-opacity, 1));
}

.hover\:ring-red-400:hover{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(248 113 113 / var(--tw-ring-opacity, 1));
}

.hover\:ring-opacity-75:hover{
    --tw-ring-opacity: 0.75;
}

.hover\:drop-shadow-lg:hover{
    --tw-drop-shadow: drop-shadow(0 10px 8px rgb(0 0 0 / 0.04)) drop-shadow(0 4px 3px rgb(0 0 0 / 0.1));
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.hover\:after\:bg-sidebar-border:hover::after{
    content: var(--tw-content);
    background-color: hsl(var(--sidebar-border));
}

.focus\:border-transparent:focus{
    border-color: transparent;
}

.focus\:bg-accent:focus{
    background-color: hsl(var(--accent));
}

.focus\:bg-primary\/10:focus{
    background-color: hsl(var(--primary) / 0.1);
}

.focus\:text-accent-foreground:focus{
    color: hsl(var(--accent-foreground));
}

.focus\:text-amber-600:focus{
    --tw-text-opacity: 1;
    color: rgb(217 119 6 / var(--tw-text-opacity, 1));
}

.focus\:text-destructive:focus{
    color: hsl(var(--destructive));
}

.focus\:text-primary:focus{
    color: hsl(var(--primary));
}

.focus\:text-red-600:focus{
    --tw-text-opacity: 1;
    color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}

.focus\:text-red-700:focus{
    --tw-text-opacity: 1;
    color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}

.focus\:opacity-100:focus{
    opacity: 1;
}

.focus\:outline-none:focus{
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.focus\:ring-2:focus{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus\:ring-primary:focus{
    --tw-ring-color: hsl(var(--primary));
}

.focus\:ring-ring:focus{
    --tw-ring-color: hsl(var(--ring));
}

.focus\:ring-offset-2:focus{
    --tw-ring-offset-width: 2px;
}

.focus-visible\:outline-none:focus-visible{
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.focus-visible\:ring-0:focus-visible{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus-visible\:ring-1:focus-visible{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus-visible\:ring-2:focus-visible{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus-visible\:ring-green-500:focus-visible{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(34 197 94 / var(--tw-ring-opacity, 1));
}

.focus-visible\:ring-purple-500:focus-visible{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(168 85 247 / var(--tw-ring-opacity, 1));
}

.focus-visible\:ring-red-500:focus-visible{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(239 68 68 / var(--tw-ring-opacity, 1));
}

.focus-visible\:ring-ring:focus-visible{
    --tw-ring-color: hsl(var(--ring));
}

.focus-visible\:ring-sidebar-ring:focus-visible{
    --tw-ring-color: hsl(var(--sidebar-ring));
}

.focus-visible\:ring-white\/30:focus-visible{
    --tw-ring-color: rgb(255 255 255 / 0.3);
}

.focus-visible\:ring-offset-0:focus-visible{
    --tw-ring-offset-width: 0px;
}

.focus-visible\:ring-offset-1:focus-visible{
    --tw-ring-offset-width: 1px;
}

.focus-visible\:ring-offset-2:focus-visible{
    --tw-ring-offset-width: 2px;
}

.focus-visible\:ring-offset-background:focus-visible{
    --tw-ring-offset-color: hsl(var(--background));
}

.active\:scale-95:active{
    --tw-scale-x: .95;
    --tw-scale-y: .95;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.active\:scale-\[0\.98\]:active{
    --tw-scale-x: 0.98;
    --tw-scale-y: 0.98;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.active\:bg-accent\/80:active{
    background-color: hsl(var(--accent) / 0.8);
}

.active\:bg-destructive\/80:active{
    background-color: hsl(var(--destructive) / 0.8);
}

.active\:bg-primary\/80:active{
    background-color: hsl(var(--primary) / 0.8);
}

.active\:bg-secondary\/70:active{
    background-color: hsl(var(--secondary) / 0.7);
}

.active\:bg-sidebar-accent:active{
    background-color: hsl(var(--sidebar-accent));
}

.active\:bg-transparent:active{
    background-color: transparent;
}

.active\:text-primary\/80:active{
    color: hsl(var(--primary) / 0.8);
}

.active\:text-sidebar-accent-foreground:active{
    color: hsl(var(--sidebar-accent-foreground));
}

.disabled\:pointer-events-none:disabled{
    pointer-events: none;
}

.disabled\:cursor-not-allowed:disabled{
    cursor: not-allowed;
}

.disabled\:opacity-50:disabled{
    opacity: 0.5;
}

.group\/menu-item:focus-within .group-focus-within\/menu-item\:opacity-100{
    opacity: 1;
}

.group:hover .group-hover\:scale-105{
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.group:hover .group-hover\:scale-110{
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.group:hover .group-hover\:border-blue-500{
    --tw-border-opacity: 1;
    border-color: rgb(59 130 246 / var(--tw-border-opacity, 1));
}

.group:hover .group-hover\:border-green-500{
    --tw-border-opacity: 1;
    border-color: rgb(34 197 94 / var(--tw-border-opacity, 1));
}

.group:hover .group-hover\:border-primary{
    border-color: hsl(var(--primary));
}

.group:hover .group-hover\:bg-gray-50{
    --tw-bg-opacity: 1;
    background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}

.group:hover .group-hover\:bg-gradient-to-r{
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.group:hover .group-hover\:from-purple-100{
    --tw-gradient-from: #f3e8ff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(243 232 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.group:hover .group-hover\:from-purple-200{
    --tw-gradient-from: #e9d5ff var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(233 213 255 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.group:hover .group-hover\:to-blue-100{
    --tw-gradient-to: #dbeafe var(--tw-gradient-to-position);
}

.group:hover .group-hover\:to-blue-200{
    --tw-gradient-to: #bfdbfe var(--tw-gradient-to-position);
}

.group:hover .group-hover\:text-blue-500{
    --tw-text-opacity: 1;
    color: rgb(59 130 246 / var(--tw-text-opacity, 1));
}

.group:hover .group-hover\:text-destructive{
    color: hsl(var(--destructive));
}

.group:hover .group-hover\:text-gray-900{
    --tw-text-opacity: 1;
    color: rgb(17 24 39 / var(--tw-text-opacity, 1));
}

.group:hover .group-hover\:text-green-500{
    --tw-text-opacity: 1;
    color: rgb(34 197 94 / var(--tw-text-opacity, 1));
}

.group:hover .group-hover\:text-primary{
    color: hsl(var(--primary));
}

.group:hover .group-hover\:text-purple-600{
    --tw-text-opacity: 1;
    color: rgb(147 51 234 / var(--tw-text-opacity, 1));
}

.group:hover .group-hover\:text-purple-700{
    --tw-text-opacity: 1;
    color: rgb(126 34 206 / var(--tw-text-opacity, 1));
}

.group:hover .group-hover\:text-red-500{
    --tw-text-opacity: 1;
    color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}

.group:hover .group-hover\:text-white{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.group\/menu-item:hover .group-hover\/menu-item\:opacity-100{
    opacity: 1;
}

.group:hover .group-hover\:opacity-100{
    opacity: 1;
}

.group:hover .group-hover\:opacity-5{
    opacity: 0.05;
}

.group:hover .group-hover\:opacity-60{
    opacity: 0.6;
}

.group.destructive .group-\[\.destructive\]\:border-muted\/40{
    border-color: hsl(var(--muted) / 0.4);
}

.group.destructive .group-\[\.destructive\]\:text-red-300{
    --tw-text-opacity: 1;
    color: rgb(252 165 165 / var(--tw-text-opacity, 1));
}

.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover{
    border-color: hsl(var(--destructive) / 0.3);
}

.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover{
    background-color: hsl(var(--destructive));
}

.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover{
    color: hsl(var(--destructive-foreground));
}

.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover{
    --tw-text-opacity: 1;
    color: rgb(254 242 242 / var(--tw-text-opacity, 1));
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus{
    --tw-ring-color: hsl(var(--destructive));
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus{
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(248 113 113 / var(--tw-ring-opacity, 1));
}

.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus{
    --tw-ring-offset-color: #dc2626;
}

.peer\/menu-button:hover ~ .peer-hover\/menu-button\:text-sidebar-accent-foreground{
    color: hsl(var(--sidebar-accent-foreground));
}

.peer:disabled ~ .peer-disabled\:cursor-not-allowed{
    cursor: not-allowed;
}

.peer:disabled ~ .peer-disabled\:opacity-70{
    opacity: 0.7;
}

.has-\[\[data-variant\=inset\]\]\:bg-sidebar:has([data-variant=inset]){
    background-color: hsl(var(--sidebar-background));
}

.has-\[\:disabled\]\:opacity-50:has(:disabled){
    opacity: 0.5;
}

.group\/menu-item:has([data-sidebar=menu-action]) .group-has-\[\[data-sidebar\=menu-action\]\]\/menu-item\:pr-8{
    padding-right: 2rem;
}

.aria-disabled\:pointer-events-none[aria-disabled="true"]{
    pointer-events: none;
}

.aria-disabled\:opacity-50[aria-disabled="true"]{
    opacity: 0.5;
}

.aria-selected\:bg-accent[aria-selected="true"]{
    background-color: hsl(var(--accent));
}

.aria-selected\:bg-primary\/5[aria-selected="true"]{
    background-color: hsl(var(--primary) / 0.05);
}

.aria-selected\:text-accent-foreground[aria-selected="true"]{
    color: hsl(var(--accent-foreground));
}

.aria-selected\:text-muted-foreground[aria-selected="true"]{
    color: hsl(var(--muted-foreground));
}

.aria-selected\:opacity-100[aria-selected="true"]{
    opacity: 1;
}

.aria-selected\:opacity-20[aria-selected="true"]{
    opacity: 0.2;
}

.data-\[disabled\=true\]\:pointer-events-none[data-disabled="true"]{
    pointer-events: none;
}

.data-\[disabled\]\:pointer-events-none[data-disabled]{
    pointer-events: none;
}

.data-\[panel-group-direction\=vertical\]\:h-px[data-panel-group-direction="vertical"]{
    height: 1px;
}

.data-\[panel-group-direction\=vertical\]\:w-full[data-panel-group-direction="vertical"]{
    width: 100%;
}

.data-\[side\=bottom\]\:translate-y-1[data-side="bottom"]{
    --tw-translate-y: 0.25rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[side\=left\]\:-translate-x-1[data-side="left"]{
    --tw-translate-x: -0.25rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[side\=right\]\:translate-x-1[data-side="right"]{
    --tw-translate-x: 0.25rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[side\=top\]\:-translate-y-1[data-side="top"]{
    --tw-translate-y: -0.25rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[state\=checked\]\:translate-x-5[data-state="checked"]{
    --tw-translate-x: 1.25rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[state\=unchecked\]\:translate-x-0[data-state="unchecked"]{
    --tw-translate-x: 0px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[swipe\=cancel\]\:translate-x-0[data-swipe="cancel"]{
    --tw-translate-x: 0px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe="end"]{
    --tw-translate-x: var(--radix-toast-swipe-end-x);
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe="move"]{
    --tw-translate-x: var(--radix-toast-swipe-move-x);
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

@keyframes accordion-up{

    from{
        height: var(--radix-accordion-content-height);
    }

    to{
        height: 0;
    }
}

.data-\[state\=closed\]\:animate-accordion-up[data-state="closed"]{
    animation: accordion-up 0.2s ease-out;
}

@keyframes accordion-down{

    from{
        height: 0;
    }

    to{
        height: var(--radix-accordion-content-height);
    }
}

.data-\[state\=open\]\:animate-accordion-down[data-state="open"]{
    animation: accordion-down 0.2s ease-out;
}

.data-\[panel-group-direction\=vertical\]\:flex-col[data-panel-group-direction="vertical"]{
    flex-direction: column;
}

.data-\[state\=checked\]\:border-primary[data-state="checked"]{
    border-color: hsl(var(--primary));
}

.data-\[state\=on\]\:border-primary[data-state="on"]{
    border-color: hsl(var(--primary));
}

.data-\[state\=unchecked\]\:border-border[data-state="unchecked"]{
    border-color: hsl(var(--border));
}

.data-\[active\=true\]\:bg-sidebar-accent[data-active="true"]{
    background-color: hsl(var(--sidebar-accent));
}

.data-\[active\]\:bg-accent\/50[data-active]{
    background-color: hsl(var(--accent) / 0.5);
}

.data-\[selected\=\'true\'\]\:bg-accent[data-selected='true']{
    background-color: hsl(var(--accent));
}

.data-\[state\=active\]\:bg-background[data-state="active"]{
    background-color: hsl(var(--background));
}

.data-\[state\=active\]\:bg-muted[data-state="active"]{
    background-color: hsl(var(--muted));
}

.data-\[state\=active\]\:bg-primary[data-state="active"]{
    background-color: hsl(var(--primary));
}

.data-\[state\=checked\]\:bg-green-500[data-state="checked"]{
    --tw-bg-opacity: 1;
    background-color: rgb(34 197 94 / var(--tw-bg-opacity, 1));
}

.data-\[state\=checked\]\:bg-primary[data-state="checked"]{
    background-color: hsl(var(--primary));
}

.data-\[state\=checked\]\:bg-primary-foreground[data-state="checked"]{
    background-color: hsl(var(--primary-foreground));
}

.data-\[state\=on\]\:bg-accent[data-state="on"]{
    background-color: hsl(var(--accent));
}

.data-\[state\=on\]\:bg-muted\/60[data-state="on"]{
    background-color: hsl(var(--muted) / 0.6);
}

.data-\[state\=open\]\:bg-accent[data-state="open"]{
    background-color: hsl(var(--accent));
}

.data-\[state\=open\]\:bg-accent\/50[data-state="open"]{
    background-color: hsl(var(--accent) / 0.5);
}

.data-\[state\=open\]\:bg-secondary[data-state="open"]{
    background-color: hsl(var(--secondary));
}

.data-\[state\=selected\]\:bg-muted[data-state="selected"]{
    background-color: hsl(var(--muted));
}

.data-\[state\=unchecked\]\:bg-muted[data-state="unchecked"]{
    background-color: hsl(var(--muted));
}

.data-\[state\=unchecked\]\:bg-red-500[data-state="unchecked"]{
    --tw-bg-opacity: 1;
    background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}

.data-\[state\=active\]\:bg-gradient-to-r[data-state="active"]{
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.data-\[state\=checked\]\:bg-gradient-to-r[data-state="checked"]{
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.data-\[state\=active\]\:from-blue-500[data-state="active"]{
    --tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.data-\[state\=checked\]\:from-purple-600[data-state="checked"]{
    --tw-gradient-from: #9333ea var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(147 51 234 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.data-\[state\=active\]\:to-purple-500[data-state="active"]{
    --tw-gradient-to: #a855f7 var(--tw-gradient-to-position);
}

.data-\[state\=checked\]\:to-pink-600[data-state="checked"]{
    --tw-gradient-to: #db2777 var(--tw-gradient-to-position);
}

.data-\[active\=true\]\:font-medium[data-active="true"]{
    font-weight: 500;
}

.data-\[active\=true\]\:text-sidebar-accent-foreground[data-active="true"]{
    color: hsl(var(--sidebar-accent-foreground));
}

.data-\[selected\=true\]\:text-accent-foreground[data-selected="true"]{
    color: hsl(var(--accent-foreground));
}

.data-\[state\=active\]\:text-foreground[data-state="active"]{
    color: hsl(var(--foreground));
}

.data-\[state\=active\]\:text-primary-foreground[data-state="active"]{
    color: hsl(var(--primary-foreground));
}

.data-\[state\=active\]\:text-white[data-state="active"]{
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.data-\[state\=checked\]\:text-primary-foreground[data-state="checked"]{
    color: hsl(var(--primary-foreground));
}

.data-\[state\=on\]\:text-accent-foreground[data-state="on"]{
    color: hsl(var(--accent-foreground));
}

.data-\[state\=open\]\:text-accent-foreground[data-state="open"]{
    color: hsl(var(--accent-foreground));
}

.data-\[state\=open\]\:text-muted-foreground[data-state="open"]{
    color: hsl(var(--muted-foreground));
}

.data-\[disabled\=true\]\:opacity-50[data-disabled="true"]{
    opacity: 0.5;
}

.data-\[disabled\]\:opacity-50[data-disabled]{
    opacity: 0.5;
}

.data-\[state\=open\]\:opacity-100[data-state="open"]{
    opacity: 1;
}

.data-\[state\=active\]\:shadow-md[data-state="active"]{
    --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.data-\[state\=on\]\:shadow-\[0_0_16px_hsl\(var\(--primary\)\/0\.6\)\][data-state="on"]{
    --tw-shadow: 0 0 16px hsl(var(--primary)/0.6);
    --tw-shadow-colored: 0 0 16px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.data-\[state\=on\]\:shadow-sm[data-state="on"]{
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.data-\[state\=on\]\:ring-2[data-state="on"]{
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.data-\[state\=on\]\:ring-primary\/30[data-state="on"]{
    --tw-ring-color: hsl(var(--primary) / 0.3);
}

.data-\[state\=on\]\:ring-offset-2[data-state="on"]{
    --tw-ring-offset-width: 2px;
}

.data-\[state\=on\]\:ring-offset-transparent[data-state="on"]{
    --tw-ring-offset-color: transparent;
}

.data-\[swipe\=move\]\:transition-none[data-swipe="move"]{
    transition-property: none;
}

.data-\[state\=closed\]\:duration-300[data-state="closed"]{
    transition-duration: 300ms;
}

.data-\[state\=open\]\:duration-500[data-state="open"]{
    transition-duration: 500ms;
}

.data-\[motion\^\=from-\]\:animate-in[data-motion^="from-"]{
    animation-name: enter;
    animation-duration: 150ms;
    --tw-enter-opacity: initial;
    --tw-enter-scale: initial;
    --tw-enter-rotate: initial;
    --tw-enter-translate-x: initial;
    --tw-enter-translate-y: initial;
}

.data-\[state\=open\]\:animate-in[data-state="open"]{
    animation-name: enter;
    animation-duration: 150ms;
    --tw-enter-opacity: initial;
    --tw-enter-scale: initial;
    --tw-enter-rotate: initial;
    --tw-enter-translate-x: initial;
    --tw-enter-translate-y: initial;
}

.data-\[state\=visible\]\:animate-in[data-state="visible"]{
    animation-name: enter;
    animation-duration: 150ms;
    --tw-enter-opacity: initial;
    --tw-enter-scale: initial;
    --tw-enter-rotate: initial;
    --tw-enter-translate-x: initial;
    --tw-enter-translate-y: initial;
}

.data-\[motion\^\=to-\]\:animate-out[data-motion^="to-"]{
    animation-name: exit;
    animation-duration: 150ms;
    --tw-exit-opacity: initial;
    --tw-exit-scale: initial;
    --tw-exit-rotate: initial;
    --tw-exit-translate-x: initial;
    --tw-exit-translate-y: initial;
}

.data-\[state\=closed\]\:animate-out[data-state="closed"]{
    animation-name: exit;
    animation-duration: 150ms;
    --tw-exit-opacity: initial;
    --tw-exit-scale: initial;
    --tw-exit-rotate: initial;
    --tw-exit-translate-x: initial;
    --tw-exit-translate-y: initial;
}

.data-\[state\=hidden\]\:animate-out[data-state="hidden"]{
    animation-name: exit;
    animation-duration: 150ms;
    --tw-exit-opacity: initial;
    --tw-exit-scale: initial;
    --tw-exit-rotate: initial;
    --tw-exit-translate-x: initial;
    --tw-exit-translate-y: initial;
}

.data-\[swipe\=end\]\:animate-out[data-swipe="end"]{
    animation-name: exit;
    animation-duration: 150ms;
    --tw-exit-opacity: initial;
    --tw-exit-scale: initial;
    --tw-exit-rotate: initial;
    --tw-exit-translate-x: initial;
    --tw-exit-translate-y: initial;
}

.data-\[motion\^\=from-\]\:fade-in[data-motion^="from-"]{
    --tw-enter-opacity: 0;
}

.data-\[motion\^\=to-\]\:fade-out[data-motion^="to-"]{
    --tw-exit-opacity: 0;
}

.data-\[state\=closed\]\:fade-out-0[data-state="closed"]{
    --tw-exit-opacity: 0;
}

.data-\[state\=closed\]\:fade-out-80[data-state="closed"]{
    --tw-exit-opacity: 0.8;
}

.data-\[state\=hidden\]\:fade-out[data-state="hidden"]{
    --tw-exit-opacity: 0;
}

.data-\[state\=open\]\:fade-in-0[data-state="open"]{
    --tw-enter-opacity: 0;
}

.data-\[state\=visible\]\:fade-in[data-state="visible"]{
    --tw-enter-opacity: 0;
}

.data-\[state\=closed\]\:zoom-out-95[data-state="closed"]{
    --tw-exit-scale: .95;
}

.data-\[state\=open\]\:zoom-in-90[data-state="open"]{
    --tw-enter-scale: .9;
}

.data-\[state\=open\]\:zoom-in-95[data-state="open"]{
    --tw-enter-scale: .95;
}

.data-\[motion\=from-end\]\:slide-in-from-right-52[data-motion="from-end"]{
    --tw-enter-translate-x: 13rem;
}

.data-\[motion\=from-start\]\:slide-in-from-left-52[data-motion="from-start"]{
    --tw-enter-translate-x: -13rem;
}

.data-\[motion\=to-end\]\:slide-out-to-right-52[data-motion="to-end"]{
    --tw-exit-translate-x: 13rem;
}

.data-\[motion\=to-start\]\:slide-out-to-left-52[data-motion="to-start"]{
    --tw-exit-translate-x: -13rem;
}

.data-\[side\=bottom\]\:slide-in-from-top-2[data-side="bottom"]{
    --tw-enter-translate-y: -0.5rem;
}

.data-\[side\=left\]\:slide-in-from-right-2[data-side="left"]{
    --tw-enter-translate-x: 0.5rem;
}

.data-\[side\=right\]\:slide-in-from-left-2[data-side="right"]{
    --tw-enter-translate-x: -0.5rem;
}

.data-\[side\=top\]\:slide-in-from-bottom-2[data-side="top"]{
    --tw-enter-translate-y: 0.5rem;
}

.data-\[state\=closed\]\:slide-out-to-bottom[data-state="closed"]{
    --tw-exit-translate-y: 100%;
}

.data-\[state\=closed\]\:slide-out-to-left[data-state="closed"]{
    --tw-exit-translate-x: -100%;
}

.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state="closed"]{
    --tw-exit-translate-x: -50%;
}

.data-\[state\=closed\]\:slide-out-to-right[data-state="closed"]{
    --tw-exit-translate-x: 100%;
}

.data-\[state\=closed\]\:slide-out-to-right-full[data-state="closed"]{
    --tw-exit-translate-x: 100%;
}

.data-\[state\=closed\]\:slide-out-to-top[data-state="closed"]{
    --tw-exit-translate-y: -100%;
}

.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state="closed"]{
    --tw-exit-translate-y: -48%;
}

.data-\[state\=open\]\:slide-in-from-bottom[data-state="open"]{
    --tw-enter-translate-y: 100%;
}

.data-\[state\=open\]\:slide-in-from-left[data-state="open"]{
    --tw-enter-translate-x: -100%;
}

.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state="open"]{
    --tw-enter-translate-x: -50%;
}

.data-\[state\=open\]\:slide-in-from-right[data-state="open"]{
    --tw-enter-translate-x: 100%;
}

.data-\[state\=open\]\:slide-in-from-top[data-state="open"]{
    --tw-enter-translate-y: -100%;
}

.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state="open"]{
    --tw-enter-translate-y: -48%;
}

.data-\[state\=open\]\:slide-in-from-top-full[data-state="open"]{
    --tw-enter-translate-y: -100%;
}

.data-\[state\=closed\]\:duration-300[data-state="closed"]{
    animation-duration: 300ms;
}

.data-\[state\=open\]\:duration-500[data-state="open"]{
    animation-duration: 500ms;
}

.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction="vertical"]::after{
    content: var(--tw-content);
    left: 0px;
}

.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction="vertical"]::after{
    content: var(--tw-content);
    height: 0.25rem;
}

.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction="vertical"]::after{
    content: var(--tw-content);
    width: 100%;
}

.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction="vertical"]::after{
    content: var(--tw-content);
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction="vertical"]::after{
    content: var(--tw-content);
    --tw-translate-x: 0px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.data-\[state\=inactive\]\:hover\:bg-muted-foreground\/10:hover[data-state="inactive"]{
    background-color: hsl(var(--muted-foreground) / 0.1);
}

.data-\[state\=open\]\:hover\:bg-sidebar-accent:hover[data-state="open"]{
    background-color: hsl(var(--sidebar-accent));
}

.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground:hover[data-state="open"]{
    color: hsl(var(--sidebar-accent-foreground));
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:left-\[calc\(var\(--sidebar-width\)\*-1\)\]{
    left: calc(var(--sidebar-width) * -1);
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:right-\[calc\(var\(--sidebar-width\)\*-1\)\]{
    right: calc(var(--sidebar-width) * -1);
}

.group[data-side="left"] .group-data-\[side\=left\]\:-right-4{
    right: -1rem;
}

.group[data-side="right"] .group-data-\[side\=right\]\:left-0{
    left: 0px;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:-mt-8{
    margin-top: -2rem;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:hidden{
    display: none;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:\!size-8{
    width: 2rem !important;
    height: 2rem !important;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:w-\[--sidebar-width-icon\]{
    width: var(--sidebar-width-icon);
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)\)\]{
    width: calc(var(--sidebar-width-icon) + 1rem);
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)_\+2px\)\]{
    width: calc(var(--sidebar-width-icon) + 1rem + 2px);
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:w-0{
    width: 0px;
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:translate-x-0{
    --tw-translate-x: 0px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.group[data-side="right"] .group-data-\[side\=right\]\:rotate-180{
    --tw-rotate: 180deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.group[data-state="open"] .group-data-\[state\=open\]\:rotate-180{
    --tw-rotate: 180deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:overflow-hidden{
    overflow: hidden;
}

.group[data-variant="floating"] .group-data-\[variant\=floating\]\:rounded-lg{
    border-radius: var(--radius);
}

.group[data-variant="floating"] .group-data-\[variant\=floating\]\:border{
    border-width: 1px;
}

.group[data-side="left"] .group-data-\[side\=left\]\:border-r{
    border-right-width: 1px;
}

.group[data-side="right"] .group-data-\[side\=right\]\:border-l{
    border-left-width: 1px;
}

.group[data-variant="floating"] .group-data-\[variant\=floating\]\:border-sidebar-border{
    border-color: hsl(var(--sidebar-border));
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:\!p-0{
    padding: 0px !important;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:\!p-2{
    padding: 0.5rem !important;
}

.group[data-collapsible="icon"] .group-data-\[collapsible\=icon\]\:opacity-0{
    opacity: 0;
}

.group[data-variant="floating"] .group-data-\[variant\=floating\]\:shadow{
    --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:after\:left-full::after{
    content: var(--tw-content);
    left: 100%;
}

.group[data-collapsible="offcanvas"] .group-data-\[collapsible\=offcanvas\]\:hover\:bg-sidebar:hover{
    background-color: hsl(var(--sidebar-background));
}

.peer\/menu-button[data-size="default"] ~ .peer-data-\[size\=default\]\/menu-button\:top-1\.5{
    top: 0.375rem;
}

.peer\/menu-button[data-size="lg"] ~ .peer-data-\[size\=lg\]\/menu-button\:top-2\.5{
    top: 0.625rem;
}

.peer\/menu-button[data-size="sm"] ~ .peer-data-\[size\=sm\]\/menu-button\:top-1{
    top: 0.25rem;
}

.peer[data-variant="inset"] ~ .peer-data-\[variant\=inset\]\:min-h-\[calc\(100svh-theme\(spacing\.4\)\)\]{
    min-height: calc(100svh - 1rem);
}

.peer\/menu-button[data-active="true"] ~ .peer-data-\[active\=true\]\/menu-button\:text-sidebar-accent-foreground{
    color: hsl(var(--sidebar-accent-foreground));
}

@supports ((-webkit-backdrop-filter: var(--tw)) or (backdrop-filter: var(--tw))){

    .supports-\[backdrop-filter\]\:bg-background\/60{
        background-color: hsl(var(--background) / 0.6);
    }
}

.dark\:border-blue-800:is(.dark *){
    --tw-border-opacity: 1;
    border-color: rgb(30 64 175 / var(--tw-border-opacity, 1));
}

.dark\:border-blue-900:is(.dark *){
    --tw-border-opacity: 1;
    border-color: rgb(30 58 138 / var(--tw-border-opacity, 1));
}

.dark\:border-destructive:is(.dark *){
    border-color: hsl(var(--destructive));
}

.dark\:border-emerald-800\/30:is(.dark *){
    border-color: rgb(6 95 70 / 0.3);
}

.dark\:border-green-800:is(.dark *){
    --tw-border-opacity: 1;
    border-color: rgb(22 101 52 / var(--tw-border-opacity, 1));
}

.dark\:border-indigo-800\/50:is(.dark *){
    border-color: rgb(55 48 163 / 0.5);
}

.dark\:border-orange-800:is(.dark *){
    --tw-border-opacity: 1;
    border-color: rgb(154 52 18 / var(--tw-border-opacity, 1));
}

.dark\:border-red-800\/30:is(.dark *){
    border-color: rgb(153 27 27 / 0.3);
}

.dark\:bg-amber-950:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(69 26 3 / var(--tw-bg-opacity, 1));
}

.dark\:bg-black:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}

.dark\:bg-blue-900\/20:is(.dark *){
    background-color: rgb(30 58 138 / 0.2);
}

.dark\:bg-blue-950:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(23 37 84 / var(--tw-bg-opacity, 1));
}

.dark\:bg-blue-950\/20:is(.dark *){
    background-color: rgb(23 37 84 / 0.2);
}

.dark\:bg-cyan-900\/20:is(.dark *){
    background-color: rgb(22 78 99 / 0.2);
}

.dark\:bg-emerald-950:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(2 44 34 / var(--tw-bg-opacity, 1));
}

.dark\:bg-emerald-950\/30:is(.dark *){
    background-color: rgb(2 44 34 / 0.3);
}

.dark\:bg-fuchsia-900\/20:is(.dark *){
    background-color: rgb(112 26 117 / 0.2);
}

.dark\:bg-gray-800:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}

.dark\:bg-gray-900\/20:is(.dark *){
    background-color: rgb(17 24 39 / 0.2);
}

.dark\:bg-green-900\/20:is(.dark *){
    background-color: rgb(20 83 45 / 0.2);
}

.dark\:bg-green-900\/30:is(.dark *){
    background-color: rgb(20 83 45 / 0.3);
}

.dark\:bg-green-950:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(5 46 22 / var(--tw-bg-opacity, 1));
}

.dark\:bg-indigo-900\/20:is(.dark *){
    background-color: rgb(49 46 129 / 0.2);
}

.dark\:bg-muted\/20:is(.dark *){
    background-color: hsl(var(--muted) / 0.2);
}

.dark\:bg-orange-900\/20:is(.dark *){
    background-color: rgb(124 45 18 / 0.2);
}

.dark\:bg-pink-900\/20:is(.dark *){
    background-color: rgb(131 24 67 / 0.2);
}

.dark\:bg-purple-900\/20:is(.dark *){
    background-color: rgb(88 28 135 / 0.2);
}

.dark\:bg-purple-950:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(59 7 100 / var(--tw-bg-opacity, 1));
}

.dark\:bg-red-400:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(248 113 113 / var(--tw-bg-opacity, 1));
}

.dark\:bg-red-900\/20:is(.dark *){
    background-color: rgb(127 29 29 / 0.2);
}

.dark\:bg-red-950:is(.dark *){
    --tw-bg-opacity: 1;
    background-color: rgb(69 10 10 / var(--tw-bg-opacity, 1));
}

.dark\:bg-red-950\/30:is(.dark *){
    background-color: rgb(69 10 10 / 0.3);
}

.dark\:bg-slate-900\/20:is(.dark *){
    background-color: rgb(15 23 42 / 0.2);
}

.dark\:bg-teal-900\/20:is(.dark *){
    background-color: rgb(19 78 74 / 0.2);
}

.dark\:bg-violet-900\/20:is(.dark *){
    background-color: rgb(76 29 149 / 0.2);
}

.dark\:bg-yellow-900\/20:is(.dark *){
    background-color: rgb(113 63 18 / 0.2);
}

.dark\:bg-yellow-950\/20:is(.dark *){
    background-color: rgb(66 32 6 / 0.2);
}

.dark\:bg-zinc-900\/20:is(.dark *){
    background-color: rgb(24 24 27 / 0.2);
}

.dark\:text-amber-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.dark\:text-blue-100:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(219 234 254 / var(--tw-text-opacity, 1));
}

.dark\:text-blue-200:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(191 219 254 / var(--tw-text-opacity, 1));
}

.dark\:text-blue-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(147 197 253 / var(--tw-text-opacity, 1));
}

.dark\:text-blue-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(96 165 250 / var(--tw-text-opacity, 1));
}

.dark\:text-cyan-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(103 232 249 / var(--tw-text-opacity, 1));
}

.dark\:text-cyan-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(34 211 238 / var(--tw-text-opacity, 1));
}

.dark\:text-emerald-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(52 211 153 / var(--tw-text-opacity, 1));
}

.dark\:text-fuchsia-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(240 171 252 / var(--tw-text-opacity, 1));
}

.dark\:text-gray-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}

.dark\:text-gray-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}

.dark\:text-green-100:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(220 252 231 / var(--tw-text-opacity, 1));
}

.dark\:text-green-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(134 239 172 / var(--tw-text-opacity, 1));
}

.dark\:text-green-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}

.dark\:text-indigo-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(165 180 252 / var(--tw-text-opacity, 1));
}

.dark\:text-orange-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(253 186 116 / var(--tw-text-opacity, 1));
}

.dark\:text-orange-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(251 146 60 / var(--tw-text-opacity, 1));
}

.dark\:text-pink-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(249 168 212 / var(--tw-text-opacity, 1));
}

.dark\:text-purple-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(216 180 254 / var(--tw-text-opacity, 1));
}

.dark\:text-purple-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(192 132 252 / var(--tw-text-opacity, 1));
}

.dark\:text-red-100:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(254 226 226 / var(--tw-text-opacity, 1));
}

.dark\:text-red-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(252 165 165 / var(--tw-text-opacity, 1));
}

.dark\:text-red-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.dark\:text-rose-400:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(251 113 133 / var(--tw-text-opacity, 1));
}

.dark\:text-slate-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(203 213 225 / var(--tw-text-opacity, 1));
}

.dark\:text-teal-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(94 234 212 / var(--tw-text-opacity, 1));
}

.dark\:text-violet-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(196 181 253 / var(--tw-text-opacity, 1));
}

.dark\:text-white:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.dark\:text-yellow-100:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(254 249 195 / var(--tw-text-opacity, 1));
}

.dark\:text-yellow-200:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(254 240 138 / var(--tw-text-opacity, 1));
}

.dark\:text-yellow-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(253 224 71 / var(--tw-text-opacity, 1));
}

.dark\:text-zinc-300:is(.dark *){
    --tw-text-opacity: 1;
    color: rgb(212 212 216 / var(--tw-text-opacity, 1));
}

.dark\:hover\:bg-yellow-900\/30:hover:is(.dark *){
    background-color: rgb(113 63 18 / 0.3);
}

@media (min-width: 640px){

    .sm\:not-sr-only{
        position: static;
        width: auto;
        height: auto;
        padding: 0;
        margin: 0;
        overflow: visible;
        clip: auto;
        white-space: normal;
    }

    .sm\:bottom-0{
        bottom: 0px;
    }

    .sm\:bottom-2{
        bottom: 0.5rem;
    }

    .sm\:right-0{
        right: 0px;
    }

    .sm\:right-\[-30px\]{
        right: -30px;
    }

    .sm\:top-\[12px\]{
        top: 12px;
    }

    .sm\:top-auto{
        top: auto;
    }

    .sm\:mb-0{
        margin-bottom: 0px;
    }

    .sm\:mb-20{
        margin-bottom: 5rem;
    }

    .sm\:mb-3{
        margin-bottom: 0.75rem;
    }

    .sm\:mb-4{
        margin-bottom: 1rem;
    }

    .sm\:mb-6{
        margin-bottom: 1.5rem;
    }

    .sm\:ml-4{
        margin-left: 1rem;
    }

    .sm\:mr-1\.5{
        margin-right: 0.375rem;
    }

    .sm\:mr-2{
        margin-right: 0.5rem;
    }

    .sm\:mr-3{
        margin-right: 0.75rem;
    }

    .sm\:mt-0{
        margin-top: 0px;
    }

    .sm\:mt-1{
        margin-top: 0.25rem;
    }

    .sm\:mt-8{
        margin-top: 2rem;
    }

    .sm\:block{
        display: block;
    }

    .sm\:inline-block{
        display: inline-block;
    }

    .sm\:inline{
        display: inline;
    }

    .sm\:flex{
        display: flex;
    }

    .sm\:hidden{
        display: none;
    }

    .sm\:h-10{
        height: 2.5rem;
    }

    .sm\:h-12{
        height: 3rem;
    }

    .sm\:h-16{
        height: 4rem;
    }

    .sm\:h-20{
        height: 5rem;
    }

    .sm\:h-24{
        height: 6rem;
    }

    .sm\:h-4{
        height: 1rem;
    }

    .sm\:h-48{
        height: 12rem;
    }

    .sm\:h-5{
        height: 1.25rem;
    }

    .sm\:h-56{
        height: 14rem;
    }

    .sm\:h-8{
        height: 2rem;
    }

    .sm\:h-9{
        height: 2.25rem;
    }

    .sm\:h-\[480px\]{
        height: 480px;
    }

    .sm\:min-h-\[110px\]{
        min-height: 110px;
    }

    .sm\:w-12{
        width: 3rem;
    }

    .sm\:w-16{
        width: 4rem;
    }

    .sm\:w-20{
        width: 5rem;
    }

    .sm\:w-24{
        width: 6rem;
    }

    .sm\:w-32{
        width: 8rem;
    }

    .sm\:w-4{
        width: 1rem;
    }

    .sm\:w-40{
        width: 10rem;
    }

    .sm\:w-5{
        width: 1.25rem;
    }

    .sm\:w-8{
        width: 2rem;
    }

    .sm\:w-96{
        width: 24rem;
    }

    .sm\:w-\[120px\]{
        width: 120px;
    }

    .sm\:w-auto{
        width: auto;
    }

    .sm\:max-w-2xl{
        max-width: 42rem;
    }

    .sm\:max-w-\[500px\]{
        max-width: 500px;
    }

    .sm\:max-w-\[800px\]{
        max-width: 800px;
    }

    .sm\:max-w-lg{
        max-width: 32rem;
    }

    .sm\:max-w-md{
        max-width: 28rem;
    }

    .sm\:max-w-sm{
        max-width: 24rem;
    }

    .sm\:flex-initial{
        flex: 0 1 auto;
    }

    .sm\:flex-shrink-0{
        flex-shrink: 0;
    }

    .sm\:basis-1\/3{
        flex-basis: 33.333333%;
    }

    .sm\:basis-1\/4{
        flex-basis: 25%;
    }

    .sm\:scale-\[0\.6\]{
        --tw-scale-x: 0.6;
        --tw-scale-y: 0.6;
        transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    }

    .sm\:grid-cols-2{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .sm\:grid-cols-3{
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .sm\:grid-cols-4{
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .sm\:grid-cols-6{
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .sm\:flex-row{
        flex-direction: row;
    }

    .sm\:flex-col{
        flex-direction: column;
    }

    .sm\:items-start{
        align-items: flex-start;
    }

    .sm\:items-end{
        align-items: flex-end;
    }

    .sm\:items-center{
        align-items: center;
    }

    .sm\:justify-start{
        justify-content: flex-start;
    }

    .sm\:justify-end{
        justify-content: flex-end;
    }

    .sm\:justify-between{
        justify-content: space-between;
    }

    .sm\:gap-2{
        gap: 0.5rem;
    }

    .sm\:gap-2\.5{
        gap: 0.625rem;
    }

    .sm\:gap-3{
        gap: 0.75rem;
    }

    .sm\:gap-4{
        gap: 1rem;
    }

    .sm\:gap-6{
        gap: 1.5rem;
    }

    .sm\:space-x-2 > :not([hidden]) ~ :not([hidden]){
        --tw-space-x-reverse: 0;
        margin-right: calc(0.5rem * var(--tw-space-x-reverse));
        margin-left: calc(0.5rem * calc(1 - var(--tw-space-x-reverse)));
    }

    .sm\:space-x-3 > :not([hidden]) ~ :not([hidden]){
        --tw-space-x-reverse: 0;
        margin-right: calc(0.75rem * var(--tw-space-x-reverse));
        margin-left: calc(0.75rem * calc(1 - var(--tw-space-x-reverse)));
    }

    .sm\:space-x-4 > :not([hidden]) ~ :not([hidden]){
        --tw-space-x-reverse: 0;
        margin-right: calc(1rem * var(--tw-space-x-reverse));
        margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse)));
    }

    .sm\:space-y-0 > :not([hidden]) ~ :not([hidden]){
        --tw-space-y-reverse: 0;
        margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse)));
        margin-bottom: calc(0px * var(--tw-space-y-reverse));
    }

    .sm\:space-y-1 > :not([hidden]) ~ :not([hidden]){
        --tw-space-y-reverse: 0;
        margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse)));
        margin-bottom: calc(0.25rem * var(--tw-space-y-reverse));
    }

    .sm\:space-y-2 > :not([hidden]) ~ :not([hidden]){
        --tw-space-y-reverse: 0;
        margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
        margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
    }

    .sm\:space-y-3 > :not([hidden]) ~ :not([hidden]){
        --tw-space-y-reverse: 0;
        margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
        margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
    }

    .sm\:space-y-4 > :not([hidden]) ~ :not([hidden]){
        --tw-space-y-reverse: 0;
        margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
        margin-bottom: calc(1rem * var(--tw-space-y-reverse));
    }

    .sm\:space-y-6 > :not([hidden]) ~ :not([hidden]){
        --tw-space-y-reverse: 0;
        margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
        margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
    }

    .sm\:rounded-lg{
        border-radius: var(--radius);
    }

    .sm\:p-3{
        padding: 0.75rem;
    }

    .sm\:p-4{
        padding: 1rem;
    }

    .sm\:p-6{
        padding: 1.5rem;
    }

    .sm\:px-2{
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }

    .sm\:px-3{
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

    .sm\:px-4{
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .sm\:px-6{
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }

    .sm\:py-1{
        padding-top: 0.25rem;
        padding-bottom: 0.25rem;
    }

    .sm\:py-12{
        padding-top: 3rem;
        padding-bottom: 3rem;
    }

    .sm\:py-3{
        padding-top: 0.75rem;
        padding-bottom: 0.75rem;
    }

    .sm\:py-4{
        padding-top: 1rem;
        padding-bottom: 1rem;
    }

    .sm\:pl-3{
        padding-left: 0.75rem;
    }

    .sm\:pt-2{
        padding-top: 0.5rem;
    }

    .sm\:pt-6{
        padding-top: 1.5rem;
    }

    .sm\:text-left{
        text-align: left;
    }

    .sm\:text-2xl{
        font-size: 1.5rem;
        line-height: 2rem;
    }

    .sm\:text-\[9px\]{
        font-size: 9px;
    }

    .sm\:text-base{
        font-size: 1rem;
        line-height: 1.5rem;
    }

    .sm\:text-lg{
        font-size: 1.125rem;
        line-height: 1.75rem;
    }

    .sm\:text-sm{
        font-size: 0.875rem;
        line-height: 1.25rem;
    }

    .sm\:text-xl{
        font-size: 1.25rem;
        line-height: 1.75rem;
    }

    .sm\:text-xs{
        font-size: 0.75rem;
        line-height: 1rem;
    }

    .data-\[state\=open\]\:sm\:slide-in-from-bottom-full[data-state="open"]{
        --tw-enter-translate-y: 100%;
    }
}

@media (min-width: 768px){

    .md\:absolute{
        position: absolute;
    }

    .md\:right-\[-35px\]{
        right: -35px;
    }

    .md\:top-\[15px\]{
        top: 15px;
    }

    .md\:col-span-2{
        grid-column: span 2 / span 2;
    }

    .md\:-ml-4{
        margin-left: -1rem;
    }

    .md\:mt-16{
        margin-top: 4rem;
    }

    .md\:block{
        display: block;
    }

    .md\:flex{
        display: flex;
    }

    .md\:hidden{
        display: none;
    }

    .md\:aspect-\[4\/3\]{
        aspect-ratio: 4/3;
    }

    .md\:h-24{
        height: 6rem;
    }

    .md\:h-40{
        height: 10rem;
    }

    .md\:h-64{
        height: 16rem;
    }

    .md\:h-\[640px\]{
        height: 640px;
    }

    .md\:max-h-\[500px\]{
        max-height: 500px;
    }

    .md\:w-24{
        width: 6rem;
    }

    .md\:w-48{
        width: 12rem;
    }

    .md\:w-96{
        width: 24rem;
    }

    .md\:w-\[140px\]{
        width: 140px;
    }

    .md\:w-\[var\(--radix-navigation-menu-viewport-width\)\]{
        width: var(--radix-navigation-menu-viewport-width);
    }

    .md\:w-auto{
        width: auto;
    }

    .md\:max-w-\[420px\]{
        max-width: 420px;
    }

    .md\:flex-1{
        flex: 1 1 0%;
    }

    .md\:basis-1\/3{
        flex-basis: 33.333333%;
    }

    .md\:basis-1\/4{
        flex-basis: 25%;
    }

    .md\:basis-1\/5{
        flex-basis: 20%;
    }

    .md\:basis-\[220px\]{
        flex-basis: 220px;
    }

    .md\:scale-\[0\.8\]{
        --tw-scale-x: 0.8;
        --tw-scale-y: 0.8;
        transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    }

    .md\:grid-cols-2{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .md\:grid-cols-3{
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .md\:grid-cols-4{
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .md\:grid-cols-6{
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .md\:grid-cols-8{
        grid-template-columns: repeat(8, minmax(0, 1fr));
    }

    .md\:flex-row{
        flex-direction: row;
    }

    .md\:justify-start{
        justify-content: flex-start;
    }

    .md\:gap-6{
        gap: 1.5rem;
    }

    .md\:space-x-10 > :not([hidden]) ~ :not([hidden]){
        --tw-space-x-reverse: 0;
        margin-right: calc(2.5rem * var(--tw-space-x-reverse));
        margin-left: calc(2.5rem * calc(1 - var(--tw-space-x-reverse)));
    }

    .md\:overflow-y-auto{
        overflow-y: auto;
    }

    .md\:py-3{
        padding-top: 0.75rem;
        padding-bottom: 0.75rem;
    }

    .md\:pl-4{
        padding-left: 1rem;
    }

    .md\:text-2xl{
        font-size: 1.5rem;
        line-height: 2rem;
    }

    .md\:text-3xl{
        font-size: 1.875rem;
        line-height: 2.25rem;
    }

    .md\:text-6xl{
        font-size: 3.75rem;
        line-height: 1;
    }

    .md\:text-8xl{
        font-size: 6rem;
        line-height: 1;
    }

    .md\:text-base{
        font-size: 1rem;
        line-height: 1.5rem;
    }

    .md\:text-sm{
        font-size: 0.875rem;
        line-height: 1.25rem;
    }

    .md\:text-xl{
        font-size: 1.25rem;
        line-height: 1.75rem;
    }

    .md\:text-xs{
        font-size: 0.75rem;
        line-height: 1rem;
    }

    .md\:opacity-0{
        opacity: 0;
    }

    .after\:md\:hidden::after{
        content: var(--tw-content);
        display: none;
    }

    .peer[data-variant="inset"] ~ .md\:peer-data-\[variant\=inset\]\:m-2{
        margin: 0.5rem;
    }

    .peer[data-state="collapsed"][data-variant="inset"] ~ .md\:peer-data-\[state\=collapsed\]\:peer-data-\[variant\=inset\]\:ml-2{
        margin-left: 0.5rem;
    }

    .peer[data-variant="inset"] ~ .md\:peer-data-\[variant\=inset\]\:ml-0{
        margin-left: 0px;
    }

    .peer[data-variant="inset"] ~ .md\:peer-data-\[variant\=inset\]\:rounded-xl{
        border-radius: 0.75rem;
    }

    .peer[data-variant="inset"] ~ .md\:peer-data-\[variant\=inset\]\:shadow{
        --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
        --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
        box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
    }
}

@media (min-width: 1024px){

    .lg\:col-span-1{
        grid-column: span 1 / span 1;
    }

    .lg\:col-span-2{
        grid-column: span 2 / span 2;
    }

    .lg\:flex{
        display: flex;
    }

    .lg\:hidden{
        display: none;
    }

    .lg\:h-48{
        height: 12rem;
    }

    .lg\:h-\[800px\]{
        height: 800px;
    }

    .lg\:w-0{
        width: 0px;
    }

    .lg\:w-64{
        width: 16rem;
    }

    .lg\:w-\[28rem\]{
        width: 28rem;
    }

    .lg\:flex-1{
        flex: 1 1 0%;
    }

    .lg\:basis-1\/4{
        flex-basis: 25%;
    }

    .lg\:basis-1\/5{
        flex-basis: 20%;
    }

    .lg\:scale-100{
        --tw-scale-x: 1;
        --tw-scale-y: 1;
        transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    }

    .lg\:grid-cols-2{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .lg\:grid-cols-3{
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .lg\:grid-cols-4{
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .lg\:grid-cols-5{
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .lg\:grid-cols-6{
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .lg\:grid-cols-9{
        grid-template-columns: repeat(9, minmax(0, 1fr));
    }

    .lg\:space-x-8 > :not([hidden]) ~ :not([hidden]){
        --tw-space-x-reverse: 0;
        margin-right: calc(2rem * var(--tw-space-x-reverse));
        margin-left: calc(2rem * calc(1 - var(--tw-space-x-reverse)));
    }

    .lg\:px-8{
        padding-left: 2rem;
        padding-right: 2rem;
    }

    .lg\:text-2xl{
        font-size: 1.5rem;
        line-height: 2rem;
    }

    .lg\:text-7xl{
        font-size: 4.5rem;
        line-height: 1;
    }
}

@media (min-width: 1280px){

    .xl\:grid-cols-4{
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .xl\:grid-cols-6{
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }
}

.\[\&\:has\(\[aria-selected\]\)\]\:bg-primary\/5:has([aria-selected]){
    background-color: hsl(var(--primary) / 0.05);
}

.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{
    border-top-left-radius: calc(var(--radius) - 2px);
    border-bottom-left-radius: calc(var(--radius) - 2px);
}

.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{
    border-top-right-radius: calc(var(--radius) - 2px);
    border-bottom-right-radius: calc(var(--radius) - 2px);
}

.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-primary\/5:has([aria-selected].day-outside){
    background-color: hsl(var(--primary) / 0.05);
}

.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){
    border-top-right-radius: calc(var(--radius) - 2px);
    border-bottom-right-radius: calc(var(--radius) - 2px);
}

.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){
    padding-right: 0px;
}

.\[\&\>button\]\:z-50>button{
    z-index: 50;
}

.\[\&\>button\]\:hidden>button{
    display: none;
}

.\[\&\>ol\]\:my-1>ol{
    margin-top: 0.25rem;
    margin-bottom: 0.25rem;
}

.\[\&\>p\]\:m-0>p{
    margin: 0px;
}

.\[\&\>p\]\:leading-snug>p{
    line-height: 1.375;
}

.\[\&\>span\:last-child\]\:truncate>span:last-child{
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.\[\&\>span\]\:line-clamp-1>span{
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
}

.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{
    --tw-translate-y: -3px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.\[\&\>svg\]\:absolute>svg{
    position: absolute;
}

.\[\&\>svg\]\:left-4>svg{
    left: 1rem;
}

.\[\&\>svg\]\:top-4>svg{
    top: 1rem;
}

.\[\&\>svg\]\:size-3\.5>svg{
    width: 0.875rem;
    height: 0.875rem;
}

.\[\&\>svg\]\:size-4>svg{
    width: 1rem;
    height: 1rem;
}

.\[\&\>svg\]\:h-2\.5>svg{
    height: 0.625rem;
}

.\[\&\>svg\]\:h-3>svg{
    height: 0.75rem;
}

.\[\&\>svg\]\:w-2\.5>svg{
    width: 0.625rem;
}

.\[\&\>svg\]\:w-3>svg{
    width: 0.75rem;
}

.\[\&\>svg\]\:shrink-0>svg{
    flex-shrink: 0;
}

.\[\&\>svg\]\:text-destructive>svg{
    color: hsl(var(--destructive));
}

.\[\&\>svg\]\:text-foreground>svg{
    color: hsl(var(--foreground));
}

.\[\&\>svg\]\:text-muted-foreground>svg{
    color: hsl(var(--muted-foreground));
}

.\[\&\>svg\]\:text-sidebar-accent-foreground>svg{
    color: hsl(var(--sidebar-accent-foreground));
}

.\[\&\>svg\~\*\]\:pl-7>svg~*{
    padding-left: 1.75rem;
}

.\[\&\>tr\]\:last\:border-b-0:last-child>tr{
    border-bottom-width: 0px;
}

.\[\&\>ul\]\:my-1>ul{
    margin-top: 0.25rem;
    margin-bottom: 0.25rem;
}

.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div{
    --tw-rotate: 90deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{
    --tw-rotate: 180deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.\[\&_\.recharts-cartesian-axis-tick_text\]\:fill-muted-foreground .recharts-cartesian-axis-tick text{
    fill: hsl(var(--muted-foreground));
}

.\[\&_\.recharts-cartesian-grid_line\[stroke\=\'\#ccc\'\]\]\:stroke-border\/50 .recharts-cartesian-grid line[stroke='#ccc']{
    stroke: hsl(var(--border) / 0.5);
}

.\[\&_\.recharts-curve\.recharts-tooltip-cursor\]\:stroke-border .recharts-curve.recharts-tooltip-cursor{
    stroke: hsl(var(--border));
}

.\[\&_\.recharts-dot\[stroke\=\'\#fff\'\]\]\:stroke-transparent .recharts-dot[stroke='#fff']{
    stroke: transparent;
}

.\[\&_\.recharts-layer\]\:outline-none .recharts-layer{
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.\[\&_\.recharts-polar-grid_\[stroke\=\'\#ccc\'\]\]\:stroke-border .recharts-polar-grid [stroke='#ccc']{
    stroke: hsl(var(--border));
}

.\[\&_\.recharts-radial-bar-background-sector\]\:fill-muted .recharts-radial-bar-background-sector{
    fill: hsl(var(--muted));
}

.\[\&_\.recharts-rectangle\.recharts-tooltip-cursor\]\:fill-muted .recharts-rectangle.recharts-tooltip-cursor{
    fill: hsl(var(--muted));
}

.\[\&_\.recharts-reference-line_\[stroke\=\'\#ccc\'\]\]\:stroke-border .recharts-reference-line [stroke='#ccc']{
    stroke: hsl(var(--border));
}

.\[\&_\.recharts-sector\[stroke\=\'\#fff\'\]\]\:stroke-transparent .recharts-sector[stroke='#fff']{
    stroke: transparent;
}

.\[\&_\.recharts-sector\]\:outline-none .recharts-sector{
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.\[\&_\.recharts-surface\]\:outline-none .recharts-surface{
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}

.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{
    font-size: 0.75rem;
    line-height: 1rem;
}

.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{
    font-weight: 500;
}

.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{
    color: hsl(var(--muted-foreground));
}

.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden]) ~[cmdk-group]{
    padding-top: 0px;
}

.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{
    height: 1.25rem;
}

.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{
    width: 1.25rem;
}

.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{
    height: 3rem;
}

.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{
    height: 1.25rem;
}

.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{
    width: 1.25rem;
}

.\[\&_\[role\=slider\]\]\:bg-gradient-to-r [role=slider]{
    background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.\[\&_\[role\=slider\]\]\:from-purple-600 [role=slider]{
    --tw-gradient-from: #9333ea var(--tw-gradient-from-position);
    --tw-gradient-to: rgb(147 51 234 / 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.\[\&_\[role\=slider\]\]\:to-pink-600 [role=slider]{
    --tw-gradient-to: #db2777 var(--tw-gradient-to-position);
}

.\[\&_li\]\:my-0 li{
    margin-top: 0px;
    margin-bottom: 0px;
}

.\[\&_p\]\:leading-relaxed p{
    line-height: 1.625;
}

.\[\&_svg\]\:pointer-events-none svg{
    pointer-events: none;
}

.\[\&_svg\]\:size-4 svg{
    width: 1rem;
    height: 1rem;
}

.\[\&_svg\]\:shrink-0 svg{
    flex-shrink: 0;
}

.\[\&_tr\:last-child\]\:border-0 tr:last-child{
    border-width: 0px;
}

.\[\&_tr\]\:border-b tr{
    border-bottom-width: 1px;
}

[data-side=left][data-collapsible=offcanvas] .\[\[data-side\=left\]\[data-collapsible\=offcanvas\]_\&\]\:-right-2{
    right: -0.5rem;
}

[data-side=left][data-state=collapsed] .\[\[data-side\=left\]\[data-state\=collapsed\]_\&\]\:cursor-e-resize{
    cursor: e-resize;
}

[data-side=left] .\[\[data-side\=left\]_\&\]\:cursor-w-resize{
    cursor: w-resize;
}

[data-side=right][data-collapsible=offcanvas] .\[\[data-side\=right\]\[data-collapsible\=offcanvas\]_\&\]\:-left-2{
    left: -0.5rem;
}

[data-side=right][data-state=collapsed] .\[\[data-side\=right\]\[data-state\=collapsed\]_\&\]\:cursor-w-resize{
    cursor: w-resize;
}

[data-side=right] .\[\[data-side\=right\]_\&\]\:cursor-e-resize{
    cursor: e-resize;
}
