/**
 * tag-modals.css
 * Стили для модальных окон TagModals компонента.
 * Идентичные стили из modules/tags/css/tags.css и modules/tags/css/components.css
 */

/* === MODAL OVERLAY === */
#tag-modals-container .modal-overlay {
    position: fixed;
    inset: 0;
    background-color: var(--bg-overlay);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    transition: opacity 0.2s ease-in-out;
    z-index: 2300; /* Above activity modals (2200) */
}

#tag-modals-container .modal-overlay.modal-top {
    z-index: 2400; /* Above tag-modals overlay for nested modals */
}

#tag-modals-container .modal-overlay.hidden {
    display: none !important;
}

/* === MODAL CONTAINER === */
#tag-modals-container .modal-container {
    background-color: var(--bg-secondary);
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
    padding: var(--space-6);
    width: 100%;
    max-width: 28rem;
    min-height: auto !important; /* Override global min-height: 70vh from modal.css */
}

#tag-modals-container .modal-container-lg {
    max-width: 32rem;
}

#tag-modals-container .modal-container-scrollable {
    max-height: 90vh;
    overflow-y: auto;
}

/* === MODAL HEADER === */
#tag-modals-container .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-4);
    padding: 0;
    border-bottom: none;
}

#tag-modals-container .modal-body {
    padding: 0;
}

#tag-modals-container .modal-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
}

/* === MODAL ACTIONS === */
#tag-modals-container .modal-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    margin-top: var(--space-6);
    gap: var(--space-4);
}

/* === FORM ELEMENTS === */
#tag-modals-container .form-label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--text-secondary);
    margin-bottom: var(--space-1);
}

#tag-modals-container .form-input {
    width: 100%;
    background-color: var(--bg-tertiary);
    border: 1px solid var(--border-secondary);
    border-radius: var(--radius-lg);
    padding: var(--space-2);
    color: var(--text-primary);
    font-family: var(--font-family);
    font-size: var(--font-size-base);
}

#tag-modals-container .form-input::placeholder {
    color: var(--text-secondary);
}

#tag-modals-container .form-input:focus {
    outline: none;
    border-color: var(--brand-primary);
    box-shadow: 0 0 0 3px var(--focus-ring);
}

#tag-modals-container .form-select {
    width: 100%;
    background-color: var(--bg-tertiary);
    border: 1px solid var(--border-secondary);
    border-radius: var(--radius-lg);
    padding: var(--space-2);
    color: var(--text-primary);
    font-family: var(--font-family);
    font-size: var(--font-size-base);
}

#tag-modals-container .form-select:focus {
    outline: none;
    border-color: var(--brand-primary);
    box-shadow: 0 0 0 3px var(--focus-ring);
}

#tag-modals-container .form-textarea {
    width: 100%;
    background-color: var(--bg-tertiary);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-2);
    color: var(--text-primary);
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    resize: none;
    overflow: hidden;
}

#tag-modals-container .form-textarea:focus {
    outline: none;
    border-color: var(--brand-primary);
}

#tag-modals-container .form-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/* === FIELDS MODAL === */

#tag-modals-container .field-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
}

#tag-modals-container .field-list-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--bg-hover);
    padding: var(--space-2);
    border-radius: var(--radius-md);
}

#tag-modals-container .field-list-item-name {
    color: var(--text-primary);
}

#tag-modals-container .field-list-item-type {
    font-size: var(--font-size-xs);
    color: var(--text-secondary);
    margin-left: var(--space-1);
}

#tag-modals-container .field-list-item-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

#tag-modals-container .field-list-item-btn-edit {
    color: var(--text-secondary);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

#tag-modals-container .field-list-item-btn-edit:hover {
    color: var(--text-primary);
}

#tag-modals-container .field-list-item-btn-remove {
    color: var(--color-error);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

#tag-modals-container .field-list-item-btn-remove:hover {
    color: var(--color-error-hover);
}

#tag-modals-container .field-list-empty {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}

#tag-modals-container .btn-add-field {
    color: var(--color-info);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

#tag-modals-container .btn-add-field:hover {
    color: var(--color-info-hover);
}

/* === ALERT ICONS === */
#tag-modals-container .alert-icon-error,
#tag-modals-container .alert-icon-warning,
#tag-modals-container .alert-icon-info,
#tag-modals-container .alert-icon-success {
    width: 1.5rem;
    height: 1.5rem;
}

#tag-modals-container .alert-icon-error {
    color: var(--color-error);
}

#tag-modals-container .alert-icon-warning {
    color: var(--color-warning);
}

#tag-modals-container .alert-icon-info {
    color: var(--color-info);
}

#tag-modals-container .alert-icon-success {
    color: var(--color-success);
}

/* === UTILITY CLASSES === */
#tag-modals-container .text-secondary {
    color: var(--text-secondary);
}

#tag-modals-container .text-tertiary {
    color: var(--text-tertiary);
}

#tag-modals-container .icon-md {
    width: 1.5rem;
    height: 1.5rem;
}

#tag-modals-container .flex-row-start {
    display: flex;
    align-items: flex-start;
}

#tag-modals-container .flex-row-end {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

#tag-modals-container .flex-row-end-gap {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: var(--space-4);
}

#tag-modals-container .flex-1 {
    flex: 1;
}

#tag-modals-container .flex-shrink-0 {
    flex-shrink: 0;
}

/* === SPACING === */
#tag-modals-container .mb-2 {
    margin-bottom: var(--space-2);
}

#tag-modals-container .mb-4 {
    margin-bottom: var(--space-4);
}

#tag-modals-container .mb-6 {
    margin-bottom: var(--space-6);
}

#tag-modals-container .mr-3 {
    margin-right: var(--space-3);
}

#tag-modals-container .mt-4 {
    margin-top: var(--space-4);
}

#tag-modals-container .pt-4 {
    padding-top: var(--space-4);
}

#tag-modals-container .divider-primary {
    border-top: 1px solid var(--border-primary);
}

/* === BUTTON STATES === */
#tag-modals-container .opacity-50 {
    opacity: 0.5;
}

#tag-modals-container .cursor-not-allowed {
    cursor: not-allowed;
}

/* === BUTTONS === */
#tag-modals-container .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-lg);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: all 0.15s ease;
    border: none;
}

#tag-modals-container .btn-primary {
    background-color: var(--brand-primary);
    color: var(--text-inverse);
}

#tag-modals-container .btn-primary:hover {
    background-color: var(--brand-primary-hover);
}

#tag-modals-container .btn-primary:disabled {
    background-color: var(--brand-primary);
    opacity: 0.5;
    cursor: not-allowed;
}

#tag-modals-container .btn-secondary {
    background-color: var(--bg-tertiary);
    color: var(--text-primary);
    border: 1px solid var(--border-secondary);
}

#tag-modals-container .btn-secondary:hover {
    background-color: var(--bg-hover);
}

#tag-modals-container .btn-danger {
    background-color: var(--color-error);
    color: var(--text-inverse);
}

#tag-modals-container .btn-danger:hover {
    background-color: var(--color-error-hover);
}

#tag-modals-container .btn-icon {
    padding: var(--space-1);
    background: transparent;
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#tag-modals-container .btn-icon:hover {
    background-color: var(--bg-hover);
}
