/* Gintic Brand Styles - Static Validation Viewer */

/* === CSS Variables === */
:root {
  /* Base */
  --white: #ffffff;
  --black: #000000;

  /* Primary (Greens) */
  --primary-dark: #033A00;
  --primary-medium: #597D58;
  --primary-light: #9DB29C;
  --primary-lighter: #CDD7CD;
  --primary-lightest: #E9EEEA;

  /* Secondary (Blues) */
  --secondary-dark: #1F3A5F;
  --secondary-medium: #495F7D;
  --secondary-light: #A7B2BF;
  --secondary-lighter: #D1D7DC;
  --secondary-lightest: #EBEEEE;

  /* Neutral (Grays) */
  --neutral-dark: #0F1412;
  --neutral-medium: #707170;
  --neutral-light: #AEB1B0;
  --neutral-lighter: #DFE1E0;
  --neutral-lightest: #F3F5F4;

  /* Validation Status - Brand Colors */
  --status-block: #dc2626;
  --status-block-bg: #fef2f2;
  /* Flag uses Flipkart brand orange */
  --status-flag: #F57224;
  --status-flag-bg: #fff7ed;
  /* Note uses neutral grey from brand palette */
  --status-note: #707170;
  --status-note-bg: #F3F5F4;
  --status-passed: #033A00;
  --status-passed-bg: #ecfdf5;
  --status-skipped: #AEB1B0;
  --status-skipped-bg: #f5f5f5;

  /* Typography */
  --font-title: 'Space Grotesk', system-ui, sans-serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
  --font-mono: 'DM Mono', 'SF Mono', monospace;

  /* Spacing */
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;

  /* Border radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
}

/* === Reset & Base === */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  height: 100%;
  font-size: 110%;
}

body {
  min-height: 100%;
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.5;
  color: var(--neutral-dark);
  background: var(--neutral-lightest);
}

/* === Login Overlay === */
.login-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 20, 18, 0.85);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  transition: opacity 0.3s ease;
}

.login-overlay.hidden {
  opacity: 0;
  pointer-events: none;
}

.login-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: var(--spacing-xl);
  width: 100%;
  max-width: 360px;
  text-align: center;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.login-logo {
  height: 48px;
  margin-bottom: var(--spacing-lg);
}

.login-title {
  font-family: var(--font-title);
  font-size: 20px;
  font-weight: 700;
  color: var(--neutral-dark);
  margin-bottom: var(--spacing-xs);
}

.login-subtitle {
  font-size: 14px;
  color: var(--neutral-medium);
  margin-bottom: var(--spacing-lg);
}

.login-form {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.passcode-input {
  width: 100%;
  padding: var(--spacing-md);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-size: 16px;
  text-align: center;
  letter-spacing: 0.2em;
  transition: border-color 0.2s ease;
}

.passcode-input:focus {
  outline: none;
  border-color: var(--primary-dark);
}

.login-btn {
  width: 100%;
  padding: var(--spacing-md);
  background: linear-gradient(135deg, var(--primary-dark) 0%, #065f00 100%);
  color: var(--white);
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.login-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(3, 58, 0, 0.3);
}

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

.login-error {
  color: var(--status-block);
  font-size: 13px;
  margin-top: var(--spacing-sm);
}

.lockout-msg {
  color: var(--status-flag);
  font-size: 13px;
  margin-top: var(--spacing-sm);
}

/* === Header === */
.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-sm) var(--spacing-lg);
  background: white;
  border-bottom: 1px solid var(--neutral-lighter);
  flex-shrink: 0;
}

.header-left {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.logo {
  height: 28px;
  width: auto;
}

.header-title {
  font-family: var(--font-title);
  font-size: 18px;
  font-weight: 700;
  color: var(--neutral-dark);
  letter-spacing: -0.04em;
}

.header-partner {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding-left: var(--spacing-md);
  border-left: 1px solid var(--neutral-lighter);
}

.header-for {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  color: var(--neutral-medium);
}

.flipkart-logo, .partner-logo {
  height: 20px;
  width: auto;
}

.header-right {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

/* Navigation Tabs */
.nav-tabs {
  display: flex;
  align-items: center;
  gap: 0;
  background: var(--neutral-lightest);
  border-radius: var(--radius-md);
  padding: 3px;
}

.nav-tab {
  display: flex;
  align-items: center;
  padding: var(--spacing-sm) var(--spacing-md);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--neutral-medium);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
  transition: all 0.15s ease;
  white-space: nowrap;
}

.nav-tab:hover {
  color: var(--neutral-dark);
  background: var(--white);
}

.nav-tab.active {
  color: var(--primary-dark);
  background: var(--white);
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.nav-btn {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: var(--spacing-xs) var(--spacing-sm);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--neutral-dark);
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.15s ease;
}

.nav-btn:hover {
  background: var(--neutral-lightest);
  border-color: var(--neutral-light);
}

.nav-btn:active {
  background: var(--neutral-lighter);
}

.nav-icon {
  font-size: 14px;
}

.entry-selector {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.entry-dropdown {
  padding: var(--spacing-xs) var(--spacing-sm);
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--neutral-dark);
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  cursor: pointer;
  min-width: 140px;
  max-width: 240px;
}

.entry-counter {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--neutral-medium);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--neutral-lightest);
  border-radius: var(--radius-sm);
}

.entry-index-input {
  width: 36px;
  padding: 2px 4px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--neutral-dark);
  text-align: center;
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
}

.entry-index-input:focus {
  outline: none;
  border-color: var(--primary-medium);
  box-shadow: 0 0 0 2px rgba(3, 58, 0, 0.1);
}

.entry-total {
  color: var(--neutral-medium);
}

/* === Invoice Navigation Bar (below header) === */
.invoice-nav-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px var(--spacing-lg);
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
  flex-shrink: 0;
}

.invoice-nav-left {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.invoice-nav-right {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

/* === Metadata Bar === */
.metadata-bar {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  padding: var(--spacing-xs) var(--spacing-lg);
  background: white;
  border-bottom: 1px solid var(--neutral-lighter);
  flex-shrink: 0;
}

.meta-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.meta-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  color: var(--neutral-medium);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.meta-value {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--neutral-dark);
}

.meta-divider {
  width: 1px;
  height: 24px;
  background: var(--neutral-lighter);
}

.status-badge {
  display: inline-flex;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
}

.status-badge.blocked {
  background: var(--status-block-bg);
  color: var(--status-block);
}

.status-badge.passed {
  background: var(--status-passed-bg);
  color: var(--status-passed);
}

.status-badge.flagged {
  background: var(--status-flag-bg);
  color: var(--status-flag);
}

.status-badge.review {
  background: var(--status-note-bg);
  color: var(--status-note);
}

/* === Step Navigation === */
.step-nav {
  display: flex;
  gap: 0;
  padding: 0 var(--spacing-lg);
  background: white;
  border-bottom: 2px solid var(--neutral-lighter);
  flex-shrink: 0;
}

.step-tab {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm) var(--spacing-md);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--neutral-medium);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.step-tab:hover {
  color: var(--neutral-dark);
  background: var(--neutral-lightest);
}

.step-tab.active {
  color: var(--primary-dark);
  border-bottom-color: var(--primary-dark);
}

.step-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  font-size: 12px;
  font-weight: 600;
  background: var(--neutral-lighter);
  border-radius: 50%;
  transition: all 0.15s ease;
}

.step-tab.active .step-number {
  background: var(--primary-dark);
  color: white;
}

.step-name {
  font-weight: 600;
}

.step-badges-container {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.step-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  color: var(--white);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}

.step-badge-ok {
  background: var(--status-passed);
}

.step-badge-block {
  background: var(--status-block);
}

.step-badge-flag {
  background: var(--status-flag);
}

.rerun-btn {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 500;
  color: var(--neutral-medium);
  background: transparent;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.15s ease;
  margin-left: auto;
}

.rerun-btn:hover {
  color: var(--primary-dark);
  border-color: var(--primary-light);
  background: var(--primary-lightest);
}

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

.rerun-btn.loading .rerun-icon {
  animation: spin 1s linear infinite;
  display: inline-block;
}

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

.rerun-icon {
  font-size: 10px;
}

/* === Content Area === */
.content {
  padding: var(--spacing-sm) var(--spacing-md);
}

.step-content {
  display: none;
}

.step-content.active {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  padding: var(--spacing-sm) var(--spacing-lg) var(--spacing-lg);
}

/* Data step uses step-section now */
#step-data.step-content.active {
  padding: var(--spacing-sm) var(--spacing-lg) var(--spacing-lg);
  gap: var(--spacing-md);
}

/* === Document Discovery === */
.document-discovery {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  padding: var(--spacing-sm) var(--spacing-md);
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  flex-wrap: nowrap;
}

.discovery-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  flex-shrink: 0;
}

.discovery-icon {
  font-size: 14px;
}

.discovery-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  color: var(--neutral-medium);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.document-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: var(--spacing-xs);
  overflow-x: auto;
}

.doc-tab {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-md);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--neutral-dark);
  background: var(--neutral-lightest);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.15s ease;
  white-space: nowrap;
}

.doc-tab:hover {
  background: var(--primary-lightest);
  border-color: var(--primary-light);
}

.doc-tab.active {
  background: var(--primary-dark);
  color: white;
  border-color: var(--primary-dark);
}

.doc-tab.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* === Split View === */
.split-view {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
  min-height: 0;
}

/* Full width when only one pane has content */
.split-view.only-left {
  grid-template-columns: 1fr;
}

.split-view.only-right {
  grid-template-columns: 1fr;
}

.pane-left, .pane-right {
  display: flex;
  flex-direction: column;
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.pane-header {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--neutral-medium);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--spacing-md);
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
}

.pdf-container {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--neutral-lightest);
  /* Optimize for PDF rendering */
  contain: layout style;
}

.pdf-container iframe {
  width: 100%;
  height: 100%;
  border: none;
  /* Improve iframe rendering performance */
  will-change: contents;
}

.pdf-placeholder, .extraction-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-sm);
  color: var(--neutral-light);
}

.placeholder-icon {
  font-size: 48px;
  opacity: 0.5;
}

