*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#09090B;--bg-surface:#18181B;--bg-card:rgba(24,24,27,0.72);--bg-elevated:#27272A;--border:#27272A;--border-hover:#3F3F46;--text:rgba(255,255,255,0.92);--text-secondary:rgba(255,255,255,0.70);--text-muted:rgba(255,255,255,0.45);--text-faint:rgba(255,255,255,0.25);--accent:#6366F1;--accent-dark:#4F46E5;--accent-light:#818CF8;--accent-glow:rgba(99,102,241,0.25);--accent-agent:#F59E0B;--accent-emerald:#10b981;--accent-amber:#f59e0b;--accent-rose:#f43f5e;--overlay-faint:rgba(255,255,255,0.03);--overlay-subtle:rgba(255,255,255,0.06);--overlay-low:rgba(255,255,255,0.08);--overlay-medium:rgba(255,255,255,0.12);--card-bg:rgba(255,255,255,0.025);--card-bg-hover:rgba(255,255,255,0.04);--section-border:rgba(255,255,255,0.06);--nav-scrolled-bg:rgba(9,9,11,0.92);--code-bg:rgba(255,255,255,0.06);--input-bg:rgba(255,255,255,0.04);--radius:10px;--font-mono:"JetBrains Mono","Fira Code","Cascadia Code",ui-monospace,monospace}[data-theme=light]{--bg:#FFFFFF;--bg-surface:#F4F4F5;--bg-card:rgba(244,244,245,0.85);--bg-elevated:#E4E4E7;--border:#E4E4E7;--border-hover:#D4D4D8;--text:rgba(9,9,11,0.92);--text-secondary:rgba(9,9,11,0.70);--text-muted:rgba(9,9,11,0.55);--text-faint:rgba(9,9,11,0.35);--accent-glow:rgba(99,102,241,0.20);--overlay-faint:rgba(0,0,0,0.025);--overlay-subtle:rgba(0,0,0,0.05);--overlay-low:rgba(0,0,0,0.07);--overlay-medium:rgba(0,0,0,0.10);--card-bg:rgba(0,0,0,0.025);--card-bg-hover:rgba(0,0,0,0.04);--section-border:rgba(0,0,0,0.08);--nav-scrolled-bg:rgba(255,255,255,0.92);--code-bg:rgba(0,0,0,0.05);--input-bg:rgba(0,0,0,0.03)}html{scroll-behavior:auto}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.capability-link:hover{color:var(--text)!important}code{font-family:var(--font-mono);font-size:.875em;background:var(--code-bg);border:1px solid var(--border);border-radius:4px;padding:1px 5px}pre{border-radius:var(--radius);overflow:hidden}pre code{background:none;border:none;padding:0;font-size:.8rem}h1,h2,h3,h4{color:var(--text);font-weight:700;line-height:1.25}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 32px 8px var(--accent-glow)}}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.demo-root{display:flex;flex-direction:column;height:100dvh;background:var(--bg)}.demo-topbar{display:flex;align-items:center;height:48px;padding:0 20px;gap:14px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;z-index:100}.demo-topbar__logo{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.demo-topbar__logo-mark{width:24px;height:24px;border-radius:6px;background:linear-gradient(135deg,#6366F1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;color:#fff}.demo-topbar__badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:99px;background:rgba(99,102,241,.15);color:#818CF8;border:1px solid rgba(99,102,241,.3);text-transform:uppercase;letter-spacing:.08em}.demo-topbar__spacer{flex:1 1}.demo-topbar__status{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted)}.demo-topbar__status-dot{width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 6px #10b981}.demo-topbar__theme-toggle{background:none;border:1px solid var(--border);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:background .15s,border-color .15s}.demo-topbar__theme-toggle:hover{background:var(--overlay-subtle);border-color:var(--border-hover)}.demo-topbar__back,.demo-topbar__docs-link{font-size:12px;color:var(--text-muted);text-decoration:none;padding:4px 8px;border-radius:6px;transition:color .15s,background .15s}.demo-topbar__back:hover,.demo-topbar__docs-link:hover{color:var(--text-secondary);background:var(--overlay-subtle)}.demo-scenario-picker{display:flex;gap:4px;align-items:center;background:var(--bg);border-radius:10px;padding:3px;border:1px solid var(--border)}.demo-scenario-btn{display:flex;align-items:center;gap:5px;padding:4px 12px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.demo-scenario-btn:hover{background:var(--overlay-subtle);color:var(--text-secondary)}.demo-scenario-btn--active{background:var(--bg-surface);border-color:var(--accent);color:var(--accent);box-shadow:0 1px 4px rgba(99,102,241,.2)}.demo-scenario-btn__icon{font-size:.82rem}@media (max-width:900px){.demo-scenario-btn__label{display:none}.demo-scenario-btn{padding:4px 8px}}.demo-scenario-info{padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.demo-scenario-info__desc{font-size:.75rem;color:var(--text-muted);line-height:1.5;margin-bottom:6px}.demo-scenario-info__stats{font-size:.68rem;font-weight:600;color:var(--text-faint);font-family:var(--font-mono);letter-spacing:.02em}.demo-export-bar{margin-top:4px}.demo-export-btns{display:flex;gap:6px;margin-top:4px}.demo-export-btn{flex:1 1;font-size:.72rem;font-weight:600;padding:7px 0;border-radius:6px;background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:all .15s ease}.demo-export-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.demo-export-btn:active:not(:disabled){transform:scale(.96)}.demo-export-btn:disabled{opacity:.4;cursor:not-allowed}.demo-main{display:flex;flex:1 1;min-height:0}.demo-canvas{flex:1 1;min-width:0;position:relative}.demo-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-surface);border-left:1px solid var(--border);overflow:hidden}.demo-sidebar__header{padding:14px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted);border-bottom:1px solid var(--border);flex-shrink:0}.demo-sidebar__body{flex:1 1;overflow-y:auto;padding:12px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.demo-agent-input{padding:12px;border-top:1px solid var(--border);flex-shrink:0}.demo-agent-input textarea{width:100%;min-height:80px;background:var(--input-bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:12px;padding:10px 12px;resize:none;outline:none;font-family:inherit;line-height:1.6;transition:border-color .15s}.demo-agent-input textarea:focus{border-color:rgba(99,102,241,.5)}.demo-agent-input textarea::placeholder{color:var(--text-faint)}.demo-agent-input__footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.demo-agent-input__hint{font-size:10px;color:var(--text-faint)}.demo-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:all .15s}.demo-btn--primary{background:linear-gradient(135deg,#6366F1,#4F46E5);color:#fff;box-shadow:0 2px 10px rgba(99,102,241,.35)}.demo-btn--primary:hover{background:linear-gradient(135deg,#818CF8,#6366F1);box-shadow:0 2px 16px rgba(99,102,241,.5)}.demo-btn--primary:disabled{opacity:.5;cursor:not-allowed}.demo-palette{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.demo-palette-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border-hover);cursor:pointer;transition:all .15s;font-size:12px;color:var(--text-muted);font-weight:500}.demo-palette-item:hover{background:var(--border-hover);color:var(--text);border-color:var(--border-hover)}.demo-palette-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px}.demo-palette-icon--chart{background:rgba(99,102,241,.2)}.demo-palette-icon--table{background:rgba(16,185,129,.2)}.demo-palette-icon--note{background:rgba(245,158,11,.2)}.demo-agent-log{display:flex;flex-direction:column;gap:8px}.demo-log-entry{padding:8px 10px;border-radius:8px;font-size:11px;line-height:1.5}.demo-log-entry--agent{background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.18);color:var(--text-secondary)}.demo-log-entry--system{background:var(--bg-elevated);border:1px solid var(--border-hover);color:var(--text-muted)}.demo-log-entry--error{background:rgba(244,63,94,.08);border:1px solid rgba(244,63,94,.2);color:#e11d48}.demo-log-entry__header{display:flex;align-items:center;gap:6px;margin-bottom:4px;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.demo-log-entry__dot{width:5px;height:5px;border-radius:50%;background:var(--text-faint)}.demo-log-entry__dot--agent{background:#0ea5e9}.demo-log-entry__dot--error{background:#f43f5e}.demo-log-entry__dot--system{background:var(--text-faint)}.demo-sidebar__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin-bottom:8px}.demo-spinner{width:10px;height:10px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:inline-block;animation:demo-spin .7s linear infinite}@keyframes demo-spin{to{transform:rotate(1turn)}}.hero-preview-frame:hover .hero-preview-overlay{background:rgba(0,0,0,.35)!important}.hero-preview-frame:hover .hero-preview-cta{opacity:1!important;transform:translateY(0)!important}.hero-loading-bar{height:100%;width:40%;background:linear-gradient(90deg,transparent,var(--accent),transparent);border-radius:2px;animation:hero-loading-slide 1.4s ease-in-out infinite}@keyframes hero-loading-slide{0%{transform:translateX(-100%)}to{transform:translateX(350%)}}body:has(.ws-root){overflow:hidden}.ws-root{display:flex;flex-direction:column;height:100dvh;background:var(--bg);color:var(--text)}.ws-topbar{display:flex;align-items:center;gap:12px;height:48px;padding:0 16px;flex-shrink:0;background:var(--bg-card);border-bottom:1px solid var(--border);font-size:.82rem}.ws-topbar__back{color:var(--text-muted);text-decoration:none;font-size:.78rem}.ws-topbar__back:hover{color:var(--text)}.ws-topbar__title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.88rem}.ws-topbar__logo-mark{width:24px;height:24px;border-radius:6px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.72rem}.ws-topbar__spacer{flex:1 1}.ws-topbar__status{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.75rem}.ws-topbar__status-dot{width:6px;height:6px;border-radius:50%;background:#10b981}.ws-topbar__theme{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 8px;cursor:pointer;font-size:.82rem}.ws-topbar__docs{color:var(--accent);text-decoration:none;font-size:.78rem;font-weight:600}.ws-topbar__docs:hover{text-decoration:underline}.ws-main{flex:1 1}.ws-chat,.ws-main{display:flex;min-height:0}.ws-chat{flex-direction:column;flex:1 1;background:var(--bg-card)}.ws-chat__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.ws-chat__logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.85rem}.ws-chat__logo-mark{width:22px;height:22px;border-radius:5px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.65rem}.ws-chat__data-badge{font-size:.68rem;padding:2px 8px;border-radius:10px;background:var(--accent-bg,rgba(99,102,241,.12));color:var(--accent);font-weight:600}.ws-chat__messages{flex:1 1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.ws-msg{display:flex;gap:10px;max-width:100%}.ws-msg--system{justify-content:center}.ws-msg--system .ws-msg__avatar{display:none}.ws-msg--system .ws-msg__body{font-size:.75rem;color:var(--text-muted);background:var(--bg);border-radius:8px;padding:8px 14px;text-align:center;max-width:90%}.ws-msg__avatar{width:28px;height:28px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;text-transform:uppercase}.ws-msg--user .ws-msg__avatar{background:var(--accent);color:#fff}.ws-msg--assistant .ws-msg__avatar{background:linear-gradient(135deg,#6366F1,#8b5cf6);color:#fff}.ws-msg__body{flex:1 1;min-width:0;background:var(--bg);border-radius:10px;padding:10px 14px;font-size:.82rem;line-height:1.55}.ws-msg--user .ws-msg__body{background:var(--accent-bg,rgba(99,102,241,.08))}.ws-msg__content p{margin:0}.ws-msg__content strong{color:var(--text);font-weight:600}.ws-msg__h2{font-size:.95rem;font-weight:700;margin:0 0 6px}.ws-msg__h3{font-size:.88rem;font-weight:700;margin:0 0 4px;color:var(--text)}.ws-msg__h4{font-size:.82rem;font-weight:600;margin:0 0 4px}.ws-msg__li,.ws-msg__p{margin:2px 0}.ws-msg__li{display:flex;gap:6px}.ws-msg__bullet{color:var(--accent);font-weight:700;flex-shrink:0;width:14px}.ws-msg__inline-code{background:var(--bg-card);padding:1px 5px;border-radius:4px;font-size:.78rem;font-family:SF Mono,Fira Code,monospace}.ws-msg__code{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-size:.75rem;font-family:SF Mono,Fira Code,monospace}.ws-msg__code,.ws-msg__table-wrap{overflow-x:auto;margin:6px 0}.ws-msg__table{border-collapse:collapse;font-size:.72rem;width:100%}.ws-msg__table td,.ws-msg__table th{padding:4px 8px;text-align:left;border-bottom:1px solid var(--border)}.ws-msg__table th{font-weight:600;color:var(--text-muted)}.ws-msg__files{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.ws-file-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:.72rem;background:var(--accent-bg,rgba(99,102,241,.1));color:var(--accent);font-weight:500;border:1px solid rgba(99,102,241,.2)}.ws-file-chip__meta{color:var(--text-muted);font-weight:400}.ws-chat__sources{border-top:1px solid var(--border);padding:10px 16px;display:flex;flex-direction:column;gap:8px;max-height:160px;overflow-y:auto}.ws-source-card{padding:8px 12px;border-radius:8px;background:var(--bg);border:1px solid var(--border)}.ws-source-card__name{font-weight:600;font-size:.78rem}.ws-source-card__meta{font-size:.68rem}.ws-col-tag{padding:1px 6px;border-radius:4px;font-weight:500;font-family:SF Mono,monospace}.ws-col-tag--string{color:#818cf8}.ws-col-tag--more{background:var(--bg-card)}.ws-chat__input{display:flex;align-items:flex-end;gap:6px;padding:12px 16px;border-top:1px solid var(--border)}.ws-chat__upload-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:8px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .15s}.ws-chat__upload-btn:hover{color:var(--accent);border-color:var(--accent)}.ws-chat__textarea{flex:1 1;min-height:38px;max-height:160px;resize:none;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:8px 12px;font-size:.82rem;color:var(--text);font-family:inherit;line-height:1.45;outline:none;transition:border-color .15s}.ws-chat__textarea:focus{border-color:var(--accent)}.ws-chat__textarea::placeholder{color:var(--text-muted)}.ws-chat__send-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.ws-chat__send-btn:disabled{opacity:.4;cursor:default}.ws-chat__send-btn:not(:disabled):hover{opacity:.9}.ws-chat__hint{text-align:center;font-size:.65rem;color:var(--text-muted);padding:4px 16px 10px;opacity:.7}.ws-thinking{display:flex;align-items:center;gap:6px;padding:4px 0}.ws-thinking__dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:ws-bounce 1.2s ease-in-out infinite}.ws-thinking__dot:nth-child(2){animation-delay:.15s}.ws-thinking__dot:nth-child(3){animation-delay:.3s}.ws-thinking__label{font-size:.75rem;color:var(--text-muted);margin-left:4px}@keyframes ws-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.ws-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.ws-rail{width:60px;flex-shrink:0;gap:4px;padding:8px 6px;background:var(--bg);border-right:1px solid var(--border)}.ws-rail,.ws-rail__btn{display:flex;flex-direction:column}.ws-rail__btn{align-items:center;gap:2px;padding:8px 4px;border-radius:8px;border:none;cursor:pointer;background:transparent;color:var(--text-muted);font-size:.58rem;transition:all .15s}.ws-rail__btn:hover{background:var(--bg-card);color:var(--text)}.ws-rail__btn--active{background:var(--accent-bg,rgba(99,102,241,.12));color:var(--accent)}.ws-rail__icon{font-size:1.1rem;line-height:1}.ws-rail__label{font-weight:600;letter-spacing:.01em}.ws-sidebar{width:400px;flex-shrink:0;border-right:1px solid var(--border);background:var(--bg-card)}.ws-panel,.ws-sidebar{display:flex;flex-direction:column;overflow:hidden}.ws-panel{height:100%}.ws-panel__header{padding:14px 16px 10px;border-bottom:1px solid var(--border)}.ws-panel__title{font-size:.88rem;font-weight:700;margin:0}.ws-panel__subtitle{font-size:.72rem;color:var(--text-muted);margin:4px 0 0}.ws-panel__content{flex:1 1;overflow-y:auto;padding:16px}.ws-panel__footer{padding:10px 16px;border-top:1px solid var(--border);font-size:.68rem;color:var(--text-muted)}.ws-panel__section{padding:12px 16px;border-top:1px solid var(--border)}.ws-panel__section-title{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.ws-subtabs{display:flex;padding:6px 12px;gap:4px;border-bottom:1px solid var(--border)}.ws-subtab{padding:5px 10px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s}.ws-subtab:hover{background:var(--bg);color:var(--text)}.ws-subtab--active{background:var(--accent-bg,rgba(99,102,241,.12));color:var(--accent)}.ws-templates{flex:1 1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px}.ws-template-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:10px;background:var(--bg);border:1px solid var(--border);cursor:pointer;transition:all .2s;text-align:left;width:100%;color:inherit}.ws-template-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.ws-template-card__icon{width:44px;height:44px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.ws-template-card__body{flex:1 1;min-width:0}.ws-template-card__name{font-weight:700;font-size:.82rem}.ws-template-card__desc{font-size:.7rem;color:var(--text-muted);margin-top:3px;line-height:1.4}.ws-template-card__meta{font-size:.65rem;color:var(--accent);font-weight:600;margin-top:4px}.ws-template-card__arrow{color:var(--text-muted);font-size:1rem;flex-shrink:0}.ws-connect-section{display:flex;flex-direction:column;gap:10px}.ws-connect-label{font-size:.72rem;font-weight:600;color:var(--text-muted)}.ws-connect-input{width:100%;padding:8px 12px;border-radius:8px;background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:.8rem;font-family:inherit;outline:none}.ws-connect-input:focus{border-color:var(--accent)}.ws-connect-textarea{width:100%;padding:8px 12px;border-radius:8px;resize:vertical;background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:.75rem;font-family:SF Mono,Fira Code,monospace;outline:none;min-height:120px}.ws-connect-textarea:focus{border-color:var(--accent)}.ws-connect-row{display:flex;align-items:center;justify-content:space-between}.ws-connect-toggle{display:flex;gap:4px}.ws-connect-toggle__btn{padding:4px 12px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s}.ws-connect-toggle__btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.ws-connect-action{padding:8px 16px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:opacity .15s}.ws-connect-action:disabled{opacity:.4;cursor:default}.ws-connect-action:not(:disabled):hover{opacity:.9}.ws-connect-dropzone{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 20px;border-radius:12px;border:2px dashed var(--border);background:transparent;cursor:pointer;transition:all .2s;width:100%;color:inherit}.ws-connect-dropzone:hover{border-color:var(--accent);background:var(--accent-bg,rgba(99,102,241,.04))}.ws-connect-dropzone__icon{color:var(--text-muted)}.ws-connect-dropzone__text{font-size:.78rem;text-align:center}.ws-connect-dropzone__text strong{color:var(--accent)}.ws-connect-dropzone__formats{font-size:.65rem;color:var(--text-muted)}.ws-export-section{display:flex;flex-direction:column;gap:8px}.ws-export-desc{font-size:.75rem;color:var(--text-muted);line-height:1.5}.ws-export-desc code{font-size:.72rem;background:var(--bg);padding:1px 5px;border-radius:4px}.ws-export-code-wrap{position:relative}.ws-export-copy{position:absolute;top:8px;right:8px;z-index:2;padding:3px 10px;border-radius:5px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:.65rem;font-weight:600;cursor:pointer;transition:all .15s}.ws-export-copy:hover{color:var(--accent);border-color:var(--accent)}.ws-export-code{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:14px 16px;overflow:auto;max-height:320px;font-size:.7rem;font-family:SF Mono,Fira Code,monospace;line-height:1.5;color:var(--text);white-space:pre;-moz-tab-size:2;tab-size:2}.ws-export-code--sm{padding:8px 12px;max-height:60px}.ws-export-code--tall{max-height:400px}.ws-export-cards{display:flex;flex-direction:column;gap:8px}.ws-export-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:10px;background:var(--bg);border:1px solid var(--border);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.ws-export-card:hover:not(:disabled){border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,.15)}.ws-export-card:active:not(:disabled){transform:scale(.98)}.ws-export-card:disabled{opacity:.45;cursor:not-allowed}.ws-export-card__icon{font-size:1.4rem;flex-shrink:0}.ws-export-card__body{flex:1 1;min-width:0}.ws-export-card__title{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:2px}.ws-export-card__desc{font-size:.7rem;color:var(--text-muted);line-height:1.4}.ws-export-empty{text-align:center;padding:20px 16px;font-size:.75rem;color:var(--text-faint);border:1px dashed var(--border);border-radius:10px;margin-top:8px}.ws-share-preview{display:flex;gap:12px;align-items:flex-start;padding:16px;border-radius:10px;background:var(--bg);border:1px solid var(--border)}.ws-share-preview__icon{font-size:1.4rem}.ws-share-preview__text{font-size:.78rem;color:var(--text-muted);line-height:1.5}.ws-share-preview__text strong{color:var(--text)}.ws-canvas{flex:1 1;min-width:0;position:relative}.ws-topbar__actions{display:flex;gap:2px;margin-left:8px}.ws-topbar__action{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s}.ws-topbar__action:hover{background:var(--bg-elevated);color:var(--text)}.ws-topbar__cmdk{display:flex;align-items:center;gap:6px;padding:5px 12px 5px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);font-size:.72rem;cursor:pointer;transition:all .15s;margin-left:8px}.ws-topbar__cmdk:hover{border-color:var(--accent);color:var(--text)}.ws-topbar__cmdk kbd{font-size:.6rem;padding:1px 5px;border-radius:4px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);font-family:inherit;margin-left:4px}.ws-rail__sep{height:1px;margin:4px 6px;background:var(--border)}.ws-rail__btn--palette .ws-rail__icon{font-size:.9rem}.ws-rail__btn--palette{padding:6px 4px;opacity:.7;transition:all .15s}.ws-rail__btn--palette:hover{opacity:1;background:var(--bg-card)}.ws-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;pointer-events:none;z-index:999}.ws-empty__icon{font-size:3rem;opacity:.15;margin-bottom:4px}.ws-empty__title{font-size:1.1rem;font-weight:700;color:var(--text-secondary)}.ws-empty__desc{font-size:.82rem;color:var(--text-muted);text-align:center;max-width:360px;line-height:1.5}.ws-empty__actions{display:flex;gap:8px;margin-top:8px;pointer-events:auto}.ws-empty__btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.ws-empty__btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg,rgba(99,102,241,.08))}.ws-empty__shortcut{font-size:.68rem;color:var(--text-muted);margin-top:12px;opacity:.6}.cmdk-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;animation:cmdk-fade .15s ease}@keyframes cmdk-fade{0%{opacity:0}to{opacity:1}}.cmdk{width:500px;max-height:420px;background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.4);animation:cmdk-slide .15s ease}@keyframes cmdk-slide{0%{transform:translateY(-8px);opacity:.8}to{transform:translateY(0);opacity:1}}.cmdk__input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);color:var(--text-muted)}.cmdk__input{flex:1 1;border:none;background:transparent;color:var(--text);font-size:.88rem;font-family:inherit;outline:none}.cmdk__input::placeholder{color:var(--text-muted)}.cmdk__esc{font-size:.6rem;padding:2px 6px;border-radius:4px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);font-family:inherit}.cmdk__list{max-height:340px;overflow-y:auto;padding:6px}.cmdk__empty{padding:20px;text-align:center;font-size:.8rem;color:var(--text-muted)}.cmdk__item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:8px;border:none;background:transparent;color:var(--text);font-size:.82rem;cursor:pointer;transition:all .1s;text-align:left}.cmdk__item--active,.cmdk__item:hover{background:var(--accent-bg,rgba(99,102,241,.12));color:var(--accent)}.cmdk__item-icon{font-size:1rem;width:24px;text-align:center;flex-shrink:0}.cmdk__item-label{flex:1 1}.ws-toasts{position:fixed;bottom:20px;right:20px;z-index:10001;display:flex;flex-direction:column;gap:8px}.ws-toast{padding:10px 20px;border-radius:10px;font-size:.78rem;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.3);animation:ws-toast-in .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes ws-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ws-toast--success{background:rgba(16,185,129,.9);color:#fff}.ws-toast--info{background:rgba(99,102,241,.9);color:#fff}.ws-toast--error{background:rgba(244,63,94,.9);color:#fff}.ws-topbar__sep{width:1px;height:18px;background:var(--border);margin:0 4px}.ws-git-files{display:flex;flex-direction:column;gap:4px;margin-top:8px}.ws-git-file{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.78rem;cursor:pointer;transition:all .15s;text-align:left}.ws-git-file:hover{border-color:var(--accent)}.ws-git-file:disabled{opacity:.5;cursor:wait}.ws-git-file__icon{font-size:1rem}.ws-git-file__name{flex:1 1;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ws-git-file__size{font-size:.68rem;color:var(--text-muted)}.ws-git-file__action{font-size:.7rem;color:var(--accent);font-weight:600}.ws-source-card{padding:10px 0;border-bottom:1px solid var(--border)}.ws-source-card:last-child{border-bottom:none}.ws-source-card__name{font-size:.82rem;font-weight:700;color:var(--text)}.ws-source-card__meta{font-size:.7rem;color:var(--text-muted);margin-top:2px}.ws-source-card__cols{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.ws-col-tag{padding:1px 8px;border-radius:12px;font-size:.62rem;font-weight:600}.ws-col-tag--string{background:rgba(99,102,241,.12);color:var(--accent)}.ws-col-tag--number{background:rgba(16,185,129,.12);color:#10b981}.ws-col-tag--date{background:rgba(245,158,11,.12);color:#f59e0b}.ws-col-tag--chart{background:rgba(99,102,241,.12);color:var(--accent)}.ws-col-tag--table{background:rgba(6,182,212,.12);color:#06b6d4}.ws-col-tag--kpi{background:rgba(245,158,11,.12);color:#f59e0b}.ws-col-tag--gauge{background:rgba(244,63,94,.12);color:#f43f5e}.ws-col-tag--note{background:rgba(139,92,246,.12);color:#8b5cf6}.ws-col-tag--filter{background:rgba(16,185,129,.12);color:#10b981}.ws-col-tag--more,.ws-col-tag--unknown{background:var(--bg-elevated);color:var(--text-muted)}.ws-profiler{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:640px;max-height:80vh;z-index:10000;background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.4);display:flex;flex-direction:column}.ws-profiler__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.ws-profiler__header h3{font-size:.92rem;font-weight:700;color:var(--text)}.ws-profiler__close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer}.ws-profiler__body{flex:1 1;overflow-y:auto;padding:16px 20px}.ws-profiler__empty{padding:32px;text-align:center;font-size:.82rem;color:var(--text-muted)}.ws-profiler__summary{display:flex;gap:24px;margin-bottom:20px}.ws-profiler__stat{text-align:center}.ws-profiler__stat-val{font-size:1.4rem;font-weight:800;color:var(--text)}.ws-profiler__stat-val--good{color:#10b981}.ws-profiler__stat-val--warn{color:#f59e0b}.ws-profiler__stat-val--bad{color:#f43f5e}.ws-profiler__stat-label{font-size:.68rem;margin-top:2px}.ws-profiler__section-title,.ws-profiler__stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.ws-profiler__section-title{font-size:.72rem;font-weight:700;margin:16px 0 8px}.ws-profiler__cols{display:flex;flex-direction:column;gap:12px}.ws-profiler__col{padding:12px;border-radius:10px;border:1px solid var(--border);background:var(--bg)}.ws-profiler__col-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.ws-profiler__col-name{font-size:.82rem;font-weight:700;color:var(--text)}.ws-profiler__col-stats{display:flex;gap:12px;font-size:.72rem;color:var(--text-muted);margin-top:4px}.ws-profiler__col-bar{height:4px;border-radius:2px;background:var(--border);margin-top:8px;overflow:hidden}.ws-profiler__col-bar-fill{height:100%;border-radius:2px;background:#10b981;transition:width .3s}.ws-profiler__top-vals{margin-top:6px}.ws-profiler__top-val{display:flex;justify-content:space-between;padding:2px 0;font-size:.68rem}.ws-profiler__top-val-name{color:var(--text-muted)}.ws-profiler__top-val-ct{color:var(--text);font-weight:600}.ws-profiler__corrs{display:flex;flex-direction:column;gap:6px}.ws-profiler__corr{display:flex;justify-content:space-between;padding:6px 10px;border-radius:6px;background:var(--bg);font-size:.78rem;color:var(--text-muted)}.ws-profiler__corr-val{font-weight:700;color:var(--text)}.ws-profiler__corr-val--strong{color:#6366f1}.ws-version-card{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg)}.ws-version-card__header{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border:none;background:none;color:var(--text);cursor:pointer;text-align:left;transition:background .15s}.ws-version-card__header:hover{background:var(--bg-elevated)}.ws-version-card__dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.ws-version-card__info{flex:1 1}.ws-version-card__name{font-size:.82rem;font-weight:700}.ws-version-card__meta{font-size:.68rem;color:var(--text-muted);margin-top:2px}.ws-version-card__actions{padding:10px 14px;border-top:1px solid var(--border)}.ws-version-card__diff{margin-bottom:4px}.ws-story-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:cmdk-fade .2s ease}.ws-story{width:680px;max-width:90vw;background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;gap:0}.ws-story,.ws-story__empty{display:flex;flex-direction:column}.ws-story__empty{padding:48px;text-align:center;color:var(--text-muted);font-size:.88rem;gap:16px;align-items:center}.ws-story__header{display:flex;align-items:center;gap:12px;padding:16px 24px;border-bottom:1px solid var(--border)}.ws-story__badge{font-size:.65rem;font-weight:700;padding:3px 10px;border-radius:20px;background:rgba(99,102,241,.15);color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.ws-story__counter{flex:1 1;text-align:right;font-size:.78rem;color:var(--text-muted)}.ws-story__close{background:none;border:none;color:var(--text-muted);font-size:1.3rem;cursor:pointer}.ws-story__content{padding:48px 32px;text-align:center}.ws-story__icon{font-size:3rem;margin-bottom:16px}.ws-story__title{font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:12px}.ws-story__narration{font-size:.92rem;color:var(--text-muted);line-height:1.7;max-width:500px;margin:0 auto}.ws-story__highlight-badge{display:inline-block;margin-top:16px;padding:4px 14px;border-radius:20px;background:rgba(245,158,11,.15);color:#f59e0b;font-size:.72rem;font-weight:700}.ws-story__progress{display:flex;justify-content:center;gap:6px;padding:16px}.ws-story__dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--border);cursor:pointer;transition:all .2s}.ws-story__dot--active{background:var(--accent);transform:scale(1.5)}.ws-story__dot--done{background:rgba(99,102,241,.5)}.ws-story__nav{display:flex;justify-content:space-between;padding:12px 24px;border-top:1px solid var(--border)}.ws-story__nav-btn{padding:8px 18px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.ws-story__nav-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.ws-story__nav-btn:disabled{opacity:.3;cursor:default}.ws-responsive-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.9);display:flex;flex-direction:column;animation:cmdk-fade .15s ease}.ws-responsive{display:flex;flex-direction:column;height:100%}.ws-responsive__header{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border);color:var(--text)}.ws-responsive__presets{display:flex;gap:4px}.ws-responsive__preset{display:flex;align-items:center;gap:4px;padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s}.ws-responsive__preset--active{background:var(--accent);color:#fff;border-color:var(--accent)}.ws-responsive__dims{font-size:.75rem;color:var(--text-muted);font-family:monospace}.ws-responsive__close{margin-left:auto;background:none;border:none;color:var(--text-muted);font-size:1.3rem;cursor:pointer}.ws-responsive__viewport{flex:1 1;display:flex;justify-content:center;align-items:center}.ws-responsive__info{display:flex;gap:24px;justify-content:center;padding:10px;font-size:.72rem;color:var(--text-muted);background:var(--bg-surface);border-top:1px solid var(--border)}.ws-refiner-wrap{position:absolute;bottom:16px;right:16px;z-index:900}.ws-refiner{width:360px;background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 12px 32px rgba(0,0,0,.3)}.ws-refiner__header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border)}.ws-refiner__badge{font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:12px;background:rgba(99,102,241,.15);color:var(--accent);text-transform:uppercase}.ws-refiner__title{flex:1 1;font-size:.82rem;font-weight:700;color:var(--text)}.ws-refiner__close{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer}.ws-refiner__quick{display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px}.ws-refiner__quick-btn{padding:4px 10px;border-radius:16px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.68rem;cursor:pointer;transition:all .15s}.ws-refiner__quick-btn:hover{border-color:var(--accent);color:var(--accent)}.ws-refiner__quick-btn:disabled{opacity:.4}.ws-refiner__history{max-height:160px;overflow-y:auto;padding:8px 12px}.ws-refiner__msg{padding:6px 10px;border-radius:8px;font-size:.75rem;margin-bottom:4px;line-height:1.4}.ws-refiner__msg--user{background:rgba(99,102,241,.12);color:var(--text);text-align:right}.ws-refiner__msg--assistant{background:var(--bg);color:var(--text-muted)}.ws-refiner__input-wrap{display:flex;gap:6px;padding:8px 12px;border-top:1px solid var(--border)}.ws-refiner__input{flex:1 1;padding:6px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.78rem;font-family:inherit;outline:none}.ws-refiner__input:focus{border-color:var(--accent)}.ws-refiner__send{padding:6px 12px;border-radius:6px;border:none;background:var(--accent);color:#fff;font-weight:700;cursor:pointer;transition:opacity .15s}.ws-refiner__send:disabled{opacity:.4;cursor:default}.ws-refine-buttons{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);z-index:800;display:flex;gap:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;padding:4px 6px;box-shadow:0 4px 12px rgba(0,0,0,.2)}.ws-refine-btn{padding:4px 10px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);font-size:.68rem;cursor:pointer;transition:all .15s;white-space:nowrap}.ws-refine-btn:hover{background:rgba(99,102,241,.12);color:var(--accent)}.ws-refine-btn--more{cursor:default}.ws-collab-badge-wrap{position:relative}.ws-collab-badge{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.72rem;cursor:pointer;transition:all .15s}.ws-collab-badge:hover{border-color:var(--accent)}.ws-collab-badge--offline{cursor:default}.ws-collab-badge__dot{width:6px;height:6px;border-radius:50%}.ws-collab-badge__dot--online{background:#10b981}.ws-collab-badge__dot--offline{background:var(--text-muted)}.ws-collab-badge__avatars{display:flex;margin-left:4px}.ws-collab-avatar{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:#fff;border:2px solid var(--bg-surface);margin-left:-4px}.ws-collab-panel{position:absolute;top:100%;right:0;margin-top:8px;width:220px;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:12px;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.3)}.ws-collab-panel__user{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:.78rem;color:var(--text)}.ws-collab-panel__ago{margin-left:auto;font-size:.65rem;color:var(--text-muted)}.ws-import-result{margin-top:12px;padding:14px;border-radius:10px;border:1px solid var(--border);background:var(--bg)}.ws-sidebar__pane{height:100%;display:flex;flex-direction:column}.ws-rail__btn{transition:all .2s ease}.ws-rail__btn:hover{transform:translateX(2px)}.ws-rail__btn:active{transform:scale(.95)}.ws-subtab{transition:all .2s ease}.ws-subtab:hover:not(.ws-subtab--active){transform:translateY(-1px)}.ws-source-card,.ws-template-card{transition:all .2s ease}.ws-source-card:hover{border-color:var(--accent);transform:translateY(-1px)}.ws-export-copy{transition:all .15s ease}.ws-export-copy:active{transform:scale(.95)}.ws-empty__btn{transition:all .2s ease}.ws-empty__btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(99,102,241,.2)}.ws-empty__btn:active{transform:scale(.97)}.ws-collab-badge{transition:all .25s ease}.ws-collab-panel{animation:ws-panel-in .2s ease}@keyframes ws-panel-in{0%{opacity:0;transform:translateY(-4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.ws-topbar .ws-topbar__back,.ws-topbar .ws-topbar__docs,.ws-topbar button{transition:all .2s ease}.ws-topbar button:hover{transform:translateY(-1px)}.ws-topbar button:active{transform:scale(.95)}.ws-dropzone{transition:all .25s ease}.ws-dropzone:hover{border-color:var(--accent);background:rgba(99,102,241,.06);transform:scale(1.01)}.ws-git-file{transition:all .15s ease}.ws-git-file:hover{background:rgba(99,102,241,.06)}.ws-version-card{transition:all .2s ease}.ws-version-card:hover{border-color:var(--accent);transform:translateY(-1px)}.ws-responsive__preset{transition:all .2s ease}.ws-responsive__preset:hover:not(.ws-responsive__preset--active){border-color:var(--accent);transform:translateY(-1px)}.ws-refiner__quick-btn{transition:all .2s ease}.ws-refiner__quick-btn:hover:not(:disabled){transform:translateY(-1px) scale(1.03)}.ws-refiner__quick-btn:active:not(:disabled){transform:scale(.96)}.ws-toasts{pointer-events:none}.ws-toast{pointer-events:auto}.onboarding-main{min-height:100vh;padding:80px 24px 60px;background:var(--bg)}.onboarding-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:40vh;color:var(--text-muted)}.onboarding-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:onboarding-spin .8s linear infinite}@keyframes onboarding-spin{to{transform:rotate(1turn)}}.onboarding-wrap{max-width:640px;margin:0 auto}.onboarding-progress{display:flex;gap:12px;margin-bottom:32px}.onboarding-progress-dot{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);background:var(--bg-surface);color:var(--text-muted);font-size:.875rem;font-weight:600;cursor:pointer;transition:border-color .2s,background .2s,color .2s}.onboarding-progress-dot:hover{border-color:var(--accent-light);color:var(--text)}.onboarding-progress-dot.active{border-color:var(--accent);background:var(--accent);color:#fff}.onboarding-title{font-size:clamp(1.5rem,2.5vw,1.85rem);font-weight:800;letter-spacing:-.03em;color:var(--text);margin-bottom:24px}.onboarding-step{margin-top:8px}.onboarding-desc{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:24px}.onboarding-goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));grid-gap:14px;gap:14px}.onboarding-goal-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 16px;border-radius:14px;border:2px solid var(--border);background:var(--card-bg);color:var(--text);cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s}.onboarding-goal-card:hover{border-color:var(--border-hover);background:var(--card-bg-hover)}.onboarding-goal-card.selected{border-color:var(--accent);background:rgba(99,102,241,.08);box-shadow:0 0 0 1px var(--accent)}.onboarding-goal-icon{font-size:1.75rem;margin-bottom:10px}.onboarding-goal-label{font-weight:600;font-size:.9rem;margin-bottom:4px}.onboarding-goal-desc{font-size:.75rem;color:var(--text-muted);line-height:1.3}.onboarding-invite-input-wrap{display:flex;gap:10px;margin-bottom:16px}.onboarding-input{flex:1 1;padding:12px 16px;border-radius:10px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:.9rem}.onboarding-invite-list{list-style:none;margin-bottom:20px}.onboarding-invite-list li{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:8px;background:var(--overlay-low);margin-bottom:6px;font-size:.875rem;color:var(--text-secondary)}.onboarding-invite-list li button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.2rem;line-height:1;padding:0 4px}.onboarding-invite-list li button:hover{color:var(--accent-rose)}.onboarding-data-actions{display:flex;flex-direction:column;gap:14px}.onboarding-file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.onboarding-paste-wrap{display:flex;flex-direction:column;gap:10px}.onboarding-paste{width:100%;padding:12px 16px;border-radius:10px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:.85rem;font-family:var(--font-mono);resize:vertical}.onboarding-data-preview{margin-top:20px;padding:18px 20px;border-radius:12px;border:1px solid var(--border);background:var(--overlay-low)}.onboarding-data-preview p{margin-bottom:14px;font-size:.9rem;color:var(--text-secondary)}.onboarding-data-preview strong{color:var(--text)}.onboarding-step-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.onboarding-btn{padding:10px 20px;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,color .2s}.onboarding-btn:disabled{opacity:.6;cursor:not-allowed}.onboarding-btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border:none;box-shadow:0 0 16px var(--accent-glow)}.onboarding-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.onboarding-btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.onboarding-btn-secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent-light)}.onboarding-btn-ghost{background:transparent;color:var(--text-muted);border:none}.onboarding-btn-ghost:hover:not(:disabled){color:var(--text)}.projects-app{display:flex;min-height:100dvh;background:var(--bg)}.projects-main{flex:1 1;min-width:0}.projects-main,.projects-sidebar{display:flex;flex-direction:column}.projects-sidebar{width:260px;flex-shrink:0;background:var(--bg-surface);border-right:1px solid var(--border)}.projects-sidebar__team{padding:12px 14px;border-bottom:1px solid var(--border)}.projects-sidebar__head{padding:16px 14px;border-bottom:1px solid var(--border)}.projects-sidebar__logo,.projects-sidebar__logo-wrap{display:flex;align-items:center;gap:10px;font-size:1rem;font-weight:800;letter-spacing:-.02em;color:var(--text);text-decoration:none;margin-bottom:12px}.projects-sidebar__logo-wrap:hover,.projects-sidebar__logo:hover{color:var(--text);text-decoration:none}.projects-sidebar__logo-mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-light));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:900;color:#fff}.projects-sidebar__new{width:100%;padding:8px 14px;border-radius:8px;border:1px solid var(--accent);background:rgba(99,102,241,.12);color:var(--accent-light);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.projects-sidebar__new:hover:not(:disabled){background:rgba(99,102,241,.2);border-color:var(--accent-light)}.projects-sidebar__new:disabled{opacity:.7;cursor:wait}.projects-sidebar__nav{flex:1 1;overflow-y:auto;padding:10px 0}.projects-sidebar__empty{padding:12px 14px;font-size:.8rem;color:var(--text-muted)}.projects-sidebar__list{list-style:none}.projects-sidebar__link{display:block;padding:10px 14px;margin:0 8px;border-radius:8px;text-decoration:none;color:var(--text-secondary);transition:background .15s,color .15s}.projects-sidebar__link:hover{background:var(--overlay-subtle);color:var(--text);text-decoration:none}.projects-sidebar__link--active{background:var(--overlay-low);color:var(--text);font-weight:600;text-decoration:none}.projects-sidebar__link-name{display:block;font-size:.875rem}.projects-sidebar__link-meta{display:block;font-size:.7rem;color:var(--text-muted);margin-top:2px}.projects-sidebar__foot{padding:12px 14px;border-top:1px solid var(--border);display:flex;gap:8px}.projects-sidebar__foot-link{font-size:.8rem;color:var(--text-muted);text-decoration:none}.projects-sidebar__foot-link:hover{color:var(--accent);text-decoration:none}.team-switcher{position:relative}.team-switcher__trigger{width:100%;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:.8125rem;font-weight:600;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.team-switcher__trigger:hover{background:var(--overlay-subtle);border-color:var(--overlay-medium)}.team-switcher__trigger-label{flex:1 1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-switcher__trigger-badge{font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px;background:var(--accent);color:#fff;text-transform:uppercase;letter-spacing:.04em}.team-switcher__chevron{flex-shrink:0;opacity:.7}.team-switcher__dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.15);z-index:50;padding:8px;max-height:360px;display:flex;flex-direction:column;gap:8px}.team-switcher__search-wrap{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;background:var(--input-bg);border:1px solid var(--border)}.team-switcher__search{flex:1 1;min-width:0;padding:4px 0;border:none;background:none;color:var(--text);font-size:.8125rem;outline:none}.team-switcher__search::placeholder{color:var(--text-muted)}.team-switcher__esc{font-size:.7rem;color:var(--text-muted)}.team-switcher__list{overflow-y:auto;max-height:200px;display:flex;flex-direction:column;gap:2px}.team-switcher__item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:8px;text-decoration:none;color:var(--text-secondary);font-size:.8125rem;font-weight:500;transition:background .15s,color .15s}.team-switcher__item:hover{background:var(--overlay-subtle);color:var(--text)}.team-switcher__item--active{background:var(--overlay-low);color:var(--text)}.team-switcher__item-name{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-switcher__empty{font-size:.8rem;color:var(--text-muted);line-height:1.5;padding:8px 10px;margin:0}.team-switcher__create{padding-top:8px;border-top:1px solid var(--border)}.team-switcher__create-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;background:transparent;color:var(--accent-light);font-size:.8125rem;font-weight:600;text-decoration:none;transition:background .15s,color .15s}.team-switcher__create-btn:hover{background:rgba(99,102,241,.12);color:var(--accent)}.team-switcher__create-icon{font-size:1rem;line-height:1;font-weight:400}.team-switcher__create-desc{font-size:.75rem;color:var(--text-muted);margin:4px 0 0 10px;line-height:1.4}.projects-welcome{flex:1 1;display:flex;align-items:center;justify-content:center;padding:24px}.projects-welcome__card{max-width:420px;padding:32px;border-radius:16px;background:var(--card-bg);border:1px solid var(--section-border);text-align:center}.projects-welcome__icon{font-size:2.5rem;margin-bottom:16px;opacity:.9}.projects-welcome__title{font-size:1.35rem;font-weight:800;margin-bottom:10px;color:var(--text)}.projects-welcome__desc{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin-bottom:12px}.projects-welcome__hint{font-size:.8rem;color:var(--text-muted)}.projects-grid{flex:1 1;display:flex;flex-direction:column;min-height:0;padding:24px 32px}.projects-grid__header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.projects-grid__title{font-size:1.5rem;font-weight:700;color:var(--text);margin:0}.projects-grid__actions{display:flex;align-items:center;gap:12px}.projects-grid__search{width:220px;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:.875rem;outline:none;transition:border-color .15s}.projects-grid__search::placeholder{color:var(--text-muted)}.projects-grid__search:focus{border-color:var(--accent)}.projects-grid__add{padding:8px 14px;border-radius:8px;border:1px solid var(--accent);background:rgba(99,102,241,.12);color:var(--accent-light);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.projects-grid__add:hover:not(:disabled){background:rgba(99,102,241,.2);border-color:var(--accent-light)}.projects-grid__add:disabled{opacity:.7;cursor:wait}.projects-grid__list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:16px;gap:16px;overflow-y:auto}.projects-grid__card{display:flex;align-items:center;gap:14px;padding:16px;border-radius:12px;border:1px solid var(--section-border);background:var(--card-bg);text-decoration:none;color:inherit;transition:border-color .15s,background .15s}.projects-grid__card:hover{border-color:var(--border);background:var(--overlay-subtle);color:inherit}.projects-grid__card-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.projects-grid__card-body{min-width:0;display:flex;flex-direction:column;gap:2px}.projects-grid__card-name{font-size:.9375rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.projects-grid__card-meta{font-size:.75rem;color:var(--text-muted)}.projects-grid__empty{grid-column:1/-1;padding:48px 24px;text-align:center;font-size:.9rem;color:var(--text-muted)}.project-view{display:flex;flex-direction:column;height:100%;min-height:0}.project-view__chat-section{flex-shrink:0;border-bottom:1px solid var(--border);background:var(--bg-surface);display:flex;flex-direction:column;max-height:42vh}.project-view__messages{overflow-y:auto;padding:12px 16px;min-height:60px;max-height:240px}.project-view__messages-empty,.project-view__messages-loading{font-size:.85rem;color:var(--text-muted);margin:0}.project-view__message{margin-bottom:12px;padding:8px 12px;border-radius:8px;background:var(--overlay-subtle)}.project-view__message--user{background:rgba(99,102,241,.12);margin-left:24px}.project-view__message--assistant{margin-right:24px}.project-view__message-role{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:4px}.project-view__message-content{font-size:.9rem;line-height:1.5;color:var(--text);white-space:pre-wrap;word-break:break-word}.project-view__message-content--thinking{color:var(--text-muted);font-style:italic}.project-view__chat-bar{flex-shrink:0;padding:12px 16px;border-top:1px solid var(--border);background:var(--bg-surface)}.project-view__chat-bar-inner{display:flex;gap:10px;align-items:center;max-width:720px;margin:0 auto}.project-view__chat-input{flex:1 1;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:.9rem;outline:none;transition:border-color .15s}.project-view__chat-input::placeholder{color:var(--text-muted)}.project-view__chat-input:focus{border-color:var(--accent)}.project-view__chat-send{padding:10px 20px;border-radius:10px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:filter .15s}.project-view__chat-send:hover:not(:disabled){filter:brightness(1.08)}.project-view__chat-send:disabled{opacity:.6;cursor:not-allowed}.project-view__saved{display:block;font-size:.7rem;color:var(--text-muted);margin-top:6px;text-align:center}.project-view__canvas-wrap{flex:1 1;min-height:0;position:relative;background:var(--bg)}.project-view__empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.project-view__empty p{font-size:.9rem;color:var(--text-muted)}.settings-page{min-height:100dvh;background:var(--bg);padding:24px;max-width:560px;margin:0 auto}.settings-page__header{margin-bottom:28px}.settings-page__back{display:inline-block;font-size:.875rem;color:var(--text-muted);text-decoration:none;margin-bottom:12px}.settings-page__back:hover{color:var(--accent);text-decoration:none}.settings-page__title{font-size:1.5rem;font-weight:800;margin-bottom:4px;color:var(--text)}.settings-page__subtitle{font-size:.9rem;color:var(--text-muted)}.settings-content{display:flex;flex-direction:column;gap:28px}.settings-section{padding:20px 0;border-bottom:1px solid var(--section-border)}.settings-section:last-of-type{border-bottom:none}.settings-section__title{font-size:1rem;font-weight:700;margin-bottom:12px;color:var(--text)}.settings-section__meta{font-size:.85rem;color:var(--text-muted);margin-bottom:14px}.settings-profile{display:flex;align-items:center;gap:16px}.settings-profile__avatar{width:56px;height:56px;border-radius:50%;object-fit:cover}.settings-profile__avatar-placeholder{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-light));display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#fff}.settings-profile__name{font-weight:600;color:var(--text);margin-bottom:2px}.settings-profile__email{font-size:.875rem;color:var(--text-muted)}.settings-usage{margin-bottom:14px}.settings-usage__row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;margin-bottom:6px}.settings-usage__label{color:var(--text-secondary)}.settings-usage__value{color:var(--text);font-weight:500}.settings-usage__bar-wrap{height:8px;border-radius:99px;background:var(--overlay-subtle);overflow:hidden;margin-bottom:14px}.settings-usage__bar{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent-light));transition:width .2s}.settings-usage__bar--secondary{background:linear-gradient(90deg,#10b981,#34d399)}.settings-usage__upgrade{display:inline-block;font-size:.875rem;font-weight:600;color:var(--accent);text-decoration:none}.settings-usage__upgrade:hover{text-decoration:underline}.settings-limits{list-style:none;font-size:.9rem;color:var(--text-secondary);line-height:1.8}.settings-limits strong{color:var(--text)}.user-popover{position:relative}.user-popover__trigger{display:flex;align-items:center;gap:8px;padding:6px 10px 6px 6px;border-radius:999px;background:var(--overlay-subtle);border:1px solid var(--overlay-medium);cursor:pointer;transition:background .15s,border-color .15s}.user-popover__trigger:hover{background:var(--overlay-low);border-color:var(--border)}.user-popover__avatar{border-radius:50%;display:block}.user-popover__avatar-placeholder{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-light));display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff}.user-popover__name{font-size:.875rem;font-weight:600;color:var(--text);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-popover__chevron{opacity:.7;transition:transform .2s}.user-popover__trigger[aria-expanded=true] .user-popover__chevron{transform:rotate(180deg)}.user-popover__dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;padding:12px 0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.35);z-index:200}.user-popover__user{padding:0 14px 10px;border-bottom:1px solid var(--border);margin-bottom:8px}.user-popover__user-name{display:block;font-weight:600;color:var(--text);font-size:.9rem}.user-popover__user-email{display:block;font-size:.75rem;color:var(--text-muted);margin-top:2px}.user-popover__nav{display:flex;flex-direction:column}.user-popover__link{display:block;padding:10px 14px;font-size:.875rem;color:var(--text-secondary);text-decoration:none;transition:background .15s,color .15s}.user-popover__link:hover{background:var(--overlay-subtle);color:var(--accent);text-decoration:none}.user-popover__notifications{padding:10px 14px;border-top:1px solid var(--border);margin-top:4px}.user-popover__notifications-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);display:flex;align-items:center;gap:6px}.user-popover__badge{font-size:.65rem;padding:2px 6px;border-radius:99px;background:var(--accent);color:#fff}.user-popover__notifications-empty{font-size:.8rem;color:var(--text-muted);margin-top:6px}.user-popover__notifications-list{list-style:none;margin-top:6px}.user-popover__notification-item{font-size:.8rem;color:var(--text-secondary);padding:4px 0}.user-popover__notification-unread{font-weight:600;color:var(--text)}.user-popover__foot{padding:8px 14px 0;border-top:1px solid var(--border)}.user-popover__signout{width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:background .15s,color .15s}.user-popover__signout:hover{background:var(--overlay-subtle);color:var(--text)}