:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body{margin:0;padding:0;height:100%}html,body,#root{height:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547}a:hover{color:#747bff}button{background-color:#f9f9f9}}.principal-title{font-size:2rem;font-weight:700;margin-bottom:24px;color:#213547}.principal-subtitle{margin-bottom:32px;font-size:1rem;color:#444}.card-grid{display:flex;justify-content:center;align-items:flex-start;gap:32px;flex-wrap:wrap;width:100%}@media(max-width:600px){.principal-main{padding:16px}.principal-title{font-size:1.6rem}.card-grid{gap:20px}}.header-container{display:flex;justify-content:space-between;align-items:center;padding:12px 40px;background:linear-gradient(90deg,#1a374d,#406882);border-bottom:3px solid #6998AB;box-shadow:0 6px 25px #00000040;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);gap:20px;flex-wrap:wrap}.header-left{display:flex;align-items:center;gap:15px;cursor:pointer;white-space:nowrap}.header-logo{width:55px;height:55px;border-radius:50%;object-fit:cover;border:2px solid #ffffff66;box-shadow:0 2px 6px #00000059}.app-title{font-family:Cormorant Garamond,serif;font-weight:700;font-size:32px;color:#eaf3f8;text-shadow:0 3px 8px rgba(0,0,0,.45);-webkit-user-select:none;user-select:none}.header-nav{display:flex;gap:10px;flex:1;justify-content:center;flex-wrap:wrap}.nav-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#ffffff1a;color:#eaf3f8;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:all .3s;white-space:nowrap}.nav-btn:hover{background:#fff3;border-color:#fff6;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.nav-btn svg{width:18px;height:18px}.header-right{display:flex;align-items:center;gap:20px;white-space:nowrap}.icon{width:30px;height:30px;color:#e8f0f7;cursor:pointer;transition:transform .25s ease,color .25s ease}.icon:hover{transform:scale(1.2);color:#fff}@media(max-width:1024px){.header-container{padding:10px 20px}.nav-btn{padding:6px 12px;font-size:12px}.app-title{font-size:24px}}@media(max-width:768px){.header-container{padding:10px 15px;gap:10px}.header-logo{width:45px;height:45px}.app-title{font-size:20px;display:none}.header-nav{flex-basis:100%;order:3;gap:8px}.nav-btn{padding:6px 10px;font-size:11px;gap:4px}.nav-btn svg{width:16px;height:16px}.icon{width:24px;height:24px}}@media(max-width:600px){.header-container{padding:8px 12px}.header-left{gap:8px}.header-logo{width:40px;height:40px}.nav-btn{padding:5px 8px;font-size:10px}.icon{width:22px;height:22px}}.main-footer{background-color:#152d3f;color:#fff;padding:30px 20px;width:100%;margin-top:auto}.footer-content-wrapper{max-width:1200px;margin:0 auto;display:flex;justify-content:space-around;flex-wrap:wrap;gap:40px;text-align:left}.footer-section{flex:1;min-width:200px}.footer-section h4{color:#fff;font-size:1.2em;font-weight:700;margin-bottom:20px}.footer-section.contact p{margin:5px 0;line-height:1.5}.footer-section a{color:#ccc;text-decoration:none;transition:color .2s}.footer-section a:hover{color:#fff}.footer-section.links ul{list-style:none;padding:0}.footer-section.links li{margin-bottom:8px}.social-icons a{color:#fff;font-size:24px;margin-right:15px;transition:color .2s}.social-icons a:hover{color:#aaa}.card-univ{background:#fff;border-radius:18px;padding:20px;width:240px;cursor:pointer;box-shadow:0 4px 14px #00000026;transition:transform .25s ease,box-shadow .25s ease;text-align:center;margin:15px}.card-univ:hover{transform:translateY(-6px);box-shadow:0 8px 22px #00000040}.card-univ-img{width:120px;height:120px;object-fit:contain;margin-bottom:15px}.card-univ-title{font-size:1.2rem;font-weight:600;color:#1a374d;margin-top:10px}.alumnos-table-wrap{overflow:auto;background:#fff;border-radius:12px;box-shadow:0 6px 20px #0c18280f;padding:12px}.alumnos-table{width:100%;border-collapse:collapse;min-width:1000px;font-family:Inter,Roboto,system-ui,Arial}thead th{text-align:left;padding:12px 16px;font-size:.85rem;color:#314158;background:linear-gradient(180deg,#f7fafc,#eef6ff);border-bottom:1px solid #e6eef7;position:sticky;top:0;z-index:2}tbody td{padding:12px 16px;border-bottom:1px solid #f0f4f8;color:#243244;font-size:.95rem}.alumno-row{transition:background .18s ease,transform .12s ease;cursor:pointer}.alumno-row:hover{background:linear-gradient(90deg,#f5faffcc,#ffffffe6);transform:translateY(-2px)}.empty-row td{text-align:center;padding:24px;color:#667}@media(max-width:900px){.alumnos-table{min-width:800px}}@media(max-width:600px){.alumnos-table{min-width:600px;font-size:.9rem}thead th,tbody td{padding:10px}}.principal-container{min-height:100vh;display:flex;flex-direction:column;background:#f3f4f6}.principal-main{flex-grow:1;padding:24px;color:#333}.principal-title{font-size:2rem;font-weight:700;margin-bottom:24px}.principal-subtitle{margin-bottom:32px;font-size:1rem}.card-grid{display:flex;justify-content:center;align-items:flex-start;gap:32px;flex-wrap:wrap}@media(max-width:600px){.principal-main{padding:16px}.card-grid{gap:20px}}.alumno-page-root{background:#f6f8fb;min-height:100vh;color:#223}.alumno-main.container{max-width:1100px;margin:26px auto;padding:18px}.back-btn{background:transparent;border:none;color:#1a374d;font-weight:600;cursor:pointer;margin-bottom:10px}.card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 6px 20px #0c18280f;margin-bottom:18px}.personal-card .personal-grid{display:flex;justify-content:space-between;gap:18px;align-items:center}.name{margin:0;font-size:1.45rem;color:#0f2b44}.sub{color:#556;margin-top:6px;font-size:.95rem}.personal-meta{display:grid;grid-template-columns:repeat(2,minmax(140px,1fr));gap:10px 18px;text-align:right;font-size:.95rem;color:#243244}.section-card .section-title{margin:0 0 10px;font-size:1.05rem;color:#123}.table-wrap{overflow:auto;border-radius:8px;background:linear-gradient(180deg,#fff,#fbfdff);padding:10px}.tabla{width:100%;border-collapse:collapse;min-width:700px;font-family:Inter,Roboto,system-ui,Arial}.tabla thead th{text-align:left;padding:12px 14px;font-size:.85rem;color:#314158;background:linear-gradient(180deg,#f7fafc,#eef6ff);border-bottom:1px solid #e6eef7;position:sticky;top:0;z-index:2}.tabla tbody td{padding:12px 14px;border-bottom:1px solid #f0f4f8;color:#243244;font-size:.95rem}.tabla tbody tr{background:transparent}.tabla tbody tr:nth-child(odd){background:#fafdff99}.estado{padding:6px 10px;border-radius:999px;display:inline-block;font-weight:600;text-transform:capitalize;font-size:.9rem}.estado.aprobada{background:#148c501f;color:#148c50}.estado.desaprobada{background:#dc282814;color:#c0392b}.estado.promocionada{background:#3c78c81a;color:#186fa0}.small-loading{padding:8px 10px;color:#556}.muted{color:#667;padding:8px 10px}.center-message{text-align:center;padding:24px;background:#fff;border-radius:12px;color:#334}@media(max-width:900px){.personal-card .personal-grid{flex-direction:column;text-align:left}.personal-meta{grid-template-columns:1fr;text-align:left}.tabla{min-width:520px}}.form-alumno-container{max-width:600px;margin:30px auto;padding:30px;background:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a}.form-alumno-container h2{text-align:center;color:#333;margin-bottom:30px;font-size:24px}.form-alumno{display:flex;flex-direction:column;gap:20px}.form-group input,.form-group select{padding:10px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s;font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4267b2;box-shadow:0 0 0 3px #4267b21a}.btn-submit{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:10px}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.alert{padding:12px 16px;border-radius:6px;margin-bottom:15px;font-size:14px;font-weight:500}.alert-error{background-color:#fee;color:#c33;border-left:4px solid #c33}.alert-success{background-color:#efe;color:#3c3;border-left:4px solid #3c3}@media(max-width:600px){.form-row{grid-template-columns:1fr}.form-alumno-container{margin:15px;padding:20px}}.dashboard-container{max-width:1200px;margin:0 auto;padding:30px 20px}.dashboard-title{text-align:center;font-size:32px;color:#1a1a1a;margin-bottom:40px;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:50px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:25px;border-radius:10px;display:flex;align-items:center;gap:15px;box-shadow:0 4px 12px #0000001a;transition:transform .3s,box-shadow .3s;cursor:pointer}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #0003}.stat-card.highlight{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-icon{font-size:40px}.stat-content{flex:1}.stat-value{font-size:28px;font-weight:700;margin-bottom:5px}.stat-label{font-size:13px;opacity:.9;font-weight:500}.dashboard-section{background:#fff;padding:30px;border-radius:10px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a}.dashboard-section h2{font-size:22px;color:#1a1a1a;margin-bottom:20px;border-bottom:3px solid #667eea;padding-bottom:10px}.top-alumnos-table table{width:100%;border-collapse:collapse}.top-alumnos-table th{background:#f5f5f5;padding:12px;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #ddd}.top-alumnos-table td{padding:12px;border-bottom:1px solid #eee}.top-alumnos-table tr:hover{background:#f9f9f9}.medal{font-size:20px;text-align:center}.nota-highlight{font-weight:700;color:#667eea;font-size:16px}.facultad-dist{display:flex;flex-direction:column;gap:15px}.facultad-item{display:flex;align-items:center;gap:15px}.facultad-name{min-width:150px;font-weight:600;color:#333}.facultad-bar{flex:1;height:30px;background:#e0e0e0;border-radius:15px;overflow:hidden}.facultad-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;min-width:40px}.no-data{text-align:center;color:#999;padding:20px;font-style:italic}.error{background:#fee;color:#c33;padding:20px;border-radius:8px;border-left:4px solid #c33;margin-bottom:20px}.btn-retry{background:#667eea;color:#fff;padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:600}.btn-retry:hover{opacity:.8}.dashboard-actions{display:flex;justify-content:center;gap:15px;margin-top:40px}.btn-refresh{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 24px;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:16px;transition:transform .2s}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.dashboard-title{font-size:24px}.facultad-item{flex-direction:column;align-items:flex-start}.facultad-bar{width:100%}}.ranking-container{max-width:1000px;margin:30px auto;padding:20px}.ranking-title{text-align:center;font-size:32px;color:#1a1a1a;margin-bottom:30px;font-weight:700}.ranking-filtros{background:#fff;padding:20px;border-radius:10px;margin-bottom:30px;display:flex;gap:15px;flex-wrap:wrap;align-items:flex-end;box-shadow:0 2px 8px #0000001a}.filtro-group{display:flex;flex-direction:column;gap:5px;flex:1;min-width:150px}.filtro-group label{font-weight:600;color:#555;font-size:14px}.filtro-group select{padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;cursor:pointer;transition:border-color .3s}.filtro-group select:focus{outline:none;border-color:#667eea}.btn-reset{background:#667eea;color:#fff;padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:background .3s}.btn-reset:hover{background:#764ba2}.ranking-table-wrap{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.ranking-table{width:100%;border-collapse:collapse}.ranking-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.ranking-table th{padding:15px;text-align:left;font-weight:600}.pos-col{width:60px;text-align:center}.nom-col{flex:1}.dni-col{width:120px}.prom-col,.mat-col{width:100px;text-align:center}.ranking-table td{padding:12px 15px;border-bottom:1px solid #eee}.rank-row{transition:background-color .2s}.rank-row:hover{background-color:#f9f9f9}.rank-1{background:#ffd7000d}.rank-2{background:#c0c0c00d}.rank-3{background:#cd7f320d}.medal-cell{font-size:18px;text-align:center;font-weight:700}.promedio-cell{font-weight:700;color:#667eea;text-align:center}.materias-cell{text-align:center;color:#666}.loading{text-align:center;padding:50px;font-size:18px;color:#666}.error{background:#fee;color:#c33;padding:15px;border-radius:8px;border-left:4px solid #c33;margin-bottom:20px}.no-data{background:#fff;text-align:center;padding:40px;border-radius:10px;color:#999;font-style:italic;box-shadow:0 2px 8px #0000001a}@media(max-width:768px){.ranking-filtros{flex-direction:column;align-items:stretch}.filtro-group{min-width:auto}.ranking-table{font-size:13px}.ranking-table th,.ranking-table td{padding:8px}.nom-col{min-width:150px}}.gestor-profesores-container{max-width:900px;margin:30px auto;padding:20px}.gestor-profesores-container h1{font-size:28px;color:#1a1a1a;margin-bottom:25px;text-align:center}.btn-agregar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:600;margin-bottom:20px;transition:transform .2s}.btn-agregar:hover{transform:scale(1.05)}.form-profesor{background:#fff;padding:25px;border-radius:10px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a}.form-profesor h2{color:#333;margin-bottom:20px}.form-profesor form{display:flex;flex-direction:column;gap:15px}.form-profesor input{padding:12px;border:2px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s}.form-profesor input:focus{outline:none;border-color:#667eea}.form-buttons{display:flex;gap:10px}.btn-submit{flex:1;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:transform .2s}.btn-cancel{padding:12px 20px;background:#ddd;color:#333;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:background .3s}.btn-cancel:hover{background:#ccc}.profesores-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.profesor-card{background:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center;transition:transform .3s,box-shadow .3s}.profesor-card:hover{transform:translateY(-5px);box-shadow:0 4px 12px #00000026}.profesor-info h3{color:#1a1a1a;margin-bottom:5px;font-size:18px}.especialidad{color:#667eea;font-style:italic;font-size:13px}.profesor-actions{display:flex;gap:10px}.btn-edit,.btn-delete{padding:8px 12px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:opacity .2s}.btn-edit{background:#e3f2fd;color:#1976d2}.btn-delete{background:#ffebee;color:#d32f2f}.btn-edit:hover,.btn-delete:hover{opacity:.8}.loading,.no-data{text-align:center;padding:40px;color:#999;font-style:italic}@media(max-width:768px){.form-row,.profesores-list{grid-template-columns:1fr}.profesor-card{flex-direction:column;align-items:flex-start;gap:15px}.profesor-actions{width:100%;gap:10px}}.gestor-notas-container{max-width:900px;margin:30px auto;padding:20px}.gestor-notas-container h1{font-size:28px;color:#1a1a1a;margin-bottom:25px;text-align:center}.tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #ddd}.tab{padding:12px 20px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:16px;font-weight:600;color:#666;transition:all .3s}.tab:hover{color:#333}.tab.active{color:#667eea;border-bottom-color:#667eea}.btn-agregar-nota{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:600;margin-bottom:20px;transition:transform .2s}.btn-agregar-nota:hover{transform:scale(1.05)}.form-nota{background:#fff;padding:25px;border-radius:10px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a}.form-nota h2{color:#333;margin-bottom:20px}.form-nota form{display:flex;flex-direction:column;gap:15px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-weight:600;color:#555;font-size:14px}.form-group select,.form-group input{padding:10px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s}.form-group select:focus,.form-group input:focus{outline:none;border-color:#667eea}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.btn-submit{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:16px;transition:transform .2s;margin-top:10px}.btn-submit:hover{transform:scale(1.02)}.info-box{background:#f5f5f5;padding:20px;border-radius:8px;border-left:4px solid #667eea}.info-box p{margin:10px 0;color:#555}@media(max-width:768px){.form-row{grid-template-columns:1fr}.tabs{flex-wrap:wrap}}.alertas-container{max-width:1000px;margin:30px auto;padding:20px}.alertas-container h1{font-size:32px;text-align:center;color:#1a1a1a;margin-bottom:30px}.summary{background:#fff3cd;padding:20px;border-radius:8px;border-left:4px solid #ff9800;margin-bottom:30px}.summary p{margin:10px 0;color:#333;font-weight:500}.summary .critical{color:#d32f2f;font-weight:700}.summary .warning{color:#ff9800;font-weight:700}.alumnos-riesgo{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-bottom:30px}.riesgo-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .3s,box-shadow .3s;border-top:5px solid #999}.riesgo-card.critical{border-top-color:#d32f2f;background:#ffebee}.riesgo-card.warning{border-top-color:#ff9800;background:#fff8e1}.riesgo-card.at-risk{border-top-color:#fbc02d;background:#fffde7}.riesgo-card:hover{transform:translateY(-5px);box-shadow:0 6px 16px #00000026}.riesgo-header{display:flex;align-items:center;gap:10px;padding:15px;background:#00000008;border-bottom:1px solid rgba(0,0,0,.1)}.emoji{font-size:28px}.numero{font-size:20px;font-weight:700;color:#666}.riesgo-content{padding:15px}.riesgo-content h3{font-size:18px;color:#1a1a1a;margin-bottom:8px}.riesgo-content p{font-size:13px;color:#666;margin:5px 0}.dni{font-weight:600;color:#555}.carrera,.facultad{color:#667eea}.riesgo-footer{padding:15px;background:#00000005;border-top:1px solid rgba(0,0,0,.1);display:flex;justify-content:space-between;align-items:center}.promedio{text-align:center}.promedio .label{font-size:12px;color:#999;font-weight:600}.promedio .valor{font-size:24px;font-weight:700;color:#d32f2f}.loading,.no-data{text-align:center;padding:50px;color:#999;font-style:italic;font-size:18px}.no-data{background:#e8f5e9;border-radius:8px;color:#2e7d32;font-weight:500}.btn-refresh{display:block;margin:20px auto 0;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:transform .2s}.btn-refresh:hover{transform:scale(1.05)}.alert{padding:12px 16px;border-radius:6px;margin-bottom:20px;font-weight:500}.alert-error{background:#ffebee;color:#d32f2f;border-left:4px solid #d32f2f}@media(max-width:768px){.alumnos-riesgo{grid-template-columns:1fr}.alertas-container h1{font-size:24px}}.badges-container{max-width:1200px;margin:30px auto;padding:20px}.badges-container h1{text-align:center;font-size:36px;color:#1a1a1a;margin-bottom:40px}section{margin-bottom:50px}section h2{font-size:24px;color:#333;margin-bottom:25px;border-bottom:3px solid #667eea;padding-bottom:10px}.badges-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.badge-info-card{background:#fff;padding:25px;border-radius:10px;text-align:center;box-shadow:0 2px 8px #0000001a;transition:transform .3s,box-shadow .3s}.badge-info-card:hover{transform:translateY(-10px);box-shadow:0 8px 16px #00000026}.badge-emoji{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;margin:0 auto 15px}.badge-info-card h3{font-size:18px;color:#1a1a1a;margin-bottom:8px}.badge-info-card p{font-size:13px;color:#666;line-height:1.5}.alumnos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.alumno-badge-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 8px #0000001a;transition:transform .3s,box-shadow .3s}.alumno-badge-card:hover{transform:translateY(-5px);box-shadow:0 6px 16px #00000026}.alumno-header{border-bottom:2px solid #eee;padding-bottom:15px;margin-bottom:15px}.alumno-header h3{color:#1a1a1a;margin-bottom:5px}.dni{font-size:12px;color:#999}.badges-list{display:flex;flex-wrap:wrap;gap:10px}.badge{display:inline-flex;align-items:center;gap:5px;padding:8px 12px;border-radius:20px;color:#fff;font-size:12px;font-weight:600;white-space:nowrap}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stat{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;border-radius:10px;text-align:center;box-shadow:0 4px 12px #0000001a}.stat p{font-size:14px;opacity:.9;margin-bottom:10px}.stat h3{font-size:32px;margin:0}.loading,.no-data{text-align:center;padding:40px;color:#999;font-style:italic;background:#f9f9f9;border-radius:8px}@media(max-width:768px){.badges-gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.alumnos-grid,.stats{grid-template-columns:1fr}.badges-container h1{font-size:28px}section h2{font-size:20px}.badge-emoji{width:60px;height:60px;font-size:30px}}
