@import url("https://fonts.googleapis.com/css2?family=Albert+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600;700&family=Poppins:wght@700;800&display=swap");:root{color-scheme:light;--paper:#f6f7f9;--paper-dk:#e8ebf0;--paper-hi:#ffffff;--paper-soft:#f1f3f6;--ink:#14161a;--ink-soft:#3f4652;--muted:#6d7480;--line:#cfd5dd;--red:#c24141;--pink:#2563eb;--orange:#b76e18;--green:#15803d;--blue:#2563eb;--yellow:#f2c94c;--code-bg:#111827;--code-panel:#1f2937;--code-line:#374151;--code-text:#eef2ff;--black:var(--ink);--surface:var(--paper-hi);--surface-2:var(--paper-dk);--border:var(--line);--border-bright:var(--line);--text:var(--ink-soft);--text-bright:var(--ink);--text-dim:var(--muted);--accent:var(--pink);--accent-dim:#1d4ed8;--accent-bg:rgba(37,99,235,0.1);--accent-border:rgba(37,99,235,0.24);--error:var(--red);--warn:var(--orange);--mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;--sans:"Albert Sans",system-ui,sans-serif;--site-nav-height:58px}*{box-sizing:border-box;letter-spacing:0;margin:0;padding:0}body,html{min-height:100%}body{background-color:var(--paper);color:var(--text);font-family:var(--sans);min-height:100vh;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button,input,pre,select,textarea{font:inherit}button{border:0}::selection{background:rgba(229,68,137,.25);color:var(--ink)}.app-shell,.workspace{height:100vh;min-height:100vh;overflow:hidden}.app-shell,.workspace{background:var(--paper)}.workspace{--paper:#16171b;--paper-dk:#111216;--paper-hi:#191b20;--paper-soft:#16171b;--ink:#f3f0f5;--ink-soft:#e9e6eb;--muted:#8e8c97;--line:#2a2c33;--red:#ff5c61;--pink:#fff;--orange:#f4a261;--green:#24c742;--blue:#7aa7ff;--yellow:#fff;--surface:var(--paper-hi);--surface-2:var(--paper-dk);--border:var(--line);--border-bright:#333640;--text:var(--ink-soft);--text-bright:var(--ink);--text-dim:var(--muted);--accent:#fff;--accent-dim:#e5e5e5;--accent-bg:rgba(255,255,255,0.16);--accent-border:rgba(255,255,255,0.44);color:var(--text);color-scheme:dark;display:flex;flex-direction:column}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}.workspace-toolbar{align-items:center;background:var(--paper-dk);display:flex;gap:12px;min-height:44px;padding:0 20px}.workspace-toolbar-logo{color:var(--accent);flex:0 0 auto;font-family:"Poppins",var(--sans);font-size:18px;font-weight:400;line-height:1}.workspace-toolbar-action{align-items:center;background:var(--paper-hi);border:2px solid var(--line);color:var(--ink);cursor:pointer;display:inline-flex;height:30px;justify-content:center;margin-left:auto;width:32px}.workspace-toolbar-action:focus-visible,.workspace-toolbar-action:hover{background:var(--yellow);color:var(--paper);outline:none}.workspace-toolbar-action svg{display:block;height:16px;width:16px}.example-select{appearance:none;background:var(--paper-hi);border:2px solid var(--line);color:var(--ink);font-family:var(--mono);font-size:.74rem;max-width:280px;min-height:30px;outline:none;padding:4px 30px 4px 9px}.example-select:focus{border-color:var(--pink);box-shadow:0 0 0 3px var(--accent-bg)}.layout{background:var(--line);display:grid;flex:1 1;gap:2px;grid-template-columns:minmax(0,1fr);height:auto;min-height:0;padding:2px}.layout.with-preview{grid-template-columns:minmax(0,1fr) minmax(340px,.72fr);grid-template-rows:none}.layout.with-ai{grid-template-columns:minmax(0,1fr) minmax(300px,.48fr)}.layout.with-preview.with-ai{grid-template-columns:minmax(0,1fr) minmax(320px,.64fr) minmax(300px,.48fr)}.panel{background:var(--paper-hi);display:flex;flex-direction:column;min-width:0;overflow:hidden}.panel-header{align-items:center;background:var(--paper-dk);border-bottom:2px solid var(--line);color:var(--ink);display:flex;gap:8px;justify-content:space-between;min-height:43px;padding:8px 16px}.panel-label{color:var(--accent);font-family:var(--mono);font-size:.68rem;font-weight:700;text-transform:uppercase}.panel-status{align-items:center;display:flex;gap:7px}.panel-header-actions{align-items:center;display:flex;gap:10px}.output-tabs{align-items:center;display:inline-flex;gap:4px}.output-tab{background:transparent;border:0;color:var(--muted);cursor:pointer;font-family:var(--mono);font-size:.72rem;font-weight:700;padding:6px 8px;text-transform:uppercase}.output-tab[aria-selected=true]{background:var(--yellow);color:var(--paper)}.output-tab:focus-visible{outline:2px solid var(--pink);outline-offset:2px}.panel-button{padding:4px 10px}.ai-sidebar{min-height:0}.ai-sidebar-header{padding-right:10px}.ai-icon-button{align-items:center;background:transparent;color:var(--muted);cursor:pointer;display:inline-flex;height:26px;justify-content:center;width:26px}.ai-icon-button:focus-visible,.ai-icon-button:hover{color:var(--ink);outline:2px solid var(--pink);outline-offset:-2px}.ai-icon-button svg{display:block;height:16px;width:16px}.ai-chat-messages{display:flex;flex:1 1;flex-direction:column;gap:10px;min-height:0;overflow-y:auto;padding:12px;scrollbar-color:var(--muted) transparent;scrollbar-width:thin}.ai-chat-messages.empty{justify-content:center}.ai-chat-empty{display:flex;flex-direction:column;gap:8px}.ai-suggestion{background:var(--paper-soft);border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;font-family:var(--mono);font-size:.72rem;line-height:1.45;padding:9px 10px;text-align:left}.ai-suggestion:focus-visible,.ai-suggestion:hover{background:#30333c;color:var(--ink);outline:2px solid var(--pink);outline-offset:-2px}.ai-suggestion:disabled{cursor:not-allowed;opacity:.5}.ai-message{color:var(--ink-soft);font-size:.78rem;line-height:1.55;overflow-wrap:anywhere}.ai-message.user{align-self:flex-end;background:#30333c;border:1px solid var(--border-bright);color:var(--ink);max-width:92%;padding:8px 10px}.ai-message.assistant{align-self:stretch}.ai-message.pending{color:var(--muted);font-family:var(--mono);font-size:.72rem}.ai-message-text>*+*{margin-top:8px}.ai-message-text code,.ai-message-text pre{font-family:var(--mono)}.ai-message-text pre{border:1px solid var(--line);overflow-x:auto;padding:10px}.ai-message-text code,.ai-message-text pre{background:var(--paper-dk);color:var(--ink)}.ai-message-text code{font-size:.72rem;padding:1px 4px}.ai-message-text pre code{background:transparent;padding:0}.ai-message-text ol,.ai-message-text ul{padding-left:18px}.ai-tool-call{align-items:center;color:var(--muted);display:flex;font-family:var(--mono);font-size:.68rem;gap:7px;line-height:1.4;margin-top:6px}.ai-tool-call.complete{color:var(--green)}.ai-tool-call.error{color:var(--red)}.ai-tool-call svg{flex:0 0 auto;height:8px;width:8px}.ai-tool-call small{color:var(--muted);display:block;font-size:.64rem;margin-top:1px;overflow-wrap:anywhere}.ai-chat-input{border:2px solid var(--line);display:grid;gap:8px;margin:12px;padding:8px}.ai-chat-input:focus-within{border-color:var(--pink);box-shadow:0 0 0 3px var(--accent-bg)}.ai-chat-input textarea{background:transparent;border:0;color:var(--ink);min-height:58px;outline:none;resize:none;scrollbar-color:var(--muted) transparent}.ai-chat-input textarea::placeholder{color:var(--muted)}.ai-chat-input button{align-items:center;background:var(--pink);color:var(--paper);cursor:pointer;display:inline-flex;height:28px;justify-content:center;justify-self:end;width:30px}.ai-chat-input button:focus-visible,.ai-chat-input button:hover{background:var(--accent-dim);outline:2px solid var(--pink);outline-offset:2px}.ai-chat-input button:disabled{cursor:not-allowed;opacity:.45}.ai-chat-input svg{display:block;height:16px;width:16px}.spin{animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.status-dot{background:var(--muted);border:1px solid var(--line);border-radius:50%;flex-shrink:0;height:8px;width:8px}.status-dot.running{background:var(--green)}.status-dot.error{background:var(--red)}.file-tabs{align-items:stretch;background:var(--paper-dk);border-bottom:2px solid var(--line);display:flex;overflow-x:auto;scrollbar-width:none}.file-tabs::-webkit-scrollbar{display:none}.file-tab-wrapper{align-items:stretch;border-bottom:2px solid transparent;display:inline-flex;padding-right:6px}.file-tab{background:none;color:var(--ink-soft);cursor:pointer;display:flex;font-family:var(--mono);font-size:.72rem;max-height:100%;min-height:36px;padding:10px 0 10px 12px;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.file-tab,.file-tab-action{align-items:center;border:none}.file-tab-action{background:transparent;color:transparent;cursor:default;display:inline-flex;flex-shrink:0;height:36px;justify-content:center;margin:0;min-width:24px;width:24px;padding:0;pointer-events:auto;position:relative}.file-tab-dirty-indicator{background:var(--accent);border-radius:50%;height:6px;left:50%;opacity:0;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:6px}.file-tab-action.dirty .file-tab-dirty-indicator{opacity:1}.file-tab-action:focus-visible,.file-tab-action:hover,.file-tab-wrapper:not(.dirty):focus-within .file-tab-action,.file-tab-wrapper:not(.dirty):hover .file-tab-action{cursor:pointer;pointer-events:auto}.file-tab-action:focus-visible .file-tab-dirty-indicator,.file-tab-action:hover .file-tab-dirty-indicator{opacity:0}.file-tab-action:focus-visible .file-tab-close-icon,.file-tab-action:hover .file-tab-close-icon{color:var(--ink-soft);opacity:1}.file-tab-wrapper:not(.dirty):focus-within .file-tab-close-icon,.file-tab-wrapper:not(.dirty):hover .file-tab-close-icon{color:var(--ink-soft);opacity:1}.file-tab-action:focus-visible,.file-tab-action:hover{color:var(--ink-soft)}.file-tab-action:focus-visible{outline:2px solid var(--pink);outline-offset:-2px}.file-tab-close-icon{color:currentColor;height:14px;opacity:0;pointer-events:none;width:14px}.file-tab:hover{background:rgba(58,37,22,.08);color:var(--ink)}.file-tab-wrapper.active,.file-tab.active{background:var(--paper-hi);color:var(--ink)}.file-tab-wrapper.active{border-bottom-color:var(--pink)}.file-tab .dot,.file-tree-file .dot{background:var(--muted);border-radius:50%;flex-shrink:0;height:6px;width:6px}.file-tab.active .dot,.file-tree-file.active .dot{background:var(--pink)}.file-tree-file.active .dot{background:var(--muted)}.file-tab .dot.dirty,.file-tree-file .dot.dirty{background:var(--accent)}.editor-body{display:grid;flex:1 1;grid-template-columns:220px minmax(0,1fr);min-height:0}.file-explorer{border-right:2px solid var(--line);flex-direction:column;min-width:0;overflow:hidden}.file-explorer,.file-explorer-header{background:var(--paper-dk);display:flex}.file-explorer-header{align-items:center;border-bottom:2px solid var(--line);gap:8px;justify-content:space-between;min-height:38px;padding:9px 12px}.file-explorer-actions,.file-tree-actions{align-items:center;display:flex;flex:0 0 auto;gap:2px}.file-explorer-action,.file-tree-action{align-items:center;background:transparent;border:none;color:var(--muted);cursor:pointer;display:inline-flex;height:24px;justify-content:center;padding:0;width:24px}.file-explorer-action:focus-visible,.file-explorer-action:hover,.file-tree-action:focus-visible,.file-tree-action:hover{color:var(--ink)}.file-explorer-action:disabled{color:var(--muted);cursor:default;opacity:.45}.file-explorer-action:focus-visible,.file-tree-action:focus-visible,.file-tree-open:focus-visible{outline:2px solid var(--pink);outline-offset:-2px}.file-explorer-action svg,.file-tree-action svg{display:block;height:15px;width:15px}.file-tree{flex:1 1;min-height:0;overflow:auto;padding:8px 0;scrollbar-color:var(--muted) transparent;scrollbar-width:thin}.file-tree-group{min-width:0}.file-tree-row{color:var(--ink-soft);font-family:var(--mono);font-size:.72rem;min-height:30px;padding:5px 10px;transition:background .15s,color .15s;width:100%}.file-tree-open,.file-tree-row{align-items:center;background:transparent;display:flex;gap:7px;text-align:left}.file-tree-open{border:none;color:inherit;cursor:pointer;flex:1 1;font:inherit;min-height:20px;min-width:0;padding:0}.file-tree-actions{margin-left:auto;opacity:0;transition:opacity .15s}.file-tree-row:focus-within .file-tree-actions,.file-tree-row:hover .file-tree-actions{opacity:1}.file-tree-row:hover{background:rgba(58,37,22,.08);color:var(--ink)}.file-tree-file.active{background:#30333c;color:var(--ink)}.file-tree-file.dirty .file-tree-name{color:var(--accent)}.file-tree-file{flex:1 1;min-height:30px;min-width:0}.file-tree-chevron{align-items:center;color:currentColor;display:inline-flex;flex:0 0 10px;justify-content:center;transition:transform .15s}.file-tree-chevron.expanded{transform:rotate(90deg)}.file-tree-chevron svg{display:block;height:12px;width:12px}.file-tree-chevron path{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.file-tree-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-main{background:var(--paper-soft);display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.editor-main.with-bottom-panel{display:grid;grid-template-rows:auto minmax(0,3fr) minmax(210px,2fr)}.editor-inner{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.code-editor{flex:1 1;height:100%;min-height:0;min-width:0;width:100%}.code-editor-loading{align-items:center;color:var(--muted);display:flex;flex:1 1;font-family:var(--mono);font-size:.76rem;justify-content:center;min-height:0}.code-editor .monaco-editor{flex:1 1;height:100%;min-height:0;width:100%}.workspace-editor-panel,.workspace-preview-column,.workspace-terminal-panel{background:var(--paper-soft);min-height:0}.workspace-terminal-panel .panel-header{flex-wrap:wrap;padding:8px 12px}.workspace-terminal-panel .panel-header-actions{gap:6px}.terminal-process-status{color:var(--muted);font-family:var(--mono);font-size:.68rem;max-width:min(38vw,260px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-main>.workspace-terminal-panel{border-top:2px solid var(--line)}.workspace-output-body{overflow:hidden}.preview-panel,.workspace-output-body{display:flex;flex:1 1;flex-direction:column;min-height:0}.preview-panel{background:var(--paper-soft)}.url-bar{background:var(--paper-dk);border-bottom:2px solid var(--line);display:flex;gap:0;padding:8px 12px}.url-bar input{background:var(--paper-hi);border-color:var(--line);color:var(--ink);flex:1 1;min-width:0}.url-bar input:focus{border-color:var(--pink);box-shadow:0 0 0 3px var(--accent-bg)}.url-bar .btn{background:var(--paper-hi);border-color:var(--line);color:var(--ink);padding:8px 14px}.url-bar .btn:hover{background:var(--yellow);color:var(--paper)}.preview-reload-icon{display:block;flex:0 0 16px;height:16px;width:16px}.preview-frame{background:#ffffff;border:none;display:block;flex:1 1;min-height:0;width:100%}.ui-test-frame{border:0;height:720px;left:-10000px;opacity:0;pointer-events:none;position:fixed;top:0;width:1280px}.preview-placeholder{align-items:center;background:var(--paper-soft);color:var(--muted);display:flex;flex:1 1;font-family:var(--mono);font-size:.74rem;justify-content:center;min-height:0;padding:20px;text-align:center}.preview-placeholder.error{color:var(--red)}.preview-placeholder.info{color:var(--ink)}.preview-install-log{align-items:center;background:var(--paper-soft);color:var(--ink);display:flex;flex:1 1;flex-direction:column;font-family:var(--mono);justify-content:center;min-height:0;overflow:hidden;padding:24px}.preview-install-log-title{color:var(--red);font-size:.7rem;font-weight:700;margin-bottom:10px;text-transform:uppercase}.preview-install-log-lines{color:var(--ink);font-size:.72rem;line-height:1.65;max-height:min(260px,52vh);max-width:min(620px,100%);overflow:hidden;text-align:left;white-space:pre-wrap;width:100%}.preview-install-log-line{display:block}.preview-install-log-empty,.preview-install-log-line.muted{color:var(--muted)}.preview-install-log-line.command,.preview-install-log-line.success{color:var(--green)}.preview-install-log-line.error{color:var(--red)}.preview-install-log-empty{font-size:.72rem}.terminal{flex:1 1;font-family:var(--mono);font-size:.74rem;line-height:1.65;min-height:0;overflow-y:auto;scrollbar-color:var(--muted) transparent;scrollbar-width:thin}.terminal-output{background:var(--paper-soft);display:flex;overflow:hidden;position:relative}.terminal-output .terminal-renderer{background:var(--paper-soft);box-sizing:border-box;flex:1 1;height:100%;min-height:0;overflow:hidden;padding:12px 16px;width:100%}.terminal-output .terminal-renderer .xterm{height:100%;overflow:hidden}.terminal-output .terminal-renderer .xterm .xterm-viewport{background-color:transparent!important;scrollbar-color:var(--muted) transparent;scrollbar-width:thin}.terminal-transcript{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;width:1px}.terminal-error,.terminal-transcript{position:absolute;white-space:pre-wrap}.terminal-error{color:var(--red);font-family:var(--mono);font-size:.74rem;inset:12px 16px;line-height:1.6;pointer-events:none}.test-results{background:#16171b;color:#e9e6eb;display:flex;flex:1 1;flex-direction:column;font-family:var(--mono);font-size:.66rem;min-height:0;overflow:hidden}.test-results-summary{align-items:center;background:#111216;border-bottom:1px solid #2a2c33;display:flex;flex-wrap:wrap;column-gap:12px;row-gap:4px;padding:6px 8px}.test-summary-item{align-items:center;display:inline-flex;gap:4px}.test-summary-label{color:#8e8c97;font-weight:700;text-transform:uppercase}.test-summary-value{color:#f3f0f5;font-weight:700}.test-results-toolbar{align-items:center;background:#111216;border-bottom:1px solid #2a2c33;display:flex;gap:8px;padding:6px 8px}.test-filter-group{display:flex;flex:1 1;gap:4px;min-width:0;overflow-x:auto}.test-filter-button{background:#191b20;border:1px solid #333640;color:#a8a5b0;cursor:pointer;flex:0 0 auto;font-family:var(--mono);font-size:.64rem;font-weight:700;min-height:24px;padding:3px 6px}.test-filter-button[aria-pressed=true]{background:#30333c;border-color:#777280;color:#f3f0f5}.test-results .test-results-search{background:#191b20;border-color:#333640;color:#f3f0f5;flex:0 1 190px;font-size:.66rem;min-width:120px;padding:5px 8px}.test-results .test-results-search:focus{border-color:#777280;box-shadow:0 0 0 3px rgba(119,114,128,.24)}.test-results-empty{align-items:center;color:#9b98a3;display:flex;flex:1 1;justify-content:center;min-height:0;padding:16px;text-align:center}.test-results-empty-content{align-items:center;display:flex;flex-direction:column;gap:12px}.test-results-empty-actions{display:flex;gap:8px;justify-content:center}.test-results-empty-button{min-width:78px}.test-results-error{color:#ff5c61}.test-results-list{flex:1 1;min-height:0;overflow:auto;scrollbar-color:#6f6b78 transparent;scrollbar-width:thin}.test-result-item{border-bottom:1px solid #2a2c33}.test-result-main{align-items:center;display:grid;gap:10px;grid-template-columns:28px minmax(0,1fr) max-content;min-height:36px;padding:0 14px 0 10px}.test-result-icon{align-items:center;display:inline-flex;justify-content:center;width:22px}.test-result-icon-symbol{height:16px;width:16px}.test-result-icon-passed{color:#24c742}.test-result-icon-failed{color:#ff5c61}.test-result-icon-pending,.test-result-icon-skipped,.test-result-icon-todo{color:#8e8c97}.test-result-name{color:#f2eef4;display:block;font-size:.76rem;line-height:1.35;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.test-result-separator{color:#9b98a3;padding:0 5px}.test-result-duration{color:#8e8c97;font-size:.68rem;white-space:nowrap}.test-failure-message{background:#17181d;border:1px solid #2d3038;border-radius:7px;color:#aaa7b2;font-family:var(--mono);font-size:.68rem;line-height:1.35;margin:0 12px 8px 36px;max-height:200px;overflow:auto;padding:10px;white-space:pre-wrap}.test-failure-detail{display:flex;flex-direction:column;gap:9px;min-width:0}.test-failure-heading{color:#f2eef4;display:block;font-weight:700;overflow-wrap:anywhere}.test-failure-gap{display:block;height:1rem}.test-failure-section-label{color:#8e8c97;display:block;font-size:.58rem;font-weight:800;letter-spacing:0;margin-bottom:4px;text-transform:uppercase}.test-failure-compare,.test-failure-diff,.test-failure-stack{background:#111216;border:1px solid #2a2c33;border-radius:5px;min-width:0;padding:7px 8px}.test-failure-compare{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.test-failure-compare-block{min-width:0}.test-failure-line{display:block;min-height:1.45em;overflow-wrap:anywhere}.test-failure-line-expected{color:#ff777b}.test-failure-line-received{color:#4ad866}.test-failure-stack{color:#a8a5b0}.test-failure-stack-frame{display:block;line-height:1.45;overflow-wrap:anywhere}.test-failure-stack-frame-source{color:#f2eef4;font-weight:700}.test-failure-stack-frame-internal{color:#72707b}input[type=text]{background:var(--paper-hi);border:2px solid var(--line);color:var(--ink);font-family:var(--mono);font-size:.76rem;outline:none;padding:8px 12px;transition:background .15s,box-shadow .15s}input[type=text]:focus{border-color:var(--pink);box-shadow:0 0 0 3px var(--accent-bg)}input[type=text]::placeholder{color:var(--muted)}.btn{align-items:center;border:2px solid var(--line);cursor:pointer;display:inline-flex;font-family:var(--mono);font-size:.74rem;font-weight:700;gap:6px;justify-content:center;padding:7px 18px;text-transform:uppercase;transition:background .15s,color .15s,transform .15s;white-space:nowrap}.btn-primary{background:var(--pink);color:var(--paper)}.btn-primary:hover{background:var(--accent-dim)}.btn-secondary{background:var(--paper-hi);color:var(--ink)}.btn-secondary:hover{background:var(--yellow);color:var(--paper)}.btn:disabled{cursor:not-allowed;opacity:.45}.site-page{min-height:100vh;overflow-x:hidden;position:relative}.marketing-page,.site-page{background:var(--paper)}.site-nav{background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(12px)}.nav-inner{align-items:center;display:flex;height:var(--site-nav-height);justify-content:space-between;margin:0 auto;max-width:1180px;padding:0 22px}.site-logo{align-items:baseline;color:var(--ink);display:inline-flex;font-family:var(--sans);font-size:1rem;font-weight:800;gap:10px;line-height:1}.site-logo small{color:var(--muted);font-family:var(--mono);font-size:.64rem;font-weight:600}.site-nav nav{align-items:center;display:flex;gap:10px}.site-nav nav a{border:1px solid transparent;border-radius:8px;color:var(--ink);font-family:var(--mono);font-size:.72rem;font-weight:700;padding:7px 10px}.site-nav nav a:hover{background:var(--paper-soft);border-color:var(--line)}.site-nav nav a[aria-current=page]{background:var(--ink);border-color:var(--ink);color:var(--paper-hi)}.hero-section{display:grid;margin:0 auto;max-width:1180px;min-height:520px;padding:88px 24px 64px;position:relative}.hero-copy{align-self:center;max-width:860px}.section-label{font-size:.74rem;margin-bottom:14px}.hero-brand,.section-label{color:var(--accent-dim);font-family:var(--mono);font-weight:800;text-transform:uppercase}.hero-brand{font-size:.78rem;margin-bottom:16px}.doc-body h1,.hero-section h1,.section-header h2{color:var(--ink);font-family:var(--sans);font-weight:800;line-height:1.04;max-width:980px}.hero-section h1{font-size:4.2rem}.section-header h2{font-size:2.4rem}.doc-description,.hero-lede{color:var(--ink-soft);font-size:1.08rem;font-weight:500;line-height:1.65;margin-top:24px;max-width:760px}.install-box{align-items:center;background:var(--paper-hi);border:1px solid var(--line);border-radius:8px;color:var(--ink);display:inline-flex;font-family:var(--mono);gap:12px;margin-top:30px;min-height:48px;padding:0 16px}.install-box .prompt{color:var(--accent-dim);font-weight:800}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}.primary-link{align-items:center;background:var(--ink);border-radius:8px;color:var(--paper-hi);display:inline-flex;font-family:var(--mono);font-size:.8rem;font-weight:800;min-height:44px;padding:0 18px}.primary-link:hover{background:var(--accent-dim)}.pg{margin:0 auto;max-width:1180px;padding:0 24px 88px}.pg:before{color:var(--accent-dim);content:"Live runtime";display:block;font-family:var(--mono);font-size:.74rem;font-weight:800;margin-bottom:14px;text-transform:uppercase}.pg-shell{background:var(--paper-hi);border:1px solid var(--line);border-radius:8px;overflow:hidden}.pg-tabs{align-items:center;background:var(--paper-soft);border-bottom:1px solid var(--line);display:flex;gap:8px;min-height:48px;overflow-x:auto;padding:0 12px;scrollbar-width:none}.pg-tabs::-webkit-scrollbar{display:none}.pg-status,.pg-tab{color:var(--muted);font-family:var(--mono);font-size:.74rem}.pg-tab{align-items:center;background:transparent;border:1px solid transparent;border-radius:7px;color:var(--ink-soft);cursor:pointer;display:inline-flex;font-weight:700;gap:8px;padding:7px 10px;white-space:nowrap}.pg-tab:hover{border-color:var(--line)}.pg-tab.active,.pg-tab:hover{background:var(--paper-hi);color:var(--ink)}.pg-tab.active{border-color:var(--accent-border)}.pg-tab .dot{background:var(--muted);border-radius:50%;height:7px;width:7px}.pg-tab.active .dot,.pg-tab.running .dot{background:var(--accent-dim)}.pg-status{font-weight:700;margin-left:auto;white-space:nowrap}.pg-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.85fr);height:520px}.pg-code-panel,.pg-output-panel{min-width:0}.pg-code-panel{background:var(--paper-soft);border-right:1px solid var(--line);display:flex;flex-direction:column}.pg-code-header,.pg-preview-header,.pg-terminal-header{background:var(--paper-hi);border-bottom:1px solid var(--line);color:var(--ink-soft);font-family:var(--mono);font-size:.72rem;min-height:40px;padding:12px 14px}.pg-code-header .filename,.pg-preview-header .label,.pg-terminal-header .label{color:var(--accent-dim);font-family:var(--mono);font-size:.68rem;font-weight:800;text-transform:uppercase}.pg-code-wrap{flex:1 1;min-height:0}.pg-code-wrap textarea{background:transparent;border:0;color:var(--ink);display:block;font-family:var(--mono);font-size:.76rem;height:100%;line-height:1.65;outline:none;padding:18px;resize:none;tab-size:2;width:100%}.pg-code-wrap textarea::selection{background:rgba(37,99,235,.18)}.pg-run-bar{background:var(--paper-hi);border-top:1px solid var(--line);display:flex;gap:12px;min-height:50px}.pg-run-bar,.pg-run-btn{align-items:center;padding:0 14px}.pg-run-btn{background:var(--ink);border-radius:8px;color:var(--paper-hi);cursor:pointer;display:inline-flex;font-family:var(--mono);font-size:.75rem;font-weight:800;gap:7px;min-height:34px;text-transform:uppercase}.pg-run-btn:hover{background:var(--accent-dim);color:var(--paper-hi)}.pg-run-btn:disabled{cursor:not-allowed;opacity:.5}.pg-run-btn svg{height:12px;width:12px}.pg-run-hint{color:var(--muted);font-family:var(--mono);font-size:.66rem}.pg-output-panel{background:var(--paper-soft);display:flex;flex-direction:column;overflow:hidden}.pg-terminal{color:var(--ink);flex:1 1;font-family:var(--mono);font-size:.74rem;line-height:1.65;min-height:0;overflow-y:auto;padding:12px 16px;scrollbar-color:var(--muted) transparent;scrollbar-width:thin}.pg-terminal .t-info{color:var(--muted)}.pg-terminal .t-ok{color:var(--green)}.pg-terminal .t-err{color:var(--red)}.pg-terminal .t-log{color:var(--ink)}.pg-terminal .t-ts{color:var(--muted);margin-right:6px;-webkit-user-select:none;user-select:none}.pg-preview-header{align-items:center;border-top:1px solid var(--line);display:flex;gap:8px}.pg-preview-url{color:var(--accent-dim);font-family:var(--mono);font-size:.66rem;margin-left:auto;opacity:0}.pg-preview-url.visible{opacity:1}.pg-preview{background:#ffffff;flex:0 0 200px;position:relative}.pg-preview iframe{border:0;display:block;height:100%;width:100%}.pg-preview-placeholder{align-items:center;background:var(--paper-soft);color:var(--muted);display:flex;font-family:var(--mono);font-size:.74rem;inset:0;justify-content:center;pointer-events:none;position:absolute}.doc-layout,.site-section{margin:0 auto;max-width:1180px;padding:68px 24px}.section-header{margin-bottom:26px;max-width:780px}.example-grid,.feature-grid,.question-grid{display:grid;gap:16px}.example-grid,.feature-grid,.question-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.example-card,.feature-card,.question-card{background:var(--paper-hi);border:1px solid var(--line);border-radius:8px;color:var(--ink);display:flex;flex-direction:column;gap:12px;min-height:164px;padding:22px;position:relative}.feature-icon{align-items:center;background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:8px;color:var(--accent-dim);display:inline-flex;height:36px;justify-content:center;width:36px}.feature-card:nth-child(2) .feature-icon{background:rgba(183,110,24,.12);color:var(--orange)}.feature-card:nth-child(3) .feature-icon{background:rgba(21,128,61,.12);color:var(--green)}.feature-card:nth-child(4) .feature-icon{background:rgba(37,99,235,.12);color:var(--blue)}.feature-card:nth-child(5) .feature-icon{background:rgba(194,65,65,.12);color:var(--red)}.feature-card:nth-child(6) .feature-icon{background:rgba(109,116,128,.14);color:var(--ink-soft)}.feature-icon svg{height:19px;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2;width:19px}.example-card-heading{align-items:center;display:flex;gap:12px}.example-logo{display:block;flex:0 0 auto;height:34px;object-fit:contain;overflow:visible;width:34px}.example-logo-fallback{background:var(--paper-dk);border:1px solid var(--line)}.example-card span,.feature-card h3,.question-card span{color:var(--ink);font-family:var(--sans);font-size:1.08rem;font-weight:800;line-height:1.25}.example-card small,.feature-card p,.question-card small{color:var(--ink-soft);font-size:.94rem;font-weight:500;line-height:1.6}.example-card em,.question-card em{color:var(--accent-dim);font-family:var(--mono);font-size:.7rem;font-style:normal;font-weight:800;margin-top:auto;text-transform:uppercase}.example-card:hover,.question-card:hover{background:var(--paper-dk)}.faq-list{border-top:1px solid var(--line)}.faq-item{border-bottom:1px solid var(--line);padding:22px 0}.faq-item summary{color:var(--ink);cursor:pointer;font-family:var(--sans);font-size:1rem;font-weight:800;line-height:1.4}.faq-item p{color:var(--ink-soft);font-weight:500;line-height:1.7;margin-top:14px;max-width:820px}.site-footer{align-items:center;border-top:1px solid var(--line);color:var(--ink-soft);display:flex;flex-wrap:wrap;font-family:var(--mono);font-size:.74rem;font-weight:700;gap:18px;justify-content:space-between;margin:0 auto;max-width:1180px;padding:34px 24px;text-transform:uppercase}.footer-links{display:flex;gap:16px}.site-footer a{color:var(--ink)}.site-footer a:hover{color:var(--red)}.doc-layout{align-items:flex-start;display:grid;gap:48px;grid-template-columns:230px minmax(0,820px)}.doc-sidebar{background:var(--paper-hi);border:1px solid var(--line);border-radius:8px;gap:18px;padding:18px;position:sticky;top:88px}.doc-sidebar,.doc-sidebar-group{display:flex;flex-direction:column}.doc-sidebar-group{gap:8px}.doc-sidebar-label{color:var(--accent-dim);font-family:var(--mono);font-size:.68rem;font-weight:800;text-transform:uppercase}.doc-sidebar a{color:var(--ink-soft);font-family:var(--mono);font-size:.76rem;font-weight:700;line-height:1.5}.doc-sidebar a:hover{color:var(--accent-dim)}.doc-sidebar a[aria-current=page]{background:var(--paper-soft);border-radius:6px;color:var(--ink);margin-left:-8px;padding:4px 8px}.doc-body{min-width:0}.doc-section{border-top:1px solid var(--line);margin-top:34px;padding-top:30px}.doc-section h2{color:var(--ink);font-family:var(--sans);font-size:1.45rem;font-weight:800;line-height:1.25;margin-bottom:12px}.doc-section p{line-height:1.8;margin:12px 0}.doc-section p,.doc-section ul{color:var(--ink-soft);font-weight:500}.doc-section ul{line-height:1.75;margin:14px 0 0 20px}.doc-body pre{background:var(--code-bg);border:1px solid var(--code-line);border-radius:8px;color:var(--code-text);font-family:var(--mono);font-size:.82rem;line-height:1.7;margin-top:18px;overflow-x:auto;padding:22px}.doc-section table{border-collapse:collapse;color:var(--ink-soft);margin-top:18px;width:100%}.doc-section td,.doc-section th{border:1px solid var(--line);line-height:1.6;padding:10px 12px;text-align:left;vertical-align:top}.doc-section th{background:var(--ink);color:var(--paper-hi);font-family:var(--mono);font-size:.75rem;font-weight:800;text-transform:uppercase}.doc-section td{background:var(--paper-hi)}.doc-callout{background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:8px;margin-top:18px;padding:16px}.doc-callout-title{color:var(--ink);font-family:var(--mono);font-size:.72rem;font-weight:800;text-transform:uppercase}.page-nav{border-top:1px solid var(--line);display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:44px;padding-top:20px}.page-nav a{background:var(--paper-hi);border:1px solid var(--line);border-radius:8px;color:var(--ink);display:flex;flex-direction:column;gap:6px;padding:16px}.page-nav a:hover{background:var(--paper-dk)}.page-nav .next{align-items:flex-end;grid-column:2;text-align:right}.page-nav span{color:var(--accent-dim);font-family:var(--mono);font-size:.72rem;font-weight:800;text-transform:uppercase}@media (min-width:900px){.hero-section h1{font-size:4.6rem}.doc-body h1{font-size:3.4rem}.section-header h2{font-size:2.8rem}}@media (max-width:900px){.app-shell,.workspace{height:auto;min-height:100vh;overflow:visible}.workspace-toolbar{gap:10px;padding:0 12px}.layout{grid-template-rows:minmax(560px,calc(100vh - 44px))}.layout,.layout.with-preview{grid-template-columns:1fr;height:calc(100vh - 44px)}.layout.with-preview{grid-template-rows:minmax(560px,58vh) minmax(360px,calc(42vh - 44px))}.layout.with-ai{grid-template-rows:minmax(560px,58vh) minmax(300px,36vh)}.layout.with-ai,.layout.with-preview.with-ai{grid-template-columns:1fr;height:auto;min-height:calc(100vh - 44px)}.layout.with-preview.with-ai{grid-template-rows:minmax(560px,48vh) minmax(360px,38vh) minmax(300px,36vh)}.editor-main.with-bottom-panel{grid-template-rows:auto minmax(0,3fr) minmax(190px,2fr)}.preview-panel{min-height:0}.editor-body{grid-template-columns:1fr;grid-template-rows:minmax(120px,28vh) minmax(0,1fr)}.file-explorer{border-bottom:2px solid var(--line);border-right:none}.site-nav{position:sticky}.nav-inner{padding:0 16px}.site-logo small{display:none}.site-nav nav{gap:6px}.site-nav nav a{font-size:.68rem;padding:6px 7px}.hero-section{min-height:auto;padding:44px 18px 64px}.hero-section h1{font-size:2.6rem}.install-box{max-width:100%}.install-box code{overflow-wrap:anywhere}.pg{padding:0 18px 70px}.pg-body{grid-template-columns:1fr;height:auto}.pg-code-panel{border-bottom:1px solid var(--line);border-right:none;min-height:420px}.pg-output-panel{min-height:360px}.doc-layout,.site-section{padding:54px 18px}.doc-layout,.example-grid,.feature-grid,.question-grid{grid-template-columns:1fr}.doc-sidebar{position:static}.page-nav{grid-template-columns:1fr}.page-nav .next{grid-column:auto}}.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#FFF;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm .xterm-cursor-pointer,.xterm.xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .xterm-accessibility-tree:not(.debug) ::selection{color:transparent}.xterm .xterm-accessibility-tree{font-family:monospace;-webkit-user-select:text;user-select:text;white-space:pre}.xterm .xterm-accessibility-tree>div{transform-origin:left;width:fit-content}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:double underline;text-decoration:double underline}.xterm-underline-3{-webkit-text-decoration:wavy underline;text-decoration:wavy underline}.xterm-underline-4{-webkit-text-decoration:dotted underline;text-decoration:dotted underline}.xterm-underline-5{-webkit-text-decoration:dashed underline;text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;background:rgba(0,0,0,0);transition:opacity .1s linear;z-index:11}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{position:absolute;display:none}.xterm .xterm-scrollable-element>.shadow.top{display:block;top:0;left:3px;height:3px;width:100%;box-shadow:var(--vscode-scrollbar-shadow,#000) 0 6px 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.left{display:block;top:3px;left:0;height:100%;width:3px;box-shadow:var(--vscode-scrollbar-shadow,#000) 6px 0 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.top-left-corner{display:block;top:0;left:0;height:3px;width:3px}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow,#000) 6px 0 6px -6px inset}