/* WorkBot Payroll UI System (Phase 6-7 Enhanced)
   - Pure CSS variable system (no hardcoded colors)
   - Bootstrap 5 CSS baseline with WorkBot customizations
   - Provides reusable layout + component primitives for payroll surfaces
   
   ARCHITECTURE:
   - Section 0: Global theme variables (aliases to theme.css)
   - Section 1: Micro-animations and transitions
   - Section 1b: Navigation and branding
   - Section 1c: Form headers and components (Phase 7)
   - Section 2: Typography scale
   - Section 3: Cards and surfaces
   - Section 4: Badges and status indicators
   - Section 5: Tables and key-value layouts
   - Section 6: Alerts and banners
   - Section 7: Sticky elements and shadows
   - Section 8: Micro-interactions (Phase 7)
   - Section 9: Form controls and buttons
   - Section 10: Responsive design (Phase 7)
   - Section 27: Dark mode helpers
   
   DESIGN SYSTEM:
   - Color variables: --primary, --text, --bg, --border (from theme.css)
   - Spacing scale: --space-xs (4px), --space-sm (8px), --space-md (16px), --space-lg (24px), --space-xl (32px)
   - Transitions: 0.2s ease (standard), 0.15s ease (quick), 0.6s ease (slow)
   - Shadows: --shadow-elevated, --shadow-sticky
   - No hardcoded hex colors (test_intelligence_polish_invariants enforces this)
*/

/* =========================
   0) Global Theme Variables
   =========================
   Palette + typography + spacing live in app/static/css/theme.css.
   Keep only non-palette UI effects here.
*/

html {
  /* Back-compat: Phase 27 tests expect these variables in wb.css. */
  --bg: var(--bs-body-bg);
  --fg: var(--bs-body-color);
  --card-bg: var(--bg-alt);
  --border: var(--bs-border-color);
  --accent: var(--primary);

  --shadow-elevated: 0 2px 4px rgba(var(--bs-body-color-rgb), 0.06);
  --shadow-sticky: 0 2px 4px rgba(var(--bs-body-color-rgb), 0.08);
  --outline-soft: 2px solid rgba(var(--bs-body-color-rgb), 0.06);
  --accent-ring: 0 0 0 1px rgba(var(--bs-primary-rgb), 0.2);
  --accent-pulse-0: 0 0 0 0 rgba(var(--bs-primary-rgb), 0);
  --accent-pulse-25: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.18);
  --accent-pulse-100: 0 0 0 0 rgba(var(--bs-primary-rgb), 0);
}

html.dark {
  /* Back-compat aliases (dark values come from theme.css + Bootstrap mapping). */
  --bg: var(--bs-body-bg);
  --fg: var(--bs-body-color);
  --card-bg: var(--bg-alt);
  --border: var(--bs-border-color);
  --accent: var(--primary);

  --shadow-elevated: 0 2px 4px rgba(var(--bs-body-color-rgb), 0.16);
  --shadow-sticky: 0 2px 4px rgba(var(--bs-body-color-rgb), 0.2);
  --outline-soft: 2px solid rgba(var(--bs-body-color-rgb), 0.14);
  --accent-ring: 0 0 0 1px rgba(var(--bs-primary-rgb), 0.28);
  --accent-pulse-0: 0 0 0 0 rgba(var(--bs-primary-rgb), 0);
  --accent-pulse-25: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.24);
  --accent-pulse-100: 0 0 0 0 rgba(var(--bs-primary-rgb), 0);
}

/* =========================
   Phase 27) Micro-animations
   ========================= */

.page-fade-in {
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.15s ease-out, transform 0.15s ease-out;
}
html.loaded .page-fade-in {
  opacity: 1;
  transform: translateY(0);
}

/* =========================
   Phase 28) Payrun Intelligence
   ========================= */

.payrun-intelligence-card {
  background: var(--bg-alt);
  padding: 1.5rem;
  border-radius: 8px;
  border: 1px solid var(--border);
  margin-bottom: 2rem;
}

.intelligence-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
  margin-top: 1rem;
  margin-bottom: 1.5rem;
}

.intelligence-summary-tile {
  background: var(--bg);
  padding: 1rem;
  border-radius: 6px;
  border: 1px solid var(--border);
}

.intelligence-tile-label {
  font-size: 0.85rem;
  opacity: 0.8;
}

.intelligence-tile-value {
  font-size: 1.25rem;
  font-weight: 600;
  margin-top: 0.25rem;
}

.intelligence-section {
  margin-top: 1.5rem;
}

.intelligence-section-title {
  margin-bottom: 0.75rem;
  font-weight: 600;
  font-size: 1.1rem;
}

/* Unified "intelligence" card shell (Phases 27-30 polish). */
.wb-intel-card {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  padding: 1.5rem;
}

