/* ============================================================
   VENDORED — DO NOT EDIT
   Source: C:/dev/ICGBrand/styleguide/components.css
   Brand version: ICG Brand v1.2 (per BRAND.md section 12)
   To update: re-copy from the canonical source.  Hand-edits
   here will be lost on the next vendor refresh.
   ============================================================ */

/* ============================================================
   ICG BRAND — COMPONENTS
   Editorial-industrial component library. Every component
   consumes ONLY semantic tokens. Re-theming = swap a theme file.
   ============================================================ */

/* ────────────────────────────────────────────────────────
   1. LAYOUT PRIMITIVES
   ──────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container-lg);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.container--narrow { max-width: var(--container-md); }
.container--wide   { max-width: var(--container-xl); }
.container--bleed  { max-width: 100%; padding-inline: 0; }

.section { padding-block: var(--space-10); position: relative; }
.section--tight    { padding-block: var(--space-7); }
.section--spacious { padding-block: var(--space-12); }
.section--inverse {
  background: var(--surface-inverse);
  color: var(--text-inverse);
}
.section--inverse h1, .section--inverse h2,
.section--inverse h3, .section--inverse h4 { color: var(--text-inverse); }
.section--inverse h5 { color: var(--gray-300); }
.section--inverse .lede { color: color-mix(in oklab, var(--text-inverse) 78%, transparent); }
.section--inverse .eyebrow { color: var(--color-spark); }

.stack > * + * { margin-block-start: var(--space-4); }
.stack-sm > * + * { margin-block-start: var(--space-2); }
.stack-lg > * + * { margin-block-start: var(--space-6); }
.stack-xl > * + * { margin-block-start: var(--space-8); }

.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}
.cluster--between {
  justify-content: space-between;
}

.grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr));
}
.grid--2 { grid-template-columns: repeat(auto-fit, minmax(min(420px, 100%), 1fr)); }
.grid--3 { grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr)); }
.grid--4 { grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr)); }

/* Editorial signature — hairline rule */
.rule {
  border: 0;
  border-top: 1px solid var(--surface-rule);
  margin: 0;
}
.rule--strong { border-top-color: var(--text-strong); }
.rule--accent { border-top-color: var(--color-action); }

/* Section header with index — editorial detail */
.section-head {
  display: grid;
  gap: var(--space-3);
  padding-block-end: var(--space-6);
  border-bottom: 1px solid var(--surface-rule);
  margin-bottom: var(--space-7);
}
.section-head__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.section-head__title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-tightest);
  line-height: var(--leading-tight);
  color: var(--text-strong);
  max-width: 24ch;
}
.section-head__index {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-index);
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
}

/* Dotted-grid backdrop — editorial atmospheric texture */
.grid-bg {
  position: relative;
  isolation: isolate;
}
.grid-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 1px 1px, color-mix(in oklab, var(--text-faint) 28%, transparent) 1px, transparent 0);
  background-size: 28px 28px;
  background-position: 0 0;
  opacity: 0.6;
  pointer-events: none;
  z-index: -1;
  mask: radial-gradient(ellipse 80% 60% at 50% 40%, black 30%, transparent 100%);
  -webkit-mask: radial-gradient(ellipse 80% 60% at 50% 40%, black 30%, transparent 100%);
}

/* ────────────────────────────────────────────────────────
   2. SITE NAVIGATION
   ──────────────────────────────────────────────────────── */
