:root {
  color-scheme: light;
  --bg: #f3f5f7;
  --surface: #ffffff;
  --surface-2: #f8fafb;
  --ink: #182226;
  --muted: #60717a;
  --faint: #8b989e;
  --line: #d8e1e6;
  --line-strong: #b7c5cd;
  --blue: #235789;
  --teal: #087f75;
  --amber: #b76800;
  --red: #b3423d;
  --violet: #665191;
  --soft-blue: #e7f0f8;
  --soft-teal: #e2f3f0;
  --soft-amber: #fff0d7;
  --soft-red: #fcebea;
  --soft-violet: #efebf7;
  --shadow: 0 18px 44px rgba(24, 34, 38, 0.1);
  --shadow-soft: 0 10px 28px rgba(24, 34, 38, 0.07);
  --radius: 8px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  min-width: 320px;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 15px;
  line-height: 1.55;
}

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

button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  border: 1px solid #1f3138;
  border-radius: 6px;
  background: #1f3138;
  color: #fff;
  padding: 0 16px;
  cursor: pointer;
  white-space: nowrap;
}

.button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  border: 1px solid #1f3138;
  border-radius: 6px;
  background: #1f3138;
  color: #fff;
  padding: 0 16px;
  font-weight: 700;
  white-space: nowrap;
}

button:hover:not(:disabled) {
  filter: brightness(1.07);
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

button.ghost {
  border-color: var(--line-strong);
  background: var(--surface);
  color: var(--ink);
}

.button-link.ghost {
  border-color: var(--line-strong);
  background: var(--surface);
  color: var(--ink);
}

button.light {
  background: rgba(255, 255, 255, 0.88);
  border-color: rgba(255, 255, 255, 0.78);
}

button svg,
button [data-lucide],
.button-link svg,
.button-link [data-lucide],
.capability-grid svg,
.rail-item svg {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  stroke-width: 2;
}

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

h1,
h2,
h3,
h4,
p {
  margin: 0;
  letter-spacing: 0;
}

h1 {
  font-size: 58px;
  line-height: 0.98;
}

h2 {
  font-size: 24px;
  line-height: 1.2;
}

h3 {
  font-size: 15px;
  line-height: 1.25;
}

.hidden {
  display: none !important;
}

.eyebrow {
  margin-bottom: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  min-height: 68px;
  padding: 10px max(18px, calc((100vw - 1240px) / 2));
  border-bottom: 1px solid rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(14px);
}

.console-mode .site-header {
  display: none;
}

.brand,
.rail-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.brand-mark {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  box-shadow: 0 12px 26px rgba(16, 24, 38, 0.16);
  flex: 0 0 auto;
}

.brand strong,
.rail-brand strong {
  white-space: nowrap;
}

.site-nav {
  display: flex;
  justify-content: center;
  gap: 22px;
  color: #3b4a51;
  font-size: 13px;
  font-weight: 800;
}

.site-nav a {
  border-bottom: 2px solid transparent;
  padding-block: 6px;
}

.site-nav a.active {
  border-color: var(--teal);
  color: var(--teal-dark);
}

.site-actions,
.hero-actions,
.console-actions,
.actions,
.ingest-actions,
.section-title,
.view-head {
  display: flex;
  align-items: center;
  gap: 10px;
}

.site-actions,
.hero-actions,
.console-actions,
.actions,
.ingest-actions {
  flex-wrap: wrap;
}

.hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 30px;
  align-items: end;
  min-height: calc(100vh - 68px);
  padding: 9vh max(18px, calc((100vw - 1240px) / 2)) 8vh;
  background:
    linear-gradient(90deg, rgba(11, 26, 33, 0.82) 0%, rgba(11, 26, 33, 0.58) 47%, rgba(11, 26, 33, 0.18) 100%),
    url("https://images.unsplash.com/photo-1503387762-592deb58ef4e?auto=format&fit=crop&w=1800&q=82") center / cover;
  color: #fff;
}

.hero-copy {
  max-width: 800px;
  padding-bottom: 4vh;
}

.hero .eyebrow,
.hero-lede {
  color: rgba(255, 255, 255, 0.78);
}

.hero-lede {
  max-width: 720px;
  margin-top: 18px;
  font-size: 19px;
  line-height: 1.55;
}

.hero-actions {
  margin-top: 26px;
}

.auth-help {
  margin: 0 0 14px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
}

.hero-panel {
  display: grid;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(16px);
  padding: 18px;
}

.hero-panel span,
.hero-panel small {
  color: rgba(255, 255, 255, 0.78);
}

.hero-panel strong {
  font-size: 24px;
  line-height: 1.15;
}

.home-flow-band {
  padding-top: 44px;
}

.home-flow-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.home-flow-card {
  display: grid;
  min-height: 210px;
  align-items: start;
  justify-items: start;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  box-shadow: var(--shadow-soft);
  padding: 18px;
  text-align: start;
  white-space: normal;
}

.home-flow-card i,
.home-flow-card svg {
  color: var(--teal);
}

.home-flow-card strong {
  display: block;
  font-size: 20px;
  line-height: 1.25;
}

.home-flow-card span {
  display: block;
  color: var(--muted);
  font-size: 14px;
  font-weight: 650;
  line-height: 1.55;
}

.home-flow-card small {
  align-self: end;
  color: var(--teal-dark);
  font-size: 13px;
  font-weight: 900;
}

.section-band,
.workflow-band {
  scroll-margin-top: 86px;
  padding: 54px max(18px, calc((100vw - 1240px) / 2));
}

.section-head {
  display: grid;
  gap: 4px;
  max-width: 760px;
  margin-bottom: 22px;
}

.capability-grid,
.pricing-grid,
.deployment-grid,
.payment-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.package-grid,
.launch-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.capability-grid article,
.pricing-grid article,
.package-card,
.info-card {
  display: grid;
  gap: 9px;
  min-height: 178px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow);
  padding: 18px;
}

.package-card span,
.info-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.package-card strong {
  font-size: 28px;
}

.package-card ul {
  display: grid;
  gap: 6px;
  margin: 4px 0 0;
  padding: 0 18px 0 0;
  color: var(--muted);
  font-size: 13px;
}

[dir="ltr"] .package-card ul {
  padding: 0 0 0 18px;
}

.package-card.featured {
  border-color: var(--teal);
  box-shadow: inset 0 0 0 1px var(--teal), var(--shadow);
}

.package-drilldown-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 40px;
  margin-top: 6px;
  padding: 9px 14px;
  border: 1px solid rgba(8, 127, 117, 0.28);
  border-radius: 8px;
  background: rgba(8, 127, 117, 0.08);
  color: var(--teal);
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
}

