/* Layout padrão — tela de OS: tudo empilhado verticalmente (sem tabela ao lado) */

.os-layout-padrao {
    display: flex;
    flex-direction: column;
    height: calc(100dvh - 5.25rem);
    min-height: 0;
    overflow: hidden;
    gap: 0.6rem;
}

.nexum-main:has(.os-layout-padrao) {
    overflow: hidden;
}

.os-layout-padrao .os-topo {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem 1rem;
    flex-shrink: 0;
}

.os-layout-padrao .os-topo .page-title {
    font-size: 1.5rem;
    margin-bottom: 0.1rem;
}

.os-layout-padrao .os-topo .page-subtitle {
    font-size: 0.88rem;
}

.os-layout-padrao .os-acoes {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    justify-content: flex-end;
}

.os-layout-padrao .os-alerta {
    flex-shrink: 0;
    margin: 0;
    padding: 0.5rem 0.85rem;
    font-size: 0.88rem;
}

.os-layout-padrao .os-fiscal-faixa {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    flex-shrink: 0;
}

.os-layout-padrao .os-fiscal-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.65rem;
    border-radius: 0.5rem;
    background: #ecfdf5;
    border: 1px solid #a7f3d0;
    font-size: 0.78rem;
    color: #065f46;
}

.os-layout-padrao .os-fiscal-chip .chave-nf {
    font-size: 0.72rem;
    max-width: 14rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin: 0;
}

.os-fiscal-nf-cell {
    display: inline-flex;
    align-items: center;
    align-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    min-height: 1.85rem;
}

.os-fiscal-nf-cell .badge {
    display: inline-flex;
    align-items: center;
    margin: 0;
    padding: 0.35rem 0.6rem;
    font-size: 0.8rem;
    line-height: 1;
}

.os-fiscal-nf-cell .form-check {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin: 0;
    padding: 0;
    min-height: 0;
}

.os-fiscal-nf-cell .form-check-input {
    float: none;
    margin: 0;
    flex-shrink: 0;
    width: 1.05rem;
    height: 1.05rem;
    vertical-align: middle;
}

.os-fiscal-nf-cell .form-check-label {
    margin: 0;
    padding: 0;
    font-size: 0.85rem;
    line-height: 1.05rem;
}

.os-fiscal-nf-cell__link {
    display: inline-flex;
    align-items: center;
    font-size: 0.85rem;
    line-height: 1.05rem;
    padding: 0;
}

.os-impressao-modal-tabela {
    max-height: min(50vh, 22rem);
    overflow: auto;
}

.os-impressao-modal-tabela .os-impressao-col-tipo {
    width: 10.5rem;
    min-width: 10.5rem;
}

.os-impressao-modal-tabela .os-impressao-col-qtd {
    width: 8rem;
    min-width: 8rem;
}

.os-impressao-modal-tabela .os-impressao-col-unit {
    width: 9.5rem;
    min-width: 9.5rem;
}

.os-impressao-modal-tabela .os-impressao-col-total {
    width: 8.5rem;
    min-width: 8.5rem;
}

.os-impressao-modal-tabela .os-impressao-input,
.os-impressao-modal-tabela td:first-child .form-select {
    min-height: 2.125rem;
    font-size: 0.9rem;
    padding: 0.4rem 0.55rem;
}

.os-impressao-modal-tabela td:first-child .form-select {
    min-width: 10rem;
    width: 100%;
}

/* Campos de seleção (cliente, funcionário, etc.) na OS */
.os-layout-padrao .os-card-dados-selecao .os-selecao-campo .nexum-selecao-campo.input-group {
    gap: 0.25rem;
}

.os-layout-padrao .os-card-dados-selecao .os-selecao-campo .nexum-selecao-autocomplete .form-control {
    border-radius: 0.45rem;
}

.os-layout-padrao .os-card-dados-selecao .os-selecao-campo .nexum-selecao-autocomplete-painel {
    border-radius: 0.5rem;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.14);
}

.os-layout-padrao .os-card-dados {
    flex-shrink: 0;
    background: #fff;
    border: none;
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(23, 29, 47, 0.08);
    padding: 0.85rem 1rem;
}

.os-layout-padrao .os-card-dados .form-label {
    margin-bottom: 0.25rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: #636e8b;
}

.os-layout-padrao .os-campo-linha {
    min-height: calc(1.5em + 0.75rem + 2px);
    resize: none;
}

.os-layout-padrao .os-card-dados .form-control,
.os-layout-padrao .os-card-dados .form-select {
    min-height: calc(1.5em + 0.75rem + 2px);
}

