*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4f46e5;--primary-dark: #4338ca;--primary-light: #818cf8;--secondary: #06b6d4;--secondary-dark: #0891b2;--accent: #8b5cf6;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--text-dark: #1e293b;--text-medium: #64748b;--text-light: #94a3b8;--text-white: #ffffff;--background: #ffffff;--background-alt: #f8fafc;--background-dark: #0f172a;--border: #e2e8f0;--border-light: #f1f5f9;--radius-sm: 6px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}body{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6;color:var(--text-dark);background:linear-gradient(135deg,#f8fafc,#e0e7ff);min-width:320px;min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4{font-weight:700;color:var(--text-dark);letter-spacing:-.025em}h1{font-size:3rem;line-height:1.1}p{margin-bottom:1em;color:var(--text-medium)}a{color:var(--primary);font-weight:500;text-decoration:none;transition:color var(--transition)}a:hover{color:var(--secondary)}button,.btn{border-radius:var(--radius);border:none;padding:.75em 1.5em;font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm)}button:hover:not(:disabled),.btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}button:active:not(:disabled),.btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--text-white)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-dark) 0%,#3730a3 100%)}.btn-secondary{background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-dark) 100%);color:var(--text-white)}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,var(--secondary-dark) 0%,#0e7490 100%)}section{padding:4rem 2rem;text-align:center}section.alt{background-color:var(--background-alt)}@media(max-width:768px){h1{font-size:2.2rem}section{padding:2rem 1rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.fade-in{animation:fadeIn .3s ease-out}.slide-in{animation:slideIn .3s ease-out}.navbar{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:1.25rem 2.5rem;font-size:1.1rem;box-shadow:var(--shadow-lg);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navbar .logo img{transition:transform var(--transition);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.navbar .logo img:hover{transform:scale(1.05) rotate(-5deg)}.tagline{font-style:italic;font-size:1.25rem;font-weight:600;letter-spacing:.05em;text-shadow:0 2px 4px rgba(0,0,0,.1)}.container{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2.5rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:95%;max-width:1200px;margin:2.5rem auto;display:flex;flex-direction:column;flex:1;border:1px solid var(--border-light);animation:fadeIn .5s ease-out}.hero{text-align:center;margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#f0f9ff,#e0e7ff);border-radius:var(--radius-lg);border:1px solid var(--border-light)}.hero h2{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.75rem;font-size:2rem}.hero p{color:var(--text-medium);font-size:1.1rem;margin-bottom:.5rem}.hero h4{color:var(--text-light);font-size:1rem;font-style:italic;margin-top:.5rem}.form-group{margin-bottom:1.75rem}#image-upload{display:none}.custom-file-upload{display:inline-flex;align-items:center;gap:.5rem;padding:12px 20px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--text-white);border-radius:var(--radius);cursor:pointer;font-weight:600;transition:all var(--transition);box-shadow:var(--shadow-md);border:2px solid transparent}.custom-file-upload:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.custom-file-upload:active{transform:translateY(0)}.custom-file-upload svg{font-size:1.1rem}label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-dark)}textarea{width:100%;padding:.875rem;border:2px solid var(--border);border-radius:var(--radius);font-size:1rem;box-sizing:border-box;resize:vertical;transition:all var(--transition);background-color:var(--background-alt);font-family:inherit}textarea:focus{outline:none;border-color:var(--primary);background-color:var(--background);box-shadow:0 0 0 3px #4f46e51a}textarea::placeholder{color:var(--text-light)}.preview{margin-top:1.25rem;text-align:center;padding:1rem;background:var(--background-alt);border-radius:var(--radius);border:2px dashed var(--border)}.preview img{max-width:100%;max-height:300px;border-radius:var(--radius);box-shadow:var(--shadow-lg);transition:transform var(--transition-slow)}.preview img:hover{transform:scale(1.02)}button[type=submit]{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);color:#fff;border:none;border-radius:var(--radius);padding:.875rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-md);width:100%;margin-top:.5rem}button[type=submit]:disabled{background:linear-gradient(135deg,var(--text-light) 0%,var(--border) 100%);cursor:not-allowed;box-shadow:none}button[type=submit]:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-xl)}button[type=submit]:active:not(:disabled){transform:translateY(0)}.chat-box{flex:1;margin:1.5rem 0;padding:1.5rem;border:2px solid var(--border-light);border-radius:var(--radius-lg);background:linear-gradient(135deg,#f8fafc,#f1f5f9);overflow-y:auto;max-height:600px;scroll-behavior:smooth}.chat-box::-webkit-scrollbar{width:8px}.chat-box::-webkit-scrollbar-track{background:var(--background-alt);border-radius:var(--radius-full)}.chat-box::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.chat-box::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.chat-message{display:flex;margin-bottom:1.25rem;animation:fadeIn .3s ease-out}.chat-message.user{justify-content:flex-end}.chat-message.assistant{justify-content:flex-start}.bubble{max-width:75%;padding:1rem 1.25rem;border-radius:var(--radius-lg);line-height:1.6;white-space:pre-wrap;font-size:.95rem;box-shadow:var(--shadow-sm);transition:all var(--transition)}.bubble:hover{box-shadow:var(--shadow-md)}.user .bubble{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border-bottom-right-radius:4px}.assistant .bubble{background:var(--background);color:var(--text-dark);border-bottom-left-radius:4px;border:2px solid var(--border-light)}.typing{display:inline-flex;align-items:center;gap:.25rem}.typing:after{content:"";animation:pulse 1.5s infinite}.chat-input{display:flex;gap:.75rem;margin-top:1.25rem}.chat-input textarea{flex:1;border-radius:var(--radius)}.chat-input button[type=submit]{width:auto;margin-top:0;padding:.875rem 1.75rem;white-space:nowrap}.chat-controls{display:flex;gap:.75rem;margin:1rem 0;flex-wrap:wrap}.chat-controls button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:var(--radius);font-weight:600;transition:all var(--transition);box-shadow:var(--shadow-md);border:2px solid transparent}.chat-controls button:first-child{background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-dark) 100%);color:#fff}.chat-controls button:first-child:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--secondary)}.chat-controls button:last-child{background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff}.chat-controls button:last-child:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--success)}.chat-controls button svg{font-size:.9rem}.error-message{margin-top:1.25rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#fef2f2,#fee2e2);color:var(--error);border:2px solid #fecaca;border-radius:var(--radius);font-weight:500;animation:slideIn .3s ease-out;display:flex;align-items:center;gap:.75rem}.error-message:before{content:"⚠";font-size:1.25rem}.footer{text-align:center;padding:1.5rem;margin-top:auto;background:linear-gradient(135deg,#f8fafc,#e2e8f0);font-size:.9rem;color:var(--text-medium);border-top:2px solid var(--border-light)}.footer img{margin-top:.75rem;transition:transform var(--transition)}.footer img:hover{transform:scale(1.05)}.skeleton{background:linear-gradient(90deg,var(--border-light) 25%,var(--border) 50%,var(--border-light) 75%);background-size:1000px 100%;animation:shimmer 2s infinite;border-radius:var(--radius)}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite;margin-right:.5rem}@keyframes spin{to{transform:rotate(360deg)}}.typing-dots span{animation:blink 1.4s infinite;animation-fill-mode:both;font-size:1.5rem;line-height:1}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:0}40%{opacity:1}}.custom-file-upload.dragging{background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-dark) 100%);border-color:var(--secondary);transform:scale(1.05)}@media(max-width:768px){.navbar{flex-direction:column;text-align:center;gap:.75rem;padding:1rem 1.5rem}.container{padding:1.5rem;width:95%;margin:1.5rem auto;border-radius:var(--radius-lg)}.hero h2{font-size:1.5rem}.hero p{font-size:1rem}.bubble{max-width:85%;font-size:.9rem;padding:.875rem 1rem}.chat-controls{flex-direction:column}.chat-controls button{width:100%;justify-content:center}.chat-input{flex-direction:column}.chat-input button[type=submit]{width:100%}}