.site-nav {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: color-mix(in oklab, var(--surface-canvas) 88%, transparent);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--border-hairline);
}
.site-nav__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-6);
  height: 76px;
}
.site-nav__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  font-size: var(--text-lg);
  color: var(--text-strong);
  letter-spacing: var(--tracking-tight);
}
.site-nav__brand-mark {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  background: var(--color-action);
  color: var(--text-on-action);
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-weight: var(--weight-bold);
}
.site-nav__links {
  display: flex;
  gap: var(--space-6);
  justify-content: center;
}
.site-nav__link {
  position: relative;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-secondary);
  padding-block: var(--space-3);
  transition: color var(--duration-fast) var(--ease-out);
}
.site-nav__link:hover { color: var(--text-strong); }
.site-nav__link[aria-current="page"] { color: var(--text-strong); }
.site-nav__link[aria-current="page"]::after {
  content: '';
  position: absolute;
  inset-inline: 0;
  bottom: -1px;
  height: 2px;
  background: var(--color-action);
}
.site-nav__cta { justify-self: end; }
@media (max-width: 760px) {
  .site-nav__links { display: none; }
  .site-nav__inner { grid-template-columns: auto 1fr; }
}

/* ────────────────────────────────────────────────────────
   3. HERO
   ──────────────────────────────────────────────────────── */
.hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  color: var(--text-inverse);
  background: var(--gradient-hero);
  padding-block: var(--space-12);
}
.hero::before {
  /* faint dotted grid */
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 1px 1px, color-mix(in oklab, white 12%, transparent) 1px, transparent 0);
  background-size: 32px 32px;
  z-index: -1;
  opacity: 0.7;
}
.hero::after {
  /* warm/cool radial accent depending on theme */
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 60% at 85% 15%, color-mix(in oklab, var(--color-spark) 28%, transparent) 0%, transparent 70%),
    radial-gradient(40% 40% at 15% 85%, color-mix(in oklab, var(--color-action) 18%, transparent) 0%, transparent 70%);
  z-index: -1;
  pointer-events: none;
}
.hero__index {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-index);
  text-transform: uppercase;
  color: color-mix(in oklab, var(--text-inverse) 60%, transparent);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.hero__index::before {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--color-spark);
}
.hero__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-index);
  text-transform: uppercase;
  color: var(--color-spark);
  margin-bottom: var(--space-4);
}
.hero__title {
  font-family: var(--font-display);
  font-size: var(--text-5xl);
  font-weight: var(--weight-semibold);
  line-height: 0.98;
  letter-spacing: var(--tracking-tightest);
  max-width: 18ch;
  color: var(--text-inverse);
  font-variation-settings: 'opsz' 144, 'SOFT' 30, 'WONK' 0;
  margin-bottom: var(--space-5);
}
.hero__title em {
  font-style: italic;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  color: var(--color-spark);
}
.hero__lede {
  font-family: var(--font-display);
  font-weight: var(--weight-regular);
  font-size: var(--text-md);
  line-height: var(--leading-snug);
  color: color-mix(in oklab, var(--text-inverse) 78%, transparent);
  max-width: 52ch;
  margin-bottom: var(--space-7);
  font-variation-settings: 'opsz' 36, 'SOFT' 50;
}
.hero__actions { gap: var(--space-3); }
.hero__meta {
  margin-top: var(--space-9);
  padding-top: var(--space-5);
  border-top: 1px solid color-mix(in oklab, var(--text-inverse) 18%, transparent);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-5);
}
.hero__meta-item {
  display: grid;
  gap: var(--space-1);
}
.hero__meta-item dt {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-index);
  text-transform: uppercase;
  color: color-mix(in oklab, var(--text-inverse) 55%, transparent);
}
.hero__meta-item dd {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--text-inverse);
  letter-spacing: var(--tracking-tight);
}

