/*
  Anson Mae Manpower CSS
  Tier 1 visual infrastructure for internal operating surfaces.
  This file is intentionally framework-free and authored as reusable CSS schema.
*/

@layer reset, tokens, base, layout, components, states, templates, utilities;

@layer reset {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  html {
    min-width: 320px;
    color-scheme: light;
    text-size-adjust: 100%;
  }

  body {
    margin: 0;
  }

  button,
  input,
  textarea,
  select {
    font: inherit;
  }

  a {
    color: inherit;
    text-decoration: none;
  }

  img,
  svg {
    display: block;
    max-width: 100%;
  }
}

@layer tokens {
  :root {
    --font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --font-mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;

    --ink-900: #111312;
    --ink-800: #1c211f;
    --ink-700: #2c3431;
    --ink-600: #43504b;
    --ink-500: #64716c;
    --ink-400: #88928e;
    --ink-300: #b7bfbb;
    --ink-200: #d8ded9;
    --ink-100: #edf0ec;
    --paper: #fbfaf5;
    --paper-strong: #ffffff;

    --teal: #d85c1f;
    --teal-soft: #ffe1c7;
    --indigo: #4057b2;
    --indigo-soft: #e4e9ff;
    --amber: #ba6b00;
    --amber-soft: #ffe7bd;
    --rose: #b93a4b;
    --rose-soft: #ffdfe4;
    --green: #b84b18;
    --green-soft: #ffe8d6;
    --violet: #6b4aa5;
    --violet-soft: #ede4ff;

    --surface: color-mix(in srgb, var(--paper-strong) 92%, var(--ink-100));
    --surface-muted: color-mix(in srgb, var(--paper) 84%, var(--ink-100));
    --line: color-mix(in srgb, var(--ink-200) 54%, transparent);
    --line-strong: color-mix(in srgb, var(--ink-300) 58%, transparent);
    --shadow-soft: 0 24px 64px rgb(17 19 18 / 6%);
    --shadow-tight: 0 12px 32px rgb(17 19 18 / 4%);

    --radius-xs: 8px;
    --radius-sm: 12px;
    --radius-md: 18px;
    --radius-lg: 26px;

    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-7: 2rem;
    --space-8: 2.5rem;
    --space-9: 3rem;

    --step--1: 0.78rem;
    --step-0: 0.92rem;
    --step-1: 1rem;
    --step-2: 1.18rem;
    --step-3: 1.42rem;
    --step-4: 1.85rem;

    --rail-width: 17rem;
    --command-height: 4.5rem;
    --content-max: 118rem;

    --state-color: var(--ink-600);
    --state-soft: var(--ink-100);
    --state-line: var(--ink-200);
  }
}

@layer base {
  body {
    min-height: 100vh;
    background:
      linear-gradient(135deg, rgb(216 92 31 / 10%), transparent 24rem),
      linear-gradient(315deg, rgb(186 107 0 / 8%), transparent 30rem),
      var(--paper);
    color: var(--ink-800);
    font-family: var(--font-sans);
    font-size: var(--step-0);
    line-height: 1.5;
  }

  :focus-visible {
    outline: 3px solid color-mix(in srgb, var(--indigo) 68%, white);
    outline-offset: 3px;
  }

  h1,
  h2,
  h3,
  p {
    margin-block: 0;
  }

  h1 {
    color: var(--ink-900);
    font-size: var(--step-4);
    font-weight: 760;
    line-height: 1.04;
  }

  h2 {
    color: var(--ink-900);
    font-size: var(--step-2);
    font-weight: 740;
    line-height: 1.15;
  }

  h3 {
    color: var(--ink-800);
    font-size: var(--step-1);
    font-weight: 720;
    line-height: 1.25;
  }

  p {
    color: var(--ink-600);
  }

  code,
  .mono {
    font-family: var(--font-mono);
    font-size: 0.92em;
  }
}

@layer layout {
  .os-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: var(--rail-width) minmax(0, 1fr);
    overflow-x: hidden;
  }

  .os-rail {
    position: sticky;
    top: 0;
    height: 100vh;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: var(--space-5);
    padding: var(--space-5);
    border-right: 1px solid var(--line);
    background: rgb(251 250 245 / 88%);
    backdrop-filter: blur(20px);
  }

  .os-workspace {
    min-width: 0;
    display: grid;
    grid-template-rows: auto 1fr;
  }

  .os-command {
    min-height: var(--command-height);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-5);
    padding: var(--space-5) clamp(var(--space-5), 3vw, var(--space-8));
    border-bottom: 1px solid var(--line);
    background: rgb(251 250 245 / 76%);
    backdrop-filter: blur(18px);
  }

  .os-plane {
    width: min(100%, var(--content-max));
    max-width: 100%;
    margin-inline: auto;
    padding: clamp(var(--space-5), 3vw, var(--space-8));
    overflow-x: clip;
  }

  .plane-stack {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-6);
  }

  .plane-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: var(--space-5);
    align-items: stretch;
    min-width: 0;
  }

  .span-12 {
    grid-column: span 12;
  }

  .span-8 {
    grid-column: span 8;
  }

  .span-6 {
    grid-column: span 6;
  }

  .span-4 {
    grid-column: span 4;
  }

  .span-3 {
    grid-column: span 3;
  }

  .plane-stack > .span-12,
  .plane-stack > .span-8,
  .plane-stack > .span-6,
  .plane-stack > .span-4,
  .plane-stack > .span-3,
  .plane-stack > .surface-panel,
  .plane-stack > .plane-grid {
    grid-column: 1 / -1;
  }

  .flow {
    display: grid;
    gap: var(--space-4);
  }

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

  .split {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    min-width: 0;
  }

  .split > * {
    min-width: 0;
  }
}

