@import "./tokens.css";
@import "./launch.css";

:root {
  --ew-lab-section-gap: var(--ew-space-8);
  --ew-lab-section-gap-mobile: var(--ew-space-6);
  --ew-lab-heading-gap: var(--ew-space-5);
  --ew-lab-heading-gap-mobile: var(--ew-space-4);
}

body {
  margin: 0;
}

.ew-lab-rail {
  background: var(--ew-color-canvas);
  border-bottom: 1px solid var(--ew-color-border);
  position: sticky;
  top: 0;
  z-index: 30;
}

.ew-lab-rail-inner {
  align-items: center;
  display: flex;
  gap: var(--ew-space-3);
  justify-content: space-between;
  margin: 0 auto;
  max-width: var(--ew-page-max);
  padding: var(--ew-space-2) var(--ew-page-x);
}

.ew-lab-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ew-space-1);
  list-style: none;
  margin: 0;
  padding: 0;
}

.ew-lab-tabs a {
  align-items: center;
  border: 1px solid var(--ew-color-border);
  border-radius: var(--ew-control-radius);
  color: var(--ew-color-ink-strong);
  display: inline-flex;
  font-family: var(--ew-font-mono);
  font-size: var(--ew-type-size-sm);
  font-weight: 750;
  min-height: var(--ew-target-size-compact);
  padding: var(--ew-space-1) var(--ew-space-2);
  text-decoration: none;
  text-transform: uppercase;
}

.ew-lab-tabs a[aria-current="page"] {
  background: var(--ew-color-institutional);
  border-color: var(--ew-color-institutional);
  color: var(--ew-color-white);
}

.ew-lab-note {
  color: var(--ew-color-muted);
  font-family: var(--ew-font-mono);
  font-size: var(--ew-type-size-xs);
  letter-spacing: 0.08em;
  line-height: 1.35;
  text-transform: uppercase;
}

.ew-lab-system-grid,
.ew-lab-page-grid,
.ew-lab-module-grid,
.ew-lab-state-grid {
  display: grid;
  gap: var(--ew-space-3);
}

.ew-lab-system-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ew-lab-page-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ew-lab-module-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ew-lab-state-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.ew-lab-section-head {
  display: grid;
  gap: var(--ew-space-2);
  margin-bottom: var(--ew-lab-heading-gap);
}

.ew-lab-section-head > .ew-kicker-alert {
  margin-bottom: 0;
}

.ew-lab-section-head h1,
.ew-lab-section-head h2 {
  max-width: var(--ew-measure);
}

.ew-lab-section-head-split {
  align-items: end;
  display: flex;
  flex-wrap: wrap;
  gap: var(--ew-space-3);
  justify-content: space-between;
}

.ew-lab-section-head-split > div {
  min-width: min(100%, 28rem);
}

.ew-lab-page-detail-stack {
  display: grid;
  gap: var(--ew-lab-section-gap);
  margin-top: var(--ew-lab-section-gap);
}

.ew-lab-card,
.ew-lab-frame,
.ew-lab-check-card {
  background: var(--ew-color-canvas);
  border: 1px solid var(--ew-color-border);
  border-radius: var(--ew-control-radius);
  padding: var(--ew-card-padding);
}

.ew-lab-card h3,
.ew-lab-frame h3,
.ew-lab-check-card h3 {
  margin-bottom: var(--ew-space-2);
}

.ew-lab-card p,
.ew-lab-frame p,
.ew-lab-check-card p {
  color: var(--ew-color-muted);
  margin-bottom: 0;
}

.ew-lab-mini-screen {
  background: var(--ew-color-surface);
  border: 1px solid var(--ew-color-border);
  border-radius: var(--ew-control-radius);
  display: grid;
  gap: var(--ew-space-2);
  margin-bottom: var(--ew-space-3);
  min-height: 12rem;
  padding: var(--ew-space-3);
}

.ew-lab-mini-screen span {
  background: var(--ew-color-canvas);
  border: 1px solid var(--ew-color-border-soft);
  border-radius: var(--ew-control-radius);
  display: block;
  min-height: var(--ew-space-5);
}

.ew-lab-mini-screen .wide {
  width: 100%;
}

.ew-lab-mini-screen .medium {
  width: 72%;
}

.ew-lab-mini-screen .short {
  width: 44%;
}

