@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Outfit:wght@400;600;700;800&display=swap";.landing-hero{text-align:center;background:linear-gradient(135deg,#0d1b5e 0%,#1a237e 40%,#283593 70%,#4527a0 100%) 0 0/200% 200%;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:100px 24px 60px;animation:8s infinite gradientShift;display:flex;position:relative;overflow:hidden}.landing-hero:before{content:"";pointer-events:none;background:radial-gradient(at 30%,#6482ff26 0%,#0000 60%),radial-gradient(at 70% 30%,#c864ff1a 0%,#0000 50%);position:absolute;inset:0}.hero-orbs{pointer-events:none;position:absolute;inset:0;overflow:hidden}.hero-orb{opacity:.08;border-radius:50%;animation:6s ease-in-out infinite bounce;position:absolute}.hero-orb:first-child{background:#5c6bc0;width:400px;height:400px;animation-delay:0s;top:-100px;left:-100px}.hero-orb:nth-child(2){background:#7c4dff;width:300px;height:300px;animation-delay:-2s;bottom:-80px;right:-80px}.hero-orb:nth-child(3){background:#00b0ff;width:200px;height:200px;animation-delay:-4s;top:50%;right:15%}.landing-logo{font-family:var(--font-display);color:#fff;letter-spacing:-1px;z-index:1;margin-bottom:8px;font-size:clamp(52px,8vw,88px);font-weight:800;line-height:1.1;position:relative}.landing-logo span{background:linear-gradient(135deg,#80deea 0%,#a5d6f7 50%,#ce93d8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-year-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border-radius:var(--radius-full);letter-spacing:.05em;text-transform:uppercase;z-index:1;background:#ffffff1f;border:1px solid #ffffff40;align-items:center;gap:6px;margin-bottom:20px;padding:6px 16px;font-size:13px;font-weight:600;display:inline-flex;position:relative}.landing-tagline{color:#ffffffd9;z-index:1;max-width:640px;margin-bottom:50px;font-size:clamp(18px,2.5vw,24px);line-height:1.5;position:relative}.hero-buttons{z-index:1;flex-wrap:wrap;justify-content:center;gap:16px;display:flex;position:relative}.btn-hero-student{color:#fff;border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-spring);background:linear-gradient(135deg,#00c853 0%,#00897b 100%);border:none;align-items:center;gap:10px;padding:20px 44px;font-size:18px;font-weight:700;text-decoration:none;display:inline-flex;box-shadow:0 8px 32px #00c85366}.btn-hero-student:hover{transform:translateY(-3px)scale(1.02);box-shadow:0 14px 40px #00c85380}.btn-hero-teacher{color:#fff;border-radius:var(--radius-full);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:var(--transition-spring);background:#ffffff26;border:2px solid #ffffff59;align-items:center;gap:10px;padding:20px 44px;font-size:18px;font-weight:700;text-decoration:none;display:inline-flex}.btn-hero-teacher:hover{background:#ffffff40;border-color:#fff9;transform:translateY(-3px)scale(1.02)}.scroll-indicator{color:#ffffff80;letter-spacing:.1em;flex-direction:column;align-items:center;gap:8px;font-size:12px;animation:2s ease-in-out infinite bounce;display:flex;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.stats-banner{background:var(--primary-800);flex-wrap:wrap;justify-content:center;gap:60px;padding:20px 40px;display:flex}.stat-item{text-align:center;color:#fff}.stat-num{font-family:var(--font-display);background:linear-gradient(135deg,#80deea,#ce93d8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:800}.stat-label{color:#fff9;letter-spacing:.05em;text-transform:uppercase;margin-top:2px;font-size:12px}.landing-section{max-width:1100px;margin:0 auto;padding:80px 24px}.section-chip{background:var(--primary-100);color:var(--primary-600);border-radius:var(--radius-full);letter-spacing:.05em;text-transform:uppercase;align-items:center;gap:6px;margin-bottom:12px;padding:6px 14px;font-size:12px;font-weight:700;display:inline-flex}.section-title{font-family:var(--font-display);color:var(--gray-900);margin-bottom:16px;font-size:clamp(28px,4vw,42px);font-weight:800;line-height:1.2}.features-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:48px;display:grid}.feature-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:var(--transition-spring);border:1px solid var(--gray-200);padding:32px;position:relative;overflow:hidden}.feature-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:4px;position:absolute;top:0;left:0;right:0}.feature-card:first-child:before{background:linear-gradient(90deg,#3f51b5,#7986cb)}.feature-card:nth-child(2):before{background:linear-gradient(90deg,#00c853,#00bfa5)}.feature-card:nth-child(3):before{background:linear-gradient(90deg,#ff6b6b,#ff8e53)}.feature-card:nth-child(4):before{background:linear-gradient(90deg,#7c4dff,#ce93d8)}.feature-card:nth-child(5):before{background:linear-gradient(90deg,#00b0ff,#00e5ff)}.feature-card:nth-child(6):before{background:linear-gradient(90deg,#ffb300,#ff6f00)}.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px)}.feature-icon-wrap{border-radius:var(--radius);background:var(--primary-100);justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;font-size:28px;display:flex}.feature-title{font-family:var(--font-display);color:var(--gray-900);margin-bottom:8px;font-size:18px;font-weight:700}.feature-desc{color:var(--gray-500);font-size:14px;line-height:1.6}.fases-section{background:var(--primary-50);padding:80px 24px}.fases-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;max-width:1100px;margin:48px auto 0;display:grid}.fase-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition);border:1px solid var(--gray-200);padding:28px}.fase-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.fase-num{font-family:var(--font-display);color:var(--primary-100);margin-bottom:4px;font-size:48px;font-weight:900;line-height:1}.fase-title{color:var(--primary-700);margin-bottom:8px;font-size:16px;font-weight:700}.fase-desc{color:var(--gray-500);font-size:13px;line-height:1.6}.landing-cta{text-align:center;background:linear-gradient(135deg,#0d1b5e 0%,#1a237e 50%,#4527a0 100%);padding:80px 24px}.cta-title{font-family:var(--font-display);color:#fff;margin-bottom:16px;font-size:clamp(28px,4vw,48px);font-weight:800}.cta-sub{color:#ffffffb3;margin-bottom:40px;font-size:18px}.landing-footer{background:var(--gray-900);color:#ffffff80;text-align:center;padding:24px;font-size:13px}@media (width<=600px){.stats-banner{gap:30px;padding:20px}.hero-buttons{flex-direction:column;align-items:stretch}.btn-hero-student,.btn-hero-teacher{justify-content:center}}.estudiante-root{background:var(--bg);min-height:100vh;font-family:var(--font-ui);padding-bottom:60px}.estudiante-header{background:linear-gradient(135deg, var(--primary-800) 0%, var(--primary-600) 100%);grid-template-columns:auto 1fr auto;align-items:start;gap:16px;padding:32px 24px 40px;display:grid}.header-left{min-width:80px}.back-btn{color:#ffffffbf;border-radius:var(--radius-full);transition:var(--transition);background:#ffffff1a;border:1px solid #ffffff26;align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.header-center{text-align:center}.header-titulo{font-family:var(--font-display);color:#fff;margin-bottom:6px;font-size:clamp(22px,4vw,32px);font-weight:800}.header-sub{color:#ffffffa6;font-size:15px}.header-right{min-width:80px}.controles-bar{z-index:10;flex-direction:column;gap:14px;max-width:1100px;margin:-20px auto 0;padding:0 24px;display:flex;position:relative}.search-wrap{border-radius:var(--radius-full);box-shadow:var(--shadow-md);transition:var(--transition);background:#fff;border:2px solid #0000;align-items:center;gap:10px;padding:4px 20px;display:flex}.search-wrap:focus-within{border-color:var(--primary-400);box-shadow:var(--shadow-glow)}.search-icon{font-size:16px}.search-input{font-size:15px;font-family:var(--font-ui);color:var(--gray-800);background:0 0;border:none;outline:none;flex:1;padding:12px 0}.search-input::placeholder{color:var(--gray-400)}.filter-chips{flex-wrap:wrap;gap:8px;display:flex}.filter-chip{border-radius:var(--radius-full);border:2px solid var(--gray-200);color:var(--gray-500);cursor:pointer;transition:var(--transition-spring);font-size:13px;font-weight:600;font-family:var(--font-ui);box-shadow:var(--shadow-sm);background:#fff;padding:8px 18px}.filter-chip:hover{border-color:var(--primary-400);color:var(--primary-500);transform:translateY(-1px)}.filter-chip.active{background:var(--primary-500);border-color:var(--primary-500);color:#fff;transform:translateY(-1px);box-shadow:0 4px 14px #3f51b559}.resultados-count{max-width:1100px;color:var(--gray-400);margin:20px auto 0;padding:0 24px;font-size:13px;font-weight:500}.lecturas-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;max-width:1100px;margin:16px auto 0;padding:0 24px;display:grid}.lectura-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);cursor:pointer;transition:var(--transition-spring);background:#fff;border:2px solid #0000;flex-direction:column;display:flex;overflow:hidden}.lectura-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-300);transform:translateY(-6px)}.lectura-card:focus-visible{outline:3px solid var(--primary-500);outline-offset:2px}.lectura-card-header{justify-content:space-between;align-items:flex-end;min-height:100px;padding:30px 20px 20px;display:flex;position:relative}.lectura-icon{filter:drop-shadow(0 4px 8px #00000026);font-size:52px;line-height:1}.lectura-badges{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.lc-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border-radius:var(--radius-full);letter-spacing:.03em;background:#ffffff40;border:1px solid #ffffff4d;padding:4px 10px;font-size:11px;font-weight:700}.lectura-card-body{flex:1;padding:20px}.lectura-titulo{font-family:var(--font-display);color:var(--gray-900);margin-bottom:10px;font-size:16px;font-weight:700;line-height:1.3}.lectura-meta{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.meta-chip{background:var(--gray-100);color:var(--gray-500);border-radius:var(--radius-full);padding:3px 10px;font-size:11px;font-weight:600}.lectura-preview{color:var(--gray-400);font-size:13px;font-style:italic;line-height:1.6}.lectura-card-footer{background:var(--primary-50);border-top:1px solid var(--gray-200);padding:14px 20px}.leer-btn{color:var(--primary-500);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:700}.empty-state{text-align:center;color:var(--gray-400);grid-column:1/-1;padding:80px 20px}.empty-icon{margin-bottom:16px;font-size:56px}.empty-state p{margin-bottom:20px;font-size:16px}@media (width<=600px){.estudiante-header{text-align:center;grid-template-columns:1fr}.header-left{text-align:center}.lecturas-grid{grid-template-columns:1fr}.filter-chips{justify-content:center}}.selector-empty{text-align:center;background:var(--bg);min-height:100vh;font-family:var(--font-ui);flex-direction:column;justify-content:center;align-items:center;padding:40px 24px;display:flex}.selector-empty-icon{filter:grayscale(.3);margin-bottom:20px;font-size:72px}.selector-empty h2{font-family:var(--font-display);color:var(--gray-900);margin-bottom:10px;font-size:24px;font-weight:800}.selector-empty p{color:var(--gray-500);max-width:380px;font-size:16px;line-height:1.6}.selector-root{background:linear-gradient(160deg, var(--primary-900) 0%, var(--primary-700) 50%, #4527a0 100%);min-height:100vh;font-family:var(--font-ui);justify-content:center;align-items:center;padding:24px;display:flex}.selector-card{border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-lg);text-align:center;background:#fff;padding:48px 40px}.selector-icon{margin-bottom:16px;font-size:64px;animation:3s ease-in-out infinite bounce;display:block}.selector-titulo{font-family:var(--font-display);color:var(--gray-900);margin-bottom:6px;font-size:28px;font-weight:800}.selector-sub{color:var(--gray-500);margin-bottom:32px;font-size:15px}.selector-field{text-align:left;margin-bottom:20px}.selector-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.selector-select{border:2px solid var(--gray-200);border-radius:var(--radius);width:100%;font-family:var(--font-ui);color:var(--gray-800);background:var(--gray-100);cursor:pointer;transition:var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%233949AB' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;background-color:var(--gray-100);outline:none;padding:14px 18px;font-size:16px;font-weight:600}.selector-select:focus{border-color:var(--primary-400);background-color:#fff;box-shadow:0 0 0 3px #3f51b526}.selector-select--disabled{opacity:.5;cursor:not-allowed}.selector-error{color:#c62828;border-radius:var(--radius);text-align:left;background:#ffebee;border:1px solid #ffcdd2;margin-bottom:12px;padding:10px 16px;font-size:13px;font-weight:600}.selector-btn{font-size:18px!important}.selector-volver{color:var(--gray-400);transition:var(--transition);margin-top:20px;font-size:13px;text-decoration:none;display:block}.selector-volver:hover{color:var(--primary-500)}.back-btn{color:#ffffffbf;border-radius:var(--radius-full);transition:var(--transition);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-ui);background:#ffffff1a;border:1px solid #ffffff26;align-items:center;gap:6px;padding:8px 14px;text-decoration:none;display:inline-flex}.back-btn:hover{color:#fff;background:#fff3}@media (width<=480px){.selector-card{padding:36px 24px}.selector-titulo{font-size:24px}}.lectura-root{background:var(--bg);min-height:100vh;font-family:var(--font-ui);flex-direction:column;display:flex}.lectura-topbar{color:#fff;box-shadow:var(--shadow-md);z-index:100;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.lectura-back{color:#fff;border-radius:var(--radius-full);cursor:pointer;transition:var(--transition);font-size:14px;font-weight:600;font-family:var(--font-ui);white-space:nowrap;background:#ffffff2e;border:1px solid #ffffff4d;padding:8px 16px}.lectura-back:hover{background:#ffffff47}.lectura-topbar-info{flex:1;justify-content:center;align-items:center;gap:12px;padding:0 20px;display:flex}.topbar-icono{filter:drop-shadow(0 2px 4px #0003);font-size:36px}.topbar-titulo{font-family:var(--font-display);color:#fff;font-size:clamp(14px,2.5vw,20px);font-weight:700;line-height:1.2}.topbar-meta{color:#ffffffb3;font-size:12px;font-weight:500}.circular-timer{background:#fff3;border:3px solid #ffffff59;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:70px;height:70px;animation:2s ease-in-out infinite recordingPulse;display:flex}.timer-inner{text-align:center}.timer-time{font-family:var(--font-display);color:#fff;font-size:16px;font-weight:800;line-height:1;display:block}.timer-label{color:#fff9;text-transform:uppercase;letter-spacing:.05em;font-size:9px;display:block}.lectura-main{flex:1;grid-template-columns:1fr;gap:24px;width:100%;max-width:1200px;margin:0 auto;padding:32px 24px 120px;display:grid}@media (width>=900px){.lectura-main{grid-template-columns:1.3fr 1fr;align-items:start}}.lectura-panel{border-radius:var(--radius-xl);box-shadow:var(--shadow-md);background:#fff;overflow:hidden}.texto-container{padding:36px}.texto-principal{color:var(--gray-800);text-align:justify;letter-spacing:.01em;font-family:Georgia,serif;font-size:clamp(22px,3.5vw,36px);line-height:1.8}.palabra-highlight{cursor:help;border-radius:3px;padding:0 2px;transition:background .3s;display:inline}.palabra-correcta{color:#1b5e20;background:#00c85326;-webkit-text-decoration:underline #00c853;text-decoration:underline #00c853}.palabra-aproximada{color:#663d00;background:#ffb30026;-webkit-text-decoration:underline wavy #ffb300;text-decoration:underline wavy #ffb300}.palabra-error{color:#b71c1c;background:#f4433626;-webkit-text-decoration:line-through #f44336;text-decoration:line-through #f44336}.leyenda-colores{border-top:1px solid var(--gray-200);flex-wrap:wrap;gap:16px;margin-top:20px;padding-top:20px;display:flex}.leyenda-dot.correcta{background:#00c853}.leyenda-dot.aproximada{background:#ffb300}.leyenda-dot.error{background:#f44336}.mic-error{color:#c62828;background:#ffebee;border-bottom:1px solid #ffcdd2;padding:12px 20px;font-size:14px;font-weight:500}.grabacion-indicador{border-top:1px solid var(--gray-200);align-items:center;gap:16px;padding:16px 36px 24px;display:flex}.mic-animated{flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:relative}.mic-icon{z-index:2;font-size:28px;position:relative}.ripple-ring{border:2px solid #f4433666;border-radius:50%;animation:2s ease-out infinite ripple;position:absolute;inset:0}.ripple-ring.r2{animation-delay:1s}.grabacion-texto{color:var(--danger);font-size:15px;font-weight:600}.resultado-panel{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:2px solid var(--primary-100);background:#fff;padding:32px;position:sticky;top:100px}.resultado-header{border-bottom:1px solid var(--gray-200);align-items:center;gap:16px;margin-bottom:28px;padding-bottom:20px;display:flex}.resultado-emoji{font-size:48px;line-height:1}.resultado-nivel{font-family:var(--font-display);font-size:26px;font-weight:800;line-height:1.1}.resultado-sub{color:var(--gray-400);margin-top:2px;font-size:12px}.metricas-grid{justify-content:space-around;gap:12px;margin-bottom:24px;display:flex}.metrica-circular{flex-direction:column;align-items:center;gap:8px;display:flex}.metrica-etiqueta{color:var(--gray-500);text-align:center;font-size:12px;font-weight:600}.stats-extra{border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.stat-row{color:var(--gray-600,#424260);border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:10px 16px;font-size:13px;display:flex}.stat-row:last-child{border-bottom:none}.stat-row span{color:var(--gray-500)}.stat-row strong{color:var(--gray-900);font-weight:700}.nota-docente{color:var(--gray-400);text-align:center;margin-bottom:20px;font-size:12px;font-style:italic}.resultado-actions{flex-direction:column;gap:10px;display:flex}.controles-flotantes{-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--gray-200);z-index:200;background:#ffffffeb;justify-content:center;align-items:center;padding:16px 24px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 32px #0f175a1f}.estado-listo,.estado-grabando{flex-wrap:wrap;justify-content:center;align-items:center;gap:20px;display:flex}.instruccion-texto{color:var(--gray-500);text-align:center;font-size:14px}.btn-accion{font-family:var(--font-ui);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-spring);box-shadow:var(--shadow-md);border:none;align-items:center;gap:12px;padding:18px 48px;font-size:18px;font-weight:700;display:inline-flex}.btn-accion:active{transform:scale(.97)!important}.btn-iniciar{color:#fff;background:linear-gradient(135deg,#00c853 0%,#00897b 100%);box-shadow:0 6px 24px #00c85366}.btn-iniciar:hover{transform:translateY(-3px)scale(1.02);box-shadow:0 12px 32px #00c85380}.btn-detener{color:#fff;background:linear-gradient(135deg,#f44336 0%,#c62828 100%);animation:2s ease-in-out infinite recordingPulse;box-shadow:0 6px 24px #f4433666}.btn-detener:hover{transform:translateY(-3px)scale(1.02)}.btn-icono{font-size:20px}.grabando-info{color:var(--danger);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.dot-recording{background:var(--danger);border-radius:50%;width:10px;height:10px;animation:1s ease-in-out infinite pulse}@media (width<=600px){.lectura-topbar{padding:12px 16px}.topbar-icono{font-size:24px}.texto-container{padding:20px}.texto-principal{font-size:22px}.metricas-grid{gap:8px}.resultado-panel{position:static}.estado-listo{text-align:center;flex-direction:column}}.panel-root{background:var(--bg);min-height:100vh;font-family:var(--font-ui);display:flex}.panel-sidebar{background:var(--primary-900);flex-direction:column;flex-shrink:0;width:220px;height:100vh;padding:0;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:24px 20px;display:flex}.brand-icon{filter:drop-shadow(0 2px 6px #fff3);font-size:28px}.brand-name{font-family:var(--font-display);color:#fff;letter-spacing:-.02em;font-size:18px;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.sidebar-item{border-radius:var(--radius);color:#ffffff8c;width:100%;font-family:var(--font-ui);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:12px 14px;font-size:14px;font-weight:500;display:flex}.sidebar-item:hover{color:#ffffffd9;background:#ffffff14}.sidebar-item.active{color:#fff;background:#ffffff1f;font-weight:600}.sidebar-icon{flex-shrink:0;font-size:18px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.sidebar-back-link{color:#ffffff80;transition:var(--transition);font-size:13px;font-weight:500;text-decoration:none}.sidebar-back-link:hover{color:#fff}.panel-content{flex-direction:column;flex:1;min-width:0;display:flex}.panel-topbar{box-shadow:var(--shadow-sm);z-index:50;border-bottom:1px solid var(--gray-200);background:#fff;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 32px;display:flex;position:sticky;top:0}.panel-titulo{font-family:var(--font-display);color:var(--gray-900);font-size:22px;font-weight:800;line-height:1.2}.panel-subtitulo{color:var(--gray-400);font-size:13px}.curso-selector{align-items:center;gap:8px;display:flex}.curso-label{color:var(--gray-500);font-size:13px;font-weight:600}.curso-select{border:2px solid var(--gray-200);border-radius:var(--radius-full);font-family:var(--font-ui);color:var(--primary-700);cursor:pointer;transition:var(--transition);appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%233949AB' stroke-width='2' fill='none'/%3E%3C/svg%3E") right 10px center no-repeat;outline:none;padding:8px 28px 8px 14px;font-size:14px;font-weight:600}.curso-select:focus{border-color:var(--primary-400);box-shadow:var(--shadow-glow)}.tab-content{flex:1;padding:28px 32px}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:28px;display:grid}.kpi-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--gray-200);transition:var(--transition);background:#fff;align-items:center;gap:16px;padding:20px 24px;display:flex}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-icon{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex}.kpi-value{font-family:var(--font-display);font-size:28px;font-weight:900;line-height:1}.kpi-label{color:var(--gray-700,#424260);margin-top:2px;font-size:13px;font-weight:600}.kpi-sub{color:var(--gray-400);margin-top:2px;font-size:11px}.graficos-grid-2{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px;margin-bottom:24px;display:grid}.grafico-card{padding:20px 24px 16px}.grafico-titulo{font-family:var(--font-display);color:var(--gray-900);margin-bottom:4px;font-size:16px;font-weight:700}.grafico-sub{color:var(--gray-400);margin-bottom:16px;font-size:12px}.leyenda-pie{flex-wrap:wrap;gap:10px 18px;margin-top:12px;display:flex}.leyenda-item{color:var(--gray-500);align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.leyenda-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.custom-tooltip{border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-md);font-size:13px;font-family:var(--font-ui);background:#fff;padding:10px 14px}.tt-label{color:var(--gray-700,#424260);margin-bottom:4px;font-weight:700}.alertas-section{border-radius:var(--radius-lg);background:#fff8f8;border:1px solid #ffcdd2;padding:24px}.alertas-titulo{color:#c62828;margin-bottom:16px;font-size:16px;font-weight:700}.alertas-grid{flex-direction:column;gap:10px;display:flex}.alerta-card{border-radius:var(--radius);background:#fff;border:1px solid #ffcdd2;align-items:center;gap:14px;padding:12px 16px;display:flex}.alerta-avatar{color:#c62828;background:#ffebee;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;font-weight:700;display:flex}.alerta-nombre{color:var(--gray-900);font-size:14px;font-weight:600}.alerta-detalle{color:var(--gray-400);margin-top:2px;font-size:12px}.tabla-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.tabla-titulo{font-family:var(--font-display);color:var(--gray-900);font-size:20px;font-weight:800}.tabla-acciones{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.tabla-busqueda{border:2px solid var(--gray-200);border-radius:var(--radius-full);font-family:var(--font-ui);transition:var(--transition);background:#fff;outline:none;min-width:200px;padding:9px 16px;font-size:13px}.tabla-busqueda:focus{border-color:var(--primary-400);box-shadow:var(--shadow-glow)}.tabla-wrapper{border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--gray-200);background:#fff;overflow:auto}.tabla-estudiantes{border-collapse:collapse;width:100%;min-width:700px;font-size:13px}.tabla-estudiantes thead tr{background:var(--primary-50);border-bottom:2px solid var(--primary-100)}.tabla-estudiantes th{color:var(--primary-700);text-align:left;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;padding:14px 16px;font-size:12px;font-weight:700}.th-sort{font:inherit;color:inherit;cursor:pointer;text-transform:uppercase;letter-spacing:.03em;background:0 0;border:none;align-items:center;gap:2px;padding:0;font-size:12px;font-weight:700;display:flex}.th-sort:hover{color:var(--primary-500)}.tabla-estudiantes tbody tr{border-bottom:1px solid var(--gray-200);transition:background .15s}.tabla-estudiantes tbody tr:last-child{border-bottom:none}.tabla-estudiantes tbody tr:hover{background:var(--primary-50)}.tabla-estudiantes tbody tr.fila-alerta{background:#fff8f8}.tabla-estudiantes tbody tr.fila-alerta:hover{background:#ffecec}.tabla-estudiantes td{vertical-align:middle;padding:12px 16px}.td-num{color:var(--gray-400);width:40px;font-size:12px;font-weight:600}.estudiante-cell{color:var(--gray-900);align-items:center;gap:10px;font-weight:600;display:flex}.est-avatar{background:var(--primary-100);width:32px;height:32px;color:var(--primary-700);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.est-avatar.small{width:28px;height:28px;font-size:12px}.pcpm-cell{flex-direction:column;gap:4px;min-width:100px;display:flex}.pcpm-valor{color:var(--gray-900);font-size:14px;font-weight:700}.pcpm-bar-wrap{background:var(--gray-200);border-radius:99px;height:5px;overflow:hidden}.pcpm-bar{border-radius:99px;height:100%;transition:width .8s}.pct-valor{font-size:14px;font-weight:700}.pct-alto{color:#00897b}.pct-medio{color:#f57f17}.pct-bajo{color:#c62828}.nivel-badge{border-radius:var(--radius-full);white-space:nowrap;padding:4px 10px;font-size:11px;font-weight:700}.tabla-nota{color:var(--gray-400);margin-top:12px;font-size:12px;font-style:italic}.progreso-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.progreso-item{background:var(--gray-100);border-radius:var(--radius);border:1px solid var(--gray-200);padding:14px}.pi-header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.pi-nombre{color:var(--gray-900);font-size:13px;font-weight:600}.pi-ppm{font-family:var(--font-display);margin-left:auto;font-size:18px;font-weight:800}.mineduc-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;display:grid}.mineduc-card{border:2px solid var(--gray-200);transition:var(--transition);padding:20px}.mineduc-card.mineduc-activo{border-color:var(--primary-400);box-shadow:var(--shadow-glow)}.mineduc-curso{font-family:var(--font-display);color:var(--primary-700);border-bottom:1px solid var(--gray-200);margin-bottom:12px;padding-bottom:10px;font-size:15px;font-weight:800}.mineduc-tabla{border-collapse:collapse;width:100%;font-size:13px}.mineduc-tabla th{text-align:left;color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em;padding-bottom:8px;font-size:11px;font-weight:700}.mineduc-tabla td{padding:7px 0}.rango{border-radius:var(--radius-full);padding:2px 10px;font-size:12px;font-weight:700}.visually-hidden{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=768px){.panel-root{flex-direction:column}.panel-sidebar{flex-flow:wrap;width:100%;height:auto;position:relative}.sidebar-nav{flex-flow:wrap;padding:8px}.tab-content{padding:16px}.graficos-grid-2{grid-template-columns:1fr}.panel-topbar{flex-direction:column;align-items:flex-start}}:root{--primary-900:#0d1b5e;--primary-800:#1a237e;--primary-700:#283593;--primary-600:#3949ab;--primary-500:#3f51b5;--primary-400:#5c6bc0;--primary-300:#7986cb;--primary-100:#e8eaf6;--primary-50:#f0f2fd;--success:#00c853;--success-light:#e8f5e9;--warning:#ffb300;--warning-light:#fff8e1;--danger:#f44336;--danger-light:#ffebee;--info:#00b0ff;--gray-900:#1a1a2e;--gray-800:#2d2d44;--gray-700:#424260;--gray-500:#6b6b8a;--gray-400:#9e9eba;--gray-200:#e5e5f0;--gray-100:#f5f5fa;--white:#fff;--surface:#fff;--surface-alt:#f8f9ff;--bg:#f2f4fc;--font-ui:"Inter", -apple-system, sans-serif;--font-display:"Outfit", sans-serif;--radius-sm:8px;--radius:16px;--radius-lg:24px;--radius-xl:32px;--radius-full:9999px;--shadow-sm:0 1px 3px #0f175a0f, 0 1px 2px #0f175a0a;--shadow:0 4px 12px #0f175a14, 0 2px 6px #0f175a0d;--shadow-md:0 8px 24px #0f175a1f, 0 4px 12px #0f175a0f;--shadow-lg:0 20px 48px #0f175a29, 0 8px 20px #0f175a14;--shadow-glow:0 0 30px #3f51b540;--transition:all .25s cubic-bezier(.4, 0, .2, 1);--transition-slow:all .4s cubic-bezier(.4, 0, .2, 1);--transition-spring:all .35s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-ui);background-color:var(--bg);color:var(--gray-800);min-height:100vh;line-height:1.6}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes ripple{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes recordingPulse{0%{box-shadow:0 0 #f4433666}70%{box-shadow:0 0 0 20px #f4433600}to{box-shadow:0 0 #f4433600}}.animate-fadeInUp{animation:.5s ease-out both fadeInUp}.animate-fadeIn{animation:.4s ease-out both fadeIn}.animate-scaleIn{animation:.4s ease-out both scaleIn}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.btn{font-family:var(--font-ui);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-spring);white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)!important}.btn-primary{background:linear-gradient(135deg, var(--primary-500) 0%, var(--primary-700) 100%);color:#fff;box-shadow:0 4px 16px #3f51b559}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3f51b573}.btn-success{color:#fff;background:linear-gradient(135deg,#00c853 0%,#00897b 100%);box-shadow:0 4px 16px #00c85359}.btn-success:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00c85373}.btn-danger{color:#fff;background:linear-gradient(135deg,#f44336 0%,#c62828 100%);box-shadow:0 4px 16px #f4433659}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 8px 24px #f4433673}.btn-ghost{color:var(--primary-500);border:2px solid var(--primary-200,#c5cae9);background:0 0}.btn-ghost:hover{background:var(--primary-50);transform:translateY(-1px)}.btn-lg{padding:18px 40px;font-size:18px}.btn-sm{padding:8px 16px;font-size:13px}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:var(--transition);padding:24px}.card:hover{box-shadow:var(--shadow-md)}.badge{border-radius:var(--radius-full);letter-spacing:.02em;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.glass{-webkit-backdrop-filter:blur(20px);background:#ffffff26;border:1px solid #fff3}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--primary-300);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--primary-500)}
