*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:#f3f6fb;color:#102033}button,input,select,textarea{font:inherit}.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px clamp(16px,4vw,48px);background:linear-gradient(135deg,#061d38,#0c3974);color:#fff;position:sticky;top:0;z-index:10;box-shadow:0 10px 30px rgba(0,0,0,.18)}.brand{display:flex;align-items:center;gap:14px}.brand-mark{width:52px;height:52px;border-radius:16px;background:#e5b037;color:#061d38;display:grid;place-items:center;font-weight:900}.brand h1{font-size:clamp(1.05rem,3vw,1.55rem);margin:0}.brand p,.dashboard-head p,.panel-title p{margin:3px 0 0;opacity:.8}.session-actions{display:flex;align-items:center;gap:12px}.login-wrap{min-height:calc(100vh - 88px);display:grid;place-items:center;padding:28px 16px;background:radial-gradient(circle at top left,rgba(229,176,55,.18),transparent 30%),linear-gradient(135deg,#eef4ff,#ffffff)}.login-card{width:min(520px,100%);background:#fff;border-radius:28px;padding:34px;box-shadow:0 24px 80px rgba(16,32,51,.16);border:1px solid #e7edf6}.pill{display:inline-flex;padding:8px 14px;border-radius:999px;background:#eaf2ff;color:#0c3974;font-weight:800;font-size:.85rem}.login-card h2,.dashboard-head h2{font-size:clamp(1.8rem,5vw,3rem);line-height:1.04;margin:16px 0 10px}.login-card p{line-height:1.65;color:#516070}.login-card label{display:block;font-weight:700;margin:16px 0 7px}.login-card input,.login-card select,.form-card input,.form-card select,.form-card textarea,.filters input,.filters select{width:100%;border:1px solid #d9e2ef;border-radius:14px;padding:13px 14px;background:#fff;color:#102033;outline:none}.form-card textarea{min-height:110px;resize:vertical}.btn{border:0;border-radius:14px;padding:12px 18px;cursor:pointer;font-weight:800;transition:.2s}.btn-primary{background:#0c3974;color:#fff}.btn-primary:hover{background:#092b58;transform:translateY(-1px)}.btn-light{background:#fff;color:#0c3974;border:1px solid #dce6f3}.btn-ghost{background:rgba(255,255,255,.14);color:#fff}.full{width:100%;margin-top:20px}.hidden{display:none!important}.message{font-weight:700}.message.ok{color:#16804a}.message.error{color:#b42318}.admin-note{margin-top:22px;background:#f6f8fb;border-left:4px solid #e5b037;padding:14px;border-radius:12px;color:#4b5b6d}.dashboard{padding:28px clamp(16px,4vw,48px) 60px}.dashboard-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;background:linear-gradient(135deg,#071f3f,#0d4082);color:#fff;border-radius:28px;padding:32px;box-shadow:0 20px 60px rgba(9,43,88,.22)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:22px 0}.stat-card{padding:24px;border-radius:24px;background:#fff;box-shadow:0 14px 40px rgba(16,32,51,.09);border:1px solid #e9eef6}.stat-card span{display:block;color:#64748b;font-weight:800;margin-bottom:10px}.stat-card strong{font-size:clamp(1.3rem,3vw,2rem)}.income strong{color:#0f8a4c}.expense strong{color:#c0392b}.balance strong{color:#0c3974}.docs strong{color:#9a6a00}.admin-panel{background:#fff;border-radius:28px;padding:26px;margin:26px 0;box-shadow:0 16px 50px rgba(16,32,51,.1);border:1px solid #e9eef6}.panel-title h3,.records-section h3{font-size:1.55rem;margin:0 0 6px}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:20px}.form-card{background:#f8fbff;border:1px solid #e3ebf6;border-radius:22px;padding:20px}.form-card h4{margin:0 0 16px;font-size:1.15rem}.form-card input,.form-card select,.form-card textarea{margin-bottom:12px}.form-card.wide{grid-column:1/-1}.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}.file-fields label{background:#fff;border:1px dashed #b8c7da;padding:12px;border-radius:14px;font-weight:800}.file-fields input{border:0;padding:8px 0 0;margin:0}.hint{font-size:.88rem;color:#64748b;line-height:1.5}.records-section{background:#fff;border-radius:28px;padding:24px;box-shadow:0 16px 50px rgba(16,32,51,.08);border:1px solid #e9eef6}.section-row{display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:18px}.filters{display:flex;gap:10px;min-width:min(520px,100%)}.records-list{display:grid;gap:14px}.record-card{border:1px solid #e2eaf5;border-radius:20px;padding:18px;background:#fbfdff;display:grid;grid-template-columns:1fr auto;gap:14px}.record-card h4{margin:0 0 8px}.record-meta{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}.tag{padding:6px 10px;border-radius:999px;font-size:.82rem;font-weight:900;background:#eef4ff;color:#0c3974}.tag.expense{background:#fff0ed;color:#b42318}.tag.income{background:#eafaf1;color:#16804a}.record-actions{display:flex;align-items:center}.details-btn{background:#e5b037;color:#071f3f}.modal{position:fixed;inset:0;background:rgba(2,12,27,.72);z-index:100;display:grid;place-items:center;padding:18px}.modal-card{width:min(980px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:26px;padding:28px;position:relative}.modal-close{position:absolute;right:16px;top:12px;border:0;background:#f1f5f9;border-radius:50%;width:38px;height:38px;font-size:24px;cursor:pointer}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}.detail-box{background:#f8fbff;border:1px solid #e3ebf6;border-radius:18px;padding:16px}.attachments{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.attachment a,.attachment img{display:block;width:100%;border-radius:14px}.attachment a{background:#0c3974;color:#fff;text-decoration:none;padding:14px;text-align:center;font-weight:900}@media(max-width:820px){.topbar{align-items:flex-start;gap:14px;flex-direction:column}.session-actions{width:100%;justify-content:space-between}.dashboard-head{flex-direction:column;padding:24px}.stats-grid{grid-template-columns:1fr 1fr}.admin-grid,.two,.detail-grid,.attachments{grid-template-columns:1fr}.section-row{align-items:stretch;flex-direction:column}.filters{flex-direction:column;min-width:0}.record-card{grid-template-columns:1fr}.record-actions{justify-content:flex-start}.login-card{padding:24px;border-radius:22px}.dashboard{padding:18px 12px 40px}.stat-card,.admin-panel,.records-section{border-radius:20px}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.brand-mark{width:44px;height:44px}.brand h1{font-size:1rem}.session-label{font-size:.86rem}.btn{width:auto}.quick-actions{width:100%}.quick-actions .btn{width:100%}}@media print{.topbar,.admin-panel,.filters,.record-actions,.quick-actions{display:none!important}body{background:#fff}.dashboard{padding:0}.dashboard-head,.stat-card,.records-section{box-shadow:none}.dashboard-head{color:#102033;background:#fff;border:1px solid #ddd}.record-card{break-inside:avoid}}

