*{margin:0;padding:0;box-sizing:border-box}:root{--primary-purple:#8b5cf6;--primary-light:#a78bfa;--primary-dark:#6b46c1;--bg-primary:#fff;--bg-secondary:#f9fafb;--text-primary:#111827;--text-secondary:#6b7280;--border-color:#e5e7eb;--hover-bg:#f3f4f6;--success-green:#10b981;--premium-gradient:linear-gradient(135deg,#8b5cf6,#6b46c1)}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:var(--bg-primary);color:var(--text-primary);overflow:hidden}.app,body{height:100vh}.app{display:flex;flex-direction:column;width:100vw}.header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);height:60px;padding:0 2rem;flex-shrink:0;z-index:100}.header,.header-content{display:flex;align-items:center}.header-content{width:100%;justify-content:space-between}.logo{display:flex;align-items:center;gap:.75rem}.logo h1{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;gap:1rem;align-items:center}.new-chat-btn,.toggle-sidebar-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s}.new-chat-btn:hover:not(:disabled),.toggle-sidebar-btn:hover{background:var(--hover-bg);border-color:var(--primary-purple);color:var(--primary-purple)}.new-chat-btn:disabled{opacity:.5;cursor:not-allowed}.chat-container,.main-container{flex:1 1;display:flex;overflow:hidden}.chat-container{flex-direction:column;background:var(--bg-secondary)}.chat-content{flex:1 1;overflow-y:auto;display:flex;flex-direction:column}.pricing-sidebar{width:380px;background:var(--bg-primary);border-left:1px solid var(--border-color);overflow-y:auto;flex-shrink:0}.sidebar-content{padding:2rem 1.5rem}.sidebar-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.pricing-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem;position:relative;transition:all .3s}.pricing-card.premium{border-color:var(--primary-purple);box-shadow:0 4px 12px rgba(139,92,246,.1)}.pricing-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.1)}.card-badge{position:absolute;top:-10px;right:20px;background:var(--premium-gradient);color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.card-header{margin-bottom:1.25rem}.card-icon{width:40px;height:40px;background:var(--bg-secondary);border-radius:.5rem;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--primary-purple)}.pricing-card h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.price{display:flex;align-items:baseline;gap:.25rem}.price .amount{font-size:2rem;font-weight:700;color:var(--text-primary)}.price .period{font-size:1rem;color:var(--text-secondary)}.features-list{list-style:none;margin-bottom:1.5rem}.features-list li{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;color:var(--text-primary);font-size:.875rem}.features-list svg{color:var(--success-green);flex-shrink:0}.upgrade-btn{width:100%;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.upgrade-btn.primary{background:var(--premium-gradient);color:#fff}.upgrade-btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(139,92,246,.3)}.upgrade-btn.secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.upgrade-btn.secondary:hover{background:var(--hover-bg);border-color:var(--primary-purple);color:var(--primary-purple)}.expert-contact{padding:1rem;background:var(--bg-secondary);border-radius:.5rem;margin-bottom:1rem}.contact-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.expert-email{color:var(--primary-purple);text-decoration:none;font-weight:500;font-size:.875rem}.expert-email:hover{text-decoration:underline}.current-plan{padding:1rem;background:var(--bg-secondary);border-radius:.5rem;text-align:center}.plan-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.plan-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.plan-limit{font-size:.75rem;color:var(--text-secondary)}.welcome-screen{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;max-width:800px;margin:0 auto;width:100%}.welcome-logo{margin-bottom:2rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.welcome-title{font-size:2rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.welcome-subtitle{font-size:1.125rem;color:var(--text-secondary);margin-bottom:3rem}.example-questions{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:1rem;gap:1rem;width:100%;max-width:600px}.example-question{display:flex;align-items:center;gap:.5rem;padding:1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;color:var(--text-primary);font-size:.875rem;text-align:left;cursor:pointer;transition:all .2s}.example-question:hover:not(:disabled){border-color:var(--primary-purple);background:var(--hover-bg);transform:translateY(-2px);box-shadow:0 4px 12px rgba(139,92,246,.1)}.example-question:disabled{opacity:.5;cursor:not-allowed}.example-question svg{color:var(--primary-purple);flex-shrink:0}.messages{flex:1 1;padding:2rem 0;display:flex;flex-direction:column;gap:1.5rem}.message-wrapper{display:flex;justify-content:center;padding:0 2rem}.message-container{width:100%;max-width:800px;display:flex;gap:1rem;align-items:flex-start}.message-wrapper.user .message-container{flex-direction:row-reverse}.avatar{width:36px;height:36px;border-radius:.5rem;background:var(--bg-primary);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.message-wrapper.user .avatar{display:none}.message-content{flex:1 1;padding:1rem 1.25rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word}.message-wrapper.user .message-content{background:var(--primary-purple);color:#fff;border:none;max-width:70%;margin-left:auto}.typing-indicator{display:flex;gap:.25rem;padding:.25rem 0}.typing-indicator span{width:8px;height:8px;background:var(--primary-purple);border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3}30%{opacity:1}}.input-wrapper{border-top:1px solid var(--border-color);background:var(--bg-primary);padding:1rem 2rem 1.5rem}.input-form{max-width:800px;margin:0 auto}.input-container{display:flex;gap:.75rem;align-items:center;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:.75rem;padding:.25rem .25rem .25rem 1rem;transition:all .2s}.input-container:focus-within{border-color:var(--primary-purple);box-shadow:0 0 0 3px rgba(139,92,246,.1)}.message-input{flex:1 1;padding:.75rem 0;background:transparent;border:none;color:var(--text-primary);font-size:1rem;outline:none}.message-input::placeholder{color:var(--text-secondary)}.send-button{padding:.75rem;background:var(--primary-purple);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.send-button:hover:not(:disabled){background:var(--primary-dark)}.send-button:disabled{opacity:.5;cursor:not-allowed}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.input-footer{text-align:center;color:var(--text-secondary);font-size:.75rem;margin-top:.75rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;transition:color .2s}.modal-close:hover{color:var(--text-primary)}.user-email{color:var(--text-secondary);font-size:.875rem;margin-right:.5rem}.login-btn,.logout-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s}.login-btn:hover,.logout-btn:hover{background:var(--hover-bg);border-color:var(--primary-purple);color:var(--primary-purple)}.question-counter-display{margin:2rem 0;padding:1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;text-align:center}.question-counter-display strong{color:var(--primary-purple);font-weight:600}.limit-warning{color:#ef4444;font-size:.875rem;margin-top:.5rem}.question-limit-bar{padding:.75rem 0;border-top:1px solid var(--border-color)}.limit-progress{width:100%;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden;margin-bottom:.5rem}.limit-fill{height:100%;background:linear-gradient(90deg,var(--primary-purple) 0,var(--primary-light) 100%);transition:width .3s ease}.limit-text{font-size:.75rem;color:var(--text-secondary);display:block;text-align:center}.auth-modal{background:var(--bg-primary);border-radius:1rem;padding:2rem;max-width:400px;width:90%;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.auth-header{text-align:center;margin-bottom:2rem}.auth-header img{margin:0 auto 1rem}.auth-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.auth-subtitle{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin-top:.5rem}.auth-form{gap:1.5rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.auth-input{padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:1rem;transition:all .2s}.auth-input:focus{outline:none;border-color:var(--primary-purple);box-shadow:0 0 0 3px rgba(139,92,246,.1)}.auth-error{padding:.75rem;background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.875rem}.auth-submit{padding:.875rem;background:var(--premium-gradient);border:none;border-radius:.5rem;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.auth-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(139,92,246,.3)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.875rem}.auth-switch{background:none;border:none;color:var(--primary-purple);font-weight:500;cursor:pointer;text-decoration:underline}.auth-switch:hover{color:var(--primary-dark)}.verification-banner{position:fixed;top:60px;left:0;right:0;background:linear-gradient(90deg,var(--primary-purple) 0,var(--primary-light) 100%);color:#fff;padding:1rem;display:flex;justify-content:center;align-items:center;gap:1rem;z-index:100;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.verification-banner button{background:hsla(0,0%,100%,.2);border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.verification-banner button:hover{background:hsla(0,0%,100%,.3)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width:1024px){.pricing-sidebar{position:fixed;right:0;top:60px;height:calc(100vh - 60px);box-shadow:-4px 0 12px rgba(0,0,0,.1);z-index:50}}@media (max-width:768px){.header{padding:0 1rem}.pricing-sidebar{width:100%}.example-questions{grid-template-columns:1fr}.message-wrapper{padding:0 1rem}.input-wrapper{padding:1rem}.welcome-title{font-size:1.5rem}.welcome-subtitle{font-size:1rem}}@media screen and (max-width:768px){.pricing-sidebar{display:none!important}.main-container{flex-direction:column}.chat-container{width:100%!important;max-width:100%!important}.header-content{padding:0 1rem}.logo h1{font-size:1.25rem}.user-email{display:none}.new-chat-btn{padding:.5rem .75rem;font-size:.875rem}.welcome-screen{padding:1rem}.example-questions{display:flex;flex-direction:column;gap:.75rem}.example-question{width:100%;justify-content:flex-start}.messages{padding:1rem 1rem 160px}.message-content{font-size:.9375rem;max-width:85%}.input-wrapper{position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-top:1px solid var(--border-color);padding:1rem;z-index:100}.auth-input,.message-input{font-size:16px!important}.auth-modal{width:90%;margin:1rem}}@media screen and (min-width:769px) and (max-width:1024px){.pricing-sidebar{width:280px}}@media screen and (max-width:380px){.logo h1{display:none}.header-actions{gap:.25rem}.new-chat-btn span{display:none}}