/* === Blue Ocean - Area Reservada Client Portal - Complete CSS Design System === */

/* === CSS CUSTOM PROPERTIES & DESIGN VARIABLES === */

:root {
  /* Colors */
  --color-dark-navy: #182453;
  --color-mid-blue: #375177;
  --color-gold: #a38050;
  --color-gold-light: #e2c5a1;
  --color-cream: #f9f3ed;
  --color-dark: #293344;
  --color-white: #ffffff;
  --color-gray-50: #f8fafc;
  --color-gray-100: #f1f5f9;
  --color-gray-200: #e2e8f0;
  --color-gray-300: #cbd5e1;
  --color-gray-400: #94a3b8;
  --color-gray-500: #64748b;
  --color-gray-600: #475569;
  --color-success: #22c55e;
  --color-warning: #f59e0b;
  --color-danger: #ef4444;

  /* Spacing */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 12px;
  --space-lg: 16px;
  --space-xl: 24px;
  --space-2xl: 32px;
  --space-3xl: 48px;

  /* Typography */
  --font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-size-2xl: 1.5rem;
  --font-size-3xl: 1.875rem;

  /* Borders */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);

  /* Transitions */
  --transition-base: 0.2s ease;
  --transition-slow: 0.3s ease;
}

/* === GLOBAL RESET & BASE STYLES === */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  line-height: 1.6;
  color: var(--color-dark);
  background-color: var(--color-gray-50);
}

body.boar-app-page {
  min-height: 100vh;
  overflow-x: hidden;
  background-color: var(--color-gray-50);
}

a {
  color: var(--color-mid-blue);
  text-decoration: none;
  transition: color var(--transition-base);
}

a:hover {
  color: var(--color-dark-navy);
}

button,
input,
select,
textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

button {
  cursor: pointer;
  border: none;
  background: none;
}

/* === LAYOUT SYSTEM === */

body.boar-app-page .boar-app-container,
body.boar-app-page .boar-app {
  display: flex;
  min-height: 100vh;
  width: 100%;
  position: relative;
}

.boar-sidebar {
  display: flex;
  flex-direction: column;
  width: 256px;
  min-width: 256px;
  flex-shrink: 0;
  min-height: 100vh;
  height: auto;
  background-color: var(--color-dark-navy);
  color: var(--color-white);
  overflow: visible;
  position: sticky;
  left: 0;
  top: 0;
  z-index: 30;
  align-self: flex-start;
  box-shadow: var(--shadow-lg);
}

.boar-main-wrap {
  display: flex;
  flex-direction: column;
  flex: 1;
  margin-left: 0;
  min-width: 0;
}

.boar-header {
  position: sticky;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-xl);
  background-color: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--color-gray-200);
  z-index: 20;
  height: 64px;
}

body.boar-app-page .boar-content {
  flex: 1;
  padding: 24px;
  background-color: var(--color-gray-50);
  margin-left: 0;
  min-width: 0;
  width: auto;
  max-width: none;
}

/* Hamburger toggle for mobile */
.boar-hamburger {
  display: none;
  position: fixed;
  top: var(--space-lg);
  left: var(--space-lg);
  z-index: 40;
  background: var(--color-dark-navy);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-md);
  width: 40px;
  height: 40px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-md);
}
.boar-hamburger svg { width: 20px; height: 20px; }
.boar-hamburger:hover { background: var(--color-mid-blue); }

/* Content uses native browser scrollbar — no custom scrollbar needed */

/* === SIDEBAR COMPONENTS === */

.boar-sidebar-logo {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-xl);
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--color-white);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.boar-sidebar-logo-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.boar-sidebar-logo-main {
  font-size: var(--font-size-lg);
  font-weight: 700;
}

.boar-sidebar-logo-sub {
  font-size: var(--font-size-xs);
  opacity: 0.85;
  font-weight: 400;
}

.boar-sidebar-role-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background-color: rgba(163, 128, 80, 0.15);
  color: var(--color-gold-light);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 600;
  margin: 0 var(--space-xl) var(--space-lg);
  text-transform: uppercase;
}

.boar-sidebar-language-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-sm);
  background-color: rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  margin: 0 var(--space-lg) var(--space-lg);
  font-size: var(--font-size-xs);
  font-weight: 600;
}

.boar-sidebar-language-toggle button {
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  color: rgba(255, 255, 255, 0.8);
  transition: all var(--transition-base);
}

.boar-sidebar-language-toggle button.active {
  background-color: var(--color-gold);
  color: var(--color-white);
}

.boar-sidebar-language-toggle button:hover {
  color: rgba(255, 255, 255, 0.8);
}

.boar-sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: var(--space-lg) var(--space-lg);
  flex: 1;
}

.boar-sidebar-nav-link,
.boar-sidebar-nav a,
.boar-nav-item,
.boar-sidebar .boar-nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  color: #ffffff;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: 500;
  transition: all var(--transition-base);
  position: relative;
  text-decoration: none;
  opacity: 0.9;
}

.boar-sidebar-nav-link:hover,
.boar-sidebar-nav a:hover,
.boar-nav-item:hover,
.boar-sidebar .boar-nav-item:hover {
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.12);
  opacity: 1;
}

.boar-sidebar-nav-link.active,
.boar-sidebar-nav a.active,
.boar-nav-item.active,
.boar-sidebar .boar-nav-item.active {
  background-color: rgba(163, 128, 80, 0.3);
  color: #ffffff;
  font-weight: 600;
  border-left: 3px solid var(--color-gold);
  opacity: 1;
}

.boar-sidebar-nav-link svg,
.boar-nav-item svg,
.boar-sidebar .boar-nav-item svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  color: #ffffff;
  stroke: #ffffff;
}

.boar-sidebar-nav-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  background-color: var(--color-gold);
  color: var(--color-white);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 700;
  margin-left: auto;
}

.boar-sidebar-user-info {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  margin-top: auto;
}

.boar-sidebar-user-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-gold);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: 700;
  flex-shrink: 0;
}

.boar-sidebar-user-details {
  flex: 1;
  min-w-0;
}

.boar-sidebar-user-name {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-white);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.boar-sidebar-user-role {
  font-size: var(--font-size-xs);
  color: rgba(255, 255, 255, 0.8);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.boar-sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 25;
}

.boar-sidebar-overlay.active {
  display: block;
}

/* === HEADER COMPONENTS === */

.boar-header-title {
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--color-dark-navy);
}

.boar-header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
}

.boar-hamburger {
  display: none;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  color: var(--color-dark-navy);
  transition: background-color var(--transition-base);
}

.boar-hamburger:hover {
  background-color: var(--color-gray-100);
}

.boar-hamburger svg {
  width: 24px;
  height: 24px;
}

.boar-notification-bell {
  position: relative;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  color: var(--color-dark-navy);
  transition: background-color var(--transition-base);
}

.boar-notification-bell:hover {
  background-color: var(--color-gray-100);
}

.boar-notification-bell svg {
  width: 20px;
  height: 20px;
}

.boar-notification-dot {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 8px;
  height: 8px;
  background-color: var(--color-gold);
  border-radius: 50%;
  box-shadow: 0 0 0 2px var(--color-white);
}

.boar-user-menu {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding-left: var(--space-lg);
  border-left: 1px solid var(--color-gray-200);
}

.boar-user-menu-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background-color: var(--color-gold);
  color: var(--color-white);
  font-size: var(--font-size-xs);
  font-weight: 700;
}

.boar-user-menu-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: var(--space-lg);
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: 40;
  min-width: 200px;
  overflow: hidden;
}

.boar-user-menu-dropdown.active {
  display: block;
}

.boar-user-menu-dropdown a,
.boar-user-menu-dropdown button {
  display: block;
  width: 100%;
  padding: var(--space-md) var(--space-lg);
  text-align: left;
  font-size: var(--font-size-sm);
  color: var(--color-dark);
  border: none;
  background: none;
  transition: background-color var(--transition-base);
}

.boar-user-menu-dropdown a:hover,
.boar-user-menu-dropdown button:hover {
  background-color: var(--color-gray-50);
}

.boar-user-menu-dropdown a:first-child,
.boar-user-menu-dropdown button:first-child {
  border-bottom: 1px solid var(--color-gray-100);
}

/* === STAT CARDS === */

.boar-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-xl);
  margin-bottom: var(--space-2xl);
}

.boar-stat-card {
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-100);
  transition: all var(--transition-base);
}

.boar-stat-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--color-gray-200);
}

.boar-stat-card-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.boar-stat-label {
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
  font-weight: 500;
  margin-bottom: var(--space-sm);
}

.boar-stat-value {
  font-size: var(--font-size-3xl);
  font-weight: 700;
  color: var(--color-dark-navy);
  line-height: 1.2;
}

.boar-stat-sub {
  font-size: var(--font-size-xs);
  margin-top: var(--space-sm);
  font-weight: 500;
}

.boar-stat-sub.success {
  color: var(--color-success);
}

.boar-stat-sub.warning {
  color: var(--color-warning);
}

.boar-stat-sub.danger {
  color: var(--color-danger);
}

.boar-stat-icon {
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  background-color: var(--color-cream);
  font-size: 24px;
  line-height: 1;
  color: var(--color-gold);
}

/* === CARDS === */

.boar-card {
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-100);
  overflow-y: auto;
  overflow-x: hidden;
  transition: all var(--transition-base);
}

.boar-card:hover {
  box-shadow: var(--shadow-md);
}

.boar-card-header {
  padding: var(--space-xl);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--color-gray-100);
}

.boar-card-header-title {
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--color-dark-navy);
}

.boar-card-body {
  padding: var(--space-xl);
}

.boar-card-footer {
  padding: var(--space-xl);
  border-top: 1px solid var(--color-gray-100);
  display: flex;
  gap: var(--space-lg);
}

/* === TABLES === */

.boar-table {
  width: 100%;
  font-size: var(--font-size-sm);
  border-collapse: collapse;
}

.boar-table thead {
  background-color: var(--color-cream);
}

.boar-table th {
  text-align: left;
  padding: var(--space-lg) var(--space-xl);
  font-weight: 600;
  color: var(--color-gray-500);
  border: none;
}

.boar-table td {
  padding: calc(var(--space-lg) + 2px) var(--space-xl);
  border-top: 1px solid var(--color-gray-100);
}

.boar-table tbody tr {
  transition: background-color var(--transition-base);
}

.boar-table tbody tr:hover {
  background-color: var(--color-gray-50);
  cursor: pointer;
}

.boar-table tbody tr:first-child td {
  border-top: none;
}

/* === BADGES & STATUS INDICATORS === */

.boar-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 600;
  white-space: nowrap;
}

.boar-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.boar-badge-em-curso {
  background-color: #dbeafe;
  color: #1e40af;
}

.boar-badge-em-curso .boar-badge-dot {
  background-color: #3b82f6;
}

.boar-badge-pendente {
  background-color: #fef3c7;
  color: #b45309;
}

.boar-badge-pendente .boar-badge-dot {
  background-color: #f59e0b;
}

.boar-badge-concluido {
  background-color: #dcfce7;
  color: #166534;
}

.boar-badge-concluido .boar-badge-dot {
  background-color: #22c55e;
}

.boar-badge-requer-acao {
  background-color: #fee2e2;
  color: #991b1b;
}

.boar-badge-requer-acao .boar-badge-dot {
  background-color: #ef4444;
}

/* === PROGRESS BARS === */

.boar-progress {
  width: 100%;
  height: 8px;
  background-color: var(--color-gray-200);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.boar-progress-fill {
  height: 100%;
  background-color: var(--color-gold);
  border-radius: var(--radius-full);
  transition: width 0.5s ease;
}

.boar-progress-fill.complete {
  background-color: var(--color-success);
}

/* === TIMELINE === */

.boar-timeline {
  position: relative;
  padding-left: 40px;
}

.boar-timeline::before {
  content: '';
  position: absolute;
  left: 8px;
  top: 0;
  bottom: 0;
  width: 2px;
  background-color: var(--color-gray-200);
}

.boar-timeline-item {
  position: relative;
  margin-bottom: var(--space-2xl);
}

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

.boar-timeline-dot {
  position: absolute;
  left: -32px;
  top: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 3px solid var(--color-white);
  z-index: 2;
  background-color: var(--color-gray-100);
  color: var(--color-gray-400);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  font-weight: 700;
  transition: all var(--transition-base);
}

.boar-timeline-dot.completed {
  background-color: var(--color-success);
  color: var(--color-white);
  box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.1);
}

.boar-timeline-dot.current {
  background-color: var(--color-gold);
  color: var(--color-white);
  width: 28px;
  height: 28px;
  box-shadow: 0 0 0 4px rgba(163, 128, 80, 0.2);
}

.boar-timeline-dot.pending {
  background-color: var(--color-gray-100);
  color: var(--color-gray-400);
}

.boar-timeline-content {
  padding: var(--space-lg);
  background-color: var(--color-gray-50);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-base);
}

.boar-timeline-content.current {
  background-color: rgba(163, 128, 80, 0.02);
  border-color: var(--color-gold-light);
}

.boar-timeline-content.completed {
  background-color: rgba(34, 197, 94, 0.03);
  border-color: rgba(34, 197, 94, 0.2);
}

.boar-timeline-title {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark-navy);
  margin-bottom: var(--space-sm);
}

.boar-timeline-date {
  font-size: var(--font-size-xs);
  color: var(--color-gray-500);
  font-weight: 500;
  margin-bottom: var(--space-sm);
}

.boar-timeline-description {
  font-size: var(--font-size-sm);
  color: var(--color-gray-600);
  line-height: 1.5;
}

/* === ACCORDION === */

.boar-accordion {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.boar-accordion-item {
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-100);
  overflow: hidden;
  transition: all var(--transition-base);
}

.boar-accordion-item:hover {
  box-shadow: var(--shadow-md);
}

.boar-accordion-header {
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-xl);
  background: none;
  text-align: left;
  border: none;
  cursor: pointer;
  transition: background-color var(--transition-base);
}

.boar-accordion-header:hover {
  background-color: var(--color-gray-50);
}

.boar-accordion-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background-color: var(--color-cream);
  color: var(--color-gold);
  border-radius: var(--radius-md);
  font-size: 18px;
  flex-shrink: 0;
}

.boar-accordion-title {
  flex: 1;
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark-navy);
}

.boar-accordion-count {
  font-size: var(--font-size-xs);
  color: var(--color-gray-400);
  font-weight: 500;
}

.boar-accordion-chevron {
  color: var(--color-gray-400);
  font-size: 18px;
  transition: transform var(--transition-base);
  flex-shrink: 0;
}

.boar-accordion-item.active .boar-accordion-chevron {
  transform: rotate(180deg);
}

.boar-accordion-content {
  display: none;
  padding: var(--space-xl);
  border-top: 1px solid var(--color-gray-100);
  background-color: var(--color-gray-50);
  font-size: var(--font-size-sm);
  color: var(--color-gray-600);
  line-height: 1.6;
}

.boar-accordion-item.active .boar-accordion-content {
  display: block;
}

/* === WIZARD STEPS === */

.boar-wizard-steps {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-100);
}

.boar-wizard-step {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex: 1;
  position: relative;
}

.boar-wizard-step:last-child .boar-wizard-step-line {
  display: none;
}

.boar-wizard-step-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-size: var(--font-size-xs);
  font-weight: 700;
  flex-shrink: 0;
  transition: all var(--transition-base);
}

.boar-wizard-step-circle.active {
  background-color: var(--color-gold);
  color: var(--color-white);
}

.boar-wizard-step-circle.completed {
  background-color: var(--color-success);
  color: var(--color-white);
}

.boar-wizard-step-circle.pending {
  background-color: var(--color-gray-100);
  color: var(--color-gray-400);
}

.boar-wizard-step-label {
  font-size: var(--font-size-xs);
  font-weight: 600;
  text-transform: uppercase;
  white-space: nowrap;
  min-w-0;
}

