/* Orçamento — extends styles.css com layout do gerador */
.orc-main { max-width: 1200px; margin: 0 auto; padding: 50px 24px 60px; }

.orc-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
  margin-bottom: 36px; flex-wrap: wrap;
}
.orc-h1 { font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 600; letter-spacing: -.04em; line-height: 1.05; margin: 14px 0 8px; }
.orc-head .lead { color: var(--text-2); max-width: 500px; }
.orc-head-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.orc-form {
  display: flex; flex-direction: column; gap: 18px;
  margin-bottom: 24px;
}
.orc-row-2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
}
@media (max-width: 900px) { .orc-row-2 { grid-template-columns: 1fr; } }

.orc-fs {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 22px 24px 24px;
}
.orc-fs legend {
  font-family: var(--mono); font-size: .75rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--text-2);
  padding: 0 10px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.orc-fs legend i { color: var(--accent); margin-right: 6px; }
.orc-fs label {
  display: block;
  font-family: var(--mono); font-size: .68rem;
  text-transform: uppercase; letter-spacing: .14em;
  color: var(--text-3); font-weight: 500;
  margin: 14px 0 6px;
}
.orc-fs input[type=text],
.orc-fs input[type=email],
.orc-fs input[type=tel],
.orc-fs input[type=date],
.orc-fs input[type=number],
.orc-fs select,
.orc-fs textarea {
  width: 100%;
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 10px 12px;
  color: var(--text);
  font-family: var(--sans);
  font-size: .94rem;
  transition: border-color .15s, box-shadow .15s;
}
.orc-fs textarea { resize: vertical; min-height: 60px; font-family: var(--sans); }
.orc-fs select option { background: var(--bg-2); }
.orc-fs input:focus, .orc-fs select:focus, .orc-fs textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(59,130,246,.15);
}
.orc-fs input::placeholder, .orc-fs textarea::placeholder { color: var(--text-3); }

.field-row { display: flex; gap: 10px; align-items: flex-end; }
.field-row .field-grow { flex: 1; }
.field-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 700px) { .field-grid-4 { grid-template-columns: repeat(2, 1fr); } }
.btn-search { white-space: nowrap; align-self: flex-end; height: 41px; }

/* Itens */
.items-table { display: flex; flex-direction: column; margin-bottom: 12px; }
.items-head, .item-row {
  display: grid;
  grid-template-columns: 1fr 90px 130px 130px 44px;
  gap: 10px;
  align-items: center;
  padding: 8px 4px;
}
.items-head {
  font-family: var(--mono); font-size: .68rem; font-weight: 500;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--text-3);
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
  padding: 8px 4px;
}
.item-row { padding: 6px 4px; }
.item-row input {
  width: 100%;
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 10px;
  color: var(--text);
  font-family: var(--sans);
  font-size: .92rem;
}
.item-row input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(59,130,246,.15);
}
.item-row .item-total {
  font-family: var(--mono); color: var(--text);
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 10px;
  text-align: right;
  font-size: .92rem;
}
.item-row .item-del {
  width: 36px; height: 36px; border: 1px solid var(--border);
  background: transparent; color: var(--text-3);
  border-radius: 8px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.item-row .item-del:hover {
  border-color: var(--red); color: var(--red);
  background: rgba(239,68,68,.08);
}
@media (max-width: 700px) {
  .items-head { display: none; }
  .item-row {
    grid-template-columns: 1fr 1fr 44px;
    grid-template-areas: "desc desc desc" "qty unit del" "total total total";
    gap: 6px;
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 12px;
    margin-bottom: 10px;
  }
  .item-row > input:nth-child(1) { grid-area: desc; }
  .item-row > input:nth-child(2) { grid-area: qty; }
  .item-row > input:nth-child(3) { grid-area: unit; }
  .item-row > .item-total { grid-area: total; }
  .item-row > .item-del { grid-area: del; }
}

/* Totais */
.totais { display: flex; flex-direction: column; gap: 10px; max-width: 480px; margin-left: auto; }
.total-row {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding: 8px 0;
}
.total-row .label {
  font-family: var(--mono); font-size: .72rem;
  text-transform: uppercase; letter-spacing: .14em;
  color: var(--text-3); font-weight: 500;
}
.total-row strong { font-family: var(--mono); font-size: 1rem; }
.total-final {
  border-top: 1px solid var(--border);
  padding-top: 14px;
  margin-top: 4px;
}
.total-big { font-size: 1.7rem !important; font-weight: 600; color: var(--text); letter-spacing: -.02em; font-family: var(--sans) !important; }
.desc-input { display: flex; gap: 6px; align-items: center; max-width: 220px; }
.desc-input input { flex: 1; }
.desc-input select { width: 70px; }

/* Actions bar */
.orc-actions-bar {
  position: sticky; bottom: 16px; z-index: 50;
  display: flex; gap: 10px; flex-wrap: wrap;
  padding: 14px 18px;
  background: rgba(15,15,18,.85);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border);
  border-radius: 14px;
  margin: 30px 0 8px;
  justify-content: center;
}