/* Opt-in hover lift for interactive tiles only. */
.hover-lift {
  transition: box-shadow 0.12s ease-out, transform 0.12s ease-out;
}

.hover-lift:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-elevated);
}

.rule-heatmap-table tbody tr:hover {
  background: var(--bg);
}

/* Cards: subtle lift + shadow on hover */
.card {
  transition: box-shadow 0.12s ease-out, transform 0.12s ease-out;
}

.card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-elevated);
}

/* =========================
   1) Layout & Grid
   ========================= */

.wb-page {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-md) var(--space-md) var(--space-xl);
}

/* Tight variant for sticky subheaders/toolbars that should not add bottom padding. */
.wb-page--tight {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-md);
}

/* =========================
   1b) Navigation Shell (Phase 7)
   ========================= */

.wb-nav {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  font-family: var(--font-monospace);
  font-size: 0.85rem;
}

.wb-nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-sm) var(--space-md);
}

/* Print column sizing helpers (avoid inline styles). */
.wb-col-when {
  width: 170px;
}

.wb-col-delta {
  width: 110px;
}

.wb-nav-brand {
  font-weight: 700;
  color: var(--primary);
  text-decoration: none;
  letter-spacing: 0.5px;
  font-size: 1.1rem;
}

.wb-nav-brand:hover {
  color: var(--primary-hover);
  text-decoration: none;
}

.wb-nav-link {
  font-weight: 500;
  padding: var(--space-sm) var(--space-md);
  border-radius: 6px;
  text-decoration: none;
}

.wb-nav-link:hover {
  color: var(--bs-primary);
  text-decoration: none;
}

.wb-link-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.wb-link-list > li + li {
  margin-top: 0.25rem;
}

.wb-link-list .wb-nav-link {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem 0;
  color: var(--bs-body-color);
}

.wb-link-list .wb-nav-link:hover {
  color: var(--bs-primary);
}

.wb-nav-link-active {
  color: var(--primary) !important;
  font-weight: 600;
  background-color: rgba(var(--bs-primary-rgb), 0.1);
  border-left: 3px solid var(--primary);
  padding-left: calc(var(--space-md) - 3px);
  transition: all 0.2s ease;
}

.wb-nav-link-active:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.15);
}

/* Dark mode navigation readability (spec 2) */
/* Fix navbar stacking so links don't render behind background */
.navbar {
  position: relative;
  z-index: 1000;
}

.navbar a,
.navbar .nav-link,
.navbar .navbar-brand {
  position: relative;
  z-index: 1001;
}

html.dark .navbar {
  background: var(--bg) !important;
  color: var(--text) !important;
}

html.dark .navbar a,
html.dark .navbar .nav-link,
html.dark .navbar .navbar-brand {
  color: var(--text) !important;
}

html.dark .navbar a:hover,
html.dark .navbar .nav-link:hover {
  color: var(--text) !important;
}

/* ========================= 
   Sidebar Navigation Polish (Phase 7)
   ========================= */

/* Offcanvas sidebar enhancement */
.offcanvas {
  border-left: 1px solid var(--border);
}

.offcanvas-header {
  border-bottom: 2px solid var(--primary);
  padding: var(--space-md);
}

.offcanvas-title {
  font-weight: 700;
  color: var(--primary);
  letter-spacing: 0.5px;
}

/* Sidebar section headers */
.offcanvas-body .text-uppercase.small.text-muted {
  display: flex;
  align-items: center;
  margin-top: 24px;
  margin-bottom: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--primary);
}

.offcanvas-body .text-uppercase.small.text-muted:first-of-type {
  margin-top: 0;
  border-top: none;
  padding-top: 0;
}

/* Sidebar list group items (navigation links) */
.offcanvas-body .list-group-item {
  background-color: transparent;
  border-left: 3px solid transparent;
  border-bottom: none;
  border-right: none;
  border-top: none;
  padding: 10px 12px;
  transition: all 0.2s ease;
}

.offcanvas-body .list-group-item:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.08);
  border-left-color: var(--primary);
}

.offcanvas-body .list-group-item.active {
  background-color: rgba(var(--bs-primary-rgb), 0.12);
  border-left-color: var(--primary);
  color: var(--primary);
  font-weight: 600;
}

.wb-nav-dropdown {
  position: relative;
}

.wb-nav-dropdown-menu {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  padding: 0.5rem 0;
  min-width: 180px;
  box-shadow: var(--bs-box-shadow);
}

/* Nested navbar dropdowns (e.g. Setup → Till & Payment Methods)
   Bootstrap doesn't position these by default, so they can overlap the parent menu. */
