*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--surface: #1a1d27;--surface-2: #22263a;--border: #2e3352;--accent: #4f7cff;--accent-hover: #6b93ff;--text: #e2e8f0;--text-muted: #8892a4;--green: #22c55e;--red: #ef4444;--yellow: #eab308;--radius: 8px;--font: "Inter", system-ui, -apple-system, sans-serif}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.app-header h1{font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--text)}.header-right{display:flex;align-items:center;gap:12px}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,opacity .15s;white-space:nowrap}.btn:hover:not(:disabled){background:var(--border)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-danger{color:var(--red);border-color:var(--red)}.btn-danger:hover:not(:disabled){background:#ef44441a}.main-content{flex:1;padding:24px;max-width:1400px;margin:0 auto;width:100%}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-header h2{font-size:15px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.empty-state{grid-column:1 / -1;text-align:center;padding:48px 24px;color:var(--text-muted)}.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--red);padding:10px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:13px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:16px}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:36px 32px}.login-card h1{font-size:20px;font-weight:700;margin-bottom:6px;color:var(--text)}.login-card p{color:var(--text-muted);font-size:13px;margin-bottom:28px}.login-card label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.login-card input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none;transition:border-color .15s;font-family:monospace}.login-card input:focus{border-color:var(--accent)}.login-card .btn{width:100%;justify-content:center;margin-top:20px;padding:10px;font-size:14px}.login-error{margin-top:12px;color:var(--red);font-size:13px;text-align:center}.stats-bar{display:flex;align-items:center;gap:20px}.stat-item{display:flex;align-items:center;gap:8px}.stat-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:13px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.stat-bar-wrap{width:64px;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:2px;transition:width .4s ease;background:var(--accent)}.stat-bar-fill.warn{background:var(--yellow)}.stat-bar-fill.danger{background:var(--red)}.stat-divider{width:1px;height:20px;background:var(--border)}.site-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:14px;transition:border-color .15s}.site-card:hover{border-color:var(--accent)}.site-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.site-card-title{font-size:15px;font-weight:600;color:var(--text)}.site-card-desc{font-size:13px;color:var(--text-muted);margin-top:2px}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;flex-shrink:0}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%}.status-badge.running{background:#22c55e1f;color:var(--green);border:1px solid rgba(34,197,94,.25)}.status-badge.running:before{background:var(--green)}.status-badge.stopped,.status-badge.failed,.status-badge.inactive,.status-badge.dead{background:#ef44441f;color:var(--red);border:1px solid rgba(239,68,68,.25)}.status-badge.stopped:before,.status-badge.failed:before,.status-badge.inactive:before,.status-badge.dead:before{background:var(--red)}.status-badge.unknown{background:#8892a41f;color:var(--text-muted);border:1px solid var(--border)}.status-badge.unknown:before{background:var(--text-muted)}.status-badge.static{background:#4f7cff1f;color:var(--accent);border:1px solid rgba(79,124,255,.25)}.status-badge.static:before{background:var(--accent)}.site-card-meta{display:flex;flex-direction:column;gap:4px}.site-meta-row{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.site-meta-row a{color:var(--accent);text-decoration:none}.site-meta-row a:hover{text-decoration:underline}.site-card-actions{display:flex;gap:8px;flex-wrap:wrap}.site-card-actions .btn{flex:1;justify-content:center;min-width:0;font-size:12px;padding:6px 8px}.btn-start{color:var(--green);border-color:#22c55e66}.btn-start:hover:not(:disabled){background:#22c55e1a}.btn-stop{color:var(--red);border-color:#ef444466}.btn-stop:hover:not(:disabled){background:#ef44441a}.btn-logs{width:100%;justify-content:center}.logs-modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h2{font-size:15px;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:20px;line-height:1;padding:2px 6px;border-radius:4px;transition:color .15s,background .15s}.modal-close:hover{color:var(--text);background:var(--surface-2)}.logs-body{flex:1;overflow-y:auto;padding:16px 20px}.logs-pre{font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:12px;line-height:1.6;color:var(--text-muted);white-space:pre-wrap;word-break:break-all}.logs-loading,.logs-empty{color:var(--text-muted);font-size:13px;padding:16px 0}.logs-error{color:var(--red);font-size:13px;padding:16px 0}.add-site-modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.add-site-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.add-site-modal .modal-header h2{font-size:15px;font-weight:600}.add-site-form{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-group input{padding:9px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none;transition:border-color .15s;width:100%;font-family:inherit}.form-group input:focus{border-color:var(--accent)}.form-group input::placeholder{color:var(--text-muted);opacity:.6}.form-hint{font-size:11px;color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-actions{display:flex;gap:10px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0}.form-error{color:var(--red);font-size:13px;padding:0 20px 8px}.type-toggle{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.type-btn{flex:1;padding:8px 12px;background:var(--bg);border:none;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.type-btn:first-child{border-right:1px solid var(--border)}.type-btn.active{background:var(--accent);color:#fff}.type-btn:not(.active):hover{background:var(--surface-2);color:var(--text)}
