*{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}.App{width:100%;min-height:100vh;background:#f5f7fa}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.top-banner{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;background:linear-gradient(90deg,#2c3e50,#3498db);box-shadow:0 2px 8px #00000026;margin:0;color:#fff;flex-shrink:0;position:fixed;top:0;left:80px;right:0;z-index:90;height:90px}.banner-left{display:flex;align-items:center;gap:20px}.banner-assistant-image{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.3);box-shadow:0 2px 10px #0000004d}.banner-text{display:flex;flex-direction:column}.banner-title{margin:0;font-size:28px;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.banner-description{margin:5px 0 0;font-size:14px;opacity:.9}.banner-right{display:flex;align-items:center;gap:20px}.banner-info{display:flex;flex-direction:column;gap:4px;font-size:13px;text-align:right}.banner-user,.banner-model{white-space:nowrap;opacity:.95;font-weight:500}.banner-system-name{font-size:24px;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.logout-button{padding:10px 20px;background:#e74c3ce6;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0003}.logout-button:hover{background:#c0392b;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}@media (max-width: 768px){.top-banner{flex-direction:column;text-align:center;gap:15px}.banner-left{flex-direction:column}.banner-right{flex-direction:column;gap:10px}.banner-title{font-size:22px}.banner-system-name{font-size:18px}}.side-panel{width:80px;height:100vh;background:#2c3e50;display:flex;flex-direction:column;align-items:center;padding:20px 0;box-shadow:2px 0 10px #0000001a;position:fixed;top:0;left:0;z-index:100;overflow-y:auto}.side-panel-button{position:relative;width:60px;height:60px;margin:8px 0;background:#ffffff1a;border:none;border-radius:12px;color:#fff;font-size:28px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.side-panel-button:hover{background:#fff3;transform:translate(5px)}.side-panel-button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea66}.button-icon{display:block}.button-tooltip{position:absolute;left:75px;background:#000000e6;color:#fff;padding:8px 12px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s ease;font-size:14px;z-index:1000}.side-panel-button:hover .button-tooltip{opacity:1}.side-panel-separator{width:50px;height:2px;background:#fff3;margin:10px 0}@media (max-width: 768px){.side-panel{width:100%;min-height:auto;flex-direction:row;justify-content:space-around;padding:10px 0;position:static}.side-panel-button{width:50px;height:50px;margin:0 5px}.button-tooltip{display:none}.side-panel-separator{width:2px;height:30px;margin:0 5px}}.directive-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.directive-modal{background:#fff;padding:25px;border-radius:12px;box-shadow:0 10px 40px #0000004d;min-width:400px;max-width:500px}.directive-modal h3{margin-top:0;margin-bottom:15px;color:#2c3e50}.settings-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000004d;width:90%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s ease-out}.settings-body{flex:1;overflow-y:auto;overflow-x:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:2px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.settings-header h2{margin:0;font-size:24px;font-weight:600}.close-button{background:#fff3;border:none;color:#fff;font-size:24px;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-button:hover{background:#ffffff4d;transform:rotate(90deg)}.settings-tabs{display:flex;background:#f8f9fa;border-bottom:2px solid #e0e0e0;padding:0 16px;overflow-x:auto;overflow-y:hidden;gap:4px;scrollbar-width:thin;position:sticky;top:0;z-index:10}.settings-tabs::-webkit-scrollbar{height:4px}.settings-tabs::-webkit-scrollbar-thumb{background:#667eea;border-radius:2px}.tab-button{background:none;border:none;padding:16px 20px;font-size:14px;font-weight:500;color:#666;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s ease;display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0}.tab-button:hover{color:#667eea;background:#667eea0d}.tab-button.active{color:#667eea;border-bottom-color:#667eea;background:#fff}.settings-content{flex:1;padding:32px}.settings-section{animation:fadeIn .3s ease-out}.settings-section h3{margin:0 0 8px;font-size:20px;font-weight:600;color:#333}.section-description{color:#666;margin:0 0 24px;font-size:14px}.setting-item{margin-bottom:28px;display:flex;flex-direction:column;gap:8px}.setting-item label{font-weight:500;color:#333;font-size:15px;display:flex;align-items:center;gap:8px}.setting-item select,.setting-item input[type=range]{padding:10px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:all .2s ease;background:#fff}.setting-item select:focus,.setting-item input[type=range]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.setting-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.setting-item input[type=range]{width:100%;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e0e0e0;outline:none;border-radius:4px}.setting-item input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;border-radius:50%;box-shadow:0 2px 4px #0003}.setting-item input[type=range]::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;border-radius:50%;border:none;box-shadow:0 2px 4px #0003}.setting-item small{color:#888;font-size:13px;margin-top:4px}.save-button,.refresh-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #0000001a;margin-top:16px}.button-group{display:flex;gap:12px;margin-top:16px}.button-group .save-button,.button-group .reset-button-secondary{flex:1;margin-top:0}.reset-button-secondary{background:#f8f9fa;border:2px solid #e0e0e0;color:#666;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.reset-button-secondary:hover{background:#e9ecef;border-color:#667eea;color:#667eea}.settings-info-box{margin-top:20px;padding:12px 16px;background:#f0f7ff;border-left:4px solid #667eea;border-radius:4px}.settings-info-box small{color:#555;font-size:13px;line-height:1.5}.settings-info-box strong{color:#667eea}.save-button:hover,.refresh-button:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.save-button:active,.refresh-button:active{transform:translateY(0)}.refresh-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.session-actions-row{display:flex;gap:12px;margin-top:16px}.session-actions-row .refresh-button{flex:1}.delete-all-button{flex:1;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #e74c3c33}.delete-all-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #e74c3c4d}.delete-all-button:active{transform:translateY(0)}.delete-all-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.sessions-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;max-height:400px;overflow-y:auto;padding-right:8px}.sessions-list::-webkit-scrollbar{width:8px}.sessions-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.sessions-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.sessions-list::-webkit-scrollbar-thumb:hover{background:#555}.session-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:12px;transition:all .2s ease;cursor:pointer}.session-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea26}.session-item.current{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea}.session-info{flex:1;display:flex;flex-direction:column;gap:8px}.session-title{display:flex;align-items:center;gap:12px;font-size:15px}.session-title strong{color:#333}[data-theme=dark] .session-item{background:#2a2a3e;border-color:#3a3a4e}[data-theme=dark] .session-item:hover{border-color:#667eea;background:#323244}[data-theme=dark] .session-item.current{background:linear-gradient(135deg,#667eea33,#764ba233);border-color:#667eea}[data-theme=dark] .session-title strong{color:#f0f0f0}[data-theme=dark] .session-meta,[data-theme=dark] .session-meta span{color:#d0d0d0}[data-theme=dark] .session-subtitle{color:#e0e0e0}[data-theme=dark] .settings-info-box{background:#2a2a3e;border-color:#667eea}[data-theme=dark] .settings-info-box small{color:silver}.current-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.session-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:#666}.session-subtitle{font-size:13px;color:#888;font-style:italic}.session-actions{display:flex;gap:8px;align-items:center}.rename-session-button,.delete-session-button{background:#e74c3c1a;border:2px solid rgba(231,76,60,.3);color:#e74c3c;font-size:18px;width:40px;height:40px;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.rename-session-button{background:#667eea1a;border-color:#667eea4d;color:#667eea}.rename-session-button:hover{background:#667eea33;border-color:#667eea;transform:scale(1.1)}.delete-session-button:hover:not(:disabled){background:#e74c3c33;border-color:#e74c3c;transform:scale(1.1)}.delete-session-button:disabled{opacity:.4;cursor:not-allowed}.loading,.empty-state{text-align:center;padding:40px;color:#888;font-size:15px}@media (max-width: 768px){.settings-modal{width:95%;max-height:90vh}.settings-header,.settings-tabs,.settings-content{padding-left:16px;padding-right:16px}.tab-button{padding:12px 16px;font-size:14px}.session-meta{flex-direction:column;gap:4px}}.home-container{display:flex;flex-direction:column;min-height:100vh;background:#f5f7fa}.home-main-content{display:flex;flex:1;margin-top:0}.assistant-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:40px;max-width:1200px;width:100%}.card-image-container{height:70%;display:flex;align-items:center;justify-content:center;background:#fff;overflow:hidden;border-bottom:3px solid rgba(0,0,0,.1);padding:10px}.mra-card .card-content{background:linear-gradient(135deg,#4facfe,#00f2fe)}.mpga-card .card-content{background:linear-gradient(135deg,#fa709a,#fee140)}.settings-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.settings-modal{background:#fff;padding:30px;border-radius:10px;box-shadow:0 10px 40px #0000004d;max-width:500px;width:90%}.settings-modal h2{margin:0 0 20px;color:#2c3e50}.settings-modal button{background:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:16px;margin-top:20px}.settings-modal button:hover{background:#2980b9}@media (max-width: 1024px){.assistant-cards-grid{grid-template-columns:1fr;max-width:600px}.assistant-card{height:450px}}@media (max-width: 768px){.home-main-content{flex-direction:column}.assistant-selector-area{padding:20px}.selector-title{font-size:24px;margin-bottom:30px}.assistant-cards-grid{gap:20px}.assistant-card{height:400px}.card-image-container,.card-content{padding:20px}.card-title{font-size:22px}.card-description{font-size:14px}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h1{text-align:center;color:#667eea;margin-bottom:10px;font-size:2em}.login-box h2{text-align:center;color:#333;margin-bottom:30px;font-size:1.5em;font-weight:400}.error-message{background:#fee;color:#c33;padding:12px;border-radius:5px;margin-bottom:20px;border:1px solid #fcc}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500}.form-group input{width:100%;padding:12px;border:2px solid #ddd;border-radius:5px;font-size:1em;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.login-box .submit-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff!important;border:none;border-radius:5px;font-size:1.1em;font-weight:700;cursor:pointer;transition:transform .2s}.login-box .submit-button:hover:not(:disabled){transform:translateY(-2px)}.login-box .submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.toggle-mode{margin-top:20px;text-align:center;color:#666}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-weight:700;text-decoration:underline}.link-button:hover{color:#764ba2}.demo-tasks-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.demo-tasks-modal{background:#fff;border-radius:12px;width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}.demo-tasks-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:2px solid #e0e0e0}.demo-tasks-header h3{margin:0;font-size:20px;color:#2c3e50}.close-button{background:none;border:none;font-size:24px;color:#95a5a6;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover{background:#f0f0f0;color:#e74c3c}.demo-tasks-controls{padding:16px 24px;border-bottom:1px solid #e0e0e0}.demo-tasks-search{width:100%;padding:10px 14px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;margin-bottom:12px;transition:border-color .2s}.demo-tasks-search:focus{outline:none;border-color:#667eea}.demo-tasks-categories{display:flex;gap:8px;flex-wrap:wrap}.category-button{padding:6px 12px;border:1px solid #ddd;border-radius:20px;background:#fff;color:#666;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.category-button:hover{background:#f8f9fa;border-color:#667eea}.category-button.active{background:#667eea;color:#fff;border-color:#667eea}.demo-tasks-list{flex:1;overflow-y:auto;padding:16px 24px}.no-tasks{text-align:center;color:#95a5a6;padding:40px 20px;font-size:15px}.demo-task-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;margin-bottom:8px;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;gap:16px}.demo-task-item:hover{border-color:#667eea;background:#f8f9ff;transform:translate(4px)}.task-text{flex:1;font-size:14px;color:#2c3e50;line-height:1.5}.select-button{padding:6px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:13px;cursor:pointer;white-space:nowrap;opacity:0;transition:opacity .2s}.demo-task-item:hover .select-button{opacity:1}.select-button:hover{background:#5568d3}.demo-tasks-footer{padding:12px 24px;border-top:1px solid #e0e0e0;background:#f8f9fa;border-radius:0 0 12px 12px}.demo-tasks-footer p{margin:0;font-size:13px;color:#666;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.demo-tasks-list::-webkit-scrollbar{width:8px}.demo-tasks-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.demo-tasks-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.demo-tasks-list::-webkit-scrollbar-thumb:hover{background:#999}.mra-chat-container{display:flex;flex-direction:column;height:100vh;width:100vw;margin:0;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:90px 0 0 80px}.mra-main-content{display:flex;gap:20px;flex:1;overflow:hidden;height:calc(100vh - 90px)}.sr-form-chat-page{display:flex;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;margin-left:80px}.sr-form-container{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:110px 20px 20px;gap:20px}.form-and-chat-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:20px;height:100%;overflow:hidden}.form-section{background:#fff;border-radius:12px;padding:25px;box-shadow:0 4px 6px #0000001a;overflow-y:auto;display:flex;flex-direction:column}.section-header{margin-bottom:20px;border-bottom:2px solid #667eea;padding-bottom:15px}.section-header h2{font-size:18px;color:#666;margin:0 0 8px;display:flex;align-items:center;gap:10px}.section-header h3{font-size:24px;color:#333;margin:0}.required-badge{background:#e74c3c;color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase}.section-progress{display:flex;justify-content:center;gap:10px;margin-bottom:25px;padding:15px 0}.progress-dot{width:12px;height:12px;border-radius:50%;background:#ddd;transition:all .3s ease;cursor:help}.progress-dot.active{width:16px;height:16px;background:#667eea;box-shadow:0 0 0 4px #667eea33}.progress-dot.completed{background:#27ae60}.form-fields{flex:1;overflow-y:auto;margin-bottom:20px}.form-field{margin-bottom:20px}.form-field label{display:block;font-weight:600;color:#333;margin-bottom:8px;font-size:14px}.required-star{color:#e74c3c;margin-left:4px}.form-field input,.form-field textarea,.form-field select{width:100%;padding:10px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-field textarea{resize:vertical;min-height:80px}.form-field input[type=date],.form-field input[type=number]{max-width:250px}.form-navigation{display:flex;gap:10px;margin-bottom:15px}.nav-button{flex:1;padding:10px 20px;border:2px solid #667eea;background:#fff;color:#667eea;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.nav-button:hover:not(:disabled){background:#667eea;color:#fff}.nav-button:disabled{opacity:.4;cursor:not-allowed;border-color:#ccc;color:#999}.submit-section-button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #667eea4d}.submit-section-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.submit-section-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;overflow:hidden}.chat-header{display:flex;justify-content:flex-end;padding:0 0 10px;border-bottom:1px solid #e0e0e0;margin-bottom:10px}.messages-container{flex:1;overflow-y:auto;padding:10px;margin-bottom:15px}.empty-chat{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#666;padding:40px 20px}.empty-chat-image{width:120px;height:120px;margin-bottom:20px;border-radius:50%;border:3px solid #667eea}.empty-chat h2{font-size:24px;color:#333;margin:0 0 10px}.empty-chat p{font-size:16px;color:#666;margin:8px 0}.help-text{font-size:14px!important;color:#999!important;font-style:italic}.chat-message{display:flex;gap:12px;margin-bottom:20px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.message-bubble{max-width:75%;padding:12px 16px;border-radius:12px;background:#f5f5f5;word-wrap:break-word}.user-message .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.typing-indicator{display:flex;gap:4px;padding:8px 0}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#667eea;animation:bounce 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-input-area{border-top:2px solid #f0f0f0;padding-top:15px}.input-label{font-size:13px;color:#666;margin:0 0 8px;font-style:italic}.input-wrapper{display:flex;gap:10px;align-items:flex-end}.input-wrapper textarea{flex:1;padding:10px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;resize:none;transition:border-color .2s}.input-wrapper textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.input-wrapper textarea:disabled{background:#f5f5f5;cursor:not-allowed}.send-button-inline{padding:10px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:18px;cursor:pointer;transition:transform .2s;flex-shrink:0}.send-button-inline:hover:not(:disabled){transform:scale(1.05)}.error-banner{background:#fee;color:#c33;padding:12px 16px;border-radius:8px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center;border-left:4px solid #e74c3c}.error-banner button{background:none;border:none;color:#c33;font-size:18px;cursor:pointer;padding:0 8px}.message-bubble h1,.message-bubble h2,.message-bubble h3{margin-top:16px;margin-bottom:8px}.message-bubble p{margin:8px 0;line-height:1.6}.message-bubble ul,.message-bubble ol{margin:8px 0;padding-left:24px}.message-bubble li{margin:4px 0}.message-bubble code{background:#0000001a;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:13px}.user-message .message-bubble code{background:#fff3}.message-bubble pre{margin:12px 0;border-radius:8px;overflow:hidden}.message-bubble table{border-collapse:collapse;width:100%;margin:12px 0}.message-bubble th,.message-bubble td{border:1px solid #ddd;padding:8px 12px;text-align:left}.message-bubble th{background:#f5f5f5;font-weight:600}.user-message .message-bubble th{background:#fff3}@media (max-width: 1200px){.form-and-chat-wrapper{grid-template-columns:1fr;grid-template-rows:auto 1fr}.form-section{max-height:500px}}@media (max-width: 768px){.sr-form-container{padding:10px}.form-section,.chat-section{padding:15px}.section-header h3{font-size:20px}.message-bubble{max-width:85%}}.dynamic-hazards-section{display:flex;flex-direction:column;gap:20px}.hazard-entry{border:2px solid #e0e0e0;border-radius:8px;padding:20px;background:#f9f9f9;position:relative}.hazard-entry:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.hazard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #ddd}.hazard-header h4{margin:0;color:#667eea;font-size:16px;font-weight:600}.remove-hazard-btn{padding:6px 12px;background:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s}.remove-hazard-btn:hover{background:#c0392b}.add-hazard-btn{width:100%;padding:12px 20px;background:#fff;color:#667eea;border:2px dashed #667eea;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.add-hazard-btn:hover{background:#667eea;color:#fff;border-style:solid}.mpga-container{display:flex;flex-direction:column;min-height:100vh;background:#f5f7fa}.mpga-main-content{display:flex;flex:1;margin-top:0}.assistant-selector-area{flex:1;padding:40px;display:flex;flex-direction:column;align-items:center}.selector-title{font-size:32px;color:#2c3e50;margin-bottom:40px;text-align:center}.assistant-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:40px;max-width:1400px;width:100%}.assistant-card{position:relative;background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 10px 30px #00000026;transition:all .3s ease;cursor:pointer;height:500px;display:flex;flex-direction:column}.assistant-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 15px 40px #00000040}.card-image-container{height:70%;display:flex;align-items:center;justify-content:center;background:#fff;overflow:hidden;border-bottom:3px solid rgba(0,0,0,.1);padding:20px}.card-assistant-image{width:100%;height:100%;object-fit:contain;object-position:center}.card-content{height:30%;padding:25px 30px;text-align:center;display:flex;flex-direction:column;justify-content:center}.scope-gradient{background:linear-gradient(135deg,#667eea,#764ba2)}.jha-gradient{background:linear-gradient(135deg,#f093fb,#f5576c)}.operations-gradient{background:linear-gradient(135deg,#4facfe,#00f2fe)}.card-title{font-size:24px;font-weight:700;color:#fff;margin:0 0 10px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.card-description{font-size:15px;color:#fffffff2;line-height:1.5;margin:0;text-shadow:1px 1px 2px rgba(0,0,0,.2)}[data-theme=dark] .mpga-container{background:#1a1a2e}[data-theme=dark] .selector-title{color:#e0e0e0}[data-theme=dark] .card-description{color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}[data-theme=dark] .card-title{text-shadow:2px 2px 6px rgba(0,0,0,.6)}[data-theme=dark] .card-image-container{background:#2c2c3e;border-bottom-color:#ffffff1a}[data-theme=dark] .assistant-card{background:#2c2c3e}@media (max-width: 1200px){.assistant-cards-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:30px}}@media (max-width: 900px){.assistant-cards-grid{grid-template-columns:1fr;max-width:500px}.assistant-card{height:450px}}@media (max-width: 768px){.mpga-main-content{flex-direction:column}.assistant-selector-area{padding:20px}.selector-title{font-size:24px;margin-bottom:30px}.assistant-cards-grid{gap:20px}.assistant-card{height:400px}.card-image-container{padding:15px}.card-content{padding:20px}.card-title{font-size:20px}.card-description{font-size:14px}}.view-requests-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}.view-requests-modal{background:#fff;border-radius:12px;width:95%;max-width:1800px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid #f0f0f0;flex-shrink:0}.modal-header h2{margin:0;font-size:1.5em;color:#2c3e50}.modal-close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#7f8c8d;width:36px;height:36px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background:#f5f5f5;color:#2c3e50}.modal-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.modal-loading,.modal-error,.modal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.modal-error{color:#e74c3c}.modal-error span{font-size:48px;margin-bottom:15px}.retry-btn{margin-top:15px;padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.retry-btn:hover{background:#5568d3;transform:translateY(-1px)}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.modal-empty h3{margin:0 0 10px;color:#2c3e50}.modal-empty p{margin:0;color:#7f8c8d}.modal-body{padding:20px 30px;overflow:hidden;flex:1;display:flex;flex-direction:column}.submissions-list{display:flex;flex-direction:column;overflow:hidden;height:100%}.submissions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;gap:20px;flex-shrink:0}.submissions-header>div{flex:1}.submissions-list h3{margin:0 0 8px;font-size:1.1em;color:#2c3e50}.list-hint{margin:0 0 15px;font-size:13px;color:#7f8c8d}.submissions-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding-right:10px}.submission-card{background:#f8f9fa;border:2px solid #e1e8ed;border-radius:8px;padding:15px;cursor:pointer;transition:all .2s}.submission-card:hover{border-color:#667eea;background:#f0f2ff;transform:translate(3px)}.submission-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 2px 8px #667eea33}.submission-preview-item{display:flex;flex-direction:column;gap:10px}.submission-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.submission-info{display:flex;flex-direction:column;gap:4px}.submission-actions{display:flex;align-items:center;gap:8px}.submission-requester{font-weight:600;color:#2c3e50;font-size:15px}.submission-date{font-size:12px;color:#95a5a6}.submission-status{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.delete-submission-btn{background:transparent;border:none;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:4px;transition:all .2s ease;opacity:.6;line-height:1}.delete-submission-btn:hover{background:#e74c3c1a;opacity:1;transform:scale(1.1)}.delete-submission-btn:active{transform:scale(.95)}.status-pending{background:#f1c40f33;color:#f39c12}.status-reviewed{background:#3498db33;color:#3498db}.status-approved{background:#2ecc7133;color:#27ae60}.status-rejected{background:#e74c3c33;color:#c0392b}.status-planned{background:#9b59b633;color:#8e44ad}.submission-details{display:flex;flex-direction:column;gap:6px}.detail-row{display:flex;gap:8px;font-size:13px}.detail-label{font-weight:500;color:#7f8c8d;min-width:90px}.detail-value{color:#2c3e50;flex:1;word-break:break-word}.submission-detail-panel{display:flex;flex-direction:column;background:#fff;border:2px solid #e1e8ed;border-radius:8px;overflow:hidden}.submission-detailed-view{flex:1;overflow-y:auto;padding:20px}.submission-detailed-view h3{margin:0 0 15px;font-size:1.2em;color:#2c3e50}.detail-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.detail-item{display:flex;flex-direction:column;gap:4px;padding:10px;background:#f8f9fa;border-radius:6px;border-left:3px solid #667eea}.detail-item-label{font-weight:600;font-size:12px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.detail-item-value{font-size:14px;color:#2c3e50;word-break:break-word}.submission-meta{margin-top:20px;padding-top:15px;border-top:1px solid #e1e8ed}.submission-meta p{margin:8px 0;font-size:13px;color:#7f8c8d}.submission-meta strong{color:#2c3e50}.detail-actions{padding:15px 20px;border-top:2px solid #f0f0f0;background:#f8f9fa}.copy-to-input-btn{width:100%;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.copy-to-input-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.copy-to-input-btn:active{transform:translateY(0)}.submissions-scroll::-webkit-scrollbar,.submission-detailed-view::-webkit-scrollbar{width:8px}.submissions-scroll::-webkit-scrollbar-track,.submission-detailed-view::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.submissions-scroll::-webkit-scrollbar-thumb,.submission-detailed-view::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:10px}.submissions-scroll::-webkit-scrollbar-thumb:hover,.submission-detailed-view::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media (max-width: 1024px){.modal-body{grid-template-columns:1fr}.submission-detail-panel{max-height:400px}}.request-type-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-right:8px}.badge-sr{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.badge-bemr{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.request-type-badge-large{display:inline-block;padding:8px 16px;border-radius:16px;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;margin-bottom:20px}.detail-badge-container{margin-bottom:20px}.submission-summary{padding:12px;background:#f7fafc;border-radius:6px;margin-top:8px;font-size:.9rem;color:#4a5568;line-height:1.5}.submission-summary strong{color:#2d3748}.detail-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e2e8f0}.detail-section:last-of-type{border-bottom:none}.detail-section h4{color:#2d3748;font-size:1rem;font-weight:600;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #667eea;display:inline-block}.detail-grid .full-width{grid-column:1 / -1}.list-display{list-style:none;padding:0;margin:0}.list-display li{padding:8px 12px;background:#f7fafc;border-radius:6px;margin-bottom:6px;border-left:3px solid #667eea}.rag-accordion{margin:10px 0;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#f8f9fa}[data-theme=dark] .rag-accordion{background:#2c2c3e;border-color:#404055}.rag-accordion-header{width:100%;padding:12px 15px;background:#fff;border:none;display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;font-weight:500;color:#2c3e50;transition:background-color .2s}[data-theme=dark] .rag-accordion-header{background:#3a3a4e;color:#e0e0e0}.rag-accordion-header:hover{background:#f5f7fa}[data-theme=dark] .rag-accordion-header:hover{background:#454560}.rag-icon{font-size:18px}.rag-title{flex:1;text-align:left}.rag-chevron{font-size:12px;transition:transform .2s;color:#7f8c8d}.rag-chevron.expanded{transform:rotate(180deg)}.rag-accordion-content{padding:15px;background:#fff;border-top:1px solid #e0e0e0;max-height:600px;overflow-y:auto;overflow-x:hidden}[data-theme=dark] .rag-accordion-content{background:#2c2c3e;border-top-color:#404055}.rag-description{margin:0 0 15px;font-size:13px;color:#7f8c8d;font-style:italic}.rag-sources{display:flex;flex-direction:column;gap:12px;max-height:500px;overflow-y:auto;overflow-x:hidden}.rag-source-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:12px}[data-theme=dark] .rag-source-item{background:#3a3a4e;border-color:#404055}.rag-source-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.rag-source-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#3498db;color:#fff;border-radius:50%;font-size:12px;font-weight:700}.rag-source-title{flex:1;font-weight:600;font-size:13px;color:#2c3e50}[data-theme=dark] .rag-source-title{color:#e0e0e0}.rag-source-score{font-size:11px;color:#27ae60;background:#27ae601a;padding:2px 8px;border-radius:10px;font-weight:500}[data-theme=dark] .rag-source-score{background:#27ae6033}.rag-source-content{font-size:13px;color:#555;line-height:1.6;padding:8px;background:#fff;border-radius:4px;border-left:3px solid #3498db;max-height:300px;overflow-y:auto;overflow-x:hidden;word-wrap:break-word}[data-theme=dark] .rag-source-content{background:#2c2c3e;color:#b0b0b0}.rag-source-metadata{margin-top:8px;display:flex;gap:15px;font-size:11px;color:#95a5a6}.rag-source-metadata span{padding:2px 6px;background:#95a5a61a;border-radius:3px}[data-theme=dark] .rag-source-metadata span{background:#95a5a633}.rag-query-section{margin-bottom:15px;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}[data-theme=dark] .rag-query-section{border-color:#404055}.rag-query-toggle{width:100%;padding:10px 12px;background:#f8f9fa;border:none;display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;font-weight:500;color:#2c3e50;transition:background-color .2s}[data-theme=dark] .rag-query-toggle{background:#3a3a4e;color:#e0e0e0}.rag-query-toggle:hover{background:#e9ecef}[data-theme=dark] .rag-query-toggle:hover{background:#454560}.rag-query-icon{font-size:14px}.rag-query-content{padding:12px;background:#fff;border-top:1px solid #e0e0e0;font-size:13px;color:#555;line-height:1.6;font-style:italic}[data-theme=dark] .rag-query-content{background:#2c2c3e;border-top-color:#404055;color:#b0b0b0}.rag-similarity{color:#27ae60;font-weight:600}.scope-chat-container{display:flex;flex-direction:column;height:100vh;width:100vw;margin:0;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:90px 0 0 80px}.scope-main-content{display:flex;gap:20px;flex:1;overflow:hidden;height:calc(100vh - 90px)}.chat-header{display:flex;justify-content:flex-end;padding-bottom:10px}.rag-toggle-button{padding:8px 16px;border:2px solid;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-right:10px}.jha-chat-container{display:flex;flex-direction:column;height:100vh;width:100vw;margin:0;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:90px 0 0 80px}.jha-main-content{display:flex;gap:20px;flex:1;overflow:hidden;height:calc(100vh - 90px)}.header-right{display:flex;justify-content:flex-end;padding:10px 15px;border-bottom:1px solid #e0e0e0}.operations-chat-container{display:flex;flex-direction:column;height:100vh;width:100vw;margin:0;overflow:hidden;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:90px 0 0 80px}.operations-main-content{display:flex;gap:20px;flex:1;overflow:hidden;height:calc(100vh - 90px)}.chat-area{flex:1;display:flex;flex-direction:column;gap:15px;padding:20px;overflow-y:auto;height:100%}.chat-header{display:flex;justify-content:flex-end;padding-bottom:10px;gap:10px}.rag-toggle-button{padding:8px 16px;border:2px solid;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.rag-toggle-button.rag-enabled{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border-color:#11998e;box-shadow:0 2px 4px #11998e4d}.rag-toggle-button.rag-enabled:hover{transform:translateY(-2px);box-shadow:0 4px 8px #11998e66}.rag-toggle-button.rag-disabled{background:linear-gradient(135deg,#757575,#9e9e9e);color:#fff;border-color:#757575;box-shadow:0 2px 4px #7575754d}.rag-toggle-button.rag-disabled:hover{transform:translateY(-2px);box-shadow:0 4px 8px #75757566}.new-chat-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}.new-chat-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #0003}.new-chat-button:disabled{opacity:.6;cursor:not-allowed}.error-banner{background:#e74c3ce6;color:#fff;padding:12px 20px;border-radius:8px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:0 5px}.messages-container{flex:1;overflow-y:auto;padding:20px;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.empty-chat{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#7f8c8d}.empty-chat-image{width:220px;height:220px;margin-bottom:20px;opacity:.8}.empty-chat h2{margin:0 0 15px;color:#2c3e50;font-size:1.6em}.empty-chat p{margin:0;font-size:17px;line-height:1.6;max-width:600px;color:#4a5568}.chat-message{display:flex;align-items:flex-start;margin-bottom:20px;animation:fadeIn .3s ease-in}.user-message{flex-direction:row-reverse}.message-avatar{width:50px;height:50px;border-radius:50%;object-fit:cover;margin:0 12px;flex-shrink:0}.message-avatar.pulsing{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.05)}}.typing-indicator{display:flex;gap:4px;padding:8px 12px}.typing-indicator span{width:8px;height:8px;border-radius:50%;background-color:#666;animation:typing-bounce 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.message-bubble{max-width:70%;padding:12px 18px;border-radius:18px;word-wrap:break-word}.user-message .message-bubble{background:var(--user-message-bg-color, linear-gradient(135deg, #667eea 0%, #764ba2 100%));color:var(--user-message-text-color, white)}.assistant-message .message-bubble{background:var(--assistant-message-bg-color, linear-gradient(135deg, #4facfe 0%, #00f2fe 100%));color:var(--assistant-message-text-color, white)}.message-bubble p{margin:0 0 8px}.message-bubble p:last-child{margin-bottom:0}.message-bubble code{background:#0000001a;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:14px}.message-bubble pre{background:#1e1e1e;padding:12px;border-radius:8px;overflow-x:auto;margin:8px 0}.message-bubble pre code{background:none;padding:0;color:#d4d4d4}.input-area{padding:15px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.input-wrapper{position:relative;display:flex;align-items:flex-end;gap:8px}.input-area textarea{flex:1;padding:12px 60px 12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;font-family:inherit;resize:vertical;transition:border-color .3s;background:var(--input-bg-color, #fafafa);color:var(--input-text-color, #2c3e50);min-height:50px;max-height:300px}.input-area textarea:focus{outline:none;border-color:#667eea;background:var(--input-bg-color, white)}.input-area textarea:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.send-button-inline{position:absolute;right:8px;bottom:8px;width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:20px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-button-inline:hover:not(:disabled){transform:scale(1.05);box-shadow:0 2px 8px #667eea66}.send-button-inline:active:not(:disabled){transform:scale(.95)}.send-button-inline:disabled{opacity:.5;cursor:not-allowed}.new-chat-button-header{padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.new-chat-button-header:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.new-chat-button-header:disabled{opacity:.5;cursor:not-allowed}.chat-header{display:flex;justify-content:flex-end;padding:10px 15px;border-bottom:1px solid #e0e0e0}.send-button{padding:0 28px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;display:flex;align-items:center;justify-content:center;min-width:100px}.send-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.settings-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.settings-modal{background:#fff;padding:30px;border-radius:12px;max-width:500px;width:90%;box-shadow:0 10px 40px #0000004d}.settings-modal h2{margin:0 0 15px;color:#2c3e50}.settings-modal p{margin:0 0 20px;color:#7f8c8d}.settings-modal button{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}.settings-modal button:hover{opacity:.9}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.messages-container::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px}.messages-container::-webkit-scrollbar-thumb:hover{background:#764ba2}@media (max-width: 768px){.chat-area{margin-left:70px;padding:10px}.message-bubble{max-width:85%}.message-avatar{width:32px;height:32px;margin:0 8px}.input-area{flex-direction:column;align-items:stretch}.send-button{width:100%}}.rag-accordion-container{margin-top:15px;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}[data-theme=dark] .rag-accordion-container{box-shadow:0 2px 8px #0000004d}.knexus-container{display:flex;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;padding-top:90px;padding-left:80px;overflow:hidden}.main-content-area{flex:1;display:flex;flex-direction:column;background:#fff;border-radius:15px 0 0 15px;overflow:hidden;box-shadow:-10px 0 30px #0000001a;height:calc(100vh - 90px)}.knexus-header{padding:30px 40px;background:#fff;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.header-left h2{margin:0 0 5px;color:#1a1a2e;font-size:1.8em}.subtitle{margin:0;color:#666;font-size:.95em}.btn-create{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-weight:700;font-size:1em;cursor:pointer;transition:transform .2s,box-shadow .3s}.btn-create:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-create:active{transform:translateY(0)}.btn-nav{width:100%;padding:12px;margin-bottom:8px;background:#0f0f1e;border:1px solid #2d3561;border-radius:8px;color:#fff;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.btn-nav:hover{background:#16213e;border-color:#667eea}.btn-nav.active{background:linear-gradient(135deg,#667eea4d,#764ba24d);border-color:#667eea}.nexuses-content{flex:1;overflow-y:auto;padding:40px;background:#f9f9f9}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666}.spinner{width:50px;height:50px;border:4px solid #f0f0f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-small{width:20px;height:20px;border:3px solid #f0f0f0;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;display:inline-block;margin-right:10px;vertical-align:middle}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#666}.empty-icon{font-size:5em;margin-bottom:20px;opacity:.3}.empty-state h3{font-size:2em;margin-bottom:10px;color:#1a1a2e}.empty-state p{font-size:1.1em;margin-bottom:30px;color:#666}.btn-create-large{padding:15px 30px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:1.1em;cursor:pointer;transition:transform .2s,box-shadow .3s}.btn-create-large:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.nexuses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:25px}.nexus-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;transition:all .3s;border:2px solid transparent}.nexus-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #667eea33;border-color:#667eea}.nexus-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.nexus-card-header h3{margin:0;color:#1a1a2e;font-size:1.3em;word-break:break-word}.btn-delete-small{background:#ff3b301a;border:none;padding:8px 12px;border-radius:8px;cursor:pointer;transition:background .3s;font-size:1.1em}.btn-delete-small:hover{background:#ff3b3033}.nexus-card-body{margin-bottom:15px}.nexus-stat{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f5f5f5}.nexus-stat:last-child{border-bottom:none}.stat-label{color:#666;font-size:.9em}.stat-value{color:#1a1a2e;font-weight:600;font-size:.95em}.nexus-card-footer{display:flex;justify-content:flex-end;margin-top:15px}.nexus-badge{padding:6px 12px;background:linear-gradient(135deg,#667eea1a,#764ba21a);color:#667eea;border-radius:6px;font-size:.85em;font-weight:600}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:15px;padding:30px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.modal-header h2{margin:0;color:#1a1a2e}.modal-close{background:transparent;border:none;font-size:1.5em;cursor:pointer;color:#666;padding:5px 10px;transition:color .3s}.modal-close:hover{color:#1a1a2e}.create-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#1a1a2e;font-size:.95em}.form-group input,.form-group select{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1em;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group input:disabled,.form-group select:disabled{background:#f5f5f5;cursor:not-allowed}.form-group small{color:#666;font-size:.85em}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.selected-files{margin-top:10px;padding:12px;background:#f9f9f9;border-radius:8px;border-left:4px solid #667eea}.selected-files ul{margin:5px 0 0;padding-left:20px}.selected-files li{color:#666;font-size:.9em;margin:4px 0}.progress-message{padding:15px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:8px;display:flex;align-items:center;color:#667eea;font-weight:500}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:10px}.btn-cancel{padding:12px 24px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#666;font-weight:600;cursor:pointer;transition:all .3s}.btn-cancel:hover:not(:disabled){border-color:#667eea;color:#667eea}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-submit{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .3s}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 768px){.knexus-header{flex-direction:column;gap:15px;align-items:flex-start}.nexuses-grid,.form-row{grid-template-columns:1fr}.modal-content{width:95%;padding:20px}}.persona-creator-container{display:flex;flex-direction:column;height:100vh;width:100%;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding-top:90px;padding-left:80px;overflow:hidden}.persona-main-content{display:flex;gap:20px;flex:1;overflow:hidden;height:calc(100vh - 90px)}.persona-creator-content{flex:1;padding:20px;overflow-y:auto;height:100%}.persona-creator-header{background:#fff;padding:20px 30px;margin-bottom:20px;border-radius:12px;box-shadow:0 2px 4px #0000001a}.persona-creator-header h1{margin:0 0 10px;font-size:24px;color:#2c3e50}.persona-creator-header p{margin:0;font-size:14px;color:#666}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer}.persona-creator-form{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #0000001a}.form-section{margin-bottom:30px;padding-bottom:30px;border-bottom:2px solid #f0f0f0}.form-section:last-child{border-bottom:none}.form-section h2{font-size:20px;color:#333;margin:0 0 20px;display:flex;align-items:center;gap:8px}.form-group label{display:block;font-weight:600;color:#333;margin-bottom:8px;font-size:14px}.form-group .required{color:#e74c3c;font-weight:700}.form-group .field-hint{display:block;font-weight:400;font-size:12px;color:#666;margin-top:4px;font-style:italic}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:12px;border:2px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input[type=text]:focus,.form-group input[type=number]:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;min-height:80px}.form-group input[type=range]{width:100%;height:6px;border-radius:3px;background:#ddd;outline:none;-webkit-appearance:none}.form-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer}.form-group input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;border:none}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:2px solid #f0f0f0}.btn-cancel,.btn-create{padding:12px 30px;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel{background:#ecf0f1;color:#555}.btn-cancel:hover:not(:disabled){background:#d5dbdc}.btn-create{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-create:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-cancel:disabled,.btn-create:disabled{opacity:.6;cursor:not-allowed}.success-message,.error-message{padding:15px 20px;margin-bottom:20px;border-radius:8px;font-weight:500}.success-message{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.error-message{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.persona-creator-footer{background:#fff;padding:20px 30px;margin-top:20px;border-radius:12px;box-shadow:0 2px 4px #0000001a}.persona-creator-footer p{margin:0;font-size:14px;color:#666}.persona-creator-footer strong{color:#333}@media (max-width: 768px){.persona-creator-container{padding:10px}.persona-creator-content{border-radius:8px}.persona-creator-header{padding:20px}.persona-creator-header h1{font-size:24px}.persona-creator-form{padding:20px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-cancel,.btn-create{width:100%}}.persona-testing-container{display:flex;flex-direction:column;min-height:100vh;width:100%;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding-top:90px;padding-left:80px}.persona-testing-main-content{display:flex;gap:20px;flex:1;overflow:hidden;height:calc(100vh - 90px)}.persona-testing-layout{flex:1;display:flex;gap:15px;padding:20px;overflow:hidden}.persona-selection-panel{width:320px;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;overflow:hidden}.panel-header{padding:20px;background:#fff;border-bottom:2px solid #e1e8ed}.panel-header h2{margin:0 0 5px;font-size:20px;color:#2c3e50}.panel-header p{margin:0;font-size:13px;color:#666}.persona-list{flex:1;overflow-y:auto;padding:15px}.persona-card{background:#fff;border:2px solid #e1e8ed;border-radius:8px;padding:15px;margin-bottom:12px;cursor:pointer;transition:all .2s;display:flex;align-items:flex-start;gap:10px}.persona-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.persona-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 4px 12px #667eea33}.delete-persona-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:5px 8px;border-radius:4px;transition:all .2s;opacity:.6;flex-shrink:0}.delete-persona-btn:hover{background:#fee;opacity:1;transform:scale(1.1)}.persona-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.persona-card-header h3{margin:0;font-size:16px;color:#2c3e50}.rag-badge{background:#4facfe;color:#fff;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.persona-description{margin:0 0 10px;font-size:13px;color:#666;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.persona-meta{display:flex;gap:10px;font-size:12px;color:#888}.meta-item{display:flex;align-items:center;gap:4px}.testing-panel{flex:1;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;overflow:hidden}.no-selection{flex:1;display:flex;align-items:center;justify-content:center;background:#f5f7fa}.no-selection-content{text-align:center;color:#888;max-width:400px;padding:40px}.no-selection-icon{font-size:64px;display:block;margin-bottom:20px}.no-selection-content h3{margin:0 0 10px;color:#555;font-size:24px}.no-selection-content p{margin:0;font-size:16px;line-height:1.5}.testing-header{padding:20px;border-bottom:2px solid #e1e8ed;display:flex;justify-content:space-between;align-items:flex-start;background:#fff;gap:20px}.testing-controls{display:flex;align-items:center;gap:15px}.rag-toggle{display:flex;align-items:center}.rag-toggle label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.rag-toggle input[type='"checkbox"']{width:18px;height:18px;cursor:pointer}.toggle-label{font-size:14px;font-weight:600;color:#667eea;white-space:nowrap}.test-params{position:relative}.test-params details{background:#fff;border:1px solid #e1e8ed;border-radius:6px;padding:8px 12px;cursor:pointer}.test-params summary{font-size:14px;font-weight:600;color:#667eea;cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none}.test-params summary::-webkit-details-marker{display:none}.param-grid{margin-top:15px;display:grid;grid-template-columns:1fr;gap:15px;max-width:300px}.param-item{display:flex;flex-direction:column;gap:5px}.param-item label{font-size:12px;font-weight:600;color:#2c3e50}.param-item select{padding:6px 10px;border:1px solid #e1e8ed;border-radius:4px;font-size:13px;background:#fff;cursor:pointer}.param-item input[type=range]{width:100%;cursor:pointer}.persona-info h2{margin:0 0 5px;font-size:22px;color:#2c3e50}.persona-info p{margin:0;font-size:14px;color:#666;line-height:1.5}.btn-clear{padding:10px 20px;background:#e74c3c;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-clear:hover:not(:disabled){background:#c0392b;transform:translateY(-1px)}.btn-clear:disabled{opacity:.5;cursor:not-allowed}.test-messages{flex:1;overflow-y:auto;padding:20px;background:#fafbfc}.empty-state{text-align:center;padding:60px 20px;color:#888}.empty-state p{margin:10px 0;font-size:16px}.empty-state .hint{font-size:14px;color:#aaa}.test-message{margin-bottom:20px;padding:15px;border-radius:8px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.test-message.user{background:#667eea;color:#fff;margin-left:20%}.test-message.assistant{background:#fff;border:2px solid #e1e8ed;margin-right:20%}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px;opacity:.8}.test-message.user .message-header{color:#ffffffe6}.test-message.assistant .message-header{color:#888}.message-role{font-weight:600}.message-content{white-space:pre-wrap;word-wrap:break-word;line-height:1.6;font-size:14px}.test-message.assistant .message-content{color:#2c3e50}.error-message{background:#fee;color:#c33;padding:15px;border-radius:8px;margin-top:10px;border:1px solid #fcc}.test-input-area{padding:20px;border-top:2px solid #e1e8ed;background:#fff;display:flex;gap:15px;align-items:flex-end}.test-input-area textarea{flex:1;padding:12px;border:2px solid #e1e8ed;border-radius:6px;font-size:14px;font-family:inherit;resize:none;transition:border-color .2s}.test-input-area textarea:focus{outline:none;border-color:#667eea}.test-input-area textarea:disabled{background:#f5f7fa;cursor:not-allowed}.btn-send{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;height:fit-content}.btn-send:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-send:disabled{opacity:.6;cursor:not-allowed}.persona-list::-webkit-scrollbar,.test-messages::-webkit-scrollbar{width:8px}.persona-list::-webkit-scrollbar-track,.test-messages::-webkit-scrollbar-track{background:#f1f1f1}.persona-list::-webkit-scrollbar-thumb,.test-messages::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.persona-list::-webkit-scrollbar-thumb:hover,.test-messages::-webkit-scrollbar-thumb:hover{background:#999}@media (max-width: 768px){.persona-testing-main-content{flex-direction:column}.persona-testing-layout{flex-direction:column;padding:10px}.persona-selection-panel{width:100%;max-height:40vh}.test-message.user,.test-message.assistant{margin-left:0;margin-right:0}.testing-header{flex-direction:column;gap:15px}.testing-controls{width:100%;flex-direction:column}.btn-clear,.rag-toggle{width:100%}.test-input-area{flex-direction:column}.btn-send{width:100%}}.knexus-creator-container{display:flex;flex-direction:column;height:100vh;width:100%;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding-top:90px;padding-left:80px;overflow:hidden}.knexus-main-content{display:flex;gap:20px;flex:1;overflow:hidden;height:calc(100vh - 90px)}.knexus-creator-content{flex:1;padding:20px;overflow-y:auto;height:100%}.success-banner{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:20px 30px;margin-bottom:20px;border-radius:12px;box-shadow:0 4px 12px #10b9814d;display:flex;align-items:center;gap:15px;font-size:16px;font-weight:500;animation:slideDown .3s ease-out}.success-banner-icon{font-size:32px;animation:bounce .6s ease-in-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.error-message{background:#fee;color:#c33;padding:15px 20px;border-radius:8px;border-left:4px solid #c33;margin-bottom:20px}.mode-selector{display:flex;gap:15px;margin-bottom:30px;background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 4px #0000001a}.mode-btn{flex:1;padding:15px 20px;border:2px solid #e1e8ed;border-radius:8px;background:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.mode-btn:hover{border-color:#667eea;background:#f8f9ff}.mode-btn.active{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);color:#667eea}.knexus-form{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #0000001a}.form-section{margin-bottom:30px;padding-bottom:30px;border-bottom:1px solid #e1e8ed}.form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section h2{margin:0 0 20px;font-size:18px;color:#2c3e50;font-weight:600}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#2c3e50;font-size:14px}.field-hint{display:block;font-size:12px;color:#666;font-weight:400;margin-top:4px}.required{color:#e74c3c;margin-left:4px}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input[type=file]{width:100%;padding:10px;border:2px dashed #ddd;border-radius:6px;cursor:pointer;background:#f8f9fa}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.file-list{margin-top:15px;padding:15px;background:#f8f9fa;border-radius:8px}.file-list h4{margin:0 0 10px;font-size:14px;color:#666}.file-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#fff;border-radius:6px;margin-bottom:8px;border:1px solid #e1e8ed}.file-name{font-size:14px;color:#2c3e50}.file-size{color:#666;font-size:12px;margin-left:8px}.remove-file-btn{background:none;border:none;color:#e74c3c;cursor:pointer;padding:5px 10px;border-radius:4px;font-size:18px;transition:all .2s}.remove-file-btn:hover{background:#fee}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 0}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;margin:0}.model-checkboxes{display:flex;flex-direction:column;gap:10px;padding:10px;background:#f8f9fa;border-radius:8px}.file-info{margin-top:10px;padding:10px;background:#e8f5e9;border-radius:6px;color:#2e7d32;font-size:14px}.form-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:30px;padding-top:20px;border-top:1px solid #e1e8ed}.btn-primary,.btn-secondary{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:#666;border:1px solid #ddd}.btn-secondary:hover:not(:disabled){background:#f8f9fa}.optimization-results{margin-top:30px}.best-config{margin-bottom:30px}.best-config h3{margin:0 0 15px;font-size:16px;color:#2c3e50}.config-card{background:linear-gradient(135deg,#667eea1a,#764ba21a);padding:20px;border-radius:8px;border:2px solid #667eea}.config-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.1)}.config-row:last-child{border-bottom:none}.config-label{font-weight:500;color:#2c3e50}.config-value{font-weight:600;color:#667eea}.all-results h3{margin:0 0 15px;font-size:16px;color:#2c3e50}.results-table{overflow-x:auto}.results-table table{width:100%;border-collapse:collapse}.results-table th{background:#f8f9fa;padding:12px;text-align:left;font-weight:600;font-size:13px;color:#2c3e50;border-bottom:2px solid #e1e8ed}.results-table td{padding:10px 12px;font-size:13px;border-bottom:1px solid #e1e8ed}.results-table tr:hover{background:#f8f9fa}.progress-container{margin:20px 0;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e1e8ed}.progress-text{margin:0 0 10px;font-size:14px;font-weight:500;color:#2c3e50;text-align:center}.progress-bar-container{width:100%;height:20px;background:#e1e8ed;border-radius:10px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;transition:width .5s ease;box-shadow:0 2px 4px #667eea66}body{margin:0;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;transition:background-color .3s ease,color .3s ease;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}body.theme-light,body:not([class*=theme-]){--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-gradient-start: #f5f7fa;--bg-gradient-end: #c3cfe2;--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #888888;--border-color: #e0e0e0;--shadow-color: rgba(0, 0, 0, .1);--accent-purple: #667eea;--accent-purple-dark: #764ba2;--message-user-bg: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--message-assistant-bg: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--input-bg: #ffffff;--input-border: #e0e0e0;--input-focus: #667eea;--card-bg: #ffffff;--card-hover-shadow: rgba(0, 0, 0, .15)}body.theme-dark{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-gradient-start: #1a1a1a;--bg-gradient-end: #3a3a3a;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #808080;--border-color: #404040;--shadow-color: rgba(0, 0, 0, .5);--accent-purple: #8b9dff;--accent-purple-dark: #9d7bc2;--message-user-bg: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--message-assistant-bg: linear-gradient(135deg, #374a6d 0%, #2d4a5e 100%);--input-bg: #2d2d2d;--input-border: #404040;--input-focus: #8b9dff;--card-bg: #2d2d2d;--card-hover-shadow: rgba(255, 255, 255, .1);background-color:var(--bg-primary);color:var(--text-primary)}body.theme-high-contrast{--bg-primary: #000000;--bg-secondary: #1a1a1a;--bg-gradient-start: #000000;--bg-gradient-end: #1a1a1a;--text-primary: #ffffff;--text-secondary: #ffffff;--text-tertiary: #cccccc;--border-color: #ffffff;--shadow-color: rgba(255, 255, 255, .3);--accent-purple: #ffff00;--accent-purple-dark: #ffff00;--message-user-bg: #0000ff;--message-assistant-bg: #006600;--input-bg: #000000;--input-border: #ffffff;--input-focus: #ffff00;--card-bg: #000000;--card-hover-shadow: rgba(255, 255, 255, .3);background-color:var(--bg-primary);color:var(--text-primary)}body.theme-high-contrast *{border-color:var(--border-color)!important}body.theme-high-contrast button,body.theme-high-contrast input,body.theme-high-contrast select,body.theme-high-contrast textarea{border:2px solid var(--border-color)!important}body.theme-ut-knoxville{--bg-primary: #ffffff;--bg-secondary: #f8f8f8;--bg-gradient-start: #ffffff;--bg-gradient-end: #f0f0f0;--text-primary: #4B4B4B;--text-secondary: #4B4B4B;--text-tertiary: #808080;--border-color: #e0e0e0;--shadow-color: rgba(255, 130, 0, .2);--accent-purple: #FF8200;--accent-purple-dark: #cc6800;--message-user-bg: linear-gradient(135deg, #FF8200 0%, #cc6800 100%);--message-assistant-bg: linear-gradient(135deg, #4B4B4B 0%, #3a3a3a 100%);--input-bg: #ffffff;--input-border: #e0e0e0;--input-focus: #FF8200;--card-bg: #ffffff;--card-hover-shadow: rgba(255, 130, 0, .3);background-color:var(--bg-primary);color:var(--text-primary)}body.theme-ut-knoxville .new-chat-button,body.theme-ut-knoxville .save-button,body.theme-ut-knoxville .refresh-button{background:linear-gradient(135deg,#ff8200,#cc6800)!important}body.theme-ut-knoxville .tab-button.active{border-bottom-color:#ff8200!important;color:#ff8200!important}body.theme-ut-knoxville .top-banner{background:linear-gradient(90deg,#ff8200,#4b4b4b)!important}body.theme-ut-knoxville .settings-header{background:linear-gradient(135deg,#ff8200,#4b4b4b)!important}body.theme-ut-knoxville .card-content{background:linear-gradient(135deg,#ff8200,#cc6800)!important}body.theme-ut-knoxville .side-panel-button.active{background:#ff820026!important;border-left:4px solid #FF8200!important}body.theme-ut-knoxville .send-button{background:linear-gradient(135deg,#ff8200,#cc6800)!important}body.theme-ut-knoxville input[type=range]::-webkit-slider-thumb,body.theme-ut-knoxville input[type=range]::-moz-range-thumb{background:linear-gradient(135deg,#ff8200,#cc6800)!important}body.theme-ut-knoxville .current-badge{background:linear-gradient(135deg,#ff8200,#cc6800)!important}body.font-small{font-size:14px}body.font-medium,body:not([class*=font-]){font-size:16px}body.font-large{font-size:18px}body.font-extra-large{font-size:20px}body.font-small h1{font-size:1.8rem}body.font-small h2{font-size:1.5rem}body.font-small h3{font-size:1.2rem}body.font-medium h1{font-size:2rem}body.font-medium h2{font-size:1.75rem}body.font-medium h3{font-size:1.4rem}body.font-large h1{font-size:2.2rem}body.font-large h2{font-size:1.9rem}body.font-large h3{font-size:1.6rem}body.font-extra-large h1{font-size:2.5rem}body.font-extra-large h2{font-size:2.1rem}body.font-extra-large h3{font-size:1.8rem}.home-container,.mra-chat-container{background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)!important}.messages-container,.input-area{background:var(--bg-primary)!important}body.theme-dark .messages-container,body.theme-high-contrast .messages-container{background:var(--bg-secondary)!important}.banner-title,.selector-title,h1,h2,h3,h4,h5,h6{color:var(--text-primary)!important}.banner-description,.card-description,p{color:var(--text-secondary)!important}.top-banner .banner-title,.top-banner .banner-description{color:#fff!important;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.settings-header h2,.settings-header button{color:#fff!important}.message-bubble.user{background:var(--message-user-bg)!important;color:#fff!important}.message-bubble.assistant{background:var(--message-assistant-bg)!important}body.theme-light .message-bubble.assistant{color:#333!important}body.theme-dark .message-bubble.assistant,body.theme-high-contrast .message-bubble.assistant{color:#fff!important}textarea,input[type=text],input[type=password],select{background:var(--input-bg)!important;color:var(--text-primary)!important;border-color:var(--input-border)!important}textarea::placeholder{color:var(--text-tertiary)!important}textarea:focus,input:focus,select:focus{border-color:var(--input-focus)!important}.assistant-card{background:var(--card-bg)!important;border-color:var(--border-color)!important}.assistant-card:hover{box-shadow:0 8px 24px var(--card-hover-shadow)!important}.card-content{color:#fff!important}body.theme-dark .side-panel,body.theme-high-contrast .side-panel{background:var(--bg-secondary)!important;border-right-color:var(--border-color)!important}body.theme-dark .side-panel-button,body.theme-high-contrast .side-panel-button{color:var(--text-primary)!important}body.theme-dark .settings-modal,body.theme-high-contrast .settings-modal,body.theme-dark .settings-content,body.theme-high-contrast .settings-content{background:var(--bg-primary)!important}body.theme-dark .settings-tabs,body.theme-high-contrast .settings-tabs{background:var(--bg-secondary)!important}body.theme-dark .tab-button,body.theme-high-contrast .tab-button{color:var(--text-secondary)!important}body.theme-dark .tab-button.active,body.theme-high-contrast .tab-button.active{background:var(--bg-primary)!important;color:var(--text-primary)!important}body.theme-dark .session-item,body.theme-high-contrast .session-item{background:var(--bg-secondary)!important;border-color:var(--border-color)!important}body.theme-dark .setting-item label,body.theme-high-contrast .setting-item label{color:var(--text-primary)!important}body.theme-dark .setting-item small,body.theme-high-contrast .setting-item small{color:var(--text-tertiary)!important}body.theme-dark .section-description,body.theme-high-contrast .section-description{color:var(--text-secondary)!important}body.theme-high-contrast .error-banner{background:red!important;border:2px solid #ffffff!important}body.theme-high-contrast *:focus{outline:3px solid #ffff00!important;outline-offset:2px!important}body.theme-dark .empty-chat,body.theme-high-contrast .empty-chat{color:var(--text-secondary)!important}body.theme-dark .empty-chat h2,body.theme-high-contrast .empty-chat h2{color:var(--text-primary)!important}.login-container,.login-container *{color:inherit!important}.login-box{background:#fff!important;color:#333!important}.login-box h1{color:#667eea!important}.login-box h2{color:#333!important}.login-box .form-group label{color:#555!important}.login-box .form-group input{background:#fff!important;color:#333!important;border-color:#ddd!important}.login-box .form-group input:focus{border-color:#667eea!important}.login-box .toggle-mode{color:#666!important}.login-box .link-button{color:#667eea!important}.login-box .error-message{background:#fee!important;color:#c33!important;border-color:#fcc!important}:root{--ut-orange: #FF8200;--ut-orange-dark: #E67300;--ut-orange-light: #FFA040;--smokey-grey: #58595B;--smokey-grey-dark: #3D3E40;--smokey-grey-light: #7A7B7D;--primary-color: var(--ut-orange);--primary-hover: var(--ut-orange-dark);--primary-light: var(--ut-orange-light);--secondary-color: var(--smokey-grey);--secondary-hover: var(--smokey-grey-dark);--bg-primary: #FFFFFF;--bg-secondary: #F5F5F5;--bg-dark: var(--smokey-grey);--bg-accent: #FFF5ED;--text-primary: #2C2C2C;--text-secondary: var(--smokey-grey);--text-light: #6B6B6B;--text-white: #FFFFFF;--border-color: #E0E0E0;--shadow-sm: 0 2px 4px rgba(88, 89, 91, .1);--shadow-md: 0 4px 8px rgba(88, 89, 91, .15);--shadow-lg: 0 8px 16px rgba(88, 89, 91, .2);--font-primary: "Segoe UI", "Helvetica Neue", Arial, sans-serif;--font-heading: "Segoe UI", "Helvetica Neue", Arial, sans-serif}.btn-primary{background:linear-gradient(135deg,var(--ut-orange) 0%,var(--ut-orange-dark) 100%);color:var(--text-white);border:none;box-shadow:var(--shadow-md);transition:all .3s ease}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--ut-orange-dark) 0%,#CC5C00 100%);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-primary:disabled{background:var(--smokey-grey-light);cursor:not-allowed;opacity:.6}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);transition:all .3s ease}.btn-secondary:hover:not(:disabled){background:var(--smokey-grey);color:var(--text-white);border-color:var(--smokey-grey);transform:translateY(-1px)}.top-banner{background:linear-gradient(135deg,var(--smokey-grey) 0%,var(--smokey-grey-dark) 100%);box-shadow:var(--shadow-md)}.top-banner h1{color:var(--text-white);font-family:var(--font-heading);font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.2)}.top-banner p{color:#ffffffe6}.side-panel{background:var(--bg-primary);border-right:3px solid var(--ut-orange);box-shadow:var(--shadow-md)}.side-panel button{color:var(--text-primary);transition:all .3s ease}.side-panel button:hover{background:var(--bg-accent);color:var(--ut-orange);border-left:4px solid var(--ut-orange)}.side-panel button.active{background:var(--ut-orange);color:var(--text-white);font-weight:600}.form-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-sm)}.form-section h2{color:var(--ut-orange);font-family:var(--font-heading);border-bottom:3px solid var(--ut-orange);padding-bottom:12px}.form-section h3{color:var(--smokey-grey);font-weight:600}input[type=text],input[type=number],input[type=email],input[type=password],textarea,select{border:2px solid var(--border-color);transition:all .3s ease}input[type=text]:focus,input[type=number]:focus,input[type=email]:focus,input[type=password]:focus,textarea:focus,select:focus{border-color:var(--ut-orange);outline:none;box-shadow:0 0 0 3px #ff82001a}input[type=checkbox]:checked{background-color:var(--ut-orange);border-color:var(--ut-orange)}.optimization-progress{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:15px}.optimization-progress>div:first-child{color:var(--text-secondary);font-weight:500}.best-config{background:linear-gradient(135deg,var(--bg-accent) 0%,#FFFFFF 100%);border:2px solid var(--ut-orange);border-radius:8px;padding:20px;box-shadow:var(--shadow-md)}.config-card{background:var(--bg-primary);border-radius:6px;padding:15px;box-shadow:var(--shadow-sm)}.config-label{color:var(--text-secondary);font-weight:600}.config-value{color:var(--ut-orange);font-weight:700;font-size:1.1em}table{border-collapse:collapse;box-shadow:var(--shadow-sm)}thead{background:linear-gradient(135deg,var(--smokey-grey) 0%,var(--smokey-grey-dark) 100%);color:var(--text-white)}thead th{font-weight:600;text-transform:uppercase;letter-spacing:.5px}tbody tr:hover{background:var(--bg-accent)}tbody tr:nth-child(2n){background:var(--bg-secondary)}.success-banner{background:linear-gradient(135deg,#4caf50,#45a049);color:var(--text-white);box-shadow:var(--shadow-lg)}.error-message{background:linear-gradient(135deg,#f44336,#d32f2f);color:var(--text-white);box-shadow:var(--shadow-md)}.required{color:var(--ut-orange)}.field-hint{color:var(--text-light);font-style:italic}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--smokey-grey-light);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--ut-orange)}@media (max-width: 768px){.top-banner h1{font-size:1.5rem}.form-section{margin:10px}}.theme-utk{--primary-color: #FF8200;--primary-hover: #E67300;--primary-light: #FFA040;--secondary-color: #58595B;--secondary-hover: #404142;--secondary-light: #808285;--accent-color: #00746F;--accent-hover: #005A56;--background: #FFFFFF;--surface: #F8F9FA;--surface-hover: #E9ECEF;--text-primary: #2C3E50;--text-secondary: #58595B;--text-muted: #808285;--text-inverse: #FFFFFF;--success: #28A745;--success-light: #D4EDDA;--warning: #FFC107;--warning-light: #FFF3CD;--error: #DC3545;--error-light: #F8D7DA;--info: #17A2B8;--info-light: #D1ECF1;--border-color: #DEE2E6;--border-hover: #ADB5BD;--shadow-sm: rgba(88, 89, 91, .075);--shadow-md: rgba(88, 89, 91, .15);--shadow-lg: rgba(88, 89, 91, .25);--gradient-primary: linear-gradient(135deg, #FF8200 0%, #E67300 100%);--gradient-secondary: linear-gradient(135deg, #58595B 0%, #404142 100%);--gradient-background: linear-gradient(135deg, #F8F9FA 0%, #E9ECEF 100%)}.theme-utk .btn-primary,.theme-utk button.btn-primary{background:var(--gradient-primary);color:var(--text-inverse);border:none}.theme-utk .btn-primary:hover,.theme-utk button.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #ff82004d}.theme-utk .btn-secondary,.theme-utk button.btn-secondary{background:var(--gradient-secondary);color:var(--text-inverse);border:none}.theme-utk .btn-secondary:hover,.theme-utk button.btn-secondary:hover{background:var(--secondary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #58595b4d}.theme-utk a{color:var(--primary-color)}.theme-utk a:hover{color:var(--primary-hover);text-decoration:underline}.theme-utk .card,.theme-utk .panel,.theme-utk .modal{background:var(--surface);border:1px solid var(--border-color);box-shadow:0 2px 8px var(--shadow-sm)}.theme-utk input,.theme-utk textarea,.theme-utk select{border:1px solid var(--border-color);background:var(--background);color:var(--text-primary)}.theme-utk input:focus,.theme-utk textarea:focus,.theme-utk select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #ff82001a;outline:none}.theme-utk .top-banner,.theme-utk .header{background:var(--gradient-primary);color:var(--text-inverse)}.theme-utk .side-panel{background:var(--surface);border-right:1px solid var(--border-color)}.theme-utk .side-panel-button{color:var(--text-secondary)}.theme-utk .side-panel-button:hover{background:var(--surface-hover);color:var(--primary-color)}.theme-utk .side-panel-button.active{background:var(--primary-light);color:var(--text-inverse)}.theme-utk .user-message .message-bubble{background:var(--gradient-primary);color:var(--text-inverse)}.theme-utk .assistant-message .message-bubble{background:var(--surface);color:var(--text-primary);border:1px solid var(--border-color)}.theme-utk .progress-bar-fill{background:var(--gradient-primary)}.theme-utk .badge{background:var(--primary-color);color:var(--text-inverse)}.theme-utk ::-webkit-scrollbar-thumb{background:var(--secondary-color)}.theme-utk ::-webkit-scrollbar-thumb:hover{background:var(--secondary-hover)}
