:root{
  --azul:#0b3d5c;
  --azul-claro:#1565a0;
  --ciano:#1aa7b3;
  --fundo:#f3f6f9;
  --card:#ffffff;
  --texto:#1b2733;
  --suave:#64748b;
  --borda:#e2e8f0;
  --verde:#15803d;
  --verde-bg:#dcfce7;
  --amarelo:#a16207;
  --amarelo-bg:#fef9c3;
  --vermelho:#b91c1c;
  --vermelho-bg:#fee2e2;
  --sombra:0 1px 3px rgba(15,40,60,.08),0 6px 18px rgba(15,40,60,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--fundo);color:var(--texto);font-size:15px;line-height:1.45;
}
a{color:var(--azul-claro)}

/* ---------- Topo ---------- */
header.topo{
  background:linear-gradient(120deg,var(--azul),var(--azul-claro));
  color:#fff;padding:14px 18px;display:flex;align-items:center;gap:12px;
  position:sticky;top:0;z-index:20;box-shadow:var(--sombra);
}
.topo .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:20px}
.topo .logo .anchor{font-size:22px}
.topo .sub{font-size:12px;opacity:.85;font-weight:400}
.topo .appbrand{font-size:10px;font-weight:700;opacity:.7;letter-spacing:.6px;margin-top:1px}
.topo .espaco{flex:1}
.topo .usuario{font-size:13px;opacity:.9}
.topo button.sair{background:rgba(255,255,255,.15);color:#fff;border:0;padding:7px 12px}
.sync{font-size:11px;font-weight:700;padding:4px 9px;border-radius:20px;white-space:nowrap}
.sync.ok{background:rgba(220,252,231,.95);color:#15803d}
.sync.syncing{background:rgba(254,249,195,.95);color:#a16207}
.sync.err{background:rgba(254,226,226,.95);color:#b91c1c}
.sync.off{background:rgba(255,255,255,.2);color:#fff}
.itens-tab .estrela{color:#a16207;background:none;border:0;font-size:18px;padding:2px 6px;line-height:1}
/* Itens do orçamento (layout responsável, legível no celular) */
.item-linha{border:1px solid var(--borda);border-radius:10px;padding:9px;margin-bottom:8px;background:#fff}
.item-linha .i-desc{width:100%;margin-bottom:8px;font-size:15px}
.item-row2{display:flex;align-items:flex-end;gap:8px}
.item-row2 .campo{display:flex;flex-direction:column}
.item-row2 .campo label{font-size:10px;color:var(--suave);margin-bottom:3px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.item-row2 .campo .num{width:100%;text-align:right;font-size:15px;padding:9px 8px}
.item-row2 .campo:nth-child(1){flex:1;min-width:56px}
.item-row2 .campo:nth-child(2){flex:1.4;min-width:78px}
.item-row2 .campo.total{flex:1.1;align-items:flex-end;min-width:78px}
.item-row2 .campo.total .col-tot{color:var(--azul);font-size:15px;padding-bottom:9px}
.item-row2 .estrela{color:#a16207;background:none;border:0;font-size:22px;padding:6px 4px;line-height:1;align-self:center}
.item-row2 .x{color:var(--vermelho);background:none;border:0;font-size:22px;padding:6px 4px;line-height:1;align-self:center}
.pix-item{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--borda)}
.pix-item span{flex:1}
.pix-pct{width:52px;text-align:right;padding:6px 7px}
#pix-qr img,#pix-qr canvas{border:6px solid #fff;border-radius:8px}
.comprovantes{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.comprovantes .thumb{position:relative;display:inline-block}
.comprovantes .thumb img{width:74px;height:74px;object-fit:cover;border-radius:8px;border:1px solid var(--borda)}
.comprovantes .thumb .x{position:absolute;top:-7px;right:-7px;background:var(--vermelho);color:#fff;border:0;border-radius:50%;width:21px;height:21px;font-size:14px;line-height:1;cursor:pointer;padding:0}
/* Ajuda */
.ajuda h3{color:var(--azul);font-size:16px;margin:18px 0 6px}
.ajuda p{margin:6px 0;color:var(--texto)}
.ajuda ol,.ajuda ul{margin:6px 0 6px 20px}
.ajuda li{margin:4px 0}

/* ---------- Navegacao ---------- */
nav.abas{
  background:var(--card);display:flex;gap:4px;padding:6px 12px;
  border-bottom:1px solid var(--borda);position:sticky;top:54px;z-index:15;overflow-x:auto;
}
nav.abas button{
  background:transparent;border:0;color:var(--suave);font-weight:600;
  padding:10px 14px;border-radius:8px;white-space:nowrap;cursor:pointer;font-size:14px;
}
nav.abas button.ativa{background:var(--fundo);color:var(--azul)}

/* ---------- Conteudo ---------- */
main{max-width:920px;margin:0 auto;padding:18px 14px 80px}
.titulo-linha{display:flex;align-items:center;gap:10px;margin:4px 0 16px}
.titulo-linha h2{margin:0;font-size:20px;color:var(--azul)}
.titulo-linha .espaco{flex:1}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--borda);border-radius:12px;
  box-shadow:var(--sombra);padding:16px;margin-bottom:14px}
.card h3{margin:0 0 10px;font-size:16px}
.lista-vazia{text-align:center;color:var(--suave);padding:32px 12px}
.lista-vazia .emoji{font-size:34px;display:block;margin-bottom:8px}

/* item de lista (cliente/orcamento) */
.item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--borda);
  border-radius:10px;margin-bottom:8px;background:#fff;cursor:pointer;transition:.12s}
.item:hover{border-color:var(--ciano);box-shadow:var(--sombra)}
.item .av{width:42px;height:42px;border-radius:10px;background:var(--fundo);
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.item .info{flex:1;min-width:0}
.item .info b{display:block;font-size:15px}
.item .info small{color:var(--suave);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.item .valor{font-weight:700;color:var(--azul);white-space:nowrap}

/* ---------- Formularios ---------- */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid .full{grid-column:1 / -1}
@media(max-width:560px){.grid{grid-template-columns:1fr}}
label{display:block;font-size:12px;font-weight:600;color:var(--suave);margin-bottom:4px}
input,select,textarea{
  width:100%;padding:10px 11px;border:1px solid var(--borda);border-radius:9px;
  font-size:15px;font-family:inherit;background:#fff;color:var(--texto)}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--ciano);
  box-shadow:0 0 0 3px rgba(26,167,179,.15)}
textarea{resize:vertical;min-height:64px}

/* ---------- Botoes ---------- */
button{cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;
  border:1px solid var(--borda);background:#fff;color:var(--texto);
  padding:10px 14px;border-radius:9px;transition:.12s}
button:hover{filter:brightness(.98)}
button.primario{background:var(--azul);color:#fff;border-color:var(--azul)}
button.ciano{background:var(--ciano);color:#fff;border-color:var(--ciano)}
button.verde{background:var(--verde);color:#fff;border-color:var(--verde)}
button.zap{background:#25d366;color:#fff;border-color:#25d366}
button.fantasma{background:transparent}
button.perigo{color:var(--vermelho);border-color:var(--vermelho-bg);background:var(--vermelho-bg)}
button.pequeno{padding:6px 10px;font-size:13px}
.acoes{display:flex;gap:8px;flex-wrap:wrap}
.fab{position:fixed;right:18px;bottom:18px;background:var(--ciano);color:#fff;
  border:0;width:56px;height:56px;border-radius:50%;font-size:28px;line-height:1;
  box-shadow:0 6px 20px rgba(26,167,179,.5);z-index:25}

/* ---------- Tags de status ---------- */
.tag{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}
.tag.rascunho{background:var(--fundo);color:var(--suave)}
.tag.enviado{background:#dbeafe;color:#1d4ed8}
.tag.aprovado{background:var(--amarelo-bg);color:var(--amarelo)}
.tag.pago{background:var(--verde-bg);color:var(--verde)}
.tag.cancelado{background:var(--vermelho-bg);color:var(--vermelho)}

/* ---------- Tabela de itens do orcamento ---------- */
.itens-tab{width:100%;border-collapse:collapse;margin-top:6px}
.itens-tab th{font-size:11px;text-transform:uppercase;color:var(--suave);text-align:left;padding:6px 6px}
.itens-tab td{padding:4px 6px;border-top:1px solid var(--borda);vertical-align:middle}
.itens-tab input{padding:7px 8px}
.itens-tab .num{text-align:right}
.itens-tab .col-qtd{width:74px}
.itens-tab .col-preco{width:120px}
.itens-tab .col-tot{width:110px;text-align:right;font-weight:600;white-space:nowrap}
.itens-tab .col-x{width:34px;text-align:center}
.itens-tab .x{color:var(--vermelho);background:none;border:0;font-size:18px;padding:2px 6px}

/* totais */
.totais{margin-top:12px;border-top:2px solid var(--borda);padding-top:10px}
.totais .ln{display:flex;justify-content:space-between;padding:3px 0;color:var(--suave)}
.totais .ln.grande{font-size:20px;font-weight:800;color:var(--azul)}
.totais .ln.grande span:last-child{color:var(--verde)}
.totais input{width:130px;text-align:right}

/* ---------- Modal ---------- */
.modal-fundo{position:fixed;inset:0;background:rgba(11,40,60,.45);z-index:40;
  display:flex;align-items:flex-start;justify-content:center;padding:24px 14px;overflow:auto}
.modal{background:#fff;border-radius:14px;max-width:640px;width:100%;padding:20px;box-shadow:var(--sombra)}
.modal h3{margin-top:0}
.modal .fechar{position:absolute}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(140deg,var(--azul),var(--ciano));padding:20px}
.login-box{background:#fff;border-radius:16px;padding:30px;max-width:380px;width:100%;box-shadow:var(--sombra)}
.login-box .marca{text-align:center;margin-bottom:18px}
.login-box .marca .anchor{font-size:40px}
.login-box .marca h1{margin:6px 0 0;color:var(--azul);font-size:24px}
.login-box .marca p{margin:2px 0 0;color:var(--suave);font-size:13px}

/* aviso de modo local */
.banner{background:var(--amarelo-bg);color:var(--amarelo);font-size:13px;
  padding:8px 14px;text-align:center;border-bottom:1px solid #fde68a}

.dica{font-size:12px;color:var(--suave);margin-top:6px}
.spinner{width:34px;height:34px;margin:16px auto 0;border:4px solid var(--borda);border-top-color:var(--ciano);border-radius:50%;animation:girar .8s linear infinite}
@keyframes girar{to{transform:rotate(360deg)}}
.erro{color:var(--vermelho);font-size:13px;margin-top:8px}
.ok{color:var(--verde);font-size:13px;margin-top:8px}
