@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fef07dbb0973bf53-s.518e079e.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.ea323500.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/53b9e256198e5412-s.853d50a3.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.55554cd0.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.3b6cae6d.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_2ae47f08-module__h69qWW__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_2ae47f08-module__h69qWW__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5ce348bf30bf5439-s.56c1f21e.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.3b336396.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6306c77e7c8268e4-s.e3369375.woff2)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7d817b4c03b0c5f1-s.a40b9a8b.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.fe42ddf4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.29207c2f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_eb58308d-module__w_p2Lq__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_eb58308d-module__w_p2Lq__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-teal-600:#009588;--color-gray-500:#6a7282;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--font-weight-bold:700;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-teal-600:lab(55.0223% -41.0774 -3.90277);--color-gray-500:lab(47.7841% -.393182 -10.0268)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.fixed{position:fixed}.relative{position:relative}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mt-2{margin-top:calc(var(--spacing)*2)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-white{background-color:var(--color-white)}.p-4{padding:calc(var(--spacing)*4)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.text-gray-500{color:var(--color-gray-500)}.text-teal-600{color:var(--color-teal-600)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--font-base:"Inter",sans-serif;--color-bg:#f5f7fb;--color-surface:#fff;--color-border:#e5e7eb;--color-text:#1f2937;--color-text-muted:#6b7280;--color-success:#16a34a;--color-warning:#f59e0b;--color-danger:#dc2626}.theme-blue{--color-primary:#00a79d;--color-primary-light:#00e6d6be;--color-primary-dark:#00837b;--color-bg:#f8fafc;--color-surface:#fff;--color-text:#0f172a;--color-text-muted:#475569;justify-content:center;align-items:center;height:100%;display:flex}.theme-red{--color-primary:#dc2626;--color-primary-light:#fca5a5;--color-primary-dark:#991b1b;--color-bg:#fef2f2;--color-surface:#fff;--color-text:#1f2937;--color-text-muted:#6b7280;justify-content:center;align-items:center;height:100%;display:flex}.theme-green{--color-primary:#16a34a;--color-primary-light:#86efac;--color-primary-dark:#166534;--color-bg:#f0fdf4;--color-surface:#fff;--color-text:#052e16;--color-text-muted:#4d7c0f;justify-content:center;align-items:center;height:100%;display:flex}.theme-purple{--color-primary:#473179;--color-primary-light:#a688d8;--color-primary-dark:#2e1a5c;--color-bg:#f5f0fc;--color-surface:#fff;--color-text:#1f1533;--color-text-muted:#6e559f;justify-content:center;align-items:center;height:100%;display:flex}.teacher-notes-table-card{background:#fff;border-radius:10px;padding:10px;overflow:hidden;box-shadow:0 1px 3px #00000014}.teacher-notes-table-wrap{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent;border-radius:8px;width:100%;max-height:calc(100vh - 220px);overflow:auto}.teacher-notes-table-wrap::-webkit-scrollbar{width:6px;height:6px}.teacher-notes-table-wrap::-webkit-scrollbar-track{background:0 0}.teacher-notes-table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.sticky-col{z-index:3;background:#fff;position:sticky;left:0;box-shadow:2px 0 4px #00000014}.th-student{color:#fff;text-align:left;background:#5d7da7;min-width:200px;box-shadow:2px 0 4px #00000026;z-index:5!important}.teacher-notes-table thead{z-index:10;position:sticky;top:0}.th-student-desktop{display:inline}.th-student-mobile{display:none}@media (max-width:768px){.attendance-page{gap:10px}.attendance-topbar{flex-direction:column;gap:8px}.attendance-info{box-sizing:border-box;width:100%;padding:10px 12px}.meta-grid{flex-direction:column;gap:4px;display:flex!important}.meta-item{justify-content:space-between;align-items:center;gap:8px;font-size:12px;display:flex}.meta-label{color:#374151;white-space:nowrap;flex-shrink:0;font-weight:600}.meta-value{color:#111827;text-align:right;white-space:nowrap;text-overflow:ellipsis;max-width:60%;overflow:hidden}.attendance-period-range{justify-content:space-between;align-items:center;gap:8px;margin-top:6px;font-size:12px;display:flex}.attendance-period-range .meta-value{max-width:none;font-size:12px}.attendance-period-row{align-items:center;gap:8px;margin-top:6px;display:flex}.attendance-period-select{flex:1;width:100%}.attendance-actions{flex-direction:column;gap:8px;width:100%;display:flex}.attendance-actions .btn-primary,.attendance-actions .btn-outline-primary{justify-content:center;width:100%}.attendance-alert{padding:8px 12px;font-size:12px}.attendance-table-card{border-radius:8px;padding:6px}.teacher-notes-info,.teacher-notes-actions,.notes-period-selector,.notes-period-select{width:100%}.teacher-notes-page{gap:10px}.teacher-notes-topbar{flex-direction:column;gap:8px}.teacher-notes-info{width:100%;padding:10px 12px}.teacher-notes-info-row{font-size:12px}.teacher-notes-actions{justify-content:flex-start;width:100%}.teacher-notes-actions .btn-primary{justify-content:center;width:100%}.notes-period-selector{width:100%;margin-top:6px}.notes-period-select{width:100%}.teacher-notes-table-card{border-radius:8px;padding:6px}.teacher-notes-table-wrap{border:1px solid #e2e8f0;border-radius:8px;max-height:calc(100vh - 200px)}.teacher-notes-table{font-size:11px}.teacher-notes-table thead th{padding:5px 4px;font-size:10px}.teacher-notes-table tbody td{padding:4px 3px}.td-student,.th-student{white-space:normal!important;word-break:break-word!important;width:110px!important;min-width:110px!important;max-width:110px!important;padding:4px 6px!important;font-size:11px!important;line-height:1.3!important;overflow:hidden!important}.student-id{display:none}.student-name{white-space:nowrap;text-overflow:ellipsis;max-width:98px;font-size:11px;font-weight:600;display:block;overflow:hidden}.th-block{padding:5px 4px;font-size:10px}.th-criteria,.th-criteria-percent,.th-recup,.th-recup-percent{min-width:56px;padding:4px 3px;font-size:10px}.th-def,.th-def-percent,.th-acum,.th-final{min-width:52px;padding:4px 3px;font-size:10px}.th-act-name{max-width:54px;font-size:10px}.cell-input{text-align:center;width:48px;padding:4px 2px;font-size:11px}.cell-input:focus{background:#0ea5a41f;border-radius:4px}.td-criteria{min-width:56px;padding:4px 3px}.td-acum{min-width:52px;padding:4px 3px;font-size:11px}.td-recup{min-width:56px;padding:4px 3px}.td-recup input{width:48px;padding:4px 2px;font-size:11px}.td-def{min-width:52px;padding:4px 3px;font-size:11px}.td-final{min-width:52px;padding:4px 3px;font-size:11px;font-weight:800}.cell-readonly{font-size:11px;font-weight:700}.cell-wrap{gap:1px}.cell-status{font-size:9px}.student-cell{gap:4px}.th-student-desktop{display:none}.th-student-mobile{display:inline}.grade-table{font-size:11px}.grade-table th,.grade-table td{padding:5px 4px;font-size:11px}.th-sticky-left,.td-sticky-left{z-index:3;background:#f3f4f6;position:sticky}.th-id,.td-id{display:none}.th-name,.td-name{text-align:left;white-space:nowrap;text-overflow:ellipsis;background:#f3f4f6;overflow:hidden;box-shadow:2px 0 4px #00000014;width:115px!important;min-width:115px!important;max-width:115px!important;padding-left:8px!important;left:0!important}.grade-table thead .th-name{color:#111827;z-index:5;background:#f3f4f6;font-weight:700}.th-date{min-width:90px;font-size:10px}.att-select{border-radius:6px;width:44px;padding:3px 2px;font-size:11px}.th-group{min-width:46px;padding:4px 3px;font-size:10px}.td-green,.td-yellow,.td-dark,.td-red{text-align:center;min-width:46px;padding:4px 3px;font-size:11px}.table-wrap{border-radius:8px}}@media (max-width:480px){.teacher-notes-table{font-size:10px}.td-student,.th-student{min-width:130px}.student-name{max-width:110px;font-size:10px}.cell-input{width:42px;padding:3px;font-size:10px}.teacher-notes-table-wrap{max-height:calc(100vh - 160px)}.teacher-notes-table-wrap:after{content:"← desliza →";text-align:center;color:#9ca3af;padding:4px;font-size:10px;display:block;position:sticky;left:0}}.cell-wrap{align-items:center;gap:2px;display:flex}.cell-status{flex-shrink:0;font-size:10px}.cell-saved-pass{border-radius:4px;background:#22c55e1a!important}.cell-saved-fail{border-radius:4px;background:#ef44441a!important}.cell-error-input{border-radius:4px;background:#ef444426!important}.th-act-name{text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-size:11px;overflow:hidden}@media (max-width:768px){.th-act-name{max-width:70px;font-size:10px}}.table-wrap{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent;background:#fff;border:1px solid #11182714;border-radius:12px;width:100%;overflow:auto}.table-wrap::-webkit-scrollbar{width:5px;height:5px}.table-wrap::-webkit-scrollbar-track{background:0 0}.table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.th-sticky-left,.td-sticky-left{z-index:3;background:#f3f4f6}.grade-table thead{z-index:10;position:sticky;top:0}.grade-table thead .th-sticky-left{z-index:11;background:#f3f4f6}@media (max-width:768px){.grade-table{font-size:11px}.grade-table th,.grade-table td{padding:6px 5px;font-size:11px}.th-id,.td-id{width:100px;min-width:100px;left:0;box-shadow:1px 0 #0000000f}.th-name,.td-name{text-align:left;width:160px;min-width:160px;padding-left:10px;left:100px;box-shadow:2px 0 4px #00000014}.th-group{min-width:52px}.att-select{width:44px;padding:3px 2px;font-size:10px}.th-date{min-width:72px;font-size:10px}}@media (max-width:480px){.grade-table{font-size:10px}.grade-table th,.grade-table td{padding:5px 4px}.th-id,.td-id{width:28px;min-width:28px}.th-name,.td-name{width:100px;min-width:100px;left:28px}.att-select{width:38px;font-size:10px}.th-date{min-width:60px;font-size:10px}.table-wrap:after{content:"← desliza →";text-align:center;color:#9ca3af;padding:4px 0 2px;font-size:10px;display:block}}.teacher-notes-page{flex-direction:column;gap:16px;display:flex}.teacher-notes-topbar{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.teacher-notes-actions{justify-content:flex-end;align-items:flex-start;display:flex}.teacher-notes-info{box-sizing:border-box;background:#fff;border-radius:10px;grid-template-columns:1fr;gap:8px;width:100%;max-width:360px;padding:14px 16px;display:grid;box-shadow:0 1px 3px #00000014}.teacher-notes-info-row{justify-content:space-between;font-size:13px;display:flex}.teacher-notes-info-row .label{color:#374151;font-weight:600}.teacher-notes-info-row .value{color:#111827}.teacher-notes-table-card{background:#fff;border-radius:10px;padding:10px;box-shadow:0 1px 3px #00000014}.teacher-notes-table-wrap{border-radius:10px;width:100%;max-height:calc(100vh - 220px);overflow:auto}.teacher-notes-table{border-collapse:collapse;width:max-content;min-width:100%;font-size:12px}.teacher-notes-table thead th{text-align:center;vertical-align:middle;white-space:nowrap;border:1px solid #00000014;padding:8px}.th-student{color:#fff;text-align:left;background:#5d7da7;min-width:280px}.th-criteria{color:#fff;background:#5d7da7;min-width:120px}.th-criteria-percent{color:#111827;background:#fde047;font-weight:700}.th-criteria-subtitle{color:#111827;background:#e5e7eb}.th-acum{color:#fff;background:#0f172a;min-width:70px}.th-activity-number{color:#fff;background:#0f172a;min-width:90px}.th-activity-date{color:#111827;background:#fde047;font-weight:700}.th-activity-title{color:#fff;background:#0ea5a4}.act-title{font-size:12px;font-weight:700}.act-subtitle{opacity:.9;font-size:11px}.teacher-notes-table tbody td{background:#fff;border:1px solid #00000014;padding:6px}.sticky-col{z-index:3;position:sticky;left:0}.td-student{z-index:4;background:#f3f4f6;min-width:280px}.student-cell{align-items:center;gap:8px;display:flex}.student-id{color:#111827;font-weight:700}.student-name{color:#111827;font-weight:500}.cell-input{text-align:center;background:0 0;border:none;outline:none;width:70px;padding:6px 8px;font-size:12px}.cell-input:focus{background:#0ea5a41f;border-radius:6px}.td-criteria{background:#d1fae5}.td-activity{background:#ffe4e6}.td-acum{text-align:center;background:#fef9c3;font-weight:700}.th-block{color:#fff;background:#0f172a;padding:8px;font-weight:700}.th-block-criteria{background:#5d7da7}.th-block-recup{background:#1d4ed8}.th-block-def{background:#16a34a}.th-final{color:#fff;background:#dc2626;min-width:80px;font-weight:800}.th-recup,.th-recup-percent{background:#fde68a}.th-def,.th-def-percent{background:#bbf7d0}.td-recup{background:#ffe4e6}.td-recup.disabled{opacity:.65;background:#e5e7eb!important}.td-recup.disabled input{cursor:not-allowed}.td-def{text-align:center;background:#dcfce7}.cell-readonly{font-weight:700}.td-final{text-align:center;background:#fee2e2;font-weight:800}.td-final.danger{color:#7f1d1d;background:#fecaca}.table-wrap{background:#fff;border:1px solid #11182714;border-radius:12px;width:100%;overflow:auto}.table-empty-hint{color:#6b7280;background:#f9fafb;border-top:1px solid #11182714;padding:14px;font-size:13px}.grade-table{border-collapse:collapse;width:100%;min-width:1000px}.grade-table th,.grade-table td{vertical-align:middle;text-align:center;border:1px solid #11182714;padding:8px;font-size:12px}.th-sticky-left,.td-sticky-left{z-index:3;background:#fff;left:0}.th-id,.td-id{width:50px;min-width:50px;left:0;box-shadow:1px 0 #0000000f}.th-name,.td-name{text-align:left;width:160px;min-width:160px;padding-left:10px;left:90px;box-shadow:2px 0 4px #00000014}.grade-table thead th{background:#f3f4f6;font-weight:700;color:#111827!important}.th-date{background:#0f172a;min-width:95px;font-weight:700;color:#fff!important}.th-group{color:#111827;min-width:90px;font-weight:700}.th-green{background:#cfe9cf!important}.th-yellow{background:#f7e2b9!important}.th-brown{background:#e0b2b2!important}.th-red{background:#f0b5b5!important}.td-green{background:#cfe9cf59}.td-yellow{background:#f7e2b959}.td-brown{background:#e0b2b259}.td-red{background:#f0b5b559}.grade-table tbody tr:nth-child(2n) td{background:#f9fafb99}.td-att{padding:4px}.att-select{text-align:center;background:#fff;border:1px solid #1118271f;border-radius:8px;outline:none;width:60px;padding:6px 8px;font-weight:700}.att-select:focus{border-color:var(--color-primary)}.status-presente{background:#22c55e2e}.status-excusa{background:#eab3082e}.status-ausente{background:#ef44442e}.status-suspendido{background:#11182738}.status-empty{background:0 0}.att-select.status-presente{color:#065f46;background:#22c55e40;border-color:#22c55e80}.att-select.status-excusa{color:#92400e;background:#eab30840;border-color:#eab3088c}.att-select.status-ausente{color:#7f1d1d;background:#ef444440;border-color:#ef44448c}.att-select.status-suspendido{color:#fff;background:#1118278c;border-color:#111827cc}.th-dark{color:#fff!important;background:#bcf7f7e6!important}.td-dark{color:#111827;background:#1118272e;font-weight:600}.table-container{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 10px #0000000d}.table-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;display:flex}.table-wrapper{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent;width:100%;overflow-x:auto}.table-wrapper::-webkit-scrollbar{height:5px}.table-wrapper::-webkit-scrollbar-track{background:0 0}.table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.admin-table{border-collapse:collapse;width:100%;min-width:560px}.admin-table th{text-align:left;white-space:nowrap;background:#f5f7fb;padding:12px;font-weight:600}.admin-table td{white-space:nowrap;border-bottom:1px solid #eee;padding:12px}.admin-table tr:hover{background:#fafafa}@media (max-width:640px){.table-container{padding:12px}.table-header{flex-direction:column;align-items:stretch}.admin-table th,.admin-table td{padding:10px 8px;font-size:12px}}.actions{gap:10px;display:flex}.table-search{border:1px solid #ddd;border-radius:6px;width:250px;padding:8px}.table-pagination{justify-content:center;gap:10px;margin-top:15px;display:flex}.dashboard-root{background-color:#f4f6f8;width:100vw;height:100vh;display:flex;overflow:hidden}.admin-dashboard-chart-grid{grid-template-columns:1fr 1fr 1fr;align-items:start;gap:20px;display:grid}@media (max-width:1024px){.admin-dashboard-chart-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.admin-dashboard-chart-grid{grid-template-columns:1fr}}.admin-dashboard-stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;display:grid}@media (max-width:480px){.admin-dashboard-stats-grid{grid-template-columns:1fr 1fr}}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff59}.sidebar{background-color:var(--color-primary);scrollbar-width:thin;scrollbar-color:#fff3 transparent;width:260px;height:100vh;padding:12px;transition:width .25s;overflow:hidden auto}.sidebar.collapsed{width:72px}.sidebar-item{color:#e6fffa;cursor:pointer;border-radius:6px;justify-content:space-between;align-items:center;padding:10px 12px;font-size:14px;display:flex}.sidebar-item:hover{background-color:#ffffff1f}.sidebar-item.active{color:var(--color-primary);background-color:#fff;font-weight:600}.sidebar-left{align-items:center;gap:10px;display:flex}.sidebar-submenu{flex-direction:column;margin-top:6px;margin-left:26px;display:flex}.sidebar-submenu a{color:#e6fffa;border-radius:6px;padding:8px 10px;font-size:13px}.sidebar-submenu a.active{background-color:#ffffff40}.chevron{transition:transform .2s}.chevron.open{transform:rotate(180deg)}.dashboard-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.dashboard-main{background-color:#f4f6f8;flex:1;padding:24px;overflow-y:auto}.page-title{color:#1f2937;font-size:20px;font-weight:600}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.chart-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (max-width:1024px){.chart-grid{grid-template-columns:1fr}}@media (max-width:640px){.chart-grid{gap:16px}}.alert-action-grid{grid-template-columns:1fr 2fr;gap:16px;display:grid}.quick-actions{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.chart-title{color:#374151;justify-content:center;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.quick-action{cursor:pointer;border:none;border-radius:18px;align-items:center;gap:14px;padding:18px 20px;font-size:14px;font-weight:600;transition:all .3s;display:flex;position:relative;overflow:hidden}.action-icon{background:#fff3;border-radius:12px;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.quick-action:first-child{animation-delay:.1s}.quick-action:nth-child(2){animation-delay:.2s}.quick-action:nth-child(3){animation-delay:.3s}.quick-action:nth-child(4){animation-delay:.4s}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.quick-action .icon{border:2px solid #ffffffe6;border-radius:8px;width:36px;height:36px;position:relative}.icon.user:before{content:"";border:2px solid #fff;border-radius:50%;width:12px;height:12px;position:absolute;top:6px;left:10px}.icon.user:after{content:"+";font-size:18px;position:absolute;top:-6px;right:-6px}.icon.money:before{content:"$";justify-content:center;align-items:center;font-size:20px;display:flex;position:absolute;inset:0}.icon.grid:before{content:"";border:2px solid #fff;position:absolute;inset:6px}.icon.file:before{content:"";border:2px solid #fff;border-radius:4px;position:absolute;inset:8px}.overlay-container{z-index:999;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0f172a8c;justify-content:center;align-items:center;animation:.3s forwards fadeBackdrop;display:flex;position:fixed;inset:0}@keyframes fadeBackdrop{0%{opacity:0}to{opacity:1}}.overlay-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffcfc;border:1px solid #ffffff26;border-radius:22px;width:95%;max-width:1000px;max-height:90vh;padding:28px;animation:.4s cubic-bezier(.16,.84,.44,1) slideModal;overflow-y:auto;box-shadow:0 25px 60px #00000080}@keyframes slideModal{0%{opacity:0;transform:translateY(40px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.overlay-body{scrollbar-gutter:stable;flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.overlay-header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.overlay-header h2{color:#353535;font-size:20px;font-weight:600}.overlay-close{cursor:pointer;color:#353535;background:#ffffff70;border:none;border-radius:12px;padding:8px;transition:all .3s}.overlay-close:hover{background:#ef4444;transform:rotate(90deg)}.card{background:#f9fafb;border-radius:12px;align-items:center;gap:16px;padding:16px;display:flex}.card.horizontal{justify-content:space-between}.card-icon{color:var(--color-primary);font-size:26px}.upload-card input{margin-left:auto}.input-error{border:1px solid #e53935}.error-text{color:#e53935;margin-top:4px;font-size:12px;display:block}.input-error{border-color:#ef4444}.input-error-text{color:#ef4444;margin-top:4px;font-size:12px;display:block}.info-box{border-radius:16px;align-items:flex-start;gap:14px;margin-top:16px;padding:16px;animation:.4s fadeInInfo;display:flex}.info-box.error{background:#ef444426;border:1px solid #ef444466}.info-box.success{background:#22c55e26;border:1px solid #22c55e66}@keyframes fadeInInfo{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.overlay-footer{background:#fff;border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.footer-left{align-items:center;min-height:24px;display:flex}.footer-progress{align-items:center;gap:12px;display:flex}.footer-progress span{white-space:nowrap;font-size:13px;font-weight:500}.footer-progress-bar{background:#e5e7eb;border-radius:6px;width:140px;height:6px;overflow:hidden}.footer-progress-fill{background:#0ea5a4;height:100%;transition:width .3s}.footer-right{gap:10px;display:flex}.btn-primary:disabled{cursor:not-allowed;background:#9ca3af}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:14px;align-items:center;padding:10px 20px;font-weight:600;transition:all .3s;display:flex}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 10px 25px #22c55e66}.btn-secondary{color:#cbd5e1;cursor:pointer;background:#ffffff1a;border:none;border-radius:14px;padding:10px 20px;transition:all .3s}.btn-secondary:hover{background:#fff3}.btn-outline{border:1px solid var(--color-primary);color:var(--color-primary);border-radius:8px;padding:8px 14px;text-decoration:none}.btn-link{cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.btn-link.danger:hover{text-decoration:underline}.overlay-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffa2;border:1px solid #ffffff1f;border-radius:16px;gap:6px;padding:6px;display:flex;position:relative}.tab-btn{color:#041325;cursor:pointer;z-index:2;background:0 0;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:600;transition:all .3s;display:flex;position:relative}.tab-btn:hover{color:#2e2e2e}.tab-btn.active{color:#585858}.form-card{flex-direction:column;align-items:stretch}.section-title{margin-bottom:10px;font-size:15px;font-weight:600}@media (max-width:900px){.form-grid{grid-template-columns:1fr}}.form-label{color:#374151;font-size:12.5px;font-weight:600}.form-input{border:1px solid #d1d5db;border-radius:10px;outline:none;padding:10px 12px;font-size:14px}.mini-errors{color:#7f1d1d;background:#fef2f2;border-radius:12px;align-items:flex-start;gap:10px;margin-top:12px;padding:12px;display:flex}.mini-errors ul{margin-top:6px;padding-left:18px;font-size:13px}.page-header-row{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.meta-grid{grid-template-columns:repeat(2,minmax(180px,1fr));gap:6px 18px;margin-top:8px;display:grid}.meta-item{gap:8px;font-size:13px;display:flex}.meta-label{color:#6b7280;font-weight:600}.meta-value{color:#111827;font-weight:600}.overlay-md{width:820px}.criteria-card{flex-direction:column;align-items:stretch}.criteria-row{grid-template-columns:2fr 1fr;gap:14px;display:grid}@media (max-width:860px){.criteria-row{grid-template-columns:1fr}}.percent-symbol{color:#374151;font-size:16px;font-weight:700}.criteria-summary{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:10px;margin-top:14px;padding-top:12px;font-size:14px;display:flex}.criteria-preview-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.criteria-preview-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.criteria-preview-name{color:#0f172a;font-size:14px;font-weight:600}.criteria-preview-percent{color:var(--color-primary);font-size:14px;font-weight:800}.course-actions{gap:20px;margin-top:30px;display:flex}.course-btn{cursor:pointer;border:none;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-width:180px;padding:30px;font-weight:600;transition:all .2s;display:flex}.course-btn:hover{transform:translateY(-3px)}.asistencia{color:#0369a1;background:#e0f2fe}.notas{color:#2e7d32;background:#e8f5e9}.logros{color:#ef6c00;background:#fff3e0}.create-logro-wrapper{max-width:640px;margin:0 auto}.create-logro-card{background:#fff;border-radius:20px;flex-direction:column;gap:20px;padding:28px;display:flex;box-shadow:0 4px 24px #00000012}.create-logro-card h2{color:#1f2937;margin:0;font-size:20px;font-weight:700}.logro-field{flex-direction:column;gap:6px;display:flex}.logro-label{color:#374151;font-size:12.5px;font-weight:600}.logro-select,.logro-textarea{color:#1f2937;background:#f9fafb;border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.logro-select:focus,.logro-textarea:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #0ea5a433}.logro-select:disabled{color:#9ca3af;cursor:not-allowed;background:#f3f4f6}.logro-textarea{resize:vertical;min-height:110px;line-height:1.6}.logro-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.logro-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#14b8a6,#0ea5e9);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 24px;font-size:15px;font-weight:700;transition:all .3s;display:flex;position:relative;overflow:hidden}.logro-submit:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 25px #0ea5e966}.logro-submit:disabled{cursor:not-allowed;box-shadow:none;background:#9ca3af;transform:none}.logro-submit:after{content:"";background:linear-gradient(120deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:all .6s;position:absolute;top:0;left:-120%}.logro-submit:hover:not(:disabled):after{left:120%}.logro-alert{border-radius:14px;padding:14px 16px;font-size:13.5px;font-weight:500;animation:.3s fadeInInfo}.logro-alert.success{color:#166534;background:#22c55e26;border:1px solid #22c55e66}.logro-alert.error{color:#991b1b;background:#ef444426;border:1px solid #ef444466}@media (max-width:640px){.create-logro-card{border-radius:16px;padding:20px 16px}.logro-grid-2{grid-template-columns:1fr}}.assign-page{flex-direction:column;gap:24px;max-width:860px;margin:0 auto;display:flex}.assign-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (max-width:640px){.assign-grid{grid-template-columns:1fr}}.assign-card{background:#fff;border-radius:20px;flex-direction:column;gap:14px;padding:24px;display:flex;box-shadow:0 4px 24px #00000012}.assign-card-header{color:var(--color-primary);align-items:center;gap:10px;font-size:15px;font-weight:700;display:flex}.assign-search,.assign-select{color:#1f2937;background:#f9fafb;border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.assign-search:focus,.assign-select:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #0ea5a433}.assign-preview{background:linear-gradient(135deg,#0ea5a414,#0ea5e914);border:1px solid #0ea5a440;border-radius:12px;flex-direction:column;gap:2px;padding:12px 14px;animation:.3s fadeInInfo;display:flex}.assign-preview-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);font-size:11px;font-weight:700}.assign-preview-value{color:#1f2937;font-size:14px;font-weight:700}.assign-preview-sub{color:#6b7280;font-size:12px}.assign-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#14b8a6,#0ea5e9);border:none;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px 28px;font-size:15px;font-weight:700;transition:all .3s;display:flex;position:relative;overflow:hidden}.assign-submit:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 25px #0ea5e966}.assign-submit:disabled{cursor:not-allowed;box-shadow:none;background:#9ca3af;transform:none}.assign-submit:after{content:"";background:linear-gradient(120deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:all .6s;position:absolute;top:0;left:-120%}.assign-submit:hover:not(:disabled):after{left:120%}.assign-alert{border-radius:14px;padding:14px 16px;font-size:13.5px;font-weight:500;animation:.3s fadeInInfo}.assign-alert.success{color:#166534;background:#22c55e26;border:1px solid #22c55e66}.assign-alert.error{color:#991b1b;background:#ef444426;border:1px solid #ef444466}.page-container{flex-direction:column;gap:24px;max-width:1100px;margin:0 auto;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.table-container{background:#fff;border-radius:20px;flex-direction:column;gap:16px;padding:24px;display:flex;overflow:hidden;box-shadow:0 4px 24px #00000012}.table-header{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.table-wrapper{border-radius:12px;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;min-width:500px;font-size:14px}.admin-table thead tr{background:linear-gradient(135deg,#0ea5a414,#0ea5e914);border-bottom:2px solid #0ea5a433}.admin-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:700}.admin-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background .15s}.admin-table tbody tr:last-child{border-bottom:none}.admin-table tbody tr:hover{background:#f9fafb}.admin-table tbody td{color:#374151;padding:13px 16px;font-size:13.5px}.admin-table tbody td:first-child{color:#9ca3af;font-size:12px;font-weight:600}.role-badge{letter-spacing:.03em;border-radius:20px;padding:3px 10px;font-size:11.5px;font-weight:700;display:inline-block}.role-badge.student{color:#4338ca;background:#6366f11f}.role-badge.teacher{color:#0f766e;background:#0ea5a41f}.role-badge.admin{color:#b45309;background:#f59e0b1f}.actions{align-items:center;gap:8px;display:flex}.btn-edit{color:var(--color-primary);cursor:pointer;background:0 0;border:1.5px solid #0ea5a466;border-radius:8px;padding:6px 14px;font-size:12.5px;font-weight:600;transition:all .2s}.btn-edit:hover{border-color:var(--color-primary);background:#0ea5a414;transform:translateY(-1px)}.btn-delete{color:#dc2626;cursor:pointer;background:0 0;border:1.5px solid #ef44444d;border-radius:8px;padding:6px 14px;font-size:12.5px;font-weight:600;transition:all .2s}.btn-delete:hover{background:#ef444414;border-color:#dc2626;transform:translateY(-1px)}.btn-save{color:#16a34a;cursor:pointer;background:0 0;border:1.5px solid #16a34a66;border-radius:8px;padding:6px 14px;font-size:12.5px;font-weight:600;transition:all .2s}.btn-save:hover{background:#16a34a14;border-color:#16a34a;transform:translateY(-1px)}.table-loading{color:#9ca3af;justify-content:center;align-items:center;gap:10px;padding:48px;font-size:14px;display:flex}.table-empty{text-align:center;color:#9ca3af;padding:48px;font-size:14px}@media (max-width:768px){.table-container{border-radius:16px;padding:16px}.table-header{justify-content:stretch}.table-header>*{width:100%}.admin-table thead th:first-child,.admin-table tbody td:first-child{display:table-cell}}@media (max-width:480px){.actions{flex-direction:column;gap:4px}.btn-edit,.btn-delete{text-align:center;width:100%}}.boletines-page{flex-direction:column;gap:28px;width:100%;max-width:900px;margin:0 auto;display:flex}.boletines-header{flex-direction:column;gap:6px;display:flex}.boletines-subtitle{color:#6b7280;margin:0;font-size:14px}.boletines-loading{text-align:center;color:#9ca3af;padding:48px;font-size:14px}.boletines-grid{grid-template-columns:repeat(4,1fr);gap:18px;display:grid}@media (max-width:900px){.boletines-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.boletines-grid{grid-template-columns:1fr 1fr;gap:12px}}.periodo-card{cursor:pointer;text-align:center;background:#fff;border:1.5px solid #0000;border-radius:20px;flex-direction:column;align-items:center;gap:12px;padding:28px 20px;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000000f}.periodo-card:before{content:"";opacity:0;background:linear-gradient(135deg,#14b8a6,#0ea5e9);height:4px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.periodo-card:hover:before{opacity:1}.periodo-card:after{content:"";background:linear-gradient(120deg,#0000,#0ea5a40f,#0000);width:100%;height:100%;transition:all .5s;position:absolute;top:0;left:-120%}.periodo-card:hover:after{left:120%}.periodo-card:hover{border-color:#0ea5a44d;transform:translateY(-5px);box-shadow:0 12px 32px #0ea5a426}.periodo-icon{font-size:32px;line-height:1}.periodo-title{color:#1f2937;margin:0;font-size:15px;font-weight:700}.periodo-cta{color:var(--color-primary);opacity:0;font-size:12px;font-weight:600;transition:all .25s;transform:translateY(4px)}.periodo-card:hover .periodo-cta{opacity:1;transform:translateY(0)}.boletines-gen-page{flex-direction:column;gap:24px;width:100%;max-width:900px;margin:0 auto;display:flex}.boletines-filters{background:#fff;border-radius:20px;flex-direction:column;gap:20px;padding:24px;display:flex;box-shadow:0 4px 24px #00000012}.boletines-filters h2{color:#1f2937;margin:0;font-size:16px;font-weight:700}.filters-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (max-width:580px){.filters-grid{grid-template-columns:1fr}}.filter-field{flex-direction:column;gap:6px;display:flex}.filter-label{color:#374151;font-size:12.5px;font-weight:600}.filter-select{color:#1f2937;background:#f9fafb;border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.filter-select:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #0ea5a433}.filters-action{justify-content:flex-end;display:flex}.boletines-results{background:#fff;border-radius:20px;flex-direction:column;gap:20px;padding:24px;animation:.3s fadeInInfo;display:flex;box-shadow:0 4px 24px #00000012}.results-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.results-title{color:#1f2937;margin:0;font-size:16px;font-weight:700}.results-count{color:#6b7280;font-size:13px;font-weight:500}.boletines-table-wrapper{border:1px solid #f3f4f6;border-radius:12px;overflow-x:auto}.boletines-table{border-collapse:collapse;width:100%;min-width:400px;font-size:14px}.boletines-table thead tr{background:linear-gradient(135deg,#0ea5a414,#0ea5e914);border-bottom:2px solid #0ea5a433}.boletines-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:700}.boletines-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background .15s}.boletines-table tbody tr:last-child{border-bottom:none}.boletines-table tbody tr:hover{background:#f9fafb}.boletines-table tbody td{color:#374151;padding:13px 16px;font-size:13.5px}.btn-download{color:var(--color-primary);cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid #0ea5a459;border-radius:9px;align-items:center;gap:6px;padding:7px 14px;font-size:12.5px;font-weight:600;transition:all .2s;display:inline-flex}.btn-download:hover{border-color:var(--color-primary);background:#0ea5a414;transform:translateY(-1px)}.btn-zip{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 20px;font-size:13.5px;font-weight:700;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.btn-zip:hover{transform:translateY(-2px);box-shadow:0 8px 20px #8b5cf666}.btn-zip:after{content:"";background:linear-gradient(120deg,#0000,#ffffff40,#0000);width:100%;height:100%;transition:all .5s;position:absolute;top:0;left:-120%}.btn-zip:hover:after{left:120%}@media (max-width:500px){.boletines-filters,.boletines-results{border-radius:16px;padding:16px}.results-header{flex-direction:column;align-items:flex-start}.btn-zip{justify-content:center;width:100%}.filters-action{justify-content:stretch}.filters-action .btn-primary{justify-content:center;width:100%}}.admin-dashboard{flex-direction:column;gap:24px;display:flex}.dashboard-chart-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (max-width:900px){.dashboard-chart-grid{grid-template-columns:1fr}}.chart-card{background:#fff;border-radius:20px;flex-direction:column;gap:16px;padding:24px;display:flex;box-shadow:0 4px 24px #00000012}.attendance-wrapper{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.attendance-legend{flex-direction:column;gap:10px;min-width:120px;display:flex}.legend-item{color:#374151;align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-dot.presente{background:#22c55e}.legend-dot.ausente{background:#ef4444}.legend-dot.excusado{background:#f59e0b}.quick-actions-card{background:#fff;border-radius:20px;flex-direction:column;gap:20px;padding:24px;display:flex;box-shadow:0 4px 24px #00000012}.quick-actions-card-title{color:#374151;margin:0;font-size:14px;font-weight:700}.quick-actions-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}@media (max-width:700px){.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:420px){.quick-actions-grid{grid-template-columns:1fr}}.quick-action{cursor:pointer;text-align:left;border:none;border-radius:16px;align-items:center;gap:12px;padding:18px 16px;font-size:13.5px;font-weight:600;transition:all .3s;display:flex;position:relative;overflow:hidden}.quick-action.primary{color:#fff;background:linear-gradient(135deg,#14b8a6,#0ea5e9);box-shadow:0 6px 18px #0ea5e94d}.quick-action.secondary{color:#fff;background:linear-gradient(135deg,#8b5cf6,#6366f1);box-shadow:0 6px 18px #8b5cf64d}.quick-action:hover{transform:translateY(-4px)scale(1.02);box-shadow:0 14px 30px #0003}.quick-action:after{content:"";background:linear-gradient(120deg,#0000,#ffffff40,#0000);width:100%;height:100%;transition:all .55s;position:absolute;top:0;left:-120%}.quick-action:hover:after{left:120%}.quick-action:first-child{animation:.4s 50ms both slideUp}.quick-action:nth-child(2){animation:.4s .1s both slideUp}.quick-action:nth-child(3){animation:.4s .15s both slideUp}.quick-action:nth-child(4){animation:.4s .2s both slideUp}.quick-action:nth-child(5){animation:.4s .25s both slideUp}.quick-action:nth-child(6){animation:.4s .3s both slideUp}.action-icon{background:#fff3;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:background .2s;display:flex}.quick-action:hover .action-icon{background:#ffffff59}@media (max-width:640px){.chart-card,.quick-actions-card{border-radius:16px;padding:16px}}@media (max-width:768px){.dashboard-root{flex-direction:column;height:100dvh}.sidebar{z-index:100;height:calc(100dvh - 52px);transition:transform .3s,width .25s;position:fixed;top:52px;left:0;overflow:hidden auto;transform:translate(-100%);width:260px!important}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff59}.sidebar.mobile-open{transform:translate(0)}.sidebar-backdrop{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;display:none;position:fixed;inset:52px 0 0}.sidebar-backdrop.visible{display:block}.dashboard-content{width:100%;height:100dvh}.dashboard-main{padding:16px}}.chart-card{background:#fff;border-radius:20px;flex-direction:column;gap:16px;min-width:0;padding:24px;display:flex;box-shadow:0 4px 24px #00000012}.chart-card-title{color:#374151;margin:0;font-size:14px;font-weight:700}@media (max-width:640px){.chart-card{border-radius:16px;padding:16px}.chart-card-title{font-size:13px}}.periodos-page{flex-direction:column;gap:24px;max-width:900px;margin:0 auto;display:flex}.periodos-header{flex-direction:column;gap:4px;display:flex}.periodos-subtitle{color:#6b7280;margin:0;font-size:14px}.periodos-layout{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}@media (max-width:720px){.periodos-layout{grid-template-columns:1fr}}.periodo-form-card,.periodos-list-card{background:#fff;border-radius:20px;flex-direction:column;gap:18px;padding:24px;display:flex;box-shadow:0 4px 24px #00000012}.periodo-form-title{color:var(--color-primary);border-bottom:1px solid #f3f4f6;align-items:center;gap:10px;padding-bottom:14px;font-size:15px;font-weight:700;display:flex}.periodo-field{flex-direction:column;gap:6px;display:flex}.periodo-label{color:#374151;font-size:12.5px;font-weight:600}.periodo-input{color:#1f2937;background:#f9fafb;border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.periodo-input:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #0ea5a433}.periodos-dates-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (max-width:400px){.periodos-dates-grid{grid-template-columns:1fr}}.periodo-date-wrapper{position:relative}.periodo-date-icon{color:#9ca3af;pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.periodo-input.with-icon{padding-left:34px}.periodo-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#14b8a6,#0ea5e9);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-size:14px;font-weight:700;transition:all .3s;display:flex;position:relative;overflow:hidden}.periodo-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #0ea5e959}.periodo-submit:disabled{cursor:not-allowed;background:#9ca3af;transform:none}.periodo-submit:after{content:"";background:linear-gradient(120deg,#0000,#ffffff40,#0000);width:100%;height:100%;transition:all .55s;position:absolute;top:0;left:-120%}.periodo-submit:hover:not(:disabled):after{left:120%}.periodo-alert{border-radius:12px;align-items:center;gap:8px;padding:12px 14px;font-size:13.5px;font-weight:500;animation:.3s fadeInInfo;display:flex}.periodo-alert.success{color:#166534;background:#22c55e26;border:1px solid #22c55e66}.periodo-alert.error{color:#991b1b;background:#ef444426;border:1px solid #ef444466}.periodos-empty{text-align:center;color:#9ca3af;padding:32px 0;font-size:13.5px}.periodos-items{flex-direction:column;gap:10px;display:flex}.periodo-item{background:#f9fafb;border:1px solid #f3f4f6;border-radius:12px;justify-content:space-between;align-items:center;padding:14px 16px;transition:all .2s;animation:.3s fadeInInfo;display:flex}.periodo-item:hover{background:#0ea5a40a;border-color:#0ea5a44d}.periodo-item-left{flex-direction:column;gap:3px;display:flex}.periodo-item-name{color:#1f2937;font-size:14px;font-weight:700}.periodo-item-dates{color:#6b7280;font-size:12px}.periodo-item-badge{color:#166534;white-space:nowrap;background:#22c55e1f;border-radius:20px;padding:3px 10px;font-size:11.5px;font-weight:700}@media (max-width:480px){.periodo-form-card,.periodos-list-card{border-radius:16px;padding:16px}}.teacher-notes-page{flex-direction:column;gap:20px;max-width:1100px;margin:0 auto;display:flex}.teacher-notes-topbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.teacher-notes-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.notes-period-selector{align-items:center;gap:10px;margin-top:10px;display:flex}.notes-period-label{color:#6b7280;white-space:nowrap;font-size:13px;font-weight:600}.notes-period-select{max-width:200px}@media (max-width:640px){.teacher-notes-topbar{flex-direction:column}.teacher-notes-actions{width:100%}.teacher-notes-actions .btn-primary{justify-content:center;width:100%}.notes-period-select{max-width:100%}}.activity-form-grid{grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;display:grid}.activity-form-grid .form-field:last-child{grid-column:1/-1}@media (max-width:580px){.activity-form-grid{grid-template-columns:1fr}.activity-form-grid .form-field:last-child{grid-column:auto}}.activity-preview{background:linear-gradient(135deg,#0ea5a40f,#0ea5e90f);border:1px solid #0ea5a433;border-radius:14px;flex-direction:column;gap:8px;margin-top:16px;padding:14px 16px;animation:.3s fadeInInfo;display:flex}.activity-preview-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);margin-bottom:2px;font-size:11px;font-weight:700}.activity-preview-row{color:#374151;border-bottom:1px dashed #e5e7eb;justify-content:space-between;padding-bottom:6px;font-size:13px;display:flex}.activity-preview-row:last-child{border-bottom:none;padding-bottom:0}.activity-preview-row span{color:#6b7280}.activity-preview-row strong{color:#1f2937}.criteria-header-left{flex-direction:column;gap:8px;display:flex}.criteria-period-selector{align-items:center;gap:10px;display:flex}.criteria-period-label{color:#6b7280;white-space:nowrap;font-size:13px;font-weight:600}.criteria-period-select{max-width:200px}.criteria-card-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.criteria-period-badge{color:var(--color-primary);vertical-align:middle;background:#0ea5a41f;border-radius:20px;margin-left:10px;padding:2px 10px;font-size:12px;font-weight:700;display:inline-block}.criteria-hint{color:#6b7280;margin:0;font-size:13px;line-height:1.5}.criteria-grid{flex-direction:column;gap:12px;margin-top:16px;display:flex}.criteria-row{background:#f9fafb;border:1px solid #f3f4f6;border-radius:12px;grid-template-columns:2fr 1fr;gap:12px;padding:14px;transition:border-color .2s;display:grid}.criteria-row:hover{border-color:#0ea5a440}@media (max-width:520px){.criteria-row{grid-template-columns:1fr}}.criteria-col.percent{max-width:100%}.percent-input{align-items:center;gap:8px;display:flex}.percent-symbol{color:#374151;flex-shrink:0;font-size:16px;font-weight:700}.criteria-total{flex-direction:column;gap:8px;margin-top:16px;display:flex}.criteria-total-bar{background:#e5e7eb;border-radius:99px;height:8px;overflow:hidden}.criteria-total-fill{border-radius:99px;height:100%;transition:width .4s,background .3s}.criteria-total.ok .criteria-total-fill{background:linear-gradient(90deg,#22c55e,#16a34a)}.criteria-total.bad .criteria-total-fill{background:linear-gradient(90deg,#f59e0b,#ef4444)}.criteria-total-text{color:#374151;align-items:center;gap:8px;font-size:13.5px;display:flex}.criteria-total.ok .criteria-total-text strong{color:#16a34a}.criteria-total.bad .criteria-total-text strong{color:#dc2626}.criteria-total-diff{color:#ef4444;font-size:12px;font-weight:500}.criteria-alert{border-radius:12px;align-items:center;gap:10px;padding:12px 14px;font-size:13.5px;font-weight:500;animation:.3s fadeInInfo;display:flex}.criteria-alert.success{color:#166534;background:#22c55e26;border:1px solid #22c55e66}.criteria-alert.error{color:#991b1b;background:#ef444426;border:1px solid #ef444466}@media (max-width:600px){.criteria-period-select{max-width:100%}.overlay-content.overlay-md{width:95%;padding:20px 16px}}:root{--bg-overlay:#0a0e1ab8;--bg-panel:#fff;--bg-surface:#f7f8fc;--bg-hover:#eef1fb;--primary:#2f54eb;--primary-hover:#1d3fcc;--primary-soft:#e8edff;--danger:#e53e3e;--danger-soft:#fff5f5;--success:#16a34a;--success-soft:#f0fdf4;--warning:#d97706;--warning-soft:#fffbeb;--text-primary:#0f172a;--text-secondary:#64748b;--text-muted:#94a3b8;--border:#e2e8f0;--border-focus:#2f54eb;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014,0 1px 4px #0000000a;--shadow-lg:0 20px 48px #0f172a29;--font-body:"DM Sans",sans-serif;--font-mono:"DM Mono",monospace}.overlay-container{z-index:1000;background:var(--bg-overlay);-webkit-backdrop-filter:blur(6px);font-family:var(--font-body);justify-content:center;align-items:center;padding:16px;animation:.18s fadeInOverlay;display:flex;position:fixed;inset:0}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.overlay-content{background:var(--bg-panel);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:680px;max-height:90vh;animation:.22s cubic-bezier(.22,.68,0,1.2) slideUp;display:flex;overflow:hidden}.overlay-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:22px 28px 18px;display:flex}.overlay-header h2{color:var(--text-primary);letter-spacing:-.3px;margin:0;font-size:1.05rem;font-weight:600}.overlay-close{background:var(--bg-surface);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border:none;justify-content:center;align-items:center;font-size:1rem;transition:background .15s,color .15s;display:flex}.overlay-close:hover{background:var(--danger-soft);color:var(--danger)}.overlay-tabs{flex-shrink:0;gap:4px;padding:12px 28px 0;display:flex}.tab-btn{border-radius:var(--radius-sm)var(--radius-sm)0 0;color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:7px;padding:7px 18px;font-size:.85rem;font-weight:500;transition:color .15s,border-color .15s,background .15s;display:flex}.tab-btn svg{flex-shrink:0;font-size:.95rem}.tab-btn:hover{color:var(--primary);background:var(--primary-soft)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--primary-soft)}.overlay-body{scrollbar-width:thin;scrollbar-color:var(--border)transparent;flex-direction:column;flex:1;gap:14px;padding:20px 28px;display:flex;overflow-y:auto}.overlay-body::-webkit-scrollbar{width:5px}.overlay-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 20px}.card h3{color:var(--text-primary);margin:0 0 3px;font-size:.9rem;font-weight:600}.card p{color:var(--text-secondary);margin:0;font-size:.82rem}.card-icon{color:var(--primary);flex-shrink:0;margin-top:1px;font-size:1.3rem}.card.horizontal{align-items:center;gap:14px;display:flex}.card.horizontal>div{flex:1}.card.upload-card{flex-wrap:wrap;align-items:flex-start;gap:14px;display:flex;position:relative}.card.upload-card>div{flex:1;min-width:140px}.card.upload-card input[type=file]{font-family:var(--font-body);color:var(--text-secondary);cursor:pointer;max-width:100%;margin-top:10px;font-size:.8rem}.card.upload-card input[type=file]::file-selector-button{background:var(--primary);color:#fff;border-radius:var(--radius-sm);font-family:var(--font-body);cursor:pointer;border:none;margin-right:10px;padding:6px 14px;font-size:.8rem;font-weight:500;transition:background .15s}.card.upload-card input[type=file]::file-selector-button:hover{background:var(--primary-hover)}.btn-link{font-family:var(--font-body);cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:0;font-size:.8rem;font-weight:500;transition:color .15s}.btn-link.danger{color:var(--danger)}.btn-link.danger:hover{color:#b91c1c}.mt-2{margin-top:8px}.info-box{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);align-items:flex-start;gap:12px;padding:14px 18px;font-size:.83rem;animation:.2s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.info-box svg{flex-shrink:0;margin-top:1px;font-size:1.1rem}.info-box strong{margin-bottom:3px;font-size:.87rem;font-weight:600;display:block}.info-box p{color:var(--text-secondary);margin:0 0 6px;font-size:.81rem}.info-box ul{margin:0;padding-left:16px}.info-box ul li{font-size:.8rem;line-height:1.65;font-family:var(--font-mono)}.info-box.error{background:var(--danger-soft);border-color:#fca5a5}.info-box.error svg,.info-box.error strong{color:var(--danger)}.info-box.error ul li{color:#b91c1c}.info-box.success{background:var(--success-soft);border-color:#86efac}.info-box.success svg,.info-box.success strong{color:var(--success)}.card.form-card{padding:20px}.section-title{color:var(--text-primary);margin:0 0 16px;font-size:.9rem;font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-field{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.2px;font-size:.78rem;font-weight:500}.form-input{font-family:var(--font-body);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);box-sizing:border-box;appearance:none;background:#fff;outline:none;width:100%;padding:8px 10px;font-size:.84rem;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #2f54eb1f}select.form-input{background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.mini-errors{background:var(--warning-soft);border-radius:var(--radius-sm);border:1px solid #fcd34d;align-items:flex-start;gap:10px;margin-top:14px;padding:12px 14px;font-size:.8rem;display:flex}.mini-errors svg{color:var(--warning);flex-shrink:0;margin-top:1px;font-size:1rem}.mini-errors strong{color:#92400e;margin-bottom:4px;font-size:.82rem;font-weight:600;display:block}.mini-errors ul{margin:0;padding-left:14px}.mini-errors ul li{color:#92400e;line-height:1.6;font-family:var(--font-mono)}.overlay-footer{border-top:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 28px;display:flex}.footer-left{flex:1;min-width:0}.footer-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.footer-progress{flex-direction:column;gap:5px;display:flex}.footer-progress span{color:var(--text-secondary);font-size:.77rem;font-family:var(--font-mono)}.footer-progress-bar{background:var(--border);border-radius:99px;width:200px;max-width:100%;height:4px;overflow:hidden}.footer-progress-fill{background:var(--primary);border-radius:99px;height:100%;transition:width .3s}.btn-primary,.btn-secondary,.btn-outline{font-family:var(--font-body);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1.5px solid #0000;align-items:center;gap:7px;padding:8px 18px;font-size:.84rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s,color .15s,opacity .15s,box-shadow .15s;display:inline-flex}.btn-outline{color:var(--primary);border-color:var(--primary);background:0 0;flex-shrink:0;padding:7px 14px;font-size:.82rem}.btn-outline:hover{background:var(--primary-soft)}@media (max-width:600px){.overlay-content{border-radius:var(--radius-md);max-height:96vh}.overlay-header,.overlay-body,.overlay-footer,.overlay-tabs{padding-left:18px;padding-right:18px}.card.horizontal{flex-wrap:wrap}.form-grid{grid-template-columns:1fr}.overlay-footer{flex-direction:column;align-items:stretch}.footer-right{justify-content:flex-end}.footer-progress-bar{width:100%}.btn-primary,.btn-secondary{flex:1;justify-content:center}}@media (max-width:400px){.overlay-header h2{font-size:.92rem}.tab-btn{padding:6px 12px;font-size:.8rem}}.attendance-page{flex-direction:column;gap:20px;max-width:1200px;margin:0 auto;display:flex}.attendance-topbar{background:#fff;border-radius:20px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;padding:20px 24px;display:flex;box-shadow:0 4px 24px #00000012}.attendance-info{flex-direction:column;gap:14px;display:flex}.attendance-period-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.attendance-period-select{max-width:220px;font-size:13.5px}.attendance-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.btn-outline-primary{border:1.5px solid var(--color-primary);color:var(--color-primary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:12px;align-items:center;gap:7px;padding:10px 18px;font-size:13.5px;font-weight:600;transition:all .2s;display:inline-flex}.btn-outline-primary:hover:not(:disabled){background:#0ea5a414;transform:translateY(-1px)}.btn-outline-primary:disabled{opacity:.4;cursor:not-allowed}.attendance-alert{border-radius:14px;align-items:center;gap:10px;padding:13px 16px;font-size:13.5px;font-weight:500;animation:.3s fadeInInfo;display:flex}.attendance-alert.success{color:#166534;background:#22c55e26;border:1px solid #22c55e66}.attendance-alert.error{color:#991b1b;background:#ef444426;border:1px solid #ef444466}.attendance-table-card{background:#fff;border-radius:20px;padding:20px;overflow:hidden;box-shadow:0 4px 24px #00000012}.table-wrap{border-radius:12px;overflow-x:auto}.grade-table{border-collapse:collapse;width:100%;min-width:600px;font-size:13px}.grade-table thead tr{background:linear-gradient(135deg,#0ea5a414,#0ea5e914)}.grade-table th{text-transform:uppercase;letter-spacing:.04em;color:#374151;white-space:nowrap;border-bottom:2px solid #f3f4f6;padding:10px 12px;font-size:11.5px;font-weight:700}.grade-table td{color:#374151;white-space:nowrap;border-bottom:1px solid #f3f4f6;padding:9px 12px}.grade-table tbody tr:hover{background:#f9fafb}.th-date{text-align:center;min-width:100px;color:var(--color-primary)}.td-att{text-align:center;padding:6px 8px}.th-group{text-align:center;min-width:64px}.th-green{color:#16a34a;border-top:3px solid #22c55e}.th-yellow{color:#b45309;border-top:3px solid #f59e0b}.th-dark{color:#374151;border-top:3px solid #6b7280}.th-red{color:#dc2626;border-top:3px solid #ef4444}.td-green{text-align:center;color:#16a34a;font-weight:600}.td-yellow{text-align:center;color:#b45309;font-weight:600}.td-dark{text-align:center;color:#374151;font-weight:600}.td-red{text-align:center;color:#dc2626;font-weight:600}.att-select{cursor:pointer;text-align:center;border:none;border-radius:8px;outline:none;width:56px;padding:5px 8px;font-size:12.5px;font-weight:700;transition:background .15s}.status-presente{color:#166534;background:#22c55e26}.status-excusa{color:#b45309;background:#f59e0b26}.status-ausente{color:#991b1b;background:#ef444426}.status-suspendido{color:#374151;background:#6b728026}.status-empty{color:#9ca3af;background:#f3f4f6}.table-empty-hint{text-align:center;color:#9ca3af;padding:40px;font-size:14px}@media (max-width:768px){.attendance-topbar{flex-direction:column;padding:16px}.attendance-actions{flex-direction:column;width:100%}.attendance-actions button{justify-content:center;width:100%}.attendance-period-select{flex:1;max-width:100%}.th-name,.td-name{min-width:140px}}.admin-attendance-page{flex-direction:column;gap:20px;max-width:1200px;margin:0 auto;display:flex}.admin-attendance-header{flex-direction:column;gap:4px;display:flex}.admin-attendance-subtitle{color:#6b7280;margin:0;font-size:14px}.admin-attendance-filters{background:#fff;border-radius:20px;grid-template-columns:1fr 1fr 1fr;gap:16px;padding:20px 24px;display:grid;box-shadow:0 4px 24px #00000012}@media (max-width:768px){.admin-attendance-filters{grid-template-columns:1fr;padding:16px}}.admin-attendance-range{background:#0ea5a40f;border:1px solid #0ea5a433;border-radius:12px;align-items:center;gap:10px;padding:10px 16px;font-size:13.5px;display:flex}.range-label{color:#6b7280;font-weight:600}.range-value{color:var(--color-primary);font-weight:700}.admin-attendance-summary{color:#6b7280;border-bottom:1px solid #f3f4f6;gap:20px;padding:0 0 14px;font-size:13.5px;display:flex}.admin-attendance-summary strong{color:#1f2937}.att-badge{border-radius:8px;justify-content:center;align-items:center;width:32px;height:28px;font-size:12.5px;font-weight:700;display:inline-flex}.student-attendance-page{flex-direction:column;gap:20px;max-width:900px;margin:0 auto;display:flex}.student-attendance-header{background:#fff;border-radius:20px;flex-direction:column;gap:14px;padding:20px 24px;display:flex;box-shadow:0 4px 24px #00000012}.student-attendance-title-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.subject-teacher-badge{color:var(--color-primary);background:#0ea5a41a;border-radius:20px;align-items:center;padding:4px 12px;font-size:12.5px;font-weight:600;display:inline-flex}.student-subject-header{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.th-block-activities{color:#4f46e5;background:#6366f114;border-top:3px solid #6366f1}.th-act-name{font-size:12px;font-weight:700}.th-act-percent{color:#6366f1;margin-top:2px;font-size:11px;font-weight:600}.cell-wrap{align-items:center;display:flex;position:relative}.cell-status{font-size:11px;font-weight:700;position:absolute;right:-16px}.cell-status.saving{color:#9ca3af}.cell-status.saved{color:#16a34a}.cell-status.error{color:#dc2626;cursor:help}.cell-saved{background:#22c55e0d;border-color:#22c55e80!important}.cell-error-input{background:#ef44440d;border-color:#ef444480!important}.cell-invalid{background:#ef44440a}.course-btn.criterios{color:#fff;background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.course-btn.criterios:hover{background:linear-gradient(135deg,#7c3aed,#5b21b6)}.cell-saved-pass{color:#16a34a;font-weight:600;border-color:#16a34a!important}.cell-saved-fail{color:#dc2626;font-weight:600;border-color:#dc2626!important}.cell-status.fail{color:#dc2626}.nota-aprobada{color:#16a34a;font-weight:600}.nota-reprobada{color:#dc2626;font-weight:600}.teacher-course-page{max-width:760px;margin:0 auto;padding:24px 20px}.teacher-course-hero{background:linear-gradient(135deg,var(--color-primary,#4f46e5)0%,#7c3aed 100%);color:#fff;border-radius:20px;align-items:center;gap:20px;margin-bottom:28px;padding:28px 24px;display:flex;box-shadow:0 8px 32px #4f46e540}.course-hero-emoji{filter:drop-shadow(0 2px 6px #0000002e);flex-shrink:0;font-size:52px;line-height:1}.course-hero-info{flex-direction:column;gap:4px;min-width:0;display:flex}.course-hero-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:22px;font-weight:800;line-height:1.2;overflow:hidden}.course-hero-meta{color:#ffffffbf;margin:0;font-size:13px;font-weight:500}.course-actions-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.course-action-card{cursor:pointer;text-align:left;background:#fff;border:none;border-radius:16px;align-items:center;gap:16px;padding:20px 18px;transition:transform .18s,box-shadow .18s;display:flex;box-shadow:0 2px 8px #00000012}.course-action-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001f}.action-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.action-card-body{flex-direction:column;gap:3px;min-width:0;display:flex}.action-card-title{color:#1e293b;font-size:15px;font-weight:700;line-height:1.2}.action-card-desc{color:#64748b;font-size:12px;font-weight:400;line-height:1.3}.course-action-card.asistencia .action-card-icon{color:#1d4ed8;background:#dbeafe}.course-action-card.notas .action-card-icon{color:#15803d;background:#dcfce7}.course-action-card.convivencia .action-card-icon{color:#be185d;background:#fce7f3}.course-action-card.logros .action-card-icon{color:#a16207;background:#fef9c3}.course-action-card.criterios .action-card-icon{color:#7c3aed;background:#ede9fe}@media (max-width:768px){.th-id-prefix{display:none}}@media (max-width:520px){.teacher-course-page{padding:16px 12px}.teacher-course-hero{border-radius:16px;gap:14px;margin-bottom:20px;padding:20px 18px}.course-hero-emoji{font-size:40px}.course-hero-title{font-size:18px}.course-actions-grid{grid-template-columns:1fr;gap:12px}.course-action-card{border-radius:14px;padding:16px 14px}}.student-subject-page{flex-direction:column;gap:20px;max-width:680px;margin:0 auto;padding:24px 20px;display:flex}.student-subject-hero{background:linear-gradient(135deg,var(--color-primary,#4f46e5)0%,#7c3aed 100%);color:#fff;border-radius:20px;align-items:center;gap:20px;padding:28px 24px;display:flex;box-shadow:0 8px 32px #4f46e538}.subject-hero-emoji{filter:drop-shadow(0 2px 6px #0000002e);flex-shrink:0;font-size:52px;line-height:1}.subject-hero-info{flex-direction:column;gap:8px;min-width:0;display:flex}.subject-hero-title{color:#fff;margin:0;font-size:24px;font-weight:800;line-height:1.15}.subject-hero-badge{color:#fff;letter-spacing:.5px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border-radius:999px;width:fit-content;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.subject-teacher-card{background:#fff;border-radius:16px;align-items:center;gap:16px;padding:18px 20px;display:flex;box-shadow:0 2px 8px #00000012}.subject-teacher-icon{color:#7c3aed;background:#ede9fe;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.subject-teacher-body{flex-direction:column;gap:2px;min-width:0;display:flex}.subject-teacher-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.subject-teacher-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:700;overflow:hidden}.subject-actions-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.subject-action-card{cursor:pointer;background:#fff;border-radius:16px;align-items:center;gap:16px;padding:20px 18px;text-decoration:none;transition:transform .18s,box-shadow .18s;display:flex;box-shadow:0 2px 8px #00000012}.subject-action-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001f}.subject-action-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.subject-action-body{flex-direction:column;gap:3px;min-width:0;display:flex}.subject-action-title{color:#1e293b;font-size:15px;font-weight:700;line-height:1.2}.subject-action-desc{color:#64748b;font-size:12px;font-weight:400;line-height:1.3}.subject-action-card.notas .subject-action-icon{color:#15803d;background:#dcfce7}.subject-action-card.asistencias .subject-action-icon{color:#1d4ed8;background:#dbeafe}@media (max-width:520px){.student-subject-page{gap:16px;padding:16px 12px}.student-subject-hero{border-radius:16px;gap:14px;padding:20px 18px}.subject-hero-emoji{font-size:40px}.subject-hero-title{font-size:20px}.subject-actions-grid{grid-template-columns:1fr;gap:12px}.subject-action-card{border-radius:14px;padding:16px 14px}}*{box-sizing:border-box}html,body{height:100%}body{font-family:var(--font-geist-sans);background-color:var(--color-bg);color:var(--color-text);margin:0}.container{justify-content:center;align-items:center;min-height:100vh;display:flex}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