.placeholder-text {
  font-size: 14px;
}

.extracted-content {
  flex: 1;
  overflow: auto;
  padding: var(--spacing-md);
}

/* === Extracted Fields === */
.field-group {
  margin-bottom: var(--spacing-lg);
}

.field-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-sm) 0;
  border-bottom: 1px solid var(--neutral-lighter);
  margin-bottom: var(--spacing-md);
  cursor: pointer;
}

.header-actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.field-group-title {
  font-family: var(--font-title);
  font-size: 14px;
  font-weight: 600;
  color: var(--neutral-dark);
  letter-spacing: -0.02em;
}

.field-group-toggle {
  font-size: 12px;
  color: var(--neutral-medium);
}

.field-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--spacing-xs) 0;
  border-bottom: 1px solid var(--neutral-lightest);
}

.field-row:last-child {
  border-bottom: none;
}

.field-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--neutral-medium);
  text-transform: uppercase;
}

.field-value {
  font-size: 14px;
  color: var(--neutral-dark);
  word-break: break-word;
}

.field-value.mono {
  font-family: var(--font-mono);
  font-size: 13px;
}

.field-value.currency {
  font-weight: 600;
  color: var(--primary-dark);
}

.field-value-input {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  font-family: var(--font-mono);
  font-size: 13px;
  padding: 4px 8px;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  background: white;
}

.field-value-input:focus {
  outline: none;
  border-color: var(--primary-medium);
}

.field-value-input.modified {
  background: #fffbeb;
  border-color: var(--status-flag);
}

/* === Summary Cards (Accounting/Payment) === */
.summary-card {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-left: 3px solid var(--primary-dark);
  border-radius: var(--radius-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.summary-card:hover {
  background: var(--primary-lightest);
  border-left-color: var(--primary-medium);
}

/* === Contract Summary (Agent Output) === */
.contract-summary-group {
  background: var(--neutral-lightest);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
}

.contract-summary-group .field-group-header {
  border-bottom: none;
  margin-bottom: var(--spacing-sm);
}

.contract-summary-group .field-group-title::before {
  content: "🤖 ";
  font-size: 14px;
}

.contract-summary-content {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  padding: var(--spacing-md);
  font-size: 13px;
  line-height: 1.6;
}

.contract-summary-content h1,
.contract-summary-content h2,
.contract-summary-content h3 {
  font-family: var(--font-title);
  color: var(--neutral-dark);
  margin-top: var(--spacing-md);
  margin-bottom: var(--spacing-sm);
}

.contract-summary-content h1 { font-size: 20px; }
.contract-summary-content h2 { font-size: 16px; border-bottom: 1px solid var(--neutral-lighter); padding-bottom: var(--spacing-xs); }
.contract-summary-content h3 { font-size: 14px; font-weight: 600; }

.contract-summary-content table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--spacing-sm) 0;
  font-size: 12px;
}

.contract-summary-content th,
.contract-summary-content td {
  padding: var(--spacing-xs) var(--spacing-sm);
  border: 1px solid var(--neutral-lighter);
  text-align: left;
}

.contract-summary-content th {
  background: var(--neutral-lightest);
  font-weight: 600;
}

.contract-summary-content hr {
  border: none;
  border-top: 1px solid var(--neutral-lighter);
  margin: var(--spacing-md) 0;
}

.summary-expand-btn {
  display: inline-block;
  margin-top: var(--spacing-sm);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--neutral-lightest);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  font-size: 12px;
  color: var(--neutral-medium);
  cursor: pointer;
}

.summary-expand-btn:hover {
  background: var(--primary-lightest);
  color: var(--primary-dark);
}

.summary-card-label {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 500;
  color: var(--neutral-medium);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.summary-card-value {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--neutral-dark);
}

.summary-card.highlight {
  background: linear-gradient(135deg, var(--primary-lightest) 0%, #e8f5e8 100%);
  border-color: var(--primary-light);
}

.summary-card.highlight .summary-card-label {
  color: var(--primary-dark);
  font-weight: 600;
}

.summary-card.highlight .summary-card-value {
  font-family: var(--font-title);
  font-size: 18px;
  font-weight: 700;
  color: var(--primary-dark);
}

.summary-card.delta-positive {
  border-color: var(--status-flag);
}

.summary-card.delta-positive .summary-card-value {
  color: var(--status-flag);
}

.summary-card-value.currency {
  font-family: var(--font-mono);
  color: var(--primary-dark);
}

/* === Line Items Table === */
.line-items-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--spacing-md);
  font-size: 13px;
}

.line-items-table th {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  color: var(--neutral-medium);
  text-transform: uppercase;
  text-align: left;
  padding: var(--spacing-sm);
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
}

.line-items-table td {
  padding: var(--spacing-sm);
  border-bottom: 1px solid var(--neutral-lightest);
  vertical-align: top;
}

.line-items-table tr:hover td {
  background: var(--primary-lightest);
}

.line-items-table .col-num {
  width: 40px;
  text-align: center;
  color: var(--neutral-medium);
}

.line-items-table .col-amount {
  text-align: right;
  font-family: var(--font-mono);
  font-weight: 500;
}

/* Line Items Table Wrapper for horizontal scroll */
.line-items-table-wrapper {
  overflow-x: auto;
  margin-bottom: var(--spacing-md);
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  padding: var(--spacing-sm);
}

/* GST Table Styling */
.gst-table-group {
  margin-top: var(--spacing-lg);
  border-top: 1px solid var(--neutral-lighter);
  padding-top: var(--spacing-md);
}

.gst-table th,
.gst-table td {
  font-size: 12px;
  padding: var(--spacing-xs) var(--spacing-sm);
  white-space: nowrap;
}

.gst-table .col-gst-rate {
  text-align: center;
  color: var(--neutral-medium);
  min-width: 50px;
}

.gst-table .col-desc-short {
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.gst-table .col-total-tax {
  font-weight: 600;
  color: var(--primary-dark);
  background: var(--primary-lightest);
}

.gst-totals-row {
  background: var(--neutral-lightest) !important;
  font-weight: 600;
}

.gst-totals-row:hover td {
  background: var(--neutral-lightest) !important;
}

.gst-totals-label {
  text-align: right !important;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--neutral-dark);
}

/* === Rules Section === */
.rules-section {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.rules-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-md);
}

.rules-header h2 {
  font-family: var(--font-title);
  font-size: 18px;
  font-weight: 700;
  color: var(--neutral-dark);
  letter-spacing: -0.04em;
  margin: 0;
}

.rules-summary {
  display: flex;
  gap: var(--spacing-md);
}

.summary-badge {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
}

.summary-badge.passed {
  background: var(--status-passed-bg);
  color: var(--status-passed);
}

.summary-badge.failed {
  background: var(--status-block-bg);
  color: var(--status-block);
}

.summary-badge.blocked {
  background: var(--status-block-bg);
  color: var(--status-block);
}

.summary-badge.flagged {
  background: var(--status-flag-bg);
  color: var(--status-flag);
}

.summary-badge.noted {
  background: var(--status-note-bg);
  color: var(--status-note);
}

.summary-badge.skipped {
  background: var(--neutral-lightest);
  color: var(--neutral-medium);
}

.rules-container {
  flex: 1;
  overflow: auto;
}

/* === Rules Groups === */
.rules-group {
  margin-bottom: var(--spacing-lg);
}

.rules-group-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-md);
  cursor: pointer;
}

.rules-group-header.failed {
  background: var(--status-block-bg);
  color: var(--status-block);
}

.rules-group-header.passed {
  background: var(--status-passed-bg);
  color: var(--status-passed);
}

.rules-group-header.skipped {
  background: var(--neutral-100);
  color: var(--neutral-500);
}

.rules-group-title {
  font-weight: 600;
  font-size: 14px;
}

.rules-group-count {
  font-size: 12px;
  opacity: 0.8;
}

.rules-group-toggle {
  margin-left: auto;
  font-size: 12px;
}

.rules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--spacing-sm);
  align-items: start; /* Prevent cards from stretching to match row height */
}

/* === Rule Card === */
.rule-card {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all 0.15s ease;
}

.rule-card:hover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.rule-card.block {
  border-left: 4px solid var(--status-block);
}

.rule-card.flag {
  border-left: 4px solid var(--status-flag);
}

.rule-card.note {
  border-left: 4px solid var(--status-note);
}

.rule-card.passed {
  border-left: 4px solid var(--status-passed);
}

.rule-card.skipped {
  border-left: 4px solid var(--status-skipped);
}

.rule-card-header {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  padding: var(--spacing-md);
  cursor: pointer;
  transition: background-color 0.15s;
}

.rule-card-header:hover {
  background-color: var(--neutral-50);
}

.rule-icon {
  font-size: 16px;
  flex-shrink: 0;
}

.rule-card.block .rule-icon { color: var(--status-block); }
.rule-card.flag .rule-icon { color: var(--status-flag); }
.rule-card.note .rule-icon { color: var(--status-note); }
.rule-card.passed .rule-icon { color: var(--status-passed); }
.rule-card.skipped .rule-icon { color: var(--status-skipped); }

.rule-info {
  flex: 1;
  min-width: 0;
}

.rule-name {
  font-weight: 600;
  font-size: 14px;
  color: var(--neutral-dark);
  margin-bottom: 2px;
}

