/* Special Olympics Ireland — Ireland Summer Games 2026 theme */
@import url('https://fonts.googleapis.com/css2?family=Ubuntu:wght@400;500;600;700&display=swap');

:root {
  /* Ireland Summer Games palette from logo */
  --primary: #006EB9;
  --primary-green: #7BCC42;
  --accent-green: #005020;
  --primary-rgb: 0, 110, 185;
  --bg: #f0f7f2;
  --surface: #fff;
  --border: #c5ddce;
  --text: #1a2e24;
  --text-muted: #2d4138;
  --danger: #7f262f;
}

/* Visually hidden, available to screen readers */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

* { box-sizing: border-box; }

/* Lock viewport so only sidebar/content scroll, not the page */
html {
  height: 100%;
  min-height: 100%;
  overflow: hidden;
}
body {
  margin: 0;
  height: 100%;
  min-height: 100vh;
  max-height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  font-family: 'Ubuntu', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text);
  background: var(--bg);
}
body.login-page {
  min-height: 100vh;
  max-height: none;
}

/* Login */
.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.login-box {
  width: 100%;
  max-width: 360px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 24px;
}
.login-box .site-logo {
  width: 100%;
  max-width: 240px;
  height: auto;
  display: block;
  margin: 0 auto 8px auto;
  object-fit: contain;
}
.login-box h1 {
  margin: 0 0 4px 0;
  font-size: 20px;
  font-weight: 600;
  color: var(--accent-green);
  text-align: center;
}
.login-subtitle {
  margin: 0 0 20px 0;
  color: var(--text-muted);
  font-size: 13px;
  text-align: center;
}
.login-form label {
  display: block;
  margin-top: 12px;
  margin-bottom: 4px;
  font-weight: 500;
}
.login-form input {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 14px;
}
.login-form button {
  margin-top: 16px;
  width: 100%;
  padding: 10px;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
}
.login-form button:hover { opacity: 0.9; }
.error { color: var(--danger); font-size: 13px; margin-top: 8px; }

/* App shell */
.app-header {
  flex-shrink: 0;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 12px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.app-header .site-logo {
  height: 40px;
  width: auto;
  display: block;
  object-fit: contain;
}
.app-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--text);
  font-weight: 600;
  font-size: 18px;
}
.app-brand:hover { color: var(--text); opacity: 0.9; }
.app-brand-name { white-space: nowrap; }
.app-nav a.active { color: var(--accent-green); }
.app-nav {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.app-nav .app-nav-link,
.app-nav .nav-dropdown-trigger {
  color: var(--text);
  text-decoration: none;
  padding: 6px 12px;
  border-radius: 4px;
  border: none;
  background: none;
  font: inherit;
  cursor: pointer;
}
.app-nav a.app-nav-link:hover,
.app-nav .nav-dropdown-trigger:hover { background: var(--bg); }
.app-nav a.active { background: rgba(0, 80, 32, 0.1); font-weight: 600; }
.app-nav .logout { color: var(--text-muted); }
.app-nav .nav-dropdown { position: relative; }
.app-nav .nav-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.app-nav .nav-dropdown-trigger::after {
  content: '';
  border: 5px solid transparent;
  border-top-color: currentColor;
  margin-left: 2px;
  margin-top: 4px;
}
.app-nav .nav-dropdown.open .nav-dropdown-trigger::after {
  border-top-color: transparent;
  border-bottom-color: currentColor;
  margin-top: -6px;
}
.app-nav .nav-dropdown:has(.nav-dropdown-menu a.active) .nav-dropdown-trigger {
  background: rgba(0, 80, 32, 0.1);
  font-weight: 600;
  color: var(--accent-green);
}
.app-nav .nav-dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  min-width: 160px;
  padding: 6px 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  z-index: 100;
  display: none;
}
.app-nav .nav-dropdown.open .nav-dropdown-menu { display: block; }
.app-nav .nav-dropdown-menu a {
  display: block;
  padding: 8px 14px;
  color: var(--text);
  text-decoration: none;
  font-size: 14px;
  white-space: nowrap;
}
.app-nav .nav-dropdown-menu a:hover { background: var(--bg); }
.app-nav .nav-dropdown-menu a.active { background: rgba(0, 80, 32, 0.1); }
.app-content {
  flex: 1 1 0;
  min-height: 0;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 20px;
  overflow: hidden;
}
.app-summary {
  flex-shrink: 0;
}
.app-hint {
  flex-shrink: 0;
  margin: 0 0 12px 0;
  padding: 10px 14px;
  font-size: 13px;
  color: var(--text-muted);
  background: rgba(0, 110, 185, 0.08);
  border-left: 4px solid var(--primary);
  border-radius: 0 6px 6px 0;
  line-height: 1.45;
}
.view {
  flex: 1 1 0;
  min-height: 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Tables */
.table-wrap { overflow-x: auto; }
table {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface);
  border: 1px solid var(--border);
  font-size: 13px;
}
th, td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
th { font-weight: 600; color: var(--text); background: var(--bg); }
tr:hover { background: #f8f9fa; }
a.row-link { color: var(--primary); text-decoration: none; }
a.row-link:hover { text-decoration: underline; }

/* Search */
.search-bar {
  margin-bottom: 16px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.search-bar input {
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 14px;
  min-width: 200px;
}

/* Sections */
.section { margin-bottom: 24px; }
.section h2 { margin: 0 0 12px 0; font-size: 16px; font-weight: 600; }
.section-desc { margin: 0 0 10px 0; color: var(--text-muted); font-size: 13px; }
.sub-section { margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border); }
.sub-section:last-child { border-bottom: none; }
.sub-section h3 { margin: 0 0 8px 0; font-size: 14px; font-weight: 600; color: var(--text); }
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 16px;
  margin-bottom: 12px;
}
.card-list { margin: 0; padding-left: 18px; font-size: 13px; color: var(--text-muted); }
.card-list li { margin-bottom: 4px; }
.card-list code { font-size: 12px; background: var(--bg); padding: 1px 4px; border-radius: 3px; }

/* Section accent (left border for key sections) */
.section-accent {
  border-left: 4px solid var(--primary);
  padding-left: 20px;
  margin-left: 0;
  border-radius: 0 8px 8px 0;
  background: linear-gradient(to right, rgba(13, 110, 253, 0.04), transparent 120px);
}

