@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: #7a7890;

    /* 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: #546e7a;
    --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;
  }

  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);
  }

  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 -- */
  [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;
  }
  [data-status="active"], [data-status="done"] { background: var(--status-active-bg); color: var(--success); }
  [data-status="idle"], [data-status="dom"], [data-status="binding"] { background: var(--status-idle-bg); color: var(--accent); }
  [data-status="error"] { background: var(--status-error-bg); color: var(--danger); }
  [data-status="pending"], [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; }

  /* -- 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); }
}
