:root{
  --verde:#1a3b2e; --verde-claro:#2a5a45; --ouro:#c9a961; --ouro-claro:#e0c885;
  --bg:#f4f6f5; --card:#fff; --txt:#1f2724; --txt-sec:#5a6b63;
  --linha:#e3e8e6; --ok:#2e7d4f; --aviso:#c47f17; --erro:#c0392b;
  --sidebar:250px; --radius:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--txt);line-height:1.5;-webkit-text-size-adjust:100%}
a{color:var(--verde-claro);text-decoration:none}
h1,h2,h3{font-family:'Playfair Display',Georgia,serif;color:var(--verde);font-weight:700}
h1{font-size:1.5rem;margin-bottom:.25rem}
h2{font-size:1.2rem;margin:1.5rem 0 .75rem}

/* ---- Header topo ---- */
.topbar{position:fixed;top:0;left:0;right:0;height:60px;background:var(--verde);
  display:flex;align-items:center;gap:12px;padding:0 16px;z-index:40;color:#fff}
.topbar .logo{font-family:'Playfair Display',serif;font-weight:700;color:var(--ouro);font-size:1.15rem}
.topbar .spacer{flex:1}
.topbar a{color:#fff}
.burger{background:none;border:0;color:#fff;font-size:1.6rem;cursor:pointer;line-height:1;
  min-width:44px;min-height:44px;display:none}

/* ---- Sidebar ---- */
.sidebar{position:fixed;top:60px;bottom:0;left:0;width:var(--sidebar);background:var(--verde);
  overflow-y:auto;z-index:30;padding:16px 0;transition:transform .25s ease}
.sidebar a{display:block;color:#cfe0d8;padding:12px 20px;font-size:.95rem;border-left:3px solid transparent}
.sidebar a:hover,.sidebar a.ativo{background:rgba(255,255,255,.07);color:#fff;border-left-color:var(--ouro)}
.sidebar .grupo{color:var(--ouro);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;padding:16px 20px 6px}
.overlay{display:none;position:fixed;inset:60px 0 0 0;background:rgba(0,0,0,.45);z-index:25}

/* ---- Conteúdo ---- */
.conteudo{padding:90px 20px 40px;margin-left:var(--sidebar)}

/* ---- Cards / grids ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.card{background:var(--card);border:1px solid var(--linha);border-radius:var(--radius);padding:18px}
.card .rotulo{color:var(--txt-sec);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}
.card .valor{font-size:1.6rem;font-weight:700;color:var(--verde);margin-top:4px}
.card .valor.neg{color:var(--erro)} .card .valor.pos{color:var(--ok)}

/* ---- Tabelas ---- */
.tabela-wrap{overflow-x:auto;background:var(--card);border:1px solid var(--linha);border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;min-width:560px}
th,td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--linha);font-size:.9rem}
th{background:#eef2f0;color:var(--verde);font-weight:600;white-space:nowrap}
tr:last-child td{border-bottom:0}

/* ---- Badges ---- */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}
.b-pago{background:#e3f3e9;color:var(--ok)} .b-pendente{background:#fdecea;color:var(--erro)}
.b-parcial{background:#fdf3e0;color:var(--aviso)} .b-anulada{background:#eee;color:#888}

/* ---- Formulários ---- */
.form-grid{display:grid;gap:14px;max-width:560px}
label{font-size:.85rem;color:var(--txt-sec);display:block;margin-bottom:4px}
input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--linha);border-radius:8px;
  font-size:1rem;font-family:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--verde-claro)}
textarea{min-height:90px;resize:vertical}

/* ---- Botões (min 44px touch) ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:44px;
  padding:0 18px;border:0;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;background:var(--verde);color:#fff}
.btn:hover{background:var(--verde-claro)}
.btn-ouro{background:var(--ouro);color:var(--verde)} .btn-ouro:hover{background:var(--ouro-claro)}
.btn-sm{min-height:34px;padding:0 12px;font-size:.82rem}
.btn-link{background:none;color:var(--verde-claro);padding:0;min-height:auto}

.aviso{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem}
.aviso.sucesso{background:#e3f3e9;color:var(--ok)} .aviso.erro{background:#fdecea;color:var(--erro)}

.topo-acao{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.seletor-cond{padding:8px 12px;border-radius:8px;border:1px solid var(--linha)}

/* ---- Login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--verde)}
.login-box{background:#fff;border-radius:16px;padding:32px;width:100%;max-width:380px}
.login-box .logo{font-family:'Playfair Display',serif;color:var(--verde);font-size:1.8rem;text-align:center;margin-bottom:4px}
.login-box .sub{text-align:center;color:var(--txt-sec);font-size:.85rem;margin-bottom:24px}

/* ===== MOBILE ===== */
@media (max-width:1024px){
  .burger{display:block}
  .sidebar{transform:translateX(-100%)}
  .sidebar.aberta{transform:translateX(0)}
  .overlay.aberta{display:block}
  .conteudo{margin-left:0}
}
@media (max-width:480px){
  .cards{grid-template-columns:1fr}
  .conteudo{padding:80px 14px 32px}
  h1{font-size:1.3rem}
}
/* ===== MODAL GLOBAL ===== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:100;
  align-items:center;justify-content:center;padding:20px}
.modal-overlay.aberto{display:flex}
.modal-box{background:#fff;border-radius:16px;padding:28px;max-width:440px;width:100%;text-align:center;
  box-shadow:0 20px 60px rgba(0,0,0,.3);animation:cgPop .18s ease}
@keyframes cgPop{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.modal-icone{font-size:3rem;line-height:1;margin-bottom:8px}
.modal-box h3{color:var(--verde);margin-bottom:8px}
.modal-box p{color:var(--txt-sec);margin-bottom:16px}
.modal-box #cgExtra:empty{display:none}
.modal-box #cgExtra{margin-bottom:16px;text-align:left}
.modal-acoes{display:flex;gap:10px;justify-content:center}
/* Inputs dentro do modal global */
.modal-box #cgExtra label{font-size:.85rem;color:var(--txt-sec);display:block;margin-bottom:6px}
.modal-box #cgExtra input,
.modal-box #cgExtra textarea,
.modal-box #cgExtra select{width:100%;padding:11px 12px;border:1px solid var(--linha);
  border-radius:8px;font-size:1rem;font-family:inherit;background:#fff}
.modal-box #cgExtra input:focus,
.modal-box #cgExtra textarea:focus{outline:0;border-color:var(--verde-claro)}