:root{
  --bg:#f6f7fb; --card:#fff; --ink:#1f2430; --soft:#5b6577; --line:#e7eaf2;
  --accent:#3b6ef5; --accent-soft:#eaf0ff; --green:#1faa73; --amber:#e08a1e;
  --rose:#d6587a; --radius:12px; --shadow:0 1px 3px rgba(20,30,60,.06),0 6px 20px rgba(20,30,60,.05);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;line-height:1.5}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* Topbar */
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:12px;
  background:#11161f;color:#fff;padding:12px 18px}
.topbar .brand{font-weight:700}
.topbar .who{margin-left:auto;font-size:13px;opacity:.85}
.topbar .who a{color:#9fc0ff}
.burger{display:none;font-size:20px;cursor:pointer;user-select:none}

/* Layout */
.shell{display:flex;min-height:calc(100vh - 49px)}
.side{flex:0 0 230px;background:var(--card);border-right:1px solid var(--line);padding:14px 10px}
.side a{display:block;padding:10px 12px;border-radius:10px;color:var(--ink);margin-bottom:2px;font-size:14.5px}
.side a:hover{background:var(--accent-soft);text-decoration:none}
.side a.on{background:var(--accent-soft);color:var(--accent);font-weight:600}
.content{flex:1;padding:24px 28px;max-width:1100px}
.page-title{font-size:24px;margin:0 0 18px}

/* Cards / dashboard */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:24px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.stat .n{font-size:30px;font-weight:700}
.stat .l{color:var(--soft);font-size:13px;margin-top:2px}
.stat a{font-size:13px}

/* Tabelas */
.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.toolbar .spacer{flex:1}
table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
th,td{text-align:left;padding:11px 14px;border-top:1px solid var(--line);font-size:14px}
th{background:#fafbff;color:var(--soft);font-size:12px;text-transform:uppercase;letter-spacing:.4px}
tr:first-child td{border-top:none}
tbody tr:hover{background:#fafbff}

/* Badges */
.badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:99px}
.b-green{background:#e6f6ef;color:var(--green)}
.b-blue{background:var(--accent-soft);color:var(--accent)}
.b-amber{background:#fdf2e0;color:var(--amber)}
.b-rose{background:#fbeaf0;color:var(--rose)}
.b-gray{background:#eef0f5;color:var(--soft)}

/* Botões */
.btn{display:inline-block;background:var(--accent);color:#fff;border:none;padding:9px 16px;
  border-radius:10px;font-size:14px;cursor:pointer;font-weight:600}
.btn:hover{text-decoration:none;filter:brightness(.95)}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.danger{background:var(--rose)}
.btn.sm{padding:5px 10px;font-size:12.5px}

/* Formulários */
form.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);max-width:640px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;color:var(--soft);margin-bottom:5px;font-weight:600}
.field input,.field select,.field textarea{width:100%;padding:9px 11px;border:1px solid var(--line);
  border-radius:9px;font-size:14px;font-family:inherit;background:#fff}
.field textarea{min-height:80px;resize:vertical}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-actions{display:flex;gap:10px;margin-top:8px}

.flash{background:#e6f6ef;border:1px solid #bfe8d5;color:#15724e;padding:10px 14px;
  border-radius:10px;margin-bottom:16px;font-size:14px}
.empty{color:var(--soft);padding:30px;text-align:center}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-box{background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:30px;width:340px;box-shadow:var(--shadow)}
.login-box h1{font-size:20px;margin:0 0 18px;text-align:center}
.login-box .err{background:#fbeaf0;color:var(--rose);padding:9px 12px;border-radius:9px;font-size:13px;margin-bottom:12px}

/* Mobile */
@media(max-width:780px){
  .burger{display:block}
  .side{position:fixed;top:49px;left:0;bottom:0;width:230px;transform:translateX(-100%);
    transition:transform .2s;z-index:20}
  #navtoggle:checked ~ .shell .side{transform:translateX(0)}
  .content{padding:18px}
  .row2{grid-template-columns:1fr}
  table{font-size:13px}
  th,td{padding:9px 10px}
}
