@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
:root{--white:#fff;--gray-25:#fcfcfd;--gray-50:#f9fafb;--gray-100:#f2f4f7;--gray-200:#eaecf0;--gray-300:#d0d5dd;--gray-400:#98a2b3;--gray-500:#667085;--gray-600:#475467;--gray-700:#344054;--gray-800:#1d2939;--gray-900:#101828;--primary-25:#f5f8ff;--primary-50:#eff4ff;--primary-100:#d1e0ff;--primary-200:#b2ccff;--primary-300:#84adff;--primary-500:#2970ff;--primary-600:#155eef;--primary-700:#004eeb;--success-50:#ecfdf3;--success-500:#12b76a;--success-700:#027a48;--warning-50:#fffaeb;--warning-500:#f79009;--warning-700:#b54708;--error-50:#fef3f2;--error-500:#f04438;--error-700:#b42318;--purple-50:#f4f3ff;--purple-500:#7a5af8;--purple-700:#5925dc;--shadow-xs:0 1px 2px rgba(16,24,40,.05);--shadow-sm:0 1px 3px rgba(16,24,40,.1),0 1px 2px rgba(16,24,40,.06);--shadow-lg:0 12px 16px -4px rgba(16,24,40,.08),0 4px 6px -2px rgba(16,24,40,.03);--topbar-h:56px;--radius:8px;--radius-lg:12px}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px}body{font-family:'Inter',-apple-system,sans-serif;background:var(--white);color:var(--gray-900);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}
/* Font Awesome fallback: some icons used in pages are not available in regular set.
   Force free solid glyph rendering so icons do not appear as broken envelope/square marks. */
.fa-regular{
  color:var(--gray-900);
  font-family:"Font Awesome 6 Free";
  font-weight:900;
}
.btn-primary .fa-regular,.btn.btn-primary .fa-regular{color:var(--white)!important}
.badge .fa-regular{color:currentColor}
.table-filter-btn:not(.btn-primary) .fa-regular{color:var(--gray-900)}
.topbar-icon-btn .fa-regular,.btn-mobile-menu .fa-regular{color:var(--gray-900)}
.stat-icon .fa-regular,.accordion-icon .fa-regular,.empty-state-icon .fa-regular,.btn-icon-only .fa-regular{color:var(--gray-900)!important}
.btn-icon-only.danger:hover .fa-regular{color:var(--error-700)!important}
.table-search-icon.fa-regular,.table-search .table-search-icon{color:var(--gray-900)}
.file-item .fa-regular{color:var(--gray-900)}
.modal-header .fa-regular,.pag-btn .fa-regular{color:var(--gray-900)}
/* Layout + sidebar width (Tailwind-inspired: expanded / collapsed) */
.layout{
  --sidebar-w:268px;
  display:flex;
  min-height:100vh;
}
.layout.sidebar-collapsed{
  --sidebar-w:76px;
}

.sidebar{
  width:var(--sidebar-w);
  background:var(--white);
  border-right:1px solid var(--gray-200);
  position:fixed;
  top:0;
  left:0;
  bottom:0;
  z-index:100;
  transition:width .22s ease,transform .2s ease;
  overflow:visible;
  display:flex;
  flex-direction:column;
}
.sidebar-surface{
  flex:1;
  display:flex;
  flex-direction:column;
  min-height:0;
  margin:10px 10px 8px;
  padding:8px 8px 10px;
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:16px;
  box-shadow:var(--shadow-xs);
  overflow:visible;
}
.sidebar-workspace{
  display:flex;
  align-items:center;
  gap:8px;
  padding:6px 6px 12px;
  margin-bottom:4px;
  border-bottom:1px solid var(--gray-100);
  position:relative;
}
.sidebar-workspace-brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
  flex:1;
}
.sidebar-workspace-logo{
  width:36px;
  height:36px;
  border-radius:10px;
  background:var(--white);
  border:2px solid var(--gray-900);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gray-900);
  font-weight:700;
  font-size:13px;
  flex-shrink:0;
}
.sidebar-workspace-logo img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:8px;
  display:block;
}
.sidebar-workspace-text{
  display:flex;
  flex-direction:column;
  min-width:0;
}
.sidebar-workspace-name{
  font-size:14px;
  font-weight:600;
  color:var(--gray-900);
  letter-spacing:-.02em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sidebar-workspace-meta{
  font-size:11px;
  color:var(--gray-500);
  margin-top:1px;
}
.sidebar-icon-btn{
  width:32px;
  height:32px;
  border:1px solid var(--gray-200);
  border-radius:10px;
  background:var(--white);
  color:var(--gray-900);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  transition:background .15s,color .15s;
}
.sidebar-icon-btn:hover{
  background:var(--gray-50);
  color:var(--gray-900);
}
.sidebar-icon-btn svg.lucide{color:var(--gray-900)}
/* Lucide: thin linear icons (sidebar) — same meanings, stroke-only look */
.sidebar svg.lucide{
  flex-shrink:0;
  stroke:currentColor;
  fill:none;
  color:var(--gray-900);
}
.sidebar .lucide-sidebar{
  width:20px;
  height:20px;
}
.sidebar .lucide-sidebar-sm{
  width:16px;
  height:16px;
}
.sidebar .lucide-sidebar-xs{
  width:14px;
  height:14px;
}
.sidebar .lucide-sidebar-sub{
  width:17px;
  height:17px;
}
.sidebar .sidebar-collapse-toggle svg.lucide{
  width:14px;
  height:14px;
}
.sidebar .nav-icon{
  display:flex;
  align-items:center;
  justify-content:center;
}
.sidebar .sidebar-popover-item-icon.lucide-sidebar{
  width:16px;
  height:16px;
  margin-right:0;
}
.sidebar .sidebar-popover-check svg.lucide{
  width:14px;
  height:14px;
}
.sidebar-workspace-menu-btn i{transition:transform .2s}
.sidebar-workspace:has(.sidebar-workspace-popover:not(.hidden)) .sidebar-workspace-menu-btn i{transform:rotate(180deg)}

.sidebar-search{
  position:relative;
  display:flex;
  align-items:center;
  margin:0 4px 12px;
}
.sidebar-search-icon{
  position:absolute;
  left:12px;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gray-900);
  pointer-events:none;
}
.sidebar-search-input{
  width:100%;
  padding:9px 44px 9px 36px;
  border:1px solid var(--gray-200);
  border-radius:12px;
  background:var(--white);
  font-family:inherit;
  font-size:13px;
  color:var(--gray-800);
  transition:border-color .15s,box-shadow .15s,background .15s;
}
.sidebar-search-input::placeholder{color:var(--gray-400)}
.sidebar-search-input:focus{
  outline:none;
  border-color:var(--gray-300);
  background:var(--white);
  box-shadow:0 0 0 2px var(--gray-100);
}
.sidebar-search-kbd{
  position:absolute;
  right:10px;
  font-size:10px;
  font-family:inherit;
  padding:3px 6px;
  border-radius:6px;
  border:1px solid var(--gray-200);
  background:var(--white);
  color:var(--gray-400);
  font-weight:500;
}

