@import "https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap";:root{--primary-red:#d92534;--primary-red-hover:#b01a26;--sidebar-bg:#151a25;--sidebar-hover:#222b3d;--bg-color:#f3f4f6;--text-main:#2d3748;--text-light:#718096;--border-color:#e2e8f0;--info-green:#2ecc71;--info-blue:#3498db;--info-lightblue:#5dade2;--info-gray:#7f8c8d}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);font-family:Roboto,sans-serif}a{color:inherit;text-decoration:none}.btn{cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.5rem 1rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-red{background-color:var(--primary-red);color:#fff}.btn-red:hover{background-color:var(--primary-red-hover)}.input-field{border:1px solid var(--border-color);border-radius:4px;outline:none;width:100%;padding:.5rem;transition:border-color .2s}.input-field:focus{border-color:var(--info-blue)}.login-wrapper{background-color:#f7f9fb;justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:#fff;border-radius:8px;flex-direction:column;align-items:center;width:100%;max-width:480px;padding:2.5rem 3rem;display:flex;position:relative;box-shadow:0 10px 40px #00000014}.login-lang{color:#3da5e6;cursor:pointer;align-items:center;gap:.25rem;font-size:.85rem;transition:opacity .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.login-lang:hover{opacity:.8}.login-header{text-align:center;margin-top:1rem;margin-bottom:1.5rem}.uni-logo-box{background-color:var(--primary-red);color:#fff;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;width:76px;height:76px;margin:0 auto 1.5rem;font-weight:700;display:flex}.hbm-text-top{font-size:14px;line-height:1}.hbm-text-bottom{font-size:28px;line-height:1.2}.login-header h2{color:var(--text-main);font-size:1.25rem;font-weight:500}.login-divider{text-align:center;width:100%;margin:1.5rem 0;position:relative}.login-divider:before{content:"";z-index:1;background-color:#e2e8f0;height:1px;position:absolute;top:50%;left:0;right:0}.login-divider span{z-index:2;color:#718096;background:#fff;padding:0 1rem;font-size:.9rem;position:relative}.login-form{flex-direction:column;gap:1.2rem;width:100%;display:flex}.form-group label,.captcha-group label{color:#4a5568;margin-bottom:.4rem;font-size:.85rem;display:block}.input-with-host{align-items:center;display:flex}.input-with-host .input-field{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0}.host-text{border:1px solid var(--border-color);color:#718096;white-space:nowrap;background-color:#fff;border-left:none;border-top-right-radius:4px;border-bottom-right-radius:4px;padding:.45rem .5rem;font-size:.85rem}.captcha-row{align-items:stretch;gap:.5rem;height:38px;display:flex}.captcha-box{background-image:repeating-linear-gradient(45deg,#e2e8f0 25%,#f7fafc 25% 50%,#e2e8f0 50% 75%,#f7fafc 75% 100%);background-size:10px 10px;border:1px dashed #cbd5e0;border-radius:4px;justify-content:center;align-items:center;padding:0 1rem;display:flex}.captcha-calc{color:#2d3748;letter-spacing:2px;text-shadow:1px 1px #ffffffb3;font-size:1.2rem;font-weight:700}.captcha-input{width:80px}.login-btn{border:1px solid var(--border-color);color:#4a5568;cursor:pointer;background-color:#f7fafc;border-radius:4px;flex:1;justify-content:center;align-items:center;gap:.5rem;transition:all .2s;display:flex}.login-btn:hover{background-color:#edf2f7}.error-msg{color:var(--primary-red);margin-top:.5rem;font-size:.8rem}.forgot-pass{text-align:center;margin:.5rem 0;font-size:.85rem}.forgot-pass a{color:#3da5e6}.forgot-pass a:hover{text-decoration:underline}.edevlet-btn{color:#fff;cursor:pointer;background-color:#d92534;border:none;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;padding:.75rem;font-size:1rem;transition:all .2s;display:flex;box-shadow:0 2px 4px #d9253433}.edevlet-btn:hover{background-color:#b01a26;box-shadow:0 4px 8px #d925344d}.edevlet-icon{color:#d92534;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.2rem;font-style:italic;font-weight:700;line-height:1;display:flex}.announcements{width:100%;margin-top:1.5rem}.announcement-btn{color:#3da5e6;cursor:pointer;background:#fff;border:1px solid #3da5e6;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.6rem;transition:all .2s;display:flex}.announcement-btn:hover{background-color:#ebf8ff}.timeout{color:#718096;margin-top:1rem;font-size:.8rem}.dashboard-container{max-width:1200px;margin:0 auto}.alert-box{color:#fff;background-color:#28a745;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.9rem;display:flex;box-shadow:0 2px 4px #28a74533}.close-alert{color:#fff;opacity:.8;cursor:pointer;background:0 0;border:none}.close-alert:hover{opacity:1}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;display:grid}.dash-card{color:#fff;cursor:default;border-radius:4px;gap:1rem;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 5px #0000001a}.dash-card:hover{transform:translateY(-2px);box-shadow:0 4px 10px #00000026}.card-icon{opacity:.9;align-items:flex-start;padding-top:.25rem;display:flex}.card-content h3{margin-bottom:.5rem;font-size:.9rem;font-weight:600;line-height:1.2}.card-content p{opacity:.9;margin-bottom:.2rem;font-size:.8rem;line-height:1.4}.detail-link{color:#fff;opacity:.9;margin-top:.5rem;font-size:.75rem;font-weight:500;display:inline-block}.detail-link:hover{opacity:1;text-decoration:underline}.bg-darkblue{background-color:#1a6296}.bg-green{background-color:#5cb85c}.bg-lightblue{background-color:#3da5e6}.bg-grayblue{background-color:#5d7b8e}.grades-container{max-width:1200px;margin:0 auto}.grades-header{align-items:center;gap:1rem;margin-bottom:1.5rem;font-size:.9rem;display:flex}.term-select{border:1px solid var(--border-color);background-color:#fff;border-radius:4px;width:300px;padding:.4rem}.tabs{border-bottom:1px solid var(--border-color);margin-bottom:1rem;display:flex}.tab{color:#718096;cursor:pointer;border:1px solid #0000;border-bottom:none;border-top-left-radius:4px;border-top-right-radius:4px;padding:.5rem 1rem;font-size:.9rem}.tab.active{color:#2d3748;border-color:var(--border-color);background-color:#f7fafc;margin-bottom:-1px}.table-responsive{border:1px solid var(--border-color);background:#fff;border-radius:4px;margin-bottom:2rem;overflow-x:auto}.grades-table{border-collapse:collapse;text-align:left;width:100%;font-size:.8rem}.grades-table th{color:#fff;white-space:nowrap;background-color:#8c8f92;padding:.75rem 1rem;font-weight:500}.grades-table td{border-bottom:1px solid var(--border-color);color:#4a5568;padding:.75rem 1rem}.grades-table tr:nth-child(2n){background-color:#f7fafc}.grades-table tr:hover{background-color:#edf2f7}.col-name{min-width:280px}.text-red{color:var(--primary-red)}.text-blue{color:#3182ce}.stat-btn{cursor:pointer;color:#4a5568;background:#fff;border:1px solid #cbd5e0;border-radius:4px;align-items:center;gap:.4rem;padding:.3rem .6rem;font-size:.75rem;transition:background .2s;display:flex}.stat-btn:hover{background:#edf2f7}.info-box{color:#31708f;background-color:#e0faff;border:1px solid #bce6f1;border-radius:4px;padding:1rem 1.5rem;font-size:.85rem;position:relative}.close-info{color:var(--primary-red);cursor:pointer;background:0 0;border:none;position:absolute;top:1rem;right:1rem}.info-title{margin-bottom:1rem;font-size:1rem;font-weight:700;text-decoration:underline}.info-subtitle{margin:1rem 0 .5rem;font-weight:700}.info-subtitle span{font-weight:400}.info-list{margin:0;padding-left:1.5rem}.info-list li{margin-bottom:.5rem}.attendance-table th,.attendance-table td{padding:.6rem .8rem}.text-right{text-align:right;padding-right:1.5rem!important}.att-status{color:#4a5568;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.info-circle{color:#3da5e6;cursor:pointer;border:1px solid #3da5e6;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.info-circle:hover{background-color:#ebf8ff}.table-footer{color:#fff;background-color:#8c8f92;border-bottom-right-radius:4px;border-bottom-left-radius:4px;padding:.3rem 1rem}.footer-content{justify-content:center;align-items:center;gap:1rem;display:flex}.footer-btn{color:#fff;cursor:pointer;opacity:.8;background:0 0;border:none;justify-content:center;align-items:center;padding:.2rem;display:flex}.footer-btn:hover{opacity:1}.pagination-text{font-size:.85rem}.page-select{color:#333;background:#fff;border:1px solid #fff;border-radius:2px;padding:.1rem .5rem;font-size:.8rem}.pagination-arrows{align-items:center;gap:.2rem;display:flex}.schedule-container{background-color:#fff;border-radius:4px;min-height:100%;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.schedule-top-info{border-bottom:1px solid #e2e8f0;margin-bottom:1rem;padding-bottom:.5rem}.schedule-top-info h3{color:#333;margin-bottom:.3rem;font-size:1.1rem;font-weight:400}.schedule-top-info p{color:#555;font-size:.95rem}.schedule-toolbar{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.schedule-dropdown-group{align-items:center;gap:1rem;display:flex}.schedule-dropdown-group label{color:#4a5568;font-size:.9rem}.print-btn{color:#4a5568;cursor:pointer;background-color:#fff;border:1px solid #cbd5e0;border-radius:4px;align-items:center;gap:.4rem;padding:.4rem 1rem;display:flex}.print-btn:hover{background-color:#f7fafc}.schedule-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=992px){.schedule-grid{grid-template-columns:1fr}}.schedule-column{flex-direction:column;gap:1.5rem;display:flex}.schedule-block{border:1px solid #e2e8f0}.schedule-block-header{color:#fff;background-color:#8a8d91;padding:.4rem .8rem;font-size:.9rem;font-weight:700}.schedule-table{border-collapse:collapse;width:100%}.schedule-table th,.schedule-table td{text-align:left;color:#2d3748;border:1px solid #e2e8f0;padding:.3rem .5rem;font-size:.75rem}.schedule-table th{color:#4a5568;background-color:#fff;font-weight:700}.schedule-table tbody tr:nth-child(2n){background-color:#fbfbfb}.schedule-table tbody tr:hover{background-color:#f1f5f9}.row-app td{font-weight:500;color:#2b7a0b!important}.empty-schedule-msg{color:#718096;padding:.5rem .8rem;font-size:.8rem}.office-hours-block .schedule-block-header{background-color:#8a8d91}.schedule-bottom-note{color:#4a5568;padding-left:.5rem;font-size:.85rem;font-style:italic}.sidebar{background-color:var(--sidebar-bg);color:#a0aec0;z-index:10;flex-direction:column;width:260px;height:100vh;transition:margin-left .3s;display:flex;overflow-y:auto;box-shadow:2px 0 10px #0000001a}.sidebar.closed{margin-left:-260px}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:#2d3748;border-radius:3px}.sidebar-logo{border-bottom:1px solid #2d3748;flex-direction:column;align-items:center;padding:1.5rem 1rem;display:flex}.uni-logo-box-small{background-color:var(--primary-red);color:#fff;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:1rem;font-weight:700;display:flex}.uni-logo-box-small .hbm-text-top{font-size:11px}.uni-logo-box-small .hbm-text-bottom{font-size:20px}.logo-text{color:#fff;text-align:center;font-size:.85rem;font-weight:500;line-height:1.3}.sidebar-title{color:#e2e8f0;text-align:center;border-bottom:1px solid #2d3748;padding:1rem;font-size:.85rem;font-weight:700}.sidebar-nav{flex:1;padding:.5rem 0}.nav-group{margin-bottom:2px}.nav-item{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.75rem;padding:.8rem 1rem;font-size:.85rem;transition:all .2s;display:flex}.nav-item:hover,.nav-item.active-group{background-color:var(--sidebar-hover);color:#fff}.ml-auto{margin-left:auto}.sub-menu{background-color:#0f141d;flex-direction:column;display:flex}.sub-item{color:#a0aec0;align-items:center;padding:.6rem 1rem .6rem 2.8rem;font-size:.8rem;transition:all .2s;display:flex;position:relative}.sub-item:before{content:"□";color:#718096;font-size:.6rem;position:absolute;left:1.5rem}.sub-item:hover{color:#fff;background-color:#1a202c}.sub-item.active{color:#fff;background-color:#2d3748}.sub-item.active:before{color:#fff}.header{color:#fff;z-index:5;background-color:#1a222f;justify-content:space-between;align-items:center;height:50px;padding:0 1.5rem;display:flex;box-shadow:0 2px 4px #0000001a}.header-left{align-items:center;gap:1rem;display:flex}.menu-btn{color:#fff;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.term-selector{font-size:.85rem;font-weight:500}.header-right{align-items:center;gap:1.5rem;display:flex}.header-icon-btn{color:#a0aec0;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:color .2s;display:flex;position:relative}.header-icon-btn:hover{color:#fff}.notification-btn{color:#a0aec0}.badge{background-color:var(--primary-red);color:#fff;border-radius:10px;padding:.1rem .3rem;font-size:.6rem;font-weight:700;position:absolute;top:-6px;right:-8px}.user-profile{cursor:pointer;align-items:center;gap:.75rem;display:flex}.avatar{border:1px solid #4a5568;border-radius:50%;width:28px;height:28px;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.user-name{font-size:.8rem;font-weight:500}.app-layout{min-height:100vh;display:flex}.main-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}.content-area{background-color:#fff;flex:1;padding:1.5rem;overflow-y:auto}
