/*
 * Empty States
 *
 * Friendly empty state screens for no issues, no teams, no comments, etc.
 * Includes helpful text and call-to-action buttons.
 */

@layer components {

/* ========================================
 * ENHANCED EMPTY STATE (Full-page)
 * Used for main content areas like Issues, Teams, Activity
 * ======================================== */
.empty-state-enhanced {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 4rem 2rem;
  min-block-size: 300px;
  background: linear-gradient(180deg, var(--color-bg-subtle) 0%, var(--color-bg-secondary) 100%);
  border: 1px dashed var(--color-border-secondary);
  border-radius: 12px;
  margin: 1rem 0;
}

  .empty-state-enhanced .empty-state__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 80px;
    block-size: 80px;
    background: var(--color-bg-accent);
    border-radius: 50%;
    margin-block-end: 1.5rem;
    color: var(--color-primary-400);
    transition: transform 0.2s ease, background 0.2s ease;
  }

    .empty-state-enhanced .empty-state__icon svg {
      inline-size: 40px;
      block-size: 40px;
    }

  .empty-state-enhanced:hover .empty-state__icon {
    transform: scale(1.05);
    background: var(--color-bg-accent-hover);
  }

  .empty-state-enhanced .empty-state__title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-text-emphasis);
    margin: 0 0 0.75rem;
    line-height: 1.4;
  }

  .empty-state-enhanced .empty-state__description {
    font-size: 0.9375rem;
    color: var(--color-text-tertiary);
    margin: 0 0 1.5rem;
    max-inline-size: 400px;
    line-height: 1.6;
  }

  .empty-state-enhanced .empty-state__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
    align-items: center;
  }

  .empty-state-enhanced .empty-state__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    font-size: 0.9375rem;
    font-weight: 500;
    text-decoration: none;
    border-radius: 8px;
    transition: all 0.15s ease;
  }

  .empty-state-enhanced .empty-state__secondary-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    font-size: 0.9375rem;
    font-weight: 500;
    text-decoration: none;
    border-radius: 8px;
    transition: all 0.15s ease;
  }

  /* ========================================
   * RESPONSIVE ADJUSTMENTS
   * ======================================== */
  @media (width <= 768px) {
.empty-state-enhanced {
    padding: 3rem 1.5rem;
    min-block-size: 250px
}

    .empty-state-enhanced .empty-state__icon {
      inline-size: 64px;
      block-size: 64px;
    }

      .empty-state-enhanced .empty-state__icon svg {
        inline-size: 32px;
        block-size: 32px;
      }

    .empty-state-enhanced .empty-state__title {
      font-size: 1.125rem;
    }

    .empty-state-enhanced .empty-state__description {
      font-size: 0.875rem;
    }

    .empty-state-enhanced .empty-state__actions {
      flex-direction: column;
      inline-size: 100%;
    }

    .empty-state-enhanced .empty-state__cta,
    .empty-state-enhanced .empty-state__secondary-cta {
      inline-size: 100%;
      justify-content: center;
    }
  }

  @media (width <= 480px) {
.empty-state-enhanced {
    padding: 2rem 1rem;
    margin: 0.5rem
}
  }

  /* Dark Mode */
  html[data-theme="dark"] .empty-state-enhanced {
    background: var(--color-surface-dark, rgba(22, 27, 34, 0.6));
    border-color: var(--color-border-dark, #30363d);
  }

    html[data-theme="dark"] .empty-state-enhanced .empty-state__icon {
      background: var(--color-slate-800, #1e293b);
      color: var(--color-slate-400, #94a3b8);
    }

    html[data-theme="dark"] .empty-state-enhanced .empty-state__title {
      color: var(--color-slate-200, #e2e8f0);
    }

    html[data-theme="dark"] .empty-state-enhanced .empty-state__description {
      color: var(--color-slate-400, #94a3b8);
    }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .empty-state-enhanced {
      background: var(--color-surface-dark, rgba(22, 27, 34, 0.6));
      border-color: var(--color-border-dark, #30363d);
    }

    html:not([data-theme]) .empty-state-enhanced .empty-state__icon {
      background: var(--color-slate-800, #1e293b);
      color: var(--color-slate-400, #94a3b8);
    }

    html:not([data-theme]) .empty-state-enhanced .empty-state__title {
      color: var(--color-slate-200, #e2e8f0);
    }

    html:not([data-theme]) .empty-state-enhanced .empty-state__description {
      color: var(--color-slate-400, #94a3b8);
    }
  }

/* ========================================
 * INLINE EMPTY STATE
 * Used for compact areas like Comments section, Dashboard cards
 * ======================================== */
.empty-state-inline {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-8, 2rem) var(--space-4, 1rem);
  gap: var(--space-3, 0.75rem);
  background: var(--color-bg-subtle);
  border-radius: 8px;
}

  /* stylelint-disable-next-line no-descending-specificity */
  .empty-state-inline .empty-state__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 56px;
    block-size: 56px;
    background: var(--color-bg-tertiary);
    border-radius: 50%;
    color: var(--color-text-muted);
  }

    .empty-state-inline .empty-state__icon svg {
      inline-size: 28px;
      block-size: 28px;
      opacity: 0.8;
    }

  /* stylelint-disable-next-line no-descending-specificity */
  .empty-state-inline .empty-state__title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text-strong);
    margin: 0;
    line-height: 1.4;
  }

  /* stylelint-disable-next-line no-descending-specificity */
  .empty-state-inline .empty-state__description {
    font-size: 0.875rem;
    color: var(--color-text-tertiary);
    margin: 0;
    max-inline-size: 280px;
    line-height: 1.5;
  }

  .empty-state-inline .empty-state__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: center;
    margin-block-start: 0.5rem;
  }

  .empty-state-inline .empty-state__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    border-radius: 6px;
    transition: all 0.15s ease;
  }

  @media (width <= 480px) {
.empty-state-inline {
    padding: 1.5rem 1rem
}
  }

  /* Dark Mode */
  html[data-theme="dark"] .empty-state-inline {
    background: var(--color-surface-dark, rgba(22, 27, 34, 0.6));
  }

    html[data-theme="dark"] .empty-state-inline .empty-state__icon {
      background: var(--color-slate-800, #1e293b);
      color: var(--color-slate-400, #94a3b8);
    }

    html[data-theme="dark"] .empty-state-inline .empty-state__title {
      color: var(--color-slate-200, #e2e8f0);
    }

    html[data-theme="dark"] .empty-state-inline .empty-state__description {
      color: var(--color-slate-400, #94a3b8);
    }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .empty-state-inline {
      background: var(--color-surface-dark, rgba(22, 27, 34, 0.6));
    }

    html:not([data-theme]) .empty-state-inline .empty-state__icon {
      background: var(--color-slate-800, #1e293b);
      color: var(--color-slate-400, #94a3b8);
    }

    html:not([data-theme]) .empty-state-inline .empty-state__title {
      color: var(--color-slate-200, #e2e8f0);
    }

    html:not([data-theme]) .empty-state-inline .empty-state__description {
      color: var(--color-slate-400, #94a3b8);
    }
  }

/* ========================================
 * CARD EMPTY STATE
 * Used for dashboard cards with minimal styling
 * ======================================== */
.card-empty-enhanced {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 1.5rem 1rem;
  flex: 1;
  min-block-size: 120px;
}

  /* stylelint-disable-next-line no-descending-specificity */
  .card-empty-enhanced .empty-state__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 48px;
    block-size: 48px;
    background: var(--color-bg-tertiary);
    border-radius: 50%;
    margin-block-end: 0.75rem;
    color: var(--color-text-muted);
  }

    .card-empty-enhanced .empty-state__icon svg {
      inline-size: 24px;
      block-size: 24px;
    }

  /* stylelint-disable-next-line no-descending-specificity */
  .card-empty-enhanced .empty-state__title {
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--color-text-secondary);
    margin: 0 0 0.375rem;
  }

  /* stylelint-disable-next-line no-descending-specificity */
  .card-empty-enhanced .empty-state__description {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    margin: 0;
    font-style: italic;
  }

  /* Dark Mode */
  html[data-theme="dark"] .card-empty-enhanced {
    background: var(--color-surface-dark, rgba(22, 27, 34, 0.6));
  }

    html[data-theme="dark"] .card-empty-enhanced .empty-state__icon {
      background: var(--color-slate-800, #1e293b);
      color: var(--color-slate-400, #94a3b8);
    }

    html[data-theme="dark"] .card-empty-enhanced .empty-state__title {
      color: var(--color-slate-200, #e2e8f0);
    }

    html[data-theme="dark"] .card-empty-enhanced .empty-state__description {
      color: var(--color-slate-400, #94a3b8);
    }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .card-empty-enhanced {
      background: var(--color-surface-dark, rgba(22, 27, 34, 0.6));
    }

    html:not([data-theme]) .card-empty-enhanced .empty-state__icon {
      background: var(--color-slate-800, #1e293b);
      color: var(--color-slate-400, #94a3b8);
    }

    html:not([data-theme]) .card-empty-enhanced .empty-state__title {
      color: var(--color-slate-200, #e2e8f0);
    }

    html:not([data-theme]) .card-empty-enhanced .empty-state__description {
      color: var(--color-slate-400, #94a3b8);
    }
  }

/* ========================================
 * ANIMATION
 * ======================================== */
@keyframes empty-state-fade-in {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* stylelint-disable no-descending-specificity -- animation for both empty state variants */
.empty-state-enhanced,
.empty-state-inline {
  animation: empty-state-fade-in 0.3s ease-out;
}
/* stylelint-enable no-descending-specificity */

/* ========================================
 * DARK MODE OVERRIDES
 * ======================================== */

} /* @layer components */