.boar-wizard-step.active .boar-wizard-step-label {
  color: var(--color-dark-navy);
}

.boar-wizard-step:not(.active) .boar-wizard-step-label {
  color: var(--color-gray-500);
}

.boar-wizard-step-line {
  flex: 1;
  height: 2px;
  background-color: var(--color-gray-200);
  margin: 0 var(--space-sm);
}

/* === FORM ELEMENTS === */

.boar-form-group {
  margin-bottom: var(--space-xl);
}

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

.boar-form-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-gray-600);
  margin-bottom: var(--space-md);
}

.boar-form-input,
.boar-form-select,
.boar-form-textarea {
  width: 100%;
  padding: var(--space-md) var(--space-lg);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  color: var(--color-dark);
  background-color: var(--color-white);
  transition: all var(--transition-base);
}

.boar-form-input::placeholder,
.boar-form-textarea::placeholder {
  color: var(--color-gray-400);
}

.boar-form-input:focus,
.boar-form-select:focus,
.boar-form-textarea:focus {
  outline: none;
  border-color: var(--color-gold);
  box-shadow: 0 0 0 3px rgba(163, 128, 80, 0.1);
  background-color: var(--color-white);
}

.boar-form-input:disabled,
.boar-form-select:disabled,
.boar-form-textarea:disabled {
  background-color: var(--color-gray-100);
  color: var(--color-gray-400);
  cursor: not-allowed;
}

.boar-form-textarea {
  resize: vertical;
  min-height: 120px;
}

.boar-form-error {
  font-size: var(--font-size-sm);
  color: var(--color-danger);
  margin-top: var(--space-sm);
}

/* === BUTTONS === */

.boar-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-xl);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  font-weight: 600;
  transition: all var(--transition-base);
  border: none;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
}

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

.boar-btn-primary {
  background-color: var(--color-dark-navy);
  color: var(--color-white);
}

.boar-btn-primary:hover:not(:disabled) {
  background-color: var(--color-mid-blue);
  box-shadow: var(--shadow-md);
}

.boar-btn-primary:active:not(:disabled) {
  transform: scale(0.98);
}

.boar-btn-secondary {
  background-color: var(--color-white);
  color: var(--color-gray-600);
  border: 1px solid var(--color-gray-200);
}

.boar-btn-secondary:hover:not(:disabled) {
  background-color: var(--color-gray-50);
  border-color: var(--color-gray-300);
}

.boar-btn-secondary:active:not(:disabled) {
  transform: scale(0.98);
}

.boar-btn-accent {
  background-color: var(--color-gold);
  color: var(--color-white);
}

.boar-btn-accent:hover:not(:disabled) {
  background-color: #8f6f45;
  box-shadow: var(--shadow-md);
}

.boar-btn-accent:active:not(:disabled) {
  transform: scale(0.98);
}

.boar-btn-outline-gold {
  border: 1.5px solid var(--color-gold);
  color: var(--color-gold);
  background-color: transparent;
}

.boar-btn-outline-gold:hover:not(:disabled) {
  background-color: var(--color-cream);
}

.boar-btn-outline-gold:active:not(:disabled) {
  transform: scale(0.98);
}

.boar-btn-sm {
  padding: var(--space-sm) var(--space-md);
  font-size: var(--font-size-xs);
}

.boar-btn-icon {
  padding: var(--space-sm);
  width: auto;
  aspect-ratio: 1;
  border-radius: var(--radius-md);
  gap: 0;
}

.boar-btn svg {
  width: 18px;
  height: 18px;
}

/* === DROPZONE === */

.boar-dropzone {
  padding: var(--space-3xl);
  border: 2px dashed var(--color-gray-300);
  border-radius: var(--radius-xl);
  text-align: center;
  transition: all var(--transition-base);
  cursor: pointer;
  background-color: rgba(249, 243, 237, 0.5);
}

.boar-dropzone:hover {
  border-color: var(--color-warning);
}

.boar-dropzone.drag-over {
  border-color: var(--color-gold);
  background-color: var(--color-cream);
}

.boar-dropzone-icon {
  font-size: 32px;
  color: var(--color-gold);
  margin-bottom: var(--space-lg);
  line-height: 1;
}

.boar-dropzone-text {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark);
  margin-bottom: var(--space-sm);
}

.boar-dropzone-subtext {
  font-size: var(--font-size-xs);
  color: var(--color-gray-400);
}

.boar-dropzone-input {
  display: none;
}

/* === MESSAGES === */

.boar-message {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-xl);
  border-bottom: 1px solid var(--color-gray-100);
  transition: background-color var(--transition-base);
}

.boar-message:hover {
  background-color: var(--color-gray-50);
}

.boar-message.unread {
  background-color: rgba(59, 130, 246, 0.05);
}

.boar-message.sent {
  background-color: rgba(245, 158, 11, 0.08);
}

.boar-message-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background-color: var(--color-gold);
  color: var(--color-white);
  font-size: var(--font-size-xs);
  font-weight: 700;
  flex-shrink: 0;
}

.boar-message-body {
  flex: 1;
  min-width: 0;
}

.boar-message-sender {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark);
  margin-bottom: var(--space-xs);
}

.boar-message-role {
  display: inline-block;
  font-size: var(--font-size-xs);
  padding: var(--space-xs) var(--space-md);
  background-color: var(--color-cream);
  color: var(--color-gold);
  border-radius: var(--radius-full);
  font-weight: 600;
  margin-left: var(--space-sm);
}

.boar-message-time {
  font-size: var(--font-size-xs);
  color: var(--color-gray-400);
  margin-top: var(--space-md);
}

.boar-message-text {
  font-size: var(--font-size-sm);
  color: var(--color-gray-600);
  line-height: 1.6;
  margin-top: var(--space-md);
}

.boar-message-compose {
  padding: var(--space-lg);
  border-top: 1px solid var(--color-gray-100);
  display: flex;
  gap: var(--space-md);
  background-color: var(--color-white);
}

.boar-message-compose-input {
  flex: 1;
  padding: var(--space-md) var(--space-lg);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  resize: none;
  min-height: 40px;
  max-height: 120px;
}

/* === DOCUMENTS === */

.boar-document-row {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-lg) var(--space-xl);
  border-bottom: 1px solid var(--color-gray-100);
  transition: background-color var(--transition-base);
  cursor: pointer;
}

.boar-document-row:hover {
  background-color: var(--color-gray-50);
}

.boar-document-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-lg);
  background-color: var(--color-cream);
  color: var(--color-gold);
  font-size: 20px;
  flex-shrink: 0;
}

.boar-document-icon.uploaded {
  background-color: #dcfce7;
  color: var(--color-success);
}

.boar-document-info {
  flex: 1;
  min-w-0;
}

.boar-document-name {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark);
  margin-bottom: var(--space-xs);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.boar-document-meta {
  font-size: var(--font-size-xs);
  color: var(--color-gray-400);
}

.boar-document-status {
  flex-shrink: 0;
}

/* === NOTIFICATIONS PANEL === */

.boar-notification {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  transition: background-color var(--transition-base);
  cursor: pointer;
}

.boar-notification:hover {
  background-color: var(--color-gray-50);
}

.boar-notification-icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  flex-shrink: 0;
}

.boar-notification-icon-wrap.info {
  background-color: #dbeafe;
  color: #3b82f6;
}

.boar-notification-icon-wrap.success {
  background-color: #dcfce7;
  color: var(--color-success);
}

.boar-notification-icon-wrap.warning {
  background-color: #fef3c7;
  color: var(--color-warning);
}

.boar-notification-icon-wrap.error {
  background-color: #fee2e2;
  color: var(--color-danger);
}

.boar-notification-text {
  flex: 1;
  font-size: var(--font-size-sm);
  color: var(--color-gray-700);
  line-height: 1.5;
}

.boar-notification-time {
  font-size: var(--font-size-xs);
  color: var(--color-gray-400);
  white-space: nowrap;
}

/* === HERO CARD === */

.boar-hero-card {
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  color: var(--color-white);
  background-color: var(--color-dark-navy);
  position: relative;
  overflow: hidden;
  margin-bottom: var(--space-2xl);
}

.boar-hero-card::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background-color: rgba(163, 128, 80, 0.1);
  z-index: 0;
}

.boar-hero-card > * {
  position: relative;
  z-index: 1;
}

.boar-hero-label {
  font-size: var(--font-size-sm);
  color: var(--color-gold-light);
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.5px;
  margin-bottom: var(--space-sm);
}

.boar-hero-title {
  font-size: var(--font-size-3xl);
  font-weight: 700;
  margin-bottom: var(--space-md);
  line-height: 1.2;
}

.boar-hero-subtitle {
  font-size: var(--font-size-sm);
  color: rgba(255, 255, 255, 0.7);
}

.boar-hero-progress {
  margin-top: var(--space-lg);
}

/* === FILTER BUTTONS === */

.boar-filter-group {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-bottom: var(--space-xl);
}

.boar-filter-btn {
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  font-weight: 600;
  transition: all var(--transition-base);
  border: 1px solid var(--color-gray-200);
  background-color: var(--color-white);
  color: var(--color-gray-500);
  cursor: pointer;
}

.boar-filter-btn:hover:not(.active) {
  border-color: var(--color-gray-300);
  background-color: var(--color-gray-100);
}

.boar-filter-btn.active {
  background-color: var(--color-dark-navy);
  color: var(--color-white);
  border-color: var(--color-dark-navy);
}

/* === EXPANDABLE ORDER CARD === */

.boar-order-card {
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-100);
  overflow: hidden;
  margin-bottom: var(--space-lg);
}

.boar-order-header {
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-xl);
  cursor: pointer;
  transition: background-color var(--transition-base);
  border: none;
  background: none;
  text-align: left;
}

.boar-order-header:hover {
  background-color: var(--color-gray-50);
}

.boar-order-header-icon {
  font-size: 20px;
  color: var(--color-gray-400);
  flex-shrink: 0;
  transition: transform var(--transition-base);
}

.boar-order-card.active .boar-order-header-icon {
  transform: rotate(180deg);
}

.boar-order-header-content {
  flex: 1;
}

.boar-order-header-title {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark-navy);
  margin-bottom: var(--space-xs);
}

.boar-order-header-meta {
  font-size: var(--font-size-xs);
  color: var(--color-gray-500);
}

.boar-order-detail {
  display: none;
  border-top: 1px solid var(--color-gray-100);
  padding: var(--space-xl);
}

.boar-order-card.active .boar-order-detail {
  display: block;
}

.boar-order-phases {
  display: flex;
  align-items: flex-start;
  gap: var(--space-lg);
  overflow-x: auto;
  padding-bottom: var(--space-sm);
}

.boar-order-phase {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  min-width: 100px;
  flex: 1;
  text-align: center;
}

.boar-order-phase-dot {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 3px solid var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  font-weight: 700;
}

.boar-order-phase-dot.completed {
  background-color: var(--color-success);
  color: var(--color-white);
}

.boar-order-phase-dot.current {
  background-color: var(--color-gold);
  color: var(--color-white);
  width: 28px;
  height: 28px;
}

.boar-order-phase-dot.pending {
  background-color: var(--color-gray-100);
  color: var(--color-gray-400);
}

.boar-order-phase-label {
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--color-gray-600);
}

/* === EMPTY STATES === */

.boar-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-2xl);
  min-height: 300px;
  text-align: center;
}

.boar-empty-state-icon {
  font-size: 64px;
  margin-bottom: var(--space-xl);
  opacity: 0.5;
  line-height: 1;
}

.boar-empty-state-title {
  font-size: var(--font-size-xl);
  font-weight: 700;
  color: var(--color-dark-navy);
  margin-bottom: var(--space-md);
}

.boar-empty-state-description {
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
  max-width: 400px;
  line-height: 1.6;
}

/* === LOADING STATES === */

.boar-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-2xl);
  min-height: 300px;
}

.boar-loading-spinner {
  width: 48px;
  height: 48px;
  border: 4px solid var(--color-gray-200);
  border-top-color: var(--color-gold);
  border-radius: 50%;
  animation: boar-spin 1s linear infinite;
}

@keyframes boar-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.boar-loading-text {
  margin-top: var(--space-lg);
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
}

/* === TOAST NOTIFICATIONS === */

.boar-toast-container {
  position: fixed;
  top: var(--space-lg);
  right: var(--space-lg);
  z-index: 60;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  pointer-events: none;
}

.boar-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-lg);
  border-radius: var(--radius-lg);
  background-color: var(--color-white);
  box-shadow: var(--shadow-lg);
  border-left: 4px solid var(--color-gray-200);
  pointer-events: auto;
  animation: boar-slideIn 0.3s ease-out;
}

@keyframes boar-slideIn {
  from {
    transform: translateX(400px);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

.boar-toast.success {
  border-left-color: var(--color-success);
}

.boar-toast.error {
  border-left-color: var(--color-danger);
}

.boar-toast.warning {
  border-left-color: var(--color-warning);
}

.boar-toast-icon {
  flex-shrink: 0;
  font-size: 20px;
  margin-top: 2px;
}

.boar-toast.success .boar-toast-icon {
  color: var(--color-success);
}

.boar-toast.error .boar-toast-icon {
  color: var(--color-danger);
}

.boar-toast.warning .boar-toast-icon {
  color: var(--color-warning);
}

.boar-toast-body {
  flex: 1;
}

.boar-toast-title {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-dark);
  margin-bottom: var(--space-xs);
}

.boar-toast-message {
  font-size: var(--font-size-sm);
  color: var(--color-gray-600);
}

.boar-toast-close {
  flex-shrink: 0;
  cursor: pointer;
  color: var(--color-gray-400);
  font-size: 18px;
  transition: color var(--transition-base);
  padding: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.boar-toast-close:hover {
  color: var(--color-gray-600);
}

/* === STRIPE FORM === */

.boar-stripe-form {
  padding: var(--space-xl);
  border: 2px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  background-color: var(--color-white);
}

#card-element {
  padding: var(--space-lg);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
}

.boar-stripe-badge {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  background-color: var(--color-gray-50);
  font-size: var(--font-size-xs);
  color: var(--color-gray-500);
  margin-top: var(--space-lg);
}

.boar-stripe-badge svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* === LOGIN PAGE === */

.boar-login-page {
  min-height: 100vh;
  display: flex;
  background-color: var(--color-gray-50);
}

.boar-login-left {
  display: none;
  width: 50%;
  background-color: var(--color-dark-navy);
  color: var(--color-white);
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  padding: var(--space-2xl);
}

.boar-login-left::before {
  content: '';
  position: absolute;
  top: -30%;
  right: -10%;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background-color: rgba(163, 128, 80, 0.15);
  z-index: 0;
}

.boar-login-left::after {
  content: '';
  position: absolute;
  bottom: -20%;
  left: -10%;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background-color: rgba(163, 128, 80, 0.1);
  z-index: 0;
}

.boar-login-left-content {
  position: relative;
  z-index: 1;
  text-align: center;
}

.boar-login-logo {
  font-size: 48px;
  margin-bottom: var(--space-xl);
  line-height: 1;
}

.boar-login-tagline {
  font-size: var(--font-size-lg);
  font-weight: 600;
  margin-bottom: var(--space-md);
}

.boar-login-description {
  font-size: var(--font-size-sm);
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.6;
}

.boar-login-right {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2xl);
}

.boar-login-form-wrapper {
  width: 100%;
  max-width: 420px;
}

.boar-login-form-title {
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--color-dark-navy);
  margin-bottom: var(--space-md);
}

.boar-login-form-subtitle {
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
  margin-bottom: var(--space-2xl);
}

.boar-login-form-error {
  display: none;
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  background-color: #fee2e2;
  color: #991b1b;
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-xl);
}

.boar-login-form-error.show {
  display: block;
}

