.login-container{height:100vh;width:100vw;display:flex;justify-content:center;align-items:center;background:#fff;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(37,99,235,.1) 0%,transparent 50%);animation:rotate 20s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-card{position:relative;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2.5rem;border-radius:24px;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px -12px #00000080;width:100%;max-width:400px;text-align:center;z-index:10}.login-header h2{color:#000;margin:1rem 0 .5rem;font-size:1.5rem}.login-header p{color:#94a3b8;font-size:.9rem;margin-bottom:2rem}.logo-icon{background:#2563eb;width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto;box-shadow:0 10px 15px -3px #2563eb66}.input-group{position:relative;display:flex;align-items:center;margin-bottom:1rem}.eye-button{position:absolute;top:50%;transform:translateY(-50%);right:15px;bottom:auto;background:none;border:none;color:#f3f3f3;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:color .2s;z-index:10}.eye-button:hover{color:#2563eb}.input-icon{position:absolute;left:1rem;top:60%;transform:translateY(-50%);color:#94a3b8}.input-icon-user,.input-icon-pass{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:#e2e2e2;z-index:10}.input-group input{width:100%;padding:12px 10px 12px 45px;background:#96969699;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;outline:none;transition:all .3s ease;box-sizing:border-box}.input-group input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33;background:#636363cc;color:#fff}.input-group input::placeholder{color:#fff;opacity:1}.btn-login{width:100%;padding:12px;background:#2563eb;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:1rem}.btn-login:hover{background:#1d4ed8;transform:translateY(-1px)}.btn-login:disabled{background:#475569;cursor:not-allowed;transform:none}.warning-banner{background:#fff7d6;color:#92400e;padding:10px;border-radius:8px;box-shadow:0 4px 12px #0000000d;border:1px solid #FACC15;font-size:.85rem;margin-bottom:1rem;transition:all .2s ease}.error-banner{background:#fee2e2;color:#991b1b;padding:10px;border-radius:8px;border:1px solid #FCA5A5;box-shadow:0 4px 12px #0000000d;font-size:.85rem;margin-bottom:1rem;transition:all .2s ease}.loader-full{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:#475569;background-color:#f1f5f9}.logo-image{width:90px;height:auto;margin:0 auto 14px;display:block;object-fit:contain}.monitoring-header.grid{display:grid;grid-template-columns:auto max-content 1fr;grid-template-rows:auto auto;gap:6px 14px;margin:8px 16px;padding:0;background:transparent;border-radius:0;box-shadow:none;border:none}.mh-left-center{grid-column:2;grid-row:1 / span 2;display:flex;flex-direction:column;justify-content:center;gap:6px}.mh-title,.mh-stats{display:flex;gap:8px;grid-column:2;align-items:center;align-self:flex-start}.mh-logo{grid-row:span 2;display:flex;align-items:center;justify-content:center}.mh-logo img{width:90px;height:auto}.mh-title h2{margin:0;font-size:32px;font-weight:700;letter-spacing:-.3px}.mh-actions{grid-column:3;grid-row:1;justify-self:end;display:flex;align-items:center;gap:18px}.mh-stat-icon{position:relative;display:flex;align-items:center;gap:2px;white-space:nowrap;height:32px;padding:0 10px;border-radius:999px;border:1px solid rgba(255,255,255,.6);background:#fff;box-shadow:0 2px 4px #00000008;border:1px solid #e2e8f0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);cursor:pointer;color:#2563eb;transition:background .2s ease,box-shadow .2s ease,border-color .2s ease}.mh-stat-icon svg{width:16px;height:16px}.mh-stat-icon .count{font-size:12px;font-weight:700}.mh-stat-icon:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.mh-stat-icon.success:hover{background:#16a34a2e;border-color:#16a34a59}.mh-stat-icon.downloading:hover{background:#2563eb2e;border-color:#2563eb59}.mh-stat-icon.paused:hover{background:#ca8a0433;border-color:#ca8a0466}.mh-stat-icon.failed:hover{background:#dc262633;border-color:#dc262666}.mh-stat-icon.green:hover{background:#16a34a2e;border-color:#16a34a59}.mh-stat-icon.red:hover{background:#dc26262e;border-color:#dc262659}.mh-stat-icon.active{box-shadow:0 6px 18px #00000024}.mh-stat-icon.active:hover{box-shadow:0 8px 22px #0000002e}.mh-stat-icon.blue{color:#2563eb}.mh-stat-icon.blue.active{background:#2563eb26;border-color:#2563eb59}.mh-stat-icon.green{color:#16a34a}.mh-stat-icon.green.active{background:#16a34a26;border-color:#16a34a59}.mh-stat-icon.red{color:#dc2626}.mh-stat-icon.red.active{background:#dc262626;border-color:#dc262659}.mh-stat-icon.success{color:#16a34a}.mh-stat-icon.success.active{background:#16a34a38;border-color:#16a34a73}.mh-stat-icon.downloading{color:#2563eb}.mh-stat-icon.downloading.active{background:#2563eb38;border-color:#2563eb73}.mh-stat-icon.paused{color:#ca8a04}.mh-stat-icon.paused.active{background:#ca8a043d;border-color:#ca8a0473}.mh-stat-icon.failed{color:#dc2626}.mh-stat-icon.failed.active{background:#dc26263d;border-color:#dc262673}.mh-stat-text{font-size:12px;font-weight:600;letter-spacing:.3px;margin-left:2px}.mh-stat-icon .count{font-weight:600;font-size:13px;min-width:14px;text-align:center}.mh-search-wrap{display:flex;justify-content:flex-end}.mh-search{width:240px;padding:8px 14px;border-radius:999px;border:1px solid #e5e7eb;background:#f3f4f6}.mh-search-box{display:flex;align-items:center;gap:8px;height:28px;padding:0 14px;background:#fff9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6);border-radius:99px;box-shadow:0 1px 3px #0000000f;transition:box-shadow .2s ease,border-color .2s ease}.mh-search-box:focus-within{background:#ffffffd9;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb2e}.mh-search-icon{width:16px;height:16px;color:#6b7280}.mh-search-input{border:none;outline:none;background:transparent;width:220px;font-size:12px}.mh-upload.modern{display:inline-flex;align-items:center;gap:8px;height:32px;padding:0 16px;border-radius:999px;border:1px solid rgba(37,99,235,.35);background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:transform .18s cubic-bezier(.2,.9,.2,1),box-shadow .18s ease,filter .18s ease}.mh-upload.modern svg{width:16px;height:16px}.mh-upload.modern:hover{transform:translateY(-1px);box-shadow:0 10px 24px #2563eb59;filter:brightness(1.05)}.mh-upload.modern:active{transform:scale(.97);box-shadow:0 4px 12px #2563eb47}.mh-dropdown{position:absolute;right:0;top:calc(100% + 8px);width:220px;background:#fff;border-radius:14px;padding:8px;box-shadow:0 10px 30px #0000001f,0 2px 6px #00000014;z-index:50}.mh-dropdown-header{display:flex;align-items:center;gap:10px;padding:8px}.mh-dropdown-header .avatar.large{width:36px;height:36px;font-size:14px}.mh-dropdown-header .name{font-weight:600;font-size:13px}.mh-dropdown-header .role{font-size:11px;color:#6b7280}.mh-dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:transparent;border:none;cursor:pointer;font-size:13px;color:#111827}.mh-dropdown-item:hover{background:#f3f4f6}.mh-dropdown-item svg{width:16px;height:16px;opacity:.8}.mh-dropdown-item.danger{color:#dc2626}.mh-dropdown-item.danger:hover{background:#fee2e2}.mh-dropdown .divider{height:1px;background:#e5e7eb;margin:6px 4px}.mh-user-trigger{display:flex;align-items:center;gap:8px;height:32px;padding:0 10px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;font-size:12px;cursor:pointer}.avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.caret{font-size:10px;opacity:.7}.mh-user-trigger .caret{transition:transform .2s ease}.mh-user-trigger[aria-expanded=true] .caret{transform:rotate(180deg)}.monitoring-header{overflow:visible}.mh-actions,.mh-user{position:relative;overflow:visible}.mh-search-wrap.with-filters{display:flex;align-items:center;gap:12px}.mh-filters{display:flex;gap:8px}.mh-filter{height:24px;padding:0 8px;border-radius:2px 2px 0 0;background:#fff9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.mh-filter:hover{border-color:#3b82f6;background:#f8fbff}.mh-filter:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #3b82f626}.mh-bulk-actions{display:flex;align-items:center;gap:4px}.bulk-btn{display:inline-flex;align-items:center;justify-content:flex-start;gap:8px;height:36px;min-width:32px;padding:0 8px;border-radius:10px;white-space:nowrap;overflow:hidden;transition:background-color .2s ease,transform .2s ease}.mh-bulk-actions .bulk-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #0f172a1f}.mh-bulk-actions .bulk-btn:active{transform:scale(.96)}.mh-bulk-actions .bulk-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none;filter:grayscale(.6)}.mh-bulk-actions .bulk-btn.pause{color:#f59e0b;background:#f59e0b14;border-color:#f59e0b40}.mh-bulk-actions .bulk-btn.resume{color:#10b981;background:#10b98114;border-color:#10b98140}.mh-bulk-actions .bulk-btn.retry{color:#3b82f6;background:#3b82f614;border-color:#3b82f640}.mh-bulk-actions .bulk-btn.cancel{color:#ef4444;background:#ef444414;border-color:#ef444440}.mh-bulk-actions .bulk-btn.delete{color:#b91c1c;background:#ef44441f;border-color:#ef444459}.mh-bulk-actions{display:flex;align-items:center;gap:6px}.bulk-text{font-size:12px;font-weight:600}.bulk-btn.expand .bulk-text{max-width:90px;opacity:1;transform:translate(0) scale(1)}.bulk-btn.expand{transform:scale(1.02)}.tb-grid{flex:1;display:flex;flex-direction:column;overflow:hidden}.tb-header,.tb-row{display:grid;grid-template-columns:28px minmax(250px,3fr) minmax(120px,1fr) minmax(220px,3fr) minmax(280px,2fr) minmax(120px,1fr) minmax(140px,1fr) 50px;align-items:center;width:100%;padding:8px;gap:6px}.tb-header{position:sticky;top:0;z-index:5;height:42px;background:var(--bg-header);border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);box-shadow:inset 0 -1px 0 var(--border-soft);font-weight:700}.tb-body{flex:1;display:flex;flex-direction:column;overflow-y:auto}.tb-row{height:var(--row-height);border-bottom:1px solid var(--border-row);background:#fff;overflow:visible}.tb-row.sub{background:#fcfcfd;border-bottom:none!important}.tb-row:hover{background:#f9fafb}.tb-row.no-border{border-bottom:none!important}.tb-row.last{border-bottom:1px solid var(--border-row)}.tb-row.client-offline{background:linear-gradient(90deg,#ef444414,#fff 45%)!important;opacity:.85}.tb-row.client-offline:hover{background:#ef44441a!important}.tb-row.no-job{background:linear-gradient(90deg,#94a3b80f,#fff 40%)}.tb-row.job-failed{background:linear-gradient(90deg,#ef44441f,#fff 45%)}.tb-row.job-failed:hover{background:#ef444424}.tb-cell{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.tb-cell.remote{display:flex;align-items:center}.tb-cell.center{display:flex;align-items:center;justify-content:center}.tb-cell.left{display:flex;align-items:center;justify-content:flex-start}.tb-cell.actions{overflow:visible;position:relative;z-index:10}.tb-row:hover .tb-cell.actions{z-index:20}.client-name{display:flex;flex-direction:column;font-weight:700;white-space:normal;word-break:break-word;overflow:visible}.client-title{display:flex;align-items:center;gap:8px}.client-label{font-weight:600;color:#111827}.client-icon{width:20px;height:20px;flex:0 0 20px;color:#2563eb}.client-meta{display:flex;flex-direction:column;gap:4px;margin-top:4px}.client-status{font-size:11px;display:flex;align-items:center;gap:12px;padding-left:2px}.client-name.online .client-status{color:#10b981}.client-name.offline .client-status{color:#ef4444}.client-status .wifi-icon{width:16px;height:16px;color:currentColor;transition:transform .24s ease,opacity .2s ease;animation:wifiPulse 1.8s infinite ease-in-out}.client-status .status-text,.health .health-text{display:inline-block;margin-left:12px}.client-status .wifi-icon-off{width:16px;height:16px;color:currentColor;animation:none}@keyframes wifiPulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.85}to{transform:scale(1);opacity:1}}.health{font-size:12px;display:flex;align-items:center;gap:12px}.health .health-icon{width:14px;height:14px;margin-right:6px;vertical-align:middle;color:#10b981}.health .health-icon.off{color:#ef4444}.remote-view{display:flex;align-items:center;gap:6px;width:100%}.remote-view .action-btn.edit{margin-left:auto}.remote-actions{display:flex;gap:6px;align-items:center;animation:fadeInUp .16s ease both}.action-btn.edit{color:#2563eb;background:#2563eb14;border-color:#2563eb40}.action-btn.success{color:#10b981;background:#10b9811a;border-color:#10b9814d}.action-btn.cancel{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.remote-badge{background:#eef2ff;color:#2563eb;padding:3px 8px;border-radius:999px;font-size:12px;font-weight:500;display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background-color .18s ease,color .18s ease,transform .12s ease}.btn-set-remote{padding:4px 10px;font-size:12px;border-radius:8px;border:1px dashed #c7d2fe;background:#f8fafc;cursor:pointer}@keyframes fadeInUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.remote-modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .12s ease both}.remote-modal{background:#fff;border-radius:12px;padding:18px;width:340px;max-width:calc(100% - 32px);box-shadow:0 10px 30px #02061724;transform:translateY(0)}.remote-modal h3{margin:0 0 8px;font-size:16px}.remote-modal-body{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.remote-modal-body .modal-client{font-size:13px;color:#374151}.remote-modal input{width:100%;padding:8px 10px;border:1px solid #e5e7eb;border-radius:8px}.remote-modal-actions{display:flex;gap:8px;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.remote-tooltip{z-index:11000}.remote-tooltip-card{background:#fff;border:1px solid #e6edf8;border-radius:8px;padding:6px;min-width:unset;width:fit-content;animation:fadeInUp .12s ease both;box-shadow:0 6px 18px #0206171f}.remote-tooltip-head{font-size:13px;font-weight:600;margin-bottom:4px}.remote-tooltip-input{width:120px;padding:4px 28px 4px 6px;font-size:12px;border-radius:6px;border:1px solid #e5e7eb}.remote-tooltip-input:focus{outline:none;border-color:#60a5fa;box-shadow:0 4px 14px #2563eb1f}.remote-tooltip-actions{display:flex;gap:6px;margin-top:4px;justify-content:flex-end}.remote-tooltip-actions .action-btn{width:28px;height:28px}.remote-input-wrap{position:relative;display:inline-flex;align-items:center}.remote-clear-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:5px;border:none;background:#ef44441f;color:#ef4444;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}.remote-clear-btn:hover{background:#ef444433}.remote-clear-btn:active{background:#ef444440}.remote-clear-btn svg{transform:scale(1.5);transform-origin:center;stroke-width:2.2}.file-name{display:flex;align-items:center;gap:6px;font-weight:500}.file-icon{flex:0 0 auto;color:#64748b}.file-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.muted{font-size:12px;color:var(--text-muted)}.progress-bar.modern{height:22px;border-radius:6px;background:#f1f5f9;box-shadow:inset 0 1px 2px #0000000f;overflow:hidden;position:relative;border:1px solid #e2e8f0}.progress-fill{height:100%;display:flex;align-items:center;justify-content:flex-end;color:#fff;border-radius:5px;transition:width .6s cubic-bezier(.25,.8,.25,1),background-image .5s ease,box-shadow .5s ease;position:relative;overflow:hidden;box-shadow:2px 0 10px #0000001a;min-width:12%}.progress-percent-animated{padding-right:8px;z-index:5;white-space:nowrap}.progress-percent-animated .percent-text{font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.25)}.progress-fill.range-1{background-image:linear-gradient(90deg,#ef4444,#f97316);box-shadow:0 0 12px #ef444466}.progress-fill.range-2{background-image:linear-gradient(90deg,#f97316,#eab308);box-shadow:0 0 12px #f9731666}.progress-fill.range-3{background-image:linear-gradient(90deg,#0ea5e9,#3b82f6);box-shadow:0 0 12px #3b82f666}.progress-fill.range-4{background-image:linear-gradient(90deg,#3b82f6,#10b981);box-shadow:0 0 12px #10b98166}.progress-fill.success{background-image:linear-gradient(90deg,#22c55e,#15803d)!important;box-shadow:none}.progress-fill.failed,.progress-fill.error{background-image:linear-gradient(90deg,#ef4444,#b91c1c)!important}.progress-fill.executing{background-image:linear-gradient(90deg,#8b5cf6,#6366f1)!important}.progress-fill:before{content:"";position:absolute;inset:0;background-image:linear-gradient(45deg,rgba(255,255,255,.12) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.12) 75%,transparent 75%,transparent);background-size:20px 20px;z-index:1;animation:stripemove 1s linear infinite;opacity:.6}.progress-glare{position:absolute;top:0;right:0;bottom:0;width:1px;background:#fff9;box-shadow:0 0 8px 2px #fff6;z-index:2}@keyframes stripemove{0%{background-position:0 0}to{background-position:20px 20px}}.progress-fill.paused{filter:grayscale(.8);opacity:.8;animation:none}.progress-fill.paused:before{animation:none}.progress-empty{height:22px;border-radius:6px;border:1px dashed #e5e7eb;background:#f8fafc;display:flex;align-items:center;justify-content:center;font-size:12px;color:#94a3b8;font-style:italic}.progress-cell{display:flex;flex-direction:column;gap:6px;overflow:visible}.progress-info.modern{display:flex;flex-wrap:wrap;gap:2px;margin-top:2px}.info-pill{display:inline-flex;align-items:center;gap:4px;padding:4px;border-radius:999px;font-size:10px;font-weight:600;line-height:1;background:#f8fafc;border:1px solid #e5e7eb;color:#0f172a}.info-pill svg{width:13px;height:13px;opacity:.9}.info-pill.size{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.info-pill.speed{background:#ecfdf5;border-color:#6ee7b7;color:#065f46;animation:pulse 1.2s ease-in-out infinite}.info-pill.speed.done{background:#fffbeb;border-color:#fde68a;color:#92400e}.info-pill.eta{background:#fff1f2;border-color:#fecaca;color:#991b1b}.info-pill .muted{font-size:11px;font-weight:500;color:#475569;opacity:.65}.tb-row .progress-info{transition:opacity .22s ease,transform .22s ease}.tb-row .badge-success~.progress-cell .progress-info{opacity:.85;transform:translateY(-1px)}@keyframes fadeSoft{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.progress-info{animation:fadeSoft .18s ease}.badge{padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600}.badge-pending{background:#f59e0b24;color:#b45309}.badge-success{background:#dcfce7;color:#15803d}.badge-deleted{background:#fee2e2;color:#b91c1c}.badge-downloading{background:#2563eb1f;color:#1d4ed8}.badge-paused{background:#f59e0b24;color:#b45309}.badge-failed,.badge-error,.badge-retry,.badge-canceled{background:#ef444424;color:#b91c1c}.badge-executing{background:#6366f124;color:#4338ca}.category-pill{position:relative;display:inline-flex;align-items:center;gap:6px;padding:4px 8px 4px 6px;border-radius:6px;font-family:inherit;font-size:11px;font-weight:600;line-height:1;cursor:pointer;transition:all .15s ease-out;-webkit-user-select:none;user-select:none;width:fit-content;max-width:100%}.category-pill:hover{filter:brightness(.96);transform:translateY(-1px);box-shadow:0 2px 5px #0000000d}.pill-icon{display:flex;opacity:.9}.pill-text{position:relative;top:.5px;letter-spacing:.4px}.pill-arrow{margin-left:2px;opacity:.5;transition:transform .2s}.category-pill:hover .pill-arrow{opacity:1;transform:translateY(1px)}.pill-select-overlay{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;appearance:none;-webkit-appearance:none;border:none;background:transparent;z-index:10}.pill-label-static{font-size:11px;font-weight:500;opacity:.6;margin:0 4px;letter-spacing:.2px}.pill-icon{display:flex;opacity:.8}.pill-text{position:relative;font-weight:700;top:.5px}.pill-arrow{margin-left:2px;opacity:.5}.actions{display:flex;gap:8px;align-items:center}.action-btn{width:28px;height:28px;border-radius:10px;border:1px solid transparent;background:#f8fafc;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .18s cubic-bezier(.2,.9,.2,1),background-color .18s ease,box-shadow .18s ease,border-color .18s ease}.action-btn svg{width:18px;height:18px}.action-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #0f172a1f}.action-btn:active{transform:scale(.96)}.action-btn.pause{color:#f59e0b;background:#f59e0b14;border-color:#f59e0b40}.action-btn.resume{color:#10b981;background:#10b98114;border-color:#10b98140}.action-btn.retry{color:#3b82f6;background:#3b82f614;border-color:#3b82f640}.action-btn.cancel{color:#ef4444;background:#ef444414;border-color:#ef444440}.action-btn.delete{color:#b91c1c;background:#ef44441f;border-color:#ef444459}.action-loading svg{width:20px;height:20px;color:#64748b;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.icon-btn.log{background:transparent;border:none;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center}.icon-btn.log:hover{color:#0f172a;transform:scale(1.05)}.action-btn.disabled,.action-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none;transform:none!important;box-shadow:none!important;filter:grayscale(.6)}.tb-footer{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:6px 10px;border-top:1px solid #e5e7eb;background:#fff;font-size:12px}.pg-left{color:#374151}.pg-btn{height:22px;width:22px;border-radius:6px;border:1px solid #d1d5db;background:#fff;cursor:pointer;font-size:12px}.pg-btn:hover:not(:disabled){background:#f1f5f9}.pg-btn:disabled{opacity:.35}.pg-input{width:36px;height:22px;font-size:12px;text-align:center;border-radius:6px;border:1px solid #d1d5db}.pg-center{display:flex;align-items:center;gap:4px;justify-content:center}.pg-total{font-size:12px;color:#6b7280}.pg-right{display:flex;align-items:center;gap:4px;justify-content:flex-end;font-size:12px}.pg-right select{height:22px;font-size:12px;border-radius:6px;border:1px solid #d1d5db;padding:0 4px}.admin-upload-scope{--c-primary: #2563eb;--c-primary-hover: #1d4ed8;--c-danger: #ef4444;--c-danger-bg: #fee2e2;--c-text-main: #1e293b;--c-text-muted: #64748b;--c-border: #e2e8f0;--c-bg-subtle: #f8fafc;--c-bg-white: #ffffff;width:100%;height:100%;display:flex;flex-direction:column;font-family:inherit;color:var(--c-text-main);overflow:hidden}.admin-upload-scope .upload-card{flex:1;display:flex;flex-direction:column;gap:12px;overflow:hidden;background:transparent;padding:20px;height:100%}.admin-upload-scope .upload-header-row{display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.admin-upload-scope .upload-header{margin:0;display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:var(--c-text-main)}.admin-upload-scope .btn-close-modal{border:none;background:transparent;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--c-text-muted);transition:all .2s}.admin-upload-scope .btn-close-modal:hover{background:var(--c-danger-bg);color:var(--c-danger)}.admin-upload-scope .dropzone{flex-shrink:0;border:2px dashed var(--c-border);border-radius:12px;padding:20px;min-height:120px;background:var(--c-bg-subtle);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1)}.admin-upload-scope .dropzone:hover,.admin-upload-scope .dropzone.dragging{border-color:var(--c-primary);background:#eff6ff;transform:translateY(-1px)}.admin-upload-scope .dropzone.has-file{min-height:0;height:auto;padding:8px 12px;background:var(--c-bg-white);border:1px solid var(--c-border);border-left:4px solid var(--c-primary);justify-content:flex-start}.admin-upload-scope .dropzone-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.admin-upload-scope .upload-icon{color:var(--c-primary);opacity:.8}.admin-upload-scope .dropzone-text{font-size:14px;font-weight:600;color:var(--c-text-muted);margin:0}.admin-upload-scope .dropzone-subtext{font-size:12px;color:#94a3b8;margin:0}.admin-upload-scope .file-preview-container{display:flex;align-items:center;gap:12px;width:100%}.admin-upload-scope .file-preview-img,.admin-upload-scope .file-icon{width:48px;height:48px;border-radius:6px;object-fit:cover;border:1px solid var(--c-border);display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--c-bg-subtle);flex-shrink:0}.admin-upload-scope .dropzone.has-file .file-preview-img,.admin-upload-scope .dropzone.has-file .file-icon{width:36px;height:36px;font-size:18px}.admin-upload-scope .file-details{flex:1;display:flex;flex-direction:column;justify-content:center;gap:2px;min-width:0}.admin-upload-scope .dropzone.has-file .file-details{flex-direction:row;align-items:center;gap:10px}.admin-upload-scope .file-name{font-size:13px;font-weight:600;color:var(--c-text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-upload-scope .dropzone.has-file .file-name{margin:0;max-width:40%}.admin-upload-scope .file-size{font-size:11px;font-weight:500;color:var(--c-text-muted);display:flex;align-items:center;gap:6px}.admin-upload-scope .dropzone.has-file .file-size{margin-right:auto;background:transparent;padding:0}.admin-upload-scope .file-queue{font-size:10px;color:var(--c-primary);font-weight:700;background:#eff6ff;padding:2px 8px;border-radius:4px;width:fit-content;white-space:nowrap}.admin-upload-scope .upload-flex{flex-shrink:0;display:flex;flex-direction:column;gap:8px;max-height:150px;transition:all .3s ease}.admin-upload-scope .upload-flex.uploading{display:grid;grid-template-columns:200px 1fr;max-height:120px}.admin-upload-scope .queue-card.modern{background:var(--c-bg-white);border-radius:10px;padding:8px;border:1px solid var(--c-border);max-height:100%;overflow-y:auto;display:flex;flex-direction:column}.admin-upload-scope .queue-title{font-size:10px;font-weight:700;color:var(--c-text-muted);margin-bottom:6px;display:flex;align-items:center;gap:4px;text-transform:uppercase;flex-shrink:0;padding-left:4px}.admin-upload-scope .queue-item{display:flex;align-items:center;padding:4px 8px;gap:8px;border-radius:6px;margin-bottom:2px;background:var(--c-bg-subtle);border:1px solid transparent;flex-shrink:0}.admin-upload-scope .queue-item.active{background:#eff6ff;border-color:#bfdbfe;color:var(--c-primary)}.admin-upload-scope .queue-info{flex:1;min-width:0;display:flex;flex-direction:column}.admin-upload-scope .queue-name{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-upload-scope .queue-size{font-size:9px;color:var(--c-text-muted)}.admin-upload-scope .queue-remove{border:none;background:transparent;color:var(--c-text-muted);cursor:pointer;padding:2px;border-radius:4px;display:flex}.admin-upload-scope .queue-remove:hover{background:var(--c-danger-bg);color:var(--c-danger)}.admin-upload-scope .progress-card.modern{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:12px;display:flex;flex-direction:column;justify-content:center;height:100%}.admin-upload-scope .progress-bar-upload{height:12px;background:#dbeafe;border-radius:999px;overflow:hidden;position:relative;width:100%}.admin-upload-scope .progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#0ea5e9);border-radius:999px;display:flex;align-items:center;justify-content:flex-end;padding-right:6px;transition:width .3s ease-out}.admin-upload-scope .progress-fill.downloading{background-size:200% 100%;animation:adminFlow 2s linear infinite}@keyframes adminFlow{0%{background-position:0% 0}to{background-position:200% 0}}.admin-upload-scope .percent-text{font-size:9px;font-weight:800;color:#fff}.admin-upload-scope .progress-info-row{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.admin-upload-scope .progress-meta{display:flex;gap:4px}.admin-upload-scope .info-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;border:1px solid transparent;background:#fff}.admin-upload-scope .info-pill svg{width:10px;height:10px}.admin-upload-scope .info-pill.size{color:#0284c7;border-color:#bae6fd}.admin-upload-scope .info-pill.speed{color:#16a34a;border-color:#bbf7d0}.admin-upload-scope .info-pill.eta{color:#dc2626;border-color:#fecaca}.admin-upload-scope .upload-filter-row{display:flex;gap:8px;flex-shrink:0}.admin-upload-scope .upload-search-box{flex:1;position:relative}.admin-upload-scope .upload-search-input{width:100%;height:36px;padding:0 32px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-bg-white);font-size:13px;outline:none;transition:border .2s}.admin-upload-scope .upload-search-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #2563eb1a}.admin-upload-scope .upload-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#94a3b8;width:15px;pointer-events:none}.admin-upload-scope .clear-search{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:transparent;color:#94a3b8;cursor:pointer;display:flex}.admin-upload-scope .upload-filter-select{height:36px;padding:0 12px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-bg-white);font-size:13px;font-weight:500;color:var(--c-text-main);outline:none;cursor:pointer}.admin-upload-scope .client-selection-area{flex:1;display:flex;flex-direction:column;min-height:0;border:1px solid var(--c-border);border-radius:10px;background:var(--c-bg-subtle);overflow:hidden;margin-bottom:0}.admin-upload-scope .selection-header{padding:8px 12px;border-bottom:1px solid var(--c-border);background:var(--c-bg-white);display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;color:var(--c-text-muted);flex-shrink:0}.admin-upload-scope .mini-btns{display:flex;gap:6px}.admin-upload-scope .btn-mini{padding:4px 10px;font-size:11px;border-radius:6px;border:1px solid transparent;font-weight:600;cursor:pointer;transition:all .2s}.admin-upload-scope .btn-mini.primary{background:#eff6ff;color:var(--c-primary);border-color:#bfdbfe}.admin-upload-scope .btn-mini.primary:hover{background:#dbeafe}.admin-upload-scope .btn-mini.warning{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.admin-upload-scope .btn-mini.warning:hover{background:#ffedd5}.admin-upload-scope .btn-mini.ghost{background:transparent;color:var(--c-text-muted)}.admin-upload-scope .btn-mini.ghost:hover{background:#f1f5f9;color:var(--c-text-main)}.admin-upload-scope .client-item{display:flex;align-items:center;gap:10px;padding:0 12px;border-radius:6px;background:var(--c-bg-white);border:1px solid var(--c-border);cursor:pointer;transition:border .1s}.admin-upload-scope .client-item:hover{border-color:#94a3b8}.admin-upload-scope .client-item.offline{background:#fef2f2;border-color:#fee2e2;opacity:.85}.admin-upload-scope .c-name{flex:1;font-weight:500;font-size:13px;color:var(--c-text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-upload-scope .client-upload-time{font-size:11px;color:#94a3b8;font-family:monospace}.admin-upload-scope .status-dot{width:6px;height:6px;border-radius:50%}.admin-upload-scope .status-dot.online{background:#22c55e}.admin-upload-scope .status-dot.offline{background:var(--c-danger)}.admin-upload-scope .status-text{font-size:11px;font-weight:600;margin-left:6px}.admin-upload-scope .status-text.online{color:#15803d}.admin-upload-scope .status-text.offline{color:#b91c1c}.admin-upload-scope .upload-footer{flex-shrink:0;margin-top:0;padding-top:12px;border-top:1px solid var(--c-border);display:flex;flex-direction:column;gap:8px;background:var(--c-bg-white);z-index:10}.admin-upload-scope .upload-message{font-size:12px;font-weight:600;color:#0369a1;background:#e0f2fe;padding:8px;border-radius:6px;text-align:center;border:1px solid #bae6fd}.admin-upload-scope .btn-upload{width:100%;height:40px;border-radius:8px;border:none;background:var(--c-primary);color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;box-shadow:0 4px 6px -1px #2563eb33}.admin-upload-scope .btn-upload:hover:not(:disabled){background:var(--c-primary-hover);transform:translateY(-1px)}.admin-upload-scope .btn-upload:active{transform:scale(.98)}.admin-upload-scope .btn-upload:disabled{background:var(--c-text-muted);cursor:not-allowed;box-shadow:none;opacity:.7}.admin-upload-scope .video-preview-overlay{position:absolute;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.admin-upload-scope .video-preview-modal{position:relative;width:90%;height:90%;background:#000;border-radius:12px;overflow:hidden;display:flex;justify-content:center;align-items:center;box-shadow:0 20px 50px #00000080}.admin-upload-scope .video-preview-modal video{max-width:100%;max-height:100%}.admin-upload-scope .btn-close-video{position:absolute;top:16px;right:16px;background:#fff3;border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;z-index:60;display:flex;align-items:center;justify-content:center;transition:background .2s}.admin-upload-scope .btn-close-video:hover{background:#fff6}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;width:400px;max-width:100%;border-radius:16px;padding:24px;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column;max-height:90vh}.modal-content.large{width:600px;padding:0;overflow:hidden}.modal-header-row{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px;border-bottom:1px solid #f1f5f9;background:#fff}.modal-title-left{margin:0;font-size:18px;font-weight:700;color:#0f172a}.modal-subtitle-left{margin:4px 0 0;font-size:13px;color:#64748b}.btn-icon-close{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:6px;transition:all .2s}.btn-icon-close:hover{background:#f1f5f9;color:#ef4444}.modal-body-scroll{padding:24px;overflow-y:auto;max-height:calc(90vh - 70px)}.log-list-container{padding:16px 20px;background:#f8fafc;height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.empty-state{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8;font-size:14px;gap:10px}.log-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;transition:all .2s;box-shadow:0 1px 2px #00000008}.log-card:hover{border-color:#cbd5e1;box-shadow:0 4px 6px -2px #0000000d}.log-header{padding:12px 14px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.log-main{flex:1}.log-top{display:flex;align-items:center;gap:8px;margin-bottom:6px}.log-badge{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase}.log-badge.info{background:#eff6ff;color:#3b82f6}.log-badge.success{background:#f0fdf4;color:#16a34a}.log-badge.warning{background:#fffbeb;color:#b45309}.log-badge.error{background:#fef2f2;color:#ef4444}.log-time{font-size:11px;color:#94a3b8;font-family:monospace}.log-msg{margin:0;font-size:13px;color:#334155;line-height:1.4}.log-chevron{color:#cbd5e1;padding-top:2px}.log-details{background:#f8fafc;border-top:1px solid #f1f5f9;padding:10px 14px;overflow:hidden}.log-meta-grid{display:flex;flex-direction:column;gap:6px;font-size:12px}.meta-row{display:flex;gap:8px;color:#64748b}.meta-row span{width:50px}.meta-row b{color:#0f172a;font-weight:500;word-break:break-all}.log-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px;border:1px solid transparent}.log-badge.info{background:#eff6ff;color:#3b82f6;border-color:#dbeafe}.log-badge.success,.log-badge.complete{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.log-badge.warning{background:#fef9c3;color:#a16207;border-color:#fde047}.log-badge.error,.log-badge.failed{background:#fee2e2;color:#b91c1c;border-color:#fecaca}:root{--row-height: 80px;--bg-page: #f9fafb;--bg-card: #ffffff;--bg-header: #f8fafc;--border-soft: #e5e7eb;--border-row: #edf2f7;--text-muted: #9ca3af}*{box-sizing:border-box}.monitoring-page{height:100vh;display:flex;flex-direction:column;overflow:hidden;background-color:transparent}.monitoring-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-page)}.btn{font-size:12px;padding:6px 12px;border-radius:999px;border:none;cursor:pointer}.btn-ghost{padding:8px 16px;background:transparent;color:#64748b;border:none;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s}.btn-ghost:hover{background:#f1f5f9;color:#0f172a}.btn-primary{padding:8px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#1d4ed8}.btn-danger-modal{padding:8px 20px;background:#dc2626;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.btn-danger-modal:hover{background:#b91c1c}.toast-container{position:fixed;top:24px;right:24px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast-item{pointer-events:auto;min-width:300px;max-width:400px;background:#fff;padding:16px;border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d,0 0 0 1px #0000000d;display:flex;align-items:center;gap:12px;font-family:inherit;font-size:14px;font-weight:500;color:#1e293b;border-left:4px solid #cbd5e1;animation:toastSlideIn .35s cubic-bezier(.21,1.02,.7,1) forwards;opacity:0;transform:translate(100%)}.toast-item.success{border-left-color:#22c55e}.toast-item.success svg{color:#22c55e}.toast-item.error{border-left-color:#ef4444}.toast-item.error svg{color:#ef4444}.toast-item.warning{border-left-color:#f59e0b}.toast-item.warning svg{color:#f59e0b}@keyframes toastSlideIn{0%{opacity:0;transform:translate(120%)}to{opacity:1;transform:translate(0)}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999}.modal-content{background:#fff;width:400px;max-width:90%;border-radius:16px;padding:24px;box-shadow:0 20px 25px -5px #0000001a}.modal-header-center{text-align:center;padding:10px 0}.modal-icon-wrap{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 6px 12px #0000000d}.modal-icon-wrap.danger{background:#fee2e2;color:#dc2626;box-shadow:0 6px 12px #dc262626}.modal-icon-wrap.warning{background:#fff7ed;color:#f59e0b;box-shadow:0 6px 12px #f59e0b26}.modal-title{font-size:20px;margin:0 0 8px;color:#0f172a;font-weight:700}.modal-desc{color:#64748b;font-size:15px;line-height:1.5;margin:0}.modal-footer{display:flex;justify-content:center;gap:12px;margin-top:30px}.user-page{display:flex;flex-direction:column;height:100vh;background:#f1f5f9;overflow:hidden;padding:12px;gap:12px}.um-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:12px 18px;border-radius:14px;box-shadow:0 1px 3px #0000000d;flex-shrink:0}.um-title-group{display:flex;align-items:center;gap:16px}.btn-back{width:36px;height:36px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-back:hover{background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.um-title h1{font-size:20px;font-weight:700;color:#1e293b;margin:0}.um-title p{font-size:13px;color:#64748b;margin:2px 0 0}.um-stats{display:flex;gap:8px;margin-left:24px}.stat-pill{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:99px;font-size:12px;font-weight:600;color:#475569}.stat-pill b{color:#0f172a}.um-actions{display:flex;gap:12px;align-items:center}.um-search{position:relative;width:240px}.um-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#94a3b8;width:16px}.um-search input{width:100%;padding:9px 12px 9px 34px;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc;font-size:13px;outline:none;transition:all .2s}.um-search input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-add{display:flex;align-items:center;gap:8px;padding:9px 16px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #2563eb33;transition:transform .2s}.btn-add:hover{transform:translateY(-1px)}.um-grid{flex:1;background:#fff;border-radius:14px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;overflow:hidden}.um-row-header,.um-row{display:grid;grid-template-columns:minmax(200px,2fr) minmax(120px,1fr) minmax(150px,1.5fr) minmax(120px,1fr) 100px;align-items:center;padding:0 16px;gap:16px}.um-row-header{height:48px;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.um-body{overflow-y:auto;flex:1}.um-row{height:64px;border-bottom:1px solid #f1f5f9;transition:background .15s}.um-row:hover{background:#f8fafc}.cell-user{display:flex;align-items:center;gap:12px}.avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1)}.avatar.superadmin{background:linear-gradient(135deg,#ef4444,#b91c1c)}.avatar.admin{background:linear-gradient(135deg,#f59e0b,#d97706)}.avatar.staff{background:linear-gradient(135deg,#3b82f6,#2563eb)}.avatar.developer{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.user-info b{display:block;font-size:14px;color:#0f172a}.user-info span{font-size:12px;color:#64748b}.badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;width:fit-content}.badge.superadmin{background:#fee2e2;color:#991b1b}.badge.admin{background:#fef3c7;color:#92400e}.badge.staff{background:#dbeafe;color:#1e40af}.badge.developer{background:#f3e8ff;color:#6b21a8}.status-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500}.status-indicator.online{color:#16a34a}.status-indicator.offline{color:#94a3b8}.dot{width:8px;height:8px;border-radius:50%;background:currentColor}.cell-actions{display:flex;gap:8px;justify-content:flex-end}.btn-icon{width:32px;height:32px;border-radius:8px;border:1px solid transparent;background:transparent;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-icon:hover{background:#f1f5f9;color:#0f172a}.btn-icon.danger:hover{background:#fee2e2;color:#dc2626}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50}.modal-content{background:#fff;width:400px;border-radius:16px;padding:24px;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.modal-header h3{margin:0;font-size:18px;color:#0f172a}.modal-header p{margin:4px 0 0;font-size:13px;color:#64748b}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:6px}.form-group input,.form-group select{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #cbd5e1;font-size:14px;outline:none}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.btn-ghost{padding:8px 16px;background:transparent;color:#64748b;border:none;font-weight:500;cursor:pointer}.btn-ghost:hover{background:#f1f5f9;color:#0f172a;border-radius:8px}.btn-primary{padding:8px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.strength-meter{display:flex;gap:4px;margin-top:8px;height:4px}.bar{flex:1;background:#e2e8f0;border-radius:2px;transition:background .3s}.level-1 .bar:nth-child(1){background:#ef4444}.level-2 .bar:nth-child(-n+2){background:#f59e0b}.level-3 .bar:nth-child(-n+3){background:#22c55e}.strength-text{font-size:11px;margin-top:4px;text-align:right;display:block;font-weight:600}.audit-page{display:flex;flex-direction:column;height:100vh;background-color:#f8fafc;font-family:Inter,system-ui,-apple-system,sans-serif;color:#0f172a}.audit-header{height:56px;padding:0 24px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.title-block h1{font-size:16px;font-weight:700;margin:0;color:#0f172a;letter-spacing:-.01em}.title-block p{font-size:12px;color:#64748b;margin:0}.btn-back{width:32px;height:32px;border:1px solid #e2e8f0;background:#fff;border-radius:8px;display:grid;place-items:center;color:#64748b;cursor:pointer;transition:all .2s ease}.btn-back:hover{background:#f1f5f9;color:#0f172a;border-color:#cbd5e1}.btn-icon-text{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:12px;font-weight:500;color:#475569;cursor:pointer;transition:all .2s}.btn-icon-text:hover{background:#f8fafc;border-color:#cbd5e1;color:#0f172a}.audit-toolbar{height:50px;padding:0 24px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;flex-shrink:0}.toolbar-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%}.search-box{position:relative;width:260px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#94a3b8;width:14px}.search-box input{width:100%;height:32px;padding:0 10px 0 32px;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;color:#334155;outline:none;transition:border-color .2s}.search-box input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select-wrapper{position:relative;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:0 10px;height:32px;display:flex;align-items:center;min-width:140px}.select-icon{color:#94a3b8;margin-right:8px}.chevron-icon{position:absolute;right:10px;color:#94a3b8;pointer-events:none}.filter-select-wrapper select{border:none;background:transparent;width:100%;font-size:12px;color:#334155;outline:none;cursor:pointer;appearance:none;padding-right:20px}.date-range-picker{display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:0 10px;height:32px;gap:6px}.date-icon{color:#94a3b8}.date-range-picker input{border:none;background:transparent;font-size:12px;color:#334155;outline:none;font-family:inherit;width:95px;cursor:pointer}.date-sep{font-size:11px;color:#94a3b8;font-weight:500}.btn-clear{display:flex;align-items:center;gap:4px;border:none;background:#f1f5f9;padding:0 10px;border-radius:6px;font-size:11px;font-weight:600;color:#64748b;cursor:pointer;height:32px;margin-left:auto}.btn-clear:hover{background:#e2e8f0;color:#475569}.audit-content{flex:1;overflow:hidden;padding:12px 24px;display:flex;flex-direction:column}.table-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:auto;box-shadow:0 2px 4px -2px #00000008;display:flex;flex-direction:column;flex:1}.audit-table{width:100%;border-collapse:collapse}.audit-table th{position:sticky;top:0;background:#f8fafc;color:#64748b;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:14px 40px;border-bottom:1px solid #e2e8f0;z-index:10;text-align:left}.audit-table tbody{background:#fff}.audit-table tr{border-bottom:1px solid #f1f5f9}.audit-table tbody tr:last-child{border-bottom:none}.audit-table tbody tr:hover{background-color:#fcfcfc}.audit-table td{padding:14px 40px;vertical-align:top;font-size:13px;height:auto}.td-time{display:flex;flex-direction:column;gap:3px}.td-time .date{font-weight:600;color:#334155;font-feature-settings:"tnum"}.td-time .time{font-size:12px;color:#94a3b8;font-feature-settings:"tnum"}.user-profile{display:flex;align-items:center;gap:12px}.avatar-initial{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.role-dev{background:#f3e8ff;color:#7e22ce}.role-admin{background:#eff6ff;color:#2563eb}.user-meta{display:flex;flex-direction:column}.user-name{font-weight:500;color:#1e293b}.user-role{font-size:10px;color:#64748b;text-transform:uppercase;font-weight:700;letter-spacing:.02em}.td-action{vertical-align:top;padding-top:16px!important}.badge-action{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.badge-action.green{background:#dcfce7;color:#166534}.badge-action.red{background:#fee2e2;color:#991b1b}.badge-action.blue{background:#dbeafe;color:#1e40af}.badge-action.orange{background:#ffedd5;color:#9a3412}.badge-action.purple{background:#f3e8ff;color:#6b21a8}.badge-action.gray{background:#f1f5f9;color:#475569}.td-details{padding-top:12px!important;padding-bottom:12px!important}.detail-stack{display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;align-items:center}.detail-pill{display:inline-flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:3px;font-size:12px;max-width:100%;box-shadow:0 1px 2px #00000005}.pill-icon-box{width:20px;height:20px;background:#f8fafc;border-radius:4px;display:grid;place-items:center;color:#64748b;margin-right:8px}.pill-label{color:#94a3b8;font-weight:500;margin-right:6px;font-size:11px;text-transform:uppercase;letter-spacing:.02em}.pill-value{color:#334155;font-weight:500;padding-right:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.state-cell{padding:80px 0;text-align:center;color:#94a3b8;vertical-align:middle!important}.state-cell span{display:block;margin-top:12px;font-size:14px;font-weight:500}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;opacity:.6}.audit-footer{height:48px;padding:0 24px;background:#fff;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.pagination-info{font-size:12px;color:#64748b}.pagination-info b{color:#0f172a;font-weight:600}.pagination-actions{display:flex;align-items:center;gap:24px}.rows-per-page{display:flex;align-items:center;gap:8px;font-size:12px;color:#64748b}.rows-per-page select{border:1px solid #e2e8f0;border-radius:6px;padding:2px 4px;font-size:12px;color:#334155;outline:none;cursor:pointer;background:#fff}.page-controls{display:flex;align-items:center;gap:8px}.page-indicator{font-size:12px;font-weight:500;color:#334155;min-width:60px;text-align:center}.pg-btn{width:28px;height:28px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;display:grid;place-items:center;color:#64748b;cursor:pointer;transition:all .2s}.pg-btn:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.pg-btn:disabled{opacity:.5;cursor:default;background:#f8fafc}.spin{animation:spin 1s linear infinite}:root{--primary-color: #2563eb;--bg-color: #f1f5f9;--text-color: #334155;--border-color: #e2e8f0;--scrollbar-size: 6px;--scrollbar-radius: 999px;--scrollbar-track: transparent;--scrollbar-thumb: rgba(148, 163, 184, .35);--scrollbar-thumb-hover: rgba(148, 163, 184, .65);--scrollbar-thumb-active: rgba(100, 116, 139, .85)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0;height:100vh;color:var(--text-color);overflow-x:hidden;background-color:#f8fafc;background-image:radial-gradient(circle at 10% 20%,rgba(37,99,235,.2) 0%,transparent 40%),radial-gradient(circle at 90% 10%,rgba(139,92,246,.2) 0%,transparent 40%),radial-gradient(circle at 50% 50%,rgba(45,212,191,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(244,63,94,.1) 0%,transparent 40%);background-size:300% 300%;animation:fluidMesh 12s ease-in-out infinite alternate}@keyframes fluidMesh{0%{background-position:0% 0%}25%{background-position:50% 0%}50%{background-position:100% 50%}75%{background-position:50% 100%}to{background-position:0% 50%}}body:before{content:"";position:fixed;inset:0;z-index:-1;opacity:.3;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");pointer-events:none;mix-blend-mode:overlay}.App{height:100vh;display:flex;flex-direction:column}.app-header{display:none}.main-content{flex:1;padding:0}.component-wrapper{height:100%;border-radius:0;border:none;box-shadow:none;background:transparent}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#64748b}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}*::-webkit-scrollbar{width:var(--scrollbar-size);height:var(--scrollbar-size)}*::-webkit-scrollbar-track{background:var(--scrollbar-track)}*::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb);border-radius:var(--scrollbar-radius);transition:background-color .25s ease,opacity .25s ease;opacity:0}*:hover::-webkit-scrollbar-thumb,*:active::-webkit-scrollbar-thumb{opacity:1}*::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover)}*::-webkit-scrollbar-thumb:active{background-color:var(--scrollbar-thumb-active)}.scroll-area{scrollbar-width:thin}.scroll-area::-webkit-scrollbar{width:8px}.scroll-area::-webkit-scrollbar-thumb{background-color:#64748b99;opacity:1}html{scroll-behavior:smooth}.scroll-area{overscroll-behavior:contain}.loader-full{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--bg-color);z-index:9999}.loader-icon{width:48px;height:48px;color:var(--primary-color);animation:spin 1s linear infinite;margin-bottom:1rem}.loader-text{font-family:Inter,sans-serif;font-size:.95rem;font-weight:500;color:var(--text-color);opacity:.8;letter-spacing:.025em;animation:pulse 2s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.8}50%{opacity:.4}}
