@layer reset, tokens, layout, components, states;

@layer reset {
  *,
  *::before,
  *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }
  html {
    hanging-punctuation: first last;
    scroll-behavior: smooth;
  }
  .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
  }
  .skip-link {
    position: absolute;
    inset-inline-start: -9999px;
    inset-block-start: -9999px;
    z-index: 10000;
    padding: 0.75rem 1rem;
    background: var(--accent);
    color: var(--surface-0);
    font-weight: 600;
    text-decoration: none;
    border-radius: 0 0 var(--radius-sm) 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    overflow: hidden;
    white-space: nowrap;
  }
  .skip-link:focus {
    inset-inline-start: 0;
    inset-block-start: 0;
    clip: auto;
    clip-path: none;
    overflow: visible;
  }
}

@layer tokens {
  :root {
    /* Surfaces */
    --surface-0: #0a0a0c;
    --surface-1: #131318;
    --surface-2: #1a1a22;
    --surface-3: #24242f;

    /* Borders */
    --border: #2a2a38;
    --border-accent: #3d3d52;

    /* Text */
    --text-0: #e8e6f0;
    --text-1: #b0adc0;
    --text-2: #9491a8;

    /* Accent */
    --accent: #e8a44a;
    --accent-dim: #b07a30;
    --accent-glow: #e8a44a33;
    --accent-glow-strong: #e8a44a55;

    /* Status */
    --danger: #f07178;
    --danger-glow: #f0717833;
    --success: #c3e88d;
    --success-glow: #c3e88d33;
    --info: #82aaff;

    /* Fonts — single family, style-switch via font-stretch */
    --font-family: 'BaseNative', system-ui, sans-serif;
    --font-sans: normal;
    --font-serif: expanded;
    --font-mono: ultra-condensed;

    /* Easing */
    --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --ease-out-back: cubic-bezier(0.34, 1.3, 0.64, 1);

    /* Durations */
    --duration-fast: 0.15s;
    --duration-med: 0.3s;
    --duration-slow: 0.5s;

    /* Line heights */
    --line-height-body: 1.65;
    --line-height-code: 1.7;
    --line-height-tight: 1.55;

    /* Sizing */
    --size-inline-max: 52rem;
    --size-text-max: 52ch;

    /* Spacing */
    --space-xs: 0.25rem;
    --space-sm: 0.5rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    --space-3xl: 4rem;
    --space-page-block-end: 6rem;

    /* Radii */
    --radius-sm: 0.25rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-pill: 1rem;

    /* Font sizes */
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.8rem;
    --font-size-base: 0.875rem;
    --font-size-md: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-hero: clamp(2rem, 4vw, 3rem);

    /* Font weights */
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;

    /* Letter spacing */
    --letter-spacing-tight: -0.02em;
    --letter-spacing-wide: 0.04em;
    --letter-spacing-wider: 0.08em;

    /* Borders */
    --border-width: 1px;
    --border-inline-width: 2px;
    --border-code-width: 3px;

    /* Shadows */
    --shadow-card: 0 4px 24px -4px #0004;
    --shadow-card-hover: 0 8px 32px -4px #0006;
    --shadow-btn: 0 0 16px -4px var(--accent-glow-strong);
    --shadow-input: 0 0 0 3px var(--accent-glow);

    /* Status backgrounds */
    --status-active-bg: #c3e88d18;
    --status-idle-bg: #e8a44a18;
    --status-error-bg: #f0717818;
    --status-pending-bg: #7a789018;

    /* Noise overlay */
    --noise-opacity: 0.025;
    --noise-size: 200px;
    --z-noise: 9999;

    /* Syntax highlighting */
    --syntax-keyword: #c792ea;
    --syntax-string: #c3e88d;
    --syntax-function: #82aaff;
    --syntax-number: #f78c6c;
    --syntax-comment: #7a98a5;
    --syntax-tag: #f07178;
    --syntax-attr: #ffcb6b;

    /* Stat grid */
    --stat-grid-columns: 4;
    --stat-value-size: var(--font-size-2xl);

    /* Playground */
    --counter-output-size: var(--font-size-2xl);
    --log-max-height: 12rem;
    --log-entry-opacity: 0.7;

    /* Container query breakpoints */
    --cq-compact: 20rem;
    --cq-medium: 30rem;

    /* Inset surfaces */
    --surface-inset: #08080a;

    /* Track (range, progress) */
    --track-bg: #2a2a38;
    --track-fill: var(--accent);
    --track-height: 0.375rem;
    --thumb-size: 1.125rem;

    /* Meter */
    --meter-low: var(--danger);
    --meter-mid: var(--accent);
    --meter-high: var(--success);

    /* Mark */
    --mark-bg: #e8a44a22;
    --mark-text: var(--accent);

    /* Kbd */
    --kbd-bg: var(--surface-3);
    --kbd-border: var(--border-accent);
    --kbd-shadow: 0 2px 0 var(--border);

    /* Blockquote */
    --blockquote-border: var(--accent-dim);

    /* Table */
    --table-stripe: #ffffff06;
    --table-header-bg: var(--surface-2);

    /* Details */
    --details-marker: var(--accent);

    /* Dialog */
    --dialog-bg: var(--surface-1);
    --dialog-border: var(--border-accent);
    --dialog-backdrop: #0a0a0ccc;
    --dialog-shadow: 0 16px 64px -16px #000a;

    /* Popover */
    --popover-bg: var(--surface-2);
    --popover-border: var(--border-accent);
    --popover-shadow: 0 8px 32px -8px #000a;
    --popover-radius: var(--radius-md);
    --anchor-offset: var(--space-sm);

    /* Tooltip */
    --tooltip-bg: var(--surface-3);
    --tooltip-text: var(--text-0);
    --tooltip-font-size: var(--font-size-xs);

    /* Select */
    --select-bg: var(--surface-0);
    --select-option-hover: var(--surface-3);

    /* Checkbox / Radio */
    --control-size: 1.125rem;
    --control-bg: var(--surface-0);
    --control-border: var(--border);
    --control-checked-bg: var(--accent);
    --control-checked-border: var(--accent);
  }
}

@layer layout {
  body {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    background: var(--surface-0);
    color: var(--text-0);
    line-height: var(--line-height-body);
    min-block-size: 100dvh;
    display: flex;
    flex-direction: column;
  }

  body::after {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    opacity: var(--noise-opacity);
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: var(--noise-size);
    z-index: var(--z-noise);
  }

  body > header {
    border-block-end: var(--border-width) solid var(--border);
    background: var(--surface-1);
  }

  body > header > nav {
    max-inline-size: var(--size-inline-max);
    margin-inline: auto;
    padding: var(--space-md) var(--space-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    flex-wrap: wrap;
    /* Stop the wordmark from shoving the nav off-screen on narrow viewports. */
    min-inline-size: 0;
  }

  body > header h1 {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-normal);
    letter-spacing: var(--letter-spacing-tight);
  }

  body > header h1 em {
    font-style: normal;
    color: var(--accent);
  }

  body > header ul {
    list-style: none;
    display: flex;
    gap: var(--space-md);
    /* Below the breakpoint, the nav links scroll horizontally with snap.
       No fixed scrollbar; works on touch + trackpads. */
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    min-inline-size: 0;
    max-inline-size: 100%;
  }
  body > header ul::-webkit-scrollbar {
    display: none;
  }
  body > header li {
    scroll-snap-align: start;
    flex: 0 0 auto;
  }

  body > header a {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
    color: var(--text-1);
    text-decoration: none;
    padding: var(--space-sm) var(--space-md);
    min-block-size: 2.75rem;
    display: inline-flex;
    align-items: center;
    border-radius: var(--radius-sm);
    transition:
      color var(--duration-fast),
      background var(--duration-fast);
  }
  body > header a:hover {
    color: var(--accent);
    background: var(--surface-2);
  }
  body > header a[aria-current='page'] {
    color: var(--accent);
  }

  main {
    flex: 1;
    max-inline-size: var(--size-inline-max);
    margin-inline: auto;
    padding: var(--space-2xl) var(--space-lg) var(--space-page-block-end);
    inline-size: 100%;
    container-type: inline-size;
    container-name: page;
  }

  body > footer {
    border-block-start: var(--border-width) solid var(--border);
    padding: var(--space-lg);
    text-align: center;
  }

  body > footer p {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    color: var(--text-2);
  }
}

