.upload-window { width: 520px; height: 486px; } .upload-form { display: flex; flex: 1; flex-direction: column; min-height: 0; } .upload-panel { display: flex; flex: 1; flex-direction: column; min-height: 0; margin: 0 8px 8px; padding: 12px; } .upload-dropzone { flex: 0 0 auto; height: 118px; box-sizing: border-box; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 14px; text-align: center; background: #dfdfdf; border: 1px dotted #000000; } .upload-dropzone.is-dragging { background: #c7d8f2; outline: 2px solid #000078; outline-offset: -4px; } .upload-dropzone:focus-visible { outline: 1px dotted #000000; outline-offset: -5px; } .upload-icon { width: 34px; height: 30px; position: relative; box-sizing: border-box; background: #ffffff; border: 2px solid #000000; box-shadow: inset -3px -3px 0 #dfdfdf; } .upload-icon::before { content: ""; position: absolute; right: -2px; top: -2px; width: 10px; height: 10px; box-sizing: border-box; background: #dfdfdf; border-left: 2px solid #000000; border-bottom: 2px solid #000000; } .upload-primary { font-size: 18px; line-height: 18px; font-weight: bold; } .upload-secondary { font-size: 13px; line-height: 15px; } .upload-input { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0); } .upload-details { flex: 0 0 auto; display: flex; align-items: center; height: 28px; margin-top: 12px; padding: 0 8px; box-sizing: border-box; background: #ffffff; border-top: 1px solid #808080; border-left: 1px solid #808080; border-right: 1px solid #dfdfdf; border-bottom: 1px solid #dfdfdf; font-size: 13px; line-height: 13px; } .upload-detail-label { flex: 0 0 auto; margin-right: 6px; font-weight: bold; } .upload-file-count { margin-left: auto; } .upload-file-list { flex: 1 1 auto; min-height: 0; margin-top: 8px; overflow-y: auto; background: #ffffff; border-top: 2px solid #808080; border-left: 2px solid #808080; border-right: 2px solid #ffffff; border-bottom: 2px solid #ffffff; } .upload-result { flex: 0 0 auto; display: grid; grid-template-columns: 72px minmax(0, 1fr) 72px; align-items: center; gap: 6px; height: 36px; box-sizing: border-box; margin-top: 8px; padding: 4px 6px; background: #dfdfdf; border-top: 1px solid #808080; border-left: 1px solid #808080; border-right: 1px solid #ffffff; border-bottom: 1px solid #ffffff; font-size: 12px; line-height: 12px; } .upload-result.is-hidden { visibility: hidden; } .upload-result-label { font-weight: bold; } .upload-result-link { min-width: 0; overflow: hidden; color: #000078; text-overflow: ellipsis; white-space: nowrap; } .upload-result-link.is-empty { color: #555555; pointer-events: none; text-decoration: none; } .upload-share-button { width: 72px; height: 24px; font-size: 12px; line-height: 12px; } .upload-share-button:disabled { color: #808080; text-shadow: 1px 1px 0 #ffffff; } .upload-empty-state { margin: 0; padding: 9px 8px; color: #555555; font-size: 13px; line-height: 13px; } .upload-file-row { display: grid; grid-template-columns: 22px minmax(0, 1fr) 82px; grid-template-rows: 20px 8px; align-items: center; height: 36px; box-sizing: border-box; padding: 4px 8px; border-bottom: 1px solid #dfdfdf; font-size: 13px; line-height: 13px; } .upload-file-row:nth-child(even) { background: #f7f7f7; } .upload-file-icon { grid-row: 1 / 3; width: 16px; height: 18px; position: relative; box-sizing: border-box; background: #ffffff; border: 1px solid #000000; box-shadow: inset -2px -2px 0 #dfdfdf; } .upload-file-icon::before { content: ""; position: absolute; top: -1px; right: -1px; width: 5px; height: 5px; background: #dfdfdf; border-left: 1px solid #000000; border-bottom: 1px solid #000000; } .upload-file-name, .upload-file-size { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .upload-file-size { text-align: right; } .upload-progress { grid-column: 2 / 4; grid-row: 2; display: block; height: 8px; box-sizing: border-box; overflow: hidden; background: #ffffff; border-top: 1px solid #808080; border-left: 1px solid #808080; border-right: 1px solid #dfdfdf; border-bottom: 1px solid #dfdfdf; } .upload-progress-bar { display: block; width: 0%; height: 100%; background: #000078; } .upload-file-row.is-uploaded .upload-progress-bar { background: #008000; } .upload-file-row.is-failed .upload-progress-bar { width: 100%; background: #800000; } .upload-actions { display: flex; justify-content: flex-end; gap: 8px; height: 40px; box-sizing: border-box; padding: 0 8px 8px; } .upload-overall { display: grid; grid-template-columns: minmax(0, 1fr) 42px; align-items: center; gap: 6px; height: 28px; box-sizing: border-box; padding: 0 8px 8px; font-size: 12px; line-height: 12px; } .upload-overall-track { height: 18px; box-sizing: border-box; overflow: hidden; background: #ffffff; border-top: 2px solid #808080; border-left: 2px solid #808080; border-right: 2px solid #ffffff; border-bottom: 2px solid #ffffff; } .upload-overall-bar { display: block; width: 0%; height: 100%; background-color: #000078; background-image: repeating-linear-gradient( to right, #000078 0, #000078 10px, #c0c0c0 10px, #c0c0c0 12px ); } .upload-overall-percent { min-width: 0; text-align: right; } .upload-statusbar { grid-template-columns: 1fr 96px; } @media (max-width: 600px) { main { display: block; min-height: 100dvh; } .upload-window { width: 100vw; height: 100dvh; border: 0; box-shadow: none; } .upload-titlebar { height: 24px; margin: 0; } .upload-menu { height: 26px; } .upload-panel { margin: 0 6px 8px; padding: 14px; } .upload-dropzone { height: 126px; min-height: 126px; } .upload-file-list { min-height: 160px; } .upload-result { grid-template-columns: 64px minmax(0, 1fr) 68px; } }