:root{--bg: #f4f4f8;--surface: #ffffff;--input-bg: #ffffff;--border: #e6e4ef;--text: #232539;--text-muted: #656263;--brand: #1c2146;--brand-dark: #2c3266;--brand-tint: #ececf4;--accent: #fab435;--accent-dark: #e09f1f;--danger: #c0392b;--radius: 10px;--shadow: 0 1px 3px rgba(16, 24, 40, .06), 0 1px 2px rgba(16, 24, 40, .04);--shadow-lg: 0 10px 30px rgba(16, 24, 40, .12);--sidebar-w: 240px;--header-h: 56px}[data-theme=dark]{--bg: #13141f;--surface: #1c1d2c;--input-bg: #24263a;--border: #2f3049;--text: #e7e6f1;--text-muted: #9d9bb3;--brand: #8f88d6;--brand-dark: #a7a0ec;--brand-tint: #292a45;--accent: #fab435;--accent-dark: #f0a92a;--danger: #e57368;--shadow: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .5)}*{box-sizing:border-box}html{color-scheme:light}html[data-theme=dark]{color-scheme:dark}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(/fonts/hanken-grotesk.woff2) format("woff2")}@font-face{font-family:Material Symbols Outlined;font-style:normal;font-weight:400;font-display:block;src:url(/fonts/material-symbols-outlined.woff2) format("woff2")}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:20px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;direction:ltr;-webkit-font-smoothing:antialiased;vertical-align:middle;font-variation-settings:"opsz" 20,"wght" 400,"FILL" 0,"GRAD" 0}html,body,#app{height:100%}body{margin:0;font-family:Hanken Grotesk,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg);font-size:15px;line-height:1.5}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer;border:none;border-radius:8px;padding:10px 16px;background:var(--brand);color:#fff;font-weight:600;transition:background .15s ease}button:hover{background:var(--brand-dark)}button:disabled{background:#9bb6d4;cursor:not-allowed}input,textarea{font:inherit;width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--input-bg);color:var(--text)}input::placeholder,textarea::placeholder{color:var(--text-muted)}input:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint)}.login{min-height:100%;display:grid;place-items:center;padding:24px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:40px;width:100%;max-width:380px;text-align:center}.login-logo{width:64px;height:64px;margin:0 auto 22px;display:block;border-radius:14px}.login-card h1{font-size:20px;margin:0 0 6px}.login-card p{color:var(--text-muted);margin:0 0 28px;font-size:14px}.login-card button{width:100%;padding:12px}.login-foot{margin-top:20px;font-size:12px;color:var(--text-muted)}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--header-h) minmax(0,1fr);height:100%}.shell-header{grid-column:1 / -1;display:flex;align-items:center;gap:16px;padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border)}.shell-header .brand{font-weight:700;color:var(--text);display:flex;align-items:center;gap:10px}.shell-header .brand:hover{text-decoration:none}.shell-header .brand-logo{width:30px;height:30px;border-radius:6px;display:block}.shell-header .spacer{flex:1}.shell-user{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-muted)}.shell-user .avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.shell-user .signout{background:none;color:var(--text-muted);padding:6px 10px;font-weight:500;font-size:13px;display:inline-flex;align-items:center;gap:6px}.shell-user .signout .material-symbols-outlined{font-size:18px}.shell-user .signout:hover{background:var(--bg);color:var(--text)}.theme-toggle,.nav-toggle{background:none;color:var(--text-muted);padding:6px;width:34px;height:34px;border-radius:8px;display:grid;place-items:center;font-size:16px}.theme-toggle:hover,.nav-toggle:hover{background:var(--bg);color:var(--text)}.nav-toggle{margin-right:4px;font-size:18px}.shell-nav{grid-column:1;background:var(--surface);border-right:1px solid var(--border);padding:16px 12px;display:flex;flex-direction:column;gap:2px}.shell-nav .nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);padding:8px 12px 6px;font-weight:600}.shell-nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--text);font-weight:500;font-size:14px;border-left:3px solid transparent}.shell-nav a .material-symbols-outlined{font-size:20px;color:var(--text-muted)}.shell-nav a:hover{background:var(--bg);text-decoration:none}.shell-nav a.active{background:var(--brand-tint);color:var(--brand);font-weight:600;border-left-color:var(--accent)}.shell-nav a.active .material-symbols-outlined{color:var(--brand)}.nav-group{display:contents}.shell-nav .subnav{display:flex;flex-direction:column;margin:2px 0 6px}.shell-nav .subnav a{padding:6px 12px 6px 38px;font-size:13px;font-weight:500;gap:8px;border-left:3px solid transparent}.shell-nav .subnav a .material-symbols-outlined{font-size:18px}.shell-nav .subnav a.active{background:var(--brand-tint);color:var(--brand);border-left-color:var(--accent)}.shell-main{grid-column:2;padding:28px 32px;overflow-y:auto;display:flex;flex-direction:column;min-height:0}.shell.nav-collapsed{grid-template-columns:0 1fr}.shell.nav-collapsed .shell-nav{display:none}.page-head{margin-bottom:24px}.page-head h2{margin:0 0 4px;font-size:22px;color:var(--brand);display:flex;align-items:center;gap:9px}.page-head h2 .material-symbols-outlined{font-size:24px}.page-head p{margin:0;color:var(--text-muted)}.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.tool-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);color:var(--text);transition:box-shadow .15s ease,transform .15s ease,border-color .15s ease}.tool-card:hover{text-decoration:none;box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:#d2dae3}.tool-card h3{margin:0 0 6px;font-size:16px}.tool-card p{margin:0;color:var(--text-muted);font-size:14px}.tool-card .tool-icon{width:40px;height:40px;border-radius:9px;background:var(--brand-tint);color:var(--brand);display:grid;place-items:center;margin-bottom:14px}.tool-card .tool-icon .material-symbols-outlined{font-size:22px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);max-width:760px}.field{margin-bottom:16px}.field label{display:block;font-weight:600;font-size:13px;margin-bottom:6px}.result{margin-top:20px;padding:16px;background:var(--bg);border:1px solid var(--border);border-radius:8px;white-space:pre-wrap}.error{color:var(--danger);margin-top:12px;font-size:14px}.muted{color:var(--text-muted)}.prompt-card{max-width:860px;margin-bottom:18px}.prompt-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.prompt-head>div:first-child{flex:1}.prompt-desc{font-size:13px;margin-top:2px}.badge{display:inline-block;margin-left:8px;padding:1px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--accent);color:#1c2146;vertical-align:middle}.prompt-status{font-size:13px;color:var(--brand);font-weight:600;white-space:nowrap}.prompt-text{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.5;resize:vertical}.prompt-actions{display:flex;gap:8px;margin-top:12px}button.ghost{background:var(--surface);color:var(--text);border:1px solid var(--border);font-weight:500}button.ghost:hover:not(:disabled){background:var(--bg)}button.ghost:disabled{color:var(--text-muted);background:var(--surface)}.diagram-toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.diagram-title{flex:1;min-width:180px;max-width:360px}.diagram-saved{font:inherit;padding:9px 12px;border:1px solid var(--border);border-radius:8px;background:var(--input-bg);color:var(--text)}.diagram-saved-state,.diagram-owner{font-size:13px;white-space:nowrap}.diagram-gallery{display:inline-flex;align-items:center;gap:6px}.diagram-gallery .material-symbols-outlined{font-size:18px}.diagram-gallery.on{color:var(--brand);border-color:var(--brand)}.browse-toolbar{display:flex;gap:10px;align-items:center;margin-bottom:18px}.browse-toolbar input{max-width:360px}.browse-new{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;padding:9px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--brand);font-weight:600}.browse-new:hover{background:var(--bg);text-decoration:none}.browse-card{text-align:left;cursor:pointer;font:inherit}.browse-card-icon{width:36px;height:36px;border-radius:9px;background:var(--brand-tint);color:var(--brand);display:grid;place-items:center;margin-bottom:12px}.browse-card-icon .material-symbols-outlined{font-size:20px}.browse-card h3{display:flex;align-items:center;gap:8px}.browse-card-cta{display:inline-block;margin-top:10px;color:var(--brand);font-weight:600;font-size:13px}.chat-panel{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.chat-wide{width:100%;max-width:860px;flex:1;min-height:0}.chat-log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.chat-empty{margin:auto 0;text-align:center;font-style:italic}.chat-msg{padding:10px 12px;border-radius:10px;font-size:14px;max-width:88%;line-height:1.45}.chat-msg.user{background:var(--brand);color:#fff;align-self:flex-end;border-bottom-right-radius:3px;white-space:pre-wrap}.chat-msg.assistant{background:var(--bg);color:var(--text);align-self:flex-start;border-bottom-left-radius:3px;max-width:92%}.chat-text{white-space:pre-wrap}.md>:first-child{margin-top:0}.md>:last-child{margin-bottom:0}.md p{margin:0 0 8px}.md ul,.md ol{margin:4px 0 8px;padding-left:20px}.md li{margin:2px 0}.md h4{margin:6px 0 4px;font-size:14px}.md code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9em;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:1px 5px}.md a{color:var(--brand)}.chat-attachment{display:flex;align-items:center;gap:10px;padding:8px 12px;border-top:1px solid var(--border);font-size:13px}.chat-attachment img{width:48px;height:48px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.chat-attachment .chat-attachment-x{margin-left:auto;background:none;color:var(--text-muted);padding:4px 8px;font-size:13px}.chat-attachment .chat-attachment-x:hover{background:var(--bg);color:var(--danger)}.chat-input-row{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border);align-items:flex-end}.chat-input-row textarea{resize:none}.chat-input-row button{white-space:nowrap}.chat-diagram{margin-top:10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);overflow:hidden}.chat-diagram-preview{padding:14px;max-height:220px;overflow:hidden;display:grid;place-items:center}.chat-diagram-actions{display:flex;border-top:1px solid var(--border)}.chat-diagram-actions button{flex:1;border:none;border-radius:0;background:var(--surface);color:var(--brand);font-weight:600}.chat-diagram-actions button+button{border-left:1px solid var(--border)}.chat-diagram-actions button:hover{background:var(--bg)}.chat-retry{margin-top:8px;padding:4px 10px;font-size:13px;font-weight:500;background:none;color:var(--text-muted);border:1px solid var(--border);border-radius:6px}.chat-retry:hover{background:var(--surface);color:var(--brand);border-color:var(--brand)}.mermaid-host{max-width:100%}.mermaid-host svg{max-width:100%;height:auto}.preview-error{color:var(--danger);font-size:14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px;max-width:90%}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c101699;z-index:100;display:grid;place-items:center;padding:24px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:min(1000px,95vw);max-height:90vh;display:flex;flex-direction:column}.modal-head{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}.modal-head>strong{flex:1;font-size:15px}.modal-actions{display:flex;gap:8px;align-items:center}.modal-close{background:none;color:var(--text-muted);padding:6px 10px}.modal-close:hover{background:var(--bg);color:var(--text)}.modal-body{flex:1;overflow:auto;padding:24px;display:grid;place-items:center;background:var(--bg)}.modal-diagram{width:100%}.modal-diagram svg{width:100%;height:auto;max-height:74vh}.annotate{display:flex;flex-direction:column;gap:12px;width:100%}.annotate-tools{display:flex;gap:8px;align-items:center}.swatch{width:24px;height:24px;border-radius:50%;padding:0;border:2px solid var(--border);cursor:pointer}.swatch.on{border-color:var(--text);box-shadow:0 0 0 3px var(--brand-tint)}.annotate-stage{position:relative;width:100%;max-height:68vh;align-self:center;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.annotate-stage img{position:absolute;display:block;pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.annotate-stage canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;cursor:crosshair;touch-action:none}.annotate-hint{margin-left:auto;font-size:12px}.annotate-foot{display:flex;gap:8px}.annotate-foot input{flex:1}
