@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap";
/* [project]/app/globals.css [app-client] (css) */
:root {
  --font-inter: "Inter";
  --font-mono: "JetBrains Mono";
  --orange: #ff4800;
  --orange-light: #f73;
  --orange-deep: #cc3d00;
  --orange-tint: #ffe0d0;
  --black: #111;
  --graphite: #1a1b1d;
  --steel: #2a2c30;
  --iron: #4a4d52;
  --paper: #fafafa;
  --paper-warm: #f5f1ec;
  --divider: #ececec;
  --ink-muted: #666;
  --ink: #1a1a1a;
  --white: #fff;
  --success: #5a8a4a;
  --danger: #c44320;
  --info: #5078a8;
  --border-strong: #d8d8d8;
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html, body {
  max-width: 100vw;
}

body {
  font-family: var(--font-inter), system-ui, sans-serif;
  background: var(--paper);
  color: var(--ink);
  min-height: 100vh;
  font-size: 14px;
  line-height: 1.5;
  display: flex;
}

.mono {
  font-family: var(--font-mono), "JetBrains Mono", monospace;
}

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

.side {
  background: var(--graphite);
  color: #cdd0d4;
  flex-direction: column;
  flex-shrink: 0;
  width: 256px;
  height: 100vh;
  display: flex;
  position: sticky;
  top: 0;
}

.brand {
  border-bottom: 1px solid var(--iron);
  align-items: center;
  gap: 12px;
  padding: 20px 18px;
  display: flex;
}

.brand svg {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
}

.brand .wm {
  letter-spacing: 3px;
  color: #fff;
  font-size: 14px;
  font-weight: 800;
}

.brand .sub {
  color: #9598a0;
  letter-spacing: .5px;
  margin-top: 1px;
  font-size: 10.5px;
}

.nav {
  flex: 1;
  padding: 10px 10px 20px;
  overflow-y: auto;
}

.nav .grp {
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #7c7f87;
  align-items: center;
  gap: 7px;
  padding: 15px 10px 5px;
  font-size: 10px;
  display: flex;
}

.nav .grp svg {
  width: 13px;
  height: 13px;
}

.nav a {
  color: #cdd0d4;
  cursor: pointer;
  border-left: 2px solid #0000;
  border-radius: 4px;
  align-items: center;
  gap: 11px;
  padding: 9px 12px;
  font-size: 13.5px;
  font-weight: 500;
  display: flex;
}

.nav a.sub {
  padding-left: 20px;
  font-size: 13px;
}

.nav a svg {
  stroke-width: 1.6px;
  width: 17px;
  height: 17px;
}

.nav a:hover {
  background: #23252a;
}

.nav a.active {
  color: #fff;
  border-left-color: var(--orange);
  background: #23252a;
}

.nav a.active svg {
  color: var(--orange);
}

.side-foot {
  border-top: 1px solid var(--iron);
  padding: 14px;
}

.contour {
  border: 1px solid var(--iron);
  background: #23252a;
  border-radius: 4px;
  padding: 10px 12px;
}

.contour .lbl {
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #7c7f87;
  margin-bottom: 7px;
  font-size: 10px;
}

.seg {
  background: var(--black);
  border-radius: 3px;
  padding: 2px;
  display: flex;
}

.seg button {
  color: #9598a0;
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 2px;
  flex: 1;
  padding: 6px 4px;
  font-family: inherit;
  font-size: 11.5px;
  font-weight: 600;
}

.seg button.on {
  background: var(--orange);
  color: #fff;
}

.seg button.on.sb {
  background: var(--info);
}

.main {
  flex-direction: column;
  flex: 1;
  min-width: 0;
  display: flex;
}

.top {
  background: var(--white);
  border-bottom: 1px solid var(--divider);
  z-index: 5;
  justify-content: space-between;
  align-items: center;
  height: 60px;
  padding: 0 28px;
  display: flex;
  position: sticky;
  top: 0;
}

.top .crumb {
  color: var(--ink-muted);
  font-size: 12px;
  font-weight: 600;
}

.top h1 {
  letter-spacing: -.3px;
  font-size: 17px;
  font-weight: 800;
}

.top .right {
  align-items: center;
  gap: 14px;
  display: flex;
}

.cbadge {
  letter-spacing: .5px;
  border-radius: 3px;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
}

.cbadge.prod {
  color: #3f6b32;
  background: #eaf3e6;
  border: 1px solid #cfe3c5;
}

.cbadge.sb {
  color: #3a597d;
  background: #e9f0f7;
  border: 1px solid #cdddec;
}

.user {
  align-items: center;
  gap: 9px;
  display: flex;
}

.ava {
  background: var(--orange);
  color: #fff;
  border-radius: 3px;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  font-size: 12px;
  font-weight: 700;
  display: flex;
}

.user .nm {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.1;
}

.user .rl {
  color: var(--ink-muted);
  font-size: 11px;
}

.wrap {
  width: 100%;
  max-width: 1180px;
  padding: 26px 28px;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--orange);
  margin-bottom: 6px;
  font-size: 11px;
  font-weight: 700;
}

