/*!*************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./app/globals.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************/
/*! tailwindcss v4.2.4 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
    --font-mono: var(--font-geist-mono);
    --color-neutral-600: oklch(43.9% 0 0);
    --color-neutral-900: oklch(20.5% 0 0);
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-xl: 36rem;
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --font-weight-light: 300;
    --tracking-tight: -0.025em;
    --tracking-wide: 0.025em;
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-geist-sans);
    --default-mono-font-family: var(--font-geist-mono);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .collapse {
    visibility: collapse;
  }
  .visible {
    visibility: visible;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .sticky {
    position: sticky;
  }
  .start {
    inset-inline-start: var(--spacing);
  }
  .end {
    inset-inline-end: var(--spacing);
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .table {
    display: table;
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .max-w-xl {
    max-width: var(--container-xl);
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .items-center {
    align-items: center;
  }
  .justify-center {
    justify-content: center;
  }
  .space-y-6 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-neutral-900 {
    border-color: var(--color-neutral-900);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .text-center {
    text-align: center;
  }
  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--line-height));
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .font-light {
    --tw-font-weight: var(--font-weight-light);
    font-weight: var(--font-weight-light);
  }
  .tracking-tight {
    --tw-tracking: var(--tracking-tight);
    letter-spacing: var(--tracking-tight);
  }
  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }
  .text-neutral-600 {
    color: var(--color-neutral-600);
  }
  .uppercase {
    text-transform: uppercase;
  }
  .italic {
    font-style: italic;
  }
  .tabular-nums {
    --tw-numeric-spacing: tabular-nums;
    font-variant-numeric: var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,);
  }
  .underline {
    text-decoration-line: underline;
  }
  .filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }
  .hover\:bg-neutral-900 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-neutral-900);
      }
    }
  }
  .hover\:text-white {
    &:hover {
      @media (hover: hover) {
        color: var(--color-white);
      }
    }
  }
}
:root {
  --background: #ffffff;
  --foreground: #171717;
}
@media (prefers-color-scheme: dark) {
  :root {
    --background: #0a0a0a;
    --foreground: #ededed;
  }
}
body {
  background: var(--background);
  color: var(--foreground);
  font-family: Arial, Helvetica, sans-serif;
}
@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.55;
  }
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-tracking {
  syntax: "*";
  inherits: false;
}
@property --tw-ordinal {
  syntax: "*";
  inherits: false;
}
@property --tw-slashed-zero {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-figure {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-spacing {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-fraction {
  syntax: "*";
  inherits: false;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-border-style: solid;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-ordinal: initial;
      --tw-slashed-zero: initial;
      --tw-numeric-figure: initial;
      --tw-numeric-spacing: initial;
      --tw-numeric-fraction: initial;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-ease: initial;
    }
  }
}

/*!***************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./styles/tokens.css ***!
  \***************************************************************************************************************************************************************************************************************************************************************/
/* ============================================================
   Proxima — design tokens
   The minimum surface the three shared chrome components
   (IdentityHeader, AltitudeBreadcrumb, HistoricalRecordBanner)
   depend on. Import once at app root.
   ============================================================ */

:root {
  /* Neutrals — warm paper */
  --background: oklch(0.985 0.004 80);
  --paper:      oklch(0.975 0.005 80);
  --card:       oklch(0.97 0.004 80);
  --muted:      oklch(0.945 0.005 260);

  /* Ink */
  --foreground:        oklch(0.16 0.01 260);
  --muted-foreground:  oklch(0.46 0.01 260);
  --faint:             oklch(0.72 0.01 260);

  /* Rules */
  --border:      oklch(0.88 0.005 260);
  --border-soft: oklch(0.92 0.005 260);
  --rule:        oklch(0.82 0.008 260);

  /* Accent */
  --primary:      oklch(0.52 0.17 30);           /* vermillion — brand mark */
  --primary-soft: oklch(0.52 0.17 30 / 0.12);

  /* Semantic tones used by badges + the historical banner */
  --amber:        oklch(0.72 0.14 70);
  --amber-soft:   oklch(0.72 0.14 70 / 0.18);
  --amber-ink:    oklch(0.38 0.11 60);
  --amber-border: oklch(0.82 0.12 75);

  --violet:        oklch(0.50 0.14 295);
  --violet-soft:   oklch(0.50 0.14 295 / 0.12);
  --violet-ink:    oklch(0.36 0.14 295);
  --violet-border: oklch(0.72 0.10 295);

  /* Type stack — pin per-project via CSS, not per-component */
  --font-sans:  'Geist', 'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-serif: 'Newsreader', Georgia, serif;
  --font-mono:  'JetBrains Mono', ui-monospace, monospace;
}