/* ────────────────────────────────────────────────────────
   4. BUTTONS
   ──────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.875rem 1.5rem;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-weight: var(--weight-medium);
  font-size: var(--text-sm);
  letter-spacing: 0.01em;
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  position: relative;
  transition: transform var(--duration-fast) var(--ease-out),
              background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out);
}
.btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.btn:active { transform: translateY(1px); }
.btn .icon { width: 14px; height: 14px; flex-shrink: 0; }
.btn--lg { padding: 1.05rem 1.85rem; font-size: var(--text-base); }
.btn--sm { padding: 0.55rem 1rem; font-size: var(--text-xs); }

.btn--primary {
  background: var(--color-action);
  color: var(--text-on-action);
  box-shadow: var(--shadow-sm);
}
.btn--primary:hover {
  background: var(--color-action-hover);
  box-shadow: var(--shadow-md);
}
.btn--primary:active { background: var(--color-action-active); }

.btn--secondary {
  background: var(--surface-canvas);
  color: var(--text-strong);
  border: 1px solid var(--border-default);
}
.btn--secondary:hover {
  border-color: var(--text-strong);
  color: var(--text-strong);
}

.btn--ghost {
  background: transparent;
  color: var(--text-strong);
  padding-inline: 0;
}
.btn--ghost:hover { color: var(--color-action); }
.btn--ghost::after {
  content: '→';
  margin-left: 0.25em;
  transition: transform var(--duration-fast) var(--ease-out);
}
.btn--ghost:hover::after { transform: translateX(3px); }

.btn--inverse {
  background: var(--color-spark);
  color: var(--navy-950);
  font-weight: var(--weight-semibold);
}
.btn--inverse:hover { filter: brightness(1.06); }

.btn--outline-light {
  background: transparent;
  color: var(--text-inverse);
  border: 1px solid color-mix(in oklab, var(--text-inverse) 40%, transparent);
}
.btn--outline-light:hover {
  border-color: var(--text-inverse);
  background: color-mix(in oklab, var(--text-inverse) 8%, transparent);
}

/* ────────────────────────────────────────────────────────
   5. FORMS
   ──────────────────────────────────────────────────────── */
.field { display: grid; gap: var(--space-2); }
.field__label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--text-secondary);
}
.field__hint  { font-size: var(--text-xs); color: var(--text-muted); }
.field__error { font-size: var(--text-xs); color: var(--color-danger); }

.input, .textarea, .select {
  width: 100%;
  padding: 0.875rem 1rem;
  background: var(--surface-canvas);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text-primary);
  transition: border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}
.input::placeholder, .textarea::placeholder { color: var(--text-faint); }
.input:focus-visible, .textarea:focus-visible, .select:focus-visible {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-action) 22%, transparent);
}
.textarea { min-height: 7rem; resize: vertical; }
.select {
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='%2345423a' stroke-width='1.5'><path d='M6 8l4 4 4-4'/></svg>");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

/* ────────────────────────────────────────────────────────
   6. CARDS
   ──────────────────────────────────────────────────────── */
.card {
  background: var(--surface-elevated);
  border: 1px solid var(--border-hairline);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: transform var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
}
.card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  border-color: var(--border-default);
}
.card__icon {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  border-radius: var(--radius-sm);
  background: var(--color-action-soft);
  color: var(--color-action-active);
  font-family: var(--font-mono);
  font-weight: var(--weight-bold);
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}
.card__index {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-index);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--space-2);
}
.card__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-tight);
  color: var(--text-strong);
}
.card__body { color: var(--text-secondary); font-size: var(--text-base); }
.card__footer {
  margin-top: auto;
  padding-top: var(--space-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

/* ────────────────────────────────────────────────────────
   7. PRICING
   ──────────────────────────────────────────────────────── */
.pricing {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr));
}
.price-card {
  position: relative;
  padding: var(--space-7) var(--space-6) var(--space-6);
  border-radius: var(--radius-lg);
  background: var(--surface-elevated);
  border: 1px solid var(--border-hairline);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: border-color var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out);
}
.price-card:hover { border-color: var(--border-default); }
.price-card--featured {
  border-color: var(--text-strong);
  box-shadow: var(--shadow-lg);
}
.price-card--featured::before {
  content: '⬢ MOST CHOSEN';
  position: absolute;
  top: var(--space-4);
  right: var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  color: var(--color-action);
}
.price-card__name {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-index);
  text-transform: uppercase;
  color: var(--text-muted);
}
.price-card__amount {
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  font-size: var(--text-4xl);
  line-height: 1;
  letter-spacing: var(--tracking-tightest);
  color: var(--text-strong);
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
}
.price-card__amount small {
  display: block;
  margin-top: var(--space-1);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-regular);
  color: var(--text-muted);
  letter-spacing: 0;
}
.price-card__note {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--text-secondary);
  letter-spacing: var(--tracking-tight);
  font-variation-settings: 'opsz' 36;
}
.price-card hr.rule { margin-block: var(--space-2); }
.price-card__features { display: grid; gap: var(--space-2); font-size: var(--text-sm); }
.price-card__features li {
  display: flex; gap: var(--space-3); align-items: flex-start;
  color: var(--text-primary);
}
.price-card__features li::before {
  content: '';
  flex: 0 0 16px; height: 16px; margin-top: 4px;
  background: var(--color-action);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center / contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center / contain no-repeat;
}
.price-card__cta { margin-top: auto; width: 100%; justify-content: center; }