/* Preview / paper */
.orc-preview {
  background: rgba(0,0,0,.5);
  border-radius: 18px;
  padding: 30px;
  margin-top: 24px;
}
.preview-actions {
  display: flex; gap: 10px; justify-content: center;
  margin-top: 22px;
}
.paper {
  background: #fff;
  color: #1a1a1a;
  max-width: 800px;
  margin: 0 auto;
  padding: 50px 60px;
  border-radius: 6px;
  font-family: var(--sans);
  line-height: 1.5;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.6);
}
.paper-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 24px;
  border-bottom: 2px solid #1a1a1a;
  padding-bottom: 22px; margin-bottom: 28px;
}
.paper-head .paper-eyebrow {
  font-family: var(--mono); font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .2em;
  color: var(--accent);
  margin-bottom: 4px;
}
.paper-head h2 { font-size: 1.8rem; font-weight: 700; letter-spacing: -.02em; color: #1a1a1a; }
.paper-from { text-align: right; font-size: .82rem; line-height: 1.5; }
.paper-from strong { display: block; font-size: .98rem; font-weight: 600; margin-bottom: 4px; color: #1a1a1a; }
.paper-from span { display: block; color: #666; }

.paper-section { margin-bottom: 22px; }
.paper-section h3 {
  font-family: var(--mono); font-size: .7rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .15em;
  color: #888;
  margin-bottom: 8px;
  padding-bottom: 4px;
  border-bottom: 1px solid #e5e5e5;
}
.paper-section strong { color: #1a1a1a; font-size: 1.05rem; font-weight: 600; }
.paper-section p { color: #444; font-size: .92rem; }
.muted-sm { color: #666 !important; font-size: .88rem; }

.paper-meta {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; margin-bottom: 14px;
}
.paper-meta div { display: flex; flex-direction: column; gap: 2px; }
.paper-meta .label, .paper-totals .label {
  font-family: var(--mono); font-size: .65rem;
  text-transform: uppercase; letter-spacing: .15em;
  color: #888; font-weight: 500;
}
.paper-meta strong { font-size: .92rem; color: #1a1a1a; }
.paper-desc { color: #444; font-size: .92rem; margin-top: 8px; }

.paper-items {
  width: 100%; border-collapse: collapse;
  margin: 24px 0;
  font-size: .9rem;
}
.paper-items th {
  text-align: left; padding: 10px 8px;
  background: #f5f5f5;
  font-family: var(--mono); font-size: .68rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .12em;
  color: #555;
  border-bottom: 2px solid #1a1a1a;
}
.paper-items th:not(:first-child),
.paper-items td:not(:first-child) { text-align: right; }
.paper-items td {
  padding: 10px 8px;
  border-bottom: 1px solid #eee;
  color: #1a1a1a;
}
.paper-items td:nth-child(2),
.paper-items td:nth-child(3),
.paper-items td:nth-child(4) { font-family: var(--mono); }

.paper-totals {
  display: flex; flex-direction: column; gap: 6px;
  max-width: 320px; margin-left: auto;
  padding: 14px 16px;
  background: #fafafa;
  border-radius: 6px;
}
.paper-totals > div {
  display: flex; justify-content: space-between; align-items: center;
}
.paper-totals strong { color: #1a1a1a; font-family: var(--mono); }
.paper-totals .total-final {
  border-top: 2px solid #1a1a1a;
  padding-top: 8px; margin-top: 6px;
}
.paper-totals .total-big { color: var(--accent) !important; font-family: var(--sans) !important; }

.paper-foot {
  margin-top: 32px;
  padding-top: 16px;
  border-top: 1px solid #e5e5e5;
  display: flex; justify-content: space-between;
  font-size: .75rem;
  color: #888;
}

/* Drafts modal */
.dlg {
  background: var(--bg-2);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 0;
  max-width: 480px; width: 90%;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.7);
}
.dlg::backdrop { background: rgba(0,0,0,.7); backdrop-filter: blur(8px); }
.dlg-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
}
.dlg-head h3 { font-size: 1.05rem; font-weight: 600; }
.btn-close {
  background: transparent; border: 0; color: var(--text-2);
  font-size: 1.5rem; cursor: pointer; padding: 4px 10px;
  border-radius: 6px;
}
.btn-close:hover { background: rgba(255,255,255,.06); color: var(--text); }
.drafts-list { list-style: none; padding: 12px 14px; max-height: 60vh; overflow-y: auto; }
.drafts-list li {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 12px 14px;
  border-radius: 8px;
  border: 1px solid var(--border);
  margin-bottom: 8px;
  cursor: pointer;
  transition: all .15s;
}
.drafts-list li:hover { border-color: var(--accent); background: rgba(59,130,246,.04); }
.drafts-list .draft-info { display: flex; flex-direction: column; gap: 2px; }
.drafts-list .draft-name { color: var(--text); font-weight: 500; font-size: .92rem; }
.drafts-list .draft-meta { color: var(--text-3); font-family: var(--mono); font-size: .72rem; }
.drafts-list .draft-actions { display: flex; gap: 4px; }
.drafts-list .draft-actions button {
  background: transparent; border: 1px solid var(--border);
  color: var(--text-3); padding: 4px 8px; border-radius: 6px; font-size: .78rem; cursor: pointer;
}
.drafts-list .draft-actions button:hover { color: var(--text); border-color: var(--border-2); }
.drafts-list .draft-actions .btn-rm:hover { border-color: var(--red); color: var(--red); }
.drafts-empty { text-align: center; color: var(--text-3); padding: 24px; font-size: .9rem; }

/* Toast */
.toast {
  position: fixed; bottom: 90px; left: 50%; transform: translateX(-50%);
  background: var(--bg-2);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 10px 18px;
  border-radius: 10px;
  font-size: .9rem;
  box-shadow: 0 12px 30px -10px rgba(0,0,0,.6);
  z-index: 1000;
  animation: toastIn .25s ease;
}
.toast.ok { border-color: var(--green); color: var(--green); }
.toast.err { border-color: var(--red); color: #f87171; }
@keyframes toastIn { from { opacity: 0; transform: translate(-50%, 10px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* Print: when imprimindo, escondemos tudo exceto o paper */
@media print {
  body * { visibility: hidden; }
  .orc-preview, .orc-preview * { visibility: visible; }
  .orc-preview { position: absolute; top: 0; left: 0; width: 100%; padding: 0; background: white; }
  .preview-actions { display: none !important; }
  .paper { box-shadow: none; max-width: none; padding: 30px; border-radius: 0; }
}
