/* Upload Summary Styles */ .upload-summary { margin: 1.5rem 0; padding: 1.5rem; border-radius: 6px; background-color: var(--content-bg); box-shadow: var(--dashboard-shadow); color: var(--content-text); } .upload-summary h3 { margin-top: 0; font-size: 1.25rem; color: var(--dashboard-header-color); margin-bottom: 1rem; } .upload-stats { display: flex; gap: 1.5rem; margin-bottom: 1rem; } .stat-box { flex: 1; padding: 1rem; border-radius: 4px; background-color: var(--input-bg); box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); text-align: center; } .stat-value { font-size: 2rem; font-weight: 600; margin-bottom: 0.25rem; color: var(--content-text); } .stat-label { font-size: 0.875rem; color: var(--label-color); } .success-stat .stat-value { color: var(--btn-success-bg); } .error-stat .stat-value { color: var(--btn-warning-bg); } /* Job Results Styles */ .job-results { margin-top: 1.5rem; } .job-result { padding: 1rem; margin-bottom: 0.5rem; border-radius: 4px; border: var(--input-border); border-left-width: 4px; background-color: var(--content-bg); box-shadow: var(--dashboard-shadow); color: var(--content-text); } .job-result.success { border-left-color: var(--btn-success-bg); } .job-result.error { border-left-color: var(--btn-warning-bg); } .job-id { font-weight: 600; display: block; margin-bottom: 0.5rem; color: var(--dashboard-header-color); } .file-results { margin-left: 1rem; margin-top: 0.5rem; } .file-result { padding: 0.75rem; margin-bottom: 0.5rem; border-radius: 4px; display: flex; align-items: center; background-color: var(--input-bg); border: var(--input-border); } .file-result.success { background-color: rgba(var(--btn-success-rgb, 52, 211, 153), 0.1); border-color: rgba(var(--btn-success-rgb, 52, 211, 153), 0.3); } .file-result.error { background-color: rgba(var(--btn-warning-rgb, 248, 113, 113), 0.1); border-color: rgba(var(--btn-warning-rgb, 248, 113, 113), 0.3); } .status-icon { font-size: 1.25rem; margin-right: 0.75rem; } .success .status-icon { color: var(--btn-success-bg); } .error .status-icon { color: var(--btn-warning-bg); } .file-name { font-weight: 500; margin-right: 0.5rem; color: var(--content-text); } .file-message { color: var(--label-color); font-size: 0.875rem; } /* Upload Progress Styles */ .upload-progress { background-color: var(--content-bg); border-radius: 6px; padding: 1.5rem; margin: 1.5rem 0; box-shadow: var(--dashboard-shadow); } .progress-info { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.75rem; } .progress-info span { font-weight: 500; color: var(--content-text); } /* Original Spinner - used for general loading indicators */ .spinner { border: 3px solid rgba(0, 0, 0, 0.1); border-radius: 50%; border-top: 3px solid var(--btn-primary-bg); width: 20px; height: 20px; animation: spin 1s linear infinite; } /* Larger spinner specifically for overlays */ .overlay-spinner { width: 50px; height: 50px; margin: 0 auto; border: 3px solid rgba(255, 255, 255, 0.3); border-radius: 50%; border-top-color: white; animation: spin 1s ease-in-out infinite; } @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } .progress { height: 0.5rem; background-color: var(--progress-bg, #e2e8f0); border-radius: 999px; overflow: hidden; } .progress-bar { height: 100%; width: 100%; background-color: var(--progress-fill, #4299e1); background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent); background-size: 1rem 1rem; border-radius: 999px; animation: progress-animation 1s linear infinite; } @keyframes progress-animation { 0% { background-position: 1rem 0; } 100% { background-position: 0 0; } } #upload-status { margin-top: 0.75rem; font-size: 0.875rem; color: var(--label-color); } .pulsing { animation: pulse 2s infinite; } @keyframes pulse { 0% { opacity: 0.6; } 50% { opacity: 1; } 100% { opacity: 0.6; } } .advice { font-weight: 500; color: var(--btn-primary-bg); } /* CSV Preview styles */ #csv-preview, #csv-preview-removal { margin-top: 1rem; padding: 1rem; background-color: var(--content-bg); border-radius: 6px; border-left: 4px solid var(--btn-primary-bg); } .csv-sample { margin-top: 0.5rem; padding: 0.75rem; background-color: var(--input-bg); border-radius: 4px; box-shadow: var(--dashboard-shadow); } #csv-preview p, #csv-preview-removal p { margin: 0.5rem 0; color: var(--content-text); } /* HTMX indicator styles */ .htmx-indicator { display: none; opacity: 0; transition: opacity 200ms ease-in; } .htmx-request .htmx-indicator { opacity: 1; display: flex; align-items: center; justify-content: center; } .loading-indicator { display: inline-block; width: 1rem; height: 1rem; border: 2px solid rgba(0, 0, 0, 0.1); border-radius: 50%; border-top-color: var(--btn-primary-bg); animation: spin 1s linear infinite; margin-left: 0.5rem; vertical-align: middle; } :root.dark-theme .spinner, :root.dark-theme .loading-indicator { border-color: rgba(255, 255, 255, 0.1); border-top-color: var(--btn-primary-bg); } /* Tab buttons */ .tab-buttons { display: flex; margin-bottom: 1rem; border-bottom: 1px solid var(--dropdown-border); } .tab-button { padding: 0.5rem 1rem; background: var(--card-bg); border: 1px solid var(--dropdown-border); border-bottom: none; border-radius: 4px 4px 0 0; color: var(--content-text); cursor: pointer; margin-right: 0.5rem; position: relative; bottom: -1px; } .tab-button.active { background: var(--content-bg); border-bottom: 1px solid var(--content-bg); font-weight: bold; } /* Checkbox styles */ .checkbox-group { display: flex; flex-wrap: wrap; gap: 0.5rem 1.5rem; margin: 0.5rem 0 1rem 0; } .checkbox-item { display: flex; align-items: center; } .checkbox-item input[type="checkbox"] { margin-right: 0.5rem; } /* Form groups */ .form-group { margin-bottom: 1rem; } .form-group label { display: block; margin-bottom: 0.5rem; color: var(--label-color); font-weight: bold; } .form-actions { margin-top: 1.5rem; display: flex; align-items: center; gap: 1rem; } /* Job summary in results */ .job-summary { margin: 0.5rem 0; font-size: 0.9rem; color: var(--soft-text); } /* Upload Overlay */ .upload-container { position: relative; min-height: 200px; width: 100%; } .upload-overlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(240, 240, 240, 0.95)); display: none; justify-content: center; align-items: center; z-index: 1000; border-radius: inherit; } .upload-overlay.htmx-request { display: flex; } .upload-overlay-content { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; max-width: 80%; } .upload-overlay h3 { margin-bottom: 0.5rem; color: #333; } .upload-overlay p { margin-top: 0.5rem; color: #555; } .upload-overlay .overlay-spinner { width: 50px; height: 50px; border: 5px solid #f3f3f3; border-top: 5px solid #3498db; border-radius: 50%; animation: spin 1s linear infinite; margin-bottom: 1rem; } /* Dark theme support */ @media (prefers-color-scheme: dark) { .upload-overlay { background: linear-gradient(135deg, rgba(30, 30, 30, 0.95), rgba(20, 20, 20, 0.95)); } .upload-overlay h3 { color: #fff; } .upload-overlay p { color: #ccc; } } @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }