*,*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;font-family:Open Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#404040;background:#fff;line-height:1.5}a{color:#1976d2;text-decoration:none}a:hover{text-decoration:underline}#app{max-width:1200px;margin:0 auto;padding:16px}.a2ui-column{display:flex;flex-direction:column}.header-row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:16px;margin-bottom:16px}.header-row>:first-child{flex:0 0 auto}.header-row>:last-child{flex:1 1 0;min-width:280px}.a2ui-section{display:block}.a2ui-section:after{content:"";display:table;clear:both}.a2ui-image{margin:0}.a2ui-image figcaption{font-size:.85rem;color:#666;margin-top:4px}.tab-bar{display:flex;background-color:#fcf3cf;border-bottom:2px solid #e0e0e0;overflow-x:auto;position:sticky;top:0;z-index:10}.tab-bar button{flex:0 0 auto;padding:12px 24px;border:none;background:transparent;font-family:inherit;font-size:.95rem;color:#404040;cursor:pointer;white-space:nowrap;position:relative;transition:background-color .2s}.tab-bar button:hover{background-color:#dc76331a}.tab-bar button.active{font-weight:600}.tab-bar button.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background-color:#dc7633}.tab-panel{display:none;padding:24px 0}.tab-panel.active{display:block}.tab-panel:after{content:"";display:table;clear:both}@media(max-width:768px){#app{padding:8px}.header-row{flex-direction:column;align-items:center}.tab-bar button{padding:10px 16px;font-size:.85rem}.tab-panel{padding:16px 0}figure{float:none!important;width:100%!important;margin:1em 0!important}figure img{width:100%!important;height:auto!important}}.data-table-container{width:100%;margin:8px 0 24px}.data-table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 0;flex-wrap:wrap;gap:8px}.data-table-title{font-size:.95rem;color:#404040}.data-table-toolbar-right{display:flex;align-items:center;gap:8px}.data-table-search{padding:6px 10px;border:1px solid #ccc;border-radius:4px;font-size:.85rem;font-family:inherit;min-width:200px}.data-table-search:focus{outline:none;border-color:#dc7633}.data-table-export{padding:6px 12px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:.85rem;font-family:inherit;color:#404040;transition:background-color .2s}.data-table-export:hover{background:#f5f5f5}.data-table-scroll{overflow:auto;border:1px solid #e0e0e0;border-radius:4px}.data-table-table{width:100%;border-collapse:collapse;table-layout:auto;font-size:.85rem}.data-table-table thead{position:sticky;top:0;z-index:1}.data-table-table th{background-color:#fdebd0;padding:10px 8px;text-align:left;font-weight:600;border-bottom:2px solid #e0e0e0;cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none}.data-table-table th:hover{background-color:#fbe0c0}.data-table-table th .sort-indicator{margin-left:4px;opacity:.6;font-size:.75rem}.data-table-table td{padding:10px 8px;border-bottom:1px solid #eee;vertical-align:top}.data-table-table tr:hover td{background-color:#fafafa}.data-table-table.dense th{padding:6px}.data-table-table.dense td{padding:4px 6px}.data-table-table .group-header td{background-color:#f5f5f5;font-weight:600;cursor:pointer;padding:6px 8px}.data-table-table .group-header td:hover{background-color:#eee}.data-table-footer{padding:6px 0;font-size:.8rem;color:#888;text-align:right}@media(max-width:768px){.data-table-search{min-width:140px}}.chat-container{display:flex;flex-direction:column;max-width:800px;margin:0 auto;min-height:400px}.chat-config{max-width:480px;margin:24px auto;padding:24px;border:1px solid #e0e0e0;border-radius:8px;background:#fff;display:flex;flex-direction:column;gap:8px}.chat-config-title{margin:0 0 4px;font-size:1.1rem;color:#404040}.chat-config-desc{margin:0 0 8px;font-size:.85rem;color:#888;line-height:1.4}.chat-label{font-size:.85rem;font-weight:600;color:#404040;margin-top:4px}.chat-config-input{padding:6px 10px;border:1px solid #ccc;border-radius:4px;font-size:.85rem;font-family:inherit;width:100%}.chat-config-input:focus{outline:none;border-color:#dc7633}.chat-connect-btn{margin-top:12px;padding:8px 16px;border:none;border-radius:4px;background:#dc7633;color:#fff;font-size:.9rem;font-family:inherit;cursor:pointer;transition:background-color .2s}.chat-connect-btn:hover{background:#c4631e}.chat-error{padding:8px 12px;border-radius:4px;background:#fdecea;color:#c0392b;font-size:.85rem;margin-bottom:8px}.chat-interface{display:flex;flex-direction:column;height:100%;min-height:500px}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e0e0e0;margin-bottom:8px;flex-wrap:wrap;gap:8px}.chat-header-status{font-size:.8rem;color:#888;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-status strong{color:#404040}.chat-header-actions{display:flex;gap:8px;flex-shrink:0}.chat-action-btn{padding:4px 12px;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:.8rem;font-family:inherit;color:#404040;cursor:pointer;transition:background-color .2s}.chat-action-btn:hover{background:#f5f5f5}.chat-messages{flex:1;overflow-y:auto;padding:8px 0;max-height:60vh;min-height:200px}.chat-empty{display:flex;align-items:center;justify-content:center;height:200px;color:#bbb;font-size:1rem;font-style:italic}.chat-message{display:flex;flex-direction:column;margin-bottom:12px}.chat-message-label{font-size:.75rem;font-weight:600;color:#888;margin-bottom:2px}.chat-message-content{padding:8px 12px;border-radius:8px;font-size:.9rem;line-height:1.5;max-width:85%;word-wrap:break-word;overflow-wrap:break-word}.chat-message-user{align-items:flex-end}.chat-message-user .chat-message-content{background:#fcf3cf;color:#404040}.chat-message-assistant{align-items:flex-start}.chat-message-assistant .chat-message-content{background:#f5f5f5;color:#404040}.chat-markdown p{margin:.4em 0}.chat-markdown p:first-child{margin-top:0}.chat-markdown p:last-child{margin-bottom:0}.chat-markdown pre{background:#e8e8e8;border-radius:4px;padding:8px 10px;overflow-x:auto;font-size:.82rem}.chat-markdown code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85em}.chat-markdown :not(pre)>code{background:#e8e8e8;border-radius:3px;padding:1px 4px}.chat-markdown ul,.chat-markdown ol{margin:.4em 0;padding-left:1.5em}.chat-markdown li{margin-bottom:.2em}.chat-markdown a{color:#1976d2}.chat-markdown blockquote{margin:.4em 0;padding-left:10px;border-left:3px solid #ddd;color:#666}.chat-markdown h1,.chat-markdown h2,.chat-markdown h3,.chat-markdown h4{margin:.6em 0 .3em;line-height:1.3}.chat-markdown table{border-collapse:collapse;margin:.4em 0;font-size:.85em}.chat-markdown th,.chat-markdown td{border:1px solid #ddd;padding:4px 8px}.chat-markdown th{background:#e8e8e8}.chat-input-row{display:flex;gap:8px;padding:8px 0 0;border-top:1px solid #e0e0e0;align-items:flex-end}.chat-textarea{flex:1;padding:8px 10px;border:1px solid #ccc;border-radius:4px;font-size:.9rem;font-family:inherit;resize:vertical;min-height:40px;max-height:120px;line-height:1.4}.chat-textarea:focus{outline:none;border-color:#dc7633}.chat-textarea:disabled{background:#fafafa;color:#999}.chat-send-btn{padding:8px 20px;border:none;border-radius:4px;background:#dc7633;color:#fff;font-size:.9rem;font-family:inherit;cursor:pointer;transition:background-color .2s;white-space:nowrap;align-self:flex-end}.chat-send-btn:hover{background:#c4631e}.chat-stop-btn{background:#c0392b}.chat-stop-btn:hover{background:#a93226}@media(max-width:768px){.chat-config{margin:16px 8px;padding:16px}.chat-message-content{max-width:95%}.chat-messages{max-height:50vh}.chat-header{flex-direction:column;align-items:flex-start}.chat-header-status{white-space:normal}}
