/* ===== AI Summit Inspired Design System ===== */
/* Inspired by India AI Impact Summit 2026 */

/* Import Font */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');

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

/* Vendor payments */
.vendor-payments-page .vendor-payment-form-card .card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.vendor-payment-metric-strip {
  display: flex;
  align-items: stretch;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.vendor-payment-metric {
  min-width: 170px;
  padding: 10px 12px;
  border: 1px solid var(--neutral-200);
  border-radius: 10px;
  background: #fff;
}

.vendor-payment-metric-primary {
  background: var(--primary-pale);
  border-color: var(--primary-lighter);
}

.vendor-payment-table-container {
  border-radius: 0;
  border-left: 0;
  border-right: 0;
}

.vendor-payment-table th {
  white-space: nowrap;
}

.vendor-payment-table td {
  vertical-align: top;
}

.vendor-invoice-row td {
  background: #fff;
  border-bottom: 0;
}

.vendor-chunks-row td {
  padding-top: 0;
  background: #fbfbfb;
}

.vendor-payment-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  min-width: 120px;
}

.vendor-payment-actions .btn {
  justify-content: center;
}

.bulk-select-control,
.vendor-payment-chunk-select {
  display: inline-flex;
  align-items: center;
  color: var(--neutral-700);
  font-size: 0.875rem;
  font-weight: 500;
}

.bulk-select-control {
  gap: 8px;
  min-height: 34px;
  padding: 7px 11px;
  border: 1px solid var(--neutral-200);
  border-radius: 999px;
  background: #fff;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.bulk-select-control:hover {
  border-color: var(--primary-lighter);
  background: var(--primary-pale);
}

.bulk-select-control:has(input:disabled) {
  cursor: not-allowed;
  opacity: 0.6;
}

.vendor-payment-chunk-select {
  justify-content: center;
  gap: 0;
}

.bulk-select-control input,
.vendor-payment-chunk-select input {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--primary);
}

.vendor-payment-chunks {
  padding: 10px 12px 14px;
  border: 1px solid var(--neutral-200);
  border-radius: 12px;
  background: #fff;
}

.vendor-payment-chunks-title {
  margin-bottom: 8px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--neutral-600);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.vendor-payment-chunk-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.vendor-payment-chunk-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--neutral-200);
  border-radius: 10px;
  background: var(--neutral-50);
}

.vendor-payment-chunk-heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  color: var(--neutral-700);
}

.vendor-payment-chunk-amount {
  margin-top: 4px;
  font-size: 1rem;
  font-weight: 600;
  color: var(--neutral-900);
}

.vendor-payment-empty-chunks {
  padding: 12px;
  border: 1px dashed var(--neutral-300);
  border-radius: 10px;
  background: var(--neutral-50);
  color: var(--neutral-500);
  font-size: 0.875rem;
}

@media (max-width: 900px) {
  .vendor-payments-page .vendor-payment-form-card .card-header {
    flex-direction: column;
  }

  .vendor-payment-chunk-card {
    align-items: flex-start;
    flex-direction: column;
  }
}

:root {
  --app-font: "Poppins", "Segoe UI", Arial, sans-serif;
  /* Primary Colors - Warm Palette */
  --primary: #C0582A;
  --primary-dark: #9A4621;
  --primary-light: #D47A51;
  --primary-lighter: #E8A485;
  --primary-pale: #FFF5F0;

  /* Accent Colors */
  --accent-coral: #E86C5D;
  --accent-amber: #F4A261;
  --accent-cream: #FFF8F3;

  /* Neutral Colors */
  --neutral-50: #FAFAFA;
  --neutral-100: #F5F5F5;
  --neutral-200: #E5E5E5;
  --neutral-300: #D4D4D4;
  --neutral-400: #A3A3A3;
  --neutral-500: #737373;
  --neutral-600: #525252;
  --neutral-700: #404040;
  --neutral-800: #262626;
  --neutral-900: #171717;

  /* Semantic Colors */
  --success: #10B981;
  --success-light: #D1FAE5;
  --error: #EF4444;
  --error-light: #FEE2E2;
  --warning: #F59E0B;
  --warning-light: #FEF3C7;
  --info: #3B82F6;
  --info-light: #DBEAFE;

  /* Typography Scale */
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;

  /* Spacing Scale */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;

  /* Border Radius */
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-2xl: 1.5rem;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);

  /* Transitions */
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 200ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* BASE STYLES */
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: var(--app-font);
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--neutral-800);
  background-color: var(--neutral-50);
  font-weight: 400;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--app-font);
  font-weight: 600;
  line-height: 1.2;
  color: var(--neutral-900);
}

/* LAYOUT */
.main-layout {
  margin-left: 280px;
  min-height: 100vh;
  background-color: var(--neutral-50);
}

.main-content {
  padding: var(--space-8);
  max-width: 1600px;
  margin: 0 auto;
}

/* SIDEBAR */
.sidebar {
  width: 280px;
  height: 100vh;
  background: linear-gradient(180deg, var(--primary) 0%, var(--primary-dark) 100%);
  display: flex;
  flex-direction: column;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 100;
  box-shadow: var(--shadow-xl);
}

.sidebar-header {
  padding: var(--space-6) var(--space-5);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.1);
}

.sidebar-logo-container {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.sidebar-logo-icon {
  font-size: 2rem;
  color: white;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
}

.sidebar-logo {
  font-family: 'Fraunces', serif;
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0;
  color: white;
  line-height: 1.2;
  letter-spacing: -0.5px;
}

.sidebar-subtitle {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.6875rem;
  color: rgba(255, 255, 255, 0.75);
  margin: var(--space-1) 0 0 0;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.sidebar-nav {
  flex: 1 1;
  padding: var(--space-4) 0;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.3) transparent;
}

.sidebar-nav::-webkit-scrollbar {
  width: 6px;
}

.sidebar-nav::-webkit-scrollbar-track {
  background: transparent;
}

.sidebar-nav::-webkit-scrollbar-thumb {
  background-color: rgba(255, 255, 255, 0.3);
  border-radius: var(--radius-full);
}

.sidebar-category {
  margin-bottom: var(--space-2);
}

.sidebar-category-header,
.sidebar-category-header-static {
  display: flex;
  align-items: center;
  padding: var(--space-3) var(--space-5);
  gap: var(--space-2);
  font-family: 'DM Sans', sans-serif;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: rgba(255, 255, 255, 0.6);
}

.sidebar-category-header {
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  transition: color var(--transition-fast);
}

.sidebar-category-header:hover {
  color: rgba(255, 255, 255, 0.9);
}

.sidebar-category-arrow {
  font-size: 0.625rem;
  transition: transform var(--transition-base);
  transform: rotate(-90deg);
}

.sidebar-category-arrow-expanded {
  transform: rotate(0deg);
}

.sidebar-category-items {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
}

.sidebar-category-items-expanded {
  max-height: 1000px;
}

.sidebar-link {
  display: flex;
  align-items: center;
  padding: var(--space-3) var(--space-5) var(--space-3) 3rem;
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  transition: all var(--transition-fast);
  position: relative;
  margin: 0 var(--space-2);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 500;
}

.sidebar-link:hover {
  background: rgba(255, 255, 255, 0.1);
  color: white;
  transform: translateX(2px);
}

.sidebar-link-active {
  background: rgba(255, 255, 255, 0.15);
  color: white;
  font-weight: 600;
}

.sidebar-link-active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 60%;
  background: white;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  box-shadow: 0 0 12px rgba(255, 255, 255, 0.5);
}

.sidebar-icon {
  font-size: 1.125rem;
  margin-right: var(--space-3);
}

.sidebar-text {
  font-size: var(--text-sm);
  flex: 1 1;
}

.sidebar-footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.15);
}

.sidebar-footer-text {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.6);
  font-weight: 500;
}

/* CARDS */
.card {
  background: white;
  border-radius: var(--radius-xl);
  border: 1px solid var(--neutral-200);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--transition-base);
}

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

.card-header {
  padding: var(--space-6);
  border-bottom: 1px solid var(--neutral-200);
  background: linear-gradient(to bottom, white 0%, var(--neutral-50) 100%);
}

.card-title {
  font-family: 'Fraunces', serif;
  font-size: var(--text-2xl);
  font-weight: 600;
  margin: 0;
  color: var(--neutral-900);
}

.card-description {
  font-size: var(--text-sm);
  color: var(--neutral-600);
  margin: var(--space-2) 0 0 0;
  line-height: 1.6;
}

.card-content {
  padding: var(--space-6);
}

.bank-upload-generator-card,
.bank-upload-generator-card .card-content {
  overflow: visible;
}

/* My Workspace */
.my-workspace-page {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.my-workspace-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  grid-gap: var(--space-6);
  gap: var(--space-6);
  align-items: stretch;
  padding: clamp(24px, 4vw, 40px);
  border: 1px solid var(--neutral-200);
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.16), transparent 34%),
    linear-gradient(135deg, #ffffff 0%, #f8fbff 52%, #f3f7ff 100%);
  box-shadow: var(--shadow-sm);
}

.my-workspace-hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.my-workspace-eyebrow {
  margin: 0 0 var(--space-2);
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--primary-600);
}

.my-workspace-hero h1 {
  margin: 0;
  color: var(--neutral-950);
  font-family: 'Fraunces', serif;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 1.05;
}

.my-workspace-hero__content > p:not(.my-workspace-eyebrow) {
  max-width: 680px;
  margin: var(--space-4) 0 0;
  color: var(--neutral-600);
  font-size: var(--text-base);
  line-height: 1.7;
}

.my-workspace-hero__stats {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: var(--space-3);
  gap: var(--space-3);
}

.my-workspace-stat {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 108px;
  padding: var(--space-5);
  border: 1px solid rgba(226, 232, 240, 0.9);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
}

.my-workspace-stat span {
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--neutral-500);
}

.my-workspace-stat strong {
  margin-top: var(--space-2);
  color: var(--neutral-950);
  font-size: var(--text-xl);
}

.my-workspace-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: var(--space-4);
  gap: var(--space-4);
}

.my-workspace-card {
  position: relative;
  min-height: 220px;
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.my-workspace-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: var(--primary-500);
}

.my-workspace-card:hover {
  transform: translateY(-2px);
  border-color: var(--primary-200);
  box-shadow: var(--shadow-md);
}

.my-workspace-card .card-content {
  height: 100%;
  padding: var(--space-5);
}

.my-workspace-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.my-workspace-card__top span,
.my-workspace-card__top strong {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 var(--space-3);
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.my-workspace-card__top span {
  color: var(--neutral-700);
  background: var(--neutral-100);
}

.my-workspace-card__top strong {
  color: var(--primary-700);
  background: var(--primary-50);
}

.my-workspace-card h3 {
  margin: 0;
  color: var(--neutral-950);
  font-size: var(--text-xl);
  font-weight: 800;
}

.my-workspace-card p {
  min-height: 70px;
  margin: var(--space-3) 0 0;
  color: var(--neutral-600);
  font-size: var(--text-sm);
  line-height: 1.65;
}

.my-workspace-card__footer {
  margin-top: var(--space-5);
}

.my-workspace-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 40px;
  padding: 0 var(--space-4);
  border: 1px solid var(--neutral-200);
  border-radius: var(--radius-lg);
  color: var(--neutral-900);
  background: #ffffff;
  font-size: var(--text-sm);
  font-weight: 800;
  text-decoration: none;
  transition: all var(--transition-base);
}

.my-workspace-card__link:hover {
  border-color: var(--primary-300);
  color: var(--primary-700);
  background: var(--primary-50);
}

.my-workspace-card__link span {
  transition: transform var(--transition-base);
}

