:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#0f172a;background-color:#f8fafc}*{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden}.app-shell{display:grid;grid-template-columns:280px 1fr;height:100vh;overflow:hidden;background:#f8fafc}.sidebar{border-right:1px solid #e2e8f0;padding:16px;background:#fff;display:flex;flex-direction:column;gap:16px;height:100vh;overflow:hidden}.sidebar-header{display:flex;justify-content:space-between;align-items:center}.eyebrow{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#64748b;margin:0 0 4px}.customer-name{margin:0;font-weight:700;color:#0f172a}.sidebar-section{flex:1;display:flex;flex-direction:column;gap:8px;min-height:0;overflow:hidden}.sidebar-title{display:flex;justify-content:space-between;align-items:center;font-weight:600}.chat-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.chat-list-item{width:100%;text-align:left;padding:10px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;display:flex;flex-direction:column;gap:4px;transition:all .15s ease}.chat-list-item:hover{border-color:#cbd5e1;background:#f8fafc}.chat-list-item.active{border-color:#2563eb;box-shadow:0 0 0 1px #2563eb}.chat-title{font-weight:600;color:#0f172a}.chat-id{font-size:12px;color:#94a3b8;word-break:break-all}.chat-pane{display:grid;grid-template-rows:auto 1fr auto;height:100vh;overflow:hidden}.chat-header{padding:16px 20px;border-bottom:1px solid #e2e8f0;background:#fff}.chat-header h1{margin:0;font-size:22px}.chat-body{padding:20px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:12px;min-height:0}.muted{color:#64748b;margin:0}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:#e2e8f0;color:#334155;font-size:12px}.error-banner{padding:10px 12px;border-radius:10px;background:#fef2f2;color:#b91c1c;border:1px solid #fecdd3}.empty-state{border:1px dashed #cbd5e1;border-radius:12px;padding:16px;background:#fff}.message-list{display:flex;flex-direction:column;gap:12px}.message{padding:12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff}.message.user{background:#eef2ff;border-color:#c7d2fe}.message.assistant{background:#f8fafc}.message-meta{margin-bottom:6px}.message-content{white-space:pre-wrap;line-height:1.6}.message-content p{margin:.75em 0;line-height:1.6}.message-content p:first-child{margin-top:0}.message-content p:last-child{margin-bottom:0}.message-content strong,.message-content b{font-weight:700;color:#0f172a}.message-content em,.message-content i{font-style:italic}.message-content ul,.message-content ol{margin:.75em 0;padding-left:1.5em;line-height:1.6}.message-content ul{list-style-type:disc}.message-content ol{list-style-type:decimal}.message-content li{margin:.4em 0;line-height:1.6}.message-content h3,.message-content h4,.message-content h5,.message-content h6{margin:1em 0 .5em;font-weight:700;color:#0f172a;line-height:1.3}.message-content h3{font-size:1.25em;margin-top:1.2em}.message-content h4{font-size:1.1em;margin-top:1em}.message-content h5,.message-content h6{font-size:1em;margin-top:.8em}.message-content table{width:100%;border-collapse:collapse;margin:1em 0;font-size:.95em;background:#fff;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0}.message-content thead{background:#f1f5f9}.message-content th{padding:10px 12px;text-align:left;font-weight:600;color:#0f172a;border-bottom:2px solid #cbd5e1}.message-content td{padding:10px 12px;border-bottom:1px solid #e2e8f0;color:#334155}.message-content tbody tr:last-child td{border-bottom:none}.message-content tbody tr:hover{background:#f8fafc}.message-content br{line-height:1.6}.message-content pre{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;padding:12px;margin:.75em 0;overflow-x:auto;font-family:Courier New,monospace;font-size:.9em;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.composer{display:flex;flex-direction:column;gap:8px;padding:14px 20px;border-top:1px solid #e2e8f0;background:#fff;position:sticky;bottom:0;z-index:10}.composer textarea{width:100%;resize:vertical;min-height:60px;padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;font:inherit;background:#f8fafc}.composer textarea:focus{outline:2px solid #2563eb;outline-offset:1px;background:#fff}.composer-actions{display:flex;justify-content:flex-end}.primary-button,.secondary-button{border:none;border-radius:10px;padding:10px 14px;font-weight:600;cursor:pointer;transition:all .15s ease}.primary-button{background:#2563eb;color:#fff}.primary-button:disabled{opacity:.6;cursor:not-allowed}.primary-button:not(:disabled):hover{background:#1d4ed8}.secondary-button{background:#e2e8f0;color:#0f172a}.secondary-button:hover{background:#cbd5e1}