@layer components {
  /* -- Sections -- */
  section {
    margin-block-end: var(--space-2xl);
  }

  section > h2 {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-hero);
    font-weight: var(--font-weight-normal);
    letter-spacing: var(--letter-spacing-tight);
    margin-block-end: var(--space-sm);
  }

  section > h2 em {
    font-style: normal;
    color: var(--accent);
  }

  section > p {
    font-size: var(--font-size-lg);
    color: var(--text-1);
    max-inline-size: var(--size-text-max);
    margin-block-end: var(--space-xl);
  }

  /* -- Hero -- */
  [data-hero] {
    padding-block: var(--space-3xl);
    text-align: center;
  }

  [data-hero] > h2 {
    font-size: var(--font-size-hero);
    margin-block-end: var(--space-md);
  }

  [data-hero] > p {
    margin-inline: auto;
    margin-block-end: var(--space-xl);
  }

  [data-hero] nav {
    justify-content: center;
  }

  [data-hero] a {
    text-decoration: none;
  }

  /* -- Stat grid -- */
  [data-stats] {
    container-type: inline-size;
    container-name: stats;
  }

  ul[role='list'][data-stat-grid] {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-md);
    list-style: none;
    flex-direction: unset;
  }

  ul[role='list'][data-stat-grid] > li {
    background: var(--surface-1);
    border: var(--border-width) solid var(--border);
    border-inline-start: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--space-xs);
    transition:
      border-color var(--duration-med),
      box-shadow var(--duration-med);
  }

  ul[role='list'][data-stat-grid] > li:hover {
    border-color: var(--border-accent);
    box-shadow: var(--shadow-card);
  }

  ul[role='list'][data-stat-grid] strong {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--stat-value-size);
    color: var(--accent);
  }

  ul[role='list'][data-stat-grid] span {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
    color: var(--text-2);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
  }

  /* -- Articles (cards) -- */
  article {
    background: var(--surface-1);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    margin-block-end: var(--space-md);
    transition:
      border-color var(--duration-med),
      box-shadow var(--duration-med);
    container-type: inline-size;
    container-name: card;
  }
  article:hover {
    border-color: var(--border-accent);
    box-shadow: var(--shadow-card);
  }

  article > header {
    margin-block-end: var(--space-sm);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
  }

  article > header h3 {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--accent);
    letter-spacing: var(--letter-spacing-wide);
  }

  article p {
    font-size: var(--font-size-base);
    color: var(--text-1);
    line-height: var(--line-height-tight);
    margin-block-end: var(--space-md);
  }

  article p:last-child {
    margin-block-end: 0;
  }

  article p code {
    font-size: var(--font-size-base);
    color: var(--accent);
    padding: var(--space-xs) var(--space-sm);
    background: var(--surface-2);
    border-radius: var(--radius-sm);
  }

  /* -- Lists -- */
  ul[role='list'] {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
  }
  ul[role='list'] li {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-base);
    padding: var(--space-sm) var(--space-md);
    background: var(--surface-2);
    border-radius: var(--radius-sm);
    border-inline-start: var(--border-inline-width) solid var(--accent-dim);
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition:
      background var(--duration-fast),
      border-color var(--duration-fast);
  }
  ul[role='list'] li:hover {
    background: var(--surface-3);
    border-inline-start-color: var(--accent);
  }

  /* -- Status badges (scoped to <mark> so component data-status is unaffected) -- */
  mark[data-status] {
    display: inline-block;
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-pill);
    font-weight: var(--font-weight-semibold);
    white-space: nowrap;
  }
  mark[data-status='active'],
  mark[data-status='done'] {
    background: var(--status-active-bg);
    color: var(--success);
  }
  mark[data-status='idle'],
  mark[data-status='dom'],
  mark[data-status='binding'] {
    background: var(--status-idle-bg);
    color: var(--accent);
  }
  mark[data-status='error'] {
    background: var(--status-error-bg);
    color: var(--danger);
  }
  mark[data-status='pending'],
  mark[data-status='server'] {
    background: var(--status-pending-bg);
    color: var(--text-2);
  }
  mark[data-status='active'],
  mark[data-status='core'],
  mark[data-status='directive'] {
    background: var(--status-active-bg);
    color: var(--success);
  }

  /* -- Buttons -- */
  button:not([data-bn]),
  a[role='button'] {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
    padding: var(--space-sm) var(--space-md);
    min-block-size: 2.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--surface-3);
    color: var(--text-0);
    border: var(--border-width) solid var(--border-accent);
    border-radius: var(--radius-sm);
    cursor: pointer;
    text-decoration: none;
    transition:
      background var(--duration-fast),
      border-color var(--duration-fast),
      color var(--duration-fast),
      box-shadow var(--duration-med);
  }
  button:not([data-bn]):hover,
  a[role='button']:hover {
    background: var(--accent-dim);
    border-color: var(--accent);
    color: var(--surface-0);
    box-shadow: var(--shadow-btn);
  }
  button:not([data-bn]):focus-visible,
  a[role='button']:focus-visible {
    outline: var(--border-inline-width) solid var(--accent);
    outline-offset: var(--border-inline-width);
  }
  button:not([data-bn])[data-variant='danger'] {
    border-color: var(--danger);
    color: var(--danger);
  }
  button:not([data-bn])[data-variant='danger']:hover {
    background: var(--danger);
    color: var(--surface-0);
  }
  [data-variant='outline'] {
    background: transparent;
    border-color: var(--border-accent);
    color: var(--text-1);
  }
  [data-variant='outline']:hover {
    background: var(--surface-2);
    border-color: var(--accent);
    color: var(--accent);
    box-shadow: none;
  }

  /* -- Icons in buttons -- */
  button:not([data-bn]) > img[src*='/icons/'] {
    inline-size: 1em;
    block-size: 1em;
    vertical-align: middle;
    filter: brightness(0) invert(0.9);
  }
  button:not([data-bn]):hover > img[src*='/icons/'] {
    filter: brightness(0) invert(0.03);
  }

  /* -- Inputs -- */
  input[type='text']:not([data-bn]) {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-base);
    padding: var(--space-sm) var(--space-md);
    background: var(--surface-0);
    color: var(--text-0);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-sm);
    outline: none;
    transition:
      border-color var(--duration-med),
      box-shadow var(--duration-med);
  }
  input[type='text']:not([data-bn]):focus {
    border-color: var(--accent);
    box-shadow: var(--shadow-input), var(--shadow-btn);
  }
  input[type='text']:not([data-bn])::placeholder {
    color: var(--text-2);
  }

  /* -- Textarea -- */
  textarea:not([data-bn]) {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-base);
    line-height: var(--line-height-code);
    padding: var(--space-sm) var(--space-md);
    background: var(--surface-0);
    color: var(--text-0);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-sm);
    outline: none;
    resize: vertical;
    field-sizing: content;
    min-block-size: 4lh;
    transition:
      border-color var(--duration-med),
      box-shadow var(--duration-med);
  }
  textarea:not([data-bn]):focus {
    border-color: var(--accent);
    box-shadow: var(--shadow-input), var(--shadow-btn);
  }
  textarea:not([data-bn])::placeholder {
    color: var(--text-2);
  }

  /* -- Checkbox -- */
  input[type='checkbox']:not([data-bn]) {
    appearance: none;
    inline-size: var(--control-size);
    block-size: var(--control-size);
    min-inline-size: 2.75rem;
    min-block-size: 2.75rem;
    background: var(--control-bg);
    border: var(--border-width) solid var(--control-border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
    transition:
      background var(--duration-fast),
      border-color var(--duration-fast),
      box-shadow var(--duration-fast);
  }
  input[type='checkbox']:not([data-bn]):checked {
    background: var(--control-checked-bg);
    border-color: var(--control-checked-border);
  }
  input[type='checkbox']:not([data-bn]):checked::after {
    content: '';
    position: absolute;
    inset-block-start: 0.125rem;
    inset-inline-start: 0.3125rem;
    inline-size: 0.3125rem;
    block-size: 0.5625rem;
    border: solid var(--surface-0);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
  }
  input[type='checkbox']:not([data-bn]):focus-visible {
    outline: var(--border-inline-width) solid var(--accent);
    outline-offset: var(--border-inline-width);
  }

  /* -- Radio -- */
  input[type='radio']:not([data-bn]) {
    appearance: none;
    inline-size: var(--control-size);
    block-size: var(--control-size);
    min-inline-size: 2.75rem;
    min-block-size: 2.75rem;
    background: var(--control-bg);
    border: var(--border-width) solid var(--control-border);
    border-radius: 50%;
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
    transition:
      background var(--duration-fast),
      border-color var(--duration-fast);
  }
  input[type='radio']:not([data-bn]):checked {
    border-color: var(--control-checked-border);
  }
  input[type='radio']:not([data-bn]):checked::after {
    content: '';
    position: absolute;
    inset-block-start: 50%;
    inset-inline-start: 50%;
    inline-size: 0.5rem;
    block-size: 0.5rem;
    background: var(--control-checked-bg);
    border-radius: 50%;
    transform: translate(-50%, -50%);
  }
  input[type='radio']:not([data-bn]):focus-visible {
    outline: var(--border-inline-width) solid var(--accent);
    outline-offset: var(--border-inline-width);
  }

  /* -- Range -- */
  input[type='range'] {
    appearance: none;
    inline-size: 100%;
    block-size: var(--track-height);
    background: linear-gradient(
      to right,
      var(--track-fill) calc(var(--range-pct, 50) * 1%),
      var(--track-bg) calc(var(--range-pct, 50) * 1%)
    );
    border-radius: var(--radius-pill);
    outline: none;
    cursor: pointer;
  }
  input[type='range']::-webkit-slider-thumb {
    appearance: none;
    inline-size: var(--thumb-size);
    block-size: var(--thumb-size);
    background: var(--accent);
    border: var(--border-inline-width) solid var(--surface-0);
    border-radius: 50%;
    box-shadow: 0 0 8px var(--accent-glow);
    transition:
      box-shadow var(--duration-fast),
      scale var(--duration-fast);
  }
  input[type='range']::-webkit-slider-thumb:hover {
    scale: 1.15;
    box-shadow: 0 0 16px var(--accent-glow-strong);
  }
  input[type='range']:focus-visible {
    outline: var(--border-inline-width) solid var(--accent);
    outline-offset: var(--space-xs);
  }

  /* -- Date input -- */
  input[type='date'] {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-base);
    padding: var(--space-sm) var(--space-md);
    background: var(--surface-0);
    color: var(--text-0);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-sm);
    outline: none;
    color-scheme: dark;
    transition:
      border-color var(--duration-med),
      box-shadow var(--duration-med);
  }
  input[type='date']:focus {
    border-color: var(--accent);
    box-shadow: var(--shadow-input), var(--shadow-btn);
  }
  input[type='date']::-webkit-calendar-picker-indicator {
    filter: invert(0.7);
    cursor: pointer;
  }

  /* -- Select (base-select) -- */
  select:not([data-bn]) {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-base);
    padding: var(--space-sm) var(--space-md);
    padding-inline-end: var(--space-xl);
    background: var(--select-bg);
    color: var(--text-0);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-sm);
    outline: none;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23e8a44a' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-sm) center;
    background-size: 0.625rem;
    transition:
      border-color var(--duration-med),
      box-shadow var(--duration-med);
  }
  select:not([data-bn]):focus {
    border-color: var(--accent);
    box-shadow: var(--shadow-input), var(--shadow-btn);
  }

  @supports (appearance: base-select) {
    select:not([data-bn]),
    select:not([data-bn])::picker(select) {
      appearance: base-select;
    }

    select:not([data-bn]) {
      padding-inline-end: var(--space-md);
      background-image: none;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    select:not([data-bn])::picker-icon {
      content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' width='10' height='7'%3E%3Cpath d='M1.5 1.5l4.5 4.5 4.5-4.5' stroke='%23e8a44a' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
      margin-inline-start: auto;
      transition: rotate var(--duration-fast);
    }
    select:not([data-bn]):open::picker-icon {
      rotate: 180deg;
    }

    select:not([data-bn])::picker(select) {
      background: var(--popover-bg);
      border: var(--border-width) solid var(--popover-border);
      border-radius: var(--popover-radius);
      box-shadow: var(--popover-shadow);
      padding: var(--space-xs);
      transition:
        opacity var(--duration-fast),
        scale var(--duration-fast);
      transition-behavior: allow-discrete;
      opacity: 1;
      scale: 1;
    }

    @starting-style {
      select:not([data-bn])::picker(select) {
        opacity: 0;
        scale: 0.96;
      }
    }

    select:not([data-bn]) option {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-base);
      padding: var(--space-sm) var(--space-md);
      border-radius: var(--radius-sm);
      color: var(--text-0);
      transition: background var(--duration-fast);
    }
    select:not([data-bn]) option:hover {
      background: var(--select-option-hover);
    }
    select:not([data-bn]) option:checked {
      color: var(--accent);
      font-weight: var(--font-weight-semibold);
    }

    select:not([data-bn]) option::checkmark {
      color: var(--accent);
      margin-inline-end: var(--space-sm);
    }

    select:not([data-bn]) optgroup {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      text-transform: uppercase;
      letter-spacing: var(--letter-spacing-wider);
      padding: var(--space-sm) var(--space-md);
    }
  }

  /* -- Progress -- */
  progress:not([data-bn]) {
    appearance: none;
    inline-size: 100%;
    block-size: var(--track-height);
    border: none;
    border-radius: var(--radius-pill);
    overflow: hidden;
    background: var(--track-bg);
  }
  progress:not([data-bn])::-webkit-progress-bar {
    background: var(--track-bg);
    border-radius: var(--radius-pill);
  }
  progress:not([data-bn])::-webkit-progress-value {
    background: var(--track-fill);
    border-radius: var(--radius-pill);
    transition: inline-size var(--duration-med);
  }
  progress:not([data-bn])::-moz-progress-bar {
    background: var(--track-fill);
    border-radius: var(--radius-pill);
  }

  /* -- Meter -- */
  meter {
    appearance: none;
    inline-size: 100%;
    block-size: var(--track-height);
    border: none;
    border-radius: var(--radius-pill);
    overflow: hidden;
    background: var(--track-bg);
  }
  meter::-webkit-meter-bar {
    background: var(--track-bg);
    border-radius: var(--radius-pill);
    border: none;
    block-size: var(--track-height);
  }
  meter::-webkit-meter-optimum-value {
    background: var(--meter-high);
    border-radius: var(--radius-pill);
  }
  meter::-webkit-meter-suboptimum-value {
    background: var(--meter-mid);
    border-radius: var(--radius-pill);
  }
  meter::-webkit-meter-even-less-good-value {
    background: var(--meter-low);
    border-radius: var(--radius-pill);
  }

  /* -- Controls nav -- */
  nav[data-controls] {
    display: flex;
    gap: var(--space-sm);
    flex-wrap: wrap;
    margin-block-start: var(--space-md);
  }

  /* -- Output -- */
  output {
    display: block;
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
    color: var(--text-1);
    margin-block-end: var(--space-md);
  }

  /* Inline output inside labels */
  abbr output {
    display: inline;
    margin: 0;
    font-size: inherit;
    color: inherit;
  }

  /* -- Code blocks -- */
  pre,
  code {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
  }
  pre {
    font-size: var(--font-size-sm);
    line-height: var(--line-height-code);
    color: var(--text-1);
    background: var(--surface-0);
    border: var(--border-width) solid var(--border);
    border-inline-start: var(--border-code-width) solid var(--accent-dim);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    overflow-x: auto;
    margin-block-start: var(--space-sm);
  }

  /* Syntax highlighting */
  .kw {
    color: var(--syntax-keyword);
  }
  .str {
    color: var(--syntax-string);
  }
  .fn {
    color: var(--syntax-function);
  }
  .num {
    color: var(--syntax-number);
  }
  .cmt {
    color: var(--syntax-comment);
    font-style: italic;
  }
  .tag {
    color: var(--syntax-tag);
  }
  .attr {
    color: var(--syntax-attr);
  }

  /* -- Labels -- */
  label:not([data-bn]) {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
  }

  label abbr {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    color: var(--text-2);
    text-decoration: none;
    letter-spacing: var(--letter-spacing-wide);
  }

  /* -- Playground specifics -- */
  [data-counter-output] {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--counter-output-size);
    display: block;
    text-align: center;
    padding: var(--space-md);
  }

  [data-effect-log] {
    margin-block-start: var(--space-md);
    border-block-start: var(--border-width) solid var(--border);
    padding-block-start: var(--space-md);
  }

  [data-effect-log] header {
    margin-block-end: var(--space-sm);
  }

  [data-effect-log] ul {
    max-block-size: var(--log-max-height);
    overflow-y: auto;
  }

  [data-effect-log] li {
    opacity: var(--log-entry-opacity);
    font-size: var(--font-size-xs);
  }

  [data-effect-log] li:first-child {
    opacity: 1;
    color: var(--accent);
  }

  [data-greeting-output] {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-xl);
  }

  [data-temp-output] {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-lg);
    color: var(--accent);
  }

  /* -- Playground controls -- */
  [data-playground] nav[data-controls] {
    margin-block-end: var(--space-md);
  }

  /* -- Fieldset / Legend -- */
  fieldset {
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    margin-block-end: var(--space-md);
  }

  legend {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    color: var(--accent);
    letter-spacing: var(--letter-spacing-wider);
    text-transform: uppercase;
    padding-inline: var(--space-sm);
  }

  fieldset > label + label {
    margin-block-start: var(--space-md);
  }

  /* -- Inline label (for checkbox/radio rows) -- */
  label:not([data-bn]):has(input[type='checkbox']),
  label:not([data-bn]):has(input[type='radio']) {
    flex-direction: row;
    align-items: center;
    gap: var(--space-sm);
    cursor: pointer;
    font-size: var(--font-size-base);
    color: var(--text-1);
  }

  /* -- Table (express pages only, not data-bn components) -- */
  table:not([data-bn]) {
    inline-size: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-base);
  }

  table:not([data-bn]) thead {
    position: sticky;
    inset-block-start: 0;
    z-index: 1;
  }

  table:not([data-bn]) th {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--text-2);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    text-align: start;
    padding: var(--space-sm) var(--space-md);
    background: var(--table-header-bg);
    border-block-end: var(--border-width) solid var(--border-accent);
  }

  table:not([data-bn]) td {
    padding: var(--space-sm) var(--space-md);
    border-block-end: var(--border-width) solid var(--border);
    color: var(--text-1);
  }

  table:not([data-bn]) tbody tr:nth-child(even) {
    background: var(--table-stripe);
  }
  table:not([data-bn]) tbody tr {
    transition: background var(--duration-fast);
  }
  table:not([data-bn]) tbody tr:hover {
    background: var(--surface-2);
  }

  /* -- Blockquote -- */
  blockquote {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-lg);
    font-style: italic;
    color: var(--text-1);
    border-inline-start: var(--border-code-width) solid var(--blockquote-border);
    padding-inline-start: var(--space-lg);
    padding-block: var(--space-sm);
    margin-block: var(--space-md);
  }

  blockquote footer {
    font-stretch: var(--font-mono);
    font-style: normal;
    font-size: var(--font-size-sm);
    color: var(--text-2);
    margin-block-start: var(--space-sm);
    border: none;
    padding: 0;
    text-align: start;
  }

  /* -- Kbd -- */
  kbd {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: 0.85em;
    padding: 0.1em 0.4em;
    background: var(--kbd-bg);
    border: var(--border-width) solid var(--kbd-border);
    border-radius: var(--radius-sm);
    box-shadow: var(--kbd-shadow);
    color: var(--text-0);
    white-space: nowrap;
  }

  /* -- Mark -- */
  mark {
    background: var(--mark-bg);
    color: var(--mark-text);
    padding-inline: 0.2em;
    border-radius: 0.15em;
  }

  /* -- Abbr -- */
  abbr[title] {
    text-decoration: underline dotted var(--text-2);
    text-underline-offset: 0.2em;
    cursor: help;
  }

  /* -- Details / Summary -- */
  details:not([data-bn]) {
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    margin-block-end: var(--space-sm);
    interpolate-size: allow-keywords;
  }

  details:not([data-bn]) > summary {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--text-0);
    padding: var(--space-sm) var(--space-md);
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    transition:
      background var(--duration-fast),
      color var(--duration-fast);
    border-radius: var(--radius-md);
  }
  details:not([data-bn]) > summary:hover {
    background: var(--surface-2);
    color: var(--accent);
  }
  details:not([data-bn]) > summary::-webkit-details-marker {
    display: none;
  }

  details:not([data-bn]) > summary::before {
    content: '▸';
    color: var(--details-marker);
    font-size: 0.85em;
    transition: rotate var(--duration-fast);
  }
  details:not([data-bn])[open] > summary::before {
    rotate: 90deg;
  }
  details:not([data-bn])[open] > summary {
    margin-block-end: 0;
  }

  details:not([data-bn]) > :not(summary) {
    padding: var(--space-sm) var(--space-md) var(--space-md);
    color: var(--text-1);
    font-size: var(--font-size-base);
  }

  /* -- Dialog -- */
  dialog:not([data-bn]) {
    margin: auto;
    background: var(--dialog-bg);
    color: var(--text-0);
    border: var(--border-width) solid var(--dialog-border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    max-inline-size: min(90vi, 28rem);
    box-shadow: var(--dialog-shadow);
    transition:
      opacity var(--duration-med),
      scale var(--duration-med),
      overlay var(--duration-med),
      display var(--duration-med);
    transition-behavior: allow-discrete;
  }

  dialog:not([data-bn])::backdrop {
    background: var(--dialog-backdrop);
    transition:
      opacity var(--duration-med),
      overlay var(--duration-med),
      display var(--duration-med);
    transition-behavior: allow-discrete;
  }

  dialog:not([data-bn])[open] {
    opacity: 1;
    scale: 1;
  }

  @starting-style {
    dialog:not([data-bn])[open] {
      opacity: 0;
      scale: 0.95;
    }
    dialog:not([data-bn])[open]::backdrop {
      opacity: 0;
    }
  }

  dialog:not([data-bn]) > header {
    margin-block-end: var(--space-md);
    padding-block-end: var(--space-md);
    border-block-end: var(--border-width) solid var(--border);
  }

  dialog:not([data-bn]) > header h3 {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-normal);
  }

  dialog:not([data-bn]) > footer {
    margin-block-start: var(--space-lg);
    display: flex;
    justify-content: flex-end;
    gap: var(--space-sm);
    border: none;
    padding: 0;
    text-align: start;
  }

  /* -- Popover -- */
  [popover]:not([data-bn]) {
    margin: 0;
    padding: var(--space-md);
    background: var(--popover-bg);
    color: var(--text-0);
    border: var(--border-width) solid var(--popover-border);
    border-radius: var(--popover-radius);
    box-shadow: var(--popover-shadow);
    inset: unset;
    transition:
      opacity var(--duration-fast),
      scale var(--duration-fast),
      overlay var(--duration-fast),
      display var(--duration-fast);
    transition-behavior: allow-discrete;
    opacity: 1;
    scale: 1;
  }

  [popover]:not([data-bn])::backdrop {
    background: transparent;
  }

  @starting-style {
    [popover]:not([data-bn]):popover-open {
      opacity: 0;
      scale: 0.96;
    }
  }

  /* Tooltip variant */
  output[popover] {
    display: none;
    padding: var(--space-xs) var(--space-sm);
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--tooltip-font-size);
    background: var(--tooltip-bg);
    color: var(--tooltip-text);
    border-radius: var(--radius-sm);
    box-shadow: var(--popover-shadow);
    max-inline-size: 20rem;
    pointer-events: none;
  }
  output[popover]:popover-open {
    display: block;
  }

  /* Dropdown menu variant */
  nav[popover] {
    display: none;
    flex-direction: column;
    gap: 0;
    padding: var(--space-xs);
    min-inline-size: 10rem;
  }
  nav[popover]:popover-open {
    display: flex;
  }

  nav[popover] a,
  nav[popover] button {
    display: block;
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
    padding: var(--space-sm) var(--space-md);
    color: var(--text-1);
    text-decoration: none;
    border-radius: var(--radius-sm);
    border: none;
    background: transparent;
    text-align: start;
    inline-size: 100%;
    cursor: pointer;
    transition:
      background var(--duration-fast),
      color var(--duration-fast);
  }

  nav[popover] a:hover,
  nav[popover] button:hover {
    background: var(--surface-3);
    color: var(--accent);
    box-shadow: none;
  }

  nav[popover] hr {
    border: none;
    border-block-start: var(--border-width) solid var(--border);
    margin-block: var(--space-xs);
  }

  /* Popover card variant */
  article[popover] {
    container-type: normal;
    inline-size: 20rem;
    padding: var(--space-lg);
  }

  /* -- Anchor positioning -- */
  @supports (anchor-name: --x) {
    [popover] {
      position: fixed;
      position-try-fallbacks: flip-block, flip-inline;
    }
  }

  /* -- Datepicker trigger (calendar icon button) -- */
  [data-datepicker-trigger] {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-base);
    color: var(--text-2);
    cursor: pointer;
    transition:
      color var(--duration-fast),
      background var(--duration-fast);
  }
  [data-datepicker-trigger]:hover {
    color: var(--accent);
    background: var(--surface-3);
    box-shadow: none;
  }
  [data-datepicker-trigger] svg {
    display: block;
  }

  /* -- Datepicker popover -- */
  [data-datepicker] {
    padding: var(--space-md);
    min-inline-size: 18rem;
  }

  [data-datepicker-header] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-block-end: var(--space-sm);
    padding: 0;
    border: none;
  }

  [data-datepicker-header] strong {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-normal);
    color: var(--text-0);
  }

  [data-datepicker-prev],
  [data-datepicker-next] {
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--font-size-sm);
    background: transparent;
    border: var(--border-width) solid transparent;
    border-radius: var(--radius-sm);
    color: var(--text-2);
    cursor: pointer;
    transition:
      background var(--duration-fast),
      color var(--duration-fast),
      border-color var(--duration-fast);
  }
  [data-datepicker-prev]:hover,
  [data-datepicker-next]:hover {
    background: var(--surface-3);
    color: var(--accent);
    border-color: var(--accent-dim);
    box-shadow: none;
  }

  [data-datepicker-grid] {
    inline-size: 100%;
    border-collapse: separate;
    border-spacing: 0;
  }

  [data-datepicker-grid] th {
    font-size: var(--font-size-xs);
    padding: var(--space-xs);
    text-align: center;
    color: var(--text-2);
    background: transparent;
    border: none;
  }

  [data-datepicker-grid] td {
    padding: 0;
    text-align: center;
    border: none;
  }

  [data-datepicker-grid] td button {
    inline-size: 2.25rem;
    block-size: 2.25rem;
    padding: 0;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    background: transparent;
    border: var(--border-width) solid transparent;
    color: var(--text-1);
    cursor: pointer;
    transition:
      background var(--duration-fast),
      color var(--duration-fast),
      border-color var(--duration-fast);
  }

  [data-datepicker-grid] td button:hover {
    background: var(--surface-3);
    color: var(--text-0);
    border-color: var(--border);
    box-shadow: none;
  }

  [data-datepicker-grid] td button[data-today] {
    border-color: var(--accent-dim);
    color: var(--accent);
  }

  [data-datepicker-grid] td button[data-selected] {
    background: var(--accent);
    color: var(--surface-0);
    border-color: var(--accent);
    font-weight: var(--font-weight-semibold);
  }

  /* -- Tasks page -- */
  [data-hydrate] > h3 {
    margin-block-end: var(--space-md);
  }
  [data-hydrate] > nav[data-controls] {
    margin-block-end: var(--space-md);
  }
  [data-hydrate] > output {
    margin-block: var(--space-sm) var(--space-md);
  }
  [data-hydrate] > nav[data-controls]:first-of-type {
    align-items: center;
  }
  [data-hydrate] > nav[data-controls]:first-of-type input[type='text'] {
    min-inline-size: min(100%, 15rem);
    flex: 1 1 15rem;
  }

  [data-hydrate] ul[role='list'] {
    gap: var(--space-sm);
  }
  [data-hydrate] ul[role='list'] li {
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-md);
    gap: var(--space-md);
  }
  [data-task-item] {
    align-items: center;
  }
  [data-task-title] {
    min-inline-size: 0;
    flex: 1 1 auto;
  }
  [data-task-actions] {
    margin-inline-start: auto;
    display: inline-flex;
    align-items: center;
    gap: var(--space-md);
    flex: 0 0 auto;
  }
  [data-task-item] button[data-variant='danger'] {
    min-inline-size: 3rem;
    padding-inline: var(--space-sm);
    box-shadow: none;
  }
  [data-task-empty] {
    justify-content: flex-start;
  }

  /* -- Datepicker input group -- */
  [data-datepicker-input] {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--surface-0);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-sm);
    padding-inline-start: var(--space-md);
    transition:
      border-color var(--duration-med),
      box-shadow var(--duration-med);
  }
  [data-datepicker-input]:focus-within {
    border-color: var(--accent);
    box-shadow: var(--shadow-input), var(--shadow-btn);
  }

  [data-datepicker-input] input {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-base);
    background: transparent;
    color: var(--text-0);
    border: none;
    outline: none;
    padding: var(--space-sm) 0;
    text-align: center;
  }
  [data-datepicker-input] input[data-date-month],
  [data-datepicker-input] input[data-date-day] {
    inline-size: 2ch;
  }
  [data-datepicker-input] input[data-date-year] {
    inline-size: 4ch;
  }
  [data-datepicker-input] input::placeholder {
    color: var(--text-2);
  }

  [data-datepicker-input] > span {
    color: var(--text-2);
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-base);
    user-select: none;
  }

  [data-datepicker-input] > button {
    margin-inline-start: auto;
    align-self: stretch;
    border: none;
    border-inline-start: var(--border-width) solid var(--border);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    background: var(--surface-2);
    padding-inline: var(--space-md);
  }

  /* -- Datepicker month/year picker -- */
  [data-datepicker-title-btn] {
    background: transparent;
    border: none;
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-normal);
    color: var(--text-0);
    cursor: pointer;
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-sm);
    transition:
      background var(--duration-fast),
      color var(--duration-fast);
  }
  [data-datepicker-title-btn]:hover {
    background: var(--surface-3);
    color: var(--accent);
    box-shadow: none;
  }

  [data-datepicker-months] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-xs);
    padding-block-start: var(--space-sm);
  }

  [data-datepicker-months] button {
    padding: var(--space-sm);
    font-size: var(--font-size-sm);
    background: transparent;
    border: var(--border-width) solid transparent;
    border-radius: var(--radius-sm);
    color: var(--text-1);
    cursor: pointer;
    transition:
      background var(--duration-fast),
      color var(--duration-fast),
      border-color var(--duration-fast);
  }
  [data-datepicker-months] button:hover {
    background: var(--surface-3);
    color: var(--text-0);
    box-shadow: none;
  }
  [data-datepicker-months] button[data-current] {
    border-color: var(--accent-dim);
    color: var(--accent);
  }

  /* -- Docs page -- */
  [data-code-preview] article + article {
    margin-block-start: var(--space-md);
  }
}