@media (min-width: 1024px) {
  .boar-login-left {
    display: flex;
  }

  .boar-login-right {
    width: 50%;
  }
}

/* === SALIENT THEME OVERRIDES === */

body.boar-app-page #header-outer-wrap,
body.boar-app-page #header-outer,
body.boar-app-page #header-space,
body.boar-app-page #footer-outer,
body.boar-app-page .bottom_controls,
body.boar-app-page #to-top,
body.boar-app-page .nectar-slider-wrap,
body.boar-app-page #slide-out-widget-area-bg,
body.boar-app-page #slide-out-widget-area,
body.boar-app-page #wpadminbar {
  display: none !important;
}

body.boar-app-page {
  padding-top: 0;
  margin-top: 0;
}

body.boar-app-page .container-wrap,
body.boar-app-page .main-content {
  padding-top: 0;
  margin-top: 0;
}

/* Force all Salient theme wrappers to full width */
body.boar-app-page .container-wrap,
body.boar-app-page .container,
body.boar-app-page .main-content,
body.boar-app-page .row {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
  margin-left: 0;
  margin-right: 0;
}

body.boar-app-page .boar-app-container,
body.boar-app-page .boar-app {
  display: flex;
  width: 100%;
  max-width: 100%;
  min-height: 100vh;
  margin: 0;
  padding: 0;
}

/* === RESPONSIVE DESIGN === */

@media (max-width: 1024px) {
  .boar-app-container,
  .boar-app {
    flex-direction: column;
  }

  .boar-sidebar {
    position: fixed;
    left: 0;
    top: 0;
    transform: translateX(-100%);
    transition: transform var(--transition-slow);
    width: 256px;
    min-width: 256px;
  }

  .boar-sidebar.active,
  .boar-sidebar.mobile-open {
    transform: translateX(0);
  }

  .boar-main-wrap,
  .boar-content {
    margin-left: 0;
    width: 100%;
  }

  .boar-hamburger {
    display: flex;
  }

  .boar-stats-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  :root {
    --space-xl: 16px;
    --space-lg: 12px;
  }

  .boar-header {
    padding: var(--space-lg);
    height: 56px;
  }

  .boar-header-title {
    font-size: var(--font-size-base);
  }

  .boar-content {
    padding: var(--space-lg);
  }

  .boar-sidebar {
    width: 256px;
  }

  .boar-login-right {
    padding: var(--space-xl);
  }

  .boar-login-form-wrapper {
    max-width: 100%;
  }

  .boar-stats-grid {
    grid-template-columns: 1fr;
  }

  .boar-toast-container {
    top: var(--space-sm);
    right: var(--space-sm);
    left: var(--space-sm);
  }

  .boar-toast {
    width: 100%;
  }

  .boar-table {
    font-size: var(--font-size-xs);
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .boar-table th,
  .boar-table td {
    padding: var(--space-sm) var(--space-md);
    white-space: nowrap;
  }

  .boar-grid-2-1 {
    grid-template-columns: 1fr;
  }

  .boar-form-grid {
    grid-template-columns: 1fr;
  }

  .boar-stat-grid {
    grid-template-columns: 1fr 1fr;
  }

  .boar-filters-bar {
    flex-direction: column;
    align-items: stretch;
  }

  .boar-search-box {
    min-width: 100%;
  }

  .boar-filter-pills {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: var(--space-sm);
  }

  .boar-modal {
    max-width: 95vw;
    max-height: 85vh;
  }

  .boar-modal-body {
    padding: var(--space-lg);
  }

  .boar-steps {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-sm);
  }

  .boar-step-line {
    display: none;
  }

  .boar-message {
    padding: var(--space-lg);
  }

  .boar-order-phases {
    gap: var(--space-md);
  }

  .boar-order-phase {
    min-width: 80px;
  }
}

/* === UTILITY CLASSES === */

.boar-text-center {
  text-align: center;
}

.boar-text-right {
  text-align: right;
}

.boar-text-left {
  text-align: left;
}

.boar-mb-xs {
  margin-bottom: var(--space-xs);
}

.boar-mb-sm {
  margin-bottom: var(--space-sm);
}

.boar-mb-md {
  margin-bottom: var(--space-md);
}

.boar-mb-lg {
  margin-bottom: var(--space-lg);
}

.boar-mb-xl {
  margin-bottom: var(--space-xl);
}

.boar-mb-2xl {
  margin-bottom: var(--space-2xl);
}

.boar-mt-xs {
  margin-top: var(--space-xs);
}

.boar-mt-sm {
  margin-top: var(--space-sm);
}

.boar-mt-md {
  margin-top: var(--space-md);
}

.boar-mt-lg {
  margin-top: var(--space-lg);
}

.boar-mt-xl {
  margin-top: var(--space-xl);
}

.boar-mt-2xl {
  margin-top: var(--space-2xl);
}

.boar-p-lg {
  padding: var(--space-lg);
}

.boar-p-xl {
  padding: var(--space-xl);
}

.boar-p-2xl {
  padding: var(--space-2xl);
}

.boar-px-lg {
  padding-left: var(--space-lg);
  padding-right: var(--space-lg);
}

.boar-py-lg {
  padding-top: var(--space-lg);
  padding-bottom: var(--space-lg);
}

.boar-hidden {
  display: none !important;
}

.boar-visible {
  display: block;
}

.boar-flex {
  display: flex;
}

.boar-flex-col {
  display: flex;
  flex-direction: column;
}

.boar-flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.boar-grid {
  display: grid;
}

.boar-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
}

.boar-grid-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-lg);
}

.boar-font-mono {
  font-family: 'Monaco', 'Courier New', monospace;
}

.boar-font-bold {
  font-weight: 700;
}

.boar-font-semibold {
  font-weight: 600;
}

.boar-font-medium {
  font-weight: 500;
}

.boar-w-full {
  width: 100%;
}

.boar-h-full {
  height: 100%;
}

.boar-max-w-md {
  max-width: 448px;
}

.boar-max-w-lg {
  max-width: 512px;
}

.boar-max-w-xl {
  max-width: 640px;
}

.boar-max-w-2xl {
  max-width: 768px;
}

.boar-opacity-50 {
  opacity: 0.5;
}

.boar-opacity-75 {
  opacity: 0.75;
}

.boar-rounded {
  border-radius: var(--radius-md);
}

.boar-rounded-lg {
  border-radius: var(--radius-lg);
}

.boar-rounded-xl {
  border-radius: var(--radius-xl);
}

.boar-rounded-full {
  border-radius: var(--radius-full);
}

.boar-shadow {
  box-shadow: var(--shadow-md);
}

.boar-shadow-lg {
  box-shadow: var(--shadow-lg);
}

.boar-border {
  border: 1px solid var(--color-gray-200);
}

.boar-border-gold {
  border-color: var(--color-gold);
}

.boar-gap-md {
  gap: var(--space-md);
}

.boar-gap-lg {
  gap: var(--space-lg);
}

.boar-gap-xl {
  gap: var(--space-xl);
}

.boar-items-center {
  align-items: center;
}

.boar-justify-between {
  justify-content: space-between;
}

.boar-justify-center {
  justify-content: center;
}

.boar-overflow-hidden {
  overflow: hidden;
}

.boar-overflow-auto {
  overflow: auto;
}

.boar-whitespace-nowrap {
  white-space: nowrap;
}

.boar-truncate {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.boar-line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.boar-line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* === PART 2 — MISSING COMPONENT STYLES (v2.0 JS integration) === */

/* ─── Text Utilities ──────────────────────────────── */
.boar-bold { font-weight: 700; }
.boar-mono { font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace; font-size: var(--font-size-xs); }
.boar-text-muted { color: var(--color-gray-500); }
.boar-text-xs { font-size: var(--font-size-xs); }
.boar-text-sm { font-size: var(--font-size-sm); }
.boar-text-lg { font-size: var(--font-size-lg); }
.text-right { text-align: right; }
.boar-p-4 { padding: var(--space-lg); }
.boar-mt-sm { margin-top: var(--space-sm); }
.boar-mt-lg { margin-top: var(--space-xl); }

/* ─── Loading / Empty States ──────────────────────── */
.boar-loading-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: var(--space-3xl) var(--space-xl); color: var(--color-gray-400);
}
.boar-spinner {
  width: 32px; height: 32px; border: 3px solid var(--color-gray-200);
  border-top-color: var(--color-gold); border-radius: 50%;
  animation: boar-spin 0.7s linear infinite; margin-bottom: var(--space-md);
}
@keyframes boar-spin { to { transform: rotate(360deg); } }

.boar-empty { text-align: center; padding: var(--space-xl); color: var(--color-gray-400); }
.boar-empty-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: var(--space-3xl); color: var(--color-gray-400); text-align: center; gap: var(--space-md);
}

/* ─── Toast Notifications ─────────────────────────── */
.boar-toast-container {
  position: fixed; top: var(--space-xl); right: var(--space-xl); z-index: 9999;
  display: flex; flex-direction: column; gap: var(--space-sm); max-width: 380px;
}
.boar-toast {
  display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md); background: var(--color-white); box-shadow: var(--shadow-lg);
  border-left: 4px solid var(--color-gray-400); animation: boar-slideIn 0.3s ease;
}
.boar-toast-success { border-left-color: var(--color-success); }
.boar-toast-error   { border-left-color: var(--color-danger); }
.boar-toast-warning { border-left-color: var(--color-warning); }
.boar-toast-info    { border-left-color: var(--color-mid-blue); }
.boar-toast-icon { flex-shrink: 0; }
.boar-toast-text { flex: 1; font-size: var(--font-size-sm); color: var(--color-dark); }
.boar-toast-close { background: none; border: none; cursor: pointer; color: var(--color-gray-400); padding: 2px; }
@keyframes boar-slideIn { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } }

/* ─── Card Enhancements ───────────────────────────── */
.boar-card-title {
  font-size: var(--font-size-base); font-weight: 600; color: var(--color-dark-navy); margin-bottom: var(--space-lg);
}
.boar-card-header-row {
  display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-lg);
}
.boar-card-header-row .boar-card-title { margin-bottom: 0; }
.boar-divider { border: none; border-top: 1px solid var(--color-gray-100); margin: var(--space-md) 0; }