.rule-breach {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.rule-card.block .rule-breach { color: var(--status-block); }
.rule-card.flag .rule-breach { color: var(--status-flag); }
.rule-card.note .rule-breach { color: var(--status-note); }
.rule-card.passed .rule-breach { color: var(--status-passed); }
.rule-card.skipped .rule-breach { color: var(--status-skipped); }

.rule-expand {
  font-size: 12px;
  color: var(--neutral-medium);
  flex-shrink: 0;
}

.rule-card-body {
  display: none;
  padding: 0 var(--spacing-md) var(--spacing-md);
  border-top: 1px solid var(--neutral-lightest);
}

.rule-card.expanded .rule-card-body {
  display: block;
}

.rule-output {
  font-size: 13px;
  color: var(--neutral-700);
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.6;
  max-height: 300px;
  overflow-y: auto;
  padding: var(--spacing-sm);
  background: var(--neutral-50);
  border-radius: var(--radius-sm);
  user-select: text;
  cursor: text;
}

.rule-resolution {
  margin-top: var(--spacing-md);
  padding: var(--spacing-sm);
  background: var(--status-flag-bg);
  border-radius: var(--radius-sm);
  font-size: 12px;
}

.rules-title-wrap {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.rule-resolution-title {
  font-weight: 600;
  color: var(--status-flag);
  margin-bottom: var(--spacing-xs);
}

/* === Placeholder Section === */
.placeholder-section {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--neutral-medium);
}

.placeholder-icon-large {
  font-size: 64px;
  opacity: 0.3;
  margin-bottom: var(--spacing-lg);
}

.placeholder-section h2 {
  font-family: var(--font-title);
  font-size: 24px;
  font-weight: 700;
  color: var(--neutral-dark);
  margin-bottom: var(--spacing-sm);
}

.placeholder-section p {
  max-width: 400px;
  line-height: 1.6;
}

/* === Collapsible === */
.collapsible-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: var(--spacing-sm);
  background: var(--neutral-lightest);
  border-radius: var(--radius-sm);
  margin-bottom: var(--spacing-sm);
}

.collapsible-header:hover {
  background: var(--neutral-lighter);
}

.collapsible-content {
  display: none;
}

.collapsible.open .collapsible-content {
  display: block;
}

/* === Excel Viewer === */
.excel-viewer {
  height: 100%;
  display: flex;
  flex-direction: column;
  background: var(--white);
  overflow: hidden;
}

.excel-sheet-tabs {
  display: flex;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm);
  background: var(--neutral-50);
  border-bottom: 1px solid var(--neutral-200);
  overflow-x: auto;
  flex-shrink: 0;
}

.excel-sheet-tab {
  padding: var(--spacing-xs) var(--spacing-md);
  background: var(--white);
  border: 1px solid var(--neutral-200);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
}

.excel-sheet-tab:hover {
  background: var(--neutral-100);
}

.excel-sheet-tab.active {
  background: var(--primary-dark);
  color: var(--white);
  border-color: var(--primary-dark);
}

.excel-sheets-container {
  flex: 1;
  overflow: auto;
}

.excel-sheet-content {
  display: none;
  padding: var(--spacing-sm);
}

.excel-sheet-content.active {
  display: block;
}

.excel-sheet-content table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 11px;
}

.excel-sheet-content th,
.excel-sheet-content td {
  border: 1px solid var(--neutral-200);
  padding: var(--spacing-xs) var(--spacing-sm);
  text-align: left;
  white-space: nowrap;
  max-width: 300px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.excel-sheet-content th {
  background: var(--neutral-100);
  font-weight: 600;
  color: var(--neutral-700);
  position: sticky;
  top: 0;
  z-index: 1;
}

.excel-sheet-content tr:nth-child(even) {
  background: var(--neutral-50);
}

.excel-sheet-content tr:hover {
  background: var(--primary-50);
}

/* === Copilot === */
.copilot-fab {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--secondary-dark);
  border: none;
  box-shadow: 0 4px 16px rgba(31, 58, 95, 0.4);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  transition: all 0.3s ease;
}

.copilot-fab:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 24px rgba(31, 58, 95, 0.5);
  background: var(--secondary-medium);
}

.copilot-fab-icon {
  width: 24px;
  height: 24px;
}

.copilot-panel {
  position: fixed;
  right: 24px;
  bottom: 96px;
  width: 400px;
  max-width: calc(100vw - 48px);
  height: 500px;
  max-height: calc(100vh - 150px);
  background: #ffffff;
  border: 1px solid #DFE1E0;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
  display: flex;
  flex-direction: column;
  z-index: 10000;
  overflow: hidden;
}

.copilot-header {
  background: var(--secondary-dark);
  color: var(--white);
  padding: var(--spacing-sm) var(--spacing-md);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.copilot-title {
  font-family: var(--font-title);
  font-weight: 600;
  font-size: 14px;
}

.copilot-header-actions {
  display: flex;
  gap: var(--spacing-xs);
}

.copilot-close {
  background: rgba(255, 255, 255, 0.2);
  border: none;
  color: var(--white);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.copilot-close:hover {
  background: rgba(255, 255, 255, 0.3);
}

.copilot-messages {
  flex: 1;
  overflow-y: auto;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: #F3F5F4;
  min-height: 100px;
}

.copilot-welcome {
  background: var(--white);
  border: 1px solid var(--neutral-200);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  font-size: 13px;
  color: var(--neutral-600);
  line-height: 1.6;
}

.copilot-welcome p {
  margin: 0 0 var(--spacing-xs) 0;
}

.copilot-welcome p:last-child {
  margin: 0;
}

.copilot-message {
  max-width: 85%;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 13px;
  line-height: 1.5;
  word-wrap: break-word;
  display: block;
}

.copilot-message.user {
  align-self: flex-end;
  background: #033A00;
  color: #ffffff;
  border-bottom-right-radius: 4px;
  min-width: 40px;
  display: block;
}

.copilot-message.assistant {
  align-self: flex-start;
  background: var(--white);
  color: var(--neutral-800);
  border: 1px solid var(--neutral-200);
  border-bottom-left-radius: 4px;
}

.copilot-message.assistant strong {
  color: #033A00;
}

.copilot-message.assistant code {
  background: #F3F5F4;
  padding: 2px 6px;
  border-radius: 4px;
  font-family: var(--font-mono, monospace);
  font-size: 12px;
}

/* Markdown headers in copilot */
.copilot-h2 {
  font-size: 16px;
  font-weight: 700;
  margin: 12px 0 8px 0;
  color: #0F1412;
  border-bottom: 1px solid #DFE1E0;
  padding-bottom: 4px;
}

.copilot-h3 {
  font-size: 14px;
  font-weight: 600;
  margin: 10px 0 6px 0;
  color: #0F1412;
}

.copilot-h4 {
  font-size: 13px;
  font-weight: 600;
  margin: 8px 0 4px 0;
  color: #495F7D;
}

.copilot-list {
  margin: 8px 0;
  padding-left: 20px;
}

.copilot-list li {
  margin: 4px 0;
}

.copilot-code {
  background: #1F3A5F;
  color: #E6EDF3;
  padding: 10px;
  border-radius: 6px;
  overflow-x: auto;
  font-size: 11px;
  margin: 8px 0;
}

.copilot-code code {
  background: none;
  padding: 0;
  color: inherit;
}

.copilot-table-wrapper {
  overflow-x: auto;
  max-width: 100%;
  margin: 8px 0;
}

.copilot-table {
  width: max-content;
  min-width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  border: 1px solid #DFE1E0;
}

.copilot-table th,
.copilot-table td {
  border: 1px solid #DFE1E0;
  padding: 6px 8px;
  text-align: left;
  white-space: nowrap;
}

.copilot-table th {
  background: #1F3A5F;
  color: #ffffff;
  font-weight: 600;
}

.copilot-table tr:nth-child(even) {
  background: #F3F5F4;
}

.copilot-table tr:hover {
  background: #E9EEEA;
}

.copilot-hr {
  border: none;
  border-top: 1px solid #DFE1E0;
  margin: 12px 0;
}

.copilot-message.error {
  align-self: flex-start;
  background: #fef2f2;
  color: #dc2626;
  border: 1px solid #fecaca;
}

.copilot-message.loading,
.copilot-message.thinking {
  align-self: flex-start;
  background: #ffffff;
  color: #707170;
  border: 1px solid #DFE1E0;
}

.thinking-content {
  display: flex;
  align-items: center;
  gap: 8px;
  font-style: italic;
  color: #707170;
}

.thinking-label {
  font-weight: 500;
}

.thinking-dots {
  display: inline-block;
  width: 20px;
  height: 8px;
  background: linear-gradient(90deg, #707170 25%, transparent 25%) 0 0 / 8px 8px;
  animation: thinking-pulse 1s infinite;
}

.thinking-stream {
  margin-top: 8px;
  padding: 8px;
  background: #f8f9fa;
  border-left: 3px solid #707170;
  font-size: 11px;
  font-family: var(--font-mono, monospace);
  color: #495F7D;
  max-height: 100px;
  overflow-y: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

@keyframes thinking-pulse {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 1; }
}

/* Reasoning toggle */
.reasoning-toggle {
  margin-top: 12px;
  border-top: 1px solid #DFE1E0;
  padding-top: 8px;
}

.reasoning-toggle summary {
  cursor: pointer;
  font-size: 12px;
  color: #495F7D;
  user-select: none;
}

.reasoning-toggle summary:hover {
  color: #1F3A5F;
}

.reasoning-content {
  margin-top: 8px;
  padding: 8px;
  background: #f8f9fa;
  border-left: 3px solid #495F7D;
  font-size: 11px;
  font-family: var(--font-mono, monospace);
  color: #495F7D;
  max-height: 200px;
  overflow-y: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

.copilot-input-area {
  padding: var(--spacing-sm);
  border-top: 1px solid var(--neutral-200);
  display: flex;
  gap: var(--spacing-sm);
  background: var(--white);
}

.copilot-input-area textarea {
  flex: 1;
  padding: var(--spacing-sm);
  border: 1px solid var(--neutral-200);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 13px;
  resize: none;
  outline: none;
}

.copilot-input-area textarea:focus {
  border-color: var(--primary-400);
}

.copilot-send {
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--secondary-dark);
  color: var(--white);
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
}

.copilot-send:hover {
  background: var(--secondary-medium);
}

.copilot-send:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Typing indicator */
.typing-indicator {
  display: flex;
  gap: 4px;
  padding: var(--spacing-xs);
}

.typing-indicator span {
  width: 8px;
  height: 8px;
  background: var(--neutral-400);
  border-radius: 50%;
  animation: typing 1.4s infinite ease-in-out;
}

.typing-indicator span:nth-child(2) { animation-delay: 0.2s; }
.typing-indicator span:nth-child(3) { animation-delay: 0.4s; }

@keyframes typing {
  0%, 60%, 100% { transform: translateY(0); }
  30% { transform: translateY(-4px); }
}

/* === Responsive === */
@media (max-width: 1024px) {
  .split-view {
    grid-template-columns: 1fr;
  }
  
  .rules-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .header {
    flex-direction: column;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
  }
  
  .metadata-bar {
    flex-wrap: wrap;
    gap: var(--spacing-md);
  }
  
  .meta-divider {
    display: none;
  }
  
  .step-nav {
    overflow-x: auto;
    padding: 0 var(--spacing-md);
  }
  
  .step-tab {
    padding: var(--spacing-sm) var(--spacing-md);
    white-space: nowrap;
  }
  
  .step-name {
    display: none;
  }
}

/* ========================================
   Accounting Step Styles
   ======================================== */

.accounting-section {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.accounting-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-md);
}

.accounting-header h2 {
  font-family: var(--font-title);
  font-size: 18px;
  font-weight: 700;
  color: var(--neutral-dark);
  letter-spacing: -0.04em;
  margin: 0;
}

.accounting-status {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.acc-status-badge {
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
}

.acc-status-badge.completed {
  background: var(--status-passed-bg);
  color: var(--status-passed);
}

.acc-status-badge.pending {
  background: var(--status-flag-bg);
  color: var(--status-flag);
}

.acc-status-badge.none {
  background: var(--neutral-lightest);
  color: var(--neutral-medium);
}

.acc-timestamp {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--neutral-medium);
}

.save-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--primary-dark);
  color: var(--white);
  border: none;
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  margin-left: auto;
}

