/**
 * Language by Typing - App Styles
 */

/* Text Prompt Display */
.text-prompt {
    background: var(--ont-bg-secondary);
    border-radius: var(--ont-radius-md);
    padding: 1.5rem;
    font-size: 1.125rem;
    line-height: 1.8;
    font-family: var(--ont-font-sans);
    color: var(--ont-text-main);
    min-height: 120px;
    white-space: pre-wrap;
    word-wrap: break-word;
}

/* Character Highlighting */
.char-correct {
    color: var(--ont-success);
    background-color: var(--ont-success-bg);
}

.char-incorrect {
    color: var(--ont-error);
    background-color: var(--ont-error-bg);
    text-decoration: underline wavy;
}

.char-current {
    background-color: var(--ont-primary-alpha);
    animation: blink 1s infinite;
}

@keyframes blink {
    0%, 50% {
        background-color: var(--ont-primary-alpha);
    }
    51%, 100% {
        background-color: transparent;
    }
}

/* Typing Input Area */
.typing-input {
    font-family: var(--ont-font-sans);
    font-size: 1rem;
    line-height: 1.6;
    resize: vertical;
    min-height: 150px;
}

.typing-input:focus {
    outline: none;
    border-color: var(--ont-primary);
    box-shadow: 0 0 0 3px var(--ont-primary-alpha);
}

/* Stats Grid */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 1rem;
    margin-top: 1.5rem;
}

@media (max-width: 640px) {
    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Stat Cards */
.stat-card {
    background-color: var(--ont-bg-secondary);
    border-radius: var(--ont-radius-md);
    padding: 1.25rem;
    text-align: center;
    transition: all var(--ont-transition-fast);
    border: 2px solid transparent;
}

.stat-card:hover {
    border-color: var(--ont-primary-light);
    background-color: var(--ont-primary-light);
    transform: translateY(-2px);
}

.stat-value {
    font-size: var(--ont-text-3xl);
    font-weight: var(--ont-font-bold);
    color: var(--ont-primary);
    margin-bottom: 0.5rem;
    font-variant-numeric: tabular-nums;
}

.stat-label {
    font-size: var(--ont-text-sm);
    font-weight: var(--ont-font-medium);
    color: var(--ont-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

/* Animation for stat updates */
@keyframes pulse {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
}

.stat-value {
    animation: pulse 0.3s ease-in-out;
}

/* Language Select */
#languageSelect {
    width: 100%;
    max-width: 300px;
}

/* Responsive Design */
@media (max-width: 768px) {
    .text-prompt {
        font-size: 1rem;
        padding: 1.25rem;
    }
    
    .typing-input {
        font-size: 0.9375rem;
    }
    
    #languageSelect {
        max-width: 100%;
    }
}

/* Dark mode adjustments (if supported by UI Kit) */
@media (prefers-color-scheme: dark) {
    .text-prompt {
        background: rgba(255, 255, 255, 0.05);
    }
    
    .char-correct {
        background-color: rgba(34, 197, 94, 0.2);
    }
    
    .char-incorrect {
        background-color: rgba(239, 68, 68, 0.2);
    }
}

/* Accessibility */
.typing-input:focus-visible {
    outline: 2px solid var(--ont-primary);
    outline-offset: 2px;
}

/* Print styles */
@media print {
    .ont-button,
    .stats-grid {
        display: none;
    }
    
    .text-prompt {
        background: none;
        border: 1px solid #ccc;
    }
}
