*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--secondary-color: #6b7280;--success-color: #10b981;--error-color: #ef4444;--background: #f9fafb;--surface: #ffffff;--surface-hover: #f3f4f6;--border-color: #e5e7eb;--text-primary: #111827;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--grey-dark: #374151;--grey-medium: #6b7280;--grey-light: #d1d5db;--off-white: #f9fafb;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--border-radius: 8px;--transition: all .2s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--text-primary);line-height:1.6}#root{min-height:100vh}.chat-screen{min-height:100vh;display:flex;flex-direction:row;background:var(--background)}.chat-main-panel{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.chat-header{background:var(--surface);border-bottom:1px solid var(--border-color);padding:1.25rem 2rem;box-shadow:var(--shadow-sm)}.header-content{max-width:1100px;margin:0 auto}.header-top{display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-left{display:flex;align-items:center;gap:.75rem}.header-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.header-user{font-size:.8125rem;color:var(--text-secondary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.sidebar-toggle{background:none;border:none;cursor:pointer;padding:.375rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border-radius:6px;transition:var(--transition);flex-shrink:0}.sidebar-toggle:hover{background:var(--surface-hover);color:var(--text-primary)}.change-token-button{padding:.4rem .75rem;background:none;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.8125rem;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap}.change-token-button:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--text-secondary)}.new-chat-button{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:linear-gradient(135deg,var(--primary-color),#7c3aed);color:#fff;border:none;border-radius:var(--border-radius);font-size:.8125rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap;box-shadow:var(--shadow-sm)}.new-chat-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:linear-gradient(135deg,var(--primary-hover),#6d28d9)}.header-content h1{font-size:1.375rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem}.header-subtitle{color:var(--text-secondary);font-size:.875rem}.chat-main{flex:1;display:flex;justify-content:center;padding:2rem;overflow-y:auto}.chat-content{width:100%;max-width:1100px;display:flex;flex-direction:column;gap:1.5rem}.error-banner{background:#fef2f2;border:1px solid #fecaca;border-left:3px solid var(--error-color);border-radius:var(--border-radius);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow-sm);animation:slideDown .3s ease}.error-content{flex:1;color:var(--text-primary);font-size:.9375rem}.error-content strong{color:var(--error-color);font-weight:600}.error-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-secondary);padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:var(--transition)}.error-close:hover{background:#0000000d;color:var(--text-primary)}.response-area{flex:1;background:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:2rem;box-shadow:var(--shadow-sm);overflow-y:auto;min-height:400px;max-height:calc(100vh - 450px)}.response-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;color:var(--text-secondary);height:100%}.response-placeholder h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:.5rem;font-weight:600}.response-placeholder p{max-width:480px;line-height:1.6;color:var(--text-secondary)}.response-container{display:flex;flex-direction:column;gap:1.75rem;animation:fadeIn .4s ease}.section-header{margin-bottom:.75rem}.section-header h3{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.query-section{background:var(--surface-hover);padding:1.25rem 1.5rem;border-radius:var(--border-radius);border-left:3px solid var(--grey-dark)}.query-text{color:var(--text-primary);font-size:1rem;line-height:1.6}.chat-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:var(--text-secondary);font-size:.9375rem;animation:fadeIn .3s ease}.loader-dots{display:flex;gap:.5rem}.loader-dots span{width:10px;height:10px;background:var(--primary-color);border-radius:50%;animation:dotBounce 1.4s ease-in-out infinite}.loader-dots span:nth-child(2){animation-delay:.2s}.loader-dots span:nth-child(3){animation-delay:.4s}.rationale-section{background:var(--surface-hover);padding:1.25rem 1.5rem;border-radius:var(--border-radius);border-left:3px solid var(--grey-dark)}.rationale-text{color:var(--text-primary);line-height:1.7;font-size:.9375rem}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin-top:1rem;margin-bottom:.5rem;font-weight:600;color:var(--text-primary)}.markdown-content h1{font-size:1.25rem}.markdown-content h2{font-size:1.125rem}.markdown-content h3{font-size:1rem}.markdown-content p{margin-bottom:.75rem}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{margin:.5rem 0;padding-left:1.5rem}.markdown-content li{margin-bottom:.25rem}.markdown-content code{background:var(--surface);border:1px solid var(--border-color);padding:.125rem .375rem;border-radius:4px;font-size:.85em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.markdown-content pre{background:var(--surface);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;overflow-x:auto;margin:.75rem 0}.markdown-content pre code{background:none;border:none;padding:0;font-size:.85em}.markdown-content blockquote{border-left:3px solid var(--grey-light);padding-left:1rem;margin:.75rem 0;color:var(--text-secondary)}.markdown-content table{border-collapse:collapse;width:100%;margin:.75rem 0}.markdown-content th,.markdown-content td{border:1px solid var(--border-color);padding:.5rem .75rem;text-align:left;font-size:.875rem}.markdown-content th{background:var(--surface);font-weight:600}.input-area{background:var(--surface);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:1.5rem;box-shadow:var(--shadow-sm)}.query-input-container{width:100%}.input-wrapper{display:flex;flex-direction:column;gap:.75rem}.query-textarea{width:100%;padding:.875rem 1rem;border:1px solid var(--border-color);border-radius:var(--border-radius);font-family:inherit;font-size:.9375rem;color:var(--text-primary);resize:vertical;min-height:100px;max-height:300px;transition:var(--transition);background:var(--surface);line-height:1.5}.query-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb14}.query-textarea:disabled{background:var(--off-white);cursor:not-allowed;opacity:.6}.query-textarea::placeholder{color:var(--text-tertiary)}.submit-button{align-self:flex-end;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 2rem;background:linear-gradient(135deg,var(--primary-color),#7c3aed);color:#fff;border:none;border-radius:var(--border-radius);font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap;min-width:140px;box-shadow:var(--shadow-sm)}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md);background:linear-gradient(135deg,var(--primary-hover),#6d28d9)}.submit-button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.submit-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.chat-footer{background:var(--surface);border-top:1px solid var(--border-color);padding:1rem 2rem;text-align:center;color:var(--text-tertiary);font-size:.8125rem}.chat-footer p{max-width:1100px;margin:0 auto}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes dotBounce{0%,80%,to{transform:scale(.4);opacity:.3}40%{transform:scale(1);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.sidebar{display:flex!important;position:fixed;left:0;top:0;height:100vh;z-index:200;transform:translate(-100%);transition:transform .3s ease;width:280px;min-width:unset}.sidebar.sidebar-open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:199}.chat-header{padding:1rem}.header-content h1{font-size:1rem}.header-subtitle,.header-user{display:none}.chat-main{padding:1rem}.response-area{padding:1.5rem;min-height:300px}.input-area{padding:1rem}.submit-button{align-self:stretch;width:100%}}.sidebar{display:none;width:260px;min-width:260px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border-color);flex-direction:column;overflow-y:auto;box-shadow:var(--shadow-sm)}.sidebar.sidebar-open{display:flex}.sidebar-backdrop{display:none}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.sidebar-title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.sidebar-close{background:none;border:none;font-size:1.375rem;line-height:1;cursor:pointer;color:var(--text-tertiary);padding:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:var(--transition)}.sidebar-close:hover{background:var(--surface-hover);color:var(--text-primary)}.sidebar-list{flex:1;overflow-y:auto;padding:.5rem 0}.sidebar-empty{padding:1.5rem 1.25rem;color:var(--text-tertiary);font-size:.875rem;text-align:center}.sidebar-item{display:flex;flex-direction:column;gap:.25rem;width:100%;text-align:left;padding:.75rem 1.25rem;background:none;border:none;cursor:pointer;transition:var(--transition);border-left:3px solid transparent}.sidebar-item:hover{background:var(--surface-hover)}.sidebar-item-active{background:var(--surface-hover);border-left-color:var(--primary-color)}.sidebar-item-title{font-size:.875rem;color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.sidebar-item-time{font-size:.75rem;color:var(--text-tertiary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:300;padding:1rem;animation:fadeIn .2s ease}.modal-box{background:var(--surface);border-radius:12px;padding:1.75rem 2rem;width:100%;max-width:480px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:.875rem}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-tertiary);padding:0;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:var(--transition)}.modal-close:hover{background:var(--surface-hover);color:var(--text-primary)}.modal-description{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.modal-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--border-radius);font-family:inherit;font-size:.9375rem;color:var(--text-primary);background:var(--off-white);line-height:1.5;transition:var(--transition)}.modal-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb14}.modal-input:disabled{opacity:.6;cursor:not-allowed}.modal-error{font-size:.875rem;color:var(--error-color);font-weight:500}.modal-confirmation{font-size:.875rem;color:var(--success-color);font-weight:500}.modal-actions{display:flex;justify-content:flex-end}.modal-save-button{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.5rem;background:linear-gradient(135deg,var(--primary-color),#7c3aed);color:#fff;border:none;border-radius:var(--border-radius);font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);min-width:110px;justify-content:center}.modal-save-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md);background:linear-gradient(135deg,var(--primary-hover),#6d28d9)}.modal-save-button:disabled{opacity:.5;cursor:not-allowed;transform:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--off-white);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--grey-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--grey-medium)}
