/* Secao Orcamento — visual inspirado no Qwilr (editor + viewer). */

:root {
    --orc-indigo: #4f3ff0;
    --orc-indigo-dark: #3d2ed6;
    --orc-indigo-soft: #edebff;
    --orc-ink: #2a2a3c;
    --orc-ink-soft: #6b6b80;
    --orc-line: #ececf2;
    --orc-bg-soft: #f5f5fa;
    --orc-card-shadow: 0 8px 30px -10px rgba(28, 24, 70, .22);
}

/* carregarSecao.js injeta uma regra global ".secao-com-cor-fundo .ki-outline {
   color: var(--cor-fonte-secao) !important; }" para auto-contraste das secoes
   onde icones ficam direto sobre o fundo colorido. No editor/viewer de
   orcamento, todos os icones estao dentro de cards/botoes com fundo proprio
   (header em accent, botao navy, cards brancos), entao esse override quebra
   visualmente (ex: lapis branco vira escuro dentro do botao navy = some).
   Restaura `inherit` aqui — cada icone herda do seu container imediato. */
.secao-com-cor-fundo .orc-editor .ki-outline,
.secao-com-cor-fundo .orc-editor i[class*="ki-"],
.secao-com-cor-fundo .orc-view .ki-outline,
.secao-com-cor-fundo .orc-view i[class*="ki-"] {
    color: inherit !important;
}

.orc-editor, .orc-editor *,
.orc-view, .orc-view *,
.orc-preset, .orc-preset * {
    box-sizing: border-box;
}

.orc-editor,
.orc-view,
.orc-preset {
    font-family: inherit;
    color: var(--orc-ink);
    width: 100%;
    position: relative;
}

/* ===================== MODAL DE PRESET ===================== */

.orc-preset {
    padding: 1.5rem .5rem 2.5rem;
    text-align: center;
}

.orc-preset-head {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin-bottom: 2rem;
}

.orc-preset-title {
    font-size: 1.55rem;
    font-weight: 700;
    color: var(--orc-ink);
}

.orc-preset-close {
    position: absolute;
    right: 0;
    top: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 50%;
    background: var(--orc-bg-soft);
    color: var(--orc-ink-soft);
    cursor: pointer;
}

.orc-preset-close:hover {
    background: #e9e9f1;
}

.orc-preset-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    max-width: 720px;
    margin: 0 auto;
}

.orc-preset-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1.25rem 1.25rem 1.5rem;
    border: 1.5px solid #e7e7f0;
    border-radius: 1rem;
    background: #fff;
    cursor: pointer;
    transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}

.orc-preset-card:hover {
    border-color: var(--orc-indigo);
    transform: translateY(-4px);
    box-shadow: var(--orc-card-shadow);
}

.orc-preset-thumb {
    width: 100%;
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: .65rem;
    background: var(--orc-bg-soft);
    margin-bottom: 1rem;
}

.orc-tmb-tabela {
    width: 76%;
    border-radius: .4rem;
    background: #fff;
    box-shadow: 0 4px 14px -6px rgba(28, 24, 70, .35);
    overflow: hidden;
}

.orc-tmb-bar {
    height: 20px;
    background: var(--orc-indigo);
}

.orc-tmb-rows {
    padding: 9px 10px;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.orc-tmb-line {
    height: 5px;
    border-radius: 3px;
    background: #e2e2ec;
}

.orc-tmb-line:nth-child(2) { width: 80%; }
.orc-tmb-line:nth-child(3) { width: 90%; }

.orc-tmb-total {
    margin: 4px 10px 10px;
    height: 13px;
    border-radius: 3px;
    background: var(--orc-indigo);
}

.orc-tmb-planos {
    display: flex;
    align-items: flex-end;
    gap: 8px;
}

.orc-tmb-plan {
    width: 34px;
    height: 70px;
    border-radius: .4rem;
    background: #fff;
    box-shadow: 0 4px 12px -6px rgba(28, 24, 70, .35);
}

.orc-tmb-plan.is-rec {
    height: 92px;
    background: var(--orc-indigo);
}

.orc-preset-name {
    font-size: 1.1rem;
    font-weight: 700;
}

.orc-preset-desc {
    font-size: .85rem;
    color: var(--orc-ink-soft);
    margin-top: .25rem;
}

.orc-preset-soon {
    position: absolute;
    top: .8rem;
    right: .8rem;
    font-size: .62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: .2rem .5rem;
    border-radius: .35rem;
    background: var(--orc-indigo-soft);
    color: var(--orc-indigo);
}

/* ===================== BLOCO (editor + viewer) ===================== */

.orc-block {
    background: #fff;
    border-radius: 1rem;
    box-shadow: var(--orc-card-shadow);
    overflow: hidden;
}

.orc-block-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    background: var(--orc-accent, #4f3ff0);
    padding: 1.5rem 2rem;
    min-height: 92px;
}

.orc-block-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--orc-accent-text, #fff);
    flex: 1 1 auto;
    min-width: 0;
}

.orc-block-title-input {
    flex: 1 1 auto;
    min-width: 0;
    border: none;
    background: transparent;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--orc-accent-text, #fff);
    padding: .15rem 0;
}