/* Login administrativo separado */
.admin-login-card {
  max-width: 520px;
}

.admin-login-card label {
  display: block;
  margin: 16px 0 7px;
  font-weight: 800;
}

.admin-login-card input {
  width: 100%;
  border: 1px solid #d9e2ef;
  border-radius: 14px;
  padding: 13px 14px;
  background: #fff;
  color: #102033;
  outline: none;
}

#adminAccessBtn {
  white-space: nowrap;
}

@media (max-width: 820px) {
  #adminAccessBtn {
    width: 100%;
  }
}



/* Correção final do login administrativo separado */
.admin-login-card {
  max-width: 540px;
}

.admin-login-card label {
  display: block;
  margin: 16px 0 7px;
  font-weight: 800;
}

.admin-login-card input {
  width: 100%;
  border: 1px solid #d9e2ef;
  border-radius: 14px;
  padding: 13px 14px;
  background: #fff;
  color: #102033;
  outline: none;
}

#adminAccessBtn {
  white-space: nowrap;
}

@media (max-width: 820px) {
  #adminAccessBtn {
    width: 100%;
  }
}



/* Gerenciar/remover condomínios */
.danger-card {
  border-color: #ffd5d0 !important;
  background: #fff8f7 !important;
}

.btn-danger {
  background: #b42318;
  color: #ffffff;
}

.btn-danger:hover {
  background: #8f1c13;
  transform: translateY(-1px);
}



/* Ajustes de gerenciamento de moradores e lançamentos */
.danger-card {
  border-color: #ffd5d0 !important;
  background: #fff8f7 !important;
}

.btn-danger {
  background: #b42318;
  color: #ffffff;
}

.btn-danger:hover {
  background: #8f1c13;
  transform: translateY(-1px);
}

.file-fields {
  display: block;
}



