/* Custom Animations */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade-in {
    animation: fadeIn 0.4s ease-out forwards;
}

/* Custom Scrollbar - Webkit */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background-color: #d1d5db;
    /* gray-300 */
    border-radius: 9999px;
}

.dark ::-webkit-scrollbar-thumb {
    background-color: #404040;
    /* gray-700/dark-600 */
}

::-webkit-scrollbar-thumb:hover {
    background-color: #9ca3af;
    /* gray-400 */
}

.dark ::-webkit-scrollbar-thumb:hover {
    background-color: #525252;
    /* gray-600 */
}

/* Navigation Active State - Manual override since we can't use @apply easily in vanilla CSS linked file without build */
.nav-btn.active {
    background-color: rgba(16, 185, 129, 0.1);
    /* brand-500/10 */
    color: #059669;
    /* brand-600 */
}

.dark .nav-btn.active {
    color: #10b981;
    /* brand-500 */
}

/* Cleanup number inputs */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Chart Container responsive fix */
canvas {
    width: 100% !important;
    height: 100% !important;
}