:root{--color-primary: #0073bb;--color-primary-hover: #005a92;--color-primary-light: rgba(0, 115, 187, .1);--color-success: #1d8102;--color-warning: #ff9900;--color-error: #d13212;--color-gray-50: #fafafa;--color-gray-100: #f2f3f3;--color-gray-200: #e9ebed;--color-gray-300: #d5dbdb;--color-gray-400: #aab7b8;--color-gray-500: #879596;--color-gray-600: #687078;--color-gray-700: #545b64;--color-gray-800: #232f3e;--color-gray-900: #16191f;--color-white: #ffffff;--color-background: var(--color-gray-100);--color-surface: var(--color-white);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Fira Mono", "Droid Sans Mono", monospace;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15);--header-height: 56px;--sidebar-width: 260px;--sidebar-collapsed-width: 60px;--task-panel-width: 320px}@media (prefers-color-scheme: dark){:root{--color-gray-50: #0d1117;--color-gray-100: #161b22;--color-gray-200: #21262d;--color-gray-300: #30363d;--color-gray-400: #484f58;--color-gray-500: #6e7681;--color-gray-600: #8b949e;--color-gray-700: #b1bac4;--color-gray-800: #c9d1d9;--color-gray-900: #f0f6fc;--color-white: #0d1117;--color-background: var(--color-gray-100);--color-surface: var(--color-gray-200);--color-primary: #58a6ff;--color-primary-hover: #79b8ff;--color-primary-light: rgba(88, 166, 255, .15);--color-success: #3fb950;--color-warning: #d29922;--color-error: #f85149}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:14px;line-height:1.5;color:var(--color-gray-900);background-color:var(--color-background)}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-gray-900)}h1{font-size:24px}h2{font-size:20px}h3{font-size:16px}h4{font-size:14px}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}code,pre{font-family:var(--font-mono);font-size:13px}code{background-color:var(--color-gray-100);padding:2px 6px;border-radius:var(--radius-sm)}pre{background-color:var(--color-gray-100);padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto}.app-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1;overflow:hidden}.content-area{flex:1;overflow:auto;padding:var(--spacing-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:8px 16px;font-size:13px;font-weight:500;line-height:1;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:4px 10px;font-size:12px}.btn-lg{padding:12px 24px;font-size:14px}.btn-primary{background-color:var(--color-primary);color:var(--color-white)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-gray-200);color:var(--color-gray-900)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-300)}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#b82a0e}.btn-warning{background-color:var(--color-warning);color:var(--color-gray-900)}.btn-warning:hover:not(:disabled){background-color:#e68a00}.btn-ghost{background-color:transparent;color:var(--color-gray-600)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-gray-900)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],select,textarea{width:100%;padding:8px 12px;font-size:14px;font-family:inherit;color:var(--color-gray-900);background-color:var(--color-surface);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}input:disabled,select:disabled,textarea:disabled{background-color:var(--color-gray-100);cursor:not-allowed}input[type=checkbox],input[type=radio]{width:16px;height:16px;cursor:pointer}label{display:block;margin-bottom:var(--spacing-xs);font-size:13px;font-weight:500;color:var(--color-gray-700)}.form-group{margin-bottom:var(--spacing-md)}.form-row{display:flex;gap:var(--spacing-md);align-items:flex-end}table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-gray-200)}th{font-weight:600;color:var(--color-gray-600);background-color:var(--color-gray-100);position:sticky;top:0;z-index:1}tbody tr:hover{background-color:var(--color-gray-50)}tbody tr.selected{background-color:var(--color-primary-light)}.status-badge{display:inline-block;padding:3px 8px;font-size:11px;font-weight:500;border-radius:var(--radius-full);text-transform:capitalize}.status-running,.status-available,.status-active{background-color:#1d810226;color:var(--color-success)}.status-pending,.status-creating,.status-modifying{background-color:#ff990026;color:var(--color-warning)}.status-stopped,.status-stopping,.status-terminated{background-color:var(--color-gray-200);color:var(--color-gray-600)}.status-error,.status-failed,.status-deleting{background-color:#d1321226;color:var(--color-error)}.loading-spinner{width:20px;height:20px;border:2px solid var(--color-gray-300);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-sm{width:14px;height:14px}.loading-spinner-lg{width:32px;height:32px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);color:var(--color-gray-600)}.error-banner{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:#d132121a;border:1px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error);font-size:13px}.error-message{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:#d132121a;border-radius:var(--radius-sm);color:var(--color-error);font-size:13px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--color-gray-600);text-align:center}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-gray-600)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:600}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}@media (max-width: 1280px){:root{--sidebar-width: 200px;--task-panel-width: 280px}.hide-on-small{display:none}}@media (max-width: 1024px){.sidebar{position:fixed;left:0;top:var(--header-height);bottom:0;z-index:50;transform:translate(-100%);transition:transform .2s}.sidebar.open{transform:translate(0)}.task-panel{position:fixed;right:0;top:var(--header-height);bottom:0;z-index:50;transform:translate(100%);transition:transform .2s}.task-panel.open{transform:translate(0)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--color-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:var(--color-gray-400)}*{scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.animate-fade-in{animation:fadeIn .2s ease-out}.animate-slide-in{animation:slideIn .2s ease-out}.animate-pulse{animation:pulse 1s ease-in-out infinite}
