*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.login-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px;box-shadow:0 20px 60px #0000004d}.login-logo{text-align:center;margin-bottom:30px}.login-logo-icon{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:16px;display:inline-flex}.login-logo-icon svg{color:#fff;width:30px;height:30px}.login-logo h1{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:24px;font-weight:700}.login-tabs{gap:8px;margin-bottom:24px;display:flex}.login-tab{cursor:pointer;background:#f0f0f0;border:none;border-radius:8px;flex:1;padding:12px;font-weight:500;transition:all .2s}.login-tab.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.form-group{margin-bottom:16px}.form-group label{color:#555;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-input{border:2px solid #e0e0e0;border-radius:8px;width:100%;padding:12px 16px;font-size:16px;transition:border-color .2s}.form-input:focus{border-color:#667eea;outline:none}.btn{cursor:pointer;border:none;border-radius:8px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:all .2s}.btn-primary{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{color:#c33;background:#fee;border-radius:8px;margin-bottom:16px;padding:12px;font-size:14px}.layout{min-height:100vh;display:flex}.sidebar{background:#fff;border-right:1px solid #e0e0e0;flex-direction:column;width:260px;display:flex}.sidebar-header{border-bottom:1px solid #e0e0e0;padding:20px}.sidebar-logo{align-items:center;gap:12px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.sidebar-logo-icon svg{color:#fff;width:20px;height:20px}.sidebar-nav{flex:1;padding:16px}.nav-link{color:#666;border-radius:8px;align-items:center;gap:12px;margin-bottom:4px;padding:12px 16px;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover,.nav-link.active{color:#667eea;background:#f0f0f0}.nav-link svg{width:20px;height:20px}.sidebar-footer{border-top:1px solid #e0e0e0;padding:16px}.user-info{align-items:center;gap:12px;margin-bottom:12px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-weight:600;display:flex}.logout-btn{cursor:pointer;color:#666;background:#f0f0f0;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px;display:flex}.logout-btn:hover{color:#c33;background:#fee}.main-content{flex:1;overflow:auto}.page-header{justify-content:space-between;align-items:center;padding:32px;display:flex}.page-title h1{margin-bottom:4px;font-size:28px}.page-title p{color:#666}.btn-add{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-weight:600;display:flex}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;padding:0 32px 32px;display:grid}.project-card{background:#fff;border-radius:12px;padding:24px;transition:all .2s;box-shadow:0 2px 8px #00000014}.project-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.project-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.project-icon{background:linear-gradient(135deg,#667eea20 0%,#764ba220 100%);border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.project-icon svg{color:#667eea;width:24px;height:24px}.project-delete{cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;padding:8px;transition:all .2s}.project-card:hover .project-delete{opacity:1}.project-delete:hover{color:#c33;background:#fee}.project-title{margin-bottom:8px;font-size:18px;font-weight:600}.project-desc{color:#666;margin-bottom:16px;font-size:14px}.project-meta{color:#999;gap:16px;font-size:13px;display:flex}.chat-container{background:#f5f5f5;flex-direction:column;height:100vh;display:flex}.chat-header{background:#fff;border-bottom:1px solid #e0e0e0;align-items:center;gap:16px;padding:20px 32px;display:flex}.chat-header-icon{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.chat-header-icon svg{color:#fff;width:22px;height:22px}.chat-messages{flex:1;padding:32px;overflow-y:auto}.welcome-screen{text-align:center;padding:60px 20px}.welcome-icon{background:linear-gradient(135deg,#667eea20 0%,#764ba220 100%);border-radius:20px;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 24px;display:flex}.welcome-icon svg{color:#667eea;width:40px;height:40px}.message{gap:12px;max-width:80%;margin-bottom:20px;display:flex}.message.user{flex-direction:row-reverse;margin-left:auto}.message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.message.user .message-avatar{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.message.assistant .message-avatar{background:linear-gradient(135deg,#764ba2 0%,#667eea 100%)}.message-avatar svg{color:#fff;width:18px;height:18px}.message-content{border-radius:16px;padding:16px 20px;line-height:1.6}.message.user .message-content{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-bottom-right-radius:4px}.message.assistant .message-content{background:#fff;border-bottom-left-radius:4px;box-shadow:0 2px 8px #00000014}.chat-input-container{background:#fff;border-top:1px solid #e0e0e0;padding:20px 32px}.chat-input-wrapper{gap:12px;max-width:800px;margin:0 auto;display:flex}.chat-input{border:2px solid #e0e0e0;border-radius:12px;flex:1;padding:14px 20px;font-size:16px;transition:border-color .2s}.chat-input:focus{border-color:#667eea;outline:none}.chat-send-btn{cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.chat-send-btn svg{color:#fff;width:20px;height:20px}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.form-create{background:#fff;border-radius:12px;margin:0 32px 24px;padding:24px;box-shadow:0 2px 8px #00000014}.form-create h2{margin-bottom:20px}.form-actions{gap:12px;margin-top:20px;display:flex}.btn-secondary{cursor:pointer;background:#f0f0f0;border:none;border-radius:8px;padding:12px 24px;font-weight:500}.loading{justify-content:center;align-items:center;height:100vh;display:flex}.spinner{border:3px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:60px 20px}.empty-icon{background:#f0f0f0;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 20px;display:flex}.empty-icon svg{color:#999;width:40px;height:40px}@media (width<=768px){.sidebar{width:200px}.projects-grid{grid-template-columns:1fr;padding:0 16px 16px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.message{max-width:90%}}
