@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{color-scheme:light;--bg: #f8fafc;--bg-surface: #ffffff;--bg-soft: rgba(51, 65, 85, .03);--text: #1e293b;--muted: #64748b;--primary: #166534;--primary-strong: #15803d;--primary-ghost: rgba(22, 101, 52, .12);--accent: #7c3aed;--border: rgba(51, 65, 85, .08);--card-border: rgba(51, 65, 85, .05);--shadow: 0 20px 40px rgba(0, 0, 0, .08);--shadow-soft: 0 12px 28px rgba(0, 0, 0, .06);--table-head: rgba(51, 65, 85, .03);--table-row: rgba(255, 255, 255, .96);--badge-running-bg: rgba(22, 163, 74, .12);--badge-running-text: #15803d;--badge-stopped-bg: rgba(239, 68, 68, .12);--badge-stopped-text: #dc2626;--error-bg: rgba(239, 68, 68, .12);--error-text: #dc2626;--success-bg: rgba(22, 163, 74, .12);--success-text: #15803d;--input-bg: #f1f5f9;--input-border: rgba(51, 65, 85, .12);--log-bg: #0f172a;--log-text: #e2e8f0;--glow-1: rgba(22, 101, 52, .08);--glow-2: rgba(124, 58, 237, .06)}:root[data-theme=dark]{color-scheme:dark;--bg: #0f172a;--bg-surface: #1e293b;--bg-soft: rgba(148, 163, 184, .06);--text: #f8fafc;--muted: #cbd5e1;--primary: #34d399;--primary-strong: #10b981;--primary-ghost: rgba(52, 211, 153, .12);--accent: #a78bfa;--border: rgba(148, 163, 184, .12);--card-border: rgba(148, 163, 184, .08);--shadow: 0 20px 40px rgba(0, 0, 0, .4);--shadow-soft: 0 12px 28px rgba(0, 0, 0, .3);--table-head: rgba(148, 163, 184, .06);--table-row: rgba(30, 41, 59, .92);--badge-running-bg: rgba(52, 211, 153, .12);--badge-running-text: #34d399;--badge-stopped-bg: rgba(248, 113, 113, .12);--badge-stopped-text: #fca5a5;--error-bg: rgba(248, 113, 113, .12);--error-text: #fca5a5;--success-bg: rgba(52, 211, 153, .12);--success-text: #34d399;--input-bg: rgba(30, 41, 59, .9);--input-border: rgba(148, 163, 184, .18);--log-bg: #0b1220;--log-text: #e2e8f0;--glow-1: rgba(52, 211, 153, .08);--glow-2: rgba(167, 139, 250, .06)}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Space Grotesk,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:radial-gradient(circle at 15% 18%,var(--glow-1),transparent 55%),radial-gradient(circle at 85% 0%,var(--glow-2),transparent 45%),var(--bg);color:var(--text);transition:background .3s ease,color .3s ease;font-size:16px;line-height:1.6;letter-spacing:.01em;animation:pageFadeIn .6s ease-out}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card{animation:cardFadeIn .4s ease-out}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card:nth-child(1){animation-delay:.1s}.card:nth-child(2){animation-delay:.2s}.btn{overflow:hidden;position:relative}.btn:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:active:after{width:300px;height:300px}input[type=text]:focus,input[type=password]:focus{animation:inputFocus .2s ease}@keyframes inputFocus{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.status-dot{animation:statusPulse 2s infinite ease-in-out}@keyframes statusPulse{0%,to{box-shadow:0 0 0 4px var(--primary-ghost),0 0 12px #16653466;opacity:1}50%{box-shadow:0 0 0 6px var(--primary-ghost),0 0 20px #16653499;opacity:.8}}.badge{transition:all .2s ease;cursor:pointer}.badge:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000001f}.modal-backdrop{animation:modalBackdropFade .3s ease-out}@keyframes modalBackdropFade{0%{opacity:0}to{opacity:1}}.modal{animation:modalSlideIn .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.log-viewer::-webkit-scrollbar{width:8px;height:8px}.log-viewer::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.log-viewer::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px;transition:background .2s ease}.log-viewer::-webkit-scrollbar-thumb:hover{background:#ffffff4d}a,button,input,select,textarea,.badge,.status-dot{transition:all .2s ease}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.error,.success{animation:messageFadeIn .4s ease-out}@keyframes messageFadeIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.3;letter-spacing:-.02em}h1{font-size:2.5rem;font-weight:700}h2{font-size:1.875rem;font-weight:700}h3{font-size:1.5rem}h4{font-size:1.25rem}p{margin:0;line-height:1.6;letter-spacing:.01em}.page{max-width:1280px;margin:0 auto;padding:48px 32px 96px}.header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;padding:28px 32px;border-radius:20px;background:var(--bg-surface);border:1px solid var(--card-border);box-shadow:var(--shadow-soft);margin-bottom:40px}.title-group{display:flex;flex-direction:column;gap:4px}.title{font-size:2rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.subtitle{font-size:13px;color:var(--muted)}.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.status-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--border);font-size:12px;font-weight:600}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px var(--primary-ghost)}.btn{border:1px solid transparent;background:linear-gradient(135deg,var(--primary),var(--primary-strong));color:#fff;padding:10px 20px;border-radius:12px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;box-shadow:0 8px 20px #16653433;text-transform:none;letter-spacing:.01em}.btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px #1665344d}.btn:active{transform:translateY(0);box-shadow:0 6px 16px #16653440}.btn.secondary{background:var(--bg-surface);color:var(--text);border-color:var(--border);box-shadow:0 4px 12px #0000000a}.btn.secondary:hover{background:var(--bg-soft);transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.btn.secondary:active{transform:translateY(0);box-shadow:0 4px 12px #0000000a}.btn.warn{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 8px 20px #dc262633}.btn.warn:hover{box-shadow:0 12px 28px #dc26264d}.btn.warn:active{box-shadow:0 6px 16px #dc262640}.btn.ghost{background:transparent;color:var(--text);border-color:var(--border);box-shadow:none}.btn.ghost:hover{background:var(--bg-soft);transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn:focus{outline:none;box-shadow:0 0 0 3px var(--primary-ghost)}.card{background:var(--bg-surface);border-radius:20px;padding:32px;border:1px solid var(--card-border);box-shadow:var(--shadow);margin-bottom:32px;transition:transform .2s ease,box-shadow .2s ease}.card:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}.card-header{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid var(--border)}.card-header h2{margin:0 0 8px;font-size:1.5rem;font-weight:700}.status-banner{background:var(--bg-surface);border:1px solid var(--border);padding:12px 16px;border-radius:12px;box-shadow:var(--shadow-soft);margin-bottom:18px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:separate;border-spacing:0 12px;font-size:14px;line-height:1.6}th,td{text-align:left;padding:16px 20px;vertical-align:middle;letter-spacing:.01em}thead th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding-bottom:12px;font-weight:600;line-height:1.4;background:transparent;border:none}tbody td{background:var(--table-row);border:1px solid var(--card-border);transition:all .2s ease}tbody td:first-child{border-radius:12px 0 0 12px}tbody td:last-child{border-radius:0 12px 12px 0}tbody tr:hover td{background:var(--bg-soft);box-shadow:0 2px 8px #0000000a}tbody tr{transition:all .2s ease}tbody tr:hover{transform:translateY(-1px)}.badge{display:inline-flex;align-items:center;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;transition:all .2s ease;letter-spacing:.01em}.badge:before{content:"";width:6px;height:6px;border-radius:50%;margin-right:6px;animation:pulse 2s infinite}.badge.running{background:var(--badge-running-bg);color:var(--badge-running-text)}.badge.running:before{background:var(--badge-running-text)}.badge.stopped{background:var(--badge-stopped-bg);color:var(--badge-stopped-text)}.badge.stopped:before{background:var(--badge-stopped-text);animation:none}.muted{color:var(--muted);font-size:12px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}label{display:block;font-weight:600;margin-bottom:6px}input[type=text],input[type=password]{width:100%;padding:12px 16px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);transition:all .2s ease;font-size:14px;letter-spacing:.01em;font-family:inherit}input[type=text]:hover,input[type=password]:hover{border-color:var(--primary)}input[type=text]:focus,input[type=password]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ghost);background:var(--bg-surface)}input[type=checkbox]{accent-color:var(--primary)}.checkbox-row{display:flex;align-items:center;gap:8px;margin-top:6px}.form-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.error{background:var(--error-bg);color:var(--error-text);padding:10px 12px;border-radius:10px;margin-bottom:12px;border:1px solid var(--border)}.success{background:var(--success-bg);color:var(--success-text);padding:10px 12px;border-radius:10px;margin-bottom:12px;border:1px solid var(--border)}.login-wrap{display:flex;justify-content:center;padding:40px 0}.login-card{max-width:420px;width:100%}.login-header{font-size:22px;font-weight:700;margin-bottom:6px}.login-grid{margin-top:16px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080d17b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-surface);border-radius:20px;width:min(1000px,100%);max-height:90vh;display:flex;flex-direction:column;border:1px solid var(--card-border);box-shadow:0 24px 60px #0000004d;animation:slideUp .2s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 28px;border-bottom:1px solid var(--border)}.modal-body{padding:0 28px 28px;overflow:auto}.log-viewer{background:var(--log-bg);color:var(--log-text);padding:20px;border-radius:14px;font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;line-height:1.7;white-space:pre-wrap;min-height:300px;max-height:60vh;overflow:auto;border:1px solid rgba(255,255,255,.08);transition:all .2s ease}.log-viewer:hover{box-shadow:inset 0 0 0 1px #ffffff1f}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.loading{position:relative;overflow:hidden}.loading:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 1.5s infinite}input[type=text]:focus,input[type=password]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ghost),0 4px 12px #16653426;background:var(--bg-surface);transform:translateY(-1px)}input[type=checkbox]{width:18px;height:18px;border-radius:4px;cursor:pointer;transition:all .2s ease}input[type=checkbox]:hover{transform:scale(1.1)}.checkbox-row{cursor:pointer;transition:all .2s ease;padding:6px 0}.checkbox-row:hover{color:var(--primary)}tbody tr{position:relative}tbody tr:hover{transform:translateY(-2px)}tbody tr:hover td{box-shadow:0 4px 16px #00000014}.btn{position:relative;overflow:hidden;z-index:1}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .3s ease;z-index:-1}.btn:hover:before{left:100%}.btn:active{transform:translateY(1px)}.modal{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 24px 60px #0000004d,0 0 0 1px #ffffff0a}.log-viewer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent)}.status-dot{box-shadow:0 0 0 4px var(--primary-ghost),0 0 12px #16653466;animation:pulse 2s infinite}@media (max-width: 1024px){.page{padding:40px 24px 80px}.card{padding:28px 24px}.table-wrap{overflow-x:auto}}@media (max-width: 900px){.header{padding:20px 24px}.card-header{flex-direction:column;align-items:flex-start;gap:16px}.form-grid{grid-template-columns:1fr;gap:16px}}@media (max-width: 700px){.page{padding:24px 16px 56px}.title{font-size:1.75rem}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.card{padding:28px 20px}.toolbar{width:100%;justify-content:stretch;gap:8px}.toolbar .btn{flex:1;min-width:0;padding:10px 12px;font-size:13px}table{font-size:13px}th,td{padding:12px 16px}.modal{margin:16px;max-height:calc(100vh - 32px)}.modal-header{padding:20px 24px}.modal-body{padding:0 24px 24px}}@media (max-width: 540px){.page{padding:16px 12px 48px}.header{padding:16px 18px;gap:16px}.title{font-size:1.5rem}.subtitle{font-size:12px}.card{padding:24px 16px}.card-header{margin-bottom:20px;padding-bottom:12px}.card-header h2{font-size:1.25rem}.toolbar{flex-direction:column}.toolbar .btn{width:100%}th,td{padding:10px 12px}.badge{padding:4px 10px;font-size:12px}.log-viewer{padding:16px;font-size:12px}.modal-header{flex-direction:column;align-items:flex-start;gap:12px}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}@media (max-width: 360px){.page{padding:12px 8px 32px}.header{padding:12px 14px}.card{padding:20px 14px;border-radius:16px}.title{font-size:1.25rem}table{font-size:12px}th,td{padding:8px 10px}.btn{padding:8px 16px;font-size:13px}}
