/* ================================================================
   WAREX EXCHANGE TERMINAL — APP SURFACE LAYER  (exchange-app.css)
   ================================================================
   Third CSS layer, [WAREX]-ruled 2026-06-10: product/app surfaces
   (load board, portals, dashboards, order detail) load
   fonts → tokens → exchange.css → THIS. Never exchange-pages.css,
   never exchange-bridge.css, never the legacy warex-* cascade.
   Real wx components, no bridged legacy neutrals.

   Namespace: .wxa-  (app). Honesty components (.wxa-banner,
   .wxa-chip--sample) are load-bearing — every product surface
   renders them visibly; honesty copy never sits inside an opacity
   reveal and never drops below 12px.
   ================================================================ */

/* ---- shell parity (app pages skip the bridge, keep its shell) ---- */
.wx-burger--always { display: flex; }
.wx-menu-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--wx-s6); }
.wx-menu-grid ul { margin-bottom: var(--wx-s5); }
@media (max-width: 1023px) { .wx-menu-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 639px)  { .wx-menu-grid { grid-template-columns: 1fr; } }

body.wxa-page { background: var(--wx-ink); color: var(--wx-paper); }

/* ---- demo banner (visible, always, every product surface) -------- */
.wxa-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--wx-s2) var(--wx-s4);
  padding: var(--wx-s3) var(--wx-gutter, var(--wx-s5));
  background: var(--wx-ink-2);
  border-top: 1px solid var(--wx-amber);
  border-bottom: 1px solid var(--wx-hair, var(--wx-ghost));
}
.wxa-banner b {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: var(--wx-track-wide);
  color: var(--wx-amber);
  text-transform: uppercase;
}
.wxa-banner span {
  font-family: var(--wx-font-body);
  font-size: 0.85rem;
  color: var(--wx-dim-hi);
}

/* ---- page scaffold ------------------------------------------------ */
.wxa-wrap { max-width: 1500px; margin: 0 auto; padding: 0 var(--wx-s5); }

.wxa-header { padding: var(--wx-s6) 0 var(--wx-s4) 0; }
.wxa-header h1 {
  font-family: var(--wx-font-display);
  font-weight: 800;
  font-size: var(--wx-disp-lg, clamp(2.2rem, 5vw, 3.4rem));
  line-height: 1;
  text-transform: uppercase;
  margin: 0 0 var(--wx-s2) 0;
}
.wxa-header .wxa-tagline {
  font-family: var(--wx-font-mono);
  font-size: 0.8125rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  color: var(--wx-cyan);
  margin: 0;
}

/* ---- KPI strip ----------------------------------------------------- */
.wxa-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--wx-s3);
  margin: var(--wx-s4) 0;
}
.wxa-kpi {
  position: relative;
  padding: var(--wx-s3) var(--wx-s4);
  background: var(--wx-panel);
  border: 1px solid var(--wx-ghost);
}
.wxa-kpi b {
  display: block;
  font-family: var(--wx-font-mono);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--wx-paper);
}
.wxa-kpi span {
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  color: var(--wx-dim);
}
.wxa-kpi .wxa-chip--sample { position: absolute; top: var(--wx-s2); right: var(--wx-s2); }

/* ---- chips ---------------------------------------------------------- */
.wxa-chip {
  display: inline-block;
  padding: 1px 8px;
  margin: 1px 4px 1px 0;
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--wx-dim-hi);
  border: 1px solid var(--wx-ghost);
  border-radius: 2px;
  white-space: nowrap;
}
.wxa-chip--sample {
  font-size: 0.75rem;                /* honesty floor: never below 12px */
  color: var(--wx-amber);
  border-color: var(--wx-amber);
  font-style: normal;
}
.wxa-chip--space   { color: var(--wx-amber); border-color: var(--wx-amber); }
.wxa-chip--service { color: var(--wx-cyan);  border-color: var(--wx-cyan); }
.wxa-chip--svc     { color: var(--wx-dim-hi); background: var(--wx-ink-2); }
.wxa-chip--prov    { color: var(--wx-dim-hi); }
.wxa-chip--neg     { color: #ff9d8d; border-color: var(--wx-red); } /* red-hi text */

/* ---- rescue strip ---------------------------------------------------- */
.wxa-rescue {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--wx-s4);
  margin: var(--wx-s4) 0;
  padding: var(--wx-s4) var(--wx-s5);
  background: var(--wx-ink-2);
  border: 1px solid var(--wx-amber);
  border-left-width: 4px;
}
.wxa-rescue--critical { border-color: var(--wx-red); }
.wxa-rescue--critical .wxa-count { color: var(--wx-red); }
.wxa-rescue-tag {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: var(--wx-track-wide);
  color: var(--wx-amber);
  margin: 0 0 var(--wx-s2) 0;
}
.wxa-rescue-title {
  font-family: var(--wx-font-body);
  font-weight: 500;
  font-size: 1.15rem;
  margin: 0 0 var(--wx-s1) 0;
  color: var(--wx-paper);
}
.wxa-rescue-meta { font-size: 0.85rem; color: var(--wx-dim-hi); margin: 0 0 var(--wx-s2) 0; }
.wxa-rescue-constraints { margin: 0; }
.wxa-rescue-clock { text-align: right; min-width: 200px; }
.wxa-count {
  font-family: var(--wx-font-mono);
  font-size: 2rem;
  font-weight: 700;
  color: var(--wx-amber);
  margin: 0;
  font-variant-numeric: tabular-nums;
}
.wxa-count-sub {
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  color: var(--wx-dim);
  margin: 0 0 var(--wx-s3) 0;
}