.package-drilldown-button.wide {
  width: 100%;
}

.package-card-details,
.package-detail-grid {
  display: grid;
  gap: 8px;
  margin-top: 4px;
}

.package-detail {
  border: 1px solid rgba(31, 49, 56, 0.12);
  border-radius: 8px;
  background: rgba(244, 248, 247, 0.74);
  padding: 0;
}

.package-detail summary {
  cursor: pointer;
  list-style: none;
  padding: 10px 12px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 900;
}

.package-detail summary::-webkit-details-marker {
  display: none;
}

.package-detail summary::after {
  content: "+";
  float: inline-end;
  color: var(--teal);
  font-weight: 900;
}

.package-detail[open] summary::after {
  content: "-";
}

.package-detail ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0 28px 12px 12px;
  color: var(--muted);
  font-size: 13px;
}

[dir="ltr"] .package-detail ul {
  padding: 0 12px 12px 28px;
}

.package-video {
  display: grid;
  gap: 10px;
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(31, 49, 56, 0.12);
}

.package-video-media {
  overflow: hidden;
  border-radius: 8px;
  background: #101820;
}

.package-video video {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #101820;
}

.package-video-copy {
  display: grid;
  gap: 7px;
}

.package-video-copy > span {
  color: var(--teal);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.package-video-copy strong {
  color: var(--ink);
  font-size: 15px;
}

.package-video-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.package-video-copy b {
  color: var(--ink);
}

.package-video-copy a {
  color: var(--teal);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
}

.package-video-details {
  display: grid;
  gap: 8px;
  margin-top: 4px;
}

.package-video-details .package-detail {
  background: rgba(255, 255, 255, 0.6);
}

body.package-drilldown-open {
  overflow: hidden;
}

.package-drilldown-page[hidden] {
  display: none;
}

.package-drilldown-page {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: grid;
  place-items: center;
  padding: 22px;
}

.package-drilldown-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(14, 25, 29, 0.6);
  backdrop-filter: blur(10px);
}

.package-drilldown-shell {
  position: relative;
  z-index: 1;
  width: min(1160px, 100%);
  max-height: min(900px, calc(100vh - 44px));
  overflow: auto;
  display: grid;
  gap: 18px;
  border: 1px solid rgba(31, 49, 56, 0.16);
  border-radius: 10px;
  background: var(--paper);
  padding: 18px;
  box-shadow: 0 30px 90px rgba(14, 25, 29, 0.32);
}

.package-drilldown-top,
.package-overview-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.package-back-button,
.package-close-button {
  min-height: 40px;
}

.package-close-button {
  width: 42px;
  padding: 0;
}

.package-overview-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.75fr);
  gap: 18px;
  align-items: stretch;
  padding: 20px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(31, 49, 56, 0.12);
}

.package-overview-hero span,
.package-story-copy span {
  color: var(--teal);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
}

.package-overview-hero h2 {
  margin: 7px 0 8px;
  color: var(--ink);
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.12;
}

.package-overview-hero p,
.package-story-copy p,
.package-story-copy li,
.package-overview-section li,
.package-overview-footer {
  color: var(--muted);
  line-height: 1.65;
}

.package-overview-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.package-overview-tags b {
  padding: 8px 11px;
  border-radius: 999px;
  background: rgba(8, 127, 117, 0.08);
  color: var(--teal);
  font-size: 12px;
}

.package-overview-fit {
  display: grid;
  align-content: start;
  gap: 10px;
  border-inline-start: 3px solid var(--teal);
  padding-inline-start: 16px;
}

.package-overview-fit strong {
  color: var(--ink);
  font-size: 16px;
}

.package-overview-fit ul,
.package-story-copy ul,
.package-overview-section ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding: 0 18px 0 0;
}

[dir="ltr"] .package-overview-fit ul,
[dir="ltr"] .package-story-copy ul,
[dir="ltr"] .package-overview-section ul {
  padding: 0 0 0 18px;
}

.package-overview-story {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(340px, 1.05fr);
  gap: 18px;
  align-items: stretch;
}

.package-overview-story.compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.package-story-copy {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 18px;
  border: 1px solid rgba(31, 49, 56, 0.12);
  border-radius: 8px;
  background: #fff;
}

.package-story-copy h3,
.package-overview-section h4 {
  margin: 0;
  color: var(--ink);
  line-height: 1.35;
}

.package-story-copy p {
  margin: 0;
}

.package-story-copy b {
  color: var(--ink);
}

.package-story-video {
  overflow: hidden;
  border-radius: 8px;
  background: #101820;
  border: 1px solid rgba(31, 49, 56, 0.12);
}

.package-story-video video {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  background: #101820;
}

.package-overview-section-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.package-overview-section {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 100%;
  padding: 16px;
  border: 1px solid rgba(31, 49, 56, 0.12);
  border-radius: 8px;
  background: #fff;
}

.package-overview-footer {
  border-top: 1px solid rgba(31, 49, 56, 0.12);
  padding-top: 14px;
  font-size: 13px;
  font-weight: 800;
}

.package-overview-footer a {
  color: var(--teal);
  text-decoration: none;
}

.compact-head {
  margin-top: 32px;
}

.capability-grid svg {
  width: 24px;
  height: 24px;
  color: var(--teal);
}

.capability-grid p,
.pricing-grid p,
.package-card p,
.info-card p,
.view-head p {
  color: var(--muted);
}

.workflow-band {
  background: #1f3138;
  color: #fff;
}

.workflow-line {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}

.workflow-line span {
  min-height: 64px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius);
  padding: 14px;
  font-weight: 850;
}

.pricing-grid article strong {
  font-size: 28px;
}

.pricing-grid .featured {
  border-color: var(--teal);
  box-shadow: inset 0 0 0 1px var(--teal), var(--shadow);
}

.compact-card {
  display: grid;
  gap: 6px;
  border-bottom: 1px solid var(--line);
  padding: 0 0 12px;
}

.compact-card:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.compact-card p {
  color: var(--muted);
  font-size: 13px;
}

.launch-readiness-panel {
  margin: 14px 0;
}

.package-advisor-panel {
  margin: 14px 0;
}

.launch-decision-panel {
  margin: 14px 0;
}

.roi-calculator-panel {
  margin: 14px 0;
}

.activation-tracker-panel {
  margin: 14px 0;
}

.production-smoke-panel {
  margin: 14px 0;
}

.production-wiring-panel {
  margin: 14px 0;
}

.customer-success-panel {
  margin: 14px 0;
}

.security-review-panel {
  margin: 14px 0;
}

.deployment-runbook-panel {
  margin: 14px 0;
}

