/* ============================================================
   JARDIM CONQUISTA — SISTEMA CONDOMÍNIO
   Dark Theme matching reference layout
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&display=swap');

:root {
  --bg:        #060E1F;
  --card:      #0D1B33;
  --elev:      #122040;
  --border:    rgba(255,255,255,0.08);
  --accent:    #3B82F6;
  --success:   #22D3A0;
  --danger:    #FF5C6C;
  --warning:   #F5B731;
  --info:      #38BDF8;
  --purple:    #A78BFA;
  --orange:    #FB923C;
  --txt:       #F1F5F9;
  --txt2:      #94A3B8;
  --txt3:      #64748B;
  --hdr1:      #0F2044;
  --hdr2:      #0A1628;
  --sidebar-w: 270px;
  --sidebar-w-collapsed: 66px;
  --tabbar-h:  64px;
  --radius:    14px;
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html,body {
  background: var(--bg); color: var(--txt);
  font-family: 'Plus Jakarta Sans', sans-serif;
  min-height: 100vh; font-size: 15px; line-height: 1.6;
}
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius: 3px; }

/* ── OVERLAY ── */
#sidebarOverlay {
  position:fixed;inset:0;z-index:40;
  background:rgba(0,0,0,.65);backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;transition:opacity .3s;
}
#sidebarOverlay.open { opacity:1;pointer-events:all; }

/* ══════════════════════════════════════
   SIDEBAR
══════════════════════════════════════ */
#sidebar {
  position:fixed;top:0;left:0;z-index:50;
  width:var(--sidebar-w);height:100vh;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--hdr1) 0%,var(--hdr2) 100%);
  border-right:1px solid var(--border);
  transform:translateX(-100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1), width .3s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
}
@media(min-width:1024px){
  #sidebar { transform:translateX(0); }
}

/* COLLAPSED */
#sidebar.sb-collapsed { width: var(--sidebar-w-collapsed); }
#sidebar.sb-collapsed .sb-logo-text-main,
#sidebar.sb-collapsed .sb-logo-text-sub  { display:none; }
#sidebar.sb-collapsed .sb-logo { padding:16px 0;justify-content:center; }
#sidebar.sb-collapsed .sb-logo-link { justify-content:center; }
#sidebar.sb-collapsed .sb-user-name,
#sidebar.sb-collapsed .sb-user-role,
#sidebar.sb-collapsed .sb-user-edit-hint { display:none; }
#sidebar.sb-collapsed .sb-user { justify-content:center;padding:12px 0; }
#sidebar.sb-collapsed .sb-section-label { display:none; }
#sidebar.sb-collapsed .sb-group-toggle .left > *:not(.icon),
#sidebar.sb-collapsed .sb-group-toggle .arrow { display:none; }
#sidebar.sb-collapsed .sb-group-toggle { justify-content:center;padding:9px 0; }
#sidebar.sb-collapsed .sb-link > *:not(.icon) { display:none; }
#sidebar.sb-collapsed .sb-link { justify-content:center;padding:9px 0;border-left:none !important; }
#sidebar.sb-collapsed .sb-link.active { padding-left:0 !important;background:rgba(59,130,246,.18);border-radius:10px; }
#sidebar.sb-collapsed .sb-submenu { display:none !important; }
#sidebar.sb-collapsed .sb-nav { padding:10px 6px; }
#sidebar.sb-collapsed .sb-footer .sb-link > *:not(.icon) { display:none; }
#sidebar.sb-collapsed .sb-footer .sb-link { justify-content:center; }
#sidebar.sb-collapsed .sb-search-wrap { display:none; }
#sidebar.sb-collapsed .sb-collapse-btn { margin:0 auto; }

/* Tooltips on collapsed */
#sidebar.sb-collapsed .sb-link[title]:hover::after {
  content:attr(title);
  position:fixed;left:calc(var(--sidebar-w-collapsed) + 8px);
  background:var(--card);border:1px solid var(--border);
  color:var(--txt);font-size:12px;font-weight:600;
  padding:5px 10px;border-radius:8px;white-space:nowrap;z-index:9999;
  pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.4);
}

