:root {
  color-scheme: light;
  font-family: Arial, Helvetica, sans-serif;
  --bg: #f6f7f9;
  --panel: #ffffff;
  --line: #d8dde5;
  --text: #1d232f;
  --muted: #687385;
  --accent: #176b5f;
  --accent-dark: #0e4d45;
  --danger-soft: #f7e6e2;
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  display: flex;
  flex-direction: column;
  font-size: 15px;
  min-height: 100vh;
}

a {
  color: var(--accent);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

.topbar {
  align-items: center;
  background: #1f2933;
  color: #fff;
  display: flex;
  gap: 28px;
  height: 52px;
  padding: 0 24px;
}

.brand {
  align-items: center;
  color: #fff;
  display: inline-flex;
  font-size: 17px;
  font-weight: 700;
  gap: 10px;
}

.brand-icon {
  background: rgb(255 255 255 / 10%);
  border-radius: 7px;
  box-shadow: 0 0 0 1px rgb(255 255 255 / 16%);
  display: block;
  flex: 0 0 auto;
  height: 32px;
  padding: 4px;
  width: 32px;
}

.tenant-menu-logo {
  background: #ffffff;
  height: 34px;
  object-fit: contain;
  padding: 3px 5px;
  width: 50px;
}

.brand-copy {
  display: grid;
  gap: 1px;
  line-height: 1;
}

.brand-copy strong {
  color: #ffffff;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.brand-copy small {
  color: #cbd5e1;
  font-size: 10px;
  font-weight: 800;
}

.print-tenant-header {
  display: none;
}

.menu-bar {
  display: flex;
  gap: 6px;
}

.topbar-permissions {
  align-items: center;
  display: inline-flex;
  gap: 7px;
  margin-left: auto;
}

.topbar-action-button,
.topbar-user-chip,
.permission-button,
.logout-button {
  align-items: center;
  border-radius: 8px;
  display: inline-flex;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  gap: 7px;
  min-height: 34px;
  padding: 0 12px;
  white-space: nowrap;
}

.topbar-action-button svg,
.topbar-user-chip svg,
.permission-button svg,
.logout-button svg {
  fill: none;
  flex: 0 0 auto;
  height: 17px;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
  width: 17px;
}

.topbar-user-chip {
  background: #263544;
  border: 1px solid #3b4a5a;
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 6%);
  color: #e5edf7;
  max-width: 150px;
}

.topbar-user-chip span {
  overflow: hidden;
  text-overflow: ellipsis;
}

.permission-button {
  background: #365fd3;
  border: 1px solid #4e73dd;
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 15%), 0 8px 18px rgb(15 23 42 / 18%);
  color: #ffffff;
  text-decoration: none;
}

.permission-button:hover {
  background: #2d50b8;
  text-decoration: none;
  transform: translateY(-1px);
}

.topbar-logout-form {
  margin: 0;
}

.logout-button {
  background: #2b3948;
  border: 1px solid #435568;
  color: #eef4fb;
  cursor: pointer;
}

.logout-button:hover {
  background: #34465a;
  transform: translateY(-1px);
}

[data-permission-hidden="1"] {
  display: none !important;
}

.login-page {
  background:
    linear-gradient(135deg, #eef3f9 0%, #f8fafc 48%, #edf2f7 100%);
  color: #0f172a;
  min-height: 100vh;
  overflow-x: hidden;
}

.login-top-mark {
  align-items: center;
  color: #334155;
  display: inline-flex;
  font-size: 13px;
  font-weight: 900;
  gap: 8px;
  left: 24px;
  letter-spacing: 0;
  position: fixed;
  top: 22px;
  z-index: 2;
}

.login-top-mark img {
  background: #ffffff;
  border: 1px solid #d7e0eb;
  border-radius: 8px;
  display: block;
  height: 34px;
  object-fit: contain;
  padding: 4px;
  width: 58px;
}

.login-shell {
  align-items: center;
  display: flex;
  flex: 1 0 auto;
  justify-content: center;
  min-height: 100vh;
  padding: 96px 28px 70px;
}

.login-demo-card {
  background: rgb(255 255 255 / 94%);
  border: 1px solid #ccd7e6;
  border-radius: 8px;
  box-shadow: 0 18px 38px rgb(15 23 42 / 10%);
  color: #0f172a;
  display: grid;
  font-size: 13px;
  gap: 7px;
  min-width: 220px;
  padding: 14px 16px;
  position: fixed;
  right: 24px;
  top: 22px;
  z-index: 2;
}

.login-demo-card strong {
  color: #1e3a8a;
  font-size: 13px;
}

.login-demo-card span {
  align-items: center;
  color: #475569;
  display: flex;
  justify-content: space-between;
  gap: 18px;
}

.login-demo-card b {
  color: #0f172a;
  font-weight: 900;
}

.login-panel {
  background: rgb(255 255 255 / 96%);
  border: 1px solid #d6dfeb;
  border-radius: 12px;
  box-shadow: 0 24px 58px rgb(15 23 42 / 14%);
  display: grid;
  gap: 20px;
  max-width: 438px;
  padding: 30px;
  width: 100%;
}

.login-brand {
  align-items: center;
  display: flex;
  gap: 14px;
}

.login-tenant-logo {
  background: #ffffff;
  border: 1px solid #d8e0ea;
  border-radius: 10px;
  box-shadow: inset 0 1px 0 #ffffff;
  display: block;
  height: 64px;
  object-fit: contain;
  padding: 6px;
  width: 104px;
}

.login-brand h1 {
  color: #0f172a;
  font-size: 28px;
  line-height: 1;
  margin: 0;
}

.login-brand p,
.login-muted {
  color: #526178;
  margin: 5px 0 0;
}

.login-alert {
  background: #fff1f2;
  border: 1px solid #fecdd3;
  border-radius: 8px;
  color: #9f1239;
  font-size: 13px;
  font-weight: 800;
  padding: 10px 12px;
}

.login-form {
  display: grid;
  gap: 14px;
}

.login-field {
  color: #1e3a8a;
  display: grid;
  font-size: 12px;
  font-weight: 900;
  gap: 7px;
  text-transform: uppercase;
}

.login-input-wrap {
  align-items: center;
  background: #ffffff;
  border: 1px solid #c9d5e5;
  border-radius: 9px;
  display: flex;
  min-height: 46px;
  transition: border-color .15s ease, box-shadow .15s ease;
}

.login-input-wrap:focus-within {
  border-color: #2f5fd3;
  box-shadow: 0 0 0 3px rgb(47 95 211 / 13%);
}

.login-input-wrap svg {
  fill: none;
  flex: 0 0 auto;
  height: 19px;
  margin-left: 13px;
  stroke: #64748b;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
  width: 19px;
}

.login-input-wrap input {
  background: transparent;
  border: 0;
  color: #0f172a;
  flex: 1 1 auto;
  font-size: 15px;
  min-height: 44px;
  min-width: 0;
  padding: 8px 13px 8px 10px;
}

.login-input-wrap input:focus {
  outline: 0;
}

.login-input-wrap input::placeholder {
  color: #94a3b8;
}

.login-submit {
  align-items: center;
  background: #2454c7;
  border: 1px solid #1d48ad;
  border-radius: 9px;
  box-shadow: 0 10px 22px rgb(36 84 199 / 22%);
  color: #ffffff;
  cursor: pointer;
  display: flex;
  font-size: 15px;
  font-weight: 900;
  justify-content: center;
  min-height: 46px;
  padding: 0 16px;
}

.login-submit:hover {
  background: #1d48ad;
}

.login-submit svg {
  fill: none;
  height: 18px;
  margin-left: 9px;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
  width: 18px;
}

.login-panel-footer {
  align-items: center;
  border-top: 1px solid #e2e8f0;
  color: #64748b;
  display: flex;
  font-size: 12px;
  justify-content: space-between;
  padding-top: 14px;
}

.login-panel-footer strong {
  color: #334155;
}

.login-page-footer {
  align-items: center;
  bottom: 18px;
  color: #64748b;
  display: flex;
  font-size: 12px;
  gap: 16px;
  justify-content: center;
  left: 24px;
  position: fixed;
  right: 24px;
}

@media (max-width: 720px) {
  .login-top-mark {
    left: 18px;
    top: 14px;
  }

  .login-shell {
    align-items: start;
    padding: 126px 18px 88px;
  }

  .login-demo-card {
    left: 18px;
    right: 18px;
    top: 62px;
  }

  .login-panel {
    padding: 22px;
  }

  .login-panel-footer,
  .login-page-footer {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }
}

.topbar nav a,
.menu-group > button {
  align-items: center;
  background: transparent;
  border: 0;
  color: #e6edf3;
  display: inline-flex;
  font: inherit;
  min-height: 34px;
  padding: 7px 9px;
}

.menu-group {
  position: relative;
}

.menu-group > button {
  cursor: default;
}

.menu-panel {
  background: #ffffff;
  border: 1px solid #b9c1cc;
  box-shadow: 0 10px 22px rgba(12, 22, 32, 0.18);
  display: none;
  min-width: 230px;
  overflow: visible;
  padding: 5px;
  position: absolute;
  top: 34px;
  z-index: 10;
}

.topbar nav .menu-panel a {
  color: #1d232f;
  display: block;
  padding: 8px 10px;
}

.topbar nav .menu-panel a[data-progress] {
  padding-right: 56px;
  position: relative;
}

.topbar nav .menu-panel a[data-progress]::after {
  background: #edf2f7;
  border: 1px solid #d2dae5;
  border-radius: 10px;
  color: #415066;
  content: attr(data-progress);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  min-width: 36px;
  padding: 3px 5px;
  position: absolute;
  right: 8px;
  text-align: center;
  top: 50%;
  transform: translateY(-50%);
}

.topbar nav .menu-panel a.menu-checked::before {
  color: #16835f;
  content: "✓";
  font-weight: 700;
  margin-right: 6px;
}

.topbar nav .menu-panel a:hover,
.submenu > button:hover {
  background: #e8f0f7;
  text-decoration: none;
}

.menu-group:hover .menu-panel,
.menu-group:focus-within .menu-panel {
  display: block;
}

.submenu {
  position: relative;
}

.submenu > button {
  align-items: center;
  background: transparent;
  border: 0;
  color: #1d232f;
  display: flex;
  font: inherit;
  justify-content: space-between;
  min-height: 34px;
  padding: 8px 10px;
  width: 100%;
}

.submenu > button::after {
  color: #526071;
  content: ">";
  font-size: 12px;
}

.submenu-panel {
  background: #ffffff;
  border: 1px solid #b9c1cc;
  box-shadow: 0 10px 22px rgba(12, 22, 32, 0.18);
  display: none;
  left: 100%;
  max-height: calc(100vh - 72px);
  min-width: 235px;
  overflow-y: auto;
  padding: 5px;
  position: absolute;
  top: -6px;
  z-index: 20;
}

.permissions-window {
  display: grid;
  gap: 14px;
  margin: 0 auto;
  max-width: 1024px;
}

.permissions-gate-shell {
  align-items: center;
  display: flex;
  justify-content: center;
  min-height: min(620px, calc(100vh - 210px));
  padding: 32px 0;
}

.permissions-gate-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid #d7e2f0;
  border-radius: 14px;
  box-shadow: 0 22px 60px rgba(15, 23, 42, 0.16);
  display: grid;
  gap: 18px;
  max-width: 460px;
  padding: 26px;
  width: min(100%, 460px);
}

.permissions-gate-brand {
  align-items: center;
  display: flex;
  gap: 14px;
}

.permissions-gate-brand img {
  background: #ffffff;
  border: 1px solid #dbe4ef;
  border-radius: 12px;
  height: 66px;
  object-fit: contain;
  padding: 7px;
  width: 96px;
}

.permissions-gate-brand span,
.permissions-gate-form span {
  color: #173a7a;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.permissions-gate-brand h1 {
  color: #0f1f35;
  font-size: 30px;
  line-height: 1;
  margin: 3px 0;
}

.permissions-gate-brand p,
.permissions-gate-copy span {
  color: #607086;
  font-size: 13px;
  line-height: 1.35;
}

.permissions-gate-copy {
  background: #eef6ff;
  border: 1px solid #cfe2ff;
  border-radius: 10px;
  display: grid;
  gap: 4px;
  padding: 12px;
}

.permissions-gate-copy strong {
  color: #0f2d5c;
  font-size: 14px;
}

.permissions-gate-error {
  background: #fff1f2;
  border: 1px solid #fecdd3;
  border-radius: 9px;
  color: #9f1239;
  font-size: 13px;
  font-weight: 800;
  padding: 10px 12px;
}

.permissions-gate-form {
  display: grid;
  gap: 14px;
}

.permissions-gate-form label {
  display: grid;
  gap: 7px;
}

.permissions-gate-input-wrap {
  align-items: center;
  background: #ffffff;
  border: 1px solid #c5d2e3;
  border-radius: 9px;
  display: flex;
  gap: 10px;
  padding: 0 12px;
}

.permissions-gate-input-wrap:focus-within {
  border-color: #4f6fdc;
  box-shadow: 0 0 0 3px rgba(79, 111, 220, 0.16);
}

.permissions-gate-input-wrap svg,
.permissions-gate-form button svg {
  fill: none;
  height: 20px;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
  width: 20px;
}

.permissions-gate-input-wrap svg {
  color: #55677f;
  flex: 0 0 auto;
}

.permissions-gate-input-wrap input {
  border: 0;
  color: #0f172a;
  flex: 1 1 auto;
  font: inherit;
  font-size: 16px;
  min-height: 46px;
  outline: 0;
}

.permissions-gate-form button {
  align-items: center;
  background: linear-gradient(135deg, #263b63, #4f46e5);
  border: 1px solid #31467c;
  border-radius: 9px;
  box-shadow: 0 10px 20px rgba(47, 70, 130, 0.22);
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  font-size: 15px;
  font-weight: 900;
  gap: 9px;
  justify-content: center;
  min-height: 46px;
  padding: 10px 16px;
}

.permissions-gate-form button:hover {
  filter: brightness(1.04);
  transform: translateY(-1px);
}

.permissions-title {
  align-items: center;
  display: flex;
  gap: 16px;
  justify-content: space-between;
}

.permissions-title > div:first-of-type {
  flex: 1 1 auto;
}

.permissions-tenant-logo {
  background: #ffffff;
  border: 1px solid #d8e0ea;
  border-radius: 8px;
  display: block;
  flex: 0 0 auto;
  height: 54px;
  object-fit: contain;
  padding: 5px;
  width: 92px;
}

.permissions-tenant-name {
  color: #64748b;
  display: inline-block;
  font-size: 12px;
  font-weight: 900;
  margin-top: 2px;
  text-transform: uppercase;
}

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

.permissions-toolbar {
  align-items: end;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 8px;
  padding: 10px;
}

.permissions-toolbar label {
  display: grid;
  gap: 4px;
  min-width: 170px;
}

.permissions-toolbar span {
  color: #173a7a;
  font-size: 12px;
  font-weight: 800;
}

.permissions-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr;
}

.permission-card {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 8px;
  overflow: visible;
  padding: 12px;
}

.permission-row {
  align-items: center;
  display: flex;
  gap: 8px;
  min-height: 28px;
}

.permission-row input {
  height: 15px;
  width: 15px;
}

.permission-row strong,
.permission-row span {
  color: #111827;
  font-size: 13px;
}

.permission-row strong {
  font-size: 15px;
}

.permission-children {
  border-left: 2px solid #e2e8f0;
  display: grid;
  gap: 4px;
  margin-left: 7px;
  padding-left: 12px;
}

.permission-children .permission-children {
  margin-left: 4px;
}

.submenu:hover .submenu-panel,
.submenu:focus-within .submenu-panel {
  display: block;
}

.page {
  flex: 1 0 auto;
  margin: 0 auto;
  max-width: min(1680px, calc(100vw - 32px));
  padding: 18px 16px 24px;
  width: 100%;
}

.app-footer {
  background: #f2f4f7;
  border-top: 1px solid #d8dde5;
  box-shadow: inset 0 1px 0 #ffffff;
  color: #5f6b7c;
  flex: 0 0 auto;
  margin: 10px auto 0;
  max-width: min(1680px, calc(100vw - 32px));
  padding: 13px 16px 10px;
  width: 100%;
}

.app-footer-main {
  display: grid;
  gap: 22px;
  grid-template-columns: minmax(220px, 1.35fr) minmax(160px, .9fr) minmax(150px, .8fr) minmax(210px, 1fr);
}

.app-footer-col {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.app-footer-col h2 {
  color: #1f2933;
  font-size: 11px;
  letter-spacing: .02em;
  margin: 0 0 2px;
  text-transform: uppercase;
}

.app-footer-brand strong {
  color: #1f2933;
  font-size: 13px;
  font-weight: 900;
}

.app-footer-col span,
.app-footer-col a {
  font-size: 11px;
  line-height: 1.25;
}

.app-footer-col a {
  color: #176b5f;
  font-weight: 800;
}

.app-footer-col a:hover {
  text-decoration: underline;
}

.app-footer-quality {
  border-left: 1px solid #d8dde5;
  padding-left: 16px;
}

.app-footer-quality span:last-child {
  color: #334155;
  font-weight: 800;
}

.app-footer-bottom {
  align-items: center;
  border-top: 1px solid #d8dde5;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin-top: 10px;
  padding-top: 7px;
}

.app-footer-bottom span {
  color: #687385;
  font-size: 10px;
  line-height: 1.2;
}

.toolbar,
.detail-header {
  align-items: end;
  display: flex;
  gap: 20px;
  justify-content: space-between;
  margin-bottom: 18px;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  font-size: 25px;
  line-height: 1.25;
}

h2 {
  font-size: 16px;
  margin-bottom: 12px;
}

.toolbar p,
.detail-header p,
.back {
  color: var(--muted);
  font-size: 13px;
}

.toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.client-fox-window {
  background: transparent;
  color: var(--text);
  margin: 0 auto;
  max-width: 1240px;
}

.client-fox-title {
  align-items: end;
  display: flex;
  gap: 20px;
  justify-content: space-between;
  margin-bottom: 14px;
}

.client-fox-title h1 {
  font-size: 25px;
  line-height: 1.25;
  margin: 0;
}

.client-fox-title p,
.client-fox-title .back {
  color: var(--muted);
  font-size: 13px;
}

.client-toolbar {
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
  padding: 10px;
}

.client-tool {
  align-items: center;
  background: #eef2f5;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #384253;
  display: inline-flex;
  font-size: 13px;
  font-weight: 700;
  justify-content: center;
  min-height: 32px;
  min-width: 38px;
  padding: 6px 10px;
  text-decoration: none;
}

.client-tool:hover {
  background: #f4f7f9;
  text-decoration: none;
}

.client-tool.coverage-tool {
  border-radius: 7px;
  font-size: 15px;
  font-weight: 900;
  min-height: 32px;
  min-width: 32px;
  padding: 0;
}

.coverage-toolbar {
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 6px;
  margin-bottom: 14px;
  padding: 10px;
}

.client-tool.disabled,
.client-tool:disabled {
  background: #f6f8fa;
  color: #728094;
  cursor: not-allowed;
  opacity: 1;
}

.client-tool.disabled:hover,
.client-tool:disabled:hover {
  background: #f6f8fa;
  color: #728094;
}

.client-tool-form {
  display: inline-flex;
  margin: 0;
}

.client-tool-form .client-tool {
  cursor: pointer;
}

.client-tabs {
  display: grid;
  gap: 12px;
}

.client-tab-labels {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.client-tab-button {
  background: #eef2f5;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #384253;
  cursor: pointer;
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  padding: 8px 12px;
}

.client-tab-button.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}

.client-panel {
  display: none;
}

.client-panel.is-active {
  display: block;
}

.client-fox-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1.35fr) minmax(340px, .9fr);
}

.client-box,
.client-fox-grid > div,
.client-fox-grid > aside,
.client-debt-total {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.client-fox-grid > div,
.client-fox-grid > aside {
  padding: 14px;
}

.client-box {
  padding: 12px;
}

.client-box h2 {
  color: #173a7a;
  font-size: 15px;
  margin: 0 0 10px;
}

.client-audit-strip {
  background: #f8fafb;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 0 0 12px;
  padding: 10px;
}

.client-audit-item {
  background: #ffffff;
  border: 1px solid #d8e0e7;
  border-radius: 7px;
  min-width: 0;
  padding: 9px 10px;
}

.client-audit-item span {
  color: #56657a;
  display: block;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 3px;
}

.client-audit-item strong {
  color: var(--text);
  display: block;
  font-size: 15px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.clientes-list-window {
  display: grid;
  gap: 14px;
  max-width: 1024px;
}

.clientes-list-title {
  margin-bottom: 0;
}

.clientes-list-filter {
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-sizing: border-box;
  display: grid !important;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) 278px;
  margin-bottom: 0;
  padding: 10px;
  width: 100%;
}

.clientes-list-filter > * {
  box-sizing: border-box;
  min-width: 0;
}

.clientes-list-filter-actions {
  display: grid;
  gap: 8px;
  grid-template-columns: 150px 120px;
  min-width: 0;
}

.clientes-list-filter-actions > * {
  min-width: 0;
}

.clientes-list-filter .grid-input {
  max-width: 100%;
  min-width: 0;
  width: 100%;
}

.clientes-list-filter select.grid-input {
  max-width: 150px;
}

.clientes-list-filter .client-tool {
  max-width: 120px;
  min-width: 0;
  width: 100%;
}

@media (max-width: 720px) {
  .clientes-list-filter {
    grid-template-columns: 1fr;
  }

  .clientes-list-filter-actions {
    grid-template-columns: minmax(0, 1fr) minmax(96px, 120px);
  }

  .clientes-list-filter select.grid-input,
  .clientes-list-filter .client-tool {
    max-width: none;
  }
}

.clientes-list-table {
  margin-top: 0;
  max-width: 100%;
  overflow: hidden;
  width: 100%;
}

.table-wrap.clientes-list-table:has(table[data-datatable]) {
  overflow: hidden;
}

.clientes-list-table .dt-container,
.clientes-list-table .dt-layout-table,
.clientes-list-table .dt-layout-cell {
  max-width: 100%;
  width: 100%;
}

.clientes-list-table .dt-layout-table {
  overflow-x: hidden !important;
}

.clientes-list-table .dt-layout-row {
  padding: 8px 10px;
}

.clientes-list-table .dt-layout-row:last-child {
  justify-content: space-between;
}

.clientes-list-table .dt-layout-row:last-child .dt-layout-cell:last-child,
.clientes-list-table .dt-layout-row:last-child .dt-end,
.clientes-list-table .dt-layout-row:last-child .dt-layout-end {
  margin-left: auto;
}

.clientes-list-table .dt-layout-row:last-child .dt-paging {
  justify-content: flex-end;
  margin-left: auto;
}

.clientes-list-table table,
.clientes-list-table table.dataTable {
  min-width: 0;
  table-layout: fixed;
  width: 100% !important;
}

.clientes-list-table th,
.clientes-list-table td {
  box-sizing: border-box;
  overflow: hidden;
  padding-left: 6px;
  padding-right: 6px;
  text-overflow: ellipsis;
  vertical-align: middle;
  white-space: nowrap;
}

.clientes-list-table th:nth-child(1),
.clientes-list-table td:nth-child(1) {
  width: 78px;
}

.clientes-list-table th:nth-child(6),
.clientes-list-table td:nth-child(6) {
  width: 118px;
}

.clientes-list-table th:nth-child(7),
.clientes-list-table td:nth-child(7) {
  text-align: center;
  width: 82px;
}

.clientes-list-table td:nth-child(1) a {
  color: #007267;
  font-weight: 800;
  text-decoration: none;
}

.clientes-list-table td:nth-child(1) a:hover {
  text-decoration: underline;
}

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

.subnav {
  display: flex;
  gap: 14px;
  margin: 0 0 14px;
}

.subnav a {
  background: #eef2f5;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #384253;
  padding: 7px 10px;
}

.filters {
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(260px, 420px) repeat(3, minmax(88px, 130px));
}

.wide-filters {
  grid-template-columns: minmax(260px, 420px) repeat(7, minmax(92px, 140px));
}

.production-list-toolbar {
  align-items: start;
  gap: 16px;
}

.production-list-toolbar .filters {
  flex: 1;
  grid-template-columns: minmax(260px, 1fr) repeat(3, minmax(96px, 128px)) auto;
  max-width: 790px;
}

.production-list-toolbar .coverage-tool {
  align-items: center;
  aspect-ratio: 1 / 1;
  border-radius: 9px;
  display: inline-flex;
  font-size: 15px;
  font-weight: 900;
  justify-content: center;
  line-height: 1;
  min-height: 32px;
  min-width: 32px;
  padding: 0;
}

.np-list-window {
  display: grid;
  gap: 14px;
  max-width: 1024px;
}

.client-toolbar.np-list-filters {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) repeat(4, minmax(94px, 135px));
  margin-bottom: 0;
}

.client-toolbar.np-list-filters .client-tool {
  width: 100%;
}

.np-list-window .compact-summary {
  margin-bottom: 0;
}

.np-list-window .table-wrap {
  margin-top: 0;
}

.budget-seller-notes-table {
  max-width: 100%;
  overflow: hidden !important;
  width: 100%;
}

.budget-seller-notes-table .dt-container,
.budget-seller-notes-table .dt-layout-table,
.budget-seller-notes-table .dt-layout-cell {
  max-width: 100%;
  width: 100%;
}

.budget-seller-notes-table .dt-layout-table {
  overflow-x: hidden !important;
}

.budget-seller-notes-table .dt-layout-row {
  padding: 8px 10px;
}

.budget-seller-notes-table .dt-layout-row:last-child {
  justify-content: space-between;
}

.budget-seller-notes-table .dt-layout-row:last-child .dt-layout-cell:last-child,
.budget-seller-notes-table .dt-layout-row:last-child .dt-end,
.budget-seller-notes-table .dt-layout-row:last-child .dt-layout-end {
  margin-left: auto;
}

.budget-seller-notes-table .dt-layout-row:last-child .dt-paging {
  justify-content: flex-end;
  margin-left: auto;
}

.budget-seller-notes-table table,
.budget-seller-notes-table table.dataTable {
  max-width: 100%;
  min-width: 0;
  table-layout: fixed;
  width: 100% !important;
}

.budget-seller-notes-table th,
.budget-seller-notes-table td {
  font-size: 11px;
  overflow: hidden;
  padding: 5px 4px;
  text-overflow: ellipsis;
  vertical-align: top;
  white-space: nowrap;
}

.budget-seller-notes-table td small {
  color: var(--muted);
  display: block;
  font-size: 10px;
  line-height: 1.15;
  margin-top: 1px;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.budget-seller-notes-table .number-cell {
  text-align: right;
}

.budget-seller-notes-table a {
  color: var(--accent);
  font-weight: 800;
  text-decoration: none;
}

.vendedores-window {
  display: grid;
  gap: 16px;
  max-width: 1024px;
}

.vendedores-toolbar {
  margin-bottom: 0;
  max-width: 100%;
  width: 100%;
}

.vendedores-form-grid {
  display: grid;
  gap: 10px 12px;
  grid-template-columns: 90px minmax(240px, 1fr) 120px minmax(260px, 1fr);
}

.vendedores-form-grid label {
  display: grid;
  gap: 4px;
}

.vendedores-form-grid span {
  color: #173a7a;
  font-size: 12px;
  font-weight: 800;
}

.vendedores-form-grid .form-actions {
  align-items: end;
  display: flex;
  gap: 8px;
  grid-column: 1 / -1;
  justify-content: flex-end;
}

.vendedores-table {
  margin-top: 0;
  max-width: 100%;
  overflow: visible;
  scrollbar-gutter: stable;
  width: 100%;
}

.vendedores-table .dt-container,
.vendedores-table .dt-layout-table,
.vendedores-table .dt-layout-cell {
  max-width: 100%;
  width: 100%;
}

.vendedores-table .dt-layout-table {
  overflow-x: auto;
}

.vendedores-table table,
.vendedores-table table.dataTable {
  table-layout: fixed;
  min-width: 0;
  width: 100%;
}

.dense-table.vendedores-table table {
  min-width: 0;
}

.vendedores-table th {
  white-space: nowrap;
}

.vendedores-table th,
.vendedores-table td {
  box-sizing: border-box;
  overflow: hidden;
  padding-left: 6px;
  padding-right: 6px;
  text-overflow: ellipsis;
  vertical-align: middle;
}

.vendedores-table th:nth-child(1),
.vendedores-table td:nth-child(1) {
  width: 72px;
  min-width: 72px;
  max-width: 72px;
}

.vendedores-table th:nth-child(2),
.vendedores-table td:nth-child(2) {
  width: 36%;
  min-width: 330px;
}

.vendedores-table th:nth-child(3),
.vendedores-table td:nth-child(3) {
  width: 110px;
  min-width: 110px;
  max-width: 110px;
}

.vendedores-table th:nth-child(4),
.vendedores-table td:nth-child(4) {
  width: 34%;
  min-width: 300px;
}

.vendedores-table th:nth-child(5),
.vendedores-table td:nth-child(5) {
  width: 82px;
  min-width: 82px;
  max-width: 82px;
  text-align: center;
}

.vendedores-table .code-input {
  min-width: 0;
  width: 100%;
}

.vendedores-table .text-input {
  min-width: 0;
  width: 100%;
}

.vendedores-table .danger-button {
  align-items: center;
  display: inline-flex;
  font-size: 12px;
  gap: 4px;
  justify-content: center;
  min-height: 30px;
  min-width: 0;
  padding: 4px 7px;
  width: 68px;
}

.vendedores-delete-button .delete-icon {
  align-items: center;
  border: 1px solid rgb(255 255 255 / 42%);
  border-radius: 50%;
  display: inline-flex;
  font-size: 13px;
  font-weight: 900;
  height: 16px;
  justify-content: center;
  line-height: 1;
  width: 16px;
}

.vendedores-table .grid-input {
  height: 34px;
}

.table-wrap:has(table[data-datatable]) {
  overflow: auto;
}

.dense-table table[data-datatable] {
  min-width: 0;
}

.aramis-datatable {
  table-layout: fixed;
}

.aramis-datatable th {
  white-space: nowrap;
}

.aramis-datatable .grid-input {
  width: 100%;
}

.dt-container {
  color: #111827;
  font-family: inherit;
  font-size: 13px;
}

.dt-container .dt-layout-row {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin: 0 0 8px;
}

.dt-container .dt-layout-row:last-child {
  margin: 8px 0 0;
}

.dt-container .dt-search,
.dt-container .dt-length,
.dt-container .dt-info,
.dt-container .dt-paging {
  color: #334155;
  font-size: 12px;
}

.dt-container .dt-search input,
.dt-container .dt-length select {
  border: 1px solid #cbd5e1;
  border-radius: 5px;
  min-height: 28px;
  padding: 4px 6px;
}

.dt-container .dt-search input {
  width: 260px;
}

.dt-container .dt-paging button {
  border: 1px solid #cbd5e1;
  border-radius: 5px;
  margin-left: 4px;
  min-height: 26px;
  padding: 3px 8px;
}

.aramis-datatable-fallback,
.dt-container {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 1px 0 rgb(15 23 42 / 3%);
  overflow: hidden;
}

.aramis-datatable-fallback .dt-layout-row,
.dt-container .dt-layout-row {
  margin: 0;
  padding: 10px;
}

.aramis-datatable-fallback .aramis-dt-toolbar,
.dt-container .dt-layout-row:first-child {
  background: #f8fafb;
  border-bottom: 1px solid var(--line);
}

.aramis-datatable-fallback .aramis-dt-footer,
.dt-container .dt-layout-row:last-child {
  background: #ffffff;
  border-top: 1px solid var(--line);
}

.aramis-datatable-fallback .dt-layout-table,
.dt-container .dt-layout-table {
  background: #ffffff;
  overflow-x: auto;
}

.aramis-datatable-fallback .dt-layout-cell,
.dt-container .dt-layout-cell {
  min-width: 0;
  width: auto;
}

.aramis-datatable-fallback .dt-start,
.dt-container .dt-start {
  justify-content: flex-start;
}

.aramis-datatable-fallback .dt-end,
.dt-container .dt-end {
  justify-content: flex-end;
}

.aramis-datatable-fallback .dt-length label,
.aramis-datatable-fallback .dt-search label,
.dt-container .dt-length label,
.dt-container .dt-search label {
  align-items: center;
  color: #334155;
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  gap: 7px;
}

.aramis-datatable-fallback .dt-length select,
.dt-container .dt-length select {
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  color: #0f172a;
  font: inherit;
  min-height: 32px;
  min-width: 78px;
  padding: 5px 28px 5px 8px;
}

.aramis-datatable-fallback .dt-search,
.dt-container .dt-search {
  position: relative;
}

.aramis-datatable-fallback .dt-search input,
.dt-container .dt-search input {
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  color: #0f172a;
  font: inherit;
  min-height: 34px;
  padding: 6px 10px;
  width: min(360px, 44vw);
}

.aramis-datatable-fallback .dt-search input:focus,
.aramis-datatable-fallback .dt-length select:focus,
.dt-container .dt-search input:focus,
.dt-container .dt-length select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgb(23 107 95 / 14%);
  outline: 0;
}

.aramis-datatable-fallback table,
.dt-container table {
  border-left: 0;
  border-right: 0;
  margin: 0;
}

.aramis-datatable-fallback thead th,
.dt-container thead th {
  background: #eaf0f4;
  color: #1f2937;
  font-size: 11px;
  letter-spacing: 0;
  position: relative;
  text-transform: uppercase;
}

.aramis-datatable-fallback thead th.sorting,
.dt-container thead th.sorting {
  cursor: pointer;
  padding-right: 18px;
}

.aramis-datatable-fallback thead th.sorting::after,
.dt-container thead th.dt-orderable-asc::after,
.dt-container thead th.dt-orderable-desc::after {
  color: #94a3b8;
  content: "↕";
  font-size: 11px;
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
}

.aramis-datatable-fallback thead th.sorting-asc::after {
  color: var(--accent);
  content: "↑";
}

.aramis-datatable-fallback thead th.sorting-desc::after {
  color: var(--accent);
  content: "↓";
}

.aramis-datatable-fallback tbody tr:hover td,
.dt-container tbody tr:hover td {
  background: #f8fbfc;
}

.aramis-datatable-fallback .dt-info,
.dt-container .dt-info {
  color: #475569;
  font-size: 12px;
  font-weight: 700;
}

.aramis-datatable-fallback .dt-paging,
.dt-container .dt-paging {
  align-items: center;
  display: flex;
  gap: 5px;
}

.aramis-datatable-fallback .dt-paging button,
.dt-container .dt-paging button {
  background: #eef2f5;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  color: #334155;
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
  min-height: 30px;
  margin-left: 0;
  padding: 5px 9px;
}

.aramis-datatable-fallback .dt-paging button:hover:not(:disabled),
.dt-container .dt-paging button:hover:not(:disabled) {
  background: #e2e8f0;
}

.aramis-datatable-fallback .dt-paging button:disabled,
.dt-container .dt-paging button:disabled,
.dt-container .dt-paging button.disabled {
  background: #f8fafc;
  color: #94a3b8;
  cursor: not-allowed;
}

.codigos-producto-window {
  display: grid;
  gap: 14px;
}

.codigos-producto-toolbar {
  margin-bottom: 0;
}

.codigos-producto-filter {
  align-items: center;
  display: grid;
  flex: 1;
  gap: 8px;
  grid-template-columns: minmax(260px, 520px) 130px 110px 110px;
  margin: 0;
}

.codigos-producto-form-grid {
  display: grid;
  gap: 10px 12px;
  grid-template-columns: 160px minmax(320px, 1fr) 100px 110px;
}

.codigos-producto-form-grid label {
  display: grid;
  gap: 4px;
}

.codigos-producto-form-grid span {
  color: #173a7a;
  font-size: 12px;
  font-weight: 800;
}

.codigos-producto-form-grid .form-actions {
  align-items: end;
  display: flex;
  gap: 8px;
  grid-column: 1 / -1;
  justify-content: flex-end;
}

.codigos-producto-table {
  margin-top: 0;
  overflow: hidden;
}

.codigos-producto-table table {
  min-width: 0;
  table-layout: fixed;
  width: 100%;
}

.codigos-producto-table th:nth-child(1),
.codigos-producto-table td:nth-child(1) {
  width: 210px;
}

.codigos-producto-table th:nth-child(3),
.codigos-producto-table td:nth-child(3) {
  width: 100px;
}

.codigos-producto-table th:nth-child(4),
.codigos-producto-table td:nth-child(4) {
  width: 120px;
}

.codigos-producto-table th:nth-child(5),
.codigos-producto-table td:nth-child(5) {
  width: 96px;
}

.codigos-producto-table .text-input,
.codigos-producto-table .code-input,
.codigos-producto-table .number-input {
  min-width: 0;
}

.tintas-window {
  display: grid;
  gap: 14px;
}

.tintas-toolbar {
  margin-bottom: 0;
}

.tintas-filter {
  align-items: center;
  display: grid;
  flex: 1;
  gap: 8px;
  grid-template-columns: minmax(220px, 1fr) 90px 95px 95px 90px;
  margin: 0;
}

.inline-alert {
  background: #e7f8ed;
  border: 1px solid #9ee0b5;
  border-radius: 6px;
  color: #0f5d2e;
  padding: 8px 10px;
}

.warning-alert {
  background: #fff8e8;
  border-color: #e3c37d;
  color: #7a4b00;
}

.tintas-form-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: 100px minmax(220px, 1fr) 160px 90px 90px 90px 90px;
}

.tintas-form-grid label {
  display: grid;
  gap: 4px;
}

.tintas-form-grid span {
  color: #002a70;
  font-weight: 700;
}

.tintas-form-grid .wide-field {
  grid-column: span 2;
}

.tintas-form-grid .form-actions {
  align-items: end;
  display: flex;
  gap: 8px;
}

.tintas-table {
  max-width: 100%;
  overflow: hidden;
  width: 100%;
}

.table-wrap.tintas-table:has(table[data-datatable]) {
  overflow: hidden;
}

.tintas-table .dt-container,
.tintas-table .dt-layout-table,
.tintas-table .dt-layout-cell {
  max-width: 100%;
  width: 100%;
}

.tintas-table .dt-layout-row:last-child {
  justify-content: space-between;
}

.tintas-table .dt-layout-row:last-child .dt-layout-cell:last-child,
.tintas-table .dt-layout-row:last-child .dt-end,
.tintas-table .dt-layout-row:last-child .dt-layout-end {
  margin-left: auto;
}

.tintas-table .dt-layout-row:last-child .dt-paging {
  justify-content: flex-end;
  margin-left: auto;
}

.tintas-table table,
.tintas-table table.dataTable {
  min-width: 1280px;
  table-layout: fixed;
}

.tintas-table th:nth-child(1),
.tintas-table td:nth-child(1) {
  width: 66px;
}

.tintas-table th:nth-child(2),
.tintas-table td:nth-child(2) {
  text-align: center;
  width: 34px;
}

.tintas-table th:nth-child(3),
.tintas-table td:nth-child(3) {
  width: 220px;
}

.tintas-table th:nth-child(4),
.tintas-table td:nth-child(4) {
  width: 130px;
}

.tintas-table th:nth-child(5),
.tintas-table td:nth-child(5) {
  width: 72px;
}

.tintas-table th:nth-child(6),
.tintas-table td:nth-child(6) {
  width: 125px;
}

.tintas-table th:nth-child(7),
.tintas-table td:nth-child(7) {
  width: 68px;
}

.tintas-table th:nth-child(8),
.tintas-table td:nth-child(8) {
  width: 78px;
}

.tintas-table th:nth-child(9),
.tintas-table td:nth-child(9) {
  width: 68px;
}

.tintas-table th:nth-child(10),
.tintas-table td:nth-child(10) {
  width: 88px;
}

.tintas-table th:nth-child(11),
.tintas-table td:nth-child(11) {
  width: 76px;
}

.tintas-table th:nth-child(12),
.tintas-table td:nth-child(12) {
  width: 118px;
}

.tintas-table th:nth-child(13),
.tintas-table td:nth-child(13) {
  width: 68px;
}

.tintas-table th:nth-child(14),
.tintas-table td:nth-child(14) {
  width: 170px;
}

.tintas-table .text-input,
.tintas-table .code-input,
.tintas-table .number-input,
.tintas-table .tiny-input {
  min-width: 0;
}

.tintas-table select.text-input {
  padding-left: 3px;
}

.tinta-esp-cell {
  vertical-align: middle;
}

.tinta-esp-checkbox {
  height: 14px;
  margin: 0;
  width: 14px;
}

.tintas-table tr.selected-row td {
  background: #eef7f4;
}

.tintas-detail-grid {
  align-items: stretch;
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.tinta-componentes-box {
  background: #ffffff;
  border: 1px solid #d2dbe7;
  border-radius: 8px;
  box-shadow: 0 1px 0 rgb(15 23 42 / 3%);
  display: grid;
  gap: 8px;
  grid-template-rows: auto 1fr auto;
  min-height: 158px;
  padding: 10px;
}

.tintas-observaciones-box {
  background: #ffffff;
  border: 1px solid #d2dbe7;
  border-radius: 8px;
  box-shadow: 0 1px 0 rgb(15 23 42 / 3%);
  display: grid;
  gap: 8px;
  grid-template-rows: auto 1fr;
  min-height: 158px;
  padding: 10px;
}

.tinta-detail-title {
  align-items: center;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.tinta-detail-title strong {
  color: #002a70;
}

.tinta-detail-title span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.tinta-componentes-grid {
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  grid-template-columns: 78px minmax(210px, 1fr) 72px 86px;
  max-width: 100%;
  overflow: hidden;
  width: 100%;
}

.tinta-componentes-grid > span,
.tinta-componentes-grid > input,
.tinta-componentes-grid > button {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  min-height: 32px;
  min-width: 0;
  padding: 4px 7px;
}

.tinta-componentes-grid > input {
  text-align: left;
  width: 100%;
}

.tinta-componentes-grid > button {
  justify-content: center;
  width: 100%;
}

.tinta-componentes-grid > span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tinta-componentes-grid > span:nth-child(-n+4) {
  background: #eaf0f4;
  color: #0b274d;
  font-size: 12px;
  font-weight: 700;
}

.tinta-componentes-grid > span:nth-child(4) {
  justify-content: center;
  text-align: center;
}

.tinta-componentes-grid > span:nth-child(1),
.tinta-componentes-grid > span:nth-child(3),
.tinta-componentes-grid > span:nth-child(4n+2) {
  justify-content: flex-start;
  text-align: left;
}

.tinta-componente-grid-row {
  display: contents;
}

.tinta-componentes-empty {
  color: #475569;
  grid-column: 1 / -1;
  justify-content: center !important;
  min-height: 56px !important;
  text-align: center !important;
  white-space: normal !important;
}

.tinta-componente-add {
  display: grid;
  gap: 6px;
  grid-template-columns: 78px 72px 150px;
  margin: 0;
  width: max-content;
}

.tinta-componente-add input {
  min-width: 0;
  text-align: left;
  width: 100%;
}

.tintas-observaciones-box textarea {
  height: 100%;
  min-height: 104px;
  resize: vertical;
}

.tintas-table .row-actions {
  align-items: center;
  display: flex;
  gap: 5px;
  justify-content: center;
}

.tintas-table .row-actions form {
  margin: 0;
}

.tintas-delete-button {
  align-items: center;
  display: inline-flex;
  font-size: 12px;
  gap: 4px;
  justify-content: center;
  min-height: 30px;
  min-width: 0;
  padding: 4px 7px;
  width: 68px;
}

.tintas-coverage-tool {
  flex: 0 0 auto;
}

.tintas-fox-footer {
  align-items: end;
  background: #ffffff;
  border: 1px solid #d2dbe7;
  border-radius: 8px;
  box-shadow: 0 1px 0 rgb(15 23 42 / 3%);
  display: flex;
  gap: 16px;
  justify-content: space-between;
  padding: 10px;
}

.tintas-fox-footer form {
  align-items: end;
  display: flex;
  gap: 8px;
  margin: 0;
}

.tintas-cotizacion-field {
  display: grid;
  gap: 3px;
}

.tintas-cotizacion-field span {
  color: #002a70;
  font-size: 12px;
  font-weight: 700;
}

.tintas-footer-tools {
  align-items: end;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.pantone-dialog {
  max-width: 720px;
  overflow: hidden;
  width: 720px;
}

.pantone-dialog::backdrop {
  background: rgb(15 23 42 / 42%);
}

.pantone-dialog-title {
  align-items: center;
  border-bottom: 1px solid #e2e8f0;
  display: flex;
  justify-content: space-between;
  margin: -4px -4px 14px;
  padding: 2px 4px 12px;
}

.pantone-dialog-title h2 {
  color: #0f172a;
  font-size: 20px;
  margin: 0;
}

.pantone-dialog-title p {
  color: #64748b;
  font-size: 12px;
  margin-top: 3px;
}

.pantone-form {
  display: grid;
  gap: 14px;
  margin: 0;
}

.pantone-calculator-shell {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1fr) 230px;
}

.pantone-calculator-panel {
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
  border: 1px solid #d8e1ec;
  border-radius: 12px;
  display: grid;
  gap: 12px;
  padding: 14px;
}

.pantone-options {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr 1fr;
}

.pantone-options label {
  align-items: center;
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  color: #0b2f69;
  cursor: pointer;
  display: flex;
  font-size: 13px;
  font-weight: 700;
  gap: 8px;
  min-height: 48px;
  padding: 8px 10px;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.pantone-options label:hover {
  border-color: #7aa2d8;
  box-shadow: 0 8px 18px rgb(15 23 42 / 8%);
  transform: translateY(-1px);
}

.pantone-options label:has(input:checked) {
  background: #eaf7f3;
  border-color: #176b5f;
  box-shadow: 0 0 0 3px rgb(23 107 95 / 10%);
  color: #11584f;
}

.pantone-options input {
  accent-color: #0f6bdc;
  height: 18px;
  margin: 0;
  width: 18px;
}

.pantone-field-card {
  background: #ffffff;
  border: 1px solid #d8e1ec;
  border-radius: 10px;
  display: grid;
  gap: 6px;
  padding: 10px;
}

.pantone-field-card.active {
  border-color: #176b5f;
  box-shadow: 0 0 0 3px rgb(23 107 95 / 12%);
}

.pantone-field-card span,
.pantone-field-card strong {
  color: #0b2f69;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.pantone-code-input {
  font-size: 18px;
  font-weight: 800;
  height: 42px;
  letter-spacing: .02em;
  margin: 0;
  width: 100%;
}

.pantone-cantidad {
  align-items: end;
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr 82px;
}

.pantone-cantidad span {
  grid-column: 1 / -1;
}

.pantone-cantidad input {
  font-size: 22px;
  font-weight: 900;
  height: 48px;
  text-align: right;
}

.pantone-cantidad strong {
  align-items: center;
  background: #eef6ff;
  border: 1px solid #d3e5fb;
  border-radius: 8px;
  display: flex;
  height: 48px;
  justify-content: center;
  text-transform: none;
}

.pantone-keypad {
  background: #182231;
  border: 1px solid #0f172a;
  border-radius: 14px;
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 8%), 0 12px 24px rgb(15 23 42 / 16%);
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, 1fr);
  padding: 12px;
}

.pantone-keypad button {
  background: linear-gradient(180deg, #f8fafc 0%, #dfe7f1 100%);
  border: 1px solid rgb(255 255 255 / 20%);
  border-radius: 10px;
  box-shadow: 0 3px 0 #9aa8ba;
  color: #0f172a;
  cursor: pointer;
  font-size: 18px;
  font-weight: 900;
  min-height: 42px;
  transition: transform .08s ease, box-shadow .08s ease, filter .12s ease;
}

.pantone-keypad button:hover {
  filter: brightness(1.04);
}

.pantone-keypad button:active {
  box-shadow: 0 1px 0 #9aa8ba;
  transform: translateY(2px);
}

.pantone-keypad .danger-key {
  background: linear-gradient(180deg, #ffe9e7 0%, #f3b8b2 100%);
  color: #9f1d16;
}

.pantone-keypad .wide-key {
  grid-column: span 2;
}

.pantone-actions {
  background: #f8fafc;
  border: 1px solid #d8e1ec;
  border-radius: 10px;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 0;
  padding: 10px;
}

.pantone-actions .client-tool:first-child {
  background: #176b5f;
  border-color: #176b5f;
  color: #ffffff;
}

@media (max-width: 820px) {
  .pantone-dialog {
    width: min(720px, calc(100vw - 24px));
  }

  .pantone-calculator-shell {
    grid-template-columns: 1fr;
  }

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

.pantone-resultado {
  display: grid;
  gap: 7px;
  margin-top: 10px;
}

.pantone-resumen {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
}

.pantone-resumen strong {
  color: #002a70;
}

.pantone-resumen span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.pantone-resultado table {
  border-collapse: collapse;
  table-layout: fixed;
  width: 100%;
}

.pantone-resultado th,
.pantone-resultado td {
  border: 1px solid var(--line);
  font-size: 12px;
  padding: 4px 5px;
}

.pantone-resultado th {
  background: #eaf0f4;
  color: #0b274d;
}

.pantone-resultado th:nth-child(1),
.pantone-resultado td:nth-child(1) {
  width: 54px;
}

.pantone-resultado th:nth-child(2),
.pantone-resultado td:nth-child(2) {
  width: 120px;
}

.pantone-resultado th:nth-child(4),
.pantone-resultado td:nth-child(4),
.pantone-resultado th:nth-child(5),
.pantone-resultado td:nth-child(5) {
  text-align: right;
  width: 70px;
}

.pantone-resultado tfoot td {
  color: #002a70;
  font-weight: 700;
}

.troqueles-window,
.troquel-detail-window {
  display: grid;
  gap: 14px;
}

.troqueles-toolbar {
  margin-bottom: 0;
}

.troqueles-filter {
  align-items: center;
  display: grid;
  flex: 1;
  gap: 8px;
  grid-template-columns: minmax(260px, 520px) 130px 110px 110px;
  margin: 0;
}

.troqueles-form-grid {
  display: grid;
  gap: 10px 12px;
  grid-template-columns: 100px minmax(280px, 1fr) 90px 140px;
}

.troqueles-form-grid label {
  display: grid;
  gap: 4px;
}

.troqueles-form-grid span {
  color: #002a70;
  font-size: 12px;
  font-weight: 700;
}

.troqueles-form-grid .form-actions {
  align-self: end;
  display: flex;
  gap: 8px;
}

.troqueles-table table {
  table-layout: fixed;
}

.troqueles-table th:nth-child(1),
.troqueles-table td:nth-child(1) {
  width: 84px;
}

.troqueles-table th:nth-child(3),
.troqueles-table td:nth-child(3) {
  width: 82px;
}

.troqueles-table th:nth-child(4),
.troqueles-table td:nth-child(4) {
  width: 150px;
}

.troqueles-table th:nth-child(5),
.troqueles-table td:nth-child(5) {
  width: 132px;
}

.troqueles-table th:nth-child(6),
.troqueles-table td:nth-child(6),
.troqueles-table th:nth-child(7),
.troqueles-table td:nth-child(7),
.troqueles-table th:nth-child(8),
.troqueles-table td:nth-child(8) {
  width: 62px;
}

.troqueles-table th:nth-child(9),
.troqueles-table td:nth-child(9) {
  width: 140px;
}

.troqueles-table .text-input,
.troqueles-table .code-input,
.troqueles-table .number-input {
  min-width: 0;
}

.sacabocados-window,
.sacabocado-detail-window {
  display: grid;
  gap: 14px;
  max-width: 1024px;
}

.sacabocados-toolbar,
.sacabocados-detail-toolbar {
  margin-bottom: 0;
}

.sacabocados-filter {
  align-items: center;
  display: grid;
  flex: 1;
  gap: 8px;
  grid-template-columns: minmax(280px, 1fr) 128px 100px;
  margin: 0;
}

.sacabocados-form-grid {
  display: grid;
  gap: 10px 12px;
  grid-template-columns: 86px 120px minmax(260px, 1fr) 86px;
}

.modal-editor.sacabocado-create-dialog {
  max-width: 880px;
  overflow: hidden;
  overflow-x: hidden;
  padding: 16px;
  width: min(880px, calc(100vw - 32px));
}

.modal-editor.sacabocado-create-dialog h2 {
  color: #0f172a;
  font-size: 18px;
  margin-bottom: 12px;
}

.sacabocado-create-dialog .sacabocado-create-form {
  display: block;
  margin-top: 0;
  min-width: 0;
}

.sacabocado-create-dialog .sacabocado-create-grid {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 10px;
  display: grid;
  gap: 12px 10px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  padding: 14px;
}

.sacabocado-create-dialog .sacabocado-create-grid label {
  grid-column: span 2;
  min-width: 0;
}

.sacabocado-create-dialog .sacabocado-create-grid .grid-input {
  height: 34px;
  max-width: none;
  min-width: 0;
  width: 100%;
}

.sacabocado-create-dialog .field-code {
  grid-column: span 2;
}

.sacabocado-create-dialog .field-date {
  grid-column: span 3;
}

.sacabocado-create-dialog .field-description {
  grid-column: span 7;
}

.sacabocado-create-dialog .create-relation-field {
  align-items: end;
  background: #f8fafc;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  display: grid;
  gap: 10px;
  grid-column: span 6;
  grid-template-columns: 120px minmax(0, 1fr);
  padding: 10px;
}

.sacabocado-create-dialog .lookup-code-row {
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) 34px;
}

.sacabocado-create-dialog .lookup-code-row .client-tool {
  height: 34px;
  justify-content: center;
  min-width: 34px;
  padding: 0;
}

.sacabocado-create-dialog .relation-name-field input {
  background: #f3f6fa;
  color: #263445;
  font-weight: 700;
}

.sacabocado-create-dialog .field-medidas {
  grid-column: span 4;
}

.sacabocado-create-dialog .field-format {
  grid-column: span 2;
}

.sacabocado-create-dialog .field-select {
  grid-column: span 4;
}

.sacabocado-create-dialog .field-nature {
  grid-column: span 4;
}

.sacabocado-create-dialog .sacabocado-create-grid .form-actions {
  border-top: 1px solid var(--line);
  grid-column: 1 / -1;
  justify-content: flex-end;
  margin-top: 4px;
  padding-top: 12px;
}

.sacabocado-create-dialog .form-actions button {
  min-height: 34px;
  min-width: 88px;
}

.sacabocados-form-grid label,
.sacabocado-field-grid label {
  display: grid;
  gap: 4px;
}

.sacabocados-form-grid span,
.sacabocado-field-grid span {
  color: #002a70;
  font-size: 12px;
  font-weight: 700;
}

.sacabocados-form-grid .form-actions {
  align-self: end;
  display: flex;
  gap: 8px;
}

.sacabocados-table:has(table[data-datatable]) {
  overflow: visible;
}

.sacabocados-table .dt-layout-table {
  overflow-x: hidden;
}

.sacabocados-table table {
  table-layout: fixed;
  width: 100%;
}

.sacabocados-table th,
.sacabocados-table td {
  font-size: 11px;
  padding: 4px 6px;
  vertical-align: middle;
}

.sacabocados-table .grid-input {
  font-size: 12px;
  height: 26px;
  min-width: 0;
  padding: 3px 5px;
}

.sacabocados-table td.split-cell-cell {
  overflow: visible;
  vertical-align: middle;
}

.sacabocados-table .sacabocados-split-controls {
  align-items: center;
  display: grid;
  gap: 4px;
  grid-template-columns: minmax(0, 1fr) 10px minmax(0, 1fr);
  width: 100%;
}

.sacabocados-table .sacabocados-split-controls span {
  color: #1d232f;
  font-size: 11px;
  font-weight: 700;
  text-align: center;
}

.sacabocados-table th:last-child,
.sacabocados-table td.actions-cell {
  padding-left: 4px;
  padding-right: 4px;
  text-align: center;
  vertical-align: middle;
  width: 132px;
}

.sacabocados-table td.actions-cell {
  overflow: visible;
  white-space: nowrap;
}

.sacabocados-table .sacabocados-row-actions {
  align-items: center;
  display: inline-flex;
  gap: 5px;
  justify-content: center;
  min-width: 0;
  width: 100%;
}

.sacabocados-table .sacabocados-row-actions .compact-action {
  align-items: center;
  border-radius: 7px;
  box-sizing: border-box;
  display: inline-flex;
  font-size: 11px;
  font-weight: 700;
  gap: 4px;
  height: 30px;
  justify-content: center;
  line-height: 1;
  min-height: 30px;
  padding: 0 7px;
}

.sacabocados-table .sacabocados-row-actions .view-action {
  min-width: 50px;
  width: 50px;
}

.sacabocados-table .sacabocados-row-actions .delete-action {
  gap: 4px;
  min-width: 68px;
  width: 68px;
}

.sacabocados-table .view-action .view-icon,
.sacabocados-table .delete-action .delete-icon {
  align-items: center;
  border-radius: 50%;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 900;
  height: 15px;
  justify-content: center;
  line-height: 1;
  width: 15px;
}

.sacabocados-table .view-action .view-icon {
  background: #dbeafe;
  color: #0f4f80;
}

.sacabocados-table .delete-action .delete-icon {
  border: 1px solid rgb(255 255 255 / 48%);
}

.sacabocado-detail-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1fr) 330px;
}

.sacabocado-card {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
}

.sacabocado-card h2 {
  color: #002a70;
  font-size: 14px;
  margin: 0 0 10px;
}

.sacabocado-field-grid {
  display: grid;
  gap: 10px 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

.sacabocado-field-grid .span-2 {
  grid-column: span 2;
}

.sacabocado-field-grid .span-4 {
  grid-column: span 4;
}

.sacabocado-field-grid textarea.grid-input {
  height: 74px;
  resize: vertical;
}

.sacabocado-figuras-table table {
  table-layout: fixed;
}

.sacabocado-figuras-table th:first-child,
.sacabocado-figuras-table td:first-child {
  width: 90px;
}

.sacabocado-figuras-table .grid-input {
  width: 100%;
}

.sacabocado-title {
  margin-bottom: 0;
}

.sacabocado-fox-card {
  background: #d4d4d4;
  border: 1px solid #aeb6c2;
  box-shadow: inset 0 0 0 1px #ececec;
  display: grid;
  gap: 10px 18px;
  grid-template-columns: minmax(0, 1fr) 176px;
  min-height: 342px;
  padding: 16px 12px 12px;
  position: relative;
}

.sacabocado-code-row {
  align-items: center;
  display: flex;
  gap: 8px;
  grid-column: 1 / -1;
  justify-content: center;
}

.sacabocado-code-row label {
  align-items: center;
  display: grid;
  gap: 12px;
  grid-template-columns: 120px 150px;
}

.sacabocado-code-row span,
.sacabocado-fox-grid span,
.cut-top-controls label,
.cut-side-panel legend {
  color: #002a70;
  font-weight: 700;
}

.sacabocado-code-row span {
  font-size: 18px;
  text-align: right;
}

.sacabocado-code-row .grid-input {
  height: 32px;
}

.sacabocado-fox-grid {
  align-content: start;
  border: 1px solid #b6b6b6;
  box-shadow: inset 1px 1px #f3f3f3, inset -1px -1px #9c9c9c;
  display: grid;
  gap: 8px 8px;
  grid-template-columns: 156px 92px 36px minmax(120px, 1fr);
  padding: 14px 12px;
}

.sacabocado-fox-grid label {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-column: 1 / span 2;
  grid-template-columns: 156px minmax(0, 1fr);
}

.sacabocado-fox-grid label.wide-row {
  grid-column: 1 / -1;
}

.sacabocado-fox-grid .pair-field {
  grid-column: 1 / -1;
  grid-template-columns: 156px 84px auto 84px;
}

.sacabocado-fox-grid .grid-input {
  background: #fff;
  height: 30px;
  min-width: 0;
  width: 100%;
}

.sacabocado-fox-grid .wide-row .grid-input {
  max-width: 100%;
}

.sacabocado-fox-grid em,
.cut-top-controls strong {
  font-style: normal;
  font-weight: 700;
  text-align: center;
}

.sacabocado-fox-grid .mini-tool {
  min-height: 30px;
  min-width: 34px;
  padding: 3px;
}

.sacabocado-linked-name {
  align-self: center;
  color: #111827;
  font-size: 14px;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sacabocado-cut-entry {
  align-self: end;
  border: 1px solid #b6b6b6;
  box-shadow: inset 1px 1px #f3f3f3, inset -1px -1px #9c9c9c;
  display: flex;
  gap: 14px;
  justify-content: center;
  margin-bottom: 10px;
  padding: 14px 10px;
}

.sacabocado-cut-entry .client-tool {
  background: #e9edf2;
  border-color: #8ea4c4;
  box-shadow: inset 1px 1px #fff, inset -1px -1px #a8b4c2;
  min-height: 46px;
}

.sacabocado-cut-entry .cut-open-button {
  color: #001a8c;
  font-size: 16px;
  min-width: 74px;
}

.sacabocado-cut-entry .cut-open-icon {
  color: #005f95;
  font-size: 26px;
  min-width: 48px;
}

.sacabocado-secondary-grid {
  display: grid;
  gap: 12px;
}

.cut-dialog {
  background: #d4d4d4;
  border: 2px solid #5d7f9d;
  max-width: 780px;
  width: min(780px, calc(100vw - 32px));
}

.cut-dialog h2 {
  background: linear-gradient(#c9deef, #a7c2d8);
  border: 1px solid #7f9cb5;
  color: #001a8c;
  margin: -10px -10px 12px;
  padding: 8px 12px;
}

.cut-editor {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) 186px;
}

.cut-canvas-panel,
.cut-side-panel fieldset {
  border: 1px solid #adadad;
  box-shadow: inset 1px 1px #f3f3f3, inset -1px -1px #9c9c9c;
  padding: 12px;
}

.cut-top-controls {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  justify-content: center;
}

.cut-top-controls label {
  align-items: center;
  display: inline-flex;
  gap: 6px;
}

.cut-top-controls .grid-input {
  height: 30px;
  width: 86px;
}

.cut-top-controls .cut-bocas-label {
  margin-left: auto;
}

.cut-sheet-wrap {
  align-items: center;
  display: grid;
  gap: 6px;
  grid-template-columns: 38px minmax(0, 1fr);
  margin: 12px 0;
}

.cut-sheet {
  background: #d7d7d7;
  border: 2px solid #7f7f7f;
  display: grid;
  min-height: 250px;
  min-width: 0;
  width: 100%;
}

.cut-cell {
  align-items: center;
  border-left: 1px solid #8c8c8c;
  border-top: 1px solid #8c8c8c;
  display: flex;
  justify-content: center;
  min-height: 42px;
  position: relative;
}

.cut-cell input {
  background: #fff;
  border: 1px solid #ccd6e3;
  height: 20px;
  text-align: center;
  width: 24px;
}

.cut-left-cut-line-1 {
  border-left: 2px solid #5e5e5e;
}

.cut-left-cut-line-2 {
  border-left: 4px double #5e5e5e;
}

.cut-left-cut-line-3 {
  border-left: 2px dotted #5e5e5e;
}

.cut-left-cut-line-4 {
  border-left: 2px dashed #5e5e5e;
}

.cut-top-cut-line-1 {
  border-top: 2px solid #5e5e5e;
}

.cut-top-cut-line-2 {
  border-top: 4px double #5e5e5e;
}

.cut-top-cut-line-3 {
  border-top: 2px dotted #5e5e5e;
}

.cut-top-cut-line-4 {
  border-top: 2px dashed #5e5e5e;
}

.cut-measure {
  color: #001a8c;
  font-size: 16px;
  font-weight: 700;
}

.cut-measure-left {
  justify-self: end;
}

.cut-measure-bottom {
  grid-column: 2;
  justify-self: center;
}

.cut-side-panel {
  display: grid;
  gap: 12px;
}

.cut-side-panel fieldset {
  display: grid;
  gap: 8px;
  margin: 0;
}

.cut-side-panel .client-tool {
  justify-content: center;
  min-height: 30px;
}

.cut-active-line {
  color: #475569;
  font-size: 12px;
  text-align: center;
}

.cut-line-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  max-height: 96px;
  overflow: auto;
}

.cut-line-pick {
  font-size: 11px;
  min-height: 24px;
  min-width: 38px;
  padding: 2px 5px;
}

.cut-line-pick.active {
  background: #fff4bd;
  border-color: #8a6d00;
}

.cut-process {
  color: #6b7280;
  position: relative;
}

.cut-process::before {
  content: "";
  display: inline-block;
  margin-right: 10px;
  width: 44px;
}

.cut-process-1::before {
  border-top: 2px solid #555;
}

.cut-process-2::before {
  border-top: 4px double #555;
}

.cut-process-3::before {
  border-top: 2px dotted #555;
}

.cut-process-4::before {
  border-top: 2px dashed #555;
}

.cut-help {
  margin-bottom: 0;
}

.sacabocado-detail-layout {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1fr) 280px;
}

.sacabocado-main-card,
.sacabocado-class-card {
  min-width: 0;
}

.sacabocado-class-card {
  grid-column: 1;
  grid-row: 2;
}

.sacabocado-card-head {
  align-items: flex-start;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin: -2px 0 12px;
  padding-bottom: 10px;
}

.sacabocado-card-head h2,
.sacabocado-cut-card h2 {
  color: #002a70;
  font-size: 15px;
  margin: 0;
}

.sacabocado-card-head p,
.sacabocado-cut-card p {
  color: var(--muted);
  font-size: 12px;
  margin: 3px 0 0;
}

.sacabocado-status-pill {
  background: #eef5fb;
  border: 1px solid #d5e2f0;
  border-radius: 999px;
  color: #405168;
  flex: 0 0 auto;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 8px;
}

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

.sacabocado-web-grid label,
.sacabocado-linked-box,
.sacabocado-class-grid label,
.sacabocado-class-grid .type-stack,
.sacabocado-provider-type-stack {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.sacabocado-web-grid span,
.sacabocado-linked-box span,
.sacabocado-class-grid span {
  color: #002a70;
  font-size: 12px;
  font-weight: 700;
}

.sacabocado-web-grid .span-2 {
  grid-column: span 2;
}

.sacabocado-web-grid .span-3 {
  grid-column: span 3;
}

.sacabocado-web-grid .grid-input {
  height: 34px;
  min-width: 0;
  width: 100%;
}

.sacabocado-field-with-check {
  align-items: center;
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) 18px;
}

.sacabocado-relation-code {
  align-items: center;
  display: grid;
  gap: 5px;
  grid-template-columns: minmax(0, 1fr) 34px 18px;
}

.sacabocado-relation-code.no-check,
.sacabocado-relation-code:has(.sacabocado-lookup-button:last-child) {
  grid-template-columns: minmax(0, 1fr) 34px;
}

.sacabocado-search-check {
  accent-color: var(--accent);
  height: 16px;
  margin: 0;
  width: 16px;
}

.sacabocado-lookup-button {
  align-items: center;
  display: inline-flex;
  font-size: 13px;
  justify-content: center;
  min-height: 34px;
  min-width: 34px;
  padding: 0;
}

.sacabocado-linked-box strong {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #cbd7e6;
  border-radius: 4px;
  color: #111827;
  display: flex;
  font-size: 13px;
  font-weight: 700;
  min-height: 34px;
  overflow: hidden;
  padding: 6px 8px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sacabocado-linked-box.compact-name strong {
  max-width: 100%;
}

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

.sacabocado-class-grid .grid-input {
  height: 34px;
  min-width: 0;
  width: 100%;
}

.sacabocado-class-grid .wide {
  grid-column: span 2;
}

.sacabocado-class-grid .type-stack {
  grid-column: span 2;
  max-width: 360px;
}

.sacabocado-class-grid .type-stack label {
  display: grid;
  gap: 4px;
}

.sacabocado-class-grid .type-stack select {
  max-width: 360px;
}

.sacabocado-provider-type-stack {
  grid-column: 1 / span 2;
  max-width: 360px;
}

.sacabocado-provider-type-stack label {
  display: grid;
  gap: 4px;
}

.sacabocado-provider-type-stack .grid-input {
  max-width: 500px;
}

.sacabocado-provider-type-stack select {
  max-width: 360px;
}

.sacabocados-detail-toolbar {
  flex-wrap: wrap;
}

.sacabocados-detail-toolbar .nav-tool {
  font-weight: 800;
  justify-content: center;
  min-width: 34px;
  padding-left: 7px;
  padding-right: 7px;
}

.relation-picker-dialog {
  max-width: 900px;
  overflow-x: hidden;
  width: min(900px, calc(100vw - 32px));
}

.relation-picker-dialog h2 {
  margin-bottom: 4px;
}

.relation-picker-table {
  margin-top: 12px;
  overflow: visible;
}

.relation-picker-table:has(table[data-datatable]) {
  overflow: visible;
}

.relation-picker-table .dt-layout-table {
  overflow-x: hidden;
  overflow-y: visible;
}

.relation-picker-table table {
  table-layout: fixed;
  width: 100%;
}

.relation-picker-table th,
.relation-picker-table td {
  font-size: 12px;
  padding: 5px 7px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.relation-picker-table .compact-action {
  min-height: 28px;
  padding: 4px 7px;
  width: 84px;
}

.relation-picker-dialog-compact {
  max-width: 700px;
  overflow-x: hidden;
  width: min(700px, calc(100vw - 32px));
}

.compact-relation-picker-table .dt-layout-table {
  overflow-x: hidden;
}

.compact-relation-picker-table table,
.compact-relation-picker-table table.dataTable {
  min-width: 0;
  width: 100%;
}

.compact-relation-picker-table th,
.compact-relation-picker-table td {
  font-size: 12px;
  padding: 6px 8px;
}

.compact-relation-picker-table .compact-action {
  width: 94px;
}

.sacabocado-copy-dialog {
  max-width: 520px;
  width: min(520px, calc(100vw - 32px));
}

.sacabocado-copy-form {
  display: grid;
  gap: 14px;
}

.sacabocado-copy-last {
  color: #002a70;
  font-size: 14px;
  font-weight: 700;
}

.sacabocado-copy-grid {
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 34px;
  padding: 18px;
}

.sacabocado-copy-grid label {
  display: grid;
  gap: 5px;
}

.sacabocado-copy-grid span {
  color: #002a70;
  font-size: 12px;
  font-weight: 700;
}

.sacabocado-copy-grid .grid-input {
  max-width: 260px;
}

.form-error {
  background: #fff2f0;
  border: 1px solid #f2b8b5;
  border-radius: 6px;
  color: #9f1d16;
  font-size: 13px;
  margin: 0;
  padding: 8px 10px;
}

.sacabocado-cut-card {
  align-self: start;
  display: grid;
  gap: 12px;
}

.sacabocado-cut-summary {
  display: grid;
  gap: 8px;
  margin: 0;
}

.sacabocado-cut-summary div {
  background: #f8fafc;
  border: 1px solid #dbe4ef;
  border-radius: 7px;
  padding: 8px 10px;
}

.sacabocado-cut-summary dt {
  color: #667085;
  font-size: 11px;
  font-weight: 700;
  margin: 0 0 3px;
  text-transform: uppercase;
}

.sacabocado-cut-summary dd {
  color: #0f172a;
  font-size: 15px;
  font-weight: 800;
  margin: 0;
}

.sacabocado-cut-card .cut-open-button {
  justify-content: center;
  min-height: 38px;
  width: 100%;
}

.sacabocado-technical-state {
  display: none;
}

.cut-dialog {
  background: #ffffff;
  border: 1px solid #cdd8e6;
  border-radius: 12px;
  box-shadow: 0 22px 70px rgb(15 23 42 / 25%);
  max-width: 860px;
  padding: 16px;
  width: min(860px, calc(100vw - 32px));
}

.cut-dialog h2 {
  background: transparent;
  border: 0;
  color: #0f172a;
  font-size: 20px;
  margin: 0 0 14px;
  padding: 0;
}

.cut-editor {
  gap: 14px;
  grid-template-columns: minmax(0, 1fr) 210px;
}

.cut-canvas-panel,
.cut-side-panel fieldset {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: none;
}

.cut-top-controls {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  justify-content: flex-start;
  padding: 8px;
}

.cut-top-controls label,
.cut-side-panel legend {
  color: #002a70;
  font-size: 12px;
}

.cut-sheet-wrap {
  gap: 8px;
  margin: 14px 0;
}

.cut-sheet {
  background: linear-gradient(135deg, #f8fafc, #eef3f9);
  border: 1px solid #9aa9ba;
  border-radius: 6px;
  min-height: 280px;
  overflow: hidden;
}

.cut-cell {
  background: rgb(255 255 255 / 45%);
  border-left-color: #bac7d6;
  border-top-color: #bac7d6;
}

.cut-cell input {
  border-radius: 3px;
  font-size: 11px;
}

.cut-measure {
  color: #475569;
  font-size: 13px;
}

.cut-side-panel fieldset {
  padding: 10px;
}

.cut-line-buttons {
  max-height: 112px;
}

.cut-process {
  color: #263445;
}

@media (max-width: 900px) {
  .sacabocados-filter,
  .sacabocados-form-grid,
  .sacabocado-create-dialog .sacabocado-create-grid,
  .sacabocado-detail-grid,
  .sacabocado-field-grid,
  .sacabocado-field-grid.compact,
  .sacabocado-fox-card,
  .sacabocado-detail-layout,
  .sacabocado-web-grid,
  .sacabocado-class-grid,
  .cut-editor {
    grid-template-columns: 1fr;
  }

  .sacabocado-field-grid .span-2,
  .sacabocado-field-grid .span-4 {
    grid-column: span 1;
  }

  .sacabocado-fox-grid,
  .sacabocado-fox-grid label,
  .sacabocado-fox-grid label.wide-row,
  .sacabocado-fox-grid .pair-field,
  .sacabocado-code-row label,
  .sacabocado-create-dialog .create-relation-field {
    grid-column: auto;
    grid-template-columns: 1fr;
  }

  .cut-top-controls .cut-bocas-label {
    margin-left: 0;
  }

  .sacabocado-web-grid .span-2,
  .sacabocado-web-grid .span-3,
  .sacabocado-create-dialog .field-code,
  .sacabocado-create-dialog .field-date,
  .sacabocado-create-dialog .field-description,
  .sacabocado-create-dialog .field-medidas,
  .sacabocado-create-dialog .field-format,
  .sacabocado-create-dialog .field-select,
  .sacabocado-create-dialog .field-nature,
  .sacabocado-create-dialog .create-relation-field,
  .sacabocado-class-grid .wide,
  .sacabocado-class-grid .type-stack,
  .sacabocado-provider-type-stack,
  .sacabocado-class-card {
    grid-column: auto;
  }

  .sacabocado-class-card {
    grid-row: auto;
  }
}

.split-cell {
  align-items: center;
  display: grid;
  gap: 4px;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
}

.row-actions {
  display: flex;
  gap: 6px;
}

.sustratos-window,
.sustrato-ficha-window {
  display: grid;
  gap: 14px;
}

.sustratos-toolbar,
.sustrato-ficha-toolbar {
  margin-bottom: 0;
}

.sustratos-filter {
  align-items: center;
  display: grid;
  flex: 1;
  gap: 8px;
  grid-template-columns: minmax(260px, 520px) 90px 100px 110px 110px;
  margin: 0;
}

.sustratos-rubros-filter {
  grid-template-columns: minmax(260px, 520px) 130px 110px 110px 110px;
}

.sustratos-rubros-table table {
  table-layout: fixed;
}

.sustratos-rubros-table th:nth-child(1),
.sustratos-rubros-table td:nth-child(1) {
  width: 80px;
}

.sustratos-rubros-table th:nth-child(2),
.sustratos-rubros-table td:nth-child(2) {
  width: 104px;
}

.sustratos-rubros-table th:nth-child(5),
.sustratos-rubros-table td:nth-child(5),
.sustratos-rubros-table th:nth-child(6),
.sustratos-rubros-table td:nth-child(6) {
  width: 62px;
}

.sustratos-rubros-table th:nth-child(7),
.sustratos-rubros-table td:nth-child(7) {
  width: 98px;
}

.sustratos-rubros-table th:nth-child(8),
.sustratos-rubros-table td:nth-child(8),
.sustratos-rubros-table th:nth-child(9),
.sustratos-rubros-table td:nth-child(9) {
  width: 76px;
}

.sustratos-rubros-table th:nth-child(10),
.sustratos-rubros-table td:nth-child(10) {
  width: 82px;
}

.sustratos-rubros-table th:nth-child(11),
.sustratos-rubros-table td:nth-child(11) {
  width: 126px;
}

.sustrato-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: -14px;
}

.sustrato-tabs a,
.sustrato-tabs span {
  border: 1px solid var(--line);
  color: var(--ink);
  font-weight: 700;
  padding: 8px 12px;
  text-align: center;
  text-decoration: none;
}

.sustrato-tabs .active {
  background: #f8fafc;
  border-bottom-color: #f8fafc;
}

.sustrato-fox-panel {
  background: #f8fafc;
  border: 1px solid var(--line);
  display: grid;
  gap: 18px 28px;
  grid-template-columns: 150px 180px 120px 110px 120px 1fr;
  padding: 28px 32px;
}

.sustrato-field {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: 140px minmax(0, 1fr);
}

.sustrato-field label,
.sustrato-field > span,
.sustrato-check span {
  color: #002a70;
  font-weight: 700;
}

.sustrato-field input,
.sustrato-field select {
  width: 100%;
}

.sustrato-code-field {
  grid-column: 1 / 3;
}

.sustrato-check {
  align-items: center;
  display: flex;
  gap: 6px;
  grid-column: 6;
  justify-self: end;
}

.sustrato-group-field {
  grid-column: 1 / 3;
}

.sustrato-ink-field {
  grid-column: 3 / 6;
}

.full-line {
  grid-column: 1 / -1;
}

.small-number {
  grid-column: span 2;
}

.sustrato-type-field {
  grid-column: 1 / 3;
}

.sustrato-unit-field {
  grid-column: 5 / -1;
}

.gram-row {
  grid-column: 1 / -1;
  grid-template-columns: 140px 50px 110px 50px 110px 60px 110px;
}

.sustrato-hidden-fields {
  display: none;
}

.sustrato-hojas-panel {
  border: 1px solid var(--line);
  display: grid;
  gap: 8px;
  overflow-x: auto;
  padding: 14px 16px 16px;
}

.sustrato-hojas-panel > p {
  margin: 2px 0 4px;
}

.sustrato-hp-grids {
  align-items: start;
  display: flex;
  gap: 12px;
  justify-content: center;
}

.sustrato-hp-card {
  display: grid;
  gap: 8px;
  justify-content: start;
}

.sustrato-hp-card:nth-child(1) {
  width: 286px;
}

.sustrato-hp-card:nth-child(2) {
  width: 342px;
}

.sustrato-hp-card:nth-child(3) {
  width: 416px;
}

.sustrato-hp-title {
  align-items: center;
  display: flex;
  gap: 8px;
  min-height: 24px;
}

.sustrato-hp-title h3 {
  color: #002a70;
  font-size: 15px;
  margin: 0;
}

.sustrato-hp-title span {
  color: var(--muted);
  font-size: 12px;
}

.sustrato-fox-grid {
  border: 1px solid var(--line);
  display: grid;
  max-height: 300px;
  overflow-y: auto;
  overflow-x: hidden;
}

.sustrato-fox-grid-hoja {
  grid-template-columns: 96px 96px 92px;
}

.sustrato-fox-grid-pliego {
  grid-template-columns: 76px 86px 86px 92px;
}

.sustrato-fox-grid-costo {
  grid-template-columns: 78px 78px 78px 88px 92px;
}

.fox-grid-head {
  background: #eaf0f4;
  border-bottom: 1px solid var(--line);
  color: #0b274d;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 7px;
  text-transform: uppercase;
}

.sustrato-grid-row {
  display: contents;
}

.sustrato-grid-row > input,
.sustrato-grid-row > form,
.sustrato-grid-row > span {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  min-height: 34px;
  padding: 3px 5px;
}

.sustrato-grid-row input {
  min-height: 26px;
  padding: 3px 5px;
}

.sustrato-grid-row form {
  margin: 0;
}

.fox-grid-action {
  justify-content: center;
}

.blank-grid-row input:disabled {
  background: #fff;
  border-color: #d6dee8;
  opacity: 1;
}

.sustrato-grid-add {
  align-items: center;
  display: grid;
  gap: 5px;
  grid-template-columns: 96px 96px 82px;
  margin: 0;
}

.sustrato-grid-add-pliego {
  grid-template-columns: 76px 86px 86px 92px;
}

.sustrato-grid-add-costo {
  grid-template-columns: 78px 78px 78px 88px 92px;
}

.sustrato-grid-add-costo .client-tool {
  justify-content: center;
}

.sustrato-grid-add input {
  min-height: 30px;
  padding: 4px 6px;
}

.mini-action {
  min-height: 26px;
  padding: 4px 8px;
  white-space: nowrap;
}

input,
select,
textarea {
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  font: inherit;
  min-height: 36px;
  padding: 7px 9px;
  width: 100%;
}

textarea {
  min-height: 120px;
  resize: vertical;
}

input[type="checkbox"] {
  min-height: auto;
  width: auto;
}

button,
.button {
  background: var(--accent);
  border: 0;
  border-radius: 6px;
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  min-height: 36px;
  padding: 8px 14px;
}

button:hover,
.button:hover {
  background: var(--accent-dark);
  text-decoration: none;
}

button:disabled,
button:disabled:hover,
.button.disabled-link {
  background: #eef2f5;
  border-color: var(--line);
  color: #7b8796;
  cursor: not-allowed;
  opacity: 0.72;
}

.danger-button {
  background: #b5473f;
  min-height: 30px;
  padding: 5px 9px;
}

.danger-button:hover {
  background: #8f342e;
}

.danger-button:disabled,
.danger-button:disabled:hover {
  background: #f2d8d5;
  color: #8f504a;
  cursor: not-allowed;
}

.confirm-ok-button {
  background: #1f7a67;
  border-color: #176757;
  color: #ffffff;
  min-height: 30px;
  padding: 5px 9px;
}

.confirm-ok-button:hover {
  background: #176757;
}

.confirm-ok-button:disabled,
.confirm-ok-button:disabled:hover {
  background: #b7d7cf;
  border-color: #a0c9bf;
  color: #f8fafc;
  cursor: not-allowed;
}

.compact-action {
  min-height: 30px;
  padding: 5px 9px;
}

.inline-action-form {
  margin: 0;
}

.notice {
  background: #e4f7e9;
  border: 1px solid #a9d8b6;
  border-radius: 6px;
  color: #245b36;
  margin: 0 0 14px;
  padding: 10px 12px;
}

.notice.warning {
  background: #fff4d8;
  border-color: #e2c36f;
  color: #6a4b12;
}

.notice.error {
  background: #f7e6e2;
  border-color: #d8aaa3;
  color: #7a2e27;
}

.notice.danger {
  background: #f7e6e2;
  border-color: #d8aaa3;
  color: #7a2e27;
}

.danger-notice {
  background: #f7e6e2;
  border-color: #d8aaa3;
  color: #7a2e27;
}

.message-stack {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.toast-stack {
  align-items: end;
  bottom: auto;
  gap: 10px;
  margin: 0;
  max-width: min(420px, calc(100vw - 28px));
  position: fixed;
  right: 18px;
  top: 72px;
  width: max-content;
  z-index: 120;
}

.toast-message {
  align-items: center;
  box-shadow: 0 16px 42px rgb(15 23 42 / 18%);
  display: grid;
  gap: 10px;
  grid-template-columns: 28px minmax(0, 1fr) 26px;
  margin: 0;
  min-height: 58px;
  min-width: min(360px, calc(100vw - 28px));
  opacity: 1;
  overflow: hidden;
  position: relative;
  transform: translateY(0);
  transition: opacity 180ms ease, transform 180ms ease;
}

.toast-message.is-hiding {
  opacity: 0;
  transform: translateY(-8px);
}

.toast-message.custom-success,
.toast-message.success {
  background: #3fbf66;
  border-color: #33a958;
  color: #ffffff;
}

.toast-message.custom-error,
.toast-message.error {
  background: #b5473f;
  border-color: #9f342e;
  color: #ffffff;
}

.toast-message.warning {
  background: #f0b429;
  border-color: #d99a16;
  color: #2b1b00;
}

.toast-icon {
  align-items: center;
  border: 2px solid currentColor;
  border-radius: 999px;
  display: inline-flex;
  font-size: 17px;
  font-weight: 900;
  height: 28px;
  justify-content: center;
  width: 28px;
}

.toast-close {
  align-items: center;
  background: transparent;
  border: 0;
  color: currentColor;
  cursor: pointer;
  display: inline-flex;
  font-size: 20px;
  height: 26px;
  justify-content: center;
  line-height: 1;
  opacity: 0.78;
  padding: 0;
  width: 26px;
}

.toast-close:hover {
  opacity: 1;
}

.toast-text {
  min-width: 0;
}

.toast-progress {
  background: rgb(255 255 255 / 55%);
  bottom: 0;
  height: 4px;
  left: 0;
  position: absolute;
  transition: none !important;
  width: 100%;
}

.toast-message.is-paused .toast-progress {
  background: rgb(255 255 255 / 72%);
}

.toast-message.is-paused {
  box-shadow: 0 18px 48px rgb(15 23 42 / 24%);
}



.confirm-dialog {
  border: 1px solid #d3dbe6;
  border-radius: 14px;
  box-shadow: 0 24px 80px rgb(15 23 42 / 28%);
  max-width: 440px;
  padding: 24px;
  text-align: center;
  width: min(440px, calc(100vw - 32px));
}

.confirm-dialog::backdrop {
  background: rgb(15 23 42 / 48%);
}

.confirm-dialog-icon {
  align-items: center;
  border: 5px solid #f0d7d4;
  border-radius: 999px;
  color: #b5473f;
  display: inline-flex;
  font-size: 30px;
  font-weight: 900;
  height: 86px;
  justify-content: center;
  margin-bottom: 12px;
  width: 86px;
}

.confirm-dialog h2 {
  color: #263445;
  font-size: 22px;
  margin: 0 0 10px;
}

.confirm-dialog p {
  color: #405168;
  font-size: 15px;
  margin: 0 0 22px;
}

.confirm-dialog .form-actions {
  justify-content: center;
}

.status-strip {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 14px;
  justify-content: space-between;
  margin: 0 0 14px;
  padding: 10px 12px;
}

.status-strip > div {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.status-strip span {
  color: #384253;
  font-size: 13px;
}

.status-badge {
  border-radius: 4px;
  font-weight: 700;
  padding: 4px 8px;
}

.status-badge.open {
  background: #e4f7e9;
  color: #245b36;
}

.status-badge.closed {
  background: #eef2f5;
  color: #384253;
}

.status-warning {
  background: #fff4d8;
  border-radius: 4px;
  color: #6a4b12;
  padding: 4px 8px;
}

.table-wrap,
.detail-grid > div,
.notes,
.form-grid {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.table-wrap {
  overflow-x: auto;
}

.dense-table {
  scrollbar-gutter: stable;
}

.dense-table table {
  min-width: 1180px;
}

.dense-table th,
.dense-table td {
  padding: 7px 8px;
}

.dense-table th {
  font-size: 11px;
}

.dense-table .grid-input {
  min-height: 30px;
  padding: 4px 6px;
}

.dense-table .date-input {
  max-width: 122px;
}

.dense-table .number-input {
  max-width: 72px;
}

.dense-table .code-input,
.dense-table .tiny-input {
  max-width: 54px;
}

.dense-table .text-input {
  min-width: 150px;
}

.dense-table .row-actions {
  flex-wrap: nowrap;
  gap: 4px;
}

.dense-table .compact-action {
  font-size: 12px;
  min-height: 28px;
  padding: 4px 7px;
}

.dense-table small {
  display: block;
  font-size: 11px;
  line-height: 1.25;
  margin-top: 2px;
}

.production-deliveries-table table {
  min-width: 1420px;
}

.production-deliveries-table .date-input {
  max-width: 116px;
}

.production-deliveries-table .text-input {
  min-width: 150px;
}

.production-deliveries-table .actions-cell {
  min-width: 126px;
  white-space: nowrap;
}

.production-deliveries-table .actions-cell .row-actions {
  align-items: center;
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(2, minmax(54px, 1fr));
}

.production-deliveries-table .actions-cell .compact-action {
  justify-content: center;
  min-width: 54px;
}

.production-remitos-table table {
  min-width: 1240px;
}

.production-remitos-table td span {
  display: block;
}

.production-sustratos-table table {
  min-width: 1420px;
}

.production-sustratos-stock-table table {
  min-width: 1120px;
}

.sustratos-filters {
  grid-template-columns: minmax(260px, 1fr) repeat(7, minmax(96px, 130px)) minmax(110px, auto) minmax(130px, auto);
  max-width: none;
}

.secondary-button {
  background: #eef2f6;
  border: 1px solid var(--line);
  color: var(--text);
}

.secondary-button:hover {
  background: #e2e8f0;
}

.section-heading-row {
  align-items: center;
  display: flex;
  gap: 16px;
  justify-content: space-between;
  margin-bottom: 12px;
}

.section-heading-row h2,
.section-heading-row p {
  margin: 0;
}

.section-heading-row p {
  color: var(--muted);
  font-size: 13px;
}

.check-line {
  align-items: center;
  color: var(--muted);
  display: inline-flex;
  gap: 7px;
  white-space: nowrap;
}

.row-checkbox {
  accent-color: var(--accent);
  height: 16px;
  width: 16px;
}

.action-toolbar {
  justify-content: flex-start;
}

.pagination-bar {
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--muted);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin: 12px 0 16px;
  padding: 10px 12px;
}

.pagination-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.page-status {
  color: var(--text);
  font-weight: 700;
  padding: 0 4px;
}

.disabled-link {
  cursor: default;
  opacity: 0.48;
  pointer-events: none;
}

.production-subordenes-table table {
  min-width: 1500px;
}

.production-costs-table table {
  min-width: 1360px;
}

.production-finished-table table {
  min-width: 1420px;
}

.production-labels-table table {
  min-width: 1420px;
}

.production-labels-table .actions-cell {
  min-width: 82px;
}

.production-planillas-table table {
  min-width: 1320px;
}

.production-parts-table table {
  min-width: 1480px;
}

.production-inputs-table table {
  min-width: 1320px;
}

.production-shift-table table {
  min-width: 1380px;
}

.production-controller-table table {
  min-width: 1580px;
}

.production-controller-table .text-input {
  min-width: 155px;
}

.production-order-advanced-table table {
  min-width: 3050px;
}

.production-order-advanced-table {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 24px;
  scrollbar-width: thin;
}

.production-order-advanced-table table {
  margin-bottom: 18px;
}

.production-order-advanced-table::-webkit-scrollbar {
  height: 10px;
}

.production-order-advanced-table::-webkit-scrollbar-thumb {
  background: #9aa6b2;
  border-radius: 999px;
}

.production-order-advanced-table td {
  height: 38px;
  white-space: nowrap;
}

.production-order-advanced-table .ot-inline-cell {
  align-items: center;
  display: inline-grid;
  gap: 4px;
  grid-auto-flow: column;
  white-space: nowrap;
}

.production-order-advanced-table .text-input {
  min-width: 128px;
}

.split-tables .dense-table table {
  min-width: 1360px;
}

.production-catalog-table table {
  min-width: 920px;
}

.production-services-table table {
  min-width: 1460px;
}

.production-services-table .text-input {
  min-width: 180px;
}

.production-auto-inputs-table table {
  min-width: 1260px;
}

.maestros-catalog-table table {
  min-width: 1180px;
}

.maestros-catalog-table .text-input {
  min-width: 170px;
}

.budget-seller-notes-table table {
  min-width: 1460px;
}

.production-order-notes-table table {
  min-width: 1560px;
}

.production-order-notes-table .text-input {
  min-width: 160px;
}

.np-fox-window {
  background: #eef2f6;
  border: 1px solid #b6c2cf;
  border-radius: 8px;
  box-shadow: 0 10px 26px rgb(15 23 42 / 10%);
  display: grid;
  gap: 8px;
  margin: 0 auto 12px;
  max-width: 1180px;
  padding: 10px;
}

.np-titlebar {
  align-items: center;
  display: flex;
  gap: 16px;
  justify-content: space-between;
}

.np-titlebar h1 {
  color: #173a7a;
  font-size: 20px;
}

.np-titlebar p {
  color: var(--muted);
  font-size: 12px;
}

.np-titlebar strong {
  color: #d01f1f;
  font-size: 13px;
  font-style: italic;
}

.np-command-row {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.np-command-row code {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: block;
  max-width: 100%;
  overflow-x: auto;
  padding: 8px 10px;
  white-space: nowrap;
}

.np-tool {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #aebbc9;
  border-radius: 4px;
  box-shadow: inset 0 1px 0 #fff;
  color: #123786;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  justify-content: center;
  min-height: 32px;
  min-width: 38px;
  padding: 5px 8px;
}

.np-tool:hover {
  background: #e8f0f7;
  text-decoration: none;
}

.np-tool:disabled,
.np-tool-muted {
  color: #7b8797;
  opacity: 0.72;
}

.np-header-grid {
  align-items: end;
  border: 1px solid #c4cfda;
  border-radius: 6px;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(190px, 1.2fr) repeat(5, minmax(96px, 0.7fr)) auto;
  padding: 10px;
}

.np-header-grid label {
  display: grid;
  gap: 3px;
}

.np-header-grid span,
.np-observation-row span {
  color: #143585;
  font-size: 13px;
  font-weight: 800;
}

.np-header-grid input,
.np-header-grid select,
.np-summary-strip input,
.np-items-table .grid-input {
  border-color: #b7c5d5;
  border-radius: 4px;
  min-height: 29px;
  padding: 4px 6px;
}

.np-header-grid button,
.np-approval-actions button,
.np-footer-actions button {
  min-height: 29px;
  padding: 4px 10px;
}

.np-summary-strip {
  align-items: center;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr auto;
}

.np-summary-strip dl {
  background: #f8fafc;
  border: 1px solid #c4cfda;
  border-radius: 6px;
  display: grid;
  gap: 4px 8px;
  grid-template-columns: repeat(6, auto);
  margin: 0;
  padding: 8px 10px;
}

.np-summary-strip dt {
  color: #143585;
  font-size: 12px;
  font-weight: 800;
}

.np-summary-strip dd {
  color: var(--text);
  font-size: 12px;
  margin: 0 8px 0 0;
}

.np-approval-actions,
.np-footer-actions {
  display: flex;
  gap: 6px;
}

.np-items-table {
  margin-top: 0;
  max-height: 340px;
  overflow: auto;
}

.np-items-table table {
  min-width: 1680px;
}

.np-items-table th {
  background: #dbe7f3;
  color: #143585;
  font-size: 12px;
}

.np-items-table td {
  height: 31px;
  padding: 4px 5px;
  vertical-align: middle;
}

.np-items-table small {
  color: var(--muted);
  display: block;
  font-size: 11px;
  line-height: 1.1;
}

.np-items-table .text-input {
  min-width: 170px;
}

.np-format-cell {
  display: grid;
  gap: 4px;
  grid-template-columns: repeat(2, 78px);
}

.np-reference-strip {
  background: #f8fafc;
  border: 1px solid #c4cfda;
  border-radius: 6px;
  color: #273449;
  display: grid;
  font-size: 12px;
  gap: 5px 22px;
  grid-template-columns: 90px repeat(3, minmax(150px, 1fr));
  padding: 7px 10px;
}

.np-reference-strip strong {
  color: #143585;
}

.np-observation-row {
  align-items: end;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr auto;
}

.np-observation-row label {
  display: grid;
  gap: 4px;
}

.np-observation-row textarea {
  border-color: #b7c5d5;
  border-radius: 4px;
  min-height: 50px;
  resize: vertical;
}

.np-source-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  bottom: 14px;
  box-shadow: 0 12px 34px rgb(15 23 42 / 12%);
  color: #384253;
  font-size: 12px;
  left: 14px;
  max-width: 340px;
  padding: 10px 12px;
  position: fixed;
  z-index: 20;
}

.np-pending-card {
  bottom: auto;
  left: auto;
  right: 14px;
  top: 66px;
}

.np-source-card h2 {
  color: var(--text);
  font-size: 13px;
  margin: 0 0 6px;
}

.np-source-list {
  display: grid;
  gap: 5px;
  margin: 0;
  padding: 0;
}

.np-source-list li {
  list-style: none;
}

.np-source-table {
  color: var(--text);
  font-weight: 800;
}

.np-pending-tag {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  color: #9a3412;
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  margin-left: 5px;
  padding: 3px 6px;
}

.np-detail-title {
  align-items: end;
  margin-bottom: 10px;
}

.np-title-number {
  font-weight: 700;
  white-space: nowrap;
}

.np-autosave-note {
  color: #4b5870;
  font-size: 12px;
  margin: 0;
}

.np-detail-notice {
  justify-self: start;
  margin: 0;
  max-width: none;
}

.np-notice-list {
  display: grid;
  gap: 3px;
  margin: 6px 0 0;
  padding-left: 18px;
}

.np-notice-list li {
  color: #612015;
  font-size: 12px;
}

.np-notice-list a {
  color: #0f766e;
  font-weight: 800;
  margin-left: 4px;
}

.np-detail-window {
  display: grid;
  gap: 14px;
  margin: 0 auto 16px;
  max-width: 1240px;
}

.np-detail-toolbar {
  margin-bottom: 0;
}

.np-detail-toolbar .button,
.np-detail-toolbar .danger-button {
  background: #eef2f5;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #384253;
  font-size: 13px;
  font-weight: 700;
  min-height: 32px;
  padding: 6px 10px;
}

.np-detail-toolbar .button:hover,
.np-detail-toolbar .danger-button:hover {
  background: #f4f7f9;
  color: #384253;
}

.np-detail-toolbar .button:disabled,
.np-detail-toolbar .danger-button:disabled {
  background: #f6f8fa;
  color: #728094;
  cursor: not-allowed;
}

.np-detail-status-row {
  background: transparent;
  border: 0;
  gap: 6px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 0;
  padding: 0;
}

.np-detail-status-row > div {
  display: block;
  min-height: 42px;
  padding: 6px 8px;
}

.np-detail-status-row strong {
  color: var(--text);
  font-size: 12px;
}

.np-detail-status-row span {
  color: #56657a;
  font-size: 11px;
  margin-bottom: 1px;
}

.np-detail-window .client-tabs {
  gap: 12px;
}

.np-detail-window .client-tab-labels {
  display: none;
}

.np-detail-window .client-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 8px;
  padding: 10px;
}

.np-detail-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
  margin: 0 auto 12px;
  max-width: 1280px;
}

.np-tab-button {
  background: #eef2f5;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #384253;
  cursor: pointer;
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  min-height: 34px;
  padding: 8px 12px;
}

.np-tab-button.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.np-tab-button:disabled {
  cursor: not-allowed;
}

.ot-quick-summary {
  align-items: stretch;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin: 0 auto 12px;
  max-width: 1280px;
}

.ot-quick-summary div {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 3px 8px;
  padding: 8px 10px;
}

.ot-quick-summary span {
  color: var(--muted);
  display: block;
  font-size: 12px;
  font-weight: 700;
  grid-column: 1 / -1;
}

.ot-quick-summary strong {
  color: var(--text);
  font-size: 16px;
}

.ot-quick-summary em {
  align-self: end;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.ot-quick-summary i {
  background: #e6edf5;
  border-radius: 999px;
  display: block;
  grid-column: 1 / -1;
  height: 4px;
  overflow: hidden;
}

.ot-quick-summary i::after {
  background: var(--accent);
  content: "";
  display: block;
  height: 100%;
  width: var(--pct, 0%);
}

.ot-quick-summary p {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  grid-column: 1 / -1;
  margin: 0;
}

.ot-quick-summary p span {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  color: #9a3412;
  padding: 4px 8px;
}

.np-detail-warning {
  color: #c53127;
  font-size: 13px;
  font-style: italic;
  font-weight: 700;
  justify-self: end;
}

.np-detail-top-grid {
  align-items: end;
  display: grid;
  gap: 6px 8px;
  grid-template-columns: 82px 92px 170px 118px 118px 118px;
}

.np-detail-top-grid label,
.np-detail-client-row label,
.np-detail-fields-grid label,
.np-detail-observation-row label {
  display: grid;
  gap: 3px;
}

.np-detail-top-grid span,
.np-detail-client-row span,
.np-detail-fields-grid span,
.np-detail-observation-row span {
  color: #173a7a;
  font-size: 12px;
  font-weight: 800;
}

.np-detail-client-row {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 8px;
  grid-template-columns: 125px 1fr;
  padding: 6px;
}

.np-detail-client-row strong {
  color: #173a7a;
  display: block;
  font-size: 15px;
}

.np-detail-client-row div > span {
  color: #4b5870;
  display: block;
  font-size: 12px;
  font-weight: 600;
}

.np-detail-authorize {
  display: flex;
  gap: 6px;
}

.np-detail-authorize button,
.np-detail-side-actions .button {
  min-height: 32px;
  padding: 6px 10px;
}

.np-detail-authorize button:disabled,
.np-detail-side-actions button:disabled,
.np-detail-side-actions .button[disabled],
.np-detail-window button:disabled {
  background: #eef2f5;
  border: 1px solid var(--line);
  color: #728094;
  cursor: not-allowed;
  opacity: 1;
}

.np-detail-authorize button:disabled:hover,
.np-detail-side-actions button:disabled:hover,
.np-detail-side-actions .button[disabled]:hover,
.np-detail-window button:disabled:hover {
  background: #eef2f5;
  color: #728094;
}

.np-detail-fields-grid {
  align-items: end;
  display: grid;
  gap: 6px 8px;
  grid-template-columns: 170px 120px 1fr 210px;
}

.np-detail-fields-grid .wide {
  grid-column: span 2;
}

.np-check-line {
  align-items: center;
  display: flex !important;
  gap: 8px;
}

.np-detail-window .grid-input,
.np-detail-extra-grid .grid-input {
  border-color: #b7c5d5;
  border-radius: 5px;
  font-size: 12px;
  min-height: 26px;
  padding: 4px 6px;
}

.np-detail-items-table {
  margin-top: 0;
  max-height: 210px;
  overflow: auto;
  padding-bottom: 12px;
  scrollbar-gutter: stable;
}

.np-detail-items-table table {
  border-collapse: separate;
  border-spacing: 0;
  min-width: 1210px;
}

.np-detail-items-table th {
  background: #e8eef4;
  color: #173a7a;
  font-size: 11px;
  white-space: nowrap;
}

.np-detail-items-table td {
  background: #ffffff;
  font-size: 12px;
  height: 30px;
  padding: 4px 5px;
  vertical-align: middle;
}

.np-detail-items-table::-webkit-scrollbar {
  height: 14px;
}

.np-detail-items-table th:nth-child(1),
.np-detail-items-table td:nth-child(1),
.np-detail-items-table th:nth-child(2),
.np-detail-items-table td:nth-child(2),
.np-detail-items-table th:nth-child(3),
.np-detail-items-table td:nth-child(3) {
  position: sticky;
  z-index: 2;
}

.np-detail-items-table th:nth-child(1),
.np-detail-items-table td:nth-child(1) {
  left: 0;
  min-width: 86px;
}

.np-detail-items-table th:nth-child(2),
.np-detail-items-table td:nth-child(2) {
  left: 86px;
  min-width: 110px;
}

.np-detail-items-table th:nth-child(3),
.np-detail-items-table td:nth-child(3) {
  left: 196px;
  min-width: 220px;
}

.np-detail-items-table th:nth-child(1),
.np-detail-items-table th:nth-child(2),
.np-detail-items-table th:nth-child(3) {
  z-index: 4;
}

.np-detail-items-table td:nth-child(1),
.np-detail-items-table td:nth-child(2),
.np-detail-items-table td:nth-child(3) {
  box-shadow: 1px 0 0 var(--line);
}

.np-detail-items-table .text-input {
  min-width: 170px;
}

.np-detail-items-table .date-input {
  min-width: 116px;
}

.np-detail-items-table .number-input {
  min-width: 92px;
}

.np-detail-items-table .tiny-input {
  min-width: 72px;
}

.np-detail-items-table .code-input {
  min-width: 110px;
}

.np-detail-items-table input[type="checkbox"] {
  display: block;
  margin: 0 auto;
}

.np-item-toolbar {
  align-items: end;
  display: flex;
  gap: 5px;
  justify-content: flex-end;
}

.np-item-toolbar button {
  background: #eef3f7;
  border: 1px solid #b8c6d6;
  border-radius: 5px;
  color: #52647a;
  font-size: 12px;
  min-height: 28px;
  padding: 4px 8px;
}

.np-detail-reference-strip {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #273449;
  display: grid;
  font-size: 11px;
  gap: 4px 18px;
  grid-template-columns: 90px repeat(3, minmax(160px, 1fr));
  padding: 6px 8px;
}

.np-detail-reference-strip strong {
  color: #173a7a;
}

.np-detail-observation-row {
  align-items: end;
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr auto;
}

.np-detail-observation-row textarea {
  min-height: 48px;
  resize: vertical;
}

.np-detail-side-actions {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(2, auto);
}

.np-detail-side-actions form {
  display: contents;
}

.np-detail-extra-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) 220px;
  margin: 0;
  max-width: none;
}

.np-detail-extra-grid > .notes,
.notes {
  border-radius: 8px;
}

.np-detail-pliegos {
  margin-left: auto;
  margin-right: auto;
  max-width: 1280px;
}

.np-action-status {
  margin: 0 auto 16px;
  max-width: 1280px;
}

.np-action-status ul {
  display: grid;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.ot-detail-toolbar,
.ot-detail-tabs,
.ot-detail-window {
  max-width: none;
  width: 100%;
}

.ot-detail-tabs {
  justify-content: flex-start;
}

.ot-detail-tabs a {
  text-decoration: none;
}

.ot-detail-window {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 12px;
  margin: 0 auto 16px;
  padding: 16px;
}

.ot-detail-window label {
  display: grid;
  gap: 3px;
}

.ot-detail-window label > span,
.ot-panel-title {
  color: #173a7a;
  font-size: 14px;
  font-weight: 800;
}

.ot-detail-window small {
  color: #526071;
  font-weight: 700;
}

.ot-detail-window .grid-input,
.ot-link-field {
  border-color: #b7c5d5;
  border-radius: 5px;
  font-size: 14px;
  min-height: 36px;
  padding: 7px 9px;
}

.ot-link-field {
  align-items: center;
  background: #fff;
  border: 1px solid #b7c5d5;
  color: var(--accent);
  display: inline-flex;
  font-weight: 800;
}

.ot-top-grid {
  align-items: end;
  display: grid;
  gap: 10px;
  grid-template-columns: 100px 140px 150px 180px minmax(220px, 1fr) 80px 135px 135px;
}

.ot-reference-grid {
  align-items: end;
  display: grid;
  gap: 10px;
  grid-template-columns: 190px 150px 180px 150px minmax(320px, 1fr);
}

.ot-reference-grid .wide {
  min-width: 0;
}

.ot-inline-fields {
  display: grid;
  gap: 4px;
  grid-template-columns: 1fr 46px;
}

.ot-check {
  align-items: center;
  display: flex !important;
  gap: 7px;
  min-height: 36px;
}

.ot-check span {
  color: #384253;
  font-size: 13px;
  font-weight: 800;
}

.ot-text-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.ot-text-grid textarea {
  line-height: 1.35;
  min-height: 190px;
  resize: vertical;
}

.ot-delivery-grid {
  align-items: end;
  display: grid;
  gap: 10px;
  grid-template-areas:
    "aviso direccion contacto"
    "aviso lugar flete"
    "motivo motivo motivo";
  grid-template-columns: minmax(0, 1.15fr) minmax(220px, 1fr) minmax(170px, 0.7fr);
}

.ot-delivery-grid .wide-left {
  grid-area: aviso;
}

.ot-delivery-grid .delivery-address {
  grid-area: direccion;
}

.ot-delivery-grid .delivery-contact {
  grid-area: contacto;
}

.ot-delivery-grid .delivery-place {
  grid-area: lugar;
}

.ot-delivery-grid .delivery-freight {
  grid-area: flete;
}

.ot-delivery-grid .delivery-deviation {
  grid-area: motivo;
}

.ot-delivery-grid textarea {
  min-height: 94px;
  resize: vertical;
}

.ot-bottom-grid {
  align-items: start;
  display: grid;
  gap: 10px 12px;
  grid-template-areas: "side close tasks process end";
  grid-template-columns: 160px 165px 165px minmax(280px, 1fr) 180px;
}

.ot-side-actions,
.ot-close-panel,
.ot-task-panel,
.ot-process-panel,
.ot-end-actions {
  display: grid;
  gap: 8px;
}

.ot-side-actions {
  grid-area: side;
}

.ot-close-panel {
  grid-area: close;
}

.ot-task-panel {
  grid-area: tasks;
}

.ot-process-panel {
  align-content: start;
  grid-area: process;
}

.ot-end-actions {
  grid-area: end;
}

.ot-panel-title {
  min-height: 18px;
}

.ot-close-mini {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 2px;
  padding: 6px 8px;
}

.ot-close-mini strong {
  color: var(--text);
  font-size: 12px;
  line-height: 1.15;
}

.ot-close-mini span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.15;
}

.cierre-productivo-grid .grid-input[readonly] {
  background: #f8fafc;
}

.ot-side-actions .button,
.ot-close-panel .button,
.ot-task-panel .button,
.ot-end-actions .button,
.ot-end-actions .danger-button {
  min-height: 36px;
}

.ot-process-checks {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(6, 1fr);
  max-width: 540px;
}

.ot-process-checks label {
  align-items: center;
  display: grid;
  justify-items: center;
}

.ot-process-mini {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ot-process-mini span {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  padding: 5px 7px;
}

.ot-process-mini strong {
  color: var(--accent);
  float: right;
}

.ot-process-action {
  justify-self: start;
  min-height: 28px;
  padding: 4px 8px;
  width: auto;
}

.ot-related-strip {
  border-top: 1px solid var(--line);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 14px;
  padding-top: 10px;
}

.ot-related-strip a {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  min-width: 96px;
  padding: 7px 10px;
  text-decoration: none;
}

.ot-related-strip span {
  color: var(--muted);
  display: block;
  font-size: 12px;
}

.ot-related-strip strong {
  color: var(--text);
  display: block;
  font-size: 14px;
}

.ot-copy-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 12px 0;
}

.ot-copy-grid div {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
}

.ot-copy-grid span {
  color: var(--muted);
  display: block;
  font-size: 12px;
}

.ot-copy-grid strong {
  color: var(--text);
  display: block;
  font-size: 14px;
}

.ot-release-checks {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 8px;
  margin-top: 12px;
  padding: 10px;
}

.ot-release-checks ul {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.ot-release-checks li {
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  padding: 5px 9px;
}

.ot-release-checks li.ok {
  background: #e4f5ee;
  color: #11614f;
}

.ot-release-checks li.pending {
  background: #fff7ed;
  color: #9a3412;
}

.ot-process-summary {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 10px 0 12px;
}

.ot-process-summary div {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 3px 8px;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 8px 10px;
}

.ot-process-summary span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  grid-column: 1 / -1;
}

.ot-process-summary strong {
  color: var(--text);
  font-size: 16px;
}

.ot-process-summary em {
  align-self: end;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.ot-process-summary i {
  background: #e6edf5;
  border-radius: 999px;
  display: block;
  grid-column: 1 / -1;
  height: 4px;
  overflow: hidden;
}

.ot-process-summary i::after {
  background: var(--accent);
  content: "";
  display: block;
  height: 100%;
  width: var(--pct, 0%);
}

.ot-delivery-summary {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin: 10px 0 12px;
}

.ot-delivery-summary div {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 3px 8px;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 8px 10px;
}

.ot-delivery-summary span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  grid-column: 1 / -1;
}

.ot-delivery-summary strong {
  color: var(--text);
  font-size: 16px;
}

.ot-delivery-summary em {
  align-self: end;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.ot-delivery-summary i {
  background: #e6edf5;
  border-radius: 999px;
  display: block;
  grid-column: 1 / -1;
  height: 4px;
  overflow: hidden;
}

.ot-delivery-summary i::after {
  background: var(--accent);
  content: "";
  display: block;
  height: 100%;
  width: var(--pct, 0%);
}

.ot-delivery-state {
  border-radius: 999px;
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  padding: 4px 7px;
}

.ot-delivery-state.ok {
  background: #e4f5ee;
  color: #11614f;
}

.ot-delivery-state.open {
  background: #eef2f5;
  color: #384253;
}

.ot-delivery-state.pending {
  background: #fff7ed;
  color: #9a3412;
}

.ot-logistics-strip {
  align-items: center;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 10px;
  padding: 8px 10px;
}

.ot-logistics-strip span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.ot-logistics-strip strong {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: #384253;
  font-size: 12px;
  padding: 4px 8px;
}

.ot-logistics-strip .warning {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a3412;
}

.ot-preclose-summary {
  align-items: center;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin: 10px 0;
  padding: 10px 12px;
}

.ot-preclose-summary strong {
  color: var(--text);
  font-size: 16px;
}

.ot-preclose-summary span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.ot-preclose-summary.listo {
  background: #e4f5ee;
  border-color: #b7e2d4;
}

.ot-preclose-summary.revisar {
  background: #fff7ed;
  border-color: #fed7aa;
}

.ot-preclose-summary.bloqueado {
  background: #fee2e2;
  border-color: #fecaca;
}

.ot-preclose-summary.loading {
  background: #eef4ff;
  border-color: #bfdbfe;
}

.ot-preclose-list li.block strong {
  color: #991b1b;
}

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

.ot-preclose-list li {
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 3px;
  padding: 8px 10px;
}

.ot-preclose-list strong {
  color: var(--text);
  font-size: 13px;
}

.ot-preclose-list span {
  color: var(--muted);
  font-size: 12px;
}

.ot-preclose-list .ok {
  background: #e4f5ee;
}

.ot-preclose-list .warn {
  background: #fff7ed;
}

.ot-preclose-list .block {
  background: #fee2e2;
}

.ot-coverage-summary {
  align-items: center;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin: 10px 0;
  padding: 10px 12px;
}

.ot-coverage-summary strong {
  color: var(--accent);
  font-size: 22px;
}

.ot-coverage-summary span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.ot-coverage-sections {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 10px 0 12px;
}

.ot-coverage-sections section {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
}

.ot-coverage-sections h3,
.ot-coverage-subtitle {
  color: var(--text);
  font-size: 13px;
  margin: 0 0 7px;
}

.ot-coverage-sections ul {
  display: grid;
  gap: 5px;
  margin: 0;
  padding-left: 18px;
}

.ot-coverage-sections li {
  color: #384253;
  font-size: 12px;
  line-height: 1.35;
}

.ot-coverage-subtitle {
  margin-top: 4px;
}

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

.ot-coverage-list li {
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 4px;
  padding: 8px 10px;
}

.ot-coverage-list strong {
  color: var(--text);
  font-size: 13px;
}

.ot-coverage-list span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.ot-coverage-list .ok {
  background: #e4f5ee;
}

.ot-coverage-list .warn {
  background: #fff7ed;
}

.ot-coverage-list .block {
  background: #fee2e2;
}

.ot-subnav {
  align-items: center;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 auto 16px;
  padding: 8px 10px;
}

.ot-subnav span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  margin-right: 2px;
  text-transform: uppercase;
}

.ot-subnav a {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #173a7a;
  font-size: 13px;
  font-weight: 800;
  padding: 6px 9px;
  text-decoration: none;
}

.ot-subnav a:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.ot-subnav a.is-active {
  background: #e4f5ee;
  border-color: var(--accent);
  color: var(--accent);
}

.ot-pliegos-section {
  display: grid;
  gap: 12px;
  margin: 0 auto 16px;
  max-width: 1024px;
}

.ot-pliegos-head {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
}

.ot-pliegos-head h2,
.ot-pliego-card h3,
.ot-pliego-data-grid h4 {
  margin: 0;
}

.ot-pliegos-head p,
.ot-pliego-card-head p,
.ot-pliego-note {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
  margin: 3px 0 0;
}

.ot-pliegos-section .button {
  background: #334155;
}

.ot-pliegos-section .button:hover {
  background: #1f2937;
}

.ot-pliegos-summary {
  display: grid;
  gap: 8px;
  grid-template-columns: 100px 88px 128px 88px minmax(0, 1fr);
}

.ot-pliegos-summary div,
.ot-pliegos-empty,
.ot-pliego-card,
.ot-pliegos-doc-card {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 1px 0 rgb(15 23 42 / 3%);
}

.ot-pliegos-summary div {
  display: grid;
  gap: 3px;
  min-height: 58px;
  padding: 9px 10px;
}

.ot-pliegos-summary span,
.ot-pliegos-doc-card span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.ot-pliegos-summary strong {
  color: var(--text);
  font-size: 17px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

.ot-pliego-card {
  display: grid;
  gap: 10px;
  padding: 12px;
}

.ot-pliego-card-head {
  align-items: start;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
}

.ot-pliego-card-head h3 {
  color: var(--text);
  font-size: 17px;
}

.ot-pliego-card-actions {
  align-items: center;
  display: flex;
  gap: 6px;
}

.ot-pliego-card-actions .compact-action {
  align-items: center;
  justify-content: center;
  min-height: 30px;
  white-space: nowrap;
}

.ot-pliego-edit-grid {
  align-items: end;
  display: grid;
  gap: 8px;
  grid-template-columns: 76px minmax(130px, 1fr) repeat(5, 104px);
}

.ot-pliego-edit-grid label,
.ot-pliego-dialog-grid label {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.ot-pliego-edit-grid label > span,
.ot-pliego-dialog-grid label > span,
.ot-pliego-data-grid h4 {
  color: #173a7a;
  font-size: 12px;
  font-weight: 900;
}

.ot-pliego-edit-grid .grid-input {
  min-width: 0;
}

.ot-pliego-edit-grid .code-input {
  max-width: none;
}

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

.ot-pliego-data-grid section {
  background: #f8fafc;
  border: 1px solid #d9e3ee;
  border-radius: 8px;
  display: grid;
  gap: 8px;
  padding: 10px;
}

.ot-pliego-data-grid dl {
  display: grid;
  gap: 5px;
  margin: 0;
}

.ot-pliego-data-grid dl div {
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(90px, .9fr) minmax(0, 1fr);
  min-height: 24px;
}

.ot-pliego-data-grid dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.ot-pliego-data-grid dd {
  color: var(--text);
  font-size: 12px;
  font-weight: 800;
  margin: 0;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ot-stock-badge {
  border-radius: 999px;
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  padding: 5px 7px;
}

.ot-stock-badge.ok {
  background: #e4f5ee;
  color: #11614f;
}

.ot-stock-badge.warn {
  background: #fff7ed;
  color: #9a3412;
}

.ot-pliego-note {
  background: #f8fafc;
  border-left: 3px solid #94a3b8;
  margin: 0;
  padding: 7px 9px;
}

.ot-pliegos-empty {
  display: grid;
  gap: 4px;
  padding: 14px;
}

.ot-pliegos-empty strong {
  color: var(--text);
}

.ot-pliegos-empty span {
  color: var(--muted);
  font-size: 13px;
}

.ot-pliegos-visual-row {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ot-pliegos-doc-card {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  text-decoration: none;
}

.ot-pliegos-doc-card strong {
  color: #334155;
  font-size: 14px;
}

.ot-pliegos-doc-card:hover {
  border-color: #94a3b8;
  text-decoration: none;
}

.ot-pliego-dialog-grid {
  grid-template-columns: 88px minmax(150px, 1fr) repeat(2, 110px);
}

.ot-pliego-dialog-grid .wide {
  grid-column: 1 / -1;
}

.legacy-pliegos-visual[hidden] {
  display: none !important;
}

@media (max-width: 1100px) {
  .ot-pliegos-section {
    max-width: 100%;
  }

  .ot-pliegos-summary,
  .ot-pliego-data-grid,
  .ot-pliegos-visual-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ot-pliego-edit-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .ot-pliego-edit-grid .wide {
    grid-column: span 2;
  }
}

@media (max-width: 720px) {
  .ot-pliegos-head,
  .ot-pliego-card-head {
    align-items: stretch;
    grid-template-columns: 1fr;
  }

  .ot-pliegos-head {
    display: grid;
  }

  .ot-pliegos-summary,
  .ot-pliego-edit-grid,
  .ot-pliego-data-grid,
  .ot-pliegos-visual-row,
  .ot-pliego-dialog-grid {
    grid-template-columns: 1fr;
  }

  .ot-pliego-card-actions {
    justify-content: flex-start;
  }
}

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

.ot-visual-card {
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 7px;
  padding: 10px;
}

.ot-visual-card h3,
.ot-process-visual p {
  margin: 0;
}

.ot-visual-card h3 {
  color: var(--text);
  font-size: 14px;
}

.ot-visual-card p,
.ot-process-visual p {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.ot-visual-placeholder {
  align-items: center;
  aspect-ratio: 16 / 7;
  background: linear-gradient(135deg, #eef7f3, #f8fafc);
  border: 1px dashed #9fc9bd;
  border-radius: 6px;
  color: var(--accent);
  display: grid;
  justify-items: center;
  padding: 12px;
  text-align: center;
}

.ot-visual-placeholder span {
  color: #35695d;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.ot-visual-placeholder strong {
  font-size: 22px;
}

.ot-visual-media {
  aspect-ratio: 16 / 7;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  overflow: hidden;
}

.ot-visual-media img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.ot-visual-media.is-missing {
  align-items: center;
  background: #eef7f3;
  border-style: dashed;
  color: #35695d;
  display: grid;
  justify-items: center;
  padding: 12px;
  text-align: center;
}

.ot-visual-media.is-missing::after {
  content: attr(data-fallback);
  font-size: 12px;
  font-weight: 800;
}

.ot-visual-media.machine {
  aspect-ratio: 4 / 3;
}

.ot-visual-media.machine img {
  object-fit: contain;
  padding: 6px;
}

.ot-print-layout {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1fr) 260px;
}

.ot-print-fields {
  display: grid;
  gap: 10px;
}

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

.ot-print-options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ot-process-visual {
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 8px;
  padding: 10px;
}

.ot-process-visual .machine {
  aspect-ratio: 4 / 3;
}

.ot-stage-grid {
  align-items: end;
  display: grid;
  gap: 10px;
  grid-template-columns: 110px 90px minmax(160px, 1fr) minmax(150px, 1fr) 120px 120px repeat(3, 110px);
}

.ot-stage-grid .wide {
  grid-column: span 2;
}

.ot-stage-grid label {
  display: grid;
  gap: 3px;
}

.ot-stage-grid label > span {
  color: #173a7a;
  font-size: 13px;
  font-weight: 800;
}

.ot-stage-table table {
  min-width: 980px;
}

.ot-stage-table th,
.ot-stage-table td {
  padding: 4px 5px;
}

.ot-stage-table .text-input {
  min-width: 110px;
}

.ot-stage-table .number-input {
  min-width: 72px;
}

.ot-stage-table .code-input,
.ot-stage-table .tiny-input {
  min-width: 54px;
}

.np-action-status li {
  color: #273449;
  font-size: 13px;
}

.np-detail-form-extra {
  margin: 0 auto 16px;
  max-width: 1280px;
}

.np-extra-form-grid {
  align-items: end;
  display: grid;
  gap: 8px 12px;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
}

.np-extra-form-grid label {
  display: grid;
  gap: 3px;
}

.np-extra-form-grid label > span {
  color: #384253;
  font-size: 13px;
  font-weight: 800;
}

.np-extra-form-grid .wide {
  grid-column: span 2;
}

.bulk-shift-strip {
  align-items: center;
}

.bulk-shift-strip > div:last-child {
  flex-wrap: nowrap;
}

.bulk-shift-strip .date-input {
  width: 148px;
}

.bulk-shift-strip .tiny-input {
  width: 72px;
}

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

.stacked-table {
  margin-top: 14px;
}

table {
  border-collapse: collapse;
  min-width: 980px;
  width: 100%;
}

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

th {
  background: #eef2f5;
  color: #384253;
  font-size: 12px;
  text-transform: uppercase;
}

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

.empty {
  color: var(--muted);
  padding: 28px;
  text-align: center;
}

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

.detail-grid > div,
.notes {
  padding: 18px;
}

dl {
  display: grid;
  gap: 9px 14px;
  grid-template-columns: 120px 1fr;
  margin: 0;
}

dt {
  color: var(--muted);
}

dd {
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
}

.notes {
  margin-top: 16px;
}

.form-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: 18px;
}

.form-grid label {
  display: grid;
  gap: 6px;
}

.form-grid .check-line {
  align-items: center;
  display: flex;
}

.form-grid label span {
  color: #384253;
  font-size: 13px;
  font-weight: 700;
}

.form-grid .wide,
.form-actions {
  grid-column: 1 / -1;
}

.form-grid small {
  color: #a33b2f;
}

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

details summary {
  color: var(--accent);
  cursor: pointer;
  font-weight: 700;
}

.inline-editor {
  margin-top: 14px;
}

.compact-editor {
  min-width: 560px;
}

.compact-editor .form-grid {
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  padding: 12px;
}

.grid-input {
  background: #fff;
  border: 1px solid #c7d2de;
  border-radius: 4px;
  min-width: 0;
  padding: 4px 5px;
  width: 100%;
}

.grid-input:hover,
.grid-input:focus {
  background: #fff;
  border-color: #4f7da8;
  outline: none;
}

.grid-input.saving {
  border-color: #d6b248;
}

.grid-input.save-ok {
  border-color: #4f9d69;
}

.grid-input.save-error {
  background: #fff2f0;
  border-color: #c44b3f;
}

.tiny-input {
  max-width: 54px;
}

.code-input {
  max-width: 76px;
}

.number-input {
  max-width: 96px;
  text-align: right;
}

.text-input {
  min-width: 180px;
}

.formula-input {
  min-width: 220px;
}

.date-input {
  max-width: 150px;
}

.modal-editor {
  border: 1px solid var(--line);
  border-radius: 8px;
  max-width: min(920px, calc(100vw - 36px));
  padding: 18px;
}

.modal-editor::backdrop {
  background: rgb(12 24 38 / 45%);
}

.modal-editor h2 {
  margin-top: 0;
}

.layout-editor-button {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  bottom: 18px;
  box-shadow: 0 8px 24px rgb(15 23 42 / 18%);
  color: #002a70;
  cursor: pointer;
  display: inline-flex;
  font-size: 17px;
  font-weight: 900;
  height: 34px;
  justify-content: center;
  position: fixed;
  right: 18px;
  width: 34px;
  z-index: 80;
}

.layout-editor-button.active {
  background: #eaf2fb;
  border-color: #2b6cb0;
}

.layout-ruler {
  background:
    repeating-linear-gradient(
      to right,
      rgb(0 42 112 / 45%) 0,
      rgb(0 42 112 / 45%) 1px,
      transparent 1px,
      transparent 10px
    ),
    linear-gradient(#ffffff, #f4f7fb);
  border-bottom: 1px solid var(--line);
  color: #002a70;
  font-size: 10px;
  height: 25px;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 75;
}

.layout-ruler span {
  position: absolute;
  top: 10px;
  transform: translateX(2px);
}

.layout-editor-panel {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  bottom: 60px;
  box-shadow: 0 12px 34px rgb(15 23 42 / 20%);
  display: grid;
  gap: 8px;
  padding: 10px;
  position: fixed;
  right: 18px;
  width: 250px;
  z-index: 80;
}

.layout-editor-panel[hidden],
.layout-ruler[hidden],
.layout-resize-handle[hidden] {
  display: none !important;
}

.layout-editor-title,
.layout-editor-row,
.layout-editor-actions {
  align-items: center;
  display: flex;
  gap: 6px;
}

.layout-editor-title {
  justify-content: space-between;
}

.layout-editor-title strong {
  color: #002a70;
  font-size: 13px;
}

.layout-editor-title span {
  color: #64748b;
  font-size: 11px;
}

.layout-editor-title span.ok {
  color: #047857;
}

.layout-editor-panel label {
  color: #002a70;
  display: grid;
  font-size: 11px;
  font-weight: 800;
  gap: 4px;
}

.layout-editor-panel input[type="range"] {
  width: 100%;
}

.layout-editor-panel select {
  border: 1px solid var(--line);
  border-radius: 6px;
  font-size: 12px;
  height: 28px;
  padding: 3px 6px;
  width: 100%;
}

.layout-editor-row input {
  border: 1px solid var(--line);
  border-radius: 6px;
  font-size: 12px;
  height: 26px;
  padding: 3px 6px;
  width: 82px;
}

.layout-editor-actions {
  justify-content: flex-end;
}

.layout-editor-actions button {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 7px;
  cursor: pointer;
  min-height: 27px;
  min-width: 30px;
}

.layout-editor-pick {
  justify-content: stretch;
}

.layout-editor-pick button {
  color: #002a70;
  font-weight: 800;
  width: 100%;
}

.layout-editor-pick button.active {
  background: #eaf2fb;
  border-color: #2b6cb0;
}

.layout-editing-target {
  outline: 2px dashed #2b6cb0;
  outline-offset: 3px;
  position: relative;
}

.layout-editor-open .layout-active-element {
  box-shadow: inset 0 0 0 2px rgb(43 108 176 / 42%);
}

.layout-picking .client-fox-window [data-layout-key]:hover {
  cursor: crosshair;
  outline: 2px solid #f97316;
  outline-offset: 2px;
}

.layout-resize-handle {
  background: #2b6cb0;
  border-radius: 6px;
  bottom: 10px;
  cursor: ew-resize;
  opacity: .75;
  position: absolute;
  right: -8px;
  top: 10px;
  width: 6px;
  z-index: 4;
}

.layout-resizing,
.layout-resizing * {
  cursor: ew-resize !important;
  user-select: none !important;
}

.gridstack-layout {
  width: 100%;
}

.gridstack-layout .grid-stack {
  min-height: 620px;
}

.gridstack-layout .grid-stack-item-content {
  inset: 4px;
  overflow: hidden;
}

.gridstack-card {
  background: #ffffff;
  border: 1px solid transparent;
  border-radius: 8px;
  display: block;
}

.gridstack-layout:not(.gridstack-editing) .grid-stack-item-content {
  inset: 0;
}

.gridstack-layout:not(.gridstack-editing) .gridstack-card {
  border-color: transparent;
}

.gridstack-layout.gridstack-editing .gridstack-card {
  border-color: #bcd1f3;
  box-shadow: inset 0 0 0 1px rgb(66 99 235 / 12%);
}

.gridstack-layout.gridstack-editing .grid-stack-item.ui-draggable-dragging .gridstack-card,
.gridstack-layout.gridstack-editing .grid-stack-item.ui-resizable-resizing .gridstack-card {
  border-color: #6d5bd0;
  box-shadow: 0 14px 28px rgb(15 23 42 / 18%);
}

.gridstack-layout .client-fox-title,
.gridstack-layout .client-toolbar,
.gridstack-layout .table-wrap {
  margin: 0;
}

.gridstack-layout .table-wrap {
  height: 100%;
  overflow: auto;
}

.gridstack-generated-layout .gridstack-card > section,
.gridstack-generated-layout .gridstack-card > div,
.gridstack-generated-layout .gridstack-card > aside,
.gridstack-generated-layout .gridstack-card > form,
.gridstack-generated-layout .gridstack-card > header,
.gridstack-generated-layout .gridstack-card > article {
  height: 100%;
  margin: 0;
  min-width: 0;
}

.gridstack-generated-layout .gridstack-card > .table-wrap,
.gridstack-generated-layout .gridstack-card > .dense-table {
  overflow: auto;
}

.gridstack-mode-button,
.gridstack-panel {
  position: fixed;
  z-index: 82;
}

.gridstack-mode-button {
  align-items: center;
  background: #6d5bd0;
  border: 1px solid #5948b6;
  border-radius: 8px;
  bottom: 18px;
  box-shadow: 0 10px 24px rgb(15 23 42 / 18%);
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  gap: 6px;
  min-height: 34px;
  padding: 0 12px;
  right: 18px;
}

.gridstack-mode-button.active {
  background: #513fb2;
}

.gridstack-panel {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 10px;
  bottom: 60px;
  box-shadow: 0 12px 34px rgb(15 23 42 / 20%);
  display: grid;
  gap: 8px;
  padding: 10px;
  right: 18px;
  width: 250px;
}

.gridstack-panel[hidden] {
  display: none !important;
}

.gridstack-panel-title {
  display: grid;
  gap: 2px;
}

.gridstack-panel-title strong {
  color: #002a70;
  font-size: 13px;
}

.gridstack-panel-title span {
  color: #64748b;
  font-size: 11px;
}

.gridstack-panel-title span.ok {
  color: #047857;
}

.gridstack-panel-actions {
  display: grid;
  gap: 6px;
  grid-template-columns: 1fr 1fr;
}

.gridstack-panel-actions button {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: #0f172a;
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
  min-height: 30px;
}

.gridstack-panel-actions button[data-gridstack-save] {
  background: #e7f5ef;
  border-color: #9ad8be;
  color: #047857;
}

.gridstack-panel-actions button[data-gridstack-reset] {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a3412;
}

.np-help-dialog {
  padding: 0;
  width: min(920px, calc(100vw - 36px));
}

.np-help-header,
.lookup-footer {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 8px;
  justify-content: space-between;
  padding: 10px 12px;
}

.np-help-header h2 {
  font-size: 16px;
  margin: 0;
}

.lookup-footer {
  border-bottom: 0;
  border-top: 1px solid var(--line);
}

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

.help-card {
  background: #f8fafb;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
}

.help-card h3 {
  font-size: 14px;
  margin: 0 0 8px;
}

.help-card ul {
  margin: 0;
  padding-left: 18px;
}

.help-card li {
  margin: 4px 0;
}

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

tr.created-flash td {
  animation: createdFlash 2.6s ease-out;
}

tr.created-flash .grid-input {
  animation: createdFlashInput 2.6s ease-out;
}

.section-flash {
  animation: sectionFlash 2.2s ease-out;
}

@keyframes createdFlash {
  0%,
  70% {
    background: #e4f7e9;
  }
  100% {
    background: transparent;
  }
}

@keyframes createdFlashInput {
  0%,
  70% {
    background: #f1fbf3;
  }
  100% {
    background: #fff;
  }
}

@keyframes sectionFlash {
  0%,
  65% {
    background: #e4f7e9;
    box-shadow: 0 0 0 2px #72c28a inset;
  }
  100% {
    background: transparent;
    box-shadow: none;
  }
}

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

.compact-summary {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  margin-bottom: 14px;
}

.module-box {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
}

.module-links {
  display: grid;
  gap: 8px;
}

.module-links a {
  align-items: center;
  background: #f2f5f8;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  display: flex;
  justify-content: space-between;
  min-height: 38px;
  padding: 8px 10px;
}

.module-links a:hover {
  background: #e8f0f7;
  text-decoration: none;
}

.module-links strong {
  color: var(--muted);
  font-size: 13px;
}

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

.ot-parts-insumos-section {
  display: grid;
  gap: 12px;
}

.ot-parts-insumos-section h2 {
  margin-bottom: 0;
}

.ot-section-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ot-parts-insumos-section .split-tables {
  grid-template-columns: 1fr;
}

.ot-parts-insumos-section .table-wrap {
  max-width: 100%;
  overflow-x: auto;
}

.ot-parts-insumos-section .dense-table table {
  min-width: 1320px;
}

.fox-order-window {
  color: var(--text);
  display: grid;
  gap: 16px;
}

.fox-toolbar {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.fox-header-grid {
  align-items: start;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  padding: 16px;
}

.fox-header-grid label {
  display: grid;
  gap: 3px;
}

.fox-header-grid label.wide {
  grid-column: span 2;
}

.fox-header-grid span,
.fox-text-panel h2,
.fox-total-panel h2 {
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}

.fox-header-grid small {
  color: var(--muted);
  font-size: 12px;
  min-height: 16px;
}

.fox-items-table {
  max-height: 360px;
  overflow: auto;
}

.fox-items-table td,
.fox-bottom-grid td {
  height: 34px;
  padding: 5px 6px;
  vertical-align: middle;
}

.fox-items-table .grid-input,
.fox-bottom-grid .grid-input,
.fox-order-window .grid-input {
  background: #fff;
  border-color: #c6d1df;
  border-radius: 5px;
  min-height: 31px;
}

.fox-items-table .text-input {
  min-width: 170px;
}

.numeric-cell {
  text-align: right;
}

.fox-bottom-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1fr) 280px;
}

.fox-text-panel,
.fox-total-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
}

.fox-text-panel h2,
.fox-total-panel h2 {
  margin: 0 0 6px;
}

.fox-total-panel dl {
  display: grid;
  gap: 6px 10px;
  grid-template-columns: 84px 1fr;
  margin: 0 0 10px;
}

.fox-total-panel dt {
  color: var(--muted);
  font-weight: 700;
  text-align: right;
}

.fox-total-panel dd {
  margin: 0;
  text-align: right;
}

.fox-order-window .danger-button {
  min-height: 25px;
  padding: 3px 8px;
}

.production-list-toolbar {
  margin: 0 auto 12px;
  max-width: 1240px;
}

.production-list-toolbar h1,
.ot-detail-header h1 {
  font-size: 23px;
  line-height: 1.1;
}

.production-list-toolbar p,
.ot-detail-header p,
.ot-detail-notice {
  font-size: 12px;
}

.production-orders-table {
  margin: 0 auto;
  max-width: 1240px;
}

.production-orders-table table {
  min-width: 1120px;
}

.production-orders-datatable .dt-container {
  width: 100%;
}

.production-orders-table th,
.production-orders-table td {
  padding: 5px 6px;
  vertical-align: middle;
}

.production-orders-table .grid-input {
  min-height: 25px;
  padding: 3px 5px;
}

.production-orders-table .compact-action {
  min-height: 24px;
  padding: 3px 6px;
}

.production-orders-table .row-actions {
  align-items: center;
  display: grid;
  gap: 4px;
  grid-template-columns: repeat(3, minmax(48px, 1fr));
  justify-items: stretch;
}

.production-orders-table .row-actions .button,
.production-orders-table .row-actions .danger-button {
  align-items: center;
  display: inline-flex;
  font-size: 11px;
  justify-content: center;
  min-width: 0;
  width: 100%;
}

.production-delete-button .delete-icon {
  align-items: center;
  border: 1px solid rgb(255 255 255 / 42%);
  border-radius: 50%;
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  height: 15px;
  justify-content: center;
  line-height: 1;
  margin-right: 3px;
  width: 15px;
}

.production-orders-table td:nth-child(8) {
  text-align: center;
}

.ot-detail-header,
.ot-detail-notice,
.ot-detail-toolbar,
.ot-detail-tabs,
.ot-quick-summary,
.ot-detail-window,
.ot-parts-insumos-section,
.ot-release-checks {
  max-width: 1040px;
}

.ot-detail-header {
  align-items: start;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 8px;
}

.ot-detail-header-tools {
  align-items: flex-start;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.ot-detail-header-tools .np-autosave-note {
  margin: 0;
}

.ot-header-coverage-tool {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  color: #0f172a;
  display: inline-flex;
  font-size: 14px;
  font-weight: 900;
  height: 31px;
  justify-content: center;
  line-height: 1;
  min-height: 31px;
  min-width: 31px;
  padding: 0;
  width: 31px;
}

.ot-header-coverage-tool:hover {
  background: #eef6ff;
  border-color: #9bb9d8;
}

.ot-detail-notice {
  margin: 0 auto 8px;
  padding: 8px 10px;
}

.ot-detail-toolbar {
  gap: 5px;
  margin: 0 auto 8px;
  padding: 8px 10px;
}

.ot-detail-toolbar .button,
.ot-detail-toolbar .danger-button {
  font-size: 12px;
  min-height: 27px;
  padding: 4px 7px;
}

.ot-detail-toolbar .coverage-tool,
.section-heading-row .coverage-tool.ot-coverage-tool {
  align-items: center;
  aspect-ratio: 1 / 1;
  border-radius: 9px;
  display: inline-flex;
  font-size: 15px;
  font-weight: 900;
  justify-content: center;
  line-height: 1;
  min-height: 30px;
  min-width: 30px;
  padding: 0;
}

.ot-detail-tabs {
  gap: 5px;
  margin-bottom: 8px;
}

.ot-detail-tabs .np-tab-button {
  font-size: 12px;
  min-height: 28px;
  padding: 5px 8px;
}

.ot-quick-summary {
  gap: 6px;
  margin-bottom: 8px;
}

.ot-quick-summary div {
  min-height: 50px;
  padding: 6px 8px;
}

.ot-quick-summary span,
.ot-quick-summary em {
  font-size: 11px;
}

.ot-quick-summary strong {
  font-size: 14px;
}

.ot-detail-window {
  gap: 8px;
  margin-bottom: 12px;
  padding: 10px;
}

.ot-detail-window label > span,
.ot-panel-title {
  font-size: 12px;
}

.ot-detail-window .grid-input,
.ot-link-field {
  font-size: 12px;
  min-height: 28px;
  padding: 4px 6px;
}

.ot-top-grid,
.ot-reference-grid,
.ot-text-grid,
.ot-delivery-grid,
.ot-bottom-grid,
.ot-stage-grid,
.ot-print-mini-grid {
  gap: 7px;
}

.ot-top-grid {
  grid-template-columns: 74px 105px 120px 135px minmax(180px, 1fr) 62px 105px 105px;
}

.ot-reference-grid {
  grid-template-columns: 145px 115px 135px 115px minmax(240px, 1fr);
}

.ot-text-grid textarea {
  min-height: 120px;
}

.ot-delivery-grid textarea {
  min-height: 68px;
}

.ot-bottom-grid {
  grid-template-columns: 125px 130px 130px minmax(220px, 1fr) 145px;
}

.ot-side-actions,
.ot-close-panel,
.ot-task-panel,
.ot-process-panel,
.ot-end-actions {
  gap: 5px;
}

.ot-side-actions .button,
.ot-close-panel .button,
.ot-task-panel .button,
.ot-end-actions .button,
.ot-end-actions .danger-button {
  font-size: 12px;
  min-height: 28px;
  padding: 4px 7px;
}

.ot-related-strip {
  margin-top: 8px;
  padding-top: 7px;
}

.ot-related-strip a {
  min-width: 82px;
  padding: 5px 8px;
}

.ot-related-strip span {
  font-size: 11px;
}

.ot-parts-insumos-section {
  margin-left: auto;
  margin-right: auto;
}

.ot-subnav,
#ot-copia,
#ot-pliegos,
#ot-impresion,
#ot-troquelado,
#ot-preparacion,
#ot-seguimiento,
#ot-partes-insumos,
#ot-textos,
#estado-funcional-ot {
  margin-left: auto;
  margin-right: auto;
  max-width: 1040px;
  width: 100%;
}

.costos-window {
  display: grid;
  gap: 12px;
  max-width: 1024px;
}

.costos-filter {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 120px 120px 90px;
  margin-bottom: 0;
}

.costos-filter .client-tool {
  width: 100%;
}

.costos-table {
  margin-top: 0;
  overflow: hidden !important;
  width: 100%;
}

.costos-table .dt-container,
.costos-table .dt-layout-table,
.costos-table .dt-layout-cell {
  max-width: 100%;
  width: 100%;
}

.costos-table .dt-layout-table {
  overflow-x: hidden !important;
}

.costos-table .dt-layout-row:last-child {
  justify-content: space-between;
}

.costos-table .dt-layout-row:last-child .dt-layout-cell:last-child,
.costos-table .dt-layout-row:last-child .dt-end,
.costos-table .dt-layout-row:last-child .dt-layout-end {
  margin-left: auto;
}

.costos-table .dt-layout-row:last-child .dt-paging {
  justify-content: flex-end;
  margin-left: auto;
}

.costos-table table,
.costos-table table.dataTable {
  min-width: 0;
  table-layout: fixed;
  width: 100% !important;
}

.costos-table th,
.costos-table td {
  box-sizing: border-box;
  font-size: 10px;
  overflow: hidden;
  padding-left: 4px;
  padding-right: 4px;
  text-overflow: ellipsis;
  vertical-align: middle;
  white-space: nowrap;
}

.costos-table th:nth-child(1),
.costos-table td:nth-child(1) {
  width: 62px;
}

.costos-table th:nth-child(2),
.costos-table td:nth-child(2) {
  width: 150px;
}

.costos-table th:nth-child(3),
.costos-table td:nth-child(3) {
  text-align: center;
  width: 42px;
}

.costos-table th:nth-child(4),
.costos-table td:nth-child(4),
.costos-table th:nth-child(5),
.costos-table td:nth-child(5) {
  text-align: right;
  width: 66px;
}

.costos-table th:nth-child(6),
.costos-table td:nth-child(6) {
  text-align: right;
  width: 58px;
}

.costos-table th:nth-child(7),
.costos-table td:nth-child(7) {
  width: 46px;
}

.costos-table th:nth-child(8),
.costos-table td:nth-child(8),
.costos-table th:nth-child(9),
.costos-table td:nth-child(9) {
  text-align: center;
  width: 52px;
}

.costos-table th:nth-child(10),
.costos-table td:nth-child(10) {
  width: 210px;
}

.costos-table th:nth-child(11),
.costos-table td:nth-child(11) {
  text-align: center;
  width: 54px;
}

.costos-rangos-table {
  margin-top: 0;
  overflow-x: auto;
}

.costos-rangos-table table {
  min-width: 1220px;
  table-layout: fixed;
}

.costos-rangos-table th,
.costos-rangos-table td {
  white-space: nowrap;
}

.costos-rangos-table th:nth-child(1),
.costos-rangos-table td:nth-child(1) {
  width: 45px;
}

.costos-rangos-table th:nth-child(16),
.costos-rangos-table td:nth-child(16) {
  width: 180px;
}

.costos-detail-window {
  box-sizing: border-box;
  max-width: 1024px;
  overflow: hidden;
  width: 100%;
}

.costos-detail-toolbar {
  gap: 5px;
  justify-content: flex-start;
  margin-bottom: 0;
  max-width: 100%;
  min-width: 0;
  width: 100%;
}

.costos-detail-toolbar .client-tool {
  min-height: 28px;
  min-width: 34px;
  padding: 5px 8px;
}

.costos-detail-toolbar .costos-coverage-tool {
  margin-left: auto;
}

.costos-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  padding: 10px;
  width: 100%;
}

.costos-card h2 {
  color: #002a70;
  font-size: 13px;
  margin: 0 0 8px;
}

.costos-field-grid,
.costos-formula-grid,
.costos-fijos-form-grid {
  display: grid;
  gap: 8px;
  max-width: 100%;
  min-width: 0;
}

.costos-field-grid label,
.costos-formula-grid label,
.costos-fijos-form-grid label {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.costos-detail-window .grid-input,
.costos-detail-window textarea,
.costos-detail-window select {
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
}

.costos-field-grid span,
.costos-formula-grid span,
.costos-fijos-form-grid span {
  color: #002a70;
  font-size: 11px;
  font-weight: 800;
}

.costos-main-grid {
  grid-template-columns: 76px minmax(220px, 1fr) 70px 82px 88px 90px;
}

.costos-values-grid,
.costos-ranges-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

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

.costos-formula-grid label:first-child {
  grid-column: 1 / -1;
}

.costos-formula-grid textarea {
  min-height: 52px;
  resize: vertical;
}

.costos-two-columns {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, .8fr) minmax(0, 1fr);
  max-width: 100%;
  min-width: 0;
}

.costos-summary-strip {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin-bottom: 8px;
}

.costos-summary-strip span {
  background: #f8fafb;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #002a70;
  font-size: 11px;
  font-weight: 800;
  padding: 5px 7px;
}

.costos-summary-strip strong {
  color: var(--text);
  display: block;
  font-size: 12px;
  font-weight: 700;
  margin-top: 2px;
}

.costos-usage-pagination {
  align-items: center;
  display: flex;
  gap: 8px;
  justify-content: space-between;
  margin-top: 8px;
}

.costos-usage-pagination > span {
  color: #415066;
  font-size: 12px;
}

.costos-usage-pagination > div {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: flex-end;
}

.costos-usage-pagination strong {
  color: var(--text);
  font-size: 12px;
  padding: 0 4px;
}

.costos-observaciones {
  min-height: 70px;
  resize: vertical;
  width: 100%;
}

.costos-fijos-window {
  display: grid;
  gap: 12px;
  max-width: 1024px;
}

.costos-fijos-toolbar {
  margin-bottom: 0;
}

.costos-fijos-filter {
  align-items: center;
  display: grid;
  flex: 1;
  gap: 8px;
  grid-template-columns: minmax(260px, 1fr) 90px;
  margin: 0;
}

.costos-fijos-form-grid {
  grid-template-columns: 90px 80px minmax(220px, 1fr) 110px;
}

.costos-fijos-form-grid .form-actions {
  align-items: end;
  display: flex;
  gap: 8px;
  grid-column: 1 / -1;
  justify-content: flex-end;
}

.costos-fijos-table {
  margin-top: 0;
  max-width: 100%;
  overflow: hidden;
  width: 100%;
}

.costos-fijos-table .dt-container,
.costos-fijos-table .dt-layout-table,
.costos-fijos-table .dt-layout-cell {
  max-width: 100%;
  width: 100%;
}

.costos-fijos-table .dt-layout-table {
  overflow-x: hidden !important;
}

.costos-fijos-table .dt-layout-row {
  padding: 8px 10px;
}

.costos-fijos-table .dt-layout-row:last-child {
  justify-content: space-between;
}

.costos-fijos-table .dt-layout-row:last-child .dt-layout-cell:last-child,
.costos-fijos-table .dt-layout-row:last-child .dt-end,
.costos-fijos-table .dt-layout-row:last-child .dt-layout-end {
  margin-left: auto;
}

.costos-fijos-table .dt-layout-row:last-child .dt-paging {
  justify-content: flex-end;
  margin-left: auto;
}

.costos-fijos-table table,
.costos-fijos-table table.dataTable {
  max-width: 100%;
  min-width: 0;
  table-layout: fixed;
  width: 100%;
}

.costos-fijos-table th,
.costos-fijos-table td {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.costos-fijos-table th:nth-child(1),
.costos-fijos-table td:nth-child(1) {
  width: 92px;
}

.costos-fijos-table th:nth-child(2),
.costos-fijos-table td:nth-child(2) {
  width: 70px;
}

.costos-fijos-table th:nth-child(4),
.costos-fijos-table td:nth-child(4) {
  width: 115px;
}

.costos-fijos-table th:nth-child(5),
.costos-fijos-table td:nth-child(5) {
  width: 92px;
}

.costos-fijos-table .grid-input,
.costos-fixed-mini-table .grid-input,
.costos-variable-table .grid-input,
.costos-usage-table .grid-input {
  min-width: 0;
}

.costos-fijos-table .grid-input {
  height: 32px;
  width: 100%;
}

.costos-fijos-delete-button {
  min-width: 74px;
}

.complejidad-window {
  display: grid;
  gap: 12px;
  max-width: 1024px;
}

.complejidad-toolbar {
  margin-bottom: 0;
}

.complejidad-filter {
  align-items: center;
  display: grid;
  flex: 1;
  gap: 8px;
  grid-template-columns: minmax(260px, 1fr) 90px;
  margin: 0;
}

.complejidad-form-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: 80px minmax(220px, 1fr) 90px 80px 90px 80px 80px;
}

.complejidad-form-grid label {
  display: grid;
  gap: 3px;
}

.complejidad-form-grid span {
  color: #002a70;
  font-size: 11px;
  font-weight: 800;
}

.complejidad-form-grid .form-actions {
  align-items: end;
  display: flex;
  gap: 8px;
  grid-column: 1 / -1;
  justify-content: flex-end;
}

.complejidad-table {
  margin-top: 0;
  max-width: 100%;
  overflow: hidden;
  width: 100%;
}

.complejidad-table .dt-container,
.complejidad-table .dt-layout-table,
.complejidad-table .dt-layout-cell {
  max-width: 100%;
  width: 100%;
}

.complejidad-table .dt-layout-table {
  overflow-x: hidden !important;
}

.complejidad-table .dt-layout-row {
  padding: 8px 10px;
}

.complejidad-table .dt-layout-row:last-child {
  justify-content: space-between;
}

.complejidad-table .dt-layout-row:last-child .dt-layout-cell:last-child,
.complejidad-table .dt-layout-row:last-child .dt-end,
.complejidad-table .dt-layout-row:last-child .dt-layout-end {
  margin-left: auto;
}

.complejidad-table .dt-layout-row:last-child .dt-paging {
  justify-content: flex-end;
  margin-left: auto;
}

.complejidad-table table,
.complejidad-table table.dataTable {
  min-width: 0;
  table-layout: fixed;
  width: 100% !important;
}

.complejidad-table th,
.complejidad-table td {
  box-sizing: border-box;
  overflow: hidden;
  padding-left: 6px;
  padding-right: 6px;
  text-overflow: ellipsis;
  vertical-align: middle;
  white-space: nowrap;
}

.complejidad-table th:nth-child(1),
.complejidad-table td:nth-child(1) {
  width: 76px;
}

.complejidad-table th:nth-child(2),
.complejidad-table td:nth-child(2) {
  width: 32%;
}

.complejidad-table th:nth-child(3),
.complejidad-table td:nth-child(3),
.complejidad-table th:nth-child(4),
.complejidad-table td:nth-child(4),
.complejidad-table th:nth-child(5),
.complejidad-table td:nth-child(5),
.complejidad-table th:nth-child(6),
.complejidad-table td:nth-child(6),
.complejidad-table th:nth-child(7),
.complejidad-table td:nth-child(7) {
  text-align: center;
  width: 86px;
}

.complejidad-table th:nth-child(8),
.complejidad-table td:nth-child(8) {
  width: 86px;
  text-align: center;
}

.complejidad-table .grid-input {
  min-width: 0;
  width: 100%;
}

.complejidad-delete-button {
  font-size: 12px;
  gap: 4px;
  min-height: 30px;
  min-width: 0;
  padding: 4px 7px;
  width: 68px;
}

.maquinas-window {
  display: grid;
  gap: 8px;
  max-width: 1080px;
}

.maquinas-filter {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 120px 90px;
  margin-bottom: 0;
}

.maquinas-table {
  margin-top: 0;
  overflow-x: auto;
}

.maquinas-datatable .dt-container {
  border-radius: 8px;
}

.maquinas-datatable .dt-layout-row {
  padding: 8px 10px;
}

.maquinas-datatable .dt-search input {
  width: min(320px, 38vw);
}

.maquinas-table table {
  min-width: 1080px;
  table-layout: fixed;
}

.maquinas-table th:nth-child(1),
.maquinas-table td:nth-child(1) {
  width: 62px;
}

.maquinas-table th:nth-child(2),
.maquinas-table td:nth-child(2) {
  width: 190px;
}

.maquinas-table th:nth-child(3),
.maquinas-table td:nth-child(3),
.maquinas-table th:nth-child(4),
.maquinas-table td:nth-child(4) {
  width: 58px;
}

.maquinas-table th:nth-child(5),
.maquinas-table td:nth-child(5),
.maquinas-table th:nth-child(6),
.maquinas-table td:nth-child(6),
.maquinas-table th:nth-child(7),
.maquinas-table td:nth-child(7),
.maquinas-table th:nth-child(8),
.maquinas-table td:nth-child(8),
.maquinas-table th:nth-child(9),
.maquinas-table td:nth-child(9),
.maquinas-table th:nth-child(10),
.maquinas-table td:nth-child(10) {
  width: 82px;
}

.maquinas-table th:nth-child(11),
.maquinas-table td:nth-child(11) {
  width: 105px;
}

.maquinas-table th:nth-child(12),
.maquinas-table td:nth-child(12),
.maquinas-table th:nth-child(13),
.maquinas-table td:nth-child(13) {
  width: 76px;
}

.maquinas-detail-window {
  max-width: 1024px;
}

.maquinas-detail-window .client-fox-title h1 {
  font-size: 20px;
  line-height: 1.1;
}

.maquinas-detail-toolbar {
  gap: 4px;
  justify-content: flex-start;
  margin-bottom: 0;
  max-width: 1008px;
}

.maquinas-detail-toolbar .client-tool {
  font-size: 11px;
  min-height: 24px;
  min-width: 34px;
  padding: 3px 7px;
}

.maquinas-detail-toolbar .maquinas-coverage-tool {
  margin-left: auto;
}

.maquinas-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 7px;
}

.maquinas-card h2 {
  color: #002a70;
  font-size: 12px;
  margin: 0 0 6px;
}

.maquinas-fox-panel {
  align-items: start;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 610px) minmax(320px, 390px);
  justify-content: start;
}

.maquinas-fox-left,
.maquinas-fox-right {
  display: grid;
  gap: 8px;
}

.maquinas-gen-card {
  padding-top: 8px;
}

.maquinas-field-grid {
  display: grid;
  gap: 5px;
}

.maquinas-field-grid label {
  display: grid;
  gap: 3px;
}

.maquinas-check-field {
  align-items: center;
  display: flex !important;
  gap: 5px;
}

.maquinas-check-field input[type="checkbox"] {
  height: 13px;
  margin: 0;
  width: 13px;
}

.maquinas-field-grid span {
  color: #002a70;
  font-size: 10px;
  font-weight: 800;
}

.maquinas-detail-window .grid-input,
.maquinas-detail-window select.grid-input {
  font-size: 12px;
  height: 26px;
  min-height: 26px;
  padding: 3px 6px;
}

.maquinas-detail-window .number-input {
  text-align: right;
}

.maquinas-detail-window [hidden] {
  display: none !important;
}

.maquinas-gen-grid {
  align-items: end;
  grid-template-columns: 70px 78px 126px minmax(250px, 1fr);
}

.maquinas-gen-grid .wide {
  grid-column: 1 / 4;
}

.maquinas-fecha-grid {
  grid-template-columns: minmax(220px, 300px);
  justify-content: center;
  margin-top: 8px;
}

.maquinas-sector-grid {
  align-items: end;
  grid-template-columns: minmax(170px, 1fr) 86px 112px;
}

.maquinas-sector-grid .wide {
  grid-column: 1 / -1;
}

.maquinas-plancha-toggle {
  grid-column: 1 / 2;
}

.maquinas-prendido-field {
  grid-column: 2 / 3;
  justify-self: start;
}

.maquinas-plancha-value {
  grid-column: 1 / 3;
}

.maquinas-plancha-date {
  grid-column: 3 / 4;
}

.maquinas-sector-select {
  background-color: #fff;
  cursor: pointer;
}

.maquinas-pliego-fox-grid {
  align-items: end;
  grid-template-columns: 72px 24px 14px 72px 24px;
  max-width: 230px;
}

.maquinas-pliego-fox-grid .wide {
  grid-column: span 5;
}

.maquinas-mm-label {
  align-self: end;
  color: #415066;
  font-size: 11px;
  padding-bottom: 5px;
}

.maquinas-x-label {
  align-self: end;
  color: #415066;
  font-size: 11px;
  font-weight: 800;
  padding-bottom: 5px;
  text-align: center;
}

.maquinas-pinza-grid {
  grid-template-columns: minmax(145px, 1fr) 62px;
}

.maquinas-pinza-grid label {
  grid-template-columns: minmax(135px, 1fr) 60px 20px;
  grid-column: 1 / -1;
  align-items: end;
}

.maquinas-pinza-grid label:nth-child(-n + 3)::after {
  align-self: end;
  color: #415066;
  content: "mm";
  font-size: 11px;
  margin-left: 4px;
}

.maquinas-radio-strip {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 4px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 30px;
  padding: 4px 8px;
}

.maquinas-radio-strip label {
  align-items: center;
  color: #002a70;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  gap: 3px;
}

.maquinas-fox-list-card {
  margin-top: 4px;
}

.maquinas-fox-list-table tbody tr[data-url] {
  cursor: pointer;
}

.maquinas-fox-list-table tbody tr[data-url]:hover {
  background: #eaf2fb;
}

.maquinas-list-title {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 4px;
}

.maquinas-list-title h2 {
  margin-bottom: 0;
}

.maquinas-help-tool {
  color: #002a70;
  font-size: 14px;
  font-weight: 900;
  min-width: 24px;
  text-align: center;
}

.maquinas-fox-list-table {
  margin: 0;
  max-height: 138px;
  overflow: auto;
}

.maquinas-fox-list-table table {
  min-width: 560px;
  table-layout: fixed;
  width: 100%;
}

.maquinas-fox-list-table th,
.maquinas-fox-list-table td {
  font-size: 11px;
  line-height: 1.15;
  padding: 3px 5px;
}

.maquinas-fox-list-table th:nth-child(1),
.maquinas-fox-list-table td:nth-child(1) {
  width: 52px;
}

.maquinas-fox-list-table th:nth-child(2),
.maquinas-fox-list-table td:nth-child(2) {
  width: 190px;
}

.maquinas-fox-list-table th:nth-child(3),
.maquinas-fox-list-table td:nth-child(3) {
  width: 70px;
  text-align: right;
}

.maquinas-fox-list-table th:nth-child(4),
.maquinas-fox-list-table td:nth-child(4),
.maquinas-fox-list-table th:nth-child(5),
.maquinas-fox-list-table td:nth-child(5) {
  width: 105px;
}

.maquinas-fox-list-table .selected-row td {
  background: #eef5ff;
}

.maquinas-fox-list-footer {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: 52px 58px minmax(0, 1fr);
  margin-top: 6px;
}

.maquinas-fox-list-footer .client-tool {
  min-height: 24px;
  padding: 3px 6px;
}

.maquinas-main-grid {
  grid-template-columns: 80px minmax(260px, 1fr) 70px 80px 90px;
}

.maquinas-pliego-grid,
.maquinas-rangos-grid,
.maquinas-tecnicos-grid {
  grid-template-columns: repeat(7, minmax(80px, 1fr));
}

.maquinas-flags-grid,
.maquinas-divisiones-grid {
  grid-template-columns: repeat(6, minmax(90px, 1fr));
}

.maquinas-valores-table,
.maquinas-usage-table {
  margin-top: 0;
  overflow-x: auto;
}

.maquinas-valores-table table {
  min-width: 0;
  table-layout: fixed;
  width: 100%;
}

.maquinas-valores-table th,
.maquinas-valores-table td {
  text-align: center;
}

.maquinas-valores-table th:first-child,
.maquinas-valores-table td:first-child {
  text-align: left;
  width: 82px;
}

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

.maquinas-summary-strip {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 8px;
}

.maquinas-summary-strip span {
  background: #f8fafb;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: #002a70;
  font-size: 11px;
  font-weight: 800;
  padding: 5px 7px;
}

.maquinas-summary-strip strong {
  color: var(--text);
  display: block;
  font-size: 12px;
  font-weight: 700;
  margin-top: 2px;
}

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

.maquinas-pagination > span,
.maquinas-pagination strong {
  color: #415066;
  font-size: 12px;
}

.maquinas-pagination > div {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: flex-end;
}

.productos-window {
  max-width: 1024px;
}

.productos-filter {
  gap: 6px;
  justify-content: flex-start;
}

.productos-filter .text-input {
  min-width: 360px;
}

.productos-filter select {
  min-width: 120px;
}

.productos-table table {
  min-width: 980px;
}

.productos-table th:nth-child(1),
.productos-table td:nth-child(1) {
  width: 72px;
}

.productos-table th:nth-child(2),
.productos-table td:nth-child(2) {
  width: 240px;
}

.productos-table th:nth-child(3),
.productos-table td:nth-child(3),
.productos-table th:nth-child(7),
.productos-table td:nth-child(7),
.productos-table th:nth-child(8),
.productos-table td:nth-child(8),
.productos-table th:nth-child(11),
.productos-table td:nth-child(11) {
  text-align: center;
  width: 64px;
}

.productos-table th:nth-child(4),
.productos-table td:nth-child(4),
.productos-table th:nth-child(5),
.productos-table td:nth-child(5),
.productos-table th:nth-child(6),
.productos-table td:nth-child(6),
.productos-table th:nth-child(9),
.productos-table td:nth-child(9),
.productos-table th:nth-child(10),
.productos-table td:nth-child(10) {
  width: 100px;
}

.productos-pagination {
  margin-top: 10px;
}

.productos-detail-toolbar {
  gap: 4px;
  justify-content: flex-start;
  margin-bottom: 6px;
}

.productos-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  margin-bottom: 8px;
  padding: 7px;
}

.productos-card h2 {
  color: #002a70;
  font-size: 12px;
  margin: 0 0 6px;
}

.productos-field-grid {
  display: grid;
  gap: 6px;
}

.productos-field-grid label {
  display: grid;
  gap: 3px;
}

.productos-field-grid span {
  color: #002a70;
  font-size: 10px;
  font-weight: 800;
}

.productos-main-grid {
  grid-template-columns: 80px minmax(220px, 1fr) 72px 120px;
}

.productos-main-grid .wide {
  grid-column: span 2;
}

.productos-production-grid {
  grid-template-columns: repeat(6, minmax(90px, 1fr));
}

.productos-two-columns {
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.productos-sub-table table,
.productos-pliegos-table table {
  min-width: 720px;
}

.productos-sub-table th,
.productos-sub-table td,
.productos-pliegos-table th,
.productos-pliegos-table td {
  font-size: 10px;
}

.productos-observaciones {
  min-height: 74px;
  resize: vertical;
  width: 100%;
}

.estructura-stock-window {
  max-width: 1024px;
}

.estructura-stock-title {
  align-items: start;
  margin-bottom: 6px;
}

.estructura-stock-title h1 {
  font-size: 16px;
}

.estructura-stock-title .coverage-tool {
  margin-top: 2px;
}

.estructura-stock-board {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 8px;
  grid-template-columns: 24px minmax(0, 1fr) 24px;
  padding: 10px 16px 10px;
  width: 100%;
}

.estructura-stock-block {
  display: grid;
  gap: 2px;
}

.estructura-grupos-block {
  grid-column: 1 / 4;
  margin-left: 26px;
  max-width: none;
}

.estructura-rubros-block {
  grid-column: 1 / 4;
  margin-left: 26px;
  max-width: none;
}

.estructura-materias-block {
  grid-column: 1 / 4;
  margin-left: 26px;
  max-width: none;
}

.estructura-stock-heading {
  align-items: end;
  display: grid;
  gap: 4px;
  grid-template-columns: 1fr auto;
}

.estructura-stock-heading h2 {
  color: #002a70;
  font-size: 12px;
  margin: 0;
}

.estructura-stock-heading p {
  color: #002a70;
  font-size: 10px;
  font-weight: 700;
  grid-column: 1 / 2;
  justify-self: end;
  margin: 0;
  max-width: 340px;
  text-align: center;
}

.estructura-icon-strip {
  align-items: center;
  display: flex;
  gap: 3px;
}

.estructura-icon-strip .client-tool {
  font-size: 9px;
  min-height: 20px;
  min-width: 24px;
  padding: 2px 5px;
}

.estructura-icon-strip .danger {
  color: #b42318;
}

.estructura-grupos-table table,
.estructura-rubros-table table,
.estructura-materias-table table {
  min-width: 0;
  table-layout: fixed;
  width: 100%;
}

.estructura-stock-datatable {
  max-height: none;
  overflow: visible;
}

.estructura-stock-datatable .dt-container {
  border-radius: 6px;
}

.estructura-stock-datatable .dt-layout-row {
  padding: 5px 7px;
}

.estructura-stock-datatable .dt-search input {
  min-height: 26px;
  width: min(260px, 38vw);
}

.estructura-stock-datatable .dt-length select {
  min-height: 26px;
  min-width: 64px;
  padding-bottom: 3px;
  padding-top: 3px;
}

.estructura-stock-datatable .dt-info,
.estructura-stock-datatable .dt-paging button,
.estructura-stock-datatable .dt-length label,
.estructura-stock-datatable .dt-search label {
  font-size: 10px;
}

.estructura-stock-datatable .dt-paging button {
  min-height: 24px;
  padding: 3px 7px;
}

.estructura-grupos-table th,
.estructura-grupos-table td,
.estructura-rubros-table th,
.estructura-rubros-table td,
.estructura-materias-table th,
.estructura-materias-table td {
  font-size: 11px;
  height: 21px;
  padding: 1px 4px;
}

.estructura-scroll-table {
  max-height: 134px;
  overflow: auto;
}

.estructura-scroll-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
}

.estructura-grupos-table th:nth-child(1),
.estructura-grupos-table td:nth-child(1),
.estructura-rubros-table th:nth-child(1),
.estructura-rubros-table td:nth-child(1),
.estructura-materias-table th:nth-child(1),
.estructura-materias-table td:nth-child(1) {
  text-align: center;
  width: 18px;
}

.estructura-grupos-table th:nth-child(2),
.estructura-grupos-table td:nth-child(2),
.estructura-rubros-table th:nth-child(2),
.estructura-rubros-table td:nth-child(2),
.estructura-materias-table th:nth-child(2),
.estructura-materias-table td:nth-child(2) {
  width: 90px;
}

.estructura-grupos-table col:nth-child(1) {
  width: 4% !important;
}

.estructura-grupos-table col:nth-child(2) {
  width: 10% !important;
}

.estructura-grupos-table col:nth-child(3) {
  width: 41% !important;
}

.estructura-grupos-table col:nth-child(4),
.estructura-grupos-table col:nth-child(5),
.estructura-grupos-table col:nth-child(6),
.estructura-grupos-table col:nth-child(7),
.estructura-grupos-table col:nth-child(8) {
  width: 9% !important;
}

.estructura-grupos-table th:nth-child(3),
.estructura-grupos-table td:nth-child(3),
.estructura-rubros-table th:nth-child(3),
.estructura-rubros-table td:nth-child(3),
.estructura-materias-table th:nth-child(3),
.estructura-materias-table td:nth-child(3) {
  min-width: 280px;
}

.estructura-grupos-table th:nth-child(3),
.estructura-grupos-table td:nth-child(3) {
  min-width: 0;
  width: 41%;
}

.estructura-grupos-table th:nth-child(4),
.estructura-grupos-table td:nth-child(4),
.estructura-grupos-table th:nth-child(5),
.estructura-grupos-table td:nth-child(5),
.estructura-grupos-table th:nth-child(6),
.estructura-grupos-table td:nth-child(6),
.estructura-grupos-table th:nth-child(7),
.estructura-grupos-table td:nth-child(7),
.estructura-grupos-table th:nth-child(8),
.estructura-grupos-table td:nth-child(8) {
  text-align: center;
  width: 9%;
}

.estructura-grupos-table .selected-row td,
.estructura-rubros-table .selected-row td {
  background: #e6e6e6;
}

.estructura-unidad-select {
  font-size: 11px;
  height: 19px;
  min-height: 19px;
  padding: 1px 2px;
  text-align: center;
  width: 54px;
}

.estructura-stock-window .grid-input,
.estructura-stock-window select.grid-input {
  font-size: 11px;
  height: 19px;
  min-height: 19px;
  padding: 1px 2px;
}

.estructura-stock-block .empty-row td {
  color: transparent;
}

@media (max-width: 760px) {
  .page {
    padding: 16px;
  }

  .app-footer {
    padding: 12px 14px;
  }

  .app-footer-main {
    gap: 12px;
    grid-template-columns: 1fr;
  }

  .app-footer-quality {
    border-left: 0;
    border-top: 1px solid #d8dde5;
    padding-left: 0;
    padding-top: 8px;
  }

  .app-footer-bottom {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .toolbar,
  .detail-header,
  .client-fox-title {
    align-items: stretch;
    display: grid;
  }

  .filters,
  .detail-grid,
  .form-grid,
  .module-grid,
  .split-tables,
  .np-header-grid,
  .np-summary-strip,
  .np-observation-row,
  .np-reference-strip {
    grid-template-columns: 1fr;
  }

  .np-titlebar {
    align-items: flex-start;
    display: grid;
  }

  .np-summary-strip dl {
    grid-template-columns: repeat(2, auto);
  }

    .np-detail-top-grid,
    .np-detail-client-row,
    .np-detail-fields-grid,
    .np-detail-reference-strip,
    .np-detail-observation-row,
    .np-detail-extra-grid,
    .client-toolbar.np-list-filters,
    .client-audit-strip,
    .client-fox-grid,
    .np-extra-form-grid,
  .ot-top-grid,
  .ot-reference-grid,
  .ot-text-grid,
  .ot-delivery-grid,
  .ot-quick-summary,
  .ot-visual-grid,
  .ot-print-layout,
  .ot-print-mini-grid,
  .ot-stage-grid,
  .ot-copy-grid,
  .ot-process-summary,
  .ot-delivery-summary,
  .ot-preclose-list,
  .ot-coverage-sections,
  .ot-coverage-list,
  .ot-bottom-grid,
  .costos-filter,
  .costos-main-grid,
  .costos-values-grid,
  .costos-ranges-grid,
  .costos-formula-grid,
  .costos-two-columns,
  .costos-summary-strip,
  .costos-usage-pagination,
  .costos-fijos-filter,
  .costos-fijos-form-grid,
  .complejidad-filter,
  .complejidad-form-grid,
  .maquinas-filter,
  .maquinas-fox-panel,
  .maquinas-gen-grid,
  .maquinas-fecha-grid,
  .maquinas-sector-grid,
  .maquinas-pliego-fox-grid,
  .maquinas-pinza-grid,
  .maquinas-fox-filter-card,
  .maquinas-main-grid,
  .maquinas-pliego-grid,
  .maquinas-rangos-grid,
  .maquinas-tecnicos-grid,
  .maquinas-flags-grid,
  .maquinas-divisiones-grid,
  .maquinas-two-columns,
  .maquinas-summary-strip,
  .maquinas-pagination,
  .productos-filter,
  .productos-main-grid,
  .productos-production-grid,
  .productos-two-columns {
    grid-template-columns: 1fr;
  }

  .maquinas-gen-grid .wide,
  .maquinas-pliego-fox-grid .wide,
  .productos-main-grid .wide {
    grid-column: auto;
  }

  .productos-filter .text-input {
    min-width: 0;
  }

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

  .np-detail-fields-grid .wide,
  .np-extra-form-grid .wide,
  .ot-stage-grid .wide,
  .ot-delivery-grid .wide-left {
    grid-column: auto;
    grid-row: auto;
  }

  .ot-delivery-grid {
    grid-template-areas:
      "aviso"
      "direccion"
      "contacto"
      "lugar"
      "flete"
      "motivo";
  }

  .ot-bottom-grid {
    grid-template-areas:
      "side"
      "close"
      "tasks"
      "process"
      "end";
  }

  .np-source-card {
    bottom: 8px;
    left: 8px;
    max-width: calc(100vw - 16px);
    position: sticky;
  }

  .np-pending-card {
    margin: 0 0 10px auto;
    right: auto;
    top: auto;
  }

  .topbar {
    align-items: flex-start;
    height: auto;
    padding: 12px 16px;
  }

  .menu-bar {
    flex-wrap: wrap;
  }

  .fox-header-grid,
  .fox-bottom-grid {
    grid-template-columns: 1fr;
  }
}

/* Sacabocados: reglas finales para evitar que DataTables/dense-table pisen la columna de acciones. */
.table-wrap.sacabocados-table table.sacabocados-datatable-table,
.table-wrap.sacabocados-table table.sacabocados-datatable-table.dataTable {
  min-width: 0;
  table-layout: fixed;
  width: 100%;
}

.table-wrap.sacabocados-table table.sacabocados-datatable-table th:last-child,
.table-wrap.sacabocados-table table.sacabocados-datatable-table td:last-child {
  box-sizing: border-box;
  padding: 4px 5px;
  text-align: center;
  vertical-align: middle;
  width: 132px;
}

.table-wrap.sacabocados-table .sacabocados-row-actions {
  align-items: center;
  box-sizing: border-box;
  display: inline-flex;
  gap: 5px;
  justify-content: center;
  min-height: 34px;
  width: 100%;
}

.table-wrap.sacabocados-table .sacabocados-row-actions .view-action,
.table-wrap.sacabocados-table .sacabocados-row-actions .delete-action {
  align-items: center;
  border-radius: 7px;
  box-sizing: border-box;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 11px;
  font-weight: 700;
  height: 30px;
  justify-content: center;
  line-height: 1;
  margin: 0;
  min-height: 30px;
  padding: 0 7px;
}

.table-wrap.sacabocados-table .sacabocados-row-actions .view-action {
  gap: 4px;
  width: 50px;
}

.table-wrap.sacabocados-table .sacabocados-row-actions .delete-action {
  gap: 4px;
  width: 68px;
}

.table-wrap.sacabocados-table .sacabocados-row-actions .view-action .view-icon,
.table-wrap.sacabocados-table .sacabocados-row-actions .delete-action .delete-icon {
  align-items: center;
  border-radius: 50%;
  display: inline-flex;
  flex: 0 0 15px;
  font-size: 12px;
  font-weight: 900;
  height: 15px;
  justify-content: center;
  line-height: 1;
  width: 15px;
}

.table-wrap.sacabocados-table .sacabocados-row-actions .view-action .view-icon {
  background: #dbeafe;
  color: #0f4f80;
}

.table-wrap.sacabocados-table .sacabocados-row-actions .delete-action .delete-icon {
  border: 1px solid rgb(255 255 255 / 48%);
}


/* Programación OT / Sin programar */
.production-schedule-toolbar,
.production-schedule-summary,
.production-schedule-table,
.production-schedule-notice {
  margin-left: auto;
  margin-right: auto;
  max-width: 1240px;
}

.production-schedule-toolbar {
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 10px 14px;
  margin-bottom: 12px;
}

.production-schedule-toolbar h1 {
  font-size: 23px;
  line-height: 1.1;
}

.production-schedule-toolbar p {
  font-size: 12px;
}

.production-schedule-actions {
  align-items: center;
  gap: 6px;
}

.production-schedule-toolbar .production-schedule-help {
  align-items: center;
  aspect-ratio: 1 / 1;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  color: #0f172a;
  display: inline-flex;
  font-size: 14px;
  font-weight: 900;
  height: 31px;
  justify-content: center;
  line-height: 1;
  min-height: 31px;
  min-width: 31px;
  padding: 0;
  width: 31px;
}

.production-schedule-toolbar .production-schedule-help:hover {
  background: #eef6ff;
  border-color: #9bb9d8;
}

.production-schedule-toolbar .production-schedule-filters {
  flex: 1 1 100%;
  grid-template-columns: minmax(260px, 1fr) minmax(116px, 180px) minmax(96px, 128px) auto;
  max-width: 900px;
}

.production-schedule-toolbar .production-programacion-filters {
  grid-template-columns: minmax(260px, 1fr) minmax(120px, 190px) minmax(116px, 170px) minmax(96px, 128px) auto;
  max-width: 1060px;
}

.production-schedule-summary {
  gap: 8px;
  margin-bottom: 10px;
}

.production-schedule-summary .module-box {
  min-height: 0;
  padding: 10px;
}

.production-schedule-summary .module-box h2 {
  font-size: 13px;
  margin-bottom: 8px;
}

.production-schedule-table {
  overflow: auto;
}

.production-schedule-table table,
.production-schedule-table table.dataTable {
  min-width: 1180px;
}

.production-programacion-table table,
.production-programacion-table table.dataTable {
  min-width: 1540px;
}

.production-schedule-table th,
.production-schedule-table td {
  padding: 5px 6px;
  vertical-align: middle;
}

.production-schedule-table .grid-input {
  font-size: 12px;
  min-height: 25px;
  padding: 3px 5px;
}

.production-schedule-table .text-input {
  min-width: 0;
}

.production-schedule-table small {
  color: var(--muted);
  display: block;
  font-size: 10px;
  line-height: 1.2;
  margin-top: 2px;
}

.production-schedule-table .select-cell {
  text-align: center;
}

.bulk-item-checkbox {
  cursor: pointer;
  height: 15px;
  margin: 0;
  width: 15px;
}

.schedule-row-actions {
  align-items: center;
  display: grid;
  gap: 4px;
  grid-template-columns: 1fr;
  justify-items: stretch;
}

.schedule-row-actions .compact-action {
  align-items: center;
  display: inline-flex;
  font-size: 11px;
  justify-content: center;
  min-height: 24px;
  min-width: 0;
  padding: 3px 6px;
  width: 100%;
}

.production-schedule-table .actions-cell {
  text-align: center;
}

.production-schedule-table .dt-container {
  width: 100%;
}

@media (max-width: 900px) {
  .production-schedule-toolbar .production-schedule-filters,
  .production-schedule-toolbar .production-programacion-filters {
    grid-template-columns: 1fr;
    max-width: none;
  }
}

/* Planeamiento Producción: aproximación funcional al panel Fox con estilo web Aramis. */

.planning-window {
  display: grid;
  gap: 10px;
  max-width: 1024px;
  width: min(1024px, 100%);
}

.planning-window .planning-header-toolbar,
.planning-window .planning-filter-panel,
.planning-window .planning-summary-strip,
.planning-window .planning-workbench,
.planning-window .production-schedule-toolbar,
.planning-window .production-schedule-summary,
.planning-window .production-schedule-table {
  max-width: 100%;
  width: 100%;
}

.planning-window .planning-header-toolbar,
.planning-window .planning-filter-panel,
.planning-window .planning-summary-strip {
  margin-bottom: 0;
}

.planning-header-toolbar,
.planning-filter-panel,
.planning-summary-strip,
.planning-workbench {
  margin-left: auto;
  margin-right: auto;
  max-width: 1180px;
}

.planning-filter-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: 0 8px 20px rgb(15 23 42 / 5%);
  display: grid;
  gap: 9px;
  margin-bottom: 10px;
  padding: 10px;
}

.planning-filter-grid {
  align-items: end;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(110px, 0.8fr) minmax(170px, 1.25fr) minmax(150px, 1fr) minmax(92px, 0.7fr) minmax(70px, 0.45fr);
}

.planning-filter-grid label,
.planning-options-row label {
  display: grid;
  gap: 3px;
}

.planning-filter-grid span,
.planning-radio-group legend,
.planning-check span {
  color: #143585;
  font-size: 12px;
  font-weight: 800;
}

.planning-filter-grid input,
.planning-filter-grid select {
  border: 1px solid #b7c5d5;
  border-radius: 5px;
  font-size: 12px;
  min-height: 30px;
  padding: 4px 7px;
  width: 100%;
}

.planning-filter-grid input:disabled,
.planning-filter-grid select:disabled {
  background: #eef2f7;
  color: #7b8797;
  cursor: not-allowed;
}

.planning-filter-grid .wide-search {
  grid-column: span 2;
}

.planning-options-row {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
}

.planning-check {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #d7e0ea;
  border-radius: 8px;
  display: inline-flex !important;
  gap: 6px !important;
  min-height: 32px;
  padding: 5px 9px;
}

.planning-radio-group {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #d7e0ea;
  border-radius: 8px;
  display: inline-flex;
  gap: 7px;
  margin: 0;
  min-height: 32px;
  padding: 4px 8px;
}

.planning-radio-group legend {
  margin-right: 2px;
  padding: 0;
}

.planning-radio-group label {
  align-items: center;
  color: #263449;
  display: inline-flex;
  font-size: 12px;
  gap: 3px;
}

.planning-filter-actions {
  align-items: center;
  display: inline-flex;
  gap: 6px;
  margin-left: auto;
}

.planning-filter-actions .secondary-button,
.production-selection-actions .secondary-button {
  background: #eef2f7;
  border-color: #cbd5e1;
  color: #233044;
}

.planning-summary-strip {
  display: flex;
  gap: 6px;
  margin-bottom: 10px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.planning-summary-card {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  display: grid;
  flex: 0 0 210px;
  gap: 2px;
  min-height: 54px;
  padding: 7px 9px;
}

.planning-summary-card strong {
  color: #0f2f6b;
  font-size: 12px;
}

.planning-summary-card span {
  color: #263449;
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.planning-summary-card em {
  color: #334155;
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
}

.planning-workbench {
  align-items: start;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) 128px;
}

.planning-grid-panel,
.planning-side-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 9px;
  box-shadow: 0 8px 20px rgb(15 23 42 / 5%);
}

.planning-grid-panel {
  min-width: 0;
  overflow: hidden;
}

.planning-alert {
  border-bottom: 1px solid #d7e0ea;
  color: #b42318;
  font-size: 13px;
  font-weight: 800;
  padding: 7px 10px;
  text-align: center;
}

.planning-table-wrap {
  border: 0;
  border-radius: 0;
  box-shadow: none;
  margin: 0;
  max-height: 520px;
  overflow: auto;
}

.production-programacion-table .planning-table-wrap table,
.production-programacion-table .planning-table-wrap table.dataTable {
  min-width: 1160px;
  table-layout: fixed;
  width: 100%;
}

.planning-table-wrap th,
.planning-table-wrap td {
  font-size: 11px;
  height: 30px;
  padding: 3px 4px;
  white-space: nowrap;
}

.planning-table-wrap th {
  background: #dfeaf3;
  color: #12376f;
  font-weight: 900;
}

.planning-table-wrap .grid-input {
  border-color: #b7c5d5;
  border-radius: 4px;
  font-size: 11px;
  min-height: 23px;
  padding: 2px 4px;
  width: 100%;
}

.planning-table-wrap .tiny-input {
  min-width: 36px;
}

.planning-table-wrap .number-input,
.planning-table-wrap .date-input,
.planning-table-wrap .code-input {
  min-width: 0;
}

.planning-table-wrap .process-input,
.planning-table-wrap .text-input {
  min-width: 0;
}

.planning-table-wrap .pending-map {
  color: #94a3b8;
  font-weight: 900;
  text-align: center;
}

.planning-table-wrap .actions-cell {
  padding: 3px 4px;
}

.planning-table-wrap .schedule-row-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.planning-table-wrap .schedule-row-actions .compact-action {
  min-height: 24px;
  padding: 2px 4px;
}

.planning-side-panel {
  display: grid;
  gap: 8px;
  padding: 8px;
}

.planning-side-panel h2 {
  color: #12376f;
  font-size: 13px;
  margin: 0;
}

.planning-side-panel dl {
  display: grid;
  gap: 4px 6px;
  grid-template-columns: 1fr auto;
  margin: 0;
}

.planning-side-panel dt {
  color: #1f2937;
  font-size: 12px;
  font-weight: 800;
}

.planning-side-panel dd {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 50%;
  color: #12376f;
  font-size: 11px;
  font-weight: 900;
  height: 20px;
  line-height: 18px;
  margin: 0;
  text-align: center;
  width: 20px;
}

.planning-confirm-box {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  display: grid;
  gap: 3px;
  padding: 7px;
}

.planning-confirm-box strong {
  color: #12376f;
  font-size: 12px;
}

.planning-confirm-box span {
  color: #475569;
  font-size: 11px;
}

.production-selection-actions {
  flex-wrap: wrap;
}

.production-schedule-table .dt-search input {
  min-width: 260px;
}

@media (max-width: 1050px) {
  .planning-filter-grid {
    grid-template-columns: repeat(3, minmax(130px, 1fr));
  }

  .planning-filter-grid .wide-search {
    grid-column: span 3;
  }

  .planning-workbench {
    grid-template-columns: 1fr;
  }

  .planning-side-panel {
    grid-template-columns: auto 1fr;
  }

  .planning-side-panel dl {
    grid-template-columns: repeat(4, auto auto);
  }
}

@media (max-width: 720px) {
  .planning-filter-grid,
  .planning-filter-grid .wide-search {
    grid-template-columns: 1fr;
    grid-column: auto;
  }

  .planning-radio-group,
  .planning-check,
  .planning-filter-actions {
    width: 100%;
  }
}

/* Planeamiento Producción vtr20 */
.planning-origin-badge {
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
  border-radius: 999px;
  color: #047857;
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  margin-left: 8px;
  padding: 2px 7px;
}

.planning-process-cell {
  align-items: center;
  display: grid;
  gap: 3px;
  grid-template-columns: auto minmax(0, 1fr);
}

.planning-process-cell small {
  background: #eef2ff;
  border: 1px solid #c7d2fe;
  border-radius: 5px;
  color: #1e3a8a;
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  padding: 4px 5px;
}

.planning-table-wrap .prio-input {
  font-weight: 900;
  text-align: right;
}

.planning-table-wrap tr.vtr20-row td:first-child {
  border-left: 3px solid #0f766e;
}

.planning-table-wrap tr.vtr28-fallback-row td:first-child {
  border-left: 3px solid #f59e0b;
}

.planning-table-wrap .grid-input:disabled {
  background: #f8fafc;
  color: #64748b;
}

/* Planeamiento: lupa real de proveedor equivalente a Fox (co05 -> TARPROV). */
.planning-provider-filter,
.planning-ot-filter {
  min-width: 0;
}

.planning-lookup-field {
  align-items: center;
  display: grid;
  gap: 4px;
  grid-template-columns: minmax(0, 1fr) 30px;
}

.planning-lookup-field input {
  min-width: 0;
}

.planning-lookup-button {
  align-items: center;
  border-radius: 6px;
  display: inline-flex;
  height: 30px;
  justify-content: center;
  min-height: 30px;
  padding: 0;
  width: 30px;
}

.planning-selected-name {
  color: #475569;
  display: block;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.15;
  max-width: 100%;
  min-height: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.planning-provider-dialog {
  max-width: 860px;
}

.planning-provider-picker-table th:nth-child(1),
.planning-provider-picker-table td:nth-child(1) {
  width: 82px;
}

.planning-provider-picker-table th:nth-child(4),
.planning-provider-picker-table td:nth-child(4) {
  width: 120px;
}

.planning-provider-picker-table th:nth-child(5),
.planning-provider-picker-table td:nth-child(5) {
  text-align: center;
  width: 92px;
}


/* Planeamiento: lupa real de Orden Trabajo equivalente a Fox (vtr28/vtr20.TAROT). */
.planning-ot-dialog {
  max-width: 920px;
}

.planning-ot-picker-table th:nth-child(1),
.planning-ot-picker-table td:nth-child(1) {
  width: 92px;
}

.planning-ot-picker-table th:nth-child(4),
.planning-ot-picker-table td:nth-child(4) {
  width: 92px;
}

.planning-ot-picker-table th:nth-child(5),
.planning-ot-picker-table td:nth-child(5) {
  text-align: center;
  width: 92px;
}

/* Planeamiento: encuadre 1024 limpio + preparación fuera del ancho principal. */
.planning-window {
  justify-items: start;
  margin-left: auto;
  margin-right: auto;
  max-width: 1024px;
  overflow: visible;
  width: min(1024px, 100%);
}

.planning-window .gridstack-generated-layout,
.planning-window .grid-stack {
  overflow: visible;
  width: 100%;
}

.planning-window .grid-stack-item[gs-id^="planning-filters-"] > .grid-stack-item-content,
.planning-window .grid-stack-item[gs-id^="planning-workbench-"] > .grid-stack-item-content,
.planning-window .grid-stack-item[gs-id^="planning-workbench-"] .gridstack-card {
  overflow: visible !important;
}

.planning-filter-panel {
  overflow: visible;
}

.planning-filter-grid {
  align-items: end;
  display: grid;
  gap: 7px 8px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.planning-filter-grid > label {
  min-width: 0;
}

.planning-filter-grid .filter-sector { grid-column: span 2; }
.planning-filter-grid .filter-proceso { grid-column: span 4; }
.planning-filter-grid .filter-maquina { grid-column: span 3; }
.planning-filter-grid .filter-ot { grid-column: span 2; }
.planning-filter-grid .filter-pliego { grid-column: span 1; }
.planning-filter-grid .filter-proveedor { grid-column: span 2; }
.planning-filter-grid .filter-cliente { grid-column: span 3; }
.planning-filter-grid .filter-fecha-desde { grid-column: span 3; }
.planning-filter-grid .filter-fecha-hasta { grid-column: span 3; }
.planning-filter-grid .filter-busqueda { grid-column: span 6; }

.planning-filter-grid input,
.planning-filter-grid select {
  box-sizing: border-box;
  min-width: 0;
}

.planning-options-row {
  align-items: end;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.planning-options-row .planning-check {
  grid-column: span 2;
  justify-content: start;
  width: 100%;
}

.planning-options-row .planning-radio-group {
  align-items: center;
  display: flex;
  grid-column: span 3;
  min-width: 0;
  padding-top: 12px;
  position: relative;
}

.planning-options-row .planning-radio-group legend {
  background: var(--panel);
  left: 8px;
  line-height: 1;
  padding: 0 4px;
  position: absolute;
  top: -6px;
}

.planning-options-row .planning-radio-group label {
  white-space: nowrap;
}

.planning-options-row .planning-filter-actions {
  grid-column: 10 / 13;
  justify-content: end;
  margin-left: 0;
  width: 100%;
}

.planning-workbench {
  display: block;
  max-width: 1024px;
  overflow: visible;
  position: relative;
  width: 100%;
}

.planning-workbench .planning-grid-panel {
  max-width: 1024px;
  width: 100%;
}

.planning-workbench .planning-side-panel {
  left: calc(100% + 10px);
  position: absolute;
  top: 0;
  width: 128px;
  z-index: 6;
}

.planning-table-wrap {
  max-width: 100%;
}

@media (max-width: 900px) {
  .planning-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .planning-filter-grid .filter-sector,
  .planning-filter-grid .filter-proceso,
  .planning-filter-grid .filter-maquina,
  .planning-filter-grid .filter-ot,
  .planning-filter-grid .filter-pliego,
  .planning-filter-grid .filter-proveedor,
  .planning-filter-grid .filter-cliente,
  .planning-filter-grid .filter-fecha-desde,
  .planning-filter-grid .filter-fecha-hasta,
  .planning-filter-grid .filter-busqueda {
    grid-column: span 2;
  }

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

  .planning-options-row .planning-check,
  .planning-options-row .planning-radio-group,
  .planning-options-row .planning-filter-actions {
    grid-column: auto;
  }

  .planning-workbench .planning-side-panel {
    margin-top: 8px;
    position: static;
    width: 100%;
  }
}


/* Planeamiento: ajuste compacto + paginación server-side. */
.planning-summary-strip {
  gap: 5px;
  margin-bottom: 8px;
  max-height: 64px;
  padding-bottom: 0;
}

.planning-summary-card {
  flex: 0 0 168px;
  gap: 1px;
  min-height: 46px;
  padding: 6px 8px;
}

.planning-summary-card strong {
  font-size: 11px;
  line-height: 1.15;
}

.planning-summary-card span,
.planning-summary-card em {
  font-size: 10px;
  line-height: 1.18;
}

.planning-table-wrap tr.vtr20-row td:first-child,
.planning-table-wrap tr.vtr28-fallback-row td:first-child {
  border-left: 0 !important;
}

.planning-datatable .dt-processing,
.planning-table-wrap .dt-processing {
  border-radius: 8px;
  font-size: 12px;
  font-weight: 800;
  padding: 8px 12px;
}

.planning-summary-strip {
  scrollbar-color: #cbd5e1 transparent;
  scrollbar-width: thin;
}

.planning-summary-strip::-webkit-scrollbar {
  height: 4px;
}

.planning-summary-strip::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 999px;
}

/* Planeamiento: correcciones de encuadre, resumen y fallback server-side. */
.planning-filter-grid {
  align-items: start;
}

.planning-filter-grid > label {
  align-content: start;
  grid-template-rows: 14px 30px 13px;
  min-height: 59px;
}

.planning-filter-grid > label:not(.planning-provider-filter):not(.planning-ot-filter)::after {
  content: "";
  display: block;
  min-height: 12px;
}

.planning-lookup-field,
.planning-filter-grid input,
.planning-filter-grid select {
  min-height: 30px;
}

.planning-selected-name {
  min-height: 13px;
}

.planning-summary-strip {
  max-height: 58px;
  min-height: 54px;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0;
  scrollbar-width: none;
}

.planning-summary-strip::-webkit-scrollbar {
  height: 0;
  width: 0;
}

.planning-summary-card {
  flex: 0 0 160px;
  min-height: 44px;
  padding: 5px 8px;
}

.planning-summary-card em {
  max-height: 24px;
  overflow: hidden;
}

.aramis-datatable-server-fallback .dt-layout-table {
  overflow: visible;
}

.aramis-datatable-server-fallback .empty {
  color: #475569;
  font-weight: 800;
  padding: 16px 10px;
  text-align: left;
}


/* Planeamiento: barra horizontal visible sin tapar el contenido de las burbujas. */
.planning-summary-strip {
  align-items: flex-start;
  max-height: 74px;
  min-height: 66px;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 12px;
  scrollbar-color: #cbd5e1 transparent;
  scrollbar-width: thin;
}

.planning-summary-strip::-webkit-scrollbar {
  height: 7px;
  width: 7px;
}

.planning-summary-strip::-webkit-scrollbar-track {
  background: transparent;
}

.planning-summary-strip::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 999px;
}

.planning-summary-card {
  min-height: 44px;
}

/* Planeamiento: resumen por máquinas con navegación por botones, sin quitar scroll del DataTable. */
.planning-window .planning-summary-carousel {
  align-items: center;
  display: grid;
  gap: 0;
  grid-template-columns: 24px minmax(0, 1fr) 24px;
  margin-bottom: 8px;
  max-width: 100%;
  min-height: 62px;
  position: relative;
  width: 100%;
}

.planning-summary-carousel .planning-summary-strip {
  align-items: flex-start;
  display: flex;
  gap: 6px;
  margin: 0;
  max-height: 62px;
  min-height: 58px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 0 2px 0;
  scroll-behavior: smooth;
  scrollbar-width: none;
  width: 100%;
}

.planning-summary-carousel .planning-summary-strip::-webkit-scrollbar {
  height: 0;
  width: 0;
}

.planning-summary-carousel .planning-summary-card {
  flex: 0 0 160px;
  min-height: 48px;
}

.planning-summary-nav {
  align-items: center;
  align-self: stretch;
  background: rgb(15 118 110 / 16%);
  border: 1px solid rgb(15 118 110 / 22%);
  border-radius: 8px;
  color: #0f766e;
  cursor: pointer;
  display: inline-flex;
  font-size: 20px;
  font-weight: 900;
  justify-content: center;
  min-height: 50px;
  opacity: .78;
  padding: 0;
  transition: background .15s ease, opacity .15s ease, transform .15s ease;
  width: 22px;
  z-index: 2;
}

.planning-summary-nav:hover:not(:disabled) {
  background: rgb(15 118 110 / 24%);
  opacity: 1;
  transform: translateY(-1px);
}

.planning-summary-nav:disabled {
  cursor: default;
  opacity: .22;
}

.planning-summary-nav-prev {
  margin-right: 3px;
}

.planning-summary-nav-next {
  margin-left: 3px;
}

@media (max-width: 900px) {
  .planning-window .planning-summary-carousel {
    grid-template-columns: 22px minmax(0, 1fr) 22px;
  }

  .planning-summary-carousel .planning-summary-card {
    flex-basis: 150px;
  }
}

/* Planeamiento: la navegación por botones solo reemplaza la barra del resumen.
   La grilla/DataTable mantiene su barra horizontal visible para columnas anchas. */
.planning-table-wrap .aramis-datatable-server-fallback,
.planning-table-wrap .dt-container {
  max-width: 100%;
  min-width: 0;
}

.planning-table-wrap .aramis-datatable-server-fallback .dt-layout-table,
.planning-table-wrap .dt-layout-table,
.planning-table-wrap .dt-scroll-body {
  max-width: 100%;
  overflow-x: auto !important;
  overflow-y: hidden;
  padding-bottom: 8px;
  scrollbar-color: #94a3b8 #edf2f7;
  scrollbar-width: thin;
}

.planning-table-wrap .aramis-datatable-server-fallback .dt-layout-table::-webkit-scrollbar,
.planning-table-wrap .dt-layout-table::-webkit-scrollbar,
.planning-table-wrap .dt-scroll-body::-webkit-scrollbar {
  height: 9px;
}

.planning-table-wrap .aramis-datatable-server-fallback .dt-layout-table::-webkit-scrollbar-track,
.planning-table-wrap .dt-layout-table::-webkit-scrollbar-track,
.planning-table-wrap .dt-scroll-body::-webkit-scrollbar-track {
  background: #edf2f7;
  border-radius: 999px;
}

.planning-table-wrap .aramis-datatable-server-fallback .dt-layout-table::-webkit-scrollbar-thumb,
.planning-table-wrap .dt-layout-table::-webkit-scrollbar-thumb,
.planning-table-wrap .dt-scroll-body::-webkit-scrollbar-thumb {
  background: #94a3b8;
  border-radius: 999px;
}

.planning-table-wrap .aramis-datatable-server-fallback .dt-layout-table table,
.planning-table-wrap .dt-layout-table table,
.planning-table-wrap .dt-scroll-body table {
  min-width: 1460px;
}

/* Planeamiento: panel Preparacion actualizado al seleccionar fila. */
.planning-workbench .planning-side-panel {
  width: 180px;
}

.planning-side-panel[data-planning-preparation-panel] {
  align-content: start;
  gap: 7px;
}

.planning-prep-empty {
  color: #475569;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.35;
  margin: 0;
}

.planning-prep-content {
  display: grid;
  gap: 7px;
}

.planning-prep-context {
  border-bottom: 1px solid #d8e2ec;
  display: grid;
  gap: 3px;
  padding-bottom: 6px;
}

.planning-prep-context strong {
  color: #0f2f6b;
  font-size: 12px;
  font-weight: 900;
}

.planning-prep-context span {
  color: #334155;
  font-size: 11px;
  line-height: 1.25;
}

.planning-prep-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
}

.planning-prep-badges span {
  background: #eef6ff;
  border: 1px solid #c7d9ee;
  border-radius: 999px;
  color: #12376f;
  font-size: 10px;
  font-weight: 800;
  padding: 1px 5px;
}

.planning-side-panel .planning-prep-checks {
  display: grid;
  gap: 3px;
  grid-template-columns: 1fr;
  margin: 0;
}

.planning-side-panel .planning-prep-checks dt {
  color: #0f172a;
  font-size: 11px;
  font-weight: 900;
  line-height: 1.15;
  margin-top: 2px;
}

.planning-side-panel .planning-prep-checks dd {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #1e293b;
  display: flex;
  gap: 5px;
  height: auto;
  justify-content: flex-start;
  line-height: 1.2;
  margin: 0;
  min-height: 24px;
  padding: 4px 5px;
  text-align: left;
  width: auto;
}

.planning-prep-mark {
  border-radius: 999px;
  flex: 0 0 auto;
  font-size: 9px;
  font-weight: 900;
  min-width: 29px;
  padding: 2px 4px;
  text-align: center;
}

.planning-prep-status strong {
  color: inherit;
  font-size: 10px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
}

.planning-prep-status.status-ok {
  background: #ecfdf3;
  border-color: #b7e4c7;
  color: #14532d;
}

.planning-prep-status.status-ok .planning-prep-mark {
  background: #dcfce7;
  color: #166534;
}

.planning-prep-status.status-warn,
.planning-confirm-box.status-warn {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a3412;
}

.planning-prep-status.status-warn .planning-prep-mark {
  background: #ffedd5;
  color: #9a3412;
}

.planning-prep-status.status-neutral {
  background: #f8fafc;
  border-color: #d7e0ea;
  color: #475569;
}

.planning-prep-status.status-neutral .planning-prep-mark,
.planning-prep-status.status-unknown .planning-prep-mark {
  background: #e2e8f0;
  color: #334155;
}

.planning-confirm-box.status-ok {
  background: #ecfdf3;
  border-color: #b7e4c7;
  color: #14532d;
}

.planning-confirm-box[data-planning-confirm-box] span {
  color: inherit;
  font-size: 11px;
  font-weight: 800;
}

.planning-datatable tbody tr.is-selected > td {
  background: #eef6ff !important;
}

.planning-selected-detail {
  background: #fff;
  border-top: 1px solid #d8e2ec;
  display: grid;
  gap: 5px;
  padding: 8px 10px;
}

.planning-selected-detail div {
  display: grid;
  gap: 2px;
}

.planning-selected-detail strong {
  color: #b42318;
  font-size: 13px;
  font-weight: 900;
}

.planning-selected-detail span,
.planning-selected-detail p,
.planning-selected-detail li {
  color: #334155;
  font-size: 12px;
  line-height: 1.3;
}

.planning-selected-detail p {
  background: #f8fafc;
  border: 1px solid #d8e2ec;
  border-radius: 6px;
  color: #0f172a;
  font-weight: 800;
  margin: 0;
  padding: 6px 8px;
}

.planning-selected-detail ul {
  display: grid;
  gap: 3px;
  margin: 0;
  padding-left: 18px;
}

.planning-selected-detail .compact-action {
  justify-self: start;
}

@media (max-width: 900px) {
  .planning-workbench .planning-side-panel {
    width: 100%;
  }
}


/* Planeamiento: controles Estado/Muestra consistentes entre Firefox y Chrome. */
.planning-options-row .planning-check,
.planning-options-row .planning-radio-group {
  align-items: center;
}

.planning-check input[type="checkbox"],
.planning-radio-group input[type="radio"] {
  -webkit-appearance: none;
  appearance: none;
  background: #ffffff;
  border: 1px solid #93a4bd;
  box-sizing: border-box;
  cursor: pointer;
  display: inline-grid;
  flex: 0 0 auto;
  height: 14px;
  margin: 0;
  place-content: center;
  vertical-align: middle;
  width: 14px;
}

.planning-radio-group input[type="radio"] {
  border-radius: 999px;
}

.planning-check input[type="checkbox"] {
  border-radius: 3px;
}

.planning-radio-group input[type="radio"]::before {
  background: #0d6efd;
  border-radius: 999px;
  content: "";
  height: 7px;
  transform: scale(0);
  transition: transform .08s ease-in-out;
  width: 7px;
}

.planning-radio-group input[type="radio"]:checked {
  border-color: #0d6efd;
}

.planning-radio-group input[type="radio"]:checked::before {
  transform: scale(1);
}

.planning-check input[type="checkbox"]::before {
  color: #ffffff;
  content: "✓";
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  transform: scale(0);
}

.planning-check input[type="checkbox"]:checked {
  background: #0d6efd;
  border-color: #0d6efd;
}

.planning-check input[type="checkbox"]:checked::before {
  transform: scale(1);
}

.planning-radio-group input[type="radio"]:focus-visible,
.planning-check input[type="checkbox"]:focus-visible {
  outline: 2px solid rgb(13 110 253 / 35%);
  outline-offset: 2px;
}

.planning-radio-group label,
.planning-check {
  line-height: 1.1;
}

/* Planeamiento: modal ? con estado coloreado y checklist real. */
.planning-coverage-status {
  margin-top: 12px;
}

.planning-coverage-status li {
  min-height: 68px;
}

.coverage-chip {
  border-radius: 999px;
  display: inline-block;
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  margin-right: 4px;
  padding: 3px 6px;
  vertical-align: middle;
  white-space: nowrap;
}

.coverage-chip.ok {
  background: #dcfce7;
  border: 1px solid #86efac;
  color: #166534;
}

.coverage-chip.warn {
  background: #ffedd5;
  border: 1px solid #fdba74;
  color: #9a3412;
}

.coverage-chip.block {
  background: #fee2e2;
  border: 1px solid #fca5a5;
  color: #991b1b;
}

.ot-coverage-sections .coverage-tested {
  background: #f0fdf4;
  border-color: #bbf7d0;
}

.ot-coverage-sections .coverage-pending {
  background: #fff7ed;
  border-color: #fed7aa;
}

.ot-coverage-sections .coverage-blockers {
  background: #fef2f2;
  border-color: #fecaca;
}

@media (max-width: 900px) {
  .planning-coverage-status {
    grid-template-columns: 1fr;
  }
}


/* Planeamiento: radio/checkbox compactos y nativos, sin ovalos grandes entre navegadores. */
.planning-options-row .planning-check,
.planning-options-row .planning-radio-group {
  align-items: center !important;
  min-height: 46px;
}

.planning-options-row .planning-radio-group {
  column-gap: 12px;
  row-gap: 4px;
  padding: 12px 12px 8px;
}

.planning-options-row .planning-radio-group label,
.planning-options-row .planning-check {
  align-items: center;
  display: inline-flex;
  gap: 5px;
  line-height: 1.15;
  min-width: 0;
}

.planning-radio-group input[type="radio"],
.planning-check input[type="checkbox"] {
  -webkit-appearance: auto !important;
  appearance: auto !important;
  accent-color: #0d6efd;
  background: initial !important;
  border: initial !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  cursor: pointer;
  display: inline-block !important;
  flex: 0 0 auto !important;
  height: 13px !important;
  margin: 0 !important;
  max-height: 13px !important;
  max-width: 13px !important;
  min-height: 13px !important;
  min-width: 13px !important;
  padding: 0 !important;
  vertical-align: -2px;
  width: 13px !important;
}

.planning-radio-group input[type="radio"]::before,
.planning-check input[type="checkbox"]::before {
  content: none !important;
  display: none !important;
}

.planning-radio-group input[type="radio"]:focus-visible,
.planning-check input[type="checkbox"]:focus-visible {
  outline: 2px solid rgb(13 110 253 / 28%);
  outline-offset: 2px;
}

/* Planeamiento: evitar que la grilla/detalle pisen el footer cuando GridStack fija alturas. */
.planning-window {
  margin-bottom: 120px;
  padding-bottom: 24px;
}

.planning-window .grid-stack,
.planning-window .gridstack-generated-layout {
  min-height: 880px;
}

.planning-workbench {
  min-height: 540px;
  padding-bottom: 18px;
}

.planning-workbench .planning-grid-panel {
  padding-bottom: 12px;
}

.planning-selected-detail {
  margin-bottom: 18px;
}

@media (max-width: 900px) {
  .planning-window .grid-stack,
  .planning-window .gridstack-generated-layout {
    min-height: auto;
  }

  .planning-window {
    margin-bottom: 36px;
  }
}

/* Planeamiento: botón Fox Agregar y Editar + modal funcional. */
.planning-alert-with-action {
  align-items: center;
  display: flex;
  gap: 8px;
  justify-content: center;
  min-height: 34px;
  padding: 5px 8px;
  position: relative;
}

.planning-alert-with-action > span {
  flex: 1 1 auto;
  min-width: 0;
  text-align: center;
}

.planning-add-edit-button {
  background: #eef2ff;
  border: 1px solid #9db3d6;
  color: #143585;
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 900;
  min-height: 26px;
  padding: 3px 8px;
}

.planning-add-edit-button:hover {
  background: #dfeaff;
}

.planning-editor-dialog {
  max-width: 760px;
  width: min(760px, calc(100vw - 32px));
}

.planning-editor-form {
  display: grid;
  gap: 10px;
}

.planning-editor-grid {
  align-items: end;
  display: grid;
  gap: 8px 10px;
  grid-template-columns: 90px 58px minmax(220px, 1fr) 130px;
}

.planning-editor-grid label {
  display: grid;
  gap: 4px;
  margin: 0;
}

.planning-editor-grid label > span,
.planning-editor-combo strong {
  color: #143585;
  font-size: 12px;
  font-weight: 900;
}

.planning-editor-grid input,
.planning-editor-grid select,
.planning-editor-grid textarea {
  border: 1px solid #b7c5d5;
  border-radius: 5px;
  font-size: 12px;
  min-height: 30px;
  padding: 4px 7px;
  width: 100%;
}

.planning-editor-process {
  grid-column: span 2;
}

.planning-editor-obs {
  grid-column: 1 / -1;
}

.planning-editor-confirm {
  align-self: stretch;
}

.planning-editor-check {
  justify-content: start;
  min-height: 30px;
}

.planning-editor-combo {
  background: #f8fafc;
  border: 1px solid #d7e0ea;
  border-radius: 8px;
  display: grid;
  gap: 6px;
  padding: 8px;
}

.planning-editor-combo > div:first-child {
  align-items: baseline;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.planning-editor-combo > div:first-child span {
  color: #475569;
  font-size: 12px;
  font-weight: 700;
}

.planning-editor-combo-table {
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  max-height: 120px;
  overflow: auto;
}

.planning-editor-combo-table table {
  border-collapse: collapse;
  font-size: 12px;
  width: 100%;
}

.planning-editor-combo-table th,
.planning-editor-combo-table td {
  border-bottom: 1px solid #dbe3ee;
  padding: 5px 7px;
  text-align: left;
}

.planning-editor-combo-table th {
  background: #dfeaf3;
  color: #12376f;
  font-weight: 900;
}

.planning-editor-actions {
  align-items: center;
  justify-content: flex-end;
}

@media (max-width: 760px) {
  .planning-editor-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .planning-editor-process,
  .planning-editor-obs {
    grid-column: 1 / -1;
  }

  .planning-alert-with-action {
    flex-wrap: wrap;
  }

  .planning-add-edit-button {
    width: 100%;
  }
}

/* Planeamiento: resumen de máquinas seleccionable y modo MySQL definitivo. */
.planning-summary-carousel button.planning-summary-card {
  appearance: none;
  background: #f8fbff;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
}

.planning-summary-carousel button.planning-summary-card:hover,
.planning-summary-carousel button.planning-summary-card:focus-visible {
  border-color: #14735f;
  box-shadow: 0 0 0 2px rgb(20 115 95 / 14%);
  outline: none;
}

.planning-summary-card.is-active {
  background: #ecfdf5;
  border-color: #14735f;
  box-shadow: inset 0 0 0 1px rgb(20 115 95 / 45%);
}

.planning-confirm-toggle {
  justify-self: start;
  margin-top: 6px;
  min-height: 24px;
  padding: 3px 8px;
}

.planning-confirm-toggle:disabled {
  opacity: .65;
}

.planning-table-wrap .prio-input:disabled {
  background: #f1f5f9;
  color: #64748b;
  cursor: not-allowed;
}

/* Planeamiento: prioridades automáticas y semáforo visual. */
.planning-priority-form {
  flex: 0 0 auto;
  margin: 0;
}

.planning-priority-button {
  background: #fff7ed;
  border-color: #fdba74;
  color: #9a3412;
  font-size: 12px;
  font-weight: 900;
  min-height: 26px;
  padding: 3px 8px;
}

.planning-priority-button:not(:disabled):hover {
  background: #ffedd5;
}

.planning-priority-button:disabled {
  cursor: not-allowed;
  opacity: .55;
}

.planning-semaphore-bar {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #d7e0ea;
  border-radius: 8px;
  color: #0f2547;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin: 8px 0 22px;
  padding: 7px 10px;
}

.planning-semaphore-bar strong {
  color: #143585;
  font-size: 12px;
  font-weight: 900;
}

.planning-semaphore-bar label {
  align-items: center;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  gap: 4px;
  margin: 0;
}

.planning-semaphore-bar input {
  accent-color: #14735f;
  height: 13px;
  width: 13px;
}

.planning-semaphore-bar span {
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
}

#tabla-programacion-maquinas tbody tr.planning-semaphore-late > td:first-child {
  box-shadow: inset 4px 0 0 #dc2626;
}

#tabla-programacion-maquinas tbody tr.planning-semaphore-soon > td:first-child {
  box-shadow: inset 4px 0 0 #f59e0b;
}

#tabla-programacion-maquinas tbody tr.planning-semaphore-ok > td:first-child {
  box-shadow: inset 4px 0 0 #16a34a;
}

#tabla-programacion-maquinas tbody tr.planning-semaphore-none > td:first-child {
  box-shadow: inset 4px 0 0 #94a3b8;
}

@media (max-width: 760px) {
  .planning-priority-form,
  .planning-priority-button {
    width: 100%;
  }
}


.planning-delete-selected {
  align-items: center;
  display: inline-flex;
  gap: 4px;
  justify-content: center;
  margin-top: 6px;
  width: 100%;
}

.planning-delete-selected .delete-icon {
  align-items: center;
  border: 1px solid rgb(255 255 255 / 46%);
  border-radius: 50%;
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  height: 15px;
  justify-content: center;
  line-height: 1;
  width: 15px;
}

/* Partes de producción · circuito OT */
.production-parts-window {
  box-sizing: border-box;
  max-width: 1024px;
  padding-bottom: 26px;
}

.production-parts-toolbar {
  align-items: flex-start;
  gap: 12px;
}

.production-parts-actions {
  align-items: center;
  display: flex;
  flex: 0 0 auto;
  gap: 8px;
  justify-content: flex-end;
}

.production-parts-help {
  align-items: center;
  border-radius: 9px;
  display: inline-flex;
  font-size: 18px;
  font-weight: 900;
  height: 34px;
  justify-content: center;
  line-height: 1;
  padding: 0;
  width: 34px;
}

.parts-filters-card {
  background: #f8fbfd;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 8px 20px rgb(15 23 42 / 5%);
  margin: 0 0 12px;
  padding: 12px;
}

.production-parts-filters {
  align-items: end;
  display: grid;
  gap: 9px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.production-parts-filters .parts-filter-search { grid-column: span 3; }
.production-parts-filters .parts-filter-ot { grid-column: span 2; }
.production-parts-filters .parts-filter-machine { grid-column: span 2; }
.production-parts-filters .parts-filter-process { grid-column: span 3; }
.production-parts-filters .parts-filter-sector { grid-column: span 2; }
.production-parts-filters .parts-filter-legajo { grid-column: span 2; }
.production-parts-filters .parts-filter-date { grid-column: span 2; }

.production-parts-filters label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
}

.production-parts-filters label span {
  color: #475569;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.production-parts-filters input,
.production-parts-filters select {
  min-height: 32px;
}

.production-parts-filters .inline-filter-actions {
  align-items: end;
  align-self: end;
  display: flex;
  gap: 7px;
  grid-column: span 6;
  justify-content: flex-end;
  margin: 0;
}

.production-part-modal {
  max-width: min(900px, calc(100vw - 32px));
}

.production-part-form-grid {
  grid-template-columns: repeat(4, minmax(130px, 1fr));
}

.production-part-form-grid .wide {
  grid-column: span 2;
}

.parts-origin-box {
  background: #eef7ff;
  border: 1px solid #bfdbfe;
  border-radius: 10px;
  color: #0f3e66;
  display: grid;
  gap: 3px;
  margin: 0 0 12px;
  padding: 9px 11px;
}

.parts-origin-box strong {
  font-size: 12px;
  text-transform: uppercase;
}

.production-parts-summary {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.25fr);
  margin-bottom: 12px;
}

.production-parts-table {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 18px;
  scrollbar-width: thin;
}

.production-parts-table table,
.production-parts-table table.dataTable {
  min-width: 1640px;
}

.production-parts-table .dt-layout-table {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 14px;
  scrollbar-width: thin;
}

.production-parts-table .aramis-dt-toolbar {
  align-items: center;
  gap: 12px;
}

.production-parts-table .aramis-dt-search input {
  min-width: 320px;
}

.production-parts-table th,
.production-parts-table td {
  white-space: nowrap;
}

.production-parts-table td small {
  color: #64748b;
  display: block;
  font-size: 10px;
  line-height: 1.15;
  margin-top: 2px;
  max-width: 190px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.parts-process-cell {
  align-items: center;
  display: grid;
  gap: 4px;
  grid-template-columns: 58px minmax(150px, 1fr);
  min-width: 220px;
}

.production-parts-table .grid-input {
  min-height: 27px;
}

.production-parts-table .date-input {
  width: 122px;
}

.production-parts-table .code-input,
.production-parts-table .number-input {
  width: 68px;
}

.production-parts-table .text-input {
  min-width: 150px;
}

.parts-row-actions {
  align-items: center;
  display: flex;
  justify-content: center;
  min-width: 78px;
}

.parts-row-actions .delete-action {
  align-items: center;
  border-radius: 7px;
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  gap: 5px;
  height: 30px;
  justify-content: center;
  min-height: 30px;
  padding: 0 8px;
}

.parts-row-actions .delete-icon,
.planning-create-part + .planning-delete-selected .delete-icon {
  align-items: center;
  border: 1px solid rgb(255 255 255 / 48%);
  border-radius: 50%;
  display: inline-flex;
  flex: 0 0 15px;
  font-size: 12px;
  font-weight: 900;
  height: 15px;
  justify-content: center;
  line-height: 1;
  width: 15px;
}

.planning-create-part {
  background: #e8f4ff;
  border-color: #bfdbfe;
  color: #13568a;
}

.production-parts-help-dialog {
  max-width: min(1080px, calc(100vw - 28px));
}

@media (max-width: 1100px) {
  .production-parts-filters {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .production-parts-filters .parts-filter-search,
  .production-parts-filters .parts-filter-process {
    grid-column: span 2;
  }
  .production-parts-filters .parts-filter-ot,
  .production-parts-filters .parts-filter-machine,
  .production-parts-filters .parts-filter-sector,
  .production-parts-filters .parts-filter-legajo,
  .production-parts-filters .parts-filter-date {
    grid-column: span 1;
  }
  .production-parts-filters .inline-filter-actions {
    grid-column: span 4;
    justify-content: flex-end;
  }
}

@media (max-width: 760px) {
  .production-parts-toolbar {
    align-items: stretch;
    flex-direction: column;
  }
  .production-parts-actions {
    justify-content: flex-start;
  }
  .production-parts-filters,
  .production-part-form-grid,
  .production-parts-summary {
    grid-template-columns: 1fr;
  }
  .production-part-form-grid .wide,
  .production-parts-filters .inline-filter-actions {
    grid-column: auto;
  }
}


/* Partes: ayuda y boton ? alineados al estilo general */
.production-parts-actions .production-parts-help.client-tool.coverage-tool {
  background: #f8fbfd;
  border: 1px solid #cbd5e1;
  color: #0f766e;
  box-shadow: none;
}

.production-parts-actions .production-parts-help.client-tool.coverage-tool:hover {
  background: #eef7ff;
  border-color: #93c5fd;
  color: #0f4c81;
}

.production-parts-help-dialog {
  max-height: min(88vh, 920px);
  max-width: min(1080px, calc(100vw - 28px));
  overflow: hidden;
}

.production-parts-help-body {
  max-height: calc(min(88vh, 920px) - 76px);
  overflow: auto;
  padding: 12px;
}

.production-parts-help-body .ot-coverage-list,
.production-parts-help-body .ot-coverage-sections {
  margin-top: 0;
}

.production-parts-status-grid li {
  align-content: start;
  min-height: 78px;
}

.production-parts-help-body .ot-coverage-list li {
  background: #fff;
}

.production-parts-help-body .ot-coverage-sections section {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.production-parts-help-body .ot-coverage-sections ul {
  gap: 7px;
}

.production-parts-help-body .ot-coverage-sections li {
  line-height: 1.45;
}

.production-parts-help-body code {
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  display: inline-block;
  font-size: 11px;
  padding: 1px 5px;
  white-space: normal;
}

@media (max-width: 900px) {
  .production-parts-help-body {
    max-height: calc(88vh - 76px);
  }

  .production-parts-status-grid,
  .production-parts-help-body .ot-coverage-sections {
    grid-template-columns: 1fr;
  }

  .production-parts-status-grid li {
    min-height: auto;
  }
}

/* Partes de Produccion: replica funcional de TRF15 con estilo web moderno */
.production-parts-fox-modern {
  max-width: 1024px;
  padding-bottom: 22px;
}

.parts-fox-panel,
.parts-fox-table-shell,
.parts-fox-detail-bar {
  background: #f8fbfd;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  box-shadow: 0 8px 18px rgb(15 23 42 / 5%);
  margin-bottom: 12px;
}

.parts-fox-panel {
  padding: 10px;
}

.parts-fox-form {
  align-items: end;
  display: grid;
  gap: 9px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.parts-fox-form label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
}

.parts-fox-form label span {
  color: #173b74;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.parts-fox-form input,
.parts-fox-form select {
  min-height: 32px;
}

.parts-fox-close-card {
  align-items: center;
  background: #eef2f7;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  display: flex;
  gap: 8px;
  grid-column: span 4;
  min-height: 46px;
  padding: 7px;
}

.parts-muted-note {
  color: #64748b;
  font-size: 11px;
  line-height: 1.25;
}

.parts-fox-sector { grid-column: span 3; }
.parts-fox-ot { grid-column: span 2; }
.parts-fox-pliego { grid-column: span 1; }
.parts-other-button { grid-column: span 2; min-height: 32px; }
.parts-fox-search { grid-column: span 5; }
.parts-fox-machine { grid-column: span 2; }
.parts-fox-process { grid-column: span 3; }
.parts-fox-legajo { grid-column: span 2; }
.parts-fox-date { grid-column: span 2; }
.parts-fox-actions {
  align-items: end;
  display: flex;
  gap: 7px;
  grid-column: 10 / -1;
  justify-content: flex-end;
  margin: 0;
}

.parts-fox-actions button,
.parts-fox-actions .button {
  min-width: 74px;
}

.parts-grid-toolbar {
  align-items: center;
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  padding: 8px 10px 0;
}

.production-parts-table {
  border-top: 1px solid #d8e2ee;
  margin-top: 8px;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 16px;
  scrollbar-width: thin;
}

.production-parts-table table,
.production-parts-table table.dataTable {
  min-width: 1720px;
}

.production-parts-table .dt-layout-table {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 14px;
  scrollbar-width: thin;
}

.production-parts-table th {
  background: #e8f0f6;
  color: #0f294d;
  font-size: 11px;
  white-space: nowrap;
}

.production-parts-table td {
  vertical-align: top;
  white-space: nowrap;
}

.production-parts-table tr.is-selected td {
  background: #eff6ff;
  box-shadow: inset 0 1px 0 #bfdbfe, inset 0 -1px 0 #bfdbfe;
}

.production-parts-table .grid-input {
  min-height: 27px;
}

.production-parts-table .date-input { width: 122px; }
.production-parts-table .code-input { width: 72px; }
.production-parts-table .number-input { width: 74px; text-align: right; }
.production-parts-table .text-input { min-width: 160px; }
.production-parts-table .maquinista-input { min-width: 96px; }
.production-parts-table .parts-obs-input { min-width: 180px; }

.parts-process-cell-modern {
  align-items: center;
  display: grid;
  gap: 4px;
  grid-template-columns: 58px minmax(150px, 1fr) minmax(130px, 0.85fr);
  min-width: 380px;
}

.parts-process-cell-modern strong {
  background: #eef2ff;
  border: 1px solid #c7d2fe;
  border-radius: 6px;
  color: #1e3a8a;
  display: inline-flex;
  font-size: 11px;
  justify-content: center;
  padding: 4px 6px;
}

.parts-total-hours {
  color: #0f766e;
  display: inline-flex;
  justify-content: flex-end;
  min-width: 58px;
  padding-top: 6px;
}

.parts-inline-check {
  align-items: center;
  display: inline-flex;
  gap: 4px;
  min-height: 27px;
}

.parts-inline-check input {
  accent-color: #0f766e;
  height: 15px;
  width: 15px;
}

.parts-inline-check span {
  color: #334155;
  font-size: 11px;
  font-weight: 800;
}

.parts-fox-detail-bar {
  display: grid;
  gap: 8px;
  padding: 10px;
}

.parts-selected-summary {
  background: #fff;
  border: 1px solid #d8e2ee;
  border-radius: 8px;
  display: grid;
  gap: 6px 18px;
  grid-template-columns: 1.4fr 1fr 0.7fr 0.8fr 0.8fr;
  padding: 9px 11px;
}

.parts-selected-summary .wide {
  grid-column: 1 / -1;
}

.parts-selected-summary strong {
  color: #b91c1c;
  margin-right: 5px;
}

.parts-selected-summary span {
  color: #0f172a;
  font-weight: 700;
}

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

.parts-default-low-check {
  color: #334155;
  font-weight: 800;
  margin-right: auto;
}

.parts-default-low-check input {
  accent-color: #0f766e;
}

.parts-modern-form .form-actions {
  margin-top: 12px;
}

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

.parts-modal-grid fieldset {
  border: 1px solid #d8e2ee;
  border-radius: 10px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0;
  padding: 12px;
}

.parts-modal-grid legend {
  color: #173b74;
  font-size: 12px;
  font-weight: 900;
  padding: 0 5px;
}

.parts-modal-grid label {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.parts-modal-grid label span {
  color: #475569;
  font-size: 11px;
  font-weight: 800;
}

.parts-modal-grid label.wide,
.parts-modal-grid .parts-check-field {
  grid-column: 1 / -1;
}

.parts-modal-grid input,
.parts-modal-grid select,
.parts-modal-grid textarea {
  min-height: 32px;
  width: 100%;
}

.parts-modal-grid input[type="checkbox"] {
  accent-color: #0f766e;
  height: 16px;
  min-height: auto;
  width: 16px;
}

@media (max-width: 1100px) {
  .parts-fox-form {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
  .parts-fox-close-card,
  .parts-fox-search { grid-column: span 3; }
  .parts-fox-sector,
  .parts-fox-process { grid-column: span 2; }
  .parts-fox-ot,
  .parts-fox-pliego,
  .parts-other-button,
  .parts-fox-machine,
  .parts-fox-legajo,
  .parts-fox-date { grid-column: span 1; }
  .parts-fox-actions { grid-column: 5 / -1; }
  .parts-modal-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .parts-fox-form,
  .parts-selected-summary {
    grid-template-columns: 1fr;
  }
  .parts-fox-close-card,
  .parts-fox-sector,
  .parts-fox-ot,
  .parts-fox-pliego,
  .parts-other-button,
  .parts-fox-search,
  .parts-fox-machine,
  .parts-fox-process,
  .parts-fox-legajo,
  .parts-fox-date,
  .parts-fox-actions,
  .parts-selected-summary .wide {
    grid-column: auto;
  }
  .parts-fox-actions {
    justify-content: flex-start;
  }
}


/* Partes: Config moderno equivalente a TRF15 Setear valores por defecto */
.production-parts-config-modal {
  max-width: min(900px, calc(100vw - 28px));
  padding: 0;
}

.parts-config-header {
  align-items: flex-start;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 12px 14px;
}

.parts-config-header h2 {
  color: #0f294d;
  font-size: 17px;
  margin: 0 0 3px;
}

.parts-config-header p {
  color: #64748b;
  font-size: 12px;
  margin: 0;
}

.parts-config-form {
  padding: 12px 14px 14px;
}

.parts-config-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.parts-config-grid fieldset {
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0;
  padding: 14px;
}

.parts-config-grid legend {
  color: #173b74;
  font-size: 13px;
  font-weight: 900;
  padding: 0 7px;
}

.parts-config-grid label,
.parts-config-radio-group,
.parts-config-checks {
  color: #24364f;
  font-size: 13px;
}

.parts-config-grid label span,
.parts-config-radio-group strong {
  color: #173b74;
  font-size: 12px;
  font-weight: 900;
}

.parts-config-wide {
  grid-column: 1 / -1;
}

.parts-config-grid input[type="text"],
.parts-config-grid select {
  min-height: 32px;
  width: 100%;
}

.parts-config-radio-group {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(125px, 1fr) auto auto;
}

.parts-config-radio-group label,
.parts-config-checks label {
  align-items: center;
  display: inline-flex;
  gap: 7px;
  margin: 0;
}

.parts-config-radio-group input,
.parts-config-checks input {
  accent-color: #0f766e;
}

.parts-config-message-row {
  grid-template-columns: minmax(125px, 1fr) auto auto minmax(120px, 1.1fr);
}

.parts-config-user {
  align-items: center !important;
  display: grid !important;
  gap: 5px !important;
  grid-template-columns: auto minmax(95px, 1fr);
}

.parts-config-checks {
  display: grid;
  gap: 9px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.parts-config-actions {
  align-items: center;
  border-top: 1px solid var(--line);
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 14px;
  padding-top: 12px;
}

.parts-config-actions .secondary-button {
  margin-right: auto;
}

@media (max-width: 860px) {
  .parts-config-grid {
    grid-template-columns: 1fr;
  }

  .parts-config-radio-group,
  .parts-config-message-row,
  .parts-config-checks {
    grid-template-columns: 1fr;
  }

  .parts-config-user {
    grid-template-columns: 1fr !important;
  }
}


/* Partes Config: radios/checks compactos y consistentes entre Firefox/Chrome */
.parts-config-radio-group input[type="radio"],
.parts-config-checks input[type="checkbox"] {
  accent-color: #0f766e;
  flex: 0 0 auto;
  height: 15px;
  margin: 0;
  min-height: 15px;
  min-width: 15px;
  width: 15px;
}

.parts-config-radio-group label,
.parts-config-checks label {
  min-height: 28px;
}

.parts-config-message-row .parts-config-user input[type="text"] {
  height: 32px;
  min-height: 32px;
  width: 100%;
}

.parts-config-grid input[type="radio"],
.parts-config-grid input[type="checkbox"] {
  border-radius: initial;
  box-shadow: none;
}

.production-parts-config-modal .parts-config-radio-group {
  align-items: center;
}

.production-parts-config-modal .parts-config-checks label {
  align-items: center;
}

/* Partes: Config aplicada al comportamiento visible */
.production-parts-window.parts-hide-machine .parts-fox-machine,
.production-parts-window.parts-hide-machine [data-parts-field="maquina"],
.production-parts-window.parts-hide-machine .production-parts-table th:nth-child(4),
.production-parts-window.parts-hide-machine .production-parts-table td:nth-child(4) {
  display: none !important;
}

.production-parts-window.parts-hide-legajo .parts-fox-legajo,
.production-parts-window.parts-hide-legajo [data-parts-field="legajo"],
.production-parts-window.parts-hide-legajo .production-parts-table th:nth-child(5),
.production-parts-window.parts-hide-legajo .production-parts-table td:nth-child(5) {
  display: none !important;
}

.production-parts-window.parts-hide-turno [data-parts-field="turno"] {
  display: none !important;
}

.production-parts-window.parts-hide-tarea [data-parts-field="tarea"],
.production-parts-window.parts-hide-tarea .parts-task-line {
  display: none !important;
}

.production-parts-window.parts-hide-rubros .parts-rubro-note,
.production-parts-window.parts-hide-tipo-parada .parts-parada-note {
  display: none !important;
}

/* Partes: Fijar Columnas por puesto/navegador */
.production-parts-columns-modal {
  max-width: min(760px, calc(100vw - 28px));
}

.parts-columns-grid {
  display: grid;
  gap: 8px 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 14px;
}

.parts-columns-grid label {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #dbe3ec;
  border-radius: 8px;
  display: flex;
  gap: 8px;
  min-height: 34px;
  padding: 6px 8px;
}

.parts-columns-grid input {
  accent-color: #0f766e;
}

.production-parts-window.parts-col-hidden-1 .production-parts-table th:nth-child(1),
.production-parts-window.parts-col-hidden-1 .production-parts-table td:nth-child(1),
.production-parts-window.parts-col-hidden-2 .production-parts-table th:nth-child(2),
.production-parts-window.parts-col-hidden-2 .production-parts-table td:nth-child(2),
.production-parts-window.parts-col-hidden-3 .production-parts-table th:nth-child(3),
.production-parts-window.parts-col-hidden-3 .production-parts-table td:nth-child(3),
.production-parts-window.parts-col-hidden-4 .production-parts-table th:nth-child(4),
.production-parts-window.parts-col-hidden-4 .production-parts-table td:nth-child(4),
.production-parts-window.parts-col-hidden-5 .production-parts-table th:nth-child(5),
.production-parts-window.parts-col-hidden-5 .production-parts-table td:nth-child(5),
.production-parts-window.parts-col-hidden-6 .production-parts-table th:nth-child(6),
.production-parts-window.parts-col-hidden-6 .production-parts-table td:nth-child(6),
.production-parts-window.parts-col-hidden-7 .production-parts-table th:nth-child(7),
.production-parts-window.parts-col-hidden-7 .production-parts-table td:nth-child(7),
.production-parts-window.parts-col-hidden-8 .production-parts-table th:nth-child(8),
.production-parts-window.parts-col-hidden-8 .production-parts-table td:nth-child(8),
.production-parts-window.parts-col-hidden-9 .production-parts-table th:nth-child(9),
.production-parts-window.parts-col-hidden-9 .production-parts-table td:nth-child(9),
.production-parts-window.parts-col-hidden-10 .production-parts-table th:nth-child(10),
.production-parts-window.parts-col-hidden-10 .production-parts-table td:nth-child(10),
.production-parts-window.parts-col-hidden-11 .production-parts-table th:nth-child(11),
.production-parts-window.parts-col-hidden-11 .production-parts-table td:nth-child(11),
.production-parts-window.parts-col-hidden-12 .production-parts-table th:nth-child(12),
.production-parts-window.parts-col-hidden-12 .production-parts-table td:nth-child(12),
.production-parts-window.parts-col-hidden-13 .production-parts-table th:nth-child(13),
.production-parts-window.parts-col-hidden-13 .production-parts-table td:nth-child(13),
.production-parts-window.parts-col-hidden-14 .production-parts-table th:nth-child(14),
.production-parts-window.parts-col-hidden-14 .production-parts-table td:nth-child(14),
.production-parts-window.parts-col-hidden-15 .production-parts-table th:nth-child(15),
.production-parts-window.parts-col-hidden-15 .production-parts-table td:nth-child(15) {
  display: none !important;
}

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

/* Insumos de Producción: pantalla operativa MySQL */
.production-inputs-window {
  margin-bottom: 28px;
}

.production-inputs-toolbar .production-parts-help.client-tool.coverage-tool {
  background: #f8fbfd;
  border: 1px solid #cbd5e1;
  color: #0f766e;
}

.production-inputs-toolbar .production-parts-help.client-tool.coverage-tool:hover {
  background: #eef7ff;
  border-color: #93c5fd;
  color: #0f4c81;
}

.production-inputs-filters-card {
  margin-bottom: 12px;
}

.production-inputs-filters {
  align-items: end;
  display: grid;
  gap: 9px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.production-inputs-filters label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
}

.production-inputs-filters label span {
  color: #0f376d;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.production-inputs-filters input,
.production-inputs-filters select {
  min-height: 32px;
}

.production-inputs-filters .inputs-filter-search {
  grid-column: span 3;
}

.production-inputs-filters .inputs-filter-actions {
  align-self: end;
  grid-column: 10 / span 3;
  justify-content: flex-end;
  margin: 0;
}

.production-inputs-summary {
  margin-bottom: 12px;
}

.production-inputs-table {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 16px;
  scrollbar-width: thin;
}

.production-inputs-table table,
.production-inputs-table table.dataTable {
  min-width: 1720px;
}

.production-inputs-table .dt-layout-table {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 14px;
  scrollbar-width: thin;
}

.production-inputs-table .aramis-dt-toolbar {
  align-items: center;
  gap: 12px;
}

.production-inputs-table .aramis-dt-search input {
  min-width: 340px;
}

.production-inputs-table th,
.production-inputs-table td {
  white-space: nowrap;
}

.production-inputs-table td small {
  color: #64748b;
  display: block;
  font-size: 10px;
  line-height: 1.15;
  margin-top: 2px;
  max-width: 210px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.production-inputs-table .grid-input {
  min-height: 27px;
}

.production-inputs-table .date-input {
  width: 122px;
}

.production-inputs-table .code-input,
.production-inputs-table .number-input {
  width: 76px;
}

.production-inputs-table .text-input {
  min-width: 170px;
}

.production-input-modal {
  max-width: min(900px, calc(100vw - 32px));
}

@media (max-width: 1100px) {
  .production-inputs-filters {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .production-inputs-filters .inputs-filter-search {
    grid-column: span 2;
  }

  .production-inputs-filters .inputs-filter-actions {
    grid-column: span 4;
  }
}

@media (max-width: 760px) {
  .production-inputs-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .production-inputs-filters,
  .production-inputs-summary {
    grid-template-columns: 1fr;
  }

  .production-inputs-filters .inputs-filter-search,
  .production-inputs-filters .inputs-filter-actions {
    grid-column: auto;
  }
}

/* Insumos: pantalla estilo moderno basada en Fox "Partes de Insumos" */
.production-inputs-window.inputs-fox-window {
  max-width: 1024px;
  width: min(1024px, calc(100vw - 32px));
}

.inputs-fox-panel {
  background: #f8fbfd;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 10px 22px rgb(15 23 42 / 5%);
  margin-bottom: 12px;
  overflow: hidden;
}

.inputs-fox-form {
  display: grid;
  gap: 0;
}

.inputs-fox-topline {
  display: grid;
  gap: 10px;
  grid-template-columns: 1.15fr 1fr .72fr;
  padding: 10px;
}

.inputs-fox-card {
  align-items: center;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  display: flex;
  gap: 8px;
  margin: 0;
  min-width: 0;
  padding: 10px 10px 9px;
}

.inputs-fox-card legend,
.inputs-article-panel h2 {
  color: #102f6a;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .01em;
  padding: 0 4px;
}

.inputs-fox-card input[type="search"],
.inputs-fox-card input[type="number"],
.inputs-fox-card input[type="date"],
.inputs-fox-card select,
.inputs-article-panel input,
.inputs-bottom-filters input,
.inputs-bottom-filters select {
  border: 1px solid #b8c7d9;
  border-radius: 7px;
  min-height: 32px;
}

.inputs-ot-card input[name="ot"] {
  flex: 1 1 auto;
  min-width: 90px;
}

.inputs-ot-card label {
  align-items: center;
  display: flex;
  gap: 6px;
  margin: 0;
}

.inputs-ot-card label span {
  color: #102f6a;
  font-weight: 900;
}

.inputs-ot-card input[name="pliego"] {
  width: 64px;
}

.inputs-slash {
  color: #102f6a;
  font-size: 20px;
  font-weight: 900;
}

.lookup-mini-button,
.inputs-go-button {
  align-items: center;
  background: #edf6ff;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
  color: #0f4c81;
  display: inline-flex;
  flex: 0 0 32px;
  font-weight: 900;
  height: 32px;
  justify-content: center;
  padding: 0;
  text-decoration: none;
  width: 32px;
}

.inputs-go-button {
  background: #e9f7ef;
  border-color: #b7e4c7;
  color: #0f766e;
}

.inputs-entry-card {
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}

.inputs-entry-card label,
.inputs-order-options label,
.inputs-filter-date-toggle,
.inputs-affects-stock,
.inputs-stock-flag {
  align-items: center;
  color: #172033;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  gap: 6px;
  margin: 0;
}

.inputs-entry-card input[type="radio"],
.inputs-order-options input[type="radio"],
.inputs-filter-date-toggle input,
.inputs-affects-stock input,
.inputs-stock-flag input {
  accent-color: #0f766e;
  height: 14px;
  margin: 0;
  width: 14px;
}

.inputs-date-card input[type="date"] {
  min-width: 135px;
}

.inputs-selected-strip {
  background: #fff;
  border-bottom: 1px solid #d6e0ea;
  border-top: 1px solid #d6e0ea;
  display: grid;
  gap: 8px 18px;
  grid-template-columns: 1.3fr 1.3fr .8fr .8fr;
  min-height: 54px;
  padding: 10px 16px;
}

.inputs-selected-strip div {
  color: #25324a;
  font-size: 13px;
  min-width: 0;
}

.inputs-selected-strip strong {
  color: #b42318;
  font-weight: 900;
  margin-right: 5px;
}

.inputs-selected-strip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.inputs-article-panel {
  background: #f8fafc;
  border-bottom: 1px solid #d6e0ea;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) 118px minmax(170px, .55fr) auto;
  padding: 9px 12px 11px;
  position: relative;
}

.inputs-article-panel h2 {
  grid-column: 1 / -1;
  justify-self: center;
  margin: 0;
}

.inputs-ref-line {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: auto minmax(0, 1fr);
  margin: 0;
}

.inputs-ref-line span {
  color: #102f6a;
  font-size: 13px;
  font-weight: 900;
}

.inputs-ref-line input {
  width: 100%;
}

.inputs-qty-line {
  align-items: center;
  display: grid;
  gap: 6px;
  grid-template-columns: auto minmax(0, 1fr);
  margin: 0;
}

.inputs-qty-line span {
  color: #102f6a;
  font-size: 13px;
  font-weight: 900;
}

.inputs-qty-line input {
  width: 100%;
}

.inputs-ref-preview {
  align-self: stretch;
  background: #ffffff;
  border: 1px solid #d6e0ea;
  border-radius: 10px;
  color: #243244;
  display: grid;
  gap: 1px;
  min-height: 45px;
  padding: 5px 8px;
}

.inputs-ref-preview strong {
  color: #0f5fa8;
  font-size: 12px;
  line-height: 1.1;
}

.inputs-ref-preview small {
  color: #64748b;
  font-size: 10px;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.inputs-article-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.inputs-article-actions .client-tool {
  min-height: 30px;
  min-width: 32px;
  padding: 0 7px;
}

.inputs-stock-flag {
  border-left: 1px solid #d6e0ea;
  color: #0f4c81;
  margin-left: 2px;
  padding-left: 8px;
}

.inputs-bottom-filters {
  align-items: end;
  background: #f1f5f9;
  display: grid;
  gap: 10px;
  grid-template-columns: 1.05fr .7fr .7fr .8fr .72fr 1.3fr auto;
  padding: 10px 12px;
}

.inputs-bottom-filters label span {
  color: #102f6a;
  display: block;
  font-size: 12px;
  font-weight: 900;
  margin-bottom: 4px;
}

.inputs-order-options {
  align-content: center;
  border: 0;
  display: grid;
  gap: 6px 12px;
  grid-template-columns: repeat(2, minmax(0, auto));
  margin: 0;
  padding: 0;
}

.inputs-fox-actions {
  align-items: end;
  display: flex;
  gap: 7px;
  justify-content: flex-end;
  margin: 0;
}

.inputs-fox-grid {
  border-radius: 12px;
  margin-bottom: 14px;
}

.production-inputs-table table,
.production-inputs-table table.dataTable {
  min-width: 1480px;
}

.production-inputs-table th:nth-child(3),
.production-inputs-table td:nth-child(3) {
  text-align: center;
  width: 34px;
}

.grid-help-chip {
  align-items: center;
  background: #eef2ff;
  border: 1px solid #c7d2fe;
  border-radius: 7px;
  color: #3730a3;
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  height: 25px;
  justify-content: center;
  padding: 0;
  width: 25px;
}

.production-inputs-table tbody tr.is-selected td {
  background: #eef7ff !important;
}

.production-inputs-table .inputs-material-code {
  width: 96px;
}

.production-inputs-table .inputs-desc-input {
  min-width: 210px;
}

@media (max-width: 1050px) {
  .production-inputs-window.inputs-fox-window {
    width: calc(100vw - 24px);
  }

  .inputs-fox-topline {
    grid-template-columns: 1fr;
  }

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

  .inputs-article-panel,
  .inputs-bottom-filters {
    grid-template-columns: 1fr;
  }

  .inputs-ref-preview {
    min-height: auto;
  }

  .inputs-fox-actions,
  .inputs-article-actions {
    justify-content: flex-start;
  }
}


/* Insumos: selector de materia prima y alta rápida desde Ref. */
.inputs-materia-dialog {
  max-height: min(88vh, 900px);
  max-width: min(920px, calc(100vw - 28px));
  overflow: hidden;
}

.inputs-materia-dialog-body {
  max-height: calc(min(88vh, 900px) - 72px);
  overflow: auto;
  padding: 12px;
}

.inputs-materia-dialog .dt-layout-table {
  overflow-x: auto;
  padding-bottom: 10px;
}

.inputs-materia-dialog table,
.inputs-materia-dialog table.dataTable {
  min-width: 820px;
}

.inputs-materia-dialog .aramis-dt-search input {
  min-width: 330px;
}

.inputs-materia-dialog td small {
  color: #64748b;
  display: block;
  font-size: 10px;
  line-height: 1.15;
  margin-top: 2px;
}

.inputs-article-actions .lookup-mini-button.client-tool {
  background: #edf6ff;
  border-color: #bfdbfe;
  color: #0f4c81;
}

.inputs-article-actions [data-inputs-quick-add] {
  background: #e9f7ef;
  border-color: #b7e4c7;
  color: #0f766e;
  font-size: 17px;
  font-weight: 900;
}

.inputs-ref-line input[data-inputs-ref] {
  font-weight: 700;
}

@media (max-width: 760px) {
  .inputs-materia-dialog .aramis-dt-search input {
    min-width: 180px;
  }
}

/* Insumos automaticos desde Partes */
.inputs-auto-window {
  max-width: 1024px;
}

.inputs-auto-filter-card {
  background: #f8fbfd;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 8px 20px rgb(15 23 42 / 5%);
  margin: 0 0 12px;
  padding: 12px;
}

.inputs-auto-filters {
  align-items: end;
  display: grid;
  gap: 9px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.inputs-auto-filters label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
}

.inputs-auto-filters label span {
  color: #07346c;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.inputs-auto-filters input,
.inputs-auto-filters select {
  min-height: 32px;
}

.inputs-auto-filters .auto-filter-search {
  grid-column: span 3;
}

.inputs-auto-filters .inputs-auto-actions {
  align-items: end;
  display: flex;
  gap: 8px;
  grid-column: 10 / span 3;
  justify-content: flex-end;
  margin: 0;
}

.inputs-auto-summary {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  margin-bottom: 12px;
}

.inputs-auto-status {
  align-items: center;
  border-radius: 12px 12px 0 0;
  margin-bottom: 0;
}

.inputs-auto-status strong {
  display: block;
  margin-bottom: 2px;
}

.inputs-auto-toolbar {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  justify-content: flex-end;
}

.inputs-auto-table {
  border-radius: 0 0 12px 12px;
  overflow-x: auto;
  padding-bottom: 16px;
}

.inputs-auto-table table {
  min-width: 1360px;
}

.inputs-auto-table td small {
  color: #64748b;
  display: block;
  font-size: 10px;
  line-height: 1.15;
  margin-top: 2px;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.inputs-auto-table tr.is-generated {
  background: #f8fafc;
  color: #64748b;
}

.inputs-auto-table tr.is-blocked {
  background: #fff7ed;
}

@media (max-width: 1040px) {
  .inputs-auto-filters {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .inputs-auto-filters .auto-filter-search {
    grid-column: span 2;
  }

  .inputs-auto-filters .inputs-auto-actions {
    grid-column: span 4;
  }

  .inputs-auto-summary {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .inputs-auto-filters,
  .inputs-auto-summary {
    grid-template-columns: 1fr;
  }

  .inputs-auto-filters .auto-filter-search,
  .inputs-auto-filters .inputs-auto-actions {
    grid-column: auto;
  }
}

/* === Insumos: equivalencias de materiales === */
.inputs-equivalence-window {
  max-width: 1024px !important;
}

.inputs-equivalence-form .auto-filter-search {
  grid-column: span 3;
}

.inputs-equivalence-form .inputs-auto-actions {
  grid-column: 10 / span 3;
}

.module-note {
  color: #475569;
  font-size: 13px;
  line-height: 1.35;
  margin: 0;
}

.inline-form {
  display: inline-flex;
  margin: 0;
}

.small-button {
  min-height: 28px;
  padding: 5px 9px;
}

.mini-link {
  color: #0f5fa8;
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  margin-top: 3px;
  text-decoration: underline;
}

@media (max-width: 1040px) {
  .inputs-equivalence-form .auto-filter-search,
  .inputs-equivalence-form .inputs-auto-actions {
    grid-column: span 4;
  }
}

@media (max-width: 760px) {
  .inputs-equivalence-form .auto-filter-search,
  .inputs-equivalence-form .inputs-auto-actions {
    grid-column: auto;
  }
}

/* === Insumos: lupa de materia en equivalencias === */
.inputs-equivalence-form .inputs-equivalence-alias {
  grid-column: span 3;
}

.inputs-equivalence-form .inputs-equivalence-material {
  grid-column: span 3;
}

.inputs-equivalence-form .inputs-equivalence-notes {
  grid-column: span 2;
}

.inputs-equivalence-lookup-line {
  align-items: center;
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) 34px;
}

.inputs-equivalence-lookup-line .lookup-mini-button {
  height: 32px;
  min-height: 32px;
  width: 34px;
}

.inputs-equivalence-preview {
  align-self: end;
  background: #f8fbff;
  border: 1px solid rgba(15, 95, 168, .18);
  border-radius: 12px;
  color: #243244;
  display: grid;
  gap: 2px;
  grid-column: span 2;
  min-height: 58px;
  padding: 8px 10px;
}

.inputs-equivalence-preview strong {
  color: #0f5fa8;
  font-size: 11px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.inputs-equivalence-preview > span {
  font-size: 13px;
  font-weight: 800;
}

.inputs-equivalence-preview small {
  color: #64748b;
  font-size: 11px;
  line-height: 1.2;
}

.inputs-equivalence-materia-dialog .inputs-materia-dialog-body {
  max-height: 64vh;
  overflow: auto;
}

@media (max-width: 1040px) {
  .inputs-equivalence-form .inputs-equivalence-alias,
  .inputs-equivalence-form .inputs-equivalence-material,
  .inputs-equivalence-form .inputs-equivalence-notes,
  .inputs-equivalence-preview {
    grid-column: span 4;
  }
}

@media (max-width: 760px) {
  .inputs-equivalence-form .inputs-equivalence-alias,
  .inputs-equivalence-form .inputs-equivalence-material,
  .inputs-equivalence-form .inputs-equivalence-notes,
  .inputs-equivalence-preview {
    grid-column: auto;
  }
}

/* === Insumos: cierre manual, sugerencias y equivalencias === */
.inputs-ref-preview[data-inputs-ref-preview] {
  cursor: default;
}

.inputs-auto-warning {
  align-items: center;
  display: grid;
  gap: 6px 12px;
  grid-template-columns: minmax(0, 1fr) auto;
  margin-bottom: 10px;
}

.inputs-auto-warning strong,
.inputs-auto-warning span {
  display: block;
}

.inputs-auto-warning span {
  color: #64748b;
  font-size: 12px;
}

.inputs-equivalence-detected {
  margin-bottom: 12px;
}

.inputs-detected-header {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-bottom: 10px;
}

.inputs-detected-header h2 {
  color: #102f6a;
  font-size: 15px;
  margin: 0 0 2px;
}

.inputs-detected-header p {
  color: #64748b;
  font-size: 12px;
  margin: 0;
}

.inputs-detected-list {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.inputs-detected-item {
  align-items: center;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 12px;
  display: grid;
  gap: 4px 8px;
  grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr) auto;
  padding: 8px 10px;
}

.inputs-detected-item strong {
  color: #9a3412;
  font-size: 13px;
}

.inputs-detected-item span,
.inputs-detected-item small {
  color: #7c2d12;
  font-size: 11px;
}

.inputs-detected-item small {
  grid-column: 2 / 3;
}

.inputs-equivalence-actions {
  flex-wrap: nowrap;
}

.inputs-equivalence-actions .danger-button {
  min-height: 28px;
  padding: 4px 8px;
}

@media (max-width: 1040px) {
  .inputs-detected-list,
  .inputs-auto-warning {
    grid-template-columns: 1fr;
  }

  .inputs-detected-item {
    grid-template-columns: 1fr;
  }

  .inputs-detected-item small {
    grid-column: auto;
  }
}

.stock-inline-check {
  align-items: center;
  display: inline-flex;
  gap: 6px;
  justify-content: center;
  min-width: 96px;
  white-space: nowrap;
}

.stock-inline-check input[type="checkbox"] {
  accent-color: #0f766e;
  height: 14px;
  margin: 0;
  width: 14px;
}

.status-badge.muted {
  background: #eef2f7;
  border: 1px solid #cbd5e1;
  color: #475569;
}

.inputs-auto-stock-flag {
  background: #f8fafc;
  border: 1px solid #d6e0ea;
  border-radius: 8px;
  min-height: 32px;
  padding: 0 9px;
}

/* Producción: entregas reales con historial. */
.production-deliveries-toolbar {
  align-items: flex-start;
  gap: 10px;
}

.production-deliveries-toolbar .production-deliveries-help {
  flex: 0 0 auto;
  margin-top: 2px;
}

.production-deliveries-table table,
.production-deliveries-table table.dataTable {
  min-width: 1540px;
}

.production-deliveries-datatable .dt-layout-table {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 14px;
  scrollbar-width: thin;
}

.production-deliveries-table .actions-cell {
  min-width: 180px;
}

.production-deliveries-table .actions-cell .delivery-actions {
  grid-template-columns: repeat(3, minmax(52px, 1fr));
}

.delivery-history-pill,
.delivery-type-pill {
  align-items: center;
  border-radius: 999px;
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  justify-content: center;
  min-height: 22px;
  min-width: 32px;
  padding: 2px 8px;
  white-space: nowrap;
}

.delivery-history-pill {
  background: #eef6ff;
  border: 1px solid #bfdbfe;
  color: #1e3a8a;
}

.delivery-type-pill.entrega {
  background: #ecfdf5;
  border: 1px solid #bbf7d0;
  color: #166534;
}

.delivery-type-pill.cierre {
  background: #eef2ff;
  border: 1px solid #c7d2fe;
  color: #3730a3;
}

.delivery-type-pill.reapertura {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  color: #9a3412;
}

.production-delivery-dialog {
  max-width: min(620px, calc(100vw - 32px));
}

.delivery-form-grid {
  grid-template-columns: repeat(2, minmax(140px, 1fr));
}

.delivery-form-grid .wide {
  grid-column: 1 / -1;
}

.ot-delivery-history-table table {
  min-width: 920px;
}

.ot-delivery-history-table td,
.ot-delivery-history-table th {
  vertical-align: middle;
}

@media (max-width: 980px) {
  .production-deliveries-toolbar {
    align-items: stretch;
  }

  .production-deliveries-toolbar .production-deliveries-help {
    align-self: flex-end;
  }
}

/* Producción / Entregas: encuadre 1024 y grilla compacta. */
.production-deliveries-window {
  display: grid;
  gap: 10px;
  margin: 0 auto;
  max-width: 1024px;
  width: min(1024px, 100%);
}

.production-deliveries-window .production-deliveries-toolbar {
  align-items: start;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  width: 100%;
}

.production-deliveries-window .production-deliveries-toolbar > div:first-child {
  min-width: 0;
}

.production-deliveries-window .production-deliveries-toolbar .wide-filters {
  display: grid;
  gap: 6px;
  grid-column: 1 / -1;
  grid-template-columns: minmax(220px, 1fr) 120px 118px 118px 118px auto;
  max-width: 100%;
  width: 100%;
}

.production-deliveries-window .production-deliveries-help {
  justify-self: end;
}

.production-deliveries-window .compact-summary {
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  max-height: 155px;
  overflow: auto;
  padding-right: 2px;
}

.production-deliveries-window .compact-summary .module-box {
  min-height: 94px;
  padding: 11px 12px;
}

.production-deliveries-window .compact-summary .module-box h2 {
  font-size: 13px;
  line-height: 1.2;
}

.production-deliveries-window .compact-summary .module-box dl {
  font-size: 12px;
  gap: 4px 8px;
}

.production-deliveries-table,
.production-deliveries-table .dt-container,
.production-deliveries-datatable .dt-layout-table,
.production-deliveries-datatable .dt-layout-table > div {
  max-width: 100%;
  overflow-x: hidden;
  width: 100%;
}

.production-deliveries-table table,
.production-deliveries-table table.dataTable {
  font-size: 11px;
  min-width: 0 !important;
  table-layout: fixed;
  width: 100% !important;
}

.production-deliveries-table .delivery-col-extra {
  display: none !important;
}

.production-deliveries-table th,
.production-deliveries-table td {
  padding-left: 5px;
  padding-right: 5px;
}

.production-deliveries-table th:nth-child(1),
.production-deliveries-table td:nth-child(1) { width: 86px; }
.production-deliveries-table th:nth-child(2),
.production-deliveries-table td:nth-child(2) { width: 56px; }
.production-deliveries-table th:nth-child(3),
.production-deliveries-table td:nth-child(3) { width: 92px; }
.production-deliveries-table th:nth-child(4),
.production-deliveries-table td:nth-child(4) { width: 42px; }
.production-deliveries-table th:nth-child(5),
.production-deliveries-table td:nth-child(5) { width: auto; }
.production-deliveries-table th:nth-child(7),
.production-deliveries-table td:nth-child(7),
.production-deliveries-table th:nth-child(8),
.production-deliveries-table td:nth-child(8),
.production-deliveries-table th:nth-child(9),
.production-deliveries-table td:nth-child(9) { width: 66px; }
.production-deliveries-table th:nth-child(10),
.production-deliveries-table td:nth-child(10) { width: 42px; }
.production-deliveries-table th:nth-child(12),
.production-deliveries-table td:nth-child(12) { width: 44px; }
.production-deliveries-table th:nth-child(14),
.production-deliveries-table td:nth-child(14) { width: 126px; }

.production-deliveries-table .grid-input {
  font-size: 11px;
  min-height: 26px;
  padding: 3px 6px;
  width: 100%;
}

.production-deliveries-table .date-input {
  max-width: 82px;
}

.production-deliveries-table .number-input,
.production-deliveries-table .tiny-input {
  max-width: 62px;
}

.production-deliveries-table .text-input {
  min-width: 0;
}

.production-deliveries-table .actions-cell {
  min-width: 0;
  white-space: normal;
}

.production-deliveries-table .actions-cell .delivery-actions {
  display: grid;
  gap: 4px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.production-deliveries-table .actions-cell .compact-action {
  font-size: 11px;
  min-height: 26px;
  min-width: 0;
  padding: 3px 5px;
  width: 100%;
}

.production-deliveries-table .actions-cell .compact-action:last-child {
  grid-column: 1 / -1;
}

.production-deliveries-table small {
  font-size: 10px;
}

@media (max-width: 1040px) {
  .production-deliveries-window .production-deliveries-toolbar .wide-filters {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .production-deliveries-window .production-deliveries-toolbar {
    grid-template-columns: 1fr;
  }

  .production-deliveries-window .production-deliveries-toolbar .wide-filters {
    grid-template-columns: 1fr;
  }
}

/* Producción / Entregas: resumen por cliente en banda horizontal estilo Planeamiento. */
.production-deliveries-window .delivery-summary-carousel {
  align-items: center;
  display: grid;
  gap: 0;
  grid-template-columns: 24px minmax(0, 1fr) 24px;
  margin: 0 0 2px;
  max-width: 100%;
  min-height: 60px;
  width: 100%;
}

.production-deliveries-window .delivery-summary-strip {
  align-items: flex-start;
  display: flex;
  gap: 6px;
  margin: 0;
  max-height: 60px;
  min-height: 56px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 0 2px;
  scroll-behavior: smooth;
  scrollbar-width: none;
  width: 100%;
}

.production-deliveries-window .delivery-summary-strip::-webkit-scrollbar {
  height: 0;
  width: 0;
}

.production-deliveries-window .delivery-summary-card {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  display: grid;
  flex: 0 0 155px;
  gap: 2px;
  min-height: 48px;
  overflow: hidden;
  padding: 7px 9px;
}

.production-deliveries-window .delivery-summary-card strong {
  color: #0f2f6b;
  font-size: 12px;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.production-deliveries-window .delivery-summary-card span,
.production-deliveries-window .delivery-summary-card em {
  color: #334155;
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.production-deliveries-window .delivery-summary-card em {
  color: #475569;
  font-weight: 600;
}

.production-deliveries-window .delivery-summary-nav {
  min-height: 50px;
}

@media (max-width: 760px) {
  .production-deliveries-window .delivery-summary-carousel {
    grid-template-columns: 22px minmax(0, 1fr) 22px;
  }

  .production-deliveries-window .delivery-summary-card {
    flex-basis: 145px;
  }
}


/* Producción / Entregas: ajuste final de DataTable server-side dentro del encuadre. */
.production-deliveries-datatable-table th.delivery-col-extra,
.production-deliveries-datatable-table td.delivery-col-extra {
  display: none !important;
}

.production-deliveries-table .actions-cell {
  min-width: 112px;
  overflow: visible;
  padding-left: 4px;
  padding-right: 4px;
  width: 112px;
}

.production-deliveries-table .actions-cell .delivery-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  justify-content: center;
}

.production-deliveries-table .actions-cell .compact-action {
  flex: 0 0 auto;
  font-size: 10px;
  line-height: 1;
  min-height: 24px;
  padding: 3px 5px;
  width: auto;
}

.production-deliveries-table th:nth-child(14),
.production-deliveries-table td:nth-child(14) {
  width: 112px;
}

.production-deliveries-table th:nth-child(5),
.production-deliveries-table td:nth-child(5) {
  width: 135px;
}

.production-deliveries-table th:nth-child(1),
.production-deliveries-table td:nth-child(1) { width: 78px; }
.production-deliveries-table th:nth-child(3),
.production-deliveries-table td:nth-child(3) { width: 72px; }
.production-deliveries-table th:nth-child(7),
.production-deliveries-table td:nth-child(7),
.production-deliveries-table th:nth-child(8),
.production-deliveries-table td:nth-child(8),
.production-deliveries-table th:nth-child(9),
.production-deliveries-table td:nth-child(9) { width: 58px; }

.production-deliveries-table .date-input { max-width: 76px; }
.production-deliveries-table .number-input,
.production-deliveries-table .tiny-input { max-width: 56px; }


/* Producción / Entregas: tres acciones compactas sin salir del encuadre. */
.production-deliveries-table .actions-cell {
  min-width: 132px;
  width: 132px;
}

.production-deliveries-table th:nth-child(14),
.production-deliveries-table td:nth-child(14) {
  width: 132px;
}

.production-deliveries-table .actions-cell .delivery-actions {
  align-items: center;
  display: flex;
  flex-wrap: nowrap;
  gap: 3px;
  justify-content: center;
}

.production-deliveries-table .actions-cell .compact-action {
  font-size: 9px;
  min-height: 24px;
  padding: 3px 4px;
}

.production-deliveries-table .actions-cell .compact-action.action-disabled,
.production-deliveries-table .actions-cell .compact-action:disabled {
  background: #e5edf5;
  border-color: #cbd5e1;
  color: #718096;
  cursor: not-allowed;
  opacity: .75;
}

.production-deliveries-table th:nth-child(5),
.production-deliveries-table td:nth-child(5) {
  width: 118px;
}

/* OT8 entregas/remitos consolidados */
.delivery-remito-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 28px;
  padding: 4px 6px;
  font-size: 12px;
  color: #123452;
}

.delivery-remito-check input[type="checkbox"] {
  width: 14px;
  height: 14px;
  accent-color: #0b7568;
}

.production-delivery-dialog form.save-error {
  outline: 2px solid rgba(185, 28, 28, 0.22);
  outline-offset: 3px;
  border-radius: 10px;
}

/* OT8 Remitos de OT: control MySQL server-side y encuadre compacto. */
.production-remitos-window {
  display: grid;
  gap: 10px;
  margin: 0 auto;
  max-width: 1024px;
  width: min(1024px, 100%);
}

.production-remitos-window .production-remitos-toolbar {
  align-items: start;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  width: 100%;
}

.production-remitos-window .production-remitos-toolbar > div:first-child {
  min-width: 0;
}

.production-remitos-window .production-remitos-help {
  justify-self: end;
}

.production-remitos-window .production-remitos-filters {
  display: grid;
  gap: 6px;
  grid-column: 1 / -1;
  grid-template-columns: minmax(220px, 1fr) 105px 118px 118px 92px 138px auto;
  max-width: 100%;
  width: 100%;
}

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

.remitos-kpi-strip article {
  background: #f8fafc;
  border: 1px solid #d5dde8;
  border-radius: 8px;
  display: grid;
  gap: 2px;
  min-height: 52px;
  padding: 9px 12px;
}

.remitos-kpi-strip strong {
  color: #073263;
  font-size: 18px;
  line-height: 1;
}

.remitos-kpi-strip span {
  color: #475569;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}

.production-remitos-window .remitos-summary-carousel {
  align-items: center;
  display: grid;
  gap: 0;
  grid-template-columns: 24px minmax(0, 1fr) 24px;
  margin: 0 0 2px;
  max-width: 100%;
  min-height: 60px;
  width: 100%;
}

.production-remitos-window .delivery-summary-strip {
  align-items: flex-start;
  display: flex;
  gap: 6px;
  max-height: 60px;
  min-height: 56px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 0 2px;
  scroll-behavior: smooth;
  scrollbar-width: none;
  width: 100%;
}

.production-remitos-window .delivery-summary-strip::-webkit-scrollbar {
  height: 0;
  width: 0;
}

.production-remitos-window .delivery-summary-card {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  display: grid;
  flex: 0 0 155px;
  gap: 2px;
  min-height: 48px;
  overflow: hidden;
  padding: 7px 9px;
}

.production-remitos-window .delivery-summary-card strong,
.production-remitos-window .delivery-summary-card span,
.production-remitos-window .delivery-summary-card em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.production-remitos-window .delivery-summary-card strong {
  color: #0f2f6b;
  font-size: 12px;
  line-height: 1.15;
}

.production-remitos-window .delivery-summary-card span,
.production-remitos-window .delivery-summary-card em {
  color: #334155;
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.15;
}

.production-remitos-table,
.production-remitos-table .dt-container,
.production-remitos-datatable .dt-layout-table,
.production-remitos-datatable .dt-layout-table > div {
  max-width: 100%;
  overflow-x: hidden;
  width: 100%;
}

.production-remitos-table table,
.production-remitos-table table.dataTable {
  font-size: 11px;
  min-width: 0 !important;
  table-layout: fixed;
  width: 100% !important;
}

.production-remitos-table .remito-col-extra {
  display: none !important;
}

.production-remitos-table th,
.production-remitos-table td {
  padding-left: 5px;
  padding-right: 5px;
  vertical-align: top;
}

.production-remitos-table th:nth-child(1),
.production-remitos-table td:nth-child(1) { width: 70px; }
.production-remitos-table th:nth-child(2),
.production-remitos-table td:nth-child(2) { width: 76px; }
.production-remitos-table th:nth-child(3),
.production-remitos-table td:nth-child(3) { width: 100px; }
.production-remitos-table th:nth-child(4),
.production-remitos-table td:nth-child(4) { width: 76px; }
.production-remitos-table th:nth-child(5),
.production-remitos-table td:nth-child(5) { width: 70px; }
.production-remitos-table th:nth-child(7),
.production-remitos-table td:nth-child(7) { width: 64px; }
.production-remitos-table th:nth-child(8),
.production-remitos-table td:nth-child(8) { width: 54px; }
.production-remitos-table th:nth-child(9),
.production-remitos-table td:nth-child(9) { width: 58px; }
.production-remitos-table th:nth-child(11),
.production-remitos-table td:nth-child(11) { width: 82px; }

.production-remitos-table td small,
.production-remitos-table td span {
  display: block;
  font-size: 10px;
  line-height: 1.15;
}

.production-remitos-table .mysql-remito-source {
  color: #0b7568;
  font-weight: 800;
}

.production-remitos-table .remito-state-pill {
  min-width: 24px;
}

.production-remitos-table .remito-actions {
  align-items: center;
  display: flex;
  gap: 6px;
  justify-content: center;
  white-space: nowrap;
}

.production-remitos-table .remito-actions .compact-action {
  font-size: 11px;
  min-height: 28px;
  min-width: 38px;
  padding: 5px 8px;
}

.production-remitos-table .remito-actions .action-disabled,
.production-remitos-table .remito-actions .remito-ot-disabled {
  background: #e9eef5 !important;
  border: 1px solid #cbd5e1 !important;
  color: #7b8797 !important;
  cursor: not-allowed;
  opacity: 0.78;
  pointer-events: none;
}

.production-remitos-table .remito-ot-unlinked {
  color: #64748b;
  font-weight: 700;
}

.production-remitos-table .remito-actions {
  min-width: 92px;
}

@media (max-width: 1040px) {
  .production-remitos-window .production-remitos-filters {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .production-remitos-window .production-remitos-toolbar,
  .production-remitos-window .production-remitos-filters,
  .remitos-kpi-strip {
    grid-template-columns: 1fr;
  }
}

.production-remitos-table .remito-ot-stack {
  align-items: center;
  display: inline-flex;
  flex-wrap: nowrap;
  gap: 4px;
  max-width: 160px;
  overflow: hidden;
  white-space: nowrap;
}

.production-remitos-table .remito-ot-chip,
.production-remitos-table .remito-ot-more {
  align-items: center;
  border-radius: 999px;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 10px;
  font-weight: 800;
  gap: 2px;
  line-height: 1;
  min-height: 19px;
  padding: 2px 6px;
  text-decoration: none;
  white-space: nowrap;
}

.production-remitos-table a.remito-ot-chip {
  background: #eefdf7;
  border: 1px solid #a7f3d0;
  color: #00796b;
}

.production-remitos-table .remito-ot-unlinked {
  background: #f1f5f9;
  border: 1px solid #cbd5e1;
  color: #64748b;
}

.production-remitos-table .remito-ot-item {
  color: #334155;
  display: inline !important;
  font-size: 9px;
  font-weight: 700;
  opacity: 0.8;
}

.production-remitos-table .remito-ot-num {
  display: inline !important;
}

.production-remitos-table .remito-ot-more {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  color: #c2410c;
}

.production-remitos-table th:nth-child(4),
.production-remitos-table td:nth-child(4) {
  min-width: 150px;
  width: 150px;
  white-space: nowrap;
}

.production-remitos-table th:nth-child(11),
.production-remitos-table td:nth-child(11) {
  min-width: 106px;
  width: 106px;
  white-space: nowrap;
}

.warning-action {
  background: #f59e0b !important;
  border-color: #d97706 !important;
  color: #fff !important;
}

.warning-action:hover {
  background: #d97706 !important;
}


.remito-detail-page {
  max-width: 1024px;
  margin: 0 auto 28px;
  padding: 0 10px;
  width: 100%;
}

.remito-detail-page .remito-detail-header,
.remito-detail-page .remito-fox-card,
.remito-detail-page .remito-detail-section,
.remito-detail-page .remito-detail-extra-grid,
.remito-detail-page .remito-fox-footer-line {
  max-width: 100%;
  width: 100%;
}

.remito-detail-page .remito-fox-card {
  align-items: start;
}

/* Remito detalle - ficha web basada en pantalla histórica, operativa MySQL */
.remito-detail-header {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  max-width: 1024px;
}

.remito-detail-actions {
  align-items: center;
  display: flex;
  gap: 8px;
}

.remito-fox-card,
.remito-detail-section,
.remito-detail-extra-grid {
  max-width: 1024px;
}

.remito-fox-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 230px;
  gap: 14px;
  margin-top: 14px;
}

.remito-fox-main,
.remito-fox-side,
.remito-detail-section,
.remito-pending-map-section {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: 0 1px 0 rgba(16, 24, 40, 0.03);
  padding: 14px;
}

.remito-fox-title-line {
  display: grid;
  grid-template-columns: 1.2fr .9fr .7fr .7fr;
  gap: 8px;
  margin-bottom: 12px;
}

.remito-fox-title-line > div,
.remito-field {
  background: #f6f9fb;
  border: 1px solid #d6e0ea;
  border-radius: 8px;
  display: grid;
  gap: 4px;
  min-height: 50px;
  padding: 8px 10px;
}

.remito-fox-title-line span,
.remito-field span,
.remito-notes-box span,
.remito-fox-side dt {
  color: #344b6b;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.remito-fox-title-line strong,
.remito-field strong,
.remito-fox-side dd {
  color: #07162c;
  font-size: 13px;
  font-weight: 700;
  min-width: 0;
  overflow-wrap: anywhere;
}

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

.remito-fox-grid .wide {
  grid-column: span 2;
}

.remito-notes-box {
  background: #fbfdff;
  border: 1px solid #d6e0ea;
  border-radius: 8px;
  margin-top: 10px;
  min-height: 76px;
  padding: 10px;
}

.remito-notes-box p {
  margin: 6px 0 0;
  min-height: 42px;
}

.remito-fox-side h2,
.remito-detail-section h2,
.remito-pending-map-section h2 {
  font-size: 15px;
  margin: 0 0 10px;
}

.remito-fox-side dl {
  grid-template-columns: 86px 1fr;
}

.remito-detail-items-wrap {
  overflow-x: auto;
}

.remito-detail-items-table,
.remito-linked-deliveries-table {
  min-width: 980px;
}

.remito-detail-items-table th,
.remito-detail-items-table td,
.remito-linked-deliveries-table th,
.remito-linked-deliveries-table td {
  font-size: 12px;
  padding: 8px 9px;
}

.remito-detail-items-table th:nth-child(1),
.remito-detail-items-table td:nth-child(1) { width: 74px; }
.remito-detail-items-table th:nth-child(2),
.remito-detail-items-table td:nth-child(2) { width: 84px; }
.remito-detail-items-table th:nth-child(3),
.remito-detail-items-table td:nth-child(3),
.remito-detail-items-table th:nth-child(4),
.remito-detail-items-table td:nth-child(4) { width: 44px; }
.remito-detail-items-table th:nth-child(5),
.remito-detail-items-table td:nth-child(5) { width: 80px; }
.remito-detail-items-table th:nth-child(6),
.remito-detail-items-table td:nth-child(6) { width: 54px; }
.remito-detail-items-table th:nth-child(10),
.remito-detail-items-table td:nth-child(10) { width: 64px; }
.remito-detail-items-table th:nth-child(11),
.remito-detail-items-table td:nth-child(11) { width: 60px; }
.remito-detail-items-table th:nth-child(12),
.remito-detail-items-table td:nth-child(12) { width: 60px; }

.remito-detail-extra-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 16px;
}

.remito-related-links {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.remito-pending-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.remito-pending-grid span {
  background: #f3f5f7;
  border: 1px solid #d5dee8;
  border-radius: 999px;
  color: #49566a;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 9px;
}

@media (max-width: 900px) {
  .remito-fox-card,
  .remito-detail-extra-grid,
  .remito-fox-title-line,
  .remito-fox-grid {
    grid-template-columns: 1fr;
  }
  .remito-fox-grid .wide {
    grid-column: auto;
  }
}

/* OT8 Remitos - ficha operativa MySQL basada en referencia Fox */
.remito-operativo-header {
    align-items: flex-start;
    gap: 12px;
}

.remito-operativo-actions,
.production-remitos-toolbar-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.inline-form {
    display: inline-flex;
    margin: 0;
}

.remito-operativo-card {
    grid-template-columns: minmax(0, 1fr) 280px;
    align-items: stretch;
    gap: 14px;
}

.remito-title-edit label,
.remito-fox-grid-edit label,
.remito-transport-edit label {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin: 0;
}

.remito-title-edit input,
.remito-fox-grid-edit input,
.remito-transport-edit input,
.remito-notes-edit textarea,
.remito-manual-line-grid input {
    width: 100%;
    min-height: 34px;
}

.tiny-input {
    max-width: 90px;
}

.small-number-input {
    max-width: 120px;
}

.remito-traer-toolbar {
    display: grid;
    grid-template-columns: minmax(120px, 170px) 70px 120px auto 1fr;
    gap: 8px;
    align-items: end;
    padding: 10px;
    margin: 10px 0;
    border: 1px solid #cfd8e3;
    border-radius: 10px;
    background: #f7fafc;
}

.remito-traer-toolbar label {
    display: flex;
    flex-direction: column;
    gap: 4px;
    color: #334155;
    font-size: 12px;
    font-weight: 700;
}

.remito-ult-rem {
    justify-self: end;
    align-self: center;
    color: #0f3f74;
    font-weight: 700;
    white-space: nowrap;
}

.remito-field em {
    display: block;
    margin-top: 3px;
    color: #475569;
    font-size: 11px;
    font-style: normal;
}

.remito-notes-edit {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 10px;
}

.remito-transport-edit {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.remito-transport-edit dl {
    margin-bottom: 6px;
}

.remito-check-line {
    flex-direction: row !important;
    align-items: center;
    gap: 8px;
    font-weight: 700;
}

.remito-check-line input {
    width: auto !important;
    min-height: auto !important;
}

.remito-fox-footer-line {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px 12px;
    margin: 12px 0;
    border: 1px solid #dbe3ee;
    border-radius: 10px;
    background: #fff;
}

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

.remito-detail-items-table th,
.remito-detail-items-table td {
    white-space: nowrap;
}

.remito-detail-items-table th:nth-child(7),
.remito-detail-items-table td:nth-child(7),
.remito-detail-items-table th:nth-child(8),
.remito-detail-items-table td:nth-child(8) {
    white-space: normal;
    min-width: 170px;
}

.danger-soft {
    background: #f8d7da !important;
    border-color: #f1b8bd !important;
    color: #8a1f2d !important;
    min-width: 34px;
}

.remito-detail-line-dialog {
    width: min(880px, 96vw);
}

.remito-manual-line-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.remito-manual-line-grid .wide {
    grid-column: span 2;
}

.print-tenant-header {
    align-items: center;
    background: #ffffff;
    border-bottom: 2px solid #d4dce8;
    gap: 12px;
    margin: 0 0 12px;
    padding: 0 0 10px;
}

.print-tenant-header img {
    background: #ffffff;
    border: 1px solid #d8e0ea;
    border-radius: 8px;
    display: block;
    height: 46px;
    object-fit: contain;
    padding: 4px;
    width: 88px;
}

.print-tenant-header strong {
    color: #0f172a;
    display: block;
    font-size: 15px;
    line-height: 1.1;
    text-transform: uppercase;
}

.print-tenant-header span {
    color: #64748b;
    display: block;
    font-size: 11px;
    font-weight: 700;
    margin-top: 2px;
}

.print-toolbar {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-bottom: 12px;
}

.remito-print-page {
    background: #fff;
    border: 1px solid #d7dee8;
    border-radius: 10px;
    padding: 22px;
    color: #111827;
}

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

.remito-print-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 16px 0;
}

.remito-print-grid div,
.remito-print-footer div {
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 8px;
}

.remito-print-grid span {
    display: block;
    color: #475569;
    font-size: 12px;
}

.remito-print-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 14px;
}

.remito-print-table th,
.remito-print-table td {
    border: 1px solid #cbd5e1;
    padding: 7px;
    text-align: left;
}

@media (max-width: 1024px) {
    .remito-operativo-card {
        grid-template-columns: 1fr;
    }
    .remito-traer-toolbar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .remito-ult-rem {
        justify-self: start;
    }
    .remito-manual-line-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media print {
    .no-print,
    .topbar,
    .navbar,
    .sidebar,
    .footer,
    .app-footer,
    .detail-header,
    .messages,
    .toast-container {
        display: none !important;
    }
    body {
        background: #fff !important;
    }
    .print-tenant-header {
        display: flex !important;
    }
    .remito-print-page {
        border: 0;
        padding: 0;
    }
}

/* OT9.1 - resolver código de producto/artículo para cierre productivo */
.ot-product-row {
  align-items: stretch;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(315px, 352px) minmax(330px, max-content);
  justify-content: start;
  margin: 8px 0 4px;
}

.ot-product-card {
  background: #f8fbfe;
  border: 1px solid var(--line);
  border-radius: 8px;
  min-width: 0;
  padding: 7px 8px;
}

.ot-product-card.warning {
  border-color: #ffd98c;
  box-shadow: inset 3px 0 0 #f0b640;
}

.ot-product-card.danger {
  border-color: #f3b4b4;
  box-shadow: inset 3px 0 0 #d9534f;
}

.ot-product-card.success {
  border-color: #b9dfc2;
  box-shadow: inset 3px 0 0 #3fa55b;
}

.ot-product-card-head {
  align-items: center;
  display: flex;
  gap: 8px;
  justify-content: space-between;
  margin-bottom: 5px;
}

.ot-product-card-head span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .02em;
}

.ot-product-card-head em {
  border: 1px solid var(--line);
  border-radius: 999px;
  color: #42505c;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  padding: 3px 7px;
  text-transform: uppercase;
}

.ot-product-card.success .ot-product-card-head em {
  background: #edf8f0;
  border-color: #b9dfc2;
  color: #2d713d;
}

.ot-product-card.warning .ot-product-card-head em {
  background: #fff6df;
  border-color: #ffd98c;
  color: #8a4b00;
}

.ot-product-card.danger .ot-product-card-head em {
  background: #fff0f0;
  border-color: #f3b4b4;
  color: #9b2d2d;
}

.ot-product-resolver-field {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) 94px;
}

.ot-product-resolver-field .grid-input {
  min-width: 0;
  width: 100%;
}

.ot-product-resolver-field .mini-action {
  align-items: center;
  display: inline-flex;
  justify-content: center;
  min-height: 30px;
  padding: 5px 10px;
  white-space: nowrap;
  width: 94px;
}

.ot-product-meta {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 5px;
  min-height: 20px;
}

.ot-product-candidate {
  background: #fff6df;
  border: 1px solid #ffd98c;
  border-radius: 999px;
  color: #8a4b00;
  display: inline-flex;
  font-size: 10.5px;
  font-weight: 800;
  line-height: 1.1;
  padding: 3px 8px;
}

.ot-product-candidate.ok {
  background: #edf8f0;
  border-color: #b9dfc2;
  color: #2d713d;
}

.ot-product-candidate.warning {
  background: #fff6df;
  border-color: #ffd98c;
  color: #8a4b00;
}

.ot-product-candidate.danger {
  background: #fff0f0;
  border-color: #f3b4b4;
  color: #9b2d2d;
}

.ot-top-flags {
  align-items: center;
  background: #f8fbfe;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  justify-content: flex-start;
  min-height: 70px;
  padding: 9px 10px;
}

.ot-top-flags .ot-check {
  min-height: 24px;
  white-space: nowrap;
}

.ot-product-resolver-dialog .form-grid.two-cols {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ot-resolver-status {
  display: grid;
  gap: 4px;
  margin-bottom: 10px;
}

.ot-resolver-status strong {
  font-size: 13px;
}

@media (max-width: 980px) {
  .ot-product-row {
    grid-template-columns: 1fr;
  }

  .ot-product-resolver-field {
    grid-template-columns: minmax(160px, 1fr) auto;
  }

  .ot-product-resolver-field .mini-action {
    width: auto;
  }

  .ot-product-resolver-dialog .form-grid.two-cols {
    grid-template-columns: 1fr;
  }
}

/* OT - trazabilidad final */
.ot-traceability-section {
  border-color: #c9d8ea;
}

.ot-trace-summary {
  min-width: 210px;
  padding: 8px 10px;
  border: 1px solid #cbd7e6;
  border-radius: 8px;
  background: #f7fafc;
  text-align: right;
}

.ot-trace-summary strong {
  display: block;
  color: #0f172a;
  font-size: 14px;
}

.ot-trace-summary span {
  display: block;
  color: #64748b;
  font-size: 11px;
  margin-top: 2px;
}

.ot-trace-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 10px 0 12px;
}

.ot-trace-kpis > div {
  border: 1px solid #d6e0eb;
  border-radius: 8px;
  background: #f8fafc;
  padding: 8px 10px;
}

.ot-trace-kpis span,
.ot-trace-kpis small {
  display: block;
  color: #64748b;
  font-size: 11px;
}

.ot-trace-kpis strong {
  display: block;
  margin: 2px 0;
  color: #0f172a;
  font-size: 14px;
}

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

.ot-trace-event {
  border: 1px solid #d7e2ec;
  border-radius: 8px;
  background: #fff;
  padding: 9px 10px;
}

.ot-trace-event.ok {
  background: #eefaf4;
  border-color: #bfe5cf;
}

.ot-trace-event.warn {
  background: #fff8ec;
  border-color: #f1d7a7;
}

.ot-trace-event.block {
  background: #fff1f2;
  border-color: #fecdd3;
}

.ot-trace-event-head {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 5px;
}

.ot-trace-event p {
  margin: 0 0 6px;
  color: #334155;
  font-size: 12px;
}

.ot-trace-event dl {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 2px 8px;
  margin: 0;
  font-size: 11px;
}

.ot-trace-event dt {
  color: #64748b;
}

.ot-trace-event dd {
  margin: 0;
  color: #0f172a;
  overflow-wrap: anywhere;
}

.status-badge.ok {
  background: #dcfce7;
  color: #166534;
  border-color: #bbf7d0;
}

.status-badge.warn {
  background: #fef3c7;
  color: #92400e;
  border-color: #fde68a;
}

.status-badge.block {
  background: #fee2e2;
  color: #991b1b;
  border-color: #fecaca;
}

.ot-trace-detail-tables {
  margin-top: 12px;
}

.ot-trace-detail-tables h3 {
  margin: 0 0 6px;
  color: #0f376e;
  font-size: 13px;
}

@media (max-width: 1024px) {
  .ot-trace-kpis,
  .ot-trace-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.permissions-title-actions {
  align-items: center;
  display: flex;
  gap: 8px;
}

.tenant-db-switcher {
  align-items: start;
  background: #f8fbff;
  border: 1px solid #d7e2f0;
  border-radius: 8px;
  display: grid;
  gap: 3px;
  min-width: 230px;
  padding: 8px;
}

.tenant-db-switcher > span {
  color: #21344a;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.tenant-db-switcher .grid-input {
  background: #ffffff;
  height: 32px;
  min-height: 32px;
  padding: 4px 28px 4px 8px;
}

.tenant-db-switcher small {
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
}

.tenant-db-local-mode {
  align-items: center;
  color: #334155;
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  gap: 6px;
  line-height: 1.1;
}

.tenant-db-local-mode input {
  accent-color: #4f46e5;
  height: 14px;
  margin: 0;
  width: 14px;
}

.permission-disabled {
  cursor: not-allowed !important;
  opacity: 0.72;
}

.permissions-legend {
  background: #eef7ff;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
  color: #28436a;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 9px 10px;
}

.permissions-legend span {
  background: #ffffff;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  font-size: 11px;
  padding: 4px 8px;
}

.permission-card-accordion {
  display: block;
  overflow: hidden;
  padding: 0;
}

.permission-card-header {
  align-items: center;
  cursor: pointer;
  display: grid;
  gap: 6px;
  grid-template-columns: 18px minmax(0, 1fr);
  min-height: 36px;
  padding: 7px 10px;
}

.permission-card-header:hover,
.permission-card-header:focus-visible {
  background: #f8fbff;
  outline: 0;
}

.permission-card-chevron {
  color: #2563eb;
  display: inline-flex;
  font-size: 20px;
  font-weight: 900;
  justify-content: center;
  line-height: 1;
  transition: transform .16s ease;
}

.permission-card[data-permission-expanded="1"] .permission-card-chevron {
  transform: rotate(90deg);
}

.permission-card-body {
  border-top: 1px solid #edf2f7;
  padding: 7px 10px 10px 28px;
}

.permission-card-children {
  margin-left: 0;
}

.permission-card-empty .permission-card-header {
  cursor: default;
}

.permission-card-header .permission-row-matrix {
  grid-template-columns: minmax(220px, 1fr) auto;
}

.permission-card-header .permission-module-toggle strong,
.permission-card-header .permission-module-toggle span {
  font-size: 14px;
}

.permission-row-matrix {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(150px, 1fr) auto;
}

.permission-module-toggle {
  align-items: center;
  display: flex;
  gap: 8px;
  min-width: 0;
}

.permission-module-toggle span,
.permission-module-toggle strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.permission-actions {
  align-items: center;
  display: flex;
  gap: 4px;
  justify-content: flex-end;
}

.permission-action-toggle,
.permission-action-label {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #d7deea;
  border-radius: 6px;
  color: #24446d;
  display: inline-flex;
  font-size: 10px;
  font-weight: 800;
  gap: 3px;
  min-height: 24px;
  padding: 2px 5px;
  text-transform: uppercase;
}

.permission-action-toggle input {
  height: 12px;
  width: 12px;
}

.permission-action-toggle:has(input:checked) {
  background: #dcfce7;
  border-color: #86efac;
  color: #166534;
}

.permission-action-toggle:has(input:disabled) {
  opacity: .52;
}

.permission-action-label-view {
  background: #eff6ff;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.permissions-help-dialog {
  max-width: 860px;
}

.permissions-help-dialog code {
  background: #eef2ff;
  border-radius: 4px;
  color: #1e3a8a;
  padding: 1px 4px;
}

.permissions-help-note {
  align-items: start;
  display: grid;
  gap: 4px;
  margin-top: 10px;
}

@media (max-width: 1050px) {
  .permission-row-matrix,
  .permission-card-header .permission-row-matrix {
    grid-template-columns: 1fr;
  }

  .permission-actions {
    justify-content: flex-start;
  }

  .permission-card-body {
    padding-left: 18px;
  }
}

/* OT detalle: encuadre 1024 y botoneras secundarias unificadas */
:root {
  --ot-detail-frame-width: 1024px;
}

.ot-detail-header,
.ot-detail-notice,
.ot-detail-toolbar,
.ot-navigation-frame,
.ot-quick-summary,
.ot-detail-window,
.ot-traceability-section,
#ot-copia,
#ot-pliegos,
#ot-impresion,
#ot-troquelado,
#ot-preparacion,
#ot-seguimiento,
#ot-partes-insumos,
#ot-textos,
#estado-funcional-ot {
  box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
  max-width: var(--ot-detail-frame-width);
  width: 100%;
}

.ot-navigation-frame {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 7px;
  margin-bottom: 8px;
  padding: 8px 10px;
}

.ot-navigation-row {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ot-navigation-row + .ot-navigation-row {
  border-top: 1px solid #e4eaf1;
  padding-top: 7px;
}

.ot-navigation-title,
.ot-navigation-frame .ot-subnav span {
  color: var(--muted);
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 800;
  margin-right: 2px;
  text-transform: uppercase;
}

.ot-navigation-frame .ot-detail-tabs,
.ot-navigation-frame .ot-subnav {
  background: transparent;
  border: 0;
  border-radius: 0;
  display: flex;
  flex: 1 1 auto;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-start;
  margin: 0;
  max-width: none;
  padding: 0;
  width: auto;
}

.ot-navigation-frame .np-tab-button,
.ot-navigation-frame .ot-subnav a {
  min-height: 28px;
  padding: 5px 8px;
}

.ot-navigation-frame .ot-subnav a {
  background: #fff;
}

.ot-quick-summary {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.ot-traceability-section .section-heading-row,
.ot-traceability-section .ot-trace-kpis,
.ot-traceability-section .ot-trace-grid,
.ot-traceability-section .ot-trace-tables {
  max-width: 100%;
}

@media (max-width: 1100px) {
  .ot-detail-header,
  .ot-detail-notice,
  .ot-detail-toolbar,
  .ot-navigation-frame,
  .ot-quick-summary,
  .ot-detail-window,
  .ot-traceability-section,
  #ot-copia,
  #ot-pliegos,
  #ot-impresion,
  #ot-troquelado,
  #ot-preparacion,
  #ot-seguimiento,
  #ot-partes-insumos,
  #ot-textos,
  #estado-funcional-ot {
    max-width: calc(100vw - 24px);
  }
}

@media (max-width: 860px) {
  .ot-quick-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ot-navigation-row {
    align-items: stretch;
    display: grid;
  }
}

/* OT detalle: panel definitivo de botoneras secundarias bajo botonera principal */
.ot-detail-nav-panel {
  background: #f8fafc;
  border: 1px solid #d5e1ee;
  border-radius: 8px;
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 70%);
  box-sizing: border-box;
  display: grid;
  gap: 7px;
  margin: 0 auto 8px;
  max-width: var(--ot-detail-frame-width, 1024px);
  padding: 8px 10px;
  width: 100%;
}

.ot-detail-nav-row {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: 132px minmax(0, 1fr);
}

.ot-detail-nav-row-secondary {
  border-top: 1px solid #e2e8f0;
  padding-top: 7px;
}

.ot-detail-nav-label {
  color: #53657a;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.ot-detail-nav-buttons,
.ot-detail-nav-panel .ot-detail-tabs,
.ot-detail-nav-panel .ot-subnav,
.ot-detail-nav-panel .ot-quick-nav-buttons {
  align-items: center;
  background: transparent;
  border: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-start;
  margin: 0;
  max-width: none;
  min-width: 0;
  padding: 0;
  width: auto;
}

.ot-detail-nav-panel .np-tab-button,
.ot-detail-nav-panel .ot-subnav a,
.ot-detail-nav-panel .ot-quick-nav-buttons a {
  align-items: center;
  background: #fff;
  border: 1px solid #d6e1ec;
  border-radius: 7px;
  color: #07366a;
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  min-height: 28px;
  padding: 5px 9px;
  text-decoration: none;
  white-space: nowrap;
}

.ot-detail-nav-panel .np-tab-button.is-active,
.ot-detail-nav-panel .ot-subnav a.is-active,
.ot-detail-nav-panel .ot-quick-nav-buttons a.is-active {
  background: #0f766e;
  border-color: #0f766e;
  color: #fff;
}

.ot-detail-nav-panel .np-tab-button:hover,
.ot-detail-nav-panel .ot-subnav a:hover,
.ot-detail-nav-panel .ot-quick-nav-buttons a:hover {
  border-color: #9bb9d8;
  box-shadow: 0 1px 3px rgb(15 23 42 / 8%);
}

/* Fallback: si una plantilla vieja todavía deja las tabs sueltas, al menos encuadrarlas. */
.ot-detail-toolbar + .np-detail-tabs.ot-detail-tabs:not(.ot-detail-nav-buttons) {
  background: #f8fafc;
  border: 1px solid #d5e1ee;
  border-radius: 8px;
  box-sizing: border-box;
  margin: 0 auto 8px;
  max-width: var(--ot-detail-frame-width, 1024px);
  padding: 8px 10px;
  width: 100%;
}

.ot-detail-toolbar + .np-detail-tabs.ot-detail-tabs:not(.ot-detail-nav-buttons)::before {
  color: #53657a;
  content: "Secciones OT";
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .02em;
  margin-right: 8px;
  text-transform: uppercase;
}

@media (max-width: 760px) {
  .ot-detail-nav-row {
    align-items: stretch;
    grid-template-columns: 1fr;
  }
}


/* FIX OT detalle: fila Accesos rápidos visible dentro del mismo marco de Secciones OT. */
.ot-detail-nav-panel .ot-detail-nav-row-secondary {
  display: grid !important;
}

.ot-detail-nav-panel .ot-quick-nav-buttons {
  align-items: center;
  background: transparent !important;
  border: 0 !important;
  display: flex !important;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-start;
  margin: 0 !important;
  padding: 0 !important;
}

.ot-detail-nav-panel .ot-quick-nav-buttons a {
  align-items: center;
  background: #fff;
  border: 1px solid #d6e1ec;
  border-radius: 7px;
  color: #07366a;
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  min-height: 28px;
  padding: 5px 9px;
  text-decoration: none;
  white-space: nowrap;
}


/* FIX OT detalle: encuadrar botonera principal Borrar/Buscar/Imprimir en el mismo estilo que Secciones OT. */
.ot-main-actions-panel {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #d5e1ee;
  border-radius: 8px;
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 70%);
  box-sizing: border-box;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 auto 8px;
  max-width: var(--ot-detail-frame-width, 1024px);
  padding: 8px 10px;
  width: 100%;
}

.ot-main-actions-title {
  color: #53657a;
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
  margin-right: 4px;
  text-transform: uppercase;
}

.ot-main-actions-panel .ot-detail-toolbar {
  align-items: center;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  display: flex;
  flex: 1 1 auto;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-start;
  margin: 0 !important;
  max-width: none !important;
  min-width: 0;
  padding: 0 !important;
  width: auto !important;
}

.ot-main-actions-panel .compact-action {
  margin: 0;
}

@media (max-width: 760px) {
  .ot-main-actions-panel {
    align-items: stretch;
    display: grid;
  }

  .ot-main-actions-panel .ot-detail-toolbar {
    width: 100% !important;
  }
}

/* FIX merge: conservar OT detalle encuadrado + listado /produccion/ 1024 + selector insumos. */
/* OT lista 1024 - encuadre compacto de /produccion/ */
.production-list-toolbar {
  align-items: end;
  background: transparent;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) auto auto;
  margin: 0 auto 10px;
  max-width: 1024px;
  width: min(1024px, 100%);
}

.production-list-toolbar > div {
  min-width: 0;
}

.production-list-toolbar h1 {
  font-size: 21px;
  line-height: 1.05;
}

.production-list-toolbar p {
  font-size: 11px;
  line-height: 1.25;
}

.production-list-toolbar > .button {
  min-height: 31px;
  padding: 6px 10px;
  white-space: nowrap;
}

.production-list-toolbar .coverage-tool {
  height: 31px;
  min-height: 31px;
  min-width: 31px;
  width: 31px;
}

.production-list-toolbar .filters {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-column: 1 / -1;
  gap: 6px;
  grid-template-columns: minmax(230px, 1fr) repeat(3, minmax(90px, 112px)) 78px;
  max-width: none;
  padding: 8px;
  width: 100%;
}

.production-list-toolbar .filters input,
.production-list-toolbar .filters select,
.production-list-toolbar .filters button {
  font-size: 12px;
  min-height: 29px;
  min-width: 0;
  padding: 4px 7px;
  width: 100%;
}

.production-orders-table {
  margin: 0 auto;
  max-width: 1024px;
  overflow: hidden !important;
  width: min(1024px, 100%);
}

.table-wrap.production-orders-table:has(table[data-datatable]),
.production-orders-table .dt-layout-table {
  overflow-x: hidden !important;
}

.production-orders-table .dt-container,
.production-orders-table .dt-layout-table,
.production-orders-table .dt-layout-cell {
  max-width: 100%;
  width: 100%;
}

.production-orders-table table,
.production-orders-table table.dataTable {
  max-width: 100%;
  min-width: 0 !important;
  table-layout: fixed;
  width: 100% !important;
}

.production-orders-table th,
.production-orders-table td {
  box-sizing: border-box;
  font-size: 11px;
  line-height: 1.15;
  overflow: hidden;
  padding: 4px 4px;
  text-overflow: ellipsis;
  vertical-align: middle;
}

.production-orders-table th {
  font-size: 10px;
  letter-spacing: 0;
}

.production-orders-table .grid-input {
  font-size: 11px;
  min-height: 23px;
  padding: 2px 4px;
}

.production-orders-table td:nth-child(3) small,
.production-orders-table .ot-list-ref-links,
.production-orders-table small {
  display: block;
  font-size: 10px;
  line-height: 1.1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.production-orders-table .ot-list-refs {
  white-space: normal;
}

.production-orders-table .ot-list-refs label {
  align-items: center;
  display: grid;
  gap: 3px;
  grid-template-columns: 30px minmax(0, 1fr);
  margin-bottom: 2px;
  min-width: 0;
}

.production-orders-table .ot-list-refs label span {
  color: #173a7a;
  font-size: 9px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.production-orders-table .ot-list-refs .tiny-input,
.production-orders-table .ot-list-refs .number-input,
.production-orders-table .ot-list-refs .code-input {
  width: 100%;
}

.production-orders-table .ot-list-ref-links {
  display: flex;
  gap: 6px;
  margin-top: 2px;
}

.production-orders-table .row-actions {
  align-items: stretch;
  display: grid;
  gap: 3px;
  grid-template-columns: 1fr;
}

.production-orders-table .compact-action,
.production-orders-table .row-actions .button,
.production-orders-table .row-actions .danger-button {
  font-size: 10px;
  min-height: 22px;
  padding: 2px 4px;
  width: 100%;
}

.production-orders-table .production-delete-button .delete-icon {
  height: 13px;
  width: 13px;
}

.production-orders-table .dt-layout-row {
  gap: 8px;
  padding: 7px 8px;
}

.production-orders-table .dt-search input {
  min-height: 30px;
  width: min(280px, 38vw);
}

.production-orders-table .dt-info,
.production-orders-table .dt-paging button,
.production-orders-table .dt-length label,
.production-orders-table .dt-search label {
  font-size: 11px;
}

@media (max-width: 900px) {
  .production-list-toolbar {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .production-list-toolbar .coverage-tool {
    grid-column: 2;
  }

  .production-list-toolbar .filters {
    grid-template-columns: 1fr 1fr;
  }
}


/* Insumos: selector visual de materia prima dentro del modal Agregar insumo */
.inputs-modal-materia-field {
  gap: 6px;
}

.inputs-modal-lookup-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.inputs-modal-lookup-line input {
  width: 100%;
}

.inputs-modal-lookup-line .lookup-mini-button {
  min-height: 44px;
  padding: 0 14px;
  white-space: nowrap;
}

.inputs-modal-field-hint {
  color: #50627a;
  font-weight: 700;
  line-height: 1.35;
}

@media (max-width: 720px) {
  .inputs-modal-lookup-line {
    grid-template-columns: 1fr;
  }
}

/* Asistente Produccion: panel global de ayuda operativa con ChatGPT/fallback local */
.assistant-button {
  align-items: center;
  background: #314357;
  border: 1px solid #4a5d72;
  border-radius: 8px;
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 10%), 0 8px 16px rgb(15 23 42 / 14%);
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  white-space: nowrap;
}

.assistant-button:hover,
.assistant-button[aria-expanded="true"] {
  background: #365fd3;
  border-color: #5b7ce2;
}

.production-assistant-panel {
  background: #ffffff;
  border: 1px solid #c8d2e0;
  border-radius: 10px;
  box-shadow: 0 20px 44px rgb(15 23 42 / 22%);
  display: grid;
  grid-template-rows: auto minmax(180px, 1fr) auto auto;
  max-height: min(640px, calc(100vh - 74px));
  overflow: hidden;
  position: fixed;
  right: 16px;
  top: 60px;
  width: min(420px, calc(100vw - 28px));
  z-index: 1200;
}

.production-assistant-panel[hidden] {
  display: none !important;
}

.production-assistant-header {
  align-items: center;
  background: linear-gradient(180deg, #f8fafc, #eef2f8);
  border-bottom: 1px solid #d9e1ec;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  min-width: 0;
  padding: 10px 12px;
}

.production-assistant-title {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.production-assistant-header-actions {
  align-items: center;
  display: inline-flex;
  flex: 0 0 auto;
  gap: 8px;
}

.production-assistant-gpt-switch {
  align-items: center;
  cursor: pointer;
  display: inline-flex;
  gap: 6px;
  user-select: none;
  white-space: nowrap;
}

.production-assistant-gpt-switch input {
  height: 1px;
  opacity: 0;
  position: absolute;
  width: 1px;
}

.production-assistant-switch-track {
  background: linear-gradient(180deg, #f59e0b, #d97706);
  border: 1px solid rgb(120 53 15 / 35%);
  border-radius: 999px;
  box-shadow: inset 0 1px 2px rgb(15 23 42 / 22%);
  display: inline-flex;
  flex: 0 0 auto;
  height: 22px;
  padding: 2px;
  transition: background .18s ease, border-color .18s ease;
  width: 44px;
}

.production-assistant-switch-thumb {
  background: #ffffff;
  border-radius: 999px;
  box-shadow: 0 1px 4px rgb(15 23 42 / 35%);
  display: block;
  height: 16px;
  transform: translateX(0);
  transition: transform .18s ease;
  width: 16px;
}

.production-assistant-gpt-switch.is-gpt-on .production-assistant-switch-track {
  background: linear-gradient(180deg, #22c55e, #16a34a);
  border-color: rgb(22 101 52 / 45%);
}

.production-assistant-gpt-switch.is-gpt-on .production-assistant-switch-thumb {
  transform: translateX(21px);
}

.production-assistant-switch-text {
  color: #475569;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .02em;
}

.production-assistant-gpt-switch.is-gpt-on .production-assistant-switch-text {
  color: #166534;
}

.production-assistant-gpt-switch.is-gpt-off .production-assistant-switch-text {
  color: #92400e;
}

.production-assistant-header strong {
  color: #111827;
  font-size: 14px;
  line-height: 1.2;
}

.production-assistant-status {
  align-items: center;
  color: #5f6f87;
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  gap: 6px;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.production-assistant-status i {
  border-radius: 999px;
  box-shadow: 0 0 0 2px rgb(255 255 255 / 95%);
  display: inline-block;
  flex: 0 0 auto;
  height: 9px;
  width: 9px;
}

.production-assistant-status span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.assistant-status-neutral i {
  background: #94a3b8;
}

.assistant-status-loading i {
  background: #64748b;
}

.assistant-status-openai i {
  background: #16a34a;
}

.assistant-status-assisted i {
  background: #0f9f6e;
}

.assistant-status-protected i {
  background: #0ea5e9;
}

.assistant-status-local i {
  background: #f59e0b;
}

.assistant-status-memoria i {
  background: #2563eb;
}

.assistant-status-error i {
  background: #dc2626;
}

.assistant-status-openai {
  color: #166534;
}

.assistant-status-assisted {
  color: #047857;
}

.assistant-status-protected {
  color: #075985;
}

.assistant-status-local {
  color: #92400e;
}

.assistant-status-memoria {
  color: #1d4ed8;
}

.assistant-status-error {
  color: #991b1b;
}

.production-assistant-close {
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #24364d;
  cursor: pointer;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  min-height: 28px;
  padding: 0 9px;
}

.production-assistant-close:hover {
  background: #f1f5f9;
}

.production-assistant-messages {
  background: #f7f9fc;
  display: grid;
  gap: 8px;
  max-height: 430px;
  overflow-y: auto;
  padding: 12px;
}

.production-assistant-message {
  border: 1px solid #d8e0ea;
  border-radius: 9px;
  color: #142033;
  font-size: 13px;
  line-height: 1.4;
  max-width: 92%;
  padding: 9px 10px;
  white-space: pre-wrap;
}

.production-assistant-message p {
  margin: 0;
}

.production-assistant-message.assistant {
  background: #ffffff;
  justify-self: start;
}

.production-assistant-message.user {
  background: #eef2ff;
  border-color: #c7d2fe;
  justify-self: end;
}

.production-assistant-message.error {
  background: #fff1f2;
  border-color: #fecdd3;
}

.production-assistant-message.loading {
  color: #607089;
  font-weight: 800;
}

.production-assistant-meta {
  border-top: 1px solid rgb(148 163 184 / 35%);
  color: #64748b;
  display: block;
  font-size: 10px;
  font-weight: 800;
  margin-top: 7px;
  padding-top: 6px;
  text-transform: uppercase;
}

.production-assistant-db-check {
  align-items: center;
  background: #ecfdf5;
  border: 1px solid #86efac;
  border-radius: 8px;
  color: #14532d;
  display: flex;
  gap: 7px;
  margin-top: 7px;
  padding: 6px 8px;
}

.production-assistant-db-check-icon {
  align-items: center;
  background: #dcfce7;
  border: 1px solid #bbf7d0;
  border-radius: 7px;
  display: inline-flex;
  flex: 0 0 auto;
  height: 24px;
  justify-content: center;
  width: 24px;
}

.production-assistant-db-check-content {
  display: grid;
  gap: 1px;
  min-width: 0;
}

.production-assistant-db-check-content strong {
  color: #166534;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .02em;
  line-height: 1.1;
  text-transform: uppercase;
}

.production-assistant-db-check-content small {
  color: #14532d;
  font-size: 11px;
  font-weight: 750;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


.production-assistant-message-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.production-assistant-open-link {
  align-items: center;
  background: #2563eb;
  border: 1px solid #1d4ed8;
  border-radius: 7px;
  color: #ffffff !important;
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  gap: 5px;
  min-height: 25px;
  padding: 0 10px;
  text-decoration: none;
  white-space: nowrap;
}

.production-assistant-open-link::before {
  content: "↗";
  font-size: 11px;
  line-height: 1;
}

.production-assistant-open-link:hover {
  background: #1d4ed8;
  border-color: #1e40af;
  color: #ffffff !important;
  text-decoration: none;
}

.production-assistant-trace {
  border-top: 1px solid rgb(148 163 184 / 28%);
  margin-top: 7px;
  padding-top: 6px;
}

.production-assistant-trace-toggle {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #334155;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 10px;
  font-weight: 900;
  gap: 5px;
  min-height: 23px;
  padding: 0 8px;
  text-transform: uppercase;
}

.production-assistant-trace-toggle:hover,
.production-assistant-trace-toggle[aria-expanded="true"] {
  background: #ecfdf5;
  border-color: #86efac;
  color: #166534;
}

.production-assistant-trace-panel {
  background: #f8fafc;
  border: 1px solid #d8e0ea;
  border-radius: 8px;
  margin-top: 6px;
  padding: 8px;
  white-space: normal;
}

.production-assistant-trace-title {
  color: #475569;
  font-size: 10px;
  font-weight: 900;
  margin-bottom: 6px;
  text-transform: uppercase;
}

.production-assistant-trace-list {
  counter-reset: traceStep;
  display: grid;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.production-assistant-trace-step {
  align-items: flex-start;
  border-left: 3px solid #cbd5e1;
  display: grid;
  gap: 7px;
  grid-template-columns: 23px 1fr;
  padding: 2px 0 2px 7px;
}

.production-assistant-trace-step.is-done {
  border-left-color: #16a34a;
}

.production-assistant-trace-step.is-blocked,
.production-assistant-trace-step.is-error {
  border-left-color: #dc2626;
}

.production-assistant-trace-step.is-warning {
  border-left-color: #f59e0b;
}

.production-assistant-trace-step.is-skipped {
  border-left-color: #94a3b8;
  opacity: .78;
}

.production-assistant-trace-icon {
  align-items: center;
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  display: inline-flex;
  font-size: 12px;
  height: 22px;
  justify-content: center;
  line-height: 1;
  width: 22px;
}

.production-assistant-trace-step.is-done .production-assistant-trace-icon {
  background: #dcfce7;
  border-color: #86efac;
}

.production-assistant-trace-step.is-blocked .production-assistant-trace-icon,
.production-assistant-trace-step.is-error .production-assistant-trace-icon {
  background: #fee2e2;
  border-color: #fecaca;
}

.production-assistant-trace-step.is-warning .production-assistant-trace-icon {
  background: #fef3c7;
  border-color: #fde68a;
}

.production-assistant-trace-content {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.production-assistant-trace-content strong {
  color: #142033;
  font-size: 11px;
  font-weight: 900;
  line-height: 1.2;
}

.production-assistant-trace-content em {
  color: #64748b;
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

.production-assistant-trace-content small {
  color: #475569;
  font-size: 10px;
  line-height: 1.35;
}

.production-assistant-feedback {
  align-items: center;
  border-top: 1px solid rgb(148 163 184 / 28%);
  display: flex;
  gap: 6px;
  margin-top: 7px;
  padding-top: 6px;
}

.production-assistant-feedback button {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  color: #24364d;
  cursor: pointer;
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  height: 25px;
  justify-content: center;
  min-width: 31px;
  padding: 0 8px;
}

.production-assistant-feedback button:hover,
.production-assistant-feedback button.active {
  background: #dbeafe;
  border-color: #93c5fd;
}

.production-assistant-feedback span {
  color: #64748b;
  font-size: 10px;
  font-weight: 800;
}

.production-assistant-feedback .production-assistant-review-button {
  background: #fff7ed;
  border-color: #fdba74;
  color: #9a3412;
  min-width: 118px;
}

.production-assistant-feedback .production-assistant-review-button:hover,
.production-assistant-feedback .production-assistant-review-button.active {
  background: #ffedd5;
  border-color: #f97316;
  color: #7c2d12;
}

.production-assistant-feedback.saving {
  opacity: .72;
}


.production-assistant-visual-actions {
  align-items: center;
  background: #f7f9fc;
  border-top: 1px solid #d9e1ec;
  display: flex;
  gap: 7px;
  min-height: 30px;
  padding: 6px 10px 5px;
}

.production-assistant-clear {
  align-items: center;
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #334155;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  gap: 5px;
  min-height: 24px;
  padding: 0 9px;
  white-space: nowrap;
}

.production-assistant-clear::before {
  content: "🧹";
  font-size: 11px;
  line-height: 1;
}

.production-assistant-clear:hover {
  background: #f1f5f9;
  border-color: #94a3b8;
}

.production-assistant-clear:disabled {
  cursor: wait;
  opacity: .62;
}

.production-assistant-clear-help {
  color: #94a3b8;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}



.production-assistant-saved {
  align-items: center;
  background: #eef2ff;
  border: 1px solid #c7d2fe;
  border-radius: 7px;
  color: #24364d;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  gap: 5px;
  min-height: 24px;
  padding: 0 9px;
  white-space: nowrap;
}

.production-assistant-saved::before {
  content: "💾";
  font-size: 11px;
  line-height: 1;
}

.production-assistant-saved:hover {
  background: #e0e7ff;
  border-color: #93c5fd;
}

.production-assistant-saved-modal {
  background: #ffffff;
  border: 1px solid #c8d2e0;
  border-radius: 10px;
  box-shadow: 0 20px 48px rgb(15 23 42 / 28%);
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  max-height: min(680px, calc(100vh - 90px));
  overflow: hidden;
  position: fixed;
  right: 452px;
  top: 72px;
  width: min(760px, calc(100vw - 480px));
  z-index: 1300;
}

.production-assistant-saved-modal header {
  align-items: center;
  background: linear-gradient(180deg, #f8fafc, #eef2f8);
  border-bottom: 1px solid #d9e1ec;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 10px 12px;
}

.production-assistant-saved-modal header div {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.production-assistant-saved-modal header strong {
  color: #111827;
  font-size: 14px;
  font-weight: 900;
}

.production-assistant-saved-modal header span {
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}

.production-assistant-saved-close {
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #24364d;
  cursor: pointer;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  min-height: 28px;
  padding: 0 10px;
}

.production-assistant-saved-tools {
  align-items: center;
  background: #f7f9fc;
  border-bottom: 1px solid #d9e1ec;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  padding: 8px 10px;
}

.production-assistant-saved-tools input {
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #111827;
  flex: 1 1 auto;
  font: inherit;
  font-size: 12px;
  min-height: 30px;
  min-width: 0;
  padding: 5px 8px;
}

.production-assistant-saved-tools span {
  color: #64748b;
  flex: 0 0 auto;
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}

.production-assistant-saved-clean {
  background: #fff7ed;
  border: 1px solid #fdba74;
  border-radius: 7px;
  color: #9a3412;
  cursor: pointer;
  flex: 0 0 auto;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  min-height: 30px;
  padding: 0 10px;
  white-space: nowrap;
}

.production-assistant-saved-clean:hover {
  background: #ffedd5;
  border-color: #fb923c;
}

.production-assistant-saved-clean:disabled {
  cursor: wait;
  opacity: .65;
}

.production-assistant-saved-review-filter {
  background: #ecfdf5;
  border: 1px solid #86efac;
  border-radius: 7px;
  color: #166534;
  cursor: pointer;
  flex: 0 0 auto;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  min-height: 30px;
  padding: 0 10px;
  white-space: nowrap;
}

.production-assistant-saved-review-filter:hover,
.production-assistant-saved-review-filter.active {
  background: #dcfce7;
  border-color: #22c55e;
}

.production-assistant-saved-table-wrap {
  overflow: auto;
}

.production-assistant-saved-table {
  border-collapse: collapse;
  font-size: 12px;
  min-width: 720px;
  width: 100%;
}

.production-assistant-saved-table th,
.production-assistant-saved-table td {
  border-bottom: 1px solid #e2e8f0;
  padding: 7px 8px;
  text-align: left;
  vertical-align: top;
}

.production-assistant-saved-table th {
  background: #f1f5f9;
  color: #334155;
  font-size: 11px;
  font-weight: 900;
  position: sticky;
  text-transform: uppercase;
  top: 0;
  z-index: 1;
}

.production-assistant-saved-num {
  color: #64748b;
  font-weight: 900;
  width: 42px;
}

.production-assistant-saved-state {
  font-weight: 900;
  white-space: nowrap;
  width: 102px;
}

.production-assistant-saved-state.is-review {
  color: #166534;
}

.production-assistant-saved-detail {
  display: grid;
  gap: 4px;
  min-width: 240px;
}

.production-assistant-saved-detail strong {
  color: #0f172a;
  font-size: 12px;
}

.production-assistant-saved-detail span {
  color: #475569;
  font-size: 11px;
  line-height: 1.35;
}

.production-assistant-saved-context,
.production-assistant-saved-date {
  color: #475569;
  font-size: 11px;
}

.production-assistant-saved-actions {
  display: grid;
  gap: 5px;
  min-width: 78px;
}

.production-assistant-saved-actions button {
  background: #b91c1c;
  border: 1px solid #991b1b;
  border-radius: 6px;
  color: #ffffff;
  cursor: pointer;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  min-height: 26px;
  padding: 0 9px;
  width: 100%;
}

.production-assistant-saved-actions button:hover {
  background: #991b1b;
}

.production-assistant-saved-actions button.production-assistant-saved-detail-button {
  background: #ffffff;
  border-color: #93c5fd;
  color: #1d4ed8;
}

.production-assistant-saved-actions button.production-assistant-saved-detail-button:hover {
  background: #eff6ff;
  border-color: #60a5fa;
}

.production-assistant-saved-actions button:disabled {
  cursor: wait;
  opacity: .7;
}

.production-assistant-saved-detail-modal {
  background: #ffffff;
  border: 1px solid #c8d2e0;
  border-radius: 10px;
  box-shadow: 0 20px 48px rgb(15 23 42 / 30%);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  left: 50%;
  max-height: min(680px, calc(100vh - 90px));
  overflow: hidden;
  position: fixed;
  top: 78px;
  transform: translateX(-50%);
  width: min(760px, calc(100vw - 32px));
  z-index: 1310;
}

.production-assistant-saved-detail-modal header {
  align-items: center;
  background: linear-gradient(180deg, #f8fafc, #eef2f8);
  border-bottom: 1px solid #d9e1ec;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 10px 12px;
}

.production-assistant-saved-detail-modal header div {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.production-assistant-saved-detail-modal header strong {
  color: #111827;
  font-size: 14px;
  font-weight: 900;
}

.production-assistant-saved-detail-modal header span {
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}

.production-assistant-saved-detail-modal header button {
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #24364d;
  cursor: pointer;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  min-height: 28px;
  padding: 0 10px;
}

.production-assistant-saved-detail-body {
  display: grid;
  gap: 10px;
  overflow: auto;
  padding: 12px;
}

.production-assistant-saved-detail-block {
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  display: grid;
  gap: 6px;
  padding: 10px;
}

.production-assistant-saved-detail-block > strong {
  color: #334155;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.production-assistant-saved-detail-block pre {
  color: #0f172a;
  font: inherit;
  font-size: 12px;
  line-height: 1.45;
  margin: 0;
  max-height: 260px;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

.production-assistant-saved-detail-block.question {
  background: #eef2ff;
  border-color: #c7d2fe;
}

.production-assistant-saved-detail-block.answer {
  background: #f8fafc;
}

.production-assistant-saved-empty {
  color: #64748b;
  font-weight: 800;
  padding: 18px !important;
  text-align: center !important;
}

@media (max-width: 1240px) {
  .production-assistant-saved-modal {
    left: 14px;
    right: 14px;
    width: auto;
  }
}

@media (max-width: 640px) {
  .production-assistant-saved-modal {
    max-height: calc(100vh - 70px);
    top: 58px;
  }

  .production-assistant-saved-tools {
    align-items: stretch;
    display: grid;
  }
}

.production-assistant-form {
  background: #ffffff;
  border-top: 1px solid #d9e1ec;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 10px;
}

.production-assistant-input {
  border: 1px solid #c5d0de;
  border-radius: 8px;
  color: #111827;
  font: inherit;
  font-size: 13px;
  line-height: 1.35;
  max-height: 120px;
  min-height: 42px;
  min-width: 0;
  padding: 9px 10px;
  resize: vertical;
  width: 100%;
}

.production-assistant-input:focus {
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgb(99 102 241 / 16%);
  outline: none;
}

.production-assistant-send {
  align-items: center;
  background: #24364d;
  border: 1px solid #1e2e42;
  border-radius: 8px;
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  justify-content: center;
  min-height: 42px;
  padding: 0 14px;
  text-align: center;
}

.production-assistant-send:hover {
  background: #172235;
}

.production-assistant-send:disabled {
  background: #9aa7b8;
  border-color: #9aa7b8;
  cursor: not-allowed;
}

@media (max-width: 980px) {
  .assistant-button {
    max-width: 142px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

@media (max-width: 520px) {
  .production-assistant-header {
    align-items: flex-start;
  }

  .production-assistant-header-actions {
    gap: 6px;
  }

  .production-assistant-switch-text {
    display: none;
  }

  .production-assistant-clear-help {
    display: none;
  }
}


/* Permisos: pestañas de usuario/configuración. */
.permissions-tabs {
  align-items: center;
  background: #edf3fb;
  border: 1px solid #cbd5e1;
  border-radius: 9px;
  display: flex;
  gap: 6px;
  padding: 5px;
}

.permissions-tab {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 7px;
  color: #334155;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  min-height: 31px;
  padding: 6px 13px;
}

.permissions-tab:hover {
  background: #fff;
  border-color: #dbeafe;
}

.permissions-tab.is-active {
  background: #0f376e;
  border-color: #0f376e;
  color: #fff;
  box-shadow: 0 1px 4px rgba(15, 55, 110, .22);
}

.permissions-tab-panel {
  display: none;
}

.permissions-tab-panel.is-active {
  display: grid;
  gap: 10px;
}

.permissions-config-panel {
  align-content: start;
}

.permissions-config-intro {
  background: #f8fafc;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  display: grid;
  gap: 3px;
  padding: 9px 10px;
}

.permissions-config-intro strong {
  color: #0f376e;
  font-size: 13px;
  font-weight: 900;
}

.permissions-config-intro span {
  color: #526071;
  font-size: 12px;
}

/* Permisos: configuración segura de clave GPT/OpenAI y conexiones externas. */
.cispro-config-card,
.gpt-key-card,
.sispro-error-log-card {
  align-items: center;
  background: #f8fbff;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(240px, 1fr) minmax(360px, 1.2fr);
  padding: 10px;
}

.gpt-key-info {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.gpt-key-info strong {
  color: #0f376e;
  font-size: 13px;
  font-weight: 900;
}

.gpt-key-info span {
  align-items: center;
  border-radius: 999px;
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  justify-self: start;
  min-height: 24px;
  padding: 3px 9px;
}

.gpt-key-info span.active {
  background: #dcfce7;
  border: 1px solid #86efac;
  color: #166534;
}

.gpt-key-info span.inactive {
  background: #f1f5f9;
  border: 1px solid #cbd5e1;
  color: #475569;
}

.gpt-key-info span.warning {
  background: #fef9c3;
  border: 1px solid #fde68a;
  color: #854d0e;
}

.gpt-key-info small {
  color: #526071;
  font-size: 11px;
  line-height: 1.35;
}

.gpt-key-form {
  align-items: center;
  display: grid;
  gap: 7px;
  grid-template-columns: minmax(190px, 1fr) auto auto;
}

.cispro-config-form {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(130px, 1fr));
}

.cispro-config-form label {
  display: grid;
  gap: 3px;
}

.cispro-config-form .cispro-enabled-toggle {
  align-items: center;
  background: #eef6ff;
  border: 1px solid #bfdbfe;
  border-radius: 7px;
  grid-template-columns: 1fr auto;
  padding: 7px 8px;
}

.cispro-enabled-toggle input[type="checkbox"] {
  height: 18px;
  width: 18px;
}

.cispro-enabled-toggle small {
  color: #526071;
  font-size: 11px;
  grid-column: 1 / -1;
  line-height: 1.3;
}

.cispro-config-form label span {
  color: #334155;
  font-size: 11px;
  font-weight: 900;
}

.cispro-driver-field small {
  color: #526071;
  font-size: 10.5px;
  line-height: 1.25;
}

.cispro-driver-field select {
  min-width: 0;
}

.cispro-config-actions {
  align-items: end;
  display: grid;
  gap: 7px;
  grid-column: 1 / -1;
  grid-template-columns: auto auto auto 1fr;
}

.gpt-key-form .client-tool,
.cispro-config-actions .client-tool {
  white-space: nowrap;
}

.client-tool.danger {
  background: #fee2e2;
  border-color: #fecaca;
  color: #991b1b;
}

.client-tool.danger:hover {
  background: #fecaca;
}


.sispro-error-log-card {
  align-items: start;
}

.sispro-error-log-body {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.sispro-error-log-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.sispro-error-log-list {
  background: #ffffff;
  border: 1px solid #dbeafe;
  border-radius: 7px;
  display: grid;
  gap: 7px;
  max-height: 280px;
  overflow: auto;
  padding: 8px;
}

.sispro-error-log-list em {
  color: #64748b;
  font-size: 12px;
}

.sispro-error-item {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 7px;
  display: grid;
  gap: 5px;
  padding: 8px;
}

.sispro-error-head {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.sispro-error-head strong {
  color: #7c2d12;
  font-size: 12px;
  font-weight: 900;
}

.sispro-error-head span,
.sispro-error-head mark {
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  padding: 2px 7px;
}

.sispro-error-head span {
  background: #ffedd5;
  color: #9a3412;
}

.sispro-error-head mark {
  background: #fee2e2;
  color: #991b1b;
}

.sispro-error-item p {
  color: #7f1d1d;
  font-size: 12px;
  font-weight: 800;
  margin: 0;
}

.sispro-error-item pre {
  background: #fff;
  border: 1px solid #fed7aa;
  border-radius: 5px;
  color: #334155;
  font-size: 11px;
  margin: 0;
  max-height: 90px;
  overflow: auto;
  padding: 6px;
  white-space: pre-wrap;
}

.sispro-error-item small {
  color: #64748b;
  font-size: 10.5px;
}

@media (max-width: 900px) {
  .cispro-config-card,
  .gpt-key-card,
  .sispro-error-log-card,
  .gpt-key-form,
  .cispro-config-form,
  .cispro-config-actions {
    grid-template-columns: 1fr;
  }

  .gpt-key-form .client-tool,
  .cispro-config-actions .client-tool {
    width: 100%;
  }
}


/* Asistente Producción: los avisos/toasts nunca deben quedar tapados por el chat. */
.toast-stack,
#toast-container,
.toast-container,
.toastify,
.Toastify__toast-container {
  z-index: 1300 !important;
}

@media (min-width: 920px) {
  body.production-assistant-is-open .toast-stack,
  body.production-assistant-is-open #toast-container,
  body.production-assistant-is-open .toast-container,
  body.production-assistant-is-open .toastify,
  body.production-assistant-is-open .Toastify__toast-container {
    right: calc(min(420px, calc(100vw - 28px)) + 34px) !important;
  }
}

@media (max-width: 919px) {
  body.production-assistant-is-open .toast-stack,
  body.production-assistant-is-open #toast-container,
  body.production-assistant-is-open .toast-container,
  body.production-assistant-is-open .toastify,
  body.production-assistant-is-open .Toastify__toast-container {
    z-index: 1300 !important;
  }
}

/* Asistente Producción - clasificación de memoria guardada */
.production-assistant-saved-type {
  width: 118px;
}

.production-assistant-saved-type span {
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  display: inline-block;
  font-size: 10px;
  font-weight: 900;
  line-height: 1.2;
  max-width: 118px;
  padding: 4px 7px;
  white-space: normal;
}

.production-assistant-saved-type.safe span {
  background: #ecfdf5;
  border-color: #86efac;
  color: #166534;
}

.production-assistant-saved-type.blocked span {
  background: #fff7ed;
  border-color: #fdba74;
  color: #9a3412;
}

.production-assistant-saved-detail-block pre {
  white-space: pre-wrap;
}

.ot-cispro-actions {
  display: grid;
  gap: 6px;
  width: 100%;
}

.ot-cispro-actions .button {
  min-width: 0;
  width: 100%;
}

.ot-cispro-actions .sispro-action-disabled,
.ot-cispro-actions .sispro-action-disabled:hover {
  background: #e5e7eb;
  border-color: #cbd5e1;
  color: #64748b;
  cursor: not-allowed;
}

/* Panel Sispro */
.sispro-panel-window {
  max-width: 1420px;
  margin-inline: auto;
}
.sispro-panel-header {
  align-items: flex-start;
}
.sispro-panel-query-card,
.sispro-sql-helper,
.sispro-latest-card,
.sispro-table-box,
.sispro-panel-link-card {
  border: 1px solid #b7d0f3;
  border-radius: 10px;
  background: linear-gradient(180deg, #f8fbff 0%, #eef6ff 100%);
  padding: 12px;
  margin: 10px 0;
  box-shadow: 0 1px 2px rgba(17, 42, 78, 0.06);
}
.sispro-panel-search {
  display: grid;
  grid-template-columns: minmax(180px, 260px) auto auto auto 1fr;
  gap: 8px;
  align-items: end;
}
.sispro-panel-search label {
  display: grid;
  gap: 3px;
  color: #0a376d;
  font-size: 12px;
  font-weight: 800;
}
.sispro-panel-status {
  margin-top: 8px;
  border-radius: 9px;
  padding: 8px 10px;
  background: #eef2f7;
  color: #274060;
  font-weight: 700;
}
.sispro-panel-status[data-state="ok"] {
  background: #dcfce7;
  color: #166534;
  border: 1px solid #86efac;
}
.sispro-panel-status[data-state="error"] {
  background: #fee2e2;
  color: #991b1b;
  border: 1px solid #fecaca;
}
.sispro-panel-status[data-state="loading"] {
  background: #e0f2fe;
  color: #075985;
  border: 1px solid #bae6fd;
}
.sispro-panel-summary {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) repeat(3, minmax(110px, 150px));
  gap: 8px;
  margin-top: 10px;
}
.sispro-panel-summary article {
  border: 1px solid #d5e3f7;
  background: #fff;
  border-radius: 9px;
  padding: 9px;
  display: grid;
  gap: 3px;
}
.sispro-panel-summary strong {
  color: #083b7b;
  font-size: 17px;
}
.sispro-panel-summary span {
  color: #3f5878;
  font-size: 12px;
}
.sispro-sql-helper summary {
  cursor: pointer;
  color: #0b3a7a;
  font-weight: 800;
}
.sispro-sql-helper pre {
  margin: 10px 0 0;
  max-height: 360px;
  overflow: auto;
  border: 1px solid #d6e1f1;
  border-radius: 8px;
  background: #08111f;
  color: #dcecff;
  padding: 12px;
  white-space: pre-wrap;
}
.sispro-latest-card h2,
.sispro-table-box h2 {
  margin: 0;
  color: #083b7b;
  font-size: 16px;
}
.sispro-latest-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 8px;
  margin-top: 10px;
}
.sispro-latest-item {
  border: 1px solid #bdd4f1;
  border-radius: 10px;
  background: #ffffff;
  color: #12345d;
  text-align: left;
  padding: 9px;
  display: grid;
  gap: 3px;
  cursor: pointer;
}
.sispro-latest-item:hover {
  outline: 2px solid #93c5fd;
}
.sispro-latest-item strong {
  color: #063d80;
}
.sispro-latest-item span,
.sispro-latest-item small,
.sispro-latest-item em {
  font-size: 12px;
}
.sispro-tables-card {
  display: grid;
  gap: 12px;
}
.sispro-table-box header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.sispro-table-box header span {
  color: #365273;
  font-size: 12px;
  font-weight: 700;
}
.sispro-table-box.missing {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a3412;
}
.sispro-data-table-wrap {
  max-height: 420px;
  overflow: auto;
  border-radius: 8px;
}
.sispro-data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.sispro-data-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #0b3a7a;
  color: #fff;
  padding: 6px 7px;
  text-align: left;
  white-space: nowrap;
}
.sispro-data-table th small {
  margin-left: 4px;
  color: #dbeafe;
  font-size: 10px;
  font-weight: 600;
}
.sispro-data-table td {
  border: 1px solid #dbe6f4;
  background: #fff;
  padding: 3px;
  min-width: 88px;
  vertical-align: middle;
}
.sispro-data-table tr:nth-child(even) td {
  background: #f8fbff;
}
.sispro-cell-input {
  min-width: 120px;
  width: 100%;
  height: 26px;
  font-size: 12px;
  background: #fffef3;
}
.sispro-cell-readonly {
  display: inline-block;
  max-width: 360px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #253c59;
}
.sispro-panel-window.is-loading {
  cursor: progress;
}
@media (max-width: 900px) {
  .sispro-panel-search,
  .sispro-panel-summary {
    grid-template-columns: 1fr;
  }
}

/* Ajuste final Panel Sispro: marco fijo 1420px y scroll interno de grillas */
.page:has(.sispro-panel-window) {
  max-width: min(1452px, calc(100vw - 24px));
  padding-left: 12px;
  padding-right: 12px;
  overflow-x: hidden;
}

.sispro-panel-window {
  width: 100%;
  max-width: 1420px !important;
  margin-left: auto;
  margin-right: auto;
  padding: 12px;
  border: 1px solid #b7d0f3;
  border-radius: 14px;
  background: linear-gradient(180deg, #f9fcff 0%, #f3f8ff 100%);
  box-shadow: 0 1px 3px rgba(17, 42, 78, 0.08);
  overflow: hidden;
}

.sispro-panel-window,
.sispro-panel-window * {
  min-width: 0;
}

.sispro-panel-header,
.sispro-panel-query-card,
.sispro-sql-helper,
.sispro-latest-card,
.sispro-tables-card,
.sispro-table-box,
.sispro-panel-link-card {
  max-width: 100%;
  min-width: 0;
}

.sispro-panel-query-card,
.sispro-sql-helper,
.sispro-latest-card,
.sispro-table-box,
.sispro-panel-link-card {
  overflow: hidden;
}

.sispro-tables-card {
  width: 100%;
  overflow: hidden;
}

.sispro-table-box {
  width: 100%;
}

.sispro-table-box header {
  min-width: 0;
}

.sispro-data-table-wrap {
  width: 100%;
  max-width: 100%;
  max-height: 420px;
  overflow: auto;
  border: 1px solid #d6e3f3;
  border-radius: 8px;
  background: #ffffff;
}

.sispro-data-table {
  width: max-content;
  min-width: 100%;
  max-width: none;
}

.sispro-data-table th,
.sispro-data-table td {
  min-width: 72px;
  max-width: 240px;
}

.sispro-cell-input {
  min-width: 0;
  max-width: 220px;
  width: 100%;
}

.sispro-cell-readonly {
  max-width: 220px;
}

/* Asistente Producción: modo enseñanza IA */
.production-assistant-instructions {
  align-items: center;
  background: #f5f3ff;
  border: 1px solid #c4b5fd;
  border-radius: 7px;
  color: #5b21b6;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  gap: 5px;
  min-height: 24px;
  padding: 0 9px;
  white-space: nowrap;
}

.production-assistant-instructions::before {
  content: "🧠";
  font-size: 11px;
  line-height: 1;
}

.production-assistant-instructions:hover {
  background: #ede9fe;
  border-color: #a78bfa;
}

.production-assistant-form {
  grid-template-columns: auto minmax(0, 1fr) auto;
}

.production-assistant-ia-toggle {
  align-items: center;
  align-self: stretch;
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  color: #334155;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 12px;
  font-weight: 950;
  justify-content: center;
  min-height: 42px;
  min-width: 42px;
  padding: 0 10px;
}

.production-assistant-ia-toggle:hover {
  background: #f8fafc;
  border-color: #94a3b8;
}

.production-assistant-ia-toggle.active,
.production-assistant-panel.is-instruction-mode .production-assistant-ia-toggle {
  background: linear-gradient(180deg, #7c3aed, #5b21b6);
  border-color: #6d28d9;
  color: #ffffff;
  box-shadow: 0 0 0 3px rgb(124 58 237 / 13%);
}

.production-assistant-panel.is-instruction-mode .production-assistant-input {
  border-color: #8b5cf6;
  box-shadow: 0 0 0 3px rgb(139 92 246 / 13%);
}

.production-assistant-panel.is-instruction-mode .production-assistant-send {
  background: #5b21b6;
  border-color: #4c1d95;
}

.assistant-status-instruccion i {
  background: #7c3aed;
}

.assistant-status-instruccion {
  color: #5b21b6;
}

.production-assistant-instructions-modal .production-assistant-saved-type span {
  background: #f5f3ff;
  border: 1px solid #ddd6fe;
  border-radius: 999px;
  color: #5b21b6;
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  padding: 2px 7px;
}

.production-assistant-instruction-toggle-button {
  background: #ffffff !important;
  border-color: #93c5fd !important;
  color: #1d4ed8 !important;
}

.production-assistant-instruction-toggle-button:hover {
  background: #eff6ff !important;
}

@media (max-width: 520px) {
  .production-assistant-form {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .production-assistant-send {
    grid-column: 1 / -1;
  }
}

/* Asistente Producción - botón superior compacto con icono */
.assistant-button.assistant-icon-button {
  border-radius: 10px;
  min-height: 34px;
  min-width: 42px;
  padding: 0 10px;
  gap: 7px;
}

.assistant-button-icon {
  align-items: center;
  background: rgb(255 255 255 / 10%);
  border: 1px solid rgb(255 255 255 / 18%);
  border-radius: 9px;
  display: inline-flex;
  height: 24px;
  justify-content: center;
  width: 24px;
}

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

.assistant-icon-bubble {
  fill: #ffffff;
  opacity: .96;
}

.assistant-icon-spark {
  fill: #365fd3;
}

.assistant-button-text {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.assistant-button.assistant-icon-button:hover .assistant-button-icon,
.assistant-button.assistant-icon-button[aria-expanded="true"] .assistant-button-icon {
  background: rgb(255 255 255 / 16%);
  transform: translateY(-1px);
}

/* Asistente Producción - guía rápida y preguntas sugeridas */
.production-assistant-panel {
  grid-template-rows: auto auto minmax(170px, 1fr) auto auto;
}

.production-assistant-guidebar {
  align-items: center;
  background: #f8fafc;
  border-bottom: 1px solid #d9e1ec;
  display: flex;
  gap: 7px;
  padding: 7px 10px;
  position: relative;
}

.production-assistant-help-button,
.production-assistant-suggestions > summary {
  align-items: center;
  background: #ffffff;
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #24364d;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  gap: 5px;
  min-height: 26px;
  padding: 0 9px;
  white-space: nowrap;
}

.production-assistant-help-button {
  background: #ecfeff;
  border-color: #a5f3fc;
  color: #155e75;
}

.production-assistant-help-button:hover,
.production-assistant-suggestions > summary:hover,
.production-assistant-suggestions[open] > summary {
  background: #eef2ff;
  border-color: #c7d2fe;
  color: #3730a3;
}

.production-assistant-suggestions {
  position: relative;
}

.production-assistant-suggestions > summary {
  list-style: none;
}

.production-assistant-suggestions > summary::-webkit-details-marker {
  display: none;
}

.production-assistant-suggestions > summary::after {
  color: #64748b;
  content: "▾";
  font-size: 10px;
  line-height: 1;
}

.production-assistant-suggestions[open] > summary::after {
  content: "▴";
}

.production-assistant-suggestions-panel {
  background: #ffffff;
  border: 1px solid #c8d2e0;
  border-radius: 10px;
  box-shadow: 0 16px 34px rgb(15 23 42 / 18%);
  display: grid;
  gap: 9px;
  left: 0;
  max-height: min(430px, calc(100vh - 180px));
  overflow-y: auto;
  padding: 10px;
  position: absolute;
  top: calc(100% + 8px);
  width: min(390px, calc(100vw - 48px));
  z-index: 5;
}

.production-assistant-suggestions-panel section {
  border-bottom: 1px solid #e2e8f0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-bottom: 8px;
}

.production-assistant-suggestions-panel section:last-of-type {
  border-bottom: 0;
  padding-bottom: 0;
}

.production-assistant-suggestions-panel h3 {
  color: #334155;
  flex: 0 0 100%;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .02em;
  margin: 0 0 1px;
  text-transform: uppercase;
}

.production-assistant-suggestions-panel button {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  color: #24364d;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 10px;
  font-weight: 850;
  min-height: 24px;
  padding: 0 9px;
  white-space: nowrap;
}

.production-assistant-suggestions-panel button:hover {
  background: #dbeafe;
  border-color: #93c5fd;
  color: #1e3a8a;
}

.production-assistant-suggestions-panel p {
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
  border-radius: 8px;
  color: #64748b;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.35;
  margin: 0;
  padding: 7px 8px;
}

@media (max-width: 720px) {
  .production-assistant-guidebar {
    align-items: stretch;
    flex-wrap: wrap;
  }

  .production-assistant-suggestions-panel {
    left: -90px;
    width: min(360px, calc(100vw - 36px));
  }
}

/* Fix Etapa 11: desplegable de preguntas sugeridas dentro del ancho del asistente */
.production-assistant-suggestions {
  position: static;
}

.production-assistant-suggestions-panel {
  left: 10px;
  right: 10px;
  width: auto;
  max-width: none;
  overflow-x: hidden;
  overflow-y: auto;
  z-index: 50;
}

.production-assistant-suggestions-tools {
  align-items: center;
  background: #ffffff;
  border-bottom: 1px solid #e2e8f0;
  display: flex;
  gap: 8px;
  padding-bottom: 8px;
  position: sticky;
  top: 0;
  z-index: 1;
}

.production-assistant-suggestions-tools input {
  border: 1px solid #cbd5e1;
  border-radius: 7px;
  color: #0f172a;
  flex: 1 1 auto;
  font: inherit;
  min-height: 30px;
  min-width: 160px;
  padding: 6px 9px;
}

.production-assistant-suggestions-tools input:focus {
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgb(37 99 235 / 12%);
  outline: 0;
}

.production-assistant-suggestions-tools span,
.production-assistant-suggestions-note {
  color: #64748b;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.3;
}

.production-assistant-suggestions-panel section {
  align-items: flex-start;
  gap: 6px;
}

.production-assistant-suggestions-panel button {
  flex: 0 1 auto;
  max-width: 100%;
  min-height: 25px;
  height: auto;
  line-height: 1.15;
  padding: 5px 9px;
  text-align: left;
  white-space: normal;
}

.production-assistant-suggestions-panel h3 {
  width: 100%;
}

.production-assistant-suggestions-note {
  flex: 0 0 100%;
  margin: -2px 0 2px;
}

@media (max-width: 720px) {
  .production-assistant-suggestions-panel {
    left: 8px;
    right: 8px;
    width: auto;
  }
}

/* Asistente IA - formato enriquecido de respuestas */
.production-assistant-message.assistant {
  max-width: 94%;
  padding: 8px;
  white-space: normal;
}

.production-assistant-message.assistant > p {
  white-space: pre-wrap;
}

.production-assistant-rich {
  display: grid;
  gap: 7px;
  white-space: normal;
}

.production-assistant-rich p {
  margin: 0;
}

.production-assistant-response-intro,
.production-assistant-response-card {
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 8px 9px;
}

.production-assistant-response-intro {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  color: #24364d;
}

.production-assistant-response-card {
  background: #f8fafc;
  box-shadow: 0 1px 0 rgb(15 23 42 / 3%);
}

.production-assistant-response-card.is-summary {
  background: #eef6ff;
  border-color: #bfdbfe;
}

.production-assistant-response-card.is-group {
  background: #ffffff;
  border-color: #dbe6f4;
}

.production-assistant-response-card.is-note {
  background: #fffbeb;
  border-color: #fde68a;
  color: #78350f;
  font-style: italic;
}

.production-assistant-response-title {
  align-items: center;
  color: #334155;
  display: flex;
  font-size: 11px;
  font-weight: 950;
  gap: 6px;
  letter-spacing: .02em;
  margin-bottom: 6px;
  text-transform: uppercase;
}

.production-assistant-response-title::before {
  background: #2563eb;
  border-radius: 999px;
  content: "";
  display: inline-block;
  height: 7px;
  width: 7px;
}

.production-assistant-response-card.is-summary .production-assistant-response-title::before {
  background: #0ea5e9;
}

.production-assistant-response-card.is-note .production-assistant-response-title::before {
  background: #f59e0b;
}

.production-assistant-response-list {
  display: grid;
  gap: 4px;
  margin: 0;
  padding-left: 18px;
}

.production-assistant-response-list + p,
.production-assistant-rich p + .production-assistant-response-list,
.production-assistant-response-card p + p,
.production-assistant-response-card p + .production-assistant-response-list {
  margin-top: 6px;
}

.production-assistant-response-list li {
  padding-left: 2px;
}

.production-assistant-response-list li::marker {
  color: #64748b;
  font-weight: 900;
}

.production-assistant-response-muted {
  color: #64748b;
  font-style: italic;
}

.production-assistant-rich strong {
  color: #0f172a;
  font-weight: 950;
}

.production-assistant-inline-ot {
  background: #e0f2fe;
  border: 1px solid #bae6fd;
  border-radius: 999px;
  color: #075985 !important;
  display: inline-flex;
  font-size: 11px;
  font-weight: 950;
  line-height: 1.25;
  padding: 0 5px;
  white-space: nowrap;
}

/* Etapa 15 - textos predictivos para preguntas sugeridas del asistente */
.production-assistant-form {
  position: relative;
}

.production-assistant-predictive {
  background: #f8fafc;
  border: 1px solid #d7dde8;
  border-radius: 10px;
  bottom: calc(100% + 7px);
  box-shadow: 0 10px 24px rgb(15 23 42 / 12%);
  display: grid;
  gap: 3px;
  left: 12px;
  max-height: min(265px, calc(100vh - 240px));
  overflow: auto;
  padding: 7px;
  position: absolute;
  right: 12px;
  z-index: 80;
}

.production-assistant-predictive[hidden] {
  display: none;
}

.production-assistant-predictive-header {
  align-items: center;
  background: #eef2f6;
  border: 0;
  border-radius: 8px;
  color: #334155;
  display: flex;
  gap: 8px;
  justify-content: space-between;
  margin-bottom: 3px;
  padding: 6px 8px;
}

.production-assistant-predictive-header strong {
  color: #1f2937;
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .015em;
  text-transform: uppercase;
}

.production-assistant-predictive-header span {
  color: #64748b;
  font-size: 10px;
  font-weight: 700;
  white-space: nowrap;
}

.production-assistant-predictive button {
  align-items: center;
  background: transparent;
  border: 0;
  border-radius: 8px;
  color: #111827;
  cursor: pointer;
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) auto;
  min-height: 31px;
  padding: 7px 8px;
  text-align: left;
  transition: background .12s ease, box-shadow .12s ease, color .12s ease;
  width: 100%;
}

.production-assistant-predictive button + button {
  border-top: 1px solid #e5e7eb;
  border-radius: 0;
}

.production-assistant-predictive button:hover,
.production-assistant-predictive button.is-active {
  background: #e5e7eb;
  box-shadow: inset 3px 0 0 #64748b;
  color: #0f172a;
}

.production-assistant-predictive-text {
  font-size: 12px;
  font-weight: 750;
  line-height: 1.25;
  min-width: 0;
}

.production-assistant-predictive small {
  background: #edf2f7;
  border: 1px solid #d9e1ea;
  border-radius: 999px;
  color: #475569;
  font-size: 9px;
  font-weight: 800;
  line-height: 1;
  max-width: 128px;
  overflow: hidden;
  padding: 4px 7px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.production-assistant-predictive button:hover small,
.production-assistant-predictive button.is-active small {
  background: #f8fafc;
  border-color: #cbd5e1;
  color: #334155;
}

.production-assistant-panel.is-instruction-mode .production-assistant-predictive {
  display: none !important;
}

/* Etapa 18 - textos predictivos: selección sobria sin barra lateral */
.production-assistant-predictive button {
  border-radius: 0;
}

.production-assistant-predictive button:first-of-type {
  border-radius: 0;
}

.production-assistant-predictive button:hover,
.production-assistant-predictive button.is-active {
  background: #e5e7eb;
  box-shadow: none;
  color: #0f172a;
}

.production-assistant-predictive button:focus-visible {
  outline: 1px solid #cbd5e1;
  outline-offset: -1px;
}

@media (max-width: 720px) {
  .production-assistant-predictive-header {
    align-items: flex-start;
    display: grid;
  }

  .production-assistant-predictive-header span {
    white-space: normal;
  }

  .production-assistant-predictive button {
    grid-template-columns: minmax(0, 1fr);
  }

  .production-assistant-predictive small {
    max-width: 100%;
    width: fit-content;
  }
}

/* O.Trabajo / Pliegos: layout operativo con estilo moderno Aramis */
.ot-pliegos-fox {
  background: #f8fafc;
  border: 1px solid #d7e0ea;
  border-radius: 12px;
  box-shadow: 0 10px 24px rgb(15 23 42 / 6%);
  color: #111827;
  gap: 10px;
  max-width: 1024px;
  padding: 10px;
}

.ot-pliegos-fox-head,
.ot-pliego-fox-toolbar,
.ot-pliegos-fox-actions,
.ot-pliego-fox-toolbar-actions,
.ot-fox-stock-row,
.ot-fox-bottom-actions {
  align-items: center;
  display: flex;
  gap: 8px;
}

.ot-pliegos-fox-head,
.ot-pliego-fox-toolbar {
  justify-content: space-between;
}

.ot-pliegos-fox-head {
  background: #ffffff;
  border: 1px solid #d7e0ea;
  border-radius: 10px;
  box-shadow: 0 4px 14px rgb(15 23 42 / 4%);
  padding: 9px 10px;
}

.ot-pliegos-fox-head h2,
.ot-pliegos-fox-head p,
.ot-pliego-fox-title strong,
.ot-pliego-fox-title span {
  margin: 0;
}

.ot-pliegos-fox-head h2,
.ot-fox-panel h3,
.ot-fox-field > span,
.ot-fox-panel label > span,
.ot-fox-stock-row span {
  color: #12376f;
  font-weight: 900;
}

.ot-pliegos-fox-head h2 {
  font-size: 18px;
}

.ot-pliegos-fox-head p,
.ot-pliego-fox-title span {
  color: #64748b;
  font-size: 12px;
}

.ot-pliegos-fox .button,
.ot-pliegos-fox .danger-button {
  align-items: center;
  border-radius: 7px;
  justify-content: center;
  min-height: 32px;
  padding: 6px 11px;
}

.ot-pliegos-fox .button {
  background: var(--accent);
  color: #ffffff;
}

.ot-pliegos-fox .button:hover {
  background: var(--accent-dark);
}

.ot-pliegos-fox .danger-button {
  background: #b5473f;
  color: #ffffff;
}

.ot-pliegos-fox .danger-button:hover {
  background: #8f342e;
}

.ot-pliegos-fox-summary {
  gap: 8px;
  grid-template-columns: 105px 80px 125px 88px minmax(0, 1fr);
}

.ot-pliegos-fox-summary div {
  background: #ffffff;
  border: 1px solid #d7e0ea;
  border-radius: 9px;
  box-shadow: 0 4px 12px rgb(15 23 42 / 4%);
  min-height: 48px;
  padding: 7px 9px;
}

.ot-pliegos-fox-list {
  display: grid;
  gap: 10px;
}

.ot-pliego-fox-card {
  background: #ffffff;
  border: 1px solid #d7e0ea;
  border-radius: 12px;
  box-shadow: 0 8px 20px rgb(15 23 42 / 5%);
  display: grid;
  gap: 9px;
  padding: 9px;
}

.ot-pliego-fox-toolbar {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 8px;
}

.ot-pliego-fox-title {
  display: grid;
  gap: 2px;
}

.ot-pliego-fox-title strong {
  color: #0f2f6b;
  font-size: 15px;
}

.ot-pliego-fox-form {
  display: grid;
  gap: 9px;
}

.ot-pliego-fox-main-fields {
  align-items: end;
  background: #f8fafc;
  border: 1px solid #d7e0ea;
  border-radius: 10px;
  display: grid;
  gap: 8px;
  grid-template-columns: 82px minmax(220px, 1fr) minmax(210px, 1fr) 70px 86px 88px;
  padding: 9px;
}

.ot-fox-field,
.ot-fox-panel label {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.ot-fox-field > span,
.ot-fox-panel label > span,
.ot-fox-stock-row span {
  font-size: 12px;
  line-height: 1.1;
}

.ot-pliegos-fox .grid-input,
.ot-pliegos-fox input:not([type="checkbox"]) {
  background: #ffffff;
  border: 1px solid #b7c5d5;
  border-radius: 5px;
  box-shadow: none;
  color: #111827;
  min-height: 30px;
  padding: 4px 7px;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}

.ot-pliegos-fox .grid-input:focus,
.ot-pliegos-fox input:not([type="checkbox"]):focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgb(23 107 95 / 13%);
  outline: 0;
}

.ot-pliegos-fox .number-input,
.ot-fox-two-inputs input,
.ot-fox-dem-row input {
  text-align: right;
}

.ot-pliegos-fox input[readonly] {
  background: #eef2f7;
  color: #334155;
}

.ot-pliego-fox-body-grid {
  display: grid;
  gap: 9px;
  grid-template-columns: 270px minmax(350px, 1fr) 300px;
}

.ot-fox-panel {
  background: #ffffff;
  border: 1px solid #d7e0ea;
  border-radius: 10px;
  box-shadow: 0 4px 14px rgb(15 23 42 / 4%);
  display: grid;
  gap: 8px;
  padding: 10px;
}

.ot-fox-panel h3 {
  align-items: center;
  border-bottom: 1px solid #e2e8f0;
  display: flex;
  font-size: 15px;
  justify-content: space-between;
  margin: 0 0 2px;
  padding-bottom: 6px;
}

.ot-fox-panel h3 small {
  align-items: center;
  color: #111827;
  display: flex;
  font-size: 12px;
  font-weight: 800;
  gap: 6px;
}

.ot-fox-panel h3 small input {
  width: 64px;
}

.ot-fox-hoja-panel label,
.ot-fox-pliego-panel > label {
  align-items: center;
  display: grid;
  gap: 7px;
  grid-template-columns: 108px minmax(0, 1fr);
}

.ot-fox-two-inputs {
  align-items: end;
  display: grid;
  gap: 4px;
  grid-template-columns: minmax(0, 1fr) 12px minmax(0, 1fr);
}

.ot-fox-two-inputs > em,
.ot-fox-dem-row > b {
  align-self: center;
  color: #111827;
  font-style: normal;
  font-weight: 900;
  text-align: center;
}

.ot-fox-dem-row {
  align-items: center;
  display: grid;
  gap: 5px;
  grid-template-columns: minmax(0, 1fr) 12px 78px;
}

.ot-fox-checkline {
  align-items: center !important;
  display: flex !important;
  gap: 6px !important;
}

.ot-fox-checkline > span {
  min-width: 92px;
}

.ot-fox-checkline em {
  color: #111827;
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.ot-fox-material-panel {
  gap: 7px;
}

.ot-fox-material-tabs {
  background: #eef2f7;
  border: 1px solid #d7e0ea;
  border-radius: 9px;
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 4px;
}

.ot-fox-material-tabs button {
  background: transparent;
  border: 0;
  border-radius: 7px;
  color: #64748b;
  cursor: default;
  font-weight: 900;
  min-height: 28px;
  padding: 5px 7px;
}

.ot-fox-material-tabs button:hover {
  background: transparent;
}

.ot-fox-material-tabs button.is-active {
  background: #ffffff;
  box-shadow: 0 2px 6px rgb(15 23 42 / 8%);
  color: #12376f;
}

.ot-fox-material-tabs button:disabled:not(.is-active) {
  color: #94a3b8;
  opacity: 1;
}

.ot-fox-material-panel > label {
  grid-template-columns: 88px minmax(0, 1fr);
}

.ot-fox-material-subgrid {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ot-fox-material-subgrid > label {
  grid-template-columns: 76px minmax(0, 1fr);
}

.ot-fox-two-inputs.compact label {
  display: grid;
  gap: 3px;
}

.ot-fox-separaciones-row {
  align-items: end;
  background: #f8fafc;
  border: 1px solid #d7e0ea;
  border-radius: 10px;
  display: grid;
  gap: 8px;
  grid-template-columns: 72px 72px 82px 82px 82px 86px;
  padding: 8px;
}

.ot-fox-separaciones-row label {
  align-items: center;
  display: grid;
  gap: 4px;
  grid-template-columns: auto minmax(0, 1fr);
}

.ot-fox-separaciones-row span {
  color: #12376f;
  font-size: 12px;
  font-weight: 900;
}

.ot-fox-stock-row {
  background: #f8fafc;
  border: 1px solid #d7e0ea;
  border-radius: 10px;
  padding: 8px;
}

.ot-fox-stock-row label {
  align-items: center;
  display: flex;
  gap: 5px;
}

.ot-fox-stock-row .button {
  margin-left: auto;
  min-width: 150px;
}

.ot-fox-reference-image {
  background: #eef2f7;
  border: 1px solid #d7e0ea;
  border-radius: 10px;
  box-shadow: 0 4px 14px rgb(15 23 42 / 4%);
  height: 128px;
  overflow: hidden;
  position: relative;
}

.ot-fox-reference-image img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.ot-fox-reference-image.is-missing::after {
  align-items: center;
  color: #12376f;
  content: attr(data-fallback);
  display: flex;
  font-weight: 900;
  inset: 0;
  justify-content: center;
  position: absolute;
}

.ot-fox-bottom-actions {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding-top: 2px;
}

.ot-fox-bottom-actions .button {
  background: var(--accent);
  border: 0;
  color: #ffffff;
  font-size: 13px;
  font-weight: 900;
  min-height: 36px;
  width: 100%;
}

.ot-fox-bottom-actions .button:hover {
  background: var(--accent-dark);
}

.ot-pliegos-fox-empty {
  background: #ffffff;
  border-color: #d7e0ea;
  border-radius: 10px;
  box-shadow: 0 4px 14px rgb(15 23 42 / 4%);
}

@media (max-width: 1120px) {
  .ot-pliego-fox-main-fields,
  .ot-pliego-fox-body-grid,
  .ot-fox-bottom-actions,
  .ot-pliegos-fox-summary {
    grid-template-columns: 1fr 1fr;
  }

  .ot-fox-material-panel,
  .ot-pliego-fox-main-fields .ot-fox-field-name,
  .ot-pliego-fox-main-fields .ot-fox-field-medidas {
    grid-column: 1 / -1;
  }
}

@media (max-width: 720px) {
  .ot-pliegos-fox-head,
  .ot-pliego-fox-toolbar,
  .ot-pliegos-fox-actions,
  .ot-pliego-fox-toolbar-actions,
  .ot-fox-stock-row {
    align-items: stretch;
    display: grid;
  }

  .ot-pliego-fox-main-fields,
  .ot-pliego-fox-body-grid,
  .ot-fox-material-subgrid,
  .ot-fox-bottom-actions,
  .ot-fox-separaciones-row,
  .ot-pliegos-fox-summary {
    grid-template-columns: 1fr;
  }

  .ot-fox-panel h3,
  .ot-fox-panel h3 small {
    align-items: flex-start;
    display: grid;
  }
}

/* OT > Pliegos > Dibujo del pliego: botonera estable y marcas de líneas editadas */
.ot-pliego-dibujo-dialog {
  max-height: calc(100vh - 24px);
  overflow: auto;
}

.ot-pliego-dibujo-dialog .client-tool,
.ot-pliego-dibujo-dialog .button,
.ot-pliego-dibujo-dialog button {
  transform: none !important;
  transition: none !important;
}

.ot-pliego-dibujo-dialog .client-tool:hover,
.ot-pliego-dibujo-dialog .button:hover,
.ot-pliego-dibujo-dialog button:hover {
  transform: none !important;
}

.ot-pliego-dibujo-dialog .cut-line-buttons {
  align-content: start;
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-height: 180px;
  overflow-y: auto;
  padding: 2px;
}

.ot-pliego-dibujo-dialog .cut-line-pick {
  background: #f8fafc;
  border: 1px solid #b7c7df;
  border-radius: 8px;
  box-shadow: none;
  color: #12376f;
  height: 34px;
  min-height: 34px;
  min-width: 0;
  padding: 0;
  position: relative;
  width: 100%;
}

.ot-pliego-dibujo-dialog .cut-line-pick:hover {
  background: #f8fafc;
  border-color: #b7c7df;
  color: #12376f;
}

.ot-pliego-dibujo-dialog .cut-line-pick.is-defined {
  background: #e0f2fe;
  border-color: #38bdf8;
  color: #075985;
}

.ot-pliego-dibujo-dialog .cut-line-pick.is-defined:hover {
  background: #e0f2fe;
  border-color: #38bdf8;
  color: #075985;
}

.ot-pliego-dibujo-dialog .cut-line-pick.is-touched {
  background: #dcfce7;
  border-color: #22c55e;
  color: #166534;
}

.ot-pliego-dibujo-dialog .cut-line-pick.is-touched:hover {
  background: #dcfce7;
  border-color: #22c55e;
  color: #166534;
}

.ot-pliego-dibujo-dialog .cut-line-pick.active {
  background: #eef2ff;
  border-color: #4f6df5;
  box-shadow: inset 0 0 0 2px #4f6df5;
  color: #1e3a8a;
}

.ot-pliego-dibujo-dialog .cut-line-pick.active:hover {
  background: #eef2ff;
  border-color: #4f6df5;
  color: #1e3a8a;
}

.ot-pliego-dibujo-dialog .cut-line-pick.is-defined::after,
.ot-pliego-dibujo-dialog .cut-line-pick.is-touched::after {
  border-radius: 999px;
  content: "";
  height: 6px;
  position: absolute;
  right: 5px;
  top: 5px;
  width: 6px;
}

.ot-pliego-dibujo-dialog .cut-line-pick.is-defined::after {
  background: #0284c7;
}

.ot-pliego-dibujo-dialog .cut-line-pick.is-touched::after {
  background: #16a34a;
}

.ot-pliego-dibujo-dialog .cut-process:hover {
  background: #eef2f5;
  border-color: var(--line);
  color: #263445;
}

/* OT > Pliegos > Ver diagrama: modal moderno operativo */
.ot-pliego-diagrama-dialog {
  border: 0;
  border-radius: 16px;
  box-shadow: 0 24px 70px rgb(15 23 42 / 28%);
  color: #0f172a;
  max-width: min(1080px, calc(100vw - 24px));
  padding: 0;
  width: 1080px;
}

.ot-pliego-diagrama-dialog::backdrop {
  background: rgb(15 23 42 / 45%);
}

.ot-pliego-diagrama-dialog .muted {
  color: #667085;
}

.ot-diagrama-head {
  align-items: flex-start;
  background: linear-gradient(135deg, #ffffff 0%, #f5f8fb 64%, #edf4ff 100%);
  border-bottom: 1px solid #dde6f0;
  display: flex;
  gap: 16px;
  justify-content: space-between;
  padding: 18px 20px;
}

.ot-diagrama-head h2,
.ot-diagrama-head p {
  margin: 0;
}

.ot-diagrama-head h2 {
  color: #12376f;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -.02em;
}

.ot-diagrama-head p {
  font-size: 13px;
  margin-top: 4px;
}

.ot-diagrama-status {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 999px;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 900;
  padding: 7px 11px;
  white-space: nowrap;
}

.ot-diagrama-status.is-ready {
  background: #ecfdf3;
  border-color: #a7f3d0;
  color: #047857;
}

.ot-diagrama-status.is-reference {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #c2410c;
}

.ot-diagrama-status.is-base {
  background: #f8fafc;
  border-color: #cbd5e1;
  color: #475569;
}

.ot-diagrama-layout,
.ot-diagrama-kpis,
.ot-diagrama-flow,
.ot-diagrama-detail-grid {
  margin-left: 20px;
  margin-right: 20px;
}

.ot-diagrama-layout {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(300px, 0.85fr) minmax(420px, 1.15fr);
  margin-top: 18px;
}

.ot-diagrama-hero-card,
.ot-diagrama-preview-card,
.ot-diagrama-detail-grid section,
.ot-diagrama-flow div,
.ot-diagrama-kpis div {
  background: #ffffff;
  border: 1px solid #d9e4ef;
  border-radius: 14px;
  box-shadow: 0 10px 26px rgb(15 23 42 / 7%);
}

.ot-diagrama-hero-card {
  display: grid;
  overflow: hidden;
}

.ot-diagrama-image {
  background: linear-gradient(135deg, #eaf2ff, #f8fbff);
  min-height: 235px;
  position: relative;
}

.ot-diagrama-image img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.ot-diagrama-image.is-missing::after {
  align-items: center;
  color: #64748b;
  content: attr(data-fallback);
  display: flex;
  font-weight: 800;
  inset: 0;
  justify-content: center;
  position: absolute;
}

.ot-diagrama-hero-copy {
  display: grid;
  gap: 4px;
  padding: 13px 15px 15px;
}

.ot-diagrama-hero-copy strong {
  color: #12376f;
  font-size: 16px;
  font-weight: 900;
}

.ot-diagrama-hero-copy span {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

.ot-diagrama-preview-card {
  display: grid;
  gap: 12px;
  padding: 15px;
}

.ot-diagrama-preview-title {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.ot-diagrama-preview-title strong {
  color: #12376f;
  font-size: 16px;
  font-weight: 900;
}

.ot-diagrama-preview-title span {
  background: #eef4ff;
  border: 1px solid #cfe0ff;
  border-radius: 999px;
  color: #12376f;
  font-size: 12px;
  font-weight: 900;
  padding: 5px 10px;
}

.ot-diagrama-cut-preview {
  --diag-cols: 1;
  --diag-rows: 1;
  aspect-ratio: 1.7 / 1;
  background:
    linear-gradient(90deg, rgb(18 55 111 / 12%) 1px, transparent 1px) 0 0 / calc(100% / max(var(--diag-cols), 1)) 100%,
    linear-gradient(0deg, rgb(18 55 111 / 12%) 1px, transparent 1px) 0 0 / 100% calc(100% / max(var(--diag-rows), 1)),
    radial-gradient(circle at 12% 16%, rgb(23 107 95 / 13%), transparent 18%),
    linear-gradient(135deg, #ffffff, #f5f9ff);
  border: 1px solid #b9c9dc;
  border-radius: 14px;
  box-shadow: inset 0 0 0 1px rgb(255 255 255 / 75%);
  overflow: hidden;
  position: relative;
}

.ot-diagrama-cut-preview::before,
.ot-diagrama-cut-preview::after {
  background: rgb(18 55 111 / 48%);
  content: '';
  position: absolute;
}

.ot-diagrama-cut-preview::before {
  height: 2px;
  left: 0;
  right: 0;
  top: calc(100% / max(var(--diag-rows), 1));
}

.ot-diagrama-cut-preview::after {
  bottom: 0;
  left: calc(100% / max(var(--diag-cols), 1));
  top: 0;
  width: 2px;
}

.ot-diagrama-cut-preview span {
  background: #ffffff;
  border: 1px solid #d3deea;
  border-radius: 999px;
  box-shadow: 0 8px 20px rgb(15 23 42 / 8%);
  color: #12376f;
  font-size: 11px;
  font-weight: 900;
  padding: 5px 8px;
  position: absolute;
  z-index: 1;
}

.ot-diagrama-cut-preview .diag-pinza {
  left: 12px;
  top: 12px;
}

.ot-diagrama-cut-preview .diag-cola {
  bottom: 12px;
  left: 12px;
}

.ot-diagrama-cut-preview .diag-sep-h {
  right: 12px;
  top: 12px;
}

.ot-diagrama-cut-preview .diag-sep-v {
  bottom: 12px;
  right: 12px;
}

.ot-diagrama-preview-card p {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
  margin: 0;
}

.ot-diagrama-kpis {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin-top: 14px;
}

.ot-diagrama-kpis div {
  display: grid;
  gap: 4px;
  min-height: 66px;
  padding: 11px 12px;
}

.ot-diagrama-kpis span,
.ot-diagrama-detail-grid dt {
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.ot-diagrama-kpis strong {
  color: #0f2f6b;
  font-size: 18px;
  font-weight: 950;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ot-diagrama-flow {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 14px;
}

.ot-diagrama-flow div {
  display: grid;
  gap: 4px;
  padding: 13px;
  position: relative;
}

.ot-diagrama-flow div:not(:last-child)::after {
  background: linear-gradient(90deg, var(--accent), transparent);
  content: '';
  height: 2px;
  position: absolute;
  right: -11px;
  top: 28px;
  width: 12px;
}

.ot-diagrama-flow span {
  align-items: center;
  background: var(--accent);
  border-radius: 999px;
  color: #ffffff;
  display: inline-flex;
  font-size: 12px;
  font-weight: 950;
  height: 28px;
  justify-content: center;
  width: 28px;
}

.ot-diagrama-flow strong {
  color: #12376f;
  font-size: 13px;
  font-weight: 900;
}

.ot-diagrama-flow em {
  color: #64748b;
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
}

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

.ot-diagrama-detail-grid section {
  padding: 14px;
}

.ot-diagrama-detail-grid h3 {
  color: #12376f;
  font-size: 15px;
  font-weight: 900;
  margin: 0 0 10px;
}

.ot-diagrama-detail-grid dl {
  display: grid;
  gap: 7px;
  margin: 0;
}

.ot-diagrama-detail-grid dl div {
  align-items: center;
  border-top: 1px solid #edf2f7;
  display: grid;
  gap: 8px;
  grid-template-columns: 126px minmax(0, 1fr);
  padding-top: 7px;
}

.ot-diagrama-detail-grid dl div:first-child {
  border-top: 0;
  padding-top: 0;
}

.ot-diagrama-detail-grid dd {
  color: #0f172a;
  font-size: 13px;
  font-weight: 800;
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ot-diagrama-actions {
  border-top: 1px solid #dde6f0;
  margin: 18px 20px 0;
  padding: 14px 0 18px;
}

.ot-pliego-diagrama-dialog .client-tool,
.ot-pliego-diagrama-dialog .button,
.ot-pliego-diagrama-dialog button {
  transform: none !important;
  transition: background-color .12s ease, border-color .12s ease, color .12s ease, box-shadow .12s ease !important;
}

.ot-pliego-diagrama-dialog .client-tool:hover,
.ot-pliego-diagrama-dialog .button:hover,
.ot-pliego-diagrama-dialog button:hover {
  transform: none !important;
}

@media (max-width: 900px) {
  .ot-diagrama-head,
  .ot-diagrama-layout,
  .ot-diagrama-kpis,
  .ot-diagrama-flow,
  .ot-diagrama-detail-grid {
    grid-template-columns: 1fr;
  }

  .ot-diagrama-head {
    display: grid;
  }

  .ot-diagrama-kpis,
  .ot-diagrama-flow,
  .ot-diagrama-detail-grid {
    margin-left: 14px;
    margin-right: 14px;
  }

  .ot-diagrama-layout {
    margin-left: 14px;
    margin-right: 14px;
  }

  .ot-diagrama-flow div:not(:last-child)::after {
    display: none;
  }
}

/* OT > Pliegos > Opciones de diagrama completo */
.ot-pliego-opciones-dialog {
  border: 0;
  border-radius: 16px;
  box-shadow: 0 24px 70px rgb(15 23 42 / 28%);
  color: #0f172a;
  max-height: calc(100vh - 24px);
  max-width: min(1120px, calc(100vw - 24px));
  overflow: auto;
  padding: 0;
  width: 1120px;
}

.ot-pliego-opciones-dialog::backdrop {
  background: rgb(15 23 42 / 45%);
}

.ot-pliego-opciones-dialog .client-tool,
.ot-pliego-opciones-dialog .button,
.ot-pliego-opciones-dialog button {
  transform: none !important;
  transition: background-color .12s ease, border-color .12s ease, color .12s ease, box-shadow .12s ease !important;
}

.ot-pliego-opciones-dialog .client-tool:hover,
.ot-pliego-opciones-dialog .button:hover,
.ot-pliego-opciones-dialog button:hover {
  transform: none !important;
}

.ot-opciones-diagrama-layout {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(300px, .82fr) minmax(0, 1.18fr);
  margin: 18px 20px 0;
}

.ot-opciones-blueprint-card,
.ot-opciones-form-card {
  background: #ffffff;
  border: 1px solid #d9e4ef;
  border-radius: 14px;
  box-shadow: 0 10px 26px rgb(15 23 42 / 7%);
}

.ot-opciones-blueprint-card {
  display: grid;
  gap: 12px;
  padding: 14px;
}

.ot-opciones-blueprint {
  --diag-cols: 1;
  --diag-rows: 1;
  aspect-ratio: 1.25 / 1;
  background:
    linear-gradient(90deg, rgb(18 55 111 / 12%) 1px, transparent 1px) 0 0 / calc(100% / max(var(--diag-cols), 1)) 100%,
    linear-gradient(0deg, rgb(18 55 111 / 12%) 1px, transparent 1px) 0 0 / 100% calc(100% / max(var(--diag-rows), 1)),
    radial-gradient(circle at 18% 18%, rgb(23 107 95 / 14%), transparent 18%),
    linear-gradient(135deg, #ffffff, #f4f8ff);
  border: 1px solid #b9c9dc;
  border-radius: 14px;
  overflow: hidden;
  position: relative;
}

.ot-opciones-blueprint > span,
.ot-opciones-blueprint .op-badge {
  background: #ffffff;
  border: 1px solid #d3deea;
  border-radius: 999px;
  box-shadow: 0 8px 20px rgb(15 23 42 / 8%);
  color: #12376f;
  font-size: 11px;
  font-weight: 900;
  padding: 5px 8px;
  position: absolute;
  z-index: 1;
}

.ot-opciones-blueprint .op-pinza { left: 10px; top: 10px; }
.ot-opciones-blueprint .op-cola { bottom: 10px; left: 10px; }
.ot-opciones-blueprint .op-lateral { right: 10px; top: 10px; }
.ot-opciones-blueprint .op-sep { bottom: 10px; right: 10px; }

.ot-opciones-blueprint .op-badge {
  background: #ecfdf3;
  border-color: #a7f3d0;
  color: #047857;
}

.ot-opciones-blueprint .op-open {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.ot-opciones-blueprint .op-vertical {
  left: 50%;
  top: calc(50% + 34px);
  transform: translateX(-50%);
}

.ot-opciones-mini-summary {
  display: grid;
  gap: 7px;
  margin: 0;
}

.ot-opciones-mini-summary div {
  align-items: center;
  border-top: 1px solid #edf2f7;
  display: grid;
  gap: 8px;
  grid-template-columns: 110px minmax(0, 1fr);
  padding-top: 7px;
}

.ot-opciones-mini-summary div:first-child {
  border-top: 0;
  padding-top: 0;
}

.ot-opciones-mini-summary dt,
.ot-opciones-form-card label > span,
.ot-opciones-checks span {
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.ot-opciones-mini-summary dd {
  color: #0f172a;
  font-size: 13px;
  font-weight: 850;
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ot-opciones-form-card {
  display: grid;
  gap: 12px;
  padding: 14px;
}

.ot-opciones-form-card h3 {
  color: #12376f;
  font-size: 15px;
  font-weight: 900;
  margin: 0;
}

.ot-opciones-form-grid,
.ot-opciones-measures-grid {
  display: grid;
  gap: 10px;
}

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

.ot-opciones-measures-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.ot-opciones-form-card label {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.ot-pliego-opciones-dialog .grid-input,
.ot-pliego-opciones-dialog input:not([type="checkbox"]),
.ot-pliego-opciones-dialog select,
.ot-pliego-opciones-dialog textarea {
  background: #ffffff;
  border: 1px solid #b7c5d5;
  border-radius: 7px;
  box-shadow: none;
  color: #111827;
  min-height: 34px;
  padding: 6px 8px;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
  width: 100%;
}

.ot-pliego-opciones-dialog textarea {
  line-height: 1.35;
  resize: vertical;
}

.ot-pliego-opciones-dialog .grid-input:focus,
.ot-pliego-opciones-dialog input:not([type="checkbox"]):focus,
.ot-pliego-opciones-dialog select:focus,
.ot-pliego-opciones-dialog textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgb(23 107 95 / 13%);
  outline: 0;
}

.ot-opciones-measures-grid .number-input {
  text-align: right;
}

.ot-opciones-rules-card,
.ot-opciones-notes-card {
  grid-column: 2;
}

.ot-opciones-checks {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ot-opciones-checks label {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #d9e4ef;
  border-radius: 11px;
  display: flex;
  gap: 8px;
  min-height: 44px;
  padding: 8px 10px;
}

.ot-opciones-checks input[type="checkbox"] {
  accent-color: var(--accent);
  height: 17px;
  width: 17px;
}

.ot-opciones-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

@media (max-width: 960px) {
  .ot-opciones-diagrama-layout,
  .ot-opciones-form-grid,
  .ot-opciones-measures-grid,
  .ot-opciones-checks {
    grid-template-columns: 1fr;
  }

  .ot-opciones-rules-card,
  .ot-opciones-notes-card {
    grid-column: auto;
  }
}

/* OT > Pliegos > Diagrama completo estilo Fox moderno */
.ot-diagrama-fox-top,
.ot-diagrama-fox-main,
.ot-diagrama-bottom-grid {
  display: grid;
  gap: 14px;
  margin: 16px 20px 0;
}

.ot-diagrama-fox-top {
  grid-template-columns: minmax(0, 1.2fr) minmax(360px, .8fr);
}

.ot-diagrama-param-card,
.ot-diagrama-fox-summary-card,
.ot-diagrama-grid-card {
  background: #ffffff;
  border: 1px solid #d9e4ef;
  border-radius: 14px;
  box-shadow: 0 10px 26px rgb(15 23 42 / 7%);
  padding: 14px;
}

.ot-diagrama-param-grid {
  align-items: end;
  display: grid;
  gap: 10px;
  grid-template-columns: 1.4fr 1fr .9fr .55fr .9fr 24px .75fr;
}

.ot-diagrama-param-grid label,
.ot-diagrama-bocas-grid label {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.ot-diagrama-param-grid label > span,
.ot-diagrama-readonly-chip span,
.ot-diagrama-bocas-grid label > span,
.ot-diagrama-grid-help strong {
  color: #12376f;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.ot-diagrama-readonly-chip {
  align-items: center;
  background: linear-gradient(135deg, #eef5ff, #ffffff);
  border: 1px solid #d7e3f1;
  border-radius: 10px;
  display: flex;
  gap: 8px;
  min-height: 34px;
  padding: 7px 9px;
}

.ot-diagrama-readonly-chip strong {
  color: #0f172a;
  font-size: 14px;
  font-weight: 900;
}

.ot-diagrama-percent-sign {
  color: #12376f;
  font-size: 16px;
  font-weight: 900;
  padding-bottom: 8px;
}

.ot-diagrama-format-title {
  align-items: center;
  border-bottom: 1px solid #e8eef6;
  color: #12376f;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  padding-bottom: 10px;
}

.ot-diagrama-format-title strong {
  font-size: 15px;
  font-weight: 950;
}

.ot-diagrama-format-title span {
  background: #f5f8fc;
  border: 1px solid #dce7f2;
  border-radius: 999px;
  color: #334155;
  font-size: 12px;
  font-weight: 850;
  padding: 4px 8px;
}

.ot-diagrama-condiciones {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  padding-top: 10px;
}

.ot-diagrama-condiciones label {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #d9e4ef;
  border-radius: 10px;
  display: flex;
  gap: 7px;
  min-height: 36px;
  padding: 6px 8px;
}

.ot-diagrama-condiciones span {
  color: #12376f;
  font-size: 12px;
  font-weight: 850;
}

.ot-diagrama-condiciones input,
.ot-diagrama-opciones-table input,
.ot-diagrama-clasif-card input[type="checkbox"] {
  accent-color: var(--accent);
}

.ot-diagrama-fox-main {
  grid-template-columns: minmax(290px, .5fr) minmax(0, 1.5fr);
}

.ot-diagrama-fox-blueprint-card {
  align-self: start;
  margin: 0;
}

.ot-diagrama-grid-card {
  min-width: 0;
  padding: 0;
  overflow: hidden;
}

.ot-diagrama-grid-scroll {
  max-height: min(42vh, 420px);
  overflow: auto;
}

.ot-diagrama-opciones-table {
  border-collapse: separate;
  border-spacing: 0;
  font-size: 12px;
  min-width: 1040px;
  width: 100%;
}

.ot-diagrama-opciones-table th {
  background: linear-gradient(180deg, #eaf2fc, #dce9f7);
  border-bottom: 1px solid #bfd0e4;
  border-right: 1px solid #d2deec;
  color: #12376f;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .02em;
  padding: 7px 6px;
  position: sticky;
  text-transform: uppercase;
  top: 0;
  z-index: 2;
}

.ot-diagrama-opciones-table td {
  border-bottom: 1px solid #e6edf5;
  border-right: 1px solid #edf2f7;
  color: #1f2937;
  font-weight: 750;
  padding: 6px;
  text-align: center;
  white-space: nowrap;
}

.ot-diagrama-opciones-table tbody tr {
  cursor: pointer;
  transition: background-color .12s ease, box-shadow .12s ease;
}

.ot-diagrama-opciones-table tbody tr:hover {
  background: #f8fbff;
}

.ot-diagrama-opciones-table tbody tr.is-definitive {
  background: #ecfdf3;
  box-shadow: inset 4px 0 0 #10b981;
}

.ot-diagrama-opciones-table tbody tr.is-borrada {
  background: #fff7ed;
  color: #9a3412;
  text-decoration: line-through;
}

.ot-diagrama-opciones-table tbody tr.is-hidden-by-filter {
  display: none;
}

.ot-diagrama-select-cell {
  background: #ffffff;
  border: 1px solid #b7c5d5;
  border-radius: 8px;
  color: #12376f;
  font-weight: 950;
  height: 28px;
  line-height: 1;
  min-width: 32px;
  padding: 0 8px;
  transform: none !important;
}

.ot-diagrama-select-cell:hover {
  background: #eef5ff;
  transform: none !important;
}

.ot-diagrama-mini-icon,
.ot-diagrama-mini-draw {
  align-items: center;
  background: #f1f5f9;
  border: 1px solid #d7e3f1;
  border-radius: 7px;
  display: inline-flex;
  height: 24px;
  justify-content: center;
  min-width: 28px;
}

.ot-diagrama-grid-help {
  background: #f8fafc;
  border-top: 1px solid #e6edf5;
  color: #64748b;
  font-size: 12px;
  margin: 0;
  padding: 9px 12px;
}

.ot-diagrama-bottom-grid {
  grid-template-columns: .85fr 1.35fr 1.2fr;
}

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

.ot-opciones-measures-grid.compact-six {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.ot-diagrama-clasif-card {
  grid-row: span 2;
}

.ot-diagrama-notes-full {
  grid-column: 1 / span 2;
}

.mt-compact {
  margin-top: 6px;
}

@media (max-width: 1100px) {
  .ot-diagrama-fox-top,
  .ot-diagrama-fox-main,
  .ot-diagrama-bottom-grid,
  .ot-diagrama-param-grid,
  .ot-diagrama-condiciones,
  .ot-opciones-measures-grid.compact-six {
    grid-template-columns: 1fr;
  }

  .ot-diagrama-notes-full,
  .ot-diagrama-clasif-card {
    grid-column: auto;
    grid-row: auto;
  }

  .ot-diagrama-percent-sign {
    display: none;
  }
}

/* O.Trabajo > Pliegos > Diagrama completo: selección definitiva siempre visible */
.ot-diagrama-definitiva-card {
  align-items: center;
  background: linear-gradient(135deg, #ecfdf5 0%, #ffffff 70%);
  border: 1px solid #a7f3d0;
  border-radius: 14px;
  box-shadow: 0 12px 28px rgba(16, 185, 129, .10);
  color: #064e3b;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto auto;
  margin: 10px;
  padding: 10px 12px;
}

.ot-diagrama-definitiva-card strong {
  color: #0f2a5f;
  display: block;
  font-size: 14px;
  line-height: 1.2;
}

.ot-diagrama-definitiva-card small {
  color: #3f5f86;
  display: block;
  font-size: 11px;
  font-weight: 700;
  margin-top: 3px;
}

.ot-diagrama-definitiva-label {
  color: #047857;
  display: block;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .06em;
  margin-bottom: 3px;
  text-transform: uppercase;
}

.ot-diagrama-definitiva-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: flex-end;
}

.ot-diagrama-definitiva-tags span {
  background: rgba(255,255,255,.9);
  border: 1px solid #bbf7d0;
  border-radius: 999px;
  color: #065f46;
  font-size: 10px;
  font-weight: 900;
  padding: 4px 8px;
  white-space: nowrap;
}

.ot-diagrama-opciones-table tbody tr.is-definitive-saved {
  background: #f0fdf4;
  box-shadow: inset 4px 0 0 #059669;
}

.ot-diagrama-opciones-table tbody tr.is-definitive-saved td:first-child::after {
  color: #047857;
  content: "Def.";
  display: block;
  font-size: 9px;
  font-weight: 950;
  line-height: 1;
  margin-top: 2px;
}

@media (max-width: 900px) {
  .ot-diagrama-definitiva-card {
    grid-template-columns: 1fr;
  }
  .ot-diagrama-definitiva-tags {
    justify-content: flex-start;
  }
}

/* O.Trabajo > Pliegos > Diagrama completo: fila definitiva dentro de la grilla */
.ot-diagrama-opciones-table tbody tr.is-definitive,
.ot-diagrama-opciones-table tbody tr.is-definitive-saved {
  background: linear-gradient(90deg, #dcfce7 0%, #f0fdf4 42%, #ffffff 100%) !important;
  box-shadow: inset 5px 0 0 #16a34a;
  color: #052e16;
  position: relative;
}

.ot-diagrama-opciones-table tbody tr.is-definitive td,
.ot-diagrama-opciones-table tbody tr.is-definitive-saved td {
  border-bottom-color: #bbf7d0;
  color: #052e16;
  font-weight: 900;
}

.ot-diagrama-opciones-table tbody tr.is-definitive .ot-diagrama-select-cell,
.ot-diagrama-opciones-table tbody tr.is-definitive-saved .ot-diagrama-select-cell {
  background: #16a34a;
  border-color: #15803d;
  color: #ffffff;
  display: inline-flex;
  flex-direction: column;
  gap: 1px;
  height: auto;
  line-height: 1;
  min-height: 30px;
}

.ot-diagrama-def-row-label {
  display: block;
  font-size: 8px;
  font-weight: 950;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.ot-diagrama-opciones-table tbody tr.is-definitive .ot-diagrama-mini-icon,
.ot-diagrama-opciones-table tbody tr.is-definitive .ot-diagrama-mini-draw,
.ot-diagrama-opciones-table tbody tr.is-definitive-saved .ot-diagrama-mini-icon,
.ot-diagrama-opciones-table tbody tr.is-definitive-saved .ot-diagrama-mini-draw {
  background: #ecfdf5;
  border-color: #86efac;
}

/* O.Trabajo > Pliegos > Diagrama completo: ajuste de respiración visual */
.ot-pliego-opciones-dialog {
  max-width: min(1240px, calc(100vw - 18px));
  width: 1240px;
}

.ot-diagrama-fox-top,
.ot-diagrama-fox-main,
.ot-diagrama-bottom-grid {
  gap: 16px;
  margin-left: 22px;
  margin-right: 22px;
}

.ot-diagrama-fox-top {
  grid-template-columns: minmax(0, 1.35fr) minmax(390px, .85fr);
}

.ot-diagrama-param-card,
.ot-diagrama-fox-summary-card,
.ot-diagrama-grid-card,
.ot-opciones-blueprint-card,
.ot-opciones-form-card {
  overflow: hidden;
}

.ot-diagrama-param-grid {
  align-items: end;
  column-gap: 12px;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  row-gap: 12px;
}

.ot-diagrama-param-grid label {
  min-width: 0;
}

.ot-diagrama-param-grid label.wide {
  grid-column: span 3;
}

.ot-diagrama-param-grid label:nth-of-type(2) {
  grid-column: span 3;
}

.ot-diagrama-param-grid label:nth-of-type(3),
.ot-diagrama-param-grid label:nth-of-type(4),
.ot-diagrama-param-grid label:nth-of-type(6) {
  grid-column: span 2;
}

.ot-diagrama-param-grid label:nth-of-type(5) {
  grid-column: span 3;
}

.ot-diagrama-param-grid label > span,
.ot-diagrama-bocas-grid label > span {
  align-items: flex-end;
  display: flex;
  line-height: 1.12;
  min-height: 26px;
  overflow-wrap: anywhere;
}

.ot-diagrama-percent-sign {
  align-self: end;
  grid-column: span 1;
  line-height: 34px;
  padding-bottom: 0;
  text-align: center;
}

.ot-pliego-opciones-dialog .grid-input,
.ot-pliego-opciones-dialog input:not([type="checkbox"]),
.ot-pliego-opciones-dialog select,
.ot-pliego-opciones-dialog textarea {
  font-size: 12px;
  min-height: 36px;
}

.ot-diagrama-condiciones {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  row-gap: 9px;
}

.ot-diagrama-condiciones label {
  align-items: center;
  gap: 8px;
  min-height: 42px;
}

.ot-diagrama-condiciones span {
  line-height: 1.08;
  overflow-wrap: anywhere;
}

.ot-diagrama-format-title {
  gap: 8px;
}

.ot-diagrama-grid-card {
  min-height: 0;
}

.ot-diagrama-grid-scroll {
  max-height: min(46vh, 470px);
}

.ot-diagrama-opciones-table th,
.ot-diagrama-opciones-table td {
  line-height: 1.12;
  vertical-align: middle;
}

.ot-diagrama-opciones-table th {
  padding: 8px 7px;
}

.ot-diagrama-opciones-table td {
  padding: 7px 7px;
}

.ot-diagrama-select-cell {
  min-width: 34px;
}

.ot-diagrama-definitiva-card {
  gap: 12px;
  margin: 12px;
  padding: 12px 14px;
}

.ot-diagrama-bottom-grid {
  grid-template-columns: minmax(210px, .9fr) minmax(290px, 1.35fr) minmax(310px, 1.2fr);
}

.ot-diagrama-bocas-grid,
.ot-opciones-measures-grid.compact-six {
  gap: 11px;
}

.ot-opciones-form-card h3 {
  line-height: 1.2;
}

.ot-opciones-form-card label > span,
.ot-opciones-checks span,
.ot-opciones-mini-summary dt {
  line-height: 1.12;
}

@media (max-width: 1180px) {
  .ot-pliego-opciones-dialog {
    max-width: calc(100vw - 16px);
    width: calc(100vw - 16px);
  }

  .ot-diagrama-fox-top {
    grid-template-columns: 1fr;
  }

  .ot-diagrama-condiciones {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .ot-diagrama-param-grid,
  .ot-diagrama-condiciones,
  .ot-diagrama-bottom-grid {
    grid-template-columns: 1fr;
  }

  .ot-diagrama-param-grid label,
  .ot-diagrama-param-grid label.wide,
  .ot-diagrama-param-grid label:nth-of-type(2),
  .ot-diagrama-param-grid label:nth-of-type(3),
  .ot-diagrama-param-grid label:nth-of-type(4),
  .ot-diagrama-param-grid label:nth-of-type(5),
  .ot-diagrama-param-grid label:nth-of-type(6),
  .ot-diagrama-percent-sign {
    grid-column: auto;
  }

  .ot-diagrama-percent-sign {
    display: none;
  }
}

/* O.Trabajo > Pliegos > Diagrama completo: cierre de los 6 puntos operativos */
.ot-diagrama-print-head {
  display: none;
}

.ot-diagrama-lock-alert {
  background: linear-gradient(135deg, #fff7ed, #ffffff);
  border: 1px solid #fed7aa;
  border-radius: 12px;
  color: #9a3412;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
  margin: 12px 22px 0;
  padding: 10px 12px;
}

.ot-diagrama-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  padding-top: 10px;
}

.ot-diagrama-stats span {
  background: #eef5ff;
  border: 1px solid #d4e2f5;
  border-radius: 999px;
  color: #12376f;
  font-size: 11px;
  font-weight: 900;
  padding: 5px 8px;
  white-space: nowrap;
}

.ot-diagrama-opciones-table tbody tr.is-libre:not(.is-definitive):not(.is-definitive-saved) {
  background: #f8fafc;
  box-shadow: inset 4px 0 0 #64748b;
}

.ot-diagrama-opciones-table tbody tr.is-libre:not(.is-definitive):not(.is-definitive-saved) td {
  color: #334155;
}

.ot-pliego-opciones-dialog[data-diagrama-locked="1"] [data-inline-save],
.ot-pliego-opciones-dialog[data-diagrama-locked="1"] [data-diagrama-option-select],
.ot-pliego-opciones-dialog[data-diagrama-locked="1"] [data-diagrama-options-save],
.ot-pliego-opciones-dialog[data-diagrama-locked="1"] [data-diagrama-recalcular],
.ot-pliego-opciones-dialog[data-diagrama-locked="1"] [data-diagrama-reaplicar-definitiva] {
  cursor: not-allowed;
  opacity: .62;
}

@media print {
  body.printing-ot-diagrama * {
    visibility: hidden !important;
  }

  body.printing-ot-diagrama .ot-pliego-opciones-dialog[open],
  body.printing-ot-diagrama .ot-pliego-opciones-dialog[open] * {
    visibility: visible !important;
  }

  body.printing-ot-diagrama .ot-pliego-opciones-dialog[open] {
    border: 0 !important;
    box-shadow: none !important;
    height: auto !important;
    inset: 0 !important;
    margin: 0 !important;
    max-height: none !important;
    max-width: none !important;
    overflow: visible !important;
    padding: 0 !important;
    position: absolute !important;
    width: 100% !important;
  }

  body.printing-ot-diagrama .ot-diagrama-print-head {
    border-bottom: 2px solid #0f2a5f;
    color: #0f2a5f;
    display: grid;
    gap: 3px;
    margin: 0 0 10px;
    padding: 0 0 8px;
  }

  body.printing-ot-diagrama .ot-diagrama-print-head strong {
    font-size: 17px;
  }

  body.printing-ot-diagrama .ot-diagrama-print-head span {
    color: #475569;
    font-size: 12px;
  }

  body.printing-ot-diagrama .ot-opciones-head,
  body.printing-ot-diagrama .ot-diagrama-actions,
  body.printing-ot-diagrama .client-tool,
  body.printing-ot-diagrama .ot-diagrama-grid-help,
  body.printing-ot-diagrama .ot-diagrama-lock-alert {
    display: none !important;
  }

  body.printing-ot-diagrama .ot-diagrama-fox-top,
  body.printing-ot-diagrama .ot-diagrama-fox-main,
  body.printing-ot-diagrama .ot-diagrama-bottom-grid {
    display: grid !important;
    gap: 8px !important;
    margin: 0 0 8px !important;
  }

  body.printing-ot-diagrama .ot-diagrama-param-card,
  body.printing-ot-diagrama .ot-diagrama-fox-summary-card,
  body.printing-ot-diagrama .ot-diagrama-grid-card,
  body.printing-ot-diagrama .ot-opciones-blueprint-card,
  body.printing-ot-diagrama .ot-opciones-form-card {
    box-shadow: none !important;
    break-inside: avoid;
    padding: 8px !important;
  }

  body.printing-ot-diagrama .ot-diagrama-grid-scroll {
    max-height: none !important;
    overflow: visible !important;
  }

  body.printing-ot-diagrama .ot-diagrama-opciones-table {
    font-size: 9px !important;
    min-width: 0 !important;
  }

  body.printing-ot-diagrama .ot-diagrama-opciones-table th,
  body.printing-ot-diagrama .ot-diagrama-opciones-table td {
    padding: 4px !important;
  }

  body.printing-ot-diagrama .ot-diagrama-opciones-table tbody tr:nth-child(n+16) {
    display: none !important;
  }
}


/* Fix puntual Pliegos OT: Fto (mm) ancho x largo sin romper modales/botones.
   Se aplica solo al panel Datos de la hoja de la tarjeta principal. */
.ot-pliegos-fox .ot-fox-hoja-panel > .ot-fox-two-inputs {
  align-items: center !important;
  display: grid !important;
  gap: 6px !important;
  grid-template-columns: 88px minmax(58px, 1fr) 14px minmax(58px, 1fr) !important;
  width: 100% !important;
}

.ot-pliegos-fox .ot-fox-hoja-panel > .ot-fox-two-inputs > label {
  display: contents !important;
  min-width: 0 !important;
}

.ot-pliegos-fox .ot-fox-hoja-panel > .ot-fox-two-inputs > label:first-child > span {
  align-self: center !important;
  grid-column: 1 !important;
  white-space: nowrap !important;
}

.ot-pliegos-fox .ot-fox-hoja-panel > .ot-fox-two-inputs > label:first-child > input {
  grid-column: 2 !important;
  min-width: 0 !important;
  width: 100% !important;
}

.ot-pliegos-fox .ot-fox-hoja-panel > .ot-fox-two-inputs > em {
  align-self: center !important;
  grid-column: 3 !important;
  justify-self: center !important;
  padding: 0 !important;
  position: static !important;
}

.ot-pliegos-fox .ot-fox-hoja-panel > .ot-fox-two-inputs > label:last-child > span {
  display: none !important;
}

.ot-pliegos-fox .ot-fox-hoja-panel > .ot-fox-two-inputs > label:last-child > input {
  grid-column: 4 !important;
  min-width: 0 !important;
  width: 100% !important;
}
