/* =============================================================================
   АРХИТЕКТУРА: OFFICE ATOMS (Атомы редактирования)
   Назначение: Элементы управления, формы и редакторы.
   Этот файл является часть Tier 2 (слой Офиса и Форм).
   ============================================================================= */

/* --- 1. Поля ввода (Inputs) --- */
.atom-input {
    width: 100%;
    margin: 0;
    padding: 4px var(--spacing-xs);
    font-size: var(--font-size-base);
    font-weight: 500;
    line-height: 1.5;
    font-family: inherit;
    color: var(--tg-theme-text-color);
    background: var(--tg-theme-secondary-bg-color);
    border: 2px solid var(--tg-theme-section-separator-color);
    border-radius: var(--border-radius-sm);
    transition: all 0.2s ease;
    box-sizing: border-box;
}

.atom-input:focus {
    outline: none;
    border-color: var(--tg-theme-button-color);
}

/* Двойной класс — без !important; при фокусе оставляем индикацию ошибки */
.atom-input.atom-input--error {
    border-color: var(--tg-theme-destructive-text-color);
}

.atom-input.atom-input--error:focus {
    border-color: var(--tg-theme-destructive-text-color);
}

/* Числовые поля: на 12 символов, текст вправо, без стрелок */
input[type="number"].atom-input {
    max-width: 12ch;
    text-align: right;
    -moz-appearance: textfield;
}

input[type="number"].atom-input::-webkit-outer-spin-button,
input[type="number"].atom-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* --- 2. Текстовые области (Textarea) --- */
textarea.atom-input {
    min-height: 2.5rem;
    resize: none;
    overflow: hidden;
    white-space: pre-wrap;
}

/* Единое поле Telegram: одна рамка, @ слева вне value (офис + форма) */
.telegram-field {
    display: flex;
    align-items: stretch;
    width: 100%;
    border: 2px solid var(--tg-theme-section-separator-color);
    border-radius: var(--border-radius-sm);
    background: var(--tg-theme-secondary-bg-color);
    box-sizing: border-box;
    transition: border-color 0.2s ease;
}

.telegram-field:focus-within {
    border-color: var(--tg-theme-button-color);
}

.telegram-field__at {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    padding: 4px 0 4px var(--spacing-xs);
    font-size: var(--font-size-base);
    font-weight: 500;
    line-height: 1.5;
    color: var(--tg-theme-hint-color);
    user-select: none;
    border-right: 1px solid var(--tg-theme-section-separator-color);
}

.telegram-field .telegram-field__input.atom-input {
    flex: 1;
    min-width: 0;
    border: none;
    border-radius: 0;
    background: transparent;
}

.telegram-field .telegram-field__input.atom-input:focus {
    border-color: transparent;
    outline: none;
}

.telegram-field .telegram-field__input.atom-input.atom-input--error:focus {
    border-color: transparent;
}

.telegram-field:has(.atom-input--error) {
    border-color: var(--tg-theme-destructive-text-color);
}

/* .atom-telegram-link — vitrine_core_atoms.css (Tier 1) */

/* --- 3. Выпадающие списки (Selects) --- */
.atom-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 18px;
    padding-right: 32px;
}

/* --- 4. Редактирование изображений (Canvas) --- */
.atom-image-canvas {
    position: relative;
    width: 100%;
    aspect-ratio: 5 / 3;
    border-radius: var(--border-radius-sm);
    overflow: hidden;
    background: var(--tg-theme-secondary-bg-color);
}

.atom-image-editable {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Кнопки действий поверх изображения */
.atom-image-actions {
    position: absolute;
    top: 8px;
    left: 8px;
    display: none;
    gap: 8px;
    z-index: 10;
}

/* Показываем кнопки ТОЛЬКО при редактировании блока */
.block.is-editing .atom-image-actions {
    display: flex;
}

.atom-image-btn {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
    padding: 0;
}