/* === PURCHASES.CSS === */
/* assets/css/purchases.css */
/* НАЗНАЧЕНИЕ: Стили для модуля закупок */
/* РАЗМЕР: ~150 строк */

/* Status colors */
.tf-pur-status-draft { color: var(--text-muted); }
.tf-pur-status-pending { color: var(--color-primary); }
.tf-pur-status-approved { color: var(--color-success); }
.tf-pur-status-rejected { color: var(--color-danger); }
.tf-pur-status-purchased { color: var(--color-warning); }
.tf-pur-status-received { color: #22c55e; }
.tf-pur-status-cancelled { color: var(--text-muted); opacity: 0.6; }

/* Purchase list item */
.tf-pur-item {
    display: flex; align-items: flex-start; gap: 8px;
    padding: 8px 10px; border-bottom: 1px solid var(--border);
    cursor: pointer; transition: background 0.1s;
}
.tf-pur-item:hover { background: var(--bg-hover); }
.tf-pur-item.active { background: hsla(217, 91%, 60%, 0.08); border-left: 2px solid var(--color-primary); }
.tf-pur-item-info { flex: 1; min-width: 0; }
.tf-pur-item-title {
    font-size: 12px; color: var(--text-primary); font-weight: 500;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tf-pur-item-meta {
    display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
    font-size: 10px; color: var(--text-muted); margin-top: 2px;
}
.tf-pur-item-amount {
    font-family: var(--font-display); font-weight: 600; font-size: 11px;
    color: var(--text-primary); flex: 0 0 auto; white-space: nowrap;
}

/* List footer (totals bar) */
.tf-pur-list-footer {
    display: flex; align-items: center; justify-content: space-between;
    padding: 6px 10px; border-top: 1px solid var(--border);
    font-size: 11px; font-family: var(--font-display);
    flex: 0 0 auto; color: var(--text-muted);
}
.tf-pur-footer-sum {
    font-weight: 700; color: var(--text-primary); font-size: 12px;
    margin-left: auto; margin-right: 8px;
}

/* Items table */
.tf-pur-items-table {
    width: 100%; border-collapse: collapse; font-size: 11px; margin-top: 6px;
}
.tf-pur-items-table th {
    text-align: left; padding: 4px 6px; font-weight: 500;
    font-family: var(--font-display); font-size: 10px;
    color: var(--text-muted); border-bottom: 1px solid var(--border);
}
.tf-pur-items-table td {
    padding: 4px 6px; border-bottom: 1px solid var(--border);
    color: var(--text-primary);
}
.tf-pur-items-table tr:last-child td { border-bottom: none; }
.tf-pur-items-table .tf-pur-total-row td {
    font-weight: 600; border-top: 2px solid var(--border);
    font-family: var(--font-display);
}
.tf-pur-items-table input {
    width: 100%; padding: 3px 5px; font-size: 11px;
    background: var(--bg-input); border: 1px solid var(--border);
    border-radius: var(--radius); color: var(--text-primary);
}
.tf-pur-items-table input[type="number"] { width: 70px; text-align: right; }

/* Add item row */
.tf-pur-add-item-row {
    display: grid; grid-template-columns: 1fr 70px 80px 90px auto; gap: 4px;
    margin-top: 6px; align-items: center;
}
.tf-pur-add-item-row input, .tf-pur-add-item-row select {
    padding: 4px 6px; font-size: 11px;
    background: var(--bg-input); border: 1px solid var(--border);
    border-radius: var(--radius); color: var(--text-primary);
}

/* Item delete btn */
.tf-pur-item-del {
    background: none; border: none; color: var(--text-muted);
    cursor: pointer; font-size: 13px; padding: 0 4px;
}
.tf-pur-item-del:hover { color: var(--color-danger); }

/* Action buttons bar */
.tf-pur-actions {
    display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px;
}
.tf-pur-actions .tf-btn { font-size: 11px; }

/* Comments */
.tf-pur-comment {
    padding: 6px 0; border-bottom: 1px solid var(--border); font-size: 11px;
}
.tf-pur-comment:last-child { border-bottom: none; }
.tf-pur-comment-header {
    display: flex; gap: 6px; align-items: center; margin-bottom: 2px;
}
.tf-pur-comment-author { font-weight: 500; color: var(--text-primary); }
.tf-pur-comment-date { color: var(--text-muted); font-size: 10px; font-family: var(--font-display); }
.tf-pur-comment-text { color: var(--text-primary); }
.tf-pur-comment.system .tf-pur-comment-text { color: var(--text-muted); font-style: italic; }

/* Comment input */
.tf-pur-comment-input {
    display: flex; gap: 6px; margin-top: 6px;
}
.tf-pur-comment-input input {
    flex: 1; padding: 4px 8px; font-size: 11px;
    background: var(--bg-input); border: 1px solid var(--border);
    border-radius: var(--radius); color: var(--text-primary);
}

/* Files list */
.tf-pur-file {
    display: flex; align-items: center; gap: 6px;
    padding: 4px 0; font-size: 11px;
}
.tf-pur-file-name {
    flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    color: var(--color-primary); cursor: pointer;
}
.tf-pur-file-name:hover { text-decoration: underline; }
.tf-pur-file-size { color: var(--text-muted); font-size: 10px; flex: 0 0 auto; }

/* Supplier modal */
.tf-pur-supplier-modal {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.5); z-index: 1000;
    display: flex; align-items: center; justify-content: center;
}
.tf-pur-supplier-modal-body {
    background: var(--bg-secondary); border: 1px solid var(--border);
    border-radius: var(--radius); width: 500px; max-height: 80vh;
    overflow-y: auto; padding: 16px;
}
.tf-pur-supplier-modal-body h3 {
    margin: 0 0 10px; font-family: var(--font-display); font-size: 14px;
    color: var(--text-primary);
}
.tf-pur-supplier-item {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 8px; border-bottom: 1px solid var(--border);
    font-size: 12px;
}
.tf-pur-supplier-item:last-child { border-bottom: none; }
.tf-pur-supplier-name { flex: 1; color: var(--text-primary); font-weight: 500; }
.tf-pur-supplier-contact { color: var(--text-muted); font-size: 11px; }

/* Inline create form additions */
.tf-pur-items-inline { margin-top: 4px; }
.tf-pur-items-header {
    display: grid; grid-template-columns: 1fr 70px 80px 90px 70px 24px; gap: 4px;
    font-size: 10px; color: var(--text-muted); font-family: var(--font-display);
    padding: 2px 0; border-bottom: 1px solid var(--border); margin-bottom: 4px;
}
.tf-pur-items-inline-row {
    display: grid; grid-template-columns: 1fr 70px 80px 90px 70px 24px; gap: 4px;
    margin-bottom: 4px; align-items: center;
}
.tf-pur-items-inline-row input, .tf-pur-items-inline-row select {
    padding: 3px 5px; font-size: 11px;
    background: var(--bg-input); border: 1px solid var(--border);
    border-radius: var(--radius); color: var(--text-primary);
}
.pur-item-total {
    font-size: 11px; font-family: var(--font-display); font-weight: 600;
    color: var(--text-primary); text-align: right; white-space: nowrap;
}
.tf-pur-items-footer {
    display: flex; justify-content: flex-end; align-items: center; gap: 10px;
    padding: 6px 0; border-top: 2px solid var(--border); margin-top: 4px;
    font-size: 12px; font-family: var(--font-display);
}
.tf-pur-items-footer span:first-child { color: var(--text-muted); font-weight: 500; }
.tf-pur-items-footer span:last-child { font-weight: 700; color: var(--text-primary); }

/* === Voice input zone === */
.tf-pur-voice-zone {
    background: var(--bg-secondary);
    border: 1px dashed var(--border);
    border-radius: var(--radius);
    padding: 10px; margin-bottom: 6px;
}
.tf-pur-voice-zone label {
    display: flex; align-items: center; gap: 6px;
    font-size: 11px; color: var(--text-muted); margin-bottom: 4px;
}
.tf-pur-voice-zone textarea {
    width: 100%; padding: 6px 8px; font-size: 12px;
    background: var(--bg-input); border: 1px solid var(--border);
    border-radius: var(--radius); color: var(--text-primary);
    resize: vertical; min-height: 50px;
}
.tf-pur-voice-actions {
    display: flex; align-items: center; gap: 8px; margin-top: 6px;
}
.tf-pur-voice-hint {
    font-size: 10px; color: var(--text-muted);
    font-family: var(--font-display);
}
.tf-pur-voice-divider {
    text-align: center; position: relative;
    margin: 8px 0; font-size: 10px; color: var(--text-muted);
}
.tf-pur-voice-divider::before {
    content: ''; position: absolute; top: 50%; left: 0; right: 0;
    height: 1px; background: var(--border);
}
.tf-pur-voice-divider span {
    position: relative; background: var(--bg-primary); padding: 0 10px;
}
#tf-pur-ai-parse svg { vertical-align: -2px; margin-right: 2px; }
