:root{--primary:#6366f1;--primary-hover:#4f46e5;--bg-gradient:linear-gradient(135deg, #0f172a 0%, #1e1b4b 100%);--glass-bg:#ffffff0d;--glass-border:#ffffff1a;--text-main:#f8fafc;--text-muted:#94a3b8;--success:#10b981;--danger:#ef4444}@keyframes toastIn{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}.toast-in{animation:.4s cubic-bezier(.16,1,.3,1) forwards toastIn}.toast-out{animation:.4s cubic-bezier(.7,0,.84,0) forwards toastOut}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,sans-serif}body{color:var(--text-main);background:#0f172a;min-height:100vh;position:relative;overflow-x:hidden}.bg-slide{z-index:-1;filter:blur(10px)brightness(.4);opacity:0;pointer-events:none;background-position:50%;background-size:cover;width:100%;height:100%;animation:30s linear infinite bgFade;position:fixed;top:0;left:0;transform:scale(1.1)}@keyframes bgFade{0%{opacity:0}3%{opacity:1}33%{opacity:1}36%{opacity:0}to{opacity:0}}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:1rem;padding:2rem;box-shadow:0 8px 32px #0000005e}.btn{cursor:pointer;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.input-group{margin-bottom:1.5rem}.input-group label{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;display:block}.input-field{border:1px solid var(--glass-border);color:#fff;background:#0003;border-radius:.5rem;width:100%;padding:.75rem;transition:border-color .2s}.input-field:focus{border-color:var(--primary);outline:none}.input-field:disabled,.btn:disabled,.icon-btn:disabled{opacity:.55;cursor:not-allowed}.table-container{border:1px solid var(--glass-border);border-radius:.5rem;overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--glass-border);padding:1rem}th{white-space:nowrap;background:#ffffff0d;font-weight:600}.compact-panel{padding:1.1rem 1.1rem .9rem}.panel-toolbar{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.6rem;display:flex}.panel-toolbar h1{color:#fff;margin:0;font-size:1.2rem;font-weight:800}.panel-actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.panel-filters{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.6rem;display:flex}.filter-item{align-items:center;gap:.55rem;display:flex}.compact-select{width:auto;min-width:220px;padding:.55rem .75rem}.panel-filters .label{white-space:nowrap;font-size:.76rem}.panel-stats{flex-wrap:wrap;gap:1rem;margin-left:auto;font-size:.82rem;display:flex}.panel-stat{align-items:center;gap:.45rem;display:inline-flex}.tab-nav{flex-wrap:wrap;gap:.6rem;margin-bottom:.6rem;display:flex}.tab-btn{border:1px solid var(--glass-border);color:var(--text-main);cursor:pointer;background:#ffffff0a;border-radius:999px;padding:.55rem .9rem}.tab-btn.active{background:var(--primary);border-color:#0000}.preview-inline{min-width:0}.compact-inline-input{padding:.65rem .75rem}.page-section{gap:.7rem;display:grid}.section-title{align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.section-title h2{font-size:.98rem}.stack-form{gap:.65rem;display:grid}.helper-text{color:var(--text-muted);margin-bottom:.7rem;font-size:.82rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{border:1px solid var(--primary);background:#1e1b4b;box-shadow:0 0 30px #6366f14d}@media (width<=900px){.tab-nav{display:none!important}.panel-toolbar{flex-direction:row;align-items:center;gap:.5rem;padding:.4rem 0}.panel-toolbar .logo-section{flex:1;order:2;gap:.5rem!important}.panel-toolbar img{height:30px}.panel-toolbar h1{white-space:nowrap;letter-spacing:-.02em;text-transform:uppercase;max-width:none;font-size:.65rem;overflow:visible}.panel-toolbar h2,.panel-toolbar .welcome-section{display:none}.panel-actions{order:1;gap:.4rem}.btn-hamburger-mobile{color:#ff8080!important;background:#ef444433!important;border:1px solid #ef44444d!important}.panel-actions .btn{padding:.4rem .6rem;font-size:.75rem}.panel-filters{grid-template-columns:1fr 1fr;gap:.4rem;margin-top:.5rem;display:grid}.filter-item{background:#ffffff08;border:1px solid #ffffff0d;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;display:flex}.filter-item label{white-space:nowrap;color:var(--text-muted);margin:0;font-size:.7rem}.compact-select{background:0 0;border:none;width:100%;min-width:0;padding:2px 4px;font-size:.75rem}.panel-stats{background:0 0;border-radius:0;grid-area:2/2;justify-content:flex-end;gap:.4rem;margin:0;padding:0;font-size:.65rem}.panel-stat{gap:.2rem}.section-title h2{white-space:nowrap;font-size:.82rem!important}}.mobile-menu-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;opacity:0;visibility:hidden;background:#0009;width:100%;height:100%;transition:all .3s;position:fixed;top:0;left:0}.mobile-menu-overlay.open{opacity:1;visibility:visible}.mobile-menu-drawer{z-index:2001;background:#111827;border-left:1px solid #ffffff1a;flex-direction:column;width:280px;height:100%;padding:1.5rem;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:-280px;box-shadow:-10px 0 30px #00000080}.mobile-menu-overlay.open .mobile-menu-drawer{right:0}.menu-header{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.menu-nav{flex-direction:column;flex:1;gap:.5rem;display:flex;overflow-y:auto}.menu-item{color:var(--text-main);cursor:pointer;background:#ffffff08;border:1px solid #ffffff0d;border-radius:12px;align-items:center;gap:12px;padding:1rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.menu-item:active{background:#ffffff14;transform:scale(.98)}.menu-item.active{background:var(--primary);border-color:#0000;box-shadow:0 4px 12px #6366f14d}.menu-footer{border-top:1px solid #ffffff0d;margin-top:auto;padding-top:1.5rem}@media (width<=600px){.compact-panel{padding:.75rem}.panel-filters{flex-direction:column;align-items:stretch}.compact-select{width:100%;min-width:0}.table-container{-webkit-overflow-scrolling:touch;border-left:none;border-right:none;border-radius:0;margin:0 -.75rem}}@media print{.bg-slide,.glass-overlay,.panel-toolbar,.btn,.icon-btn,.tab-nav,.panel-filters,.section-title,.panel-actions,.helper-text,.panel-status,header{display:none!important}body,.container{color:#000!important;background:#fff!important;margin:0!important;padding:0!important}.glass-card{-webkit-backdrop-filter:none!important;box-shadow:none!important;background:0 0!important;border:none!important;width:100%!important;max-width:100%!important;margin:0!important;padding:0!important}.table-container{border:1px solid #000!important;overflow:visible!important}table{border-collapse:collapse!important;color:#000!important;width:100%!important}th,td{color:#000!important;background:#fff!important;border:1px solid #000!important;padding:3px 5px!important;font-size:8pt!important;line-height:1.1!important}th{background:#f0f0f0!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.print-only-container{visibility:visible;width:100%;position:absolute;top:0;left:0;background:#fff!important;display:block!important}.printable-page{page-break-after:always;min-height:29.7cm;padding:1.5cm;color:#000!important;background:#fff!important}.print-table{border-collapse:collapse;border:2px solid #000;width:100%;margin-top:1rem}.print-table th,.print-table td{text-align:left;border:1px solid #000;padding:12px 8px;font-size:.9rem;color:#000!important}}@keyframes skeleton-loading{0%{background-position:100%}to{background-position:0}}.skeleton{background:linear-gradient(90deg,#ffffff08 25%,#ffffff14 37%,#ffffff08 63%) 0 0/400% 100%;border-radius:4px;animation:1.4s infinite skeleton-loading}.skeleton-text{width:100%;height:.8rem;margin:.4rem 0}.skeleton-circle{border-radius:50%;width:32px;height:32px}.skeleton-table-row{width:100%;height:48px;margin-bottom:2px}.compact-table-container{max-width:100%}.grades-table{table-layout:fixed;border-collapse:separate;border-spacing:0;width:max-content;min-width:100%}.grades-table th,.grades-table td{padding:.55rem .45rem;font-size:.83rem}.grades-table thead th{z-index:1;background:#0f172a padding-box padding-box;position:sticky;top:0}.student-column,.student-name{z-index:2;width:120px;min-width:120px;max-width:120px;position:sticky;left:0;background:#0f172a!important}.student-column{z-index:3}.student-column-header{white-space:normal;word-break:break-word;font-size:.74rem;line-height:1.2;z-index:12!important;background:#0f172a!important}.student-name{font-weight:500}.student-name-main{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.student-name-meta{color:var(--text-muted);margin-top:.18rem;font-size:.72rem;line-height:1.1}.subject-header{text-align:center;white-space:normal;word-break:break-word;background:#0f172a;font-size:.72rem;line-height:1.2}.grades-table thead .cell-t,.grades-table thead .cell-p,.grades-table thead .cell-pond,.grades-table thead .cell-letras,.grades-table thead .cell-grade,.grades-table thead .cell-grade-header{text-align:center;border-bottom:2px solid var(--primary);background:#6366f11a;width:48px;min-width:48px}.grades-table thead .cell-final-spacer{background:#e74c3c1f;border-bottom:2px solid #e74c3c}.grades-table tbody td{background:0 0}.grades-table tbody td:not(:first-child){text-align:center}.grades-table tbody td:not(:first-child) .cell-input{margin:0 auto;display:block}.cell-input{color:#fff;text-align:center;border:1px solid var(--glass-border);background:#ffffff12;border-radius:4px;width:34px;padding:.18rem;font-size:.82rem;transition:all .2s;box-shadow:inset 0 1px 3px #0003}.cell-input:hover{border-color:var(--text-muted);background:#ffffff1f}.cell-input:focus{border-color:var(--primary);background:#ffffff1a;outline:none}.subject-sep{border-right:2px solid #fff6!important}.subject-taller{color:#a5b4fc;background:#6366f126!important}.taller-label{color:var(--primary);border:1px solid var(--primary);background:#6366f133;border-radius:4px;margin-bottom:4px;padding:2px 4px;font-size:.6rem;font-weight:800;display:inline-block}.obs-input{width:100%;color:var(--text-muted);background:#ffffff0d;border:1px solid #0000;border-radius:4px;margin-top:4px;padding:2px 5px;font-size:.7rem;transition:all .2s}.obs-input:focus{border-color:var(--primary);color:#fff;background:#ffffff1a;outline:none}.btn-obs{border:1px solid var(--primary);color:#a5b4fc;cursor:pointer;background:#6366f11a;border-radius:4px;align-items:center;gap:.35rem;margin-top:.4rem;padding:.35rem .6rem;font-size:.72rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-obs:hover{background:var(--primary);color:#fff;transform:translateY(-1px)}.nomenclatura-link{color:var(--primary);text-underline-offset:3px;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:.85rem;font-weight:600;text-decoration:underline;transition:color .2s,transform .2s;display:inline-flex}.nomenclatura-link:hover{color:#818cf8;transform:translateY(-1px)}.nomenclatura-table{border-collapse:separate;border-spacing:0;background:#0003;border:1px solid #ffffff1a;border-radius:12px;width:100%;overflow:hidden}.nomenclatura-table th{color:var(--primary);text-align:left;text-transform:uppercase;letter-spacing:.05em;background:#ffffff0d;border-bottom:1px solid #ffffff1a;padding:1rem;font-size:.8rem}.nomenclatura-table td{color:var(--text-main);border-bottom:1px solid #ffffff0d;padding:.8rem 1rem;font-size:.9rem}.nomenclatura-table tr:last-child td{border-bottom:none}.nomenclatura-table td strong{color:var(--primary);font-size:1rem}@media (width<=900px){.student-column,.student-name{width:100px;min-width:100px;max-width:100px;font-size:.7rem;background:#0f172a!important}.student-column-header{background:#0f172a!important;font-size:.58rem!important}}@media (width<=600px){.grades-table-mobile-grouped{table-layout:fixed;width:100%;min-width:100%}.cell-input{width:36px;height:34px;padding:.15rem;font-size:.92rem}.grades-table th,.grades-table td{white-space:nowrap;min-width:0;padding:.42rem .3rem}.grades-table th:first-child,.grades-table td:first-child{z-index:14;min-width:110px;position:sticky;left:0}.subject-header{background:#0f172a!important;min-width:0!important}.grades-table td:first-child{min-width:140px;white-space:normal!important}.grades-table th:first-child{white-space:nowrap!important}.grades-table td,.grades-table th{min-width:0}.grades-table thead th{z-index:11;background:#0f172a!important}.grades-table thead .student-column,.grades-table thead .student-column-header{box-shadow:1px 0 #ffffff0f;z-index:16!important;background:#0f172a!important}.grades-table .cell-t,.grades-table .cell-p,.grades-table .cell-pond,.grades-table .cell-grade,.grades-table .cell-grade-header{width:34px;min-width:34px;padding-left:.08rem;padding-right:.08rem}.grades-table .cell-pond{width:38px;min-width:38px}.grades-table-mobile-grouped.grades-table-mobile-grouped-modular .cell-t,.grades-table-mobile-grouped.grades-table-mobile-grouped-modular .cell-p,.grades-table-mobile-grouped.grades-table-mobile-grouped-modular .cell-pond,.grades-table-mobile-grouped.grades-table-mobile-grouped-modular .cell-grade-header{text-align:center;width:auto;min-width:0;padding-left:.12rem;padding-right:.12rem}.grades-table-mobile-grouped.grades-table-mobile-grouped-modular .cell-pond{width:auto;min-width:0}.grades-table-mobile-grouped.grades-table-mobile-grouped-modular .cell-input{width:30px;height:30px;padding:.12rem;font-size:.82rem}.grades-table-mobile-grouped:not(.grades-table-mobile-grouped-modular) .cell-grade-header,.grades-table-mobile-grouped:not(.grades-table-mobile-grouped-modular) .cell-t,.grades-table-mobile-grouped:not(.grades-table-mobile-grouped-modular) .cell-p,.grades-table-mobile-grouped:not(.grades-table-mobile-grouped-modular) .cell-pond{text-align:center;width:auto;min-width:0;padding-left:.16rem;padding-right:.16rem}.grades-table-mobile-grouped:not(.grades-table-mobile-grouped-modular) .cell-input{width:32px;height:32px;padding:.14rem;font-size:.84rem}}.student-list{gap:.65rem;max-height:700px;padding-right:4px;display:grid;overflow-y:auto}.pagination-controls{border-top:1px solid #ffffff0d;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1rem;display:flex}.page-btn{color:#fff;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;transition:all .2s}.page-btn:hover:not(:disabled){background:#ffffff1a}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{color:var(--text-muted);font-size:.85rem}.student-item{background:#ffffff0a;border-radius:.75rem;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem .8rem;display:flex}.student-item p{color:var(--text-muted);margin-top:.2rem;font-size:.8rem}.student-item-actions{gap:.45rem;display:flex}.icon-btn{width:32px;height:32px;color:var(--text-main);cursor:pointer;background:#ffffff14;border:none;border-radius:999px;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.icon-btn:hover:not(:disabled){background:#ffffff26;transform:translateY(-1px)}.icon-btn.danger{color:#fecaca;background:#ef444429}.icon-btn.danger:hover:not(:disabled){background:#ef44444d}.badge{text-transform:uppercase;letter-spacing:.02em;border-radius:4px;padding:.2rem .5rem;font-size:.65rem;font-weight:800}.badge-admin{color:#fecaca;background:#ef444433;border:1px solid #ef4444}.badge-jefe_de_auxiliares{color:#fbcfe8;background:#ec489933;border:1px solid #ec4899}.badge-preceptor{color:#d1fae5;background:#10b98133;border:1px solid #10b981}.badge-preceptor_taller{color:#fef3c7;background:#f59e0b33;border:1px solid #f59e0b}.badge-preceptor_ef{color:#ccfbf1;background:#14b8a633;border:1px solid #14b8a6}.badge-profesor{color:#e0e7ff;background:#6366f133;border:1px solid #6366f1}.badge-director{color:#ddd6fe;background:#8b5cf633;border:1px solid #8b5cf6}.badge-vicedirector{color:#ede9fe;background:#a78bfa33;border:1px solid #a78bfa}.badge-secretaria_de_alumnos{color:#cffafe;background:#06b6d433;border:1px solid #06b6d4}.badge-danger{background:var(--danger);color:#fff;border:none}.badge-warning{color:#fff;background:#f39c12;border:none}.badge-never{color:#000;background:#f1c40f;border:none;font-weight:700}.multi-select{min-height:120px}.multi-select-container{border:1px dashed var(--glass-border);background:#0000001a;border-radius:.5rem;gap:.5rem;padding:1rem;display:grid}@media (width<=600px){.student-item-actions{flex-wrap:wrap;justify-content:flex-start;gap:.4rem}}.boletin-header{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.boletin-field{border-bottom:1px dashed var(--text-muted);padding-bottom:.25rem}.boletin-view img{height:60px;margin-bottom:1rem}.boletin-view h2{margin-bottom:1rem;font-size:1.5rem}.boletin-view h1{padding-top:10px;font-size:1.2rem}.observations-box{border:1px solid var(--glass-border);border-radius:.5rem;margin-top:2rem;padding:1rem}@media print{.boletin-view img{height:45px!important;margin-bottom:5px!important}.boletin-view h2{margin-bottom:5px!important;font-size:1rem!important}.boletin-view h1{padding-top:5px!important;font-size:.8rem!important}.boletin-header{border:1px solid #ccc;border-radius:4px;padding:5px;grid-template-columns:repeat(4,1fr)!important;gap:8px!important;margin-bottom:10px!important}.boletin-field{border-bottom:1px solid #eee!important}.boletin-footer,tr{page-break-inside:avoid}.boletin-footer{gap:2rem!important;margin-top:2rem!important}.observations-box{border:1px solid #ccc!important;margin-top:10px!important;padding:5px!important}}.management-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1rem;display:grid}.management-card{border:1px solid var(--glass-border);background:#0f172a61;border-radius:.85rem;padding:1rem}.subject-editor{gap:.55rem;display:grid}.subject-row{border-radius:8px;grid-template-columns:24px minmax(0,1fr) 130px 32px;align-items:center;gap:.5rem;padding:4px;transition:all .2s;display:grid}.drag-handle{cursor:grab;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.subject-row.dragging{opacity:.4;background:#ffffff0d;transform:scale(.98)}.academic-locks-table thead .academic-locks-header{color:#f8fafc;background:#22c55e1f;border-bottom:2px solid #22c55e}.academic-locks-table thead .academic-locks-header-main{background:#22c55e29}@media (width<=900px){.management-grid{grid-template-columns:1fr}}@media (width<=600px){.subject-row{grid-template-columns:1fr}}.attendance-container{flex-direction:column;gap:1.5rem;padding-bottom:2rem;display:flex}.attendance-header{background:#ffffff08;border:1px solid #ffffff0d;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem;display:flex}.attendance-legend-top{background:#ffffff08;border:1px solid #ffffff14;border-radius:10px;gap:1.5rem;margin-bottom:1rem;padding:.75rem 1.25rem;display:flex}.month-selector-wrapper{align-items:center;gap:.75rem;display:flex}.month-selector-wrapper label{color:var(--text-muted);font-size:.85rem;font-weight:500}.month-select{border:1px solid var(--glass-border);color:#fff;cursor:pointer;background:#0f172acc;border-radius:8px;outline:none;padding:.5rem 1rem;font-size:.9rem;transition:all .2s}.month-select:hover{border-color:var(--primary);background:#0f172af2}.search-input-container{border:1px solid var(--glass-border);background:#0f172a99;border-radius:8px;align-items:center;padding:0 .75rem;transition:all .2s;display:flex}.search-input-container:focus-within{border-color:var(--primary);background:#0f172acc}.search-icon{color:var(--text-muted);margin-right:.5rem}.search-input{color:#fff;background:0 0;border:none;outline:none;width:200px;padding:.5rem 0;font-size:.9rem}.attendance-grid-wrapper{background:#0003;border:1px solid #ffffff0d;border-radius:12px;position:relative;overflow-x:auto}.attendance-table{border-collapse:separate;border-spacing:0;width:max-content;min-width:100%}.attendance-table th,.attendance-table td{text-align:center;border-bottom:1px solid #ffffff0d;border-right:1px solid #ffffff0d;padding:.5rem}.attendance-table thead th{z-index:10;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:#0f172a;font-size:.75rem;font-weight:600;position:sticky;top:0}.day-label{opacity:.6;margin-bottom:2px;font-size:.6rem}.day-num{font-size:.9rem;font-weight:700}.attendance-table .student-col{z-index:11;text-align:left;width:180px;min-width:180px;max-width:180px;padding-left:1rem;position:sticky;left:0;box-shadow:2px 0 5px #0000004d;background:#0f172a!important}.attendance-table thead th.student-col{z-index:12}.attendance-student-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.day-cell{width:45px;min-width:45px}.attendance-input{color:#fff;text-align:center;text-transform:uppercase;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;width:34px;height:32px;font-size:.85rem;font-weight:600;transition:all .2s}.attendance-input:hover{background:#ffffff1a;border-color:#fff3}.attendance-input:focus{border-color:var(--primary);background:#6366f11a;outline:none;box-shadow:0 0 0 2px #6366f133}.attendance-input.val-p{color:#10b981}.attendance-input.val-a{color:#ef4444}.attendance-input.val-aj{color:#f59e0b}.week-alt{background:#ffffff0a!important}.attendance-table th.week-alt{background:#ffffff14!important}.day-active{border-left:2px solid #10b981;border-right:2px solid #10b981;background:#10b98126!important}.day-empty{opacity:.3;background:#0000001a}.mobile-nav-arrows{gap:.25rem;display:flex}.btn-icon{border:1px solid var(--glass-border);color:#fff;cursor:pointer;background:#ffffff0d;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:all .2s;display:flex}.btn-icon:hover:not(:disabled){border-color:var(--primary);background:#ffffff1a}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.legend-card{background:#ffffff08;border:1px solid #ffffff0d;border-radius:10px;flex-wrap:wrap;gap:1.5rem;padding:1rem;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.legend-badge{border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.badge-p{color:#10b981;background:#10b98126;border:1px solid #10b9814d}.badge-a{color:#ef4444;background:#ef444426;border:1px solid #ef44444d}.badge-aj{color:#f59e0b;background:#f59e0b26;border:1px solid #f59e0b4d}@media (width<=768px){.attendance-header{flex-direction:column;align-items:stretch}.attendance-table .student-col{width:140px;min-width:140px;font-size:.75rem}}