/* Painel administrativo amplo e organizado */
#adminPanel {
  max-width: 1240px !important;
  width: calc(100vw - 72px) !important;
  margin: 24px auto !important;
}

#adminPanel .admin-grid,
.admin-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(240px, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch !important;
}

#adminPanel .form-card,
.form-card {
  width: 100% !important;
  min-width: 0 !important;
  padding: 22px !important;
  border-radius: 18px !important;
}

#adminPanel .form-card.wide,
.form-card.wide {
  grid-column: span 2 !important;
}

#formLancamento {
  grid-column: span 2 !important;
}

#formRemoverLancamento {
  grid-column: span 2 !important;
}

#adminPanel input,
#adminPanel select,
#adminPanel textarea {
  width: 100% !important;
  min-height: 44px !important;
  font-size: 14px !important;
}

#adminPanel textarea {
  min-height: 120px !important;
}

#adminPanel .two {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

#adminPanel .btn {
  width: 100% !important;
  min-height: 46px !important;
}

#adminPanel h3,
#adminPanel h4 {
  line-height: 1.2 !important;
}

@media (max-width: 1180px) {
  #adminPanel .admin-grid,
  .admin-grid {
    grid-template-columns: repeat(2, minmax(240px, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  #adminPanel {
    width: calc(100vw - 24px) !important;
  }

  #adminPanel .admin-grid,
  .admin-grid {
    grid-template-columns: 1fr !important;
  }

  #adminPanel .form-card.wide,
  .form-card.wide,
  #formLancamento,
  #formRemoverLancamento {
    grid-column: span 1 !important;
  }

  #adminPanel .two {
    grid-template-columns: 1fr !important;
  }
}



/* Correção visual complementar */
#adminPanel {
  max-width: 1240px !important;
  width: calc(100vw - 72px) !important;
  margin: 24px auto !important;
}

.admin-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(240px, 1fr)) !important;
  gap: 22px !important;
}

.form-card.wide,
#formLancamento,
#formRemoverLancamento {
  grid-column: span 2 !important;
}

@media (max-width: 1180px) {
  .admin-grid {
    grid-template-columns: repeat(2, minmax(240px, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  #adminPanel {
    width: calc(100vw - 24px) !important;
  }
  .admin-grid {
    grid-template-columns: 1fr !important;
  }
  .form-card.wide,
  #formLancamento,
  #formRemoverLancamento {
    grid-column: span 1 !important;
  }
}



/* Evidência/anexo no detalhe do lançamento */
.image-evidence {
  background: #f8fbff;
  border: 1px solid #e3ebf6;
  border-radius: 18px;
  padding: 14px;
}

.image-evidence strong {
  display: block;
  margin-bottom: 10px;
  color: #0c3974;
}

.image-evidence img {
  max-height: 420px;
  object-fit: contain;
  background: #fff;
  border: 1px solid #dce6f3;
}



/* Alterar senha de morador */
.senha-card {
  background: #f7fbff !important;
  border-color: #cfe0f5 !important;
}

.senha-card label {
  display: block;
  font-weight: 800;
  margin: 10px 0 6px;
  color: #102033;
}

.resident-card label,.residents-tools-card label{display:block;font-weight:800;color:#14345c;margin:3px 0 7px}.repeat-list{display:grid;gap:10px;margin-bottom:10px}.repeat-row{display:grid;grid-template-columns:1fr auto;gap:10px}.btn-small{padding:10px 12px;border-radius:12px;font-size:.88rem}.top-gap{margin-top:12px}.action-row{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}.report-summary{background:#eef4ff;border-left:5px solid #0c3974;padding:12px 14px;border-radius:12px;font-weight:800;margin:12px 0}.residents-table-wrap{overflow:auto;border:1px solid #dbe5f2;border-radius:16px;background:#fff}.residents-table{width:100%;border-collapse:collapse;min-width:980px}.residents-table th{background:#0c3974;color:#fff;text-align:left;padding:11px;font-size:.85rem}.residents-table td{padding:10px;border-bottom:1px solid #e7edf6;font-size:.88rem;vertical-align:top}.residents-table tr:nth-child(even) td{background:#f8fbff}.resident-photo{margin-bottom:12px}
@media(max-width:800px){.repeat-row{grid-template-columns:1fr}.action-row .btn{width:100%}}

/* ==========================================================
   PAINEL ADMINISTRATIVO ULTRA PREMIUM - DM Gestão Patrimonial
   Organização real dos módulos internos do painel administrativo
   ========================================================== */
#adminPanel.admin-panel {
  max-width: 1480px !important;
  width: calc(100vw - 80px) !important;
  margin: 34px auto !important;
  padding: 34px !important;
  border-radius: 34px !important;
  background:
    radial-gradient(circle at top left, rgba(229,176,55,.16), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f7fbff 100%) !important;
  border: 1px solid rgba(12,57,116,.10) !important;
  box-shadow: 0 28px 80px rgba(6,29,56,.14) !important;
}

#adminPanel .panel-title {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding: 6px 4px 22px !important;
  border-bottom: 1px solid #e4edf8 !important;
  margin-bottom: 24px !important;
}

