/* ==========================================================================
   components.css — Componentes reutilizáveis
   ========================================================================== */

/* =========================
   CARDS / FEATURES
========================= */
.feature{
  flex: 1;
  padding: 20px;
  border-radius: var(--radius-10);
  text-align: center;
  transition: transform .25s ease, box-shadow .25s ease;
}

.feature img{
  width: 100px;
  height: 100px;
  object-fit: cover;
  border-radius: 50%;
  margin-bottom: 20px;
}

.feature h3{
  font-size: 18px;
  color: var(--cor-preto);
  margin-bottom: 10px;
  font-weight: 700;
}

.feature p{
  font-size: 14px;
  color: var(--cor-cinza-texto);
}

.feature:hover{
  transform: scale(1.05);
  box-shadow: var(--shadow-2);
}

/* =========================
   BOTÕES (ÚNICO PADRÃO — remove conflito)
   - Mantém seu visual original da landing
========================= */
.btn,
.btn-primary,
.btn-secondary{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 18px;            /* ✅ padrão da landing */
  border-radius: 14px;
  font-weight: 900;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  transition: var(--transition);
  user-select: none;
}

.btn-primary{
  background: var(--cor-primaria);
  color: var(--cor-branco);
}
.btn-primary:hover{ filter: brightness(1.06); }

.btn-secondary{
  background: transparent;
  color: var(--cor-primaria);
  border-color: rgba(12,63,140,.35);
}
.btn-secondary:hover{ background: rgba(12,63,140,.08); }

/* CTA full */
.buy-button{
  width: 100%;
  margin: 10px 0 0;
  padding: 14px 16px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 900;
  border: none;
  cursor: pointer;
  background: var(--cor-primaria);
  color: var(--cor-branco);
  transition: var(--transition);
}
.buy-button:hover{ background: var(--cor-botao-hover); }

/* =========================
   PULSE
========================= */
.pulse{ animation: pulsar 1.5s infinite; }
@keyframes pulsar{
  0%{ transform: scale(1); }
  50%{ transform: scale(1.06); }
  100%{ transform: scale(1); }
}

/* =========================
   GARANTIA
========================= */
.garantia{
  width: 100%;
  background: var(--cor-atencao);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px 0;
}

.garantia-conteudo{
  display: flex;
  flex-direction: row;
  align-items: center;
  max-width: var(--container);
  padding: 20px;
}

.img-garantia img{
  max-width: 400px;
  margin-right: 40px;
  transition: transform .25s ease;
}
.img-garantia img:hover{ transform: scale(1.06); }

.texto-negrito{
  font-size: 2.2rem;
  font-weight: 900;
  color: var(--cor-branco);
  margin: 0 0 10px 0;
}

.texto-regular{
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--cor-branco);
  margin: 0;
}

/* =========================
   PACOTES
========================= */
.choose-package-section{
  text-align: center;
  margin: 50px 0;
}

.package-options{
  display: flex;
  justify-content: center;
  gap: 22px;
  flex-wrap: wrap;
  padding: 10px 0 0;
}

.package-column{
  background: var(--cor-branco);
  border-radius: var(--radius-16);
  box-shadow: var(--shadow-1);
  padding: 18px;
  width: 310px;
  text-align: center;
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
  border: 1px solid rgba(12,63,140,.12);
}

.package-column:hover{
  transform: translateY(-6px);
  box-shadow: var(--shadow-2);
}

.package-column.highlight{
  border: 2px solid var(--cor-secundaria);
  transform: translateY(-6px);
}

.package-badge{
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--cor-secundaria);
  color: var(--cor-preto);
  font-weight: 900;
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
}

.package-title{
  font-size: 18px;
  font-weight: 900;
  color: var(--cor-primaria);
  margin: 10px 0 12px;
}

.package-list{
  list-style: none;
  padding: 0;
  margin: 0 0 14px;
  text-align: left;
  display: grid;
  gap: 10px;
}

