@layer base {
  .statusCard {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-6);
    box-shadow: var(--shadow);
  }

  .statusHeader {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-6);
    padding-bottom: var(--spacing-4);
    border-bottom: 1px solid var(--border);
  }

  .statusTitle {
    font-family: var(--font-family-heading);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--foreground);
    margin: 0;
  }

  .overallStatus {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-2) var(--spacing-3);
    border-radius: var(--radius);
    font-size: 0.875rem;
    font-weight: 500;
  }

  .statusList {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
  }

  .statusItem {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--spacing-4);
    padding: var(--spacing-3);
    border-radius: var(--radius);
    background: var(--muted);
    transition: background-color var(--animation-duration-fast) ease;
  }

  .statusItem:hover {
    background: color-mix(in srgb, var(--muted) 80%, transparent);
  }

  .serviceInfo {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
  }

  .serviceName {
    font-weight: 500;
    color: var(--foreground);
    font-size: 0.9375rem;
  }

  .serviceDescription {
    font-size: 0.8125rem;
    color: var(--muted-foreground);
    line-height: 1.4;
  }

  .statusInfo {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--spacing-1);
  }

  .statusBadge {
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
    padding: var(--spacing-1) var(--spacing-2);
    border-radius: var(--radius);
    font-size: 0.8125rem;
    font-weight: 500;
    white-space: nowrap;
  }

  .lastChecked {
    font-size: 0.75rem;
    color: var(--muted-foreground);
    white-space: nowrap;
  }

  /* Status variants */
  .operational {
    background: color-mix(in srgb, var(--success) 10%, transparent);
    color: var(--success);
  }

  .operationalIcon {
    color: var(--success);
  }

  .degraded {
    background: color-mix(in srgb, var(--warning) 10%, transparent);
    color: var(--warning);
  }

  .degradedIcon {
    color: var(--warning);
  }

  .outage {
    background: color-mix(in srgb, var(--error) 10%, transparent);
    color: var(--error);
  }

  .outageIcon {
    color: var(--error);
  }

  .unknown {
    background: color-mix(in srgb, var(--muted-foreground) 10%, transparent);
    color: var(--muted-foreground);
  }

  .unknownIcon {
    color: var(--muted-foreground);
  }

  .statusFooter {
    margin-top: var(--spacing-6);
    padding-top: var(--spacing-4);
    border-top: 1px solid var(--border);
    text-align: center;
  }

  .footerText {
    font-size: 0.8125rem;
    color: var(--muted-foreground);
    margin: 0;
  }

  /* Mobile responsive */
  @media (max-width: 768px) {
    .statusCard {
      padding: var(--spacing-4);
    }

    .statusHeader {
      flex-direction: column;
      align-items: flex-start;
      gap: var(--spacing-3);
    }

    .statusTitle {
      font-size: 1.125rem;
    }

    .statusItem {
      flex-direction: column;
      align-items: flex-start;
      gap: var(--spacing-2);
    }

    .statusInfo {
      align-items: flex-start;
      width: 100%;
    }

    .statusBadge {
      align-self: flex-start;
    }

    .lastChecked {
      align-self: flex-start;
    }
  }
}