.ew-lab-mini-screen .danger {
  background: var(--ew-color-danger-soft);
  border-color: var(--ew-color-danger-line);
}

.ew-lab-mini-screen .action {
  background: var(--ew-color-action-soft);
  border-color: var(--ew-color-action-line);
}

.ew-lab-mini-screen .success {
  background: var(--ew-color-success-soft);
  border-color: var(--ew-color-success-line);
}

.ew-lab-two-up {
  display: grid;
  gap: var(--ew-module-gap);
  grid-template-columns: minmax(0, 0.95fr) minmax(22rem, 1fr);
}

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

.ew-lab-toolbar {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: var(--ew-space-2);
  justify-content: space-between;
}

.ew-lab-toggle-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ew-space-1);
}

.ew-lab-toggle-group button,
.ew-lab-small-button {
  align-items: center;
  background: var(--ew-color-canvas);
  border: 1px solid var(--ew-color-border);
  border-radius: var(--ew-control-radius);
  color: var(--ew-color-ink-strong);
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-weight: 750;
  justify-content: center;
  min-height: var(--ew-target-size-compact);
  padding: var(--ew-space-1) var(--ew-space-2);
}

.ew-lab-toggle-group button[aria-pressed="true"],
.ew-lab-small-button[aria-pressed="true"] {
  background: var(--ew-color-action-soft);
  border-color: var(--ew-color-action);
}

.ew-lab-page-type[hidden],
.ew-lab-module-panel[hidden] {
  display: none;
}

.ew-lab-page-type {
  border-top: 1px solid var(--ew-color-border);
  margin-top: 0;
  padding-top: var(--ew-lab-section-gap);
}

.ew-lab-page-type > h3 {
  margin-bottom: var(--ew-space-4);
}

.ew-r-page {
  background: var(--ew-color-canvas);
  border: 1px solid var(--ew-color-border);
  display: grid;
}

.ew-r-page h1,
.ew-r-page h2,
.ew-r-page h3,
.ew-r-page p {
  margin-top: 0;
}

.ew-r-hero {
  align-items: stretch;
  background: var(--ew-color-surface-alt);
  display: grid;
  gap: var(--ew-module-gap);
  grid-template-columns: minmax(0, 1.1fr) minmax(18rem, 0.75fr);
  min-height: 34rem;
  overflow: hidden;
  padding: var(--ew-space-10) var(--ew-space-8);
}

.ew-r-hero-copy {
  align-content: center;
  display: grid;
}

.ew-r-alert-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ew-space-1);
  margin-bottom: var(--ew-space-4);
}

.ew-r-hero h1 {
  font-size: var(--ew-type-size-display);
  line-height: 0.95;
  max-width: 12ch;
}

.ew-r-hero-art {
  align-self: stretch;
  margin: 0;
  min-height: 30rem;
}

.ew-r-training {
  display: grid;
  justify-items: center;
  padding: var(--ew-space-10) var(--ew-space-8);
  text-align: center;
}

.ew-r-training .ew-kicker-alert {
  margin-bottom: var(--ew-space-2);
}

.ew-r-training p {
  max-width: var(--ew-measure);
}

.ew-r-question-focus {
  background: var(--ew-color-surface);
  display: grid;
  min-height: 38rem;
  padding: var(--ew-space-10) var(--ew-space-8);
  place-items: center;
}

.ew-r-question-card {
  background: var(--ew-color-canvas);
  border: 1px solid var(--ew-color-border);
  border-radius: var(--ew-control-radius);
  display: grid;
  gap: var(--ew-space-5);
  max-width: 58rem;
  padding: var(--ew-space-8);
  width: 100%;
}

.ew-r-question-card fieldset {
  display: grid;
  gap: var(--ew-space-4);
  margin: 0;
  padding: 0;
}

.ew-r-question-card legend {
  font-size: var(--ew-type-size-xl);
  font-weight: 750;
  line-height: var(--ew-line-tight);
  margin-bottom: var(--ew-space-2);
}

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

.ew-r-question-actions {
  display: grid;
  gap: var(--ew-space-2);
  justify-items: center;
}

.ew-r-question-actions .ew-submit {
  max-width: 18rem;
  width: 100%;
}

