*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f7f6f4;--surface:#fff;--border:rgba(0,0,0,.1);--border2:rgba(0,0,0,.2);
  --text:#1a1a18;--muted:#6b6a65;
  --primary:#3c3489;--primary-l:#eeedfe;--primary-h:#534ab7;
  --ok:#3b6d11;--ok-l:#eaf3de;
  --warn:#854f0b;--warn-l:#faeeda;
  --err:#a32d2d;--err-l:#fcebeb;
  --info:#185fa5;--info-l:#e6f1fb;
  --r:8px;--rl:12px;--sh:0 1px 3px rgba(0,0,0,.07)
}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:15px;
  color:var(--text);background:var(--bg);min-height:100vh;display:flex;flex-direction:column}

/* NAV */
nav{background:var(--surface);border-bottom:1px solid var(--border);height:54px;
  display:flex;align-items:center;gap:1.5rem;padding:0 1.5rem;
  position:sticky;top:0;z-index:50;box-shadow:var(--sh)}
.brand{font-weight:600;font-size:15px;color:var(--primary);text-decoration:none;white-space:nowrap}
.nav-links{display:flex;gap:2px;flex:1;flex-wrap:wrap}
.nav-links a{padding:5px 11px;border-radius:var(--r);color:var(--muted);text-decoration:none;font-size:14px;transition:.15s}
.nav-links a:hover{background:var(--bg);color:var(--text)}
.nav-links a.active{background:var(--primary-l);color:var(--primary);font-weight:500}
.nav-user{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);white-space:nowrap}
.btn-link{color:var(--muted);text-decoration:none;font-size:13px}
.btn-link:hover{color:var(--text)}

/* MAIN */
main{flex:1;padding:1.5rem;max-width:1200px;width:100%;margin:0 auto}
h1{font-size:21px;font-weight:600;margin-bottom:1.25rem}
h2{font-size:16px;font-weight:600;margin-bottom:.75rem}
footer{text-align:center;padding:.75rem;font-size:12px;color:var(--muted);border-top:1px solid var(--border)}

/* ALERT */
.alert{padding:11px 15px;border-radius:var(--r);margin-bottom:1.25rem;font-size:14px}
.alert-ok{background:var(--ok-l);color:var(--ok)}
.alert-error{background:var(--err-l);color:var(--err)}
.alert-info{background:var(--info-l);color:var(--info)}
.alert-warn{background:var(--warn-l);color:var(--warn)}

/* CARD */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);
  padding:1.25rem;box-shadow:var(--sh)}
.card-title{font-size:14px;font-weight:600;margin-bottom:1rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:.04em}

/* METRICS */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:1.5rem}
.metric{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:.9rem 1.1rem}
.metric .lbl{font-size:12px;color:var(--muted);margin-bottom:3px}
.metric .val{font-size:24px;font-weight:600}
.metric .sub{font-size:11px;color:var(--muted);margin-top:2px}

/* BUTTONS */
.btn,.btn-p,.btn-ok,.btn-err,.btn-warn{
  display:inline-flex;align-items:center;gap:5px;padding:7px 14px;
  border-radius:var(--r);border:1px solid var(--border2);background:var(--surface);
  color:var(--text);font-size:14px;cursor:pointer;text-decoration:none;
  transition:.15s;white-space:nowrap;line-height:1}