.my-workspace-card__link:hover span {
  transform: translateX(3px);
}

.my-workspace-card--attendance::before { background: #2563eb; }
.my-workspace-card--profile::before { background: #7c3aed; }
.my-workspace-card--leave::before { background: #059669; }
.my-workspace-card--appraisal::before { background: #4f46e5; }
.my-workspace-card--reimbursement::before { background: #ea580c; }
.my-workspace-card--projects::before { background: #0891b2; }
.my-workspace-card--team::before { background: #be123c; }

.my-appraisal-page {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.my-appraisal-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: var(--space-4);
  gap: var(--space-4);
}

.my-appraisal-summary > .card {
  border-radius: var(--radius-xl);
}

.my-appraisal-summary > .card .card-content {
  padding: var(--space-4);
}

.my-appraisal-summary__item span {
  display: block;
  color: var(--neutral-500);
  font-size: var(--font-size-xs);
  font-weight: 600;
}

.my-appraisal-summary__item strong {
  display: block;
  margin-top: 6px;
  color: var(--foreground);
  font-size: var(--font-size-xl);
  font-weight: 700;
  line-height: 1;
}

.my-appraisal-summary__item {
  min-width: 0;
}

.my-appraisal-mode-tabs {
  display: flex;
  width: -moz-fit-content;
  width: fit-content;
  gap: 4px;
  flex-wrap: wrap;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--neutral-100);
  padding: 4px;
}

.my-appraisal-mode-tabs button {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border: 0;
  border-radius: var(--radius-lg);
  padding: 8px 13px;
  font-size: var(--font-size-sm);
  font-weight: 600;
  box-shadow: none;
}

.my-appraisal-mode-tabs .btn-primary {
  background: #fff;
  color: var(--primary);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.12);
}

.my-appraisal-mode-tabs .btn-secondary {
  background: transparent;
  color: var(--neutral-700);
}

.my-appraisal-mode-tabs button strong,
.my-appraisal-filter-tabs button strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  background: var(--neutral-100);
  color: var(--neutral-700);
  font-size: var(--font-size-xs);
  font-weight: 600;
}

.my-appraisal-mode-tabs .btn-primary strong {
  background: var(--primary-50);
  color: var(--primary);
}

.my-appraisal-monitoring-banner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4);
  border: 1px solid rgba(180, 83, 9, 0.28);
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, #fffbeb 0%, #fff7ed 100%);
  color: #78350f;
  box-shadow: 0 10px 24px rgba(180, 83, 9, 0.08);
}

.my-appraisal-monitoring-banner strong,
.my-appraisal-monitoring-card strong {
  display: block;
  color: #7c2d12;
  font-weight: 800;
}

.my-appraisal-monitoring-banner p,
.my-appraisal-monitoring-card p {
  margin: 4px 0 0;
  color: #92400e;
  font-size: var(--font-size-sm);
  line-height: 1.5;
}

.my-appraisal-monitoring-banner__actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
  flex-shrink: 0;
}

.my-appraisal-monitoring-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border: 1px dashed rgba(180, 83, 9, 0.4);
  border-radius: var(--radius-lg);
  background: #fffbeb;
}

.my-appraisal-group-preview {
  margin-top: var(--space-4);
  border: 1px dashed var(--border);
  border-radius: var(--radius-lg);
  background: var(--neutral-50);
  padding: var(--space-3);
}

.my-appraisal-group-preview p {
  margin: 4px 0 var(--space-3);
  color: var(--muted-foreground);
  font-size: var(--font-size-sm);
}

.my-appraisal-timer {
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--primary-100);
  border-radius: var(--radius-xl);
  background: var(--primary-50);
  color: var(--primary);
}

.my-appraisal-timer span {
  font-size: var(--font-size-sm);
  font-weight: 700;
}

.my-appraisal-timer strong {
  font-size: var(--font-size-xl);
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.my-appraisal-timer--expired {
  border-color: #fecaca;
  background: #fef2f2;
  color: #b91c1c;
}

.my-appraisal-start-panel {
  display: grid;
  grid-gap: var(--space-3);
  gap: var(--space-3);
  padding: var(--space-6);
  border: 1px solid rgba(180, 83, 9, 0.24);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at top right, rgba(251, 191, 36, 0.22), transparent 28%),
    #fffaf0;
  color: #78350f;
}

.my-appraisal-start-panel strong {
  color: #7c2d12;
  font-size: var(--font-size-lg);
  font-weight: 800;
}

.my-appraisal-start-panel p {
  max-width: 680px;
  margin: 0;
  color: #92400e;
  line-height: 1.55;
}

.my-appraisal-start-panel .btn {
  width: -moz-fit-content;
  width: fit-content;
}

.my-appraisal-pause-overlay {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  border-radius: 22px;
  background: rgba(255, 251, 235, 0.92);
  -webkit-backdrop-filter: blur(3px);
          backdrop-filter: blur(3px);
}

.my-appraisal-pause-overlay > div {
  width: min(520px, 100%);
  padding: var(--space-6);
  border: 1px solid rgba(180, 83, 9, 0.28);
  border-radius: var(--radius-xl);
  background: #fff;
  text-align: center;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.14);
}

.my-appraisal-pause-overlay strong {
  display: block;
  color: #7c2d12;
  font-size: var(--font-size-lg);
  font-weight: 800;
}

.my-appraisal-pause-overlay p {
  margin: var(--space-2) 0 var(--space-4);
  color: #92400e;
}

.my-appraisal-shell {
  display: grid;
  grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
  grid-gap: var(--space-4);
  gap: var(--space-4);
  align-items: start;
}

.my-appraisal-sidebar,
.my-appraisal-detail {
  min-height: 0;
}

.my-appraisal-sidebar {
  position: -webkit-sticky;
  position: sticky;
  top: 88px;
}

.my-appraisal-sidebar,
.my-appraisal-detail {
  border-radius: 22px;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.05);
}

.my-appraisal-sidebar .card-content,
.my-appraisal-detail .card-content {
  padding: var(--space-4);
}

.my-appraisal-sidebar__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.my-appraisal-filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.my-appraisal-filter-tabs button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 11px;
  font-size: var(--font-size-sm);
  font-weight: 600;
  line-height: 1.2;
}

.my-appraisal-panel-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.my-appraisal-sidebar__header .my-appraisal-panel-title {
  margin-bottom: 0;
}

.my-appraisal-panel-title span {
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: var(--neutral-900);
}

.my-appraisal-panel-title p {
  margin: 3px 0 0;
  color: var(--neutral-500);
  font-size: var(--font-size-xs);
  line-height: 1.35;
}

.my-appraisal-panel-title strong {
  min-width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-50);
  color: var(--primary);
  font-size: var(--font-size-xs);
  font-weight: 700;
}

.my-appraisal-task-list {
  max-height: calc(100vh - 268px);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-right: 4px;
}

.my-appraisal-task-group {
  display: grid;
  grid-gap: var(--space-2);
  gap: var(--space-2);
}

.my-appraisal-task-group__title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-1);
  color: var(--neutral-600);
  font-size: var(--font-size-xs);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.review-project-picker {
  display: grid;
  grid-gap: var(--space-2);
  gap: var(--space-2);
  padding: var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: #fff;
}

.review-project-picker__title {
  color: var(--neutral-600);
  font-size: var(--font-size-xs);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.review-project-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--neutral-50);
  padding: var(--space-2) var(--space-3);
  color: var(--neutral-800);
  font-size: var(--font-size-sm);
  font-weight: 700;
  text-align: left;
  cursor: pointer;
}

.review-project-option--active {
  border-color: var(--primary);
  background: var(--primary-50);
  color: var(--primary);
}

.review-project-option__meta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.review-project-option__done {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #16a34a;
  box-shadow: 0 0 0 3px #dcfce7;
}

.my-appraisal-task {
  width: 100%;
  border: 1px solid transparent;
  border-radius: var(--radius-xl);
  background: var(--neutral-50);
  padding: var(--space-3);
  text-align: left;
  cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);
}

.my-appraisal-task:hover,
.my-appraisal-task--active {
  border-color: var(--primary);
  background: var(--primary-50);
  box-shadow: inset 3px 0 0 var(--primary);
}

.my-appraisal-task__name {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--neutral-900);
  line-height: 1.25;
}

.my-appraisal-task__meta {
  margin-top: 4px;
  font-size: var(--font-size-xs);
  color: var(--neutral-500);
}

.my-appraisal-task__footer {
  margin-top: var(--space-2);
  display: flex;
  justify-content: space-between;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--neutral-600);
}

.my-appraisal-task__footer strong {
  color: var(--primary);
  font-weight: 700;
}

.my-appraisal-detail {
  position: relative;
}

.my-appraisal-detail__header {
  margin-bottom: var(--space-4);
  padding: var(--space-4);
  background: linear-gradient(135deg, #f8fafc, #fff);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
}

.my-appraisal-detail__header .card-title {
  font-size: var(--font-size-base);
  font-weight: 700;
}

.my-appraisal-detail__header .text-sm {
  font-size: var(--font-size-xs);
}

.my-appraisal-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.my-appraisal-section-tabs {
  display: flex;
  width: 100%;
  gap: var(--space-4);
  overflow-x: auto;
  border-bottom: 1px solid var(--border);
  background: transparent;
  padding: 0;
}

.my-appraisal-section-tab {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border: 0;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  background: transparent;
  color: var(--neutral-500);
  padding: 0 0 10px;
  font-size: var(--font-size-sm);
  font-weight: 600;
  white-space: nowrap;
  cursor: pointer;
  transition: border-color var(--transition-fast), color var(--transition-fast);
}

.my-appraisal-section-tab strong {
  min-width: 20px;
  height: 20px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--neutral-100);
  color: var(--neutral-600);
  font-size: var(--font-size-xs);
  font-weight: 600;
}

.my-appraisal-section-tab--active {
  border-bottom-color: var(--primary);
  background: transparent;
  color: var(--primary);
  box-shadow: none;
}

.my-appraisal-section-tab--active strong {
  background: var(--primary-50);
  color: var(--primary);
}

.my-appraisal-section-tab:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.my-appraisal-question-section {
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: #fff;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.my-appraisal-question-section__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  border-bottom: 1px solid var(--border);
  background: #f8fafc;
  padding: var(--space-3) var(--space-4);
}

.my-appraisal-question-section__header h3 {
  margin: 0;
  color: var(--neutral-900);
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.my-appraisal-question-section__header span {
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  color: var(--neutral-600);
  padding: 4px 9px;
  font-size: var(--font-size-xs);
  font-weight: 600;
  white-space: nowrap;
}

.my-appraisal-question-section__body {
  display: grid;
  grid-gap: 0;
  gap: 0;
  padding: 0;
}

.my-appraisal-question {
  border: 0;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  padding: var(--space-4);
  background: #fff;
}

.my-appraisal-question:last-child {
  border-bottom: 0;
}

.my-appraisal-question .form-label {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  grid-gap: var(--space-2);
  gap: var(--space-2);
  align-items: start;
  margin-bottom: var(--space-3);
  color: var(--neutral-900);
  font-size: var(--font-size-sm);
  font-weight: 600;
  line-height: 1.4;
}

.my-appraisal-question .form-label span {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--neutral-100);
  color: var(--neutral-600);
  font-size: var(--font-size-xs);
  font-weight: 700;
}

.my-appraisal-question .form-textarea {
  min-height: 88px;
  resize: vertical;
}

.my-appraisal-question .form-input:disabled,
.my-appraisal-question .form-select:disabled,
.my-appraisal-question .form-textarea:disabled {
  background: var(--neutral-50);
  color: var(--neutral-700);
  cursor: not-allowed;
}

