*{box-sizing:border-box}body{font:14px/1.45 ui-monospace,SFMono-Regular,Menlo,monospace;max-width:880px;margin:2rem auto;padding:0 1rem;color:#111}.app-header h1{font-size:1.1rem;margin:0}.app-header{margin-bottom:.75rem}h1{font-size:1.1rem;margin:0 0 1.5rem;border-bottom:1px solid #ccc;padding-bottom:.5rem}nav.tabs{display:flex;gap:0;border-bottom:1px solid #ccc;margin-bottom:1.25rem}nav.tabs .tab{font:inherit;background:transparent;color:#555;border:0;border-bottom:2px solid transparent;padding:.55rem .9rem;margin:0;cursor:pointer;border-radius:0;display:inline-flex;align-items:center;gap:.35rem}nav.tabs .tab:hover{color:#111}nav.tabs .tab.active{color:#111;border-bottom-color:#111}.tab-badge{font-size:10px;padding:1px 5px;border-radius:8px;background:#eee;color:#444}.tab-content{min-height:60vh}.auth-row{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem;align-items:flex-start}.auth-row input{width:320px}.auth-status{margin-bottom:.6rem}.vnc-frame{width:100%;height:600px;border:1px solid #ccc;border-radius:3px;background:#000}label.inline{display:inline-flex;flex-direction:row;margin-bottom:0}.log-viewport{border:1px solid #ccc;border-radius:3px;background:#0e0e10;color:#e0e0e0;font-size:12px;line-height:1.5;height:540px;overflow-y:auto;padding:.6rem .75rem;margin-top:.5rem}.log-empty{color:#888;font-style:italic}.log-line{display:grid;grid-template-columns:90px 50px 72px 1fr;gap:.6rem;padding:1px 0;white-space:pre-wrap;word-break:break-word}.log-time{color:#777}.log-level{text-transform:uppercase;color:#9ad;font-weight:600}.log-run{color:#c8a8ff;font-variant-numeric:tabular-nums}.log-warn .log-level{color:#f5c542}.log-warn .log-msg{color:#fce7a7}.log-error .log-level{color:#ff7a7a}.log-error .log-msg{color:#ffb4b4}.log-info .log-level{color:#7ad77a}h2{font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;color:#555;margin:2rem 0 .6rem}h3{font-size:.85rem;margin:1.2rem 0 .5rem;color:#222}button{font:inherit;padding:.4rem .8rem;background:#111;color:#fff;border:0;border-radius:3px;cursor:pointer;margin-right:.5rem}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:#eee;color:#111}a{color:#06c}pre{background:#f5f5f5;padding:.75rem;border-radius:3px;font-size:12px;max-height:320px;overflow:auto;margin:.3rem 0 0;white-space:pre-wrap;word-break:break-word}pre.error{background:#fdecea;color:#b71c1c}.row{display:flex;gap:.5rem;align-items:center;margin-bottom:.4rem;flex-wrap:wrap}.pill{font-size:11px;padding:1px 6px;border-radius:10px;background:#eee}.pill.ok{background:#cfe9c9}.pill.err{background:#f5c2c0}.pill.run{background:#fce7a7}input,select{font:inherit;padding:.3rem .5rem;border:1px solid #ccc;border-radius:3px;background:#fff}input[type=text],input[type=date]{width:160px}form.routine-form{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}form.routine-form input{width:130px}label{display:flex;gap:.5rem;align-items:center;margin-bottom:.4rem}.status{font-size:12px;color:#666;margin-top:.5rem}.status.err{color:#c00}.note{font-size:12px;color:#666;margin-top:.4rem}.queue-section{margin-bottom:1.4rem}.queue-empty{font-size:12px;color:#888;font-style:italic;padding:.4rem 0}.queue-list{border:1px solid #e3e3e3;border-radius:3px;overflow:hidden}.queue-row{display:flex;flex-direction:column;gap:.25rem;font-size:12px;padding:.5rem .6rem;border-top:1px solid #f0f0f0}.queue-row:first-child{border-top:0}.queue-row-head{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.queue-routine{font-weight:600;color:#222}.queue-runid{display:inline-flex;align-items:center;gap:.3rem;background:#f0ebff;color:#5b3eb8;border:1px solid #d8ccff;border-radius:3px;padding:1px 6px;font-size:11px;font-variant-numeric:tabular-nums;cursor:pointer;margin:0}.queue-runid:hover{background:#e3d9ff}.queue-runid-icon{font-size:10px;opacity:.7}.queue-meta{color:#777;margin-left:auto;font-variant-numeric:tabular-nums}.queue-meta strong{color:#222;font-weight:600}.queue-row-params,.queue-row-error,.queue-row-result{display:flex;gap:.5rem;align-items:flex-start}.queue-result-body{flex:1;display:flex;flex-direction:column;gap:.3rem}.queue-result-toggle{align-self:flex-start;background:#eef4ff;color:#14a;border:0;border-radius:3px;padding:2px 8px;font-size:11px;cursor:pointer;margin:0}.queue-result-toggle:hover{background:#dde9ff}.queue-result-pre{background:#0e0e10;color:#e0e0e0;font-size:11.5px;padding:6px 10px;border-radius:3px;margin:0;max-height:300px;overflow:auto;white-space:pre}.queue-label{flex:0 0 50px;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:#999;padding-top:2px}.queue-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.queue-header .note{flex:1;margin:0}.queue-cancel,.queue-cancel-all{background:#ffefef;color:#b00020;border:1px solid #f3c4c4;border-radius:3px;padding:2px 8px;font-size:11px;font-weight:600;cursor:pointer}.queue-cancel:hover,.queue-cancel-all:hover{background:#ffd9d9}.queue-cancel-all{padding:4px 10px;font-size:12px}.queue-cancel-all:disabled{background:#f6f6f6;color:#aaa;border-color:#e0e0e0;cursor:not-allowed}.queue-input,.queue-error{flex:1;background:#f7f7f7;border-radius:3px;padding:2px 6px;font-size:11.5px;color:#333;word-break:break-word;white-space:pre-wrap}.queue-error{background:#fdecea;color:#b71c1c}.queue-duration{color:#777}.queue-duration.live{color:#1565c0;font-weight:500}.throttle-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.4rem}.throttle-row{display:flex;align-items:center;gap:.8rem;padding:.5rem .7rem;border:1px solid #e0e0e0;border-radius:4px;background:#fafafa}.throttle-host{font-weight:600;min-width:100px}.throttle-stats{color:#555;flex:1}.throttle-input-wrap{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;color:#555}.throttle-input{width:4rem;padding:.2rem .4rem;border:1px solid #ccc;border-radius:3px;font-family:inherit;font-size:.9rem}.health-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.4rem;margin-bottom:.6rem}.health-stat{display:flex;flex-direction:column;gap:.15rem;padding:.4rem .6rem;border:1px solid #e3e3e3;border-radius:3px;background:#fafafa}.health-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:#888}.health-stat-value{font-size:1.1rem;font-weight:600;color:#111;font-variant-numeric:tabular-nums}.health-stat-value.warn{color:#b00020}