h2.sec {
  letter-spacing: -.5px;
  margin-bottom: 3px;
  font-size: 22px;
  font-weight: 800;
}

.lead {
  color: var(--ink-muted);
  margin-bottom: 22px;
}

.stats {
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 26px;
  display: grid;
}

.stat {
  background: var(--white);
  border: 1px solid var(--divider);
  border-radius: 4px;
  padding: 16px;
  box-shadow: 0 2px 8px #1111110a;
}

.stat .k {
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--ink-muted);
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  font-size: 11px;
  display: flex;
}

.stat .k svg {
  width: 15px;
  height: 15px;
  color: var(--orange);
}

.stat .v {
  letter-spacing: -1px;
  font-size: 26px;
  font-weight: 800;
}

.stat .d {
  color: var(--ink-muted);
  margin-top: 3px;
  font-size: 11.5px;
}

.stat .v small {
  color: var(--ink-muted);
  font-size: 13px;
  font-weight: 600;
}

.card {
  background: var(--white);
  border: 1px solid var(--divider);
  border-radius: 4px;
  margin-bottom: 18px;
  box-shadow: 0 2px 8px #1111110a;
}

.card .hd {
  border-bottom: 1px solid var(--divider);
  justify-content: space-between;
  align-items: center;
  padding: 14px 18px;
  display: flex;
}

.card .hd h3 {
  font-size: 15px;
  font-weight: 700;
}

.card .bd {
  padding: 18px;
}

table {
  border-collapse: collapse;
  width: 100%;
  font-size: 13px;
}

th {
  text-align: left;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--ink-muted);
  border-bottom: 1px solid var(--divider);
  background: var(--paper-warm);
  padding: 10px 14px;
  font-size: 11px;
  font-weight: 600;
}

td {
  border-bottom: 1px solid var(--divider);
  padding: 11px 14px;
}

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

tbody tr:hover td {
  background: #fcfaf8;
}

.pill {
  border-radius: 3px;
  padding: 3px 9px;
  font-size: 11px;
  font-weight: 700;
  display: inline-block;
}

.p-ok {
  color: #3f6b32;
  background: #eaf3e6;
}

.p-warn {
  color: var(--orange-deep);
  background: #fff1e8;
}

.p-bad {
  color: var(--danger);
  background: #fbe9e3;
}

.p-info {
  color: #3a597d;
  background: #e9f0f7;
}

.p-mut {
  color: #666;
  background: #eee;
}

.btn {
  cursor: pointer;
  border: 0;
  border-radius: 4px;
  align-items: center;
  gap: 7px;
  padding: 9px 16px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  display: inline-flex;
}

.btn svg {
  width: 16px;
  height: 16px;
}

.btn:disabled {
  opacity: .55;
  cursor: not-allowed;
}

.btn-pri {
  background: var(--orange);
  color: #fff;
}

.btn-pri:hover:not(:disabled) {
  background: var(--orange-light);
}

.btn-gh {
  color: var(--ink);
  border: 1px solid var(--border-strong);
  background: none;
}

.btn-gh:hover {
  background: var(--paper-warm);
}