.my-appraisal-note {
  margin-top: var(--space-2);
  color: var(--neutral-600);
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.my-appraisal-actions {
  position: -webkit-sticky;
  position: sticky;
  bottom: 0;
  z-index: 4;
  display: flex;
  justify-content: flex-end;
  padding: var(--space-3) 0 0;
  background: linear-gradient(to top, #fff 72%, rgba(255, 255, 255, 0));
}

.my-appraisal-secondary-actions {
  margin-top: var(--space-3);
  display: flex;
  justify-content: flex-end;
}

.review-allocation-panel {
  margin-bottom: var(--space-4);
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: #f8fafc;
}

.review-allocation-panel__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.review-allocation-panel__header strong {
  display: block;
  color: var(--neutral-900);
  font-weight: 800;
}

.review-allocation-panel__header p {
  margin: 4px 0 0;
  color: var(--neutral-600);
  font-size: var(--font-size-sm);
}

.review-allocation-list {
  display: grid;
  grid-gap: var(--space-2);
  gap: var(--space-2);
}

.review-allocation-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px 110px;
  align-items: end;
  grid-gap: var(--space-3);
  gap: var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: #fff;
}

.review-allocation-row--active {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-50);
}

.review-allocation-row label {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  font-size: var(--font-size-xs);
  color: var(--neutral-600);
}

.questionnaire-builder {
  display: grid;
  grid-gap: var(--space-4);
  gap: var(--space-4);
}

.questionnaire-list-title {
  color: var(--neutral-900);
  font-size: var(--font-size-base);
  font-weight: 600;
}

.questionnaire-section-tabs {
  display: flex;
  gap: var(--space-2);
  overflow-x: auto;
  padding-bottom: var(--space-1);
}

.questionnaire-stage-builder {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface-muted);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}

.questionnaire-stage-list,
.questionnaire-group-list {
  display: grid;
  grid-gap: var(--space-3);
  gap: var(--space-3);
}

.questionnaire-stage-item,
.questionnaire-group-item {
  display: grid;
  grid-gap: var(--space-2);
  gap: var(--space-2);
  align-items: center;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
  padding: var(--space-2);
}

.questionnaire-stage-item {
  grid-template-columns: minmax(150px, 1fr) minmax(140px, 0.9fr) minmax(160px, 1fr) minmax(180px, 1fr) auto auto auto;
}

.questionnaire-group-item {
  grid-template-columns: minmax(160px, 1fr) minmax(180px, 1fr) auto auto auto;
}

.questionnaire-builder-headings {
  background: transparent;
  border-color: transparent;
  color: var(--muted-foreground);
  font-size: var(--font-size-xs);
  font-weight: 700;
  padding-top: 0;
  padding-bottom: 0;
  text-transform: uppercase;
}

.questionnaire-stage-item--active {
  border-color: var(--primary);
}

.questionnaire-stage-item__label {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  border: 0;
  background: transparent;
  color: var(--foreground);
  font-weight: 600;
  text-align: left;
  cursor: pointer;
}

.questionnaire-stage-item__label strong {
  min-width: 24px;
  height: 24px;
  border-radius: 999px;
  background: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
}

.questionnaire-section-tab {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: #fff;
  padding: 8px 11px;
  color: var(--neutral-600);
  font-size: var(--font-size-sm);
  font-weight: 500;
  white-space: nowrap;
}

.questionnaire-section-tab strong {
  min-width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--neutral-100);
  color: var(--neutral-600);
  font-size: var(--font-size-xs);
  font-weight: 600;
}

.questionnaire-section-tab--active {
  border-color: var(--primary);
  background: var(--primary-50);
  color: var(--primary);
}

.questionnaire-section-tab--active strong {
  background: #fff;
  color: var(--primary);
}

.questionnaire-section-tab--add {
  border-style: dashed;
  color: var(--primary);
}

.questionnaire-section-editor {
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: #fff;
  padding: var(--space-3);
}

.questionnaire-section-editor__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-gap: var(--space-3);
  gap: var(--space-3);
  align-items: end;
  margin-bottom: var(--space-4);
}

.questionnaire-question-list {
  display: grid;
  grid-gap: var(--space-2);
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.questionnaire-question-row {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) 150px 110px auto;
  grid-gap: var(--space-2);
  gap: var(--space-2);
  align-items: start;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--neutral-50);
  padding: var(--space-2);
}

.questionnaire-question-row__main {
  display: grid;
  grid-gap: var(--space-2);
  gap: var(--space-2);
}

.questionnaire-required-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 40px;
  color: var(--neutral-700);
  font-size: var(--font-size-sm);
}

.questionnaire-options-input {
  grid-column: 1 / -1;
  min-height: 72px;
}

.questionnaire-preview {
  display: grid;
  grid-gap: var(--space-3);
  gap: var(--space-3);
}

.questionnaire-view-summary {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.questionnaire-view-summary div {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--neutral-50);
  padding: 7px 10px;
  color: var(--neutral-700);
  font-size: var(--font-size-sm);
}

.questionnaire-view-summary strong {
  color: var(--neutral-500);
  font-size: var(--font-size-xs);
  font-weight: 600;
}

.questionnaire-preview-section {
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: #fff;
  overflow: hidden;
}

.questionnaire-preview-stage {
  display: grid;
  grid-gap: var(--space-2);
  gap: var(--space-2);
}

.questionnaire-preview-stage > h3 {
  margin: 0;
  color: var(--neutral-700);
  font-size: var(--font-size-sm);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.questionnaire-preview-section__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  border-bottom: 1px solid var(--border);
  background: var(--neutral-50);
  padding: var(--space-3);
}

.questionnaire-preview-section__header h3 {
  margin: 0;
  color: var(--neutral-800);
  font-size: var(--font-size-base);
  font-weight: 600;
}

.questionnaire-preview-section__header p {
  margin: 4px 0 0;
  color: var(--muted-foreground);
  font-size: var(--font-size-sm);
}

.questionnaire-preview-section__header span {
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--border);
  color: var(--neutral-600);
  padding: 5px 9px;
  font-size: var(--font-size-xs);
  font-weight: 500;
  white-space: nowrap;
}

.questionnaire-preview-table {
  display: grid;
}

.questionnaire-preview-question {
  display: grid;
  grid-template-columns: 36px minmax(260px, 1fr) minmax(220px, auto);
  grid-gap: var(--space-3);
  gap: var(--space-3);
  align-items: start;
  border-bottom: 1px solid var(--border);
  background: #fff;
  padding: var(--space-3);
}

.questionnaire-preview-question:last-child {
  border-bottom: 0;
}

.questionnaire-preview-question__number {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--neutral-100);
  color: var(--neutral-500);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  font-weight: 600;
}

.questionnaire-preview-question__title {
  color: var(--neutral-800);
  font-weight: 500;
  line-height: 1.4;
}

.questionnaire-preview-help {
  margin: 4px 0 0;
  color: var(--muted-foreground);
  font-size: var(--font-size-sm);
}

.questionnaire-preview-question__meta,
.questionnaire-preview-options {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.questionnaire-preview-options {
  margin-top: var(--space-2);
}

.questionnaire-preview-question__meta {
  justify-content: flex-end;
}

.questionnaire-preview-question__meta span,
.questionnaire-preview-options span {
  border-radius: 999px;
  background: var(--neutral-100);
  color: var(--neutral-600);
  padding: 4px 8px;
  font-size: var(--font-size-xs);
  font-weight: 500;
}

@media (max-width: 1024px) {
  .my-appraisal-summary {
    grid-template-columns: 1fr;
  }

  .my-appraisal-shell {
    grid-template-columns: 1fr;
  }

  .my-appraisal-monitoring-banner,
  .my-appraisal-monitoring-card {
    flex-direction: column;
  }

  .my-appraisal-monitoring-banner__actions {
    justify-content: flex-start;
  }

  .my-appraisal-sidebar {
    position: static;
  }

  .my-appraisal-task-list {
    max-height: 320px;
  }

  .questionnaire-section-editor__header,
  .questionnaire-question-row,
  .questionnaire-preview-question {
    grid-template-columns: 1fr;
  }

  .questionnaire-preview-question__meta {
    justify-content: flex-start;
  }

}

@media (max-width: 1024px) {
  .my-workspace-hero {
    grid-template-columns: 1fr;
  }

  .my-workspace-hero__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .my-workspace-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .my-workspace-hero {
    padding: var(--space-5);
    border-radius: 22px;
  }

  .my-workspace-hero__stats,
  .my-workspace-grid {
    grid-template-columns: 1fr;
  }

  .my-workspace-card p {
    min-height: auto;
  }
}

/* SETTINGS */
.settings-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(300px, 1fr);
  grid-gap: var(--space-6);
  gap: var(--space-6);
  align-items: start;
}

.settings-main,
.settings-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.settings-soft-panel {
  border: 1px solid var(--neutral-200);
  background: var(--neutral-50);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.settings-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: var(--space-2);
  gap: var(--space-2);
}

.settings-preview-tile {
  background: white;
  border: 1px solid var(--neutral-200);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  overflow-wrap: anywhere;
}

.settings-toggle-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  border: 1px solid var(--neutral-200);
  background: var(--neutral-50);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  cursor: pointer;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.settings-toggle-row:hover {
  background: var(--neutral-100);
  border-color: var(--neutral-300);
}

.settings-danger-panel {
  border: 1px solid #fcd34d;
  background: #fffbeb;
  border-radius: var(--radius-xl);
  padding: var(--space-4);
}

.settings-save-panel {
  border: 1px solid var(--neutral-200);
  background: white;
  border-radius: var(--radius-xl);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
}

.settings-full-button {
  width: 100%;
}

.bank-statement-narration-cell {
  max-width: 280px;
  min-width: 180px;
}

.bank-statement-narration-cell .btn-link {
  display: block;
  max-width: 100%;
}

.bank-statement-narration-text {
  display: block !important;
  overflow: visible;
  white-space: normal;
  line-height: 1.35;
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 1024px) {
  .settings-layout {
    grid-template-columns: 1fr;
  }

  .settings-preview-grid {
    grid-template-columns: 1fr;
  }
}

/* BUTTONS */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-lg);
  font-family: 'DM Sans', sans-serif;
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  transition: all var(--transition-fast);
  border: 2px solid transparent;
  outline: none;
  text-decoration: none;
  white-space: nowrap;
  box-shadow: var(--shadow-sm);
}

.btn:focus-visible {
  outline: 3px solid var(--primary-lighter);
  outline-offset: 2px;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none;
}

.btn-primary {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}