.deployment-estimator-panel {
  margin: 14px 0;
}

.proposal-brief-panel {
  margin: 14px 0;
}

.implementation-service-panel {
  margin: 14px 0;
}

.data-intake-panel {
  margin-top: 14px;
}

.whatsapp-benchmark-panel {
  margin-top: 6px;
}

.supplier-coverage-panel {
  margin-top: 6px;
}

.readiness-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.readiness-card {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 12px;
}

html[dir="rtl"] .readiness-card {
  border-left-width: 1px;
  border-right: 5px solid var(--blue);
}

.readiness-card.readyNow {
  border-left-color: var(--teal);
}

html[dir="rtl"] .readiness-card.readyNow {
  border-right-color: var(--teal);
}

.readiness-card.buildNext {
  border-left-color: var(--amber);
}

html[dir="rtl"] .readiness-card.buildNext {
  border-right-color: var(--amber);
}

.readiness-card.enterpriseGate {
  border-left-color: var(--blue);
}

html[dir="rtl"] .readiness-card.enterpriseGate {
  border-right-color: var(--blue);
}

.readiness-card.selected {
  background: #fff;
  box-shadow: 0 0 0 2px rgba(23, 103, 120, 0.12);
}

.readiness-card span {
  color: var(--faint);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.readiness-card p {
  color: var(--muted);
  font-size: 13px;
}

.preset-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 12px;
}

.preset-card p {
  margin: 4px 0 6px;
  color: var(--muted);
  font-size: 13px;
}

.preset-card span {
  color: var(--faint);
  font-size: 12px;
  font-weight: 800;
}

.preset-card.installed {
  border-color: rgba(14, 157, 142, 0.32);
  background: var(--soft-teal);
}

.preset-card button {
  min-height: 34px;
  padding: 7px 10px;
}

.automation-history-panel {
  grid-column: 1 / -1;
}

.automation-coverage-panel {
  margin-bottom: 14px;
}

.automation-coverage-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.automation-coverage-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 12px;
}

.automation-coverage-card strong {
  color: var(--ink);
}

.automation-coverage-card dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

.automation-coverage-card dl div {
  display: grid;
  gap: 3px;
}

.automation-coverage-card dt {
  color: var(--teal);
  font-size: 11px;
  font-weight: 900;
}

.automation-coverage-card dd {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
}

.payment-compliance-panel {
  grid-column: span 2;
}

.payment-readiness-panel {
  grid-column: span 2;
}

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

.api-bridge-panel {
  grid-column: 1 / -1;
}

.tenant-onboarding-panel {
  grid-column: 1 / -1;
}

.onboarding-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.onboarding-band {
  background: #eef4f2;
}

.onboarding-shell {
  display: grid;
  grid-template-columns: minmax(0, 560px);
  gap: 12px;
  align-items: start;
  justify-content: center;
  max-width: 640px;
  margin-inline: auto;
}

.auth-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 6px;
}

.auth-tabs button {
  min-height: 46px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--muted);
  font-weight: 900;
  box-shadow: none;
}

.auth-tabs button.active {
  background: var(--ink);
  color: #fff;
}

.onboarding-card.request-card,
.onboarding-card.auth-card {
  background: var(--surface);
  box-shadow: var(--shadow);
}

.auth-card {
  position: static;
  width: 100%;
  justify-self: center;
}

.auth-code-step {
  display: grid;
  gap: 10px;
}

.auth-card:not(.auth-code-ready) .auth-code-step {
  display: none;
}

.onboarding-shell.access-mode-signin #accessRequestCard,
.onboarding-shell.access-mode-signin .accept-invite-box,
.onboarding-shell.access-mode-request #signin,
.onboarding-shell.access-mode-invite #accessRequestCard,
.onboarding-shell.access-mode-invite #signInForm,
.onboarding-shell.access-mode-invite #signinHelp,
.onboarding-shell.access-mode-invite #authDevHint,
.onboarding-shell.access-mode-invite #authStatus,
.onboarding-shell.access-mode-invite .auth-switch-panel {
  display: none;
}

.access-mode-invite .accept-invite-box {
  border-top: 0;
  padding-top: 0;
}

.small-title {
  margin-top: 8px;
}

.accept-invite-box {
  display: grid;
  gap: 10px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

.auth-switch-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

.auth-switch-panel p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.auth-switch-panel .record-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.auth-switch-panel .record-actions .ghost {
  display: inline-flex;
}

.text-link {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--teal);
  padding: 0;
  font: inherit;
  font-size: 13px;
  font-weight: 900;
  text-align: start;
  cursor: pointer;
}

.text-link:hover {
  text-decoration: underline;
}

.auth-status,
.dev-hint,
.session-summary {
  display: grid;
  gap: 8px;
  min-height: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.auth-status.ok,
.session-summary.ok {
  color: var(--teal);
}

.auth-status.warn,
.dev-hint {
  color: var(--amber);
}

.auth-status.bad {
  color: var(--red);
}

.session-summary {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 10px;
}

.session-summary ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.session-summary li {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.onboarding-card {
  display: grid;
  gap: 10px;
  align-content: start;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 12px;
}

.onboarding-card span {
  display: inline-flex;
  color: var(--teal);
  font-size: 11px;
  font-weight: 900;
}

.onboarding-card strong {
  display: block;
  margin-top: 4px;
}

.onboarding-card p,
.onboarding-card li,
.onboarding-card dd {
  color: var(--muted);
  font-size: 12px;
}

.onboarding-card dl {
  display: grid;
  gap: 6px;
  margin: 0;
}

.onboarding-card dl div {
  display: grid;
  grid-template-columns: minmax(88px, 0.34fr) minmax(0, 1fr);
  gap: 8px;
  align-items: start;
}

.onboarding-card dt {
  color: var(--ink);
  font-size: 11px;
  font-weight: 900;
}

.onboarding-card dd {
  margin: 0;
}

.onboarding-card ul {
  margin: 0;
  padding-inline-start: 18px;
}

.api-bridge-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.api-summary-line {
  margin-top: 10px;
  color: var(--muted);
  font-weight: 800;
}

.api-snapshot {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.api-snapshot > strong {
  color: var(--ink);
}

.api-snapshot-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.api-snapshot-grid article {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-2);
  padding: 9px;
}

.api-snapshot-grid span,
.api-snapshot-grid strong {
  display: block;
}

.api-snapshot-grid span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.api-snapshot-grid strong {
  margin-top: 3px;
  color: var(--ink);
  font-size: 18px;
}

.status-ok {
  color: var(--teal);
}

.status-warn {
  color: var(--amber);
}

.run-match-list {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.run-match-list li {
  display: grid;
  gap: 2px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-2);
  padding: 8px;
}

.console {
  display: grid;
  grid-template-columns: 304px minmax(0, 1fr);
  gap: 0;
  min-height: 100vh;
}

.app-rail {
  position: sticky;
  top: 0;
  height: 100vh;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: var(--space-3);
  border-right: 1px solid var(--line);
  background: #fff;
  padding: var(--space-4);
}

.rail-brand {
  padding: 4px 2px 10px;
  border-bottom: 1px solid var(--line);
}

.rail-brand small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.app-nav {
  display: grid;
  align-content: start;
  gap: var(--space-2);
  overflow: auto;
  padding-right: 2px;
}

.rail-section-label {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0;
  padding: 4px 6px 0;
}

.rail-advanced {
  display: grid;
  gap: var(--space-2);
  margin-top: 4px;
}

.rail-advanced summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--muted);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  padding: 0 10px;
  list-style: none;
}

