/* ── Variáveis — tema claro (padrão) ──────────────────────────────── */
:root {
  --bg-app:       #f0f4fa;
  --bg-primary:   #ffffff;
  --bg-secondary: #f7f9fd;
  --bg-card:      #ffffff;
  --bg-sidebar:   #ffffff;
  --text-primary:   #0d1b2e;
  --text-secondary: #4a5870;
  --text-muted:     #8a97b0;
  --border:       #dde4ef;
  --border-strong:#b8c4d8;
  /* Cores institucionais AMMA */
  --blue:        #1a4a8f;
  --blue-mid:    #1e5bad;
  --blue-light:  #e8f0fb;
  --blue-hover:  #163d78;
  --gold:        #c9a84c;
  --gold-light:  #fdf8ec;
  --gold-dark:   #9e7e2a;
  /* Semânticas */
  --success:     #0a7a52;
  --success-bg:  #e0f7ef;
  --warning:     #966000;
  --warning-bg:  #fff5e0;
  --danger:      #b91c2c;
  --danger-bg:   #fdeaec;
  --honorario:   #6432b8;
  --honorario-bg:#f2ecfd;
  /* Sombras e forma */
  --shadow-xs: 0 1px 2px rgba(26,74,143,.06);
  --shadow-sm: 0 1px 4px rgba(26,74,143,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow:    0 4px 16px rgba(26,74,143,.10);
  --shadow-lg: 0 12px 40px rgba(26,74,143,.14);
  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --sidebar-w: 242px;
  --topbar-h:  60px;
  --ease:      .15s ease;
}

/* ── Tema escuro ─────────────────────────────────────────────────────── */
[data-theme="dark"] {
  --bg-app:       #080f1a;
  --bg-primary:   #0e1826;
  --bg-secondary: #132030;
  --bg-card:      #0e1826;
  --bg-sidebar:   #0b1420;
  --text-primary:   #dde8f5;
  --text-secondary: #7a96b8;
  --text-muted:     #445870;
  --border:       #1c2e42;
  --border-strong: #283e58;
  --blue:        #4a80d4;
  --blue-mid:    #3a6bbf;
  --blue-light:  #0f2244;
  --blue-hover:  #5a90e4;
  --gold:        #ddb84a;
  --gold-light:  #2a1e06;
  --gold-dark:   #c9a84c;
  --success:     #0ec47a;
  --success-bg:  #052a18;
  --warning:     #e0a020;
  --warning-bg:  #281800;
  --danger:      #f06475;
  --danger-bg:   #2a0810;
  --honorario:   #9c6aec;
  --honorario-bg:#1a0838;
  --shadow-xs: 0 1px 2px rgba(0,0,0,.3);
  --shadow-sm: 0 1px 4px rgba(0,0,0,.35);
  --shadow:    0 4px 16px rgba(0,0,0,.45);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.55);
}

/* ── Reset base ─────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg-app);color:var(--text-primary);
  font-size:14px;line-height:1.5;
  transition:background var(--ease),color var(--ease);
}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%}

/* ════════════════════════════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════════════════════════ */
.app-layout{display:flex;height:100vh;overflow:hidden}

/* ── Sidebar ─────────────────────────────────────────────────────── */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--bg-sidebar);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;
  transition:background var(--ease),border-color var(--ease);
}
.sidebar-logo{
  padding:20px 18px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
}
.sidebar-logo img{height:46px;width:auto;object-fit:contain}
.sidebar-nav{padding:14px 8px;flex:1}
.nav-section{margin-bottom:22px}
.nav-section-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.1px;color:var(--text-muted);padding:0 10px 7px;
}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:var(--radius-sm);
  cursor:pointer;color:var(--text-secondary);
  font-size:13px;font-weight:400;
  transition:background var(--ease),color var(--ease);
  margin-bottom:2px;border:none;background:none;width:100%;text-align:left;
}
.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}
.nav-item.active{
  background:var(--blue-light);color:var(--blue);font-weight:600;
}
.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.7}
.nav-item.active svg{opacity:1}
.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border)}

/* ── Main area ───────────────────────────────────────────────────── */
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}

