@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #0a0a0f;--bg-subtle: #0f1019;--surface: #14151f;--surface-hover: #1a1b28;--surface-raised: #1e1f2e;--border: #242536;--border-light: #2e3045;--primary: #7c5cfc;--primary-hover: #6a4ce8;--primary-glow: rgba(124, 92, 252, .15);--primary-soft: rgba(124, 92, 252, .08);--accent: #00d4aa;--accent-soft: rgba(0, 212, 170, .1);--text: #eeeef0;--text-secondary: #b0b0c0;--text-muted: #6b6b80;--success: #00d47e;--success-soft: rgba(0, 212, 126, .1);--danger: #ff4d6a;--danger-soft: rgba(255, 77, 106, .1);--warning: #ffb020;--warning-soft: rgba(255, 176, 32, .1);--gradient-primary: linear-gradient(135deg, #7c5cfc 0%, #00d4aa 100%);--gradient-bg: linear-gradient(180deg, #0f1019 0%, #0a0a0f 100%);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 16px rgba(0,0,0,.3);--shadow-lg: 0 8px 32px rgba(0,0,0,.4);--shadow-glow: 0 0 20px rgba(124, 92, 252, .1);--radius: 10px;--radius-lg: 16px;--radius-xl: 20px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background:var(--primary);color:#fff}.app-layout{display:flex;min-height:100vh;background:var(--bg)}.main-content{flex:1;overflow-y:auto;height:100vh;padding:28px 32px 60px;background:var(--gradient-bg);min-width:0}.sidebar{width:270px;min-width:270px;height:100vh;position:sticky;top:0;display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;z-index:50}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:22px 20px 18px;border-bottom:1px solid var(--border)}.sidebar-brand .brand-icon{width:36px;height:36px;border-radius:10px;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:#fff;flex-shrink:0}.brand-name{font-size:15px;font-weight:700;letter-spacing:-.3px}.brand-sub{font-size:11px;color:var(--text-muted);font-weight:400}.sidebar-new-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin:16px 16px 0;padding:10px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #7c5cfc4d}.sidebar-new-btn:hover{background:var(--primary-hover);box-shadow:0 4px 16px #7c5cfc66;transform:translateY(-1px)}.sidebar-new-btn span{font-size:16px;font-weight:400}.sidebar-form{padding:12px 16px;border-bottom:1px solid var(--border)}.sidebar-form input{width:100%;padding:9px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;font-family:inherit;outline:none;margin-bottom:8px;transition:border-color .2s}.sidebar-form input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}.sidebar-form-actions{display:flex;gap:6px}.sidebar-hint{font-size:11px;color:var(--warning);margin-top:6px}.sidebar-error{font-size:11px;color:var(--danger);margin-top:6px}.sidebar-nav{padding:12px 10px 0}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s}.sidebar-nav-item:hover{background:var(--surface-hover);color:var(--text)}.nav-icon{font-size:15px}.sidebar-section{padding:4px 10px;margin-top:8px}.sidebar-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:8px 12px 6px}.sidebar-task-list{max-height:calc(100vh - 480px);overflow-y:auto}.sidebar-task{padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .15s;margin-bottom:2px}.sidebar-task:hover{background:var(--surface-hover)}.sidebar-task.selected{background:var(--primary-soft);border:1px solid rgba(124,92,252,.2)}.sidebar-task.running{border:1px solid rgba(124,92,252,.25);background:linear-gradient(135deg,var(--surface-hover) 0%,rgba(124,92,252,.05) 100%)}.sidebar-task-row{display:flex;align-items:center;gap:8px}.sidebar-task-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0}.sidebar-task-dot.pulse{animation:dot-pulse 1.5s ease infinite}@keyframes dot-pulse{0%,to{opacity:1;box-shadow:0 0 #7c5cfc66}50%{opacity:.7;box-shadow:0 0 0 6px #7c5cfc00}}.sidebar-task-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.sidebar-task-meta{font-size:11px;color:var(--text-muted);margin-top:3px;padding-left:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-cancel-btn{display:block;width:100%;margin-top:8px;padding:5px;background:var(--danger-soft);border:1px solid rgba(255,77,106,.2);border-radius:6px;color:var(--danger);font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.sidebar-cancel-btn:hover{background:var(--danger);color:#fff}.sidebar-del-btn{background:transparent;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;padding:2px 4px;border-radius:4px;opacity:0;transition:all .15s;flex-shrink:0}.sidebar-task:hover .sidebar-del-btn{opacity:1}.sidebar-del-btn:hover{color:var(--danger);background:var(--danger-soft)}.si{width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}.si-ok{background:var(--success-soft);color:var(--success)}.si-fail{background:var(--danger-soft);color:var(--danger)}.si-warn{background:var(--warning-soft);color:var(--warning)}.sidebar-footer{margin-top:auto;padding:16px;border-top:1px solid var(--border)}.sidebar-logout{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-muted);font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s}.sidebar-logout:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-soft)}.page{width:100%}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px}.page-title{font-size:24px;font-weight:700;letter-spacing:-.5px}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:32px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 20px;transition:all .2s}.stat-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-value{font-size:28px;font-weight:700;letter-spacing:-1px;margin-bottom:4px}.stat-label{font-size:12px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-running .stat-value{color:var(--primary)}.stat-success .stat-value{color:var(--success)}.stat-danger .stat-value{color:var(--danger)}.stat-accent .stat-value{color:var(--accent)}.recent-section{margin-top:8px}.section-title{font-size:15px;font-weight:600;margin-bottom:14px}.recent-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.recent-table{width:100%;border-collapse:collapse}.recent-table th{text-align:left;padding:12px 16px;font-size:11px;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-subtle)}.recent-table td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--border)}.recent-table tbody tr:last-child td{border-bottom:none}.clickable-row{cursor:pointer;transition:background .1s}.clickable-row:hover{background:var(--surface-hover)}.fw-500{font-weight:500}.detail-info-bar{display:flex;align-items:center;gap:20px;padding:16px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px}.login-wrapper{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--gradient-bg);position:relative;overflow:hidden}.login-wrapper:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,var(--primary-glow) 0%,transparent 70%);top:30%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.login-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px 40px;width:400px;position:relative;box-shadow:var(--shadow-lg),var(--shadow-glow)}.login-logo{width:48px;height:48px;border-radius:14px;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;margin:0 auto 20px}.login-box h2{margin-bottom:6px;font-size:22px;font-weight:700;text-align:center;letter-spacing:-.5px}.login-subtitle{text-align:center;font-size:13px;color:var(--text-muted);margin-bottom:32px}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:7px;font-size:13px;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group select{width:100%;padding:11px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:all .2s}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.form-group input::placeholder{color:var(--text-muted)}.btn{padding:10px 20px;border:none;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn-primary{background:var(--primary);color:#fff;width:100%;box-shadow:0 2px 8px #7c5cfc4d}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 16px #7c5cfc66;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 8px #ff4d6a40}.btn-danger:hover{opacity:.9;box-shadow:0 4px 12px #ff4d6a59}.btn-sm{padding:7px 14px;font-size:12px;border-radius:8px}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.btn-success{background:var(--accent);color:#0a0a0f;font-weight:600;box-shadow:0 2px 8px #00d4aa40}.btn-success:hover{opacity:.9}.error-msg{color:var(--danger);font-size:13px;margin-top:10px;text-align:center;background:var(--danger-soft);padding:8px 12px;border-radius:8px}.page-section{margin-top:32px;margin-bottom:20px}.page-section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;margin-bottom:14px;transition:all .2s}.card:hover{border-color:var(--border-light)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.new-task-section{margin-top:28px;margin-bottom:10px}.new-task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;position:relative;overflow:hidden}.new-task-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-primary)}.new-task-card h3{font-size:15px;font-weight:600;margin-bottom:4px}.new-task-card p{font-size:13px;color:var(--text-muted);margin-bottom:18px}.new-task-form{display:flex;gap:10px}.new-task-form input{flex:1;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:all .2s}.new-task-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.new-task-form input::placeholder{color:var(--text-muted)}.new-task-form input:disabled{opacity:.5}.new-task-form .btn{min-width:130px;white-space:nowrap;flex-shrink:0}.progress-card{border:1px solid rgba(124,92,252,.3);background:linear-gradient(135deg,var(--surface) 0%,rgba(124,92,252,.03) 100%);position:relative;overflow:hidden}.progress-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-primary)}.progress-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.progress-header-left{display:flex;align-items:center;gap:12px}.progress-category{font-size:16px;font-weight:600;letter-spacing:-.3px}.progress-bar-container{background:var(--bg);border-radius:100px;overflow:hidden;height:6px;margin:14px 0 10px}.progress-bar{height:100%;background:var(--gradient-primary);border-radius:100px;transition:width .4s ease;position:relative}.progress-bar:after{content:"";position:absolute;right:0;top:0;width:30px;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3));animation:progress-shine 1.5s ease infinite}@keyframes progress-shine{0%{opacity:0}50%{opacity:1}to{opacity:0}}.progress-footer{display:flex;justify-content:space-between;align-items:center}.progress-text{font-size:13px;color:var(--text-secondary)}.progress-percent{font-size:13px;font-weight:600;color:var(--primary)}.progress-phase{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:4px}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:100px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-running{background:var(--primary-soft);color:var(--primary);border:1px solid rgba(124,92,252,.2)}.badge-completed{background:var(--success-soft);color:var(--success);border:1px solid rgba(0,212,126,.2)}.badge-failed{background:var(--danger-soft);color:var(--danger);border:1px solid rgba(255,77,106,.2)}.badge-cancelled{background:var(--warning-soft);color:var(--warning);border:1px solid rgba(255,176,32,.2)}.task-item{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;margin-bottom:8px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all .15s}.task-item:hover{border-color:var(--border-light);background:var(--surface-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.task-item:last-child{margin-bottom:0}.task-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.task-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.task-icon-completed{background:var(--success-soft);color:var(--success)}.task-icon-failed{background:var(--danger-soft);color:var(--danger)}.task-icon-cancelled{background:var(--warning-soft);color:var(--warning)}.task-details{min-width:0}.task-details h3{font-size:14px;font-weight:600;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-details p{font-size:12px;color:var(--text-muted)}.task-meta{font-size:12px;color:var(--text-muted);text-align:right;white-space:nowrap}.task-actions{display:flex;gap:8px;align-items:center;margin-left:16px}.product-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.product-table{width:100%;border-collapse:collapse;table-layout:auto}.product-table th{text-align:left;padding:16px 18px;font-size:13px;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-subtle);white-space:nowrap}.product-table td{padding:14px 18px;font-size:15px;border-bottom:1px solid var(--border);vertical-align:middle}.product-table tbody tr{transition:background .1s}.product-table tbody tr:hover{background:var(--surface-hover)}.product-table tbody tr:last-child td{border-bottom:none}.product-img{width:120px;height:120px;border-radius:10px;object-fit:cover;border:1px solid var(--border)}.product-title{font-weight:500;font-size:15px;white-space:normal;word-break:break-word}.product-artist{color:var(--text-secondary);font-size:15px}.product-price{font-weight:600;color:var(--accent);font-size:16px}.product-link{color:var(--primary);text-decoration:none;font-size:14px;display:inline-flex;align-items:center;gap:3px;transition:color .15s}.product-link:hover{color:var(--primary-hover)}.detail-images-inline{display:flex;gap:6px;flex-wrap:wrap}.detail-img-thumb{width:100px;height:100px;border-radius:8px;object-fit:cover;border:1px solid var(--border);cursor:pointer;transition:all .15s}.detail-img-thumb:hover{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow);transform:scale(1.05)}.pagination{display:flex;justify-content:center;align-items:center;gap:4px;margin:16px 0;padding:12px 0;flex-wrap:wrap}.pagination button{padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-size:13px;font-family:inherit;transition:all .15s;min-width:38px;text-align:center}.pagination button:hover:not(:disabled):not(.pg-active){border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}.pagination button:disabled{opacity:.3;cursor:not-allowed}.pagination button.pg-active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600;box-shadow:0 2px 8px #7c5cfc4d}.pagination span{font-size:13px;color:var(--text-muted);padding:0 10px}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px}.toolbar-search{display:flex;gap:8px}.toolbar input{padding:9px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:13px;font-family:inherit;outline:none;width:320px;transition:all .2s}.toolbar input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.toolbar-info{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.toolbar-info strong{color:var(--text-secondary);font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadein .15s ease}@keyframes fadein{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;max-width:700px;width:92%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideup .2s ease}@keyframes slideup{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h3{margin-bottom:20px;font-size:16px;font-weight:600}.modal-images{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.modal-images img{width:100%;border-radius:var(--radius);border:1px solid var(--border)}.modal-close{margin-top:20px;display:flex;justify-content:flex-end}.new-task-page-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;max-width:600px;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.new-task-page-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}.new-task-page-form{display:flex;flex-direction:column;gap:16px}.new-task-page-form label{font-size:14px;font-weight:600;color:var(--text-secondary)}.new-task-page-form input{padding:14px 18px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:15px;font-family:inherit;outline:none;transition:all .2s}.new-task-page-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.new-task-page-form input::placeholder{color:var(--text-muted)}.new-task-hint{font-size:12px;color:var(--text-muted);margin-top:-8px}.btn-lg{padding:14px 28px;font-size:16px;border-radius:var(--radius)}.empty-state{text-align:center;padding:80px 20px;color:var(--text-muted)}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.3}.empty-state h3{margin-bottom:8px;font-size:16px;font-weight:600;color:var(--text-secondary)}.empty-state p{font-size:13px;max-width:320px;margin:0 auto;line-height:1.6}.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}.spinner-lg{width:24px;height:24px;border-width:2.5px}@keyframes spin{to{transform:rotate(360deg)}}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);text-decoration:none;font-size:13px;margin-bottom:20px;padding:6px 0;transition:color .15s}.back-link:hover{color:var(--text)}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.detail-header-left{display:flex;align-items:center;gap:14px}.detail-header-left h2{font-size:20px;font-weight:700;letter-spacing:-.3px}.detail-stats{display:flex;gap:24px;margin-top:4px}.detail-stat{font-size:13px;color:var(--text-muted)}.detail-stat strong{color:var(--text);font-weight:600}.flex-between{display:flex;justify-content:space-between;align-items:center}.text-muted{color:var(--text-muted)}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mb-16{margin-bottom:16px}.gap-8{gap:8px}
