/* ============================================================
   EVENTIPO — Orçamentos (Budgets) styles
   ============================================================ */
.orc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.orc-card { text-align: left; background: var(--bg-surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 20px; cursor: pointer; display: flex; flex-direction: column; gap: 6px; transition: all .14s; }
.orc-card:hover { border-color: var(--line-strong); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.orc-card-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 6px; }
.orc-card-date { font-size: 10.5px; color: var(--ink-4); }
.orc-card-name { font-size: 17px; color: var(--ink); font-weight: 500; line-height: 1.2; text-wrap: pretty; }
.orc-card-client { font-size: 11.5px; color: var(--ink-3); }
.orc-card-foot { display: flex; justify-content: space-between; gap: 12px; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line-soft); }
.orc-card-foot > div { display: flex; flex-direction: column; gap: 3px; }
.orc-card-foot > div:last-child { align-items: flex-end; }
.orc-card-total { font-size: 20px; font-weight: 500; letter-spacing: -0.01em; }
.orc-card-cpg { font-size: 14px; color: var(--ink); }
.orc-card-lab { font-size: 10px; color: var(--ink-4); }

/* editor */
.orc-ed-bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.orc-head { padding: 22px 24px; }
.orc-title { width: 100%; background: transparent; border: 0; border-bottom: 1px solid var(--line-strong); outline: 0; color: var(--ink); font-size: 24px; font-family: var(--serif); padding: 4px 0 10px; }
.orc-title:focus { border-color: var(--gold); }
.orc-title::placeholder { color: var(--ink-4); }
.orc-head-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 14px; margin-top: 18px; }

.orc-cat { padding: 0; overflow: hidden; }
.orc-cat-head { display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--line-soft); }
.orc-cat-toggle { background: none; border: 0; color: var(--ink-3); cursor: pointer; display: flex; padding: 2px; }
.orc-cat-name { flex: 1; background: transparent; border: 1px solid transparent; border-radius: 6px; outline: 0; color: var(--ink); font-size: 16px; font-family: var(--serif); padding: 4px 8px; }
.orc-cat-name:hover { border-color: var(--line); } .orc-cat-name:focus { border-color: var(--gold-line); }
.orc-cat-total { font-size: 14px; color: var(--gold); }
.orc-item-head { display: grid; grid-template-columns: 2.4fr 0.7fr 0.8fr 1fr 1fr 30px; gap: 10px; padding: 10px 18px; }
.orc-item-head span { font-family: var(--mono); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-4); }
.orc-item-row { display: grid; grid-template-columns: 2.4fr 0.7fr 0.8fr 1fr 1fr 30px; gap: 10px; align-items: center; padding: 4px 18px; }
.orc-inp { background: transparent; border: 1px solid transparent; border-radius: 6px; padding: 7px 9px; color: var(--ink); font-family: var(--sans); font-size: 13px; outline: 0; width: 100%; transition: border-color .12s; }
.orc-inp:hover { border-color: var(--line); } .orc-inp:focus { border-color: var(--gold-line); background: var(--bg-inset); }
.orc-inp.mono { font-family: var(--mono); } .orc-inp.num { text-align: right; }
.orc-sub { text-align: right; font-size: 13px; color: var(--ink); }
.orc-additem { display: inline-flex; align-items: center; gap: 6px; background: none; border: 0; color: var(--gold); font-size: 12px; padding: 12px 18px; cursor: pointer; }
.orc-additem:hover { color: var(--gold-bright); }
.orc-addcat { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; background: none; border: 1px dashed var(--line-strong); border-radius: var(--r-md); color: var(--ink-3); font-size: 13px; padding: 14px; cursor: pointer; transition: all .14s; }
.orc-addcat:hover { border-color: var(--gold-line); color: var(--gold); }