/* ---- time economics strip -------------------------------------------- */
.wxa-econ {
  display: flex;
  flex-wrap: wrap;
  gap: var(--wx-s3);
  margin: 0 0 var(--wx-s4) 0;
}
.wxa-econ p {
  flex: 1 1 260px;
  margin: 0;
  padding: var(--wx-s3) var(--wx-s4);
  border: 1px dashed var(--wx-ghost);
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  line-height: 1.5;
  color: var(--wx-dim-hi);
}
.wxa-econ p b { color: var(--wx-green); font-weight: 700; }

/* ---- layout: rail / board / feed -------------------------------------- */
.wxa-cols {
  display: grid;
  grid-template-columns: 210px minmax(0, 1fr) 250px;
  gap: var(--wx-s5);
  align-items: start;
  padding-bottom: var(--wx-s8);
}

/* filter rail */
.wxa-rail {
  position: sticky;
  top: 84px;
  background: var(--wx-panel);
  border: 1px solid var(--wx-ghost);
  padding: var(--wx-s4);
}
.wxa-rail h2 {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  letter-spacing: var(--wx-track-wide);
  text-transform: uppercase;
  color: var(--wx-faint);
  margin: 0 0 var(--wx-s3) 0;
}
.wxa-rail fieldset { border: 0; padding: 0; margin: 0 0 var(--wx-s4) 0; }
.wxa-rail legend {
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  color: var(--wx-dim);
  margin-bottom: var(--wx-s2);
}
.wxa-rail label {
  display: flex;
  align-items: center;
  gap: var(--wx-s2);
  font-family: var(--wx-font-body);
  font-size: 0.85rem;
  color: var(--wx-dim-hi);
  padding: 2px 0;
  cursor: pointer;
}
.wxa-rail input[type="checkbox"] { accent-color: var(--wx-amber); width: 15px; height: 15px; }
.wxa-rail select,
.wxa-toolbar select {
  width: 100%;
  padding: 6px 8px;
  background: var(--wx-ink-2);
  color: var(--wx-paper);
  border: 1px solid var(--wx-ghost);
  font-family: var(--wx-font-mono);
  font-size: 0.8125rem;
}
.wxa-ghost-btn {
  width: 100%;
  padding: var(--wx-s2);
  background: transparent;
  color: var(--wx-dim-hi);
  border: 1px solid var(--wx-ghost);
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  cursor: pointer;
}
.wxa-ghost-btn:hover { color: var(--wx-paper); border-color: var(--wx-dim); }
.wxa-sheet-btn { display: none; }

/* ---- tabs -------------------------------------------------------------- */
.wxa-tabs {
  display: flex;
  gap: 0;
  overflow-x: auto;
  border-bottom: 1px solid var(--wx-ghost);
  margin-bottom: var(--wx-s3);
}
.wxa-tabs [role="tab"] {
  padding: var(--wx-s2) var(--wx-s3);
  background: none;
  border: 0;
  border-bottom: 2px solid transparent;
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  color: var(--wx-dim);
  cursor: pointer;
  white-space: nowrap;
}
.wxa-tabs [role="tab"][aria-selected="true"] {
  color: var(--wx-amber);
  border-bottom-color: var(--wx-amber);
}
.wxa-tabs [role="tab"]:hover { color: var(--wx-paper); }
.wxa-tab-n {
  display: inline-block;
  min-width: 1.4em;
  margin-left: 4px;
  padding: 0 4px;
  background: var(--wx-ink-2);
  border-radius: 8px;
  font-size: 0.6875rem;
  text-align: center;
}

/* ---- toolbar ------------------------------------------------------------- */
.wxa-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--wx-s3);
  margin-bottom: var(--wx-s3);
}
.wxa-toolbar input[type="search"] {
  flex: 1 1 220px;
  padding: 8px 10px;
  background: var(--wx-ink-2);
  border: 1px solid var(--wx-ghost);
  color: var(--wx-paper);
  font-family: var(--wx-font-mono);
  font-size: 0.8125rem;
}
.wxa-toolbar input[type="search"]::placeholder { color: var(--wx-faint); }
.wxa-toolbar select { width: auto; }
.wxa-count-note {
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  color: var(--wx-dim);
  margin: 0;
}

#wxaBoardWrap { min-width: 0; }
.wxa-tabs { max-width: 100%; }

/* ---- the grid -------------------------------------------------------------- */
.wxa-grid { border: 1px solid var(--wx-ghost); }
.wxa-head, .wxa-row {
  display: grid;
  grid-template-columns: 100px minmax(0, 1fr) 100px 150px 78px 104px;
  gap: var(--wx-s2) var(--wx-s3);
  align-items: start;
  padding: var(--wx-s3) var(--wx-s4);
}

