@layer components {
  .image-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--r-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-md);
  }
  .image-card:hover { box-shadow: var(--shadow-md); }
  .image-preview {
    aspect-ratio: 4/3;
    background: var(--ink-100);
    position: relative;
    overflow: hidden;
  }
  .image-preview img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .image-preview-placeholder {
    width: 100%; height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--forest-100) 0%, var(--ink-100) 100%);
  }
  .image-preview-placeholder svg { width: 32px; height: 32px; color: var(--ink-300, var(--ink-400)); }
  .image-status-overlay {
    position: absolute;
    top: var(--s3);
    right: var(--s3);
  }
  .image-delete-btn {
    position: absolute;
    top: var(--s3);
    left: var(--s3);
    width: 28px; height: 28px;
    border-radius: var(--r-full);
    background: rgba(20,23,20,.6);
    border: none;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    opacity: 0;
    transition: opacity var(--transition);
  }
  .image-card:hover .image-delete-btn { opacity: 1; }
  .image-delete-btn svg { width: 14px; height: 14px; color: #fff; }
  .image-body { padding: var(--s4); }
  .image-meta-input {
    font-family: var(--font-ui);
    font-size: 13px;
    color: var(--ink-800);
    background: transparent;
    border: none;
    border-bottom: 1px solid transparent;
    width: 100%;
    padding: 3px 0;
    transition: border-color var(--transition);
    outline: none;
  }
  .image-meta-input::placeholder { color: var(--ink-400); }
  .image-meta-input:hover { border-bottom-color: var(--ink-200); }
  .image-meta-input:focus { border-bottom-color: var(--forest-500); }
  .image-meta-label { font-size: 10px; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; color: var(--ink-400); margin-top: var(--s3); display: block; }
  .image-save-indicator {
    font-size: 11px;
    color: var(--ink-400);
    text-align: right;
    margin-top: var(--s2);
    height: 14px;
  }
  .image-save-indicator.saving { color: var(--amber-700); }
  .image-save-indicator.saved  { color: var(--success-500); }
}
