Spaces:
Sleeping
Sleeping
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| JX Claims Intelligence β Premium Dark Theme | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| :root { | |
| --bg-primary: #f8f9fb; | |
| --bg-secondary: #ffffff; | |
| --bg-card: #ffffff; | |
| --bg-card-hover: #f1f5f9; | |
| --bg-glass: rgba(0, 0, 0, 0.02); | |
| --border: #e2e8f0; | |
| --border-active: rgba(102, 126, 234, 0.5); | |
| --text-primary: #1e293b; | |
| --text-secondary: #475569; | |
| --text-muted: #94a3b8; | |
| --accent-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%); | |
| --accent-blue: #667eea; | |
| --accent-purple: #764ba2; | |
| --success: #10b981; | |
| --success-bg: rgba(16, 185, 129, 0.08); | |
| --warning: #f59e0b; | |
| --warning-bg: rgba(245, 158, 11, 0.08); | |
| --danger: #ef4444; | |
| --danger-bg: rgba(239, 68, 68, 0.06); | |
| --info: #3b82f6; | |
| --info-bg: rgba(59, 130, 246, 0.06); | |
| --radius: 12px; | |
| --radius-sm: 8px; | |
| --radius-xs: 6px; | |
| --shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.06); | |
| --shadow-lg: 0 4px 12px rgba(0, 0, 0, 0.1), 0 2px 4px rgba(0, 0, 0, 0.06); | |
| --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif; | |
| --font-mono: 'JetBrains Mono', 'Fira Code', monospace; | |
| } | |
| * { margin: 0; padding: 0; box-sizing: border-box; } | |
| body { | |
| font-family: var(--font-sans); | |
| background: var(--bg-primary); | |
| color: var(--text-primary); | |
| min-height: 100vh; | |
| overflow-x: hidden; | |
| } | |
| /* ββ Header ββ */ | |
| .header { | |
| display: flex; | |
| align-items: center; | |
| justify-content: space-between; | |
| padding: 0.75rem 1.5rem; | |
| background: var(--bg-secondary); | |
| border-bottom: 1px solid var(--border); | |
| position: sticky; | |
| top: 0; | |
| z-index: 100; | |
| box-shadow: var(--shadow); | |
| } | |
| .header-left { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.75rem; | |
| } | |
| .logo { | |
| width: 40px; | |
| height: 40px; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| background: var(--accent-gradient); | |
| border-radius: var(--radius-sm); | |
| padding: 6px; | |
| } | |
| .logo svg { stroke: white; } | |
| .header-title { | |
| font-size: 1.1rem; | |
| font-weight: 700; | |
| background: var(--accent-gradient); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| background-clip: text; | |
| letter-spacing: -0.02em; | |
| } | |
| .header-subtitle { | |
| font-size: 0.7rem; | |
| color: var(--text-muted); | |
| font-weight: 400; | |
| letter-spacing: 0.05em; | |
| text-transform: uppercase; | |
| } | |
| .status-badge { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.5rem; | |
| padding: 0.4rem 0.75rem; | |
| border-radius: 20px; | |
| font-size: 0.75rem; | |
| font-weight: 500; | |
| background: var(--bg-glass); | |
| border: 1px solid var(--border); | |
| color: var(--text-secondary); | |
| } | |
| .status-dot { | |
| width: 8px; | |
| height: 8px; | |
| border-radius: 50%; | |
| background: var(--success); | |
| animation: pulse 2s infinite; | |
| } | |
| @keyframes pulse { | |
| 0%, 100% { opacity: 1; } | |
| 50% { opacity: 0.4; } | |
| } | |
| /* ββ Layout ββ */ | |
| .app-container { | |
| display: grid; | |
| grid-template-columns: 240px 1fr 300px; | |
| height: calc(100vh - 57px); | |
| overflow: hidden; | |
| } | |
| /* ββ Sidebar ββ */ | |
| .sidebar { | |
| background: var(--bg-secondary); | |
| border-right: 1px solid var(--border); | |
| padding: 1.25rem; | |
| overflow-y: auto; | |
| } | |
| .sidebar-title { | |
| font-size: 0.65rem; | |
| text-transform: uppercase; | |
| letter-spacing: 0.1em; | |
| color: var(--text-muted); | |
| font-weight: 600; | |
| margin-bottom: 1rem; | |
| } | |
| /* ββ Sidebar onboarding shortcut βββββββββββββββββββββββ */ | |
| .sidebar-onboarding-btn { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.5rem; | |
| padding: 0.55rem 0.75rem; | |
| margin-bottom: 1rem; | |
| border-radius: var(--radius-sm); | |
| background: linear-gradient(135deg, rgba(102,126,234,0.08) 0%, rgba(118,75,162,0.08) 100%); | |
| border: 1px solid rgba(102,126,234,0.2); | |
| text-decoration: none; | |
| color: var(--accent-blue); | |
| font-size: 0.78rem; | |
| font-weight: 600; | |
| transition: background 0.2s, border-color 0.2s; | |
| } | |
| .sidebar-onboarding-btn:hover { | |
| background: linear-gradient(135deg, rgba(102,126,234,0.15) 0%, rgba(118,75,162,0.15) 100%); | |
| border-color: rgba(102,126,234,0.4); | |
| } | |
| .sidebar-onboarding-icon { font-size: 1rem; line-height: 1; } | |
| .sidebar-onboarding-label { flex: 1; } | |
| /* ββ Payer-level claim group (outer) βββββββββββββββββββ */ | |
| .claim-group--payer { | |
| margin-bottom: 0.75rem; | |
| margin-left: 0.75rem; | |
| } | |
| .claim-group-header--payer { | |
| background: linear-gradient(135deg, rgba(102,126,234,0.06) 0%, rgba(118,75,162,0.06) 100%); | |
| border-color: rgba(102,126,234,0.2); | |
| font-size: 0.78rem; | |
| color: var(--text-primary); | |
| } | |
| .claim-group-header--payer:hover { | |
| background: linear-gradient(135deg, rgba(102,126,234,0.12) 0%, rgba(118,75,162,0.12) 100%); | |
| } | |
| /* ββ CARC-level claim group (inner, indented) ββββββββββ */ | |
| .claim-group--carc { | |
| margin-left: 0.75rem; | |
| margin-top: 0.35rem; | |
| margin-bottom: 0; | |
| } | |
| .claim-group-header--carc { | |
| font-size: 0.72rem; | |
| background: var(--bg-glass); | |
| } | |
| .pipeline-steps { display: flex; flex-direction: column; } | |
| .step { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.75rem; | |
| padding: 0.6rem; | |
| border-radius: var(--radius-sm); | |
| transition: all 0.3s ease; | |
| } | |
| .step[data-status="active"] { | |
| background: var(--info-bg); | |
| border: 1px solid rgba(59, 130, 246, 0.2); | |
| } | |
| .step[data-status="complete"] .step-indicator { | |
| background: var(--success); | |
| border-color: var(--success); | |
| } | |
| .step[data-status="active"] .step-indicator { | |
| background: var(--accent-gradient); | |
| border-color: var(--accent-blue); | |
| animation: pulse 1.5s infinite; | |
| } | |
| .step-indicator { | |
| width: 28px; | |
| height: 28px; | |
| border-radius: 50%; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| border: 2px solid var(--border); | |
| background: var(--bg-primary); | |
| flex-shrink: 0; | |
| transition: all 0.3s ease; | |
| } | |
| .step-number { | |
| font-size: 0.7rem; | |
| font-weight: 600; | |
| color: var(--text-secondary); | |
| } | |
| .step[data-status="active"] .step-number, | |
| .step[data-status="complete"] .step-number { | |
| color: white; | |
| } | |
| .step-label { | |
| font-size: 0.8rem; | |
| font-weight: 600; | |
| color: var(--text-primary); | |
| } | |
| .step-desc { | |
| font-size: 0.65rem; | |
| color: var(--text-muted); | |
| margin-top: 1px; | |
| } | |
| .step-connector { | |
| width: 2px; | |
| height: 16px; | |
| background: var(--border); | |
| margin-left: 19px; | |
| transition: background 0.3s ease; | |
| } | |
| .step-connector.active { background: var(--accent-blue); } | |
| .quick-claims { | |
| display: flex; | |
| flex-direction: column; | |
| gap: 0.35rem; | |
| } | |
| .quick-claim { | |
| padding: 0.5rem 0.65rem; | |
| border-radius: var(--radius-xs); | |
| background: var(--bg-glass); | |
| border: 1px solid var(--border); | |
| cursor: pointer; | |
| transition: all 0.2s ease; | |
| font-size: 0.75rem; | |
| } | |
| .quick-claim:hover { | |
| background: var(--bg-card-hover); | |
| border-color: var(--border-active); | |
| } | |
| .quick-claim .qc-id { | |
| font-weight: 600; | |
| color: var(--accent-blue); | |
| font-family: var(--font-mono); | |
| } | |
| .quick-claim .qc-detail { | |
| color: var(--text-muted); | |
| font-size: 0.65rem; | |
| } | |
| .quick-claim.completed { | |
| background: #F0FDF4; | |
| border-color: #86EFAC; | |
| } | |
| .quick-claim.completed .qc-id { | |
| color: #16A34A; | |
| } | |
| .quick-claim.completed .qc-detail { | |
| color: #4ADE80; | |
| } | |
| .quick-claim.completed::after { | |
| content: ' β'; | |
| color: #16A34A; | |
| font-weight: 700; | |
| font-size: 0.75rem; | |
| } | |
| /* Suspended claim β greyed out, not clickable */ | |
| .quick-claim.suspended { | |
| background: #fffbeb; | |
| border-color: #fde68a; | |
| cursor: not-allowed; | |
| opacity: 0.75; | |
| } | |
| .quick-claim.suspended .qc-id { | |
| color: #92400e; | |
| } | |
| .quick-claim.suspended .qc-detail, | |
| .quick-claim.suspended .qc-desc { | |
| color: #b45309; | |
| opacity: 0.8; | |
| } | |
| /* ββ Prior Auth Quick Access β collapsible claim groups ββ */ | |
| .claim-group { | |
| margin-bottom: 0.5rem; | |
| } | |
| .claim-group-header { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.35rem; | |
| padding: 0.4rem 0.5rem; | |
| border-radius: var(--radius-xs); | |
| background: var(--bg-glass); | |
| border: 1px solid var(--border); | |
| cursor: pointer; | |
| font-size: 0.75rem; | |
| font-weight: 600; | |
| color: var(--text-secondary); | |
| list-style: none; | |
| user-select: none; | |
| transition: background 0.2s; | |
| } | |
| .claim-group-header:hover { | |
| background: var(--bg-card-hover); | |
| } | |
| .claim-group-header .group-chevron { | |
| font-size: 0.6rem; | |
| transition: transform 0.2s; | |
| color: var(--text-muted); | |
| } | |
| details[open] > .claim-group-header .group-chevron { | |
| transform: rotate(90deg); | |
| } | |
| .claim-count { | |
| margin-left: auto; | |
| background: rgba(102, 126, 234, 0.15); | |
| color: var(--accent-blue); | |
| border-radius: 999px; | |
| padding: 0 0.4rem; | |
| font-size: 0.65rem; | |
| font-weight: 700; | |
| min-width: 1.2rem; | |
| text-align: center; | |
| } | |
| .quick-claim .qc-desc { | |
| color: var(--text-muted); | |
| font-size: 0.6rem; | |
| margin-top: 0.1rem; | |
| line-height: 1.3; | |
| } | |
| /* ββ CARC group badges (sidebar) ββ */ | |
| .carc-badge { | |
| display: inline-block; | |
| padding: 0.1rem 0.4rem; | |
| border-radius: 4px; | |
| font-size: 0.6rem; | |
| font-weight: 700; | |
| letter-spacing: 0.04em; | |
| font-family: var(--font-mono); | |
| flex-shrink: 0; | |
| } | |
| /* One color per CARC key β extend here when adding new CARCs */ | |
| .carc-197 { background: rgba(102,126,234,0.18); color: #818cf8; } | |
| .carc-183 { background: rgba(251,146,60,0.18); color: #fb923c; } | |
| .carc-252 { background: rgba(168,85,247,0.18); color: #c084fc; } | |
| .carc-197_m62 { background: rgba(20,184,166,0.18); color: #2dd4bf; } | |
| .carc-default { background: rgba(148,163,184,0.18); color: #94a3b8; } | |
| /* ββ Terminal action badges ββ */ | |
| .pa-badge { | |
| display: inline-block; | |
| padding: 0.15rem 0.5rem; | |
| border-radius: 999px; | |
| font-size: 0.7rem; | |
| font-weight: 700; | |
| letter-spacing: 0.03em; | |
| } | |
| .badge-redet { background: rgba(99, 102, 241, 0.15); color: #818cf8; } | |
| .badge-resubmit { background: rgba(34, 197, 94, 0.15); color: #4ade80; } | |
| .badge-reprocessed { background: rgba(20, 184, 166, 0.15); color: #2dd4bf; } | |
| .badge-escalate { background: rgba(251, 191, 36, 0.15); color: #fbbf24; } | |
| .badge-nonrec { background: rgba(239, 68, 68, 0.15); color: #f87171; } | |
| /* ββ Document Review Card ββ */ | |
| .event-card.doc-review { | |
| border-left: 3px solid var(--accent-blue); | |
| padding: 0; | |
| overflow: hidden; | |
| } | |
| .event-card.doc-review .event-body { | |
| padding: 0; | |
| } | |
| .doc-review-card { | |
| display: flex; | |
| flex-direction: column; | |
| } | |
| .doc-review-header { | |
| padding: 0.75rem 1rem; | |
| font-weight: 600; | |
| font-size: 0.875rem; | |
| color: var(--accent-blue); | |
| background: rgba(102, 126, 234, 0.06); | |
| border-bottom: 1px solid var(--border); | |
| } | |
| .doc-review-meta { | |
| padding: 0.625rem 1rem; | |
| display: flex; | |
| flex-wrap: wrap; | |
| gap: 0.75rem; | |
| background: var(--bg-glass); | |
| border-bottom: 1px solid var(--border); | |
| } | |
| .doc-meta-item { | |
| font-size: 0.8rem; | |
| color: var(--text-secondary); | |
| } | |
| .doc-letter-label { | |
| padding: 0.625rem 1rem 0.25rem; | |
| font-size: 0.75rem; | |
| font-weight: 600; | |
| text-transform: uppercase; | |
| letter-spacing: 0.05em; | |
| color: var(--text-muted); | |
| } | |
| .doc-letter-body { | |
| padding: 0.75rem 1rem 1rem; | |
| font-family: 'JetBrains Mono', monospace; | |
| font-size: 0.78rem; | |
| line-height: 1.7; | |
| color: var(--text-primary); | |
| white-space: pre-wrap; | |
| max-height: 380px; | |
| overflow-y: auto; | |
| background: #f8fafc; | |
| border-top: 1px solid var(--border); | |
| } | |
| /* ββ Main Content ββ */ | |
| .main-content { | |
| padding: 1.5rem; | |
| overflow-y: auto; | |
| display: flex; | |
| flex-direction: column; | |
| gap: 1rem; | |
| } | |
| .input-card { | |
| background: var(--bg-card); | |
| border: 1px solid var(--border); | |
| box-shadow: var(--shadow); | |
| border-radius: var(--radius); | |
| padding: 1.5rem; | |
| backdrop-filter: blur(12px); | |
| } | |
| .input-title { | |
| font-size: 1.1rem; | |
| font-weight: 700; | |
| margin-bottom: 0.35rem; | |
| } | |
| .input-desc { | |
| font-size: 0.8rem; | |
| color: var(--text-secondary); | |
| margin-bottom: 1rem; | |
| } | |
| .input-row { | |
| display: flex; | |
| gap: 0.75rem; | |
| align-items: flex-end; | |
| } | |
| .input-wrapper { | |
| flex: 1; | |
| } | |
| .input-wrapper label { | |
| display: block; | |
| font-size: 0.7rem; | |
| font-weight: 600; | |
| text-transform: uppercase; | |
| letter-spacing: 0.05em; | |
| color: var(--text-muted); | |
| margin-bottom: 0.35rem; | |
| } | |
| .input-wrapper input { | |
| width: 100%; | |
| padding: 0.65rem 0.85rem; | |
| background: #f1f5f9; | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius-sm); | |
| color: var(--text-primary); | |
| font-family: var(--font-mono); | |
| font-size: 0.9rem; | |
| outline: none; | |
| transition: border-color 0.2s ease; | |
| } | |
| .input-wrapper input:focus { | |
| border-color: var(--accent-blue); | |
| box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.15); | |
| } | |
| .input-wrapper input::placeholder { | |
| color: var(--text-muted); | |
| } | |
| /* ββ Claim context info strip (below input, above Start Analysis) ββ */ | |
| .claim-context-info { | |
| margin-top: 0.85rem; | |
| padding: 0.65rem 0.9rem; | |
| background: rgba(102, 126, 234, 0.07); | |
| border: 1px solid rgba(102, 126, 234, 0.25); | |
| border-radius: var(--radius-sm); | |
| display: flex; | |
| flex-wrap: wrap; | |
| gap: 0.5rem 1.5rem; | |
| } | |
| .cci-item { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.4rem; | |
| font-size: 0.78rem; | |
| color: var(--text-secondary); | |
| } | |
| .cci-label { | |
| font-weight: 600; | |
| color: var(--text-primary); | |
| white-space: nowrap; | |
| } | |
| .cci-value { | |
| color: var(--text-secondary); | |
| } | |
| .cci-npi { | |
| font-family: var(--font-mono); | |
| font-size: 0.72rem; | |
| color: var(--text-muted); | |
| margin-left: 0.15rem; | |
| } | |
| /* ββ Buttons ββ */ | |
| .btn { | |
| display: inline-flex; | |
| align-items: center; | |
| gap: 0.5rem; | |
| padding: 0.65rem 1.25rem; | |
| border: none; | |
| border-radius: var(--radius-sm); | |
| font-family: var(--font-sans); | |
| font-size: 0.8rem; | |
| font-weight: 600; | |
| cursor: pointer; | |
| transition: all 0.2s ease; | |
| white-space: nowrap; | |
| } | |
| .btn:disabled { | |
| opacity: 0.5; | |
| cursor: not-allowed; | |
| } | |
| .btn-primary { | |
| background: var(--accent-gradient); | |
| color: white; | |
| } | |
| .btn-primary:hover:not(:disabled) { | |
| box-shadow: 0 4px 15px rgba(102, 126, 234, 0.4); | |
| transform: translateY(-1px); | |
| } | |
| .btn-success { | |
| background: var(--success); | |
| color: white; | |
| } | |
| .btn-success:hover:not(:disabled) { | |
| box-shadow: 0 4px 15px rgba(16, 185, 129, 0.4); | |
| transform: translateY(-1px); | |
| } | |
| .btn-danger { | |
| background: transparent; | |
| color: var(--danger); | |
| border: 1px solid rgba(239, 68, 68, 0.3); | |
| } | |
| .btn-danger:hover:not(:disabled) { | |
| background: var(--danger-bg); | |
| } | |
| .btn-ghost { | |
| background: transparent; | |
| color: var(--text-secondary); | |
| border: 1px solid var(--border); | |
| padding: 0.4rem 0.75rem; | |
| font-size: 0.7rem; | |
| } | |
| .btn-ghost:hover { background: var(--bg-glass); } | |
| /* ββ Output Area ββ */ | |
| .output-area { | |
| display: flex; | |
| flex-direction: column; | |
| gap: 0.75rem; | |
| } | |
| .event-card { | |
| background: var(--bg-card); | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| padding: 1rem 1.25rem; | |
| animation: fadeInUp 0.3s ease; | |
| } | |
| @keyframes fadeInUp { | |
| from { opacity: 0; transform: translateY(10px); } | |
| to { opacity: 1; transform: translateY(0); } | |
| } | |
| .event-card.status { | |
| border-left: 3px solid var(--accent-blue); | |
| background: var(--info-bg); | |
| } | |
| .event-card.tool-call { | |
| border-left: 3px solid var(--warning); | |
| font-family: var(--font-mono); | |
| font-size: 0.78rem; | |
| } | |
| .event-card.tool-result { | |
| border-left: 3px solid var(--success); | |
| font-family: var(--font-mono); | |
| font-size: 0.75rem; | |
| color: var(--text-secondary); | |
| max-height: 200px; | |
| overflow-y: auto; | |
| } | |
| .event-card.thinking { | |
| border-left: 3px solid var(--text-muted); | |
| color: var(--text-muted); | |
| font-size: 0.8rem; | |
| font-style: italic; | |
| } | |
| .event-card.final-output { | |
| border: 1px solid var(--border-active); | |
| background: rgba(102, 126, 234, 0.05); | |
| } | |
| .event-card.final-output .markdown-content { | |
| line-height: 1.65; | |
| } | |
| .event-card.final-output h2 { | |
| font-size: 1.1rem; | |
| margin: 1rem 0 0.5rem; | |
| background: var(--accent-gradient); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| background-clip: text; | |
| } | |
| .event-card.final-output h3 { | |
| font-size: 0.95rem; | |
| margin: 0.8rem 0 0.4rem; | |
| color: var(--text-primary); | |
| } | |
| .event-card.final-output table { | |
| width: 100%; | |
| border-collapse: collapse; | |
| margin: 0.5rem 0; | |
| font-size: 0.8rem; | |
| } | |
| .event-card.final-output th, | |
| .event-card.final-output td { | |
| padding: 0.45rem 0.65rem; | |
| border: 1px solid var(--border); | |
| text-align: left; | |
| } | |
| .event-card.final-output th { | |
| background: rgba(102, 126, 234, 0.1); | |
| font-weight: 600; | |
| font-size: 0.75rem; | |
| text-transform: uppercase; | |
| letter-spacing: 0.03em; | |
| } | |
| .event-card.final-output td { | |
| color: var(--text-secondary); | |
| } | |
| .event-card.final-output strong { | |
| color: var(--text-primary); | |
| } | |
| .event-card.final-output ul, .event-card.final-output ol { | |
| padding-left: 1.25rem; | |
| margin: 0.4rem 0; | |
| } | |
| .event-card.final-output li { | |
| margin: 0.2rem 0; | |
| font-size: 0.85rem; | |
| color: var(--text-secondary); | |
| } | |
| .event-card.final-output pre { | |
| background: #f1f5f9; | |
| padding: 0.75rem; | |
| border-radius: var(--radius-sm); | |
| overflow-x: auto; | |
| font-size: 0.75rem; | |
| margin: 0.5rem 0; | |
| } | |
| .event-card.final-output code { | |
| font-family: var(--font-mono); | |
| font-size: 0.8rem; | |
| } | |
| .event-card.error { | |
| border-left: 3px solid var(--danger); | |
| background: var(--danger-bg); | |
| color: var(--danger); | |
| } | |
| .event-card.checkpoint-resolved { | |
| border: 1px solid #e2e8f0; | |
| background: #fafafa; | |
| border-radius: 8px; | |
| } | |
| .event-label { | |
| font-size: 0.65rem; | |
| text-transform: uppercase; | |
| letter-spacing: 0.08em; | |
| font-weight: 600; | |
| margin-bottom: 0.3rem; | |
| display: flex; | |
| align-items: center; | |
| gap: 0.4rem; | |
| } | |
| .event-label .label-icon { | |
| width: 14px; | |
| height: 14px; | |
| } | |
| .tool-name { | |
| color: var(--warning); | |
| font-weight: 700; | |
| } | |
| /* ββ Approval Section ββ */ | |
| .approval-section { | |
| position: sticky; | |
| bottom: 0; | |
| z-index: 10; | |
| } | |
| .approval-card { | |
| background: #ffffff; | |
| border: 1px solid var(--border-active); | |
| border-radius: var(--radius); | |
| padding: 1.25rem; | |
| display: flex; | |
| align-items: flex-start; | |
| gap: 1rem; | |
| box-shadow: var(--shadow-lg); | |
| } | |
| .approval-buttons { | |
| display: flex; | |
| gap: 0.5rem; | |
| flex-shrink: 0; | |
| align-self: center; | |
| } | |
| .approval-icon { font-size: 1.5rem; } | |
| .approval-text { | |
| flex: 1; | |
| font-size: 0.85rem; | |
| color: var(--text-secondary); | |
| line-height: 1.5; | |
| } | |
| /* ββ Loading Spinner ββ */ | |
| .spinner { | |
| display: inline-block; | |
| width: 16px; | |
| height: 16px; | |
| border: 2px solid rgba(255,255,255,0.2); | |
| border-top-color: white; | |
| border-radius: 50%; | |
| animation: spin 0.8s linear infinite; | |
| } | |
| @keyframes spin { to { transform: rotate(360deg); } } | |
| /* ββ Database Panel ββ */ | |
| .db-panel { | |
| background: var(--bg-secondary); | |
| border-left: 1px solid var(--border); | |
| display: flex; | |
| flex-direction: column; | |
| overflow: hidden; | |
| } | |
| .db-tabs { | |
| display: flex; | |
| border-bottom: 1px solid var(--border); | |
| padding: 0; | |
| } | |
| .db-tab { | |
| flex: 1; | |
| padding: 0.6rem 0.25rem; | |
| background: transparent; | |
| border: none; | |
| color: var(--text-muted); | |
| font-family: var(--font-sans); | |
| font-size: 0.65rem; | |
| font-weight: 600; | |
| cursor: pointer; | |
| border-bottom: 2px solid transparent; | |
| transition: all 0.2s ease; | |
| text-transform: uppercase; | |
| letter-spacing: 0.03em; | |
| } | |
| .db-tab:hover { color: var(--text-secondary); } | |
| .db-tab.active { | |
| color: var(--accent-blue); | |
| border-bottom-color: var(--accent-blue); | |
| } | |
| .db-content { | |
| flex: 1; | |
| overflow-y: auto; | |
| padding: 0.75rem; | |
| font-size: 0.72rem; | |
| } | |
| .db-refresh { | |
| margin: 0.5rem; | |
| } | |
| .db-table { | |
| width: 100%; | |
| border-collapse: collapse; | |
| font-size: 0.68rem; | |
| } | |
| .db-table th { | |
| background: rgba(102, 126, 234, 0.08); | |
| padding: 0.4rem 0.5rem; | |
| text-align: left; | |
| font-weight: 600; | |
| color: var(--text-secondary); | |
| text-transform: uppercase; | |
| letter-spacing: 0.03em; | |
| font-size: 0.6rem; | |
| position: sticky; | |
| top: 0; | |
| border-bottom: 1px solid var(--border); | |
| } | |
| .db-table td { | |
| padding: 0.35rem 0.5rem; | |
| border-bottom: 1px solid var(--border); | |
| color: var(--text-muted); | |
| max-width: 120px; | |
| overflow: hidden; | |
| text-overflow: ellipsis; | |
| white-space: nowrap; | |
| font-family: var(--font-mono); | |
| font-size: 0.65rem; | |
| } | |
| .db-table tr:hover td { | |
| color: var(--text-secondary); | |
| background: var(--bg-glass); | |
| } | |
| @keyframes highlightFade { | |
| 0% { background-color: rgba(16, 185, 129, 0.2); } | |
| 100% { background-color: transparent; } | |
| } | |
| .db-table tr.new-record td { | |
| animation: highlightFade 4s ease-out; | |
| border-bottom: 2px solid var(--success); | |
| color: var(--text-primary); | |
| font-weight: 500; | |
| } | |
| .db-loading { | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| height: 100px; | |
| color: var(--text-muted); | |
| font-size: 0.8rem; | |
| } | |
| .db-empty { | |
| text-align: center; | |
| padding: 2rem 1rem; | |
| color: var(--text-muted); | |
| font-size: 0.75rem; | |
| } | |
| /* ββ Responsive ββ */ | |
| @media (max-width: 1200px) { | |
| .app-container { | |
| grid-template-columns: 200px 1fr 260px; | |
| } | |
| } | |
| @media (max-width: 900px) { | |
| .app-container { | |
| grid-template-columns: 1fr; | |
| } | |
| .sidebar, .db-panel { | |
| display: none; | |
| } | |
| } | |
| /* ββ Scrollbar ββ */ | |
| ::-webkit-scrollbar { width: 6px; } | |
| ::-webkit-scrollbar-track { background: transparent; } | |
| ::-webkit-scrollbar-thumb { | |
| background: rgba(0,0,0,0.15); | |
| border-radius: 3px; | |
| } | |
| ::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,0.25); } | |
| /* ββ Agent label badges ββ */ | |
| .agent-badge { | |
| display: inline-flex; | |
| align-items: center; | |
| gap: 0.3rem; | |
| padding: 0.15rem 0.5rem; | |
| border-radius: 10px; | |
| font-size: 0.6rem; | |
| font-weight: 700; | |
| text-transform: uppercase; | |
| letter-spacing: 0.05em; | |
| } | |
| .agent-badge.rca { | |
| background: rgba(59, 130, 246, 0.15); | |
| color: var(--info); | |
| } | |
| .agent-badge.execution { | |
| background: rgba(168, 85, 247, 0.15); | |
| color: #a855f7; | |
| } | |
| /* ββ Intro Screen Overlay ββ */ | |
| /* ββ Intro / Landing Screen βββββββββββββββββββββββββββββββββββββββ */ | |
| .intro-screen { | |
| position: fixed; | |
| top: 0; left: 0; | |
| width: 100vw; height: 100vh; | |
| background: linear-gradient(140deg, #EBF4FF 0%, #F0F9FF 55%, #E0F2FE 100%); | |
| z-index: 9999; | |
| display: flex; | |
| align-items: center; | |
| padding: 0 6%; | |
| transition: opacity 0.5s ease; | |
| overflow: hidden; | |
| } | |
| .intro-content { | |
| width: 100%; | |
| max-width: 1280px; | |
| display: flex; | |
| flex-direction: column; | |
| gap: 1.75rem; | |
| animation: fadeInUp 0.5s ease; | |
| } | |
| .intro-header { text-align: left; } | |
| .intro-badge { | |
| display: inline-block; | |
| font-size: 0.7rem; | |
| font-weight: 600; | |
| letter-spacing: 0.08em; | |
| text-transform: uppercase; | |
| color: #0077B6; | |
| background: #DBEAFE; | |
| padding: 0.3rem 0.85rem; | |
| border-radius: 2rem; | |
| margin-bottom: 0.65rem; | |
| } | |
| .intro-title { | |
| font-size: 1.9rem; | |
| font-weight: 700; | |
| color: #1E3A5F; | |
| margin: 0 0 0.3rem 0; | |
| line-height: 1.2; | |
| } | |
| .intro-tagline { | |
| font-size: 0.9rem; | |
| color: #4A6785; | |
| margin: 0; | |
| } | |
| .intro-sections { | |
| display: grid; | |
| grid-template-columns: 1fr 1fr 1fr; | |
| gap: 1.25rem; | |
| } | |
| .intro-section { | |
| background: #fff; | |
| border-radius: 10px; | |
| padding: 1.25rem 1.5rem; | |
| border-top: 3px solid; | |
| box-shadow: 0 2px 10px rgba(0, 60, 120, 0.07); | |
| } | |
| .intro-section.problem { border-top-color: #EF4444; } | |
| .intro-section.solution { border-top-color: #10B981; } | |
| .intro-section.implementation { border-top-color: #0077B6; } | |
| .section-header { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.5rem; | |
| margin-bottom: 0.6rem; | |
| } | |
| .section-icon { font-size: 1rem; } | |
| .section-header h2 { | |
| font-size: 0.78rem; | |
| font-weight: 700; | |
| text-transform: uppercase; | |
| letter-spacing: 0.07em; | |
| color: #1E3A5F; | |
| margin: 0; | |
| } | |
| .section-context { | |
| font-size: 0.8rem; | |
| color: #4A6785; | |
| margin: 0 0 0.65rem 0; | |
| line-height: 1.55; | |
| } | |
| .intro-section ul { | |
| list-style: none; | |
| padding: 0; margin: 0; | |
| } | |
| .intro-section ul li { | |
| font-size: 0.8rem; | |
| color: #1E3A5F; | |
| padding: 0.25rem 0 0.25rem 1.1rem; | |
| position: relative; | |
| line-height: 1.45; | |
| } | |
| .intro-section ul li::before { | |
| content: 'β'; | |
| position: absolute; | |
| left: 0; | |
| color: #0077B6; | |
| font-size: 0.72rem; | |
| top: 0.28rem; | |
| } | |
| .agent-item { | |
| background: #F0F7FF; | |
| border-radius: 7px; | |
| padding: 0.65rem 0.85rem; | |
| margin-bottom: 0.6rem; | |
| } | |
| .agent-item:last-child { margin-bottom: 0; } | |
| .agent-label { | |
| font-size: 0.8rem; | |
| font-weight: 600; | |
| color: #1E3A5F; | |
| margin-bottom: 0.2rem; | |
| display: flex; | |
| align-items: center; | |
| gap: 0.35rem; | |
| } | |
| .agent-item p { | |
| font-size: 0.77rem; | |
| color: #4A6785; | |
| line-height: 1.5; | |
| margin: 0; | |
| } | |
| .intro-cta { text-align: left; } | |
| .intro-note { | |
| margin-top: 0.65rem; | |
| font-size: 0.75rem; | |
| color: #4A6785; | |
| line-height: 1.55; | |
| } | |
| .btn-enter { | |
| background: #0077B6; | |
| color: #fff; | |
| border: none; | |
| padding: 0.75rem 2rem; | |
| border-radius: 7px; | |
| font-size: 0.92rem; | |
| font-weight: 600; | |
| cursor: pointer; | |
| letter-spacing: 0.01em; | |
| transition: background 0.2s ease, transform 0.15s ease; | |
| } | |
| .btn-enter:hover { | |
| background: #023E8A; | |
| transform: translateY(-1px); | |
| } | |
| /* ββ Metrics Card ββ */ | |
| .metrics-card { | |
| display: flex; | |
| align-items: center; | |
| justify-content: space-around; | |
| border: 1px dashed var(--accent-blue); | |
| border-radius: var(--radius); | |
| padding: 1rem 1.25rem; | |
| margin-top: 0.25rem; | |
| animation: fadeInUp 0.4s ease; | |
| background: rgba(102, 126, 234, 0.05); | |
| } | |
| .metric { | |
| font-size: 0.85rem; | |
| color: var(--text-secondary); | |
| display: flex; | |
| align-items: center; | |
| gap: 0.4rem; | |
| } | |
| .metric strong { | |
| color: var(--text-primary); | |
| } | |
| .metric-icon { | |
| font-size: 1.1rem; | |
| } | |
| /* ββ Claim Queue βββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .countdown-banner { | |
| display: flex; | |
| align-items: center; | |
| justify-content: space-between; | |
| background: #EFF6FF; | |
| border: 1px solid #BFDBFE; | |
| border-left: 4px solid #0077B6; | |
| border-radius: 8px; | |
| padding: 0.85rem 1.25rem; | |
| margin-top: 1rem; | |
| font-size: 0.88rem; | |
| color: #1E3A5F; | |
| animation: fadeInUp 0.3s ease; | |
| } | |
| .btn-cancel-queue { | |
| background: transparent; | |
| border: 1px solid #93C5FD; | |
| color: #0077B6; | |
| padding: 0.3rem 0.8rem; | |
| border-radius: 5px; | |
| font-size: 0.8rem; | |
| font-weight: 600; | |
| cursor: pointer; | |
| margin-left: 1rem; | |
| white-space: nowrap; | |
| transition: background 0.15s ease; | |
| } | |
| .btn-cancel-queue:hover { | |
| background: #DBEAFE; | |
| } | |
| .final-metrics { | |
| border-top: 3px solid #0077B6; | |
| background: #F0F7FF; | |
| } | |
| .final-metrics-title { | |
| font-weight: 700; | |
| font-size: 0.9rem; | |
| color: #1E3A5F; | |
| margin-bottom: 0.5rem; | |
| } | |
| /* ββ Payer Voice Call Panel ββ */ | |
| .payer-call-panel { | |
| border: 1.5px solid #0077B6; | |
| border-radius: var(--radius); | |
| background: linear-gradient(135deg, #f0f7ff 0%, #e8f4fd 100%); | |
| overflow: hidden; | |
| margin-top: 0.5rem; | |
| animation: fadeInUp 0.4s ease; | |
| } | |
| .call-header { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.75rem; | |
| padding: 0.85rem 1.25rem; | |
| background: #0077B6; | |
| color: white; | |
| } | |
| .call-icon { | |
| font-size: 1.4rem; | |
| } | |
| .call-meta { | |
| flex: 1; | |
| } | |
| .call-title { | |
| font-weight: 700; | |
| font-size: 0.85rem; | |
| letter-spacing: 0.06em; | |
| } | |
| .call-subtitle { | |
| font-size: 0.75rem; | |
| opacity: 0.85; | |
| } | |
| .call-status-dot { | |
| width: 10px; | |
| height: 10px; | |
| border-radius: 50%; | |
| background: #4ade80; | |
| box-shadow: 0 0 0 3px rgba(74, 222, 128, 0.3); | |
| animation: pulse 1.5s infinite; | |
| } | |
| .call-transcript { | |
| padding: 1rem 1.25rem; | |
| display: flex; | |
| flex-direction: column; | |
| gap: 1rem; | |
| } | |
| .call-turn { | |
| display: flex; | |
| flex-direction: column; | |
| gap: 0.35rem; | |
| } | |
| .call-speaker { | |
| font-size: 0.75rem; | |
| font-weight: 600; | |
| color: #1E3A5F; | |
| opacity: 0.75; | |
| } | |
| .call-bubble { | |
| padding: 0.65rem 0.9rem; | |
| border-radius: 0.5rem; | |
| font-size: 0.85rem; | |
| line-height: 1.5; | |
| color: #1E3A5F; | |
| max-width: 90%; | |
| } | |
| .rca-bubble { | |
| background: #dbeafe; | |
| border-left: 3px solid #3b82f6; | |
| align-self: flex-start; | |
| } | |
| .payer-bubble { | |
| background: #dcfce7; | |
| border-left: 3px solid #16a34a; | |
| align-self: flex-start; | |
| } | |
| .call-audio-row { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.5rem; | |
| margin-top: 0.25rem; | |
| } | |
| .btn-play-audio { | |
| font-size: 0.72rem; | |
| padding: 0.25rem 0.7rem; | |
| border-radius: 2rem; | |
| border: 1px solid #0077B6; | |
| background: white; | |
| color: #0077B6; | |
| cursor: pointer; | |
| transition: background 0.2s; | |
| } | |
| .btn-play-audio:hover { | |
| background: #0077B6; | |
| color: white; | |
| } | |
| .call-footer { | |
| padding: 0.6rem 1.25rem; | |
| background: rgba(0, 119, 182, 0.08); | |
| font-size: 0.75rem; | |
| color: #0077B6; | |
| font-weight: 500; | |
| border-top: 1px solid rgba(0, 119, 182, 0.15); | |
| display: flex; | |
| align-items: center; | |
| gap: 1rem; | |
| } | |
| .btn-continue-call { | |
| background: #0077B6; | |
| color: white; | |
| border: none; | |
| border-radius: 6px; | |
| padding: 0.35rem 0.9rem; | |
| font-size: 0.75rem; | |
| font-weight: 600; | |
| cursor: pointer; | |
| transition: background 0.2s; | |
| } | |
| .btn-continue-call:hover { | |
| background: #005f92; | |
| } | |
| /* ββ Ringing / calling state ββ */ | |
| .payer-call-ringing .call-header { | |
| background: #1a5276; | |
| animation: headerPulse 1.2s ease-in-out infinite; | |
| } | |
| @keyframes headerPulse { | |
| 0%, 100% { background: #1a5276; } | |
| 50% { background: #0077B6; } | |
| } | |
| .ringing-dot { | |
| background: #facc15 ; | |
| box-shadow: 0 0 0 3px rgba(250, 204, 21, 0.35) ; | |
| animation: ringDotPulse 0.6s ease-in-out infinite ; | |
| } | |
| @keyframes ringDotPulse { | |
| 0%, 100% { transform: scale(1); opacity: 1; } | |
| 50% { transform: scale(1.4); opacity: 0.6; } | |
| } | |
| .call-icon-ringing { | |
| animation: shake 0.5s ease-in-out infinite; | |
| } | |
| @keyframes shake { | |
| 0%, 100% { transform: rotate(0deg); } | |
| 20% { transform: rotate(-15deg); } | |
| 40% { transform: rotate(15deg); } | |
| 60% { transform: rotate(-10deg); } | |
| 80% { transform: rotate(10deg); } | |
| } | |
| .call-connecting { | |
| padding: 1.5rem 1.25rem; | |
| display: flex; | |
| flex-direction: column; | |
| align-items: center; | |
| gap: 0.85rem; | |
| } | |
| .ringing-bars { | |
| display: flex; | |
| align-items: flex-end; | |
| gap: 4px; | |
| height: 32px; | |
| } | |
| .ring-bar { | |
| display: inline-block; | |
| width: 6px; | |
| border-radius: 3px; | |
| background: #0077B6; | |
| animation: barBounce 0.8s ease-in-out infinite; | |
| } | |
| .ring-bar:nth-child(1) { animation-delay: 0s; height: 12px; } | |
| .ring-bar:nth-child(2) { animation-delay: 0.1s; height: 20px; } | |
| .ring-bar:nth-child(3) { animation-delay: 0.2s; height: 28px; } | |
| .ring-bar:nth-child(4) { animation-delay: 0.3s; height: 20px; } | |
| .ring-bar:nth-child(5) { animation-delay: 0.4s; height: 12px; } | |
| @keyframes barBounce { | |
| 0%, 100% { transform: scaleY(1); opacity: 0.5; } | |
| 50% { transform: scaleY(1.8); opacity: 1; } | |
| } | |
| .ringing-label { | |
| font-size: 0.82rem; | |
| color: #1E3A5F; | |
| font-weight: 500; | |
| opacity: 0.8; | |
| } | |
| /* ββ Payer Call Checkpoint Card ββ */ | |
| .payer-call-checkpoint-card { | |
| display: flex; | |
| flex-direction: column; | |
| background: var(--bg-secondary); | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| overflow: hidden; | |
| } | |
| .payer-call-checkpoint-header { | |
| padding: 0.75rem 1rem; | |
| font-weight: 600; | |
| font-size: 0.875rem; | |
| color: var(--accent-blue); | |
| background: rgba(102, 126, 234, 0.06); | |
| border-bottom: 1px solid var(--border); | |
| display: flex; | |
| align-items: center; | |
| gap: 0.5rem; | |
| } | |
| .call-reason-block, | |
| .call-instructions-block { | |
| padding: 0.75rem 1rem; | |
| border-bottom: 1px solid var(--border); | |
| } | |
| .call-block-label { | |
| font-size: 0.72rem; | |
| font-weight: 700; | |
| text-transform: uppercase; | |
| letter-spacing: 0.06em; | |
| color: var(--text-muted); | |
| margin-bottom: 0.35rem; | |
| } | |
| .call-block-body { | |
| font-size: 0.83rem; | |
| line-height: 1.55; | |
| color: var(--text-primary); | |
| } | |
| .payer-contact-row { | |
| display: flex; | |
| align-items: center; | |
| gap: 0.6rem; | |
| padding: 0.65rem 1rem; | |
| background: rgba(102, 126, 234, 0.04); | |
| border-bottom: 1px solid var(--border); | |
| font-size: 0.82rem; | |
| color: var(--text-secondary); | |
| } | |
| .payer-contact-row .contact-phone { | |
| font-weight: 600; | |
| color: var(--accent-blue); | |
| } | |
| .call-actions-row { | |
| padding: 0.75rem 1rem; | |
| border-bottom: 1px solid var(--border); | |
| } | |
| .outcome-section-label { | |
| padding: 0.6rem 1rem 0.35rem; | |
| font-size: 0.72rem; | |
| font-weight: 700; | |
| text-transform: uppercase; | |
| letter-spacing: 0.06em; | |
| color: var(--text-muted); | |
| } | |
| .outcome-btn-row { | |
| display: flex; | |
| flex-wrap: wrap; | |
| gap: 0.5rem; | |
| padding: 0.5rem 1rem 1rem; | |
| } | |
| .outcome-btn { | |
| padding: 0.45rem 0.9rem; | |
| border-radius: 999px; | |
| font-size: 0.8rem; | |
| font-weight: 500; | |
| cursor: pointer; | |
| border: 1.5px solid var(--border-active); | |
| background: var(--bg-primary); | |
| color: var(--accent-blue); | |
| transition: all 0.18s ease; | |
| } | |
| .outcome-btn:hover:not(:disabled) { | |
| background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); | |
| border-color: transparent; | |
| color: #fff; | |
| box-shadow: 0 2px 8px rgba(102, 126, 234, 0.35); | |
| transform: translateY(-1px); | |
| } | |
| .outcome-btn:disabled { | |
| opacity: 0.42; | |
| cursor: not-allowed; | |
| transform: none; | |
| box-shadow: none; | |
| } | |
| .outcome-btn.selected { | |
| background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); | |
| border-color: transparent; | |
| color: #fff; | |
| opacity: 1; | |
| } | |
| /* ββ Suspend / Resume βββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| /* Suspend button styled as a 3rd outcome option */ | |
| .outcome-btn-suspend { | |
| background: #fff8e1 ; | |
| border-color: #f59e0b ; | |
| color: #92400e ; | |
| } | |
| .outcome-btn-suspend:hover:not(:disabled) { | |
| background: #fef3c7 ; | |
| border-color: #d97706 ; | |
| transform: translateY(-1px); | |
| } | |
| /* Resume Panel (main content area) */ | |
| .resume-panel { | |
| background: #fff; | |
| border: 1.5px solid #e2e8f0; | |
| border-radius: 12px; | |
| padding: 24px 28px; | |
| max-width: 680px; | |
| margin: 24px auto; | |
| box-shadow: 0 2px 8px rgba(0,0,0,0.06); | |
| } | |
| .resume-panel-header { | |
| font-size: 1.1em; | |
| font-weight: 700; | |
| color: #1e293b; | |
| margin-bottom: 18px; | |
| padding-bottom: 12px; | |
| border-bottom: 1px solid #e2e8f0; | |
| } | |
| .resume-meta-grid { | |
| display: grid; | |
| grid-template-columns: repeat(3, 1fr); | |
| gap: 12px; | |
| margin-bottom: 18px; | |
| } | |
| .resume-label { | |
| display: block; | |
| font-size: 0.75em; | |
| color: #64748b; | |
| text-transform: uppercase; | |
| letter-spacing: 0.05em; | |
| margin-bottom: 2px; | |
| } | |
| .resume-value { font-weight: 600; color: #1e293b; font-size: 0.9em; } | |
| .resume-section-label { | |
| font-size: 0.8em; | |
| font-weight: 700; | |
| color: #64748b; | |
| text-transform: uppercase; | |
| letter-spacing: 0.06em; | |
| margin: 14px 0 6px; | |
| } | |
| .resume-finding { | |
| background: #f8fafc; | |
| border: 1px solid #e2e8f0; | |
| border-radius: 6px; | |
| padding: 10px 12px; | |
| font-size: 0.9em; | |
| color: #334155; | |
| line-height: 1.55; | |
| } | |
| .resume-verdict-row { | |
| display: flex; | |
| flex-direction: column; | |
| gap: 8px; | |
| } | |
| .resume-verdict-option { | |
| display: flex; | |
| align-items: center; | |
| gap: 8px; | |
| font-size: 0.92em; | |
| cursor: pointer; | |
| padding: 8px 12px; | |
| border: 1px solid #e2e8f0; | |
| border-radius: 6px; | |
| transition: background 0.12s; | |
| } | |
| .resume-verdict-option:hover { background: #f8fafc; } | |
| .resume-verdict-option input[type="radio"] { accent-color: #6366f1; } | |
| /* Resume summary card (Option B β shown at top of resumed pipeline) */ | |
| .resume-summary-card { | |
| background: linear-gradient(135deg, #f0f4ff 0%, #faf5ff 100%); | |
| border: 1.5px solid #c7d2fe; | |
| border-radius: 10px; | |
| padding: 16px 18px; | |
| margin-bottom: 4px; | |
| } | |
| .resume-summary-header { | |
| font-weight: 700; | |
| color: #3730a3; | |
| margin-bottom: 10px; | |
| font-size: 0.95em; | |
| } | |
| .resume-summary-row { | |
| font-size: 0.88em; | |
| color: #334155; | |
| margin-bottom: 5px; | |
| line-height: 1.5; | |
| } | |
| /* ββ EHR Case Notes block βββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .case-notes-block { | |
| margin-top: 14px; | |
| padding: 14px 16px; | |
| background: rgba(34, 197, 94, 0.06); | |
| border: 1px solid rgba(34, 197, 94, 0.25); | |
| border-radius: 8px; | |
| } | |
| .case-notes-label { | |
| font-size: 0.82rem; | |
| font-weight: 600; | |
| color: #22c55e; | |
| letter-spacing: 0.04em; | |
| text-transform: uppercase; | |
| margin-bottom: 8px; | |
| } | |
| .case-notes-body { | |
| font-size: 0.88rem; | |
| color: var(--text-secondary, #cdd6f4); | |
| line-height: 1.6; | |
| white-space: pre-wrap; | |
| } | |
| /* ββ Header icon button (gear icon) βββββββββββββββββββββββββββββββββββββββ */ | |
| .header-icon-btn { | |
| display: inline-flex; | |
| align-items: center; | |
| justify-content: center; | |
| width: 34px; | |
| height: 34px; | |
| border-radius: var(--radius-sm); | |
| text-decoration: none; | |
| font-size: 1.15rem; | |
| transition: background 0.15s; | |
| margin-right: 8px; | |
| } | |
| .header-icon-btn:hover { | |
| background: rgba(102, 126, 234, 0.12); | |
| } | |
| /* ββ Onboarding page layout ββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .ob-container { | |
| display: grid; | |
| grid-template-columns: 200px 1fr; | |
| flex: 1; /* fills remaining body height after header + context bar */ | |
| min-height: 0; /* required for flex children to shrink correctly */ | |
| overflow: hidden; | |
| } | |
| .ob-nav { | |
| background: var(--bg-secondary); | |
| border-right: 1px solid var(--border); | |
| padding: 16px 0; | |
| display: flex; | |
| flex-direction: column; | |
| gap: 2px; | |
| overflow-y: auto; | |
| } | |
| .ob-nav-item { | |
| display: flex; | |
| align-items: center; | |
| gap: 8px; | |
| padding: 10px 16px; | |
| font-size: 0.88rem; | |
| font-weight: 500; | |
| color: var(--text-secondary); | |
| cursor: pointer; | |
| border-left: 3px solid transparent; | |
| transition: all 0.15s; | |
| user-select: none; | |
| } | |
| .ob-nav-item:hover { | |
| background: rgba(102,126,234,0.07); | |
| color: var(--text-primary); | |
| } | |
| .ob-nav-item.active { | |
| background: rgba(102,126,234,0.1); | |
| color: var(--accent-blue); | |
| border-left-color: var(--accent-blue); | |
| } | |
| .ob-nav-icon { font-size: 1rem; } | |
| .ob-main { | |
| overflow-y: auto; | |
| padding: 24px 28px; | |
| background: var(--bg-primary); | |
| } | |
| /* Practice context bar */ | |
| .ob-context-bar { | |
| display: flex; | |
| align-items: center; | |
| gap: 12px; | |
| padding: 10px 16px; | |
| background: var(--bg-secondary); | |
| border-bottom: 1px solid var(--border); | |
| font-size: 0.88rem; | |
| flex-shrink: 0; /* never compressed by flex layout */ | |
| } | |
| .ob-context-bar label { | |
| font-weight: 600; | |
| color: var(--text-secondary); | |
| white-space: nowrap; | |
| } | |
| .ob-context-bar select { | |
| flex: 1; | |
| max-width: 320px; | |
| padding: 6px 10px; | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius-xs); | |
| background: var(--bg-primary); | |
| font-size: 0.88rem; | |
| color: var(--text-primary); | |
| cursor: pointer; | |
| } | |
| /* Tab panels */ | |
| .ob-tab { display: none; } | |
| .ob-tab.active { display: block; } | |
| .ob-section-title { | |
| font-size: 1.05rem; | |
| font-weight: 600; | |
| color: var(--text-primary); | |
| margin-bottom: 4px; | |
| } | |
| .ob-section-sub { | |
| font-size: 0.82rem; | |
| color: var(--text-muted); | |
| margin-bottom: 20px; | |
| } | |
| /* Onboarding form */ | |
| .ob-form { | |
| background: var(--bg-secondary); | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| padding: 20px 24px; | |
| margin-bottom: 24px; | |
| } | |
| .ob-form-grid { | |
| display: grid; | |
| grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); | |
| gap: 14px 20px; | |
| } | |
| .ob-field { | |
| display: flex; | |
| flex-direction: column; | |
| gap: 5px; | |
| } | |
| .ob-field label { | |
| font-size: 0.8rem; | |
| font-weight: 600; | |
| color: var(--text-secondary); | |
| text-transform: uppercase; | |
| letter-spacing: 0.04em; | |
| } | |
| .ob-field input, | |
| .ob-field select, | |
| .ob-field textarea { | |
| padding: 8px 10px; | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius-xs); | |
| background: var(--bg-primary); | |
| font-size: 0.88rem; | |
| color: var(--text-primary); | |
| font-family: var(--font-sans); | |
| transition: border-color 0.15s; | |
| } | |
| .ob-field input:focus, | |
| .ob-field select:focus, | |
| .ob-field textarea:focus { | |
| outline: none; | |
| border-color: var(--accent-blue); | |
| } | |
| .ob-field input[readonly], | |
| .ob-field select[disabled], | |
| .ob-field textarea[readonly] { | |
| background: rgba(0,0,0,0.03); | |
| color: var(--text-muted); | |
| cursor: not-allowed; | |
| } | |
| .ob-field.span2 { grid-column: span 2; } | |
| .ob-field.span3 { grid-column: span 3; } | |
| .ob-form-footer { | |
| display: flex; | |
| align-items: center; | |
| gap: 10px; | |
| margin-top: 18px; | |
| flex-wrap: wrap; | |
| } | |
| /* Onboarding table */ | |
| .ob-table-wrap { | |
| background: var(--bg-secondary); | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius); | |
| overflow: hidden; | |
| margin-bottom: 24px; | |
| } | |
| .ob-table { | |
| width: 100%; | |
| border-collapse: collapse; | |
| font-size: 0.85rem; | |
| } | |
| .ob-table th { | |
| background: rgba(102,126,234,0.06); | |
| padding: 9px 12px; | |
| text-align: left; | |
| font-weight: 600; | |
| color: var(--text-secondary); | |
| font-size: 0.78rem; | |
| text-transform: uppercase; | |
| letter-spacing: 0.04em; | |
| border-bottom: 1px solid var(--border); | |
| } | |
| .ob-table td { | |
| padding: 9px 12px; | |
| border-bottom: 1px solid var(--border); | |
| color: var(--text-primary); | |
| } | |
| .ob-table tr:last-child td { border-bottom: none; } | |
| .ob-table tr:hover td { background: rgba(102,126,234,0.04); } | |
| .ob-table .badge { | |
| display: inline-block; | |
| padding: 2px 8px; | |
| border-radius: 20px; | |
| font-size: 0.75rem; | |
| font-weight: 600; | |
| } | |
| .ob-table .badge-admin { background: rgba(102,126,234,0.15); color: var(--accent-blue); } | |
| .ob-table .badge-user { background: rgba(148,163,184,0.15); color: var(--text-muted); } | |
| .ob-table-empty { | |
| padding: 24px; | |
| text-align: center; | |
| color: var(--text-muted); | |
| font-size: 0.88rem; | |
| } | |
| /* CSV upload strip */ | |
| .ob-csv-strip { | |
| display: flex; | |
| align-items: center; | |
| gap: 10px; | |
| padding: 10px 14px; | |
| background: rgba(102,126,234,0.05); | |
| border: 1px dashed rgba(102,126,234,0.3); | |
| border-radius: var(--radius-sm); | |
| margin-bottom: 16px; | |
| font-size: 0.85rem; | |
| color: var(--text-secondary); | |
| } | |
| .ob-csv-strip input[type="file"] { display: none; } | |
| /* File upload strip (for PDFs/docs) */ | |
| .ob-file-row { | |
| display: flex; | |
| align-items: center; | |
| gap: 10px; | |
| margin-top: 8px; | |
| font-size: 0.83rem; | |
| color: var(--text-muted); | |
| } | |
| .ob-file-row a { color: var(--accent-blue); text-decoration: none; } | |
| .ob-file-row a:hover { text-decoration: underline; } | |
| /* Toast notification */ | |
| .ob-toast { | |
| position: fixed; | |
| bottom: 24px; | |
| right: 24px; | |
| padding: 10px 18px; | |
| border-radius: var(--radius-sm); | |
| font-size: 0.88rem; | |
| font-weight: 500; | |
| z-index: 9999; | |
| animation: fadeInUp 0.25s ease; | |
| pointer-events: none; | |
| } | |
| .ob-toast.success { background: var(--success); color: #fff; } | |
| .ob-toast.error { background: var(--danger); color: #fff; } | |
| /* Edit row button */ | |
| .ob-edit-btn { | |
| padding: 3px 10px; | |
| font-size: 0.78rem; | |
| border: 1px solid var(--border); | |
| border-radius: var(--radius-xs); | |
| background: transparent; | |
| cursor: pointer; | |
| color: var(--text-secondary); | |
| transition: all 0.12s; | |
| } | |
| .ob-edit-btn:hover { | |
| border-color: var(--accent-blue); | |
| color: var(--accent-blue); | |
| } | |
| /* ββ Batch Upload βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .batch-upload-bar { | |
| display: flex; | |
| align-items: center; | |
| gap: 8px; | |
| padding: 8px 12px; | |
| margin: 8px 0 4px; | |
| } | |
| .btn-upload-csv { | |
| flex: 1; | |
| display: inline-block; | |
| padding: 6px 10px; | |
| background: var(--accent-blue); | |
| color: #fff; | |
| border-radius: var(--radius-xs); | |
| font-size: 0.78rem; | |
| font-weight: 600; | |
| cursor: pointer; | |
| text-align: center; | |
| transition: opacity 0.15s; | |
| } | |
| .btn-upload-csv:hover { opacity: 0.85; } | |
| .btn-download-template { | |
| font-size: 0.75rem; | |
| color: var(--text-secondary); | |
| text-decoration: none; | |
| white-space: nowrap; | |
| } | |
| .btn-download-template:hover { color: var(--accent-blue); } | |
| .batch-progress { | |
| font-size: 0.75rem; | |
| color: var(--text-secondary); | |
| padding: 4px 12px 2px; | |
| } | |
| /* Batch claim status badges */ | |
| .quick-claim.batch-pending { border-left: 3px solid #3b82f6; } | |
| .quick-claim.batch-inprogress{ border-left: 3px solid #f59e0b; } | |
| .quick-claim.batch-complete { border-left: 3px solid #22c55e; opacity: 0.7; pointer-events: none; } | |
| .quick-claim.batch-failed { border-left: 3px solid #ef4444; opacity: 0.7; pointer-events: none; } | |
| .quick-claim.batch-unroutable{ border-left: 3px solid #9ca3af; opacity: 0.6; pointer-events: none; } | |
| .qc-status-badge { | |
| font-size: 0.68rem; | |
| font-weight: 600; | |
| padding: 1px 5px; | |
| border-radius: 3px; | |
| margin-left: 4px; | |
| vertical-align: middle; | |
| } | |
| .badge-pending { background: #dbeafe; color: #1d4ed8; } | |
| .badge-inprogress { background: #fef3c7; color: #92400e; } | |
| .badge-complete { background: #dcfce7; color: #166534; } | |
| .badge-failed { background: #fee2e2; color: #991b1b; } | |
| .badge-unroutable { background: #f3f4f6; color: #6b7280; } | |