/* ============================================================
   Ordem de Carregamento v2 — componentes específicos
   Usa os design tokens de design-system.css (:root vars)
   Prefixo: .oc-
   ============================================================ */

/* ── jQuery UI Autocomplete (transportadora) ── */
.ui-autocomplete.ui-menu {
    list-style: none;
    margin: 4px 0 0;
    padding: 6px;
    background: var(--salescode-card, #fff);
    border: 1px solid var(--salescode-border, #E2EAF0);
    border-radius: var(--salescode-radius-md, 8px);
    box-shadow: var(--salescode-shadow-md, 0 4px 12px rgba(4,45,77,.12));
    max-height: 280px;
    overflow-y: auto;
    z-index: 99999 !important;       /* acima da topbar/cards */
    font-family: var(--salescode-font, inherit);
}

.ui-autocomplete .ui-menu-item { margin: 0; list-style: none; }

.ui-autocomplete .ui-menu-item-wrapper,
.ui-autocomplete .ui-menu-item a {
    display: block;
    padding: 8px 12px;
    font-size: 13px;
    color: var(--salescode-title, #032036);
    border-radius: var(--salescode-radius-sm, 4px);
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    border: none;
    transition: background .12s, color .12s;
}

.ui-autocomplete .ui-menu-item-wrapper.ui-state-active,
.ui-autocomplete .ui-menu-item-wrapper:hover,
.ui-autocomplete .ui-menu-item a.ui-state-active,
.ui-autocomplete .ui-menu-item a:hover {
    background: var(--salescode-navy, #042D4D);
    color: #fff;
    margin: 0;                        /* anula o margin que o jQuery UI aplica no active */
}

/* Remove o foco pontilhado padrão do jQuery UI */
.ui-autocomplete .ui-menu-item-wrapper:focus { outline: none; }

/* ── Layout wizard full-viewport ── */
.oc-layout {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 56px); /* desconta app-topbar */
    overflow: hidden;
    background: #eff1f6;
}

.oc-topbar {
    flex-shrink: 0;
    height: 60px;
    background: var(--salescode-card, #fff);
    border-bottom: 1px solid var(--salescode-border, #E2EAF0);
    display: flex;
    align-items: center;
    padding: 0 20px;
    gap: 16px;
    box-shadow: var(--salescode-shadow-sm);
    z-index: 10;
}

.oc-topbar-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--salescode-navy, #042D4D);
    white-space: nowrap;
}

.oc-topbar-stepper {
    flex: 1;
    display: flex;
    justify-content: center;
}

.oc-main {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    position: relative;
}

.oc-step-pane {
    display: none;
    height: 100%;
    animation: sc-fade-in 0.18s ease;
}
.oc-step-pane.oc-active {
    display: flex;
    flex-direction: column;
}

.oc-footer {
    flex-shrink: 0;
    height: 56px;
    background: var(--salescode-card, #fff);
    border-top: 1px solid var(--salescode-border, #E2EAF0);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    gap: 12px;
}

.oc-footer-hint {
    font-size: 12px;
    color: var(--salescode-bismark, #5D7989);
}

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

/* ── Stepper ── */
.oc-stepper {
    display: flex;
    align-items: center;
    gap: 4px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.oc-stepper-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.oc-stepper-btn {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 6px 10px;
    border: none;
    background: transparent;
    cursor: pointer;
    border-radius: var(--salescode-radius-md, 8px);
    transition: background var(--salescode-transition, .2s ease);
    color: var(--salescode-bismark, #5D7989);
}
.oc-stepper-btn:hover:not(:disabled) {
    background: #f0f7ff;
}
.oc-stepper-btn:disabled {
    cursor: not-allowed;
    opacity: .5;
}
.oc-stepper-btn.oc-step-active {
    color: var(--salescode-navy, #042D4D);
}
.oc-stepper-btn.oc-step-done {
    color: #16a34a;
}

.oc-step-circle {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid currentColor;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
    transition: background .2s, border-color .2s;
}
.oc-stepper-btn.oc-step-active .oc-step-circle {
    background: var(--salescode-navy, #042D4D);
    border-color: var(--salescode-navy, #042D4D);
    color: #fff;
}
.oc-stepper-btn.oc-step-done .oc-step-circle {
    background: #16a34a;
    border-color: #16a34a;
    color: #fff;
}

.oc-step-label {
    font-size: 12px;
    font-weight: 600;
}

.oc-stepper-sep {
    color: var(--salescode-border, #E2EAF0);
    font-size: 16px;
    padding: 0 2px;
}

/* ── Medidor de capacidade ── */
.oc-capacity {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: #f7fafc;
    border: 1px solid var(--salescode-border, #E2EAF0);
    border-radius: 999px;
    font-size: 12px;
    white-space: nowrap;
}

.oc-capacity-bar-wrap {
    width: 80px;
    height: 6px;
    background: #e2eaf0;
    border-radius: 3px;
    overflow: hidden;
}

.oc-capacity-bar {
    height: 100%;
    border-radius: 3px;
    background: #16a34a;
    transition: width .3s ease, background .3s;
}
.oc-capacity-bar.oc-cap-warn   { background: #f59e0b; }
.oc-capacity-bar.oc-cap-over   { background: #dc2626; }

.oc-capacity-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--salescode-bismark);
}

/* ── Etapa 1 — Pedidos ── */
.oc-step1-grid {
    display: grid;
    grid-template-columns: minmax(320px, 380px) 1fr;
    height: 100%;
    overflow: hidden;
}

.oc-pedidos-panel {
    display: flex;
    flex-direction: column;
    background: var(--salescode-card, #fff);
    border-right: 1px solid var(--salescode-border, #E2EAF0);
    overflow: hidden;
}

.oc-pedidos-header {
    padding: 16px 16px 10px;
    border-bottom: 1px solid var(--salescode-border);
    flex-shrink: 0;
}

.oc-pedidos-header h2 {
    font-size: 14px;
    font-weight: 700;
    color: var(--salescode-title, #032036);
    margin: 0 0 2px;
}

.oc-pedidos-header p {
    font-size: 12px;
    color: var(--salescode-bismark);
    margin: 0 0 10px;
}

.oc-search-input {
    width: 100%;
    padding: 7px 12px;
    border: 1px solid var(--salescode-border);
    border-radius: var(--salescode-radius-md, 8px);
    font-size: 12px;
    background: #f7fafc;
    outline: none;
    transition: border-color .2s;
}
.oc-search-input:focus {
    border-color: var(--salescode-navy);
    background: #fff;
}

.oc-pedidos-actions {
    display: flex;
    gap: 8px;
    margin-top: 8px;
}

.oc-pedidos-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px 8px;
}

.oc-pedido-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 10px;
    border-radius: var(--salescode-radius-md, 8px);
    border: 1px solid transparent;
    cursor: pointer;
    transition: background .15s, border-color .15s;
    margin-bottom: 4px;
}
.oc-pedido-row:hover {
    background: #f7fafc;
}
.oc-pedido-row.oc-selected {
    background: #eef3ff;
    border-color: var(--salescode-navy);
}

.oc-pedido-checkbox {
    width: 18px;
    height: 18px;
    border: 2px solid #c8d4de;
    border-radius: 4px;
    flex-shrink: 0;
    margin-top: 2px;
    transition: background .15s, border-color .15s;
    display: flex;
    align-items: center;
    justify-content: center;
}
.oc-pedido-row.oc-selected .oc-pedido-checkbox {
    background: var(--salescode-navy);
    border-color: var(--salescode-navy);
}
.oc-pedido-checkbox-check {
    display: none;
    color: #fff;
    font-size: 11px;
}
.oc-pedido-row.oc-selected .oc-pedido-checkbox-check {
    display: block;
}

.oc-pedido-info {
    flex: 1;
    min-width: 0;
}

.oc-pedido-code {
    font-size: 11px;
    font-weight: 600;
    color: var(--salescode-navy);
    font-family: monospace;
    letter-spacing: .03em;
}

.oc-pedido-entrega-num {
    display: none;
    font-size: 10px;
    color: #16a34a;
    font-weight: 700;
    margin-left: 6px;
}
.oc-pedido-row.oc-selected .oc-pedido-entrega-num {
    display: inline;
}

.oc-pedido-cliente {
    font-size: 13px;
    font-weight: 700;
    color: var(--salescode-title);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.oc-pedido-cidade {
    font-size: 11px;
    color: var(--salescode-bismark);
    margin-top: 1px;
}

.oc-pedido-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    flex-shrink: 0;
}

.oc-pedido-paletes {
    font-size: 11px;
    font-weight: 600;
    color: var(--salescode-bismark);
}

/* ── Diagrama / variações do mapa ── */
.oc-diagrama-panel {
    overflow: hidden;
    background: linear-gradient(135deg, #f0f4ff 0%, #eef6ff 100%);
    position: relative;
    display: flex;
    flex-direction: column;
}

/* Quando o mapa Leaflet está ativo, o painel não faz scroll — o mapa preenche */
.oc-diagrama-panel.oc-mapa-ativo {
    overflow: hidden;
    height: 100%;           /* garante que o flex pai tem altura definida */
}
.oc-diagrama-panel.oc-mapa-ativo .oc-diagrama-content {
    display: none;
}

/* Leaflet exige altura explícita em px — garante via altura absoluta do flex */
#oc-mapa-leaflet {
    flex: 1 1 0;
    min-height: 0;
    height: 100%;           /* fallback para quando flex não propaga altura */
}

/* Garante que toda a cadeia pai→filho propague a altura até o mapa */
.oc-step1-grid,
.oc-diagrama-panel {
    height: 100%;
}
.oc-step-pane.oc-active {
    height: 100%;
}

/* Sobrescreve z-index do popup Leaflet para não ficar atrás de outros elementos */
.leaflet-popup { z-index: 1000; }

/* Marcador numérico de rota */
.oc-marker-num {
    background: var(--salescode-navy, #042D4D);
    color: #fff;
    border-radius: 50%;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    border: 2px solid #fff;
    box-shadow: 0 2px 6px rgba(0,0,0,.3);
}
.oc-marker-num.oc-marker-sel {
    background: var(--salescode-navy, #042D4D);
}
.oc-marker-num.oc-marker-unsel {
    background: #94a3b8;
}

.oc-diagrama-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px 10px;
    flex-shrink: 0;
}

.oc-diagrama-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--salescode-bismark);
    text-transform: uppercase;
    letter-spacing: .06em;
}

.oc-variant-tabs {
    display: flex;
    background: #fff;
    border: 1px solid var(--salescode-border);
    border-radius: 6px;
    padding: 2px;
    gap: 2px;
}

.oc-variant-tab {
    padding: 4px 12px;
    font-size: 11px;
    font-weight: 600;
    border: none;
    background: transparent;
    border-radius: 4px;
    cursor: pointer;
    color: var(--salescode-bismark);
    transition: background .15s, color .15s;
}
.oc-variant-tab.oc-active {
    background: var(--salescode-navy);
    color: #fff;
}

.oc-diagrama-content {
    flex: 1;
    position: relative;
    min-height: 300px;
    padding: 16px 20px;
}

/* Hub / constelação */
.oc-hub-map {
    position: relative;
    width: 100%;
    padding-top: 70%;
    background-image: radial-gradient(circle, #d8e2f0 1px, transparent 1px);
    background-size: 28px 28px;
    border-radius: var(--salescode-radius-lg);
    overflow: hidden;
}

.oc-hub-inner {
    position: absolute;
    inset: 0;
}

.oc-hub-node {
    position: absolute;
    transform: translate(-50%, -50%);
}

.oc-fab-node {
    width: 54px;
    height: 54px;
    background: var(--salescode-navy);
    color: #fff;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: 700;
    text-align: center;
    box-shadow: var(--salescode-shadow-md);
}

.oc-ped-node {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
}

.oc-ped-pin {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid #c8d4de;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    transition: background .15s, border-color .15s;
    box-shadow: var(--salescode-shadow-sm);
}
.oc-ped-node.oc-selected .oc-ped-pin {
    background: var(--salescode-navy);
    border-color: var(--salescode-navy);
    color: #fff;
}
.oc-ped-node:hover .oc-ped-pin {
    border-color: var(--salescode-navy);
}

.oc-ped-node-label {
    font-size: 10px;
    font-weight: 600;
    color: var(--salescode-subtitle);
    margin-top: 3px;
    white-space: nowrap;
}

/* Grade de cards */
.oc-grade-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
}

.oc-grade-card {
    background: var(--salescode-card);
    border: 1px solid var(--salescode-border);
    border-radius: var(--salescode-radius-md);
    padding: 12px;
    cursor: pointer;
    transition: border-color .15s, box-shadow .15s;
}
.oc-grade-card:hover {
    border-color: #aac0d4;
    box-shadow: var(--salescode-shadow-sm);
}
.oc-grade-card.oc-selected {
    border-color: var(--salescode-navy);
    background: #eef3ff;
}

/* Resumo flutuante */
.oc-resumo-float {
    position: absolute;
    bottom: 16px;
    right: 16px;
    background: var(--salescode-card);
    border: 1px solid var(--salescode-border);
    border-radius: var(--salescode-radius-md);
    padding: 10px 14px;
    box-shadow: var(--salescode-shadow-md);
    font-size: 12px;
    display: none;
    gap: 12px;
}
.oc-resumo-float.oc-visible {
    display: flex;
}

.oc-resumo-item {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.oc-resumo-val {
    font-size: 18px;
    font-weight: 800;
    color: var(--salescode-navy);
    line-height: 1;
}

.oc-resumo-lbl {
    font-size: 10px;
    color: var(--salescode-bismark);
    margin-top: 2px;
}

/* ── Separador de estado na lista lateral ── */
.oc-uf-separator {
    padding: 6px 10px 4px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--salescode-bismark);
    background: #f7fafc;
    border-top: 1px solid var(--salescode-border);
    border-bottom: 1px solid var(--salescode-border);
    margin: 4px 0 2px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.oc-uf-separator:first-child {
    border-top: none;
    margin-top: 0;
}


.oc-ped-produtos {
    display: none;
    margin-top: 6px;
    border-top: 1px solid var(--salescode-border);
    padding-top: 6px;
}

/* Exibe automaticamente quando o pedido está selecionado */
.oc-pedido-row.oc-selected .oc-ped-produtos {
    display: block;
}

.oc-produto-linha {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 3px 0;
    font-size: 11px;
    color: var(--salescode-subtitle);
    gap: 8px;
}
.oc-produto-linha:not(:last-child) {
    border-bottom: 1px solid #f0f4f8;
}
.oc-produto-nome {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.oc-produto-qtd {
    font-weight: 700;
    color: var(--salescode-title);
    white-space: nowrap;
    flex-shrink: 0;
}

/* ── FreteBadge ── */
.oc-frete-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 7px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    line-height: 1.4;
}
.oc-frete-badge.oc-cif {
    background: #e0f2f7;
    color: #0e7490;
}
.oc-frete-badge.oc-fob {
    background: #fbedd8;
    color: #b45309;
}
.oc-frete-badge.oc-sem {
    background: #f1f5f9;
    color: #64748b;
}

/* ── Etapa 2 — Ordem de Carga ── */
.oc-step2-grid {
    display: grid;
    grid-template-columns: minmax(340px, 400px) 1fr;
    height: 100%;
    overflow: hidden;
}

.oc-veiculo-panel {
    background: var(--salescode-card);
    border-right: 1px solid var(--salescode-border);
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.oc-panel-section-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--salescode-bismark);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 8px;
}

/* Motorista — campo livre com sugestões */
.oc-motorista-input-wrap {
    position: relative;
}

/* Caminhão — cards de tipo */
.oc-caminhao-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.oc-caminhao-card {
    padding: 10px 12px;
    border: 2px solid var(--salescode-border);
    border-radius: var(--salescode-radius-md);
    cursor: pointer;
    text-align: center;
    transition: border-color .15s, background .15s;
    background: #f7fafc;
}
.oc-caminhao-card:hover {
    border-color: #aac0d4;
    background: #fff;
}
.oc-caminhao-card.oc-selected {
    border-color: var(--salescode-navy);
    background: #eef3ff;
}

.oc-caminhao-label {
    font-size: 14px;
    font-weight: 700;
    color: var(--salescode-title);
}

.oc-caminhao-cap {
    font-size: 11px;
    color: var(--salescode-bismark);
    margin-top: 2px;
}

/* Capacidade no painel */
.oc-capacity-card {
    border: 1px solid var(--salescode-border);
    border-radius: var(--salescode-radius-md);
    padding: 12px 14px;
    background: #f7fafc;
}

.oc-capacity-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}

.oc-capacity-nums {
    font-size: 13px;
    font-weight: 700;
    color: var(--salescode-title);
}

/* Ordem de entrega */
.oc-entrega-panel {
    overflow-y: auto;
    background: #f6f7fb;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.oc-entrega-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 4px;
}

.oc-drag-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.oc-drag-item {
    background: var(--salescode-card);
    border: 1px solid var(--salescode-border);
    border-radius: var(--salescode-radius-md);
    overflow: hidden;
    transition: box-shadow .15s;
}
.oc-drag-item.oc-dragging {
    box-shadow: var(--salescode-shadow-lg);
    opacity: .8;
}
.oc-drag-item.oc-drag-over {
    border-color: var(--salescode-navy);
}

.oc-drag-item-top {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
}

.oc-drag-handle {
    cursor: grab;
    color: #c8d4de;
    padding: 2px;
    flex-shrink: 0;
}
.oc-drag-handle:active {
    cursor: grabbing;
}

.oc-drag-num {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--salescode-navy);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.oc-drag-info {
    flex: 1;
    min-width: 0;
}

.oc-drag-cliente {
    font-size: 14px;
    font-weight: 700;
    color: var(--salescode-title);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.oc-drag-sub {
    font-size: 11px;
    color: var(--salescode-bismark);
    margin-top: 1px;
}

.oc-drag-item-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    padding: 8px 12px;
    border-top: 1px solid var(--salescode-border);
    background: #fafbfc;
}

/* ── Corpo do card de entrega (produtos + paletes) ── */
.oc-drag-item-body {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 8px 12px;
    border-top: 1px solid var(--salescode-border);
    background: #fafbfc;
}

.oc-drag-produtos-list {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.oc-drag-produto-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    color: var(--salescode-subtitle);
}

.oc-drag-produto-nome {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}

.oc-drag-produto-qtd {
    font-weight: 700;
    color: var(--salescode-title);
    white-space: nowrap;
    flex-shrink: 0;
}

.oc-drag-palete-ctrl {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex-shrink: 0;
    align-items: flex-end;
}

.oc-palete-row {
    display: flex;
    align-items: center;
    gap: 4px;
}

.oc-palete-label {
    font-size: 10px;
    font-weight: 700;
    color: var(--salescode-bismark);
    text-transform: uppercase;
    letter-spacing: .04em;
    width: 28px;
    text-align: right;
}

.oc-palete-input {
    width: 44px;
    text-align: center;
    font-size: 13px;
    font-weight: 700;
    color: var(--salescode-title);
    border: 1px solid var(--salescode-border);
    border-radius: 4px;
    padding: 2px 4px;
    background: #fff;
}
.oc-palete-input:focus {
    outline: none;
    border-color: var(--salescode-navy);
}

/* ── Edição de capacidade do caminhão ── */
.oc-cap-edit-row {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 8px 0;
}

.oc-cap-sugestao {
    font-size: 11px;
    color: var(--salescode-bismark);
    margin-left: 4px;
}

.oc-cap-sugestao a {
    color: var(--salescode-navy);
    cursor: pointer;
    text-decoration: underline;
    font-weight: 600;
}

/* ── Segmented control ── */
.oc-segmented {
    display: flex;
    align-items: center;
    gap: 4px;
}

.oc-segmented-label {
    font-size: 10px;
    font-weight: 700;
    color: var(--salescode-bismark);
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
}

.oc-segmented-group {
    display: flex;
    background: #f0f4f8;
    border-radius: 6px;
    padding: 2px;
    gap: 2px;
}

.oc-seg-btn {
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 600;
    border: none;
    background: transparent;
    border-radius: 4px;
    cursor: pointer;
    color: var(--salescode-bismark);
    transition: background .15s, color .15s;
}
.oc-seg-btn.oc-seg-active {
    background: var(--salescode-card);
    color: var(--salescode-title);
    box-shadow: 0 1px 3px rgba(0,0,0,.1);
}

/* ── Etapa 3 — Paletização ── */
.oc-step3-grid {
    display: grid;
    grid-template-columns: 300px 1fr;
    height: 100%;
    overflow: hidden;
    transition: grid-template-columns .25s ease;
}
.oc-step3-grid.oc-editor-open {
    grid-template-columns: 300px 1fr 360px;
}

.oc-paletizacao-legenda {
    background: var(--salescode-card);
    border-right: 1px solid var(--salescode-border);
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.oc-ped-legend-card {
    border: 1px solid var(--salescode-border);
    border-radius: var(--salescode-radius-md);
    overflow: hidden;
}

.oc-ped-legend-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--salescode-border);
    background: #fafbfc;
}

.oc-ped-color-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}

.oc-ped-legend-nome {
    font-size: 12px;
    font-weight: 700;
    color: var(--salescode-title);
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.oc-ped-legend-body {
    padding: 8px 12px;
    display: flex;
    gap: 12px;
}

.oc-unit-counter {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
}

.oc-unit-label {
    font-size: 10px;
    font-weight: 700;
    color: var(--salescode-bismark);
    text-transform: uppercase;
    letter-spacing: .04em;
}

.oc-counter-ctrl {
    display: flex;
    align-items: center;
    gap: 4px;
}

.oc-counter-btn {
    width: 22px;
    height: 22px;
    border: 1px solid var(--salescode-border);
    background: #f7fafc;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    font-weight: 700;
    color: var(--salescode-navy);
    transition: background .1s;
}
.oc-counter-btn:hover {
    background: #e8f0f8;
}

.oc-counter-val {
    width: 28px;
    text-align: center;
    font-size: 13px;
    font-weight: 700;
    color: var(--salescode-title);
}

/* Caminhão — vista superior */
.oc-caminhao-panel {
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 24px 20px;
    background: #eff1f6;
    gap: 16px;
}

.oc-caminhao-wrap {
    width: 100%;
    max-width: 480px;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.oc-caminhao-cabine {
    background: var(--salescode-navy);
    border-radius: 10px 10px 4px 4px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--salescode-lime);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.oc-caminhao-bau {
    border: 3px solid var(--salescode-navy);
    border-top: none;
    border-radius: 0 0 8px 8px;
    background: repeating-linear-gradient(
        45deg,
        #e8eff6,
        #e8eff6 4px,
        #f0f4fa 4px,
        #f0f4fa 16px
    );
    padding: 10px;
}

.oc-caminhao-fundo {
    font-size: 9px;
    font-weight: 700;
    text-align: center;
    color: var(--salescode-bismark);
    text-transform: uppercase;
    letter-spacing: .08em;
    padding-top: 4px;
}

.oc-slot-grid {
    display: grid;
    gap: 6px;
}
.oc-slot-grid[data-cols="2"] { grid-template-columns: 1fr 1fr; }
.oc-slot-grid[data-cols="3"] { grid-template-columns: 1fr 1fr 1fr; }

.oc-slot {
    min-height: 68px;
    border-radius: var(--salescode-radius-sm);
    border: 2px dashed #c8d4de;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    color: #b0bec5;
    font-weight: 600;
    cursor: pointer;
    transition: border-color .15s, background .15s;
    position: relative;
}
.oc-slot:hover {
    border-color: var(--salescode-navy);
    background: rgba(4,45,77,.04);
}

.oc-slot.oc-slot-filled {
    border-style: solid;
    border-color: transparent;
    color: #fff;
    flex-direction: column;
    gap: 2px;
    text-align: center;
    padding: 6px 4px;
}

.oc-slot-cliente {
    font-size: 10px;
    font-weight: 700;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 100%;
    text-align: center;
}

.oc-slot-code {
    font-size: 9px;
    opacity: .85;
    font-family: monospace;
}

/* Bags zone */
.oc-bags-zone {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

.oc-bag-chip {
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    color: #fff;
    cursor: pointer;
    transition: opacity .15s;
}
.oc-bag-chip:hover { opacity: .85; }

/* ── Etapa 4 — Romaneio ── */
.oc-romaneio-stage {
    background: #eff1f6;
    overflow-y: auto;
    padding: 32px 24px;
    display: flex;
    justify-content: center;
    align-items: flex-start; /* não estica o papel — ele cresce com o conteúdo */
}

.oc-papel {
    width: 820px;
    max-width: 100%;
    background: #fff;
    border-radius: var(--salescode-radius-md);
    box-shadow: var(--salescode-shadow-lg);
    padding: 40px 44px;
    font-size: 13px;
    color: #191c27;
}

.oc-papel-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding-bottom: 16px;
    border-bottom: 2px solid #191c27;
    margin-bottom: 20px;
}

.oc-papel-titulo {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #6a7080;
    font-weight: 700;
}

.oc-papel-nome {
    font-size: 20px;
    font-weight: 800;
    color: #191c27;
    margin-top: 4px;
}

.oc-papel-num {
    font-family: monospace;
    font-size: 13px;
    font-weight: 600;
    color: var(--salescode-navy);
}

.oc-papel-data {
    font-size: 11px;
    color: #6a7080;
    margin-top: 2px;
    text-align: right;
}

.oc-dados-gerais {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border: 1px solid #e2e5ee;
    border-radius: var(--salescode-radius-sm);
    overflow: hidden;
    margin-bottom: 20px;
}

.oc-dado-cell {
    padding: 10px 14px;
    border-right: 1px solid #e2e5ee;
}
.oc-dado-cell:last-child { border-right: none; }

.oc-dado-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #6a7080;
    margin-bottom: 4px;
}

.oc-dado-val {
    font-size: 13px;
    font-weight: 600;
    color: #191c27;
}

.oc-entrega-bloco {
    border: 1px solid #e2e5ee;
    border-radius: var(--salescode-radius-sm);
    overflow: hidden;
    margin-bottom: 12px;
    page-break-inside: avoid;
}

.oc-entrega-bloco-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: #f6f7fb;
    border-bottom: 1px solid #e2e5ee;
}

.oc-entrega-num-badge {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--salescode-navy);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.oc-entrega-bloco-cliente {
    flex: 1;
}

.oc-entrega-bloco-nome {
    font-size: 13px;
    font-weight: 700;
}

.oc-entrega-bloco-sub {
    font-size: 11px;
    color: #6a7080;
}

.oc-entrega-produtos {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}

.oc-entrega-produtos th {
    background: #f6f7fb;
    padding: 6px 14px;
    text-align: left;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #6a7080;
    border-bottom: 1px solid #e2e5ee;
}

.oc-entrega-produtos td {
    padding: 8px 14px;
    border-bottom: 1px solid #f0f2f7;
}

.oc-entrega-produtos tr:last-child td {
    border-bottom: none;
}

/* Checklist de unidades */
.oc-checklist {
    border: 1px solid #e2e5ee;
    border-radius: var(--salescode-radius-sm);
    padding: 14px;
    margin-bottom: 16px;
}

.oc-checklist-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #6a7080;
    margin-bottom: 10px;
}

.oc-checklist-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 8px;
}

.oc-checklist-item {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.oc-checklist-box {
    width: 16px;
    height: 16px;
    border: 2px solid #c8d4de;
    border-radius: 3px;
    flex-shrink: 0;
    transition: background .15s, border-color .15s;
}
.oc-checklist-item.oc-checked .oc-checklist-box {
    background: var(--salescode-navy);
    border-color: var(--salescode-navy);
}

.oc-checklist-text {
    font-size: 12px;
    font-weight: 500;
}

/* Termo */
.oc-termo {
    border: 1px solid #e2e5ee;
    border-radius: var(--salescode-radius-sm);
    padding: 14px;
    margin-bottom: 16px;
    background: #fafbfc;
}

.oc-termo-title {
    font-size: 12px;
    font-weight: 700;
    margin-bottom: 8px;
}

.oc-termo-text {
    font-size: 11px;
    color: #3a3f4f;
    line-height: 1.6;
}

.oc-termo-check {
    margin-top: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
}

/* Assinaturas */
.oc-assinaturas {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-top: 24px;
}

.oc-assinatura {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.oc-assinatura-linha {
    width: 100%;
    border-bottom: 1px solid #191c27;
    margin-bottom: 4px;
    height: 32px;
}

.oc-assinatura-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #6a7080;
    text-align: center;
}

/* ── @media print ── */
@media print {
    .oc-layout .oc-topbar,
    .oc-layout .oc-footer,
    .oc-termo-check,
    .no-print { display: none !important; }

    .oc-layout {
        height: auto;
        overflow: visible;
    }

    .oc-main {
        overflow: visible;
    }

    .oc-romaneio-stage {
        padding: 0;
        background: #fff;
    }

    .oc-papel {
        width: 100%;
        box-shadow: none;
        border-radius: 0;
        padding: 20px;
    }
}

/* ── Responsivo ── */
@media (max-width: 768px) {
    .oc-step1-grid,
    .oc-step2-grid,
    .oc-step3-grid {
        grid-template-columns: 1fr;
    }

    .oc-pedidos-panel,
    .oc-veiculo-panel {
        max-height: 50vh;
    }

    .oc-stepper .oc-step-label { display: none; }

    .oc-dados-gerais {
        grid-template-columns: 1fr 1fr;
    }

    .oc-assinaturas {
        grid-template-columns: 1fr 1fr;
    }
}