@layer components {
  .brand-mark {
    display: grid;
    grid-template-columns: 2.75rem minmax(0, 1fr);
    gap: var(--space-3);
    align-items: center;
  }

  .brand-sigil {
    width: 2.75rem;
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-md);
    background:
      linear-gradient(145deg, rgb(216 92 31 / 16%), transparent 62%),
      var(--surface);
    color: var(--teal);
    box-shadow: var(--shadow-tight);
    font-weight: 820;
  }

  .brand-title {
    color: var(--ink-900);
    font-size: var(--step-1);
    font-weight: 780;
    line-height: 1.05;
  }

  .brand-subtitle,
  .eyebrow,
  .meta {
    color: var(--ink-500);
    font-size: var(--step--1);
    font-weight: 660;
    letter-spacing: 0;
    text-transform: uppercase;
  }

  .nav-list {
    display: grid;
    gap: var(--space-2);
    padding: 0;
    margin: 0;
    list-style: none;
  }

  .nav-link {
    min-height: 2.5rem;
    display: grid;
    grid-template-columns: 1.35rem minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-3);
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    color: var(--ink-700);
    font-weight: 700;
  }

  .nav-link[aria-current="page"],
  .nav-link:hover {
    border-color: var(--line);
    background: var(--surface);
    color: var(--ink-900);
  }

  .nav-icon {
    width: 1rem;
    aspect-ratio: 1;
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-xs);
    background: var(--state-soft);
    box-shadow: inset 0 0 0 3px rgb(255 255 255 / 54%);
  }

  .rail-note {
    display: grid;
    gap: var(--space-2);
    padding: var(--space-4);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--surface-muted);
  }

  .command-title {
    display: grid;
    gap: var(--space-1);
    min-width: 0;
  }

  .command-actions {
    display: flex;
    align-items: center;
    gap: var(--space-3);
  }

  .icon-button {
    width: 2.5rem;
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--ink-700);
    box-shadow: var(--shadow-tight);
    cursor: pointer;
  }

  .icon-button:hover {
    border-color: var(--line-strong);
    color: var(--ink-900);
  }

  .kpi-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-4);
  }

  .kpi {
    display: grid;
    gap: var(--space-2);
    min-height: 7.5rem;
    padding: var(--space-4);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--surface);
    box-shadow: var(--shadow-tight);
  }

  .kpi-value {
    color: var(--ink-900);
    font-size: var(--step-4);
    font-weight: 800;
    line-height: 0.95;
  }

  .kpi-label {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 700;
    text-transform: uppercase;
  }

  .surface-panel {
    container-type: inline-size;
    width: 100%;
    display: grid;
    align-content: start;
    gap: var(--space-4);
    min-width: 0;
    min-height: 100%;
    padding: var(--space-5);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--surface);
    box-shadow: var(--shadow-soft);
  }

  .panel-header {
    display: grid;
    gap: var(--space-2);
  }

  .panel-rule {
    height: 1px;
    background: var(--line);
  }

  .status-chip {
    width: fit-content;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    min-height: 1.75rem;
    padding: 0.25rem 0.55rem;
    border: 1px solid var(--state-line);
    border-radius: 999px;
    background: var(--state-soft);
    color: var(--state-color);
    font-size: var(--step--1);
    font-weight: 780;
    line-height: 1;
  }

  .status-chip::before {
    content: "";
    width: 0.5rem;
    aspect-ratio: 1;
    border-radius: 999px;
    background: currentColor;
  }

  .status-chip[data-project] {
    --state-color: var(--project-color);
    --state-soft: var(--project-soft);
    --state-line: color-mix(in srgb, var(--project-color) 30%, white);
  }

  .data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--step--1);
  }

  .data-table th,
  .data-table td {
    padding: 0.75rem 0.65rem;
    border-bottom: 1px solid var(--line);
    text-align: left;
    vertical-align: top;
  }

  .data-table th {
    color: var(--ink-500);
    font-weight: 760;
    text-transform: uppercase;
  }

  .data-table td {
    color: var(--ink-700);
    font-weight: 620;
  }

  .project-ladder,
  .task-lane,
  .integration-map,
  .gate-list {
    display: grid;
    gap: var(--space-3);
  }

  .project-row,
  .task-row,
  .integration-row,
  .gate-row {
    display: grid;
    gap: var(--space-3);
    padding: var(--space-4);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--surface) 82%, var(--project-soft, var(--paper)));
  }

  a.project-row {
    color: inherit;
    cursor: pointer;
    text-decoration: none;
  }

  a.project-row:focus-visible {
    outline-offset: 5px;
  }

  a.project-row::after {
    content: "Open";
    justify-self: end;
    align-self: start;
    padding: 0.25rem 0.45rem;
    border: 1px solid color-mix(in srgb, var(--project-color, var(--state-color)) 26%, var(--line));
    border-radius: 999px;
    background: color-mix(in srgb, var(--project-soft, var(--state-soft)) 70%, white);
    color: var(--project-color, var(--state-color));
    font-size: var(--step--1);
    font-weight: 820;
    line-height: 1;
  }

  a.project-row .project-name {
    transition: color 180ms ease;
  }

  a.project-row:hover .project-name {
    color: var(--project-color, var(--state-color));
  }

  .project-row {
    grid-template-columns: 3.25rem minmax(0, 1fr) auto auto;
    align-items: center;
    border-left: 0.35rem solid var(--project-color, var(--ink-300));
  }

  .project-id {
    color: var(--project-color, var(--ink-700));
    font-family: var(--font-mono);
    font-size: var(--step-1);
    font-weight: 820;
  }

  .project-main {
    display: grid;
    gap: var(--space-1);
    min-width: 0;
  }

  .project-name {
    color: var(--ink-900);
    font-weight: 760;
  }

  .project-purpose {
    color: var(--ink-500);
    font-size: var(--step--1);
    font-weight: 620;
  }

  .task-row {
    grid-template-columns: minmax(9rem, 0.9fr) minmax(0, 1.6fr) auto;
    align-items: start;
  }

  .task-id {
    color: var(--ink-500);
    font-family: var(--font-mono);
    font-size: var(--step--1);
    font-weight: 740;
  }

  .task-action {
    color: var(--ink-700);
    font-weight: 650;
  }

  .integration-row {
    grid-template-columns: 1.1fr 1.4fr auto;
    align-items: start;
  }

  .gate-row {
    grid-template-columns: 2rem minmax(0, 1fr);
    align-items: start;
  }

  .gate-step {
    width: 2rem;
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    border: 1px solid var(--state-line);
    border-radius: 999px;
    background: var(--state-soft);
    color: var(--state-color);
    font-family: var(--font-mono);
    font-size: var(--step--1);
    font-weight: 820;
  }

  .flowline {
    display: grid;
    grid-template-columns: repeat(7, minmax(7rem, 1fr));
    gap: var(--space-2);
    align-items: stretch;
  }

  .flow-node {
    min-height: 5.5rem;
    display: grid;
    align-content: center;
    gap: var(--space-2);
    padding: var(--space-3);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
  }

  .flow-node strong {
    color: var(--ink-900);
    line-height: 1.2;
  }

  .flow-node span {
    color: var(--ink-500);
    font-size: var(--step--1);
    font-weight: 650;
  }

  .template-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-4);
  }

  .template-tile {
    display: grid;
    gap: var(--space-3);
    min-height: 11rem;
    padding: var(--space-4);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
  }

  .token-swatch {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: var(--space-2);
  }

  .swatch {
    min-height: 3rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--swatch);
  }

  .project-shell .brand-mark {
    color: inherit;
    text-decoration: none;
  }

  .project-hero {
    gap: var(--space-5);
  }

  .project-hero > p {
    max-width: 74ch;
    color: var(--ink-700);
    font-size: var(--step-1);
  }

  .subpage-nav {
    position: sticky;
    top: 0;
    z-index: 8;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: var(--space-2);
    padding: var(--space-2);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: rgb(251 250 245 / 82%);
    backdrop-filter: blur(18px);
    box-shadow: var(--shadow-tight);
  }

  .subpage-nav a,
  .project-link-grid a {
    min-height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 0.75rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--ink-700);
    font-size: var(--step--1);
    font-weight: 760;
    text-align: center;
    text-decoration: none;
    transition:
      border-color 180ms ease,
      color 180ms ease,
      transform 180ms ease;
  }

  .subpage-nav a:hover,
  .project-link-grid a:hover {
    border-color: var(--state-line);
    color: var(--state-color);
    transform: translateY(-1px);
  }

  .project-link-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-3);
  }

  .public-site {
    min-height: 100vh;
    overflow-x: clip;
  }

  .glass-layer {
    border: 1px solid rgb(255 255 255 / 46%);
    background:
      linear-gradient(180deg, rgb(255 250 242 / 78%), rgb(237 232 224 / 58%));
    backdrop-filter: blur(18px) saturate(132%);
    box-shadow: var(--shadow-tight);
  }

  .public-nav {
    position: sticky;
    top: var(--space-4);
    z-index: 12;
    width: min(calc(100% - var(--space-6)), 78rem);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-4);
    margin: var(--space-4) auto 0;
    padding: var(--space-3);
    border-radius: var(--radius-lg);
    min-width: 0;
  }

  .public-nav-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: var(--space-2);
  }

  .public-nav-links a,
  .primary-action,
  .secondary-action,
  .state-card-actions a {
    min-height: 2.45rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 0.8rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    font-size: var(--step--1);
    font-weight: 780;
    line-height: 1.16;
    overflow-wrap: anywhere;
    text-align: center;
    transition:
      border-color 180ms ease,
      color 180ms ease,
      transform 180ms ease,
      box-shadow 180ms ease;
  }

  .public-nav-links a,
  .secondary-action,
  .state-card-actions a {
    background: var(--surface);
    color: var(--ink-700);
  }

  .primary-action {
    border-color: color-mix(in srgb, var(--teal) 42%, white);
    background:
      linear-gradient(145deg, color-mix(in srgb, var(--teal) 88%, white), var(--green));
    color: white;
    box-shadow:
      inset 0 1px 0 rgb(255 255 255 / 38%),
      0 14px 32px rgb(216 92 31 / 12%);
  }

  .compact-action {
    width: fit-content;
  }

  .public-nav-links a:hover,
  .secondary-action:hover,
  .state-card-actions a:hover {
    border-color: var(--state-line);
    color: var(--state-color);
    transform: translateY(-1px);
  }

  .primary-action:hover {
    transform: translateY(-1px);
    box-shadow:
      inset 0 1px 0 rgb(255 255 255 / 46%),
      0 18px 38px rgb(216 92 31 / 14%);
  }

  .public-main {
    width: min(calc(100% - var(--space-6)), 78rem);
    display: grid;
    gap: var(--space-7);
    margin: 0 auto;
    padding: var(--space-7) 0 var(--space-9);
  }

  .public-hero {
    min-height: min(42rem, calc(100vh - 7rem));
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(19rem, 0.7fr);
    align-items: center;
    gap: var(--space-7);
  }

  .public-hero--landing {
    min-height: min(44rem, calc(100vh - 7rem));
    grid-template-columns: minmax(0, 1.02fr) minmax(22rem, 0.98fr);
  }

  .hero-copy {
    display: grid;
    gap: var(--space-5);
    align-content: center;
    min-width: 0;
  }

  .hero-copy h1 {
    max-width: 13ch;
    font-size: 4.8rem;
    overflow-wrap: anywhere;
  }

  .hero-copy p {
    max-width: 56ch;
    color: var(--ink-700);
    font-size: var(--step-2);
  }

  .hero-orientation {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-3);
    max-width: 44rem;
  }

  .orientation-pill {
    min-width: 0;
    display: grid;
    gap: var(--space-2);
    padding: var(--space-4);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background:
      linear-gradient(145deg, rgb(255 250 242 / 88%), rgb(229 224 216 / 62%));
  }

  .orientation-pill strong {
    color: var(--ink-900);
    font-size: var(--step--1);
    font-weight: 820;
  }

  .orientation-pill span {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 650;
    overflow-wrap: anywhere;
  }

  .hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    align-items: center;
    min-width: 0;
  }

  .hero-route-choices {
    display: grid;
    gap: var(--space-3);
    max-width: 46rem;
  }

  .hero-route-choices > span {
    color: var(--ink-500);
    font-size: var(--step--2);
    font-weight: 820;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .hero-route-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-3);
  }

  .hero-route-grid a {
    min-width: 0;
    display: grid;
    gap: var(--space-1);
    min-height: 4.6rem;
    padding: var(--space-3);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--ink-700);
    transition:
      border-color 180ms ease,
      color 180ms ease,
      transform 180ms ease,
      box-shadow 180ms ease;
  }

  .hero-route-grid a:hover {
    border-color: color-mix(in srgb, var(--teal) 28%, var(--line));
    color: var(--teal);
    transform: translateY(-1px);
    box-shadow: var(--shadow-tight);
  }

  .hero-route-grid strong {
    min-width: 0;
    color: inherit;
    font-size: var(--step--1);
    font-weight: 820;
    line-height: 1.18;
    overflow-wrap: anywhere;
  }

  .hero-route-grid small {
    min-width: 0;
    color: var(--ink-500);
    font-size: 0.76rem;
    font-weight: 680;
    line-height: 1.25;
    overflow-wrap: anywhere;
  }

  .hero-status {
    min-height: auto;
  }

  .status-stack {
    display: grid;
    gap: var(--space-3);
  }

  .state-line {
    min-width: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--space-3);
    align-items: center;
    padding: var(--space-3);
    border: 1px solid var(--state-line);
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--state-soft) 54%, var(--surface));
  }

  .state-line span {
    min-width: 0;
    color: var(--ink-600);
    font-weight: 700;
    overflow-wrap: anywhere;
  }

  .state-line strong {
    min-width: 0;
    justify-self: end;
    color: var(--state-color);
    font-size: var(--step--1);
    overflow-wrap: anywhere;
    text-align: right;
    text-transform: uppercase;
  }

  .public-section,
  .section-heading {
    display: grid;
    gap: var(--space-4);
  }

  .section-heading {
    max-width: 54rem;
  }

  .service-path-grid,
  .state-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-5);
  }

  .service-path-card,
  .state-card {
    display: grid;
    align-content: start;
    gap: var(--space-4);
    min-width: 0;
    min-height: 15rem;
    padding: var(--space-5);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background:
      linear-gradient(145deg, rgb(255 250 242 / 92%), rgb(229 224 216 / 72%));
    box-shadow: var(--shadow-tight);
  }

  .service-path-card {
    border-left: 0.32rem solid var(--state-color);
  }

  .service-path-card h3,
  .state-card h2 {
    color: var(--ink-900);
  }

  .service-path-card p,
  .state-card p {
    color: var(--ink-600);
    overflow-wrap: anywhere;
  }

  .public-flowline {
    grid-template-columns: repeat(auto-fit, minmax(min(9.5rem, 100%), 1fr));
  }

  .public-hero--service {
    min-height: min(34rem, calc(100vh - 7rem));
  }

  .public-hero--solo {
    grid-template-columns: minmax(0, 1fr);
    min-height: min(27rem, calc(100vh - 7rem));
  }

  .public-hero--solo .hero-copy {
    max-width: 58rem;
  }

  .public-hero--service .hero-copy h1 {
    max-width: 14ch;
    font-size: 4.25rem;
  }

  .availability-page .public-hero--solo {
    min-height: min(36rem, calc(100vh - 7rem));
    align-items: end;
    padding-block: var(--space-4) var(--space-3);
  }

  .availability-page .hero-copy {
    max-width: 72rem;
  }

  .availability-page .hero-copy h1 {
    max-width: 15ch;
    font-size: clamp(3.15rem, 7.2vw, 5.35rem);
    line-height: 0.98;
  }

  .availability-page .hero-copy p {
    max-width: 62ch;
  }

  .availability-page .hero-orientation {
    max-width: 42rem;
  }

  .availability-page .orientation-pill {
    border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
    background:
      linear-gradient(145deg, rgb(255 250 242 / 94%), rgb(232 239 238 / 74%));
  }

  .availability-page .hero-route-choices {
    max-width: 50rem;
  }

  .availability-page .hero-route-grid a {
    background:
      linear-gradient(145deg, rgb(255 255 255 / 80%), rgb(255 250 242 / 70%));
  }

  .public-hero-card {
    align-self: center;
  }

  .public-hero-visual {
    align-self: center;
    min-width: 0;
  }

  .public-hero-media {
    align-self: center;
    min-width: 0;
  }

  .hero-media-frame {
    position: relative;
    min-width: 0;
    min-height: clamp(28rem, 48vw, 36rem);
    margin: 0;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--teal) 18%, var(--line));
    border-radius: var(--radius-md);
    background:
      linear-gradient(145deg, rgb(255 250 242 / 90%), rgb(229 224 216 / 74%));
    box-shadow: var(--shadow-soft);
  }

  .hero-media-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(180deg, rgb(17 19 18 / 0%) 46%, rgb(17 19 18 / 52%) 100%),
      linear-gradient(90deg, rgb(255 250 242 / 22%), rgb(255 250 242 / 0%) 36%);
    pointer-events: none;
  }

  .hero-media-frame img {
    width: 100%;
    height: 100%;
    min-height: inherit;
    object-fit: cover;
  }

  .arrival-map {
    position: absolute;
    z-index: 1;
    right: var(--space-4);
    bottom: var(--space-4);
    left: var(--space-4);
    display: grid;
    gap: var(--space-3);
    margin: 0;
    padding: var(--space-4);
    border: 1px solid rgb(255 255 255 / 48%);
    border-radius: var(--radius-sm);
    background: rgb(255 250 242 / 86%);
    backdrop-filter: blur(14px) saturate(128%);
  }

  .arrival-step {
    min-width: 0;
    display: grid;
    grid-template-columns: minmax(4.5rem, auto) minmax(0, 1fr);
    gap: var(--space-3);
    align-items: start;
  }

  .arrival-step strong {
    color: var(--teal);
    font-size: var(--step--1);
    font-weight: 840;
  }

  .arrival-step span {
    color: var(--ink-700);
    font-size: var(--step--1);
    font-weight: 680;
    overflow-wrap: anywhere;
  }

  .service-desk-visual {
    display: grid;
    gap: var(--space-4);
    padding: var(--space-5);
    border: 1px solid color-mix(in srgb, var(--teal) 18%, var(--line));
    border-radius: var(--radius-md);
    background:
      linear-gradient(90deg, rgb(216 92 31 / 5%) 1px, transparent 1px) 0 0 / 3.25rem 3.25rem,
      linear-gradient(0deg, rgb(64 87 178 / 4%) 1px, transparent 1px) 0 0 / 3.25rem 3.25rem,
      linear-gradient(145deg, rgb(255 250 242 / 90%), rgb(229 224 216 / 74%));
    box-shadow: var(--shadow-soft);
  }

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

  .desk-visual-header strong {
    display: inline-flex;
    min-height: 2rem;
    align-items: center;
    padding: 0.35rem 0.65rem;
    border: 1px solid color-mix(in srgb, var(--indigo) 24%, var(--line));
    border-radius: 999px;
    background: color-mix(in srgb, var(--indigo-soft) 56%, var(--surface));
    color: var(--indigo);
    font-size: var(--step--2);
    font-weight: 820;
    text-transform: uppercase;
  }

  .route-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .route-chip {
    display: inline-flex;
    min-height: 2.1rem;
    align-items: center;
    padding: 0.35rem 0.65rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface);
    color: var(--ink-700);
    font-size: var(--step--2);
    font-weight: 780;
    line-height: 1.12;
    overflow-wrap: anywhere;
  }

  .route-chip[data-service="fdw_import"],
  .route-chip[data-service="fdw_transfer"] {
    border-color: color-mix(in srgb, var(--teal) 28%, var(--line));
    color: var(--teal);
  }

  .route-chip[data-service="direct_hire"] {
    border-color: color-mix(in srgb, var(--indigo) 24%, var(--line));
    background: color-mix(in srgb, var(--indigo-soft) 54%, var(--surface));
    color: var(--indigo);
  }

  .route-chip[data-service="insurance_bond"] {
    border-color: color-mix(in srgb, var(--green) 28%, var(--line));
    background: color-mix(in srgb, var(--green-soft) 58%, var(--surface));
    color: var(--green);
  }

  .desk-ticket {
    display: grid;
    gap: var(--space-2);
    padding: var(--space-4);
    border: 1px solid color-mix(in srgb, var(--amber) 30%, var(--line));
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--amber-soft) 54%, var(--surface));
  }

  .desk-ticket span {
    color: var(--ink-500);
    font-size: var(--step--2);
    font-weight: 820;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .desk-ticket strong {
    color: var(--ink-800);
    font-size: var(--step--1);
    overflow-wrap: anywhere;
  }

  .trust-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-4);
  }

  .trust-item,
  .info-list-item {
    display: grid;
    gap: var(--space-2);
    padding: var(--space-4);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface);
    box-shadow: var(--shadow-tight);
  }

  .trust-item strong {
    color: var(--ink-900);
    font-weight: 780;
  }

  .trust-item span,
  .info-list-item p {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 650;
  }

  a.service-path-card {
    color: inherit;
    text-decoration: none;
    transition:
      border-color 180ms ease,
      transform 180ms ease,
      box-shadow 180ms ease;
  }

  a.service-path-card:hover {
    border-color: var(--state-line);
    transform: translateY(-1px);
    box-shadow: var(--shadow-soft);
  }

  .info-list-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
  }

  .intake-blueprint {
    gap: var(--space-5);
  }

  .intake-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-4);
  }

  .intake-field {
    display: grid;
    align-content: start;
    gap: var(--space-3);
    min-width: 0;
    min-height: 13rem;
    padding: var(--space-4);
    border: 1px solid var(--state-line);
    border-radius: var(--radius-sm);
    background:
      linear-gradient(145deg, color-mix(in srgb, var(--state-soft) 42%, var(--surface)), var(--surface-muted));
    box-shadow: var(--shadow-tight);
  }

  .intake-field h3 {
    color: var(--ink-900);
  }

  .intake-field p {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 650;
    overflow-wrap: anywhere;
  }

  .availability-stats {
    gap: var(--space-5);
  }

  .availability-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-4);
  }

  .availability-stat {
    display: grid;
    align-content: start;
    gap: var(--space-3);
    min-width: 0;
    min-height: 11.25rem;
    padding: var(--space-4);
    border: 1px solid var(--state-line);
    border-radius: var(--radius-sm);
    background:
      linear-gradient(145deg, color-mix(in srgb, var(--state-soft) 46%, var(--surface)), var(--surface));
    box-shadow: var(--shadow-tight);
  }

  .availability-stat strong {
    color: var(--ink-900);
    font-size: var(--step-4);
    font-weight: 820;
    line-height: 1;
    overflow-wrap: anywhere;
  }

  .availability-stat p {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 650;
    overflow-wrap: anywhere;
  }

  .availability-shortlist-panel {
    display: grid;
    gap: var(--space-5);
    padding: clamp(var(--space-5), 4vw, var(--space-7));
    border: 1px solid color-mix(in srgb, var(--teal) 24%, var(--line));
    border-radius: var(--radius-md);
    background:
      linear-gradient(135deg, rgb(47 92 136 / 10%), transparent 42%),
      linear-gradient(145deg, rgb(255 250 242 / 94%), rgb(229 224 216 / 68%));
    box-shadow: var(--shadow-tight);
  }

  .availability-guidance-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-4);
  }

  .availability-guidance-card {
    min-width: 0;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    gap: var(--space-2) var(--space-3);
    padding-top: var(--space-3);
    border-top: 1px solid color-mix(in srgb, var(--teal) 24%, var(--line));
  }

  .availability-guidance-card > span {
    display: inline-grid;
    place-items: center;
    width: 2rem;
    aspect-ratio: 1;
    border-radius: 999px;
    background: var(--teal);
    color: white;
    font-size: var(--step--1);
    font-weight: 840;
    line-height: 1;
  }

  .availability-guidance-card h3 {
    color: var(--ink-900);
    font-size: var(--step-1);
  }

  .availability-guidance-card p {
    grid-column: 2;
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 660;
    overflow-wrap: anywhere;
  }

  .availability-roster {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(34rem, 100%), 1fr));
    gap: var(--space-5);
  }

  .availability-card {
    position: relative;
    display: grid;
    gap: var(--space-4);
    min-width: 0;
    padding: clamp(var(--space-4), 3vw, var(--space-5));
    border: 1px solid var(--line);
    border-top: 0.32rem solid var(--state-color);
    border-radius: var(--radius-md);
    background:
      linear-gradient(145deg, rgb(255 250 242 / 96%), rgb(232 226 216 / 74%));
    box-shadow: var(--shadow-tight);
    transition:
      border-color 180ms ease,
      box-shadow 180ms ease,
      transform 180ms ease;
  }

  .availability-card:hover {
    border-color: color-mix(in srgb, var(--state-color) 35%, var(--line));
    box-shadow:
      var(--shadow-soft),
      inset 0 1px 0 rgb(255 255 255 / 48%);
    transform: translateY(-2px);
  }

  .availability-card[data-freshness="needs_reconfirmation"] {
    --state-color: var(--indigo);
    --state-soft: var(--indigo-soft);
    --state-line: color-mix(in srgb, var(--indigo) 28%, white);
  }

  .availability-card-main {
    display: grid;
    grid-template-columns: minmax(6.75rem, 8.75rem) minmax(0, 1fr);
    gap: var(--space-4);
    align-items: start;
    min-width: 0;
  }

  .availability-avatar {
    width: min(8.75rem, 100%);
    aspect-ratio: 1;
    height: auto;
    border: 1px solid color-mix(in srgb, var(--state-color) 24%, var(--line));
    border-radius: var(--radius-md);
    background: var(--surface);
    box-shadow: var(--shadow-tight);
    object-fit: contain;
  }

  .availability-profile-copy,
  .availability-drawer-grid {
    display: grid;
    gap: var(--space-4);
    min-width: 0;
  }

  .availability-card-header,
  .availability-card-actions,
  .availability-chip-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    min-width: 0;
  }

  .availability-card-actions {
    padding-top: var(--space-1);
  }

  .availability-profile-copy h3 {
    color: var(--ink-900);
    font-size: var(--step-2);
    line-height: 1.08;
    max-width: 18ch;
  }

  .availability-fit-note {
    margin-top: var(--space-2);
    padding-left: var(--space-3);
    border-left: 0.18rem solid color-mix(in srgb, var(--state-color) 50%, var(--line));
  }

  .availability-fit-note strong {
    color: var(--ink-800);
    font-weight: 820;
  }

  .availability-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-2);
    padding-block: var(--space-3);
    border-block: 1px solid color-mix(in srgb, var(--state-color) 18%, var(--line));
  }

  .availability-facts div {
    min-width: 0;
    display: grid;
    gap: var(--space-1);
    padding-right: var(--space-2);
  }

  .availability-facts span {
    color: var(--ink-500);
    font-size: var(--step--1);
    font-weight: 780;
    text-transform: uppercase;
  }

  .availability-facts strong {
    color: var(--ink-800);
    font-size: var(--step--1);
    font-weight: 760;
    overflow-wrap: anywhere;
  }

  .availability-tag {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: 0.32rem 0.62rem;
    border: 1px solid color-mix(in srgb, var(--state-color) 20%, var(--line));
    border-radius: 999px;
    background: color-mix(in srgb, var(--state-soft) 46%, var(--surface));
    color: var(--ink-700);
    font-size: var(--step--1);
    font-weight: 720;
    line-height: 1.12;
    overflow-wrap: anywhere;
  }

  .availability-drawer {
    min-width: 0;
    border-top: 1px solid var(--line);
    padding-top: var(--space-3);
  }

  .availability-drawer summary {
    width: fit-content;
    min-height: 2.35rem;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: 0.45rem 0.72rem;
    border: 1px solid color-mix(in srgb, var(--teal) 24%, var(--line));
    border-radius: 999px;
    background: rgb(255 255 255 / 46%);
    color: var(--teal);
    font-weight: 800;
    cursor: pointer;
    transition:
      background-color 180ms ease,
      border-color 180ms ease;
  }

  .availability-drawer summary::marker {
    color: var(--teal);
  }

  .availability-drawer summary:hover {
    border-color: color-mix(in srgb, var(--teal) 40%, var(--line));
    background: rgb(255 255 255 / 68%);
  }

  .availability-drawer[open] summary {
    margin-bottom: var(--space-3);
  }

  .availability-drawer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding-block: var(--space-3);
    border-block: 1px solid var(--line);
  }

  .availability-drawer-grid > div {
    min-width: 0;
    display: grid;
    align-content: start;
    gap: var(--space-2);
  }

  .availability-drawer-grid p,
  .availability-drawer-note,
  .availability-profile-copy p {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 650;
    overflow-wrap: anywhere;
  }

  .availability-drawer-note {
    margin-top: var(--space-3);
  }

  .availability-experience-breakdown {
    display: grid;
    gap: var(--space-3);
    margin-top: var(--space-4);
    padding-top: var(--space-4);
    border-top: 1px solid var(--line);
  }

  .availability-experience-list {
    display: grid;
    gap: var(--space-3);
  }

  .availability-experience-item {
    display: grid;
    gap: var(--space-3);
    min-width: 0;
    padding: var(--space-4);
    border: 1px solid color-mix(in srgb, var(--state-color) 18%, var(--line));
    border-radius: var(--radius-sm);
    background: rgb(255 255 255 / 36%);
  }

  .availability-experience-item > div:first-child {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--space-2);
    min-width: 0;
  }

  .availability-experience-item strong {
    color: var(--ink-900);
    font-size: var(--step-0);
    font-weight: 820;
    line-height: 1.2;
    overflow-wrap: anywhere;
  }

  .availability-experience-item > div:first-child span {
    color: var(--state-color);
    font-size: var(--step--1);
    font-weight: 820;
    line-height: 1.2;
    overflow-wrap: anywhere;
  }

  .availability-experience-item p,
  .availability-experience-breakdown > p {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 660;
    overflow-wrap: anywhere;
  }

  .info-list-item {
    grid-template-columns: 0.8rem minmax(0, 1fr);
    align-items: start;
  }

  .info-list-item > span {
    width: 0.65rem;
    aspect-ratio: 1;
    margin-top: 0.42rem;
    border-radius: 999px;
    background: var(--teal);
    box-shadow: 0 0 0 0.28rem var(--teal-soft);
  }

  .check-list {
    display: grid;
    gap: var(--space-3);
    padding: 0;
    margin: 0;
    list-style: none;
  }

  .check-list li {
    position: relative;
    min-width: 0;
    padding-left: 1.45rem;
    color: var(--ink-650, var(--ink-600));
    font-weight: 650;
    overflow-wrap: anywhere;
  }

  .check-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.45rem;
    width: 0.55rem;
    aspect-ratio: 1;
    border-radius: 999px;
    background: var(--state-color, var(--teal));
    box-shadow: 0 0 0 0.22rem var(--state-soft, var(--teal-soft));
  }

  .public-boundary {
    min-height: auto;
  }

  .email-template-section {
    gap: var(--space-5);
  }

  .email-template-grid {
    display: grid;
    grid-template-columns: minmax(15rem, 0.42fr) minmax(0, 0.58fr);
    gap: var(--space-5);
    align-items: stretch;
    min-width: 0;
  }

  .email-template-meta,
  .email-template-message {
    min-height: auto;
  }

  .email-template-meta {
    align-content: start;
  }

  .email-template-value {
    color: var(--ink-800);
    font-weight: 760;
    overflow-wrap: anywhere;
  }

  .email-template-box {
    min-width: 0;
    max-width: 100%;
    min-height: 18rem;
    margin: 0;
    padding: var(--space-4);
    border: 1px solid color-mix(in srgb, var(--indigo) 20%, var(--line));
    border-radius: var(--radius-sm);
    background:
      linear-gradient(145deg, color-mix(in srgb, var(--indigo-soft) 20%, var(--surface-muted)), var(--surface));
    color: var(--ink-800);
    box-shadow:
      inset 4px 4px 14px rgb(156 140 122 / 12%),
      inset -4px -4px 16px rgb(255 255 255 / 48%);
    font-family: var(--font-mono);
    font-size: var(--step--1);
    font-weight: 650;
    line-height: 1.65;
    overflow-x: auto;
    overflow-wrap: anywhere;
    white-space: pre-wrap;
  }

  .cta-band {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-5);
    padding: var(--space-5);
    border: 1px solid color-mix(in srgb, var(--teal) 30%, var(--line));
    border-radius: var(--radius-md);
    background:
      linear-gradient(145deg, rgb(216 92 31 / 10%), rgb(64 87 178 / 7%)),
      var(--surface);
    box-shadow: var(--shadow-soft);
    min-width: 0;
  }

  .cta-band > div {
    display: grid;
    gap: var(--space-2);
    min-width: 0;
  }

  .availability-closing-cta {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(17rem, 0.88fr);
    align-items: center;
    gap: clamp(var(--space-5), 4vw, var(--space-8));
    min-width: 0;
    padding: clamp(var(--space-6), 5vw, var(--space-9));
    border: 1px solid color-mix(in srgb, var(--teal) 34%, var(--line));
    border-radius: var(--radius-md);
    background:
      linear-gradient(135deg, rgb(216 92 31 / 18%), transparent 42%),
      linear-gradient(315deg, rgb(64 87 178 / 14%), transparent 48%),
      linear-gradient(145deg, rgb(255 250 242 / 96%), rgb(232 226 216 / 88%));
    box-shadow:
      0 28px 80px rgb(17 19 18 / 10%),
      inset 0 1px 0 rgb(255 255 255 / 58%);
  }

  .availability-closing-cta::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
      linear-gradient(90deg, rgb(216 92 31 / 7%) 1px, transparent 1px) 0 0 / 3.5rem 3.5rem,
      linear-gradient(0deg, rgb(64 87 178 / 6%) 1px, transparent 1px) 0 0 / 3.5rem 3.5rem;
    mask-image: linear-gradient(90deg, black, transparent 82%);
  }

  .availability-closing-copy,
  .availability-closing-action {
    min-width: 0;
    display: grid;
    gap: var(--space-4);
  }

  .availability-closing-copy h2 {
    max-width: 13ch;
    font-size: clamp(2rem, 4.5vw, 3.85rem);
    line-height: 1.04;
  }

  .availability-closing-copy p {
    max-width: 58ch;
    color: var(--ink-700);
    font-size: var(--step-2);
  }

  .availability-closing-pills {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    min-width: 0;
  }

  .availability-closing-pills span {
    display: inline-flex;
    align-items: center;
    min-height: 2.25rem;
    padding: 0.45rem 0.72rem;
    border: 1px solid color-mix(in srgb, var(--teal) 24%, var(--line));
    border-radius: 999px;
    background: rgb(255 255 255 / 52%);
    color: var(--ink-700);
    font-size: var(--step--1);
    font-weight: 780;
    line-height: 1.12;
  }

  .availability-closing-action {
    justify-items: start;
    padding: var(--space-5);
    border: 1px solid rgb(255 255 255 / 54%);
    border-radius: var(--radius-sm);
    background: rgb(255 250 242 / 72%);
    box-shadow:
      inset 0 1px 0 rgb(255 255 255 / 64%),
      0 18px 42px rgb(17 19 18 / 7%);
  }

  .availability-closing-action strong {
    color: var(--teal);
    font-size: var(--step-2);
    font-weight: 840;
    line-height: 1.15;
    overflow-wrap: anywhere;
  }

  .availability-closing-action .primary-action {
    min-height: 3.25rem;
    padding: 0.78rem 1.05rem;
    font-size: var(--step-1);
  }

  .availability-closing-action p {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 680;
    overflow-wrap: anywhere;
  }

  .public-footer {
    width: min(calc(100% - var(--space-6)), 78rem);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-4);
    margin: 0 auto var(--space-6);
    padding: var(--space-4);
    border-top: 1px solid var(--line);
  }

  .public-footer-links {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    justify-content: flex-end;
  }

  .public-footer-links a {
    color: var(--ink-600);
    font-size: var(--step--1);
    font-weight: 760;
  }

  .public-footer-links a:hover {
    color: var(--teal);
  }

  .project-state-shell .surface-panel[data-template="cockpit"] {
    border-color: color-mix(in srgb, var(--teal) 24%, var(--line));
  }

  .state-card {
    border-left: 0.35rem solid var(--project-color, var(--state-color));
  }

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

  .state-facts {
    display: grid;
    gap: var(--space-2);
    margin: 0;
  }

  .state-facts div {
    display: grid;
    grid-template-columns: 7.25rem minmax(0, 1fr);
    gap: var(--space-3);
    padding-top: var(--space-2);
    border-top: 1px solid var(--line);
  }

  .state-facts dt {
    color: var(--ink-500);
    font-size: var(--step--1);
    font-weight: 780;
    text-transform: uppercase;
  }

  .state-facts dd {
    margin: 0;
    color: var(--ink-700);
    font-weight: 660;
  }

  .state-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: auto;
  }
}