.save-btn:hover { background: var(--primary-medium); }
.save-btn:disabled { opacity: 0.6; cursor: not-allowed; }

.accounting-container {
  flex: 1;
  overflow: auto;
}

.accounting-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  color: var(--neutral-light);
  min-height: 200px;
}

/* Oracle Entry Card */
.oracle-entry-card {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--spacing-lg);
}

.oracle-header {
  padding: var(--spacing-md) var(--spacing-lg);
  background: linear-gradient(135deg, var(--secondary-dark) 0%, var(--secondary-medium) 100%);
  color: white;
}

.oracle-title {
  font-family: var(--font-title);
  font-size: 16px;
  font-weight: 600;
}

.oracle-body { padding: var(--spacing-lg); }

.oracle-key-fields {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}

.oracle-field {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm);
  background: var(--neutral-lightest);
  border-radius: var(--radius-md);
}

.oracle-field:hover { background: var(--primary-lightest); }

.oracle-field-content { flex: 1; min-width: 0; }

.oracle-field-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--neutral-medium);
  text-transform: uppercase;
  margin-bottom: 2px;
}

.oracle-field-value {
  width: 100%;
  padding: 4px 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--neutral-dark);
  background: white;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
}

.oracle-field-value:hover { border-color: var(--neutral-lighter); }
.oracle-field-value:focus { outline: none; border-color: var(--primary-medium); box-shadow: 0 0 0 3px rgba(3, 58, 0, 0.1); }
.oracle-field-value.modified { background: #fffbeb; border-color: var(--status-flag); }

/* GST Summary */
.oracle-gst-summary {
  padding: var(--spacing-md);
  background: var(--neutral-lightest);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-lg);
}

.oracle-gst-title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--neutral-medium);
  text-transform: uppercase;
  margin-bottom: var(--spacing-sm);
}

.oracle-gst-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-md);
}

.oracle-gst-item { text-align: center; }

.oracle-gst-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--neutral-medium);
  margin-bottom: 4px;
}

.oracle-gst-value {
  width: 100%;
  padding: 6px;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 600;
  color: var(--primary-dark);
  background: white;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  text-align: center;
}

.oracle-gst-value:focus { outline: none; border-color: var(--primary-medium); }
.oracle-gst-value.modified { background: #fffbeb; border-color: var(--status-flag); }

/* GL Codes Table */
.oracle-gl-section { margin-bottom: var(--spacing-lg); }

.oracle-gl-title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--neutral-medium);
  text-transform: uppercase;
  margin-bottom: var(--spacing-sm);
}

.oracle-gl-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.oracle-gl-table th {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  color: var(--neutral-medium);
  text-transform: uppercase;
  text-align: left;
  padding: var(--spacing-sm);
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
}

.oracle-gl-table td {
  padding: var(--spacing-sm);
  border-bottom: 1px solid var(--neutral-lightest);
}

.oracle-gl-table tr:hover td { background: var(--primary-lightest); }
.oracle-gl-table .col-num { width: 40px; text-align: center; color: var(--neutral-medium); }
.oracle-gl-table .col-amount { text-align: right; font-family: var(--font-mono); font-weight: 500; }

.gl-code-input {
  width: 80px;
  padding: 4px 8px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--secondary-dark);
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  text-align: center;
}

.gl-code-input:focus { outline: none; border-color: var(--primary-medium); }
.gl-code-input.modified { background: #fffbeb; border-color: var(--status-flag); }

/* GST Input */
.gst-input {
  font-family: var(--font-mono);
  font-size: 13px;
  padding: 6px 10px;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  background: transparent;
  text-align: right;
  width: 120px;
}

.gst-input:focus { outline: none; border-color: var(--primary-medium); }
.gst-input.modified { background: #fffbeb; border-color: var(--status-flag); }
.gst-input.total { font-weight: 700; color: var(--primary-dark); }

/* Header SPOC (inline in field-group-header) */
.header-spoc {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--neutral-medium);
}

.header-spoc .spoc-label {
  font-weight: 600;
  color: var(--neutral-dark);
}

/* Total Row for Tables */
.total-row td {
  font-weight: 600;
  background: var(--primary-lightest);
}

/* SPOC Section */
.oracle-spoc {
  padding: var(--spacing-md);
  background: var(--primary-lightest);
  border-radius: var(--radius-md);
  border-left: 4px solid var(--primary-dark);
}

.oracle-spoc-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  color: var(--primary-dark);
  text-transform: uppercase;
  margin-bottom: var(--spacing-xs);
}

.oracle-spoc-name { font-weight: 600; color: var(--neutral-dark); }
.oracle-spoc-email { font-size: 13px; color: var(--neutral-medium); }

/* Account Entry Results */
.account-results-section { margin-top: var(--spacing-lg); }

.account-results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-md);
}

.account-results-title {
  font-family: var(--font-title);
  font-size: 16px;
  font-weight: 600;
  color: var(--neutral-dark);
}

.account-results-count {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--neutral-medium);
  background: var(--neutral-lightest);
  padding: 4px 8px;
  border-radius: var(--radius-sm);
}

.account-results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
  gap: var(--spacing-md);
}

.account-result-card {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.account-result-card:hover { box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08); }

.account-result-header {
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
}

.account-field-name {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--secondary-dark);
  text-transform: uppercase;
}

.account-result-body { padding: var(--spacing-md); }
.account-value-row { margin-bottom: var(--spacing-sm); }
.account-value-label { display: block; font-size: 11px; color: var(--neutral-medium); margin-bottom: 4px; }

.account-value-input {
  width: 100%;
  padding: 8px 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--neutral-dark);
  background: var(--neutral-lightest);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
}

.account-value-input:hover { background: white; border-color: var(--neutral-lighter); }
.account-value-input:focus { outline: none; background: white; border-color: var(--primary-medium); }
.account-value-input.modified { background: #fffbeb; border-color: var(--status-flag); }

.account-value-complex { padding: var(--spacing-sm); background: var(--neutral-lightest); border-radius: var(--radius-sm); font-size: 13px; }

.account-gl-mini { display: flex; flex-direction: column; gap: 4px; }
.account-gl-row { display: flex; align-items: center; gap: var(--spacing-sm); }

.gl-code-badge {
  padding: 2px 8px;
  background: var(--secondary-dark);
  color: white;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
}

.gl-amount { font-family: var(--font-mono); font-size: 12px; color: var(--neutral-medium); }

.account-explanation { padding-top: var(--spacing-sm); border-top: 1px solid var(--neutral-lightest); }
.account-explanation-label { display: block; font-size: 11px; color: var(--neutral-medium); margin-bottom: 4px; }
.account-explanation-text { font-size: 12px; color: var(--neutral-700); line-height: 1.5; max-height: 80px; overflow-y: auto; }

.acc-status-badge.edited {
  background: var(--status-flag-bg);
  color: var(--status-flag);
}

/* ========================================
   Payment Step Styles
   ======================================== */

.payment-section {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.payment-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-md);
}

.payment-header h2 {
  font-family: var(--font-title);
  font-size: 18px;
  font-weight: 700;
  color: var(--neutral-dark);
  letter-spacing: -0.04em;
  margin: 0;
}

.payment-status {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.pay-status-badge {
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
}

.pay-status-badge.completed { background: var(--status-passed-bg); color: var(--status-passed); }
.pay-status-badge.pending { background: var(--status-flag-bg); color: var(--status-flag); }
.pay-status-badge.none { background: var(--neutral-lightest); color: var(--neutral-medium); }
.pay-status-badge.edited { background: var(--status-flag-bg); color: var(--status-flag); }

.pay-timestamp {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--neutral-medium);
}

.payment-container { flex: 1; overflow: auto; }

.payment-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  color: var(--neutral-light);
  min-height: 200px;
}

/* Payment Entry Card */
.payment-entry-card {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--spacing-lg);
}

/* Net Payable Hero Section */
.payment-hero {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-xl);
  background: linear-gradient(135deg, var(--primary-dark) 0%, #065f00 100%);
  color: white;
}

.payment-hero-main { flex: 1; }

.payment-hero-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.9;
  margin-bottom: 4px;
}

.payment-hero-amount {
  font-family: var(--font-title);
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.payment-hero-breakdown {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-sm);
  font-size: 13px;
  opacity: 0.85;
}

.breakdown-operator { opacity: 0.6; }
.breakdown-item.tds { color: #fbbf24; }

.payment-hero-due {
  text-align: right;
  padding-left: var(--spacing-lg);
  border-left: 1px solid rgba(255,255,255,0.2);
}

.due-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.8;
}

.due-date {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 600;
  margin: 4px 0;
}

.due-date.overdue { color: #ef4444; }

.due-days {
  font-size: 12px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.15);
}

