:root{font-family:Poppins,Montserrat,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.55;font-weight:400;color-scheme:dark;color:#f6f8ff;background-color:#05020f;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary: #f6c743;--primary-strong: #ffd96b;--primary-soft: rgba(246, 199, 67, .2);--secondary: #8a4dff;--secondary-soft: rgba(138, 77, 255, .2);--accent: #5ea2ff;--background: #05020f;--background-gradient: radial-gradient( circle at 50% 18%, #32146b 0%, #1c0c48 35%, #0a0424 65%, #05020f 100% );--surface-glass: rgba(15, 10, 44, .65);--surface-solid: rgba(18, 12, 58, .92);--surface-muted: rgba(18, 12, 58, .75);--surface-border: rgba(255, 255, 255, .16);--text-main: #f7f8ff;--text-muted: rgba(236, 239, 255, .7);--text-silent: rgba(236, 239, 255, .5);--shadow-soft: 0 18px 38px rgba(4, 2, 20, .45);--shadow-strong: 0 26px 60px rgba(4, 2, 20, .55);--input-bg: rgba(255, 255, 255, .08);--input-border: rgba(255, 255, 255, .22);--input-focus: rgba(246, 199, 67, .48)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;min-height:100vh}body{background:var(--background-gradient);background-attachment:fixed;margin:0;min-width:320px;color:var(--text-main)}#root{min-height:100vh;width:100%;display:flex;flex-direction:column}a{font-weight:500;color:var(--primary);text-decoration:none;transition:color .25s ease}a:hover{color:var(--primary-strong)}button{border-radius:14px;border:1px solid transparent;padding:.65em 1.4em;font-size:1rem;font-weight:600;font-family:inherit;background:linear-gradient(135deg,var(--primary),#ffb347);color:#251437;cursor:pointer;box-shadow:0 12px 28px #f6c74359;transition:transform .2s ease,box-shadow .3s ease,filter .3s ease}button:hover{transform:translateY(-1px);filter:brightness(1.03);box-shadow:0 16px 36px #f6c74366}button:focus-visible{outline:3px solid rgba(246,199,67,.6);outline-offset:3px}input,select,textarea{font-family:inherit}.page-shell{position:relative;min-height:100vh;padding:clamp(24px,3vw,48px);color:var(--text-main);width:100%}.glass-panel{background:var(--surface-glass);border:1px solid var(--surface-border);border-radius:24px;box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(16px) saturate(1.1);backdrop-filter:blur(16px) saturate(1.1)}.surface-card{background:var(--surface-solid);border-radius:22px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-strong)}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.04em}.badge-primary{background:#f6c74338;border:1px solid rgba(246,199,67,.5);color:var(--primary-strong)}.badge-secondary{background:#8a4dff38;border:1px solid rgba(138,77,255,.45);color:#e2d9fff2}.table-container,.estudiantes-table,.tutores-table,.actividades-table,.historial-table-wrapper,.tabla-con-scroll,.card-ranking .table-container,.ranking-card .table-container{-webkit-overflow-scrolling:touch;overscroll-behavior-inline:contain}@media (max-width: 768px){.page-shell{padding:24px 16px 32px}}:root{--primary: #f6c743;--primary-glow: rgba(246, 199, 67, .4);--secondary: #8a4dff;--secondary-glow: rgba(138, 77, 255, .3);--background: #12063c;--panel-bg: rgba(16, 12, 52, .55);--panel-border: rgba(255, 255, 255, .18);--text-main: #f8f9ff;--text-muted: rgba(238, 240, 255, .72);--glass-highlight: rgba(255, 255, 255, .12);--shadow-color: rgba(5, 3, 25, .6);--input-bg: rgba(255, 255, 255, .08);--input-border: rgba(255, 255, 255, .2);--input-focus: rgba(246, 199, 67, .5)}*{box-sizing:border-box}html,body,#root{height:100%;min-height:100vh;margin:0;padding:0;background:#05020f}body{margin:0;font-family:Poppins,Montserrat,system-ui,-apple-system,sans-serif;color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}.login-page{position:relative;height:100vh;width:100vw;color:var(--text-main);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(20px,3vh,40px) clamp(16px,2vw,24px);box-sizing:border-box;background:radial-gradient(circle at 50% 20%,#3a1070,#1f0b4d,#0f0630 70%,#05020f);background-attachment:fixed;background-size:cover;overflow-y:auto;overflow-x:auto}.login-background{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.gradient-layer{position:fixed;top:-60%;right:-60%;bottom:-60%;left:-60%;background:conic-gradient(from 20deg,#ffc75f40,#8a4dff99,#ff6a9e59,#5ea2ff4d,#ffc75f40);animation:gradientRotate 30s cubic-bezier(.45,0,.55,1) infinite;filter:blur(150px);opacity:.8;will-change:transform;z-index:1}.stars{position:fixed;top:-100px;right:-100px;bottom:-100px;left:-100px;background-repeat:repeat;background-size:200px 200px;opacity:.6;animation:drift 60s linear infinite;will-change:transform;z-index:1}.stars--one{background-image:radial-gradient(2px 2px at 10px 20px,rgba(255,255,255,.95),transparent),radial-gradient(2px 2px at 50px 80px,rgba(255,255,255,.75),transparent),radial-gradient(1px 1px at 90px 120px,rgba(255,255,255,.65),transparent),radial-gradient(1.5px 1.5px at 140px 40px,rgba(246,199,67,.8),transparent);animation-duration:70s}.stars--two{background-image:radial-gradient(1.5px 1.5px at 20px 40px,rgba(255,255,255,.65),transparent),radial-gradient(1px 1px at 130px 90px,rgba(255,255,255,.55),transparent),radial-gradient(1.2px 1.2px at 170px 150px,rgba(138,77,255,.7),transparent);animation-duration:95s;opacity:.45}.stars--three{background-image:radial-gradient(1px 1px at 30px 60px,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 80px 140px,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 160px 30px,rgba(255,255,255,.35),transparent);animation-duration:120s;opacity:.3}@keyframes gradientRotate{0%{transform:rotate(0) scale(1.12)}50%{transform:rotate(180deg) scale(1.06)}to{transform:rotate(360deg) scale(1.12)}}@keyframes drift{0%{transform:translateZ(0)}to{transform:translate3d(-200px,-200px,0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.login-content{position:relative;z-index:2;width:min(1200px,100%);height:100%;max-height:100vh;display:flex;flex-direction:column;gap:clamp(16px,2.5vh,32px);align-items:center;text-align:center;animation:fadeInUp .8s ease-out;overflow:hidden}.login-hero{display:flex;flex-direction:column;gap:clamp(6px,1vh,12px);align-items:center;padding:0;flex-shrink:0}.hero-logo{width:clamp(140px,15vw,320px);height:auto;filter:drop-shadow(0 8px 20px rgba(246,199,67,.3)) drop-shadow(0 4px 12px rgba(0,0,0,.4));transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.hero-logo:hover{transform:scale(1.05) rotate(2deg)}.hero-title{font-size:clamp(2rem,4vw,3.5rem);letter-spacing:.1em;font-weight:800;text-transform:uppercase;background:linear-gradient(135deg,var(--primary) 0%,#ffd966 50%,var(--primary) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;text-shadow:0 0 40px var(--primary-glow);animation:shimmer 3s linear infinite;position:relative;line-height:1.1}.hero-title:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:60%;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent);opacity:.6;border-radius:2px}.hero-subtitle{margin:0;font-size:clamp(.85rem,1.8vw,1.1rem);color:var(--text-muted);font-weight:500;letter-spacing:.02em;line-height:1.4}.hero-claim{margin:4px 0 0;font-size:clamp(.8rem,1.6vw,1rem);color:#eef0ffa6;line-height:1.4}.hero-claim span{display:inline;color:var(--primary);font-weight:600;margin-top:0;margin-left:4px;font-size:1em;letter-spacing:.01em}.login-panels{width:100%;flex:1;display:grid;gap:clamp(16px,2vw,24px);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));align-items:stretch;overflow:hidden;max-height:calc(100vh - 280px)}.panel{background:linear-gradient(155deg,#1c1652e6,#140f41d9,#201458a6);border:1px solid var(--panel-border);border-radius:clamp(20px,3vw,32px);padding:clamp(20px,2.5vw,32px);-webkit-backdrop-filter:blur(20px) saturate(1.2);backdrop-filter:blur(20px) saturate(1.2);box-shadow:0 8px 32px #0006,0 2px 8px #8a4dff1a,inset 0 1px 0 var(--glass-highlight);position:relative;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;height:100%}.panel:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);transition:left .5s ease}.panel:hover{transform:translateY(-4px);box-shadow:0 12px 48px #00000080,0 4px 16px #8a4dff33,inset 0 1px 0 var(--glass-highlight)}.panel:hover:before{left:100%}.card-form{display:flex;flex-direction:column;gap:clamp(14px,2vh,20px);text-align:left;position:relative;z-index:1;height:100%}.card-form h2,.card-ranking h2{margin:0;font-size:clamp(1.15rem,1.8vw,1.4rem);font-weight:600;letter-spacing:.02em;color:var(--text-main);position:relative;padding-bottom:8px;flex-shrink:0}.card-form h2:after,.card-ranking h2:after{content:"";position:absolute;bottom:0;left:0;width:50px;height:3px;background:linear-gradient(90deg,var(--primary),transparent);border-radius:2px}.login-form{display:flex;flex-direction:column;gap:clamp(12px,1.5vh,16px)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:clamp(.85rem,1vw,.95rem);color:#f8f9ffe0;font-weight:500;letter-spacing:.01em}.form-group input,.login-form input[type=email],.login-form input[type=password],.login-form input[type=text]{width:100%;padding:clamp(10px,1.2vh,14px) clamp(14px,1.5vw,18px);font-size:clamp(.9rem,1vw,1rem);font-family:inherit;color:var(--text-main);background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:12px;outline:none;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.form-group input::placeholder{color:#eef0ff66}.form-group input:focus{background:#ffffff1f;border-color:var(--primary);box-shadow:0 0 0 3px var(--input-focus),0 4px 12px #f6c74326;transform:translateY(-1px)}.form-group input:hover:not(:focus){border-color:#ffffff4d;background:#ffffff1a}.card-form button,.card-form .button,button[type=submit],.login-form button{width:100%;padding:clamp(11px,1.3vh,15px) clamp(18px,2vw,24px);font-size:clamp(.95rem,1vw,1.05rem);font-weight:600;font-family:inherit;color:#1a0946;background:linear-gradient(135deg,var(--primary) 0%,#ffd966 100%);border:none;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);letter-spacing:.02em;text-transform:none;box-shadow:0 4px 15px #f6c7434d,0 2px 8px #0003;position:relative;overflow:hidden}.card-form button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.card-form button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #f6c74366,0 4px 12px #0000004d;background:linear-gradient(135deg,#ffd966 0%,var(--primary) 100%)}.card-form button:hover:before{left:100%}.card-form button:active{transform:translateY(0);box-shadow:0 2px 8px #f6c7434d}.card-form button:disabled{opacity:.5;cursor:not-allowed;transform:none}.card-form .button.google{background:#ffffff1a;border:1.5px solid rgba(255,255,255,.22);color:#ffffffeb;font-weight:600;letter-spacing:.01em;display:inline-flex;align-items:center;justify-content:center;gap:12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 10px 28px #00000047}.card-form .button.google:hover{background:#ffffff2e;border-color:#ffffff52;color:#fffffff2}.card-form .button.google .button-icon{width:20px;height:20px}.card-form .error-message{margin-top:-4px;padding:10px 14px;border-radius:14px;border:1px solid rgba(255,92,92,.6);background:#ff475726;color:#ffccd5;font-size:.9rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.card-form .divider{display:flex;align-items:center;width:100%;gap:12px;color:var(--text-muted);font-size:clamp(.8rem,1vw,.9rem);margin:2px 0}.card-form .divider:before,.card-form .divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent)}.card-ranking{display:flex;flex-direction:column;gap:clamp(12px,1.8vh,18px);text-align:left;position:relative;z-index:1;height:100%;padding-bottom:clamp(32px,3vh,48px);overflow:hidden}.ranking-header p{margin:4px 0 0;font-size:clamp(.8rem,1vw,.88rem);color:var(--text-muted);line-height:1.4}.ranking-empty{padding:20px;border-radius:16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-muted);text-align:center;font-size:.95rem}.card-ranking .table-container{background:transparent;box-shadow:none;max-height:calc(100% - 60px);overflow-y:auto;overflow-x:auto;border-radius:12px;scrollbar-width:thin;scrollbar-color:rgba(138,77,255,.5) rgba(255,255,255,.05);flex:1;--table-container-bg: transparent;--table-bg: rgba(14, 8, 48, .4);--table-text: rgba(248, 249, 255, .9);--table-head-bg: rgba(138, 77, 255, .35);--table-head-text: rgba(255, 255, 255, .9);--table-head-transform: uppercase;--table-border: 1px solid rgba(255, 255, 255, .08);--table-hover-bg: rgba(138, 77, 255, .2);--table-cell-padding: clamp(8px, 1vh, 12px) clamp(10px, 1.2vw, 14px);--table-font-size: clamp(.78rem, .95vw, .88rem);--table-radius: 12px;--table-min-width: 420px}.card-ranking .table-container::-webkit-scrollbar{width:6px}.card-ranking .table-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.card-ranking .table-container::-webkit-scrollbar-thumb{background:#8a4dff80;border-radius:10px}.card-ranking .table-container::-webkit-scrollbar-thumb:hover{background:#8a4dffb3}.card-ranking table{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.card-ranking table tr:hover{background:none;transform:none}.card-ranking thead,.card-ranking thead tr,.card-ranking thead th{pointer-events:auto}.card-ranking thead tr{position:sticky;top:0;z-index:2;background-color:#05020f;box-shadow:0 4px 12px #05031940}.card-ranking thead tr:hover,.card-ranking thead th:hover{background-color:#05020f;transform:none}.card-ranking table tbody tr{transition:background .2s ease,transform .2s ease}.card-ranking table tbody tr:hover{background:var(--table-hover-bg);transform:translate(2px)}@supports (height: 100dvh){.login-page{min-height:100dvh}}@media (max-width: 768px){.login-content{width:100%;max-width:560px;margin:0 auto;max-height:none!important;overflow:visible}.login-page{height:auto;padding:20px 14px;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 14px);background-attachment:scroll}.gradient-layer{filter:blur(120px);opacity:.55}.stars{opacity:.35}.hero-logo{width:68px}.hero-title{letter-spacing:.06em;text-shadow:none;animation:none}.hero-title:after,.hero-claim{display:none}.hero-subtitle{font-size:.95rem}.login-panels{grid-template-columns:1fr;gap:14px;max-height:none!important;overflow:visible}.panel{padding:16px;border-radius:16px;-webkit-backdrop-filter:blur(12px) saturate(1.05);backdrop-filter:blur(12px) saturate(1.05);box-shadow:0 6px 18px #00000059;height:auto;overflow:visible}.card-form h2,.card-ranking h2{font-size:1.05rem}.card-ranking{max-height:52vh;overflow:hidden;margin-bottom:20px}.form-group input{padding:12px 14px;border-radius:10px;background:#ffffff17;border:1.2px solid var(--input-border)}.form-group input:focus{box-shadow:0 0 0 3px var(--input-focus);transform:none}.card-form button,.login-form button,button[type=submit]{padding:12px 16px;font-size:1rem;border-radius:12px;background:var(--primary);box-shadow:0 4px 12px #f6c74359,0 2px 8px #0003}.card-form button:hover{transform:none}.card-ranking .table-container{max-height:min(320px,44vh);--table-font-size: .82rem;--table-cell-padding: 10px 12px;--table-head-bg: rgba(138, 77, 255, .28);--table-min-width: 360px;overflow-y:auto;overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 380px),(max-height: 600px){.hero-subtitle{display:none}.panel{padding:14px}}.button{padding:12px 18px;font-size:.96rem;font-weight:600;border-radius:14px;border:1px solid transparent;cursor:pointer;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .2s ease,box-shadow .25s ease,filter .25s ease;text-decoration:none;white-space:nowrap}.button.primary{background:linear-gradient(135deg,var(--primary),#ffb347);color:#26143d;box-shadow:0 14px 26px #f6c74352}.button.primary:hover{transform:translateY(-1px);box-shadow:0 18px 34px #f6c74366;filter:brightness(1.04)}.button.secondary{background:#ffffff14;border:1px solid rgba(255,255,255,.16);color:var(--text-main);box-shadow:0 12px 26px #00000040}.button.secondary:hover{transform:translateY(-1px);background:#ffffff24}.button.danger{background:linear-gradient(135deg,#ff6a9e,#ff3f6d);color:#fff;box-shadow:0 14px 30px #ff6a9e59}.button.danger:hover{transform:translateY(-1px);box-shadow:0 18px 36px #ff6a9e6b}.button.black{background:linear-gradient(135deg,#180d36f2,#10092aeb);border:1px solid rgba(255,255,255,.14);color:var(--text-main);box-shadow:0 12px 26px #05031473}.button.black:hover{transform:translateY(-2px);filter:brightness(1.02)}.button.white{background:#fffffff0;color:#1f0f35;border:1px solid rgba(255,255,255,.6);box-shadow:0 16px 34px #ffffff2e}.button.white:hover{transform:translateY(-1px);filter:brightness(1.05)}.button-text{display:inline-block}.button-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:currentColor}.button-icon img,.button-icon svg{width:100%;height:100%;display:block}.navbar-container.collapsed .button{justify-content:center;gap:0}.navbar-container.collapsed .button-text{display:none}.navbar-container.collapsed .button-icon{width:24px;height:24px}@media screen and (max-width: 576px){.navbar-container.collapsed .button{padding:10px 12px}.navbar-container.collapsed .button-text{font-size:0}}.table-container{width:100%;overflow-x:auto;overflow-y:auto;background:var(--surface-glass);border-radius:22px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(16px) saturate(1.08);backdrop-filter:blur(16px) saturate(1.08)}.table{width:100%;min-width:var(--table-min-width, 0);border-collapse:collapse;font-size:var(--table-font-size, .94rem);text-align:left;background:#0f0a30bf;color:var(--table-text, var(--text-main))}.table th,.table td{padding:var(--table-cell-padding, 14px 16px);border-bottom:var(--table-border, 1px solid rgba(255, 255, 255, .1))}.table th{font-weight:600;text-transform:var(--table-head-transform, uppercase);letter-spacing:.08em;background:var(--table-head-bg, rgba(138, 77, 255, .28));color:var(--table-head-text, rgba(255, 255, 255, .92))}.table tr:hover{background:var(--table-hover-bg, rgba(138, 77, 255, .16))}.text-field{width:100%;padding:12px 16px;font-size:.95rem;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.text-field::placeholder{color:#ebeeff94}.text-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f6c7434d;background:#ffffff1f}.text-field[disabled]{opacity:.65;cursor:not-allowed}.navbar-container{position:fixed;top:0;left:0;height:100vh;width:220px;display:flex;flex-direction:column;justify-content:space-between;padding:24px 18px;box-sizing:border-box;transition:width .3s ease,padding .3s ease,transform .3s ease;overflow:hidden;z-index:1000;color:var(--text-main);background:linear-gradient(190deg,#140c3aeb,#08051cf2);border-right:1px solid rgba(255,255,255,.12);box-shadow:0 24px 48px #0503148c;-webkit-backdrop-filter:blur(18px) saturate(1.12);backdrop-filter:blur(18px) saturate(1.12);isolation:isolate}.mobile-menu-toggle{display:none}.navbar-container:before{content:"";position:absolute;top:-120%;right:-80%;bottom:-120%;left:-80%;background:radial-gradient(circle at 40% 20%,rgba(246,199,67,.32),transparent 55%),radial-gradient(circle at 60% 80%,rgba(138,77,255,.26),transparent 60%);animation:navbarGlow 18s linear infinite;opacity:.6;z-index:0}@keyframes navbarGlow{0%{transform:rotate(0) scale(1.05)}50%{transform:rotate(180deg) scale(1.12)}to{transform:rotate(360deg) scale(1.05)}}.navbar-inner-scroll{flex:1;overflow-y:auto;padding-right:6px;position:relative;z-index:1}.navbar-container.collapsed{width:80px;padding:24px 12px}.navbar-header{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:20px}.navbar-logo{width:120px;height:auto;object-fit:contain;transition:width .3s ease,opacity .3s ease}.navbar-header h2{margin:0;font-size:1rem;font-weight:700;letter-spacing:.04em;text-align:center;color:var(--text-main)}.navbar-buttons{display:flex;flex-direction:column;gap:12px}.navbar-buttons .button{width:100%}.navbar-footer{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:18px;align-items:center;position:relative;z-index:1}.navbar-footer-logo img{width:80px;filter:drop-shadow(0 10px 18px rgba(0,0,0,.35))}.navbar-user-card{width:100%;display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:18px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(135deg,#f6c74338,#8a4dff2e);box-shadow:0 16px 32px #05031459}.navbar-photo{display:grid;place-items:center;padding:0;border:none;background:#ffffff24;border-radius:14px;width:52px;height:52px;box-shadow:inset 0 0 12px #ffffff29;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.navbar-photo img{width:44px;height:44px;border-radius:50%;border:2px solid rgba(255,255,255,.28);box-shadow:0 12px 28px #05031459}.navbar-photo:hover{transform:translateY(-2px);box-shadow:inset 0 0 16px #ffffff3d}.navbar-user-meta{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.navbar-user-role{font-weight:600;font-size:.92rem;color:#ffffffeb;letter-spacing:.04em;text-transform:uppercase}.navbar-logout{border:none;background:transparent;color:#ffffffbf;font-size:.78rem;font-weight:500;padding:0;cursor:pointer;transition:color .2s ease}.navbar-logout:hover{color:var(--primary)}.navbar-container.collapsed .navbar-logo,.navbar-container.collapsed h2{opacity:0;width:0;margin:0}.navbar-container.collapsed .navbar-user-card{justify-content:center;padding:10px;background:#ffffff1f;box-shadow:0 12px 26px #0503144d}.navbar-container.collapsed .navbar-user-card .navbar-user-meta{display:none}@media (max-width: 768px){.navbar-mobile-header{position:sticky;top:0;z-index:1100;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;margin-bottom:12px;background:linear-gradient(190deg,#140c3aeb,#08051ce0);border-bottom:1px solid rgba(255,255,255,.12);box-shadow:0 12px 28px #05031459}.navbar-mobile-title{font-size:1.1rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffffe6}.mobile-menu-toggle{position:fixed;top:18px;left:18px;width:44px;height:44px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:none;border-radius:14px;background:#0b0722db;color:inherit;cursor:pointer;z-index:1101;box-shadow:0 12px 28px #05031459}.mobile-menu-toggle span{width:24px;height:2px;border-radius:999px;background:#ffffffe6;transition:transform .25s ease,opacity .25s ease}.mobile-menu-toggle.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}.mobile-menu-toggle.active span:nth-child(2){opacity:0}.mobile-menu-toggle.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.navbar-mobile-header .mobile-menu-toggle{position:static;width:44px;height:44px;box-shadow:0 8px 20px #05031459}.mobile-menu-toggle{position:fixed}.navbar-container{transform:translate(-100%);width:220px}.navbar-container.open{transform:translate(0)}.navbar-container.hidden{transform:translate(-100%)}}@media (min-width: 769px){.navbar-mobile-header{display:none}}:root{--dashboard-gap: clamp(18px, 2vw, 26px)}.dashboard-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,44px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;isolation:isolate}.dashboard-container:before{content:"";position:fixed;top:0;left:0;width:200vmax;height:200vmax;pointer-events:none;background:radial-gradient(50% 50% at 30% 20%,rgba(246,199,67,.22),transparent 70%),radial-gradient(50% 50% at 70% 65%,rgba(138,77,255,.3),transparent 72%),radial-gradient(45% 45% at 20% 70%,rgba(94,162,255,.18),transparent 78%);filter:blur(140px);opacity:.55;transform:translate(-50vmax,-60vmax);z-index:-1}.dashboard-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 32px 36px,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.32),transparent);opacity:.28;z-index:0}.dashboard-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}.dashboard-content{position:relative;z-index:1;background:linear-gradient(150deg,#120c3adb,#090620e6);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(24px,3vw,36px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:var(--dashboard-gap)}.dashboard-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08)}.dashboard-title{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;letter-spacing:.05em;margin:0}.dashboard-fecha{color:var(--text-muted);font-size:.95rem}.dashboard-tabs{display:flex;flex-wrap:wrap;gap:12px}.dashboard-tab{padding:12px 18px;border-radius:16px;border:1px solid transparent;background:#ffffff14;color:var(--text-muted);font-weight:600;cursor:pointer;transition:all .25s ease}.dashboard-tab:hover,.dashboard-tab.active{color:var(--text-main);border-color:#f6c74373;box-shadow:0 10px 24px #f6c74340;background:#f6c7432e}.dashboard-main{display:flex;flex-direction:column;gap:var(--dashboard-gap)}.dashboard-secondary-row>:first-child{grid-column:1 / -1}.dashboard-secondary-row{display:grid;grid-template-columns:3fr 1fr;gap:var(--dashboard-gap);align-items:start}.dashboard-card,.dashboard-actividades-recientes,.dashboard-grafico-container,.dashboard-columna-izquierda{background:#0b0722b8;border-radius:24px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;overflow:hidden}.dashboard-card-header{padding:clamp(16px,2vw,22px);display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--text-main)}.dashboard-card-body{padding:clamp(18px,2vw,24px);display:flex;flex-direction:column;gap:16px}.actividades-table{width:100%;border-collapse:collapse;min-width:720px}.actividades-table th,.actividades-table td{padding:12px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}.actividades-table th{text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;background:#8a4dff47;color:#ffffffe6}.dashboard-stat-card{background:#ffffff0f;border-radius:20px;border:1px solid rgba(255,255,255,.1);padding:18px;display:flex;gap:12px;align-items:center}.dashboard-select{padding:10px 16px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);background-color:#120c3ab8}.dashboard-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #f6c74347;outline:none}.tabla-con-scroll{max-height:360px;overflow-y:auto;overflow-x:auto;border-radius:18px;box-shadow:inset 0 0 12px #05031959;-webkit-overflow-scrolling:touch}@media (max-width: 1200px){.dashboard-secondary-row{grid-template-columns:minmax(0,1fr)}}@media (max-width: 1024px){.dashboard-container{margin-left:180px;width:calc(100vw - 180px)}.dashboard-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}}@media (max-width: 768px){.dashboard-container,.dashboard-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.dashboard-content{border-radius:22px;padding:18px}.dashboard-tabs{width:100%;overflow-x:auto}}.dashboard-loading{display:grid;place-items:center;padding:40px 0}.dashboard-spinner{width:42px;height:42px;border-radius:50%;border:4px solid rgba(255,255,255,.15);border-top-color:var(--primary);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tipo-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:#f6c7432e;color:var(--primary-strong)}.no-actividades,.no-actividad-seleccionada{padding:clamp(18px,2vw,24px);border-radius:18px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#ecefffa6;text-align:center}.mensaje-seleccion{display:flex;flex-direction:column;align-items:center;gap:8px}.icono-seleccion{font-size:2rem}.grafico-container-centrado{display:flex;flex-direction:column;align-items:center;gap:20px}.grafico-circular-container{display:grid;place-items:center}.grafico-circular{width:220px;height:220px;border-radius:50%;position:relative;display:grid;place-items:center;box-shadow:inset 0 0 22px #00000073}.circulo-centro{width:120px;height:120px;border-radius:50%;background:#0b0722c7;display:grid;place-items:center;gap:4px}.circulo-total{font-size:1.8rem;font-weight:700}.circulo-label{font-size:.85rem;color:var(--text-muted)}.grafico-mini-leyenda{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.mini-leyenda-item{display:flex;align-items:center;gap:8px;background:#ffffff14;border-radius:14px;padding:10px 14px}.mini-leyenda-color{width:14px;height:14px;border-radius:50%}.dashboard-download-btn{background:#ffffff14}.dashboard-download-btn:hover{background:#ffffff24}:root{--student-primary: #f6c743;--student-secondary: #8a4dff;--student-surface: rgba(18, 12, 58, .72);--student-border: rgba(255, 255, 255, .14);--student-text: #f8f9ff;--student-text-muted: rgba(238, 240, 255, .72);--student-gap: clamp(8px, 1.2vw, 16px);--student-margin: clamp(10px, 1.5vw, 20px);--navbar-current-width: 220px}.perfil-container{position:relative;min-height:100vh;margin-left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px));padding:var(--student-margin);box-sizing:border-box;background:radial-gradient(circle at 50% 18%,#32146b,#1c0c48 35%,#0a0424 65%,#05020f);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;isolation:isolate}.perfil-container:before{content:"";position:fixed;top:0;left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px));height:100vh;pointer-events:none;background:radial-gradient(55% 55% at 30% 20%,rgba(246,199,67,.24),transparent 70%),radial-gradient(50% 50% at 70% 65%,rgba(138,77,255,.3),transparent 72%),radial-gradient(45% 45% at 20% 70%,rgba(94,162,255,.2),transparent 80%);filter:blur(140px);opacity:.62;z-index:-1}.perfil-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 32px 36px,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.34),transparent);opacity:.3;z-index:0}.perfil-container.navbar-collapsed{margin-left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px))}.perfil-container.navbar-collapsed:before{left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px))}.perfil-content{position:relative;z-index:1;max-width:1280px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:var(--student-gap);color:var(--student-text);padding:0 var(--student-margin) var(--student-margin)}.perfil-header-logo{display:flex;align-items:center;gap:12px;margin-bottom:var(--student-gap)}.perfil-logo{height:clamp(45px,5.5vw,65px);width:auto;filter:drop-shadow(0 14px 30px rgba(246,199,67,.35))}.perfil-title{font-size:clamp(1.6rem,2.8vw,2.2rem);letter-spacing:.06em;font-weight:700;margin:0}.perfil-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:var(--student-gap);align-items:start;margin:var(--student-margin) 0}.perfil-card,.estadistica-card,.actividades-card{background:var(--student-surface);border-radius:clamp(20px,2.2vw,26px);border:1px solid var(--student-border);padding:var(--student-margin);box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;gap:var(--student-gap)}.perfil-info-card{gap:var(--student-gap)}.perfil-header{display:flex;flex-wrap:wrap;gap:var(--student-gap);align-items:center}.perfil-avatar-container{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:2%;text-align:center}.perfil-avatar{width:clamp(110px,14vw,150px);height:clamp(110px,14vw,150px);border-radius:50%;border:4px solid rgba(255,255,255,.85);object-fit:cover;box-shadow:0 16px 36px #00000073}.perfil-nivel-badge{bottom:4px;right:4px;padding:6px 14px;border-radius:999px;background:linear-gradient(135deg,var(--student-primary),#ffd96b);color:#1b0b4c;font-weight:600;letter-spacing:.05em;box-shadow:0 12px 24px #f6c74359;white-space:nowrap}.perfil-info-principal{flex:1;min-width:240px}.perfil-nombre{margin:0 0 6px;font-size:clamp(1.6rem,2.8vw,2.2rem);font-weight:700;line-height:1.2}.perfil-carrera{margin:0 0 var(--student-gap) 0;color:var(--student-text-muted);font-size:clamp(.95rem,1.6vw,1.08rem);line-height:1.4}.perfil-nivel-info{background:#ffffff14;border-radius:clamp(12px,1.5vw,16px);padding:var(--student-gap);display:flex;flex-direction:column;gap:clamp(10px,1.4vw,14px)}.perfil-nivel-info p{margin:0;font-size:clamp(.9rem,1.5vw,1rem);line-height:1.5}.nivel-barra{height:10px;border-radius:999px;background:#ffffff24;overflow:hidden;width:100%}.nivel-progreso{height:100%;border-radius:inherit;background:linear-gradient(135deg,var(--student-primary),var(--student-secondary));transition:width .6s ease}.perfil-datos{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--student-gap);color:var(--student-text-muted)}.perfil-datos p{margin:0;font-size:clamp(.88rem,1.5vw,.98rem);line-height:1.6}.datos-etiqueta{color:var(--student-text);font-weight:600;display:inline}.estadisticas-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--student-gap)}.estadistica-card{flex-direction:row;align-items:center;gap:var(--student-gap);padding:var(--student-gap)}.estadistica-icono{width:clamp(42px,6vw,52px);height:clamp(42px,6vw,52px);border-radius:12px;display:grid;place-items:center;background:#ffffff1f;font-size:clamp(1.1rem,2vw,1.3rem);flex-shrink:0}.estadistica-info{flex:1;min-width:0}.estadistica-info h3{margin:0 0 2px;font-size:clamp(1.2rem,2.2vw,1.5rem);font-weight:700;line-height:1.2}.estadistica-info p{margin:0;font-size:clamp(.85rem,1.4vw,.92rem);color:var(--student-text-muted);line-height:1.4}.actividades-card{gap:var(--student-gap)}.actividades-lista{max-height:320px;overflow-x:auto;overflow-y:auto;border-radius:18px;box-shadow:inset 0 0 12px #05031940}.actividades-card h2{margin:0;font-size:clamp(1.2rem,2vw,1.5rem);font-weight:700;line-height:1.3}.perfil-actividades-table{width:100%;border-collapse:collapse;color:var(--student-text);font-size:clamp(.88rem,1.5vw,.96rem)}.perfil-actividades-table th,.perfil-actividades-table td{padding:var(--student-gap);border-bottom:1px solid rgba(255,255,255,.1);text-align:left;line-height:1.5}.perfil-actividades-table thead tr{background:#ffffff1f}.perfil-actividades-table th{font-weight:600}.perfil-actividades-table tbody tr:hover{background:#ffffff0d;transition:background .2s ease}.no-actividades{padding:var(--student-gap);border-radius:14px;background:#ffffff14;text-align:center;color:var(--student-text-muted);font-size:clamp(.9rem,1.5vw,1rem)}.perfil-historial-credito{font-weight:600}.perfil-historial-credito.positivo{color:#6ee7b7}.perfil-historial-credito.negativo{color:#fecaca}.tipo-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;text-transform:capitalize;font-size:.78rem;background:#ffffff14}.tipo-asistencia{color:#6ee7b7;background:#10b9812e}.tipo-bonus{color:#bfdbfe;background:#3b82f62e}.tipo-cobro{color:#fecaca;background:#ef44442e}.autor-col{display:flex;flex-direction:column;gap:2px}.nivel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--student-margin);margin:0;overflow:hidden;isolation:isolate}.nivel-overlay:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(140deg,#060316d1,#0603168c);z-index:1;pointer-events:none;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.nivel-modal{background:linear-gradient(150deg,#1b1246fa,#0e0a30f2);border-radius:clamp(16px,2.5vw,24px);border:1px solid rgba(255,255,255,.25);padding:var(--student-margin);max-width:min(420px,90vw);width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0009;display:flex;flex-direction:column;gap:var(--student-gap);text-align:center;position:relative;z-index:10000}.nivel-modal h2{margin:0;font-size:clamp(1.4rem,3.5vw,1.8rem);font-weight:700;color:var(--student-primary)}.nivel-modal p{margin:0;font-size:clamp(.95rem,2vw,1.05rem);line-height:1.6;color:var(--student-text)}.nivel-modal button{padding:var(--student-gap) clamp(20px,4vw,32px);border-radius:12px;border:none;background:linear-gradient(135deg,var(--student-primary),#ffd96b);color:#1b0b4c;font-weight:700;font-size:clamp(.95rem,2vw,1.05rem);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-top:var(--student-gap)}.nivel-modal button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #f6c74366}.nivel-overlay .nivel-video-wrapper{position:relative;top:0;right:0;bottom:0;left:0;width:100%;height:100vh;max-width:100%;max-height:100vh;background:transparent;display:flex;align-items:center;justify-content:center;z-index:2;overflow:hidden}.nivel-overlay .nivel-video-full{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100vh;max-width:100%;max-height:100vh;object-fit:contain;object-position:center;z-index:1}.nivel-overlay .nivel-video-background{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100vh;max-width:100%;max-height:100vh;object-fit:cover;object-position:center;filter:blur(40px) saturate(180%) brightness(.8);opacity:.5;z-index:0;transform:scale(1.2)}.nivel-video-skip{position:fixed;bottom:var(--student-margin);right:var(--student-margin);padding:var(--student-gap) clamp(18px,3vw,26px);border-radius:999px;border:2px solid rgba(255,255,255,.3);background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-weight:600;font-size:clamp(.9rem,1.8vw,1.05rem);cursor:pointer;z-index:10001;transition:all .3s ease;white-space:nowrap}.nivel-video-skip:hover{background:#000000d9;border-color:#ffffff80;transform:scale(1.05)}.perfil-desbloqueado-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#060316e6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--student-margin);overflow-y:auto}.perfil-desbloqueado-modal{background:linear-gradient(150deg,#1b1246fa,#0e0a30f2);border-radius:clamp(20px,3vw,28px);border:1px solid rgba(255,255,255,.25);padding:var(--student-margin);max-width:min(500px,90vw);width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 72px #000000b3;display:flex;flex-direction:column;gap:var(--student-gap);align-items:center;text-align:center}.perfil-desbloqueado-modal h2{margin:0;font-size:clamp(1.5rem,4vw,2rem);font-weight:700;background:linear-gradient(135deg,var(--student-primary),#ffd96b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.perfil-desbloqueado-imagen-container{position:relative;width:clamp(150px,40vw,240px);height:clamp(150px,40vw,240px);max-width:240px;max-height:240px;border-radius:50%;overflow:hidden;border:4px solid rgba(246,199,67,.6);box-shadow:0 20px 50px #f6c7434d;flex-shrink:0}.perfil-desbloqueado-imagen-container img{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:cover;object-position:center;display:block}.perfil-desbloqueado-modal p{margin:0;font-size:clamp(1rem,2.2vw,1.15rem);line-height:1.6;color:var(--student-text-muted);max-width:400px}.perfil-desbloqueado-modal button{padding:var(--student-gap) clamp(28px,5vw,40px);border-radius:14px;border:none;background:linear-gradient(135deg,var(--student-primary),#ffd96b);color:#1b0b4c;font-weight:700;font-size:clamp(1rem,2.2vw,1.1rem);cursor:pointer;transition:all .3s ease;margin-top:var(--student-gap);white-space:nowrap}.perfil-desbloqueado-modal button:hover{transform:translateY(-3px);box-shadow:0 12px 32px #f6c74380}body,html{overflow-x:hidden;max-width:100%}.nivel-overlay,.perfil-desbloqueado-overlay{overflow-x:hidden;overflow-y:hidden;max-width:100%;max-height:100vh}.nivel-overlay img,.nivel-overlay video,.perfil-desbloqueado-overlay img{max-width:100%;max-height:100%;display:block}.nivel-modal,.perfil-desbloqueado-modal{box-sizing:border-box;max-width:min(420px,90vw);max-height:90vh}.nivel-modal *,.perfil-desbloqueado-modal *{box-sizing:border-box;max-width:100%}@media (max-width: 1024px){.perfil-container{margin-left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px))}.perfil-container:before{left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px))}.perfil-container.navbar-collapsed{margin-left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px))}.perfil-container.navbar-collapsed:before{left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px))}.perfil-grid{grid-template-columns:1fr}.estadisticas-container{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width: 768px){.perfil-container,.perfil-container.navbar-collapsed{margin-left:0;width:100%;padding:var(--student-gap)}.perfil-container:before,.perfil-container.navbar-collapsed:before{left:0;width:100%}.perfil-grid{grid-template-columns:1fr}.perfil-header{flex-direction:column;align-items:center;text-align:center}.perfil-nombre,.perfil-carrera{text-align:center}.estadisticas-container,.perfil-datos{grid-template-columns:1fr}.perfil-card,.estadistica-card,.actividades-card{border-radius:clamp(16px,2vw,20px);padding:var(--student-gap)}}@media (max-width: 480px){.perfil-actividades-table{font-size:clamp(.8rem,1.4vw,.9rem)}.perfil-actividades-table th,.perfil-actividades-table td{padding:clamp(8px,1.2vw,12px)}.nivel-modal,.perfil-desbloqueado-modal{padding:var(--student-gap);width:95%}.perfil-desbloqueado-imagen-container{width:clamp(120px,30vw,160px);height:clamp(120px,30vw,160px)}}@media (max-height: 600px) and (orientation: landscape){.nivel-modal,.perfil-desbloqueado-modal{max-height:95vh;padding:var(--student-gap);gap:clamp(10px,1.5vw,14px)}.perfil-desbloqueado-imagen-container{width:clamp(100px,25vw,120px);height:clamp(100px,25vw,120px)}.nivel-video-skip{bottom:var(--student-gap);right:var(--student-gap);padding:clamp(8px,1.2vw,12px) clamp(12px,2vw,16px);font-size:clamp(.8rem,1.6vw,.9rem)}.nivel-overlay .nivel-video-full{width:auto;height:100vh;max-height:100vh}}@media (orientation: portrait){.nivel-overlay .nivel-video-full{width:100%;height:auto;max-width:100%}}.tutores-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;-webkit-overflow-scrolling:touch}.tutores-container:before{content:"";position:absolute;top:-45%;right:-45%;bottom:-45%;left:-45%;background:conic-gradient(from 30deg,#f6c74338,#8a4dff80,#5ea2ff4d,#ff6a9e47);filter:blur(150px);opacity:.75;z-index:0}.tutores-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 32px 36px,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.32),transparent);opacity:.28;z-index:0}.tutores-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}.tutores-content{position:relative;z-index:1;flex:1;background:linear-gradient(150deg,#120c3adb,#090620e6);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(20px,2.6vw,32px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(18px,2.2vw,24px)}.tutores-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.tutores-title{font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:700;margin:0}.tutores-table{width:100%;background:#0b0722c7;border-radius:22px;border:1px solid rgba(255,255,255,.12);overflow:hidden;box-shadow:var(--shadow-soft);min-width:0}.tutores-table__scroll{width:100%;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-inline:contain;min-width:0}.tutores-table table{width:max-content;min-width:720px;table-layout:auto;border-collapse:collapse;display:table}.tutores-table th,.tutores-table td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.tutores-table th{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;background:#8a4dff47;color:#ffffffe6}.tutores-table tbody tr:hover{background:#8a4dff24}.tutores-table .action-buttons{display:flex;align-items:center;justify-content:center;gap:8px}.tutores-table .action-button{border:none;background:transparent;padding:6px;border-radius:12px;cursor:pointer;transition:transform .2s ease,background-color .2s ease;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center}.tutores-table .action-button:hover{transform:translateY(-1px);background-color:#8a4dff2e}.tutores-table .action-button img{width:20px;height:20px;display:block;object-fit:contain}@media (max-width: 1024px){.tutores-container{margin-left:180px;width:calc(100vw - 180px)}.tutores-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}}@media (max-width: 768px){.tutores-container,.tutores-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.tutores-content{border-radius:22px;padding:18px}}.create-tutores-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;-webkit-overflow-scrolling:touch}.create-tutores-container:before{content:"";position:absolute;top:-45%;right:-45%;bottom:-45%;left:-45%;background:conic-gradient(from 28deg,#f6c74338,#8a4dff80,#5ea2ff4d,#ff6a9e47);filter:blur(150px);opacity:.75;z-index:0}.create-tutores-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 32px 40px,rgba(255,255,255,.52),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.32),transparent);opacity:.28;z-index:0}.create-tutores-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}.create-tutores-content{position:relative;z-index:1;flex:1;background:linear-gradient(150deg,#120c3adb,#090620e6);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(20px,2.8vw,34px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(18px,2.4vw,26px)}.create-tutores-title{font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:700;margin:0;letter-spacing:.05em}.create-tutores-subtitle{margin:-6px 0 0;color:var(--text-muted)}.info-container,.academic-container{background:#0b0722b8;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:clamp(20px,2.6vw,30px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(14px,1.8vw,20px)}.input-group input,.input-group select{width:100%;padding:12px 16px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease}@media (max-width: 1024px){.create-tutores-container{margin-left:180px;width:calc(100vw - 180px)}.create-tutores-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}}@media (max-width: 768px){.create-tutores-container,.create-tutores-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.create-tutores-content{border-radius:22px;padding:18px}.action-buttons{justify-content:flex-start}}.create-estudiante-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;-webkit-overflow-scrolling:touch}.create-estudiante-container:before{content:"";position:absolute;top:-45%;right:-45%;bottom:-45%;left:-45%;background:conic-gradient(from 32deg,#f6c74338,#8a4dff80,#5ea2ff4d,#ff6a9e47);filter:blur(150px);opacity:.75;z-index:0}.create-estudiante-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 32px 40px,rgba(255,255,255,.52),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.32),transparent);opacity:.28;z-index:0}.create-estudiante-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}.create-estudiante-content{position:relative;z-index:1;flex:1;background:linear-gradient(150deg,#120c3adb,#090620e6);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(20px,2.8vw,34px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(18px,2.4vw,26px)}.create-estudiante-title{font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:700;margin:0;letter-spacing:.05em}.create-estudiante-subtitle{margin:-6px 0 0;color:var(--text-muted)}.info-container,.academic-container,.password-container{background:#0b0722b8;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:clamp(20px,2.6vw,30px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(14px,1.8vw,20px)}.info-title,.academic-title,.password-title{font-size:1.2rem;font-weight:600;color:var(--primary);margin:0}.info-subtitle,.academic-subtitle{color:var(--text-muted);margin:-4px 0 0}.info-grid,.academic-grid,.password-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-size:.9rem;font-weight:600;color:var(--text-muted)}.input-group input,.input-group select{width:auto;padding:12px 16px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease}.input-group input:focus,.input-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #f6c74347;outline:none}@media (max-width: 1024px){.create-estudiante-container{margin-left:180px;width:calc(100vw - 180px)}.create-estudiante-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}}@media (max-width: 768px){.create-estudiante-container,.create-estudiante-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.create-estudiante-content{border-radius:22px;padding:18px}.action-buttons{justify-content:flex-start}}.estudiantes-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;-webkit-overflow-scrolling:touch;isolation:isolate}.estudiantes-container:before{content:"";position:fixed;top:0;left:0;width:200vmax;height:200vmax;pointer-events:none;background:radial-gradient(50% 50% at 30% 20%,rgba(246,199,67,.25),transparent 70%),radial-gradient(50% 50% at 70% 60%,rgba(138,77,255,.32),transparent 72%),radial-gradient(45% 45% at 20% 75%,rgba(94,162,255,.2),transparent 80%);filter:blur(140px);opacity:.58;transform:translate(-48vmax,-58vmax);z-index:-1}.estudiantes-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 32px 36px,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.32),transparent);opacity:.28;z-index:0}.estudiantes-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}.estudiantes-content{position:relative;z-index:1;width:min(1080px,100%);margin:0 auto;min-height:calc(100vh - (clamp(24px,3vw,40px)*2));background:linear-gradient(150deg,#120c3adb,#090620e6);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(22px,3vw,34px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(18px,2.4vw,26px)}.estudiantes-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:12px}.estudiantes-title{font-size:clamp(1.6rem,2.6vw,2.3rem);font-weight:700;margin:0;letter-spacing:.05em}.estudiantes-subtitle{color:var(--text-muted)}.estudiantes-filters{display:flex;flex-wrap:wrap;gap:16px;align-items:stretch}.estudiantes-search{flex:1 1 240px;display:flex}.filters-right{display:flex;gap:12px;align-items:center}.filters-right select{padding:10px 14px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease}.estudiantes-body{display:grid;gap:clamp(18px,2.4vw,26px)}.estudiantes-table{width:100%;background:#0b0722bf;border-radius:22px;border:1px solid rgba(255,255,255,.12);overflow-x:auto;overflow-y:auto;box-shadow:var(--shadow-soft)}.estudiantes-table table{width:100%;min-width:720px;border-collapse:collapse}.estudiantes-table th,.estudiantes-table td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08);color:var(--text-main)}.estudiantes-table th{text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;background:#8a4dff47;color:#ffffffe6}.estudiantes-table tbody tr:hover{background:#8a4dff24}.estudiantes-table .action-buttons{display:flex;align-items:center;justify-content:center;gap:8px}.estudiantes-table .action-button{border:none;background:transparent;padding:6px;border-radius:12px;cursor:pointer;transition:transform .2s ease,background-color .2s ease;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center}.estudiantes-table .action-button:hover{transform:translateY(-1px);background-color:#8a4dff2e}.estudiantes-table .action-button img{width:20px;height:20px;display:block;object-fit:contain}.cobrar-puntos-container,.estudiantes-form-panel{background:#0b0722b8;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:clamp(20px,2.4vw,30px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(14px,1.8vw,20px)}.cobrar-puntos-container .error-message{background:#ef44441f;border:1px solid rgba(239,68,68,.45);color:#fecaca;border-radius:12px;padding:10px 14px;font-size:.9rem}.success-message{background:#10b9811f;border:1px solid rgba(16,185,129,.45);color:#a7f3d0;border-radius:12px;padding:12px 16px;font-size:.92rem}.success-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-top:8px}.creditos-stack{display:flex;flex-direction:column;gap:20px;margin-top:1.5rem}.cobrar-card{background:#0a0720eb;border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:clamp(18px,2vw,26px);display:flex;flex-direction:column;gap:18px;box-shadow:0 20px 45px #05031966,0 8px 16px #0000004d,inset 0 1px #ffffff0d;transition:all .3s ease}.cobrar-card:hover{box-shadow:0 24px 55px #05031980,0 12px 20px #00000059,inset 0 1px #ffffff14;transform:translateY(-2px)}.cobrar-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08);flex-wrap:wrap}.cobrar-pretitle{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#ffffff80;margin:0 0 4px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.cobrar-header h2{margin:0;font-size:1.5rem;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.4)}.cobrar-saldos{display:flex;gap:12px;flex-wrap:wrap}.cobrar-saldos>div{display:flex;flex-direction:column;align-items:flex-end;gap:2px;padding:8px 12px;background:#ffffff0d;border-radius:8px;box-shadow:inset 0 1px 3px #0003,0 1px 2px #ffffff0d}.cobrar-saldos span{font-size:.7rem;color:#fff9;text-shadow:0 1px 2px rgba(0,0,0,.3)}.cobrar-saldos strong{font-size:1.25rem;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.cobrar-info{padding:10px 14px;background:#ffffff0a;border-radius:10px;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 3px #00000026,0 1px 2px #ffffff0d}.cobrar-info p{margin:0;font-size:.9rem;color:#ffffffb3;text-shadow:0 1px 2px rgba(0,0,0,.3)}.cobrar-info strong{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4)}.cobrar-form{display:flex;flex-direction:column;gap:14px}.cobrar-form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:#ffffffb3;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.3)}.cobrar-card .textfield{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:10px 14px;color:#fff;font-size:.95rem;box-shadow:inset 0 2px 4px #0003,0 1px 2px #ffffff0d;transition:all .25s ease}.cobrar-card .textfield:hover{background:#ffffff1a;box-shadow:inset 0 2px 4px #00000026,0 2px 4px #ffffff14}.cobrar-card .textfield:focus{outline:none;border-color:#f6c74399;background:#ffffff1c;box-shadow:0 0 0 3px #f6c7432e,0 4px 12px #f6c74326,inset 0 2px 4px #0000001a}.cobrar-buttons{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap}.cobrar-buttons .button{flex:1;min-width:140px;padding:12px 20px;border-radius:10px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .25s ease;border:none;box-shadow:0 4px 8px #0000004d,inset 0 1px #ffffff1a}.cobrar-buttons .button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #0006,inset 0 1px #ffffff26}.cobrar-buttons .button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000004d,inset 0 1px 3px #0003}.cobrar-buttons .button.black{background:#ffffff26;color:#fff}.cobrar-buttons .button.black:disabled{opacity:.5;cursor:not-allowed;box-shadow:0 2px 4px #0003,inset 0 1px #ffffff0d}.cobrar-buttons .button.danger{background:#ff466433;color:#ff4664;border:1px solid rgba(255,70,100,.3)}.cobrar-buttons .button.danger:hover{background:#ff466440;box-shadow:0 6px 12px #ff46644d,inset 0 1px #ffffff1a}.historial-card{background:#07051cd9;border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:clamp(18px,2vw,24px);display:flex;flex-direction:column;gap:18px;box-shadow:0 16px 40px #03020f80,0 6px 12px #0000004d,inset 0 1px #ffffff0a;transition:all .3s ease}.historial-card:hover{box-shadow:0 20px 48px #03020f99,0 8px 16px #00000059,inset 0 1px #ffffff0f;transform:translateY(-2px)}.historial-card-header{display:flex;flex-direction:column;gap:8px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08)}.historial-card-header h2{margin:0;font-size:clamp(1.3rem,2vw,1.5rem);color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.4)}.historial-card-header p{margin:0;font-size:.88rem;color:#ffffffa6;text-shadow:0 1px 2px rgba(0,0,0,.3);line-height:1.5}.historial-pretitle{margin:0;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:#ffffff80;text-shadow:0 1px 2px rgba(0,0,0,.3)}.historial-grid{display:flex;flex-direction:column;gap:18px}.historial-table{background:#090620e6;border-radius:16px;border:1px solid rgba(255,255,255,.08);padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 20px #0000004d,inset 0 1px 2px #0003,0 1px #ffffff08;transition:all .25s ease}.historial-table:hover{box-shadow:0 10px 24px #00000059,inset 0 1px 2px #00000026,0 1px #ffffff0d;transform:translateY(-1px)}.historial-table-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06)}.historial-table-header h3{margin:0;font-size:1.05rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4)}.historial-table-wrapper{overflow-x:auto;border-radius:10px;box-shadow:inset 0 1px 3px #00000026}.historial-table table{width:100%;border-collapse:collapse}.historial-table th,.historial-table td{padding:11px 14px;border-bottom:1px solid rgba(255,255,255,.06);font-size:.88rem;text-align:left}.historial-table th{text-transform:uppercase;font-size:.72rem;letter-spacing:.08em;font-weight:600;color:#fff9;background:#8a4dff1f;text-shadow:0 1px 2px rgba(0,0,0,.3)}.historial-table th:first-child{border-top-left-radius:8px}.historial-table th:last-child{border-top-right-radius:8px}.historial-table tbody tr{transition:all .2s ease}.historial-table tbody tr:hover{background:#8a4dff14;box-shadow:0 2px 8px #8a4dff26}.historial-table tbody tr:last-child td{border-bottom:none}.historial-table td{color:#ffffffd9;text-shadow:0 1px 2px rgba(0,0,0,.2)}.historial-credito{font-weight:600;font-size:.92rem;padding:5px 10px;border-radius:6px;display:inline-block;transition:all .2s ease}.historial-credito.positivo{color:#6ee7b7;background:#6ee7b71f;box-shadow:0 2px 6px #6ee7b733,inset 0 1px #6ee7b726;text-shadow:0 1px 3px rgba(0,0,0,.3)}.historial-credito.positivo:hover{background:#6ee7b72e;box-shadow:0 3px 8px #6ee7b740,inset 0 1px #6ee7b733;transform:scale(1.05)}.historial-credito.negativo{color:#fecaca;background:#fecaca1f;box-shadow:0 2px 6px #fecaca33,inset 0 1px #fecaca26;text-shadow:0 1px 3px rgba(0,0,0,.3)}.historial-credito.negativo:hover{background:#fecaca2e;box-shadow:0 3px 8px #fecaca40,inset 0 1px #fecaca33;transform:scale(1.05)}.historial-placeholder,.historial-error{margin:0;color:var(--text-muted);text-align:center;padding:16px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.historial-error{color:#fecaca;background:#fecaca14;border-radius:8px;font-size:.85rem;border:1px solid rgba(254,202,202,.2);box-shadow:inset 0 1px 3px #00000026}.historial-table .loading-row td,.historial-table .empty-row td{text-align:center;padding:20px 12px;color:#ffffff80;font-style:italic;text-shadow:0 1px 2px rgba(0,0,0,.3)}.historial-creditos-container{background:#07051cd9;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:clamp(18px,2.2vw,26px);box-shadow:0 16px 40px #03020f80,0 6px 12px #0000004d,inset 0 1px #ffffff0a;display:flex;flex-direction:column;gap:18px;transition:all .3s ease}.historial-creditos-container:hover{box-shadow:0 20px 48px #03020f99,0 8px 16px #00000059,inset 0 1px #ffffff0f}@media (max-width: 1024px){.estudiantes-container{margin-left:180px;width:calc(100vw - 180px)}.estudiantes-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}}@media (max-width: 768px){.estudiantes-container,.estudiantes-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.estudiantes-content{border-radius:22px;padding:18px;width:100%}.historial-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.historial-table table{min-width:500px}.cobrar-header{flex-direction:column;align-items:flex-start}.cobrar-saldos{width:100%;justify-content:space-between}}@media (max-width: 480px){.cobrar-buttons .button{min-width:100px}.historial-table th,.historial-table td{padding:9px 10px;font-size:.82rem}}.create-actividad-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;-webkit-overflow-scrolling:touch}.create-actividad-container:before{content:"";position:absolute;top:-45%;right:-45%;bottom:-45%;left:-45%;background:conic-gradient(from 32deg,#f6c74338,#8a4dff80,#5ea2ff4d,#ff6a9e47);filter:blur(150px);opacity:.75;z-index:0}.create-actividad-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 32px 36px,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.34),transparent);opacity:.28;z-index:0}.create-actividad-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}.create-actividad-content{position:relative;z-index:1;flex:1;background:linear-gradient(150deg,#120c3adb,#090620e6);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(20px,2.8vw,34px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(18px,2.4vw,26px)}.create-actividad-title{font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:700;margin:0;letter-spacing:.05em}.create-actividad-subtitle{margin:-6px 0 0;color:var(--text-muted)}.academic-container{background:#0b0722b3;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:clamp(20px,2.6vw,30px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(14px,2vw,20px)}.info-title{font-size:1.2rem;font-weight:600;color:var(--primary);margin:0}.info-subtitle{margin:-4px 0 0;color:var(--text-muted)}.error-message{color:#ff9ab2;font-size:.82rem;font-weight:500}.error-general{background:#ff52522e;border:1px solid rgba(255,82,82,.4);color:#ffdfe3;padding:10px 12px;border-radius:12px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.field-container input,.field-container select,.select-semestre,.a�o-input{width:100%;padding:12px 16px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease}.field-container input:focus,.field-container select:focus,.select-semestre:focus,.a�o-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #f6c74347;outline:none}@media (max-width: 1024px){.create-actividad-container{margin-left:180px;width:calc(100vw - 180px)}.create-actividad-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}}@media (max-width: 768px){.create-actividad-container,.create-actividad-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.create-actividad-content{border-radius:22px;padding:18px}.action-buttons{justify-content:flex-start}}.selected-semestre{background:#ffffff14;border-radius:16px;padding:12px 16px;color:var(--text-muted)}.actividades-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;-webkit-overflow-scrolling:touch}.actividades-container:before{content:"";position:absolute;top:-45%;right:-45%;bottom:-45%;left:-45%;background:conic-gradient(from 35deg,#f6c74338,#8a4dff85,#5ea2ff4d,#ff6a9e47);filter:blur(150px);opacity:.75;z-index:0}.actividades-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 24px 28px,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.32),transparent),radial-gradient(1px 1px at 320px 80px,rgba(255,255,255,.38),transparent);opacity:.28;z-index:0}.actividades-content{position:relative;z-index:1;flex:1;background:linear-gradient(150deg,#120c3ae0,#090620e0);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(20px,2.6vw,32px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(16px,2.2vw,24px);min-width:0}.actividades-title{font-size:clamp(1.6rem,2.4vw,2.1rem);font-weight:700;letter-spacing:.04em;color:var(--primary);margin:0}.actividades-filters{display:flex;gap:16px;flex-wrap:wrap;align-items:stretch;justify-content:flex-end}.actividades-search{display:flex}.actividades-search .text-field{width:100%}.filters-right{display:flex;gap:12px}.filters-right select{padding:10px 14px;border-radius:12px;border:1px solid var(--surface-border);background:var(--input-bg);color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease}.filters-right select:focus,.filters-right select:hover{border-color:var(--primary);box-shadow:0 0 0 3px #f6c74347;outline:none}.info-container,.academic-container{background:#0b0722b8;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:clamp(20px,2.4vw,28px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(14px,1.8vw,20px)}.info-title,.academic-title{font-size:1.2rem;font-weight:600;color:var(--primary);margin:0}.info-subtitle,.academic-subtitle{color:var(--text-muted);margin:-6px 0 0}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.field-container{display:flex;flex-direction:column;gap:8px}.field-container label{font-size:.9rem;font-weight:600;color:var(--text-muted)}.field-container input,.field-container select,.select-semestre{width:auto;padding:12px 16px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main)}.field-container input:focus,.field-container select:focus,.select-semestre:focus{border-color:var(--primary);box-shadow:0 0 0 3px #f6c74347;outline:none}.action-buttons{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.action-buttons .button{min-width:150px}.actividades-table{width:100%;background:#0b0722c7;border-radius:22px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-soft);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-inline:contain;min-width:0}.actividades-table::-webkit-scrollbar{height:8px}.actividades-table::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.actividades-table::-webkit-scrollbar-thumb{background:#8a4dff80;border-radius:10px}.actividades-table::-webkit-scrollbar-thumb:hover{background:#8a4dffb3}.actividades-table table{width:max-content;min-width:1120px;table-layout:auto;border-collapse:collapse;margin:0}.bonus-container{background:#07051ce6;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:20px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-soft)}.bonus-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.bonus-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.bonus-form .input-field{display:flex;flex-direction:column;gap:6px}.bonus-feedback{grid-column:1 / -1;padding:12px 16px;border-radius:14px;font-size:.92rem}.bonus-feedback.error{background:#ef444424;border:1px solid rgba(239,68,68,.4);color:#fecaca}.bonus-feedback.success{background:#10b98126;border:1px solid rgba(16,185,129,.45);color:#a7f3d0;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.bonus-actions{grid-column:1 / -1;display:flex;gap:12px;flex-wrap:wrap}.bonus-hint{display:block;margin-top:4px;font-size:.82rem;color:#bfdbfe}.table-header td,.actividades-table th{text-transform:uppercase;font-size:.8rem;letter-spacing:.08em;text-align:center;padding:14px;background:#8a4dff47;color:#ffffffe6}.table-row,.actividades-table tbody tr{border-bottom:1px solid rgba(255,255,255,.08);transition:background .2s ease}.actividades-table .action-buttons{display:flex;align-items:center;justify-content:center;gap:8px}.actividades-table .action-button{border:none;background:transparent;padding:6px;border-radius:12px;cursor:pointer;transition:transform .2s ease,background-color .2s ease;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center}.actividades-table .action-button:hover{transform:translateY(-1px);background-color:#8a4dff2e}.actividades-table .action-button img{width:20px;height:20px;display:block;object-fit:contain}@media (max-width: 768px){.actividades-container,.actividades-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.actividades-content{border-radius:22px;padding:18px}.filters-right,.actividades-filters{width:100%;justify-content:flex-start}.filters-right select{flex:1}.actividades-table table{min-width:960px}}.actividades-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;-webkit-overflow-scrolling:touch;box-sizing:border-box}.actividades-container:before{content:"";position:absolute;top:-45%;right:-45%;bottom:-45%;left:-45%;background:conic-gradient(from 30deg,#f6c74333,#8a4dff80,#5ea2ff47,#ff6a9e42);filter:blur(140px);opacity:.75;z-index:0}.actividades-container:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 32px 40px,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 220px 160px,rgba(255,255,255,.34),transparent);opacity:.28;z-index:0}.actividades-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}.actividades-content{position:relative;z-index:1;flex:1;background:linear-gradient(150deg,#120c3ad6,#090620e6);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(20px,2.6vw,32px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(16px,2.2vw,24px);overflow-x:hidden;min-width:0}.actividades-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.actividades-title{font-size:clamp(1.6rem,2.4vw,2rem);font-weight:700;color:var(--primary);margin:0}.actividades-filters{display:flex;gap:16px;flex-wrap:wrap;align-items:stretch}.actividades-search{display:flex;gap:12px}.date-field{display:flex;flex-direction:column;gap:8px;flex:1}.date-field label{font-size:.9rem;font-weight:600;color:var(--text-muted)}.date-field input{width:100%;padding:12px 16px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease}.date-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #f6c74347;outline:none}.search-container .button{min-width:140px}.info-container{background:#0b0722b8;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:clamp(20px,2.4vw,28px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(14px,1.8vw,20px)}.info-container h2{margin:0;color:var(--primary)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.action-buttons{display:flex;justify-content:center;gap:10px}.action-button{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:8px 10px;cursor:pointer}.actividades-table{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-inline:contain;background:#0b0722c7;border-radius:22px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-soft)}.actividades-table table{width:max-content;min-width:1120px;table-layout:auto;border-collapse:collapse}.actividades-table thead .table-cell,.actividades-table tbody .table-cell{white-space:nowrap}.table-header td,.actividades-table th{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1);text-transform:uppercase;font-size:.8rem;letter-spacing:.08em;background:#8a4dff47;color:#ffffffe6}.table-row,.actividades-table tbody tr{border-bottom:1px solid rgba(255,255,255,.08)}.actividades-table tbody tr:hover{background:#8a4dff24}.table-cell,.actividades-table td{padding:12px 16px;color:var(--text-main);font-size:.92rem}@media (max-width: 1024px){.actividades-container{margin-left:180px;width:calc(100vw - 180px)}.actividades-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}}@media (max-width: 768px){.actividades-container,.actividades-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.actividades-content{border-radius:22px;padding:18px}.search-container{flex-direction:column;gap:12px;align-items:stretch}.search-container .button{width:100%;min-width:auto}.actividades-table table{min-width:960px}}.asistencia-detalle-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(246,199,67,.45) transparent;-webkit-overflow-scrolling:touch;isolation:isolate}.asistencia-detalle-container:before{content:"";position:fixed;top:0;left:0;width:200vmax;height:200vmax;pointer-events:none;background:radial-gradient(55% 55% at 30% 20%,rgba(246,199,67,.24),transparent 70%),radial-gradient(50% 50% at 70% 65%,rgba(138,77,255,.3),transparent 72%),radial-gradient(45% 45% at 20% 70%,rgba(94,162,255,.18),transparent 78%);filter:blur(140px);opacity:.58;transform:translate(-48vmax,-60vmax);z-index:-1}.asistencia-detalle-content{position:relative;z-index:1;background:linear-gradient(150deg,#120c3adb,#090620e0);border:1px solid var(--surface-border);border-radius:28px;padding:clamp(22px,2.6vw,32px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(18px,2.2vw,24px)}.asistencia-detalle-header{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}.info-container,.groups-container,.academic-container{background:#0b0722b8;border-radius:22px;border:1px solid rgba(255,255,255,.12);padding:clamp(20px,2.4vw,30px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:clamp(14px,1.8vw,20px)}.info-grid,.academic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.groups-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}.group-checkbox{display:flex;align-items:center;gap:10px}.action-buttons{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}@media (max-width: 1024px){.asistencia-detalle-container{margin-left:180px;width:calc(100vw - 180px)}.asistencia-detalle-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}}@media (max-width: 768px){.asistencia-detalle-container,.asistencia-detalle-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.asistencia-detalle-content{border-radius:22px;padding:18px}}.tabla-asistencia{border-radius:22px;background:#0b0722c7;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-soft);overflow-x:auto;overflow-y:auto}.tabla-asistencia table{width:100%;min-width:640px;border-collapse:collapse}.tabla-asistencia th,.tabla-asistencia td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1);color:var(--text-main)}.tabla-asistencia th{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;background:#8a4dff47}:root{--student-primary: #f6c743;--student-secondary: #8a4dff;--student-border: rgba(255, 255, 255, .18);--student-text: #f8f9ff;--student-text-muted: rgba(238, 240, 255, .7)}.ranking-shell{position:relative;min-height:100vh;margin-left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px));padding:clamp(28px,4vw,48px) clamp(24px,4vw,48px);box-sizing:border-box;background:radial-gradient(circle at 40% 15%,#321082,#1b0a55,#070321);overflow-x:auto;overflow-y:auto;color:var(--student-text);transition:margin-left .3s ease,width .3s ease}.ranking-shell.navbar-collapsed{margin-left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px))}.ranking-shell:before{content:"";position:fixed;top:0;left:var(--navbar-current-width, 220px);right:0;bottom:0;background:conic-gradient(from 60deg,#f6c74340,#8a4dff8c,#5ea2ff4d,#ff6a9e59);filter:blur(130px);opacity:.8;animation:rankingGlow 24s linear infinite;transform-origin:center;z-index:0;pointer-events:none}.ranking-shell:after{content:"";position:fixed;top:0;left:var(--navbar-current-width, 220px);right:0;bottom:0;background-image:radial-gradient(1px 1px at 20px 20px,rgba(255,255,255,.55),transparent),radial-gradient(1px 1px at 180px 120px,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 260px 60px,rgba(255,255,255,.4),transparent);background-size:200% 200%;opacity:.35;animation:rankingStars 80s linear infinite;z-index:0;pointer-events:none}@keyframes rankingGlow{0%{transform:rotate(0) scale(1.8)}50%{transform:rotate(180deg) scale(1.8)}to{transform:rotate(360deg) scale(1.8)}}@keyframes rankingStars{0%{transform:translateZ(0)}to{transform:translate3d(-180px,-180px,0)}}.ranking-content{position:relative;z-index:1;width:min(1000px,100%);margin:0 auto;display:flex;flex-direction:column;gap:clamp(18px,2vw,28px)}.ranking-hero{display:flex;flex-direction:column;gap:4px}.ranking-hero h1{margin:0;font-size:clamp(1.8rem,3.2vw,2.4rem);letter-spacing:.08em;text-transform:uppercase;color:var(--student-primary)}.ranking-hero p{margin:0;color:var(--student-text-muted);font-size:clamp(.9rem,1.5vw,1rem)}.ranking-card{background:linear-gradient(160deg,#120c3ae6,#1b1046a6);border-radius:28px;border:1px solid var(--student-border);padding:clamp(20px,2.5vw,32px);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 20px 45px #05031980;overflow:hidden;display:flex;flex-direction:column;gap:clamp(14px,1.6vw,18px)}.ranking-card h2{margin:0;font-size:clamp(1.1rem,1.8vw,1.3rem);font-weight:600;letter-spacing:.02em;color:var(--student-text)}.ranking-card p{margin:0;color:var(--student-text-muted);font-size:.95rem}.ranking-card-header{display:flex;flex-direction:column;gap:6px}.ranking-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ranking-filters label{font-size:.85rem;color:var(--student-text-muted)}.ranking-filters select{background:#0e0830a6;border:1px solid rgba(255,255,255,.15);color:var(--student-text);padding:8px 12px;border-radius:12px;font-size:.9rem;min-width:180px}.ranking-filters select:focus{outline:none;border-color:#f6c74399;box-shadow:0 0 0 2px #f6c74333}.ranking-card .table-container{max-height:420px;overflow-y:auto;overflow-x:auto;--table-container-bg: transparent;--table-bg: rgba(14, 8, 48, .45);--table-text: rgba(248, 249, 255, .92);--table-head-bg: rgba(138, 77, 255, .35);--table-head-text: rgba(255, 255, 255, .9);--table-head-transform: uppercase;--table-border: 1px solid rgba(255, 255, 255, .1);--table-hover-bg: rgba(138, 77, 255, .22);--table-cell-padding: clamp(10px, 1.2vw, 14px);--table-font-size: clamp(.82rem, 1vw, .92rem);--table-min-width: 480px}.ranking-empty{padding:20px;border-radius:18px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);text-align:center;color:var(--student-text-muted)}.ranking-error{padding:16px;border-radius:16px;background:#ff525233;border:1px solid rgba(255,82,82,.4);color:#ffdfdf}.ranking-loading{padding:20px;border-radius:18px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);text-align:center;color:var(--student-text-muted)}@media (max-width: 1024px){.ranking-shell,.ranking-shell.navbar-collapsed{margin-left:var(--navbar-current-width, 220px);width:calc(100vw - var(--navbar-current-width, 220px))}}@media (max-width: 768px){.ranking-shell,.ranking-shell.navbar-collapsed{margin-left:0;width:100vw;padding:24px 16px 40px}.ranking-card{border-radius:22px;padding:20px}.ranking-card .table-container{max-height:360px;--table-min-width: 360px}}@media (max-width: 480px){.ranking-card{padding:18px}}.niveles-page{position:relative;min-height:100vh;margin-left:var(--navbar-current-width, 220px);padding:clamp(24px,3vw,40px);background:linear-gradient(145deg,#050414f2,#0a0720d9);color:#fff}.niveles-content{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.niveles-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.niveles-breadcrumb{margin:0;font-size:.85rem;color:#fff9}.niveles-header h1{margin:6px 0 0;font-size:clamp(1.8rem,3vw,2.4rem)}.niveles-subtitle{margin-top:8px;color:#ffffffbf}.niveles-state-card{padding:18px 20px;border-radius:16px;background:#ffffff14;text-align:center}.niveles-state-card.error{border:1px solid rgba(239,68,68,.45);color:#fecaca}.niveles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.nivel-card{border-radius:22px;padding:20px;border:1px solid rgba(255,255,255,.1);background:#0b0820d9;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-soft, 0 8px 24px rgba(0, 0, 0, .25))}.nivel-card.completado{border-color:#10b98173}.nivel-card.actual{border-color:#f6c743a6;background:linear-gradient(145deg,#201741f2,#140e2ce6)}.nivel-card-header{display:flex;align-items:center;gap:14px}.nivel-icon{width:54px;height:54px;border-radius:50%;background:#ffffff14;display:flex;align-items:center;justify-content:center}.nivel-icon img{width:32px;height:32px;object-fit:contain}.nivel-id{margin:0;font-size:.85rem;color:#ffffffb3}.nivel-status-badge{margin-left:auto;padding:4px 10px;border-radius:999px;font-size:.78rem;text-transform:uppercase}.nivel-status-badge.completado{background:#10b9812e;color:#6ee7b7}.nivel-status-badge.actual{background:#f6c74333;color:#fde68a}.nivel-status-badge.pendiente{background:#ffffff1f;color:#fffc}.nivel-descripcion{margin:0;color:#ffffffbf;min-height:48px}.nivel-range{display:flex;flex-direction:column;gap:6px}.nivel-range-bar{width:100%;height:6px;border-radius:999px;background:#ffffff1f;overflow:hidden}.nivel-range-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#f6c743,#ff7b54);transition:width .3s ease}.nivel-range-info{display:flex;justify-content:space-between;font-size:.85rem;color:#ffffffb3}@media (max-width: 768px){.niveles-page{margin-left:0;padding:20px 16px 40px}.niveles-header{flex-direction:column}}.creditos-container{position:relative;min-height:100vh;margin-left:220px;width:calc(100vw - 220px);padding:clamp(24px,3vw,40px);box-sizing:border-box;transition:margin-left .3s ease,width .3s ease;color:var(--text-main);overflow-x:hidden}.creditos-container.navbar-collapsed{margin-left:80px;width:calc(100vw - 80px)}.creditos-content{background:#0b0722eb;border-radius:28px;padding:clamp(22px,3vw,32px);border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:18px}.creditos-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:12px}.creditos-header h1{margin:0;font-size:clamp(1.6rem,2.6vw,2.2rem)}.creditos-header-actions{display:flex;gap:12px}.creditos-panel{background:#110c34d9;border-radius:22px;border:1px solid rgba(255,255,255,.1);padding:20px;display:flex;flex-direction:column;gap:12px}.creditos-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.filter-field{display:flex;flex-direction:column;gap:6px}.filter-field label{font-size:.9rem;color:var(--text-muted)}.filter-field select,.filter-field input{border-radius:12px;border:1px solid rgba(255,255,255,.2);padding:10px;background:#060318d9;color:var(--text-main)}.filter-actions{display:flex;flex-wrap:wrap;gap:12px}.movement-hint{background:#3b82f626;border:1px solid rgba(59,130,246,.45);border-radius:16px;padding:12px 16px;font-size:.92rem}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.historial-table-wrapper{overflow-x:auto;border-radius:18px;border:1px solid rgba(255,255,255,.08)}.historial-table-wrapper table{width:100%;border-collapse:collapse;min-width:880px}.historial-table-wrapper th,.historial-table-wrapper td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08)}.historial-table-wrapper th{text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;color:#ffffffb3}.loading-row,.empty-row{text-align:center;padding:24px 0;color:var(--text-muted)}.highlight-row{background:#3b82f61f}.estudiante-col,.autor-col{display:flex;flex-direction:column;gap:4px}.estudiante-col .nombre{font-weight:600}.tipo-badge{padding:4px 10px;border-radius:999px;font-size:.78rem;text-transform:capitalize}.tipo-asistencia{background:#10b9812e;color:#6ee7b7}.tipo-bonus{background:#3b82f633;color:#bfdbfe}.tipo-cobro{background:#ef444433;color:#fecaca}.tipo-ajuste{background:#f59e0b33;color:#fde68a}.creditos{font-weight:600}.creditos.positivo{color:#6ee7b7}.creditos.negativo{color:#fecaca}.pagination-controls{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}.creditos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.import-form input[type=file]{color:var(--text-main)}.import-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}.import-resumen,.import-errores{background:#ffffff0a;border-radius:18px;padding:12px 16px;border:1px solid rgba(255,255,255,.08)}.import-errores table{width:100%;border-collapse:collapse}.import-errores th,.import-errores td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left}.error-banner{background:#ef44442e;border:1px solid rgba(239,68,68,.4);border-radius:18px;padding:10px 14px;color:#fecaca;font-size:.92rem}@media (max-width: 1024px){.creditos-container{margin-left:180px;width:calc(100vw - 180px)}}@media (max-width: 768px){.creditos-container,.creditos-container.navbar-collapsed{margin-left:0!important;width:100vw!important;padding:20px 16px 28px}.creditos-content{border-radius:22px;padding:18px}}