@layer states {
  [data-state="active"],
  [data-status="active"],
  [data-status="active_core"],
  [data-status="active_foundation"],
  [data-status="active_concurrent"],
  [data-status="connected_live_state_route"] {
    --state-color: var(--teal);
    --state-soft: var(--teal-soft);
    --state-line: color-mix(in srgb, var(--teal) 32%, white);
  }

  [data-state="complete"],
  [data-status="complete"],
  [data-status="harvested"],
  [data-status="proof_passed_review_pending"] {
    --state-color: var(--green);
    --state-soft: var(--green-soft);
    --state-line: color-mix(in srgb, var(--green) 30%, white);
  }

  [data-state="review"],
  [data-status="complete_review_pending"],
  [data-status="proof_mode"],
  [data-status="proof_pending"],
  [data-status="static_protocol_kernel"] {
    --state-color: var(--amber);
    --state-soft: var(--amber-soft);
    --state-line: color-mix(in srgb, var(--amber) 34%, white);
  }

  [data-state="blocked"],
  [data-status="blocked"] {
    --state-color: var(--rose);
    --state-soft: var(--rose-soft);
    --state-line: color-mix(in srgb, var(--rose) 30%, white);
  }

  [data-state="planned"],
  [data-status="info"],
  [data-status="planned"],
  [data-status="pending"],
  [data-status="pipeline"],
  [data-status="coming_soon"],
  [data-status="later"] {
    --state-color: var(--indigo);
    --state-soft: var(--indigo-soft);
    --state-line: color-mix(in srgb, var(--indigo) 28%, white);
  }

  [data-state="deferred"],
  [data-status="deferred"] {
    --state-color: var(--violet);
    --state-soft: var(--violet-soft);
    --state-line: color-mix(in srgb, var(--violet) 28%, white);
  }
}