.wxa-c-prov {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  padding-top: var(--wx-s1);
  border-top: 1px dashed var(--wx-ink-2);
}
.wxa-c-type { display: flex; flex-direction: column; align-items: flex-start; gap: 3px; }
.wxa-head {
  background: var(--wx-ink-2);
  border-bottom: 1px solid var(--wx-ghost);
}
.wxa-head [role="columnheader"] {
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  color: var(--wx-faint);
}
.wxa-row { border-bottom: 1px solid var(--wx-ink-2); position: relative; }
.wxa-row:last-child { border-bottom: 0; }
.wxa-row:hover { background: var(--wx-ink-2); }
.wxa-row:focus-visible {
  outline: 2px solid var(--wx-amber);
  outline-offset: -2px;
}
.wxa-row--rescue { border-left: 3px solid var(--wx-amber); }
/* closed rows dim via COLOR, never opacity — contrast scans read
   effective opacity (V2 Director-hold lesson, binding) */
.wxa-row--closed { background: oklch(14% 0.024 262); }
.wxa-row--closed .wxa-title { color: var(--wx-dim-hi); }
.wxa-row--closed .wxa-chip--space,
.wxa-row--closed .wxa-chip--service { color: var(--wx-dim-hi); border-color: var(--wx-ghost); }

.wxa-title { font-family: var(--wx-font-body); font-weight: 500; font-size: 0.98rem; color: var(--wx-paper); margin: 0 0 2px 0; }
.wxa-sub   { font-size: 0.8rem; color: var(--wx-dim-hi); margin: 0 0 4px 0; }
.wxa-svc   { margin: 0; }
.wxa-reason {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  color: #ff9d8d; /* red-hi */
  margin: var(--wx-s2) 0 0 0;
}
.wxa-c-units { font-family: var(--wx-font-body); font-size: 0.85rem; color: var(--wx-dim-hi); }
.wxa-c-units .wxa-num { font-family: var(--wx-font-mono); font-weight: 700; color: var(--wx-paper); }
.wxa-c-units small { display: block; font-size: 0.72rem; color: var(--wx-dim); }
.wxa-c-window { font-family: var(--wx-font-mono); font-size: 0.78rem; color: var(--wx-dim-hi); }
.wxa-dim { color: var(--wx-faint); }

.wxa-rowstate {
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--wx-track-data);
  color: var(--wx-faint);
}
.wxa-rowstate--ok { color: var(--wx-green); }

.wxa-quote-btn {
  padding: 7px 14px;
  background: var(--wx-amber);
  color: var(--wx-ink);
  border: 0;
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: var(--wx-track-data);
  cursor: pointer;
}
.wxa-quote-btn:hover { filter: brightness(1.08); }
.wxa-quote-btn:focus-visible { outline: 2px solid var(--wx-paper); outline-offset: 2px; }
.wxa-quote-btn--big { padding: 11px 20px; font-size: 0.8125rem; }

.wxa-empty [role="gridcell"] {
  grid-column: 1 / -1;
  padding: var(--wx-s6);
  font-family: var(--wx-font-mono);
  font-size: 0.8125rem;
  color: var(--wx-dim-hi);
  text-align: center;
}
.wxa-empty { display: block; }

/* ---- match pill + popover --------------------------------------------------- */
.wxa-match {
  font-family: var(--wx-font-mono);
  font-weight: 700;
  font-size: 0.95rem;
  padding: 4px 9px;
  background: var(--wx-ink-2);
  border: 1px solid;
  cursor: pointer;
  color: var(--wx-paper);
}
.wxa-match small { font-size: 0.65em; color: var(--wx-dim); font-weight: 400; }
.wxa-match--hi  { border-color: var(--wx-green); color: var(--wx-green); }
.wxa-match--mid { border-color: var(--wx-amber); color: var(--wx-amber); }
.wxa-match--low { border-color: var(--wx-red);   color: #ff9d8d; } /* red-hi: 4.5:1 on ink-2 */
.wxa-match[aria-expanded="true"], .wxa-match:hover { background: var(--wx-panel); }

.wxa-pop {
  position: absolute;
  right: var(--wx-s4);
  top: calc(100% - var(--wx-s2));
  z-index: 30;
  width: min(360px, 86vw);
  padding: var(--wx-s4);
  background: var(--wx-panel);
  border: 1px solid var(--wx-dim);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
}
.wxa-pop-head {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  letter-spacing: var(--wx-track-data);
  color: var(--wx-cyan);
  margin: 0 0 var(--wx-s2) 0;
}
.wxa-pop ul { list-style: none; margin: 0 0 var(--wx-s3) 0; padding: 0; }
.wxa-pop li { font-size: 0.85rem; color: var(--wx-dim-hi); padding: 3px 0; }
.wxa-pop li b { font-family: var(--wx-font-mono); margin-right: 6px; }
.wxa-pop li.pos b { color: var(--wx-green); }
.wxa-pop li.neg b { color: var(--wx-red); }
.wxa-pop-foot {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  color: var(--wx-amber);
  margin: 0;
}

/* ---- floor feed rail ----------------------------------------------------------- */
.wxa-feed {
  position: sticky;
  top: 84px;
  background: var(--wx-panel);
  border: 1px solid var(--wx-ghost);
  padding: var(--wx-s4);
}
.wxa-feed-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 0 var(--wx-s3) 0;
}
.wxa-feed-head p {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  letter-spacing: var(--wx-track-wide);
  text-transform: uppercase;
  color: var(--wx-faint);
  margin: 0;
}
.wxa-feed-head p b { color: var(--wx-amber); }
.wxa-feed-pause {
  background: none;
  border: 1px solid var(--wx-ghost);
  color: var(--wx-dim-hi);
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  padding: 3px 8px;
  cursor: pointer;
}
.wxa-feed ul { list-style: none; margin: 0; padding: 0; }
.wxa-feed li {
  font-size: 0.82rem;
  color: var(--wx-dim-hi);
  padding: var(--wx-s2) 0;
  border-bottom: 1px dashed var(--wx-ink-2);
}
.wxa-feed li:last-child { border-bottom: 0; }
.wxa-feed-t {
  display: block;
  font-family: var(--wx-font-mono);
  font-size: 0.6875rem;
  color: var(--wx-faint);
}
.wxa-feed-pending { display: none; }
.wxa-feed-new { animation: wxaFeedIn var(--wx-dur-slow) var(--wx-ease-out); }
@keyframes wxaFeedIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: none; }
}