/* Collapse toggle button */
.sb-collapse-btn {
  display:none;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:8px;
  background:rgba(255,255,255,.06);border:1px solid var(--border);
  color:var(--txt2);cursor:pointer;font-size:13px;
  transition:all .2s;flex-shrink:0;
}
.sb-collapse-btn:hover { background:rgba(255,255,255,.14);color:var(--txt); }
@media(min-width:1024px){ .sb-collapse-btn { display:flex; } }
@media(min-width:1024px){ .sb-close-btn { display:none !important; } }
@media(max-width:1023px){ .sb-collapse-btn { display:none !important; } }

/* main-content adjustment */
.main-content.sb-collapsed-content { margin-left: var(--sidebar-w-collapsed) !important; }

/* LOGO */
.sb-logo { display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0; }
.sb-logo-link { display:flex;align-items:center;gap:10px;text-decoration:none; }
.sb-logo-img { width:42px;height:42px;border-radius:10px;object-fit:contain;background:white;padding:3px;flex-shrink:0; }
.sb-logo-text-main { font-size:13px;font-weight:800;color:var(--txt);line-height:1.2; }
.sb-logo-text-sub  { font-size:10px;color:var(--accent);font-weight:700;letter-spacing:.5px; }
.sb-close-btn { display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--txt2);cursor:pointer;font-size:16px; }
.sb-close-btn:hover { background:rgba(255,255,255,.12);color:var(--txt); }

/* USER */
.sb-user { display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0;text-decoration:none;transition:background .2s; }
.sb-user:hover { background:rgba(255,255,255,.04); }
.sb-avatar { width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--success),#0DA870);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:#fff;flex-shrink:0; }
.sb-user-name { font-size:13px;font-weight:700;color:var(--txt); }
.sb-user-role { font-size:11px;color:var(--txt3); }
.sb-user-edit-hint { font-size:10px;color:var(--accent);margin-top:1px;opacity:.7; }

/* SEARCH */
.sb-search-wrap { padding:8px 10px 4px;flex-shrink:0; }
.sb-search-box { display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:10px;padding:7px 10px;transition:border-color .2s,background .2s; }
.sb-search-box:focus-within { border-color:var(--accent);background:rgba(59,130,246,.05); }
.sb-search-ico { font-size:13px;color:var(--txt3);flex-shrink:0;line-height:1; }
.sb-search-input { flex:1;background:none;border:none;outline:none;color:var(--txt);font-size:12px;min-width:0;font-family:inherit; }
.sb-search-input::placeholder { color:var(--txt3); }
.sb-search-clr { display:none;background:none;border:none;color:var(--txt3);cursor:pointer;font-size:11px;padding:0;line-height:1;transition:color .15s; }
.sb-search-clr:hover { color:var(--txt); }
.sb-search-clr.visible { display:block; }
.sb-search-empty { display:none;padding:10px 12px;font-size:12px;color:var(--txt3);text-align:center; }
.sb-link.sb-srch-hide,.sb-group.sb-srch-hide,.sb-section-label.sb-srch-hide { display:none !important; }
.sb-searching .sb-submenu { max-height:none !important;opacity:1 !important;overflow:visible !important; }

