*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#fff;color:#2c3e50;line-height:1.6}#root,.app-container{width:100%;height:100vh}.prio-bot{display:flex;flex-direction:column;width:100%;height:100vh;background-color:#fff}.prio-bot-header{background-color:#fff;padding:20px 60px;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;flex-shrink:0}.incit-logo{height:45px;width:auto;display:block}.prio-bot-header h2{display:none}.split-layout{display:flex;flex:1;height:calc(100vh - 85px);overflow:hidden}.left-panel{width:40%;background-color:#fff;border-right:1px solid #e2e8f0;overflow-y:auto;flex-shrink:0}.right-panel{width:60%;background-color:#f8fafc;overflow-y:auto;padding:24px 32px}.assessment-form{padding:24px 32px}.form-section{margin-bottom:32px}.form-section h3{font-size:1.25rem;font-weight:600;color:#2c3e50;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #3498db}.form-row{display:flex;gap:16px;margin-bottom:20px}.form-row .form-group{flex:1;margin-bottom:0}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#2c3e50;margin-bottom:6px}.form-group label small{display:block;font-weight:400;color:#7f8c8d;font-size:.85rem;margin-top:5px}.required{color:#e74c3c;margin-left:3px}.form-group input[type=text],.form-group input[type=url],.form-group input[type=number],.form-group input[type=file],.form-group select,.form-group textarea{width:100%;padding:8px 12px;font-size:.875rem;font-family:inherit;color:#2c3e50;background-color:#fff;border:1px solid #d1d5db;border-radius:4px;transition:all .2s}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group textarea{resize:vertical;min-height:80px;line-height:1.5}.form-group select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.checkbox-label input[type=checkbox]{margin-right:12px;cursor:pointer}.form-group input[type=file]{padding:10px;cursor:pointer}.file-list{margin-top:15px;padding:15px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px}.file-item{display:flex;align-items:center;padding:8px 0;color:#2c3e50;font-size:.9rem}.file-item:before{content:"📎";margin-right:10px;font-size:1.1rem}.submit-button{width:100%;padding:16px 24px;font-size:1rem;font-weight:600;color:#fff;background-color:#3498db;border:none;border-radius:8px;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;transition:all .3s;margin-top:20px}.submit-button:hover:not(:disabled){background-color:#2980b9;transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{background-color:#bdc3c7;cursor:not-allowed;transform:none}.reset-button{display:block;margin:30px auto;padding:14px 32px;font-size:1rem;font-weight:600;color:#fff;background-color:#6c757d;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.reset-button:hover{background-color:#5a6268;transform:translateY(-2px);box-shadow:0 4px 12px #6c757d4d}.error-message{padding:16px 20px;margin:20px 0;background-color:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#dc2626;font-weight:500}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#94a3b8;text-align:center;padding:40px}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state h3{font-size:1.5rem;color:#64748b;margin-bottom:10px}.empty-state p{font-size:1rem;color:#94a3b8;max-width:400px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px;color:#64748b}.loading-stages{width:100%;max-width:500px;display:flex;flex-direction:column;gap:24px}.loading-stage{display:flex;align-items:flex-start;gap:16px;padding:20px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;transition:all .3s ease;opacity:.4}.loading-stage.active{opacity:1;border-color:#3498db;background:#eff6ff;box-shadow:0 4px 12px #3498db26}.loading-stage.completed{opacity:1;border-color:#10b981}.stage-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.stage-icon-pending{width:40px;height:40px;border-radius:50%;background:#e2e8f0;color:#94a3b8;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem}.stage-text{flex:1;display:flex;flex-direction:column;gap:4px}.stage-text strong{font-size:1rem;font-weight:600;color:#1e293b}.stage-text small{font-size:.875rem;color:#64748b}.loading-stage.active .stage-text strong{color:#3498db}.spinner{width:50px;height:50px;border:4px solid #e2e8f0;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.spinner-small{width:40px;height:40px;border:3px solid #e2e8f0;border-top:3px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state p{font-size:1.1rem;font-weight:500}.product-results{width:100%}.product-results h3{font-size:1.2rem;font-weight:700;color:#1e40af;margin-bottom:12px}.dimension-description-section{margin-bottom:32px;padding:20px;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000000d}.dimension-description-label{display:block;font-size:.95rem;font-weight:600;color:#2c3e50;margin-bottom:12px}.dimension-description-textarea{width:100%;padding:12px;font-size:.875rem;font-family:inherit;color:#2c3e50;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;resize:vertical;min-height:120px;line-height:1.6;transition:all .2s}.dimension-description-textarea::placeholder{color:#9ca3af}.dimension-description-textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.project-section{margin-bottom:40px;padding-bottom:32px;border-bottom:2px solid #e2e8f0}.project-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.project-section h3{font-size:1.4rem;font-weight:700;color:#1e293b;margin-bottom:12px}.project-description{font-size:.875rem;color:#64748b;line-height:1.6;margin-bottom:24px;padding:12px;background-color:#f1f5f9;border-radius:6px;border-left:3px solid #3b82f6}.building-block-wrapper{margin-bottom:16px}.building-block-main-title{font-size:1.15rem;font-weight:700;color:#fff;background-color:#2563eb;padding:12px 16px;border-radius:8px;margin-bottom:0;transition:all .2s}.building-block-main-title.collapsible{cursor:pointer;display:flex;align-items:center;gap:10px;-webkit-user-select:none;user-select:none}.building-block-main-title.collapsible:hover{background-color:#1d4ed8}.collapse-icon{font-size:.9rem;transition:transform .2s}.building-block-wrapper:has(.building-block-main-title.collapsible){border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.building-block-wrapper:has(.building-block-main-title.collapsible) .building-block-main-title{margin:0;border-radius:0}.building-block-section{background-color:#f8fafc;border-radius:0;padding:16px;margin-bottom:0;border-bottom:1px solid #e2e8f0}.building-block-section:last-child{border-bottom:none}.building-block-title{font-size:.95rem;font-weight:600;color:#1e40af;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #dbeafe}.dimensions-list{display:flex;flex-direction:column;gap:8px}.dimension-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;transition:all .2s;cursor:pointer}.dimension-item.selected{background-color:#dbeafe;border-color:#3b82f6;cursor:pointer!important}.dimension-checkbox{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.empty-checkbox{width:16px;height:16px;border:2px solid #cbd5e1;border-radius:50%;background-color:#fff}.dimension-name{font-size:.9rem;color:#334155;font-weight:500}.dimension-item.selected .dimension-name{color:#1e40af;font-weight:600}.dimension-reason{font-size:.8rem;color:#64748b;margin-top:4px;font-style:italic;line-height:1.4}.clarification-section{margin-bottom:40px;padding:30px;background-color:#fff8e1;border-left:5px solid #ffa726;border-radius:12px}.clarification-section h4{font-size:1.4rem;font-weight:700;color:#e65100;margin-bottom:20px}.clarification-card{background-color:#fff;padding:20px;border-radius:8px;margin-top:20px;box-shadow:0 1px 3px #0000001a}.clarification-card h5{font-size:1.1rem;font-weight:600;color:#e65100;margin-bottom:12px}.clarification-card p{color:#4a5568;line-height:1.6;margin-bottom:12px}.follow-up-questions{margin-top:15px}.follow-up-questions strong{display:block;font-weight:600;color:#2c3e50;margin-bottom:10px}.follow-up-questions ul{margin:0;padding-left:24px}.follow-up-questions li{color:#4a5568;line-height:1.6;margin-bottom:8px}.left-panel::-webkit-scrollbar,.right-panel::-webkit-scrollbar{width:8px}.left-panel::-webkit-scrollbar-track,.right-panel::-webkit-scrollbar-track{background:#f1f5f9}.left-panel::-webkit-scrollbar-thumb,.right-panel::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.left-panel::-webkit-scrollbar-thumb:hover,.right-panel::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width: 1024px){.split-layout{flex-direction:column}.left-panel,.right-panel{width:100%;height:auto}.left-panel{border-right:none;border-bottom:1px solid #e2e8f0}.right-panel{min-height:400px}}@media (max-width: 768px){.chat-header{padding:15px 20px}.incit-logo{height:35px}.assessment-form,.right-panel{padding:20px}.form-section h3,.assessment-results h3{font-size:1.3rem}.framework-title{font-size:1rem}.dimension-box{font-size:.85rem}}.confidence-banner{margin-bottom:20px;padding:14px 18px;border-radius:6px;border-left:4px solid;background-color:#fff;border:1px solid}.confidence-banner.confidence-low{border-left-color:#dc3545;border-color:#f8d7da;background-color:#fff5f5}.confidence-banner.confidence-medium{border-left-color:#ff9800;border-color:#fff3cd;background-color:#fffbf0}.confidence-header{font-size:.95rem;margin-bottom:6px;color:#1a202c;display:flex;align-items:center;gap:6px}.confidence-message{margin:0;font-size:.875rem;color:#4a5568;line-height:1.5}.missing-information-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000000f}.missing-info-title{font-size:1.1rem;font-weight:600;margin-bottom:6px;color:#1a202c;display:flex;align-items:center;gap:8px}.missing-info-subtitle{font-size:.875rem;margin-bottom:20px;color:#4a5568;line-height:1.5}.follow-up-questions{display:flex;flex-direction:column;gap:14px;margin-bottom:20px}.follow-up-question{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:16px;display:flex;gap:14px;transition:all .2s ease}.follow-up-question:hover{background:#f1f5f9;border-color:#cbd5e1;box-shadow:0 1px 3px #00000014}.question-number{background:#3b82f6;color:#fff;font-weight:600;font-size:.875rem;min-width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.question-content{flex:1}.question-text{font-size:.9375rem;font-weight:500;margin-bottom:10px;line-height:1.5;color:#1a202c}.question-reason{font-size:.875rem;margin-bottom:8px;line-height:1.5;color:#4a5568;padding-left:12px;border-left:3px solid #e2e8f0}.question-reason strong{font-weight:600;color:#2d3748}.related-dimension{font-size:.8125rem;margin-top:8px;padding:4px 10px;background:#eff6ff;border-radius:4px;display:inline-block;color:#1e40af}.related-dimension strong{font-weight:600}.missing-info-actions{display:flex;justify-content:flex-end;padding-top:4px}.copy-questions-btn{background:#3b82f6;color:#fff;border:none;padding:10px 18px;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.copy-questions-btn:hover{background:#2563eb;box-shadow:0 2px 4px #3b82f633}.copy-questions-btn:active{background:#1d4ed8;transform:translateY(1px)}.dimension-description-display{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 1px 3px #0000000d}.dimension-description-title{font-size:16px;font-weight:600;color:#1f2937;margin:0 0 12px}.dimension-description-content{font-size:14px;line-height:1.6;color:#4b5563;white-space:pre-wrap}.chat{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;display:flex;justify-content:center;align-items:center;min-height:100vh;padding:10px;box-sizing:border-box}.app-container{width:100%;max-width:700px;margin:20px auto}.chat-window{background-color:#fff;border-radius:12px;box-shadow:0 6px 18px #0000001a;overflow:hidden;display:flex;flex-direction:column;height:calc(100vh - 40px);max-height:750px;position:relative}.chat-header{background-color:#fff;color:#fff;padding:15px 20px;display:flex;align-items:center;border-bottom:1px solid #caccce}.incit-logo{height:40px;width:auto;margin-right:15px}.chat-header h2{margin:0;font-size:1.25rem;font-weight:600}.message-list{flex-grow:1;padding:20px 25px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;background-color:#f9f9f9;scrollbar-width:thin;scrollbar-color:#0056b3 #e0e0e0}.message-list::-webkit-scrollbar{width:8px}.message-list::-webkit-scrollbar-track{background:#e0e0e0;border-radius:10px}.message-list::-webkit-scrollbar-thumb{background-color:#0056b3;border-radius:10px;border:2px solid #e0e0e0}.message{padding:10px 15px;border-radius:18px;max-width:75%;word-wrap:break-word;line-height:1.5;box-shadow:0 2px 4px #00000012;display:flex;flex-direction:column}.message-text{margin-bottom:5px}.message-text:not(:empty)+.message-image{margin-top:5px}.message-text:empty+.message-image{margin-top:0}.message-text:empty{display:none}.message-image{max-width:100%;width:100%;height:auto;max-height:250px;object-fit:contain;border-radius:10px;border:1px solid #eee;align-self:center}.message-text img{max-width:100%;height:unset!important;border-radius:10px;margin-top:5px;object-fit:contain\;}.message.user{background-color:#007bff;color:#fff;align-self:flex-end;border-bottom-right-radius:6px}.message.user .message-text{color:#fff}.message.bot{padding-top:16px;background-color:#e9ecef;color:#212529;align-self:flex-start;border-bottom-left-radius:6px}.message.bot .message-text{color:#212529}.message-text *{margin-top:0}.contact-wrapper{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px}.contact-card{background-color:#fff;padding:30px;border-radius:16px;box-shadow:0 8px 20px #00000014;width:100%;max-width:480px}.contact-card h2{text-align:center;margin-bottom:24px;color:#222}.contact-form{display:flex;flex-direction:column;gap:0px}.contact-form label{font-size:14px;color:#444}.contact-form input,.contact-form select,.contact-form textarea{padding:12px 16px;font-size:14px;border:1px solid #ccc;border-radius:8px;background-color:#fff;color:#333}.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:#5b8dfc;box-shadow:0 0 0 2px #5b8dfc26}.contact-form button{padding:14px;font-size:16px;background-color:#5b8dfc;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease}.contact-form button:hover{background-color:#3e6de0}.contact-item{display:flex;flex-direction:column;width:100%;align-items:stretch;gap:4px;margin-bottom:16px}.wa-typing{display:inline-block;vertical-align:middle;height:8px;padding:0 4px}.wa-dot{display:inline-block;width:4px;height:4px;margin:0 2px;background:#000;border-radius:50%;opacity:.85;box-shadow:0 1px 2px #0000001f;animation:wa-bounce 1.2s linear infinite both}.wa-dot:nth-child(2){animation-delay:.2s}.wa-dot:nth-child(3){animation-delay:.4s}@keyframes wa-bounce{0%,80%,to{transform:scale(.7);opacity:.7}40%{transform:scale(1.2);opacity:1}}.related-questions-container{padding:5px;background-color:#f9f9f9}.related-question-badge{display:inline-block;padding:.2em 1em;font-size:.8em;color:#000;background-color:#fff;border:1px solid #007bff;border-radius:20px;margin:2px;-webkit-border-radius:20px;-moz-border-radius:20px;-ms-border-radius:20px;-o-border-radius:20px}.message-input-form{display:flex;flex-direction:column;padding:10px 15px;border-top:1px solid #dee2e6;background-color:#f8f9fa}.image-preview-container{position:relative;display:inline-block;margin-bottom:10px;max-width:150px}.image-preview{max-width:100%;max-height:100px;border-radius:8px;border:1px solid #ddd}.remove-image-btn{position:absolute;top:-5px;right:-5px;background-color:#0009;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:14px;line-height:18px;text-align:center;cursor:pointer;padding:0}.input-controls{display:flex;align-items:center;width:100%}.input-controls input[type=text]{flex-grow:1;padding:12px 18px;border:1px solid #ced4da;border-radius:25px;color:#495057;background-color:#fff;margin-left:10px;margin-right:10px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.input-controls input[type=text]:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .25rem #007bff40}.attach-btn,.send-btn{padding:10px;background-color:#007bff;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:1.2rem;font-weight:700;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;width:44px;height:44px}.send-btn{border-radius:25px;padding:12px 22px;font-size:1rem;font-weight:500;width:auto}.attach-btn:hover,.send-btn:hover{background-color:#0056b3}.send-btn:disabled{background-color:#6c757d;cursor:not-allowed}