.package-list li{
  position: relative;
  padding-left: 26px;
  font-size: 13.5px;
  line-height: 1.25;
  color: var(--cor-preto);
}

.package-list li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  font-weight: 900;
  color: var(--cor-primaria);
}

.package-list .is-off{
  color: var(--cor-cinza-texto);
  text-decoration: line-through;
  opacity: .80;
}
.package-list .is-off::before{ content: "–"; color: #9ca3af; }

.package-prices{ margin: 10px 0 14px; }
.price-original{ display:block; font-size: 13px; color: var(--cor-cinza-texto); text-decoration: line-through; margin-bottom: 6px; }
.price-discount{ font-size: 26px; font-weight: 900; margin: 0 0 6px; color: var(--cor-preto); }
.price-discount span{ color: var(--cor-primaria); }
.installments{ font-size: 14px; font-weight: 900; color: #374151; margin: 0; }

.package-image{
  margin: 14px 0;
  border-radius: var(--radius-14);
  overflow: hidden;
  box-shadow: 0 8px 18px rgba(0,0,0,.10);
}
.package-image img{ width: 100%; height: 170px; object-fit: cover; }

.package-column.highlight .buy-button{
  background: var(--cor-secundaria);
  color: var(--cor-preto);
}
.package-column.highlight .buy-button:hover{
  background: var(--cor-botao-destaque-hover);
}

/* ======================================================================
   SYSTEM UI (APP) — Forms / Alerts / Tabelas / Helpers
   - aqui não mexe na landing, só dá padrões pro sistema
   ====================================================================== */

/* Inputs padrão */
.form-control{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 2px solid rgba(12,63,140,.16);
  background: #fff;
  font-size: 14px;
  outline: none;
  transition: var(--transition);
}
.form-control:focus{
  border-color: rgba(12,63,140,.55);
  box-shadow: 0 0 0 5px rgba(12,63,140,.10);
}
textarea.form-control{ resize: vertical; }

/* Alerts (único) */
.alert{
  border-radius: 14px;
  padding: 10px 12px;
  font-weight: 800;
  margin-bottom: 12px;
}
.alert-danger{
  background: rgba(255, 0, 0, .06);
  border: 1px solid rgba(255, 0, 0, .16);
  color: #7f1d1d;
}
.alert-success{
  background: rgba(16, 185, 129, .10);
  border: 1px solid rgba(16, 185, 129, .25);
  color: #065f46;
}
.alert-info{
  background: rgba(59, 130, 246, .10);
  border: 1px solid rgba(59, 130, 246, .22);
  color: #1e3a8a;
}

/* Grid helper */
.grid-2{
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 16px;
}
@media (max-width: 980px){
  .grid-2{ grid-template-columns: 1fr; }
}

/* Colunas usadas na página */
.col-12{ width: 100%; }
.col-6{ width: calc(50% - 6px); }
.col-4{ width: calc(33.333% - 8px); }
.col-9{ width: calc(75% - 6px); }
.col-3{ width: calc(25% - 6px); }
.col-5{ width: calc(41.666% - 8px); }
.col-2{ width: calc(16.666% - 10px); }

@media (max-width: 700px){
  .col-9,.col-3,.col-5,.col-2,.col-6,.col-4{ width: 100%; }
}

.w-70{width:70px}
.w-110{width:110px}
.w-150{width:150px}
.w-170{width:170px}
.w-260{width:260px}

/* OS layout (sem duplicar) */
.os-grid{display:grid;grid-template-columns:1fr 340px;gap:14px;align-items:start}
@media (max-width: 980px){.os-grid{grid-template-columns:1fr}.os-aside{position:static}}

.os-inline-actions{display:flex;gap:10px;align-items:center}
.os-actions{gap:10px;flex-wrap:wrap}
.os-status-actions{display:flex;gap:10px;flex-wrap:wrap;margin-left:auto}

/* Totais */
.os-totals{display:flex;flex-direction:column;gap:10px}
.os-tot{display:flex;justify-content:space-between;gap:10px;padding:10px;border:1px solid rgba(0,0,0,.08);border-radius:10px}
.os-tot-grand{font-weight:700}
.os-tot-label{opacity:.75}
.os-tot-value{font-weight:700}

/* Textarea grande */
.textarea-lg{width:100%;min-height:260px;white-space:pre-wrap}

/* =========================
   TABELAS (APP)
========================= */
.table-wrap{
  width: 100%;
  overflow: auto;
  border: 1px solid rgba(12,63,140,.12);
  border-radius: var(--radius-16);
  background: #fff;
}

.table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 760px;
}

.table thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  background: linear-gradient(180deg, rgba(12,63,140,.06), rgba(12,63,140,.03));
  color: #0f172a;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .4px;
  text-transform: uppercase;
  padding: 12px 12px;
  border-bottom: 1px solid rgba(12,63,140,.12);
  white-space: nowrap;
}

