/*
 * Fitly Utilities (fitly-utilities.css)
 * ═════════════════════════════════════
 * Fitly-specific utility classes that complement Bootstrap's
 * utility system. Loaded AFTER fitly-components.css.
 *
 * RULE: Before adding a class here, check if Bootstrap already
 * provides an equivalent utility (d-flex, gap-3, p-4, rounded-3,
 * text-body-secondary, etc.). Only add classes for concepts
 * Bootstrap does not cover.
 */

/* ══════════════════════════════════════════════════════════
   Animations
   ══════════════════════════════════════════════════════════ */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

.fade-in {
    animation: fadeIn 0.4s ease;
}

/* ══════════════════════════════════════════════════════════
   Loading State (button spinner)
   ══════════════════════════════════════════════════════════ */
.btn.loading {
    position: relative;
    pointer-events: none;
    opacity: 0.6;
}

.btn.loading::after {
    content: "";
    position: absolute;
    width: 16px;
    height: 16px;
    top: 50%;
    left: 50%;
    margin-left: -8px;
    margin-top: -8px;
    border: 2px solid transparent;
    border-top-color: currentColor;
    border-radius: 50%;
    animation: fitlySpin 0.6s linear infinite;
}

/* ══════════════════════════════════════════════════════════
   Selection & Focus
   ══════════════════════════════════════════════════════════ */
.no-select {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

/* ══════════════════════════════════════════════════════════
   Text Gradient (Fitly brand)
   ══════════════════════════════════════════════════════════ */
.text-gradient {
    background: linear-gradient(135deg, var(--fitly-primary) 0%, var(--fitly-primary-dark) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ══════════════════════════════════════════════════════════
   Accessibility
   ══════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

@media (prefers-contrast: high) {
    :root {
        --border-color: #000000;
        --border-light: #333333;
        --text-secondary: #000000;
        --text-muted: #333333;
    }
}

/* ══════════════════════════════════════════════════════════
   Print
   ══════════════════════════════════════════════════════════ */
@media print {
    .tab-bar,
    .tab-bar-container,
    .fitly-tab-bar,
    .modal-backdrop,
    .modal-container,
    #blazor-error-ui {
        display: none !important;
    }
}

/* ══════════════════════════════════════════════════════════
   Blazor Error UI
   ══════════════════════════════════════════════════════════ */
#blazor-error-ui {
    background: var(--bs-warning);
    bottom: 0;
    box-shadow: var(--fitly-shadow-lg);
    display: none;
    left: 0;
    padding: var(--fitly-spacing-lg) var(--fitly-spacing-2xl);
    position: fixed;
    width: 100%;
    z-index: var(--fitly-z-notification);
    color: var(--bs-body-color);
}

#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: var(--fitly-spacing-lg);
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--fitly-font-size-lg);
    font-weight: var(--fitly-font-weight-bold);
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, var(--bs-danger);
    padding: var(--fitly-spacing-lg) var(--fitly-spacing-lg) var(--fitly-spacing-lg) var(--fitly-spacing-4xl);
    color: var(--fitly-text-inverse);
    border-radius: var(--border-radius);
    margin: var(--fitly-spacing-lg);
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

/* ══════════════════════════════════════════════════════════
   Form Validation (Blazor)
   ══════════════════════════════════════════════════════════ */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--bs-success);
}

.invalid {
    outline: 1px solid var(--bs-danger);
}

.validation-message {
    color: var(--bs-danger);
    font-size: var(--fitly-font-size-sm);
    margin-top: var(--fitly-spacing-xs);
}

h1:focus {
    outline: none;
}