.orc-rev { display: flex; flex-direction: column; gap: 2px; margin-bottom: 14px; }
.orc-rev-row { display: grid; grid-template-columns: 1fr 130px 30px; gap: 10px; align-items: center; }
.orc-margin { border-radius: var(--r-md); padding: 14px 16px; margin-top: 6px; border: 1px solid; }
.orc-margin[data-pos="true"] { background: oklch(0.74 0.07 155 / 0.1); border-color: oklch(0.74 0.07 155 / 0.4); }
.orc-margin[data-pos="false"] { background: oklch(0.58 0.18 28 / 0.1); border-color: oklch(0.58 0.18 28 / 0.4); }
.orc-margin-lab { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; font-family: var(--mono); color: var(--ink-3); }
.orc-margin-val { font-size: 20px; font-weight: 500; }
.orc-margin[data-pos="true"] .orc-margin-val { color: var(--pos); }
.orc-margin[data-pos="false"] .orc-margin-val { color: var(--neg); }
.orc-margin-hint { font-size: 11.5px; line-height: 1.5; color: var(--ink-3); margin-top: 12px; text-wrap: pretty; }

.orc-totals { display: flex; flex-direction: column; gap: 2px; justify-content: center; }
.orc-tot-row { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--line-soft); }
.orc-tot-row:last-child { border-bottom: 0; }
.orc-tot-row span:first-child { font-size: 13px; color: var(--ink-3); }
.orc-tot-big { font-size: 30px; font-weight: 500; letter-spacing: -0.02em; }
.orc-tot-row.sub span { font-size: 13.5px; color: var(--ink-2); }
.orc-tot-row.sub .mono { color: var(--ink); }

/* report */
.orc-report { padding: 40px 44px; }
.orc-rep-cat { padding: 18px 0; border-bottom: 1px solid var(--line-soft); }
.orc-rep-cat-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 8px; }
.orc-rep-cat-tot { font-size: 14px; color: var(--gold); }
.orc-rep-table { width: 100%; border-collapse: collapse; }
.orc-rep-table td { padding: 7px 0; font-size: 13px; color: var(--ink-2); border-bottom: 1px solid var(--line-soft); }
.orc-rep-desc { color: var(--ink); width: 50%; }
.orc-rep-qty { color: var(--ink-3); }
.orc-rep-unit { color: var(--ink-3); text-align: right; }
.orc-rep-sub { text-align: right; color: var(--ink); }
.orc-rep-totals { padding: 20px 0; }
.orc-rep-trow { display: flex; justify-content: space-between; padding: 8px 0; font-size: 14px; color: var(--ink-2); }
.orc-rep-trow.grand { font-size: 18px; color: var(--ink); border-bottom: 1px solid var(--line); padding-bottom: 14px; margin-bottom: 6px; }
.orc-rep-trow.grand .mono { color: var(--gold); font-weight: 500; }

@media (max-width: 1000px) { .orc-grid { grid-template-columns: 1fr 1fr; } .orc-head-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 680px) {
  .orc-grid { grid-template-columns: 1fr; }
  .orc-item-head, .orc-item-row { grid-template-columns: 2fr 0.6fr 1fr 30px; }
  .orc-item-head span:nth-child(3), .orc-item-row > .orc-inp:nth-child(3), .orc-item-head span:nth-child(5), .orc-item-row > .orc-sub { display: none; }
  .card:has(.orc-item-row) { overflow-x: auto; }
}
@media print {
  .sidebar, .topbar, .no-print { display: none !important; }
  .main, .scroll, .page, .app { overflow: visible !important; height: auto !important; display: block !important; }
  body, .app, .main, .scroll { background: #fff !important; }
  .orc-report { border: 0; padding: 0; background: #fff !important; }
  .orc-report, .orc-report * { color: #111 !important; }
  .rp-title { color: #000 !important; }
  .orc-rep-cat-tot, .orc-rep-trow.grand .mono, .rp-meta, .sp-foot2-mark { color: #9a7b3a !important; -webkit-text-fill-color: #9a7b3a !important; }
  .orc-rep-cat { break-inside: avoid; border-color: #e4e4e4 !important; }
  .sp-foot2 { background: #f4f4f4 !important; -webkit-print-color-adjust: exact; }
}
