@charset "UTF-8";body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b 50%,#334155);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;min-height:100vh;padding:1rem}.login-card{background-color:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-width:400px;overflow:hidden;padding:3rem;position:relative;width:100%}.logo-section{margin-bottom:2rem;text-align:center}.logo-container{display:inline-flex;margin-bottom:1rem}.login-logo-image,.logo-container{align-items:center;justify-content:center;position:relative}.login-logo-image{border-radius:16px;display:flex;height:70px;width:200px}.title{color:#111827;font-size:28px;margin:0 0 4px}.subtitle{color:#6b7280;font-size:16px;margin:0}.tagline{color:#9ca3af;font-size:14px;margin-top:8px}.login-form form{display:flex;flex-direction:column;gap:1.5rem}.label{color:#374151;font-size:14px;font-weight:500;margin-bottom:6px}.role-label{margin-bottom:-16px}.input-group,.input-wrapper{position:relative}.input-wrapper{align-items:center;background-color:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;display:flex;padding:12px 16px 12px 44px;transition:all .2s}.input-wrapper.focused{background-color:#fff;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1a}.input-icon{color:#9ca3af;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.input-field{background:#0000;border:none;font-size:16px;outline:none;width:100%}.password-toggle{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.role-selection{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);margin-bottom:1rem}.role-button{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:12px;font-weight:500;padding:12px 8px;text-align:center;transition:all .2s}.role-button.active{background-color:#f0fdf4;border-color:#16a34a;color:#15803d}.button-group{margin-top:1rem}.submit-button{align-items:center;background:linear-gradient(135deg,#16a34a,#84cc16);border:none;border-radius:8px;box-shadow:0 4px 14px #16a34a4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:14px;transition:all .2s;width:100%}.submit-button:hover{box-shadow:0 6px 20px #16a34a66;transform:translateY(-1px)}.submit-icon{margin-right:4px}.error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;margin-top:1rem;padding:12px;text-align:center}.footer{border-top:1px solid #f3f4f6;margin-top:2rem;padding-top:1rem;text-align:center}.footer-text{color:#9ca3af;font-size:12px}@media (max-width:640px){.login-card{border-radius:12px;padding:2rem}.title{font-size:22px}.subtitle{font-size:14px}.tagline{font-size:12px}.role-selection{grid-template-columns:repeat(2,1fr)}.submit-button{font-size:14px;padding:12px}.input-wrapper{padding:10px 14px 10px 40px}.input-field{font-size:14px}.error-message{font-size:13px;padding:10px}}@media (max-width:420px){.role-selection{grid-template-columns:1fr}}.sidebar-main{display:flex;flex-direction:column;height:calc(100vh - 120px);overflow-y:auto}.sidebar{background-color:#fff;border-right:1px solid #e2e8f0;box-shadow:2px 0 10px #0000001a;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:17%;z-index:1000}.sidebar-header-title{margin-left:20px}.sidebar-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;gap:12px;padding:1.5rem}.sidebar-logo-icon{align-items:center;display:flex;height:80px;justify-content:center;position:relative;width:250px}.logo-image{height:100%;margin-right:30px;width:100%}.header-title{font-size:16px;margin:0}.header-subtitle{color:#64748b;font-size:12px;margin:0}nav{padding:1rem 0}.main-menu{align-items:center;border-left:3px solid #0000;border-radius:0 8px 8px 0;color:#64748b;cursor:pointer;display:flex;gap:12px;padding:12px 1.5rem;text-decoration:none;transition:all .2s}.main-menu:hover{background-color:#f3f4f6}.main-menu.active{background-color:#f0fdf4;border-left-color:#16a34a;color:#16a34a}.main-menu.active .menu-item{color:#fff}.menu-item{font-weight:500}.main-content{display:flex;flex-direction:column;margin-left:17%;min-height:100vh}.logout-section{border-top:1px solid #e2e8f0;margin:1rem 0;padding:1rem}.nav-item-logout{align-items:center;border-left:3px solid #0000;color:#64748b;cursor:pointer;display:flex;gap:12px;padding:12px 1.5rem;transition:all .2s}.nav-item-logout:hover{background-color:#f8fafc;color:#334155}@media (max-width:1024px){.sidebar{width:220px}.main-content{margin-left:220px}.sidebar-logo-icon{height:60px;width:180px}}@media (max-width:768px){.sidebar{border-bottom:1px solid #e2e8f0;border-right:none;box-shadow:0 2px 6px #0000000d;height:auto;position:relative;width:100%}.main-content{margin-left:0}.sidebar-header{gap:8px;padding:1rem}.sidebar-logo-icon{height:50px;width:150px}.logo-image{margin-right:15px}nav{display:flex;flex-direction:column;padding:.5rem 0}.main-menu{border-bottom:1px solid #f1f5f9;border-left:none;border-radius:0;flex:1 1 auto;padding:12px 1rem}.main-menu:last-child{border-bottom:none}.logout-section{border-top:1px solid #e2e8f0;margin:0;padding:.5rem 1rem}.nav-item-logout{border-left:none;border-radius:0;border-top:1px solid #f1f5f9;padding:12px 1rem}}@media (max-width:480px){.header-title{font-size:14px}.header-subtitle{font-size:10px}.menu-item{font-size:14px}}.sidebar-toggle{background:#0000;border:none;display:none;padding:0}.sidebar-toggle-bar{background-color:#111827;border-radius:999px;display:block;height:2px;width:18px}@media (max-width:768px){.sidebar{border-bottom:1px solid #e2e8f0;border-right:none;box-shadow:0 2px 6px #0000000d;height:auto;position:relative;width:100%}.sidebar-header{align-items:center;display:flex;gap:10px;justify-content:flex-start;padding:.8rem 1rem;position:relative}.sidebar-logo-icon{height:50px;width:150px}.logo-image{margin-right:0}.sidebar-header-title{margin-left:0}.header-title{font-size:16px;font-weight:700}.header-subtitle{font-size:11px}.sidebar-toggle{align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:999px;box-shadow:0 1px 3px #0f172a1f;cursor:pointer;display:inline-flex;flex-direction:column;gap:4px;height:36px;justify-content:center;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:36px}.sidebar-toggle-bar{background-color:#111827;height:2px;width:18px}.sidebar-main{background-color:#f9fafb;border-top:1px solid #e2e8f0;display:none;height:auto}.sidebar-main.open{display:block}.sidebar-main nav{display:flex;flex-direction:column;padding:.5rem 0}.sidebar-main .main-menu{border-bottom:1px solid #f1f5f9;border-left:none;border-radius:0;flex:1 1 auto;padding:11px 1rem}.sidebar-main .main-menu:last-of-type{border-bottom:none}.sidebar-main .main-menu.active{background-color:#f0fdf4;border-left:3px solid #16a34a;color:#16a34a;padding-left:calc(1rem - 3px)}.sidebar-main .main-menu svg{flex-shrink:0}.sidebar-main .logout-section{border-top:1px solid #e2e8f0;margin:0;padding:.5rem 1rem .75rem}.sidebar-main .nav-item-logout{border-left:none;border-radius:0;border-top:1px solid #f1f5f9;padding:11px 0}.main-content{margin-left:0}}@media (min-width:1025px){.sidebar{background-color:#fff;border-right:1px solid #e2e8f0;box-shadow:2px 0 8px #0f172a0f;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:240px}.sidebar-header{gap:10px;padding:1.25rem}.sidebar-logo-icon{height:60px;width:160px}.logo-image{height:100%;margin-right:0;width:100%}.sidebar-header-title{margin-left:0}.header-title{font-size:15px;font-weight:700;letter-spacing:.04em}.header-subtitle{font-size:11px}nav{padding:.75rem 0}.main-menu{border-left:3px solid #0000;border-radius:0 10px 10px 0;font-size:14px;gap:10px;padding:9px 1.25rem}.main-menu:hover{background-color:#f3f4f6}.main-menu.active{background-color:#f0fdf4;border-left-color:#16a34a;color:#14532d;font-weight:600}.main-menu svg{flex-shrink:0}.logout-section{margin-top:auto;padding:.75rem 0 1.25rem}.nav-item-logout{border-left:3px solid #0000;padding:9px 1.25rem}.nav-item-logout:hover{background-color:#fef2f2;color:#b91c1c}.main-content{margin-left:240px;padding:24px 32px 40px}}.message-modal *,.message-modal :after,.message-modal :before{box-sizing:border-box}.message-modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:9999}.message-modal{background:#fff;border-radius:10px;box-shadow:0 8px 30px #0000001f;max-height:95vh;max-width:560px;overflow-y:auto;padding:18px 20px;width:100%}.message-modal h2{font-size:1.25rem;margin:0 0 12px}.message-modal form{display:flex;flex-direction:column;gap:12px}.message-modal label{color:#222;display:block;font-size:.9rem;font-weight:600;margin-bottom:6px}.message-modal input,.message-modal input[type=datetime-local],.message-modal select,.message-modal textarea{background:#fff;border:1px solid #dcdcdc;border-radius:8px;font-size:.95rem;padding:8px 10px;width:100%}.message-modal textarea{min-height:110px;resize:vertical}.message-row{align-items:flex-start;display:flex;gap:10px;margin-bottom:1rem}.message-row>div{display:flex;flex:1 1;flex-direction:column;min-width:0}.message-row input[type=datetime-local]{padding:6px 8px}.message-modal input[type=checkbox]{margin-right:8px;width:auto}.message-groups-section{grid-gap:8px;background:#fbfbfb;border:1px solid #f0f0f0;border-radius:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:6px;padding:8px}.message-groups-section label{align-items:center;background:#fff;border:1px solid #eee;border-radius:6px;display:flex;font-size:.95rem;font-weight:500;gap:8px;padding:6px 8px}.message-groups-section label:hover{background:#f7fbff;border-color:#e6f0ff}.message-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}@media (max-width:520px){.message-row{flex-direction:column}.message-modal{padding:14px}.message-modal-actions{flex-direction:column-reverse;gap:8px}.message-modal-actions .btn{width:100%}}.admin-dashboard-panel{background-color:#f3f4f6;display:flex;min-height:100vh}.admin-dashboard-panel .main-content{display:flex;flex:1 1;flex-direction:column}.admin-dashboard-inner{box-sizing:border-box;margin:0 auto;max-width:1180px;padding:24px 32px 40px}.admin-dashboard-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:18px}.admin-dashboard-title{font-size:28px;font-weight:700;letter-spacing:.01em;margin:0}.admin-dashboard-subtitle{color:#6b7280;font-size:14px;margin:6px 0 0}.admin-dashboard-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:20px}.admin-dashboard-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 18px 40px #0f172a0a}.admin-dashboard-stat-card{align-items:center;display:flex;gap:14px;padding:16px 18px}.admin-dashboard-stat-icon-wrap{align-items:center;background-color:#ecfdf3;border-radius:999px;color:#16a34a;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.admin-dashboard-stat-content{display:flex;flex-direction:column;gap:2px}.admin-dashboard-stat-label{color:#6b7280;font-size:13px;margin:0}.admin-dashboard-stat-value{font-size:22px;font-weight:700;margin:0}.admin-dashboard-stat-desc{color:#9ca3af;font-size:12px;margin:0}.admin-dashboard-quick-actions{margin-bottom:20px;padding:16px 18px}.admin-dashboard-section-title{font-size:15px;font-weight:600;margin:0 0 10px}.admin-dashboard-actions-row{display:flex;flex-wrap:wrap;gap:10px}.admin-dashboard-chip{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;color:inherit;cursor:pointer;display:inline-flex;font-size:13px;gap:6px;padding:7px 13px;text-decoration:none;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease}.admin-dashboard-chip:hover{background-color:#ecfdf3;border-color:#16a34a;box-shadow:0 6px 16px #16a34a1f;color:inherit;text-decoration:none}.admin-dashboard-main-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);margin-bottom:20px}.admin-dashboard-messages,.admin-dashboard-upcoming{padding:16px 18px 14px}.admin-dashboard-list{list-style:none;margin:4px 0 0;padding:0}.admin-dashboard-list-item{border-bottom:1px solid #f3f4f6;color:#374151;font-size:13px;padding:7px 0}.admin-dashboard-list-item:last-child{border-bottom:none}.admin-dashboard-activity{padding:16px 18px 14px}.admin-dashboard-table-wrapper{margin-top:8px;overflow-x:auto}.admin-dashboard-table{border-collapse:collapse;font-size:13px;width:100%}.admin-dashboard-table td,.admin-dashboard-table th{padding:8px 10px;text-align:left}.admin-dashboard-table thead th{border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600}.admin-dashboard-table tbody tr:nth-child(2n){background-color:#f9fafb}@media (max-width:1024px){.admin-dashboard-inner{padding:20px 20px 32px}.admin-dashboard-title{font-size:24px}}@media (max-width:768px){.admin-dashboard-panel{display:block}.admin-dashboard-panel .main-content{margin-left:0;width:100%}.admin-dashboard-inner{max-width:100%;padding:18px 14px 26px}.admin-dashboard-header{align-items:flex-start;flex-direction:column;gap:8px}.admin-dashboard-title{font-size:22px}.admin-dashboard-subtitle{font-size:13px}.admin-dashboard-main-grid,.admin-dashboard-stats-grid{grid-template-columns:minmax(0,1fr)}.admin-dashboard-quick-actions{margin-bottom:16px}}@media (max-width:640px){.admin-dashboard-inner{padding:16px 10px 22px}.admin-dashboard-card{box-shadow:0 10px 26px #0f172a0a}.admin-dashboard-quick-actions,.admin-dashboard-stat-card{padding:14px}.admin-dashboard-activity,.admin-dashboard-messages,.admin-dashboard-upcoming{padding:14px 14px 12px}.admin-dashboard-actions-row{gap:8px}.admin-dashboard-chip{font-size:12px;padding:6px 11px}.admin-dashboard-section-title{font-size:14px}}.admin-dashboard-note-helper{color:#9ca3af;font-size:12px;margin:0 0 8px}.admin-dashboard-note-textarea{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;box-sizing:border-box;font-size:13px;line-height:1.45;min-height:140px;outline:none;padding:10px 12px;resize:vertical;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease;width:100%}.admin-dashboard-note-textarea:focus{background-color:#fff;border-color:#16a34a;box-shadow:0 0 0 1px #16a34a14}@media (max-width:640px){.admin-dashboard-note-textarea{font-size:12px;min-height:120px;padding:9px 10px}.admin-dashboard-note-helper{font-size:11px}}.admin-dashboard-admin-notes{border-top:1px solid #f3f4f6;margin-top:16px;padding-top:12px}.admin-dashboard-admin-notes-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.admin-dashboard-admin-notes-title{color:#111827;font-size:13px;font-weight:600;margin:0}.admin-dashboard-add-note-btn{align-items:center;background-color:#16a34a;border:1px solid #16a34a;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:6px 12px;transition:background-color .15s ease,border-color .15s ease}.admin-dashboard-add-note-btn:hover{background-color:#15803d;border-color:#15803d}.admin-dashboard-admin-notes-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.admin-dashboard-admin-note-item{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;line-height:1.5;padding:10px 12px}.admin-dashboard-admin-note-content{display:flex;flex-direction:column;gap:6px}.admin-dashboard-admin-note-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.admin-dashboard-admin-note-author{color:#111827;font-weight:600}.admin-dashboard-admin-note-date{color:#6b7280;font-size:11px}.admin-dashboard-delete-note-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#ef4444;cursor:pointer;display:flex;margin-left:auto;padding:4px;transition:background-color .15s ease}.admin-dashboard-delete-note-btn:hover{background-color:#fee2e2}.admin-dashboard-admin-note-text{word-wrap:break-word;color:#374151}.admin-dashboard-empty-notes{color:#6b7280;font-size:12px;font-style:italic;padding:16px 0;text-align:center}@media (max-width:640px){.admin-dashboard-admin-notes-title{font-size:12px}.admin-dashboard-admin-note-item{font-size:12px;padding:6px 10px}}.page-subtitle{color:#64748b;margin-bottom:2rem}.page-title{color:#1e293b;font-size:2rem;font-weight:700;margin-bottom:.5rem}.management-content{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.management-card{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.card-header-management{margin-bottom:.5rem}.btn{padding:8px 16px}.btn-secondary{background-color:#f1f5f9}.btn:hover{opacity:.9}.btn-success{background-color:#28a745;color:#fff}.icon-style{margin-right:.25rem}.error-message{color:red}.student-list-container{border:1px solid #e2e8f0;border-radius:8px;margin-top:1rem;overflow:hidden}.student-grid-row{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:1.5fr 2fr 2.5fr 120px;padding:.75rem 1rem;word-break:break-word}.student-list-header{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;font-weight:600}.student-row{border-bottom:1px solid #e2e8f0;transition:opacity .3s ease,transform .3s ease,background-color .2s ease}.student-row:hover{background-color:#f8fafc}.student-row.removing{opacity:0;transform:translateX(-20px)}.student-row:last-child{border-bottom:none}.student-name{font-weight:500}.student-email{color:#64748b}.student-row span:nth-child(3){font-size:14px;white-space:nowrap}.action-buttons{gap:.5rem;justify-content:flex-start}.icon-button{background:#0000;padding:.25rem}.edit-button{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px}.modal-overlay-management{align-items:center;background-color:#00000080;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2000}.modal-content-management{animation:fadeIn .3s ease;background-color:#fff;border-radius:10px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:92vh;max-width:500px;overflow:hidden;padding:30px;width:90%;z-index:2100}.modal-content-management h2{flex-shrink:0;font-size:20px;margin-bottom:20px;margin-top:0}.modal-content-management form{display:flex;flex:1 1;flex-direction:column;margin-right:-10px;min-height:0;overflow-x:hidden;overflow-y:auto;padding-right:10px}.modal-content-management form::-webkit-scrollbar{width:8px}.modal-content-management form::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.modal-content-management form::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.modal-content-management form::-webkit-scrollbar-thumb:hover{background:#94a3b8}.modal-content-management>p{align-items:center;display:flex;flex:1 1;justify-content:center}.modal-view-student{max-width:600px}.student-view-content{flex:1 1;margin-right:-10px;overflow-x:hidden;overflow-y:auto;padding-right:10px}.student-view-content::-webkit-scrollbar{width:8px}.student-view-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.student-view-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.student-view-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.student-info-grid{display:flex;flex-direction:column;gap:20px}.student-info-item{align-items:flex-start;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:12px;padding:12px}.student-info-item svg{flex-shrink:0;margin-top:2px}.info-label{color:#64748b;font-size:12px;font-weight:500;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.info-value{color:#1e293b;font-size:15px;font-weight:500;word-break:break-word}.modal-content-management label{display:block;font-weight:500;margin-bottom:16px}.modal-content-management input{border:1px solid #ccc;border-radius:5px;box-sizing:border-box;margin-top:6px;padding:10px;width:100%}.modal-actions{border-top:1px solid #e2e8f0;padding-top:20px}.form-label{font-size:14px}.action-buttons{display:flex;gap:8px}.icon-button{background:none;border:none;cursor:pointer;font-size:1.2rem;margin:0 5px;transition:transform .2s ease}.icon-button.delete:hover{color:red;transform:scale(1.2)}.icon-button.edit:hover{color:#28a745;transform:scale(1.2)}select.form-input{appearance:none;background-color:#fff;background-position:right 10px center;background-repeat:no-repeat;background-size:12px;border:1px solid #ccc;border-radius:5px;cursor:pointer;font-size:14px;margin-bottom:12px;margin-top:6px;padding:10px;transition:border-color .2s;width:100%}select.form-input:focus{border-color:#28a745;outline:none}.menagment-form-select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;margin-bottom:12px;padding:8px 12px;width:100%}@media (max-width:1024px){.page-title{font-size:1.5rem}.student-grid-row{gap:.5rem;grid-template-columns:1fr 2fr 2fr 100px;padding:.5rem .75rem}.btn{font-size:14px;padding:6px 12px}}@media (max-width:768px){.page-title{font-size:1.25rem}.management-content{padding:1rem}.card-header-management{align-items:flex-start;flex-direction:column;gap:.5rem}.button-container{flex-wrap:wrap;justify-content:flex-start;width:100%}.student-grid-row{align-items:flex-start;display:flex;flex-direction:column;gap:.25rem;padding:.75rem}.student-list-header{display:none}.student-row{border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem;padding:.75rem}.action-buttons{margin-top:.5rem}}@media (max-width:480px){.page-title{font-size:1.1rem}.btn{font-size:12px;padding:6px 10px}.student-row{padding:.5rem}.management-card{gap:.5rem}}.search-container{display:flex;justify-content:center;margin:1rem 0}.management-search-input{border:1px solid #ccc;border-radius:8px;font-size:14px;max-width:600px;padding:8px 12px;width:100%}.card-header-left{display:flex;flex-direction:column;gap:.5rem}.management-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.management-filter-select{background-color:#f8fafc;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;font-size:.875rem;min-width:160px;padding:6px 10px;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.management-filter-select:focus{background-color:#fff;border-color:#16a34a;box-shadow:0 0 0 1px #16a34a1f;outline:none}@media (max-width:768px){.card-header-left,.management-filters{width:100%}.management-filter-select{flex:1 1 100%}}.dashboard-profile{background-color:#f8fafc;min-height:100vh;padding:2rem}.consent-notice{background-color:#fffbeb;border:1px solid #fcd34d;border-radius:12px;color:#92400e;justify-content:space-between;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.consent-notice,.consent-notice-content{align-items:flex-start;display:flex;gap:1rem}.consent-notice-content,.consent-notice-main{flex-direction:column}.consent-notice-main{display:flex;gap:.5rem}.consent-notice-title{font-weight:600;margin:0 0 .25rem}.consent-notice-text{color:#b45309;font-size:.95rem;margin:0}.consent-notice-header{align-items:flex-start;display:flex;gap:.75rem}.consent-notice-header svg{margin-top:20px}.consent-notice-checkboxes{display:flex;flex-direction:column;gap:.4rem;margin-top:.25rem}.consent-notice-checkbox{align-items:center;display:flex;font-size:.9rem;gap:.4rem}.consent-notice-button{background-color:#f97316;border:none;color:#fff;white-space:nowrap}.terms-checkbox,.terms-checkbox:checked{accent-color:#16a34a!important}.terms-checkbox:checked{background-color:#16a34a!important;border-color:#16a34a!important}.profile-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:2rem;overflow:hidden;padding:2rem;position:relative}.profile-banner{background:linear-gradient(135deg,#16a34a,#84cc16);height:120px;left:0;opacity:.1;position:absolute;right:0;top:0}.profile-section{align-items:center;display:flex;gap:2rem;position:relative;z-index:1}.profile-picture{background-color:#e5e7eb;border:4px solid #fff;border-radius:50%;box-shadow:0 4px 12px #0000001a;color:#6b7280;font-size:48px;font-weight:700;height:120px;position:relative;width:120px}.profile-edit,.profile-picture{align-items:center;display:flex;justify-content:center}.profile-edit{background-color:#16a34a;border:2px solid #fff;border-radius:50%;bottom:8px;cursor:pointer;height:32px;position:absolute;right:8px;width:32px}.profile-info{flex:1 1}.profile-name{color:#1e293b;font-size:2rem;font-weight:700;margin-bottom:.5rem}.profile-details{color:#64748b;margin-bottom:1rem}.profile-stats-row{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr);margin-top:1.5rem}.profile-stat-item{text-align:center}.profile-stat-value{color:#16a34a;font-size:1.75rem;font-weight:700}.profile-stat-label{color:#64748b;font-size:14px;margin-top:4px}.profile-tabs-container{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:2rem}.profile-tabs-card{border:1px solid #f1f5f9;display:flex}.profile-tab{align-items:center;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:1rem 1.5rem;transition:all .2s}.profile-tab.active-tab{background-color:#f0fdf4;border-bottom:#16a34a;color:#16a34a}.overview-grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.grid-2-columns{grid-template-columns:repeat(2,1fr)}.overview-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:1.5rem;margin-left:2rem;margin-right:2rem;padding:1.5rem}.overview-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.overview-card-title{align-items:center;color:#1e293b;display:flex;font-size:1.25rem;font-weight:600;gap:8px}.btn-secondary-profile{background-color:#fff;border:1px solid #d1d5db;color:#374151}.overview-data-row{align-items:center;display:flex;gap:8px;margin-bottom:8px}.overview-card-footer{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;padding:1rem}.overview-note{color:#166534;font-size:12px;font-weight:500}.overview-progress-row-label{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.overview-progress-label{font-size:14px;font-weight:600}.overview-student-grade{font-size:18px;font-weight:700}.overview-progress-bar-background{background-color:#f1f5f9;border-radius:4px;height:8px;margin-bottom:1rem;overflow:hidden;width:100%}.grade-green-overall{color:#16a34a}.grade-yellow-overall{color:#eab308}.grade-red-overall{color:#dc2626}.overview-progress-bar-fill{border-radius:4px;height:100%;transition:width .3s}.attendance-green-overall{color:#16a34a}.attendance-yellow-overall{color:#eab308}.attendance-red-overall{color:#dc2626}.overview-assignments-completed{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.overview-assignments-item{background-color:#f8fafc;border-radius:6px;padding:1rem;text-align:center}.overview-assignments-value{color:#16a34a;font-size:1.5rem;font-weight:700}.overview-assignments-label{color:#64748b;font-size:12px}.overview-upcoming-session-row{align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:1rem;padding:1rem}.course-card{border-radius:8px;margin-bottom:1rem;margin-left:2rem;margin-right:2rem;transition:all .2s}.course-card-section{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.course-lecturer{color:#64748b;font-size:14px;margin:0}.course-status-badge{border-radius:12px;font-size:12px;font-weight:500;padding:4px 8px}.course-progress-bar-label{display:flex;justify-content:space-between;margin-bottom:4px}.course-statistics-row{grid-gap:1rem;display:grid;font-size:14px;gap:1rem;grid-template-columns:1fr 1fr 1fr}.course-statistics-value{color:#16a34a;font-weight:500}.course-statistics-label{color:#64748b;font-size:12px}.course-next-class{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;margin-top:1rem;padding:.75rem}.course-next-class-label{color:#166534;font-size:12px;font-weight:500}.overview-data-row-settings{align-items:center;display:flex;font-size:18px;gap:12px;margin-bottom:12px}.profile-label{color:#374151;font-size:14px;font-weight:600;margin-bottom:6px;margin-top:6px}.profile-input{border:1px solid #d1d5db;margin:0;padding:8px 12px;width:80%}.btn-profile,.profile-input{border-radius:6px;font-size:14px;transition:all .2s}.btn-profile{align-items:center;border:none;cursor:pointer;display:flex;font-weight:500;gap:8px;justify-content:center;padding:8px 16px}.btn-primary-profile{background-color:#16a34a;color:#fff}.btn-secondary-profile{background-color:#fbfcff;color:#6b7280}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{appearance:button;cursor:pointer;overflow:visible;text-transform:none}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{align-items:stretch;box-sizing:border-box;display:flex;flex-direction:column;height:100%}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar :after,.rbc-calendar :before{box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.rbc-ellipsis,.rbc-event-label,.rbc-row-segment .rbc-event-content,.rbc-show-more{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{border-bottom:1px solid #ddd;flex:1 0;font-size:90%;font-weight:700;min-height:0;overflow:hidden;padding:0 3px;text-align:center;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{background:none;border:none;color:inherit;cursor:pointer;margin:0;padding:0;-webkit-user-select:text;user-select:text}.rbc-row-content{position:relative;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:flex;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{-ms-overflow-style:none;height:100%;overflow-y:scroll;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{align-items:center;display:flex;flex-wrap:wrap;font-size:16px;justify-content:center;margin-bottom:10px}.rbc-toolbar .rbc-toolbar-label{flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{background:none;background-image:none;border:1px solid #ccc;border-radius:4px;color:#373a3c;display:inline-block;line-height:normal;margin:0;padding:.375rem 1rem;text-align:center;vertical-align:middle;white-space:nowrap}.rbc-toolbar button.rbc-active,.rbc-toolbar button:active{background-color:#e6e6e6;background-image:none;border-color:#adadad;box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.rbc-toolbar button.rbc-active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button:active:hover{background-color:#d4d4d4;border-color:#8c8c8c;color:#373a3c}.rbc-toolbar button:focus,.rbc-toolbar button:hover{background-color:#e6e6e6;border-color:#adadad;color:#373a3c}.rbc-toolbar button:hover{cursor:pointer}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:4px;border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px;border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media (max-width:767px){.rbc-toolbar{flex-direction:column}}.rbc-day-slot .rbc-background-event,.rbc-event{background-color:#3174ad;border:none;border-radius:5px;box-shadow:none;box-sizing:border-box;color:#fff;cursor:pointer;margin:0;padding:2px 5px;text-align:left;width:100%}.rbc-day-slot .rbc-slot-selecting .rbc-background-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-slot-selecting .rbc-event{cursor:inherit;pointer-events:none}.rbc-day-slot .rbc-selected.rbc-background-event,.rbc-event.rbc-selected{background-color:#265985}.rbc-day-slot .rbc-background-event:focus,.rbc-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{box-shadow:-1px 1px 5px 0 #33333380}.rbc-event-continues-prior{border-bottom-left-radius:0;border-top-left-radius:0}.rbc-event-continues-after{border-bottom-right-radius:0;border-top-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:flex;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;color:#3174ad;font-size:85%;font-weight:700;height:auto;line-height:normal;z-index:4}.rbc-show-more:focus,.rbc-show-more:hover{color:#265985}.rbc-month-view{border:1px solid #ddd;display:flex;flex:1 0;flex-direction:column;height:100%;position:relative;user-select:none;-webkit-user-select:none;width:100%}.rbc-month-header{display:flex;flex-direction:row}.rbc-month-row{display:flex;flex:1 0;flex-basis:0px;flex-direction:column;height:100%;overflow:hidden;position:relative}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{flex:1 1;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:flex;flex:1 0;flex-direction:row;overflow:hidden;right:1px}.rbc-day-bg{flex:1 0}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{background-color:#fff;border:1px solid #e5e5e5;box-shadow:0 5px 15px #00000040;padding:10px;position:absolute;z-index:5}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:flex;flex:1 0;flex-direction:column;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{border:1px solid #ddd;border-collapse:collapse;border-spacing:0;width:100%}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{border-bottom:1px solid #ddd;padding:3px 5px;text-align:left}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:flex;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{flex:1 1}.rbc-timeslot-group{border-bottom:1px solid #ddd;display:flex;flex-flow:column nowrap;min-height:40px}.rbc-header-gutter,.rbc-time-gutter{flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{bottom:0;left:0;margin-right:10px;position:absolute;right:0;top:0}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-event{align-items:flex-start;border:1px solid #265985;display:flex;flex-flow:column wrap;max-height:100%;min-height:20px;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{word-wrap:break-word;flex:1 1;height:100%;line-height:1;min-height:1em;width:100%}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{background-color:#fff;border-right:1px solid #ddd;left:0;margin-right:-1px;position:sticky;z-index:10}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{flex:1 0;flex-basis:0px;min-width:auto}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-day-bg,.rbc-time-view-resources .rbc-header{flex:1 1;flex-basis:0 px;width:140px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{flex:1 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{background-color:#00000080;color:#fff;font-size:75%;padding:3px;position:absolute;width:100%;z-index:10}.rbc-slot-selecting{cursor:move}.rbc-time-view{border:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-height:0;width:100%}.rbc-time-view .rbc-time-gutter{text-align:right;white-space:nowrap}.rbc-time-view .rbc-allday-cell{box-sizing:initial;height:100%;position:relative;width:100%}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{box-sizing:border-box;min-height:20px}.rbc-time-header{display:flex;flex:0 0 auto;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-left:1px solid #ddd;border-right-width:0}.rbc-time-header>.rbc-row.rbc-row-resource,.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{border-left:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-width:0}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;flex-shrink:0}.rbc-time-content{align-items:flex-start;border-top:2px solid #ddd;display:flex;flex:1 0;overflow-y:auto;position:relative;width:100%}.rbc-time-content>.rbc-time-gutter{flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{user-select:none;-webkit-user-select:none;width:100%}.rbc-current-time-indicator{background-color:#74ad31;height:1px;left:0;pointer-events:none;position:absolute;right:0;z-index:3}.rbc-resource-grouping.rbc-time-header-content{display:flex;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.tippy-box[data-animation=fade][data-state=hidden]{opacity:0}[data-tippy-root]{max-width:calc(100vw - 10px)}.tippy-box{background-color:#333;border-radius:4px;color:#fff;font-size:14px;line-height:1.4;outline:0;position:relative;transition-property:transform,visibility,opacity;white-space:normal}.tippy-box[data-placement^=top]>.tippy-arrow{bottom:0}.tippy-box[data-placement^=top]>.tippy-arrow:before{border-top-color:initial;border-width:8px 8px 0;bottom:-7px;left:0;transform-origin:center top}.tippy-box[data-placement^=bottom]>.tippy-arrow{top:0}.tippy-box[data-placement^=bottom]>.tippy-arrow:before{border-bottom-color:initial;border-width:0 8px 8px;left:0;top:-7px;transform-origin:center bottom}.tippy-box[data-placement^=left]>.tippy-arrow{right:0}.tippy-box[data-placement^=left]>.tippy-arrow:before{border-left-color:initial;border-width:8px 0 8px 8px;right:-7px;transform-origin:center left}.tippy-box[data-placement^=right]>.tippy-arrow{left:0}.tippy-box[data-placement^=right]>.tippy-arrow:before{border-right-color:initial;border-width:8px 8px 8px 0;left:-7px;transform-origin:center right}.tippy-box[data-inertia][data-state=visible]{transition-timing-function:cubic-bezier(.54,1.5,.38,1.11)}.tippy-arrow{color:#333;height:16px;width:16px}.tippy-arrow:before{border-color:#0000;border-style:solid;content:"";position:absolute}.tippy-content{padding:5px 9px;position:relative;z-index:1}.calendar-container{box-sizing:border-box;display:flex;flex-direction:column;gap:8px;padding:8px 0;width:100%}.calendar-header{align-items:center;display:flex;justify-content:flex-end;margin-bottom:6px}.calendar-scroll-wrapper{-webkit-overflow-scrolling:touch;border-radius:12px;flex:1 1;overflow-x:auto;overflow-y:hidden}.rbc-time-view{border:1px solid #e5e7eb;border-radius:12px;min-width:900px}.rbc-time-content{border-top:1px solid #e5e7eb}.rbc-time-gutter{background-color:#fafafa;border-right:1px solid #e5e7eb}@media (max-width:1024px){.calendar-container{padding:6px 0}.rbc-time-view{min-width:720px}}@media (max-width:768px){.calendar-container{padding:4px 0}.rbc-time-view{min-width:640px}}@media (max-width:480px){.rbc-time-view{min-width:580px}.rbc-event,.rbc-header,.rbc-time-gutter{font-size:12px}}.calendar-page-inner{box-sizing:border-box;margin:0 auto;max-width:1180px;padding:24px 32px 40px}.calendar-page-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:12px}.calendar-page-header h1{font-size:22px;font-weight:700;margin:0}.calendar-page-subtitle{color:#6b7280;font-size:13px;margin:4px 0 0}.calendar-page-actions{display:flex;flex-wrap:wrap;gap:8px}.calendar-page-actions .btn-primary,.calendar-page-actions .btn-secondary{border-radius:999px;cursor:pointer;font-size:14px;padding:8px 14px;white-space:nowrap}.calendar-page-actions .btn-primary{background-color:#16a34a;border:none;color:#fff}.calendar-page-actions .btn-primary:hover{background-color:#15803d}.calendar-page-actions .btn-secondary{background-color:#f9fafb;border:1px solid #e5e7eb}.calendar-page-actions .btn-secondary:hover{background-color:#e5e7eb}.calendar-filters-section{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}.calendar-filters-label{color:#6b7280;font-size:13px}.calendar-group-select-wrap{min-width:260px}.calendar-group-select{background-color:#fff;border:1px solid #d1d5db;border-radius:999px;cursor:pointer;font-size:13px;padding:7px 12px;width:100%}.calendar-main-section{background-color:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 14px 30px #0f172a0f;box-sizing:border-box;margin-top:4px;overflow:visible;padding:14px 16px 18px;width:100%}.calendar-main-section .calendar-header{display:none}.calendar-main-section .calendar-container{gap:4px;padding:0}.calendar-main-section .rbc-calendar{border-radius:12px;box-shadow:none;font-size:13px;min-height:430px;width:100%}.calendar-main-section .rbc-month-view{width:100%}.calendar-main-section .rbc-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:6px;justify-content:space-between;margin-bottom:8px}.calendar-main-section .rbc-toolbar .rbc-btn-group{display:flex;flex-wrap:wrap;gap:4px}.calendar-main-section .rbc-toolbar button{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;cursor:pointer;font-size:12px;padding:3px 10px}.calendar-main-section .rbc-toolbar button.rbc-active,.calendar-main-section .rbc-toolbar button:hover{background-color:#16a34a;border-color:#16a34a;color:#fff}.calendar-main-section .rbc-toolbar-label{font-weight:600}.calendar-main-section .refresh-btn{display:none}@media (max-width:1024px){.calendar-page-inner{padding:20px 18px 32px}.calendar-page-header{align-items:flex-start;flex-direction:column;gap:6px}.calendar-main-section .rbc-calendar{min-height:400px}}@media (max-width:640px){.calendar-page-inner{max-width:100%;padding:16px 0 24px}.calendar-page-header{padding:0 10px}.calendar-page-header h1{font-size:20px}.calendar-page-subtitle{font-size:12px}.calendar-filters-section{align-items:flex-start;flex-direction:column;padding:0 10px}.calendar-group-select-wrap{width:100%}.calendar-main-section{border-radius:16px;box-sizing:border-box;margin-left:50%;margin-top:10px;max-width:calc(100vw - 20px);padding:10px 12px 14px;transform:translateX(-50%);width:calc(100vw - 20px)}.calendar-main-section .rbc-calendar{font-size:12px;min-height:360px;width:100%}.calendar-main-section .rbc-toolbar{align-items:center;flex-direction:column}}.calendar-filters-row{display:flex;flex-wrap:wrap;gap:8px}.calendar-select-wrap{min-width:180px}.calendar-filter-select{background-color:#fff;border:1px solid #d1d5db;border-radius:999px;cursor:pointer;font-size:13px;padding:7px 12px;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease;width:100%}.calendar-filter-select:focus{background-color:#fff;border-color:#16a34a;box-shadow:0 0 0 1px #16a34a1f;outline:none}@media (min-width:1025px){.calendar-page-inner{max-width:1320px;padding:24px 24px 40px}.calendar-main-section{padding:18px 20px 22px}.calendar-main-section .rbc-calendar{min-height:520px}}@media (max-width:640px){.calendar-filters-section{align-items:flex-start;padding:0 10px}.calendar-filters-row{flex-direction:column;width:100%}.calendar-select-wrap{width:100%}}@media (min-width:1025px){.calendar-page-inner{max-width:1400px;padding-left:24px;padding-right:24px}.calendar-main-section{max-width:100%}.calendar-main-section .rbc-calendar,.calendar-main-section .rbc-month-view,.calendar-main-section .rbc-time-view{width:100%!important}.calendar-main-section .rbc-calendar{min-height:560px}}@media (min-width:1200px){.calendar-page-inner{max-width:1500px;padding-left:32px;padding-right:32px}.calendar-main-section{max-width:100%}.calendar-main-section .rbc-calendar,.calendar-main-section .rbc-month-view,.calendar-main-section .rbc-time-view{width:100%!important}}@media (max-width:640px){.calendar-main-section .rbc-calendar{min-height:420px}}@media (min-width:1200px){.admin-calendar-page .calendar-page-inner{margin-left:0;margin-right:24px;max-width:none;padding-left:24px;padding-right:24px}.admin-calendar-page .calendar-main-section{width:100%}.admin-calendar-page .calendar-main-section .rbc-calendar,.admin-calendar-page .calendar-main-section .rbc-month-view,.admin-calendar-page .calendar-main-section .rbc-time-view{width:100%!important}}@media (max-width:640px){.admin-calendar-page .calendar-main-section .rbc-calendar{min-height:440px}}.admin-modal-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:50}.admin-modal-box{background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden;padding:0;width:500px}.admin-modal-content{flex:1 1;min-height:0;overflow-y:auto;padding:20px}.admin-modal-title{font-size:24px;font-weight:700;-webkit-hyphens:auto;hyphens:auto;line-height:1.2;margin-bottom:8px;overflow-wrap:break-word;white-space:normal;word-break:break-word}.admin-modal-description{font-size:16px;margin-bottom:8px}.admin-modal-actions{background:#fff;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;padding:20px}.btn{font-size:14px;padding:8px 14px}.btn-edit{color:#fff}.btn-edit,.btn-edit:hover{background:#16a34a}.btn-delete{background:#dc2626;color:#fff}.btn-delete:hover{background:#991b1b}.btn-close{background:#e5e7eb;color:#111827}.btn-close:hover{background:#9ca3af}.admin-form-group{display:flex;flex-direction:column;margin-bottom:12px}.admin-form-group label{font-size:14px;margin-bottom:4px}.admin-form-group input,.admin-form-group textarea{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:6px 10px}.modal-overlay{background-color:#00000080;height:100vh;overflow:auto;width:100vw;z-index:999}.modal-content{animation:fadeIn .3s ease;background-color:#fff;border-radius:10px;box-shadow:0 10px 40px #0000004d;box-sizing:border-box;max-width:600px;overflow:hidden;padding:30px;width:90%}.modal-body{box-sizing:border-box;flex-shrink:0;height:calc(90vh - 160px);overflow-y:auto;padding:20px 30px}.modal-title{font-size:22px;font-weight:600;margin-bottom:20px;margin-top:0}.form-group{margin-bottom:8px}.form-group select,.form-input{border:1px solid #ccc;border-radius:5px;box-sizing:border-box;font-size:14px;margin-top:6px;padding:10px;width:100%}label{display:block;font-weight:500;margin-bottom:6px}.form-grid{grid-gap:20px;gap:20px}.modal-actions{flex-shrink:0;gap:10px;height:auto;justify-content:flex-end;margin-top:20px;padding:0 30px 30px}.button-primary,.button-secondary{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:10px 16px}.button-primary{color:#fff}.button-primary,.button-primary:hover{background-color:#16a34a}.button-secondary{background-color:#f1f1f1;color:#333}.button-secondary:hover{background-color:#e2e2e2}.courses-dashboard{background-color:#f9fafb;padding:2rem}.courses-container{margin-bottom:2rem}.courses-title{color:#1e293b;font-size:2rem;font-weight:700;margin-bottom:.5rem}.courses-subtitle{color:#64748b;font-size:1rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.courses-tabs{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;gap:.5rem;margin:0 0 2rem;padding:.5rem;width:100%}.courses-tabs,.view-tabs{display:flex;justify-content:center}.view-tabs{align-items:center;border-radius:8px;color:#64748b;cursor:pointer;font-size:14px;font-weight:500;gap:8px;padding:.75rem 1.5rem;transition:all .2s}.view-tabs.active-tab{background-color:#16a34a;color:#fff}.toolbar{flex-wrap:wrap;justify-content:space-between;margin-bottom:2rem}.toolbar,.toolbar-left{align-items:center;display:flex;gap:1rem}.toolbar-left-item{position:relative}.toolbar-search{color:#9ca3af;left:12px;position:absolute;top:50%;transform:translate(-50%,-50%)}.search-input{background:#fff;padding:8px 12px 8px 40px;width:250px}.search-input,.toolbar-select{border:1px solid #d1d5db;border-radius:6px;font-size:14px}.toolbar-select{background-color:#fff;padding:8px 12px}.btn-toolbar{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s}.btn-toolbar-secondary{background-color:#fff;border:1px solid #d1d5db;color:#374151}.btn-toolbar-primary{background-color:#16a34a;color:#fff}.toolbar-right{align-items:center;display:flex;gap:.5rem}.groups-section{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 400px;grid-template-columns:1fr}.groups-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.group-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:1.5rem;transition:all .2s ease-in-out}.group-card:hover{border-color:#16a34a;box-shadow:0 4px 12px #0000001a}.group-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.group-title{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:4px}.group-code{color:#64748b;font-family:monospace;font-size:12px}.status-badge{border-radius:12px;font-size:12px;font-weight:500;padding:4px 8px}.status-badge.active{background-color:#dcfce7;color:#166534}.status-badge.inactive{background-color:#f3f4f678;color:#6b7280}.group-meta{grid-gap:1rem;display:grid;font-size:14px;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.meta-item{align-items:center;color:#64748b;display:flex;gap:6px}.progress-section{margin-bottom:1rem}.progress-header{display:flex;font-size:14px;font-weight:500;justify-content:space-between;margin-bottom:.5rem}.progress-percent{color:#16a34a}.progress-bar{background-color:#f1f5f9;border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden;width:100%}.progress-fill{background-color:#16a34a;border-radius:4px;height:100%;transition:width .3s ease-in-out}.progress-stats{color:#64748b;display:flex;font-size:12px;justify-content:space-between}.group-actions{display:flex;gap:.5rem;margin-top:1rem}.action-button{align-items:center;background-color:initial;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:12px;gap:4px;padding:4px 8px;transition:background-color .2s ease-in-out}.action-button:hover{background-color:#f3f4f6}.courses-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.course-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:1.5rem;transition:all .2s ease-in-out}.course-card:hover{border-color:#2563eb;box-shadow:0 4px 12px #0000001a}.course-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.course-title{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:4px}.lecturer-text{color:#64748b;font-size:14px}.course-meta{color:#64748b;font-family:monospace;font-size:12px}.course-status{border-radius:12px;font-size:12px;font-weight:500;margin-top:20px;padding:4px 8px}.course-status.status-active{background-color:#dcfce7;color:#166534}.course-status.status-inactive{background-color:#fef3c7;color:#92400e}.course-description{color:#475569;font-size:14px;margin-bottom:1rem}.course-details-grid{grid-gap:1rem;display:grid;font-size:14px;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.course-detail{align-items:center;color:#64748b;display:flex;gap:6px}.course-teacher-section{margin-bottom:1rem}.teacher-label{color:#475569;font-size:12px;font-weight:500}.teacher-name{color:#1e293b}.course-extra-info{margin-bottom:.5rem}.extra-label{color:#475569;font-size:12px;font-weight:500}.extra-value{color:#1e293b;font-size:14px}.course-actions{display:flex;gap:.5rem}.action-btn{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;font-size:12px;gap:4px;padding:6px 10px;transition:all .2s}.action-btn:hover{background-color:#f1f5f9}.no-underline{text-decoration:none}.modal-overlay-courses{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-courses{background:#fff;border-radius:10px;max-width:90%;padding:24px;width:500px}.modal-title-courses{font-size:24px;font-weight:700;margin-bottom:24px}.form-group-courses{margin-bottom:16px}.form-group-courses label{display:block;font-size:16px;font-weight:600;margin-bottom:6px}.form-group-courses input,.form-group-courses textarea{border:1px solid #aaa;border-radius:4px;padding:8px;width:100%}.form-actions-courses{display:flex;gap:12px;justify-content:center}.btn-courses{border:none;border-radius:4px;cursor:pointer;padding:8px 16px}.btn-primary-courses{background:#16a34a;color:#fff}.btn-secondary-courses{background:#ddd}.details-grid,.groups-grid-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));list-style:none;margin:2rem 0;padding:0}.details-card,.group-card-details{background:#f8fafc;border-radius:16px;box-shadow:0 4px 12px #00000014;cursor:pointer;padding:1.2rem;transition:transform .25s ease,box-shadow .25s ease}.details-card:hover,.group-card-details:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-5px) scale(1.02) rotate(-.5deg)}.group-details{background:#fff;border-radius:16px;box-shadow:0 6px 20px #0000001a;padding:2rem}.group-details h3{margin-bottom:.8rem;margin-top:1.5rem}.group-details ul{list-style:none;padding-left:0}.group-details ul li{background:#f1f5f9;border-radius:12px;margin-bottom:.6rem;padding:.8rem 1rem;transition:transform .2s ease}.group-details ul li:hover{background:#e2e8f0;transform:translateX(6px)}.group-details button{background:#16a34a;border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:500;margin-right:1rem;margin-top:1.5rem;padding:.6rem 1.2rem;transition:background .3s ease}.group-details button:hover{background:#166534}.courses-page-inner{box-sizing:border-box;margin:0 auto;max-width:1180px;padding:24px 32px 40px}.courses-page-inner .courses-dashboard{padding-left:0;padding-right:0}.subjects-search-row{display:flex;justify-content:flex-start;margin-bottom:1.25rem}.subjects-search-input{background-color:#fff;border:1px solid #d1d5db;border-radius:999px;font-size:14px;max-width:360px;padding:8px 12px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.subjects-search-input:focus{border-color:#16a34a;box-shadow:0 0 0 1px #16a34a26;outline:none}.subjects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.courses-grid,.groups-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.toolbar{align-items:stretch;flex-direction:column}.toolbar-left{flex-wrap:wrap;justify-content:space-between}.search-input{width:100%}.groups-section{grid-template-columns:1fr}.courses-page-inner{padding:20px 18px 32px}.subjects-grid{grid-template-columns:1fr}}@media (max-width:768px){.courses-tabs{flex-wrap:wrap}.courses-tabs,.view-tabs{justify-content:center;padding:.75rem}.view-tabs{flex:1 1 45%;font-size:13px}.stats-grid{grid-template-columns:1fr}.toolbar{align-items:stretch;flex-direction:column;gap:1rem}.toolbar-left,.toolbar-right{justify-content:space-between;width:100%}.btn-toolbar,.search-input,.toolbar-select{width:100%}.courses-grid,.groups-grid{grid-template-columns:1fr}.modal-courses{padding:16px;width:95%}}@media (max-width:640px){.courses-page-inner{padding:16px 12px 28px}.courses-page-inner .courses-dashboard{padding-bottom:16px;padding-top:16px}.subjects-search-row{justify-content:stretch}.subjects-search-input{max-width:100%}}@media (max-width:480px){.courses-title{font-size:1.5rem}.view-tabs{flex:1 1 100%;justify-content:center}.courses-tabs{gap:.25rem}.toolbar{gap:.75rem}.btn-toolbar{font-size:12px;padding:6px 10px}.course-card,.group-card{padding:1rem}}.stat-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;text-align:center}.stat-value{color:#1e293b;font-size:2rem;margin-bottom:.5rem}.stat-card:nth-child(2) .stat-value{color:#16a34a}.stat-card:nth-child(3) .stat-value{color:#3b82f6}.stat-card:nth-child(4) .stat-value{color:#8b5cf6}.stat-card:nth-child(5) .stat-value{color:#f59e0b}.stat-label{font-size:.95rem}body,html{height:100%;margin:0;padding:0}.module-modal-overlay{align-items:center;background-color:#00000080;display:flex;height:100%;justify-content:center;left:0;overflow:auto;position:fixed;top:0;width:100%;z-index:9999}.module-modal-content{animation:fadeIn .3s ease;background-color:#fff;border-radius:10px;box-shadow:0 10px 40px #0000004d;box-sizing:border-box;max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}textarea{height:100px;width:90%}.aa-layout{background:#f6f7f9;display:flex;min-height:100vh}.aa-details,.aa-grid,.aa-main,.aa-tableWrap{min-width:0}.aa-main *{box-sizing:border-box}.aa-main{flex:1 1;padding:28px 28px 48px}.aa-pageHeader{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:18px}.aa-title{color:#0f172a;font-size:clamp(28px,3vw,44px);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin:0}.aa-subtitle{font-size:15px;margin:8px 0 0}.aa-stats{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));margin-bottom:16px}.aa-statCard{background:#fff;border:1px solid #e6eaf2;border-radius:16px;box-shadow:0 8px 24px #0f172a0a;padding:14px 16px}.aa-statLabel{color:#64748b;font-size:13px;margin-bottom:6px}.aa-statValue{color:#0f172a;font-size:28px;font-weight:800;line-height:1.1}.aa-statHint{color:#94a3b8;font-size:12px;margin-top:6px}.aa-red{color:#dc2626}.aa-amber{color:#d97706}.aa-card{border:1px solid #e6eaf2;box-shadow:0 10px 28px #0f172a0d;overflow:hidden}.aa-cardHeader{border-bottom:1px solid #eef2f7;padding:16px 18px 12px}.aa-cardTitle{color:#0f172a;font-size:18px;font-weight:800}.aa-cardDesc{color:#64748b;font-size:13px;margin-top:4px}.aa-filters{grid-gap:12px;align-items:end;border-bottom:1px solid #eef2f7;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));padding:14px 18px 16px}.aa-field{display:flex;flex-direction:column;gap:6px}.aa-field--grow{min-width:220px}.aa-label{color:#64748b;font-size:12px}.aa-input{background:#fff;border:1px solid #d9e1ee;border-radius:10px;color:#0f172a;height:40px;outline:none;padding:0 12px;transition:border-color .15s ease,box-shadow .15s ease}.aa-input:focus{border-color:#16a34a8c;box-shadow:0 0 0 4px #16a34a1f}.aa-input--small{border-radius:9px;font-size:13px;height:34px;padding:0 10px}.aa-btn{background:#16a34a;border:1px solid #16a34a;border-radius:10px;color:#fff;font-weight:700;height:40px;padding:0 14px;transition:transform .08s ease,opacity .15s ease}.aa-btn:disabled{opacity:.5}.aa-btn--outline{background:#fff;border:1px solid #cbd5e1;color:#0f172a}.aa-btn--tiny{background:#fff;border:1px solid #cbd5e1;border-radius:9px;color:#0f172a;font-size:13px;height:32px;padding:0 10px}.aa-grid{grid-template-columns:minmax(0,1.35fr) minmax(320px,.85fr);padding:14px 18px 18px}.aa-tableWrap{-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #e6eaf2;border-radius:14px;overflow:auto}.aa-table{border-collapse:initial;border-spacing:0;min-width:900px;table-layout:fixed;width:100%}.aa-table thead{display:table-header-group}.aa-table tbody{display:table-row-group}.aa-table thead th{background:#f8fafc;border-bottom:1px solid #e6eaf2;color:#0f172a;display:table-cell!important;font-size:13px;font-weight:800;padding:12px;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:10}.aa-table thead th:first-child{min-width:120px;width:120px}.aa-table thead th:nth-child(2){min-width:140px;width:140px}.aa-table thead th:nth-child(3){min-width:200px;width:auto}.aa-table thead th:nth-child(4){min-width:180px;width:180px}.aa-table thead th:nth-child(5){min-width:120px;width:120px}.aa-table tbody tr{display:table-row!important}.aa-table tbody td{border-bottom:1px solid #eef2f7;color:#0f172a;display:table-cell!important;font-size:14px;overflow:visible;padding:12px;vertical-align:middle;white-space:normal}.aa-table tbody td:first-child{min-width:120px;width:120px}.aa-table tbody td:nth-child(2){min-width:140px;width:140px}.aa-table tbody td:nth-child(3){min-width:200px;width:auto;word-break:break-word}.aa-table tbody td:nth-child(4){min-width:180px;width:180px}.aa-table tbody td:nth-child(5){min-width:120px;width:120px}.aa-row{cursor:pointer;display:table-row!important;transition:background .12s ease}.aa-row:hover{background:#f8fafc}.aa-row--active{background:#16a34a0f}.aa-empty{color:#64748b;font-size:14px;padding:22px 12px;text-align:center}.aa-topic{color:#0f172a;display:inline;font-weight:700}.aa-mono{color:#334155;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;white-space:nowrap}.aa-muted{color:#64748b;font-size:13px}.aa-pill{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;height:26px;padding:0 10px;white-space:nowrap}.aa-pill--good{background:#16a34a1f;border-color:#16a34a40;color:#166534}.aa-pill--warn{background:#d977061f;border-color:#d9770640;color:#92400e}.aa-pill--bad{background:#dc26261f;border-color:#dc262640;color:#991b1b}.aa-pill--neutral{background:#64748b1f;border-color:#64748b40;color:#334155}.aa-details{background:#fff;border:1px solid #e6eaf2;border-radius:14px;overflow:hidden}.aa-detailsHeader{border-bottom:1px solid #eef2f7;padding:14px 14px 12px}.aa-detailsTitle{color:#0f172a;font-size:16px;font-weight:900}.aa-detailsDesc{color:#64748b;font-size:13px;margin-top:6px}.aa-strong{color:#0f172a;font-weight:900}.aa-detailsMeta{padding:12px 14px 4px}.aa-metaRow{border-bottom:1px dashed #eef2f7;display:flex;gap:10px;justify-content:space-between;padding:8px 0}.aa-metaKey{color:#64748b;font-size:12px}.aa-metaVal{color:#0f172a;font-size:13px;font-weight:700;text-align:right}.aa-actions{display:flex;flex-wrap:wrap;gap:10px;padding:10px 14px 12px}.aa-studentSearch{padding:0 14px 12px}.aa-students{-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:10px;max-height:520px;overflow:auto;padding:0 14px 14px}.aa-studentRow{align-items:center;background:#fff;border:1px solid #eef2f7;border-radius:12px;display:flex;gap:12px;justify-content:space-between;padding:10px}.aa-studentInfo{min-width:0}.aa-studentName{color:#0f172a;font-size:13px;font-weight:900}.aa-studentEmail,.aa-studentName{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.aa-studentEmail{color:#64748b;font-size:12px}.aa-studentControls{align-items:center;display:flex;flex-shrink:0;gap:10px}.aa-emptyBox{color:#64748b;font-size:14px;padding:14px}.aa-footerNote{border-top:1px solid #eef2f7;color:#94a3b8;font-size:12px;padding:10px 14px 14px}@media (max-width:1100px){.aa-grid{grid-template-columns:1fr}.aa-table{min-width:700px}.aa-students{max-height:420px}}@media (max-width:768px){.aa-main{padding:16px 12px 24px}.aa-pageHeader{align-items:stretch;flex-direction:column}.aa-btn--outline{width:100%}.aa-cardHeader{padding:14px 14px 10px}.aa-filters,.aa-grid{padding:12px 14px 14px}.aa-table{min-width:640px}.aa-studentEmail,.aa-studentName{max-width:200px}}@media (max-width:640px){.aa-table{min-width:520px}.aa-table td:nth-child(2),.aa-table td:nth-child(5),.aa-table th:nth-child(2),.aa-table th:nth-child(5){display:none}}.aa-notification{animation:slideInRight .3s ease-out;border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:14px;line-height:1.5;max-width:500px;min-width:300px;padding:16px 20px;position:fixed;right:20px;top:20px;z-index:10000}.aa-notification--success{background-color:#10b981;color:#fff}.aa-notification--error{background-color:#ef4444;color:#fff}.aa-notification-content{align-items:center;display:flex;gap:8px}@media (max-width:420px){.aa-studentControls{gap:8px}.aa-input--small{width:120px}.aa-notification{left:10px;max-width:none;min-width:auto;right:10px}}.admin-grades-page{width:100%}.admin-grades-inner{box-sizing:border-box;margin:0 auto;max-width:1400px;padding:24px 32px 40px}.ag-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:14px}.ag-title{color:#0f172a;font-size:26px;font-weight:800;letter-spacing:-.02em;margin:0}.ag-subtitle{color:#6b7280;font-size:13px;margin:6px 0 0;max-width:760px}.ag-btn{background:#16a34a;border:none;border-radius:999px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;height:40px;padding:0 14px;transition:background .15s ease,transform .08s ease,opacity .15s ease;white-space:nowrap}.ag-btn:hover{background:#15803d}.ag-btn:active{transform:translateY(1px)}.ag-btn:disabled{cursor:not-allowed;opacity:.55}.ag-btn--outline{background:#fff;border:1px solid #e5e7eb;color:#0f172a}.ag-btn--outline:hover{background:#f3f4f6}.ag-input{background:#fff;border:1px solid #d1d5db;border-radius:999px;box-sizing:border-box;color:#0f172a;font-size:13px;height:40px;outline:none;padding:0 12px;transition:border-color .15s ease,box-shadow .15s ease}.ag-input:focus{border-color:#16a34a;box-shadow:0 0 0 1px #16a34a26}.ag-input--small{height:34px}.ag-input--note{min-width:180px;width:100%}.ag-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,minmax(180px,1fr));margin-bottom:14px}.ag-statCard{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 14px 30px #0f172a0f;padding:14px 16px}.ag-statLabel{color:#6b7280;font-size:12px;margin-bottom:6px}.ag-statValue{color:#0f172a;font-size:26px;font-weight:900;line-height:1.1}.ag-statHint{color:#9ca3af;font-size:12px;margin-top:6px}.ag-red{color:#dc2626}.ag-slate{color:#334155}.ag-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 14px 30px #0f172a0f;box-sizing:border-box;padding:14px 16px 18px;width:100%}.ag-cardHeader{border-bottom:1px solid #eef2f7;margin-bottom:12px;padding:2px 2px 12px}.ag-cardTitle{color:#0f172a;font-size:16px;font-weight:800}.ag-cardDesc{color:#6b7280;font-size:13px;margin-top:4px}.ag-filters{grid-gap:10px;align-items:end;display:grid;gap:10px;grid-template-columns:240px 240px 260px 1fr;margin-bottom:14px}.ag-field{display:flex;flex-direction:column;gap:6px;min-width:0}.ag-label{color:#6b7280;font-size:12px}.ag-grid{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:minmax(0,1.35fr) minmax(320px,.85fr);min-width:0}.ag-tableWrap{-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #e5e7eb;border-radius:16px;overflow:auto}.ag-table{border-collapse:collapse;min-width:860px;width:100%}.ag-table thead th{background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:800;text-align:left;white-space:nowrap}.ag-table tbody td,.ag-table thead th{color:#0f172a;font-size:13px;padding:12px}.ag-table tbody td{border-bottom:1px solid #eef2f7;vertical-align:middle}.ag-row:hover{background:#f9fafb}.ag-student{font-weight:800}.ag-muted{color:#6b7280;font-size:12px}.ag-empty{color:#6b7280;padding:18px 12px;text-align:center}.ag-gradeCell{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.ag-pill{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;height:26px;padding:0 10px;white-space:nowrap}.ag-pill--good{background:#16a34a1f;border-color:#16a34a40;color:#166534}.ag-pill--warn{background:#d977061f;border-color:#d9770640;color:#92400e}.ag-pill--bad{background:#dc26261f;border-color:#dc262640;color:#991b1b}.ag-pill--neutral{background:#64748b1f;border-color:#64748b40;color:#334155}.ag-side{background:#fff;border:1px solid #e5e7eb;border-radius:16px;overflow:hidden}.ag-sideHeader{border-bottom:1px solid #eef2f7;padding:12px 14px}.ag-sideTitle{color:#0f172a;font-size:14px;font-weight:900}.ag-sideDesc{color:#6b7280;font-size:12px;line-height:1.35;margin-top:6px}.ag-sideBody{padding:12px 14px 14px}.ag-kpi{align-items:center;border-bottom:1px dashed #eef2f7;display:flex;justify-content:space-between;padding:10px 0}.ag-kpiKey{color:#6b7280;font-size:12px}.ag-kpiVal{color:#0f172a;font-size:13px;font-weight:900}.ag-note{color:#9ca3af;font-size:12px;margin-top:12px}@media (max-width:1100px){.admin-grades-inner{padding:20px 18px 32px}.ag-filters,.ag-stats{grid-template-columns:repeat(2,minmax(180px,1fr))}.ag-grid{grid-template-columns:1fr}.ag-table{min-width:820px}}@media (max-width:640px){.admin-grades-inner{max-width:100%;padding:16px 0 24px}.ag-header,.ag-stats{padding:0 10px}.ag-stats{grid-template-columns:repeat(2,minmax(160px,1fr))}.ag-card{border-radius:16px;margin-left:50%;max-width:calc(100vw - 20px);padding:12px 12px 14px;transform:translateX(-50%);width:calc(100vw - 20px)}.ag-filters{grid-template-columns:1fr}.ag-btn--outline{width:100%}.ag-table{min-width:760px}}@media (max-width:420px){.ag-table{min-width:620px}.ag-table td:nth-child(2),.ag-table td:nth-child(4),.ag-table th:nth-child(2),.ag-table th:nth-child(4){display:none}}.ag-notification{animation:slideInRight .3s ease-out;border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:14px;line-height:1.5;max-width:500px;min-width:300px;padding:16px 20px;position:fixed;right:20px;top:20px;z-index:10000}.ag-notification--success{background-color:#10b981;color:#fff}.ag-notification--error{background-color:#ef4444;color:#fff}.ag-notification-content{align-items:center;display:flex;gap:8px}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:420px){.ag-notification{left:10px;max-width:none;min-width:auto;right:10px}}.ag-exam-grades{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.ag-exam-type-group{align-items:center;display:inline-flex;gap:8px}.ag-exam-type-label{color:#6b7280;font-size:11px;font-weight:600;white-space:nowrap}.ag-exam-attempts{align-items:center;display:inline-flex;gap:6px}.ag-exam-strikethrough{opacity:.5;text-decoration:line-through}.ag-exam-separator{color:#d1d5db;display:inline-block;font-size:16px;font-weight:300;margin:0 4px;opacity:.6}.ag-other-grades{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:10px;max-width:100%;min-width:200px}.ag-other-grade-item{align-items:center;display:inline-flex;flex-shrink:0;gap:6px;white-space:nowrap}.ag-grade-type-label{color:#6b7280;font-size:11px;font-weight:500;white-space:nowrap}.ag-pill--small{font-size:11px;padding:2px 6px}.ag-pill--editable{cursor:pointer;transition:opacity .15s ease,transform .08s ease}.ag-pill--editable:hover{opacity:.8;transform:scale(1.05)}.ag-input--tiny{font-size:12px;height:28px;min-width:60px;padding:0 8px}.message-table{box-shadow:0 2px 5px #0000000f;margin-top:1rem}.message-table td,.message-table th{border-bottom:1px solid #edf2f7;font-size:14px}.message-actions{height:100%}.badge{font-size:.8rem}.badge-alert{background-color:#f8d7da;color:#721c24}.messages-page-inner{box-sizing:border-box;margin:0 auto;max-width:1180px;padding:24px 32px 40px}.messages-page-header{margin-bottom:16px}.messages-page-title{color:#111827;font-size:22px;font-weight:700;margin:0}.messages-page-subtitle{color:#6b7280;font-size:13px;margin:4px 0 0}.messages-card{margin-top:8px}.user-messages-card{margin-top:1.5rem}.user-message-actions{align-items:center;display:flex;gap:8px;justify-content:center}.btn-message{background-color:#16a34a;color:#fff;font-size:13px;gap:6px;transition:background-color .2s ease,box-shadow .2s ease;white-space:nowrap}.btn-message:hover{background-color:#15803d;box-shadow:0 4px 10px #16a34a40}.btn-message-secondary{background-color:#22c55e}.btn-message-secondary:hover{background-color:#16a34a}@media (max-width:1024px){.messages-page-inner{padding:20px 18px 32px}}@media (max-width:768px){.messages-page-inner{padding:18px 14px 28px}.messages-page-title{font-size:20px}.messages-page-subtitle{font-size:12px}.message-table{border:0;box-shadow:none}.message-table thead{display:none}.message-table tr{background-color:#fff;border-radius:10px;box-shadow:0 1px 4px #00000014;display:block;margin-bottom:1rem;overflow:hidden}.message-table td{align-items:flex-start;border:none;border-bottom:1px solid #f0f0f0;display:flex;flex-direction:column;padding:10px 12px;text-align:left}.message-table td:last-child{border-bottom:none}.message-table td:before{color:#4b5563;content:attr(data-label);font-size:12px;font-weight:600;margin-bottom:4px}.message-actions,.user-message-actions{justify-content:flex-start}.btn-message{padding:6px 10px}}@media (max-width:480px){.messages-page-inner{padding:16px 10px 24px}.badge{font-size:.75rem;padding:3px 6px}.message-table td{font-size:.85rem;padding:8px 10px}.btn-icon{padding:4px}.user-message-actions{align-items:stretch;flex-direction:column}.btn-message,.btn-message-secondary{width:100%}}.user-message-modal,.user-selector-modal{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:100%}.user-message-modal-content{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto}.user-selector-header{flex-shrink:0}.user-selector-list{min-height:0;overflow-x:hidden}.user-selector-footer{flex-shrink:0}.user-message-section .form-label{color:#1e293b;display:block;font-size:.875rem;font-weight:500}.user-message-section .form-input,.user-message-section .form-textarea{border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;font-family:inherit;font-size:.875rem;padding:.625rem;transition:border-color .2s}.user-message-section .form-input:focus,.user-message-section .form-textarea:focus{border-color:#16a34a;outline:none}.user-message-section .form-textarea{min-height:120px;resize:vertical}.user-message-section .section-label{color:#475569;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin-bottom:.75rem;text-transform:uppercase}.user-message-section .user-types{display:flex;flex-direction:column;gap:.5rem}.user-message-section .checkbox-label{align-items:center;color:#1e293b;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem}.user-message-section .checkbox-label input[type=checkbox],.user-message-section .checkbox-label input[type=radio]{accent-color:#16a34a;cursor:pointer;height:16px;width:16px}.user-selector-footer .btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;padding:.625rem 1.5rem;transition:all .2s}.user-selector-footer .btn-primary{background-color:#16a34a;color:#fff}.user-selector-footer .btn-primary:hover{background-color:#15803d}.user-selector-footer .btn-primary:disabled{cursor:not-allowed;opacity:.5}.user-selector-footer .btn-secondary{background-color:#fff;border:1px solid #cbd5e1;color:#475569}.user-selector-footer .btn-secondary:hover{background-color:#f8fafc}.admin-mail{display:flex}.admin-mail,.admin-mail .main-content{background-color:#f9fafb;min-height:100vh}.admin-mail .main-content{margin-left:17%;width:83%}.admin-mail .header{align-items:center;background-color:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 2rem;top:0}.admin-mail .header-title{font-size:1.5rem;font-weight:600;margin:0}.admin-mail .dashboard{background:#f9fafb;font-family:sans-serif;padding:32px}.admin-mail .page-title{color:#1e293b;font-size:2rem;font-weight:700;margin-bottom:.5rem}.admin-mail .page-subtitle{color:#64748b;margin-bottom:2rem}.mail-nav-tabs{border-bottom:2px solid #e2e8f0;display:flex;gap:.5rem;margin-bottom:2rem}.nav-tab{background:none;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;font-size:.95rem;font-weight:500;margin-bottom:-2px;padding:.75rem 1.5rem;transition:all .2s}.nav-tab:hover{color:#16a34a}.nav-tab.active{border-bottom-color:#16a34a;color:#16a34a}.mail-stats-section{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem}.stat-card-mail{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000001a;flex:1 1;min-width:200px;padding:1.5rem}.stat-card-mail .stat-label{color:#64748b;font-size:.875rem;margin-bottom:.5rem}.stat-card-mail .stat-value{color:#1e293b;font-size:1.5rem;font-weight:700}.mail-content-wrapper{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.mail-card{align-self:start;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000001a;height:fit-content;padding:1.25rem}.mail-card .card-title{border-bottom:1px solid #e2e8f0;color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:1rem;padding-bottom:.75rem}.section-block,.section-label{margin-bottom:.75rem}.section-label{color:#475569;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.quick-selection-buttons{display:flex;flex-direction:column;gap:.5rem}.quick-btn{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;font-size:.875rem;font-weight:500;padding:.625rem 1rem;text-align:left;transition:all .2s}.quick-btn:hover{background-color:#e2e8f0}.quick-btn.active{background-color:#16a34a;border-color:#16a34a;color:#fff}.user-types{display:flex;flex-direction:column;gap:.5rem}.checkbox-label{align-items:center;color:#1e293b;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem}.checkbox-label input[type=checkbox],.checkbox-label input[type=radio]{accent-color:#16a34a;cursor:pointer;height:16px;width:16px}.filter-group{margin-bottom:1rem}.filter-label{color:#1e293b;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.year-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.year-btn{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.year-btn:hover{background-color:#e2e8f0}.year-btn.active{background-color:#16a34a;border-color:#16a34a;color:#fff}.group-search-input{background-color:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;color:#64748b;font-size:.875rem;margin-bottom:.75rem;padding:.625rem;width:100%}.group-search-input:disabled{cursor:not-allowed}.group-buttons{display:flex;flex-direction:column;gap:.5rem}.group-btn{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;font-size:.875rem;font-weight:500;padding:.625rem 1rem;text-align:left;transition:all .2s}.group-btn:hover{background-color:#e2e8f0}.group-btn.active{background-color:#16a34a;border-color:#16a34a;color:#fff}.estimated-recipients{border-top:1px solid #e2e8f0;color:#1e293b;font-size:.875rem;margin-top:1.5rem;padding-top:1rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-weight:500;margin-bottom:.5rem}.form-input,.form-label{color:#1e293b;font-size:.875rem}.form-input{border:1px solid #cbd5e1;border-radius:6px;padding:.625rem;transition:border-color .2s;width:100%}.form-input:focus{border-color:#16a34a;outline:none}.form-textarea{border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;font-family:inherit;font-size:.875rem;max-height:200px;min-height:120px;padding:.625rem;resize:vertical;transition:border-color .2s;width:100%}.form-textarea:focus{border-color:#16a34a;outline:none}.radio-label{align-items:center;color:#1e293b;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem}.message-card .section-block:last-of-type,.radio-label{margin-bottom:.25rem}.radio-label input[type=radio]{accent-color:#16a34a;cursor:pointer;height:16px;width:16px}.recipients-summary{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;font-size:.875rem;margin-bottom:.5rem;margin-top:.5rem;padding:.75rem}.message-actions{gap:1rem;height:auto;justify-content:center;margin-bottom:0;margin-top:0!important;min-height:auto;padding-bottom:0;padding-top:0}@media (max-width:1200px){.mail-content-wrapper{grid-template-columns:1fr}}@media (max-width:768px){.admin-mail .main-content{margin-left:0;width:100%}.mail-nav-tabs{flex-wrap:wrap}.nav-tab{font-size:.875rem;padding:.5rem 1rem}.mail-stats-section{flex-direction:column}.stat-card-mail{min-width:100%}.mail-content-wrapper{grid-template-columns:1fr}.message-actions{flex-direction:column}.btn{justify-content:center;width:100%}}@media (max-width:480px){.admin-mail .dashboard{padding:1rem}.admin-mail .page-title{font-size:1.5rem}.mail-card{padding:1rem}.group-buttons,.quick-selection-buttons,.year-buttons{gap:.375rem}.group-btn,.quick-btn,.year-btn{font-size:.8125rem;padding:.5rem .75rem}}.user-selector-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.user-selector-modal{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;max-height:80vh;max-width:600px;overflow:hidden;width:100%}.user-selector-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.5rem}.user-selector-header h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.user-selector-close{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.user-selector-close:hover{background-color:#f1f5f9;color:#1e293b}.user-selector-search{border-bottom:1px solid #e2e8f0;padding:1rem 1.5rem}.user-selector-search input{border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;font-size:.875rem;padding:.625rem;transition:border-color .2s;width:100%}.user-selector-search input:focus{border-color:#16a34a;outline:none}.user-selector-list{flex:1 1;overflow-y:auto;padding:.5rem}.user-selector-item{align-items:flex-start;border-radius:6px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:background-color .2s}.user-selector-item:hover{background-color:#f8fafc}.user-selector-item input[type=checkbox]{accent-color:#16a34a;cursor:pointer;flex-shrink:0;height:18px;margin-top:2px;width:18px}.user-selector-item-info{flex:1 1;min-width:0}.user-selector-item-name{color:#1e293b;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.user-selector-item-details{align-items:center;color:#64748b;display:flex;flex-wrap:wrap;font-size:.75rem;gap:.5rem}.user-type-badge{border-radius:4px;font-size:.7rem;font-weight:500;padding:.125rem .5rem}.user-type-student{background-color:#dbeafe;color:#1e40af}.user-type-lecturer{background-color:#fef3c7;color:#92400e}.user-type-administrator{background-color:#fce7f3;color:#9f1239}.user-selector-footer{border-top:1px solid #e2e8f0;display:flex;gap:1rem;justify-content:flex-end;padding:1rem 1.5rem}.user-message-modal{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:700px;overflow:hidden;width:100%}.user-message-section{border-bottom:1px solid #e2e8f0;padding:1rem 1.5rem}.user-message-section:last-of-type{border-bottom:none}.user-message-section .form-label{margin-bottom:.5rem}.user-message-section .form-input,.user-message-section .form-textarea{width:100%}.user-selector-footer .btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.user-message-modal,.user-selector-modal{max-height:90vh;max-width:100%}}.stats-grid-reports{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(4,1fr);margin-bottom:2rem}.stat-card-reports{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;text-align:center}.stat-number{font-size:2rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#64748b;font-size:14px}.stat-number-dark{color:#1e293b}.stat-number-green{color:#16a34a}.stat-number-blue{color:#3b82f6}.stat-number-purple{color:#8b5cf6;font-size:1.2rem;font-weight:700;margin-bottom:.5rem}.report-main-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr;margin-bottom:2rem;width:100%}.report-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;box-sizing:border-box;padding:1.5rem;width:100%}.report-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.report-card-title,.report-card-title-icon{align-items:center;display:flex;gap:8px}.report-card-title{font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;padding-top:8px}.report-button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s}.report-button-primary{background-color:#16a34a;color:#fff}.report-list{background-color:#fff}.report-table{table-layout:auto}.report-th{background-color:#f8fafc;border-bottom:2px solid #e5e7eb;color:#374151;text-align:left}.report-td,.report-th{padding:12px;white-space:nowrap;width:auto}.report-td{border-bottom:1px solid #e5e7eb}.report-list::-webkit-scrollbar{height:8px}.report-list::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:6px}.name-row{font-size:14px;font-weight:500}.row-div{gap:12px}.icon-row,.row-div{align-items:center;display:flex}.icon-row{background-color:#f1f5f9;border-radius:6px;height:32px;justify-content:center;width:32px}.row-raport-name{font-size:14px;font-weight:500}.row-description{color:#64748b;font-size:12px}.report-actions{display:flex;gap:4px;justify-content:center}.report-download-button{align-items:center;background-color:initial;border:none;cursor:pointer;display:inline-flex;padding:4px;transition:opacity .2s}.report-download-button:hover{opacity:.7}.report-delete-button{align-items:center;background-color:initial;border:none;cursor:pointer;display:inline-flex;padding:4px;transition:opacity .2s}.report-delete-button:hover{opacity:.7}.admin-dashboard{display:flex;min-height:100vh}.main-content{background-color:#f9fafb;flex:1 1;overflow-x:hidden;padding:2rem}.header{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between;margin-bottom:2rem}.header-title{color:#1e293b;font-size:1.75rem;font-weight:700}@media (max-width:1024px){.admin-dashboard{flex-direction:column}.main-content{padding:1.5rem}.stats-grid-reports{gap:1rem;grid-template-columns:repeat(2,1fr)}.report-main-grid{gap:1.5rem;grid-template-columns:1fr;width:100%}.report-card{padding:1.25rem}.report-card-header{align-items:flex-start;flex-direction:column;gap:.75rem}.report-button{justify-content:center;width:100%}}@media (max-width:768px){.main-content{padding:1rem}.header-title{font-size:1.5rem}.stats-grid-reports{gap:1rem;grid-template-columns:1fr}.report-main-grid{grid-template-columns:1fr;width:100%}.report-card-title{flex-wrap:wrap;font-size:1.1rem}.report-button{font-size:13px;padding:6px 12px}}@media (max-width:480px){.header-title{font-size:1.25rem}.report-card{padding:1rem}.report-card-header{align-items:stretch}.report-button{font-size:12px;width:100%}.stat-number{font-size:1.5rem}}.admin-dashboard .main-content{box-sizing:border-box;min-width:0;overflow-x:visible}.report-card{min-width:0;overflow:visible}.report-list{-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-sizing:border-box;display:block;max-width:100%;min-width:0;overflow-x:auto;padding-bottom:8px;width:100%}.report-table{border-collapse:collapse;min-width:700px;width:100%}.report-td,.report-th{white-space:nowrap}.admin-dashboard .sidebar,.admin-dashboard>.sidebar,.admin-dashboard>aside{bottom:0;left:0;position:fixed;top:0;width:240px;z-index:30}.admin-dashboard .main-content,.admin-dashboard>.main-content{box-sizing:border-box;margin-left:240px;width:calc(100% - 240px)}@media (max-width:1024px){.admin-dashboard .sidebar,.admin-dashboard>.sidebar,.admin-dashboard>aside{position:relative;width:100%}.admin-dashboard .main-content,.admin-dashboard>.main-content{margin-left:0;width:100%}}.report-modal{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.report-modal-holder{max-height:90vh;max-width:800px;overflow-y:auto;padding:0;width:90%}.report-modal-card,.report-modal-holder{background-color:#fff;border-radius:12px}.report-modal-card{border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.report-modal-title{align-items:center;display:flex;font-size:1.25rem;font-weight:600;gap:8px;margin-bottom:1.5rem}.report-modal-buttons{display:flex;gap:1rem;justify-content:flex-end}.report-modal-button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s}.report-modal-button-primary{background-color:#16a34a;color:#fff}.report-modal-types{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}.report-modal-type-card{border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:1.5rem;position:relative;transition:all .2s}.report-modal-type-card-active{background-color:#f0fdf4;border-color:#16a34a}.report-modal-type-icon{align-items:center;border-radius:12px;color:#fff;display:flex;height:48px;justify-content:center;margin-bottom:1rem;width:48px}.report-modal-type-name{font-weight:600;margin:0 0 .5rem}.report-modal-type-description{color:#64748b;font-size:14px;margin:0}.report-modal-type-formats{display:flex;flex-wrap:wrap;gap:4px;margin-top:1rem}.report-modal-type-format{background-color:#f1f5f9;border-radius:4px;color:#475569;font-size:14px;padding:2px 6px}.report-modal-form{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.report-modal-form-group{margin-bottom:1rem}.report-modal-form-label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.report-modal-form-select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px}.report-modal-button-secondary{background-color:#fff;border:1px solid #d1d5db;color:#374151}.settings-layout{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:280px 1fr}.settings-sidebar{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;height:fit-content;padding:1.5rem}.settings-sidebar-title{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.settings-sidebar-list{display:flex;flex-direction:column;gap:.5rem}.section-item{border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;padding:12px;transition:all .2s}.section-item.active{background-color:#f0fdf4;border-color:#bbf7d0;color:#166534}.settings-sidebar-icon{margin-bottom:.5rem}.settings-sidebar-name{font-size:14px;font-weight:500;margin-bottom:2px}.settings-sidebar-description{color:#64748b;font-size:12px}.settings-content{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem}.setting-content-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.settings-content-title{color:#1e293b;font-size:1.5rem;font-weight:600}.users-settings{align-items:flex-start;border-radius:8px;display:flex;gap:12px;margin-bottom:1.5rem;padding:1rem}.users-settings-title{margin:0 0 4px}.users-settings-description{color:#64748b;font-size:14px;margin:0}.user-role-card{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1rem;padding:1.5rem}.user-role-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.user-role-title{color:#1e293b;margin:0 0 4px}.user-role-description{color:#64748b;font-size:14px;margin:0}.user-role-count{align-items:center;display:flex;gap:1rem}.user-badge{border-radius:12px;font-size:12px;font-weight:500;padding:4px 8px}.user-badge-info{background-color:#dbeafe;color:#1e40af}.settings-button-container{display:flex;justify-content:flex-end;margin-bottom:2rem;margin-top:2rem}.lecturers-list-container{overflow:hidden}.lecturers-list th{background-color:#f8fafc;border-bottom:2px solid #e5e7eb;color:#374151;font-weight:600;padding:12px;text-align:left}.lecturer-td{border-bottom:1px solid #e5e7eb;padding:12px}.form-input-lecturer{border:1px solid #ccc;border-radius:5px;font-size:14px;margin-bottom:12px;margin-top:6px;padding:10px}.lecturer-email{color:#475569}.lecturer-students{color:#16a34a;display:flex;font-weight:700;justify-content:center}.rooms-list{cursor:pointer}.room-card{background:#fff;border:1px solid #ddd;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:16px}.room-name{font-size:16px;font-weight:500;margin:0 0 4px}.room-capacity{color:#555;font-size:14px;margin:12px 0}.users-list-header{width:45%}.users-list-header-action{text-align:center;width:10%}.users-list-cell{border-bottom:2px solid #e5e7eb;padding:12px 4px 12px 12px;width:45%}.users-list-cell-action{border-bottom:2px solid #e5e7eb;padding:8px 12px;text-align:center;width:10%}.button-danger{background-color:#b91c1c;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:8px 16px;transition:background-color .2s}.settings-layout,.settings-layout *{box-sizing:border-box}.settings-layout,.settings-layout>.settings-content,.settings-layout>.settings-sidebar{min-width:0}.settings-sidebar{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 4rem);overflow:auto;position:sticky;top:2rem}.lecturers-list-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-sizing:border-box;display:block;max-width:100%;overflow-x:auto;width:100%}.lecturers-list{border-collapse:collapse;min-width:720px;width:100%}.lecturer-td,.lecturers-list th{white-space:nowrap}.rooms-list{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.room-card{min-width:0}.form-input-lecturer{box-sizing:border-box;width:100%}.users-list-cell,.users-list-cell-action,.users-list-header,.users-list-header-action{min-width:0;width:auto}@media (max-width:1024px){.settings-layout{gap:1rem;grid-template-columns:1fr}.settings-sidebar{max-height:none;overflow:visible;position:relative;top:auto;width:100%}.settings-button-container{justify-content:center}.users-settings{align-items:stretch;flex-direction:column}.rooms-list{grid-template-columns:1fr}.lecturers-list{min-width:600px}}@media (max-width:768px){.main-content,.settings-content,.settings-sidebar{padding:1rem}.button-danger,.report-button,.settings-button-container .button{width:100%}.users-list-cell,.users-list-cell-action,.users-list-header{display:table-cell;width:auto}}@media (max-width:480px){.settings-sidebar{position:relative;top:auto}.user-role-card{padding:1rem}.rooms-list{gap:12px;grid-template-columns:1fr}.form-input-lecturer{font-size:14px;padding:8px}}.user-role-card.clickable{cursor:pointer;transition:background .2s}.user-role-card.clickable:hover{background-color:#f7f9fb}.role-users-section{border-top:1px solid #ddd;margin-top:20px;padding:10px}.users-table{border-collapse:collapse;width:100%}.users-table td,.users-table th{border:1px solid #ddd;padding:8px}.users-table th{background-color:#f0f0f0;text-align:left}@media (max-width:768px){.user-role-card.clickable{border-radius:8px;box-shadow:0 2px 5px #0000001a;padding:12px}.role-users-section{padding:8px}.users-table{border:none;display:block;overflow-x:auto;white-space:nowrap;width:100%}.users-table td,.users-table th{font-size:.9rem;padding:10px;text-align:center}.users-table th{background-color:#f7f9fb;position:sticky;top:0;z-index:2}.users-table tr{border-bottom:1px solid #eee}}@media (max-width:480px){.user-role-card.clickable{padding:10px}.users-table td,.users-table th{font-size:.85rem;padding:8px 6px}}.lecturer-page-inner{box-sizing:border-box;margin:0 auto;max-width:1180px;padding:24px 32px 40px}.lecturer-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px}.lecturer-header-title{font-size:22px;font-weight:700;margin:0}.lecturer-header-subtitle{color:#6b7280;font-size:13px;margin-bottom:0;margin-top:4px}.lecturer-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:28px}.lecturer-stat-card{background-color:#eef2ff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 18px #0f172a0a;padding:14px 16px}.lecturer-stat-card.blue{background-color:#e0f2fe}.lecturer-stat-card.green{background-color:#d1fae5}.lecturer-stat-label{color:#6b7280;font-size:13px;margin:0}.lecturer-stat-value{color:#111827;font-size:24px;font-weight:700;margin:4px 0}.lecturer-stat-hint{color:#9ca3af;font-size:11px;margin:0}.lecturer-main-grid{grid-gap:24px;align-items:flex-start;display:grid;gap:24px;grid-template-columns:repeat(2,minmax(0,1fr))}.lecturer-card-dashboard{background-color:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 14px 30px #0f172a0f;padding:16px 18px 18px}.lecturer-card-header{align-items:center;display:flex;font-size:15px;font-weight:600;gap:10px;margin:0 0 10px}.lecturer-dashboard-card-title{margin-left:0}.lecturer-card-full{grid-column:1/-1}.lecturer-upcoming-courses-list{list-style:none;margin:8px 0 0;padding:0}.lecturer-upcoming-course{border-bottom:1px solid #e5e7eb;padding:10px 0}.lecturer-upcoming-course:last-child{border-bottom:none}.lecturer-upcoming-main{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}.lecturer-upcoming-title{font-size:14px}.lecturer-upcoming-subtitle{color:#6b7280;font-size:12px}.lecturer-upcoming-meta{color:#4b5563;display:flex;flex-wrap:wrap;font-size:12px;gap:6px 12px}.lecturer-room-block{display:flex;flex-wrap:wrap;gap:6px 12px;width:100%}.lecturer-meta-chip{background-color:#f3f4f6;border-radius:999px;padding:3px 8px}.lecturer-meta-chip,.lecturer-meta-inline{align-items:center;display:inline-flex;gap:4px}.lecturer-assignments-list{display:flex;flex-direction:column;gap:12px;margin-top:4px}.lecturer-assignment{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px}.lecturer-assignment-title{font-size:14px;font-weight:600;margin:0 0 4px}.lecturer-assignment-desc{color:#4b5563;font-size:13px;margin:0 0 6px}.lecturer-assignment-meta{color:#6b7280;display:flex;flex-wrap:wrap;font-size:12px;gap:8px 16px}.lecturer-grades-wrapper{display:flex;flex-direction:column;gap:18px;margin-top:6px}.lecturer-grade-group-block{margin-bottom:0}.lecturer-grade-groups-title{color:#1e40af;font-size:14px;font-weight:600;margin:0 0 6px}.lecturer-grade-avg-table{border-collapse:collapse;font-size:13px;width:100%}.lecturer-grade-avg-table thead tr{background-color:#f1f5f9}.lecturer-grade-avg-table thead tr th{font-weight:500;padding:8px;text-align:left}.lecturer-grade-avg-table tbody tr{border-bottom:1px solid #e5e7eb}.lecturer-grade-avg-table tbody tr:last-child{border-bottom:none}.lecturer-grade-avg-table tbody tr td{padding:7px 8px}.lecturer-terms-backdrop{align-items:center;background-color:#0f172a8c;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.lecturer-terms-modal{background-color:#fffbeb;border:1px solid #facc15;border-radius:16px;box-shadow:0 20px 40px #0f172a40;color:#92400e;max-width:720px;padding:1.75rem 2rem;width:min(90%,720px)}@media (max-width:1024px){.lecturer-page-inner{padding:20px 18px 32px}.lecturer-stats-row{grid-template-columns:repeat(2,minmax(0,1fr))}.lecturer-main-grid{grid-template-columns:1fr}}@media (max-width:640px){.lecturer-page-inner{padding:16px 12px 24px}.lecturer-header-title{font-size:20px}.lecturer-stats-row{grid-template-columns:1fr}.lecturer-card-dashboard{padding:14px 14px 16px}.lecturer-assignment-meta,.lecturer-upcoming-meta{align-items:flex-start;flex-direction:column}}.lecturer-student-grid-row{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:2fr 1fr 2fr 2.5fr;padding:.75rem 1rem;word-break:break-word}.filter-container{align-items:center;display:flex;gap:8px}.filter-container label{font-weight:500;margin-bottom:0;padding:4px}.filter-container select{background-color:#fff;border:1px solid #ccc;border-radius:6px;padding:6px 10px}.session-grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.session-grid-columns{grid-template-columns:repeat(2,1fr)}.session-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-left:24px;margin-right:32px;padding:1.5rem}.sessions-today-column{margin-top:1rem}.session-item{border-radius:8px;margin-bottom:.5rem;padding:1rem}.today-session-title{margin:0 0 .5rem}.today-session-subtitle{color:#64748b;margin:0}.session-upcoming-item{border-bottom:1px solid #e2e8f0;margin-bottom:1rem;padding-bottom:1rem}.upcoming-session-title{margin:0 0 .25rem}.upcoming-session-subtitle{color:#64748b;font-size:14px;margin:0}.calendar-modal-body ul{list-style:disc;margin-left:20px}.lecturer-calendar-container{box-sizing:border-box;display:flex;flex-direction:column;gap:8px;padding-top:0;width:100%}.lecturer-calendar-header-row{align-items:center;display:flex;justify-content:flex-end}.lecturer-calendar-wrapper{height:80vh;min-height:540px;width:100%}.refresh-btn{align-items:center;background-color:#16a34a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:6px;justify-content:center;padding:8px 14px;transition:background .2s ease-in-out}.refresh-btn:hover{background-color:#15803d}@media (max-width:640px){.lecturer-calendar-container{padding-top:4px}.lecturer-calendar-wrapper{height:75vh;min-height:480px}.refresh-btn{justify-content:center;width:100%}}.lecturer-tasks-actions{display:flex;justify-content:flex-end}.lecturer-tasks-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:20px}.lecturer-task-card{background-color:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 5px #0000001a;cursor:pointer;padding:16px;transition:transform .2s ease}.lecturer-task-title{color:#333;font-size:1.2rem;margin-bottom:8px}.lecturer-task-desc{color:#555;font-size:.95rem;margin-bottom:12px}.lecturer-task-info{font-size:.9rem;margin:4px 0}.lecturer-task-stats{display:flex;justify-content:center;margin-top:12px}.lecturer-task-not-graded{color:#dc2626;font-weight:700;margin-right:50px}.lecturer-task-graded{color:#16a34a;font-weight:700}.lecturer-task-actions{display:flex;gap:8px;justify-content:center;margin-top:12px}.task-button{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 14px;text-align:center}.lecturer-task-grade{background-color:#3b82f6}.lecturer-task-edit{background-color:#16a34a}.lecturer-task-delete{background-color:#dc2626}.lecturer-task-grade:hover{background-color:#2563eb}.lecturer-task-edit:hover{background-color:#15803d}.lecturer-task-delete:hover{background-color:#b91c1c}.task-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.task-modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;padding:0;width:90%}.task-modal-content-large{max-width:700px}.task-modal-header{background:linear-gradient(135deg,#10b981,#059669);border-bottom:1px solid #e5e7eb;justify-content:space-between;padding:24px}.task-modal-header,.task-modal-header h2{align-items:center;color:#fff;display:flex}.task-modal-header h2{font-size:22px;font-weight:600;margin:0}.task-modal-close{align-items:center;background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.task-modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.task-modal-body{-ms-overflow-style:none;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:24px;scrollbar-width:none}.task-modal-body::-webkit-scrollbar{display:none}.task-form-field{margin-bottom:20px}.task-form-field label{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:600;margin-bottom:8px;width:100%}.task-form-field input,.task-form-field select,.task-form-field textarea{border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;margin-top:4px;padding:12px;transition:all .2s ease;width:100%}.task-form-field input:focus,.task-form-field select:focus,.task-form-field textarea:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;outline:none}.task-form-field textarea{min-height:100px;resize:vertical}.task-form-field input::placeholder,.task-form-field textarea::placeholder{color:#9ca3af}.task-modal-actions{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.task-edit-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-edit-task-secondary{background-color:#e5e7eb;color:#374151}.btn-edit-task-secondary:hover{background-color:#d1d5db;transform:translateY(-1px)}.btn-edit-task-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-edit-task-primary:hover{box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.task-files-section{margin-bottom:32px}.task-files-section h3{align-items:center;border-bottom:2px solid #e5e7eb;color:#374151;display:flex;font-size:18px;font-weight:600;margin-bottom:16px;padding-bottom:8px}.task-empty-message{color:#9ca3af;font-style:italic;padding:20px;text-align:center}.task-files-list,.task-student-list{list-style:none;margin:0;padding:0}.task-file-item,.task-student-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:8px;padding:12px 16px;transition:all .2s ease}.task-file-item:hover,.task-student-item:hover{background:#f3f4f6;border-color:#d1d5db;transform:translateX(4px)}.task-student-name{color:#374151;font-weight:500}.task-student-email{color:#6b7280;font-size:13px}.task-file-student{color:#374151;font-weight:500}.task-file-download-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:13px;padding:8px 16px;transition:all .2s ease}.task-file-download-btn:hover{box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.task-grade-list{display:flex;flex-direction:column;gap:16px}.task-grade-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:16px;transition:all .2s ease}.task-grade-item:hover{background:#f3f4f6;border-color:#d1d5db}.task-grade-student-info{margin-bottom:12px}.task-grade-student-name{color:#374151;font-size:15px;font-weight:600;margin-bottom:6px}.task-grade-file-info{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.task-grade-file-badge{align-items:center;background:#dbeafe;border-radius:6px;color:#1e40af;display:inline-flex;font-size:12px;font-weight:500;padding:4px 10px}.task-grade-download-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:6px 10px;transition:all .2s ease}.task-grade-download-btn:hover{box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.task-grade-no-file-badge{background:#fee2e2;border-radius:6px;color:#991b1b;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.task-grade-inputs{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:120px 1fr}.task-grade-input-group{display:flex;flex-direction:column}.task-grade-input-group label{color:#6b7280;font-size:12px;font-weight:600;margin-bottom:6px}.task-grade-input-group input,.task-grade-input-group textarea{border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:10px;transition:all .2s ease}.task-grade-input-group input:focus,.task-grade-input-group textarea:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;outline:none}.task-grade-input-group input{width:100%}.task-grade-feedback textarea{min-height:60px;resize:vertical}@media (max-width:768px){.task-grade-inputs{grid-template-columns:1fr}}.grades-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 14px 30px #0f172a0f;padding:14px 16px 18px}.lg-cardTop{align-items:flex-start;border-bottom:1px solid #eef2f7;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.lg-h3{color:#0f172a;font-size:16px;font-weight:800;margin:0}.lg-sub{color:#6b7280;font-size:13px;margin:6px 0 0;max-width:780px}.lg-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.lg-toggle{align-items:center;display:inline-flex;gap:8px}.lg-filters{grid-gap:10px;display:grid;gap:10px;grid-template-columns:240px 280px 1fr;margin-bottom:12px}.lg-filter{display:flex;flex-direction:column;gap:6px}.lg-filter label{color:#6b7280;font-size:12px}.lg-filter input,.lg-filter select{background:#fff;border:1px solid #d1d5db;border-radius:999px;box-sizing:border-box;color:#0f172a;font-size:13px;height:40px;outline:none;padding:0 12px;transition:border-color .15s ease,box-shadow .15s ease}.lg-filter input:focus,.lg-filter select:focus{border-color:#16a34a;box-shadow:0 0 0 1px #16a34a26}.lg-filterGrow{min-width:0}.lg-tableWrap{-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #e5e7eb;border-radius:16px;overflow:auto}.lg-row,.lg-tableHeader{grid-gap:0;align-items:center;display:grid;gap:0;grid-template-columns:220px 140px 260px 110px 110px 110px 110px 110px 140px 140px 140px;min-width:1500px}.lg-tableHeader{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#0f172a;font-size:13px;font-weight:800}.lg-row>span,.lg-tableHeader>span{border-bottom:1px solid #eef2f7;overflow:hidden;padding:12px;text-overflow:ellipsis;white-space:nowrap}.lg-row{color:#0f172a;font-size:13px}.lg-row-clickable{cursor:pointer;transition:background-color .15s ease}.lg-row-clickable:hover{background:#f3f4f6}.lg-name{font-weight:800}.lg-module{font-weight:700}.lg-gradeCell{color:#334155}.lg-final-grade,.lg-gradeCell{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.lg-final-grade{background:#16a34a1a;border:2px solid #16a34a4d;border-radius:6px;color:#16a34a;display:inline-block;font-weight:700;padding:4px 10px}.lg-final-grade-modal{background:#16a34a26;border:2px solid #16a34a66;border-radius:8px;font-size:16px;padding:6px 12px}.lg-final-average{color:#9ca3af;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-weight:400}.lg-exam-grade{background:#dc26261a;border:2px solid #dc26264d;border-radius:6px;color:#dc2626;display:inline-block;font-weight:700;padding:4px 10px}.lg-chip-final-exam{background:#dc262626!important;border-color:#dc262659!important;border-width:2px;color:#991b1b!important;font-weight:900}.lg-chip-exam{background:#dc26261a!important;border-color:#dc262640!important;color:#991b1b!important;font-weight:800}.lg-final-exam-grade{color:#dc2626;font-size:15px;font-weight:900}.lg-date{color:#64748b}.lg-hidePartials .lg-col-partial{display:none}.lg-hidePartials .lg-row,.lg-hidePartials .lg-tableHeader{grid-template-columns:220px 140px 260px 140px 140px 140px;min-width:1020px}.lg-modalOverlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:18px;position:fixed;z-index:9999}.lg-modal{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 30px 70px #0f172a40;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:min(900px,100%)}.lg-modalHeader{align-items:flex-start;border-bottom:1px solid #eef2f7;display:flex;gap:12px;justify-content:space-between;padding:14px 16px}.lg-modalTitle{color:#0f172a;font-size:16px;font-weight:900}.lg-modalSub{color:#6b7280;font-size:12px;margin-top:6px}.lg-close{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:999px;cursor:pointer;display:inline-flex;height:38px;justify-content:center;width:38px}.lg-close:hover{background:#f3f4f6}.lg-modalBody{-webkit-overflow-scrolling:touch;flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:12px 16px}.lg-gradeSection{margin-bottom:24px}.lg-gradeSection:last-child{margin-bottom:0}.lg-sectionTitle{border-bottom:2px solid #e5e7eb;color:#0f172a;font-size:14px;font-weight:700;margin:0 0 12px;padding-bottom:8px}.lg-detailRow{align-items:flex-start;border:1px solid #eef2f7;border-radius:14px;display:flex;gap:12px;justify-content:space-between;margin-bottom:10px;padding:12px 14px;transition:background-color .15s ease}.lg-detailRow:hover{background:#f9fafb}.lg-detailMain{min-width:0}.lg-detailGrade{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.lg-chip{background:#16a34a1a;border:1px solid #16a34a33;border-radius:999px;color:#166534;display:inline-block;font-size:12px;font-weight:800;max-width:100%;overflow:hidden;padding:4px 10px;text-overflow:ellipsis;white-space:nowrap}.lg-chip-presentation{background:#8b5cf61a;border-color:#8b5cf633;color:#6b21a8}.lg-chip-quiz{background:#3b82f61a;border-color:#3b82f633;color:#1e40af}.lg-chip-test{background:#ec48991a;border-color:#ec489933;color:#9f1239}.lg-chip-activity{background:#16a34a1a;border-color:#16a34a33;color:#166534}.lg-chip-other{background:#6b72801a;border-color:#6b728033;color:#374151}.lg-chip-assignment{background:#f59e0b1a;border-color:#f59e0b33;color:#92400e}.lg-grade-chip{border-radius:6px;display:inline-block;font-size:12px;font-weight:600;padding:2px 8px}.lg-grade-chip.lg-chip-presentation{background:#8b5cf626;color:#6b21a8}.lg-grade-chip.lg-chip-quiz{background:#3b82f626;color:#1e40af}.lg-grade-chip.lg-chip-test{background:#ec489926;color:#9f1239}.lg-grade-chip.lg-chip-activity{background:#16a34a26;color:#166534}.lg-grade-chip.lg-chip-other{background:#6b728026;color:#374151}.lg-grade-chip.lg-chip-assignment{background:#f59e0b26;color:#92400e}.lg-gradeVal{color:#0f172a;font-size:14px;font-weight:900}.lg-detailMeta{color:#6b7280;display:flex;flex-direction:column;font-size:12px;gap:4px;margin-top:6px}.lg-metaItem{display:inline-block;margin-right:12px}.lg-assignmentTitle{color:#334155;font-weight:600;margin-bottom:4px}.lg-feedback{border-left:3px solid #16a34a}.lg-description,.lg-feedback{background:#f9fafb;border-radius:6px;color:#475569;font-size:12px;margin-top:6px;padding:8px}.lg-description{border-left:3px solid #3b82f6}.lg-statusBadge{border-radius:999px;display:inline-block;font-size:11px;font-weight:600;margin-left:8px;padding:4px 10px}.lg-status-passed{background:#16a34a1a;color:#166534}.lg-status-failed{background:#ef44441a;color:#991b1b}.lg-status-absent{background:#6b72801a;color:#374151}.lg-status-exempt{background:#3b82f61a;color:#1e40af}.lg-detailActions{display:flex;gap:10px}.lg-modalFooter{border-top:1px solid #eef2f7;padding:10px 16px 14px}.lg-note{color:#9ca3af;font-size:12px}.lg-exam-type-group{gap:12px}.lg-exam-attempts,.lg-exam-type-group{align-items:center;display:inline-flex}.lg-exam-attempts{flex-wrap:wrap;gap:8px}.lg-exam-attempt{display:inline-block}.lg-exam-strikethrough{color:#6b7280;opacity:.5;text-decoration:line-through}.lg-exam-separator{color:#d1d5db;display:inline-block;font-size:18px;font-weight:300;margin:0 4px;opacity:.6}.lg-exam-attempts-modal{align-items:center;display:inline-flex;flex-wrap:wrap;gap:8px}.lg-exam-attempt-modal{display:inline-block}.lg-exam-attempt-modal.lg-exam-strikethrough{color:#6b7280;opacity:.5;text-decoration:line-through}@media (max-width:1000px){.lg-filters{grid-template-columns:1fr 1fr}.lg-filterGrow{grid-column:1/-1}}@media (max-width:640px){.lg-filters{grid-template-columns:1fr}.lg-actions{width:100%}.lg-toggle span{display:none}}@media (max-width:900px){.lg-tableWrap .lg-col-partial{display:none}.lg-tableWrap.lg-showPartials .lg-col-partial{display:block}}.modal-overlay{height:100vh!important;left:0!important;position:fixed!important;top:0!important;width:100vw!important;z-index:10001!important}.modal-overlay .modal-content{display:flex;flex-direction:column;max-height:90vh;max-width:1400px;overflow-x:hidden;overflow-y:auto!important;padding:30px;width:95%}.modal-overlay .modal-content::-webkit-scrollbar{width:8px}.modal-overlay .modal-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.modal-overlay .modal-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.modal-overlay .modal-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.exam-type-selection{grid-gap:1rem;display:grid;flex:1 1;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem;min-height:0}.exam-type-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:1.5rem;position:relative;transition:all .2s}.exam-type-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.exam-type-card-active,.exam-type-card:hover{background-color:#f0fdf4;border-color:#16a34a}.exam-type-card-active{box-shadow:0 4px 12px #16a34a33}.exam-type-icon{align-items:center;background-color:#16a34a;border-radius:12px;color:#fff;display:flex;font-size:20px;font-weight:700;height:48px;justify-content:center;margin-bottom:1rem;width:48px}.exam-type-name{color:#0f172a;font-size:16px;font-weight:600;margin:0 0 .5rem}.exam-type-description{color:#64748b;font-size:13px;line-height:1.4;margin:0}.exam-type-header{justify-content:space-between}.exam-form-header,.exam-type-header{align-items:center;display:flex;flex-shrink:0;margin-bottom:20px}.exam-form-header{gap:12px}.modal-close-button{align-items:center;background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;flex-shrink:0;font-size:32px;height:36px;justify-content:center;line-height:1;padding:4px 8px;transition:all .2s;width:36px}.modal-close-button:hover{background:#f1f5f9;color:#0f172a}.exam-type-header .modal-title{flex:1 1;margin:0}.modal-overlay .modal-content form.form-group{display:flex;flex-direction:column;gap:1rem}.back-button{align-items:center;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:36px;justify-content:center;transition:all .2s;width:36px}.back-button:hover{background:#e2e8f0;border-color:#cbd5e1;color:#334155}.exam-form-header .modal-title{flex:1 1;margin:0}.form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.form-group input[type=checkbox]{cursor:pointer;margin:0;width:auto}.report-modal-buttons{flex-shrink:0;margin-top:auto;padding-top:1.5rem}.modal-title{flex-shrink:0}.final-grades-table-container{border:1px solid #e5e7eb;border-radius:12px;margin-top:1.5rem;max-height:500px;min-width:100%;overflow-x:auto;overflow-y:auto}.final-grades-table-header,.final-grades-table-row{grid-gap:20px;align-items:center;border-bottom:1px solid #eef2f7;display:grid;gap:20px;grid-template-columns:220px 140px 140px 150px 140px 120px 160px;min-width:1070px;padding:14px 20px}.final-grades-table-header{background:#f9fafb;border-bottom:2px solid #e5e7eb;color:#0f172a;font-size:13px;font-weight:700;position:sticky;top:0;z-index:10}.final-grades-table-row{color:#0f172a;font-size:13px;transition:background-color .15s}.final-grades-table-row:hover{background-color:#f9fafb}.final-grades-table-row:last-child{border-bottom:none}.student-name{font-weight:600}.average-grade{align-items:center;color:#16a34a;display:flex;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-weight:600;gap:8px}.use-average-button{align-items:center;background:#16a34a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:24px;justify-content:center;padding:0;transition:all .2s;width:24px}.use-average-button:hover{background:#15803d;transform:scale(1.1)}.final-grade-select{box-sizing:border-box;font-size:13px;min-width:100px;padding:8px 10px;width:100%}.final-grades-table-row span{min-width:0;overflow:visible}.final-grades-table-row span:has(.final-grade-select){min-width:100px}.final-grades-table-body{background:#fff}.final-grades-modal-content{margin:0 auto;max-width:1400px!important;width:95%!important}@media (max-width:1400px){.final-grades-table-container{overflow-x:auto}}@media (max-width:640px){.exam-type-selection,.form-grid{grid-template-columns:1fr}.modal-overlay .modal-content{max-height:95vh;max-width:98%!important;width:98%!important}.final-grades-table-header,.final-grades-table-row{gap:8px;grid-template-columns:1fr;min-width:auto}.final-grades-table-header{display:none}.final-grades-table-row{border:1px solid #eef2f7;border-radius:8px;margin-bottom:8px;padding:12px}.final-grades-table-row>span{display:flex;flex-direction:column;gap:4px}.final-grades-table-row>span:before{color:#64748b;content:attr(data-label);font-size:12px;font-weight:600;margin-bottom:4px}}.egm-modal-backdrop{align-items:center;background:#0f172a99;bottom:0;display:flex;justify-content:center;left:0;padding:18px;position:fixed;right:0;top:0;z-index:10000}.egm-modal{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 30px 70px #0f172a40;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:min(500px,100%)}.egm-modal-header{align-items:center;border-bottom:1px solid #eef2f7;display:flex;justify-content:space-between;padding:16px 20px}.egm-modal-header h2{color:#0f172a;font-size:18px;font-weight:900;margin:0}.egm-close-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:999px;cursor:pointer;display:inline-flex;height:32px;justify-content:center;padding:0;transition:background-color .15s ease;width:32px}.egm-close-btn:hover{background:#f3f4f6}.egm-modal-body{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:20px}.egm-form-group{margin-bottom:20px}.egm-form-group:last-child{margin-bottom:0}.egm-form-group label{color:#374151;display:flex;flex-direction:column;font-size:13px;font-weight:600;gap:8px;margin-bottom:0}.egm-form-input{border:1px solid #d1d5db;border-radius:8px;color:#0f172a;font-family:inherit;font-size:14px;outline:none;padding:10px 12px;transition:border-color .15s ease,box-shadow .15s ease}.egm-form-input:focus{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1a}.egm-form-input:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.egm-form-input textarea{min-height:80px;resize:vertical}.egm-info{background:#f9fafb;border-radius:6px;color:#6b7280;font-size:12px;margin-top:8px;padding:8px 12px}.egm-modal-actions{border-top:1px solid #eef2f7;display:flex;gap:12px;justify-content:flex-end;padding:16px 20px}.egm-modal-actions .btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .15s ease}.egm-modal-actions .btn-primary{background:#16a34a;color:#fff}.egm-modal-actions .btn-primary:hover{background:#15803d}.egm-modal-actions .btn-secondary{background:#f3f4f6;color:#374151}.egm-modal-actions .btn-secondary:hover{background:#e5e7eb}.modal-overlay-upload{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0003;max-width:95%;padding:24px;width:380px}.modal-title-upload{font-size:1.25rem;font-weight:700;margin-bottom:16px}.modal-label-upload{display:block;font-weight:500;margin-bottom:6px}.modal-input-upload,.modal-select{border:1px solid #ccc;border-radius:6px;font-size:.95rem;margin-bottom:16px;padding:8px;width:100%}.modal-actions{display:flex;gap:8px;justify-content:center}.modal-btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;padding:8px 16px}.modal-btn.cancel{background:#e5e5e5;color:#333}.modal-btn.cancel:hover{background:#d6d6d6}.modal-btn.primary{background:#15803d;color:#fff}.modal-btn.primary:hover{background:#16a34a}.file-input-hidden{display:none}.file-upload-btn{align-items:center;background:#16a34a;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:500;justify-content:center;padding:10px 16px}.file-upload-btn:hover{background:#15803d}.file-chosen{color:#333;font-size:.9rem;margin-top:8px;text-align:center}.file-list-grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.file-grid-cols-3{grid-template-columns:repeat(3,1fr)}.file-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.file-icon{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.file-extension{color:#64748b;font-size:12px}.file-module{font-weight:500}.file-module,.file-name{font-size:14px;margin:0 0 .5rem}.file-size{color:#64748b;font-size:12px;margin:0 0 .5rem}.file-actions{display:flex;gap:.5rem;margin-top:.5rem}.button-delete,.button-download{align-items:center;display:flex;flex:1 1;font-size:12px;justify-content:center}.button-delete{background-color:#dc2626;border:none;color:#fff;transition:background-color .2s}.button-delete:hover{background-color:#b91c1c}.lecturer-messages-content{background-color:#f8fafc;box-sizing:border-box;min-height:100vh;padding:24px 24px 40px}.management-card{background-color:#fff;border-radius:16px;box-shadow:0 2px 10px #0f172a0f;margin-bottom:24px;padding:20px 22px}.card-header-management{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.card-header-management h3{color:#111827;font-size:1rem;font-weight:600;margin:0}.header-subtitle{color:#6b7280;font-size:.9rem;margin-top:4px}.message-table{background-color:#fff;border-collapse:collapse;border-radius:10px;margin-top:.5rem;overflow:hidden;width:100%}.message-table td,.message-table th{border-bottom:1px solid #eee;font-size:.9rem;padding:12px 15px;text-align:left;vertical-align:middle}.message-table th{background-color:#f7f9fb;color:#374151;font-weight:600}.message-table tr:hover{background-color:#f3f7ff}.badge{border-radius:999px;display:inline-block;font-size:.75rem;font-weight:500;padding:4px 8px;text-transform:capitalize}.badge-info{background-color:#e0f2fe;color:#0369a1}.badge-warning{background-color:#fff3cd;color:#856404}.badge-alert{background-color:#fee2e2;color:#b91c1c}.message-actions{align-items:center;display:flex;gap:8px}.btn-message{align-items:center;border:none;border-radius:999px;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:500;justify-content:center;padding:6px 12px;transition:background-color .15s ease,box-shadow .15s ease}.btn-message.reply{background-color:#16a34a;color:#fff}.btn-message.reply:hover{background-color:#15803d}.btn-message.delete{background-color:#22c55e;color:#fff}.btn-message.delete:hover{background-color:#16a34a}@media (max-width:768px){.lecturer-messages-content{padding:16px 12px 28px}.management-card{padding:16px 14px}.message-table{box-shadow:none}.message-table td,.message-table th{font-size:.8rem;padding:8px 10px}.message-actions{align-items:flex-start;flex-direction:column}.btn-message{justify-content:center;width:100%}}.button-container{display:flex;gap:.5rem}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1.5rem;transition:all .2s}.btn-primary{background-color:#16a34a;color:#fff}.btn-primary:hover{background-color:#15803d}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background-color:#fff;border:1px solid #cbd5e1;color:#475569}.btn-secondary:hover{background-color:#f8fafc}.icon-style{margin-right:0}.btn-icon{background:none;border:none;border-radius:6px;cursor:pointer;padding:6px;transition:background-color .2s ease}.btn-icon.edit:hover{background-color:#e0f2fe}.btn-icon.delete:hover{background-color:#fee2e2}.modal-overlay-attendance{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content-attendance{animation:slideDown .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;max-height:80vh;max-width:700px;overflow-y:auto;padding:20px;position:relative;width:90%}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.modal-header h2{color:#333;font-size:1.5rem;margin:0}.close-btn{background:none;border:none;color:#666;cursor:pointer;transition:color .2s}.close-btn:hover{color:#000}.modal-search{border-bottom:1px solid #e5e7eb;margin-bottom:20px;padding-bottom:16px}.modal-search-input{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0f172a0a;display:flex;gap:10px;padding:12px 16px;transition:all .25s cubic-bezier(.4,0,.2,1)}.modal-search-input:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 4px 8px #0f172a0f}.modal-search-input:focus-within{background:#fff;border-color:#16a34a;box-shadow:0 0 0 4px #16a34a1f,0 4px 12px #0f172a14;transform:translateY(-1px)}.modal-search-input svg{color:#64748b;flex-shrink:0;transition:color .2s ease}.modal-search-input:focus-within svg{color:#16a34a}.modal-search-field{background:#0000;border:none;color:#0f172a;flex:1 1;font-size:14px;font-weight:500;outline:none;width:100%}.modal-search-field::placeholder{color:#94a3b8;font-weight:400}.modal-search-clear{align-items:center;background:#e2e8f0;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;padding:0;transition:all .15s ease;width:24px}.modal-search-clear:hover{background:#cbd5e1;color:#475569;transform:scale(1.1)}.modal-search-clear:active{transform:scale(.95)}.modal-search-results{color:#64748b;font-size:13px;font-weight:500;margin-top:10px}.modal-table{border-collapse:collapse;margin-top:10px;width:100%}.modal-table td,.modal-table th{border-bottom:1px solid #e0e0e0;padding:10px;text-align:left}.modal-table th{background-color:#f5f5f5;font-weight:600}.modal-table select{background-color:#fff;border:1px solid #ccc;border-radius:6px;cursor:pointer;padding:5px}.modal-table tr td select[value=present]{background-color:#d4edda;color:#155724}.modal-table tr td select[value=late]{background-color:#fff3cd;color:#856404}.modal-table tr td select[value=absent]{background-color:#f8d7da;color:#721c24}.modal-table tr td select[value=not_checked]{background-color:#e2e3e5;color:#6c757d}@media (max-width:600px){.modal-content-attendance{padding:15px;width:95%}.modal-header h2{font-size:1.3rem}.modal-table td,.modal-table th{font-size:.9rem;padding:8px}}.la-page{box-sizing:border-box;padding:24px 28px 40px;width:100%}.la-topbar{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px}.la-h1{font-size:22px;font-weight:800;letter-spacing:-.2px;margin:0}.la-subtitle{color:#64748b;font-size:13px;margin:6px 0 0}.la-topbar-actions{display:flex;flex-wrap:wrap;gap:10px}.la-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 14px 30px #0f172a0f;box-sizing:border-box;overflow:hidden;padding:14px 16px 16px;width:100%}.la-card+.la-card{margin-top:14px}.la-card-head{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:10px}.la-card-head-tight{margin-bottom:8px}.la-card-title{font-size:15px;font-weight:800;margin:0}.la-card-title-sm{font-size:14px;font-weight:800;margin:0}.la-card-hint{margin:4px 0 0}.la-card-hint,.la-card-note{color:#64748b;font-size:12px}.la-card-note{margin:0;text-align:right}.la-card-icon{background:#f1f5f9;border-radius:10px;color:#334155;display:grid;height:32px;place-items:center;width:32px}.la-btn{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;color:#0f172a;cursor:pointer;display:inline-flex;font-size:13px;gap:8px;line-height:1;padding:8px 12px;transition:background .15s ease,border-color .15s ease,transform .08s ease;-webkit-user-select:none;user-select:none}.la-btn:hover{background:#eef2f7;border-color:#dbe3ee}.la-btn:active{transform:translateY(1px)}.la-btn-primary{background:#16a34a;border-color:#16a34a;color:#fff}.la-btn-primary:hover{background:#15803d;border-color:#15803d}.la-btn-ghost{background:#fff}.la-btn-row{padding:7px 12px}.la-btn-full{justify-content:center;margin-top:10px;width:100%}.la-filters{grid-gap:10px;align-items:end;display:grid;gap:10px;grid-template-columns:180px 160px 190px 220px;margin-top:8px}.la-field{min-width:0}.la-label{color:#64748b;display:block;font-size:12px;margin-bottom:6px}.la-select{background:#fff;border:1px solid #d1d5db;border-radius:12px;font-size:13px;outline:none;padding:8px 12px;width:100%}.la-select:focus{border-color:#16a34a;box-shadow:0 0 0 2px #16a34a14}.la-search{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:12px;color:#64748b;display:flex;gap:8px;padding:8px 12px;transition:all .2s ease}.la-search:focus-within{background:#fff;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1a}.la-input{background:#0000;border:none;color:#0f172a;font-size:13px;outline:none;width:100%}.la-field-toggle{display:flex;justify-content:flex-end}.la-toggle{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;color:#0f172a;cursor:pointer;display:inline-flex;font-size:12px;gap:10px;padding:8px 12px;-webkit-user-select:none;user-select:none}.la-toggle input{height:14px;width:14px}.la-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,minmax(180px,1fr));margin-top:12px}.la-stat{align-items:center;background:#fbfdff;border:1px solid #eef2f7;border-radius:16px;display:flex;gap:10px;padding:12px}.la-stat-ic{background:#f1f5f9;border-radius:12px;color:#334155;display:grid;height:34px;place-items:center;width:34px}.la-stat-ic-green{background:#ecfdf5;color:#047857}.la-stat-ic-yellow{background:#fff7ed;color:#b45309}.la-stat-ic-blue{background:#eff6ff;color:#1d4ed8}.la-stat-label{color:#64748b;font-size:12px}.la-stat-value{color:#0f172a;font-size:18px;font-weight:800;margin-top:2px}.la-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 320px;margin-top:14px}.la-card-table{padding-bottom:10px}.la-table-search{margin:12px 0 14px;padding:0 2px}.la-search-enhanced{background:#f9fafb;border:2px solid #e5e7eb;border-radius:14px;box-shadow:0 2px 4px #0f172a0a;padding:12px 16px;transition:all .25s cubic-bezier(.4,0,.2,1)}.la-search-enhanced:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 4px 8px #0f172a0f}.la-search-enhanced:focus-within{background:#fff;border-color:#16a34a;box-shadow:0 0 0 4px #16a34a1f,0 4px 12px #0f172a14;transform:translateY(-1px)}.la-search-enhanced svg{color:#64748b;flex-shrink:0;transition:color .2s ease}.la-search-enhanced:focus-within svg{color:#16a34a}.la-search-enhanced .la-input{font-size:14px;font-weight:500}.la-search-enhanced .la-input::placeholder{color:#94a3b8;font-weight:400}.la-search-clear{align-items:center;background:#e2e8f0;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;margin-left:auto;padding:0;transition:all .15s ease;width:24px}.la-search-clear:hover{background:#cbd5e1;color:#475569;transform:scale(1.1)}.la-search-clear:active{transform:scale(.95)}.la-card-details{padding:12px 14px}.la-table-wrap{border:1px solid #eef2f7;border-radius:14px;overflow-x:auto;width:100%}.la-table{background:#fff;border-collapse:collapse;min-width:900px;width:100%}.la-table th{background:#f8fafc;border-bottom:1px solid #eef2f7;color:#334155;font-size:12px;padding:10px 12px;text-align:left;white-space:nowrap}.la-table td{border-bottom:1px solid #f1f5f9;color:#0f172a;font-size:13px;padding:12px;vertical-align:middle}.la-table tbody tr{cursor:pointer}.la-table tbody tr:hover{background:#fbfdff}.la-table tbody tr.is-active{background:#f0fdf4}.la-date{color:#64748b;font-weight:600;white-space:nowrap}.la-topic-title{font-weight:800;white-space:nowrap}.la-topic-sub{color:#64748b;margin-top:2px;max-width:520px;overflow:hidden;text-overflow:ellipsis}.la-pill,.la-topic-sub{font-size:12px;white-space:nowrap}.la-pill{background:#f1f5f9;border:1px solid #e5e7eb;border-radius:999px;font-weight:700;justify-content:center;padding:6px 10px}.la-inline,.la-pill{align-items:center;color:#0f172a;display:inline-flex}.la-inline{gap:6px;white-space:nowrap}.la-badge{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;justify-content:center;padding:6px 10px;white-space:nowrap}.att-badge-neutral{background:#f1f5f9;border-color:#e5e7eb;color:#334155}.att-badge-green{background:#ecfdf5;border-color:#a7f3d0;color:#047857}.att-badge-yellow{background:#fff7ed;border-color:#fed7aa;color:#b45309}.att-badge-red{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.la-progress{align-items:center;display:flex;gap:10px;min-width:220px}.la-progress-bar{background:#eef2f7;border-radius:999px;flex:1 1;height:10px;overflow:hidden}.la-progress-fill{border-radius:999px;height:100%}.la-progress-fill.att-badge-green{background:#16a34a}.la-progress-fill.att-badge-yellow{background:#f59e0b}.la-progress-fill.att-badge-red{background:#ef4444}.la-details-empty{padding:6px 2px}.la-details-title{font-size:14px;font-weight:900;margin-bottom:2px}.la-details-sub{color:#64748b;font-size:12px;margin-bottom:10px}.la-details-text{color:#64748b;font-size:12px;line-height:1.45;margin:0}.la-details-top{align-items:flex-start;border-bottom:1px solid #eef2f7;display:flex;gap:10px;justify-content:space-between;padding-bottom:10px}.la-details-date{color:#64748b;font-size:12px;font-weight:700}.la-details-module{font-size:13px;font-weight:900;margin-top:6px}.la-details-title2{color:#64748b;font-size:12px;margin-top:3px}.la-details-kpis{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-top:12px}.la-kpi{background:#fbfdff;border:1px solid #eef2f7;border-radius:16px;padding:10px 12px}.la-kpi-label{color:#64748b;font-size:12px}.la-kpi-value{color:#0f172a;font-size:16px;font-weight:900;margin-top:4px}.la-student-search{margin-top:12px}.la-help{color:#94a3b8;font-size:12px;line-height:1.35;margin-top:6px}.la-recent{grid-gap:10px;-webkit-overflow-scrolling:touch;display:grid;gap:10px;grid-auto-columns:minmax(260px,320px);grid-auto-flow:column;overflow-x:auto;padding-bottom:6px}.la-recent-card{background:#fff;border:1px solid #eef2f7;border-radius:16px;cursor:pointer;padding:12px;text-align:left}.la-recent-card:hover{background:#fbfdff}.la-recent-top{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:8px}.la-recent-date{white-space:nowrap}.la-recent-date,.la-recent-title{color:#0f172a;font-size:12px;font-weight:900}.la-recent-title{margin-top:2px}.la-recent-sub{color:#64748b;font-size:12px;height:34px;line-height:1.35;margin-top:2px;overflow:hidden}.la-recent-meta{color:#64748b;display:flex;flex-wrap:wrap;font-size:12px;gap:10px;margin-top:10px}.la-td-muted{color:#64748b;font-size:13px;padding:10px 2px}@media (max-width:1100px){.la-filters{grid-template-columns:1fr 1fr}.la-field-toggle{justify-content:flex-start}.la-table-search{margin:10px 0 12px}.la-stats{grid-template-columns:repeat(2,minmax(180px,1fr))}.la-grid{grid-template-columns:1fr}}@media (max-width:640px){.la-page{padding:16px 12px 28px}.la-topbar{align-items:flex-start;flex-direction:column}.la-topbar-actions{justify-content:flex-start;width:100%}.la-filters,.la-stats{grid-template-columns:1fr}.la-card-note{text-align:left}.la-table{min-width:860px}.la-recent{grid-auto-columns:minmax(240px,280px)}}.student-dashboard-panel{background-color:#f3f4f6;display:flex;min-height:100vh}.student-dashboard-panel .main-content{background-color:#f3f4f6;display:flex;flex:1 1;flex-direction:column}.student-dashboard-panel .header{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 10px 26px #0f172a08;padding:14px 18px;position:sticky;top:0;z-index:60}.student-dashboard-panel .header .header-title,.student-dashboard-panel .header .page-title,.student-dashboard-panel .header .title,.student-dashboard-panel .header h1,.student-dashboard-panel .header h2{display:none!important}.student-page-inner{box-sizing:border-box;margin:0;max-width:100%;padding:24px 24px 40px;width:100%}@media (max-width:1024px){.student-page-inner{padding:20px 16px 32px}}@media (max-width:640px){.student-page-inner{padding:16px 12px 28px}.student-dashboard-panel .header{padding:12px 14px}}.student-header-main{align-items:flex-start;display:flex;gap:14px;justify-content:space-between;margin-bottom:18px}.student-header-title{color:#111827;font-size:28px;font-weight:700;letter-spacing:.01em;margin:0}.student-header-subtitle{color:#6b7280;font-size:14px;margin:6px 0 0}@media (max-width:640px){.student-header-title{font-size:22px}}.student-stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:20px}.student-stat-card{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 18px 40px #0f172a0a;display:flex;gap:14px;padding:16px 18px}.student-stat-icon{align-items:center;background-color:#ecfdf3;border-radius:999px;color:#16a34a;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.student-stat-icon svg{height:20px;width:20px}.student-stat-body{display:flex;flex-direction:column;gap:2px}.student-stat-value{color:#111827;font-size:22px;font-weight:700;margin:0}.student-stat-label{color:#6b7280;font-size:13px;margin:0}.student-stat-badge{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;color:#6b7280;display:inline-flex;font-size:11px;letter-spacing:.04em;margin-top:6px;padding:3px 9px;text-transform:uppercase}.stat-success{color:#16a34a}.stat-danger{color:#b91c1c}.stat-progress{color:#047857}.stat-neutral{color:#111827}.student-quick-actions{background-color:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 18px 40px #0f172a0a;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;padding:16px 18px}.student-quick-action-btn{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;color:inherit;cursor:pointer;display:inline-flex;font-size:13px;gap:8px;padding:7px 13px;text-decoration:none;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease}.student-quick-action-btn:hover{background-color:#ecfdf3;border-color:#16a34a;box-shadow:0 6px 16px #16a34a1f;color:inherit;text-decoration:none}.student-quick-icon{align-items:center;background-color:#ecfdf3;border-radius:999px;color:#16a34a;display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.student-quick-icon svg{height:16px;width:16px}.student-quick-text{align-items:flex-start;display:flex;flex-direction:column}.student-quick-label{color:#111827;font-size:13px;font-weight:600;line-height:1.2}.student-quick-desc{color:#6b7280;font-size:12px;line-height:1.2}@media (max-width:640px){.student-quick-actions{padding:14px}.student-quick-action-btn{justify-content:flex-start;width:100%}}.student-main-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);margin-bottom:20px}.student-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 18px 40px #0f172a0a;padding:16px 18px 14px}.student-card-header{align-items:center;color:#111827;display:flex;font-size:15px;font-weight:600;gap:10px;margin:0 0 10px}.student-card-header svg{height:18px;opacity:.9;width:18px}.student-upcoming-list{list-style:none;margin:4px 0 0;padding:0}.student-upcoming-item{grid-gap:12px;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;display:grid;gap:12px;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);margin-bottom:10px;padding:10px 12px}.student-up-title{color:#111827;font-size:14px;font-weight:600;margin:0}.student-up-subtitle{color:#4b5563;font-size:13px;margin:2px 0 0}.student-up-lecturer{color:#6b7280;font-size:12px;margin:2px 0 0}.student-up-desc{color:#6b7280;font-size:12px;margin:6px 0 0}.student-up-meta{font-size:12px;gap:6px;justify-content:center}.student-room-block,.student-up-meta{align-items:flex-end;display:flex;flex-direction:column}.student-room-block{gap:4px}.student-chip{align-items:center;background-color:#ecfdf3;border:1px solid #16a34a38;border-radius:999px;color:#065f46;display:inline-flex;font-weight:600;gap:6px;padding:6px 10px}.student-meta-inline{color:#4b5563}.student-tasks-list{list-style:none;margin:4px 0 0;padding:0}.student-task-item{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;display:flex;flex-direction:column;gap:6px;margin-bottom:10px;padding:10px 12px}.student-task-title{color:#111827;font-size:14px;font-weight:600;margin:0}.student-task-desc{color:#6b7280;font-size:12px;margin:0}.student-task-meta{color:#4b5563;display:flex;flex-wrap:wrap;font-size:12px;gap:10px;justify-content:space-between;margin-top:2px}.student-task-status{color:#047857;font-weight:600}.student-empty{color:#6b7280;font-size:13px;margin:6px 0 0}@media (max-width:960px){.student-main-grid,.student-upcoming-item{grid-template-columns:minmax(0,1fr)}.student-up-meta{align-items:flex-start}}@media (max-width:640px){.student-card,.student-stat-card{box-shadow:0 10px 26px #0f172a0a}.student-stat-card{padding:14px}.student-card{padding:14px 14px 12px}}.student-dashboard-panel .header{display:none!important}.student-controls{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.student-module-select{border:1px solid #d1d5db;border-radius:6px;max-width:300px;padding:.5rem}.search-icon-grades{color:#9ca3af;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.search-input-grades{border:1px solid #d1d5db;border-radius:6px;padding:.5rem 1rem .5rem 2rem;width:200px}.show-stat-grades{background-color:#059669;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.5rem 1rem}.student-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:2rem}.stat-item-grades{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1rem}.stat-value{font-size:1.5rem;font-weight:700;margin:.5rem 0}.avg{color:#059669}.progress{color:#d97706}.final-grade-display{margin-bottom:1.5rem}.final-grade-card{align-items:center;background:linear-gradient(135deg,#16a34a1a,#16a34a0d);border:2px solid #16a34a4d;border-radius:16px;box-shadow:0 4px 12px #16a34a1a;display:flex;flex-direction:column;gap:12px;padding:24px}.final-grade-clickable{cursor:pointer;transition:all .2s ease}.final-grade-clickable:hover{border-color:#16a34a66;box-shadow:0 6px 16px #16a34a26;transform:translateY(-2px)}.final-grade-proposed{background:linear-gradient(135deg,#6b72801a,#6b72800d);border:2px solid #6b72804d;box-shadow:0 4px 12px #6b72801a;cursor:default}.final-grade-proposed-value{color:#6b7280!important;opacity:.8}.final-grade-label{color:#166534;font-size:14px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.final-grade-proposed .final-grade-label{color:#6b7280}.final-grade-value{font-size:3rem;font-weight:900;line-height:1}.final-grade-status{border-radius:999px;display:inline-block;font-size:13px;font-weight:600;padding:6px 16px}.final-grade-date{color:#6b7280;font-size:13px;margin-top:4px}.grades-list-container{background:#fff;border:1px solid #e5e7eb;border-radius:16px;margin-top:1rem;overflow:hidden}.grades-list-header{grid-gap:12px;background:#f9fafb;border-bottom:2px solid #e5e7eb;color:#0f172a;display:grid;font-size:13px;font-weight:700;gap:12px;grid-template-columns:140px 200px 100px 120px 120px 180px 100px;padding:14px 16px}.grades-list-body{display:flex;flex-direction:column}.grades-list-row{grid-gap:12px;align-items:center;border-bottom:1px solid #eef2f7;cursor:pointer;display:grid;gap:12px;grid-template-columns:140px 200px 100px 120px 120px 180px 100px;padding:14px 16px;transition:background-color .15s ease}.grades-list-row:hover{background:#f9fafb}.grades-list-row:last-child{border-bottom:none}.sg-chip{border-radius:999px;display:inline-block;font-size:12px;font-weight:700;padding:4px 10px;white-space:nowrap}.sg-chip-exam{background:#dc26261a;border:1px solid #dc262640;color:#991b1b}.sg-chip-assignment{background:#f59e0b1a;border:1px solid #f59e0b40;color:#92400e}.sg-chip-activity{background:#8b5cf61a;border:1px solid #8b5cf640;color:#6b21a8}.sg-chip-final{background:#16a34a26;border:2px solid #16a34a66;color:#166534;font-weight:900}.sg-grade-name{color:#0f172a;font-size:14px;font-weight:600}.sg-date{color:#64748b;font-size:13px}.sg-lecturer{color:#6b7280;font-size:13px}.sg-details-btn{background:#059669;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:background-color .15s ease}.sg-details-btn:hover{background:#047857}.subject-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.student-grade{font-size:1.25rem;font-weight:700;margin:0 0 .5rem}.grade-green{color:#16a34a}.grade-yellow{color:#d97706}.grade-red{color:#dc2626}.student-passed{border-radius:6px;display:inline-block;padding:.25rem .5rem}.status-passed{background-color:#dcfce7;color:#166534}.status-failed{background-color:#fee2e2;color:#991b1b}.grades-details-button{background-color:#059669;border:none;border-radius:6px;color:#fff;cursor:pointer;display:block;margin-top:.75rem;padding:.5rem;width:100%}.grade-modal-overlay{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.grade-modal-content{background:#fff;border-radius:.5rem;box-shadow:0 4px 12px #0000004d;max-width:90%;padding:2rem;width:400px}.grade-label-details{font-size:18px;font-weight:700;margin-top:.5rem}.grade-title-details{font-size:24px;font-weight:700;margin-bottom:.5rem}.exam-style{background:#dc26261a;border:2px solid #dc26264d;border-radius:8px;color:#dc2626}.assignment-style,.exam-style{display:inline-block;font-weight:900;padding:8px 16px}.assignment-style{background:#f59e0b1a;border:2px solid #f59e0b4d;border-radius:8px;color:#f59e0b}.activity-style{background:#8b5cf61a;border:2px solid #8b5cf64d;border-radius:8px;color:#8b5cf6}.activity-style,.final-style{display:inline-block;font-weight:900;padding:8px 16px}.final-style{background:#16a34a26;border:2px solid #16a34a66;border-radius:8px;color:#16a34a}.modal-overlay{align-items:center;background:#0f172a99;bottom:0;display:flex;justify-content:center;left:0;padding:18px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 30px 70px #0f172a40;max-height:90vh;overflow-y:auto;padding:24px;width:min(500px,100%)}.modal-content p{color:#374151;font-size:14px;margin:.75rem 0}.grade-label-details{color:#6b7280;font-weight:600;margin-right:.5rem}.sg-exam-attempts{align-items:center;display:inline-flex;flex-wrap:wrap;gap:8px}.sg-exam-attempt{display:inline-block;font-size:1.25rem;font-weight:700}.sg-exam-strikethrough{opacity:.5;text-decoration:line-through}.sg-exam-attempts-modal{align-items:center;display:inline-flex;flex-wrap:wrap;gap:8px}.sg-exam-attempt-modal{display:inline-block;font-size:1.25rem;font-weight:700}.sg-exam-attempt-modal.sg-exam-strikethrough{opacity:.5;text-decoration:line-through}.student-calendar-wrapper{box-sizing:border-box;height:80vh;padding:20px;position:relative}.student-calendar-header-row{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:10px}.student-calendar-title{color:#0f172a;font-size:20px;font-weight:600;margin:0}.student-calendar-subtitle{color:#6b7280;font-size:13px;margin:2px 0 0}.student-calendar-refresh-btn{align-items:center;background-color:#16a34a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:6px;padding:8px 14px;transition:background-color .18s ease}.student-calendar-refresh-btn:hover{background-color:#15803d}.calendar-modal-overlay{align-items:center;background-color:#0006;bottom:0;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:50}.calendar-modal-content{animation:fadeIn .2s ease-in-out;background:#fff;border-radius:12px;box-shadow:0 5px 20px #00000040;max-height:80vh;max-width:100%;overflow-y:auto;padding:20px;width:450px}.calendar-modal-header{align-items:center;display:flex;justify-content:space-between}.calendar-close-btn{background:none;border:none;color:#555;cursor:pointer}.calendar-modal-body p{font-size:14px;margin:8px 0}@keyframes fadeIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.student-calendar-wrapper{height:75vh;padding:12px}.student-calendar-header-row{align-items:flex-start;flex-direction:column;gap:6px}.calendar-modal-content{padding:16px}}@media (max-width:480px){.student-calendar-wrapper{height:70vh;padding:10px}.student-calendar-title{font-size:18px}.student-calendar-subtitle{font-size:12px}.student-calendar-refresh-btn{justify-content:center;width:100%}}.student-tasks-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:20px}.student-task-card{background-color:#fff;border:1px solid #ddd;border-radius:12px;box-shadow:0 2px 6px #0000001a;padding:16px;transition:transform .2s ease}.student-task-alert{background:#fbeaea;border:2px solid #d9534f}.student-task-warning{background:#fff3cd;border:2px solid #f0ad4e}.student-task-card:hover{transform:translateY(-3px)}.student-task-title{color:#333;font-size:1.2rem;margin-bottom:8px}.student-task-desc{color:#555;font-size:.95rem;margin-bottom:12px}.student-task-info{font-size:.9rem;margin:4px 0}.student-task-actions{display:flex;justify-content:center}.student-task-submit-btn{background-color:#16a34a;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:12px;padding:8px 14px;text-align:center;transition:background-color .2s ease;width:100%}.student-task-submit-btn:hover{background-color:#166534}.add-task-modal-overlay{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.add-task-modal{background:#fff;border-radius:12px;max-width:400px;padding:20px;width:100%}.add-task-modal-actions{display:flex;justify-content:center;margin-top:16px}.add-task-modal h2{color:#333;margin-bottom:0}.add-task-modal p{margin-top:2px}:root{--max-width:900px;--gap:20px;--muted:#555;--accent:#0b6efd;--bg:#fff;--text:#222;--card:#fafafa}.container{background:#fff;background:var(--bg);border-radius:10px;box-shadow:0 6px 18px #1414140a;color:#222;color:var(--text);font-family:Inter,Helvetica Neue,Arial,sans-serif;line-height:1.55;margin:36px auto;max-width:900px;max-width:var(--max-width);padding:28px}.title{font-size:1.9rem;font-weight:700;line-height:1.15;margin:0 0 8px}.meta{color:#555;color:var(--muted);font-size:.95rem;margin:0 0 20px}.section-block{background:#fafafa;background:var(--card);border:1px solid #00000008;border-radius:8px;margin-bottom:20px;margin-bottom:var(--gap);padding:14px}.section-title{color:#222;color:var(--text);font-size:1.05rem;font-weight:600;margin:0 0 8px}.section-content p{color:#222;font-size:.98rem;margin:8px 0;text-align:justify}.footer{color:#555;color:var(--muted);font-size:.95rem;margin-top:22px}@media (max-width:720px){.container{margin:18px;padding:18px}.title{font-size:1.5rem}.section-title{font-size:1rem}}@media print{.container{box-shadow:none}.container,.section-block{background:#fff;border:none}}.lecturer-profile-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:minmax(0,1.1fr) minmax(0,1.1fr);margin-top:24px}.lecturer-profile-card{background-color:#fff;border-radius:16px;box-shadow:0 2px 10px #0f172a0f;padding:20px 22px}.lecturer-profile-card-header{align-items:flex-start;display:flex;gap:12px;margin-bottom:18px}.lecturer-profile-card-header h2{color:#111827;font-size:1.05rem;font-weight:600;margin:0 0 4px}.lecturer-profile-card-header p{color:#6b7280;font-size:.88rem;margin:0}.lecturer-profile-icon{align-items:center;background-color:#e0f2fe;border-radius:999px;color:#0369a1;display:flex;height:36px;justify-content:center;width:36px}.lecturer-profile-icon.locked{background-color:#dcfce7;color:#15803d}.lecturer-profile-data{margin:0}.lecturer-profile-row{border-bottom:1px solid #e5e7eb;display:flex;flex-direction:column;gap:2px;padding:8px 0}.lecturer-profile-row:last-child{border-bottom:none}.lecturer-profile-row dt{color:#6b7280;font-size:.8rem;font-weight:600}.lecturer-profile-row dd{color:#111827;font-size:.95rem;margin:0}.lecturer-profile-with-icon{align-items:center;display:inline-flex;gap:6px}.lecturer-password-form{display:flex;flex-direction:column;gap:14px}.lecturer-input-group{display:flex;flex-direction:column;gap:4px}.lecturer-input-group label{color:#374151;font-size:.85rem;font-weight:600}.lecturer-input-group input{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:.94rem;padding:8px 10px;transition:border-color .15s ease,box-shadow .15s ease}.lecturer-input-group input:focus{border-color:#16a34a;box-shadow:0 0 0 1px #16a34a26;outline:none}.lecturer-password-btn{align-self:flex-start;background-color:#16a34a;border:none;border-radius:999px;color:#fff;cursor:pointer;font-size:.94rem;font-weight:600;margin-top:4px;padding:9px 16px;transition:background-color .15s ease,box-shadow .15s ease}.lecturer-password-btn:hover:enabled{background-color:#15803d;box-shadow:0 4px 10px #16a34a40}.lecturer-password-btn:disabled{cursor:default;opacity:.7}.profile-message{font-size:.85rem;margin-top:6px}.profile-message-success{color:#15803d}.profile-message-error{color:#b91c1c}@media (max-width:1024px){.lecturer-profile-grid{grid-template-columns:minmax(0,1fr)}}@media (max-width:640px){.lecturer-profile-card{padding:16px 14px}.lecturer-profile-card-header h2{font-size:1rem}.lecturer-password-btn{text-align:center;width:100%}}.admin-materials-panel .main-content{background-color:#f3f4f6}.admin-materials-inner{box-sizing:border-box;padding:24px 24px 40px;width:100%}@media (max-width:1024px){.admin-materials-inner{padding:20px 16px 32px}}@media (max-width:640px){.admin-materials-inner{padding:16px 12px 28px}}.admin-materials-header{align-items:flex-end;display:flex;gap:12px;justify-content:space-between;margin-bottom:16px}.admin-materials-title-wrap{display:flex;flex-direction:column;gap:6px}.admin-materials-title{align-items:center;color:#111827;display:inline-flex;font-size:26px;font-weight:700;gap:10px;letter-spacing:.01em;margin:0}.admin-materials-subtitle{color:#6b7280;font-size:14px;margin:0}.admin-materials-header-actions{align-items:center;display:flex;gap:10px}@media (max-width:640px){.admin-materials-header{align-items:stretch;flex-direction:column}.admin-materials-title{font-size:20px}.admin-materials-header-actions{justify-content:flex-end}}.admin-materials-primary-btn{align-items:center;background-color:#16a34a;border:1px solid #16a34a;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:9px 14px;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease;white-space:nowrap}.admin-materials-primary-btn:hover{background-color:#15803d;border-color:#15803d;box-shadow:0 10px 22px #16a34a24}.admin-materials-primary-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.6}.admin-materials-ghost-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:inline-flex;height:38px;justify-content:center;transition:background-color .15s ease,box-shadow .15s ease;width:38px}.admin-materials-ghost-btn:hover{background-color:#f9fafb;box-shadow:0 8px 18px #0f172a0f}.admin-materials-ghost-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.6}.admin-materials-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 18px 40px #0f172a0a;overflow:hidden}.admin-materials-card-head{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;gap:12px;justify-content:space-between;padding:16px 18px}.admin-materials-card-title{color:#111827;font-size:15px;font-weight:700;margin:0}.admin-materials-card-desc{color:#6b7280;font-size:12px;margin:6px 0 0}.admin-materials-card-body{padding:16px 18px 18px}@media (max-width:640px){.admin-materials-card-body,.admin-materials-card-head{padding:14px}}.admin-materials-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.admin-materials-label{color:#6b7280;display:flex;flex-direction:column;font-size:12px;gap:6px;min-width:220px}.admin-materials-select{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;color:#111827;font-size:13px;outline:none;padding:9px 10px;width:100%}.admin-materials-select:focus{background:#fff;border-color:#16a34a8c;box-shadow:0 0 0 2px #16a34a1a}@media (max-width:640px){.admin-materials-label{min-width:100%}}.admin-materials-error{align-items:center;background:#fff1f2;border:1px solid #ef444459;border-radius:12px;color:#7f1d1d;display:flex;font-size:13px;gap:12px;justify-content:space-between;margin:0 0 12px;padding:10px 12px}.admin-materials-error-close{align-items:center;background:#0000;border:none;color:#7f1d1d;cursor:pointer;display:flex;justify-content:center;opacity:.7;padding:4px;transition:opacity .15s ease}.admin-materials-error-close:hover{opacity:1}.admin-materials-empty{color:#6b7280;font-size:13px;margin:6px 0 0}.admin-materials-chip{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;color:#111827;display:inline-flex;font-size:12px;gap:8px;margin-bottom:12px;padding:8px 10px}.admin-materials-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}@media (max-width:640px){.admin-materials-grid{grid-template-columns:minmax(0,1fr)}}.admin-materials-files-section{margin-top:16px}.admin-materials-file,.admin-materials-file-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:14px;display:flex;flex-direction:column;gap:12px;padding:16px;transition:box-shadow .15s ease,border-color .15s ease}.admin-materials-file-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #0f172a14}.admin-materials-file-top{display:flex;gap:12px}.admin-materials-file-icon{align-items:center;background-color:#ecfdf3;border-radius:12px;color:#16a34a;display:flex;flex-shrink:0;height:48px;justify-content:center;position:relative;width:48px}.admin-materials-file-extension{border:1px solid #e5e7eb;border-radius:6px;bottom:-4px;font-size:9px;right:-4px;text-transform:uppercase}.admin-materials-file-ext,.admin-materials-file-extension{background:#fff;color:#111827;font-weight:700;padding:2px 6px;position:absolute}.admin-materials-file-ext{border:1px solid #e5e7eb;border-radius:999px;bottom:-6px;font-size:10px;right:-8px}.admin-materials-file-info{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.admin-materials-file-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#111827;display:-webkit-box;font-size:14px;font-weight:600;line-height:1.4;margin:0;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.admin-materials-file-size{color:#6b7280;font-size:12px;margin:0}.admin-materials-file-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.admin-materials-module{color:#6b7280;font-size:12px;margin:0}.admin-materials-name{color:#111827;font-size:13px;font-weight:700;margin:0;word-break:break-word}.admin-materials-size{color:#6b7280;font-size:12px;margin:2px 0 0}.admin-materials-file-actions{display:flex;gap:8px;margin-top:4px}.admin-materials-file-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:inline-flex;height:36px;justify-content:center;padding:0;transition:all .15s ease;width:36px}.admin-materials-file-btn:hover{box-shadow:0 2px 8px #0f172a1a}.admin-materials-file-download{color:#16a34a}.admin-materials-file-download:hover{background:#ecfdf3;border-color:#16a34a4d}.admin-materials-file-delete{color:#ef4444}.admin-materials-file-delete:hover{background:#fee2e2;border-color:#ef44444d}.admin-materials-actions{display:flex;flex-wrap:wrap;gap:8px}.admin-materials-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:8px;padding:8px 10px;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease}.admin-materials-btn:hover{background-color:#f9fafb;box-shadow:0 8px 18px #0f172a0f}.admin-materials-btn-secondary:hover{border-color:#16a34a59;box-shadow:0 8px 18px #16a34a1a}.admin-materials-btn-danger{border-color:#ef444459}.admin-materials-btn-danger:hover{background-color:#fee2e2;border-color:#ef44448c;box-shadow:0 8px 18px #ef44441a}.admin-materials-modal-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:18px;position:fixed;z-index:2000}.admin-materials-modal{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 22px 70px #0f172a40;max-width:520px;overflow:hidden;width:100%}.admin-materials-modal-head{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;gap:12px;justify-content:space-between;padding:14px 16px}.admin-materials-modal-title{color:#111827;font-size:14px;font-weight:800;margin:0}.admin-materials-modal-subtitle{color:#6b7280;font-size:12px;margin:6px 0 0}.admin-materials-modal-close{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:inline-flex;height:34px;justify-content:center;width:34px}.admin-materials-modal-body{padding:14px 16px 16px}.admin-materials-upload{background:#f9fafb;border:1px dashed #d1d5db;border-radius:14px;cursor:pointer;display:block;padding:14px}.admin-materials-upload input{display:none}.admin-materials-upload span{color:#111827;display:block;font-size:13px}.admin-materials-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}.admin-account-page{display:flex;min-height:100vh}.admin-account-inner{box-sizing:border-box;margin:0 auto;max-width:1180px;padding:24px 32px 40px}.aa-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:12px}.aa-header h1{font-size:22px;font-weight:800;letter-spacing:-.2px;margin:0}.aa-subtitle{color:#64748b;font-size:13px;margin:6px 0 0}.aa-alert{border:1px solid #0000;border-radius:14px;font-size:13px;margin:12px 0 14px;padding:10px 12px}.aa-alert--ok{background:#ecfdf5;border-color:#a7f3d0;color:#047857}.aa-alert--error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.aa-loading{color:#64748b;font-size:13px;padding:14px 0}.aa-grid{align-items:start;grid-template-columns:1.35fr 1fr}.aa-col,.aa-grid{grid-gap:14px;display:grid;gap:14px}.aa-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 14px 30px #0f172a0f;box-sizing:border-box;padding:14px 16px 16px}.aa-card-head{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:10px}.aa-card-title{color:#0f172a;font-size:14px;font-weight:900}.aa-btn,.aa-card-title{align-items:center;display:inline-flex;gap:8px}.aa-btn{background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;cursor:pointer;font-size:13px;padding:8px 12px;transition:background .15s ease,border-color .15s ease,transform .08s ease;white-space:nowrap}.aa-btn:hover{background:#eef2f7;border-color:#dbe3ee}.aa-btn:active{transform:translateY(1px)}.aa-btn-primary{background:#16a34a;border-color:#16a34a;color:#fff}.aa-btn-primary:hover{background:#15803d;border-color:#15803d}.aa-btn-full{justify-content:center;margin-top:6px;width:100%}.aa-btn:disabled{cursor:not-allowed;opacity:.65}.aa-form{grid-gap:10px}.aa-form,.aa-row{display:grid;gap:10px}.aa-row{grid-gap:10px;grid-template-columns:1fr 1fr}.aa-field label{color:#64748b;display:block;font-size:12px;margin-bottom:6px}.aa-field input,.aa-field textarea{background:#fff;border:1px solid #d1d5db;border-radius:12px;box-sizing:border-box;font-size:13px;outline:none;padding:10px 12px;width:100%}.aa-field textarea{resize:vertical}.aa-field input:focus,.aa-field textarea:focus{border-color:#16a34a;box-shadow:0 0 0 2px #16a34a14}.aa-input-icon{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:12px;display:flex;gap:8px;padding:0 10px}.aa-input-icon svg{color:#64748b}.aa-input-icon input{border:none;padding:10px 0}.aa-input-icon input:focus{box-shadow:none}.aa-note{color:#94a3b8;font-size:12px;line-height:1.4;padding-top:2px}@media (max-width:1024px){.admin-account-inner{padding:20px 18px 32px}.aa-grid{grid-template-columns:1fr}}@media (max-width:640px){.admin-account-inner{max-width:100%;padding:16px 12px 24px}.aa-row{grid-template-columns:1fr}}
/*# sourceMappingURL=main.a82c4573.css.map*/