/* ---- quote composer dialog ----------------------------------------------------- */
.wxa-dialog {
  width: min(680px, 94vw);
  max-height: 86vh;
  background: var(--wx-panel);
  color: var(--wx-paper);
  border: 1px solid var(--wx-dim);
  padding: 0;
}
.wxa-dialog::backdrop { background: rgba(4, 8, 18, 0.78); }
.wxa-comp { padding: var(--wx-s5); }
.wxa-comp header { margin-bottom: var(--wx-s4); }
.wxa-comp-kicker {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  letter-spacing: var(--wx-track-wide);
  color: var(--wx-cyan);
  margin: 0 0 var(--wx-s2) 0;
}
.wxa-comp h2 {
  font-family: var(--wx-font-display);
  font-size: 1.5rem;
  text-transform: uppercase;
  line-height: 1.05;
  margin: 0 0 var(--wx-s1) 0;
}
.wxa-version {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  color: var(--wx-amber);
  border: 1px dashed var(--wx-amber);
  padding: var(--wx-s2) var(--wx-s3);
  margin: var(--wx-s3) 0 0 0;
}
.wxa-comp-groups { max-height: 44vh; overflow-y: auto; padding-right: var(--wx-s2); }
.wxa-comp fieldset { border: 1px solid var(--wx-ghost); padding: var(--wx-s3); margin: 0 0 var(--wx-s3) 0; }
.wxa-comp legend {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  letter-spacing: var(--wx-track-data);
  text-transform: uppercase;
  color: var(--wx-cyan);
  padding: 0 var(--wx-s2);
}
.wxa-line {
  display: flex;
  align-items: center;
  gap: var(--wx-s3);
  padding: 5px 0;
  font-size: 0.88rem;
  color: var(--wx-dim-hi);
}
.wxa-line span { flex: 1; }
.wxa-line b { font-family: var(--wx-font-mono); font-size: 0.78rem; color: var(--wx-paper); white-space: nowrap; }
.wxa-line input { accent-color: var(--wx-amber); width: 15px; height: 15px; }
.wxa-comp-qual {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  color: var(--wx-amber);
  margin: var(--wx-s3) 0;
}
.wxa-comp footer { display: flex; gap: var(--wx-s3); justify-content: flex-end; }
.wxa-comp footer .wxa-ghost-btn { width: auto; padding: 9px 16px; }

/* ---- toast ------------------------------------------------------------------ */
.wxa-toast {
  position: fixed;
  left: 50%;
  bottom: var(--wx-s5);
  transform: translate(-50%, 16px);
  z-index: 80;
  max-width: min(560px, 92vw);
  padding: var(--wx-s3) var(--wx-s5);
  background: var(--wx-ink-2);
  border: 1px solid var(--wx-green);
  color: var(--wx-paper);
  font-family: var(--wx-font-body);
  font-size: 0.9rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--wx-dur-base) var(--wx-ease-out),
              transform var(--wx-dur-base) var(--wx-ease-out);
}
.wxa-toast.on { opacity: 1; transform: translate(-50%, 0); }

/* ---- breakpoints --------------------------------------------------------------- */
@media (max-width: 1180px) {
  .wxa-cols { grid-template-columns: 220px minmax(0, 1fr); }
  .wxa-feed { display: none; }
}
@media (max-width: 880px) {
  .wxa-cols { grid-template-columns: minmax(0, 1fr); }
  .wxa-sheet-btn {
    display: inline-block;
    width: auto;
    padding: 8px 14px;
  }
  .wxa-rail {
    position: fixed;
    inset: auto 0 0 0;
    top: auto;
    max-height: 76vh;
    overflow-y: auto;
    z-index: 60;
    transform: translateY(105%);
    transition: transform var(--wx-dur-base) var(--wx-ease-out);
    border-width: 1px 0 0 0;
    box-shadow: 0 -16px 40px rgba(0, 0, 0, 0.55);
  }
  .wxa-rail.open { transform: none; }

  /* card rows @390-class viewports */
  
.wxa-c-prov {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  padding-top: var(--wx-s1);
  border-top: 1px dashed var(--wx-ink-2);
}
.wxa-c-type { display: flex; flex-direction: column; align-items: flex-start; gap: 3px; }
.wxa-head { display: none; }
  .wxa-row {
    grid-template-columns: 1fr;
    gap: var(--wx-s2);
    padding: var(--wx-s4);
  }
  .wxa-c-act { order: 99; }
  .wxa-c-match { position: absolute; top: var(--wx-s4); right: var(--wx-s4); }
  .wxa-c-type { padding-right: 110px; }
  .wxa-pop { right: var(--wx-s2); left: var(--wx-s2); width: auto; }
  .wxa-rescue { flex-direction: column; }
  .wxa-rescue-clock { text-align: left; }
}

