:root{color:#1f2933;background:#f4f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{height:100vh;overflow:hidden}body{margin:0}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled,textarea:disabled,input:disabled{cursor:not-allowed;opacity:.6}.app-shell{height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{height:64px;flex-shrink:0;padding:0 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #d8dee5;background:#fff}.app-header h1{margin:0;font-size:22px;line-height:1.1}.sidebar-toggle-btn{margin-left:16px;padding:4px 10px;border:1px solid #d8dee5;border-radius:4px;background:#fff;color:#5f6c7b;font-size:12px;font-weight:600;cursor:pointer;vertical-align:middle;transition:background .15s}.sidebar-toggle-btn:hover{background:#f4f6f8;color:#1f2933}.app-header span{color:#667085;font-size:13px}.notice{max-width:48vw;padding:8px 12px;overflow:hidden;border-radius:6px;background:#fff7e6;color:#8a5a00;text-overflow:ellipsis;white-space:nowrap}.workspace{flex:1;min-height:0;display:flex;overflow:hidden}.sidebar{width:340px;flex-shrink:0;overflow-y:auto;display:flex;flex-direction:column;border-right:1px solid #d8dee5;background:#fff}.main-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.sidebar-section{padding:16px;border-bottom:1px solid #e5eaf0}.file-section{min-height:0;flex:1;display:flex;flex-direction:column}.section-title{margin-bottom:10px;color:#52616f;font-size:13px;font-weight:700}.persona-list,.file-list{display:grid;gap:6px}.persona-entry{display:flex;flex-direction:column;gap:4px}.persona-actions{display:flex;gap:8px;padding:0 4px 2px}.action-link{border:none;background:none;padding:2px 4px;color:#5f6c7b;font-size:12px;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.action-link:hover{color:#1f2933}.action-link.danger{color:#c9353e}.action-link.danger:hover{color:#a1252d}.protected-badge{font-size:11px;color:#9aa7b4;padding:2px 6px;border:1px solid #d8dee5;border-radius:4px;display:inline-block}.rename-form,.delete-confirm{display:flex;flex-direction:column;gap:6px;padding:8px;border:1px solid #d8dee5;border-radius:6px;background:#fbfcfd}.rename-form input,.delete-confirm input{padding:6px 8px;border:1px solid #c8d0d9;border-radius:4px;font-size:13px}.delete-prompt{font-size:12px;color:#c9353e;line-height:1.4}.delete-prompt code{font-weight:700;background:#fef0ef;padding:1px 4px;border-radius:3px}.danger-button{padding:0 12px;border:0;border-radius:6px;background:#c9353e;color:#fff;font-weight:700;cursor:pointer}.danger-button:disabled{opacity:.4;cursor:not-allowed}.file-list{display:grid;gap:6px}.list-button{width:100%;padding:9px 10px;border:1px solid transparent;border-radius:6px;background:#f4f6f8;color:#1f2933;text-align:left}.list-button.active{border-color:#26a269;background:#eaf7f0;color:#17613d;font-weight:700}.create-persona{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-top:12px}.create-persona input,.chat-input textarea{border:1px solid #c8d0d9;border-radius:6px}.create-persona input{min-width:0;padding:8px 10px}.create-persona button,.create-toggle,.chat-input button,.ghost-button{border:0;border-radius:6px;background:#26a269;color:#fff;font-weight:700}.create-persona button{padding:0 12px}.create-toggle{width:100%;margin-top:12px;padding:9px 10px}.create-persona{grid-template-columns:1fr}.form-actions{display:flex;gap:8px}.secondary-button{background:#e5eaf0!important;color:#344054!important}.upload-button{margin-bottom:10px;padding:9px 10px;border:1px dashed #9aa7b4;border-radius:6px;color:#344054;text-align:center;cursor:pointer}.upload-button input{display:none}.action-button{padding:8px 16px;border:0;border-radius:6px;background:#26a269;color:#fff;font-size:13px;font-weight:700;cursor:pointer;line-height:1.3}.action-button.cancel{background:#e5eaf0;color:#344054}.action-button.active{background:#1a8a52}.file-preview{min-height:0;flex:1;margin-top:8px;overflow:hidden;border:1px solid #e5eaf0;border-radius:6px;background:#fbfcfd}.file-preview pre{height:100%;margin:0;padding:12px;overflow:auto;white-space:pre-wrap;word-break:break-word;font-family:Cascadia Mono,Consolas,monospace;font-size:13px;line-height:1.5}.file-editor{width:100%;height:100%;min-height:200px;padding:12px;border:0;resize:vertical;outline:none;font-family:Cascadia Mono,Consolas,monospace;font-size:13px;line-height:1.5}.chat-panel{flex:1;min-height:0;display:flex;flex-direction:column;background:#eef2f5;overflow:hidden}.chat-header{min-height:68px;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #d8dee5;background:#fff}.chat-title{font-size:18px;font-weight:800}.chat-subtitle{margin-top:2px;color:#667085;font-size:12px}.ghost-button{padding:8px 12px;background:#5f6c7b}.ghost-button.danger{background:#c9353e}.ghost-button.cancel{background:#e5eaf0;color:#344054}.clear-confirm{display:flex;align-items:center;gap:8px;font-size:13px;color:#c9353e}.clear-confirm button{padding:4px 10px;border:0;border-radius:4px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.message-list{flex:1;min-height:0;padding:18px;overflow-y:auto}.empty-state{margin:48px auto 0;color:#667085;text-align:center}.message-row{display:flex;margin-bottom:12px}.message-row.user{justify-content:flex-end}.message-row.assistant{justify-content:flex-start}.message-bubble{max-width:min(72%,680px);padding:10px 12px 7px;border-radius:8px;background:#fff;box-shadow:0 1px 2px #0f172a14}.message-row.user .message-bubble{background:#d9fdd3}.message-bubble.pending{color:#667085}.message-content{white-space:pre-wrap;word-break:break-word;line-height:1.55}.message-time{margin-top:4px;color:#7b8794;font-size:11px;text-align:right}.chat-input{padding:12px;display:grid;grid-template-columns:minmax(0,1fr) 88px;gap:10px}.chat-input textarea{width:100%;min-height:48px;max-height:140px;padding:10px 12px;resize:vertical}.chat-input button{min-height:48px}.file-editor-panel{flex:1;min-height:0;display:flex;flex-direction:column;background:#fff;overflow:hidden}.file-editor-header{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;border-bottom:1px solid #d8dee5;background:#fff}.file-editor-title{font-size:18px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-editor-actions{display:flex;gap:8px;flex-shrink:0}.file-editor-body{flex:1;min-height:0;overflow:hidden}.file-editor-textarea{width:100%;height:100%;padding:16px;border:0;outline:none;resize:none;font-family:Cascadia Mono,Consolas,monospace;font-size:13px;line-height:1.6;overflow-y:auto}.file-editor-textarea:focus{background:#fbfcfd}@media(max-width:860px){.workspace{flex-direction:column}.sidebar{max-height:42vh;width:100%;border-right:0;border-bottom:1px solid #d8dee5}.message-bubble{max-width:86%}}.empty-hint{padding:20px 0;color:#667085;font-size:13px;text-align:center}.file-switch-confirm{margin-top:8px;padding:8px 12px;border:1px solid #d8dee5;border-radius:6px;background:#fff7e6;font-size:13px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.conversation-list{display:grid;gap:6px;max-height:240px;overflow-y:auto}.message-footer{margin-top:4px;display:flex;align-items:center;justify-content:space-between;min-height:18px}.message-actions{display:none;gap:4px}.message-row:hover .message-actions{display:flex}.action-icon{border:none;background:none;padding:2px 6px;font-size:11px;color:#7b8794;cursor:pointer;border-radius:3px;line-height:1.4}.action-icon:hover{background:#e5eaf0;color:#1f2933}.chat-input-area{border-top:1px solid #d8dee5;background:#fff}.edit-banner{padding:8px 12px;display:flex;align-items:center;justify-content:space-between;background:#fff7e6;border-bottom:1px solid #f0dbb4;font-size:13px;color:#8a5a00}.cancel-edit{font-size:12px;font-weight:700;color:#c9353e}.conv-entry{width:100%}.rename-conv-form{display:flex;flex-direction:column;gap:6px;padding:8px;border:1px solid #d8dee5;border-radius:6px;background:#fbfcfd}.rename-conv-form input{padding:6px 8px;border:1px solid #c8d0d9;border-radius:4px;font-size:13px}.rename-conv-actions{display:flex;gap:8px}.conv-title-row{display:flex;align-items:center;justify-content:space-between;gap:4px}.conv-title-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;text-align:left}.conv-rename-btn{font-size:11px;color:#7b8794;cursor:pointer;flex-shrink:0;text-decoration:underline;text-underline-offset:2px}.conv-rename-btn:hover{color:#1f2933}.delete-confirm-bubble{border:1px solid #f0c4c4!important;background:#fff5f5!important}.delete-bubble-confirm{margin-top:6px;padding-top:6px;border-top:1px solid #f0c4c4;display:flex;align-items:center;gap:6px;font-size:12px;color:#c9353e}.delete-bubble-confirm button{padding:2px 8px;border:0;border-radius:4px;font-size:12px;font-weight:700;cursor:pointer}.action-icon.danger{color:#c9353e}.action-icon.danger:hover{background:#fef0ef;color:#a1252d}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:#f4f6f8}.login-form{width:320px;padding:32px;border-radius:12px;background:#fff;box-shadow:0 2px 12px #0f172a14;display:flex;flex-direction:column;gap:16px}.login-form h1{margin:0;font-size:22px;text-align:center}.login-subtitle{margin:-8px 0 0;color:#667085;font-size:13px;text-align:center}.login-error{padding:8px 12px;border-radius:6px;background:#fef0ef;color:#c9353e;font-size:13px;text-align:center}.login-label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:#344054}.login-label input{padding:10px 12px;border:1px solid #c8d0d9;border-radius:6px;font-size:15px}.login-form button{padding:10px;border:0;border-radius:6px;background:#26a269;color:#fff;font-size:15px;font-weight:700;cursor:pointer}.login-form button:disabled{opacity:.5;cursor:not-allowed}.logout-btn{margin-left:8px;padding:4px 10px;border:1px solid #d8dee5;border-radius:4px;background:#fff;color:#7b8794;font-size:11px;font-weight:600;cursor:pointer;vertical-align:middle}.logout-btn:hover{background:#fef0ef;border-color:#c9353e;color:#c9353e}.mobile-nav-btn{display:none}.mobile-overlay{position:fixed;inset:0;background:#0006;z-index:100;display:flex;justify-content:center;align-items:flex-start;padding-top:20px}.mobile-menu{width:90%;max-width:360px;max-height:80vh;background:#fff;border-radius:12px;overflow-y:auto;padding:16px;box-shadow:0 4px 24px #00000026}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.mobile-menu-header h3{margin:0;font-size:17px}.mobile-menu-close{padding:6px 12px;border:1px solid #d8dee5;border-radius:6px;background:#fff;font-size:13px;cursor:pointer}.mobile-menu-section{margin-bottom:16px}.mobile-menu-section:last-child{margin-bottom:0}.mobile-menu-item{width:100%;padding:10px 12px;border:1px solid #e5eaf0;border-radius:6px;background:#fff;text-align:left;margin-bottom:6px;font-size:14px;cursor:pointer}.mobile-menu-item.active{border-color:#26a269;background:#eaf7f0;color:#17613d;font-weight:700}@media(max-width:640px){html,body,#root,.app-shell{height:100dvh}.app-header{padding:0 10px;height:44px}.app-header h1{font-size:16px}.app-header span{display:none}.mobile-header-title{font-size:13px}.mobile-header-sub{margin-top:0}.mobile-conv-name{font-size:11px}.sidebar-toggle-btn{display:none}.mobile-nav-btn{display:inline-block;margin-left:8px;padding:4px 10px;border:1px solid #d8dee5;border-radius:4px;background:#fff;color:#5f6c7b;font-size:12px;font-weight:600;cursor:pointer;vertical-align:middle}.sidebar{display:none}.message-bubble{max-width:92%}.message-actions{display:flex}.action-icon{padding:4px 10px;font-size:12px}.chat-input{padding:6px 8px;grid-template-columns:minmax(0,1fr) 52px;gap:4px}.chat-input textarea{min-height:34px;max-height:80px;padding:6px 10px}.chat-input button{min-height:34px;font-size:12px}.message-list{padding:8px 10px}.message-row{margin-bottom:4px}.chat-header{min-height:52px;padding:10px 12px}.chat-title{font-size:15px}.chat-subtitle{display:none}.notice{max-width:50vw;font-size:11px;padding:4px 8px}.login-form{width:88%;max-width:300px;padding:24px 20px;gap:14px}.login-form h1{font-size:20px}.edit-banner{font-size:12px;padding:6px 10px}}.mobile-header-compact{width:100%;display:flex;flex-direction:column;gap:0}.mobile-header-row{display:flex;align-items:center;justify-content:space-between;width:100%}.mobile-header-title{font-size:15px;font-weight:600;color:#1f2933;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-header-title strong{font-weight:700}.mobile-header-sub{display:flex;align-items:center;justify-content:space-between;margin-top:2px;width:100%}.mobile-conv-name{font-size:12px;color:#667085;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-notice{position:absolute;top:100%;left:0;right:0;z-index:50;max-width:100%;border-radius:0;font-size:12px;padding:6px 12px;text-align:center}.mobile-persona-wrapper{margin-bottom:6px}.mobile-persona-wrapper .mobile-menu-item{display:inline-flex;align-items:center;gap:8px;width:calc(100% - 60px);margin-bottom:0;vertical-align:middle}.mobile-persona-manage-btn{width:52px;padding:10px 0;border:1px solid #e5eaf0;border-radius:6px;background:#fff;color:#5f6c7b;font-size:12px;cursor:pointer;vertical-align:middle;margin-left:6px}.mobile-persona-manage-btn:hover{background:#f4f6f8}.mobile-persona-manage-panel{margin-top:6px;padding:10px;border:1px solid #e5eaf0;border-radius:8px;background:#fbfcfd}.mobile-manage-section{margin-bottom:10px}.mobile-manage-section:last-child{margin-bottom:0}.mobile-manage-label{font-size:12px;font-weight:700;color:#344054;margin-bottom:4px}.mobile-manage-desc{font-size:11px;color:#c9353e;margin-bottom:4px;line-height:1.4}.mobile-manage-desc code{font-weight:700;background:#fef0ef;padding:1px 4px;border-radius:3px}.mobile-manage-row{display:flex;gap:6px;align-items:center}.mobile-create-persona{margin-bottom:10px;padding:10px;border:1px solid #e5eaf0;border-radius:8px;background:#fbfcfd}.mobile-create-persona .mobile-manage-input{width:100%;box-sizing:border-box}.mobile-manage-input{flex:1;min-width:0;padding:6px 8px;border:1px solid #c8d0d9;border-radius:4px;font-size:13px}.mobile-manage-btn{padding:6px 10px;border:0;border-radius:4px;background:#26a269;color:#fff;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.mobile-manage-btn:disabled{opacity:.4;cursor:not-allowed}.danger-section{border-top:1px solid #f0c4c4;padding-top:8px}.danger-label{color:#c9353e}.danger-btn{background:#c9353e}.danger-btn:disabled{opacity:.4;cursor:not-allowed}.mobile-conv-wrapper{display:flex;align-items:center;gap:6px;margin-bottom:6px}.mobile-conv-wrapper .mobile-menu-item{flex:1;min-width:0;margin-bottom:0}.mobile-conv-delete-btn{flex-shrink:0;padding:6px 8px;border:1px solid #f0c4c4;border-radius:4px;background:#fff;color:#c9353e;font-size:11px;font-weight:600;cursor:pointer}.mobile-conv-delete-btn:hover{background:#fef0ef}.mobile-conv-delete-confirm{flex:1;display:flex;align-items:center;gap:6px;padding:8px 10px;border:1px solid #f0c4c4;border-radius:6px;background:#fff5f5;font-size:12px;color:#c9353e;white-space:nowrap;overflow:hidden}.mobile-confirm-btn{padding:4px 8px;border:0;border-radius:4px;background:#c9353e;color:#fff;font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap}.mobile-cancel-btn{padding:4px 8px;border:1px solid #d8dee5;border-radius:4px;background:#fff;color:#344054;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap}.logout-item{color:#c9353e!important;font-weight:600}@media(max-width:640px){.chat-header{min-height:0;padding:4px 10px}.chat-title{font-size:12px}.message-content{font-size:14px}.message-actions{gap:1px}.action-icon{padding:2px 6px;font-size:10px}}