.table tbody td{
  padding: 12px 12px;
  border-bottom: 1px solid rgba(12,63,140,.10);
  font-size: 14px;
  color: #111827;
  vertical-align: middle;
}

.table tbody tr:nth-child(even){
  background: rgba(12,63,140,.02);
}

.table tbody tr:hover{
  background: rgba(252,173,11,.10);
}

.table .empty{
  text-align: center;
  padding: 18px 12px;
  color: var(--cor-cinza-texto);
  font-weight: 800;
}

.right{ text-align: right; }
.strong{ font-weight: 900; }
.id{ font-weight: 900; color: var(--cor-primaria); }

.row-locked{ opacity: .92; }
.row-muted{ opacity: .60; }

/* Pills status */
.pill-status{ font-weight: 900; border: 1px solid rgba(12,63,140,.12); background: #fff; }
.pill-aberto{ background: rgba(59,130,246,.10); border-color: rgba(59,130,246,.25); color: #1e3a8a; }
.pill-aprovado{ background: rgba(16,185,129,.12); border-color: rgba(16,185,129,.28); color: #065f46; }
.pill-cancelado{ background: rgba(239,68,68,.10); border-color: rgba(239,68,68,.26); color: #7f1d1d; }
.pill-reprovado{ background: rgba(234,179,8,.14); border-color: rgba(234,179,8,.30); color: #7c2d12; }

/* Botões pequenos */
.btn-sm{
  padding: 9px 12px;
  border-radius: 12px;
  font-size: 12px;
}

.inline{ display: inline-flex; }

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

/* Pager */
.pager{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.btn.disabled{
  pointer-events: none;
  opacity: .55;
}

/* Sticky card */
.card-sticky{
  position: sticky;
  top: 88px;
}
@media (max-width: 980px){
  .card-sticky{ position: static; }
}

/* Resumo */
.summary{ display: grid; gap: 10px; }
.summary-line{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(12,63,140,.12);
  background: rgba(12,63,140,.02);
}
.summary-grand{
  border-color: rgba(252,173,11,.38);
  background: rgba(252,173,11,.12);
}

/* Divider/section */
.divider{
  height: 1px;
  background: rgba(12,63,140,.12);
  margin: 6px 0;
}

.section-head{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.section-head h3{
  margin: 0;
  font-weight: 900;
  color: var(--cor-primaria);
}

/* =========================
   AUTOCOMPLETE (mantido)
========================= */
#cliente_lista, #produto_lista{
  margin-top: 8px;
  display: grid;
  gap: 8px;
}

.lw-ac-item{
  width: 100%;
  text-align: left;
  border: 1px solid rgba(12,63,140,.12);
  background: #fff;
  border-radius: 14px;
  padding: 10px 12px;
  cursor: pointer;
  transition: var(--transition);
}

.lw-ac-item:hover{
  background: rgba(12,63,140,.06);
  border-color: rgba(12,63,140,.22);
}

.lw-ac-item .nm{
  font-weight: 900;
  color: #0f172a;
  line-height: 1.2;
}

.lw-ac-item .sm{
  margin-top: 3px;
  font-size: 12px;
  color: var(--cor-cinza-texto);
  font-weight: 800;
}

/* Botão mini */
.btn-mini{
  padding: 8px 10px;
  border-radius: 12px;
  font-size: 12px;
}

/* ==========================================================================
   POPUP / MODAL ORÇAMENTO (ÚNICO — sem duplicar)
   Compatível com: pop_up.js e #popup-orcamento
   ========================================================================== */

.popup-container,
#popup-orcamento.popup-container{
  position: fixed;
  inset: 0;
  display: none; /* abre via JS */
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(0,0,0,.55);
  z-index: var(--z-popup);
}

/* JS pode usar is-open ou setar display:flex */
.popup-container.is-open{ display:flex; }

#popup-orcamento.popup-container{
  z-index: 99999;
}

.popup-content,
#popup-orcamento .popup-content{
  width: min(540px, 100%);
  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(12,63,140,.12);
  box-shadow: 0 18px 40px rgba(2,8,23,.22);
  padding: 16px;
  position: relative;
}

.close-btn,
#popup-orcamento .close-btn{
  position: absolute;
  top: 10px;
  right: 12px;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  cursor: pointer;
  font-size: 22px;
  font-weight: 900;
  color: var(--cor-primaria);
  background: rgba(12,63,140,.06);
}

.popup-content h2,
#popup-orcamento h2{
  margin: 4px 40px 6px 0;
  font-weight: 900;
  color: var(--cor-primaria);
}

.popup-subtitle,
#popup-orcamento .popup-subtitle{
  margin: 0 0 14px 0;
  color: rgba(75,85,99,.95);
  font-weight: 700;
}