@layer templates {
  [data-project="P0"] {
    --project-color: var(--teal);
    --project-soft: var(--teal-soft);
  }

  [data-project="P1"] {
    --project-color: var(--green);
    --project-soft: var(--green-soft);
  }

  [data-project="P2"] {
    --project-color: var(--indigo);
    --project-soft: var(--indigo-soft);
  }

  [data-project="P3"] {
    --project-color: var(--amber);
    --project-soft: var(--amber-soft);
  }

  [data-project="P4"] {
    --project-color: var(--rose);
    --project-soft: var(--rose-soft);
  }

  [data-project="P5"] {
    --project-color: var(--violet);
    --project-soft: var(--violet-soft);
  }

  .surface-panel[data-template="cockpit"] {
    background:
      linear-gradient(160deg, rgb(216 92 31 / 8%), transparent 48%),
      var(--surface);
  }

  .surface-panel[data-template="ratification"] {
    border-color: color-mix(in srgb, var(--amber) 34%, var(--line));
  }

  .surface-panel[data-template="proof"] {
    border-color: color-mix(in srgb, var(--green) 26%, var(--line));
  }
}

@layer utilities {
  .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .muted {
    color: var(--ink-500);
  }

  .strong {
    color: var(--ink-900);
    font-weight: 760;
  }
}

