@import"https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&display=swap";.navbar{background-color:#fff;padding:1rem 2rem;position:fixed;top:0;left:0;right:0;z-index:1000;box-shadow:0 4px 20px #00000014;transition:all .3s ease-in-out}.navbar-container{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:0 1.5rem;position:relative}.navbar-logo{display:flex;align-items:center;color:#007bff;font-size:1.8rem;font-weight:700;text-decoration:none;transition:color .3s ease-in-out}.navbar-logo:hover{color:#0056b3}.logo-container{display:flex;align-items:center}.navbar-logo-image{height:50px;margin-right:12px;transition:transform .3s ease-in-out}.navbar-logo-image:hover{transform:scale(1.1)}.navbar-menu{list-style:none;display:flex;gap:.2rem;margin:0;align-items:center}.navbar-item{display:flex;align-items:center}.navbar-links{color:#333;text-decoration:none;font-size:.95rem;font-weight:500;padding:.5rem .75rem;border-radius:25px;transition:all .3s ease-in-out;position:relative;white-space:nowrap}.navbar-links:hover{background-color:#007bff1a;color:#007bff;transform:translateY(-2px)}.navbar-links.active{background-color:#007bff33;color:#007bff;font-weight:600}@media screen and (max-width: 900px){.navbar-links.active{background-color:#007bff26;color:#007bff;font-weight:700;border-left:4px solid #007bff;border-radius:0 8px 8px 0}}.navbar-links:after{display:none}.navbar-links:hover:after{display:none}.navbar-actions{display:flex;align-items:center;gap:1rem}.hamburger-menu{display:none;flex-direction:column;justify-content:space-between;width:28px;height:22px;background:transparent;border:none;cursor:pointer;z-index:1001;padding:4px;box-sizing:content-box}.hamburger-line{display:block;width:100%;height:4px;background-color:#007bff;border-radius:3px;transition:all .3s ease-in-out;box-sizing:content-box}.hamburger-menu.open .hamburger-line:nth-child(1){transform:translateY(9px) rotate(45deg)}.hamburger-menu.open .hamburger-line:nth-child(2){opacity:0}.hamburger-menu.open .hamburger-line:nth-child(3){transform:translateY(-9px) rotate(-45deg)}.logout-button{background:transparent;border:2px solid #007bff;color:#007bff;font-size:.95rem;font-weight:500;padding:.5rem 1rem;border-radius:25px;cursor:pointer;transition:all .3s ease-in-out;white-space:nowrap;text-decoration:none!important}.logout-button:hover{background-color:#007bff;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d;text-decoration:none!important}.logout-button:active{transform:translateY(0)}.logout-button:after{display:none!important}@media screen and (max-width: 1200px){.navbar-container{max-width:1100px}.navbar-menu{gap:.15rem}.navbar-links{font-size:.9rem;padding:.5rem .65rem}.logout-button{font-size:.9rem;padding:.5rem .9rem}}@media screen and (max-width: 900px){.navbar{padding:1rem 1.5rem}.navbar-logo{font-size:1.5rem}.navbar-logo-image{height:40px}.navbar-menu{display:none;flex-direction:column;width:100%;position:absolute;top:100%;left:0;background-color:#fff;box-shadow:0 4px 20px #00000014;padding:1rem 0 2rem;text-align:center;transition:all .3s ease-in-out;gap:0;max-height:80vh;overflow-y:auto}.navbar-menu.active{display:flex}.navbar-links{display:block;padding:.8rem;font-size:1.1rem;width:100%}.hamburger-menu{display:flex!important;width:28px;height:22px}.hamburger-line{display:block!important;height:4px!important;background-color:#007bff!important}.logout-button{margin:1.5rem auto 1rem;padding:.75rem 2rem;font-size:1rem;display:inline-block;width:auto;min-width:150px}.logout-button:after{display:none!important}}@media screen and (max-width: 768px){.navbar{padding:.8rem 1rem}.navbar-container{padding:0 1rem}.navbar-logo{font-size:1.4rem}.navbar-logo-image{height:35px}.navbar-links{font-size:1rem;padding:.7rem}.hamburger-menu{width:26px;height:20px}.hamburger-line{height:3px!important}.navbar-menu{padding:1rem 0 2.5rem;border-radius:0 0 12px 12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffffa;max-height:85vh;overflow-y:auto}.navbar-item{opacity:0;transform:translateY(-10px);animation:fadeInDown .4s ease forwards}.navbar-menu.active .navbar-item:nth-child(1){animation-delay:.1s}.navbar-menu.active .navbar-item:nth-child(2){animation-delay:.15s}.navbar-menu.active .navbar-item:nth-child(3){animation-delay:.2s}.navbar-menu.active .navbar-item:nth-child(4){animation-delay:.25s}.navbar-menu.active .navbar-item:nth-child(5){animation-delay:.3s}.navbar-links{margin:.3rem 1rem;border-radius:8px;font-weight:600;letter-spacing:.3px}.navbar-links:active{transform:scale(.95)}.logout-button{margin:1.5rem auto;display:block;width:auto;min-width:180px;padding:.75rem 2rem;box-shadow:0 2px 8px #007bff33}}@media screen and (max-width: 480px){.navbar{padding:.6rem .8rem}.navbar-container{padding:0 .8rem}.navbar-logo{font-size:1.3rem}.navbar-logo-image{height:30px}.navbar-links{font-size:.95rem;padding:.6rem}.hamburger-menu{width:24px;height:18px}.hamburger-line{height:3px!important}.logout-button{padding:.5rem 1rem;font-size:.95rem}.navbar-menu{padding:1.2rem 0;gap:.2rem}.navbar-links{margin:.2rem .8rem;padding:.75rem 1rem;font-size:1rem}}@media screen and (max-width: 360px){.navbar{padding:.5rem .6rem}.navbar-container{padding:0 .6rem}.navbar-logo{font-size:1.2rem}.navbar-logo-image{height:28px}.navbar-links{font-size:.9rem;padding:.5rem}.hamburger-menu{width:22px;height:16px}.hamburger-line{height:3px!important}.logout-button{padding:.4rem .8rem;font-size:.9rem}.navbar-menu{padding:1rem 0}.navbar-links{margin:.15rem .6rem;padding:.65rem .8rem;font-size:.95rem}}@media screen and (max-width: 900px){.navbar-menu{max-height:0;overflow:hidden;opacity:0;display:flex;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,padding .4s ease}.navbar-menu.active{max-height:85vh;opacity:1;overflow-y:auto}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media screen and (max-width: 900px){body.menu-open:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000004d;z-index:999;animation:fadeIn .3s ease}}@media screen and (max-width: 900px){.navbar-links,.logout-button{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.hamburger-menu{padding:.5rem;margin:-.5rem}.hamburger-menu:active .hamburger-line{background-color:#0056b3}}.navbar-item{isolation:isolate}@media screen and (min-width: 1400px){.navbar-menu{gap:.3rem}.navbar-links{padding:.5rem .85rem;font-size:1rem}}.notification-bell-container{position:relative}.notification-bell-btn{position:relative;background:transparent;border:none;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .3s ease;color:#333;display:flex;align-items:center;justify-content:center}.notification-bell-btn:hover{background:#667eea1a;color:#667eea}.notification-bell-btn.connected{color:#10b981}.connection-indicator{position:absolute;bottom:4px;right:4px;width:8px;height:8px;background:#10b981;border-radius:50%;border:2px solid white;animation:pulse-green 2s infinite}@keyframes pulse-green{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 4px #10b98100}}.notification-badge{position:absolute;top:2px;right:2px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:.7rem;font-weight:700;padding:.15rem .4rem;border-radius:10px;min-width:18px;text-align:center;box-shadow:0 2px 4px #ef444466;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notification-toast{position:fixed;top:80px;right:20px;width:340px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;display:flex;align-items:flex-start;gap:12px;padding:16px;z-index:9999;animation:slideInRight .4s ease,fadeOut .4s ease 4.6s forwards;border-left:4px solid #667eea}.notification-toast.priority-urgent{border-left-color:#ef4444;background:linear-gradient(to right,#fef2f2,#fff)}.notification-toast.priority-high{border-left-color:#f59e0b;background:linear-gradient(to right,#fffbeb,#fff)}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.toast-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f3f4f6}.toast-content{flex:1;min-width:0}.toast-title{font-weight:600;font-size:.9rem;color:#1f2937;margin-bottom:4px}.toast-message{font-size:.8rem;color:#6b7280;line-height:1.4}.toast-close{flex-shrink:0;background:transparent;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.toast-close:hover{background:#f3f4f6;color:#6b7280}.notification-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:360px;max-height:480px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;display:flex;flex-direction:column;animation:slideDown .3s ease}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-bottom:1px solid #e5e7eb}.notification-header h3{margin:0;font-size:1rem;font-weight:600;color:#1a237e;display:flex;align-items:center;gap:8px}.live-badge{font-size:.6rem;font-weight:700;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:2px 6px;border-radius:4px;animation:pulse-green 2s infinite}.mark-all-read-btn{display:flex;align-items:center;gap:.4rem;background:transparent;border:none;color:#667eea;font-size:.85rem;font-weight:500;cursor:pointer;padding:.4rem .8rem;border-radius:6px;transition:all .2s ease}.mark-all-read-btn:hover{background:#667eea1a}.mark-all-read-btn:disabled{opacity:.5;cursor:not-allowed}.notification-list{flex:1;overflow-y:auto;max-height:360px}.notification-item{display:flex;gap:.625rem;padding:.75rem 1rem;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:all .2s ease;position:relative}.notification-item:hover{background:#f9fafb}.notification-item.unread{background:#f0f4ff}.notification-item.unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(135deg,#667eea,#764ba2)}.notification-item.priority-urgent:before{background:linear-gradient(135deg,#ef4444,#dc2626)}.notification-item.priority-high:before{background:linear-gradient(135deg,#f59e0b,#d97706)}.notification-icon-wrapper{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f3f4f6}.notif-icon{color:#667eea}.notif-icon.attendance{color:#3b82f6}.notif-icon.grades{color:#10b981}.notif-icon.fee{color:#f59e0b}.notif-icon.schedule{color:#8b5cf6}.notif-icon.approval{color:#06b6d4}.notif-icon.alert{color:#ef4444}.notif-icon.announcement{color:#667eea}.notif-icon.detector{color:#f97316}.notif-icon.feedback{color:#8b5cf6}.notif-icon.general{color:#6b7280}.notification-content{flex:1;min-width:0}.notification-title{font-weight:600;font-size:.875rem;color:#1f2937;margin-bottom:.25rem}.notification-message{font-size:.8125rem;color:#6b7280;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.notification-time{font-size:.7rem;color:#9ca3af}.notification-meta{display:flex;align-items:center;gap:8px;margin-top:.25rem}.urgent-tag{font-size:.6rem;font-weight:700;background:#fef2f2;color:#ef4444;padding:2px 6px;border-radius:4px;text-transform:uppercase}.notification-delete-btn{flex-shrink:0;background:#fee2e2;border:none;color:#ef4444;cursor:pointer;width:32px;height:32px;min-width:32px;min-height:32px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;align-self:center}.notification-delete-btn:hover{background:#fecaca;color:#dc2626;transform:scale(1.1)}.no-notifications{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;color:#9ca3af}.no-notifications svg{margin-bottom:.75rem;opacity:.3}.no-notifications p{margin:0;font-size:.875rem;font-weight:500;color:#6b7280}.no-notifications span{font-size:.75rem;color:#9ca3af;margin-top:4px}.notification-footer{padding:.625rem 1rem;border-top:1px solid #e5e7eb;display:flex;justify-content:center}.notification-count{font-size:.75rem;color:#9ca3af}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f3f4f6}.notification-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 768px){.notification-dropdown{width:300px;max-height:420px}.notification-list{max-height:300px}}.home{font-family:Poppins,sans-serif;min-height:100vh;background-color:#f9fafb;color:#333}.hero{height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#e3f2fd,#fff)}.hero-content{text-align:center;padding:0 20px;max-width:850px}.hero-content h1{font-size:3.8rem;font-weight:800;margin-bottom:1.5rem;color:#123456;letter-spacing:1px;animation:fadeInDown 1s ease-out}.hero-content p{font-size:1.3rem;margin-bottom:2rem;color:#4a5568;line-height:1.6;animation:fadeInUp 1s ease-out}.cta-button{display:inline-flex;align-items:center;padding:14px 26px;border:none;border-radius:50px;background:linear-gradient(90deg,#2563eb,#1e40af);color:#fff;font-size:1.1rem;font-weight:700;text-decoration:none;transition:all .3s ease;box-shadow:0 4px 10px #00000026}.cta-button:hover{background:linear-gradient(90deg,#1e40af,#2563eb);transform:translateY(-3px);box-shadow:0 6px 12px #0003}.cta-button:active{transform:scale(.98)}.arrow-icon{margin-left:10px;font-size:1.2rem}.animate-fade-in-down{animation:fadeInDown .8s ease-out}.animate-fade-in-up{animation:fadeInUp .8s ease-out}@media (prefers-reduced-motion: reduce){.animate-fade-in-down,.animate-fade-in-up,.feature-card,.cta-button{animation:none;transition:none}}@media (max-width: 768px){.hero-content h1{font-size:2.8rem}.hero-content p{font-size:1.1rem}.cta-button{font-size:1rem;padding:12px 22px}.features h2{font-size:2.3rem}}@media (max-width: 480px){.hero-content h1{font-size:2.4rem}.hero-content p{font-size:1rem}.cta-button{font-size:.9rem;padding:10px 18px}.features h2{font-size:2rem}}.dashboard-wrapper{background-color:#f8f9fa;min-height:100vh;margin-top:70px;padding:1.5rem}.dashboard-loading,.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:1rem}.dashboard-error{text-align:center;padding:1rem}.dashboard-error p{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:.5rem 0;word-wrap:break-word}.error-message{color:#666;font-size:.9rem;max-width:400px;word-wrap:break-word}.retry-button{margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.retry-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.retry-button:active{transform:translateY(0)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#2196f3;border-radius:50%;animation:spin 1s linear infinite}.spin{animation:spin 1s linear infinite}.no-data{text-align:center;color:#999;padding:2rem;font-style:italic}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem 2rem;border-radius:12px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 15px #667eea4d;color:#fff}.student-info{display:flex;align-items:center;gap:1rem;min-width:0;flex:1}.header-icon{padding:10px;background:#fff3;border-radius:12px;flex-shrink:0}.student-info h1{margin:0;font-size:1.75rem;font-weight:600;color:#fff;word-wrap:break-word;overflow-wrap:break-word}.student-info p{margin:.25rem 0 0;color:#ffffffd9;font-size:.95rem;word-wrap:break-word}.role-badge{padding:8px 16px;border-radius:20px;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;background:#fff3;color:#fff;white-space:nowrap;flex-shrink:0}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:1.5rem}.stat-card{background:#fff;padding:1.25rem;border-radius:12px;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s;min-width:0}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;flex-shrink:0}.stat-info{min-width:0;flex:1}.stat-info h3{margin:0;font-size:1.5rem;font-weight:700;color:#1a1a1a;word-wrap:break-word}.stat-info p{margin:.25rem 0 0;color:#666;font-size:.85rem;word-wrap:break-word}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.25rem}.dashboard-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s;min-width:0}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.wide-card{grid-column:span 2}.card-header{display:flex;align-items:center;gap:.625rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid #f0f0f0}.card-header svg{color:#667eea;flex-shrink:0}.card-header h3{margin:0;color:#1a1a1a;font-size:1rem;font-weight:600;word-wrap:break-word;min-width:0}.risk-metrics{display:flex;gap:1.5rem;flex-wrap:wrap}.main-risk-score{text-align:center;min-width:100px;flex-shrink:0}.score{font-size:3rem;font-weight:700;line-height:1}.score.good{color:#4caf50}.score.warning{color:#ffc107}.score.danger{color:#ff5252}.main-risk-score span{display:block;margin-top:.5rem;color:#666;font-size:.85rem}.risk-breakdown{flex:1;min-width:200px}.metric{margin-bottom:.75rem}.metric>span{display:block;margin-bottom:.25rem;color:#666;font-size:.85rem;text-transform:capitalize;word-wrap:break-word}.progress-bar{height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}.progress{height:100%;border-radius:4px;transition:width .3s ease}.chart-container{width:100%;height:250px;overflow:hidden}.chart-container-small{width:100%;height:200px;overflow:hidden}.subject-scores{display:flex;flex-direction:column;gap:1rem}.subject-score-item{padding-bottom:.75rem;border-bottom:1px solid #f0f0f0}.subject-score-item:last-child{border-bottom:none;padding-bottom:0}.subject-info{display:flex;justify-content:space-between;margin-bottom:.5rem;gap:.5rem;flex-wrap:wrap}.subject-name{color:#1a1a1a;font-weight:500;word-wrap:break-word}.score-details{display:flex;align-items:center;gap:4px;white-space:nowrap}.score-value{color:#2196f3;font-weight:600}.attendance-container{display:flex;align-items:center;justify-content:space-around;padding:.5rem;flex-wrap:wrap;gap:1rem}.attendance-legend{display:flex;flex-direction:column;gap:.75rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#444}.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.deadlines-list{display:flex;flex-direction:column;gap:.75rem}.deadline-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid transparent;transition:background .2s;gap:.75rem;flex-wrap:wrap}.deadline-item:hover{background:#f0f0f0}.deadline-item.priority-high{border-left-color:#ff5252}.deadline-item.priority-medium{border-left-color:#ffc107}.deadline-item.priority-low{border-left-color:#4caf50}.deadline-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.deadline-info .subject{font-weight:500;color:#1a1a1a;word-wrap:break-word}.deadline-info .task{font-size:.85rem;color:#666;word-wrap:break-word}.due-date{color:#ff5252;font-weight:500;font-size:.85rem;white-space:nowrap;flex-shrink:0}.schedule-list{display:flex;flex-direction:column;gap:.75rem}.schedule-item{display:flex;gap:1rem;padding:.75rem;background:#f8f9fa;border-radius:8px;flex-wrap:wrap}.schedule-time{min-width:80px;font-weight:600;color:#667eea;flex-shrink:0}.schedule-details{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.schedule-subject{font-weight:500;color:#1a1a1a;word-wrap:break-word}.schedule-class{font-size:.85rem;color:#666;word-wrap:break-word}.class-attendance-list{display:flex;flex-direction:column;gap:1rem}.class-attendance-item{padding-bottom:.75rem;border-bottom:1px solid #f0f0f0}.class-attendance-item:last-child{border-bottom:none}.class-info{display:flex;justify-content:space-between;margin-bottom:.5rem;gap:.5rem;flex-wrap:wrap}.class-name{font-weight:500;color:#1a1a1a;word-wrap:break-word}.class-stats{font-size:.85rem;color:#666}.attendance-bar-container{display:flex;align-items:center;gap:.75rem}.attendance-bar-container .attendance-bar{flex:1;height:8px;background:#4caf50;border-radius:4px}.attendance-percentage{font-weight:600;color:#4caf50;min-width:45px;flex-shrink:0}.submissions-list{display:flex;flex-direction:column;gap:.75rem}.submission-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8f9fa;border-radius:8px}.submission-avatar{width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;flex-shrink:0}.submission-info{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.submission-student{font-weight:500;color:#1a1a1a;word-wrap:break-word}.submission-assignment{font-size:.85rem;color:#666;word-wrap:break-word}.submission-time{font-size:.8rem;color:#999;flex-shrink:0}.staff-list{display:flex;flex-direction:column;gap:.75rem}.staff-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8f9fa;border-radius:8px}.staff-avatar{width:40px;height:40px;background:linear-gradient(135deg,#11998e,#38ef7d);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;flex-shrink:0}.staff-info{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.staff-name{font-weight:500;color:#1a1a1a;word-wrap:break-word}.staff-stats{font-size:.85rem;color:#666;word-wrap:break-word}.staff-rating{font-weight:600;color:#ffc107;flex-shrink:0}.alerts-list{display:flex;flex-direction:column;gap:.75rem}.alert-item{display:flex;gap:.75rem;padding:.75rem;border-radius:8px}.alert-item.alert-warning{background:#fff3e0}.alert-item.alert-info{background:#e3f2fd}.alert-item.alert-success{background:#e8f5e9}.alert-icon{padding:8px;border-radius:8px;flex-shrink:0}.alert-warning .alert-icon{background:#ffc107;color:#fff}.alert-info .alert-icon{background:#2196f3;color:#fff}.alert-success .alert-icon{background:#4caf50;color:#fff}.alert-content{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.alert-message{font-size:.9rem;color:#1a1a1a;word-wrap:break-word}.alert-time{font-size:.8rem;color:#666}.risk-students-list{display:flex;flex-direction:column;gap:.75rem}.risk-student-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ffebee;border-radius:8px;border-left:4px solid #FF5252;gap:.75rem;flex-wrap:wrap}.risk-student-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.risk-student-name{font-weight:500;color:#1a1a1a;word-wrap:break-word}.risk-student-year{font-size:.85rem;color:#666}.risk-student-stats{text-align:right;flex-shrink:0}.risk-attendance{display:block;font-weight:600;color:#ff5252}.risk-issue{font-size:.8rem;color:#666}.dept-table{overflow-x:auto}.dept-table-header,.dept-table-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:1rem;padding:.75rem 1rem;min-width:600px}.dept-table-header{background:#f8f9fa;border-radius:8px;font-weight:600;color:#666;font-size:.85rem;text-transform:uppercase}.dept-table-row{border-bottom:1px solid #f0f0f0}.dept-table-row:last-child{border-bottom:none}.dept-name{font-weight:600;color:#667eea;word-wrap:break-word}.good-stat{color:#4caf50;font-weight:600}.warning-stat{color:#ffc107;font-weight:600}.top-performers-list{display:flex;flex-direction:column;gap:.75rem}.performer-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8f9fa;border-radius:8px}.performer-rank{width:30px;height:30px;background:linear-gradient(135deg,gold,orange);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0}.performer-info{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.performer-name{font-weight:500;color:#1a1a1a;word-wrap:break-word}.performer-dept{font-size:.85rem;color:#666}.performer-cgpa{font-size:1.25rem;font-weight:700;color:#4caf50;flex-shrink:0}.announcements-list{display:flex;flex-direction:column;gap:.75rem}.announcement-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8f9fa;border-radius:8px;gap:.75rem;flex-wrap:wrap}.announcement-content{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.announcement-title{font-weight:500;color:#1a1a1a;word-wrap:break-word}.announcement-date{font-size:.85rem;color:#666}.announcement-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.badge-event{background:#e3f2fd;color:#1976d2}.badge-academic{background:#f3e5f5;color:#7b1fa2}.badge-achievement{background:#e8f5e9;color:#388e3c}@media (max-width: 1200px){.stats-row{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.wide-card{grid-column:span 1}}@media (max-width: 1024px){.dashboard-wrapper{padding:1.25rem}.dashboard-header{padding:1.25rem 1.75rem}.stats-row{grid-template-columns:repeat(2,1fr);gap:1rem}.wide-card{grid-column:span 1}.chart-container{height:220px}.chart-container-small{height:180px}.dept-table-header,.dept-table-row{grid-template-columns:1.5fr 1fr 1fr .8fr .8fr;gap:.75rem;font-size:.8rem}}@media (max-width: 768px){.dashboard-wrapper{padding:1rem;margin-top:60px}.dashboard-header{flex-direction:column;gap:1rem;text-align:center;padding:1.25rem 1.5rem}.student-info{flex-direction:column;text-align:center}.student-info h1{font-size:1.5rem}.student-info p{font-size:.9rem}.stats-row{grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{padding:1rem;flex-direction:column;text-align:center}.stat-info h3{font-size:1.25rem}.stat-info p{font-size:.8rem}.dashboard-grid{grid-template-columns:1fr}.wide-card{grid-column:span 1}.risk-metrics{flex-direction:column;align-items:center}.main-risk-score,.risk-breakdown{width:100%}.dept-table-header,.dept-table-row{grid-template-columns:1.2fr .8fr .8fr .8fr;font-size:.75rem;min-width:350px;gap:.5rem}.dept-table-header span:nth-child(3),.dept-table-row span:nth-child(3){display:none}.chart-container{height:200px}.chart-container-small{height:160px}.card-header h3{font-size:.95rem}.dashboard-card{padding:1rem}.deadline-item,.announcement-item,.risk-student-item{flex-direction:column;align-items:flex-start}.risk-student-stats{text-align:left}.due-date{align-self:flex-start}}@media (max-width: 480px){.dashboard-wrapper{padding:.75rem;margin-top:55px}.dashboard-header{padding:1rem;border-radius:10px}.student-info h1{font-size:1.25rem}.student-info p{font-size:.85rem}.role-badge{padding:6px 12px;font-size:.75rem}.stats-row{grid-template-columns:1fr;gap:.875rem}.stat-card{padding:.875rem}.stat-icon{padding:10px}.stat-info h3{font-size:1.1rem}.stat-info p{font-size:.75rem}.dashboard-card{padding:1rem;border-radius:10px}.card-header{margin-bottom:1rem;padding-bottom:.625rem}.card-header h3{font-size:.9rem}.score{font-size:2.5rem}.subject-name,.deadline-info .subject,.schedule-subject,.class-name,.submission-student,.staff-name,.alert-message,.risk-student-name,.performer-name,.announcement-title{font-size:.9rem}.subject-info .score-details,.deadline-info .task,.schedule-class,.class-stats,.submission-assignment,.staff-stats,.alert-time,.risk-student-year,.performer-dept,.announcement-date{font-size:.8rem}.submission-time,.risk-issue{font-size:.75rem}.schedule-time{min-width:70px;font-size:.85rem}.submission-avatar,.staff-avatar{width:35px;height:35px;font-size:.9rem}.performer-rank{width:28px;height:28px;font-size:.85rem}.performer-cgpa{font-size:1.1rem}.announcement-badge{font-size:.7rem;padding:3px 8px}.dept-table-header,.dept-table-row{grid-template-columns:1fr .7fr .7fr .7fr;padding:.625rem .75rem;font-size:.7rem;min-width:300px;gap:.4rem}.dept-table-header span:nth-child(3),.dept-table-row span:nth-child(3){display:none}.retry-button{padding:.625rem 1.25rem;font-size:.9rem}.loading-spinner{width:35px;height:35px}.chart-container{height:180px}.chart-container-small{height:150px}}@media (max-width: 360px){.dashboard-wrapper{padding:.625rem}.dashboard-header{padding:.875rem}.student-info h1{font-size:1.15rem}.student-info p{font-size:.8rem}.stat-card{padding:.75rem}.stat-info h3{font-size:1rem}.dashboard-card{padding:.875rem}.score{font-size:2rem}.dept-table-header,.dept-table-row{min-width:280px}}@media (max-width: 900px) and (orientation: landscape){.dashboard-wrapper{margin-top:50px}.stats-row{grid-template-columns:repeat(4,1fr)}.dashboard-grid{grid-template-columns:repeat(2,1fr)}.chart-container{height:200px}}@media (hover: none) and (pointer: coarse){.retry-button,.stat-card,.dashboard-card,.deadline-item,.schedule-item,.submission-item,.staff-item,.alert-item,.risk-student-item,.performer-item,.announcement-item,.dept-table-row{min-height:44px}}@media (prefers-reduced-motion: reduce){.stat-card,.dashboard-card,.retry-button,.deadline-item,.progress{transition:none}.stat-card:hover,.dashboard-card:hover,.retry-button:hover{transform:none}.loading-spinner,.spin{animation:none}}@media print{.dashboard-wrapper{margin:0;padding:1rem;background:#fff}.dashboard-header,.stat-card,.dashboard-card{box-shadow:none;page-break-inside:avoid}.retry-button{display:none}.chart-container,.chart-container-small{page-break-inside:avoid}}.loading-container{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);z-index:9999;animation:fadeIn .3s ease-out}.loading-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-logo-wrapper{position:relative;width:100px;height:100px;display:flex;justify-content:center;align-items:center}.loading-logo{width:60px;height:60px;object-fit:contain;animation:pulse 2s ease-in-out infinite;z-index:2}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.loading-ring{position:absolute;width:90px;height:90px;border:3px solid transparent;border-top:3px solid #1a237e;border-right:3px solid #3949ab;border-radius:50%;animation:spin 1.2s linear infinite}.loading-brand{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#1a237e,#3949ab);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:.5px}.loading-dots{display:flex;gap:6px;margin-top:.5rem}.loading-dots span{width:8px;height:8px;background:linear-gradient(135deg,#1a237e,#3949ab);border-radius:50%;animation:bounce 1.4s ease-in-out infinite}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.loading-text{font-size:.9rem;color:#64748b;margin:0;font-weight:500;letter-spacing:.3px}@media (max-width: 480px){.loading-logo-wrapper{width:80px;height:80px}.loading-logo{width:50px;height:50px}.loading-ring{width:70px;height:70px}.loading-brand{font-size:1.25rem}.loading-dots span{width:6px;height:6px}.loading-text{font-size:.85rem}}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: #e74c3c;--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient( to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55 );--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;padding:4px;width:var(--toastify-toast-width);box-sizing:border-box;color:#fff}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right)}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right)}@media only screen and (max-width : 480px){.Toastify__toast-container{width:100vw;padding:0;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}}.Toastify__toast{--y: 0;position:relative;-ms-touch-action:none;touch-action:none;min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:8px;border-radius:var(--toastify-toast-bd-radius);box-shadow:0 4px 12px #0000001a;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);cursor:default;direction:ltr;z-index:0;overflow:hidden}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{margin:auto 0;-ms-flex:1 1 auto;flex:1 1 auto;padding:6px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.Toastify__toast-body>div:last-child{word-break:break-word;-ms-flex:1;flex:1}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px;width:20px;-ms-flex-negative:0;flex-shrink:0;display:-ms-flexbox;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}@media only screen and (max-width : 480px){.Toastify__toast{margin-bottom:0;border-radius:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;-ms-flex-item-align:start;align-self:flex-start;z-index:1}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:var(--toastify-z-index);opacity:.7;transform-origin:left;border-bottom-left-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial;border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp{position:absolute;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-container{display:flex;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#e6f2ff,#f0f7ff,#e6f2ff);box-sizing:border-box;padding:0;overflow-x:hidden;width:100%;max-width:100vw}.login-content{display:flex;max-width:1600px;width:100%;background:#fff;box-shadow:0 20px 60px #00000026;overflow-x:hidden;position:relative;min-height:100vh}.login-logo-container{position:relative;background:transparent;padding:0;border-radius:0;box-shadow:none;z-index:2;margin-bottom:20px}.login-left{flex:1;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:80px 160px;margin-bottom:0;position:relative;overflow:hidden;min-height:400px}.login-header{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;width:100%;position:relative;z-index:2}.login-logo{width:100px;height:100px;object-fit:contain;display:block;margin:0 auto 20px;background:#fff;padding:15px;border-radius:20px;box-shadow:0 10px 30px #0003;transition:transform .3s ease;position:relative;z-index:2}.login-logo:hover{transform:scale(1.05)}.login-left:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#ffffff0d;transform:skew(-15deg);z-index:1}.login-left:after{content:"";position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%;top:-150px;right:-150px;z-index:1}@media (max-width: 768px){.login-left:before,.login-left:after{display:none}}.login-left h1{font-size:2.5rem;font-weight:700;margin-bottom:15px;position:relative;z-index:2;word-wrap:break-word;max-width:100%;text-shadow:0 2px 10px rgba(0,0,0,.1);letter-spacing:-.5px}.login-left p{font-size:1.1rem;max-width:350px;line-height:1.7;position:relative;z-index:2;opacity:.95;word-wrap:break-word}.login-right{flex:2;padding:70px;display:flex;flex-direction:column;justify-content:center;background:#f9fbff;min-height:100vh}.login-form-container{width:100%;max-width:500px;margin:0 auto}.login-form-container h2{font-size:2rem;margin-bottom:10px;color:#2c3e50;text-align:center;font-weight:700;word-wrap:break-word;letter-spacing:-.5px}.login-subtitle{text-align:center;font-size:1rem;color:#7f8c8d;margin-bottom:30px;font-weight:500;letter-spacing:.3px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;word-wrap:break-word}.login-form{display:flex;flex-direction:column;gap:20px;width:100%}.form-group{display:flex;flex-direction:column;gap:10px;width:100%}.form-group label{font-size:.95rem;color:#34495e;font-weight:600;letter-spacing:.2px}.form-group input,.form-group select{width:100%;padding:12px 16px;border:2px solid #e3e8ef;border-radius:50px;font-size:1rem;transition:all .3s ease;box-sizing:border-box;background-color:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea26;transform:translateY(-1px)}.form-group input:hover,.form-group select:hover{border-color:#b8c5e0}.login-submit-btn,.submit-btn{width:40%;margin:10px auto 0;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d;display:block;letter-spacing:.5px}.login-submit-btn:hover,.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.login-submit-btn:active,.submit-btn:active{transform:translateY(0)}.login-submit-btn:disabled,.submit-btn:disabled{background:linear-gradient(135deg,#a0c4e8,#b8c8e8);cursor:not-allowed;transform:none;opacity:.6}.social-login{display:flex;flex-direction:column;gap:15px;margin-top:20px;width:100%}.google-btn,.facebook-btn{width:40%;margin:0 auto;padding:14px;border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s ease;box-shadow:0 4px 12px #0000001f;letter-spacing:.3px}.google-btn{background:linear-gradient(135deg,#db4437,#c23321);color:#fff}.facebook-btn{background:linear-gradient(135deg,#1877f2,#0d65d9);color:#fff}.google-btn:hover,.facebook-btn:hover{transform:translateY(-2px);box-shadow:0 6px 18px #0000002e}.google-btn:active,.facebook-btn:active{transform:translateY(0)}.login-divider{text-align:center;margin:25px 0;position:relative}.login-divider span{background:#f9fbff;padding:0 15px;color:#95a5a6;position:relative;z-index:1;font-weight:500}.login-divider:before{content:"";width:100%;height:1px;background:linear-gradient(90deg,transparent 0%,#d5dde5 20%,#d5dde5 80%,transparent 100%);position:absolute;top:50%;left:0;z-index:0}.toggle-form{text-align:center;margin-top:20px;font-size:.95rem;color:#7f8c8d}.toggle-form button{background:none;border:none;color:#667eea;font-size:.95rem;cursor:pointer;transition:all .3s ease;font-weight:700;padding:4px 8px}.toggle-form button:hover{text-decoration:underline;color:#764ba2;transform:scale(1.05)}.toggle-form button:active{transform:scale(.98)}@media (max-width: 1024px){.login-left{padding:60px 80px}.login-right{padding:50px}.login-left h1{font-size:2.2rem}.login-left p{font-size:1rem}.login-form-container h2{font-size:1.8rem}}@media (max-width: 900px){.login-content{flex-direction:column;min-height:auto}.login-left{padding:60px 40px;margin-bottom:0;min-height:300px}.login-right{padding:40px;min-height:auto}.login-logo-container{top:20px}.login-logo{width:70px;height:70px;padding:12px;border-radius:16px}.login-submit-btn,.submit-btn,.google-btn,.facebook-btn{width:60%}}@media (max-width: 768px){.login-container{overflow-x:hidden;width:100%;max-width:100vw;background:linear-gradient(135deg,#667eea,#764ba2)}.login-content{flex-direction:column;overflow-x:hidden;min-height:100vh;width:100%;max-width:100%;box-shadow:none;background:transparent}.login-left{padding:40px 20px 30px;min-height:auto;margin-bottom:0;overflow:hidden;width:100%;box-sizing:border-box;background:transparent;color:#fff}.login-left h1{font-size:1.8rem;margin-bottom:10px;letter-spacing:-.3px;color:#fff}.login-left p{font-size:.95rem;max-width:100%;margin-bottom:0;opacity:.95;color:#fff}.login-header{padding-top:0}.login-logo{width:80px;height:80px;margin:0 auto 15px;padding:12px;border-radius:16px;background:#fff;box-shadow:0 8px 25px #0003}.login-right{padding:30px 25px 35px;min-height:auto;width:100%;box-sizing:border-box;border-radius:30px 30px 0 0;background:#fff;margin-top:0;position:relative;z-index:5;flex:1}.login-logo-container{position:relative;transform:none;margin:0 auto 15px;background:transparent;padding:0;box-shadow:none}.login-form-container h2{font-size:1.6rem;margin-bottom:8px}.login-subtitle{font-size:.95rem;margin-bottom:25px}.form-group{gap:8px}.form-group label{font-size:.9rem}.form-group input,.form-group select{padding:13px 16px;font-size:.95rem;border-width:1.5px}.login-submit-btn,.submit-btn,.google-btn,.facebook-btn{width:100%;padding:14px;font-size:.95rem;box-shadow:0 4px 12px #00000026}.toggle-form,.toggle-form button{font-size:.9rem}.login-right{animation:slideUpFade .4s ease-out}.form-group{animation:fadeInUp .5s ease-out}.form-group:nth-child(1){animation-delay:.1s}.form-group:nth-child(2){animation-delay:.2s}.form-group:nth-child(3){animation-delay:.3s}}@media (max-width: 480px){.login-container{padding:0;overflow-x:hidden;width:100%;max-width:100vw}.login-content{overflow-x:hidden;min-height:100vh;width:100%;max-width:100%;background:transparent}.login-left{padding:35px 20px 25px;min-height:auto;overflow:hidden;width:100%;box-sizing:border-box;background:transparent;color:#fff}.login-left h1{font-size:1.5rem;margin-bottom:8px;color:#fff}.login-left p{font-size:.9rem;line-height:1.5;margin-bottom:0;color:#fff}.login-header{padding-top:0}.login-logo{width:70px;height:70px;margin:0 auto 12px;padding:10px;border-radius:14px;background:#fff;box-shadow:0 6px 20px #0003}.login-right{padding:25px 20px 30px;width:100%;box-sizing:border-box;border-radius:25px 25px 0 0;background:#fff;flex:1}.login-logo-container{padding:0;margin:10px auto 12px;background:transparent;box-shadow:none}.login-form-container h2{font-size:1.4rem;margin-bottom:6px}.login-subtitle{font-size:.9rem;margin-bottom:20px}.login-form{gap:16px}.form-group{gap:7px}.form-group label{font-size:.88rem}.form-group input,.form-group select{padding:12px 15px;font-size:.9rem}.login-submit-btn,.submit-btn,.google-btn,.facebook-btn{padding:13px;font-size:.9rem}.social-login{gap:12px;margin-top:16px}.login-divider{margin:18px 0}.login-divider span{padding:0 12px;font-size:.85rem}.toggle-form{margin-top:16px;font-size:.88rem}.toggle-form button{font-size:.88rem}}@media (max-width: 360px){.login-container{overflow-x:hidden}.login-left{padding:30px 16px 20px;overflow:hidden;width:100%;box-sizing:border-box;background:transparent;color:#fff}.login-right{padding:20px 16px 25px;width:100%;box-sizing:border-box;background:#fff;flex:1}.login-logo{width:60px;height:60px;margin-bottom:10px;padding:8px;border-radius:12px;background:#fff;box-shadow:0 5px 15px #0003}.login-left h1{font-size:1.35rem;margin-bottom:6px;color:#fff}.login-left p{font-size:.85rem;color:#fff}.login-form-container h2{font-size:1.3rem}.login-subtitle{font-size:.85rem;margin-bottom:18px}.form-group input,.form-group select{padding:11px 14px;font-size:.88rem}.login-submit-btn,.submit-btn,.google-btn,.facebook-btn{padding:12px;font-size:.88rem}}@media (max-width: 900px) and (orientation: landscape){.login-content{flex-direction:row}.login-left{min-height:100vh;padding:40px 30px;background:linear-gradient(135deg,#667eea,#764ba2)}.login-right{min-height:100vh;padding:30px;border-radius:0;margin-top:0}.login-logo-container{position:relative;margin:0 auto 15px;background:transparent;padding:0;box-shadow:none}.login-logo{width:60px;height:60px}.login-left h1{font-size:1.6rem}.login-left p{font-size:.85rem}}@media (hover: none) and (pointer: coarse){.login-submit-btn,.submit-btn,.google-btn,.facebook-btn,.toggle-form button,.form-group input,.form-group select{min-height:48px}.form-group input,.form-group select{padding:14px 16px}.login-submit-btn:hover,.submit-btn:hover,.google-btn:hover,.facebook-btn:hover{transform:none}.login-submit-btn:active,.submit-btn:active,.google-btn:active,.facebook-btn:active{transform:scale(.98)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.login-logo{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.login-submit-btn,.submit-btn,.google-btn,.facebook-btn,.toggle-form button,.form-group input,.form-group select{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.login-submit-btn:hover,.submit-btn:hover,.google-btn:hover,.facebook-btn:hover{transform:none}}@media print{.login-container{background:#fff}.login-content{box-shadow:none}.social-login,.login-divider,.toggle-form{display:none}.login-left:before,.login-left:after{display:none}}.login-submit-btn.loading,.submit-btn.loading{position:relative;color:transparent;pointer-events:none}.login-submit-btn.loading:after,.submit-btn.loading:after{content:"";position:absolute;width:20px;height:20px;top:50%;left:50%;margin-left:-10px;margin-top:-10px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.crs-courses-container{max-width:1600px;margin-top:60px;margin-left:auto;margin-right:auto;padding:2rem;background-color:#fff;min-height:100vh}.crs-back-button-header{position:absolute;left:20px;top:20px;display:inline-flex;align-items:center;gap:6px;background-color:#fffffff2;color:#333;font-size:14px;font-weight:600;padding:8px 16px;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease-in-out;text-decoration:none;box-shadow:0 2px 8px #00000026;z-index:5}.crs-back-button-header:hover{background-color:#fff;transform:translate(-3px);box-shadow:0 4px 12px #0003}.crs-back-button-header:active{transform:translate(0)}.crs-back-button-header:before{content:"←";font-size:16px;font-weight:700}.crs-courses-header{text-align:center;margin-top:1rem;margin-bottom:3rem;padding:2rem 1rem;background:linear-gradient(135deg,#1a237e,#3949ab);color:#fff;border-radius:16px;box-shadow:0 4px 20px #1a237e26;position:relative}.crs-courses-header h1{font-size:2.8rem;font-weight:700;margin-bottom:1rem;background:linear-gradient(120deg,#fff,#e3f2fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:2px 2px 4px rgba(0,0,0,.1);word-wrap:break-word}.crs-courses-header p{font-size:1.2rem;color:#e3f2fd;max-width:600px;margin:0 auto;word-wrap:break-word;padding:0 1rem}.crs-search-container{margin:2rem auto;max-width:600px;position:relative;padding:0 1rem}.crs-search-input{width:100%;padding:1rem 1.5rem;font-size:1.1rem;border:2px solid #e0e0e0;border-radius:50px;background-color:#fff;transition:all .3s ease;box-shadow:0 2px 10px #0000000d;box-sizing:border-box}.crs-search-input:focus{outline:none;border-color:#1a237e;box-shadow:0 4px 15px #1a237e26}.crs-departments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;padding:1rem 0}.crs-department-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;cursor:pointer}.crs-department-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.crs-department-image{position:relative;height:200px;overflow:hidden}.crs-department-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.crs-department-card:hover .crs-department-image img{transform:scale(1.05)}.crs-department-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,#0003,#0009);display:flex;align-items:flex-start;justify-content:flex-end;padding:1rem}.crs-dept-code{background-color:#1a237e;color:#fff;padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:1.1rem;box-shadow:0 2px 8px #0003}.crs-department-content{padding:1.5rem}.crs-department-content h2{color:#1a237e;font-size:1.4rem;margin-bottom:.8rem;font-weight:600;line-height:1.3;word-wrap:break-word}.crs-department-content p{color:#546e7a;font-size:.95rem;line-height:1.6;margin-bottom:1.2rem;word-wrap:break-word}.crs-semesters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;padding:1rem 0}.crs-semester-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;cursor:pointer}.crs-semester-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.crs-semester-content{padding:1.5rem;text-align:center}.crs-semester-content h2{color:#1a237e;font-size:1.4rem;margin-bottom:.8rem;font-weight:600;word-wrap:break-word}.crs-semester-content p{color:#546e7a;font-size:.95rem;margin-bottom:1.2rem;word-wrap:break-word}.crs-explore-btn{width:100%;padding:.8rem;background:linear-gradient(135deg,#1a237e,#3949ab);color:#fff;border:none;border-radius:50px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.crs-explore-btn:hover{background:linear-gradient(135deg,#0d1757,#2c3a8c);transform:translateY(-2px)}.crs-explore-btn:active{transform:translateY(0)}.crs-subjects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;padding:1rem 0}.crs-subject-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;cursor:pointer}.crs-subject-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.crs-subject-header{background:#1a237e;padding:1rem;text-align:center}.crs-subject-code{color:#fff;font-size:1.2rem;font-weight:600;word-wrap:break-word}.crs-subject-content{padding:1.5rem;text-align:center}.crs-subject-content h2{color:#1a237e;font-size:1.4rem;margin-bottom:.8rem;font-weight:600;word-wrap:break-word}.crs-subject-content p{color:#546e7a;font-size:.95rem;margin-bottom:1.2rem;word-wrap:break-word}.crs-resources-container{padding:2rem;max-width:1350px;margin:0 auto;background-color:#f9fafb;border-radius:12px;box-shadow:0 4px 12px #0000001a}.crs-resource-section{margin-bottom:2.5rem;background-color:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000000d;transition:transform .3s ease,box-shadow .3s ease}.crs-resource-section:hover{transform:translateY(-5px);box-shadow:0 8px 16px #0000001a}.crs-resource-section h2{color:#1a237e;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e8eaf6;position:relative;word-wrap:break-word}.crs-resource-section h2:after{content:"";position:absolute;bottom:-2px;left:0;width:60px;height:2px;background-color:#3949ab}.crs-resource-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.crs-resource-item{background-color:#fff;border-radius:10px;padding:1.5rem;border:1px solid #e8eaf6;transition:all .3s ease;display:flex;flex-direction:column;gap:.75rem;min-width:0}.crs-resource-item:hover{border-color:#3949ab;box-shadow:0 4px 12px #3949ab1a}.crs-resource-item h3{color:#1a237e;font-size:1.2rem;font-weight:600;margin:0;word-wrap:break-word;overflow-wrap:break-word}.crs-resource-item p{color:#546e7a;font-size:.95rem;margin:0;word-wrap:break-word}.crs-resource-btn{background-color:#3949ab;color:#fff;border:none;border-radius:6px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:center;text-transform:uppercase;letter-spacing:.5px;margin-top:.5rem}.crs-resource-btn:hover{background-color:#283593;transform:translateY(-2px);box-shadow:0 4px 8px #3949ab33}.crs-resource-btn:active{transform:translateY(0);box-shadow:none}.crs-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:1rem}.crs-modal-content{background-color:#fff;padding:30px;border-radius:20px;width:450px;max-width:95%;box-shadow:0 15px 30px #00000026;transition:all .3s ease;position:relative;overflow:hidden}.crs-modal-content h2{margin-bottom:25px;text-align:center;color:#2c3e50;font-weight:600;letter-spacing:-.5px;word-wrap:break-word}.crs-modal-content form{display:flex;flex-direction:column;gap:15px}.crs-modal-content input{padding:12px 15px;border:2px solid #e0e0e0;border-radius:50px;font-size:14px;transition:all .3s ease;width:100%;box-sizing:border-box}.crs-modal-content input:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 3px #4285f433}.crs-modal-actions{display:flex;justify-content:space-between;margin-top:20px;gap:15px}.crs-modal-actions button{flex-grow:1;padding:12px 20px;border:none;border-radius:50px;cursor:pointer;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease}.crs-modal-actions button:first-child{background-color:#4caf50;color:#fff;box-shadow:0 4px 10px #4caf504d}.crs-modal-actions button:first-child:hover{background-color:#45a049;transform:translateY(-2px)}.crs-modal-actions button:first-child:active{transform:translateY(0)}.crs-modal-actions button:last-child{background-color:#f44336;color:#fff;box-shadow:0 4px 10px #f443364d}.crs-modal-actions button:last-child:hover{background-color:#d32f2f;transform:translateY(-2px)}.crs-modal-actions button:last-child:active{transform:translateY(0)}.crs-loading{text-align:center;font-size:1.5rem;color:#1a237e;margin-top:2rem;padding:3rem}.crs-resource-upload-controls{background-color:#f8f9fa;border-radius:12px;padding:25px;margin:25px 0;box-shadow:0 4px 8px #00000014;border:1px solid #e1e6eb}.crs-resource-upload-controls h3{color:#1a5f7a;margin-bottom:20px;font-size:1.4rem;font-weight:700;border-bottom:2px solid #3498db;padding-bottom:10px;word-wrap:break-word}.crs-upload-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:20px}.crs-upload-btn{background-color:#3949ab;color:#fff;width:100%;border:none;border-radius:50px;padding:12px 25px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;text-align:center;min-height:50px;text-transform:uppercase;letter-spacing:.5px;box-sizing:border-box}.crs-upload-btn:hover{background-color:#283593;transform:translateY(-3px);box-shadow:0 5px 10px #00000026}.crs-upload-btn:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.crs-no-resources{text-align:center;padding:3rem 2rem;background-color:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.crs-no-resources p{color:#6c757d;font-size:1rem;margin:.5rem 0;word-wrap:break-word}.crs-no-resources p:first-child{font-size:1.1rem;font-weight:600;color:#495057}.crs-uploaded-by{font-size:.85rem!important;color:#7e57c2!important;font-style:italic;margin-top:.5rem!important}@media screen and (max-width: 1200px){.crs-departments-grid,.crs-subjects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.crs-semesters-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media screen and (max-width: 1024px){.crs-courses-container{padding:1.5rem}.crs-courses-header h1{font-size:2.4rem}.crs-courses-header p{font-size:1.1rem}.crs-resource-list{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.crs-upload-buttons{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media screen and (max-width: 768px){.crs-courses-container{padding:1rem;margin-top:60px}.crs-back-button-header{left:10px;top:10px;font-size:11px;padding:4px 12px;gap:3px}.crs-back-button-header:before{font-size:12px}.crs-courses-header{padding:1.5rem 1rem;margin-bottom:2rem}.crs-courses-header h1{font-size:2rem}.crs-courses-header p{font-size:1rem}.crs-search-container{margin:1.5rem auto}.crs-search-input{padding:.8rem 1.2rem;font-size:1rem}.crs-departments-grid,.crs-semesters-grid,.crs-subjects-grid{grid-template-columns:1fr;gap:1.5rem}.crs-department-image{height:150px}.crs-department-content,.crs-semester-content,.crs-subject-content{padding:1.25rem}.crs-department-content h2,.crs-semester-content h2,.crs-subject-content h2{font-size:1.2rem}.crs-department-content p,.crs-semester-content p,.crs-subject-content p{font-size:.9rem}.crs-dept-code{font-size:1rem;padding:.4rem .8rem}.crs-resources-container{padding:1rem}.crs-resource-section{padding:1rem;margin-bottom:2rem}.crs-resource-section h2{font-size:1.3rem}.crs-resource-list{grid-template-columns:1fr;gap:1rem}.crs-resource-item{padding:1.25rem}.crs-resource-item h3{font-size:1.1rem}.crs-resource-upload-controls{padding:20px}.crs-resource-upload-controls h3{font-size:1.25rem}.crs-upload-buttons{grid-template-columns:1fr;gap:15px}.crs-modal-content{width:90%;padding:20px}.crs-modal-content h2{font-size:1.3rem;margin-bottom:20px}.crs-modal-content input{font-size:13px}.crs-modal-actions button{padding:10px 15px;font-size:.9rem}}@media screen and (max-width: 480px){.crs-courses-container{padding:.75rem;margin-top:55px}.crs-back-button-header{left:8px;top:8px;font-size:10px;padding:6px 12px;gap:2px}.crs-back-button-header:before{font-size:11px}.crs-courses-header{padding:1.25rem .75rem;padding-top:45px;margin-bottom:1.5rem}.crs-courses-header h1{font-size:1.75rem}.crs-courses-header p{font-size:.9rem}.crs-search-container{margin:1rem auto}.crs-search-input{padding:.7rem 1rem;font-size:.9rem}.crs-departments-grid,.crs-semesters-grid,.crs-subjects-grid{gap:1rem}.crs-department-image{height:120px}.crs-department-content,.crs-semester-content,.crs-subject-content{padding:1rem}.crs-department-content h2,.crs-semester-content h2,.crs-subject-content h2{font-size:1.1rem}.crs-department-content p,.crs-semester-content p,.crs-subject-content p{font-size:.85rem}.crs-dept-code{font-size:.9rem;padding:.35rem .7rem}.crs-subject-code{font-size:1.1rem}.crs-explore-btn{padding:.7rem;font-size:.95rem}.crs-resources-container{padding:.75rem}.crs-resource-section{padding:.875rem;margin-bottom:1.5rem}.crs-resource-section h2{font-size:1.15rem;margin-bottom:1rem}.crs-resource-item{padding:1rem}.crs-resource-item h3{font-size:1rem}.crs-resource-item p{font-size:.875rem}.crs-resource-btn{padding:.65rem 1.25rem;font-size:.85rem}.crs-resource-upload-controls{padding:15px;margin:20px 0}.crs-resource-upload-controls h3{font-size:1.15rem;margin-bottom:15px}.crs-upload-buttons{gap:12px}.crs-upload-btn{padding:10px 20px;font-size:.85rem;min-height:44px}.crs-modal-content{padding:15px}.crs-modal-content h2{font-size:1.2rem;margin-bottom:15px}.crs-modal-content input{padding:10px 12px;font-size:12px}.crs-modal-actions{flex-direction:column;gap:10px}.crs-modal-actions button{width:100%;padding:10px;font-size:.85rem}.crs-no-resources{padding:2rem 1rem}.crs-no-resources p{font-size:.9rem}.crs-no-resources p:first-child{font-size:1rem}.crs-loading{font-size:1.2rem;padding:2rem}}@media screen and (max-width: 360px){.crs-courses-container{padding:.625rem}.crs-back-button-header{left:6px;top:6px;font-size:9px;padding:3px 8px;gap:2px}.crs-back-button-header:before{font-size:10px}.crs-courses-header{padding-top:40px}.crs-courses-header h1{font-size:1.5rem}.crs-courses-header p{font-size:.85rem}.crs-search-input{padding:.6rem .9rem;font-size:.85rem}.crs-department-content h2,.crs-semester-content h2,.crs-subject-content h2{font-size:1rem}.crs-department-content p,.crs-semester-content p,.crs-subject-content p{font-size:.8rem}.crs-resource-section h2,.crs-resource-upload-controls h3{font-size:1.05rem}}@media screen and (max-width: 900px) and (orientation: landscape){.crs-courses-container{margin-top:50px}.crs-departments-grid,.crs-semesters-grid,.crs-subjects-grid{grid-template-columns:repeat(2,1fr)}.crs-department-image{height:140px}}@media (hover: none) and (pointer: coarse){.crs-back-button-header,.crs-explore-btn,.crs-resource-btn,.crs-upload-btn,.crs-modal-actions button,.crs-search-input,.crs-modal-content input{min-height:44px}}@media (prefers-reduced-motion: reduce){.crs-department-card,.crs-semester-card,.crs-subject-card,.crs-resource-section,.crs-resource-item,.crs-back-button-header,.crs-explore-btn,.crs-resource-btn,.crs-upload-btn,.crs-modal-actions button,.crs-search-input,.crs-modal-content input,.crs-department-image img{transition:none}.crs-department-card:hover,.crs-semester-card:hover,.crs-subject-card:hover,.crs-resource-section:hover,.crs-back-button-header:hover,.crs-explore-btn:hover,.crs-resource-btn:hover,.crs-upload-btn:hover,.crs-department-card:hover .crs-department-image img{transform:none}}@media print{.crs-courses-container{margin:0;padding:1rem}.crs-back-button-header,.crs-search-container,.crs-explore-btn,.crs-resource-btn,.crs-upload-btn,.crs-resource-upload-controls,.crs-modal-overlay{display:none}.crs-department-card,.crs-semester-card,.crs-subject-card,.crs-resource-section{box-shadow:none;page-break-inside:avoid}.crs-courses-header{box-shadow:none}}.pro-profile-container{max-width:1200px;margin:100px auto 40px;padding:0 20px}.pro-loading{text-align:center;padding:60px;color:#666;font-size:1.1rem}.pro-profile-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:30px;display:flex;align-items:center;gap:24px;margin-bottom:24px;box-shadow:0 4px 20px #667eea4d}.pro-profile-picture{flex-shrink:0}.pro-avatar{width:100px;height:100px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:#fff;border:4px solid rgba(255,255,255,.3)}.pro-header-info{flex:1;min-width:0}.pro-header-info h1{margin:0;color:#fff;font-size:1.75rem;font-weight:600;word-wrap:break-word}.pro-role-badge{display:inline-block;background:#fff3;color:#fff;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600;margin:8px 0;text-transform:uppercase;letter-spacing:.5px}.pro-department{color:#ffffffd9;margin:0;font-size:.95rem;word-wrap:break-word}.pro-edit-button{background:#fff;color:#667eea;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem;white-space:nowrap}.pro-edit-button:hover{background:#f0f0f0;transform:translateY(-2px)}.pro-edit-button:active{transform:translateY(0)}.pro-profile-content{display:flex;flex-direction:column;gap:20px}.pro-profile-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000f}.pro-profile-section h2{margin:0 0 20px;color:#1a1a1a;font-size:1.1rem;font-weight:600;padding-bottom:12px;border-bottom:2px solid #f0f0f0;word-wrap:break-word}.pro-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.pro-info-item{display:flex;flex-direction:column;gap:6px}.pro-info-item label{font-size:.85rem;color:#666;font-weight:500}.pro-info-item span{font-size:1rem;color:#1a1a1a;padding:10px 0;word-wrap:break-word;overflow-wrap:break-word}.pro-info-item input,.pro-info-item select{padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:1rem;color:#1a1a1a;transition:border-color .2s,box-shadow .2s;width:100%;box-sizing:border-box}.pro-info-item input:focus,.pro-info-item select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.pro-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.pro-list li{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f8f9fa;border-radius:8px;color:#1a1a1a;word-wrap:break-word;gap:12px}.pro-list li.pro-empty{color:#999;font-style:italic;justify-content:center}.pro-remove-button{background:#ff5252;color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}.pro-remove-button:hover{background:#d32f2f}.pro-remove-button:active{transform:scale(.95)}.pro-add-item{display:flex;gap:10px;margin-top:12px}.pro-add-item input{flex:1;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:.95rem;min-width:0}.pro-add-item input:focus{outline:none;border-color:#667eea}.pro-add-item button{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.pro-add-item button:hover{background:#5a6fd6}.pro-add-item button:active{transform:scale(.98)}@media (max-width: 1024px){.pro-profile-container{max-width:100%;margin:80px auto 30px;padding:0 16px}.pro-profile-header{padding:24px;gap:20px}.pro-info-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.pro-profile-section{padding:20px}}@media (max-width: 768px){.pro-profile-container{margin-top:70px;padding:0 12px}.pro-profile-header{flex-direction:column;text-align:center;padding:20px;gap:16px}.pro-header-info{text-align:center}.pro-header-info h1{font-size:1.5rem}.pro-avatar{width:80px;height:80px;font-size:2rem}.pro-edit-button{width:100%;max-width:300px}.pro-profile-section{padding:16px;border-radius:10px}.pro-profile-section h2{font-size:1rem;margin-bottom:16px}.pro-info-grid{grid-template-columns:1fr;gap:14px}.pro-list li{padding:10px 12px;flex-wrap:wrap}.pro-add-item{flex-direction:column;gap:8px}.pro-add-item button{width:100%}.pro-loading{padding:40px 20px;font-size:1rem}}@media (max-width: 480px){.pro-profile-container{margin-top:60px;margin-bottom:20px;padding:0 10px}.pro-profile-header{padding:16px;border-radius:12px}.pro-header-info h1{font-size:1.3rem}.pro-role-badge{font-size:.75rem;padding:3px 10px}.pro-department{font-size:.9rem}.pro-avatar{width:70px;height:70px;font-size:1.75rem;border:3px solid rgba(255,255,255,.3)}.pro-edit-button{padding:10px 20px;font-size:.9rem}.pro-profile-section{padding:14px;border-radius:8px}.pro-profile-section h2{font-size:.95rem;margin-bottom:14px}.pro-info-item label{font-size:.8rem}.pro-info-item span,.pro-info-item input,.pro-info-item select{font-size:.95rem;padding:9px 12px}.pro-list li{padding:9px 10px;font-size:.95rem}.pro-remove-button{width:22px;height:22px;font-size:.9rem}.pro-add-item input{padding:9px 12px;font-size:.9rem}.pro-add-item button{padding:9px 16px;font-size:.9rem}}@media (max-width: 360px){.pro-profile-container{padding:0 8px}.pro-header-info h1{font-size:1.2rem}.pro-avatar{width:60px;height:60px;font-size:1.5rem}.pro-profile-section{padding:12px}.pro-info-grid{gap:12px}}@media (hover: none) and (pointer: coarse){.pro-edit-button,.pro-add-item button,.pro-remove-button{min-height:44px}.pro-remove-button{min-width:44px;width:44px;height:44px}.pro-info-item input,.pro-info-item select{min-height:44px}}@media (max-width: 768px) and (orientation: landscape){.pro-profile-container{margin-top:50px}.pro-profile-header{flex-direction:row;text-align:left;padding:20px}.pro-header-info{text-align:left}.pro-avatar{width:70px;height:70px;font-size:1.75rem}.pro-edit-button{width:auto}}@media print{.pro-profile-container{margin:0;padding:0}.pro-edit-button,.pro-add-item,.pro-remove-button{display:none}.pro-profile-header,.pro-profile-section{box-shadow:none;page-break-inside:avoid}}.learning-room{height:90vh;width:100%;display:flex;flex-direction:column;background-color:#fff;font-family:Inter,system-ui,-apple-system,sans-serif;margin-top:70px}.room-header{padding:1.5rem 2rem;background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 2px 4px #0000000d}.room-header-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.room-header-info{display:flex;align-items:center;gap:1rem}.room-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#1a1a1a}.course-code{font-size:.875rem;color:#4a5568;background-color:#f3f4f6;padding:.25rem .75rem;border-radius:4px;font-weight:500}.room-header-stats{display:flex;align-items:center;gap:1rem}.room-status{font-size:.875rem;color:#059669;background-color:#ecfdf5;padding:.375rem 1rem;border-radius:9999px;font-weight:500}.participant-count{font-size:.875rem;color:#4b5563;background-color:#f3f4f6;padding:.375rem 1rem;border-radius:9999px;font-weight:500}.room-header-subtitle{font-size:.875rem;color:#6b7280}.chat-area{flex:1;overflow-y:auto;padding:2rem;background-color:#f9fafb;background-image:linear-gradient(rgba(255,255,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.1) 1px,transparent 1px);background-size:20px 20px}.messages-container{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.message-group{display:flex;margin-bottom:.25rem}.message-wrapper{display:flex;gap:1rem;max-width:70%;animation:fadeSlideIn .3s ease-out forwards}.own-message{justify-content:flex-end}.own-message .message-wrapper{flex-direction:row-reverse}.avatar{width:2.75rem;height:2.75rem;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;color:#fff;flex-shrink:0;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease}.avatar:hover{transform:scale(1.05)}.system{background:linear-gradient(135deg,#4b5563,#374151)}.instructor{background:linear-gradient(135deg,#1d4ed8,#1e40af)}.student{background:linear-gradient(135deg,#059669,#047857)}.message-content{display:flex;flex-direction:column;gap:.375rem}.message-info{display:flex;gap:.75rem;align-items:center}.own-message .message-info{justify-content:flex-end}.sender{font-size:.875rem;font-weight:600;color:#374151}.timestamp{font-size:.75rem;color:#6b7280}.message-bubble{background-color:#fff;padding:1rem 1.25rem;border-radius:12px;font-size:.9375rem;line-height:1.6;color:#1f2937;box-shadow:0 2px 4px #0000000d;border:1px solid #e5e7eb;white-space:pre-wrap}.own-message .message-bubble{background-color:#059669;color:#fff;border:none;box-shadow:0 2px 4px #05966933}.cr-input-area{padding:1.5rem;background-color:#fff;border-top:1px solid #e5e7eb}.cr-input-container{max-width:800px;margin:0 auto;display:flex;gap:1rem;align-items:flex-end;background-color:#f9fafb;border-radius:50px;padding:.75rem;border:1px solid #e5e7eb;transition:all .2s ease}.cr-input-container:focus-within{border-color:#059669;box-shadow:0 0 0 2px #0596691a}.message-input{flex:1;border:none;background:transparent;font-size:.9375rem;padding:.75rem;color:#1f2937;min-width:0;resize:none;max-height:150px;line-height:1.5;font-family:inherit}.message-input::placeholder{color:#9ca3af}.message-input:focus{outline:none}.send-button{background-color:#f3f4f6;color:#6b7280;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:100px}.send-button.active{background-color:#059669;color:#fff}.send-button.active:hover{background-color:#047857;transform:translateY(-1px)}.send-button:disabled{cursor:not-allowed;opacity:.5}.input-info{text-align:center;font-size:.75rem;color:#6b7280;margin-top:.5rem;max-width:900px;margin:.5rem auto 0}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:translateY(0)}}.chat-area::-webkit-scrollbar{width:.5rem}.chat-area::-webkit-scrollbar-track{background:#f9fafb}.chat-area::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:.25rem}.chat-area::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}.gr-batch-container,.gr-dept-container,.gr-student-container,.gr-grades-container,.gr-student-grades-container{padding:32px;max-width:1600px;margin:70px auto 40px;background-color:#f8fafc;min-height:calc(100vh - 70px)}.gr-main-title{font-size:2rem;color:#0f172a;margin-bottom:8px;font-weight:700;word-wrap:break-word}.gr-subtitle{color:#64748b;font-size:1rem;margin-bottom:32px;word-wrap:break-word}.gr-loading{text-align:center;padding:60px;color:#64748b;font-size:1.1rem}.gr-error{text-align:center;padding:40px;color:#dc2626;background:#fef2f2;border-radius:12px;margin:20px 0;word-wrap:break-word}.gr-no-data{text-align:center;padding:40px;color:#64748b;background:#f8fafc;border-radius:12px;word-wrap:break-word}.gr-header{display:flex;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}.gr-header-content{flex:1;min-width:0}.gr-header-content h1{font-size:1.75rem;color:#0f172a;margin:0 0 4px;word-wrap:break-word}.gr-back-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;color:#64748b;font-weight:500;transition:all .2s;white-space:nowrap;flex-shrink:0}.gr-back-btn:hover{background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.gr-back-btn:active{transform:scale(.98)}.gr-batch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.gr-batch-card{background:#fff;padding:28px;border-radius:16px;box-shadow:0 2px 8px #0000000f;cursor:pointer;transition:all .3s;border:2px solid transparent;text-align:center;min-width:0}.gr-batch-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:#667eea}.gr-batch-icon{margin-bottom:16px;color:#667eea}.gr-batch-card h2{color:#0f172a;font-size:1.25rem;margin:0 0 8px;word-wrap:break-word}.gr-batch-description{color:#64748b;font-size:.9rem;margin:0;word-wrap:break-word}.gr-dept-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.gr-dept-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000000f;cursor:pointer;transition:all .3s;text-align:center;border:2px solid transparent;min-width:0}.gr-dept-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#667eea}.gr-dept-icon{margin-bottom:12px;color:#667eea}.gr-dept-card h3{color:#0f172a;font-size:1rem;margin:0 0 4px;word-wrap:break-word}.gr-dept-card p{color:#64748b;font-size:.85rem;margin:0;word-wrap:break-word}.gr-filter-section{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}.gr-search-bar{flex:1;min-width:250px;display:flex;align-items:center;gap:10px;padding:10px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:8px}.gr-search-bar input{flex:1;border:none;outline:none;font-size:.95rem;color:#0f172a;min-width:0}.gr-search-bar svg{color:#94a3b8;flex-shrink:0}.gr-download-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#10b981;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap}.gr-download-btn:hover{background:#059669}.gr-download-btn:active{transform:scale(.98)}.gr-student-list{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.gr-student-list-header{display:grid;grid-template-columns:1fr 2fr 1fr .8fr .8fr;gap:16px;padding:14px 20px;background:#f8fafc;font-weight:600;font-size:.8rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.gr-student-list-item{display:grid;grid-template-columns:1fr 2fr 1fr .8fr .8fr;gap:16px;padding:16px 20px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .2s;font-size:.95rem;color:#334155}.gr-student-list-item:hover{background:#f8fafc}.gr-student-list-item:last-child{border-bottom:none}.gr-student-list-header>div,.gr-student-list-item>div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gr-cgpa{font-weight:600;color:#667eea}.gr-student-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:30px;display:flex;align-items:center;gap:24px;margin-bottom:24px;color:#fff;box-shadow:0 4px 20px #667eea4d}.gr-student-avatar{width:80px;height:80px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gr-student-info{flex:1;min-width:0}.gr-student-info h1,.gr-student-info h2{margin:0 0 8px;font-size:1.75rem;color:#fff;word-wrap:break-word}.gr-student-info p{margin:4px 0;color:#ffffffd9;font-size:.95rem;word-wrap:break-word}.gr-cgpa-display{text-align:center;background:#ffffff26;padding:16px 24px;border-radius:12px;flex-shrink:0}.gr-cgpa-label{display:block;font-size:.85rem;color:#fffc;margin-bottom:4px}.gr-cgpa-value{display:block;font-size:2.5rem;font-weight:700}.gr-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.gr-summary-card{background:#fff;padding:20px;border-radius:12px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000f;min-width:0}.gr-summary-card svg{color:#667eea;flex-shrink:0}.gr-summary-card-content{flex:1;min-width:0}.gr-summary-card h3{margin:0;font-size:1.5rem;color:#0f172a}.gr-summary-card p{margin:4px 0 0;color:#64748b;font-size:.85rem;word-wrap:break-word}.gr-semesters-container{margin-top:24px}.gr-semesters-container>h2{font-size:1.25rem;color:#0f172a;margin:0 0 20px;word-wrap:break-word}.gr-semester-card{background:#fff;border-radius:12px;margin-bottom:20px;overflow:visible;box-shadow:0 2px 8px #0000000f}.gr-semester-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f8fafc;border-bottom:1px solid #e2e8f0;gap:16px;flex-wrap:wrap}.gr-semester-header h3{margin:0;color:#0f172a;font-size:1.1rem;word-wrap:break-word;flex:1;min-width:0}.gr-semester-stats{display:flex;gap:16px;flex-wrap:wrap}.gr-semester-gpa{font-weight:600;color:#667eea;white-space:nowrap}.gr-semester-credits{color:#64748b;white-space:nowrap}.gr-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.gr-grades-table{width:100%;border-collapse:collapse;min-width:500px}.gr-grades-table th,.gr-grades-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #f1f5f9}.gr-grades-table th{font-weight:600;color:#64748b;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;background:#fff;white-space:nowrap}.gr-grades-table td{color:#334155;font-size:.95rem}.gr-grades-table tr:last-child td{border-bottom:none}.gr-grade-pill{display:inline-block;padding:4px 12px;border-radius:20px;color:#fff;font-weight:600;font-size:.85rem;white-space:nowrap}.gr-no-semesters{text-align:center;padding:60px;background:#fff;border-radius:12px;color:#64748b}.gr-page-title{font-size:2rem;color:#0f172a;margin-bottom:8px;font-weight:700;word-wrap:break-word}@media (max-width: 1024px){.gr-batch-container,.gr-dept-container,.gr-student-container,.gr-grades-container,.gr-student-grades-container{padding:24px}.gr-batch-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.gr-dept-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.gr-summary-cards{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.gr-student-list-header,.gr-student-list-item{grid-template-columns:1fr 2fr 1fr .8fr;gap:12px}.gr-student-list-header>div:nth-child(5),.gr-student-list-item>div:nth-child(5){display:none}}@media (max-width: 768px){.gr-batch-container,.gr-dept-container,.gr-student-container,.gr-grades-container,.gr-student-grades-container{padding:20px;margin-top:60px}.gr-main-title,.gr-page-title{font-size:1.75rem}.gr-subtitle{font-size:.95rem;margin-bottom:24px}.gr-header{flex-direction:column;align-items:flex-start}.gr-header-content h1{font-size:1.5rem}.gr-back-btn{align-self:flex-start}.gr-batch-grid{grid-template-columns:1fr;gap:16px}.gr-batch-card{padding:24px}.gr-batch-card h2{font-size:1.15rem}.gr-dept-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.gr-dept-card{padding:20px}.gr-student-header{flex-direction:column;text-align:center;padding:20px}.gr-student-avatar{width:70px;height:70px}.gr-student-info{text-align:center}.gr-student-info h1,.gr-student-info h2{font-size:1.5rem}.gr-student-info p{font-size:.9rem}.gr-cgpa-display{width:100%;max-width:200px}.gr-cgpa-value{font-size:2.25rem}.gr-summary-cards{grid-template-columns:1fr;gap:12px}.gr-summary-card{padding:16px}.gr-summary-card h3{font-size:1.35rem}.gr-semester-header{flex-direction:column;align-items:flex-start}.gr-semester-header h3{font-size:1rem}.gr-semester-stats{width:100%;justify-content:flex-start}.gr-student-list-header,.gr-student-list-item{grid-template-columns:1fr 1.5fr .8fr;font-size:.85rem;padding:12px 16px;gap:10px}.gr-student-list-header>div:nth-child(3),.gr-student-list-item>div:nth-child(3){display:none}.gr-filter-section{flex-direction:column;gap:12px}.gr-search-bar{width:100%;min-width:unset}.gr-download-btn{width:100%;justify-content:center}.gr-grades-table{min-width:480px}.gr-grades-table th,.gr-grades-table td{padding:10px 8px;font-size:.85rem}.gr-grade-pill{font-size:.8rem;padding:3px 10px}.gr-semesters-container>h2{font-size:1.15rem}.gr-loading{padding:40px 20px;font-size:1rem}.gr-error,.gr-no-data,.gr-no-semesters{padding:30px 20px}}@media (max-width: 480px){.gr-batch-container,.gr-dept-container,.gr-student-container,.gr-grades-container,.gr-student-grades-container{padding:15px;margin-top:55px}.gr-main-title,.gr-page-title{font-size:1.5rem}.gr-subtitle{font-size:.9rem}.gr-header-content h1{font-size:1.35rem}.gr-back-btn{padding:8px 14px;font-size:.9rem}.gr-batch-card{padding:20px}.gr-batch-card h2{font-size:1.1rem}.gr-batch-description{font-size:.85rem}.gr-dept-grid{grid-template-columns:1fr}.gr-dept-card{padding:18px}.gr-dept-card h3{font-size:.95rem}.gr-dept-card p{font-size:.8rem}.gr-student-header{padding:16px}.gr-student-avatar{width:60px;height:60px;font-size:1.5rem}.gr-student-info h1,.gr-student-info h2{font-size:1.25rem}.gr-student-info p{font-size:.85rem}.gr-cgpa-display{padding:12px 20px}.gr-cgpa-label{font-size:.8rem}.gr-cgpa-value{font-size:2rem}.gr-summary-card{padding:14px}.gr-summary-card h3{font-size:1.25rem}.gr-summary-card p{font-size:.8rem}.gr-semester-header{padding:14px 16px}.gr-semester-header h3{font-size:.95rem}.gr-semester-gpa,.gr-semester-credits{font-size:.85rem}.gr-student-list-header,.gr-student-list-item{grid-template-columns:1fr 1.5fr;font-size:.8rem;padding:10px 12px;gap:8px}.gr-student-list-header>div:nth-child(3),.gr-student-list-item>div:nth-child(3),.gr-student-list-header>div:nth-child(4),.gr-student-list-item>div:nth-child(4){display:none}.gr-search-bar{padding:9px 14px}.gr-search-bar input{font-size:.9rem}.gr-download-btn{padding:9px 18px;font-size:.9rem}.gr-grades-table{min-width:450px}.gr-grades-table th,.gr-grades-table td{padding:8px 6px;font-size:.8rem}.gr-grade-pill{font-size:.75rem;padding:3px 8px}.gr-semesters-container>h2{font-size:1.05rem}.gr-loading{padding:30px 15px;font-size:.95rem}.gr-error,.gr-no-data,.gr-no-semesters{padding:25px 15px;font-size:.9rem}}@media (max-width: 360px){.gr-batch-container,.gr-dept-container,.gr-student-container,.gr-grades-container,.gr-student-grades-container{padding:12px}.gr-main-title,.gr-page-title{font-size:1.35rem}.gr-batch-card,.gr-dept-card{padding:16px}.gr-batch-card h2{font-size:1rem}.gr-student-header{padding:14px}.gr-student-info h1,.gr-student-info h2{font-size:1.15rem}.gr-cgpa-value{font-size:1.85rem}.gr-grades-table{min-width:420px}.gr-grades-table th,.gr-grades-table td{padding:8px 5px;font-size:.75rem}}@media (max-width: 900px) and (orientation: landscape){.gr-batch-container,.gr-dept-container,.gr-student-container,.gr-grades-container,.gr-student-grades-container{margin-top:50px}.gr-student-header{flex-direction:row;text-align:left}.gr-student-info{text-align:left}.gr-student-avatar{width:60px;height:60px}.gr-batch-grid{grid-template-columns:repeat(2,1fr)}.gr-dept-grid{grid-template-columns:repeat(3,1fr)}.gr-summary-cards{grid-template-columns:repeat(2,1fr)}}@media (hover: none) and (pointer: coarse){.gr-back-btn,.gr-download-btn,.gr-batch-card,.gr-dept-card,.gr-student-list-item,.gr-search-bar input{min-height:44px}}@media (prefers-reduced-motion: reduce){.gr-batch-card,.gr-dept-card,.gr-student-list-item,.gr-back-btn,.gr-download-btn,.gr-semester-card,.gr-summary-card{transition:none}.gr-batch-card:hover,.gr-dept-card:hover{transform:none}}@media print{.gr-batch-container,.gr-dept-container,.gr-student-container,.gr-grades-container,.gr-student-grades-container{margin:0;padding:1rem;background:#fff}.gr-back-btn,.gr-download-btn,.gr-filter-section{display:none}.gr-batch-card,.gr-dept-card,.gr-student-list,.gr-semester-card,.gr-summary-card,.gr-student-header{box-shadow:none;page-break-inside:avoid}.gr-grades-table{page-break-inside:avoid}}.lt-chatbot-container{position:fixed;bottom:24px;right:24px;z-index:9999;font-family:Outfit,system-ui,-apple-system,sans-serif}.lt-chatbot-toggle{position:relative;width:60px;height:60px;border-radius:50%;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #667eea66;transition:all .3s ease}.lt-chatbot-toggle:hover{transform:scale(1.08);box-shadow:0 6px 25px #667eea80}.lt-toggle-icon{font-size:26px}.lt-toggle-pulse{position:absolute;width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);animation:pulse 2s infinite;z-index:-1}@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.3);opacity:0}to{transform:scale(1);opacity:0}}.lt-chatbot-window{position:fixed;bottom:100px;right:24px;width:380px;height:560px;background:#fff;border-radius:20px;box-shadow:0 10px 40px #00000026;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lt-chatbot-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:16px 20px;display:flex;justify-content:space-between;align-items:center}.lt-header-left{display:flex;align-items:center;gap:12px}.lt-bot-avatar{width:44px;height:44px;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px}.lt-header-info h3{margin:0;font-size:16px;font-weight:600;color:#fff}.lt-status{display:flex;align-items:center;gap:6px;font-size:12px;color:#ffffffe6}.lt-status-dot{width:8px;height:8px;background:#4ade80;border-radius:50%;animation:blink 2s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.lt-close-btn{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.lt-close-btn:hover{background:#ffffff40}.lt-chatbot-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;background:#f8fafc}.lt-message-wrapper{display:flex;gap:10px;max-width:85%;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.lt-message-wrapper.user{flex-direction:row-reverse;align-self:flex-end}.lt-message-wrapper.bot{align-self:flex-start}.lt-message-avatar{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}.lt-message-wrapper.bot .lt-message-avatar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.lt-message-wrapper.user .lt-message-avatar{background:#e0e7ff;color:#667eea}.lt-message-bubble-container{display:flex;flex-direction:column;gap:4px}.lt-message-bubble{padding:12px 16px;border-radius:16px;font-size:14px;line-height:1.5;word-wrap:break-word}.lt-message-wrapper.bot .lt-message-bubble{background:#fff;color:#1e293b;border:1px solid #e2e8f0;border-top-left-radius:4px;box-shadow:0 1px 3px #0000000d}.lt-message-wrapper.user .lt-message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-top-right-radius:4px}.lt-message-bubble.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.lt-message-bubble p{margin:0 0 8px}.lt-message-bubble p:last-child{margin-bottom:0}.lt-message-bubble ul,.lt-message-bubble ol{margin:8px 0;padding-left:20px}.lt-message-bubble li{margin:4px 0}.lt-message-bubble strong{font-weight:600}.lt-message-bubble code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-size:13px}.lt-action-btn{display:block;width:100%;margin-top:12px;padding:10px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.lt-action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.lt-action-btn:active{transform:translateY(0)}.lt-message-time{font-size:11px;color:#94a3b8;padding:0 4px}.lt-message-wrapper.user .lt-message-time{text-align:right}.lt-typing-indicator{display:flex;align-items:center;gap:5px;padding:14px 18px;background:#fff;border:1px solid #e2e8f0;border-radius:4px 16px 16px}.lt-typing-indicator span{width:8px;height:8px;background:#667eea;border-radius:50%;animation:bounce 1.4s infinite ease-in-out}.lt-typing-indicator span:nth-child(1){animation-delay:0s}.lt-typing-indicator span:nth-child(2){animation-delay:.2s}.lt-typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.lt-quick-actions{padding:12px 16px;display:flex;flex-wrap:wrap;gap:8px;background:#f8fafc;border-top:1px solid #e2e8f0}.lt-quick-action-btn{padding:8px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:20px;font-size:12px;color:#667eea;cursor:pointer;transition:all .2s;font-family:inherit}.lt-quick-action-btn:hover{background:#667eea;color:#fff;border-color:#667eea}.lt-chatbot-input-area{padding:16px;background:#fff;border-top:1px solid #e2e8f0;display:flex;gap:10px;align-items:center}.lt-chat-input{flex:1;padding:12px 18px;border:2px solid #e2e8f0;border-radius:25px;font-size:14px;font-family:inherit;outline:none;transition:border-color .2s;background:#f8fafc}.lt-chat-input:focus{border-color:#667eea;background:#fff}.lt-chat-input::placeholder{color:#94a3b8}.lt-send-btn{width:44px;height:44px;border:none;border-radius:50%;background:#e2e8f0;color:#94a3b8;cursor:not-allowed;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.lt-send-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer}.lt-send-btn.active:hover{transform:scale(1.05);box-shadow:0 4px 15px #667eea66}.lt-chatbot-messages::-webkit-scrollbar{width:6px}.lt-chatbot-messages::-webkit-scrollbar-track{background:transparent}.lt-chatbot-messages::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.lt-chatbot-messages::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media screen and (max-width: 768px){.lt-chatbot-container{bottom:20px;right:20px}.lt-chatbot-toggle{width:56px;height:56px}.lt-toggle-icon{font-size:24px}.lt-chatbot-window{width:340px;height:500px;bottom:90px;right:20px}.lt-bot-avatar{width:40px;height:40px;font-size:20px}.lt-header-info h3{font-size:15px}}@media screen and (max-width: 480px){.lt-chatbot-container{bottom:16px;right:16px}.lt-chatbot-toggle{width:52px;height:52px}.lt-toggle-icon{font-size:22px}.lt-chatbot-window{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;border-radius:0;animation:slideUpMobile .3s ease}@keyframes slideUpMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.lt-chatbot-header{padding:14px 16px;border-radius:0}.lt-bot-avatar{width:38px;height:38px;font-size:18px}.lt-header-info h3{font-size:14px}.lt-status{font-size:11px}.lt-close-btn{width:34px;height:34px}.lt-chatbot-messages{padding:16px;gap:14px}.lt-message-wrapper{max-width:90%}.lt-message-avatar{width:30px;height:30px;font-size:14px}.lt-message-bubble{padding:10px 14px;font-size:13px}.lt-quick-actions{padding:10px 14px;gap:6px}.lt-quick-action-btn{padding:7px 12px;font-size:11px}.lt-chatbot-input-area{padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom))}.lt-chat-input{padding:10px 16px;font-size:14px}.lt-send-btn{width:40px;height:40px}}@media screen and (max-width: 360px){.lt-chatbot-container{bottom:12px;right:12px}.lt-chatbot-toggle{width:48px;height:48px}.lt-toggle-icon{font-size:20px}.lt-chatbot-header{padding:12px 14px}.lt-bot-avatar{width:34px;height:34px;font-size:16px}.lt-header-info h3{font-size:13px}.lt-chatbot-messages{padding:12px;gap:12px}.lt-message-avatar{width:28px;height:28px;font-size:12px}.lt-message-bubble{padding:8px 12px;font-size:12px}.lt-quick-action-btn{padding:6px 10px;font-size:10px}.lt-chatbot-input-area{padding:10px 12px}.lt-chat-input{padding:8px 14px;font-size:13px}.lt-send-btn{width:36px;height:36px}}@media screen and (max-width: 900px) and (orientation: landscape){.lt-chatbot-window{height:100%;width:400px;right:0;bottom:0;top:0;border-radius:0}.lt-chatbot-messages{padding:12px}.lt-quick-actions{padding:8px 12px}}@media (hover: none) and (pointer: coarse){.lt-chatbot-toggle,.lt-close-btn,.lt-quick-action-btn,.lt-send-btn{min-height:44px;min-width:44px}.lt-chat-input{min-height:44px}}@media (prefers-reduced-motion: reduce){.lt-chatbot-toggle,.lt-chatbot-window,.lt-message-wrapper,.lt-send-btn,.lt-quick-action-btn{animation:none;transition:none}.lt-toggle-pulse{display:none}.lt-typing-indicator span{animation:none;opacity:.7}.lt-status-dot{animation:none}}.att-container{padding:40px;min-height:calc(100vh - 60px);margin-top:75px;background:#fff;box-shadow:0 2px 4px #0000001a}.att-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:15px;border-bottom:1px solid #e1e1e1}.att-header h2{font-size:24px;color:#333;margin:0}.att-header-right{display:flex;align-items:center;gap:20px}.att-date{display:flex;align-items:center;gap:10px;font-size:16px;color:#666}.att-date input{padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.att-controls{margin-bottom:20px}.att-filters{display:flex;gap:20px;margin-bottom:20px;flex-wrap:wrap}.att-filter-item{display:flex;flex-direction:column;gap:8px;min-width:200px}.att-filter-item label{font-size:14px;color:#666;font-weight:500}.att-filter-item select,.att-search-input{padding:8px 16px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff}.att-search-input{min-width:250px}.att-actions{display:flex;gap:10px;flex-wrap:wrap}.att-btn{padding:8px 20px;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;transition:opacity .2s}.att-btn:hover{opacity:.9}.att-btn:disabled{background:#ccc;cursor:not-allowed}.att-btn-present{background:#10b981}.att-btn-absent{background:#ef4444}.att-btn-submit{background:#3b82f6;min-width:150px}.att-btn-download{background:#8b5cf6}.att-btn-secondary{background:#6b7280}.att-table{margin:20px 0;border:1px solid #e1e1e1;border-radius:8px;overflow:hidden;overflow-x:auto}.att-table table{width:100%;border-collapse:collapse;min-width:800px}.att-table th{background:#f8fafc;padding:12px;text-align:left;font-weight:500;color:#333;border-bottom:1px solid #e1e1e1;position:sticky;top:0;z-index:1}.att-table td{padding:12px;border-bottom:1px solid #e1e1e1;color:#555}.att-table tr:last-child td{border-bottom:none}.att-table tr:hover{background-color:#f8fafc}.att-attendance-radio{display:flex;align-items:center;gap:8px;cursor:pointer}.att-attendance-radio input{width:16px;height:16px;cursor:pointer}.att-attendance-radio span{font-size:14px;color:#666}.att-submit{display:flex;justify-content:center;margin-top:20px}.att-no-data{text-align:center;padding:40px;color:#666;font-size:16px;background:#f8fafc;border-radius:8px;border:1px dashed #e1e1e1}.att-alert{padding:6px 12px;border-radius:4px;font-size:13px;font-weight:500;white-space:nowrap}.att-alert-danger{background-color:#fee2e2;color:#dc2626;border:1px solid #fecaca}.att-alert-warning{background-color:#fef3c7;color:#d97706;border:1px solid #fde68a}@media (max-width: 768px){.att-header{flex-direction:column;align-items:flex-start;gap:15px}.att-header-right{width:100%;flex-direction:column;align-items:flex-start}.att-filters{flex-direction:column}.att-filter-item{width:100%}.att-search-input{width:100%;min-width:unset}.att-actions{flex-direction:column;width:100%}.att-btn{width:100%}.att-table{margin:10px -20px;border-radius:0;border-left:none;border-right:none}}@media print{.att-container{margin:0;padding:0;box-shadow:none}.att-controls,.att-submit,.att-btn{display:none}.att-table{border:none}.att-table th{background-color:#fff;color:#000}.att-attendance-radio input{-webkit-appearance:none;-moz-appearance:none;appearance:none}.att-attendance-radio span{color:#000}}.att-alert{animation:slideIn .3s ease-out}.att-attendance-radio input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border:2px solid #ddd;border-radius:4px;display:inline-block;position:relative;width:18px;height:18px;vertical-align:middle;transition:all .2s ease}.att-attendance-radio input[type=checkbox]:checked{background-color:#3b82f6;border-color:#3b82f6}.att-attendance-radio input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:2px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.att-attendance-radio input[type=checkbox]:focus{outline:2px solid rgba(59,130,246,.5);outline-offset:2px}.att-loading{display:flex;justify-content:center;align-items:center;padding:40px}.att-loading:after{content:"";width:30px;height:30px;border:3px solid #f3f3f3;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.att-error{background-color:#fee2e2;color:#dc2626;padding:12px;border-radius:4px;margin:20px 0;display:flex;align-items:center;gap:10px}.att-error:before{content:"⚠️"}.att-dept-display{padding:8px 16px;background-color:#f0f9ff;border:1px solid #0284c7;border-radius:4px;font-size:14px;font-weight:600;color:#0369a1}.att-present-count{color:#10b981;font-weight:600}.att-absent-count{color:#ef4444;font-weight:600}.att-percentage{font-weight:600;padding:4px 8px;border-radius:4px}.att-percentage.att-good{background-color:#d1fae5;color:#059669}.att-percentage.att-medium{background-color:#fef3c7;color:#d97706}.att-percentage.att-low{background-color:#fee2e2;color:#dc2626}.att-btn-add{background-color:#8b5cf6;text-decoration:none;display:inline-block;margin-bottom:10px}.att-btn-add:hover{background-color:#7c3aed}:root{--primary-color: #2c3e50;--secondary-color: #34495e;--accent-color: #3498db;--background-light: #ecf0f1;--text-color: #333;--border-color: #bdc3c7}.gr-schedule-container{width:100%;min-height:100vh;margin-top:40px;padding:2rem;background-color:var(--background-light);box-shadow:0 4px 6px #0000001a;box-sizing:border-box;overflow-y:none}.gr-delete-btn,.gr-modal-submit,.gr-modal-cancel{border-radius:8px}.gr-table-container{height:calc(100% - 200px);overflow-x:auto;overflow-y:auto;background-color:#fff;border-radius:12px;-webkit-overflow-scrolling:touch}.gr-title{text-align:center;color:var(--primary-color);font-size:2.5rem;margin-bottom:2rem;font-weight:300;letter-spacing:1px;word-wrap:break-word}.gr-filters{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem;min-height:38px;flex-wrap:wrap}.gr-filters-left{display:flex;flex-direction:row;gap:1rem;align-items:center;height:38px;flex-wrap:nowrap}.gr-filters-right{display:flex;gap:1rem;align-items:center;margin-left:auto;height:38px;flex-wrap:nowrap}.sc-gr-select,.gr-select{padding:.5rem .875rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;transition:all .3s ease;min-width:140px;height:38px;background-color:#fff;color:var(--text-color);box-sizing:border-box}.sc-gr-select:focus,.gr-select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3498db1a}.sc-dept-display{padding:.5rem 1rem;background-color:#e0f2fe;border:1px solid #0284c7;border-radius:8px;font-size:.9rem;font-weight:600;color:#0369a1;height:38px;display:flex;align-items:center;box-sizing:border-box;min-width:140px;justify-content:center;word-wrap:break-word}.gr-download-btn,.sc-add-exam-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:50px;font-weight:500;cursor:pointer;transition:background .2s,transform .2s;height:38px;min-width:130px;justify-content:center;box-sizing:border-box;white-space:nowrap;flex-shrink:0}.gr-download-btn:hover,.sc-add-exam-btn:hover{background:var(--secondary-color);transform:translateY(-1px)}.gr-download-btn:active,.sc-add-exam-btn:active{transform:translateY(0)}.gr-table{width:100%;border-collapse:separate;border-spacing:0;min-width:600px}.gr-mobile-cards{display:none}.gr-table thead{background-color:var(--primary-color);color:#fff;position:sticky;top:0;z-index:10}.gr-table th,.gr-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color);word-wrap:break-word}.gr-table th{white-space:nowrap}.gr-table tbody tr{transition:background-color .2s}.gr-table tbody tr:hover{background-color:#3498db0d}.gr-delete-btn{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;cursor:pointer;transition:background-color .3s ease,transform .2s;white-space:nowrap}.gr-delete-btn:hover{background-color:#c0392b;transform:scale(1.05)}.gr-delete-btn:active{transform:scale(1)}.gr-no-data{text-align:center;color:var(--secondary-color);padding:2rem;font-style:italic}.gr-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem;overflow-y:auto}.gr-modal{background-color:#fff;border-radius:12px;padding:2rem;width:100%;max-width:500px;box-shadow:0 6px 12px #00000026;max-height:90vh;overflow-y:auto}.gr-modal h3{text-align:center;color:var(--primary-color);margin-bottom:1.5rem;word-wrap:break-word}.gr-modal-form{display:grid;grid-template-columns:1fr;gap:1rem}.gr-modal-form input,.gr-modal-form select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;box-sizing:border-box}.gr-modal-form input:focus,.gr-modal-form select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3498db1a}.gr-modal-actions{display:flex;justify-content:space-between;margin-top:1.5rem;gap:1rem;flex-wrap:wrap}.gr-modal-submit{background-color:var(--accent-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:50px;cursor:pointer;transition:background-color .3s ease,transform .2s;flex:1;min-width:120px}.gr-modal-submit:hover{background-color:var(--secondary-color);transform:translateY(-1px)}.gr-modal-submit:active{transform:translateY(0)}.gr-modal-cancel{background-color:var(--background-light);color:var(--text-color);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:50px;cursor:pointer;transition:background-color .3s ease;flex:1;min-width:120px}.gr-modal-cancel:hover{background-color:#f1f3f4}.grr-back-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:50px;font-weight:500;cursor:pointer;transition:background .2s,transform .2s;height:38px;min-width:130px;justify-content:center;box-sizing:border-box;white-space:nowrap;margin-top:20px}.grr-back-btn:hover{background:var(--secondary-color);transform:translateY(-1px)}.grr-back-btn:active{transform:translateY(0)}.sc-dept-input-disabled{background-color:#f0f9ff!important;color:#0369a1!important;font-weight:600;cursor:not-allowed}.gr-approval-toggle-section{margin-bottom:2rem}.gr-approval-toggle-btn{width:100%;display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d;font-size:1.1rem;font-weight:600;color:#fff;height:48px;box-sizing:border-box}.gr-approval-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66;background:linear-gradient(135deg,#5568d3,#6a3f8f)}.gr-approval-toggle-btn:active{transform:translateY(0)}.gr-toggle-icon{font-size:1rem;transition:transform .3s ease;flex-shrink:0}.gr-toggle-text{flex:1;text-align:left;word-wrap:break-word;min-width:0}.gr-toggle-badge{background-color:#ffffff4d;padding:.3rem .8rem;border-radius:20px;font-size:.9rem;font-weight:700;min-width:35px;text-align:center;flex-shrink:0}.gr-pending-section{margin-top:1rem;background-color:#f8f9ff;border:2px solid #667eea;border-radius:12px;padding:1.5rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.gr-pending-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1rem}.gr-pending-card{background-color:#fff;border:1px solid #667eea;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #667eea1a;transition:transform .2s,box-shadow .2s}.gr-pending-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #667eea33}.gr-pending-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e0e0e0;gap:.5rem;flex-wrap:wrap}.gr-pending-exam-name{font-weight:600;font-size:1.1rem;color:var(--primary-color);word-wrap:break-word;flex:1;min-width:0}.gr-status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;white-space:nowrap;flex-shrink:0}.gr-status-pending{background-color:#e0e7ff;color:#4338ca}.gr-status-hod_approved{background-color:#dbeafe;color:#1e40af}.gr-status-approved{background-color:#d1fae5;color:#065f46}.gr-status-rejected{background-color:#fee2e2;color:#991b1b}.gr-pending-details{margin-bottom:1rem}.gr-pending-details p{margin:.5rem 0;font-size:.95rem;color:var(--text-color);word-wrap:break-word}.gr-approval-info{color:#28a745;font-weight:600;margin-top:.75rem!important}.gr-pending-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.gr-approve-btn{flex:1;background-color:#28a745;color:#fff;border:none;padding:.6rem 1rem;border-radius:50px;cursor:pointer;font-weight:600;transition:background-color .3s ease,transform .2s;min-width:100px}.gr-approve-btn:hover{background-color:#218838;transform:translateY(-1px)}.gr-approve-btn:active{transform:translateY(0)}.gr-reject-btn{flex:1;background-color:#dc3545;color:#fff;border:none;padding:.6rem 1rem;border-radius:50px;cursor:pointer;font-weight:600;transition:background-color .3s ease,transform .2s;min-width:100px}.gr-reject-btn:hover{background-color:#c82333;transform:translateY(-1px)}.gr-reject-btn:active{transform:translateY(0)}.gr-approval-details{background-color:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:1rem}.gr-approval-details p{margin:.5rem 0;font-size:.95rem;word-wrap:break-word}.gr-approval-form{margin-bottom:1rem}.gr-approval-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;box-sizing:border-box;min-height:100px}.gr-approval-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3498db1a}.gr-date-past{color:#6c757d;font-style:italic}.gr-date-today{color:#007bff;font-weight:700;background-color:#e7f3ff;padding:.25rem .5rem;border-radius:4px}.gr-date-future{color:#28a745;font-weight:600}.gr-row-past{background-color:#f8f9fa;opacity:.8}.gr-row-today{background-color:#e7f3ff;font-weight:500}.gr-row-future{background-color:#f0fff4}.gr-row-past:hover,.gr-row-today:hover,.gr-row-future:hover{background-color:#3498db1a!important}@media screen and (max-width: 1024px){.gr-schedule-container{padding:1.5rem}.gr-title{font-size:2.2rem}.gr-filters,.gr-filters-left,.gr-filters-right{gap:.875rem}.sc-gr-select,.gr-select{min-width:130px}.gr-pending-container{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.gr-table{min-width:550px}}@media screen and (max-width: 768px){.gr-schedule-container{padding:1rem;margin-top:60px}.gr-title{font-size:1.75rem;margin-bottom:1.5rem}.gr-filters{flex-direction:column;gap:.75rem;align-items:stretch}.gr-filters-left,.gr-filters-right{width:100%;margin-left:0;flex-direction:row;height:auto;gap:.5rem}.sc-gr-select,.gr-select,.sc-dept-display,.gr-download-btn,.sc-add-exam-btn{flex:1;min-width:0}.grr-back-btn{width:100%;min-width:unset}.gr-table-container{display:none}.gr-mobile-cards{display:flex;flex-direction:column;gap:1rem}.gr-exam-card{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 2px 8px #00000014;border-left:4px solid var(--primary-color)}.gr-exam-card.gr-card-past{border-left-color:#9ca3af;opacity:.85}.gr-exam-card.gr-card-today{border-left-color:#3b82f6;background:#eff6ff}.gr-exam-card.gr-card-future{border-left-color:#10b981}.gr-exam-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:.5rem}.gr-exam-card-title{font-weight:600;font-size:1rem;color:var(--primary-color);flex:1}.gr-exam-card-type{font-size:.75rem;padding:.25rem .6rem;border-radius:20px;font-weight:600;white-space:nowrap}.gr-exam-card-type.online{background:#dbeafe;color:#1d4ed8}.gr-exam-card-type.offline{background:#f3e8ff;color:#7c3aed}.gr-exam-card-subject{font-size:.95rem;color:#374151;margin-bottom:.75rem;font-weight:500}.gr-exam-card-details{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;font-size:.85rem;color:#6b7280}.gr-exam-card-detail{display:flex;flex-direction:column;gap:.15rem}.gr-exam-card-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af}.gr-exam-card-value{font-weight:500;color:#374151}.gr-exam-card-date{color:var(--accent-color);font-weight:600}.gr-exam-card.gr-card-today .gr-exam-card-date{color:#2563eb}.gr-exam-card.gr-card-past .gr-exam-card-date{color:#9ca3af}.gr-exam-card-actions{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.gr-exam-card-delete{background:#fee2e2;color:#dc2626;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;width:100%}.gr-exam-card-delete:hover{background:#fecaca}.gr-no-exams-mobile{text-align:center;padding:2rem;color:#6b7280;background:#fff;border-radius:12px}.gr-modal{padding:1.5rem;max-width:90%}.gr-modal h3{font-size:1.5rem}.gr-modal-form input,.gr-modal-form select{padding:.6rem}.gr-modal-submit,.gr-modal-cancel{padding:.6rem 1.2rem}.gr-approval-toggle-btn{font-size:1rem;padding:.9rem 1.2rem;height:auto;min-height:44px}.gr-toggle-badge{font-size:.85rem;padding:.25rem .6rem}.gr-pending-container{grid-template-columns:1fr}.gr-pending-section{padding:1rem}.gr-pending-card{padding:.875rem}.gr-pending-exam-name{font-size:1rem}.gr-pending-details p{font-size:.9rem}.gr-approve-btn,.gr-reject-btn{padding:.55rem .9rem}}@media screen and (max-width: 480px){.gr-schedule-container{padding:.75rem;margin-top:55px}.gr-title{font-size:1.5rem;margin-bottom:1rem}.gr-filters{gap:.625rem}.gr-filters-left,.gr-filters-right{gap:.5rem;flex-direction:row}.sc-gr-select,.gr-select,.sc-dept-display{padding:.45rem .5rem;font-size:.8rem;flex:1}.gr-download-btn,.sc-add-exam-btn{padding:9px 12px;font-size:.85rem;flex:1}.grr-back-btn{padding:9px 18px;font-size:.9rem}.gr-exam-card{padding:.875rem}.gr-exam-card-title{font-size:.95rem}.gr-exam-card-subject{font-size:.9rem}.gr-exam-card-details{font-size:.8rem}.gr-exam-card-label{font-size:.65rem}.gr-modal{padding:1rem}.gr-modal h3{font-size:1.3rem;margin-bottom:1rem}.gr-modal-form{gap:.75rem}.gr-modal-form input,.gr-modal-form select{padding:.5rem;font-size:.9rem}.gr-modal-actions{flex-direction:column;gap:.75rem}.gr-modal-submit,.gr-modal-cancel{padding:.5rem 1rem;font-size:.9rem;width:100%}.gr-approval-toggle-btn{font-size:.95rem;padding:.8rem 1rem;gap:.75rem}.gr-toggle-icon{font-size:.9rem}.gr-toggle-badge{font-size:.8rem;padding:.2rem .5rem}.gr-pending-section{padding:.875rem}.gr-pending-card{padding:.75rem}.gr-pending-exam-name{font-size:.95rem}.gr-status-badge{font-size:.8rem;padding:.2rem .6rem}.gr-pending-details p{font-size:.85rem}.gr-pending-actions{flex-direction:column;gap:.5rem}.gr-approve-btn,.gr-reject-btn{padding:.5rem .875rem;font-size:.9rem;width:100%}.gr-approval-details p{font-size:.9rem}.gr-approval-textarea{padding:.6rem;font-size:.9rem}}@media screen and (max-width: 360px){.gr-schedule-container{padding:.5rem;margin-top:15px}.gr-title{font-size:1.6rem}.gr-filters-left,.gr-filters-right{flex-direction:row;gap:.4rem}.sc-gr-select,.gr-select,.sc-dept-display{font-size:.75rem;padding:.4rem;flex:1}.gr-download-btn,.sc-add-exam-btn{padding:8px 10px;font-size:.8rem;flex:1}.grr-back-btn{padding:8px 16px;font-size:.85rem}.gr-table{font-size:.75rem;min-width:400px}.gr-table th,.gr-table td{padding:.5rem .3rem}.gr-delete-btn{padding:.3rem .6rem;font-size:.75rem}.gr-modal h3{font-size:1.2rem}.gr-modal-form input,.gr-modal-form select{padding:.4rem;font-size:.85rem}.gr-modal-submit,.gr-modal-cancel{padding:.4rem .8rem;font-size:.85rem}.gr-approval-toggle-btn{font-size:.9rem;padding:.7rem .9rem}.gr-pending-exam-name{font-size:.9rem}.gr-status-badge{font-size:.75rem}.gr-pending-details p{font-size:.8rem}.gr-approve-btn,.gr-reject-btn{padding:.45rem .75rem;font-size:.85rem}.gr-approval-textarea{font-size:.85rem}}@media screen and (max-width: 900px) and (orientation: landscape){.gr-schedule-container{margin-top:25px}.gr-filters{flex-direction:row}.gr-filters-left,.gr-filters-right{flex-direction:row;width:auto}.gr-pending-container{grid-template-columns:repeat(2,1fr)}}@media (hover: none) and (pointer: coarse){.sc-gr-select,.gr-select,.sc-dept-display,.gr-download-btn,.sc-add-exam-btn,.grr-back-btn,.gr-delete-btn,.gr-modal-submit,.gr-modal-cancel,.gr-approval-toggle-btn,.gr-approve-btn,.gr-reject-btn,.gr-modal-form input,.gr-modal-form select,.gr-approval-textarea{min-height:44px}}@media (prefers-reduced-motion: reduce){.gr-approval-toggle-btn,.gr-pending-card,.gr-modal-submit,.gr-modal-cancel,.gr-download-btn,.sc-add-exam-btn,.grr-back-btn,.gr-delete-btn,.gr-approve-btn,.gr-reject-btn,.sc-gr-select,.gr-select,.gr-table tbody tr{transition:none}.gr-approval-toggle-btn:hover,.gr-pending-card:hover,.gr-modal-submit:hover,.gr-download-btn:hover,.sc-add-exam-btn:hover,.grr-back-btn:hover,.gr-delete-btn:hover,.gr-approve-btn:hover,.gr-reject-btn:hover{transform:none}.gr-pending-section{animation:none}}@media print{.gr-schedule-container{margin:0;padding:1rem;box-shadow:none}.gr-filters,.gr-download-btn,.sc-add-exam-btn,.grr-back-btn,.gr-delete-btn,.gr-approval-toggle-section,.gr-modal-overlay{display:none}.gr-table-container{box-shadow:none}.gr-table{page-break-inside:avoid}.gr-table thead{position:static}}:root{--primary-color: #2c3e50;--secondary-color: #34495e;--accent-color: #3498db;--background-light: #ecf0f1;--text-color: #333;--border-color: #bdc3c7;--break-color: #fff3cd;--weekend-color: #f8f9fa}.tt-container{width:100%;min-height:100vh;margin-top:40px;padding:2rem;background-color:var(--background-light);box-shadow:0 4px 6px #0000001a;box-sizing:border-box}.tt-title{text-align:center;color:var(--primary-color);font-size:2.5rem;margin-bottom:2rem;font-weight:300;letter-spacing:1px}.tt-filters{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.tt-filters-left{display:flex;gap:1rem;align-items:center}.tt-filters-right{display:flex;gap:1rem;align-items:center;margin-left:auto}.tt-select{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:50px;font-size:1rem;transition:all .3s ease;min-width:180px;height:48px;background-color:#fff;color:var(--text-color)}.tt-dept-display{padding:.75rem 1.5rem;background-color:#e0f2fe;border:1px solid #0284c7;border-radius:50px;font-size:1rem;font-weight:600;color:#0369a1;height:48px;display:flex;align-items:center;box-sizing:border-box;min-width:180px;justify-content:center}.tt-download-btn,.tt-add-btn{background-color:var(--accent-color);color:#fff;border:none;cursor:pointer;padding:.75rem 1.5rem;height:48px;display:flex;align-items:center;justify-content:center;min-width:140px;border-radius:50px;transition:background-color .3s ease}.tt-download-btn:hover,.tt-add-btn:hover{background-color:var(--secondary-color)}.tt-loading{text-align:center;padding:2rem;font-size:1.2rem;color:var(--secondary-color)}.tt-grid-wrapper{background-color:#fff;border-radius:12px;overflow-x:auto;box-shadow:0 2px 8px #0000001a}.tt-grid{width:100%;border-collapse:collapse;min-width:1200px}.tt-grid thead{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;position:sticky;top:0;z-index:10}.tt-time-header,.tt-day-header{padding:1rem;text-align:center;font-weight:600;font-size:1.1rem;border:2px solid var(--border-color)}.tt-time-header{width:150px;background-color:var(--primary-color)}.tt-day-header{width:calc((100% - 150px) / 7)}.tt-time-cell{padding:1rem;text-align:center;background-color:#f8f9fa;border:2px solid var(--border-color);font-weight:600;vertical-align:middle}.tt-period{font-size:.9rem;color:var(--accent-color);margin-bottom:.25rem}.tt-time{font-size:.85rem;color:var(--text-color)}.tt-break-row{background-color:var(--break-color)}.tt-break-cell{padding:.75rem;text-align:center;font-weight:600;color:#856404;border:2px solid #ffc107;font-size:1rem}.tt-class-cell{padding:.5rem;border:2px solid var(--border-color);vertical-align:top;height:100px;position:relative;background-color:#fff;transition:background-color .2s ease}.tt-class-cell:hover{background-color:#f0f9ff}.tt-weekend{background-color:var(--weekend-color)}.tt-weekend:hover{background-color:#e9ecef}.tt-class-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem;border-radius:8px;height:100%;display:flex;flex-direction:column;justify-content:center;position:relative;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.tt-class-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.tt-class-subject{font-weight:700;font-size:.95rem;margin-bottom:.25rem;line-height:1.2}.tt-class-code{font-size:.75rem;opacity:.9;margin-bottom:.5rem}.tt-class-faculty{font-size:.8rem;opacity:.95;margin-bottom:.25rem}.tt-class-room{font-size:.75rem;opacity:.9}.tt-delete-mini{position:absolute;top:4px;right:4px;background-color:#e74c3ce6;color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;padding:0;line-height:1}.tt-delete-mini:hover{background-color:#c0392b}.tt-empty-slot{text-align:center;color:#adb5bd;font-size:1.5rem;padding:2rem 0}.tt-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.tt-modal{background-color:#fff;border-radius:12px;padding:2rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 6px 12px #00000026}.tt-modal h3{text-align:center;color:var(--primary-color);margin-bottom:1.5rem}.tt-modal-form{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.tt-modal-form input,.tt-modal-form select{width:95%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem}.tt-modal-form input:disabled{background-color:#f0f9ff;color:#0369a1;font-weight:600;cursor:not-allowed}.tt-modal-actions{display:flex;justify-content:space-between;margin-top:1.5rem;gap:1rem}.tt-modal-submit{background-color:var(--accent-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:50px;cursor:pointer;transition:background-color .3s ease;flex:1}.tt-modal-submit:hover{background-color:var(--secondary-color)}.tt-modal-cancel{background-color:var(--background-light);color:var(--text-color);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:50px;cursor:pointer;transition:background-color .3s ease;flex:1}.tt-modal-cancel:hover{background-color:#f1f3f4}.tt-conflicts-list{max-height:400px;overflow-y:auto;margin-bottom:1rem}.tt-conflict-item{background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:1rem;margin-bottom:.75rem}.tt-conflict-type{font-weight:600;color:#856404;margin-bottom:.5rem;text-transform:uppercase;font-size:.9rem}.tt-conflict-message{color:var(--text-color);font-size:.95rem}.tt-back-btn{display:block;width:10%;margin-top:1.5rem;padding:.75rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:50px;cursor:pointer;transition:background-color .3s ease}.tt-back-btn:hover{background-color:var(--secondary-color)}@media screen and (max-width: 1400px){.tt-grid{min-width:1000px}.tt-class-subject{font-size:.85rem}.tt-class-code,.tt-class-faculty,.tt-class-room{font-size:.7rem}}@media screen and (max-width: 1024px){.tt-container{padding:1.5rem}.tt-title{font-size:2.2rem}.tt-filters{flex-wrap:wrap}.tt-grid{min-width:900px}}@media screen and (max-width: 768px){.tt-container{padding:1rem;margin-top:30px}.tt-title{font-size:2rem;margin-bottom:1.5rem}.tt-filters{flex-direction:column;gap:.75rem}.tt-filters-left,.tt-filters-right{width:100%;flex-direction:column}.tt-select,.tt-dept-display,.tt-download-btn,.tt-add-btn{width:100%}.tt-grid-wrapper{border-radius:8px}.tt-grid{min-width:800px}.tt-class-cell{height:90px}.tt-modal{padding:1.5rem;max-width:90%}.tt-modal-form{grid-template-columns:1fr}.tt-back-btn{width:100%}.tt-select,.tt-dept-display,.tt-download-btn,.tt-add-btn{font-size:.95rem;box-shadow:0 2px 8px #00000014;-webkit-tap-highlight-color:transparent}.tt-download-btn:active,.tt-add-btn:active{transform:scale(.97)}.tt-grid-wrapper{box-shadow:0 4px 12px #0000001f}.tt-grid-wrapper::-webkit-scrollbar{height:8px}.tt-grid-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.tt-grid-wrapper::-webkit-scrollbar-thumb{background:var(--accent-color);border-radius:4px}.tt-grid-wrapper::-webkit-scrollbar-thumb:hover{background:var(--secondary-color)}}@media screen and (max-width: 480px){.tt-container{padding:.75rem;margin-top:20px}.tt-title{font-size:1.8rem;margin-bottom:1rem}.tt-grid{min-width:700px}.tt-class-cell{height:80px;padding:.25rem}.tt-class-card{padding:.5rem}.tt-class-subject{font-size:.75rem}.tt-class-code,.tt-class-faculty,.tt-class-room{font-size:.65rem}.tt-modal{padding:1rem}.tt-modal h3{font-size:1.3rem;margin-bottom:1rem}.tt-modal-form{gap:.75rem}.tt-modal-form input,.tt-modal-form select{padding:.5rem;font-size:.9rem}.tt-modal-submit,.tt-modal-cancel{padding:.5rem 1rem;font-size:.9rem}.tt-title{font-weight:400;line-height:1.3}.tt-filters{gap:.6rem}.tt-select,.tt-dept-display,.tt-download-btn,.tt-add-btn{height:44px;font-size:.9rem;min-width:auto;box-shadow:0 2px 6px #0000001a;font-weight:600}.tt-select{background-image:linear-gradient(45deg,transparent 50%,var(--accent-color) 50%),linear-gradient(135deg,var(--accent-color) 50%,transparent 50%);background-position:calc(100% - 15px) calc(1em + 2px),calc(100% - 10px) calc(1em + 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:2rem}.tt-download-btn,.tt-add-btn{font-weight:600;letter-spacing:.3px}.tt-download-btn:active,.tt-add-btn:active{transform:scale(.96)}.tt-grid-wrapper{border-radius:10px;box-shadow:0 3px 10px #0000001f;margin-bottom:1rem}.tt-grid-wrapper::-webkit-scrollbar{height:6px}.tt-time-header,.tt-day-header{font-size:.85rem;padding:.7rem .4rem;white-space:nowrap}.tt-time-cell{padding:.6rem .3rem}.tt-period{font-size:.75rem;font-weight:700}.tt-time{font-size:.7rem}.tt-break-cell{font-size:.85rem;padding:.5rem}.tt-class-card{border-radius:6px;padding:.4rem}.tt-class-subject{font-size:.7rem;font-weight:700;line-height:1.1}.tt-class-code{font-size:.6rem;margin-bottom:.3rem}.tt-class-faculty{font-size:.65rem;margin-bottom:.2rem}.tt-class-room{font-size:.6rem}.tt-delete-mini{width:20px;height:20px;font-size:12px;top:2px;right:2px}.tt-delete-mini:active{transform:scale(.9)}.tt-empty-slot{font-size:1.2rem;padding:1.5rem 0}.tt-modal{border-radius:16px;padding:1.25rem;max-width:95%;animation:slideUpModal .3s ease-out}.tt-modal h3{font-size:1.2rem;font-weight:600}.tt-modal-form input,.tt-modal-form select{width:100%;padding:.7rem;font-size:.9rem;border-radius:8px;border:1.5px solid var(--border-color);transition:border-color .2s ease}.tt-modal-form input:focus,.tt-modal-form select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3498db1a}.tt-modal-actions{gap:.6rem;margin-top:1.2rem}.tt-modal-submit,.tt-modal-cancel{padding:.7rem 1.2rem;font-size:.9rem;font-weight:600;letter-spacing:.3px}.tt-modal-submit:active,.tt-modal-cancel:active{transform:scale(.96)}.tt-conflict-item{border-radius:10px;padding:.8rem;margin-bottom:.6rem}.tt-conflict-type{font-size:.8rem}.tt-conflict-message{font-size:.85rem}.tt-back-btn{font-weight:600;font-size:.9rem;letter-spacing:.3px}.tt-back-btn:active{transform:scale(.97)}}.tt-grid-wrapper{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}@keyframes slideUpModal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media screen and (max-width: 768px){.tt-select,.tt-dept-display,.tt-download-btn,.tt-add-btn,.tt-modal-submit,.tt-modal-cancel,.tt-back-btn,.tt-delete-mini{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}}@media screen and (max-width: 480px){.tt-loading{font-size:1rem;padding:1.5rem;animation:pulse 1.5s ease-in-out infinite}}@media screen and (max-width: 480px){.tt-modal-overlay{background-color:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:.5rem}.tt-conflicts-list{max-height:300px}.tt-conflicts-list::-webkit-scrollbar{width:4px}.tt-conflicts-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.tt-conflicts-list::-webkit-scrollbar-thumb{background:var(--accent-color);border-radius:2px}}@media screen and (max-width: 768px){.tt-download-btn:active,.tt-add-btn:active,.tt-modal-submit:active{background-color:var(--secondary-color)}.tt-modal-cancel:active{background-color:#e1e3e4}.tt-back-btn:active{background-color:var(--secondary-color)}}@media screen and (max-width: 768px){*{-webkit-tap-highlight-color:transparent}.tt-select,.tt-download-btn,.tt-add-btn,.tt-modal-submit,.tt-modal-cancel,.tt-back-btn{transition:all .2s ease}.tt-class-card{transition:transform .15s ease,box-shadow .15s ease}.tt-delete-mini{transition:all .15s ease}}.fees-container{max-width:1600px;margin:4rem auto 2rem;padding:2rem 4rem;background:#fff;min-height:calc(100vh - 4rem)}.fees-title{display:flex;align-items:center;gap:.75rem;color:#1a237e;font-size:1.8rem;margin-bottom:2rem;font-weight:600}.fee-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.fee-stat-card{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;border-radius:12px;color:#fff;box-shadow:0 4px 12px #667eea4d}.fee-stat-card h4{margin:0 0 .5rem;font-size:.9rem;font-weight:500;opacity:.9}.fee-stat-card .stat-value{font-size:1.8rem;font-weight:700;margin:0}.fee-stat-card .stat-value.success{color:#4ade80}.fee-filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-select{padding:.5rem .875rem;border:1px solid #bdc3c7;border-radius:8px;font-size:.9rem;width:140px;background-color:#fff;cursor:pointer;transition:all .3s ease;height:38px}.filter-select:hover{border-color:#667eea}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.fee-table-container{background:#fff;border-radius:12px;overflow-x:auto;box-shadow:0 2px 8px #00000014}.fee-table{width:100%;border-collapse:collapse}.fee-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.fee-table th{padding:1rem;text-align:left;font-weight:600;font-size:.95rem}.fee-table td{padding:1rem;border-bottom:1px solid #ecf0f1;font-size:.95rem}.fee-table tbody tr:hover{background-color:#f8f9ff}.fee-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:600}.status-paid{background-color:#d1fae5;color:#065f46}.status-partial{background-color:#fef3c7;color:#92400e}.status-pending{background-color:#e0e7ff;color:#3730a3}.status-overdue{background-color:#fee2e2;color:#991b1b}.success{color:#10b981;font-weight:600}.danger{color:#ef4444;font-weight:600}.download-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease}.download-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#667eea}.no-data{text-align:center;padding:3rem;color:#6b7280;font-style:italic}@media (max-width: 1024px){.fees-container{padding:2rem}.fee-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.fees-container{padding:1rem;margin-top:60px}.fees-title{font-size:1.5rem}.fee-stats{grid-template-columns:1fr;gap:1rem}.fee-stat-card{padding:1.25rem}.fee-filters{flex-direction:column;gap:.75rem}.filter-select{width:100%}.fee-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.fee-table{min-width:800px;font-size:.85rem}.fee-table th,.fee-table td{padding:.75rem .5rem}.fees-title{font-weight:700}.fee-stat-card{transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 3px 10px #667eea40}.fee-stat-card:active{transform:scale(.98)}.filter-select{height:44px;font-size:.9rem;font-weight:500;border-radius:10px}.fee-table-container{border-radius:10px;box-shadow:0 3px 10px #0000001a}.fee-table-container::-webkit-scrollbar{height:8px}.fee-table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.fee-table-container::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.fee-table-container::-webkit-scrollbar-thumb:hover{background:#764ba2}.download-btn{box-shadow:0 2px 8px #667eea4d}.download-btn:active{transform:scale(.97)}}@media (max-width: 480px){.fees-container{padding:.75rem;margin-top:55px}.fees-title{font-size:1.25rem}.fee-stat-card{padding:1rem}.fee-stat-card h4{font-size:.85rem}.fee-stat-card .stat-value{font-size:1.5rem}.fee-table{font-size:.8rem}.action-button{padding:.4rem .8rem;font-size:.8rem}.fees-title{font-size:1.35rem;gap:.5rem;margin-bottom:1.25rem}.fees-title svg{width:24px;height:24px}.fee-stats{gap:.75rem;margin-bottom:1.5rem}.fee-stat-card{padding:1.25rem;border-radius:10px;box-shadow:0 2px 8px #667eea40;transition:transform .2s ease}.fee-stat-card:active{transform:scale(.98)}.fee-stat-card h4{font-size:.8rem;margin-bottom:.4rem;letter-spacing:.3px}.fee-stat-card .stat-value{font-size:1.6rem;font-weight:800}.fee-filters{gap:.6rem;margin-bottom:1.5rem}.filter-select{height:44px;padding:.65rem 1rem;font-size:.9rem;border-radius:10px;font-weight:600;border-width:1.5px;-webkit-tap-highlight-color:transparent}.filter-select:active{transform:scale(.98)}.fee-table-container{border-radius:10px;margin-bottom:1rem;box-shadow:0 3px 10px #0000001f}.fee-table{min-width:700px;font-size:.8rem}.fee-table th{padding:.7rem .6rem;font-size:.8rem;white-space:nowrap}.fee-table td{padding:.7rem .6rem}.status-badge{padding:.35rem .7rem;font-size:.75rem;border-radius:16px;font-weight:700}.download-btn{padding:.6rem 1.1rem;font-size:.85rem;font-weight:600;border-radius:50px;box-shadow:0 2px 8px #667eea4d;-webkit-tap-highlight-color:transparent}.download-btn:active{transform:scale(.96)}.action-button{padding:.5rem .9rem;font-size:.8rem;border-radius:8px;font-weight:600;transition:transform .2s ease}.action-button:active{transform:scale(.95)}.loading{padding:2rem;font-size:1rem;animation:pulse 1.5s ease-in-out infinite}.no-data{padding:2rem;font-size:.9rem}}.fee-table-container{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}@media (max-width: 768px){.filter-select,.download-btn,.action-button{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@media (max-width: 768px){.fee-table tbody tr{transition:background-color .2s ease}.fee-table tbody tr:active{background-color:#f0f4ff}}@media (max-width: 480px){.fee-stat-card{animation:fadeInUp .4s ease-out}.fee-stat-card:nth-child(1){animation-delay:.1s}.fee-stat-card:nth-child(2){animation-delay:.2s}.fee-stat-card:nth-child(3){animation-delay:.3s}.fee-stat-card:nth-child(4){animation-delay:.4s}}@media (max-width: 480px){.status-paid{background-color:#d1fae5;color:#065f46;box-shadow:0 1px 3px #065f4626}.status-partial{background-color:#fef3c7;color:#92400e;box-shadow:0 1px 3px #92400e26}.status-pending{background-color:#e0e7ff;color:#3730a3;box-shadow:0 1px 3px #3730a326}.status-overdue{background-color:#fee2e2;color:#991b1b;box-shadow:0 1px 3px #991b1b26}}@media (max-width: 768px){.filter-select:focus{box-shadow:0 0 0 3px #667eea33;border-color:#667eea}.download-btn:focus{outline:none;box-shadow:0 0 0 3px #667eea4d}}@media (max-width: 480px){.fee-table thead{position:sticky;top:0;z-index:10}.fee-table td{white-space:nowrap}.success,.danger{font-weight:700}}@media (max-width: 480px){.fees-container{animation:fadeIn .3s ease-in}}.pay-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:50px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;margin-left:.5rem}.pay-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.pay-btn:active{transform:scale(.97)}.payment-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.payment-modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.payment-modal h3{display:flex;align-items:center;gap:.75rem;margin:0 0 1.5rem;color:#1a237e;font-size:1.4rem}.payment-details{background:#f8fafc;border-radius:12px;padding:1rem;margin-bottom:1.5rem}.payment-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.95rem}.payment-row.highlight{border-top:1px dashed #e2e8f0;margin-top:.5rem;padding-top:.75rem;font-weight:600}.payment-input-group{margin-bottom:1.5rem}.payment-input-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151}.payment-input-group input{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:1.1rem;font-weight:600;transition:border-color .2s}.payment-input-group input:focus{outline:none;border-color:#667eea}.quick-amounts{display:flex;gap:.75rem;margin-top:.75rem}.quick-amounts button{flex:1;padding:.5rem;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.quick-amounts button:hover{background:#e5e7eb}.payment-actions{display:flex;gap:1rem}.cancel-btn{flex:1;padding:.875rem;background:#f3f4f6;border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;color:#6b7280;transition:all .2s}.cancel-btn:hover{background:#e5e7eb}.proceed-btn{flex:2;padding:.875rem;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;color:#fff;transition:all .2s}.proceed-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.proceed-btn:disabled{opacity:.6;cursor:not-allowed}.payment-note{text-align:center;margin-top:1rem;font-size:.85rem;color:#6b7280}@media (max-width: 480px){.payment-modal{padding:1.5rem;margin:.5rem}.payment-modal h3{font-size:1.2rem}.payment-actions{flex-direction:column}.cancel-btn,.proceed-btn{flex:none;width:100%}.pay-btn{padding:.4rem .8rem;font-size:.8rem;margin-left:0;margin-top:.5rem}}.attendance-container{display:flex;gap:2rem;padding:2rem;max-width:1600px;margin-top:60px;margin-left:auto;margin-right:auto}.qr-section,.attendance-log{flex:1;background:#fff;border-radius:8px;padding:1.5rem}.qr-wrapper{background:#fff;padding:1rem;border-radius:8px;border:2px solid #eaeaea;display:flex;justify-content:center;margin:1rem 0}h2{color:#333;margin-bottom:1rem;font-size:1.5rem}.refresh-text{color:#666;text-align:center;margin-top:1rem;font-size:.9rem}.current-code{text-align:center;margin-top:1rem;padding:.5rem;background:#f5f5f5;border-radius:4px;font-family:monospace}.log-container{height:400px;overflow-y:auto;border:1px solid #eaeaea;border-radius:6px}.scan-list{padding:.5rem}.scan-item{display:flex;justify-content:space-between;padding:.75rem;border-bottom:1px solid #eaeaea;background:#f9f9f9;margin-bottom:.5rem;border-radius:4px}.scan-time{color:#666;font-size:.9rem}.scan-user{font-weight:500;color:#333}.no-scans{text-align:center;color:#666;padding:2rem}@media (max-width: 768px){.attendance-container{flex-direction:column}.qr-section,.attendance-log{width:100%}}.confirmation-popup{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.confirmation-content{background:#fff;padding:2rem;border-radius:8px;text-align:center;box-shadow:0 4px 12px #00000026}.student-name{font-size:1.2rem;font-weight:600;margin:1rem 0}.confirmation-buttons{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.confirmation-buttons button{padding:.5rem 2rem;border:none;border-radius:4px;cursor:pointer;font-weight:500}.confirmation-buttons button:first-child{background:#4caf50;color:#fff}.confirmation-buttons button:last-child{background:#f44336;color:#fff}.scan-name{font-weight:600;color:#333}.detector-container{max-width:1600px;margin-top:4rem;margin-left:auto;margin-right:auto;padding:2rem 4rem;background:#fff;min-height:calc(100vh - 4rem)}.page-title{color:#1a237e;font-size:1.8rem;margin-bottom:2rem;text-align:center;font-weight:600}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.spin{animation:spin 1.5s linear infinite;color:#1a237e}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.view-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:linear-gradient(135deg,#1a237e,#3949ab);border-radius:12px;color:#fff}.view-header .header-left{display:flex;align-items:center;gap:1rem;flex:1}.view-header h3{margin:0;flex:1}.student-count{background:#fff3;padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.year-filter{margin-left:auto}.year-dropdown{padding:.6rem 1.2rem;border:2px solid rgba(255,255,255,.3);border-radius:50px;background:#ffffff26;color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;outline:none;transition:all .3s ease;min-width:140px}.year-dropdown:hover{background:#ffffff40;border-color:#ffffff80}.year-dropdown:focus{background:#ffffff4d;border-color:#fff}.year-dropdown option{background:#1a237e;color:#fff;padding:.5rem}.alerts-container{margin-bottom:2rem;display:flex;flex-direction:column;gap:.75rem}.alert-card{display:flex;align-items:flex-start;padding:1rem 1.25rem;border-radius:8px;gap:1rem;background:#fff;box-shadow:0 2px 8px #00000014}.alert-card.critical{border-left:4px solid #ef5350;background:#ffebee}.alert-card.warning{border-left:4px solid #ffa726;background:#fff3e0}.alert-card.info{border-left:4px solid #29b6f6;background:#e1f5fe}.alert-content{flex:1}.alert-message{margin:0;font-weight:600;color:#333}.alert-action{margin:.25rem 0 0;font-size:.85rem;color:#666}.performance-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 20px #00000014}.performance-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.performance-header h3{margin:0;font-size:1.4rem;color:#1a237e}.performance-header .student-info{margin:.25rem 0 0;color:#666;font-size:.9rem}.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.metric{background:#f8f9fa;padding:1.5rem;border-radius:12px;text-align:center;transition:transform .2s,box-shadow .2s}.metric:hover{transform:translateY(-3px);box-shadow:0 4px 12px #0000001a}.metric span{display:block;color:#666;margin:.5rem 0;font-size:.85rem}.metric h4{margin:.5rem 0;font-size:1.6rem}.metric small{color:#888;font-size:.8rem}.text-success{color:#2e7d32!important}.text-warning{color:#f57c00!important}.text-danger{color:#c62828!important}.subjects-section{background:#f8f9fa;padding:1.5rem;border-radius:12px}.subjects-section h4{margin:0 0 1rem;color:#1a237e}.semester-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#fff;border-radius:8px;margin-bottom:.5rem}.gpa-badge{background:#e8f5e9;color:#2e7d32;padding:.25rem .75rem;border-radius:20px;font-weight:600;font-size:.85rem}.credits-badge{background:#e3f2fd;color:#1565c0;padding:.25rem .75rem;border-radius:20px;font-size:.85rem}.risk-summary{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 20px #00000014;margin-bottom:2rem}.risk-summary h4{margin:0 0 1rem;color:#1a237e;display:flex;align-items:center;gap:.5rem}.alerts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.risk-card{padding:1.25rem;border-radius:10px;background:#fff;box-shadow:0 2px 8px #00000014;transition:transform .2s}.risk-card:hover{transform:translateY(-2px)}.risk-card.critical{border-left:4px solid #ef5350;background:#fff5f5}.risk-card.warning{border-left:4px solid #ffa726;background:#fffaf0}.risk-card h5{margin:0 0 .25rem;color:#333;font-size:1rem}.risk-card .reg-no{margin:0;font-size:.8rem;color:#888}.risk-card .risk-score{font-size:1.1rem;font-weight:600;margin:.5rem 0;color:#1a237e}.risk-card .risk-details{font-size:.85rem;color:#666;margin:0}.students-table-container,.departments-table-container{overflow-x:auto;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 20px #00000014}.students-table-container h4,.departments-table-container h4{margin:0 0 1rem;color:#1a237e}.students-table{width:100%;border-collapse:collapse;text-align:left;table-layout:fixed}.students-table th,.students-table td{text-align:left;overflow:visible;text-overflow:clip}.students-table td:nth-child(10){overflow:visible!important}.students-table th:nth-child(1),.students-table td:nth-child(1){width:10%}.students-table th:nth-child(2),.students-table td:nth-child(2){width:15%}.students-table th:nth-child(3),.students-table td:nth-child(3){width:8%}.students-table th:nth-child(4),.students-table td:nth-child(4){width:9%}.students-table th:nth-child(5),.students-table td:nth-child(5){width:9%}.students-table th:nth-child(6),.students-table td:nth-child(6){width:11%}.students-table th:nth-child(7),.students-table td:nth-child(7){width:8%}.students-table th:nth-child(8),.students-table td:nth-child(8){width:11%}.students-table th:nth-child(9),.students-table td:nth-child(9){width:10%}.students-table th:nth-child(10),.students-table td:nth-child(10){width:12%;min-width:80px}.students-table th{background:#f8f9fa;padding:.875rem 1rem;font-weight:600;color:#1a237e;border-bottom:2px solid #e0e0e0;white-space:nowrap}.students-table td{padding:.875rem 1rem;border-bottom:1px solid #e0e0e0;vertical-align:middle}.students-table tr:last-child td{border-bottom:none}.students-table tr.high-risk{background:#ffebee}.students-table tr.medium-risk{background:#fff8e1}.students-table tr.low-risk{background:#f1f8e9}.students-table tr:hover{filter:brightness(.98)}.present-cell{color:#2e7d32}.present-cell svg{vertical-align:middle;margin-right:.25rem}.absent-cell{color:#c62828}.absent-cell svg{vertical-align:middle;margin-right:.25rem}.risk-badge{display:inline-block;padding:.35rem .75rem;border-radius:20px;font-weight:600;font-size:.8rem;white-space:nowrap}.risk-badge.critical{background:#ffebee;color:#c62828}.risk-badge.warning{background:#fff3e0;color:#e65100}.risk-badge.safe{background:#e8f5e9;color:#2e7d32}.overview-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:2rem}.overview-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;align-items:center;gap:1rem;transition:transform .2s}.overview-card:hover{transform:translateY(-3px)}.overview-card svg{color:#1a237e}.overview-card h4{margin:0;font-size:1.5rem;color:#1a237e}.overview-card p{margin:0;font-size:.85rem;color:#666}.overview-card.warning{border-left:4px solid #ef5350}.overview-card.warning svg{color:#ef5350}.overview-card.warning h4{color:#ef5350}@media (max-width: 1200px){.overview-cards{grid-template-columns:repeat(3,1fr)}.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.detector-container{padding:1rem;margin-top:60px}.page-title{font-size:1.75rem}.overview-cards{grid-template-columns:repeat(2,1fr);gap:1rem}.overview-card{padding:1rem}.metrics-grid{grid-template-columns:1fr 1fr}.alerts-grid{grid-template-columns:1fr}.view-header{flex-direction:column;text-align:center;gap:1rem}.student-count{margin-top:.5rem}.students-grid{grid-template-columns:1fr}.view-header{border-radius:10px;padding:1.25rem}.year-dropdown{width:100%;max-width:300px}.overview-card{box-shadow:0 3px 10px #0000001a}.overview-card:active{transform:scale(.97)}.metric{padding:1.25rem}.metric:active{transform:scale(.97)}.students-table-container,.departments-table-container{border-radius:10px;padding:1.25rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.students-table-container::-webkit-scrollbar,.departments-table-container::-webkit-scrollbar{height:8px}.students-table-container::-webkit-scrollbar-track,.departments-table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.students-table-container::-webkit-scrollbar-thumb,.departments-table-container::-webkit-scrollbar-thumb{background:#1a237e;border-radius:4px}.alert-card{border-radius:10px}.risk-card{border-radius:12px}}@media (max-width: 480px){.detector-container{padding:.75rem;margin-top:55px}.page-title{font-size:1.5rem}.overview-cards{grid-template-columns:1fr}.overview-card{padding:.875rem}.card-value{font-size:1.75rem}.metrics-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-btn{width:100%;justify-content:center}.page-title{font-size:1.4rem;margin-bottom:1.25rem;font-weight:700}.loading-container{min-height:300px}.view-header{border-radius:10px;padding:1rem;box-shadow:0 3px 10px #0000001f}.view-header h3{font-size:1.1rem}.student-count{padding:.4rem .8rem;font-size:.85rem;font-weight:600}.year-dropdown{width:100%;padding:.65rem 1rem;font-size:.9rem;font-weight:600}.overview-cards{gap:.75rem}.overview-card{padding:1rem;border-radius:10px;flex-direction:column;text-align:center;box-shadow:0 2px 8px #0000001a}.overview-card svg{width:32px;height:32px}.overview-card h4{font-size:1.4rem;margin:.25rem 0}.overview-card p{font-size:.8rem}.overview-card:active{transform:scale(.98)}.alerts-container{gap:.6rem}.alert-card{padding:.875rem 1rem;border-radius:8px;gap:.75rem}.alert-message{font-size:.9rem}.alert-action{font-size:.8rem}.performance-card{padding:1.25rem;border-radius:10px}.performance-header h3{font-size:1.2rem}.metrics-grid{gap:.75rem}.metric{padding:1rem;border-radius:10px}.metric span{font-size:.8rem}.metric h4{font-size:1.4rem}.metric small{font-size:.75rem}.metric:active{transform:scale(.98)}.subjects-section{padding:1.25rem;border-radius:10px}.subjects-section h4{font-size:1rem}.semester-row{padding:.7rem .875rem;font-size:.9rem}.gpa-badge,.credits-badge{font-size:.8rem;padding:.3rem .6rem}.risk-summary{padding:1.25rem;border-radius:10px}.risk-summary h4{font-size:1rem}.alerts-grid{gap:.75rem}.risk-card{padding:1rem;border-radius:10px}.risk-card h5{font-size:.95rem}.risk-card .risk-score{font-size:1rem}.risk-card .risk-details{font-size:.8rem}.students-table-container,.departments-table-container{padding:1rem;border-radius:10px;margin-bottom:1rem}.students-table-container h4,.departments-table-container h4{font-size:1rem;margin-bottom:.875rem}.students-table{font-size:.85rem}.students-table th{padding:.7rem .5rem;font-size:.8rem}.students-table td{padding:.7rem .5rem}.risk-badge{font-size:.75rem;padding:.3rem .6rem}.action-buttons{gap:.6rem;margin-bottom:1.25rem}.action-btn{padding:.875rem 1.25rem;border-radius:10px;font-size:.9rem;box-shadow:0 2px 8px #0000001f}.action-btn:active{transform:scale(.97)}.clickable-row:active{transform:scale(.995)}.icon-btn{min-width:36px;min-height:36px;padding:.5rem}.icon-btn:active{transform:scale(.9)}}.action-buttons{display:flex;gap:1rem;margin-bottom:1.5rem}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.action-btn.topper-btn{background:linear-gradient(135deg,#2e7d32,#43a047);color:#fff}.action-btn.risk-btn{background:linear-gradient(135deg,#c62828,#e53935);color:#fff}.action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.click-hint{font-size:.8rem;color:#888;font-weight:400;margin-left:.5rem}.clickable-row{cursor:pointer;transition:all .2s}.clickable-row:hover{transform:scale(1.005);box-shadow:0 2px 8px #0000001a}.action-cell{white-space:nowrap;display:inline-flex;align-items:center;gap:.5rem;overflow:visible!important}.action-cell .icon-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.icon-btn{padding:.4rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s;display:inline-flex!important;align-items:center;justify-content:center;min-width:32px;min-height:32px;visibility:visible!important;opacity:1!important}.icon-btn.view-btn{background:#e3f2fd;color:#1565c0}.icon-btn.download-btn{background:#e8f5e9;color:#2e7d32;margin-left:.5rem}.icon-btn:hover{transform:scale(1.1)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1a237e,#3949ab);color:#fff}.modal-title{display:flex;align-items:center;gap:1rem}.modal-title h3{margin:0;font-size:1.3rem}.modal-title p{margin:.25rem 0 0;opacity:.9;font-size:.9rem}.close-btn{background:#fff3;border:none;color:#fff;padding:.5rem;border-radius:8px;cursor:pointer;transition:background .2s}.close-btn:hover{background:#ffffff4d}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.modal-metric{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#f8f9fa;border-radius:10px}.modal-metric svg{color:#1a237e;flex-shrink:0}.modal-metric span{font-size:.8rem;color:#666}.modal-metric h4{margin:.25rem 0;font-size:1.2rem}.modal-metric small{font-size:.75rem;color:#888}.modal-semesters h4{margin:0 0 1rem;color:#1a237e}.semester-block{margin-bottom:1.5rem;border:1px solid #e0e0e0;border-radius:10px;overflow:hidden}.semester-header-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f5f5f5;font-weight:600}.semester-table{width:100%;border-collapse:collapse}.semester-table th{background:#fafafa;padding:.6rem 1rem;text-align:left;font-size:.85rem;color:#666}.semester-table td{padding:.6rem 1rem;border-top:1px solid #eee}.grade-pill{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.8rem;font-weight:600}.grade-pill.grade-Aplus,.grade-pill.grade-A{background:#e8f5e9;color:#2e7d32}.grade-pill.grade-Aminus,.grade-pill.grade-Bplus{background:#e3f2fd;color:#1565c0}.grade-pill.grade-B,.grade-pill.grade-Bminus{background:#fff3e0;color:#e65100}.grade-pill.grade-Cplus,.grade-pill.grade-C{background:#fff8e1;color:#f57c00}.grade-pill.grade-D,.grade-pill.grade-F{background:#ffebee;color:#c62828}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1rem 1.5rem;border-top:1px solid #e0e0e0;background:#fafafa}.modal-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.modal-btn.secondary{background:#e0e0e0;color:#333}.modal-btn.primary{background:linear-gradient(135deg,#1a237e,#3949ab);color:#fff}.modal-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}@media (max-width: 768px){.modal-metrics{grid-template-columns:repeat(2,1fr)}.action-buttons{flex-direction:column}.modal-content{max-height:95vh}.modal-overlay{padding:1rem}.modal-header{padding:1.25rem;border-radius:16px 16px 0 0}.modal-title h3{font-size:1.2rem}.modal-title p{font-size:.85rem}.close-btn{padding:.6rem}.close-btn:active{transform:scale(.9)}.modal-body{padding:1.25rem}.modal-metric{padding:.875rem;border-radius:8px}.modal-metric span{font-size:.75rem}.modal-metric h4{font-size:1.1rem}.semester-block{border-radius:8px}.semester-header-row{padding:.7rem .875rem;font-size:.9rem}.modal-footer{padding:1rem;flex-wrap:wrap}.modal-btn{flex:1;min-width:120px}.modal-btn:active{transform:scale(.97)}}@media (max-width: 480px){.modal-overlay{padding:.5rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{border-radius:12px;max-height:92vh;animation:slideUpModal .3s ease-out}.modal-header{padding:1rem}.modal-title{flex-direction:column;align-items:flex-start;gap:.5rem}.modal-title h3{font-size:1.1rem}.modal-title p{font-size:.8rem}.close-btn{padding:.5rem;position:absolute;right:1rem;top:1rem}.modal-body{padding:1rem}.modal-metrics{grid-template-columns:1fr;gap:.75rem}.modal-metric{padding:.875rem;gap:.6rem}.modal-metric svg{width:20px;height:20px}.modal-metric span{font-size:.75rem}.modal-metric h4{font-size:1rem}.modal-metric small{font-size:.7rem}.modal-semesters h4{font-size:.95rem}.semester-block{margin-bottom:1rem}.semester-header-row{padding:.7rem;font-size:.85rem;flex-wrap:wrap;gap:.5rem}.semester-table{font-size:.85rem}.semester-table th{padding:.5rem .7rem;font-size:.8rem}.semester-table td{padding:.5rem .7rem}.grade-pill{font-size:.75rem;padding:.25rem .5rem}.modal-footer{padding:.875rem;gap:.6rem}.modal-btn{padding:.75rem 1.25rem;font-size:.85rem;border-radius:10px}}@keyframes slideUpModal{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.overview-card,.metric,.risk-card,.action-btn,.icon-btn,.close-btn,.modal-btn,.year-dropdown{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.clickable-row{-webkit-tap-highlight-color:rgba(26,35,126,.1)}}.students-table-container,.departments-table-container,.modal-body{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}@media (max-width: 480px){.loading-container{animation:fadeIn .3s ease-in}.spin{width:40px;height:40px}}.add-student-page{min-height:100vh;background:#f8fafc;padding:2rem;padding-top:100px;position:relative}.as-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffe6;z-index:1000;display:flex;align-items:center;justify-content:center}.add-student-container{max-width:700px;margin:0 auto;background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014}.as-back-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#f1f5f9;border:none;border-radius:8px;color:#475569;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:1.5rem}.as-back-btn:hover{background:#e2e8f0;color:#1e293b}.as-header{text-align:center;margin-bottom:2rem}.as-header h2{font-size:1.75rem;color:#1e293b;margin:0 0 .5rem}.as-header p{color:#64748b;margin:0}.as-form{display:flex;flex-direction:column;gap:1.5rem}.as-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.as-form-group{display:flex;flex-direction:column;gap:.5rem}.as-form-group label{font-size:14px;font-weight:600;color:#374151}.as-form-group select{padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;color:#1e293b;background:#fff;cursor:pointer;transition:border-color .2s}.as-form-group select:focus{outline:none;border-color:#667eea}.as-upload-zone{border:2px dashed #cbd5e1;border-radius:12px;padding:2.5rem;text-align:center;transition:all .3s;background:#f8fafc;cursor:pointer}.as-upload-zone:hover,.as-upload-zone.drag-active{border-color:#667eea;background:#f0f4ff}.as-upload-zone.has-file{border-color:#10b981;background:#ecfdf5}.as-file-input{display:none}.as-upload-label{display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer}.as-upload-icon{font-size:48px;color:#94a3b8}.as-upload-zone:hover .as-upload-icon,.as-upload-zone.drag-active .as-upload-icon{color:#667eea}.as-upload-text{font-size:16px;font-weight:500;color:#475569}.as-upload-subtext{font-size:14px;color:#94a3b8}.as-file-icon{font-size:48px}.as-file-icon.success{color:#10b981}.as-file-name{font-size:16px;font-weight:600;color:#1e293b}.as-file-size{font-size:14px;color:#64748b}.as-actions{display:flex;gap:1rem;justify-content:space-between}.as-template-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;border:2px solid #667eea;border-radius:10px;color:#667eea;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.as-template-btn:hover{background:#667eea;color:#fff}.as-submit-btn{flex:1;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.as-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.as-submit-btn:disabled{opacity:.6;cursor:not-allowed}.as-result{margin-top:1.5rem;padding:1.25rem;border-radius:12px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.as-result.success{background:#ecfdf5;border:1px solid #a7f3d0}.as-result.error{background:#fef2f2;border:1px solid #fecaca}.as-result-header{display:flex;align-items:center;gap:10px;font-weight:600;margin-bottom:1rem}.as-result-icon{font-size:20px}.as-result-icon.success{color:#10b981}.as-result-icon.error{color:#ef4444}.as-result.success .as-result-header{color:#065f46}.as-result.error .as-result-header{color:#991b1b}.as-result-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:1rem}.as-summary-item{background:#fff;padding:12px;border-radius:8px;text-align:center}.as-summary-item span{display:block;font-size:12px;color:#64748b;margin-bottom:4px}.as-summary-item strong{font-size:20px;color:#1e293b}.as-summary-item.error strong{color:#ef4444}.as-result-note{background:#fff;padding:12px;border-radius:8px;font-size:14px;color:#475569}.as-error-list{margin-top:1rem;font-size:13px;color:#991b1b}.as-error-list ul{margin:.5rem 0 0 1.5rem;padding:0}.as-error-list li{margin:4px 0}.as-instructions{margin-top:2rem;padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.as-instructions h4{margin:0 0 .75rem;color:#1e293b;font-size:16px}.as-instructions p{margin:0 0 .75rem;color:#64748b;font-size:14px}.as-instructions ul{margin:0;padding-left:1.25rem}.as-instructions li{margin:6px 0;color:#475569;font-size:14px}.as-instructions li strong{color:#1e293b}@media screen and (max-width: 768px){.add-student-page{padding:1rem;padding-top:80px}.add-student-container{padding:1.5rem}.as-header h2{font-size:1.5rem}.as-form-row{grid-template-columns:1fr}.as-upload-zone{padding:2rem 1.5rem}.as-upload-icon{font-size:40px}.as-actions{flex-direction:column}.as-template-btn,.as-submit-btn{width:100%;justify-content:center}.as-result-summary{grid-template-columns:repeat(2,1fr)}}@media screen and (max-width: 480px){.add-student-page{padding:.75rem;padding-top:70px}.add-student-container{padding:1.25rem;border-radius:12px}.as-header h2{font-size:1.25rem}.as-upload-zone{padding:1.5rem 1rem}.as-upload-icon,.as-file-icon{font-size:36px}.as-upload-text{font-size:14px}.as-result-summary{grid-template-columns:1fr 1fr;gap:.75rem}.as-summary-item{padding:10px}.as-summary-item strong{font-size:18px}.as-instructions{padding:1rem}}.sv-container{min-height:100vh;padding:2.5rem 2rem;background:linear-gradient(135deg,#f5f7fa,#e8ecf1,#f5f7fa);margin-top:60px}.sv-header{text-align:center;margin-bottom:2.5rem;animation:fadeInDown .6s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.sv-title-section{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.75rem}.sv-title-icon{width:52px;height:52px;color:#667eea;filter:drop-shadow(0 2px 4px rgba(102,126,234,.2));animation:iconFloat 3s ease-in-out infinite}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.sv-title-section h1{font-size:2.75rem;color:#1e293b;margin:0;font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sv-title-section p{color:#64748b;margin:.5rem 0 0;font-size:1.05rem;font-weight:400;letter-spacing:.2px}.sv-search-section{max-width:850px;margin:0 auto 2.5rem;animation:fadeInUp .6s ease-out .2s both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sv-search-form{display:flex;gap:1rem;margin-bottom:1.25rem}.sv-search-input-wrapper{flex:1;position:relative}.sv-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:#94a3b8;width:20px;height:20px;transition:color .2s ease;pointer-events:none}.sv-search-input:focus~.sv-search-icon{color:#667eea}.sv-search-input{width:100%;padding:16px 20px 16px 52px;border:2px solid #e2e8f0;border-radius:16px;font-size:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);background:#fff;box-shadow:0 1px 3px #0000000d;font-weight:400}.sv-search-input:hover{border-color:#cbd5e1;box-shadow:0 2px 6px #00000014}.sv-search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1f,0 2px 8px #00000014;transform:translateY(-1px)}.sv-search-input::placeholder{color:#94a3b8;font-weight:400}.sv-search-btn{padding:16px 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #667eea4d;letter-spacing:.3px;position:relative;overflow:hidden}.sv-search-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.sv-search-btn:hover:before{left:100%}.sv-search-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #667eea66}.sv-search-btn:active{transform:translateY(-1px)}.sv-categories{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap;padding:.75rem 0;justify-content:center}.sv-categories svg{color:#64748b}.sv-category-btn{padding:8px 18px;background:#fff;border:2px solid #e2e8f0;border-radius:24px;font-size:.875rem;color:#475569;cursor:pointer;transition:all .2s ease;font-weight:500;letter-spacing:.2px;box-shadow:0 1px 3px #0000000d}.sv-category-btn:hover{border-color:#667eea;color:#667eea;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 3px 8px #667eea26}.sv-category-btn:active{transform:translateY(0)}.sv-category-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 4px 12px #667eea4d}.sv-empty-state{max-width:1100px;margin:0 auto;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sv-recent-section,.sv-suggestions-section{background:#fff;border-radius:20px;padding:2rem;margin-bottom:1.75rem;box-shadow:0 2px 8px #0000000f,0 1px 3px #0000000a;border:1px solid rgba(226,232,240,.6);transition:box-shadow .3s ease}.sv-recent-section:hover,.sv-suggestions-section:hover{box-shadow:0 4px 16px #00000014,0 2px 6px #0000000a}.sv-recent-section h3,.sv-suggestions-section h3{color:#1e293b;margin:0 0 .75rem;font-size:1.35rem;font-weight:700;letter-spacing:-.3px}.sv-suggestions-section p{color:#64748b;margin:0 0 1.25rem;line-height:1.6}.sv-recent-tags{display:flex;flex-wrap:wrap;gap:.625rem}.sv-recent-tag{padding:10px 20px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:24px;color:#475569;cursor:pointer;transition:all .2s ease;font-weight:500;font-size:.9rem}.sv-recent-tag:hover{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);color:#1e293b;transform:translateY(-2px);box-shadow:0 3px 8px #0000001a}.sv-recent-tag:active{transform:translateY(0)}.sv-suggestions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}.sv-suggestion-card{display:flex;align-items:center;gap:.875rem;padding:1.25rem;background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #e2e8f0;border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:left;box-shadow:0 1px 3px #0000000a}.sv-suggestion-card:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 20px #667eea26;background:linear-gradient(135deg,#fff,#f8f9ff)}.sv-suggestion-card:active{transform:translateY(-2px)}.sv-suggestion-card svg{color:#667eea;flex-shrink:0;width:24px;height:24px}.sv-suggestion-card span{color:#334155;font-size:.925rem;font-weight:500;letter-spacing:.2px}.sv-results{max-width:1400px;margin:0 auto;animation:fadeIn .5s ease-out}.sv-results-title{color:#1e293b;margin-bottom:2rem;font-size:1.5rem;font-weight:700;letter-spacing:-.3px}.sv-videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.sv-video-card{background:#fff;border-radius:20px;overflow:hidden;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000f,0 1px 3px #0000000a;border:1px solid rgba(226,232,240,.6)}.sv-video-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #0000001f,0 4px 12px #0000000f;border-color:#667eea33}.sv-thumbnail-wrapper{position:relative;aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.sv-thumbnail-wrapper img{width:100%;height:100%;object-fit:cover;transition:transform .4s cubic-bezier(.4,0,.2,1)}.sv-video-card:hover .sv-thumbnail-wrapper img{transform:scale(1.08)}.sv-duration{position:absolute;bottom:10px;right:10px;background:#000000d9;color:#fff;padding:4px 8px;border-radius:6px;font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);letter-spacing:.3px}.sv-play-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sv-video-card:hover .sv-play-overlay{opacity:1}.sv-play-overlay svg{color:#fff;width:64px;height:64px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));transition:transform .2s ease}.sv-video-card:hover .sv-play-overlay svg{transform:scale(1.1)}.sv-video-details{padding:1.25rem}.sv-video-title{font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 .625rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5;letter-spacing:.1px}.sv-video-channel{font-size:.875rem;color:#64748b;margin:0 0 .625rem;font-weight:500}.sv-video-meta{display:flex;align-items:center;gap:.625rem;font-size:.8125rem;color:#94a3b8;font-weight:500}.sv-video-meta span{display:flex;align-items:center;gap:.375rem}.sv-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000eb;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease-out}.sv-modal{background:#1e293b;border-radius:20px;width:100%;max-width:1000px;overflow:hidden;position:relative;box-shadow:0 20px 60px #00000080;animation:modalSlideUp .4s cubic-bezier(.4,0,.2,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.sv-modal-close{position:absolute;top:-48px;right:0;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;padding:10px;transition:all .2s ease;z-index:1001;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sv-modal-close:hover{background:#fff3;transform:scale(1.1) rotate(90deg)}.sv-modal-close:active{transform:scale(1) rotate(90deg)}.sv-video-player{position:relative;width:100%;padding-bottom:56.25%;background:#000}.sv-video-player iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.sv-video-player iframe:fullscreen,.sv-video-player iframe:-webkit-full-screen,.sv-video-player iframe:-moz-full-screen,.sv-video-player iframe:-ms-fullscreen{width:100vw!important;height:100vh!important;position:fixed!important;top:0!important;left:0!important;z-index:9999!important}.sv-video-info{padding:2rem;color:#fff;background:linear-gradient(to bottom,#1e293b,#0f172a)}.sv-video-info h3{margin:0 0 .75rem;font-size:1.25rem;line-height:1.5;font-weight:600;letter-spacing:-.2px}.sv-video-info .sv-channel{color:#94a3b8;margin:0 0 1.25rem;font-size:.95rem;font-weight:500}.sv-video-stats{display:flex;gap:2rem;color:#94a3b8;font-size:.9rem;font-weight:500}.sv-video-stats span{display:flex;align-items:center;gap:.625rem}.sv-back-btn{display:block;margin:2.5rem auto 0;padding:14px 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #667eea4d;letter-spacing:.3px}.sv-back-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #667eea66}.sv-back-btn:active{transform:translateY(-1px)}@media screen and (max-width: 1024px){.sv-videos-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.sv-suggestions-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media screen and (max-width: 768px){.sv-container{padding:1.5rem 1rem;margin-top:60px}.sv-title-section{flex-direction:column;text-align:center;gap:.75rem}.sv-title-icon{width:44px;height:44px}.sv-title-section h1{font-size:2rem}.sv-title-section p{font-size:.95rem}.sv-search-form{flex-direction:column;gap:.875rem}.sv-search-input{padding:14px 18px 14px 48px;border-radius:14px}.sv-search-btn{width:100%;padding:14px;border-radius:14px}.sv-categories{justify-content:center;gap:.5rem}.sv-category-btn{padding:7px 16px;font-size:.85rem}.sv-suggestions-grid{grid-template-columns:1fr;gap:1rem}.sv-suggestion-card{padding:1rem}.sv-videos-grid{grid-template-columns:1fr;gap:1.5rem}.sv-video-card{border-radius:16px}.sv-video-details{padding:1.125rem}.sv-recent-section,.sv-suggestions-section{padding:1.5rem;border-radius:16px}.sv-modal-overlay{padding:0;align-items:center}.sv-modal{max-width:100%;border-radius:0;max-height:100vh;overflow-y:auto}.sv-modal-close{top:12px;right:12px;background:#000000b3;border:2px solid rgba(255,255,255,.3);border-radius:50%;padding:10px;z-index:1002;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sv-modal-close:hover{background:#000c}.sv-video-player{padding-bottom:56.25%}.sv-video-info{padding:1.5rem}.sv-video-info h3{font-size:1.1rem}.sv-video-stats{flex-wrap:wrap;gap:1.25rem}}@media screen and (max-width: 480px){.sv-container{padding:1.25rem .875rem}.sv-title-section h1{font-size:1.75rem}.sv-title-icon{width:40px;height:40px}.sv-title-section p{font-size:.9rem}.sv-search-input{padding:13px 16px 13px 46px;font-size:.95rem}.sv-search-btn{padding:13px;font-size:.95rem}.sv-category-btn{padding:6px 14px;font-size:.8rem}.sv-recent-section,.sv-suggestions-section{padding:1.25rem}.sv-recent-section h3,.sv-suggestions-section h3{font-size:1.2rem}.sv-suggestion-card{padding:.875rem}.sv-suggestion-card span{font-size:.875rem}.sv-videos-grid{gap:1.25rem}.sv-video-card{border-radius:14px}.sv-video-details{padding:1rem}.sv-video-title{font-size:.95rem}.sv-modal-close{top:10px;right:10px;width:36px;height:36px;padding:8px}.sv-video-info{padding:1.25rem}.sv-video-info h3{font-size:1rem}.sv-video-stats{font-size:.85rem;gap:1rem}.sv-back-btn{padding:12px 32px;font-size:.95rem}}@media screen and (max-width: 900px) and (orientation: landscape){.sv-modal-overlay{padding:0}.sv-modal{max-height:100vh;display:flex;flex-direction:row;border-radius:0}.sv-video-player{flex:1;padding-bottom:0;height:100vh}.sv-video-info{display:none}.sv-modal-close{top:12px;right:12px}}@media (hover: none) and (pointer: coarse){.sv-search-btn,.sv-category-btn,.sv-recent-tag,.sv-suggestion-card,.sv-video-card,.sv-back-btn,.sv-modal-close{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.sv-search-input{font-size:16px}}@media (prefers-reduced-motion: no-preference){.sv-video-card{animation:cardFadeIn .5s ease-out both}.sv-video-card:nth-child(1){animation-delay:.1s}.sv-video-card:nth-child(2){animation-delay:.2s}.sv-video-card:nth-child(3){animation-delay:.3s}.sv-video-card:nth-child(4){animation-delay:.4s}.sv-video-card:nth-child(5){animation-delay:.5s}.sv-video-card:nth-child(6){animation-delay:.6s}}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.feedback-container{max-width:1400px;margin:100px auto 2rem;padding:0 1.5rem}.feedback-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff}.feedback-header svg{flex-shrink:0}.feedback-header h1{margin:0;font-size:1.75rem}.feedback-header p{margin:.25rem 0 0;opacity:.9;font-size:.95rem}.anonymous-notice{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #10b981;border-radius:12px;color:#065f46;margin-bottom:1.5rem;font-size:.9rem}.anonymous-notice svg{flex-shrink:0;color:#10b981}.feedback-form-container{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014}.feedback-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#374151;font-size:.95rem}.select-wrapper{position:relative}.select-wrapper select{width:100%;padding:.875rem 2.5rem .875rem 1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:1rem;background:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:border-color .2s}.select-wrapper select:focus{outline:none;border-color:#667eea}.select-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#6b7280;pointer-events:none}.ratings-section{background:#f9fafb;padding:1.5rem;border-radius:12px}.ratings-section h3{margin:0 0 1.25rem;color:#1f2937;font-size:1.1rem}.star-rating-group{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e5e7eb}.star-rating-group:last-child{border-bottom:none}.star-rating-group label{font-weight:500;color:#374151}.stars{display:flex;align-items:center;gap:.25rem}.star{cursor:pointer;color:#d1d5db;transition:all .15s}.star.filled{color:#fbbf24;fill:#fbbf24}.star:hover{transform:scale(1.15)}.rating-value{margin-left:.75rem;font-weight:600;color:#6b7280;min-width:35px}.text-feedback-section{display:flex;flex-direction:column;gap:1.25rem}.text-feedback-section textarea{width:100%;padding:1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:.95rem;min-height:100px;resize:vertical;font-family:inherit;transition:border-color .2s}.text-feedback-section textarea:focus{outline:none;border-color:#667eea}.char-count{font-size:.8rem;color:#9ca3af;text-align:right}.submit-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50px;font-size:1rem;font-weight:600;width:280px;cursor:pointer;transition:all .2s}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.feedback-dashboard{display:flex;flex-direction:column;gap:2rem}.feedback-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.feedback-dashboard .stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f}.feedback-dashboard .stat-card svg{color:#667eea}.feedback-dashboard .stat-card h4{margin:0;font-size:.85rem;color:#6b7280;font-weight:500}.feedback-dashboard .stat-card p{margin:.25rem 0 0;font-size:1.5rem;font-weight:700;color:#1f2937}.department-filter{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f}.department-filter label{font-weight:600;color:#374151;white-space:nowrap}.department-filter .select-wrapper{width:200px}.department-stats-section{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 10px #0000000f}.department-stats-section h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:#1f2937}.department-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.dept-stat-card{padding:1rem;background:#f9fafb;border-radius:10px;text-align:center}.dept-stat-card h4{margin:0 0 .5rem;color:#374151}.dept-rating{display:flex;align-items:center;justify-content:center;gap:.25rem;font-size:1.25rem;font-weight:700}.dept-stat-card p{margin:.5rem 0 0;font-size:.8rem;color:#6b7280}.staff-summary-section{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 10px #0000000f}.staff-summary-section h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:#1f2937}.staff-table-container{overflow-x:auto}.staff-table{width:100%;border-collapse:collapse}.staff-table th,.staff-table td{padding:1rem;text-align:left;border-bottom:1px solid #e5e7eb}.staff-table th{background:#f9fafb;font-weight:600;color:#374151;font-size:.85rem;text-transform:uppercase}.staff-table td{color:#1f2937}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.role-badge.staff{background:#dbeafe;color:#1d4ed8}.role-badge.hod{background:#fef3c7;color:#b45309}.rating-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .75rem;border-radius:20px;color:#fff;font-weight:600;font-size:.9rem}.view-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:.85rem;cursor:pointer;transition:background .2s}.view-btn:hover{background:#5a67d8}.no-data{text-align:center;padding:3rem;color:#6b7280}.no-data svg{color:#d1d5db;margin-bottom:1rem}.feedback-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.feedback-modal{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:80vh;overflow-y:auto;padding:2rem;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280}.feedback-modal h2{margin:0;color:#1f2937}.staff-info{color:#6b7280;margin:.25rem 0 1.5rem}.feedback-list{display:flex;flex-direction:column;gap:1rem}.feedback-item{padding:1rem;background:#f9fafb;border-radius:10px;border-left:4px solid #667eea}.feedback-ratings{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.feedback-ratings span{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:#6b7280;background:#fff;padding:.25rem .5rem;border-radius:6px}.fb-text{margin:.5rem 0;font-size:.9rem;color:#374151;line-height:1.5}.fb-text.positive{color:#059669}.fb-text.improvement{color:#d97706}.fb-date{font-size:.75rem;color:#9ca3af}.no-feedbacks{text-align:center;color:#6b7280;padding:2rem}@media (max-width: 768px){.feedback-container{margin-top:70px;padding:0 1rem}.feedback-header{flex-direction:column;text-align:center;padding:1.25rem}.feedback-header h1{font-size:1.4rem}.feedback-form-container{padding:1.25rem}.star-rating-group{flex-direction:column;align-items:flex-start;gap:.5rem}.feedback-stats-row{grid-template-columns:1fr}.department-filter{flex-direction:column;align-items:stretch}.department-filter .select-wrapper{width:100%}.department-stats-grid{grid-template-columns:repeat(2,1fr)}.staff-table th,.staff-table td{padding:.75rem .5rem;font-size:.85rem}.feedback-modal{padding:1.25rem;max-height:90vh}.feedback-ratings{gap:.5rem}.feedback-ratings span{font-size:.7rem}}@media (max-width: 480px){.anonymous-notice{flex-direction:column;text-align:center}.department-stats-grid{grid-template-columns:1fr}.staff-table{font-size:.8rem}.view-btn{padding:.4rem .75rem;font-size:.75rem}}*,*:before,*:after{box-sizing:border-box}svg,svg *{box-sizing:content-box}html{scroll-behavior:smooth}body{margin:0;padding:0;font-family:Outfit,sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background-color:#e0e0e0;border-radius:10px}::-webkit-scrollbar-thumb{background-color:#5a5a5a;border-radius:10px}::-webkit-scrollbar-thumb:hover{background-color:#4a4a4a}