.orc-block-title-input::placeholder {
    color: var(--orc-accent-text, #fff);
    opacity: .55;
    font-weight: 600;
}

.orc-block-title-input:focus {
    outline: none;
}

/* logo do cliente no cabecalho (viewer) */
.orc-view-logo {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
}

.orc-view-logo:empty {
    display: none;
}

/* logo editavel no cabecalho (editor da tabela) */
.orc-logo-edit {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.orc-logo-img {
    position: relative;
    display: inline-flex;
    cursor: pointer;
}

.orc-logo-img img {
    display: block;
    max-height: 46px;
    max-width: 170px;
    background: #fff;
    border-radius: .55rem;
    padding: .4rem .65rem;
    object-fit: contain;
    box-shadow: 0 4px 14px -4px rgba(20, 20, 50, .3);
}

/* logo sem a plaquinha branca (direto no cabecalho) */
.orc-logo-img img.orc-logo-plain,
.orc-view-logo img.orc-logo-plain {
    background: transparent;
    box-shadow: none;
    padding: 0;
    border-radius: 0;
}

/* dica de "editar" ao passar o mouse na logo */
.orc-logo-hint {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(20, 20, 50, .5);
    border-radius: .55rem;
    color: #fff;
    opacity: 0;
    transition: opacity .12s ease;
}

.orc-logo-img:hover .orc-logo-hint { opacity: 1; }

.orc-logo-menu { min-width: 220px; }

.orc-logo-add {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    border: 1px dashed rgba(255, 255, 255, .55);
    background: transparent;
    color: var(--orc-accent-text, #fff);
    font-size: .78rem;
    font-weight: 600;
    padding: .32rem .6rem;
    border-radius: .4rem;
    cursor: pointer;
    opacity: .85;
}

.orc-logo-add:hover { opacity: 1; }

.orc-logo-loading {
    color: var(--orc-accent-text, #fff);
    font-size: .8rem;
    opacity: .8;
}

.orc-view-logo img {
    display: block;
    max-height: 46px;
    max-width: 170px;
    background: #fff;
    border-radius: .55rem;
    padding: .4rem .65rem;
    object-fit: contain;
    box-shadow: 0 4px 14px -4px rgba(20, 20, 50, .3);
}

.orc-block-body {
    padding: .35rem 2rem 1.2rem;
}

#orcamentoTabelaWrap {
    overflow-x: auto;
}

/* ----- tabela ----- */
.orc-table {
    width: 100%;
    border-collapse: collapse;
}

.orc-table thead th {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--orc-ink);
    padding: 1rem .6rem;
    border-bottom: 1px solid var(--orc-line);
    text-align: left;
    vertical-align: middle;
}

.orc-table thead th.orc-th-num { text-align: right; }

/* drag-and-drop de colunas */
.orc-th-over {
    box-shadow: inset 3px 0 0 0 var(--orc-ink);
    background: var(--orc-bg-soft);
}

.orc-th-cell {
    display: flex;
    align-items: center;
    gap: .2rem;
}

.orc-th-num .orc-th-cell { justify-content: flex-end; }

.orc-grip {
    flex-shrink: 0;
    color: #c2c2cf;
    cursor: grab;
    font-size: 1rem;
    line-height: 1;
    padding: 0 .15rem;
    user-select: none;
}

.orc-grip:active { cursor: grabbing; }

.orc-th-name {
    border: none;
    background: transparent;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--orc-ink);
    padding: .25rem .35rem;
    border-radius: .35rem;
    min-width: 50px;
    width: 100%;
}

.orc-th-num .orc-th-name { text-align: right; }

.orc-th-name:focus {
    outline: none;
    background: var(--orc-bg-soft);
}

.orc-col-tipo {
    flex-shrink: 0;
    border: 1px solid var(--orc-line);
    border-radius: .35rem;
    background: #fff;
    font-size: .72rem;
    font-weight: 600;
    color: var(--orc-ink-soft);
    padding: .2rem .25rem;
    cursor: pointer;
}

.orc-col-tipo:focus { outline: none; }

.orc-th-btn {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    border-radius: .3rem;
    color: #b9b9c6;
    cursor: pointer;
}

.orc-th-btn:hover {
    background: var(--orc-bg-soft);
    color: var(--orc-ink-soft);
}

.orc-table tbody td {
    padding: .6rem .6rem;
    border-bottom: 1px solid var(--orc-line);
    vertical-align: middle;
    font-size: 1.05rem;
    color: var(--orc-ink);
}

.orc-table tbody tr:last-child td { border-bottom: none; }

.orc-td-num { text-align: right; }

.orc-cell {
    width: 100%;
    border: 1px solid transparent;
    background: transparent;
    border-radius: .4rem;
    padding: .5rem .55rem;
    font-size: 1.05rem;
    color: var(--orc-ink);
}

.orc-cell:hover { border-color: var(--orc-line); }

.orc-cell:focus {
    outline: none;
    border-color: var(--orc-ink-soft);
    background: #fff;
}

.orc-cell-num {
    text-align: right;
    -moz-appearance: textfield;
}

.orc-total-desc-val,
.orc-line-desc-val {
    -moz-appearance: textfield;
    appearance: textfield;
}

.orc-cell-num::-webkit-outer-spin-button,
.orc-cell-num::-webkit-inner-spin-button,
.orc-total-desc-val::-webkit-outer-spin-button,
.orc-total-desc-val::-webkit-inner-spin-button,
.orc-line-desc-val::-webkit-outer-spin-button,
.orc-line-desc-val::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.orc-td-total {
    text-align: right;
    font-weight: 700;
    white-space: nowrap;
}

/* celula "Total" da linha quando ha desconto na linha */
.orc-ct {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    line-height: 1.25;
}

.orc-ct-final { font-weight: 700; }

.orc-ct-cheio {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin-top: .1rem;
}

.orc-ct-cheio s {
    color: var(--orc-ink-soft);
    font-weight: 500;
    font-size: .9em;
}

.orc-off-tag {
    color: var(--orc-indigo);
    font-weight: 700;
    font-size: .76em;
    white-space: nowrap;
}

.orc-td-tools {
    width: 1%;
    white-space: nowrap;
}

.orc-row-btn {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: var(--orc-ink);
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    /* Halo branco (visivel sobre fundo escuro) + sombra escura (visivel sobre
       fundo claro/colorido). Cobre qualquer cor de destaque ou de fundo da
       secao sem o botao virar uma "bolota" sem definicao. */
    box-shadow: 0 0 0 2px #fff, 0 4px 12px rgba(28, 24, 70, .3);
    opacity: 0;
    transition: opacity .12s ease, transform .12s ease, box-shadow .12s ease;
}

.orc-table tbody tr:hover .orc-row-btn,
.orc-row-btn.is-on { opacity: 1; }

.orc-row-btn:hover {
    transform: scale(1.07);
    box-shadow: 0 0 0 2px #fff, 0 6px 16px rgba(28, 24, 70, .38);
}

.orc-row-opt td {
    background: #fffaf0;
}

/* Escolher 1: apenas a linha escolhida pelo cliente recebe o tom da cor de destaque da secao */
.orc-row-escolha:not(.orc-row-excl) td {
    background: color-mix(in srgb, var(--orc-accent, #4f3ff0) 12%, #fff);
}

.orc-col-hidden { opacity: .45; }

/* ----- menu de opcoes da linha ----- */
.orc-line-menu {
    display: none;
    position: absolute;
    z-index: 50;
    min-width: 240px;
    background: #fff;
    border: 1px solid var(--orc-line);
    border-radius: .65rem;
    box-shadow: 0 12px 34px -8px rgba(28, 24, 70, .3);
    padding: .35rem;
}

.orc-line-menu.is-open { display: block; }

.orc-line-item {
    display: flex;
    align-items: center;
    gap: .55rem;
    width: 100%;
    border: none;
    background: transparent;
    text-align: left;
    padding: .55rem .6rem;
    border-radius: .4rem;
    cursor: pointer;
    font-size: .92rem;
    color: var(--orc-ink);
}

.orc-line-item:hover { background: var(--orc-bg-soft); }

.orc-line-item-del { color: #f1416c; }
.orc-line-item-del:hover { background: #ffeef2; }

.orc-line-sep {
    height: 1px;
    background: var(--orc-line);
    margin: .35rem .3rem;
}

.orc-line-toggle {
    display: flex;
    align-items: center;
    gap: .55rem;
    padding: .5rem .6rem;
    margin: 0;
    cursor: pointer;
    font-size: .92rem;
    color: var(--orc-ink);
}

.orc-line-toggle input {
    width: 16px;
    height: 16px;
    accent-color: var(--orc-ink);
    flex-shrink: 0;
    cursor: pointer;
}

.orc-line-rec {
    padding: .55rem .6rem;
}

.orc-line-rec-label {
    display: block;
    font-size: .92rem;
    color: var(--orc-ink);
    margin-bottom: .45rem;
}

.orc-line-rec-chips {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}

.orc-rec-chip {
    border: 1px solid var(--orc-line);
    background: #fff;
    color: var(--orc-ink-soft);
    font-size: .8rem;
    font-weight: 600;
    padding: .32rem .68rem;
    border-radius: 999px;
    cursor: pointer;
    transition: background-color .12s ease, border-color .12s ease, color .12s ease;
}

.orc-rec-chip:hover {
    border-color: var(--orc-ink-soft);
    color: var(--orc-ink);
}

.orc-rec-chip.is-on {
    background: var(--orc-ink);
    border-color: var(--orc-ink);
    color: #fff;
}

.orc-line-desc-val {
    width: 100%;
    margin-top: .5rem;
    border: 1px solid var(--orc-line);
    border-radius: .4rem;
    background: #fff;
    color: var(--orc-ink);
    font-size: .85rem;
    padding: .36rem .5rem;
}

.orc-line-desc-val:focus {
    outline: none;
    border-color: var(--orc-ink-soft);
}

/* ----- pills adicionar ----- */
.orc-add {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
    margin-top: 1rem;
}

.orc-pill {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    border: 1.5px solid #e3e3ee;
    background: #fff;
    color: var(--orc-ink);
    font-size: .9rem;
    font-weight: 600;
    padding: .55rem 1.1rem;
    border-radius: 999px;
    cursor: pointer;
    transition: border-color .12s ease, background-color .12s ease;
}

.orc-pill:hover {
    border-color: #c9c9d6;
    background: var(--orc-bg-soft);
}

/* ----- caixa Total ----- */
.orc-total {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    width: 100%;
    margin-top: 1.6rem;
    background: var(--orc-accent, #4f3ff0);
    border-radius: 1rem;
    padding: 1.7rem 2.2rem;
}

.orc-total-linha {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1.5rem;
    color: var(--orc-accent-text, #fff);
}

/* selo de desconto geral, no canto superior direito */
.orc-total-selo {
    position: absolute;
    top: -12px;
    right: 20px;
    background: #1a1a27;
    color: #fff;
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .02em;
    padding: .36rem .72rem;
    border-radius: .5rem;
    box-shadow: 0 8px 18px -6px rgba(20, 20, 50, .55);
}

/* linhas de grupo (Pagamento único, Mensal, ...) */
#orcTotGrupos {
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

#orcTotGrupos:empty { display: none; }

.orc-total-grupo {
    font-size: 1.05rem;
    font-weight: 600;
}

/* valor cheio riscado, antes do desconto geral */
.orc-total-cheio {
    font-weight: 600;
    opacity: .6;
    margin-right: .15rem;
}

.orc-total-divisor {
    height: 1px;
    background: var(--orc-accent-text, #fff);
    opacity: .22;
    margin: .35rem 0;
}

.orc-total-principal span:first-child {
    font-size: 1.15rem;
    font-weight: 700;
}

.orc-total-principal span:last-child {
    font-size: 1.6rem;
    font-weight: 700;
}

.orc-total-principal .orc-total-cheio {
    font-size: 1rem;
    font-weight: 600;
}

/* ----- controle do desconto geral (editor) ----- */
.orc-total-desc-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .55rem;
    margin-bottom: .35rem;
}

.orc-total-desc-label {
    font-size: .98rem;
    font-weight: 600;
    color: var(--orc-accent-text, #fff);
}

.orc-desc-chips {
    display: inline-flex;
    gap: .3rem;
}

.orc-desc-chip {
    border: 1px solid var(--orc-accent-text, #fff);
    background: transparent;
    color: var(--orc-accent-text, #fff);
    opacity: .78;
    font-size: .8rem;
    font-weight: 600;
    padding: .26rem .64rem;
    border-radius: 999px;
    cursor: pointer;
    transition: background-color .12s ease, opacity .12s ease, color .12s ease;
}

.orc-desc-chip:hover { opacity: 1; }

.orc-desc-chip.is-on {
    background: var(--orc-accent-text, #fff);
    color: var(--orc-accent, #4f3ff0);
    opacity: 1;
}

.orc-total-desc-val {
    width: 86px;
    border: 1px solid var(--orc-accent-text, #fff);
    border-radius: .4rem;
    background: transparent;
    color: var(--orc-accent-text, #fff);
    font-size: .85rem;
    font-weight: 600;
    padding: .26rem .5rem;
}

.orc-total-desc-val::placeholder {
    color: var(--orc-accent-text, #fff);
    opacity: .5;
}

/* ===================== EDITOR — frame ===================== */

.orc-bar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .5rem;
    margin-bottom: .75rem;
}

.orc-bar .form-select {
    width: auto;
}

.orc-cor-pick {
    display: inline-flex;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    overflow: hidden;
    border: 1px solid #dcdce6;
    padding: 0;
    margin: 0;
    cursor: pointer;
    flex-shrink: 0;
}

.orc-cor-pick input[type="color"] {
    width: 150%;
    height: 150%;
    margin: -25%;
    padding: 0;
    border: none;
    background: none;
    cursor: pointer;
}

.orc-bar-close {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 50%;
    background: var(--orc-bg-soft);
    color: var(--orc-ink-soft);
    cursor: pointer;
}

.orc-bar-close:hover { background: #e9e9f1; }

.orc-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1.75rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--orc-line);
}

.orc-foot-acoes {
    display: flex;
    gap: .5rem;
}

.orc-nome-galeria {
    margin-top: 1rem;
}

.orc-btn-apply {
    background: var(--orc-ink);
    color: #fff;
    border: none;
    border-radius: .55rem;
    font-weight: 600;
    font-size: .9rem;
    padding: .62rem 1.6rem;
    cursor: pointer;
    transition: background-color .12s ease;
}

.orc-btn-apply:hover { background: #3d3d52; }
.orc-btn-apply:disabled { opacity: .6; cursor: default; }

.orc-btn-cancel {
    background: var(--orc-bg-soft);
    color: var(--orc-ink-soft);
    border: none;
    border-radius: .55rem;
    font-weight: 600;
    font-size: .9rem;
    padding: .62rem 1.3rem;
    cursor: pointer;
    transition: background-color .12s ease;
}

.orc-btn-cancel:hover { background: #e9e9f1; }

/* ===================== VIEWER — interativo ===================== */

.orc-stepper {
    display: inline-flex;
    align-items: center;
    border: 1px solid #dcdce6;
    border-radius: .55rem;
    overflow: hidden;
}

.orc-step {
    width: 32px;
    height: 36px;
    border: none;
    background: var(--orc-bg-soft);
    color: var(--orc-ink-soft);
    font-size: 1.15rem;
    line-height: 1;
    cursor: pointer;
}

.orc-step:hover {
    background: var(--orc-indigo);
    color: #fff;
}

.orc-step-inp {
    width: 50px;
    height: 36px;
    border: none;
    border-left: 1px solid #dcdce6;
    border-right: 1px solid #dcdce6;
    text-align: center;
    font-size: 1.05rem;
    color: var(--orc-ink);
}

.orc-step-inp:focus { outline: none; }

.orc-opt {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    cursor: pointer;
    margin: 0;
}

.orc-opt-check {
    width: 20px;
    height: 20px;
    accent-color: var(--orc-accent, var(--orc-indigo));
    cursor: pointer;
    flex-shrink: 0;
}

.orc-row-excl { opacity: .45; }

.orc-row-excl .orc-td-total { text-decoration: line-through; }

/* Grupo "Escolher 1": as linhas nao escolhidas sao opcoes validas (nao exclusoes) -
   continuam legiveis, sem opacidade nem riscado; so a escolhida recebe destaque */
.orc-row-escolha.orc-row-excl { opacity: 1; }

.orc-row-escolha.orc-row-excl .orc-td-total { text-decoration: none; }

/* ===================== RESPONSIVO ===================== */

@media (max-width: 768px) {
    .orc-block-head { padding: 1.15rem 1.25rem; min-height: 0; }
    .orc-block-body { padding: .35rem 1rem 1rem; }
    .orc-block-title,
    .orc-block-title-input { font-size: 1.2rem; }
    .orc-view-logo img { max-height: 38px; max-width: 120px; }

    .orc-view .orc-table,
    .orc-view .orc-table tbody,
    .orc-view .orc-table tr,
    .orc-view .orc-table td {
        display: block;
        width: 100%;
    }

    .orc-view .orc-table thead { display: none; }

    .orc-view .orc-table tr {
        border: 1px solid var(--orc-line);
        border-radius: .65rem;
        padding: .25rem .25rem;
        margin-bottom: .85rem;
    }

    .orc-view .orc-table td {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        border-bottom: 1px solid var(--orc-bg-soft);
        text-align: right;
    }

    .orc-view .orc-table tr td:last-child { border-bottom: none; }

    .orc-view .orc-table td::before {
        content: attr(data-label);
        font-size: .72rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .04em;
        color: var(--orc-ink-soft);
        text-align: left;
    }

    .orc-total { width: 100%; min-width: 0; }
}

@media (max-width: 576px) {
    .orc-preset-grid { grid-template-columns: 1fr; }
}

/* ===================== PLANOS — editor ===================== */

.orc-planos { padding: .4rem 0 1.2rem; }

.orc-planos-titulo {
    width: 100%;
    border: none;
    background: transparent;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--orc-ink);
    padding: .4rem .2rem;
    margin-bottom: .5rem;
}

.orc-planos-titulo::placeholder { color: #c2c2cf; }
.orc-planos-titulo:focus { outline: none; }

/* ----- barra de períodos (editor) ----- */
.orc-per-bar {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.4rem;
}

.orc-per-tab {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--orc-line);
    border-radius: .6rem;
    background: var(--orc-bg-soft);
}

.orc-per-tab.is-on {
    background: #fff;
    border-color: var(--orc-ink-soft);
    box-shadow: 0 2px 8px -2px rgba(28, 24, 70, .18);
}

.orc-per-pick {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    border: none;
    background: transparent;
    color: var(--orc-ink);
    font-size: .95rem;
    font-weight: 600;
    padding: .5rem .3rem .5rem .85rem;
    cursor: pointer;
}

.orc-per-edit {
    border: none;
    background: transparent;
    color: var(--orc-ink-soft);
    cursor: pointer;
    padding: .5rem .65rem .5rem .35rem;
    display: inline-flex;
    align-items: center;
}

.orc-per-edit:hover { color: var(--orc-ink); }

.orc-per-selo {
    background: var(--orc-accent, var(--orc-indigo));
    color: var(--orc-accent-text, #fff);
    font-size: .68rem;
    font-weight: 700;
    padding: .14rem .42rem;
    border-radius: .35rem;
    white-space: nowrap;
}

.orc-per-add {
    width: 38px;
    height: 38px;
    border: 1px dashed #c8c8d4;
    border-radius: .6rem;
    background: #fff;
    color: var(--orc-ink-soft);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.orc-per-add:hover { border-color: var(--orc-ink-soft); color: var(--orc-ink); }

/* ----- grade de cards (editor) ----- */
.orc-planos-grade {
    display: flex;
    gap: 1.1rem;
    align-items: stretch;
    flex-wrap: wrap;
}

.orc-card {
    flex: 1 1 220px;
    min-width: 220px;
    background: #fff;
    border: 1.5px solid var(--orc-line);
    border-radius: 1rem;
    padding: 1.1rem 1.1rem 1.3rem;
    display: flex;
    flex-direction: column;
}

.orc-card.is-destaque { border-color: var(--orc-accent, var(--orc-indigo)); }

.orc-card.orc-card-over {
    border-color: var(--orc-ink);
    box-shadow: 0 0 0 3px var(--orc-line);
}

.orc-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .5rem;
}

.orc-card-top-l,
.orc-card-top-r {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
}

.orc-card-grip {
    cursor: grab;
    color: #c8c8d4;
    font-size: 1rem;
    line-height: 1;
    padding: .15rem;
    user-select: none;
}

.orc-card-grip:active { cursor: grabbing; }

.orc-card-dup {
    border: none;
    background: transparent;
    color: #c2c2cf;
    cursor: pointer;
    padding: .2rem;
    display: inline-flex;
}

.orc-card-dup:hover { color: var(--orc-ink); }

.orc-card-star {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    border: 1px solid var(--orc-line);
    background: #fff;
    color: var(--orc-ink-soft);
    font-size: .72rem;
    font-weight: 700;
    padding: .26rem .55rem;
    border-radius: 999px;
    cursor: pointer;
}

.orc-card-star.is-on {
    background: var(--orc-accent, var(--orc-indigo));
    border-color: var(--orc-accent, var(--orc-indigo));
    color: var(--orc-accent-text, #fff);
}

.orc-card-del {
    border: none;
    background: transparent;
    color: #c2c2cf;
    cursor: pointer;
    padding: .2rem;
}

.orc-card-del:hover { color: #f1416c; }

.orc-card-nome,
.orc-card-desc {
    width: 100%;
    border: 1px solid transparent;
    border-radius: .4rem;
    padding: .35rem .4rem;
    background: transparent;
    color: var(--orc-ink);
}

.orc-card-nome { font-size: 1.05rem; font-weight: 700; }
.orc-card-desc { font-size: .82rem; color: var(--orc-ink-soft); margin-top: .1rem; }
.orc-card-nome:hover,
.orc-card-desc:hover { border-color: var(--orc-line); }
.orc-card-nome:focus,
.orc-card-desc:focus { outline: none; border-color: var(--orc-ink-soft); background: #fff; }
.orc-card-nome::placeholder,
.orc-card-desc::placeholder { color: #c2c2cf; }

.orc-card-preco {
    display: flex;
    align-items: baseline;
    gap: .25rem;
    margin: .7rem .4rem .35rem;
}

.orc-card-cifrao { font-size: 1rem; font-weight: 700; color: var(--orc-ink); }

.orc-card-preco-inp {
    width: 96px;
    border: 1px solid var(--orc-line);
    border-radius: .4rem;
    padding: .3rem .45rem;
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--orc-ink);
    background: #fff;
}

.orc-card-preco-inp:focus { outline: none; border-color: var(--orc-ink-soft); }
.orc-card-sfx { font-size: .82rem; font-weight: 600; color: var(--orc-ink-soft); }

.orc-card-descrow {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .4rem;
    margin: .2rem .4rem 0;
}

.orc-card-descrow-lbl {
    font-size: .78rem;
    font-weight: 600;
    color: var(--orc-ink-soft);
    width: 100%;
}

.orc-card-desc-val { width: 78px; margin-top: 0; }

.orc-card-preview {
    margin: .3rem .4rem .1rem;
    font-size: .8rem;
    color: var(--orc-ink-soft);
}

.orc-card-preview b { color: var(--orc-accent, var(--orc-indigo)); font-weight: 700; }

.orc-card-toggle {
    display: flex;
    align-items: center;
    gap: .45rem;
    margin: .5rem .4rem .2rem;
    cursor: pointer;
    font-size: .8rem;
    color: var(--orc-ink-soft);
}

.orc-card-toggle input { width: 15px; height: 15px; accent-color: var(--orc-ink); cursor: pointer; }

.orc-card-sob {
    margin: .7rem .4rem .4rem;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--orc-ink);
}

.orc-card-cta-inp {
    width: 100%;
    border: 1px solid var(--orc-line);
    border-radius: .4rem;
    background: #fff;
    color: var(--orc-ink);
    font-size: .85rem;
    padding: .4rem .5rem;
}

.orc-card-cta-inp:focus { outline: none; border-color: var(--orc-ink-soft); }
.orc-card-cta-inp::placeholder { color: #c2c2cf; }

.orc-card-v-sob { font-size: 1.5rem; font-weight: 800; color: var(--orc-ink); }
.orc-card-v.is-filled .orc-card-v-sob { color: var(--orc-accent-text, #fff); }

.orc-card-v-obs {
    font-size: .82rem;
    color: var(--orc-ink-soft);
    margin-top: .4rem;
    line-height: 1.4;
}

.orc-card-v.is-filled .orc-card-v-obs { color: var(--orc-accent-text, #fff); opacity: .72; }

.orc-card-sep { height: 1px; background: var(--orc-line); margin: .8rem 0; }

.orc-card-itens { display: flex; flex-direction: column; gap: .35rem; }

.orc-card-item { display: flex; align-items: center; gap: .4rem; }

.orc-card-item-ic { color: var(--orc-accent, var(--orc-indigo)); flex-shrink: 0; }

.orc-card-item-inp {
    flex: 1;
    border: 1px solid transparent;
    border-radius: .35rem;
    padding: .3rem .4rem;
    font-size: .85rem;
    color: var(--orc-ink);
    background: transparent;
}

.orc-card-item-inp:hover { border-color: var(--orc-line); }
.orc-card-item-inp:focus { outline: none; border-color: var(--orc-ink-soft); background: #fff; }
.orc-card-item-inp::placeholder { color: #c2c2cf; }

.orc-card-item-del {
    border: none;
    background: transparent;
    color: #c8c8d4;
    cursor: pointer;
    padding: .15rem;
    flex-shrink: 0;
}

.orc-card-item-del:hover { color: #f1416c; }

.orc-card-add-item {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    border: none;
    background: transparent;
    color: var(--orc-ink);
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
    padding: .5rem .4rem 0;
    margin-top: .25rem;
}

.orc-card-add {
    flex: 0 0 132px;
    min-width: 132px;
    border: 1.5px dashed #c8c8d4;
    border-radius: 1rem;
    background: transparent;
    color: var(--orc-ink-soft);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    font-size: .85rem;
    font-weight: 600;
}

.orc-card-add:hover { border-color: var(--orc-ink-soft); color: var(--orc-ink); }

/* ===================== PLANOS — viewer ===================== */

.orc-view-planos { padding: .5rem 0; }

/* Sem titulo, o switcher / grade vira o primeiro filho e cola no que esta
   acima — compensa o respiro que o titulo daria. */
.orc-view-planos > .orc-per-switch:first-child,
.orc-view-planos > .orc-locked-periodo:first-child,
.orc-view-planos > .orc-planos-grade-view:first-child {
    margin-top: 2rem;
}

.orc-planos-titulo-view {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--orc-ink);
    text-align: center;
    margin-bottom: 1.5rem;
}

.orc-per-switch {
    display: flex;
    width: fit-content;
    gap: .25rem;
    background: var(--orc-bg-soft);
    border: 1px solid var(--orc-line);
    border-radius: 999px;
    padding: .28rem;
    margin: 0 auto 1.7rem;
}

.orc-per-sw {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    border: none;
    background: transparent;
    color: var(--orc-ink-soft);
    font-size: .9rem;
    font-weight: 600;
    padding: .5rem 1.1rem;
    border-radius: 999px;
    cursor: pointer;
}

.orc-per-sw.is-on {
    background: #fff;
    color: var(--orc-ink);
    box-shadow: 0 2px 6px -1px rgba(20, 20, 50, .15);
}

.orc-planos-grade-view {
    display: flex;
    gap: 1.4rem;
    align-items: stretch;
    flex-wrap: wrap;
    justify-content: center;
}

.orc-card-v {
    position: relative;
    flex: 1 1 240px;
    max-width: 340px;
    background: #fff;
    border: 1.5px solid var(--orc-line);
    border-radius: 1.1rem;
    padding: 2rem 1.6rem;
    display: flex;
    flex-direction: column;
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
}

.orc-card-v:hover {
    transform: translateY(-5px);
    border-color: var(--orc-accent, var(--orc-indigo));
    box-shadow: 0 22px 46px -18px color-mix(in srgb, var(--orc-accent, #4f3ff0) 55%, transparent);
}

.orc-card-v.is-destaque { border-color: var(--orc-accent, var(--orc-indigo)); }

/* card "preenchido": o recomendado por padrao, ou o que o cliente selecionar */
.orc-card-v.is-filled {
    background: var(--orc-accent, var(--orc-indigo));
    border-color: var(--orc-accent, var(--orc-indigo));
    box-shadow: 0 18px 42px -16px color-mix(in srgb, var(--orc-accent, #4f3ff0) 50%, transparent);
    transform: scale(1.045);
    z-index: 1;
}

.orc-card-v.is-filled:hover {
    transform: scale(1.06);
    box-shadow: 0 24px 52px -18px color-mix(in srgb, var(--orc-accent, #4f3ff0) 62%, transparent);
}

.orc-card-v.is-filled.is-selected {
    box-shadow: 0 26px 58px -18px color-mix(in srgb, var(--orc-accent, #4f3ff0) 68%, transparent);
}

.orc-card-v.is-filled .orc-card-v-nome,
.orc-card-v.is-filled .orc-card-v-final b { color: var(--orc-accent-text, #fff); }

.orc-card-v.is-filled .orc-card-v-desc,
.orc-card-v.is-filled .orc-card-v-sfx { color: var(--orc-accent-text, #fff); opacity: .72; }

.orc-card-v.is-filled .orc-card-v-cheio { color: var(--orc-accent-text, #fff); opacity: .55; }

.orc-card-v.is-filled .orc-card-v-itens li,
.orc-card-v.is-filled .orc-card-v-itens li i { color: var(--orc-accent-text, #fff); }

.orc-card-v.is-filled .orc-card-v-sep { background: var(--orc-accent-text, #fff); opacity: .22; }

.orc-card-v.is-filled .orc-card-v-btn {
    background: var(--orc-accent-text, #fff);
    border-color: var(--orc-accent-text, #fff);
    color: var(--orc-accent, var(--orc-indigo));
}

.orc-card-v.is-filled .orc-card-v-btn:hover {
    background: var(--orc-accent-text, #fff);
    opacity: .9;
}

.orc-card-v.is-filled .orc-card-badge,
.orc-card-v.is-filled .orc-card-vcheck {
    background: var(--orc-accent-text, #fff);
    color: var(--orc-accent, var(--orc-indigo));
}

.orc-card-badge {
    position: absolute;
    top: -13px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--orc-accent, var(--orc-indigo));
    color: var(--orc-accent-text, #fff);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    padding: .36rem .9rem;
    border-radius: 999px;
    white-space: nowrap;
}

.orc-card-vcheck {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--orc-accent, var(--orc-indigo));
    color: var(--orc-accent-text, #fff);
    display: flex;
    align-items: center;
    justify-content: center;
}

.orc-card-v-nome { font-size: 1.2rem; font-weight: 700; color: var(--orc-ink); }
.orc-card-v-desc { font-size: .85rem; color: var(--orc-ink-soft); margin-top: .25rem; }

.orc-card-v-preco {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: .5rem;
    margin: 1.1rem 0 .2rem;
}

.orc-card-v-cheio { color: var(--orc-ink-soft); font-size: 1rem; font-weight: 600; }
.orc-card-v-final { display: inline-flex; align-items: baseline; gap: .3rem; }
.orc-card-v-final b { font-size: 2.2rem; font-weight: 800; color: var(--orc-ink); letter-spacing: -.02em; }
.orc-card-v-sfx { font-size: .9rem; font-weight: 600; color: var(--orc-ink-soft); }

.orc-card-v-sep { height: 1px; background: var(--orc-line); margin: 1.2rem 0; }

.orc-card-v-itens {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .7rem;
}

.orc-card-v-itens li {
    display: flex;
    gap: .55rem;
    font-size: .9rem;
    color: var(--orc-ink);
    line-height: 1.4;
}

.orc-card-v-itens li i { color: var(--orc-accent, var(--orc-indigo)); flex-shrink: 0; margin-top: .1rem; }

.orc-card-v-btn {
    margin-top: auto;
    border: 1.5px solid var(--orc-accent, var(--orc-indigo));
    background: #fff;
    color: var(--orc-accent, var(--orc-indigo));
    font-family: inherit;
    font-size: .92rem;
    font-weight: 700;
    padding: .85rem;
    border-radius: .7rem;
    cursor: pointer;
    transition: background-color .12s ease, color .12s ease;
}

.orc-card-v-btn:hover { background: var(--orc-bg-soft); }

.orc-card-v-btn.is-on {
    background: var(--orc-accent, var(--orc-indigo));
    color: var(--orc-accent-text, #fff);
}

/* "Total no <periodo>: R$ X" — linha pequena/sutil abaixo do bloco de preco
   nos cards de plano Anual/Trimestral/Semestral. Mensal e Unico nao mostram.
   .orc-card-totalper = editor (com data-card-totalper pra update reativa).
   .orc-card-v-totalper = viewer publico e viewer travado. */
.orc-card-totalper,
.orc-card-v-totalper {
    display: block;
    font-size: .78rem;
    font-weight: 500;
    color: var(--orc-ink-soft);
    text-align: center;
    margin: -.25rem .4rem .35rem;
}

/* No card "filled" (recomendado / selecionado, fundo accent), o cinza some;
   usamos o accent-text com opacidade pra ficar legivel sem competir. */
.orc-card-v.is-filled .orc-card-v-totalper {
    color: var(--orc-accent-text, #fff);
    opacity: .8;
}

/* ===================== VIEWER TRAVADO (proposta aprovada) ===================== */

/* Badge "Aprovado" no cabecalho da tabela travada: pill branca em cima do accent. */
.orc-locked-badge {
    display: inline-flex;
    align-items: center;
    background: var(--orc-accent-text, #fff);
    color: var(--orc-accent, #4f3ff0);
    font-size: .68rem;
    font-weight: 800;
    padding: .28rem .6rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-left: auto;
    margin-right: .75rem;
    white-space: nowrap;
}

/* Lista de itens que ficaram fora do aceite (opcionais nao marcadas / escolhas
   nao selecionadas) — pequena nota abaixo da tabela. */
.orc-locked-excluidos {
    margin-top: 1rem;
    padding: 1rem 1.25rem 0;
    border-top: 1px dashed var(--orc-line);
}

.orc-locked-excluidos-title {
    font-size: .7rem;
    font-weight: 700;
    color: var(--orc-ink-soft);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: .4rem;
}

.orc-locked-excluidos-list {
    color: var(--orc-ink-soft);
    font-size: .85rem;
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.orc-locked-excluidos-list li {
    text-decoration: line-through;
    padding: .15rem 0;
}

/* Modo Planos travado: rotulo do periodo e centralizacao do unico card. */
.orc-locked-periodo {
    text-align: center;
    color: var(--orc-ink-soft);
    font-size: .9rem;
    margin-bottom: 1rem;
}

.orc-planos-locked {
    justify-content: center;
}

.orc-planos-locked .orc-card-v {
    max-width: 360px;
}

/* Botao "Plano contratado" desabilitado mantem o look filled — pequeno ajuste
   pra remover o cursor not-allowed default do disabled e dar a sensacao de
   "este e o plano que voce contratou". */
.orc-card-v-btn[disabled] {
    cursor: default;
    opacity: 1;
}
