@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&display=swap);.react-calendar{background:#fff;border:1px solid #a0a096;font-family:Arial,Helvetica,sans-serif;line-height:1.125em;max-width:100%;width:350px}.react-calendar--doubleView{width:700px}.react-calendar--doubleView .react-calendar__viewContainer{display:flex;margin:-.5em}.react-calendar--doubleView .react-calendar__viewContainer>*{margin:.5em;width:50%}.react-calendar,.react-calendar *,.react-calendar :after,.react-calendar :before{box-sizing:border-box}.react-calendar button{border:0;margin:0;outline:none}.react-calendar button:enabled:hover{cursor:pointer}.react-calendar__navigation{display:flex;height:44px;margin-bottom:1em}.react-calendar__navigation button{background:none;min-width:44px}.react-calendar__navigation button:disabled{background-color:#f0f0f0}.react-calendar__navigation button:enabled:focus,.react-calendar__navigation button:enabled:hover{background-color:#e6e6e6}.react-calendar__month-view__weekdays{font:inherit;font-size:.75em;font-weight:700;text-align:center;text-transform:uppercase}.react-calendar__month-view__weekdays__weekday{padding:.5em}.react-calendar__month-view__weekNumbers .react-calendar__tile{align-items:center;display:flex;font:inherit;font-size:.75em;font-weight:700;justify-content:center}.react-calendar__month-view__days__day--weekend{color:#d10000}.react-calendar__century-view__decades__decade--neighboringCentury,.react-calendar__decade-view__years__year--neighboringDecade,.react-calendar__month-view__days__day--neighboringMonth{color:#757575}.react-calendar__century-view .react-calendar__tile,.react-calendar__decade-view .react-calendar__tile,.react-calendar__year-view .react-calendar__tile{padding:2em .5em}.react-calendar__tile{background:none;font:inherit;font-size:.833em;max-width:100%;padding:10px 6.6667px;text-align:center}.react-calendar__tile:disabled{background-color:#f0f0f0;color:#ababab}.react-calendar__century-view__decades__decade--neighboringCentury:disabled,.react-calendar__decade-view__years__year--neighboringDecade:disabled,.react-calendar__month-view__days__day--neighboringMonth:disabled{color:#cdcdcd}.react-calendar__tile:enabled:focus,.react-calendar__tile:enabled:hover{background-color:#e6e6e6}.react-calendar__tile--now{background:#ffff76}.react-calendar__tile--now:enabled:focus,.react-calendar__tile--now:enabled:hover{background:#ffffa9}.react-calendar__tile--hasActive{background:#76baff}.react-calendar__tile--hasActive:enabled:focus,.react-calendar__tile--hasActive:enabled:hover{background:#a9d4ff}.react-calendar__tile--active{background:#006edc;color:#fff}.react-calendar__tile--active:enabled:focus,.react-calendar__tile--active:enabled:hover{background:#1087ff}.react-calendar--selectRange .react-calendar__tile--hover{background-color:#e6e6e6}.main-header{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;font-family:Poppins,sans-serif;height:70px;justify-content:space-between;padding:10px 28px;position:relative;z-index:1000}.header-left,.main-header{align-items:center;display:flex}.header-left{gap:20px}.logo{border-radius:10px;color:#fff;font-size:18px;font-weight:600;height:38px;justify-content:center;width:38px}.logo,.main-nav{align-items:center;background:linear-gradient(135deg,#102f74,#1d4ed8);display:flex}.main-nav{border-radius:50px;gap:25px;left:50%;padding:10px 25px;position:absolute;top:50%;transform:translate(-50%,-50%)}.active-nav{background:#e9efff!important;color:#0056d6!important;font-weight:600}.nav-item{border-radius:30px;color:#e7edf7;font-size:14px;font-weight:600;padding:8px 18px;text-decoration:none;transition:.25s ease}.nav-item:hover{background:#e9efff;color:#0056d6}.dropdown-container{position:relative}.dropdown-menu.work-menu{background:#fff;border-radius:20px;box-shadow:0 15px 35px #00000014,0 5px 10px #00000008;left:50%;padding:12px;position:absolute;top:115%;transform:translateX(-50%);width:250px;z-index:99999}.dropdown-item{border-radius:12px;gap:12px;padding:12px;transition:.24s ease}.dropdown-item:hover{background:#0073ff14;transform:translateX(5px)}.dropdown-item a{color:#222;font-size:15px;font-weight:500;gap:12px;text-decoration:none;width:100%}.dropdown-item a,.user-profile{align-items:center;display:flex}.user-profile{background:#fff;border-radius:30px;cursor:pointer;gap:10px;padding:6px 12px}.profile-dropdown{top:65px;width:230px;z-index:9999}.calendar-container{position:relative}.icon-button{background:#0000;padding:6px}.calendar-dropdown{animation:fadeIn .25s ease-in-out;background:#fff;border-radius:12px;box-shadow:0 6px 15px #0000002e;padding:12px;position:absolute;right:0;top:45px;width:320px;z-index:100}.custom-calendar{border:none!important;width:100%}.custom-calendar .react-calendar__tile--active{background:#673ab7!important;border-radius:10px;color:#fff!important}.custom-calendar .react-calendar__tile:hover{background:#e8e8e8!important;border-radius:10px}.legend{border-top:1px solid #ececec;display:flex;font-size:12px;justify-content:space-between;margin-top:8px;padding:4px 0}.selected-events-box{background:#fafafa;border:1px solid #e0e0e0;border-radius:12px;margin-top:10px;padding:12px}.selected-events-header{align-items:center;display:flex;justify-content:space-between}.modal-close-btn{background:none;border:none;cursor:pointer;font-size:18px}.event-box{align-items:center;background:#fff;border:1px solid #ddd;border-radius:10px;display:flex;justify-content:space-between;margin-top:8px;padding:10px}.event-box b{font-size:14px}.event-type{color:#777;font-size:11px;margin:0}.no-events-text{color:#888;font-size:14px;margin-top:8px;text-align:center}.add-event-btn,.save-btn{background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;margin-top:10px;padding:10px;width:100%}.delete-event-btn{background:#ff7070;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:14px;padding:4px 7px}.cancel-btn{background:#bbb;border-radius:6px;padding:8px 12px}.add-event-modal{background:#fff;border:1px solid #ddd;border-radius:12px;margin-top:10px;padding:12px}.event-input,.event-select{border:1px solid #ccc;border-radius:6px;margin-top:8px;padding:8px;width:100%}.event-modal-actions{display:flex;justify-content:space-between;margin-top:12px}.notification-dropdown{animation:notifFade .25s ease-in-out;background:#fff;border-radius:18px;box-shadow:0 6px 20px #00000026;font-family:Poppins,sans-serif;padding:14px;position:absolute;right:80px;top:60px;width:320px;z-index:2000}@keyframes notifFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.header-right{gap:16px}.header-right,.icon-button{align-items:center;display:flex}.icon-button{background:#000;border:none;border-radius:50%;color:#fff;cursor:pointer;height:38px;justify-content:center;transition:all .3s;width:38px}.icon-button:hover{opacity:.85}.user-info{display:flex;flex-direction:column;line-height:1.2}.user-name{color:#333;font-size:14px;font-weight:600}.user-role{color:#888;font-size:12px}.notif-card{background:#f8f9fc;border-radius:12px;margin-bottom:10px;padding:12px;transition:background .25s ease}.notif-card:hover{background:#eef4ff}.notif-type{color:#111;font-size:14px;font-weight:600;margin-bottom:4px}.notif-card p{color:#444;font-size:13px;margin:4px 0}.notif-card a{color:#005eff;font-weight:500;text-decoration:none}.notif-card a:hover{text-decoration:underline}.notif-time{color:#777;font-size:12px;text-align:right}user-profile{align-items:center;background:#fff;border-radius:30px;box-shadow:0 2px 6px #00000014;cursor:pointer;display:flex;gap:10px;padding:6px 12px;transition:background .3s ease}.user-profile:hover{background:#f9f9f9}.profile-avatar{border:2px solid #e6e6e6;border-radius:50%;height:38px;object-fit:cover;width:38px}.profile-dropdown{background:#fff;border-radius:12px;box-shadow:0 5px 15px #00000026;overflow:hidden;position:absolute;right:10px;top:60px;width:240px;z-index:1000}.profile-header{align-items:center;border-bottom:1px solid #eee;display:flex;gap:10px;padding:12px}.profile-avatar-large{border-radius:50%;height:50px;object-fit:cover;width:50px}.dropdown-menu{display:flex;flex-direction:column}.dropdown-item{align-items:center;cursor:pointer;display:flex;gap:10px;padding:10px 16px;transition:background .2s ease}.dropdown-item:hover{background:#f3f4f6}.dropdown-item.logout{color:#e63946}.navbar-page{padding:8px 0;transition:.3s ease;width:100%}.navbar-page.white-header{background:#fff;box-shadow:0 2px 8px #0000001a}.navbar-container{background:#fff;border-radius:14px;box-shadow:0 3px 10px #0000001f;margin-bottom:12px;padding:12px;width:100%}.navbar-scroll{overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scrollbar-width:none;white-space:nowrap;width:100%}.navbar-scroll::-webkit-scrollbar{display:none}.navbar-secondary{display:inline-flex;gap:10px}.secondary-nav-item{align-items:center;background:linear-gradient(135deg,#102f74,#1d4ed8);border:1px solid #0d47a1;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;height:50px;justify-content:center;transition:.3s ease;white-space:nowrap;width:150px}.secondary-nav-item:hover{background:#1565c0}.secondary-nav-item.active{background:#fff;border:1px solid #0d47a1;box-shadow:0 2px 6px #00000040;color:#0d47a1;font-weight:700}.overlay{background:#0003;inset:0;position:fixed;z-index:10}.popup-center{background:#fff;border-radius:12px;left:50%;padding:20px;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:20}.nextperiod-wrapper{align-items:flex-start;display:flex;height:auto;justify-content:center;position:fixed;right:0;top:10%;width:450px;z-index:1000}.nextperiod-card{animation:slideIn .4s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 8px 25px #0000001a;font-family:Poppins,sans-serif;padding:20px 24px;width:380px}.legend-bar{background:#f5f5f5;border-radius:10px;color:#333;font-size:.9rem;font-weight:500;justify-content:space-between;margin-bottom:14px;padding:8px 14px}.legend-bar,.legend-item{align-items:center;display:flex}.legend-item{gap:6px}.legend-dot{border-radius:50%;height:12px;width:12px}.legend-item.current .legend-dot{background-color:#4caf50}.legend-item.next .legend-dot{background-color:#ffc107}.legend-item.normal .legend-dot{background-color:#e0e0e0}.nextperiod-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.nextperiod-header h2{color:#111;font-size:1.4rem;font-weight:600}.nextperiod-topbar{background-color:#1c1c1c;border-radius:40px;color:#fff;font-weight:500;margin-bottom:10px}.nextperiod-row,.nextperiod-topbar{display:flex;font-size:.95rem;justify-content:space-between;padding:12px 18px}.nextperiod-row{align-items:center;border-bottom:1px solid #eee;border-radius:10px;color:#222;letter-spacing:.3px;margin-bottom:6px;transition:background .3s ease}.nextperiod-row.current{background-color:#c9f7d5;color:#0c6b2f;font-weight:600}.nextperiod-row.next{background-color:#fff2cc;color:#856404;font-weight:600}.nextperiod-empty{color:#666;padding:15px;text-align:center}.nextperiod-table{max-height:none;overflow:visible}@media (max-width:480px){.nextperiod-card{width:90%}}body{font-family:Arial,sans-serif;overflow-y:auto}*{scrollbar-color:#3b82f6 #f1f1f1;scrollbar-width:thin}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:10px}::-webkit-scrollbar-track{background:#f1f1f1}.periods{overflow-x:auto;padding-bottom:5px;scroll-behavior:smooth}.period{flex-shrink:0;min-width:140px;padding:8px 12px}.student-marks{display:flex;flex-direction:column;max-height:450px;overflow-y:auto}.student-marks td,.student-marks th{border-bottom:1px solid #e5e7eb;padding:10px;text-align:center}.events-card,.leave-card{max-height:450px;overflow-y:auto}.dashboard-container,.dashboard-wrapper{overflow:hidden!important}.dashboard-container{padding:20px 30px}.page-title{font-size:26px;margin-bottom:20px}.attendance-card,.today-class-card{height:100%}.top-layout{grid-gap:20px;align-items:stretch!important;gap:20px;grid-template-columns:2fr 1.5fr 1fr}.greeting-card{background:#1b54e7!important;border-radius:12px;height:150%;padding:25px}.greeting-card h2{font-size:26px;margin-bottom:8px}.notice{background:#ffffff40;border-radius:8px;font-weight:700;margin-bottom:auto;padding:15px}.card{border:1px solid #e2e2e2;border-radius:12px;box-shadow:0 2px 5px #0000000d;padding:18px}.bottom-sections{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 1fr 1fr;margin-top:20px}.student-marks{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:18px}.table-header{align-items:center;display:flex;justify-content:space-between}.table-header h3{font-size:16px;font-weight:600}.filters{color:#555;font-size:13px;gap:15px}.filters label{cursor:pointer}.student-marks table{border-collapse:collapse;margin-top:12px;width:100%}.student-marks th{border-bottom:2px solid #e5e7eb;color:#555;font-size:13px;text-align:left}.student-marks td,.student-marks th{justify-content:center;padding:12px 10px}.student-marks td{border-bottom:1px solid #e5e7eb;color:#333;font-size:14px}.status.pass{background:#32d74b;border-radius:6px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.filters{align-items:center;display:flex;gap:12px}.filters select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#f5f7ff;border:1px solid #c7d2f3;border-radius:25px;color:#0f1a35;cursor:pointer;font-size:14px;font-weight:600;padding:10px 35px 10px 18px}.filters select::-ms-expand{display:none}.filters select{background-position:right 12px center;background-repeat:no-repeat;background-size:14px;position:relative}.filters select:hover{border-color:#8ea6e8}.filters select:focus{border-color:#4b6fe5;outline:none}.table-bottom{color:#555;display:flex;font-size:13px;justify-content:space-between;margin-top:12px}.pager{color:#1555d1;cursor:pointer;display:flex;gap:15px}.pager span:hover{text-decoration:underline}.event-row{background:#f7f7f7;border:1px solid #ececec;border-radius:8px;gap:10px;margin-bottom:10px;padding:10px}.icon-circle{background:#dae4ff;font-size:20px;padding:10px}.leave-row{background:#fafafa;border:1px solid #ececec;border-radius:8px;margin-bottom:10px;padding:12px}.badge{border-radius:6px;padding:6px 10px}.badge.pending{background:#007aff}.badge.approve{background:#32d74b}.badge.decline{background:#ff3b30}.today-class-card .header-row{align-items:center;display:flex;justify-content:space-between}.icons{align-items:center;display:flex;gap:10px}.periods{gap:12px;margin-top:15px}.period{border-radius:8px;color:#fff;min-width:100px;padding:7px 14px;text-align:center}.attendance-card .header-row{display:flex;justify-content:space-between}.days{gap:8px;margin-top:12px}.day{background:#32d74b;border-radius:6px;color:#fff;font-weight:700;padding:8px 12px}.range{margin-top:12px}.teacher-strip{align-items:center;border-radius:12px;display:flex;justify-content:space-between;margin-top:-10px;padding:14px}.teacher-strip img{border-radius:50%;height:48px;width:48px}.teacher-id{background:#ffffff40;border-radius:6px;padding:4px 8px}.edit-btn{background:#1555d1;border-radius:6px;font-weight:600;padding:8px 14px}.dashboard-wrapper{background:#f7f8fc;min-height:100vh}.dashboard-container{padding:15px 25px}.page-title{font-size:22px;font-weight:600;margin-bottom:15px}.top-layout{grid-gap:15px;align-items:start;display:grid;gap:15px;grid-template-columns:1.6fr 1.3fr 1fr}.greeting-card{background:#1b54e7;border-radius:10px;color:#fff;padding:18px}.greeting-card h2{font-size:20px;margin-bottom:5px}.greeting-card p{font-size:13px}.notice{border-radius:6px;font-size:12px;margin-top:30px;padding:8px}.card{background:#fff;border:1px solid #ddd;border-radius:10px;box-shadow:0 1px 4px #0000000d;padding:12px}.today-class-card h3{font-size:15px}.periods{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.period{border-radius:6px;min-width:80px;padding:4px 10px}.period .time{font-size:10px;font-weight:600}.period .cls{font-size:9px}.red{background:#ff3b30}.pink{background:#ff2d55}.blue{background:#007aff}.indigo{background:#5856d6}.navy{background:#003e8a}.attendance-card h3{font-size:15px}.small{font-size:11px}.days{display:flex;gap:5px;margin-top:8px}.day{font-size:11px;padding:6px 8px}.teacher-strip{background:#0e133d;border-radius:10px;color:#fff;grid-column:2/4;margin-top:-8px;padding:10px 14px}.teacher-strip img{height:40px;width:40px}.teacher-id{font-size:10px;padding:3px 6px}.teacher-name{font-size:13px}.edit-btn,.teacher-classes{font-size:12px}.edit-btn{border-radius:5px;padding:6px 12px}.pagination{font-size:10px;font-weight:600;margin-top:15px}.pagination .prev{background:#d9e1ee;cursor:not-allowed;-webkit-user-select:none;user-select:none}.pagination .next,.pagination .prev{border-radius:25px;color:#fff;padding:8px 18px}.pagination .next{background:#1473ff;cursor:pointer}.events-card{background:#fff;border:1px solid #e2e6ed;border-radius:12px;padding:18px}.events-card h3{font-size:16px;font-weight:600;margin-bottom:12px}.event-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:12px;padding:10px 0}.event-row:last-child{border-bottom:none}.icon-circle{align-items:center;background:#eaf1ff;border-radius:10px;display:flex;font-size:18px;height:35px;justify-content:center;width:35px}.event-title{color:#1e293b;font-size:14px;font-weight:600}.event-date{color:#64748b;font-size:12px;margin-top:2px}.leave-card{background:#fff;border:1px solid #e2e6ed;border-radius:12px;padding:18px}.leave-card .header-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.leave-card h3{font-size:16px;font-weight:600}.small{color:#64748b;font-size:13px}.leave-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:12px 0}.leave-row:last-child{border-bottom:none}.leave-title{color:#1e293b;font-size:14px;font-weight:600}.leave-date{color:#64748b;font-size:12px;margin-top:2px}.badge{border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:6px 12px}.badge.pending{background:#0ea5e9}.badge.approve{background:#22c55e}.badge.decline{background:#ef4444}@media (max-width:1000px){.top-layout{grid-template-columns:1fr}}.assignment-container{align-items:flex-start;background:#f9fafb;display:flex;justify-content:center;min-height:100vh;overflow-y:auto;padding:40px 20px}.assignment-box{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000000f;margin-top:40px;max-width:95%;padding:25px 30px 30px;position:relative;width:90%}.add-task-btn{align-items:center;background:linear-gradient(135deg,#0043ff,#06f);border:none;border-radius:30px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:6px;padding:10px 20px;position:absolute;right:80px;top:25px;transition:.3s ease}.add-task-btn:hover{background:linear-gradient(135deg,#0032cc,#004de6);transform:translateY(-2px)}.top-filters{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;margin-top:50px;padding-bottom:12px}.date-filters{display:flex;gap:10px}.filter-btn{background:#d1d5db;border-radius:20px;font-size:.85rem;padding:7px 16px}.select-filter{background:#fff;border:1px solid #cbd5e1;border-radius:8px;cursor:pointer;padding:8px 14px}.assignment-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-top:10px;overflow:hidden}.assignment-table-wrapper table{border-collapse:collapse;text-align:left;width:100%}thead tr{background:#2d2d2d}thead th{font-weight:700;padding:12px 16px}tbody td{border:1px solid #e2e8f0;font-size:.95rem;padding:12px 16px}tbody tr:nth-child(odd){background-color:#f9fafb}.preview-btn{background:linear-gradient(135deg,#5a00f8,#7a20ff)}.preview-btn,.upload-btn{border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:.85rem;padding:7px 16px}.upload-btn{background:linear-gradient(135deg,green,#00b300);transition:.3s ease}.upload-btn:hover{background:linear-gradient(135deg,#060,#090);transform:scale(1.04)}.pagination{gap:12px}.pagination button{background:#1a73e8;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:.85rem;padding:6px 14px}.pagination button:disabled{background:#cbd5e1;cursor:not-allowed}.status-badge{border-radius:6px;display:inline-block;font-size:12px;font-weight:600;padding:4px 8px;text-transform:capitalize}.status-submitted{background-color:#d4f8d4;color:#0b8a0b}.status-pending{background-color:#ffe7ca;color:#d47b00}.status-late{background-color:#ffd4d4;color:#d00000}@media (max-width:768px){.top-filters{align-items:flex-start;flex-direction:column;gap:12px}table td,table th{font-size:.8rem}.add-task-btn{right:20px;top:15px}}.settings-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:end;position:fixed;z-index:1000}.settings-modal{animation:slideIn .3s ease-in-out;background:#fff;border-radius:20px;box-shadow:0 8px 25px #00000026;font-family:Poppins,sans-serif;max-width:80%;padding:35px 40px;position:relative;width:450px}.settings-modal::-webkit-scrollbar{width:8px}.settings-modal::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.settings-modal::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:10px}.settings-modal::-webkit-scrollbar-thumb:hover{background-color:#94a3b8}.close-btn{background:#ff4d4f;border-radius:50%;color:#fff;font-size:18px;height:30px;width:30px}.close-btn:hover{background:#ef4444}.settings-title{color:#1e293b;font-size:24px;font-weight:600;margin-bottom:25px}.settings-body{display:flex;flex-direction:column;gap:20px}.setting-row{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:10px;padding-bottom:10px}.setting-label{color:#374151;font-size:1rem;font-weight:500}.edit-btn{background:#2563eb;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:.9rem;padding:6px 14px;transition:all .2s ease-in-out}.edit-btn:hover{background:#1d4ed8;transform:translateY(-1px)}.setting-field input{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;margin-top:8px;padding:10px 14px;transition:all .3s ease;width:100%}.setting-field input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.setting-field p{color:#374151;font-size:.95rem}.setting-field strong{color:#111827;font-weight:600}.profile-container{align-items:center;background:#f9f9f9;display:flex;font-family:Poppins,sans-serif;justify-content:center;min-height:80vh;padding:40px}.profile-box{background:#fff;border:1px solid #ddd;border-radius:10px;box-shadow:0 4px 20px #0000000d;padding:40px 40px 60px;position:relative;width:600px}.profile-id{color:#d0d0d0;font-size:24px;font-weight:700;left:-60px;position:absolute;top:50%;transform:rotate(-90deg) translateY(-50%);transform-origin:left}.profile-content{text-align:center}.profile-title{font-size:22px;font-weight:600;margin-bottom:15px}.profile-image-wrapper{display:flex;justify-content:center}.profile-image{border:3px solid #1a73e8;border-radius:50%;height:110px;object-fit:cover;width:110px}.profile-name{font-size:20px;font-weight:500;margin:10px 0 2px}.profile-subtext{color:#666;font-size:13px;margin-bottom:10px}.tabs{border-bottom:1px solid #ddd;display:flex;justify-content:center;margin:25px 0 20px}.tab{background:none;border:none;border-bottom:3px solid #0000;color:#555;cursor:pointer;font-weight:500;padding:10px 20px;transition:.3s}.tab.active{background:#1a73e8;border-radius:3px 3px 0 0;color:#fff}.primary-details{align-items:flex-start;display:flex;gap:40px;justify-content:space-between;text-align:left}.column{flex:1 1}.primary-details p{color:#333;font-size:14px;line-height:1.5;margin:8px 0}.documents{display:flex;flex-wrap:wrap;gap:25px;justify-content:center}.doc-item{text-align:center;width:150px}.doc-item img{border:1px solid #ddd;border-radius:6px;height:auto;width:100%}.doc-item p{font-size:14px;font-weight:500;margin-top:8px}.close-button{color:#333}.view-icon{align-items:center;background:#e9fdf0;border:none;border-radius:20px;color:#2d8a55;font-size:13px;padding:5px 12px;text-decoration:none;transition:all .2s ease-in-out}.slide-overlay{align-items:stretch;animation:fadeIn .3s ease forwards;background-color:#0006;display:flex;height:100%;justify-content:flex-end;left:0;position:fixed;top:0;width:100%;z-index:9999}.slide-form{animation:formSlideIn .4s ease forwards;background:#fff;border-radius:16px 0 0 16px;box-shadow:-4px 0 20px #0003;height:100%;overflow-y:auto;padding:30px;transform:translateX(100%);width:450px}@keyframes formSlideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.close-btn{font-size:1.8rem;top:15px}h2{color:#1a1a1a;font-size:22px;font-weight:700;margin-top:0;text-align:center}.form-group{margin-bottom:20px}.checkbox-group{flex-wrap:wrap;gap:15px;margin-bottom:10px}input[type=date],input[type=email],input[type=text],textarea{border:1px solid #bbb;border-radius:8px;font-size:14px;margin-bottom:10px;outline:none;padding:10px;transition:.2s ease;width:100%}input:focus,textarea:focus{border-color:#007bff;box-shadow:0 0 3px #007bff4d}.date-row{display:flex;gap:10px}.form-row{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between}.form-row div{flex:1 1}textarea{height:100px;resize:none}.send-btn{background-color:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;padding:12px;transition:.3s ease;width:100%}.send-btn:hover{background-color:#0056b3}.from-row{justify-content:space-between;margin-bottom:6px}.from-row,.multiple-days{align-items:center;display:flex}.multiple-days{color:#444;font-size:13px;gap:6px}.slide-form::-webkit-scrollbar{width:6px}.slide-form::-webkit-scrollbar-thumb{background-color:#0003;border-radius:3px}.slide-form::-webkit-scrollbar-track{background-color:initial}.timetable-overlay{align-items:center;background-color:#0006;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.timetable-container{animation:popup-scale .3s ease;background-color:#fff;border-radius:16px;box-shadow:0 6px 20px #0000001f;max-width:850px;padding:30px;position:relative;width:90%}@keyframes popup-scale{0%{opacity:.5;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.timetable-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.timetable-title{color:#1e293b;font-size:24px;font-weight:600}.request-btn{background-color:#173983;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:400;margin-right:10%;padding:8px 16px;transition:all .2s ease-in-out}.request-btn:hover{background-color:#1d4ed8;transform:translateY(-1px)}tbody td:nth-child(odd){background-color:#f9fafb}tbody td:nth-child(2n){background-color:#fff}tbody td:hover{background-color:#e8eeff!important}.close-button{background:none;border:none;color:#444;cursor:pointer;font-size:2em;position:absolute;right:15px;top:15px;transition:transform .2s ease}.close-button:hover{color:#000;transform:rotate(90deg)}.timetable-title{color:#0f172a;font-size:1.6em;font-weight:700;letter-spacing:1px;margin-bottom:25px;text-align:center}.timetable-wrapper{border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 3px 8px #00000014;overflow:hidden}.timetable-table{border-collapse:collapse;font-family:Poppins,sans-serif;text-align:center;width:100%}.timetable-table thead tr{background:linear-gradient(135deg,#0d0d0d,#1c1c1c)}.timetable-table thead tr th:first-child{border-bottom-left-radius:30px;border-top-left-radius:30px}.timetable-table thead tr th:last-child{border-bottom-right-radius:30px;border-top-right-radius:30px}.timetable-table th{border-right:1px solid #ffffff1a;color:#fff;font-weight:600;letter-spacing:.5px;padding:14px 10px}.timetable-table th:last-child{border-right:none}.timetable-table td{background-color:#f9fafb;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;color:#1e293b;padding:12px;transition:background .2s ease}.timetable-table td:last-child{border-right:none}.timetable-table tr:nth-child(2n) td{background-color:#fff}.timetable-table tr:hover td{background-color:#f1f5f9}.break-row td{background-color:#e2e8f0;color:#1e293b;letter-spacing:1px;text-transform:uppercase}.break-row td,.end-row td{font-style:italic;font-weight:700}.end-row td{background-color:#f0f0f0;letter-spacing:2px}@media (max-width:768px){.timetable-container{padding:20px}.timetable-table td,.timetable-table th{font-size:.85rem;padding:10px}.timetable-title{font-size:1.3em}}.timetable-wrapper{max-height:430px;overflow-x:auto;overflow-y:auto}.timetable-wrapper::-webkit-scrollbar{height:8px;width:8px}.timetable-wrapper::-webkit-scrollbar-thumb,.timetable-wrapper::-webkit-scrollbar-track{background:#e5e7eb;border-radius:10px}.timetable-wrapper::-webkit-scrollbar-thumb:hover{background:#e5e7eb}.request-overlay{background:#0006;inset:0;justify-content:flex-end;z-index:1000}.status-filter{background:#f1f5f9;border:1px solid #e2e8f0;color:#334155;margin-right:10px;padding:5px 10px;transition:.2s ease}.status-filter:hover{background:#e2e8f0}.request-header{gap:10px}.request-panel{animation:slideIn .3s ease;border-radius:15px 0 0 15px;box-shadow:-5px 0 25px #00000026;height:100%;max-width:85%;overflow-y:auto;padding:25px 30px;width:400px}.request-header h2{color:#1e293b;font-size:22px}.close-btn{transition:.2s ease}.close-btn:hover{color:#fcfcfc}.teacher-info{background:#f9fafb;margin:20px 0;padding:12px 16px}.teacher-info h3{font-size:16px;font-weight:600;margin:0}.subject{color:#64748b;font-size:14px}.teacher-id{color:#94a3b8}.status{align-items:center;color:#ef4444;display:flex;font-size:14px}.status-dot{background:#ef4444;height:8px;margin-right:5px;width:8px}.request-form label{color:#374151;display:block;margin-bottom:10px}.request-form input,.request-form textarea{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;margin-bottom:15px;margin-top:5px;padding:10px 14px;transition:.2s ease;width:100%}.request-form input:focus,.request-form textarea:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26;outline:none}.btn-group{justify-content:space-between}.cancel-btn,.submit-btn{border-radius:10px;font-size:14px;transition:all .2s ease-in-out;width:48%}.cancel-btn{color:#475569}.submit-btn:hover{background:#1d4ed8}.teacher-status{font-size:14px;font-weight:500}.status-label{color:#374151}.dot-active{background:#22c55e}.dot-leave{background:#ef4444}.status-text{color:#000}.request-message{margin-top:25px}.request-message label{color:#374151;display:block;font-weight:500;margin-bottom:10px}.request-text{background:#f9fafb;border-radius:10px;color:#1e293b;margin-bottom:10px;padding:12px}.request-note{color:#475569;margin-bottom:20px}.request-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000073;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:2000}.request-panel{animation:popupScale .25s ease;background:#fff;border-radius:18px;box-shadow:0 10px 30px #0003;font-family:Poppins,sans-serif;padding:20px 24px;width:480px}@keyframes popupScale{0%{opacity:.5;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.request-header{align-items:center;display:flex;justify-content:space-between}.request-header h2{color:#111;font-size:20px;font-weight:600}.status-filter{background:#f7f7f7;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:14px;outline:none;padding:6px 10px}.close-btn{color:#555;font-weight:700}.teacher-info{background:#f6f8fb;border-radius:12px;justify-content:space-between;margin-top:18px;padding:14px}.teacher-info,.teacher-left{align-items:center;display:flex}.teacher-left{gap:12px}.teacher-avatar{border-radius:50%;height:48px;width:48px}.teacher-details h3{font-size:16px;font-weight:600;margin:0}.subject{color:#666;font-size:13px}.teacher-id{color:#777;font-size:12px;margin-top:2px}.teacher-status{align-items:center;display:flex;gap:6px}.status-label{color:#444;font-size:13px}.status-text{font-size:13px;font-weight:600}.status-dot{border-radius:50%;height:10px;width:10px}.dot-active{background:#0cb400}.dot-leave{background:#d60000}.request-form{gap:18px;margin-top:20px}.request-form,.request-form label{display:flex;flex-direction:column}.request-form label{color:#333;font-size:14px;font-weight:500;gap:6px}.request-form input,.request-form select,.request-form textarea{background:#f9f9f9;border:1px solid #ccc;border-radius:10px;font-size:14px;outline:none;padding:10px 12px;transition:.25s ease;width:100%}.request-form input:focus,.request-form select:focus,.request-form textarea:focus{background:#fff;border-color:#0d47a1}.request-form textarea{height:90px;resize:none}.btn-group{display:flex;gap:12px;justify-content:flex-end;margin-top:10px}.cancel-btn{background:#ccc;border:none;border-radius:10px;color:#222;cursor:pointer;font-size:14px;padding:10px 22px;transition:.25s}.cancel-btn:hover{background:#b5b5b5}.submit-btn{background:#0d47a1;border-radius:10px;font-size:14px;padding:10px 22px;transition:.25s}.submit-btn:hover{background:#09347a}.submit-btn:disabled{cursor:not-allowed;opacity:.6}.request-message{margin-top:20px}.request-text{color:#444;font-size:14px;line-height:1.5}.request-note{color:#777;font-size:13px;margin-top:6px}.attendance-page{align-items:flex-start;background:#f9f9fb;color:#1e293b;display:flex;font-family:Poppins,sans-serif;justify-content:center;min-height:100vh;padding:40px 30px}.attendance-container{background:#fff;border-radius:16px;box-shadow:0 8px 25px #00000014;margin:40px auto;max-width:1400px;padding:25px 30px 30px;position:relative;transition:all .2s ease-in-out;width:92%}.attendance-header{align-items:center;display:flex;flex-wrap:nowrap;gap:10px;justify-content:space-between;margin-bottom:25px}.attendance-header h2{color:#1e293b;font-size:24px;font-weight:700;text-align:start}.toggle-group{background:#f1f5f9;border-radius:30px;display:flex;flex-shrink:0;overflow:hidden}.toggle-group button{background:#0000;border:none;color:#475569;cursor:pointer;font-weight:500;padding:8px 20px;transition:background-color .15s ease,color .15s ease}.toggle-group button.active{background:#18429c;color:#fff}.header-actions{flex-shrink:1;flex-wrap:nowrap;gap:12px;margin-right:5%}.add-btn,.header-actions{align-items:center;display:flex}.add-btn{background:#18429c;border-radius:8px;font-weight:500;gap:6px;padding:8px 20px;transition:background-color .15s ease;white-space:nowrap}.add-btn:hover{background:#1e40af}.plus-icon{color:#fff;font-size:18px}.filter-dropdown{-webkit-appearance:none;appearance:none;background:#f9fbff;border:1px solid #e2e8f0;border-radius:25px;box-shadow:0 2px 8px #0000000a;color:#1e293b;cursor:pointer;flex-shrink:1;font-family:Poppins,sans-serif;font-size:.9rem;outline:none;padding:8px 40px 8px 16px;position:relative;transition:all .15s ease-in-out;white-space:nowrap}.filter-dropdown:focus,.filter-dropdown:hover{background:#fff;border-color:#2563eb;box-shadow:0 2px 10px #2563eb26}.filter-dropdown:active{background:linear-gradient(145deg,#f9fbff,#fff)}.filter-dropdown:after{color:#475569;content:"▼";font-size:12px;pointer-events:none;position:absolute;right:14px;top:50%;transform:translateY(-50%)}.attendance-table-wrapper{margin-top:20px;overflow-x:auto}.attendance-table{border-collapse:collapse;text-align:center;width:100%}.attendance-table td,.attendance-table th{border-bottom:1px solid #e2e8f0;padding:12px 15px}.attendance-table th{background:#000;color:#fff;font-weight:700;text-transform:capitalize}.student-id{color:#64748b;font-size:13px}.attendance-table tbody tr:hover{background:#f9fafb;transition:background-color .2s ease}@media (max-width:768px){.attendance-header{flex-direction:column;gap:15px}.header-actions{flex-direction:column;width:100%}.attendance-container{padding:20px}.attendance-table td,.attendance-table th{font-size:.9rem;padding:8px 10px}}.student-dropdown-toggle .caret{font-size:.85rem;margin-left:8px}.student-dropdown-panel{border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 6px 20px #10182814;left:0;margin-top:6px;right:0;z-index:50}.student-list-scroll{margin-top:8px;max-height:220px;padding-right:6px}.no-students{color:#64748b;padding:8px}.dropdown-select{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#111827;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:12px;width:100%}.dropdown-select:hover{border-color:#2563eb}.dropdown-panel{animation:dropdownFade .2s ease-out;background:#fff;border:1px solid #d1d5db;border-radius:10px;box-shadow:0 4px 16px #00000026;max-height:260px;overflow-y:auto;padding:10px;position:absolute;top:105%;width:100%;z-index:2000}.student-search-input{border-radius:6px;padding:8px 10px}.student-search-input:focus{box-shadow:0 0 3px #2563eb66}.student-list-scroll{padding-right:5px}.student-item{gap:10px;padding:6px 2px}.leave-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f0f0f99;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.leave-container.fixed-box{background:#fff;border-radius:16px;box-shadow:0 6px 18px #00000040;font-family:Poppins,sans-serif;height:80vh;max-width:850px;overflow-y:auto;padding:30px 35px;position:relative;transition:all .3s ease;width:75%}.leave-header h2{font-size:20px;font-weight:600;margin-bottom:10px}.leave-header span{color:#444;font-size:13px}.leave-legend{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:12px;margin-bottom:18px;padding:8px 12px}.dot{height:10px;margin-right:4px;width:10px}.present{background-color:#22c55e}.leave{background-color:#ef4444}.holiday{background-color:#facc15}.month-nav{justify-content:space-between;margin-bottom:18px}.nav-btn{border-radius:6px}.month-title{font-size:15px}.calendar{grid-gap:6px;gap:6px;grid-template-columns:repeat(7,90px);justify-content:center}.calendar-day-header{border-radius:5px;font-size:13px;height:32px;line-height:32px}.calendar-day{background:#f3f4f6;border-radius:6px;box-sizing:border-box;color:#111;flex-direction:column;flex-shrink:0;font-size:13px;height:85px;justify-content:space-around;text-align:center;width:90px}.calendar-day .date{font-size:14px}.calendar-day .status{border-radius:5px;font-size:12px;font-weight:600;margin-top:3px;overflow:hidden;padding:3px 6px;text-align:center;text-overflow:ellipsis;white-space:nowrap;width:85%}.calendar-day.present .status{background-color:#22c55e;color:#fff}.calendar-day.leave .status{background-color:#ef4444;color:#fff}.calendar-day.holiday .status{background-color:#facc15;color:#000}.calendar-day:hover{background:#e0f2fe;transform:scale(1.02)}.calendar-day:hover .status{background:#0d47a1;box-shadow:0 3px 6px #00000026;color:#fff;overflow:visible;padding:4px 6px;transition:all .2s ease-in-out;white-space:normal;z-index:10}.leave-container::-webkit-scrollbar{width:8px}.leave-container::-webkit-scrollbar-thumb{background:#a1a1aa;border-radius:8px}.leave-container::-webkit-scrollbar-thumb:hover{background:#71717a}@media (max-width:1024px){.calendar{gap:4px;grid-template-columns:repeat(7,70px)}.calendar-day{font-size:11px;height:70px;width:70px}.calendar-day .date{font-size:12px}.calendar-day .status{font-size:10px}}.reports-page{align-items:flex-start;background:#f7f9fb;display:flex;font-family:Poppins,sans-serif;justify-content:center;min-height:100vh;padding:40px;width:100%}.reports-layout{display:flex;position:relative}.reports-page{flex:1 1;transition:all .3s ease}.addreport-sidebar{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fffffff2;border-left:2px solid #b5d2f3;box-shadow:-4px 0 12px #0000001a;position:fixed;right:0;top:0;z-index:999}.reports-container{background:#fff;border-radius:20px;border-radius:16px;box-shadow:0 4px 20px #00000014;box-shadow:0 2px 10px #0000000f;margin:40px auto;max-width:1100px;max-width:1400px;padding:25px 30px 30px;position:relative;width:90%;width:92%}.report-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.report-header h2{color:#1e293b;font-size:22px;font-weight:600}.add-report-btn{background:#1d4ed8;border:none;border-radius:10px;color:#fff;cursor:pointer;font-weight:500;margin-right:3%;padding:8px 20px;transition:.2s ease}.reports-department{font-size:15px;font-weight:500;margin-bottom:15px}.reports-department strong{color:#1e40af}.reports-filters{align-items:center;display:flex;flex-wrap:wrap;justify-content:end;margin-bottom:20px}.test-toggle{background:#f1f5f9;border-radius:30px;display:flex;gap:8px;padding:4px}.test-toggle button{background:#0000;border:none;border-radius:25px;color:#475569;cursor:pointer;font-weight:500;padding:8px 20px;transition:all .3s ease}.test-toggle button.active{background:#2563eb;color:#fff}.dropdown-group{display:flex;gap:10px}.dropdown-group select{background:#f9fafb;border:1px solid #e2e8f0;border-radius:25px;cursor:pointer;font-size:14px;outline:none;padding:6px 16px;transition:.2s}.dropdown-group select:hover{border-color:#2563eb}.reports-table{border-collapse:collapse;margin-top:15px;width:100%}.reports-table th{background:#0b0b0b;border-bottom:2px solid #e5e7eb;color:#e8e9eb;font-size:15px;font-weight:600;padding:12px;text-align:left}.reports-table td{border-top:1px solid #e5e7eb;color:#334155;font-size:14px;padding:12px;vertical-align:middle}.reports-table tr:hover{background:#f9fafb;transition:.3s ease}.profile-cell{align-items:center;display:flex;gap:12px}.profile-pic{border-radius:50%;height:40px;object-fit:cover;width:40px}.profile-info p{color:#1e293b;font-weight:600;margin:0}.profile-info span{color:#64748b;font-size:12px}.download-btn{background:#e0f2fe;border-radius:20px;color:#0284c7;font-weight:500;padding:6px 16px;transition:.2s}.download-btn:hover{background:#bae6fd}.overall-rank{color:#111;font-weight:600;margin-top:25px;text-align:right}.rank-percentage{color:#ef4444;font-weight:700}.addreport-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fff9;display:flex;inset:0;justify-content:flex-end;position:fixed;z-index:3000}.addreport-sidebar{animation:slideInRight .35s ease forwards;background:#fff;border-left:1px solid #d4d8dd;border-radius:12px 0 0 12px;box-shadow:-4px 0 15px #0000001a;display:flex;flex-direction:column;height:100vh;overflow-y:auto;padding:24px;width:420px}.addreport-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.addreport-header h2{color:#111827;font-size:1.2rem;font-weight:600;margin-right:4%}.close-btn{color:#334155;font-size:24px}label{color:#1e293b;font-size:.9rem;font-weight:500;margin-bottom:6px}.input-field{border:1px solid #cbd5e1;border-radius:8px;font-size:.9rem;margin-bottom:14px;outline:none;padding:10px;width:100%}.input-field:focus{border-color:#2563eb;box-shadow:0 0 4px #2563eb4d}.checkbox-group{align-items:center;color:#334155;display:flex;font-size:.9rem;gap:12px;margin-bottom:20px}.upload-section{align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px}.upload-box{align-items:center;background:#f6faff;border:2px dashed #b5d2f3;border-radius:10px;display:flex;height:90px;justify-content:center;margin-bottom:25px;margin-top:25px;transition:.3s;width:90px}.upload-box:hover{border-color:#2563eb}.plus-icon{color:#2563eb;cursor:pointer;font-size:20px}.upload-small{align-items:center;background:#cfd1d6;border-radius:8px;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;margin-top:25px;transition:.3s;width:40px}.upload-small:hover{background:#155bd4;color:#cfd1d6}.file-display{align-items:center;background:#eef2ff;border-radius:8px;display:flex;justify-content:space-between;overflow:hidden;padding:8px 10px;width:90px}.file-display span{color:#1e293b;font-size:.8rem;max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remove-btn{background:none;border:none;color:#ef4444;cursor:pointer;font-size:16px;transition:.2s}.remove-btn:hover{color:#dc2626}.button-row{display:flex;gap:10px;justify-content:space-between;margin-top:20px}.cancel-btn,.submit-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-weight:500;padding:10px 0;transition:.3s}.cancel-btn{background:#f1f5f9;color:#1e3a8a}.cancel-btn:hover{background:#e2e8f0}.submit-btn{background:#2563eb}.submit-btn:hover{background:#155bd4}.student-dropdown{margin-bottom:15px;position:relative;width:100%}.student-dropdown-toggle{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:12px;text-align:left;width:100%}.student-dropdown-toggle:hover{border-color:#2563eb}.student-dropdown-panel{animation:dropdownFade .2s ease-out;background:#fff;border:1px solid #d1d5db;border-radius:10px;box-shadow:0 4px 14px #00000026;max-height:260px;overflow-y:auto;padding:10px;position:absolute;top:105%;width:100%;z-index:9999}@keyframes dropdownFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.student-search-input{border:1px solid #cbd5e1;border-radius:7px;font-size:14px;margin-bottom:10px;padding:9px;width:100%}.student-search-input:focus{border-color:#2563eb;box-shadow:0 0 2px #2563eb80;outline:none}.student-list-scroll{max-height:200px;overflow-y:auto;padding-right:4px}.student-item{align-items:center;color:#1e293b;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:6px 4px}.student-item:hover{background:#f1f5ff;border-radius:6px}.student-item input[type=checkbox]{cursor:pointer;transform:scale(1.2)}.student-list-scroll::-webkit-scrollbar{width:6px}.student-list-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:5px}.student-list-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes slideInRight{0%{opacity:.8;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.app-container{align-items:center;background:#f8f9fc;display:flex;justify-content:center;min-height:100vh}.app-container,.login-card{position:relative}.blue-card{background:#2563eb;left:25px;position:absolute;top:25px;z-index:1}.blue-card,.login-container{border-radius:8px;height:480px;width:430px}.login-container{background:#fff;box-shadow:0 8px 30px #00000026;display:flex;flex-direction:column;justify-content:center;overflow:hidden;position:relative;z-index:2}@media (max-width:500px){.login-card{width:90vw}.login-container{height:auto;min-height:450px;width:90vw}.blue-card{display:none}}.login-content{display:flex;flex-direction:column;flex-grow:1;justify-content:center;padding:40px}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#111827;font-size:26px;font-weight:600;margin-bottom:5px}.login-header h2{color:#111827;font-size:18px;font-weight:500;margin-bottom:10px}.login-header p{color:#6b7280;font-size:13px;line-height:1.5}.form-group{margin-bottom:22px}.form-group label{color:#374151;display:block;font-size:13px;font-weight:500;margin-bottom:6px}.form-group input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:12px 14px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26;outline:none}.form-options{display:flex;font-size:13px;justify-content:flex-end;margin-bottom:25px}.forgot-link{color:#2563eb;cursor:pointer;text-decoration:none;transition:color .2s}.forgot-link:hover{color:#1d4ed8;text-decoration:underline}.sign-in-btn{align-items:center;background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;justify-content:center;padding:13px;transition:.3s;width:100%}.sign-in-btn:hover:not(:disabled){background:#1d4ed8}.sign-in-btn:disabled{background:#93c5fd;cursor:not-allowed}.toast{border-radius:6px;box-shadow:0 4px 12px #0000001a;font-size:14px;padding:12px 20px;position:fixed;right:20px;top:20px;z-index:9999}.toast.success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.toast.error{background:#fee2e2;border:1px solid #fecaca;color:#b91c1c}.otp-box-container{display:flex;gap:10px;justify-content:center;margin:20px 0}.otp-box{border:2px solid #d0d0ff;border-radius:8px;font-size:20px;font-weight:700;height:50px;outline:none;text-align:center;width:45px}.otp-box:focus{border-color:#4b7bff;box-shadow:0 0 8px #4b7bff80}.warning-text{color:#ff3b3b;font-size:13px;margin-top:5px}.loader{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#1d4ed8;height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.sports-box h2{color:#111827;font-size:22px;font-weight:700;margin-bottom:20px;margin-top:0}.sports-table-wrapper{margin-top:10px}table{border-collapse:collapse;text-align:center;width:100%}thead tr{background:#2e2e2e;color:#fff}thead th{font-size:.95rem;padding:14px}tbody tr:nth-child(odd){background:#f9fafb}tbody tr:nth-child(2n){background:#fff}td{border:1px solid #e2e8f0;font-size:.95rem;padding:12px}tbody tr:hover td{background:#e8eeff}.pagination{align-items:center}body{background-color:#f9fafb;font-family:Poppins,sans-serif}.exam-duty-container{align-items:flex-start;background:#f9fafb;display:flex;justify-content:center;min-height:100vh;overflow-y:auto;padding:40px 20px}.exam-duty-box{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000000f;margin-top:40px;max-width:95%;padding:25px 30px 30px;position:relative;width:90%;z-index:10}.exam-duty-header{align-items:center;display:flex;justify-content:space-between}.exam-duty-header h2{color:#111827;font-size:22px;font-weight:700;margin:0}.exam-duty-filters{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin:25px 0 15px}.filter-buttons{background:#fff;border:1px solid #e2e8f0;border-radius:50px;box-shadow:0 2px 8px #0000001a;display:flex;padding:4px}.filter-btn{background:#0000;border:none;border-radius:50px;color:#334155;cursor:pointer;font-family:Poppins,sans-serif;font-size:small;font-weight:800;padding:10px 22px;transition:all .3s ease}.filter-btn.active{background:linear-gradient(135deg,#0043ff,#06f);box-shadow:0 2px 8px #0066ff4d;color:#fff}.exam-duty-table-wrapper{margin-top:10px}.exam-duty-table-wrapper table{border:1px solid #e2e8f0;border-collapse:collapse;border-radius:12px;overflow:hidden;text-align:center;width:100%}.exam-duty-table-wrapper thead tr{background:#2d2d2d;color:#fff}.exam-duty-table-wrapper th{border:none;font-size:.95rem;font-weight:600;padding:14px 16px}.exam-duty-table-wrapper tbody tr:nth-child(odd){background-color:#f9fafb}.exam-duty-table-wrapper tbody tr:nth-child(2n){background-color:#fff}.exam-duty-table-wrapper td{border:1px solid #e2e8f0;color:#1e293b;font-size:.95rem;padding:12px 16px}.exam-duty-table-wrapper tbody tr:hover td{background-color:#e8eeff!important}@media (max-width:768px){.exam-duty-filters{flex-direction:column;gap:12px}table td,table th{font-size:.85rem;padding:10px}.pagination{flex-direction:column;gap:10px}}.fines-popup-container{align-items:center;background:#0006;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:1%;width:100%;z-index:999}.fines-panel{background:#fff;border-radius:14px;box-shadow:0 4px 20px #0003;max-height:90vh;overflow-y:auto;padding:20px;position:relative;width:800px}.fines-header{align-items:center;display:flex;justify-content:space-between}.close-btn{color:#333}.fines-tabs{display:flex;font-size:16px;gap:25px;margin-top:10px}.fines-tabs span{cursor:pointer;padding-bottom:4px}.active-tab{border-bottom:2px solid #1976d2;color:#1976d2;font-weight:700}.fine-cards-section{margin-top:12px}.fine-card{border:1px dashed #888;border-radius:8px;font-size:15px;margin-bottom:12px;padding:14px}.fine-card h3{font-size:17px;margin:0 0 5px}.fine-amount-row{align-items:center;display:flex;justify-content:space-between}.pay-btn{background:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:6px 14px}.scroll-btn-container{display:flex;gap:10px;justify-content:center;margin-top:5px}.scroll-btn{background:#eaeaea;border:none;border-radius:50%;cursor:pointer;font-size:18px;height:36px;width:36px}.fines-table-section{margin-top:15px}.fines-table-section table{border-collapse:collapse;font-size:13px;width:100%}.fines-table-section th{background:#000;color:#fff;font-size:14px;padding:8px}.fines-table-section td{border-bottom:1px solid #ccc;padding:6px 8px}.paid-status{color:green;font-weight:600}.unpaid-status{color:red;font-weight:600}.payment-page{margin-top:15px}.amount-box{align-items:center;border:1px solid #ddd;border-radius:10px;display:flex;justify-content:space-between;padding:14px}.amount-text{font-size:22px;font-weight:700}.payment-title{font-size:18px;font-weight:700;margin-top:15px}.gpay-row{align-items:center;border:1px solid #ddd;border-radius:10px;display:flex;gap:10px;margin-bottom:10px;padding:12px}.gpay-logo{width:40px}.update-box{margin-top:10px}.update-title{font-size:16px;font-weight:700}.update-sub{color:#555;font-size:13px;margin-top:-5px}.form-rows{display:flex;gap:10px;margin-top:10px}.form-rows input{border:1px solid #ccc;border-radius:8px;padding:8px;width:100%}.btn-row{display:flex;gap:10px;justify-content:flex-end;margin-top:15px}.cancel-btn,.proceed-btn{border:none;border-radius:6px;cursor:pointer;font-size:16px;padding:8px 18px}.cancel-btn{background:#888;color:#fff}.proceed-btn{background:#1976d2;color:#fff}.exam-container{background:#f9f9fb;font-family:Poppins,sans-serif;min-height:100vh;padding:0 30px 30px;position:relative}.exam-box{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000000f;margin-top:40px;padding:25px 30px 30px;position:relative}.exam-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:25px}.exam-header h2{color:#111827;font-size:1.4rem;font-weight:700}.exam-table{border-collapse:initial;border-spacing:0;margin-top:20px;text-align:center;width:100%}.exam-table thead tr{background-color:#2e2e2e;color:#fff}.exam-table th{font-size:.95rem;font-weight:500;padding:14px 16px}.exam-table thead tr th:first-child{border-bottom-left-radius:40px;border-top-left-radius:40px}.exam-table thead tr th:last-child{border-bottom-right-radius:40px;border-top-right-radius:40px}.exam-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .2s ease}.exam-table tbody tr:hover{background:#f9fafb}.exam-table td{color:#1e293b;font-size:.95rem;padding:12px 16px}.stars{color:#fbc02d;font-size:18px}.pagination{margin-top:25px}.pagination-btn{cursor:pointer;transition:all .3s ease}.pagination-btn:disabled{cursor:not-allowed}.pagination-btn:hover:not(:disabled){background:#155bd4;transform:translateY(-1px)}.page-info{color:#334155;font-weight:500}@media (max-width:768px){.exam-header{align-items:flex-start;flex-direction:column;gap:10px}.exam-filters{width:100%}.exam-table td,.exam-table th{font-size:.9rem;padding:10px}}.sports-container{align-items:flex-start;background:#f9fafb;display:flex;font-family:Poppins,sans-serif;justify-content:center;min-height:100vh;padding:40px 20px}.sports-box{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000001a;margin-top:40px;max-width:95%;padding:25px 30px 30px;position:relative;width:90%}.sports-header{align-items:center;display:flex;justify-content:space-between}.sports-header h2{color:#111827;font-size:22px;font-weight:700}.add-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:25px;color:#fff;cursor:pointer;font-weight:600;margin-right:3%;padding:8px 18px}.sports-table{border-collapse:collapse;margin-top:20px;width:100%}.sports-table th{background:#2d2d2d;color:#fff;font-size:14px;padding:12px}.sports-table td{border:1px solid #e2e8f0;font-size:14px;padding:12px}.sports-table tr:nth-child(2n){background:#f9fafb}.sports-table tr:hover td{background:#e8eeff}.pagination-btn{background:#1a73e8;border:none;border-radius:25px;color:#fff;font-weight:600;padding:10px 18px}.pagination-btn:disabled{background:#cbd5e1}.sidebar-overlay{animation:fadeIn .25s ease-in-out;background:#00000059;display:flex;inset:0;justify-content:flex-end;position:fixed;z-index:1000}.sidebar-box{animation:slideIn .35s ease;background:#fff;border-radius:20px 0 0 20px;box-shadow:-6px 0 18px #00000026;height:100%;overflow-y:auto;padding:28px 25px;width:420px}@keyframes slideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.sidebar-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:18px;padding-bottom:8px}.sidebar-header h2{color:#1f2937;font-size:22px;font-weight:700}.sidebar-header .close-btn{color:#555;font-size:32px;position:static}label{color:#374151;font-size:13px;font-weight:600}.input-field,.textarea-field{background:#f8fafc;border:1px solid #cbd5e1;border-radius:10px;font-size:14px;margin-bottom:18px;margin-top:5px;padding:13px;transition:.25s;width:100%}.input-field:focus,.textarea-field:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb40}.textarea-field{height:95px;resize:none}.submit-btn{background:#1a73e8;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:15px;font-weight:700;margin-top:10px;padding:12px;transition:.2s;width:100%}.submit-btn:hover{background:#1a73e8;transform:translateY(-2px)}.term-filter{outline:none;padding:10px 16px}.term-container{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;font-family:Poppins,sans-serif;justify-content:flex-start;margin:40px auto;max-width:95%;padding:25px 30px 30px;position:relative;width:90%}.close-btn{font-size:28px;top:20px}.term-header{align-items:center;display:flex;justify-content:space-between}.term-header h2{color:#111827;font-size:22px;font-weight:700}.term-filter{background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;font-size:14px;margin-right:3%;padding:12px 16px}.table-wrapper{border:1px solid #e2e8f0;border-radius:12px;margin-top:20px;overflow:hidden}.term-table{border-collapse:collapse;width:100%}.term-table thead tr{background:#2d2d2d;color:#fff}.term-table th{font-size:14px;font-weight:600;padding:12px;text-align:left}.term-table td{border:1px solid #e2e8f0;font-size:14px;padding:12px}.term-table tr:nth-child(2n){background:#f9fafb}.term-table tr:hover td{background:#e8eeff}.download-btn{background:#d1f7d9;border:none;border-radius:18px;color:#2e7d32;cursor:pointer;font-weight:600;padding:8px 18px}.pagination{display:flex;gap:15px;justify-content:center;margin-top:20px}.page-btn{background:#1a73e8;border:none;border-radius:25px;color:#fff;font-weight:600;padding:10px 18px}.page-btn.disabled{background:#cbd5e1;cursor:default}.pagination span{font-size:14px;font-weight:600}.term-footer{display:flex;font-size:15px;justify-content:space-between;margin-top:20px}.rank span{color:red;font-weight:700}.grade b{color:green;font-size:18px}.attendence-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f0f0f99;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.attendence-container{animation:fadeIn .3s ease;background:#fff;border-radius:16px;box-shadow:0 8px 20px #00000040;font-family:Poppins,sans-serif;height:85vh;max-width:950px;overflow-y:auto;padding:30px 40px;position:relative;width:90%}.attendence-container::-webkit-scrollbar{width:8px}.attendence-container::-webkit-scrollbar-thumb{background:#a1a1aa;border-radius:8px}.attendence-container::-webkit-scrollbar-thumb:hover{background:#71717a}.close-btn{color:#444;font-size:26px;right:15px;top:12px;z-index:10}.close-btn:hover{color:#000;transform:scale(1.1)}.attendence-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.attendence-header h2{font-size:20px;font-weight:600}.attendence-header span{color:#555;font-size:14px}.eye-btn{align-items:center;background:#0d47a1;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:34px;justify-content:center;margin-right:2%;transition:.2s;width:34px}.eye-btn:hover{background:#1565c0;transform:scale(1.05)}.attendence-legend{background:#fff;border-radius:8px;box-shadow:0 2px 6px #0000001a;display:flex;gap:15px;justify-content:start;margin-bottom:15px;padding:8px 12px}.dot{border-radius:50%;display:inline-block;height:12px;margin-right:5px;width:12px}.dot.present{background:#22c55e}.dot.leave{background:#ef4444}.dot.halfday{background:#871353}.month-nav{align-items:center;display:flex;gap:10px;justify-content:end;margin-bottom:15px}.nav-btn{background:#0d47a1;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:5px 10px}.nav-btn:hover{background:#1565c0}.month-title{color:#222;font-weight:600}.calendar{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr)}.calendar-day-header{background:#0d47a1;border-radius:6px;color:#fff;font-weight:500;padding:6px;text-align:center}.calendar-day{align-items:center;background:#e5e7eb;border-radius:8px;display:flex;height:70px;justify-content:center;transition:transform .2s ease}.calendar-day:hover{transform:scale(1.05)}.calendar-day.present{background:#dcfce7;border:1px solid #22c55e}.calendar-day.absent{background:#fee2e2;border:1px solid #ef4444}.calendar-day.halfday{background:#fbe3ef;border:1px solid #871353}.calendar-day.today{background:#e0ecff;border:2px solid #2563eb}.calendar-day .date{font-weight:600}.popup-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0f0f0f80;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.summary-popup{animation:popIn .3s ease;background:#fff;border-radius:16px;box-shadow:0 8px 20px #00000040;padding:25px 30px;position:relative;text-align:center;width:420px}.summary-popup h3{color:#0d47a1;margin-bottom:20px}.popup-close-btn{background:#ff4d4d;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:18px;height:28px;position:absolute;right:12px;top:10px;transition:.3s;width:28px}.popup-close-btn:hover{background:#d93636;transform:scale(1.1)}.summary-box-container{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(2,1fr)}.summary-box{border-radius:12px;color:#fff;font-weight:600;padding:15px 10px;transition:transform .2s ease}.summary-box.total{background:#2563eb}.summary-box.present{background:#22c55e}.summary-box.absent{background:#ef4444}.summary-box.half-day{background:#871353}.summary-box:hover{transform:scale(1.05)}@keyframes fadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.ptmeet-container{align-items:flex-start;background:#f9fafb;display:flex;font-family:Poppins,sans-serif;justify-content:center;min-height:100vh;padding:40px 20px}.ptmeet-box{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000000f;margin-top:40px;max-width:95%;padding:25px 30px 30px;position:relative;width:90%;z-index:10}.ptmeet-header{align-items:center;display:flex;justify-content:space-between}.ptmeet-header h2{color:#111827;font-size:22px;font-weight:700;margin:0}.close-btn{background:none;border:none;color:#475569;cursor:pointer;font-size:22px;position:absolute;right:25px;top:25px;transition:.2s}.ptm-table{border:1px solid #e2e8f0;border-collapse:collapse;border-radius:12px;margin-top:15px;overflow:hidden;text-align:center;width:100%}.ptm-table thead tr{background:#2d2d2d;color:#fff}.ptm-table th{border:none;font-size:.95rem;font-weight:600;padding:14px 16px}.ptm-table tbody tr:nth-child(odd){background-color:#f9fafb}.ptm-table tbody tr:nth-child(2n){background-color:#fff}.ptm-table td{border:1px solid #e2e8f0;color:#1e293b;font-size:.95rem;padding:12px 16px}.ptm-table tbody tr:hover td{background-color:#e8eeff!important}.timeslot-list{display:flex;flex-direction:column;gap:4px}.timeslot-item{background:#e9f1ff;border-radius:6px;color:#1e293b;font-size:.85rem;font-weight:600;margin:auto;padding:5px 10px;width:-webkit-fit-content;width:fit-content}.teacher-list{display:flex;flex-direction:column;gap:4px}.teacher-item{background:#eef2ff;border-radius:6px;color:#334155;font-size:.85rem;font-weight:600;margin:auto;padding:5px 10px;width:-webkit-fit-content;width:fit-content}.no-data{color:#475569;font-size:15px;padding:20px;text-align:center}@media (max-width:768px){.ptmeet-header{align-items:flex-start;flex-direction:column;gap:10px}.ptm-table td,.ptm-table th{font-size:.85rem;padding:10px}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Poppins,sans-serif,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue;margin:0}code{font-family:Poppins,sans-serif,Courier New,monospace}
/*# sourceMappingURL=main.daf9a670.css.map*/