:root{--bg-primary: #0a0a0f;--bg-secondary: #14141f;--bg-card: #1a1a2e;--accent: #4f46e5;--accent-hover: #6366f1;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--text-primary: #f0f0f0;--text-secondary: #9ca3af;--border: #2a2a3e}[data-theme=light]{--bg-primary: #f5f5f7;--bg-secondary: #f0f0f3;--bg-card: #ffffff;--accent: #4f46e5;--accent-hover: #4338ca;--success: #059669;--warning: #d97706;--error: #dc2626;--text-primary: #1f2937;--text-secondary: #6b7280;--border: #d1d5db}*{box-sizing:border-box}body{background:var(--bg-primary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6}.app{max-width:800px;margin:0 auto;padding:2rem;min-height:100vh}.header{text-align:center;margin-bottom:2rem}.header h1{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent),#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header p{color:var(--text-secondary)}.connection-status{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;border-radius:.5rem;margin-bottom:1.5rem;font-size:.875rem}.connection-status.online{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--success)}.connection-status.offline{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--error)}.connection-status.connecting{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--warning)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.login-container{max-width:400px;margin:2rem auto;padding:2rem;background:var(--bg-card);border-radius:1rem;border:1px solid var(--border)}.login-container h2{text-align:center;margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.875rem}.form-group input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;width:100%}.btn:hover{background:var(--accent-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-card);border-color:var(--accent)}.error-message{color:var(--error);font-size:.875rem;margin-top:.5rem;text-align:center}.toggle-mode{text-align:center;margin-top:1rem;color:var(--text-secondary);font-size:.875rem}.toggle-mode button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit}.upload-zone{border:2px dashed var(--border);border-radius:1rem;padding:3rem 2rem;text-align:center;transition:all .2s;cursor:pointer;background:var(--bg-card)}.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent);background:#4f46e50d}.upload-zone.disabled{opacity:.5;cursor:not-allowed}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-zone h3{margin-bottom:.5rem}.upload-zone p{color:var(--text-secondary);font-size:.875rem}.file-queue{margin-top:2rem}.file-queue h3{margin-bottom:1rem;font-size:1rem;color:var(--text-secondary)}.file-item{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1rem;margin-bottom:.75rem}.file-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.file-name{font-weight:500;word-break:break-all}.file-size{color:var(--text-secondary);font-size:.875rem;white-space:nowrap;margin-left:1rem}.file-status{font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem;text-transform:uppercase;font-weight:500}.file-status.pending{background:#9ca3af33;color:var(--text-secondary)}.file-status.uploading{background:#4f46e533;color:var(--accent)}.file-status.completed{background:#10b98133;color:var(--success)}.file-status.error{background:#ef444433;color:var(--error)}.progress-container{margin-top:.5rem}.progress-bar{height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#818cf8);border-radius:3px;transition:width .3s ease}.progress-stats{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:var(--text-secondary)}.user-info{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--bg-card);border-radius:.5rem;margin-bottom:1.5rem;border:1px solid var(--border)}.user-info>span{color:var(--text-secondary)}.user-info strong{color:var(--text-primary)}.user-info>div{display:flex;flex-wrap:wrap;gap:.5rem}.logout-btn,.admin-btn{padding:.5rem 1rem;font-size:.875rem;width:auto}.admin-page{background:var(--bg-card);border-radius:1rem;padding:1.5rem;border:1px solid var(--border)}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.admin-header h2{margin:0}.admin-actions{display:flex;gap:.5rem}.admin-actions .btn{width:auto;padding:.5rem 1rem;font-size:.875rem}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;font-size:.875rem}.users-table th,.users-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.users-table th{color:var(--text-secondary);font-weight:500;white-space:nowrap}.users-table td.actions{white-space:nowrap}.role-badge{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500;text-transform:uppercase}.role-badge.admin{background:#4f46e533;color:var(--accent)}.role-badge.user{background:#9ca3af33;color:var(--text-secondary)}.btn-small{padding:.35rem .75rem;font-size:.75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.35rem;color:var(--text-primary);cursor:pointer;margin-right:.35rem;transition:background-color .2s}.btn-small:hover{background:var(--bg-card);border-color:var(--accent)}.btn-small.btn-danger{background:#ef44441a;border-color:#ef44444d;color:var(--error)}.btn-small.btn-danger:hover{background:#ef444433}.no-users{text-align:center;color:var(--text-secondary);padding:2rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--bg-card);border-radius:1rem;padding:1.5rem;width:100%;max-width:400px;border:1px solid var(--border)}.modal h3{margin:0 0 1.5rem}.modal-actions{display:flex;gap:.5rem;margin-top:1.5rem}.modal-actions .btn{flex:1}.form-group.checkbox label{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);cursor:pointer}.form-group.checkbox input{width:auto}.settings-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1rem;margin-bottom:1.5rem}.settings-card h3{margin:0 0 .25rem;font-size:1rem}.settings-desc{color:var(--text-secondary);font-size:.875rem;margin:0 0 1rem}.settings-row{display:flex;gap:.5rem}.settings-row input{flex:1;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:.35rem;color:var(--text-primary);font-size:.875rem}.settings-row input:focus{outline:none;border-color:var(--accent)}.settings-row .btn{width:auto;padding:.5rem 1rem;font-size:.875rem}.rules-section{margin-top:1.5rem}.rules-section h3{margin:0 0 .25rem;font-size:1rem}.no-rules{text-align:center;color:var(--text-secondary);padding:2rem;background:var(--bg-secondary);border-radius:.5rem}.rules-table-container{overflow-x:auto}.match-value,.destination{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:monospace;font-size:.8rem}.status-badge{display:inline-block;padding:.2rem .5rem;border-radius:.25rem;font-size:.7rem;font-weight:500;text-transform:uppercase}.status-badge.enabled{background:#10b98133;color:var(--success)}.status-badge.disabled{background:#9ca3af33;color:var(--text-secondary)}.disabled-row{opacity:.5}.modal-wide{max-width:500px}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.form-group-small{flex:0 0 100px!important}.form-group select{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-size:1rem}.form-group select:focus{outline:none;border-color:var(--accent)}.form-help{display:block;margin-top:.35rem;color:var(--text-secondary);font-size:.75rem}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.status-card{display:flex;gap:1rem;padding:1rem;border-radius:.5rem;background:var(--bg-secondary);border:1px solid var(--border)}.status-card.status-ok{border-left:4px solid var(--success)}.status-card.status-error{border-left:4px solid var(--error)}.status-card.status-info{border-left:4px solid var(--accent)}.status-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;font-size:1.25rem;font-weight:700;flex-shrink:0}.status-ok .status-icon{background:#10b98133;color:var(--success)}.status-error .status-icon{background:#ef444433;color:var(--error)}.status-info .status-icon{background:#4f46e533;color:var(--accent)}.status-content h3{margin:0 0 .25rem;font-size:.875rem;color:var(--text-secondary)}.status-value{margin:0;font-size:1.125rem;font-weight:500}.status-detail{margin:.25rem 0 0;font-size:.75rem;color:var(--text-secondary)}.status-hint{margin:.5rem 0 0;font-size:.75rem;color:var(--warning)}.setup-instructions{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.setup-instructions h3{margin:0 0 1rem}.setup-instructions ol{margin:0;padding-left:1.25rem}.setup-instructions li{margin-bottom:1rem}.setup-instructions li strong{display:block;margin-bottom:.25rem}.setup-instructions li p{margin:0;color:var(--text-secondary);font-size:.875rem}.code-block{background:var(--bg-primary);border:1px solid var(--border);border-radius:.35rem;padding:.75rem;font-family:monospace;font-size:.8rem;overflow-x:auto;white-space:pre;margin-top:.5rem}.diagnostics-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1rem}.diagnostics-section h3{margin:0 0 1rem;font-size:1rem}.diagnostics-table{width:100%;font-size:.875rem}.diagnostics-table td{padding:.5rem 0;border-bottom:1px solid var(--border)}.diagnostics-table td:first-child{color:var(--text-secondary);width:150px}.diagnostics-table code{background:var(--bg-primary);padding:.15rem .35rem;border-radius:.25rem;font-size:.8rem}.history-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.stat-item{flex:1;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1rem;text-align:center}.stat-value{display:block;font-size:1.5rem;font-weight:600;color:var(--accent)}.stat-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.no-history{text-align:center;padding:3rem;background:var(--bg-secondary);border-radius:.5rem}.no-history p{margin:0}.no-history .hint{color:var(--text-secondary);font-size:.875rem;margin-top:.5rem}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem}.history-item-main{flex:1;min-width:0}.history-filename{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-meta{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.history-meta .separator{margin:0 .5rem}.history-status{padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:500;white-space:nowrap;margin-left:1rem}.history-status.status-completed{background:#10b98133;color:var(--success)}.history-status.status-pending{background:#4f46e533;color:var(--accent)}.history-status.status-failed{background:#ef444433;color:var(--error)}.history-status.status-unknown{background:#9ca3af33;color:var(--text-secondary)}.theme-toggle{background:none;border:1px solid var(--border);border-radius:.35rem;padding:.5rem;cursor:pointer;color:var(--text-primary);font-size:1.1rem;line-height:1;transition:background-color .2s}.theme-toggle:hover{background:var(--bg-secondary)}.header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.header-row .header{margin-bottom:0;text-align:left}.email-status{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1.5rem;font-size:.875rem}.email-status.configured{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--success)}.email-status.not-configured{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--warning)}.status-indicator{font-weight:700}.success-message{color:var(--success);background:#10b9811a;border:1px solid rgba(16,185,129,.3);padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}.email-form{margin-bottom:1.5rem}.settings-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1rem;margin-bottom:1rem}.settings-section h3{margin:0 0 1rem;font-size:.9rem;color:var(--text-secondary)}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.form-actions .btn{width:auto}.email-help{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1rem}.email-help h3{margin:0 0 .5rem;font-size:.9rem}.email-help p{margin:0 0 .5rem;color:var(--text-secondary);font-size:.875rem}.email-help ul{margin:0;padding-left:1.25rem;font-size:.8rem;color:var(--text-secondary)}.email-help li{margin-bottom:.25rem}.settings-description{color:var(--text-secondary);font-size:.875rem;margin:0 0 1rem;line-height:1.5}.settings-note{color:var(--text-secondary);font-size:.8rem;font-style:italic;margin-top:.75rem}.form-hint{display:block;margin-top:.35rem;color:var(--text-secondary);font-size:.75rem}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-primary)}.checkbox-group input[type=checkbox]{width:auto;accent-color:var(--accent)}.checkbox-group input[type=checkbox]:disabled{opacity:.5}.checkbox-group input[type=checkbox]:disabled+span{opacity:.5}.zerotier-id{font-family:monospace;font-size:.9rem;letter-spacing:.05em;-webkit-user-select:all;user-select:all}.not-configured{color:var(--warning);font-style:italic}.active-uploads-section{margin-bottom:1.5rem}.active-uploads-section h3{margin:0 0 1rem;font-size:1rem}.active-uploads-list{display:flex;flex-direction:column;gap:.75rem}.active-upload-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem}.upload-info{flex:1;min-width:0}.upload-filename{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.upload-meta{font-size:.75rem;color:var(--text-secondary)}.upload-meta .separator{margin:0 .4rem}.upload-user{color:var(--accent)}.upload-progress-container{display:flex;align-items:center;gap:.75rem;min-width:150px}.upload-progress-bar{flex:1;height:8px;background:var(--bg-primary);border-radius:4px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s ease}.upload-progress-text{font-size:.875rem;font-weight:500;min-width:40px;text-align:right}.upload-zone .folder-btn{margin-top:1rem;padding:.5rem 1.25rem;font-size:.875rem}.upload-zone .upload-hint{margin-top:.75rem;font-size:.75rem;opacity:.6}.upload-zone.processing{pointer-events:none;opacity:.8}.audit-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.audit-filter{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.35rem;color:var(--text-primary);font-size:.875rem}.audit-count{color:var(--text-secondary);font-size:.875rem}.audit-list{display:flex;flex-direction:column;gap:.5rem}.audit-entry{padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem}.audit-entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.audit-action{padding:.2rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.audit-info{background:#4f46e533;color:var(--accent)}.audit-success{background:#10b98133;color:var(--success)}.audit-warning{background:#f59e0b33;color:var(--warning)}.audit-error{background:#ef444433;color:var(--error)}.audit-time{color:var(--text-secondary);font-size:.75rem}.audit-entry-body{display:flex;flex-direction:column;gap:.25rem}.audit-user{font-weight:500}.audit-details{color:var(--text-secondary);font-size:.8rem;word-break:break-word}.audit-ip{color:var(--text-secondary);font-size:.75rem;margin-top:.25rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.page-info{color:var(--text-secondary);font-size:.875rem}.no-data{text-align:center;padding:3rem;background:var(--bg-secondary);border-radius:.5rem;color:var(--text-secondary)}.no-data .hint{font-size:.875rem;margin-top:.5rem;opacity:.7}.dashboard-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1.25rem;text-align:center}.summary-value{display:block;font-size:1.75rem;font-weight:600;color:var(--accent)}.summary-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.dashboard-section{margin-bottom:2rem}.dashboard-section h3{margin:0 0 1rem;font-size:1rem}.days-select{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.35rem;color:var(--text-primary);font-size:.875rem}.chart-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1rem;height:200px}.bar-chart{display:flex;align-items:flex-end;justify-content:space-around;height:100%;gap:4px}.bar-item{display:flex;flex-direction:column;align-items:center;flex:1;max-width:30px;height:100%}.bar-container{flex:1;width:100%;display:flex;align-items:flex-end}.bar-fill{width:100%;background:var(--accent);border-radius:2px 2px 0 0;min-height:2px;transition:height .3s ease}.bar-label{font-size:.6rem;color:var(--text-secondary);margin-top:.25rem;white-space:nowrap}.leaderboard{display:flex;flex-direction:column;gap:.5rem}.leaderboard-item{display:grid;grid-template-columns:40px 1fr auto 100px;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem}.leaderboard-rank{font-weight:600;color:var(--accent)}.leaderboard-name{font-weight:500}.leaderboard-stats{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.leaderboard-bar{height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden}.leaderboard-bar-fill{height:100%;background:var(--accent);border-radius:3px}.webhooks-list{display:flex;flex-direction:column;gap:1rem}.webhook-item{padding:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem}.webhook-item.disabled{opacity:.5}.webhook-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.webhook-name{font-weight:500}.webhook-type{padding:.2rem .5rem;border-radius:.25rem;font-size:.7rem;font-weight:500;text-transform:uppercase}.type-slack{background:#4f46e533;color:var(--accent)}.type-discord{background:#5865f233;color:#5865f2}.type-generic{background:#9ca3af33;color:var(--text-secondary)}.webhook-url{font-family:monospace;font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.5rem}.webhook-events{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.75rem}.event-tag{padding:.15rem .4rem;background:var(--bg-primary);border-radius:.25rem;font-size:.7rem;color:var(--text-secondary);text-transform:capitalize}.webhook-actions{display:flex;gap:.5rem}.btn-small{padding:.35rem .75rem;font-size:.75rem}.btn-danger{color:var(--error)}.btn-danger:hover{background:#ef44441a}.test-result{padding:.5rem;border-radius:.35rem;font-size:.8rem;margin-bottom:.5rem}.test-result.success{background:#10b9811a;color:var(--success)}.test-result.error{background:#ef44441a;color:var(--error)}.event-checkboxes{display:flex;flex-direction:column;gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input{width:auto}.zerotier-section{margin-top:2rem}.zerotier-section h3{margin-bottom:1rem}.zerotier-status-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1rem}.zerotier-status-card.zt-connected{border-color:var(--success);border-left:4px solid var(--success)}.zerotier-status-card.zt-disconnected{border-color:var(--error);border-left:4px solid var(--error)}.zt-status-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border)}.zt-status-row:last-child{border-bottom:none}.zt-label{color:var(--text-secondary);font-size:.875rem}.zt-value{font-weight:500}.zt-value code{background:var(--bg-primary);padding:.25rem .5rem;border-radius:.25rem;font-family:monospace;font-size:.875rem}.zt-ok{color:var(--success)}.zt-error{color:var(--error)}.routing-summary{margin-top:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;overflow:hidden}.routing-summary-toggle{width:100%;padding:1rem;display:flex;justify-content:space-between;align-items:center;background:transparent;border:none;color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.routing-summary-toggle:hover{background:var(--bg-secondary)}.toggle-icon{font-size:1.25rem;color:var(--text-secondary)}.routing-summary-content{padding:0 1rem 1rem;border-top:1px solid var(--border)}.routing-summary-desc{font-size:.85rem;color:var(--text-secondary);margin:1rem 0}.routing-rules-list{display:flex;flex-direction:column;gap:.5rem}.routing-rule-item{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:.35rem;font-size:.85rem}.routing-rule-item.default-rule{border:1px dashed var(--border);background:transparent}.rule-match{display:flex;flex-direction:column;gap:.25rem}.rule-type{font-size:.7rem;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em}.rule-value{font-family:monospace;color:var(--accent);word-break:break-word}.rule-arrow{color:var(--text-secondary);font-size:1.1rem}.rule-destination{text-align:right;font-weight:500;color:var(--success);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.incomplete-uploads{margin-top:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;padding:1rem}.incomplete-uploads h3{margin:0 0 .5rem;font-size:1rem;color:var(--warning)}.incomplete-uploads-desc{font-size:.85rem;color:var(--text-secondary);margin:0 0 1rem}.incomplete-uploads-list{display:flex;flex-direction:column;gap:.75rem}.incomplete-upload-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:.35rem;border-left:3px solid var(--warning)}.incomplete-upload-info{flex:1;min-width:0}.incomplete-upload-name{font-weight:500;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.incomplete-upload-details{font-size:.8rem;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:.5rem}.incomplete-upload-date{opacity:.7}.incomplete-upload-progress{height:4px;background:var(--border);border-radius:2px;margin-top:.5rem;overflow:hidden}.incomplete-upload-progress-bar{height:100%;background:var(--warning);border-radius:2px;transition:width .3s ease}.incomplete-upload-actions{display:flex;gap:.5rem;flex-shrink:0}.btn-small{padding:.35rem .75rem;font-size:.8rem}.destination-primary{font-weight:500}.destination-copies{margin-top:.25rem}.destination-copy{font-size:.8rem;color:var(--text-secondary);padding-left:.5rem}.copy-to-row{display:flex;gap:.5rem;margin-bottom:.5rem}.copy-to-row input{flex:1}.copy-to-help{margin-bottom:.75rem}.btn-add-copy{margin-top:.5rem;font-size:.85rem}.label-optional{font-weight:400;font-size:.8rem;color:var(--text-secondary);margin-left:.5rem}.rule-copies{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.25rem}.rule-copy-badge{font-size:.7rem;padding:.1rem .35rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.2rem;color:var(--text-secondary)}.success-message{background:#10b9811a;border:1px solid var(--success);color:var(--success);padding:.75rem;border-radius:.35rem;margin-bottom:1rem;font-size:.9rem}.auth-description{color:var(--text-secondary);font-size:.9rem;margin-bottom:1.5rem;text-align:center}