.wb-nav .dropdown-menu {
  /* Above sticky subheaders, below modals/backdrops. */
  z-index: 1040;
}

.wb-nav .dropdown-submenu {
  position: relative;
}

.wb-nav .dropdown-submenu > .dropdown-menu {
  top: 0;
  left: 100%;
  margin-top: -0.25rem;
  margin-left: 0.25rem;
}

.wb-nav .dropdown-submenu > .dropdown-item.dropdown-toggle::after {
  float: right;
  margin-top: 0.35rem;
  transform: rotate(-90deg);
}

@media (max-width: 767.98px) {
  /* On mobile, keep submenus inside the flow so they don't go offscreen. */
  .wb-nav .dropdown-submenu > .dropdown-menu {
    position: static;
    margin: 0.25rem 0 0 0;
  }

  .wb-nav .dropdown-submenu > .dropdown-item.dropdown-toggle::after {
    transform: rotate(0deg);
  }
}

/* ========================= 
   Form Headers (Phase 7)
   ========================= */

.wb-form-header {
  position: relative;
  margin-bottom: 32px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}

.wb-form-header-accent {
  position: absolute;
  top: 0;
  left: 0;
  height: 3px;
  width: 48px;
  background: var(--primary);
  border-radius: 2px;
}

.wb-form-header h1 {
  margin-top: 0;
  color: var(--text);
}

/* ========================= 
   Form Components (Phase 7)
   ========================= */

.wb-form-group {
  margin-bottom: var(--space-md);
  display: flex;
  flex-direction: column;
}

.wb-form-group:last-child {
  margin-bottom: 0;
}

.form-label {
  font-weight: 600;
  font-size: var(--font-size-base);
  color: var(--text);
  margin-bottom: var(--space-sm);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.form-control-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.wb-form-actions {
  display: flex;
  gap: var(--space-lg);
  justify-content: flex-end;
  margin-top: var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid var(--border);
}

.wb-form-actions .btn {
  flex-shrink: 0;
}

.invalid-feedback {
  font-size: var(--font-size-small);
  color: var(--bs-danger);
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

.form-text {
  font-size: var(--font-size-small);
  color: var(--text-muted);
  margin-top: var(--space-sm);
  display: block;
}

/* ========================= 
   Form Control Enhancement (Phase 7)
   ========================= */

.form-control,
.form-select,
.form-check-input {
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.form-control:focus,
.form-select:focus,
.form-check-input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.1);
}

/* =========================
   1c) Notification Center (Phase 28)
   ========================= */

.wb-notif-bell-icon {
  vertical-align: -0.125em;
}

.wb-notif-dropdown-list {
  min-width: 280px;
  max-width: 360px;
}

.wb-notif-dropdown-item {
  white-space: normal;
}

.wb-notif-title {
  font-weight: 600;
  color: var(--bs-body-color);
  line-height: 1.2;
}

.wb-notif-meta {
  font-size: 0.75rem;
  color: var(--bs-secondary-color);
}

.wb-notif-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  margin-top: 0.35rem;
  flex: 0 0 auto;
  background: rgb(var(--bs-secondary-rgb));
}

.wb-notif-dot-warning {
  background: rgb(var(--bs-warning-rgb));
}

.wb-notif-dot-payrun_complete {
  background: rgb(var(--bs-success-rgb));
}

.wb-notif-dot-approval_request {
  background: rgb(var(--bs-primary-rgb));
}

.wb-notif-dot-system_alert {
  background: rgb(var(--bs-danger-rgb));
}

.wb-notif-unread {
  background: rgba(var(--bs-primary-rgb), 0.06);
}

.wb-notif-message {
  padding: 0.75rem 1rem;
  border: 1px solid var(--bs-border-color);
  border-top: 0;
  background: var(--bs-body-bg);
}

.wb-notif-day {
  margin-bottom: 1.5rem;
}

.wb-notif-day-title {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--bs-secondary-color);
  margin: 0 0 0.5rem;
}

/* Mobile accordion menus should look like part of the collapsed panel. */
@media (max-width: 767.98px) {
  .wb-nav-inner {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }
  
  /* Responsive form layouts */
  .wb-form-actions {
    flex-direction: column-reverse;
    gap: var(--space-md);
  }
  
  .wb-form-actions .btn {
    width: 100%;
  }
  
  /* Stack card rows on mobile */
  .wb-card-row {
    grid-template-columns: 1fr;
  }
  
  /* Reduce padding on mobile */
  .wb-card {
    padding: var(--space-md);
  }
  
  .wb-table th,
  .wb-table td {
    padding: var(--space-sm) var(--space-sm);
    font-size: 0.9rem;
  }
  
  /* Reduce form spacing on mobile */
  .wb-form-group {
    margin-bottom: var(--space-md);
  }
  
  /* Hide less important columns on mobile tables */
  .wb-table-hide-mobile {
    display: none;
  }
}

