﻿/* Phone input styles compatible with _Input partial */
.phone-formatted {
    font-family: var(--font-family-primary);
    font-size: 16px;
}

.phone-formatted::placeholder {
    color: transparent;
}

.phone-formatted:invalid:not(:placeholder-shown) {
    border-color: var(--color-danger);
    background-color: var(--color-bg-secondary);
}

.phone-formatted:invalid:not(:placeholder-shown):focus {
    border-color: var(--color-danger);
    background-color: var(--color-bg-primary);
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.phone-formatted:valid:not(:placeholder-shown) {
    border-color: var(--color-success);
    background-color: var(--color-success-bg);
}

.phone-formatted:valid:not(:placeholder-shown):focus {
    border-color: var(--color-success);
    background-color: var(--color-bg-primary);
    box-shadow: 0 0 0 3px var(--color-success-border);
}

.phone-formatted:not(:placeholder-shown) ~ label {
    opacity: 1;
    transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
}

@media (max-width: 768px) {
    .phone-formatted {
        font-size: 16px;
    }
}

.phone-validator {
    margin-top: 5px;
    font-size: 12px;
    color: #6c757d;
    display: none;
}

.phone-validator.show {
    display: block;
}

.phone-validator.valid {
    color: #28a745;
}

.phone-validator.invalid {
    color: #dc3545;
}

