html,body{margin:0;padding:0;height:100%;width:100%}:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--text-color: #333333;--background-color: #f5f5f5;--border-color: #e5e5e5}.stat{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;border:1px solid #ddd}.score-stat{background-color:#e3f2fd;color:#1976d2;border-color:#1976d2}.critical-stat{background-color:#ffebee;color:#d32f2f;border-color:#d32f2f}.warning-stat{background-color:#fff8e1;color:#ff8f00;border-color:#ff8f00}.info-stat{background-color:#e8f5e9;color:#388e3c;border-color:#388e3c}.metadata-tag{background-color:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;margin-right:4px;margin-top:4px;display:inline-block}.markdown-content{font-size:14px;line-height:1.6}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin-top:16px;margin-bottom:8px;font-weight:600}.markdown-content h1{font-size:1.4em;border-bottom:1px solid #eee;padding-bottom:4px}.markdown-content h2{font-size:1.3em}.markdown-content h3{font-size:1.2em}.markdown-content h4{font-size:1.1em}.markdown-content p{margin:8px 0}.markdown-content ul,.markdown-content ol{margin:8px 0;padding-left:20px}.markdown-content li{margin-bottom:4px}.markdown-content code{background-color:#f6f8fa;padding:2px 4px;border-radius:3px;font-family:SFMono-Regular,Monaco,Inconsolata,Fira Code,monospace;font-size:.9em}.markdown-content pre{background-color:#f6f8fa;padding:12px;border-radius:6px;overflow-x:auto;margin:10px 0}.markdown-content pre code{background-color:transparent;padding:0;border-radius:0}.markdown-content blockquote{border-left:4px solid #ddd;padding-left:16px;margin-left:0;color:#666}.markdown-content table{border-collapse:collapse;width:100%;margin:12px 0}.markdown-content table th,.markdown-content table td{border:1px solid #ddd;padding:6px 8px}.markdown-content table th{background-color:#f6f8fa;font-weight:600}.markdown-content img{max-width:100%;border-radius:4px}.markdown-content strong{font-weight:600}.markdown-content a{color:#1976d2;text-decoration:none}.markdown-content a:hover{text-decoration:underline}.code-review-info{padding:12px 20px;background-color:#f5f5f5;border-bottom:1px solid #e1e1e1}.info-message{background-color:#e3f2fd;padding:10px 16px;border-radius:8px;border-left:4px solid #1976d2}.info-message p{margin:0;font-size:14px;color:#333}.ai-chat-container{display:flex;flex-direction:column;height:700px;width:100%;max-width:900px;margin:0 auto;border:1px solid #e1e1e1;border-radius:12px;overflow:hidden;box-shadow:0 5px 20px #0000001a;background-color:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.chat-header{padding:16px 20px;background-color:#4f7cac;color:#fff;border-bottom:1px solid #e1e1e1;text-align:center}.chat-header h2{margin:0 0 12px;font-size:1.2rem;font-weight:600}.mode-toggle{display:flex;gap:8px;justify-content:center}.mode-button{padding:8px 16px;border:1px solid rgba(255,255,255,.3);background-color:transparent;color:#fff;border-radius:20px;cursor:pointer;font-size:14px;transition:all .2s ease}.mode-button:hover{background-color:#ffffff1a}.mode-button.active{background-color:#fff;color:#4f7cac;border-color:#fff}.code-review-settings{padding:16px 20px;background-color:#f5f5f5;border-bottom:1px solid #e1e1e1;display:flex;gap:20px;flex-wrap:wrap}.setting-group{display:flex;flex-direction:column;gap:4px}.setting-group label{font-size:12px;font-weight:500;color:#666}.language-select,.author-input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s}.language-select:focus,.author-input:focus{border-color:#4f7cac}.language-select{min-width:120px}.author-input{min-width:150px}.messages-container{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;background-color:#f8f9fa;background-image:linear-gradient(rgba(255,255,255,.8) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.8) 1px,transparent 1px);background-size:20px 20px}.empty-state{color:#888;text-align:center;margin:auto;font-style:italic}.message{display:flex;align-items:flex-start;gap:8px;max-width:85%;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-message{align-self:flex-end;flex-direction:row-reverse}.ai-message{align-self:flex-start}.code-review-message{max-width:95%}.message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.user-message .message-avatar{background-color:#e3f2fd}.ai-message .message-avatar{background-color:#e8f5e9}.message-bubble{background-color:#fff;padding:12px 16px;border-radius:18px;box-shadow:0 1px 2px #0000001a;position:relative;word-break:break-word;line-height:1.5}.user-message .message-bubble{background-color:#1976d2;color:#fff;border-bottom-right-radius:4px}.ai-message .message-bubble{background-color:#fff;color:#333;border-bottom-left-radius:4px}.code-review-response{max-width:100%}.code-review-response .message-content{white-space:pre-wrap;font-family:SFMono-Regular,Monaco,Inconsolata,Fira Code,Droid Sans Mono,Source Code Pro,monospace;font-size:13px;line-height:1.6;margin-bottom:12px}.review-summary{background-color:#f5f5f5;padding:12px;border-radius:8px;margin-top:12px;border-left:4px solid #4f7cac}.review-summary h4{margin:0 0 8px;font-size:14px;color:#333}.summary-stats{display:flex;gap:12px;flex-wrap:wrap}.stat{background-color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;border:1px solid #ddd}.review-metadata{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}.metadata-tag{background-color:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500}.loading-indicator{display:flex;align-items:center;gap:4px;padding:8px 4px}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background-color:#90a4ae;animation:bounce 1.4s infinite ease-in-out both}.dot:nth-child(1){animation-delay:-.32s}.dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.input-form{display:flex;padding:16px;gap:10px;background-color:#fff;border-top:1px solid #e1e1e1;position:relative}.input-field{flex:1;padding:12px 16px;border:1px solid #ddd;border-radius:12px;outline:none;font-size:16px;font-family:inherit;transition:border-color .2s,box-shadow .2s;resize:vertical;min-height:44px;max-height:120px}.input-field:focus{border-color:#1976d2;box-shadow:0 0 0 2px #1976d233}.code-input{font-family:SFMono-Regular,Monaco,Inconsolata,Fira Code,Droid Sans Mono,Source Code Pro,monospace;font-size:14px;line-height:1.5}.input-form button{width:44px;height:44px;background-color:#e0e0e0;color:#9e9e9e;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s,transform .1s;align-self:flex-end}.input-form button svg{width:20px;height:20px}.input-form button.active{background-color:#1976d2;color:#fff}.input-form button:hover:not(:disabled).active{background-color:#1565c0;transform:scale(1.05)}.input-form button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.ai-chat-container{height:100vh;max-width:100%;border-radius:0;border:none}.code-review-settings{flex-direction:column;gap:12px}.mode-toggle{flex-direction:column;gap:4px}.summary-stats{flex-direction:column;gap:8px}.message{max-width:95%}.code-review-message{max-width:98%}}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#f0f2f5;color:#333}.app{min-height:100vh;display:flex;flex-direction:column;padding:20px;max-width:1200px;margin:0 auto}.app-header{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.app-header h1{color:#1976d2;margin-bottom:8px;font-weight:600}.app-subtitle{color:#666;font-size:1rem;margin-top:0}.app-main{flex:1;width:100%;max-width:800px;margin:0 auto}.app-footer{margin-top:40px;text-align:center;color:#666;font-size:14px;padding-top:20px;border-top:1px solid #e0e0e0}@media (max-width: 768px){.app{padding:10px}.app-header{margin-bottom:20px}.app-header h1{font-size:1.5rem}.app-subtitle{font-size:.9rem}.app-footer{margin-top:20px}}