/* Corpo: coluna única — dados já acima; depois add item, pagamentos, itens */
.os-layout-padrao .os-corpo-vertical {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.os-layout-padrao .os-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: none;
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(23, 29, 47, 0.08);
    overflow: hidden;
    flex-shrink: 0;
}

.os-layout-padrao .os-card--itens {
    flex: 1;
    min-height: 0;
    flex-shrink: 1;
}

.os-layout-padrao .os-card-cabecalho {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.6rem 1rem;
    border-bottom: 1px solid #dde2ef;
    flex-shrink: 0;
}

.os-layout-padrao .os-card-cabecalho h5 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: #171d2f;
}

.os-layout-padrao .os-card-corpo {
    padding: 0.75rem 1rem;
}

/* Adicionar item */
.os-layout-padrao .os-add-linha {
    display: grid;
    grid-template-columns: 6.5rem 1fr;
    gap: 0.65rem;
    align-items: end;
}

.os-layout-padrao .os-add-linha + .os-add-linha {
    margin-top: 0.6rem;
}

.os-layout-padrao .os-add-linha--acao {
    grid-template-columns: 5.5rem 1fr;
}

/* Pagamentos */
.os-layout-padrao .os-pg-formulario {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

@media (min-width: 768px) {
    .os-layout-padrao .os-pg-formulario .os-pg-linha:first-child:last-child {
        max-width: 28rem;
    }
}

.os-layout-padrao .os-pg-linha {
    display: grid;
    grid-template-columns: 1fr 7rem;
    gap: 0.65rem;
    align-items: end;
}

.os-layout-padrao .os-pg-linha--com-remover {
    grid-template-columns: 1fr 7rem 2rem;
    max-width: 32rem;
}

.os-layout-padrao .os-pg-botoes {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.6rem;
}

.os-layout-padrao .os-pg-salvos {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 0.6rem;
}

.os-layout-padrao .os-pg-tag {
    font-size: 0.78rem;
    padding: 0.25rem 0.55rem;
    background: #e8ebf0;
    border-radius: 0.35rem;
}

.os-layout-padrao .os-pg-resumo {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
    flex-shrink: 0;
    padding: 0.5rem 0.85rem;
    background: #fff;
    border-radius: 0.5rem;
    box-shadow: 0 1px 3px rgba(23, 29, 47, 0.06);
}

/* Tabela de itens — largura total, por último */
.os-layout-padrao .os-itens-scroll {
    flex: 1;
    min-height: 0;
    overflow: auto;
}

.os-layout-padrao .os-itens-scroll .table thead th {
    padding: 0.55rem 1rem;
    font-size: 0.75rem;
    position: sticky;
    top: 0;
    z-index: 1;
    background: #e8ebf0;
}

.os-layout-padrao .os-itens-scroll .table tbody td {
    padding: 0.55rem 1rem;
    font-size: 0.88rem;
    vertical-align: middle;
}

/* CFOP (4 dígitos), CSOSN (até 4) e alíquota IPI — largura para exibir o valor inteiro */
.os-layout-padrao .os-input-fiscal-cfop {
    width: 6.25rem;
    min-width: 6.25rem;
    max-width: 6.25rem;
}

.os-layout-padrao .os-input-fiscal-csosn {
    width: 5rem;
    min-width: 5rem;
    max-width: 5rem;
}

.os-layout-padrao .os-input-fiscal-ipi {
    width: 5.5rem;
    min-width: 5.5rem;
    max-width: 5.5rem;
}

.os-layout-padrao .os-itens-rodape {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem 1.5rem;
    padding: 0.6rem 1rem;
    background: #f2f4fa;
    border-top: 1px solid #dde2ef;
    font-size: 0.9rem;
    flex-shrink: 0;
}

.os-layout-padrao .os-itens-rodape .os-total-final {
    margin-left: auto;
    font-size: 1rem;
    font-weight: 700;
}

.os-emissao-opcao {
    display: flex;
    gap: 0.65rem;
    align-items: flex-start;
    padding: 0.75rem 1rem;
    border: 1px solid #dde2ef;
    border-radius: 8px;
    cursor: pointer;
    margin: 0;
}

.os-emissao-opcao.ativo {
    border-color: var(--kaju-primary, #2563eb);
    background: rgba(37, 99, 235, 0.06);
}

.os-emissao-opcao input {
    margin-top: 0.2rem;
}

@media (max-width: 767.98px) {
    .os-layout-padrao {
        height: auto;
        overflow: visible;
    }

    .os-layout-padrao .os-corpo-vertical {
        overflow: visible;
    }

    .os-layout-padrao .os-card--itens {
        max-height: none;
    }

    .os-layout-padrao .os-itens-scroll {
        max-height: 240px;
    }
}