#adminPanel .panel-title h3 {
  font-size: clamp(1.55rem, 2.5vw, 2.15rem) !important;
  letter-spacing: -.04em !important;
  color: #061d38 !important;
  margin: 0 0 6px !important;
}

#adminPanel .panel-title p {
  color: #64748b !important;
  font-weight: 600 !important;
  margin: 0 !important;
}

#adminPanel .admin-grid {
  display: grid !important;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch !important;
  margin-top: 0 !important;
}

#adminPanel .form-card {
  position: relative !important;
  overflow: hidden !important;
  min-width: 0 !important;
  padding: 24px !important;
  border-radius: 26px !important;
  background: rgba(255,255,255,.88) !important;
  border: 1px solid rgba(148,163,184,.28) !important;
  box-shadow: 0 18px 45px rgba(15,23,42,.07) !important;
  backdrop-filter: blur(12px) !important;
}

#adminPanel .form-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: linear-gradient(90deg, #0c3974, #1d4ed8, #e5b037);
}

#adminPanel .danger-card::before {
  background: linear-gradient(90deg, #991b1b, #dc2626, #f59e0b) !important;
}

#adminPanel .form-card h4 {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 0 14px !important;
  font-size: 1.15rem !important;
  line-height: 1.2 !important;
  letter-spacing: -.02em !important;
  color: #061d38 !important;
}

#adminPanel .form-card h4::before {
  content: "";
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  border-radius: 12px;
  background: linear-gradient(135deg, #0c3974, #1d4ed8);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 8px 18px rgba(30,64,175,.18);
}

#adminPanel .danger-card h4::before {
  background: linear-gradient(135deg, #991b1b, #dc2626) !important;
}

#adminPanel .hint {
  color: #64748b !important;
  line-height: 1.55 !important;
  font-size: .92rem !important;
  margin: 0 0 16px !important;
}

#adminPanel label {
  display: block !important;
  font-size: .84rem !important;
  font-weight: 900 !important;
  color: #334155 !important;
  margin: 0 0 8px !important;
}

#adminPanel input,
#adminPanel select,
#adminPanel textarea {
  width: 100% !important;
  min-height: 48px !important;
  border-radius: 16px !important;
  border: 1px solid #d7e3f2 !important;
  background: #ffffff !important;
  padding: 13px 15px !important;
  font-size: .94rem !important;
  color: #102033 !important;
  box-shadow: 0 1px 0 rgba(15,23,42,.02) !important;
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease !important;
}

#adminPanel input:focus,
#adminPanel select:focus,
#adminPanel textarea:focus {
  border-color: #1d4ed8 !important;
  box-shadow: 0 0 0 4px rgba(29,78,216,.12) !important;
  transform: translateY(-1px) !important;
}

#adminPanel textarea {
  min-height: 130px !important;
}

#adminPanel .two {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

#adminPanel .top-gap {
  margin-top: 14px !important;
}

#adminPanel .btn {
  min-height: 48px !important;
  border-radius: 16px !important;
  font-weight: 900 !important;
  letter-spacing: -.01em !important;
}

#adminPanel .btn-primary {
  background: linear-gradient(135deg, #0c3974, #1558ad) !important;
  box-shadow: 0 14px 26px rgba(12,57,116,.22) !important;
}

#adminPanel .btn-danger {
  background: linear-gradient(135deg, #991b1b, #c0261d) !important;
  box-shadow: 0 14px 26px rgba(153,27,27,.20) !important;
}

#adminPanel .btn-light {
  background: #ffffff !important;
  border: 1px solid #dbeafe !important;
  color: #0c3974 !important;
}

#formCondominio,
#formRemoverCondominio,
#formRemoverMorador {
  grid-column: span 4 !important;
}