.ew-r-room-finder {
  background: var(--ew-color-surface-alt);
  display: grid;
  gap: var(--ew-space-4);
  justify-items: center;
  padding: var(--ew-space-10) var(--ew-space-8);
  text-align: center;
}

.ew-r-room-finder .ew-search-panel {
  max-width: 40rem;
  width: 100%;
}

.ew-r-content {
  align-items: start;
  display: grid;
  gap: var(--ew-module-gap);
  grid-template-columns: minmax(13rem, 0.32fr) minmax(0, 1fr);
  padding: var(--ew-space-10) var(--ew-space-8);
}

.ew-r-content-nav {
  position: sticky;
  top: var(--ew-scroll-offset);
}

.ew-r-content-nav h2 {
  font-size: var(--ew-type-size-lg);
  margin-bottom: var(--ew-space-3);
}

.ew-r-content-nav ul {
  display: grid;
  gap: var(--ew-space-1);
  list-style: none;
  margin: 0;
  padding: 0;
}

.ew-r-content-nav a {
  color: var(--ew-color-muted);
  font-weight: 750;
  text-decoration: none;
}

.ew-r-side-card {
  background: var(--ew-color-surface-strong);
  border-radius: var(--ew-control-radius);
  min-height: 14rem;
  margin-top: var(--ew-space-5);
}

.ew-r-prose {
  max-width: 68ch;
}

.ew-r-prose p {
  font-size: var(--ew-type-size-lg);
  line-height: var(--ew-line-prose);
}

.ew-r-prose-placeholder {
  background: var(--ew-color-surface);
  border: 1px solid var(--ew-color-border-soft);
  border-radius: var(--ew-control-radius);
  margin-top: var(--ew-space-6);
  min-height: 14rem;
  padding: var(--ew-space-5);
}

.ew-r-room-footer {
  background: var(--ew-color-surface-alt);
  display: grid;
  gap: var(--ew-space-8);
  padding: var(--ew-space-10) var(--ew-space-8);
}

.ew-r-room-footer h2 {
  font-size: var(--ew-type-size-3xl);
  line-height: var(--ew-line-tight);
  max-width: 11ch;
}

.ew-r-footer-card {
  background: var(--ew-color-canvas);
  border: 1px solid var(--ew-color-border-soft);
  border-radius: var(--ew-control-radius);
  display: grid;
  gap: var(--ew-space-2);
  justify-items: center;
  padding: var(--ew-space-8);
  text-align: center;
}

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

.ew-lab-coverage-list li {
  align-items: start;
  display: grid;
  gap: var(--ew-space-2);
  grid-template-columns: auto minmax(0, 1fr);
}

.ew-lab-coverage-list span:first-child {
  background: var(--ew-color-success-soft);
  border: 1px solid var(--ew-color-success-line);
  border-radius: var(--ew-radius-pill);
  color: var(--ew-color-success);
  display: inline-grid;
  font-family: var(--ew-font-mono);
  font-size: var(--ew-type-size-xs);
  font-weight: 800;
  height: 1.5rem;
  place-items: center;
  width: 1.5rem;
}

.ew-lab-inline-form {
  display: grid;
  gap: var(--ew-space-3);
}

.ew-lab-inline-form label {
  display: grid;
  gap: var(--ew-space-1);
}

.ew-lab-inline-form input,
.ew-lab-inline-form select,
.ew-lab-inline-form textarea {
  min-height: var(--ew-target-size);
  width: 100%;
}

.ew-lab-flow-svg {
  background: var(--ew-color-surface);
  border: 1px solid var(--ew-color-border);
  border-radius: var(--ew-control-radius);
  display: block;
  height: auto;
  width: 100%;
}

.ew-lab-flow-node {
  fill: var(--ew-color-canvas);
  stroke: var(--ew-color-action);
  stroke-width: 2;
}

.ew-lab-flow-line {
  fill: none;
  stroke: var(--ew-color-border-strong);
  stroke-width: 2;
}

.ew-lab-flow-label {
  fill: var(--ew-color-ink-strong);
  font-family: var(--ew-font-mono);
  font-size: 12px;
  font-weight: 700;
}

.ew-lab-mobile-frame {
  border: 1px solid var(--ew-color-border);
  border-radius: var(--ew-radius-lg);
  margin: 0 auto;
  max-width: 24rem;
  overflow: hidden;
}