.popup-content label,
#popup-orcamento label{
  display:block;
  margin: 10px 0 6px;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .6px;
  color: rgba(17,24,39,.82);
}

.popup-content input,
.popup-content textarea,
#popup-orcamento input,
#popup-orcamento textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 2px solid rgba(12,63,140,.16);
  outline: none;
  font-size: 14px;
  transition: var(--transition);
}

.popup-content input:focus,
.popup-content textarea:focus,
#popup-orcamento input:focus,
#popup-orcamento textarea:focus{
  border-color: rgba(12,63,140,.55);
  box-shadow: 0 0 0 5px rgba(12,63,140,.10);
}

.popup-textarea{ resize: vertical; }

.btn-continue,
#popup-orcamento .btn-continue{
  width: 100%;
  margin-top: 10px;
  padding: 13px 14px;
  border-radius: 14px;
  font-weight: 900;
  cursor: pointer;
  border: 2px solid transparent;
}

.btn-primary-fill,
#popup-orcamento .btn-primary-fill{
  background: var(--cor-primaria);
  color: #fff;
  box-shadow: 0 10px 18px rgba(12,63,140,.18);
}

.btn-outline,
#popup-orcamento .btn-outline{
  background: transparent;
  border-color: rgba(12,63,140,.22);
  color: var(--cor-primaria);
}

.btn-highlight,
#popup-orcamento .btn-highlight{
  background: var(--cor-secundaria);
  color: #111;
}

.popup-footnote,
#popup-orcamento .popup-footnote{
  margin-top: 10px;
  font-size: 12px;
  color: rgba(75,85,99,.9);
}



/* =========================
   MOBILE CARDS
   ========================= */

.only-desktop { display: block; }
.only-mobile  { display: none; }