/* Tablet optimizations */
@media (min-width: 768px) and (max-width: 991.98px) {
  .wb-card-row {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .wb-form-actions {
    gap: var(--space-md);
  }
}

/* Desktop optimizations */
@media (min-width: 992px) {
  .wb-card-row {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  }
}

.wb-section {
  margin-top: var(--space-lg);
  margin-bottom: 0;
}

/* First section on a page: no top margin */
.wb-page > .wb-section:first-child,
.container > .wb-section:first-child {
  margin-top: 0;
}

/* Consistent header/section spacing (spec 4) */
.wb-page h1,
.wb-page .wb-title-xl {
  margin-bottom: var(--space-md);
  margin-top: 0;
}

.wb-page h2,
.wb-page .wb-title-lg {
  margin-top: var(--space-lg);
  margin-bottom: var(--space-sm);
}

/* Vertical rhythm: card stacking */
.wb-card-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.wb-card-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-md);
}

/* Consistent list spacing */
.wb-list,
.wb-list-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

/* Form group spacing */
.wb-form-group,
.form-group {
  margin-bottom: var(--space-md);
}

.wb-form-group:last-child,
.form-group:last-child {
  margin-bottom: 0;
}

/* Section containers within forms */
.wb-form-section {
  padding: var(--space-lg) 0;
  border-bottom: 1px solid var(--border);
}

.wb-form-section:last-child {
  border-bottom: none;
}

/* Back-compat utility used by earlier phases */
.wb-max-1200 {
  max-width: 1200px;
}

/* =========================
   2) Typography Scale
   ========================= */

.wb-title-xl {
  font-size: var(--font-size-large);
  font-weight: 600;
  line-height: 1.2;
  margin: 0;
}

.wb-title-lg {
  font-size: var(--font-size-base);
  font-weight: 600;
  line-height: 1.25;
  margin: 0;
}

.wb-title-md {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.25;
  margin: 0;
}

.wb-text-body {
  color: var(--bs-body-color);
  font-size: var(--font-size-base);
}

.wb-text-muted {
  color: var(--bs-secondary-color);
}

.wb-label {
  font-size: var(--font-size-small);
  font-weight: 600;
  color: var(--bs-secondary-color);
  text-transform: none;
}

/* Admin dashboard: improve dark-mode tile readability */
html.dark .wb-admin-dashboard .wb-card .wb-label,
html.dark .wb-admin-dashboard .wb-card .wb-text-muted {
  color: var(--text-muted) !important;
}

/* =========================
   3) Cards & Surfaces
   ========================= */

.wb-card {
  background: var(--bg-alt);
  border-radius: 0.5rem;
  border: 1px solid var(--border);
  padding: var(--space-md);
  box-shadow: none;
}

/* When using Bootstrap `.card` markup, keep padding on card-body/header/footer. */
.card.wb-card {
  padding: 0;
}

.wb-card-elevated {
  box-shadow: var(--shadow-elevated);
}

.wb-card-compact {
  padding: 0.75rem 1rem;
}

/* Make Bootstrap cards align to our spacing token without rewriting markup. */
.card.wb-card > .card-header {
  background: transparent;
  padding: 0.75rem 1.25rem;
  border-bottom: 1px solid var(--bs-border-color);
}

.card.wb-card > .card-body {
  padding: 1rem 1.25rem;
}

.card.wb-card > .card-footer {
  padding: 0.75rem 1.25rem;
  background: transparent;
  border-top: 1px solid var(--bs-border-color);
}

.wb-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.wb-card-footer {
  margin-top: 0.75rem;
}

/* =========================
   4) Badges, Pills & Status
   ========================= */

.wb-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.125rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.2;
  border: 1px solid transparent;
  white-space: nowrap;
}

.wb-badge-primary {
  background: var(--bs-info-bg-subtle);
  color: var(--bs-info-text-emphasis);
  border-color: var(--bs-info-border-subtle);
}

.wb-badge-muted {
  background: var(--bs-secondary-bg-subtle);
  color: var(--bs-secondary-text-emphasis);
  border-color: var(--bs-secondary-border-subtle);
}

.wb-badge-warning {
  background: var(--bs-warning-bg-subtle);
  color: var(--bs-warning-text-emphasis);
  border-color: var(--bs-warning-border-subtle);
}

.wb-badge-success {
  background: var(--bs-success-bg-subtle);
  color: var(--bs-success-text-emphasis);
  border-color: var(--bs-success-border-subtle);
}

.wb-badge-danger {
  background: var(--bs-danger-bg-subtle);
  color: var(--bs-danger-text-emphasis);
  border-color: var(--bs-danger-border-subtle);
}

