/* Unified Upload Center Styles (scoped) */
/* Minimal initial styling; builds on existing color palette. */
#upload-center-root { position:fixed; inset:0; z-index:14000; font-family:var(--font-mono, 'VT323', monospace); 
  opacity:0; visibility:hidden; pointer-events:none;
  transition: opacity 380ms cubic-bezier(0.16, 1, 0.3, 1), visibility 0s linear 380ms;
}
#upload-center-root.is-open { opacity:1; visibility:visible; pointer-events:auto; transition: opacity 380ms cubic-bezier(0.16, 1, 0.3, 1), visibility 0s linear 0s; }
#upload-center-backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.72); backdrop-filter:blur(2px); opacity:0; transition:opacity 380ms cubic-bezier(0.16, 1, 0.3, 1); }
#upload-center-root.is-open #upload-center-backdrop { opacity:1; }
#upload-center-shell { position:absolute; left:50%; top:12vh; transform:translateX(-50%) translateY(-8px) scale(0.985); width: min(960px,92vw); max-height: calc(100vh - 24vh); background:#101018; border:1px solid #00ff88; border-radius:18px; padding:18px 20px 16px; box-shadow:0 0 22px -4px rgba(0,255,136,0.45),0 0 3px 1px rgba(0,255,136,0.35) inset; display:flex; flex-direction:column; 
  opacity:0; transition: opacity 380ms cubic-bezier(0.16, 1, 0.3, 1) 120ms, transform 380ms cubic-bezier(0.16, 1, 0.3, 1) 120ms;
}
#upload-center-root.is-open #upload-center-shell { opacity:1; transform:translateX(-50%) translateY(0) scale(1); }
@media (max-width: 700px){
  #upload-center-shell { top: 8vh; max-height: calc(100vh - 16vh); }
}
#upload-center-shell h2 { margin:0; font-size:1.6rem; letter-spacing:1px; color:#d6d6d6; }
.uc-header { display:flex; align-items:center; justify-content:space-between; gap:12px; padding-bottom:8px; border-bottom:1px solid rgba(255,255,255,0.12); }
.uc-close-btn { background:none; border:1px solid #00ff88; color:#d6d6d6; padding:6px 10px; border-radius:10px; cursor:pointer; font-weight:600; }
.uc-close-btn:hover { background:#00ff8815; }
.uc-overall-bar { height:4px; border-radius:3px; background:rgba(255,255,255,0.12); overflow:hidden; margin-top:10px; }
.uc-overall-bar span { display:block; height:100%; width:0%; background:linear-gradient(90deg,#00ff88,#35ffc9); transition:width .4s ease; }
.uc-main { flex:1; min-height:0; display:grid; grid-template-columns:1fr; gap:14px; margin-top:14px; }
.uc-panels { display:grid; gap:14px; grid-template-columns:1fr 1fr; }
@media (max-width:860px){ .uc-panels { grid-template-columns:1fr; } }
.uc-section { background:#0b0b11; border:1px solid rgba(0,255,136,0.35); border-radius:14px; padding:14px 14px 12px; display:flex; flex-direction:column; min-height:0; }
.uc-section h3 { margin:0 0 6px; font-size:0.9rem; letter-spacing:1px; font-weight:600; color:#8ff6ff; }
.uc-dropzone { border:2px dashed #00ff88; border-radius:14px; padding:22px 12px; text-align:center; color:#b8b8b8; cursor:pointer; font-size:0.95rem; line-height:1.35; background:#0b0b14; transition:border-color .25s, background .25s; }
.uc-dropzone.is-drag { background:#112a21; border-color:#35ffc9; }
/* Global drag overlay */
.uc-global-drop { position:fixed; inset:0; background:rgba(6,18,14,0.78); backdrop-filter:blur(3px); display:flex; align-items:center; justify-content:center; border:2px dashed #00ff88; border-radius:10px; pointer-events:none; opacity:0; transition:opacity .25s; z-index:2147483000; }
.uc-global-drop.is-visible { opacity:1; }
.uc-global-drop-inner { font-size:1.1rem; font-weight:600; letter-spacing:3px; text-align:center; padding:32px 40px; max-width:600px; line-height:1.3; background:linear-gradient(90deg,#8ff6ff,#35ffc9); -webkit-background-clip:text; background-clip:text; color:transparent; text-shadow:0 0 6px rgba(53,255,201,0.35); }

/* Staging flash */
@keyframes ucFlash { 0%{ box-shadow:0 0 0 0 rgba(0,255,136,.9); } 100%{ box-shadow:0 0 0 28px rgba(0,255,136,0);} }
#uc-staging-panel.uc-staging-flash { animation: ucFlash .9s ease-out; }
.uc-pref { display:flex; align-items:center; gap:6px; font-size:0.65rem; letter-spacing:1px; margin-top:10px; color:#aaa; }
.uc-pref label { display:inline-flex; align-items:center; gap:8px; cursor:pointer; user-select:none; }
#upload-center-root .uc-pref input[type="checkbox"] { appearance:none; -webkit-appearance:none; width:16px; height:16px; border:2px solid #00ff88; border-radius:4px; background:#0b0b14; position:relative; display:inline-block; cursor:pointer; box-shadow:0 0 0 0 rgba(0,255,136,0.4); transition:background .25s, box-shadow .25s, transform .15s; }
#upload-center-root .uc-pref input[type="checkbox"]:hover { box-shadow:0 0 6px 1px rgba(0,255,136,0.45); }
#upload-center-root .uc-pref input[type="checkbox"]:active { transform:scale(.9); }
#upload-center-root .uc-pref input[type="checkbox"]:focus-visible { outline:none; box-shadow:0 0 0 3px rgba(0,255,136,0.35); }
#upload-center-root .uc-pref input[type="checkbox"]:checked { background:linear-gradient(135deg,#00ff88,#35ffc9); border-color:#35ffc9; }
#upload-center-root .uc-pref input[type="checkbox"]:checked::after { content:""; position:absolute; inset:0; background:center/70% 70% no-repeat url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'><path d='M1 5 L4.5 8.5 L11 1.5' stroke='%2301120d' stroke-width='2.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>"); filter: drop-shadow(0 0 2px rgba(0,0,0,0.4)) drop-shadow(0 0 3px rgba(53,255,201,.55)); }
#upload-center-root .uc-pref input[type="checkbox"]:not(:checked)::after { content:""; position:absolute; inset:0; background:repeating-conic-gradient(from 0deg,#0f1814 0deg,#0f1814 5deg,#112d22 5deg,#112d22 10deg); opacity:.15; border-radius:2px; }
#upload-center-root .uc-pref input[type="checkbox"]:disabled { opacity:.35; cursor:not-allowed; }
.uc-pref label:hover input[type="checkbox"]:not(:disabled) { box-shadow:0 0 8px -1px rgba(0,255,136,0.6); }
.uc-pref label span.uc-pref-text { background:linear-gradient(90deg,#8ff6ff,#35ffc9); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:1px; font-weight:600; }
.uc-list { flex:1; overflow:auto; display:flex; flex-direction:column; gap:10px; padding-right:4px; }
.uc-file-card, .uc-job-card { background:#14141d; border:1px solid rgba(0,255,136,0.3); border-radius:12px; padding:10px 12px 10px; display:flex; gap:10px; position:relative; }
.uc-file-meta { flex:1; min-width:0; }
.uc-file-name { font-size:0.85rem; font-weight:600; color:#dcdcdc; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.uc-file-size { font-size:0.65rem; opacity:.65; margin-top:2px; }
.uc-mini-actions { display:flex; align-items:center; gap:6px; }
.uc-btn-sm { background:none; border:1px solid #00ff88; color:#d6d6d6; padding:4px 8px; font-size:0.65rem; letter-spacing:0.5px; border-radius:8px; cursor:pointer; }
.uc-btn-sm:hover { background:#00ff8815; }
.uc-submit-row { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-top:12px; }
.uc-primary { background:#FFD400; color:#000; border:none; font-weight:700; padding:8px 18px; border-radius:10px; font-size:0.8rem; letter-spacing:0.5px; cursor:pointer; }
.uc-primary:disabled { opacity:.35; cursor:not-allowed; }
.uc-secondary { background:none; border:1px solid #00ff88; color:#d6d6d6; padding:8px 14px; border-radius:10px; font-size:0.75rem; cursor:pointer; }
.uc-secondary:hover { background:#00ff8818; }
.uc-progress-outer { height:6px; background:rgba(255,255,255,0.12); border-radius:5px; margin-top:6px; overflow:hidden; }
.uc-progress-inner { height:100%; width:0%; background:#35ffc9; transition:width .35s ease; }
.uc-status-row { margin-top:4px; display:flex; flex-wrap:wrap; align-items:center; gap:6px; font-size:0.55rem; letter-spacing:0.5px; }
.uc-pill { padding:2px 6px; border-radius:999px; background:#2a2a36; text-transform:uppercase; font-weight:600; font-size:0.55rem; letter-spacing:0.5px; display:inline-flex; align-items:center; gap:4px; }
.uc-pill.q { background:#2e2a10; color:#ffc400; }
.uc-pill.p { background:#1a3023; color:#35ffc9; }
.uc-pill.d { background:#183020; color:#6dff9e; }
.uc-pill.f { background:#301818; color:#ff6060; }
.uc-queue-label { font-size:0.55rem; opacity:.7; }
.uc-empty { font-size:0.7rem; opacity:.55; padding:10px 4px 6px; }
.uc-recent-label { font-size:0.6rem; opacity:.5; margin-top:2px; }
.uc-divider { height:1px; background:rgba(255,255,255,0.08); margin:6px 0; }
.uc-dock { position:fixed; left:50%; bottom:10px; transform:translateX(-50%); background:#101018; border:1px solid #00ff88; padding:6px 14px 8px; border-radius:40px; box-shadow:0 0 14px -3px rgba(0,255,136,0.45); display:none; align-items:center; gap:10px; cursor:pointer; z-index:13950; }
.uc-dock.is-visible { display:flex; }
.uc-dock-bar { width:120px; height:5px; background:rgba(255,255,255,0.15); border-radius:4px; overflow:hidden; position:relative; }
.uc-dock-bar span { display:block; height:100%; background:linear-gradient(90deg,#00ff88,#35ffc9); width:0%; transition:width .4s ease; }
.uc-dock-count { font-size:0.6rem; letter-spacing:0.5px; color:#c9c9c9; }
.uc-inline-warn { font-size:0.55rem; color:#ff8e52; margin-top:4px; }
.uc-log-btn { font-size:0.55rem; padding:2px 6px; background:none; border:1px solid rgba(0,255,136,0.4); border-radius:6px; cursor:pointer; color:#9fd; }
.uc-log-panel { display:none; position:absolute; right:6px; top:6px; background:#09090d; border:1px solid #00ff88; padding:8px 8px 10px; border-radius:10px; width:260px; max-height:220px; overflow:auto; font-size:0.55rem; line-height:1.25; box-shadow:0 0 12px -2px rgba(0,255,136,0.35); }
.uc-job-card.show-logs .uc-log-panel { display:block; }
.uc-job-card { cursor:default; }
.uc-job-actions { display:flex; flex-direction:column; gap:6px; }
.uc-job-actions button { background:none; border:1px solid rgba(0,255,136,0.35); color:#d6d6d6; border-radius:7px; padding:4px 6px; font-size:0.55rem; cursor:pointer; }
.uc-job-actions button:hover { background:#00ff8815; }
.uc-sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
.uc-badge-new { position:absolute; top:-6px; left:-6px; background:#FFD400; color:#000; font-size:0.55rem; padding:2px 6px; border-radius:40px; font-weight:700; box-shadow:0 0 8px -1px rgba(255,212,0,0.65); }
.uc-queue-pos { font-size:0.55rem; color:#ffc400; }
/* Reduced motion adjustments */
@media (prefers-reduced-motion:reduce){ .uc-progress-inner, .uc-overall-bar span, .uc-dock-bar span { transition:none; }
  #upload-center-root, #upload-center-backdrop, #upload-center-shell { transition:none; }
}

/* Log expansion */
.uc-log-toggle { margin-top:6px; font-size:0.55rem; letter-spacing:0.5px; display:inline-flex; gap:4px; align-items:center; background:#1a1a24; padding:3px 8px; border-radius:7px; cursor:pointer; border:1px solid rgba(0,255,136,0.25); user-select:none; }
.uc-log-toggle:hover { background:#22332c; }
.uc-log-wrap { max-height:0; overflow:hidden; transition:max-height .35s ease; background:#0c0c11; border:1px solid rgba(0,255,136,0.25); margin-top:6px; border-radius:8px; }
.uc-job-card.logs-open .uc-log-wrap { /* height expanded inline */ border-color: rgba(0,255,136,0.4); }
.uc-log-lines { padding:6px 8px 8px; font-size:0.55rem; line-height:1.25; color:#b9e8d6; max-height:180px; overflow:auto; }

/* Scrollbar theming */
.uc-list::-webkit-scrollbar, .uc-log-lines::-webkit-scrollbar { width:10px; height:10px; }
.uc-list::-webkit-scrollbar-track, .uc-log-lines::-webkit-scrollbar-track { background:#0b0b11; }
.uc-list::-webkit-scrollbar-thumb, .uc-log-lines::-webkit-scrollbar-thumb { background:linear-gradient(#00ff88,#35ffc9); border-radius:12px; box-shadow:0 0 0 2px #0b0b11 inset; }
.uc-list::-webkit-scrollbar-thumb:hover, .uc-log-lines::-webkit-scrollbar-thumb:hover { filter:brightness(1.15); }

/* Firefox */
.uc-list, .uc-log-lines { scrollbar-width:thin; scrollbar-color:#00ff88 #0b0b11; }