@media (max-width: 900px){
  .only-desktop { display: none; }
  .only-mobile  { display: block; }

  .orc-cards{
    display: grid;
    gap: 12px;
  }

  .orc-card{
    border: 1px solid var(--border);
    background: var(--bg-card);
    border-radius: 16px;
    box-shadow: var(--shadow);
    padding: 12px;
  }

  .orc-card.orc-muted{ opacity: .65; }
  .orc-card.orc-locked{ border-style: dashed; }

  .orc-card-top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap: 10px;
    margin-bottom: 10px;
  }

  .orc-id-main{
    font-weight: 800;
    font-size: 16px;
  }

  .orc-id-sub{
    font-size: 12px;
    color: var(--muted);
    margin-top: 2px;
  }

  .orc-card-mid{
    display:grid;
    gap: 8px;
    margin-bottom: 10px;
  }

  .orc-line{
    display:flex;
    justify-content:space-between;
    gap: 10px;
  }

  .orc-line .k{
    font-size: 11px;
    color: var(--muted);
    letter-spacing: .5px;
  }

  .orc-line .v{
    font-weight: 700;
    text-align: right;
    max-width: 70%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .orc-total{
    display:flex;
    justify-content:space-between;
    padding-top: 8px;
    border-top: 1px solid var(--border);
  }

  .orc-total .k{
    font-size: 11px;
    color: var(--muted);
    letter-spacing: .5px;
  }

  .orc-total .v{
    font-weight: 900;
    font-size: 16px;
  }

  .orc-card-actions{
    display:flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .orc-card-actions .btn{
    flex: 1 1 auto;
    min-width: 90px;
  }
}



/* ITENS (MOBILE) - transforma tabela em CARDS */
/* ======================================================================
   ORÇAMENTO (APP) — MOBILE CARDS (LISTA) + ITENS MOBILE (CADASTRO)
   Corrigido para usar SUAS variáveis (--cor-*, --shadow-1, --radius-16)
   ====================================================================== */

.only-desktop{ display:block; }
.only-mobile{ display:none; }

@media (max-width: 900px){
  .only-desktop{ display:none; }
  .only-mobile{ display:block; }

  /* =========================
     LISTA DE ORÇAMENTOS (CARDS) — se você usar na lista.php
     (mantém compatível, mas sem quebrar por variáveis inexistentes)
  ========================= */
  .orc-cards{
    display: grid;
    gap: 12px;
  }

  .orc-card{
    border: 1px solid rgba(12,63,140,.14);
    background: var(--cor-branco);
    border-radius: var(--radius-16);
    box-shadow: var(--shadow-1);
    padding: 12px;
  }

  .orc-card.orc-muted{ opacity: .65; }
  .orc-card.orc-locked{ border-style: dashed; }

  .orc-card-top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap: 10px;
    margin-bottom: 10px;
  }

  .orc-id-main{
    font-weight: 900;
    font-size: 16px;
    color: var(--cor-preto);
  }

  .orc-id-sub{
    font-size: 12px;
    color: var(--cor-cinza-texto);
    margin-top: 2px;
    font-weight: 800;
  }

  .orc-card-mid{
    display:grid;
    gap: 8px;
    margin-bottom: 10px;
  }

  .orc-line{
    display:flex;
    justify-content:space-between;
    gap: 10px;
  }

  .orc-line .k{
    font-size: 11px;
    color: var(--cor-cinza-texto);
    letter-spacing: .5px;
    font-weight: 900;
    text-transform: uppercase;
  }

  .orc-line .v{
    font-weight: 900;
    text-align: right;
    max-width: 70%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--cor-preto);
  }

  .orc-total{
    display:flex;
    justify-content:space-between;
    padding-top: 8px;
    border-top: 1px solid rgba(12,63,140,.12);
  }

  .orc-total .k{
    font-size: 11px;
    color: var(--cor-cinza-texto);
    letter-spacing: .5px;
    font-weight: 900;
    text-transform: uppercase;
  }

  .orc-total .v{
    font-weight: 900;
    font-size: 16px;
    color: var(--cor-primaria);
  }

  .orc-card-actions{
    display:flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .orc-card-actions .btn{
    flex: 1 1 auto;
    min-width: 90px;
  }

  /* =========================
     CADASTRO DE ORÇAMENTO > ITENS (MOBILE CARDS)
  ========================= */

  .page-orcamento-cadastro .form-row{ gap: 10px; }
  .page-orcamento-cadastro .form-field{ margin-bottom: 10px; }

  .itens-cards{
    display: grid;
    gap: 12px;
  }

  .item-card{
    background: var(--cor-branco);
    border: 1px solid rgba(12,63,140,.14);
    border-radius: var(--radius-16);
    box-shadow: var(--shadow-1);
    padding: 12px;
    overflow: hidden;
  }

  .item-card-top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:10px;
    margin-bottom:10px;
  }

  .item-card-title{
    font-weight: 900;
    font-size: 14px;
    line-height: 1.2;
    color: var(--cor-preto);
    max-width: 260px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .item-card-sub{
    margin-top: 4px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 900;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(12,63,140,.06);
    border: 1px solid rgba(12,63,140,.14);
    color: var(--cor-primaria);
    letter-spacing: .3px;
    text-transform: uppercase;
  }

  .item-card-actions{
    display:flex;
    gap:8px;
    align-items:center;
  }

  .item-card-grid{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap:10px;
    margin-bottom:10px;
  }

  .kv{
    background: rgba(12,63,140,.03);
    border: 1px dashed rgba(12,63,140,.20);
    border-radius: 14px;
    padding: 10px;
  }

  .kv .k{
    display:block;
    font-size: 10px;
    color: var(--cor-cinza-texto);
    font-weight: 900;
    letter-spacing: .6px;
    text-transform: uppercase;
    margin-bottom: 6px;
  }

  .kv .v{
    display:block;
    font-weight: 900;
    font-size: 13px;
    color: var(--cor-preto);
  }

  .item-card-total{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap: 10px;
    padding-top:10px;
    border-top: 1px solid rgba(12,63,140,.12);
  }

  .item-card-total .k{
    font-size: 10px;
    color: var(--cor-cinza-texto);
    font-weight: 900;
    letter-spacing: .6px;
    text-transform: uppercase;
  }

  .item-card-total .v{
    font-weight: 900;
    font-size: 16px;
    color: var(--cor-primaria);
  }
}


