:root {
    --petroleo: #0f6b6e; --petroleo-escuro: #095255; --petroleo-claro: #158589;
    --branco: #ffffff; --cinza-claro: #f3f4f6; --cinza-medio: #e5e7eb;
    --cinza-escuro: #374151; --cinza-texto: #4b5563;
    --verde: #10b981; --amarelo: #f59e0b; --vermelho: #ef4444;
    --sombra-suave: 0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);
    --sombra-media: 0 4px 6px rgba(0,0,0,0.05),0 2px 4px rgba(0,0,0,0.04);
    --sombra-elevada: 0 10px 25px rgba(0,0,0,0.08),0 4px 10px rgba(0,0,0,0.05);
    --borda: 1px solid #e5e7eb; --raio: 10px; --raio-input: 8px;
    --transicao: 0.2s ease; --fonte: 'Segoe UI','Inter',system-ui,-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--fonte);background:#f8f9fb;color:var(--cinza-escuro);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}
.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0c5e61 0%,#0a4f52 100%);padding:20px}
.login-card{background:#fff;border-radius:var(--raio);box-shadow:var(--sombra-elevada);padding:40px 36px;width:100%;max-width:420px;text-align:center}
.login-card .logo{font-size:1.8rem;font-weight:700;color:var(--petroleo);letter-spacing:.5px;margin-bottom:6px}
.login-card .logo span{color:#7dd3d8;font-size:.8rem;display:block;letter-spacing:2px;margin-top:2px}
.login-card h2{font-size:1.2rem;margin:16px 0 20px;color:var(--cinza-escuro);font-weight:600}
.login-campo{margin-bottom:18px;text-align:left}
.login-campo label{font-size:.82rem;font-weight:600;color:var(--cinza-escuro);display:block;margin-bottom:5px}
.login-campo input{width:100%;padding:12px 14px;border:var(--borda);border-radius:var(--raio-input);font-size:.95rem;font-family:var(--fonte);background:#fafbfc;transition:all var(--transicao)}
.login-campo input:focus{outline:none;border-color:var(--petroleo-claro);box-shadow:0 0 0 3px rgba(15,107,110,.08);background:#fff}
.login-btn{width:100%;padding:12px;background:var(--petroleo);color:#fff;border:none;border-radius:var(--raio-input);font-weight:700;font-size:1rem;cursor:pointer;transition:all var(--transicao);letter-spacing:.3px;margin-top:8px;font-family:var(--fonte)}
.login-btn:hover{background:var(--petroleo-escuro);box-shadow:var(--sombra-media)}.login-btn:disabled{opacity:0.7;cursor:wait}
.login-erro{color:var(--vermelho);font-size:.8rem;margin-top:8px;display:none}.login-erro.visivel{display:block}
.app-container{display:none}.app-container.logado{display:flex}
.sidebar{width:260px;min-width:260px;background:linear-gradient(180deg,#0c5e61 0%,#0a4f52 100%);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;box-shadow:2px 0 20px rgba(0,0,0,.15);transition:transform var(--transicao)}
.sidebar-header{padding:28px 22px 20px;border-bottom:1px solid rgba(255,255,255,.12);text-align:center}
.sidebar-header .logo{font-size:1.5rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.sidebar-header .logo span{color:#7dd3d8;font-weight:400;font-size:.75rem;display:block;letter-spacing:2px;margin-top:2px}
.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}
.sidebar-nav button{display:flex;align-items:center;gap:10px;width:100%;padding:13px 22px;border:none;background:transparent;color:rgba(255,255,255,.8);font-size:.9rem;cursor:pointer;transition:all var(--transicao);text-align:left;font-family:var(--fonte);font-weight:500}
.sidebar-nav button:hover{background:rgba(255,255,255,.08);color:#fff}
.sidebar-nav button.ativo{background:rgba(255,255,255,.14);color:#fff;font-weight:600;box-shadow:inset 3px 0 0 #7dd3d8}
.sidebar-footer{padding:14px 22px;border-top:1px solid rgba(255,255,255,.12);font-size:.7rem;color:rgba(255,255,255,.5);text-align:center}
.logout-btn{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 16px;border-radius:20px;font-size:.75rem;cursor:pointer;margin-top:10px;transition:all var(--transicao);font-family:var(--fonte);width:100%;justify-content:center}
.logout-btn:hover{background:rgba(255,255,255,.2)}.acoes-dados{display:flex;gap:6px;margin-bottom:6px;justify-content:center;flex-wrap:wrap}
.btn-dados{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:#fff;padding:5px 10px;border-radius:14px;font-size:.65rem;cursor:pointer;transition:all var(--transicao);font-family:var(--fonte)}.btn-dados:hover{background:rgba(255,255,255,.2)}
.main{flex:1;margin-left:260px;padding:28px 32px;min-height:100vh;transition:margin-left var(--transicao)}
.secao{display:none}.secao.ativa{display:block}
.cabecalho-secao{margin-bottom:24px}.cabecalho-secao h1{font-size:1.7rem;font-weight:700;color:#1a1a1a}.cabecalho-secao p{font-size:.85rem;color:#6b7280;margin-top:2px}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:10px;margin-bottom:24px}
.card-stat{background:#fff;border-radius:var(--raio);padding:14px 16px;box-shadow:var(--sombra-suave);border:var(--borda);transition:all var(--transicao);display:flex;align-items:center;gap:8px}
.card-stat:hover{box-shadow:var(--sombra-media);transform:translateY(-1px)}
.card-stat .icone-stat{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.card-stat .info-stat .valor{font-size:1.2rem;font-weight:700;color:#1a1a1a;line-height:1}
.card-stat .info-stat .rotulo{font-size:.68rem;color:#6b7280;margin-top:2px;font-weight:500}
.bg-azul-claro{background:#e0f2f3;color:var(--petroleo)}.bg-verde-claro{background:#d1fae5;color:#065f46}.bg-amarelo-claro{background:#fef3c7;color:#92400e}.bg-vermelho-claro{background:#fee2e2;color:#991b1b}.bg-cinza-claro-stat{background:#e5e7eb;color:#4b5563}
.form-container{background:#fff;border-radius:var(--raio);padding:24px 26px;box-shadow:var(--sombra-suave);border:var(--borda)}
.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.form-grupo{display:flex;flex-direction:column;gap:4px}.form-grupo.span-2{grid-column:span 2}
.form-grupo label{font-size:.8rem;font-weight:600;color:var(--cinza-escuro)}.form-grupo label .obrigatorio{color:#ef4444;margin-left:2px}
.form-grupo input,.form-grupo select,.form-grupo textarea{padding:9px 12px;border:var(--borda);border-radius:var(--raio-input);font-size:.88rem;font-family:var(--fonte);transition:all var(--transicao);background:#fafbfc;color:var(--cinza-escuro);width:100%}
.form-grupo input:focus,.form-grupo select:focus,.form-grupo textarea:focus{outline:none;border-color:var(--petroleo-claro);box-shadow:0 0 0 3px rgba(15,107,110,.08);background:#fff}
.form-grupo textarea{resize:vertical;min-height:70px}
.form-secao-titulo{font-size:.9rem;font-weight:700;color:#1a1a1a;margin:16px 0 10px;padding-bottom:6px;border-bottom:2px solid #e5e7eb;grid-column:1/-1}
.btn{padding:10px 20px;border-radius:var(--raio-input);font-weight:600;font-size:.84rem;cursor:pointer;border:none;transition:all var(--transicao);font-family:var(--fonte);display:inline-flex;align-items:center;gap:6px}
.btn-primario{background:var(--petroleo);color:#fff;box-shadow:var(--sombra-suave)}.btn-primario:hover{background:var(--petroleo-escuro)}
.btn-secundario{background:#fff;color:var(--cinza-escuro);border:var(--borda)}.btn-secundario:hover{background:#f9fafb}
.btn-perigo{background:#fff;color:#dc2626;border:1px solid #fca5a5}.btn-perigo:hover{background:#fef2f2}
.btn-pequeno{padding:6px 10px;font-size:.74rem;border-radius:6px}.btn-icone{width:32px;height:32px;padding:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.95rem}
.btn-whatsapp{background:#25D366;color:#fff;border:none}.btn-whatsapp:hover{background:#1ebe57}
.botoes-form{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;grid-column:1/-1}
.barra-pesquisa{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;background:#fff;padding:14px 16px;border-radius:var(--raio);box-shadow:var(--sombra-suave);border:var(--borda);align-items:flex-end}
.barra-pesquisa .campo-pesquisa{flex:1;min-width:160px;display:flex;flex-direction:column;gap:3px}
.barra-pesquisa .campo-pesquisa label{font-size:.7rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.4px}
.barra-pesquisa input,.barra-pesquisa select{padding:8px 12px;border:var(--borda);border-radius:var(--raio-input);font-size:.85rem;font-family:var(--fonte);background:#fafbfc}
.tabela-container{background:#fff;border-radius:var(--raio);box-shadow:var(--sombra-suave);border:var(--borda);overflow:hidden}
.tabela-wrapper{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.8rem;min-width:650px}
table thead{background:#f8fafb;border-bottom:2px solid #e5e7eb}
table thead th{padding:10px 12px;text-align:left;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.4px;color:#6b7280;white-space:nowrap}
table tbody tr{border-bottom:1px solid #f3f4f6;transition:background var(--transicao)}table tbody tr:hover{background:#f8fafb}
table tbody td{padding:10px 12px;vertical-align:middle;color:var(--cinza-escuro)}
.badge-status{display:inline-block;padding:4px 8px;border-radius:16px;font-size:.68rem;font-weight:700;text-transform:uppercase}
.badge-pendente{background:#d1fae5;color:#065f46}.badge-parcial{background:#fef3c7;color:#92400e}.badge-pago{background:#fee2e2;color:#991b1b}
.acoes-cell{display:flex;gap:3px;flex-wrap:wrap}.sem-dados{text-align:center;padding:30px;color:#9ca3af;font-style:italic}
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.modal-overlay.visivel{display:flex}
.modal{background:#fff;border-radius:var(--raio);padding:24px 26px;width:90%;max-width:650px;max-height:85vh;overflow-y:auto;box-shadow:var(--sombra-elevada)}
.modal h2{font-size:1.2rem;margin-bottom:14px;color:#1a1a1a}
.modal-fechar{float:right;background:none;border:none;font-size:1.4rem;cursor:pointer;color:#9ca3af;transition:color var(--transicao);line-height:1}.modal-fechar:hover{color:#374151}
.modal-detalhes{display:grid;grid-template-columns:1fr 1fr;gap:10px;font-size:.82rem}
.modal-detalhes .item-detalhe{padding:6px 0;border-bottom:1px solid #f3f4f6}
.modal-detalhes .item-detalhe strong{display:block;font-size:.68rem;text-transform:uppercase;color:#6b7280;letter-spacing:.3px;margin-bottom:1px}
.modal-detalhes .item-detalhe span{color:#1a1a1a;font-weight:500}
.modal-acoes{display:flex;gap:8px;margin-top:16px;justify-content:flex-end;flex-wrap:wrap}
.toast{position:fixed;bottom:24px;right:24px;background:#1a1a1a;color:#fff;padding:10px 18px;border-radius:8px;font-size:.82rem;font-weight:600;z-index:300;box-shadow:var(--sombra-elevada);animation:slideIn .3s ease}
@keyframes slideIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.toast.sucesso{background:#065f46}.toast.erro{background:#991b1b}
@media(max-width:768px){.sidebar{width:220px;min-width:220px;transform:translateX(-100%)}.sidebar.aberta{transform:translateX(0)}.main{margin-left:0;padding:14px 12px}.form-grid{grid-template-columns:1fr}.form-grupo.span-2{grid-column:span 1}.grid-cards{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px}.card-stat{padding:10px 12px;gap:6px}.card-stat .icone-stat{width:32px;height:32px;font-size:.9rem}.card-stat .info-stat .valor{font-size:1rem}.barra-pesquisa{flex-direction:column;gap:8px;padding:10px 12px}.modal-detalhes{grid-template-columns:1fr}.btn-menu-mobile{display:flex!important}.tabela-wrapper table{min-width:550px;font-size:.7rem}}
.btn-menu-mobile{display:none;position:fixed;top:10px;left:10px;z-index:150;background:var(--petroleo);color:#fff;border:none;border-radius:50%;width:38px;height:38px;font-size:1.2rem;cursor:pointer;align-items:center;justify-content:center;box-shadow:var(--sombra-media)}
@media(min-width:769px){.sidebar{transform:translateX(0)!important}}
.tabs-relatorio{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.summary-row{background:#f0fdf4;font-weight:700}
.exportar-opcoes{display:none;position:absolute;top:100%;right:0;background:#fff;border:var(--borda);border-radius:var(--raio);box-shadow:var(--sombra-media);z-index:10;min-width:140px}
.exportar-opcoes.visivel{display:block}.exportar-opcoes button{display:block;width:100%;padding:9px 14px;border:none;background:none;text-align:left;cursor:pointer;font-family:var(--fonte);font-size:.8rem}.exportar-opcoes button:hover{background:var(--cinza-claro)}
.campo-novo{background:#fffbeb;border:1px dashed #f59e0b;padding:8px;border-radius:6px;margin-top:3px;display:none}.campo-novo.visivel{display:block}
.grafico-container{background:#fff;border-radius:var(--raio);padding:16px;box-shadow:var(--sombra-suave);border:var(--borda);margin-bottom:16px}
.grafico-barras{display:flex;align-items:flex-end;gap:6px;height:180px;padding:8px 0;border-bottom:2px solid #e5e7eb;overflow-x:auto}
.grafico-barras .barra-item{flex:1;min-width:36px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.grafico-barras .barra{width:100%;max-width:50px;background:linear-gradient(180deg,var(--petroleo-claro),var(--petroleo));border-radius:3px 3px 0 0;transition:all var(--transicao);min-height:3px}
.grafico-barras .barra-label{font-size:.6rem;color:#6b7280;margin-top:3px;text-align:center;word-break:break-all}
.grafico-barras .barra-valor{font-size:.65rem;font-weight:700;color:var(--cinza-escuro);margin-bottom:3px}
.saldo-info{background:#f0fdf4;border:1px solid #10b981;border-radius:6px;padding:8px 12px;font-size:.8rem;color:#065f46;margin-top:3px}
@media(max-width:480px){.grid-cards{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.card-stat{padding:8px 10px}.card-stat .icone-stat{width:28px;height:28px;font-size:.8rem}.card-stat .info-stat .valor{font-size:.9rem}}