*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;color:#333;line-height:1.5}.container{max-width:1200px;margin:0 auto;padding:0 20px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}a{color:inherit;text-decoration:none}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:18px;color:#666}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.manual-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;z-index:4000;display:flex;align-items:center;justify-content:center;padding:24px}.manual-modal{width:min(1050px,100%);max-height:90vh;background:#fff;border-radius:14px;box-shadow:0 24px 80px #0f172a59;overflow:hidden;display:flex;flex-direction:column}.manual-modal-header{padding:16px 20px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;background:#f8fafc}.manual-modal-header h2{margin:0;font-size:20px;color:#1e3a8a}.manual-close-btn{width:34px;height:34px;border:none;border-radius:8px;cursor:pointer;background:#e2e8f0;color:#1e293b;font-size:24px;line-height:1}.manual-close-btn:hover{background:#cbd5e1}.manual-modal-body{padding:20px;overflow:auto;display:grid;gap:18px}.manual-section{border:1px solid #e2e8f0;border-radius:12px;padding:16px;background:#fff}.manual-section h3{margin:0 0 8px;color:#1d4ed8;font-size:18px}.manual-section p,.manual-section li{color:#334155}.manual-section ol{margin:10px 0 0;padding-left:18px}.manual-image{width:100%;margin-top:12px;border-radius:10px;border:1px solid #dbeafe}.manual-image-compact{width:72%;display:block;margin-left:auto;margin-right:auto}@media (max-width: 768px){.manual-modal-overlay{padding:10px}.manual-modal{max-height:95vh}.manual-modal-body{padding:14px}.manual-image-compact{width:100%}}.main-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 0}.header-content{display:flex;justify-content:space-between;align-items:center}.logo-section{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}.logo-icon{font-size:32px}.logo-text h1{margin:0;font-size:20px;font-weight:700}.logo-subtext{margin:0;font-size:13px;opacity:.8}.user-section{display:flex;align-items:center;gap:16px}.user-welcome{display:flex;flex-direction:column;text-align:right}.welcome-text{font-size:12px;opacity:.85}.user-name{font-weight:600;font-size:15px}.dropdown{position:relative}.header-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff26;border:none;border-radius:8px;color:#fff;cursor:pointer;transition:background-color .2s;font-size:14px}.header-btn:hover{background:#ffffff40}.user-avatar-circle{width:36px;height:36px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.chevron{font-size:10px;opacity:.8}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;min-width:240px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s;z-index:1000;overflow:hidden}.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-header{padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.dropdown-user-info{display:flex;flex-direction:column;gap:4px}.dropdown-user-info strong{font-size:15px}.dropdown-user-info small{font-size:12px;opacity:.9}.role-badge{display:inline-block;background:#fff3;padding:2px 10px;border-radius:12px;font-size:11px;text-transform:capitalize;margin-top:4px;width:fit-content}.dropdown-item{display:flex;align-items:center;gap:10px;padding:12px 16px;color:#333;text-decoration:none;font-size:14px;cursor:pointer;background:none;border:none;width:100%;text-align:left;transition:background-color .2s}.dropdown-item:hover{background:#f5f7fa}.dropdown-item.logout-item{color:#e53e3e}.dropdown-item.logout-item:hover{background:#fff5f5}.dropdown-divider{height:1px;background:#e5e7eb;margin:4px 0}.main-nav{background:#fff;box-shadow:0 2px 4px #0000000d}.main-nav .container{display:flex;gap:4px}.nav-link{padding:16px 20px;color:#666;text-decoration:none;font-weight:500;font-size:15px;transition:color .2s,background-color .2s;border-bottom:3px solid transparent}.nav-link:hover{color:#667eea;background:#f8faff}.nav-link.active{color:#667eea;border-bottom-color:#667eea}.main-content{flex:1;padding:24px 0}.app-footer{background:#1a1a2e;color:#fff;padding:24px 0;margin-top:auto}.footer-content{display:flex;justify-content:space-between;align-items:center}.footer-left h5{margin:0 0 4px;font-size:16px}.footer-left p,.footer-right p{margin:0;font-size:14px;opacity:.7}@media (max-width: 768px){.header-content{flex-direction:column;gap:16px}.logo-section{justify-content:center}.user-section{width:100%;justify-content:center}.user-welcome{display:none}.main-nav .container{justify-content:center}.footer-content{flex-direction:column;text-align:center;gap:16px}}.auth-layout{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.home-page{min-height:100vh;color:#fff}.home-header{padding:4rem 2rem;text-align:center}.home-title{font-size:3rem;margin-bottom:1rem}.home-subtitle{font-size:1.25rem;margin-bottom:2rem;opacity:.9}.home-actions{margin-top:2rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;padding:4rem 2rem}.feature-card{background:#fff;color:#333;padding:2rem;border-radius:.5rem;text-align:center;box-shadow:0 4px 6px #0000001a}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{margin:1rem 0;color:#667eea}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0003}.login-header{text-align:center;margin-bottom:32px}.logo{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:8px}.logo-icon{font-size:48px}.logo h1{margin:0;color:#1a1a2e;font-size:24px;font-weight:700}.subtitle{color:#666;margin:0;font-size:15px}.login-form{margin-bottom:24px}.alert{padding:14px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px;font-size:14px}.alert-info{background-color:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.form-group{margin-bottom:20px}.form-group input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.btn-block{width:100%;padding:14px 24px;font-size:16px;font-weight:600}.forgot-password-link{margin-top:12px;text-align:center}.forgot-password-link a{color:#667eea;font-size:14px;text-decoration:none}.forgot-password-link a:hover{text-decoration:underline}.login-footer{text-align:center}.demo-credentials{background:#f8fafc;border-radius:8px;padding:16px;margin-bottom:20px}.demo-credentials p{margin:0 0 8px;font-size:14px;color:#555}.demo-credentials p:last-child{margin-bottom:0}.demo-credentials strong{color:#1a1a2e;font-size:13px}.register-link{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.register-link p{margin:0;color:#666;font-size:14px}.register-link a{color:#667eea;font-weight:600;text-decoration:none}.register-link a:hover{text-decoration:underline}.links{margin-top:16px}.links a{color:#667eea;text-decoration:none;font-size:14px}.links a:hover{text-decoration:underline}@media (max-width: 480px){.login-container{padding:24px}.logo h1{font-size:20px}}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.register-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:500px}.register-header{text-align:center;margin-bottom:32px}.register-logo{width:80px;height:80px;margin-bottom:16px}.register-header h1{font-size:1.8rem;color:#1a1a2e;margin:0 0 8px}.register-header p{color:#666;margin:0;font-size:.95rem}.register-form{display:flex;flex-direction:column;gap:20px}.form-group input:disabled{background:#f7fafc;cursor:not-allowed}.password-strength{margin-top:8px}.strength-bar{height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden;margin-bottom:4px}.strength-fill{height:100%;transition:width .3s ease,background .3s ease;border-radius:2px}.password-strength.weak .strength-fill{background:#e53e3e}.password-strength.medium .strength-fill{background:#dd6b20}.password-strength.good .strength-fill{background:#38a169}.password-strength.strong .strength-fill{background:#2f855a}.strength-text{font-size:.75rem;color:#666}.password-strength.weak .strength-text{color:#e53e3e}.password-strength.medium .strength-text{color:#dd6b20}.password-strength.good .strength-text{color:#38a169}.password-strength.strong .strength-text{color:#2f855a}.field-error{font-size:.8rem;color:#e53e3e;margin-top:4px}.field-success{font-size:.8rem;color:#38a169;margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.register-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0}.register-footer p{color:#666;margin:0}.register-footer a{color:#667eea;text-decoration:none;font-weight:500}.register-footer a:hover{text-decoration:underline}@media (max-width: 576px){.register-container{padding:24px}.register-header h1{font-size:1.5rem}.form-row{grid-template-columns:1fr}}.confirmar-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.confirmar-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:60px 40px;width:100%;max-width:450px;text-align:center}.confirmar-loading{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner-large{width:60px;height:60px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.confirmar-loading h2{margin:0;color:#1a1a2e;font-size:1.5rem}.confirmar-loading p{margin:0;color:#666}.confirmar-success{display:flex;flex-direction:column;align-items:center;gap:16px}.icon-success{width:80px;height:80px;background:linear-gradient(135deg,#38a169,#2f855a);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;color:#fff;animation:scaleIn .5s ease}@keyframes scaleIn{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.confirmar-success h2{margin:0;color:#276749;font-size:1.8rem}.confirmar-success p{margin:0;color:#666;font-size:1.1rem}.confirmar-error{display:flex;flex-direction:column;align-items:center;gap:16px}.icon-error{width:80px;height:80px;background:linear-gradient(135deg,#e53e3e,#c53030);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;color:#fff;animation:scaleIn .5s ease}.confirmar-error h2{margin:0;color:#c53030;font-size:1.8rem}.confirmar-error p{margin:0;color:#666;font-size:1.1rem}.error-actions{display:flex;gap:12px;margin-top:8px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media (max-width: 480px){.confirmar-container{padding:40px 24px}.error-actions{flex-direction:column;width:100%}.error-actions .btn{width:100%}}.olvidar-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.olvidar-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:440px}.olvidar-header{text-align:center;margin-bottom:24px}.olvidar-header h1{font-size:1.5rem;color:#1a1a2e;margin:0 0 8px}.olvidar-header p{color:#666;margin:0;font-size:.95rem}.alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.olvidar-form .form-group{margin-bottom:20px}.olvidar-form label{display:block;font-weight:500;color:#333;margin-bottom:8px;font-size:.95rem}.olvidar-form input{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;box-sizing:border-box}.olvidar-form input:focus{outline:none;border-color:#667eea}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s}.btn-secondary{background:#e2e8f0;color:#1e293b;margin-top:10px}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.btn-block{width:100%}.olvidar-success{text-align:center;padding:20px 0}.olvidar-success .icon-success{width:64px;height:64px;background:linear-gradient(135deg,#38a169,#2f855a);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;margin:0 auto 16px}.olvidar-success h2{margin:0 0 12px;color:#276749;font-size:1.3rem}.olvidar-success p{margin:0 0 12px;color:#555;font-size:.95rem}.olvidar-success .small{font-size:.85rem;color:#888}.olvidar-success .btn{margin-top:16px}.olvidar-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.olvidar-footer a{color:#667eea;text-decoration:none;font-weight:500}.olvidar-footer a:hover{text-decoration:underline}.restablecer-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.restablecer-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:440px}.restablecer-header{text-align:center;margin-bottom:24px}.restablecer-header h1{font-size:1.5rem;color:#1a1a2e;margin:0 0 8px}.restablecer-header p{color:#666;margin:0;font-size:.95rem}.alert{padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px;font-size:.9rem}.restablecer-form .form-group{margin-bottom:20px}.restablecer-form label{display:block;font-weight:500;color:#333;margin-bottom:8px;font-size:.95rem}.restablecer-form input{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;box-sizing:border-box}.restablecer-form input:focus{outline:none;border-color:#667eea}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;margin-top:8px}.btn-secondary{background:#e2e8f0;color:#4a5568;margin-left:12px}.btn-secondary:hover{background:#cbd5e0}.btn-block{width:100%;margin-top:8px}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.restablecer-loading,.restablecer-error,.restablecer-success{text-align:center;padding:24px 0}.restablecer-loading .spinner-large{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.restablecer-error .icon-error,.restablecer-success .icon-success{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;margin:0 auto 16px}.restablecer-error .icon-error{background:linear-gradient(135deg,#e53e3e,#c53030)}.restablecer-success .icon-success{background:linear-gradient(135deg,#38a169,#2f855a)}.restablecer-error h2,.restablecer-success h2{margin:0 0 12px;font-size:1.3rem}.restablecer-error h2{color:#c53030}.restablecer-success h2{color:#276749}.restablecer-error p,.restablecer-success p{margin:0 0 20px;color:#555;font-size:.95rem}.restablecer-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.restablecer-footer a{color:#667eea;text-decoration:none;font-weight:500}.restablecer-footer a:hover{text-decoration:underline}.dashboard-page{padding:20px 0}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.dashboard-header h1{margin:0;color:#1a1a2e;font-size:28px}.dashboard-header .welcome-text{margin:4px 0 0;font-size:1rem;color:#667eea;font-weight:500}.dashboard-header .welcome-user-name{margin:4px 0 0;font-size:1.1rem;font-weight:600;color:#1a1a2e}.dashboard-header-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.btn-outline-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border:2px solid #667eea;color:#667eea;background:transparent;border-radius:8px;font-size:15px;font-weight:600;text-decoration:none;transition:background .2s,color .2s}.btn-outline-primary:hover{background:#667eea;color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #00000014;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.stat-card-cneb{text-decoration:none;color:inherit;cursor:pointer;border:2px solid #e0e7ff;background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.stat-card-cneb:hover{border-color:#667eea;box-shadow:0 4px 16px #667eea33}.stat-card-cneb .stat-info small{font-size:12px;color:#64748b;text-transform:none;letter-spacing:0;margin-top:4px}.stat-arrow{margin-left:auto;font-size:20px;color:#667eea}.stat-icon{font-size:40px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:32px;font-weight:700;color:#1a1a2e}.stat-label{font-size:14px;color:#666;text-transform:uppercase;letter-spacing:.5px}.aulas-section h2{margin-bottom:20px;color:#1a1a2e;font-size:22px}.empty-state{background:#fff;border-radius:12px;padding:60px 40px;text-align:center;box-shadow:0 2px 8px #00000014}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{margin:0 0 10px;color:#1a1a2e;font-size:20px}.empty-state p{color:#666;margin-bottom:24px;max-width:400px;margin-left:auto;margin-right:auto}.aulas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.aula-card{background:#fff;border-radius:12px;padding:20px;text-decoration:none;color:inherit;box-shadow:0 2px 8px #00000014;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.aula-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.aula-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.aula-header h3{margin:0;color:#1a1a2e;font-size:18px;font-weight:600}.badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.aula-info{flex:1}.aula-info p{margin:0 0 8px;color:#555;font-size:14px}.aula-info strong{color:#333}.aula-footer{margin-top:16px;padding-top:16px;border-top:1px solid #eee}.aula-footer small{color:#888;font-size:12px}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:16px}.stats-grid,.aulas-grid{grid-template-columns:1fr}}.crear-aula-page{padding:20px 0;max-width:700px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{margin:0;color:#1a1a2e;font-size:28px}.alert{padding:16px 20px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.aula-form{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #00000014}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.form-group input[type=text],.form-group select{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s;background-color:#fff}.form-group input[type=text]:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.form-group input:disabled,.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-hint{display:block;margin-top:6px;color:#666;font-size:13px}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;padding:16px;background:#f8fafc;border-radius:8px;border:2px solid #e5e7eb}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 12px;background:#fff;border-radius:6px;transition:background-color .2s}.checkbox-label:hover{background:#f0f4ff}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#667eea;cursor:pointer}.checkbox-text{display:flex;flex-direction:column;font-size:14px;color:#333}.ciclo-badge{font-size:11px;color:#666;margin-top:2px}.loading-grados,.no-grados{padding:16px;background:#f8fafc;border-radius:8px;color:#666;font-size:14px;margin:0}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}@media (max-width: 768px){.crear-aula-page{padding:10px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.aula-form{padding:20px}.checkbox-group{grid-template-columns:1fr 1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.ver-aula-page{padding:20px 0}.not-found{text-align:center;padding:60px 40px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.not-found h2{color:#1a1a2e;margin-bottom:10px}.not-found p{color:#666;margin-bottom:24px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;flex-wrap:wrap;gap:16px}.header-info{display:flex;flex-direction:column;gap:8px}.back-link{color:#667eea;text-decoration:none;font-size:14px;display:inline-flex;align-items:center;gap:4px}.header-info h1{margin:0;color:#1a1a2e;font-size:28px}.aula-details{display:grid;grid-template-columns:1fr auto;gap:20px;margin-bottom:40px}.detail-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.detail-card h3{margin:0 0 20px;color:#1a1a2e;font-size:18px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:12px;color:#666;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:16px;color:#1a1a2e;font-weight:500}.stats-mini{display:flex;flex-direction:column;gap:12px}.stat-mini{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px;border-radius:12px;text-align:center;min-width:140px}.stat-number{display:block;font-size:36px;font-weight:700}.stat-text{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.experiencias-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{margin:0;color:#1a1a2e;font-size:20px}.empty-state{text-align:center;padding:40px 20px}.empty-state h3{margin:0 0 8px;color:#1a1a2e;font-size:18px}.empty-state p{color:#666;margin-bottom:20px}.experiencias-list{display:flex;flex-direction:column;gap:16px}.experiencia-card{border:1px solid #e5e7eb;border-radius:10px;padding:20px;transition:border-color .2s,box-shadow .2s}.experiencia-card:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea26}.experiencia-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.experiencia-header h3{margin:0;color:#1a1a2e;font-size:16px;font-weight:600}.experiencia-actions{display:flex;gap:8px}.btn-icon{background:#f1f5f9;border:none;cursor:pointer;padding:6px 10px;border-radius:8px;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background-color:#e2e8f0;transform:translateY(-1px)}.btn-icon.btn-view{background:#dbeafe}.btn-icon.btn-view:hover{background:#bfdbfe}.btn-icon.btn-primary{background:#eef2ff}.btn-icon.btn-primary:hover{background:#e0e7ff}.experiencia-descripcion{color:#555;font-size:14px;line-height:1.5;margin:0 0 12px}.experiencia-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px}.meta-item{font-size:13px;color:#666;display:flex;align-items:center;gap:4px}.experiencia-areas{display:flex;gap:8px;flex-wrap:wrap}.area-badge{background:#f0f4ff;color:#667eea;padding:4px 10px;border-radius:16px;font-size:12px;font-weight:500}@media (max-width: 768px){.page-header{flex-direction:column}.header-actions{width:100%}.header-actions .btn{flex:1}.aula-details{grid-template-columns:1fr}.stats-mini{flex-direction:row;justify-content:center}.stat-mini{flex:1;min-width:auto}}.ver-experiencia-page{max-width:1200px;margin:0 auto;padding:20px}.loading-state,.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}.page-header{margin-bottom:32px}.header-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:14px}.header-breadcrumb a{color:#6366f1;text-decoration:none}.header-breadcrumb a:hover{text-decoration:underline}.header-breadcrumb span{color:#94a3b8}.header-breadcrumb .current{color:#1e293b;font-weight:500}.header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap}.header-info h1{margin:0 0 12px;color:#1e293b;font-size:28px;font-weight:700;line-height:1.3}.header-badges{display:flex;gap:12px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:500}.badge.nivel{background:#eef2ff;color:#6366f1}.badge.fecha{background:#f0fdf4;color:#16a34a}.header-actions{display:flex;gap:12px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn-primary{background:#6366f1;color:#fff}.btn-primary:hover{background:#4f46e5;transform:translateY(-2px)}.btn-danger{background:#fee2e2;color:#dc2626}.btn-danger:hover{background:#fecaca}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px)}.btn-success:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.btn-info{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-info:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);transform:translateY(-2px)}.btn-sm{padding:8px 16px;font-size:13px}.btn-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#f1f5f9;border:none;cursor:pointer;text-decoration:none;transition:all .2s}.btn-icon:hover{background:#e2e8f0}.btn-icon.btn-danger{background:#fee2e2}.btn-icon.btn-danger:hover{background:#fecaca}.btn-icon.btn-instrumento{background:#ede9fe}.btn-icon.btn-instrumento:hover{background:#ddd6fe}.experiencia-info-section{margin-bottom:32px}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.info-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000f;border:1px solid #e2e8f0}.info-card.full-width{grid-column:1 / -1}.info-card h3{margin:0 0 16px;color:#374151;font-size:16px;font-weight:600}.info-card p{margin:0;color:#4b5563;font-size:14px;line-height:1.7;white-space:pre-wrap}.tags-list{display:flex;flex-wrap:wrap;gap:8px}.tag{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500}.tag.area{background:#dbeafe;color:#1d4ed8}.competencias-list{display:flex;flex-direction:column;gap:12px}.competencia-item{padding:12px 16px;background:#f8fafc;border-radius:10px;border-left:3px solid #6366f1}.comp-nombre{display:block;color:#1e293b;font-size:14px;font-weight:500}.comp-area{display:block;color:#64748b;font-size:12px;margin-top:4px}.actividades-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000f;border:1px solid #e2e8f0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.section-header h2{margin:0;color:#1e293b;font-size:20px;font-weight:700}.empty-actividades{text-align:center;padding:48px 24px}.empty-icon{font-size:48px;margin-bottom:16px}.empty-actividades h3{margin:0 0 8px;color:#374151}.empty-actividades p{color:#64748b;margin:0 0 24px}.actividades-list{display:flex;flex-direction:column;gap:16px}.instrumento-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1200;padding:16px}.instrumento-modal{width:min(920px,100%);max-height:90vh;overflow:hidden;background:#fff;border-radius:14px;box-shadow:0 15px 45px #02061740;display:flex;flex-direction:column}.instrumento-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid #e2e8f0}.instrumento-modal-header h3{margin:0;font-size:18px;color:#1f2937}.instrumento-modal-close{width:34px;height:34px;border:none;border-radius:8px;background:#f1f5f9;cursor:pointer;font-size:20px;color:#475569}.instrumento-modal-body{padding:16px 18px;overflow-y:auto}.instrumento-modal-help{margin-top:0;color:#475569}.instrumento-config-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}.instrumento-config-row label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#334155;font-weight:600}.instrumento-config-row select{border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px;font-size:14px}.instrumento-output{width:100%;border:1px solid #cbd5e1;border-radius:10px;padding:10px 12px;line-height:1.5;resize:vertical;box-sizing:border-box}.instrumento-output:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f124}.instrumento-error{margin-top:10px;padding:10px 12px;border-radius:9px;border:1px solid #fecaca;background:#fef2f2;color:#b91c1c;font-size:14px}.instrumento-modal-footer{border-top:1px solid #e2e8f0;padding:12px 18px;display:flex;justify-content:flex-end;gap:8px}.btn-word{background:linear-gradient(135deg,#0f4c81,#1d6fa5);color:#fff;border:none}.btn-word:hover:not(:disabled){filter:brightness(1.05)}.btn-word:disabled{opacity:.6;cursor:not-allowed}.actividad-card{display:flex;gap:16px;padding:20px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0;transition:all .2s}.actividad-card:hover{border-color:#6366f1;box-shadow:0 4px 12px #6366f11a}.actividad-number{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#6366f1;color:#fff;border-radius:50%;font-weight:700;font-size:16px;flex-shrink:0}.actividad-content{flex:1;min-width:0}.actividad-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.actividad-header h4{margin:0;color:#1e293b;font-size:16px;font-weight:600}.actividad-actions{display:flex;gap:8px}.actividad-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.meta-item{display:inline-flex;align-items:center;font-size:13px;color:#64748b}.meta-item.estrategia{color:#7c3aed;background:#f3e8ff;padding:4px 10px;border-radius:12px}.actividad-proposito{margin:0 0 12px;color:#4b5563;font-size:14px;line-height:1.5}.actividad-proposito strong{color:#374151}.momentos-resumen{display:flex;flex-wrap:wrap;gap:8px}.momento-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.momento-badge.inicio{background:#fef3c7;color:#92400e}.momento-badge.desarrollo{background:#dbeafe;color:#1e40af}.momento-badge.cierre{background:#d1fae5;color:#065f46}.secuencia-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1200;padding:16px}.secuencia-modal{width:min(920px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:14px;box-shadow:0 18px 40px #0f172a40}.secuencia-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid #e2e8f0}.secuencia-modal-header h3{margin:0;color:#1e293b}.secuencia-modal-close{border:none;background:transparent;font-size:24px;line-height:1;cursor:pointer;color:#64748b}.secuencia-modal-body{padding:16px 18px}.secuencia-help{margin:0 0 12px;color:#475569;font-size:14px}.secuencia-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px}.secuencia-competencia-item{border:1px solid #e2e8f0;border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:10px}.secuencia-competencia-main{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.secuencia-competencia-nombre{color:#1e293b;font-size:13px;line-height:1.35}.secuencia-cantidad{display:flex;align-items:center;gap:8px;color:#334155;font-size:12px}.secuencia-competencia-item input{width:72px;border:1px solid #cbd5e1;border-radius:8px;padding:6px 8px}.secuencia-duracion{display:flex;flex-direction:column;gap:4px;min-width:250px}.secuencia-duracion span{color:#334155;font-size:12px}.secuencia-duracion select{border:1px solid #cbd5e1;border-radius:8px;padding:7px 9px;background:#fff}.secuencia-dias{border-top:1px dashed #e2e8f0;padding-top:8px}.secuencia-dias-label{display:block;font-size:12px;color:#64748b;margin-bottom:6px}.secuencia-dias-chips{display:flex;flex-wrap:wrap;gap:6px}.dia-chip{border:1px solid #cbd5e1;background:#fff;color:#334155;border-radius:999px;padding:4px 9px;font-size:12px;cursor:pointer}.dia-chip.active{background:#6366f1;border-color:#6366f1;color:#fff}.secuencia-config-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}.secuencia-config-row label{display:flex;flex-direction:column;gap:6px;color:#334155;font-size:13px}.secuencia-config-row input[type=date],.secuencia-config-row input[type=number],.secuencia-config-row select{border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px}.secuencia-prompt-extra{margin-bottom:12px}.secuencia-prompt-extra label{display:flex;flex-direction:column;gap:6px;color:#334155;font-size:13px}.secuencia-prompt-extra textarea{width:100%;min-height:92px;border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px;line-height:1.45;font-size:14px;resize:vertical;box-sizing:border-box;font-family:inherit}.secuencia-prompt-extra textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.secuencia-check{flex-direction:row!important;align-items:center;gap:8px!important;margin-top:24px}.secuencia-total{margin:10px 0 12px;color:#334155}.secuencia-progress{border:1px solid #dbeafe;background:#eff6ff;border-radius:10px;padding:10px 12px;margin-bottom:12px}.secuencia-progress-top{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#1e3a8a;margin-bottom:8px}.secuencia-progress-bar{width:100%;height:10px;background:#dbeafe;border-radius:999px;overflow:hidden}.secuencia-progress-fill{height:100%;background:linear-gradient(90deg,#2563eb,#4f46e5);transition:width .4s ease}.secuencia-progress small{display:block;margin-top:8px;color:#1e40af}.secuencia-error{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;border-radius:10px;padding:10px 12px;margin-bottom:12px;font-size:13px}.secuencia-preview{margin-top:10px;border:1px solid #e2e8f0;border-radius:10px;padding:12px;max-height:280px;overflow:auto}.secuencia-preview h4{margin:0 0 10px;color:#1e293b}.secuencia-preview-item{border:1px solid #e2e8f0;border-radius:8px;padding:9px 10px;margin-bottom:8px;background:#f8fafc;animation:fadeInSlide .3s ease-out}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.secuencia-preview-loading{display:flex;align-items:center;gap:10px;padding:12px;background:#eff6ff;border:1px dashed #3b82f6;border-radius:8px;margin-top:8px;color:#1e40af;font-size:13px}.spinner-small{width:20px;height:20px;border:2px solid #dbeafe;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.secuencia-modal-footer{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid #e2e8f0;padding:12px 18px}@media (max-width: 768px){.ver-experiencia-page{padding:16px}.header-content{flex-direction:column}.header-actions{width:100%}.header-actions .btn{flex:1}.info-grid{grid-template-columns:1fr}.actividad-card{flex-direction:column;align-items:flex-start}.actividad-number{width:32px;height:32px;font-size:14px}.actividad-header,.momentos-resumen{flex-direction:column}.secuencia-grid,.secuencia-config-row{grid-template-columns:1fr}}.ver-actividad-page{max-width:1200px;margin:0 auto;padding:24px}.ver-actividad-page .loading-state,.ver-actividad-page .not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.ver-actividad-page .spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.ver-actividad-page .page-header{margin-bottom:32px}.ver-actividad-page .header-breadcrumb{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b7280;margin-bottom:16px;flex-wrap:wrap}.ver-actividad-page .header-breadcrumb a{color:#3b82f6;text-decoration:none}.ver-actividad-page .header-breadcrumb a:hover{text-decoration:underline}.ver-actividad-page .header-breadcrumb .current{color:#1f2937;font-weight:500}.ver-actividad-page .header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap}.ver-actividad-page .header-info h1{font-size:28px;font-weight:700;color:#1f2937;margin:0 0 12px}.ver-actividad-page .header-badges{display:flex;flex-wrap:wrap;gap:8px}.ver-actividad-page .badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.ver-actividad-page .badge.nivel{background:#dbeafe;color:#1e40af}.ver-actividad-page .badge.grado{background:#dcfce7;color:#166534}.ver-actividad-page .badge.ciclo{background:#fef3c7;color:#92400e}.ver-actividad-page .badge.fecha{background:#f3e8ff;color:#7c3aed}.ver-actividad-page .badge.duracion{background:#fce7f3;color:#be185d}.ver-actividad-page .header-actions{display:flex;gap:12px;flex-wrap:wrap}.ver-actividad-page .btn{padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;border:none;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.ver-actividad-page .btn-primary{background:#3b82f6;color:#fff}.ver-actividad-page .btn-primary:hover{background:#2563eb}.ver-actividad-page .btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.ver-actividad-page .btn-success:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px)}.ver-actividad-page .btn-success:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.ver-actividad-page .btn-danger{background:#ef4444;color:#fff}.ver-actividad-page .btn-danger:hover{background:#dc2626}.ver-actividad-page .btn-lg{padding:14px 32px;font-size:16px}.ver-actividad-page .actividad-info-section{margin-bottom:32px}.ver-actividad-page .info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.ver-actividad-page .info-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f;border:1px solid #e5e7eb}.ver-actividad-page .info-card.full-width{grid-column:1 / -1}.ver-actividad-page .info-card h3{font-size:14px;font-weight:600;color:#6b7280;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.ver-actividad-page .info-card p{margin:0;color:#1f2937;line-height:1.6}.ver-actividad-page .proposito-card{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6}.ver-actividad-page .hilo-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.ver-actividad-page .estrategia-badge{display:inline-block;background:#3b82f6;color:#fff;padding:8px 16px;border-radius:8px;font-weight:600}.ver-actividad-page .competencias-list{display:flex;flex-direction:column;gap:8px}.ver-actividad-page .competencia-item{background:#f3f4f6;padding:10px 14px;border-radius:8px;font-size:14px}.ver-actividad-page .momentos-section{margin-bottom:40px}.ver-actividad-page .momentos-section>h2{font-size:22px;font-weight:700;color:#1f2937;margin:0 0 24px}.ver-actividad-page .momento-card{background:#fff;border-radius:16px;margin-bottom:24px;overflow:hidden;box-shadow:0 4px 12px #00000014;border:2px solid transparent}.ver-actividad-page .momento-card.inicio{border-color:#3b82f6}.ver-actividad-page .momento-card.desarrollo{border-color:#10b981}.ver-actividad-page .momento-card.cierre{border-color:#8b5cf6}.ver-actividad-page .momento-card.tarea{border-color:#f59e0b}.ver-actividad-page .momento-header{display:flex;align-items:center;gap:16px;padding:20px 24px}.ver-actividad-page .momento-card.inicio .momento-header{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.ver-actividad-page .momento-card.desarrollo .momento-header{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.ver-actividad-page .momento-card.cierre .momento-header{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.ver-actividad-page .momento-card.tarea .momento-header{background:linear-gradient(135deg,#fef3c7,#fde68a)}.ver-actividad-page .momento-icon{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.ver-actividad-page .momento-title h3{margin:0;font-size:20px;font-weight:700;color:#1f2937}.ver-actividad-page .momento-duracion{font-size:14px;color:#6b7280;font-weight:500}.ver-actividad-page .badge.obligatoria{background:#fef2f2;color:#dc2626;margin-left:12px}.ver-actividad-page .momento-content{padding:24px}.ver-actividad-page .momento-subsection{margin-bottom:24px}.ver-actividad-page .momento-subsection:last-child{margin-bottom:0}.ver-actividad-page .momento-subsection h4{font-size:15px;font-weight:600;color:#374151;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid #e5e7eb}.ver-actividad-page .contenido-texto{color:#1f2937;line-height:1.8;white-space:pre-wrap;font-size:15px}.ver-actividad-page .estrategias-badges{display:flex;flex-wrap:wrap;gap:8px}.ver-actividad-page .estrategia-tag{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500}.ver-actividad-page .download-section{text-align:center;padding:40px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:16px;border:2px dashed #10b981}.ver-actividad-page .download-hint{margin:16px 0 0;color:#6b7280;font-size:14px}@media (max-width: 768px){.ver-actividad-page{padding:16px}.ver-actividad-page .header-content{flex-direction:column}.ver-actividad-page .header-info h1{font-size:22px}.ver-actividad-page .header-actions{width:100%}.ver-actividad-page .header-actions .btn{flex:1;justify-content:center}.ver-actividad-page .info-grid{grid-template-columns:1fr}.ver-actividad-page .momento-header{flex-direction:column;text-align:center}.ver-actividad-page .momento-content{padding:16px}.ver-actividad-page .download-section{padding:24px}}.wizard-container{max-width:900px;margin:0 auto;padding:20px}.wizard-error{text-align:center;padding:60px 40px;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014}.wizard-header{margin-bottom:24px;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px}.wizard-header-info h1{margin:8px 0 12px;font-size:24px;color:#1a1a2e}.ia-selector{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#667eea15,#764ba215);padding:10px 16px;border-radius:10px}.ia-selector label{font-size:14px;font-weight:600;color:#667eea}.ia-selector select{padding:8px 12px;border:2px solid #667eea;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.back-link{color:#667eea;text-decoration:none;font-size:14px}.back-link:hover{text-decoration:underline}.aula-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:20px;font-size:14px;color:#555}.aula-badge .aula-icon{font-size:18px}.aula-badge .separator{color:#ccc}.wizard-progress{display:flex;justify-content:space-between;margin-bottom:32px;padding:20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000f}.progress-step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;cursor:pointer;opacity:.5;transition:opacity .3s}.progress-step.active,.progress-step.completed{opacity:1}.progress-step.completed{cursor:pointer}.step-indicator{width:48px;height:48px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .3s}.progress-step.active .step-indicator{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.progress-step.completed .step-indicator{background:#10b981;color:#fff}.step-title{font-size:12px;font-weight:500;color:#666;text-align:center}.progress-step.active .step-title{color:#667eea;font-weight:600}.wizard-content{display:grid;grid-template-columns:280px 1fr;gap:24px;margin-bottom:24px}.wizard-assistant{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;color:#fff;position:sticky;top:20px;height:fit-content}.assistant-message h3{margin:0 0 12px;font-size:18px}.assistant-message .tip{background:#ffffff26;padding:12px;border-radius:8px;font-size:13px}.wizard-form{background:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 20px #00000014}.step-content{animation:fadeIn .3s ease}.step-welcome{text-align:center}.welcome-card{padding:20px}.welcome-icon{font-size:64px;margin-bottom:16px}.welcome-card h2{margin:0 0 16px;color:#1a1a2e}.aula-info-card{background:#f8fafc;border-radius:12px;padding:20px;margin:20px auto;max-width:300px}.info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e5e7eb}.info-row:last-child{border-bottom:none}.info-row .label{color:#666;font-size:14px}.info-row .value{font-weight:600;color:#1a1a2e}.ready-text{font-size:18px;color:#667eea;font-weight:600;margin-top:24px!important}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:15px}.form-group input[type=text],.form-group input[type=date],.form-group textarea{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:15px;transition:all .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.form-group input.valid,.form-group textarea.valid{border-color:#10b981}.form-group small{display:block;margin-top:6px;color:#888;font-size:13px}.form-description{margin:0 0 12px;color:#666;font-size:14px}.label-with-button{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.label-with-button label{margin-bottom:0}.btn-ia{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:12px 20px;font-size:14px;font-weight:600;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;white-space:nowrap;min-width:160px;transition:all .2s ease}.btn-ia:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.btn-ia:disabled{opacity:.6;cursor:not-allowed;transform:none}.selected-summary{background:#f8fafc;border-radius:10px;padding:16px;margin-top:20px}.selected-summary h4{margin:0 0 10px;color:#667eea;font-size:14px}.selected-summary p{margin:4px 0;font-size:14px;color:#555}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.checkbox-grid.small{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.checkbox-card{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#f8fafc;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s}.checkbox-card:hover{border-color:#667eea;background:#f0f4ff}.checkbox-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea10,#764ba210)}.checkbox-card input{display:none}.checkbox-card span{font-size:14px;color:#333}.checkbox-card.small{padding:10px 12px}.checkbox-card.small span{font-size:13px}.competencias-list{display:flex;flex-direction:column;gap:20px}.competencias-area h4{margin:0 0 12px;color:#667eea;font-size:14px;padding-bottom:8px;border-bottom:2px solid #667eea20}.competencias-grid{display:flex;flex-direction:column;gap:8px}.step-review{display:flex;flex-direction:column;gap:20px}.review-section{padding:16px;background:#f8fafc;border-radius:10px}.review-section h4{margin:0 0 8px;color:#667eea;font-size:14px}.review-section p{margin:0;color:#333;line-height:1.6}.tags{display:flex;flex-wrap:wrap;gap:8px}.tag{padding:6px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;font-size:13px}.tag.small{padding:4px 10px;font-size:12px}.review-text{background:#fff;padding:12px;border-radius:8px;border:1px solid #e5e7eb;white-space:pre-wrap;line-height:1.6}.review-text.highlight{font-size:18px;font-weight:600;color:#667eea}.ia-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:16px;display:flex;align-items:center;gap:10px}.ia-error button{margin-left:auto;background:none;border:none;font-size:20px;cursor:pointer;color:#991b1b}.prompt-group{background:linear-gradient(135deg,#667eea08,#764ba208);border:2px dashed #667eea40;border-radius:12px;padding:20px;margin-bottom:20px}.prompt-group label{color:#667eea;font-weight:600;margin-bottom:12px;display:block}.prompt-input-container{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.prompt-input{flex:1;min-width:200px;padding:14px 16px;border:2px solid #667eea30;border-radius:10px;font-size:15px;transition:all .3s}.warning-message{margin-top:12px;padding:10px 14px;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;color:#92400e;font-size:13px}.btn-generar-ia,.btn-generar-situacion{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff!important;padding:14px 24px;font-size:15px;font-weight:600;border-radius:10px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;min-width:180px;transition:all .3s ease;box-shadow:0 4px 15px #667eea59;-moz-appearance:none;appearance:none;-webkit-appearance:none}.btn-generar-ia:hover:not(:disabled),.btn-generar-situacion:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea73;color:#fff!important}.btn-generar-ia:disabled,.btn-generar-situacion:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn-generar-ia--large{width:100%;min-width:unset;padding:16px 28px;font-size:16px;margin-top:16px}.btn-generar-ia--small{min-width:200px;padding:12px 20px;font-size:14px}.prompt-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea20}.prompt-input::placeholder{color:#999;font-style:italic}.prompt-hint{display:block;margin-top:10px;color:#666;font-size:13px;line-height:1.5}@media (max-width: 768px){.prompt-input-container{flex-direction:column;align-items:stretch}.prompt-input-container .btn-generar-ia,.prompt-input-container .btn-generar-situacion{width:100%;min-width:unset}.btn-generar-ia--small{min-width:unset;width:100%}}.context-summary{background:linear-gradient(135deg,#667eea10,#764ba210);border-radius:10px;padding:16px;margin-top:20px}.context-summary h4{margin:0 0 10px;color:#667eea;font-size:14px}.context-summary p{margin:4px 0;font-size:14px;color:#555}.criterios-config{background:#f8fafc;border-radius:12px;padding:24px;margin-bottom:24px}.radio-group{display:grid;grid-template-columns:1fr 1fr;gap:12px}.radio-card{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#fff;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s}.radio-card:hover{border-color:#667eea}.radio-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea10,#764ba210)}.radio-card input{margin-top:3px;accent-color:#667eea}.radio-card div{display:flex;flex-direction:column;gap:4px}.radio-card strong{color:#1a1a2e}.radio-card small{color:#666;font-size:12px}.btn-large{width:100%;padding:16px;font-size:16px;margin-top:16px}.criterios-list{margin-top:24px}.criterios-list h4{margin:0 0 16px;color:#1a1a2e}.criterio-item{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px;margin-bottom:12px}.criterio-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.criterio-competencia{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:500}.btn-remove{background:#fee2e2;border:none;color:#991b1b;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}.btn-remove:hover{background:#fca5a5}.criterio-texto{width:100%;margin:0;padding:14px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:15px;line-height:1.6;font-family:inherit;resize:vertical;min-height:100px;box-sizing:border-box}.criterio-texto:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.criterios-empty{text-align:center;padding:40px 20px;background:#f8fafc;border-radius:12px;color:#666}.criterios-empty .tip{background:linear-gradient(135deg,#667eea15,#764ba215);padding:12px;border-radius:8px;margin-top:16px;font-size:13px}.criterios-review{list-style:none;padding:0;margin:0}.criterios-review li{padding:12px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:8px;font-size:14px;line-height:1.5}.evidencias-section{display:flex;flex-direction:column;gap:24px}.criterio-evidencias-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000d}.criterio-header-evidencia{display:flex;align-items:center;gap:12px;margin-bottom:12px}.criterio-numero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.criterio-competencia-small{color:#666;font-size:13px}.criterio-descripcion{color:#333;line-height:1.6;margin-bottom:16px;padding-bottom:16px;border-bottom:1px dashed #e5e7eb}.evidencias-list{background:#f8fafc;border-radius:10px;padding:16px}.evidencias-list h5{margin:0 0 12px;color:#667eea;font-size:14px}.evidencia-item{display:flex;align-items:flex-start;gap:10px;background:#fff;padding:12px;border-radius:8px;margin-bottom:8px;border:1px solid #e5e7eb}.evidencia-item p{flex:1;margin:0;font-size:14px;line-height:1.5;color:#333}.evidencia-textarea{flex:1;padding:10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;line-height:1.5;font-family:inherit;resize:vertical;min-height:60px}.evidencia-textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.btn-remove-small{background:#fee2e2;border:none;color:#991b1b;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:14px;flex-shrink:0}.btn-remove-small:hover{background:#fca5a5}.agregar-evidencia{margin-top:16px;padding-top:12px;border-top:1px dashed #e5e7eb;display:flex;flex-wrap:wrap;gap:12px;align-items:center}.agregar-evidencia .btn-generar-ia--small{flex-shrink:0}.review-criterio{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px;margin-bottom:12px}.review-criterio p{margin:0 0 10px;line-height:1.6}.review-evidencias{list-style:none;margin:0;padding:0 0 0 16px}.review-evidencias li{padding:8px 12px;background:#f0fdf4;border-radius:6px;margin-bottom:6px;font-size:13px;color:#166534}.wizard-navigation{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014}.step-indicator-text{color:#888;font-size:14px}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}@media (max-width: 768px){.wizard-content{grid-template-columns:1fr}.wizard-assistant{position:static}.wizard-progress{flex-wrap:wrap;gap:16px;justify-content:center}.progress-step{flex:0 0 auto}.step-title{display:none}.form-row,.checkbox-grid{grid-template-columns:1fr}.wizard-navigation{flex-direction:column;gap:16px}.wizard-navigation .btn{width:100%}}.wizard-actividad-container{max-width:1200px;width:100%;margin:0 auto;padding:20px;min-height:calc(100vh - 100px);box-sizing:border-box}.wizard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#666;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.wizard-header-info{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 15px #667eea4d}.info-badge{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fffffff2;border-radius:25px;font-size:13px;box-shadow:0 2px 8px #0000001a}.info-badge .label{color:#64748b;font-weight:500}.info-badge .value{color:#1e293b;font-weight:600}.info-badge.experiencia{flex:1;min-width:250px;background:#fff}.info-badge.experiencia .value{color:#6366f1;font-weight:700}.wizard-actividad-ia-bar{display:flex;flex-wrap:wrap;align-items:flex-start;gap:20px;margin-bottom:24px;padding:20px;background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:16px;border:1px solid #e2e8f0}.wizard-actividad-ia-bar .ia-selector{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#fff;border-radius:10px;border:2px solid #c7d2fe}.wizard-actividad-ia-bar .ia-selector label{font-size:14px;font-weight:600;color:#6366f1}.wizard-actividad-ia-bar .ia-selector select{padding:8px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;min-width:160px}.wizard-actividad-ia-bar .ia-selector select:focus{border-color:#6366f1;outline:none}.prompt-adicional-group{flex:1;min-width:280px}.prompt-adicional-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:#374151}.prompt-adicional-input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:14px;resize:vertical;min-height:56px;box-sizing:border-box}.prompt-adicional-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.prompt-adicional-input::placeholder{color:#94a3b8}.ia-error{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;padding:14px 18px;background:#fef2f2;border:2px solid #fecaca;border-radius:12px;color:#dc2626;font-size:14px;font-weight:500}.ia-error button{flex-shrink:0;width:32px;height:32px;padding:0;border:none;background:#fecaca;color:#dc2626;border-radius:8px;font-size:20px;line-height:1;cursor:pointer}.ia-error button:hover{background:#fca5a5}.wizard-progress{display:flex;justify-content:center;align-items:flex-start;gap:8px;margin-bottom:32px;padding:24px;background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f}.progress-step{display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:all .3s;flex:1;max-width:120px;position:relative}.progress-step:not(:last-child):after{content:"";position:absolute;top:22px;left:calc(50% + 25px);width:calc(100% - 50px);height:3px;background:#e2e8f0;z-index:0;border-radius:2px}.progress-step.completed:not(:last-child):after{background:linear-gradient(90deg,#10b981,#059669)}.step-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border-radius:50%;font-size:22px;margin-bottom:10px;border:3px solid #e2e8f0;z-index:1;transition:all .3s}.progress-step.active .step-icon{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-color:#6366f1;transform:scale(1.15);box-shadow:0 6px 20px #6366f166}.progress-step.completed .step-icon{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981}.step-title{font-size:12px;color:#64748b;font-weight:600;text-align:center;max-width:80px}.progress-step.active .step-title{color:#6366f1;font-weight:700}.progress-step.completed .step-title{color:#10b981}.wizard-actividad-container .wizard-content{display:grid!important;grid-template-columns:280px 1fr!important;gap:24px;margin-bottom:24px;width:100%;box-sizing:border-box}.wizard-actividad-container .wizard-assistant{background:linear-gradient(135deg,#667eea,#764ba2)!important;border-radius:16px;padding:24px;color:#fff;position:sticky;top:20px;height:fit-content;display:block!important;visibility:visible!important;opacity:1!important}.assistant-avatar{width:60px;height:60px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:16px}.assistant-message h3{margin:0 0 12px;font-size:18px;font-weight:600}.assistant-message p{margin:0 0 12px;font-size:14px;line-height:1.6;opacity:.95}.assistant-message .tip{background:#ffffff26;padding:12px;border-radius:8px;font-size:13px;margin-top:12px}.wizard-actividad-container .wizard-form{background:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 20px #00000014;display:block!important}.step-content{width:100%;max-width:100%;box-sizing:border-box;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-content h2{margin:0 0 24px;color:#1e293b;font-size:24px;font-weight:700;text-align:left}.form-group{margin-bottom:24px;width:100%;box-sizing:border-box}.form-group label{display:block;margin-bottom:10px;font-weight:600;color:#374151;font-size:15px}.form-group input[type=text],.form-group input[type=date],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:14px 18px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;transition:all .2s;background:#fafafa;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6366f1;background:#fff;box-shadow:0 0 0 4px #6366f11a}.form-group textarea{resize:vertical;min-height:120px}.form-row{display:flex;flex-direction:column;gap:24px;width:100%;box-sizing:border-box}.form-row .form-group{width:100%;margin-bottom:0}.helper-text{color:#64748b;font-size:13px;margin-bottom:14px;font-style:italic}.tip{color:#d97706;font-size:13px;margin-top:10px;padding:12px 16px;background:#fffbeb;border-radius:10px;border-left:4px solid #f59e0b}.textarea-with-ia{position:relative;width:100%;box-sizing:border-box}.textarea-with-ia textarea{padding-right:150px;width:100%;box-sizing:border-box}.btn-ia{position:absolute;right:12px;top:12px;padding:10px 18px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #6366f14d}.btn-ia:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.btn-ia:disabled{opacity:.6;cursor:not-allowed}.duracion-display{padding:24px 32px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:16px;text-align:center;border:2px solid #c7d2fe;width:100%;max-width:400px;box-sizing:border-box}.duracion-valor{font-size:32px;font-weight:800;color:#6366f1;display:block}.duracion-display small{display:block;color:#64748b;margin-top:6px;font-size:13px}.estrategia-descripcion{margin-top:12px;padding:14px 18px;background:#f0fdf4;border-radius:12px;color:#166534;font-size:14px;border-left:4px solid #22c55e;line-height:1.5;width:100%;box-sizing:border-box}.experiencia-competencias-info{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:12px;padding:16px 20px;margin-bottom:20px;border-left:4px solid #6366f1}.info-badge-text{margin:0 0 8px;font-size:14px;color:#1e293b;line-height:1.5}.info-badge-text strong{color:#6366f1;font-weight:600}.no-competencias-message{background:#fef2f2;border:2px solid #fecaca;border-radius:12px;padding:20px;text-align:center;color:#991b1b;margin:20px 0}.tip-warning{background:#fffbeb;border:2px solid #fde68a;border-radius:12px;padding:14px 18px;margin-top:16px;color:#92400e;font-size:14px;line-height:1.5}.tip-warning strong{font-weight:600}.more-capacidades{color:#6366f1;font-style:italic;font-size:12px}.competencias-grid{display:flex;flex-direction:column;gap:16px;width:100%;box-sizing:border-box}.competencia-card{padding:20px;border:2px solid #e2e8f0;border-radius:16px;cursor:pointer;transition:all .2s;background:#fafafa;width:100%;box-sizing:border-box}.competencia-card:hover{border-color:#6366f1;background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #6366f126}.competencia-card.selected{border-color:#6366f1;background:linear-gradient(135deg,#eef2ff,#e0e7ff);box-shadow:0 4px 12px #6366f133}.comp-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}.comp-header input[type=checkbox]{width:22px;height:22px;margin-top:2px;accent-color:#6366f1;cursor:pointer}.comp-nombre{font-weight:700;color:#1e293b;font-size:15px;line-height:1.4}.comp-estandar{margin-top:14px;padding:14px;background:#fff;border-radius:10px;border:1px solid #e2e8f0}.comp-estandar strong{color:#6366f1;font-size:12px;display:block;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.comp-estandar p{margin:0;color:#475569;font-size:13px;line-height:1.6}.comp-capacidades{margin-top:14px}.comp-capacidades strong{color:#059669;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.comp-capacidades ul{margin:10px 0 0;padding-left:20px}.comp-capacidades li{color:#475569;font-size:13px;margin-bottom:6px;line-height:1.4}.momento-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:20px;border-bottom:3px solid}.momento-header.inicio{border-color:#f59e0b}.momento-header.desarrollo{border-color:#6366f1}.momento-header.cierre{border-color:#10b981}.momento-header h2{margin:0;text-align:left}.duracion-input{display:flex;align-items:center;gap:10px;background:#f8fafc;padding:10px 18px;border-radius:12px;border:2px solid #e2e8f0}.duracion-input label{margin:0;font-size:14px;color:#64748b;font-weight:500}.duracion-input input{width:70px;padding:8px 12px;text-align:center;font-weight:700;font-size:16px;border:2px solid #e2e8f0;border-radius:8px}.duracion-input input:focus{border-color:#6366f1;outline:none}.momento-descripcion{color:#64748b;font-size:14px;margin-bottom:28px;padding:16px;background:#f8fafc;border-radius:12px;text-align:center;font-style:italic;width:100%;box-sizing:border-box}.estrategias-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;width:100%;box-sizing:border-box}.checkbox-label{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#f8fafc;border-radius:12px;cursor:pointer;transition:all .2s;font-size:14px;border:2px solid transparent}.checkbox-label:hover{background:#eef2ff;border-color:#c7d2fe}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:#6366f1;cursor:pointer}.toggle-group{padding:20px;background:#f8fafc;border-radius:16px;border:2px solid #e2e8f0;width:100%;box-sizing:border-box}.toggle-label{display:flex;align-items:center;gap:14px;cursor:pointer}.toggle-label input[type=checkbox]{width:24px;height:24px;accent-color:#6366f1;cursor:pointer}.toggle-text{font-weight:600;color:#374151;font-size:16px}.no-tarea-info{padding:40px;text-align:center;color:#64748b;background:#f8fafc;border-radius:16px;margin-top:24px;font-size:15px;width:100%;box-sizing:border-box}.step-content.revision{background:#f8fafc;padding:30px;border-radius:16px}.revision-section{background:#fff;padding:24px;border-radius:16px;margin-bottom:20px;box-shadow:0 2px 8px #0000000a;border:1px solid #e2e8f0}.revision-section h3{margin:0 0 18px;color:#374151;font-size:17px;padding-bottom:14px;border-bottom:2px solid #e2e8f0}.revision-item{display:flex;gap:14px;margin-bottom:12px;font-size:14px;align-items:flex-start}.revision-item .label{color:#64748b;min-width:130px;font-weight:600}.revision-item .value{color:#1e293b;flex:1}.revision-subsection{margin-bottom:18px;padding-bottom:18px;border-bottom:1px dashed #e2e8f0}.revision-subsection:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.revision-subsection strong{color:#6366f1;font-size:13px;display:block;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.revision-subsection p{margin:0;color:#475569;font-size:14px;line-height:1.7}.save-error{padding:18px;background:#fef2f2;color:#dc2626;border-radius:12px;text-align:center;margin-top:24px;font-weight:600;border:2px solid #fecaca}.save-success{padding:18px;background:#f0fdf4;color:#16a34a;border-radius:12px;text-align:center;margin-top:24px;font-weight:600;border:2px solid #bbf7d0}.wizard-navigation{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:24px 30px;background:#fff;border-radius:16px;box-shadow:0 -4px 20px #0000000f;border:1px solid #e2e8f0}.btn-secondary,.btn-primary,.btn-success,.btn-ia-full{padding:14px 28px;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s}.btn-secondary{background:#f1f5f9;color:#475569}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-primary{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 4px 12px #6366f14d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.btn-ia-full{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;flex:1;max-width:320px;box-shadow:0 4px 12px #8b5cf64d}.btn-ia-full:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.contexto-experiencia-box{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #7dd3fc;border-radius:12px;padding:16px 20px;margin-bottom:20px;box-shadow:0 2px 8px #0ea5e91a}.contexto-experiencia-box.proposito-hilo{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.contexto-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.contexto-icon{font-size:24px}.contexto-title{font-weight:700;font-size:15px;color:#0369a1}.contexto-experiencia-box.proposito-hilo .contexto-title{color:#b45309}.contexto-content{background:#ffffffb3;border-radius:8px;padding:12px 16px;margin-bottom:12px}.contexto-content p{margin:0;font-size:14px;line-height:1.5;color:#334155}.contexto-content p+p{margin-top:8px}.proposito-destacado{font-weight:600;color:#92400e!important;font-size:15px!important}.contexto-tip{margin:0;font-size:13px;color:#64748b;font-style:italic}.proposito-info-box,.hilo-conductor-info-box{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;margin-bottom:12px}.proposito-definicion,.hilo-definicion{margin:0;font-size:13px;color:#475569;line-height:1.5}.proposito-definicion strong,.hilo-definicion strong{color:#1e293b}.proposito-info-box{border-left:4px solid #6366f1}.hilo-conductor-info-box{border-left:4px solid #f59e0b}.contexto-sesion-box{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;padding:16px 20px;margin-bottom:20px;box-shadow:0 2px 8px #0000000d}.contexto-dual{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px}.contexto-item{background:#fff;border-radius:8px;padding:12px 16px;border:1px solid #e2e8f0}.contexto-item.proposito{border-left:4px solid #6366f1}.contexto-item.hilo{border-left:4px solid #f59e0b}.contexto-item-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.contexto-item-header .contexto-icon{font-size:18px}.contexto-label{font-weight:600;font-size:13px;color:#475569}.contexto-item.proposito .contexto-label{color:#4f46e5}.contexto-item.hilo .contexto-label{color:#d97706}.contexto-texto{margin:0;font-size:13px;color:#334155;line-height:1.5}@media (max-width: 768px){.contexto-dual{grid-template-columns:1fr}}.ia-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.btn-regenerar{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)!important;color:#475569!important;border:1px solid #cbd5e1!important}.btn-regenerar:hover:not(:disabled){background:linear-gradient(135deg,#e2e8f0,#cbd5e1)!important;color:#334155!important}.btn-mejorar{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;color:#92400e!important;border:1px solid #f59e0b!important}.btn-mejorar:hover:not(:disabled){background:linear-gradient(135deg,#fde68a,#fcd34d)!important;color:#78350f!important}.textarea-with-ia .ia-buttons{position:absolute;bottom:10px;right:10px;margin-top:0}.textarea-with-ia .ia-buttons .btn-ia{position:static;padding:8px 14px;font-size:12px}.input-with-ia{display:flex;gap:10px;align-items:center}.input-with-ia input{flex:1}.btn-ia-inline{padding:10px 16px!important;font-size:13px!important;white-space:nowrap}.label-highlight{color:#f59e0b;font-weight:600;font-size:12px}.generar-sesion-completa-box{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:16px;padding:24px;margin:24px 0;text-align:center}.sesion-completa-header{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}.sesion-icon{font-size:48px}.sesion-info h4{margin:0 0 4px;font-size:18px;color:#065f46}.sesion-info p{margin:0;font-size:14px;color:#047857}.btn-generar-sesion{padding:16px 32px;font-size:16px;font-weight:700;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #10b9814d}.btn-generar-sesion:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-generar-sesion:disabled{opacity:.7;cursor:not-allowed;transform:none}.sesion-tip{margin:16px 0 0;font-size:13px;color:#047857;font-style:italic}.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;padding:20px}.modal-mejora{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #00000040}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px 16px 0 0}.modal-header h3{margin:0;font-size:18px;color:#1e293b}.modal-close{background:none;border:none;font-size:28px;color:#64748b;cursor:pointer;padding:0;line-height:1;transition:color .2s}.modal-close:hover{color:#ef4444}.modal-body{padding:24px}.contenido-actual{margin-bottom:20px}.contenido-actual label{display:block;font-weight:600;font-size:14px;color:#475569;margin-bottom:8px}.contenido-preview{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;font-size:13px;color:#64748b;line-height:1.5;max-height:150px;overflow-y:auto}.instruccion-mejora{margin-bottom:16px}.instruccion-mejora label{display:block;font-weight:600;font-size:14px;color:#1e293b;margin-bottom:8px}.instruccion-mejora textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;resize:vertical;transition:border-color .2s}.instruccion-mejora textarea:focus{outline:none;border-color:#6366f1}.sugerencias-mejora{margin-bottom:8px}.sugerencias-mejora>span{display:block;font-size:13px;color:#64748b;margin-bottom:8px}.sugerencias-chips{display:flex;flex-wrap:wrap;gap:8px}.sugerencias-chips button{padding:6px 12px;font-size:12px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;color:#475569;cursor:pointer;transition:all .2s}.sugerencias-chips button:hover{background:#e2e8f0;color:#1e293b}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e2e8f0;background:#f8fafc;border-radius:0 0 16px 16px}.criterios-experiencia-section{margin-top:32px;padding:20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;border:1px solid #f59e0b}.criterios-experiencia-section .section-header h3{margin:0 0 8px;color:#92400e;font-size:18px}.criterios-experiencia-section .section-header .helper-text{margin:0 0 16px;color:#a16207;font-size:13px}.criterios-list{display:flex;flex-direction:column;gap:12px}.criterio-item{background:#fff;padding:16px;border-radius:8px;border-left:4px solid #f59e0b}.criterio-descripcion{font-weight:500;color:#1f2937;margin-bottom:8px}.criterio-numero{color:#f59e0b;font-weight:700;margin-right:8px}.criterio-evidencias{margin-top:12px;padding-top:12px;border-top:1px dashed #e5e7eb}.criterio-evidencias strong{color:#6b7280;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.criterio-evidencias ul{margin:8px 0 0;padding-left:20px}.criterio-evidencias li{color:#4b5563;font-size:13px;margin-bottom:4px}.areas-experiencia-section{margin-top:24px;padding:16px 20px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:12px;border:1px solid #6366f1}.areas-experiencia-section .section-header h3{margin:0 0 12px;color:#4338ca;font-size:16px}.areas-badges{display:flex;flex-wrap:wrap;gap:8px}.area-badge{background:#fff;color:#4338ca;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;border:1px solid #a5b4fc}@media (max-width: 768px){.wizard-actividad-container{padding:16px}.wizard-header-info{flex-direction:column;padding:16px}.info-badge.experiencia{min-width:auto}.wizard-progress{padding:16px 8px;gap:4px}.progress-step{max-width:60px}.step-icon{width:40px;height:40px;font-size:18px}.step-title{font-size:10px;max-width:60px}.progress-step:not(:last-child):after{display:none}.wizard-content{grid-template-columns:1fr}.wizard-assistant{position:static;margin-bottom:24px}.wizard-form{padding:24px 20px}.step-content h2{font-size:22px}.form-row,.estrategias-checkboxes{grid-template-columns:1fr}.wizard-navigation{flex-wrap:wrap;padding:16px}.btn-ia-full{order:-1;width:100%;max-width:none;margin-bottom:12px}.textarea-with-ia textarea{padding-right:16px}.btn-ia{position:static;width:100%;margin-top:10px}.momento-header{flex-direction:column;gap:16px;align-items:flex-start}.duracion-input{width:100%;justify-content:center}}.generar-rubrica-page{padding:20px;max-width:1400px;margin:0 auto}.generar-rubrica-page .page-header{margin-bottom:24px}.generar-rubrica-page .header-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#666;margin-bottom:16px;flex-wrap:wrap}.generar-rubrica-page .header-breadcrumb a{color:#4a90d9;text-decoration:none}.generar-rubrica-page .header-breadcrumb a:hover{text-decoration:underline}.generar-rubrica-page .header-breadcrumb .current{color:#333;font-weight:500}.generar-rubrica-page .header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.generar-rubrica-page .header-info h1{font-size:1.8rem;margin:0 0 8px;color:#1a1a2e}.generar-rubrica-page .header-info .subtitle{color:#666;margin:0}.experiencia-context{margin-bottom:24px}.context-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px;border-radius:12px}.context-card h3{margin:0 0 12px;font-size:1.2rem}.context-badges{display:flex;gap:8px;flex-wrap:wrap}.context-badges .badge{background:#fff3;color:#fff;padding:4px 12px;border-radius:20px;font-size:.85rem}.error-message{background:#fff5f5;border:1px solid #feb2b2;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.step-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;margin-bottom:24px}.step-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #eee}.step-header h2{font-size:1.3rem;margin:0 0 8px;color:#1a1a2e}.step-header p{color:#666;margin:0}.no-criterios{text-align:center;padding:40px 20px}.no-criterios .empty-icon{font-size:4rem;margin-bottom:16px}.no-criterios h3{margin:0 0 12px;color:#333}.no-criterios p{color:#666;margin:0 0 8px}.criterios-actions{display:flex;align-items:center;flex-wrap:wrap;gap:16px;margin-bottom:16px}.criterios-count{color:#666;font-size:.9rem}.criterios-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.criterio-card{display:flex;gap:16px;padding:16px;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s ease;background:#fafafa}.criterio-card:hover{border-color:#4a90d9;background:#fff}.criterio-card.selected{border-color:#4a90d9;background:#f0f7ff}.criterio-checkbox{display:flex;align-items:flex-start;padding-top:4px}.criterio-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.criterio-content{flex:1}.criterio-descripcion-input{width:100%;border:1px solid #d5dce5;border-radius:8px;padding:10px 12px;font-size:.95rem;line-height:1.5;resize:vertical;font-family:inherit;background:#fff}.criterio-inline-actions{margin-top:8px;display:flex;justify-content:flex-end}.criterio-new-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}.criterio-new-row textarea{flex:1;min-height:70px;border:1px solid #d5dce5;border-radius:8px;padding:10px 12px;resize:vertical;font-family:inherit}.criterio-numero{font-size:.85rem;color:#4a90d9;font-weight:600;margin-bottom:4px}.criterio-descripcion{margin:0 0 8px;color:#333;line-height:1.5}.criterio-evidencias{font-size:.85rem;color:#666;background:#f8f9fa;padding:8px 12px;border-radius:6px}.criterio-evidencias strong{color:#555}.criterio-evidencias ul{margin:4px 0 0;padding-left:20px}.criterio-evidencias li{margin-bottom:2px}.criterio-evidencias li.more{color:#888;font-style:italic}.ia-config{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px}.ia-config label{font-weight:500;color:#333}.ia-config select{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:.95rem;min-width:170px}.generar-actions{text-align:center;padding-top:16px;border-top:1px solid #eee}.generating-hint{color:#666;font-size:.9rem;margin-top:12px}.rubrica-preview{margin-bottom:24px}.rubrica-header{margin-bottom:20px}.rubrica-header h3{margin:0 0 8px;color:#1a1a2e}.rubrica-meta{display:flex;gap:20px;color:#666;font-size:.9rem}.rubrica-table-container{overflow-x:auto;border-radius:10px;border:1px solid #e2e8f0}.rubrica-table{width:100%;border-collapse:collapse;min-width:900px}.rubrica-table th,.rubrica-table td{padding:12px 16px;text-align:left;border:1px solid #e2e8f0;vertical-align:top}.rubrica-table th{background:#f8f9fa;font-weight:600;color:#333;font-size:.9rem}.rubrica-table th.col-criterio{width:25%;background:#1a1a2e;color:#fff}.rubrica-table th.col-nivel{width:18.75%;text-align:center}.rubrica-table th.col-nivel.inicio{background:#fed7d7;color:#c53030}.rubrica-table th.col-nivel.proceso{background:#feebc8;color:#c05621}.rubrica-table th.col-nivel.logrado{background:#c6f6d5;color:#276749}.rubrica-table th.col-nivel.destacado{background:#bee3f8;color:#2b6cb0}.criterio-cell strong{display:block;color:#4a90d9;margin-bottom:4px}.criterio-cell p{margin:0;font-size:.9rem;line-height:1.4}.rubrica-edit-input{width:100%;border:1px solid #d5dce5;border-radius:8px;padding:8px 10px;font-size:.9rem;line-height:1.4;font-family:inherit;resize:vertical;background:#fff}.rubrica-edit-input.nivel{min-height:120px}.evidencias-mini{margin-top:8px;padding-top:8px;border-top:1px dashed #ddd}.evidencias-mini small{display:block;color:#888;font-size:.75rem;margin-bottom:4px}.evidencias-mini span{display:block;font-size:.8rem;color:#666;padding:2px 0}.evidencias-mini span.sugerida{color:#805ad5;font-style:italic}.evidencias-mini span.sugerida:before{content:"✨ "}.rubrica-table td.col-nivel{font-size:.85rem;line-height:1.5}.rubrica-nivel-readonly{white-space:pre-wrap;line-height:1.5}.rubrica-actions{display:flex;justify-content:center;gap:16px;padding-top:20px;border-top:1px solid #eee}.spinner-sm{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:8px}@media (max-width: 768px){.generar-rubrica-page{padding:16px}.generar-rubrica-page .header-info h1{font-size:1.4rem}.context-card,.step-section{padding:16px}.criterios-actions{flex-direction:column;align-items:flex-start}.criterio-new-row{flex-direction:column}.criterio-new-row .btn{width:100%}.ia-config{flex-direction:column;align-items:flex-start}.ia-config select{width:100%}.rubrica-actions{flex-direction:column}.rubrica-actions .btn{width:100%}}.rubricas-experiencia-page{padding:20px;max-width:1400px;margin:0 auto}.rubricas-experiencia-page .page-header{margin-bottom:24px}.rubricas-experiencia-page .header-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#666;margin-bottom:16px;flex-wrap:wrap}.rubricas-experiencia-page .header-breadcrumb a{color:#4a90d9;text-decoration:none}.rubricas-experiencia-page .header-breadcrumb a:hover{text-decoration:underline}.rubricas-experiencia-page .header-breadcrumb .current{color:#333;font-weight:500}.rubricas-experiencia-page .header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}.rubricas-experiencia-page .header-info h1{font-size:1.8rem;margin:0 0 8px;color:#1a1a2e}.rubricas-experiencia-page .header-info .subtitle{color:#666;margin:0}.rubricas-experiencia-page .experiencia-context{margin-bottom:24px}.rubricas-experiencia-page .context-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px;border-radius:12px}.rubricas-experiencia-page .context-card h3{margin:0 0 12px;font-size:1.2rem}.rubricas-experiencia-page .context-badges{display:flex;gap:8px;flex-wrap:wrap}.rubricas-experiencia-page .context-badges .badge{background:#fff3;color:#fff;padding:4px 12px;border-radius:20px;font-size:.85rem}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.empty-state .empty-icon{font-size:4rem;margin-bottom:16px}.empty-state h3{margin:0 0 12px;color:#333}.empty-state p{color:#666;margin:0 0 24px}.rubricas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.rubrica-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.rubrica-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.rubrica-card-header{padding:16px 20px;background:linear-gradient(135deg,#1a1a2e,#2d2d44);color:#fff}.rubrica-card-header h3{margin:0 0 8px;font-size:1.1rem;line-height:1.4}.rubrica-date{font-size:.85rem;opacity:.8}.rubrica-card-body{padding:16px 20px}.rubrica-info{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px;font-size:.9rem;color:#666}.rubrica-preview-criterios{font-size:.85rem;color:#555}.preview-criterio{padding:8px 0;border-bottom:1px solid #f0f0f0}.preview-criterio:last-child{border-bottom:none}.preview-criterio strong{color:#4a90d9}.more-criterios{padding:8px 0;color:#888;font-style:italic}.rubrica-card-actions{display:flex;gap:8px;padding:12px 20px;background:#f8f9fa;border-top:1px solid #eee}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-sm{padding:6px 12px;font-size:.85rem}.btn-lg{padding:14px 28px;font-size:1.05rem}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #38a16966}.btn-danger{background:#e53e3e;color:#fff}.btn-danger:hover:not(:disabled){background:#c53030}@media (max-width: 768px){.rubricas-experiencia-page{padding:16px}.rubricas-experiencia-page .header-info h1{font-size:1.4rem}.rubricas-experiencia-page .header-content{flex-direction:column}.rubricas-grid{grid-template-columns:1fr}.rubrica-card-actions{flex-wrap:wrap}}.ver-rubrica-page{padding:20px;max-width:1600px;margin:0 auto}.ver-rubrica-page .page-header{margin-bottom:24px}.ver-rubrica-page .header-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#666;margin-bottom:16px;flex-wrap:wrap}.ver-rubrica-page .header-breadcrumb a{color:#4a90d9;text-decoration:none}.ver-rubrica-page .header-breadcrumb a:hover{text-decoration:underline}.ver-rubrica-page .header-breadcrumb .current{color:#333;font-weight:500}.ver-rubrica-page .header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}.ver-rubrica-page .header-info h1{font-size:1.6rem;margin:0 0 12px;color:#1a1a2e}.ver-rubrica-page .header-meta{display:flex;gap:20px;color:#666;font-size:.95rem}.ver-rubrica-page .header-actions{display:flex;gap:12px;flex-wrap:wrap}.rubrica-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;overflow:hidden;margin-bottom:24px}.rubrica-table-wrapper{overflow-x:auto}.rubrica-table{width:100%;border-collapse:collapse;min-width:1000px}.rubrica-table th,.rubrica-table td{padding:16px;text-align:left;border:1px solid #e2e8f0;vertical-align:top}.rubrica-table thead th{font-weight:600;font-size:.95rem}.rubrica-table th.col-criterio{width:25%;background:#1a1a2e;color:#fff;font-size:1rem}.rubrica-table th.col-nivel{width:18.75%;text-align:center;padding:12px 16px}.nivel-header{display:flex;flex-direction:column;align-items:center;gap:4px}.nivel-letra{font-size:1.5rem;font-weight:700}.nivel-nombre{font-size:.85rem;font-weight:500}.rubrica-table th.col-nivel.inicio{background:linear-gradient(135deg,#fed7d7,#feb2b2);color:#9b2c2c}.rubrica-table th.col-nivel.proceso{background:linear-gradient(135deg,#feebc8,#fbd38d);color:#975a16}.rubrica-table th.col-nivel.logrado{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);color:#276749}.rubrica-table th.col-nivel.destacado{background:linear-gradient(135deg,#bee3f8,#90cdf4);color:#2b6cb0}.rubrica-table td.col-criterio{background:#f8f9fa}.criterio-cell{display:flex;flex-direction:column;gap:8px}.criterio-numero{font-size:.8rem;font-weight:600;color:#4a90d9;text-transform:uppercase;letter-spacing:.5px}.criterio-descripcion{margin:0;font-size:.95rem;line-height:1.5;color:#333}.criterio-evidencias{margin-top:8px;padding-top:8px;border-top:1px dashed #ddd;font-size:.85rem}.criterio-evidencias strong{display:block;color:#555;margin-bottom:4px}.criterio-evidencias ul{margin:0;padding-left:16px}.criterio-evidencias li{margin-bottom:4px;color:#666}.criterio-evidencias li.sugerida{color:#805ad5}.tag-sugerida{display:inline-block;background:#805ad5;color:#fff;font-size:.65rem;padding:2px 6px;border-radius:4px;margin-right:6px;font-weight:600}.rubrica-table td.col-nivel{font-size:.9rem;line-height:1.6}.nivel-content{color:#333}.rubrica-table td.col-nivel.inicio{background:#fff5f5}.rubrica-table td.col-nivel.proceso{background:#fffaf0}.rubrica-table td.col-nivel.logrado{background:#f0fff4}.rubrica-table td.col-nivel.destacado{background:#ebf8ff}.rubrica-legend{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.rubrica-legend h4{margin:0 0 16px;color:#333;font-size:1.1rem}.legend-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.legend-item{display:flex;gap:12px;padding:12px;border-radius:8px;background:#f8f9fa}.legend-badge{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;font-weight:700;font-size:1rem;flex-shrink:0}.legend-item.inicio .legend-badge{background:#fed7d7;color:#9b2c2c}.legend-item.proceso .legend-badge{background:#feebc8;color:#975a16}.legend-item.logrado .legend-badge{background:#c6f6d5;color:#276749}.legend-item.destacado .legend-badge{background:#bee3f8;color:#2b6cb0}.legend-item div strong{display:block;margin-bottom:4px;color:#333}.legend-item div p{margin:0;font-size:.85rem;color:#666;line-height:1.4}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666}.spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#4a90d9;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.not-found{text-align:center;padding:60px 20px}.not-found h2{color:#333;margin-bottom:20px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-success{background:linear-gradient(135deg,#38a169,#2f855a);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #38a16966}@media print{.ver-rubrica-page{padding:0}.header-breadcrumb,.header-actions{display:none}.rubrica-container{box-shadow:none;border:1px solid #ccc}.rubrica-table{min-width:auto}.rubrica-legend{page-break-inside:avoid}}@media (max-width: 768px){.ver-rubrica-page{padding:16px}.ver-rubrica-page .header-info h1{font-size:1.3rem}.ver-rubrica-page .header-content{flex-direction:column}.ver-rubrica-page .header-actions{width:100%}.ver-rubrica-page .header-actions .btn{flex:1}.legend-items{grid-template-columns:1fr}}.calendario-page{padding:16px}.calendario-header h1{margin:0 0 4px}.calendario-header p{margin:0 0 12px;color:#64748b}.calendario-filtros{display:flex;gap:10px;margin-bottom:12px}.calendario-filtros select{padding:8px 10px;border:1px solid #d8e0ea;border-radius:8px}.calendario-toolbar{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:12px}.calendario-toolbar button{border:1px solid #d8e0ea;background:#fff;border-radius:8px;padding:6px 12px;cursor:pointer}.calendario-toolbar h2{margin:0;min-width:280px;text-align:center;font-size:1.1rem}.calendario-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.calendario-dia-header{background:#0f172a;color:#fff;padding:8px;text-align:center;font-weight:600;font-size:.9rem}.calendario-cell{min-height:130px;border-top:1px solid #e2e8f0;border-right:1px solid #e2e8f0;padding:6px;background:#fff}.calendario-cell:nth-child(7n){border-right:none}.calendario-cell.empty{background:#f8fafc}.calendario-cell.today{background:#eff6ff}.calendario-numero{font-weight:700;font-size:.85rem;margin-bottom:4px;color:#334155}.calendario-eventos{display:flex;flex-direction:column;gap:4px}.evento-item{text-align:left;border:none;background:#dbeafe;color:#1d4ed8;border-radius:6px;padding:4px 6px;font-size:.75rem;cursor:pointer}.evento-item:hover{background:#bfdbfe}.evento-more{font-size:.72rem;color:#64748b}.error-banner{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:8px;padding:10px 12px;margin-bottom:10px}.perfil-page{padding:20px 0}.perfil-header{margin-bottom:24px}.perfil-header h1{font-size:1.8rem;color:#1a1a2e;margin:0 0 8px}.perfil-header p{color:#666;margin:0}.alert{padding:14px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px;font-size:.95rem}.alert-error{background:#fff5f5;border:1px solid #feb2b2;color:#c53030}.alert-success{background:#f0fff4;border:1px solid #9ae6b4;color:#276749}.perfil-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.perfil-loading p{margin:0;color:#666}.perfil-loading .spinner-large{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:perfil-spin .8s linear infinite}@keyframes perfil-spin{to{transform:rotate(360deg)}}.perfil-content{display:flex;flex-direction:column;gap:24px}.perfil-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.card-header h3{margin:0;font-size:1.2rem;color:#1a1a2e}.user-card{display:flex;align-items:center;gap:24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.user-avatar-large{width:100px;height:100px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:600;border:3px solid rgba(255,255,255,.3)}.user-details h2{margin:0 0 8px;font-size:1.5rem}.user-email{margin:0 0 12px;opacity:.9}.user-badge{display:inline-block;background:#fff3;padding:4px 12px;border-radius:20px;font-size:.85rem;text-transform:capitalize}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f7fafc;color:#4a5568;cursor:not-allowed}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:#e2e8f0;color:#4a5568}.btn-secondary:hover:not(:disabled){background:#cbd5e0}.btn-outline{background:transparent;border:2px solid #667eea;color:#667eea}@media (max-width: 768px){.user-card{flex-direction:column;text-align:center}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:1}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.cneb-page{padding:20px 0;max-width:900px;margin:0 auto}.cneb-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:12px}.cneb-page .page-header h1{margin:0 0 4px;color:#1a1a2e;font-size:26px}.cneb-page .page-subtitle{margin:0;color:#64748b;font-size:14px}.cneb-filtros{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000f;margin-bottom:28px}.cneb-filtros .filtros-title{margin:0 0 20px;font-size:18px;color:#334155}.filtros-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:20px}.filtros-grid .form-group label{display:block;margin-bottom:6px;font-weight:600;color:#475569;font-size:13px}.filtros-grid .form-group select{width:100%;padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff}.filtros-grid .form-group select:focus{outline:none;border-color:#667eea}.filtros-actions{margin-top:8px}.cneb-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#64748b}.cneb-loading .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}.cneb-resultado{margin-top:8px}.resultado-header{margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.resultado-header h2{margin:0 0 4px;font-size:20px;color:#1e293b}.resultado-header p{margin:0;font-size:14px;color:#64748b}.cneb-bloque{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px}.cneb-bloque .bloque-competencia{margin:0 0 20px;font-size:17px;color:#0f172a;padding-bottom:10px;border-bottom:2px solid #e2e8f0}.cneb-seccion{margin-bottom:18px}.cneb-seccion:last-child{margin-bottom:0}.cneb-seccion h4{margin:0 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.02em;color:#64748b}.cneb-seccion.estandares h4{color:#0d9488}.cneb-seccion .contenido-texto{font-size:15px;line-height:1.6;color:#334155}.cneb-seccion ul{margin:0;padding-left:20px}.cneb-seccion li{margin-bottom:6px;line-height:1.5;color:#334155}.cneb-seccion .cap-desc{color:#64748b;font-size:14px}.cneb-seccion .competencia-descripcion{margin:8px 0 0;color:#475569;font-size:14px;line-height:1.5;font-weight:400}.cneb-bloque .sin-datos{margin:0;color:#94a3b8;font-style:italic;font-size:14px}.cneb-page .alert{padding:14px 18px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px}.cneb-page .alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.cneb-page .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.cneb-page .btn:disabled{opacity:.6;cursor:not-allowed}.cneb-page .btn-primary{background:#667eea;color:#fff}.cneb-page .btn-primary:hover:not(:disabled){background:#5a67d8}.cneb-page .btn-secondary{background:#e2e8f0;color:#475569}.cneb-page .btn-secondary:hover{background:#cbd5e1}.cneb-page .card{border:1px solid #e2e8f0}.admin-dashboard-page{padding:24px 0;max-width:1000px;margin:0 auto}.admin-header{margin-bottom:28px}.admin-header h1{margin:0 0 8px;font-size:26px;color:#1a1a2e}.admin-subtitle{margin:0;color:#64748b;font-size:15px}.admin-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;margin-bottom:32px}.admin-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;text-decoration:none;color:inherit;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column;position:relative}.admin-card:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.admin-card-icon{font-size:32px;margin-bottom:12px}.admin-card h3{margin:0 0 8px;font-size:18px;color:#1e293b}.admin-card p{margin:0;font-size:14px;color:#64748b;flex:1}.admin-card-count{margin-top:12px;font-weight:700;color:#667eea;font-size:20px}.admin-docentes-preview{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:24px}.admin-docentes-preview h2{margin:0 0 16px;font-size:18px;color:#334155}.docentes-table-wrap{overflow-x:auto;margin-bottom:16px}.docentes-table{width:100%;border-collapse:collapse}.docentes-table th,.docentes-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e2e8f0}.docentes-table th{font-weight:600;color:#475569;font-size:13px}.docentes-table td{font-size:14px;color:#334155}.badge{padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-success{background:#dcfce7;color:#166534}.badge-inactive{background:#f1f5f9;color:#64748b}.admin-dashboard-page .alert-error{background:#fef2f2;color:#991b1b;padding:14px 18px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px}.btn-outline{display:inline-block;padding:10px 20px;border:2px solid #667eea;color:#667eea;border-radius:8px;font-weight:600;text-decoration:none;transition:background .2s,color .2s}.btn-outline:hover{background:#667eea;color:#fff}.admin-docentes-page{padding:24px 0;max-width:1000px;margin:0 auto}.admin-docentes-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:24px}.admin-docentes-page .page-header h1{margin:0 0 4px;font-size:24px;color:#1a1a2e}.admin-docentes-page .page-subtitle{margin:0;color:#64748b;font-size:14px}.admin-docentes-page .btn{padding:10px 20px;border-radius:8px;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;border:none;cursor:pointer}.admin-docentes-page .btn-secondary{background:#e2e8f0;color:#475569}.admin-docentes-page .btn-secondary:hover{background:#cbd5e1}.table-wrap{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #e2e8f0}.data-table th{background:#f8fafc;font-weight:600;color:#475569;font-size:13px}.data-table td{font-size:14px;color:#334155}.data-table tbody tr:last-child td{border-bottom:none}.admin-docentes-page .badge{padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.admin-docentes-page .badge-success{background:#dcfce7;color:#166534}.admin-docentes-page .badge-inactive{background:#f1f5f9;color:#64748b}.admin-docentes-page .alert-error{background:#fef2f2;color:#991b1b;padding:14px 18px;border-radius:8px;margin-bottom:20px}.admin-docentes-page .loading-state{display:flex;flex-direction:column;align-items:center;padding:40px;color:#64748b}.admin-docentes-page .loading-state .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}@keyframes spin{to{transform:rotate(360deg)}}.admin-curriculo-page{padding:24px 0;max-width:1100px;margin:0 auto}.admin-curriculo-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:24px}.admin-curriculo-page .page-header h1{margin:0 0 4px;font-size:24px;color:#1a1a2e}.admin-curriculo-page .page-subtitle{margin:0;color:#64748b;font-size:14px}.admin-curriculo-page .btn{padding:10px 20px;border-radius:8px;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;border:none;cursor:pointer}.admin-curriculo-page .btn-secondary{background:#e2e8f0;color:#475569}.admin-curriculo-page .btn-secondary:hover{background:#cbd5e1}.tabs{display:flex;gap:8px;margin-bottom:24px}.tabs button{padding:10px 20px;border:2px solid #e2e8f0;background:#fff;border-radius:8px;font-weight:600;cursor:pointer;color:#64748b}.tabs button.active{border-color:#667eea;background:#667eea;color:#fff}.tabs button:hover:not(.active){border-color:#cbd5e1}.crud-section{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:24px}.form-inline{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:20px}.form-inline input[type=text],.form-inline select{padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;min-width:180px}.form-inline input:focus,.form-inline select:focus{outline:none;border-color:#667eea}.form-inline button[type=submit]{padding:10px 18px;background:#667eea;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.form-inline button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{padding:10px 14px;background:#f1f5f9;color:#475569;border:none;border-radius:8px;cursor:pointer}.form-competencia input[type=text]:last-of-type{min-width:240px}.form-estandar .form-estandar-desc{min-width:280px}.filter-bar{display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px;margin-bottom:16px;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.filter-bar label{font-size:13px;font-weight:600;color:#475569;margin:0}.filter-input{padding:8px 12px;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;min-width:200px}.filter-input:focus{outline:none;border-color:#667eea}.filter-select{padding:8px 12px;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;min-width:180px}.filter-select:focus{outline:none;border-color:#667eea}.btn-clear-filter{padding:6px 12px;font-size:13px}.filter-count{font-size:12px;color:#64748b;margin-left:auto}.admin-curriculo-page .table-wrap{overflow-x:auto}.admin-curriculo-page .data-table{width:100%;border-collapse:collapse}.admin-curriculo-page .data-table th,.admin-curriculo-page .data-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e2e8f0}.admin-curriculo-page .data-table th{background:#f8fafc;font-weight:600;color:#475569;font-size:13px}.admin-curriculo-page .data-table .desc-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-sm{padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;border:none;cursor:pointer;margin-right:8px}.btn-edit{background:#dbeafe;color:#1d4ed8}.btn-delete{background:#fee2e2;color:#b91c1c}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.admin-curriculo-page .alert-error{background:#fef2f2;color:#991b1b;padding:14px 18px;border-radius:8px;margin-bottom:20px}.admin-curriculo-page .loading-state{display:flex;flex-direction:column;align-items:center;padding:40px;color:#64748b}.admin-curriculo-page .loading-state .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:admin-spin .8s linear infinite;margin-bottom:12px}@keyframes admin-spin{to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#fff;min-height:100vh;color:#1a1a1a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}
