:root{--vh-charcoal: #07080a;--vh-bone: #e4ded2;--vh-taupe: #bfb7a7;--vh-bone-tint: #f4f1ea;--vh-accent-300: #8fe2d7;--vh-accent-400: #57d0c0;--vh-accent-500: #2fb6a4;--vh-accent-600: #1f9384;--vh-accent-700: #14756a;--vh-neutral-950: #07080a;--vh-neutral-900: #101113;--vh-neutral-800: #1b1c1f;--vh-neutral-700: #2a2b2e;--vh-neutral-600: #3d3e41;--vh-neutral-500: #56575a;--vh-neutral-400: #7a7a78;--vh-neutral-300: #a3a095;--vh-neutral-200: #c7c2b5;--vh-neutral-100: #e4ded2;--vh-neutral-50: #f4f1ea;--vh-neutral-0: #ffffff;--vh-success: #3fb984;--vh-warning: #e0a33c;--vh-danger: #e2603f;--vh-info: #4fa3d1;--vh-bg: var(--vh-charcoal);--vh-bg-elevated: var(--vh-neutral-900);--vh-surface: var(--vh-neutral-800);--vh-border: var(--vh-neutral-700);--vh-text-primary: var(--vh-bone);--vh-text: var(--vh-bone);--vh-text-secondary: var(--vh-neutral-300);--vh-text-muted: var(--vh-neutral-400);--vh-accent: var(--vh-accent-500);--vh-accent-text: var(--vh-accent-400);--vh-focus-ring: var(--vh-accent-400);--vh-font-display: "Jost", Futura, "Century Gothic", system-ui, sans-serif;--vh-font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--vh-font-mono: "JetBrains Mono", "SF Mono", "Roboto Mono", Menlo, Consolas, monospace;--vh-fw-medium: 500;--vh-fw-regular: 400;--vh-fw-semibold: 600;--vh-text-xs: .75rem;--vh-text-sm: .875rem;--vh-text-base: 1rem;--vh-text-lg: 1.125rem;--vh-text-xl: 1.25rem;--vh-text-2xl: 1.563rem;--vh-text-3xl: 1.953rem;--vh-lh-tight: 1.1;--vh-lh-snug: 1.25;--vh-lh-normal: 1.5;--vh-lh-relaxed: 1.7;--vh-ls-heading: .01em;--vh-radius-sm: 4px;--vh-radius-md: 6px;--vh-radius-lg: 8px;--vh-space-1: 4px;--vh-space-2: 8px;--vh-space-3: 12px;--vh-space-4: 16px;--vh-space-5: 20px;--vh-space-6: 24px;--vh-space-8: 32px;--vh-space-10: 40px;--vh-shadow-panel: 0 18px 50px rgba(0, 0, 0, .28);--vh-sidebar-w: 248px}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--vh-bg);color:var(--vh-text-primary);font-family:var(--vh-font-body);font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{min-width:320px}h1,h2,h3{font-family:var(--vh-font-display);font-weight:var(--vh-fw-medium);letter-spacing:var(--vh-ls-heading);color:var(--vh-text-primary)}h1,h2,h3,p{margin-top:0}a{color:var(--vh-accent-text);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--vh-font-body);cursor:pointer;color:var(--vh-text-primary);background:var(--vh-surface);border:1px solid var(--vh-border);border-radius:6px;padding:6px 12px;font-size:13px;transition:border-color .15s ease,color .15s ease}button:hover:not(:disabled){border-color:var(--vh-accent);color:var(--vh-bone)}button:disabled{opacity:.5;cursor:default}pre{background:var(--vh-bg-elevated);border:1px solid var(--vh-border);color:var(--vh-text-secondary);border-radius:6px}input{background:var(--vh-bg-elevated);color:var(--vh-text-primary);border:1px solid var(--vh-border);border-radius:6px;padding:4px 8px}select,textarea{background:var(--vh-bg-elevated);color:var(--vh-text-primary);border:1px solid var(--vh-border);border-radius:var(--vh-radius-md)}:focus-visible{outline:2px solid var(--vh-focus-ring);outline-offset:2px;border-radius:4px}::selection{background:#2fb6a44d}.vh-shell{min-height:100vh;display:grid;grid-template-columns:var(--vh-sidebar-w) minmax(0,1fr);background:linear-gradient(180deg,rgba(47,182,164,.035),transparent 320px),var(--vh-bg)}.vh-sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:18px 14px;background:linear-gradient(180deg,rgba(47,182,164,.07),transparent 190px),linear-gradient(90deg,rgba(255,255,255,.025),transparent 68%),var(--vh-bg-elevated);border-right:1px solid rgba(87,208,192,.16);box-shadow:14px 0 42px #00000038}.vh-sidebar-logo{display:block;width:176px;max-width:94%;margin:2px auto 18px}.vh-sidebar-brand{padding:0 6px 16px;border-bottom:1px solid rgba(228,222,210,.08)}.vh-project-form{margin:16px 0 18px;padding:10px;border:1px solid rgba(228,222,210,.08);border-radius:var(--vh-radius-lg);background:#07080a59}.vh-project-select{width:100%;min-height:34px;padding:7px 9px;font-size:12px;border-color:#57d0c02e;background:#1b1c1fe6}.vh-project-link{display:inline-flex;margin-top:7px;font-size:11px;color:var(--vh-taupe);text-decoration:none}.vh-project-link:hover{color:var(--vh-accent-text);text-decoration:none}.vh-sidebar-section{margin-top:8px}.vh-sidebar-section-label{padding:0 10px 8px;font-family:var(--vh-font-mono);font-size:10px;color:var(--vh-text-muted);text-transform:uppercase}.vh-sidebar-link{display:flex;align-items:center;gap:10px;min-height:36px;padding:8px 10px;margin-bottom:4px;border:1px solid transparent;border-radius:var(--vh-radius-md);color:var(--vh-taupe);font-size:13px;font-weight:500;text-decoration:none;position:relative}.vh-sidebar-link:hover{color:var(--vh-bone);text-decoration:none;background:#ffffff09;border-color:#e4ded214}.vh-sidebar-link.is-active{color:var(--vh-bone);background:linear-gradient(90deg,#2fb6a42e,#2fb6a40a),#ffffff05;border-color:#57d0c047;box-shadow:inset 3px 0 0 var(--vh-accent)}.vh-sidebar-icon{display:inline-grid;place-items:center;width:22px;height:22px;border:1px solid rgba(191,183,167,.2);border-radius:var(--vh-radius-sm);color:var(--vh-text-muted);font-family:var(--vh-font-mono);font-size:11px;flex:0 0 auto}.vh-sidebar-link.is-active .vh-sidebar-icon{border-color:#57d0c080;color:var(--vh-accent-text);background:#2fb6a414}.vh-sidebar-text{min-width:0;flex:1}.vh-sidebar-footer{margin-top:auto;padding:14px 0 2px;border-top:1px solid rgba(228,222,210,.08);color:var(--vh-text-muted);font-size:12px}.vh-sidebar-status{display:grid;grid-template-columns:9px minmax(0,1fr);gap:9px;align-items:center;padding:0 10px 12px}.vh-sidebar-status-dot{width:8px;height:8px;border-radius:999px;background:var(--vh-success);box-shadow:0 0 0 4px #3fb9841a}.vh-sidebar-status-label{font-family:var(--vh-font-mono);font-size:10px;color:var(--vh-text-muted);text-transform:uppercase}.vh-sidebar-account{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--vh-text-secondary);font-size:12px;margin-top:2px}.vh-sidebar-project-card{margin:0 6px 10px;padding:9px 10px;border:1px solid rgba(87,208,192,.16);border-radius:var(--vh-radius-md);background:#2fb6a40e}.vh-sidebar-project-name{margin-top:3px;color:var(--vh-bone);font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vh-sidebar-signout{display:flex;align-items:center;justify-content:center;min-height:32px;margin:0 6px;border:1px solid rgba(226,96,63,.26);border-radius:var(--vh-radius-md);color:var(--vh-taupe);background:#e2603f09;font-size:12px;font-weight:600;text-decoration:none;transition:border-color .15s ease,color .15s ease,background .15s ease}.vh-sidebar-signout:hover{color:var(--vh-danger);border-color:#e2603f8c;background:#e2603f13;text-decoration:none}.vh-page{width:min(1280px,100%);padding:34px 38px}@media(min-width:901px){html,body{height:100%;overflow:hidden}.vh-shell{height:100svh;min-height:0;overflow:hidden}.vh-sidebar{height:100svh;overflow:hidden}.vh-page{height:100svh;overflow-y:auto;scrollbar-gutter:stable}}.vh-page-header{display:flex;justify-content:space-between;gap:var(--vh-space-4);align-items:flex-start;margin-bottom:var(--vh-space-5)}.vh-page-title{margin:0;font-size:var(--vh-text-3xl);line-height:var(--vh-lh-tight)}.vh-page-kicker{margin-top:6px;color:var(--vh-text-muted);font-size:13px;line-height:var(--vh-lh-normal)}.vh-page-meta{color:var(--vh-text-muted);font-family:var(--vh-font-mono);font-size:12px;line-height:var(--vh-lh-normal);text-align:right}.vh-section{margin-top:var(--vh-space-6)}.vh-section-head{display:flex;justify-content:space-between;gap:var(--vh-space-4);align-items:baseline;margin-bottom:var(--vh-space-3)}.vh-label{font-family:var(--vh-font-mono);font-size:11px;font-weight:500;letter-spacing:0;text-transform:uppercase;color:var(--vh-text-muted)}.vh-surface{border:1px solid var(--vh-border);background:linear-gradient(180deg,rgba(255,255,255,.018),transparent),var(--vh-surface);border-radius:var(--vh-radius-lg);padding:14px 16px}.vh-surface-accent{border-left:3px solid var(--vh-accent-line, var(--vh-accent))}.vh-clickable{cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .15s ease}.vh-clickable:hover{border-color:#57d0c06b;background:linear-gradient(180deg,#57d0c00b,#ffffff05),var(--vh-surface);text-decoration:none}.vh-clickable:active{transform:translateY(1px)}.vh-link-reset,.vh-link-reset:hover{color:inherit;text-decoration:none}.vh-row-arrow{margin-left:auto;color:var(--vh-accent-text);font-family:var(--vh-font-mono);font-size:12px}.vh-panel{border:1px solid rgba(87,208,192,.16);background:linear-gradient(180deg,#2fb6a412,#ffffff04),var(--vh-bg-elevated);border-radius:var(--vh-radius-lg);box-shadow:var(--vh-shadow-panel)}.vh-stack{display:flex;flex-direction:column;gap:var(--vh-space-2)}.vh-row{display:flex;align-items:center;justify-content:space-between;gap:var(--vh-space-4)}.vh-row-wrap{display:flex;align-items:center;gap:var(--vh-space-2);flex-wrap:wrap}.vh-grid{display:grid;gap:var(--vh-space-3)}.vh-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.vh-grid-main{grid-template-columns:minmax(0,2fr) minmax(280px,.9fr)}.vh-badge{display:inline-flex;align-items:center;min-height:18px;border:1px solid currentColor;border-radius:2px;padding:1px 9px;color:var(--vh-badge-color, var(--vh-text-muted));font-size:11px;font-weight:600;line-height:1.35;white-space:nowrap;transform:skew(-12deg);background:#ffffff05}.vh-badge>span{display:inline-block;transform:skew(12deg)}.vh-metric{min-height:92px}.vh-metric-value{margin-top:8px;font-family:var(--vh-font-display);font-size:30px;line-height:1}.vh-metric-sub{margin-top:6px;color:var(--vh-text-muted);font-size:12px}.vh-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:32px;border-radius:var(--vh-radius-md);padding:6px 12px;font-size:12px;font-weight:600;text-decoration:none}.vh-button:hover{text-decoration:none}.vh-button-primary{color:var(--vh-charcoal);background:var(--vh-accent-400);border-color:var(--vh-accent-400)}.vh-button-secondary{color:var(--vh-text-secondary);background:var(--vh-surface);border-color:var(--vh-border)}.vh-button-danger{color:var(--vh-danger);border-color:#e2603f8c}.vh-form{display:flex;flex-direction:column;gap:var(--vh-space-3)}.vh-form-row{display:flex;gap:var(--vh-space-2);align-items:center}.vh-field{display:flex;flex-direction:column;gap:5px;min-width:0;font-size:12px}.vh-field-label{color:var(--vh-text-muted)}.vh-input{width:100%;min-height:34px;padding:7px 9px;font-size:12px}.vh-callout{border:1px solid rgba(87,208,192,.2);background:#2fb6a411;border-radius:var(--vh-radius-lg);padding:12px 14px;font-size:12.5px;line-height:1.65}.vh-callout-danger{border-color:#e2603f6b;background:#e2603f13}.vh-error{color:var(--vh-danger);font-size:12px}.vh-success-text{color:var(--vh-success)}.vh-danger-text{color:var(--vh-danger)}.vh-divider{height:1px;background:var(--vh-border);margin:var(--vh-space-2) 0}.vh-codeblock{width:100%;margin:0;padding:14px;overflow:auto;border-radius:var(--vh-radius-lg);font-family:var(--vh-font-mono);font-size:12px;line-height:1.6}.vh-tabs{display:flex;gap:var(--vh-space-2);align-items:center;margin-bottom:var(--vh-space-3)}.vh-tab-active{border-color:var(--vh-accent);color:var(--vh-bone);background:#2fb6a41a}.vh-empty{text-align:center;padding:48px 24px;background:var(--vh-bg-elevated)}.vh-table{width:100%;border-collapse:collapse;font-size:13px}.vh-table th{text-align:left;padding:9px 12px;font-family:var(--vh-font-mono);font-size:11px;font-weight:500;letter-spacing:0;text-transform:uppercase;color:var(--vh-text-muted)}.vh-table td{padding:10px 12px;border-top:1px solid var(--vh-border)}.vh-status-bar{height:9px;border-radius:999px;background:#57d0c024;overflow:hidden}.vh-status-fill{height:100%;border-radius:999px;background:var(--vh-accent-400)}.vh-muted{color:var(--vh-text-muted)}.vh-secondary{color:var(--vh-text-secondary)}.vh-mono{font-family:var(--vh-font-mono)}@media(max-width:900px){.vh-shell{grid-template-columns:1fr}.vh-sidebar{position:relative;height:auto;border-right:0;border-bottom:1px solid var(--vh-border);box-shadow:none}.vh-sidebar-brand{border-bottom:0;padding-bottom:8px}.vh-sidebar-section{margin-top:12px}.vh-sidebar-footer{margin-top:14px}.vh-page{padding:var(--vh-space-5)}.vh-page-header,.vh-row{flex-direction:column;align-items:flex-start}.vh-page-meta{text-align:left}.vh-grid-4,.vh-grid-main{grid-template-columns:1fr}.vh-form-row{flex-direction:column;align-items:stretch}.vh-form-row .vh-button,.vh-form-row button{width:100%}}
