.chat-container{display:flex;flex-direction:column;height:600px}.chat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border)}.chat-header h2{color:var(--dark);font-size:1.8rem}.chat-controls{display:flex;gap:10px;align-items:center}.status{padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600}.status.connected{background:#e6fffa;color:#047857}.status.disconnected{background:#fee2e2;color:#dc2626}.btn-clear{padding:8px 16px;background:var(--danger);color:#fff;border-radius:8px;font-size:.9rem}.messages-container{flex:1;overflow-y:auto;padding:20px;background:var(--light);border-radius:12px;margin-bottom:20px}.empty-state{text-align:center;padding:60px 20px;color:#718096}.empty-state p{font-size:1.2rem;margin-bottom:10px}.empty-state .hint{font-size:.95rem;opacity:.7}.message{display:flex;gap:12px;margin-bottom:20px;animation:messageSlide .3s ease}.message.user{flex-direction:row-reverse}.message-avatar{font-size:2rem;flex-shrink:0}.message-content{max-width:70%}.message.user .message-content{background:var(--primary);color:#fff;border-radius:18px 18px 4px}.message.assistant .message-content{background:#fff;color:var(--dark);border-radius:18px 18px 18px 4px;box-shadow:0 2px 8px var(--shadow)}.message-text{padding:12px 16px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.input-form{display:flex;gap:10px}.message-input{flex:1;padding:14px 20px;border:2px solid var(--border);border-radius:25px;font-size:1rem;transition:all .3s ease}.message-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.message-input:disabled{background:#f7fafc;opacity:.7}.btn-send{padding:14px 28px;background:var(--primary);color:#fff;border-radius:25px;font-size:1rem;font-weight:600;min-width:100px}.btn-send:hover:not(:disabled){background:var(--primary-dark)}@keyframes messageSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#e2e8f0;border-radius:10px}.messages-container::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:10px}.messages-container::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media (max-width: 768px){.chat-container{height:500px}.chat-header{flex-direction:column;align-items:flex-start;gap:10px}.message-content{max-width:85%}.input-form{flex-direction:column}.btn-send{width:100%}}.imagegen-container{max-width:800px;margin:0 auto}.imagegen-header{text-align:center;margin-bottom:30px}.imagegen-header h2{color:var(--dark);font-size:2rem;margin-bottom:10px}.imagegen-header p{color:#718096;font-size:1.1rem}.imagegen-form{margin-bottom:30px}.prompt-input{width:100%;padding:16px;border:2px solid var(--border);border-radius:12px;font-size:1rem;resize:vertical;margin-bottom:15px;transition:all .3s ease}.prompt-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.prompt-input:disabled{background:#f7fafc;opacity:.7}.btn-generate{width:100%;padding:16px 32px;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;border-radius:12px;font-size:1.1rem;font-weight:600}.btn-generate:hover:not(:disabled){box-shadow:0 8px 20px #667eea66}.error-message{padding:16px;background:#fee2e2;color:#dc2626;border-radius:12px;margin-bottom:20px;text-align:center}.image-result{animation:fadeIn .5s ease}.image-wrapper{margin-bottom:20px;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px var(--shadow)}.generated-image{width:100%;height:auto;display:block}.image-actions{display:flex;gap:10px;margin-bottom:20px}.btn-download,.btn-open{flex:1;padding:12px 24px;border-radius:10px;font-size:1rem;font-weight:600;text-align:center;text-decoration:none;display:inline-block}.btn-download{background:var(--success);color:#fff}.btn-open{background:var(--primary);color:#fff}.image-info{padding:16px;background:var(--light);border-radius:12px;color:var(--dark)}.image-info p{margin-bottom:8px}.image-info p:last-child{margin-bottom:0}.loading-state{text-align:center;padding:60px 20px;animation:fadeIn .5s ease}.spinner{width:60px;height:60px;margin:0 auto 20px;border:6px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.loading-state p{font-size:1.2rem;color:var(--dark);margin-bottom:8px}.loading-state small{color:#718096}.examples{padding:30px;background:var(--light);border-radius:12px;margin-top:30px}.examples h3{color:var(--dark);margin-bottom:15px;font-size:1.3rem}.examples ul{list-style:none}.examples li{padding:12px 16px;margin-bottom:10px;background:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;border:2px solid transparent}.examples li:hover{border-color:var(--primary);transform:translate(5px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.imagegen-header h2{font-size:1.5rem}.image-actions{flex-direction:column}.btn-download,.btn-open{width:100%}}.app{max-width:1200px;margin:0 auto;padding:20px;min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;color:#fff;margin-bottom:30px;animation:fadeIn .5s ease}.app-header h1{font-size:3rem;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.app-header p{font-size:1.1rem;opacity:.9}.app-nav{display:flex;gap:10px;margin-bottom:20px;background:#ffffff1a;padding:10px;border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-nav button{flex:1;padding:12px 24px;background:#fff3;color:#fff;border-radius:10px;font-size:1rem;font-weight:600}.app-nav button.active{background:#fff;color:var(--primary);box-shadow:0 4px 12px #0003}.app-main{flex:1;background:#fff;border-radius:20px;padding:30px;box-shadow:0 20px 60px #0000004d;animation:slideUp .5s ease}.app-footer{text-align:center;color:#fff;margin-top:20px;opacity:.8;font-size:.9rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.app{padding:10px}.app-header h1{font-size:2rem}.app-main{padding:15px}}:root{--primary: #667eea;--primary-dark: #5a67d8;--secondary: #764ba2;--success: #48bb78;--danger: #f56565;--dark: #2d3748;--light: #f7fafc;--border: #e2e8f0;--shadow: rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}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:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{cursor:pointer;font-family:inherit;border:none;outline:none;transition:all .3s ease}button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}button:disabled{opacity:.6;cursor:not-allowed}input,textarea{font-family:inherit;outline:none}