/* =========================
   Diff viewer highlights
   ========================= */

.wb-diff-badge.increase {
  background: var(--bs-success-bg-subtle);
  color: var(--bs-success-text-emphasis);
  border-color: var(--bs-success-border-subtle);
}

.wb-diff-badge.decrease {
  background: var(--bs-danger-bg-subtle);
  color: var(--bs-danger-text-emphasis);
  border-color: var(--bs-danger-border-subtle);
}

.wb-diff-badge.added {
  background: var(--bs-info-bg-subtle);
  color: var(--bs-info-text-emphasis);
  border-color: var(--bs-info-border-subtle);
}

.wb-diff-badge.removed {
  background: var(--bs-secondary-bg-subtle);
  color: var(--bs-secondary-text-emphasis);
  border-color: var(--bs-secondary-border-subtle);
}

/* Back-compat helper used by drilldown */
.wb-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

/* =========================
   5) Tables & Key/Value
   ========================= */

.wb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-base);
  background: var(--bg);
}

.wb-table-header {
  background: var(--bg-alt);
  border-bottom: 2px solid var(--border);
}

.wb-table th {
  text-align: left;
  padding: var(--space-md) var(--space-md);
  font-weight: 600;
  border-bottom: 1px solid var(--border);
  background: var(--bg-alt);
  color: var(--text);
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  border-right: 1px solid var(--border);
}

.wb-table th:last-child {
  border-right: none;
}

.wb-table td {
  padding: var(--space-md) var(--space-md);
  vertical-align: middle;
  border-bottom: 1px solid var(--bs-border-color-translucent);
}

.wb-table tbody tr {
  min-height: 44px;
  transition: background-color 0.2s ease;
}

.wb-table tbody tr:hover {
  background: rgba(var(--bs-primary-rgb), 0.04);
}

html.dark .wb-table th {
  background: var(--bg-alt);
  color: var(--text);
  border-bottom-color: var(--border);
}

html.dark .wb-table tbody tr:hover {
  background: rgba(var(--bs-primary-rgb), 0.08);
}

.wb-table-striped tbody tr:nth-child(even) {
  background: var(--bg-alt);
}

.wb-table-striped tbody tr:nth-child(even):hover {
  background: rgba(var(--bs-primary-rgb), 0.04);
}

/* Token-first subtle striping (used by premium totals/accruals). */
.wb-table-striped-soft tbody tr {
  background: var(--bg);
}

.wb-table-striped-soft tbody tr:nth-child(even) {
  background: var(--bg-alt);
}

/* PayPacket premium totals: emphasize net */
.wb-paypacket-net-row {
  background: var(--bg-alt);
  font-weight: 600;
  border-top: 2px solid var(--border);
}

.wb-paypacket-net-label {
  font-weight: 700;
  color: var(--text);
}

.wb-paypacket-net-value {
  font-weight: 700;
  font-size: 1.15rem;
  font-variant-numeric: tabular-nums;
  color: var(--primary);
}

/* Premium debug accordion (max-height transitions + chevron rotation) */
.wb-acc {
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  overflow: hidden;
  background: var(--bg);
}

.wb-acc-item + .wb-acc-item {
  border-top: 1px solid var(--border);
}

.wb-acc-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: var(--space-md) var(--space-md);
  background: transparent;
  color: var(--text);
  border: 0;
  text-align: left;
  font-weight: 600;
  transition: background-color 0.2s ease;
  cursor: pointer;
}

.wb-acc-btn:hover {
  background: rgba(var(--bs-primary-rgb), 0.04);
}

.wb-acc-chevron {
  transition: transform 0.2s ease;
  color: var(--primary);
}

.wb-acc-item.is-open .wb-acc-chevron {
  transform: rotate(180deg);
}

.wb-acc-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.2s ease;
  background: var(--bg);
}

.wb-acc-inner {
  padding: var(--space-md) var(--space-md);
  border-top: 1px solid var(--border);
  color: var(--text);
}

.wb-table-numeric {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-family: var(--font-monospace);
}

.wb-kv-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.wb-kv-table th {
  width: 40%;
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  font-weight: 600;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  background: var(--bg-alt);
}

.wb-kv-table td {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--bs-border-color-translucent);
  font-weight: 500;
  color: var(--text);
}

/* =========================
   6) Alerts, Banners
   ========================= */

.wb-banner {
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  border: 1px solid var(--bs-border-color);
}

.wb-banner-icon {
  margin-top: 0.125rem;
  color: var(--bs-secondary-color);
}

.wb-banner-content {
  flex: 1;
}

.wb-banner-title {
  font-weight: 600;
  margin-bottom: 0.25rem;
}

