.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:var(--color-bg);padding:2.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px}.login-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;text-align:center}.login-subtitle{color:var(--color-text-secondary);text-align:center;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group input{padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.btn-primary{padding:.875rem 1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;transition:all .2s}.login-footer{text-align:center;margin-top:1.5rem;color:var(--color-text-secondary);font-size:.875rem}.home-container{min-height:100vh;background:var(--color-bg-secondary)}.header{background:var(--color-bg);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.header-content{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-actions{display:flex;align-items:center;gap:1rem}.btn-chat{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;transition:all .2s}.btn-chat:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.user-info{color:var(--color-text-secondary);font-size:.875rem}.btn-secondary{padding:.5rem 1rem;background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;transition:all .2s}.main-content{max-width:1200px;margin:0 auto;padding:2rem}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.content-header h2{font-size:1.875rem;font-weight:700}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.loading{text-align:center;padding:4rem;color:var(--color-text-secondary);display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:5rem 3rem;color:var(--color-text-secondary);display:flex;flex-direction:column;align-items:center;gap:1.25rem}.empty-icon{font-size:3.5rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.prompt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}@keyframes cardIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.prompt-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;position:relative;overflow:hidden;transition:box-shadow .25s,transform .25s,border-color .25s;animation:cardIn .4s ease both}.prompt-card-accent{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2,#f093fb);background-size:200% 100%;opacity:0;transition:opacity .3s;animation:shimmer 3s linear infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.prompt-card:hover{box-shadow:0 8px 30px #667eea26;transform:translateY(-4px);border-color:#667eea4d}.prompt-card:hover .prompt-card-accent{opacity:1}.prompt-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.75rem;gap:.5rem}.prompt-header h3{font-size:1.125rem;font-weight:600;flex:1;transition:color .2s}.prompt-card:hover .prompt-header h3{color:var(--color-primary)}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.7rem;font-weight:500;white-space:nowrap}.badge.public{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border:1px solid #bfdbfe}.badge.private{background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb}.prompt-description{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:.5rem;line-height:1.5}.btn-text{background:none;border:none;color:var(--color-primary);font-size:.875rem;font-weight:500;padding:0;transition:color .2s}.btn-text:hover{color:var(--color-primary-dark)}.btn-text.danger{color:var(--color-danger)}.btn-text.danger:hover{color:#dc2626}.btn-text.use{color:#059669;font-weight:600}.btn-text.use:hover{color:#047857}.prompt-meta{display:flex;align-items:center;margin-bottom:.75rem}.prompt-date{font-size:.75rem;color:var(--color-text-secondary);opacity:.7}.prompt-actions{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid var(--color-border);flex-wrap:wrap}.chat-container{display:flex;height:100vh;background:var(--color-bg-secondary)}.chat-sidebar{width:280px;background:var(--color-bg);border-right:1px solid var(--color-border);display:flex;flex-direction:column}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--color-border)}.sidebar-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.btn-back-home{padding:.25rem .625rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.75rem;color:var(--color-text-secondary);white-space:nowrap;transition:all .2s;flex-shrink:0}.btn-back-home:hover{background:var(--color-bg-hover);color:var(--color-text);border-color:var(--color-primary);color:var(--color-primary)}.sidebar-header h2{font-size:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-new-chat{width:100%;padding:.75rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;transition:all .2s}.btn-new-chat:hover{background:var(--color-primary-dark)}.session-list{flex:1;overflow-y:auto;padding:.5rem}.session-item{padding:1rem;margin-bottom:.5rem;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.session-item:hover{background:var(--color-bg-hover)}.session-item.active{background:var(--color-primary);color:#fff}.session-info{flex:1}.session-info h4{font-size:.875rem;font-weight:600;margin-bottom:.25rem}.session-time{font-size:.75rem;opacity:.7}.btn-delete-session{width:24px;height:24px;border:none;background:transparent;color:inherit;font-size:1.5rem;line-height:1;opacity:.5;transition:opacity .2s}.btn-delete-session:hover{opacity:1}.sidebar-footer{padding:1rem;border-top:1px solid var(--color-border)}.user-info{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.btn-logout{padding:.5rem 1rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;transition:all .2s}.btn-logout:hover{background:var(--color-bg-hover)}.chat-main{flex:1;display:flex;flex-direction:column;background:var(--color-bg)}.chat-header{padding:1.5rem 2rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.chat-header h3{font-size:1.25rem;font-weight:600}.chat-model{padding:.25rem .75rem;background:var(--color-bg-secondary);border-radius:9999px;font-size:.75rem;color:var(--color-text-secondary)}.messages-container{flex:1;overflow-y:auto;padding:2rem}.message{margin-bottom:1.5rem;display:flex}.message.user{justify-content:flex-end}.message-content{max-width:70%;display:flex;flex-direction:column;gap:.5rem}.message.user .message-content{align-items:flex-end}.message-role{font-size:.75rem;font-weight:600;color:var(--color-text-secondary)}.message-text{padding:1rem 1.5rem;border-radius:var(--radius-lg);line-height:1.6;white-space:pre-wrap;word-wrap:break-word;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.message.user .message-text{background:var(--color-primary);color:#fff}.message.assistant .message-text{background:var(--color-bg-secondary);color:var(--color-text)}.message.assistant .message-text:empty:after{content:"▋";animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.chat-input-form{padding:1.5rem 2rem;border-top:1px solid var(--color-border);display:flex;gap:1rem}.chat-input-form input{flex:1;padding:.875rem 1.25rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:1rem;transition:all .2s}.chat-input-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.chat-input-form button{padding:.875rem 2rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:600;transition:all .2s}.chat-input-form button:hover:not(:disabled){background:var(--color-primary-dark)}.chat-input-form button:disabled{opacity:.5;cursor:not-allowed}.chat-empty{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;color:var(--color-text-secondary)}.chat-empty h2{font-size:2rem;margin-bottom:.5rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:var(--color-bg);padding:2rem;border-radius:var(--radius-lg);width:90%;max-width:500px;box-shadow:var(--shadow-lg)}.modal-content h3{font-size:1.5rem;margin-bottom:1.5rem}.modal-content .form-group{margin-bottom:1.5rem}.modal-content .form-group label{display:block;font-weight:500;margin-bottom:.5rem;font-size:.875rem}.modal-content .form-group input,.modal-content .form-group select{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;transition:all .2s}.modal-content .form-group input:focus,.modal-content .form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.btn-primary{padding:.75rem 1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;transition:all .2s}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{padding:.75rem 1.5rem;background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);font-weight:600;transition:all .2s}.form-container{min-height:100vh;background:var(--color-bg-secondary);padding:2rem}.form-card{max-width:800px;margin:0 auto;background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.form-header h1{font-size:1.875rem;font-weight:700}.btn-back{padding:.5rem 1rem;background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;transition:all .2s}.btn-back:hover{background:var(--color-bg-hover)}.prompt-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;font-size:.875rem;color:var(--color-text)}.form-group input,.form-group textarea{padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;transition:all .2s;resize:vertical}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.form-group-inline{display:flex;align-items:center}.form-group-inline label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-group-inline input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.btn-primary{padding:.75rem 1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;transition:all .2s}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.75rem 1.5rem;background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;transition:all .2s}.btn-secondary:hover{background:var(--color-bg-hover)}.error-message{padding:.75rem 1rem;background:#fee2e2;color:#991b1b;border-radius:var(--radius-md);font-size:.875rem}:root{--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-primary-light: #60a5fa;--color-success: #10b981;--color-danger: #ef4444;--color-warning: #f59e0b;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-border: #e5e7eb;--color-bg: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-hover: #f3f4f6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem}*{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;color:var(--color-text);background-color:var(--color-bg-secondary);line-height:1.6}#root{min-height:100vh}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-dark)}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}
