.progress-panel { display: grid; grid-template-rows: auto minmax(0, 1fr); min-height: 0; } .progress-panel :where(button) { border: 0; background: transparent; cursor: pointer; font: inherit; } .progress-panel :where(button:disabled) { cursor: not-allowed; opacity: 0.7; } .section-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; min-height: 24px; margin-bottom: 5px; } .section-head h2 { margin: 0; color: var(--workbench-ink); font-size: 16px; line-height: 1.25; font-weight: 850; } .progress-section-head { align-items: center; } .progress-range-select { width: 124px; flex: 0 0 124px; } .progress-range-control { position: relative; z-index: 6; flex: 0 0 124px; } .progress-range-select:deep(.el-select__wrapper) { min-height: 32px; border-radius: 4px; box-shadow: 0 0 0 1px var(--workbench-line) inset; background: rgba(255, 255, 255, 0.86); } .progress-range-select:deep(.el-select__wrapper.is-focused), .progress-range-select:deep(.el-select__wrapper:hover) { box-shadow: 0 0 0 1px rgba(var(--theme-primary-rgb, 58, 124, 165), 0.38) inset; } .progress-table-shell { position: relative; display: grid; --progress-table-columns: minmax(92px, 0.4fr) minmax(76px, 0.3fr) minmax(138px, 0.72fr) minmax(84px, 0.42fr) minmax(238px, 1.16fr) minmax(96px, 0.44fr); grid-template-rows: 36px minmax(0, 1fr); min-height: 0; overflow: hidden; } .progress-table-header { position: relative; z-index: 3; display: grid; grid-template-columns: var(--progress-table-columns); gap: 8px; align-items: center; height: 36px; min-height: 36px; max-height: 36px; padding: 0 4px 0 0; overflow: hidden; border-radius: 4px; background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.94)), rgba(var(--theme-primary-rgb, 58, 124, 165), 0.04); border: 1px solid rgba(var(--theme-primary-rgb, 58, 124, 165), 0.08); box-shadow: 0 1px 0 rgba(var(--theme-primary-rgb, 58, 124, 165), 0.08); box-sizing: border-box; } .header-cell { display: flex; align-items: center; justify-content: center; min-width: 0; height: 100%; overflow: hidden; color: var(--workbench-muted); font-size: 12px; font-weight: 850; line-height: 1; text-overflow: ellipsis; white-space: nowrap; } .header-time { padding-left: 0; } .header-applicant, .header-type { text-align: center; } .header-steps { justify-content: center; } .header-result { text-align: center; padding-right: 0; } .progress-list { position: relative; z-index: 1; display: grid; min-height: 0; height: 100%; align-content: start; grid-auto-rows: minmax(76px, auto); overflow-x: hidden; overflow-y: auto; padding: 4px 4px 0 0; scrollbar-width: thin; scrollbar-color: rgba(var(--theme-primary-rgb, 58, 124, 165), 0.28) transparent; } .progress-list::-webkit-scrollbar { width: 6px; } .progress-list::-webkit-scrollbar-thumb { border-radius: 999px; background: rgba(var(--theme-primary-rgb, 58, 124, 165), 0.24); } .progress-empty-state { min-height: 220px; height: 100%; display: grid; place-items: center; align-content: center; gap: 8px; padding: 28px 18px; border: 1px dashed rgba(var(--theme-primary-rgb, 58, 124, 165), 0.22); border-radius: 4px; background: linear-gradient(180deg, rgba(255, 255, 255, 0.68), rgba(255, 255, 255, 0.42)), rgba(var(--theme-primary-rgb, 58, 124, 165), 0.025); color: var(--workbench-muted); text-align: center; } .progress-empty-icon { width: 42px; height: 42px; display: grid; place-items: center; border: 1px solid rgba(var(--theme-primary-rgb, 58, 124, 165), 0.18); border-radius: 4px; background: var(--workbench-primary-soft); color: var(--workbench-primary-active); font-size: 22px; } .progress-empty-state strong { color: var(--workbench-ink); font-size: 14px; font-weight: 850; } .progress-empty-state p { max-width: 260px; margin: 0; color: var(--workbench-muted); font-size: 12px; line-height: 1.55; } .progress-row { position: relative; display: grid; grid-template-columns: var(--progress-table-columns); align-items: center; gap: 8px; width: 100%; min-height: 76px; padding: 10px 0; border-top: 0; background: transparent; box-shadow: inset 0 1px 0 rgba(var(--theme-primary-rgb, 58, 124, 165), 0.1); color: inherit; text-align: center; animation: workbenchItemIn 480ms var(--ease, cubic-bezier(0.2, 0.8, 0.2, 1)) both; animation-delay: calc(300ms + var(--item-index, 0) * 80ms); } .progress-row:first-child { padding-top: 2px; border-top: 0; box-shadow: none; } .progress-row:hover { border-color: rgba(var(--theme-primary-rgb, 58, 124, 165), 0.24); background: linear-gradient(180deg, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0.18)), rgba(var(--theme-primary-rgb, 58, 124, 165), 0.035); box-shadow: inset 0 1px 0 rgba(var(--theme-primary-rgb, 58, 124, 165), 0.14); color: var(--workbench-primary-active); } .progress-time-wrapper { display: flex; align-items: center; justify-content: center; gap: 14px; min-width: 0; } .expense-type-icon { position: relative; flex-shrink: 0; width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; border-radius: 12px; font-size: 22px; box-shadow: 0 4px 10px rgba(0, 0, 0, 0.04), inset 0 1px 0 rgba(255, 255, 255, 0.9), inset 0 -1px 0 rgba(0, 0, 0, 0.03); } .expense-type-icon::before { content: ""; position: absolute; inset: 0; z-index: 0; border-radius: inherit; background: linear-gradient(135deg, rgba(255, 255, 255, 0.5) 0%, rgba(255, 255, 255, 0) 100%); } .expense-type-icon i { position: relative; z-index: 1; filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.12)); } .expense-type-icon--blue { border: 1px solid color-mix(in srgb, var(--workbench-primary, #3a7ca5) 20%, #ffffff); background: linear-gradient(135deg, color-mix(in srgb, var(--workbench-primary, #3a7ca5) 12%, #ffffff) 0%, color-mix(in srgb, var(--workbench-primary, #3a7ca5) 3%, #ffffff) 100%); color: var(--workbench-primary, #3a7ca5); } .expense-type-icon--amber { border: 1px solid color-mix(in srgb, var(--workbench-chart-amber, #b58b4c) 20%, #ffffff); background: linear-gradient(135deg, color-mix(in srgb, var(--workbench-chart-amber, #b58b4c) 12%, #ffffff) 0%, color-mix(in srgb, var(--workbench-chart-amber, #b58b4c) 3%, #ffffff) 100%); color: var(--workbench-chart-amber, #b58b4c); } .expense-type-icon--emerald { border: 1px solid color-mix(in srgb, #0f8f68 20%, #ffffff); background: linear-gradient(135deg, color-mix(in srgb, #0f8f68 12%, #ffffff) 0%, color-mix(in srgb, #0f8f68 3%, #ffffff) 100%); color: #0f8f68; } .expense-type-icon--violet { border: 1px solid color-mix(in srgb, #6d5bd0 20%, #ffffff); background: linear-gradient(135deg, color-mix(in srgb, #6d5bd0 12%, #ffffff) 0%, color-mix(in srgb, #6d5bd0 3%, #ffffff) 100%); color: #6d5bd0; } .expense-type-icon--cyan { border: 1px solid color-mix(in srgb, #0788a2 20%, #ffffff); background: linear-gradient(135deg, color-mix(in srgb, #0788a2 12%, #ffffff) 0%, color-mix(in srgb, #0788a2 3%, #ffffff) 100%); color: #0788a2; } .expense-type-icon--muted { border: 1px solid var(--workbench-line); background: linear-gradient(135deg, var(--info-soft, #f1f5f9) 0%, #ffffff 100%); color: var(--workbench-muted, #64748b); } .progress-time, .progress-applicant, .progress-identity, .progress-type, .progress-result { min-width: 0; display: grid; gap: 2px; } .progress-time { justify-items: center; color: var(--workbench-muted); } .progress-applicant { justify-items: center; text-align: center; } .progress-applicant strong { max-width: 100%; overflow: hidden; color: var(--workbench-ink); font-size: 12.5px; font-weight: 850; line-height: 1.25; text-overflow: ellipsis; white-space: nowrap; } .progress-time time { min-width: 0; overflow: hidden; color: var(--workbench-ink); font-size: 12px; font-weight: 850; line-height: 1.2; text-overflow: ellipsis; white-space: nowrap; } .progress-identity { display: flex; flex-direction: column; align-items: center; gap: 2px; text-align: center; } .progress-identity strong { margin-bottom: 2px; } .progress-identity strong, .progress-result strong { max-width: 100%; overflow: hidden; color: var(--workbench-ink); font-size: 13px; font-weight: bold; line-height: 1.25; text-overflow: ellipsis; white-space: nowrap; } .progress-identity small { max-width: 100%; overflow: hidden; color: var(--workbench-muted); font-size: 11.5px; line-height: 1.25; text-overflow: ellipsis; white-space: nowrap; } .progress-type { justify-self: stretch; justify-items: center; text-align: center; } .progress-type strong { max-width: 100%; min-height: 22px; overflow: hidden; display: inline-flex; align-items: center; justify-content: center; padding: 0 8px; border: 1px solid rgba(var(--theme-primary-rgb, 58, 124, 165), 0.18); border-radius: 4px; background: rgba(var(--theme-primary-rgb, 58, 124, 165), 0.08); color: var(--workbench-primary-active); font-size: 11.5px; font-weight: 850; line-height: 1.2; text-overflow: ellipsis; white-space: nowrap; } .progress-result { justify-self: stretch; align-items: center; justify-content: center; justify-items: center; padding-right: 0; text-align: center; } .progress-result strong { width: 100%; text-align: center; } .progress-steps { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); align-items: start; justify-items: stretch; } .progress-step { position: relative; display: grid; justify-items: center; gap: 1px; color: color-mix(in srgb, var(--workbench-muted) 64%, #ffffff); } .progress-step::before { content: ""; position: absolute; top: 8px; left: calc(-50% + 12px); right: calc(50% + 12px); height: 2px; background: var(--workbench-line); } .progress-step:first-child::before { display: none; } .progress-step.is-done::before, .progress-step.is-current::before { background: var(--workbench-primary); } .progress-step i { position: relative; z-index: 1; width: 16px; height: 16px; display: grid; place-items: center; border: 2px solid var(--workbench-line); border-radius: 999px; background: var(--workbench-surface); color: var(--workbench-line-strong, #cbd5e1); font-size: 12px; line-height: 1; } .progress-step.is-done i { border-color: var(--workbench-primary); background: var(--workbench-primary-soft); color: var(--workbench-primary-active); } .progress-step.is-current i { border-color: var(--workbench-primary-active); background: var(--theme-primary-light-9); color: var(--workbench-primary-active); } .progress-step small { color: currentColor; font-size: 10px; font-weight: 750; line-height: 1.2; white-space: nowrap; } .progress-step.is-done, .progress-step.is-current { color: var(--workbench-ink); } @media (max-width: 760px) { .progress-table-shell { grid-template-rows: minmax(0, 1fr); } .progress-table-header { display: none; } .progress-row { grid-template-columns: minmax(70px, auto) minmax(62px, auto) 1fr minmax(74px, auto); grid-template-areas: "time applicant identity result" "type type type type" "steps steps steps steps"; justify-items: center; } .progress-section-head { align-items: center; } .progress-range-select { width: 120px; flex-basis: 120px; } .progress-range-control { flex-basis: 120px; } .progress-empty-state { min-height: 180px; } .progress-time-wrapper { grid-area: time; } .progress-applicant { grid-area: applicant; } .progress-identity { grid-area: identity; } .progress-type { grid-area: type; width: 100%; } .progress-result { grid-area: result; width: 100%; justify-items: center; gap: 2px; } .progress-steps { grid-area: steps; width: 100%; margin-top: 4px; } .progress-step i { width: 14px; height: 14px; font-size: 10px; } .progress-step small { font-size: 9px; } .progress-step::before { top: 7px; } } @media (prefers-reduced-motion: reduce) { .progress-row { animation: none !important; } }