/* ─── Grid Layouts ────────────────────────────────── */
.boar-stat-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-lg); margin-bottom: var(--space-xl);
}
.boar-stat-grid-3 { grid-template-columns: repeat(3, 1fr); }
.boar-grid-2-1 {
  display: grid; grid-template-columns: 2fr 1fr; gap: var(--space-xl); margin-bottom: var(--space-xl);
}
.boar-grid-1-1 {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-xl); margin-bottom: var(--space-xl);
}
@media (max-width: 1024px) {
  .boar-stat-grid { grid-template-columns: repeat(2, 1fr); }
  .boar-grid-2-1, .boar-grid-1-1 { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .boar-stat-grid, .boar-stat-grid-3 { grid-template-columns: 1fr; }
}

/* ─── Stat Card Sub-Elements ──────────────────────── */
.boar-stat-card-body {
  display: flex; align-items: flex-start; justify-content: space-between;
}
.boar-stat-card-info { flex: 1; }
.boar-stat-card-label { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-bottom: var(--space-xs); }
.boar-stat-card-value { font-size: var(--font-size-2xl); font-weight: 700; color: var(--color-dark-navy); }
.boar-stat-card-sub { font-size: var(--font-size-xs); margin-top: var(--space-xs); }
.boar-stat-card-icon {
  padding: 10px; border-radius: var(--radius-md); background: var(--color-cream); color: var(--color-gold);
}

/* ─── Hero Card (Client Dashboard) ────────────────── */
.boar-hero-card {
  background: var(--color-dark-navy); color: var(--color-white); border-radius: var(--radius-lg);
  padding: var(--space-xl); margin-bottom: var(--space-xl);
}
.boar-hero-meta { font-size: var(--font-size-sm); color: var(--color-gold-light); margin-bottom: var(--space-xs); }
.boar-hero-title { font-size: var(--font-size-2xl); font-weight: 700; margin-bottom: var(--space-sm); }
.boar-hero-sub { font-size: var(--font-size-sm); color: rgba(255,255,255,0.7); }
.boar-hero-sub strong { color: var(--color-white); }
.boar-hero-progress { margin-top: var(--space-md); }

/* ─── Timeline Enhancements ───────────────────────── */
.boar-timeline { position: relative; padding-left: var(--space-xl); }
.boar-timeline-line {
  position: absolute; left: 16px; top: 0; bottom: 0; width: 2px; background: var(--color-gray-200);
}
.boar-timeline-item { position: relative; padding-left: var(--space-2xl); padding-bottom: var(--space-xl); }
.boar-timeline-dot {
  position: absolute; left: -8px; width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; z-index: 1; background: var(--color-gray-100); color: var(--color-gray-400);
}
.boar-timeline-completed .boar-timeline-dot { background: var(--color-success); color: var(--color-white); }
.boar-timeline-current .boar-timeline-dot {
  background: var(--color-gold); color: var(--color-white); box-shadow: 0 0 0 4px rgba(163,128,80,0.2);
}
.boar-timeline-content { padding-top: var(--space-xs); }
.boar-timeline-highlight {
  background: #fffbeb; margin: -8px -12px; padding: 12px; border-radius: var(--radius-md); border: 1px solid #fde68a;
}
.boar-timeline-header { display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; }
.boar-timeline-phase { font-size: var(--font-size-sm); font-weight: 600; color: var(--color-dark); }
.boar-timeline-date { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: 2px; }
.boar-timeline-desc { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-top: var(--space-xs); }

/* ─── Tags/Badges ─────────────────────────────────── */
.boar-tag {
  display: inline-flex; align-items: center; gap: 4px; font-size: var(--font-size-xs);
  font-weight: 500; padding: 2px 10px; border-radius: 999px;
}
.boar-tag-gold { background: rgba(163,128,80,0.15); color: var(--color-gold); }
.boar-tag-cream { background: var(--color-cream); color: var(--color-gold); }
.boar-tag-blue { background: #eff6ff; color: #1d4ed8; }
.boar-tag-green { background: #ecfdf5; color: #059669; }
.boar-tag-red { background: #fef2f2; color: #dc2626; }

/* ─── Notification Items ──────────────────────────── */
.boar-notif-list { display: flex; flex-direction: column; gap: var(--space-sm); }
.boar-notif-item {
  display: flex; gap: var(--space-md); padding: var(--space-md); border-radius: var(--radius-md);
  transition: background 0.15s;
}
.boar-notif-item:hover { background: var(--color-gray-50); }
.boar-notif-icon {
  width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; flex-shrink: 0; background: var(--color-gray-100);
}
.boar-notif-body { flex: 1; min-width: 0; }
.boar-notif-text { font-size: var(--font-size-sm); color: var(--color-dark); }
.boar-notif-time { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: 2px; }

/* ─── Checklist ───────────────────────────────────── */
.boar-checklist { display: flex; flex-direction: column; gap: var(--space-sm); }
.boar-checklist-item {
  display: flex; align-items: center; gap: var(--space-md); padding: 10px;
  border-radius: var(--radius-md); transition: background 0.15s;
}
.boar-checklist-item:hover { background: var(--color-gray-50); }
.boar-checklist-action { background: #fef2f2; border: 1px solid #fecaca; }
.boar-checklist-action:hover { background: #fef2f2; }
.boar-checklist-dot {
  width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; flex-shrink: 0;
}
.boar-checklist-validated { background: #ecfdf5; color: #059669; }
.boar-checklist-action .boar-checklist-dot { background: #fecaca; color: #dc2626; }
.boar-checklist-pending { background: var(--color-gray-100); color: var(--color-gray-400); }
.boar-checklist-label { flex: 1; font-size: var(--font-size-sm); }

/* ─── Disclaimer ──────────────────────────────────── */
.boar-disclaimer {
  display: flex; align-items: center; gap: var(--space-md); padding: var(--space-lg);
  background: var(--color-white); border-radius: var(--radius-lg); border: 1px solid var(--color-gray-100);
  box-shadow: var(--shadow-sm); margin-bottom: var(--space-xl); color: var(--color-gold);
}
.boar-disclaimer p { font-size: var(--font-size-sm); color: var(--color-gray-600); }

/* ─── Accordion (Catalog) ─────────────────────────── */
.boar-accordion { display: flex; flex-direction: column; gap: var(--space-md); }
.boar-accordion-body {
  display: none; border-top: 1px solid var(--color-gray-100); overflow-x: auto;
}
.boar-accordion-body.active { display: block; }

/* ─── Forms ───────────────────────────────────────── */
.boar-input, .boar-textarea {
  width: 100%; padding: 10px 16px; border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-md); font-size: var(--font-size-sm); color: var(--color-dark);
  background: var(--color-white); transition: border-color 0.2s, box-shadow 0.2s;
}
.boar-input:focus, .boar-textarea:focus {
  outline: none; border-color: var(--color-gold); box-shadow: 0 0 0 3px rgba(163,128,80,0.1);
}
.boar-textarea { resize: vertical; min-height: 80px; }
.boar-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); margin-bottom: var(--space-lg); }
.boar-form-full { grid-column: 1 / -1; }
.boar-form-actions { display: flex; gap: var(--space-md); margin-top: var(--space-lg); }
.boar-form-error { color: var(--color-danger); font-size: var(--font-size-sm); padding: var(--space-sm) var(--space-md); background: #fef2f2; border-radius: var(--radius-sm); }
@media (max-width: 640px) {
  .boar-form-grid { grid-template-columns: 1fr; }
}

/* ─── Steps / Wizard ──────────────────────────────── */
.boar-steps {
  display: flex; align-items: center; gap: var(--space-sm); background: var(--color-white);
  border-radius: var(--radius-lg); padding: var(--space-lg); box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-100); margin-bottom: var(--space-xl);
}
.boar-step { display: flex; align-items: center; gap: var(--space-sm); flex: 1; }
.boar-step-circle {
  width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; font-size: var(--font-size-xs); font-weight: 700; flex-shrink: 0;
  background: var(--color-gray-100); color: var(--color-gray-400);
}
.boar-step-active .boar-step-circle { background: var(--color-gold); color: var(--color-white); }
.boar-step-completed .boar-step-circle { background: var(--color-success); color: var(--color-white); }
.boar-step-label { font-size: var(--font-size-xs); font-weight: 500; color: var(--color-gray-400); }
.boar-step-active .boar-step-label { color: var(--color-dark); }
.boar-step-line { flex: 1; height: 2px; background: var(--color-gray-200); margin: 0 var(--space-sm); }

/* ─── Order Summary ───────────────────────────────── */
.boar-order-summary { height: fit-content; position: sticky; top: var(--space-xl); }
.boar-summary-row { margin-bottom: var(--space-xs); }
.boar-summary-total { display: flex; justify-content: space-between; font-weight: 700; }
.boar-price { font-weight: 600; color: var(--color-dark-navy); }
.boar-price-lg { font-size: var(--font-size-xl); font-weight: 700; color: var(--color-dark-navy); }

/* ─── Confirmation Screen ─────────────────────────── */
.boar-confirmation {
  max-width: 480px; margin: 0 auto; text-align: center; background: var(--color-white);
  border-radius: var(--radius-lg); padding: var(--space-3xl); box-shadow: var(--shadow-sm); border: 1px solid var(--color-gray-100);
}
.boar-confirmation-icon { color: var(--color-success); margin-bottom: var(--space-lg); }
.boar-confirmation h2 { font-size: var(--font-size-xl); font-weight: 700; color: var(--color-dark-navy); margin-bottom: var(--space-sm); }
.boar-confirmation p { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-bottom: var(--space-xl); }
.boar-confirmation-ref {
  background: var(--color-cream); padding: var(--space-lg); border-radius: var(--radius-md); margin-bottom: var(--space-xl);
}

/* ─── Service Picker (Request Step 1) ─────────────── */
.boar-service-picker { display: flex; flex-direction: column; gap: var(--space-md); }
.boar-service-option {
  display: flex; align-items: center; gap: var(--space-lg); width: 100%;
  padding: var(--space-lg); border: 2px solid var(--color-gray-100); border-radius: var(--radius-md);
  background: var(--color-white); cursor: pointer; text-align: left;
  transition: border-color 0.2s, background 0.2s;
}
.boar-service-option:hover { border-color: var(--color-gold-light); }
.boar-service-option.selected { border-color: var(--color-gold); background: #fffbeb; }
.boar-service-option-info { flex: 1; }
.boar-service-option-name { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-dark); }
.boar-service-option-notes { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: 2px; }
.boar-service-option-price { text-align: right; }

/* ─── Stripe / Payment ────────────────────────────── */
.boar-stripe-container {
  padding: var(--space-xl); border: 2px solid var(--color-gray-200);
  border-radius: var(--radius-lg); margin-bottom: var(--space-lg);
}
.boar-stripe-element { min-height: 40px; }
.boar-stripe-info {
  display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-md);
  background: var(--color-gray-50); border-radius: var(--radius-md); font-size: var(--font-size-xs);
  color: var(--color-gray-500); margin-bottom: var(--space-lg);
}
.boar-stripe-logo { margin-left: auto; font-weight: 700; font-size: var(--font-size-sm); color: #635bff; }

/* ─── Order Cards (Tracking) ──────────────────────── */
.boar-orders-list { display: flex; flex-direction: column; gap: var(--space-lg); }
.boar-order-card {
  background: var(--color-white); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); border: 1px solid var(--color-gray-100); overflow: hidden;
}
.boar-order-header, .boar-order-toggle {
  display: flex; align-items: center; gap: var(--space-lg); width: 100%;
  padding: var(--space-xl); background: none; border: none; cursor: pointer;
  text-align: left; transition: background 0.15s;
}
.boar-order-header:hover { background: var(--color-gray-50); }
.boar-order-info { flex: 1; min-width: 0; }
.boar-order-meta { display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; margin-bottom: var(--space-xs); }
.boar-order-name { font-size: var(--font-size-base); font-weight: 600; color: var(--color-dark-navy); }
.boar-order-progress { width: 96px; text-align: right; }
.boar-order-chevron { color: var(--color-gray-400); transition: transform 0.3s; }
.boar-order-card.expanded .boar-order-chevron { transform: rotate(180deg); }
.boar-order-detail {
  display: none; border-top: 1px solid var(--color-gray-100); padding: var(--space-xl);
}
.boar-order-card.expanded .boar-order-detail { display: block; }
.boar-detail-title {
  font-size: var(--font-size-sm); font-weight: 600; color: var(--color-dark-navy);
  margin-bottom: var(--space-md); margin-top: var(--space-xl);
}
.boar-detail-title:first-child { margin-top: 0; }

/* ─── Phase Row ───────────────────────────────────── */
.boar-phase-row {
  display: flex; align-items: flex-start; gap: var(--space-md); overflow-x: auto; padding-bottom: var(--space-sm);
}
.boar-phase-row-vertical { flex-direction: column; }
.boar-phase {
  display: flex; flex-direction: column; align-items: center; flex: 1; min-width: 0; text-align: center;
}
.boar-phase-row-vertical .boar-phase {
  flex-direction: row; gap: var(--space-md); text-align: left; align-items: flex-start;
}
.boar-phase-dot {
  width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; flex-shrink: 0; background: var(--color-gray-100); color: var(--color-gray-400);
  margin-bottom: var(--space-xs);
}
.boar-phase-done .boar-phase-dot { background: var(--color-success); color: var(--color-white); }
.boar-phase-current .boar-phase-dot {
  background: var(--color-gold); color: var(--color-white); box-shadow: 0 0 0 4px rgba(163,128,80,0.15);
}
.boar-phase-name { font-size: var(--font-size-xs); font-weight: 500; color: var(--color-gray-500); }
.boar-phase-current .boar-phase-name { color: var(--color-dark); }
.boar-phase-date { font-size: var(--font-size-xs); color: var(--color-gray-400); }

/* ─── Document Rows ───────────────────────────────── */
.boar-doc-list { display: flex; flex-direction: column; }
.boar-doc-list-bordered .boar-doc-row { border-bottom: 1px solid var(--color-gray-100); }
.boar-doc-list-bordered .boar-doc-row:last-child { border-bottom: none; }
.boar-doc-row {
  display: flex; align-items: center; gap: var(--space-md); padding: var(--space-md) var(--space-lg);
  transition: background 0.15s;
}
.boar-doc-row:hover { background: var(--color-gray-50); }
.boar-doc-icon {
  width: 40px; height: 40px; border-radius: var(--radius-md); display: flex;
  align-items: center; justify-content: center; background: var(--color-cream); color: var(--color-gold);
  flex-shrink: 0;
}
.boar-doc-icon-success { background: #ecfdf5; color: #059669; }
.boar-doc-info { flex: 1; min-width: 0; }
.boar-doc-name { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-dark); }
.boar-doc-ok { color: var(--color-success); }

/* ─── Dropzone Enhancements ───────────────────────── */
.boar-dropzone-title { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-dark); margin-top: var(--space-md); }
.boar-dropzone-sub { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: var(--space-xs); }
.boar-upload-item {
  display: flex; align-items: center; gap: var(--space-md); padding: var(--space-sm) 0;
  font-size: var(--font-size-sm); color: var(--color-gray-600);
}

/* ─── Messages ────────────────────────────────────── */
.boar-messages-card { display: flex; flex-direction: column; }
.boar-messages-list { flex: 1; max-height: 500px; overflow-y: auto; }
.boar-message { display: flex; gap: var(--space-md); padding: var(--space-xl); }
.boar-message + .boar-message { border-top: 1px solid var(--color-gray-100); }
.boar-message-unread { background: rgba(59,130,246,0.04); }
.boar-message-self { background: rgba(163,128,80,0.04); }
.boar-message-avatar {
  width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; color: var(--color-white); font-size: 11px; font-weight: 700; flex-shrink: 0;
}
.boar-message-body { flex: 1; min-width: 0; }
.boar-message-header { display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; }
.boar-message-sender { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-dark); }
.boar-message-time { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-left: auto; }
.boar-message-text { font-size: var(--font-size-sm); color: var(--color-gray-600); margin-top: var(--space-sm); line-height: 1.6; }
.boar-compose {
  display: flex; gap: var(--space-md); padding: var(--space-lg);
  border-top: 1px solid var(--color-gray-100);
}
.boar-compose .boar-input { flex: 1; }

/* ─── Filter Tabs ─────────────────────────────────── */
.boar-filter-tabs { display: flex; gap: var(--space-sm); margin-bottom: var(--space-xl); }
.boar-filter-btn {
  padding: var(--space-sm) var(--space-lg); border-radius: var(--radius-md);
  font-size: var(--font-size-sm); font-weight: 500; border: 1px solid var(--color-gray-200);
  background: var(--color-white); color: var(--color-gray-500); cursor: pointer; transition: all 0.2s;
}
.boar-filter-btn.active { background: var(--color-dark-navy); color: var(--color-white); border-color: var(--color-dark-navy); }

/* ─── Chart Bars (Simple) ─────────────────────────── */
.boar-chart-card { min-height: 260px; }
.boar-chart-bars {
  display: flex; align-items: flex-end; gap: var(--space-sm); height: 180px; padding-top: var(--space-md);
}
.boar-bar-col { flex: 1; display: flex; flex-direction: column; align-items: center; height: 100%; justify-content: flex-end; }
.boar-bar {
  width: 100%; max-width: 40px; border-radius: 4px 4px 0 0; background: var(--color-mid-blue);
  transition: height 0.5s ease; min-height: 4px;
}
.boar-bar-label { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: var(--space-xs); }

/* ─── Type Breakdown List ─────────────────────────── */
.boar-type-list { display: flex; flex-direction: column; gap: var(--space-sm); margin-top: var(--space-sm); }
.boar-type-row { display: flex; align-items: center; gap: var(--space-sm); font-size: var(--font-size-xs); }
.boar-type-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.boar-type-name { flex: 1; color: var(--color-gray-600); }
.boar-type-value { font-weight: 500; color: var(--color-dark); }

/* ─── Table Enhancements ──────────────────────────── */
.boar-table-wrap { overflow-x: auto; }
.boar-table-card .boar-card-header-row { padding: var(--space-lg) var(--space-xl); margin-bottom: 0; }
.boar-progress-cell { width: 120px; }
.boar-process-row { cursor: pointer; }

/* ─── Search Box ──────────────────────────────────── */
.boar-search-box {
  display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-gray-200); border-radius: var(--radius-md); color: var(--color-gray-400);
}
.boar-search-box input {
  border: none; outline: none; font-size: var(--font-size-sm); width: 160px; background: transparent;
}

/* ─── Process Header (Detail View) ────────────────── */
.boar-process-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: var(--space-xl);
}
.boar-process-status { flex-shrink: 0; }
.boar-detail-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg);
}
.boar-detail-grid span { font-size: var(--font-size-xs); }
.boar-detail-grid p { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-dark); margin-top: 2px; }

/* ─── Process Detail Organization ─────────────────── */
.boar-process-meta-grid {
  display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: var(--space-md); margin: var(--space-lg) 0 var(--space-xl);
}
.boar-process-meta-card {
  background: var(--color-white); border: 1px solid var(--color-gray-100); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); padding: 14px 16px;
}
.boar-process-meta-label {
  display:block; font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: .04em; color: var(--color-gray-400); margin-bottom: 6px;
}
.boar-process-meta-value {
  font-size: var(--font-size-sm); font-weight: 600; color: var(--color-dark-navy); margin: 0;
}
.boar-process-section-label {
  display:flex; align-items:center; gap:10px; margin: 0 0 var(--space-md); font-size: var(--font-size-sm); font-weight: 700; color: var(--color-dark-navy);
}
.boar-process-section-label::before {
  content:''; width:4px; height:18px; border-radius:999px; background: var(--color-gold);
}
.boar-process-overview-grid,
.boar-process-content-grid {
  display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: var(--space-xl); margin-bottom: var(--space-xl);
}
.boar-process-progress-card,
.boar-process-details-card,
.boar-folder-docs-card,
.boar-process-documents-available,
.boar-process-messages-card {
  height: 100%;
}
.boar-detail-grid-compact {
  display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: var(--space-md) var(--space-lg);
}
.boar-detail-grid-compact > div {
  padding: 10px 12px; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 10px;
}
.boar-process-action-bar {
  display:flex; gap:8px; margin-top:14px; padding-top:14px; border-top:1px solid #e2e8f0; flex-wrap:wrap; align-items:center;
}
.boar-process-messages-content {
  border-top: 1px solid var(--color-gray-100); padding-top: var(--space-md);
}
@media (max-width: 1024px) {
  .boar-process-meta-grid,
  .boar-process-overview-grid,
  .boar-process-content-grid,
  .boar-detail-grid-compact { grid-template-columns: 1fr; }
}

