@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);.loading-spinner{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:2rem}.loading-spinner__circle{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#0095c8}.loading-spinner__circle--small{border-width:2px;height:24px;width:24px}.loading-spinner__circle--medium{border-width:3px;height:40px;width:40px}.loading-spinner__circle--large{border-width:4px;height:64px;width:64px}.loading-spinner__text{color:#4b5563;font-size:.875rem;font-weight:500;margin:0}.header{background:linear-gradient(135deg,#0095c8,#0082af);border-bottom:2px solid #ff8200;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:1020}.header__container{align-items:center;display:flex;height:4rem;justify-content:space-between;max-width:100%;padding:0 1rem}.header__left{align-items:center;display:flex;gap:1rem;justify-content:flex-start}.header__menu-btn{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:24px;justify-content:space-around;padding:0;width:24px}@media(min-width:1024px){.header__menu-btn{display:none}}.header__menu-btn span{background:#fff;border-radius:2px;height:2px;transition:all .2s ease-in-out;width:100%}.header__menu-btn:hover span{background:#ffb466}.header__logo{align-items:center;display:flex;justify-content:flex-start}.header__title{font-size:1.125rem;font-weight:700;margin:0}@media(max-width:767px){.header__title{font-size:1rem}}.header__right{align-items:center;display:flex;justify-content:flex-end}.header__user{position:relative}.header__user-btn{align-items:center;background:#0000;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;gap:.75rem;justify-content:flex-start;padding:.5rem;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.header__user-btn:hover{background:#ffffff1a}.header__user-avatar{align-items:center;background:#ff8200;border-radius:50%;display:flex;font-size:.875rem;font-weight:700;height:32px;justify-content:center;width:32px}.header__user-name{font-weight:500}@media(max-width:767px){.header__user-name{display:none}}.header__user-arrow{transition:transform .2s ease-in-out}.header__user-arrow.open{transform:rotate(180deg)}.header__user-menu{animation:fadeIn .3s ease-in-out forwards;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:.5rem;min-width:250px;opacity:0;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.header__user-info{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:1rem}.header__user-full-name{color:#1f2937;font-weight:600;margin-bottom:.25rem}.header__user-email{color:#4b5563;font-size:.875rem}.header__user-actions{padding:.5rem}.header__user-action{background:#0000;border:none;border-radius:.5rem;color:#374151;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;text-align:left;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.header__user-action:hover{background:#f3f4f6;color:#0095c8}.header__overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.sidebar{background:#fff;border-right:1px solid #e5e7eb;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;height:calc(100vh - 4rem);left:-16rem;overflow-y:auto;position:fixed;top:4rem;transition:transform .3s ease-in-out;width:16rem;z-index:1030}@media(min-width:1024px){.sidebar{box-shadow:none;left:0;position:-webkit-sticky;position:sticky;transform:translateX(0)}}.sidebar--open{transform:translateX(16rem)}.sidebar__nav{padding:1rem 0}.sidebar__link{align-items:center;border-left:3px solid #0000;color:#374151;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;justify-content:flex-start;padding:.75rem 1rem;text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.sidebar__link:hover{background:#f9fafb;border-left-color:#2fcaff;color:#0095c8}.sidebar__link--active{background:linear-gradient(90deg,#0095c8,#2fcaff);border-left-color:#ff8200;color:#fff}.sidebar__link--active .sidebar__icon{color:#fff}.sidebar__icon{align-items:center;color:inherit;display:flex;height:20px;justify-content:center;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:20px}.sidebar__label{font-weight:inherit}.sidebar__overlay{background:#00000080;bottom:0;left:0;position:fixed;right:0;top:4rem;z-index:1029}@media(min-width:1024px){.sidebar__overlay{display:none}}@media(max-width:767px){.sidebar{left:-280px;width:280px}.sidebar--open{transform:translateX(280px)}}.footer{background:linear-gradient(135deg,#0095c8,#006f95);border-top:3px solid #ff8200;color:#fff;margin-top:auto;padding:1rem 0}.footer__content{margin:0 auto;max-width:1200px;padding:0 1rem;text-align:center}@media(min-width:768px){.footer__content{align-items:center;display:flex;justify-content:space-between;text-align:left}}.footer__text{font-size:.875rem;font-weight:500;margin-bottom:.5rem}@media(min-width:768px){.footer__text{margin-bottom:0}}.footer__author{font-size:.75rem;font-style:italic;opacity:.9}@media(max-width:767px){.footer{padding:.75rem 0}.footer__content{padding:0 .75rem}.footer__author,.footer__text{font-size:.75rem}}.layout{background:#f9fafb;display:flex;flex-direction:column;min-height:100vh}.layout__content{display:flex;flex:1 1}@media(min-width:1024px){.layout__content{padding-left:16rem}}.layout__main{display:flex;flex:1 1;flex-direction:column;min-height:calc(100vh - 4rem)}.layout__main-content{flex:1 1;margin:0 auto;max-width:1200px;padding:1.5rem;width:100%}@media(max-width:767px){.layout__main-content{padding:1rem}.layout__content{padding-left:0}}.login{align-items:center;background:linear-gradient(135deg,#0095c8,#ff8200);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login__container{animation:fadeIn .3s ease-in-out forwards;max-width:420px;opacity:0;width:100%}.login__header{color:#fff;margin-bottom:2rem;text-align:center}.login__title{font-size:1.875rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px #0000004d}@media(max-width:767px){.login__title{font-size:1.5rem}}.login__subtitle{font-size:1.125rem;font-weight:500;opacity:.9}.login__form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin-bottom:1.5rem;padding:1.5rem}.login__form-title{color:#1f2937;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.login__error{background:#ef44441a;border:1px solid #ef44444d;border-radius:.5rem;color:#ef4444;font-size:.875rem;margin-bottom:1rem;padding:.75rem;text-align:center}.login__submit{margin-top:.5rem;width:100%}.login__submit-loading{align-items:center;display:flex;gap:.5rem;justify-content:center}.login__footer{color:#fff;font-size:.875rem;opacity:.8;text-align:center}.login__footer p{margin:0}.login .form-group{margin-bottom:1.25rem}.login .form-group:last-of-type{margin-bottom:1.5rem}.login .form-label{color:#374151;font-weight:500}.login .input-field{background:#ffffffe6;border:1px solid #ffffff4d}.login .input-field:focus{background:#fff;border-color:#0095c8;box-shadow:0 0 0 3px #0095c81a}.login .input-field:disabled{opacity:.6}@media(max-width:767px){.login{padding:.75rem}.login__container{max-width:100%}.login__form{padding:1.25rem}}.dashboard{animation:fadeIn .3s ease-in-out forwards;opacity:0}.dashboard__header{margin-bottom:2rem;text-align:center}.dashboard__subtitle{color:#4b5563;font-size:1.125rem;margin-top:.5rem}.dashboard__stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(4,1fr)}@media(min-width:640px){.dashboard__stats{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.dashboard__stats{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.dashboard__stats{grid-template-columns:repeat(4,1fr)}}.dashboard__stats{margin-bottom:2rem}.dashboard__stat-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem;transition:transform .2s ease-in-out,color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.dashboard__stat-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.dashboard__stat-card{align-items:center;border-left:4px solid #0000;color:inherit;display:flex;gap:1rem;justify-content:flex-start;text-decoration:none;transition:all .2s ease-in-out}.dashboard__stat-card--primary{border-left-color:#0095c8}.dashboard__stat-card--primary .dashboard__stat-icon{background:#0095c81a;color:#0095c8}.dashboard__stat-card--accent{border-left-color:#ff8200}.dashboard__stat-card--accent .dashboard__stat-icon{background:#ff82001a;color:#ff8200}.dashboard__stat-card--success{border-left-color:#10b981}.dashboard__stat-card--success .dashboard__stat-icon{background:#10b9811a;color:#10b981}.dashboard__stat-card--info{border-left-color:#0095c8}.dashboard__stat-card--info .dashboard__stat-icon{background:#0095c81a;color:#0095c8}.dashboard__stat-card:hover{border-left-width:6px}.dashboard__stat-icon{align-items:center;border-radius:.75rem;display:flex;flex-shrink:0;height:60px;justify-content:center;width:60px}.dashboard__stat-content{flex:1 1}.dashboard__stat-title{color:#4b5563;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.dashboard__stat-value{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.dashboard__actions{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem;text-align:center}.dashboard__action-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1.5rem}.dashboard__error{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;color:#ef4444;padding:1.5rem;text-align:center}.dashboard__error p{font-size:1.125rem;margin-bottom:1rem}@media(max-width:767px){.dashboard__stats{grid-template-columns:1fr}.dashboard__stat-card{padding:1rem}.dashboard__stat-card__stat-icon{height:48px;width:48px}.dashboard__stat-card__stat-value{font-size:1.25rem}.dashboard__action-buttons{flex-direction:column;width:100%}.dashboard__action-buttons .btn{width:100%}}.search-filter{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin-bottom:1.5rem;padding:1.5rem}.search-filter__main{align-items:center;display:flex;gap:1rem;justify-content:space-between}@media(max-width:767px){.search-filter__main{align-items:stretch;flex-direction:column}}.search-filter__search{flex:1 1;max-width:400px}@media(max-width:767px){.search-filter__search{max-width:none}}.search-filter__search-input{align-items:center;display:flex;justify-content:flex-start;position:relative}.search-filter__search-icon{color:#9ca3af;left:.75rem;pointer-events:none;position:absolute;z-index:1}.search-filter__input{border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;line-height:1.5;padding:.5rem .75rem;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.search-filter__input:focus{border-color:#0095c8;box-shadow:0 0 0 3px #0095c81a;outline:none}.search-filter__input::placeholder{color:#9ca3af}.search-filter__input:disabled{background-color:#f9fafb;cursor:not-allowed}.search-filter__input{padding-left:2.5rem;padding-right:2.5rem}.search-filter__clear{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:0;position:absolute;right:.75rem}.search-filter__clear:hover{color:#4b5563}.search-filter__actions{align-items:center;display:flex;gap:.75rem;justify-content:flex-start}@media(max-width:767px){.search-filter__actions{justify-content:space-between}}.search-filter__toggle{border:1px solid #0000;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;justify-content:center;line-height:1.25;padding:.5rem 1rem;text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;-webkit-user-select:none;user-select:none}.search-filter__toggle:focus{box-shadow:0 0 0 3px #0095c81a;outline:none}.search-filter__toggle:disabled{cursor:not-allowed;opacity:.6}.search-filter__toggle{background-color:#e5e7eb;color:#1f2937}.search-filter__toggle:hover:not(:disabled){background-color:#d1d5db}.search-filter__toggle{align-items:center;display:flex;gap:.5rem;justify-content:flex-start;position:relative}.search-filter__toggle.active{background:#0095c8;color:#fff}.search-filter__badge{background:#ff8200;border-radius:50%;height:8px;position:absolute;right:-2px;top:-2px;width:8px}.search-filter__reset{align-items:center;border:1px solid #0000;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;justify-content:center;line-height:1.25;padding:.5rem 1rem;text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;-webkit-user-select:none;user-select:none}.search-filter__reset:focus{box-shadow:0 0 0 3px #0095c81a;outline:none}.search-filter__reset:disabled{cursor:not-allowed;opacity:.6}.search-filter__reset{background:#0000;color:#4b5563}.search-filter__reset:hover{color:#0095c8}.search-filter__expanded{animation:slideUp .3s ease-in-out forwards;border-top:1px solid #e5e7eb;margin-top:1rem;opacity:0;padding-top:1rem;transform:translateY(20px)}.search-filter__filters{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}@media(max-width:767px){.search-filter__filters{grid-template-columns:1fr}}.search-filter__filter{align-items:center;display:flex;flex-direction:column;gap:.5rem;justify-content:flex-start}.search-filter__filter-label{color:#374151;font-size:.875rem;font-weight:500}.search-filter__date,.search-filter__select,.search-filter__text{border:1px solid #d1d5db;border-radius:.5rem;line-height:1.5;padding:.5rem .75rem;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.search-filter__date:focus,.search-filter__select:focus,.search-filter__text:focus{border-color:#0095c8;box-shadow:0 0 0 3px #0095c81a;outline:none}.search-filter__date::placeholder,.search-filter__select::placeholder,.search-filter__text::placeholder{color:#9ca3af}.search-filter__date:disabled,.search-filter__select:disabled,.search-filter__text:disabled{background-color:#f9fafb;cursor:not-allowed}.search-filter__date,.search-filter__select,.search-filter__text{font-size:.875rem}.search-filter__select{cursor:pointer}.teacher-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem;transition:transform .2s ease-in-out,color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.teacher-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.teacher-card{position:relative;transition:all .2s ease-in-out}.teacher-card--inactive{background:#f9fafb;opacity:.7}.teacher-card__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.teacher-card__avatar{align-items:center;background:linear-gradient(135deg,#0095c8,#2fcaff);border-radius:50%;color:#fff;display:flex;font-size:1.125rem;font-weight:700;height:60px;justify-content:center;width:60px}.teacher-card__actions{position:relative}.teacher-card__menu-button{align-items:center;background:none;border:none;border-radius:.5rem;color:#9ca3af;cursor:pointer;display:flex;height:32px;justify-content:center;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:32px}.teacher-card__menu-button:hover{background:#f3f4f6;color:#4b5563}.teacher-card__menu{animation:fadeIn .3s ease-in-out forwards;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:160px;opacity:0;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.teacher-card__menu-item{background:none;border:none;color:#374151;cursor:pointer;display:block;font-size:.875rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.teacher-card__menu-item:hover{background:#f9fafb}.teacher-card__menu-item--danger{color:#ef4444}.teacher-card__menu-item--danger:hover{background:#ef44441a}.teacher-card__menu-item:disabled{cursor:not-allowed;opacity:.5}.teacher-card__content{flex:1 1}.teacher-card__name{color:#1f2937;display:block;font-size:1.125rem;font-weight:600;margin-bottom:.75rem;text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.teacher-card__name:hover{color:#0095c8}.teacher-card__info{margin-bottom:1rem}.teacher-card__position{color:#374151;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.teacher-card__department{color:#4b5563;font-size:.875rem}.teacher-card__stats{margin-bottom:1rem}.teacher-card__stat{align-items:center;display:flex;justify-content:space-between;padding:.5rem 0}.teacher-card__stat-label{color:#4b5563;font-size:.875rem}.teacher-card__stat-value{color:#0095c8;font-size:.875rem;font-weight:600}.teacher-card__status{align-items:center;display:flex;justify-content:flex-start;margin-top:auto}.teacher-card__overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}@media(max-width:767px){.teacher-card__avatar{font-size:1rem;height:48px;width:48px}.teacher-card__name{font-size:1rem}.teacher-card__menu{min-width:140px}}.pagination{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-top:1.5rem}@media(max-width:767px){.pagination{align-items:center;flex-direction:column;text-align:center}}.pagination__info{color:#4b5563;font-size:.875rem;font-weight:500}.pagination__nav{gap:.5rem}.pagination__nav,.pagination__pages{align-items:center;display:flex;justify-content:center}.pagination__pages{gap:.25rem}.pagination__button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;height:40px;justify-content:center;min-width:40px;padding:0 .5rem;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.pagination__button:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.pagination__button:focus{box-shadow:0 0 0 2px #0095c833;outline:none}.pagination__button:disabled{cursor:not-allowed;opacity:.5}.pagination__button:disabled:hover{background:#fff;border-color:#d1d5db}.pagination__button--active{background:#0095c8;border-color:#0095c8;color:#fff}.pagination__button--active:hover{background:#004962;border-color:#004962}.pagination__button--next,.pagination__button--prev,.pagination__dots{align-items:center;display:flex;justify-content:center}.pagination__dots{color:#9ca3af;font-weight:700;height:40px;min-width:40px}@media(max-width:767px){.pagination__info{order:2}.pagination__nav{order:1}.pagination__button{font-size:.75rem}.pagination__button,.pagination__dots{height:36px;min-width:36px}}.teacher-list{animation:fadeIn .3s ease-in-out forwards;opacity:0}.teacher-list__grid{grid-gap:1.5rem;display:grid;gap:1.5rem;margin-bottom:1.5rem}.teacher-list__grid--grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}@media(min-width:640px){.teacher-list__grid--grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.teacher-list__grid--grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.teacher-list__grid--grid{grid-template-columns:repeat(3,1fr)}}.teacher-list__grid--list{grid-template-columns:1fr}.teacher-list__item{animation:slideUp .3s ease-in-out forwards;opacity:0;transform:translateY(20px)}.teacher-list__loading{align-items:center;display:flex;justify-content:center;padding:1rem}.teacher-list__empty{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin:0 auto;max-width:400px;padding:2rem;text-align:center}.teacher-list__empty-icon{align-items:center;background:#f3f4f6;border-radius:50%;color:#9ca3af;display:flex;height:80px;justify-content:center;margin:0 auto 1rem;width:80px}.teacher-list__empty-title{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.teacher-list__empty-description{color:#6b7280;font-size:.875rem;line-height:1.5}@media(max-width:767px){.teacher-list__grid{gap:1rem}.teacher-list__grid--grid{grid-template-columns:1fr}.teacher-list__empty{padding:1.5rem}.teacher-list__empty-icon{height:64px;width:64px}.teacher-list__empty-title{font-size:1.125rem}}.teacher-form{max-width:600px}.teacher-form__error{background:#ef44441a;border:1px solid #ef44444d;border-radius:.5rem;color:#ef4444;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.teacher-form__row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}@media(max-width:767px){.teacher-form__row{gap:0;grid-template-columns:1fr}}.teacher-form__textarea{font-family:inherit;min-height:100px;resize:vertical}.teacher-form__checkbox{align-items:center;cursor:pointer;display:flex;gap:.75rem;justify-content:flex-start;-webkit-user-select:none;user-select:none}.teacher-form__checkbox input[type=checkbox]{accent-color:#0095c8;cursor:pointer;height:18px;width:18px}.teacher-form__checkbox-label{color:#374151;font-size:.875rem}.teacher-form__actions{align-items:center;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}@media(max-width:767px){.teacher-form__actions{flex-direction:column-reverse}.teacher-form__actions .btn{width:100%}}.teacher-form__loading{align-items:center;display:flex;gap:.5rem;justify-content:center}.teacher-form .input-field--error{border-color:#ef4444}.teacher-form .input-field--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.teacher-form .form-group{margin-bottom:1rem}.teacher-form .form-error{color:#ef4444;font-size:.75rem;margin-top:.25rem}.modal-backdrop{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1050}.modal{animation:slideUp .3s ease-out;background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.modal--small{max-width:400px;width:100%}.modal--medium{max-width:600px;width:100%}.modal--large{max-width:800px;width:100%}.modal--full{max-height:95vh;max-width:1200px;width:95%}.modal__header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.modal__title{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.modal__close{align-items:center;background:none;border:none;border-radius:.5rem;color:#9ca3af;cursor:pointer;display:flex;height:32px;justify-content:center;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:32px}.modal__close:hover{background:#f3f4f6;color:#4b5563}.modal__close:focus{box-shadow:0 0 0 2px #0095c8;outline:none}.modal__body{flex:1 1;overflow-y:auto;padding:1.5rem}@media(max-width:767px){.modal{margin:.5rem;max-height:calc(100vh - 1rem)}.modal__header{padding:1rem}.modal__title{font-size:1.125rem}.modal__body{padding:1rem}.modal--full,.modal--large,.modal--medium,.modal--small{max-width:none;width:100%}}.teachers-page{animation:fadeIn .3s ease-in-out forwards;opacity:0}.teachers-page__header{margin-bottom:1.5rem}.teachers-page__title-section{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}@media(max-width:767px){.teachers-page__title-section{align-items:stretch;flex-direction:column;gap:.75rem}}.teachers-page__error{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;color:#ef4444;margin-bottom:1.5rem;padding:1.5rem;text-align:center}.teachers-page__error p{font-size:1.125rem;margin-bottom:1rem}@media(max-width:767px){.teachers-page .page-title{margin-bottom:0;text-align:center}.teachers-page__title-section .btn{width:100%}}.category-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem;transition:transform .2s ease-in-out,color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.category-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.category-card{position:relative;transition:all .2s ease-in-out}.category-card__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.category-card__icon{align-items:center;background:linear-gradient(135deg,#ff8200,#ffb466);border-radius:.75rem;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.category-card__actions{position:relative}.category-card__menu-button{align-items:center;background:none;border:none;border-radius:.5rem;color:#9ca3af;cursor:pointer;display:flex;height:32px;justify-content:center;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:32px}.category-card__menu-button:hover{background:#f3f4f6;color:#4b5563}.category-card__menu{animation:fadeIn .3s ease-in-out forwards;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:160px;opacity:0;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.category-card__menu-item{background:none;border:none;color:#374151;cursor:pointer;display:block;font-size:.875rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.category-card__menu-item:hover{background:#f9fafb}.category-card__menu-item--danger{color:#ef4444}.category-card__menu-item--danger:hover{background:#ef44441a}.category-card__content{flex:1 1}.category-card__name{color:#1f2937;font-size:1.125rem;font-weight:600;line-height:1.3;margin-bottom:.75rem}.category-card__description{color:#4b5563;font-size:.875rem;line-height:1.5;margin-bottom:1rem}.category-card__stats{display:flex;flex-direction:column;gap:.5rem}.category-card__stat{align-items:center;display:flex;justify-content:space-between}.category-card__stat-label{color:#4b5563;font-size:.875rem}.category-card__stat-value{color:#ff8200;font-size:.875rem;font-weight:600}.category-card__overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}@media(max-width:767px){.category-card__icon{height:40px;width:40px}.category-card__name{font-size:1rem}.category-card__menu{min-width:140px}}.category-list{animation:fadeIn .3s ease-in-out forwards;opacity:0}.category-list__grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}@media(min-width:640px){.category-list__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.category-list__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.category-list__grid{grid-template-columns:repeat(2,1fr)}}.category-list__grid{margin-bottom:1.5rem}.category-list__item{animation:slideUp .3s ease-in-out forwards;opacity:0;transform:translateY(20px)}.category-list__loading{align-items:center;display:flex;justify-content:center;padding:1rem}.category-list__empty{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin:0 auto;max-width:400px;padding:2rem;text-align:center}.category-list__empty-icon{align-items:center;background:#f3f4f6;border-radius:50%;color:#9ca3af;display:flex;height:80px;justify-content:center;margin:0 auto 1rem;width:80px}.category-list__empty-title{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.category-list__empty-description{color:#6b7280;font-size:.875rem;line-height:1.5}@media(max-width:767px){.category-list__grid{gap:1rem;grid-template-columns:1fr}.category-list__empty{padding:1.5rem}.category-list__empty-icon{height:64px;width:64px}.category-list__empty-title{font-size:1.125rem}}.category-form{max-width:500px}.category-form__error{background:#ef44441a;border:1px solid #ef44444d;border-radius:.5rem;color:#ef4444;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.category-form__textarea{font-family:inherit;min-height:100px;resize:vertical}.category-form__help{color:#6b7280;font-size:.75rem;font-style:italic;margin-top:.25rem}.category-form__actions{align-items:center;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}@media(max-width:767px){.category-form__actions{flex-direction:column-reverse}.category-form__actions .btn{width:100%}}.category-form__loading{align-items:center;display:flex;gap:.5rem;justify-content:center}.category-form .input-field--error{border-color:#ef4444}.category-form .input-field--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.category-form .form-group{margin-bottom:1rem}.category-form .form-error{color:#ef4444;font-size:.75rem;margin-top:.25rem}.categories-page{animation:fadeIn .3s ease-in-out forwards;opacity:0}.categories-page__header{margin-bottom:1.5rem}.categories-page__title-section{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}@media(max-width:767px){.categories-page__title-section{align-items:stretch;flex-direction:column;gap:.75rem}}.categories-page__error{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;color:#ef4444;margin-bottom:1.5rem;padding:1.5rem;text-align:center}.categories-page__error p{font-size:1.125rem;margin-bottom:1rem}@media(max-width:767px){.categories-page .page-title{margin-bottom:0;text-align:center}.categories-page__title-section .btn{width:100%}}.entry-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem;transition:transform .2s ease-in-out,color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.entry-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.entry-card{position:relative;transition:all .2s ease-in-out}.entry-card__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.entry-card__points{align-items:center;background:linear-gradient(135deg,#10b981,#14e8a2);border-radius:.75rem;color:#fff;display:flex;flex-direction:column;justify-content:flex-start;min-width:80px;padding:.75rem}.entry-card__points-value{font-size:1.25rem;font-weight:700;line-height:1}.entry-card__points-label{font-size:.75rem;margin-top:.25rem;opacity:.9}.entry-card__actions{position:relative}.entry-card__menu-button{align-items:center;background:none;border:none;border-radius:.5rem;color:#9ca3af;cursor:pointer;display:flex;height:32px;justify-content:center;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:32px}.entry-card__menu-button:hover{background:#f3f4f6;color:#4b5563}.entry-card__menu{animation:fadeIn .3s ease-in-out forwards;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:160px;opacity:0;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.entry-card__menu-item{background:none;border:none;color:#374151;cursor:pointer;display:block;font-size:.875rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.entry-card__menu-item:hover{background:#f9fafb}.entry-card__menu-item--danger{color:#ef4444}.entry-card__menu-item--danger:hover{background:#ef44441a}.entry-card__content{flex:1 1}.entry-card__description{color:#1f2937;font-size:1rem;font-weight:600;line-height:1.4;margin-bottom:1rem}.entry-card__meta{margin-bottom:1rem}.entry-card__category,.entry-card__date,.entry-card__teacher{color:#4b5563;font-size:.875rem;margin-bottom:.5rem}.entry-card__category strong,.entry-card__date strong,.entry-card__teacher strong{color:#374151}.entry-card__notes{background:#f9fafb;border-left:3px solid #ff8200;border-radius:.5rem;color:#4b5563;font-size:.875rem;font-style:italic;padding:.75rem}.entry-card__notes strong{color:#374151;font-style:normal}.entry-card__overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}@media(max-width:767px){.entry-card__points{min-width:70px;padding:.5rem}.entry-card__points-value{font-size:1.125rem}.entry-card__description{font-size:.875rem}.entry-card__menu{min-width:140px}}.entry-list{animation:fadeIn .3s ease-in-out forwards;opacity:0}.entry-list__grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}@media(min-width:640px){.entry-list__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.entry-list__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.entry-list__grid{grid-template-columns:repeat(2,1fr)}}.entry-list__grid{margin-bottom:1.5rem}.entry-list__item{animation:slideUp .3s ease-in-out forwards;opacity:0;transform:translateY(20px)}.entry-list__loading{align-items:center;display:flex;justify-content:center;padding:1rem}.entry-list__empty{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin:0 auto;max-width:400px;padding:2rem;text-align:center}.entry-list__empty-icon{align-items:center;background:#f3f4f6;border-radius:50%;color:#9ca3af;display:flex;height:80px;justify-content:center;margin:0 auto 1rem;width:80px}.entry-list__empty-title{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.entry-list__empty-description{color:#6b7280;font-size:.875rem;line-height:1.5}@media(max-width:767px){.entry-list__grid{gap:1rem;grid-template-columns:1fr}.entry-list__empty{padding:1.5rem}.entry-list__empty-icon{height:64px;width:64px}.entry-list__empty-title{font-size:1.125rem}}.entry-form{max-width:700px}.entry-form__error{background:#ef44441a;border:1px solid #ef44444d;border-radius:.5rem;color:#ef4444;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.entry-form__row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}@media(max-width:767px){.entry-form__row{gap:0;grid-template-columns:1fr}}.entry-form__textarea{font-family:inherit;min-height:100px;resize:vertical}.entry-form__actions{align-items:center;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}@media(max-width:767px){.entry-form__actions{flex-direction:column-reverse}.entry-form__actions .btn{width:100%}}.entry-form__loading{align-items:center;display:flex;gap:.5rem;justify-content:center}.entry-form .input-field--error{border-color:#ef4444}.entry-form .input-field--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.entry-form .form-group{margin-bottom:1rem}.entry-form .form-error{color:#ef4444;font-size:.75rem;margin-top:.25rem}.entries-page{animation:fadeIn .3s ease-in-out forwards;opacity:0}.entries-page__header{margin-bottom:1.5rem}.entries-page__title-section{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}@media(max-width:767px){.entries-page__title-section{align-items:stretch;flex-direction:column;gap:.75rem}}.entries-page__error{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;color:#ef4444;margin-bottom:1.5rem;padding:1.5rem;text-align:center}.entries-page__error p{font-size:1.125rem;margin-bottom:1rem}@media(max-width:767px){.entries-page .page-title{margin-bottom:0;text-align:center}.entries-page__title-section .btn{width:100%}}.reports-page{animation:fadeIn .3s ease-in-out forwards;opacity:0}.reports-page__header{margin-bottom:1.5rem}.reports-page__description{color:#4b5563;font-size:1.125rem;margin-top:.5rem}.reports-page__content{margin-bottom:2rem}.reports-page__grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1.5rem}.reports-page__item{border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;transition:all .2s ease-in-out}.reports-page__item:hover{border-color:#0095c8;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.reports-page__item h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin-bottom:.75rem}.reports-page__item p{color:#4b5563;line-height:1.5;margin-bottom:1rem}@media(max-width:767px){.reports-page__grid{gap:1rem;grid-template-columns:1fr}.reports-page__item{padding:1rem}}.App{background:#f9fafb;display:flex;flex-direction:column;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;color:#1f2937;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}#root{display:flex;flex-direction:column;min-height:100vh}.main-container{display:flex;flex:1 1;flex-direction:column}.content-wrapper{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.page-title{color:#1f2937;font-size:1.875rem;font-weight:700;margin-bottom:1.5rem}.section-title{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem}.btn{align-items:center;border:1px solid #0000;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;justify-content:center;line-height:1.25;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.btn:focus{box-shadow:0 0 0 3px #0095c81a;outline:none}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:#0095c8;color:#fff}.btn-primary:hover:not(:disabled){background-color:#007bb3}.btn-secondary{background-color:#e5e7eb;color:#1f2937}.btn-secondary:hover:not(:disabled){background-color:#d1d5db}.btn-accent{background-color:#ff8200;color:#fff}.btn-accent:hover:not(:disabled){background-color:#e66f00}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover:not(:disabled){background-color:#059669}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-sm{font-size:.75rem;padding:.375rem .75rem}.btn-lg{font-size:1.125rem;padding:.75rem 1.5rem}.input-field{border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;line-height:1.5;padding:.5rem .75rem;transition:all .2s ease-in-out;width:100%}.input-field:focus{border-color:#0095c8;box-shadow:0 0 0 3px #0095c81a;outline:none}.input-field::placeholder{color:#9ca3af}.input-field:disabled{background-color:#f9fafb;cursor:not-allowed}.form-group{margin-bottom:1rem}.form-label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-error{color:#ef4444;font-size:.75rem;margin-top:.25rem}.table-container{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;overflow-x:auto}.table{border-collapse:initial;border-spacing:0;width:100%}.table-header{background-color:#f9fafb}.table-header-cell{color:#6b7280;font-size:.75rem;font-weight:500;letter-spacing:.05em;padding:.75rem 1.5rem;text-align:left;text-transform:uppercase}.table-row{transition:background-color .15s ease-in-out}.table-row:hover{background-color:#f9fafb}.table-cell{color:#111827;font-size:.875rem;padding:1rem 1.5rem;white-space:nowrap}.status-badge{border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:600;padding:.25rem .5rem}.status-active{background-color:#d1fae5;color:#065f46}.status-inactive{background-color:#fee2e2;color:#991b1b}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#0095c8}.fade-in{animation:fadeIn .3s ease-in-out}.slide-up{animation:slideUp .3s ease-in-out}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.content-wrapper{padding:1rem}.page-title{font-size:1.5rem}.table-container{font-size:.875rem}}
/*# sourceMappingURL=main.baf3f2d7.css.map*/