.wb-banner-warning {
  background: var(--bs-warning-bg-subtle);
  border-left: 4px solid var(--bs-warning);
}

.wb-banner-info {
  background: var(--bs-info-bg-subtle);
  border-left: 4px solid var(--bs-info);
}

.wb-banner-danger {
  background: var(--bs-danger-bg-subtle);
  border-left: 4px solid var(--bs-danger);
}

/* =========================
   6b) Small UI utilities
   ========================= */

.wb-divider {
  border: 0;
  border-top: 1px solid var(--border);
  opacity: 1;
}

.wb-pre {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px;
  color: var(--text);
  font-family: var(--font-monospace);
  font-size: 0.85rem;
  line-height: 1.35;
}

.wb-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}

html.dark .wb-icon {
  color: var(--text-muted);
}

.wb-row-total:nth-child(odd) {
  background: var(--bg-alt);
}

html.dark .wb-row-total:nth-child(odd) {
  background: var(--bg-alt);
}

/* Print column sizing helpers (avoid inline styles) */
.wb-col-when {
  width: 170px;
}

.wb-col-delta {
  width: 110px;
}

/* Back-compat: old warning banner name */
.wb-warning-banner {
  border-left: 0.25rem solid var(--bs-warning);
}

/* =========================
   7) Sticky elements & shadows
   ========================= */

.wb-sticky-subheader {
  position: sticky;
  top: 0;
  z-index: 1030;
}

.wb-sticky-subheader.wb-hidden {
  display: none;
}

/* Only enable sticky context bar on desktop */
@media (min-width: 992px) {
  .wb-sticky-subheader {
    display: block;
  }
}

@media (max-width: 991.98px) {
  .wb-sticky-subheader {
    display: none !important;
  }
}

.wb-sticky-shadow {
  box-shadow: var(--shadow-sticky);
}

/* Back-compat: older class name used previously */
.wb-shadowed {
  box-shadow: var(--shadow-sticky);
}

.wb-sticky-table thead th {
  position: sticky;
  top: var(--wb-sticky-top, 0px);
  z-index: 2;
  background: var(--bs-body-bg);
}

.wb-audit-toolbar {
  position: sticky;
  top: var(--wb-sticky-top, 0px);
  z-index: 1020;
  background: var(--bs-body-bg);
}

/* =========================
   8) Micro-interactions (Phase 7)
   ========================= */

/* Row linking and interactivity */
.wb-row-link {
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.15s ease;
}

.wb-row-link:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.04);
  transform: translateX(2px);
}

.wb-row-link:active {
  transform: translateX(0);
}

/* Highlights and focus states */
.wb-related-highlight {
  outline: var(--outline-soft);
  background-color: var(--bs-tertiary-bg);
  transition: background-color 0.2s ease;
}

.wb-highlight-focus {
  animation: highlightPulse 0.6s ease-out;
}

@keyframes highlightPulse {
  0% {
    background-color: rgba(var(--bs-primary-rgb), 0.2);
  }
  100% {
    background-color: transparent;
  }
}

/* Explain buttons */
.wb-explain-btn {
  border: 0;
  background: transparent;
  color: var(--bs-secondary-color);
  padding: var(--space-sm);
  line-height: 1;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.wb-explain-btn:hover {
  color: var(--primary);
  background-color: rgba(var(--bs-primary-rgb), 0.06);
}

.wb-explain-btn:active {
  transform: scale(0.95);
}

/* Accordion interactions */
.wb-accordion-button {
  --bs-accordion-btn-icon: none;
  --bs-accordion-btn-active-icon: none;
  transition: all 0.2s ease;
}

.wb-accordion-button:hover:not(.collapsed) {
  background-color: rgba(var(--bs-primary-rgb), 0.04);
}

.wb-accordion-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 999px;
  color: var(--bs-secondary-color);
  transform: rotate(0deg);
  transition: transform 150ms ease-in-out;
}

.accordion-button[aria-expanded="true"] .wb-accordion-chevron {
  transform: rotate(90deg);
}

.wb-hover-linked:hover {
  background-color: var(--bs-tertiary-bg);
}

.wb-icon {
  font-size: 0.9rem;
  vertical-align: -1px;
}

/* Legacy: section stacks in employee profile */
.wb-section-stack > * + * {
  margin-top: 1.5rem;
}

.wb-search-input {
  min-width: 240px;
}

/* Global navbar search: dark-mode input styling */
html.dark .wb-search-input {
  background-color: var(--bg-alt) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}

html.dark .wb-search-input::placeholder {
  color: var(--text-muted) !important;
}

/* Phase 26: Global search dropdown (read-only) */
.wb-search-dropdown {
  position: absolute;
  top: calc(100% + 0.25rem);
  left: 0;
  right: 0;
  z-index: 1050;
  max-height: 60vh;
  overflow: auto;
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  background: var(--bs-body-bg);
}

