:root{--color-bg:#0e1115;--color-bg-canvas:#11151b;--color-surface:#161b23;--color-surface-light:#1c222b;--color-surface-hover:#1f2630;--color-primary:#5ce6e0;--color-primary-hover:#2bd0cb;--color-primary-soft:#5ce6e01f;--color-primary-text:#062a2a;--color-success:#5bd49a;--color-warning:#f1b85b;--color-error:#ef6f6c;--color-info:#79b7f0;--color-text:#e6e9ee;--color-text-muted:#7c8593;--color-text-secondary:#b5bcc7;--color-text-faint:#565e6b;--color-border:#262d38;--color-border-soft:#1f252e;--color-border-strong:#313947;--color-header-bg:var(--color-bg);--font-family:"Inter", "Inter Display", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", "Cascadia Code", "Fira Code", monospace;--sidebar-width:236px;--topbar-height:56px;--radius:8px;--radius-sm:6px;--radius-lg:12px;--shadow-sm:0 1px 2px #00000059;--shadow:0 4px 16px #00000052, 0 1px 2px #00000040;--shadow-lg:0 16px 40px #00000073;--ease:cubic-bezier(.22, 1, .36, 1)}[data-theme=light]{--color-bg:#f6f4ee;--color-bg-canvas:#faf8f3;--color-surface:#fff;--color-surface-light:#f1eee6;--color-surface-hover:#ebe7dc;--color-primary:#149c99;--color-primary-hover:#0d7a78;--color-primary-soft:#149c991a;--color-primary-text:#fff;--color-success:#1f9d63;--color-warning:#b7771f;--color-error:#c85553;--color-info:#2c72b5;--color-text:#1a1f26;--color-text-secondary:#41495a;--color-text-muted:#6f7785;--color-text-faint:#97a0b0;--color-border:#dcd5c5;--color-border-soft:#ece7db;--color-border-strong:#c4bba5;--color-header-bg:var(--color-bg);--shadow-sm:0 1px 2px #231e140f;--shadow:0 6px 18px #231e1414;--shadow-lg:0 18px 40px #231e141a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}body{font-family:var(--font-family);font-feature-settings:"cv11", "ss01", "ss03";background:var(--color-bg);color:var(--color-text);letter-spacing:-.005em;min-height:100vh;line-height:1.5}#root{min-height:100vh}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);background-clip:padding-box;border:2px solid #0000;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong);background-clip:padding-box;border:2px solid #0000}.auth-loading{min-height:100vh;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.auth-loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.theme-toggle{cursor:pointer;background:0 0;border:none;padding:0;line-height:0}.theme-toggle-track{background:var(--color-surface-light);border:1px solid var(--color-border);border-radius:12px;align-items:center;width:44px;height:24px;transition:background .3s,border-color .3s;display:flex;position:relative}.theme-toggle:hover .theme-toggle-track{border-color:var(--color-primary)}.theme-toggle-thumb{background:var(--color-primary);border-radius:50%;width:20px;height:20px;transition:transform .3s;position:absolute;top:1px;left:1px;box-shadow:0 1px 3px #0000004d}[data-theme=light] .theme-toggle-thumb{transform:translate(20px)}.theme-toggle-icon{transition:opacity .25s;position:absolute;top:50%;transform:translateY(-50%)}.theme-toggle-sun{color:#f5c842;opacity:1;left:5px}.theme-toggle-moon{color:#c4cad4;opacity:.4;right:5px}[data-theme=light] .theme-toggle-sun{opacity:.4}[data-theme=light] .theme-toggle-moon{color:#5a6a7a;opacity:1}.topbar{height:var(--topbar-height);background:var(--color-header-bg);border-bottom:1px solid var(--color-border-soft);z-index:100;-webkit-backdrop-filter:blur(12px);align-items:center;gap:18px;padding:0 18px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-left{min-width:var(--sidebar-width);align-items:center;gap:14px;padding-right:18px;display:flex}.topbar-brand{transition:background .15s var(--ease);border-radius:7px;align-items:center;gap:10px;margin-left:-6px;padding:4px 6px;text-decoration:none;display:inline-flex}.topbar-brand:hover{background:var(--color-surface-hover)}.topbar-brand-mark{background:linear-gradient(135deg,#5ce6e0 0%,#1f7a8c 100%);border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex;overflow:hidden;box-shadow:0 0 0 1px #5ce6e059,0 4px 14px #5ce6e040}.topbar-brand-mark img{object-fit:contain;mix-blend-mode:screen;width:22px;height:22px}[data-theme=light] .topbar-brand-mark img{mix-blend-mode:multiply}.topbar-brand-name{color:var(--color-text);letter-spacing:-.01em;font-size:14px;font-weight:600}.topbar-brand-accent{color:var(--color-primary);margin:0 1px}.topbar-brand-suffix{color:var(--color-text-muted);font-weight:500}.topbar-breadcrumbs{color:var(--color-text-muted);border-left:1px solid var(--color-border-soft);align-items:center;gap:8px;height:24px;padding-left:14px;font-size:13px;display:flex}.topbar-breadcrumbs svg{color:var(--color-text-faint);flex-shrink:0}.topbar-crumb{color:var(--color-text);white-space:nowrap;font-weight:500}.topbar-crumb-muted{color:var(--color-text-muted);font-weight:400}.topbar-center{flex:1;justify-content:center;max-width:520px;display:flex}.topbar-search{background:var(--color-surface);border:1px solid var(--color-border-soft);width:100%;height:32px;transition:border-color .15s var(--ease), background .15s var(--ease);border-radius:7px;align-items:center;gap:8px;padding:0 10px;display:flex;position:relative}.topbar-search:focus-within{border-color:var(--color-primary);background:var(--color-bg-canvas);box-shadow:0 0 0 3px var(--color-primary-soft)}.topbar-search>svg{color:var(--color-text-muted);flex-shrink:0}.topbar-search input{color:var(--color-text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13px}.topbar-search input::placeholder{color:var(--color-text-muted)}.topbar-kbd{font-size:10.5px;font-family:var(--font-mono);color:var(--color-text-muted);background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);border-radius:4px;flex-shrink:0;align-items:center;padding:2px 6px;display:inline-flex}.topbar-actions{align-items:center;gap:10px;display:flex}.topbar-action-group{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:8px;align-items:center;gap:2px;padding:3px;display:inline-flex}.topbar-btn{color:var(--color-text-secondary);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease);background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:5px 10px;font-family:inherit;font-size:12.5px;font-weight:500;display:inline-flex}.topbar-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.topbar-btn-primary{background:var(--color-primary);color:var(--color-primary-text)}.topbar-btn-primary:hover{background:var(--color-primary-hover);color:var(--color-primary-text)}.topbar-icon-btn{width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease);background:0 0;border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;display:inline-flex;position:relative}.topbar-icon-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.topbar-bell-dot{background:var(--color-primary);width:7px;height:7px;box-shadow:0 0 0 2px var(--color-bg);border-radius:50%;position:absolute;top:7px;right:8px}.topbar-avatar{border:1px solid var(--color-border);color:#062a2a;letter-spacing:.02em;cursor:pointer;width:32px;height:32px;transition:transform .15s var(--ease), box-shadow .15s var(--ease);background:linear-gradient(135deg,#5ce6e0 0%,#1f7a8c 100%);border-radius:50%;justify-content:center;align-items:center;font-family:inherit;font-size:11.5px;font-weight:600;display:inline-flex}.topbar-avatar:hover{box-shadow:0 0 0 2px var(--color-primary-soft);transform:scale(1.05)}.topbar-avatar-initials{line-height:1}.topbar-user-menu{position:relative}.topbar-dropdown{background:var(--color-surface);border:1px solid var(--color-border);width:240px;box-shadow:var(--shadow-lg);border-radius:10px;flex-direction:column;gap:2px;padding:6px;display:flex;position:absolute;top:calc(100% + 6px);right:0}.topbar-dropdown-info{align-items:center;gap:10px;padding:8px 8px 10px;display:flex}.topbar-dropdown-avatar{color:#062a2a;background:linear-gradient(135deg,#5ce6e0 0%,#1f7a8c 100%);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:inline-flex}.topbar-dropdown-meta{flex-direction:column;min-width:0;display:flex}.topbar-dropdown-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.topbar-dropdown-email{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}.topbar-dropdown-sep{background:var(--color-border-soft);height:1px;margin:2px 4px}.topbar-dropdown-item{color:var(--color-text-secondary);text-align:left;cursor:pointer;transition:background .12s var(--ease), color .12s var(--ease);background:0 0;border:none;border-radius:6px;align-items:center;gap:9px;padding:7px 9px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.topbar-dropdown-item:hover{background:var(--color-surface-hover);color:var(--color-text)}@media (width<=1180px){.topbar-center,.topbar-action-group .topbar-btn span{display:none}}@media (width<=900px){.topbar-breadcrumbs{display:none}}.sidebar{top:var(--topbar-height);width:var(--sidebar-width);background:var(--color-bg);border-right:1px solid var(--color-border-soft);z-index:90;transition:width .2s var(--ease);flex-direction:column;display:flex;position:fixed;bottom:0;left:0}.sidebar-collapsed{width:60px}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:18px 12px 12px;display:flex;overflow-y:auto}.sidebar-section{flex-direction:column;gap:1px;margin-bottom:16px;display:flex}.sidebar-section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-faint);margin-top:4px;padding:6px 8px 4px;font-size:10.5px;font-weight:500}.sidebar-section:last-of-type{margin-bottom:0}.sidebar-link{color:var(--color-text-secondary);transition:background .15s var(--ease), color .15s var(--ease);border-radius:7px;align-items:center;gap:10px;padding:7px 10px;font-size:13px;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar-link-active{background:var(--color-surface);color:var(--color-text);box-shadow:0 0 0 1px var(--color-border) inset}.sidebar-link-active:before{content:"";background:var(--color-primary);width:3px;height:18px;box-shadow:0 0 8px var(--color-primary-soft);border-radius:0 3px 3px 0;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.sidebar-link-icon{width:18px;height:18px;color:var(--color-text-muted);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sidebar-link:hover .sidebar-link-icon,.sidebar-link-active .sidebar-link-icon{color:var(--color-primary)}.sidebar-link-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sidebar-link-badge{background:var(--color-surface-light);min-width:22px;height:18px;color:var(--color-text-muted);letter-spacing:-.01em;border:1px solid var(--color-border-soft);border-radius:999px;justify-content:center;align-items:center;padding:0 6px;font-size:10.5px;font-weight:500;display:inline-flex}.sidebar-link-active .sidebar-link-badge{background:var(--color-primary-soft);color:var(--color-primary);border-color:#5ce6e040}.sidebar-collapsed .sidebar-nav{padding:18px 8px 12px}.sidebar-collapsed .sidebar-link{justify-content:center;padding:8px 0}.sidebar-collapsed .sidebar-section{margin-bottom:12px}.sidebar-collapsed .sidebar-section+.sidebar-section{border-top:1px solid var(--color-border-soft);padding-top:12px}.sidebar-footer{border-top:1px solid var(--color-border-soft);align-items:center;gap:8px;padding:10px 12px;display:flex}.sidebar-status{flex:1;align-items:center;gap:9px;min-width:0;display:flex}.sidebar-status-dot{background:var(--color-success);border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-flex;box-shadow:0 0 0 3px #5bd49a2e}.sidebar-status-dot svg{display:none}.sidebar-status-info{flex-direction:column;min-width:0;display:flex}.sidebar-status-label{color:var(--color-text);font-size:11.5px;font-weight:500}.sidebar-status-detail{color:var(--color-text-muted);font-size:10.5px;font-family:var(--font-mono)}.sidebar-collapse-btn{border:1px solid var(--color-border-soft);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease), border-color .15s var(--ease);background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sidebar-collapse-btn:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border)}.sidebar-collapse-icon{transition:transform .2s var(--ease);display:inline-flex;transform:rotate(180deg)}.sidebar-collapse-icon[data-collapsed=true]{transform:rotate(0)}.sidebar-collapsed .sidebar-footer{flex-direction:column;padding:12px 8px}.app-layout{background:var(--color-bg);min-height:100vh}.app-main{margin-top:var(--topbar-height);margin-left:var(--sidebar-width);min-height:calc(100vh - var(--topbar-height));padding:24px;transition:margin-left .2s}.landing{background:radial-gradient(circle at top right, var(--color-primary-soft), transparent 28%), linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-canvas) 100%);min-height:100vh;color:var(--color-text);flex-direction:column;display:flex}.landing-page-shell{flex:1;gap:28px;width:100%}.landing-header{z-index:100;background:color-mix(in srgb, var(--color-header-bg) 88%, transparent);border-bottom:1px solid var(--color-border-soft);-webkit-backdrop-filter:blur(12px);position:sticky;top:0}.landing-header-inner{max-width:1480px;min-height:var(--topbar-height);grid-template-columns:auto 1fr auto;align-items:center;gap:18px;margin:0 auto;padding:0 32px;display:grid}.landing-brand{align-items:center;gap:10px;min-width:0;display:inline-flex}.landing-brand-mark{background:linear-gradient(135deg,#5ce6e0 0%,#1f7a8c 100%);border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex;overflow:hidden;box-shadow:0 0 0 1px #5ce6e059,0 4px 14px #5ce6e040}.landing-logo-img{object-fit:contain;mix-blend-mode:screen;width:28px;height:28px}[data-theme=light] .landing-logo-img{mix-blend-mode:multiply}.landing-brand-name{color:var(--color-text);letter-spacing:-.01em;font-size:14px;font-weight:600}.landing-brand-accent{color:var(--color-primary);margin:0 1px}.landing-brand-suffix{color:var(--color-text-muted);font-weight:500}.landing-header-meta{justify-content:center;display:flex}.landing-header-label{border:1px solid var(--color-border-soft);background:var(--color-surface);color:var(--color-text-muted);font-size:11.5px;font-family:var(--font-mono);border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;display:inline-flex}.landing-header-actions{justify-content:flex-end;align-items:center;gap:12px;display:flex}.landing-header-cta{justify-content:center;min-width:72px}.landing-hero-grid{grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr);align-items:stretch;gap:24px;display:grid}.landing-hero-copy{flex-direction:column;justify-content:center;gap:14px;padding:18px 0;display:flex}.landing-hero-title{letter-spacing:-.04em;max-width:11ch;font-size:clamp(2.3rem,3.5vw,4.1rem);line-height:.98}.landing-hero-subtitle{max-width:640px}.landing-hero-actions{flex-wrap:wrap;gap:12px;display:flex}.landing-action{min-height:38px;padding-inline:16px}.landing-hero-tags{flex-wrap:wrap;gap:8px;display:flex}.landing-hero-panel{min-height:100%;box-shadow:var(--shadow-sm);justify-content:space-between}.landing-hero-panel-header{align-items:flex-start}.landing-panel-badge{background:var(--color-primary-soft);color:var(--color-primary);border:1px solid #5ce6e04d;border-radius:999px;align-items:center;padding:4px 8px;display:inline-flex}.landing-hero-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.landing-summary-item{border-radius:var(--radius-sm);background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);flex-direction:column;gap:6px;padding:12px;display:flex}.landing-summary-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-faint);font-size:11px}.landing-summary-item strong{color:var(--color-text);font-size:12.5px;font-weight:600;line-height:1.45}.landing-hero-typing{align-items:center;height:24px;margin-bottom:4px;display:flex}.landing-hero-typing-text{font-family:var(--font-mono);color:var(--color-text-secondary);letter-spacing:.01em;font-size:13px}.landing-hero-typing-cursor{background:var(--color-primary);vertical-align:middle;border-radius:1px;width:2px;height:14px;margin-left:2px;animation:1s step-end infinite cursor-blink;display:inline-block}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.landing-section-block{flex-direction:column;gap:18px;display:flex}.landing-section-card{gap:20px}.landing-section-heading{align-items:flex-start}.landing-overview-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.landing-overview-item{border-radius:var(--radius);background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);flex-direction:column;gap:10px;padding:16px;display:flex}.landing-overview-step{width:fit-content;color:var(--color-primary);background:var(--color-primary-soft);border:1px solid #5ce6e04d;border-radius:4px;justify-content:center;align-items:center;padding:2px 6px;display:inline-flex}.landing-overview-item h3,.landing-grid-card h3{letter-spacing:-.01em;color:var(--color-text);font-size:14px;font-weight:600}.landing-overview-item p,.landing-grid-card p{color:var(--color-text-muted);font-size:13px;line-height:1.55}.landing-card-grid{gap:14px;display:grid}.landing-card-grid--three{grid-template-columns:repeat(3,minmax(0,1fr))}.landing-card-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-grid-card{min-height:180px}.landing-card-kicker{text-transform:uppercase;letter-spacing:.1em;color:var(--color-primary);font-size:10.5px}.landing-workflow{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.landing-workflow-item{align-items:center;gap:12px;display:flex}.landing-workflow-step{background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);min-width:110px;transition:border-color .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);flex-direction:column;align-items:center;gap:8px;padding:12px 14px;display:flex}.landing-workflow-step--active{background:var(--color-primary-soft);border-color:#5ce6e059;box-shadow:inset 0 0 0 1px #5ce6e02e}.landing-workflow-step--done{border-color:var(--color-border);box-shadow:none;background:var(--color-bg-canvas)}.landing-workflow-label{text-align:center;font-size:13px;font-weight:600}.landing-workflow-arrow{color:var(--color-text-muted);transition:color .2s var(--ease);margin:0 2px;font-size:18px}.landing-workflow-arrow--active{color:var(--color-primary)}.landing-cta-card{align-items:flex-start}.landing-cta-text{max-width:560px}.landing-cta-actions{align-items:center;gap:12px;display:flex}.landing-footer{border-top:1px solid var(--color-border-soft)}.landing-footer-shell{padding-top:18px;padding-bottom:24px}.landing-footer p{color:var(--color-text-muted);font-size:12.5px}@media (width<=1180px){.landing-header-inner{grid-template-columns:auto auto}.landing-header-meta{display:none}.landing-hero-grid{grid-template-columns:1fr}.landing-overview-grid,.landing-card-grid--three{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=768px){.landing-page-shell{padding:20px 18px 36px}.landing-header-inner{grid-template-columns:1fr;justify-items:stretch;gap:12px;padding:12px 18px}.landing-header-actions{justify-content:space-between}.landing-hero-title{max-width:none;font-size:clamp(2rem,10vw,2.8rem)}.landing-hero-summary,.landing-overview-grid,.landing-card-grid--three,.landing-card-grid--two{grid-template-columns:1fr}.landing-workflow{gap:10px}.landing-workflow-item{justify-content:flex-start;width:100%}.landing-workflow-step{width:100%;min-width:0}.landing-workflow-arrow{display:none}}@media (prefers-reduced-motion:reduce){.landing-hero-typing-cursor{opacity:1;animation:none}.landing-workflow-step,.landing-workflow-arrow{transition:none}}.login-page{background:var(--color-bg);min-height:100vh;color:var(--color-text);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-bg-grid{background-image:linear-gradient(var(--color-border-soft) 1px, transparent 1px), linear-gradient(90deg, var(--color-border-soft) 1px, transparent 1px);opacity:.35;pointer-events:none;background-size:64px 64px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle at 30%,#00000080,#0000 70%);mask-image:radial-gradient(circle at 30%,#00000080,#0000 70%)}.login-bg-glow{pointer-events:none;filter:blur(20px);background:radial-gradient(closest-side,#5ce6e02e,#0000);width:600px;height:600px;position:absolute;top:-120px;right:-120px}.login-shell{grid-template-columns:1fr 1fr;align-items:stretch;gap:48px;width:min(1080px,100% - 64px);display:grid;position:relative}.login-pitch{flex-direction:column;gap:28px;padding:12px 0;display:flex}.login-brand{align-items:center;gap:12px;display:flex}.login-brand-name{letter-spacing:-.012em;font-size:18px;font-weight:700}.login-brand-tag{color:var(--color-text-faint);letter-spacing:.12em;text-transform:uppercase;font-size:11px}.login-pitch-title{letter-spacing:-.02em;color:var(--color-text);max-width:460px;font-size:32px;font-weight:600;line-height:1.18}.login-pitch-list{flex-direction:column;gap:12px;padding:0;list-style:none;display:flex}.login-pitch-list li{color:var(--color-text-secondary);align-items:center;gap:12px;font-size:13.5px;display:flex}.login-pitch-dot{background:var(--color-primary);border-radius:999px;width:6px;height:6px;box-shadow:0 0 10px #5ce6e099}.login-pitch-foot{color:var(--color-text-faint);letter-spacing:.04em;font-size:11.5px;font-family:var(--font-mono);margin-top:auto}.login-main{justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);flex-direction:column;gap:22px;padding:32px;display:flex}.login-card-header{flex-direction:column;gap:6px;display:flex}.login-eyebrow{letter-spacing:.14em;color:var(--color-primary);text-transform:uppercase;font-size:11px;font-weight:600}.login-title{letter-spacing:-.018em;font-size:24px;font-weight:600}.login-subtitle{color:var(--color-text-muted);font-size:13.5px;line-height:1.55}.login-error{border-radius:var(--radius-sm);color:var(--color-error);background:#ef6f6c1a;border:1px solid #ef6f6c52;align-items:center;gap:10px;padding:10px 14px;font-size:13px;display:flex}.login-error-dot{background:var(--color-error);border-radius:999px;width:6px;height:6px}.login-form{flex-direction:column;gap:10px;display:flex}.login-btn{border-radius:var(--radius-sm);background:var(--color-primary);width:100%;color:var(--color-primary-text);border:1px solid var(--color-primary);cursor:pointer;transition:background .15s var(--ease), transform 80ms var(--ease);justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.login-btn:hover:not(:disabled){background:var(--color-primary-hover)}.login-btn:active:not(:disabled){transform:translateY(1px)}.login-btn:disabled{opacity:.7;cursor:progress}.login-btn-spinner{border:2px solid #062a2a4d;border-top-color:var(--color-primary-text);border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin}.login-link{color:var(--color-text-muted);cursor:pointer;transition:color .15s var(--ease);background:0 0;border:0;align-self:center;padding:6px;font-family:inherit;font-size:13px}.login-link:hover:not(:disabled){color:var(--color-primary)}.login-link:disabled{opacity:.5;cursor:not-allowed}.login-divider{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.12em;justify-content:center;align-items:center;font-size:11.5px;display:flex;position:relative}.login-divider:before,.login-divider:after{content:"";border-top:1px solid var(--color-border-soft);flex:1}.login-divider span{padding:0 12px}.login-foot{color:var(--color-text-muted);text-align:center;font-size:12.5px;line-height:1.55}@media (width<=900px){.login-shell{grid-template-columns:1fr;gap:32px}.login-pitch{display:none}}.auth-callback-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex}.auth-callback-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);flex-direction:column;align-items:center;gap:16px;padding:36px 40px;display:flex}.auth-callback-card h1{font-size:18px;font-weight:600}.auth-callback-card p{color:var(--color-text-muted);text-align:center;font-size:13px}.auth-callback-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.dashboard{max-width:1480px;margin:0 auto;padding:28px 32px 48px;position:relative}.toast{top:calc(var(--topbar-height) + 16px);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);color:var(--color-text);z-index:200;animation:toast-in .3s var(--ease);border-radius:8px;align-items:center;gap:8px;padding:9px 14px;font-size:13px;font-weight:500;display:inline-flex;position:fixed;right:24px}.toast svg{color:var(--color-success)}@keyframes toast-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dashboard-hero{justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:28px;display:flex}.dashboard-hero-text{max-width:720px}.dashboard-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary);align-items:center;gap:6px;margin-bottom:14px;font-size:11px;font-weight:500;display:inline-flex}.dashboard-hero h1{letter-spacing:-.025em;color:var(--color-text);margin-bottom:12px;font-size:32px;font-weight:600;line-height:1.1}.dashboard-hero-accent{color:var(--color-text-muted);font-weight:400;display:block}.dashboard-hero-sub{color:var(--color-text-muted);max-width:580px;font-size:14px;line-height:1.6}.dashboard-hero-actions{flex-shrink:0;gap:8px;display:flex}.stats-strip{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);padding:16px 18px;position:relative;overflow:hidden}.stat-card:after{content:"";background:radial-gradient(circle at top right, var(--color-primary-soft), transparent 60%);opacity:0;transition:opacity .2s var(--ease);pointer-events:none;position:absolute;inset:0}.stat-card:hover:after{opacity:.6}.stat-card-top{align-items:center;gap:8px;margin-bottom:12px;display:flex}.stat-card-icon{background:var(--color-surface-light);width:28px;height:28px;color:var(--color-text-muted);border-radius:7px;justify-content:center;align-items:center;display:inline-flex}.stat-card-success .stat-card-icon{color:var(--color-success);background:#5bd49a1a}.stat-card-info .stat-card-icon{color:var(--color-info);background:#79b7f01f}.stat-card-warning .stat-card-icon{color:var(--color-warning);background:#f1b85b1f}.stat-card-error .stat-card-icon{color:var(--color-error);background:#ef6f6c1f}.stat-card-label{color:var(--color-text-muted);letter-spacing:0;font-size:12px;font-weight:500}.stat-card-pulse{background:var(--color-info);border-radius:50%;width:8px;height:8px;margin-left:auto;position:relative}.stat-card-pulse:before{content:"";border:2px solid var(--color-info);opacity:.4;border-radius:50%;animation:1.6s ease-out infinite pulse;position:absolute;inset:-3px}@keyframes pulse{0%{opacity:.6;transform:scale(.6)}to{opacity:0;transform:scale(1.6)}}.stat-card-value{letter-spacing:-.025em;color:var(--color-text);font-variant-numeric:tabular-nums;font-size:30px;font-weight:600;line-height:1}.stat-card-delta{color:var(--color-text-muted);margin-top:6px;font-size:11.5px}.dashboard-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;display:flex}.dashboard-search-wrap{background:var(--color-surface);border:1px solid var(--color-border-soft);min-width:240px;max-width:380px;height:36px;transition:border-color .15s var(--ease);border-radius:8px;flex:1;align-items:center;gap:8px;padding:0 12px;display:flex;position:relative}.dashboard-search-wrap:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}.dashboard-search-wrap>svg{color:var(--color-text-muted)}.dashboard-search{color:var(--color-text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13px}.dashboard-search::placeholder{color:var(--color-text-muted)}.filter-pills{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:8px;align-items:center;gap:4px;padding:3px;display:inline-flex}.filter-pills .filter-btn{color:var(--color-text-muted);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease);background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:5px 12px;font-family:inherit;font-size:12.5px;font-weight:500;display:inline-flex}.filter-pills .filter-btn:hover{color:var(--color-text)}.filter-pills .filter-btn-active{background:var(--color-bg-canvas);color:var(--color-text);box-shadow:0 0 0 1px var(--color-border) inset}.filter-count{min-width:18px;height:16px;color:var(--color-text-faint);background:var(--color-surface-light);font-variant-numeric:tabular-nums;border-radius:999px;justify-content:center;align-items:center;padding:0 5px;font-size:10.5px;font-weight:500;display:inline-flex}.filter-btn-active .filter-count{background:var(--color-primary-soft);color:var(--color-primary)}.view-toggle{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:8px;gap:2px;margin-left:auto;padding:3px;display:inline-flex}.view-toggle button{width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.view-toggle button:hover{color:var(--color-text)}.view-toggle .view-toggle-active{background:var(--color-bg-canvas);color:var(--color-text);box-shadow:0 0 0 1px var(--color-border) inset}.dashboard-body{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:20px;display:grid}@media (width<=1180px){.dashboard-body{grid-template-columns:1fr}}.project-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.project-card{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s var(--ease), transform .15s var(--ease), box-shadow .15s var(--ease);flex-direction:column;padding:18px;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:linear-gradient(90deg, transparent, var(--color-primary) 50%, transparent);opacity:0;height:1px;transition:opacity .2s var(--ease);position:absolute;top:0;left:0;right:0}.project-card:hover{border-color:var(--color-border);box-shadow:var(--shadow);transform:translateY(-2px)}.project-card:hover:before{opacity:.6}.project-card-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.project-card-id{align-items:center;gap:8px;display:inline-flex}.project-card-mono{background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);height:22px;color:var(--color-primary);font-family:var(--font-mono);letter-spacing:.04em;border-radius:5px;align-items:center;padding:0 8px;font-size:10.5px;font-weight:500;display:inline-flex}.project-card-version{color:var(--color-text-faint);font-size:11px;font-family:var(--font-mono)}.project-pin{width:28px;height:28px;color:var(--color-text-faint);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease);background:0 0;border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;display:inline-flex}.project-pin:hover{background:var(--color-surface-hover);color:var(--color-warning)}.project-pin-on{color:var(--color-warning);background:#f1b85b1a}.project-pin-on svg{fill:var(--color-warning)}.project-card-title{letter-spacing:-.015em;color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:16px;font-weight:600;overflow:hidden}.project-card-customer{color:var(--color-text-muted);align-items:center;gap:5px;margin-bottom:10px;font-size:12px;display:inline-flex}.project-card-customer svg{color:var(--color-text-faint)}.project-card-desc{color:var(--color-text-secondary);-webkit-line-clamp:2;text-wrap:pretty;-webkit-box-orient:vertical;margin-bottom:14px;font-size:12.5px;line-height:1.5;display:-webkit-box;overflow:hidden}.project-card-progress{background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);border-radius:7px;margin:4px 0 14px;padding:9px 11px}.project-card-progress-head{color:var(--color-text-muted);font-size:11px;font-family:var(--font-mono);justify-content:space-between;margin-bottom:6px;display:flex}.project-card-progress-track{background:var(--color-surface-light);border-radius:999px;height:4px;overflow:hidden}.project-card-progress-bar{background:linear-gradient(90deg, var(--color-primary), var(--color-primary-hover));height:100%;transition:width .4s var(--ease);border-radius:999px;position:relative}.project-card-progress-bar:after{content:"";background:linear-gradient(90deg,#0000,#fff6,#0000);animation:1.6s linear infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.project-card-meta{border-bottom:1px solid var(--color-border-soft);flex-wrap:wrap;gap:12px;margin-bottom:14px;padding-bottom:14px;display:flex}.project-card-meta span{color:var(--color-text-muted);font-size:11.5px;font-family:var(--font-mono);align-items:center;gap:4px;display:inline-flex}.project-card-meta svg{color:var(--color-text-faint)}.project-card-foot{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.project-card-edited{color:var(--color-text-muted);font-size:11.5px}.project-card-owner{display:none;position:absolute;top:14px;right:14px}.project-list{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);overflow:hidden}.project-list-head,.project-list-row{grid-template-columns:32px 1.5fr 1fr 1fr auto 110px 36px;align-items:center;gap:16px;height:44px;padding:0 16px;display:grid}.project-list-head{background:var(--color-bg-canvas);letter-spacing:.07em;text-transform:uppercase;height:36px;color:var(--color-text-faint);border-bottom:1px solid var(--color-border-soft);font-size:10.5px;font-weight:500}.project-list-row{border:none;border-bottom:1px solid var(--color-border-soft);text-align:left;cursor:pointer;color:var(--color-text-secondary);transition:background .12s var(--ease);background:0 0;font-family:inherit}.project-list-row:last-child{border-bottom:0}.project-list-row:hover{background:var(--color-surface-hover)}.project-list-name{flex-direction:column;min-width:0;display:flex}.project-list-name strong{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.project-list-name small{color:var(--color-text-muted);font-size:11px;font-family:var(--font-mono)}.project-list-cell{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;overflow:hidden}.project-list-cell.mono{font-family:var(--font-mono);font-size:11.5px}.project-list-arrow{color:var(--color-text-faint);justify-content:flex-end;display:inline-flex}.project-list-row:hover .project-list-arrow{color:var(--color-primary)}.project-pin-list{border-radius:5px;width:24px;height:24px}.dashboard-aside{top:calc(var(--topbar-height) + 16px);flex-direction:column;gap:16px;display:flex;position:sticky}.aside-card{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);padding:16px}.aside-card-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.aside-card-head h3{color:var(--color-text);letter-spacing:-.005em;font-size:12.5px;font-weight:600}.aside-card-link{color:var(--color-primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-family:inherit;font-size:11.5px;font-weight:500;display:inline-flex}.aside-card-link:hover{color:var(--color-primary-hover)}.activity-list{flex-direction:column;gap:4px;list-style:none;display:flex}.activity-row{border-radius:6px;grid-template-columns:28px 1fr auto;align-items:center;gap:10px;padding:8px 4px;display:grid}.activity-row:hover{background:var(--color-surface-hover)}.activity-icon{background:var(--color-surface-light);width:28px;height:28px;color:var(--color-text-muted);border-radius:7px;justify-content:center;align-items:center;display:inline-flex}.activity-icon-success{color:var(--color-success);background:#5bd49a1a}.activity-icon-error{color:var(--color-error);background:#ef6f6c1a}.activity-icon-info{color:var(--color-info);background:#79b7f01a}.activity-icon-warning{color:var(--color-warning);background:#f1b85b1a}.activity-meta{flex-direction:column;min-width:0;display:flex}.activity-title{color:var(--color-text);font-size:12.5px;font-weight:500}.activity-detail{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.activity-time{color:var(--color-text-faint);font-size:10.5px;font-family:var(--font-mono)}.quick-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.quick-action{background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);cursor:pointer;text-align:left;transition:border-color .15s var(--ease), background .15s var(--ease);border-radius:8px;align-items:center;gap:10px;padding:11px;font-family:inherit;display:flex}.quick-action:hover{border-color:var(--color-border);background:var(--color-surface-hover)}.quick-action-icon{background:var(--color-primary-soft);width:30px;height:30px;color:var(--color-primary);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.quick-action-text{flex-direction:column;min-width:0;display:flex}.quick-action-text strong{color:var(--color-text);font-size:12px;font-weight:600}.quick-action-text small{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:10.5px;overflow:hidden}.empty-state{text-align:center;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:8px;padding:60px 30px;display:flex}.empty-state-icon{background:var(--color-primary-soft);width:56px;height:56px;color:var(--color-primary);border-radius:14px;justify-content:center;align-items:center;margin-bottom:8px;display:inline-flex}.empty-state h3{color:var(--color-text);font-size:16px;font-weight:600}.empty-state p{color:var(--color-text-muted);max-width:340px;margin-bottom:12px;font-size:13px}@media (width<=900px){.dashboard{padding:20px 16px 32px}.dashboard-hero{flex-direction:column;align-items:flex-start}.stats-strip{grid-template-columns:repeat(2,1fr)}}.project-setup .setup-header{flex-direction:row;justify-content:space-between;align-items:flex-end;gap:24px}.setup-meta{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius);gap:8px;padding:8px;display:flex}.setup-meta-item{border-right:1px solid var(--color-border-soft);flex-direction:column;min-width:110px;padding:6px 14px;display:flex}.setup-meta-item:last-child{border-right:0}.setup-meta-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint);font-size:10.5px;font-weight:500}.setup-meta-value{color:var(--color-text);text-transform:capitalize;margin-top:2px;font-size:13px;font-weight:500}.setup-meta-value.mono{font-family:var(--font-mono);text-transform:none}.setup-form{flex-direction:column;gap:16px;display:flex}.setup-actions{justify-content:flex-end;align-items:center;gap:10px;padding:12px 0 0;display:flex;position:sticky;bottom:0}.setup-saved{color:var(--color-success);align-items:center;gap:6px;margin-right:auto;font-size:12.5px;display:inline-flex}.components-page .catalog-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.components-page .catalog-header-left{align-items:baseline;gap:10px;display:flex}.components-page .catalog-count{background:var(--color-surface-light);border:1px solid var(--color-border-soft);color:var(--color-text-muted);font-size:11.5px;font-family:var(--font-mono);border-radius:999px;align-items:center;padding:1px 8px;display:inline-flex}.components-page .catalog-search-wrap{align-items:center;width:320px;max-width:50%;display:flex;position:relative}.components-page .catalog-search-wrap svg{color:var(--color-text-faint);position:absolute;left:11px}.components-page .catalog-search{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);padding:8px 12px 8px 32px;font-family:inherit;font-size:13px}.components-page .catalog-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.components-page .catalog-filters{flex-wrap:wrap;gap:6px;display:flex}.catalog-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.catalog-card{background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);border-radius:var(--radius);transition:border-color .15s var(--ease), background .15s var(--ease), transform .15s var(--ease);flex-direction:column;gap:8px;padding:16px;display:flex;position:relative}.catalog-card:hover{border-color:var(--color-border-strong);transform:translateY(-1px)}.catalog-card-added{background:var(--color-primary-soft);border-color:#5ce6e059}.catalog-card-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.catalog-category{letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary);font-size:10.5px;font-weight:600}.catalog-comm{color:var(--color-text-muted);background:var(--color-surface-light);border:1px solid var(--color-border-soft);border-radius:4px;padding:1px 7px;font-size:11px}.catalog-name{color:var(--color-text);letter-spacing:-.005em;font-size:14px;font-weight:600}.catalog-type{color:var(--color-text-secondary);font-size:12px}.catalog-desc{color:var(--color-text-muted);flex:1;font-size:12.5px;line-height:1.5}.catalog-foot{justify-content:flex-end;margin-top:4px;display:flex}.selected-components .actions-cell{text-align:right;white-space:nowrap;width:1%}.empty-state{border:1px dashed var(--color-border);border-radius:var(--radius);background:var(--color-bg-canvas);flex-direction:column;align-items:center;gap:6px;padding:36px 20px;display:flex}.empty-icon{background:var(--color-surface-light);border:1px solid var(--color-border);width:36px;height:36px;color:var(--color-text-muted);border-radius:999px;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.empty-state-title{color:var(--color-text);font-size:14px;font-weight:500}.empty-state-text{color:var(--color-text-muted);font-size:12.5px}.validation-panel{flex-direction:column;gap:12px;display:flex}.validation-header{justify-content:space-between;align-items:center;display:flex}.validation-header h3{letter-spacing:-.005em;font-size:13px;font-weight:600}.validation-counts{flex-wrap:wrap;gap:4px;display:flex}.count-pill{letter-spacing:.02em;border-radius:999px;padding:1px 7px;font-size:10.5px;font-weight:500}.count-error{color:var(--color-error);background:#ef6f6c21;border:1px solid #ef6f6c47}.count-warning{color:var(--color-warning);background:#f1b85b21;border:1px solid #f1b85b40}.count-info{color:var(--color-info);background:#79b7f01f;border:1px solid #79b7f038}.validation-empty{color:var(--color-success);border-radius:var(--radius-sm);background:#5bd49a0f;border:1px dashed #5bd49a40;flex-direction:column;align-items:center;gap:6px;padding:22px 8px;font-size:12.5px;display:flex}.validation-list{flex-direction:column;gap:6px;list-style:none;display:flex}.validation-item{border-radius:var(--radius-sm);background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);cursor:pointer;transition:border-color .15s var(--ease), background .15s var(--ease);gap:10px;padding:10px;display:flex}.validation-item:hover{border-color:var(--color-border-strong)}.validation-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.validation-icon-error{color:var(--color-error);background:#ef6f6c1f}.validation-icon-warning{color:var(--color-warning);background:#f1b85b1f}.validation-icon-info{color:var(--color-info);background:#79b7f01f}.validation-content{flex-direction:column;gap:2px;min-width:0;display:flex}.validation-message{color:var(--color-text);font-size:12.5px;line-height:1.4}.validation-path{color:var(--color-text-faint);font-size:11px}.config-layout{grid-template-columns:240px minmax(0,1fr) 280px;align-items:start;gap:16px;display:grid}@media (width<=1180px){.config-layout{grid-template-columns:220px 1fr}.config-validation{grid-column:1/-1}}.config-sidebar{padding:14px}.config-list{flex-direction:column;gap:4px;list-style:none;display:flex}.config-list-item{border-radius:var(--radius-sm);cursor:pointer;transition:background .12s var(--ease), border-color .12s var(--ease);border:1px solid #0000;align-items:center;gap:10px;padding:8px 10px;display:flex}.config-list-item:hover{background:var(--color-surface-hover)}.config-list-active{background:var(--color-primary-soft);border-color:#5ce6e04d}.config-list-active .config-list-name{color:var(--color-text)}.config-dot{flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.config-dot.is-on{color:var(--color-success)}.config-dot.is-off{color:var(--color-text-faint)}.config-list-body{flex-direction:column;min-width:0;display:flex}.config-list-name{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.config-list-type{color:var(--color-text-faint);font-size:11px}.config-main{padding:0;overflow:hidden}.config-tabs-row{border-bottom:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;padding:0 16px;display:flex}.config-tabs-row .tab-row{border-bottom:0}.mode-toggle{color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:12px;display:inline-flex}.config-content{padding:20px}.config-section{flex-direction:column;gap:14px;max-width:720px;display:flex}.config-validation{padding:16px}.mapping-overview{grid-template-columns:1fr auto;align-items:center;gap:24px;display:grid}.overview-stat{flex-direction:column;gap:8px;min-width:0;display:flex}.overview-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint);font-size:11px}.overview-value-row{align-items:baseline;gap:10px;display:flex}.overview-value{letter-spacing:-.02em;color:var(--color-text);font-variant-numeric:tabular-nums;font-size:28px;font-weight:600}.overview-sub{color:var(--color-text-muted);font-size:13px;font-family:var(--font-mono)}.overview-stats{gap:8px;display:flex}.overview-pill{border-radius:var(--radius);background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);min-width:96px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 14px;font-size:11.5px;display:flex}.overview-pill-num{font-size:18px;font-weight:600;font-family:var(--font-mono);color:var(--color-text);text-transform:none;letter-spacing:0}.overview-pill.stat-mapped{border-color:#5bd49a40}.overview-pill.stat-mapped .overview-pill-num{color:var(--color-success)}.overview-pill.stat-unmapped{border-color:#f1b85b40}.overview-pill.stat-unmapped .overview-pill-num{color:var(--color-warning)}.overview-pill.stat-invalid{border-color:#ef6f6c47}.overview-pill.stat-invalid .overview-pill-num{color:var(--color-error)}.mapping-controls{justify-content:space-between;align-items:center;gap:16px;display:flex}.mapping-filters{flex-wrap:wrap;gap:6px;display:flex}.mapping-actions{gap:6px;display:flex}.mapping-table .mapping-arrow{text-align:center;width:32px;color:var(--color-text-faint)}.mapping-row.mapping-mapped .mapping-arrow{color:var(--color-success)}.mapping-row.mapping-invalid .mapping-arrow{color:var(--color-error)}.vendor-cell{flex-direction:column;display:flex}.vendor-name{color:var(--color-text);font-size:13px}.vendor-detail{color:var(--color-text-muted);font-size:11.5px}.mapping-empty{color:var(--color-text-faint);font-size:12.5px;font-style:italic}.modes-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.mode-card{transition:border-color .15s var(--ease), background .15s var(--ease);gap:10px}.mode-card.mode-active{background:linear-gradient(180deg, var(--color-primary-soft), var(--color-surface));border-color:#5ce6e04d}.mode-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.mode-title-block{flex-direction:column;gap:4px;display:flex}.mode-card h3{letter-spacing:-.005em;font-size:14px;font-weight:600}.mode-state{text-transform:uppercase;letter-spacing:.1em;font-size:10.5px;font-weight:500}.mode-state.on{color:var(--color-success)}.mode-state.off{color:var(--color-text-faint)}.mode-desc{color:var(--color-text-muted);font-size:13px;line-height:1.5}.recovery-cell,.condition-cell{color:var(--color-text-muted);font-size:12.5px}.sequence-columns{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=980px){.sequence-columns{grid-template-columns:1fr}}.sequence-list{flex-direction:column;gap:4px;list-style:none;display:flex}.sequence-list li{border-radius:var(--radius-sm);background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);grid-template-columns:36px 1fr auto;align-items:center;gap:12px;padding:10px 12px;display:grid}.seq-step{font-family:var(--font-mono);color:var(--color-primary);background:var(--color-primary-soft);text-align:center;border:1px solid #5ce6e04d;border-radius:4px;padding:2px 6px;font-size:11px}.seq-action{color:var(--color-text);font-size:13px}.seq-timeout{color:var(--color-text-muted);font-size:11.5px}.controller-cards{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.controller-card{background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);border-radius:var(--radius);cursor:pointer;transition:border-color .15s var(--ease), transform .15s var(--ease), background .15s var(--ease);flex-direction:column;gap:4px;padding:16px;display:flex;position:relative}.controller-card:hover{border-color:var(--color-border-strong);transform:translateY(-1px)}.controller-selected{border-color:var(--color-primary);background:var(--color-primary-soft)}.controller-check{background:var(--color-primary);width:22px;height:22px;color:var(--color-primary-text);border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:12px;right:12px}.controller-family{text-transform:uppercase;letter-spacing:.12em;color:var(--color-primary);font-size:10.5px;font-weight:600}.controller-model{letter-spacing:-.01em;color:var(--color-text);font-size:16px;font-weight:600}.controller-meta{color:var(--color-text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.details-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.compat-row{border-radius:var(--radius-sm);align-items:center;gap:10px;padding:10px 14px;font-size:13px;display:flex}.compat-ok{color:var(--color-text);background:#5bd49a14;border:1px solid #5bd49a40}.compat-icon{background:var(--color-success);color:#06291a;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.build-controls .build-row{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}@media (width<=720px){.build-controls .build-row{grid-template-columns:1fr}}.build-actions{border-top:1px solid var(--color-border-soft);flex-wrap:wrap;gap:8px;padding-top:14px;display:flex}.build-progress{gap:12px}.progress-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.progress-label{align-items:center;gap:10px;display:flex}.progress-id{color:var(--color-text-faint);font-size:11.5px}.progress-profile{color:var(--color-text);font-size:13px;font-weight:500}.progress-pct{color:var(--color-primary);font-variant-numeric:tabular-nums;font-size:13px}.build-log{background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);max-height:280px;padding:12px 14px;font-size:12px;line-height:1.6;overflow:auto}.log-line{color:var(--color-text-secondary);grid-template-columns:36px 1fr;gap:12px;display:grid}.log-line-num{color:var(--color-text-faint);text-align:right;-webkit-user-select:none;user-select:none}.artifacts-page .actions-cell{white-space:nowrap;text-align:right;width:1%}.artifact-summary{grid-template-columns:auto 1fr auto;align-items:center;gap:18px;display:grid}.artifact-icon{background:var(--color-primary-soft);width:44px;height:44px;color:var(--color-primary);border:1px solid #5ce6e04d;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.artifact-info{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:4px 16px;display:grid}.artifact-info-line{align-items:baseline;gap:8px;font-size:12.5px;display:flex}.artifact-info-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint);min-width:64px;font-size:10.5px}.artifact-info-value{color:var(--color-text)}.artifact-name{font-weight:500}.vh-timeline{flex-direction:column;list-style:none;display:flex}.vh-row{grid-template-columns:44px 1fr;gap:12px;padding-bottom:18px;display:grid}.vh-row:last-child{padding-bottom:0}.vh-rail{flex-direction:column;align-items:center;display:flex;position:relative}.vh-dot{background:var(--color-bg-canvas);border:1px solid var(--color-border);width:28px;height:28px;color:var(--color-text-muted);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.vh-row-current .vh-dot{background:var(--color-primary-soft);border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 0 0 4px #5ce6e014}.vh-line{background:var(--color-border-soft);flex:1;width:1px;margin-top:4px}.vh-content{background:var(--color-bg-canvas);border:1px solid var(--color-border-soft);border-radius:var(--radius);flex-direction:column;gap:8px;padding:14px 16px;display:flex}.vh-row-current .vh-content{border-color:#5ce6e04d}.vh-content-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.vh-version{align-items:center;gap:8px;display:flex}.vh-tag{color:var(--color-text);background:var(--color-surface-light);border:1px solid var(--color-border-soft);border-radius:5px;padding:2px 8px;font-size:13px;font-weight:600}.vh-current-badge{letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary);background:var(--color-primary-soft);border:1px solid #5ce6e04d;border-radius:999px;padding:1px 7px;font-size:10.5px;font-weight:600}.vh-actions{gap:6px;display:flex}.vh-notes{color:var(--color-text-secondary);font-size:13px;line-height:1.5}.vh-meta{color:var(--color-text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.vh-author{align-items:center;gap:8px;display:inline-flex}.vh-avatar{background:var(--color-surface-light);border:1px solid var(--color-border);letter-spacing:0;width:22px;height:22px;color:var(--color-text);border-radius:999px;justify-content:center;align-items:center;font-size:10.5px;font-weight:600;display:inline-flex}.vh-meta-sep{color:var(--color-text-faint)}.btn-primary,.btn-secondary,.btn-danger{border-radius:var(--radius-sm);letter-spacing:-.005em;cursor:pointer;transition:background .15s var(--ease), border-color .15s var(--ease), color .15s var(--ease), transform 80ms var(--ease);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;align-items:center;gap:6px;padding:7px 13px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.btn-primary:active,.btn-secondary:active,.btn-danger:active{transform:translateY(.5px)}.btn-primary{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary-soft), 0 1px 0 #ffffff14 inset}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-border-strong)}.btn-danger{color:var(--color-error);border-color:var(--color-border);background:0 0}.btn-danger:hover{border-color:var(--color-error);background:#ef6f6c1f}.btn-sm{border-radius:5px;gap:4px;padding:4px 9px;font-size:12px}.form-group{flex-direction:column;flex:1;gap:6px;display:flex}.form-group label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-size:11.5px;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:border-color .15s var(--ease), background .15s var(--ease);padding:9px 12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.form-group input[readonly]{opacity:.7;cursor:default}.form-group textarea{resize:vertical}.form-row{gap:16px;display:flex}.status-badge{letter-spacing:0;white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:5px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.status-badge:before{content:"";background:currentColor;border-radius:999px;width:6px;height:6px}.badge-success{color:var(--color-success);background:#5bd49a1f;border-color:#5bd49a40}.badge-warning{color:var(--color-warning);background:#f1b85b21;border-color:#f1b85b40}.badge-error{color:var(--color-error);background:#ef6f6c21;border-color:#ef6f6c47}.badge-info{color:var(--color-info);background:#79b7f021;border-color:#79b7f040}.badge-default{color:var(--color-text-secondary);border-color:var(--color-border);background:#b4bcc71a}.components-table{border-collapse:separate;border-spacing:0;background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius);width:100%;font-size:13px;overflow:hidden}.components-table th,.components-table td{text-align:left;border-bottom:1px solid var(--color-border-soft);padding:11px 16px}.components-table th{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-faint);background:var(--color-bg-canvas);white-space:nowrap;font-size:10.5px;font-weight:500}.components-table tbody tr:last-child td{border-bottom:0}.components-table tbody tr{transition:background .12s var(--ease)}.components-table tbody tr:hover{background:var(--color-surface-hover)}.components-table td{color:var(--color-text-secondary);vertical-align:middle}.mono{font-family:var(--font-mono);font-size:12px}.filter-btn{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:all .15s var(--ease);border-radius:999px;padding:4px 11px;font-family:inherit;font-size:12px;font-weight:500}.filter-btn:hover{border-color:var(--color-border-strong);color:var(--color-text)}.filter-btn-active{background:var(--color-primary-soft);color:var(--color-primary);border-color:#5ce6e066}.page-shell{flex-direction:column;gap:24px;width:100%;max-width:1480px;margin:0 auto;padding:28px 32px 48px;display:flex}.page-header{flex-direction:column;gap:6px;display:flex}.page-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-faint);font-size:11px;font-weight:600}.page-title{letter-spacing:-.018em;color:var(--color-text);font-size:24px;font-weight:600}.page-subtitle{color:var(--color-text-muted);max-width:720px;font-size:13.5px}.section-card{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);flex-direction:column;gap:16px;padding:20px;display:flex}.section-card-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.section-card-header h2,.section-card-header h3{letter-spacing:-.01em;color:var(--color-text);font-size:14px;font-weight:600}.section-desc,.muted-text,.empty-text{color:var(--color-text-muted);font-size:13px}.tab-row{border-bottom:1px solid var(--color-border-soft);gap:4px;padding:0 4px;display:flex}.tab-btn{cursor:pointer;color:var(--color-text-muted);transition:color .15s var(--ease), border-color .15s var(--ease);background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:500}.tab-btn:hover{color:var(--color-text)}.tab-btn-active{color:var(--color-text);border-color:var(--color-primary)}.toggle-switch{cursor:pointer;width:34px;height:20px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{background:var(--color-surface-light);border:1px solid var(--color-border);transition:background .15s var(--ease), border-color .15s var(--ease);border-radius:999px;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--color-text-muted);width:14px;height:14px;transition:transform .18s var(--ease), background .15s var(--ease);border-radius:50%;position:absolute;top:2px;left:2px}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary-soft);border-color:#5ce6e073}.toggle-switch input:checked+.toggle-slider:before{background:var(--color-primary);transform:translate(14px)}.toggle-sm{width:30px;height:18px}.toggle-sm .toggle-slider:before{width:12px;height:12px}.toggle-sm input:checked+.toggle-slider:before{transform:translate(12px)}.bar-track{background:var(--color-surface-light);border:1px solid var(--color-border-soft);border-radius:999px;height:6px;overflow:hidden}.bar-fill{background:linear-gradient(90deg, var(--color-primary) 0%, var(--color-info) 100%);height:100%;transition:width .3s var(--ease);border-radius:999px}.bar-fill-success{background:var(--color-success)}.bar-fill-error{background:var(--color-error)}.icon-btn{width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease);background:0 0;border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;font-family:inherit;display:inline-flex}.icon-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}
