:root{
  --bg:#f5f8fc;
  --surface:#ffffff;
  --surface-alt:#f8fbff;
  --text:#172b3a;
  --text-light:#5b6f82;
  --line:#e2e9f2;
  --accent:#0d3b66;
  --accent-ghost:#0d3b6620;
  --accent-strong:#0b2f50;
  --danger:#b42318;
  --danger-ghost:#ffe3de;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font:14px/1.6 "Segoe UI",Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}
.bg-gradient{background:linear-gradient(180deg,#f6faff 0%,#eef3fb 100%)}

/* Topbar */
.topbar{position:sticky;top:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;background:rgba(255,255,255,0.92);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(226,233,242,0.7);box-shadow:0 20px 40px rgba(15,41,94,0.05)}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{width:30px;height:30px}
.title{font-weight:700;font-size:16px}
.subtitle{font-size:12px;color:var(--text-light);letter-spacing:.02em}
.menu{display:flex;align-items:center;gap:10px}
.menu button{background:#fff;border:1px solid var(--line);color:var(--text);padding:8px 18px;border-radius:999px;cursor:pointer;font-weight:600;transition:all .2s}
.menu button.active,.menu button:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 6px 12px rgba(13,59,102,0.12)}
.menu .ghost{border-style:dashed;color:var(--text-light)}

/* Layout geral */
main{padding:24px;max-width:1280px;margin:auto}
.view{display:none}
.view.active{display:block}
h2{font-size:24px;margin:16px 0;color:var(--accent-strong)}
h3{font-size:18px;margin:0;color:var(--accent-strong)}
small{color:var(--text-light);font-size:12px}

.card{background:var(--surface);border:1px solid rgba(226,233,242,0.8);border-radius:18px;box-shadow:0 10px 30px rgba(13,59,102,0.06);padding:20px;margin:16px 0}
.card.full{grid-column:1/-1}

/* Form e botões */
label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-light)}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--text);font:inherit;transition:border .2s,box-shadow .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:#8bb1da;box-shadow:0 0 0 3px rgba(139,177,218,0.3)}
textarea{resize:vertical;min-height:80px}
.actions{display:flex;gap:12px;justify-content:flex-end;margin-top:18px;padding-top:12px;border-top:1px solid rgba(226,233,242,0.7);flex-wrap:wrap}
.btn-primary{background:var(--accent);border:1px solid var(--accent);color:#fff;font-weight:600;padding:10px 18px;border-radius:999px;cursor:pointer;transition:all .2s}
.btn-primary:hover{background:var(--accent-strong);border-color:var(--accent-strong);box-shadow:0 12px 24px rgba(13,59,102,0.2)}
.btn-secondary{background:#eaf2ff;border:1px solid transparent;color:var(--accent);font-weight:600;padding:9px 16px;border-radius:999px;cursor:pointer;transition:all .2s}
.btn-secondary:hover{border-color:#c9ddff;background:#dce8ff}
.btn-link{background:transparent;border:0;color:var(--accent);cursor:pointer;padding:0 2px;font-size:13px;font-weight:600}
.btn-danger{background:transparent;border:0;color:var(--danger);cursor:pointer;padding:8px 14px;border-radius:12px;font-weight:600}
.btn-danger:hover{background:var(--danger-ghost)}

/* Alertas */
.alert{background:#fff8e6;border:1px solid #ffebb6;color:#8a6d1d;border-radius:12px;padding:12px 16px;margin:12px 0}

/* Tabelas (mantém o resto do app coerente) */
.table-wrap{overflow:auto;border:1px solid rgba(226,233,242,0.9);border-radius:14px;background:var(--surface)}
table{width:100%;border-collapse:collapse;border-radius:14px;overflow:hidden}
thead tr{background:#edf3ff}
th,td{padding:12px 14px;text-align:left;border-bottom:1px solid rgba(226,233,242,0.9);font-size:13px;color:var(--text)}
tbody tr:hover{background:#f5f9ff}
tbody tr:last-child td{border-bottom:0}

/* Listas simples de cadastros */
.lista{list-style:none;margin:12px 0 0;padding:0;max-height:240px;overflow:auto}
.lista li{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px dashed var(--line)}
.lista li:last-child{border-bottom:0}

/* LOGIN — layout igual ao dos Indicadores */
.login-wrap{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 120px)}
.login-card{display:grid;grid-template-columns:1.1fr 1fr;background:#fff;border-radius:18px;border:1px solid var(--line);
  box-shadow:0 30px 80px rgba(13,59,102,0.18);overflow:hidden;max-width:880px;width:95%}
.login-left{background:radial-gradient(70% 100% at 30% 10%,#f1f7ff 0%,#ffffff 70%);display:flex;align-items:center;justify-content:center;padding:38px}
.login-logo{width:220px;max-width:80%}
.login-right{padding:34px 40px}
.login-form{display:grid;gap:16px;margin-top:12px}
.muted{color:var(--text-light)}
.small{font-size:12px}

/* Responsivo */
@media (max-width:960px){
  .login-card{grid-template-columns:1fr}
  .login-left{display:none}
  main{padding:16px}
}