#formMorador.resident-card {
  grid-column: 1 / -1 !important;
  background:
    linear-gradient(135deg, rgba(12,57,116,.04), rgba(229,176,55,.07)),
    #ffffff !important;
  border: 1px solid rgba(12,57,116,.14) !important;
}

#formMorador.resident-card .two {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

#formMorador .repeat-list {
  display: grid !important;
  gap: 10px !important;
  margin-bottom: 10px !important;
}

#formMorador .repeat-row {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 10px !important;
  align-items: center !important;
}

#formMorador .btn-small {
  min-height: 42px !important;
  padding: 10px 14px !important;
  white-space: nowrap !important;
}

#formAlterarSenhaMorador {
  grid-column: span 6 !important;
}

#formLancamento {
  grid-column: span 6 !important;
}

#formRemoverLancamento {
  grid-column: span 6 !important;
}

#adminPanel .residents-tools-card {
  grid-column: 1 / -1 !important;
  background:
    radial-gradient(circle at top right, rgba(229,176,55,.14), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%) !important;
}

#adminPanel .action-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin: 16px 0 !important;
}

#adminPanel .action-row .btn {
  width: auto !important;
  flex: 1 1 220px !important;
}

#adminPanel .custom-upload {
  border: 1px dashed #9db8df !important;
  border-radius: 18px !important;
  background: #f8fbff !important;
  padding: 16px !important;
}

#adminPanel .upload-title {
  color: #061d38 !important;
  font-weight: 900 !important;
}

#adminPanel .upload-button {
  background: linear-gradient(135deg, #0c3974, #1558ad) !important;
  border-radius: 14px !important;
  box-shadow: 0 10px 22px rgba(12,57,116,.18) !important;
}

#adminPanel .report-summary,
#adminPanel .residents-table-wrap {
  border-radius: 18px !important;
  background: #f8fbff !important;
  border: 1px solid #dbeafe !important;
  padding: 16px !important;
  overflow: auto !important;
}

@media (max-width: 1180px) {
  #adminPanel {
    width: calc(100vw - 44px) !important;
    padding: 24px !important;
  }

  #adminPanel .admin-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }

  #formCondominio,
  #formRemoverCondominio,
  #formRemoverMorador,
  #formAlterarSenhaMorador,
  #formLancamento,
  #formRemoverLancamento {
    grid-column: span 6 !important;
  }
}

@media (max-width: 760px) {
  #adminPanel {
    width: calc(100vw - 24px) !important;
    padding: 18px !important;
    border-radius: 24px !important;
  }

  #adminPanel .panel-title {
    display: block !important;
  }

  #adminPanel .admin-grid,
  #adminPanel .two,
  #formMorador.resident-card .two,
  #formMorador .repeat-row {
    grid-template-columns: 1fr !important;
  }

  #adminPanel .form-card,
  #formCondominio,
  #formRemoverCondominio,
  #formRemoverMorador,
  #formAlterarSenhaMorador,
  #formLancamento,
  #formRemoverLancamento,
  #formMorador.resident-card,
  #adminPanel .residents-tools-card {
    grid-column: 1 / -1 !important;
  }
}

/* =========================================================
   LAYOUT ADMINISTRATIVO COM MENU LATERAL - VERSÃO PREMIUM
   ========================================================= */
#adminPanel.admin-premium-shell {
  width: min(1560px, calc(100vw - 56px)) !important;
  max-width: 1560px !important;
  margin: 34px auto !important;
  padding: 28px !important;
  border-radius: 30px !important;
  background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,251,255,.96)) !important;
  border: 1px solid rgba(12,57,116,.12) !important;
  box-shadow: 0 28px 80px rgba(15, 23, 42, .12) !important;
  overflow: visible !important;
}

#adminPanel .premium-title {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 4px 4px 22px !important;
  margin: 0 !important;
}

#adminPanel .admin-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: #eaf2ff !important;
  color: #0c3974 !important;
  border: 1px solid #cfe0ff !important;
  border-radius: 999px !important;
  padding: 7px 12px !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  margin-bottom: 10px !important;
}

#adminPanel .premium-title h3 {
  font-size: clamp(1.65rem, 2vw, 2.4rem) !important;
  margin: 0 0 6px !important;
  letter-spacing: -.04em !important;
  color: #071b34 !important;
}

#adminPanel .premium-title p {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 1rem !important;
}

#adminPanel .admin-workspace {
  display: grid !important;
  grid-template-columns: 285px minmax(0, 1fr) !important;
  gap: 24px !important;
  align-items: start !important;
}