.wb-search-group-title {
  padding: 0.5rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--bs-secondary-color);
  border-top: 1px solid var(--bs-border-color);
}

.wb-search-group:first-child .wb-search-group-title {
  border-top: none;
}

.wb-search-item {
  display: block;
  padding: 0.5rem 0.75rem;
  text-decoration: none;
  color: inherit;
}

.wb-search-item:hover {
  background: var(--bs-tertiary-bg);
}

.wb-search-label {
  line-height: 1.2;
}

.wb-search-meta {
  font-size: 0.85em;
  color: var(--bs-secondary-color);
}

/* =========================
   9) Forms & validation
   ========================= */

.wb-form-control {
  border-radius: 6px;
  border: 1px solid var(--border);
  padding: 8px;
  font-size: var(--font-size-base);
  background: var(--bg);
  color: var(--text);
}

.wb-form-control:focus {
  border-color: var(--primary);
  box-shadow: var(--accent-ring);
  outline: none;
}

/* Button system (spec 6) */
.btn {
  border-radius: 6px;
  font-weight: 600;
  padding: 8px 16px;
  font-size: 0.95rem;
  border: 1px solid transparent;
  transition: all 0.2s ease;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  white-space: nowrap;
}

.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.btn-primary {
  background: var(--primary);
  border-color: var(--primary);
  color: white;
  padding: 8px 16px;
  box-shadow: 0 2px 4px rgba(var(--bs-primary-rgb), 0.2);
}

.btn-primary:hover:not(:disabled) {
  background: var(--primary-hover);
  border-color: var(--primary-hover);
  box-shadow: 0 4px 8px rgba(var(--bs-primary-rgb), 0.3);
  transform: translateY(-1px);
}

.btn-primary:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(var(--bs-primary-rgb), 0.2);
}

.btn-primary:focus {
  outline: none;
  box-shadow: var(--accent-ring);
}

.btn-outline-secondary {
  background: transparent;
  border: 1.5px solid var(--border);
  color: var(--text);
  padding: 7px 15px;
}

.btn-outline-secondary:hover:not(:disabled) {
  border-color: var(--primary);
  color: var(--primary);
  background: rgba(var(--bs-primary-rgb), 0.02);
}

.btn-outline-secondary:active:not(:disabled) {
  background: rgba(var(--bs-primary-rgb), 0.04);
}

.btn-danger {
  background: var(--bs-danger);
  border-color: var(--bs-danger);
  color: white;
  box-shadow: 0 2px 4px rgba(var(--bs-danger-rgb), 0.2);
}

.btn-danger:hover:not(:disabled) {
  background: var(--bs-danger);
  border-color: var(--bs-danger);
  box-shadow: 0 4px 8px rgba(var(--bs-danger-rgb), 0.3);
  filter: brightness(0.92);
}

.btn-danger:active:not(:disabled) {
  box-shadow: 0 2px 4px rgba(var(--bs-danger-rgb), 0.2);
}

/* Link buttons */
.btn-link {
  color: var(--primary);
  text-decoration: none;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  font-weight: 600;
}

.btn-link:hover:not(:disabled) {
  color: var(--primary-hover);
  text-decoration: underline;
}

.wb-nav-link {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
  transition: color 0.2s ease;
}

.wb-nav-link:hover {
  color: var(--primary-hover);
}

.wb-field-error {
  border-color: var(--bs-danger);
}

.wb-field-warning {
  border-color: var(--bs-warning);
}

.wb-field-success {
  border-color: var(--bs-success);
}

.wb-field-message {
  font-size: 0.75rem;
  margin-top: 0.25rem;
}

.wb-field-message-error {
  color: var(--bs-danger-text-emphasis);
}

.wb-field-focus {
  animation: wbFieldFocusFlash 1200ms ease-in-out;
}

@keyframes wbFieldFocusFlash {
  0% { box-shadow: var(--accent-pulse-0); }
  25% { box-shadow: var(--accent-pulse-25); }
  100% { box-shadow: var(--accent-pulse-100); }
}

/* =========================
   Existing payroll UI helpers
   ========================= */

.wb-timeline {
  position: relative;
  padding-left: 1rem;
}

.wb-timeline::before {
  content: "";
  position: absolute;
  top: 0.25rem;
  bottom: 0.25rem;
  left: 0.35rem;
  width: 2px;
  background: var(--bs-border-color);
}

.wb-timeline-item {
  position: relative;
  margin-bottom: 0.5rem;
}

.wb-timeline-item:last-child {
  margin-bottom: 0;
}