/* Reports: sidebar + content layout */
#view-reports {
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.reports-layout {
  display: flex;
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
  position: relative;
}
.reports-sidebar {
  width: 220px;
  flex-shrink: 0;
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.reports-sidebar .sidebar-head {
  flex-shrink: 0;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.reports-sidebar .sidebar-title { margin: 0; font-size: 16px; font-weight: 600; }
.reports-layout.sidebar-collapsed .reports-sidebar {
  width: 48px;
  min-width: 48px;
  padding: 8px 0;
}
.reports-layout.sidebar-collapsed .reports-sidebar .sidebar-head {
  padding: 8px;
  justify-content: center;
}
.reports-layout.sidebar-collapsed .reports-sidebar .reports-nav {
  display: none;
}
.reports-layout.sidebar-collapsed .reports-sidebar .sidebar-head .sidebar-title {
  display: none;
}
.reports-layout.sidebar-collapsed .reports-sidebar .sidebar-toggle {
  margin: 0 auto;
  font-size: 0;
}
.reports-layout.sidebar-collapsed .reports-sidebar .sidebar-toggle::before {
  content: '▶';
  font-size: 14px;
}
.reports-nav {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 8px 0;
}
.reports-nav-item {
  display: block;
  padding: 10px 16px;
  font-size: 14px;
  color: var(--text);
  text-decoration: none;
  border-left: 3px solid transparent;
  transition: background 0.15s, border-color 0.15s;
}
.reports-nav-item:hover { background: var(--bg); color: var(--text); }
.reports-nav-item.active {
  font-weight: 600;
  border-left-color: var(--primary);
  background: rgba(13, 110, 253, 0.06);
}
.reports-content {
  flex: 1 1 0;
  min-width: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 16px 20px;
  background: var(--bg);
}
.reports-mobile-picker {
  display: none;
  margin-bottom: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}
.reports-mobile-picker-label { font-size: 13px; color: var(--text-muted); margin-right: 8px; }
.reports-mobile-picker .reports-filter-select { min-width: 200px; }
.reports-panel { display: block; }
.reports-panel-hidden { display: none !important; }
.reports-panel h3 { margin: 0 0 12px 0; font-size: 18px; }
.reports-byfa-table { width: 100%; max-width: 560px; font-size: 14px; border-collapse: collapse; margin-top: 12px; }
.reports-byfa-table th, .reports-byfa-table td { padding: 10px 14px; text-align: left; border-bottom: 1px solid var(--border); }
.reports-byfa-table th { background: var(--surface-alt, #f5f5f5); font-weight: 600; }
.reports-byfa-content .reports-stat-card { margin-bottom: 16px; }
.reports-panel .section-desc { margin-bottom: 16px; }
.reports-dashboard { max-width: 900px; padding-bottom: 24px; }
.reports-stats-row { margin-bottom: 24px; }
.reports-executive-section { margin-top: 28px; }
.reports-executive-section:first-child { margin-top: 0; }
.reports-executive-note { margin-top: 20px; font-size: 12px; }
.reports-stats-cards {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.reports-stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 20px 24px;
  min-width: 120px;
}
.reports-stat-card .reports-stat-value { display: block; font-size: 28px; font-weight: 600; color: var(--text); }
.reports-stat-card .reports-stat-label { font-size: 13px; color: var(--text-muted); }
.reports-permission-note {
  font-size: 13px;
  color: var(--text-muted);
  margin: 0 0 16px 0;
  padding: 10px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  border-left: 3px solid var(--accent, #0d6efd);
}
.reports-permission-note strong { color: var(--text); }
.reports-last-refresh { margin-bottom: 20px; }

/* Shared theme: Report list & Report viewer (BI Reports list, Dashboards list + viewer) */
.report-list-page { flex: 1; display: flex; flex-direction: column; min-height: 0; padding: 0 4px; }
.report-list-header { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 12px; }
.report-list-title { margin: 0; font-size: 26px; font-weight: 700; color: var(--text); letter-spacing: -0.02em; }
.report-list-desc { margin: 0 0 24px 0; font-size: 15px; color: var(--text-muted); line-height: 1.5; max-width: 56ch; }
.report-list-body { flex: 1; min-height: 0; overflow: auto; display: flex; flex-direction: column; gap: 12px; padding: 2px 0; }
.report-list-empty { margin: 32px 0; font-size: 15px; color: var(--text-muted); text-align: center; padding: 24px; background: var(--surface); border-radius: 12px; border: 1px dashed var(--border); }
.report-card {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 18px 20px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  transition: box-shadow 0.2s, border-color 0.2s;
}
.report-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.08); border-color: var(--primary); }
.report-card-content { flex: 1; min-width: 0; }
.report-card-title { margin: 0 0 4px 0; font-size: 17px; font-weight: 600; color: var(--text); }
.report-card-desc { margin: 0; font-size: 14px; color: var(--text-muted); line-height: 1.45; }
.report-card-desc:empty { display: none; }
.report-card-meta { margin-top: 8px; font-size: 13px; color: var(--text-muted); }
.report-card-action { flex-shrink: 0; }
.report-card-btn {
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  border-radius: 8px;
  background: var(--primary);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: filter 0.15s;
}
.report-card-btn:hover { filter: brightness(1.08); }

@media (max-width: 560px) {
  .report-card { flex-direction: column; align-items: stretch; gap: 14px; }
  .report-card-action { flex-shrink: 0; }
  .report-card-btn { width: 100%; }
}

.report-viewer-page { flex: 1; display: flex; flex-direction: column; min-height: 0; min-width: 0; overflow-y: auto; -webkit-overflow-scrolling: touch; padding: 0 4px; }
.report-viewer-header { margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.report-viewer-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 16px;
  padding: 8px 0;
  font-size: 15px;
  font-weight: 500;
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  transition: color 0.15s;
}
.report-viewer-back:hover { color: var(--primary); }
.report-viewer-title { margin: 0 0 8px 0; font-size: 28px; font-weight: 700; color: var(--text); line-height: 1.25; letter-spacing: -0.02em; }
.report-viewer-desc { margin: 0; font-size: 15px; line-height: 1.55; color: var(--text-muted); max-width: 60ch; }
.report-viewer-desc:empty { display: none; }
.report-viewer-canvas { flex: 0 0 auto; min-height: 320px; width: 100%; margin-top: 8px; }

/* Dashboards: list + viewer (uses shared report-list / report-viewer theme) */
.dashboards-page.section { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.dashboards-list-panel { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.dashboards-list-header { margin-bottom: 0; }
.dashboards-list-title { margin: 0; }
.dashboards-list-desc { margin: 0 0 24px 0; }
.dashboards-list-empty { margin: 0; }
.dashboards-reports-body { flex: 1; min-height: 0; overflow: auto; }
.dashboards-viewer-panel { flex: 1; display: flex; flex-direction: column; min-height: 0; min-width: 0; overflow-y: auto; }
.dashboards-viewer-header { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.dashboards-viewer-back { margin-bottom: 0; }
.dashboards-viewer-title { margin: 0; }
.dashboards-viewer-desc { margin: 0; }
.dashboards-viewer-canvas { flex: 0 0 auto; }

.dashboards-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 8px;
}
.dashboards-header h2 { margin: 0 0 4px 0; }
.dashboards-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.dashboards-layout {
  display: flex;
  gap: 24px;
  margin-top: 16px;
  min-height: 400px;
}
.dashboards-sidebar {
  width: 240px;
  flex-shrink: 0;
  padding: 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.dashboards-sidebar h3 { margin: 0 0 12px 0; font-size: 16px; }
.dashboards-list { display: flex; flex-direction: column; gap: 6px; }
.dashboards-list .dashboards-report-item {
  display: block;
  padding: 10px 12px;
  text-align: left;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  color: var(--text);
  text-decoration: none;
}
.dashboards-list .dashboards-report-item:hover,
.dashboards-list .dashboards-report-item.active {
  background: rgba(var(--primary-rgb), 0.1);
  border-color: var(--primary);
  color: var(--primary);
}
.dashboards-list .dashboards-report-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.dashboards-list .dashboards-report-row .dashboards-report-item { flex: 1; }
.dashboards-add-widget-btn {
  flex-shrink: 0;
  padding: 6px 10px;
  font-size: 12px;
}
.dashboards-content { flex: 1; min-width: 0; }
.dashboards-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  padding: 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.dashboards-filters-label { font-weight: 600; font-size: 14px; }
.dashboards-filter-select { padding: 6px 10px; border-radius: 6px; border: 1px solid var(--border); background: var(--bg); color: var(--text); margin-left: 4px; }
.dashboards-empty {
  padding: 32px;
  text-align: center;
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: 8px;
}
/* GridStack canvas: use grid-stack for drag/resize */
.dashboards-canvas.grid-stack { min-height: 200px; }
.dashboards-canvas .grid-stack-item-content {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.dashboards-canvas .grid-stack-item-content.edit-mode { border-color: var(--primary); box-shadow: 0 0 0 2px rgba(var(--primary-rgb), 0.2); }
.dashboards-widget {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  min-height: 100px;
  position: relative;
  display: flex;
  flex-direction: column;
}
.dashboards-widget.edit-mode { border-color: var(--primary); box-shadow: 0 0 0 2px rgba(var(--primary-rgb), 0.2); }

/* BI Reports — power-admin full layout */
body.bi-reports-active .app-content { max-width: none; width: 100%; padding: 16px; }
body.dashboards-active .app-content { max-width: none; width: 100%; padding: 16px; }
#view-bi_reports .bi-reports-page { flex: 1; display: flex; flex-direction: column; min-height: 0; }
#view-dashboards .dashboards-page { flex: 1; display: flex; flex-direction: column; min-height: 0; width: 100%; min-width: 0; }

/* BI Reports list (uses shared report-list theme) */
.bi-reports-list-panel { flex: 1; display: flex; flex-direction: column; min-height: 0; max-width: 100%; }
.bi-reports-list-header { margin-bottom: 0; }
.bi-reports-list-title { margin: 0; }
.bi-reports-list-desc { margin: 0 0 24px 0; }
.bi-reports-list-body { flex: 1; min-height: 0; overflow: auto; }
.bi-reports-list-empty { margin: 0; }
.bi-reports-btn-create { flex-shrink: 0; padding: 10px 20px; font-weight: 600; border-radius: 8px; }

/* Editor layout: sidebar + main */
.bi-reports-editor-layout {
  flex: 1;
  display: flex;
  min-height: 0;
  gap: 0;
}
.bi-reports-editor-sidebar {
  width: 360px;
  min-width: 320px;
  max-width: 420px;
  flex-shrink: 0;
  padding: 20px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--bg) 100%);
  border-right: 1px solid var(--border);
  border-left: 4px solid var(--primary, #006eb9);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.bi-reports-editor-back {
  padding: 0;
  margin: 0;
  font-size: 14px;
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  align-self: flex-start;
}
.bi-reports-editor-back:hover { color: var(--primary); }
.bi-reports-editor-title { margin: 0; font-size: 20px; font-weight: 700; color: var(--text, #1a1a1a); line-height: 1.25; }
.bi-reports-editor-desc { margin: 0; font-size: 13px; color: var(--text-muted); line-height: 1.5; }
.bi-reports-editor-desc:empty { display: none; }
.bi-reports-editor-toolbar { margin-top: 8px; padding-top: 16px; border-top: 1px solid var(--border); }
.bi-reports-editor-toolbar-head { margin: 0 0 8px 0; font-size: 13px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.03em; }
.bi-reports-editor-hint { margin: 0 0 12px 0; font-size: 12px; color: var(--text-muted); line-height: 1.4; }
.bi-reports-editor-grid-options { display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 8px 12px; margin-bottom: 14px; }
.bi-reports-editor-grid-options .bi-reports-grid-label { font-size: 12px; font-weight: 600; color: var(--text-muted); }
.bi-reports-editor-grid-options .bi-reports-grid-columns { min-width: 64px; }
.bi-reports-editor-grid-options .bi-reports-cell-height { width: 80px; }
.bi-reports-editor-add { display: flex; gap: 8px; margin-bottom: 12px; }
.bi-reports-editor-add .admin-input { flex: 1; min-width: 0; }
.bi-reports-component-select { width: 100%; }
.bi-reports-editor-add-extra { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin-bottom: 12px; }
.bi-reports-add-extra-btn { min-width: 120px; }
.bi-reports-filter-rows { margin-bottom: 12px; }
.bi-reports-filter-row { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-bottom: 8px; padding: 8px 10px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px; }
.bi-reports-filter-row .bi-reports-filter-ds { width: 90px; font-size: 12px; }
.bi-reports-filter-row .bi-reports-filter-col { flex: 1; min-width: 80px; font-size: 12px; }
.bi-reports-filter-row .bi-reports-filter-val { min-width: 100px; font-size: 12px; }
.bi-reports-filter-row .bi-reports-filter-remove { padding: 4px 8px; font-size: 11px; }
.bi-reports-editor-add-filter { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-bottom: 12px; }
.bi-reports-editor-add-filter .bi-reports-filter-label { font-size: 12px; font-weight: 600; color: var(--text-muted); margin-right: 4px; }
.bi-reports-add-filter-new .bi-reports-filter-ds { width: 100px; }
.bi-reports-add-filter-new .bi-reports-filter-col { flex: 1; min-width: 90px; }
.bi-reports-add-filter-new .bi-reports-filter-val { min-width: 100px; }
.bi-reports-component-list { margin-bottom: 12px; max-height: 200px; overflow-y: auto; border: 1px solid var(--border); border-radius: 6px; background: var(--surface); }
.bi-reports-component-list:empty { min-height: 48px; }
.bi-reports-component-list:empty::after { content: 'No components yet'; display: block; padding: 12px; font-size: 12px; color: var(--text-muted); text-align: center; }
.bi-reports-component-list-item { display: block; width: 100%; padding: 10px 12px; font-size: 13px; text-align: left; background: none; border: none; border-bottom: 1px solid var(--border); cursor: pointer; color: var(--text); }
.bi-reports-component-list-item:last-child { border-bottom: none; }
.bi-reports-component-list-item:hover { background: rgba(0, 110, 185, 0.08); }
.bi-reports-component-list-item.selected { background: rgba(0, 110, 185, 0.12); font-weight: 600; border-left: 3px solid var(--primary); }
.bi-reports-properties-pane { width: 280px; min-width: 260px; flex-shrink: 0; padding: 16px; background: var(--surface); border-left: 1px solid var(--border); overflow-y: auto; display: flex; flex-direction: column; }
.bi-reports-properties-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
.bi-reports-properties-title { margin: 0; font-size: 14px; font-weight: 600; }
.bi-reports-properties-close { padding: 4px 8px; font-size: 18px; line-height: 1; background: none; border: none; cursor: pointer; color: var(--text-muted); }
.bi-reports-properties-close:hover { color: var(--text); }
.bi-reports-properties-content .admin-form-group { margin-bottom: 14px; }
.bi-reports-properties-content label { display: block; font-size: 12px; font-weight: 600; color: var(--text-muted); margin-bottom: 4px; }
.bi-reports-properties-content .admin-input { width: 100%; }
.bi-reports-filter-widget { padding: 12px 14px; display: flex; flex-direction: column; min-height: 0; }
.bi-reports-filter-widget-label { font-size: 13px; font-weight: 600; color: var(--text, #1a1a1a); margin-bottom: 8px; flex-shrink: 0; }
.bi-reports-filter-widget-hint { font-size: 12px; color: var(--text-muted); }
.bi-reports-filter-na-hint { font-size: 11px; color: var(--text-muted); margin-top: 8px; padding-top: 6px; border-top: 1px solid var(--border, #dee2e6); }
.bi-reports-filter-select { width: 100%; max-width: 240px; }
.bi-reports-filter-checkbox-wrap { margin-top: 6px; max-height: 200px; overflow-y: auto; flex: 1; min-height: 0; }
.bi-reports-canvas.bi-reports-view-only .bi-reports-filter-checkbox-wrap { max-height: none; }
.bi-reports-filter-checkbox-link { padding: 0; margin: 0; font-size: 12px; background: none; border: none; cursor: pointer; color: var(--primary); }
.bi-reports-filter-checkbox-link:hover { text-decoration: underline; }
.bi-reports-filter-checkbox-label { display: block; font-size: 13px; margin: 4px 0; cursor: pointer; }
.bi-reports-filter-checkbox-label input { margin-right: 6px; }
.bi-reports-filter-val[multiple] { min-height: 80px; }
.bi-reports-canvas.bi-reports-view-only .bi-reports-filter-widget .bi-reports-filter-widget-label { margin-bottom: 6px; }
.bi-reports-save-status { margin: 0 0 10px 0; font-size: 13px; min-height: 1.3em; }
.bi-reports-save-status:empty { display: none; }
.bi-reports-btn-save { width: 100%; padding: 10px; font-weight: 600; background: var(--primary, #006eb9); color: #fff; border: none; border-radius: 6px; cursor: pointer; }
.bi-reports-btn-save:hover { filter: brightness(1.08); }
.bi-reports-widget-head { display: flex; justify-content: flex-end; padding: 4px 6px 0 0; flex-shrink: 0; }
.bi-reports-widget-remove {
  padding: 4px 10px;
  font-size: 12px;
  color: #b91c1c;
  background: rgba(185, 28, 28, 0.08);
  border: 1px solid rgba(185, 28, 28, 0.25);
  border-radius: 4px;
  cursor: pointer;
}
.bi-reports-widget-remove:hover { background: rgba(185, 28, 28, 0.14); }
.bi-reports-text-block .bi-reports-text-content {
  padding: 12px 14px;
  margin: 0;
  border-radius: 4px;
  min-height: 1.5em;
  font-size: 14px;
  line-height: 1.5;
  flex: 1;
  min-height: 0;
}
.bi-reports-text-block .bi-reports-text-content[contenteditable="true"] { outline: 1px dashed var(--border); }
.bi-reports-component-measure {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 16px;
  border-radius: 8px;
  min-height: 80px;
}
.bi-reports-measure-component-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 6px;
  text-align: center;
}
.bi-reports-measure-component-value {
  font-size: 32px;
  font-weight: 700;
  color: var(--text, #1a1a1a);
  line-height: 1;
}
.bi-reports-editor-main {
  flex: 1;
  min-width: 0;
  min-height: 0;
  padding: 20px;
  background: var(--bg);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

/* Canvas: visible grid in edit mode, strong component cards; height grows with content so main scrolls */
.bi-reports-canvas {
  min-height: 400px;
  width: 100%;
  background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: calc(100% / 12) 100px;
  background-color: var(--surface);
  border-radius: 10px;
  border: 1px solid var(--border);
  padding: 16px;
}
.bi-reports-canvas.bi-reports-view-only {
  background-image: none;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 100px;
  gap: 20px;
  align-content: start;
  padding: 0;
}
.bi-reports-canvas.grid-stack { min-height: 400px; }
.bi-reports-canvas .grid-stack-item-content {
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: 8px;
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.bi-reports-canvas .grid-stack-item-content.edit-mode {
  border-color: var(--primary, #006eb9);
  box-shadow: 0 0 0 1px var(--primary), 0 2px 8px rgba(0,0,0,0.1);
  cursor: move;
}
.bi-reports-widget-card {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  position: relative;
  height: 100%;
}
.bi-reports-widget-card.bi-reports-widget-selected {
  box-shadow: 0 0 0 2px var(--primary, #006eb9);
  outline: none;
}
.bi-reports-widget-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text, #1a1a1a);
  margin: 0;
  padding: 12px 14px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.bi-reports-widget-chart {
  flex: 1;
  min-height: 120px;
  position: relative;
  padding: 14px;
}
.bi-reports-widget-chart canvas { max-width: 100%; max-height: 100%; }

.bi-reports-datatable-card { display: flex; flex-direction: column; min-height: 120px; }
.bi-reports-datatable-wrap { overflow: auto; max-height: 320px; flex: 1; min-height: 80px; }
.bi-reports-datatable-wrap .gap-table { width: 100%; font-size: 12px; }

/* View-only canvas: explicit grid reserves exact space per component so nothing overlaps */
.bi-reports-canvas.bi-reports-view-only {
  align-content: start;
  min-width: 0;
  overflow: hidden;
}
.bi-reports-canvas.bi-reports-view-only > * {
  min-height: 0;
  max-height: 100%;
  overflow: hidden;
  position: relative;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
  display: flex;
  flex-direction: column;
  min-height: 0;
  height: 100%;
  max-height: 100%;
  overflow: hidden;
  position: relative;
  contain: layout;
  box-sizing: border-box;
  min-width: 0;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget .bi-reports-widget-title { border-radius: 8px 8px 0 0; }
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget .bi-reports-widget-chart {
  flex: 1;
  min-height: 0;
  padding: 8px;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget .bi-reports-text-block .bi-reports-text-content {
  flex: 1;
  padding: 16px 18px;
  margin: 0;
  font-size: 15px;
  line-height: 1.5;
  color: var(--text, #1a1a1a);
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget .bi-reports-datatable-wrap {
  flex: 1;
  min-height: 0;
  max-height: none;
}
/* Filter widgets in view: fill grid cell, compact layout, scroll list inside */
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget {
  padding: 4px 8px;
  display: flex;
  flex-direction: column;
  min-height: 0;
  border-radius: 8px;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-widget-label {
  margin-bottom: 2px;
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.2;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-checkbox-wrap {
  margin-top: 0;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  max-height: none;
  -webkit-overflow-scrolling: touch;
  display: block;
  padding-right: 6px;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-checkbox-wrap::-webkit-scrollbar {
  width: 6px;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-checkbox-wrap::-webkit-scrollbar-track {
  background: var(--bg, #f5f5f5);
  border-radius: 3px;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-checkbox-wrap::-webkit-scrollbar-thumb {
  background: var(--border, #ddd);
  border-radius: 3px;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-checkbox-wrap::-webkit-scrollbar-thumb:hover {
  background: var(--text-muted, #888);
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-checkbox-link {
  font-size: 10px;
  padding: 0 1px 0 0;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-checkbox-label {
  margin: 0;
  padding: 1px 0;
  font-size: 10px;
  line-height: 1.2;
  cursor: pointer;
}
.bi-reports-canvas.bi-reports-view-only .bi-reports-view-widget.bi-reports-filter-widget .bi-reports-filter-checkbox-label input {
  margin-right: 3px;
  vertical-align: middle;
  transform: scale(0.85);
}
.bi-reports-canvas.bi-reports-canvas-empty { background-image: none; }
.bi-reports-widget-card .dashboards-widget-remove { top: 6px; right: 6px; z-index: 2; }

/* Floating filter context (report view + dashboards) – fixed so it stays visible when scrolling */
.bi-reports-editor-layout,
.dashboards-viewer-panel { position: relative; }
.bi-reports-filter-context {
  position: fixed;
  top: 72px;
  right: 16px;
  z-index: 100;
  max-width: 320px;
  max-height: calc(100vh - 96px);
  overflow-y: auto;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  font-size: 12px;
}
.bi-reports-filter-context-title {
  font-weight: 700;
  color: var(--text, #1a1a1a);
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.bi-reports-filter-context-list { display: flex; flex-direction: column; gap: 4px; }
.bi-reports-filter-context-row { display: flex; flex-wrap: wrap; gap: 4px; align-items: baseline; }
.bi-reports-filter-context-label { font-weight: 600; color: var(--text-muted); flex-shrink: 0; }
.bi-reports-filter-context-values { color: var(--text, #1a1a1a); word-break: break-word; }
.bi-reports-filter-context-values.bi-reports-filter-context-all { color: var(--text-muted); font-style: italic; }

/* BI Reports & Dashboards: scroll canvas + mobile */
@media (max-width: 768px) {
  body.bi-reports-active .app-content { padding: 12px; }
  body.dashboards-active .app-content { padding: 12px; }
  .bi-reports-editor-layout { flex-direction: column; min-height: 0; }
  .bi-reports-editor-sidebar {
    width: 100%;
    min-width: 0;
    padding: 16px;
    border-left: none;
    border-right: none;
    border-bottom: 1px solid var(--border);
    max-height: 45vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .bi-reports-editor-main { padding: 12px; flex: 1; min-height: 200px; }
  .bi-reports-canvas { min-height: 300px; padding: 12px; }
  .bi-reports-editor-add { flex-wrap: wrap; }
  .bi-reports-editor-add .admin-input { min-width: 140px; }
  .bi-reports-editor-add-filter { flex-direction: column; align-items: stretch; }
  .bi-reports-editor-add-filter .bi-reports-filter-ds,
  .bi-reports-editor-add-filter .bi-reports-filter-col { width: 100%; min-width: 0; }
  .bi-reports-add-extra-btn,
  .bi-reports-editor-add-filter button { min-height: 44px; }
  .bi-reports-btn-save { min-height: 44px; }
  .bi-reports-canvas.bi-reports-view-only { gap: 12px; }
  .dashboards-viewer-panel { padding: 0 12px 12px; width: 100%; min-width: 0; }
  .dashboards-viewer-header { margin-bottom: 16px; padding-bottom: 12px; }
  .dashboards-viewer-title { font-size: 20px; }
  .dashboards-viewer-back { min-height: 44px; padding: 8px 0; }
  .dashboards-viewer-canvas { width: 100%; min-width: 0; }
  .bi-reports-widget-remove { min-width: 44px; min-height: 44px; }
  /* Chart composition on mobile: shrink title/labels so chart area dominates */
  .bi-reports-view-widget .bi-reports-widget-title { font-size: 12px; padding: 8px 10px; }
  .bi-reports-view-widget .bi-reports-widget-chart { min-height: 140px; padding: 8px; flex: 1; }
  .bi-reports-view-widget.bi-reports-component-measure .bi-reports-measure-component-label { font-size: 10px; }
  .bi-reports-view-widget.bi-reports-component-measure .bi-reports-measure-component-value { font-size: 24px; }
}

@media (max-width: 480px) {
  body.bi-reports-active .app-content { padding: 8px; }
  body.dashboards-active .app-content { padding: 8px; }
  .bi-reports-editor-sidebar { max-height: 40vh; padding: 12px; }
  .bi-reports-editor-main { padding: 8px; }
  .bi-reports-canvas { min-height: 260px; padding: 8px; }
  .bi-reports-list-header { flex-direction: column; align-items: stretch; }
  .bi-reports-btn-create { min-height: 44px; }
  .bi-reports-open-btn { min-height: 44px; }
  .dashboards-viewer-panel { padding: 0 8px 8px; }
  .dashboards-viewer-canvas { padding: 0; }
}

.dashboards-widget-remove {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: var(--bg);
  color: var(--text-muted);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  display: none;
}
.dashboards-widget.edit-mode .dashboards-widget-remove { display: block; }
.dashboards-widget-remove:hover { background: var(--danger-bg, #f8d7da); color: var(--danger, #dc3545); }
.dashboards-widget-config-btn {
  position: absolute;
  top: 8px;
  right: 40px;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: var(--bg);
  color: var(--text-muted);
  cursor: pointer;
  font-size: 14px;
  display: none;
}
.dashboards-widget.edit-mode .dashboards-widget-config-btn { display: block; }
.dashboards-widget-config-btn:hover { background: rgba(var(--primary-rgb), 0.15); color: var(--primary); }
.dashboards-widget-title { font-weight: 600; font-size: 14px; margin-bottom: 8px; }
.dashboards-widget-metric { font-size: 22px; font-weight: 600; color: var(--primary, #0d6efd); }
.dashboards-widget-metric-label { font-size: 12px; color: var(--text-muted); }
.dashboards-widget-chart-wrap { height: 80px; margin-top: 8px; flex: 1; min-height: 0; }
.dashboards-widget-chart-wrap canvas { max-height: 80px; }
.dashboards-report-wrap { margin-top: 0; }
.dashboards-report-title { margin: 0 0 8px 0; font-size: 18px; }
.dashboards-report-wrap .gap-table { width: 100%; }
.dashboards-metrics-row {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin: 16px 0;
}
.dashboards-metric-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px 20px;
  min-width: 120px;
}
.dashboards-metric-card .dashboards-metric-value {
  display: block;
  font-size: 28px;
  font-weight: 600;
  color: var(--primary, #0d6efd);
}
.dashboards-metric-card .dashboards-metric-label {
  font-size: 13px;
  color: var(--text-muted);
}
.dashboards-chart-wrap {
  margin: 20px 0;
  max-width: 700px;
  height: 360px;
}

/* BI Builder (PowerBI-style, frontend-only) */
/* BI Builder: use full screen when active */
body.bi-builder-active .app-content { max-width: none; width: 100%; padding: 16px; }
#view-bi_builder .bi-builder-page { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.bi-builder-components-section { margin-bottom: 16px; }
.bi-builder-components-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.bi-builder-components-title { margin: 0; font-size: 15px; font-weight: 600; color: var(--text, #1a1a1a); }
.bi-builder-components-list { display: flex; flex-wrap: wrap; gap: 8px; min-height: 36px; }
.bi-builder-component-item {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 6px;
  font-size: 13px; box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.bi-builder-component-item .bi-builder-component-name { font-weight: 500; color: var(--text); margin-right: 4px; }
.bi-builder-component-item .bi-builder-component-actions { display: flex; gap: 6px; }
.bi-builder-component-item .bi-builder-component-edit,
.bi-builder-component-item .bi-builder-component-delete {
  padding: 4px 10px; font-size: 12px; border-radius: 4px; border: 1px solid var(--border);
  background: var(--bg); color: var(--text); cursor: pointer;
}
.bi-builder-component-item .bi-builder-component-edit:hover { background: rgba(0, 110, 185, 0.1); border-color: var(--primary); color: var(--primary); }
.bi-builder-component-item .bi-builder-component-delete:hover { background: rgba(185, 28, 28, 0.08); border-color: var(--danger); color: var(--danger); }
.bi-builder-data-model-section { margin-bottom: 16px; padding: 16px; background: var(--surface); border: 1px solid var(--border); border-radius: 8px; }
.bi-builder-data-model-header {
  display: flex; align-items: center; justify-content: space-between; width: 100%;
  margin: 0 0 12px 0; padding: 0; font-size: 15px; font-weight: 600; color: var(--text, #1a1a1a);
  background: none; border: none; cursor: pointer; text-align: left; gap: 8px;
}
.bi-builder-data-model-header:hover { color: var(--primary); }
.bi-builder-data-model-title { margin: 0; }
.bi-builder-data-model-toggle-icon {
  flex-shrink: 0; width: 20px; height: 20px; opacity: 0.7;
  background: currentColor; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/contain no-repeat; -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/contain no-repeat;
}
.bi-builder-data-model-section--collapsed .bi-builder-data-model-toggle-icon {
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M9 6l6 6-6 6'/%3E%3C/svg%3E") center/contain no-repeat; -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M9 6l6 6-6 6'/%3E%3C/svg%3E") center/contain no-repeat;
}
.bi-builder-data-model-section--collapsed .bi-builder-data-model-content { display: none; }
.bi-builder-data-model-section--collapsed .bi-builder-data-model-header { margin-bottom: 0; }
.bi-builder-data-model-content { font-size: 13px; }
.bi-builder-data-model-intro { margin: 0 0 14px 0; font-size: 13px; color: var(--text-muted); line-height: 1.5; }
.bi-builder-data-model-scroll { max-height: 420px; overflow-y: auto; overflow-x: hidden; margin-bottom: 12px; padding-right: 4px; }
.bi-builder-data-model-scroll::-webkit-scrollbar { width: 8px; }
.bi-builder-data-model-scroll::-webkit-scrollbar-track { background: var(--bg); border-radius: 4px; }
.bi-builder-data-model-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.bi-builder-tables-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 10px; margin-bottom: 16px; }
.bi-builder-table-card { background: var(--bg); border: 1px solid var(--border); border-radius: 6px; overflow: hidden; }
.bi-builder-table-card-header {
  display: flex; align-items: center; gap: 8px; width: 100%; padding: 10px 12px; font-size: 13px; text-align: left;
  background: none; border: none; cursor: pointer; color: var(--text); transition: background 0.15s ease;
}
.bi-builder-table-card-header:hover { background: rgba(0, 110, 185, 0.06); }
.bi-builder-table-card-chevron {
  flex-shrink: 0; width: 16px; height: 16px; opacity: 0.7;
  background: currentColor; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M9 6l6 6-6 6'/%3E%3C/svg%3E") center/contain no-repeat; -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M9 6l6 6-6 6'/%3E%3C/svg%3E") center/contain no-repeat;
  transition: transform 0.2s ease;
}
.bi-builder-table-card:not(.bi-builder-table-card--collapsed) .bi-builder-table-card-chevron { transform: rotate(90deg); }
.bi-builder-table-card-header .bi-builder-table-name { font-weight: 600; flex: 1; min-width: 0; }
.bi-builder-table-card-header .bi-builder-table-meta { font-size: 11px; color: var(--text-muted); white-space: nowrap; }
.bi-builder-table-card-header .bi-builder-table-meta code { font-size: 10px; background: var(--surface); padding: 1px 4px; border-radius: 3px; }
.bi-builder-table-card-body { padding: 0 12px 12px 12px; border-top: 1px solid var(--border); }
.bi-builder-table-card--collapsed .bi-builder-table-card-body { display: none; }
.bi-builder-table-card--collapsed .bi-builder-table-card-header { border-bottom: none; }
.bi-builder-table-desc { margin: 8px 0 0 0; font-size: 12px; color: var(--text-muted); line-height: 1.4; }
.bi-builder-table-cols { margin: 8px 0 0 0; font-size: 11px; color: var(--text-muted); }
.bi-builder-cols-list { word-break: break-all; }
.bi-builder-table-rels { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.bi-builder-rel-pill { font-size: 11px; padding: 2px 8px; background: rgba(0, 110, 185, 0.1); color: var(--primary); border-radius: 4px; }
.bi-builder-relationships-block { border: 1px solid var(--border); border-radius: 6px; background: var(--bg); margin-bottom: 12px; overflow: hidden; }
.bi-builder-relationships-block-header {
  display: flex; align-items: center; gap: 8px; width: 100%; padding: 10px 12px; font-size: 13px; text-align: left;
  background: none; border: none; cursor: pointer; color: var(--text); transition: background 0.15s ease;
}
.bi-builder-relationships-block-header:hover { background: rgba(0, 110, 185, 0.06); }
.bi-builder-relationships-block--collapsed .bi-builder-relationships-grid { display: none; }
.bi-builder-relationships-block .bi-builder-table-card-chevron { transform: rotate(0deg); }
.bi-builder-relationships-block:not(.bi-builder-relationships-block--collapsed) .bi-builder-table-card-chevron { transform: rotate(90deg); }
.bi-builder-relationships-grid { padding: 0 12px 12px 12px; margin-bottom: 0; }
.bi-builder-rel-table { width: 100%; max-width: 560px; font-size: 12px; border-collapse: collapse; margin-top: 8px; }
.bi-builder-rel-table th, .bi-builder-rel-table td { padding: 6px 10px; text-align: left; border-bottom: 1px solid var(--border); }
.bi-builder-rel-table th { font-weight: 600; color: var(--text-muted); background: var(--bg); }
.bi-builder-rel-table code { font-size: 11px; background: var(--bg); padding: 1px 4px; border-radius: 3px; }
.bi-builder-relationships-summary { font-size: 12px; color: var(--text-muted); line-height: 1.5; }
.bi-builder-relationships-summary code { font-size: 11px; background: var(--bg); padding: 1px 4px; border-radius: 3px; }
.bi-builder-field-hint { margin: 4px 0 0 0; font-size: 12px; color: var(--text-muted); }
.bi-builder-related-tables-list { display: flex; flex-direction: column; gap: 8px; }
.bi-builder-related-table-row { display: flex; align-items: center; gap: 8px; }
.bi-builder-related-table-row .admin-input { flex: 1; min-width: 0; }
.bi-builder-related-table-row .bi-builder-remove-related { flex-shrink: 0; padding: 6px 10px; }
.bi-builder-order-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.bi-builder-order-row .admin-input:first-of-type { flex: 1; min-width: 120px; }
.bi-builder-order-row .admin-input:last-of-type { min-width: 140px; }
.bi-builder-layout {
  display: flex;
  gap: 24px;
  margin-top: 12px;
  flex: 1;
  min-height: 0;
}
.bi-builder-sidebar {
  flex: 0 0 33.333%;
  width: 33.333%;
  min-width: 300px;
  max-width: 520px;
  padding: 20px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--bg) 100%);
  border: 1px solid var(--border);
  border-left: 4px solid var(--primary, #006eb9);
  border-radius: 10px;
  overflow-y: auto;
  overflow-x: visible;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.bi-builder-sidebar h3 {
  margin: 0 0 20px 0;
  font-size: 17px;
  font-weight: 600;
  color: var(--text, #1a1a1a);
}
.bi-builder-sidebar .admin-form-group {
  margin-bottom: 18px;
}
.bi-builder-sidebar .admin-form-group label {
  display: block;
  margin-bottom: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
}
.bi-builder-sidebar .admin-form-group .admin-input {
  width: 100%;
  box-sizing: border-box;
}
.bi-builder-main { flex: 1; min-width: 0; min-height: 0; display: flex; flex-direction: column; gap: 16px; }
.bi-builder-chart-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  flex: 1;
  min-height: 260px;
  position: relative;
}
.bi-builder-chart-wrap canvas { max-width: 100%; }
.bi-builder-measure-preview {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: absolute;
  inset: 16px;
  border-radius: 8px;
  padding: 24px;
}
.bi-builder-measure-preview[style*="display: flex"] { display: flex !important; }
.bi-builder-measure-preview-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 8px;
  text-align: center;
}
.bi-builder-measure-preview-value {
  font-size: 42px;
  font-weight: 700;
  color: var(--text, #1a1a1a);
  line-height: 1;
}
.bi-builder-raw-query { margin: 12px 0; padding: 10px 12px; background: var(--surface); border: 1px solid var(--border); border-radius: 6px; font-size: 12px; }
.bi-builder-raw-query strong { display: block; margin-bottom: 6px; font-size: 13px; }
.bi-builder-raw-query-pre { margin: 0; padding: 0; font-family: inherit; font-size: 12px; line-height: 1.5; white-space: pre-wrap; word-break: break-word; color: var(--text, #1a1a1a); }

.bi-builder-table-wrap { flex-shrink: 0; max-height: 280px; overflow: auto; }
.bi-builder-table-wrap h4 { margin: 0 0 8px 0; font-size: 14px; font-weight: 600; }
.bi-builder-table-wrap .gap-table { width: 100%; }

/* Filters: clear section + card per filter */
.bi-builder-filters {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
}
.bi-builder-filters h4 {
  margin: 0 0 6px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text, #1a1a1a);
}
.bi-builder-filters-hint {
  margin: 0 0 14px 0;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
}
.bi-builder-filter-rows {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.bi-builder-filter-row {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.bi-builder-filter-row-header {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  min-height: 36px;
  margin: -2px -2px 0 0;
}
.bi-builder-filter-row .bi-builder-filter-remove {
  flex-shrink: 0;
  min-width: 80px;
  padding: 8px 14px;
  font-size: 12px;
  font-weight: 500;
  color: #b91c1c;
  background: rgba(185, 28, 28, 0.08);
  border: 1px solid rgba(185, 28, 28, 0.25);
  border-radius: 6px;
}
.bi-builder-filter-row .bi-builder-filter-remove:hover {
  background: rgba(185, 28, 28, 0.14);
  border-color: rgba(185, 28, 28, 0.4);
}
.bi-builder-filter-row .bi-builder-filter-col-wrap { }
.bi-builder-filter-row .bi-builder-filter-op-val-wrap {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}
.bi-builder-filter-row label.filter-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.bi-builder-filter-row .bi-builder-filter-col { width: 100%; min-width: 0; box-sizing: border-box; }
.bi-builder-filter-row .bi-builder-filter-op { min-width: 128px; }
.bi-builder-filter-row .bi-builder-filter-val { min-width: 140px; flex: 1; }

.reports-last-refresh-title { margin: 0 0 8px 0; font-size: 14px; font-weight: 600; }
.reports-section { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); }
.reports-list-wrap { margin-top: 12px; }
.reports-list-wrap .reports-subheading { margin: 20px 0 8px 0; font-size: 14px; font-weight: 600; }
.reports-list-wrap .reports-subheading:first-child { margin-top: 0; }
.reports-events-table { width: 100%; font-size: 13px; border-collapse: collapse; margin-bottom: 20px; }
.reports-events-table th,
.reports-events-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border); }
.reports-events-table th { color: var(--text-muted); font-weight: 600; }
.reports-events-table td { vertical-align: top; }
.reports-gap-count { color: var(--status-warn, #d4a012); font-weight: 600; }
.reports-insights { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); }
.reports-insights .section-desc { margin-bottom: 14px; }
.reports-insights-cards { margin-bottom: 16px; }
.reports-stat-card.reports-insight-ok .reports-stat-value { color: var(--status-ok, #198754); }
.reports-stat-card.reports-insight-warn .reports-stat-value { color: var(--status-warn, #d4a012); }
.reports-stat-card.reports-insight-muted .reports-stat-value { color: var(--text-muted); }
.reports-gaps-summary { margin-top: 16px; }
.reports-gaps-heading { margin: 0 0 8px 0; font-size: 14px; font-weight: 600; }
.reports-gaps-table { width: 100%; font-size: 13px; border-collapse: collapse; margin-top: 8px; }
.reports-gaps-table th,
.reports-gaps-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border); }
.reports-gaps-table th { color: var(--text-muted); font-weight: 600; }
.reports-gaps-none { color: var(--status-ok, #198754); }
.reports-ontheday-section { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); }
.reports-ontheday-table { width: 100%; font-size: 13px; border-collapse: collapse; margin-top: 8px; }
.reports-ontheday-table th,
.reports-ontheday-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border); }
.reports-ontheday-table th { color: var(--text-muted); font-weight: 600; }
/* Unified filter bar: same look across Users, Events, Applicants, Reports */
.filter-bar {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 18px;
  margin-bottom: 16px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 20px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
.filter-bar .reports-filter-label,
.filter-bar .filter-label,
.filter-bar label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  white-space: nowrap;
  margin: 0;
}
.filter-bar .reports-filter-select,
.filter-bar .reports-filter-search,
.filter-bar .applicant-filter-select,
.filter-bar .applicant-filter-search,
.filter-bar .sidebar-filter-select,
.filter-bar select,
.filter-bar input[type="text"].reports-filter-search,
.filter-bar input[type="text"].applicant-filter-search {
  min-height: 36px;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  background: var(--surface);
  color: var(--text);
  transition: border-color 0.15s ease;
}
.filter-bar select:focus,
.filter-bar input[type="text"]:focus {
  outline: none;
  border-color: var(--primary);
}
.filter-bar .reports-filter-select { min-width: 160px; }
.filter-bar .reports-filter-search { min-width: 180px; }
.filter-bar .applicant-filter-select { min-width: 140px; }
.filter-bar .reports-export-btn,
.filter-bar .applicant-export-btn {
  min-height: 36px;
  padding: 8px 14px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  margin-left: auto;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.filter-bar .reports-export-btn:hover,
.filter-bar .applicant-export-btn:hover { background: var(--bg); }
.filter-bar button.filter-bar-primary {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}
.filter-bar button.filter-bar-primary:hover {
  background: #1a3d73;
  border-color: #1a3d73;
  color: #fff;
}
.filter-bar .reports-filter-checkbox-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  margin: 0;
}
.filter-bar .reports-filter-checkbox { cursor: pointer; }

/* Sidebar filter bars: slightly tighter so they fit narrow sidebars */
.sidebar-filters.filter-bar {
  padding: 10px 12px;
  gap: 8px 12px;
}

/* Events sidebar: same filter structure as Applicants (label + control, flex wrap) */
.events-sidebar-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  margin-bottom: 12px;
}
.events-sidebar-filters .events-filter-search {
  width: 100%;
  min-width: 0;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
  background: var(--surface);
}
.events-sidebar-filters .events-filter-search:focus {
  outline: none;
  border-color: var(--primary);
}
.events-filter-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}
.events-sidebar-filters .sidebar-filter-select {
  min-width: 100px;
  max-width: 160px;
  flex: 1 1 auto;
}
.events-sidebar-filters .sidebar-filter-date {
  min-height: 36px;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  width: 130px;
  flex-shrink: 0;
}

/* Events main body: filters collapsed by default */
.events-main-filters {
  margin-bottom: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
}
.events-main-filters-summary {
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.events-main-filters-summary::-webkit-details-marker { display: none; }
.events-main-filters-summary::before {
  content: '▶';
  font-size: 10px;
  color: var(--text-muted);
  transition: transform 0.2s;
}
.events-main-filters[open] .events-main-filters-summary::before { transform: rotate(90deg); }
.events-main-filters-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  padding: 12px 14px 14px 14px;
  border-top: 1px solid var(--border);
}
.events-main-filters-inner .events-filter-search {
  width: 100%;
  min-width: 0;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
  background: var(--bg);
}
.events-main-filters-inner .events-filter-search:focus {
  outline: none;
  border-color: var(--primary);
}
.events-main-filters-inner .events-filter-label { font-size: 12px; font-weight: 500; color: var(--text-muted); white-space: nowrap; }
.events-filter-clear-btn {
  min-height: 36px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  background: var(--surface, #fff);
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 6px;
  cursor: pointer;
  white-space: nowrap;
}
.events-filter-clear-btn:hover {
  color: var(--text);
  background: var(--bg, #f8f9fa);
  border-color: var(--text-muted);
}
.events-main-filters-inner .sidebar-filter-select {
  min-width: 100px;
  max-width: 160px;
  flex: 1 1 auto;
}
.events-main-filters-inner .sidebar-filter-date {
  min-height: 36px;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  width: 130px;
  flex-shrink: 0;
}

.reports-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 16px;
  margin-bottom: 16px;
}
.reports-filter-label { font-size: 13px; color: var(--text-muted); white-space: nowrap; }
.reports-filter-select {
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  min-width: 160px;
}
.reports-filter-search {
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  min-width: 180px;
}
.reports-filter-checkbox-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
}
.reports-filter-checkbox { cursor: pointer; }
.reports-export-btn {
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  font-size: 13px;
  cursor: pointer;
  margin-left: auto;
}
.reports-export-btn:hover { background: var(--bg); }
.reports-gaps-filters { margin-top: 12px; }
.reports-focus-section { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); }
.reports-focus-list { margin-top: 12px; }

/* Event accordion: one per event, expand to see summary + gaps + on-the-day */
.reports-event-accordions { margin-top: 16px; }
.event-accordion {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 10px;
  overflow: hidden;
}
.event-accordion--open { border-color: var(--accent, #0d6efd); }
.event-accordion__header {
  width: 100%;
  padding: 14px 18px;
  font-size: 14px;
  font-weight: 600;
  text-align: left;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  color: var(--text);
  transition: background 0.15s ease;
}
.event-accordion__header:hover { background: var(--bg); }
.event-accordion__header:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.event-accordion__title { flex: 1 1 auto; min-width: 0; }
.event-accordion__summary-row {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  font-weight: 400;
  font-size: 13px;
  color: var(--text-muted);
}
.event-accordion__summary-row span { white-space: nowrap; }
.event-accordion__summary-row .event-accordion__roles { color: var(--text); }
.event-accordion__summary-row .event-accordion__applicants { color: var(--status-ok, #198754); }
.event-accordion__summary-row .event-accordion__gaps { color: var(--status-warn, #d4a012); font-weight: 600; }
.event-accordion__summary-row .event-accordion__gaps.event-accordion__gaps--none { color: var(--text-muted); font-weight: 400; }
.event-accordion__chevron {
  flex-shrink: 0;
  transition: transform 0.2s ease;
  color: var(--text-muted);
  font-size: 12px;
}
.event-accordion--open .event-accordion__chevron { transform: rotate(90deg); }
.event-accordion__body {
  display: none;
  padding: 0;
  border-top: 1px solid var(--border);
}
.event-accordion--open .event-accordion__body { display: block; }
.event-accordion__section {
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}
.event-accordion__section:last-child { border-bottom: none; }
.event-accordion__section-title { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.03em; color: var(--text-muted); margin: 0 0 10px 0; }
.event-accordion__section table { width: 100%; font-size: 13px; border-collapse: collapse; }
.event-accordion__section th,
.event-accordion__section td { padding: 6px 10px; text-align: left; border-bottom: 1px solid var(--border); }
.event-accordion__section th { color: var(--text-muted); font-weight: 600; }
.event-accordion__section .event-accordion__empty { color: var(--text-muted); font-size: 13px; }
.reports-focus-event { /* legacy: keep for any remaining use */
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 12px;
  overflow: hidden;
}
.reports-focus-event-header {
  padding: 12px 16px;
  font-weight: 600;
  font-size: 14px;
  background: rgba(212, 160, 18, 0.08);
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.reports-focus-event-gaps-count { color: var(--status-warn, #d4a012); font-weight: 700; }
.reports-focus-event-roles { padding: 12px 16px; font-size: 13px; }
.reports-focus-event-roles table { width: 100%; border-collapse: collapse; }
.reports-focus-event-roles th,
.reports-focus-event-roles td { padding: 6px 10px; text-align: left; border-bottom: 1px solid var(--border); }
.reports-focus-event-roles th { color: var(--text-muted); font-weight: 600; }
.reports-ontheday-section { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); }
.reports-ontheday-table { width: 100%; font-size: 13px; border-collapse: collapse; margin-top: 12px; }
.reports-ontheday-table th,
.reports-ontheday-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border); }
.reports-ontheday-table th { color: var(--text-muted); font-weight: 600; }
.kv { display: grid; grid-template-columns: 140px 1fr; gap: 8px 16px; font-size: 13px; }
.kv dt { color: var(--text-muted); margin: 0; }
.kv dd { margin: 0; }

/* Users: sidebar + content layout */
.users-layout,
.events-layout {
  display: flex;
  gap: 0;
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
  position: relative;
}
.users-sidebar,
.events-sidebar {
  width: 280px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  margin-right: 20px;
  overflow: hidden;
  transition: width 0.2s ease, margin 0.2s ease, padding 0.2s ease;
}
.sidebar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
  flex-shrink: 0;
}
.sidebar-head .sidebar-title {
  margin: 0;
  flex: 1;
  min-width: 0;
}
.sidebar-toggle {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text-muted);
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}
.sidebar-toggle:hover {
  background: var(--bg);
  color: var(--text);
}
.sidebar-inner {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
/* Applicants filters panel: scroll inner content so Export CSV and message are reachable */
.applicants-filters-panel .sidebar-inner {
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  padding-right: 4px;
}
/* Collapsed: narrow strip, only toggle visible */
.users-layout.sidebar-collapsed .users-sidebar,
.events-layout.sidebar-collapsed .events-sidebar {
  width: 48px;
  min-width: 48px;
  padding: 8px;
  margin-right: 8px;
}
.users-layout.sidebar-collapsed .users-sidebar .sidebar-inner,
.events-layout.sidebar-collapsed .events-sidebar .sidebar-inner {
  display: none;
}
.users-layout.sidebar-collapsed .users-sidebar .sidebar-head .sidebar-title,
.events-layout.sidebar-collapsed .events-sidebar .sidebar-head .sidebar-title {
  display: none;
}
.users-layout.sidebar-collapsed .users-sidebar .sidebar-toggle,
.events-layout.sidebar-collapsed .events-sidebar .sidebar-toggle {
  margin: 0 auto;
}
.users-layout.sidebar-collapsed .users-sidebar .sidebar-toggle::before,
.events-layout.sidebar-collapsed .events-sidebar .sidebar-toggle::before {
  content: '▶';
}
.users-layout.sidebar-collapsed .users-sidebar .sidebar-toggle,
.events-layout.sidebar-collapsed .events-sidebar .sidebar-toggle {
  font-size: 0;
}
.users-layout.sidebar-collapsed .users-sidebar .sidebar-toggle::before,
.events-layout.sidebar-collapsed .events-sidebar .sidebar-toggle::before {
  font-size: 14px;
}
/* Hide default toggle text when collapsed (show ::before only) */
.users-layout.sidebar-collapsed .users-sidebar .sidebar-toggle,
.events-layout.sidebar-collapsed .events-sidebar .sidebar-toggle {
  font-size: 0;
}
/* Reports: open button (mobile) */
.reports-sidebar-open-btn {
  display: none;
  position: absolute;
  left: 12px;
  top: 12px;
  z-index: 42;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  align-items: center;
  justify-content: center;
}
.reports-sidebar-open-btn:hover { background: var(--bg); }
.reports-layout.sidebar-collapsed .reports-sidebar-open-btn {
  display: flex;
}

/* Open button: show when sidebar collapsed on desktop; always available on mobile */
.sidebar-open-btn {
  display: none;
  position: fixed;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 45;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  align-items: center;
  justify-content: center;
  transition: background 0.15s, box-shadow 0.15s;
}
.sidebar-open-btn:hover {
  background: var(--bg);
  box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}
.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 40;
  background: rgba(0,0,0,0.35);
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
}
.sidebar-open .sidebar-backdrop {
  pointer-events: auto;
}

/* Mobile: sidebar/filters as overlay, open button to show */
@media (max-width: 768px) {
  .users-layout .sidebar-open-btn,
  .events-layout .sidebar-open-btn,
  .applicants-layout .sidebar-open-btn {
    display: flex !important;
  }
  .reports-layout .reports-sidebar-open-btn {
    display: flex !important;
  }
  .reports-layout.sidebar-open .reports-sidebar-open-btn {
    display: none !important;
  }
  .users-layout.sidebar-open .sidebar-open-btn,
  .events-layout.sidebar-open .sidebar-open-btn,
  .applicants-layout.sidebar-open .sidebar-open-btn {
    display: none !important;
  }
  .reports-mobile-picker {
    display: flex !important;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
  }
  .reports-sidebar {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: 260px;
    max-width: 85vw;
    z-index: 50;
    transform: translateX(-100%);
    transition: transform 0.2s ease;
    box-shadow: 4px 0 20px rgba(0,0,0,0.1);
  }
  .reports-layout.sidebar-open .reports-sidebar {
    transform: translateX(0);
  }
  .reports-layout.sidebar-open .reports-sidebar-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 40;
    background: rgba(0,0,0,0.35);
    pointer-events: auto;
  }
  .reports-content { padding: 12px 16px; }
  .reports-filters { flex-wrap: wrap; }
  .reports-filter-select { min-width: 140px; }
  .reports-panel .reports-events-table,
  .reports-panel .reports-gaps-table,
  .reports-panel .reports-ontheday-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .reports-panel .reports-events-table th,
  .reports-panel .reports-events-table td,
  .reports-panel .reports-gaps-table th,
  .reports-panel .reports-gaps-table td,
  .reports-panel .reports-ontheday-table th,
  .reports-panel .reports-ontheday-table td {
    padding: 6px 10px;
    font-size: 12px;
  }
  .users-sidebar,
  .events-sidebar,
  .applicants-filters-panel {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: 280px;
    max-width: 85vw;
    z-index: 50;
    margin: 0;
    border-radius: 0 12px 12px 0;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    box-shadow: none;
  }
  .users-layout.sidebar-open .users-sidebar,
  .events-layout.sidebar-open .events-sidebar,
  .applicants-layout.sidebar-open .applicants-filters-panel {
    transform: translateX(0);
    box-shadow: 4px 0 20px rgba(0,0,0,0.15);
  }
  .users-layout.sidebar-open .sidebar-backdrop,
  .events-layout.sidebar-open .sidebar-backdrop,
  .applicants-layout.sidebar-open .sidebar-backdrop {
    display: block;
    opacity: 1;
  }
  /* On mobile, collapsed state still uses full-width overlay when open */
  .users-layout.sidebar-collapsed.sidebar-open .users-sidebar,
  .events-layout.sidebar-collapsed.sidebar-open .events-sidebar,
  .applicants-layout.sidebar-collapsed.sidebar-open .applicants-filters-panel {
    width: 280px;
    max-width: 85vw;
    padding: 16px;
  }
  .users-layout.sidebar-collapsed.sidebar-open .users-sidebar .sidebar-inner,
  .events-layout.sidebar-collapsed.sidebar-open .events-sidebar .sidebar-inner,
  .applicants-layout.sidebar-collapsed.sidebar-open .applicants-filters-panel .sidebar-inner {
    display: flex;
  }
  .users-layout.sidebar-collapsed.sidebar-open .users-sidebar .sidebar-head .sidebar-title,
  .events-layout.sidebar-collapsed.sidebar-open .events-sidebar .sidebar-head .sidebar-title,
  .applicants-layout.sidebar-collapsed.sidebar-open .applicants-filters-panel .sidebar-head .sidebar-title {
    display: block;
  }
  .users-layout.sidebar-collapsed.sidebar-open .users-sidebar .sidebar-toggle,
  .events-layout.sidebar-collapsed.sidebar-open .events-sidebar .sidebar-toggle,
  .applicants-layout.sidebar-collapsed.sidebar-open .applicants-filters-panel .sidebar-toggle {
    font-size: 0;
  }
  .users-layout.sidebar-collapsed.sidebar-open .users-sidebar .sidebar-toggle::before,
  .events-layout.sidebar-collapsed.sidebar-open .events-sidebar .sidebar-toggle::before,
  .applicants-layout.sidebar-collapsed.sidebar-open .applicants-filters-panel .sidebar-toggle::before {
    content: '◀';
    font-size: 14px;
  }
}
.sidebar-title {
  margin: 0 0 6px 0;
  font-size: 16px;
  font-weight: 600;
}
.sidebar-hint {
  margin: 0 0 12px 0;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
  flex-shrink: 0;
}
.sidebar-search {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  margin-bottom: 8px;
  flex-shrink: 0;
}
.sidebar-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
  flex-shrink: 0;
}
.sidebar-filters .sidebar-filter-select {
  flex: 1;
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
}
.sidebar-message {
  font-size: 12px;
  margin: 0 0 10px 0;
  flex-shrink: 0;
}
.user-list {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.user-list-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 8px;
  padding: 8px 10px;
  border-radius: 6px;
  margin-bottom: 4px;
  font-size: 13px;
}
.user-list-item:hover { background: var(--bg); }
.user-list-item.selected {
  background: #e7f1ff;
  border-left: 3px solid var(--primary);
  padding-left: 7px;
}
.user-list-avatar {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--bg);
}
.user-avatar-wrap {
  display: block;
  width: 100%;
  height: 100%;
}
.user-avatar-wrap .user-avatar-initials { width: 100%; height: 100%; }
.user-avatar {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.user-avatar-initials {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--border);
}
.user-list-link {
  flex: 1 1 auto;
  min-width: 0;
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}
.user-list-link:hover { text-decoration: underline; }
.user-item-extra {
  font-size: 11px;
  color: var(--text-muted);
  background: var(--bg);
  padding: 2px 6px;
  border-radius: 4px;
}
.pill {
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  flex-shrink: 0;
  border: 1px solid transparent;
  letter-spacing: 0.02em;
}
/* User list: Active / Archived */
.pill-active {
  background: linear-gradient(135deg, #0f5132 0%, #198754 100%);
  color: #fff;
  border-color: #0a3622;
  box-shadow: 0 1px 2px rgba(0,0,0,0.08);
}
.pill-archived {
  background: #e9ecef;
  color: #495057;
  border-color: #dee2e6;
}

.users-content {
  flex: 1;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}
.users-stats {
  margin-bottom: 20px;
}
.stats-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 18px;
  min-width: 100px;
}
.stat-card .stat-value { display: block; font-size: 22px; font-weight: 600; color: var(--text); }
.stat-card .stat-label { font-size: 12px; color: var(--text-muted); display: inline-flex; align-items: center; gap: 4px; }
.stat-card .stat-label-icon { font-size: 13px; opacity: 0.9; }
.stat-card .stat-label-icon-ok { color: #198754; }
.stat-card .stat-label-icon-warn { color: #856404; }
.stat-card.stat-ok .stat-value { color: #198754; }
.stat-card.stat-warn .stat-value { color: #856404; }
.stat-card.stat-muted .stat-value { color: var(--text-muted); }

.user-detail {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 20px;
  border-left: 4px solid var(--primary);
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
.user-detail h2 { margin: 0 0 16px 0; font-size: 16px; font-weight: 600; }
.user-profile-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.user-profile-image-wrap {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--bg);
}
.user-profile-image-wrap .user-profile-image,
.user-profile-image-wrap .user-profile-initials { width: 100%; height: 100%; }
.user-profile-image {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--bg);
}
.user-profile-initials {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--border);
}
.user-profile-header-info { min-width: 0; }
.user-profile-name { margin: 0; font-size: 18px; font-weight: 600; }
.user-detail-empty {
  padding: 24px;
  text-align: center;
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: 8px;
}

/* User profile tabs (same format as Rosterfy profile modal) */
.user-profile-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 2px 0;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.user-profile-tabs button {
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  background: transparent;
  border: none;
  border-radius: 6px;
  cursor: pointer;
}
.user-profile-tabs button:hover {
  color: var(--text);
  background: var(--bg);
}
.user-profile-tabs button.active {
  color: var(--primary);
  background: rgba(var(--primary-rgb), 0.1);
}
.user-profile-tab-panel {
  display: none;
}
.user-profile-tab-panel.active {
  display: block;
}
.user-profile-tab-panel .sub-section {
  margin-bottom: 20px;
}
.user-profile-tab-panel .sub-section:last-child { margin-bottom: 0; }

/* Applicants: collapsible filters panel + content (same pattern as sidebars) */
.applicants-layout {
  display: flex;
  gap: 0;
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
  position: relative;
}
.applicants-filters-panel {
  width: 280px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  margin-right: 20px;
  overflow: hidden;
  transition: width 0.2s ease, margin 0.2s ease, padding 0.2s ease;
}
.applicants-filters-panel .sidebar-head {
  flex-shrink: 0;
}
.applicants-layout.sidebar-collapsed .applicants-filters-panel {
  width: 48px;
  min-width: 48px;
  padding: 8px;
  margin-right: 8px;
}
.applicants-layout.sidebar-collapsed .applicants-filters-panel .sidebar-inner {
  display: none;
}
.applicants-layout.sidebar-collapsed .applicants-filters-panel .sidebar-head .sidebar-title {
  display: none;
}
.applicants-layout.sidebar-collapsed .applicants-filters-panel .sidebar-toggle {
  margin: 0 auto;
  font-size: 0;
}
.applicants-layout.sidebar-collapsed .applicants-filters-panel .sidebar-toggle::before {
  content: '▶';
  font-size: 14px;
}
.applicants-page.applicants-content {
  flex: 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 16px;
}
.applicants-page-title {
  margin: 0 0 8px 0;
  font-size: 16px;
  font-weight: 600;
}
.applicants-content .section-accent {
  margin-bottom: 16px;
}
.event-list {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.event-list-item {
  padding: 8px 10px;
  border-radius: 6px;
  margin-bottom: 6px;
  font-size: 13px;
  border-left: 3px solid transparent;
}
.event-list-item:hover { background: var(--bg); }
.event-list-item.selected {
  background: #e7f1ff;
  border-left-color: var(--primary);
}
/* Events sidebar: same card layout as Functional areas */
.events-sidebar .event-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.events-sidebar .event-list-item {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: left;
  width: 100%;
  padding: 12px 14px;
  margin-bottom: 0;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 8px;
  background: var(--card-bg, #fff);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.events-sidebar .event-list-item:hover {
  border-color: var(--primary, #0d6efd);
  box-shadow: 0 2px 6px rgba(13, 110, 253, 0.12);
  background: var(--card-bg, #fff);
}
.events-sidebar .event-list-item.selected {
  border-color: var(--primary, #0d6efd);
  background: #e7f1ff;
  box-shadow: 0 2px 6px rgba(13, 110, 253, 0.15);
  border-left: 1px solid var(--primary);
}
.events-sidebar .event-list-item .event-list-item-name,
.events-sidebar .event-list-item .event-list-link {
  display: block;
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 6px;
  line-height: 1.3;
  color: var(--text, #212529);
  text-align: left;
}
.events-sidebar .event-list-item .event-list-link:hover { color: var(--primary); text-decoration: underline; }
.events-sidebar .event-list-item .event-item-meta {
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-color, #eee);
}
.events-sidebar .event-list-item .event-item-meta span { display: block; }
.events-sidebar .event-list-item .event-item-stats {
  margin-top: 0;
  font-size: 12px;
  gap: 12px;
}
/* Reset button appearance so event cards look like FA cards */
.events-sidebar .event-list-item {
  font-family: inherit;
  cursor: pointer;
  text-align: left;
  border-left: none;
}

.event-list-link {
  display: block;
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
  margin-bottom: 4px;
}
.event-list-link:hover { text-decoration: underline; }
.event-item-meta {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.4;
}
.event-item-meta span { display: block; }
.event-item-meta .event-item-venue { display: block; }

.events-content {
  flex: 1;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 16px;
}

/* Applicants: filters panel inner (stats + filters) */
.applicants-filters-panel .applicants-stats-row {
  margin-bottom: 12px;
}
.applicants-filters-panel .applicants-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
}
.applicants-filters-panel .applicants-filters .applicant-filter-search {
  min-width: 100%;
}
.applicants-page {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
  padding: 16px;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}
.page-hint {
  margin: 0 0 14px 0;
  padding: 10px 14px;
  font-size: 13px;
  color: #495057;
  background: #f0f4f8;
  border-left: 4px solid #6c757d;
  border-radius: 0 6px 6px 0;
  line-height: 1.45;
}
.applicants-stats-row {
  margin-bottom: 20px;
}
.applicants-page .applicants-stats-row .stats-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.applicants-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
}
.applicant-filter-search {
  min-width: 200px;
  max-width: 280px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
}
.applicant-filter-select {
  padding: 8px 10px;
  min-height: 38px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
  min-width: 140px;
}
.applicant-export-btn {
  padding: 8px 14px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  font-size: 14px;
  cursor: pointer;
  margin-left: auto;
}
.applicant-export-btn:hover { background: var(--bg); }
.applicants-message { margin: 12px 0 24px 0; font-size: 13px; }
.applicants-message-empty { padding: 10px 12px; background: var(--surface-alt, #f0f6fc); border-left: 4px solid var(--status-warn, #d4a012); border-radius: 4px; }
.applicants-empty-cell { padding: 2rem; text-align: center; vertical-align: middle; }
.applicants-empty-title { font-weight: 600; margin: 0 0 0.5rem 0; }
.applicants-empty-hint { margin: 0; font-size: 14px; color: var(--text-muted); max-width: 480px; margin-left: auto; margin-right: auto; line-height: 1.5; }
.applicants-table-wrap { overflow-x: auto; margin-bottom: 16px; flex: 1; min-height: 0; }
.applicants-table {
  width: 100%;
  font-size: 13px;
  border-collapse: collapse;
}
.applicants-table th,
.applicants-table td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.applicants-table th { background: var(--bg); font-weight: 600; }
.applicant-user-link { color: var(--primary); text-decoration: none; }
.applicant-user-link:hover { text-decoration: underline; }
.applicant-detail-modal-link { color: var(--primary); text-decoration: none; }
.applicant-detail-modal-link:hover { text-decoration: underline; }

/* Status pills (application status) — used in Users profile roles & Applicants */
.pill-status-accepted {
  background: linear-gradient(135deg, #0d6938 0%, #198754 100%);
  color: #fff;
  border-color: #0a3d21;
  box-shadow: 0 1px 2px rgba(0,0,0,0.1);
}
.pill-status-pending {
  background: linear-gradient(135deg, #e6a800 0%, #ffc107 100%);
  color: #000;
  border-color: #b38600;
  box-shadow: 0 1px 2px rgba(0,0,0,0.08);
}
.pill-status-applied {
  background: linear-gradient(135deg, #0a58ca 0%, #0d6efd 100%);
  color: #fff;
  border-color: #084298;
  box-shadow: 0 1px 2px rgba(0,0,0,0.1);
}
.pill-status-declined {
  background: linear-gradient(135deg, #5c5c5c 0%, #6c757d 100%);
  color: #fff;
  border-color: #424649;
  box-shadow: 0 1px 2px rgba(0,0,0,0.08);
}
.pill-status-other {
  background: #e9ecef;
  color: #495057;
  border-color: #dee2e6;
}
.pill-status-invited {
  background: linear-gradient(135deg, #5a3d8a 0%, #6f42c1 100%);
  color: #fff;
  border-color: #432874;
}
.pill-status-withdrawn {
  background: linear-gradient(135deg, #8b475d 0%, #a55a6e 100%);
  color: #fff;
  border-color: #6b3949;
}
.pill-status-rejected {
  background: linear-gradient(135deg, #7a2a2a 0%, #a52a2a 100%);
  color: #fff;
  border-color: #5c1f1f;
}

/* Eligibility pills */
.pill-eligibility-ok {
  background: linear-gradient(135deg, #0d6938 0%, #198754 100%);
  color: #fff;
  border-color: #0a3d21;
}
.pill-eligibility-pending {
  background: linear-gradient(135deg, #e6a800 0%, #ffc107 100%);
  color: #000;
  border-color: #b38600;
}
.pill-eligibility-no {
  background: linear-gradient(135deg, #b02a37 0%, #dc3545 100%);
  color: #fff;
  border-color: #842029;
}
.pill-eligibility-expired {
  background: linear-gradient(135deg, #8a5a00 0%, #d4a012 100%);
  color: #fff;
  border-color: #6b4600;
}
.pill-eligibility-partial {
  background: linear-gradient(135deg, #0d6efd 0%, #4d8bdd 100%);
  color: #fff;
  border-color: #0a58ca;
}
.pill-eligibility-other {
  background: linear-gradient(135deg, #5c5c7a 0%, #6c757d 100%);
  color: #fff;
  border-color: #4a4a5e;
}

/* Pagination */
.applicants-pagination { margin-top: 12px; }
.pagination-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 13px;
}
.pagination-info { color: var(--text-muted); }
.pagination-pages { color: var(--text); }
.pagination-btn {
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  cursor: pointer;
  font-size: 13px;
}
.pagination-btn:hover:not(:disabled) { background: var(--bg); }
.pagination-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.events-stats { margin-bottom: 20px; }
.event-detail {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 20px;
  border-left: 4px solid var(--primary);
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
  min-width: 0;
}
.event-detail #event-detail-content { min-width: 0; }
.event-detail h2 { margin: 0 0 16px 0; font-size: 16px; font-weight: 600; }
.event-detail-empty {
  padding: 24px;
  text-align: center;
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: 8px;
  border-left: 4px solid var(--primary);
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
.gap-table { width: 100%; font-size: 13px; border-collapse: collapse; margin-top: 12px; }
.gap-table th, .gap-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border); }
.gap-table th { background: var(--bg); font-weight: 600; }
.gap-focus {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  background: rgba(220, 53, 69, 0.18);
  color: #b02a37;
  border: 1px solid rgba(220, 53, 69, 0.5);
}
.gap-focus .gap-badge-icon { font-size: 12px; opacity: 1; }
.gap-ok {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  background: rgba(25, 135, 84, 0.18);
  color: #0d6938;
  border: 1px solid rgba(25, 135, 84, 0.45);
}
.gap-ok .gap-badge-icon { font-size: 12px; opacity: 1; }
.gap-partial {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  background: rgba(255, 193, 7, 0.22);
  color: #856404;
  border: 1px solid rgba(255, 193, 7, 0.5);
}
.gap-partial .gap-badge-icon { font-size: 11px; opacity: 0.95; }
.gap-row-focus { background: rgba(220, 53, 69, 0.08); border-left: 3px solid rgba(220, 53, 69, 0.5); }
.gap-legend { margin-top: 8px; font-size: 12px; color: var(--muted); }

/* Gap legend strip: quick visual key */
.gap-legend-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 16px;
  margin: 12px 0 8px 0;
  padding: 8px 12px;
  background: var(--bg);
  border-radius: 8px;
  border: 1px solid var(--border);
  font-size: 12px;
}
.gap-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-weight: 500;
}
.gap-legend-icon { font-size: 14px; }
.gap-legend-focus { color: #b02a37; }
.gap-legend-focus .gap-legend-icon { color: #b02a37; }
.gap-legend-ok { color: #0d6938; }
.gap-legend-ok .gap-legend-icon { color: #0d6938; }
.gap-legend-partial { color: #856404; }
.gap-legend-partial .gap-legend-icon { color: #856404; }

/* "Where to focus" callout */
.gap-focus-callout {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 12px;
  padding: 12px 14px;
  background: rgba(220, 53, 69, 0.08);
  border-left: 4px solid #dc3545;
  border-radius: 6px;
}
.gap-focus-callout-icon { font-size: 18px; flex-shrink: 0; }
.gap-focus-callout-text { margin: 0; font-size: 13px; color: var(--text); }
.gap-focus-callout-text strong { color: #b02a37; }

/* Gap analysis: fit in detail view – scrollable table + card slider */
.event-detail-tab-panel { overflow: hidden; min-width: 0; }
.gap-table-scroll-wrap {
  overflow-x: auto;
  overflow-y: visible;
  max-width: 100%;
  margin-top: 12px;
  -webkit-overflow-scrolling: touch;
}
.gap-table-scroll-wrap .gap-table { min-width: 800px; }

.gap-view-tabs {
  display: flex;
  gap: 4px;
  margin: 12px 0 0 0;
}
.gap-view-tabs [data-gap-view] {
  padding: 6px 14px;
  font-size: 13px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  cursor: pointer;
  font-weight: 500;
}
.gap-view-tabs [data-gap-view]:hover { background: var(--bg); }
.gap-view-tabs [data-gap-view].active { background: var(--primary); color: #fff; border-color: var(--primary); }

.gap-view-panel { display: none; margin-top: 12px; }
.gap-view-panel.gap-view-panel--active { display: block; }

.gap-cards-slider {
  display: flex;
  align-items: stretch;
  gap: 12px;
  margin-bottom: 8px;
}
.gap-slider-prev,
.gap-slider-next {
  flex: 0 0 auto;
  width: 40px;
  padding: 0;
  font-size: 24px;
  line-height: 1;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  cursor: pointer;
  color: var(--text);
}
.gap-slider-prev:hover:not(:disabled),
.gap-slider-next:hover:not(:disabled) { background: var(--bg); }
.gap-slider-prev:disabled,
.gap-slider-next:disabled { opacity: 0.5; cursor: not-allowed; }

.gap-cards-track {
  flex: 1 1 auto;
  min-width: 0;
  position: relative;
}
.gap-card {
  display: none;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.gap-card.gap-card--active { display: block; }
.gap-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.gap-card-title { margin: 0; font-size: 14px; font-weight: 600; line-height: 1.3; flex: 1 1 auto; min-width: 0; }
.gap-card-badge { flex: 0 0 auto; }
.gap-card-dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 16px;
  margin: 0;
  font-size: 13px;
}
.gap-card-dl dt { color: var(--text-muted); font-weight: 500; }
.gap-card-dl dd { margin: 0; }
.gap-card-dl dd.applicants-cell { word-break: break-word; }
.gap-slider-pos { margin: 0; font-size: 12px; color: var(--text-muted); }

.event-item-stats {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-muted);
}
.event-item-stat,
.event-item-venue {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.event-item-stat-icon {
  font-size: 10px;
  color: var(--primary);
  opacity: 0.9;
}
.event-item-stat-confirmed .event-item-stat-icon { color: #198754; }
.event-item-stat-onshift .event-item-stat-icon { color: var(--primary); opacity: 0.85; }
.event-item-venue-icon {
  font-size: 11px;
  color: var(--text-muted);
  opacity: 0.9;
}
.event-item-venue {
  margin-top: 2px;
  font-size: 12px;
  color: var(--text-muted);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pill-event {
  font-weight: 600;
  border: 1px solid transparent;
  margin-top: 6px;
}
.pill-event:not(.pill-archived):not(.pill-unpublished) {
  background: linear-gradient(135deg, #0d6938 0%, #198754 100%);
  color: #fff;
  border-color: #0a3d21;
}
.pill-event.pill-unpublished {
  background: linear-gradient(135deg, #b38600 0%, #ffc107 100%);
  color: #000;
  border-color: #856404;
}

/* Events sidebar: collapsing legend (symbols + tips) */
.events-sidebar-legend {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border, #dee2e6);
  font-size: 12px;
  color: var(--text-muted);
}
.events-sidebar-legend-summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--text, #1a1a1a);
  list-style: none;
  user-select: none;
}
.events-sidebar-legend-summary::-webkit-details-marker { display: none; }
.events-sidebar-legend-summary::before {
  content: '▶ ';
  font-size: 10px;
  margin-right: 4px;
}
.events-sidebar-legend[open] .events-sidebar-legend-summary::before { content: '▼ '; }
.events-sidebar-legend-content {
  margin-top: 8px;
  padding-left: 0;
}
.events-sidebar-legend-content p {
  margin: 0 0 6px 0;
  line-height: 1.4;
}
.events-sidebar-legend-row { display: flex; align-items: flex-start; gap: 6px; }
.events-sidebar-legend-icon {
  flex-shrink: 0;
  font-size: 12px;
  color: var(--primary);
  opacity: 0.9;
}
.events-sidebar-legend-icon-confirmed { color: #0d6938; font-weight: bold; }
.events-sidebar-legend-colors { margin-top: 8px; }
.events-sidebar-legend-tip {
  margin-top: 10px;
  padding: 8px 10px;
  background: rgba(13, 110, 253, 0.08);
  border-radius: 6px;
  border-left: 3px solid var(--primary);
}

/* Shared legend & tips (Users, Applicants sidebars) */
.sidebar-legend {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border, #dee2e6);
  font-size: 12px;
  color: var(--text-muted);
}
.sidebar-legend-summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--text, #1a1a1a);
  list-style: none;
  user-select: none;
}
.sidebar-legend-summary::-webkit-details-marker { display: none; }
.sidebar-legend-summary::before {
  content: '▶ ';
  font-size: 10px;
  margin-right: 4px;
}
.sidebar-legend[open] .sidebar-legend-summary::before { content: '▼ '; }
.sidebar-legend-content { margin-top: 8px; padding-left: 0; }
.sidebar-legend-content p { margin: 0 0 6px 0; line-height: 1.4; }
.sidebar-legend-row { display: flex; align-items: flex-start; gap: 6px; }
.sidebar-legend-tip {
  margin-top: 10px;
  padding: 8px 10px;
  background: rgba(13, 110, 253, 0.08);
  border-radius: 6px;
  border-left: 3px solid var(--primary);
}

/* Shifts by role offer blocks */
.role-offer-block {
  margin-bottom: 20px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}
.role-offer-block:last-child { border-bottom: none; }
.role-offer-heading {
  margin: 0 0 10px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.shifts-sub-table {
  width: 100%;
  font-size: 13px;
  border-collapse: collapse;
  margin: 8px 0 12px 0;
}
.shifts-sub-table th,
.shifts-sub-table td {
  padding: 6px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.shifts-sub-table th {
  background: var(--bg);
  font-weight: 600;
}
.applicants-list {
  margin: 0;
  font-size: 13px;
}

/* Applicant cards in role (Roles & shifts): name link, role status, shift status, contact */
.applicant-cards-list {
  list-style: none;
  margin: 8px 0 0 0;
  padding: 0;
  font-size: 13px;
}
.applicant-card {
  margin-bottom: 10px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg);
}
.applicant-card:last-child { margin-bottom: 0; }
.applicant-card-name {
  font-weight: 600;
  color: var(--primary);
  text-decoration: none;
}
.applicant-card-name:hover { text-decoration: underline; }
.applicant-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}
.applicant-card-role-status,
.applicant-card-shift-status,
.applicant-card-email,
.applicant-card-phone { display: inline; }

/* Event description rendered as HTML */
.event-description-html {
  font-size: 13px;
  line-height: 1.5;
  max-width: 100%;
}
.event-description-html p { margin: 0 0 0.75em 0; }
.event-description-html p:last-child { margin-bottom: 0; }
.event-description-html strong { font-weight: 600; }
.event-description-html em { font-style: italic; }
.event-description-html a { color: var(--primary); text-decoration: none; }
.event-description-html a:hover { text-decoration: underline; }
.event-description-html ul, .event-description-html ol { margin: 0.5em 0; padding-left: 1.25em; }
.event-description-html li { margin-bottom: 0.25em; }
.event-description-html span[style] { display: inline; }

/* Status */
.status-ok { color: #198754; }
.status-warn { color: #856404; }
.status-error { color: #b02a37; }
.status-muted { color: var(--text-muted); }

/* Admin page */
#view-admin {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}
.admin-layout {
  display: flex;
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
}
.admin-sidebar {
  width: 220px;
  flex-shrink: 0;
  border-right: 1px solid var(--border);
  background: var(--bg-alt, #f6f8fa);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.admin-sidebar-head {
  padding: 16px 14px 12px;
  border-bottom: 1px solid var(--border);
}
.admin-sidebar-title {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--text, #1a1a1a);
}
.admin-nav {
  padding: 12px 0;
}
.admin-nav-item {
  display: block;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text, #1a1a1a);
  text-decoration: none;
  border-left: 3px solid transparent;
}
.admin-nav-item:hover { background: rgba(0,0,0,0.04); color: var(--primary); }
.admin-nav-item.active { color: var(--primary); border-left-color: var(--primary); background: rgba(0,0,0,0.03); }
.admin-main {
  flex: 1 1 0;
  min-width: 0;
  overflow-y: auto;
  padding: 20px 24px 32px;
  -webkit-overflow-scrolling: touch;
}
.admin-main .admin-page-title { margin: 0 0 4px 0; font-size: 22px; font-weight: 700; color: var(--text, #1a1a1a); }
.admin-page-title { margin: 0 0 4px 0; font-size: 22px; font-weight: 700; color: var(--text, #1a1a1a); }
.admin-page {
  min-height: min-content;
  display: flex;
  flex-direction: column;
}
.admin-page-desc { margin: 0 0 20px 0; font-size: 14px; color: var(--text-muted); line-height: 1.45; }
.admin-quick-access { padding: 16px; background: var(--bg-alt, #f6f8fa); border-radius: 8px; border: 1px solid var(--border); }
.admin-quick-links { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; }
.admin-quick-link {
  display: inline-block; padding: 8px 14px; background: var(--primary); color: #fff; border-radius: 6px;
  font-size: 14px; font-weight: 500; text-decoration: none; transition: opacity 0.15s;
}
.admin-quick-link:hover { opacity: 0.9; color: #fff; }
.admin-panel { flex: 1 1 auto; min-height: 0; }
.admin-panel-hidden { display: none !important; }
.admin-page .admin-section {
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
.admin-page .admin-section:last-of-type { border-bottom: none; }
.admin-page .admin-section h3 { margin: 0 0 8px 0; font-size: 15px; font-weight: 600; }
.admin-page .admin-section h4 { margin: 12px 0 8px 0; font-size: 14px; font-weight: 500; }
.admin-form { margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.admin-input, .admin-select {
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 14px;
}
.admin-input { min-width: 180px; }
.admin-btn {
  padding: 8px 14px;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
}
.admin-btn:hover { opacity: 0.9; }
.admin-btn-small { padding: 4px 8px; font-size: 12px; }
.admin-btn-danger { background: #c33; }
.admin-btn-danger:hover { opacity: 0.9; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 8px; }
.admin-table th, .admin-table td { padding: 8px 10px; text-align: left; border-bottom: 1px solid var(--border); }
.admin-table th { font-weight: 600; background: var(--bg); }
.admin-permissions-wrap {
  overflow-x: auto;
  margin-top: 8px;
}
.admin-permissions-table th:nth-child(n+2), .admin-permissions-table td:nth-child(n+2) { text-align: center; }
.admin-permissions-table input[type="checkbox"] { cursor: pointer; }
.admin-list { margin-top: 8px; }
.admin-nav-link { font-weight: 500; }

/* Admin edit user modal */
.admin-modal { position: fixed; inset: 0; z-index: 100; display: flex; align-items: center; justify-content: center; padding: 20px; }
.admin-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.4); }
.admin-modal-content {
  position: relative; background: var(--bg); border-radius: 8px; padding: 24px; max-width: 400px; width: 100%;
  box-shadow: 0 4px 20px rgba(0,0,0,0.15); display: flex; flex-direction: column; gap: 12px;
}
.admin-modal-content h3 { margin: 0 0 8px 0; font-size: 18px; }
.admin-modal-content label { font-size: 13px; font-weight: 500; }
.admin-modal-content .admin-input, .admin-modal-content .admin-select { width: 100%; box-sizing: border-box; }
.admin-modal-actions { display: flex; gap: 10px; margin-top: 8px; }
.admin-btn-secondary { background: var(--border); color: var(--text); }
.admin-event-access-modal-content { max-width: 480px; }
.admin-event-access-no-restriction { display: block; margin-bottom: 12px; font-weight: 500; }
.admin-event-access-checkboxes { max-height: 280px; overflow-y: auto; border: 1px solid var(--border); border-radius: 6px; padding: 10px; margin-bottom: 8px; }
.admin-event-access-checkbox-label { display: block; padding: 4px 0; cursor: pointer; font-weight: normal; }
.admin-event-access-checkbox-label input { margin-right: 8px; }
.admin-btn-secondary:hover { opacity: 0.9; }

/* Database viewer (admin): sidebar + query + tables tabs */
.db-viewer-layout {
  display: flex;
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
  position: relative;
}
.db-viewer-sidebar {
  width: 240px;
  flex-shrink: 0;
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.db-viewer-sidebar .sidebar-head {
  flex-shrink: 0;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.db-viewer-sidebar .sidebar-title { margin: 0; font-size: 16px; font-weight: 600; }
.db-viewer-sidebar-inner {
  flex: 1 1 0;
  overflow-y: auto;
  padding: 12px;
}
.db-viewer-sidebar-inner .sidebar-hint {
  margin: 0 0 14px 0;
  font-size: 12px;
  line-height: 1.4;
  padding: 10px 12px;
  background: linear-gradient(135deg, rgba(13, 110, 253, 0.06) 0%, rgba(13, 110, 253, 0.02) 100%);
  border-radius: 6px;
  border-left: 3px solid var(--primary);
}
.db-viewer-table-list { display: flex; flex-direction: column; gap: 8px; }
.db-viewer-table-item {
  border-radius: 8px;
  overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.db-viewer-table-item.expanded { border-color: var(--primary); box-shadow: 0 0 0 1px rgba(13, 110, 253, 0.2); }
.db-viewer-table-name {
  width: 100%;
  padding: 10px 12px;
  text-align: left;
  font-size: 13px;
  font-weight: 600;
  background: var(--bg);
  border: none;
  cursor: pointer;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: ui-monospace, monospace;
  transition: background 0.15s ease;
}
.db-viewer-table-name::before {
  content: '▸';
  font-size: 10px;
  color: var(--text-muted);
  transition: transform 0.2s ease;
}
.db-viewer-table-item.expanded .db-viewer-table-name::before { transform: rotate(90deg); }
.db-viewer-table-name:hover { background: rgba(13, 110, 253, 0.08); }
.db-viewer-table-item.expanded .db-viewer-table-name { background: rgba(13, 110, 253, 0.06); }
.db-viewer-columns {
  padding: 10px 14px 12px 14px;
  font-size: 12px;
  color: var(--text-muted);
  background: linear-gradient(180deg, rgba(0,0,0,0.02) 0%, transparent 8px);
  border-top: 1px solid var(--border);
}
.db-viewer-col {
  padding: 5px 0;
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}
.db-viewer-col-name { font-weight: 500; color: var(--text); font-family: ui-monospace, monospace; min-width: 0; }
.db-viewer-col-type {
  font-family: ui-monospace, monospace;
  font-size: 11px;
  color: var(--text-muted);
  background: var(--bg);
  padding: 2px 6px;
  border-radius: 4px;
}
.db-viewer-content {
  flex: 1 1 0;
  min-width: 0;
  overflow-y: auto;
  padding: 20px;
  display: flex;
  flex-direction: column;
}
.db-viewer-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.db-viewer-tab {
  padding: 8px 16px;
  font-size: 14px;
  font-weight: 500;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  color: var(--text-muted);
}
.db-viewer-tab:hover { color: var(--text); }
.db-viewer-tab.active { color: var(--primary); border-bottom-color: var(--primary); }
.db-viewer-panel { flex: 1 1 auto; min-height: 0; }
.db-viewer-panel-hidden { display: none !important; }
.db-viewer-table-views {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.db-viewer-load-view-label { font-size: 13px; font-weight: 500; color: var(--text); }
.db-viewer-select {
  min-width: 280px;
  padding: 8px 10px;
  font-size: 13px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--surface);
}
.db-viewer-editor-wrap { margin: 12px 0; }
.db-viewer-sql {
  width: 100%;
  min-height: 120px;
  padding: 12px;
  font-family: ui-monospace, monospace;
  font-size: 13px;
  border: 1px solid var(--border);
  border-radius: 4px;
  resize: vertical;
  box-sizing: border-box;
}
.db-viewer-actions { display: flex; gap: 10px; margin-top: 10px; }
.db-viewer-query-message { margin: 8px 0; font-size: 13px; }
.db-viewer-results-wrap {
  overflow-x: auto;
  margin-top: 16px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--surface);
}
.db-viewer-results { width: 100%; min-width: 400px; }
.db-viewer-results th, .db-viewer-results td { padding: 8px 10px; text-align: left; border-bottom: 1px solid var(--border); white-space: nowrap; max-width: 300px; overflow: hidden; text-overflow: ellipsis; }
.db-viewer-results th { font-weight: 600; background: var(--bg); position: sticky; top: 0; }
.db-viewer-schema-detail { overflow-x: auto; }
.db-viewer-schema-detail .gap-table { width: 100%; }

/* Relationships tab: link table cards */
.db-viewer-rel-section-title { font-size: 14px; font-weight: 600; color: var(--text); margin: 20px 0 10px 0; }
.db-viewer-rel-section-title:first-of-type { margin-top: 0; }
.db-viewer-relationships-list { display: flex; flex-direction: column; gap: 16px; margin-top: 12px; }
.db-viewer-rel-card {
  padding: 14px 18px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  border-left: 4px solid var(--primary);
}
.db-viewer-rel-card h4 { margin: 0 0 6px 0; font-size: 14px; font-family: ui-monospace, monospace; color: var(--primary); }
.db-viewer-rel-card p { margin: 0 0 10px 0; font-size: 13px; color: var(--text-muted); line-height: 1.45; }
.db-viewer-rel-card code { font-size: 12px; background: var(--bg); padding: 2px 6px; border-radius: 4px; }
.db-viewer-rel-card .db-viewer-btn-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.db-viewer-rel-card .db-viewer-example-btn { margin-top: 0; }
.db-viewer-rel-card .db-viewer-example-btn-primary { font-weight: 600; }

/* Query results: object/JSONB cells */
.db-viewer-cell { white-space: normal; vertical-align: top; }
.db-viewer-obj-cell { min-width: 120px; max-width: 320px; }
.db-viewer-obj-preview {
  font-size: 12px;
  color: var(--primary);
  cursor: pointer;
  padding: 4px 8px;
  background: rgba(13, 110, 253, 0.06);
  border-radius: 4px;
  border: 1px dashed var(--border);
}
.db-viewer-obj-preview:hover { background: rgba(13, 110, 253, 0.12); }
.db-viewer-obj-preview.expanded { border-style: solid; margin-bottom: 6px; }
.db-viewer-obj-full {
  font-size: 11px;
  margin: 0;
  padding: 8px;
  background: var(--bg);
  border-radius: 4px;
  overflow: auto;
  max-height: 200px;
  white-space: pre-wrap;
  word-break: break-word;
}

.db-viewer-sidebar-open-btn {
  display: none;
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--surface);
  cursor: pointer;
  font-size: 14px;
}
@media (max-width: 768px) {
  .db-viewer-layout .db-viewer-sidebar-open-btn { display: flex !important; }
  .db-viewer-layout.sidebar-open .db-viewer-sidebar-open-btn { display: none !important; }
  .db-viewer-sidebar {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: 260px;
    max-width: 85vw;
    z-index: 100;
    transform: translateX(-100%);
    transition: transform 0.2s ease;
  }
  .db-viewer-layout.sidebar-open .db-viewer-sidebar { transform: translateX(0); }
  .db-viewer-layout.sidebar-open .db-viewer-sidebar-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.3);
    z-index: 99;
  }
  .db-viewer-content { padding: 12px 16px; }
}

/* Role offer user detail: clickable rows and modal */
.role-offer-row-link { cursor: pointer; }
.role-offer-row-link:hover { background: var(--bg); }
.role-offer-detail-body { margin: 16px 0; max-height: 60vh; overflow-y: auto; }
.role-offer-modal-section { margin-bottom: 16px; }
.role-offer-modal-section:last-child { margin-bottom: 0; }
.role-offer-modal-section-title { margin: 0 0 8px 0; font-size: 14px; font-weight: 600; color: var(--text); }
.role-offer-detail-kv { display: grid; grid-template-columns: auto 1fr; gap: 6px 16px; align-items: baseline; }
.role-offer-detail-kv dt { font-weight: 600; color: var(--text-muted); margin: 0; }
.role-offer-detail-kv dd { margin: 0; }
.role-offer-detail-kv-grid { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); }

/* Role offer modal: user header with profile picture */
.role-offer-modal-user-section { padding-bottom: 4px; }
.role-offer-modal-user-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 4px;
}
.role-offer-modal-avatar-wrap {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--bg);
}
.role-offer-modal-avatar-wrap .role-offer-modal-avatar,
.role-offer-modal-avatar-wrap .role-offer-modal-avatar-initials { width: 100%; height: 100%; }
.role-offer-modal-avatar {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--bg);
}
.role-offer-modal-avatar-initials {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--border);
}
.role-offer-modal-user-header-info { min-width: 0; }
.role-offer-modal-user-name { margin: 0 0 2px 0; font-size: 17px; font-weight: 600; color: var(--text); }
.role-offer-modal-user-meta { margin: 0; font-size: 13px; color: var(--text-muted); }

.role-offer-application-modal-content { max-width: 520px; }
.role-offer-application-modal-content.role-offer-modal-with-shifts { max-width: 680px; }
.role-offer-application-modal-content .role-offer-modal-heading { margin: 0 0 4px 0; font-size: 17px; font-weight: 600; color: var(--text); padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.role-offer-application-modal-content .role-offer-modal-section + .role-offer-modal-section { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border); }
.role-offer-shifts-table { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 8px; }
.role-offer-shifts-table th, .role-offer-shifts-table td { padding: 6px 10px; text-align: left; border-bottom: 1px solid var(--border); }
.role-offer-shifts-table th { background: var(--surface-alt, #f5f5f5); font-weight: 600; }
.applicants-section-header { position: relative; }
.applicants-toolbar { margin-top: 10px; display: flex; align-items: center; gap: 8px; }
.applicants-columns-dropdown { position: absolute; top: 100%; left: 0; margin-top: 4px; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; box-shadow: 0 4px 12px rgba(0,0,0,0.12); padding: 12px 16px; z-index: 20; min-width: 220px; max-height: 320px; overflow-y: auto; }
.applicants-columns-dropdown-title { margin: 0 0 10px 0; font-size: 13px; font-weight: 600; }
.applicants-column-checkbox-label { display: block; margin: 4px 0; font-size: 13px; cursor: pointer; }
.applicants-column-checkbox-label input { margin-right: 8px; }
.applicants-columns-reset-btn { display: block; margin-top: 12px; padding: 6px 10px; font-size: 12px; color: var(--primary); background: none; border: 1px solid var(--border); border-radius: 6px; cursor: pointer; }
.applicants-columns-reset-btn:hover { background: var(--surface-alt, rgba(0,0,0,0.04)); }
.applicant-row-clickable { cursor: pointer; }
.applicant-row-clickable:hover { background: var(--surface-alt, rgba(0,0,0,0.04)); }
.applicant-row-clickable:focus { outline: 2px solid var(--primary); outline-offset: -1px; }

/* Event detail: tabs (match user profile feel) */
.event-detail-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 2px 0;
  margin: 0 0 16px 0;
  border-bottom: 1px solid var(--border);
}
.event-detail-tabs button {
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  border-radius: 4px 4px 0 0;
}
.event-detail-tabs button:hover {
  color: var(--text);
  background: var(--bg);
}
.event-detail-tabs button.active {
  color: var(--primary);
  background: rgba(var(--primary-rgb), 0.08);
  border-bottom-color: var(--primary);
}
.event-detail-tab-panel {
  display: none;
  padding-top: 4px;
}
.event-detail-tab-panel.active {
  display: block;
}

/* Functional areas view: event tabs in detail */
/* Functional areas sidebar: row-by-row cards */
.fa-sidebar .event-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.fa-sidebar .fa-list-item,
.fa-sidebar .event-list-item.fa-list-item {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: left;
  width: 100%;
  padding: 12px 14px;
  margin-bottom: 0;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 8px;
  background: var(--card-bg, #fff);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.fa-sidebar .fa-list-item:hover,
.fa-sidebar .event-list-item.fa-list-item:hover {
  border-color: var(--primary, #0d6efd);
  box-shadow: 0 2px 6px rgba(13, 110, 253, 0.12);
  background: var(--card-bg, #fff);
}
.fa-sidebar .fa-list-item.selected,
.fa-sidebar .event-list-item.fa-list-item.selected {
  border-color: var(--primary, #0d6efd);
  background: #e7f1ff;
  box-shadow: 0 2px 6px rgba(13, 110, 253, 0.15);
}
.fa-sidebar .fa-list-item .event-list-item-name {
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 6px;
  line-height: 1.3;
  color: var(--text, #212529);
}
.fa-sidebar .fa-list-item .event-item-meta {
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-color, #eee);
}
.fa-sidebar .fa-list-item .event-item-stats {
  margin-top: 0;
  font-size: 12px;
  gap: 12px;
}

.event-detail-heading-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.event-detail-heading-row h2 { margin: 0; flex: 1; min-width: 0; }
.export-pdf-btn {
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 500;
  color: #0d6efd;
  background: #fff;
  border: 1px solid #0d6efd;
  border-radius: 6px;
  cursor: pointer;
  white-space: nowrap;
}
.export-pdf-btn:hover { background: #e7f1ff; }
.export-pdf-btn:disabled { opacity: 0.6; cursor: not-allowed; }

/* FA role mini card: totals with colour by shift coverage */
.fa-role-mini-card {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  padding: 10px 16px;
  margin-top: 12px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  border: 1px solid transparent;
}
.fa-role-mini-card--ok {
  background: rgba(25, 135, 84, 0.12);
  border-color: rgba(25, 135, 84, 0.35);
  color: #1a6b1a;
}
.fa-role-mini-card--partial {
  background: rgba(210, 140, 0, 0.12);
  border-color: rgba(210, 140, 0, 0.35);
  color: #8b6914;
}
.fa-role-mini-card--empty {
  background: rgba(108, 117, 125, 0.1);
  border-color: rgba(108, 117, 125, 0.25);
  color: var(--text-muted);
}
.fa-mini-card-stat { font-variant-numeric: tabular-nums; white-space: nowrap; }
.fa-role-mini-card--ok .fa-mini-card-stat { color: #1a6b1a; }
.fa-role-mini-card--partial .fa-mini-card-stat { color: #8b6914; }

/* FA role table: Venue > Role | Event | □ | ● | ▷ | ✔ (6 columns; detail page uses different symbols from sidebar) */
.fa-role-table {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 12px;
  border: 1px solid var(--border-color, #dee2e6);
  border-radius: 8px;
  overflow: hidden;
  background: var(--surface, #fff);
}
.fa-role-row,
.fa-role-header {
  display: grid;
  grid-template-columns: minmax(140px, 2.5fr) minmax(120px, 1.5fr) 56px 56px 56px 56px;
  gap: 12px 16px;
  align-items: center;
  padding: 10px 14px;
  font-size: 13px;
  text-align: left;
}
.fa-role-header {
  background: var(--bg, #f8f9fa);
  font-weight: 600;
  color: var(--text-muted, #6c757d);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  border-bottom: 1px solid var(--border-color, #dee2e6);
}
.fa-role-row {
  cursor: pointer;
  border-bottom: 1px solid var(--border-color, #eee);
  list-style: none;
}
.fa-role-row-wrap:last-child .fa-role-row { border-bottom: 0; }
.fa-role-row:hover { background: rgba(13, 110, 253, 0.06); }
.fa-role-cell-venue-role { font-weight: 500; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.fa-role-disclosure { margin-right: 4px; font-size: 14px; color: var(--text-muted); }
.fa-role-row-wrap[open] .fa-role-disclosure { transform: rotate(90deg); display: inline-block; }
.fa-role-cell-event { color: var(--text-muted); min-width: 0; overflow: hidden; text-overflow: ellipsis; font-size: 12px; }
.fa-role-cell-shifts,
.fa-role-cell-apps,
.fa-role-cell-onshift,
.fa-role-cell-confirmed {
  text-align: center;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.fa-role-cell-shifts { color: var(--text, #212529); }
.fa-role-cell-apps { color: #0d6efd; }
.fa-role-cell-onshift { color: var(--primary); }
.fa-role-cell-confirmed { color: #198754; }
/* Detail page flair: □ ● ▷ ✔ (distinct from sidebar ◇ ◆ ◐ ✓) */
.role-shift-flair-detail .role-shift-flair-shifts { color: var(--text, #212529); }
.role-shift-flair-detail .role-shift-flair-apps { color: #0d6efd; }
.role-shift-flair-detail .role-shift-flair-onshift { color: var(--primary); }
.role-shift-flair-detail .role-shift-flair-confirmed { color: #198754; }
.fa-role-cell-detail { font-weight: 600; }
.fa-mini-card-stat-detail { font-weight: 600; }
.fa-role-row-wrap summary::-webkit-details-marker { display: none; }
.fa-role-row-wrap summary::before { display: none; }
.fa-role-row-wrap .accordion-body { padding: 12px 14px 14px 28px; border-top: 1px solid var(--border-color, #eee); background: #fafbfc; }

.fa-detail-tabs-wrap { margin-top: 12px; }
#fa-event-tabs.event-detail-tabs { margin-bottom: 12px; }
.fa-all-event-section { margin-bottom: 24px; }
.fa-all-event-section:last-child { margin-bottom: 0; }
.fa-all-event-heading { font-size: 1rem; margin: 0 0 8px 0; padding-bottom: 4px; border-bottom: 1px solid var(--border-color, #dee2e6); color: var(--text-muted, #6c757d); }
#fa-event-tab-panels { min-height: 120px; }

/* Event detail: roles search */
.event-roles-search-wrap { margin: 12px 0; }
.event-roles-search {
  width: 100%;
  max-width: 320px;
  padding: 8px 12px;
  font-size: 14px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
}
.event-roles-search::placeholder { color: var(--text-muted); }
.event-roles-search:focus { outline: 2px solid var(--primary); outline-offset: 2px; }

/* Event detail: accordion (roles) */
.event-accordion { margin-top: 12px; }
.event-accordion details {
  border: 1px solid var(--border);
  border-radius: 6px;
  margin-bottom: 8px;
  background: var(--surface);
}
.event-accordion details[open] { border-color: var(--primary); }
.event-accordion summary {
  padding: 12px 14px;
  font-weight: 600;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.event-accordion summary::-webkit-details-marker { display: none; }
.event-accordion summary::after {
  content: '▼';
  font-size: 10px;
  color: var(--text-muted);
  transition: transform 0.2s;
}
.event-accordion details[open] summary::after { transform: rotate(-180deg); }
.event-accordion .accordion-body {
  padding: 0 14px 14px 14px;
  border-top: 1px solid var(--border);
}
.event-accordion .accordion-meta {
  font-size: 12px;
  color: var(--text-muted);
  margin: 10px 0 8px 0;
}
.event-accordion .shifts-sub-table { margin: 8px 0 12px 0; }
.event-accordion .applicants-list { margin: 8px 0 0 0; font-size: 13px; }

/* Event detail: roles grouped by functional area */
.event-fa-group { margin-bottom: 20px; }
.event-fa-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  margin-bottom: 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-left: 4px solid var(--border);
  border-radius: 0 6px 6px 0;
  font-weight: 600;
  font-size: 14px;
}
.event-fa-group-title { flex: 1; min-width: 0; }
.event-fa-group-header--ok {
  border-left-color: #198754;
  background: rgba(25, 135, 84, 0.06);
}
.event-fa-group-header--partial {
  border-left-color: #d4a012;
  background: rgba(212, 160, 18, 0.06);
}
.event-fa-group-header--empty {
  border-left-color: #dc3545;
  background: rgba(220, 53, 69, 0.06);
}

/* Event detail: Roles & shifts — tabs by functional area */
.event-fa-tabs-wrap { margin-top: 12px; }
.event-fa-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 8px;
  margin: 0 0 12px 0;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.event-fa-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  flex-shrink: 0;
}
.event-fa-tab:hover {
  color: var(--text);
  background: var(--bg);
  border-color: var(--primary);
}
.event-fa-tab.active {
  color: var(--primary);
  background: rgba(var(--primary-rgb, 59, 130, 246), 0.1);
  border-color: var(--primary);
}
.event-fa-tab .role-shift-flair { font-size: 11px; padding: 2px 6px; }
.event-fa-tab-panels { min-height: 80px; }
.event-fa-tab-panel {
  display: none;
  padding-top: 4px;
}
.event-fa-tab-panel.active { display: block; }

/* Roles & shifts legend strip (green / amber / grey) */
.role-flair-legend-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 20px;
  margin: 8px 0 10px 0;
  padding: 8px 12px;
  background: var(--bg);
  border-radius: 8px;
  border: 1px solid var(--border);
  font-size: 12px;
}
.role-flair-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
  color: var(--text-muted);
}
.role-flair-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.role-flair-legend-ok .role-flair-legend-dot { background: #198754; }
.role-flair-legend-partial .role-flair-legend-dot { background: #d4a012; }
.role-flair-legend-empty .role-flair-legend-dot { background: #6c757d; }

/* Per-role flair: shifts to cover + applicants interested (icons + colours) */
.event-accordion summary .role-summary-label { flex: 1; min-width: 0; margin-right: 10px; }
.role-shift-flair {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 6px;
  white-space: nowrap;
  flex-shrink: 0;
}
.role-shift-flair-shifts { opacity: 0.9; }
.role-shift-flair-apps { opacity: 0.95; }
.role-shift-flair--ok {
  background: rgba(34, 139, 34, 0.15);
  color: #1a6b1a;
  border: 1px solid rgba(34, 139, 34, 0.35);
}
.role-shift-flair--ok .role-shift-flair-shifts { color: #1a6b1a; }
.role-shift-flair--ok .role-shift-flair-apps { color: #0d5c0d; }
.role-shift-flair--partial {
  background: rgba(210, 140, 0, 0.12);
  color: #8b6914;
  border: 1px solid rgba(210, 140, 0, 0.35);
}
.role-shift-flair--partial .role-shift-flair-shifts { color: #8b6914; }
.role-shift-flair--partial .role-shift-flair-apps { color: #6b5010; }
.role-shift-flair--empty {
  background: rgba(160, 80, 80, 0.1);
  color: var(--text-muted);
  border: 1px solid rgba(160, 80, 80, 0.2);
}
.role-shift-flair--empty .role-shift-flair-shifts,
.role-shift-flair--empty .role-shift-flair-apps { color: var(--text-muted); }
.role-shift-flair-confirmed { opacity: 0.95; }
.role-shift-flair--ok .role-shift-flair-confirmed { color: #0d5c0d; }
.role-shift-flair--partial .role-shift-flair-confirmed { color: #6b5010; }
.role-shift-flair--empty .role-shift-flair-confirmed { color: var(--text-muted); }

.shift-row-confirmed { background: rgba(25, 135, 84, 0.08); }
.shifts-sub-table tr.shift-row-confirmed:hover { background: rgba(25, 135, 84, 0.12); }

.event-accordion .role-flair-legend {
  font-size: 12px;
  color: var(--text-muted);
  white-space: nowrap;
}
