:root{color-scheme:light;--bg: #eef2f7;--panel: rgba(255, 255, 255, .78);--panel-strong: rgba(255, 255, 255, .95);--line: rgba(15, 23, 42, .1);--text: #0f172a;--muted: #64748b;--accent: #0d9488;--accent-strong: #0f766e;--shadow: 0 24px 56px rgba(15, 23, 42, .09);font-family:Plus Jakarta Sans,system-ui,sans-serif}*{box-sizing:border-box}html{height:100%}body{margin:0;min-height:100%;height:100%;background:radial-gradient(circle at 12% 8%,rgba(13,148,136,.14),transparent 28%),radial-gradient(circle at 88% 92%,rgba(37,99,235,.08),transparent 24%),linear-gradient(165deg,#e8eef5,#f8fafc 46%,#eef2f7);color:var(--text)}button,textarea{font:inherit}#root{min-height:100%;height:100%;overflow:hidden}.home{min-height:100%;height:100%;overflow:auto;padding:20px;box-sizing:border-box}.home-shell{max-width:1120px;margin:0 auto;border:1px solid var(--line);border-radius:28px;background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);overflow:hidden}.home-header{padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line);background:#fff6}.home-brand{font-family:JetBrains Mono,ui-monospace,monospace;font-size:.92rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-strong);font-weight:700}.home-main{padding:28px;display:flex;flex-direction:column;gap:28px}.home-hero{padding:26px;border-radius:24px;background:linear-gradient(160deg,#0d94881f,#2563eb0f);border:1px solid rgba(15,23,42,.08)}.home-title{margin:0;font-size:clamp(1.8rem,3.2vw,2.45rem);line-height:1.12;letter-spacing:-.02em}.home-subtitle{margin:12px 0 0;color:var(--muted);font-size:1.02rem;line-height:1.5;max-width:62ch}.home-actions{margin-top:18px;display:flex;flex-wrap:wrap;align-items:center;gap:14px}.home-cta{border:0;cursor:pointer;padding:14px 18px;border-radius:16px;font-weight:700;background:linear-gradient(180deg,var(--accent),var(--accent-strong));color:#fff;box-shadow:0 16px 30px #0d948838}.home-cta:hover{filter:brightness(1.03)}.home-cta:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:2px}.home-cta-secondary{background:#ffffff8c;color:var(--text);border:1px solid rgba(15,23,42,.12);box-shadow:none;font-weight:650;padding:12px 16px}.home-cta-secondary:hover{background:#ffffffb8}.home-badges{display:flex;flex-wrap:wrap;gap:8px}.home-badge{font-size:.86rem;color:#0f172ac7;border:1px solid rgba(15,23,42,.12);padding:8px 10px;border-radius:999px;background:#ffffff8c}.home-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.home-card{border:1px solid rgba(15,23,42,.1);border-radius:20px;padding:18px;background:#ffffff85}.home-card-title{font-weight:800;letter-spacing:-.01em}.home-card-text{margin-top:8px;color:var(--muted);line-height:1.5}.home-section-title{font-weight:900;letter-spacing:-.01em;margin-bottom:10px}.home-screenshots{border-top:1px solid rgba(15,23,42,.08);padding-top:18px}.home-shot-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.home-shot{border:1px solid rgba(15,23,42,.1);border-radius:20px;background:#ffffff80;overflow:hidden}.home-shot-label{padding:12px 14px;color:var(--muted);font-size:.86rem;border-bottom:1px solid rgba(15,23,42,.08)}.home-shot-placeholder{height:170px;background:radial-gradient(circle at 30% 30%,rgba(13,148,136,.16),transparent 40%),radial-gradient(circle at 75% 60%,rgba(37,99,235,.12),transparent 42%),linear-gradient(180deg,#ffffffbf,#f1f5f9d9)}.home-shot-note{margin-top:10px;color:var(--muted);font-size:.9rem}.home-prompts{border-top:1px solid rgba(15,23,42,.08);padding-top:18px}.chat-suggested-prompts{border-top:0;padding-top:0;margin-bottom:14px}.chat-suggested-prompts .home-prompt{background:#0f172a0f;border-color:#0f172a24}.chat-suggested-prompts .home-prompt:hover{background:#0f172a17;border-color:#0f172a2e}.home-prompt-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.home-prompt-item{margin:0}.home-prompt{width:100%;text-align:left;border:1px solid rgba(15,23,42,.1);border-radius:16px;padding:12px 14px;background:#ffffff8c;cursor:pointer;color:var(--text)}.home-prompt:hover{background:#ffffffb8;border-color:#0d948847}.home-prompt:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:2px}.home-footer{border-top:1px solid var(--line);padding:18px 24px;color:var(--muted);font-size:.9rem;background:#ffffff59}@media (max-width: 980px){.home-shot-grid{grid-template-columns:1fr}}@media (max-width: 820px){.home-grid,.home-prompt-list{grid-template-columns:1fr}}.layout{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(440px,1.4fr);grid-template-rows:minmax(0,1fr);gap:20px;height:100%;min-height:0;padding:20px;box-sizing:border-box;overflow:hidden}.chat-panel,.canvas-panel{border:1px solid var(--line);border-radius:28px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow)}.chat-panel{display:grid;grid-template-rows:auto minmax(0,1fr) auto;min-height:0;background:var(--panel);overflow:hidden}.canvas-panel{min-height:0;overflow-y:auto;background:linear-gradient(180deg,#fffffff0,#f1f5f9e6);padding:28px}.canvas-panel-charts{display:flex;flex-direction:column}.chat-header,.chat-input{padding:24px}.chat-header{border-bottom:1px solid var(--line);padding-bottom:0;padding-top:14px}.chat-input{padding:16px}.chat-header-top{display:flex;align-items:center;justify-content:space-between;gap:16px}.chat-brand{display:inline-flex;align-items:center;gap:0}.sidebar-toggle{width:32px;height:32px;border-radius:10px;border:0;padding:0;background:transparent;color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:1.55rem;line-height:1;flex-shrink:0;margin-left:-10px;transform:translateY(-2px)}.sidebar-toggle:hover{color:var(--accent-strong)}.sidebar-toggle:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:2px}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:40}.sidebar-drawer{position:fixed;top:0;left:0;height:100%;width:min(440px,92vw);background:#f8fafceb;border-right:1px solid var(--line);box-shadow:24px 0 56px #0f172a2e;transform:translate(-102%);transition:transform .18s ease;z-index:50;display:flex;flex-direction:column}.sidebar-drawer.is-open{transform:translate(0)}.sidebar-header{padding:18px 18px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line)}.sidebar-title{font-family:JetBrains Mono,ui-monospace,monospace;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-strong);font-weight:600}.sidebar-close{width:54px;height:54px;border-radius:14px;border:0;background:transparent;color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:2rem;line-height:1}.sidebar-close:hover{color:var(--accent-strong)}.sidebar-close:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:2px}.sidebar-list{padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;min-height:0}.sidebar-group{display:flex;flex-direction:column;gap:10px}.sidebar-group-title{padding:2px 4px 0;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}.sidebar-group-items{display:flex;flex-direction:column;gap:10px}.sidebar-item{text-align:left;width:100%;border:0;border-radius:0;padding:10px;background:transparent;cursor:pointer;position:relative}.sidebar-item:hover{background:#0f172a0a}.sidebar-item.is-active{background:#0d94881a}.sidebar-item-title{color:var(--text);font-weight:500;letter-spacing:-.005em;font-size:.9rem;line-height:1.25;padding-right:58px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sidebar-item-badge{position:absolute;top:10px;right:10px;display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 10px;border-radius:999px;border:1px solid var(--line);background:#ffffffc7;color:var(--muted);font-family:JetBrains Mono,ui-monospace,monospace;font-size:.78rem;line-height:1}.sidebar-item-badge-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.sidebar-item-badge-icon svg{width:16px;height:16px;display:block}.sidebar-item-badge-count{font-variant-numeric:tabular-nums}.sidebar-item-subtitle{margin-top:6px;color:var(--muted);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-empty{padding:8px 4px}.app-logo{font-size:1.45rem;font-weight:600;letter-spacing:-.04em;line-height:1;color:var(--text)}.app-beta-badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 6px;border-radius:999px;border:1px solid var(--line);background:#0d94881f;color:var(--accent-strong);font-family:JetBrains Mono,ui-monospace,monospace;font-size:.6rem;line-height:1;letter-spacing:.08em;text-transform:uppercase;transform:translateY(-2px)}.app-home-link{display:inline-flex;align-items:center;gap:12px;text-decoration:none;color:inherit}.app-home-link:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:4px;border-radius:14px}.button-new-thread{flex-shrink:0;border:0;border-radius:12px;width:56px;height:56px;margin:0;padding:0;background:transparent;color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transform:translateY(-3px);-moz-appearance:none;appearance:none;-webkit-appearance:none;-webkit-tap-highlight-color:transparent}.button-new-thread:hover{background:transparent;color:var(--accent-strong)}.button-new-thread:active,.button-new-thread:active:hover{background:transparent!important}.button-new-thread:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:2px}.button-new-thread svg{width:32px;height:32px;display:block}.chat-header h1,.canvas-hero h2,.empty-state h2{margin:6px 0 10px;font-size:clamp(1.35rem,2.4vw,2rem);line-height:1}.canvas-hero .canvas-hero-title{font-size:clamp(1.05rem,1.7vw,1.35rem)}.chat-header p,.message p,.status,.muted,li{color:var(--muted)}.eyebrow,.message-role{font-family:JetBrains Mono,ui-monospace,monospace;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}.eyebrow{color:var(--accent-strong)}.chat-stream{min-height:0;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:14px;overscroll-behavior:contain}.empty-state,.message{border:1px solid var(--line);border-radius:22px}.empty-state{padding:22px;background:#ffffff8c}.message{padding:16px 18px;max-width:92%;position:relative}.message p{margin:8px 0 0;white-space:pre-wrap}.message-revert-button{border:0;background:transparent;color:var(--muted);padding:2px;margin-left:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;border-radius:10px;position:absolute;top:10px;right:12px}.message-revert-button svg{width:18px;height:18px;display:block}.message-revert-button:hover{background:transparent;color:var(--text)}.message-revert-button:active{background:transparent}.message-revert-button:disabled{opacity:.5;cursor:default}.message-revert-button:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:3px}.message-assistant{padding-right:46px}.message-markdown{margin-top:8px;color:var(--text);line-height:1.55;font-size:.95rem}.message-markdown>:first-child{margin-top:0}.message-markdown>:last-child{margin-bottom:0}.message-markdown p{margin:.65em 0 0;white-space:normal;color:var(--text)}.message-markdown p:first-child{margin-top:0}.message-markdown h1,.message-markdown h2,.message-markdown h3{margin:1em 0 .4em;font-weight:600;line-height:1.25;color:var(--text)}.message-markdown h1{font-size:1.25rem}.message-markdown h2{font-size:1.1rem}.message-markdown h3{font-size:1rem}.message-markdown ul,.message-markdown ol{margin:.5em 0 0;padding-left:1.35em;color:var(--text)}.message-markdown li{margin:.25em 0;color:var(--text)}.message-markdown li>p{margin-top:.25em}.message-markdown a{color:var(--accent-strong);text-decoration:underline;text-underline-offset:2px}.message-markdown a:hover{color:var(--accent)}.message-markdown code{font-family:JetBrains Mono,ui-monospace,monospace;font-size:.88em;padding:.12em .35em;border-radius:6px;background:#0f172a0d;border:1px solid var(--line)}.message-markdown pre{margin:.65em 0 0;padding:12px 14px;border-radius:12px;overflow-x:auto;background:#0f172a0a;border:1px solid var(--line)}.message-markdown pre code{padding:0;border:none;background:transparent;font-size:.82rem;line-height:1.45}.message-markdown blockquote{margin:.65em 0 0;padding:.35em 0 .35em .9em;border-left:3px solid var(--accent);color:var(--muted)}.message-markdown table{margin:.65em 0 0;border-collapse:collapse;width:100%;font-size:.88rem}.message-markdown th,.message-markdown td{border:1px solid var(--line);padding:6px 10px;text-align:left}.message-markdown th{background:#0f172a0a;font-weight:600}.message-markdown hr{margin:1em 0;border:none;border-top:1px solid var(--line)}.message-user{align-self:flex-end;background:linear-gradient(135deg,#0d948829,#2dd4bf1f)}.message-assistant{align-self:flex-start;background:#f8fafceb}.message-clickable{cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.message-clickable:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.message-active-run{border-color:var(--accent-strong);box-shadow:0 0 0 2px var(--accent-strong)}.button-back-to-current{margin-top:0;border:1px solid var(--accent);border-radius:999px;padding:4px 10px;background:transparent;color:var(--accent-strong);font-size:.82rem;line-height:1.1;cursor:pointer;transition:background .15s ease}.button-back-to-current:hover{background:#0d948814}.chat-processing .message-role{display:block}.chat-spinner-row{display:flex;align-items:center;gap:12px;margin-top:8px}.chat-processing-label{color:var(--muted);font-size:.95rem}.chat-spinner{display:inline-block;width:22px;height:22px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:chat-spin .65s linear infinite;flex-shrink:0}.chat-spinner-inline{width:16px;height:16px;border-width:2px;vertical-align:middle}.chat-actions-status{display:inline-flex;align-items:center;gap:8px}@keyframes chat-spin{to{transform:rotate(360deg)}}.chat-input{flex-shrink:0;border-top:1px solid var(--line);background:#f8fafcd9}.chat-input textarea{width:100%;resize:none;border:1px solid var(--line);border-radius:18px;padding:16px;background:var(--panel-strong);color:var(--text);outline:none}.chat-compose{position:relative}.chat-compose textarea{padding-right:64px}.chat-actions{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:12px}.chat-actions button{border:0;border-radius:999px;padding:0;background:transparent;color:var(--accent-strong);cursor:pointer}.chat-actions button:hover{color:#177fb3}.chat-actions button:focus-visible{outline:none}.chat-send-button{width:56px;height:56px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:0;border:0;background:transparent;box-shadow:none;color:#1d8fc8;cursor:pointer;position:absolute;right:0;top:50%;transform:translateY(-50%);transition:transform .12s ease,color .12s ease,opacity .12s ease}.chat-send-button svg{width:26px;height:26px;display:block;transition:filter .12s ease}.chat-send-button:hover{transform:translateY(-50%) scale(1.06)}.chat-send-button:hover svg{filter:drop-shadow(0 6px 10px rgba(29,143,200,.25))}.chat-send-button:active{transform:translateY(-50%) scale(.98)}.chat-actions button:disabled{opacity:.65;cursor:default}.chat-send-button:disabled{cursor:default}.canvas-hero{padding-bottom:18px;display:flex;flex-direction:column}.canvas-hero-actions{position:static;display:inline-flex;align-items:center;gap:10px;width:100%;justify-content:flex-end;margin-bottom:10px}.button-delete-thread,.button-deploy-live{width:42px;height:42px;border-radius:14px;border:0;background:transparent;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .15s ease,transform .15s ease}.button-deploy-live span{font-size:18px;line-height:1;display:block}.button-deploy-live:hover{color:var(--accent-strong);transform:translateY(-1px)}.button-deploy-live:disabled{opacity:.45;cursor:default;box-shadow:none;color:var(--muted);filter:grayscale(1)}.button-deploy-live:disabled:hover{box-shadow:none;color:var(--muted);transform:none}.button-deploy-live:focus-visible{outline:2px solid rgba(14,116,144,.35);outline-offset:2px}.button-delete-thread:hover{color:#be123c;transform:translateY(-1px)}.button-delete-thread:focus-visible{outline:2px solid rgba(190,18,60,.35);outline-offset:2px}.button-delete-thread svg{width:18px;height:18px;display:block}.canvas-text-block{margin-bottom:20px;padding:18px 20px;border:1px solid var(--line);border-radius:18px;background:var(--panel-strong)}.canvas-text-block-title{margin:0 0 12px;font-size:.78rem;font-family:JetBrains Mono,ui-monospace,monospace;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-strong);font-weight:600}.canvas-text-block-body{margin:0;white-space:pre-wrap;color:var(--text);font-size:.95rem;line-height:1.5}.canvas-pseudocode-summary{margin:0;cursor:pointer;list-style:none;font-size:.78rem;font-family:JetBrains Mono,ui-monospace,monospace;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-strong);font-weight:600;display:flex;align-items:center;gap:10px}.canvas-pseudocode-summary::-webkit-details-marker{display:none}.canvas-pseudocode-summary:before{content:"";flex-shrink:0;width:6px;height:6px;border-right:2px solid var(--accent-strong);border-bottom:2px solid var(--accent-strong);transform:rotate(-45deg);margin-top:-2px;transition:transform .15s ease}.canvas-pseudocode-details[open]>.canvas-pseudocode-summary:before{transform:rotate(45deg);margin-top:2px}.canvas-text-block-pseudocode .canvas-pseudocode{margin:14px 0 0;white-space:pre-wrap;word-break:break-word;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.82rem;line-height:1.45;color:var(--text)}.canvas-pseudocode-diff-details{margin-top:10px}.canvas-pseudocode-diff-summary{cursor:pointer;font-size:.74rem;font-family:JetBrains Mono,ui-monospace,monospace;letter-spacing:.06em;text-transform:uppercase;color:var(--muted, #888);font-weight:600;list-style:none}.canvas-pseudocode-diff-summary::-webkit-details-marker{display:none}.canvas-pseudocode-diff{margin:8px 0 0;white-space:pre-wrap;word-break:break-word;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.78rem;line-height:1.4;background:var(--surface-2, #1a1a2e);border-radius:6px;padding:10px 12px;overflow-x:auto;color:var(--text)}.canvas-pseudocode-diff .diff-add{color:#4ade80;background:#4ade8014}.canvas-pseudocode-diff .diff-del{color:#f87171;background:#f8717114}.canvas-pseudocode-diff .diff-hunk{color:#60a5fa}.canvas-pseudocode-diff .diff-ctx{color:var(--text);opacity:.7}.canvas-charts-mount{flex:1;min-height:720px;width:100%}.canvas-charts-mount:empty{min-height:0}.canvas-charts-placeholder{margin:0 0 16px}.canvas-chart-error{margin:0 0 12px;color:#be123c;font-size:.9rem}.auth-btn{border:0;cursor:pointer;padding:10px 18px;border-radius:999px;font-weight:650;font-size:.88rem;background:linear-gradient(180deg,var(--accent),var(--accent-strong));color:#fff;white-space:nowrap;transition:filter .15s ease}.auth-btn:hover{filter:brightness(1.06)}.auth-btn:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:2px}.auth-btn-secondary{background:#ffffff8c;color:var(--text);border:1px solid rgba(15,23,42,.12);font-size:.82rem;padding:8px 14px}.auth-btn-secondary:hover{background:#ffffffc7}.auth-user-area{display:flex;align-items:center;gap:10px}.auth-avatar{width:32px;height:32px;border-radius:50%;border:1px solid var(--line);object-fit:cover}.auth-name{font-size:.88rem;font-weight:500;color:var(--text);white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}.chat-header-actions{display:flex;align-items:center;gap:10px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 980px){.layout{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) minmax(0,1fr)}.sidebar-drawer{width:100vw;height:100dvh;background:#f8fafcfa;border-right:0;box-shadow:none}.layout.layout-narrow{grid-template-rows:minmax(0,1fr);padding:0;gap:0}.layout.layout-narrow .chat-panel{border:0;border-radius:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.layout.layout-narrow .canvas-panel{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;border-radius:0;transform:translate(102%);transition:transform .18s ease;z-index:45;pointer-events:none}.layout.layout-narrow.is-mobile-canvas-open .chat-panel{display:none}.layout.layout-narrow.is-mobile-canvas-open .canvas-panel{transform:translate(0);pointer-events:auto}}.message-view-strategy-button{border:1px solid rgba(15,23,42,.14);border-radius:999px;padding:4px 10px;background:#0d94881a;color:var(--accent-strong);cursor:pointer;font-size:.82rem;font-weight:650}.message-view-strategy-row{margin-top:12px;display:flex;justify-content:center}.message-view-strategy-button:hover{background:#0d948824;border-color:#0d94884d}.message-view-strategy-button:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:3px}.button-close-canvas{width:42px;height:42px;border-radius:14px;border:0;background:transparent;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .15s ease,transform .15s ease}.button-close-canvas svg{width:22px;height:22px;display:block}.button-close-canvas:hover{color:var(--text);transform:translateY(-1px)}.button-close-canvas:focus-visible{outline:2px solid rgba(13,148,136,.55);outline-offset:2px}
