.chat-container[data-v-ab51f507]{display:flex;flex-direction:column;height:calc(100vh - 112px);max-height:800px}.welcome[data-v-ab51f507]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px}.welcome-icon[data-v-ab51f507]{font-size:64px;margin-bottom:20px}.welcome-title[data-v-ab51f507]{font-size:24px;color:var(--text-dark);margin-bottom:12px}.welcome-desc[data-v-ab51f507]{color:var(--text-gray);max-width:400px;margin-bottom:32px}.suggestions[data-v-ab51f507]{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.suggestion-btn[data-v-ab51f507]{padding:10px 18px;background:var(--bg-white);border:1px solid var(--border-color);border-radius:20px;color:var(--text-gray);font-size:14px;cursor:pointer;transition:all .2s ease}.suggestion-btn[data-v-ab51f507]:hover{border-color:var(--primary);color:var(--primary);box-shadow:var(--shadow)}.messages[data-v-ab51f507]{flex:1;overflow-y:auto;padding:20px 0}.message[data-v-ab51f507]{display:flex;gap:12px;margin-bottom:20px;animation:fadeIn .3s ease}.message.user[data-v-ab51f507]{flex-direction:row-reverse}.message-avatar[data-v-ab51f507]{width:36px;height:36px;border-radius:50%;background:var(--bg-gray);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.message.user .message-avatar[data-v-ab51f507]{background:var(--primary-light)}.message-content[data-v-ab51f507]{max-width:70%}.message.user .message-content[data-v-ab51f507]{display:flex;flex-direction:column;align-items:flex-end}.message-bubble[data-v-ab51f507]{padding:12px 16px;border-radius:var(--radius);line-height:1.6;word-break:break-word;white-space:pre-wrap}.message.user .message-bubble[data-v-ab51f507]{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.message.assistant .message-bubble[data-v-ab51f507]{background:var(--bg-white);box-shadow:var(--shadow);border-bottom-left-radius:4px}.loading-dots[data-v-ab51f507]{display:inline-flex;gap:4px;margin-left:8px}.loading-dots span[data-v-ab51f507]{width:6px;height:6px;background:var(--text-light);border-radius:50%;animation:bounce-ab51f507 1.4s infinite ease-in-out}.loading-dots span[data-v-ab51f507]:nth-child(1){animation-delay:-.32s}.loading-dots span[data-v-ab51f507]:nth-child(2){animation-delay:-.16s}@keyframes bounce-ab51f507{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.sources[data-v-ab51f507]{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;align-items:center}.sources-label[data-v-ab51f507]{font-size:12px;color:var(--text-light)}.source-tag[data-v-ab51f507]{padding:2px 8px;background:var(--bg-light);color:var(--primary);border-radius:10px;font-size:11px}.input-area[data-v-ab51f507]{padding:16px 0;border-top:1px solid var(--border-color);background:var(--bg-white);position:sticky;bottom:0}.input-wrapper[data-v-ab51f507]{display:flex;gap:12px;align-items:center;background:var(--bg-gray);border-radius:var(--radius);padding:4px}.chat-input[data-v-ab51f507]{flex:1;padding:12px 16px;background:transparent;border:none;font-size:15px;outline:none}.send-btn[data-v-ab51f507]{width:44px;height:44px;border:none;border-radius:var(--radius-sm);background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.send-btn[data-v-ab51f507]:hover:not(:disabled){background:var(--primary-dark)}.send-btn[data-v-ab51f507]:disabled{background:var(--text-light);cursor:not-allowed}.documents-container[data-v-8b8eee9d]{display:grid;grid-template-columns:1fr 1fr;gap:24px;min-height:calc(100vh - 112px)}.sidebar[data-v-8b8eee9d]{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;display:flex;flex-direction:column}.sidebar-header[data-v-8b8eee9d]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.sidebar-header h3[data-v-8b8eee9d]{font-size:16px;color:var(--text-dark)}.loading-state[data-v-8b8eee9d]{text-align:center;padding:40px;color:var(--text-gray)}.loading-inline[data-v-8b8eee9d]{display:inline-block;width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin-8b8eee9d .8s linear infinite;margin-right:8px}@keyframes spin-8b8eee9d{to{transform:rotate(360deg)}}.empty-state[data-v-8b8eee9d]{text-align:center;padding:60px 20px;color:var(--text-gray)}.empty-icon[data-v-8b8eee9d]{font-size:48px;margin-bottom:16px}.empty-hint[data-v-8b8eee9d]{font-size:13px;color:var(--text-light);margin-top:8px}.document-list[data-v-8b8eee9d]{flex:1;overflow-y:auto}.document-card[data-v-8b8eee9d]{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg-light);border-radius:var(--radius-sm);margin-bottom:10px;transition:all .2s ease}.document-card[data-v-8b8eee9d]:hover{background:var(--bg-gray)}.doc-icon[data-v-8b8eee9d]{font-size:32px}.doc-info[data-v-8b8eee9d]{flex:1;min-width:0}.doc-title[data-v-8b8eee9d]{font-size:14px;font-weight:500;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}.doc-meta[data-v-8b8eee9d]{display:flex;align-items:center;gap:10px}.doc-date[data-v-8b8eee9d]{font-size:12px;color:var(--text-light)}.delete-btn[data-v-8b8eee9d]{padding:6px;background:transparent;border:none;cursor:pointer;opacity:.5;transition:opacity .2s}.delete-btn[data-v-8b8eee9d]:hover{opacity:1}.upload-area[data-v-8b8eee9d]{display:flex;flex-direction:column;gap:20px}.upload-card[data-v-8b8eee9d]{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.upload-card h3[data-v-8b8eee9d]{font-size:18px;margin-bottom:8px}.upload-hint[data-v-8b8eee9d]{color:var(--text-gray);font-size:14px;margin-bottom:20px}.drop-zone[data-v-8b8eee9d]{border:2px dashed var(--border-color);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s ease;margin-bottom:20px}.drop-zone[data-v-8b8eee9d]:hover,.drop-zone.dragover[data-v-8b8eee9d]{border-color:var(--primary);background:var(--bg-light)}.drop-icon[data-v-8b8eee9d]{font-size:48px;margin-bottom:16px}.drop-text[data-v-8b8eee9d]{color:var(--text-gray);margin-bottom:8px}.drop-text .highlight[data-v-8b8eee9d]{color:var(--primary);font-weight:500}.drop-hint[data-v-8b8eee9d]{font-size:12px;color:var(--text-light)}.upload-btn[data-v-8b8eee9d]{width:100%}.progress-bar[data-v-8b8eee9d]{height:4px;background:var(--bg-gray);border-radius:2px;margin-top:16px;overflow:hidden}.progress-fill[data-v-8b8eee9d]{height:100%;background:var(--primary);animation:progress-8b8eee9d 2s ease-in-out infinite}@keyframes progress-8b8eee9d{0%{width:0;margin-left:0}50%{width:60%;margin-left:20%}to{width:0;margin-left:100%}}.success-message[data-v-8b8eee9d]{margin-top:16px;padding:12px;background:#e8f5e9;color:var(--primary-dark);border-radius:var(--radius-sm);text-align:center}.error-message[data-v-8b8eee9d]{margin-top:16px;padding:12px;background:#ffebee;color:#c62828;border-radius:var(--radius-sm);text-align:center}.tips-card[data-v-8b8eee9d]{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.tips-card h4[data-v-8b8eee9d]{font-size:14px;color:var(--text-dark);margin-bottom:12px}.tips-card ul[data-v-8b8eee9d]{list-style:none;padding:0}.tips-card li[data-v-8b8eee9d]{font-size:13px;color:var(--text-gray);padding:6px 0 6px 16px;position:relative}.tips-card li[data-v-8b8eee9d]:before{content:"•";position:absolute;left:0;color:var(--primary)}@media (max-width: 900px){.documents-container[data-v-8b8eee9d]{grid-template-columns:1fr}}.formulas-container[data-v-0a4b0f60]{max-width:1000px;margin:0 auto}.section-title[data-v-0a4b0f60]{font-size:20px;color:var(--text-dark);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--primary-light)}.ingredients-section[data-v-0a4b0f60]{margin-bottom:40px}.search-bar[data-v-0a4b0f60]{margin-bottom:20px}.search-input[data-v-0a4b0f60]{max-width:400px;padding:12px 16px;font-size:15px}.loading-state[data-v-0a4b0f60]{text-align:center;padding:40px;color:var(--text-gray)}.loading-spinner[data-v-0a4b0f60]{display:inline-block;width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin-0a4b0f60 .8s linear infinite;margin-right:8px;vertical-align:middle}@keyframes spin-0a4b0f60{to{transform:rotate(360deg)}}.empty-state[data-v-0a4b0f60]{text-align:center;padding:40px;color:var(--text-gray);background:var(--bg-white);border-radius:var(--radius)}.ingredients-grid[data-v-0a4b0f60]{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.ingredient-card[data-v-0a4b0f60]{background:var(--bg-white);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);cursor:pointer;transition:all .2s ease}.ingredient-card[data-v-0a4b0f60]:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.ing-header[data-v-0a4b0f60]{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.ing-name[data-v-0a4b0f60]{font-size:16px;color:var(--text-dark);font-weight:600}.ing-efficacy[data-v-0a4b0f60]{font-size:13px;color:var(--text-gray);line-height:1.5;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ing-footer[data-v-0a4b0f60]{padding-top:10px;border-top:1px solid var(--border-color)}.inci-name[data-v-0a4b0f60]{font-size:12px;color:var(--text-light);font-style:italic}.formulas-list[data-v-0a4b0f60]{display:flex;flex-direction:column;gap:20px}.formula-card[data-v-0a4b0f60]{background:var(--bg-white);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);transition:box-shadow .2s ease}.formula-card[data-v-0a4b0f60]:hover{box-shadow:var(--shadow-hover)}.formula-header[data-v-0a4b0f60]{margin-bottom:16px}.formula-title-row[data-v-0a4b0f60]{display:flex;align-items:center;gap:12px;margin-bottom:8px}.formula-name[data-v-0a4b0f60]{font-size:18px;color:var(--text-dark);font-weight:600}.formula-desc[data-v-0a4b0f60]{color:var(--text-gray);font-size:14px;line-height:1.6}.formula-category[data-v-0a4b0f60]{margin-bottom:16px}.category-label[data-v-0a4b0f60]{display:inline-block;padding:4px 12px;background:var(--bg-light);color:var(--text-gray);border-radius:4px;font-size:12px}.formula-ingredients h5[data-v-0a4b0f60]{font-size:14px;color:var(--text-dark);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.ingredient-list[data-v-0a4b0f60]{display:flex;flex-direction:column;gap:8px}.ingredient-item[data-v-0a4b0f60]{display:grid;grid-template-columns:120px 60px 1fr;gap:12px;padding:10px 12px;background:var(--bg-light);border-radius:var(--radius-sm);font-size:13px;align-items:center}.item-name[data-v-0a4b0f60]{font-weight:500;color:var(--text-dark)}.item-percent[data-v-0a4b0f60]{color:var(--primary);font-weight:600;text-align:center}.item-function[data-v-0a4b0f60]{color:var(--text-gray);font-size:12px}.modal-overlay[data-v-0a4b0f60]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content[data-v-0a4b0f60]{background:var(--bg-white);border-radius:var(--radius);max-width:500px;width:100%;max-height:80vh;overflow-y:auto;position:relative;animation:modalIn-0a4b0f60 .2s ease}@keyframes modalIn-0a4b0f60{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-close[data-v-0a4b0f60]{position:absolute;top:12px;right:12px;width:32px;height:32px;border:none;background:var(--bg-gray);border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-gray);transition:all .2s ease}.modal-close[data-v-0a4b0f60]:hover{background:var(--border-color);color:var(--text-dark)}.modal-header[data-v-0a4b0f60]{padding:20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.modal-header h3[data-v-0a4b0f60]{font-size:18px;color:var(--text-dark)}.modal-body[data-v-0a4b0f60]{padding:20px}.detail-row[data-v-0a4b0f60]{margin-bottom:16px}.detail-row[data-v-0a4b0f60]:last-child{margin-bottom:0}.detail-row label[data-v-0a4b0f60]{display:block;font-size:13px;color:var(--text-light);margin-bottom:4px}.detail-row span[data-v-0a4b0f60]{font-size:14px;color:var(--text-dark);line-height:1.6}.app[data-v-6bc0185c]{min-height:100vh;display:flex;flex-direction:column}.header[data-v-6bc0185c]{background:var(--bg-white);box-shadow:0 1px 3px #0000000d;position:sticky;top:0;z-index:100}.header-content[data-v-6bc0185c]{max-width:1200px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between}.logo[data-v-6bc0185c]{display:flex;align-items:center;gap:10px}.logo-icon[data-v-6bc0185c]{font-size:28px}.logo-text[data-v-6bc0185c]{font-size:20px;font-weight:600;color:var(--primary)}.nav[data-v-6bc0185c]{display:flex;gap:8px}.nav-btn[data-v-6bc0185c]{display:flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:none;border-radius:var(--radius-sm);font-size:14px;color:var(--text-gray);cursor:pointer;transition:all .2s ease}.nav-btn[data-v-6bc0185c]:hover{background:var(--bg-light);color:var(--text-dark)}.nav-btn.active[data-v-6bc0185c]{background:var(--primary);color:#fff}.nav-icon[data-v-6bc0185c]{font-size:16px}.main[data-v-6bc0185c]{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:24px}@media (max-width: 768px){.header-content[data-v-6bc0185c]{padding:0 16px}.logo-text[data-v-6bc0185c]{font-size:18px}.nav-text[data-v-6bc0185c]{display:none}.nav-btn[data-v-6bc0185c]{padding:10px}.main[data-v-6bc0185c]{padding:16px}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4CAF50;--primary-light: #66BB6A;--primary-dark: #388E3C;--bg-white: #FFFFFF;--bg-light: #F8FBF8;--bg-gray: #F5F5F5;--text-dark: #333333;--text-gray: #666666;--text-light: #999999;--border-color: #E8E8E8;--shadow: 0 2px 8px rgba(0, 0, 0, .08);--shadow-hover: 0 4px 16px rgba(0, 0, 0, .12);--radius: 12px;--radius-sm: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-light);color:var(--text-dark);line-height:1.6;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-gray)}::-webkit-scrollbar-thumb{background:var(--primary-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-size:14px;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{background:var(--text-light);cursor:not-allowed}.btn-outline{background:transparent;border:1px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--bg-light)}.btn-sm{padding:6px 12px;font-size:12px}.input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;transition:border-color .2s ease;outline:none}.input:focus{border-color:var(--primary)}.input::placeholder{color:var(--text-light)}.card{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;transition:box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-hover)}.tag{display:inline-block;padding:4px 10px;background:var(--bg-light);color:var(--primary);border-radius:20px;font-size:12px;font-weight:500}.tag-primary{background:var(--primary);color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{animation:pulse 1.5s ease-in-out infinite}