/* ---- reduced motion --------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .wxa-feed-new { animation: none; }
  .wxa-toast { transition: none; }
  .wxa-rail { transition: none; }
}

/* ================================================================
   P2 — flagship-to-masterpiece layer
   ================================================================ */

/* ---- loading skeleton (pre-data shimmer; static under reduced motion) */
.wxa-skel {
  display: grid;
  gap: var(--wx-s2);
  padding: var(--wx-s4);
  border-bottom: 1px solid var(--wx-ink-2);
}
.wxa-skel i {
  display: block;
  height: 14px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--wx-ink-2) 25%, var(--wx-panel) 50%, var(--wx-ink-2) 75%);
  background-size: 200% 100%;
  animation: wxaShimmer 1.4s linear infinite;
}
.wxa-skel i:nth-child(1) { width: 42%; }
.wxa-skel i:nth-child(2) { width: 78%; }
.wxa-skel i:nth-child(3) { width: 58%; }
@keyframes wxaShimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* ---- fail-closed error state ---- */
.wxa-error {
  padding: var(--wx-s6);
  border: 1px solid var(--wx-red);
  text-align: center;
}
.wxa-error p { margin: 0 0 var(--wx-s3) 0; color: var(--wx-dim-hi); font-size: 0.9rem; }
.wxa-error p b { color: var(--wx-paper); }
.wxa-error .wxa-ghost-btn { width: auto; padding: 9px 22px; }

/* ---- composer: qty + running total ---- */
.wxa-line label {
  display: flex;
  flex: 1;
  align-items: center;
  gap: var(--wx-s3);
  cursor: pointer;
  min-width: 0;
}
.wxa-line label span { flex: 1; }
.wxa-qty {
  width: 64px;
  padding: 4px 6px;
  background: var(--wx-ink-2);
  border: 1px solid var(--wx-ghost);
  color: var(--wx-paper);
  font-family: var(--wx-font-mono);
  font-size: 0.8rem;
  text-align: right;
}
.wxa-qty:disabled { opacity: 1; color: var(--wx-faint); border-color: var(--wx-ink-2); }
.wxa-comp-total {
  font-family: var(--wx-font-mono);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--wx-green);
  text-align: right;
  margin: var(--wx-s3) 0 0 0;
  padding-top: var(--wx-s3);
  border-top: 1px solid var(--wx-ghost);
}

/* ---- board pulse: quotes-in tick flash (visibly simulated) ---- */
.wxa-chip--tick {
  border-color: var(--wx-cyan);
  color: var(--wx-cyan);
  transition: border-color var(--wx-dur-slow) var(--wx-ease-out),
              color var(--wx-dur-slow) var(--wx-ease-out);
}

/* ---- micro-interactions (acknowledge: lift 2px; popover fade) ---- */
.wxa-quote-btn,
.wxa-ghost-btn,
.wxa-match {
  transition: transform var(--wx-dur-fast) var(--wx-ease-out),
              filter var(--wx-dur-fast) var(--wx-ease-out),
              border-color var(--wx-dur-fast) var(--wx-ease-out),
              color var(--wx-dur-fast) var(--wx-ease-out),
              background var(--wx-dur-fast) var(--wx-ease-out);
}
.wxa-quote-btn:hover, .wxa-quote-btn:focus-visible { transform: translateY(-2px); }
.wxa-quote-btn:active { transform: translateY(0); }
.wxa-row { transition: background var(--wx-dur-fast) var(--wx-ease-out); }
.wxa-tabs [role="tab"] { transition: color var(--wx-dur-fast) var(--wx-ease-out),
                                     border-color var(--wx-dur-fast) var(--wx-ease-out); }
.wxa-pop {
  animation: wxaPopIn var(--wx-dur-base) var(--wx-ease-out);
}
@keyframes wxaPopIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: none; }
}

/* countdown urgency: breathe only when critical, never the label */
.wxa-rescue--critical .wxa-count { animation: wxaCritical 2.8s ease-in-out infinite; }
@keyframes wxaCritical {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.72; }
}

/* ---- rescue strip: persistent on mobile (compact sticky) ---- */
@media (max-width: 880px) {
  .wxa-rescue {
    position: sticky;
    top: var(--wxa-nav-h, 96px);
    z-index: 50;
    flex-direction: row;
    align-items: center;
    gap: var(--wx-s3);
    padding: var(--wx-s2) var(--wx-s3);
    margin: var(--wx-s3) 0;
    background: var(--wx-ink);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.45);
  }
  .wxa-rescue-meta, .wxa-rescue-constraints, .wxa-count-sub { display: none; }
  .wxa-rescue-tag { margin: 0; font-size: 0.6875rem; }
  .wxa-rescue-title {
    font-size: 0.85rem;
    margin: 2px 0 0 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .wxa-rescue-in { flex: 1; min-width: 0; }
  .wxa-rescue-clock { min-width: 0; text-align: right; }
  .wxa-count { font-size: 1.25rem; }
  .wxa-rescue-clock .wxa-quote-btn--big { padding: 8px 12px; font-size: 0.6875rem; }
}