.btn-primary:hover:not(:disabled) {
  background: var(--primary-dark);
  border-color: var(--primary-dark);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.btn-primary:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.btn-secondary {
  background: white;
  color: var(--neutral-700);
  border-color: var(--neutral-300);
}

.btn-secondary:hover:not(:disabled) {
  background: var(--neutral-50);
  border-color: var(--neutral-400);
  box-shadow: var(--shadow-md);
}

.btn-success {
  background: var(--success);
  color: white;
  border-color: var(--success);
}

.btn-success:hover:not(:disabled) {
  background: #0EA371;
  border-color: #0EA371;
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.btn-error {
  background: var(--error);
  color: white;
  border-color: var(--error);
}

.btn-error:hover:not(:disabled) {
  background: #DC2626;
  border-color: #DC2626;
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.btn-sm {
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
}

.btn-lg {
  padding: var(--space-4) var(--space-8);
  font-size: var(--text-base);
}

/* BNR beneficiary download — explicit colors (Tailwind bg-* on .btn was not reliably applied) */
.btn.btn-bnr-green {
  background: #059669 !important;
  color: #fff !important;
  border-color: #059669 !important;
}
.btn.btn-bnr-green:hover:not(:disabled) {
  background: #047857 !important;
  border-color: #047857 !important;
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.btn.btn-bnr-red {
  background: #dc2626 !important;
  color: #fff !important;
  border-color: #dc2626 !important;
}
.btn.btn-bnr-red:hover:not(:disabled) {
  background: #b91c1c !important;
  border-color: #b91c1c !important;
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.btn.btn-bnr-orange {
  background: #ea580c !important;
  color: #fff !important;
  border-color: #ea580c !important;
}
.btn.btn-bnr-orange:hover:not(:disabled) {
  background: #c2410c !important;
  border-color: #c2410c !important;
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

/* FORM ELEMENTS */
.form {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

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

label {
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--neutral-700);
  margin-bottom: var(--space-1);
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
input[type="tel"],
textarea,
select,
.form-input,
.form-select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-family: 'DM Sans', sans-serif;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--neutral-800);
  background-color: white;
  border: 2px solid var(--neutral-300);
  border-radius: var(--radius-md);
  outline: none;
  transition: all var(--transition-fast);
}

input:not([type="checkbox"]):not([type="radio"]):hover:not(:disabled):not(:focus),
textarea:hover:not(:disabled):not(:focus),
select:hover:not(:disabled):not(:focus) {
  border-color: var(--neutral-400);
}

input:not([type="checkbox"]):not([type="radio"]):focus,
textarea:focus,
select:focus,
.form-input:focus,
.form-select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-pale);
  background-color: white;
}

input:not([type="checkbox"]):not([type="radio"]):disabled,
textarea:disabled,
select:disabled {
  background-color: var(--neutral-100);
  color: var(--neutral-500);
  cursor: not-allowed;
  border-color: var(--neutral-200);
}

textarea {
  resize: vertical;
  min-height: 100px;
}

select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%23525252' d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  padding-right: var(--space-10);
}

.form-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  margin-top: var(--space-4);
  padding-top: var(--space-6);
  border-top: 1px solid var(--neutral-200);
}

/* ALERTS */
.alert {
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-lg);
  border-left: 4px solid;
  margin-bottom: var(--space-4);
  font-size: var(--text-sm);
  line-height: 1.6;
  font-weight: 500;
}

.alert-error {
  background-color: var(--error-light);
  color: #991B1B;
  border-color: var(--error);
}

.alert-success {
  background-color: var(--success-light);
  color: #065F46;
  border-color: var(--success);
}

.alert-info {
  background-color: var(--info-light);
  color: #1E40AF;
  border-color: var(--info);
}

.alert-warning {
  background-color: var(--warning-light);
  color: #92400E;
  border-color: var(--warning);
}

/* TABLES */
.table-container {
  overflow-x: auto;
  border-radius: var(--radius-lg);
  border: 1px solid var(--neutral-200);
  box-shadow: var(--shadow-sm);
}

.salary-employee-table-toolbar {
  display: flex;
  width: 100%;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  padding: 0.625rem 0.875rem;
  border-bottom: 1px solid var(--neutral-200);
  background: linear-gradient(to bottom, var(--neutral-50) 0%, white 100%);
}

.salary-employee-table-toolbar__meta {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  font-size: var(--text-sm);
  color: var(--neutral-600);
}

.salary-employee-table-toolbar__actions {
  display: flex;
  flex: 0 0 auto;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-left: auto;
}

.salary-employee-table-toolbar__filter {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--neutral-600);
  white-space: nowrap;
}

.salary-employee-table-toolbar .form-select {
  width: 10.5rem;
  min-width: 10.5rem;
  max-width: 10.5rem;
  min-height: 2.25rem;
  padding: 0.375rem 0.625rem;
  font-size: var(--text-sm);
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  background: white;
}

.data-table thead {
  background: linear-gradient(to bottom, var(--neutral-100) 0%, var(--neutral-50) 100%);
  border-bottom: 2px solid var(--neutral-300);
}

.data-table th {
  text-align: left;
  padding: var(--space-4) var(--space-5);
  font-family: 'DM Sans', sans-serif;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--neutral-700);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.data-table td {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--neutral-200);
  font-size: var(--text-sm);
  color: var(--neutral-700);
}

.data-table tbody tr {
  transition: background-color var(--transition-fast);
}

.data-table tbody tr:hover {
  background-color: var(--primary-pale);
}

.data-table tbody tr:last-child td {
  border-bottom: none;
}

/* Force full-row highlight for saved leave allocation rows */
.data-table tbody tr.leave-row-saved td {
  background-color: #dcfce7 !important;
}

.data-table tbody tr.leave-row-saved:hover td {
  background-color: #bbf7d0 !important;
}

.table-link {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
  transition: color var(--transition-fast);
}

.table-link:hover {
  color: var(--primary-dark);
  text-decoration: underline;
}

/* Action column: keep buttons from sticking together */
.data-table th.col-actions,
.data-table td.table-actions-cell {
  vertical-align: middle;
  min-width: 12rem;
}

.table-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem 0.75rem;
  row-gap: 0.5rem;
}

/* PAGE ELEMENTS */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-8);
}

.page-title {
  font-family: 'Fraunces', serif;
  font-size: var(--text-4xl);
  font-weight: 700;
  color: var(--neutral-900);
  margin: 0;
  letter-spacing: -0.5px;
}

.page-description {
  font-size: var(--text-base);
  color: var(--neutral-600);
  margin: var(--space-2) 0 0 0;
  line-height: 1.6;
}

.page-actions {
  display: flex;
  gap: var(--space-3);
}

.space-y-6 > * + * {
  margin-top: var(--space-6);
}

/* BADGES */
.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.3px;
}

.badge-success {
  background-color: var(--success-light);
  color: #065F46;
}

.badge-warning {
  background-color: var(--warning-light);
  color: #92400E;
}

.badge-error {
  background-color: var(--error-light);
  color: #991B1B;
}

.badge-info {
  background-color: var(--info-light);
  color: #1E40AF;
}

/* UTILITY CLASSES */
.text-success {
  color: var(--success);
}

.text-error {
  color: var(--error);
}

.text-warning {
  color: var(--warning);
}

.text-info {
  color: var(--info);
}

.text-muted {
  color: var(--neutral-500);
}

.bg-gray-50 {
  background-color: var(--neutral-50);
}

/* GRID SYSTEM */
.grid {
  display: grid;
  grid-gap: var(--space-6);
  gap: var(--space-6);
}

.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.grid-cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.grid-cols-12 {
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.col-span-1 { grid-column: span 1 / span 1; }
.col-span-2 { grid-column: span 2 / span 2; }
.col-span-3 { grid-column: span 3 / span 3; }
.col-span-4 { grid-column: span 4 / span 4; }
.col-span-5 { grid-column: span 5 / span 5; }
.col-span-6 { grid-column: span 6 / span 6; }
.col-span-12 { grid-column: span 12 / span 12; }

/* AUTH PAGES */
.auth-container {
  display: flex;
  min-height: 100vh;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 50%, var(--accent-coral) 100%);
  padding: var(--space-6);
}

.auth-card {
  width: 100%;
  max-width: 28rem;
  padding: var(--space-12);
  background: white;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-2xl);
}

.auth-title {
  font-family: 'Fraunces', serif;
  font-size: var(--text-3xl);
  font-weight: 700;
  margin-bottom: var(--space-8);
  color: var(--neutral-900);
  text-align: center;
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.auth-submit {
  width: 100%;
  padding: var(--space-4) var(--space-6);
  background: var(--primary);
  color: white;
  border: 2px solid var(--primary);
  border-radius: var(--radius-lg);
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  font-size: var(--text-base);
  cursor: pointer;
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-md);
  margin-top: var(--space-4);
}

.auth-submit:hover:not(:disabled) {
  background: var(--primary-dark);
  border-color: var(--primary-dark);
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}

.auth-submit:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: var(--shadow-md);
}

/* RESPONSIVE DESIGN */
@media (max-width: 1024px) {
  .grid-cols-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-title {
    font-size: var(--text-3xl);
  }
}

@media (max-width: 768px) {
  .sidebar {
    transform: translateX(-100%);
  }

  .main-layout {
    margin-left: 0;
  }

  .main-content {
    padding: var(--space-4);
  }

  .page-title {
    font-size: var(--text-2xl);
  }

  .grid-cols-2,
  .grid-cols-3,
  .grid-cols-4,
  .grid-cols-12 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

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

  .page-header {
    flex-direction: column;
    gap: var(--space-4);
  }

  .page-actions {
    width: 100%;
  }
}

/* Payslip preview */
.payslip-card-shell {
  background: #f6f6f6;
}

.payslip-paper {
  width: min(900px, 100%);
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid #2f2f2f;
  padding: 16px;
}

.payslip-logo-wrap {
  display: flex;
  justify-content: center;
  margin: 4px 0 12px;
}

.payslip-logo-img {
  width: 180px;
  height: auto;
  object-fit: contain;
  display: block;
}

.payslip-logo-mark {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  line-height: 1;
}

.payslip-logo-bracket {
  font-size: 68px;
  font-weight: 700;
  color: #111827;
  letter-spacing: -2px;
}

.payslip-logo-text {
  font-size: 62px;
  font-weight: 800;
  letter-spacing: -2px;
  display: inline-flex;
  align-items: baseline;
}

.payslip-logo-c {
  color: #d18a2a;
}

.payslip-logo-b {
  color: #d18a2a;
}

.payslip-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  font-size: 12px;
  color: #111827;
}

.payslip-table th,
.payslip-table td {
  border: 1px solid #2f2f2f;
  padding: 6px 8px;
  vertical-align: top;
}

.payslip-heading {
  background: #e7ad67;
  font-weight: 700;
  text-align: center;
}

.payslip-subheading {
  background: #ececec;
  font-weight: 700;
  text-align: center;
}

.payslip-label {
  background: #f0bc7d;
  font-weight: 600;
}

.payslip-heading-cell {
  background: #e7ad67;
  font-weight: 700;
  text-align: left;
}

.payslip-number {
  text-align: right;
}

.payslip-strong {
  font-weight: 700;
}

.payslip-net-row {
  background: #f3f4f6;
  text-align: center;
  font-weight: 700;
}

.payslip-note-row {
  font-size: 11px;
}

.payslip-mt {
  margin-top: 10px;
}

@media print {
  body * {
    visibility: hidden !important;
  }

  #tag-wise-print-area,
  #tag-wise-print-area * {
    visibility: visible !important;
  }

  #tag-wise-print-area {
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    margin: 0;
    padding: 8mm;
    border: 0;
    box-shadow: none;
    background: #fff;
    color: #111827;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  #tag-wise-print-area .card,
  #tag-wise-print-area .table-container {
    box-shadow: none !important;
    border-color: #d1d5db !important;
    background: #fff !important;
    color: #111827 !important;
  }

  #tag-wise-print-area .table-container {
    overflow: visible !important;
  }

  #tag-wise-print-area .data-table {
    width: 100% !important;
    table-layout: fixed;
  }

  #tag-wise-print-area .data-table th {
    background: #f3f4f6 !important;
    color: #111827 !important;
    padding: 6px 8px !important;
    font-size: 11px !important;
  }

  #tag-wise-print-area .data-table td {
    color: #111827 !important;
    padding: 6px 8px !important;
    font-size: 11px !important;
    white-space: normal !important;
    word-break: break-word;
    vertical-align: top;
  }

  #tag-wise-print-area .data-table th:last-child,
  #tag-wise-print-area .data-table td:last-child {
    width: 34% !important;
    min-width: 260px;
  }

  #tag-wise-print-area .text-muted {
    color: #4b5563 !important;
  }

  #tag-wise-print-area .text-success {
    color: #047857 !important;
  }

  #tag-wise-print-area .text-danger {
    color: #b91c1c !important;
  }

  #payslip-print-area,
  #payslip-print-area * {
    visibility: visible !important;
  }

  #payslip-print-area {
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    margin: 0;
    padding: 8mm;
    border: 0;
    box-shadow: none;
    background: #fff;
  }

  .no-print {
    display: none !important;
  }
}

