/*!*************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[3]!./app/globals.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************/
:root {
  --text: #1d1d1f;
  --text-muted: #6e6e73;
  --line: #e5e5e7;
  --bg: #ffffff;
  --surface: #ffffff;
  --surface-subtle: #fafafa;
  --topnav-link: rgba(29, 29, 31, 0.8);
  --topnav-link-hover: rgba(29, 29, 31, 0.98);
  --primary-bg: #1d1d1f;
  --primary-fg: #ffffff;
  --danger-bg: #fffbfa;
  --danger-fg: #b42318;
  --danger-line: #fecdca;
  --success-bg: #ecfdf3;
  --success-fg: #067647;
  --success-line: #abefc6;
  --status-bg: #ffffff;
  --status-line: #d0d5dd;
  --status-fg: #475467;
  --shadow-lg: 0 20px 50px rgba(16, 24, 40, 0.3);
}

html[data-theme='dark'] {
  --text: #f2f4f7;
  --text-muted: #c3c7cf;
  --line: #2d323a;
  --bg: #101418;
  --surface: #161b22;
  --surface-subtle: #1a2028;
  --topnav-link: rgba(242, 244, 247, 0.78);
  --topnav-link-hover: rgba(242, 244, 247, 0.98);
  --primary-bg: #f2f4f7;
  --primary-fg: #111418;
  --danger-bg: #2a1516;
  --danger-fg: #ff9c93;
  --danger-line: #6f2a2d;
  --success-bg: #102a1c;
  --success-fg: #73e2a7;
  --success-line: #245f43;
  --status-bg: #161b22;
  --status-line: #3a414b;
  --status-fg: #d0d5dd;
  --shadow-lg: 0 20px 50px rgba(0, 0, 0, 0.6);
}

html,
body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial,
    sans-serif;
}

* {
  box-sizing: border-box;
}

.topbar {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 40;
  height: 48px;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
}

.topbar-container,
.page-container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

.topnav {
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.topnav-links {
  display: flex;
  align-items: center;
  gap: 28px;
}

@media (min-width: 1025px) {
  .topnav {
    position: relative;
  }

  .topnav-links {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }

  .topnav-actions {
    margin-left: auto;
  }
}

.topnav-link {
  position: relative;
  color: var(--topnav-link);
  text-decoration: none;
  font-size: 14px;
  line-height: 1;
  transition: color 0.2s ease;
  padding: 4px 0;
}

.topnav-link-button {
  border: 0;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
}

.topnav-link-has-submenu {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.topnav-link-submenu-arrow {
  opacity: 0;
  transform: translateX(-3px);
  transition: opacity 0.18s ease, transform 0.18s ease;
  font-size: 13px;
  line-height: 1;
  color: var(--text-muted);
}

.topnav-link-has-submenu:hover .topnav-link-submenu-arrow,
.topnav-link-has-submenu:focus-visible .topnav-link-submenu-arrow,
.topnav-link-has-submenu.is-open .topnav-link-submenu-arrow {
  opacity: 1;
  transform: translateX(0);
}

.topnav-link:hover {
  color: var(--topnav-link-hover);
}

.topnav-link.is-active {
  color: var(--text);
}

.topnav-link.is-active::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -15px;
  height: 1px;
  background: var(--text);
}

.topbar-submenu-backdrop {
  position: fixed;
  left: 0;
  right: 0;
  top: 48px;
  bottom: 0;
  border: 0;
  background: color-mix(in srgb, var(--bg) 70%, transparent);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  z-index: 34;
}

.topbar-submenu-panel {
  position: fixed;
  left: 0;
  right: 0;
  top: 48px;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  -webkit-backdrop-filter: blur(16px);
          backdrop-filter: blur(16px);
  z-index: 35;
}

.topbar-submenu-content {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
  justify-content: start;
  padding-top: 8px;
  padding-bottom: 10px;
  padding-left: var(--submenu-offset-x, 0px);
}

.topbar-submenu-link {
  min-width: 0;
  border: 0;
  border-radius: 0;
  padding: 2px 0;
  text-decoration: none;
  color: var(--topnav-link);
  font-size: 13px;
  line-height: 1.3;
  text-align: left;
  transition: color 0.2s ease;
}

.topbar-submenu-link:hover {
  color: var(--topnav-link-hover);
}

.topbar-submenu-link.is-active {
  color: var(--text);
  font-weight: 600;
}

.topbar-submenu-link.is-active::after {
  content: '';
  display: block;
  height: 1px;
  margin-top: 3px;
  background: currentColor;
}

.topbar-submenu-link:focus-visible {
  outline: 1px solid var(--line);
  outline-offset: 2px;
}

.topbar-submenu-link-depth-1 {
  padding-left: 14px;
  font-size: 12px;
  color: var(--text-muted);
}

.theme-toggle {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  color: var(--text);
  width: 34px;
  height: 34px;
  padding: 0;
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.theme-toggle-icon {
  font-size: 16px;
  line-height: 1;
}

.topnav-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.topnav-auth {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.topnav-actions-divider {
  width: 1px;
  height: 18px;
  background: var(--line);
}

.menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0 8px;
  cursor: pointer;
}

.menu-toggle span {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 2px;
  background: var(--text);
}

.mobile-menu {
  display: none;
}

.mobile-menu-backdrop {
  display: none;
}

.page-container {
  padding-top: 28px;
  padding-bottom: 40px;
}

.page-content h1 {
  margin: 0 0 12px;
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.page-content p {
  margin: 0 0 10px;
  color: var(--text-muted);
  line-height: 1.5;
}

.home-page {
  display: grid;
  grid-gap: 28px;
  gap: 28px;
  padding-top: 24px;
}

.home-eyebrow {
  margin: 0;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.home-intro {
  max-width: 640px;
  font-size: 17px;
}

.home-showcase {
  position: relative;
  min-height: 640px;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background: #eef2f5;
  overflow: hidden;
}

.home-showcase-media {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
}

.home-showcase-shell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 640px;
  width: min(100%, 1200px);
  margin: 0 auto;
  padding: 40px 16px;
  position: relative;
  z-index: 1;
}

.home-showcase-panel {
  width: min(100%, 760px);
  margin: 0 auto;
  padding: 32px 36px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82) 0%, rgba(255, 255, 255, 0.72) 100%);
  -webkit-backdrop-filter: blur(12px);
          backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.55);
  border-radius: 28px;
  box-shadow: 0 22px 60px rgba(15, 23, 42, 0.16);
}

.home-showcase-content {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  justify-items: center;
}

.home-showcase-content h1 {
  margin: 0;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 0.95;
  letter-spacing: -0.05em;
  text-align: center;
}

.home-showcase-content .home-service-lead,
.home-showcase-content .home-intro,
.home-showcase-content .home-service-points {
  width: 100%;
  max-width: none;
  text-align: left;
}

.home-service-card {
  min-height: 380px;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 22px;
  display: grid;
  align-content: start;
  grid-gap: 14px;
  gap: 14px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--surface-subtle) 100%);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}

.home-service-card h2 {
  margin: 0;
  font-size: 26px;
  line-height: 1.05;
  letter-spacing: -0.03em;
}

.home-service-card-head {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  justify-items: center;
  text-align: center;
}

.home-service-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.home-service-icon svg {
  width: 54px;
  height: 54px;
  color: var(--text);
}

.home-service-card p {
  margin: 0;
}

.home-service-kicker {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  background: rgba(255, 255, 255, 0.62);
  color: var(--text-muted);
}

.home-service-lead {
  font-size: 17px;
  line-height: 1.45;
  color: var(--text);
}

.home-service-points {
  margin: 0;
  padding-left: 18px;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  color: var(--text-muted);
}