@layer states {
  /* -- Container queries for view encapsulation -- */

  /* Stat grid: adapt columns to container width, not viewport */
  @container stats (max-width: 36rem) {
    ul[role='list'][data-stat-grid] {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @container stats (max-width: 20rem) {
    ul[role='list'][data-stat-grid] {
      grid-template-columns: 1fr;
    }
  }

  /* Cards: compact layout when card is narrow */
  @container card (max-width: 24rem) {
    header {
      flex-direction: column;
      align-items: start;
    }

    pre {
      font-size: var(--font-size-xs);
      padding: var(--space-md);
    }
  }

  /* Page container: responsive layout */
  @container page (max-width: 28rem) {
    [data-hero] {
      padding-block: var(--space-xl);
    }

    [data-hero] nav {
      flex-direction: column;
      align-items: stretch;
    }
  }

  /* List items: stack content when container is narrow */
  @container card (max-width: 20rem) {
    ul[role='list'] li {
      flex-direction: column;
      align-items: start;
      gap: var(--space-xs);
    }
  }

  /* Table: horizontal scroll on narrow containers */
  @container card (max-width: 24rem) {
    table {
      font-size: var(--font-size-sm);
    }
    th,
    td {
      padding: var(--space-xs) var(--space-sm);
    }
  }

  /* Fieldset: tighter spacing on narrow containers */
  @container card (max-width: 20rem) {
    fieldset {
      padding: var(--space-md);
    }
    fieldset > label + label {
      margin-block-start: var(--space-sm);
    }
  }

  /* Datepicker: compact layout on narrow cards */
  @container card (max-width: 20rem) {
    [data-datepicker-input] {
      padding-inline-start: var(--space-sm);
    }

    [data-datepicker-input] input {
      font-size: var(--font-size-sm);
    }

    [data-datepicker-input] > span {
      font-size: var(--font-size-sm);
    }

    [data-datepicker-input] > button {
      padding-inline: var(--space-sm);
    }
  }

  /* Datepicker popover: smaller cells on narrow viewports */
  @media (max-width: 40rem) {
    [data-datepicker] {
      min-inline-size: auto;
      padding: var(--space-sm);
    }

    [data-datepicker-grid] td button {
      inline-size: 2rem;
      block-size: 2rem;
      font-size: var(--font-size-xs);
    }

    [data-datepicker-grid] th {
      font-size: 0.625rem;
      padding: var(--space-xs);
    }

    [data-datepicker-months] {
      gap: var(--space-xs);
    }

    [data-datepicker-months] button {
      padding: var(--space-xs);
      font-size: var(--font-size-xs);
    }

    body > header > nav {
      flex-direction: column;
      gap: var(--space-sm);
    }
  }

  @media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
    }
  }

  /* -- Showcase layout helpers -- */
  [data-showcase-row] {
    display: flex;
    gap: var(--space-md);
    flex-wrap: wrap;
    align-items: center;
  }
  [data-showcase-form] {
    display: grid;
    gap: var(--space-lg);
    max-inline-size: 32rem;
  }
  [data-showcase-stack] {
    display: grid;
    gap: var(--space-sm);
  }
  [data-showcase-card] {
    max-inline-size: 24rem;
  }
  [data-showcase-hero] {
    display: grid;
    gap: var(--space-sm);
    padding-block-end: var(--space-md);
  }
  [data-showcase-toc] {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    padding: var(--space-sm);
    margin-block-start: var(--space-md);
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
  }
  [data-showcase-toc] a {
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-sm);
    color: var(--text-1);
    text-decoration: none;
    font-size: 0.875rem;
  }
  [data-showcase-toc] a:hover {
    background: var(--surface-2);
    color: var(--text-0);
  }
  [data-showcase-toc] a:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
  }

  [data-showcase-counter] {
    display: inline-flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    font-variant-numeric: tabular-nums;
  }
  [data-showcase-counter] [data-bn-counter-value] {
    font-size: 1.75rem;
    font-weight: 600;
    min-inline-size: 3ch;
    text-align: center;
    color: var(--accent);
  }
  [data-showcase-counter] [data-bn-counter-doubled],
  [data-showcase-counter] [data-bn-counter-parity] {
    color: var(--text-1);
    font-size: 0.875rem;
  }
  [data-showcase-counter] [data-bn-counter-parity][data-parity='odd'] {
    color: var(--info);
  }
  [data-showcase-counter] [data-bn-counter-parity][data-parity='even'] {
    color: var(--success);
  }

  [data-bn-clock] {
    display: inline-block;
    padding: var(--space-sm) var(--space-md);
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    font-variant-numeric: tabular-nums;
    font-size: 1.25rem;
    color: var(--accent);
  }

  [data-showcase-package-grid] {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--space-xl);
  }
  [data-bn-package-group] {
    display: grid;
    gap: var(--space-md);
  }
  [data-bn-package-group] > h3 {
    margin: 0;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-2);
  }
  [data-bn-package-list] {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--space-md);
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
  }
  [data-bn-package-card] {
    display: grid;
    gap: var(--space-xs);
    padding: var(--space-md);
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    transition:
      border-color var(--duration-fast) var(--ease-out-expo),
      box-shadow var(--duration-fast) var(--ease-out-expo);
  }
  [data-bn-package-card]:hover {
    border-color: var(--border-accent);
    box-shadow: 0 0 0 1px var(--accent-glow);
  }
  [data-bn-package-card] code {
    font-size: 0.85rem;
    color: var(--accent);
    font-weight: 500;
    background: transparent;
    padding: 0;
  }
  [data-bn-package-card] p {
    margin: 0;
    color: var(--text-1);
    font-size: 0.875rem;
  }

  [data-bn='virtualizer'] {
    background: var(--surface-1);
  }
  [data-bn='virtual-item'] {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding-inline: var(--space-md);
    color: var(--text-0);
  }
  [data-bn='virtual-item']::before {
    content: attr(data-index);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    inline-size: 2.5rem;
    block-size: 1.25rem;
    background: var(--surface-3);
    color: var(--text-2);
    border-radius: var(--radius-pill);
    font-size: 0.75rem;
    font-variant-numeric: tabular-nums;
  }

  /* Tooltip popover positioning */
  [data-bn='tooltip'][popover] {
    background: var(--surface-3);
    color: var(--text-0);
    border: 1px solid var(--border-accent);
    box-shadow: 0 8px 24px rgb(0 0 0 / 0.4);
  }

  /* Toast container surfaces */
  [data-bn='toast-container'] [data-bn='toast'] {
    background: var(--surface-2);
    color: var(--text-0);
    border-color: var(--border-accent);
    box-shadow: 0 8px 24px rgb(0 0 0 / 0.45);
    animation: bn-toast-in 0.25s var(--ease-out-back);
  }
  @keyframes bn-toast-in {
    from {
      opacity: 0;
      transform: translateY(-8px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  /* -- New showcase + components page primitives (data-bn-*) -- */
  [data-bn-visually-hidden] {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
  }

  [data-bn-skip-link] {
    position: absolute;
    inset-inline-start: -9999px;
    inset-block-start: -9999px;
    z-index: 10000;
    padding: 0.75rem 1rem;
    background: var(--accent);
    color: var(--surface-0);
    font-weight: var(--font-weight-semibold);
    text-decoration: none;
    border-radius: 0 0 var(--radius-sm) 0;
  }
  [data-bn-skip-link]:focus {
    inset-inline-start: 0;
    inset-block-start: 0;
  }

  /* Site header / nav */
  body > [data-bn-site-header] menu {
    list-style: none;
    display: flex;
    gap: var(--space-md);
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    min-inline-size: 0;
    margin: 0;
    padding: 0;
  }
  body > [data-bn-site-header] menu::-webkit-scrollbar {
    display: none;
  }
  body > [data-bn-site-header] menu li {
    scroll-snap-align: start;
    flex: 0 0 auto;
    list-style: none;
  }

  body > [data-bn-site-header] [data-bn-wordmark] {
    color: inherit;
    text-decoration: none;
  }

  /* Site footer */
  body > [data-bn-site-footer] {
    display: grid;
    gap: var(--space-sm);
    padding: var(--space-lg);
  }
  body > [data-bn-site-footer] nav {
    display: flex;
    gap: var(--space-md);
    justify-content: center;
    flex-wrap: wrap;
  }
  body > [data-bn-site-footer] nav a {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    color: var(--text-2);
    text-decoration: none;
    transition: color var(--duration-fast);
  }
  body > [data-bn-site-footer] nav a:hover {
    color: var(--accent);
  }

  /* ==========================================================================
   * Components index (/components) + Showcase (/showcase) + per-component pages.
   * Uses native CSS nesting, :has(), and container queries. No classes.
   * ========================================================================== */

  /* -- Hero shared by /components and /showcase -- */
  [data-bn-page-hero],
  [data-bn-showcase-header] {
    margin-block-end: var(--space-2xl);

    & h2 {
      font-family: var(--font-family);
      font-stretch: var(--font-serif);
      font-size: var(--font-size-hero);
      font-weight: var(--font-weight-normal);
      letter-spacing: var(--letter-spacing-tight);
      margin-block-end: var(--space-md);

      & em {
        font-style: normal;
        color: var(--accent);
      }
    }
  }

  [data-bn-eyebrow] {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    color: var(--accent);
    letter-spacing: var(--letter-spacing-wider);
    text-transform: uppercase;
    margin-block-end: var(--space-sm);
  }

  [data-bn-lede] {
    font-size: var(--font-size-lg);
    color: var(--text-1);
    max-inline-size: var(--size-text-max);
    margin-block-end: var(--space-lg);

    & code {
      font-size: 0.95em;
      color: var(--accent);
      background: var(--surface-2);
      padding: 0.1em 0.4em;
      border-radius: var(--radius-sm);
    }
  }

  [data-bn-page-hero-actions],
  [data-bn-showcase-actions] {
    display: flex;
    gap: var(--space-sm);
    flex-wrap: wrap;
  }

  [data-bn-cta] {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-lg);
    min-block-size: 2.75rem;
    border-radius: var(--radius-sm);
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
    text-decoration: none;
    border: var(--border-width) solid transparent;
    transition:
      background var(--duration-fast),
      border-color var(--duration-fast),
      color var(--duration-fast),
      box-shadow var(--duration-med);

    &[data-bn-cta='primary'] {
      background: var(--accent);
      color: var(--surface-0);
      border-color: var(--accent);

      &:hover {
        background: var(--accent-dim);
        box-shadow: var(--shadow-btn);
      }
    }

    &[data-bn-cta='secondary'] {
      background: transparent;
      color: var(--text-1);
      border-color: var(--border-accent);

      &:hover {
        background: var(--surface-2);
        color: var(--accent);
        border-color: var(--accent);
      }
    }
  }

  /* -- /components category TOC -- */
  [data-bn-component-toc] {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    padding: var(--space-md);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    margin-block-end: var(--space-2xl);
    position: sticky;
    inset-block-start: var(--space-sm);
    z-index: 5;
    backdrop-filter: blur(8px);
    background: color-mix(in srgb, var(--surface-1) 92%, transparent);

    & a {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      text-decoration: none;
      padding: var(--space-xs) var(--space-sm);
      border-radius: var(--radius-sm);
      transition:
        background var(--duration-fast),
        color var(--duration-fast);

      &:hover {
        background: var(--surface-3);
        color: var(--accent);
      }
    }
  }

  /* -- /components category section -- */
  [data-bn-component-category] {
    margin-block-end: var(--space-3xl);
    scroll-margin-block-start: var(--space-2xl);
  }

  [data-bn-component-category-head] {
    display: block;
    margin-block-end: var(--space-lg);
    border: none;
    padding: 0;
    background: none;

    & h2 {
      font-family: var(--font-family);
      font-stretch: var(--font-serif);
      font-size: var(--font-size-2xl);
      font-weight: var(--font-weight-normal);
      margin-block-end: var(--space-xs);
    }

    & p {
      color: var(--text-2);
      font-size: var(--font-size-base);
      max-inline-size: var(--size-text-max);
    }
  }

  /* -- Component grid -- */
  [data-bn-component-grid] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
    gap: var(--space-md);
    list-style: none;
    padding: 0;
    margin: 0;

    & > li {
      display: flex;
      background: none;
      border: none;
      padding: 0;
    }
  }

  [data-bn-component-card] {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    inline-size: 100%;
    padding: var(--space-lg);
    background: var(--surface-1);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    text-decoration: none;
    color: inherit;
    transition:
      border-color var(--duration-med),
      background var(--duration-med),
      transform var(--duration-med);
    container-type: inline-size;

    &:hover {
      border-color: var(--accent-dim);
      background: var(--surface-2);
      transform: translateY(-2px);
    }

    &:focus-visible {
      outline: var(--border-inline-width) solid var(--accent);
      outline-offset: var(--border-inline-width);
    }

    & > header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: var(--space-sm);
      margin: 0;
      padding: 0;
      background: none;
      border: none;

      & h3 {
        font-family: var(--font-family);
        font-stretch: var(--font-serif);
        font-size: var(--font-size-lg);
        font-weight: var(--font-weight-normal);
        color: var(--text-0);
        letter-spacing: var(--letter-spacing-tight);
      }
    }

    & > p {
      flex: 1;
      color: var(--text-1);
      font-size: var(--font-size-sm);
      line-height: var(--line-height-tight);
      margin: 0;
    }

    & > footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: var(--space-sm);
      color: var(--accent);
      font-size: var(--font-size-md);
      margin: 0;
      padding: 0;
      border: none;
      background: none;

      & [data-bn-component-fn] {
        color: var(--text-2);
        font-size: var(--font-size-xs);
      }
    }

    &:hover > footer {
      color: var(--text-0);
    }
  }

  [data-bn-component-tag] {
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    color: var(--accent);
    background: color-mix(in srgb, var(--accent) 12%, transparent);
    padding: 0.15rem 0.45rem;
    border-radius: var(--radius-sm);
    white-space: nowrap;
  }

  /* -- Axioms list on /components -- */
  [data-bn-component-philosophy] {
    margin-block-start: var(--space-3xl);
    padding-block: var(--space-2xl);
    border-block-start: var(--border-width) solid var(--border);

    & > h2 em {
      font-style: normal;
      color: var(--accent);
    }
  }

  [data-bn-axioms] {
    counter-reset: axiom;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
    gap: var(--space-lg);
    padding: 0;
    margin-block-start: var(--space-lg);

    & > li {
      counter-increment: axiom;
      background: var(--surface-1);
      border: var(--border-width) solid var(--border);
      border-radius: var(--radius-md);
      padding: var(--space-lg);
      position: relative;

      &::before {
        content: counter(axiom, decimal-leading-zero);
        font-family: var(--font-family);
        font-stretch: var(--font-mono);
        font-size: var(--font-size-xs);
        color: var(--accent);
        letter-spacing: var(--letter-spacing-wider);
        margin-block-end: var(--space-sm);
        display: block;
      }

      & h3 {
        font-family: var(--font-family);
        font-stretch: var(--font-serif);
        font-size: var(--font-size-lg);
        font-weight: var(--font-weight-normal);
        color: var(--text-0);
        margin-block-end: var(--space-xs);
      }

      & p {
        color: var(--text-1);
        font-size: var(--font-size-sm);
        line-height: var(--line-height-tight);
      }
    }

    & code {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: 0.95em;
      color: var(--accent);
      background: var(--surface-2);
      padding: 0.1em 0.35em;
      border-radius: var(--radius-sm);
    }
  }

  /* -- Per-component page (/components/:slug) -- */
  [data-bn-component-page] {
    background: none;
    border: none;
    padding: 0;
    container: page-component / inline-size;

    &:hover {
      border-color: transparent;
      box-shadow: none;
    }
  }

  [data-bn-component-hero] {
    display: block;
    margin-block: var(--space-xl) var(--space-2xl);
    background: none;
    border: none;
    padding: 0;

    & h2 {
      font-family: var(--font-family);
      font-stretch: var(--font-serif);
      font-size: var(--font-size-hero);
      font-weight: var(--font-weight-normal);
      margin-block-end: var(--space-sm);
      letter-spacing: var(--letter-spacing-tight);
    }
  }

  [data-bn-component-meta] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
    gap: var(--space-md);
    margin-block-start: var(--space-lg);
    padding-block: var(--space-md);
    border-block: var(--border-width) solid var(--border);

    & > div {
      display: flex;
      flex-direction: column;
      gap: var(--space-xs);
    }

    & dt {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      text-transform: uppercase;
      letter-spacing: var(--letter-spacing-wider);
    }

    & dd {
      margin: 0;
    }

    & code {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-sm);
      color: var(--accent);
    }
  }

  /* Section heading style shared across the component-page sections. */
  [data-bn-component-quickstart] > header,
  [data-bn-component-examples] > header,
  [data-bn-component-api] > header {
    display: block;
    background: none;
    border: none;
    padding: 0;
    margin-block-end: var(--space-md);

    & > h3 {
      font-family: var(--font-family);
      font-stretch: var(--font-serif);
      font-size: var(--font-size-2xl);
      font-weight: var(--font-weight-normal);
      letter-spacing: var(--letter-spacing-tight);
      margin-block-end: var(--space-xs);
    }

    & > p {
      color: var(--text-1);
      font-size: var(--font-size-base);
      max-inline-size: var(--size-text-max);
      margin: 0;
    }
  }

  [data-bn-component-quickstart],
  [data-bn-component-examples],
  [data-bn-component-api] {
    margin-block-end: var(--space-2xl);
  }

  [data-bn-component-quickstart] > pre {
    margin: 0;
  }

  /* Per example block. */
  [data-bn-component-example] {
    margin-block-end: var(--space-2xl);
    padding-block-end: var(--space-xl);
    border-block-end: var(--border-width) solid var(--border);

    &:last-of-type {
      border-block-end: none;
      padding-block-end: 0;
    }

    & > header {
      display: block;
      margin-block-end: var(--space-md);
      background: none;
      border: none;
      padding: 0;

      & > h4 {
        font-family: var(--font-family);
        font-stretch: var(--font-serif);
        font-size: var(--font-size-xl);
        font-weight: var(--font-weight-normal);
        color: var(--text-0);
        letter-spacing: var(--letter-spacing-tight);
        margin-block-end: var(--space-xs);
      }

      & > p {
        color: var(--text-1);
        font-size: var(--font-size-base);
        max-inline-size: var(--size-text-max);
        margin: 0;
      }
    }
  }

  /* Side-by-side preview + source. Stacks on narrow containers. */
  [data-bn-component-split] {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);

    @container page-component (min-width: 48rem) {
      & {
        grid-template-columns: 1fr 1fr;
      }
    }
  }

  /* Live render figure. */
  [data-bn-component-preview],
  [data-bn-component-source] {
    margin: 0;
    padding: 0;
    background: var(--surface-1);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    overflow: hidden;
    display: flex;
    flex-direction: column;

    & > figcaption {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      text-transform: uppercase;
      letter-spacing: var(--letter-spacing-wider);
      padding: var(--space-sm) var(--space-md);
      background: var(--surface-2);
      border-block-end: var(--border-width) solid var(--border);
    }
  }

  [data-bn-component-preview] {
    & > output {
      display: flex;
      flex-wrap: wrap;
      gap: var(--space-md);
      align-items: center;
      padding: var(--space-xl);
      flex: 1;
      background-color: var(--surface-inset);
      background-image:
        linear-gradient(45deg, var(--surface-1) 25%, transparent 25%),
        linear-gradient(-45deg, var(--surface-1) 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, var(--surface-1) 75%),
        linear-gradient(-45deg, transparent 75%, var(--surface-1) 75%);
      background-size: 24px 24px;
      background-position:
        0 0,
        0 12px,
        12px -12px,
        12px 0;
      min-block-size: 8rem;

      /* When the preview contains a form-style demo, drop the row layout
         so labels and fields stack vertically. */
      &:has([data-bn='field']),
      &:has([data-bn='fieldset']),
      &:has(textarea) {
        flex-direction: column;
        align-items: stretch;
        gap: var(--space-md);
      }
    }
  }

  [data-bn-component-source] {
    & > pre {
      margin: 0;
      padding: var(--space-md);
      background: var(--surface-inset);
      border: none;
      border-radius: 0;
      flex: 1;
      font-size: var(--font-size-xs);
      line-height: var(--line-height-code);
      overflow-x: auto;
      max-block-size: 22rem;
    }
  }

  /* API options table. */
  [data-bn-component-api] {
    & > table {
      inline-size: 100%;
      border-collapse: collapse;
      background: var(--surface-1);
      border: var(--border-width) solid var(--border);
      border-radius: var(--radius-md);
      overflow: hidden;
      font-size: var(--font-size-sm);
    }

    & thead {
      background: var(--surface-2);
    }

    & th,
    & td {
      text-align: start;
      padding: var(--space-sm) var(--space-md);
      border-block-end: var(--border-width) solid var(--border);
      vertical-align: top;
    }

    & thead th {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      text-transform: uppercase;
      letter-spacing: var(--letter-spacing-wider);
      font-weight: var(--font-weight-normal);
    }

    & tbody tr:last-child > * {
      border-block-end: none;
    }

    & tbody th[scope='row'] {
      color: var(--accent);
      font-weight: var(--font-weight-normal);
    }

    & code {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-1);
    }

    & tbody th[scope='row'] code {
      color: var(--accent);
    }
  }

  /* Pager between sibling component pages. */
  [data-bn-component-pager] {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: var(--space-md);
    padding-block: var(--space-xl);
    margin-block-start: var(--space-xl);
    border-block-start: var(--border-width) solid var(--border);

    & a {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-sm);
      color: var(--text-1);
      text-decoration: none;
      padding: var(--space-sm) var(--space-md);
      border-radius: var(--radius-sm);
      transition:
        background var(--duration-fast),
        color var(--duration-fast);

      &:hover {
        color: var(--accent);
        background: var(--surface-2);
      }

      &[rel='prev'] {
        justify-self: start;
      }

      &[rel='next'] {
        justify-self: end;
      }
    }

    & [data-bn-component-pager-index] {
      color: var(--text-2);
      justify-self: center;
    }
  }

  /* -- Demo-page interactive helpers -- */
  [data-bn-demo-row] {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    align-items: center;
  }

  [data-bn-demo-counter] {
    display: block;
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-2xl);
    color: var(--accent);
    margin-block-end: var(--space-sm);
  }

  [data-bn-demo-bio-count],
  [data-bn-demo-words],
  [data-bn-demo-region-out],
  [data-bn-demo-tier-out],
  [data-bn-demo-progress-out],
  [data-bn-demo-pager-out] {
    display: block;
    margin-block-start: var(--space-sm);
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    color: var(--text-2);
  }

  /* Generic styled "live readout" block used by reactive demos. */
  [data-demo-display] {
    margin-block-start: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    background: var(--surface-2);
    border: var(--border-width) dashed var(--border-accent);
    border-radius: var(--radius-sm);
    color: var(--text-1);
    font-size: var(--font-size-sm);
    line-height: var(--line-height-tight);

    & strong {
      display: block;
      color: var(--text-0);
      margin-block-end: var(--space-xs);
    }

    & p {
      margin: 0;
    }
  }

  /* Theme card flips its surface based on the toggle's data attribute. */
  [data-bn-demo-theme-card] {
    transition:
      background var(--duration-med),
      color var(--duration-med),
      border-color var(--duration-med);

    &[data-dim='on'] {
      background: var(--surface-0);
      color: var(--text-2);
      border-color: var(--accent-dim);
    }
  }

  /* Stack of dismissible alerts */
  [data-bn-demo-alert-stack] {
    margin-block-start: var(--space-md);
    display: grid;
    gap: var(--space-sm);
  }

  [data-bn-demo-alert-stack]:empty {
    display: none;
  }

  /* -- Showcase page (/showcase) layout -- */
  [data-bn-showcase] {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
    background: none;
    border: none;
    padding: 0;
    container-type: normal;

    &:hover {
      border-color: transparent;
      box-shadow: none;
    }
  }

  [data-bn-showcase-toc] {
    background: var(--surface-1);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-md) var(--space-lg);
    position: sticky;
    inset-block-start: var(--space-sm);
    z-index: 5;
    backdrop-filter: blur(8px);
    background: color-mix(in srgb, var(--surface-1) 92%, transparent);

    & h3 {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      text-transform: uppercase;
      letter-spacing: var(--letter-spacing-wider);
      margin-block-end: var(--space-sm);
    }

    & ol {
      list-style: none;
      margin: 0;
      padding: 0;
      display: flex;
      flex-wrap: wrap;
      gap: var(--space-xs);
    }

    & ol li {
      background: none;
      border: none;
      padding: 0;
    }

    & a {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-1);
      text-decoration: none;
      padding: var(--space-xs) var(--space-sm);
      border-radius: var(--radius-sm);
      transition:
        background var(--duration-fast),
        color var(--duration-fast);

      &:hover {
        background: var(--surface-3);
        color: var(--accent);
      }

      &[aria-current='true'] {
        background: color-mix(in srgb, var(--accent) 15%, transparent);
        color: var(--accent);
      }
    }
  }

  [data-bn-showcase-section] {
    scroll-margin-block-start: 6rem;
    margin: 0;
    padding-block: var(--space-xl);
    border-block-start: var(--border-width) solid var(--border);
    background: none;

    &:first-of-type {
      border-block-start: none;
      padding-block-start: 0;
    }

    & > header {
      margin: 0 0 var(--space-lg) 0;
      padding: 0;
      background: none;
      border: none;
      display: block;

      & h2 {
        font-family: var(--font-family);
        font-stretch: var(--font-serif);
        font-size: var(--font-size-2xl);
        font-weight: var(--font-weight-normal);
        letter-spacing: var(--letter-spacing-tight);
        margin-block-end: var(--space-xs);
      }

      & p {
        color: var(--text-1);
        font-size: var(--font-size-base);
        max-inline-size: var(--size-text-max);
        margin: 0;
      }

      & code {
        color: var(--accent);
        font-family: var(--font-family);
        font-stretch: var(--font-mono);
      }
    }
  }

  [data-bn-showcase-demo] {
    margin: 0 0 var(--space-md) 0;
    padding: 0;
    background: var(--surface-1);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    overflow: hidden;

    & figcaption {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      text-transform: uppercase;
      letter-spacing: var(--letter-spacing-wider);
      padding: var(--space-sm) var(--space-md);
      background: var(--surface-2);
      border-block-end: var(--border-width) solid var(--border);
    }

    & > output {
      display: block;
      padding: var(--space-xl);
      background: var(--surface-inset);
    }
  }

  [data-bn-showcase-row] {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
    align-items: center;
  }

  [data-bn-showcase-form] {
    display: grid;
    gap: var(--space-lg);
    max-inline-size: 32rem;
  }

  [data-bn-showcase-stack] {
    display: grid;
    gap: var(--space-sm);
  }

  [data-bn-showcase-card] {
    max-inline-size: 24rem;
  }

  /* Two-column showcase layout once there is room for a sidebar. */
  @container page (min-width: 56rem) {
    [data-bn-showcase] {
      grid-template-columns: 14rem 1fr;
      align-items: start;
    }

    [data-bn-showcase-toc] {
      position: sticky;
      inset-block-start: var(--space-md);
      align-self: start;

      & ol {
        flex-direction: column;
        gap: var(--space-xs);
      }
    }
  }
  /* -- Component overrides for express theme -- */
  [data-bn='button'] {
    min-block-size: 2.75rem;
  }
  [data-bn='spinner'] > span {
    border-width: 3px;
  }
  [data-bn='progress'] {
    block-size: var(--track-height, 0.375rem);
  }
  [data-bn='progress']::-webkit-progress-bar {
    background: var(--track-bg, var(--surface-2));
  }
  [data-bn='progress']::-webkit-progress-value {
    background: var(--accent);
  }
  [data-bn='progress']::-moz-progress-bar {
    background: var(--accent);
  }

  /* -- Overlay overrides (showcase + per-component pages) -- */

  /* Dialog: native showModal() requires margin: auto + inset: 0 to center */
  dialog[data-bn='dialog'] {
    margin: auto;
    inset: 0;
    inline-size: 28rem;
    max-inline-size: calc(100% - 2rem);
    block-size: max-content;
    max-block-size: calc(100% - 2rem);
    background: var(--surface-1);
    color: var(--text-0);
    border: var(--border-width) solid var(--border-accent);
    border-radius: var(--radius-lg);
    padding: 0;
    box-shadow: var(--dialog-shadow);
  }
  dialog[data-bn='dialog']::backdrop {
    background: var(--dialog-backdrop, rgb(0 0 0 / 0.55));
    backdrop-filter: blur(4px);
  }
  dialog[data-bn='dialog'][data-size='lg'] {
    inline-size: 40rem;
  }
  dialog[data-bn='dialog'] [data-bn='dialog-header'] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding: var(--space-lg);
    border-block-end: var(--border-width) solid var(--border);
  }
  dialog[data-bn='dialog'] [data-bn='dialog-title'] {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-normal);
    color: var(--text-0);
  }
  dialog[data-bn='dialog'] [data-bn='dialog-close'] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    inline-size: 2rem;
    block-size: 2rem;
    border: none;
    background: transparent;
    border-radius: var(--radius-sm);
    color: var(--text-2);
    font-size: var(--font-size-xl);
    cursor: pointer;
    line-height: 1;
  }
  dialog[data-bn='dialog'] [data-bn='dialog-close']:hover {
    background: var(--surface-3);
    color: var(--accent);
  }
  dialog[data-bn='dialog'] [data-bn='dialog-body'] {
    padding: var(--space-lg);
    color: var(--text-1);
  }
  dialog[data-bn='dialog'] [data-bn='dialog-footer'] {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-sm);
    padding: var(--space-md) var(--space-lg) var(--space-lg);
  }

  /* Drawer: fixed position, slides in from edge */
  [data-bn='drawer'] {
    position: fixed;
    inset-block: 0;
    inset-inline-end: 0;
    z-index: 1000;
    inline-size: min(90vw, 22rem);
    background: var(--surface-1);
    border-inline-start: var(--border-width) solid var(--border-accent);
    box-shadow: -16px 0 48px rgb(0 0 0 / 0.4);
    transform: translateX(100%);
    transition: transform var(--duration-med) var(--ease-out-expo);
    display: flex;
    flex-direction: column;
  }
  [data-bn='drawer'][data-position='left'] {
    inset-inline-end: auto;
    inset-inline-start: 0;
    border-inline-start: none;
    border-inline-end: var(--border-width) solid var(--border-accent);
    transform: translateX(-100%);
  }
  [data-bn='drawer'][data-open] {
    transform: translateX(0);
  }
  [data-bn='drawer'] [data-bn='drawer-header'] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding: var(--space-lg);
    border-block-end: var(--border-width) solid var(--border);
  }
  [data-bn='drawer'] [data-bn='drawer-title'] {
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-normal);
  }
  [data-bn='drawer'] [data-bn='drawer-close'] {
    inline-size: 2rem;
    block-size: 2rem;
    border: none;
    background: transparent;
    color: var(--text-2);
    font-size: var(--font-size-xl);
    border-radius: var(--radius-sm);
    cursor: pointer;
    line-height: 1;
  }
  [data-bn='drawer'] [data-bn='drawer-close']:hover {
    background: var(--surface-3);
    color: var(--accent);
  }
  [data-bn='drawer'] [data-bn='drawer-body'] {
    padding: var(--space-lg);
    color: var(--text-1);
    flex: 1;
    overflow-y: auto;
  }
  [data-bn='drawer-overlay'] {
    position: fixed;
    inset: 0;
    z-index: 999;
    background: rgb(0 0 0 / 0.55);
    backdrop-filter: blur(2px);
  }
  [data-bn='drawer-overlay'][hidden] {
    display: none;
  }

  /* Tooltip: anchored popover with arrow */
  [data-bn='tooltip'] {
    position: fixed;
    inset: auto;
    margin: 0;
    padding: var(--space-xs) var(--space-sm);
    background: var(--surface-3);
    color: var(--text-0);
    border: var(--border-width) solid var(--border-accent);
    border-radius: var(--radius-sm);
    box-shadow: var(--popover-shadow, 0 8px 32px rgb(0 0 0 / 0.5));
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    max-inline-size: 18rem;
    pointer-events: none;
  }
  [data-bn='tooltip']:not(:popover-open) {
    display: none;
  }

  /* Dropdown menu: popover with anchored position */
  [data-bn='dropdown-menu'] {
    position: fixed;
    inset: auto;
    margin: 0;
    min-inline-size: 12rem;
    padding: var(--space-xs);
    background: var(--surface-2);
    color: var(--text-0);
    border: var(--border-width) solid var(--border-accent);
    border-radius: var(--radius-md);
    box-shadow: var(--popover-shadow, 0 8px 32px rgb(0 0 0 / 0.5));
  }
  [data-bn='dropdown-menu']:not(:popover-open) {
    display: none;
  }
  [data-bn='dropdown-item'] {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    inline-size: 100%;
    padding: var(--space-sm) var(--space-md);
    background: transparent;
    border: none;
    color: var(--text-1);
    text-align: start;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-sm);
  }
  [data-bn='dropdown-item']:hover {
    background: var(--surface-3);
    color: var(--accent);
  }
  [data-bn='dropdown-icon'] {
    inline-size: 1rem;
    text-align: center;
  }
  [data-bn='dropdown-shortcut'] {
    margin-inline-start: auto;
    color: var(--text-2);
    font-size: var(--font-size-xs);
  }
  [data-bn='dropdown-separator'] {
    border: none;
    border-block-start: var(--border-width) solid var(--border);
    margin-block: var(--space-xs);
  }

  /* Command palette: extend the dialog rule for size */
  dialog[data-bn='command-palette'] {
    margin: auto;
    inset: 0;
    background: var(--surface-1);
    color: var(--text-0);
    border: var(--border-width) solid var(--border-accent);
    border-radius: var(--radius-lg);
    padding: 0;
    inline-size: 36rem;
    max-inline-size: calc(100% - 2rem);
    block-size: max-content;
    max-block-size: calc(100% - 2rem);
    box-shadow: var(--dialog-shadow);
  }
  dialog[data-bn='command-palette']::backdrop {
    background: var(--dialog-backdrop, rgb(0 0 0 / 0.55));
    backdrop-filter: blur(4px);
  }

  /* Tooltip trigger should be inline-flex so popover anchoring works */
  [data-bn='tooltip-trigger'] {
    display: inline-flex;
  }
}