/* ======================================================================
   ORÇAMENTO (LISTA) — MOBILE: MAIS ESPAÇO / RESPIRO
   ====================================================================== */

@media (max-width: 900px){

  /* mais espaço entre os cards */
  .orc-cards{
    gap: 14px; /* era 12 */
  }

  /* card com mais respiro */
  .orc-card{
    padding: 14px;             /* era 12 */
    border-radius: 18px;        /* levemente maior */
  }

  /* separa topo do meio */
  .orc-card-top{
    margin-bottom: 12px;        /* era 10 */
    gap: 12px;                  /* era 10 */
  }

  /* aumenta espaço entre as linhas internas */
  .orc-card-mid{
    gap: 10px;                  /* era 8 */
    margin-bottom: 12px;        /* era 10 */
  }

  /* linha com mais “ar” */
  .orc-line{
    padding: 8px 10px;
    border: 1px solid rgba(12,63,140,.10);
    border-radius: 14px;
    background: rgba(12,63,140,.02);
  }

  /* melhora a leitura: label e valor */
  .orc-line .k{
    font-size: 10.5px;          /* um tiquinho menor */
  }
  .orc-line .v{
    max-width: 68%;
  }

  /* total mais destacado e com folga */
  .orc-total{
    margin-top: 4px;
    padding-top: 10px;
  }

  /* botões com mais espaço e menos “colado” */
  .orc-card-actions{
    gap: 10px;                  /* era 8 */
    margin-top: 2px;
  }

  .orc-card-actions .btn{
    padding: 12px 14px;         /* mais confortável no touch */
    border-radius: 14px;
  }

  /* pills/status com mais espaço visual */
  .pill.pill-status{
    padding: 8px 12px;
    border-radius: 999px;
    line-height: 1;
  }

  /* quando estiver “muted”, mantém legível */
  .orc-card.orc-muted{
    opacity: .75;               /* era .65 */
  }
}