/* ---- Utility classes used by the shared chrome ---------------------------- */

.serif   { font-family: var(--font-serif); font-weight: 400; }
.serif-i { font-family: var(--font-serif); font-weight: 400; font-style: italic; }
.mono    { font-family: var(--font-mono); }
.tnum    { font-variant-numeric: tabular-nums; }

/* Mono eyebrow — used as section labels and the "Altitude" header */
.up-eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted-foreground);
}

/* Chip — the 10px mono pill. Used for source tags and badges. */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--muted-foreground);
  border-radius: 2px;
}
.chip.ink    { background: transparent; }
.chip.ghost  { color: var(--faint); }
.chip.amber  { background: var(--amber-soft);  border-color: var(--amber-border);  color: var(--amber-ink); }
.chip.violet { background: var(--violet-soft); border-color: var(--violet-border); color: var(--violet-ink); }

/* Ghost button — action rail + pills use this surface */
.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--muted-foreground);
  border-radius: 2px;
  cursor: pointer;
}
.btn-ghost:hover  { color: var(--foreground); border-color: var(--rule); }
.btn-ghost.active { color: var(--foreground); background: var(--muted); }

/*!***************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./styles/shared.css ***!
  \***************************************************************************************************************************************************************************************************************************************************************/
/* ============================================================
   Shared Proxima look — matches product surface (light, warm paper)
   Used by all three career-view artboards.
   ============================================================ */

:root {
  --background: oklch(0.985 0.004 80);
  --paper:      oklch(0.975 0.005 80);
  --foreground: oklch(0.16 0.01 260);
  --card: oklch(0.97 0.004 80);
  --muted: oklch(0.945 0.005 260);
  --muted-foreground: oklch(0.46 0.01 260);
  --faint: oklch(0.72 0.01 260);
  --border: oklch(0.88 0.005 260);
  --border-soft: oklch(0.92 0.005 260);
  --rule: oklch(0.82 0.008 260);
  --primary: oklch(0.52 0.17 30);        /* vermillion */
  --primary-soft: oklch(0.52 0.17 30 / 0.12);
  --violet: oklch(0.50 0.14 295);
  --violet-soft: oklch(0.50 0.14 295 / 0.12);
  --amber: oklch(0.72 0.14 70);
  --amber-soft: oklch(0.72 0.14 70 / 0.18);
  --emerald: oklch(0.55 0.12 155);
  --sky: oklch(0.56 0.12 235);
}

* { box-sizing: border-box; }
.serif   { font-family: 'Newsreader', Georgia, serif; font-weight: 400; }
.serif-i { font-family: 'Newsreader', Georgia, serif; font-weight: 400; font-style: italic; }
.sans    { font-family: 'Geist', 'Inter', ui-sans-serif, system-ui, sans-serif; }
.mono    { font-family: 'JetBrains Mono', ui-monospace, monospace; }

.up-eyebrow {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--muted-foreground);
}
.tnum { font-variant-numeric: tabular-nums; }

/* The design canvas artboards run at 1440×N.  We set the artboard's body-like
   surface via these wrappers so each direction just focuses on content.  */
.cv-page {
  width: 1440px;
  margin-inline: auto;
  background: var(--background);
  color: var(--foreground);
  font-family: 'Geist', 'Inter', ui-sans-serif, system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ----------------------------------------------------------------------
   .cv-section — full-bleed section helper.
   Background, borders, and any inline-set bg/border-bottom/border-top
   on this element extend edge-to-edge regardless of viewport width.
   Content stays centered inside a 1440px column with a 40px minimum
   horizontal gutter.

   Works in two contexts:
     - Direct child of <body> (or any 100vw parent): negative margin = 0,
       horizontal padding centers the content.
     - Child of a centered 1440px wrapper (e.g. .cv-page): negative
       margin pushes the box out to viewport edges; padding centers content.

   Vertical padding should be set inline (paddingTop / paddingBottom).
   Horizontal padding is computed here — do NOT set padding-left/right
   inline, it will override the centering math.
   ---------------------------------------------------------------------- */
.cv-section {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding-left: max(40px, calc(50vw - 720px));
  padding-right: max(40px, calc(50vw - 720px));
}

/* Utility ruler-style borders */
.hr-soft { border-top: 1px solid var(--border-soft); }
.hr { border-top: 1px solid var(--border); }

/* Chips */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 8px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--muted-foreground);
  border-radius: 2px;
}
.chip.amber { background: var(--amber-soft); border-color: oklch(0.82 0.12 75); color: oklch(0.38 0.11 60); }
.chip.violet{ background: var(--violet-soft); border-color: oklch(0.72 0.10 295); color: oklch(0.36 0.14 295); }
.chip.ink   { background: transparent; }
.chip.ghost { color: var(--faint); }

