/*
 * Copyright (c) SupportSystem s.r.o. Všechna práva vyhrazena.
 * Autoři: Petr Marek, Jan Kučera
 *
 * Input v2 — textový input (text, number, password, email, ...) s podporou
 * virtuální klávesnice. Designerova specifikace WFP yellow-outline:
 *   default border = --ui-field-emphasis-border
 *   focus border   = --ui-field-emphasis-border-edit
 *   bg             = --ui-surface-input-bg
 *
 * @uses-design-tokens-v2
 */

.input-v2 {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
}

.input-v2__wrapper {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
}

/*
 * Default varianta — designer (.eu-input):
 *   1px solid --ui-border-default, bg --ui-surface-card-bg, radius small.
 *   Focus přepne na --ui-action-primary-bg (accent modrá) + soft halo.
 */
.input-v2__field {
    flex: 1;
    min-width: 0;
    padding: var(--ui-spacing-xs) var(--ui-spacing-sm);
    height: var(--ui-density-cozy-field-height);
    font-family: var(--ui-font-base);
    font-size: var(--ui-text-size-heading-medium);
    color: var(--ui-text-primary);
    background: var(--ui-surface-card-bg);
    border: 1px solid var(--ui-border-default);
    border-radius: var(--ui-radius-small);
    outline: none;
    transition:
        border-color var(--ui-transition-fast),
        box-shadow var(--ui-transition-fast);
}

.input-v2__field:focus:not(:disabled):not(:read-only) {
    border-color: var(--ui-action-primary-bg, #ff0000);
    box-shadow: 0 0 0 3px var(--ui-action-primary-soft-bg);
}

/*
 * Emphasis varianta — designer (.eu-input.is-emph):
 *   2px solid --ui-field-emphasis-border (WFP žlutá).
 *   Focus: silnější žlutá (--ui-field-emphasis-border-edit), halo zůstává
 *   accent-soft (uživatelovo rozhodnutí — emphasis si zachovává yellow
 *   charakter při focus, nepřepíná na accent modrou).
 */
.input-v2--emphasis .input-v2__field {
    border-width: 2px;
    border-color: var(--ui-field-emphasis-border, #ff0000);
}

.input-v2--emphasis .input-v2__field:focus:not(:disabled):not(:read-only) {
    border-color: var(--ui-field-emphasis-border-edit, #ff0000);
    box-shadow: 0 0 0 3px var(--ui-action-primary-soft-bg);
}

.input-v2__field:disabled {
    background: var(--ui-surface-stripe-bg);
    color: var(--ui-text-disabled);
    cursor: not-allowed;
    opacity: 0.7;
}

.input-v2__field:read-only {
    background: var(--ui-surface-input-alt-bg);
    cursor: default;
}

/*
 * Emphasis + disabled/read-only — žluté podbarvení (--ui-field-emphasis-bg)
 * místo neutrálního stripe/alt-bg. V edit režimu (enabled) pouze žlutý border,
 * v browse režimu (disabled/readonly) border + žluté podbarvení.
 */
.input-v2--emphasis .input-v2__field:disabled,
.input-v2--emphasis .input-v2__field:read-only {
    background: var(--ui-field-emphasis-bg, #ff0000);
}

/* Error stav */
.input-v2--error .input-v2__field {
    border-color: var(--ui-feedback-danger-text);
    background: var(--ui-feedback-danger-bg);
}

.input-v2--error .input-v2__field:focus {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--ui-feedback-danger-text) 18%, transparent);
}

/*
 * UKOL 235 P13f — skryj nativní spinner šipky na <input type="number">.
 * Důvod: PPP touch-first UX, šipečky působí v textovém formuláři rušivě
 * a uživatel hodnotu mění klávesnicí (Arrow Up/Down) nebo OSK. Konzistentní
 * s DataTable cell editor variantou (= identický override v data-table-v2.css).
 */
.input-v2__field[type="number"] {
    -moz-appearance: textfield;
}
.input-v2__field[type="number"]::-webkit-outer-spin-button,
.input-v2__field[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Keyboard button (pravá strana inputu) */
.input-v2__keyboard-btn {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: var(--ui-radius-small);
    cursor: pointer;
    font-size: var(--ui-text-size-heading-medium);
    line-height: 1;
    color: var(--ui-text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition:
        background-color var(--ui-transition-fast),
        color var(--ui-transition-fast);
    z-index: 1;
}

.input-v2__keyboard-btn:hover {
    background: var(--ui-overlay-hover-bg);
    color: var(--ui-text-primary);
}

.input-v2__keyboard-btn:active {
    background: var(--ui-overlay-active-bg);
}

.input-v2--has-keyboard .input-v2__field {
    padding-right: var(--ui-spacing-3xl);
}

/* Error message pod inputem */
.input-v2__error-msg {
    display: none;
    margin-top: var(--ui-spacing-2xs);
    padding-left: var(--ui-spacing-3xs);
    color: var(--ui-feedback-danger-text);
    font-family: var(--ui-font-base);
    font-size: var(--ui-text-size-label);
    line-height: var(--ui-text-leading-normal);
}

.input-v2--error .input-v2__error-msg {
    display: block;
}
