:root{--color-bg:#f5f6fb;--color-surface:#fff;--color-border:#0f172a1f;--color-text:#0f172a;--color-text-muted:#64748b;--color-text-subtle:#94a3b8;--color-primary:#1d7df2;--color-primary-hover:#1666cc;--color-success:#16a34a;--color-warning:#f59e0b;--color-danger:#ef4444;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 10px 20px #00000014;--shadow-lg:0 20px 40px #0000001f;--transition-fast:.15s ease;--transition-normal:.3s ease;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-family);background:linear-gradient(180deg, var(--color-bg) 0%, #e7ebf5 100%);color:var(--color-text);flex-direction:column;min-height:100vh;display:flex}.login-navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.login-navbar__brand{align-items:center;gap:1rem;display:flex}.login-navbar__logo{color:var(--color-text);font-size:1.25rem;font-weight:700;text-decoration:none}.login-navbar__links{align-items:center;gap:1.5rem;display:flex}.login-navbar__link{color:var(--color-text-muted);transition:color var(--transition-fast);font-size:.9rem;font-weight:500;text-decoration:none}.login-navbar__link:hover{color:var(--color-text)}.login-navbar__help{border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:.5rem 1rem;font-size:.9rem;font-weight:500}.login-navbar__help:hover{border-color:var(--color-text-muted);color:var(--color-text);background:#00000005}.login-main{flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.login-background{pointer-events:none;z-index:-1;background-image:radial-gradient(circle at 20% 20%,#1d7df20d 0%,#0000 50%),radial-gradient(circle at 80% 80%,#1d7df208 0%,#0000 50%);width:100%;height:100%;position:absolute;top:0;left:0}.login-container{width:100%;max-width:480px;margin:0 auto}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:2.5rem;position:relative;overflow:hidden}.login-card:before{content:"";background:linear-gradient(90deg, var(--color-primary), #60a5fa);opacity:.8;height:4px;position:absolute;top:0;left:0;right:0}.login-card__header{text-align:center;margin-bottom:2rem}.login-title{color:var(--color-text);letter-spacing:-.025em;margin-bottom:.5rem;font-size:1.875rem;font-weight:700}.login-subtitle{color:var(--color-text-muted);font-size:.95rem;font-weight:500}.login-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{position:relative}.form-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:block}.form-input-wrapper{position:relative}.form-input{background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);transition:all var(--transition-normal);outline:none;padding:.875rem 1rem;font-size:1rem}.form-input::placeholder{color:var(--color-text-subtle);opacity:1}.form-input:hover{background:#fff;border-color:#cbd5e1}.form-input:focus{border-color:var(--color-input-focus);background:#fff;box-shadow:0 0 0 3px #1d7df226}.form-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-icon{color:var(--color-text-subtle);pointer-events:none;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.form-link{color:var(--color-link);transition:color var(--transition-fast);font-size:.875rem;font-weight:500;text-decoration:none}.form-link:hover{color:var(--color-primary-hover);text-decoration:underline}.form-checkbox-row{align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.form-checkbox,.form-label-checkbox input[type=checkbox],.checkbox-group input[type=checkbox]{cursor:pointer;width:46px;height:26px;transition:all var(--transition-fast);appearance:none;background:#64748b;border:1px solid #475569;border-radius:999px;flex:none;position:relative;box-shadow:inset 0 1px 2px #0f172a33}.form-checkbox:before,.form-label-checkbox input[type=checkbox]:before,.checkbox-group input[type=checkbox]:before{content:"";width:20px;height:20px;transition:transform var(--transition-fast);background:#fff;border-radius:50%;position:absolute;top:2px;left:3px;box-shadow:0 1px 4px #0f172a3d}.form-checkbox:checked,.form-label-checkbox input[type=checkbox]:checked,.checkbox-group input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}.form-checkbox:checked:before,.form-label-checkbox input[type=checkbox]:checked:before,.checkbox-group input[type=checkbox]:checked:before{transform:translate(20px)}.form-checkbox:focus-visible,.form-label-checkbox input[type=checkbox]:focus-visible,.checkbox-group input[type=checkbox]:focus-visible{outline-offset:2px;outline:3px solid #1d7df238}.form-checkbox-label{color:var(--color-text-muted);cursor:pointer;font-size:.875rem}.checkbox-group label{color:var(--color-text);cursor:pointer;align-items:center;gap:.75rem;font-weight:600;display:inline-flex}.switch-group{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.switch-label{width:100%;color:var(--color-text);cursor:pointer;justify-content:space-between;align-items:center;gap:1rem;font-size:.95rem;display:flex}.switch-wrapper{width:46px;height:26px;display:inline-block;position:relative}.form-switch{opacity:0;width:0;height:0;position:absolute;top:0;left:0}.switch-slider{transition:background var(--transition-fast);background:#64748b;border-radius:999px;position:absolute;inset:0;box-shadow:inset 0 1px 2px #0f172a33}.switch-slider:before{content:"";width:20px;height:20px;transition:transform var(--transition-fast);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0000001f}.form-switch:checked+.switch-slider{background:var(--color-primary)}.form-switch:checked+.switch-slider:before{transform:translate(20px)}.form-switch:focus-visible+.switch-slider{outline-offset:2px;outline:3px solid #1d7df238}.login-button{background:var(--color-primary);border-radius:var(--radius-md);color:#fff;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;width:100%;transition:all var(--transition-normal);border:none;padding:.875rem 1.5rem;font-size:.95rem;font-weight:600;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #1d7df24d}.login-button:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 6px 12px -2px #1d7df266}.login-button:active{transform:translateY(0);box-shadow:0 2px 8px -1px #1d7df24d}.login-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.login-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.login-card__footer{border-top:1px solid var(--color-border);text-align:center;margin-top:2rem;padding-top:1.5rem}.login-register-text{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.9rem}.login-register-link{color:var(--color-link);transition:color var(--transition-fast);font-weight:600;text-decoration:none}.login-register-link:hover{color:var(--color-primary-hover);text-decoration:underline}.login-support{text-align:center;margin-top:1.5rem}.login-support__link{color:var(--color-text-subtle);transition:color var(--transition-fast);font-size:.8rem;text-decoration:none}.login-support__link:hover{color:var(--color-text-muted);text-decoration:underline}.login-page__footer{text-align:center;color:var(--color-text-subtle);border-top:1px solid var(--color-border);background:var(--color-surface);padding:1.5rem 2rem;font-size:.8rem}.login-page{background:linear-gradient(135deg,#f4f5fa 0%,#d0d9f7 100%);flex-direction:column;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-shell{z-index:1;min-height:100vh;display:flex;position:relative}.login-illustration{color:#fff;flex-direction:column;flex:1;justify-content:center;padding:3rem;display:flex}.login-illustration__title{color:#fff;margin:0 0 1rem;font-size:3rem;font-weight:800;line-height:1.1}.login-illustration__brand{color:#22d3ee}.login-illustration__description{color:#94a3b8;max-width:400px;font-size:1.1rem;line-height:1.6}.login-illustration__graphic{opacity:.3;margin-top:3rem}.login-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.login-logo{width:48px;height:48px;color:var(--color-primary);margin:0 auto 1rem}.login-logo svg{width:100%;height:100%}.login-error{color:#ef4444;text-align:center;background-color:#ef44441a;border-radius:8px;margin-bottom:1rem;padding:.5rem;font-size:.875rem}.error-message{color:#ef4444;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.field-error{color:#ef4444;margin-top:.25rem;font-size:.8rem;display:block}.login-footer{text-align:center;color:var(--color-text-muted);margin-top:1.5rem;font-size:.875rem}.register-link{color:var(--color-link);transition:color var(--transition-fast);font-weight:500;text-decoration:none}.register-link:hover{color:var(--color-primary-hover);text-decoration:underline}.app-shell{background:var(--color-bg);grid-template-rows:64px 1fr;grid-template-columns:minmax(64px,280px) 1fr;min-height:100vh;display:grid}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);height:100vh;width:var(--sidebar-width);max-width:var(--sidebar-width);transition:width var(--transition-fast);flex-direction:column;flex-shrink:0;grid-area:1/1/-1/2;gap:1.5rem;display:flex;position:sticky;top:0;padding:3.25rem .5rem 1.5rem!important}.sidebar-toggle{cursor:pointer;background:0 0;border:none;place-items:center;width:32px;height:32px;padding:0;display:grid;position:absolute;top:12px;right:12px}.sidebar-toggle-icon{width:20px;height:20px;color:var(--color-text-muted)}.sidebar--expanded{width:240px}.sidebar--collapsed{width:72px}.sidebar-header{border-bottom:1px solid #94a3b82e;flex-direction:column;gap:1rem;padding:1rem 1rem 1.35rem;display:flex;position:relative}.sidebar-toggle{cursor:pointer;width:36px;height:36px;transition:background var(--transition-fast);background:0 0;border:none;border-radius:8px;place-items:center;padding:.5rem;display:grid;position:absolute;top:-40px;right:0}.sidebar-toggle:hover{background:#0f172a14}.sidebar-toggle-icon{width:20px;height:20px;color:var(--color-text-muted);transition:color var(--transition-fast)}.sidebar-toggle:hover .sidebar-toggle-icon{color:var(--color-text)}.sidebar-brand,.sidebar__brand{min-width:0;transition:opacity var(--transition-fast);align-items:center;gap:.75rem;display:flex}.sidebar-logo{object-fit:contain;width:46px;max-width:100%;height:46px;transition:width var(--transition-fast), height var(--transition-fast);flex-shrink:0;display:block}.sidebar-brand-copy{flex-direction:column;gap:.18rem;min-width:0;display:flex}.sidebar-brand-text{letter-spacing:-.03em;color:#2563eb;white-space:nowrap;font-size:1.55rem;font-weight:800;line-height:1}.sidebar-brand-subtext{color:#64748b;white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;font-weight:600;overflow:hidden}.sidebar--collapsed .sidebar-brand{justify-content:center}.sidebar--collapsed .sidebar-logo{background:#0f172a14;border-radius:8px;width:42px;height:42px;padding:6px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.sidebar--collapsed .sidebar-brand-copy{display:none}.sidebar-nav{scrollbar-width:thin;scrollbar-color:#64748b33 transparent;flex-direction:column;flex:1;gap:.25rem;display:flex;overflow-y:auto}.sidebar-group{flex-direction:column;display:flex}.sidebar-group-header{border-radius:var(--radius-lg);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.07em;cursor:pointer;text-align:left;width:100%;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:center;gap:.75rem;padding:.65rem 1rem;font-size:.76rem;font-weight:700;display:flex;position:relative}.sidebar-group-header:hover{color:var(--color-text);background:#1d7df212}.sidebar-group-header--active,.sidebar-group-header--active .sidebar-icon{color:var(--color-primary)}.sidebar-group-header__label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.sidebar-group-chevron{width:14px;height:14px;color:var(--color-text-subtle);flex-shrink:0;transition:transform .2s}.sidebar-group-chevron--open{transform:rotate(180deg)}.sidebar-group-items{border-left:2px solid #1d7df224;flex-direction:column;gap:.05rem;margin-left:.9rem;padding:.15rem 0 .35rem 1rem;display:flex}.sidebar-subitem{border-radius:var(--radius-md);color:var(--color-text-muted);transition:background var(--transition-fast), color var(--transition-fast);align-items:center;gap:.6rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.sidebar-subitem:hover{color:var(--color-text);background:#1d7df212}.sidebar-subitem--active{color:var(--color-primary);background:#1d7df21f;font-weight:600}.sidebar-subitem__icon{color:#94a3b8;flex-shrink:0;width:17px;height:17px}.sidebar-subitem--active .sidebar-subitem__icon{color:var(--color-primary)}.sidebar--collapsed .sidebar-group-header{justify-content:center;padding:.9rem}.sidebar--collapsed .sidebar-group-header__label,.sidebar--collapsed .sidebar-group-chevron,.sidebar--collapsed .sidebar-group-items{display:none}.sidebar--collapsed .sidebar-group-header,.sidebar--collapsed .sidebar-item{position:relative}.sidebar--collapsed .sidebar-group-header:after,.sidebar--collapsed .sidebar-item:after{content:attr(data-tooltip);color:#f1f5f9;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;z-index:200;text-transform:none;letter-spacing:0;background:#1e293b;padding:.3rem .7rem;font-size:.78rem;font-weight:600;transition:opacity .15s;position:absolute;top:50%;left:calc(100% + 10px);transform:translateY(-50%)}.sidebar--collapsed .sidebar-group-header:hover:after,.sidebar--collapsed .sidebar-item:hover:after{opacity:1}.sidebar-item{border-radius:var(--radius-lg);color:var(--color-text);transition:background var(--transition-fast), color var(--transition-fast);align-items:center;gap:.75rem;padding:.9rem 1rem;font-weight:600;text-decoration:none;display:flex}.sidebar-icon{color:#475569;flex-shrink:0;width:22px;height:22px}.sidebar-item--active .sidebar-icon{color:#1f7ae7}.sidebar--collapsed .sidebar-item{justify-content:center;padding:.9rem}.sidebar--collapsed .sidebar-item__label{display:none}.sidebar-logout{border-radius:var(--radius-lg);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast);background:#1d7df214;padding:.9rem 1rem;font-weight:600}.sidebar-logout:hover{background:#1d7df21f}.sidebar--collapsed .sidebar-logout{justify-content:center;padding:.9rem}.sidebar--collapsed .sidebar-logout .sidebar-item__label{display:none}.topbar-user{color:var(--color-text);align-items:center;gap:.75rem;display:flex}.topbar-user--trigger{cursor:pointer;background:linear-gradient(#ffffffeb,#f8fafcf5);border:1px solid #94a3b82e;border-radius:18px;padding:.55rem .75rem;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}.topbar-user--trigger:hover{background:linear-gradient(#fffffffa,#eff6fff0);border-color:#2563eb42;transform:translateY(-1px);box-shadow:0 14px 28px #0f172a14}.topbar-user--trigger:focus-visible{outline-offset:2px;outline:3px solid #2563eb2e}.topbar-user-avatar{width:36px;height:36px;color:var(--color-primary);background:#1d7df226;border-radius:9999px;place-items:center;font-weight:700;display:grid;overflow:hidden}.topbar-user-avatar img{object-fit:cover;border-radius:50%;width:36px;height:36px}.topbar-user-name{color:var(--color-text);font-size:.95rem;font-weight:700}.topbar-user-copy{flex-direction:column;align-items:flex-start;gap:.1rem;display:flex}.topbar-user-role{color:var(--color-text-muted);font-size:.78rem;font-weight:500}.dashboard-content{flex:1;grid-area:2/2/3/3;grid-template-columns:1fr;gap:1.5rem;width:auto;min-width:0;padding:1.75rem 2rem;display:grid}.page{max-width:1200px;margin:0 auto}.text-center{text-align:center}.mt-2{margin-top:.5rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:2rem;position:relative;overflow:hidden}.card-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.card-title{color:var(--color-text);margin-bottom:1rem;font-size:2rem;font-weight:700}.card-subtitle{color:var(--color-text-muted);font-size:.95rem;font-weight:500}.card-stat{color:var(--color-primary);margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.card-stat-icon{width:2.5rem;height:2.5rem;color:var(--color-primary)}.card-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:600}.badge{border-radius:9999px;padding:.25rem .75rem;font-size:.8rem;font-weight:600;display:inline-block}.badge-primary{background:var(--color-bg-soft);color:var(--color-primary)}.badge-secondary{color:#475569;background:#94a3b826}.badge-warning{color:#d97706;background:#f59e0b26}.table{border-collapse:collapse;width:100%}.table th,.table td{text-align:left;padding:1rem}.table th{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border);font-size:.875rem;font-weight:600}.table tr{border-bottom:1px solid #f1f5f9}.table td{color:var(--color-text);font-size:.95rem;font-weight:500}.user-list-avatar{background:var(--color-surface);border:1px solid var(--color-input-border);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex;overflow:hidden}.user-list-avatar img{object-fit:cover;width:100%;height:100%;display:block}.avatar-placeholder{color:var(--color-text-muted);font-size:.75rem}.dashboard{padding:0}.dashboard-header{border-bottom:1px solid #e5e7eb;margin-bottom:24px;padding:20px 0}.dashboard-header h1{color:#1f2937;margin:0 0 8px;font-size:1.75rem;font-weight:800}.dashboard-header p{color:#6b7280;margin:0;font-size:1rem}.dashboard-section{margin-bottom:32px}.dashboard-section h2{color:#1f2937;margin:0 0 16px;font-size:1.25rem;font-weight:700}.subject-table,.recent-grades{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid #e5e7eb;overflow:hidden}.subject-table table,.recent-grades table{border-collapse:collapse;width:100%;font-size:.9rem}.subject-table th,.recent-grades th{text-align:left;color:#374151;text-transform:uppercase;letter-spacing:.5px;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:12px 16px;font-size:.8rem;font-weight:700}.subject-table td,.recent-grades td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:12px 16px}.subject-table tr:hover,.recent-grades tr:hover{background:#f9fafb}.empty-row{text-align:center;color:#9ca3af;padding:20px;font-style:italic}.kpi-cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;display:grid}.kpi-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-md);transition:transform var(--transition-fast), box-shadow var(--transition-fast);border:1px solid #0000;padding:1.5rem;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.kpi-card__content{z-index:2;position:relative}.kpi-card__watermark{opacity:.14;pointer-events:none;z-index:1;width:96px;height:96px;position:absolute;bottom:-12px;right:-12px}.kpi-card__watermark-icon{width:100%;height:100%;color:inherit}.kpi-card__title{color:#0f172abf;text-transform:uppercase;letter-spacing:.04em;margin:0;font-size:.85rem;font-weight:700}.kpi-card__value{color:#0f172ae6;margin:.5rem 0 0;font-size:2rem;font-weight:800}.kpi-card__meta{color:#0f172ab3;margin-top:.5rem;font-size:.9rem}.kpi-card--blue{color:#0f172a;background:#1d7df21f;border-color:#1d7df240}.kpi-card--green{color:#0f172a;background:#16a34a1f;border-color:#16a34a40}.kpi-card--purple{color:#0f172a;background:#8b5cf61f;border-color:#8b5cf640}.kpi-card--yellow{color:#0f172a;background:#f59e0b1f;border-color:#f59e0b40}.kpi-card--blue .kpi-card__watermark,.kpi-card--green .kpi-card__watermark,.kpi-card--purple .kpi-card__watermark,.kpi-card--yellow .kpi-card__watermark{color:#0f172a1f}.grades-page{padding:0}.grades-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px 0;display:flex}.grades-header h1{color:#1f2937;margin:0;font-size:1.5rem;font-weight:800}.grades-actions{align-items:center;gap:16px;display:flex}.year-filter{background:var(--color-surface);border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;display:flex}.year-filter label{color:#374151;text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.year-filter select{color:#1f2937;cursor:pointer;background:0 0;border:none;outline:none;font-size:.9rem}.grades-content{grid-template-columns:1fr 2fr;gap:24px;display:grid}.grades-form-section{grid-column:1/2}.grades-table-section{grid-column:2/3}.grade-form{background:var(--color-surface);box-shadow:var(--shadow-lg);border:1px solid #e5e7eb;border-radius:12px;margin-bottom:24px;padding:24px}.grade-form h2{color:#1f2937;margin-bottom:20px;font-size:1.25rem;font-weight:700}.form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#374151;text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.form-group input,.form-group select{background:var(--color-surface);color:#1f2937;border:2px solid #e5e7eb;border-radius:8px;padding:12px;font-size:1rem;transition:all .3s}.form-group input:focus,.form-group select:focus{border-color:#4169e1;outline:none;box-shadow:0 0 0 3px #4169e11a}.form-group input.error,.form-group select.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.submit-btn{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#4169e1,#2563eb);border:none;border-radius:8px;margin-top:8px;padding:14px;font-size:1rem;font-weight:700;transition:all .3s;box-shadow:0 4px 12px #4169e14d}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #4169e166}.submit-btn:disabled{opacity:.7;cursor:not-allowed;box-shadow:none;transform:none}.grades-table{background:var(--color-surface);box-shadow:var(--shadow-lg);border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.table-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.table-header h2{color:#1f2937;margin:0;font-size:1.1rem;font-weight:700}.table-count{color:#6b7280;background:#e5e7eb;border-radius:999px;padding:4px 8px;font-size:.85rem}.table-container{overflow-x:auto}.table-container table{border-collapse:collapse;width:100%;font-size:.9rem}.table-container th{text-align:left;color:#374151;text-transform:uppercase;letter-spacing:.5px;background:#f3f4f6;border-bottom:1px solid #e5e7eb;padding:12px 16px;font-size:.8rem;font-weight:700}.table-container td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:12px 16px}.table-container tr:hover{background:#f9fafb}.grade-badge{border:1px solid #0000;border-radius:6px;padding:4px 8px;font-size:.8rem;font-weight:700}.grade-badge.excellent{color:#16a34a;background:#dcfce7;border-color:#bbf7d0}.grade-badge.good{color:#2563eb;background:#dbeafe;border-color:#bfdbfe}.grade-badge.average{color:#d97706;background:#fef3c7;border-color:#fde68a}.grade-badge.low{color:#dc2626;background:#fee2e2;border-color:#fecaca}.grade-badge.failed{color:#b91c1c;background:#fee2e2;border-color:#fecaca}.delete-btn{color:#dc2626;cursor:pointer;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;padding:6px 8px;font-size:1rem;transition:all .2s;display:flex}.delete-btn:hover{background:#fecaca;transform:scale(1.05)}.loading-state,.error-state,.empty-state{text-align:center;color:#6b7280;padding:40px 20px}.loading-spinner{border:3px solid #e5e7eb;border-top-color:#4169e1;border-radius:50%;width:32px;height:32px;margin:0 auto 16px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-icon,.empty-icon{margin-bottom:12px;font-size:2rem;display:block}.retry-btn{color:#fff;cursor:pointer;background:#4169e1;border:none;border-radius:6px;margin-top:12px;padding:8px 16px;font-weight:600}.retry-btn:hover{background:#2563eb}@media (width<=768px){.login-navbar{padding:1rem}.login-navbar__links{display:none}.login-card{border-radius:var(--radius-lg);padding:2rem 1.5rem}.login-title{font-size:1.5rem}.login-form{gap:1.25rem}}@media (width<=480px){.login-card{margin:0 1rem;padding:1.5rem 1rem}.login-title{font-size:1.375rem}.login-form{gap:1rem}.login-button{padding:.75rem 1rem;font-size:.9rem}}:root{--color-bg:#f5f6fb;--color-surface:#fff;--color-border:#0f172a1f;--color-text:#0f172a;--color-text-muted:#64748b;--color-text-subtle:#94a3b8;--color-primary:#1d7df2;--color-primary-hover:#1666cc;--color-success:#16a34a;--color-warning:#f59e0b;--color-danger:#ef4444;--color-kpi-blue:#1d7df2;--color-kpi-green:#16a34a;--color-kpi-purple:#8b5cf6;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 10px 20px #00000014;--shadow-lg:0 20px 40px #0000001f}.app-shell{--sidebar-width:240px;grid-template-columns:var(--sidebar-width) 1fr;background:var(--color-bg);grid-template-rows:64px 1fr;min-height:100vh;display:grid}.app-shell:has(.sidebar--collapsed){--sidebar-width:72px}.dashboard-layout{gap:1.5rem;width:100%;display:flex}.dashboard-main{flex:1;min-width:0}.dashboard-side{flex-shrink:0;width:340px}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;grid-area:1/1/-1/2;gap:1.5rem;height:100vh;padding:3.25rem 1.5rem 1.5rem;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar__brand{font-family:var(--font-family);letter-spacing:-.02em;color:var(--color-text);font-size:1.5rem;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;gap:.4rem;display:flex}.sidebar-item{border-radius:var(--radius-lg);color:var(--color-text);transition:background var(--transition-fast), color var(--transition-fast);justify-content:space-between;align-items:center;padding:.85rem 1rem;font-weight:600;text-decoration:none;display:flex}.sidebar-item:hover{background:#1d7df214}.sidebar-item--active{color:var(--color-primary);background:#1d7df229}.sidebar-footer{border-top:1px solid var(--color-border);color:var(--color-text-muted);margin-top:auto;padding-top:1rem;font-size:.85rem}.topbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:10;grid-area:1/2/2/3;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;box-shadow:0 1px #0000000a}.topbar-search{flex:1;align-items:center;gap:.5rem;max-width:520px;display:flex}.topbar-search input{border:1px solid var(--color-border);width:100%;color:var(--color-text);transition:border var(--transition-fast), box-shadow var(--transition-fast);background:#ffffffe0;border-radius:999px;padding:.75rem 1rem}.topbar-search input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #1d7df21f}.topbar-user{color:var(--color-text);align-items:center;gap:.75rem;font-weight:600;display:flex}.topbar-user-avatar{width:36px;height:36px;color:var(--color-primary);background:#1d7df226;border-radius:9999px;place-items:center;font-weight:700;display:grid}.dashboard-main,.dashboard-side{flex-direction:column;gap:1.5rem;display:flex}.analytics-card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-md);padding:1.75rem}.analytics-card h2{color:var(--color-text);margin:0 0 1rem;font-size:1.25rem;font-weight:700}.events-card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-md);padding:1.75rem}.events-card h3{color:var(--color-text);margin:0 0 1rem;font-size:1.1rem;font-weight:700}.event-item{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:1rem;padding:.75rem 0;display:flex}.event-item:last-child{border-bottom:none}.event-item__content{flex:1}.event-item__title{color:var(--color-text);margin:0 0 .25rem;font-size:.95rem;font-weight:700}.event-item__meta{color:var(--color-text-muted);margin:0;font-size:.85rem}.activity-card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-md);padding:1.75rem}.activity-card h3{color:var(--color-text);margin:0 0 1rem;font-size:1.1rem;font-weight:700}.activity-table{border-collapse:collapse;width:100%;font-size:.9rem}.activity-table th,.activity-table td{text-align:left;padding:.85rem .75rem}.activity-table th{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);font-weight:700}.activity-table tr{border-bottom:1px solid #0f172a14}.activity-table tr:hover{background:#1d7df20f}.activity-table td{color:var(--color-text)}.btn-primary{background:var(--color-primary);color:#fff;cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);border:none;border-radius:12px;justify-content:center;align-items:center;padding:.75rem 1.25rem;font-weight:700;display:inline-flex;box-shadow:0 6px 16px #1d7df233}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0);box-shadow:0 4px 12px #1d7df233}.btn-secondary{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);border-radius:12px;justify-content:center;align-items:center;padding:.75rem 1.25rem;font-weight:600;display:inline-flex}.btn-secondary:hover{border-color:var(--color-primary);background:#0f172a0a}.user-create-page,.user-unified-page{grid-template-columns:minmax(320px,1fr) minmax(420px,2fr);align-items:start;gap:2rem;width:100%;display:grid}.user-create-page .user-list-card{grid-column:2}.user-create-page .user-form-card{grid-column:1}.user-unified-page{grid-template-columns:minmax(320px,1fr) minmax(420px,2fr)}.user-unified-page .user-list-card{grid-column:2}.user-unified-page .user-form-card{grid-column:1}@media (width<=900px){.user-create-page,.user-unified-page{grid-template-columns:1fr}.user-create-page .user-list-card,.user-create-page .user-form-card,.user-unified-page .user-list-card,.user-unified-page .user-form-card{grid-column:auto}}.user-form-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:2.5rem;position:relative;overflow:hidden}.user-form-card:before{content:"";background:linear-gradient(90deg, var(--color-primary), #60a5fa);opacity:.8;height:4px;position:absolute;top:0;left:0;right:0}.user-list-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:2rem;position:relative;overflow:hidden}.user-list-card:before{content:"";background:linear-gradient(90deg, var(--color-kpi-green), #22c55e);opacity:.8;height:4px;position:absolute;top:0;left:0;right:0}.user-create-header{text-align:center;margin-bottom:2rem}.user-create-title{color:var(--color-text);letter-spacing:-.025em;margin-bottom:.5rem;font-size:1.875rem;font-weight:700}.user-create-subtitle{color:var(--color-text-muted);font-size:.95rem;font-weight:500}.user-create-alert{border-radius:var(--radius-md);text-align:center;margin-bottom:1.5rem;padding:.75rem 1rem;font-weight:600}.user-create-alert.success{color:#16a34a;background:#16a34a1a;border:1px solid #16a34a4d}.user-create-alert.error{color:#ef4444;background:#ef44441a;border:1px solid #ef44444d}.user-create-form{flex-direction:column;gap:1.5rem;display:flex}.form-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;display:grid}@media (width<=768px){.form-row{grid-template-columns:1fr}}.user-create-actions{justify-content:center;gap:1rem;margin-top:1rem;display:flex}.empty-row{text-align:center;color:#6b7280;padding:18px 0}.btn-cancel{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);border-radius:12px;padding:.75rem 1.25rem;font-weight:700;box-shadow:0 2px 4px #0000000d}.btn-cancel:hover{border-color:var(--color-primary);background:#0f172a0a}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.btn-edit{background:var(--color-kpi-green);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:8px;padding:.5rem 1rem;font-weight:600;box-shadow:0 2px 4px #22c55e33}.btn-edit:hover:not(:disabled){background:#16a34a;transform:translateY(-1px);box-shadow:0 4px 8px #22c55e4d}.btn-edit:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.icon-button{color:#15803d;cursor:pointer;width:2.25rem;height:2.25rem;transition:all var(--transition-fast);background:#22c55e24;border:none;border-radius:999px;justify-content:center;align-items:center;font-size:1rem;line-height:1;display:inline-flex}.icon-button:hover:not(:disabled){background:#22c55e38;transform:translateY(-1px);box-shadow:0 4px 10px #22c55e2e}.icon-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.icon-button.danger{color:#dc2626;background:#ef444424}.icon-button.danger:hover:not(:disabled){background:#ef444438;box-shadow:0 4px 10px #ef44442e}.status-icon{border-radius:999px;justify-content:center;align-items:center;width:1.75rem;height:1.75rem;font-size:.95rem;font-weight:700;line-height:1;display:inline-flex}.status-icon.active{color:#15803d;background:#22c55e24}.status-icon.inactive{color:#dc2626;background:#ef444424}.optional-label{color:var(--color-text-subtle);font-size:.8rem;font-style:italic;font-weight:400}.user-table-container{overflow-x:auto}.user-table{border-collapse:collapse;width:100%;font-size:.9rem}.user-table th{text-align:left;color:#374151;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--color-border);background:#f9fafb;padding:12px 16px;font-size:.8rem;font-weight:700}.user-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:12px 16px}.user-table-row:hover{background:#f9fafb}tr.row--inactive td{background:#ef44440a;border-top:1px solid #ef444459;border-bottom:1px solid #ef444459}tr.row--inactive td:first-child{border-left:2px solid #ef4444}tr.row--inactive td:last-child{border-right:1px solid #ef444459}tr.row--inactive:hover td{background:#ef444414}.user-table-actions{gap:.5rem;display:flex}.badge-administrador{color:var(--color-kpi-blue);background:#1d7df226;border-color:#1d7df24d}.badge-profesor{color:var(--color-kpi-purple);background:#8b5cf626;border-color:#8b5cf64d}.badge-estudiante{color:#d97706;background:#f59e0b26;border-color:#f59e0b4d}.badge-padre de familia{color:var(--color-kpi-green);background:#16a34a26;border-color:#16a34a4d}.loading-state,.empty-state{text-align:center;color:#6b7280;padding:40px 20px}.loading-spinner{border:3px solid #e5e7eb;border-top:3px solid var(--color-primary);border-radius:50%;width:32px;height:32px;margin:0 auto 16px;animation:1s linear infinite spin}.empty-icon{color:var(--color-text-subtle);margin-bottom:12px;font-size:2rem;display:block}.empty-subtitle{color:#9ca3af;margin-top:4px;font-size:.9rem}@media (width<=1024px){.dashboard-layout{flex-direction:column}.dashboard-content{grid-template-columns:1fr}.sidebar{height:auto;padding-bottom:1.5rem;position:relative}}@media (width<=768px){.app-shell{grid-template-rows:64px 1fr;grid-template-columns:1fr}.sidebar{grid-area:2/1/3/-1}.topbar{grid-column:1/-1}.dashboard-content{padding:1.25rem}.user-create-card{border-radius:var(--radius-lg);padding:2rem 1.5rem}.user-create-title{font-size:1.5rem}}@media (width<=480px){.user-create-card{margin:0 1rem;padding:1.5rem 1rem}.user-create-title{font-size:1.375rem}.user-create-form{gap:1.25rem}}.academic-periods-page{grid-template-columns:minmax(320px,1fr) minmax(420px,1fr)}.academic-periods-page .user-form-card,.academic-periods-page .user-list-card{grid-column:auto}.academic-units-card__header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.academic-units-card__title-block{text-align:left;margin-bottom:0}.academic-units-summary{text-align:center;border:1px solid #0000;border-radius:999px;flex-direction:column;gap:.125rem;min-width:92px;padding:.625rem .875rem;font-size:.85rem;display:flex}.academic-units-summary strong{font-size:1rem}.academic-units-summary--valid{color:#166534;background:#16a34a1f;border-color:#16a34a3d}.academic-units-summary--pending{color:#92400e;background:#f59e0b1f;border-color:#f59e0b3d}.academic-units-form{margin-bottom:0}.form-label-checkbox{align-items:center;gap:.5rem;min-height:44px;display:flex}.user-table-row--selected{background:#1d7df214}@media (width<=900px){.academic-units-card__header{flex-direction:column}}.teacher-assignments-page{grid-template-columns:minmax(360px,.95fr) minmax(420px,1.05fr)}.teacher-assignments-card,.teacher-assignments-list-card{flex-direction:column;gap:1.5rem;display:flex}.teacher-assignments-header{margin-bottom:0}.teacher-assignments-context{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.teacher-selection-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(#f8fafcf5,#f1f5f9eb);padding:1.25rem}.teacher-selection-panel__header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.teacher-selection-panel__title{color:var(--color-text);margin:0;font-size:1.125rem}.teacher-selection-panel__subtitle{color:var(--color-text-muted);margin:.25rem 0 0;font-size:.92rem}.teacher-selection-panel__header-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.5rem;display:flex}.toggle-switch{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.45rem;display:inline-flex}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-switch__track{background:#d1d5db;border-radius:999px;flex-shrink:0;width:36px;height:20px;transition:background .2s;display:inline-block;position:relative}.toggle-switch input:checked+.toggle-switch__track{background:#6366f1}.toggle-switch__thumb{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-switch__track .toggle-switch__thumb{transform:translate(16px)}.toggle-switch__label{color:var(--color-text-muted);min-width:48px;font-size:.78rem;font-weight:600}.toggle-switch input:checked~.toggle-switch__label{color:#6366f1}.teacher-selection-panel__count{min-width:92px;color:var(--color-primary);background:#1d7df21f;border-radius:999px;justify-content:center;align-items:center;padding:.6rem .85rem;font-size:.85rem;font-weight:700;display:inline-flex}.teacher-selection-list{flex-direction:column;gap:.85rem;max-height:520px;padding-right:.25rem;display:flex;overflow-y:auto}.teacher-selection-card{text-align:left;cursor:pointer;background:#ffffffeb;border:1px solid #94a3b859;border-radius:20px;align-items:center;gap:1rem;width:100%;padding:1rem;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;display:flex}.teacher-selection-card:hover{border-color:#1d7df25c;transform:translateY(-1px);box-shadow:0 16px 30px #0f172a14}.teacher-selection-card--active{background:linear-gradient(135deg,#dbeafef5,#eff6fffa);border-color:#1d7df28c;box-shadow:0 18px 34px #1d7df224}.teacher-selection-card__avatar{color:#0f172a;background:linear-gradient(135deg,#cbd5e1,#94a3b8);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:58px;height:58px;font-size:1rem;font-weight:700;display:inline-flex;overflow:hidden}.teacher-selection-card__avatar img{object-fit:cover;width:100%;height:100%}.teacher-selection-card__content{flex-direction:column;flex:1;gap:.3rem;min-width:0;display:flex}.teacher-selection-card__name-row{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.teacher-selection-card__name{color:var(--color-text);font-weight:700}.teacher-selection-card__badge{color:#334155;white-space:nowrap;background:#0f172a14;border-radius:999px;justify-content:center;align-items:center;padding:.35rem .75rem;font-size:.8rem;font-weight:700;display:inline-flex}.teacher-selection-card__meta{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;overflow:hidden}.teacher-subjects-header{text-align:left}.teacher-subject-groups{flex-direction:column;gap:1.25rem;display:flex}.teacher-subject-context{border-radius:var(--radius-lg);background:#eff6ffcc;border:1px solid #1d7df229;flex-direction:column;gap:.25rem;padding:1rem 1.1rem;display:flex}.teacher-subject-context__label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary);font-size:.75rem;font-weight:700}.teacher-subject-context__meta{color:var(--color-text-muted);font-size:.9rem}.teacher-subject-group{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(#fffffff5,#f8fafcf5);padding:1.1rem}.teacher-subject-group__header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.95rem;display:flex}.teacher-subject-group__header h3{color:var(--color-text);margin:0;font-size:1.05rem}.teacher-subject-group__header span{color:var(--color-text-muted);font-size:.88rem;font-weight:600}.teacher-subject-group__buttons{flex-wrap:wrap;gap:.75rem;display:flex}.teacher-subject-chip{color:#334155;cursor:pointer;background:#fff;border:1px solid #64748b47;border-radius:999px;padding:.72rem 1rem;font-size:.92rem;font-weight:700;transition:transform .18s,border-color .18s,background .18s,color .18s,box-shadow .18s}.teacher-subject-chip:hover:not(:disabled){border-color:#1d7df270;transform:translateY(-1px);box-shadow:0 12px 24px #0f172a14}.teacher-subject-chip--active{background:linear-gradient(135deg, var(--color-primary), #2563eb);color:#fff;border-color:#0000;box-shadow:0 16px 26px #2563eb47}.teacher-subject-chip:disabled{opacity:.7;cursor:wait}.teacher-subject-chip--locked,.teacher-subject-chip--locked:disabled{opacity:.45;cursor:not-allowed;color:#9ca3af;border-color:#ef444433}@media (width<=1100px){.teacher-assignments-context{grid-template-columns:1fr}}@media (width<=900px){.teacher-assignments-page{grid-template-columns:1fr}}@media (width<=640px){.teacher-selection-panel__header,.teacher-selection-card__name-row,.teacher-subject-group__header{flex-direction:column;align-items:flex-start}.teacher-selection-card{align-items:flex-start}}.activities-cards-grid{grid-template-columns:1fr;gap:.85rem;display:grid}.card-activity{border:1px solid #94a3b838;border-left:6px solid var(--color-primary);background:#fff;border-radius:24px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:1rem;min-height:0;padding:1rem 1.1rem;display:grid;position:relative;overflow:hidden;box-shadow:0 12px 28px #0f172a12}.card-activity:after{content:"✦";color:#3b82f60f;pointer-events:none;font-size:3.25rem;line-height:1;position:absolute;top:50%;right:1.1rem;transform:translateY(-50%)}.card-activity__icon,.card-activity__content,.card-header,.card-body,.card-footer,.card-activity__weight{z-index:1;position:relative}.card-activity__icon{width:52px;height:52px;color:var(--color-primary);background:linear-gradient(#f8fafc,#e2e8f0);border:1px solid #94a3b83d;border-radius:16px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:800;display:inline-flex;box-shadow:inset 0 1px #ffffffe6}.card-activity__content{flex-direction:column;gap:.45rem;min-width:0;display:flex}.card-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.card-header h3{color:var(--color-text);letter-spacing:-.01em;margin:0;font-size:1rem;font-weight:700}.card-header p{color:#0f766e;margin:.18rem 0 0;font-size:.9rem;font-weight:600}.card-body{flex-wrap:wrap;align-items:center;gap:.45rem .8rem;display:flex}.card-body span{color:var(--color-text-muted);margin:0;font-size:.84rem;font-weight:500}.card-footer{justify-content:space-between;align-items:center;gap:.75rem;margin-top:auto;padding-top:.1rem;display:flex}.card-activity__weight{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.08rem;display:flex}.card-activity__weight span{letter-spacing:.08em;text-transform:uppercase;color:#94a3b8;font-size:.66rem;font-weight:700}.card-activity__weight strong{color:#0f172a;font-size:1.7rem;line-height:1}.badge-status{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;padding:.32rem .72rem;font-size:.75rem;font-weight:700;display:inline-flex}.badge-status--active{color:#166534;background:#16a34a1f;border:1px solid #16a34a33}.badge-status--inactive{color:#334155;background:#64748b24;border:1px solid #64748b38}.activity-actions{align-items:center;gap:.45rem;display:flex}.score-container{gap:1.5rem;display:grid}.score-header{flex-direction:column;gap:1.25rem;display:flex}.score-center-strip{justify-content:flex-start;display:flex}.score-center-chip{color:var(--color-text);cursor:pointer;background:#ffffffeb;border:1px solid #94a3b83d;border-radius:18px;align-items:center;gap:.9rem;padding:.85rem 1rem;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;display:inline-flex}.score-center-chip:hover{border-color:#2563eb52;transform:translateY(-1px);box-shadow:0 14px 28px #0f172a14}.score-center-chip--active{background:linear-gradient(135deg,#eff6fffa,#dbeafef0);border-color:#2563eb66}.score-center-chip__icon,.score-flow__icon,.score-selector-panel__icon{color:#2563eb;justify-content:center;align-items:center;display:inline-flex}.score-center-chip__icon{background:#2563eb1a;border-radius:14px;width:42px;height:42px}.score-center-chip__icon svg,.score-flow__icon svg,.score-flow__arrow svg,.score-selector-panel__icon svg{width:22px;height:22px}.score-center-chip__copy{flex-direction:column;align-items:flex-start;gap:.12rem;display:flex}.score-center-chip__copy strong{text-transform:uppercase;letter-spacing:.06em;color:#2563eb;font-size:.82rem}.score-center-chip__copy small{color:var(--color-text);font-size:.95rem;font-weight:700}.score-flow{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.score-flow__item{text-align:left;cursor:pointer;background:#ffffffeb;border:1px solid #94a3b838;border-radius:20px;flex:180px;grid-template-columns:48px minmax(0,1fr);align-items:center;gap:.9rem;min-width:180px;padding:.95rem 1rem;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s;display:grid;box-shadow:0 10px 24px #0f172a0d}.score-flow__item:hover:not(:disabled){border-color:#2563eb4d;transform:translateY(-1px);box-shadow:0 18px 30px #0f172a14}.score-flow__item--active{background:linear-gradient(135deg,#eff6fffa,#dbeafef0);border-color:#2563eb6b;box-shadow:0 18px 34px #2563eb24}.score-flow__item--selected{border-left:4px solid #2563eb}.score-flow__item--disabled{opacity:.52;cursor:not-allowed;box-shadow:none}.score-flow__icon{background:linear-gradient(#f8fafcfa,#eff6ffeb);border:1px solid #94a3b82e;border-radius:16px;width:48px;height:48px}.score-flow__copy{flex-direction:column;gap:.18rem;min-width:0;display:flex}.score-flow__copy strong{text-transform:uppercase;letter-spacing:.06em;color:#2563eb;font-size:.84rem}.score-flow__copy p{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.9rem;font-weight:600;overflow:hidden}.score-flow__arrow{color:#f97316;flex:none;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.score-toolbar{flex-direction:column;gap:1rem;display:flex}.score-selector-panel{background:linear-gradient(#f8fafcfa,#fffffff0);border:1px solid #94a3b833;border-radius:24px;padding:1.15rem 1.2rem;box-shadow:inset 0 1px #ffffffb8}.score-selector-panel__header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.score-selector-panel__eyebrow{letter-spacing:.08em;text-transform:uppercase;color:#2563eb;margin-bottom:.3rem;font-size:.76rem;font-weight:800;display:inline-block}.score-selector-panel__header h3{color:var(--color-text);margin:0;font-size:1.15rem}.score-selector-panel__header p{color:var(--color-text-muted);max-width:620px;margin:.3rem 0 0;font-size:.92rem}.score-selector-panel__icon{background:#2563eb1a;border-radius:16px;flex:none;width:48px;height:48px}.score-selector-options{flex-wrap:wrap;gap:.8rem;display:flex}.score-selector-option{text-align:left;cursor:pointer;background:#fff;border:1px solid #94a3b83d;border-radius:18px;flex-direction:column;gap:.28rem;min-width:190px;padding:.95rem 1rem;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s;display:flex}.score-selector-option:hover{border-color:#2563eb57;transform:translateY(-1px);box-shadow:0 16px 28px #0f172a14}.score-selector-option strong{color:var(--color-text);font-size:.95rem}.score-selector-option span{color:var(--color-text-muted);font-size:.84rem}.score-selector-option--active{background:linear-gradient(135deg,#dbeafee6,#eff6fff5);border-color:#2563eb61;box-shadow:0 16px 30px #2563eb24}.score-selector-panel__empty{color:var(--color-text-muted);background:#ffffffe6;border:1px dashed #94a3b85c;border-radius:18px;padding:1rem 1.1rem;font-weight:600}.score-toolbar__actions{flex-wrap:wrap;justify-content:space-between;gap:.75rem;display:flex}.score-matrix{flex-direction:column;gap:1rem;display:flex}.score-cell{flex-direction:column;gap:.12rem;display:flex}.score-cell span{color:var(--color-text-muted);font-size:.8rem;font-weight:600}.score-input{text-align:center;width:88px;height:42px;color:var(--color-text);border:1px solid #94a3b847;border-radius:12px;outline:none;font-weight:700;transition:border-color .18s,box-shadow .18s,background .18s}.score-input:focus{border-color:#2563eb73;box-shadow:0 0 0 4px #2563eb1f}.score-input--empty{background:#f8fafc}.score-input--filled{background:#dbeafe9e;border-color:#2563eb3d}.score-input--high{color:#166534;background:#dcfce7cc;border-color:#16a34a40}.score-input--low{color:#b91c1c;background:#fee2e2d1;border-color:#ef444438}.score-average{color:#0f172a;background:#0ea5e91f;border-radius:999px;justify-content:center;align-items:center;min-width:74px;padding:.58rem .75rem;font-weight:800;display:inline-flex}.score-loading,.score-empty{text-align:center;min-height:220px;color:var(--color-text-muted);place-items:center;gap:.75rem;display:grid}.score-empty span{font-size:2rem}.attendance-daily-shell{gap:1.2rem;display:grid}.attendance-header-card{background:linear-gradient(#fffffffa,#f8fafcf5);border:1px solid #94a3b829;border-radius:28px;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.35rem 1.4rem;display:flex;box-shadow:0 18px 38px #0f172a0f}.attendance-header-card__copy h1{letter-spacing:-.04em;color:var(--color-text);margin:0;font-size:2rem}.attendance-header-card__copy p{max-width:520px;color:var(--color-text-muted);margin:.35rem 0 0;line-height:1.55}.attendance-header-card__controls{flex-wrap:wrap;justify-content:flex-end;gap:.8rem;display:flex}.attendance-control-pill{background:#f4f7fbe6;border:1px solid #94a3b82e;border-radius:20px;min-width:188px;padding:.72rem .85rem;box-shadow:inset 0 1px #ffffffe6}.attendance-control-pill--wide{min-width:220px}.attendance-control-pill__label{letter-spacing:.08em;text-transform:uppercase;color:#94a3b8;margin-bottom:.28rem;font-size:.7rem;font-weight:800;display:block}.attendance-control-pill__field{align-items:center;gap:.55rem;display:flex}.attendance-control-pill__field svg{color:#3b82f6;flex-shrink:0;width:18px;height:18px}.attendance-control-pill__field select,.attendance-control-pill__field input{width:100%;color:var(--color-text);background:0 0;border:none;outline:none;font-size:.95rem;font-weight:700}.attendance-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;display:grid}.attendance-stat-card{background:#fffffff5;border:1px solid #94a3b829;border-radius:22px;padding:1rem 1.05rem;box-shadow:0 14px 28px #0f172a0d}.attendance-stat-card span{letter-spacing:.08em;text-transform:uppercase;color:#94a3b8;margin-bottom:.5rem;font-size:.72rem;font-weight:800;display:block}.attendance-stat-card strong{color:var(--color-text);font-size:2rem;line-height:1}.attendance-stat-card--present{background:linear-gradient(#f0fdf4fa,#dcfce7eb)}.attendance-stat-card--absent{background:linear-gradient(#fef2f2fa,#fee2e2eb)}.attendance-stat-card--late{background:linear-gradient(#fffbebfa,#fef3c7f0)}.attendance-roster-card{background:linear-gradient(#fffffffc,#f8fafcf7);border:1px solid #94a3b829;border-radius:30px;padding:1.35rem 1.4rem;box-shadow:0 24px 48px #0f172a12}.attendance-roster-card__header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.attendance-roster-card__header h2{color:var(--color-text);margin:0;font-size:1.3rem}.attendance-roster-card__header p{color:var(--color-text-muted);margin:.3rem 0 0;line-height:1.5}.attendance-roster-card__actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.7rem;display:flex}.attendance-search{background:#f8fafceb;border:1px solid #94a3b82e;border-radius:18px;align-items:center;gap:.6rem;min-width:240px;padding:.82rem .95rem;display:flex}.attendance-search svg{color:#94a3b8;flex-shrink:0;width:18px;height:18px}.attendance-search input{width:100%;color:var(--color-text);background:0 0;border:none;outline:none;font-weight:600}.attendance-ghost-button,.attendance-primary-inline,.attendance-primary-button{cursor:pointer;border-radius:999px;padding:.78rem 1rem;font-weight:700;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}.attendance-ghost-button{color:var(--color-text-muted);background:#f8fafcf0;border:1px solid #94a3b82e}.attendance-primary-inline{color:#2563eb;background:#eff6fffa;border:1px solid #3b82f62e}.attendance-primary-button{color:#fff;background:linear-gradient(135deg,#60a5fa,#3b82f6);border:none;box-shadow:0 14px 24px #3b82f633}.attendance-ghost-button:hover,.attendance-primary-inline:hover,.attendance-primary-button:hover{transform:translateY(-1px)}.attendance-ghost-button:disabled,.attendance-primary-inline:disabled,.attendance-primary-button:disabled{opacity:.58;cursor:not-allowed;box-shadow:none;transform:none}.attendance-students-list{flex-direction:column;gap:.8rem;display:flex}.attendance-students-list--daily{margin-top:.5rem}.attendance-student-card{justify-content:space-between;align-items:center;gap:1rem;display:flex}.attendance-student-card--daily{border-bottom:1px solid #e2e8f0e6;padding:1rem .15rem}.attendance-student-card--daily:last-child{border-bottom:none}.attendance-student-card__identity{min-width:0}.attendance-student-card__identity--daily{align-items:center;gap:.9rem;display:flex}.attendance-student-card__avatar{flex-shrink:0}.attendance-student-card__avatar--photo{color:#2563eb;background:linear-gradient(135deg,#dbeafef0,#fffffff5);border-radius:16px;justify-content:center;align-items:center;width:48px;height:48px;display:inline-flex;box-shadow:inset 0 1px #ffffffe6}.attendance-student-card__avatar--photo svg{width:28px;height:28px}.attendance-student-card__copy strong{color:var(--color-text);font-size:.98rem;display:block}.attendance-student-card__copy span{color:#94a3b8;margin-top:.18rem;font-size:.82rem;font-weight:700;display:block}.attendance-status-buttons{display:flex}.attendance-status-buttons--daily{flex-wrap:wrap;justify-content:flex-end;gap:.65rem}.attendance-status-button{color:#94a3b8;cursor:pointer;background:#f8fafcf5;border:1px solid #e2e8f0f5;justify-content:center;align-items:center;gap:.42rem;font-weight:700;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s,color .18s;display:inline-flex}.attendance-status-button--daily{border-radius:999px;min-width:116px;padding:.7rem .95rem}.attendance-status-button svg{width:18px;height:18px}.attendance-status-button:hover{transform:translateY(-1px)}.attendance-status-button--present.attendance-selected{color:#16a34a;background:#f0fdf4fa;border-color:#22c55e73;box-shadow:0 0 0 3px #22c55e1f}.attendance-status-button--absent.attendance-selected{color:#ef4444;background:#fef2f2fa;border-color:#f8717180;box-shadow:0 0 0 3px #f871711f}.attendance-status-button--late.attendance-selected{color:#d97706;background:#fffbebfa;border-color:#f59e0b7a;box-shadow:0 0 0 3px #f59e0b1f}.attendance-status-button--justified.attendance-selected{color:#2563eb;background:#eff6fffa;border-color:#3b82f673;box-shadow:0 0 0 3px #3b82f61f}.attendance-empty{text-align:center;min-height:320px;color:var(--color-text-muted);place-items:center;gap:.5rem;display:grid}.attendance-empty--soft{background:#f8fafccc;border:1px dashed #94a3b842;border-radius:26px;padding:2rem}.attendance-empty__icon{color:#2563eb;background:#2563eb14;border-radius:22px;justify-content:center;align-items:center;width:64px;height:64px;display:inline-flex}.attendance-empty__icon svg{width:30px;height:30px}.attendance-empty strong{color:var(--color-text);font-size:1.05rem}.attendance-empty p{max-width:460px;line-height:1.6}.attendance-footer{display:flex}.attendance-footer--daily{justify-content:space-between;align-items:center;gap:1rem;padding-top:1rem}.attendance-footer__hint{color:var(--color-text-muted);font-weight:600}.attendance-save-button{min-width:220px}.context-drawer-backdrop{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:120;background:#0f172a47;justify-content:flex-end;align-items:stretch;padding:0;display:flex;position:fixed;inset:0}.context-drawer{background:radial-gradient(circle at 100% 0,#3b82f629,#0000 22%),radial-gradient(circle at 0 100%,#0ea5e914,#0000 28%),linear-gradient(#fffffff5,#f8fafcfa);border-left:1px solid #94a3b82e;width:min(520px,100%);height:100vh;padding:1.5rem 1.35rem 1.75rem;overflow:auto;box-shadow:-28px 0 60px #0f172a2e}.context-drawer__header{justify-content:space-between;align-items:flex-start;gap:1.1rem;margin-bottom:1.35rem;display:flex}.context-drawer__identity{align-items:center;gap:1rem;min-width:0;display:flex}.context-drawer__avatar{color:#1d4ed8;background:linear-gradient(135deg,#bfdbfee6,#e0f2feeb);border-radius:24px;flex-shrink:0;place-items:center;width:72px;height:72px;font-size:1.35rem;font-weight:800;display:grid;overflow:hidden}.context-drawer__avatar img{object-fit:cover;width:100%;height:100%}.context-drawer__identity-copy{min-width:0}.context-drawer__eyebrow{letter-spacing:.08em;text-transform:uppercase;color:#2563eb;margin-bottom:.32rem;font-size:.74rem;font-weight:800;display:inline-block}.context-drawer__identity-copy h2{color:var(--color-text);letter-spacing:-.03em;margin:0;font-size:1.45rem}.context-drawer__identity-copy p{color:var(--color-text-muted);margin:.3rem 0 0;font-size:.92rem;line-height:1.45}.context-drawer__close{width:42px;height:42px;color:var(--color-text-muted);cursor:pointer;background:#ffffffe6;border:1px solid #94a3b842;border-radius:14px;font-size:1.5rem;line-height:1;transition:background .18s,color .18s,transform .18s}.context-drawer__close:hover{color:var(--color-text);background:#fff;transform:translateY(-1px)}.context-drawer__body{flex-direction:column;gap:1rem;display:flex}.context-drawer__panel{background:linear-gradient(135deg,#dbeafeb3,#eff6ffe6);border:1px solid #2563eb24;border-radius:26px;padding:1.15rem 1.2rem}.context-drawer__section-label{letter-spacing:.08em;text-transform:uppercase;color:#1d4ed8;margin-bottom:.3rem;font-size:.72rem;font-weight:800;display:inline-block}.context-drawer__panel h3{color:var(--color-text);margin:0;font-size:1.08rem}.context-drawer__panel p{color:var(--color-text-muted);margin:.4rem 0 0;font-size:.92rem;line-height:1.55}.context-drawer__selectors{gap:.95rem;display:grid}.context-drawer__field{background:#ffffffd6;border:1px solid #94a3b82e;border-radius:24px;padding:1rem 1.05rem;box-shadow:inset 0 1px #ffffffbf}.context-drawer__field label{letter-spacing:.08em;text-transform:uppercase;color:#2563eb;margin-bottom:.5rem;font-size:.76rem;font-weight:800;display:block}.context-drawer__select-wrap{position:relative}.context-drawer__select{width:100%;min-height:48px;color:var(--color-text);background:linear-gradient(#fffffff5,#f8fafcf0);border:1px solid #94a3b83d;border-radius:16px;padding:.82rem .95rem;font-weight:600;transition:border-color .18s,box-shadow .18s,background .18s}.context-drawer__select:focus{border-color:#2563eb73;outline:none;box-shadow:0 0 0 4px #2563eb1f}.context-drawer__select:disabled{opacity:.72;cursor:not-allowed}.context-drawer__field small{color:var(--color-text-muted);margin-top:.55rem;line-height:1.45;display:block}.context-drawer__quick-grid{grid-template-columns:1fr;gap:.85rem;display:grid}.context-drawer__quick-card{text-align:left;cursor:pointer;background:#ffffffeb;border:1px solid #94a3b83d;border-radius:24px;flex-direction:column;gap:.45rem;padding:1.1rem;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;display:flex}.context-drawer__quick-card:hover{border-color:#2563eb57;transform:translateY(-2px);box-shadow:0 18px 34px #0f172a1a}.context-drawer__quick-card--active{background:linear-gradient(135deg,#dbeafef2,#eff6fffa);border-color:#2563eb6b;box-shadow:0 22px 40px #2563eb29}.context-drawer__quick-badge{color:#1d4ed8;letter-spacing:.04em;text-transform:uppercase;background:#2563eb1a;border-radius:999px;justify-content:center;align-items:center;width:fit-content;padding:.28rem .68rem;font-size:.72rem;font-weight:800;display:inline-flex}.context-drawer__quick-card strong{color:var(--color-text);font-size:1rem}.context-drawer__quick-card span:last-child{color:var(--color-text-muted);font-size:.88rem;line-height:1.45}.context-drawer__empty{color:var(--color-text-muted);background:#ffffffd6;border:1px dashed #94a3b866;border-radius:22px;padding:1.15rem 1.2rem;font-weight:600}.students-list-page{flex-direction:column;gap:1.5rem;display:flex}.students-list-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.75rem 1.75rem 1.25rem}.students-list__header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.students-list__title{color:var(--color-text);letter-spacing:-.025em;margin:0 0 .25rem;font-size:1.3rem;font-weight:800}.students-list__subtitle{color:var(--color-text-muted);margin:0;font-size:.82rem;font-weight:500}.students-list__filters{border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:.65rem;margin-bottom:1.25rem;padding-bottom:1.25rem;display:flex}.students-list__filter-input{flex:160px;min-width:160px;max-width:220px;padding:.6rem .9rem}.students-list__search-input{flex:2 220px;max-width:340px;padding:.6rem .9rem}.students-list__clear-btn{border-radius:var(--radius-md);color:#dc2626;cursor:pointer;white-space:nowrap;background:#fef2f2b3;border:1px solid #ef444438;flex-shrink:0;padding:.55rem 1rem;font-size:.82rem;font-weight:600;transition:background .15s,border-color .15s}.students-list__clear-btn:hover{background:#fee2e2e6;border-color:#ef444461}.students-list__recalc-btn{border-radius:var(--radius-md);color:#4f46e5;cursor:pointer;background:#eef2ffb3;border:1px solid #6366f14d;flex-shrink:0;padding:.55rem 1rem;font-size:.8125rem;font-weight:600;transition:background .15s,border-color .15s}.students-list__recalc-btn:hover:not(:disabled){background:#e0e7fff2;border-color:#6366f180}.students-list__recalc-btn:disabled{opacity:.55;cursor:not-allowed}.students-list__pdf-btn{border-radius:var(--radius-md);color:#1d4ed8;cursor:pointer;white-space:nowrap;background:#eff6ffd9;border:1px solid #2563eb59;flex-shrink:0;padding:.55rem 1.1rem;font-size:.8125rem;font-weight:600;transition:background .15s,border-color .15s}.students-list__pdf-btn:hover{background:#dbeafef2;border-color:#2563eb8c}.students-list__clave-msg{border-radius:var(--radius-md);margin:.5rem 0 .25rem;padding:.45rem .9rem;font-size:.8125rem;font-weight:500}.students-list__clave-msg--ok{color:#065f46;background:#10b98114;border:1px solid #10b98140}.students-list__clave-msg--error{color:#991b1b;background:#ef444412;border:1px solid #ef444440}.students-list__col-clave{text-align:center;width:42px;padding-left:.5rem!important;padding-right:.25rem!important}.students-list__clave{text-align:center;font-variant-numeric:tabular-nums;color:#4f46e5;background:#eef2ffcc;border:1px solid #6366f140;border-radius:4px;min-width:26px;padding:1px 4px;font-size:.78rem;font-weight:700;display:inline-block}.students-list__clave--empty{color:var(--color-text-muted);background:0 0;border-color:#0000;font-weight:400}.students-list__col-avatar{width:44px;padding-right:0!important}.students-list__table th:nth-child(2),.students-list__table td:nth-child(2){padding-right:.25rem}.students-list__name{color:var(--color-text);font-weight:600}.students-list__email{color:var(--color-text-muted);font-size:.82rem}.student-avatar{background:linear-gradient(135deg,#bfdbfee6,#e0f2feeb);border-radius:10px;flex-shrink:0;width:34px;height:34px;overflow:hidden}.student-avatar img{object-fit:cover;width:100%;height:100%}.student-avatar--initials{color:#1d4ed8;place-items:center;font-size:.85rem;font-weight:800;display:grid}.grades-chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);margin-bottom:1.5rem;padding:1.5rem 1.5rem 1rem}.grades-chart-card__header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.grades-chart-card__header h2{color:var(--color-text);letter-spacing:-.02em;margin:0 0 .22rem;font-size:1.05rem;font-weight:700}.grades-chart-card__header p{color:var(--color-text-muted);margin:0;font-size:.8rem}.grades-chart-card__badges{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.grades-chart-card__kpi{color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.82rem;display:flex}.grades-chart-card__kpi strong{color:var(--color-text);font-weight:700}.grades-chart-card__kpi-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.grades-chart-card__kpi-dot--alumnos{background:#1d7df2}.grades-chart-card__kpi-dot--secciones{background:#10b981}.grades-chart-card__scroll{scrollbar-width:thin;scrollbar-color:#94a3b84d transparent;margin:0 -.25rem;padding:0 .25rem;overflow:auto hidden}.grades-chart-card__scroll::-webkit-scrollbar{height:4px}.grades-chart-card__scroll::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:4px}.grades-chart-card__placeholder{min-height:220px}.grades-chart-card__legend{border-top:1px solid var(--color-border);align-items:center;gap:1.25rem;margin-top:.75rem;padding-top:.75rem;display:flex}.grades-chart-card__legend-item{color:var(--color-text-muted);align-items:center;gap:.4rem;font-size:.78rem;display:flex}.grades-chart-card__legend-box{border-radius:3px;flex-shrink:0;width:12px;height:12px}.grades-chart-card__legend-box--alumnos{background:#1d7df2}.grades-chart-card__legend-box--secciones{background:#10b981}.grades-chart__tooltip{color:#f1f5f9;background:#0f172aeb;border-radius:12px;min-width:140px;padding:.65rem .9rem;font-size:.83rem;box-shadow:0 8px 24px #0f172a38}.grades-chart__tooltip-title{color:#fff;margin:0 0 .4rem;font-size:.88rem;font-weight:700}.grades-chart__tooltip p{align-items:center;gap:.4rem;margin:.18rem 0;display:flex}.grades-chart__tooltip-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px;display:inline-block}.grades-chart__tooltip-dot--alumnos{background:#1d7df2}.grades-chart__tooltip-dot--secciones{background:#10b981}.global-search{flex:1;max-width:520px;position:relative}.global-search__input-wrap{align-items:center;display:flex;position:relative}.global-search__icon{width:16px;height:16px;color:var(--color-text-muted);pointer-events:none;flex-shrink:0;position:absolute;left:1rem}.global-search__input{border:1px solid var(--color-border);width:100%;color:var(--color-text);transition:border var(--transition-fast), box-shadow var(--transition-fast);background:#ffffffe0;border-radius:999px;padding:.72rem 2.5rem .72rem 2.6rem;font-size:.875rem}.global-search__input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #1d7df21f}.global-search__spinner{border:2px solid #1d7df233;border-top-color:var(--color-primary);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin;position:absolute;right:1rem}.global-search__clear{width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;background:#94a3b833;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:absolute;right:.75rem}.global-search__clear:hover{color:var(--color-text);background:#94a3b866}.global-search__dropdown{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:200;background:#fffffffa;border:1px solid #94a3b833;border-radius:18px;max-height:460px;padding:.5rem;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow-y:auto;box-shadow:0 20px 48px #0f172a24,0 4px 12px #0f172a0f}.global-search__group{margin-bottom:.2rem}.global-search__group:last-child{margin-bottom:0}.global-search__group-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-subtle);-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;padding:.45rem .8rem .3rem;font-size:.7rem;font-weight:800;display:flex}.global-search__item{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:11px;align-items:baseline;gap:.45rem;width:100%;min-width:0;padding:.55rem .8rem;transition:background .12s;display:flex}.global-search__item:hover,.global-search__item--active{background:#1d7df212}.global-search__item-label{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;max-width:45%;font-size:.88rem;font-weight:600;overflow:hidden}.global-search__item-sub{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.8rem;overflow:hidden}.global-search__item-arrow{color:var(--color-primary);opacity:.65;flex-shrink:0;margin-left:auto;font-size:.72rem;font-weight:700}.global-search__empty{text-align:center;color:var(--color-text-muted);padding:1.4rem .8rem;font-size:.88rem}.context-drawer__footer{margin-top:.5rem;padding-top:.5rem}.context-drawer__footer-divider{background:linear-gradient(90deg,#0000,#94a3b838,#0000);height:1px;margin-bottom:1rem}.context-drawer__logout-btn{cursor:pointer;text-align:left;background:#fef2f299;border:1px solid #ef444424;border-radius:16px;align-items:center;gap:.9rem;width:100%;padding:.85rem 1rem;transition:background .18s,border-color .18s,box-shadow .18s;display:flex}.context-drawer__logout-btn:hover{background:#fee2e2d9;border-color:#ef444447;box-shadow:0 2px 12px #ef444414}.context-drawer__logout-icon{color:#ef4444;opacity:.85;flex-shrink:0;width:20px;height:20px}.context-drawer__logout-copy{flex-direction:column;gap:.1rem;min-width:0;display:flex}.context-drawer__logout-label{color:#dc2626;font-size:.9rem;font-weight:700;line-height:1.2}.context-drawer__logout-hint{color:#f87171;opacity:.85;text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;font-weight:500;overflow:hidden}@media (width<=1180px){.attendance-header-card,.attendance-roster-card__header{flex-direction:column}.attendance-header-card__controls,.attendance-roster-card__actions{justify-content:flex-start}.attendance-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.score-flow{flex-direction:column;align-items:stretch}.score-flow__arrow{align-self:center;transform:rotate(90deg)}}@media (width<=640px){.topbar{flex-wrap:wrap;justify-content:flex-end;gap:.75rem;padding:.75rem 1rem}.topbar-search{width:100%;max-width:none;margin:0}.context-drawer{width:100%;padding:1.15rem 1rem 1.5rem}.context-drawer__header,.context-drawer__identity{align-items:flex-start}.context-drawer__avatar{border-radius:20px;width:60px;height:60px}.context-drawer__identity-copy h2{font-size:1.28rem}.score-selector-panel__header,.score-toolbar__actions,.attendance-footer{flex-direction:column;align-items:stretch}.score-center-chip,.score-flow__item,.score-selector-option{width:100%}.score-toolbar__actions button,.attendance-save-button{width:100%;max-width:none}.score-input{width:72px}.attendance-stats-grid{grid-template-columns:1fr}.attendance-header-card__controls,.attendance-roster-card__actions,.attendance-status-buttons--daily,.attendance-footer--daily,.attendance-student-card{flex-direction:column;align-items:flex-start}.attendance-search,.attendance-control-pill,.attendance-control-pill--wide,.attendance-status-button--daily,.attendance-save-button{width:100%;min-width:0}.card-activity{grid-template-columns:1fr}.card-header,.card-footer{flex-direction:column;align-items:flex-start}.card-activity__weight{align-items:flex-start}}.attendance-justification-container{gap:1.5rem;display:grid}.attendance-justification-hero{background:linear-gradient(145deg,#fffffff5,#f2f7ffeb);border:1px solid #d2ddf1cc;border-radius:28px;padding:2rem 2.2rem;box-shadow:0 28px 60px #0f172a14}.attendance-justification-hero h1{color:#1f2937;letter-spacing:-.04em;margin:0;font-size:clamp(2rem,2.6vw,2.7rem);font-weight:800}.attendance-justification-hero p{color:#6b7280;max-width:42rem;margin:.45rem 0 0;font-size:1rem}.attendance-justification-grid{grid-template-columns:minmax(320px,380px) minmax(0,1fr);gap:1.5rem;display:grid}.attendance-justification-form,.attendance-justification-list{background:#fffffff5;border:1px solid #d6e0efd1;border-radius:28px;box-shadow:0 24px 50px #0f172a14}.attendance-justification-form{gap:1.5rem;height:fit-content;padding:1.7rem;display:grid}.attendance-justification-form__header{align-items:flex-start;gap:1rem;display:flex}.attendance-justification-form__icon{color:#2563eb;background:linear-gradient(140deg,#2563eb24,#60a5fa33);border-radius:18px;justify-content:center;align-items:center;width:3.1rem;height:3.1rem;display:inline-flex}.attendance-justification-form__icon svg{width:1.35rem;height:1.35rem}.attendance-justification-form__header h2,.attendance-justification-list__header h2{color:#1f2937;letter-spacing:-.03em;margin:0;font-size:1.9rem;font-weight:800}.attendance-justification-form__header p,.attendance-justification-list__header p{color:#6b7280;margin:.35rem 0 0}.attendance-justification-fields{gap:1rem;display:grid}.attendance-justification-field{gap:.5rem;display:grid}.attendance-justification-field>span{color:#4b5563;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;font-weight:800}.attendance-justification-input{background:#f3f6fb;border:1px solid #cbd5e1e6;border-radius:18px;align-items:center;gap:.7rem;min-height:3.3rem;padding:0 1rem;display:flex}.attendance-justification-input svg{color:#94a3b8;flex:none;width:1.05rem;height:1.05rem}.attendance-justification-input select{appearance:none;color:#1f2937;font:inherit;background:0 0;border:0;outline:none;flex:auto;width:100%}.attendance-justification-note,.attendance-justification-warning{border-radius:18px;align-items:flex-start;gap:.75rem;padding:.9rem 1rem;display:flex}.attendance-justification-note{color:#2563eb;background:#eff6ffcc;border:1px solid #93c5fd8c}.attendance-justification-note svg{flex:none;width:1.05rem;height:1.05rem;margin-top:.1rem}.attendance-justification-warning{color:#b91c1c;background:#fef2f2e0;border:1px solid #fca5a599;font-weight:700}.attendance-justification-editor{background:#f8fafc;border:1px solid #cbd5e1e6;border-radius:22px;overflow:hidden}.attendance-justification-editor__toolbar{color:#64748b;background:linear-gradient(#f8fafc,#f1f5f9f2);border-bottom:1px solid #e2e8f0f2;align-items:center;gap:.65rem;padding:.9rem 1rem;display:flex}.attendance-justification-editor__toolbar svg{color:#2563eb;width:1rem;height:1rem}.attendance-justification-editor textarea{color:#1f2937;font:inherit;resize:vertical;background:0 0;border:0;outline:none;width:100%;min-height:11rem;padding:1rem;display:block}.attendance-justification-actions{gap:.9rem;display:flex}.attendance-justification-button{cursor:pointer;font:inherit;border:0;border-radius:18px;min-height:3rem;padding:0 1.35rem;font-weight:800;transition:transform .18s,box-shadow .18s,background-color .18s}.attendance-justification-button:hover{transform:translateY(-1px)}.attendance-justification-button--primary{color:#fff;background:linear-gradient(135deg,#1d4ed8,#3b82f6);box-shadow:0 16px 26px #2563eb3d}.attendance-justification-button--ghost{color:#475569;background:#eef2f7}.attendance-justification-list{align-self:start;display:grid}.attendance-justification-list__header{border-bottom:1px solid #e2e8f0e6;justify-content:space-between;align-items:center;gap:1rem;padding:1.6rem 1.8rem;display:flex}.attendance-justification-search{background:#f3f6fb;border:1px solid #cbd5e1d6;border-radius:18px;align-items:center;gap:.7rem;min-width:min(100%,22rem);min-height:3.1rem;padding:0 1rem;display:flex}.attendance-justification-search svg{color:#94a3b8;width:1rem;height:1rem}.attendance-justification-search input{color:#1f2937;font:inherit;background:0 0;border:0;outline:none;flex:auto}.attendance-justification-table{min-height:26rem;display:grid}.attendance-justification-table__head,.attendance-justification-card{grid-template-columns:minmax(190px,1.4fr) minmax(100px,.8fr) minmax(95px,.7fr) minmax(120px,.8fr) minmax(180px,1.6fr) minmax(90px,.65fr);align-items:center;column-gap:1rem;display:grid}.attendance-justification-table__head{color:#6b7280;letter-spacing:.07em;text-transform:uppercase;padding:.95rem 1.8rem;font-size:.78rem;font-weight:800}.attendance-justification-table__body{display:grid}.attendance-justification-card{border-top:1px solid #e2e8f0eb;min-height:5.8rem;padding:1rem 1.8rem}.attendance-justification-card>span,.attendance-justification-card>p{color:#475569;margin:0}.attendance-justification-card>p{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.attendance-justification-card__student{align-items:center;gap:.9rem;min-width:0;display:flex}.attendance-justification-card__student strong{color:#1f2937;font-size:1rem;display:block}.attendance-justification-card__student span{color:#94a3b8;margin-top:.2rem;font-size:.84rem;display:block}.attendance-justification-card__avatar{color:#6d28d9;background:linear-gradient(135deg,#c4b5fd9e,#f472b652);border-radius:999px;flex:0 0 2.35rem;justify-content:center;align-items:center;width:2.35rem;height:2.35rem;font-size:.85rem;font-weight:800;display:inline-flex}.attendance-justification-status{letter-spacing:.06em;text-transform:uppercase;border-radius:999px;justify-content:center;width:fit-content;padding:.45rem .85rem;font-size:.76rem;font-weight:800;display:inline-flex}.attendance-justification-status--absent{color:#dc2626;background:#fee2e2eb}.attendance-justification-status--late{color:#a16207;background:#fef08a94}.attendance-justification-status--justified{color:#2563eb;background:#dbeafef2}.attendance-justification-card__actions{justify-content:flex-start;gap:.55rem;display:flex}.attendance-justification-icon-button{color:#2563eb;cursor:pointer;background:#eff6ff;border:0;border-radius:14px;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;transition:transform .18s,background-color .18s;display:inline-flex}.attendance-justification-icon-button:hover{background:#dbeafe;transform:translateY(-1px)}.attendance-justification-icon-button svg{width:1.05rem;height:1.05rem}.attendance-justification-icon-button--danger{color:#dc2626;background:#fef2f2}.attendance-justification-icon-button--danger:hover{background:#fee2e2}.attendance-justification-empty{color:#64748b;text-align:center;justify-content:center;align-items:center;min-height:18rem;padding:2rem;font-weight:600;display:flex}@media (width<=1180px){.attendance-justification-grid{grid-template-columns:1fr}}@media (width<=920px){.attendance-justification-list__header{flex-direction:column;align-items:stretch}.attendance-justification-search{min-width:100%}.attendance-justification-table__head{display:none}.attendance-justification-card{grid-template-columns:1fr;align-items:flex-start;row-gap:.75rem;padding:1.2rem 1.25rem}.attendance-justification-card__actions{justify-content:flex-end}}@media (width<=640px){.attendance-justification-hero,.attendance-justification-form,.attendance-justification-list{border-radius:22px}.attendance-justification-hero,.attendance-justification-form{padding:1.25rem}.attendance-justification-list__header,.attendance-justification-card{padding-left:1.1rem;padding-right:1.1rem}.attendance-justification-actions{flex-direction:column}}.report-card-actions{flex-wrap:wrap}.report-card-actions .attendance-justification-button{flex:12rem}.report-card-table-head,.report-card-row{grid-template-columns:minmax(190px,1.5fr) minmax(70px,.45fr) minmax(110px,.65fr) minmax(90px,.55fr) minmax(110px,.7fr) minmax(140px,.8fr)}.report-card-row--selected{background:#eff6ffb8;box-shadow:inset 4px 0 #2563eb}.report-card-detail-panel{border-top:1px solid #e2e8f0eb;gap:1rem;padding:1.35rem 1.8rem 1.7rem;display:grid}.report-card-detail-panel__header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.report-card-detail-panel__header h3{color:#1f2937;margin:0;font-size:1.25rem;font-weight:800}.report-card-detail-panel__header p{color:#64748b;margin:.35rem 0 0;font-weight:600}.report-card-detail-grid{gap:.75rem;display:grid}.report-card-detail-item{background:#f8fafc;border:1px solid #cbd5e1d1;border-radius:18px;grid-template-columns:minmax(180px,1fr) repeat(3,minmax(82px,.28fr));align-items:center;gap:.8rem;padding:.95rem 1rem;display:grid}.report-card-detail-item div{gap:.2rem;display:grid}.report-card-detail-item strong{color:#1f2937}.report-card-detail-item span{color:#64748b;font-size:.82rem;font-weight:700}.report-card-detail-note{color:#475569}@media (width<=920px){.report-card-table-head,.report-card-row,.report-card-detail-item{grid-template-columns:1fr}.report-card-detail-panel{padding:1.2rem 1.1rem}}.rc-modal-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.rc-modal{background:var(--color-surface);border-radius:12px;flex-direction:column;width:min(960px,100%);height:min(90vh,820px);display:flex;overflow:hidden;box-shadow:0 24px 64px #0000004d}.rc-modal__header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.rc-modal__title{color:var(--color-text-primary);margin:0;font-size:1rem;font-weight:700}.rc-modal__sub{color:var(--color-text-muted);margin:.125rem 0 0;font-size:.8125rem}.rc-modal__actions{align-items:center;gap:.625rem;display:flex}.rc-modal__download-btn{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex}.rc-modal__download-btn:hover{background:var(--color-primary-hover,#1d4ed8)}.rc-modal__close-btn{width:2rem;height:2rem;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:background .15s;display:flex}.rc-modal__close-btn:hover{background:var(--color-border);color:var(--color-text-primary)}.rc-modal__body{background:#525659;flex:1;overflow:hidden}.rc-modal__loading{color:#fff;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;height:100%;font-size:.875rem;display:flex}.teachers-directory-page{max-width:1100px;margin:0 auto;padding:1.5rem}.teachers-directory-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.75rem 1.75rem 1.25rem}.teachers-directory__header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.teachers-directory__title{color:var(--color-text);margin:0 0 .25rem;font-size:1.25rem;font-weight:700}.teachers-directory__subtitle{color:var(--color-text-muted);margin:0;font-size:.85rem}.teachers-directory__filters{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.teachers-directory__center-select{flex-shrink:0;min-width:180px}.teachers-directory__search{flex:1;min-width:200px}.teachers-directory__status-tabs{border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;overflow:hidden}.teachers-directory__tab{background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;border:none;border-right:1px solid var(--color-border);padding:.45rem .9rem;font-size:.8125rem;font-weight:500;transition:background .15s,color .15s}.teachers-directory__tab:last-child{border-right:none}.teachers-directory__tab:hover:not(.teachers-directory__tab--active){background:var(--color-surface-alt,#f9fafb)}.teachers-directory__tab--active{color:#1d4ed8;background:#2563eb1a;font-weight:600}.teachers-directory__list{flex-direction:column;gap:.85rem;display:flex}.teacher-dir-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);transition:box-shadow .15s;overflow:hidden}.teacher-dir-card:hover{box-shadow:0 2px 8px #0000000f}.teacher-dir-card--inactive{background:#fef2f259;border-left:3px solid #ef44448c}.teacher-dir-card__info{border-bottom:1px solid var(--color-border);align-items:center;gap:.875rem;padding:.875rem 1rem;display:flex}.teacher-dir-avatar{background:linear-gradient(135deg,#bfdbfe,#e0f2fe);border-radius:50%;flex-shrink:0;place-items:center;width:40px;height:40px;display:grid;overflow:hidden}.teacher-dir-avatar img{object-fit:cover;width:100%;height:100%}.teacher-dir-avatar--initials{color:#1d4ed8;font-size:1rem;font-weight:800}.teacher-dir-card__identity{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.teacher-dir-card__name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:600;overflow:hidden}.teacher-dir-card__email{color:var(--color-text-muted);font-size:.8rem}.teacher-dir-card__status{color:#065f46;background:#10b9811a;border:1px solid #10b98140;border-radius:99px;flex-shrink:0;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.teacher-dir-card__status--inactive{color:#991b1b;background:#ef444414;border-color:#ef444438}.teacher-dir-card__sections{flex-direction:column;gap:.6rem;padding:.625rem 1rem .75rem;display:flex}.teacher-dir-card__no-assignments{color:var(--color-text-muted);padding:.6rem 1rem;font-size:.8rem;font-style:italic}.teacher-dir-section{flex-direction:column;gap:.35rem;display:flex}.teacher-dir-section__header{align-items:center;gap:.5rem;display:flex}.teacher-dir-section__label{color:var(--color-text);font-size:.8125rem;font-weight:600}.teacher-dir-section__tipo{color:#4b5563;text-transform:uppercase;letter-spacing:.03em;background:#6b72801a;border:1px solid #6b728033;border-radius:99px;padding:.15rem .5rem;font-size:.7rem;font-weight:700}.teacher-dir-section__tipo--titular{color:#1d4ed8;background:#2563eb1a;border-color:#2563eb40}.teacher-dir-section__subjects{flex-wrap:wrap;gap:.35rem;display:flex}.teacher-dir-section__no-subjects{color:var(--color-text-muted);margin:0;font-size:.78rem;font-style:italic}.teacher-dir-subject-chip{border:1px solid var(--color-border);color:#374151;background:#f3f4f6e6;border-radius:4px;padding:.2rem .6rem;font-size:.78rem;font-weight:500}.ta-titular-toggle{cursor:pointer;align-items:center;gap:.5rem;margin-top:.25rem;display:inline-flex}
