@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;overflow:auto;padding:20px;width:400px}.admin-modal-title{font-size:24px;font-weight:700;line-height:1.2;margin-bottom:8px;overflow:visible;text-overflow:clip;white-space:normal;word-break:break-word}.admin-modal-description{font-size:16px;margin-bottom:8px}.admin-modal-actions{display:flex;gap:10px;justify-content:flex-end}.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{align-items:center;background-color:#00000080;display:flex;height:100vh;justify-content:center;left:0;overflow:auto;position:fixed;top:0;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-height:90vh;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{flex-shrink:0;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;display:grid;gap:20px;grid-template-columns:1fr 1fr}.modal-actions{flex-shrink:0;gap:10px;height:auto;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;width:100%}.progress-fill{background-color:#16a34a;border-radius:4px;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%}.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-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-edit{background-color:#16a34a}.lecturer-task-delete{background-color:#dc2626}.lecturer-task-edit:hover{background-color:#15803d}.lecturer-task-delete:hover{background-color:#b91c1c}.task-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.task-modal-content{background:#fff;border-radius:12px;box-shadow:0 6px 16px #0000004d;max-width:500px;padding:24px;width:100%}.task-modal-content h2{color:#333;font-size:20px;margin-bottom:16px}.task-modal-content label{display:block;font-weight:700;margin-top:8px}.task-modal-content input,.task-modal-content select,.task-modal-content textarea{border:1px solid #ccc;border-radius:6px;font-size:14px;margin-top:2px;padding:8px;width:100%}.task-modal-content textarea{min-height:80px;resize:vertical}.task-modal-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.task-edit-btn{border:none;border-radius:6px;cursor:pointer;padding:8px 16px}.btn-edit-task-secondary{background-color:#ccc;color:#000}.btn-edit-task-secondary:hover{background-color:#aaa}.btn-edit-task-primary{background-color:#16a34a;color:#fff}.btn-edit-task-primary:hover{background-color:#15803d}.grades-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.grades-card-content{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.grades-card-list{border:1px solid #e2e8f0;border-radius:8px;margin-top:2rem}.grades-list-header{grid-gap:1rem;align-items:center;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;display:grid;font-weight:600;gap:1rem;grid-template-columns:1fr 1fr 1fr .5fr .5fr .5fr .5fr;padding:1rem}.loading-text,.no-grades-text{display:flex;justify-content:center;padding-top:2rem}.no-grades-text{font-weight:600}.grades-list-item{grid-gap:1rem;align-items:center;border-bottom:1px solid #e2e8f0;display:grid;gap:1rem;grid-template-columns:1fr 1fr 1fr .5fr .5fr .5fr .5fr;padding:1rem}.grades-name{font-weight:600}.grades-grade{color:#16a34a;font-weight:700}.grades-exam-date{color:#64748b}.modal-backdrop{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{padding:2rem;width:300px}.modal-actions{gap:1rem;justify-content:flex-end;margin-top:1rem}label{margin-bottom:1.5rem}.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}.attendance-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin:1.5rem 0}.control-select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;min-width:160px;padding:8px 12px}.class-attendance-grid{grid-gap:1.5rem;align-items:flex-start;display:grid;gap:1.5rem}.attendance-grid-cols{grid-template-columns:minmax(0,2.6fr) minmax(260px,1fr)}.attendance-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 25px #0f172a0a;padding:1.5rem 1.75rem}.attendance-grid-cols2{grid-column:auto}.attendance-title-grid{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.25rem}.attendance-card-title{font-size:1.25rem;font-weight:600;margin:0}.sessions-attendance-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.attendance-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto;width:100%}.attendance-table{border-collapse:collapse;font-size:14px;min-width:640px;width:100%}.attendance-table-header{background-color:#f8fafc;border-bottom:2px solid #e5e7eb;color:#374151;font-weight:600;padding:12px;text-align:left;white-space:nowrap}.attendance-table-row,.attendance-table-row-button{border-bottom:1px solid #e5e7eb;padding:12px}.attendance-table-row-button{text-align:right}.attendance-table tr:last-child .attendance-table-row,.attendance-table tr:last-child .attendance-table-row-button{border-bottom:none}.course-name-row{font-weight:500}.course-group-row{color:#64748b;font-size:13px}.course-number-row{color:#16a34a;font-weight:600}.attendance-empty,.attendance-loading{color:#6b7280;font-size:14px;padding:16px 12px;text-align:center}.attendance-progress-container{align-items:center;display:flex;gap:10px;white-space:nowrap}.progress-bar{background-color:#e5e7eb;border-radius:6px;flex:1 1;height:10px;min-width:60px;overflow:hidden}.progress-fill{border-radius:6px;height:100%;transition:width .3s ease}.progress-fill.attendance-green{background-color:#16a34a}.progress-fill.attendance-yellow{background-color:#eab308}.progress-fill.attendance-red{background-color:#dc2626}.attendance-label.attendance-green{color:#16a34a;font-weight:600}.attendance-label.attendance-yellow{color:#eab308;font-weight:600}.attendance-label.attendance-red{color:#dc2626;font-weight:600}.attendance-not-checked{color:#6b7280;font-size:14px;font-style:italic;font-weight:500}.btn-attendance{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s}.button-primary-attendance{background-color:#16a34a;box-shadow:0 8px 15px #16a34a40;color:#fff}.button-primary-attendance:hover{background-color:#15803d;box-shadow:0 10px 20px #15803d4d}.button-primary-attendance:disabled{background-color:#9ca3af;box-shadow:none;cursor:default}.button-secondary-attendance{background-color:#f1f5f9;color:#475569}.button-secondary-attendance:hover{background-color:#e2e8f0}.attendance-color{background-color:#fff}.class-attendance-grid>.sessions-attendance-card.attendance-color{border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 25px #0f172a0a;padding:0 0 1rem}.last-attendance{font-size:1.15rem;font-weight:600;margin:0;padding:1.5rem 1.5rem 1rem}.recent-card-grid{display:flex;flex-direction:column;gap:.75rem;padding:0 1.25rem 1rem}.recent-session-card{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:.9rem 1rem}.recent-session-div{align-items:flex-start;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:.4rem}.recent-session-header{color:#1e293b;font-size:14px;font-weight:500}.recent-session-title{color:#64748b;font-size:13px;line-height:1.4;margin-bottom:.4rem}.recent-session-attendance{color:#9ca3af;display:flex;font-size:12px;gap:.5rem;justify-content:space-between}@media (max-width:1024px){.class-attendance-grid{grid-template-columns:minmax(0,1fr)}.attendance-card{padding:1.25rem 1.25rem 1.5rem}.class-attendance-grid>.sessions-attendance-card.attendance-color{margin-top:.5rem}}@media (max-width:640px){.attendance-controls{align-items:stretch;flex-direction:column}.control-select{width:100%}.attendance-title-grid{align-items:flex-start;flex-direction:column}.attendance-table{font-size:13px}.attendance-table-header{padding:10px}.attendance-table-row,.attendance-table-row-button{padding:9px 10px}.recent-session-attendance{align-items:flex-start;flex-direction:column}.recent-session-card{padding:.85rem .9rem}.last-attendance{padding:1.25rem 1.25rem .75rem}}.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-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}}.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{align-items:flex-end;display:flex;flex-direction:column;font-size:12px;gap:6px;justify-content:center}.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}.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-right:.5rem;margin-top:.5rem}.grade-title-details{font-size:24px;font-weight:700;margin-bottom:.5rem}.exam-style{color:#059669;font-style:bold}.assignment-style{color:#2563eb;font-style:bold}.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}
/*# sourceMappingURL=main.7ed3ac48.css.map*/