.due-days.urgent { background: #fbbf24; color: #000; }
.due-days.overdue { background: #ef4444; color: #fff; }

/* Payment Due Card (right side of hero) */
.payment-due-card {
  text-align: right;
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
}

.payment-due-card.urgent {
  background: rgba(251, 191, 36, 0.15);
  border-color: rgba(251, 191, 36, 0.4);
}

.payment-due-card.overdue {
  background: rgba(239, 68, 68, 0.15);
  border-color: rgba(239, 68, 68, 0.4);
}

.due-date-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.8;
  margin-bottom: 4px;
}

.due-date-value {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 600;
}

.due-date-status {
  font-size: 12px;
  margin-top: 4px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.15);
  display: inline-block;
}

.payment-due-card.urgent .due-date-status {
  background: #fbbf24;
  color: #000;
}

.payment-due-card.overdue .due-date-status {
  background: #ef4444;
  color: #fff;
}

/* Breakdown Cards (below hero) */
.payment-breakdown-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-md);
  margin-top: var(--spacing-md);
}

.breakdown-card {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  padding: var(--spacing-lg);
}

.breakdown-card-label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--neutral-medium);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: var(--spacing-xs);
}

.breakdown-card-value {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 600;
  color: var(--neutral-dark);
}

.breakdown-card.tds .breakdown-card-value {
  color: var(--status-flag);
}

.breakdown-card.rcm .breakdown-card-value {
  color: var(--status-block);
}

.payment-header-bar {
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
}

.payment-title {
  font-family: var(--font-title);
  font-size: 14px;
  font-weight: 600;
  color: var(--neutral-dark);
}

.payment-body { padding: var(--spacing-lg); }

.payment-section-title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--neutral-medium);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: var(--spacing-lg) 0 var(--spacing-sm) 0;
  padding-bottom: var(--spacing-xs);
  border-bottom: 1px solid var(--neutral-lighter);
}

.payment-section-title:first-child { margin-top: 0; }

.payment-fields-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--spacing-sm);
}

.payment-field {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm);
  background: var(--neutral-lightest);
  border-radius: var(--radius-sm);
}

.payment-field:hover { background: var(--primary-lightest); }

.payment-field-icon { font-size: 16px; flex-shrink: 0; }

.payment-field-content { flex: 1; min-width: 0; }

.payment-field-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--neutral-medium);
  text-transform: uppercase;
  margin-bottom: 2px;
}

.payment-field-value {
  width: 100%;
  padding: 2px 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--neutral-dark);
  background: white;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
}

.payment-field-value:hover { border-color: var(--neutral-lighter); }
.payment-field-value:focus { outline: none; border-color: var(--primary-medium); }
.payment-field-value.modified { background: #fffbeb; border-color: var(--status-flag); }

/* Amount Breakdown Grid */
.payment-amounts-grid {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  background: var(--neutral-lightest);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
}

.payment-amount-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-xs) 0;
}

.payment-amount-item.highlight {
  padding: var(--spacing-sm) 0;
  border-top: 1px solid var(--neutral-lighter);
  margin-top: var(--spacing-xs);
}

.payment-amount-item.hero {
  background: var(--primary-dark);
  color: white;
  margin: var(--spacing-sm) calc(-1 * var(--spacing-md));
  margin-bottom: calc(-1 * var(--spacing-md));
  padding: var(--spacing-md);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.payment-amount-item.negative .amount-value { color: var(--status-flag); }

.amount-label { font-size: 13px; color: var(--neutral-medium); }
.payment-amount-item.hero .amount-label { color: rgba(255,255,255,0.8); }

.amount-value {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 600;
  text-align: right;
  padding: 4px 8px;
  background: white;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  width: 140px;
}

.payment-amount-item.hero .amount-value {
  background: rgba(255,255,255,0.15);
  color: white;
  font-size: 18px;
}

.amount-value:focus { outline: none; border-color: var(--primary-medium); }
.amount-value.modified { background: #fffbeb; border-color: var(--status-flag); }

.payment-spoc {
  padding: var(--spacing-md);
  background: var(--primary-lightest);
  border-radius: var(--radius-md);
  border-left: 4px solid var(--primary-dark);
}

.spoc-name { font-weight: 600; color: var(--neutral-dark); }
.spoc-email, .spoc-phone { font-size: 13px; color: var(--neutral-medium); margin-top: 2px; }

/* Pay Entry Results */
.pay-results-section { margin-top: var(--spacing-lg); }

.pay-results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-md);
}

.pay-results-title {
  font-family: var(--font-title);
  font-size: 16px;
  font-weight: 600;
  color: var(--neutral-dark);
}

.pay-results-count {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--neutral-medium);
  background: var(--neutral-lightest);
  padding: 4px 8px;
  border-radius: var(--radius-sm);
}

.pay-results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--spacing-md);
}

.pay-result-card {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.pay-result-card:hover { box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08); }

.pay-result-header {
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
}

.pay-field-name {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--secondary-dark);
  text-transform: uppercase;
}

.pay-result-body { padding: var(--spacing-md); }
.pay-value-row { margin-bottom: var(--spacing-sm); }
.pay-value-label { display: block; font-size: 10px; color: var(--neutral-medium); margin-bottom: 4px; }

.pay-value-input {
  width: 100%;
  padding: 6px 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--neutral-dark);
  background: var(--neutral-lightest);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
}

.pay-value-input:hover { background: white; border-color: var(--neutral-lighter); }
.pay-value-input:focus { outline: none; background: white; border-color: var(--primary-medium); }
.pay-value-input.modified { background: #fffbeb; border-color: var(--status-flag); }

.pay-value-complex {
  padding: var(--spacing-sm);
  background: var(--neutral-lightest);
  border-radius: var(--radius-sm);
  font-size: 12px;
  word-break: break-word;
}

.pay-explanation { padding-top: var(--spacing-sm); border-top: 1px solid var(--neutral-lightest); }
.pay-explanation-label { display: block; font-size: 10px; color: var(--neutral-medium); margin-bottom: 4px; }
.pay-explanation-text { font-size: 11px; color: var(--neutral-600); line-height: 1.4; }

/* Updated Payment Layout */
.payment-top-banner {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
}

.payment-vendor-info {
  flex: 1;
  padding: var(--spacing-lg);
}

.vendor-main {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}

.vendor-name {
  font-family: var(--font-title);
  font-size: 22px;
  font-weight: 700;
  color: var(--neutral-dark);
}

.vendor-code {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--neutral-medium);
  background: white;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--neutral-lighter);
}

.msme-badge {
  background: var(--secondary-dark);
  color: white;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.vendor-invoice {
  margin-top: var(--spacing-xs);
  font-size: 13px;
  color: var(--neutral-medium);
}

.vendor-invoice strong {
  color: var(--neutral-dark);
  font-family: var(--font-mono);
}

.payment-due-info {
  padding: var(--spacing-lg);
  background: var(--primary-lightest);
  border-left: 4px solid var(--primary-dark);
  text-align: center;
  min-width: 160px;
}

.payment-due-info.urgent {
  background: #fef3c7;
  border-left-color: #f59e0b;
}

.payment-due-info.overdue {
  background: #fef2f2;
  border-left-color: #ef4444;
}

.payment-due-info .due-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--neutral-medium);
}

.payment-due-info .due-date {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--primary-dark);
  margin: 4px 0;
}

