/* Shared card surface — GitHub issue #75. Partial: app/views/shared/components/_card.html.erb */
@layer components {

.card {
  padding: var(--space-6);
  background: var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow);
  margin-bottom: var(--space-6);
}

.card h2 {
  margin: 0 0 var(--space-3);
  font-size: var(--text-lg);
  font-weight: 600;
}

.card p {
  margin: 0 0 var(--space-4);
  color: var(--color-text-muted);
}

.card .btn {
  margin-right: var(--space-2);
  margin-bottom: var(--space-2);
}

/* Elevated interactive surface (host dashboard tiles, property list rows) */
.card--interactive {
  margin-bottom: 0;
  border: 1px solid color-mix(in srgb, var(--color-text) 8%, transparent);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  transition: border-color var(--duration-normal) var(--ease-default), box-shadow var(--duration-normal) var(--ease-default), transform var(--duration-normal) var(--ease-default);
}

.card--interactive:hover {
  border-color: color-mix(in srgb, var(--color-primary) 35%, transparent);
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-2px);
}

a.card--interactive:hover {
  color: inherit;
}

.card--interactive:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.card--compact {
  padding: var(--space-5);
}

/* Property show — warm details strip */
.card--warm {
  background: linear-gradient(180deg, #fffbeb 0%, #fffbf5 100%);
  border: 1px solid color-mix(in srgb, var(--color-primary) 12%, transparent);
  box-shadow: 0 2px 10px color-mix(in srgb, var(--color-text) 4%, transparent), 0 0 0 1px color-mix(in srgb, var(--color-primary) 4%, transparent);
}

/* Property show — recordings panel (subtle depth); sticky header uses this custom property */
.card--recordings {
  --sticky-section-top: 4rem; /* clear app nav when sticky */

  background: var(--color-surface);
  border: 1px solid color-mix(in srgb, var(--color-text) 8%, transparent);
  box-shadow: 0 2px 12px color-mix(in srgb, var(--color-text) 6%, transparent), 0 4px 20px color-mix(in srgb, var(--shadow-color) 4%, transparent);
}

/* Checklist edit — meta name / hours bar */
.card--meta {
  margin-bottom: var(--space-2);
  padding: var(--space-4) var(--space-5);
  background: linear-gradient(180deg, var(--color-surface-muted) 0%, var(--color-surface-subtle-2) 100%);
  border: 1px solid color-mix(in srgb, var(--color-text) 8%, transparent);
  border-left: 3px solid var(--color-primary);
  border-radius: var(--radius-ml);
  box-shadow: var(--shadow);
}

/* Auth-style forms — centered panel (no stack margin; matches legacy .auth-card) */
.card--auth {
  width: 100%;
  max-width: 24rem;
  margin-bottom: 0;
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
}

}
