/*
 * Subscriber management styles
 * Covers both admin subscriber management and public subscribe form
 */

@layer components {
  /* ==========================================================================
     Admin Subscriber Management
     ========================================================================== */

  .subscriber-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-4);
    margin-block-end: var(--space-6);
  }

  .subscriber-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    margin-block-end: var(--space-6);
  }

  .subscriber-search {
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .subscriber-filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  /* ==========================================================================
     Public Subscribe Form
     ========================================================================== */

  .subscribe-section {
    margin-block-end: var(--space-8);
  }

  .subscribe-form {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--space-4) var(--space-5);
  }

  .subscribe-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
  }

  .subscribe-text {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-ink);
  }

  .subscribe-icon {
    color: var(--color-ink-muted);
    flex-shrink: 0;
  }

  .subscribe-input-group {
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .subscribe-email {
    min-width: 220px;
  }

  /* Feedback messages (replace form after submit) */
  .subscribe-feedback {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-5);
    border-radius: var(--radius-xl);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
  }

  .subscribe-feedback-success {
    background: var(--color-surface);
    border: 1px solid var(--color-positive);
    color: var(--color-positive);
  }

  .subscribe-feedback-error {
    background: var(--color-surface);
    border: 1px solid var(--color-negative);
    color: var(--color-negative);
  }

  /* Responsive */
  @media (max-width: 640px) {
    .subscriber-stats {
      grid-template-columns: repeat(2, 1fr);
    }

    .subscriber-toolbar {
      flex-direction: column;
      align-items: stretch;
    }

    .subscribe-content {
      flex-direction: column;
      align-items: stretch;
    }

    .subscribe-input-group {
      flex-direction: column;
    }

    .subscribe-email {
      min-width: 0;
      width: 100%;
    }
  }
}