/* ── Topbar ──────────────────────────────────────────────────────── */
.topbar{
  height:var(--topbar-h);
  background:var(--bg-primary);border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;flex-shrink:0;gap:12px;
  box-shadow:var(--shadow-xs);
}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar-title{font-size:15px;font-weight:700;letter-spacing:-.2px}
.topbar-right{display:flex;align-items:center;gap:8px}
.main-content{flex:1;overflow-y:auto;padding:24px}

/* ════════════════════════════════════════════════════════════════════
   BOTÕES
═══════════════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:var(--radius-sm);
  font-size:13px;font-weight:500;cursor:pointer;
  border:1px solid var(--border-strong);
  background:var(--bg-primary);color:var(--text-primary);
  transition:all var(--ease);white-space:nowrap;
}
.btn:hover{background:var(--bg-secondary)}
.btn:active{transform:scale(.98)}
.btn svg{width:14px;height:14px}

.btn-primary{
  background:var(--blue);color:#fff;border-color:transparent;
  box-shadow:0 2px 8px rgba(26,74,143,.28);
}
.btn-primary:hover{background:var(--blue-hover);box-shadow:0 4px 14px rgba(26,74,143,.38)}

.btn-gold{
  background:var(--gold);color:#fff;border-color:transparent;
  box-shadow:0 2px 8px rgba(201,168,76,.3);
}
.btn-gold:hover{background:var(--gold-dark)}

.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:transparent}
.btn-danger:hover{filter:brightness(.94)}
.btn-sm{padding:5px 11px;font-size:12px}
.btn-icon{padding:8px}

/* ════════════════════════════════════════════════════════════════════
   CARDS E STATS
═══════════════════════════════════════════════════════════════════ */
.card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);
}
.card-header{
  padding:16px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.card-body{padding:20px}
.card-title{font-size:14px;font-weight:600}

.stats-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:14px;margin-bottom:24px;
}
.stat-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:18px 20px 16px;
  box-shadow:var(--shadow-sm);position:relative;overflow:hidden;
}
.stat-card::after{
  content:'';position:absolute;top:0;left:0;
  width:4px;height:100%;background:var(--blue);
}
.stat-card.gold::after{background:var(--gold)}
.stat-card.green::after{background:var(--success)}
.stat-card.purple::after{background:var(--honorario)}
.stat-card.muted::after{background:var(--text-muted)}
.stat-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.9px;color:var(--text-muted);margin-bottom:8px;
}
.stat-value{font-size:30px;font-weight:800;line-height:1;letter-spacing:-1px}
.stat-sub{font-size:12px;color:var(--text-secondary);margin-top:5px}

/* ════════════════════════════════════════════════════════════════════
   TABELA
═══════════════════════════════════════════════════════════════════ */
.table-container{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
}
.table-toolbar{
  padding:14px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{
  padding:10px 14px;text-align:left;font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);
  background:var(--bg-secondary);border-bottom:1px solid var(--border);
  white-space:nowrap;
}
tbody tr{border-bottom:1px solid var(--border);transition:background var(--ease);cursor:pointer}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--bg-secondary)}
td{padding:11px 14px;vertical-align:middle}

/* ════════════════════════════════════════════════════════════════════
   FORMULÁRIOS
═══════════════════════════════════════════════════════════════════ */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.full-col{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-label{
  font-size:11px;font-weight:600;color:var(--text-secondary);
  text-transform:uppercase;letter-spacing:.5px;
}
.form-control{
  padding:8px 12px;border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);
  background:var(--bg-primary);color:var(--text-primary);
  font-size:13px;font-family:inherit;
  transition:border-color var(--ease),box-shadow var(--ease);width:100%;
}
.form-control:focus{
  outline:none;border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(26,74,143,.13);
}
textarea.form-control{resize:vertical;min-height:80px}
.form-section{
  margin:24px 0 14px;padding-bottom:10px;
  border-bottom:2px solid var(--blue-light);
  font-size:13px;font-weight:700;color:var(--blue);
  display:flex;align-items:center;gap:8px;
}
.form-section svg{width:15px;height:15px}