.payment-due-info.overdue .due-date { color: #ef4444; }

.payment-due-info .due-status {
  font-size: 11px;
  font-weight: 600;
  color: var(--primary-dark);
}

.payment-due-info.urgent .due-status { color: #f59e0b; }
.payment-due-info.overdue .due-status { color: #ef4444; }

/* Updated Payment Hero */
.payment-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-lg) var(--spacing-xl);
  background: linear-gradient(135deg, var(--primary-dark) 0%, #065f00 100%);
  color: white;
}

.payment-hero-main {
  text-align: left;
}

.payment-hero-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.85;
}

.payment-hero-amount {
  font-family: var(--font-title);
  font-size: 42px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.payment-hero-breakdown {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-left: var(--spacing-lg);
  border-left: 1px solid rgba(255,255,255,0.25);
  min-width: 200px;
}

.breakdown-row {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  opacity: 0.9;
}

.breakdown-row.tds { color: #fbbf24; }
.breakdown-row.rcm { color: #a5f3fc; font-size: 12px; }

.breakdown-label { opacity: 0.8; }
.breakdown-value { font-family: var(--font-mono); font-weight: 500; }

/* Amounts Table */
.payment-amounts-table {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  overflow: hidden;
}

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

.amounts-table td {
  padding: var(--spacing-sm) var(--spacing-md);
  border-bottom: 1px solid var(--neutral-lightest);
}

.amounts-table .amt-label {
  color: var(--neutral-medium);
  font-size: 13px;
}

.amounts-table .amt-value {
  text-align: right;
  width: 150px;
}

.amt-input {
  width: 100%;
  padding: 4px 8px;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 500;
  text-align: right;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--neutral-dark);
}

.amt-input:hover { background: var(--neutral-lightest); }
.amt-input:focus { outline: none; border-color: var(--primary-medium); background: white; }
.amt-input.modified { background: #fffbeb; border-color: var(--status-flag); }

.amounts-table .subtotal-row { background: var(--neutral-lightest); }
.amounts-table .subtotal-row .amt-label { font-weight: 500; }

.amounts-table .total-row { 
  background: var(--neutral-lightest); 
  border-top: 2px solid var(--neutral-lighter);
}
.amounts-table .total-row .amt-label { font-weight: 600; color: var(--neutral-dark); }
.amounts-table .total-row .amt-input { font-weight: 600; }

.amounts-table .deduction-row .amt-input { color: var(--status-flag); }

.amounts-table .final-row {
  background: var(--primary-dark);
}
.amounts-table .final-row .amt-label { 
  color: white; 
  font-weight: 700; 
  font-size: 14px;
}
.amounts-table .final-row .amt-input {
  color: white;
  font-size: 18px;
  font-weight: 700;
  background: transparent;
}
.amounts-table .final-row .amt-input:hover { background: rgba(255,255,255,0.1); }

/* RCM Note */
.rcm-note {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-md);
  background: #e0f2fe;
  border-radius: var(--radius-md);
  margin-top: var(--spacing-md);
  font-size: 13px;
  color: #0369a1;
}

.rcm-icon { font-size: 18px; }
.rcm-note strong { color: #0c4a6e; }

/* Payment Action Buttons */
.payment-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: var(--spacing-md);
  border-left: 1px solid var(--neutral-lighter);
}

.action-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}

.action-btn .btn-icon { font-size: 16px; }

.push-btn {
  background: linear-gradient(135deg, var(--primary-dark) 0%, #065f00 100%);
  color: white;
  box-shadow: 0 2px 8px rgba(3, 58, 0, 0.3);
}

.push-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(3, 58, 0, 0.4);
}

.push-btn:active {
  transform: translateY(0);
}

.hold-btn {
  background: white;
  color: var(--neutral-dark);
  border: 1px solid var(--neutral-lighter);
}

.hold-btn:hover {
  background: var(--neutral-lightest);
  border-color: var(--status-flag);
  color: var(--status-flag);
}

/* Toast Notification */
.payment-toast {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%) translateY(100px);
  background: var(--neutral-dark);
  color: white;
  padding: 14px 24px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 500;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
  opacity: 0;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 10000;
}

.payment-toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

.payment-toast .toast-icon {
  width: 24px;
  height: 24px;
  background: var(--primary-dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}

/* Payment Save Button - make it more visible */
.payment-save-btn {
  position: fixed;
  bottom: 30px;
  right: 30px;
  z-index: 1000;
  padding: 12px 24px;
  font-size: 14px;
  box-shadow: 0 4px 20px rgba(3, 58, 0, 0.4);
  animation: pulse-save 2s infinite;
}

@keyframes pulse-save {
  0%, 100% { box-shadow: 0 4px 20px rgba(3, 58, 0, 0.4); }
  50% { box-shadow: 0 4px 30px rgba(3, 58, 0, 0.6); }
}

.payment-save-btn:hover {
  animation: none;
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(3, 58, 0, 0.5);
}

/* Floating Save Button - shared for Accounting and Payment */
.floating-save-btn {
  position: fixed !important;
  bottom: 30px;
  right: 30px;
  z-index: 1000;
  padding: 12px 24px !important;
  font-size: 14px !important;
  box-shadow: 0 4px 20px rgba(3, 58, 0, 0.4);
  animation: pulse-save 2s infinite;
}

.floating-save-btn:hover {
  animation: none;
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(3, 58, 0, 0.5);
}

/* ========================================
   AR Invoice Generator - New Components
   ======================================== */

/* Data Sub-Tabs - sit inside step-section-header */
.data-tabs-container {
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
  padding: 0 var(--spacing-lg);
}

.data-tabs {
  display: flex;
  gap: 0;
}

.data-tab {
  padding: 8px 16px;
  border: none;
  background: none;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--neutral-medium);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  transition: all 0.2s ease;
}

.data-tab:hover {
  color: var(--primary-dark);
  background: rgba(3, 58, 0, 0.05);
}

.data-tab.active {
  color: var(--primary-dark);
  border-bottom-color: var(--primary-dark);
  font-weight: 600;
  background: rgba(3, 58, 0, 0.04);
}

.data-tab-content {
  padding: var(--spacing-lg);
  min-height: 400px;
}

/* Invoice Render */
.invoice-render {
  max-width: 1200px;
}

.invoice-header-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  border: 1px solid var(--neutral-lighter);
  margin-bottom: var(--spacing-lg);
}

.invoice-header-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-lg);
}

.invoice-header-col .inv-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  color: var(--neutral-medium);
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.invoice-header-col .inv-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--neutral-dark);
}

/* Summary Cards Grid */
.summary-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}

.summary-card {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  border: 1px solid var(--neutral-lighter);
}

.summary-card.negative {
  border-color: var(--status-block);
}

.summary-card-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  color: var(--neutral-medium);
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.summary-card-value {
  font-size: 16px;
  font-weight: 600;
  color: var(--neutral-dark);
}

.summary-card.negative .summary-card-value {
  color: var(--status-block);
}

/* Status Tags */
.status-tag {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}

.status-tag.passed {
  background: var(--status-passed-bg);
  color: var(--status-passed);
}

.status-tag.pending {
  background: var(--status-flag-bg);
  color: var(--status-flag);
}

.status-tag.blocked {
  background: var(--status-block-bg);
  color: var(--status-block);
}

/* Data Sections */
.data-section {
  max-width: 1200px;
}

.col-amount.negative {
  color: var(--status-block);
}

/* Empty State */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  color: var(--neutral-medium);
  gap: 8px;
}

.empty-state .placeholder-icon {
  font-size: 32px;
}

/* Billing Input Form */
.billing-input-form {
  max-width: 600px;
  padding: var(--spacing-lg);
}

/* ===== Enhanced Billing Input Form ===== */
.billing-input-form-full {
  padding: var(--spacing-md);
}

.billing-form-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: var(--spacing-lg);
  background: linear-gradient(135deg, var(--primary-lightest) 0%, #f0f7f0 100%);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-lg);
  border: 1px solid var(--primary-lighter);
}

.billing-form-header-left {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-md);
}

.billing-form-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  background: var(--primary-dark);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.billing-form-header h3 {
  font-family: var(--font-title);
  color: var(--primary-dark);
  margin: 0 0 4px 0;
  font-size: 18px;
}

.billing-form-header p {
  color: var(--neutral-medium);
  font-size: 13px;
  margin: 0;
  max-width: 480px;
  line-height: 1.5;
}

.billing-form-brand-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  background: var(--primary-dark);
  color: white;
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Context bar */
.billing-context-bar {
  background: var(--neutral-lightest);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}

.billing-context-title {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--neutral-medium);
  margin-bottom: var(--spacing-sm);
}

.billing-context-cards {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.billing-context-card {
  background: white;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  padding: 6px 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 110px;
}

.billing-context-card.jarvis {
  border-color: var(--secondary-light);
  background: #f8f9ff;
}

.billing-context-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  color: var(--neutral-medium);
}

.billing-context-value {
  font-family: var(--font-title);
  font-size: 14px;
  font-weight: 600;
  color: var(--neutral-dark);
}

/* Suggestions panel */
.billing-suggestions-panel {
  background: #fffbeb;
  border: 1px solid #fcd34d;
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}

.billing-suggestions-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
}

.billing-suggestions-icon {
  font-size: 16px;
}

.billing-suggestions-title {
  font-family: var(--font-title);
  font-size: 14px;
  font-weight: 600;
  color: #92400e;
}

.billing-suggestions-hint {
  font-size: 11px;
  color: #b45309;
  margin-left: auto;
}

.billing-suggestions-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.billing-suggestion-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  background: white;
  border: 1px solid #fcd34d;
  border-radius: 20px;
  padding: 6px 14px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 13px;
}

.billing-suggestion-chip:hover {
  background: #fef3c7;
  border-color: #f59e0b;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(245, 158, 11, 0.2);
}

.suggestion-desc {
  color: var(--neutral-dark);
  font-weight: 500;
}

.suggestion-value {
  font-family: var(--font-mono);
  font-weight: 600;
  color: var(--primary-dark);
}

.suggestion-source {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  background: #fef3c7;
  color: #92400e;
  padding: 2px 6px;
  border-radius: 4px;
}

/* Invoices container */
.billing-invoices-container {
  min-height: 60px;
}

.billing-invoices-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-xl);
  color: var(--neutral-medium);
  font-size: 13px;
  border: 2px dashed var(--neutral-lighter);
  border-radius: var(--radius-md);
}

.billing-empty-icon {
  font-size: 20px;
}

/* Invoice card */
.billing-invoice-card {
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-md);
  background: white;
  overflow: hidden;
  transition: box-shadow 0.2s;
}

.billing-invoice-card:hover {
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}

.billing-invoice-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md) var(--spacing-md);
  background: var(--neutral-lightest);
  border-bottom: 1px solid var(--neutral-lighter);
}

.billing-invoice-header-left {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.billing-invoice-badge {
  font-family: var(--font-title);
  font-size: 13px;
  font-weight: 600;
  background: var(--primary-dark);
  color: white;
  padding: 3px 10px;
  border-radius: 4px;
}

.billing-invoice-total {
  font-family: var(--font-title);
  font-size: 15px;
  font-weight: 700;
  color: var(--primary-dark);
}

.billing-invoice-items-count {
  font-size: 12px;
  color: var(--neutral-medium);
}

.billing-remove-invoice-btn {
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--status-block);
  font-size: 20px;
  cursor: pointer;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.billing-remove-invoice-btn:hover {
  background: var(--status-block-bg);
}

.billing-invoice-number-row {
  display: flex;
  gap: var(--spacing-md);
  padding: var(--spacing-md);
  border-bottom: 1px solid var(--neutral-lighter);
}

.billing-invoice-number-row .form-group {
  margin-bottom: 0;
}

/* Line items */
.billing-line-items {
  padding: var(--spacing-sm) var(--spacing-md);
}

.billing-line-item {
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  margin-bottom: var(--spacing-sm);
  background: var(--neutral-lightest);
  transition: border-color 0.2s;
}

.billing-line-item:hover {
  border-color: var(--primary-light);
}

.billing-line-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-xs);
}

.billing-li-num {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--neutral-medium);
  font-weight: 600;
}

.billing-remove-li-btn {
  width: 22px;
  height: 22px;
  border: none;
  background: transparent;
  color: var(--neutral-medium);
  font-size: 16px;
  cursor: pointer;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.billing-remove-li-btn:hover {
  background: var(--status-block-bg);
  color: var(--status-block);
}

.billing-li-fields {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--spacing-sm);
}

.billing-li-fields .form-group {
  margin-bottom: 0;
}

.billing-li-comment {
  margin-top: var(--spacing-xs);
  margin-bottom: 0 !important;
  flex: 1;
}

.billing-li-comment .form-input {
  font-size: 12px;
  padding: 6px 10px;
}

.billing-li-bottom-row {
  display: flex;
  gap: var(--spacing-sm);
  align-items: flex-end;
  margin-top: var(--spacing-xs);
}

.billing-li-attach-group {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
  padding-bottom: 1px;
}

