:root{--font-mono:system-ui,sans-serif;--font-size-xs:.7rem;--font-size-sm:.8rem;--font-size-base:.875rem;--font-size-md:.95rem;--font-size-lg:1.1rem;--font-size-xl:1.35rem;--font-size-2xl:1.75rem;--color-bg-primary:#fafafa;--color-bg-secondary:#fff;--color-bg-tertiary:#f5f5f5;--color-bg-hover:#f0f0f0;--color-bg-active:#e8e8e8;--color-text-primary:#1a1a1a;--color-text-secondary:#4a4a4a;--color-text-tertiary:#7a7a7a;--color-text-muted:#9a9a9a;--color-border:#e0e0e0;--color-border-light:#ececec;--color-border-focus:#2a2a2a;--color-accent:#2a2a2a;--color-accent-hover:#1a1a1a;--color-accent-light:#4a4a4a;--color-success:#5a8a5a;--color-success-bg:#e8f4e8;--color-warning:#f59e0b;--color-warning-hover:#d97706;--color-warning-bg:#fef3c7;--color-error:#ef4444;--color-error-hover:#dc2626;--color-error-bg:#fee2e2;--color-info:#4a7ac8;--color-info-bg:#e8f0fe;--color-status-running:#5a8a5a;--color-status-stopped:#ef4444;--color-status-pending:#f59e0b;--sidebar-width:220px;--topbar-height:56px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--height-control-sm:32px;--height-control:36px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 2px 4px #0000000f;--shadow-lg:0 4px 8px #00000014;--transition-fast:.15s ease;--transition-base:.2s ease}body.dark-theme{--color-bg-primary:#0a0a0a;--color-bg-secondary:#141414;--color-bg-tertiary:#1a1a1a;--color-bg-hover:#222;--color-bg-active:#2a2a2a;--color-text-primary:#fafafa;--color-text-secondary:#d0d0d0;--color-text-tertiary:#a0a0a0;--color-text-muted:#7a7a7a;--color-border:#2a2a2a;--color-border-light:#1f1f1f;--color-border-focus:#fafafa;--color-accent:#fafafa;--color-accent-hover:#fff;--color-accent-light:#d0d0d0;--color-success-bg:#1a2a1a;--color-warning-bg:#2a221a;--color-error-bg:#2a1a1a;--color-info-bg:#1a222a;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 2px 4px #0006;--shadow-lg:0 4px 8px #00000080}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-mono);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-base),color var(--transition-base);line-height:1.6}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background-color:var(--color-bg-secondary);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;display:flex}.sidebar-header{height:var(--topbar-height);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);align-items:center;gap:var(--spacing-sm);display:flex}.logo{font-size:var(--font-size-lg);color:var(--color-text-primary);letter-spacing:-.02em;font-weight:600}.sidebar-nav{padding:var(--spacing-sm);flex:1;overflow-y:auto}.nav-section{margin-bottom:var(--spacing-lg)}.nav-section-title{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);padding:var(--spacing-sm)var(--spacing-md);margin-bottom:var(--spacing-xs);font-weight:500}.nav-item{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)var(--spacing-md);color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);cursor:pointer;font-size:var(--font-size-sm);border:1px solid #0000;text-decoration:none;display:flex}.nav-item:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item.active{background-color:var(--color-bg-active);color:var(--color-text-primary);border-color:var(--color-border)}.nav-icon{flex-shrink:0;width:16px;height:16px}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border)}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:var(--topbar-height);background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);padding:0 var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.topbar-title{font-size:var(--font-size-lg);color:var(--color-text-primary);font-weight:500}.topbar-actions{align-items:center;gap:var(--spacing-md);display:flex}.content-area{padding:var(--spacing-lg);flex:1;overflow-y:auto}.btn,.btn-secondary,.btn-ghost{align-items:center;gap:var(--spacing-sm);padding:0 var(--spacing-md);height:var(--height-control);font-family:var(--font-mono);font-size:var(--font-size-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:500;text-decoration:none;display:inline-flex}.btn{color:var(--color-bg-primary);background-color:var(--color-accent)}.btn:hover{background-color:var(--color-accent-hover)}.btn:active{transform:translateY(1px)}.btn-secondary{color:var(--color-text-primary);border:1px solid var(--color-border);background-color:#0000}.btn-secondary:hover{background-color:var(--color-bg-hover);border-color:var(--color-text-tertiary)}.btn-secondary:active{transform:translateY(1px)}.btn-ghost{color:var(--color-text-secondary);background-color:#0000}.btn-ghost:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.btn-ghost:active{transform:translateY(1px)}.btn-sm,button.btn-sm{padding:0 var(--spacing-md);height:var(--height-control-sm);font-size:var(--font-size-xs);align-items:center;gap:var(--spacing-sm);font-family:var(--font-mono);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:500;text-decoration:none;display:inline-flex}.btn-sm.btn-secondary,button.btn-sm.btn-secondary{border:1px solid var(--color-border)}button.btn-sm:not(.btn-secondary,.btn-ghost,.btn-icon,.btn-warning,.btn-error,.btn-danger){color:var(--color-bg-primary);background-color:var(--color-accent)}button.btn-sm:not(.btn-secondary,.btn-ghost,.btn-icon,.btn-warning,.btn-error,.btn-danger):hover{background-color:var(--color-accent-hover)}button.btn-sm:not(.btn-secondary,.btn-ghost,.btn-icon,.btn-warning,.btn-error,.btn-danger):active{transform:translateY(1px)}.btn-warning,button.btn-sm.btn-warning{background-color:var(--color-warning);color:var(--color-bg-primary)}.btn-warning:hover,button.btn-sm.btn-warning:hover{background-color:var(--color-warning-hover)}.btn-warning:active,button.btn-sm.btn-warning:active{transform:translateY(1px)}.btn-error,.btn-danger,button.btn-sm.btn-error,button.btn-sm.btn-danger{background-color:var(--color-error);color:var(--color-bg-primary)}.btn-error:hover,.btn-danger:hover,button.btn-sm.btn-error:hover,button.btn-sm.btn-danger:hover{background-color:var(--color-error-hover)}.btn-error:active,.btn-danger:active,button.btn-sm.btn-error:active,button.btn-sm.btn-danger:active{transform:translateY(1px)}.btn-icon{padding:var(--spacing-sm);justify-content:center;width:32px;height:32px}.form-group{margin-bottom:var(--spacing-md)}.form-label,.form-group label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:var(--spacing-xs);font-weight:500;display:block}.form-input,.form-select,.form-control{width:100%;padding:var(--spacing-sm)var(--spacing-md);height:var(--height-control);font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast);box-sizing:border-box}textarea.form-control{padding:var(--spacing-sm)var(--spacing-md);resize:vertical;height:auto}.form-textarea{width:100%;padding:var(--spacing-sm)var(--spacing-md);font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast);resize:vertical;min-height:100px}.form-input:focus,.form-select:focus,.form-control:focus,.form-textarea:focus{border-color:var(--color-border-focus);background-color:var(--color-bg-secondary);outline:none}.card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);overflow:auto}.card-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--font-size-md);color:var(--color-text-primary);font-weight:500}.card-body{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.table{border-collapse:collapse;table-layout:auto;width:100%}.table thead{border-bottom:1px solid var(--color-border)}.table th{text-align:left;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);padding:var(--spacing-sm);font-weight:500}.table td{padding:var(--spacing-md)var(--spacing-sm);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.table tr:hover{background-color:var(--color-bg-hover)}.table-logs{table-layout:fixed}.table-logs td{text-overflow:ellipsis;white-space:nowrap;max-width:0;overflow:hidden}.badge{align-items:center;gap:var(--spacing-xs);padding:2px var(--spacing-sm);font-size:var(--font-size-xs);border-radius:var(--radius-sm);border:1px solid;font-weight:500;display:inline-flex}.badge-success{color:var(--color-success);background-color:var(--color-success-bg);border-color:var(--color-success)}.badge-error{color:var(--color-error);background-color:var(--color-error-bg);border-color:var(--color-error)}.badge-warning{color:var(--color-warning);background-color:var(--color-warning-bg);border-color:var(--color-warning)}.badge-info{color:var(--color-info);background-color:var(--color-info-bg);border-color:var(--color-info)}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-running{background-color:var(--color-status-running)}.status-stopped{background-color:var(--color-status-stopped)}.status-pending{background-color:var(--color-status-pending)}.code-block{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-md);font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-text-secondary);overflow-x:auto}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-content{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:90%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:var(--font-size-lg);margin:0;font-weight:500}.modal-close{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:1.5rem;transition:background-color .2s;display:flex}.modal-close:hover{background-color:var(--color-border)}.modal-title{font-size:var(--font-size-lg);font-weight:500}.modal-body{padding:var(--spacing-lg)}.modal-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);gap:var(--spacing-sm);justify-content:flex-end;display:flex}.toast{bottom:var(--spacing-lg);right:var(--spacing-lg);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-lg);z-index:2000;font-size:var(--font-size-sm);max-width:400px;position:fixed}.toast.success{border-color:var(--color-success)}.toast.error{border-color:var(--color-error)}.toast.warning{border-color:var(--color-warning)}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.hidden{display:none!important}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.grid{display:grid}.inline-flex{display:inline-flex}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-center{justify-content:center}@media (width>=768px){.justify-end{justify-content:flex-end}}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.gap-2xl{gap:var(--spacing-2xl)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.w-full{width:100%}.max-w-1200{max-width:1200px}.max-w-500{max-width:500px}.max-w-600{max-width:600px}.max-w-700{max-width:700px}.text-muted{color:var(--color-text-muted)}.text-center{text-align:center}@media (width>=768px){.text-right{text-align:right!important}}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.font-medium,.font-semibold{font-weight:500}.font-bold{font-weight:600}.m-0{margin:0}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.mb-2xl{margin-bottom:var(--spacing-2xl)}.mr-xs{margin-right:var(--spacing-xs)}.mr-sm{margin-right:var(--spacing-sm)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.p-2xl{padding:var(--spacing-2xl)}.pt-sm{padding-top:var(--spacing-sm)}.pb-sm{padding-bottom:var(--spacing-sm)}.pb-md{padding-bottom:var(--spacing-md)}.border{border:1px solid var(--color-border)}.border-light{border:1px solid var(--color-border-light)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.grid-auto-fill-300{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.grid-auto-fill-350{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));display:grid}.grid-auto-fill-350-mb-lg{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(350px,1fr));display:grid}.grid-auto-fit-300{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));display:grid}.overflow-y-auto{overflow-y:auto}.overflow-x-auto{overflow-x:auto}.bg-secondary{background-color:var(--color-bg-secondary)}.color-error{color:var(--color-error)}.color-info{color:var(--color-info)}.cursor-pointer{cursor:pointer}.no-underline{text-decoration:none}.underline{text-decoration:underline}.block{display:block}.word-break-all{word-break:break-all}.w-80{width:80px!important}.w-100{width:100px!important}.w-120{width:120px!important}.w-200{width:200px!important}.mx-auto{margin-left:auto;margin-right:auto}.my-2xl{margin-top:var(--spacing-2xl);margin-bottom:var(--spacing-2xl)}.mobile-menu-toggle{font-size:var(--font-size-lg);transition:transform var(--transition-base);display:none}.mobile-menu-toggle.open{transform:rotate(180deg)}@media (width<=768px){.mobile-menu-toggle{margin-right:var(--spacing-sm);display:flex}.topbar{padding-left:var(--spacing-md)}.sidebar{z-index:100;width:85%;transition:left var(--transition-base);position:fixed;top:0;bottom:0;left:-85%;box-shadow:2px 0 8px #00000026}.sidebar.open{left:0}.content-area{padding:var(--spacing-md)}}.auth-container{min-height:100vh;padding:var(--spacing-lg);background-color:var(--color-bg-primary);justify-content:center;align-items:center;display:flex}.auth-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;max-width:400px;padding:var(--spacing-2xl)}.auth-logo{font-size:var(--font-size-2xl);text-align:center;margin-bottom:var(--spacing-xl);color:var(--color-text-primary);font-weight:600}.auth-title{font-size:var(--font-size-xl);margin-bottom:var(--spacing-sm);text-align:center;font-weight:500}.auth-subtitle{color:var(--color-text-tertiary);text-align:center;margin-bottom:var(--spacing-xl);font-size:var(--font-size-sm)}