/* LOADING SPINNER */
.spinner {
  border: 3px solid var(--neutral-200);
  border-radius: 50%;
  border-top-color: var(--primary);
  width: 24px;
  height: 24px;
  animation: spin 0.8s linear infinite;
  display: inline-block;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* FOCUS VISIBLE */
*:focus-visible {
  outline: 3px solid var(--primary-lighter);
  outline-offset: 2px;
}

button:focus-visible,
a:focus-visible {
  outline: 3px solid var(--primary-lighter);
  outline-offset: 2px;
}

/* CUSTOM SCROLLBAR */
::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}

::-webkit-scrollbar-track {
  background: var(--neutral-100);
  border-radius: var(--radius-sm);
}

::-webkit-scrollbar-thumb {
  background: var(--neutral-400);
  border-radius: var(--radius-sm);
  border: 2px solid var(--neutral-100);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--neutral-500);
}

/* ANIMATIONS */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideIn {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(0);
  }
}

/* SELECTION */
::selection {
  background-color: var(--primary-lighter);
  color: white;
}

::-moz-selection {
  background-color: var(--primary-lighter);
  color: white;
}

/* ===== Material Product Redesign Overrides ===== */
:root {
  --primary: #1a73e8;
  --primary-dark: #1557b0;
  --primary-light: #8ab4f8;
  --primary-lighter: #d2e3fc;
  --primary-pale: #eef3fd;

  --neutral-50: #f8f9fa;
  --neutral-100: #f1f3f4;
  --neutral-200: #e8eaed;
  --neutral-300: #dadce0;
  --neutral-400: #bdc1c6;
  --neutral-500: #9aa0a6;
  --neutral-600: #5f6368;
  --neutral-700: #3c4043;
  --neutral-800: #202124;
  --neutral-900: #171717;

  --success: #188038;
  --success-light: #e6f4ea;
  --error: #d93025;
  --error-light: #fce8e6;
  --warning: #ea8600;
  --warning-light: #fef7e0;
  --info: #1a73e8;
  --info-light: #e8f0fe;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 20px;

  --shadow-sm: 0 1px 2px rgb(60 64 67 / 0.16), 0 1px 3px 1px rgb(60 64 67 / 0.08);
  --shadow-md: 0 2px 6px 2px rgb(60 64 67 / 0.15), 0 1px 2px rgb(60 64 67 / 0.3);
  --shadow-lg: 0 8px 12px 6px rgb(60 64 67 / 0.12), 0 4px 4px rgb(60 64 67 / 0.16);
}

html,
body {
  background: var(--neutral-50);
  color: var(--neutral-800);
  font-family: "Poppins", "Segoe UI", Arial, sans-serif;
}

a {
  color: inherit;
}

.main-layout {
  margin-left: 288px;
  min-height: 100vh;
  background: var(--neutral-50);
}

.main-content {
  padding: 28px;
  max-width: 1600px;
}

/* Sidebar */
.sidebar {
  width: 288px;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1301;
  display: flex;
  flex-direction: column;
  background: #ffffff;
  border-right: 1px solid var(--neutral-200);
  box-shadow: var(--shadow-sm);
}

.sidebar-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--neutral-200);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.sidebar-logo-container {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sidebar-logo-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  background: linear-gradient(180deg, var(--primary) 0%, var(--primary-dark) 100%);
  box-shadow: 0 2px 4px rgb(26 115 232 / 0.36);
}

.sidebar-logo {
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.2;
  font-weight: 700;
  color: var(--neutral-900);
}

.sidebar-subtitle {
  margin: 2px 0 0 0;
  font-size: 0.75rem;
  color: var(--neutral-600);
  letter-spacing: 0.02em;
}

.sidebar-search-wrap {
  margin-top: 14px;
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  height: 38px;
  border: 1px solid var(--neutral-200);
  border-radius: 10px;
  background: #fff;
  padding: 0 12px 0 14px;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.sidebar-search-icon {
  position: static;
  transform: none;
  color: var(--neutral-500);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  pointer-events: none;
  flex: 0 0 16px;
  z-index: auto;
}

.sidebar-search-input {
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
  height: auto;
  border-radius: 10px;
  border: 0;
  background: transparent;
  color: var(--neutral-900);
  padding: 0;
  font-size: 0.9rem;
  line-height: 1.25;
  outline: none;
  transition: none;
}

.sidebar-search-wrap .sidebar-search-input,
input.sidebar-search-input {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  min-height: 0;
  height: auto;
  line-height: 1.25;
}

.sidebar-search-wrap .sidebar-search-input:hover,
.sidebar-search-wrap .sidebar-search-input:focus {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.sidebar-search-wrap:focus-within {
  border-color: #9fc2ff;
  box-shadow: 0 0 0 3px rgba(26, 115, 232, 0.12);
}

.sidebar-search-input::placeholder {
  color: var(--neutral-500);
}

.sidebar-nav {
  flex: 1 1;
  overflow-y: auto;
  padding: 8px 8px 12px;
}

.sidebar-category {
  margin-bottom: 6px;
}

.sidebar-category-header,
.sidebar-category-header-static {
  width: 100%;
  border: 0;
  background: transparent;
  padding: 10px 12px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--neutral-700);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.sidebar-category-header {
  cursor: pointer;
}

.sidebar-category-header:hover {
  background: var(--neutral-100);
}

.sidebar-category-icon {
  color: var(--neutral-600);
  display: inline-flex;
  align-items: center;
}

.sidebar-category-name {
  flex: 1 1;
  text-align: left;
}

.sidebar-category-arrow {
  display: inline-flex;
  align-items: center;
  color: var(--neutral-500);
  transform: rotate(-90deg);
  transition: transform var(--transition-fast);
}

.sidebar-category-arrow-expanded {
  transform: rotate(0deg);
}

.sidebar-category-items {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
}

.sidebar-category-items-expanded {
  max-height: 900px;
}

.sidebar-link {
  margin: 4px 4px 4px 28px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  color: var(--neutral-700);
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 500;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.sidebar-link-row {
  display: flex;
  align-items: center;
  gap: 0.2rem;
  margin: 0 4px 0 28px;
}

.sidebar-link-row .sidebar-link {
  margin: 4px 0;
  min-width: 0;
  flex: 1 1;
}

.sidebar-link-row-subitem {
  margin-left: 36px;
}

.sidebar-link-row-subitem .sidebar-link {
  margin-left: 0;
}

.sidebar-pin-btn {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--neutral-500);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
}

.sidebar-pin-btn:hover {
  background: #e8f0fe;
  color: #174ea6;
}

.sidebar-pin-btn.is-pinned {
  color: #174ea6;
  border-color: #c4d7fb;
  background: #edf4ff;
}

.sidebar-link:hover {
  background: #e8f0fe;
  color: #174ea6;
}

.sidebar-link-active {
  background: #d2e3fc;
  color: #174ea6;
  font-weight: 600;
}

.sidebar-icon {
  color: currentColor;
  display: inline-flex;
  align-items: center;
}

.sidebar-text {
  flex: 1 1;
}

.sidebar-active-indicator {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #174ea6;
}

.sidebar-footer {
  border-top: 1px solid var(--neutral-200);
  padding: 14px 16px;
  color: var(--neutral-600);
}

.sidebar-footer-text {
  display: flex;
  justify-content: center;
}

.sidebar-search-empty {
  padding: 12px 16px 8px 20px;
  color: var(--neutral-500);
  font-size: 0.85rem;
}

/* Top header */
.header {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgb(248 249 250 / 0.88);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--neutral-200);
}

.header-content {
  min-height: 72px;
  padding: 12px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.header-eyebrow {
  color: var(--neutral-600);
  font-size: 0.75rem;
  font-weight: 500;
  margin: 0;
}

.header-title {
  margin: 2px 0 0 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--neutral-900);
}

.header-subtitle {
  margin: 2px 0 0 0;
  color: var(--neutral-600);
  font-size: 0.8125rem;
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.header-notification-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 8px 12px;
  border: 1px solid var(--neutral-200);
  border-radius: 999px;
  background: #ffffff;
  color: var(--neutral-700);
  text-decoration: none;
  transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast);
}

.header-notification-btn:hover {
  background: var(--neutral-100);
  border-color: var(--neutral-300);
}

.header-notification-btn.is-active {
  color: #b42318;
  border-color: #fda29b;
  background: #fff5f5;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.08);
}

.header-notification-icon-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.header-notification-dot {
  position: absolute;
  top: -2px;
  right: -2px;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--error);
  border: 2px solid #ffffff;
}

.header-notification-label {
  font-size: 0.8125rem;
  font-weight: 600;
}

.header-notification-count {
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--error);
  color: #ffffff;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1;
}

.user-menu {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--neutral-200);
  border-radius: 999px;
  padding: 6px 8px 6px 6px;
  background: #ffffff;
}

.user-avatar {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  color: #174ea6;
  background: #e8f0fe;
}

.user-email {
  font-size: 0.8125rem;
  color: var(--neutral-700);
}

/* Shared surface styles */
.card,
.stat-card,
.action-card {
  background: #ffffff;
  border: 1px solid var(--neutral-200);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.card {
  overflow: hidden;
}

.employee-form-card {
  overflow: visible;
}

.card.bank-upload-generator-card {
  overflow: visible;
}

.employee-form-card .card-content {
  overflow: visible;
}

.bank-upload-generator-card .card-content {
  overflow: visible;
}

.card-header {
  padding: 18px 20px;
  border-bottom: 1px solid var(--neutral-200);
  background: #ffffff;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.card-title {
  margin: 0;
  color: var(--neutral-900);
  font-size: 1.125rem;
  font-weight: 600;
}

.card-description {
  margin: 6px 0 0 0;
  color: var(--neutral-600);
  font-size: 0.875rem;
}

.card-content {
  padding: 20px;
}

.stat-card {
  padding: 18px;
}

.stat-label {
  color: var(--neutral-600);
  font-size: 0.8125rem;
  margin-bottom: 4px;
}

.stat-value {
  color: var(--neutral-900);
  font-size: 1.6rem;
  line-height: 1.25;
  font-weight: 700;
}

.action-card {
  display: block;
  padding: 18px;
  text-decoration: none;
  transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}

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

.action-icon {
  font-size: 1.2rem;
  margin-bottom: 8px;
}

.action-title {
  margin: 0;
  color: var(--neutral-900);
  font-size: 1rem;
  font-weight: 600;
}

.action-description {
  margin: 6px 0 0 0;
  color: var(--neutral-600);
  font-size: 0.875rem;
}

/* Buttons */
.btn {
  min-height: 36px;
  border-radius: 999px;
  border: 1px solid transparent;
  padding: 8px 16px;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}

.btn-primary {
  color: #ffffff;
  background: var(--primary);
  border-color: var(--primary);
}

.btn-primary:hover:not(:disabled) {
  background: var(--primary-dark);
  border-color: var(--primary-dark);
}

.btn-secondary {
  color: #174ea6;
  background: #ffffff;
  border-color: var(--neutral-300);
}

.btn-secondary:hover:not(:disabled) {
  background: #f8fbff;
}

.btn-success {
  color: #ffffff;
  background: var(--success);
  border-color: var(--success);
}

.btn-success:hover:not(:disabled) {
  background: #137333;
  border-color: #137333;
}

.btn-error,
.btn-danger {
  color: #ffffff;
  background: var(--error);
  border-color: var(--error);
}

.btn-error:hover:not(:disabled),
.btn-danger:hover:not(:disabled) {
  background: #b3261e;
  border-color: #b3261e;
}

.btn-sm {
  min-height: 30px;
  font-size: 0.8125rem;
  padding: 6px 12px;
}

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

.btn-link {
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}

.btn-link:hover {
  text-decoration: underline;
}

/* Forms */
.form,
.auth-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  grid-gap: 18px;
  gap: 18px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.form-label {
  color: var(--neutral-700);
  font-size: 0.8125rem;
  font-weight: 500;
}

input:not([type="checkbox"]):not([type="radio"]),
textarea,
select,
.form-input,
.form-select {
  width: 100%;
  min-height: 40px;
  border-radius: 8px;
  border: 1px solid var(--neutral-300);
  background: #ffffff;
  color: var(--neutral-800);
  padding: 9px 12px;
  font-size: 0.9rem;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

input:not([type="checkbox"]):not([type="radio"]):focus,
textarea:focus,
select:focus,
.form-input:focus,
.form-select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgb(26 115 232 / 0.18);
  outline: none;
}

.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 4px;
  padding-top: 16px;
  border-top: 1px solid var(--neutral-200);
}