/* ─── Settings — Toggle Switch ────────────────────── */
.boar-toggle-list { display: flex; flex-direction: column; gap: var(--space-md); }
.boar-toggle-row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-xl); padding: var(--space-md) 0; }
.boar-toggle-row + .boar-toggle-row { border-top: 1px solid var(--color-gray-100); }
.boar-toggle-info { flex: 1; }
.boar-toggle-label { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-dark); }
.boar-toggle-desc { font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: 2px; }
.boar-switch { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.boar-switch input { opacity: 0; width: 0; height: 0; }
.boar-switch-slider {
  position: absolute; inset: 0; background: var(--color-gray-200); border-radius: 24px;
  cursor: pointer; transition: background 0.3s;
}
.boar-switch-slider::before {
  content: ''; position: absolute; width: 18px; height: 18px; border-radius: 50%;
  background: var(--color-white); top: 3px; left: 3px; transition: transform 0.3s;
}
.boar-switch input:checked + .boar-switch-slider { background: var(--color-gold); }
.boar-switch input:checked + .boar-switch-slider::before { transform: translateX(20px); }

/* ─── Language Toggle (Settings + Sidebar) ────────── */
.boar-lang-toggle { display: flex; gap: var(--space-sm); }
.boar-lang-btn {
  padding: var(--space-sm) var(--space-lg); border-radius: var(--radius-md);
  font-size: var(--font-size-sm); font-weight: 500; border: 1px solid var(--color-gray-200);
  background: var(--color-white); color: var(--color-gray-500); cursor: pointer; transition: all 0.2s;
}
.boar-lang-btn.active { background: var(--color-dark-navy); color: var(--color-white); border-color: var(--color-dark-navy); }

/* ─── Button Variants ─────────────────────────────── */
.boar-btn-gold {
  background: var(--color-gold); color: var(--color-white); border: none;
}
.boar-btn-gold:hover { background: #8c6c3f; }
.boar-btn-outline-gold {
  background: transparent; color: var(--color-gold); border: 1px solid var(--color-gold);
}
.boar-btn-outline-gold:hover { background: rgba(163,128,80,0.08); }
.boar-btn-outline {
  background: transparent; border: 1px solid var(--color-mid-blue); color: var(--color-mid-blue);
}
.boar-btn-outline:hover { background: rgba(55,81,119,0.06); }
.boar-btn-link {
  background: none; border: none; color: var(--color-mid-blue); cursor: pointer;
  display: inline-flex; align-items: center; gap: var(--space-xs); font-size: var(--font-size-sm);
  padding: var(--space-sm) 0;
}
.boar-btn-link:hover { text-decoration: underline; }
.boar-btn-block { width: 100%; }
.boar-btn-lg { padding: 12px var(--space-xl); font-size: var(--font-size-base); }
.boar-btn-xs {
  padding: 4px 10px; font-size: var(--font-size-xs); border-radius: var(--radius-sm);
}

/* ─── Login Page Styles ───────────────────────────── */
.boar-login-wrapper {
  display: flex; min-height: 100vh; background: var(--color-cream);
}
.boar-login-panel {
  display: none; width: 50%; position: relative; background: var(--color-dark-navy);
  align-items: center; justify-content: center; overflow: hidden;
}
.boar-login-panel-bg {
  position: absolute; inset: 0; opacity: 0.1;
}
.boar-login-panel-content {
  position: relative; z-index: 1; text-align: center; padding: 48px;
}
.boar-login-brand, .boar-login-brand-mobile {
  display: flex; align-items: center; justify-content: center; margin-bottom: 32px;
}
.boar-login-logo-img {
  max-width: 220px; height: auto;
}
.boar-login-logo-img-mobile {
  max-width: 180px; height: auto;
}
.boar-login-logo-icon {
  width: 40px; height: 40px; border-radius: var(--radius-md); background: var(--color-gold);
  color: var(--color-white); display: flex; align-items: center; justify-content: center;
}
.boar-login-brand-name { font-weight: 700; font-size: var(--font-size-lg); color: var(--color-white); }
.boar-login-brand-sub { font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: 3px; color: var(--color-gold-light); }
.boar-login-brand-mobile .boar-login-brand-name { color: var(--color-dark-navy); }
.boar-login-brand-mobile .boar-login-brand-sub { color: var(--color-gold); }
.boar-login-tagline {
  font-size: var(--font-size-3xl); font-weight: 300; color: var(--color-white); line-height: 1.3; margin-bottom: var(--space-xl);
}
.boar-login-tagline span { font-weight: 700; color: var(--color-gold-light); }
.boar-login-motto { font-size: var(--font-size-sm); color: var(--color-gold-light); }

.boar-login-form-panel {
  flex: 1; display: flex; align-items: center; justify-content: center; padding: 32px;
}
.boar-login-form-container { width: 100%; max-width: 420px; }
.boar-login-brand-mobile { margin-bottom: 40px; }
.boar-login-lang {
  display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-md);
  border-radius: var(--radius-md); border: 1px solid var(--color-gray-200); background: var(--color-white);
  margin-bottom: var(--space-xl); color: var(--color-gold);
}
.boar-login-lang span { font-size: var(--font-size-sm); color: var(--color-gray-500); }
.boar-login-title { font-size: var(--font-size-2xl); font-weight: 700; color: var(--color-dark-navy); margin-bottom: var(--space-sm); }
.boar-login-subtitle { font-size: var(--font-size-sm); color: var(--color-gray-500); margin-bottom: var(--space-2xl); }
.boar-login-error {
  background: #fef2f2; color: #dc2626; padding: var(--space-md); border-radius: var(--radius-md);
  font-size: var(--font-size-sm); margin-bottom: var(--space-lg);
}
.boar-login-form { display: flex; flex-direction: column; gap: var(--space-lg); }
.boar-login-form .boar-form-group label {
  display: block; font-size: var(--font-size-sm); font-weight: 500; color: var(--color-dark);
  margin-bottom: var(--space-xs);
}
.boar-login-options {
  display: flex; align-items: center; justify-content: space-between; font-size: var(--font-size-sm);
}
.boar-checkbox { display: flex; align-items: center; gap: var(--space-sm); cursor: pointer; color: var(--color-gray-600); }
.boar-forgot { color: var(--color-gold); text-decoration: none; font-weight: 500; }
.boar-forgot:hover { text-decoration: underline; }
.boar-login-footer-text {
  text-align: center; font-size: var(--font-size-xs); color: var(--color-gray-400); margin-top: var(--space-2xl);
}
.boar-login-divider {
  display: flex; align-items: center; margin: 20px 0; gap: 12px;
}
.boar-login-divider::before,
.boar-login-divider::after {
  content: ''; flex: 1; height: 1px; background: #e2e8f0;
}
.boar-login-divider span {
  font-size: 13px; color: #94a3b8; font-weight: 500;
}
#boar-google-login-wrapper {
  display: flex; justify-content: center;
}
#boar-google-login-wrapper .g_id_signin {
  width: 100%;
}

@media (min-width: 1024px) {
  .boar-login-panel { display: flex; }
  .boar-login-brand-mobile { display: none; }
}

/* ─── Sidebar Enhancements (App Shell from PHP) ───── */
.boar-sidebar-brand {
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-xl) var(--space-lg); border-bottom: 1px solid rgba(255,255,255,0.08);
}
.boar-sidebar-logo-img {
  max-width: 190px; max-height: 90px; width: 100%; height: auto; object-fit: contain;
}
.boar-sidebar-close {
  display: none; margin-left: auto; background: none; border: none; color: rgba(255,255,255,0.5);
  font-size: 24px; cursor: pointer;
}
@media (max-width: 1024px) { .boar-sidebar-close { display: block; } }

.boar-sidebar-role {
  margin: 0 var(--space-lg) var(--space-sm); padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md); background: rgba(163,128,80,0.15); color: var(--color-gold-light);
  font-size: var(--font-size-xs);
}
.boar-sidebar-lang {
  display: flex; gap: 4px; margin: 0 var(--space-lg) var(--space-md);
  padding: 4px; border-radius: var(--radius-md); background: rgba(255,255,255,0.08);
}
.boar-sidebar-lang-btn {
  flex: 1; padding: 4px 0; border: none; border-radius: var(--radius-sm);
  font-size: var(--font-size-xs); font-weight: 500; background: transparent;
  color: rgba(255,255,255,0.75); cursor: pointer; transition: all 0.2s;
}
.boar-sidebar-lang-btn.active { background: rgba(163,128,80,0.3); color: var(--color-white); }
.boar-sidebar-user {
  display: flex; align-items: center; gap: var(--space-md); padding: var(--space-lg);
  margin-top: auto;
}
.boar-sidebar-avatar {
  width: 32px; height: 32px; border-radius: 50%; background: var(--color-mid-blue);
  color: var(--color-white); display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
}
.boar-sidebar-user-name { font-size: var(--font-size-sm); color: var(--color-white); font-weight: 500; }
.boar-sidebar-user-role { font-size: var(--font-size-xs); color: var(--color-gold-light); }

/* ─── Mobile Toggle / Logout ──────────────────────── */
.boar-mobile-toggle { display: none; }
.boar-logout { display: inline-flex; }

/* ─── Footer ──────────────────────────────────────── */
.boar-footer {
  padding: var(--space-xl); text-align: center;
}
.boar-footer p { font-size: var(--font-size-xs); color: var(--color-gray-400); }

/* === PART 3: Notifications Page === */

.boar-notif-actions { margin-bottom: 16px; }

.boar-notifications-list { display: flex; flex-direction: column; gap: 0; }

.boar-notif-card {
  position: relative;
  padding: 16px;
  border: 1px solid var(--color-gray-200, #e2e8f0);
  border-radius: 8px;
  margin-bottom: 12px;
  background: #fff;
  transition: background 0.2s, box-shadow 0.2s;
}
.boar-notif-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.06); }

.boar-notif-unread {
  background: #fef8f3;
  border-color: var(--color-gold-light, #e2c5a1);
}

.boar-notif-dot {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-gold, #a38050);
}

.boar-notif-title {
  margin: 0 0 4px 0;
  font-weight: 600;
  color: var(--color-dark-navy, #0f172a);
  font-size: 14px;
}

.boar-notif-text {
  margin: 0 0 8px 0;
  color: var(--color-gray-500, #475569);
  font-size: 14px;
  line-height: 1.4;
}

.boar-notif-time {
  margin: 0;
  color: var(--color-gray-400, #94a3b8);
  font-size: 12px;
}

.boar-notif-read-btn {
  margin-left: 8px;
  padding: 6px 12px;
  background: none;
  border: 1px solid var(--color-gray-200, #e2e8f0);
  border-radius: 4px;
  cursor: pointer;
  color: var(--color-gray-500, #475569);
  font-size: 12px;
  flex-shrink: 0;
  transition: background 0.15s, border-color 0.15s;
}
.boar-notif-read-btn:hover {
  background: var(--color-cream, #f9f3ed);
  border-color: var(--color-gold, #a38050);
}

.boar-filter-tab {
  padding: 8px 12px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  color: var(--color-gray-400, #94a3b8);
  font-size: 14px;
  font-weight: 500;
  transition: color 0.15s, border-color 0.15s;
}
.boar-filter-tab:hover { color: var(--color-mid-blue, #375177); }
.boar-filter-tab.active {
  color: var(--color-mid-blue, #375177);
  border-bottom-color: var(--color-gold, #a38050);
}

/* Notification item (dashboard inline) */
.boar-notif-list { display: flex; flex-direction: column; gap: 12px; }
.boar-notif-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-gray-100, #f1f5f9);
}
.boar-notif-item:last-child { border-bottom: none; }
.boar-notif-icon { flex-shrink: 0; margin-top: 2px; }
.boar-notif-body { flex: 1; min-width: 0; }

/* === MODAL OVERLAY & DIALOG === */

.boar-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(24, 36, 83, 0.5);
  backdrop-filter: blur(4px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
}

.boar-modal {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  width: 100%;
  max-width: 640px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.boar-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-xl) var(--space-xl) var(--space-lg);
  border-bottom: 1px solid var(--color-gray-200);
}

.boar-modal-header h3 {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--color-dark-navy);
  margin: 0;
}

.boar-modal-close {
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  color: var(--color-gray-400);
  transition: all var(--transition-base);
}

.boar-modal-close:hover {
  background: var(--color-gray-100);
  color: var(--color-dark);
}

.boar-modal-body {
  padding: var(--space-xl);
}

.boar-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-md);
  padding: var(--space-lg) var(--space-xl);
  border-top: 1px solid var(--color-gray-200);
}

.boar-referral-service-info {
  padding: var(--space-md) var(--space-lg);
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-xl);
  font-size: var(--font-size-sm);
}

/* === SEARCH & FILTER BAR === */

.boar-filters-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
  margin-bottom: var(--space-xl);
}

.boar-search-box {
  display: flex;
  gap: var(--space-sm);
  flex: 1;
  min-width: 250px;
}

.boar-search-box .boar-input {
  flex: 1;
}

.boar-filter-pills {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.boar-pill {
  padding: var(--space-sm) var(--space-lg);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-full);
  background: var(--color-white);
  color: var(--color-gray-500);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all var(--transition-base);
}

.boar-pill:hover {
  border-color: var(--color-gold);
  color: var(--color-gold);
}

.boar-pill.active {
  background: var(--color-dark-navy);
  color: var(--color-white);
  border-color: var(--color-dark-navy);
}

.boar-clickable-row {
  cursor: pointer;
  transition: background var(--transition-base);
}

.boar-clickable-row:hover {
  background: var(--color-gray-50);
}

.boar-pagination {
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  margin-top: var(--space-xl);
}

.boar-page-btn {
  width: 36px;
  height: 36px;
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-md);
  background: var(--color-white);
  cursor: pointer;
  font-size: var(--font-size-sm);
}

.boar-page-btn.active {
  background: var(--color-dark-navy);
  color: var(--color-white);
  border-color: var(--color-dark-navy);
}

/* === PARTNER PRICING STYLES === */

.boar-price-original {
  text-decoration: line-through;
  color: var(--color-gray-400);
  font-size: var(--font-size-sm);
}

.boar-price-partner {
  color: var(--color-success);
  font-weight: 700;
  font-size: var(--font-size-base);
}

/* === Assign Service Form === */
.boar-form-divider {
  border-top: 1px solid var(--color-gray-200);
  margin: var(--space-lg) 0;
}
.boar-form-section-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--color-navy);
  margin-bottom: var(--space-md);
}
.boar-form-row {
  display: flex;
  gap: var(--space-md);
}
.boar-form-col {
  flex: 1;
  min-width: 0;
}
.boar-textarea {
  resize: vertical;
  min-height: 80px;
  font-family: inherit;
}
.boar-form-actions {
  margin-top: var(--space-lg);
  display: flex;
  justify-content: flex-end;
}
.boar-btn-lg {
  padding: var(--space-sm) var(--space-xl);
  font-size: var(--font-size-base);
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
}
@media (max-width: 768px) {
  .boar-form-row {
    flex-direction: column;
    gap: 0;
  }
}

/* === End of CSS v3.1 === */

/* ═══════════════════════════════════════════════════
   SCROLL FIX — Salient Theme Override (CSS-only, no JS)
   High specificity selectors to override theme styles
   ═══════════════════════════════════════════════════ */
body.boar-app-page,
body.boar-app-page .container-wrap,
body.boar-app-page .main-content,
body.boar-app-page .row,
body.boar-app-page #ajax-content-wrap,
body.boar-app-page .container-wrap .main-content {
    overflow: visible;
    height: auto;
    min-height: 0;
    max-height: none;
    position: static;
}

body.boar-app-page {
    overflow-x: hidden;
    overflow-y: auto;
}

/* App shell: sidebar fixed, content scrollable */
.boar-app {
    display: flex;
    min-height: 100vh;
    position: relative;
}

.boar-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 260px;
    height: 100vh;
    overflow-y: auto;
    z-index: 1000;
    display: flex;
    flex-direction: column;
}

.boar-content {
    margin-left: 260px;
    flex: 1;
    min-height: 100vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 2rem;
}

/* ═══════════════════════════════════════════════════
   SKELETON LOADING SCREENS
   ═══════════════════════════════════════════════════ */
@keyframes boar-skeleton-pulse {
    0% { opacity: 0.6; }
    50% { opacity: 1; }
    100% { opacity: 0.6; }
}

.boar-skeleton {
    animation: boar-skeleton-pulse 1.5s ease-in-out infinite;
    background: linear-gradient(90deg, var(--boar-gray-100, #f0f0f0) 25%, var(--boar-gray-200, #e0e0e0) 50%, var(--boar-gray-100, #f0f0f0) 75%);
    background-size: 200% 100%;
    border-radius: 4px;
}

.boar-skeleton-text {
    height: 14px;
    margin-bottom: 10px;
    width: 100%;
}

.boar-skeleton-text.short { width: 40%; }
.boar-skeleton-text.medium { width: 70%; }

.boar-skeleton-title {
    height: 24px;
    width: 50%;
    margin-bottom: 16px;
}

.boar-skeleton-card {
    background: var(--boar-white, #fff);
    border-radius: 12px;
    padding: 1.25rem;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    margin-bottom: 1rem;
}

.boar-skeleton-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
}

.boar-skeleton-row {
    display: flex;
    gap: 1rem;
    margin-bottom: 12px;
}

.boar-skeleton-kpi {
    flex: 1;
    height: 100px;
    border-radius: 12px;
}

.boar-skeleton-table-row {
    height: 48px;
    margin-bottom: 4px;
    border-radius: 6px;
}

/* Dark mode skeleton variants */
.boar-dark .boar-skeleton {
    background: linear-gradient(90deg, #2a2a2a 25%, #3a3a3a 50%, #2a2a2a 75%);
    background-size: 200% 100%;
}

/* ═══════════════════════════════════════════════════
   v3.5.0 — PROCESS TYPE BADGES & CONDITIONAL FIELDS
   ═══════════════════════════════════════════════════ */

/* Process type badge */
.boar-badge-type {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.boar-badge-type--aima {
    background: #FFF3CD;
    color: #856404;
}

.boar-badge-type--irn {
    background: #D5E8F0;
    color: #182453;
}

.boar-badge-type--certidao {
    background: #D4EDDA;
    color: #155724;
}

.boar-badge-type--outro {
    background: #E2E3E5;
    color: #383D41;
}

/* Origin badge */
.boar-badge-origin {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 10px;
    font-weight: 500;
}

.boar-badge-origin--parceria {
    background: #C8A951;
    color: #fff;
}

.boar-badge-origin--direta {
    background: #6C757D;
    color: #fff;
}

/* Needs action alert badge */
.boar-badge-action {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    background: #F8D7DA;
    color: #721C24;
    animation: boar-pulse 2s infinite;
}

@keyframes boar-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.7; }
}

/* Conditional field sections */
.boar-fields-section {
    margin-top: 20px;
    padding: 20px;
    background: #F8F9FA;
    border-radius: 8px;
    border-left: 4px solid #182453;
}

.boar-fields-section h3 {
    margin-top: 0;
    color: #182453;
    font-size: 16px;
}

.boar-fields-section--aima {
    border-left-color: #C8A951;
}

.boar-fields-section--irn {
    border-left-color: #2E75B6;
}

/* Process filters bar */
.boar-filters-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 15px;
    background: #F8F9FA;
    border-radius: 8px;
    margin-bottom: 20px;
}

.boar-filters-bar select,
.boar-filters-bar input[type="search"] {
    padding: 8px 12px;
    border: 1px solid #DEE2E6;
    border-radius: 6px;
    font-size: 13px;
    background: #fff;
    min-width: 150px;
}

.boar-filters-bar select:focus,
.boar-filters-bar input:focus {
    border-color: #C8A951;
    outline: none;
    box-shadow: 0 0 0 2px rgba(200, 169, 81, 0.2);
}

/* Document category badges */
.boar-doc-category {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    background: #E9ECEF;
    color: #495057;
}

/* Google Drive link indicator */
.boar-gdrive-indicator {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #4285F4;
    font-size: 12px;
}

.boar-gdrive-indicator::before {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 87.3 78' fill='%234285f4'%3E%3Cpath d='M6.6 66.85l14.6-25.3L35.8 66.85z'/%3E%3Cpath d='M21.2 41.55L35.8 66.85h50.9l14.6-25.3z'/%3E%3Cpath d='M57.7 0L43.1 25.3 57.7 50.6 87.3 0z'/%3E%3C/svg%3E") no-repeat center / contain;
}

/* Kanban board styles (for case management) */
.boar-kanban {
    display: flex;
    gap: 15px;
    overflow-x: auto;
    padding: 10px 0;
    -webkit-overflow-scrolling: touch;
}

.boar-kanban-column {
    min-width: 260px;
    max-width: 300px;
    background: #F8F9FA;
    border-radius: 8px;
    padding: 12px;
    flex-shrink: 0;
}

.boar-kanban-column h4 {
    margin: 0 0 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid #DEE2E6;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #6C757D;
}

.boar-kanban-card {
    background: #fff;
    border-radius: 6px;
    padding: 12px;
    margin-bottom: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    cursor: grab;
    transition: box-shadow 0.2s;
}

.boar-kanban-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.boar-kanban-card .card-ref {
    font-size: 11px;
    color: #6C757D;
    margin-bottom: 4px;
}

.boar-kanban-card .card-client {
    font-weight: 600;
    font-size: 14px;
    color: #182453;
    margin-bottom: 6px;
}

.boar-kanban-card .card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 11px;
    color: #6C757D;
}

/* Invoice/billing section */
.boar-invoice-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 15px;
}

.boar-invoice-table th,
.boar-invoice-table td {
    padding: 10px 12px;
    text-align: left;
    border-bottom: 1px solid #DEE2E6;
}

.boar-invoice-table th {
    background: #182453;
    color: #fff;
    font-size: 12px;
    text-transform: uppercase;
}

.boar-invoice-table tr:hover td {
    background: #F8F9FA;
}

.boar-invoice-total {
    text-align: right;
    padding: 15px;
    font-size: 18px;
    font-weight: 700;
    color: #182453;
}

/* ═══════════════════════════════════════════════════════
   DOCUMENT VIEWER MODAL (PDF.js + Image lightbox)
   ═══════════════════════════════════════════════════════ */
.boar-doc-viewer-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.92);
    z-index: 99999;
    display: flex;
    flex-direction: column;
    animation: boar-viewer-fadein 0.2s ease;
}