/* Dot glyph used as event marker */
.dot { width: 7px; height: 7px; border-radius: 50%; display:inline-block; background: currentColor; }

/* Scroll/overflow inside the focus view is disabled — these are artboards */
.cv-page, .cv-page * { overflow: visible; }

/* Soft wash used for employer stripes */
.wash-slate   { background: #f2f2ef; }
.wash-wpx     { background: #eef3f7; }
.wash-gap     { background: #f4f1ea; }
.wash-hp      { background: #faeee6; }

/* Tab pills */
.tabs { display:flex; gap: 0; border-bottom: 1px solid var(--border); }
.tabs button {
  appearance:none; border:0; background:transparent;
  font: inherit; color: var(--muted-foreground);
  padding: 10px 16px; border-bottom: 1px solid transparent;
  font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; cursor: pointer;
  margin-bottom: -1px;
}
.tabs button.active { color: var(--foreground); border-bottom-color: var(--foreground); }
.tabs button:hover { color: var(--foreground); }

/* Buttons */
.btn-ghost {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 10px; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  border: 1px solid var(--border); background: var(--card);
  color: var(--muted-foreground); border-radius: 2px; cursor: pointer;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.btn-ghost:hover { color: var(--foreground); border-color: var(--rule); }
.btn-ghost.active { color: var(--foreground); background: var(--muted); }

/* Artboard-level header strip (the 'app header' mimic) */
.app-top {
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 40px; border-bottom: 1px solid var(--border);
  background: var(--paper);
}
.app-top .left { display:flex; align-items:center; gap: 18px; }
.app-top .brand-mark {
  width: 22px; height: 22px; border-radius: 2px; background: var(--primary);
  display:grid; place-items:center; color:white; font-size: 11px; font-weight: 600;
  font-family:'Newsreader',serif;
}
.app-top .wordmark { font-family: 'Newsreader', serif; font-size: 18px; }
.app-top nav { display:flex; gap: 22px; font-size: 12px; color: var(--muted-foreground); }
.app-top nav a { text-decoration:none; color: inherit; }
.app-top nav a.active { color: var(--foreground); }
.app-top .search {
  border: 1px solid var(--border); border-radius: 2px;
  background: var(--card); padding: 6px 10px; color: var(--muted-foreground);
  font-size: 12px; display:flex; align-items:center; gap:8px; min-width: 260px;
}
.app-top .right { display:flex; align-items:center; gap: 12px; }

/* Breadcrumb row */
.bc {
  padding: 12px 40px; font-size: 11px; color: var(--muted-foreground);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  letter-spacing: 0.12em; text-transform: uppercase;
  border-bottom: 1px solid var(--border-soft);
  display:flex; gap: 10px; align-items:center;
}
.bc .sep { color: var(--faint); }
.bc a { color: inherit; text-decoration:none; }
.bc a:hover { color: var(--foreground); }

/* Common tiny stat tile */
.stat {
  display:flex; flex-direction:column; gap: 6px;
  padding: 14px 16px;
  border-right: 1px solid var(--border);
}
.stat:last-child { border-right: 0; }
.stat .lbl { font-family:'JetBrains Mono',monospace; font-size: 10px; letter-spacing:0.16em;
  text-transform: uppercase; color: var(--muted-foreground); }
.stat .v   { font-family:'Newsreader',serif; font-size: 28px; letter-spacing: -0.01em; }
.stat .v small { font-family:'Geist',sans-serif; color: var(--muted-foreground); font-size: 12px; margin-left:6px; }
.stat .sub { font-size: 11px; color: var(--muted-foreground); }

/* Small legend dot + label */
.legend {
  display:flex; gap: 14px; flex-wrap: wrap;
  font-size: 11px; color: var(--muted-foreground);
}
.legend span.sw { width: 10px; height: 10px; display:inline-block; margin-right:6px; border-radius: 2px; vertical-align: middle; }

