.ta-availability-widget {
    background: #ffffff;
    padding: 28px;
    border-radius: 5px;
    box-shadow: 0 16px 40px rgba(40, 40, 70, 0.12);
    color: #1f1f1f;
}

.ta-availability-title {
    margin: 0 0 8px;
    font-size: 28px;
    font-weight: 700;
}

.ta-availability-subtitle {
    margin: 0 0 20px;
    font-size: 15px;
    opacity: 0.85;
}

.ta-availability-form {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 14px;
}

.ta-availability-field input,
.ta-availability-field button {
    width: 100%;
    padding: 12px 14px;
    border-radius: 5px;
    border: none;
    font-size: 15px;
    outline: none;
}

.ta-availability-field input {
    background: #ffffff;
    color: #1f1f1f;
    box-shadow: 0 10px 18px rgba(24, 24, 40, 0.12);
}

.ta-availability-field input:focus {
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.35);
}

.ta-availability-submit {
    background: linear-gradient(135deg, #ff6b6b 0%, #ff4d6d 100%);
    color: #fff;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ta-availability-submit:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 22px rgba(255, 77, 109, 0.35);
}

@media (max-width: 640px) {
    .ta-availability-widget {
        padding: 20px;
    }

    .ta-availability-title {
        font-size: 22px;
    }
}
