.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.auth-modal{background:#fff;border-radius:12px;padding:24px;width:100%;max-width:400px;box-shadow:0 10px 25px #0003;position:relative}.auth-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.auth-modal-header h2{margin:0;color:#333;font-size:24px;font-weight:600}.auth-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.auth-modal-close:hover{background-color:#f5f5f5}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:#333;font-size:14px}.form-group input{padding:12px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#007bff}.auth-error{background-color:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px;border:1px solid #fcc}.auth-submit{background-color:#007bff;color:#fff;border:none;padding:12px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s;margin-top:8px}.auth-submit:hover:not(:disabled){background-color:#0056b3}.auth-submit:disabled{background-color:#ccc;cursor:not-allowed}.auth-switch{margin-top:24px;text-align:center}.auth-switch p{margin:0;color:#666;font-size:14px}.auth-switch-button{background:none;border:none;color:#007bff;cursor:pointer;font-size:14px;text-decoration:underline;padding:0;margin:0}.auth-switch-button:hover{color:#0056b3}.app{max-width:1200px;margin:0 auto;padding:20px;min-height:100vh;display:flex;flex-direction:column}header{margin-bottom:40px;padding:20px;background:linear-gradient(135deg,#2d5a27,#4a7c59);border-radius:15px;color:#fff;box-shadow:0 4px 15px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.header-content>div:first-child{text-align:left}.auth-section,.user-info{display:flex;align-items:center;gap:1rem}.login-button,.logout-button{background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.login-button:hover,.logout-button:hover{background:#ffffff4d;border-color:#ffffff80}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}header h1{margin:0 0 10px;font-size:2.5em;font-weight:700}header p{margin:0;font-size:1.2em;opacity:.9}main{flex:1;display:flex;flex-direction:column;gap:30px}.provider-selector{display:flex;align-items:center;gap:15px;justify-content:center;padding:20px;background:#f8f9fa;border-radius:10px;border:2px solid #e9ecef}.provider-selector label{font-weight:600;color:#495057}.provider-selector select{padding:8px 15px;border:2px solid #ced4da;border-radius:8px;font-size:1em;background:#fff;color:#495057;cursor:pointer}.provider-selector select:focus{outline:none;border-color:#4a7c59;box-shadow:0 0 0 3px #4a7c591a}.upload-area{border:3px dashed #4a7c59;border-radius:15px;padding:40px;text-align:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);transition:all .3s ease;cursor:pointer}.upload-area:hover{border-color:#2d5a27;background:linear-gradient(135deg,#e9ecef,#dee2e6);transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.upload-button{background:none;border:none;width:100%;height:100%;cursor:pointer;padding:0}.upload-content{display:flex;flex-direction:column;align-items:center;gap:15px}.upload-icon{font-size:4em;color:#4a7c59}.upload-content h3{margin:0;font-size:1.8em;color:#2d5a27;font-weight:700}.upload-content p{margin:0;font-size:1.1em;color:#6c757d}.upload-hint{font-size:.9em!important;color:#868e96!important;font-style:italic}.loading-spinner{width:30px;height:30px;border:3px solid #f3f3f3;border-top:3px solid #4a7c59;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background:#f8d7da;color:#721c24;padding:15px;border-radius:8px;border:1px solid #f5c6cb;text-align:center;font-weight:500}.image-section{display:flex;flex-direction:column;align-items:center;gap:20px;padding:30px;background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a}.image-preview{max-width:100%;max-height:500px;border-radius:10px;box-shadow:0 4px 15px #0003}.image-actions{display:flex;gap:15px;flex-wrap:wrap;justify-content:center}.image-actions button{padding:12px 24px;font-size:1.1em;font-weight:600;border-radius:10px;border:none;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.image-actions button:first-child{background:linear-gradient(135deg,#4a7c59,#2d5a27);color:#fff}.image-actions button:first-child:hover{background:linear-gradient(135deg,#2d5a27,#1e3d1a);transform:translateY(-2px);box-shadow:0 6px 20px #2d5a274d}.image-actions button:last-child{background:#6c757d;color:#fff}.image-actions button:last-child:hover{background:#5a6268;transform:translateY(-2px)}.image-actions button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.creature-container{background:#fff;border-radius:15px;padding:30px;box-shadow:0 4px 15px #0000001a;border-left:5px solid #4a7c59}.creature-title{display:flex;align-items:center;gap:15px;margin:0 0 20px;color:#2d5a27;font-size:1.8em;font-weight:700}.streaming-indicator{display:flex;align-items:center;gap:5px}.typing-dots{display:flex;gap:3px}.typing-dots span{width:6px;height:6px;background:#4a7c59;border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-dots span:nth-child(1){animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.creature-content{line-height:1.8;color:#495057;font-size:1.1em;white-space:pre-wrap}.creature-content h2,.creature-content h3{color:#2d5a27;margin-top:20px;margin-bottom:10px}.creature-content ul,.creature-content ol{margin:10px 0;padding-left:20px}.creature-content li{margin:5px 0}footer{text-align:center;margin-top:40px;padding:20px;color:#6c757d;font-style:italic}@media (max-width: 768px){.app{padding:15px}header h1{font-size:2em}.upload-area{padding:30px 20px}.image-actions{flex-direction:column;width:100%}.image-actions button{width:100%;justify-content:center}.provider-selector{flex-direction:column;gap:10px}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
