@charset "UTF-8";@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap&subset=vietnamese);.header_navbar-search-clear{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:14px;padding:4px;position:absolute;right:50px;top:50%;transform:translateY(-50%)}.header_navbar-search-clear:hover{color:#ef4444}.bell-wrapper{background:none;border:none;padding:0}.notification-dropdown{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #e2e8f0cc;border-radius:12px;box-shadow:0 10px 25px #0000001a;display:flex;flex-direction:column;margin-top:15px;overflow:hidden;position:absolute;right:-10px;top:100%;width:350px;z-index:1000}.notif-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:15px}.notif-header h4{color:#0f172a;font-size:1rem;font-weight:600;margin:0}.notif-header span{color:#3b82f6;cursor:pointer;font-size:.85rem;font-weight:500}.notif-header span:hover{text-decoration:underline}.notif-list{max-height:350px;overflow-y:auto;padding:0}.notif-empty{color:#64748b;font-size:.9rem;padding:30px 15px;text-align:center}.notif-item{align-items:flex-start;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;gap:12px;padding:12px 15px;text-align:left;transition:all .2s}.notif-item:hover{background:#f8fafc}.notif-unread{background:#eff6ff}.notif-footer{background:#f8fafc;border-top:1px solid #e2e8f0;color:#475569;cursor:pointer;font-size:.85rem;font-weight:500;padding:10px;text-align:center}.notif-footer:hover{background:#f1f5f9}.skeleton-notif{animation:pulse 1.5s infinite;border-bottom:1px solid #f1f5f9;display:flex;gap:12px;padding:12px 15px}.skeleton-icon{background:#e2e8f0;border-radius:50%;height:24px;width:24px}.skeleton-text{flex:1 1}.skeleton-line{background:#e2e8f0;border-radius:4px;height:12px;margin-bottom:6px}body{font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif}.login-container{align-items:center;background-color:#f3f4f6;background:linear-gradient(135deg,#f3f4f6,#eef2f5);display:flex;height:100vh;justify-content:center;width:100%}.login-card{background:#fff;border:1px solid #00000005;border-radius:12px;box-shadow:0 4px 25px #0000000d;max-width:420px;padding:40px 45px;width:100%}.login-header{margin-bottom:35px;text-align:center}.login-header h2{color:#1f2937;font-size:24px;font-weight:700;margin:0}.form-group label{color:#4b5563}.form-group input{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:15px;outline:none;padding:12px 15px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.btn-login{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:15px;padding:14px;transition:background .3s ease;width:100%}.btn-login:hover{background:#2563eb}.btn-login:disabled{background:#9ca3af;cursor:not-allowed}.error-message{align-items:center;background:#fef2f2;border:1px solid #fee2e2;border-radius:6px;color:#dc2626;display:flex;font-size:14px;justify-content:center;margin-bottom:20px;padding:12px;text-align:center}.password-toggle-btn{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;padding:0;position:absolute;right:12px;transition:color .2s}.password-toggle-btn:hover{color:#4b5563}:root{--google-blue:#1a73e8;--google-blue-hover:#1765cc;--google-gray-border:#dadce0;--google-gray-light:#f1f3f4;--text-primary:#3c4043;--text-secondary:#70757a;--event-radius:4px}body{color:#3c4043;font-family:Google Sans,Roboto,Arial,sans-serif}.calendar-container{background:#fff;display:flex;flex-direction:column;height:calc(100vh - 64px);overflow:hidden}.gcal-header-container{align-items:center;background-color:#fff;display:flex;justify-content:space-between;padding:12px 24px 16px}.gcal-header-left{align-items:center;display:flex;gap:8px}.gcal-btn-today{background-color:initial;border:1px solid #747775;border-radius:100px;color:#444746;cursor:pointer;font-size:14px;font-weight:500;height:36px;line-height:34px;margin-right:8px;padding:0 16px;transition:background-color .15s,border-color .15s}.gcal-btn-today:hover{background-color:#f1f3f4}.gcal-nav-arrows{display:flex;gap:4px}.gcal-icon-btn{fill:#444746;align-items:center;background-color:initial;border:none;border-radius:50%;cursor:pointer;display:flex;height:40px;justify-content:center;transition:background-color .15s;width:40px}.gcal-icon-btn:hover{background-color:#f1f3f4}.gcal-title{color:#1f1f1f;font-size:22px;font-weight:400;margin:0 0 0 8px}.gcal-header-right{align-items:center;display:flex;gap:24px}.gcal-legend{color:#5f6368;display:flex;font-size:14px;gap:16px}.gcal-legend-item{align-items:center;display:flex;gap:6px}.gcal-dot{border-radius:50%;display:inline-block;height:10px;width:10px}.gv-dot{background-color:#4caf50}.ta-dot{background-color:#ff9800}.gcal-view-select{-webkit-appearance:none;appearance:none;background-color:initial;background-image:url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22%23444746%22%3E%3Cpath%20d%3D%22M7%2010l5%205%205-5z%22%2F%3E%3C%2Fsvg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:20px;border:1px solid #747775;border-radius:100px;color:#444746;cursor:pointer;font-size:14px;font-weight:500;height:36px;line-height:34px;outline:none;padding:0 36px 0 16px;transition:background-color .15s}.gcal-view-select:hover{background-color:#f1f3f4}.calendar-scroll-container{border-top:1px solid #dadce0;border-top:1px solid var(--google-gray-border);display:flex;flex:1 1;overflow:auto;position:relative;scroll-behavior:smooth}.time-column{border-right:1px solid #dadce0;border-right:1px solid var(--google-gray-border);flex-direction:column;flex-shrink:0;left:0;min-width:60px;width:60px;z-index:30}.time-column,.time-header-spacer{background:#fff;display:flex;position:-webkit-sticky;position:sticky}.time-header-spacer{align-items:flex-end;border-bottom:1px solid #dadce0;border-bottom:1px solid var(--google-gray-border);box-sizing:border-box;height:60px;justify-content:flex-end;padding-bottom:4px;padding-right:8px;top:0;z-index:40}.time-slot-label{box-sizing:border-box;flex-shrink:0;height:60px;min-height:60px;position:relative}.time-slot-label span{background-color:initial;color:#70757a;color:var(--text-secondary);font-size:11px;font-weight:500;line-height:1;position:absolute;right:8px;top:0;z-index:10}.teacher-grid-wrapper{display:flex;flex-direction:column;min-width:-webkit-max-content;min-width:max-content}.teacher-header-row{background:#fff;border-bottom:1px solid #dadce0;border-bottom:1px solid var(--google-gray-border);box-sizing:border-box;display:flex;height:60px;position:-webkit-sticky;position:sticky;top:0;z-index:20}.teacher-header-cell{align-items:center;background:#fff;border-right:1px solid #dadce0;border-right:1px solid var(--google-gray-border);display:flex;flex-direction:column;justify-content:center;min-width:200px;width:200px}.t-name{color:#3c4043;color:var(--text-primary);font-size:14px;font-weight:500;margin-bottom:4px}.t-badge{border-radius:12px;font-size:10px;font-weight:600;letter-spacing:.5px;padding:2px 8px}.badge-gv{background:#e8f0fe;color:#1967d2}.badge-ta{background:#fef7e0;color:#ea8600}.teacher-columns-container{display:flex;min-width:-webkit-max-content;min-width:max-content;position:relative}.teacher-day-column{background:#fff;border-right:1px solid #dadce0;border-right:1px solid var(--google-gray-border);min-width:200px;position:relative;width:200px}.grid-cell-bg{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--google-gray-light);box-sizing:border-box;flex-shrink:0;height:60px;min-height:60px}.current-time-line{background-color:#ea4335;height:2px;left:0;pointer-events:none;position:absolute;z-index:10}.current-time-line:before{background-color:#ea4335;border-radius:50%;content:"";height:10px;left:-5px;position:absolute;top:-4px;width:10px}.cal-event{border-radius:4px;border-radius:var(--event-radius);box-shadow:none;cursor:pointer;font-size:12px;left:2%;overflow:hidden;padding:4px 8px;position:absolute;transition:opacity .2s,box-shadow .2s;width:96%;z-index:5}.cal-event:hover{box-shadow:0 2px 6px #00000026;opacity:.95;z-index:15}.ev-title{font-size:12px;font-weight:600;margin-bottom:2px}.ev-room,.ev-time{font-size:11px;margin-bottom:2px;opacity:.9}.week-month-layout{border-top:1px solid #dadce0;border-top:1px solid var(--google-gray-border);font-family:Google Sans,Roboto,Arial,sans-serif}.wm-sidebar{padding-top:16px}.staff-filter-item{border-radius:0 16px 16px 0!important;margin-right:8px;padding:8px 12px!important;transition:background-color .2s}.staff-filter-item:hover{background-color:#f1f3f4!important;background-color:var(--google-gray-light)!important}.staff-filter-item input[type=checkbox]{accent-color:#70757a;accent-color:var(--text-secondary);cursor:pointer;height:16px;margin-right:12px!important;width:16px}.wm-calendar-wrapper{border:none!important;padding:0!important}.rbc-header{border-bottom:none!important;border-left:none!important;color:#70757a;color:var(--text-secondary);font-size:11px!important;font-weight:500!important;padding:12px 0!important;text-transform:uppercase}.rbc-header+.rbc-header{border-left:1px solid #dadce0!important;border-left:1px solid var(--google-gray-border)!important}.rbc-month-view,.rbc-time-view{border:none!important;border-radius:0!important}.rbc-day-bg,.rbc-month-view,.rbc-time-view{border-left:1px solid #dadce0!important;border-left:1px solid var(--google-gray-border)!important}.rbc-month-row{border-top:1px solid #dadce0!important;border-top:1px solid var(--google-gray-border)!important}.rbc-today{background-color:initial!important}.rbc-date-cell{padding-right:0!important;padding-top:4px!important;text-align:center!important}.rbc-date-cell.rbc-now>a{background-color:#1a73e8;background-color:var(--google-blue);border-radius:50%;color:#fff;display:inline-block;font-weight:500;height:24px;line-height:24px;text-align:center;width:24px}.rbc-event{border:none!important;border-radius:4px!important;box-shadow:none!important;font-size:12px!important;margin:1px 0!important;padding:2px 6px!important}.rbc-time-header{border-bottom:1px solid #dadce0!important;border-bottom:1px solid var(--google-gray-border)!important}.rbc-time-content{border-top:none!important}.rbc-timeslot-group{border-bottom:1px solid #f1f3f4!important;border-bottom:1px solid var(--google-gray-light)!important}.rbc-day-slot .rbc-time-slot{border-top:none!important}.rbc-day-slot{border-left:1px solid #dadce0!important;border-left:1px solid var(--google-gray-border)!important}.rbc-current-time-indicator{background-color:#ea4335!important;height:2px!important}.rbc-current-time-indicator:before{background-color:#ea4335;border-radius:50%;content:"";height:10px;left:-5px;position:absolute;top:-4px;width:10px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#dadce0;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#bdc1c6}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{-webkit-appearance:button;appearance:button;cursor:pointer;overflow:visible;text-transform:none}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{align-items:stretch;box-sizing:border-box;display:flex;flex-direction:column;height:100%}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar :after,.rbc-calendar :before{box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.rbc-ellipsis,.rbc-event-label,.rbc-row-segment .rbc-event-content,.rbc-show-more{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{border-bottom:1px solid #ddd;flex:1 0;font-size:90%;font-weight:700;min-height:0;overflow:hidden;padding:0 3px;text-align:center;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{background:none;border:none;color:inherit;cursor:pointer;margin:0;padding:0;-webkit-user-select:text;user-select:text}.rbc-row-content{position:relative;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:flex;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{-ms-overflow-style:none;height:100%;overflow-y:scroll;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{align-items:center;display:flex;flex-wrap:wrap;font-size:16px;justify-content:center;margin-bottom:10px}.rbc-toolbar .rbc-toolbar-label{flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{background:none;background-image:none;border:1px solid #ccc;border-radius:4px;color:#373a3c;display:inline-block;line-height:normal;margin:0;padding:.375rem 1rem;text-align:center;vertical-align:middle;white-space:nowrap}.rbc-toolbar button.rbc-active,.rbc-toolbar button:active{background-color:#e6e6e6;background-image:none;border-color:#adadad;box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.rbc-toolbar button.rbc-active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button:active:hover{background-color:#d4d4d4;border-color:#8c8c8c;color:#373a3c}.rbc-toolbar button:focus,.rbc-toolbar button:hover{background-color:#e6e6e6;border-color:#adadad;color:#373a3c}.rbc-toolbar button:hover{cursor:pointer}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:4px;border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px;border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media (max-width:767px){.rbc-toolbar{flex-direction:column}}.rbc-day-slot .rbc-background-event,.rbc-event{background-color:#3174ad;border:none;border-radius:5px;box-shadow:none;box-sizing:border-box;color:#fff;cursor:pointer;margin:0;padding:2px 5px;text-align:left;width:100%}.rbc-day-slot .rbc-slot-selecting .rbc-background-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-slot-selecting .rbc-event{cursor:inherit;pointer-events:none}.rbc-day-slot .rbc-selected.rbc-background-event,.rbc-event.rbc-selected{background-color:#265985}.rbc-day-slot .rbc-background-event:focus,.rbc-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{box-shadow:-1px 1px 5px 0 #33333380}.rbc-event-continues-prior{border-bottom-left-radius:0;border-top-left-radius:0}.rbc-event-continues-after{border-bottom-right-radius:0;border-top-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:flex;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;color:#3174ad;font-size:85%;font-weight:700;height:auto;line-height:normal;z-index:4}.rbc-show-more:focus,.rbc-show-more:hover{color:#265985}.rbc-month-view{border:1px solid #ddd;display:flex;flex:1 0;flex-direction:column;height:100%;position:relative;user-select:none;-webkit-user-select:none;width:100%}.rbc-month-header{display:flex;flex-direction:row}.rbc-month-row{display:flex;flex:1 0;flex-basis:0px;flex-direction:column;height:100%;overflow:hidden;position:relative}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{flex:1 1;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:flex;flex:1 0;flex-direction:row;overflow:hidden;right:1px}.rbc-day-bg{flex:1 0}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{background-color:#fff;border:1px solid #e5e5e5;box-shadow:0 5px 15px #00000040;padding:10px;position:absolute;z-index:5}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:flex;flex:1 0;flex-direction:column;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{border:1px solid #ddd;border-collapse:collapse;border-spacing:0;width:100%}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{border-bottom:1px solid #ddd;padding:3px 5px;text-align:left}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:flex;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{flex:1 1}.rbc-timeslot-group{border-bottom:1px solid #ddd;display:flex;flex-flow:column nowrap;min-height:40px}.rbc-header-gutter,.rbc-time-gutter{flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{bottom:0;left:0;margin-right:10px;position:absolute;right:0;top:0}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-event{align-items:flex-start;border:1px solid #265985;display:flex;flex-flow:column wrap;max-height:100%;min-height:20px;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{word-wrap:break-word;flex:1 1;height:100%;line-height:1;min-height:1em;width:100%}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{background-color:#fff;border-right:1px solid #ddd;left:0;margin-right:-1px;position:-webkit-sticky;position:sticky;z-index:10}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{flex:1 0;flex-basis:0px;min-width:auto}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-day-bg,.rbc-time-view-resources .rbc-header{flex:1 1;flex-basis:0 px;width:140px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{flex:1 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{background-color:#00000080;color:#fff;font-size:75%;padding:3px;position:absolute;width:100%;z-index:10}.rbc-slot-selecting{cursor:move}.rbc-time-view{border:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-height:0;width:100%}.rbc-time-view .rbc-time-gutter{text-align:right;white-space:nowrap}.rbc-time-view .rbc-allday-cell{box-sizing:initial;height:100%;position:relative;width:100%}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{box-sizing:border-box;min-height:20px}.rbc-time-header{display:flex;flex:0 0 auto;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-left:1px solid #ddd;border-right-width:0}.rbc-time-header>.rbc-row.rbc-row-resource,.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{border-left:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-width:0}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;flex-shrink:0}.rbc-time-content{align-items:flex-start;border-top:2px solid #ddd;display:flex;flex:1 0;overflow-y:auto;position:relative;width:100%}.rbc-time-content>.rbc-time-gutter{flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{user-select:none;-webkit-user-select:none;width:100%}.rbc-current-time-indicator{background-color:#74ad31;height:1px;left:0;pointer-events:none;position:absolute;right:0;z-index:3}.rbc-resource-grouping.rbc-time-header-content{display:flex;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.mobile-agenda-container{background-color:initial;padding:24px 0}.agenda-layout{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr}@media (min-width:1000px){.agenda-layout{grid-template-columns:340px 1fr}}.mini-calendar-wrapper{background:#fff;border:1px solid #f0f0f0;border-radius:16px;box-shadow:0 4px 16px #0000000a;padding:24px}.mc-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.mc-title{color:#262626;font-size:16px;font-weight:700}.mc-nav-btn{align-items:center;background:#fff;border:1px solid #ff4d4f;border-radius:50%;color:#ff4d4f;cursor:pointer;display:flex;height:30px;justify-content:center;transition:all .2s ease-in-out;width:30px}.mc-nav-btn:hover{background:#fff1f0;transform:scale(1.05)}.mc-days-header{color:#262626;font-size:14px;font-weight:600;margin-bottom:16px;text-align:center}.mc-days-header,.mc-grid{display:grid;grid-template-columns:repeat(7,1fr)}.mc-grid{grid-gap:16px 4px;gap:16px 4px}.mc-cell{align-items:center;border-radius:50%;color:#595959;cursor:pointer;display:flex;flex-direction:column;font-size:14px;font-weight:500;height:36px;justify-content:center;margin:0 auto;position:relative;transition:all .2s;width:36px}.mc-cell:hover:not(.mc-empty):not(.mc-selected){background-color:#f0f0f0}.mc-empty{color:#d9d9d9;cursor:default}.mc-selected{background-color:#d32f2f!important;box-shadow:0 4px 8px #d32f2f4d;color:#fff!important;font-weight:600}.mc-dots{bottom:-8px;display:flex;gap:4px;position:absolute}.dot-event{background-color:#faad14}.dot-event,.dot-today{border-radius:50%;height:5px;width:5px}.dot-today{background-color:#1890ff}.agenda-main-title{color:#262626;font-size:18px;font-weight:700;margin-bottom:24px;margin-top:0;text-align:center}.agenda-empty{background:#fff;border:1px dashed #d9d9d9;border-radius:16px;box-shadow:0 4px 16px #0000000a;color:#8c8c8c;font-size:15px;padding:60px 20px;text-align:center}.agenda-list{display:flex;flex-direction:column;gap:16px}.agenda-item{background-color:#fff;border:1px solid #f0f0f0;border-radius:16px;box-shadow:0 2px 12px #0000000a;display:flex;gap:28px;padding:24px 28px;transition:all .3s ease}.agenda-item:hover{border-color:#d9d9d9;box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.agenda-time-col{align-items:center;display:flex;flex-direction:column;min-width:50px}.time-text{color:#262626;font-size:14px;font-weight:600}.time-divider{background-color:#d9d9d9;border-radius:2px;flex:1 1;margin:10px 0;min-height:48px;width:2px}.agenda-content-col{flex:1 1;padding-top:2px}.agenda-class-title{color:#1890ff;font-size:16px;font-weight:600;line-height:1.4;margin-bottom:16px}.agenda-details-grid{display:flex;flex-direction:column;font-size:14px;gap:12px}.detail-row{align-items:baseline;display:flex}.detail-label{color:#8c8c8c;min-width:90px}.detail-value{color:#262626;flex:1 1;font-weight:500}.staff-link{color:#1890ff;cursor:pointer;text-decoration:none;transition:color .2s}.staff-link:hover{color:#096dd9}:root{--hv-grid:40px 110px 100px 1.5fr 1fr 120px 140px 100px}.hv-container{background-color:#f5f6fa;background-color:var(--bg-body);box-sizing:border-box;color:#2c3e50;color:var(--text-dark);font-family:Segoe UI,sans-serif;font-size:14px;padding:0}.hv-topbar{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease,margin-bottom .3s ease}.hv-topbar.active{grid-template-rows:1fr;margin-bottom:16px}.hv-title-group h2{color:#333;font-size:24px;font-weight:700;margin:0 0 4px}.hv-subtitle{color:#7f8c8d;color:var(--text-gray);font-size:13px;margin:0}.hv-actions-group{align-items:flex-end;display:flex;gap:12px;overflow:hidden}.btn-cancel{border:1px solid #ddd;border-radius:8px;color:#555;font-size:13px;font-weight:600;transition:all .2s ease}.btn-cancel:hover{background:#f9f9f9;border-color:#bbb}.btn-confirm{background:#ffb347;background:var(--primary);border-radius:8px;box-shadow:0 2px 4px #0000001a;font-size:13px;padding:8px 16px;transition:all .2s ease}.btn-confirm:hover{background:#ffa01a;background:var(--primary-hover);transform:translateY(-1px)}.btn-confirm:active{transform:translateY(0)}.hv-card{background:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 4px 12px #00000008;display:flex;flex-direction:column;min-height:500px;overflow-x:auto}.hv-row{grid-column-gap:12px;align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);column-gap:12px;display:grid;grid-template-columns:40px 110px 100px 1.5fr 1fr 120px 140px 100px;grid-template-columns:var(--hv-grid);min-width:1000px;padding:12px 16px}.hv-header{background-color:#2c3e50;border-top-left-radius:12px;border-top-right-radius:12px;color:#fff;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.hv-filter-row{background-color:#fff;border-bottom:2px solid #f1f1f1;padding:10px 16px}.hv-input{background:#fcfcfc;border:1px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-size:13px;outline:none;padding:8px 12px;transition:.2s;width:100%}.hv-input:focus{background:#fff;border-color:#ffb347;border-color:var(--primary);box-shadow:0 0 0 3px #ffb34726}.date-toggle-btn{background:#fcfcfc;border:1px solid #e0e0e0;border-radius:6px;color:#555;cursor:pointer;font-size:13px;padding:8px 10px;text-align:left;width:100%}.hv-date-popup{animation:fadeIn .2s ease-out;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 10px 30px #00000026;padding:15px;position:absolute;right:0;top:110%;width:280px;z-index:100}.popup-row{margin-bottom:10px}.popup-row label{color:#555;display:block;font-size:12px;font-weight:600;margin-bottom:4px}.popup-row input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;padding:6px;width:100%}.popup-actions{display:flex;justify-content:flex-end;margin-top:10px}.popup-actions button{background:none;border:none;color:#e53e3e;cursor:pointer;font-size:12px;font-weight:600}.popup-actions button:hover{text-decoration:underline}.hv-item{cursor:pointer;transition:background .1s}.hv-item:hover{background-color:#fffbf2}.hv-selected{background-color:#fff4e6!important}.hv-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hv-cell.center{display:flex;justify-content:center}.hv-cell.text-bold{color:#555;font-family:monospace;font-weight:700}.hv-cell.text-primary{color:#2c3e50;font-weight:600}.hv-cell.text-gray{color:#888;font-size:13px}.hv-cell input[type=checkbox]{accent-color:#ffb347;accent-color:var(--primary);cursor:pointer;height:16px;width:16px}.hv-status{border-radius:12px;display:inline-block;font-size:11px;font-weight:700;min-width:70px;padding:4px 10px;text-align:center;text-transform:uppercase}.hv-status.active{background:#dcfce7;color:#166534}.hv-status.inactive{background:#fee2e2;color:#991b1b}.hv-actions{gap:8px}.hv-actions,.hv-icon-btn{display:flex;justify-content:center}.hv-icon-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;font-size:14px;height:30px;transition:.2s;width:30px}.hv-icon-btn.edit{background:#f0f4f8;color:#555}.hv-icon-btn.edit:hover{background:#e2e8f0;color:#334155;transform:scale(1.05)}.hv-icon-btn.delete{background:#fff1f2;color:#e11d48}.hv-icon-btn.delete:hover{background:#ffe4e6;color:#be123c;transform:scale(1.05)}.hv-pagination-bar{align-items:center;background:#fcfcfc;border-bottom-left-radius:12px;border-bottom-right-radius:12px;border-top:1px solid #eee;display:flex;justify-content:space-between;margin-top:auto;padding:15px 20px}.hv-page-size{align-items:center;color:#666;display:flex;font-size:13px;gap:8px}.hv-page-size select{border:1px solid #ddd;border-radius:4px;cursor:pointer;outline:none;padding:4px 8px}.hv-pagination-controls{align-items:center;display:flex;gap:6px}.p-btn{border:1px solid #e0e0e0;color:#666}.p-btn:disabled{background:#f9f9f9}.hv-total-info{color:#999;font-size:13px}.hv-empty{color:#a3a3a3;font-style:italic;padding:60px;text-align:center}.spinner{border:4px solid #0000001a;border-left:4px solid var(--primary);height:36px;margin:0 auto 15px;width:36px}.hv-modal{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0006;inset:0;z-index:999}.hv-modal-content{animation:modalScale .2s ease-out;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:25px;text-align:center;width:350px}@keyframes modalScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-actions{justify-content:center}.hv-toast{align-items:flex-start;animation:slideInRight .3s ease-out;background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;display:flex;gap:12px;min-width:300px;padding:16px 20px;position:fixed;right:24px;top:24px;z-index:2000}.hv-toast.success{border-left-color:#22c55e}.hv-toast.error{border-left-color:#ef4444}.hv-toast.success .toast-icon{color:#22c55e}.hv-toast.error .toast-icon{color:#ef4444}.hv-container{display:flex;flex-direction:column;height:100%}.hv-topbar{margin-bottom:0}.hv-pagination-bar,.hv-topbar{flex-shrink:0}.hv-modal{align-items:center;animation:modalFadeIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:flex;height:100%;justify-content:center;left:0;padding:10px;position:fixed;top:0;width:100%;z-index:2000}.hv-modal-content{animation:modalSlideUp .3s cubic-bezier(.16,1,.3,1);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;font-family:Inter,Segoe UI,sans-serif;max-height:90vh;max-width:600px;overflow-y:auto;padding:24px 32px;position:relative;width:100%}.hv-modal-content h2{color:#1a1a1a;font-size:20px;font-weight:700;margin:0}.add-field{margin-bottom:16px;position:relative}.add-field input,.add-field select,.add-field textarea{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;color:#333;font-size:14px;height:48px;outline:none;padding:12px 14px;transition:all .2s ease;width:100%}.add-field textarea{height:auto;min-height:80px;resize:vertical}.add-field input:focus,.add-field select:focus,.add-field textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.add-field input:disabled,.add-field input[readOnly]{background-color:#f3f4f6;border-color:#e5e7eb;color:#6b7280;cursor:not-allowed}.add-field label{background:#fff;color:#9ca3af;font-size:14px;left:12px;padding:0 4px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s ease;z-index:1}.add-field textarea+label{top:24px}.add-field input:focus+label,.add-field input:not(:placeholder-shown)+label,.add-field select:focus+label,.add-field select:not([value=""])+label,.add-field textarea:focus+label,.add-field textarea:not(:placeholder-shown)+label{background:#fff;color:#3b82f6;font-size:11px;font-weight:600;left:10px;padding:0 6px;top:0}.add-field input[readOnly]:not(:placeholder-shown)+label{background:#0000;color:#6b7280}input[type=radio]{accent-color:#3b82f6;cursor:pointer;height:16px;width:16px}.add-buttons{border-top:1px dashed #f0f0f0;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px}.add-buttons button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;justify-content:center;padding:10px 20px;transition:all .2s}.btn-cancel{border:1px solid #e5e7eb!important}.btn-cancel:hover{background-color:#f9fafb;border-color:#d1d5db!important}.btn-submit{background-color:#2563eb;box-shadow:0 2px 4px #2563eb33}.btn-submit:hover{background-color:#1d4ed8;box-shadow:0 4px 6px #2563eb4d;transform:translateY(-1px)}.btn-submit:disabled{background-color:#93c5fd;box-shadow:none;cursor:not-allowed;transform:none}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hv-modal-content::-webkit-scrollbar{width:6px}.hv-modal-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.hv-modal-content::-webkit-scrollbar-track{background:#0000}.st-table-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:24px;padding:24px}.st-table-toolbar{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.st-table-heading{color:#1f2937;font-size:18px;margin:0}.st-table-wrapper{overflow-x:auto}.st-table{border-collapse:collapse;font-size:14px;text-align:left;width:100%}.st-table th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-weight:600;padding:14px 16px;white-space:nowrap}.st-table td{border-bottom:1px solid #f1f5f9;color:#334155;padding:14px 16px;vertical-align:middle}.st-table tr:hover td{background-color:#f8fafc}.st-center{text-align:center!important}.st-right{text-align:right!important}.st-empty{color:#999;font-style:italic;padding:40px!important;text-align:center}.st-checkbox{accent-color:#3b82f6;cursor:pointer;height:16px;margin:0;vertical-align:middle;width:16px}.st-row-selected td{background-color:#f0fdf4!important}.st-action-group{gap:8px;justify-content:center}.st-action-group,.st-btn-icon{align-items:center;display:flex}.st-btn-icon{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;gap:6px;padding:6px 12px;transition:all .2s}.st-btn-edit{background:#e0f2fe;color:#0284c7}.st-btn-edit:hover{background:#bae6fd}.st-btn-delete{background:#fee2e2;color:#ef4444}.st-btn-delete:hover{background:#fca5a5}.st-btn-view{background:#f3f4f6;color:#4b5563}.st-btn-view:hover{background:#e5e7eb}.st-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:4px 10px}.st-badge-active{background:#dcfce7;color:#166534}.st-badge-inactive{background:#f3f4f6;color:#4b5563}.st-table-card{display:flex;flex:1 1;flex-direction:column;margin-bottom:0;min-height:0;overflow:hidden}.st-table-wrapper{flex:1 1;overflow:auto}.st-table th{box-shadow:0 2px 2px -1px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:10}:root{--nv-grid:50px 120px 100px 1fr 140px 100px;--primary:#ffb347;--primary-hover:#ffa01a;--text-dark:#2c3e50;--text-gray:#7f8c8d;--bg-body:#f5f6fa}.nv-container{background-color:#f5f6fa;background-color:var(--bg-body);box-sizing:border-box;color:#2c3e50;color:var(--text-dark);font-family:Segoe UI,sans-serif;font-size:14px;margin-top:0;padding:0 20px 20px;transition:margin-left .3s ease,padding .3s ease;width:auto}@media (max-width:991.98px){.nv-container{margin-left:64px!important;padding:20px}}@media (max-width:575.98px){.nv-container{margin-left:60px!important;padding:15px}.nv-row{min-width:800px}}.nv-topbar{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease,margin-bottom .3s ease}.nv-topbar.active{grid-template-rows:1fr;margin-bottom:16px}.nv-top-actions{align-items:flex-end;display:flex;gap:12px;overflow:hidden}.nv-btn{align-items:center;border:none;border-radius:8px;box-shadow:0 2px 4px #0000000d;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:8px;padding:8px 16px;transition:all .2s ease}.nv-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}.nv-delete-bulk{background:#ef4444;color:#fff}.nv-delete-bulk:hover{background:#dc2626}.nv-cancel-bulk{background:#fff;border:1px solid #ddd;box-shadow:none;color:#555}.nv-cancel-bulk:hover{background:#f9f9f9}.nv-card{background:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 4px 12px #00000008;display:flex;flex-direction:column;min-height:500px;overflow-x:auto}.nv-row{grid-column-gap:12px;align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);column-gap:12px;display:grid;grid-template-columns:50px 120px 100px 1fr 140px 100px;grid-template-columns:var(--nv-grid);min-width:900px;padding:12px 16px}.nv-header{background-color:#2c3e50;border-top-left-radius:12px;border-top-right-radius:12px;color:#fff;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.nv-filter-row{background-color:#fff;border-bottom:2px solid #f1f1f1;padding:10px 16px}.nv-input{background:#fcfcfc;border:1px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-size:13px;outline:none;padding:8px 12px;transition:.2s;width:100%}.nv-input:focus{background:#fff;border-color:#ffb347;border-color:var(--primary);box-shadow:0 0 0 3px #ffb34726}.nv-row:not(.nv-header){cursor:pointer;transition:background .1s}.nv-row:not(.nv-header):hover{background-color:#fffbf2}.nv-selected{background-color:#fff4e6!important}.multi-active:hover{background-color:#fff4e6}.nv-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nv-cell.center{align-items:center;display:flex;justify-content:center}.nv-cell.bold{font-family:monospace;font-size:13px;font-weight:700}.nv-user{align-items:center;display:flex;gap:12px}.nv-avatar{background-color:#f8f9fa;border:1px solid #eee;border-radius:50%;flex-shrink:0;font-size:14px;height:36px;width:36px}.nv-user span{color:#34495e;font-weight:600}.nv-role{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;line-height:1.4;min-width:80px;padding:4px 10px;text-align:center}.nv-role.ceo{background:#f3e8ff;border:1px solid #d8b4fe;color:#7e22ce}.nv-role.quanly{background:#e0f2fe;border:1px solid #bae6fd;color:#0369a1}.nv-role.giaovien{background:#dcfce7;border:1px solid #86efac;color:#15803d}.nv-role.trogiang{background:#ffedd5;border:1px solid #fdba74;color:#c2410c}.nv-role.default{background:#f3f4f6;border:1px solid #e5e7eb;color:#4b5563}.nv-actions{display:flex;gap:8px;justify-content:center}.nv-delete-icon,.nv-view{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s;width:32px}.nv-view{background:#f0f4f8;border-color:#cbd5e1;color:#64748b}.nv-view:hover{background:#e2e8f0;color:#334155}.nv-delete-icon{background:#fff1f2;border-color:#fecdd3;color:#e11d48}.nv-delete-icon:hover{background:#ffe4e6;color:#be123c}.nv-pagination{background:#fcfcfc;border-bottom-left-radius:12px;border-bottom-right-radius:12px;border-top:1px solid #eee;justify-content:space-between;margin-top:auto;padding:15px 20px}.nv-page-size,.nv-pagination{align-items:center;display:flex}.nv-page-size{color:#666;font-size:13px;gap:8px}.nv-page-size select{border:1px solid #ddd;border-radius:4px;cursor:pointer;outline:none;padding:4px 8px}.nv-pagination-controls{gap:6px}.nv-pagination-controls,.p-btn{align-items:center;display:flex}.p-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;font-size:13px;font-weight:500;height:32px;justify-content:center;min-width:32px;transition:.2s}.p-btn:hover:not(:disabled){background:#fffdf5;border-color:#ffb347;border-color:var(--primary);color:#ffb347;color:var(--primary)}.active-page{align-items:center;background:#ffb347;background:var(--primary);border:1px solid #ffb347;border:1px solid var(--primary);border-radius:6px;color:#fff;cursor:default;display:flex;font-weight:600;height:32px;justify-content:center;min-width:32px}.p-btn:disabled{background:#f8fafc;cursor:not-allowed;opacity:.5}.nv-total-info{color:#94a3b8;font-size:13px}.nv-empty{color:#a3a3a3;font-style:italic;padding:60px;text-align:center}.nv-modal{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:999}.nv-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:25px;text-align:center;width:350px}.nv-modal-actions{display:flex;gap:12px;justify-content:center;margin-top:24px}.nv-toast{align-items:flex-start;animation:slideInRight .3s cubic-bezier(.16,1,.3,1);background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;display:flex;gap:12px;min-width:320px;padding:16px 20px;position:fixed;right:24px;top:24px;z-index:2000}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.nv-toast.success{border-left-color:#22c55e}.nv-toast.error{border-left-color:#ef4444}.toast-icon{font-size:20px;margin-top:-2px}.nv-toast.success .toast-icon{color:#22c55e}.nv-toast.error .toast-icon{color:#ef4444}.toast-content h4{color:#1e293b;font-size:14px;font-weight:600;margin:0}.toast-content p{color:#64748b;font-size:13px;line-height:1.4;margin:4px 0 0}.nv-container{display:flex;flex-direction:column;height:100%}.nv-topbar{margin-bottom:0}.nv-pagination-bar,.nv-topbar{flex-shrink:0}body{background-color:#f8f9fa;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:all .3s ease}.qllh-action-bar{background:#f8f9fa;justify-content:space-between;padding:20px 24px;transition:margin-left .3s ease}.qllh-action-bar,.qllh-filters{align-items:center;display:flex}.qllh-filters{gap:16px}.search-box{position:relative;width:280px}.search-box i{color:#9ca3af;font-size:14px;left:14px;position:absolute;top:50%;transform:translateY(-50%)}.search-box input{border:1px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-size:14px;outline:none;padding:10px 16px 10px 40px;transition:all .2s;width:100%}.search-box input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;outline:none;padding:10px 16px;transition:all .2s}.filter-select:focus{border-color:#3b82f6}.qllh-add-btn{align-items:center;background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:8px 16px;transition:background .2s ease}.qllh-add-btn:hover{background:#1d4ed8}.class-grid{grid-gap:20px;box-sizing:border-box;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:24px}.class-grid,.qllh-pagination{transition:margin-left .3s ease}.qllh-pagination{gap:6px;margin:10px 0 40px 250px}.qllh-pagination button{align-items:center;border:1px solid #e5e7eb;border-radius:8px;display:flex;font-weight:600;height:36px;justify-content:center;transition:all .2s;width:36px}.qllh-pagination button:hover:not(:disabled){border-color:#2563eb;color:#2563eb}.qllh-pagination .active-page{background:#2563eb;border-color:#2563eb}.qllh-pagination button:disabled{border-color:#e5e7eb;color:#d1d5db}.empty{border:2px dashed #e5e7eb;color:#9ca3af;font-weight:500;grid-column:1/-1;padding:60px 20px;text-align:center}.clickable-card,.empty{background:#fff;border-radius:12px}.clickable-card{border:1px solid #e5e7eb;cursor:pointer;display:flex;flex-direction:column;height:100%;padding-bottom:25px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.clickable-card:hover{border-color:#3b82f6;box-shadow:0 12px 24px #3b82f61f;transform:translateY(-4px)}.card-header{align-items:flex-start;border-bottom:1px dashed #f3f4f6;display:flex;gap:12px;justify-content:space-between;padding:16px 20px}.card-header>div:first-child{flex:1 1;min-width:0}.class-name{color:#111827;font-size:16px;font-weight:700;margin:0}.class-code-mini,.class-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.class-code-mini{color:#6b7280;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px;margin-top:4px}.badge.small{border-radius:20px;font-size:11px;font-weight:600;padding:4px 10px;text-transform:uppercase;white-space:nowrap}.badge.active{background-color:#dcfce7;color:#166534}.badge.pending{background-color:#fef3c7;color:#92400e}.card-body{flex:1 1;justify-content:space-between;padding:16px 20px}.card-body,.info-grid-minimal{display:flex;flex-direction:column}.info-grid-minimal{gap:10px}.info-item-mini{color:#4b5563;font-size:13px;gap:12px}.info-icon,.info-item-mini{align-items:center;display:flex}.info-icon{border-radius:8px;flex-shrink:0;font-size:14px;height:32px;justify-content:center;width:32px}.info-icon.text-blue{background-color:#eff6ff;color:#3b82f6}.info-icon.text-green{background-color:#ecfdf5;color:#10b981}.info-icon.text-orange{background-color:#fffbeb;color:#f59e0b}.info-icon.text-purple{background-color:#f5f3ff;color:#8b5cf6}.info-icon.text-teal{background-color:#f0fdfa;color:#0d9488}.info-text{align-items:center;display:flex;flex-wrap:wrap;font-size:13px;line-height:1.4}.info-label{color:#6b7280;font-weight:400;margin-right:6px}.info-value{color:#111827;font-weight:600}.info-value.text-danger{color:#e63946}.progress-section-mini{border-top:1px dashed #e5e7eb;margin-top:16px;padding-top:16px}.progress-text-row{display:flex;justify-content:space-between;margin-bottom:8px}.progress-label{color:#6b7280;font-size:13px;font-weight:500}.progress-count{color:#3b82f6;font-size:13px;font-weight:700}.progress-container-mini{background-color:#f3f4f6;border-radius:10px;height:8px;overflow:hidden;width:100%}.progress-bar-mini{background-color:#3b82f6;border-radius:10px;height:100%;transition:width .5s ease}@media (max-width:1000px){.class-grid,.qllh-action-bar,.qllh-pagination{margin-left:50px!important}}@media (max-width:768px){.qllh-action-bar{gap:16px}.qllh-action-bar,.qllh-filters{align-items:stretch;flex-direction:column}.search-box{width:100%}}@media (max-width:575.98px){.class-grid,.qllh-action-bar,.qllh-pagination{margin-left:0!important;width:100%}.qllh-add-btn{justify-content:center}.class-grid{grid-template-columns:1fr;padding:16px}}.dash-stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card-action-menu{flex-shrink:0;position:relative}.card-menu-trigger{align-items:center;background:#0000;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;font-size:13px;height:28px;justify-content:center;opacity:0;transition:all .15s ease;width:28px}.clickable-card:hover .card-menu-trigger{opacity:1}.card-menu-trigger:hover{background:#f3f4f6;color:#374151}.card-menu-dropdown{animation:dropdownFadeIn .15s ease;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 10px 30px #0000001f,0 4px 8px #0000000f;display:none;min-width:150px;overflow:hidden;position:absolute;right:0;top:calc(100% + 4px);z-index:100}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.card-action-menu:hover .card-menu-dropdown{display:block}.card-menu-item{align-items:center;background:#0000;border:none;color:#374151;cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:500;gap:9px;padding:10px 14px;text-align:left;transition:background .12s;width:100%}.card-menu-item:hover{background:#f5f7ff;color:#2563eb}.card-menu-item.danger{color:#dc2626}.card-menu-item.danger:hover{background:#fff5f5;color:#b91c1c}.card-menu-item i{font-size:12px;text-align:center;width:14px}.ql-tai-chinh-container{background-color:#f4f7f6;box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;padding:24px 32px}.ql-tai-chinh-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.ql-tai-chinh-title{color:#2c3e50;font-size:24px;font-weight:600;margin:0}.view-mode-tabs{background-color:#e2e8f0;border-radius:8px;display:flex;gap:4px;padding:4px}.tab-btn{background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.tab-btn:hover{color:#1e293b}.tab-btn.active{background-color:#fff;box-shadow:0 1px 3px #0000001a;color:#2563eb}.ql-tai-chinh-controls{align-items:center;display:flex;gap:12px}.control-label{color:#4b5563;font-size:14px;font-weight:600}.control-input-month{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;outline:none;padding:8px 12px;transition:border-color .2s}.control-input-month:focus{border-color:#2563eb}.btn-create-fee{background-color:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:9px 18px;transition:background-color .2s ease}.btn-create-fee:hover{background-color:#1d4ed8}.btn-create-fee.loading,.btn-create-fee:disabled{background-color:#9ca3af;cursor:not-allowed}.ql-table-container{background-color:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 4px 6px #00000005;overflow-x:auto;padding:0}.ql-table{border-collapse:collapse;text-align:left;white-space:nowrap;width:100%}.ql-table th{background-color:#f9fafb;border-bottom:2px solid #e5e7eb;color:#4b5563;font-size:13px;font-weight:600;padding:16px 20px;text-transform:uppercase}.ql-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:14px;padding:16px 20px;vertical-align:middle}.ql-table tbody tr:hover{background-color:#f9fafb}.empty-state{font-size:15px;line-height:1.6;padding:60px 20px!important}.td-code{color:#6b7280}.td-name{color:#111827;font-weight:600}.class-name{color:#2563eb;font-weight:600}.class-code{color:#6b7280;font-size:12px;margin-top:2px}.td-content{color:#4b5563}.td-amount{color:#dc2626;font-weight:700}.td-date{color:#4b5563}.status-badge{border-radius:6px;display:inline-block;font-size:12px;font-weight:600;min-width:70px;padding:6px 12px;text-align:center}.status-paid{background-color:#d1fae5;color:#065f46}.status-unpaid{background-color:#fee2e2;color:#991b1b}.status-pending{background-color:#fef3c7;color:#92400e}.status-cancelled{background-color:#f3f4f6;color:#374151}.pagination-container{align-items:center;background-color:#fff;border-radius:0 0 10px 10px;border-top:1px solid #e5e7eb;display:flex;gap:16px;justify-content:flex-end;padding:16px 20px}.pagination-info{color:#6b7280;font-size:14px}.pagination-controls{display:flex;gap:8px}.btn-page{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;padding:6px 14px;transition:all .2s}.btn-page:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.btn-page:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.notification-toast{align-items:center;animation:slideIn .3s ease-out;border-radius:8px;box-shadow:0 4px 12px #0000001a;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 20px;position:fixed;right:24px;top:24px;z-index:9999}.notification-toast.error{background-color:#fef2f2;border:1px solid #fecaca;color:#991b1b}.notification-toast.success{background-color:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}.btn-close-toast{background:#0000;border:none;color:inherit;cursor:pointer;font-size:18px;font-weight:700;opacity:.6}.btn-close-toast:hover{opacity:1}.loading-state{color:#6b7280;padding:60px 0;text-align:center}.spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;height:30px;margin:0 auto 12px;width:30px}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-weight:600;gap:8px;justify-content:center;outline:none;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-sm{font-size:13px;padding:6px 12px}.btn-md{font-size:14px;padding:8px 16px}.btn-lg{font-size:16px;padding:12px 24px}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover:not(:disabled){background-color:#059669}.btn-warning{background-color:#f59e0b;color:#fff}.btn-warning:hover:not(:disabled){background-color:#d97706}.btn-outline{background-color:initial;border:1px solid #d1d5db;color:#374151}.btn-outline:hover:not(:disabled),.btn-secondary{background-color:#f3f4f6}.btn-secondary{color:#374151}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.btn-icon{font-size:.9em}.bctk-container{background-color:#f4f7fd;box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow-x:hidden;padding:20px 30px;position:relative;transition:margin-left .3s ease}.bctk-loading{align-items:center;color:#636e72;display:flex;font-weight:500;height:100vh;justify-content:center}.bctk-cards-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(5,1fr);margin-bottom:25px}.bctk-card{background:#fff;border-radius:16px;box-shadow:0 4px 15px #00000008;cursor:pointer;padding:20px;transition:transform .2s ease,box-shadow .2s ease}.bctk-card:hover{box-shadow:0 8px 25px #0000000f;transform:translateY(-3px)}.bctk-card-header{color:#1f2937;font-size:13px;font-weight:700;justify-content:space-between;margin-bottom:15px}.bctk-card-header,.bctk-icon{align-items:center;display:flex}.bctk-icon{border-radius:8px;font-size:14px;height:32px;justify-content:center;width:32px}.bctk-icon.blue{background:#e0e7ff;color:#4f46e5}.bctk-icon.green{background:#d1fae5;color:#10b981}.bctk-icon.orange{background:#ffedd5;color:#f97316}.bctk-icon.purple{background:#ede9fe;color:#8b5cf6}.bctk-icon.teal{background:#ccfbf1;color:#14b8a6}.bctk-badge{border-radius:20px;font-size:11px;font-weight:700;padding:4px 8px}.bctk-badge.green{background:#d1fae5;color:#10b981}.bctk-badge.purple{background:#ede9fe;color:#8b5cf6}.bctk-card-value{color:#111827;font-size:28px;font-weight:800;margin-bottom:5px}.bctk-card-desc{color:#6b7280;font-size:13px;font-weight:500}.bctk-charts-wrapper{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1.5fr 1fr;margin-bottom:25px}.bctk-chart-box{background:#fff;border-radius:16px;box-shadow:0 4px 15px #00000008;min-width:0;overflow:hidden;padding:20px}.bctk-chart-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.bctk-chart-header h3{color:#111827;font-size:16px;margin:0 0 5px}.bctk-chart-header p{color:#6b7280;font-size:13px;margin:0}.bctk-chart-filters button{background:#0000;border:none;border-radius:20px;color:#9ca3af;cursor:pointer;font-size:11px;font-weight:700;margin-left:5px;padding:6px 12px}.bctk-chart-filters button.active{background:#fef3c7;color:#d97706}.bctk-dots-menu{color:#9ca3af;cursor:pointer;font-size:20px}.bctk-chart-body{height:250px;width:100%}.bctk-progress-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.bctk-progress-card{background:#fff;border-radius:16px;box-shadow:0 4px 15px #00000008;padding:20px}.bctk-progress-title{color:#111827;font-size:14px;font-weight:700;margin-bottom:5px}.bctk-progress-value{color:#111827;font-size:28px;font-weight:800;margin-bottom:15px}.bctk-progress-bar-bg{background:#f3f4f6;border-radius:4px;height:8px;margin-bottom:10px;overflow:hidden;width:100%}.bctk-progress-fill{border-radius:4px;height:100%;transition:width 1s ease-in-out}.bctk-progress-fill.yellow{background:#fbbf24}.bctk-progress-fill.green{background:#10b981}.bctk-progress-fill.orange{background:#f97316}.bctk-progress-desc{color:#6b7280;font-size:13px}.bctk-fab-btn{align-items:center;background:#fbbf24;border:none;border-radius:16px;bottom:30px;box-shadow:0 4px 15px #fbbf2466;color:#fff;cursor:pointer;display:flex;font-size:32px;font-weight:300;height:56px;justify-content:center;position:fixed;right:30px;transition:transform .2s;width:56px}.bctk-fab-btn:hover{transform:scale(1.05)}.header-container{height:64px;left:0;position:fixed;right:0;top:0;z-index:1000}.sidebar-container{bottom:0;left:0;overflow-x:hidden;position:fixed;top:64px;transition:width .3s ease;width:250px;z-index:999}.main-content-wrapper{transition:margin-left .3s ease}@media (max-width:1366px){.bctk-cards-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:1000px){.bctk-container{margin-left:50px;padding:15px 20px}.bctk-progress-grid{grid-template-columns:repeat(2,1fr)}.sidebar-container{width:50px}.main-content-wrapper{margin-left:50px;width:calc(100% - 50px)}.sidebar-container .menu-text{opacity:0;transition:opacity .2s;visibility:hidden}.sidebar-container .menu-item{justify-content:center;padding-left:0}}@media (max-width:768px){.bctk-cards-grid{grid-template-columns:repeat(2,1fr)}.bctk-charts-wrapper,.bctk-progress-grid{grid-template-columns:1fr}.bctk-chart-body{height:200px}.bctk-chart-header{flex-direction:column;gap:10px}.bctk-fab-btn{bottom:20px;height:50px;right:20px;width:50px}}@media (max-width:480px){.bctk-cards-grid{grid-template-columns:1fr}}.thiet-lap-chung-container{--primary-color:var(--xb-main,#ffc107);background-color:#f8f9fa;box-sizing:border-box;max-width:100%;padding:2rem;transition:margin-left .3s ease,padding .3s ease}.setting-content{align-items:flex-start;background:#fff;border-radius:1rem;box-shadow:0 4px 12px #0000000d;display:flex;flex-wrap:nowrap;gap:3rem;margin-bottom:2rem;padding:2rem}@media (max-width:991.98px){.thiet-lap-chung-container{margin-left:64px!important;padding:1.5rem}.setting-content{flex-direction:column;gap:2rem;padding:1.5rem}.left-section{flex-direction:row;flex-wrap:wrap;justify-content:center;position:static!important;width:100%}.logo-upload-wrapper,.theme-selection{flex:1 1;max-width:300px}}@media (max-width:575.98px){.thiet-lap-chung-container{margin-left:60px!important;padding:1rem}.setting-content{padding:1rem}.form-row{gap:1rem}.campus-item,.form-row,.left-section{flex-direction:column}.campus-item{align-items:flex-start;gap:15px}.campus-item>div:first-child{width:100%}.campus-actions{display:flex;flex-direction:row;gap:10px;width:100%}.btn-delete-campus,.btn-edit-campus{flex:1 1;justify-content:center}}.left-section{align-items:center;display:flex;flex:0 0 260px;flex-direction:column;gap:2rem;position:-webkit-sticky;position:sticky;top:80px}.right-section{display:flex;flex:1 1;flex-direction:column;gap:1.25rem;min-width:0;width:100%}.thiet-lap-chung-container h1{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.75rem;font-weight:700;margin-bottom:1.5rem;padding-bottom:.5rem}.section-label{color:#4b5563;display:block;font-weight:600;margin-bottom:.75rem;text-align:center}.divider{border:0;border-top:1px dashed #e5e7eb;margin:3rem 0 2rem}.logo-upload-wrapper{align-items:center;display:flex;flex-direction:column;gap:1rem;width:100%}.logo-preview{align-items:center;background-color:#f9fafb;border:2px dashed #d1d5db;border-radius:1rem;display:flex;height:160px;justify-content:center;overflow:hidden;width:160px}.logo-preview img{height:100%;object-fit:contain;width:100%}.theme-selection{align-items:center;display:flex;flex-direction:column;width:100%}.color-grid{grid-gap:10px;background:#f3f4f6;border-radius:12px;display:grid;gap:10px;grid-template-columns:repeat(5,1fr);padding:12px}.color-swatch{border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;cursor:pointer;height:32px;transition:transform .2s;width:32px}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{border-color:#fff;box-shadow:0 0 0 2px #374151;transform:scale(1.2)}.form-group{width:100%}.form-group label{color:#374151;font-size:.9rem;font-weight:600;margin-bottom:.4rem}.form-input{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;box-sizing:border-box;color:#1f2937;font-size:.95rem;padding:.65rem .85rem;transition:border .2s;width:100%}.form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #0000000d;outline:none}.form-row{display:flex;gap:1rem}.half-width{flex:1 1}.save-button{background:var(--primary-color);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:.85rem;transition:filter .2s;width:100%}.save-button:hover{filter:brightness(.9)}.campus-section{width:100%}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.section-title{color:#1f2937;font-size:1.2rem;font-weight:700}.campus-count-badge{background:#e5e7eb;border-radius:12px;color:#374151;font-size:.75rem;margin-left:10px;padding:2px 8px}.campus-list{display:flex;flex-direction:column;gap:12px}.campus-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;display:flex;justify-content:space-between;padding:1rem;transition:all .2s ease}.campus-item:hover{border-color:var(--primary-color);box-shadow:0 4px 6px -1px #0000001a}.campus-info-name{color:#111827;font-size:1rem;font-weight:700}.campus-info-address{align-items:center;color:#6b7280;display:flex;font-size:.85rem;gap:6px;margin-top:4px}.campus-actions{display:flex;flex-direction:column;gap:8px}.btn-delete-campus,.btn-edit-campus{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:6px;padding:6px 12px;transition:background .2s}.btn-edit-campus{background:#eff6ff;color:#2563eb}.btn-edit-campus:hover{background:#dbeafe}.btn-delete-campus{background:#fef2f2;color:#dc2626}.btn-delete-campus:hover{background:#fee2e2}.btn-add-campus{align-items:center;background:#0000;border:2px dashed #d1d5db;border-radius:.75rem;color:#6b7280;cursor:pointer;display:flex;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:all .2s;width:100%}.btn-add-campus:hover{background:#fff;border-color:var(--primary-color);color:var(--primary-color)}.modal-overlay{animation:fadeIn .2s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;z-index:2000}.modal-content{animation:scaleIn .3s cubic-bezier(.16,1,.3,1);border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a;overflow-y:auto;padding:2rem}.modal-content h3{color:#111827;font-size:1.25rem;margin-bottom:1.5rem;margin-top:0;text-align:center}.modal-form-group{margin-bottom:1rem}.modal-label{color:#374151;display:block;font-size:.9rem;font-weight:600;margin-bottom:6px}.modal-actions{gap:12px;margin-top:1.5rem}.btn-cancel:hover{background:#f3f4f6}.btn-confirm{background:var(--primary-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:8px 20px}.btn-confirm:hover{filter:brightness(.9)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.tk-container{background-color:#f5f7fa;box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:0;transition:margin-left .3s ease,width .3s ease}body.sidebar-is-collapsed .tk-container{margin-left:64px;width:calc(100% - 64px)}.tk-header-wrapper{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.tk-title h2{color:#2c3e50;font-size:24px;margin:0}.tk-title p{color:#7f8c8d;font-size:14px;margin:5px 0 0}.tk-create-btn{align-items:center;background-color:#27ae60;border:none;border-radius:8px;box-shadow:0 4px 10px #27ae6033;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 24px;transition:background .2s}.tk-create-btn:hover{background-color:#219150}.tk-tabs{display:flex;gap:15px;margin-bottom:20px}.tk-tab-btn{align-items:flex-start;background-color:#fff;border:1px solid #0000;border-radius:12px;box-shadow:0 2px 5px #0000000d;color:#7f8c8d;cursor:pointer;display:flex;flex-direction:column;font-weight:600;min-width:160px;padding:15px 24px;transition:all .2s}.tk-tab-btn:hover{background-color:#fafafa}.tk-tab-btn span{font-size:12px;font-weight:400;margin-top:4px;opacity:.8}.tk-tab-btn strong{font-size:16px}.tk-tab-btn.active{border-color:#0000;color:#fff;transform:translateY(-2px)}.tk-tab-btn.tab-admin.active{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 5px 15px #e74c3c66}.tk-tab-btn.tab-teacher.active{background:linear-gradient(135deg,#f1c40f,#f39c12);box-shadow:0 5px 15px #f1c40f66}.tk-tab-btn.tab-user.active{background:linear-gradient(135deg,#3498db,#2980b9);box-shadow:0 5px 15px #3498db66}.tk-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000d;overflow:hidden}.tk-row{grid-gap:15px;align-items:center;border-bottom:1px solid #f0f0f0;display:grid;gap:15px;grid-template-columns:50px 150px 200px 140px 180px 1fr;padding:16px 20px}.tk-row:last-child{border-bottom:none}.tk-header{background-color:#f8f9fa;color:#7f8c8d;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.tk-cell{color:#34495e;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tk-cell.center{text-align:center}.tk-cell.bold{color:#2c3e50;font-weight:600}.tk-batch-container{animation:fadeIn .3s ease;background:#fff;border:1px solid #eef2f7;border-radius:12px;box-shadow:0 4px 15px #0000000d;margin:20px;padding:20px}.tk-table-scroll{border:1px solid #ecf0f1;border-radius:8px;margin-bottom:20px;overflow-x:auto}.tk-batch-table{border-collapse:collapse;min-width:1000px;width:100%}.tk-batch-table th{background:#f8f9fa;border-bottom:2px solid #dfe6e9;border-right:1px solid #ecf0f1;color:#2c3e50;font-size:13px;font-weight:700;padding:12px 10px;text-align:left;white-space:nowrap}.tk-batch-table td{border-bottom:1px solid #f1f2f6;border-right:1px solid #f8f9fa;padding:6px;vertical-align:top}.tk-input-sm{background:#0000;border:1px solid #0000;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:13px;padding:8px 10px;transition:all .2s;width:100%}.tk-input-sm:hover{background:#f8f9fa;border-color:#e0e0e0}.tk-input-sm:focus{background:#fff;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.tk-input-sm.readonly{background:#f1f8e9;color:#27ae60;font-weight:700;pointer-events:none;text-align:center}.tk-btn-save{align-items:center;background-color:#27ae60;border:none;border-radius:8px;box-shadow:0 4px 6px #27ae6033;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 24px;transition:.2s}.tk-btn-save:hover{background-color:#219150;transform:translateY(-1px)}.tk-btn-cancel{background-color:#ecf0f1;border:none;border-radius:8px;color:#7f8c8d;cursor:pointer;font-weight:600;padding:10px 20px;transition:.2s}.tk-btn-cancel:hover{background-color:#dfe6e9;color:#2c3e50}.tk-btn-outline{align-items:center;background-color:#fff;border:1px solid #bdc3c7;border-radius:8px;box-shadow:0 2px 5px #0000000d;color:#2c3e50;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:8px;height:38px;justify-content:center;padding:8px 16px!important;transition:all .2s ease}.tk-btn-outline:hover{background-color:#f8f9fa;border-color:#95a5a6;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}button.tk-btn-outline[style*=background]{border:none;box-shadow:0 4px 10px #27ae6033}button.tk-btn-outline[style*=background]:hover{filter:brightness(110%);transform:translateY(-2px)}@media (max-width:768px){.tk-batch-container>div:first-child{align-items:flex-start;flex-direction:column;gap:15px}.tk-batch-container>div:first-child>div{justify-content:space-between;width:100%}}.tk-pagination{align-items:center;background-color:#fff;border-bottom-left-radius:12px;border-bottom-right-radius:12px;border-top:1px solid #ecf0f1;display:flex;justify-content:space-between;padding:15px 20px}.tk-pagination-info{color:#7f8c8d;font-size:13px}.tk-pagination-controls{display:flex;gap:5px}.tk-page-btn{align-items:center;background:#fff;border:1px solid #dfe6e9;border-radius:6px;color:#2c3e50;cursor:pointer;display:flex;font-size:13px;height:32px;justify-content:center;min-width:32px;transition:all .2s}.tk-page-btn:hover:not(:disabled){background-color:#f1f2f6;border-color:#bdc3c7}.tk-page-btn.active{background-color:#3498db;border-color:#3498db;color:#fff;font-weight:700}.tk-page-btn:disabled{background-color:#f9f9f9;cursor:not-allowed;opacity:.5}.tk-loading-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#ffffffd9;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.tk-spinner{animation:spin 1s linear infinite;border:5px solid #ecf0f1;border-radius:50%;border-top-color:#3498db;height:50px;margin-bottom:15px;width:50px}.tk-loading-text{animation:pulse 1.5s infinite;color:#2c3e50;font-size:18px;font-weight:600}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.tk-lock-screen{align-items:center;color:#7f8c8d;display:flex;flex-direction:column;height:calc(100vh - 100px);justify-content:center;text-align:center}.tk-lock-icon{color:#bdc3c7;font-size:64px;margin-bottom:20px}.tk-lock-btn{background-color:#2c3e50;border:none;border-radius:30px;box-shadow:0 4px 15px #2c3e504d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 30px;transition:all .3s}.tk-lock-btn:hover{background-color:#34495e;transform:translateY(-2px)}.tk-modal{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:2000}.tk-modal-content{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 10px 30px #0003;padding:30px;width:400px}.tk-input{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:14px;margin:8px 0 16px;padding:12px;width:100%}.tk-input:focus{border-color:#3498db;outline:none}.tk-btn-confirm{background:#2c3e50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:700;padding:12px;transition:background .2s;width:100%}.tk-btn-confirm:hover{background:#1a252f}.tk-btn-close{background:none;border:none;color:#95a5a6;cursor:pointer;font-size:24px;position:absolute;right:15px;top:15px}.tk-container{display:flex;flex-direction:column;gap:20px;height:100%}.tk-topbar{margin-bottom:0}.tk-pagination-bar,.tk-topbar{flex-shrink:0}.qltt-page-container{background-color:#f5f7fa;box-sizing:border-box;padding:24px}.qltt-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.qltt-title{color:#333;font-size:24px;font-weight:700;margin:0}.qltt-add-btn{align-items:center;background-color:#0d6efd;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 16px;transition:background-color .2s}.qltt-add-btn:hover{background-color:#0b5ed7}.qltt-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;padding:20px}.qltt-loading{color:#666;padding:40px 0;text-align:center}.qltt-table-wrapper{overflow-x:auto}.qltt-table{border-collapse:collapse;width:100%}.qltt-th{background-color:#fafafa;border-bottom:2px solid #eaeaea;color:#555;font-weight:600;padding:12px 16px;text-align:left}.qltt-th-center{text-align:center}.qltt-td{border-bottom:1px solid #eaeaea;color:#333;padding:12px 16px;vertical-align:middle}.qltt-td-center{text-align:center}.qltt-tr{transition:background .2s}.qltt-tr:hover{background-color:#f9fafb}.qltt-td-code{color:#1890ff;font-weight:600}.qltt-logo-wrapper{align-items:center;display:flex}.qltt-logo-img{border:1px solid #eee;border-radius:6px;object-fit:cover}.qltt-logo-img,.qltt-logo-placeholder{height:36px;margin-right:12px;width:36px}.qltt-logo-placeholder{align-items:center;background-color:#f0f2f5;border-radius:6px;color:#a0aabf;display:flex;justify-content:center}.qltt-center-name{font-weight:500}.qltt-no-phone{color:#999;font-style:italic}.qltt-action-btn{border-radius:4px;cursor:pointer;margin-right:8px;padding:6px 12px}.qltt-action-btn.delete{border-color:red;color:red}.qltt-empty{color:#888;padding:40px 0;text-align:center}.qltt-empty-icon{color:#ddd;font-size:40px;margin-bottom:10px}.cd-container{background-color:#fff;display:flex;flex-direction:column;transition:margin-left .3s ease}@media (max-width:1000px){.cd-container{margin-left:50px}}.cd-header{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;gap:20px;padding:20px 30px}.cd-back-btn{background:#f3f4f6;border-radius:8px;color:#4b5563;font-weight:600;padding:8px 16px;transition:all .2s}.cd-back-btn:hover{background:#e5e7eb;color:#1f2937}.cd-title-area{display:flex;flex-direction:column}.cd-class-name{color:#111827;font-size:22px;font-weight:700;margin:0}.cd-class-code{color:#6b7280;font-family:monospace;font-size:13px;margin-top:4px}.cd-tabs-wrapper{border-bottom:2px solid #e5e7eb;padding:0 30px}.cd-tabs-container{display:flex;gap:30px;overflow-x:auto}.cd-tab-btn{background:#0000;border:none;color:#6b7280;cursor:pointer;font-size:15px;font-weight:600;padding:16px 0;position:relative;transition:color .3s;white-space:nowrap}.cd-tab-btn:hover{color:#374151}.cd-tab-btn.active{color:#6366f1}.cd-tab-btn:after{background-color:#6366f1;bottom:-2px;content:"";height:2px;left:0;position:absolute;transform:scaleX(0);transition:transform .3s ease;width:100%}.cd-tab-btn.active:after{transform:scaleX(1)}.cd-content-area{background-color:#f9fafb;border-radius:0 0 12px 12px;flex:1 1;padding:30px}.cd-info-card,.cd-table-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:24px;padding:24px}.cd-info-grid{display:flex;flex-wrap:wrap;gap:24px}.cd-info-item{background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;flex:1 1;min-width:250px;padding:16px}.cd-info-label{color:#64748b;display:block;font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.cd-info-value{align-items:center;color:#1e293b;display:flex;font-size:15px;gap:10px}.cd-btn{border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.btn-icon-edit{background:#e0f2fe;color:#0284c7;font-size:12px;padding:4px 8px}.btn-icon-edit:hover{background:#bae6fd}.cd-select{border:1px solid #cbd5e1;border-radius:6px;font-size:14px;outline:none;padding:6px 10px}.cd-table-toolbar{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.cd-table-heading{color:#1f2937;font-size:18px;margin:0}.btn-add-student{background:#10b981;color:#fff;font-size:14px;padding:8px 16px}.btn-add-student:hover:not(:disabled){background:#059669}.cd-table-wrapper{overflow-x:auto}.cd-table{border-collapse:collapse;font-size:14px;text-align:left;width:100%}.cd-table th{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#475569;font-weight:600;padding:12px 16px}.cd-table td{border-bottom:1px solid #f1f5f9;padding:12px 16px;vertical-align:middle}.cd-table tr:hover td{background-color:#f8fafc}.btn-icon-delete{background:#fee2e2;color:#ef4444;font-size:14px;padding:6px 10px}.btn-icon-delete:hover{background:#fca5a5}.center{text-align:center}.tab-content-placeholder{background:#fff;border:2px dashed #d1d5db;border-radius:12px;color:#9ca3af;font-size:15px;padding:60px;text-align:center}.cd-modal-overlay{align-items:center;background:#00000080;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:9999}.cd-modal-box{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000001a;max-width:400px;padding:24px;width:100%}.cd-modal-input{border:1px solid #cbd5e1;border-radius:6px;box-sizing:border-box;margin:15px 0;padding:10px;width:100%}.cd-modal-actions{display:flex;gap:10px;justify-content:flex-end}.cd-dashboard-container{display:flex;flex-direction:column;gap:24px}.dash-stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.dash-stat-card{align-items:center;background:#fff;border:1px solid #f1f5f9;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;display:flex;gap:16px;padding:20px;transition:transform .2s,box-shadow .2s}.dash-stat-card:hover{box-shadow:0 10px 20px -5px #00000014;transform:translateY(-3px)}.dash-stat-card .stat-icon{align-items:center;border-radius:14px;display:flex;font-size:24px;height:56px;justify-content:center;width:56px}.stat-info{flex:1 1}.stat-label{color:#64748b;font-size:13px}.stat-value-group{align-items:baseline;display:flex;gap:4px;margin-top:4px}.stat-value{color:#0f172a;font-size:26px;line-height:1}.stat-max{color:#94a3b8;font-size:14px;font-weight:600}.stat-progress-bg{background:#e2e8f0;border-radius:4px;height:6px;margin-top:10px;overflow:hidden;width:100%}.stat-progress-bar{border-radius:4px;height:100%}.dash-content-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}@media (max-width:992px){.dash-content-grid{grid-template-columns:1fr}}.dash-box{background:#fff;border:1px solid #f1f5f9;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;padding:24px}.dash-box-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.dash-box-title{color:#0f172a;font-size:18px;font-weight:700;margin:0}.next-session-card{align-items:center;background:linear-gradient(90deg,#f8fafc,#fff);border:1px dashed #cbd5e1;border-radius:12px;display:flex;gap:20px;padding:20px}.ns-date{background:#3b82f6;border-radius:12px;box-shadow:0 4px 6px -1px #3b82f64d;color:#fff;display:flex;flex-direction:column;justify-content:center;min-width:70px;padding:12px;text-align:center}.ns-day{font-size:28px;font-weight:800;line-height:1}.ns-month{font-size:11px;font-weight:600;margin-top:6px;opacity:.9;text-transform:uppercase}.ns-details{flex:1 1}.ns-details h4{color:#1e293b;font-size:16px;margin:0 0 8px}.ns-details p{align-items:center;color:#475569;display:flex;font-size:14px;gap:8px;margin:4px 0}.dash-action-btn{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:10px 16px;transition:.2s;white-space:nowrap}.dash-action-btn.primary{background:#3b82f6;color:#fff}.dash-action-btn.primary:hover{background:#2563eb;box-shadow:0 4px 10px #3b82f64d;transform:translateY(-2px)}.ns-empty{background:#f8fafc;border-radius:12px;color:#94a3b8;font-style:italic;padding:30px;text-align:center}.action-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.action-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:10px;justify-content:center;padding:16px;transition:all .2s}.action-item:hover{background:#f0fdf4;border-color:#3b82f6;box-shadow:0 4px 6px -1px #0000000d;transform:translateY(-2px)}.action-icon{align-items:center;border-radius:12px;display:flex;font-size:20px;height:44px;justify-content:center;width:44px}.action-item span{color:#334155;font-size:13px;font-weight:600}.dash-matrix-box{grid-column:span 1;overflow:hidden;padding:24px 0 0}.dash-matrix-box .dash-box-header{padding:0 24px 16px}.dash-view-more{align-items:center;background:#0000;border:none;color:#3b82f6;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px}.dash-view-more:hover{color:#1d4ed8;text-decoration:underline}.dash-matrix-wrapper{overflow-x:auto;overflow-y:hidden;padding-bottom:10px;width:100%}.dash-matrix-wrapper::-webkit-scrollbar{height:8px}.dash-matrix-wrapper::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px;margin:0 24px}.dash-matrix-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.dash-matrix-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dash-matrix{border-collapse:initial;border-spacing:0;min-width:800px;width:100%}.dash-matrix td,.dash-matrix th{border-bottom:1px solid #f1f5f9;padding:12px 8px;vertical-align:middle}.dash-matrix th{background:#fff;border-bottom:2px solid #e2e8f0;color:#475569;font-weight:600;text-align:center}.m-th-date{color:#64748b;font-size:12px}.m-th-badge{background:#f1f5f9;border-radius:12px;color:#334155;display:inline-block;font-size:11px;font-weight:700;margin-top:4px;padding:2px 8px}.dash-matrix .sticky-col{background:#fff;border-right:1px solid #e2e8f0;left:0;min-width:220px;padding-left:24px;position:-webkit-sticky;position:sticky;text-align:left;z-index:10}.dash-matrix tr:hover .sticky-col,.dash-matrix tr:hover td{background-color:#f8fafc}.m-student-info{gap:12px}.m-avatar,.m-student-info{align-items:center;display:flex}.m-avatar{background:#e0e7ff;border-radius:50%;color:#4338ca;flex-shrink:0;font-size:12px;font-weight:700;height:32px;justify-content:center;width:32px}.m-name{color:#1e293b;font-size:14px;font-weight:600;white-space:nowrap}:root{--header-height:64px;--sidebar-width-small:48px;--success-color:#10b981;--danger-color:#ef4444;--warning-color:#d97706;--text-primary:#1f2937;--bg-light:#f3f4f6}body{color:#1f2937;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;padding:0}.kqht-wrapper,body{background-color:#f3f4f6;background-color:var(--bg-light)}.kqht-wrapper{margin-left:0;margin-top:0;min-height:calc(100vh - 64px);min-height:calc(100vh - var(--header-height));padding:20px;transition:all .3s ease}.kqht-container{margin:0 auto;max-width:1200px;width:100%}@media (max-width:992px){.kqht-wrapper{margin-left:0}}.kqht-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:24px}.kqht-header,.kqht-header-left{align-items:center;display:flex;gap:15px}.kqht-header-right{align-items:center;display:flex;gap:10px}.kqht-title-group h1{color:#1f2937;color:var(--text-primary);font-size:24px;font-weight:700;margin:0}.kqht-title-group p{color:#6b7280;color:var(--text-secondary);font-size:14px;margin:4px 0 0}.btn-back-circle{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:50%;color:#374151;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;transition:all .2s;width:40px}.btn-back-circle:hover{background:#f9fafb;border-color:#d1d5db;transform:translateX(-2px)}.btn-create{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-color) 0,#2563eb 100%);border:none;border-radius:10px;box-shadow:0 4px 10px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-create:hover{background:linear-gradient(135deg,#60a5fa,#3b82f6);background:linear-gradient(135deg,#60a5fa 0,var(--primary-color) 100%);box-shadow:0 6px 15px #3b82f666;transform:translateY(-2px)}.btn-save{align-items:center;background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--success-color) 0,#059669 100%);border:none;border-radius:10px;box-shadow:0 4px 10px #10b9814d;color:#fff;cursor:pointer;display:flex;font-weight:600;justify-content:center;min-width:120px;padding:10px 24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-save:hover{background:linear-gradient(135deg,#34d399,#10b981);background:linear-gradient(135deg,#34d399 0,var(--success-color) 100%);box-shadow:0 6px 15px #10b98166;transform:translateY(-2px)}.btn-lock-all{align-items:center;background:linear-gradient(135deg,#d97706,#b45309);background:linear-gradient(135deg,var(--warning-color) 0,#b45309 100%);border:none;border-radius:10px;box-shadow:0 4px 10px #d977064d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-lock-all:hover{background:linear-gradient(135deg,#f59e0b,#d97706);background:linear-gradient(135deg,#f59e0b 0,var(--warning-color) 100%);box-shadow:0 6px 15px #d9770666;transform:translateY(-2px)}.btn-lock-all:disabled,.btn-save:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.kqht-card{background:#fff;border:1px solid #0000000a;border-radius:16px;box-shadow:0 10px 25px -5px #0000000d,0 8px 10px -6px #00000003;padding:24px;transition:box-shadow .3s ease}.kqht-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.table-responsive{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;min-height:300px;overflow-x:auto;width:100%}.kqht-table{border-collapse:collapse;min-width:900px;width:100%}.kqht-table thead th{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#374151;font-size:13px;font-weight:600;padding:14px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.kqht-table tbody td{border-bottom:1px solid #f3f4f6;color:#1f2937;color:var(--text-primary);font-size:14px;padding:12px 16px;vertical-align:middle}.kqht-table tbody tr:hover{background-color:#f9fafb}.clickable-row:hover{background-color:#eff6ff!important}.btn-icon-action{background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;color:#4f46e5;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s}.btn-icon-action:hover{background:#4f46e5;box-shadow:0 4px 6px #4f46e533;color:#fff;transform:translateY(-1px)}.empty-state{background-color:#f9fafb;color:#6b7280;color:var(--text-secondary);font-style:italic;padding:40px!important;text-align:center}.input-wrapper{display:inline-block;max-width:80px;position:relative;width:100%}.input-score{border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:600;padding:8px;text-align:center;transition:all .2s;width:100%}.input-score:focus{border-color:#3b82f6;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a;outline:none}.input-score.has-score{background-color:#eff6ff;border-color:#93c5fd;color:#1d4ed8;font-weight:700}.input-score.error-border{background-color:#fef2f2;border-color:#ef4444;border-color:var(--danger-color)}.input-note:disabled,.input-score:disabled{background-color:#f3f4f6!important;border-color:#e5e7eb!important;color:#9ca3af!important;cursor:not-allowed}.error-tooltip{background:#ef4444;background:var(--danger-color);border-radius:4px;color:#fff;font-size:11px;left:50%;margin-top:4px;padding:4px 8px;position:absolute;top:100%;transform:translateX(-50%);white-space:nowrap;z-index:10}.input-note{background:#0000;border:1px solid #0000;border-radius:6px;color:#4b5563;font-size:14px;padding:8px 12px;transition:all .2s;width:100%}.input-note:focus,.input-note:hover{background:#fff;border-color:#d1d5db;outline:none}.badge-type{background:#e0e7ff;border-radius:4px;color:#4338ca;font-size:11px;font-weight:700;padding:2px 8px;text-transform:uppercase}.fw-600{font-weight:600}.font-mono{color:#6b7280;font-family:monospace;font-size:13px}.pagination-toolbar{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.page-size-selector select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;padding:6px 12px}.page-info{color:#6b7280;color:var(--text-secondary);font-size:14px}.badge-status{border-radius:4px;font-size:11px;font-weight:700;padding:4px 8px;text-transform:uppercase;white-space:nowrap}.status-draft{background:#f3f4f6;border:1px solid #d1d5db;color:#6b7280}.status-finalized{background:#e0f2fe;border:1px solid #bae6fd;color:#0369a1}.status-published{background:#dcfce7;border:1px solid #86efac;color:#15803d}.action-btn-group{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.btn-action{background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;white-space:nowrap}.btn-finalize{background-color:#fffbeb;border-color:#fcd34d;color:#d97706}.btn-finalize:hover{background-color:#fef3c7}.btn-publish{background-color:#ecfdf5;border-color:#6ee7b7;color:#059669}.btn-publish:hover{background-color:#d1fae5}.btn-history{background-color:#eff6ff;border-color:#93c5fd;color:#2563eb}.btn-history:hover{background-color:#dbeafe}.btn-update{background-color:#eff6ff;border-color:#93c5fd;color:#2563eb}.btn-update:hover{background-color:#dbeafe;border-color:#2563eb}.modal-overlay{animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#11182766;bottom:0;right:0;z-index:9999}.modal-content{animation:popIn .4s cubic-bezier(.34,1.56,.64,1);background:#fff;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 25px 50px -12px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:500px;width:90%}.modal-header{background-color:#fff;border-bottom:1px solid #e5e7eb;border-radius:20px 20px 0 0;padding:24px 28px}.modal-header h3{color:#1f2937;font-size:18px}.close-btn{background:none;color:#9ca3af;font-size:24px}.close-btn:hover{color:#4b5563}.form-group,.modal-body{overflow-y:auto}.form-group{padding:20px}.history-list{list-style:none;margin:0;padding:0}.history-item{border-bottom:1px solid #f3f4f6;padding:12px 0}.history-time{color:#9ca3af;font-size:11px;margin-bottom:4px}.history-content{color:#374151;font-size:14px}.history-user{color:#3b82f6;color:var(--primary-color);font-weight:600}.modal-form-group{margin-bottom:16px}.modal-form-group label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.modal-input,.modal-textarea{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:10px;width:100%}.modal-input:focus,.modal-textarea:focus{border-color:#3b82f6;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a;outline:none}.modal-textarea{min-height:80px;resize:vertical}.modal-actions{border-top:1px solid #f3f4f6;display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:16px}.btn-cancel{background:#fff;border:1px solid #d1d5db;color:#374151}.btn-submit-update{background:#3b82f6;background:var(--primary-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px}.btn-submit-update:hover{background:#2563eb}.modal-overlay{align-items:center;background-color:#00000073;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:1000}.modal-content{animation:modalFadeIn .3s ease-out;background-color:#fff;border-radius:8px;box-shadow:0 6px 16px #00000014,0 3px 6px -4px #0000001f,0 9px 28px 8px #0000000d;max-width:90%;padding:24px;width:500px}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.modal-header h3{color:#1f1f1f;font-size:16px;font-weight:600;margin:0}.close-btn{background:#0000;border:none;color:#999;cursor:pointer;font-size:20px;line-height:1;transition:color .2s}.close-btn:hover{color:#ff4d4f}.form-group{margin-bottom:20px;text-align:left}.form-group label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-control{background-color:#fff;border:1px solid #d9d9d9;border-radius:6px;box-sizing:border-box;color:#1f1f1f;font-size:14px;line-height:1.5715;padding:8px 12px;transition:all .3s;width:100%}.form-control:focus{border-color:#1677ff;box-shadow:0 0 0 2px #1677ff33;outline:0}.form-control:disabled{background-color:#f5f5f5;color:#00000040;cursor:not-allowed}textarea.form-control{min-height:80px;resize:vertical}.modal-footer{display:flex;gap:12px;justify-content:flex-start;margin-top:32px}.btn-cancel{background-color:#fff;border:1px solid #d9d9d9;border-radius:6px;color:#333;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-cancel:hover{border-color:#1677ff;color:#1677ff}.btn-submit{background-color:#1677ff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-submit:hover{background-color:#4096ff}:root{--primary-color:#3b82f6;--primary-hover:#2563eb;--bg-body:#f3f4f6;--bg-card:#fff;--text-main:#111827;--text-secondary:#6b7280;--border-color:#e5e7eb;--success-bg:#ecfdf5;--success-border:#10b981;--success-text:#047857;--warning-bg:#fffbeb;--warning-border:#f59e0b;--warning-text:#b45309;--danger-bg:#fef2f2;--danger-border:#ef4444;--danger-text:#b91c1c}body{font-family:Inter,sans-serif}.dd-container{background-color:initial}.dd-card,.dd-container{box-sizing:border-box;width:100%}.dd-card{background:#fff;background:var(--bg-card);border:1px solid #00000005;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;margin-bottom:24px;padding:24px}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.dd-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}@media (max-width:640px){.dd-header{align-items:flex-start;flex-direction:column}.dd-header>div:last-child{align-items:center;display:flex;justify-content:space-between;width:100%}}.dd-title h2{color:#1f2937;font-size:20px;font-weight:800;margin:0}.dd-filter-section{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 4px #00000005;justify-content:space-between;margin-bottom:24px;padding:20px}.dd-filter-group,.dd-filter-section{display:flex;flex-wrap:wrap;gap:16px}.dd-filter-group{align-items:flex-end}.dd-filter-item{display:flex;flex-direction:column;gap:6px}.dd-filter-item label{color:#6b7280;color:var(--text-secondary);font-size:13px;font-weight:600;text-transform:uppercase}.dd-input-date{background:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#111827;color:var(--text-main);font-family:inherit;font-size:14px;min-width:150px;outline:none;padding:9px 12px}.dd-input-date:focus{background:#fff;border-color:#3b82f6;border-color:var(--primary-color)}.dd-stat-card{align-items:flex-end;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:10px;display:flex;flex-direction:column;min-width:180px;padding:10px 20px}.stat-label{color:#1e40af;font-size:12px;font-weight:600;text-transform:uppercase}.stat-value{color:#1e3a8a;font-size:20px;font-weight:800}.dd-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-weight:600;gap:6px;justify-content:center;padding:9px 18px;transition:all .2s}.dd-btn-primary{background-color:#3b82f6;background-color:var(--primary-color);color:#fff}.dd-btn-primary:hover:not(:disabled){box-shadow:0 4px 6px #3b82f64d;transform:translateY(-1px)}.dd-btn-success{background-color:#10b981;color:#fff}.dd-btn-success:hover:not(:disabled){background-color:#059669}.dd-btn-back{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#111827;color:var(--text-main)}.dd-btn-back:hover{background-color:#f9fafb;border-color:#d1d5db}.dd-btn:disabled{cursor:not-allowed;opacity:.6}.dd-btn-simple{align-items:center;background:none;border:none;color:#3b82f6;color:var(--primary-color);display:flex;font-family:inherit;gap:5px;padding:0}.dd-btn-icon,.dd-btn-simple{cursor:pointer;font-weight:600}.dd-btn-icon{background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;color:#4f46e5;font-size:12px;padding:6px 12px}.dd-btn-icon:hover{background:#4f46e5;color:#fff}.dd-form-wrapper{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;padding:24px}.dd-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(12,1fr)}.col-4{grid-column:span 4}.col-8{grid-column:span 8}@media (max-width:768px){.col-4,.col-8{grid-column:span 12}}.dd-label{color:#4b5563;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.dd-input{border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:10px;width:100%}.dd-input:focus{border-color:#3b82f6;border-color:var(--primary-color);outline:none}.dd-input-small{border:1px solid #d1d5db;border-radius:4px;font-family:inherit;font-size:13px;padding:6px;width:100%}.dd-table-container{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;overflow-x:auto}.dd-table{background:#fff;border-collapse:collapse;min-width:800px;width:100%}.dd-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:700;padding:12px 16px;text-align:left}.dd-table td{border-bottom:1px solid #f3f4f6;font-size:14px;padding:14px 16px;vertical-align:middle}.dd-table tr:hover{background:#f9fafb}.row-hover{cursor:pointer;transition:all .2s}.row-hover:hover{background-color:#eff6ff!important}.row-absent{background-color:#fff1f2!important}.att-stats-container{display:flex;flex-wrap:wrap;gap:10px}.att-radio-badge{align-items:center;border:1px solid #0000;border-radius:6px;box-shadow:0 1px 2px #0000000d;cursor:default;display:inline-flex;font-size:13px;font-weight:600;gap:8px;justify-content:center;padding:8px 16px;white-space:nowrap}.att-icon{display:block;height:18px;width:18px}.att-radio-badge.success{background:#ecfdf5;background:var(--success-bg);border-color:#10b981;border-color:var(--success-border);color:#047857;color:var(--success-text)}.att-radio-badge.warning{background:#fffbeb;background:var(--warning-bg);border-color:#f59e0b;border-color:var(--warning-border);color:#b45309;color:var(--warning-text)}.att-radio-badge.danger{background:#fef2f2;background:var(--danger-bg);border-color:#ef4444;border-color:var(--danger-border);color:#b91c1c;color:var(--danger-text)}.dd-radio-group{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.dd-radio-item{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:6px 12px;transition:all .2s}.selected-present{background:#ecfdf5!important;background:var(--success-bg)!important;border-color:#10b981!important;border-color:var(--success-border)!important;box-shadow:0 0 0 2px #10b98133;color:#047857;color:var(--success-text)}.selected-absent{background:#fef2f2!important;background:var(--danger-bg)!important;border-color:#ef4444!important;border-color:var(--danger-border)!important;box-shadow:0 0 0 2px #ef444433;color:#b91c1c;color:var(--danger-text)}.selected-late{background:#fffbeb!important;background:var(--warning-bg)!important;border-color:#f59e0b!important;border-color:var(--warning-border)!important;box-shadow:0 0 0 2px #f59e0b33;color:#b45309;color:var(--warning-text)}.dd-loading-container{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;flex-direction:column;gap:10px;padding:60px 0}.dd-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;border-top:3px solid var(--primary-color);height:32px;width:32px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dd-empty-state{background:#f8fafc;border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:12px;color:#6b7280;color:var(--text-secondary);padding:60px;text-align:center}.dd-badge{border-radius:20px;font-size:11px;font-weight:700;padding:4px 10px;text-transform:uppercase}.badge-done{background:#d1fae5;color:#065f46}.badge-scheduled{background:#f3f4f6;color:#6b7280}.session-content-highlight{background:#eff6ff;border-left:3px solid #3b82f6;border-left:3px solid var(--primary-color);border-radius:4px;color:#1e40af;display:inline-block;font-size:13px;font-weight:500;margin-top:4px;padding:4px 8px}.session-content-empty{color:#9ca3af;font-size:13px;font-style:italic;margin-top:4px}.text-center{text-align:center}.text-bold{font-weight:600}.text-muted{color:#9ca3af;font-size:13px}.dd-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#111827b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.dd-modal-content{animation:popIn .3s cubic-bezier(.16,1,.3,1);background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;max-width:500px;overflow:hidden;width:100%}.dd-modal-header{align-items:center;background-color:#fff;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:20px 24px}.dd-modal-header h3{color:#111827;font-size:20px;font-weight:700;margin:0}.dd-modal-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#9ca3af;cursor:pointer;display:flex;font-size:28px;height:36px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:36px}.dd-modal-close:hover{background-color:#fee2e2;color:#dc2626}.dd-modal-body{background-color:#fff;max-height:70vh;overflow-y:auto;padding:24px}.dd-modal-body .dd-label{color:#374151;display:block;font-weight:600;margin-bottom:10px}.dd-modal-body .dd-label span[style*="color:red"]{color:#dc2626!important;margin-left:4px}.dd-textarea{background-color:#f9fafb;border:1px solid #d1d5db;border-radius:10px;box-sizing:border-box;color:#1f2937;font-family:inherit;font-size:14px;min-height:120px;outline:none;padding:12px 16px;resize:vertical;transition:all .2s;width:100%}.dd-textarea:focus{background-color:#fff;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a}.dd-textarea::placeholder{color:#9ca3af}.dd-modal-footer{background-color:#f9fafb;border-top:1px solid #f3f4f6;display:flex;gap:16px;justify-content:flex-end;padding:20px 24px}.dd-modal-footer .dd-btn{border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;font-size:14px;padding:10px 20px}.dd-btn-outline{background-color:#fff;border:1px solid #d1d5db;color:#374151;font-weight:600}.dd-btn-outline:hover{background-color:#f3f4f6;border-color:#9ca3af}@keyframes popIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.dd-form-row{display:flex;gap:16px;width:100%}.dd-form-row .modal-form-group{flex:1 1;margin-bottom:0}input[type=datetime-local].dd-input-full{background-color:#f9fafb!important;cursor:pointer;height:44px!important}input[type=datetime-local].dd-input-full:focus{background-color:#fff!important}.student-classes-wrapper{padding:24px;transition:all .3s ease}.uni-table-container{background:#fff;border:1px solid #e8e8e8;border-radius:8px;box-shadow:0 2px 8px #0000000f;overflow-x:auto;width:100%}.uni-table{border-collapse:collapse;font-size:14px;min-width:900px;width:100%}.uni-table th{background-color:#e6f7ff;border-bottom:2px solid #1890ff;color:#262626;font-weight:600;padding:16px;text-align:left}.uni-table td{border-bottom:1px solid #f0f0f0;color:#595959;padding:16px;vertical-align:top}.clickable-row{cursor:pointer;transition:background-color .2s}.clickable-row:hover{background-color:#f5f5f5}.text-center{text-align:center!important}.tc-class-name{color:#1890ff;font-size:15px;font-weight:600;margin-bottom:4px}.tc-class-code{color:#8c8c8c;font-size:13px}.tc-schedule-line{align-items:center;color:#262626;display:flex;margin-bottom:6px}.tc-schedule-line i{color:#8c8c8c;margin-right:6px;text-align:center;width:14px}.tc-date-line{color:#8c8c8c;font-size:13px;margin-top:8px}.tc-room-cell{color:#262626;font-weight:500}.tc-room-cell i{color:#1890ff;margin-right:6px}.tc-staff{margin-bottom:6px}.staff-role{color:#8c8c8c;display:inline-block;font-weight:600;width:28px}.uni-status{border-radius:4px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.uni-status.active{background:#e6f4ea;color:#1e8e3e}.uni-status.pending{background:#fff7e6;color:#fa8c16}.uni-btn-detail{background:#0000;border:1px solid #1890ff;border-radius:4px;color:#1890ff;cursor:pointer;font-weight:500;padding:6px 12px;transition:all .2s}.uni-btn-detail:hover{background:#1890ff;color:#fff}.uni-empty{color:#8c8c8c;padding:60px 20px;text-align:center}.class-dashboard-container{background:#fff;border-radius:8px;box-shadow:0 2px 12px #0000000f;margin-left:274px;margin-right:24px;margin-top:24px;min-height:500px;padding:24px;transition:all .3s ease}.cd-header{border-bottom:1px solid #f0f0f0;margin-bottom:24px;padding-bottom:16px}.cd-back-btn{background:#0000;border:none;color:#595959;cursor:pointer;font-size:14px;margin-bottom:12px;padding:0;transition:color .2s}.cd-back-btn:hover{color:#1890ff}.cd-back-btn i{margin-right:6px}.cd-header h2{color:#262626;font-size:24px;margin:0}.cd-code{color:#8c8c8c;font-size:18px;font-weight:400}.cd-tabs{border-bottom:2px solid #f0f0f0;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.cd-tab{background:#0000;border:none;border-bottom:2px solid #0000;bottom:-2px;color:#595959;cursor:pointer;font-size:15px;font-weight:500;padding:12px 24px;position:relative;transition:all .2s}.cd-tab i{margin-right:8px}.cd-tab:hover{color:#1890ff}.cd-tab.active{border-bottom:2px solid #1890ff;color:#1890ff}.cd-content{animation:fadeIn .3s ease}.cd-placeholder{background:#fafafa;border:1px dashed #d9d9d9;border-radius:8px;color:#595959;padding:60px 20px;text-align:center}.cd-placeholder h3{color:#262626;margin:0 0 8px}.qllh-pagination{display:flex;gap:8px;justify-content:center}.qllh-pagination button{background:#fff;border:1px solid #d9d9d9;border-radius:4px;color:#595959;cursor:pointer;padding:6px 12px}.qllh-pagination button:hover:not(:disabled){border-color:#1890ff;color:#1890ff}.qllh-pagination button:disabled{cursor:not-allowed;opacity:.5}.qllh-pagination .active-page{background:#1890ff;border-color:#1890ff;color:#fff}.student-info-tab{padding-top:8px}.info-cards-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.info-card{align-items:flex-start;background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #00000005;display:flex;padding:20px}.info-card.highlight-card{background:#f0f7ff;border-color:#bae0ff}.ic-icon{align-items:center;background:#e6f7ff;border-radius:8px;color:#1890ff;display:flex;font-size:18px;height:40px;justify-content:center;margin-right:16px;width:40px}.highlight-card .ic-icon{background:#1890ff;color:#fff}.ic-content{flex:1 1}.ic-label{color:#8c8c8c;font-size:13px;margin-bottom:4px}.ic-value{color:#262626;font-size:16px;font-weight:600}.progress-container{background-color:#e0e0e0;border-radius:4px;height:6px;overflow:hidden;width:100%}.progress-bar{background-color:#1890ff;border-radius:4px;height:100%;transition:width .5s ease-in-out}.info-sections-row{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.info-section-box{background:#fafafa;border:1px solid #f0f0f0;border-radius:12px;padding:24px}.section-title{align-items:center;color:#262626;display:flex;font-size:16px;margin-bottom:20px;margin-top:0}.section-title i{color:#1890ff;margin-right:8px}.schedule-list,.staff-list{display:flex;flex-direction:column;gap:12px}.schedule-item-row,.staff-item-row{align-items:center;background:#fff;border:1px solid #e8e8e8;border-radius:8px;display:flex;justify-content:space-between;padding:12px 16px}.sch-day{color:#595959;font-weight:600}.sch-time{color:#1890ff;font-weight:500}.staff-role-badge{border-radius:4px;font-size:12px;font-weight:600;padding:4px 10px}.staff-role-badge.gv{background:#fff1f0;color:#ff4d4f}.staff-role-badge.ta{background:#f6ffed;color:#52c41a}.staff-name{color:#262626;font-weight:500}@media screen and (max-width:992px){.student-classes-wrapper{margin-left:0;padding:16px}.class-dashboard-container{margin-left:16px;margin-right:16px}}.uni-btn-pay{align-items:center;background:#1890ff;border:1px solid #1890ff;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:6px;padding:6px 16px;transition:all .2s}.uni-btn-pay:hover{background:#096dd9;border-color:#096dd9;box-shadow:0 2px 6px #1890ff4d}.qr-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.qr-modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;max-width:90%;overflow:hidden;width:400px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.qr-modal-header{align-items:center;background:#fafafa;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:16px 24px}.qr-modal-header h3{color:#262626;font-size:16px;margin:0}.qr-close-btn{background:#0000;border:none;color:#8c8c8c;cursor:pointer;font-size:24px;line-height:1;padding:0}.qr-close-btn:hover{color:#ff4d4f}.qr-modal-body{padding:24px}.qr-error-box,.qr-loading-box{color:#8c8c8c;padding:40px 0;text-align:center}.qr-loading-box i{color:#1890ff;margin-bottom:16px}.qr-error-box i{color:#ff4d4f;margin-bottom:16px}.qr-success-box{text-align:center}.qr-image-wrapper{background:#fafafa;border:1px solid #e8e8e8;border-radius:8px;display:inline-block;margin-bottom:20px;padding:16px}.qr-image-wrapper img{display:block;max-width:250px}.qr-details{background:#f6ffed;border:1px solid #b7eb8f;border-radius:8px;margin-bottom:16px;padding:16px;text-align:left}.qr-row{color:#595959;display:flex;font-size:14px;justify-content:space-between;margin-bottom:8px}.qr-row:last-child{margin-bottom:0}.qr-amount{color:#ff4d4f;font-size:16px}.qr-warning{align-items:flex-start;background:#fff7e6;border-radius:6px;color:#fa8c16;display:flex;font-size:13px;gap:8px;padding:12px;text-align:left}.qr-warning i{margin-top:2px}*{border:none;box-sizing:border-box;margin:0;padding:0}html{font-size:62.5%}body{background-color:#f5f6fa;color:#333;font-family:Segoe UI,sans-serif;line-height:1.5}.grid{margin:0 auto;max-width:1400px;width:100%}a{color:inherit;text-decoration:none}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}:root{--xb-grad-start:#ffd966;--xb-grad-end:#e6b400;--xb-text:#c99700;--xb-text-hover:#e0b300;--xb-bg-pale:#fff9ed;--xb-main:#ffc107;--xb-rgb:255,193,7;--sidebar-width:250px;--sidebar-collapsed-width:80px}.header{background-color:#fff;box-shadow:0 2px 6px #0000001f;height:64px;justify-content:center;left:0;position:fixed;top:0;z-index:1000}.header,.header_navbar{align-items:center;display:flex;width:100%}.header_navbar{gap:16px;justify-content:space-between;max-width:1280px;padding:0 24px}.header_navbar-logo,.header_navbar-logo a{align-items:center;display:flex}.header_navbar-logo a{text-decoration:none}.header_navbar-logo img{height:64px;object-fit:contain;width:160px}.header_navbar-search{align-items:center;display:flex;flex:1 1;gap:16px;justify-content:center}.search-wrapper{align-items:center;display:flex;max-width:600px;position:relative;width:70%}.search-wrapper form{display:flex;width:100%}.header_navbar-search-input{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(-45deg,#ffd966,#e6b400) border-box;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(-45deg,var(--xb-grad-start),var(--xb-grad-end)) border-box;border:2px solid #0000;border-radius:24px;flex:1 1;font-size:1.4rem;height:44px;outline:none;padding:0 44px 0 16px;transition:all .3s ease}.header_navbar-search-input::placeholder{color:#888}.header_navbar-search-input:hover{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(-45deg,color-mix(in srgb,#ffd966,#fff 30%),#ffc107) border-box;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(-45deg,color-mix(in srgb,var(--xb-grad-start),#fff 30%),var(--xb-main)) border-box;transform:translateY(-1px)}.header_navbar-search-input:focus,.header_navbar-search-input:hover{box-shadow:0 0 6px #ffc10766;box-shadow:0 0 6px rgba(var(--xb-rgb),.4)}.header_navbar-search-input:focus{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(-45deg,#ffd966,#c99700) border-box;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(-45deg,var(--xb-grad-start),var(--xb-text)) border-box}.search-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:all .25s ease;width:36px}.search-btn i{color:#c99700;color:var(--xb-text);font-size:18px;transition:color .25s ease}.search-btn:hover i{color:#e0b300;color:var(--xb-text-hover)}.search-btn:active{transform:translateY(-50%) scale(.9)}.bell-icon{align-items:center;color:#c99700;color:var(--xb-text);cursor:pointer;display:flex;font-size:22px;justify-content:center;transition:all .25s ease}.bell-icon:hover{color:#e0b300;color:var(--xb-text-hover);transform:scale(1.1)}.bell-wrapper{cursor:pointer;position:relative}.bell-badge,.bell-wrapper{align-items:center;display:flex;justify-content:center}.bell-badge{background:linear-gradient(135deg,#ffd966,#ffc107);background:linear-gradient(135deg,var(--xb-grad-start),var(--xb-main));border-radius:50%;box-shadow:0 2px 6px #00000026;color:#fff;font-size:10px;font-weight:600;height:16px;min-width:16px;padding:2px 5px;position:absolute;right:-5px;top:-5px;transition:all .25s ease}.bell-wrapper:hover .bell-badge{transform:scale(1.1)}.header_navbar-user-wrapper{align-items:center;display:flex;gap:16px}.header_navbar-user{align-items:center;cursor:pointer;display:flex;gap:10px;transition:all .25s ease}.header_navbar-user:hover{transform:translateY(-1px)}.header_navbar-ava{align-items:center;border:2px solid #0000;border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;overflow:hidden;transition:all .25s ease;width:40px}.header_navbar-ava img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.header_navbar-ava:hover img{transform:scale(1.05)}.header_navbar-user:hover .header_navbar-ava{border-color:#ffd966;border-color:var(--xb-grad-start)}.header_navbar-name{color:#333;font-size:1.4rem;font-weight:500;transition:color .25s ease;white-space:nowrap}.header_navbar-user:hover .header_navbar-name{color:#c99700;color:var(--xb-text)}@media (max-width:768px){.search-wrapper{width:90%}.header_navbar-logo img{height:auto;width:120px}.bell-icon{font-size:20px}.header_navbar-name{display:none}}.sidebar{background-color:#fff;border-right:1px solid #eee;box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;height:calc(100vh - 64px);left:0;overflow:visible!important;padding-bottom:20px;position:fixed;top:64px;transition:width .3s cubic-bezier(.25,.8,.25,1);width:260px;z-index:999}.sidebar-menu{flex:1 1;list-style:none;margin:0;overflow-x:hidden;overflow-y:auto;padding:10px 0;width:100%}.sidebar-menu::-webkit-scrollbar{width:4px}.sidebar-menu::-webkit-scrollbar-thumb{background-color:#ddd;border-radius:4px}.sidebar-menu::-webkit-scrollbar-track{background:#0000}.sidebar-toggle-btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:50%;box-shadow:2px 1px 4px #0000001a;color:#555;cursor:pointer;display:flex;height:24px;justify-content:center;position:absolute;right:-12px;top:24px;transition:transform .2s ease,background .2s;width:24px;z-index:1000}.sidebar-toggle-btn:hover{background:#fff9ed;background:var(--xb-bg-pale,#fff9ed);color:#c99700;color:var(--xb-text,#e6b400);transform:scale(1.1)}.sidebar-toggle-btn i{font-size:10px}.menu-item{align-items:center;border-radius:12px;color:#555;cursor:pointer;display:flex;font-size:15px;gap:12px;margin:4px 12px;overflow:hidden;padding:12px 16px;position:relative;transition:all .2s ease;white-space:nowrap}.menu-item i{color:#c99700;color:var(--xb-text,#cca400);flex-shrink:0;font-size:18px;text-align:center;width:24px}.menu-item.active{background:linear-gradient(90deg,#ffc107,#e6b400);background:linear-gradient(90deg,var(--xb-main,gold),var(--xb-grad-end,#ffb800));box-shadow:0 4px 10px #00000026;color:#fff;font-weight:600}.menu-item.active i{color:#fff}.menu-item:hover:not(.active){background:#fff9ed;background:var(--xb-bg-pale,#fffdf5);color:#c99700;color:var(--xb-text,#b38f00);transform:translateX(2px)}.branch-select-box{background:linear-gradient(135deg,#fffcf5,#fff9ed);background:linear-gradient(135deg,#fffcf5,var(--xb-bg-pale,#fff9ed));border:1px solid #c9970026;border-radius:12px;display:flex;flex-direction:column;flex-shrink:0;gap:12px;margin:10px 12px;padding:14px 16px}.branch-select-item{display:flex;flex-direction:column;gap:4px}.branch-select-label{color:#777;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.branch-select-input{background-color:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#333;cursor:pointer;font-size:14px;outline:none;padding:8px 10px;transition:border-color .2s;width:100%}.branch-select-input:focus{border-color:#ffc107;border-color:var(--xb-main,#ffc107)}.branch-select-input:disabled{background-color:#f8f9fa;color:#999;cursor:not-allowed}.branch-select-text-value{font-size:14px;font-weight:700;padding:4px 0;word-break:break-word}.branch-select-text-value.center-name{color:#333}.branch-select-text-value.branch-name{color:#c99700;color:var(--xb-text,#c99700)}.sidebar.collapsed{width:80px}.sidebar.collapsed .branch-select-box{display:none!important}.sidebar.collapsed .menu-item label,.sidebar.collapsed .menu-item span{display:none}.sidebar.collapsed .menu-item{height:48px;justify-content:center;margin:6px auto;padding:0;width:48px}.sidebar.collapsed .menu-item i{font-size:20px;margin:0}.menu-group-title{color:#aaa;display:block;font-size:11px;font-weight:700;letter-spacing:1px;margin:0;padding:16px 16px 8px;text-transform:uppercase}.sidebar.collapsed .menu-group-title{display:none}.menu-divider{background-color:#eee;border:none;height:1px;margin:10px 16px}.collapsed-branding{display:none}.sidebar.collapsed .collapsed-branding{align-items:center;color:#c99700;color:var(--xb-text);display:flex;font-size:24px;height:60px;justify-content:center;margin-bottom:10px}.app-container{display:flex;margin-top:64px;overflow:hidden;width:100%}.app-content{display:block;flex:1 1;height:calc(100vh - 64px);margin-left:260px;overflow-y:auto;padding:24px;transition:margin-left .3s cubic-bezier(.25,.8,.25,1);width:calc(100% - 260px)}body.sidebar-is-collapsed .app-content{margin-left:80px;width:calc(100% - 80px)}@media (max-width:992px){.app-content,body.sidebar-is-collapsed .app-content{margin-left:0;width:100%}}