.billing-attach-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  background: white;
  color: var(--neutral-medium);
  font-size: 11px;
  font-family: var(--font-body);
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}

.billing-attach-btn:hover {
  border-color: var(--primary-medium);
  color: var(--primary-dark);
  background: var(--primary-lightest);
}

.billing-attach-icon {
  display: flex;
  align-items: center;
}

.billing-mail-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  background: white;
  color: var(--neutral-medium);
  font-size: 11px;
  font-family: var(--font-body);
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}

.billing-mail-btn:hover {
  border-color: var(--secondary-dark);
  color: var(--secondary-dark);
  background: var(--secondary-lightest);
}

.billing-li-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
  min-height: 0;
}

.billing-attachment-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  background: var(--primary-lightest);
  border: 1px solid var(--primary-lighter);
  border-radius: 12px;
  font-size: 11px;
  color: var(--primary-dark);
}

.attachment-name {
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.attachment-remove {
  background: none;
  border: none;
  color: var(--neutral-medium);
  cursor: pointer;
  font-size: 14px;
  padding: 0 2px;
  line-height: 1;
}

.attachment-remove:hover {
  color: var(--status-block);
}

.billing-approval-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 12px;
  font-size: 11px;
  color: var(--secondary-dark);
}

.billing-add-li-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  background: transparent;
  border: 1px dashed var(--primary-light);
  border-radius: var(--radius-sm);
  padding: 6px 14px;
  margin: var(--spacing-sm) var(--spacing-md) var(--spacing-md);
  color: var(--primary-medium);
  font-size: 12px;
  font-family: var(--font-body);
  cursor: pointer;
  transition: all 0.2s;
  width: calc(100% - var(--spacing-md) * 2);
}

.billing-add-li-btn:hover {
  background: var(--primary-lightest);
  border-color: var(--primary-medium);
  color: var(--primary-dark);
}

/* Actions area */
.billing-form-actions {
  margin-top: var(--spacing-md);
  margin-bottom: var(--spacing-md);
}

.billing-add-invoice-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: white;
  border: 2px dashed var(--primary-light);
  border-radius: var(--radius-md);
  padding: var(--spacing-md) var(--spacing-lg);
  color: var(--primary-dark);
  font-family: var(--font-title);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
  justify-content: center;
  transition: all 0.2s;
}

.billing-add-invoice-btn:hover {
  background: var(--primary-lightest);
  border-color: var(--primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(3, 58, 0, 0.12);
}

.billing-add-icon {
  font-size: 18px;
  font-weight: 700;
}

/* Submit area */
.billing-submit-area {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--primary-lightest);
  border: 1px solid var(--primary-lighter);
  border-radius: var(--radius-md);
  margin-top: var(--spacing-lg);
  gap: var(--spacing-md);
}

.billing-submit-summary {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: 13px;
  color: var(--primary-dark);
}

.billing-summary-stat strong {
  font-family: var(--font-title);
}

.billing-summary-divider {
  color: var(--primary-light);
}

.billing-submit-actions {
  display: flex;
  gap: var(--spacing-sm);
  flex-shrink: 0;
}

.billing-submit-btn {
  background: linear-gradient(135deg, var(--primary-dark) 0%, #065f00 100%);
  color: white;
  border: none;
  padding: 10px 24px;
  border-radius: var(--radius-sm);
  font-family: var(--font-title);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}

.billing-submit-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(3, 58, 0, 0.4);
}

.billing-draft-btn {
  background: white;
  color: var(--primary-dark);
  border: 1px solid var(--primary-light);
  padding: 10px 20px;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
}

.billing-draft-btn:hover {
  background: var(--primary-lightest);
  border-color: var(--primary-dark);
}

/* Responsive adjustments for billing form */
@media (max-width: 768px) {
  .billing-form-header {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  .billing-li-fields {
    grid-template-columns: 1fr 1fr;
  }
  .billing-submit-area {
    flex-direction: column;
    text-align: center;
  }
  .billing-context-cards {
    flex-direction: column;
  }
}

.form-header {
  margin-bottom: var(--spacing-lg);
}

.form-header h3 {
  font-family: var(--font-title);
  color: var(--neutral-dark);
  margin-bottom: 4px;
}

.form-header p {
  color: var(--neutral-medium);
  font-size: 13px;
}

.form-group {
  margin-bottom: var(--spacing-md);
  flex: 1;
}

.form-group label {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  color: var(--neutral-medium);
  margin-bottom: 4px;
}

.form-input {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 14px;
  transition: border-color 0.2s;
}

.form-input:focus {
  outline: none;
  border-color: var(--primary-medium);
}

.form-row {
  display: flex;
  gap: var(--spacing-md);
}

/* ========================================
   Unified Step Section Layout
   ======================================== */
.step-section {
  background: var(--white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--neutral-lighter);
  margin-bottom: var(--spacing-lg);
  overflow: hidden;
}

.step-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md) var(--spacing-lg);
  border-bottom: 1px solid var(--neutral-lighter);
  background: var(--neutral-lightest);
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.step-section-header h2 {
  font-family: var(--font-title);
  font-size: 18px;
  font-weight: 700;
  color: var(--neutral-dark);
  letter-spacing: -0.04em;
  margin: 0;
}

.approve-container,
.accounting-container,
.clearing-container,
.rules-container {
  padding: var(--spacing-lg);
}

.approve-action {
  margin-top: var(--spacing-lg);
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--neutral-lighter);
}

/* Status badge for pending */
.status-badge.pending, .meta-value.pending {
  background: var(--status-flag-bg);
  color: var(--status-flag);
}

/* Mono class for codes */
.mono, td.mono {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.5px;
}

/* Meta bar */
.meta-value {
  word-break: break-word;
}

/* ========================================
   Customer Details - Hero Layout
   ======================================== */
.customer-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--secondary-dark) 100%);
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  margin-bottom: var(--spacing-lg);
  color: white;
}

.customer-hero-main {
  display: flex;
  align-items: center;
  gap: 16px;
}

.customer-hero-icon {
  font-size: 36px;
  width: 56px;
  height: 56px;
  background: rgba(255,255,255,0.15);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

.customer-hero-parent {
  font-family: var(--font-title);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.customer-hero-legal {
  font-size: 13px;
  opacity: 0.8;
  margin-top: 2px;
}

.customer-hero-badges {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.customer-nature-badge, .customer-category-badge {
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: rgba(255,255,255,0.15);
  color: white;
}

/* Customer Grid */
.customer-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
}

.customer-card {
  background: var(--white);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-lg);
  padding: 20px;
}

.customer-card.full-width {
  grid-column: 1 / -1;
}

.customer-card-title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--neutral-medium);
  margin-bottom: 16px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--neutral-lighter);
}

.brand-count {
  font-weight: 400;
  color: var(--neutral-light);
  margin-left: 8px;
}

/* Customer detail rows */
.customer-detail-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--neutral-lightest);
}

.customer-detail-row:last-child {
  border-bottom: none;
}

.customer-detail-label {
  font-size: 13px;
  color: var(--neutral-medium);
}

.customer-detail-value {
  font-size: 13px;
  font-weight: 500;
  color: var(--neutral-dark);
  text-align: right;
  max-width: 60%;
}

/* Contact cards */
.customer-contact {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--neutral-lightest);
}

.customer-contact:last-child {
  border-bottom: none;
}

.contact-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--primary-lightest);
  color: var(--primary-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
  flex-shrink: 0;
}

.contact-avatar.approver {
  background: var(--secondary-lightest);
  color: var(--secondary-dark);
}

.contact-avatar.brand {
  background: #f3e8ff;
  color: #7B2D8E;
}

.contact-name {
  font-weight: 600;
  font-size: 14px;
  color: var(--neutral-dark);
}

.contact-role {
  font-size: 12px;
  color: var(--neutral-medium);
}

.contact-type {
  font-size: 10px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  color: var(--neutral-light);
  letter-spacing: 0.5px;
}

.contact-email {
  font-size: 12px;
  color: var(--secondary-medium);
}

/* Brand chips */
.brand-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.brand-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--neutral-lightest);
  border-radius: 20px;
  border: 1px solid var(--neutral-lighter);
}

.brand-chip-name {
  font-weight: 600;
  font-size: 13px;
  color: var(--neutral-dark);
}

.brand-chip-cat {
  font-size: 10px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  color: var(--neutral-medium);
  padding: 1px 6px;
  background: var(--white);
  border-radius: 4px;
}

/* Data sources */
.data-sources {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--spacing-md);
}

.data-sources-label {
  font-size: 11px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  color: var(--neutral-light);
}

.data-source-tag {
  font-size: 11px;
  padding: 2px 8px;
  background: var(--neutral-lightest);
  border: 1px solid var(--neutral-lighter);
  border-radius: 4px;
  color: var(--neutral-medium);
  font-family: var(--font-mono);
}

/* ========================================
   Approval Banner
   ======================================== */
.approval-banner {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 24px 28px;
  border-radius: var(--radius-lg);
  margin-bottom: var(--spacing-lg);
}

.approval-banner.approved {
  background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
  border: 2px solid #059669;
}

.approval-banner.pending-approval {
  background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
  border: 2px solid #d97706;
}

.approval-banner-icon {
  font-size: 48px;
  flex-shrink: 0;
}

.approval-banner-text {
  flex: 1;
}

.approval-banner-title {
  font-family: var(--font-title);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.approved .approval-banner-title {
  color: #065f46;
}

.pending-approval .approval-banner-title {
  color: #92400e;
}

.approval-banner-subtitle {
  font-size: 14px;
  margin-top: 4px;
  line-height: 1.5;
}

.approved .approval-banner-subtitle {
  color: #047857;
}

.pending-approval .approval-banner-subtitle {
  color: #b45309;
}

.approval-banner-date {
  font-size: 12px;
  margin-top: 8px;
  font-family: var(--font-mono);
  opacity: 0.7;
}

.approve-btn {
  padding: 12px 28px;
  background: #d97706;
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
}

.approve-btn:hover {
  background: #b45309;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(217, 119, 6, 0.3);
}

/* Approval contacts */
.approval-contacts {
  margin-top: var(--spacing-lg);
}

.approval-contacts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--spacing-md);
}

