/* ═══════════════════════════════════════════════════════════════
   Files V2 — модалка файлов задачи
   Извлечено из checklist_operational.css строки 8554–8728
   ═══════════════════════════════════════════════════════════════ */

/* ===== FILES V2 ===== */
.files-v2-wrap {
    padding: var(--space-3, 12px) var(--space-5, 20px) var(--space-4, 16px);
}
.files-v2-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    flex-wrap: wrap;
    gap: var(--space-2);
}
.files-v2-title {
    font-size: var(--text-md);
    font-weight: 700;
    color: var(--color-text);
    margin-right: 10px;
}
.files-v2-subtitle {
    font-size: var(--text-xs);
    color: var(--color-gray-400);
}
.files-v2-refresh-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-gray-100);
    color: var(--color-text-strong);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 8px 12px;
    font-size: var(--text-sm);
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s;
}
.files-v2-refresh-btn:hover { background: var(--color-border); }

/* Empty state */
.files-v2-empty {
    text-align: center;
    padding: 60px 40px;
    color: var(--color-gray-400);
}
.files-v2-empty-icon {
    font-size: 44px;
    display: block;
    margin-bottom: 14px;
}
.files-v2-empty-title {
    font-size: var(--text-md);
    font-weight: 600;
    color: var(--color-text-secondary);
    margin-bottom: 6px;
}
.files-v2-empty-sub {
    font-size: var(--text-sm);
    color: var(--color-gray-400);
}

/* List of file rows */
.files-v2-grid {
    display: flex;
    flex-direction: column;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
}
.files-v2-row {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: 12px 16px;
    border-bottom: 1px solid var(--color-bg-subtle);
    transition: background 0.15s;
}
.files-v2-row:last-child { border-bottom: none; }
.files-v2-row:hover { background: var(--color-bg-subtle); }

.files-v2-icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-lg);
    flex-shrink: 0;
}
.files-v2-icon--pdf { background: var(--color-danger-50); }
.files-v2-icon--img { background: var(--color-primary-50); }
.files-v2-icon--doc { background: var(--color-primary-50); }
.files-v2-icon--xls { background: var(--color-success-50); }
.files-v2-icon--zip { background: var(--color-warning-50); }
.files-v2-icon--other { background: var(--color-gray-100); }

.files-v2-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.files-v2-name {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.35;
    white-space: normal;
    overflow: hidden;
}
.files-v2-name a {
    color: inherit;
    text-decoration: none;
}
.files-v2-name a:hover { color: var(--color-primary); text-decoration: underline; }

.files-v2-breadcrumb {
    font-size: var(--text-xs);
    color: var(--color-text-secondary);
    white-space: normal;
    overflow: hidden;
}

.files-v2-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
    min-width: 110px;
}
.files-v2-size {
    font-size: var(--text-xs);
    color: var(--color-text-secondary);
    font-weight: 500;
}
.files-v2-date {
    font-size: var(--text-xs);
    color: var(--color-gray-400);
}

.files-v2-btn-delete {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    color: var(--color-gray-400);
    cursor: pointer;
    font-size: var(--text-sm);
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    flex-shrink: 0;
    opacity: 0;
}
.files-v2-row:hover .files-v2-btn-delete { opacity: 1; }
.files-v2-btn-delete:hover {
    background: var(--color-danger-50);
    color: var(--color-danger-600);
    border-color: #fca5a5;
    opacity: 1;
}

@media (max-width: 640px) {
    .files-v2-wrap { padding: var(--space-3); }
    .files-v2-row { gap: var(--space-2); padding: 8px 12px; flex-wrap: wrap; }
    .files-v2-meta { min-width: 0; flex-direction: row; gap: var(--space-2); }
    .files-v2-btn-delete { opacity: 1; }
}