.home-service-card-consulting {
  background:
    radial-gradient(circle at top left, rgba(60, 145, 230, 0.18), transparent 42%),
    linear-gradient(180deg, #ffffff 0%, #f3f7fb 100%);
}

.home-service-card-projects {
  background:
    radial-gradient(circle at top left, rgba(30, 136, 84, 0.16), transparent 42%),
    linear-gradient(180deg, #ffffff 0%, #f2f8f4 100%);
}

.home-service-card-training {
  background:
    radial-gradient(circle at top left, rgba(201, 124, 28, 0.18), transparent 42%),
    linear-gradient(180deg, #ffffff 0%, #fbf6ef 100%);
}

@media (max-width: 1024px) {
  .home-showcase {
    min-height: 0;
    margin-left: 0;
    margin-right: 0;
    border-radius: 20px;
  }

  .home-showcase-media {
    background-position: center;
  }

  .home-showcase-shell {
    min-height: 0;
    padding: 18px;
  }

  .home-showcase-panel {
    width: 100%;
    padding: 22px 18px 24px;
    -webkit-clip-path: none;
            clip-path: none;
  }

  .home-showcase-content h1 {
    font-size: 38px;
  }

  .home-service-card {
    min-height: 0;
  }
}

.project-list {
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.project-item {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  background: var(--surface);
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.project-item h2 {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
}

.projects-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.projects-toolbar {
  margin-top: 14px;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.company-new-page .project-form {
  margin-top: 14px;
}

.field-input,
.field-select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 10px;
  font: inherit;
  color: var(--text);
  background: var(--surface);
}

input.field-input,
select.field-select {
  height: 40px;
  min-height: 40px;
  line-height: 1.25;
}

select.field-select {
  padding-top: 0;
  padding-bottom: 0;
}

.field-input:focus,
.field-select:focus {
  outline: 2px solid rgba(0, 113, 227, 0.25);
  outline-offset: 1px;
}

.projects-toolbar .field-input {
  max-width: 380px;
}

.projects-toolbar .field-select {
  width: auto;
  min-width: 150px;
}

.company-details-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 8px 16px;
  gap: 8px 16px;
}

.company-details-title-row {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}

.company-details-title {
  margin: 0;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 650;
  letter-spacing: -0.01em;
}

.company-details-col {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}


.contact-details-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 8px 16px;
  gap: 8px 16px;
}

.contact-details-title-row {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}

.contact-details-title {
  margin: 0;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 650;
  letter-spacing: -0.01em;
}

.contact-details-col {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.contact-details-col p {
  margin: 0;
}

.program-details-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 8px 16px;
  gap: 8px 16px;
}

.program-details-title-row {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}

.program-details-title {
  margin: 0;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 650;
  letter-spacing: -0.01em;
}

.program-details-col {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.program-details-col p {
  margin: 0;
}

.program-projects-picker {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.program-projects-picker-head {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 10px;
  gap: 10px;
  align-items: start;
}

.program-projects-picker-section {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.program-projects-picker-accordion {
  border: 0;
  margin: 0;
  padding: 0;
}

.program-projects-picker-accordion-summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  cursor: pointer;
}

.program-projects-picker-accordion-summary::-webkit-details-marker {
  display: none;
}

.program-projects-picker-accordion-chevron {
  color: var(--text-muted);
  transition: transform 0.18s ease;
}

.program-projects-picker-accordion[open] .program-projects-picker-accordion-chevron {
  transform: rotate(90deg);
}

.program-projects-picker-accordion-body {
  margin-top: 4px;
}

.program-projects-picker-section-title {
  margin: 0;
  font-size: 12px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-weight: 600;
}

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

.program-projects-view-toggle {
  display: inline-flex;
  gap: 8px;
  justify-self: start;
}

.program-projects-view-toggle .btn-secondary {
  min-width: 90px;
}

.program-projects-table {
  min-width: 720px;
}

.program-projects-col-select {
  width: 64px;
  white-space: nowrap;
}

.program-projects-col-select input[type='checkbox'] {
  width: 16px;
  height: 16px;
  cursor: pointer;
}

.program-projects-cards {
  margin-top: 0;
}

.program-projects-card {
  gap: 6px;
}

.program-projects-row-disabled {
  opacity: 0.55;
}

.program-projects-card-disabled {
  opacity: 0.55;
}

.program-projects-linked-note {
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 500;
}

.program-projects-warning-note {
  color: #b42318;
  font-size: 12px;
  font-weight: 600;
}

.program-projects-card-name {
  margin: 0;
  font-size: 16px;
  line-height: 1.3;
  font-weight: 600;
  color: var(--text);
}

.program-projects-card-separator {
  border-bottom: 1px solid var(--line);
  margin: 2px 0 4px;
}

.program-projects-card-select-row {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  width: auto;
  margin-top: 4px;
  white-space: nowrap;
}

.program-projects-card-select-row input[type='checkbox'] {
  width: 16px;
  height: 16px;
  margin: 0;
  flex: 0 0 auto;
}

.program-projects-card-select-text {
  display: inline-block;
  line-height: 1;
}

.project-form .program-projects-card-select-row {
  display: inline-flex;
  grid-auto-flow: column;
  gap: 6px;
}

.project-form .program-projects-picker-section-title {
  display: block;
}

.receipts-toolbar {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 10px 12px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  width: 100%;
}

.receipts-toolbar-section {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  min-width: 0;
}

.receipts-toolbar-accordion {
  border: 0;
  margin: 0;
  padding: 0;
  min-width: 0;
}

.receipts-toolbar-summary {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  min-width: 0;
}

.receipts-toolbar-summary::-webkit-details-marker {
  display: none;
}

.receipts-toolbar-chevron {
  color: var(--text-muted);
  transition: transform 0.18s ease;
}

.receipts-toolbar-accordion[open] .receipts-toolbar-chevron {
  transform: rotate(90deg);
}

.receipts-toolbar-section-display {
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.receipts-toolbar-label {
  margin: 0;
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.receipts-toolbar-row {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  align-items: center;
  min-width: 0;
}

.receipts-toolbar-body {
  margin-top: 8px;
  min-width: 0;
}

.receipts-toolbar-row-primary {
  grid-template-columns: minmax(220px, 1.6fr) repeat(3, minmax(140px, 1fr));
}

.companies-toolbar-row-primary {
  grid-template-columns: minmax(260px, 2fr) minmax(180px, 1fr);
}


.contacts-toolbar-row-primary {
  grid-template-columns: minmax(260px, 2fr);
}

.programs-toolbar-row-primary {
  grid-template-columns: minmax(260px, 2fr);
}

.projects-toolbar-row-primary {
  grid-template-columns: minmax(280px, 2fr) minmax(180px, 1fr);
}

.wbs-toolbar-row-primary {
  grid-template-columns: minmax(260px, 1fr) auto;
}

.receipts-toolbar-row-secondary {
  grid-template-columns: repeat(3, minmax(140px, 1fr)) auto;
}

.receipts-toolbar .field-input {
  max-width: none;
}

.receipts-toolbar .field-select {
  width: 100%;
  min-width: 0;
  max-width: 100%;
}

.receipts-toolbar-row-secondary .btn-secondary {
  justify-self: end;
}

.wbs-view-toggle-inline {
  margin-top: 0;
  justify-content: flex-start;
}

.projects-view-type-section {
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.projects-toolbar-view-row {
  margin-top: 2px;
}

.projects-view-type-label {
  margin: 0;
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.projects-toolbar-view-row .btn-secondary {
  width: auto;
}

.receipts-mobile-list {
  display: none;
  width: 100%;
  min-width: 0;
}

.receipts-mobile-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 12px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  width: 100%;
  min-width: 0;
}

.receipts-mobile-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}

.receipts-mobile-order-number {
  margin: 0;
  font-weight: 600;
  color: var(--text);
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.receipts-mobile-grid {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 8px 12px;
  gap: 8px 12px;
}

.receipts-mobile-grid dt {
  margin: 0;
  font-size: 12px;
  color: var(--text-muted);
}

.receipts-mobile-grid dd {
  margin: 2px 0 0;
  color: var(--text);
  font-size: 13px;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.receipts-mobile-actions {
  display: flex;
  justify-content: center;
}

.receipts-page {
  min-width: 0;
  overflow-x: clip;
}

.btn-primary,
.btn-secondary,
.btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid transparent;
  padding: 8px 14px;
  text-decoration: none;
  font-size: 13px;
  line-height: 1;
  cursor: pointer;
}

.btn-primary {
  color: var(--primary-fg);
  background: var(--primary-bg);
}

.btn-secondary {
  color: var(--text);
  border-color: var(--line);
  background: var(--surface);
}

.btn-secondary.is-active {
  border-color: var(--text);
  background: var(--surface-subtle);
}

.btn-danger {
  color: var(--danger-fg);
  border-color: var(--danger-line);
  background: var(--danger-bg);
}

.project-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.status-badge {
  border: 1px solid var(--status-line);
  background: var(--status-bg);
  color: var(--status-fg);
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 12px;
}

.project-actions {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: center;
}

.project-actions-bottom {
  margin-top: auto;
  padding-top: 12px;
}

.project-title-badges {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.project-card-body {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

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

.project-card-section {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-subtle);
  padding: 10px;
}

.project-card-section h3 {
  margin: 0 0 8px;
  font-size: 13px;
  color: var(--text-muted);
  font-weight: 600;
}

.project-kv-grid {
  margin: 0;
  display: grid;
  grid-gap: 7px;
  gap: 7px;
}

.project-kv-row {
  display: grid;
  grid-template-columns: minmax(90px, 120px) minmax(0, 1fr);
  grid-gap: 8px;
  gap: 8px;
  align-items: baseline;
}

.project-kv-row dt {
  margin: 0;
  color: var(--text-muted);
  font-size: 12px;
}

.project-kv-row dd {
  margin: 0;
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  min-width: 0;
}

.project-kv-grid-budget .project-kv-row dd {
  text-align: right;
  justify-self: end;
}

.project-kv-row dd.variance-0 {
  color: var(--text);
}

.project-kv-row dd.variance-ok {
  color: #067647;
}

.project-kv-row dd.variance-warn {
  color: #b54708;
}

.project-kv-row dd.variance-attn {
  color: #c4320a;
}

.project-kv-row dd.variance-bad {
  color: #b42318;
  font-weight: 600;
}

.project-kv-block {
  grid-template-columns: 1fr;
  gap: 4px;
}

.project-description-clamp {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text-muted);
  font-weight: 400;
}

.text-action {
  color: var(--text);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: normal;
  text-decoration: none;
  cursor: pointer;
}

a.text-action:visited {
  color: var(--text);
}

button.text-action {
  display: inline;
  vertical-align: baseline;
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  font-family: inherit;
  cursor: pointer;
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
}

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

.text-action:focus-visible {
  outline: 2px solid rgba(0, 113, 227, 0.25);
  outline-offset: 1px;
}

.text-action.is-disabled {
  color: var(--text-muted);
  cursor: not-allowed;
  text-decoration: none;
  opacity: 0.75;
}

.danger-action {
  color: #b42318;
}

.company-role-badges {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
}

.inline-details {
  position: relative;
}

.inline-details summary {
  list-style: none;
}

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

.inline-form {
  margin-top: 8px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  max-width: 240px;
}

.inline-form p {
  margin: 0;
}

.inline-form-actions {
  display: flex;
  justify-content: flex-start;
}

.confirm-line {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-muted);
}

.project-form {
  margin-top: 10px;
  max-width: 640px;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.project-form-wide {
  max-width: none;
}

.project-form label {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  font-size: 14px;
}

.project-form-readonly {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  font-size: 14px;
}

.project-form-readonly p {
  margin: 0;
  min-height: 40px;
  display: flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0 10px;
  background: var(--surface-subtle);
  color: var(--text);
}

.roles-fieldset {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.roles-fieldset legend {
  padding: 0 4px;
  color: var(--text-muted);
  font-size: 13px;
}

.roles-fieldset-inline {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: center;
  column-gap: 18px;
}

.project-form .roles-fieldset .confirm-line {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.project-form textarea.field-input {
  resize: vertical;
}

.project-form-layout {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.project-form-section {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-subtle);
  padding: 12px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.project-form-section h2 {
  margin: 0;
  font-size: 16px;
}

.project-form-accordion {
  padding: 0;
}

.project-form-accordion-summary {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  padding: 12px;
  border-bottom: 1px solid var(--line);
}

.project-form-accordion-summary::-webkit-details-marker {
  display: none;
}

.project-form-accordion-summary::before {
  content: '▶';
  color: var(--text-muted);
  font-size: 12px;
  line-height: 1;
  transition: transform 0.18s ease;
}

.project-form-accordion[open] .project-form-accordion-summary::before {
  transform: rotate(90deg);
}

.project-form-accordion-summary h2 {
  margin: 0;
}

.project-form-accordion-body {
  padding: 12px;
}

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

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

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

.project-form-agenda-grid > label {
  min-width: 0;
}

.project-form-agenda-grid input[type='date'].field-input {
  width: 0;
  min-width: 100%;
  max-width: 100%;
  min-inline-size: 100%;
  max-inline-size: 100%;
  height: 40px;
  min-height: 40px;
  padding: 0 10px;
  line-height: 1.25;
}

.project-form-agenda-grid input[type='date'].field-input::-webkit-datetime-edit,
.project-form-agenda-grid input[type='date'].field-input::-webkit-datetime-edit-fields-wrapper,
.project-form-agenda-grid input[type='date'].field-input::-webkit-date-and-time-value {
  min-width: 0;
  max-width: 100%;
  text-align: left;
  padding: 0;
  margin: 0;
}

.project-form-span-2 {
  grid-column: 1 / -1;
}

.project-form-span-3 {
  grid-column: 1 / -1;
}

.project-budget-readonly {
  margin: 0;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.project-budget-readonly > div {
  display: grid;
  grid-template-columns: minmax(90px, 120px) minmax(0, 1fr);
  grid-gap: 8px;
  gap: 8px;
  align-items: baseline;
}

.project-budget-readonly dt {
  margin: 0;
  color: var(--text-muted);
  font-size: 12px;
}

.project-budget-readonly dd {
  margin: 0;
  text-align: right;
  justify-self: end;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.project-budget-note {
  margin: 0;
  font-size: 12px;
  color: var(--text-muted);
}

.order-header-inline {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 10px;
  gap: 10px;
}

.order-header-inline-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 10px;
}

.order-header-inline input[type='date'].field-input {
  width: 0;
  min-width: 100%;
  max-width: 100%;
  min-inline-size: 100%;
  max-inline-size: 100%;
  height: 40px;
  min-height: 40px;
  padding: 0 10px;
  line-height: 1.25;
}

.order-header-inline input[type='date'].field-input::-webkit-datetime-edit,
.order-header-inline input[type='date'].field-input::-webkit-datetime-edit-fields-wrapper,
.order-header-inline input[type='date'].field-input::-webkit-date-and-time-value {
  min-width: 0;
  max-width: 100%;
  text-align: left;
  padding: 0;
  margin: 0;
}

.order-info-panel {
  margin-top: 12px;
  padding: 0;
}

.order-info-accordion-header {
  border-bottom: 1px solid var(--line);
}

.order-info-toggle {
  border: 0;
  background: transparent;
  color: inherit;
  width: 100%;
  padding: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  cursor: pointer;
}

.order-info-chevron {
  color: var(--text-muted);
  transition: transform 0.18s ease;
}

.order-info-chevron.is-open {
  transform: rotate(90deg);
}

.order-info-title h2 {
  margin: 0;
  font-size: 16px;
}

.order-info-accordion-body {
  margin-top: 0;
  padding: 12px;
}

.orders-list-table-wrap {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: auto;
  background: var(--surface);
}

.orders-list-table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
  font-size: 13px;
  line-height: 1.3;
  color: var(--text);
}

.interactive-list-table {
  min-width: 0;
}

.orders-list-table th,
.orders-list-table td {
  border-bottom: 1px solid var(--line);
  text-align: left;
  padding: 9px 10px;
  vertical-align: top;
  background: var(--surface);
}

.orders-list-table th {
  color: var(--text-muted);
  font-weight: 600;
  white-space: nowrap;
}

.orders-list-col-order,
.orders-list-col-date,
.orders-list-col-total {
  white-space: nowrap;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.orders-list-col-project {
  min-width: 220px;
}

.orders-list-col-actions {
  min-width: 150px;
}

.orders-list-actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.projects-list-table {
  min-width: 0;
  table-layout: fixed;
}

.projects-list-table th,
.projects-list-table td {
  padding: 8px;
}

.projects-list-table th {
  white-space: nowrap;
}

.interactive-list-table th {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.interactive-list-table.is-resizing {
  cursor: col-resize;
}

.interactive-col-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.interactive-col-resize-handle {
  width: 10px;
  min-width: 10px;
  align-self: stretch;
  cursor: col-resize;
  border-right: 1px solid var(--line);
  opacity: 0.8;
}

.interactive-col-resize-handle:hover {
  border-right-color: var(--text-muted);
}

.interactive-list-table-controls {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.projects-columns-menu,
.interactive-columns-menu {
  position: relative;
}

.projects-columns-menu summary,
.interactive-columns-menu summary {
  list-style: none;
}

.projects-columns-menu summary::-webkit-details-marker,
.interactive-columns-menu summary::-webkit-details-marker {
  display: none;
}

.projects-columns-menu-body,
.interactive-columns-menu-body {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 20;
  min-width: 180px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.projects-columns-menu-body .confirm-line,
.interactive-columns-menu-body .confirm-line {
  font-size: 13px;
}

.projects-list-col-id {
  white-space: nowrap;
}

.projects-list-col-name {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.projects-list-col-client {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.projects-list-col-program {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.projects-list-col-cost,
.projects-list-col-delivery,
.projects-list-col-wbs {
  white-space: nowrap;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.projects-list-table td {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.projects-list-table .orders-list-col-actions {
  white-space: nowrap;
}

.projects-list-table .orders-list-actions {
  gap: 8px;
  justify-content: flex-start;
}

.projects-list-table .orders-icon-action {
  width: 20px;
  height: 20px;
  font-size: 13px;
}

.interactive-list-table .orders-list-actions {
  gap: 8px;
  justify-content: flex-start;
}

.programs-list-table {
  min-width: 0;
  table-layout: fixed;
}

.programs-list-table th,
.programs-list-table td {
  padding: 8px;
}

.programs-list-table th {
  white-space: nowrap;
}

.programs-list-col-programId,
.programs-list-col-projects,
.programs-list-col-endDate,
.programs-list-col-budget,
.programs-list-col-updated {
  white-space: nowrap;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.programs-list-col-name {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.programs-list-col-portfolio {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.programs-list-table td {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.programs-list-table .orders-list-col-actions {
  white-space: nowrap;
}

.programs-list-table .orders-list-actions {
  gap: 8px;
  justify-content: flex-start;
}

.portfolios-list-col-portfolioId,
.portfolios-list-col-programs,
.portfolios-list-col-projects,
.portfolios-list-col-endDate,
.portfolios-list-col-budget,
.portfolios-list-col-updated {
  white-space: nowrap;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.portfolios-list-col-name {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.orders-mobile-list {
  display: none;
  width: 100%;
  min-width: 0;
}

.orders-mobile-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 12px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  width: 100%;
  min-width: 0;
}

.orders-mobile-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}

.orders-mobile-order-number {
  margin: 0;
  font-weight: 600;
  color: var(--text);
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.orders-mobile-grid {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 8px 12px;
  gap: 8px 12px;
}

.orders-mobile-grid dt {
  margin: 0;
  font-size: 12px;
  color: var(--text-muted);
}

.orders-mobile-grid dd {
  margin: 2px 0 0;
  color: var(--text);
  font-size: 13px;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.orders-mobile-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.orders-icon-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  font-size: 14px;
  line-height: 1;
  text-decoration: none !important;
}

.orders-icon-svg {
  width: 18px;
  height: 18px;
  display: block;
}

.orders-mobile-edit-action .orders-icon-svg {
  width: 20px;
  height: 20px;
}

.orders-icon-action:hover,
.orders-icon-action:focus-visible,
.orders-icon-action:active {
  text-decoration: none !important;
}

.orders-icon-button {
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
}

.orders-icon-button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.orders-mobile-actionbar {
  display: none;
}

.projects-mobile-actionbar {
  display: none;
}

.programs-mobile-actionbar {
  display: none;
}

.companies-mobile-actionbar {
  display: none;
}


.contacts-mobile-actionbar {
  display: none;
}

.project-edit-mobile-actionbar {
  display: none;
}

.orders-lines-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.orders-lines-head h2 {
  margin: 0;
  font-size: 16px;
}

.receipt-lines-panel {
  padding: 0;
}

.order-lines-editor .orders-lines-head,
.receipt-lines-panel .orders-lines-head {
  border-bottom: 1px solid var(--line);
  padding: 12px;
}

.receipt-lines-panel .order-lines-table-wrap {
  margin: 12px;
}

.receipt-lines-panel .order-lines-table td {
  vertical-align: middle;
}

.receipt-history-panel {
  padding: 0;
}

.order-lines-summary {
  margin-top: 8px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 10px;
  background: var(--surface-subtle);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 13px;
}

.order-lines-table-wrap {
  margin-top: 8px;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: auto;
}

.order-lines-footer {
  margin-top: 10px;
  display: flex;
  justify-content: flex-end;
}

.receipt-detail-panel {
  margin-top: 0;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

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

.receipt-project-inline {
  margin-top: 8px;
}

.receipt-project-inline .wbs-readonly {
  margin: 0;
  min-height: 40px;
  display: flex;
  align-items: center;
  min-width: 0;
}

.receipt-project-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.receipt-row-comment {
  margin-bottom: 0;
}

.receipt-comment-field {
  grid-column: 1 / -1;
}

.receipt-form {
  max-width: none;
  margin-top: 0;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.receipt-lines-panel {
  margin-top: 0;
}

.receipt-history-panel {
  margin-top: 0;
}

.receipt-detail-actions {
  margin-top: 0;
  margin-bottom: 0;
}

.receipt-history {
  margin-top: 8px;
}

.receipt-lines-mobile-list {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.receipt-line-mobile-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 10px;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.receipt-line-mobile-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.receipt-line-mobile-supplier {
  margin: 0;
  color: var(--text-muted);
  font-size: 13px;
}

.receipt-line-mobile-description {
  margin: 0;
  font-size: 13px;
  color: var(--text);
}

.receipt-line-mobile-metrics {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 8px;
  gap: 8px;
}

.receipt-line-mobile-metrics dt {
  margin: 0;
  font-size: 12px;
  color: var(--text-muted);
}

.receipt-line-mobile-metrics dd {
  margin: 2px 0 0;
  font-size: 13px;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.receipt-line-mobile-field {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  font-size: 13px;
}

.receipt-history-mobile-list {
  display: none;
}

.receipt-history-mobile-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 10px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.receipt-history-mobile-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.receipt-history-mobile-grid {
  margin: 0;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.receipt-history-mobile-grid dt {
  margin: 0;
  color: var(--text-muted);
  font-size: 12px;
}

.receipt-history-mobile-grid dd {
  margin: 2px 0 0;
  font-size: 13px;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.receipt-history-mobile-empty {
  margin: 0;
}

.order-lines-table {
  width: 100%;
  min-width: 1120px;
  border-collapse: collapse;
  background: var(--surface);
}

.receipt-detail-panel .order-lines-table {
  min-width: 980px;
}

.order-lines-table .col-description {
  width: 16%;
}

.order-lines-table .col-qty {
  width: 78px;
}

.order-lines-table .col-type {
  width: 92px;
}

.order-lines-table .col-line-cost {
  width: 120px;
}

.order-lines-table .col-company {
  width: 180px;
}

.order-lines-table .col-wp {
  width: 190px;
}

.order-lines-table .col-deliverable {
  width: 190px;
}

.order-lines-table th,
.order-lines-table td {
  border-bottom: 1px solid var(--line);
  padding: 8px;
  text-align: left;
  vertical-align: top;
}

.order-lines-table td {
  font-size: 12px;
}

.order-lines-table th {
  font-size: 12px;
  color: var(--text-muted);
  white-space: nowrap;
}

.order-lines-table td .field-input,
.order-lines-table td .field-select {
  min-width: 0;
  font-size: 12px;
}

.order-lines-table td .field-input[type='number'] {
  min-width: 76px;
}

.order-line-cost-cell {
  white-space: nowrap;
  font-size: 13px;
  color: var(--text-muted);
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
  vertical-align: middle !important;
}

.order-line-remove-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  min-height: 22px;
  padding: 0;
  font-size: 16px;
  line-height: 1;
}

.order-line-actions-cell {
  text-align: center;
  vertical-align: middle !important;
}

.order-lines-mobile-list {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  margin-top: 12px;
}

.order-line-mobile-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 10px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.order-line-mobile-head {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.order-line-mobile-footer {
  display: flex;
  justify-content: center;
  margin-top: 2px;
}

.order-line-mobile-accordion summary {
  list-style: none;
}

.order-line-mobile-accordion summary::-webkit-details-marker {
  display: none;
}

.order-line-mobile-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  margin: -10px -10px 0;
  padding: 10px;
  border-bottom: 1px solid var(--line);
}

.order-line-mobile-summary::after {
  content: '▶';
  color: var(--text-muted);
  font-size: 12px;
  transition: transform 0.18s ease;
}

.order-line-mobile-accordion[open] .order-line-mobile-summary::after {
  transform: rotate(90deg);
}

.order-line-mobile-field {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  font-size: 13px;
}

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

.order-line-mobile-grid-stack {
  grid-template-columns: 1fr;
}

.order-line-mobile-cost {
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-subtle);
  padding: 8px 10px;
  display: grid;
  align-content: center;
  grid-gap: 4px;
  gap: 4px;
  font-size: 12px;
  color: var(--text-muted);
}

.order-line-mobile-cost strong {
  color: var(--text);
  font-size: 14px;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.order-line-mobile-remove-btn {
  min-width: 160px;
}

.order-edit-mobile-actionbar {
  display: none;
}

.form-actions {
  display: flex;
  gap: 10px;
}

.error-banner {
  margin-top: 12px;
  border: 1px solid var(--danger-line);
  background: var(--danger-bg);
  color: var(--danger-fg);
  border-radius: 10px;
  padding: 10px 12px;
}

.login-page {
  min-height: calc(100vh - 120px);
  display: grid;
  place-items: center;
  padding: 24px 0 48px;
}

.login-card {
  width: min(100%, 440px);
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in srgb, var(--surface) 94%, var(--surface-subtle));
  box-shadow: var(--shadow-lg);
  padding: 28px;
}

.login-logo {
  display: flex;
  justify-content: center;
  margin-bottom: 14px;
}

.login-logo-image {
  display: block;
  width: 88px;
  height: 88px;
  object-fit: contain;
}

.login-logo-image-dark {
  display: none;
}

.login-logo-image-light {
  display: block;
}

.login-title {
  margin: 0 0 18px;
  text-align: center;
}

html[data-theme='dark'] .login-logo-image-dark {
  display: block;
}

html[data-theme='dark'] .login-logo-image-light {
  display: none;
}

.login-form {
  margin-top: 0;
  max-width: none;
  gap: 16px;
}

.login-actions {
  justify-content: space-between;
  align-items: center;
  margin-top: 6px;
}

.pagination-row {
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.pagination-actions {
  display: flex;
  gap: 8px;
}

.contacts-panel {
  margin-top: 24px;
}

.contacts-panel h2,
.contacts-panel h3 {
  margin: 12px 0;
  font-size: 20px;
}

.company-contacts-table-wrap {
  display: block;
}

.company-contacts-table {
  min-width: 760px;
}

.company-contacts-mobile-list {
  display: none;
}

.wbs-grid {
  margin-top: 16px;
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: 1fr 1fr;
}

.wbs-panel h2 {
  margin: 0;
  font-size: 22px;
}

.wbs-inline-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

@media (max-width: 1024px) {
  .topbar {
    height: auto;
  }

  .topbar-container {
    position: relative;
  }

  .topnav {
    min-height: 48px;
    justify-content: flex-start;
  }

  .topnav-links {
    display: none;
  }

  .menu-toggle {
    display: inline-flex;
  }

  .topnav-actions {
    width: 100%;
    justify-content: space-between;
  }

  .menu-toggle {
    order: 1;
  }

  .theme-toggle {
    order: 2;
  }

  .mobile-menu {
    display: none;
    position: fixed;
    top: 48px;
    left: 0;
    right: 0;
    border-top: 0;
    border-right: 0;
    border-left: 0;
    border-bottom: 1px solid var(--line);
    border-radius: 0;
    background: color-mix(in srgb, var(--surface) 88%, transparent);
    -webkit-backdrop-filter: blur(16px);
            backdrop-filter: blur(16px);
    box-shadow: var(--shadow-lg);
    z-index: 38;
    padding: 10px 16px 12px;
    max-height: calc(100vh - 48px);
    overflow: auto;
  }

  .mobile-menu.is-open {
    display: block;
  }

  .mobile-menu-backdrop {
    display: block;
    position: fixed;
    left: 0;
    right: 0;
    top: 48px;
    bottom: 0;
    border: 0;
    background: color-mix(in srgb, var(--bg) 66%, transparent);
    -webkit-backdrop-filter: blur(10px);
            backdrop-filter: blur(10px);
    z-index: 37;
  }

  .mobile-menu-shell {
    overflow: hidden;
  }

  .mobile-menu-track {
    display: flex;
    width: 200%;
    transition: transform 0.24s ease;
    transform: translateX(0);
  }

  .mobile-menu-track.is-submenu-open {
    transform: translateX(-50%);
  }

  .mobile-menu-panel {
    width: 50%;
    min-width: 50%;
  }

  .mobile-menu-links,
  .mobile-submenu-links {
    display: grid;
    grid-gap: 4px;
    gap: 4px;
  }

  .mobile-menu-link,
  .mobile-submenu-link {
    display: block;
    border: 0;
    border-radius: 0;
    color: var(--text);
    text-decoration: none;
    padding: 8px 10px;
    font-size: 14px;
    min-height: 42px;
    line-height: 1.25;
  }

  .mobile-menu-link:hover,
  .mobile-submenu-link:hover {
    background: var(--surface-subtle);
  }

  .mobile-menu-link.is-active,
  .mobile-submenu-link.is-active {
    background: var(--surface-subtle);
  }

  .mobile-submenu-link-depth-1 {
    padding-left: 22px;
    font-size: 13px;
    color: var(--text-muted);
  }

  .mobile-menu-link-drilldown {
    width: 100%;
    border: 0;
    background: transparent;
    text-align: left;
    font-family: inherit;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
  }

  .mobile-menu-link-caret {
    color: var(--text-muted);
    font-size: 16px;
    line-height: 1;
  }

  .mobile-submenu-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
  }

  .mobile-submenu-back {
    border: 0;
    background: transparent;
    color: var(--text);
    border-radius: 0;
    min-width: 32px;
    min-height: 32px;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    padding: 0;
  }

  .mobile-submenu-back:hover {
    background: var(--surface-subtle);
  }

  .mobile-submenu-title {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--text-muted);
  }
}

@media (max-width: 640px), (max-device-width: 640px) {
  .topnav {
    gap: 16px;
  }

  .topnav-link {
    font-size: 13px;
  }

  .page-content h1 {
    font-size: 24px;
  }

  .projects-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .pagination-row {
    align-items: flex-start;
    flex-direction: column;
  }

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

  .project-sections-grid {
    grid-template-columns: 1fr;
  }

  .project-kv-row {
    grid-template-columns: minmax(76px, 104px) minmax(0, 1fr);
    gap: 6px;
  }

  .company-details-grid {
    grid-template-columns: 1fr;
  }

  .program-details-grid {
    grid-template-columns: 1fr;
  }

  .program-projects-picker-filters {
    grid-template-columns: 1fr;
  }

  .program-projects-view-toggle {
    display: none;
  }

  .company-contacts-table-wrap {
    display: none;
  }

  .company-contacts-mobile-list {
    display: grid;
  }

  .project-form-grid {
    grid-template-columns: 1fr;
  }

  .roles-fieldset-inline {
    grid-template-columns: 1fr;
  }

  .project-form-span-2 {
    grid-column: auto;
  }

  .project-form-span-3 {
    grid-column: auto;
  }

  .project-card-section-info .project-kv-row dd,
  .project-card-section-dates .project-kv-row dd {
    text-align: right;
    justify-self: end;
  }

  .project-actions-bottom {
    align-items: flex-start;
  }

  .companies-toolbar-row-primary,
  .programs-toolbar-row-primary,
  .projects-toolbar-row-primary,
  .wbs-toolbar-row-primary,
  .receipts-toolbar-row-secondary {
    grid-template-columns: 1fr;
  }

  .receipts-toolbar-row-secondary .btn-secondary {
    justify-self: start;
  }

  .receipts-desktop-table {
    display: none;
  }

  .orders-desktop-table {
    display: none;
  }

  .receipts-mobile-list {
    margin-top: 14px;
    display: grid;
    grid-gap: 10px;
    gap: 10px;
  }

  .orders-mobile-list {
    margin-top: 14px;
    display: grid;
    grid-gap: 10px;
    gap: 10px;
  }

  .orders-page {
    padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px));
  }

  .orders-page .orders-new-order-top-btn {
    display: none;
  }

  .orders-page .orders-mobile-actionbar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: flex;
    justify-content: center;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }

  .orders-page .orders-mobile-actionbar .btn-primary {
    border: 0;
    background: transparent;
    color: var(--text);
    border-radius: 0;
    min-height: 44px;
    min-width: 44px;
    padding: 6px 8px;
    font-size: 28px;
    line-height: 1;
    text-decoration: none;
  }

  .projects-page {
    padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px));
  }

  .projects-page .projects-new-project-top-btn {
    display: none;
  }

  .projects-page .projects-mobile-actionbar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: flex;
    justify-content: center;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }

  .projects-page .projects-mobile-actionbar .btn-primary {
    border: 0;
    background: transparent;
    color: var(--text);
    border-radius: 0;
    min-height: 44px;
    min-width: 44px;
    padding: 6px 8px;
    font-size: 28px;
    line-height: 1;
    text-decoration: none;
  }

  .programs-page-blocks {
    padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px));
  }

  .programs-page-blocks .programs-new-program-top-btn {
    display: none;
  }

  .programs-page-blocks .programs-mobile-actionbar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: flex;
    justify-content: center;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }

  .programs-page-blocks .programs-mobile-actionbar .btn-primary {
    border: 0;
    background: transparent;
    color: var(--text);
    border-radius: 0;
    min-height: 44px;
    min-width: 44px;
    padding: 6px 8px;
    font-size: 28px;
    line-height: 1;
    text-decoration: none;
  }

  .companies-page-blocks {
    padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px));
  }

  .companies-page-blocks .companies-new-company-top-btn {
    display: none;
  }

  .companies-page-blocks .companies-mobile-actionbar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: flex;
    justify-content: center;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }

  .companies-page-blocks .companies-mobile-actionbar .btn-primary {
    border: 0;
    background: transparent;
    color: var(--text);
    border-radius: 0;
    min-height: 44px;
    min-width: 44px;
    padding: 6px 8px;
    font-size: 28px;
    line-height: 1;
    text-decoration: none;
  }

  
  .contacts-page-blocks {
    padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px));
  }

  .contacts-page-blocks .contacts-new-contact-top-btn {
    display: none;
  }

  .contacts-page-blocks .contacts-mobile-actionbar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: flex;
    justify-content: center;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }

  .contacts-page-blocks .contacts-mobile-actionbar .btn-primary {
    border: 0;
    background: transparent;
    color: var(--text);
    border-radius: 0;
    min-height: 44px;
    min-width: 44px;
    padding: 6px 8px;
    font-size: 28px;
    line-height: 1;
    text-decoration: none;
  }

  .project-edit-page {
    padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px));
  }

  .project-edit-page .form-actions {
    display: none;
  }

  .project-edit-page .project-edit-mobile-actionbar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-gap: 8px;
    gap: 8px;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }

  .project-edit-page .project-edit-mobile-actionbar .btn-primary,
  .project-edit-page .project-edit-mobile-actionbar .btn-secondary {
    width: 100%;
    min-height: 44px;
    padding: 6px 8px;
    border: 0;
    background: transparent;
    color: var(--text);
    border-radius: 0;
    font-size: 24px;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
  }

  .login-page {
    min-height: auto;
    padding: 8px 0 24px;
  }

  .login-card {
    padding: 20px 16px;
    border-radius: 14px;
    box-shadow: none;
  }

  .login-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .login-actions .btn-primary,
  .login-actions .btn-secondary {
    width: 100%;
    justify-content: center;
  }

  .interactive-list-table-controls {
    display: none;
  }

  .receipts-toolbar {
    padding: 10px;
    overflow-x: clip;
  }

  .receipts-toolbar-summary {
    width: 100%;
    min-width: 0;
  }

  .receipts-toolbar .field-input,
  .receipts-toolbar .field-select,
  .receipts-toolbar .btn-secondary {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .projects-view-type-section {
    display: none;
  }

  .order-edit-page {
    overflow-x: clip;
  }

  .order-edit-page .project-form-accordion-summary {
    padding: 10px;
  }

  .order-edit-page .project-form-accordion-body {
    padding: 10px;
  }

  .order-edit-page .order-lines-summary {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .order-edit-page .order-lines-table-wrap {
    margin-top: 10px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .order-edit-page .order-lines-table {
    min-width: 900px;
  }

  .order-edit-page .order-lines-table th,
  .order-edit-page .order-lines-table td {
    padding: 6px;
  }

  .order-edit-page .order-lines-table td .field-input,
  .order-edit-page .order-lines-table td .field-select {
    font-size: 13px;
  }

  .order-edit-page .order-line-mobile-grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .order-edit-page .order-line-mobile-grid-2.order-line-mobile-grid-stack {
    grid-template-columns: 1fr;
  }

  .order-edit-page .order-lines-footer {
    justify-content: stretch;
  }

  .order-edit-page .order-lines-footer .btn-secondary {
    width: 100%;
  }

  .order-edit-page .form-actions {
    flex-direction: column;
    gap: 8px;
  }

  .order-edit-page .form-actions .btn-primary,
  .order-edit-page .form-actions .btn-secondary,
  .order-edit-page .form-actions .btn-danger {
    width: 100%;
  }

  .order-edit-page {
    padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px));
  }

  .order-edit-page .form-actions {
    display: none;
  }

  .order-edit-page .order-lines-footer {
    display: none;
  }

  .order-edit-page .order-edit-mobile-actionbar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: 8px;
    gap: 8px;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid var(--line);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }

  .order-edit-page .order-edit-mobile-actionbar .btn-primary,
  .order-edit-page .order-edit-mobile-actionbar .btn-secondary,
  .order-edit-page .order-edit-mobile-actionbar .btn-danger {
    width: 100%;
    min-height: 44px;
    padding: 6px 8px;
    border: 0;
    background: transparent;
    border-radius: 0;
    font-size: 24px;
    font-weight: 600;
    line-height: 1;
  }

  .order-edit-page .order-edit-mobile-actionbar .btn-primary {
    color: var(--text);
  }

  .receipt-detail-page {
    overflow-x: clip;
  }

  .receipt-detail-page .receipt-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .receipt-detail-page .receipt-project-inline {
    margin-top: 0;
  }

  .receipt-detail-page .project-form-accordion-summary {
    padding: 10px;
  }

  .receipt-detail-page .project-form-accordion-body {
    padding: 10px;
  }

  .receipt-detail-page .receipt-lines-panel .order-lines-table-wrap {
    display: none;
  }

  .receipt-detail-page .receipt-line-mobile-metrics {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .receipt-detail-page .receipt-history {
    display: none;
  }

  .receipt-detail-page .receipt-history-mobile-list {
    display: grid;
    grid-gap: 10px;
    gap: 10px;
    margin-top: 8px;
  }

  .receipt-detail-page .receipt-history-mobile-card .inline-form {
    max-width: none;
    width: 100%;
  }

  .receipt-detail-page .receipt-history-mobile-card .inline-form-actions {
    justify-content: stretch;
  }

  .receipt-detail-page .receipt-history-mobile-card .inline-form-actions .btn-danger {
    width: 100%;
  }

  .receipt-detail-page .receipt-detail-actions {
    flex-direction: column;
    gap: 8px;
  }

  .receipt-detail-page .receipt-detail-actions .btn-primary,
  .receipt-detail-page .receipt-detail-actions .btn-secondary,
  .receipt-detail-page .receipt-detail-actions .btn-danger {
    width: 100%;
  }

  .receipt-detail-page input[type='date'].field-input {
    width: 0;
    min-width: 100%;
    max-width: 100%;
    min-inline-size: 100%;
    max-inline-size: 100%;
    height: 40px;
    min-height: 40px;
    padding: 0 10px;
    line-height: 1.25;
  }

  .receipt-detail-page input[type='date'].field-input::-webkit-datetime-edit,
  .receipt-detail-page input[type='date'].field-input::-webkit-datetime-edit-fields-wrapper,
  .receipt-detail-page input[type='date'].field-input::-webkit-date-and-time-value {
    min-width: 0;
    max-width: 100%;
    text-align: left;
    padding: 0;
    margin: 0;
  }
}

@media (max-width: 1024px) and (min-width: 641px) {
  .project-sections-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .receipts-toolbar-row-primary {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }

  .companies-toolbar-row-primary {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }

  .programs-toolbar-row-primary {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }

  .contacts-toolbar-row-primary {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }

  .projects-toolbar-row-primary {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }

  .receipts-toolbar-row-secondary {
    grid-template-columns: repeat(2, minmax(160px, 1fr));
  }

  .receipts-toolbar-row-secondary .btn-secondary {
    justify-self: start;
  }
}

.wbs-grid {
  margin-top: 16px;
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.wbs-panel {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  background: var(--surface);
}

.baseline-panel {
  margin-top: 14px;
}

.baseline-form .field-input {
  max-width: 340px;
}

.baseline-note {
  margin-top: 6px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-subtle);
  white-space: pre-wrap;
}

.baseline-empty-note {
  margin-top: 6px;
  color: var(--text-muted);
}

.baseline-meta-block {
  margin-top: 8px;
}

.baseline-last-status {
  margin: 6px 0 0;
  font-size: 12px;
  color: var(--text-muted);
}

.baseline-activity {
  margin-top: 10px;
}

.baseline-activity-list {
  margin: 6px 0 0;
  padding: 0 0 0 12px;
  list-style: none;
  border-left: 2px solid var(--line);
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.baseline-activity-item {
  margin: 0;
  padding: 0 0 0 10px;
}

.baseline-activity-item p {
  margin: 4px 0 0;
}

.baseline-activity-head {
  display: flex;
  gap: 8px;
  align-items: center;
}

.baseline-activity-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--status-line);
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 11px;
  color: var(--status-fg);
}

.baseline-activity-time {
  color: var(--text-muted);
  font-size: 12px;
}

.form-error-inline {
  width: 100%;
  margin: 2px 0 0;
  border: 1px solid var(--danger-line);
  border-radius: 8px;
  background: var(--danger-bg);
  color: var(--danger-fg);
  padding: 7px 9px;
  font-size: 12px;
}

.edit-inline-alert {
  border: 1px solid var(--danger-line);
  background: var(--danger-bg);
  color: var(--danger-fg);
  border-radius: 10px;
  padding: 10px 12px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.edit-inline-alert p {
  margin: 0;
}

.edit-inline-alert-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.form-success-inline {
  margin-top: 12px;
  border: 1px solid var(--success-line);
  background: var(--success-bg);
  color: var(--success-fg);
  border-radius: 10px;
  padding: 10px 12px;
}

.revision-target-card {
  margin-top: 10px;
}

.revision-target-card p {
  margin: 0;
}

.revision-form {
  margin-top: 12px;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(16, 24, 40, 0.5);
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.modal-dialog {
  width: min(900px, 92vw);
  max-height: 90vh;
}

.modal-content {
  background: var(--surface);
  border-radius: 12px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.modal-sheet-handle {
  display: none;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  background: var(--surface-subtle);
}

.modal-header h3 {
  margin: 0;
  font-size: 16px;
}

.modal-close {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  padding: 4px 8px;
  cursor: pointer;
}

.modal-body {
  padding: 12px 14px;
  overflow-x: auto;
  background: var(--surface);
}

.modal-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  font-size: 13px;
  line-height: 1.3;
  background: var(--surface);
  color: var(--text);
}

.modal-table th,
.modal-table td {
  border-bottom: 1px solid var(--line);
  text-align: left;
  padding: 8px 10px;
  vertical-align: top;
  background: var(--surface);
}

.modal-table th {
  color: var(--text-muted);
  font-weight: 600;
}

.modal-table .rev-col,
.modal-table .date-col,
.modal-table .delta-col,
.modal-table .budget-col,
.modal-table .author-col {
  white-space: nowrap;
}

.modal-table .note-col {
  white-space: normal;
  max-width: 320px;
  word-break: break-word;
}

.modal-table tr.history-row-event td {
  background: var(--surface-subtle);
  color: var(--text-muted);
}

@keyframes modal-sheet-up {
  from {
    transform: translateY(24px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.wbs-inline-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

.wbs-baseline-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.wbs-baseline-title h2 {
  margin: 0;
}

.wbs-baseline-accordion-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.wbs-baseline-toggle {
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.wbs-baseline-chevron {
  color: var(--text-muted);
  transition: transform 0.18s ease;
}

.wbs-baseline-chevron.is-open {
  transform: rotate(90deg);
}

.wbs-baseline-accordion-body {
  margin-top: 10px;
}

.wbs-view-toggle {
  margin-top: 10px;
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
}

.wbs-tree-panel {
  margin-top: 14px;
}

.wbs-tree-subtle {
  color: var(--text-muted);
}

.wbs-tree-list {
  margin-top: 12px;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.wbs-tree-node {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-subtle);
  padding: 0;
}

.wbs-tree-node.is-open .wbs-tree-chevron {
  transform: rotate(90deg);
}

.wbs-tree-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 190px 84px 260px;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  padding: 10px 12px;
}

.wbs-tree-toggle {
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  grid-column: 1 / 4;
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 190px 84px;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  text-align: left;
  cursor: pointer;
}

.wbs-tree-head {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.wbs-tree-head strong {
  font-size: 15px;
  line-height: 1.25;
  font-weight: 600;
}

.wbs-tree-count-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.wbs-tree-deliverable-icon {
  width: 12px;
  height: 12px;
  flex: 0 0 auto;
}

.wbs-tree-chevron {
  display: inline-flex;
  width: 14px;
  justify-content: center;
  color: var(--text-muted);
  transition: transform 0.18s ease;
}

.wbs-tree-wp-total {
  display: inline-flex;
  justify-content: flex-start;
  white-space: nowrap;
  color: var(--text-muted);
  font-size: 13px;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.wbs-tree-wp-type-spacer {
  display: inline-flex;
  justify-content: center;
  min-height: 24px;
}

.wbs-tree-children {
  border-top: 1px solid var(--line);
  margin-top: 0;
  padding: 10px 12px;
}

.wbs-tree-deliverable-list {
  list-style: none;
  margin: 0;
  padding: 0 0 0 18px;
  border-left: 2px solid var(--line);
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.wbs-tree-deliverable-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 190px 84px 260px;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
}

.wbs-tree-deliverable-main {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
  min-width: 0;
}

.wbs-tree-deliverable-main strong {
  font-size: 13px;
  line-height: 1.25;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wbs-tree-deliverable-code {
  font-size: 11px;
  line-height: 1.2;
  color: var(--text-muted);
}

.wbs-tree-deliverable-mobile-meta {
  display: none;
}

.wbs-tree-meta-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 11px;
  line-height: 1.3;
  color: var(--text-muted);
  background: var(--surface);
}

.wbs-tree-deliverable-budget {
  display: inline-flex;
  justify-content: flex-start;
  white-space: nowrap;
  color: var(--text-muted);
  font-size: 13px;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.wbs-tree-deliverable-type {
  display: inline-flex;
  justify-content: center;
  min-height: 24px;
}

.wbs-tree-row-actions {
  display: grid;
  grid-template-columns: 96px 72px 78px;
  justify-content: end;
  align-items: center;
  grid-gap: 10px;
  gap: 10px;
}

.wbs-tree-action-placeholder {
  visibility: hidden;
  white-space: nowrap;
}

.wbs-history-trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
}

.wbs-history-count {
  font-size: 11px;
  line-height: 1.1;
}

.wbs-tree-desktop-actions {
  display: inline-flex;
}

.wbs-tree-mobile-actions {
  display: none;
}

.wbs-tree-row-menu {
  position: relative;
}

.wbs-tree-row-menu summary {
  list-style: none;
}

.wbs-tree-actions-trigger {
  line-height: 0;
}

.wbs-tree-actions-icon {
  width: 14px;
  height: 14px;
  display: block;
}

.wbs-tree-row-menu summary::-webkit-details-marker {
  display: none;
}

.wbs-tree-row-menu-content {
  margin-top: 8px;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  width: max-content;
}

.wbs-tree-row-menu[open] .wbs-tree-row-menu-content {
  position: absolute;
  right: 0;
  z-index: 20;
}

.wbs-tree-row-menu-content .text-action {
  display: inline-flex;
  width: auto;
  text-align: center;
}

.wbs-tree-row-menu-content button.text-action {
  vertical-align: middle;
}

.wbs-tree-row-menu-content .wbs-history-count {
  display: none;
}

.summary-strip {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 10px;
  gap: 10px;
}

.summary-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.summary-evolution-card {
  grid-column: 1 / -1;
}

.summary-evolution-grid {
  display: grid;
  grid-template-columns: minmax(96px, auto) repeat(3, minmax(0, 1fr));
  grid-gap: 8px 12px;
  gap: 8px 12px;
  align-items: center;
}

.variance-0 {
  color: inherit;
}

.variance-ok {
  color: #067647;
}

.variance-warn {
  color: #b54708;
}

.variance-attn {
  color: #c4320a;
}

.variance-bad {
  color: #b42318;
  font-weight: 600;
}

.summary-label {
  color: var(--text-muted);
  font-size: 12px;
}

.inline-move-form {
  display: inline-flex;
}

.btn-small {
  padding: 6px 10px;
  font-size: 12px;
}

@media (max-width: 900px) {
  .wbs-grid,
  .summary-strip {
    grid-template-columns: 1fr;
  }

  .order-header-inline {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .summary-evolution-card {
    overflow-x: auto;
  }

  .summary-evolution-grid {
    grid-template-columns: minmax(96px, auto) repeat(3, minmax(92px, 1fr));
    min-width: 420px;
  }
}

@media (max-width: 640px) {
  .modal-backdrop-sheet {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100dvh;
    overflow: hidden;
    padding: 10px;
    align-items: flex-end;
  }

  .modal-dialog-sheet {
    width: 100%;
    max-height: min(88dvh, 88vh);
    margin-top: auto;
    animation: modal-sheet-up 0.2s ease-out;
  }

  .modal-content-sheet {
    border-radius: 14px 14px 0 0;
    padding-bottom: env(safe-area-inset-bottom, 0);
  }

  .modal-content-sheet .modal-header,
  .modal-content-sheet .modal-body {
    padding: 10px;
  }

  .modal-content-sheet .modal-table {
    min-width: 680px;
    font-size: 12px;
  }

  .modal-content-sheet .modal-sheet-handle {
    display: block;
    width: 38px;
    height: 4px;
    border-radius: 999px;
    background: var(--line);
    margin: 8px auto 4px;
  }

  .wbs-view-toggle {
    display: flex;
  }

  .wbs-tree-summary {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }

  .wbs-tree-toggle {
    grid-column: auto;
    width: 100%;
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .wbs-tree-wp-total {
    width: 100%;
    justify-content: space-between;
  }

  .wbs-tree-wp-type-spacer {
    display: none;
  }

  .wbs-tree-deliverable-row {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: flex-start;
    gap: 8px 10px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--surface);
    padding: 10px;
  }

  .wbs-tree-deliverable-main {
    grid-column: 1 / 2;
    gap: 6px;
  }

  .wbs-tree-deliverable-main strong {
    white-space: normal;
    line-height: 1.35;
  }

  .wbs-tree-deliverable-mobile-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }

  .wbs-tree-deliverable-budget,
  .wbs-tree-deliverable-type {
    display: none;
  }

  .wbs-tree-mobile-actions {
    display: inline-flex;
    grid-column: 2 / 3;
    grid-row: 1 / 2;
    justify-self: end;
  }

  .wbs-tree-row-menu[open] .wbs-tree-row-menu-content {
    min-width: 0;
    width: max-content;
  }

  .wbs-tree-desktop-actions {
    display: none;
  }
}

.wbs-readonly {
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 10px;
  background: var(--surface-subtle);
  color: var(--text);
}

