@keyframes popupFadeIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.login-container{display:flex;flex-direction:column;align-items:center;gap:80px;color:#e0e0e0;text-align:center;height:100vh;width:100%;background:linear-gradient(135deg,#1f2a38,#3a4a5c,#5a6b7f);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden}.login{margin-top:80px;font-size:1.3rem;font-weight:500;color:#d1d9e0}.login-form{background:#141e2dd9;padding:2.5rem 3rem;border-radius:12px;width:28rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 8px 25px #0006;animation:popupFadeIn .8s ease-out forwards;opacity:0;transform:scale(.5)}.login-form h2{text-align:center;margin-bottom:1.5rem;color:#7aa9d9;font-size:1.5rem}.login-form input{width:100%;padding:12px;margin-bottom:1rem;border:1px solid #556677;border-radius:8px;background-color:#1c2a3a;color:#d1d9e0;font-size:1rem;transition:border .3s,box-shadow .3s}.login-form input:focus{outline:none;border:1px solid #7aa9d9;box-shadow:0 0 8px #7aa9d980}.login-form button[type=submit]{width:100%;padding:12px;background:linear-gradient(90deg,#5a8bcf,#3b5f9e);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:background .3s,transform .2s}.login-form button[type=submit]:hover{background:linear-gradient(90deg,#3b5f9e,#2a3f6b);transform:translateY(-2px)}.close-button{position:absolute;top:12px;right:15px;background:transparent;border:none;font-size:22px;cursor:pointer;color:#bbb;transition:color .3s}.close-button:hover{color:#7aa9d9}.error-text{color:#ff6b6b;margin-top:10px;font-size:.9rem;text-align:center}.signup-text{margin-top:15px;font-size:.9rem;text-align:center;color:#b0c4d9}.signup-link{color:#7aa9d9;cursor:pointer;text-decoration: underline}@media (max-width: 1024px){.login-container{gap:50px;padding:20px}.login-form{width:22rem;padding:2rem}.login{font-size:1.1rem}.login-form h2{font-size:1.3rem}.login-form input{padding:10px;font-size:.95rem}.login-form button[type=submit]{padding:10px;font-size:1rem}}@media (max-width: 768px){.login-container{gap:30px;padding:15px}.login{font-size:1rem}.login-form{width:100%;max-width:90%;padding:1.8rem;margin-top:40px}.login-form h2{font-size:1.2rem}.login-form input{padding:10px;font-size:.9rem}.login-form button[type=submit]{padding:10px;font-size:1rem}.login h1{font-size:1.5rem}.login h6{font-size:.85rem}}@media (max-width: 375px){.login-container{gap:20px;padding:10px}.login{font-size:.9rem}.login h1{font-size:1.2rem}.login h6{font-size:.8rem}.login-form{width:100%;max-width:95%;padding:1.5rem;margin-top:30px;border-radius:10px}.login-form h2{font-size:1.1rem;margin-bottom:1rem}.login-form input{padding:8px;font-size:.85rem}.login-form button[type=submit]{padding:10px;font-size:.95rem}.signup-text,.error-text{font-size:.8rem}.close-button{top:8px;right:10px;font-size:20px}}.schedule-widget-card{background-color:var(--card_bg);border-radius:12px;padding:1rem;box-shadow:0 1px 3px var(--card_shadow);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent;font-family:Inter,sans-serif;margin-top:1rem}.schedule-widget-card:hover{transform:translateY(-3px);background-color:var(--hover_bg);box-shadow:0 4px 8px var(--card_shadow)}.schedule-widget-card:active{transform:scale(.99)}.widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border_color)}.widget-title{margin:0;font-size:1rem;font-weight:600;color:var(--accent_text)}.widget-arrow-icon{color:var(--icon_color);transition:color .2s ease}.schedule-widget-card:hover .widget-arrow-icon{color:var(--icon_hover_color)}.widget-content{min-height:80px;display:flex;flex-direction:column;justify-content:center}.widget-state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-align:center;color:var(--secondary_text)}.widget-spinner-icon{animation:spin 1s linear infinite;font-size:1.5rem;color:var(--accent_color)}.widget-error-icon{font-size:1.5rem;color:var(--danger_color)}.widget-state-text{font-size:.875rem;font-weight:500}.widget-empty-icon{font-size:1.75rem}.widget-state-title{font-size:.9rem;font-weight:600;color:var(--primary_text);margin:0}.widget-schedule-list{display:flex;flex-direction:column;gap:.6rem}.widget-schedule-item{display:flex;align-items:center;gap:.75rem;font-size:.875rem}.period-time{background-color:var(--secondary_bg);color:var(--accent_color);padding:.2rem .5rem;border-radius:6px;font-weight:500;font-size:.75rem;flex-shrink:0}.period-details{color:var(--primary_text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.more-items-text{font-size:.8rem;color:var(--secondary_text);margin:.5rem 0 0;text-align:center}.mobile-attendance-container{min-height:100vh;background-color:var(--body_bg);padding:1rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;width:100%}.mobile-header{background-color:var(--card_bg);border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px var(--card_shadow)}.mobile-header-top{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.mobile-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--primary_text);word-break:break-word}.mobile-filter-toggle{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;background-color:var(--secondary_bg);border:none;border-radius:8px;font-size:.875rem;font-weight:500;color:var(--secondary_text);cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.mobile-filter-toggle:active{background-color:var(--hover_bg);transform:scale(.98)}.chevron-rotated{transform:rotate(180deg);transition:transform .2s ease}.mobile-filter-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:1rem;padding:1rem;background-color:var(--card_bg);border-radius:12px;box-shadow:0 1px 3px var(--card_shadow);animation:slideDown .3s ease}.mobile-select{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.625rem;border-radius:8px;border:1px solid var(--border_color);font-size:.875rem;background-color:var(--card_bg);color:var(--primary_text);cursor:pointer;transition:border-color .2s ease}.mobile-select:focus{outline:none;border-color:var(--accent_color)}.mobile-select:disabled{opacity:.6;cursor:not-allowed;background-color:var(--hover_bg)}.dropdown{position:relative;width:100%}.dropdown-menu{position:absolute;z-index:50;background-color:var(--secondary_bg);border:1px solid var(--border_color);border-radius:8px;margin-top:.25rem;width:100%;max-height:200px;overflow-y:auto;box-shadow:0 4px 6px var(--card_shadow);list-style:none;padding:.25rem}.dropdown-item{display:block;padding:.625rem;width:100%;text-align:left;border:none;background:none;cursor:pointer;font-size:.875rem;color:var(--primary_text);border-radius:6px;transition:background-color .1s ease-in-out}.dropdown-item.active{background-color:var(--hover_bg)}.dropdown-item:disabled{cursor:not-allowed;opacity:.6}.mobile-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1rem}.mobile-kpi-card{background-color:var(--card_bg);padding:1rem;border-radius:12px;box-shadow:0 1px 3px var(--card_shadow);display:flex;align-items:center;gap:.75rem;transition:transform .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}.mobile-kpi-card:active{transform:scale(.98)}.mobile-kpi-content{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}.mobile-kpi-label{font-size:.75rem;font-weight:500;color:var(--secondary_text);text-transform:uppercase;letter-spacing:.025em}.mobile-kpi-value{font-size:1.5rem;font-weight:700;color:var(--primary_text);line-height:1;word-break:break-all}.mobile-kpi-total{border-left:4px solid var(--accent_color)}.mobile-kpi-present{border-left:4px solid var(--success_color)}.mobile-kpi-absent{border-left:4px solid var(--danger_color)}.mobile-kpi-rate{border-left:4px solid var(--warning_color)}.mobile-chart-card{background-color:var(--card_bg);border-radius:12px;padding:1rem;box-shadow:0 1px 3px var(--card_shadow);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-chart-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--primary_text)}.mobile-chart-wrapper{position:relative;height:280px;width:100%}.mobile-loading-container,.mobile-no-data-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:.75rem}.mobile-spinner{border:3px solid var(--secondary_bg);border-top:3px solid var(--accent_color);border-radius:50%;width:32px;height:32px;animation:spin 1s linear infinite}.mobile-loading-text,.mobile-no-data-text{margin:0;font-size:.875rem;color:var(--secondary_text);text-align:center}.mobile-error-container{background-color:var(--card_bg);border-radius:12px;padding:2rem 1rem;text-align:center;box-shadow:0 1px 3px var(--card_shadow)}.mobile-error-title{margin:1rem 0 .5rem;font-size:1.125rem;font-weight:600;color:var(--danger_color)}.mobile-error-text{margin:0;font-size:.875rem;color:var(--secondary_text);line-height:1.5}@media (min-width: 768px){.mobile-attendance-container{padding:1.5rem;max-width:1200px;margin:0 auto}.mobile-title{font-size:1.875rem}.mobile-kpi-grid{gap:1rem}.mobile-chart-wrapper{height:340px}.mobile-chart-card{padding:1.5rem}}@media (min-width: 1024px){.mobile-attendance-container{padding:2rem}.mobile-header{padding:1.5rem}.mobile-kpi-card{padding:1.25rem}.mobile-kpi-value{font-size:1.75rem}.mobile-chart-wrapper{height:380px}}@media (max-width: 480px){.mobile-attendance-container{padding:.75rem}.mobile-title{font-size:1.25rem}.mobile-kpi-card{padding:.875rem}.mobile-kpi-value{font-size:1.25rem}.mobile-chart-wrapper{height:240px}.mobile-chart-title{font-size:.9375rem}}.CustomDropdown-wrapper{position:relative;width:100%}.CustomDropdown-button{position:relative;width:100%;cursor:pointer;background-color:var(--card_bg);padding:10px 12px;border:1px solid var(--border_color);border-radius:6px;text-align:left;color:var(--primary_text);font-size:14px;display:flex;align-items:center;justify-content:space-between;transition:border-color .3s}.CustomDropdown-button:focus{outline:none;border-color:var(--accent_color)}.CustomDropdown-button-text{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.CustomDropdown-icon-wrapper{pointer-events:none;display:flex;align-items:center;margin-left:8px}.CustomDropdown-icon{height:20px;width:20px;color:var(--secondary_text)}.CustomDropdown-transition-leave{transition:opacity .1s ease-in}.CustomDropdown-transition-opacity-100{opacity:1}.CustomDropdown-transition-opacity-0{opacity:0}.CustomDropdown-options{position:absolute;margin-top:4px;max-height:240px;width:100%;overflow:auto;border-radius:6px;background-color:var(--card_bg);padding:4px 0;font-size:14px;box-shadow:0 4px 12px var(--card_shadow);border:1px solid var(--border_color);z-index:20}.CustomDropdown-options:focus{outline:none}.CustomDropdown-option{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 12px;display:flex;align-items:center;justify-content:space-between;color:var(--primary_text)}.CustomDropdown-option[data-active]{background-color:var(--accent_color);color:var(--accent_text)}.CustomDropdown-option-text{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.CustomDropdown-option-text-selected{font-weight:600}.CustomDropdown-check-icon-wrapper{display:flex;align-items:center;color:var(--accent_color)}.CustomDropdown-option[data-active] .CustomDropdown-check-icon-wrapper{color:var(--accent_text)}.CustomDropdown-check-icon{height:20px;width:20px}.CustomDropdown-button:disabled{background-color:var(--disabled_bg, #f3f4f6);cursor:not-allowed;opacity:.6}.attendance-container{max-width:1100px;margin:50px auto;background:var(--primary_bg);border-radius:20px;box-shadow:0 8px 24px var(--card_shadow);padding:40px;font-family:Inter,sans-serif}.title{text-align:center;font-size:2rem;color:var(--primary_text);margin-bottom:30px;font-weight:700;letter-spacing:-.5px}.date-picker{display:flex;justify-content:center;align-items:center;gap:15px;margin-bottom:30px}.date-picker label{font-size:1rem;font-weight:600;color:var(--primary_text)}.date-picker input[type=date]{padding:10px 16px;border:2px solid var(--border_color);border-radius:12px;background:var(--card_bg);color:var(--primary_text);font-size:1rem;cursor:pointer;outline:none;transition:all .3s ease}.date-picker input[type=date]:focus{border-color:var(--accent_color);box-shadow:0 0 0 3px #3b82f61a}.dropdowns{display:flex;justify-content:center;gap:20px;margin-bottom:30px;flex-wrap:wrap}.dropdown{padding:12px 20px;border:2px solid var(--border_color);border-radius:12px;background:var(--card_bg);color:var(--primary_text);font-size:1rem;cursor:pointer;outline:none;transition:all .3s ease;min-width:200px;font-weight:500}.dropdown:focus{border-color:var(--accent_color);box-shadow:0 0 0 3px #3b82f61a}.dropdown:disabled{opacity:.5;cursor:not-allowed}.stats{display:flex;justify-content:center;gap:30px;margin-bottom:30px;flex-wrap:wrap}.stat{display:flex;flex-direction:column;align-items:center;padding:20px 40px;border-radius:16px;box-shadow:0 4px 12px var(--card_shadow);min-width:140px}.present-stat{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.absent-stat{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.stat-label{font-size:.9rem;opacity:.95;margin-bottom:8px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2.5rem;font-weight:800}.quick-actions{display:flex;justify-content:center;gap:20px;margin-bottom:30px;flex-wrap:wrap}.quick-btn{padding:12px 28px;border:none;border-radius:12px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 8px #0000001a}.mark-all-present{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.mark-all-present:hover{transform:translateY(-2px);box-shadow:0 6px 12px #10b9814d}.mark-all-absent{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.mark-all-absent:hover{transform:translateY(-2px);box-shadow:0 6px 12px #ef44444d}.table-wrapper{overflow-x:auto;border-radius:12px;margin-bottom:30px}.attendance-table{width:100%;border-collapse:separate;border-spacing:0}.attendance-table thead{background:var(--table_header_bg);position:sticky;top:0;z-index:10}.attendance-table th{padding:16px;text-align:left;font-weight:700;color:var(--table_header_text);font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border_color)}.attendance-table th:first-child{border-top-left-radius:12px}.attendance-table th:last-child{border-top-right-radius:12px;text-align:center}.student-row{transition:all .2s ease;border-bottom:1px solid var(--border_color)}.student-row:hover{background:var(--card_bg)}.student-row:last-child{border-bottom:none}.attendance-table td{padding:18px 16px;color:var(--table_text);font-size:.95rem}.roll-number{font-weight:600;color:var(--primary_text);width:15%}.student-name{font-weight:500;width:45%}.attendance-actions{text-align:center;width:40%}.btn-group{display:inline-flex;gap:10px;justify-content:center}.attendance-btn{padding:10px 24px;border:2px solid transparent;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .3s ease;min-width:100px;background:var(--card_bg);color:var(--primary_text)}.present-btn{border-color:#10b981;color:#10b981}.present-btn:hover{background:#ecfdf5;transform:translateY(-1px)}.present-btn.active{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981;box-shadow:0 4px 8px #10b9814d}.absent-btn{border-color:#ef4444;color:#ef4444}.absent-btn:hover{background:#fef2f2;transform:translateY(-1px)}.absent-btn.active{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444;box-shadow:0 4px 8px #ef44444d}.submit-section{display:flex;justify-content:center;margin-top:30px}.submit-btn{padding:16px 60px;background:var(--button_primary_bg);color:var(--button_primary_text);border:none;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 16px var(--card_shadow);text-transform:uppercase;letter-spacing:.5px}.submit-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 20px var(--card_shadow)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.loading,.no-data{text-align:center;padding:40px;color:var(--secondary_text);font-size:1.1rem;font-weight:500}@media (max-width: 1200px){.attendance-container{max-width:95%;padding:35px}.title{font-size:1.8rem}.dropdown{min-width:180px}.stat{padding:18px 35px}.stat-value{font-size:2.2rem}.roll-number{width:18%}.student-name{width:42%}.attendance-actions{width:40%}}@media (max-width: 1024px){.attendance-container{margin:30px 20px;padding:30px}.title{font-size:1.6rem}.dropdowns{gap:15px}.dropdown{min-width:160px}.stats{gap:20px}.stat{padding:16px 30px;min-width:120px}.stat-value{font-size:2rem}.quick-actions{gap:15px}.quick-btn{padding:11px 24px;font-size:.9rem}.attendance-table th,.attendance-table td{padding:14px 12px;font-size:.9rem}.btn-group{gap:8px}.attendance-btn{padding:9px 20px;font-size:.85rem;min-width:90px}.submit-btn{padding:14px 50px;font-size:1rem}}@media (max-width: 768px){.attendance-container{margin:20px 15px;padding:25px;border-radius:16px}.title{font-size:1.5rem;margin-bottom:25px}.date-picker{flex-direction:column;gap:10px;margin-bottom:25px}.date-picker input[type=date]{width:100%}.dropdowns{flex-direction:column;gap:12px}.dropdown{width:100%;min-width:unset}.stats{gap:15px}.stat{flex:1;padding:14px 25px;min-width:110px}.stat-label{font-size:.85rem}.stat-value{font-size:1.8rem}.quick-actions{flex-direction:column;gap:12px}.quick-btn{width:100%;padding:12px 20px}.attendance-table th,.attendance-table td{padding:12px 10px}.roll-number{width:20%}.student-name{width:35%}.attendance-actions{width:45%}.btn-group{gap:6px}.attendance-btn{flex:1;min-width:unset;padding:8px 12px}.submit-btn{width:100%;padding:14px 40px}}@media (max-width: 640px){.attendance-container{margin:15px 10px;padding:20px}.title{font-size:1.4rem;margin-bottom:20px}.stats{gap:12px}.stat{padding:12px 20px}.stat-value{font-size:1.6rem}.attendance-table{font-size:.85rem}.attendance-table th,.attendance-table td{padding:10px 8px;font-size:.85rem}.roll-number{width:18%}.student-name{width:32%}.attendance-actions{width:50%}.attendance-btn{padding:7px 12px;font-size:.8rem}.submit-btn{padding:12px 35px;font-size:.95rem}}@media (max-width: 480px){.attendance-container{margin:10px 8px;padding:16px;border-radius:12px}.title{font-size:1.2rem;margin-bottom:18px}.date-picker label{font-size:.9rem}.date-picker input[type=date]{padding:9px 12px;font-size:.9rem}.dropdown{padding:10px 16px;font-size:.9rem}.stats{gap:10px}.stat{padding:10px 16px;min-width:100px}.stat-label{font-size:.75rem}.stat-value{font-size:1.4rem}.quick-btn{padding:10px 16px;font-size:.85rem}.attendance-table th,.attendance-table td{padding:8px 6px;font-size:.8rem}.roll-number{width:16%}.student-name{width:30%;font-size:.8rem}.attendance-actions{width:54%}.btn-group{gap:5px}.attendance-btn{flex:1;padding:6px 8px;font-size:.75rem;border-width:1.5px}.submit-btn{padding:11px 30px;font-size:.9rem}}@media (max-width: 360px){.attendance-container{padding:14px;margin:8px 5px}.title{font-size:1.1rem;margin-bottom:15px}.date-picker input[type=date]{padding:8px 10px;font-size:.85rem}.dropdown{padding:9px 14px;font-size:.85rem}.stat{padding:8px 14px}.stat-label{font-size:.7rem}.stat-value{font-size:1.2rem}.quick-btn{padding:9px 14px;font-size:.8rem}.attendance-table th,.attendance-table td{padding:7px 4px;font-size:.75rem}.attendance-btn{padding:5px 8px;font-size:.7rem}.submit-btn{padding:10px 25px;font-size:.85rem}}.topbar{position:fixed;top:0;left:0;right:0;height:60px;background:var(--topbar_bg, #ffffff);color:var(--topbar_text, #333);border-bottom:1px solid var(--border_color, #ddd);display:flex;justify-content:space-between;align-items:center;padding:0 1rem;z-index:1000;box-shadow:0 2px 4px #0000000d}.left-section{display:flex;align-items:center;gap:1rem}.hamburger{font-size:1.5rem;background:none;border:none;cursor:pointer;color:var(--topbar_text, #333)}.app-title{font-size:1.2rem;font-weight:600;color:var(--topbar_text, #333)}.right-section{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem}.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.user-details{display:flex;flex-direction:column;font-size:.85rem}.user-details .name{font-weight:500;color:var(--topbar_text, #333)}.user-details .role{font-size:.75rem;color:var(--topbar_text, #333)}.Sidebar-container{width:250px;background-color:var(--sidebar_bg);color:var(--sidebar_text);font-family:Inter,sans-serif;display:flex;flex-direction:column;height:100vh;position:fixed;left:0;top:0;overflow-y:auto;box-shadow:2px 0 8px var(--card_shadow);transition:width .3s ease}.Sidebar-header{font-size:1.25rem;font-weight:600;padding:1.5rem 1rem;text-align:center;border-bottom:1px solid var(--border_color);background:var(--secondary_bg)}.Sidebar-logo{width:90px;height:90px;background-color:var(--hover_bg);border-radius:8px;margin:0 auto;display:flex;align-items:center;justify-content:center;overflow:hidden}.Sidebar-logo-img{width:100%;height:100%;object-fit:contain}.Sidebar-institute-name{text-align:center;margin-top:8px;font-weight:700;font-size:14px;color:var(--sidebar_text)}.Sidebar-menu{flex:1;padding:.5rem 0}.Sidebar-menu-item{display:flex;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background .2s ease}.Sidebar-menu-item:hover{color:var(--sidebar_submenu_text_hover)}.Sidebar-icon{margin-right:.75rem;font-size:1.1rem;color:var(--accent_color)}.Sidebar-label{flex:1;font-weight:500;font-size:.95rem}.Sidebar-chevron{transition:color .3s,transform .3s;color:var(--sidebar_text)}.Sidebar-chevron.rotate{transform:rotate(180deg)}.Sidebar-chevron.open{color:var(--accent_color)}.Sidebar-submenu{display:flex;flex-direction:column;margin-left:2.5rem;margin-top:.25rem;margin-bottom:.25rem}.Sidebar-submenu-item{padding:.4rem .5rem;font-size:.9rem;color:var(--sidebar_submenu_text);text-decoration:none}.Sidebar-submenu-item.active{font-weight:700;color:var(--sidebar_submenu_text);transition:all .5s ease}.Sidebar-submenu-item:hover{color:var(--sidebar_submenu_text_hover);padding-left:.75rem}.Sidebar-footer{padding:1rem;border-top:1px solid var(--border_color)}.Sidebar-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;background:var(--danger_color);border:none;border-radius:6px;padding:.6rem .75rem;color:var(--button_primary_text);font-weight:500;cursor:pointer;transition:background .2s ease,transform .2s ease}.Sidebar-logout:hover{background:#ff1900;transform:translateY(-1px)}.Sidebar-container::-webkit-scrollbar{width:6px}.Sidebar-container::-webkit-scrollbar-track{background:var(--secondary_bg)}.Sidebar-container::-webkit-scrollbar-thumb{background:var(--hover_bg);border-radius:3px}.Sidebar-container::-webkit-scrollbar-thumb:hover{background:var(--border_color)}@media (min-width: 576px) and (max-width: 992px){.Sidebar-container{width:200px}.Sidebar-header{padding:1rem .5rem;font-size:1rem}.Sidebar-logo{width:70px;height:70px}.Sidebar-institute-name{font-size:12px}.Sidebar-menu-item{padding:.6rem .8rem}.Sidebar-icon{font-size:1rem;margin-right:.5rem}.Sidebar-label{font-size:.85rem}.Sidebar-submenu-item{font-size:.8rem;padding:.35rem .4rem}.Sidebar-logout{padding:.5rem;font-size:.85rem}}.overlay{position:fixed;inset:0;background:#00000080;z-index:900}.Sidebar-container{left:-260px;transition:left .3s ease-in-out;z-index:1000}.Sidebar-container.open{left:0}.Sidebar-close-btn{display:none;position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--sidebar_text);font-size:1.2rem;cursor:pointer}@media (max-width: 768px){.Sidebar-close-btn{display:block}}.spinner-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#fff9;z-index:2000}.layout{display:flex;min-height:100vh;background:var(--body_bg-gradient)}.content{flex:1;padding:1.5rem;margin-top:60px;transition:filter .3s ease}.content.blur{filter:blur(2px)}.Layout-back-button-container{margin:10px 20px}.Layout-back-button{display:flex;align-items:center;gap:6px;background:#005eff;border:1px solid #ddd;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:17px}select{width:100%;max-width:100%;box-sizing:border-box;font-size:15px;padding:8px 10px;border-radius:6px;background-color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}select option{white-space:normal;word-wrap:break-word}@media (max-width: 480px){select{font-size:14px;padding:6px 8px;width:100%}.content select,.layout select{max-width:100%;width:100%}}@media (min-width: 481px) and (max-width: 1024px){select{font-size:15px;padding:7px 10px}}@media (min-width: 1025px){select{font-size:16px;padding:8px 12px;min-width:200px;max-width:100%}}select{max-width:100vw}select option{overflow-wrap:break-word}.NotificationModalComponent-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000}.NotificationModalComponent-content{background:var(--card_bg);padding:25px 30px;border-radius:12px;box-shadow:var(--card-shadow);max-width:400px;width:90%;text-align:center}.NotificationModalComponent-message{font-size:18px;font-weight:600;margin-bottom:20px;color:var(--primary_text)}.NotificationModalComponent-buttons{display:flex;justify-content:center;gap:15px}.NotificationModalComponent-confirm-btn{background-color:var(--danger_color);color:var(----button_primary_text);border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-weight:500;transition:background-color .2s}.NotificationModalComponent-confirm-btn:hover{background-color:var(--danger-hover)}.NotificationModalComponent-cancel-btn{background:var(--secondary_bg);color:var(----button_primary_text);border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-weight:500;transition:background-color .2s}.NotificationModalComponent-cancel-btn:hover{background-color:var(--hover_bg)}.viewAssignments-container{padding:2rem;font-family:Segoe UI,sans-serif;min-height:100vh}.filters-bar{display:flex;gap:1rem;margin-bottom:2rem;background:var(--card_bg);padding:1rem 1.5rem;border-radius:14px;box-shadow:0 4px 12px var(--card_shadow);align-items:center;flex-wrap:wrap}.filters-bar input,.filters-bar select{padding:.6rem .8rem;border-radius:8px;border:1px solid var(--border_color);flex:1;min-width:150px;transition:.2s ease;background:var(--hover_bg);color:var(--primary_text)}.filters-bar input:focus,.filters-bar select:focus{border-color:var(--accent_color);outline:none}.clear-filters-btn{background:var(--button_primary_bg);color:var(--button_primary_text);padding:.6rem 1.4rem;border-radius:8px;border:none;cursor:pointer;font-weight:500;transition:.25s ease;white-space:nowrap}.clear-filters-btn:hover{background:var(--accent_color);transform:translateY(-2px)}.results-summary{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:.5rem .2rem;color:var(--secondary_text);font-size:.9rem}.results-info{flex-shrink:0}.per-page-selector{display:flex;align-items:center;gap:.5rem}.assignments-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.no-assignments{grid-column:1 / -1;text-align:center;padding:3rem;color:var(--secondary_text)}.no-assignments p{font-size:1.1rem;margin:0}.assignment-card{background:var(--card_bg);padding:1.4rem;border-radius:14px;box-shadow:0 4px 12px var(--card_shadow);display:flex;flex-direction:column;gap:1rem;transition:.25s ease}.assignment-card:hover{transform:translateY(-6px);box-shadow:0 8px 20px var(--card_shadow)}.assignment-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.assignment-header h3{font-size:1.2rem;font-weight:600;color:var(--primary_text);margin:0;flex:1;line-height:1.3}.due-date{font-size:.85rem;color:var(--secondary_text);background:var(--hover_bg);padding:.3rem .6rem;border-radius:6px;white-space:nowrap;border:1px solid var(--border_color)}.assignment-images{margin:.5rem 0}.images-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.8rem;color:var(--secondary_text);font-size:.9rem;font-weight:500}.images-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;max-width:100%}.image-thumbnail{position:relative;aspect-ratio:16/9;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s ease;border:1px solid var(--border_color)}.image-thumbnail:hover{transform:scale(1.05)}.image-thumbnail img{width:100%;height:100%;object-fit:cover;display:block}.more-images{display:flex;align-items:center;justify-content:center;background:var(--hover_bg);border:1px solid var(--border_color);border-radius:8px;color:var(--secondary_text);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.more-images:hover{background:var(--accent_color);color:#fff}.assignment-body{font-size:.95rem;color:var(--primary_text);flex:1}.assignment-body p{margin:.4rem 0;line-height:1.4}.assignment-body .description{margin-top:.8rem;padding-top:.8rem;border-top:1px solid var(--border_color)}.assignment-footer{display:flex;justify-content:flex-end;gap:.6rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border_color)}.icon-btn{border:none;padding:.6rem;border-radius:10px;cursor:pointer;font-size:1rem;transition:.25s ease;display:flex;align-items:center;justify-content:center;min-width:40px;height:40px}.icon-btn.view{background:var(--info_color);color:#fff}.icon-btn.delete{background:var(--danger_color);color:#fff}.icon-btn:hover{transform:scale(1.12)}.va-pagination-wrapper{margin-top:2rem;display:flex;justify-content:center;align-items:center}.va-pagination-controls{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;justify-content:center}.va-pagination-btn{border:1px solid var(--border_color);background:var(--card_bg);color:var(--primary_text);padding:.5rem .8rem;border-radius:8px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;gap:.3rem;transition:all .2s ease}.va-pagination-btn:hover:not(.va-pagination-disabled){background:var(--accent_color);color:#fff;transform:translateY(-2px)}.va-pagination-btn.va-pagination-disabled{opacity:.5;cursor:not-allowed}.va-pagination-btn.va-pagination-active{background:var(--accent_color);color:#fff;border-color:var(--accent_color);font-weight:600}.va-pagination-pages{display:flex;gap:.3rem;align-items:center}.va-pagination-ellipsis{padding:0 .3rem;color:var(--secondary_text);font-weight:600}@media (max-width: 480px){.va-pagination-btn{padding:.4rem .6rem;font-size:.8rem}.va-pagination-controls{gap:.3rem}}@media (max-width: 1024px){.viewAssignments-container{padding:1.5rem}.assignments-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem}.filters-bar{flex-direction:column;align-items:stretch;gap:.8rem;padding:1rem}.filters-bar input,.filters-bar select{min-width:auto}}@media (max-width: 768px){.viewAssignments-container{padding:1rem}.assignments-grid{grid-template-columns:1fr;gap:1rem}.assignment-card{padding:1rem}.assignment-header{flex-direction:column;align-items:flex-start;gap:.5rem}.assignment-header h3{font-size:1.1rem}.due-date{font-size:.8rem;padding:.25rem .5rem}.assignment-body{font-size:.9rem}.assignment-footer{gap:.4rem}.icon-btn{padding:.5rem;min-width:36px;height:36px;font-size:.9rem}.images-grid{grid-template-columns:repeat(2,1fr)}.image-modal-overlay{padding:1rem}.close-image-modal{width:36px;height:36px;font-size:1.3rem}}@media (max-width: 480px){.filters-bar{padding:.8rem}.filters-bar input,.filters-bar select{font-size:.9rem;padding:.5rem .6rem}.clear-filters-btn{padding:.5rem 1rem;font-size:.9rem}.assignment-header h3{font-size:1rem}.images-grid{grid-template-columns:1fr;gap:.4rem}.image-thumbnail{aspect-ratio:2/1}}@media (prefers-color-scheme: dark){.image-modal{background:var(--card_bg)}}.Alert-wrapper{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:2000}.Alert-card{padding:16px 20px;border-radius:8px;box-shadow:0 2px 8px var(--card_shadow);max-width:320px;width:90%;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;transition:transform .2s ease,box-shadow .2s ease;text-align:center;background-color:var(--card_bg)}.Alert-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--card-shadow)}.Alert-title{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--primary_text)}.Alert-message{margin:0;font-size:14px;color:var(--secondary_text)}.Alert-info{border-left:4px solid var(--accent_color);color:var(--accent_text)}.Alert-success,.Alert-warning,.Alert-error{border-left:4px solid var(--accent_color);color:var(--primary_text)}.back-btn{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;background-color:transparent;border:none;color:var(--accent_color);font-weight:600;cursor:pointer;font-size:.95rem;transition:all .2s ease-in-out;padding:.5rem 0}.back-btn:hover{color:var(--button_primary_bg)}.form-box{flex:1;background-color:var(--card_bg);padding:1rem 1.2rem;border-radius:12px;box-shadow:0 2px 12px var(--card_shadow);display:flex;flex-direction:column}.form-box select,.form-box textarea,.form-box input[type=text],.form-box input[type=date]{padding:.6rem .8rem;border:1px solid var(--border_color);border-radius:8px;font-size:.95rem;outline:none;background-color:var(--card_bg);color:var(--primary_text);transition:all .2s ease-in-out}.form-box select:disabled,.form-box input:disabled,.form-box textarea:disabled{background-color:var(--hover_bg);color:var(--secondary_text);cursor:not-allowed}.form-box select:hover:not(:disabled),.form-box input:hover:not(:disabled),.form-box textarea:hover:not(:disabled){border-color:var(--accent_color)}.teacher-search-input{margin-bottom:.5rem;border:1px solid var(--border_color);border-radius:8px;padding:.6rem .8rem;background:var(--card_bg);color:var(--primary_text)}.target-selectors{display:flex;gap:.8rem}.target-selectors select{flex:1}.upload-zone{display:flex;justify-content:center;align-items:center;min-height:100px;border:2px dashed var(--border_color);border-radius:12px;background:var(--card_bg);cursor:pointer;transition:all .3s ease}.upload-content span{font-size:.95rem;font-weight:500}.image-item{position:relative;border-radius:12px;overflow:hidden;background:var(--card_bg);box-shadow:0 2px 8px var(--card_shadow);transition:transform .2s ease;cursor:pointer}.no-images{text-align:center;color:var(--secondary_text);font-style:italic;padding:2rem;border:1px dashed var(--border_color);border-radius:8px;background:var(--hover_bg)}.image-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:2rem}.image-modal{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;border-radius:12px;overflow:hidden;background:#fff}.image-modal-header{position:absolute;top:10px;right:10px;z-index:10000}.close-image-modal{background:#000000b3;color:#fff;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.close-image-modal:hover{background:#000000e6}.image-modal-content{display:flex;align-items:center;justify-content:center}.image-modal-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px}.button-group{display:flex;gap:1rem;justify-content:flex-start;align-items:center}.edit-btn,.assignment-details-save-btn,.cancel-btn{font-weight:600;padding:.8rem 1.5rem;border:none;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease-in-out;color:#fff;font-size:.95rem;min-width:140px;justify-content:center}.edit-btn{background-color:var(--button_primary_bg)}.edit-btn:hover{background-color:var(--accent_color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.assignment-details-save-btn{background-color:var(--success_color)}.assignment-details-save-btn:hover{background-color:var(--success_color);filter:brightness(.9);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.cancel-btn{background-color:var(--danger_color)}.cancel-btn:hover{background-color:var(--danger_color);filter:brightness(.9);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.Ad-submit-btn{font-weight:600;padding:.8rem 1.5rem;border:none;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease-in-out;color:var(--button_primary_text);background-color:var(--button_primary_bg);font-size:.95rem;min-width:140px;justify-content:center}.loading{text-align:center;font-size:1.1rem;color:var(--accent_color);margin-top:3rem}@media (max-width: 1024px){.assignment-page{padding:1rem}.form-row.top-row{flex-direction:column}.target-selectors{flex-direction:column;gap:.5rem}.image-gallery{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem}}@media (max-width: 768px){.assignment-page{padding:.5rem;margin:1rem auto}.page-title{font-size:1.5rem;margin-bottom:1.5rem}.form-row{flex-direction:column;gap:1rem}.target-selectors{flex-direction:column}.image-gallery{grid-template-columns:repeat(2,1fr);gap:.6rem}.image-item img{height:120px}.button-group{flex-direction:column;align-items:stretch}.edit-btn,.assignment-details-save-btn,.cancel-btn{min-width:auto;padding:.7rem 1rem}.upload-zone{min-height:80px}.upload-content span{font-size:.9rem}.image-modal-overlay{padding:1rem}.close-image-modal{width:36px;height:36px;font-size:1.3rem}}@media (max-width: 480px){.image-gallery{grid-template-columns:1fr;gap:.5rem}.image-item img{height:160px}.upload-header{flex-direction:column;align-items:flex-start;gap:.5rem}.upload-info{font-size:.8rem}}@media (prefers-color-scheme: dark){.upload-zone{border-color:#444}.upload-zone:hover{border-color:var(--accent_color);background:rgba(var(--accent_color_rgb),.1)}.image-modal{background:var(--card_bg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.image-item{animation:fadeInUp .3s ease}.upload-zone:focus,.image-remove-btn:focus,.edit-btn:focus,.assignment-details-save-btn:focus,.cancel-btn:focus{outline:2px solid var(--accent_color);outline-offset:2px}.assignment-page{max-width:1100px;margin:2rem auto;padding:1rem 2rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--primary_text)}.page-title{font-size:2rem;margin-bottom:2rem;text-align:center;color:var(--primary_text)}.assignment-form{display:flex;flex-direction:column;gap:1.5rem}.form-row,.form-row.top-row{display:flex;gap:1.5rem}.form-box{flex:1;background-color:var(--card_bg);padding:1rem 1.2rem;border-radius:12px;box-shadow:0 2px 8px var(--card_shadow);display:flex;flex-direction:column}.form-box label{font-weight:600;margin-bottom:.5rem;color:var(--secondary_text)}.form-box select,.form-box textarea,.form-box input[type=text],.form-box input[type=date]{padding:.6rem .8rem;border:1px solid var(--border_color);border-radius:8px;font-size:.95rem;outline:none;background:var(--card_bg);color:var(--primary_text);transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.form-box select:hover,.form-box textarea:hover,.form-box input:hover{border-color:var(--accent_color)}.form-box textarea{resize:vertical;min-height:100px}.full-width{flex:1 1 100%}.image-upload-section{width:100%}.upload-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.upload-label{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--secondary_text)}.upload-info{font-size:.85rem;color:var(--secondary_text);opacity:.8}.upload-area{margin-bottom:1.5rem}.upload-zone{display:flex;justify-content:center;align-items:center;min-height:120px;border:2px dashed var(--border_color);border-radius:12px;background:var(--card_bg);cursor:pointer;transition:all .3s ease}.upload-zone:hover{border-color:var(--accent_color);background:rgba(var(--accent_color_rgb),.05)}.upload-content{display:flex;flex-direction:column;align-items:center;gap:.8rem;color:var(--secondary_text)}.upload-content span{font-size:1rem;font-weight:500}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-top:1rem}.image-item{position:relative;border-radius:12px;overflow:hidden;background:var(--card_bg);box-shadow:0 2px 8px var(--card_shadow);transition:transform .2s ease}.image-item:hover{transform:translateY(-2px)}.image-item img{width:100%;height:140px;object-fit:cover;display:block}.image-controls{position:absolute;top:8px;right:8px;display:flex;gap:.4rem;opacity:0;transition:opacity .2s ease}.image-item:hover .image-controls{opacity:1}.image-remove-btn{width:32px;height:32px;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.8rem;transition:all .2s ease;background:#f44336e6;color:#fff}.image-remove-btn:hover{background:#f44336;transform:scale(1.1)}.cropper-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;display:flex;align-items:center;justify-content:center}.cropper-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center}.cropper-container{background:var(--card_bg);border-radius:16px;padding:1.5rem;max-width:90vw;max-height:90vh;width:600px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d}.cropper-header{margin-bottom:1rem}.cropper-header h3{margin:0;color:var(--primary_text);font-size:1.3rem}.cropper-box{position:relative;width:100%;height:400px;background:#000;border-radius:8px;overflow:hidden;margin-bottom:1rem}.zoom-control{display:flex;align-items:center;gap:1rem}.zoom-control label{font-weight:500;color:var(--secondary_text);min-width:50px}.zoom-slider{flex:1;height:6px;border-radius:3px;background:var(--border_color);outline:none;-webkit-appearance:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent_color);cursor:pointer;border:2px solid white;box-shadow:0 2px 6px #0003}.zoom-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent_color);cursor:pointer;border:2px solid white;box-shadow:0 2px 6px #0003}.cropper-buttons{display:flex;justify-content:flex-end;gap:.8rem}.btn-crop-done,.btn-crop-cancel{padding:.6rem 1.2rem;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:80px}.btn-crop-done{background:var(--success_color, #4caf50);color:#fff}.btn-crop-done:hover{background:var(--success_hover, #45a049);transform:translateY(-1px)}.btn-crop-cancel{background:var(--danger_color, #f44336);color:#fff}.btn-crop-cancel:hover{background:var(--danger_hover, #da190b);transform:translateY(-1px)}.submit-btn{background-color:var(--button_primary_bg);color:var(--button_primary_text);font-weight:600;padding:.8rem 2rem;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease-in-out;align-self:flex-start;font-size:1rem;min-width:160px}.submit-btn:hover:not(:disabled){background-color:var(--accent_color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.success-msg{color:var(--success_color);font-weight:500}.error-msg{color:var(--danger_color);font-weight:500}@media (max-width: 768px){.assignment-page{padding:1rem}.form-row.top-row{flex-direction:column}.image-gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.8rem}.image-item img{height:120px}@media (max-width: 480px){.image-gallery{grid-template-columns:repeat(2,1fr)}.upload-header{flex-direction:column;align-items:flex-start;gap:.5rem}.upload-info{font-size:.8rem}}@media (prefers-color-scheme: dark){.upload-zone{border-color:#444}.upload-zone:hover{border-color:var(--accent_color);background:rgba(var(--accent_color_rgb),.1)}.cropper-box{background:#1a1a1a}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.image-item{animation:fadeInUp .3s ease}.upload-zone:focus,.image-remove-btn:focus,.submit-btn:focus{outline:2px solid var(--accent_color);outline-offset:2px}.submit-btn:disabled:after{content:"";display:inline-block;width:16px;height:16px;margin-left:8px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}}.timetable-container{padding:24px;min-height:100vh;background:var(--body_bg);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.timetable-header{margin-bottom:24px}.timetable-title{font-size:28px;font-weight:700;color:var(--primary_text);margin:0}.timetable-filters{display:flex;gap:16px;margin-bottom:32px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:8px;flex:1;min-width:200px}.filter-label{font-size:14px;font-weight:600;color:var(--primary_text)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:var(--card_bg);border-radius:12px;box-shadow:0 2px 8px var(--card_shadow)}.empty-state-icon{font-size:64px;margin-bottom:16px;opacity:.7}.empty-state-text{font-size:16px;color:var(--secondary_text);text-align:center;margin:0}.timetable-desktop{display:block}.timetable-mobile{display:none}.table-wrapper{overflow-x:auto;background:var(--card_bg);border-radius:12px;box-shadow:0 2px 8px var(--card_shadow)}.timetable-table{width:100%;border-collapse:collapse;min-width:800px}.timetable-table thead{background:var(--table_header_bg);position:sticky;top:0;z-index:10}.timetable-table th{padding:16px;text-align:center;font-weight:600;font-size:14px;color:var(--table_header_text);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border_color)}.time-header{background:var(--accent_color);color:var(--button_primary_text);border-bottom-color:var(--accent_color)}.day-header{font-weight:600}.timetable-table td{padding:16px;text-align:center;border:1px solid var(--border_color);color:var(--table_text);font-size:14px;transition:background .2s ease}.time-cell{font-weight:600;background:var(--secondary_bg);color:var(--primary_text);white-space:nowrap}.subject-cell{cursor:default}.subject-cell:hover,.timetable-table tbody tr:hover .time-cell{background:var(--hover_bg)}.day-card{background:var(--card_bg);border-radius:12px;margin-bottom:16px;overflow:hidden;box-shadow:0 2px 8px var(--card_shadow);border:1px solid var(--border_color)}.day-card-header{background:var(--accent_color);padding:16px;border-bottom:1px solid var(--border_color)}.day-name{margin:0;font-size:18px;font-weight:700;color:var(--button_primary_text);text-transform:uppercase;letter-spacing:.5px}.day-card-body{padding:12px;display:flex;flex-direction:column;gap:12px}.period-item{display:flex;align-items:center;background:var(--secondary_bg);border-radius:8px;overflow:hidden;transition:all .2s ease;border:1px solid var(--border_color)}.period-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--card_shadow)}.period-number-container{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--primary_bg);padding:12px;width:80px;align-self:stretch;border-right:1px solid var(--border_color)}.period-number-label{font-size:11px;font-weight:600;color:var(--accent_color);text-transform:uppercase;letter-spacing:.5px}.period-number{font-size:24px;font-weight:700;color:var(--accent_color)}.period-details{flex:1;padding:12px 16px;display:flex;flex-direction:column;gap:4px}.period-subject{font-size:16px;font-weight:600;color:var(--primary_text)}.period-time{font-size:13px;color:var(--secondary_text);font-weight:500}@media (max-width: 1200px){.timetable-container{padding:20px}.timetable-title{font-size:24px}.filter-group{min-width:180px}.timetable-table{min-width:700px}.timetable-table th,.timetable-table td{padding:12px 8px;font-size:13px}}@media (max-width: 768px){.timetable-container{padding:16px}.timetable-title{font-size:22px}.timetable-filters{flex-direction:column;gap:12px}.filter-group{min-width:100%}.timetable-desktop{display:none}.timetable-mobile{display:block}.empty-state{padding:40px 20px}.empty-state-icon{font-size:48px}.empty-state-text{font-size:14px}}@media (max-width: 480px){.timetable-container{padding:12px}.timetable-title{font-size:20px}.day-card-header{padding:12px}.day-name{font-size:16px}.period-subject{font-size:15px}.period-number-container{width:70px}}.all-notices{max-width:1500px;margin:30px auto;padding:25px 30px;border-radius:16px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--primary_text);transition:all .3s ease}.notices-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:12px;border-bottom:3px solid var(--border_color);flex-wrap:wrap;gap:12px}.all-notices h2{font-size:2.2rem;margin:0;color:var(--accent_color);font-weight:700}.notices-count{font-size:.95rem;color:var(--secondary_text);font-weight:500;background:var(--info_bg);padding:8px 16px;border-radius:20px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid var(--border_color);border-top:4px solid var(--accent_color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-container p{color:var(--button_danger_bg);font-size:1.1rem;font-weight:600}.empty-state{text-align:center;padding:80px 20px;background:var(--card_bg);border-radius:16px;border:2px dashed var(--border_color)}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state h3{font-size:1.5rem;color:var(--accent_color);margin-bottom:12px;font-weight:600}.empty-state p{color:var(--secondary_text);font-size:1rem}.notices-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem;margin-bottom:2rem}.notice-card{background:var(--card_bg);border-radius:16px;padding:24px;box-shadow:0 6px 20px #00000014;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease;border:1px solid var(--border_color);position:relative;overflow:hidden}.notice-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--accent_color),var(--button_primary_bg));transform:scaleY(0);transition:transform .3s ease}.notice-card:hover:before{transform:scaleY(1)}.notice-card:hover{transform:translateY(-6px);box-shadow:0 12px 28px #00000026}.notice-title{margin:0 0 12px;font-size:1.4rem;font-weight:700;color:var(--accent_color);line-height:1.3}.notice-description{margin:12px 0;font-size:1rem;line-height:1.6;white-space:pre-wrap;word-break:break-word;color:var(--secondary_text);flex-grow:1}.notice-assigned{margin:12px 0;padding:14px;background:var(--info_bg);border-radius:12px;font-size:.95rem;color:var(--accent_color);border-left:3px solid var(--accent_color)}.notice-assigned p{margin:4px 0}.notice-assigned strong{font-weight:600;color:var(--accent_dark)}.notice-issued-by{font-size:.9rem;font-weight:500;color:var(--secondary_text);margin:8px 0 4px}.notice-date{font-size:.85rem;color:var(--tertiary_text);margin-top:4px;margin-bottom:12px}.card-actions{display:flex;gap:12px;margin-top:18px}.edit-btn,.delete-btn{border:none;cursor:pointer;border-radius:10px;padding:10px 20px;font-size:.95rem;font-weight:600;transition:all .25s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:120px}.edit-btn{background:var(--button_primary_bg);color:var(--button_primary_text);box-shadow:0 4px 12px #3b82f64d}.edit-btn:hover{background:var(--button_primary_hover);transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #3b82f666}.delete-btn{background:var(--button_danger_bg);color:var(--button_danger_text);box-shadow:0 4px 12px #ef44444d}.delete-btn:hover{background:var(--button_danger_hover);transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #ef444466}.pagination-container{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:40px;padding:24px 0;flex-wrap:wrap}.pagination-numbers{display:flex;gap:8px;align-items:center}.page-number{min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border_color);background:var(--card_bg);color:var(--primary_text);border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .25s ease;padding:0 12px}.page-number:hover{border-color:var(--accent_color);background:var(--info_bg);transform:translateY(-2px)}.page-number.active{background:var(--accent_color);color:#fff;border-color:var(--accent_color);box-shadow:0 4px 12px #3b82f64d;transform:scale(1.1)}.page-dots{color:var(--secondary_text);font-weight:600;padding:0 8px;-webkit-user-select:none;user-select:none}.pagination-nav{display:flex;align-items:center;gap:8px;padding:10px 20px;border:2px solid var(--border_color);background:var(--card_bg);color:var(--primary_text);border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .25s ease;min-width:110px;justify-content:center}.pagination-nav:hover:not(:disabled){border-color:var(--accent_color);background:var(--accent_color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.pagination-nav:disabled{opacity:.4;cursor:not-allowed;border-color:var(--border_color);background:var(--card_bg)}.pagination-nav span{font-size:1.2rem;line-height:1}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;padding:12px;z-index:1000}.modal{background:var(--card_bg);padding:20px 22px;border-radius:14px;width:420px;max-width:95%;max-height:80vh;overflow-y:auto;box-shadow:0 6px 20px #00000026;animation:fadeIn .25s ease-in-out;text-align:left}.modal h3{margin-bottom:14px;font-size:1.2rem;font-weight:700;color:var(--accent_dark);border-bottom:2px solid var(--border_color);padding-bottom:6px}.modal .form-group{margin-bottom:10px}.modal .form-group label{font-size:.8rem;font-weight:600;color:var(--secondary_text)}.modal .form-group input,.modal .form-group textarea,.modal .form-group select{width:100%;padding:7px 10px;border-radius:8px;border:1px solid var(--border_color);font-size:.85rem;transition:all .25s ease;color:var(--primary_text);background-color:var(--card_bg)}.modal .form-group input:focus,.modal .form-group textarea:focus,.modal .form-group select:focus{border-color:var(--button_primary_bg);box-shadow:0 0 0 2px #3b82f633}.modal-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 16px;margin-top:10px}.modal-form-grid .form-group{margin-bottom:0}.modal-actions{margin-top:16px;display:flex;align-items:center;gap:10px;justify-content:flex-end}.modal-actions .cancel-btn,.modal-actions .confirm-btn{box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;height:40px;min-height:40px;padding:0 16px;font-size:.9rem;font-weight:600;line-height:1;border-radius:8px;cursor:pointer;font-family:inherit;transition:transform .16s ease,box-shadow .16s ease}.modal-actions .cancel-btn{background:transparent;color:var(--secondary_text);border:1px solid var(--border_color)}.modal-actions .confirm-btn{background:var(--button_primary_bg);color:var(--button_primary_text);border:none;box-shadow:0 6px 14px #2563eb2e}.modal-actions .cancel-btn:hover,.modal-actions .confirm-btn:hover{transform:translateY(-2px)}.modal-actions .cancel-btn{order:1}.modal-actions .confirm-btn{order:2;margin-left:auto}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.all-notices{padding:20px 16px}.notices-header{flex-direction:column;align-items:flex-start}.all-notices h2{font-size:1.8rem}.pagination-container{gap:12px}.pagination-numbers{order:3;width:100%;justify-content:center}.pagination-nav{min-width:auto;flex:1}}@media (max-width: 640px){.notices-container{grid-template-columns:1fr}.card-actions{flex-direction:column}.edit-btn,.delete-btn{width:100%}.modal{width:100%;padding:20px}.modal h3{font-size:1.2rem}.modal-form-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column;align-items:stretch}.modal-actions .cancel-btn,.modal-actions .confirm-btn{width:100%;min-width:unset;height:44px;margin-left:0;order:unset}.page-number{min-width:36px;height:36px;font-size:.9rem}.pagination-nav{font-size:.85rem;padding:8px 14px}.notices-count{font-size:.85rem;padding:6px 12px}}@media (max-width: 480px){.all-notices h2{font-size:1.6rem}.notice-card{padding:18px}.notice-title{font-size:1.2rem}.notice-description{font-size:.95rem}.pagination-numbers{gap:4px}.page-number{min-width:32px;height:32px;font-size:.85rem;padding:0 8px}.pagination-nav{font-size:.8rem;padding:6px 10px;min-width:90px}.pagination-nav span{font-size:1rem}}form-grid{grid-template-columns:1fr}.student-address-edit{display:flex;flex-direction:column;gap:.3rem;max-width:700px;margin:0 auto;font-family:Arial,sans-serif;padding:.3rem;background-color:var(--body_bg)}.form-group{display:flex;flex-direction:column;margin-bottom:0}.form-group label{font-weight:700;margin-bottom:.15rem;font-size:.9rem;color:var(--primary_text)}.form-group input,.form-group textarea,.form-group select{padding:.3rem .5rem;border:1px solid var(--border_color);border-radius:4px;font-size:.9rem;background-color:var(--body_bg);color:var(--primary_text);transition:border-color .2s ease}textarea{resize:vertical;min-height:45px}.error{border-color:var(--danger_color)!important}.error-text,.info-text{font-size:.8rem;margin-top:.125rem}.error-text{color:var(--danger_color)}.info-text{color:var(--secondary_text)}select{cursor:pointer;background-color:var(--card_bg)}@media (min-width: 576px) and (max-width: 992px){.student-address-edit{gap:.2rem;padding:.2rem .35rem;max-width:100%}.form-group input,.form-group textarea,.form-group select{font-size:.85rem;padding:.2rem .3rem}.form-group label{font-size:.85rem}}@media (min-width: 993px) and (max-width: 1399px){.student-address-edit{gap:.25rem;padding:.25rem .4rem;max-width:650px}.form-group input,.form-group textarea,.form-group select{font-size:.88rem;padding:.25rem .4rem}.form-group label{font-size:.88rem}}.profile-page-wide{width:100%;min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;position:relative;overflow-x:hidden}.profile-hero-strip{position:absolute;top:0;left:-10%;width:120%;height:250px;background:linear-gradient(135deg,#6366f1,#4f46e5);transform:skewY(-6deg);box-shadow:0 10px 30px #00000026;z-index:0}.profile-container{position:relative;z-index:1;display:flex;flex-wrap:wrap;max-width:1200px;margin:0 auto;padding:4rem 2rem;gap:3rem}.profile-left{flex:1 1 300px;display:flex;flex-direction:column;align-items:center}.avatar-wrap{position:relative;z-index:2}.avatar-img{width:220px;height:220px;border-radius:20px;object-fit:cover;box-shadow:0 8px 20px #0003;border:4px solid #fff;position:relative;z-index:2}.avatar-edit{position:absolute;bottom:15px;right:15px;background:#4f46e5;color:#fff;border:none;border-radius:50%;padding:.6rem;cursor:pointer;font-size:1.2rem;box-shadow:0 4px 10px #0003;z-index:3;transition:all .3s ease}.avatar-edit:hover{background:#4338ca;transform:scale(1.1)}.edit-btn-wide{margin-top:2rem;background:#4f46e5;color:#fff;border:none;padding:.8rem 1.8rem;border-radius:12px;font-size:1rem;cursor:pointer;transition:background .3s ease;z-index:2;position:relative}.edit-btn-wide:hover{background:#4338ca}.edit-actions{margin-top:2rem;display:flex;gap:1rem;z-index:2;position:relative}.save-btn{background:#4f46e5;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:12px;font-size:1rem;cursor:pointer;transition:background .3s ease;display:flex;align-items:center;gap:.5rem}.save-btn:hover{background:#4338ca}.save-btn:disabled{background:#9ca3af;cursor:not-allowed}.cancel-btn{background:#e5e7eb;color:#111;border:none;padding:.8rem 1.5rem;border-radius:12px;font-size:1rem;cursor:pointer;transition:background .3s ease;display:flex;align-items:center;gap:.5rem}.cancel-btn:hover{background:#d1d5db}.profile-right{flex:2 1 600px;border-radius:20px;padding:2.5rem;position:relative;z-index:1}.profile-name{font-size:2.2rem;margin:0;color:var(--secondary_text)}.profile-name-input{font-size:2.2rem;font-weight:700;margin-bottom:.5rem}.profile-role-input{margin-bottom:1rem}.profile-role-badge{display:inline-block;margin-top:.5rem;padding:.3rem .8rem;background:var(--secondary_bg);color:var(--primary_text);border-radius:999px;font-weight:600}.profile-edit-input,.profile-edit-select,.profile-edit-textarea{width:100%;padding:.6rem .8rem;border:1px solid var(--border_color, #d1d5db);border-radius:8px;font-size:.95rem;background:var(--card_bg, #fff);color:var(--primary_text, #111);box-sizing:border-box;transition:border-color .3s ease,box-shadow .3s ease}.profile-edit-input:focus,.profile-edit-select:focus,.profile-edit-textarea:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.profile-edit-textarea{resize:vertical;min-height:100px}.info-grid{margin-top:2rem;display:grid;grid-template-columns:1fr 1fr;gap:1.2rem 2rem}.info-row{display:flex;align-items:center;background:var(--card_bg);padding:.8rem 1rem;border-radius:12px;box-shadow:0 1px 3px #0000000d;gap:.8rem;position:relative;z-index:1}.info-row span:first-child{min-width:80px;font-weight:500;color:var(--secondary_text)}.info-row .profile-edit-input,.info-row .profile-edit-select{flex:1;margin:0}.info-icon{color:#4f46e5;font-size:1.2rem;flex-shrink:0}.Profile-status-active{color:#059669;font-weight:600}.Profile-status-resigned{color:#dc2626;font-weight:600}.Profile-status-retired{color:#7c2d12;font-weight:600}.change-password-box{margin-top:2rem;background:var(--card_bg);padding:1.5rem;border-radius:16px;box-shadow:0 2px 8px #0000001a;border:1px solid var(--border_color, #e5e7eb);position:relative;z-index:1}.change-password-box h2{margin:0 0 1rem;color:#4f46e5;font-size:1.2rem}.password-row{margin-bottom:1rem}.password-actions{display:flex;gap:.75rem;margin-top:1.5rem}.password-actions .save-btn,.password-actions .cancel-btn{padding:.6rem 1.2rem;font-size:.9rem}.about-box{margin-top:2.5rem;position:relative;z-index:1}.about-box h2{margin-bottom:.6rem;color:#4f46e5}.about-box p{color:var(--primary_text);line-height:1.5}.toast{position:fixed;top:20px;right:20px;padding:1rem 1.5rem;border-radius:8px;color:#fff;font-weight:500;z-index:9999;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px #0003;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:#059669}.toast-error{background:#dc2626}.toast button{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0;line-height:1}.error-text{color:#dc2626;text-align:center;padding:2rem;font-size:1.1rem}.cropper-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cropper-box{background:#fff;border-radius:16px;padding:1.5rem;width:90%;max-width:500px;height:auto;max-height:90vh;box-shadow:0 20px 50px #0000004d;display:flex;flex-direction:column;gap:1rem;position:relative;z-index:10001}.cropper-inner{position:relative;width:100%;height:400px;border-radius:12px;overflow:hidden;background:#f8f9fa}.cropper-controls{display:flex;flex-direction:column;gap:1rem}.cropper-controls input[type=range]{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;-webkit-appearance:none}.cropper-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#4f46e5;cursor:pointer;box-shadow:0 2px 4px #0003}.cropper-controls input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#4f46e5;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.cropper-buttons{display:flex;justify-content:space-between;gap:1rem}.btn-done,.btn-cancel{flex:1;padding:.8rem 0;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:1rem;transition:all .3s ease}.btn-done{background-color:#4f46e5;color:#fff}.btn-done:hover{background-color:#4338ca;transform:translateY(-1px)}.btn-cancel{background-color:#e5e7eb;color:#111}.btn-cancel:hover{background-color:#d1d5db;transform:translateY(-1px)}.address-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:8000;display:flex;align-items:center;justify-content:center}.address-modal{background:#fff;border-radius:16px;padding:2rem;width:90%;max-width:500px;max-height:90%;overflow-y:auto;box-shadow:0 10px 25px #00000040;display:flex;flex-direction:column;gap:1rem;position:relative;z-index:8001}.address-modal h2{margin:0 0 1rem;color:#4f46e5;font-size:1.5rem}.address-edit{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem 1.5rem}.address-edit input,.address-edit textarea{width:100%;padding:.6rem .8rem;border-radius:8px;border:1px solid #d1d5db;font-size:.95rem;box-sizing:border-box}.address-edit select{width:100%;padding:.6rem .8rem;border-radius:8px;border:1px solid #d1d5db;font-size:.95rem;color:var(--primary_text);background-color:var(--card_bg);box-sizing:border-box}.address-edit textarea{resize:none}.address-modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.address-modal-actions button{padding:.6rem 1.2rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:.95rem;transition:background .3s ease}.address-modal-actions button:first-child{background-color:#e5e7eb;color:#111}.address-modal-actions button:first-child:hover{background-color:#d1d5db}.address-modal-actions button:last-child{background-color:#4f46e5;color:#fff}.address-modal-actions button:last-child:hover{background-color:#4338ca}.edit-address-btn{background-color:#4f46e5;color:#fff;padding:.5rem 1rem;border-radius:8px;border:none;cursor:pointer;font-size:.9rem;transition:background .3s ease;font-weight:500}.edit-address-btn:hover{background-color:#4338ca}@media (max-width: 768px){.info-grid{grid-template-columns:1fr}.profile-container{flex-direction:column;padding:3rem 1rem;gap:2rem}.avatar-img{width:180px;height:180px}.profile-name,.profile-name-input{font-size:1.8rem}.address-edit{grid-template-columns:1fr}.cropper-box{width:95%;margin:1rem}.cropper-inner{height:300px}.edit-actions{flex-direction:column;width:100%}.password-actions{flex-direction:column}}.yarl__fullsize{height:100%;width:100%}.yarl__relative{position:relative}.yarl__portal{inset:0;opacity:0;overflow:hidden;position:fixed;transition:opacity var(--yarl__fade_animation_duration,.25s) var(--yarl__fade_animation_timing_function,ease);z-index:var(--yarl__portal_zindex,9999)}.yarl__portal_open{opacity:1}.yarl__container{background-color:var(--yarl__container_background_color,var(--yarl__color_backdrop,#000));inset:0;outline:none;overflow:hidden;overscroll-behavior:var(--yarl__controller_overscroll_behavior,contain);position:absolute;touch-action:var(--yarl__controller_touch_action,none);-webkit-user-select:none;-moz-user-select:none;user-select:none}.yarl__carousel{align-content:center;align-items:stretch;display:flex;flex:0 0 auto;height:100%;justify-content:center;opacity:var(--yarl__pull_opacity,1);transform:translate(var(--yarl__swipe_offset,0),var(--yarl__pull_offset,0));width:calc(100% + (var(--yarl__carousel_slides_count) - 1)*(100% + var(--yarl__carousel_spacing_px, 0)*1px + var(--yarl__carousel_spacing_percent, 0)*1%))}.yarl__carousel_with_slides{-moz-column-gap:calc(var(--yarl__carousel_spacing_px, 0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent, 0))*var(--yarl__carousel_spacing_percent, 0)*1%);column-gap:calc(var(--yarl__carousel_spacing_px, 0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent, 0))*var(--yarl__carousel_spacing_percent, 0)*1%)}.yarl__flex_center{align-content:center;align-items:center;display:flex;justify-content:center}.yarl__slide{flex:1;overflow:hidden;padding:calc(var(--yarl__carousel_padding_px, 0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent, 0))*var(--yarl__carousel_padding_percent, 0)*1%);position:relative}[dir=rtl] .yarl__slide{--yarl__direction:-1}.yarl__slide_image{max-height:100%;max-width:100%;-o-object-fit:contain;object-fit:contain;touch-action:var(--yarl__controller_touch_action,none);-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.yarl__slide_image_cover{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.yarl__slide_image_loading{opacity:0}@media screen and (min-width:800px){.yarl__slide_wrapper:not(.yarl__slide_wrapper_interactive) .yarl__slide_image{-webkit-backface-visibility:hidden;-webkit-transform:translateZ(0);-webkit-transform-style:preserve-3d}}.yarl__slide_placeholder{left:50%;line-height:0;position:absolute;top:50%;transform:translate(-50%) translateY(-50%)}.yarl__slide_loading{animation:yarl__delayed_fadein 1s linear;color:var(--yarl__slide_icon_loading_color,var(--yarl__color_button,hsla(0,0%,100%,.8)))}.yarl__slide_loading line{animation:yarl__stroke_opacity 1s linear infinite}.yarl__slide_loading line:first-of-type{animation-delay:-1.875s}.yarl__slide_loading line:nth-of-type(2){animation-delay:-1.75s}.yarl__slide_loading line:nth-of-type(3){animation-delay:-1.625s}.yarl__slide_loading line:nth-of-type(4){animation-delay:-1.5s}.yarl__slide_loading line:nth-of-type(5){animation-delay:-1.375s}.yarl__slide_loading line:nth-of-type(6){animation-delay:-1.25s}.yarl__slide_loading line:nth-of-type(7){animation-delay:-1.125s}.yarl__slide_loading line:nth-of-type(8){animation-delay:-1s}.yarl__slide_error{color:var(--yarl__slide_icon_error_color,red);height:var(--yarl__slide_icon_error_size,48px);width:var(--yarl__slide_icon_error_size,48px)}@media (prefers-reduced-motion){.yarl__portal,.yarl__slide{transition:unset}.yarl__slide_loading,.yarl__slide_loading line{animation:unset}}.yarl__toolbar{display:flex;justify-content:flex-end;inset:0 0 auto auto;padding:var(--yarl__toolbar_padding,8px);position:absolute}[dir=rtl] .yarl__toolbar{inset:0 auto auto 0}.yarl__icon{height:var(--yarl__icon_size,32px);width:var(--yarl__icon_size,32px)}.yarl__button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--yarl__button_background_color,transparent);border:var(--yarl__button_border,0);color:var(--yarl__color_button,hsla(0,0%,100%,.8));cursor:pointer;filter:var(--yarl__button_filter,drop-shadow(2px 2px 2px rgba(0,0,0,.8)));line-height:0;margin:var(--yarl__button_margin,0);outline:none;padding:var(--yarl__button_padding,8px);-webkit-tap-highlight-color:transparent}.yarl__button:focus{color:var(--yarl__color_button_active,#fff)}.yarl__button:focus:not(:focus-visible){color:var(--yarl__color_button,hsla(0,0%,100%,.8))}.yarl__button:focus-visible{color:var(--yarl__color_button_active,#fff)}@media (hover:hover){.yarl__button:focus-visible:hover,.yarl__button:focus:hover,.yarl__button:hover{color:var(--yarl__color_button_active,#fff)}}.yarl__button:disabled{color:var(--yarl__color_button_disabled,hsla(0,0%,100%,.4));cursor:default}.yarl__navigation_next,.yarl__navigation_prev{padding:var(--yarl__navigation_button_padding,24px 16px);position:absolute;top:50%;transform:translateY(-50%)}.yarl__navigation_prev{left:0}[dir=rtl] .yarl__navigation_prev{left:unset;right:0;transform:translateY(-50%) rotate(180deg)}.yarl__navigation_next{right:0}[dir=rtl] .yarl__navigation_next{left:0;right:unset;transform:translateY(-50%) rotate(180deg)}.yarl__no_scroll{height:100%;overflow:hidden;overscroll-behavior:none}@keyframes yarl__delayed_fadein{0%{opacity:0}80%{opacity:0}to{opacity:1}}@keyframes yarl__stroke_opacity{0%{stroke-opacity:1}to{stroke-opacity:.125}}.EventPage-page{padding:40px 20px;min-height:100vh;font-family:Poppins,sans-serif;color:var(--primary_text)}.EventPage-title{text-align:center;font-size:2.5rem;color:var(--accent_color);margin-bottom:40px;font-weight:700}.EventPage-card{background:var(--secondary_bg);border-radius:16px;padding:25px;margin-bottom:30px;box-shadow:0 4px 10px var(--card_shadow);transition:transform .3s ease,box-shadow .3s ease}.EventPage-card:hover{transform:translateY(-5px);box-shadow:0 6px 15px var(--card_shadow)}.EventPage-card h2{color:var(--accent_text);margin-bottom:10px}.EventPage-date{color:var(--secondary_text);font-weight:500;margin-bottom:15px}.EventPage-description{color:var(--table_text);line-height:1.6;margin-bottom:20px}.EventPage-images{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.EventPage-images img{width:30%;border-radius:10px;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}.EventPage-images img:hover{transform:scale(1.05);box-shadow:0 4px 10px var(--accent_color)}.EventPage-viewGalleryBtn{background:var(--accent_color);color:var(--button_primary_text);border:none;border-radius:8px;padding:8px 14px;font-size:.9rem;cursor:pointer;transition:background .3s ease}.EventPage-viewGalleryBtn:hover{background:var(--icon_hover_color)}.EventPage-pagination{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:30px}.EventPage-pagination button{background:var(--accent_color);color:var(--button_primary_text);border:none;border-radius:6px;padding:6px 12px;cursor:pointer;transition:background .3s ease}.EventPage-pagination button:disabled{background:var(--secondary_bg);cursor:not-allowed}.EventPage-pagination button:hover:not(:disabled){background:var(--icon_hover_color)}.EventPage-search{text-align:center;margin-bottom:30px}.EventPage-search input{padding:8px 12px;font-size:1rem;border-radius:8px;border:1px solid var(--border_color);width:300px;max-width:90%;background-color:var(--secondary_bg);color:var(--primary_text)}.EventPage-search input::placeholder{color:var(--secondary_text)}.exam-schedules{padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--primary_text)}.exam-schedules-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:1.5rem;flex-wrap:wrap}.exam-schedules h2{margin:0;color:var(--primary_text);border-bottom:2px solid var(--border_color);padding-bottom:6px;flex:1 1 auto;min-width:250px}.exam-schedules-search{position:relative;flex:0 0 auto;width:350px;max-width:100%}.exam-schedules-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--secondary_text);font-size:1rem;pointer-events:none;z-index:1}.search-input{width:100%;padding:.65rem 1rem .65rem 2.8rem;border:1px solid var(--border_color);border-radius:8px;background:var(--card_bg);color:var(--primary_text);font-size:.9rem;transition:all .2s ease;box-sizing:border-box}.search-input:focus{outline:none;border-color:var(--button_primary_bg);box-shadow:0 0 0 2px var(--button_focus_shadow)}.search-input::placeholder{color:var(--secondary_text)}.loading,.error{margin:20px 0;padding:12px 16px;border-radius:8px;font-weight:500;text-align:center}.loading{background:var(--info_color);color:var(--accent_text)}.error{background:var(--danger_color);color:var(--accent_text)}.table-wrapper{width:100%;overflow-x:auto}.exam-table{width:100%;min-width:800px;border-collapse:collapse;background:var(--card_bg);border:1px solid var(--border_color);border-radius:10px;overflow:hidden}.exam-table th,.exam-table td{border-bottom:1px solid var(--border_color);padding:12px 15px;text-align:left;color:var(--table_text);white-space:nowrap}.exam-table td{font-size:.95rem}.exam-table th{background:var(--table_header_bg);color:var(--table_header_text);font-weight:600}.exam-table tbody tr{transition:background-color .2s ease}.exam-table tbody tr:last-of-type td{border-bottom:none}.exam-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease}.exam-table th.sortable:hover{background:var(--hover_bg)}.exam-table tr:nth-child(2n){background-color:var(--table_row_even_bg)}.exam-table tr:hover{background-color:var(--hover_bg);color:var(--accent_text)}.status-badge{display:inline-block;padding:.3rem .7rem;border-radius:12px;font-size:.8rem;font-weight:600;text-align:center}.status-badge.published{background:var(--success_color);color:#fff}.status-badge.unpublished{background:var(--secondary_text);color:#fff}.details-btn{padding:6px 12px;background-color:var(--button_primary_bg);color:var(--button_primary_text);border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease}.details-btn:hover{background-color:var(--sidebar_text_hover);transform:translateY(-1px)}.exam-schedules-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding:1rem;background:var(--card_bg);border-radius:8px;box-shadow:0 2px 8px var(--card_shadow);flex-wrap:wrap;gap:1rem}.pagination-info{font-size:.9rem;color:var(--secondary_text);font-weight:500}.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--border_color);background:var(--card_bg);color:var(--primary_text);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:var(--button_primary_bg);color:var(--button_primary_text);border-color:var(--button_primary_bg);transform:translateY(-1px)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-numbers{display:flex;align-items:center;gap:.3rem}.pagination-number{min-width:2.2rem;height:2.2rem;display:flex;align-items:center;justify-content:center;border:1px solid var(--border_color);background:var(--card_bg);color:var(--primary_text);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.pagination-number:hover{background:var(--hover_bg);border-color:var(--button_primary_bg);transform:translateY(-1px)}.pagination-number.active{background:var(--button_primary_bg);color:var(--button_primary_text);border-color:var(--button_primary_bg);font-weight:600}.pagination-ellipsis{padding:0 .5rem;color:var(--secondary_text);font-weight:500}@media (max-width: 1200px){.exam-schedules{padding:15px}.exam-schedules-header{flex-direction:column;align-items:stretch;gap:1rem}.exam-schedules h2{font-size:1.5rem}.exam-schedules-search{width:100%}}@media (max-width: 768px){.table-wrapper{overflow-x:hidden}.exam-table{min-width:100%;border:none;border-radius:0}.exam-table thead{display:none}.exam-table tr{display:block;margin-bottom:1rem;border:1px solid var(--border_color);border-radius:8px;box-shadow:0 2px 4px var(--card_shadow);overflow:hidden}.exam-table tr:nth-child(2n){background-color:var(--card_bg)}.exam-table td{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;text-align:right;white-space:normal}.exam-table td:last-child{border-bottom:none}.exam-table td[data-label]:before{content:attr(data-label);font-weight:600;text-align:left;padding-right:1rem;color:var(--primary_text)}.exam-schedules-pagination{flex-direction:column;align-items:center;gap:1rem}.pagination-controls{flex-wrap:wrap;justify-content:center;gap:.75rem}}@media (max-width: 480px){.pagination-controls{flex-direction:column;width:100%}.pagination-btn{width:100%;justify-content:center}.pagination-numbers{justify-content:center;flex-wrap:wrap}}.ExamDetailsPage-container{max-width:1200px;width:100%;margin:2rem auto;padding:1.5rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--primary_text);overflow-x:clip}.ExamDetailsPage-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--border_color);width:100%}.ExamDetailsPage-header h2{font-size:1.6rem;font-weight:600;margin:0;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.ExamDetailsPage-id{font-size:.9rem;color:var(--accent_text);background:var(--secondary_bg);padding:.3rem .6rem;border-radius:6px;word-break:break-all}.ExamDetailsPage-subjects-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.2rem;width:100%;max-width:100%;overflow-x:clip}.exam-subject-card{background:var(--card_bg);border-radius:12px;box-shadow:0 4px 10px var(--card_shadow);padding:1rem 1.5rem;border-left:5px solid var(--accent_color);transition:transform .2s ease-in-out,box-shadow .2s ease-in-out;overflow-wrap:break-word;width:100%}.exam-subject-card:hover{transform:translateY(-3px);box-shadow:0 8px 16px var(--card_shadow)}.card-row{display:flex;justify-content:space-between;align-items:center;padding:.85rem 0;border-bottom:1px solid var(--border_color);gap:1rem;flex-wrap:wrap;width:100%}.card-row:last-child{border-bottom:none}.card-label{font-weight:600;color:var(--primary_text);font-size:.9rem;white-space:nowrap;overflow-wrap:break-word}.card-value{color:var(--secondary_text);text-align:right;font-weight:500;overflow-wrap:break-word;word-break:break-word}.ExamDetailsPage-empty-state{margin:1rem 0;padding:2rem;background:var(--card_bg);border:1px dashed var(--border_color);border-radius:8px;text-align:center;color:var(--secondary_text);overflow-wrap:break-word;width:100%}.ExamDetailsPage-loader,.ExamDetailsPage-error-msg{text-align:center;padding:2rem;border-radius:8px;font-weight:500;width:100%}.ExamDetailsPage-loader{background-color:var(--secondary_bg);color:var(--primary_text)}.ExamDetailsPage-error-msg{background:var(--danger_color);color:#fff}.ExamDetailsPage-pagination{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-top:2rem;padding:1rem;background:var(--card_bg);border-radius:8px;box-shadow:0 2px 8px var(--card_shadow);gap:1.5rem;width:100%;max-width:100%;overflow-x:clip}.ExamDetailsPage-pagination-info{font-size:.9rem;color:var(--secondary_text);font-weight:500;word-wrap:break-word;max-width:100%}.ExamDetailsPage-pagination-controls{display:flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%}.ExamDetailsPage-pagination-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--border_color);background:var(--card_bg);color:var(--primary_text);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.ExamDetailsPage-pagination-btn:hover:not(:disabled){background:var(--button_primary_bg);color:var(--button_primary_text);border-color:var(--button_primary_bg)}.ExamDetailsPage-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.ExamDetailsPage-pagination-numbers{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap;justify-content:center;width:100%}.ExamDetailsPage-pagination-number{min-width:2.2rem;height:2.2rem;display:flex;align-items:center;justify-content:center;border:1px solid var(--border_color);background:var(--card_bg);color:var(--primary_text);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.ExamDetailsPage-pagination-number:hover{background:var(--hover_bg);border-color:var(--button_primary_bg)}.ExamDetailsPage-pagination-number.active{background:var(--button_primary_bg);color:var(--button_primary_text);border-color:var(--button_primary_bg);font-weight:600}.ExamDetailsPage-pagination-ellipsis{padding:0 .5rem;color:var(--secondary_text);font-weight:500}.results-container{padding:1.5rem;max-width:1400px;margin:0 auto;background:var(--body_bg_);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.results-header{margin-bottom:2rem;text-align:center}.results-title{font-size:2rem;font-weight:700;color:var(--primary_text);margin:0 0 .5rem;letter-spacing:-.5px}.results-subtitle{font-size:1rem;color:var(--secondary_text);margin:0}.results-card{background:var(--card_bg);border-radius:12px;box-shadow:0 4px 12px var(--card_shadow);padding:1.5rem;margin-bottom:2rem;border:1px solid var(--border_color);transition:transform .2s ease,box-shadow .2s ease}.results-card:hover{box-shadow:0 6px 20px var(--card_shadow)}.results-card-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border_color)}.results-card-title{font-size:1.5rem;font-weight:600;color:var(--primary_text);margin:0}.results-btn-back{background:var(--secondary_bg);color:var(--primary_text);border:1px solid var(--border_color);padding:.625rem 1.25rem;font-size:.95rem;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-weight:500;transition:all .2s ease}.results-btn-back:hover{background:var(--hover_bg);color:var(--accent_text);transform:translate(-3px)}.back-arrow{font-size:1.2rem;font-weight:700}.results-exam-info{margin-bottom:1.5rem;padding:1rem;background:var(--secondary_bg);border-radius:8px;border-left:4px solid var(--accent_color)}.results-exam-details{font-size:.95rem;color:var(--secondary_text);margin:.5rem 0 0}.results-section-title{font-size:1.25rem;font-weight:600;color:var(--primary_text);margin:1.5rem 0 1rem}.results-table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid var(--border_color)}.results-table{width:100%;border-collapse:collapse;font-size:.95rem;background:var(--card_bg)}.results-table thead{background:var(--table_header_bg);position:sticky;top:0;z-index:10}.results-table th{padding:1rem;text-align:left;font-weight:600;color:var(--table_header_text);border-bottom:2px solid var(--border_color);white-space:nowrap}.results-table td{padding:1rem;color:var(--table_text);border-bottom:1px solid var(--border_color)}.results-table tbody tr{transition:background-color .2s ease}.results-table tbody tr:hover{background:var(--hover_bg)}.results-table tbody tr.editing{background:var(--secondary_bg);border-left:3px solid var(--accent_color)}.results-table tbody tr:last-child td{border-bottom:none}.results-subject-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem}.results-subject-card{background:var(--secondary_bg);border:1px solid var(--border_color);border-radius:10px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;transition:all .2s ease}.results-subject-card:hover{background:var(--hover_bg);transform:translateY(-2px);box-shadow:0 4px 12px var(--card_shadow)}.results-subject-name{font-size:1.1rem;font-weight:600;color:var(--primary_text);flex-grow:1}.results-btn{border:none;padding:.625rem 1.25rem;font-size:.9rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease;display:inline-block;text-align:center}.results-btn-primary{background:var(--button_primary_bg);color:var(--button_primary_text)}.results-btn-primary:hover{opacity:.9;transform:translateY(-1px)}.results-btn-secondary{background:var(--button_secondary_bg);color:var(--button_secondary_text)}.results-btn-secondary:hover{opacity:.9}.results-btn-success{background:var(--success_color);color:#fff}.results-btn-success:hover{opacity:.9}.results-input{width:100%;padding:.5rem .75rem;border:2px solid var(--border_color);border-radius:6px;font-size:.9rem;background:var(--card_bg);color:var(--primary_text);transition:border-color .2s ease}.results-input:focus{outline:none;border-color:var(--accent_color);background:var(--secondary_bg)}.results-marks-value,.results-grade-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-weight:500}.results-marks-value{background:var(--info_color);color:#fff}.results-grade-badge{background:var(--accent_color);color:#fff}.results-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border_color)}.results-pagination-btn{background:var(--button_primary_bg);color:var(--button_primary_text);border:none;padding:.625rem 1.5rem;font-size:.9rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease;min-width:100px}.results-pagination-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.results-pagination-btn:disabled{background:var(--secondary_text);cursor:not-allowed;opacity:.5}.results-page-info{font-size:.95rem;color:var(--primary_text);font-weight:600;min-width:120px;text-align:center}.results-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--secondary_text)}.results-spinner{width:40px;height:40px;border:4px solid var(--border_color);border-top-color:var(--accent_color);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.results-empty{text-align:center;padding:3rem 1rem;color:var(--secondary_text);font-size:1rem}@media (max-width: 1200px){.results-container{padding:1.25rem}.results-title{font-size:1.75rem}.results-subject-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.875rem}.results-table{font-size:.9rem}.results-table th,.results-table td{padding:.875rem}}@media (max-width: 992px){.results-card{padding:1.25rem}.results-subject-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}@media (max-width: 768px){.results-container{padding:1rem}.results-header{margin-bottom:1.5rem}.results-title{font-size:1.5rem}.results-subtitle{font-size:.9rem}.results-card{padding:1rem;border-radius:10px}.results-card-title{font-size:1.25rem}.results-table-wrapper{border:none}.results-table{font-size:.85rem}.results-table thead{display:none}.results-table tbody tr{display:block;margin-bottom:1rem;border:1px solid var(--border_color);border-radius:8px;background:var(--card_bg);overflow:hidden}.results-table tbody tr.editing{border-left:3px solid var(--accent_color)}.results-table td{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-bottom:1px solid var(--border_color);text-align:right}.results-table td:last-child{border-bottom:none}.results-table td:before{content:attr(data-label);font-weight:600;color:var(--primary_text);text-align:left;flex:0 0 40%}.results-table td:last-child{justify-content:center}.results-table td:last-child:before{display:none}.results-subject-grid{grid-template-columns:1fr;gap:.75rem}.results-subject-card{padding:1rem}.results-pagination{flex-wrap:wrap;gap:.75rem}.results-pagination-btn{flex:1;min-width:auto;padding:.625rem 1rem}.results-page-info{width:100%;order:-1;margin-bottom:.5rem}.results-btn{width:100%;padding:.625rem}.results-btn-back{width:100%;justify-content:center}.results-input{max-width:150px}.results-exam-info{padding:.875rem}.results-section-title{font-size:1.1rem}}@media (max-width: 480px){.results-container{padding:.75rem}.results-title{font-size:1.35rem}.results-card{padding:.875rem}.results-card-title{font-size:1.1rem}.results-table td{padding:.625rem;font-size:.8rem}.results-subject-card{padding:.875rem}.results-subject-name{font-size:1rem}.results-btn{font-size:.85rem;padding:.5rem}.results-input{padding:.4rem .6rem;font-size:.85rem}}@media print{.results-btn,.results-pagination,.results-btn-back{display:none}.results-card{box-shadow:none;page-break-inside:avoid}.results-table{font-size:.85rem}}.AllParentsPage-wrapper{padding:20px;max-width:1200px;margin:0 auto;overflow-x:hidden;color:var(--primary_text)}.AllParentsPage-title{font-size:24px;font-weight:600;margin-bottom:20px;color:var(--primary_text)}.AllParentsPage-filters{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:20px;align-items:center}.AllParentsPage-search-wrapper{position:relative}.AllParentsPage-search{width:100%;padding:10px 35px 10px 14px;border:1px solid var(--border_color);border-radius:8px;background:var(--card_bg);color:var(--primary_text);font-size:14px;box-sizing:border-box;height:42px}.AllParentsPage-search-clear-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;font-size:22px;color:var(--secondary_text);padding:0 5px;line-height:1}.AllParentsPage-search-clear-btn:hover{color:var(--primary_text)}.AllParentsPage-search:focus{outline:none;border-color:var(--accent_color);box-shadow:0 0 0 3px rgba(var(--accent_color_rgb),.2)}.AllParentsPage-clear-btn{padding:10px 20px;background:var(--danger_color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease,transform .2s ease;height:42px;box-sizing:border-box}.AllParentsPage-clear-btn:hover{opacity:.9;transform:translateY(-1px)}.AllParentsPage-table-wrapper{overflow-x:auto;border:1px solid var(--border_color);border-radius:8px;width:100%}.AllParentsPage-table{width:100%;border-collapse:collapse;background:var(--card_bg);min-width:800px}.AllParentsPage-table th,.AllParentsPage-table td{border-bottom:1px solid var(--border_color);padding:14px 16px;text-align:left;vertical-align:middle;color:var(--primary_text)}.AllParentsPage-table th{background:var(--table_header_bg);color:var(--table_header_text);font-weight:600;position:sticky;top:0;z-index:10}.AllParentsPage-table td ul{margin:0;padding-left:18px}.AllParentsPage-card-view{display:none}.AllParentsPage-card{background:var(--card_bg);border:1px solid var(--border_color);border-radius:8px;padding:16px;margin-bottom:16px;box-shadow:0 2px 4px #0000000d}.AllParentsPage-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--border_color);gap:10px}.AllParentsPage-card-name{font-size:18px;font-weight:600;color:var(--primary_text)}.AllParentsPage-card-mobile{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--secondary_text);font-weight:500;flex-shrink:0}.AllParentsPage-card-mobile svg{font-size:12px}.AllParentsPage-card-body{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.AllParentsPage-card-field{display:flex;flex-direction:column}.AllParentsPage-card-field-full{grid-column:1 / -1}.AllParentsPage-card-label{font-size:12px;color:var(--secondary_text);margin-bottom:4px;text-transform:uppercase;font-weight:500}.AllParentsPage-card-value{font-size:14px;color:var(--primary_text)}.AllParentsPage-students-section{border-top:1px solid var(--border_color);padding-top:12px}.AllParentsPage-students-section h4{margin:0 0 10px;font-size:14px;font-weight:600}.AllParentsPage-students-section ul{margin:0;padding-left:20px;font-size:14px;color:var(--primary_text)}.AllParentsPage-pagination{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:25px;flex-wrap:wrap}.AllParentsPage-pagination button{padding:10px 20px;background:var(--accent_color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.AllParentsPage-pagination button:disabled{opacity:.5;cursor:not-allowed;background:var(--disabled_bg);color:var(--secondary_text)}.AllParentsPage-pagination button:not(:disabled):hover{opacity:.9;transform:translateY(-1px)}.AllParentsPage-pagination span{font-weight:500;font-size:14px;color:var(--secondary_text)}@media (max-width: 992px){.AllParentsPage-table-wrapper{display:none}.AllParentsPage-card-view{display:block}}@media (max-width: 768px){.AllParentsPage-wrapper{padding:15px}.AllParentsPage-title{font-size:22px}.AllParentsPage-filters{flex-direction:column;align-items:stretch;gap:12px}.AllParentsPage-search-wrapper,.AllParentsPage-filters .CustomDropdown-wrapper,.AllParentsPage-clear-btn{width:100%;min-width:100%}}@media (max-width: 600px){.AllParentsPage-wrapper{padding:10px}.AllParentsPage-title{font-size:20px;text-align:center;margin-bottom:15px}.AllParentsPage-filters{gap:10px}.AllParentsPage-search,.AllParentsPage-clear-btn{height:40px;font-size:13px}.AllParentsPage-card-body{grid-template-columns:1fr}.AllParentsPage-pagination{flex-direction:column;gap:10px}.AllParentsPage-pagination span{order:-1;margin-bottom:5px}.AllParentsPage-pagination .pagination-controls{display:flex;width:100%;gap:10px}.AllParentsPage-pagination button{flex-grow:1;width:auto}}.teacher-subject-section-page{padding:20px;background-color:var(--secondary_bg, #f4f7fa);min-height:100vh;font-family:var(--font_family, "Poppins", sans-serif);color:var(--primary_text, #333)}.page-header{margin-bottom:25px;text-align:center}.page-header h2{font-size:2rem;font-weight:700;color:var(--primary_text, #2c3e50)}.filter-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px;background-color:var(--card_bg, #ffffff);padding:25px;border-radius:12px;box-shadow:0 4px 12px var(--card_shadow, rgba(0, 0, 0, .07))}.filter-group{display:flex;flex-direction:column}.filter-group label{font-size:14px;font-weight:600;margin-bottom:8px;color:var(--secondary_text, #555)}.filter-group select{padding:12px;border:1px solid var(--border_color, #ddd);border-radius:8px;background-color:var(--primary_bg, #ffffff);font-size:14px;cursor:pointer;transition:all .3s ease}.filter-group select:hover:not(:disabled){border-color:var(--accent_color, #ff6b81)}.filter-group select:focus{outline:none;border-color:var(--accent_color, #ff6b81);box-shadow:0 0 0 3px #ff6b8133}.filter-group select:disabled{opacity:.6;cursor:not-allowed;background-color:var(--secondary_bg, #f5f5f5)}.filter-actions{display:flex;align-items:flex-end}.Tss-clear-btn{width:100%;padding:12px 20px;background-color:var(--danger_color, #e74c3c);color:var(--button_primary_text, #ffffff);border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease}.Tss-clear-btn:hover{background-color:#c0392b;transform:translateY(-2px);box-shadow:0 4px 8px var(--card_shadow, rgba(0, 0, 0, .15))}.status-message{padding:20px;margin:20px 0;border-radius:8px;text-align:center;font-size:1rem;font-weight:500;color:var(--button_primary_text, #ffffff)}.status-loading{background-color:var(--info_color, #3498db)}.status-error{background-color:var(--danger_color, #e74c3c)}.status-empty{background-color:var(--warning_color, #f39c12)}.table-container{background-color:var(--card_bg, #ffffff);border-radius:12px;overflow:hidden;box-shadow:0 4px 12px var(--card_shadow, rgba(0, 0, 0, .07))}.mapping-table{width:100%;border-collapse:collapse}.mapping-table th,.mapping-table td{padding:16px 20px;text-align:left;font-size:14px;border-bottom:1px solid var(--border_color, #e0e0e0)}.mapping-table th{background-color:var(--table_header_bg, #f8f9fa);font-weight:600;color:var(--table_header_text, #2c3e50)}.mapping-table tbody tr:hover{background-color:var(--hover_bg, #fff3f5)}.index-cell{font-weight:600;width:70px;color:var(--accent_color, #ff6b81)}.mapping-card-container{display:grid;gap:20px}.mapping-card{background-color:var(--card_bg, #ffffff);border-radius:12px;padding:20px;box-shadow:0 4px 12px var(--card_shadow, rgba(0, 0, 0, .08));transition:transform .2s ease,box-shadow .2s ease}.mapping-card:hover{transform:translateY(-4px);box-shadow:0 6px 16px var(--card_shadow, rgba(0, 0, 0, .1))}.card-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border_color, #eee);padding-bottom:15px;margin-bottom:15px}.card-index{font-size:1rem;font-weight:700;color:var(--button_primary_text, #ffffff);background-color:var(--accent_color, #ff6b81);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.card-teacher{font-size:1.1rem;font-weight:600;color:var(--primary_text, #2c3e50)}.card-body{display:grid;gap:12px}.card-item{display:flex;justify-content:space-between;align-items:center;font-size:.95rem}.card-label{font-weight:500;color:var(--secondary_text, #7f8c8d)}.card-value{font-weight:600;color:var(--primary_text, #34495e)}.pagination{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:30px}.pagination button{padding:10px 22px;background-color:var(--button_primary_bg, #ff6b81);color:var(--button_primary_text, #ffffff);border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease}.pagination button:hover:not(:disabled){background-color:#ff5470;transform:translateY(-2px);box-shadow:0 4px 8px var(--card_shadow, rgba(0, 0, 0, .15))}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{font-size:1rem;font-weight:500;color:var(--primary_text, #333)}@media (max-width: 1200px){.teacher-subject-section-page{padding:15px}.filter-controls{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px}}@media (max-width: 768px){.page-header h2{font-size:1.6rem}.filter-controls{grid-template-columns:1fr 1fr}.filter-actions{grid-column:1 / -1}}@media (max-width: 480px){.filter-controls{grid-template-columns:1fr}.pagination{flex-direction:column}}.AllStudentsPage-all-students-page{max-width:1500px;margin:30px auto;padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--primary_text)}.AllStudentsPage-title{text-align:center;margin-bottom:25px;color:var(--primary_text);font-size:2rem;font-weight:700}.AllStudentsPage-filters-container{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:20px;padding:15px;background:var(--card_bg);border-radius:8px;box-shadow:0 2px 8px var(--card_shadow)}.AllStudentsPage-search-input{flex:1 1 300px;padding:10px 12px;border:1px solid var(--border_color);border-radius:6px;background:var(--body_bg_alt);color:var(--primary_text);font-size:14px;transition:border-color .3s}.AllStudentsPage-search-input:focus{outline:none;border-color:var(--accent_color)}.AllStudentsPage-students-table-wrapper{width:100%;overflow-x:auto;margin-bottom:20px;border-radius:8px;box-shadow:0 2px 10px var(--card_shadow)}.AllStudentsPage-students-table{width:100%;min-width:1000px;border-collapse:collapse;background:var(--card_bg);color:var(--table_text)}.AllStudentsPage-students-table th,.AllStudentsPage-students-table td{border:1px solid var(--border_color);padding:12px 16px;text-align:left;white-space:nowrap;font-size:14px}.AllStudentsPage-students-table th{background-color:var(--table_header_bg);color:var(--table_header_text);font-weight:600;position:sticky;top:0;z-index:10}.AllStudentsPage-students-table tbody tr:hover{background-color:var(--hover_bg);transition:background-color .2s}.AllStudentsPage-actions-cell{display:flex!important;gap:8px;align-items:center;justify-content:center}.AllStudentsPage-view-btn{background:transparent;border:none;color:var(--icon_color);font-size:18px;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;transition:color .3s,transform .2s}.AllStudentsPage-view-btn:hover{color:var(--accent_color);transform:scale(1.1)}.AllStudentsPage-delete-btn{background-color:var(--danger_color);color:var(--button_primary_text);border:none;padding:6px 12px;border-radius:5px;cursor:pointer;font-size:13px;font-weight:500;transition:background-color .25s ease,transform .2s}.AllStudentsPage-delete-btn:hover:not(:disabled){background-color:#9e202f;transform:translateY(-1px)}.AllStudentsPage-delete-btn:disabled{background-color:#e399a3;cursor:not-allowed;opacity:.6}.AllStudentsPage-present-green{background-color:var(--success_color);color:var(--accent_text);font-weight:700;text-align:center;padding:4px 8px;border-radius:4px}.AllStudentsPage-present-red{background-color:var(--danger_color);color:var(--accent_text);font-weight:700;text-align:center;padding:4px 8px;border-radius:4px}.AllStudentsPage-mobile-cards{display:none}.AllStudentsPage-student-card{background:var(--card_bg);border-radius:8px;padding:16px;margin-bottom:16px;box-shadow:0 2px 8px var(--card_shadow);border:1px solid var(--border_color)}.AllStudentsPage-card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border_color)}.AllStudentsPage-card-name{font-size:16px;font-weight:700;color:var(--primary_text);margin-bottom:4px}.AllStudentsPage-card-reg{font-size:12px;color:var(--secondary_text)}.AllStudentsPage-card-actions{display:flex;gap:8px;align-items:center}.AllStudentsPage-card-body{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.AllStudentsPage-card-field{display:flex;flex-direction:column}.AllStudentsPage-card-label{font-size:11px;font-weight:600;color:var(--secondary_text);text-transform:uppercase;margin-bottom:4px}.AllStudentsPage-card-value{font-size:14px;color:var(--primary_text)}.AllStudentsPage-pagination{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:20px;padding:15px;background:var(--card_bg);border-radius:8px;box-shadow:0 2px 8px var(--card_shadow)}.AllStudentsPage-pagination span{font-size:14px;font-weight:600;color:var(--primary_text)}.AllStudentsPage-pagination-btn{padding:8px 16px;background-color:var(--accent_color);color:var(--accent_text);border:none;border-radius:5px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .3s,transform .2s}.AllStudentsPage-pagination-btn:hover:not(:disabled){background-color:var(--primary_text);transform:translateY(-1px)}.AllStudentsPage-pagination-btn:disabled{background-color:var(--border_color);cursor:not-allowed;opacity:.5}.AllStudentsPage-loading,.AllStudentsPage-no-students{text-align:center;padding:40px 20px;font-size:16px;color:var(--secondary_text)}.AllStudentsPage-error-message{color:var(--danger_color);text-align:center;font-weight:600;padding:20px;background:#ff00001a;border-radius:8px;margin:20px 0}@media (min-width: 1440px){.AllStudentsPage-all-students-page{max-width:1600px}.AllStudentsPage-title{font-size:2.5rem}}@media (max-width: 1300px){.AllStudentsPage-all-students-page{margin:20px;padding:16px}.AllStudentsPage-title{font-size:1.75rem;margin-bottom:20px}.AllStudentsPage-filters-container{gap:10px;padding:12px}.AllStudentsPage-search-input{flex:1 1 100%}.AllStudentsPage-filters-container .CustomDropdown-wrapper{flex:1 1 calc(50% - 5px)}.AllStudentsPage-students-table{min-width:900px;font-size:13px}.AllStudentsPage-students-table th,.AllStudentsPage-students-table td{padding:10px 12px;font-size:13px}}@media (max-width: 1200px){.AllStudentsPage-all-students-page{margin:15px;padding:12px}.AllStudentsPage-title{font-size:1.5rem;margin-bottom:18px}.AllStudentsPage-filters-container{flex-direction:column;gap:10px;padding:12px}.AllStudentsPage-search-input,.AllStudentsPage-filters-container .CustomDropdown-wrapper{flex:1 1 100%;width:100%}.AllStudentsPage-students-table-wrapper{display:none}.AllStudentsPage-mobile-cards{display:block}.AllStudentsPage-pagination{flex-wrap:wrap;gap:10px;padding:12px}.AllStudentsPage-pagination span{font-size:13px;width:100%;text-align:center}.AllStudentsPage-pagination-btn{padding:8px 20px;font-size:13px;flex:1}}@media (max-width: 599px){.AllStudentsPage-all-students-page{margin:10px;padding:10px}.AllStudentsPage-title{font-size:1.3rem;margin-bottom:15px}.AllStudentsPage-filters-container{padding:10px;gap:8px}.AllStudentsPage-search-input{padding:9px 10px;font-size:13px}.AllStudentsPage-student-card{padding:14px;margin-bottom:14px}.AllStudentsPage-card-name{font-size:15px}.AllStudentsPage-card-body{gap:10px}.AllStudentsPage-card-value{font-size:13px}.AllStudentsPage-view-btn{font-size:16px;padding:5px}.AllStudentsPage-delete-btn{padding:5px 10px;font-size:12px}}@media (max-width: 479px){.AllStudentsPage-all-students-page{margin:8px;padding:8px}.AllStudentsPage-title{font-size:1.2rem;margin-bottom:12px}.AllStudentsPage-filters-container{padding:8px;gap:8px}.AllStudentsPage-search-input{padding:8px;font-size:12px}.AllStudentsPage-student-card{padding:12px;margin-bottom:12px}.AllStudentsPage-card-name{font-size:14px}.AllStudentsPage-card-reg{font-size:11px}.AllStudentsPage-card-body{grid-template-columns:1fr;gap:8px}.AllStudentsPage-card-label{font-size:10px}.AllStudentsPage-card-value{font-size:12px}.AllStudentsPage-view-btn{font-size:14px;padding:4px}.AllStudentsPage-delete-btn{padding:4px 8px;font-size:11px}.AllStudentsPage-pagination{padding:10px;gap:8px}.AllStudentsPage-pagination span{font-size:12px}.AllStudentsPage-pagination-btn{padding:7px 16px;font-size:12px}}@media (max-width: 319px){.AllStudentsPage-all-students-page{margin:5px;padding:6px}.AllStudentsPage-title{font-size:1.1rem;margin-bottom:10px}.AllStudentsPage-student-card{padding:10px}.AllStudentsPage-card-name{font-size:13px}.AllStudentsPage-pagination-btn{padding:6px 12px;font-size:11px}}.student-details-page{background:var(--body_bg_alt);min-height:100vh;padding:40px 20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--primary_text)}.profile-card{max-width:1100px;margin:0 auto;display:flex;gap:28px;background:var(--card_bg);border-radius:16px;box-shadow:var(--shadow_md);padding:24px}.photo-section{flex-shrink:0;width:240px;min-height:300px;border-radius:12px;box-shadow:var(--shadow_sm);padding:12px;display:flex;flex-direction:column;gap:12px}.photo-container{display:flex;flex-direction:column;gap:12px;align-items:center;width:100%}.profile-photo{width:100%;height:300px;object-fit:cover;display:block;border-radius:8px;box-shadow:0 4px 8px #0000001a;transition:transform .2s}.profile-photo:hover{transform:scale(1.02)}.info-section{flex-grow:1;display:flex;flex-direction:column;gap:22px}.student-name{font-size:2.3rem;font-weight:700;color:var(--accent_color);margin-bottom:8px;border-bottom:3px solid var(--accent_color);padding-bottom:6px}.info-group{background:var(--hover_bg);border-radius:10px;padding:16px 22px;box-shadow:var(--shadow_sm)}.group-title{font-size:1.2rem;font-weight:600;margin-bottom:14px;color:var(--primary_text);border-left:4px solid var(--accent_color);padding-left:10px}dl{display:grid;grid-template-columns:150px 1fr;row-gap:10px;column-gap:20px;margin:0}dt{font-weight:600;color:var(--secondary_text);align-self:center;font-size:.95rem}dd{margin:0;color:var(--primary_text);font-size:.95rem;line-height:1.4}.toolbar{display:flex;justify-content:flex-end;gap:12px;margin-bottom:12px}.toolbar button{background:var(--accent_color);color:var(--accent_text);border:none;border-radius:5px;padding:6px 10px;font-size:1rem;cursor:pointer;transition:background .3s;min-width:44px}.toolbar button:hover{background:var(--primary_text);color:var(--body_bg)}.profile-photo[src*=placehold]{background:#f8f9fa;border:2px dashed #dee2e6;display:flex;align-items:center;justify-content:center;color:#6c757d;font-size:14px}.loading,.error,.empty{text-align:center;padding:40px 20px;font-size:1.2rem;color:var(--primary_text)}.error{color:#dc3545}@media (min-width: 1200px){.profile-card{max-width:1200px}.photo-section{width:260px}.profile-photo{height:320px}}@media (max-width: 1199px){.profile-card{max-width:1000px}.student-name{font-size:2rem}}@media (max-width: 1023px){.student-details-page{padding:30px 16px}.profile-card{gap:20px;padding:20px}.photo-section{width:200px;min-height:250px}.profile-photo{height:250px}.student-name{font-size:1.8rem}.info-group{padding:14px 18px}.group-title{font-size:1.1rem}dl{grid-template-columns:130px 1fr;column-gap:16px;row-gap:8px}dt,dd{font-size:.9rem}}@media (max-width: 899px){.profile-card{flex-direction:column;align-items:center;gap:24px;padding:24px 20px}.photo-section{width:100%;max-width:280px;min-height:auto;padding:16px}.profile-photo{height:320px;max-width:260px;margin:0 auto}.info-section{width:100%;gap:20px}.student-name{text-align:center;font-size:1.9rem}.toolbar{justify-content:center}dl{grid-template-columns:140px 1fr}}@media (max-width: 767px){.student-details-page{padding:20px 12px}.profile-card{padding:20px 16px;border-radius:12px}.photo-section{max-width:240px;padding:12px}.profile-photo{height:280px;max-width:220px}.student-name{font-size:1.6rem;border-bottom-width:2px}.info-group{padding:12px 16px;border-radius:8px}.group-title{font-size:1rem;margin-bottom:12px}dl{grid-template-columns:120px 1fr;column-gap:12px;row-gap:8px}dt,dd{font-size:.85rem}.toolbar button{padding:8px 12px;font-size:.95rem}}@media (max-width: 599px){.student-details-page{padding:16px 10px}.profile-card{padding:16px 12px;gap:20px}.photo-section{max-width:200px;padding:10px}.profile-photo{height:240px;max-width:180px}.student-name{font-size:1.4rem;padding-bottom:4px}.info-section{gap:16px}.info-group{padding:10px 14px}.group-title{font-size:.95rem;margin-bottom:10px;border-left-width:3px;padding-left:8px}dl{grid-template-columns:1fr;row-gap:4px}dt{font-size:.8rem;margin-bottom:2px;color:var(--secondary_text)}dd{font-size:.85rem;padding-bottom:8px;border-bottom:1px solid var(--border_color)}dd:last-child{border-bottom:none;padding-bottom:0}.toolbar{margin-bottom:8px}.toolbar button{padding:7px 12px;font-size:.9rem;min-width:40px}}@media (max-width: 479px){.student-details-page{padding:12px 8px}.profile-card{padding:14px 10px;gap:16px;border-radius:10px}.photo-section{max-width:180px;padding:8px}.profile-photo{height:220px;max-width:160px;border-radius:6px}.student-name{font-size:1.25rem;margin-bottom:6px}.info-section{gap:14px}.info-group{padding:10px 12px}.group-title{font-size:.9rem;margin-bottom:8px}dt{font-size:.75rem}dd{font-size:.8rem;padding-bottom:6px}.toolbar button{padding:6px 10px;font-size:.85rem;min-width:38px}.loading,.error,.empty{padding:30px 15px;font-size:1rem}}@media (max-width: 359px){.student-details-page{padding:10px 6px}.profile-card{padding:12px 8px;gap:14px}.photo-section{max-width:160px;padding:6px}.profile-photo{height:200px;max-width:140px}.student-name{font-size:1.15rem;padding-bottom:3px;border-bottom-width:2px}.info-group{padding:8px 10px}.group-title{font-size:.85rem;margin-bottom:6px;padding-left:6px}dt{font-size:.7rem}dd{font-size:.75rem;padding-bottom:5px}.toolbar button{padding:5px 8px;font-size:.8rem;min-width:36px}}@media (max-width: 319px){.student-details-page{padding:8px 4px}.profile-card{padding:10px 6px;gap:12px}.photo-section{max-width:140px;padding:5px}.profile-photo{height:180px;max-width:130px}.student-name{font-size:1.05rem}.info-group{padding:6px 8px}.group-title{font-size:.8rem}dt{font-size:.68rem}dd{font-size:.72rem}}@media print{.student-details-page{background:#fff;padding:0}.profile-card{box-shadow:none;page-break-inside:avoid}.toolbar{display:none!important}.profile-photo{box-shadow:none}.info-group{page-break-inside:avoid}}.mobile-attendance-page{max-width:1200px;margin:0 auto;padding:1rem;background:var(--body_bg_);min-height:100vh}.mobile-attendance-header{background:var(--card_bg);padding:1.5rem;border-radius:16px;margin-bottom:1.5rem;box-shadow:0 2px 12px var(--card_shadow);border:1px solid var(--border_color)}.mobile-attendance-header h2{margin:0 0 .5rem;color:var(--primary_text);font-size:1.75rem;font-weight:700}.mobile-attendance-header .subtitle{margin:0;color:var(--secondary_text);font-size:.95rem}.mobile-filters-card{background:var(--card_bg);padding:1.25rem;border-radius:16px;margin-bottom:1.5rem;box-shadow:0 2px 12px var(--card_shadow);border:1px solid var(--border_color)}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.filter-item{display:flex;flex-direction:column;gap:.5rem}.filter-item label{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;color:var(--primary_text)}.filter-icon{color:var(--icon_color);font-size:.9rem}.filter-item select{padding:.75rem;border-radius:10px;border:1px solid var(--border_color);background:var(--primary_bg);color:var(--primary_text);font-size:.95rem;transition:all .3s ease;cursor:pointer}.filter-item select:focus{outline:none;border-color:var(--accent_color);box-shadow:0 0 0 3px #ff6b811a}.filter-item select:disabled{opacity:.5;cursor:not-allowed;background:var(--secondary_bg)}.section-stats-card{background:var(--card_bg);border-radius:16px;margin-bottom:1.5rem;box-shadow:0 2px 12px var(--card_shadow);border:1px solid var(--border_color);overflow:hidden}.stats-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;cursor:pointer;transition:background .2s ease;background:var(--primary_bg)}.stats-header:hover{background:var(--hover_bg)}.stats-title{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:1.1rem;color:var(--primary_text)}.stats-icon{color:var(--accent_color);font-size:1.2rem}.stats-header svg:last-child{color:var(--icon_color);font-size:1rem}.stats-content{padding:1.25rem;background:var(--secondary_bg);border-top:1px solid var(--border_color)}.stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-item{background:var(--card_bg);padding:1rem;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:.5rem;border:1px solid var(--border_color);transition:transform .2s ease}.stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--card_shadow)}.stat-label{font-size:.85rem;color:var(--secondary_text);font-weight:500}.stat-value{font-size:1.75rem;font-weight:700;color:var(--primary_text)}.present-stat .stat-value{color:green}.absent-stat .stat-value{color:#790606}.chart-container{max-width:300px;margin:0 auto;padding:1rem;background:var(--card_bg);border-radius:12px;border:1px solid var(--border_color)}.students-list{display:flex;flex-direction:column;gap:1rem}.student-card{background:var(--card_bg);border-radius:16px;overflow:hidden;box-shadow:0 2px 8px var(--card_shadow);border:1px solid var(--border_color);transition:all .3s ease}.student-card.expanded{box-shadow:0 4px 20px var(--card_shadow);border-color:var(--accent_color)}.student-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;cursor:pointer;transition:background .2s ease;background:var(--primary_bg)}.student-header:hover{background:var(--hover_bg)}.student-info{flex:1}.student-info h4{margin:0 0 .75rem;color:var(--primary_text);font-size:1.15rem;font-weight:600}.student-quick-stats{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.quick-stat{display:inline-flex;align-items:center;padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.present-badge{background:var(--success_color);color:var(--accent_text)}.absent-badge{background:var(--danger_color);color:var(--accent_text)}.attendance-percentage{padding:.35rem .75rem;border-radius:20px;background:var(--info_color);color:var(--accent_text);font-size:.85rem;font-weight:600}.expand-icon{color:var(--icon_color);font-size:1.1rem;margin-left:1rem;transition:transform .3s ease}.student-card.expanded .expand-icon{transform:rotate(180deg)}.student-details{padding:1.25rem;background:var(--secondary_bg);border-top:1px solid var(--border_color);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.attendance-calendar{margin-bottom:1.5rem}.attendance-calendar h5{margin:0 0 1rem;color:var(--primary_text);font-size:1rem;font-weight:600}.calendar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.5rem}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:10px;border:2px solid var(--border_color);background:var(--card_bg);transition:all .2s ease;cursor:default}.calendar-day:hover{transform:scale(1.05)}.day-number{font-size:.75rem;color:var(--secondary_text);font-weight:500}.day-mark{font-size:1rem;font-weight:700;margin-top:.15rem}.day-present{background:var(--success_color);border-color:var(--success_color)}.day-present .day-number,.day-present .day-mark{color:var(--accent_text)}.day-absent{background:var(--danger_color);border-color:var(--danger_color)}.day-absent .day-number,.day-absent .day-mark{color:var(--accent_text)}.day-na{background:var(--secondary_bg);border-color:var(--border_color);opacity:.6}.student-chart{max-width:280px;margin:0 auto;padding:1rem;background:var(--card_bg);border-radius:12px;border:1px solid var(--border_color)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;background:var(--card_bg);border-radius:16px;border:1px solid var(--border_color)}.spinner{width:48px;height:48px;border:4px solid var(--border_color);border-top-color:var(--accent_color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:var(--secondary_text);font-size:.95rem;margin:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;background:var(--card_bg);border-radius:16px;border:1px solid var(--border_color);text-align:center}.empty-icon{font-size:4rem;color:var(--icon_color);opacity:.4;margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;color:var(--primary_text);font-size:1.25rem;font-weight:600}.empty-state p{margin:0;color:var(--secondary_text);font-size:.95rem}@media (max-width: 768px){.mobile-attendance-page{padding:.75rem}.mobile-attendance-header{padding:1.25rem}.mobile-attendance-header h2{font-size:1.5rem}.filter-grid{grid-template-columns:1fr}.stats-summary{grid-template-columns:repeat(2,1fr)}.calendar-grid{grid-template-columns:repeat(auto-fill,minmax(45px,1fr));gap:.4rem}.student-header{padding:1rem}.student-info h4{font-size:1.05rem}.quick-stat,.attendance-percentage{font-size:.8rem;padding:.3rem .6rem}.student-details,.attendance-calendar,.chart-container,.student-chart{box-sizing:border-box}.student-details{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1rem}.attendance-calendar,.chart-container,.student-chart{width:100%;max-width:100%;margin:0}.chart-container,.student-chart{padding:.5rem}}@media (max-width: 480px){.mobile-attendance-header h2{font-size:1.35rem}.stats-summary{grid-template-columns:1fr}.stat-value{font-size:1.5rem}.calendar-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:.3rem}.student-quick-stats{gap:.5rem}}@media (min-width: 768px) and (max-width: 1200px){.mobile-attendance-page{padding:1.5rem}.filter-grid{grid-template-columns:repeat(2,1fr)}.stats-summary{grid-template-columns:repeat(4,1fr)}.calendar-grid{grid-template-columns:repeat(auto-fill,minmax(55px,1fr))}}@media print{.mobile-attendance-page{background:#fff}.filter-grid,.expand-icon,.stats-header svg{display:none}.student-card{page-break-inside:avoid;box-shadow:none;border:1px solid #ddd}.student-details{display:block!important}}.chart-container,.student-chart{position:relative;box-sizing:border-box;width:100%;min-width:0}.EventDetails-page{padding:40px 20px;min-height:100vh;font-family:Poppins,sans-serif;color:var(--primary_text);display:flex;justify-content:center}.EventDetails-card{max-width:900px;width:100%;background-color:var(--card_bg, #fff);padding:30px 25px;border-radius:15px;box-shadow:0 8px 20px #0000001a}.EventDetails-title{font-size:2.5rem;color:var(--accent_color);margin-bottom:15px;text-align:center;font-weight:700}.EventDetails-date{color:var(--secondary_text);font-weight:500;margin-bottom:15px;text-align:center}.EventDetails-staff{color:var(--table_text);margin-bottom:20px;text-align:center}.EventDetails-description-box{background-color:var(--card_bg_light, #f9f9f9);padding:15px 20px;border-radius:10px;margin-bottom:30px;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.EventDetails-description{color:var(--table_text);line-height:1.6;margin:0}.EventDetails-images{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.EventDetails-image-box{display:flex;flex-direction:column;align-items:center;max-width:250px;word-wrap:break-word}.EventDetails-image{width:100%;border-radius:12px;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}.EventDetails-image:hover{transform:scale(1.05);box-shadow:0 4px 12px var(--accent_color)}.EventDetails-image-caption{font-size:.9rem;color:var(--secondary_text);text-align:center;margin-top:5px;word-wrap:break-word}.EventDetails-loading,.EventDetails-error,.EventDetails-noEvent{text-align:center;font-size:1.2rem;margin-top:50px;color:var(--secondary_text)}.schedule-page{background-color:#f3f4f6;min-height:100vh;padding:1rem}.schedule-container{max-width:896px;margin:0 auto}.page-header{margin-bottom:1.5rem}.page-title{font-size:1.875rem;font-weight:700;color:#1f2937}.page-subtitle{font-size:1rem;color:#6b7280}.content-wrapper{background-color:#fff;padding:1rem;border-radius:.75rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.schedule-list{display:flex;flex-direction:column;gap:1rem}.schedule-card{background-color:#fff;border-left:4px solid #3b82f6;border-radius:0 .5rem .5rem 0;box-shadow:0 1px 2px #0000000d;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.schedule-card:hover{transform:scale(1.02);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.card-content{padding:1.25rem;display:flex;flex-direction:column}.card-left{flex-shrink:0;margin-bottom:1rem}.period-icon-wrapper{display:flex;align-items:center}.period-number{font-size:1.5rem;font-weight:700;color:#2563eb;background-color:#dbeafe;border-radius:9999px;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center}.period-details{margin-left:1rem}.period-title{font-size:1.125rem;font-weight:600;color:#1f2937}.time-info{display:flex;align-items:center;font-size:.875rem;color:#6b7280;margin-top:.25rem}.card-right{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;align-items:center;color:#4b5563}.info-title{font-weight:600;margin-right:.5rem}.icon{margin-right:.75rem;color:#9ca3af}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:16rem;text-align:center}.spinner-icon{font-size:2.25rem;color:#3b82f6;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{margin-left:1rem;font-size:1.125rem;color:#4b5563}.error-icon{font-size:3rem;color:#ef4444}.error-title{margin-top:1rem;font-size:1.125rem;font-weight:600;color:#b91c1c}.error-message{margin-top:.25rem;font-size:.875rem;color:#dc2626}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-title{font-size:1.25rem;font-weight:600;color:#374151}.empty-message{color:#6b7280}@media (min-width: 640px){.schedule-page,.content-wrapper{padding:1.5rem}}@media (min-width: 768px){.schedule-list{gap:1.5rem}.card-content{flex-direction:row;align-items:center;justify-content:space-between}.card-left{margin-bottom:0;border-right:1px solid #e5e7eb;padding-right:1.5rem}.card-right{flex-grow:1;padding-left:1.5rem}}@media (min-width: 1024px){.schedule-page{padding:2rem}}.manage-schedule-page{padding:1rem;background-color:var(--body_bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--primary_text)}.manage-schedule-header{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.manage-schedule-header h1{font-size:1.75rem;font-weight:700;color:var(--primary_text)}.manage-schedule-save-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s ease-in-out;background-color:var(--success_color);color:var(--button_primary_text)}.manage-schedule-save-button:hover{background-color:var(--sidebar_text_hover);transform:translateY(-2px)}.manage-schedule-save-button:disabled{background-color:var(--button_secondary_bg);cursor:not-allowed;transform:none;opacity:.7}.manage-schedule-spinner-icon{animation:manage-schedule-spin 1s linear infinite}@keyframes manage-schedule-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.manage-schedule-grid-view{display:none}.manage-schedule-card-view{display:flex;flex-direction:column;gap:1.5rem}.manage-schedule-day-card{background-color:var(--card_bg);border-radius:.75rem;box-shadow:var(--card_shadow);overflow:hidden}.manage-schedule-day-card-header{padding:.75rem 1rem;background-color:var(--primary_bg);color:var(--primary_text);font-size:1.1rem;font-weight:600;border-bottom:1px solid var(--border_color)}.manage-schedule-period-row{display:flex;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border_color);cursor:pointer;transition:background-color .2s}.manage-schedule-period-row:last-child{border-bottom:none}.manage-schedule-period-row:hover{background-color:var(--hover_bg)}.manage-schedule-period-label-mobile{flex-shrink:0;font-weight:600;color:var(--accent_color);background-color:var(--secondary_bg);border-radius:.375rem;padding:.25rem .5rem;margin-right:1rem;min-width:40px;text-align:center}.manage-schedule-period-content{flex-grow:1;display:flex;flex-direction:column;gap:.25rem}.manage-schedule-class-name{font-weight:600;color:var(--primary_text)}.manage-schedule-subject-name,.manage-schedule-empty-slot-text{font-size:.9rem;color:var(--secondary_text)}.manage-schedule-period-action-icon{margin-left:1rem;color:var(--icon_color)}.manage-schedule-time-slot{font-size:.8rem;color:var(--secondary_text);background-color:var(--hover_bg);padding:2px 6px;border-radius:4px;align-self:flex-start}@media (min-width: 992px){.manage-schedule-card-view{display:none}.manage-schedule-grid-view{display:grid;grid-template-columns:8rem repeat(6,1fr);gap:2px;background-color:var(--body_bg);border:1px solid var(--border_color);border-radius:.5rem;overflow:hidden}.manage-schedule-header{flex-direction:row;justify-content:space-between;align-items:center}.manage-schedule-grid-header,.manage-schedule-period-label{background-color:var(--table_header_bg);color:var(--table_header_text)}.manage-schedule-grid-header,.manage-schedule-period-label,.manage-schedule-grid-cell{padding:.75rem;min-height:6rem;display:flex;align-items:center;justify-content:center;font-weight:600;text-align:center}.manage-schedule-grid-cell{background-color:var(--card_bg);cursor:pointer;transition:background-color .2s}.manage-schedule-grid-cell:hover{background-color:var(--hover_bg)}.manage-schedule-empty-cell{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--secondary_text)}.manage-schedule-filled-cell{position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.2rem;width:100%;height:100%;padding:.5rem;background-color:var(--accent_color);border-radius:.375rem;font-weight:500;font-size:.8rem;color:var(--accent_text)}.manage-schedule-filled-cell .manage-schedule-class-name{font-weight:700}.manage-schedule-filled-cell .manage-schedule-subject-name{opacity:.9}.manage-schedule-filled-cell .manage-schedule-section-name{font-size:.7rem;opacity:.8}.manage-schedule-edit-icon{display:none;position:absolute;top:5px;right:5px}.manage-schedule-filled-cell:hover .manage-schedule-edit-icon{display:block}}.manage-schedule-modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:100}.manage-schedule-modal-content{background-color:var(--card_bg);padding:0;border-radius:.75rem;width:90%;max-width:450px;border:1px solid var(--border_color);overflow:hidden}.manage-schedule-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border_color);background-color:var(--primary_bg)}.manage-schedule-modal-header h2{font-size:1.25rem;font-weight:600;color:var(--primary_text)}.manage-schedule-modal-body{padding:1.5rem}.manage-schedule-close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--icon_color)}.manage-schedule-close-button:hover{color:var(--icon_hover_color)}.manage-schedule-slot-info{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--accent_text);background-color:var(--info_color);padding:.5rem 1rem;border-radius:99px;margin-bottom:1.5rem}.manage-schedule-modal-form .manage-schedule-form-group{margin-bottom:1rem}.manage-schedule-modal-form label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--primary_text)}.manage-schedule-modal-form select,.manage-schedule-modal-form input[type=time]{width:100%;padding:.75rem;border:1px solid var(--border_color);border-radius:.5rem;font-size:1rem;background-color:var(--primary_bg);color:var(--primary_text);box-sizing:border-box}.manage-schedule-form-row{display:flex;gap:1rem;width:100%}.manage-schedule-form-row .manage-schedule-form-group{flex:1}.manage-schedule-modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-top:1px solid var(--border_color)}.manage-schedule-footer-actions{display:flex;gap:.75rem}.manage-schedule-cancel-button,.manage-schedule-delete-button,.manage-schedule-save-slot-button{padding:.6rem 1.2rem;font-weight:600;border-radius:.5rem;border:none;cursor:pointer;transition:opacity .2s}.manage-schedule-cancel-button{background-color:transparent;border:1px solid var(--button_secondary_bg);color:var(--primary_text)}.manage-schedule-cancel-button:hover{background-color:var(--hover_bg)}.manage-schedule-delete-button{background-color:var(--danger_color);color:var(--accent_text)}.manage-schedule-delete-button:hover{opacity:.8}.manage-schedule-save-slot-button{background-color:var(--button_primary_bg);color:var(--button_primary_text)}.manage-schedule-save-slot-button:hover{background-color:var(--sidebar_text_hover)}.manage-schedule-message{padding:.75rem;border-radius:.5rem;margin-bottom:1rem;font-weight:500;color:var(--accent_text)}.manage-schedule-message.success{background-color:var(--success_color)}.manage-schedule-message.error{background-color:var(--danger_color)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:sans-serif;background:var(--body_bg);color:var(--primary_text);min-height:100vh;font-size:var(--base-font-size)}@media (max-width: 768px){body{font-size:15px}}@media (max-width: 480px){body{font-size:14px}}