/* ---- P2 reduced-motion guards ---- */
@media (prefers-reduced-motion: reduce) {
  .wxa-skel i { animation: none; }
  .wxa-pop { animation: none; }
  .wxa-rescue--critical .wxa-count { animation: none; }
  .wxa-quote-btn:hover, .wxa-quote-btn:focus-visible { transform: none; }
  .wxa-quote-btn, .wxa-ghost-btn, .wxa-match, .wxa-row,
  .wxa-tabs [role="tab"], .wxa-chip--tick { transition: none; }
}

/* ---- CLS-guard skeletons (static markup, JS swaps in place) ---- */
.wxa-kpi--skel b {
  min-width: 56px;
  background: linear-gradient(90deg, var(--wx-ink-2) 25%, var(--wx-panel) 50%, var(--wx-ink-2) 75%);
  background-size: 200% 100%;
  animation: wxaShimmer 1.4s linear infinite;
  border-radius: 2px;
}
@media (prefers-reduced-motion: reduce) { .wxa-kpi--skel b { animation: none; } }

/* ================================================================
   P3 — surface components (owner portal, tower, order, finder,
   dev portal, login). Same namespace, same rails.
   ================================================================ */

.wxa-persona {
  display: inline-flex;
  align-items: center;
  gap: var(--wx-s2);
  padding: 4px 12px;
  border: 1px solid var(--wx-cyan);
  border-radius: 14px;
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  letter-spacing: var(--wx-track-data);
  color: var(--wx-cyan);
  text-transform: uppercase;
}

.wxa-grid2 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--wx-s5);
  align-items: start;
  margin-bottom: var(--wx-s6);
}
.wxa-panel {
  background: var(--wx-panel);
  border: 1px solid var(--wx-ghost);
  padding: var(--wx-s5);
  position: relative;
}
.wxa-panel > h2 {
  font-family: var(--wx-font-mono);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: var(--wx-track-wide);
  text-transform: uppercase;
  color: var(--wx-cyan);
  margin: 0 0 var(--wx-s4) 0;
}
.wxa-panel > h2 .wxa-chip--sample { float: right; }

.wxa-money { display: flex; flex-direction: column; gap: var(--wx-s3); }
.wxa-money-row { display: flex; justify-content: space-between; align-items: baseline; gap: var(--wx-s3); border-bottom: 1px dashed var(--wx-ink-2); padding-bottom: var(--wx-s2); }
.wxa-money-row:last-child { border-bottom: 0; }
.wxa-money-row span { font-family: var(--wx-font-body); font-size: 0.88rem; color: var(--wx-dim-hi); }
.wxa-money-row b { font-family: var(--wx-font-mono); font-size: 1.25rem; color: var(--wx-paper); white-space: nowrap; }
.wxa-money-row b.pos { color: var(--wx-green); }
.wxa-money-row b.flight { color: var(--wx-amber); }
.wxa-money-row small { display: block; font-family: var(--wx-font-mono); font-size: 0.6875rem; color: var(--wx-faint); }

.wxa-radar { display: flex; flex-direction: column; gap: var(--wx-s3); }
.wxa-radar-card { border: 1px dashed var(--wx-ghost); padding: var(--wx-s3) var(--wx-s4); }
.wxa-radar-card .sig { font-family: var(--wx-font-body); font-weight: 500; color: var(--wx-paper); margin: 0 0 2px 0; font-size: 0.95rem; }
.wxa-radar-card .proj { font-family: var(--wx-font-mono); font-size: 0.78rem; color: var(--wx-cyan); margin: 0; }
.wxa-radar-card .hor { font-family: var(--wx-font-mono); font-size: 0.6875rem; color: var(--wx-faint); margin: 2px 0 0 0; text-transform: uppercase; letter-spacing: var(--wx-track-data); }

.wxa-lever label { display: block; font-family: var(--wx-font-mono); font-size: 0.75rem; text-transform: uppercase; letter-spacing: var(--wx-track-data); color: var(--wx-dim-hi); margin: var(--wx-s3) 0 var(--wx-s1) 0; }
.wxa-lever input[type="range"] { width: 100%; accent-color: var(--wx-amber); }
.wxa-lever output { font-family: var(--wx-font-mono); color: var(--wx-amber); }
.wxa-lever-out { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--wx-s3); margin-top: var(--wx-s4); }
.wxa-lever-out div { border: 1px solid var(--wx-ghost); padding: var(--wx-s3); text-align: center; }
.wxa-lever-out b { display: block; font-family: var(--wx-font-mono); font-size: 1.2rem; color: var(--wx-paper); }
.wxa-lever-out span { font-family: var(--wx-font-mono); font-size: 0.6563rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--wx-dim); }

.wxa-checks { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 2px var(--wx-s4); }
.wxa-checks label { display: flex; align-items: center; gap: var(--wx-s2); font-size: 0.85rem; color: var(--wx-dim-hi); padding: 3px 0; }
.wxa-checks input { accent-color: var(--wx-amber); width: 15px; height: 15px; }
.wxa-field { margin-bottom: var(--wx-s4); }
.wxa-field > span { display: block; font-family: var(--wx-font-mono); font-size: 0.6875rem; text-transform: uppercase; letter-spacing: var(--wx-track-data); color: var(--wx-dim); margin-bottom: var(--wx-s2); }
.wxa-coi { display: flex; align-items: center; gap: var(--wx-s3); border: 1px dashed var(--wx-green); padding: var(--wx-s3); font-family: var(--wx-font-mono); font-size: 0.78rem; color: var(--wx-green); }

