/* Обновленные стили для экрана ввода проверочного кода */

/* Стили для контейнера поля ввода */
#enterOTPScreen .plaid-input-group {
    position: relative !important;
    margin-bottom: 10px !important;
    padding-top: 10px !important;
}

/* Базовые стили для поля ввода */
#enterOTPScreen .plaid-input {
    width: 100% !important;
    height: 48px !important;
    padding: 0 16px !important;
    font-size: 16px !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 8px !important;
    outline: none !important;
    transition: border-color 200ms ease-in-out, box-shadow 200ms ease-in-out !important;
    font-family: inherit !important;
    background-color: white !important;
    box-shadow: 0 1px 3px 0 rgba(118,118,118,.05) !important;
    box-sizing: border-box !important;
    line-height: 48px !important;
    letter-spacing: 1px !important;
}

/* Стиль при наведении */
#enterOTPScreen .plaid-input:hover {
    border-color: #b0b0b0 !important;
}

/* Стиль при фокусе */
#enterOTPScreen .plaid-input:focus {
    border-color: #0a85ea !important;
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(10, 133, 234, 0.1) !important;
}

/* Стили для лейбла - исправленная версия */
#enterOTPScreen .plaid-input-label {
    position: absolute !important;
    left: 16px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 16px !important;
    line-height: 20px !important;
    color: #767676 !important;
    pointer-events: none !important;
    transition: transform 250ms cubic-bezier(0.23, 1, 0.32, 1),
                font-size 250ms cubic-bezier(0.23, 1, 0.32, 1),
                color 250ms cubic-bezier(0.23, 1, 0.32, 1) !important;
    transform-origin: left top !important;
    z-index: 2 !important;
    padding: 0 4px !important;
    border-radius: 3px !important;
}

/* Стили для лейбла при фокусе или когда поле не пустое */
#enterOTPScreen .plaid-input:focus + .plaid-input-label,
#enterOTPScreen .plaid-input:not(:placeholder-shown) + .plaid-input-label {
    transform: translateY(-28px) scale(0.85) !important;
    color: #0a85ea !important;
    top: 20px !important;
    font-weight: 500 !important;
    letter-spacing: 0.01em !important;
    padding: 0 4px !important;
}

/* Добавляем стили для анимации при фокусировке на поле ввода */
#enterOTPScreen .plaid-input-group:focus-within .plaid-input-label {
    transform: translateY(-28px) scale(0.85) !important;
    color: #0a85ea !important;
    top: 20px !important;
    font-weight: 500 !important;
    letter-spacing: 0.01em !important;
}

/* Прозрачный плейсхолдер */
#enterOTPScreen .plaid-input::placeholder {
    color: transparent !important;
}

/* Центрирование заголовка */
#enterOTPScreen .plaid-title {
    text-align: center !important;
    margin-top: 12px !important;
    margin-bottom: 16px !important;
    width: 100% !important;
    font-size: 20px !important;
    font-weight: 600 !important;
    color: #333 !important;
}

/* Центрирование описания */
#enterOTPScreen .plaid-description {
    text-align: center !important;
    margin-bottom: 20px !important;
    max-width: 320px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    color: #666 !important;
    line-height: 1.5 !important;
}

/* Стили для контейнера иконки банка */
#enterOTPScreen .plaid-bank-icon-container {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 80px !important;
    padding: 12px 16px 8px 16px !important;
    margin-bottom: 4px !important;
}

/* Увеличенный размер иконки банка */
#enterOTPScreen .plaid-bank-icon-circle {
    width: 80px !important;
    height: 80px !important;
    border-radius: 50% !important;
    background-color: #f9fafb !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    position: relative !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.12) !important;
}

/* Стили для логотипа банка внутри круга */
#enterOTPScreen .plaid-selected-bank-logo {
    width: 75% !important;
    height: 75% !important;
    object-fit: contain !important;
}

/* Кнопка отправки кода верификации */
#enterOTPScreen .plaid-submit-button {
    margin-top: 8px !important;
    background-color: #111 !important;
    color: white !important;
    border: none !important;
    border-radius: 8px !important;
    height: 48px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    width: 100% !important;
    transition: background-color 0.2s ease !important;
}

/* Эффект наведения на кнопку */
#enterOTPScreen .plaid-submit-button:hover:not(:disabled) {
    background-color: #333 !important;
}

/* Кнопка повторной отправки кода */
#enterOTPScreen .plaid-reset-button {
    margin-top: 12px !important;
    background-color: transparent !important;
    color: #111 !important;
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    height: 48px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    width: 100% !important;
    transition: background-color 0.2s ease, border-color 0.2s ease !important;
}

/* Эффект наведения на кнопку сброса */
#enterOTPScreen .plaid-reset-button:hover {
    background-color: #f8f8f8 !important;
    border-color: #ccc !important;
}

/* Стили для отключенной кнопки */
#enterOTPScreen .plaid-submit-button:disabled,
#enterOTPScreen .plaid-submit-button-disabled {
    background-color: #e0e0e0 !important;
    color: #999 !important;
    cursor: not-allowed !important;
    opacity: 0.7 !important;
    box-shadow: none !important;
}