@keyframes boar-viewer-fadein {
    from { opacity: 0; }
    to { opacity: 1; }
}

.boar-viewer-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 20px;
    background: rgba(27, 42, 74, 0.95);
    color: #fff;
    flex-shrink: 0;
}

.boar-viewer-filename {
    font-size: 14px;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 40%;
}

.boar-viewer-filename small {
    color: #94a3b8;
    font-weight: 400;
}

.boar-viewer-controls {
    display: flex;
    align-items: center;
    gap: 6px;
}

.boar-viewer-controls button,
.boar-viewer-controls a {
    background: rgba(255,255,255,0.1);
    border: none;
    color: #fff;
    padding: 6px 10px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    display: flex;
    align-items: center;
    text-decoration: none;
    transition: background 0.15s;
}

.boar-viewer-controls button:hover,
.boar-viewer-controls a:hover {
    background: rgba(255,255,255,0.2);
}

.boar-viewer-btn-close {
    background: rgba(220, 38, 38, 0.3);
}

.boar-viewer-btn-close:hover {
    background: rgba(220, 38, 38, 0.6);
}

.boar-viewer-page-info,
.boar-viewer-zoom {
    font-size: 13px;
    color: #cbd5e1;
    min-width: 50px;
    text-align: center;
}

.boar-viewer-sep {
    color: #475569;
    margin: 0 4px;
}

.boar-viewer-content {
    flex: 1;
    overflow: auto;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 20px;
}

.boar-viewer-content canvas {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
    background: #fff;
}

/* ═══════════════════════════════════════════════════════
   URGENT ACTIONS WIDGET
   ═══════════════════════════════════════════════════════ */
.boar-urgent-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.boar-urgent-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-radius: 8px;
    border-left: 4px solid transparent;
    background: var(--boar-white, #fff);
    transition: background 0.15s, transform 0.1s;
}

.boar-urgent-item:hover {
    transform: translateX(2px);
}

.boar-urgent-critical {
    border-left-color: #dc2626;
    background: #fef2f2;
}

.boar-urgent-high {
    border-left-color: #f59e0b;
    background: #fffbeb;
}

.boar-urgent-medium {
    border-left-color: #3b82f6;
    background: #eff6ff;
}

.boar-urgent-icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(0,0,0,0.05);
}