/* ============================================================================
 * Showcase + components — modern CSS layer
 * Uses @scope, :has(), container queries, color-mix(), nesting
 * ============================================================================ */

@layer states {
  /* -- Showcase: search bar + empty state ----------------------------------- */
  [data-bn-showcase-search] {
    display: grid;
    gap: var(--space-sm);
    margin-block-end: var(--space-lg);
    padding: var(--space-md);
    background: color-mix(in srgb, var(--surface-1) 92%, transparent);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    backdrop-filter: blur(8px);
    position: sticky;
    inset-block-start: var(--space-sm);
    z-index: 6;

    & input[type='search'] {
      inline-size: 100%;
      padding: var(--space-sm) var(--space-md);
      background: var(--surface-0);
      color: var(--text-0);
      border: var(--border-width) solid var(--border);
      border-radius: var(--radius-sm);
      font-family: var(--font-family);
      font-size: var(--font-size-sm);
      transition:
        border-color var(--duration-fast),
        box-shadow var(--duration-fast);

      &::placeholder {
        color: var(--text-2);
      }

      &:focus-visible {
        outline: none;
        border-color: var(--accent);
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
      }
    }

    & [data-bn-showcase-empty] {
      display: none;
      color: var(--text-1);
      font-size: var(--font-size-sm);
      margin: 0;

      & button {
        background: none;
        border: none;
        color: var(--accent);
        font-family: inherit;
        font-size: inherit;
        cursor: pointer;
        text-decoration: underline;
        padding: 0;
      }
    }
  }
  :root[data-bn-showcase-empty] [data-bn-showcase-empty] {
    display: block;
  }

  /* Dim TOC link for hidden sections via :has() — pure CSS */
  [data-bn-showcase-toc] a[hidden] {
    display: none;
  }

  /* -- Showcase: section + figure -------------------------------------------- */
  [data-bn-showcase-section][hidden] {
    display: none;
  }

  [data-bn-showcase-demo] {
    container-type: inline-size;

    & > [data-bn-showcase-stage] {
      display: block;
      padding: var(--space-xl);
      background: var(--surface-inset);
      min-block-size: 6rem;
    }

    &[data-bn-layout='row'] > [data-bn-showcase-stage] {
      display: flex;
      flex-wrap: wrap;
      gap: var(--space-md);
      align-items: center;
    }

    &[data-bn-layout='stack'] > [data-bn-showcase-stage] {
      display: grid;
      gap: var(--space-md);
    }

    &[data-bn-layout='form'] > [data-bn-showcase-stage] {
      display: grid;
      gap: var(--space-lg);
      max-inline-size: 36rem;
    }

    &[data-bn-layout='card'] > [data-bn-showcase-stage] {
      max-inline-size: 28rem;
    }
  }

  /* Source viewer: native <details> with copy button */
  [data-bn-showcase-source],
  [data-bn-component-source] {
    border-block-start: var(--border-width) solid var(--border);
    background: var(--surface-2);
    margin: 0;
    padding: 0;

    & > summary {
      list-style: none;
      cursor: pointer;
      padding: var(--space-sm) var(--space-md);
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      letter-spacing: var(--letter-spacing-wider);
      text-transform: uppercase;
      display: flex;
      align-items: center;
      gap: var(--space-xs);
      user-select: none;

      &::-webkit-details-marker {
        display: none;
      }

      & > span:first-child {
        display: inline-block;
        transition: transform var(--duration-fast) var(--ease-out-expo);
      }
    }

    &[open] > summary > span:first-child {
      transform: rotate(180deg);
    }

    & > pre {
      margin: 0;
      padding: var(--space-md) var(--space-lg);
      background: var(--surface-inset);
      color: var(--text-0);
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-sm);
      line-height: var(--line-height-code);
      overflow-x: auto;
    }

    & > [data-bn-action='copy-code'] {
      margin: var(--space-sm) var(--space-md) var(--space-md);
      cursor: pointer;
    }

    & > [data-bn-action='copy-code'][data-bn-copied] {
      background: color-mix(in srgb, var(--success) 25%, transparent);
      border-color: var(--success);
      color: var(--success);
    }
  }

  /* -- Live demo styles ------------------------------------------------------ */
  [data-bn-live-counter] {
    display: inline-block;
    font-family: var(--font-family);
    font-stretch: var(--font-serif);
    font-size: var(--font-size-3xl, 2.5rem);
    color: var(--accent);
    min-inline-size: 4ch;
    text-align: center;
    padding: var(--space-xs) var(--space-md);
    background: color-mix(in srgb, var(--accent) 10%, transparent);
    border-radius: var(--radius-md);
  }

  [data-bn-live-validate-feedback] {
    display: block;
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-xs);
    color: var(--text-2);
    margin-block-start: var(--space-xs);

    &[data-bn-state='ok'] {
      color: var(--success);
    }

    &[data-bn-state='error'] {
      color: var(--danger);
    }

    &:empty {
      display: none;
    }
  }

  [data-bn-clock] {
    display: inline-block;
    font-family: var(--font-family);
    font-stretch: var(--font-mono);
    font-size: var(--font-size-2xl);
    color: var(--accent);
    padding: var(--space-sm) var(--space-md);
    background: var(--surface-2);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    font-variant-numeric: tabular-nums;
  }

  [data-bn-clock-note] {
    margin-block-start: var(--space-sm);
    color: var(--text-2);
    font-size: var(--font-size-xs);
    max-inline-size: 32rem;
  }

  [data-bn-theme-preview] {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    align-items: center;
    padding: var(--space-md);
    border: var(--border-width) dashed var(--border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--accent) 4%, transparent);
    transition: background var(--duration-med);
  }

  /* Computed counter readout — definition list */
  [data-bn-counter-readout] {
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: var(--space-md);
    row-gap: var(--space-xs);
    padding: var(--space-md);
    background: var(--surface-2);
    border-radius: var(--radius-md);
    max-inline-size: 24rem;

    & dt {
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      color: var(--text-2);
      letter-spacing: var(--letter-spacing-wider);
      text-transform: uppercase;
      align-self: center;
    }

    & dd {
      margin: 0;
      font-family: var(--font-family);
      font-stretch: var(--font-serif);
      font-size: var(--font-size-lg);
      color: var(--text-0);

      &[data-parity='odd'] {
        color: var(--accent);
      }

      &[data-parity='even'] {
        color: var(--success);
      }
    }
  }

  /* -- Components page: search + tag filter --------------------------------- */
  [data-bn-component-search] {
    display: grid;
    gap: var(--space-sm);
    margin-block-end: var(--space-xl);
    padding: var(--space-md);
    background: color-mix(in srgb, var(--surface-1) 92%, transparent);
    border: var(--border-width) solid var(--border);
    border-radius: var(--radius-md);
    backdrop-filter: blur(8px);
    position: sticky;
    inset-block-start: var(--space-sm);
    z-index: 6;

    & input[type='search'] {
      inline-size: 100%;
      padding: var(--space-sm) var(--space-md);
      background: var(--surface-0);
      color: var(--text-0);
      border: var(--border-width) solid var(--border);
      border-radius: var(--radius-sm);
      font-family: var(--font-family);
      font-size: var(--font-size-sm);

      &::placeholder {
        color: var(--text-2);
      }

      &:focus-visible {
        outline: none;
        border-color: var(--accent);
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
      }
    }

    & [data-bn-component-empty] {
      display: none;
      color: var(--text-1);
      font-size: var(--font-size-sm);
      margin: 0;

      & button {
        background: none;
        border: none;
        color: var(--accent);
        font-family: inherit;
        font-size: inherit;
        cursor: pointer;
        text-decoration: underline;
        padding: 0;
      }
    }
  }
  :root[data-bn-no-results] [data-bn-component-empty] {
    display: block;
  }

  [data-bn-component-filters] {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);

    & button {
      background: var(--surface-2);
      border: var(--border-width) solid var(--border);
      color: var(--text-1);
      font-family: var(--font-family);
      font-stretch: var(--font-mono);
      font-size: var(--font-size-xs);
      letter-spacing: var(--letter-spacing-wider);
      text-transform: uppercase;
      padding: var(--space-xs) var(--space-md);
      border-radius: var(--radius-sm);
      cursor: pointer;
      transition:
        background var(--duration-fast),
        color var(--duration-fast),
        border-color var(--duration-fast);

      &:hover {
        background: var(--surface-3);
        color: var(--accent);
      }

      &[aria-pressed='true'] {
        background: color-mix(in srgb, var(--accent) 18%, transparent);
        color: var(--accent);
        border-color: var(--accent);
      }
    }
  }

  [data-bn-component-card-host][hidden],
  [data-bn-component-category][hidden] {
    display: none;
  }

  /* Hide a category whose cards are all filtered out — :has() */
  [data-bn-component-category]:not(:has([data-bn-component-card-host]:not([hidden]))) {
    display: none;
  }

  /* -- Component detail: related components --------------------------------- */
  [data-bn-component-related] {
    margin-block: var(--space-2xl) var(--space-xl);
    padding-block-start: var(--space-xl);
    border-block-start: var(--border-width) solid var(--border);

    & > h3 {
      font-family: var(--font-family);
      font-stretch: var(--font-serif);
      font-size: var(--font-size-xl);
      font-weight: var(--font-weight-normal);
      margin-block-end: var(--space-lg);

      & em {
        font-style: normal;
        color: var(--accent);
      }
    }
  }

  /* -- Container queries: showcase grid adaptation -------------------------- */
  @container (min-width: 36rem) {
    [data-bn-showcase-demo][data-bn-layout='form'] > [data-bn-showcase-stage] {
      grid-template-columns: 1fr 1fr;
      gap: var(--space-xl);
    }
  }
}

@layer states {
  /* -- @scope: keep showcase TOC styles from leaking ------------------------ */
  @scope ([data-bn-showcase-toc]) {
    :scope a:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 2px;
    }
  }

  /* -- @scope: per-section card host styling -------------------------------- */
  @scope ([data-bn-component-grid]) {
    :scope > li:has(a:focus-visible) {
      transform: translateY(-2px);
    }
  }
}