/* Tables */
.table-container {
  border: 1px solid var(--neutral-200);
  border-radius: 12px;
  overflow-x: auto;
  background: #ffffff;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
}

.data-table th,
.data-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--neutral-200);
  font-size: 0.875rem;
}

.data-table th {
  color: var(--neutral-600);
  text-align: left;
  font-weight: 600;
  background: #f8fbff;
}

.data-table tbody tr:hover {
  background: #f6f9fe;
}

.data-table tbody tr:last-child td {
  border-bottom: none;
}

/* Badges and states */
.badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 0.75rem;
  font-weight: 600;
}

.badge-success {
  background: var(--success-light);
  color: var(--success);
}

.badge-warning {
  background: var(--warning-light);
  color: #a05a00;
}

.badge-error,
.badge-danger {
  background: var(--error-light);
  color: var(--error);
}

.badge-info,
.badge-secondary {
  background: var(--info-light);
  color: #174ea6;
}

.alert {
  border-radius: 10px;
  border: 1px solid transparent;
  padding: 12px 14px;
  font-size: 0.875rem;
}

.alert-error {
  background: var(--error-light);
  border-color: #f6aea9;
  color: #8b1d18;
}

.alert-success {
  background: var(--success-light);
  border-color: #9ad6aa;
  color: #0d652d;
}

.alert-warning {
  background: var(--warning-light);
  border-color: #f8cf70;
  color: #8c4f00;
}

.alert-info {
  background: var(--info-light);
  border-color: #a8c7fa;
  color: #174ea6;
}

/* Global floating error popup (all screens) */
.alert.alert-error {
  position: fixed;
  top: 84px;
  right: 20px;
  width: min(460px, calc(100vw - 2rem));
  margin: 0;
  z-index: 1200;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
  border-left: 4px solid var(--error);
  animation: slideInErrorPopup 0.2s ease-out;
}

@keyframes slideInErrorPopup {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 640px) {
  .alert.alert-error {
    top: 72px;
    right: 12px;
    width: calc(100vw - 24px);
  }
}

/* Common empty/loading/error blocks */
.empty-state,
.loading-container,
.error-container {
  border: 1px dashed var(--neutral-300);
  border-radius: 12px;
  padding: 24px;
  text-align: center;
  background: #ffffff;
}

.empty-icon,
.error-icon {
  font-size: 1.5rem;
  margin-bottom: 8px;
}

.empty-title,
.error-title {
  margin: 0;
  font-size: 1.125rem;
  color: var(--neutral-900);
}

.empty-message,
.error-message,
.loading-text {
  margin: 8px 0 0 0;
  color: var(--neutral-600);
}

