@layer components {
  /* ── News List: Breaking / Promoted ── */
  .news-breaking-section {
    padding: 0 var(--space-md) var(--space-lg);
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
  }

  .news-breaking {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    background-color: var(--color-surface);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-xl);
    text-decoration: none;
    transition: background-color var(--transition-fast);

    &:hover {
      background-color: var(--color-canvas);
    }
  }

  .news-breaking__thumb {
    width: 5rem;
    height: 5rem;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, var(--color-primary-container), var(--color-canvas));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--color-primary);

    & .material-symbols-outlined {
      font-size: 1.75rem;
    }
  }

  .news-breaking__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: var(--radius-lg);
  }

  .news-breaking__body {
    flex: 1;
    min-width: 0;
  }

  .news-breaking__label {
    display: block;
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-primary);
    margin-bottom: 0.125rem;
  }

  .news-breaking__title {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    color: var(--color-ink);
    line-height: var(--leading-tight);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .news-breaking__meta {
    font-size: var(--text-xs);
    color: var(--color-ink-muted);
    margin-top: 0.125rem;
  }

  .news-breaking__bookmark {
    color: var(--color-ink-muted);
    font-size: 1.25rem;
    flex-shrink: 0;
    margin-right: var(--space-sm);
    transition: color var(--transition-fast);
  }

  .news-breaking:hover .news-breaking__bookmark {
    color: var(--color-primary);
  }
}
