/* === VENDA DE PLANOS === */
/* ── VENDA DE PLANOS ── */
.venda-step-bar{display:flex;align-items:center;gap:0;margin-bottom:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.venda-step{flex:1;padding:12px 16px;text-align:center;font-size:12px;color:var(--txt3);border-right:1px solid var(--border);cursor:default;position:relative}
.venda-step:last-child{border-right:none}
.venda-step.done{color:var(--teal);background:var(--teal-l)}
.venda-step.active{color:var(--primary);font-weight:500;background:var(--primary-l)}
.venda-step .step-num{display:inline-flex;width:20px;height:20px;border-radius:50%;background:var(--border);color:var(--txt3);font-size:10px;font-weight:600;align-items:center;justify-content:center;margin-right:6px}
.venda-step.active .step-num{background:var(--primary);color:#fff}
.venda-step.done .step-num{background:var(--teal);color:#fff}
.vp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:14px}
.vp-head{padding:12px 16px;background:var(--bg);border-bottom:1px solid var(--border);font-size:12px;font-weight:500;color:var(--txt);display:flex;align-items:center;gap:8px}
.vp-head i{color:var(--primary);font-size:15px}
.vp-body{padding:16px}
.venda-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:16px}
.vt{padding:9px 16px;font-size:12px;cursor:pointer;color:var(--txt2);border-bottom:2px solid transparent;white-space:nowrap}
.vt:hover{color:var(--primary)}
.vt.on{color:var(--primary);border-bottom-color:var(--primary);font-weight:500}
.servico-table{width:100%;border-collapse:collapse;font-size:12px}
.servico-table th{padding:8px 10px;text-align:left;font-size:10px;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:.05em;background:var(--bg);border-bottom:1px solid var(--border)}
.servico-table td{padding:9px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.servico-table tr:last-child td{border-bottom:none}
.servico-table tr:hover td{background:var(--bg)}
.num-input{width:60px;border:1px solid var(--border2);border-radius:var(--radius-sm);padding:4px 6px;font-size:12px;text-align:center;font-family:inherit;color:var(--txt)}
.num-input:focus{outline:none;border-color:var(--primary)}
.resumo-total{background:var(--primary-l);border:1px solid var(--primary);border-radius:var(--radius);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.rt-label{font-size:13px;color:var(--primary-d,#5A1F54);font-weight:500}
.rt-value{font-size:22px;font-weight:700;color:var(--primary)}
.pagto-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.pagto-opt{border:1px solid var(--border2);border-radius:var(--radius);padding:14px;text-align:center;cursor:pointer;transition:all .15s}
.pagto-opt:hover{border-color:var(--primary);background:var(--primary-l)}
.pagto-opt.on{border-color:var(--primary);background:var(--primary-l);border-width:2px}
.pagto-opt i{font-size:24px;color:var(--primary);display:block;margin-bottom:6px}
.pagto-opt span{font-size:11px;font-weight:500;color:var(--txt2)}
.pagto-opt.on span{color:var(--primary)}
.parcelas-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px}
.vendas-table .dt-head{grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1fr 140px}
.vendas-table .dt-row{grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1fr 140px}
.status-nova{background:var(--blue-l);color:var(--blue-d,#0C447C)}
.status-aprovada{background:var(--teal-l);color:var(--teal-d,#085041)}
.status-cancelada{background:#FCEBEB;color:#A32D2D}
.status-pendente{background:var(--amber-l);color:var(--amber-d,#633806)}
.itens-resumo{font-size:11px;color:var(--txt2);margin-top:2px}
.pagto-detalhe{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:12px}
.pagto-detalhe-title{font-size:11px;font-weight:500;color:var(--txt2);margin-bottom:8px}
.fin-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}
.lote-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;font-size:12px}
.lote-item:last-child{margin-bottom:0}
.venda-detail-modal .modal{width:700px;max-height:92vh}
.retorno-section{margin-top:20px}
.retorno-section h3{font-weight:700;font-size:15px;color:var(--txt);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.retorno-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.rc-head{display:grid;padding:9px 14px;font-size:10px;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:.06em;background:var(--bg);border-bottom:1px solid var(--border)}
.rc-row{display:grid;padding:10px 14px;border-bottom:1px solid var(--border);align-items:center;font-size:12px;transition:background .1s}
.rc-row:last-child{border-bottom:none}
.rc-row:hover{background:var(--bg)}
/* ── Tarefas de retorno: vira CARD no celular/tablet (≤820px) ── */
@media(max-width:820px){
  .rc-head{display:none}
  .rc-row{
    display:flex;flex-direction:column;align-items:stretch;gap:7px;
    grid-template-columns:1fr !important;     /* anula o inline grid */
    padding:13px 15px;
  }
  .rc-row .rc-cliente{font-size:14px;font-weight:600}
  /* Cada célula vira "Rótulo: valor" alinhado nas pontas */
  .rc-row > span[data-th]{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    font-size:12px !important;
  }
  .rc-row > span[data-th]::before{
    content:attr(data-th);
    font-size:10px;font-weight:600;color:var(--txt3);
    text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;
  }
  .rc-row > span[data-th].spill{align-self:flex-start;width:auto;justify-content:flex-start}
  .rc-row > span[data-th].spill::before{display:none}   /* não põe rótulo dentro da pílula */
  .rc-row .rc-acoes{
    justify-content:flex-end;border-top:1px solid var(--border);
    padding-top:9px;margin-top:2px;
  }
  .rc-row .rc-acoes .btn-sm{flex:0 0 auto}
}
.urgente{border-left:3px solid #E24B4A}
.proximo{border-left:3px solid #BA7517}
.ok{border-left:3px solid #1D9E75}
.retorno-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.r-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;text-align:center}
.r-stat-val{font-size:20px;font-weight:700}
.r-stat-lbl{font-size:10px;color:var(--txt3);margin-top:2px}
.btn-sm{border:none;border-radius:var(--radius-sm);padding:4px 10px;font-size:11px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.btn-sm-green{background:var(--teal-l);color:var(--teal-d,#085041)}
.btn-sm-green:hover{background:#b3e6d4}
.btn-sm-red{background:#FCEBEB;color:#A32D2D}
.btn-sm-red:hover{background:#f7c1c1}
.btn-sm-purple{background:var(--primary-l);color:var(--primary-d,#5A1F54)}
.btn-sm-purple:hover{background:#e5d0e3}
.retorno-highlight{background:linear-gradient(135deg,var(--primary-l) 0%,#fff 100%);border:1px solid var(--primary);border-radius:var(--radius);padding:14px 16px;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.rh-icon{font-size:24px;color:var(--primary)}
.rh-text{flex:1}
.rh-count{font-size:22px;font-weight:700;color:var(--primary)}
.rh-label{font-size:11px;color:var(--txt2)}


/* ═══════════════════════════════════════
   MODAL NOVA VENDA V2 — STYLES
   ═══════════════════════════════════════ */

/* Stepper */
.nv2-step{flex:1;display:flex;flex-direction:column;gap:4px}
.nv2-step-bar{height:3px;border-radius:2px;background:#E8E0EF}
.nv2-step.on .nv2-step-bar,.nv2-step.done .nv2-step-bar{background:var(--primary)}
.nv2-step-lbl{font-size:10px;color:#A89DB5;font-weight:500;text-transform:uppercase;letter-spacing:.04em}
.nv2-step.on .nv2-step-lbl,.nv2-step.done .nv2-step-lbl{color:var(--primary)}

/* Lista de serviços (passo 1) */
.nv2-serv-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;background:#fff}
.nv2-serv-item:hover{background:var(--primary-l)}
.nv2-serv-item.on{background:var(--primary-l)}
.nv2-serv-item:last-child{border-bottom:none}
.nv2-serv-check{width:18px;height:18px;border-radius:4px;border:2px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff}
.nv2-serv-item.on .nv2-serv-check{background:var(--primary);border-color:var(--primary);color:#fff}
.nv2-serv-item.on .nv2-serv-check::after{content:"\2713";font-size:11px;line-height:1;font-weight:700}
.nv2-serv-icon{width:28px;height:28px;border-radius:6px;background:var(--primary-l);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.nv2-serv-item.on .nv2-serv-icon{background:var(--primary);color:#fff}
.nv2-serv-info{flex:1;min-width:0}
.nv2-serv-nome{font-size:12.5px;font-weight:500;color:var(--txt)}
.nv2-serv-meta{font-size:10px;color:var(--txt3);margin-top:1px}
.nv2-serv-valor{font-size:12px;font-weight:500;color:var(--primary);white-space:nowrap}

/* Resultados da busca de cliente */
.nv2-cli-resultado{padding:9px 12px;border-bottom:1px solid var(--border);cursor:pointer;display:flex;align-items:center;gap:9px;transition:background .1s}
.nv2-cli-resultado:hover{background:var(--primary-l)}
.nv2-cli-resultado:last-child{border-bottom:none}
.nv2-cli-resultado-av{width:26px;height:26px;border-radius:50%;background:var(--primary-l);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:9.5px;font-weight:500;flex-shrink:0}
.nv2-cli-resultado-info{flex:1;min-width:0}
.nv2-cli-resultado-nome{font-size:12.5px;font-weight:500;color:var(--txt)}
.nv2-cli-resultado-meta{font-size:10px;color:var(--txt3)}

/* Cards de item configurando áreas (passo 2) */
.nv2-item-card{background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:12px}
.nv2-item-card-head{padding:11px 14px;background:var(--primary-l);display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.nv2-item-card.sem-areas .nv2-item-card-head{background:var(--teal-l)}
.nv2-item-card-icon{width:30px;height:30px;border-radius:6px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.nv2-item-card.sem-areas .nv2-item-card-icon{background:var(--teal)}
.nv2-item-card-nome{flex:1;font-size:13px;font-weight:500;color:var(--primary-d)}
.nv2-item-card.sem-areas .nv2-item-card-nome{color:#04342C}
.nv2-item-card-valor{font-size:11px;color:var(--primary);font-weight:500}
.nv2-item-card.sem-areas .nv2-item-card-valor{color:var(--teal)}
.nv2-item-card-body{padding:12px 14px}

/* Lista de áreas com input de sessões */
.nv2-area-line{display:flex;align-items:center;gap:10px;padding:7px 0}
.nv2-area-line+.nv2-area-line{border-top:1px dashed var(--border)}
.nv2-area-chip-line{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border-radius:18px;border:1.5px solid var(--border2);background:#fff;font-size:11.5px;color:var(--txt2);cursor:pointer;font-weight:500}
.nv2-area-chip-line.on{background:var(--primary-l);border-color:var(--primary);color:var(--primary-d)}
.nv2-area-chip-line.on::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--primary);display:inline-block}
.nv2-area-line .nv2-area-nome-only{flex:1;font-size:12px;font-weight:500;color:var(--txt)}
.nv2-num-input{display:flex;align-items:center;border:1px solid var(--border2);border-radius:6px;background:#fff;overflow:hidden}
.nv2-num-btn{width:26px;height:26px;background:transparent;border:none;color:var(--primary);font-size:14px;cursor:pointer;font-weight:500}
.nv2-num-btn:hover:not(:disabled){background:var(--primary-l)}
.nv2-num-btn:disabled{opacity:.3;cursor:not-allowed}
.nv2-num-val{width:42px;text-align:center;font-size:12px;font-weight:500;color:var(--txt);border:none;font-family:inherit;background:transparent;padding:0}
.nv2-num-val:focus{outline:none}
.nv2-area-subtotal{font-size:11px;font-weight:500;color:var(--primary);white-space:nowrap;min-width:90px;text-align:right}

/* Formas de pagamento (pills) */
.nv2-forma-pill{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border:2px solid var(--border2);border-radius:8px;cursor:pointer;transition:all .15s;background:#fff}
.nv2-forma-pill:hover{border-color:var(--primary)}
.nv2-forma-pill.on{border-color:var(--primary);background:var(--primary-l)}
.nv2-forma-pill i{font-size:18px;color:var(--txt2)}
.nv2-forma-pill.on i{color:var(--primary)}
.nv2-forma-pill span{font-size:11px;font-weight:500;color:var(--txt2)}
.nv2-forma-pill.on span{color:var(--primary)}

/* Linha de parcela */
.nv2-parcela-line{display:grid;grid-template-columns:60px 1fr 120px;gap:8px;padding:7px 12px;border-bottom:1px solid var(--border);align-items:center;font-size:11.5px}
.nv2-parcela-line:last-child{border-bottom:none}
.nv2-parcela-num{color:var(--txt2);font-weight:500}
.nv2-parcela-data{color:var(--txt2)}
.nv2-parcela-valor{text-align:right;font-weight:500;color:var(--primary)}


/* Status "Orçamento" na lista de Vendas — cor de proposta (lilás/dourado suave) */
.tag.status-orcamento{background:#EEEDFE;color:#534AB7}

/* ── Lista de Vendas no celular/tablet: CARDS premium empilhados ── */
@media(max-width:820px){
  .vendas-table .dt-head{display:none}                /* esconde cabeçalho da tabela */
  .vendas-table #vendas-list{display:flex;flex-direction:column;gap:12px}
  .vendas-table .dt-row{
    display:flex!important;flex-direction:column;align-items:stretch;gap:0;
    border:1px solid var(--border);border-left:4px solid var(--primary);
    border-radius:14px;background:var(--surface);
    box-shadow:0 4px 16px -10px rgba(122,45,114,.25);
    padding:14px 16px;transition:transform .15s ease,box-shadow .15s ease;
  }
  .vendas-table .dt-row:active{transform:scale(.99)}
  /* Cliente = título do card */
  .vendas-table .dt-row .vd-cliente{
    font-size:15px!important;font-weight:700;color:var(--txt);
    border-bottom:1px solid var(--border);padding-bottom:9px;margin-bottom:9px;
    display:flex;flex-wrap:wrap;align-items:center;gap:6px;
  }
  .vendas-table .dt-row .vd-cliente .itens-resumo{flex-basis:100%;font-size:10.5px;color:var(--txt3);font-weight:400;margin-top:2px}
  /* Rótulo (coluna fixa) + valor ao lado, com separador suave entre as linhas */
  .vendas-table .dt-row > span[data-th]{
    display:flex;flex-wrap:wrap;align-items:baseline;gap:3px 8px;
    width:100%;font-size:13px!important;text-align:left;color:var(--txt);font-weight:600;
    padding:7px 0;border-top:1px dashed var(--border);
  }
  .vendas-table .dt-row > span[data-th]::before{
    content:attr(data-th);color:var(--txt3);font-weight:600;font-size:9.5px;
    text-transform:uppercase;letter-spacing:.04em;flex:0 0 78px;align-self:center;
  }
  .vendas-table .dt-row > span[data-th] > div{margin-left:86px;text-align:left;font-weight:500}
  /* TOTAL em destaque */
  .vendas-table .dt-row > span[data-th="Total"]{font-size:18px!important;font-weight:800;color:var(--primary)}
  .vendas-table .dt-row > span[data-th="Total"]::before{align-self:center}
  /* Barra de ações: toolbar arredondada com leve fundo */
  .vendas-table .dt-row .dt-actions{
    display:flex!important;flex-wrap:wrap;gap:6px;justify-content:flex-start;
    margin-top:11px;padding:8px;background:var(--bg,#FAF7FB);border-radius:12px;
  }
  .vendas-table .dt-row .dt-actions .ic-btn{
    width:38px;height:38px;font-size:17px;background:var(--surface);
    border:1px solid var(--border);border-radius:10px;
  }
  .vendas-table .dt-row .dt-actions .ic-btn:active{background:var(--primary-l)}
}