.rail-advanced summary::-webkit-details-marker {
  display: none;
}

.rail-advanced[open] summary svg {
  transform: rotate(180deg);
}

.rail-item {
  display: grid;
  grid-template-columns: 30px 22px minmax(0, 1fr);
  grid-template-areas:
    "step icon title"
    "step icon meta";
  justify-content: start;
  width: 100%;
  min-height: 64px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--ink);
  padding: 10px;
  text-align: left;
  white-space: normal;
}

.rail-item.compact {
  min-height: 58px;
  padding-block: 8px;
}

.rail-item:hover,
.rail-item.active {
  border-color: var(--line);
  background: var(--surface-2);
  filter: none;
}

.rail-item.active {
  box-shadow: inset 4px 0 0 var(--teal);
}

html[dir="rtl"] .rail-item.active {
  box-shadow: inset -4px 0 0 var(--teal);
}

.rail-item span {
  grid-area: step;
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--soft-blue);
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
}

.rail-item svg {
  grid-area: icon;
  align-self: center;
  color: var(--teal);
}

.rail-item strong {
  grid-area: title;
  min-width: 0;
  overflow-wrap: anywhere;
}

.rail-item small {
  grid-area: meta;
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.source-box {
  display: grid;
  gap: 2px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

.source-box span,
.source-box small,
.section-title span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.source-box strong,
.source-box small {
  overflow-wrap: anywhere;
}

.console-main {
  min-width: 0;
}

.console-top {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 82px;
  border-bottom: 1px solid var(--line);
  background: rgba(243, 245, 247, 0.92);
  backdrop-filter: blur(14px);
  padding: 14px 24px;
}

.console-title-block {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.console-title-block h2,
.console-title-block span {
  overflow-wrap: anywhere;
}

.console-title-block > span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.console-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.utility-menu {
  position: relative;
}

.utility-menu summary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  cursor: pointer;
  font-weight: 900;
  list-style: none;
  padding: 0 14px;
}

.utility-menu summary::-webkit-details-marker {
  display: none;
}

.utility-menu > div {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 35;
  display: grid;
  gap: 8px;
  min-width: 190px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
  padding: 10px;
}

.utility-menu:not([open]) > div {
  display: none;
}

html[dir="rtl"] .utility-menu > div {
  right: auto;
  left: 0;
}

.utility-menu button {
  justify-content: flex-start;
  width: 100%;
}

.compact-label {
  display: grid;
  grid-template-columns: auto minmax(190px, 1fr);
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.content {
  display: grid;
  gap: var(--space-5);
  min-width: 0;
  padding: 22px 24px 42px;
}

.view {
  display: none;
  gap: var(--space-5);
}

.view.active {
  display: grid;
}

.view-head {
  justify-content: space-between;
  align-items: flex-start;
  min-height: 68px;
  gap: var(--space-4);
}

.view-head > div:first-child {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
  max-width: 920px;
}

.panel,
.kpi,
.health-item,
.action-item,
.record-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.panel {
  padding: var(--space-5);
  overflow: hidden;
}

.section-title {
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.section-title span {
  color: var(--faint);
  text-align: right;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: minmax(360px, 0.9fr) minmax(440px, 1.1fr);
  gap: var(--space-5);
  align-items: start;
}

.project-command {
  display: grid;
  grid-template-columns: minmax(260px, 1.4fr) repeat(3, minmax(170px, 1fr));
  gap: var(--space-3);
}

.project-command article {
  display: grid;
  gap: 5px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  padding: var(--space-4);
}

.project-command .command-primary {
  background: var(--ink);
  color: #fff;
}

.project-command span,
.project-command small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.project-command .command-primary span,
.project-command .command-primary small {
  color: rgba(255, 255, 255, 0.72);
}

.project-command strong {
  overflow-wrap: anywhere;
}

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

.dashboard-action-card {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  grid-template-areas:
    "icon label"
    "icon count"
    "icon meta";
  align-items: center;
  justify-items: start;
  gap: 3px 10px;
  min-height: 96px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  padding: var(--space-4);
  text-align: start;
  box-shadow: none;
}

.dashboard-action-card:hover {
  border-color: rgba(23, 103, 120, 0.35);
  background: var(--surface-2);
  filter: none;
}

.dashboard-action-card svg {
  grid-area: icon;
  color: var(--teal);
}

.dashboard-action-card span {
  grid-area: label;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.dashboard-action-card strong {
  grid-area: count;
  font-size: 18px;
  overflow-wrap: anywhere;
}

.dashboard-action-card small {
  grid-area: meta;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.dashboard-grid > .panel:nth-child(3) {
  grid-column: 1 / -1;
}

.autopilot-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.75fr);
  gap: var(--space-5);
  align-items: center;
  background: linear-gradient(180deg, #ffffff, #f7faf9);
}

.autopilot-hero h2 {
  max-width: 760px;
  font-size: 34px;
  line-height: 1.12;
}

.autopilot-hero p:not(.eyebrow) {
  max-width: 760px;
  margin-top: var(--space-3);
  color: var(--muted);
  font-size: 16px;
}

.autopilot-promise {
  display: grid;
  gap: var(--space-2);
}

.autopilot-promise span {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--ink);
  font-weight: 800;
  padding: 12px;
}

.autopilot-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: var(--space-3);
}

.autopilot-card {
  display: grid;
  justify-items: start;
  align-content: start;
  gap: var(--space-2);
  min-height: 184px;
  border-color: var(--line);
  background: var(--surface);
  color: var(--ink);
  padding: var(--space-4);
  text-align: start;
  white-space: normal;
  box-shadow: var(--shadow-soft);
}

.autopilot-card:hover {
  border-color: var(--teal);
  filter: none;
}

.autopilot-card svg {
  width: 22px;
  height: 22px;
  color: var(--teal);
}

.autopilot-card span {
  font-size: 17px;
  font-weight: 900;
}

.autopilot-card small {
  color: var(--muted);
  font-weight: 700;
  line-height: 1.45;
}

.autopilot-card strong {
  align-self: end;
  color: var(--blue);
}

.autopilot-grid {
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(360px, 1fr);
  gap: var(--space-5);
  align-items: start;
}

.daily-flow {
  margin-block: var(--space-4);
}

.project-story {
  display: grid;
  gap: var(--space-4);
  border-color: rgba(34, 111, 95, 0.22);
  background: linear-gradient(180deg, #ffffff, #f6fbf9);
}

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

.project-story-summary article {
  display: grid;
  gap: 6px;
  min-height: 96px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  padding: 12px;
}

.project-story-summary span,
.project-story-steps span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.project-story-summary strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

.project-story-summary small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.35;
}

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

.project-story-step {
  display: grid;
  align-content: start;
  justify-items: start;
  gap: 8px;
  min-height: 176px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--ink);
  padding: 14px;
  text-align: start;
  white-space: normal;
  box-shadow: var(--shadow-soft);
}

.project-story-step:hover {
  border-color: var(--teal);
  filter: none;
}

.project-story-step svg {
  width: 21px;
  height: 21px;
  color: var(--teal);
}

.project-story-step strong {
  font-size: 15px;
  font-weight: 900;
  line-height: 1.3;
}

.project-story-step p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.45;
}

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

.daily-flow-steps article {
  display: grid;
  gap: 6px;
  min-height: 112px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  padding: 12px;
}

.daily-flow-steps span,
.supplier-workflow-step span {
  color: var(--teal);
  font-size: 12px;
  font-weight: 900;
}

.daily-flow-steps strong,
.supplier-workflow-step strong {
  color: var(--ink);
  font-weight: 900;
}

.daily-flow-steps p,
.supplier-workflow-step small {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.45;
}

.autopilot-grid .record-card header {
  align-items: center;
}

.autopilot-grid .record-card button {
  min-height: 34px;
  padding: 0 12px;
}

.autopilot-inline-action {
  width: auto;
  color: var(--ink);
}

.health-list,
.action-list,
.record-list,
.preset-list,
.log-list,
.claims-list {
  display: grid;
  gap: var(--space-3);
}

.compact-list,
.claims-list {
  max-height: 650px;
  overflow: auto;
  padding-right: 4px;
}

.health-item,
.action-item,
.record-card,
.log-item,
.claim {
  display: grid;
  gap: var(--space-2);
  padding: 14px;
  box-shadow: none;
}

.health-item {
  border-left-width: 5px;
}

.health-item.ok {
  border-left-color: var(--teal);
}

.health-item.warn {
  border-left-color: var(--amber);
}

.health-item.danger,
.record-card.danger {
  border-left: 5px solid var(--red);
}

.record-card.ok {
  border-left: 5px solid var(--teal);
}

.record-card.warn {
  border-left: 5px solid var(--amber);
}

.health-item span,
.action-item span,
.record-card span,
.log-item span,
.claim span,
.meta-line,
label {
  color: var(--muted);
}

.health-item strong,
.action-item strong {
  overflow-wrap: anywhere;
}

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(185px, 1fr));
  gap: var(--space-3);
}

