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;overflow-x:hidden}#root{min-height:100vh}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #000000;--primary-light: #000000;--secondary: #c53030;--accent: #2b6cb0;--light: #f7fafc;--dark: #2d3748;--gray: #e2e8f0;--gray-dark: #a0aec0;--success: #48bb78;--warning: #ed8936;--shadow: 0 4px 6px rgba(0, 0, 0, .1);--gradient: linear-gradient(135deg, #7c6531 0%, #9d8a5d 100%);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--radius: 8px;--transition: all .3s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#fff;min-height:100vh;color:var(--dark)}.app{min-height:100vh}.header{background:#010101f2;color:#7c6531;font-size:1.8rem;font-weight:700;padding:1.5rem 2rem;box-shadow:var(--shadow)}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.header-logo{width:80px;height:80px;object-fit:contain}.university-info{display:flex;align-items:center;gap:1rem}.university-logo{background:#fff;color:var(--primary);padding:.5rem;border-radius:50%}.university-info h1{font-size:1.5rem;font-weight:700;color:var(--gradient)}.university-subtitle{color:#cbd5e0;font-size:.9rem}.methodology-info{text-align:right}.methodology-tag{display:inline-block;background:var(--secondary);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;margin-bottom:.5rem}.methodology-desc{color:#cbd5e0;font-size:.85rem;max-width:300px}.main-container{max-width:1400px;margin:0 auto;padding:2rem;display:flex;gap:2rem;position:relative}.content{flex:1}.status-section{margin-bottom:2rem}.status-card{background:#fff;padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow)}.status-card.connected{border-left:4px solid var(--success)}.status-card.configured{border-left:4px solid var(--warning)}.status-card.not-configured{border-left:4px solid #e53e3e}.status-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray)}.status-card.connected .status-header{color:var(--success)}.status-card.configured .status-header{color:var(--warning)}.status-card.not-configured .status-header{color:#e53e3e}.connected-icon{color:var(--success)}.status-content{line-height:1.6}.status-details{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--gray)}.status-item{display:flex;flex-direction:column;gap:.25rem}.status-label{font-size:.9rem;color:var(--gray-dark)}.status-value{font-weight:600;font-size:.95rem}.status-value.configured{color:var(--success)}.status-value.not-configured{color:#e53e3e}.status-value.connected{color:var(--success)}.status-value.disconnected{color:#e53e3e}.config-instructions{margin-top:1rem;padding:1rem;background:#f7fafc;border-radius:var(--radius);border:1px solid var(--gray)}.config-instructions h4{color:var(--dark);margin-bottom:.5rem}.config-instructions p{color:var(--gray-dark);margin-bottom:.5rem}.config-instructions ol{padding-left:1.5rem;color:var(--dark)}.config-instructions li{margin-bottom:.25rem;font-size:.9rem}.config-instructions code{background:#e2e8f0;padding:.125rem .25rem;border-radius:4px;font-family:monospace;font-size:.85rem}.retry-btn{background:var(--accent);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer;font-size:.9rem;margin-top:1rem;transition:var(--transition)}.retry-btn:hover:not(:disabled){background:#2c5282}.retry-btn:disabled{opacity:.6;cursor:not-allowed}.generator-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media(max-width:1200px){.generator-container{grid-template-columns:1fr}}.form-section{background:#fff;padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid #000000}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--gray)}.section-header h2{color:var(--primary);font-size:1.5rem}.methodology-badge{background:var(--accent);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;margin-left:auto}.prompt-form{display:flex;flex-direction:column;gap:1.5rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-control{width:100%;padding:.75rem;border:2px solid var(--gray);border-radius:var(--radius);font-size:.95rem;background-color:#fff;color:var(--dark);transition:var(--transition);appearance:none;background-repeat:no-repeat;background-position:right .75rem center;background-size:16px 12px;position:relative}.large-select{font-size:1.1rem;padding:12px;border-radius:8px;border:2px solid #e2e8f0;transition:border-color .3s}.large-select:focus{border-color:#4f46e5;outline:none;box-shadow:0 0 0 3px #4f46e51a}.field-description{display:block;font-size:.9rem;color:#64748b;margin-top:4px;font-weight:400}.form-group label{font-weight:600;color:var(--dark);font-size:.95rem}.form-select{width:100%;padding:.75rem;border:2px solid var(--gray);border-radius:var(--radius);font-size:.95rem;background-color:#fff;color:var(--dark);transition:var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%232d3748' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:16px 12px;position:relative}.form-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2b6cb01a}.form-select:disabled{background-color:var(--gray);cursor:not-allowed}.api-warning-banner{background:#fffaf0;border:1px solid #feebc8;border-radius:var(--radius);padding:1rem;margin-bottom:1.5rem;display:flex;align-items:flex-start;gap:.75rem}.api-warning-banner svg{color:#dd6b20;flex-shrink:0;margin-top:.125rem}.api-warning-banner div{color:#744210;line-height:1.5}.form-actions{display:flex;flex-direction:column;gap:.75rem;align-items:center;margin-top:1.5rem}.submit-btn{display:flex;align-items:center;gap:.5rem;background:#a78842;color:#fff;border:none;padding:.75rem 2rem;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.form-note{color:var(--gray-dark);font-size:.85rem;text-align:center;max-width:500px}.result-section{background:#fff;padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;border:1px solid #000000}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--gray)}.result-header h2{color:var(--primary);font-size:1.5rem}.result-actions{display:flex;gap:.75rem}.history-btn,.copy-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius);font-weight:500;cursor:pointer;transition:var(--transition);border:2px solid transparent}.history-btn{background:var(--gray);color:var(--dark);border:2px solid var(--gray)}.history-btn:hover{background:var(--gray-dark);border-color:var(--gray-dark)}.copy-btn{background:#a78842;color:#fff}.copy-btn:hover:not(:disabled){background:#38a169}.copy-btn:disabled{opacity:.6;cursor:not-allowed}.copy-btn.small{padding:.25rem .75rem;font-size:.85rem;display:flex;align-items:center;gap:.25rem}.prompt-display{flex:1;background:#f8f9fa;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray);min-height:300px}.prompt-display.empty{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:3rem;text-align:center;color:var(--gray-dark)}.empty-icon{color:var(--gray);margin-bottom:1rem}.prompt-content{height:100%;overflow-y:auto;padding:1.5rem}.prompt-content pre{white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,Courier,monospace;font-size:.9rem;line-height:1.5;color:var(--dark);margin:0}.action-buttons{margin-top:1.5rem;display:flex;justify-content:flex-end}.competency-badge{display:inline-flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,var(--accent) 0%,#2c5282 100%);color:#fff;padding:.5rem 1rem;border-radius:9999px;font-size:.9rem;font-weight:500;box-shadow:0 2px 4px #0000001a;transition:var(--transition);animation:fadeIn .3s ease-out}.generate-btn{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--secondary) 0%,#e53e3e 100%);color:#fff;border:none;padding:.75rem 2rem;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.generate-btn.disabled{background:#a0aec0;cursor:not-allowed}.generate-btn.disabled:hover{transform:none;box-shadow:none}.spinner{width:24px;height:24px;border:3px solid var(--gray);border-top:3px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}.spinner.small{width:16px;height:16px;border-width:2px}.deepseek-response{margin-top:2rem;background:#f0fff4;border:1px solid #c6f6d5;border-radius:var(--radius);overflow:hidden}.response-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#c6f6d5;color:#22543d}.response-header h3{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;margin:0}.response-content{padding:1.5rem;max-height:400px;overflow-y:auto}.response-content pre{white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,Courier,monospace;font-size:.9rem;line-height:1.5;color:var(--dark);margin:0}.demo-notice{background:#fffaf0;border:1px solid #feebc8;border-radius:var(--radius);padding:1rem;text-align:center;margin-top:1rem}.demo-notice p{color:#744210;margin:0;font-size:.9rem}.history-sidebar{position:absolute;right:0;top:0;width:400px;height:calc(100vh - 2rem);background:#fff;box-shadow:var(--shadow-lg);border-radius:var(--radius);z-index:1000;display:flex;flex-direction:column;transform:translate(0);transition:transform .3s ease}@media(max-width:768px){.history-sidebar{width:100%}}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:var(--primary);color:#fff;border-radius:var(--radius) var(--radius) 0 0}.sidebar-header h3{display:flex;align-items:center;gap:.5rem;font-size:1.25rem}.close-btn{background:none;border:none;color:#fff;cursor:pointer;padding:.25rem;border-radius:4px;transition:var(--transition)}.competency-badge svg{color:#fffc;transition:color .2s;margin-left:4px}.competencies-dropdown{position:absolute;z-index:1000;width:100%;max-height:250px;overflow-y:auto;background-color:#fff;border:1px solid var(--gray);border-radius:var(--radius);box-shadow:var(--shadow-lg);margin-top:.5rem;padding:.5rem;animation:fadeIn .2s ease-out}.competency-option{display:flex;align-items:center;padding:.6rem .8rem;border-radius:var(--radius);cursor:pointer;transition:var(--transition);margin-bottom:2px}.competency-option:hover{background-color:#f7fafc}.competency-option .form-check-input{margin-top:0;margin-right:.75rem;cursor:pointer;width:1.1em;height:1.1em}.competency-option label{cursor:pointer;width:100%;font-weight:400;margin-bottom:0;color:var(--dark)}.close-btn:hover{background:#ffffff1a}.sidebar-content{flex:1;overflow-y:auto;padding:1.25rem}.empty-history{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:var(--gray-dark);text-align:center}.history-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray)}.clear-history-btn{display:flex;align-items:center;gap:.5rem;background:var(--gray);border:none;padding:.5rem 1rem;border-radius:var(--radius);font-size:.9rem;cursor:pointer;transition:var(--transition)}.clear-history-btn:hover{background:var(--gray-dark)}.history-count{font-size:.9rem;color:var(--gray-dark)}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{background:var(--light);border:1px solid var(--gray);border-radius:var(--radius);padding:1rem;cursor:pointer;transition:var(--transition)}.history-item:hover{border-color:var(--accent);transform:translate(-4px)}.history-item.active{border-color:var(--accent);background:#e6f7ff}.history-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.history-item-header h4{font-size:.95rem;color:var(--primary);flex:1}.delete-item-btn{background:none;border:none;color:var(--gray-dark);cursor:pointer;padding:.25rem;border-radius:4px;transition:var(--transition)}.delete-item-btn:hover{color:var(--secondary);background:#fed7d7}.history-item-meta{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--gray-dark);margin-bottom:.5rem}.history-item-meta span{display:flex;align-items:center;gap:.25rem}.item-status{font-size:.75rem;padding:.125rem .5rem;border-radius:12px}.item-status.responded{background:#c6f6d5;color:#22543d}.item-status.pending{background:#fed7d7;color:#742a2a}.item-program{background:var(--accent);color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.7rem}.history-item-preview{font-size:.85rem;color:var(--dark);display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.metodologia-section{background:#f8fafc;border:1px solid var(--gray);border-radius:var(--radius);padding:1.5rem;margin-bottom:1rem}.metodologia-section h4{color:var(--primary);margin-bottom:.5rem;font-size:1.1rem}.section-description{color:var(--gray-dark);font-size:.9rem;margin-bottom:1.5rem}.metodologia-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.metodologia-grid .form-group{margin:0}.metodologia-grid .form-group label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--dark)}.seccion-seleccionada{background:#fff;border:1px solid var(--accent);border-radius:var(--radius);padding:1rem;margin-top:1rem}.seccion-seleccionada strong{color:var(--primary);display:block;margin-bottom:.5rem;font-size:.9rem}.seccion-text{color:var(--dark);font-size:1rem;font-weight:500;display:block;padding:.5rem;background:#e6f7ff;border-radius:var(--radius);border-left:4px solid var(--accent)}.form-group.full-width{grid-column:1 / -1}.metodologia-grid .form-group:nth-child(1) .form-select{border-left:4px solid var(--primary)}.metodologia-grid .form-group:nth-child(2) .form-select{border-left:4px solid var(--accent)}.metodologia-grid .form-group:nth-child(3) .form-select{border-left:4px solid var(--success)}.metodologia-grid .form-group:nth-child(4) .form-select{border-left:4px solid var(--warning)}.metodologia-grid .form-group:nth-child(5) .form-select{border-left:4px solid #9f7aea}.metodologia-grid .form-group:nth-child(6) .form-select{border-left:4px solid #ed64a6}.metodologia-grid .form-group:nth-child(7) .form-select{border-left:4px solid #38b2ac}.metodologia-grid .form-group:nth-child(8) .form-select{border-left:4px solid #ecc94b}.tabs-container{margin-bottom:1.5rem}.tabs{display:flex;background:var(--color-surface);border-radius:8px;padding:4px;border:1px solid var(--color-border)}.tab-btn{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:6px;font-size:.95rem;font-weight:500;color:#000;cursor:pointer;transition:all .2s ease;text-align:center}.tab-btn:hover{background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary)}.tab-btn.active{background:var(--color-primary);color:#8d743a;box-shadow:0 2px 4px #0000001a;font-weight:700}.tab-btn:focus{outline:none;box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.3)}.form-select option.current-selection{font-weight:700;color:var(--color-primary);background:rgba(var(--color-primary-rgb),.2)}.programa-warning{margin-top:.5rem;padding:.5rem;background:rgba(var(--color-warning-rgb),.1);border-radius:4px;border-left:3px solid var(--color-warning)}.programa-warning small{color:var(--color-warning);font-size:.85rem}.btn-dropdown{text-align:left}.div-dropdown{position:"absolute";Height:"300px";background-color:"white"}