/* NAV */
.sb-nav { flex:1;overflow-y:auto;overflow-x:hidden;padding:10px;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent; }
.sb-nav::-webkit-scrollbar { width:3px; }
.sb-nav::-webkit-scrollbar-thumb { background:rgba(255,255,255,.1);border-radius:2px; }
.sb-section-label { font-size:9px;font-weight:800;letter-spacing:1px;color:var(--txt3);text-transform:uppercase;padding:10px 10px 4px; }
.sb-link { display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:12px;font-size:13px;font-weight:600;color:var(--txt2);text-decoration:none;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background .15s,color .15s,padding-left .15s; }
.sb-link:hover { background:rgba(255,255,255,.06);color:var(--txt); }
.sb-link.active { background:rgba(59,130,246,.15);color:var(--accent);border-left:3px solid var(--accent);padding-left:9px; }
.sb-link .icon { font-size:16px;flex-shrink:0; }
.sb-group { margin-bottom:2px; }
.sb-group-toggle { display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-radius:12px;font-size:13px;font-weight:700;color:var(--txt2);cursor:pointer;border:none;background:none;width:100%;transition:background .15s,color .15s; }
.sb-group-toggle:hover { background:rgba(255,255,255,.06);color:var(--txt); }
.sb-group-toggle .left { display:flex;align-items:center;gap:9px; }
.sb-group-toggle .icon { font-size:16px; }
.sb-group-toggle .arrow { font-size:10px;color:var(--txt3);transition:transform .25s; }
.sb-group-toggle.expanded .arrow { transform:rotate(180deg); }
.sb-submenu { max-height:0;overflow:hidden;transition:max-height .3s ease,opacity .2s;opacity:0;padding-left:10px; }
.sb-submenu.open { max-height:600px;opacity:1; }
.sb-submenu .sb-link { font-size:12px;color:var(--txt3);padding:7px 12px; }
.sb-submenu .sb-link:hover { color:var(--txt); }
.sb-submenu .sb-link.active { color:var(--accent); }
.sb-footer { padding:10px;border-top:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:2px; }
.sb-footer .sb-link { font-size:12px; }
.sb-link-danger { color:var(--danger) !important; }
.sb-link-danger:hover { background:rgba(255,92,108,.1) !important;color:var(--danger) !important; }

/* ══════════════════════════════════════
   TOPBAR MOBILE
══════════════════════════════════════ */
#topbar {
  display:flex;align-items:center;justify-content:space-between;
  position:fixed;top:0;left:0;right:0;z-index:30;
  padding:0 16px;height:52px;
  background:var(--card);border-bottom:1px solid var(--border);
}
@media(min-width:1024px){ #topbar{display:none;} }
.topbar-logo { display:flex;align-items:center;gap:8px;text-decoration:none; }
.topbar-logo-img { width:30px;height:30px;border-radius:8px;object-fit:contain;background:white;padding:2px; }
.topbar-logo-text { font-size:13px;font-weight:800;color:var(--txt); }
.topbar-right { display:flex;align-items:center;gap:8px; }
.topbar-btn { display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.05);color:var(--txt2);cursor:pointer;font-size:17px;text-decoration:none;flex-shrink:0; }
.topbar-btn:hover { background:rgba(255,255,255,.1);color:var(--txt); }
.topbar-logout { background:rgba(255,92,108,.1);border-color:rgba(255,92,108,.25);color:var(--danger); }
.topbar-logout:hover { background:rgba(255,92,108,.2); }

