@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);
    animation: card-in .25s ease both;
  }
  @keyframes card-in {
    from { opacity: 0; transform: translateY(8px) scale(.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
  }
  .image-card:hover { box-shadow: var(--shadow-md); }

  /* Error state */
  .image-card.error { border-color: var(--danger-500); }

  /* Preview */
  .image-preview {
    aspect-ratio: 4/3;
    background: var(--ink-100);
    position: relative;
    overflow: hidden;
  }
  .image-preview-link { display: block; width: 100%; height: 100%; }
  .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; }
  .image-preview-placeholder--error {
    background: var(--danger-50);
  }
  .image-preview--error {
    background: var(--danger-50);
  }

  /* Status badge */
  .image-status-overlay {
    position: absolute;
    top: var(--s3);
    right: var(--s3);
  }

  /* Delete button */
  .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--visible { opacity: 1; background: rgba(192,57,43,.65); }
  .image-delete-btn:hover { background: rgba(192,57,43,.8); }
  .image-delete-btn svg { width: 14px; height: 14px; color: #fff; }

  /* Upload progress bar on card */
  .image-upload-bar {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: rgba(0,0,0,.15);
  }
  .image-upload-bar-fill {
    height: 100%;
    background: var(--amber-500);
    transition: width .3s ease;
    width: 0%;
  }

  /* Body */
  .image-body { padding: var(--s4); }

  /* Metadata inputs */
  .image-meta-input {
    font-family: var(--font-ui);
    font-size: 14px;
    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: 11px; font-weight: 600;
    letter-spacing: .07em; text-transform: uppercase;
    color: var(--ink-400); margin-top: var(--s3); display: block;
  }

  /* Checkboxes */
  .image-card-checkbox {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: var(--ink-600);
    cursor: pointer;
  }
  .image-card-checkbox input[type="checkbox"] {
    width: 14px;
    height: 14px;
    accent-color: var(--forest-700);
    cursor: pointer;
    margin: 0;
  }

  /* Save indicator */
  .image-save-indicator {
    font-size: 12px;
    color: var(--ink-400);
    text-align: right;
    height: 14px;
    display: flex;
    align-items: center;
    gap: 3px;
  }
  .image-save-indicator.saving { color: var(--ink-400); }
  .image-save-indicator.saved  { color: var(--success-500); }

  /* Tiny spinner */
  .save-spinner {
    width: 12px;
    height: 12px;
    border: 1.5px solid var(--ink-200);
    border-top-color: var(--ink-500);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
  }
  @keyframes spin { to { transform: rotate(360deg); } }

  /* Error notice + retry */
  .image-error-notice {
    margin: 8px 0 6px;
    padding: 9px 11px;
    background: var(--danger-50);
    border-radius: var(--r-md);
    font-size: 13px;
    color: var(--danger-500);
    line-height: 1.5;
  }
  .image-retry-btn {
    width: 100%;
    padding: 6px 0;
    background: var(--color-surface);
    border: 1px solid var(--ink-200);
    border-radius: var(--r-md);
    font-size: 13px;
    font-family: var(--font-ui);
    color: var(--forest-700);
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition);
  }
  .image-retry-btn:hover { background: var(--forest-50); border-color: var(--forest-300); }

  /* Error toast stack */
  .upload-error-stack {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: var(--s4);
  }
  .upload-error-stack:empty { display: none; }
  .upload-error-toast {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: var(--danger-50);
    border: 1px solid var(--danger-500);
    border-radius: var(--r-md);
    font-size: 14px;
    color: var(--danger-600);
    line-height: 1.4;
    transition: opacity .3s;
  }
  .upload-error-toast strong { font-weight: 600; }
  .upload-error-toast-icon { flex-shrink: 0; }
  .upload-error-toast-icon svg { width: 16px; height: 16px; color: var(--danger-500); }
  .upload-error-toast-close {
    margin-left: auto;
    background: none;
    border: none;
    font-size: 19px;
    color: var(--danger-500);
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
  }
  @keyframes toast-in {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: none; }
  }

  /* Responsive — tablet */
  @media (max-width: 768px) {
    .image-body {
      padding: var(--s3);
    }

    .image-meta-input {
      width: 100%;
      font-size: 15px;
      padding: 4px 0;
    }

    .image-delete-btn {
      opacity: 1;
      width: 44px;
      height: 44px;
    }

    .image-delete-btn svg {
      width: 18px;
      height: 18px;
    }

    .image-retry-btn {
      min-height: 44px;
      font-size: 14px;
    }

    .upload-error-toast-close {
      min-width: 44px;
      min-height: 44px;
      display: flex;
      align-items: center;
      justify-content: center;
    }
  }

  /* Responsive — mobile */
  @media (max-width: 480px) {
    .image-body {
      padding: var(--s2);
    }

    .image-meta-label {
      margin-top: var(--s2);
    }

    .image-card-checkbox {
      font-size: 14px;
      gap: 8px;
      min-height: 44px;
    }

    .image-card-checkbox input[type="checkbox"] {
      width: 18px;
      height: 18px;
    }
  }
}