.approval-contact-card {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  background: var(--white);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
}

/* ========================================
   Approve SPOCs Panel (beside timeline)
   ======================================== */
.approve-spocs-panel {
  flex: 0 0 240px;
  padding: 24px;
  background: var(--white);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-lg);
}

.approve-spocs-title {
  font-family: var(--font-title);
  font-size: 15px;
  font-weight: 600;
  color: var(--neutral-dark);
  margin-bottom: var(--spacing-md);
  letter-spacing: -0.01em;
}

.approve-spoc-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--neutral-lightest);
}

.approve-spoc-card:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.approve-spoc-card:first-of-type {
  padding-top: 0;
}

.approve-spoc-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--primary-light);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
}

.approve-spoc-avatar.approver {
  background: #dbeafe;
  color: #1d4ed8;
}

.approve-spoc-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}

.approve-spoc-name {
  font-weight: 600;
  font-size: 13px;
  color: var(--neutral-dark);
}

.approve-spoc-role {
  font-size: 11px;
  color: var(--neutral);
}

.approve-spoc-email {
  font-size: 10px;
  color: var(--primary);
  font-family: var(--font-mono);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ========================================
   Approve Timeline
   ======================================== */
.approve-row {
  display: flex;
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
  align-items: flex-start;
}

.approve-timeline {
  flex: 1;
  padding: 24px;
  background: var(--white);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-lg);
}

.approve-timeline-title {
  font-family: var(--font-title);
  font-size: 15px;
  font-weight: 600;
  color: var(--neutral-dark);
  margin-bottom: 20px;
  letter-spacing: -0.01em;
}

.approve-timeline-track {
  display: flex;
  align-items: flex-start;
  gap: 0;
  position: relative;
}

.approve-timeline-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  flex: 1;
  max-width: 280px;
}

.approve-timeline-node {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  z-index: 2;
  flex-shrink: 0;
  border: 3px solid var(--neutral-lighter);
  background: var(--neutral-lightest);
  transition: all 0.3s;
}

.approve-timeline-step.completed .approve-timeline-node {
  background: #059669;
  border-color: #059669;
}

.approve-timeline-step.pending .approve-timeline-node {
  background: #fef3c7;
  border-color: #d97706;
}

.approve-timeline-check {
  color: white;
  font-weight: 700;
  font-size: 18px;
}

.approve-timeline-pending {
  font-size: 18px;
}

.approve-timeline-connector {
  position: absolute;
  top: 22px;
  left: calc(50% + 22px);
  width: calc(100% - 44px);
  height: 3px;
  background: var(--neutral-lighter);
  z-index: 1;
}

.approve-timeline-connector.completed {
  background: #059669;
}

.approve-timeline-detail {
  text-align: center;
  margin-top: 12px;
}

.approve-timeline-step-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--neutral);
  font-weight: 600;
  margin-bottom: 4px;
}

.approve-timeline-step-name {
  font-weight: 700;
  font-size: 15px;
  color: var(--neutral-dark);
  font-family: var(--font-title);
}

.approve-timeline-step-role {
  font-size: 12px;
  color: var(--neutral);
  margin-top: 2px;
}

.approve-timeline-approved-tag {
  display: inline-block;
  margin-top: 8px;
  padding: 4px 12px;
  background: #ecfdf5;
  color: #059669;
  border-radius: 100px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: 1px solid #a7f3d0;
}

.approve-timeline-pending-tag {
  display: inline-block;
  margin-top: 8px;
  padding: 4px 12px;
  background: #fffbeb;
  color: #d97706;
  border-radius: 100px;
  font-size: 12px;
  font-weight: 600;
  border: 1px solid #fde68a;
}

/* ========================================
   Generate & Send Invoice Section
   ======================================== */
.invoice-gen-section {
  margin-top: var(--spacing-lg);
  background: var(--white);
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.invoice-gen-header {
  padding: 20px 24px;
  border-bottom: 1px solid var(--neutral-lighter);
  background: linear-gradient(135deg, #faf5ff 0%, #f3e8ff 100%);
}

.invoice-gen-title-row {
  display: flex;
  align-items: center;
  gap: 14px;
}

.invoice-gen-icon {
  width: 28px;
  height: 28px;
  color: var(--primary);
  flex-shrink: 0;
}

.invoice-gen-title {
  font-family: var(--font-title);
  font-size: 18px;
  font-weight: 700;
  color: var(--neutral-dark);
  letter-spacing: -0.02em;
}

.invoice-gen-subtitle {
  font-size: 13px;
  color: var(--neutral);
  margin-top: 2px;
}

.invoice-gen-items {
  padding: 16px 24px;
  border-bottom: 1px solid var(--neutral-lighter);
}

.invoice-gen-items-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.invoice-gen-items-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--neutral-dark);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.invoice-gen-select-all {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--neutral);
  cursor: pointer;
  user-select: none;
}

.invoice-gen-select-all input {
  accent-color: var(--primary);
}

.invoice-gen-items-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.invoice-gen-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--neutral-lightest);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.15s;
}

.invoice-gen-item:hover {
  border-color: var(--primary-light);
  background: #faf5ff;
}

.invoice-gen-item input[type="checkbox"] {
  accent-color: var(--primary);
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.invoice-gen-item-info {
  flex: 1;
  min-width: 0;
}

.invoice-gen-item-desc {
  font-size: 13px;
  font-weight: 500;
  color: var(--neutral-dark);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.invoice-gen-item-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 2px;
}

.invoice-gen-item-num {
  font-size: 11px;
  font-family: var(--font-mono);
  color: var(--neutral);
}

.invoice-gen-item-val {
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
}

.invoice-gen-actions {
  padding: 20px 24px;
  display: flex;
  align-items: flex-end;
  gap: 20px;
  flex-wrap: wrap;
}

.invoice-gen-recipient {
  flex: 1;
  min-width: 220px;
}

.invoice-gen-field-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--neutral);
  margin-bottom: 6px;
}

.invoice-gen-email-row {
  display: flex;
  gap: 8px;
}

.invoice-gen-email-input {
  flex: 1;
  padding: 9px 14px;
  border: 1px solid var(--neutral-lighter);
  border-radius: var(--radius-md);
  font-size: 13px;
  font-family: var(--font-mono);
  outline: none;
  transition: border-color 0.2s;
}

.invoice-gen-email-input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-light);
}

.invoice-gen-email-hint {
  font-size: 11px;
  color: var(--neutral);
  margin-top: 4px;
}

.invoice-gen-btns {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}

.invoice-gen-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border: none;
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}

.invoice-gen-btn.generate {
  background: var(--neutral-lightest);
  color: var(--neutral-dark);
  border: 1px solid var(--neutral-lighter);
}

.invoice-gen-btn.generate:hover {
  background: var(--neutral-lighter);
  border-color: var(--neutral);
}

.invoice-gen-btn.send {
  background: var(--primary);
  color: white;
}

.invoice-gen-btn.send:hover {
  background: var(--primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(123, 45, 142, 0.3);
}

/* ========================================
   Clearing Hero Card
   ======================================== */
.clearing-hero {
  display: flex;
  align-items: stretch;
  background: linear-gradient(135deg, var(--primary-dark) 0%, #065f00 100%);
  border-radius: var(--radius-lg);
  margin-bottom: var(--spacing-lg);
  color: white;
  overflow: hidden;
}

.clearing-hero.overdue {
  background: linear-gradient(135deg, #7f1d1d 0%, #991b1b 100%);
}

.clearing-hero-amount {
  flex: 0 0 auto;
  padding: 28px 32px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 240px;
}

.clearing-hero-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.8;
  margin-bottom: 4px;
}

.clearing-hero-value {
  font-family: var(--font-title);
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.clearing-hero-breakdown {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 10px;
}

.clearing-breakdown-item {
  font-size: 12px;
  opacity: 0.9;
  padding: 2px 10px;
  border-radius: 20px;
  background: rgba(255,255,255,0.15);
}

.clearing-breakdown-item.outstanding {
  background: rgba(251, 191, 36, 0.25);
  color: #fde68a;
}

.clearing-hero-customer {
  flex: 1;
  padding: 24px 28px;
  border-left: 1px solid rgba(255,255,255,0.15);
  border-right: 1px solid rgba(255,255,255,0.15);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
}

.clearing-hero-cust-name {
  font-family: var(--font-title);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.clearing-hero-cust-code {
  font-family: var(--font-mono);
  font-size: 13px;
  opacity: 0.7;
}

.clearing-hero-cust-gst {
  font-family: var(--font-mono);
  font-size: 12px;
  opacity: 0.65;
}

.clearing-hero-ref {
  font-family: var(--font-mono);
  font-size: 11px;
  opacity: 0.6;
  margin-top: 4px;
  word-break: break-all;
}

.clearing-hero-recon {
  font-family: var(--font-mono);
  font-size: 11px;
  opacity: 0.6;
}

.clearing-hero-due {
  flex: 0 0 auto;
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 140px;
  text-align: center;
  gap: 4px;
  background: rgba(255,255,255,0.06);
}

.clearing-status-icon {
  font-size: 32px;
}

.clearing-status-label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.85;
}

.clearing-due-date {
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 600;
}

.clearing-due-badge {
  font-size: 11px;
  padding: 2px 10px;
  border-radius: 20px;
  background: rgba(255,255,255,0.15);
  margin-top: 2px;
}

.clearing-due-badge.overdue {
  background: #ef4444;
  color: #fff;
}

.clearing-due-badge.urgent {
  background: #fbbf24;
  color: #000;
}

.clearing-hero-due.paid {
  background: rgba(255,255,255,0.1);
}

/* Cleared invoice row */
.cleared-row td {
  background: var(--status-passed-bg);
}

.cleared-row:hover td {
  background: #d1fae5 !important;
}

@media (max-width: 768px) {
  .clearing-hero {
    flex-direction: column;
  }
  .clearing-hero-customer {
    border-left: none;
    border-right: none;
    border-top: 1px solid rgba(255,255,255,0.15);
    border-bottom: 1px solid rgba(255,255,255,0.15);
  }
}