.kpi {
  min-height: 118px;
  padding: var(--space-4);
  border-left-width: 5px;
}

.kpi span,
.kpi small {
  display: block;
  color: var(--muted);
}

.kpi strong {
  display: block;
  margin: 8px 0 6px;
  font-size: 22px;
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.kpi.blue {
  border-left-color: var(--blue);
  background: linear-gradient(180deg, var(--soft-blue), #fff 76%);
}

.kpi.green {
  border-left-color: var(--teal);
  background: linear-gradient(180deg, var(--soft-teal), #fff 76%);
}

.kpi.amber {
  border-left-color: var(--amber);
  background: linear-gradient(180deg, var(--soft-amber), #fff 76%);
}

.kpi.red {
  border-left-color: var(--red);
  background: linear-gradient(180deg, var(--soft-red), #fff 76%);
}

.kpi.violet {
  border-left-color: var(--violet);
  background: linear-gradient(180deg, var(--soft-violet), #fff 76%);
}

.ingest-grid,
.plan-grid,
.notification-grid {
  display: grid;
  grid-template-columns: minmax(340px, 0.82fr) minmax(420px, 1fr);
  gap: var(--space-5);
  align-items: start;
}

.schedule-exchange-panel {
  grid-column: 1 / -1;
}

.planning-autopilot-panel {
  grid-column: 1 / -1;
}

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

.phase-draft-card {
  display: grid;
  gap: var(--space-3);
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  padding: var(--space-4);
}

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

.phase-draft-card header div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.phase-draft-card header strong,
.phase-draft-card header span,
.phase-draft-card p {
  overflow-wrap: anywhere;
}

.phase-draft-card header span,
.phase-draft-card p {
  color: var(--muted);
  font-size: 13px;
}

.phase-draft-card header select {
  max-width: 160px;
}

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

.schedule-import-zone {
  min-height: 86px;
  margin-top: var(--space-4);
}

.schedule-export-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: var(--space-4) 0;
}

.schedule-export-actions button {
  min-height: 42px;
}

.schedule-import-compare {
  max-height: 420px;
  overflow: auto;
  padding-inline-end: 4px;
}

.board-grid {
  display: grid;
  grid-template-columns: minmax(340px, 390px) minmax(0, 1fr);
  gap: var(--space-5);
  align-items: start;
}

.capture-grid {
  display: grid;
  grid-template-columns: minmax(340px, 390px) minmax(430px, 1fr) minmax(330px, 0.86fr);
  gap: var(--space-5);
  align-items: start;
}

.document-grid,
.subcontracts-grid,
.procurement-grid,
.supplier-grid,
.commercial-grid {
  display: grid;
  grid-template-columns: minmax(330px, 380px) minmax(300px, 340px) minmax(0, 1fr);
  gap: var(--space-5);
  align-items: start;
}

.supplier-grid {
  grid-template-columns: minmax(330px, 0.9fr) minmax(330px, 0.84fr) minmax(380px, 1fr);
}

.supplier-command-panel {
  grid-column: 1 / -1;
}

.supplier-guided-lane {
  display: grid;
  gap: var(--space-4);
  margin: 0 0 var(--space-4);
  padding: var(--space-4);
  border: 1px solid color-mix(in srgb, var(--teal) 34%, var(--line));
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(42, 157, 143, 0.1), rgba(243, 156, 18, 0.08)),
    #fff;
}

.guided-lane-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
}

.guided-lane-head div {
  display: grid;
  gap: 4px;
}

.guided-lane-head span,
.guided-lane-card span {
  color: var(--teal-strong);
  font-size: 12px;
  font-weight: 900;
}

.guided-lane-head strong {
  color: var(--ink);
  font-size: 22px;
}

.guided-lane-head p,
.guided-lane-card p {
  color: var(--muted);
  font-size: 13px;
}

.guided-lane-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.guided-lane-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.86);
  padding: 14px;
  box-shadow: 0 10px 25px rgba(37, 48, 52, 0.06);
}

.guided-lane-card.warn {
  border-top: 4px solid var(--amber);
}

.guided-lane-card.danger {
  border-top: 4px solid var(--danger);
}

.guided-lane-card.ok {
  border-top: 4px solid var(--teal);
}

.guided-lane-card header {
  display: flex;
  align-items: center;
  gap: 10px;
}

.guided-lane-card header i {
  width: 30px;
  height: 30px;
  padding: 6px;
  border-radius: 8px;
  background: rgba(42, 157, 143, 0.12);
  color: var(--teal-strong);
}

.guided-lane-card header div {
  display: grid;
  min-width: 0;
}

.guided-lane-card strong {
  color: var(--ink);
  font-size: 15px;
}

.guided-lane-card small {
  color: var(--muted);
  line-height: 1.45;
}

.guided-lane-card footer {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-self: end;
}

.guided-lane-card footer button {
  width: auto;
  min-height: 34px;
  padding: 0 11px;
}

.supplier-workflow-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: var(--space-4);
}