.btn:hover{background:var(--bg)}
.btn-p{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-p:hover{background:var(--primary-h)}
.btn-ok{background:var(--ok);color:#fff;border-color:var(--ok)}
.btn-err{color:var(--err);border-color:#f09595}
.btn-err:hover{background:var(--err-l)}
.btn-warn{background:var(--warn);color:#fff;border-color:var(--warn)}
.btn-sm{padding:4px 10px;font-size:13px}

/* TOOLBAR */
.tb{display:flex;gap:8px;margin-bottom:1rem;flex-wrap:wrap;align-items:center}
.tb-space{flex:1}
.search{padding:7px 11px;border:1px solid var(--border2);border-radius:var(--r);
  font-size:14px;min-width:200px;background:var(--surface)}
.search:focus{outline:none;border-color:var(--primary)}
select.sel{padding:7px 10px;border:1px solid var(--border2);border-radius:var(--r);
  font-size:14px;background:var(--surface);cursor:pointer}

/* TABLE */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;font-size:12px;font-weight:600;color:var(--muted);
  padding:7px 11px;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:9px 11px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg)}

/* BADGE */
.b{display:inline-block;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:500}
.b-alta,.b-pagat,.b-ok{background:var(--ok-l);color:var(--ok)}
.b-baixa,.b-err{background:var(--err-l);color:var(--err)}
.b-pendent,.b-warn{background:var(--warn-l);color:var(--warn)}
.b-info{background:var(--info-l);color:var(--info)}
.b-infantil{background:#fbeaf0;color:#993556}
.b-major{background:var(--primary-l);color:var(--primary)}
.b-jove{background:#e1f5ee;color:#0f6e56}
.b-admin{background:var(--primary-l);color:var(--primary)}
.b-junta{background:var(--info-l);color:var(--info)}
.b-borrador{background:var(--warn-l);color:var(--warn)}
.b-enviada{background:var(--info-l);color:var(--info)}
.b-cerrada{background:var(--ok-l);color:var(--ok)}

/* AVATAR */
.av{width:32px;height:32px;border-radius:50%;background:var(--primary-l);
  color:var(--primary);font-size:12px;font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.soc-cell{display:flex;align-items:center;gap:9px}
.soc-name{font-weight:500;line-height:1.2}
.soc-sub{font-size:11px;color:var(--muted)}

/* FORM */
.fg{display:flex;flex-direction:column;gap:4px;margin-bottom:.9rem}
.fg label{font-size:13px;font-weight:500;color:var(--muted)}
.fg input,.fg select,.fg textarea{
  padding:7px 10px;border:1px solid var(--border2);border-radius:var(--r);
  font-size:14px;background:var(--surface);color:var(--text)}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--primary)}
.fg textarea{resize:vertical;min-height:70px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.full{grid-column:1/-1}
.fsec{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;
  letter-spacing:.05em;padding-bottom:5px;border-bottom:1px solid var(--border);
  margin:1.2rem 0 .8rem}
.factions{display:flex;gap:8px;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}

/* TABS */
.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.25rem}
.tab{padding:9px 15px;font-size:14px;color:var(--muted);text-decoration:none;
  border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;background:none;border-top:none;border-left:none;border-right:none}
.tab:hover{color:var(--text)}
.tab.on{color:var(--primary);border-bottom-color:var(--primary);font-weight:500}

/* PROGRESS */
.prog{height:7px;background:var(--bg);border-radius:4px;overflow:hidden;margin:6px 0}
.prog-bar{height:100%;background:var(--primary);border-radius:4px}

/* EMPTY */
.empty{text-align:center;padding:2.5rem;color:var(--muted);font-size:14px}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);
  padding:2rem;width:100%;max-width:360px;box-shadow:0 4px 20px rgba(0,0,0,.08)}
.login-logo{text-align:center;margin-bottom:1.5rem}
.login-logo .ico{font-size:36px}
.login-logo h1{font-size:19px;margin-top:6px}
.login-logo p{font-size:13px;color:var(--muted);margin-top:3px}

/* PAGINACIÓN */
.pag{display:flex;gap:3px;margin-top:.75rem;justify-content:center}
.pag a{padding:5px 10px;border:1px solid var(--border);border-radius:var(--r);
  font-size:13px;text-decoration:none;color:var(--text);background:var(--surface)}
.pag a.on{background:var(--primary);color:#fff;border-color:var(--primary)}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:200;
  align-items:center;justify-content:center;min-height:400px}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border-radius:var(--rl);padding:1.5rem;
  width:100%;max-width:420px}
.modal h2{font-size:16px;margin-bottom:1rem}

@media(max-width:720px){
  nav{padding:0 1rem;gap:1rem}
  .nav-links a{padding:5px 7px;font-size:13px}
  main{padding:1rem}
  .grid2,.grid3{grid-template-columns:1fr}
  .metrics{grid-template-columns:repeat(2,1fr)}
}
