*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#333;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.app{min-height:100vh;max-height:100vh;display:flex;flex-direction:column;background:#0f172a;overflow:hidden}.app-header{background:#1e293b;padding:1.5rem 2rem;box-shadow:0 4px 6px -1px #0000004d;border-bottom:1px solid #334155}.app-header h1{margin:0 0 1rem;font-size:1.75rem;color:#f8fafc;font-weight:700}.tab-navigation{display:flex;gap:.5rem}.tab-button{padding:.625rem 1.25rem;border:none;background:transparent;color:#94a3b8;font-size:1.2rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease}.tab-button:hover{color:#f8fafc;background:#334155}.tab-button.active{color:#fff;background:#3b82f6}.app-main{flex:1;padding:2rem;overflow-y:auto;max-height:calc(100vh - 120px)}.section{max-width:1400px;margin:0 auto;height:100%}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;color:#f8fafc}.section-header h2{margin:0;color:#f8fafc;font-size:1.5rem;font-weight:700}.btn-primary,.btn-secondary{padding:.625rem 1.25rem;border:none;border-radius:6px;font-size:1.2rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:#3b82f6;color:#fff;box-shadow:0 1px 2px #0000000d}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 4px #0000001a}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.btn-secondary{background:#fff;color:#475569;border:1px solid #cbd5e1}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-outline{background:transparent;color:#3b82f6;border:1px solid #3b82f6}.btn-outline:hover:not(:disabled){background:#3b82f6;color:#fff}.btn-outline:disabled{opacity:.5;cursor:not-allowed}.btn-small{padding:.5rem 1rem;font-size:.9375rem;font-weight:600}.btn-close{background:transparent;border:none;color:#94a3b8;font-size:1.5rem;cursor:pointer;padding:.5rem;line-height:1;transition:color .2s ease}.btn-close:hover{color:#f8fafc}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.survey-card{background:#1e293b;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px -1px #0000004d,0 2px 4px -1px #0003;border:1px solid #334155}.survey-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px -5px #00000080,0 6px 15px -2px #0000004d;border-color:#3b82f6}.survey-card h3{margin:0;color:#f8fafc;font-size:1rem;font-weight:500;line-height:1.6}.survey-date{color:#94a3b8;font-size:.875rem;margin:0 0 1rem}.survey-themes-preview{margin-bottom:1rem}.theme-badge{display:inline-block;background:#dbeafe;color:#1e40af;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:500}.survey-goal{color:#f8fafc;font-size:1rem;font-weight:500;margin:0;line-height:1.6;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.field-label{display:inline-block;font-size:1rem;font-weight:500;color:#94a3b8;text-transform:capitalize;letter-spacing:0;min-width:120px;flex-shrink:0;line-height:1.6}.survey-field{margin-bottom:1rem;display:flex;align-items:center;gap:1rem}.survey-field:last-child{margin-bottom:0}.survey-field h3,.survey-field p{font-size:1rem;font-weight:500;color:#f8fafc;margin:0;line-height:1.6}.chat-field{margin-bottom:.75rem;display:flex;align-items:center;gap:1rem}.chat-field:last-child{margin-bottom:0}.chat-field h1,.chat-field h2,.chat-field p{font-size:1rem;font-weight:500;color:#f8fafc;margin:0;line-height:1.6}.thread-card{background:#1e293b;border-radius:8px;padding:1.25rem;cursor:pointer;transition:all .3s ease;border:1px solid #334155;box-shadow:0 2px 4px #0003}.thread-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px -5px #0006,0 4px 10px -2px #0000004d;border-color:#3b82f6}.thread-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.thread-id{font-weight:600;color:#60a5fa;font-size:.875rem}.thread-date{color:#64748b;font-size:.75rem}.thread-responses{margin-bottom:.5rem}.response-count{display:inline-block;background:#dbeafe;color:#1e40af;padding:.25rem .5rem;border-radius:10px;font-size:.75rem;font-weight:500}.thread-preview{color:#cbd5e1;font-size:.875rem;margin:0;line-height:1.5}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:16px;padding:2.5rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;border:1px solid #e2e8f0}.modal-content h2{margin:0 0 1.5rem;color:#0f172a;font-size:1.5rem;font-weight:600}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#475569;font-weight:500;font-size:.875rem}.form-group input,.form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.9375rem;font-family:inherit;transition:all .2s ease;color:#0f172a}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:100px}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.chat-container{background:#1e293b;border-radius:12px;height:calc(100vh - 14px);max-height:calc(100vh - 14rem);display:flex;flex-direction:column;box-shadow:0 10px 40px -5px #00000080;border:1px solid #334155;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 2rem;border-bottom:1px solid #334155;background:#1e293b;flex-shrink:0}.chat-goal{color:#f8fafc;font-size:1rem;font-weight:500;margin:0;line-height:1.6}.chat-body{flex:1;display:flex;overflow:hidden}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.message{max-width:75%;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-human{align-self:flex-end}.message-ai{align-self:flex-start}.message-system{align-self:center;max-width:90%}.message-content{padding:.875rem 1rem;border-radius:10px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;font-size:.9375rem}.message-human .message-content{background:#3b82f6;color:#fff;border-bottom-right-radius:3px}.message-ai .message-content{background:#f1f5f9;color:#0f172a;border:1px solid #e2e8f0;border-bottom-left-radius:3px}.message-system .message-content{background:#fef3c7;color:#92400e;text-align:center;font-size:.875rem;border:1px solid #fde68a}.typing-indicator{display:flex;gap:.375rem;padding:.5rem 1rem}.typing-indicator span{width:7px;height:7px;border-radius:50%;background:#9ca3af;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{transform:translateY(0);opacity:.6}30%{transform:translateY(-8px);opacity:1}}.message-input-form{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #334155;background:#1e293b;flex-shrink:0}.message-input-form input{flex:1;padding:.625rem 1rem;border:1px solid #475569;border-radius:6px;font-size:.9375rem;font-family:inherit;transition:all .2s ease;color:#f8fafc;background:#334155}.message-input-form input::placeholder{color:#94a3b8}.message-input-form input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.message-input-form button{padding:.625rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease}.message-input-form button:hover:not(:disabled){background:#2563eb}.message-input-form button:disabled{opacity:.5;cursor:not-allowed;background:#93c5fd}.chat-sidebar{width:600px;border-left:1px solid #334155;padding:1.25rem;overflow-y:auto;background:#0f172a;flex-shrink:0}.chat-sidebar h3{margin:0 0 1rem;color:#f8fafc;font-size:1.125rem;font-weight:600}.themes-list,.theme-responses-list{display:flex;flex-direction:column;gap:.625rem}.theme-item{background:#1e293b;padding:.75rem .875rem;border-radius:6px;font-size:.9375rem;color:#e2e8f0;box-shadow:0 2px 4px #0003;border:1px solid #334155;border-left:3px solid #3b82f6}.theme-response-item{background:#1e293b;padding:.875rem;border-radius:6px;box-shadow:0 2px 4px #0003;border:1px solid #334155}.theme-response-theme{font-weight:600;color:#60a5fa;font-size:.9375rem;margin-bottom:.5rem}.theme-response-text{color:#cbd5e1;font-size:.9375rem;line-height:1.5}.no-themes{color:#9ca3af;font-size:.875rem;font-style:italic;text-align:center;padding:2rem 1rem}.additional-thoughts-container{margin-top:.75rem}.additional-thoughts-text{background:#1e293b;padding:1rem;border-radius:6px;font-size:.9375rem;color:#e2e8f0;line-height:1.6;box-shadow:0 2px 4px #0003;border:1px solid #334155;border-left:3px solid #10b981}.participation-list{display:flex;flex-direction:column;gap:1rem}.participation-survey{background:#1e293b;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px #0000004d;border:1px solid #334155}.participation-survey-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;cursor:pointer;transition:background .2s ease}.participation-survey-header:hover{background:#334155}.participation-survey-header h3{margin:0;color:#f8fafc;font-size:1rem;font-weight:500;line-height:1.6}.survey-theme-count{color:#64748b;font-size:.93rem;margin:.25rem 0 0}.participation-survey-actions{display:flex;align-items:center;gap:1rem}.expand-icon{color:#3b82f6;font-size:1.125rem;transition:transform .2s ease}.threads-container{padding:1.5rem 2rem;background:#0f172a;border-top:1px solid #334155}.threads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.loading,.empty-state{text-align:center;padding:3rem;color:#94a3b8;font-size:1rem}.empty-state-small{text-align:center;padding:2rem;color:#94a3b8;font-size:.875rem}.loading-overlay{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000}.loading-spinner{background:#fff;border-radius:12px;padding:2rem 3rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.loading-spinner p{margin:0;color:#0f172a;font-size:1rem;font-weight:500}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.app-header{padding:1rem}.app-header h1{font-size:1.5rem}.app-main{padding:1rem}.cards-grid{grid-template-columns:1fr}.chat-container{height:calc(100vh - 6rem)}.chat-body{flex-direction:column}.chat-sidebar{width:100%;border-left:none;border-top:1px solid #e2e8f0;max-height:300px}.message{max-width:90%}.threads-grid{grid-template-columns:1fr}}
