@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap');

/* ═══════════════════════════════════════════════════════════════════════════
   mude. propostas — design system v2
   100% Lato · identidade amarelo/bege · preview branco/claro pro PDF
   ═══════════════════════════════════════════════════════════════════════════ */

*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100vh;font-family:'Lato',-apple-system,BlinkMacSystemFont,sans-serif;background:#f4f3ef;color:#1a1a1a;font-size:14px;font-weight:400}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:#f0f0ec}
::-webkit-scrollbar-thumb{background:#ddd;border-radius:2px}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
input,select,textarea{font-family:inherit;font-size:inherit}
code{background:#f4f3ef;padding:1px 6px;border-radius:4px;font-size:12px;font-family:'SF Mono',Monaco,monospace}

/* ─── LOGIN ──────────────────────────────────────────────────────────────── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f4f3ef}
.login-bg{position:fixed;inset:0;background:radial-gradient(ellipse 50% 50% at 30% 50%,#ffe60030 0%,transparent 70%);pointer-events:none}
.login-card{position:relative;z-index:1;width:420px;padding:48px;background:#fff;border:1px solid #e8e8e4;border-radius:16px;box-shadow:0 4px 40px #0000000a}
.login-logo{font-family:'Lato',sans-serif;font-size:36px;font-weight:900;color:#1a1a1a;line-height:1;letter-spacing:-.03em}
.login-logo span{display:block;font-size:12px;color:#888;font-weight:400;margin-top:4px;margin-bottom:32px;letter-spacing:0}

.form-group{margin-bottom:16px}
.form-label{display:block;font-size:11px;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.form-input{width:100%;padding:11px 14px;background:#f9f9f7;border:1px solid #e8e8e4;border-radius:8px;color:#1a1a1a;font-size:14px;outline:none;transition:border .2s,background .2s;font-weight:400}
.form-input:focus{border-color:#ffe600;background:#fff}
select.form-input{cursor:pointer}
textarea.form-input{resize:vertical;min-height:80px;line-height:1.5}

.btn-primary{padding:11px 20px;background:#ffe600;color:#1a1a1a;font-weight:700;font-size:13px;border:none;border-radius:8px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}
.btn-primary:hover{background:#f5dc00;transform:translateY(-1px);box-shadow:0 3px 10px #ffe60044}
.btn-primary:disabled{opacity:.4;cursor:not-allowed}
.btn-primary.full{width:100%;justify-content:center;padding:13px}

.btn-ghost{padding:9px 14px;background:transparent;color:#666;font-weight:700;font-size:13px;border:1px solid #e8e8e4;border-radius:8px;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{background:#fff;color:#1a1a1a;border-color:#ccc}

.btn-dark{padding:9px 14px;background:#1a1a1a;color:#fff;font-weight:700;font-size:13px;border-radius:8px;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-dark:hover{background:#000;transform:translateY(-1px);box-shadow:0 3px 10px #0000001a}

.btn-danger{padding:9px 14px;background:transparent;color:#dc2626;border:1px solid #fecaca;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-danger:hover{background:#fee2e2}

.btn-icon{padding:7px;border-radius:6px;color:#999;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;font-size:13px}
.btn-icon:hover{background:#f4f3ef;color:#1a1a1a}

.btn-sm{padding:6px 12px;font-size:12px}

.error-msg{color:#e53e3e;font-size:12px;margin-top:8px;text-align:center;min-height:16px}

/* ─── APP LAYOUT ─────────────────────────────────────────────────────────── */
.app{display:flex;min-height:100vh}
.sidebar{width:220px;background:#ffe600;display:flex;flex-direction:column;flex-shrink:0;position:fixed;top:0;left:0;bottom:0;z-index:10}
.sidebar-logo{padding:24px 20px 18px;font-family:'Lato',sans-serif;font-size:26px;font-weight:900;color:#1a1a1a;border-bottom:1px solid #f0d80055;line-height:1;letter-spacing:-.03em}
.sidebar-logo small{display:block;font-size:10px;color:#1a1a1a77;font-weight:700;margin-top:4px;text-transform:uppercase;letter-spacing:.12em;letter-spacing:.12em}
.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}
.nav-section{font-size:9px;font-weight:900;color:#1a1a1a66;text-transform:uppercase;letter-spacing:.12em;padding:14px 20px 4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:13px;font-weight:700;color:#1a1a1aaa;cursor:pointer;transition:all .15s;border-left:3px solid transparent;text-decoration:none}
.nav-item svg{opacity:.7;flex-shrink:0;transition:all .15s}
.nav-item:hover{color:#1a1a1a;background:#fff3}
.nav-item:hover svg{opacity:1}
.nav-item.active{color:#1a1a1a;border-left-color:#1a1a1a;background:#fff5}
.nav-item.active svg{opacity:1}
.nav-item .count{margin-left:auto;font-size:10px;background:#1a1a1a15;padding:2px 7px;border-radius:99px;font-weight:700}
.nav-item.active .count{background:#1a1a1a;color:#ffe600}
.sidebar-footer{padding:14px 18px;border-top:1px solid #f0d80055}
.user-name{font-size:13px;font-weight:700;color:#1a1a1a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-role{font-size:11px;color:#1a1a1a77;margin-top:2px}
.btn-logout{margin-top:10px;background:#1a1a1a15;border:1px solid #1a1a1a20;color:#1a1a1aaa;padding:7px 12px;border-radius:7px;font-size:11px;cursor:pointer;width:100%;font-weight:700;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.btn-logout:hover{background:#1a1a1a;color:#ffe600}

.main{margin-left:220px;flex:1;min-height:100vh;min-width:0}

.page-header{padding:26px 28px 0;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-title{font-family:'Lato',sans-serif;font-size:26px;font-weight:900;color:#1a1a1a;letter-spacing:-.02em;line-height:1.1}
.page-sub{font-size:13px;color:#888;margin-top:4px;font-weight:400}
.page-body{padding:0 28px 40px}
.page-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.section-label{font-size:11px;font-weight:900;color:#bbb;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}

/* ─── CARDS ──────────────────────────────────────────────────────────────── */
.card{background:#fff;border:1px solid #e8e8e4;border-radius:12px;padding:20px}
.card-title{font-family:'Lato',sans-serif;font-size:15px;font-weight:900;margin-bottom:14px;letter-spacing:-.01em}

.grid{display:grid;gap:14px}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-2-1{grid-template-columns:minmax(0,2fr) minmax(0,1fr)}
@media (max-width:1200px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:900px){.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-2-1{grid-template-columns:1fr}}

/* ─── METRICS (fix dos valores cortados) ────────────────────────────────── */
.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:22px}
@media (max-width:1200px){.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:600px){.metrics-grid{grid-template-columns:1fr}}

.metric-card{
  background:#fff;border:1px solid #e8e8e4;border-radius:12px;
  padding:16px 18px;position:relative;overflow:hidden;min-width:0;
}
.metric-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--a,#ffe600)}
.metric-val{
  font-family:'Lato',sans-serif;font-size:22px;font-weight:900;color:var(--a,#1a1a1a);
  letter-spacing:-.02em;font-variant-numeric:tabular-nums;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;
}
.metric-lbl{font-size:10px;color:#999;text-transform:uppercase;letter-spacing:.08em;margin-top:6px;font-weight:700}
.metric-hint{font-size:11px;color:#bbb;margin-top:4px;font-weight:400}
.metric-card.dark{background:#1a1a1a;border-color:#1a1a1a}
.metric-card.dark .metric-val{color:#ffe600}
.metric-card.dark .metric-lbl{color:#fff7}
.metric-card.dark .metric-hint{color:#fff5}

/* ─── TABLES ─────────────────────────────────────────────────────────────── */
.table-wrap{background:#fff;border:1px solid #e8e8e4;border-radius:12px;overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;padding:11px 16px;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#999;background:#faf9f5;border-bottom:1px solid #e8e8e4}
tbody td{padding:13px 16px;border-bottom:1px solid #f0f0ec;font-size:13px;vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#fafaf7}
td.num{font-variant-numeric:tabular-nums;text-align:right}
th.num{text-align:right}

/* ─── STATUS PILL ────────────────────────────────────────────────────────── */
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:10px;font-weight:900;letter-spacing:.02em;text-transform:uppercase}
.pill::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor}
.pill-draft{background:#f4f4f5;color:#52525b}
.pill-sent{background:#dbeafe;color:#1e40af}
.pill-review{background:#fef3c7;color:#92400e}
.pill-approved{background:#d1fae5;color:#065f46}
.pill-rejected{background:#fee2e2;color:#991b1b}

.status-select{border:1px solid #e8e8e4;padding:5px 10px;border-radius:99px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;background:#fff;color:#1a1a1a;outline:none}

/* ─── FILTERS (chips) ────────────────────────────────────────────────────── */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.filter-btn{background:#fff;border:1px solid #e8e8e4;color:#666;padding:6px 14px;border-radius:99px;font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap;font-weight:700;display:inline-flex;align-items:center;gap:6px}
.filter-btn:hover{color:#1a1a1a;border-color:#ccc}
.filter-btn.on{background:#1a1a1a;border-color:#1a1a1a;color:#fff}
.filter-btn .c{font-size:10px;background:#0000000f;padding:1px 6px;border-radius:99px;font-weight:900}
.filter-btn.on .c{background:#ffffff22;color:#ffe600}

/* ─── SEARCH ─────────────────────────────────────────────────────────────── */
.search-bar{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e8e8e4;border-radius:8px;padding:8px 12px;min-width:260px}
.search-bar input{border:none;background:transparent;outline:none;width:100%;color:#1a1a1a;font-size:13px}
.search-bar .ico{color:#aaa;font-size:14px}

/* ─── MODAL ──────────────────────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:#0000006a;z-index:50;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);padding:20px}
.modal-box{background:#fff;border:1px solid #e8e8e4;border-radius:16px;width:560px;max-width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000015}
.modal-box.wide{width:880px}
.modal-head{padding:20px 24px;border-bottom:1px solid #f0f0ec;display:flex;justify-content:space-between;align-items:center}
.modal-ttl{font-family:'Lato',sans-serif;font-size:17px;font-weight:900;letter-spacing:-.01em}
.modal-body{padding:24px}
.modal-foot{padding:14px 24px;border-top:1px solid #f0f0ec;display:flex;justify-content:space-between;gap:8px;background:#faf9f5;border-radius:0 0 16px 16px}

/* ─── WIZARD ─────────────────────────────────────────────────────────────── */
.wizard{display:flex;gap:8px;margin-bottom:22px;flex-wrap:wrap}
.wiz-step{flex:1;min-width:180px;padding:11px 14px;border-radius:10px;background:#fff;border:1px solid #e8e8e4;display:flex;align-items:center;gap:10px;font-size:12px;font-weight:700;color:#888;cursor:pointer;transition:all .15s}
.wiz-step:hover{border-color:#ccc}
.wiz-step.active{background:#1a1a1a;color:#fff;border-color:#1a1a1a}
.wiz-step.done{background:#fff6b0;color:#1a1a1a;border-color:#ffe600}
.wiz-step .n{width:22px;height:22px;border-radius:50%;background:#f4f3ef;color:#888;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:11px;flex-shrink:0}
.wiz-step.active .n{background:#ffe600;color:#1a1a1a}
.wiz-step.done .n{background:#ffe600;color:#1a1a1a}

.wiz-nav{display:flex;justify-content:space-between;margin-top:22px;padding-top:18px;border-top:1px solid #e8e8e4;gap:10px;flex-wrap:wrap}

/* ─── FIELDS ─────────────────────────────────────────────────────────────── */
.row{display:grid;gap:12px}
.row-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.row-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.row-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:700px){.row-3,.row-4{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* ─── CATALOG PICKER ─────────────────────────────────────────────────────── */
.catalog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
@media (max-width:900px){.catalog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.catalog-card{padding:14px;border:1px solid #e8e8e4;border-radius:10px;cursor:pointer;transition:all .15s;background:#fff;display:flex;flex-direction:column;gap:6px;min-width:0}
.catalog-card:hover{border-color:#1a1a1a;transform:translateY(-1px);box-shadow:0 4px 12px #00000008}
.cat-tag{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:6px}
.cat-tag .dot{width:8px;height:8px;border-radius:50%}
.catalog-card .title{font-weight:900;font-size:14px;line-height:1.3;overflow:hidden;text-overflow:ellipsis}
.catalog-card .bottom{display:flex;justify-content:space-between;align-items:center;margin-top:4px;gap:6px}
.catalog-card .value{font-family:'Lato',sans-serif;font-weight:900;font-size:16px;letter-spacing:-.01em}
.catalog-card .billing-hint{font-size:10px;color:#999;text-transform:uppercase;letter-spacing:.04em;font-weight:700;white-space:nowrap}

/* ─── ITEM ROW ───────────────────────────────────────────────────────────── */
.item-row{background:#fff;border:1px solid #e8e8e4;border-radius:10px;padding:14px;margin-bottom:10px;display:grid;gap:10px}
.item-row-head{display:flex;align-items:center;gap:10px}
.item-row-head .idx{font-size:11px;color:#aaa;font-weight:900;width:24px}
.item-row-head .title-inp{flex:1;font-weight:900}
.item-row .totals-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding-top:8px;border-top:1px dashed #e8e8e4;font-weight:700}
details summary{cursor:pointer;font-size:11px;color:#888;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:4px 0}
details summary:hover{color:#1a1a1a}

/* ─── INSTALLMENTS ──────────────────────────────────────────────────────── */
.inst-head{display:grid;grid-template-columns:32px 1fr 1fr 1fr 32px;gap:8px;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.05em;color:#aaa;padding:0 6px 6px}
.inst-row{display:grid;grid-template-columns:32px 1fr 1fr 1fr 32px;gap:8px;align-items:center;padding:6px;background:#faf9f5;border-radius:8px;margin-bottom:5px}
.inst-row input{background:#fff;padding:8px 10px;border:1px solid #e8e8e4;border-radius:6px;font-size:13px;outline:none;min-width:0}
.inst-row input:focus{border-color:#ffe600}
.inst-row .num{text-align:center;color:#888;font-weight:900;font-size:12px}

/* ─── CLIENT CARDS ──────────────────────────────────────────────────────── */
.client-card{
  background:#fff;border:1px solid #e8e8e4;border-radius:12px;padding:16px;
  display:flex;flex-direction:column;gap:12px;transition:all .15s;min-width:0;
  min-height:150px;cursor:pointer;
}
.client-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000000d;border-color:#1a1a1a22}
.client-head{display:flex;align-items:flex-start;gap:10px}
.client-avatar{
  width:40px;height:40px;border-radius:10px;background:#ffe600;
  display:flex;align-items:center;justify-content:center;
  font-family:'Lato',sans-serif;font-weight:900;font-size:14px;color:#1a1a1a;flex-shrink:0;
}
.client-name{
  font-weight:900;font-size:14px;letter-spacing:-.01em;line-height:1.3;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.client-sub{
  font-size:11px;color:#999;margin-top:2px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.client-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.client-tag{
  font-size:10px;color:#666;background:#f4f3ef;padding:2px 8px;border-radius:99px;
  font-weight:700;letter-spacing:.02em;
}
.client-tag.muted-tag{color:#999;background:transparent;padding:2px 0}
.client-actions{display:flex;gap:4px;flex-shrink:0}
.client-meta{display:flex;gap:10px;font-size:10px;color:#999;margin-top:auto;padding-top:10px;border-top:1px solid #f0f0ec}
.client-meta .metric{display:flex;flex-direction:column;min-width:0;flex:1}
.client-meta .metric span{font-size:9px;color:#999;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.client-meta .metric b{color:#1a1a1a;font-size:13px;font-weight:900;font-family:'Lato',sans-serif;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.link-client{color:#1a1a1a;font-weight:700;text-decoration:none;border-bottom:1px dashed #ccc;padding-bottom:1px}
.link-client:hover{border-bottom-color:#1a1a1a;color:#000}

/* ─── ACTIVITY ──────────────────────────────────────────────────────────── */
.activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid #f0f0ec}
.activity-item:last-child{border:none}
.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0;background:#ffe600}
.activity-content{flex:1;font-size:13px;line-height:1.4;min-width:0}
.activity-time{font-size:11px;color:#bbb;margin-top:2px}

/* ─── USERS ─────────────────────────────────────────────────────────────── */
.user-row{display:flex;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid #f0f0ec}
.user-row:last-child{border:none}
.user-avatar{width:38px;height:38px;border-radius:50%;background:#1a1a1a;color:#ffe600;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;flex-shrink:0;letter-spacing:-.02em}
.user-info{flex:1;min-width:0}
.user-info .n{font-weight:900;font-size:14px;letter-spacing:-.01em}
.user-info .e{font-size:12px;color:#888}
.user-badge-inactive{font-size:10px;background:#fee2e2;color:#991b1b;padding:2px 8px;border-radius:99px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}

/* ─── EMPTY ──────────────────────────────────────────────────────────────── */
.empty{text-align:center;padding:60px 20px;color:#999}
.empty .emoji{font-size:38px;margin-bottom:12px;display:block;opacity:.6}
.empty h3{color:#1a1a1a;margin-bottom:6px;font-weight:900;font-family:'Lato',sans-serif;font-size:16px;letter-spacing:-.01em}

/* ─── UTILS ──────────────────────────────────────────────────────────────── */
.muted{color:#999}
.small{font-size:12px}
.flex{display:flex}
.ai-c{align-items:center}
.jc-sb{justify-content:space-between}
.gap-2{gap:8px}
.gap-3{gap:12px}
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}
.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}
.color-sw{width:32px;height:32px;border-radius:7px;cursor:pointer;border:3px solid transparent}
.color-sw.on{border-color:#1a1a1a}

.loading{padding:40px;text-align:center;color:#bbb}

.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:10px;background:#1a1a1a;color:#fff;font-size:13px;font-weight:700;z-index:100;box-shadow:0 6px 20px #00000033;animation:toast .3s ease}
.toast.success{background:#10b981}
.toast.error{background:#ef4444}
@keyframes toast{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ═══════════════════════════════════════════════════════════════════════════
   PREVIEW — tela (navegador)
   ═══════════════════════════════════════════════════════════════════════════ */
body.preview-page{background:#e8e8e4;margin:0;padding:0}
.preview-ui{
  max-width:794px;margin:24px auto 18px;padding:0 12px;
  display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  font-family:'Lato',sans-serif;
}
.preview-ui .title-box b{font-size:16px;display:block;font-weight:900;letter-spacing:-.01em;color:#1a1a1a}
.preview-ui .title-box small{font-size:11px;color:#666;font-weight:400}

.proposal-preview{
  background:#fff;color:#1a1a1a;font-family:'Lato',sans-serif;font-size:10pt;line-height:1.45;
  padding:40px 44px;max-width:794px;margin:0 auto 40px;box-sizing:border-box;
  box-shadow:0 4px 20px #00000012;border-radius:2px;font-weight:400;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PREVIEW — impressão (fallback se usuário fizer Cmd+P na página normal)
   A impressão principal acontece via /preview.php?print=1 em janela dedicada
   ═══════════════════════════════════════════════════════════════════════════ */
@media print{
  @page{size:A4;margin:14mm 12mm}
  html,body{background:#fff !important;margin:0 !important;padding:0 !important}

  /* Esconde UI do app */
  .sidebar,.page-header,.preview-ui,.no-print,
  .modal-bg,.toast,header,nav{display:none !important}

  /* Documento ocupa naturalmente a página */
  .proposal-preview{
    box-shadow:none !important;background:#fff !important;
    margin:0 !important;padding:0 !important;max-width:none !important;width:100% !important;
    min-height:0 !important;border-radius:0 !important;
    print-color-adjust:exact;-webkit-print-color-adjust:exact;color-adjust:exact;
  }

  /* Não quebra no meio */
  .pp-header,.pp-info-bar,.pp-total-bar,.pp-payment-block,.pp-obs,.pp-footer{
    page-break-inside:avoid;break-inside:avoid;
  }
  .pp-item-row{page-break-inside:avoid;break-inside:avoid}
  thead{display:table-header-group}

  .pp-total-bar .value,.pp-brand{
    print-color-adjust:exact !important;-webkit-print-color-adjust:exact !important;
  }
}

.pp-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;gap:20px}
.pp-title{font-family:'Lato',sans-serif;line-height:1.15;min-width:0}
.pp-title .pp-num{font-weight:300;color:#666;font-size:15pt}
.pp-title .pp-num b{font-weight:900;color:#1a1a1a;letter-spacing:-.01em}
.pp-title .pp-sub{font-weight:400;font-size:11pt;color:#666;text-transform:uppercase;letter-spacing:.05em;margin-top:4px;display:block}
.pp-brand{font-family:'Lato',sans-serif;font-weight:900;font-size:22pt;color:#ffe600;letter-spacing:-.03em;line-height:.9;flex-shrink:0}

.pp-info-bar{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid #d4d4d4;border-bottom:1px solid #d4d4d4;padding:10px 0;margin-bottom:22px;font-size:9pt;gap:8px}
.pp-info-bar .label{color:#666}
.pp-info-bar b{color:#1a1a1a;font-weight:700;margin-left:2px}

.pp-section-label{font-weight:900;font-size:10pt;margin:14px 0 8px;color:#1a1a1a;letter-spacing:-.01em}

.pp-item-table{width:100%;border-collapse:collapse;margin-bottom:4px}
.pp-item-table th{background:#f5f5f5;color:#666;font-weight:700;font-size:8.5pt;text-transform:uppercase;letter-spacing:.04em;padding:8px 10px;text-align:left;border-top:1px solid #d4d4d4;border-bottom:1px solid #d4d4d4}
.pp-item-table th.r,.pp-item-table td.r{text-align:right}
.pp-item-table th.c,.pp-item-table td.c{text-align:center}
.pp-item-table td{padding:9px 10px;font-size:9.5pt;font-weight:700;border-bottom:1px solid #eaeaea}
.pp-item-table td.item-num{width:32px;text-align:center;color:#999;font-weight:400}
.pp-item-table td.item-title small{font-weight:400;color:#666;margin-left:4px;font-size:8.5pt}
.pp-item-desc{font-weight:400;font-size:9pt;color:#333;white-space:pre-line;padding:8px 10px 14px;border-bottom:1px solid #eaeaea;line-height:1.55}
.pp-item-desc .h{font-weight:900;color:#1a1a1a;margin-top:8px;margin-bottom:2px;display:block;letter-spacing:-.01em}

.pp-total-bar{text-align:right;margin:18px 0 26px;padding-top:10px;border-top:2px solid #1a1a1a}
.pp-total-bar .sub{font-size:9pt;color:#666;margin-bottom:6px}
.pp-total-bar .label{font-size:10pt;color:#1a1a1a;font-weight:900;margin-right:12px}
.pp-total-bar .value{font-family:'Lato',sans-serif;font-size:14pt;font-weight:900;color:#1a1a1a;letter-spacing:-.02em;background:#ffe600;padding:3px 12px;border-radius:3px}

.pp-section-title{font-size:10pt;font-weight:900;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;color:#1a1a1a}

.pp-payment-table{width:100%;border-collapse:collapse;background:#f9f9f9;border:1px solid #eaeaea;border-radius:4px;overflow:hidden}
.pp-payment-table th{background:transparent;color:#1a1a1a;font-weight:900;font-size:9pt;padding:10px 14px;text-align:left;border-bottom:1px solid #eaeaea}
.pp-payment-table th.r{text-align:right}
.pp-payment-table td{padding:7px 14px;font-size:9.5pt;border-bottom:1px solid #eee;font-weight:400}
.pp-payment-table td.r{text-align:right}
.pp-payment-table tr:last-child td{border-bottom:none}
.pp-payment-table .first-col{color:#666;font-style:italic;font-size:9pt}

.pp-obs{margin-top:20px;padding:14px 16px;background:#fffbe6;border-left:3px solid #ffe600;font-size:9.5pt;line-height:1.55;color:#333;border-radius:0 4px 4px 0}

.pp-footer{margin-top:50px;display:flex;justify-content:space-between;font-size:8pt;color:#999;border-top:1px solid #eaeaea;padding-top:10px;gap:10px}

/* ═══════════════════════════════════════════════════════════════════════════
   SEARCHABLE SELECT
   ═══════════════════════════════════════════════════════════════════════════ */
.ss-wrap{position:relative;min-width:0}
.ss-trigger{
  width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:8px;
  cursor:pointer;background:#f9f9f7;font-weight:400;
}
.ss-trigger:hover{background:#fff}
.ss-trigger svg{flex-shrink:0;color:#999}
.ss-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.ss-placeholder{color:#999}
.ss-panel{
  position:absolute;z-index:20;top:calc(100% + 4px);left:0;right:0;
  background:#fff;border:1px solid #e0e0dc;border-radius:8px;
  box-shadow:0 8px 28px #00000018;overflow:hidden;
}
.ss-search{
  width:100%;padding:10px 12px;border:none;border-bottom:1px solid #f0f0ec;
  font-size:13px;outline:none;font-family:inherit;
}
.ss-list{max-height:280px;overflow-y:auto}
.ss-item{
  padding:9px 14px;font-size:13px;cursor:pointer;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.ss-item:hover{background:#f4f3ef}
.ss-item.on{background:#fff6b0;font-weight:700}
.ss-item.ss-clear{color:#999;font-style:italic;font-size:12px}
.ss-empty{padding:14px;text-align:center;color:#aaa;font-size:12px}

/* ═══════════════════════════════════════════════════════════════════════════
   NUMBERED PAGER
   ═══════════════════════════════════════════════════════════════════════════ */
.pg{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.pg-btn{
  min-width:34px;height:34px;padding:0 10px;
  background:#fff;border:1px solid #e8e8e4;border-radius:7px;
  font-size:13px;font-weight:700;color:#666;cursor:pointer;transition:all .15s;
  display:inline-flex;align-items:center;justify-content:center;
}
.pg-btn:hover:not(:disabled):not(.on){background:#f4f3ef;color:#1a1a1a;border-color:#ccc}
.pg-btn.on{background:#1a1a1a;border-color:#1a1a1a;color:#ffe600;cursor:default}
.pg-btn:disabled{opacity:.3;cursor:not-allowed}
.pg-sep{color:#aaa;font-size:13px;padding:0 4px}

/* ═══════════════════════════════════════════════════════════════════════════
   CLIENTS LIST VIEW
   ═══════════════════════════════════════════════════════════════════════════ */
.view-toggle{display:inline-flex;background:#fff;border:1px solid #e8e8e4;border-radius:8px;padding:2px;gap:2px}
.view-toggle button{
  padding:6px 12px;border-radius:6px;background:transparent;border:none;color:#888;
  font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:5px;
}
.view-toggle button.on{background:#1a1a1a;color:#ffe600}
.view-toggle svg{opacity:.9}

.clients-table td{padding:10px 14px;font-size:13px}
.clients-table .avatar-sm{
  width:28px;height:28px;border-radius:6px;background:#ffe600;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;font-size:11px;color:#1a1a1a;letter-spacing:-.02em;margin-right:8px;vertical-align:middle;
}