.wb-timeline-item::before {
  content: "";
  position: absolute;
  left: -0.85rem;
  top: 0.2rem;
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 999px;
  background: var(--bs-body-bg);
  border: 2px solid var(--bs-secondary-color);
}

.wb-timeline-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.wb-timeline-list {
  list-style: none;
  padding-left: 0;
}

.wb-timeline-day {
  margin: 0.5rem 0 0.25rem;
  padding-left: 0.25rem;
  font-weight: 600;
  color: var(--bs-secondary-color);
  font-size: 0.85rem;
}

.wb-timeline-item {
  display: flex;
  gap: 0.75rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--bs-border-color);
  border-radius: 0.5rem;
  background: var(--bs-body-bg);
}

.wb-timeline-item:hover {
  background: var(--bs-tertiary-bg);
}

.wb-timeline-left {
  min-width: 170px;
}

.wb-timeline-time {
  font-size: 0.85rem;
  color: var(--bs-body-color);
}

.wb-timeline-delta {
  font-size: 0.75rem;
  color: var(--bs-secondary-color);
}

.wb-timeline-body {
  flex: 1;
  min-width: 0;
}

.wb-employee-card {
  border: 1px solid var(--bs-border-color);
  border-radius: 0.5rem;
  padding: 0.75rem;
}

.wb-employee-card:hover {
  background: var(--bs-tertiary-bg);
}

.wb-mini-label {
  font-size: 0.75rem;
  color: var(--bs-secondary-color);
}

.wb-audit-accordion .accordion-item + .accordion-item {
  border-top: 1px solid var(--bs-border-color);
}

.wb-audit-accordion .accordion-button:hover {
  background-color: var(--bs-tertiary-bg);
}

.wb-audit-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.wb-audit-list-item {
  display: block;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--bs-border-color);
  border-radius: 0.5rem;
  text-decoration: none;
  color: var(--bs-body-color);
  background: var(--bs-body-bg);
}

.wb-audit-list-item:hover {
  background: var(--bs-tertiary-bg);
}

.wb-audit-list-item.active {
  border-color: var(--bs-primary);
  box-shadow: var(--accent-ring);
}

/* Employee profile specifics retained but now centralized */
.wb-config-card .card-header {
  background: var(--bs-body-bg);
}

.wb-config-card .card-header:hover {
  background: var(--bs-tertiary-bg);
}

.wb-validation-card {
  border-left: 0.25rem solid var(--bs-border-color);
}

.wb-sticky-footer {
  position: sticky;
  bottom: 0.75rem;
  z-index: 1020;
}

.wb-mobile-savebar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1030;
}

.wb-avatar-circle {
  width: 48px;
  height: 48px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: var(--bs-body-color);
  background: var(--bs-secondary-bg);
  border: 1px solid var(--bs-border-color);
}

/* =========================
   27) Dark Mode Helpers
   ========================= */

html.dark .bg-light {
  background-color: var(--card-bg) !important;
}

html.dark .text-muted {
  color: var(--muted) !important;
}

html.dark .border-top,
html.dark .border-bottom,
html.dark .border {
  border-color: var(--border) !important;
}

/* =========================
   Jobs: Builder (responsive)
   ========================= */

/* Opt-in wider pages for dense screens (e.g. job builder). */
.wb-page.wb-page--wide {
  max-width: 1600px;
}

@media (min-width: 1600px) {
  .wb-page.wb-page--wide {
    max-width: 1760px;
  }
}

.wb-builder-shell {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
  position: relative;
}

.wb-builder-livebox {
  min-height: 520px;
  max-height: 70vh;
  overflow: auto;
  background: var(--bs-body-bg);
}

.wb-builder-toolbar {
  width: 220px;
}

.wb-builder-toolbar-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.35rem;
}

.wb-builder-panel {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: 420px;
  max-width: 100%;
  background: var(--bs-body-bg);
  border-left: 1px solid rgba(0, 0, 0, 0.12);
  box-shadow: -8px 0 18px rgba(0, 0, 0, 0.08);
  overflow: auto;
  z-index: 1050;
}

@media (max-width: 767.98px) {
  .wb-builder-shell {
    flex-direction: column;
  }

  .wb-builder-livebox {
    min-height: 320px;
    max-height: 65vh;
  }

  .wb-builder-toolbar {
    width: 100%;
  }

  .wb-builder-toolbar-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .wb-builder-toolbar-grid .btn {
    font-size: 0.85rem;
    padding: 0.35rem 0.4rem;
  }

  /* Slide-out becomes a full-screen drawer on phones. */
  .wb-builder-panel {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    border-left: 0;
    box-shadow: none;
  }
}

.wb-builder-footer {
  background: var(--bs-body-bg);
  border-color: var(--bs-border-color) !important;
  padding: 0.6rem 0.75rem;
}