/* ════════════════════════════════════════════════════════════════════
   BADGES
═══════════════════════════════════════════════════════════════════ */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:20px;
  font-size:11px;font-weight:600;white-space:nowrap;
}
.badge-ativo{background:var(--success-bg);color:var(--success)}
.badge-inativo{background:var(--bg-secondary);color:var(--text-muted)}
.badge-aposentado{background:var(--blue-light);color:var(--blue)}
.badge-pensionista{background:#f5eeff;color:#6432b8}
.badge-vinculado{background:#e8f4ff;color:#0b66c3}
.badge-correspondentes{background:#f1e8ff;color:#7c3aed}
.badge-honorario{background:var(--honorario-bg);color:var(--honorario)}
.badge-peculista{background:var(--gold-light);color:var(--gold-dark)}

/* ════════════════════════════════════════════════════════════════════
   AVATAR
═══════════════════════════════════════════════════════════════════ */
.avatar{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;flex-shrink:0;overflow:hidden;
}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar-lg{width:58px;height:58px;font-size:18px}
.avatar-xl{width:100px;height:100px;font-size:28px;border-radius:var(--radius)}

/* ════════════════════════════════════════════════════════════════════
   CARTEIRINHA DIGITAL
   Ratio real: 2000×1253 = 1.596 : 1
═══════════════════════════════════════════════════════════════════ */
.membership-card{
  position:relative;border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-lg);
  aspect-ratio:1.596;margin:14px 0;
  background:#c8d8ee;
}
.membership-card-bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
/* Sobreposição de dados sobre o lado ESQUERDO da carteirinha */
.membership-card-overlay{
  position:absolute;inset:0;
  display:flex;align-items:stretch;
}
.card-data-zone{
  /* ocupa ~50% esquerdo — área branca da carteirinha */
  width:50%;
  display:flex;flex-direction:column;
  justify-content:center;
  padding:8% 6% 8% 8%;
  gap:5%;
}
.card-photo-wrap{
  width:30%;aspect-ratio:1;
  border-radius:8%;
  border:2px solid rgba(26,74,143,.25);
  overflow:hidden;background:rgba(26,74,143,.08);
  display:flex;align-items:center;justify-content:center;
  font-size:clamp(10px,2.5vw,18px);font-weight:800;color:#1a4a8f;
  flex-shrink:0;
}
.card-photo-wrap img{width:100%;height:100%;object-fit:cover}
.card-member-name{
  font-size:clamp(8px,1.6vw,13px);font-weight:800;
  color:#0d1b2e;line-height:1.2;
}
.card-member-cargo{
  font-size:clamp(6px,1.2vw,10px);color:#4a5870;
  text-transform:uppercase;letter-spacing:.5px;margin-top:2px;
}
.card-status-pill{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:20px;
  font-size:clamp(6px,1.1vw,9px);font-weight:700;
  width:fit-content;margin-top:3%;
}
.card-status-pill.ativo{background:rgba(10,122,82,.15);color:#0a5c40}
.card-status-pill.inativo{background:rgba(0,0,0,.08);color:#555}
.card-id{
  font-size:clamp(6px,1vw,9px);color:#7a8fa8;
  font-family:monospace;margin-top:2%;
}
.card-qr-box{
  position:absolute;bottom:8%;left:4.5%;
  width:13%;aspect-ratio:1;
  background:white;border-radius:6px;padding:3px;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.card-qr-box img{width:100%;height:100%}

/* ════════════════════════════════════════════════════════════════════
   MODAL
═══════════════════════════════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(8,18,36,.6);backdrop-filter:blur(2px);
  display:flex;align-items:center;justify-content:center;
  z-index:1000;padding:20px;
  opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;
}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{
  background:var(--bg-primary);border-radius:var(--radius-lg);
  width:100%;max-width:760px;max-height:90vh;
  overflow-y:auto;box-shadow:var(--shadow-lg);
  transform:scale(.96);transition:transform .2s;
  border:1px solid var(--border);
}
.modal-overlay.open .modal{transform:scale(1)}
.modal-header{
  padding:18px 24px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;background:var(--bg-primary);z-index:1;
}
.modal-body{padding:24px}
.modal-footer{
  padding:16px 24px;border-top:1px solid var(--border);
  display:flex;justify-content:flex-end;gap:8px;
  position:sticky;bottom:0;background:var(--bg-primary);
}

/* ════════════════════════════════════════════════════════════════════
   PAINEL LATERAL
═══════════════════════════════════════════════════════════════════ */
.detail-panel{
  width:430px;flex-shrink:0;
  background:var(--bg-primary);border-left:1px solid var(--border);
  display:flex;flex-direction:column;overflow-y:auto;
  transition:width .25s ease;
}
.detail-panel.closed{width:0;overflow:hidden}
.panel-header{
  padding:16px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;position:sticky;top:0;background:var(--bg-primary);z-index:1;
}
.panel-body{padding:20px;flex:1}
.panel-section{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.9px;color:var(--text-muted);
  padding:14px 0 8px;border-top:1px solid var(--border);margin-top:4px;
}
.panel-section:first-child{padding-top:0;border-top:none;margin-top:0}
.info-row{display:flex;gap:8px;margin-bottom:9px}
.info-label{font-size:11px;color:var(--text-muted);min-width:112px;flex-shrink:0;padding-top:1px}
.info-val{font-size:13px;color:var(--text-primary)}

/* ════════════════════════════════════════════════════════════════════
   PAGINAÇÃO
═══════════════════════════════════════════════════════════════════ */
.pagination{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-top:1px solid var(--border);
  font-size:12px;color:var(--text-secondary);
}
.pagination-btns{display:flex;gap:4px}
.page-btn{
  padding:4px 10px;border:1px solid var(--border);
  border-radius:var(--radius-sm);background:var(--bg-primary);
  color:var(--text-primary);cursor:pointer;font-size:12px;
}
.page-btn:hover{background:var(--bg-secondary)}
.page-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.page-btn:disabled{opacity:.4;cursor:not-allowed}

/* ════════════════════════════════════════════════════════════════════
   DEPENDENTES
═══════════════════════════════════════════════════════════════════ */
.dependente-row{
  display:grid;grid-template-columns:1fr 140px 150px 34px;
  gap:8px;align-items:end;padding:10px 12px;
  background:var(--bg-secondary);border-radius:var(--radius-sm);
  border:1px solid var(--border);margin-bottom:8px;
}

/* ════════════════════════════════════════════════════════════════════
   UPLOAD FOTO
═══════════════════════════════════════════════════════════════════ */
.photo-upload{
  width:100px;height:100px;border-radius:var(--radius);
  border:2px dashed var(--border-strong);cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;color:var(--text-muted);font-size:11px;
  transition:border-color var(--ease),background var(--ease);
  position:relative;overflow:hidden;
}
.photo-upload:hover{border-color:var(--blue);background:var(--blue-light)}
.photo-upload input{position:absolute;inset:0;opacity:0;cursor:pointer}
.photo-upload img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ════════════════════════════════════════════════════════════════════
   ALERTAS & TOAST
═══════════════════════════════════════════════════════════════════ */
.alert{
  padding:12px 16px;border-radius:var(--radius-sm);
  font-size:13px;display:flex;align-items:center;gap:10px;margin-bottom:16px;
}
.alert-success{background:var(--success-bg);color:var(--success)}
.alert-danger{background:var(--danger-bg);color:var(--danger)}
.alert-info{background:var(--blue-light);color:var(--blue)}

#toast-container{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  display:flex;flex-direction:column;gap:8px;
}
.toast{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:12px 18px;
  box-shadow:var(--shadow-lg);font-size:13px;
  max-width:340px;animation:slideIn .2s ease;
  display:flex;align-items:center;gap:10px;
}
.toast.success{border-left:3px solid var(--success)}
.toast.error{border-left:3px solid var(--danger)}
.toast.info{border-left:3px solid var(--blue)}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ════════════════════════════════════════════════════════════════════
   TEMA TOGGLE
═══════════════════════════════════════════════════════════════════ */
.theme-toggle{
  cursor:pointer;padding:7px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--bg-primary);
  color:var(--text-secondary);display:flex;align-items:center;
  transition:all var(--ease);
}
.theme-toggle:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}

/* ════════════════════════════════════════════════════════════════════
   LOADING
═══════════════════════════════════════════════════════════════════ */
.spinner{
  width:22px;height:22px;border:2px solid var(--border);
  border-top-color:var(--blue);border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ════════════════════════════════════════════════════════════════════
   LOGIN — layout split impressionante
═══════════════════════════════════════════════════════════════════ */
.login-page{min-height:100vh;display:flex}

.login-left{
  flex:1;background:var(--blue);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:48px;position:relative;overflow:hidden;
}
/* Círculos decorativos dourados */
.login-left::before{
  content:'';position:absolute;
  top:-100px;right:-100px;
  width:380px;height:380px;border-radius:50%;
  border:60px solid rgba(201,168,76,.18);
}
.login-left::after{
  content:'';position:absolute;
  bottom:-80px;left:-80px;
  width:280px;height:280px;border-radius:50%;
  border:40px solid rgba(255,255,255,.07);
}
.login-logo-img{
  width:220px;height:auto;
  position:relative;z-index:1;margin-bottom:28px;
  /* logo colorida precisa ficar branca no fundo azul */
  filter:brightness(0) invert(1);
}
.login-tagline{
  color:rgba(255,255,255,.7);font-size:13px;
  text-align:center;letter-spacing:.5px;line-height:1.6;
  position:relative;z-index:1;max-width:280px;
}
.login-gold-bar{
  width:40px;height:3px;background:var(--gold);
  border-radius:2px;margin:16px auto;position:relative;z-index:1;
}

.login-right{
  width:440px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  padding:48px;background:var(--bg-primary);
}
.login-form-wrap{width:100%}
.login-title{font-size:24px;font-weight:800;margin-bottom:4px;letter-spacing:-.5px}
.login-sub{font-size:13px;color:var(--text-secondary);margin-bottom:32px}
.login-logo-small{
  width:100px;height:auto;margin-bottom:28px;display:block;
}

@media(max-width:700px){
  .login-left{display:none}
  .login-right{width:100%;padding:32px 24px}
}

/* ════════════════════════════════════════════════════════════════════
   PÁGINA PÚBLICA QR CODE
═══════════════════════════════════════════════════════════════════ */
.pub-page{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,#dce8f8 0%,#eef4fd 55%,#f4f8ff 100%);
  padding:24px;
}
.pub-card{
  background:#fff;border-radius:var(--radius-xl);
  width:100%;max-width:400px;
  box-shadow:0 24px 64px rgba(26,74,143,.18);
  overflow:hidden;
}
.pub-card-top{
  background:var(--blue);padding:24px 28px 22px;
  display:flex;align-items:center;gap:16px;
}
.pub-card-top img{height:36px;width:auto;filter:brightness(0) invert(1)}
.pub-card-top-text{color:rgba(255,255,255,.75);font-size:11px;letter-spacing:.5px;text-transform:uppercase}
.pub-card-body{padding:28px}
.pub-status{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 18px;border-radius:20px;font-size:13px;font-weight:600;
  margin-bottom:18px;
}
.pub-status.ativo{background:var(--success-bg);color:var(--success)}
.pub-status.inativo{background:var(--bg-secondary);color:var(--text-muted)}
.pub-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.pub-dot.ativo{background:var(--success)}
.pub-dot.inativo{background:var(--text-muted)}
.pub-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;
}
.pub-row:last-child{border-bottom:none}
.pub-row-label{color:var(--text-muted)}
.pub-footer{
  background:var(--bg-secondary);padding:14px 28px;
  font-size:11px;color:var(--text-muted);text-align:center;line-height:1.6;
}

/* ════════════════════════════════════════════════════════════════════
   BUSCA
═══════════════════════════════════════════════════════════════════ */
.search-wrap{position:relative;flex:1;min-width:200px;max-width:360px}
.search-wrap svg{
  position:absolute;left:10px;top:50%;transform:translateY(-50%);
  width:15px;height:15px;color:var(--text-muted);pointer-events:none;
}
.search-input{padding-left:34px !important}

/* ════════════════════════════════════════════════════════════════════
   UTILIDADES
═══════════════════════════════════════════════════════════════════ */
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.text-sm{font-size:12px}.text-muted{color:var(--text-muted)}
.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}
.empty-state svg{width:40px;height:40px;margin:0 auto 12px;opacity:.25;display:block}

@media(max-width:768px){
  .sidebar{position:fixed;left:-100%;top:0;height:100vh;z-index:500;transition:left .25s}
  .sidebar.mobile-open{left:0}
  .detail-panel{position:fixed;right:0;top:0;height:100vh;z-index:400;width:100% !important}
  .detail-panel.closed{width:0 !important}
  .form-grid,.form-grid-3{grid-template-columns:1fr}
  .dependente-row{grid-template-columns:1fr 1fr}
  .main-content{padding:16px}
}


.modal-large{max-width:1120px;width:min(1120px,96vw);max-height:92vh}
.full-view-stack{display:block}
.full-header-card{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;margin-bottom:18px}
.full-header-photo{width:220px;height:260px;border-radius:22px;overflow:hidden;background:#eef3fb;display:flex;align-items:center;justify-content:center}
.full-header-photo img{width:100%;height:100%;object-fit:cover}
.full-header-meta{min-width:0}
.full-header-kicker{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:8px}
.full-header-name{font-size:42px;line-height:1.05;font-weight:800;color:var(--text-primary)}
.full-header-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.full-header-subline{font-size:13px;color:var(--text-muted);margin-top:12px}
.full-avatar-fallback{font-size:52px;font-weight:800;color:var(--blue)}
.full-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:16px}
.full-section h3{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:12px}
.full-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}
.full-field{padding:10px 12px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border)}
.full-field-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:4px}
.full-field-value{font-size:14px;font-weight:600;color:var(--text-primary);word-break:break-word;white-space:pre-wrap}
.membership-card-shell{width:100%;overflow:auto;padding-bottom:8px}
.membership-card-shell.full{max-width:100%}
.membership-card{position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--shadow-lg);background:#dce6f2;width:900px;height:564px;max-width:none;aspect-ratio:auto}
.membership-card-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.membership-card-overlay{position:absolute;inset:0}
.card-photo-column{position:absolute;left:98px;top:54px;width:300px}
.card-photo-wrap{width:240px;height:290px;border-radius:18px;overflow:hidden;border:none;background:#eef3fb;display:flex;align-items:center;justify-content:center}
.card-photo-wrap img{width:100%;height:100%;object-fit:cover}
.card-photo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:72px;font-weight:800;color:#1a4a8f}
.card-id-number{margin-top:16px;font-size:48px;line-height:1;font-weight:800;color:#16549e}
.card-member-cargo{margin-top:8px;font-size:18px;line-height:1.1;color:#16549e;letter-spacing:.5px}
.card-member-name{margin-top:8px;font-size:28px;line-height:1.06;font-weight:800;color:#16549e;text-transform:uppercase;max-width:470px;word-break:break-word}
.card-meta-line{margin-top:12px;font-size:15px;color:#4a5870;font-weight:600;max-width:560px;line-height:1.35}
.card-qr-box{position:absolute;right:46px;top:34px;width:126px;height:126px;border-radius:12px;background:#fff;padding:10px;box-shadow:0 12px 24px rgba(15,23,42,.14)}
.card-qr-box img{width:100%;height:100%;object-fit:contain}
.card-actions{display:flex;justify-content:flex-end;gap:8px;margin:10px 0 18px}
@media (max-width: 900px){.full-header-card{grid-template-columns:1fr}.full-header-photo{width:220px;height:260px}.full-header-name{font-size:34px}.full-fields{grid-template-columns:1fr}.modal-large{width:min(96vw,1120px)}.membership-card{width:900px;height:564px}}


/* Overrides finais carteirinha */
.card-photo-column{left:98px;top:74px;width:340px}
.card-photo-wrap{width:240px;height:240px;border-radius:18px;border:none;background:#eef3fb}
.card-id-number{margin-top:18px;font-size:58px;line-height:1;font-weight:800;color:#16549e}
.card-member-cargo{margin-top:8px;font-size:22px;line-height:1.1;color:#16549e;letter-spacing:.5px}
.card-member-name{margin-top:10px;font-size:32px;line-height:1.04;font-weight:800;color:#16549e;text-transform:uppercase;max-width:520px;word-break:normal}
.card-member-name span{display:block}
.card-qr-box{position:absolute;right:46px !important;left:auto !important;top:34px !important;bottom:auto !important;width:126px;height:126px;border-radius:12px;background:#fff;padding:10px;box-shadow:0 12px 24px rgba(15,23,42,.14)}
.card-meta-line{display:none}

/* ── Dashboard ampliado ───────────────────────────────────────────── */
.dashboard-grid-3{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}
.dashboard-card-span-2{grid-column:span 2}
.dashboard-card-span-1{grid-column:span 1}
.dashboard-column-stack{display:grid;gap:20px}
.dashboard-list{display:flex;flex-direction:column;gap:10px}
.dashboard-list-item{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--bg-secondary);
}
.dashboard-list-item-main{min-width:0;flex:1}
.dashboard-list-item-title{font-size:13px;font-weight:600;line-height:1.25}
.dashboard-list-item-sub{font-size:11px;color:var(--text-muted);margin-top:2px}
.dashboard-list-item-meta{font-size:11px;color:var(--text-secondary);text-align:right;white-space:nowrap}
.card-badge{
  font-size:11px;font-weight:700;padding:5px 9px;border-radius:999px;
  background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);
}
.simple-bar-list{display:flex;flex-direction:column;gap:12px}
.simple-bar-row{display:flex;flex-direction:column;gap:5px}
.simple-bar-head{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:var(--text-secondary)}
.simple-bar-track{height:8px;background:var(--bg-secondary);border-radius:999px;overflow:hidden;border:1px solid var(--border)}
.simple-bar-fill{height:100%;border-radius:999px}
.column-chart{display:flex;align-items:flex-end;gap:12px;min-height:220px;padding-top:8px}
.column-chart-item{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:8px}
.column-chart-value{font-size:12px;font-weight:700;color:var(--text-secondary)}
.column-chart-bar-wrap{height:160px;width:100%;border-radius:14px;border:1px solid var(--border);background:linear-gradient(180deg,var(--bg-primary),var(--bg-secondary));display:flex;align-items:flex-end;justify-content:center;padding:8px}
.column-chart-bar{width:100%;max-width:48px;border-radius:10px 10px 6px 6px;box-shadow:0 10px 22px rgba(0,0,0,.08)}
.column-chart-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-align:center;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.donut-chart-wrap{display:grid;grid-template-columns:160px 1fr;gap:16px;align-items:center}
.donut-chart{width:160px;height:160px;border-radius:50%;display:grid;place-items:center;box-shadow:inset 0 0 0 1px var(--border),0 14px 30px rgba(0,0,0,.06)}
.donut-chart-hole{width:88px;height:88px;border-radius:50%;background:var(--bg-primary);border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut-chart-hole strong{font-size:24px;line-height:1}
.donut-chart-hole span{font-size:11px;color:var(--text-muted);margin-top:4px}
.donut-legend{display:flex;flex-direction:column;gap:10px}
.donut-legend-item{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:8px;font-size:12px}
.donut-dot{width:10px;height:10px;border-radius:50%}
.donut-label{color:var(--text-secondary);min-width:0}
.donut-legend-item strong{font-size:12px}
.donut-legend-item small{font-size:11px;color:var(--text-muted)}
.mini-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}
.mini-calendar-head{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;
  color:var(--text-muted);text-align:center;padding-bottom:4px;
}
.mini-calendar-day{
  min-height:72px;border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:8px;background:var(--bg-secondary);display:flex;flex-direction:column;gap:8px;
}
.mini-calendar-day.muted{opacity:.42}
.mini-calendar-day.today{border-color:var(--blue);box-shadow:0 0 0 2px rgba(26,74,143,.12)}
.mini-calendar-date{font-size:12px;font-weight:700}
.mini-calendar-count{font-size:11px;color:var(--blue);font-weight:600}
.reservas-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.reserve-panel{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;background:var(--bg-secondary)}
.reserve-panel-title{font-size:12px;font-weight:700;margin-bottom:8px}
.reserve-stats{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.reserve-pill{font-size:11px;border:1px solid var(--border);background:var(--bg-primary);padding:4px 8px;border-radius:999px;color:var(--text-secondary)}
.alert-compact{padding:10px 12px;border-radius:var(--radius-sm);font-size:12px;border:1px solid transparent}
.alert-compact.warn{background:var(--warning-bg);color:var(--warning);border-color:rgba(150,96,0,.18)}
@media (max-width: 1100px){
  .dashboard-grid-3{grid-template-columns:1fr}
  .dashboard-card-span-2,.dashboard-card-span-1{grid-column:span 1}
}
@media (max-width: 720px){
  .reservas-grid{grid-template-columns:1fr}
  .mini-calendar{gap:6px}
  .mini-calendar-day{min-height:60px;padding:6px}
  .donut-chart-wrap{grid-template-columns:1fr}
  .donut-chart{margin:0 auto}
  .column-chart{gap:8px;min-height:190px}
  .column-chart-bar-wrap{height:130px}
}