#adminPanel .admin-sidebar {
  position: sticky !important;
  top: 110px !important;
  background: linear-gradient(180deg, #082a54 0%, #0c3974 100%) !important;
  border-radius: 24px !important;
  padding: 16px !important;
  box-shadow: 0 22px 42px rgba(12, 57, 116, .24) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
}

#adminPanel .admin-menu-btn {
  width: 100% !important;
  min-height: 54px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  padding: 13px 16px !important;
  margin-bottom: 10px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  background: rgba(255,255,255,.08) !important;
  color: #eef6ff !important;
  font-weight: 900 !important;
  text-align: left !important;
  box-shadow: none !important;
  cursor: pointer !important;
}

#adminPanel .admin-menu-btn:hover,
#adminPanel .admin-menu-btn.active {
  background: linear-gradient(135deg, #ffffff, #eef6ff) !important;
  color: #0c3974 !important;
  transform: translateX(3px) !important;
  box-shadow: 0 14px 30px rgba(0,0,0,.18) !important;
}

#adminPanel .admin-content {
  min-width: 0 !important;
  background: #ffffff !important;
  border-radius: 26px !important;
  border: 1px solid #dbeafe !important;
  padding: 26px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85) !important;
}

#adminPanel .admin-tab-panel {
  display: none !important;
  animation: adminFade .22s ease !important;
}

#adminPanel .admin-tab-panel.active {
  display: block !important;
}

@keyframes adminFade {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

#adminPanel .admin-section-head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 16px !important;
  margin-bottom: 22px !important;
  padding-bottom: 18px !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

#adminPanel .admin-section-head h4 {
  margin: 0 0 6px !important;
  font-size: 1.45rem !important;
  color: #071b34 !important;
  letter-spacing: -.03em !important;
}

#adminPanel .admin-section-head p {
  margin: 0 !important;
  color: #64748b !important;
}

#adminPanel .admin-cards.two-columns {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 22px !important;
}

#adminPanel .form-card,
#adminPanel .full-card {
  width: 100% !important;
  max-width: none !important;
  min-height: auto !important;
  grid-column: auto !important;
  padding: 24px !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%) !important;
  border: 1px solid #dbeafe !important;
  box-shadow: 0 16px 40px rgba(12, 57, 116, .08) !important;
}

#adminPanel .resident-card {
  padding: 28px !important;
}

#adminPanel .form-section-title {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 8px 0 16px !important;
  padding: 12px 14px !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, #eaf2ff, #fff7df) !important;
  color: #0c3974 !important;
  font-weight: 900 !important;
  border: 1px solid rgba(12,57,116,.10) !important;
}

#adminPanel .two,
#adminPanel .three {
  display: grid !important;
  gap: 18px !important;
  align-items: start !important;
}

#adminPanel .two { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
#adminPanel .three { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }

#adminPanel input,
#adminPanel select,
#adminPanel textarea {
  min-width: 0 !important;
  width: 100% !important;
  font-size: .96rem !important;
}

#adminPanel .large-upload {
  margin: 18px 0 !important;
}

#adminPanel .large-action {
  width: min(420px, 100%) !important;
  margin-top: 8px !important;
}

#adminPanel .repeat-row {
  grid-template-columns: minmax(0, 1fr) auto !important;
}

#adminPanel .residents-tools-card,
#adminPanel .senha-card {
  margin-top: 22px !important;
}

#adminPanel .residents-table-wrap {
  max-height: 460px !important;
}

@media (max-width: 1180px) {
  #adminPanel.admin-premium-shell {
    width: calc(100vw - 28px) !important;
    padding: 18px !important;
  }
  #adminPanel .admin-workspace {
    grid-template-columns: 1fr !important;
  }
  #adminPanel .admin-sidebar {
    position: static !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }
  #adminPanel .admin-menu-btn {
    margin-bottom: 0 !important;
  }
  #adminPanel .three {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  #adminPanel.admin-premium-shell {
    width: calc(100vw - 18px) !important;
    padding: 14px !important;
    border-radius: 22px !important;
  }
  #adminPanel .admin-content {
    padding: 16px !important;
    border-radius: 20px !important;
  }
  #adminPanel .admin-sidebar,
  #adminPanel .admin-cards.two-columns,
  #adminPanel .two,
  #adminPanel .three,
  #adminPanel .repeat-row {
    grid-template-columns: 1fr !important;
  }
}