.wxa-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.wxa-table th { font-family: var(--wx-font-mono); font-size: 0.6875rem; text-transform: uppercase; letter-spacing: var(--wx-track-data); color: var(--wx-faint); text-align: left; padding: var(--wx-s2); border-bottom: 1px solid var(--wx-ghost); }
.wxa-table td { padding: var(--wx-s2); border-bottom: 1px solid var(--wx-ink-2); color: var(--wx-dim-hi); }
.wxa-table td b { font-family: var(--wx-font-mono); color: var(--wx-paper); }
.wxa-table .num { text-align: right; font-family: var(--wx-font-mono); }

.wxa-exc { border: 1px solid var(--wx-amber); border-left-width: 4px; padding: var(--wx-s4); margin-bottom: var(--wx-s3); }
.wxa-exc.applied { border-color: var(--wx-green); }
.wxa-exc .what { font-family: var(--wx-font-body); font-weight: 500; color: var(--wx-paper); margin: 0 0 var(--wx-s1) 0; }
.wxa-exc .fix { font-size: 0.85rem; color: var(--wx-dim-hi); margin: 0 0 var(--wx-s3) 0; }
.wxa-exc .fix b { color: var(--wx-cyan); font-weight: 500; }
.wxa-exc-foot { display: flex; align-items: center; justify-content: space-between; gap: var(--wx-s3); }

.wxa-eta { margin: var(--wx-s3) 0; }
.wxa-eta-bar { position: relative; height: 10px; background: var(--wx-ink-2); border: 1px solid var(--wx-ghost); }
.wxa-eta-band { position: absolute; top: 0; bottom: 0; background: var(--wx-cyan); opacity: 0.35; }
.wxa-eta-dot { position: absolute; top: -3px; width: 4px; height: 14px; background: var(--wx-amber); }
.wxa-eta-lab { display: flex; justify-content: space-between; font-family: var(--wx-font-mono); font-size: 0.6875rem; color: var(--wx-faint); margin-top: var(--wx-s1); }

.wxa-timeline { list-style: none; margin: 0; padding: 0; }
.wxa-timeline li { position: relative; padding: 0 0 var(--wx-s4) var(--wx-s6); border-left: 2px solid var(--wx-ghost); margin-left: 7px; }
.wxa-timeline li::before { content: ""; position: absolute; left: -7px; top: 2px; width: 12px; height: 12px; border-radius: 50%; background: var(--wx-green); border: 2px solid var(--wx-ink); }
.wxa-timeline li.projected { border-left-style: dashed; }
.wxa-timeline li.projected::before { background: var(--wx-ink); border: 2px solid var(--wx-cyan); }
.wxa-timeline .t { font-family: var(--wx-font-mono); font-size: 0.6875rem; color: var(--wx-faint); display: block; text-transform: uppercase; }
.wxa-timeline .l { color: var(--wx-dim-hi); font-size: 0.9rem; }
.wxa-timeline li.projected .l::after { content: " · projected"; font-family: var(--wx-font-mono); font-size: 0.6875rem; color: var(--wx-cyan); }

.wxa-route { display: flex; align-items: stretch; gap: 0; margin: var(--wx-s4) 0; flex-wrap: wrap; }
.wxa-route-stop { flex: 1; min-width: 150px; border: 1px solid var(--wx-ghost); padding: var(--wx-s3); position: relative; }
.wxa-route-stop + .wxa-route-stop { border-left: 0; }
.wxa-route-stop .k { font-family: var(--wx-font-mono); font-size: 0.6563rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--wx-cyan); display: block; }
.wxa-route-stop .v { color: var(--wx-paper); font-size: 0.88rem; }
.wxa-route-stop .w { font-family: var(--wx-font-mono); font-size: 0.72rem; color: var(--wx-dim-hi); }

.wxa-docs { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--wx-s3); }
.wxa-doc { border: 1px dashed var(--wx-ghost); padding: var(--wx-s4) var(--wx-s3); text-align: center; font-family: var(--wx-font-mono); font-size: 0.75rem; color: var(--wx-dim-hi); }
.wxa-doc b { display: block; font-size: 1.4rem; margin-bottom: var(--wx-s2); }