.sidebar-nav{
  flex:1;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  padding:0 2px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.sidebar-nav-section{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.sidebar-section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 10px 6px;
  font-size:11px;
  font-weight:600;
  color:var(--gray-400);
  text-transform:uppercase;
  letter-spacing:.06em;
}
.sidebar-section-header-actions{font-size:12px;color:var(--gray-300)}

.nav-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 12px;
  border-radius:12px;
  font-size:13px;
  font-weight:500;
  color:var(--gray-700);
  cursor:pointer;
  border:none;
  background:none;
  width:100%;
  text-align:left;
  font-family:inherit;
  transition:background .15s,color .15s;
}
.nav-item:hover{
  background:var(--gray-50);
  color:var(--gray-900);
}
.nav-item.active{
  background:#edf3ff;
  color:#0038ff;
  font-weight:600;
  box-shadow:0 1px 2px rgba(21,94,239,.10);
}
.nav-item-ghost{
  color:var(--gray-600);
}
.nav-icon{
  width:20px;
  height:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:15px;
  color:var(--gray-900);
  flex-shrink:0;
}
.nav-item.active .nav-icon,
.nav-item.active .nav-icon svg,
.nav-item.active .nav-arrow,
.nav-item.active .lucide-sidebar,
.nav-item.active .lucide-sidebar-sm{color:#0038ff}
.nav-label{
  flex:1;
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.nav-kbd{
  font-size:10px;
  font-family:inherit;
  padding:2px 6px;
  border-radius:6px;
  border:1px solid var(--gray-200);
  background:var(--white);
  color:var(--gray-400);
  font-weight:500;
}

.sidebar-bottom{
  margin-top:auto;
  padding-top:8px;
  border-top:1px solid var(--gray-100);
  display:flex;
  flex-direction:column;
  gap:2px;
}

.sidebar-user-wrap{
  position:relative;
  margin-top:8px;
  padding-top:8px;
  border-top:1px solid var(--gray-100);
}
.sidebar-user-trigger{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  padding:8px 10px;
  border:1px solid var(--gray-200);
  border-radius:12px;
  background:var(--white);
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  transition:background .15s;
}
.sidebar-user-trigger:hover{background:var(--gray-50)}
.sidebar-user-trigger svg.lucide{color:var(--gray-900)}
.sidebar-user-text{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
}
.sidebar-user-name{
  font-size:13px;
  font-weight:600;
  color:var(--gray-800);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sidebar-user-email{
  font-size:11px;
  color:var(--gray-500);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sidebar-user-chev{
  font-size:10px;
  color:var(--gray-900);
  flex-shrink:0;
  transition:transform .2s;
}
.sidebar-user-wrap:has(.sidebar-user-popover:not(.hidden)) .sidebar-user-chev{transform:rotate(180deg)}

.sidebar-avatar{
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--white);
  border:2px solid var(--gray-900);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:12px;
  color:var(--gray-900);
  flex-shrink:0;
}
.sidebar-avatar-lg{
  width:40px;
  height:40px;
  font-size:14px;
}

.sidebar-popover{
  position:absolute;
  left:8px;
  right:8px;
  bottom:calc(100% + 8px);
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:14px;
  box-shadow:0 12px 24px -6px rgba(16,24,40,.12),0 4px 8px -2px rgba(16,24,40,.06);
  padding:8px;
  z-index:120;
  animation:sidebarPop .16s ease;
}
.sidebar-workspace-popover{
  top:calc(100% + 6px);
  bottom:auto;
  left:0;
  right:0;
}
@keyframes sidebarPop{
  from{opacity:0;transform:translateY(4px)}
  to{opacity:1;transform:translateY(0)}
}
.sidebar-popover-title{
  font-size:11px;
  font-weight:600;
  color:var(--gray-400);
  text-transform:uppercase;
  letter-spacing:.05em;
  padding:6px 10px 8px;
}
.sidebar-popover-item{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  padding:10px 12px;
  border:none;
  border-radius:10px;
  background:none;
  font-family:inherit;
  font-size:13px;
  font-weight:500;
  color:var(--gray-700);
  cursor:pointer;
  text-align:left;
  text-decoration:none;
  transition:background .15s;
}
.sidebar-popover-item:hover{background:var(--gray-50)}
.sidebar-popover-item.is-active{
  background:var(--gray-100);
  color:var(--gray-900);
}
.sidebar-popover-check{
  width:18px;
  color:var(--gray-900);
  font-size:12px;
}
.sidebar-popover-item-text{display:flex;flex-direction:column;gap:1px}
.sidebar-popover-item-name{font-weight:600;color:var(--gray-800)}
.sidebar-popover-item-sub{font-size:11px;color:var(--gray-500)}
.sidebar-popover-item-icon{
  width:18px;
  text-align:center;
  color:var(--gray-900);
  font-size:14px;
}
.sidebar-popover-divider{
  height:1px;
  background:var(--gray-100);
  margin:6px 4px;
}
.sidebar-popover-danger{color:var(--error-700)!important}
.sidebar-popover-danger:hover{background:var(--error-50)!important}

.sidebar-user-popover-head{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px 12px;
  border-bottom:1px solid var(--gray-100);
  margin-bottom:6px;
}

.sidebar-collapse-toggle{
  position:absolute;
  right:-12px;
  top:50%;
  transform:translateY(-50%);
  width:24px;
  height:24px;
  border-radius:8px;
  border:1px solid var(--gray-200);
  background:var(--white);
  box-shadow:var(--shadow-sm);
  color:var(--gray-500);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
  z-index:101;
  transition:color .15s,background .15s;
}
.sidebar-collapse-toggle:hover{
  color:var(--gray-800);
  background:var(--gray-50);
}
.layout.sidebar-collapsed .sidebar-collapse-toggle svg{transform:rotate(180deg)}

/* Collapsed: icon rail */
.layout.sidebar-collapsed .sidebar-surface{
  margin:10px 8px;
  padding:8px 6px;
  align-items:center;
}
.layout.sidebar-collapsed .sidebar-workspace-text,
.layout.sidebar-collapsed .sidebar-workspace-menu-btn,
.layout.sidebar-collapsed .sidebar-search,
.layout.sidebar-collapsed .nav-label,
.layout.sidebar-collapsed .nav-kbd,
.layout.sidebar-collapsed .nav-arrow,
.layout.sidebar-collapsed .sidebar-section-header,
.layout.sidebar-collapsed .sidebar-user-text,
.layout.sidebar-collapsed .sidebar-user-chev{
  display:none!important;
}
.layout.sidebar-collapsed .sidebar-workspace{
  justify-content:center;
  border-bottom:none;
  padding-bottom:8px;
}
.layout.sidebar-collapsed .sidebar-workspace-brand{
  justify-content:center;
}
.layout.sidebar-collapsed .nav-item,
.layout.sidebar-collapsed .nav-sub-item{
  justify-content:center;
  padding:10px;
}
.layout.sidebar-collapsed .nav-sub{
  padding-left:0;
  border-left:none;
}
.layout.sidebar-collapsed .nav-sub-item span{display:none}
.layout.sidebar-collapsed .nav-sub-item svg.lucide{margin:0}
.layout.sidebar-collapsed .sidebar-bottom .nav-item{padding:10px}
.layout.sidebar-collapsed .sidebar-user-trigger{
  justify-content:center;
  padding:8px;
}
.layout.sidebar-collapsed .sidebar-collapse-toggle{right:-10px}

.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh;transition:margin-left .22s ease}
.topbar{height:var(--topbar-h);background:var(--white);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 24px;gap:12px;position:sticky;top:0;z-index:50}
.topbar-breadcrumb{font-size:13px;color:var(--gray-500)}.topbar-breadcrumb .current{color:var(--gray-700);font-weight:500}
.topbar-right{margin-left:auto;display:flex;gap:8px}
.topbar-icon-btn{width:36px;height:36px;border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);display:flex;align-items:center;justify-content:center;color:var(--gray-900);cursor:pointer;font-size:14px;transition:all .15s}.topbar-icon-btn:hover{background:var(--gray-50);color:var(--gray-900)}
.topbar-pill-btn{
  height:36px;
  border:1px solid #c8d7ff;
  border-radius:999px;
  background:#fff;
  color:#0038ff;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:0 12px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.01em;
  cursor:pointer;
  transition:all .15s;
}
.topbar-pill-btn:hover{background:#edf3ff;border-color:#b7ccff}
.topbar-pill-ai .topbar-ai-ico{
  color:#f5c518 !important;
  stroke:#f5c518 !important;
  filter:drop-shadow(0 0 3px rgba(245,197,24,.65)) drop-shadow(0 0 8px rgba(245,197,24,.45));
  animation:aiGlow 1.8s ease-in-out infinite;
}
.settings-logo-preview{
  width:112px;
  height:112px;
  border-radius:16px;
  border:1px solid var(--gray-200);
  background:var(--white);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gray-700);
  font-size:28px;
  font-weight:700;
  overflow:hidden;
  box-shadow:var(--shadow-xs);
}
.settings-logo-preview img{
  width:100%;
  height:100%;
  object-fit:contain;
  background:var(--white);
}
@keyframes aiGlow{
  0%,100%{opacity:.9;transform:scale(1)}
  50%{opacity:1;transform:scale(1.08)}
}
.ai-chat-shell{padding:14px}
.ai-chat-toolbar{
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;
  border-bottom:1px solid var(--gray-200);padding-bottom:10px;margin-bottom:10px;
}
.ai-chat-messages{
  min-height:360px;max-height:58vh;overflow:auto;
  background:#f8fafc;border:1px solid var(--gray-200);border-radius:12px;
  padding:12px;display:flex;flex-direction:column;gap:10px;
}
.ai-msg{max-width:90%;padding:10px 12px;border-radius:12px;border:1px solid var(--gray-200);background:#fff}
.ai-msg-user{margin-left:auto;background:#edf3ff;border-color:#c9d8ff}
.ai-msg-assistant{margin-right:auto;background:#fff}
.ai-msg-head{font-size:11px;font-weight:700;color:var(--gray-500);margin-bottom:4px;text-transform:uppercase;letter-spacing:.03em}
.ai-msg-body{font-size:13px;color:var(--gray-800);white-space:pre-wrap;line-height:1.5}
.ai-chat-input-wrap{margin-top:12px}
.ai-chat-actions{display:flex;justify-content:flex-end;margin-top:8px}
.btn-mobile-menu{display:none;background:none;border:none;font-size:18px;color:var(--gray-700);cursor:pointer}
/* Rev4: centered forms - max-width on page-content */
.page-content{flex:1;padding:24px 32px;max-width:760px;margin:0 auto;width:100%}
.page-content.page-wide{max-width:1100px}
/* Create Agenda: wider centered column for section accordions */
.page-content.page-agenda-builder{max-width:min(1320px,calc(100vw - 48px));margin-left:auto;margin-right:auto}
.page-hidden{display:none!important}
.page-header{
  margin-bottom:20px;
  padding:14px 16px;
  border:1px solid var(--gray-200);
  border-radius:14px;
  background:linear-gradient(180deg,var(--white) 0%,var(--gray-25) 100%);
  box-shadow:var(--shadow-xs);
}

/* Dashboard header glow */
#page-dashboard .page-header{
  box-shadow:
    0 0 0 1px rgba(232,235,241,.85),
    0 10px 26px rgba(16,24,40,.06);
  border-color:rgba(232,235,241,.95);
}
.page-header h2{
  font-size:22px;
  font-weight:700;
  letter-spacing:-.02em;
  color:var(--gray-900);
  display:flex;
  align-items:center;
  gap:10px;
}
.page-header h2 i,
.page-header h2 svg.lucide{
  width:30px;
  height:30px;
  min-width:30px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px;
  border-radius:10px;
  border:1px solid var(--primary-200);
  background:linear-gradient(145deg,var(--primary-50),var(--white));
  color:var(--primary-700)!important;
  box-shadow:0 1px 2px rgba(41,112,255,.15);
}
.page-header p{
  font-size:13px;
  color:var(--gray-500);
  margin-top:6px;
  max-width:72ch;
}
/* Document History: compact boxed title for long resolution/ordinance names */
#page-doc-history #docHistoryTitle{
  display:inline-block;
  max-width:min(860px,100%);
  font-size:14px;
  font-weight:600;
  line-height:1.35;
  letter-spacing:-.01em;
  padding:8px 12px;
  border:1px solid var(--gray-200);
  border-radius:12px;
  background:var(--gray-25);
  box-shadow:var(--shadow-xs);
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
}
.page-header-actions{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--primary-600);color:var(--white);border-color:var(--primary-600)}.btn-primary:hover{background:var(--primary-700)}
.btn-outline{background:var(--white);color:var(--gray-700);border-color:var(--gray-300)}.btn-outline:hover{background:var(--gray-50)}
.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:10px 20px;font-size:14px}
/* Signature Tracking — compact action */
.btn-view-signed{
    min-height:30px;
    padding:5px 10px;
    font-size:12px;
    font-weight:500;
    border-radius:var(--radius);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:5px;
    box-shadow:none;
    transition:background .12s ease,opacity .12s ease;
}
.btn-view-signed:hover{opacity:.92}
.btn-view-signed .lucide-main{width:14px!important;height:14px!important;flex-shrink:0}
.btn-icon-only{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--white);border:1px solid var(--gray-300);border-radius:var(--radius);color:var(--gray-900);cursor:pointer;font-size:13px;transition:all .15s}.btn-icon-only:hover{background:var(--gray-50);color:var(--gray-900)}.btn-icon-only.danger:hover{background:var(--error-50);color:var(--error-700)}
.vfield{margin-bottom:10px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--gray-700);margin-bottom:2px;line-height:1.35}.form-label .req{color:var(--error-500)}
.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1px solid var(--gray-300);border-radius:var(--radius);font-family:inherit;font-size:14px;color:var(--gray-900);background:var(--white);transition:all .15s}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-300);box-shadow:0 0 0 4px var(--primary-25)}.form-input::placeholder{color:var(--gray-400)}.form-textarea{resize:vertical;min-height:60px}
.sub-desc{font-size:12px;color:var(--gray-400);margin-bottom:12px;font-style:italic}
.file-upload-area{position:relative}.file-input-hidden{position:absolute;opacity:0;width:0;height:0}
.file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;border:2px dashed var(--gray-300);border-radius:var(--radius);cursor:pointer;text-align:center;color:var(--gray-500);font-size:13px;transition:all .15s;min-height:70px}
.file-upload-label:hover{border-color:var(--primary-300);background:var(--primary-25);color:var(--primary-600)}.file-upload-label i{font-size:18px;margin-bottom:4px}.file-upload-label small{font-size:11px;color:var(--gray-400)}
.file-list{margin-top:8px}.file-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);font-size:12px;margin-bottom:4px}
.file-item .fname{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--gray-700);font-weight:500}.file-item .fremove{color:var(--gray-400);cursor:pointer}.file-item .fremove:hover{color:var(--error-500)}
.accordion-section{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);margin-bottom:10px;overflow:hidden;box-shadow:var(--shadow-xs)}
.accordion-header{display:flex;align-items:center;gap:12px;padding:14px 20px;cursor:pointer;transition:background .15s;user-select:none}.accordion-header:hover{background:var(--gray-25)}
.accordion-chevron{color:var(--gray-900);font-size:11px;transition:transform .2s;flex-shrink:0}.accordion-section.open .accordion-chevron{transform:rotate(90deg);transform-origin:center}
.accordion-icon{width:34px;height:34px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.accordion-header-text h3{font-size:14px;font-weight:600}.accordion-header-text p{font-size:12px;color:var(--gray-500);margin-top:1px}
/* Inset body content so fields sit clearly under the section title (not flush with header row) */
.accordion-body{display:none;padding:10px 28px 28px 44px}.accordion-section.open .accordion-body{display:block}
.acc-session{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.acc-ceremonial{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.acc-reports{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.acc-public{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.acc-legislative{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.acc-continuing{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.acc-new{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.acc-sig{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}
.sub-section{padding:12px 0;border-bottom:1px solid var(--gray-100)}.sub-section:last-child{border-bottom:none}
.sub-section-header{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0}.sub-section-header h4{font-size:13px;font-weight:600;color:var(--gray-700)}
.sub-chevron{font-size:10px;color:var(--gray-900);transition:transform .2s}.sub-section.open .sub-chevron{transform:rotate(90deg)}
.sub-section-body{display:none;padding:12px 0 4px}.sub-section.open .sub-section-body{display:block}
.biz-group{margin:10px 0 6px 0;border:1px solid var(--gray-200);border-radius:8px;background:var(--white)}
.biz-group-header{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;user-select:none}
.biz-group-body{display:none;padding:0 8px 6px 20px} /* level 1 indent */
.biz-group.open .biz-group-body{display:block}
.biz-group.open .sub-chevron{transform:rotate(90deg)}
.biz-group .sub-section{margin-left:10px;padding-left:8px;border-left:2px solid var(--gray-200)} /* level 2 indent */
.biz-group .sub-section .rep-items-container{margin-left:14px} /* level 3 indent for item boxes */
.biz-group .sub-section .sub-section-header h4{font-weight:700}
.save-bar{position:sticky;bottom:0;background:var(--white);border-top:1px solid var(--gray-200);padding:16px 0;display:flex;gap:10px;justify-content:flex-end;margin-top:20px;z-index:40}
.table-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs)}
/* Reporting: allow multiselect dropdowns to escape card (otherwise lists are clipped) */
.table-card.report-shell{overflow:visible}
.create-draft-card{padding:22px 26px!important}
.create-draft-form-body{
  margin:8px auto 0;
  max-width:920px;
  padding:0 12px;
}
.table-toolbar{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--gray-200);flex-wrap:wrap}

.ai-sign-toolbar{
  display:flex;
  flex-direction:column;
  gap:10px;
  width:100%;
}
.ai-sign-date-range{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:flex-end;
}
.ai-sign-heading{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:12px;
  font-weight:800;
  color:var(--gray-700);
}
.ai-sign-heading::after{
  content:'';
  flex:1;
  border-bottom:2px dashed var(--gray-200);
}
.ai-sign-toolbar .af-checks{
  justify-content:flex-start;
}
.table-search{position:relative;min-width:200px}.table-search input{width:100%;padding:8px 12px 8px 32px;border:1px solid var(--gray-300);border-radius:var(--radius);font-family:inherit;font-size:13px}.table-search input:focus{outline:none;border-color:var(--primary-300);box-shadow:0 0 0 4px var(--primary-25)}.table-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;color:var(--gray-900);pointer-events:none}
.table-filter-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);font-family:inherit;font-size:13px;font-weight:500;color:var(--gray-700);cursor:pointer;transition:all .15s}.table-filter-btn:hover{background:var(--gray-50)}
.data-table{width:100%;border-collapse:collapse}.data-table th{padding:10px 16px;text-align:left;font-size:12px;font-weight:500;color:var(--gray-500);background:var(--white);border-bottom:1px solid var(--gray-200);white-space:nowrap}
.data-table td{padding:10px 16px;font-size:13px;color:var(--gray-600);border-bottom:1px solid var(--gray-200);vertical-align:middle}.data-table tbody tr:hover{background:var(--gray-25)}.data-table tbody tr:last-child td{border-bottom:none}
.td-title-col{font-weight:500;color:var(--gray-900)}
/* Resolutions / Ordinances — long titles without stretching the table */
.data-table--legislative{table-layout:fixed;width:100%}
.data-table--legislative .th-doc-title{width:56%;white-space:normal;line-height:1.35}
.data-table--legislative .th-doc-actions{width:228px;min-width:228px}
.data-table--legislative td.td-doc-actions-cell{
  width:228px;
  min-width:228px;
  overflow:visible;
  box-sizing:border-box;
  vertical-align:middle;
}
.data-table td.td-doc-actions-cell .doc-table-actions{
  display:flex;
  flex-direction:row;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
  align-items:center;
  max-width:100%;
}
/* Legislative list: horizontal scroll if needed (overrides .table-card overflow:hidden so actions are not clipped) */
.table-card.table-card--table-scroll{overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}
.data-table--legislative td.td-doc-title-cell{
  min-width:0;
  vertical-align:top;
  padding-top:12px;
  padding-bottom:12px;
}
.data-table--legislative .td-doc-title-clamp{
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:3;
  overflow:hidden;
  word-break:break-word;
  overflow-wrap:anywhere;
  line-height:1.45;
  font-size:13px;
  color:var(--gray-800);
  font-weight:500;
}
/* Sponsors (col 2) */
.data-table--legislative td:nth-child(2){
  font-size:12px;
  min-width:0;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  vertical-align:middle;
}
.data-table--legislative td:nth-child(3),
.data-table--legislative td:nth-child(4){
  vertical-align:middle;
}
/* Generic small reading/status pill (used in history header) */
.td-reading-tag{
  display:inline-flex;
  align-items:center;
  padding:2px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
  background:var(--primary-50);
  color:var(--primary-700);
}
/* Rev5: Dashboard stat icons */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:20px}
.stat-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-xs);position:relative}
.stat-card-label{font-size:13px;font-weight:500;color:var(--gray-500);margin-bottom:6px}.stat-card-value{font-size:26px;font-weight:700;letter-spacing:-.02em}