/* ────────────────────────────────────────────────────────
   8. TESTIMONIAL
   ──────────────────────────────────────────────────────── */
.testimonial {
  position: relative;
  padding: var(--space-7);
  background: var(--surface-subtle);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-action);
}
.testimonial::before {
  content: '\201C';   /* opening curly quote */
  position: absolute;
  top: var(--space-3);
  right: var(--space-5);
  font-family: var(--font-display);
  font-size: 6rem;
  line-height: 1;
  color: var(--color-action);
  opacity: 0.18;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
}
.testimonial__quote {
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: var(--weight-regular);
  line-height: var(--leading-snug);
  color: var(--text-strong);
  letter-spacing: var(--tracking-tight);
  font-variation-settings: 'opsz' 36, 'SOFT' 50;
  position: relative;
  z-index: 1;
}
.testimonial__author {
  display: flex; align-items: center; gap: var(--space-3);
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-hairline);
}
.testimonial__avatar {
  width: 40px; height: 40px;
  border-radius: var(--radius-pill);
  background: var(--color-action-soft);
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-weight: var(--weight-semibold);
  font-size: var(--text-sm);
  color: var(--color-action-active);
}
.testimonial__name { font-weight: var(--weight-semibold); color: var(--text-strong); }
.testimonial__role {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 2px;
}

/* ────────────────────────────────────────────────────────
   9. TAGS / PILLS
   ──────────────────────────────────────────────────────── */
.tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 4px 10px;
  background: var(--color-action-soft);
  color: var(--color-action-active);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  border-radius: var(--radius-xs);
}
.tag--outline {
  background: transparent;
  border: 1px solid var(--border-default);
  color: var(--text-secondary);
}
.tag--spark {
  background: var(--color-spark-soft);
  color: var(--text-strong);
}

/* ────────────────────────────────────────────────────────
   10. FOOTER
   ──────────────────────────────────────────────────────── */
.site-footer {
  background: var(--surface-inverse);
  color: var(--text-inverse);
  padding-block: var(--space-10) var(--space-7);
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 1px 1px, color-mix(in oklab, white 8%, transparent) 1px, transparent 0);
  background-size: 32px 32px;
  opacity: 0.5;
  pointer-events: none;
}
.site-footer__top {
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: var(--space-8);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--border-inverse);
  position: relative;
}
@media (max-width: 880px) {
  .site-footer__top { grid-template-columns: 1fr; }
}
.site-footer__brand {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-tightest);
  color: var(--text-inverse);
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
}
.site-footer__pitch {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: color-mix(in oklab, var(--text-inverse) 70%, transparent);
  margin-top: var(--space-3);
  max-width: 38ch;
  letter-spacing: var(--tracking-tight);
}
.site-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
@media (max-width: 560px) {
  .site-footer__nav { grid-template-columns: 1fr 1fr; }
}
.site-footer__col h5 {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-index);
  text-transform: uppercase;
  color: var(--gray-400);
  margin-bottom: var(--space-4);
}
.site-footer__col a {
  display: block;
  padding-block: 6px;
  font-size: var(--text-sm);
  color: var(--gray-300);
  transition: color var(--duration-fast) var(--ease-out);
}
.site-footer__col a:hover { color: var(--color-spark); }
.site-footer__legal {
  margin-top: var(--space-7);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  color: var(--gray-400);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  position: relative;
}

