@layer components {

/* Activities Page Layout */
.activities-page {
  max-inline-size: 1000px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

  @media (width <= 640px) {
.activities-page {
    padding: 1rem
}
  }

/* Activity Filters */
.activity-filters {
  margin-block-end: 1.5rem;
  padding: 1rem;
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-primary);
  border-radius: 8px;
}

  @media (width <= 640px) {
.activity-filters {
    padding: 0.75rem
}
  }

  html[data-theme="dark"] .activity-filters {
    background: var(--color-surface-dark);
    border-color: var(--color-border-dark);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity-filters {
      background: var(--color-surface-dark);
      border-color: var(--color-border-dark);
    }
  }

.filters-form {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: flex-end;
}

  @media (width <= 640px) {
.filters-form {
    flex-direction: column;
    align-items: stretch
}
  }

.filter-group {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  min-inline-size: 160px;
}

  @media (width <= 640px) {
.filter-group {
    inline-size: 100%
}
  }

.filter-label {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

  html[data-theme="dark"] .filter-label {
    color: var(--color-slate-400);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .filter-label {
      color: var(--color-slate-400);
    }
  }

.filter-select {
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  border: 1px solid var(--color-border-secondary);
  border-radius: 6px;
  background: var(--color-bg-secondary);
  font-size: 0.875rem;
  color: var(--color-text-emphasis);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em;
}

  .filter-select:focus {
    outline: none;
    border-color: var(--color-primary-500);
    box-shadow: 0 0 0 3px var(--color-primary-100);
  }

  html[data-theme="dark"] .filter-select {
    background-color: var(--color-slate-800);
    border-color: var(--color-border-dark);
    color: var(--color-slate-200);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
  }

    html[data-theme="dark"] .filter-select:focus {
      border-color: var(--color-primary-400);
      box-shadow: 0 0 0 3px var(--color-primary-alpha-20);
    }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .filter-select {
      background-color: var(--color-slate-800);
      border-color: var(--color-border-dark);
      color: var(--color-slate-200);
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
      background-position: right 0.5rem center;
      background-repeat: no-repeat;
      background-size: 1.5em 1.5em;
    }

    html:not([data-theme]) .filter-select:focus {
      border-color: var(--color-primary-400);
      box-shadow: 0 0 0 3px rgba(19, 164, 236, 0.2);
    }
  }

.btn-text {
  background: none;
  border: none;
  color: var(--color-text-link);
  font-size: 0.875rem;
  cursor: pointer;
  padding: 0.5rem;
  text-decoration: none;
}

  .btn-text:hover {
    text-decoration: underline;
  }

/* Activity Feed */
.activity-feed {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-primary);
  border-radius: 8px;
  overflow: hidden;
}

  html[data-theme="dark"] .activity-feed {
    background: var(--color-surface-dark);
    border-color: var(--color-border-dark);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity-feed {
      background: var(--color-surface-dark);
      border-color: var(--color-border-dark);
    }
  }

/* Activity List */
.activity-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.activity-item {
  display: flex;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-block-end: 1px solid var(--color-border-primary);
  transition: background-color 0.15s ease;
}

  .activity-item:last-child {
    border-block-end: none;
  }

  .activity-item:hover {
    background: var(--color-bg-subtle);
  }

  @media (width <= 640px) {
.activity-item {
    padding: 0.875rem 1rem
}
  }

  html[data-theme="dark"] .activity-item {
    border-block-end-color: var(--color-border-dark);
  }

    html[data-theme="dark"] .activity-item:hover {
      background: var(--color-row-hover);
    }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity-item {
      border-block-end-color: var(--color-border-dark);
    }

    html:not([data-theme]) .activity-item:hover {
      background: var(--color-row-hover);
    }
  }

/* Activity Icon */
.activity-icon {
  flex-shrink: 0;
  inline-size: 36px;
  block-size: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--color-bg-tertiary);
  color: var(--color-text-secondary);
}

  .activity-icon svg {
    inline-size: 16px;
    block-size: 16px;
  }

  @media (width <= 640px) {
.activity-icon {
    inline-size: 32px;
    block-size: 32px
}

    .activity-icon svg {
      inline-size: 14px;
      block-size: 14px;
    }
  }

  html[data-theme="dark"] .activity-icon {
    background: var(--color-slate-800);
    color: var(--color-slate-400);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity-icon {
      background: var(--color-slate-800);
      color: var(--color-slate-400);
    }
  }

/* Icon color variations based on activity type */
/* stylelint-disable-next-line no-descending-specificity */
.activity--success .activity-icon {
  background: var(--color-success-100);
  color: var(--color-status-success-action);
}

  html[data-theme="dark"] .activity--success .activity-icon {
    background: var(--color-green-alpha-20);
    color: var(--color-success-400);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity--success .activity-icon {
      background: rgba(34, 197, 94, 0.2);
      color: var(--color-success-400);
    }
  }

