*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#fff;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{background:#fff;flex-direction:column;width:100%;height:100vh;display:flex}.header{background:#fff;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.header .title h1{color:#111;margin:0;font-size:1.1rem;font-weight:600}.header .title p{color:#888;margin:2px 0 0;font-size:.78rem}.header .meta{color:#666;align-items:center;gap:12px;font-size:.78rem;display:flex}.header .meta .tenant{background:#f0f0f0;border-radius:6px;padding:2px 8px;font-weight:600}.nav-link{color:#111;text-underline-offset:2px;font-size:.8rem;text-decoration:underline}.nav-link:hover{color:#555}.signout-btn{cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:5px 10px;font-size:.78rem}.signout-btn:hover{background:#f5f5f5}.kb-bar{background:#fafafa;border-bottom:1px solid #f5f5f5;flex-wrap:wrap;align-items:center;gap:8px;padding:10px max(20px,50% - 340px);display:flex}.kb-bar .label{color:#888;font-size:.75rem}.kb-chip{cursor:pointer;color:#333;background:#fff;border:1px solid #e0e0e0;border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:.78rem;display:inline-flex}.kb-chip.selected{color:#fff;background:#111;border-color:#111}.messages{flex:1;width:100%;max-width:720px;margin:0 auto;padding:24px 20px;overflow-y:auto}.empty-state{color:#bbb;text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;font-size:.9rem;line-height:1.8;display:flex}.empty-icon{margin-bottom:16px;font-size:3rem}.message-row{margin-bottom:12px;display:flex}.message-row.user{justify-content:flex-end}.message-row.assistant{justify-content:flex-start}.bubble{word-break:break-word;border-radius:14px;max-width:78%;padding:10px 14px;font-size:.9rem;line-height:1.65}.bubble.user{color:#fff;white-space:pre-wrap;background:#111;border-bottom-right-radius:4px;max-width:100%}.bubble.assistant{color:#222;background:#f7f7f8;border:1px solid #ebebeb;border-bottom-left-radius:4px}.bubble.assistant p{margin:0 0 8px}.bubble.assistant p:last-child{margin-bottom:0}.bubble.assistant ul,.bubble.assistant ol{margin:4px 0 8px 20px}.bubble.assistant code{background:#eee;border-radius:4px;padding:1px 5px;font-size:.85em}.bubble.assistant pre{color:#e0e0e0;background:#1a1a1a;border-radius:8px;margin:8px 0;padding:12px;font-size:.82em;overflow-x:auto}.bubble.assistant pre code{color:inherit;background:0 0;padding:0}.bubble.assistant strong{font-weight:600}.bubble.assistant a{color:#111;text-underline-offset:2px;text-decoration:underline}.refs{border-top:1px solid #ececec;margin-top:10px;padding-top:8px}.refs .refs-title{color:#999;margin-bottom:4px;font-size:.72rem}.refs ul{color:#555;margin:0 0 0 16px;font-size:.8rem}.ref-images{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.ref-images a{display:block}.ref-images img{object-fit:cover;border:1px solid #e5e5e5;border-radius:8px;width:120px;height:90px}.shimmer-text{background:linear-gradient(90deg,#aaa 0% 40%,#ccc 50%,#aaa 60% 100%) 0 0/200% 100%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:.9rem;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.input-area{background:#fff;border-top:1px solid #f0f0f0;flex-direction:column;gap:8px;padding:16px max(20px,50% - 340px);display:flex}.input-row{align-items:center;gap:8px;display:flex}.input-row textarea{resize:none;background:#fafafa;border:1px solid #e0e0e0;border-radius:10px;outline:none;flex:1;min-height:42px;max-height:200px;padding:10px 14px;font-family:inherit;font-size:.9rem;line-height:1.5;transition:border-color .15s;overflow-y:hidden}.input-row textarea:focus{background:#fff;border-color:#999}.input-row textarea:disabled{color:#999;background:#f5f5f5}.input-row button[type=submit]{color:#fff;cursor:pointer;background:#111;border:none;border-radius:10px;padding:10px 20px;font-size:.9rem;font-weight:500;transition:background .15s}.input-row button[type=submit]:hover:not(:disabled){background:#333}.input-row button[type=submit]:disabled{color:#999;cursor:not-allowed;background:#ddd}.cancel-btn{color:#fff;cursor:pointer;background:#111;border:none;border-radius:10px;padding:10px 20px;font-size:.9rem;font-weight:500;transition:background .15s}.cancel-btn:hover{background:#333}.cancelled-notice{text-align:center;color:#aaa;margin:4px 0 8px;font-size:.8rem}.attach-btn{color:#555;cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:10px;flex-shrink:0;padding:8px 12px;font-size:1.1rem;line-height:1;transition:background .15s}.attach-btn:hover:not(:disabled){background:#f5f5f5}.attach-btn:disabled{color:#ccc;cursor:not-allowed}.attach-previews{flex-wrap:wrap;gap:8px;display:flex}.attach-preview-item{position:relative}.attach-preview-item img{object-fit:cover;border:1px solid #e0e0e0;border-radius:8px;width:80px;height:60px;display:block}.attach-remove{color:#fff;cursor:pointer;background:#555;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;line-height:1;display:flex;position:absolute;top:-6px;right:-6px}.attach-remove:hover{background:#222}.attach-error{color:#c0392b;margin:0;font-size:.8rem}.user-message-stack{flex-direction:column;align-items:flex-end;gap:6px;max-width:78%;display:flex}.bubble.user.image-bubble{flex-direction:column;max-width:none;padding:0;display:flex;overflow:hidden}.bubble.user.image-bubble img{object-fit:cover;max-width:260px;max-height:200px;display:block}.clickable-img{cursor:zoom-in}.lightbox-overlay{z-index:1000;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-img{object-fit:contain;cursor:default;border-radius:8px;max-width:90vw;max-height:90vh}.admin-wrap{width:100%;max-width:880px;margin:0 auto;padding:24px 20px;overflow-y:auto}.admin-section{margin-bottom:28px}.admin-section h2{color:#111;margin-bottom:10px;font-size:.95rem}.upload-box{text-align:center;color:#888;border:1.5px dashed #ccc;border-radius:12px;padding:24px;font-size:.85rem}.kb-table{border-collapse:collapse;width:100%;font-size:.82rem}.kb-table th,.kb-table td{text-align:left;border-bottom:1px solid #f0f0f0;padding:8px 10px}.kb-table th{color:#888;font-weight:600}.danger-btn{color:#c0392b;cursor:pointer;background:#fff;border:1px solid #e3b4b4;border-radius:8px;padding:4px 10px;font-size:.78rem}.danger-btn:hover{background:#fdf2f2}.notice{border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:.82rem}.notice.error{color:#c0392b;background:#fdf2f2;border:1px solid #f5d3d3}.notice.ok{color:#1e7e45;background:#f1f8f3;border:1px solid #cfe9d8}.guard{text-align:center;color:#999;padding:48px 20px}.header-left{align-items:center;gap:12px;display:flex}.sidebar-toggle-btn{color:#666;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:1.25rem;line-height:1}.sidebar-toggle-btn:hover{color:#111;background:#f3f3f3}.main-body{flex:1;min-height:0;display:flex;overflow:hidden}.sidebar{background:#fafafa;border-right:1px solid #f0f0f0;flex-direction:column;flex-shrink:0;width:312px;transition:width .18s,padding .18s;display:flex}.sidebar.collapsed{border-right:none;width:0;overflow:hidden}.sidebar-header{padding:12px}.new-chat-btn{color:#111;cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:9px 12px;font-size:.85rem;font-weight:500;transition:background .15s;display:flex}.new-chat-btn:hover{background:#f0f0f0}.new-chat-icon{font-size:1rem;line-height:1}.sidebar-label{color:#999;text-transform:none;letter-spacing:.02em;padding:6px 16px;font-size:.7rem}.session-list{flex:50%;min-height:0;padding:0 8px 12px;overflow-y:auto}.session-list::-webkit-scrollbar{width:4px}.session-list::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:3px}.sidebar-divider{background:#f0f0f0;height:1px;margin:4px 12px}.kb-hint{color:#aaa;padding:0 6px 8px 16px;font-size:.6rem;line-height:1.6}.kb-hint>div{white-space:nowrap}.kb-list{flex:50%;min-height:0;padding:0 8px 12px;overflow-y:auto}.kb-list::-webkit-scrollbar{width:4px}.kb-list::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:3px}.kb-list-item{color:#555;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:8px;padding:8px 10px;font-size:.82rem;overflow:hidden}.kb-list-item:hover{background:#f0f0f0}.kb-list-item.selected{color:#fff;background:#111;font-weight:600}.kb-list-item.selected:hover{background:#111}.kb-list-empty,.session-loading,.session-empty{color:#aaa;text-align:center;padding:16px;font-size:.78rem}.session-item{border-radius:8px;align-items:center;margin-bottom:2px;display:flex}.session-item:hover{background:#f0f0f0}.session-item.active{background:#ececec}.session-item.active .session-title{color:#111;font-weight:600}.session-item-btn{text-align:left;cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;gap:2px;min-width:0;padding:8px 10px;display:flex}.session-title{color:#333;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;overflow:hidden}.session-date{color:#aaa;font-size:.68rem}.session-delete-btn{color:#bbb;cursor:pointer;opacity:0;background:0 0;border:none;flex-shrink:0;padding:6px 10px;font-size:.85rem;transition:opacity .15s,color .15s}.session-item:hover .session-delete-btn{opacity:1}.session-delete-btn:hover{color:#c0392b}.chat-area{flex-direction:column;flex:1;min-height:0;display:flex}
