/* Youlyzer — Custom CSS Overrides */

/* Enforce sharp corners globally */
*,
*::before,
*::after {
    border-radius: 0 !important;
}

/* Storyboard loading spinner */
.storyboard-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid #e5e7eb;
    border-top-color: #4f46e5;
    animation: spin 0.8s linear infinite;
}

.dark .storyboard-spinner {
    border-color: #374151;
    border-top-color: #818cf8;
}

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

/* Smooth fade-in for content */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

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

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

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

/* Focus visible styles */
*:focus-visible {
    outline: 2px solid #4f46e5;
    outline-offset: 2px;
}

.dark *:focus-visible {
    outline-color: #818cf8;
}

/* Scrollbar styling — Light */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: #f1f5f9;
}

::-webkit-scrollbar-thumb {
    background: #cbd5e1;
}

::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}

/* Scrollbar styling — Dark */
.dark ::-webkit-scrollbar-track,
.dark::-webkit-scrollbar-track {
    background: #1e1e2e;
}

.dark ::-webkit-scrollbar-thumb,
.dark::-webkit-scrollbar-thumb {
    background: #4b5563;
}

.dark ::-webkit-scrollbar-thumb:hover,
.dark::-webkit-scrollbar-thumb:hover {
    background: #6b7280;
}

/* Smooth color transitions for theme switch */
body,
nav,
footer,
.theme-transition {
    transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}

/* Wave divider dark mode support */
.dark .wave-divider-fill {
    fill: #030712;
}