.seg2 {
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  margin-bottom: 18px;
  display: inline-flex;
  overflow: hidden;
}

.seg2 button {
  background: var(--white);
  color: var(--ink-muted);
  cursor: pointer;
  border: 0;
  border-right: 1px solid var(--border-strong);
  padding: 7px 15px;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 600;
}

.seg2 button:last-child {
  border-right: 0;
}

.seg2 button.on {
  background: var(--orange);
  color: #fff;
}

.fn {
  margin-bottom: 6px;
}

.fn .row {
  align-items: center;
  gap: 14px;
  margin-bottom: 9px;
  display: flex;
}

.fn .nm2 {
  flex-shrink: 0;
  width: 210px;
  font-size: 13px;
  font-weight: 600;
}

.fn .bar {
  background: var(--paper-warm);
  border-radius: 3px;
  flex: 1;
  height: 30px;
  position: relative;
  overflow: hidden;
}

.fn .fill {
  color: #fff;
  height: 100%;
  font-size: 12px;
  font-weight: 700;
  font-family: var(--font-mono), monospace;
  border-radius: 3px;
  align-items: center;
  padding: 0 10px;
  display: flex;
}

.lot {
  grid-template-columns: 1fr 360px;
  gap: 0;
  display: grid;
}

.lot .info {
  padding: 18px;
}