/* dev portal: Stripe three-column */
.wxa-dev { display: grid; grid-template-columns: 200px minmax(0, 1.1fr) minmax(0, 1fr); gap: var(--wx-s5); align-items: start; padding-bottom: var(--wx-s8); }
.wxa-dev-toc { position: sticky; top: 84px; border: 1px solid var(--wx-ghost); background: var(--wx-panel); padding: var(--wx-s4); }
.wxa-dev-toc p { font-family: var(--wx-font-mono); font-size: 0.6875rem; text-transform: uppercase; letter-spacing: var(--wx-track-wide); color: var(--wx-faint); margin: var(--wx-s3) 0 var(--wx-s1) 0; }
.wxa-dev-toc a { display: block; padding: 3px 0; font-size: 0.85rem; color: var(--wx-dim-hi); text-decoration: none; }
.wxa-dev-toc a:hover { color: var(--wx-paper); }
.wxa-dev-prose section { margin-bottom: var(--wx-s7); }
.wxa-dev-prose h2 { font-family: var(--wx-font-display); text-transform: uppercase; font-size: 1.4rem; margin: 0 0 var(--wx-s3) 0; }
.wxa-dev-prose p, .wxa-dev-prose li { color: var(--wx-dim-hi); font-size: 0.92rem; line-height: 1.6; }
.wxa-dev-code { position: sticky; top: 84px; display: flex; flex-direction: column; gap: var(--wx-s4); }
.wxa-code { background: oklch(13% 0.02 262); border: 1px solid var(--wx-ghost); padding: var(--wx-s4); font-family: var(--wx-font-mono); font-size: 0.78rem; line-height: 1.55; color: var(--wx-dim-hi); overflow-x: auto; margin: 0; }
.wxa-code .c { color: var(--wx-faint); }
.wxa-code .s { color: var(--wx-green); }
.wxa-code .k { color: var(--wx-cyan); }
.wxa-key { display: flex; align-items: center; gap: var(--wx-s3); flex-wrap: wrap; }
.wxa-key code { flex: 1; min-width: 200px; font-family: var(--wx-font-mono); font-size: 0.8rem; color: var(--wx-amber); background: var(--wx-ink-2); border: 1px dashed var(--wx-amber); padding: var(--wx-s2) var(--wx-s3); overflow-x: auto; white-space: nowrap; }
.wxa-replay-log { list-style: none; margin: var(--wx-s3) 0 0 0; padding: 0; font-family: var(--wx-font-mono); font-size: 0.78rem; }
.wxa-replay-log li { padding: var(--wx-s1) 0; color: var(--wx-faint); border-bottom: 1px dashed var(--wx-ink-2); }
.wxa-replay-log li.hit { color: var(--wx-paper); }
.wxa-replay-log li.hit .st { color: var(--wx-green); }
.wxa-replay-log li .st { font-weight: 700; }

/* login: sandbox entrance */
.wxa-personas { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--wx-s5); max-width: 760px; margin: var(--wx-s6) auto; }
.wxa-persona-card { background: var(--wx-panel); border: 1px solid var(--wx-ghost); padding: var(--wx-s6); text-align: left; display: block; text-decoration: none; transition: border-color var(--wx-dur-fast) var(--wx-ease-out), transform var(--wx-dur-fast) var(--wx-ease-out); }
.wxa-persona-card:hover, .wxa-persona-card:focus-visible { border-color: var(--wx-amber); transform: translateY(-2px); }
.wxa-persona-card .role { font-family: var(--wx-font-mono); font-size: 0.6875rem; letter-spacing: var(--wx-track-wide); text-transform: uppercase; color: var(--wx-cyan); }
.wxa-persona-card h2 { font-family: var(--wx-font-display); text-transform: uppercase; font-size: 1.5rem; color: var(--wx-paper); margin: var(--wx-s2) 0; }
.wxa-persona-card p { color: var(--wx-dim-hi); font-size: 0.9rem; margin: 0 0 var(--wx-s4) 0; }

/* finder */
.wxa-finder-map { border: 1px solid var(--wx-ghost); background: var(--wx-ink-2); padding: var(--wx-s4); margin-bottom: var(--wx-s5); }
.wxa-fac { border: 1px solid var(--wx-ghost); background: var(--wx-panel); padding: var(--wx-s4); margin-bottom: var(--wx-s3); display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: var(--wx-s3); }
.wxa-fac h3 { font-family: var(--wx-font-body); font-weight: 500; font-size: 1rem; color: var(--wx-paper); margin: 0 0 var(--wx-s1) 0; }
.wxa-fac .meta { font-family: var(--wx-font-mono); font-size: 0.72rem; color: var(--wx-dim-hi); margin: 0 0 var(--wx-s2) 0; }

@media (max-width: 1100px) {
  .wxa-dev { grid-template-columns: minmax(0, 1fr); }
  .wxa-dev-toc, .wxa-dev-code { position: static; }
}
@media (max-width: 880px) {
  .wxa-lever-out { grid-template-columns: 1fr; }
  .wxa-fac { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .wxa-persona-card { transition: none; }
  .wxa-persona-card:hover { transform: none; }
}

/* finder map: clamp the signature device so results stay above the fold */
.wxa-finder-map > div { max-width: 880px; margin: 0 auto; }

/* prose links inside app surfaces must not be colour-only (axe link-in-text-block) */
.wxa-banner a, .wxa-wrap p a { text-decoration: underline; text-underline-offset: 3px; }

/* ---- P4 CLS guards: async containers reserve their space ---- */
#wxoMoney { min-height: 196px; }
#wxoRadar { min-height: 248px; }
#wxoHistory { min-height: 120px; display: table-row-group; }
.wxa-finder-map > div { aspect-ratio: 5 / 4; }
#wxfResults { min-height: 430px; }
#wxtExceptions { min-height: 300px; }
#wxtEta { min-height: 220px; }

/* ---- focusable scroll regions (axe scrollable-region-focusable) ---- */
.wxa-scroll { overflow-x: auto; }
.wxa-scroll:focus-visible, .wxa-code:focus-visible { outline: 2px solid var(--wx-amber); outline-offset: 2px; }