.boar-urgent-critical .boar-urgent-icon { color: #dc2626; background: rgba(220,38,38,0.1); }
.boar-urgent-high .boar-urgent-icon { color: #f59e0b; background: rgba(245,158,11,0.1); }
.boar-urgent-medium .boar-urgent-icon { color: #3b82f6; background: rgba(59,130,246,0.1); }

.boar-urgent-content {
    flex: 1;
    min-width: 0;
}

.boar-urgent-content strong {
    display: block;
    font-size: 13px;
    color: #1e293b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.boar-urgent-content p {
    font-size: 12px;
    color: #64748b;
    margin: 2px 0 0;
}

.boar-urgent-days {
    flex-shrink: 0;
    font-size: 13px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 12px;
    background: rgba(0,0,0,0.06);
    color: #475569;
}

.boar-urgent-critical .boar-urgent-days {
    background: #dc2626;
    color: #fff;
}

@media (max-width: 640px) {
    .boar-viewer-filename { max-width: 30%; font-size: 12px; }
    .boar-viewer-controls { gap: 3px; }
    .boar-viewer-controls button { padding: 4px 6px; }
}

/* ═══════════════════════════════════════════════════
   DARK MODE (preparation)
   ═══════════════════════════════════════════════════ */
.boar-dark {
    --boar-bg: #0f1923;
    --boar-surface: #1a2733;
    --boar-text: #e4e8ec;
    --boar-text-secondary: #8899aa;
    --boar-border: #2a3a4a;
    --boar-sidebar-bg: #0a1219;
    --boar-primary: #c9a94e;
    --boar-primary-hover: #d4b85e;
}

/* ═══════════════════════════════════════════════════
   Sprint 3: Kanban Board
   ═══════════════════════════════════════════════════ */
.boar-kanban-board {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 16px;
  min-height: 400px;
}
.boar-kanban-column {
  flex: 1;
  min-width: 220px;
  max-width: 300px;
  background: #f8fafc;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
}
.boar-kanban-col-header {
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 12px 12px 0 0;
  background: #fff;
}
.boar-kanban-col-title {
  font-size: 13px;
  font-weight: 600;
  color: #1e293b;
}
.boar-kanban-col-count {
  font-size: 11px;
  font-weight: 700;
  color: #94a3b8;
  background: #f1f5f9;
  padding: 2px 8px;
  border-radius: 10px;
}
.boar-kanban-cards {
  flex: 1;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 60px;
  transition: background 0.2s;
}
.boar-kanban-cards.boar-kanban-drop-target {
  background: rgba(99, 102, 241, 0.06);
  border-radius: 0 0 12px 12px;
}
.boar-kanban-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 12px;
  cursor: grab;
  transition: box-shadow 0.15s, transform 0.15s;
}
.boar-kanban-card:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  transform: translateY(-1px);
}
.boar-kanban-card.boar-kanban-dragging {
  opacity: 0.4;
  transform: rotate(2deg);
}
.boar-kanban-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.boar-kanban-card-title {
  font-size: 13px;
  font-weight: 600;
  color: #1e293b;
  margin: 0 0 4px;
  line-height: 1.3;
}
.boar-kanban-card-footer {
  margin-top: 8px;
}
.boar-kanban-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--color-mid-blue, #375177);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════
   Sprint 3: Process Detail Notes
   ═══════════════════════════════════════════════════ */
.boar-notes-tabs {
  display: flex;
  border-bottom: 1px solid #e2e8f0;
  margin-bottom: 12px;
}
.boar-notes-tab {
  flex: 1;
  padding: 10px;
  font-size: 13px;
  font-weight: 600;
  border: none;
  background: none;
  cursor: pointer;
  color: #94a3b8;
  border-bottom: 2px solid transparent;
  transition: all 0.2s;
}
.boar-notes-tab.active {
  color: #1e293b;
  border-bottom-color: var(--color-gold, #c9a94e);
}
.boar-notes-textarea {
  width: 100%;
  min-height: 80px;
  padding: 10px 12px;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  font-size: 14px;
  resize: vertical;
  font-family: inherit;
}

/* ═══════════════════════════════════════════════════
   Sprint 3: Timeline Animated
   ═══════════════════════════════════════════════════ */
.boar-timeline-animated {
  position: relative;
  padding-left: 32px;
}
.boar-timeline-animated::before {
  content: '';
  position: absolute;
  left: 14px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: #e2e8f0;
}
.boar-timeline-step {
  position: relative;
  padding-bottom: 24px;
  opacity: 0;
  animation: boar-timeline-fadein 0.4s ease forwards;
}
.boar-timeline-step:nth-child(1) { animation-delay: 0.05s; }
.boar-timeline-step:nth-child(2) { animation-delay: 0.15s; }
.boar-timeline-step:nth-child(3) { animation-delay: 0.25s; }
.boar-timeline-step:nth-child(4) { animation-delay: 0.35s; }
.boar-timeline-step:nth-child(5) { animation-delay: 0.45s; }
.boar-timeline-step:nth-child(6) { animation-delay: 0.55s; }
.boar-timeline-step:nth-child(7) { animation-delay: 0.65s; }
.boar-timeline-step:nth-child(8) { animation-delay: 0.75s; }
@keyframes boar-timeline-fadein {
  from { opacity: 0; transform: translateX(-8px); }
  to { opacity: 1; transform: translateX(0); }
}
.boar-timeline-dot {
  position: absolute;
  left: -25px;
  top: 2px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.boar-timeline-dot-done {
  background: var(--color-success, #22c55e);
  color: #fff;
}
.boar-timeline-dot-current {
  background: var(--color-gold, #c9a94e);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(201, 169, 78, 0.2);
  animation: boar-pulse-dot 2s infinite;
}
@keyframes boar-pulse-dot {
  0%, 100% { box-shadow: 0 0 0 4px rgba(201, 169, 78, 0.2); }
  50% { box-shadow: 0 0 0 8px rgba(201, 169, 78, 0.1); }
}
.boar-timeline-dot-pending {
  background: #e2e8f0;
  color: #94a3b8;
}
.boar-timeline-step-name {
  font-size: 14px;
  font-weight: 600;
  color: #1e293b;
}
.boar-timeline-step-date {
  font-size: 12px;
  color: #94a3b8;
  margin-top: 2px;
}
.boar-timeline-step-expected {
  font-size: 11px;
  color: #c9a94e;
  font-style: italic;
}

/* ═══════════════════════════════════════════════════
   Sprint 3: Completion Estimate Widget
   ═══════════════════════════════════════════════════ */
.boar-estimate-widget {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px;
  background: linear-gradient(135deg, #f0f9ff 0%, #f5f3ff 100%);
  border-radius: 12px;
  border: 1px solid #e0e7ff;
}
.boar-estimate-date {
  font-size: 20px;
  font-weight: 700;
  color: #1e293b;
}
.boar-estimate-label {
  font-size: 12px;
  color: #64748b;
}
.boar-confidence-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  text-transform: uppercase;
}
.boar-confidence-high { background: #dcfce7; color: #16a34a; }
.boar-confidence-medium { background: #fef3c7; color: #d97706; }
.boar-confidence-low { background: #f1f5f9; color: #94a3b8; }

/* Responsive kanban */
@media (max-width: 768px) {
  .boar-kanban-board {
    flex-direction: column;
  }
  .boar-kanban-column {
    max-width: 100%;
    min-width: 100%;
  }
}

/* === ACCESSIBILITY === */

/* Skip navigation link — visible only on focus */
.boar-skip-link {
  position: absolute;
  top: -100px;
  left: 16px;
  z-index: 10000;
  background: var(--color-dark-navy);
  color: #fff;
  padding: 12px 24px;
  border-radius: 0 0 8px 8px;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  transition: top 0.2s ease;
}
.boar-skip-link:focus {
  top: 0;
  outline: 3px solid var(--color-gold);
  outline-offset: 2px;
}

/* Focus-visible styles for keyboard navigation */
.boar-app *:focus-visible {
  outline: 2px solid var(--color-gold);
  outline-offset: 2px;
}
.boar-btn:focus-visible {
  outline: 3px solid var(--color-gold);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(163, 128, 80, 0.2);
}
.boar-input:focus-visible,
.boar-app select:focus-visible,
.boar-app textarea:focus-visible {
  outline: 2px solid var(--color-gold);
  outline-offset: 0;
  border-color: var(--color-gold);
}
.boar-nav-item:focus-visible {
  outline: 2px solid var(--color-gold-light);
  outline-offset: -2px;
  border-radius: 8px;
}

/* Reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  .boar-app *,
  .boar-app *::before,
  .boar-app *::after {
    animation-duration: 0.01ms;
    animation-iteration-count: 1;
    transition-duration: 0.01ms;
  }
  .boar-sidebar {
    transition: none;
  }
}

/* High contrast adjustments */
@media (prefers-contrast: high) {
  .boar-card {
    border: 2px solid #333;
  }
  .boar-status-badge {
    border: 1px solid currentColor;
  }
  .boar-btn {
    border: 2px solid currentColor;
  }
}

/* ═══ Questionnaire Styles ═══ */
.boar-q-section { margin-bottom: 20px; }
.boar-q-section-title {
  font-size: 14px; font-weight: 600; color: #1e293b;
  padding-bottom: 8px; margin: 0 0 12px;
  border-bottom: 2px solid var(--color-gold, #c9a84c);
}
.boar-q-field { margin-bottom: 12px; }
.boar-q-field label { display: block; font-size: 13px; font-weight: 500; color: #334155; margin-bottom: 4px; }
.boar-field-hint { font-size: 11px; color: #94a3b8; margin: 4px 0 0; }
.boar-checkbox-label { display: flex; align-items: center; gap: 8px; font-size: 13px; color: #334155; cursor: pointer; }
.boar-checkbox-label input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--color-gold, #c9a84c); }
.boar-q-upload-wrap { position: relative; }
.boar-q-upload-btn {
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px;
  background: #f8fafc; border: 2px dashed #cbd5e1; border-radius: 8px;
  cursor: pointer; font-size: 13px; color: #475569; transition: all .2s;
}
.boar-q-upload-btn:hover { border-color: var(--color-gold, #c9a84c); background: #fffef7; }
.boar-q-file-progress { margin-top: 6px; }
.boar-q-file-progress-bar {
  width: 100%; height: 6px; background: #e2e8f0; border-radius: 3px; overflow: hidden;
}
.boar-q-file-progress-fill {
  height: 100%; background: linear-gradient(90deg, var(--color-gold, #c9a84c), #e5c56b);
  border-radius: 3px; transition: width .3s ease;
}
.boar-q-file-status { font-size: 11px; color: #22c55e; margin-top: 4px; }
.boar-q-divider { border-top: 2px solid #e2e8f0; padding-top: 16px; margin-top: 8px; }
.boar-intake-data-view { padding: 4px 0; }
.boar-intake-file-link:hover { background: #e2e8f0; }

/* ═══════════════════════════════════════════════════
   Sprint 9: Analytics Dashboard
   ═══════════════════════════════════════════════════ */
.boar-analytics-wrap { padding: 0; }
.boar-analytics-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 24px; flex-wrap: wrap; gap: 12px;
}
.boar-analytics-header h2 {
  display: flex; align-items: center; gap: 8px;
  font-size: 20px; font-weight: 700; color: #1e293b; margin: 0;
}
.boar-analytics-period .boar-select {
  padding: 8px 14px; border-radius: 8px; border: 1px solid #cbd5e1;
  font-size: 13px; background: #fff; color: #334155; cursor: pointer;
}

/* KPI Cards */
.boar-analytics-kpis {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px; margin-bottom: 24px;
}
.boar-kpi-card {
  background: #fff; border-radius: 12px; padding: 18px;
  box-shadow: 0 1px 3px rgba(0,0,0,.06); border: 1px solid #e2e8f0;
  display: flex; align-items: center; gap: 14px; transition: box-shadow .2s;
}
.boar-kpi-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.08); }
.boar-kpi-icon {
  width: 44px; height: 44px; border-radius: 10px; background: #f1f5f9;
  display: flex; align-items: center; justify-content: center; color: #64748b; flex-shrink: 0;
}
.boar-kpi-value { font-size: 22px; font-weight: 800; color: #1e293b; line-height: 1.2; }
.boar-kpi-label { font-size: 12px; color: #64748b; margin-top: 2px; }
.boar-kpi-blue .boar-kpi-icon { background: #dbeafe; color: #2563eb; }
.boar-kpi-green .boar-kpi-icon { background: #dcfce7; color: #16a34a; }
.boar-kpi-purple .boar-kpi-icon { background: #ede9fe; color: #7c3aed; }
.boar-kpi-gold .boar-kpi-icon { background: #fef3c7; color: #b45309; }
.boar-kpi-orange .boar-kpi-icon { background: #ffedd5; color: #ea580c; }

/* Charts grid */
.boar-analytics-charts {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 20px; margin-bottom: 24px;
}
.boar-analytics-card {
  background: #fff; border-radius: 12px; padding: 20px;
  box-shadow: 0 1px 3px rgba(0,0,0,.06); border: 1px solid #e2e8f0;
}
.boar-analytics-card-wide { grid-column: 1 / -1; }
.boar-analytics-card h3 {
  display: flex; align-items: center; gap: 8px;
  font-size: 15px; font-weight: 600; color: #334155;
  margin: 0 0 16px 0; padding-bottom: 12px; border-bottom: 1px solid #f1f5f9;
}

/* Bar chart */
.boar-analytics-bar-chart {
  display: flex; align-items: flex-end; gap: 6px; height: 200px; padding-top: 24px;
}
.boar-bar-col {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: flex-end; height: 100%; position: relative;
}
.boar-bar {
  width: 100%; max-width: 48px; background: linear-gradient(180deg, var(--color-gold, #c9a84c), #e5c56b);
  border-radius: 4px 4px 0 0; min-height: 4px; transition: height .4s ease;
}
.boar-bar-value {
  font-size: 9px; color: #64748b; margin-bottom: 4px; white-space: nowrap;
  text-overflow: ellipsis; overflow: hidden; max-width: 60px; text-align: center;
}
.boar-bar-label {
  font-size: 10px; color: #94a3b8; margin-top: 6px; text-align: center;
}

/* Analytics table */
.boar-analytics-table { overflow-x: auto; }
.boar-analytics-table table { width: 100%; border-collapse: collapse; font-size: 13px; }
.boar-analytics-table th {
  text-align: left; padding: 8px 10px; border-bottom: 2px solid #e2e8f0;
  font-weight: 600; color: #475569; font-size: 12px; text-transform: uppercase; letter-spacing: .3px;
}
.boar-analytics-table td { padding: 8px 10px; border-bottom: 1px solid #f1f5f9; color: #334155; }
.boar-analytics-table tr:hover td { background: #f8fafc; }
.boar-analytics-table .center { text-align: center; }
.boar-analytics-table .right { text-align: right; }

/* Funnel */
.boar-funnel { display: flex; flex-direction: column; gap: 8px; }
.boar-funnel-step { width: 100%; }
.boar-funnel-bar {
  background: linear-gradient(90deg, var(--color-gold, #c9a84c), #e5c56b);
  border-radius: 6px; padding: 10px 14px; display: flex;
  align-items: center; justify-content: space-between; min-width: 60px;
  transition: width .4s ease;
}
.boar-funnel-label { font-size: 13px; font-weight: 600; color: #1e293b; }
.boar-funnel-count { font-size: 13px; font-weight: 700; color: #1e293b; }
.boar-funnel-count small { font-weight: 400; font-size: 11px; opacity: .7; }

/* Status bars */
.boar-status-bars { display: flex; flex-direction: column; gap: 10px; }
.boar-status-bar-row { display: flex; align-items: center; gap: 10px; }
.boar-status-bar-label { font-size: 12px; color: #475569; width: 120px; flex-shrink: 0; text-align: right; }
.boar-status-bar-track {
  flex: 1; height: 22px; background: #f1f5f9; border-radius: 6px; overflow: hidden;
}
.boar-status-bar-fill {
  height: 100%; border-radius: 6px; transition: width .4s ease; min-width: 4px;
}
.boar-status-bar-count { font-size: 12px; color: #64748b; width: 80px; flex-shrink: 0; }

/* Responsive */
@media (max-width: 768px) {
  .boar-analytics-kpis { grid-template-columns: repeat(2, 1fr); }
  .boar-analytics-charts { grid-template-columns: 1fr; }
  .boar-kpi-value { font-size: 18px; }
  .boar-analytics-bar-chart { height: 150px; }
  .boar-status-bar-label { width: 90px; font-size: 11px; }
}

/* ═══════════════════════════════════════════════════
   Sprint 10: Process Type Fields & Data Import
   ═══════════════════════════════════════════════════ */

/* Type fields grid */
.boar-type-fields-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px; margin-top: 12px;
}
.boar-tf-item {
  display: flex; flex-direction: column; padding: 8px 10px;
  background: #f8fafc; border-radius: 8px; border: 1px solid #e2e8f0;
}
.boar-tf-label { font-size: 11px; color: #64748b; font-weight: 500; text-transform: uppercase; letter-spacing: .3px; }
.boar-tf-value { font-size: 13px; color: #1e293b; font-weight: 600; margin-top: 2px; }
.boar-court-history {
  background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px;
  padding: 12px; font-size: 13px; color: #334155; line-height: 1.6; margin-top: 6px;
  max-height: 200px; overflow-y: auto;
}

/* Type/origin badges */
.boar-badge-type {
  display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 12px;
  font-size: 11px; font-weight: 600; letter-spacing: .2px;
}
.boar-badge-type--judicial { background: #dbeafe; color: #1e40af; }
.boar-badge-type--irn { background: #fef3c7; color: #92400e; }
.boar-badge-type--certidao { background: #e0e7ff; color: #3730a3; }
.boar-badge-type--outro { background: #f1f5f9; color: #475569; }
.boar-badge-origin {
  display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 12px;
  font-size: 11px; font-weight: 600;
}
.boar-badge-origin--parceria { background: #dcfce7; color: #166534; }
.boar-badge-origin--direta { background: #e0e7ff; color: #3730a3; }
.boar-badge-action {
  display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 12px;
  font-size: 11px; font-weight: 600; background: #fef2f2; color: #991b1b;
}

/* Data Import Page */
.boar-import-wrap { padding: 0; }
.boar-import-wrap h2 {
  display: flex; align-items: center; gap: 8px;
  font-size: 20px; font-weight: 700; color: #1e293b; margin: 0 0 24px 0;
}
.boar-import-card {
  background: #fff; border-radius: 12px; padding: 20px;
  box-shadow: 0 1px 3px rgba(0,0,0,.06); border: 1px solid #e2e8f0;
  margin-bottom: 20px;
}
.boar-import-card h3 {
  display: flex; align-items: center; gap: 8px;
  font-size: 15px; font-weight: 600; color: #334155; margin: 0 0 8px 0;
}
.boar-import-upload { display: flex; align-items: center; margin-bottom: 12px; }
.boar-import-success {
  display: flex; align-items: center; gap: 8px; padding: 10px 14px;
  background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 8px;
  color: #166534; font-size: 13px; font-weight: 500;
}
.boar-import-error {
  display: flex; align-items: center; gap: 8px; padding: 10px 14px;
  background: #fef2f2; border: 1px solid #fecaca; border-radius: 8px;
  color: #991b1b; font-size: 13px; font-weight: 500;
}

/* GDrive indicator */
.boar-gdrive-indicator {
  display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px;
  background: #e0e7ff; color: #3730a3; border-radius: 6px; font-size: 11px;
  font-weight: 500; text-decoration: none;
}
.boar-gdrive-indicator:hover { background: #c7d2fe; }

/* Document category badge */
.boar-doc-category {
  display: inline-flex; padding: 2px 8px; border-radius: 6px;
  background: #f1f5f9; color: #475569; font-size: 11px; font-weight: 500;
}

/* ═══════════════════════════════════════════════════
   Sprint 12: Enhanced Client Dashboard
   ═══════════════════════════════════════════════════ */

/* Next Steps Panel */
.boar-next-steps-panel {
  display: flex; flex-direction: column; gap: 12px;
}
.boar-next-step-item {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px; background: #f8fafc; border-radius: 8px;
  border-left: 4px solid #c9a84c;
}
.boar-step-number {
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; min-width: 28px;
  background: #c9a84c; color: #fff; font-weight: 600;
  border-radius: 50%; font-size: 13px;
}
.boar-step-content {
  flex: 1; display: flex; flex-direction: column; gap: 4px;
}
.boar-step-text {
  margin: 0; font-size: 14px; color: #334155; font-weight: 500;
  line-height: 1.5;
}

/* Enhanced Timeline with animated current phase */
.boar-timeline-animated .boar-timeline-dot.current {
  animation: pulse-ring 2s infinite;
}
@keyframes pulse-ring {
  0% { box-shadow: 0 0 0 0 rgba(201, 168, 76, 0.7); }
  50% { box-shadow: 0 0 0 8px rgba(201, 168, 76, 0); }
  100% { box-shadow: 0 0 0 0 rgba(201, 168, 76, 0); }
}

/* Enhanced document checklist */
.boar-checklist-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 12px;
  background: #f8fafc; border-radius: 6px; border: 1px solid #e2e8f0;
  margin-bottom: 8px;
}
.boar-checklist-dot {
  display: flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; min-width: 24px;
  border-radius: 50%; font-size: 12px;
}
.boar-checklist-label {
  flex: 1; font-size: 14px; color: #334155; font-weight: 500;
}
.boar-checklist-action {
  background: #fef3c7; border-color: #fde68a;
}

/* Document status colors */
.boar-checklist-dot {
  background: #e2e8f0; color: #64748b;
}

@media (max-width: 768px) {
  .boar-type-fields-grid { grid-template-columns: 1fr 1fr; }
  .boar-next-step-item { flex-direction: column; }
  .boar-step-number { align-self: flex-start; }
}

/* === FEATURE 2: MOBILE RESPONSIVE DESIGN (Sprint 13) === */

/* Hamburger button for mobile */
.boar-mobile-toggle {
  display: none;
  position: fixed;
  top: 16px;
  left: 16px;
  z-index: 1001;
  background: var(--color-dark-navy);
  color: var(--color-white);
  border: none;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}
.boar-mobile-toggle:hover {
  background: var(--color-mid-blue);
}
.boar-mobile-toggle:active {
  transform: scale(0.95);
}

/* Table responsive wrapper */
.boar-table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-md);
}
.boar-table-responsive table {
  width: 100%;
}

@media (max-width: 768px) {
  /* Sidebar collapse and toggle */
  .boar-sidebar {
    position: fixed;
    left: -260px;
    top: 0;
    z-index: 1000;
    width: 260px;
    height: 100vh;
    transition: left var(--transition-slow);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .boar-sidebar.open {
    left: 0;
  }

  /* Main content adjusts when sidebar is closed */
  .boar-main {
    margin-left: 0;
  }

  /* Show mobile toggle button */
  .boar-mobile-toggle {
    display: flex;
  }

  /* Adjust main content padding to account for hamburger */
  .boar-content {
    padding-top: 76px;
  }

  /* Header remains fixed and sticky */
  .boar-header {
    position: sticky;
    top: 0;
    z-index: 999;
    background: var(--color-white);
    border-bottom: 1px solid var(--color-gray-200);
  }

  /* Card grid collapses to single column */
  .boar-grid-2, .boar-grid-3, .boar-grid-4 {
    grid-template-columns: 1fr;
  }

  /* Tables become scrollable */
  .boar-table-responsive {
    font-size: var(--font-size-sm);
  }
  .boar-table-responsive table th,
  .boar-table-responsive table td {
    padding: 8px 12px;
  }

  /* Process list items stack better */
  .boar-process-item {
    flex-direction: column;
  }
  .boar-process-meta {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
  }

  /* Forms on mobile */
  .boar-form-row {
    grid-template-columns: 1fr;
  }

  /* Buttons stack on mobile */
  .boar-button-group {
    flex-direction: column;
  }
  .boar-button-group button {
    width: 100%;
  }

  /* Modal adjustments */
  .boar-modal-dialog {
    width: 95vw;
    max-width: 95vw;
    max-height: 95vh;
  }

  /* Sidebar overlay when open */
  .boar-sidebar.open::after {
    content: '';
    position: fixed;
    top: 0;
    left: 260px;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    z-index: -1;
  }

  /* Analytics cards */
  .boar-analytics-grid {
    grid-template-columns: 1fr;
  }

  /* Message thread adjustments */
  .boar-message-thread {
    max-height: calc(100vh - 200px);
  }

  /* Tabs responsive */
  .boar-tabs-list {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Fix for iOS modal scrolling */
  body.boar-modal-open {
    overflow: hidden;
  }
}

/* OVERRIDE: sidebar scrolls with page instead of internal fixed scrollbar */
@media (min-width: 1025px) {
  .boar-app { align-items: flex-start; }
  .boar-sidebar { position: sticky; top: 0; height: auto; max-height: none; overflow: visible; }
  .boar-content, .boar-content { overflow: visible; }
}

/* Ticket UI refinements */
.boar-ticket-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-left:auto;}
.boar-ticket-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:#f1f5f9;color:#334155;}
.boar-ticket-status.awaiting{background:#fef3c7;color:#92400e;}
.boar-ticket-status.active{background:#dbeafe;color:#1d4ed8;}
.boar-ticket-status.archived{background:#dcfce7;color:#166534;}
.boar-message-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.boar-message-attachment{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:12px;color:#334155;text-decoration:none;}
.boar-message-attachment:hover{background:#f8fafc;}
.boar-settings-avatar-wrap{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.boar-settings-avatar-preview{width:64px;height:64px;border-radius:50%;overflow:hidden;background:#0f172a;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;}
.boar-settings-avatar-preview img{width:100%;height:100%;object-fit:cover;}
.boar-kb-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width: 900px){.boar-kb-edit-grid{grid-template-columns:1fr;}}

/* Final layout corrections */
@media (min-width:1025px){
  body.boar-app-page .boar-app{display:flex;align-items:flex-start;gap:0;}
  body.boar-app-page .boar-sidebar{position:sticky;top:0;left:auto;height:100vh;overflow-y:auto;width:256px;min-width:256px;box-sizing:border-box;}
  body.boar-app-page .boar-content, body.boar-app-page .boar-content{margin-left:0;padding:20px 24px;min-width:0;flex:1 1 auto;}
}

/* Final layout corrections */
@media (min-width:1025px){
  body.boar-app-page .boar-app{display:flex;align-items:flex-start;gap:0;}
  body.boar-app-page .boar-sidebar{position:sticky;top:0;left:auto;height:100vh;overflow-y:auto;width:256px;min-width:256px;box-sizing:border-box;}
  body.boar-app-page .boar-content, body.boar-app-page .boar-content{margin-left:0;padding:20px 24px;min-width:0;flex:1 1 auto;}
}
.boar-modal .boar-input, .boar-modal select.boar-input{width:100%;}
.boar-kb-doc-row .boar-doc-info, .boar-kb-link-row .boar-doc-info{min-width:0;}
.boar-kb-doc-row .boar-doc-info .boar-input, .boar-kb-link-row .boar-doc-info .boar-input{width:100%;}

.boar-folder-chevron.boar-open svg{transform:rotate(90deg);}
.boar-header-user-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:#375177;color:#fff;font-size:11px;font-weight:700;}
.boar-header-user-avatar img{width:100%;height:100%;object-fit:cover;display:block;}
@media (max-width: 1024px){body.boar-app-page .boar-content{width:100%;max-width:100%;}}

@media (min-width:1025px){
  body.boar-app-page .boar-sidebar{position:sticky;top:0;height:auto;max-height:none;overflow:visible;align-self:flex-start;}
  body.boar-app-page .boar-app{align-items:flex-start;}
}

/* Definitive desktop sidebar flow: no internal scrollbar, scrolls with page */
@media (min-width:1025px){
  body.boar-app-page .boar-app{display:flex;align-items:stretch;}
  body.boar-app-page .boar-sidebar,
  body.boar-app-page .boar-sidebar{
    position:relative;
    top:auto;
    left:auto;
    height:auto;
    min-height:100vh;
    max-height:none;
    overflow:visible;
    overflow-y:visible;
    align-self:stretch;
  }
  body.boar-app-page .boar-content,
  body.boar-app-page .boar-content{margin-left:0;overflow:visible;}
}

/* Round 5 desktop layout and header fixes */
body.boar-app-page .boar-app{border:none;outline:none;box-shadow:none;}
@media (min-width:1025px){
  body.boar-app-page .boar-app{display:flex;align-items:flex-start;min-height:100vh;}
  body.boar-app-page .boar-sidebar,
  body.boar-app-page .boar-sidebar{
    position:sticky;
    top:0;
    left:auto;
    height:auto;
    min-height:100vh;
    max-height:none;
    overflow:visible;
    overflow-y:visible;
    align-self:flex-start;
  }
  body.boar-app-page .boar-content,
  body.boar-app-page .boar-content{
    margin-left:0;
    padding:20px 24px;
    overflow:visible;
    flex:1 1 auto;
  }
}
.boar-header-user-group{display:inline-flex;align-items:center;gap:8px;}
.boar-header-user-group > *:not(.boar-header-user-avatar):not(.boar-logout){display:none !important;}
.boar-row-paid td{background:#f0fdf4;border-color:#86efac;}
.boar-row-paid td:first-child{box-shadow:inset 3px 0 0 #16a34a;}
.boar-table .boar-row-paid .boar-tag,
.boar-row-paid .boar-ticket-status{background:#dcfce7;color:#166534;border-color:#16a34a;}
#boar-kb-doc-list .boar-text-muted.boar-text-xs{display:none !important;}

/* Round 6 fixes */
@media (min-width: 1025px) {
  body.boar-app-page,
  body.boar-app-page .boar-app { align-items: stretch; }
  body.boar-app-page .boar-sidebar,
  body.boar-app-page .boar-sidebar {
    position: sticky;
    top: 0;
    align-self: stretch;
    min-height: 100vh;
    height: auto;
    overflow: visible;
    background: var(--color-dark-navy);
  }
  body.boar-app-page .boar-sidebar-nav { overflow: visible; }
}
.boar-messages-container{display:grid;grid-template-columns:340px minmax(0,1fr);gap:18px;min-height:640px;align-items:stretch}
.boar-conversations-list{background:#fff;border:1px solid #e2e8f0;border-radius:18px;overflow:hidden;min-height:640px}
.boar-messages-panel{background:#fff;border:1px solid #e2e8f0;border-radius:18px;min-height:640px;display:flex;flex-direction:column;overflow:hidden}
.boar-messages-header{padding:16px 18px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;gap:12px}
.boar-messages-list{padding:18px;display:flex;flex-direction:column;gap:12px;flex:1;overflow:auto;background:#f8fafc}
.boar-message-bubble{max-width:72%;padding:12px 14px;border-radius:18px;box-shadow:0 4px 12px rgba(15,23,42,.06);font-size:14px;line-height:1.45}
.boar-message-bubble.self{align-self:flex-end;background:#1e3a8a;color:#fff;border-bottom-right-radius:6px}
.boar-message-bubble.other{align-self:flex-start;background:#fff;color:#0f172a;border:1px solid #dbe3ef;border-bottom-left-radius:6px}
.boar-message-meta{font-size:11px;opacity:.75;margin-top:6px}
.boar-message-attachments{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.boar-message-attachment{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #dbe3ef;border-radius:12px;background:#fff;color:#0f172a;text-decoration:none}
.boar-message-bubble.self .boar-message-attachment{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.25);color:#fff}
.boar-messages-compose{padding:14px 18px;border-top:1px solid #e2e8f0;background:#fff}
.boar-kb-actions{display:flex;gap:8px;flex-wrap:wrap}
.boar-kb-link-row .boar-doc-info.readonly, .boar-kb-doc-row .boar-doc-info.readonly{display:block}
.boar-kb-link-row .boar-doc-info.readonly .boar-doc-name, .boar-kb-doc-row .boar-doc-info.readonly .boar-doc-name{margin:0}
.boar-client-name-highlight{display:inline-block;padding:0 .3em;border-radius:10px;background:#fff7ed;color:#9a6700;font-weight:800}
@media (max-width: 1024px){.boar-messages-container{grid-template-columns:1fr}.boar-conversations-list,.boar-messages-panel{min-height:auto}}

/* Round 8 layout final */
body.boar-app-page .boar-app{display:flex;align-items:stretch;min-height:100vh;}
body.boar-app-page .boar-sidebar{min-height:100vh;align-self:stretch;background:var(--color-dark-navy);overflow:visible;overflow-y:visible;}
body.boar-app-page .boar-sidebar-nav{overflow:visible;}
body.boar-app-page .boar-content, body.boar-app-page .boar-content{overflow:visible;min-width:0;}
.boar-grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;}
.boar-text-danger{color:#b91c1c;}
.boar-conversation-item{padding:14px 16px;border-bottom:1px solid #e2e8f0;cursor:pointer;transition:background .2s;}
.boar-conversation-item:hover{background:#f8fafc;}
.boar-conversation-item.active{background:#eff6ff;}
.boar-conversation-title{font-weight:600;margin:0 0 4px;}
.boar-conversation-subtitle{margin:0;color:#64748b;font-size:12px;}
.boar-messages-shell{display:grid;grid-template-columns:minmax(260px,340px) 1fr;gap:16px;}
@media (max-width: 1024px){.boar-messages-shell{grid-template-columns:1fr;}}

/* Round 9 layout overrides */
.boar-app{display:flex;align-items:stretch;min-height:100vh;overflow:visible;}
.boar-sidebar{position:sticky;top:0;align-self:flex-start;min-height:100vh;height:auto;overflow:visible;background:var(--color-dark-navy);}
.boar-content,.boar-content{overflow:visible;min-height:100vh;}
body.boar-app-page, body.boar-app-page .container-wrap, body.boar-app-page .main-content, body.boar-app-page .row, body.boar-app-page #ajax-content-wrap{overflow:visible;}
.boar-invoice-row.paid, .boar-status-paid, .boar-tag-paid{background:#ecfdf5;border:1px solid #22c55e;color:#166534;}
.boar-app{border:none;box-shadow:none;}
.boar-client-name-highlight{color:#0f3c68;font-weight:800;}

/* Round12 layout fixes */
.boar-app{display:flex;align-items:stretch;overflow:visible;min-height:100vh;}
.boar-sidebar{min-height:100vh;align-self:stretch;overflow:visible;background:#0f3c68;position:sticky;top:0;}
body.boar-app-page .boar-content, .boar-content{overflow:visible;}
.boar-client-greeting, .boar-hero-title{font-weight:700;letter-spacing:-0.02em;}
.boar-hero-title .boar-client-name-highlight{background:linear-gradient(transparent 65%, rgba(15,60,104,.14) 65%);padding:0 4px;border-radius:4px;}
.boar-kb-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;}
.boar-process-visual-status .boar-tag-green{background:#dcfce7;color:#166534;}
@media (max-width:1024px){.boar-sidebar{position:fixed;min-height:100vh;overflow:auto;}}

.boar-kb-actions .boar-btn[disabled]{opacity:.55;cursor:not-allowed;pointer-events:none;}
.boar-kb-actions .boar-text-xs{margin-top:4px;}

/* Knowledge base document layout improvements */
.boar-kb-doc-row-stacked{
  align-items:flex-start;
}
.boar-kb-doc-main{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.boar-kb-doc-top{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
}
.boar-kb-doc-caption{
  font-size:12px;
  font-weight:600;
  color:var(--color-gray-500);
  line-height:1.2;
}
.boar-kb-doc-top .boar-input,
.boar-kb-doc-top .boar-doc-name{
  width:100%;
  margin:0;
}
.boar-kb-doc-top .boar-doc-name{
  font-size:16px;
  font-weight:600;
  color:var(--color-dark-navy);
  line-height:1.35;
  word-break:break-word;
}
.boar-kb-doc-bottom{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.boar-kb-doc-meta{
  display:flex;
  align-items:center;
  min-height:38px;
}
.boar-kb-doc-meta .boar-text-xs{
  margin:0;
}
.boar-kb-doc-row-stacked .boar-kb-actions{
  flex:1;
  justify-content:flex-end;
  align-items:center;
}
.boar-kb-doc-row-stacked .boar-kb-actions .boar-btn{
  white-space:nowrap;
}
@media (max-width: 900px){
  .boar-kb-doc-bottom{
    flex-direction:column;
    align-items:stretch;
  }
  .boar-kb-doc-row-stacked .boar-kb-actions{
    justify-content:flex-start;
  }
}

/* Process health, unified activity and enhanced document center */
.boar-process-health-card,
.boar-process-task-summary-card,
.boar-unified-activity-card,
.boar-process-pending-card {
  border: 1px solid #e2e8f0;
  box-shadow: 0 8px 20px rgba(15,23,42,.04);
}
.boar-process-health-card .boar-tag,
.boar-process-task-summary-card .boar-tag,
.boar-unified-activity-card .boar-tag,
.boar-process-pending-card .boar-tag {
  font-weight: 700;
}
.boar-process-meta-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit,minmax(170px,1fr));
  gap: 12px;
  margin: 14px 0 18px;
}
.boar-process-overview-grid,
.boar-process-content-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit,minmax(300px,1fr));
  gap: 14px;
}
.boar-process-section-label {
  margin: 18px 0 10px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #475569;
}

/* ═══ Google Drive File Browser Styles ═══ */
.boar-gdrive-container {
  background: #fff;
  border-radius: 8px;
  padding: 16px;
  border: 1px solid #e2e8f0;
}

.boar-gdrive-browser {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.boar-breadcrumb {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
  padding: 8px 12px;
  background: #f8fafc;
  border-radius: 6px;
  font-size: 13px;
  border: 1px solid #e2e8f0;
}

.boar-breadcrumb-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #0f63cc;
  text-decoration: none;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
  transition: background 0.2s;
}

.boar-breadcrumb-item:hover {
  background: #e0e7ff;
  color: #0c47a1;
}

.boar-gdrive-item-list {
  display: flex;
  flex-direction: column;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  overflow: hidden;
}

.boar-gdrive-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px;
  border-bottom: 1px solid #e2e8f0;
  transition: background 0.15s;
}

.boar-gdrive-item:last-child {
  border-bottom: none;
}

.boar-gdrive-item:hover {
  background: #f8fafc;
}

.boar-gdrive-item-icon {
  flex: 0 0 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #64748b;
}

.boar-gdrive-item-content {
  flex: 1;
  min-width: 0;
}

.boar-gdrive-item-name {
  font-weight: 500;
  color: #0f172a;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.boar-gdrive-item-meta {
  font-size: 12px;
  color: #64748b;
  margin-top: 2px;
}

.boar-gdrive-item-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.boar-gdrive-folder-empty {
  padding: 24px;
  text-align: center;
  color: #94a3b8;
  font-size: 13px;
}

.boar-gdrive-browser-error {
  padding: 16px;
  background: #fee2e2;
  border: 1px solid #fca5a5;
  border-radius: 6px;
  color: #991b1b;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 8px;
}

@media (max-width: 768px) {
  .boar-gdrive-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .boar-gdrive-item-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .boar-gdrive-item-actions .boar-btn {
    flex: 1;
    min-width: 80px;
  }
}