/* Type and spacing utility classes used across pages */
.text-primary { color: var(--primary); }
.text-success, .text-green-600 { color: var(--success); }
.text-green-700 { color: #0d652d; }
.text-error, .text-danger, .text-red-600, .text-red-500 { color: var(--error); }
.text-red-700 { color: #8b1d18; }
.text-info, .text-blue-600 { color: var(--primary); }
.text-blue-700 { color: #1557b0; }
.text-blue-800 { color: #174ea6; }
.text-purple-600 { color: #7b1fa2; }
.text-yellow-600 { color: #a05a00; }
.text-yellow-800 { color: #8c4f00; }
.text-gray-400 { color: var(--neutral-400); }
.text-gray-500 { color: var(--neutral-500); }
.text-gray-600 { color: var(--neutral-600); }
.text-gray-700 { color: var(--neutral-700); }
.text-gray-900 { color: var(--neutral-900); }
.text-white { color: #ffffff; }
.text-muted { color: var(--neutral-600); }

.text-xs { font-size: 0.75rem; }
.text-sm { font-size: 0.875rem; }
.text-base { font-size: 1rem; }
.text-lg { font-size: 1.125rem; }
.text-xl { font-size: 1.25rem; }
.text-2xl { font-size: 1.5rem; }

.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }
.uppercase { text-transform: uppercase; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.whitespace-pre-wrap { white-space: pre-wrap; }

.w-full { width: 100%; }
.w-1\/6 { width: 16.666667%; }
.w-1\/4 { width: 25%; }
.w-1\/3 { width: 33.333333%; }
.max-w-xs { max-width: 20rem; }
.max-w-4xl { max-width: 56rem; }
.mx-auto { margin-left: auto; margin-right: auto; }
.max-h-60 { max-height: 15rem; }
.max-h-96 { max-height: 24rem; }
.overflow-hidden { overflow: hidden; }
.overflow-x-auto { overflow-x: auto; }
.overflow-y-auto { overflow-y: auto; }

.flex { display: flex; }
.grid { display: grid; }
.block { display: block; }
.items-center { align-items: center; }
.items-end { align-items: flex-end; }
.items-start { align-items: flex-start; }
.justify-between { justify-content: space-between; }
.justify-end { justify-content: flex-end; }
.justify-center { justify-content: center; }
.flex-wrap { flex-wrap: wrap; }
.flex-1 { flex: 1 1; }

.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }
.col-span-1 { grid-column: span 1 / span 1; }
.col-span-2 { grid-column: span 2 / span 2; }
.col-span-3 { grid-column: span 3 / span 3; }
.col-span-4 { grid-column: span 4 / span 4; }
.col-span-5 { grid-column: span 5 / span 5; }

.gap-1 { gap: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: 1rem; }
.gap-6 { gap: 1.5rem; }

.mt-1 { margin-top: 0.25rem; }
.mt-2 { margin-top: 0.5rem; }
.mt-4 { margin-top: 1rem; }
.mt-6 { margin-top: 1.5rem; }
.mt-8 { margin-top: 2rem; }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 0.25rem; }
.mb-2 { margin-bottom: 0.5rem; }
.mb-3 { margin-bottom: 0.75rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-6 { margin-bottom: 1.5rem; }
.mr-2 { margin-right: 0.5rem; }
.ml-1 { margin-left: 0.25rem; }
.ml-5 { margin-left: 1.25rem; }
.p-2 { padding: 0.5rem; }
.p-3 { padding: 0.75rem; }
.p-4 { padding: 1rem; }
.p-6 { padding: 1.5rem; }
.p-8 { padding: 2rem; }
.pt-2 { padding-top: 0.5rem; }
.pt-3 { padding-top: 0.75rem; }
.pt-4 { padding-top: 1rem; }
.pt-6 { padding-top: 1.5rem; }
.py-2 { padding-top: 0.5rem; padding-bottom: 0.5rem; }
.py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
.py-4 { padding-top: 1rem; padding-bottom: 1rem; }
.py-8 { padding-top: 2rem; padding-bottom: 2rem; }
.px-3 { padding-left: 0.75rem; padding-right: 0.75rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }

.space-y-1 > * + * { margin-top: 0.25rem; }
.space-y-2 > * + * { margin-top: 0.5rem; }
.space-y-3 > * + * { margin-top: 0.75rem; }
.space-y-4 > * + * { margin-top: 1rem; }
.space-y-6 > * + * { margin-top: 1.5rem; }

.rounded { border-radius: 0.5rem; }
.rounded-md { border-radius: 0.625rem; }
.rounded-lg { border-radius: 0.75rem; }
.border { border: 1px solid var(--neutral-300); }
.border-t { border-top: 1px solid var(--neutral-300); }
.border-t-2 { border-top: 2px solid var(--neutral-300); }
.border-b { border-bottom: 1px solid var(--neutral-300); }
.border-border { border-color: var(--neutral-300); }
.border-gray-200 { border-color: var(--neutral-200); }
.border-gray-300 { border-color: var(--neutral-300); }
.border-red-200 { border-color: #f2b8b5; }
.border-yellow-200 { border-color: #f8cf70; }
.border-blue-200 { border-color: #a8c7fa; }
.bg-white { background-color: #ffffff; }
.bg-gray-50 { background-color: var(--neutral-50); }
.bg-red-50 { background-color: var(--error-light); }
.bg-yellow-50 { background-color: var(--warning-light); }
.bg-blue-50 { background-color: var(--info-light); }
.bg-blue-600 { background-color: var(--primary); }
.hover\:bg-blue-700:hover { background-color: var(--primary-dark); }
.hover\:bg-gray-50:hover { background-color: var(--neutral-50); }
.hover\:text-blue-700:hover { color: #1557b0; }
.hover\:text-red-700:hover { color: #8b1d18; }
.shadow { box-shadow: var(--shadow-sm); }
.disabled\:bg-blue-300:disabled { background-color: #a8c7fa; }

.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }

.list-disc { list-style-type: disc; }

.focus\:outline-none:focus { outline: none; }
.focus\:ring-2:focus { box-shadow: 0 0 0 2px rgb(26 115 232 / 0.3); }
.focus\:ring-blue-500:focus { box-shadow: 0 0 0 2px rgb(26 115 232 / 0.35); }

/* Page-level primitives */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 1.5rem;
}

.page-title {
  margin: 0;
  color: var(--neutral-900);
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.2;
}

.page-description {
  margin: 6px 0 0 0;
  color: var(--neutral-600);
  font-size: 0.95rem;
}

.page-actions {
  display: flex;
  gap: 10px;
}

/* Authentication pages */
.auth-container {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: radial-gradient(circle at top right, #d2e3fc 0%, #f6f9fe 38%, #f8f9fa 100%);
}

.auth-card {
  width: 100%;
  max-width: 430px;
  background: #ffffff;
  border: 1px solid var(--neutral-200);
  border-radius: 18px;
  box-shadow: var(--shadow-md);
  padding: 28px;
}

.auth-title {
  margin: 0 0 20px 0;
  color: var(--neutral-900);
  font-size: 1.6rem;
  font-weight: 700;
  text-align: center;
}

.auth-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.auth-submit {
  width: 100%;
  min-height: 42px;
  border: 0;
  border-radius: 999px;
  background: var(--primary);
  color: #ffffff;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.auth-submit:hover:not(:disabled) {
  background: var(--primary-dark);
}

/* Login page enhancements */
.auth-login-card {
  max-width: 900px;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
}

.auth-login-brand-panel {
  background: linear-gradient(150deg, #eef4ff 0%, #e3efff 52%, #d5e7ff 100%);
  color: #1f3b66;
  padding: 36px 34px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  position: relative;
}

.auth-login-brand-panel::after {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  border-radius: 999px;
  right: -50px;
  top: -48px;
  background: radial-gradient(circle, rgba(129, 170, 230, 0.26) 0%, rgba(129, 170, 230, 0) 72%);
  pointer-events: none;
}

.auth-login-brand-chip {
  width: -moz-fit-content;
  width: fit-content;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(67, 112, 176, 0.26);
  background: rgba(67, 112, 176, 0.08);
  padding: 6px 10px;
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 700;
  color: #295289;
}

.auth-login-brand-link {
  width: -moz-fit-content;
  width: fit-content;
  display: inline-flex;
  align-items: center;
}

.auth-login-logo {
  width: 122px;
  height: auto;
  object-fit: contain;
}

.auth-login-brand-tag {
  margin: 2px 0 0 0;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #3e6aa5;
}

.auth-login-brand-title {
  margin: 2px 0 0 0;
  font-size: 1.55rem;
  line-height: 1.25;
  font-weight: 700;
  color: #1f3b66;
}

.auth-login-brand-description {
  margin: 0;
  font-size: 0.93rem;
  line-height: 1.5;
  color: #4d6d99;
}

.auth-login-form-panel {
  padding: 34px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.auth-login-form-top {
  margin-bottom: 10px;
}

.auth-login-form-panel .auth-title {
  text-align: left;
  margin-bottom: 2px;
}

.auth-login-form-subtitle {
  margin: 0;
  font-size: 0.95rem;
  color: var(--neutral-600);
}

.auth-sso-button {
  margin-bottom: 14px;
  width: 100%;
}

.auth-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.auth-otp-divider {
  margin-top: 16px;
  margin-bottom: 16px;
}

.auth-divider-line {
  flex: 1 1;
  height: 1px;
  background: var(--neutral-200);
}

.auth-divider-text {
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  color: var(--neutral-500);
  font-weight: 700;
  white-space: nowrap;
}

.auth-password-wrap {
  position: relative;
}

.auth-password-wrap input {
  padding-right: 72px;
}

.auth-password-toggle {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  color: var(--primary);
  font-size: 0.82rem;
  font-weight: 600;
  padding: 4px 8px;
  cursor: pointer;
}

.auth-password-toggle:hover {
  color: var(--primary-dark);
}

.auth-primary-button {
  margin-top: 4px;
  background: linear-gradient(135deg, #1a73e8 0%, #1557b0 100%);
  box-shadow: 0 6px 16px rgba(21, 87, 176, 0.24);
}

.auth-primary-button:hover:not(:disabled) {
  background: linear-gradient(135deg, #175fbe 0%, #124a95 100%);
}

.auth-login-support-note {
  margin: 14px 0 0 0;
  font-size: 0.82rem;
  color: var(--neutral-500);
}

.auth-otp-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 8px;
  gap: 8px;
}

@media (max-width: 860px) {
  .auth-login-card {
    grid-template-columns: 1fr;
    max-width: 460px;
  }

  .auth-login-brand-panel,
  .auth-login-form-panel {
    padding: 26px;
  }

  .auth-login-brand-title {
    font-size: 1.4rem;
  }
}

@media (max-width: 640px) {
  .auth-container {
    padding: 12px;
  }

  .auth-login-card {
    border-radius: 14px;
  }

  .auth-login-brand-panel,
  .auth-login-form-panel {
    padding: 18px 16px;
  }

  .auth-login-brand-chip {
    font-size: 0.65rem;
    padding: 4px 8px;
  }

  .auth-login-logo {
    width: 106px;
  }

  .auth-login-brand-title,
  .auth-login-form-panel .auth-title {
    font-size: 1.25rem;
  }

  .auth-login-form-subtitle {
    font-size: 0.86rem;
  }

  .auth-divider-text {
    font-size: 0.62rem;
    letter-spacing: 0.04em;
  }

  .auth-submit {
    min-height: 42px;
  }

  .auth-otp-actions {
    grid-template-columns: 1fr;
  }

  .auth-login-support-note {
    text-align: center;
  }
}

/* Responsive */
@media (max-width: 1200px) {
  .grid-cols-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .sidebar {
    width: 264px;
  }

  .main-layout {
    margin-left: 264px;
  }

  .header-content,
  .main-content {
    padding-left: 20px;
    padding-right: 20px;
  }

  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .md\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .md\:grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

/* Project details screen */
.project-overview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 12px;
  gap: 12px;
}

.project-metric-card {
  padding: 14px;
}

.project-metric-card .stat-value {
  font-size: 1.35rem;
}

.compact-card .card-content {
  padding: 14px;
}

.compact-card .card-header {
  padding: 12px 14px;
}

.compact-card .card-title {
  font-size: 1rem;
}

.tag-wise-filter-card .card-header {
  padding: 12px 14px;
}

.tag-wise-filter-card .card-content {
  padding: 14px;
}

.tag-wise-filter-card .card-title {
  font-size: 1rem;
  font-weight: 600;
}

.tag-wise-filter-card .tag-wise-date-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.tag-wise-filter-card .tag-wise-date-field {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 8px;
  border: 1px solid var(--neutral-200);
  border-radius: 8px;
  background: #f9fafb;
}

.tag-wise-filter-card .tag-wise-date-input {
  min-height: 32px;
  max-width: 160px;
  padding: 5px 9px;
  font-size: 0.825rem;
}

.tag-wise-filter-card .tag-wise-date-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--neutral-600);
  white-space: nowrap;
}

@media (max-width: 768px) {
  .tag-wise-filter-card .card-header {
    flex-direction: column;
    align-items: stretch;
  }

  .tag-wise-filter-card .card-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
  }

  .tag-wise-filter-card .tag-wise-date-row {
    flex-wrap: wrap;
  }

  .tag-wise-filter-card .tag-wise-date-field {
    width: 100%;
    justify-content: space-between;
  }

  .tag-wise-filter-card .tag-wise-date-input {
    max-width: 100%;
    flex: 1 1;
    min-width: 140px;
  }
}

.filter-card-open {
  overflow: visible !important;
}

.filter-card-open .card-content {
  overflow: visible;
}

.rbac-users-card {
  overflow: visible;
}

.rbac-users-card .card-content {
  overflow: visible;
}

.rbac-screen {
  width: 100%;
}

.rbac-layout {
  display: grid;
  grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
  grid-gap: 12px;
  gap: 12px;
  align-items: start;
}

.rbac-side-card,
.rbac-main-card {
  min-width: 0;
}

.permission-matrix-table .data-table th,
.permission-matrix-table .data-table td {
  padding: 10px 10px;
  font-size: 0.8125rem;
}

.permission-matrix-table .data-table th {
  white-space: nowrap;
}

.permission-matrix-table .data-table td:first-child,
.permission-matrix-table .data-table th:first-child {
  position: -webkit-sticky;
  position: sticky;
  left: 0;
  z-index: 2;
  background: #ffffff;
}

.permission-matrix-table .data-table th:first-child {
  z-index: 3;
  background: #f8fbff;
}

.mini-empty {
  border: 1px dashed var(--neutral-300);
  border-radius: 10px;
  background: #fafafa;
  color: var(--neutral-600);
  padding: 12px;
  font-size: 0.875rem;
}

.category-list {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.category-item {
  border: 1px solid var(--neutral-200);
  border-radius: 10px;
  padding: 10px 12px;
  background: #ffffff;
}

.category-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.subcategory-list {
  margin-top: 6px;
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.subcategory-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 0.8125rem;
  color: var(--neutral-600);
}

.project-txn-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.project-txn-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--neutral-200);
  border-radius: 10px;
  padding: 10px 12px;
  background: #ffffff;
}

.project-txn-main {
  min-width: 0;
}

.project-txn-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--neutral-900);
}

.project-txn-meta {
  margin-top: 2px;
  font-size: 0.75rem;
  color: var(--neutral-500);
}

.project-txn-amount {
  font-size: 0.875rem;
  font-weight: 700;
  white-space: nowrap;
}

/* Ledger page compaction */
.ledger-page .page-header {
  margin-bottom: 14px;
}

.ledger-page .card-header {
  padding: 12px 14px;
}

.ledger-page .card-content {
  padding: 12px 14px;
}

.ledger-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 10px;
  gap: 10px;
}

@media (max-width: 1024px) {
  .ledger-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .ledger-summary-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}

/* Sidebar subsection controls */
.sidebar-subsection {
  margin-top: 0.25rem;
}

.sidebar-subsection-header {
  width: calc(100% - 8px);
  margin: 0 4px 2px 22px;
  padding: 6px 8px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.sidebar-subsection-header:hover {
  background: var(--neutral-100);
}

.sidebar-subsection-name {
  color: var(--neutral-600);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.sidebar-subsection-name-active {
  color: var(--neutral-800);
}

.sidebar-subsection-arrow {
  color: var(--neutral-500);
  display: inline-flex;
  align-items: center;
  transition: transform var(--transition-fast);
}

.sidebar-subsection-arrow-wrap {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid var(--neutral-300);
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sidebar-subsection-arrow-expanded {
  transform: rotate(180deg);
}

.sidebar-link-subitem {
  margin-left: 0;
}

/* My project mappings responsive layout */
.project-mapping-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.project-mapping-mobile-label {
  display: none;
  margin-bottom: 0.25rem;
  font-size: 0.75rem;
  color: var(--neutral-600);
}

.project-mapping-actions {
  display: flex;
  justify-content: flex-end;
}

/* My profile responsive layout */
.profile-chip-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.profile-hero-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.profile-hero-identity {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.profile-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 0.5rem;
  gap: 0.5rem;
}

.profile-tab-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.profile-tab-btn {
  width: auto;
}

@media (max-width: 768px) {
  .project-mapping-header {
    flex-direction: column;
    align-items: stretch;
  }

  .project-mapping-add-btn,
  .project-mapping-save-btn {
    width: 100%;
  }

  .project-mapping-row {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .project-mapping-row .col-span-1,
  .project-mapping-row .col-span-2,
  .project-mapping-row .col-span-3,
  .project-mapping-row .col-span-12 {
    grid-column: span 1 / span 1;
  }

  .project-mapping-mobile-label {
    display: block;
  }

  .project-mapping-actions {
    justify-content: stretch;
  }

  .profile-chip-list {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    align-items: stretch;
    width: 100%;
  }

  .profile-chip-list .badge {
    width: 100%;
    justify-content: flex-start;
    display: flex;
    white-space: normal;
    line-height: 1.35;
  }

  .profile-kpi-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .profile-tab-list {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .profile-tab-btn {
    width: 100%;
  }

  .profile-hero-top {
    flex-direction: column;
    align-items: stretch;
  }

  .profile-hero-identity {
    width: 100%;
  }
}

@media (max-width: 1024px) {
  .project-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .project-overview-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .sidebar {
    transform: translateX(-100%);
  }

  .main-layout {
    margin-left: 0;
  }

  .header-content {
    padding: 12px 14px;
  }

  .main-content {
    padding: 14px;
  }

  .page-header {
    flex-direction: column;
  }

  .grid-cols-2,
  .grid-cols-3,
  .grid-cols-4,
  .md\:grid-cols-2,
  .md\:grid-cols-3,
  .md\:grid-cols-4,
  .md\:grid-cols-5 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .rbac-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* Product consistency pass */
h1, h2, h3, h4, h5, h6 {
  font-family: "Poppins", "Segoe UI", Arial, sans-serif;
  letter-spacing: -0.01em;
}

.btn,
.btn-link,
button,
input,
select,
textarea {
  font-family: "Poppins", "Segoe UI", Arial, sans-serif;
}

.btn svg,
.btn-link svg,
.sidebar-icon svg,
.sidebar-category-icon svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.btn-link {
  font-weight: 500;
  color: var(--primary);
}

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

.page-header {
  margin-bottom: 1.1rem;
}

.data-table th,
.data-table td {
  vertical-align: middle;
}

.section-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  padding: 2px 0;
}

.section-nav-link {
  text-decoration: none;
  color: var(--neutral-600);
  font-size: 0.9rem;
  font-weight: 500;
  padding: 6px 0;
  border-bottom: 2px solid transparent;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

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

.section-nav-link-active {
  color: var(--primary);
  font-weight: 700;
  border-bottom-color: var(--primary);
}

.subnav-shell {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  background: #ffffff;
  border: 1px solid var(--neutral-200);
  border-radius: 12px;
  padding: 12px;
}

.subnav-title {
  margin: 0 8px 0 2px;
  color: var(--neutral-600);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.subnav-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: var(--neutral-700);
  font-size: 0.875rem;
  font-weight: 500;
  border: 1px solid var(--neutral-300);
  border-radius: 999px;
  padding: 7px 12px;
  background: #fff;
  transition: border-color var(--transition-fast), color var(--transition-fast), background-color var(--transition-fast);
}

.subnav-item:hover {
  color: var(--primary-dark);
  border-color: var(--primary-light);
  background: #f8fbff;
}

.subnav-item-active {
  color: #174ea6;
  border-color: #9bbcf8;
  background: #e8f0fe;
  font-weight: 600;
}

/* Shared modal primitive */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(17, 24, 39, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  z-index: 1200;
}

.modal-card {
  width: min(100%, 420px);
  background: #ffffff;
  border: 1px solid var(--neutral-200);
  border-radius: 14px;
  box-shadow: var(--shadow-lg);
}

/* Funded debits compact filters */
.funded-filters-row {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.funded-filter-item {
  min-width: 180px;
  flex: 1 1 220px;
}

.funded-filter-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
  margin-left: auto;
  padding-bottom: 1px;
}

@media (max-width: 768px) {
  .funded-filters-row {
    align-items: stretch;
  }

  .funded-filter-item,
  .funded-filter-actions {
    flex: 1 1 100%;
  }
}

/* Enforce one typography across the app */
body,
body * {
  font-family: var(--app-font) !important;
}

/* Global button refresh */
:root {
  --btn-radius: 10px;
  --btn-height: 38px;
  --btn-padding-x: 14px;
}

.btn {
  min-height: var(--btn-height);
  padding: 8px var(--btn-padding-x);
  border-radius: var(--btn-radius);
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  text-decoration: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast),
    background-color var(--transition-fast), border-color var(--transition-fast),
    color var(--transition-fast);
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.08);
}

.btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(16, 24, 40, 0.12);
}

.btn:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: 0 1px 3px rgba(16, 24, 40, 0.12);
}

.btn:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 3px rgba(26, 115, 232, 0.22);
}

.btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

.btn-primary {
  background: linear-gradient(180deg, #2b7de9 0%, #1a73e8 100%);
  border-color: #1668d2;
  color: #ffffff;
}

.btn-primary:hover:not(:disabled) {
  background: linear-gradient(180deg, #236fd0 0%, #155fc0 100%);
  border-color: #1357ad;
}

.btn-secondary {
  background: #ffffff;
  border-color: var(--neutral-300);
  color: var(--neutral-700);
}

.btn-secondary:hover:not(:disabled) {
  background: var(--neutral-50);
  border-color: var(--neutral-400);
  color: var(--neutral-900);
}

.btn-success {
  background: linear-gradient(180deg, #1f9b4b 0%, #188038 100%);
  border-color: #166e31;
  color: #ffffff;
}

.btn-success:hover:not(:disabled) {
  background: linear-gradient(180deg, #178a3f 0%, #106a2e 100%);
  border-color: #0f5c28;
}

.btn-error,
.btn-danger {
  background: linear-gradient(180deg, #e24a40 0%, #d93025 100%);
  border-color: #c6281f;
  color: #ffffff;
}

.btn-error:hover:not(:disabled),
.btn-danger:hover:not(:disabled) {
  background: linear-gradient(180deg, #cd3e35 0%, #b3261e 100%);
  border-color: #a81f18;
}

.btn-sm {
  min-height: 32px;
  padding: 6px 10px;
  font-size: 0.8125rem;
  border-radius: 8px;
}

.btn-lg {
  min-height: 44px;
  padding: 10px 18px;
  font-size: 0.95rem;
}

.btn-link {
  background: transparent;
  border: 0;
  padding: 0;
  min-height: auto;
  border-radius: 0;
  box-shadow: none;
  color: var(--primary);
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
}

.btn-link:hover {
  color: var(--primary-dark);
  text-decoration: underline;
  transform: none;
  box-shadow: none;
}

/* DMS browser layout fixes */
.dms-drive-shell {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  grid-gap: 16px;
  gap: 16px;
  align-items: start;
}

.dms-drive-rail,
.dms-drive-main {
  min-width: 0;
}

.dms-drive-library-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dms-drive-library-item {
  width: 100%;
  min-width: 0;
  text-align: left;
}

.dms-drive-library-top,
.dms-drive-library-title,
.dms-drive-library-meta-line {
  min-width: 0;
}

.dms-drive-library-title {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 auto;
}

.dms-drive-library-title svg {
  flex: 0 0 auto;
}

.dms-drive-library-name,
.dms-drive-library-meta,
.dms-drive-library-access {
  display: block;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dms-drive-library-badges {
  flex: 0 0 auto;
  max-width: 42%;
}

.dms-browser-table {
  overflow-x: auto;
}

.dms-browser-table .dms-files-table {
  min-width: 860px;
  table-layout: fixed;
}

.dms-files-table th,
.dms-files-table td {
  vertical-align: middle;
}

.dms-files-table .dms-col-name {
  width: 42%;
}

.dms-files-table .dms-col-doc-number {
  width: 170px;
}

.dms-files-table .dms-col-added {
  width: 180px;
}

.dms-files-table .dms-col-actions {
  width: 290px;
}

.dms-file-name-cell,
.dms-table-primary {
  min-width: 0;
}

.dms-table-primary {
  display: flex;
  align-items: center;
  gap: 8px;
}

.dms-table-primary svg {
  flex: 0 0 auto;
}

.dms-table-name-link,
.dms-table-name-text {
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dms-table-name-link {
  display: inline-block;
  text-align: left;
}

.dms-table-meta {
  white-space: nowrap;
}

.dms-action-group {
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-end;
  gap: 6px;
  max-width: none;
  margin-left: auto;
  overflow-x: auto;
  padding-bottom: 2px;
}

.dms-action-group .btn-link,
.dms-action-group a.btn-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 4px 10px;
  border: 1px solid var(--neutral-200);
  border-radius: 999px;
  background: #fff;
  color: var(--primary);
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.2;
  text-decoration: none;
  white-space: nowrap;
}

@media (max-width: 1100px) {
  .dms-drive-shell {
    grid-template-columns: 1fr;
  }
}

.dms-action-group .btn-link:hover,
.dms-action-group a.btn-link:hover {
  background: var(--primary-pale);
  border-color: var(--primary-lighter);
  color: var(--primary-dark);
  text-decoration: none;
}

.dms-action-group .dms-action-danger {
  color: var(--error);
  border-color: #fecaca;
  background: #fff7f7;
}

.dms-action-group .dms-action-danger:hover {
  color: #b91c1c;
  border-color: #fca5a5;
  background: #fef2f2;
}

/* Ensure dropdown UI uses app font everywhere */
select,
option,
optgroup {
  font-family: var(--app-font) !important;
}

/* Disable number input spinner controls globally */
input[type="number"] {
  -moz-appearance: textfield;
  -webkit-appearance: textfield;
          appearance: textfield;
}

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Mobile navigation support */
.header-left {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  min-width: 0;
}

.header-copy {
  min-width: 0;
}

.mobile-sidebar-toggle {
  display: none;
  margin-top: 2px;
  width: 34px;
  height: 34px;
  border: 1px solid var(--neutral-200);
  border-radius: 10px;
  background: #ffffff;
  color: var(--neutral-700);
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.mobile-sidebar-toggle:hover {
  background: var(--neutral-100);
}

.sidebar-overlay {
  display: none;
}

@media (max-width: 768px) {
  .sidebar {
    transform: translateX(-100%);
    transition: transform 0.2s ease;
    z-index: 1301;
  }

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

  .mobile-sidebar-toggle {
    display: inline-flex;
  }

  .header-title {
    font-size: 1rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 52vw;
  }

  .header-notification-label {
    display: none;
  }

  .header-notification-btn {
    padding: 8px 10px;
  }

  .user-email {
    display: none;
  }

  .sidebar-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.35);
    z-index: 105;
    border: none;
    padding: 0;
  }
}

/* BNR beneficiary button — repeated at EOF so it wins over "Global button refresh" .btn rules */
.btn.btn-bnr-green {
  background: #059669 !important;
  color: #fff !important;
  border-color: #059669 !important;
}
.btn.btn-bnr-green:hover:not(:disabled) {
  background: #047857 !important;
  border-color: #047857 !important;
}
.btn.btn-bnr-red {
  background: #dc2626 !important;
  color: #fff !important;
  border-color: #dc2626 !important;
}
.btn.btn-bnr-red:hover:not(:disabled) {
  background: #b91c1c !important;
  border-color: #b91c1c !important;
}
.btn.btn-bnr-orange {
  background: #ea580c !important;
  color: #fff !important;
  border-color: #ea580c !important;
}
.btn.btn-bnr-orange:hover:not(:disabled) {
  background: #c2410c !important;
  border-color: #c2410c !important;
}

/* Global route loader (App Router loading.jsx) */
.app-route-loader {
  min-height: 100vh;
  width: 100%;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at 20% 10%, #eef4ff 0%, #f7f9fd 44%, #ffffff 100%);
  padding: 24px;
}

.app-route-loader .app-route-loader-card {
  min-width: min(92vw, 340px);
  border: 1px solid var(--neutral-200);
  border-radius: 14px;
  background: #ffffff;
  box-shadow: var(--shadow-md);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.app-route-loader .spinner {
  width: 22px;
  height: 22px;
  border-width: 3px;
}

.app-route-loader-title {
  margin: 0;
  font-size: 0.93rem;
  font-weight: 600;
  color: var(--neutral-800);
}

.app-route-loader-subtitle {
  margin: 2px 0 0 0;
  font-size: 0.8rem;
  color: var(--neutral-600);
}

.statement-review-loader {
  position: fixed;
  top: 84px;
  left: 50%;
  z-index: 1000;
  display: flex;
  min-width: min(420px, calc(100vw - 32px));
  max-width: calc(100vw - 32px);
  transform: translateX(-50%);
  align-items: center;
  gap: 12px;
  border: 1px solid #bfdbfe;
  border-radius: 16px;
  background: #eff6ff;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.18);
  color: #1e3a8a;
  padding: 14px 18px;
}

.statement-review-loader .spinner {
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  border-width: 3px;
  border-top-color: #1d4ed8;
}

.statement-review-loader-title,
.statement-review-loader-subtitle {
  display: block;
}

.statement-review-loader-title {
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.25;
}

.statement-review-loader-subtitle {
  margin-top: 2px;
  font-size: 0.78rem;
  color: #1d4ed8;
}