@container (max-width: 34rem) {
  .project-row,
  .task-row,
  .integration-row {
    grid-template-columns: 1fr;
  }

  a.project-row::after {
    justify-self: start;
  }

  .project-id {
    font-size: var(--step-0);
  }
}

@media (max-width: 1180px) {
  .os-shell {
    grid-template-columns: 1fr;
  }

  .os-rail {
    position: static;
    height: auto;
    grid-template-columns: 1fr;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .nav-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .plane-grid {
    grid-template-columns: 1fr;
  }

  .plane-grid > * {
    grid-column: 1 / -1;
    min-width: 0;
  }

  .span-8,
  .span-6,
  .span-4,
  .span-3,
  .span-12 {
    grid-column: 1 / -1;
  }

  .kpi-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .flowline,
  .template-grid,
  .project-link-grid,
  .service-path-grid,
  .trust-strip,
  .availability-guidance-grid,
  .availability-stat-grid,
  .availability-roster,
  .info-list-grid,
  .email-template-grid,
  .intake-grid,
  .state-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .os-command,
  .surface-panel,
  .project-row,
  .task-row,
  .integration-row,
  .gate-row,
  .flow-node {
    max-width: 100%;
  }

  .os-command p,
  .surface-panel p,
  .project-name,
  .project-purpose,
  .task-action,
  .integration-row span,
  .flow-node span {
    overflow-wrap: anywhere;
  }

  .public-hero {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .hero-copy h1 {
    max-width: 16ch;
  }
}

@media (max-width: 900px) {
  .split {
    align-items: flex-start;
    flex-direction: column;
  }

  .flowline,
  .template-grid,
  .project-link-grid,
  .service-path-grid,
  .trust-strip,
  .availability-guidance-grid,
  .availability-stat-grid,
  .availability-roster,
  .availability-facts,
  .availability-drawer-grid,
  .hero-orientation,
  .hero-route-grid,
  .info-list-grid,
  .email-template-grid,
  .intake-grid,
  .state-card-grid,
  .public-flowline {
    grid-template-columns: 1fr;
  }

  .public-nav {
    grid-template-columns: 1fr;
  }

  .public-nav-links {
    justify-content: flex-start;
  }

  .cta-band,
  .availability-closing-cta,
  .public-footer {
    grid-template-columns: 1fr;
  }

  .availability-closing-copy h2 {
    max-width: 16ch;
  }

  .public-footer-links {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .public-nav,
  .public-main,
  .public-footer {
    width: min(calc(100% - clamp(var(--space-7), 7vw, var(--space-8))), 78rem);
  }

  .os-command {
    grid-template-columns: 1fr;
  }

  .command-actions {
    justify-content: flex-start;
  }

  .nav-list,
  .flowline,
  .template-grid,
  .subpage-nav,
  .project-link-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kpi {
    min-height: 6.35rem;
    padding: var(--space-4);
  }

  .kpi-value {
    font-size: var(--step-3);
  }

  .nav-link {
    grid-template-columns: 1.2rem minmax(0, 1fr);
    align-content: center;
    min-height: 3rem;
  }

  .nav-link .meta {
    grid-column: 2;
    justify-self: start;
    font-size: 0.68rem;
  }

  .subpage-nav a,
  .project-link-grid a {
    min-height: 2.85rem;
  }
}

@media (max-width: 480px) {
  .nav-list,
  .kpi-strip,
  .subpage-nav,
  .project-link-grid,
  .service-path-grid,
  .availability-guidance-grid,
  .availability-stat-grid,
  .availability-roster,
  .availability-facts,
  .availability-drawer-grid,
  .intake-grid,
  .state-card-grid,
  .public-flowline {
    grid-template-columns: 1fr;
  }

  .surface-panel {
    padding: var(--space-4);
  }

  .data-table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  .public-nav,
  .public-main,
  .public-footer {
    width: min(calc(100% - clamp(var(--space-7), 9vw, var(--space-8))), 78rem);
  }

  .public-nav {
    gap: var(--space-2);
    padding: var(--space-2);
  }

  .public-nav-links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-2);
  }

  .public-nav-links a {
    min-height: 2.15rem;
    padding: 0.42rem 0.52rem;
  }

  .public-main {
    gap: var(--space-5);
    padding-top: var(--space-5);
  }

  .public-hero {
    gap: var(--space-4);
  }

  .hero-copy {
    gap: var(--space-4);
  }

  .hero-copy h1 {
    font-size: 2.55rem;
  }

  .public-hero--landing .hero-copy h1 {
    font-size: 2.75rem;
  }

  .public-hero--service .hero-copy h1 {
    font-size: 2.55rem;
  }

  .availability-closing-cta {
    padding: var(--space-5);
  }

  .availability-closing-copy h2 {
    font-size: 2.15rem;
  }

  .availability-closing-copy p {
    font-size: var(--step-1);
  }

  .availability-closing-action {
    padding: var(--space-4);
  }

  .availability-card {
    padding: var(--space-4);
  }

  .availability-card-main {
    grid-template-columns: 1fr;
  }

  .availability-avatar {
    width: min(11rem, 100%);
  }

  .hero-orientation {
    display: none;
  }

  .hero-route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-2);
  }

  .orientation-pill,
  .hero-route-grid a,
  .arrival-map {
    padding: var(--space-3);
  }

  .hero-route-grid a {
    min-height: 4.15rem;
  }

  .hero-route-grid small {
    font-size: 0.68rem;
  }

  .hero-media-frame {
    min-height: 23rem;
  }

  .arrival-map {
    right: var(--space-3);
    bottom: var(--space-3);
    left: var(--space-3);
  }

  .arrival-step {
    grid-template-columns: 1fr;
    gap: var(--space-1);
  }

  .service-desk-visual {
    gap: var(--space-3);
    padding: var(--space-4);
  }

  .service-desk-visual .state-line {
    grid-template-columns: 1fr;
    gap: var(--space-2);
    padding: 0.72rem 0.82rem;
  }

  .service-desk-visual .state-line strong {
    justify-self: start;
    text-align: left;
  }

  .service-desk-visual .desk-ticket {
    display: none;
  }

  .route-chip {
    min-height: 1.9rem;
    padding: 0.25rem 0.52rem;
  }

  .state-line,
  .state-facts div {
    grid-template-columns: 1fr;
  }

  .service-desk-visual .state-line {
    grid-template-columns: 1fr;
  }
}