.supplier-workflow-step {
  display: grid;
  justify-items: start;
  gap: 5px;
  min-height: 100px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfdfc;
  color: var(--ink);
  padding: 12px;
  text-align: start;
  white-space: normal;
}

.supplier-workflow-step:hover {
  border-color: var(--teal);
  filter: none;
}

.supplier-command-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: var(--space-4);
}

.supplier-command-grid article {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  padding: 12px;
}

.supplier-command-grid article.ok {
  border-left: 5px solid var(--teal);
}

.supplier-command-grid article.warn {
  border-left: 5px solid var(--amber);
}

.supplier-command-grid article strong {
  color: var(--ink);
  font-size: 24px;
  line-height: 1;
}

.supplier-command-grid article span {
  color: var(--ink);
  font-size: 13px;
  font-weight: 900;
}

.supplier-command-grid article p {
  color: var(--muted);
  font-size: 12px;
}

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

.supplier-board-grid > section {
  min-width: 0;
}

.supplier-board-grid .record-list {
  max-height: 460px;
  overflow: auto;
  padding-inline-end: 2px;
}

.card-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.card-action-row button {
  width: auto;
  min-height: 34px;
  padding: 0 11px;
}

.copy-output {
  min-height: 172px;
  background: var(--surface-2);
  color: var(--ink);
  resize: vertical;
}

.report-grid {
  display: grid;
  grid-template-columns: minmax(320px, 370px) minmax(310px, 360px) minmax(0, 1fr);
  gap: var(--space-5);
  align-items: start;
}

.admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(300px, 1fr));
  gap: var(--space-5);
  align-items: start;
}

.wide-panel {
  grid-column: span 1;
}

.admin-grid .wide-panel {
  grid-column: 1 / -1;
}

.scope-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-3);
}

.scope-metric {
  display: grid;
  gap: var(--space-2);
  min-height: 124px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-soft);
  padding: var(--space-4);
}

.scope-metric span,
.scope-metric small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.scope-metric strong {
  color: var(--ink);
  font-size: 22px;
  line-height: 1.18;
  overflow-wrap: anywhere;
}

.scope-metric[data-tone="risk"] {
  border-left: 5px solid var(--amber);
}

.scope-metric[data-tone="ok"] {
  border-left: 5px solid var(--teal);
}

.scope-metric[data-tone="money"] {
  border-left: 5px solid var(--blue);
}

.scope-metric[data-tone="work"] {
  border-left: 5px solid var(--violet);
}

html[dir="rtl"] .scope-metric[data-tone] {
  border-left-width: 1px;
  border-right-width: 5px;
}

html[dir="rtl"] .scope-metric[data-tone="risk"] {
  border-right-color: var(--amber);
}

html[dir="rtl"] .scope-metric[data-tone="ok"] {
  border-right-color: var(--teal);
}

html[dir="rtl"] .scope-metric[data-tone="money"] {
  border-right-color: var(--blue);
}

html[dir="rtl"] .scope-metric[data-tone="work"] {
  border-right-color: var(--violet);
}

.setup-panel,
.certificate-panel {
  position: sticky;
  top: 92px;
}

.payment-line {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.payment-line span,
.payment-line a {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  padding: 5px 8px;
}

.payment-line a {
  color: var(--blue);
  text-decoration: none;
}

.payment-reconciliation-panel > button {
  width: 100%;
  margin-bottom: 12px;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.status-pill.ok {
  background: var(--soft-teal);
  color: var(--teal);
}

.status-pill.bad {
  background: var(--soft-red);
  color: var(--red);
}

.upload-panel,
.form-stack,
.capture-panel,
.field-grid {
  display: grid;
  gap: var(--space-3);
}

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

label {
  display: grid;
  gap: var(--space-2);
  font-size: 12px;
  font-weight: 800;
}

.checkbox-line {
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 10px;
  color: var(--muted);
  line-height: 1.55;
}

.checkbox-line input {
  width: 18px;
  min-height: 18px;
  margin-top: 3px;
}

input,
select,
textarea {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  color: var(--ink);
  padding: 9px 11px;
}

textarea {
  resize: vertical;
  line-height: 1.45;
}

input:focus,
select:focus,
textarea:focus,
button:focus-visible {
  outline: 2px solid rgba(35, 87, 137, 0.28);
  outline-offset: 2px;
}

.upload-zone,
.mini-upload {
  display: grid;
  place-items: center;
  gap: 8px;
  min-height: 210px;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius);
  background: linear-gradient(180deg, #fff, #f7faf9);
  color: var(--ink);
  text-align: center;
  cursor: pointer;
  padding: 22px;
}

.mini-upload {
  min-height: 104px;
  padding: 14px;
}

.upload-zone.dragover,
.mini-upload.dragover {
  border-color: var(--teal);
  background: var(--soft-teal);
}

.upload-zone input,
.mini-upload input {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
}

.upload-zone small,
.mini-upload small {
  max-width: 520px;
  color: var(--muted);
}

.upload-mark {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 8px;
  background: var(--soft-blue);
  color: var(--blue);
  font-size: 30px;
  line-height: 1;
}

.schema-hints {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.schema-hints span,
.tag,
.attachment-pill,
.status-chip {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  min-height: 26px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--muted);
  padding: 3px 8px;
  font-size: 12px;
  font-weight: 800;
}

.summary-list {
  display: grid;
  gap: 10px;
}

.summary-list ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.summary-list li {
  display: grid;
  gap: 4px;
  min-height: 76px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  padding: 12px;
}

.summary-list li strong {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.summary-list li span {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 20px;
}

.table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

#view-scope .table-wrap {
  max-height: calc(100vh - 360px);
  min-height: 420px;
  overflow: auto;
}

.responsive-card-list {
  display: none;
  gap: var(--space-3);
}

.responsive-record {
  display: grid;
  gap: var(--space-3);
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: var(--space-4);
  overflow: hidden;
}

.responsive-record header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-3);
  align-items: start;
}

