/* ========================================
   Studoro WebApp - App-Specific Overrides
   ======================================== */

/* Form validation styles for Blazor */
.valid.modified:not([type=checkbox]) {
    border-color: var(--color-success, #10B981);
}

.invalid {
    border-color: var(--color-error, #EF4444);
}

.validation-message {
    color: var(--color-error, #EF4444);
    font-size: var(--text-xs, 0.75rem);
    margin-top: var(--spacing-xs, 0.25rem);
}

/* Blazor error boundary */
.blazor-error-boundary {
    background: var(--color-error, #EF4444);
    padding: var(--spacing-md, 1rem);
    color: white;
    border-radius: var(--radius-md, 0.75rem);
    margin: var(--spacing-md, 1rem);
}

.blazor-error-boundary::after {
    content: "Hiba történt. Kérjük, próbáld újra."
}

/* InputText and InputTextArea focus states */
input.form-input:focus,
textarea.form-input:focus {
    border-color: var(--color-primary, #6366F1);
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.2);
}

/* Navbar mobile toggle animation */
.navbar-toggle.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.navbar-toggle.active span:nth-child(2) {
    opacity: 0;
}

.navbar-toggle.active span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* Scroll animation initial state */
.animate-on-scroll {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.animate-on-scroll.animate-fade-in-up {
    opacity: 1;
    transform: translateY(0);
}

/* Loading state for buttons */
.btn-studoro.loading {
    position: relative;
    color: transparent !important;
    pointer-events: none;
}

.btn-studoro.loading::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: white;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

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

/* Focus visible for accessibility */
:focus-visible {
    outline: 2px solid var(--color-primary, #6366F1);
    outline-offset: 2px;
}

/* Remove focus outline from non-interactive heading elements (FocusOnNavigate) */
h1:focus,
h2:focus,
h3:focus,
h4:focus,
h5:focus,
h6:focus {
    outline: none;
}

/* Smooth transitions for interactive elements */
a, button, input, textarea {
    transition-property: color, background-color, border-color, box-shadow, transform;
    transition-duration: 150ms;
    transition-timing-function: ease-out;
}

/* Selection color */
::selection {
    background-color: var(--color-primary-light, #EEF2FF);
    color: var(--color-primary, #6366F1);
}

/* Scrollbar styling */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--color-background, #FAFAFC);
}

::-webkit-scrollbar-thumb {
    background: var(--color-border, #E5E7EB);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--color-text-tertiary, #9CA3AF);
}

/* Print styles */
@media print {
    .navbar-studoro,
    .footer-studoro,
    .hero-wave,
    .hero-pattern {
        display: none !important;
    }
    
    body {
        background: white;
        color: black;
    }
}