/* ══════════════════════════════════════
   BOTTOM TAB BAR (mobile)
══════════════════════════════════════ */
#bottomTabBar {
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:30;
  height:var(--tabbar-h);background:var(--card);border-top:1px solid var(--border);
  align-items:stretch;
}
@media(max-width:1023px){ #bottomTabBar{display:flex;} }

.tab-btn {
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;background:none;border:none;cursor:pointer;text-decoration:none;
  color:var(--txt3);font-size:10px;font-weight:700;letter-spacing:.3px;
  transition:color .15s;padding-bottom:env(safe-area-inset-bottom,0px);
}
.tab-btn .tab-ico { font-size:22px;line-height:1; }
.tab-btn.active { color:var(--accent); }
.tab-btn:hover  { color:var(--txt2); }

/* ══════════════════════════════════════
   MOBILE MENU
══════════════════════════════════════ */
#mobileMenu {
  display:none;position:fixed;inset:0;z-index:100;background:var(--bg);
  overflow-y:auto;transform:translateY(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
  padding-bottom:calc(var(--tabbar-h) + 12px);
}
#mobileMenu.open { display:block;transform:translateY(0); }
@media(min-width:1024px){ #mobileMenu{display:none !important;} }

.nm-search-wrap { padding:8px 14px 4px; }
.nm-search-box { display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:13px;padding:10px 14px;transition:border-color .2s; }
.nm-search-box:focus-within { border-color:var(--accent); }
.nm-search-input { flex:1;background:none;border:none;outline:none;color:var(--txt);font-size:14px;min-width:0;font-family:inherit; }
.nm-search-input::placeholder { color:var(--txt3); }
.nm-search-clr { display:none;background:none;border:none;color:var(--txt3);cursor:pointer;font-size:14px;padding:0; }
.nm-search-clr.visible { display:block; }
.nm-user { display:flex;align-items:center;gap:14px;padding:20px 18px 16px;text-decoration:none;transition:background .15s;border-bottom:1px solid var(--border);margin-bottom:6px; }
.nm-user:hover { background:rgba(255,255,255,.04); }
.nm-avatar { width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,var(--accent),#1D4ED8);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;flex-shrink:0; }
.nm-user-name { font-size:17px;font-weight:800;color:var(--txt); }
.nm-user-role-txt { font-size:12px;color:var(--txt3);margin-top:2px; }
.nm-role-badge { margin-left:auto;flex-shrink:0;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);color:var(--accent);border-radius:999px;padding:5px 12px;font-size:12px;font-weight:800; }
.nm-section { display:flex;align-items:center;gap:8px;padding:10px 18px 8px;font-size:10px;font-weight:800;letter-spacing:1.2px;color:var(--txt3);text-transform:uppercase; }
.nm-group { margin:0 14px 18px;background:var(--card);border:1px solid var(--border);border-radius:18px;overflow:hidden; }
.nm-item { display:flex;align-items:center;gap:14px;padding:14px 16px;text-decoration:none;color:var(--txt);transition:background .12s;position:relative; }
.nm-item:not(:last-child)::after { content:'';position:absolute;bottom:0;left:56px;right:0;height:1px;background:var(--border); }
.nm-item:active,.nm-item:hover { background:rgba(255,255,255,.04); }
.nm-item.active { background:rgba(59,130,246,.07); }
.nm-ico { width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0; }
.nm-ico.blue   { background:rgba(59,130,246,.18); }
.nm-ico.green  { background:rgba(34,211,160,.18); }
.nm-ico.red    { background:rgba(255,92,108,.18); }
.nm-ico.yellow { background:rgba(245,183,49,.18); }
.nm-ico.purple { background:rgba(167,139,250,.18); }
.nm-ico.orange { background:rgba(251,146,60,.18); }
.nm-ico.teal   { background:rgba(56,189,248,.18); }
.nm-ico.gray   { background:rgba(255,255,255,.08); }
.nm-item-text  { flex:1;min-width:0; }
.nm-item-title { font-size:15px;font-weight:700;color:var(--txt); }
.nm-item-sub   { font-size:11px;color:var(--txt3);margin-top:2px; }
.nm-arrow { color:var(--txt3);font-size:13px;flex-shrink:0;margin-left:4px; }
.nm-grp-header { display:flex;align-items:center;justify-content:space-between;padding:12px 18px;cursor:pointer;transition:background .15s; }
.nm-grp-header:hover { background:rgba(255,255,255,.04); }
.nm-grp-title { font-size:14px;font-weight:800;color:var(--txt2); }
.nm-grp-arrow { font-size:11px;color:var(--txt3);transition:transform .25s; }
.nm-grp-header.open .nm-grp-arrow { transform:rotate(180deg); }
.nm-grp-body { max-height:0;overflow:hidden;transition:max-height .3s ease,opacity .2s;opacity:0; }
.nm-grp-body.open { max-height:1000px;opacity:1; }
.nm-grp-body .nm-group { margin:0 14px 12px; }
.nm-flat { background:var(--card);border:1px solid var(--border);border-radius:14px; }
.nm-item.nm-srch-hide,.nm-group.nm-srch-hide { display:none !important; }
.nm-searching .nm-grp-body  { max-height:none !important;opacity:1 !important; }

/* ══════════════════════════════════════
   MAIN CONTENT
══════════════════════════════════════ */
.main-content {
  min-height:100vh;background:var(--bg);padding-top:52px;
  transition:margin-left .3s cubic-bezier(.4,0,.2,1);
}
@media(min-width:1024px){
  .main-content { margin-left:var(--sidebar-w);padding-top:0; }
}
@media(max-width:1023px){
  .main-content { padding-bottom:calc(var(--tabbar-h) + 12px); }
}
.page-inner { padding:24px 28px; }
@media(max-width:768px){ .page-inner { padding:16px; } }

/* ══════════════════════════════════════
   COMPONENTS
══════════════════════════════════════ */

/* PAGE HEADER */
.pg-header { display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px; }
.pg-title { font-size:24px;font-weight:900;color:var(--txt);line-height:1.1; }
.pg-sub   { font-size:13px;color:var(--txt3);margin-top:4px; }

/* STATS GRID */
.stat-grid { display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px; }
@media(min-width:768px){ .stat-grid { grid-template-columns:repeat(4,1fr); } }

.stat-card {
  background:var(--card);border:1px solid var(--border);border-radius:18px;padding:18px;
  position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;
}
.stat-card:hover { transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.4); }
.stat-card::before { content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:2px 0 0 2px; }
.stat-card.blue::before   { background:var(--accent); }
.stat-card.green::before  { background:var(--success); }
.stat-card.yellow::before { background:var(--warning); }
.stat-card.red::before    { background:var(--danger); }
.stat-card.purple::before { background:var(--purple); }
.stat-top  { display:flex;align-items:flex-start;justify-content:space-between; }
.stat-label{ font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px; }
.stat-value{ font-size:28px;font-weight:900;margin-top:4px;line-height:1; }
.stat-value.blue   { color:var(--accent); }
.stat-value.green  { color:var(--success); }
.stat-value.yellow { color:var(--warning); }
.stat-value.red    { color:var(--danger); }
.stat-value.purple { color:var(--purple); }
.stat-icon { font-size:26px;opacity:.6; }
.stat-sub  { font-size:11px;color:var(--txt3);margin-top:8px; }

/* CARDS */
.db-card { background:var(--card);border:1px solid var(--border);border-radius:20px;overflow:hidden;margin-bottom:16px; }
.db-card-header { padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between; }
.db-card-title { font-size:15px;font-weight:800;color:var(--txt); }
.db-card-link  { font-size:12px;color:var(--accent);text-decoration:none;font-weight:700; }
.db-card-link:hover { color:var(--info); }
.db-card-body  { padding:16px 18px; }

/* BUTTONS */
.btn { display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:10px;font-family:inherit;font-size:13.5px;font-weight:700;cursor:pointer;border:none;text-decoration:none;transition:all .2s;line-height:1;white-space:nowrap; }
.btn-primary { background:var(--accent);color:#fff; }
.btn-primary:hover { background:#2563EB; }
.btn-success { background:var(--success);color:#0A1628; }
.btn-success:hover { filter:brightness(1.1); }
.btn-danger  { background:var(--danger);color:#fff; }
.btn-danger:hover  { filter:brightness(1.1); }
.btn-warning { background:var(--warning);color:#0A1628; }
.btn-warning:hover { filter:brightness(1.1); }
.btn-ghost   { background:rgba(255,255,255,.06);color:var(--txt2);border:1px solid var(--border); }
.btn-ghost:hover   { background:rgba(255,255,255,.12);color:var(--txt); }
.btn-sm { padding:6px 13px;font-size:12px;border-radius:8px; }
.btn-lg { padding:13px 28px;font-size:16px;border-radius:12px; }

/* BADGES */
.badge { display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.3px; }
.badge-success { background:rgba(34,211,160,.15);color:var(--success);border:1px solid rgba(34,211,160,.3); }
.badge-danger  { background:rgba(255,92,108,.15);color:var(--danger);border:1px solid rgba(255,92,108,.3); }
.badge-warning { background:rgba(245,183,49,.15);color:var(--warning);border:1px solid rgba(245,183,49,.3); }
.badge-info    { background:rgba(56,189,248,.15);color:var(--info);border:1px solid rgba(56,189,248,.3); }
.badge-purple  { background:rgba(167,139,250,.15);color:var(--purple);border:1px solid rgba(167,139,250,.3); }
.badge-gray    { background:rgba(255,255,255,.06);color:var(--txt3);border:1px solid var(--border); }

/* ALERT */
.alert { padding:14px 18px;border-radius:12px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:14px; }
.alert-success { background:rgba(34,211,160,.1);color:var(--success);border:1px solid rgba(34,211,160,.3); }
.alert-error   { background:rgba(255,92,108,.1);color:var(--danger);border:1px solid rgba(255,92,108,.3); }
.alert-info    { background:rgba(56,189,248,.1);color:var(--info);border:1px solid rgba(56,189,248,.3); }
.alert-close   { background:none;border:none;font-size:18px;cursor:pointer;opacity:.6;color:inherit; }

/* FORMS */
.form-group  { margin-bottom:18px; }
.form-label  { display:block;font-size:12px;font-weight:700;color:var(--txt2);margin-bottom:7px;text-transform:uppercase;letter-spacing:.5px; }
.form-control {
  width:100%;padding:11px 14px;border-radius:10px;
  border:1.5px solid var(--border);background:var(--elev);
  color:var(--txt);font-family:inherit;font-size:14px;
  transition:border-color .2s,box-shadow .2s;
  appearance:none;
}
.form-control:focus { outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.12); }
.form-control::placeholder { color:var(--txt3); }
.form-row { display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px; }
.form-hint { font-size:11.5px;color:var(--txt3);margin-top:5px; }
.form-req { color:var(--danger); }

/* TABLE */
.table-wrap { background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden; }
.data-table { width:100%;border-collapse:collapse; }
.data-table th { background:var(--elev);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--txt3);padding:12px 16px;text-align:left;border-bottom:1px solid var(--border); }
.data-table td { padding:13px 16px;border-bottom:1px solid rgba(255,255,255,.04);font-size:14px;vertical-align:middle; }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:rgba(255,255,255,.025); }

/* CHECKLIST TABLE */
.cl-section-title { background:linear-gradient(135deg,#1a3a6b,#0f2550);color:#fff;font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:10px 18px;text-align:center; }
.cl-table { width:100%;border-collapse:collapse; }
.cl-table th { background:var(--elev);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--txt3);padding:9px 12px;text-align:center;border-bottom:1px solid var(--border);border-right:1px solid var(--border); }
.cl-table th.col-item { text-align:left;width:38%; }
.cl-table td { padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.04);text-align:center;vertical-align:middle; }
.cl-table td.item-name { text-align:left;font-size:13px;color:var(--txt);font-weight:600;padding-left:16px; }
.cl-table td.obs-cell  { text-align:left;min-width:140px; }
.cl-table tr:nth-child(even) td { background:rgba(255,255,255,.015); }
.cl-table tr:hover td { background:rgba(59,130,246,.06); }
.cl-table tr:last-child td { border-bottom:none; }
.check-input { width:20px;height:20px;cursor:pointer;accent-color:var(--success); }
.check-input.ruim-chk { accent-color:var(--danger); }
.obs-input { width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;color:var(--txt);font-size:11.5px;padding:4px 8px;font-family:inherit;resize:vertical;min-height:30px; }
.obs-input:focus { outline:none;border-color:var(--accent); }

/* PANEL */
.panel { background:var(--card);border:1px solid var(--border);border-radius:18px;overflow:hidden;margin-bottom:18px; }
.panel-header { padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.02); }
.panel-title  { font-size:15px;font-weight:800;color:var(--txt); }
.panel-body   { padding:20px; }

/* QR CODE */
.qr-wrap { display:flex;flex-direction:column;align-items:center;gap:12px; }
.qr-img  { width:200px;height:200px;border-radius:16px;border:2px solid var(--border);background:white;padding:10px; }
.qr-token { font-size:10px;color:var(--txt3);font-family:monospace;word-break:break-all;text-align:center;background:var(--elev);border-radius:8px;padding:8px 12px; }

/* SIGNATURE */
.signature-area { border:2px dashed var(--border);border-radius:12px;background:var(--elev);overflow:hidden; }
.signature-canvas { display:block;cursor:crosshair;touch-action:none;background:rgba(255,255,255,.03); }
.signature-toolbar { display:flex;gap:8px;padding:8px 12px;border-top:1px solid var(--border); }

/* MORADOR CARD */
.mor-card { background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;display:flex;align-items:center;gap:16px;transition:transform .2s,box-shadow .2s; }
.mor-card:hover { transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.4); }
.mor-avatar { width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--accent),#1D4ED8);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;color:#fff;flex-shrink:0; }
.mor-info { flex:1;min-width:0; }
.mor-name { font-size:15px;font-weight:800;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.mor-sub  { font-size:12px;color:var(--txt3);margin-top:3px; }

/* QR SCAN MODAL */
.modal-overlay { position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center; }
.modal-box { background:var(--card);border:1px solid var(--border);border-radius:24px;padding:32px;max-width:440px;width:90%;text-align:center;box-shadow:0 24px 64px rgba(0,0,0,.6); }
.modal-box h3 { font-size:20px;font-weight:900;color:var(--txt);margin-bottom:8px; }
.modal-box p  { font-size:13px;color:var(--txt3);margin-bottom:20px; }

/* INFO BOX */
.info-box { background:rgba(245,183,49,.06);border:1px solid rgba(245,183,49,.2);border-left:4px solid var(--warning);border-radius:12px;padding:14px 18px;margin-bottom:18px; }
.info-box h4 { font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--warning);margin-bottom:6px; }
.info-box p  { font-size:12.5px;color:var(--txt2);margin-bottom:4px; }

/* FOOTER */
.app-footer { background:var(--card);border-top:1px solid var(--border);padding:16px 28px; }
.footer-inner { display:flex;justify-content:space-between;align-items:center;color:var(--txt3);font-size:12px; }

/* LOGIN PAGE */
.login-wrap { min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:16px; }
.login-box { background:var(--card);border:1px solid var(--border);border-radius:24px;padding:40px;width:100%;max-width:420px;box-shadow:0 24px 64px rgba(0,0,0,.5); }
.login-logo { text-align:center;margin-bottom:28px; }
.login-logo img { width:80px;height:80px;border-radius:16px;object-fit:contain;background:white;padding:6px; }

/* GRIDS */
.grid-2 { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px; }

/* Empty */
.empty-state { text-align:center;padding:48px 16px;color:var(--txt3); }
.empty-state .ico { font-size:48px;margin-bottom:12px; }
.empty-state p { font-size:14px;font-weight:600; }

/* Print */
@media print {
  #sidebar,.app-footer,#topbar,#bottomTabBar,.btn,.alert { display:none !important; }
  .main-content { margin-left:0 !important;padding:0 !important; }
  body { background:white;color:black; }
  .cl-table th,.cl-table td,.data-table th,.data-table td { border-color:#ccc !important;color:black !important; }
  .panel,.db-card,.table-wrap { box-shadow:none;border:1px solid #ccc; }
}