.ew-lab-mobile-frame .ew-site-header {
  position: static;
}

.ew-lab-mobile-section {
  padding: var(--ew-section-y-mobile) var(--ew-page-x-mobile);
}

.ew-lab-mobile-frame .ew-hero-grid,
.ew-lab-mobile-frame .ew-two-col,
.ew-lab-mobile-frame .ew-role-hero {
  grid-template-columns: 1fr;
}

.ew-lab-mobile-frame .ew-launch h1 {
  font-size: var(--ew-type-size-display-mobile);
}

.ew-lab-results {
  display: grid;
  gap: var(--ew-space-2);
  margin-top: var(--ew-space-3);
}

.ew-lab-result-row {
  align-items: center;
  border: 1px solid var(--ew-color-border);
  display: grid;
  gap: var(--ew-space-3);
  grid-template-columns: minmax(0, 1fr) auto;
  padding: var(--ew-space-2);
}

.ew-lab-result-row strong,
.ew-lab-result-row span {
  display: block;
}

.ew-lab-result-row span {
  color: var(--ew-color-muted);
  font-size: var(--ew-type-size-md);
}

.ew-lab-component-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ew-space-1);
  margin-bottom: var(--ew-space-4);
}

.ew-lab-component-nav button {
  background: var(--ew-color-canvas);
  border: 1px solid var(--ew-color-border);
  border-radius: var(--ew-control-radius);
  cursor: pointer;
  font: inherit;
  font-weight: 750;
  min-height: var(--ew-target-size-compact);
  padding: var(--ew-space-1) var(--ew-space-2);
}

.ew-lab-component-nav button[aria-selected="true"] {
  background: var(--ew-color-institutional);
  border-color: var(--ew-color-institutional);
  color: var(--ew-color-white);
}

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

.ew-lab-test-grid code {
  background: var(--ew-color-code-surface);
  border-radius: var(--ew-control-radius);
  color: var(--ew-color-code-text);
  display: block;
  overflow-wrap: anywhere;
  padding: var(--ew-space-2);
}

@media (max-width: 64rem) {
  .ew-lab-rail-inner,
  .ew-lab-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .ew-lab-system-grid,
  .ew-lab-page-grid,
  .ew-lab-module-grid,
  .ew-lab-state-grid,
  .ew-lab-two-up,
  .ew-lab-test-grid,
  .ew-r-hero,
  .ew-r-choice-grid,
  .ew-r-content {
    grid-template-columns: 1fr;
  }

  .ew-r-content-nav {
    position: static;
  }
}

@media (max-width: 48rem) {
  .ew-lab-rail {
    position: static;
  }

  .ew-lab-rail-inner {
    padding: var(--ew-space-2) var(--ew-page-x-mobile);
  }

  .ew-lab-tabs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ew-lab-tabs a {
    width: 100%;
  }

  .ew-lab-card,
  .ew-lab-frame,
  .ew-lab-check-card {
    padding: var(--ew-card-padding-mobile);
  }

  .ew-lab-section-head {
    margin-bottom: var(--ew-lab-heading-gap-mobile);
  }

  .ew-lab-page-detail-stack {
    gap: var(--ew-lab-section-gap-mobile);
    margin-top: var(--ew-lab-section-gap-mobile);
  }

  .ew-lab-page-type {
    padding-top: var(--ew-lab-section-gap-mobile);
  }

  .ew-r-hero,
  .ew-r-training,
  .ew-r-question-focus,
  .ew-r-room-finder,
  .ew-r-content,
  .ew-r-room-footer {
    padding: var(--ew-space-7) var(--ew-page-x-mobile);
  }

  .ew-r-hero {
    min-height: auto;
  }

  .ew-r-hero h1,
  .ew-r-room-footer h2 {
    font-size: var(--ew-type-size-display-mobile);
  }

  .ew-r-hero-art {
    min-height: 16rem;
  }

  .ew-r-question-focus {
    min-height: auto;
  }

  .ew-r-question-card {
    padding: var(--ew-card-padding-mobile);
  }

  .ew-r-question-card legend {
    font-size: var(--ew-type-size-lg);
  }

  .ew-r-prose p {
    font-size: var(--ew-type-size-base);
  }

  .ew-r-footer-card {
    padding: var(--ew-space-5);
  }
}
