@layer components {
  /* Fizzy-inspired refresh */
  .container {
    max-width: 36rem;
    padding-inline: clamp(var(--space-md), 3vw, var(--space-xl));
  }

  .page-title {
    font-size: clamp(1.75rem, 3vw, 2.3rem);
    letter-spacing: -0.01em;
  }

  .card {
    border: 1px solid var(--color-border);
    border-radius: 0.75rem;
    box-shadow: var(--shadow);
    background: var(--color-surface);
  }

  .btn {
    --btn-hover-brightness: 0.94;

    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    font-weight: 600;
    transition: 120ms ease-out;
    transition-property: background-color, border-color, box-shadow, color, filter;
  }

  .btn:hover {
    filter: brightness(var(--btn-hover-brightness));
  }

  .btn--primary {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
  }

  .btn--negative {
    background-color: var(--color-negative);
    border-color: var(--color-negative);
    color: #fff;
  }

  .input {
    border: 1px solid var(--color-border);
    border-radius: 0.6rem;
    background-color: var(--color-surface);
    padding: 0.6rem 0.85rem;
    font-size: max(16px, 1rem);
  }

  .input:focus {
    border-color: var(--color-link);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-link) 22%, transparent);
  }

  .input--pill {
    border-radius: 99rem;
    padding-inline: 1rem 2.75rem;
  }

  .filter-select,
  .filter-date {
    border-color: var(--color-border);
    border-radius: 99rem;
    background-color: var(--color-surface);
  }

  .month-section {
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: 0.75rem;
    box-shadow: var(--shadow);
    margin-bottom: var(--space-xl);
    padding: var(--space-lg);
  }

  .timeline-page .month-section {
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    margin-bottom: var(--space-xl);
    padding: 0;
  }

  .timeline-page {
    --timeline-divider-color: var(--color-border);
    --timeline-divider-fade-top-size: 1.1rem;
    --timeline-divider-fade-bottom-size: 1.1rem;
  }

  .timeline-page .timeline__line {
    background-color: var(--timeline-divider-color);
    -webkit-mask-image: linear-gradient(
      to bottom,
      transparent 0,
      #000 var(--timeline-divider-fade-top-size),
      #000 calc(100% - var(--timeline-divider-fade-bottom-size)),
      transparent 100%
    );
    mask-image: linear-gradient(
      to bottom,
      transparent 0,
      #000 var(--timeline-divider-fade-top-size),
      #000 calc(100% - var(--timeline-divider-fade-bottom-size)),
      transparent 100%
    );
  }

  .timeline-page .month-section {
    margin-bottom: var(--space-lg);
  }

  .month-header {
    font-style: normal;
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: var(--space-md);
  }

  .metrics {
    border-color: var(--color-border-light);
    background: color-mix(in srgb, var(--color-link) 3%, var(--color-surface));
  }

  .timeline__item {
    border: 1px solid transparent;
    border-radius: 0.65rem;
    padding: 0.5rem 0.65rem;
  }

  .timeline__item:hover {
    background: color-mix(in srgb, var(--color-link) 4%, var(--color-surface));
    border-color: var(--color-border-light);
  }

}
