/* ==========================================================================
   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);
  line-height: 1.5;
}

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

/* =========================
   BOTÕES
========================= */
.btn,
.btn-primary,
.btn-secondary{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 18px;
  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);
}

.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.35;
  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
   ====================================================================== */

.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;
}

.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-2{
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 16px;
}
@media (max-width: 980px){
  .grid-2{
    grid-template-columns: 1fr;
  }
}

.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-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;
}

.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-lg{
  width: 100%;
  min-height: 260px;
  white-space: pre-wrap;
}

/* =========================
   TABELAS
========================= */
.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; }

.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;
}

.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{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

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

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

.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{
  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
========================= */
#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;
}

.btn-mini{
  padding: 8px 10px;
  border-radius: 12px;
  font-size: 12px;
}

/* =========================
   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: 14px;
  }

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

  .orc-card.orc-muted{
    opacity: .75;
  }

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

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

  .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: 10px;
    margin-bottom: 12px;
  }

  .orc-line{
    display: flex;
    justify-content: space-between;
    gap: 10px;
    padding: 8px 10px;
    border: 1px solid rgba(12,63,140,.10);
    border-radius: 14px;
    background: rgba(12,63,140,.02);
  }

  .orc-line .k{
    font-size: 10.5px;
    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: 68%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--cor-preto);
  }

  .orc-total{
    display: flex;
    justify-content: space-between;
    margin-top: 4px;
    padding-top: 10px;
    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: 10px;
    margin-top: 2px;
  }

  .orc-card-actions .btn{
    flex: 1 1 auto;
    min-width: 90px;
    padding: 12px 14px;
    border-radius: 14px;
  }

  .pill.pill-status{
    padding: 8px 12px;
    border-radius: 999px;
    line-height: 1;
  }

  .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);
  }
}