/* ────────────────────────────────────────────────────────
   11. FEATURE BLOCK (text + visual side-by-side)
   ──────────────────────────────────────────────────────── */
.feature {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-9);
  align-items: center;
}
@media (max-width: 880px) {
  .feature { grid-template-columns: 1fr; gap: var(--space-6); }
}
.feature--reverse > :first-child { order: 2; }
.feature__visual {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--gradient-hero);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* ────────────────────────────────────────────────────────
   12. STATS BAND
   ──────────────────────────────────────────────────────── */
.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-7);
  padding-block: var(--space-7);
  border-block: 1px solid var(--border-hairline);
}
.stat__num {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-tightest);
  line-height: 1;
  color: var(--text-strong);
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
}
.stat__num em {
  font-style: normal;
  color: var(--color-action);
}
.stat__label {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-index);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: var(--space-2);
}

/* ════════════════════════════════════════════════════════════
   MONITORING COMPONENTS
   Originally driven by FourthShift Monitor's needs, but built
   theme-blind so any product surface can use them.
   ════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────
   13. STATUS DOT  (.status-dot, with state variants + live ping)
   ──────────────────────────────────────────────────────── */
.status-dot {
  position: relative;
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: var(--radius-pill);
  background: currentColor;
  flex-shrink: 0;
  /* Halo ring */
  box-shadow: 0 0 0 2px color-mix(in oklab, currentColor 22%, transparent);
}
.status-dot--lg { width: 14px; height: 14px; }
.status-dot--sm { width: 8px;  height: 8px;  }
.status-dot--live      { color: var(--color-spark); }
.status-dot--ok        { color: var(--color-success); }
.status-dot--warn      { color: var(--color-warning); }
.status-dot--critical  { color: var(--color-danger); }
.status-dot--info      { color: var(--color-info); }
.status-dot--idle      { color: var(--text-faint); box-shadow: 0 0 0 2px color-mix(in oklab, currentColor 14%, transparent); }
.status-dot--paused    { color: var(--text-muted); box-shadow: 0 0 0 2px color-mix(in oklab, currentColor 14%, transparent); }

/* Animated radar-ping ring on .status-dot--live (and any dot with .status-dot--ping) */
.status-dot--live::after,
.status-dot--ping::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: currentColor;
  animation: icg-ping 2.4s var(--ease-out) infinite;
  z-index: -1;
  pointer-events: none;
}

/* ────────────────────────────────────────────────────────
   14. SEVERITY BADGE  (.severity-badge)
   ──────────────────────────────────────────────────────── */
.severity-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 3px 10px 3px 8px;
  border-radius: var(--radius-xs);
  border: 1px solid currentColor;
  background: color-mix(in oklab, currentColor 8%, var(--surface-canvas));
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  white-space: nowrap;
}
.severity-badge::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: currentColor;
  flex-shrink: 0;
}
.severity-badge--critical { color: var(--color-danger); }
.severity-badge--warning  { color: var(--color-warning); }
.severity-badge--info     { color: var(--color-info); }
.severity-badge--ok       { color: var(--color-success); }
.severity-badge--neutral  { color: var(--text-muted); border-color: var(--border-default); background: var(--surface-muted); }

/* ────────────────────────────────────────────────────────
   15. LIVE BADGE  (.live-badge — pulsing dot + LIVE label)
   ──────────────────────────────────────────────────────── */
.live-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px 12px 4px 10px;
  border-radius: var(--radius-pill);
  background: var(--surface-inverse);
  color: var(--text-inverse);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.live-badge__dot {
  position: relative;
  width: 7px;
  height: 7px;
  border-radius: var(--radius-pill);
  background: var(--color-spark);
  animation: icg-pulse-dot 1.8s ease-in-out infinite;
  flex-shrink: 0;
}
.live-badge__dot::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--color-spark);
  animation: icg-ping 2.4s var(--ease-out) infinite;
  z-index: 0;
}

