*,*:before,*:after{box-sizing:border-box}body{margin:0;background:#fafafa;color:#000}:root{--font-body: "Sora", "Segoe UI", sans-serif;--font-mono: "IBM Plex Mono", "Menlo", monospace;--accent: #dc2626;--sidebar-w: 64px;--border: #e5e5e5}.app-layout{display:flex;height:100vh;overflow:hidden;font-family:var(--font-body)}.main-content{flex:1;display:flex;flex-direction:column;gap:28px;padding:40px 48px;overflow-y:auto;min-width:0}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:#000;display:flex;flex-direction:column;justify-content:space-between;padding:32px 0;align-items:center}.sidebar-top{display:flex;flex-direction:column;align-items:center;gap:32px;width:100%}.sidebar-logo{font-family:var(--font-body);font-size:16px;font-weight:700;color:#fafafa;letter-spacing:0;-webkit-user-select:none;user-select:none}.sidebar-nav{display:flex;flex-direction:column;align-items:center;gap:24px;width:100%}.sidebar-nav-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:#666;cursor:pointer;border-radius:8px;transition:color .15s,background .15s;padding:0}.sidebar-nav-btn:hover{color:#fafafa;background:#ffffff14}.sidebar-nav-btn.active{color:#fafafa}.sidebar-nav-btn.logout{color:#999}.sidebar-nav-btn.logout:hover{color:#fafafa;background:#dc262626}.sidebar-bottom{display:flex;flex-direction:column;align-items:center;gap:16px}.main-header{display:flex;justify-content:space-between;align-items:flex-start}.main-header-left{display:flex;flex-direction:column;gap:4px}.main-title{font-family:var(--font-body);font-size:28px;font-weight:600;letter-spacing:-1px;color:#000;margin:0}.main-subtitle{font-family:var(--font-mono);font-size:12px;color:#5e5e5e;margin:0}.main-header-right{display:flex;align-items:center;gap:12px}.search-box{display:flex;align-items:center;gap:8px;width:260px;height:36px;background:#fff;border:1px solid var(--border);padding:0 12px}.search-icon{color:#999;flex-shrink:0}.search-input{border:none;outline:none;background:transparent;font-family:var(--font-mono);font-size:12px;color:#333;width:100%}.search-input::placeholder{color:#999}.btn-upload{display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 16px;background:var(--accent);color:#fafafa;border:none;cursor:pointer;font-family:var(--font-body);font-size:12px;font-weight:500;transition:opacity .15s}.btn-upload:hover{opacity:.88}.btn-upload:disabled{opacity:.5;cursor:not-allowed}.btn-upload.btn-block{width:100%;justify-content:center;height:40px;font-size:14px;margin-top:4px}.btn-secondary{display:inline-flex;align-items:center;height:32px;padding:0 12px;background:#fff;color:#333;border:1px solid var(--border);cursor:pointer;font-family:var(--font-mono);font-size:12px;transition:background .15s}.btn-secondary:hover{background:#f5f5f5}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-sm{height:28px;font-size:11px;padding:0 10px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:#999;cursor:pointer;border-radius:4px;transition:color .1s,background .1s}.icon-btn:hover{color:#000;background:#f0f0f0}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.kpi-row{display:flex;width:100%;background:#fff;border:1px solid var(--border)}.kpi-item{flex:1;display:flex;flex-direction:column;gap:4px;padding:16px 20px}.kpi-divider{border-right:1px solid var(--border)}.kpi-label{font-family:var(--font-mono);font-size:11px;font-weight:500;color:#999;letter-spacing:1px;text-transform:uppercase}.kpi-value{font-family:var(--font-body);font-size:36px;font-weight:600;color:#000;letter-spacing:-2px;line-height:1}.kpi-danger{color:var(--accent)}.kpi-value-row{display:flex;align-items:flex-end;gap:8px;width:100%}.kpi-sub{font-family:var(--font-mono);font-size:11px;color:#5e5e5e;padding-bottom:5px}.kpi-ok{color:#22c55e;font-weight:600}.tab-bar{display:flex;border-bottom:1px solid var(--border);gap:0}.tab-btn{padding:12px 16px;border:none;background:transparent;font-family:var(--font-body);font-size:13px;font-weight:400;color:#5e5e5e;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s}.tab-btn:hover{color:#000}.tab-btn.tab-active{font-weight:600;color:#000;border-bottom-color:var(--accent)}.tab-content{flex:1;display:flex;flex-direction:column;gap:16px;min-height:0}.filter-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.filter-select-wrap{position:relative;display:flex;align-items:center}.filter-select{appearance:none;height:32px;padding:0 28px 0 12px;background:#fff;border:1px solid var(--border);font-family:var(--font-mono);font-size:12px;color:#5e5e5e;cursor:pointer;outline:none}.filter-select:focus{border-color:#aaa}.filter-chevron{position:absolute;right:8px;color:#999;pointer-events:none}.filter-date{gap:0}.filter-date-icon{position:absolute;left:10px;color:#999;pointer-events:none}.filter-select-date{padding-left:28px}.data-table-wrap{flex:1;display:flex;flex-direction:column;border:1px solid var(--border);background:#fff;min-height:0;overflow:hidden}.data-table-scroll{flex:1;overflow:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table-thead-row{background:#f5f5f5;height:40px;position:sticky;top:0;z-index:1}.data-table-th{text-align:left;padding:0 12px;font-family:var(--font-mono);font-size:11px;font-weight:600;color:#5e5e5e;letter-spacing:1px;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap}.data-table-th:first-child{padding-left:20px}.data-table-th:last-child{padding-right:20px}.data-table-row{height:44px}.data-table-row:hover{background:#fafafa}.data-table-td{padding:0 12px;border-bottom:1px solid var(--border);vertical-align:middle}.data-table-td:first-child{padding-left:20px}.data-table-td:last-child{padding-right:20px}.data-table-empty{text-align:center;padding:40px;color:#999;font-family:var(--font-mono);font-size:13px}.data-table-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-top:1px solid var(--border);background:#fafafa}.data-table-info{font-family:var(--font-mono);font-size:12px;color:#999}.data-table-pages{display:flex;align-items:center;gap:8px}.page-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);background:#fff;color:#555;cursor:pointer;padding:0;transition:background .1s}.page-btn:hover:not(:disabled){background:#f0f0f0}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-num{font-family:var(--font-mono);font-size:12px;color:#555;min-width:48px;text-align:center}.cell-primary{font-family:var(--font-body);font-size:13px;font-weight:500;color:#000}.cell-mono{font-family:var(--font-mono);font-size:13px;font-weight:500;color:#000}.cell-secondary{font-family:var(--font-mono);font-size:12px;color:#5e5e5e}.cell-muted{font-family:var(--font-mono);font-size:12px;color:#999}.cell-truncate{display:block;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-actions{display:flex;align-items:center;gap:4px}.badge{display:inline-flex;align-items:center;height:22px;padding:0 8px;font-family:var(--font-mono);font-size:11px;font-weight:500;white-space:nowrap}.badge-stable{background:#f0fdf4;color:#16a34a;border:1px solid #22c55e}.badge-beta{background:#fef3c7;color:#d97706;border:1px solid #f59e0b}.badge-active{background:#000;color:#fff;border:1px solid #000}.badge-inactive{background:transparent;color:#999;border:1px solid var(--border)}.badge-completed{background:#f0fdf4;color:#16a34a;border:1px solid #22c55e}.badge-failed{background:#fef2f2;color:var(--accent);border:1px solid #fca5a5}.badge-started{background:#eff6ff;color:#2563eb;border:1px solid #93c5fd}.badge-downloading{background:#f5f3ff;color:#7c3aed;border:1px solid #c4b5fd}.badge-applying{background:#fff7ed;color:#ea580c;border:1px solid #fdba74}.badge-waiting{background:#f0f9ff;color:#0284c7;border:1px solid #7dd3fc}.badge-cancelled{background:#f9fafb;color:#6b7280;border:1px solid #d1d5db}.form-label{display:flex;flex-direction:column;gap:4px;font-family:var(--font-mono);font-size:12px;color:#5e5e5e}.form-control{height:36px;padding:0 10px;border:1px solid var(--border);background:#fff;font-family:var(--font-mono);font-size:13px;color:#000;outline:none;width:100%}.form-control:focus{border-color:#999}textarea.form-control{height:auto;padding:8px 10px;resize:vertical}.form-error{font-family:var(--font-mono);font-size:12px;color:var(--accent);margin:0}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:100}.modal-box{background:#fff;width:min(520px,92vw);max-height:92vh;overflow-y:auto;padding:32px;display:flex;flex-direction:column;gap:24px}.modal-header{display:flex;justify-content:space-between;align-items:center}.modal-title{font-family:var(--font-body);font-size:18px;font-weight:600;margin:0}.modal-close{display:flex;align-items:center;border:none;background:transparent;color:#999;cursor:pointer;padding:4px}.modal-close:hover{color:#000}.modal-form{display:flex;flex-direction:column;gap:16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.products-tab{display:flex;flex-direction:column;gap:16px;flex:1}.products-tab-toolbar{display:flex;justify-content:flex-end}.inline-form{background:#fff;border:1px solid var(--border);padding:20px 24px;display:grid;grid-template-columns:1fr 1fr;gap:16px}.inline-form .form-label:last-of-type{grid-column:1 / -1}.inline-form button[type=submit]{grid-column:1 / -1;width:fit-content;justify-self:end}.inline-form .form-error{grid-column:1 / -1}.notices{display:flex;flex-direction:column;gap:8px}.notice-error{font-family:var(--font-mono);font-size:12px;color:var(--accent);margin:0;padding:10px 16px;background:#fef2f2;border:1px solid #fca5a5}.notice-apikey{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;color:#5e5e5e;padding:10px 16px;background:#fffbeb;border:1px solid #f59e0b;flex-wrap:wrap}.notice-apikey code{color:#000;word-break:break-all}.notice-dismiss{margin-left:auto;border:none;background:transparent;cursor:pointer;color:#999;font-size:14px;padding:2px 4px}.notice-dismiss:hover{color:#000}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fafafa;font-family:var(--font-body)}.login-card{width:min(420px,90vw);background:#fff;border:1px solid var(--border);padding:40px;display:flex;flex-direction:column;gap:16px}.login-logo{width:44px;height:44px;background:#000;color:#fafafa;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center}.login-title{font-size:22px;font-weight:600;margin:0}.login-sub{font-family:var(--font-mono);font-size:12px;color:#5e5e5e;margin:0}.login-form{display:flex;flex-direction:column;gap:14px}