/* stylelint-disable-next-line no-descending-specificity */
.activity--info .activity-icon {
  background: var(--color-bg-accent-hover);
  color: var(--color-text-accent-bright);
}

  html[data-theme="dark"] .activity--info .activity-icon {
    background: var(--color-primary-alpha-20);
    color: var(--color-primary-400);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity--info .activity-icon {
      background: rgba(19, 164, 236, 0.2);
      color: var(--color-primary-400);
    }
  }

/* stylelint-disable-next-line no-descending-specificity */
.activity--warning .activity-icon {
  background: var(--color-status-warning-subtle);
  color: var(--color-status-warning-text);
}

  html[data-theme="dark"] .activity--warning .activity-icon {
    background: var(--color-warning-alpha-20);
    color: var(--color-warning-400);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity--warning .activity-icon {
      background: rgba(245, 158, 11, 0.2);
      color: var(--color-warning-400);
    }
  }

/* stylelint-disable-next-line no-descending-specificity */
.activity--primary .activity-icon {
  background: var(--color-bg-accent-hover);
  color: var(--color-text-accent-bright);
}

  html[data-theme="dark"] .activity--primary .activity-icon {
    background: var(--color-primary-alpha-20);
    color: var(--color-primary-400);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity--primary .activity-icon {
      background: rgba(19, 164, 236, 0.2);
      color: var(--color-primary-400);
    }
  }

/* stylelint-disable-next-line no-descending-specificity */
.activity--neutral .activity-icon {
  background: var(--color-bg-tertiary);
  color: var(--color-text-secondary);
}

  html[data-theme="dark"] .activity--neutral .activity-icon {
    background: var(--color-slate-800);
    color: var(--color-slate-400);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity--neutral .activity-icon {
      background: var(--color-slate-800);
      color: var(--color-slate-400);
    }
  }

/* Activity Content */
.activity-content {
  flex: 1;
  min-inline-size: 0;
}

.activity-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-block-end: 0.25rem;
}

.activity-description {
  font-size: 0.875rem;
  color: var(--color-text-strong);
  font-weight: 500;
}

  @media (width <= 640px) {
.activity-description {
    font-size: 0.8125rem
}
  }

  html[data-theme="dark"] .activity-description {
    color: var(--color-slate-300);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity-description {
      color: var(--color-slate-300);
    }
  }

.activity-team {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--team-color, var(--color-neutral-600));
  background: color-mix(in srgb, var(--team-color, var(--color-neutral-600)) 15%, transparent);
  padding: 0.125rem 0.5rem;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.activity-subject {
  margin: 0.25rem 0;
  font-size: 0.9375rem;
  line-height: 1.4;
}

  @media (width <= 640px) {
.activity-subject {
    font-size: 0.875rem
}
  }

.activity-link {
  color: var(--color-text-emphasis);
  text-decoration: none;
  transition: color 0.15s ease;
}

  .activity-link:hover {
    color: var(--color-text-link);
  }

.activity-comment-preview {
  margin: 0.375rem 0 0;
  font-size: 0.8125rem;
  color: var(--color-text-tertiary);
  font-style: italic;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

  html[data-theme="dark"] .activity-comment-preview {
    color: var(--color-slate-500);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity-comment-preview {
      color: var(--color-slate-500);
    }
  }

.activity-time {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-block-start: 0.375rem;
  display: block;
}

  html[data-theme="dark"] .activity-time {
    color: var(--color-slate-500);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .activity-time {
      color: var(--color-slate-500);
    }
  }

/* Empty State */
.empty-state {
  text-align: center;
  padding: 3rem 1.5rem;
}

  .empty-state__icon {
    color: var(--color-text-muted);
    margin-block-end: 1rem;
  }

    .empty-state__icon svg {
      inline-size: 48px;
      block-size: 48px;
    }

  .empty-state__title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-text-strong);
    margin: 0 0 0.5rem;
  }

  .empty-state__description {
    font-size: 0.9375rem;
    color: var(--color-text-tertiary);
    margin: 0;
    max-inline-size: 320px;
    margin-inline-start: auto;
    margin-inline-end: auto;
  }

/* Pagination */
.pagination {
  padding: 1rem;
  border-block-start: 1px solid var(--color-border-primary);
  background: var(--color-bg-subtle);
}

  html[data-theme="dark"] .pagination {
    border-block-start-color: var(--color-border-dark);
    background: rgba(30, 41, 59, 0.5);
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .pagination {
      border-block-start-color: var(--color-border-dark);
      background: rgba(30, 41, 59, 0.5);
    }
  }

.btn-full-width {
  inline-size: 100%;
  display: block;
  text-align: center;
}

/* Error Banner */
.error-banner {
  background: var(--color-status-error-bg);
  border: 1px solid var(--color-error-200);
  border-radius: 8px;
  padding: 1rem 1.25rem;
  margin-block-end: 1.5rem;
}

  .error-banner p {
    margin: 0;
    color: var(--color-error-700);
    font-size: 0.9375rem;
  }

/* Responsive adjustments */
@media (width <= 640px) {
  .header-actions {
    inline-size: 100%;
    justify-content: flex-end;
  }
}

} /* @layer components */