/* ────────────────────────────────────────────────────────
   16. METRIC TILE  (.metric-tile — dashboard / status-page tile)
   ──────────────────────────────────────────────────────── */
.metric-tile {
  position: relative;
  padding: var(--space-5);
  background: var(--surface-elevated);
  border: 1px solid var(--border-hairline);
  border-radius: var(--radius-md);
  display: grid;
  gap: var(--space-3);
  transition: border-color var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out);
}
.metric-tile:hover {
  border-color: var(--border-default);
  box-shadow: var(--shadow-md);
}
.metric-tile__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}
.metric-tile__label {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--text-muted);
}
.metric-tile__value {
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  font-size: var(--text-3xl);
  line-height: 1;
  letter-spacing: var(--tracking-tightest);
  color: var(--text-strong);
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
}
.metric-tile__value small {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-regular);
  color: var(--text-muted);
  margin-left: 4px;
  letter-spacing: 0;
}
.metric-tile__trend {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.metric-tile__trend--up   { color: var(--color-success); }
.metric-tile__trend--down { color: var(--color-danger); }
.metric-tile__trend--flat { color: var(--text-muted); }
.metric-tile__sparkline {
  height: 32px;
  width: 100%;
  display: block;
  color: var(--color-action);
  opacity: 0.85;
}
.metric-tile__sparkline path { vector-effect: non-scaling-stroke; }
.metric-tile__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-hairline);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide);
  color: var(--text-muted);
  text-transform: uppercase;
}

/* ────────────────────────────────────────────────────────
   17. CONSOLE BLOCK  (.console-block — log lines, agent output)
   ──────────────────────────────────────────────────────── */
.console-block {
  position: relative;
  background: var(--surface-inverse);
  color: var(--text-inverse);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.7;
  padding: var(--space-5) var(--space-6);
  border-radius: var(--radius-md);
  border: 1px solid var(--navy-700);
  overflow-x: auto;
}
.console-block::before {
  /* Subtle dotted grid backdrop, matching the editorial-industrial signature */
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 1px 1px, color-mix(in oklab, white 6%, transparent) 1px, transparent 0);
  background-size: 24px 24px;
  pointer-events: none;
  border-radius: inherit;
}
.console-block__head {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin: calc(var(--space-5) * -1) calc(var(--space-6) * -1) var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--navy-700);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--gray-400);
  background: color-mix(in oklab, var(--surface-inverse) 70%, black);
  border-top-left-radius: var(--radius-md);
  border-top-right-radius: var(--radius-md);
}
.console-block__lines {
  position: relative;
  display: grid;
  gap: 0;
}
.console-block__line {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: var(--space-4);
  padding-block: 1px;
}
.console-block__num {
  color: var(--gray-500);
  text-align: right;
  user-select: none;
  font-variant-numeric: tabular-nums;
}
.console-block__msg { color: color-mix(in oklab, var(--text-inverse) 88%, transparent); }
.console-block__line--pinned .console-block__msg { color: var(--color-spark); font-weight: var(--weight-medium); }
.console-block__line--ok       .console-block__msg { color: color-mix(in oklab, var(--color-success) 70%, white 30%); }
.console-block__line--warn     .console-block__msg { color: color-mix(in oklab, var(--color-warning) 70%, white 30%); }
.console-block__line--critical .console-block__msg { color: color-mix(in oklab, var(--color-danger) 70%, white 30%); }
.console-block__line--muted    .console-block__msg { color: var(--gray-500); }
.console-block__msg .ts {
  color: var(--gray-500);
  margin-right: var(--space-2);
}
.console-block__msg .tag {
  background: transparent;
  border: 1px solid color-mix(in oklab, var(--text-inverse) 24%, transparent);
  color: var(--text-inverse);
  text-transform: uppercase;
  padding: 1px 6px;
  font-size: 9px;
  letter-spacing: var(--tracking-wide);
  margin-right: var(--space-2);
  border-radius: var(--radius-xs);
}