.responsive-record header > div {
  display: grid;
  gap: 4px;
  min-width: 0;
  flex: 1 1 190px;
}

.responsive-record header > button,
.responsive-record header > .status-pill,
.responsive-record header > .status-chip {
  flex: 0 0 auto;
}

.responsive-record header span,
.responsive-record p {
  min-width: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.responsive-record strong {
  min-width: 0;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.record-card,
.log-item,
.claim {
  min-width: 0;
  overflow-wrap: anywhere;
}

.record-card * {
  min-width: 0;
}

table {
  width: 100%;
  min-width: 1240px;
  border-collapse: collapse;
  background: #fff;
}

.compact table {
  min-width: 920px;
}

th,
td {
  border-bottom: 1px solid var(--line);
  padding: 10px 11px;
  text-align: left;
  vertical-align: middle;
}

html[dir="rtl"] th,
html[dir="rtl"] td {
  text-align: right;
}

th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #eef3f5;
  color: #334148;
  font-size: 12px;
  font-weight: 800;
}

td {
  color: #273238;
  font-size: 14px;
}

td input,
td select {
  min-width: 96px;
  min-height: 36px;
  padding: 7px 9px;
}

td:nth-child(2) input {
  min-width: 260px;
}

td:nth-child(11),
td:nth-child(12),
.numeric,
.number {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

tr:last-child td {
  border-bottom: 0;
}

.empty-cell {
  height: 90px;
  color: var(--muted);
  text-align: center;
}

.good {
  color: var(--teal);
  font-weight: 800;
}

.bad {
  color: var(--red);
  font-weight: 800;
}

.timeline {
  display: grid;
  gap: 10px;
}

.timeline-row {
  display: grid;
  grid-template-columns: minmax(180px, 270px) minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.timeline-row > div:first-child {
  min-width: 0;
}

.timeline-row > div:first-child strong,
.timeline-row > div:first-child span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.timeline-row > div:first-child span {
  color: var(--muted);
}

.bar-track {
  position: relative;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: repeating-linear-gradient(90deg, #f2f5f7, #f2f5f7 23px, #e8eef1 24px);
  overflow: hidden;
}

.bar {
  position: absolute;
  top: 4px;
  bottom: 4px;
  border-radius: 4px;
  background: var(--blue);
  overflow: hidden;
}

.bar i {
  display: block;
  height: 100%;
  background: var(--teal);
}

.bar.lag {
  background: #d4a24e;
}

.evidence-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 32px;
}

.evidence-strip > img {
  width: 72px;
  height: 72px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  object-fit: cover;
  overflow: hidden;
}

.pdf-chip {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-2);
  color: var(--muted);
  padding: 5px 8px;
  font-size: 12px;
  font-weight: 800;
  overflow-wrap: anywhere;
}

.tiny {
  min-height: 26px;
  border-color: var(--line);
  background: #fff;
  color: var(--red);
  padding: 0 8px;
  font-size: 12px;
}

.record-card header,
.claim > div:first-child,
.log-item header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}

.record-card header > div,
.log-item header > div,
.claim > div:first-child > div {
  display: grid;
  gap: 4px;
  min-width: 0;
  flex: 1 1 180px;
}

.record-card header > .status-pill,
.record-card header > .status-chip,
.log-item header > .status-pill,
.claim > div:first-child > .status-pill {
  flex: 0 0 auto;
}

.record-card p,
.claim p,
.log-item p {
  color: #334148;
}

.meta-line {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  font-size: 12px;
}

.claim dl,
.certificate-grid,
.mini-dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

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

.mini-dl {
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.record-card .mini-dl {
  grid-template-columns: repeat(auto-fit, minmax(108px, 1fr));
}

#view-suppliers .record-card .mini-dl {
  grid-template-columns: 1fr;
}

.claim dl div,
.certificate-grid div,
.mini-dl div {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-2);
  padding: 9px;
}

.claim dt,
.certificate-grid dt,
.mini-dl dt {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.claim dd,
.certificate-grid dd,
.mini-dl dd {
  margin: 2px 0 0;
  font-weight: 800;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.mini-dl dd {
  overflow-wrap: normal;
  word-break: normal;
}

.claim.monitor {
  border-left: 4px solid var(--amber);
}

.role-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.role-grid article {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
  padding: 12px;
}

.role-grid p {
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
}

.report-preview {
  max-height: 680px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  padding: 18px;
}

.server-report-block {
  overflow: auto;
  max-width: 100%;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-2);
  padding: 12px;
  color: var(--ink);
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  font-size: 12px;
  line-height: 1.5;
  white-space: pre-wrap;
}

.print-doc {
  display: grid;
  gap: 12px;
  max-width: 980px;
  margin: 0 auto;
  color: #172024;
}

.print-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 3px solid #1f3138;
  padding-bottom: 10px;
}

.print-header strong,
.print-header span {
  display: block;
}

.print-header strong {
  font-size: 20px;
}

.print-header span,
.report-section li,
.report-section p,
footer {
  color: var(--muted);
}

.report-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.report-kpis div {
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 6px;
  padding: 9px;
}

.report-kpis span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.report-kpis strong {
  display: block;
  font-size: 17px;
  line-height: 1.2;
}

.report-section {
  break-inside: avoid;
}

.report-section h4 {
  margin-bottom: 8px;
  border-left: 4px solid var(--teal);
  background: #24333a;
  color: #fff;
  padding: 7px 9px;
  font-size: 13px;
}

.report-section ul {
  margin: 8px 0 0 18px;
  padding: 0;
}

.report-section li {
  margin: 5px 0;
}

.report-preview table {
  min-width: 0;
}

footer {
  border-top: 2px solid #1f3138;
  padding-top: 8px;
  font-size: 11px;
}