/* Dashboard analytics (React/Tailwind inspired, app theme colors) */
.dashx-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}
.dashx-kpi{background:#fff;border:1px solid #e8ebf1;border-radius:12px;padding:14px 16px;box-shadow:0 0 0 1px rgba(232,235,241,.85), 0 10px 26px rgba(16,24,40,.06)}
.dashx-kpi-label{font-size:12px;color:#667085;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.dashx-kpi-ico{width:18px;height:18px;border-radius:6px;background:#f3f4f8;border:1px solid #e4e7ec;display:inline-flex;align-items:center;justify-content:center}
.dashx-kpi-ico .lucide-main{width:12px;height:12px;color:#667085}
.dashx-kpi-value{font-size:34px;line-height:1.08;font-weight:700;color:#101828;letter-spacing:-.02em}
.dashx-grid-two{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;margin-bottom:14px}
.dashx-card{background:#fff;border:1px solid #e8ebf1;border-radius:14px;padding:14px;box-shadow:0 0 0 1px rgba(232,235,241,.85), 0 12px 30px rgba(16,24,40,.06)}
.dashx-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.dashx-card-head h3{display:flex;align-items:center;gap:8px;font-size:15px;margin:0;color:var(--gray-900)}
.dashx-star-ico{color:#f5b301!important;filter:drop-shadow(0 0 4px rgba(245,179,1,.35))}
.dashx-head-note{font-size:11px;color:var(--gray-500)}
.dashx-period-select{max-width:150px;height:34px;padding:6px 10px;font-size:12px}
.dashx-list{display:flex;flex-direction:column;gap:10px}
.dashx-row{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid #edf0f5;border-radius:10px;background:#fff;box-shadow:0 0 0 1px rgba(237,240,245,.55), 0 10px 26px rgba(16,24,40,.05)}
.dashx-rank{min-width:36px;height:26px;border-radius:999px;border:1px solid #e4e7ec;background:#f8f9fb;color:#475467;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.dashx-rank.is-top{background:#fff7db;border-color:#f5d271;color:#a25c00}
.dashx-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.dashx-row-main{flex:1;min-width:0}
.dashx-row-name{font-size:13px;font-weight:600;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dashx-row-sub{font-size:11px;color:var(--gray-500)}
.dashx-progress{height:8px;background:var(--gray-100);border-radius:999px;overflow:hidden;margin-top:6px}
.dashx-progress>span{display:block;height:100%;background:#6a5ce6}
.dashx-doc-total{font-size:12px;color:var(--gray-600);margin-bottom:8px}
.dashx-bars{display:flex;flex-direction:column;gap:10px}
.dashx-bar-row{display:grid;grid-template-columns:116px 1fr auto;gap:8px;align-items:center}
.dashx-bar-label{font-size:12px;color:var(--gray-700)}
.dashx-bar{height:12px;background:var(--gray-100);border-radius:999px;overflow:hidden}
.dashx-bar>span{display:block;height:100%;background:#66cfd0}
.dashx-bar-val{font-size:12px;color:var(--gray-600);min-width:26px;text-align:right}
.dashx-sig{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.dashx-sig-item{border:1px solid #edf0f5;border-radius:10px;padding:12px;text-align:center;background:#fff;box-shadow:0 0 0 1px rgba(237,240,245,.55), 0 10px 26px rgba(16,24,40,.05)}
.dashx-sig-ico{width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;margin:0 auto 6px}
.dashx-sig-ico .lucide-main{width:14px;height:14px}
.dashx-sig-signed{border-color:#ccebdc;background:#f6fdf9}
.dashx-sig-signed .dashx-sig-ico{background:#e8f8ef;color:#1f8f56}
.dashx-sig-pending{border-color:#f3dfbf;background:#fffaf2}
.dashx-sig-pending .dashx-sig-ico{background:#fff1dd;color:#b76812}
.dashx-sig-total{border-color:#d9dbff;background:#f8f8ff}
.dashx-sig-total .dashx-sig-ico{background:#ececff;color:#5e4fe0}
.dashx-sig-item strong{display:block;font-size:24px;color:var(--gray-900);line-height:1.1}
.dashx-sig-item span{font-size:12px;color:var(--gray-500)}
.dashx-sig-status{margin-top:10px;border:1px solid #edf0f5;border-radius:10px;padding:10px;background:#fff}
.dashx-sig-status-row{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#667085;margin-bottom:6px}
.dashx-sig-status-row strong{font-size:13px;color:#155eef}
.dashx-sig-status-bar{height:10px;background:#eef2f6;border-radius:999px;overflow:hidden}
.dashx-sig-status-bar>span{display:block;height:100%;background:#155eef}
.dashx-dist{display:flex;align-items:flex-end;gap:9px;min-height:210px;padding:8px 4px 2px;border:1px solid #edf0f5;border-radius:10px;background:#fff}
.dashx-dist-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}
.dashx-dist-bar{width:100%;max-width:36px;min-height:8px;border-radius:8px 8px 6px 6px;background:#6a5ce6}
.dashx-dist-val{font-size:11px;color:var(--gray-600)}
.dashx-dist-lbl{font-size:11px;color:var(--gray-500)}

/* subtle per-card accents to mimic clean dashboard screenshot */
#dashKpiAgendas{color:#101828}
#dashKpiDocuments{color:#101828}
#dashKpiSlots{color:#101828}
#dashKpiCompletion{color:#1f8f95}
.stat-icon{width:40px;height:40px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px}
.si-total{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.si-draft{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.si-submitted{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}.si-approved{background:var(--white);border:1px solid var(--gray-200);color:var(--gray-900)}
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:16px;font-size:12px;font-weight:500}.badge-dot{width:6px;height:6px;border-radius:50%}
.badge-draft{background:var(--gray-100);color:var(--gray-700)}.badge-draft .badge-dot{background:var(--gray-500)}
.badge-submitted{background:var(--primary-50);color:var(--primary-700)}.badge-submitted .badge-dot{background:var(--primary-500)}
.badge-approved{background:var(--success-50);color:var(--success-700)}.badge-approved .badge-dot{background:var(--success-500)}
.badge-archived{background:var(--warning-50);color:var(--warning-700)}.badge-archived .badge-dot{background:var(--warning-500)}
.badge-info{background:var(--primary-50);color:var(--primary-700)}
.form-panel{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-xs);animation:slideDown .2s}@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.empty-state{padding:40px 24px;text-align:center}.empty-state-icon{width:44px;height:44px;border-radius:50%;background:var(--white);border:2px solid var(--gray-200);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:18px;color:var(--gray-900)}
.empty-state h4{font-size:14px;font-weight:600;margin-bottom:4px}.empty-state p{font-size:13px;color:var(--gray-500)}
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);transform:translateX(120%);transition:transform .3s;max-width:380px;border:1px solid}.toast.show{transform:translateX(0)}
.toast-success{background:var(--success-50);color:var(--success-700);border-color:#a6f4c5}.toast-error{background:var(--error-50);color:var(--error-700);border-color:#fecdca}.toast-warning{background:var(--warning-50);color:var(--warning-700);border-color:#fedf89}.toast-info{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-200)}
.toast .fa-regular{color:currentColor!important}
.toast .lucide-main,.toast .lucide-toast-ico,.toast svg.lucide{width:18px;height:18px;flex-shrink:0;color:currentColor;stroke:currentColor;fill:none}
.modal-overlay .lucide-main,.modal-overlay svg.lucide{color:var(--gray-900);stroke:currentColor;fill:none}
#pdfSignModalOverlay .btn-primary .lucide-main,#pdfSignModalOverlay .btn.btn-primary .lucide-main{color:var(--white)!important}
/* Lucide in main content (top bar, Create Agenda, dashboard) — thin strokes */
.main svg.lucide,.main .lucide-main{color:var(--gray-900);stroke:currentColor;fill:none}
.btn-primary .lucide-main,.btn.btn-primary .lucide-main{color:var(--white)!important}
.btn-outline .lucide-main{color:var(--gray-800)}
.btn-mobile-menu .lucide-main,.topbar-icon-btn .lucide-main{width:18px;height:18px}
.topbar-breadcrumb svg.lucide,.topbar-breadcrumb .lucide-breadcrumb-ico{width:13px;height:13px;vertical-align:middle;display:inline-block}
.lucide-btn-ico{width:16px;height:16px;flex-shrink:0}
.btn-lg .lucide-btn-ico{width:17px;height:17px}
.main .accordion-icon svg.lucide,.main .lucide-acc-ico{width:17px;height:17px}
.main .accordion-chevron svg.lucide,.main .lucide-chevron{width:14px;height:14px;flex-shrink:0}
.main .stat-icon svg.lucide{width:18px;height:18px}
.main .empty-state-icon svg.lucide{width:18px;height:18px}
.main .table-search .table-search-icon{display:flex;align-items:center;justify-content:center}
.main .table-search .table-search-icon svg.lucide,.main .lucide-search-ico{width:15px;height:15px}
.hidden{display:none!important}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:99}.sidebar-overlay.show{display:block}
.sig-preview{max-width:200px;border:1px solid var(--gray-200);border-radius:var(--radius);padding:8px;margin-bottom:8px}.sig-preview img{width:100%;height:auto}
/* Rev2: View modal */
.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  z-index:200;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px 20px; /* consistent breathing room around modal */
  box-sizing:border-box;
  animation:fadeIn .15s;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-box{
  background:var(--white);
  border-radius:16px;
  box-shadow:var(--shadow-lg);
  width:100%;
  max-width:540px;   /* modern card width so it never feels cut */
  max-height:85vh;
  display:flex;
  flex-direction:column;
  box-sizing:border-box;
  overflow:hidden;
  animation:slideUp .2s;
}
.modal-box.modal-lg{max-width:800px}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 18px;
  border-bottom:1px solid var(--gray-200);
}
.modal-header h3{font-size:15px;font-weight:600}
.btn-close-modal{background:none;border:none;font-size:16px;color:var(--gray-400);cursor:pointer;padding:4px}.btn-close-modal:hover{color:var(--gray-700)}
.modal-body{
  padding:16px 18px 18px;
  overflow-y:auto;
  flex:1;
}
/* Rev2: Professional agenda view styling */
.agenda-view{font-size:13px;color:var(--gray-700)}
.av-header{text-align:center;padding:20px;border-bottom:2px solid var(--gray-900);margin-bottom:16px}
.av-header h2{font-size:18px;font-weight:700;color:var(--gray-900)}.av-header p{color:var(--gray-500);font-size:12px;margin-top:2px}
.av-ref{display:inline-block;background:var(--primary-50);color:var(--primary-700);padding:4px 14px;border-radius:16px;font-weight:600;font-size:12px;margin-top:8px}
.av-section{margin-bottom:16px}.av-section-title{font-size:14px;font-weight:700;color:var(--gray-900);padding:8px 0;border-bottom:1px solid var(--gray-200);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.av-section-title i{color:var(--primary-500);font-size:13px}
.av-sub{margin-bottom:10px;padding-left:12px;border-left:3px solid var(--gray-200)}.av-sub-title{font-weight:600;font-size:13px;color:var(--gray-800);margin-bottom:4px}
.av-field{display:flex;padding:3px 0;font-size:12px}.av-field-label{width:160px;color:var(--gray-500);flex-shrink:0;font-weight:500}.av-field-value{color:var(--gray-800);flex:1}
.av-field.av-field-box{
  align-items:flex-start;
  padding:6px 0;
}
.av-field.av-field-box .av-field-value{
  border:1px solid var(--gray-200);
  background:var(--gray-25);
  border-radius:10px;
  padding:10px 12px;
  line-height:1.5;
  min-height:42px;
}
.av-field.av-field-box.av-field-box-desc .av-field-value{
  min-height:96px;
  white-space:pre-wrap;
}
.av-signatures{display:flex;gap:24px;margin-top:20px;padding-top:16px;border-top:2px solid var(--gray-900)}
.av-sig-block{flex:1;text-align:center}.av-sig-block p{font-size:12px;color:var(--gray-500)}.av-sig-block .av-sig-name{font-weight:600;color:var(--gray-900);margin-top:24px;border-top:1px solid var(--gray-900);padding-top:4px;display:inline-block;min-width:140px}
/* Shadowed box sections inside full-page views */
.shadow-box{
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-xs);
  padding:14px 16px;
}
/* Compact, centered cards inside First Reading repeater */
.fr-item{
  margin:4px 0;
  display:flex;
  justify-content:center; /* center card within the sub-section width */
}
.fr-item .accordion-section{
  margin-bottom:6px;
  border-radius:10px;
  max-width:88%; /* slightly narrower than full width for clearer UI */
  width:100%;
}
.fr-item .accordion-header{
  padding:10px 14px;
  background:var(--gray-50);
}
.fr-item .accordion-body{
  padding:10px 18px 14px 32px;
}
.fr-item .accordion-header h3{
  font-size:12px;
  font-weight:600;
  padding:2px 8px;
  border-radius:999px;
  background:var(--primary-50);
  color:var(--primary-700);
}
/* Professional pagination */
.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--gray-200);font-size:13px;color:var(--gray-500)}
.table-pagination:empty{display:none}
.pag-info{font-size:13px;color:var(--gray-500)}
.pag-info strong{color:var(--gray-700);font-weight:600}
.pag-controls{display:flex;align-items:center;gap:2px}
.pag-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);color:var(--gray-600);cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;transition:all .15s}
.pag-btn:hover:not(:disabled):not(.pag-active){background:var(--gray-50);color:var(--gray-900)}
.pag-btn:disabled{opacity:.4;cursor:default}
.pag-btn.pag-active{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-200);font-weight:600}
.pag-btn.pag-arrow{font-size:12px}
.pag-dots{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--gray-400);font-size:12px}
/* Table row number column */
.td-num{color:var(--gray-400);font-size:12px;text-align:center;font-weight:500}
/* Role badges */
.role-badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.02em}
.role-admin{background:#fef3c7;color:#92400e}.role-staff{background:#e0f2fe;color:#075985}.role-department{background:#ecfdf3;color:#166534}.role-visitor{background:#f3f4f6;color:#374151}.role-proponent{background:#dbeafe;color:#1e40af}.role-councilor{background:#ede9fe;color:#5b21b6}
/* Reporting — row attachment modal */
.report-att-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.report-att-item{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--gray-25)}
.report-att-name{font-weight:600;font-size:13px;color:var(--gray-900);flex:1;min-width:0;word-break:break-word}
.report-att-meta{font-size:11px;color:var(--gray-500);width:100%}
.report-att-actions{margin-left:auto;flex-shrink:0}
.th-report-files{font-weight:600}
/* Reporting — batched ZIP export progress */
.report-export-modal .modal-header{align-items:flex-start;gap:12px}
.report-export-modal .modal-header h3{margin:0}
.report-export-lead{margin:6px 0 0;font-size:13px;font-weight:400;color:var(--gray-500);line-height:1.4}
.report-export-body{padding-top:12px}
.report-export-progress-wrap{margin-bottom:12px}
.report-export-progress-track{height:10px;border-radius:999px;background:var(--gray-100);overflow:hidden;border:1px solid var(--gray-200)}
.report-export-progress-fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));transition:width .25s ease}
.report-export-progress-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;font-size:13px;font-weight:600;color:var(--gray-800)}
.report-export-pct{color:var(--primary-700);font-variant-numeric:tabular-nums}
.report-export-batch{font-weight:500;color:var(--gray-600);font-size:12px;text-align:right}
.report-export-detail{margin:0 0 8px;font-size:13px;color:var(--gray-700);min-height:1.35em;line-height:1.45}
.report-export-hint{margin:0;font-size:12px;color:var(--gray-500);line-height:1.5}
/* Advanced filter panel */
.adv-filter-panel{padding:16px 20px;border-bottom:1px solid var(--gray-200);background:var(--gray-25);animation:slideDown .2s}
.af-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px}.af-row:last-child{margin-bottom:0}
.af-group{flex:1;min-width:160px}.af-label{display:block;font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.af-checks{display:flex;flex-wrap:wrap;gap:6px}
.af-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--gray-300);border-radius:20px;font-size:12px;font-weight:500;color:var(--gray-600);cursor:pointer;transition:all .15s;user-select:none;background:var(--white)}
.af-chip:hover{border-color:var(--primary-300);color:var(--primary-600)}
.af-chip input[type="checkbox"]{display:none}
.af-chip:has(input:checked){background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700);font-weight:600}
.af-select{min-height:36px;font-size:12px;padding:4px 8px}
.af-select option{padding:4px 8px}
.af-select option:checked{background:var(--primary-50);color:var(--primary-700)}
.af-date{font-size:12px;padding:6px 10px}
.af-active-count{display:inline-flex;align-items:center;justify-content:center;background:var(--primary-500);color:var(--white);font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;margin-left:4px}

/* Tailwind-inspired searchable multi-select (chips + dropdown) */
.ms-wrap{position:relative;width:100%}
.ms-hidden-select{display:none}
.ms-control{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  padding:8px 10px;
  border:1px solid var(--gray-300);
  border-radius:var(--radius);
  background:var(--white);
  cursor:text;
  transition:all .15s;
  min-height:44px;
}
.ms-control:focus-within{border-color:var(--primary-300);box-shadow:0 0 0 4px var(--primary-25)}
.ms-search{
  border:none;
  outline:none;
  flex:1;
  min-width:160px;
  font-size:13px;
  padding:2px 0;
  color:var(--gray-900);
  background:transparent;
}
.ms-chips{display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.ms-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:4px 10px;
  border-radius:999px;
  background:var(--primary-50);
  border:1px solid var(--primary-200);
  color:var(--primary-700);
  font-size:12px;
  font-weight:600;
  white-space:nowrap;
}
.ms-chip-remove{cursor:pointer;color:var(--primary-700);user-select:none}
.ms-chip-remove:hover{color:var(--error-700)}
.ms-dropdown{
  position:absolute;
  left:0;right:0;
  top:calc(100% + 6px);
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  z-index:150;
  max-height:260px;
  overflow:auto;
}
.ms-option{
  padding:9px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  font-size:13px;
  color:var(--gray-700);
  user-select:none;
}
.ms-option:hover{background:var(--primary-25)}
.ms-option.selected{
  background:var(--primary-50);
  color:var(--primary-700);
  font-weight:700;
}
.ms-option-check{
  width:18px;height:18px;border-radius:6px;
  border:1px solid var(--gray-300);
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-400);
  flex-shrink:0;
}
.ms-option.selected .ms-option-check{
  border-color:var(--primary-200);
  background:var(--primary-50);
  color:var(--primary-700);
}
.ms-option-text{flex:1;min-width:0}

/* Create Agenda — For Signatures: selected rows + cards */
.agenda-sig-row-selected{
  background:var(--primary-25);color:var(--gray-900);
  box-shadow:inset 3px 0 0 var(--primary-500);
}
.agenda-sig-row-selected td{border-bottom-color:var(--primary-100);}

.agenda-sig-selected-card{
  border:1px solid var(--primary-200);
  background:linear-gradient(180deg,var(--primary-25) 0%,var(--white) 48px);
  box-shadow:var(--shadow-sm),0 0 0 1px rgba(41,112,255,.06);
}
.agenda-sig-selected-card .td-title-col{color:var(--primary-700);}
/* Sidebar dropdown nav */
.nav-has-sub{position:relative}.nav-has-sub .nav-arrow{margin-left:auto;font-size:10px;transition:transform .2s;color:var(--gray-900)}.nav-has-sub.open .nav-arrow{transform:rotate(180deg)}
.nav-sub{
  padding:4px 0 6px 12px;
  margin-left:8px;
  border-left:2px solid var(--gray-100);
  display:flex;
  flex-direction:column;
  gap:2px;
}
.nav-sub-item{
  display:flex;
  align-items:center;
  gap:8px;
  padding:7px 10px 7px 8px;
  border-radius:10px;
  font-size:12px;
  font-weight:500;
  color:var(--gray-600);
  cursor:pointer;
  border:none;
  background:none;
  width:100%;
  text-align:left;
  font-family:inherit;
  transition:background .15s,color .15s;
}
.nav-sub-item:hover{background:var(--gray-50);color:var(--gray-900)}
.nav-sub-item.active{
  background:#edf3ff;
  color:#0038ff;
  font-weight:600;
}
.nav-sub-item svg.lucide{color:var(--gray-900);flex-shrink:0}
.nav-sub-item.active svg.lucide{color:#0038ff}
.nav-sub-item span{flex:1;min-width:0;text-align:left}
/* Table tabs */
.table-tabs{display:flex;gap:0;border:1px solid var(--gray-300);border-radius:var(--radius);overflow:hidden;flex-shrink:0}
.table-tab{padding:6px 12px;font-size:12px;font-weight:500;color:var(--gray-500);background:var(--white);border:none;border-right:1px solid var(--gray-300);cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}
.table-tab:last-child{border-right:none}.table-tab:hover{background:var(--gray-50);color:var(--gray-700)}.table-tab.active{background:var(--gray-50);color:var(--gray-900);font-weight:600}
/* Reading status badges */
.badge-first{background:#fef3c7;color:#92400e}.badge-first .badge-dot{background:#f59e0b}
.badge-second{background:#dbeafe;color:#1e40af}.badge-second .badge-dot{background:#3b82f6}
.badge-third{background:#ede9fe;color:#5b21b6}.badge-third .badge-dot{background:#8b5cf6}
/* Modal xl */
.modal-box.modal-xl{
  max-width:1000px;
  max-height:90vh;
  width:100%;
  margin:0 20px; /* explicit 20px left/right margin */
}
/* PDF sign modal: left sidebar + right portrait viewer */
.modal-box.pdf-sign-modal{
  max-height:min(94vh,920px);
  min-height:0;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.modal-box.pdf-sign-modal-wide{
  max-width:min(1180px,98vw);
  width:100%;
}
.pdf-sign-modal-header{
  flex-shrink:0;
  padding:12px 16px;
  border-bottom:1px solid var(--gray-200);
}
.pdf-sign-header-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
}
.pdf-sign-body-split{
  display:flex;
  flex:1 1 auto;
  min-height:0;
  overflow:hidden;
}
.pdf-sign-sidebar{
  width:min(300px,32vw);
  min-width:260px;
  flex-shrink:0;
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:14px 14px 16px;
  border-right:1px solid var(--gray-200);
  background:var(--gray-25);
  overflow-y:auto;
  overflow-x:hidden;
}
.pdf-sign-sidebar-title{
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--gray-500);
}
.pdf-sign-toolbar-vertical{
  display:flex;
  flex-direction:column;
  gap:10px;
  width:100%;
}
.pdf-sign-field{
  display:flex;
  flex-direction:column;
  min-width:0;
}
.pdf-sign-field .form-label{
  font-size:12px;
  margin-bottom:4px;
  color:var(--gray-700);
}
.pdf-sign-add-full{width:100%;justify-content:center}
.pdf-sign-help{
  font-size:11px;
  line-height:1.45;
  color:var(--gray-600);
  margin:0;
  padding:10px 10px;
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:var(--radius);
}
.pdf-sign-user-select{
  width:100%;
  padding:8px 10px;
  font-size:13px;
}
.pdf-sign-viewer-column{
  flex:1 1 55%;
  min-width:0;
  min-height:0;
  display:flex;
  flex-direction:column;
  background:var(--gray-100);
}
/* Main viewer area: portrait column — PDF scales to width */
.modal-body.pdf-sign-modal-body{
  flex:1 1 auto;
  min-height:0;
  max-height:none;
  display:flex;
  flex-direction:column;
  padding:0 !important;
  overflow:hidden;
  background:var(--gray-100);
  position:relative;
}
.pdf-sign-scroll{
  flex:1 1 auto;
  min-height:200px;
  overflow:auto;
  padding:14px 16px 18px;
  text-align:center;
}
.pdf-sign-pdf-wrap{
  display:inline-block;
  text-align:left;
  max-width:100%;
}
.pdf-sign-canvas-stack{
  position:relative;
  display:inline-block;
  vertical-align:top;
  max-width:100%;
}
.pdf-sign-overlays{
  position:absolute;
  left:0;
  top:0;
  pointer-events:none;
}
#pdfViewerContainer canvas,
.pdf-sign-pdf-wrap canvas{
  max-width:100%;
  height:auto;
}
.pdf-sign-pagebar{
  flex-shrink:0;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-top:1px solid var(--gray-200);
  background:var(--white);
}
.pdf-sign-page-info{
  font-size:12px;
  color:var(--gray-500);
  min-width:100px;
}
.pdf-sign-pagebar-actions{
  margin-left:auto;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.pdf-sign-assigned-panel{
  flex:1 1 auto;
  min-height:120px;
  max-height:280px;
  overflow-y:auto;
  padding:10px 0 0;
  margin-top:4px;
  border-top:1px dashed var(--gray-300);
}
.pdf-sign-assigned-title{
  font-size:12px;
  font-weight:600;
  color:var(--gray-800);
  margin-bottom:8px;
}
.pdf-sign-list{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:13px;
  color:var(--gray-700);
}
.pdf-sign-list--empty{
  color:var(--gray-500);
  font-style:italic;
  padding:4px 0;
}
.pdf-sign-list-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:var(--radius);
  box-shadow:var(--shadow-xs);
}
.pdf-sign-list-avatar{
  width:32px;
  height:32px;
  border-radius:var(--radius);
  background:var(--primary-50);
  color:var(--primary-600);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  font-size:13px;
}
.pdf-sign-list-main{flex:1;min-width:0}
.pdf-sign-list-name{font-weight:600;color:var(--gray-900);font-size:12px}
.pdf-sign-list-role{font-size:11px;color:var(--gray-500);margin-top:1px}
.pdf-sign-list-status{flex-shrink:0}
.pdf-sign-slot{
  display:inline-block;
  font-size:10px;
  font-weight:700;
  padding:1px 6px;
  border-radius:4px;
  background:var(--primary-100);
  color:var(--primary-700);
  vertical-align:middle;
}
.sig-slot-badge{
  display:inline-block;
  font-size:9px;
  font-weight:700;
  padding:0 4px;
  border-radius:3px;
  background:var(--primary-100);
  color:var(--primary-700);
  vertical-align:middle;
}
.sig-overlay{
  position:absolute;
  border:2px dashed var(--primary-300);
  background:rgba(41,112,255,.08);
  padding:4px 8px;
  border-radius:4px;
  font-size:11px;
  color:var(--primary-700);
  cursor:move;
  user-select:none;
  display:flex;
  align-items:center;
  gap:4px;
  /* make blue tag boxes resizable for large text */
  resize:both;
  overflow:auto;
  min-width:140px;
  min-height:32px;
  max-width:100%;
}
.sig-overlay.sig-signed{
  border:2px solid rgba(18,183,106,.35);
  background:rgba(18,183,106,.08);
  padding:4px;
  resize:none;
  overflow:hidden;
}
.sig-overlay .sig-remove{cursor:pointer;color:var(--error-500);font-size:12px}
/* File item with sign button */
.file-item .fsign{color:var(--primary-500);cursor:pointer;font-size:12px;margin-left:4px}.file-item .fsign:hover{color:var(--primary-700)}
/* ═══ Reporting (Tailwind-inspired) ═══ */
.report-shell-head{padding:16px 18px;border-bottom:1px solid var(--gray-200);background:linear-gradient(180deg,var(--gray-25) 0%,var(--white) 100%)}
.report-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.report-tab{border:1px solid var(--gray-200);background:var(--white);color:var(--gray-600);font-size:12px;font-weight:600;padding:7px 14px;border-radius:999px;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s,color .15s}
.report-tab:hover{background:var(--gray-50);color:var(--gray-900)}
.report-tab.active{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700);box-shadow:0 0 0 1px rgba(41,112,255,.06)}
.report-toolbar-wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;width:100%}
.report-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.report-toolbar-end{margin-left:auto}
@media(max-width:640px){
  .report-toolbar-wrap{flex-direction:column;align-items:stretch}
  .report-toolbar-end{margin-left:0;justify-content:flex-end}
}
.report-filter-panel{padding:16px 18px 18px;border-bottom:1px solid var(--gray-200);background:var(--white);position:relative;z-index:1}
.report-shell{overflow:visible}
.report-filter-panel,.report-filter-grid,.report-field{overflow:visible}
.report-filter-row--dates{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:14px}
.report-field{min-width:140px}
.report-field-grow{flex:1;min-width:220px}
.report-field-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);margin-bottom:6px}
.report-filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;position:relative}
/* Reporting: chip multiselects (Tailwind-style, scoped) */
.report-filter-panel .report-ms-wrap .ms-control{
  min-height:46px;
  border-radius:10px;
  border:1px solid var(--gray-200);
  box-shadow:var(--shadow-xs);
  transition:border-color .15s,box-shadow .15s;
}
.report-filter-panel .report-ms-wrap .ms-control:focus-within{
  border-color:var(--primary-300);
  box-shadow:0 0 0 3px var(--primary-25),var(--shadow-xs);
}
.report-filter-panel .report-ms-wrap .ms-search{
  min-width:100px;
  font-size:12px;
}
.report-filter-panel .report-ms-wrap .ms-search::placeholder{color:var(--gray-400);font-weight:400}
.report-filter-panel .report-ms-wrap{
  position:relative;
  z-index:1;
}
.report-filter-panel .report-ms-wrap:focus-within{
  z-index:80;
}
.report-filter-panel .report-ms-wrap.ms-open{
  z-index:180;
}
.report-filter-panel .report-ms-wrap .ms-dropdown{
  max-height:240px;
  border-radius:12px;
  box-shadow:0 12px 24px -6px rgba(16,24,40,.12),0 4px 8px -2px rgba(16,24,40,.06);
  scrollbar-width:thin;
  scrollbar-color:var(--gray-300) transparent;
  z-index:190;
  position:absolute;
}
.report-filter-panel .report-ms-wrap--committees .ms-dropdown{
  max-height:min(380px,55vh);
}
.report-filter-panel .report-ms-wrap .ms-dropdown::-webkit-scrollbar{width:7px;height:7px}
.report-filter-panel .report-ms-wrap .ms-dropdown::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:6px}
.report-filter-panel .report-ms-wrap .ms-dropdown::-webkit-scrollbar-track{background:transparent}
.report-filter-panel .report-ms-wrap .ms-chip{font-size:11px;padding:3px 9px}
.report-filter-panel .report-ms-wrap .ms-chip-remove{font-size:14px;line-height:1;font-weight:500;opacity:.75;padding:0 2px}
.report-filter-panel .report-ms-wrap .ms-chip-remove:hover{opacity:1}
.report-ms-empty{padding:14px 12px;font-size:12px;color:var(--gray-500);text-align:left}
.adv-filter-panel .ms-control{
  min-height:40px;
  border-color:#dbe3ef;
  background:#fff;
}
.adv-filter-panel .ms-control:focus-within{
  border-color:#b7ccff;
  box-shadow:0 0 0 4px rgba(0,56,255,.08);
}
.adv-filter-panel .ms-dropdown{
  border-color:#e2e8f3;
  box-shadow:0 10px 24px rgba(17,24,39,.10);
}
.report-results-head{padding:10px 18px;border-bottom:1px solid var(--gray-100);background:var(--gray-25)}
.report-results-meta{font-size:12px;font-weight:500;color:var(--gray-600)}
.report-table-wrap{overflow:auto;max-height:min(520px,55vh);border-top:1px solid var(--gray-100)}
.report-data-table{margin:0}
.report-data-table th,.report-data-table td{font-size:11px;padding:8px 10px;vertical-align:middle}
.report-data-table td{max-width:min(320px,28vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.report-section-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;margin:0;color:var(--gray-900)}
.report-print-mount{display:none}

/* Notifications bell + popover (tailwind-inspired card) */
.notif-bell-btn{position:relative}
.notif-bell-btn.notif-bell-clicked{
  color:var(--primary-600)!important;
  border-color:var(--primary-200)!important;
  background:var(--primary-50)!important;
}
.notif-dot{
  position:absolute;top:2px;right:2px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;
  background:var(--error-500);border:2px solid var(--white);color:#fff;
  font-size:10px;font-weight:700;line-height:14px;display:flex;align-items:center;justify-content:center;
}
.notif-popover{
  position:absolute;top:62px;right:24px;width:min(420px,92vw);max-height:70vh;
  background:var(--white);border:1px solid var(--gray-200);border-radius:12px;
  box-shadow:var(--shadow-lg);z-index:85;display:flex;flex-direction:column;overflow:hidden;
}
.notif-popover-head,.notif-popover-foot{
  padding:10px 12px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;
}
.notif-popover-foot{border-bottom:none;border-top:1px solid var(--gray-100)}
.notif-link-btn{border:none;background:none;color:var(--primary-600);font-size:12px;font-weight:600;cursor:pointer}
.notif-popover-list{overflow:auto;max-height:52vh}
.notif-item{
  width:100%;text-align:left;border:none;background:var(--white);padding:10px 12px;cursor:pointer;
  border-bottom:1px solid var(--gray-100);
}
.notif-item:hover{background:var(--gray-25)}
.notif-item.unread{background:var(--primary-25)}
.notif-item-row{display:flex;align-items:flex-start;gap:10px}
.notif-item-main{min-width:0;flex:1}
.notif-avatar{
  width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;letter-spacing:.01em;flex-shrink:0;border:1px solid rgba(16,24,40,.08);
}
.notif-item-title{font-size:13px;font-weight:600;color:var(--gray-900)}
.notif-item-msg{font-size:12px;color:var(--gray-600);margin-top:2px}
.notif-item-time{font-size:11px;color:var(--gray-400);margin-top:4px}

/* Print: landscape report with margins (PDF via browser print) */
body.report-print-mode #sidebarOverlay,
body.report-print-mode #appLayout,
body.report-print-mode .toast-container{display:none!important}
body.report-print-mode #reportPrintMount{
  display:block!important;
  position:static!important;
  width:100%!important;
  min-height:100vh!important;
  margin:0!important;
  padding:10mm 12mm 12mm!important;
  box-sizing:border-box!important;
  background:#fff!important;
  color:var(--gray-900)!important;
  font-family:Inter,-apple-system,sans-serif!important;
  font-size:9.5pt!important;
  line-height:1.35!important;
}
.rp-doc{margin:0 0 10px;font-size:15pt;font-weight:700;letter-spacing:-.02em;color:var(--gray-900)}
.rp-meta{font-size:9pt;color:var(--gray-600);margin:0 0 14px;line-height:1.45}
.rp-filters{font-size:8.5pt;color:var(--gray-700);margin:0 0 12px;padding:8px 10px;border:1px solid var(--gray-200);border-radius:8px;background:var(--gray-25)}
.rp-table{width:100%;border-collapse:collapse;font-size:8.5pt}
.rp-table th,.rp-table td{border:1px solid var(--gray-300);padding:5px 7px;text-align:left;vertical-align:top}
.rp-table th{background:var(--gray-100);font-weight:600;color:var(--gray-800);font-size:8pt}
.rp-foot{margin-top:12px;font-size:8pt;color:var(--gray-500)}

/* Audit trail (tailwind-inspired structure, same app tokens/theme) */
.audit-shell{padding:0;overflow:hidden}
.audit-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid var(--gray-200);
  background:linear-gradient(180deg,var(--gray-25) 0%,var(--white) 100%);
}

/* Committee Management hero (React/Tailwind-inspired) */
.cm-hero{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:16px 18px;
  border:1px solid #e8ebf1;
  border-radius:14px;
  background:linear-gradient(180deg,#ffffff 0%,#f9fbff 100%);
  box-shadow:0 1px 2px rgba(16,24,40,.04);
  margin-bottom:12px;
}
.perf-hero-flat{
  background:#fff !important;
  box-shadow:none !important;
  border-color:#eaecf0 !important;
}
.cm-hero-main{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.cm-hero-ico{
  width:40px;
  height:40px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#eef4ff;
  border:1px solid #dbe7ff;
  color:#2458d6;
  flex-shrink:0;
}
.cm-hero-ico .lucide-main{width:18px;height:18px;color:#2458d6}
.cm-hero-ico.cm-hero-ico-warn{
  background:#fff4e8;
  border-color:#ffe3c5;
  color:#b56a12;
}
.cm-hero-ico.cm-hero-ico-warn .lucide-main{color:#b56a12}
.pers-hero-btn{
  background:#fff!important;
  border-color:#dfe3ea!important;
  color:#344054!important;
  font-weight:600;
}
.pers-hero-btn:hover{
  background:#f8fafc!important;
  border-color:#cfd6e1!important;
  color:#1d2939!important;
}
.pers-hero-btn .lucide-main{color:currentColor!important}
.cm-hero-text h2{
  margin:0;
  font-size:20px;
  line-height:1.2;
  color:#101828;
  letter-spacing:-.02em;
}
.cm-hero-text p{
  margin:3px 0 0 0;
  font-size:13px;
  color:#667085;
}

/* Performances page */
.perf-card{overflow:hidden}
.perf-table thead th{font-weight:600;color:var(--gray-600)}
.perf-person-cell{display:flex;align-items:center;gap:10px}
.perf-avatar{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.perf-rank{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:26px;border-radius:999px;border:1px solid #e4e7ec;background:#f8fafc;color:#475467;font-size:12px;font-weight:700}
.perf-rank.is-top{background:#fff7db;border-color:#f3d07e;color:#9a5b00}
.perf-chip{display:inline-flex;align-items:center;justify-content:center;min-width:46px;height:28px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:700}
.perf-chip-auth{background:#edf3ff;color:#0038ff}
.perf-chip-spon{background:#ecfdf3;color:#027a48}
.perf-chip-total{background:#f4f3ff;color:#5925dc}
.perf-table .perf-chip{white-space:nowrap}
.arv-shell .agenda-view{
  border:1px solid #e8ebf1;
  border-radius:12px;
  background:#fff;
  padding:14px;
}
.arv-shell .av-header{
  border:1px solid #e8ebf1;
  border-radius:12px;
  background:#f8fbff;
  padding:14px;
  margin-bottom:12px;
  text-align:left;
}
.arv-shell .av-box-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:10px;
}
.arv-shell .av-sub-box{
  border:1px solid #e8ebf1;
  border-radius:12px;
  background:#fff;
  padding:12px;
  margin-bottom:8px;
}
.arv-shell .av-attach-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.arv-shell .av-attach-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  border:1px solid #e8ebf1;
  border-radius:10px;
  padding:8px 10px;
  background:#fdfdff;
}
.arv-shell .av-attach-name{
  font-size:12px;
  color:var(--gray-700);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.arv-shell .av-section-title,
.arv-shell .av-sub-title{
  text-align:left;
}
.arv-shell .av-number-list{
  margin:6px 0 0 18px;
  padding:0;
  color:var(--gray-700);
}
.arv-shell .av-number-list li{
  margin:0 0 8px 0;
  line-height:1.45;
  text-align:left;
}
.audit-filters{
  display:flex;
  gap:10px;
  align-items:flex-end;
  flex-wrap:wrap;
}
.audit-field{min-width:140px}
.audit-field .form-label{font-size:11px;color:var(--gray-500);margin-bottom:6px}
.audit-search-wrap{max-width:360px;min-width:260px}
.audit-table-wrap{
  overflow:auto;
  max-height:min(62vh,760px);
}
.audit-table-wrap .data-table th{
  position:sticky;
  top:0;
  z-index:2;
  background:var(--gray-50);
}

@media print{
/* US Legal 8.5×14 in — landscape (print / Save as PDF) */
@page{size:legal landscape;margin:12mm 14mm 14mm 14mm}
.modal-header,.btn-close-modal,.topbar,.sidebar,.sidebar-overlay{display:none!important}
.modal-overlay{position:static;background:none}
.modal-box{max-width:100%;max-height:none;box-shadow:none;border:none;width:100%}
body.report-print-mode #sidebarOverlay,
body.report-print-mode #appLayout,
body.report-print-mode .toast-container{display:none!important}
body.report-print-mode #reportPrintMount{display:block!important}
}
@media(max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}.sidebar-overlay.show{display:block}.main{margin-left:0}.btn-mobile-menu{display:flex!important;align-items:center;justify-content:center;padding:6px}.page-content{max-width:100%}}
@media(max-width:640px){.page-content{padding:16px}.stats-grid{grid-template-columns:1fr 1fr}.table-toolbar{flex-direction:column;align-items:stretch}.table-search{min-width:auto}.audit-toolbar{align-items:stretch;flex-direction:column}.audit-search-wrap{min-width:100%;max-width:100%}.dashx-kpis{grid-template-columns:1fr 1fr}.dashx-grid-two{grid-template-columns:1fr}.dashx-bar-row{grid-template-columns:90px 1fr auto}}