.lot .map {
  color: #7c7f87;
  text-align: center;
  border-left: 1px solid var(--divider);
  background: linear-gradient(135deg, #2a2c30, #1a1b1d);
  justify-content: center;
  align-items: center;
  min-height: 380px;
  font-size: 12px;
  display: flex;
  position: relative;
}

.lot .map .ph {
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 20px;
  display: flex;
}

.lot .map .ph svg {
  width: 30px;
  height: 30px;
  color: var(--orange);
}

.kv {
  border-bottom: 1px dashed var(--divider);
  justify-content: space-between;
  padding: 7px 0;
  font-size: 13px;
  display: flex;
}

.kv:last-child {
  border: 0;
}

.kv .l {
  color: var(--ink-muted);
}

.kv .r {
  font-weight: 600;
}

.verdict {
  border-radius: 4px;
  align-items: center;
  gap: 7px;
  margin: 6px 0 14px;
  padding: 7px 12px;
  font-size: 13px;
  font-weight: 700;
  display: inline-flex;
}

.v-man {
  color: #3f6b32;
  background: #eaf3e6;
  border: 1px solid #cfe3c5;
}

.v-bad {
  color: var(--danger);
  background: #fbe9e3;
  border: 1px solid #f0cabe;
}

.nb {
  border-bottom: 1px solid var(--divider);
  justify-content: space-between;
  padding: 6px 0;
  font-size: 12.5px;
  display: flex;
}

.nb:last-child {
  border: 0;
}

.nb .dot {
  color: var(--info);
  font-weight: 700;
}

.flow {
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  display: flex;
}

.step {
  border: 1px solid var(--border-strong);
  background: var(--white);
  border-radius: 4px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 600;
}

.step.now {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.step.fut {
  color: var(--ink-muted);
  background: var(--paper-warm);
  border-style: dashed;
}

.flow .arr {
  color: var(--ink-muted);
  font-weight: 700;
}

.tabs {
  border-bottom: 1px solid var(--divider);
  gap: 4px;
  margin-bottom: 18px;
  display: flex;
}

.tabs button {
  color: var(--ink-muted);
  cursor: pointer;
  background: 0;
  border: 0;
  border-bottom: 2px solid #0000;
  margin-bottom: -1px;
  padding: 11px 16px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
}

.tabs button.on {
  color: var(--orange);
  border-bottom-color: var(--orange);
}

.ver {
  border: 1px solid var(--divider);
  border-radius: 4px;
  margin-bottom: 10px;
  overflow: hidden;
}

.ver .vh {
  background: var(--paper-warm);
  cursor: pointer;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  display: flex;
}

.ver .vh .vt {
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 700;
  display: flex;
}

.ver .vh .who {
  color: var(--ink-muted);
  font-size: 12px;
}

.ver .vb {
  color: #333;
  padding: 14px 16px;
  font-size: 13px;
}

.ver .vb li {
  margin: 5px 0 5px 18px;
}

.up {
  border: 2px dashed var(--border-strong);
  text-align: center;
  color: var(--ink-muted);
  background: var(--paper-warm);
  border-radius: 4px;
  margin-bottom: 18px;
  padding: 30px;
}

.up svg {
  width: 32px;
  height: 32px;
  color: var(--orange);
  margin-bottom: 8px;
}

.up.drag {
  border-color: var(--orange);
  background: #fff4ec;
}

tr.dppt-clk:hover > td {
  background: #fff4ec;
}

.auth-screen {
  background: var(--paper-warm);
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding: 24px;
  display: flex;
}

.auth-card {
  background: var(--white);
  border: 1px solid var(--border-strong);
  border-radius: 6px;
  width: 100%;
  max-width: 380px;
  padding: 28px;
  box-shadow: 0 6px 28px #00000014;
}

.auth-brand {
  align-items: center;
  gap: 12px;
  margin-bottom: 22px;
  display: flex;
}

.auth-brand .wm {
  letter-spacing: .5px;
  font-weight: 800;
}

.auth-brand .sub {
  color: var(--ink-muted);
  font-size: 12px;
}

.auth-lbl {
  color: var(--ink-muted);
  margin: 12px 0 4px;
  font-size: 12px;
  font-weight: 600;
  display: block;
}

.auth-card .input {
  width: 100%;
}

.md-body {
  color: var(--ink);
  font-size: 13.5px;
  line-height: 1.6;
}

.md-body .md-h {
  margin: 18px 0 8px;
  line-height: 1.3;
}

.md-body h1.md-h {
  font-size: 20px;
}

.md-body h2.md-h {
  font-size: 17px;
}

.md-body h3.md-h {
  font-size: 15px;
}

.md-body h4.md-h {
  font-size: 13.5px;
}

.md-body p {
  margin: 8px 0;
}

.md-body .md-ul {
  margin: 8px 0 8px 4px;
  padding-left: 20px;
}

.md-body .md-ul li {
  margin: 3px 0;
}

.md-body code {
  background: var(--paper-warm);
  border-radius: 3px;
  padding: 1px 5px;
  font-size: 12px;
}

.md-body .md-code {
  background: var(--paper-warm);
  border: 1px solid var(--divider);
  border-radius: 4px;
  padding: 10px 12px;
  font-size: 12px;
  overflow: auto;
}

.md-body .md-code code {
  background: none;
  padding: 0;
}

.md-body hr {
  border: 0;
  border-top: 1px solid var(--divider);
  margin: 16px 0;
}

.note {
  color: var(--ink-muted);
  border-left: 2px solid var(--orange);
  background: #fff8f4;
  border-radius: 0 4px 4px 0;
  margin-bottom: 18px;
  padding: 10px 14px;
  font-size: 12px;
}

.svc {
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  display: grid;
}

.svc .s {
  border: 1px solid var(--divider);
  background: var(--white);
  border-radius: 4px;
  padding: 18px;
  box-shadow: 0 2px 8px #1111110a;
}

.svc .s.ghost {
  background: var(--paper-warm);
  color: var(--ink-muted);
  border-style: dashed;
}

.svc .s h4 {
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  font-size: 15px;
  font-weight: 700;
  display: flex;
}

.svc .s h4 svg {
  width: 18px;
  height: 18px;
  color: var(--orange);
}

.svc .s p {
  color: var(--ink-muted);
  font-size: 12.5px;
}

.foot {
  color: #9aa;
  border-top: 1px solid var(--divider);
  margin-top: 10px;
  padding: 18px 28px;
  font-size: 11.5px;
}

.field {
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  display: flex;
}

.input {
  font-family: var(--font-mono), monospace;
  border: 1px solid var(--border-strong);
  background: var(--white);
  color: var(--ink);
  border-radius: 4px;
  min-width: 240px;
  padding: 9px 12px;
  font-size: 14px;
}

.input:focus {
  outline: 2px solid var(--orange-tint);
  border-color: var(--orange);
}

.spinner {
  border: 2px solid #fff6;
  border-top-color: #fff;
  border-radius: 50%;
  width: 16px;
  height: 16px;
  animation: .7s linear infinite spin;
  display: inline-block;
}

.spinner.dark {
  border-color: #00000026;
  border-top-color: var(--orange);
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.loading-box {
  color: var(--ink-muted);
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 40px;
  font-size: 13px;
  display: flex;
}

.err-box {
  color: var(--danger);
  background: #fbe9e3;
  border: 1px solid #f0cabe;
  border-radius: 4px;
  margin-bottom: 18px;
  padding: 12px 16px;
  font-size: 13px;
}

.flt {
  background: var(--white);
  border: 1px solid var(--divider);
  border-radius: 4px;
  margin-bottom: 18px;
  padding: 16px 18px;
  box-shadow: 0 2px 8px #1111110a;
}

.flt-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 12px 16px;
  display: grid;
}

.flt-f {
  flex-direction: column;
  gap: 5px;
  display: flex;
}

.flt-f > label {
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--ink-muted);
  font-size: 10.5px;
  font-weight: 600;
}

.flt .input, .flt select {
  width: 100%;
  min-width: 0;
}

select.input {
  font-family: var(--font-inter), sans-serif;
  cursor: pointer;
}

.flt .row2 {
  gap: 8px;
  display: flex;
}

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

.chip {
  border: 1px solid var(--border-strong);
  background: var(--white);
  color: var(--ink-muted);
  cursor: pointer;
  border-radius: 14px;
  padding: 5px 10px;
  font-size: 11.5px;
  font-weight: 600;
}

.chip.on {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.flt-foot {
  border-top: 1px solid var(--divider);
  align-items: center;
  gap: 12px;
  margin-top: 14px;
  padding-top: 14px;
  display: flex;
}

.terr {
  grid-template-columns: 1fr 320px;
  display: grid;
}

.terr-map {
  background: linear-gradient(135deg, #2a2c30, #1a1b1d);
  justify-content: center;
  align-items: center;
  min-height: 400px;
  display: flex;
  position: relative;
}

.terr-map .ph {
  color: #9aa;
  text-align: center;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 20px;
  font-size: 12px;
  display: flex;
}

.terr-map .ph svg {
  width: 30px;
  height: 30px;
  color: var(--orange);
}

.terr-list {
  border-left: 1px solid var(--divider);
  max-height: 400px;
  padding: 14px 16px;
  overflow-y: auto;
}

.terr-h {
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--ink-muted);
  align-items: center;
  gap: 7px;
  margin-bottom: 12px;
  font-size: 11px;
  font-weight: 600;
  display: flex;
}

.terr-skel {
  color: var(--ink-muted);
  padding: 8px 0;
  font-size: 12.5px;
}

.terr-area {
  color: var(--ink-muted);
  border-bottom: 1px dashed var(--divider);
  margin-bottom: 10px;
  padding: 0 0 10px;
  font-size: 12px;
}

.parcel {
  border-bottom: 1px solid var(--divider);
  padding: 9px 0;
}

.parcel:last-child {
  border-bottom: 0;
}

.parcel-kn {
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 700;
  display: flex;
}

.parcel-meta {
  color: var(--ink-muted);
  margin-top: 4px;
  margin-left: 19px;
  font-size: 12px;
}

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

  .terr-list {
    border-left: 0;
    border-top: 1px solid var(--divider);
  }
}

.ribbon {
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
  display: flex;
}

.rib {
  background: var(--white);
  border: 1px solid var(--divider);
  cursor: pointer;
  color: var(--ink);
  border-radius: 6px;
  align-items: center;
  gap: 7px;
  padding: 7px 12px;
  font-family: inherit;
  font-size: 13px;
  display: inline-flex;
}

.rib:hover {
  background: var(--paper-warm);
}

.rib.on {
  border-color: var(--orange);
  box-shadow: inset 0 0 0 1px var(--orange);
  background: #fff8f4;
}

.rib-n {
  font-size: 15px;
  font-weight: 800;
}

.rib-l {
  color: var(--ink-muted);
}

.rib-dot {
  background: #999;
  border-radius: 50%;
  width: 9px;
  height: 9px;
  display: inline-block;
}

.rib-dot.p-ok {
  background: var(--success);
}

.rib-dot.p-bad {
  background: var(--danger);
}

.rib-dot.p-info {
  background: var(--info);
}

.rib-dot.p-warn {
  background: var(--orange);
}

.rib-dot.p-mut {
  background: #b0b0b0;
}

.kanban {
  flex-flow: row;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 18px;
  padding-bottom: 12px;
  display: flex;
  overflow: auto hidden;
}

.kcol {
  box-sizing: border-box;
  background: var(--paper-warm);
  border: 1px solid var(--divider);
  border-radius: 6px;
  flex-direction: column;
  flex: 0 0 300px;
  min-width: 300px;
  max-width: 320px;
  max-height: 72vh;
  display: flex;
}

.kcol.over {
  border-color: var(--orange);
  background: #fff8f4;
}

.kcol-flash {
  animation: 1.2s kcolFlash;
}

@keyframes kcolFlash {
  0%, 100% {
    box-shadow: none;
  }

  25% {
    box-shadow: 0 0 0 3px var(--orange);
    border-color: var(--orange);
  }
}

.kpis {
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 16px 0;
  display: grid;
}

.kpic {
  background: var(--white);
  border: 1px solid var(--divider);
  border-radius: 4px;
  padding: 14px 16px;
}

.kpic-accent {
  border-left: 3px solid var(--orange);
}

.kpic-v {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.1;
}

.kpic-k {
  color: var(--ink-muted);
  margin-top: 4px;
  font-size: 12px;
}

.vfn {
  flex-direction: column;
  gap: 10px;
  display: flex;
}

.vrow {
  grid-template-columns: 210px 1fr 130px;
  align-items: center;
  gap: 12px;
  display: grid;
}

.vlbl {
  white-space: nowrap;
  text-overflow: ellipsis;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  display: flex;
  overflow: hidden;
}

.vdot {
  border-radius: 2px;
  flex: none;
  width: 9px;
  height: 9px;
}

.vtrack {
  background: var(--paper-warm);
  border-radius: 4px;
  height: 22px;
  overflow: hidden;
}

.vfill {
  border-radius: 4px 0 0 4px;
  height: 100%;
  transition: width .2s;
}

.vval {
  text-align: right;
  white-space: nowrap;
  font-size: 14px;
}

.vval .mono {
  font-weight: 700;
}

.vpct {
  color: var(--ink-muted);
  margin-left: 4px;
  font-size: 12px;
}

@media (max-width: 720px) {
  .kpis {
    grid-template-columns: repeat(2, 1fr);
  }

  .vrow {
    grid-template-columns: 130px 1fr 92px;
  }
}

.kcol-h {
  border-bottom: 1px solid var(--divider);
  align-items: center;
  gap: 7px;
  padding: 10px 12px;
  font-size: 12.5px;
  font-weight: 700;
  display: flex;
  position: sticky;
  top: 0;
}

.kcol-n {
  background: var(--white);
  border: 1px solid var(--divider);
  color: var(--ink-muted);
  border-radius: 10px;
  margin-left: auto;
  padding: 0 8px;
  font-size: 11px;
}

.kcol-body {
  flex-direction: column;
  gap: 8px;
  padding: 8px;
  display: flex;
  overflow-y: auto;
}

.kcard {
  background: var(--white);
  border: 1px solid var(--border-strong);
  cursor: pointer;
  border-radius: 5px;
  padding: 7px 9px;
  box-shadow: 0 1px 3px #1111110d;
}

.kcard:hover {
  border-color: var(--orange);
}

.kcard:active {
  cursor: grabbing;
}

.kcard-t {
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-bottom: 3px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.25;
  overflow: hidden;
}

.kcard-kn {
  color: var(--ink-muted);
  font-size: 10.5px;
}

.kcol-empty {
  color: var(--ink-muted);
  text-align: center;
  padding: 10px 0;
  font-size: 12px;
}

.kpi-grid {
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  display: grid;
}

.kpi-cell {
  background: var(--paper-warm);
  border: 1px solid var(--divider);
  border-radius: 5px;
  padding: 10px 12px;
}

.kpi-v {
  letter-spacing: -.3px;
  font-size: 18px;
  font-weight: 800;
  font-family: var(--font-mono), monospace;
}

.kpi-u {
  color: var(--ink-muted);
  margin-left: 4px;
  font-size: 11px;
  font-weight: 600;
}

.kpi-k {
  color: var(--ink-muted);
  margin-top: 4px;
  font-size: 10.5px;
  line-height: 1.25;
}

@media (max-width: 880px) {
  .kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.nspd-tag {
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--info);
  vertical-align: middle;
  background: #e9f0f7;
  border: 1px solid #cdddec;
  border-radius: 3px;
  margin-left: 8px;
  padding: 1px 5px;
  font-size: 9.5px;
  font-weight: 700;
}

.task {
  border: 1px solid var(--divider);
  border-radius: 5px;
  margin-bottom: 10px;
  padding: 10px 12px;
}

.task-h {
  align-items: center;
  gap: 4px;
  font-size: 13.5px;
  display: flex;
}

.task-x {
  color: var(--ink-muted);
  cursor: pointer;
  background: 0;
  border: 0;
  margin-left: auto;
  padding: 2px;
}

.task-x:hover {
  color: var(--danger);
}

.task-ci {
  cursor: pointer;
  align-items: center;
  gap: 8px;
  padding: 4px 0 0 2px;
  font-size: 13px;
  display: flex;
}

.task-add {
  border-top: 1px dashed var(--divider);
  margin-top: 4px;
  padding-top: 12px;
}

.letter {
  border: 1px solid var(--divider);
  background: var(--paper-warm);
  border-radius: 5px;
  margin-bottom: 10px;
  padding: 10px 12px;
}

.letter-text {
  white-space: pre-wrap;
  font-family: var(--font-inter), sans-serif;
  color: #333;
  margin: 0;
  font-size: 12.5px;
  line-height: 1.5;
}

.stbc {
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-bottom: 16px;
  display: flex;
}

.stbc-i {
  border: 1px solid var(--border-strong);
  background: var(--white);
  color: var(--ink-muted);
  white-space: nowrap;
  cursor: default;
  border-radius: 4px;
  padding: 5px 10px;
  font-size: 12px;
}

.stbc-i.done {
  color: var(--ink);
  border-color: var(--divider);
}

.stbc-i.cur {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
  font-weight: 700;
}

.stbc-i.term {
  color: var(--danger);
  background: #fbe9e3;
  border-color: #f0cabe;
  font-weight: 700;
}

.stbc-s {
  color: var(--ink-muted);
}

.modal-bg {
  z-index: 50;
  background: #11111180;
  justify-content: center;
  align-items: center;
  display: flex;
  position: fixed;
  inset: 0;
}

.modal {
  background: var(--white);
  border-radius: 6px;
  width: 460px;
  max-width: 92vw;
  box-shadow: 0 12px 40px #00000040;
}

.modal .mh {
  border-bottom: 1px solid var(--divider);
  padding: 16px 20px;
  font-size: 15px;
  font-weight: 700;
}

.modal .mb {
  padding: 18px 20px;
}

.modal .mf {
  border-top: 1px solid var(--divider);
  justify-content: flex-end;
  gap: 10px;
  padding: 14px 20px;
  display: flex;
}

.modal textarea {
  border: 1px solid var(--border-strong);
  resize: vertical;
  border-radius: 4px;
  width: 100%;
  min-height: 80px;
  padding: 10px 12px;
  font-family: inherit;
  font-size: 14px;
}

.modal textarea:focus {
  outline: 2px solid var(--orange-tint);
  border-color: var(--orange);
}

@media (max-width: 880px) {
  .stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .lot, .svc {
    grid-template-columns: 1fr;
  }

  .fn .nm2 {
    width: 130px;
  }
}

.seg2 button:disabled {
  opacity: .5;
  cursor: not-allowed;
}

/*# sourceMappingURL=app_globals_0yg4wg8.css.map*/