#reportText {
  margin-top: 10px;
  min-height: 220px;
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  font-size: 12px;
}

.mailto {
  width: max-content;
  color: var(--blue);
  font-size: 12px;
  font-weight: 800;
}

.empty {
  color: var(--muted);
}

.record-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.toast {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 100;
  min-width: 220px;
  max-width: min(420px, calc(100vw - 32px));
  border: 1px solid var(--line);
  border-left: 4px solid var(--teal);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow);
  color: var(--ink);
  padding: 12px 14px;
  transform: translateY(18px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

html[dir="rtl"] .toast {
  right: auto;
  left: 18px;
  border-left-width: 1px;
  border-right: 4px solid var(--teal);
}

.toast.show {
  transform: translateY(0);
  opacity: 1;
}

@media (max-width: 1240px) {
  .console {
    grid-template-columns: 1fr;
  }

  .app-rail {
    position: static;
    height: auto;
    grid-template-rows: auto auto auto;
  }

  .app-nav {
    grid-template-columns: repeat(3, minmax(160px, 1fr));
  }

  .source-box {
    display: none;
  }

  .setup-panel,
  .certificate-panel {
    position: static;
  }

  .dashboard-grid,
  .autopilot-hero,
  .autopilot-grid,
  .board-grid,
  .capture-grid,
  .document-grid,
  .subcontracts-grid,
  .procurement-grid,
  .supplier-grid,
  .commercial-grid,
  .report-grid,
  .admin-grid {
    grid-template-columns: 1fr;
  }

  .payment-compliance-panel {
    grid-column: 1;
  }

  .payment-readiness-panel {
    grid-column: 1;
  }

  .package-grid,
  .launch-grid,
  .guided-lane-cards,
  .schedule-export-actions,
  .supplier-command-grid,
  .supplier-board-grid,
	  .supplier-workflow-strip,
	  .daily-flow-steps,
	  .home-flow-grid,
	  .project-story-summary,
	  .project-story-steps,
	  .project-command,
	  .dashboard-action-grid,
	  .readiness-grid,
  .compliance-matrix,
  .onboarding-grid,
  .automation-coverage-grid,
  .deployment-grid,
  .phase-draft-list,
  .payment-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .package-overview-hero,
  .package-overview-story,
  .package-overview-story.compact {
    grid-template-columns: 1fr;
  }

  .package-overview-section-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .site-header {
    position: static;
    grid-template-columns: 1fr;
  }

  .site-nav {
    justify-content: flex-start;
    overflow-x: auto;
  }

  .hero {
    grid-template-columns: 1fr;
    min-height: 86vh;
  }

  h1 {
    font-size: 42px;
  }

  .capability-grid,
  .pricing-grid,
	  .package-grid,
	  .home-flow-grid,
	  .guided-lane-cards,
  .schedule-export-actions,
  .deployment-grid,
  .payment-grid,
  .launch-grid,
  .supplier-command-grid,
  .supplier-board-grid,
  .supplier-workflow-strip,
  .daily-flow-steps,
	  .project-story-summary,
	  .project-story-steps,
	  .project-command,
	  .dashboard-action-grid,
	  .readiness-grid,
  .compliance-matrix,
  .onboarding-shell,
  .onboarding-grid,
  .automation-coverage-grid,
  .workflow-line,
  .autopilot-actions,
  .ingest-grid,
  .plan-grid,
  .document-grid,
  .subcontracts-grid,
  .procurement-grid,
  .supplier-grid,
  .commercial-grid,
  .notification-grid,
  .summary-list ul,
  .field-grid,
  .kpi-grid,
  .claim dl,
  .mini-dl,
  .phase-draft-fields,
  .phase-draft-list,
  .report-kpis,
  .api-snapshot-grid,
  .role-grid {
    grid-template-columns: 1fr;
  }

  .auth-card {
    position: static;
  }

  .package-drilldown-page {
    padding: 0;
    place-items: stretch;
  }

  .package-drilldown-shell {
    width: 100%;
    max-height: 100vh;
    border-radius: 0;
    padding: 14px;
  }

  .package-overview-hero,
  .package-story-copy,
  .package-overview-section {
    padding: 14px;
  }

  .package-overview-section-grid {
    grid-template-columns: 1fr;
  }

  .package-story-video video {
    min-height: 220px;
  }

  .package-overview-footer,
  .package-drilldown-top {
    align-items: stretch;
    flex-direction: column;
  }

  .package-close-button {
    align-self: flex-end;
  }

  .guided-lane-head {
    display: grid;
  }

  #view-scope .table-wrap,
  #view-admin .wide-panel .table-wrap.compact {
    display: none;
  }

  #view-scope .responsive-card-list,
  #view-admin .responsive-card-list {
    display: grid;
  }

	  .console-top,
	  .view-head,
	  .record-card header,
	  .print-header {
	    align-items: stretch;
	    flex-direction: column;
	  }

  .console-actions {
    justify-content: stretch;
  }

  .utility-menu > div {
    position: static;
    margin-top: 8px;
    min-width: 0;
  }

	  #exportJson,
  #loadSample,
  #resetStorage {
    display: none;
  }

  .app-nav {
    display: flex;
    overflow-x: auto;
    padding: 2px 0 10px;
    scroll-snap-type: x proximity;
  }

  .rail-section-label {
    align-self: center;
    flex: 0 0 auto;
    padding-inline: 4px;
    white-space: nowrap;
  }

  .rail-advanced {
    flex: 0 0 210px;
    min-width: 210px;
  }

  .rail-advanced[open] {
    flex-basis: min(82vw, 360px);
  }

  .rail-item {
    flex: 0 0 172px;
    width: 172px;
    scroll-snap-align: start;
  }

  .rail-item.active,
  html[dir="rtl"] .rail-item.active {
    box-shadow: inset 0 -4px 0 var(--teal);
  }

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

  .compact-label {
    grid-template-columns: 1fr;
  }

  .timeline-row {
    grid-template-columns: 1fr;
  }

  button {
    width: 100%;
  }

  .icon-button,
  .tiny {
    width: auto;
  }
}

@media print {
  body {
    background: #fff;
  }

  .site-header,
  .app-rail,
  .console-top,
  .view-head,
  #reportText,
  .toast {
    display: none !important;
  }

  .console,
  .console-main,
  .content,
  .view,
  .panel {
    display: block !important;
    width: auto;
    margin: 0;
    padding: 0;
    border: 0;
    box-shadow: none;
  }

  .view:not(#view-reports) {
    display: none !important;
  }

  .report-preview {
    max-height: none;
    overflow: visible;
    border: 0;
    padding: 0;
  }
}
